polycopy 0.2.2 → 0.2.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +18 -17
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1156,9 +1156,9 @@ class Redeemer {
|
|
|
1156
1156
|
}
|
|
1157
1157
|
return 0;
|
|
1158
1158
|
}
|
|
1159
|
-
toMessages(records) {
|
|
1159
|
+
toMessages(records, withExecInfo) {
|
|
1160
1160
|
return records.map(
|
|
1161
|
-
({ position, matchedCount, failedCount }) => ` - ${position.slug} ${position.outcome}: ${position.currentValue} USDC (成功匹配: ${matchedCount} 失败重试: ${failedCount})`
|
|
1161
|
+
({ position, matchedCount, failedCount }) => ` - ${position.slug} ${position.outcome}: ${position.currentValue} USDC${withExecInfo ? ` (成功匹配: ${matchedCount} 失败重试: ${failedCount})` : ""}`
|
|
1162
1162
|
);
|
|
1163
1163
|
}
|
|
1164
1164
|
/**
|
|
@@ -1203,7 +1203,7 @@ class Redeemer {
|
|
|
1203
1203
|
pendingRedeems.splice(insertIndex, 0, record);
|
|
1204
1204
|
}
|
|
1205
1205
|
}
|
|
1206
|
-
const execRedeems = pendingRedeems.
|
|
1206
|
+
const execRedeems = pendingRedeems.splice(0, MAX_BATCH_SIZE);
|
|
1207
1207
|
if (execRedeems.length > 0) {
|
|
1208
1208
|
try {
|
|
1209
1209
|
const txHash = await this.options.redeemFn(
|
|
@@ -1235,50 +1235,51 @@ class Redeemer {
|
|
|
1235
1235
|
}
|
|
1236
1236
|
const messages = [];
|
|
1237
1237
|
if (successRedeem.length > 0) {
|
|
1238
|
-
messages.push(
|
|
1238
|
+
messages.push(
|
|
1239
|
+
"🟢 redeem 成功:",
|
|
1240
|
+
...this.toMessages(successRedeem, false)
|
|
1241
|
+
);
|
|
1239
1242
|
}
|
|
1240
1243
|
if (failedRedeems.length > 0) {
|
|
1241
|
-
messages.push(
|
|
1244
|
+
messages.push(
|
|
1245
|
+
"🔴 redeem 失败:",
|
|
1246
|
+
...this.toMessages(failedRedeems, false)
|
|
1247
|
+
);
|
|
1242
1248
|
}
|
|
1243
1249
|
if (messages.length > 0) {
|
|
1244
1250
|
telegramService.info(messages.join("\n"));
|
|
1245
1251
|
}
|
|
1246
|
-
const logLines = [];
|
|
1252
|
+
const logLines = ["自动 redeem 状态:"];
|
|
1247
1253
|
if (execRedeems.length > 0) {
|
|
1248
1254
|
logLines.push(
|
|
1249
1255
|
`redeem 本轮执行(待确认): ${execRedeems.length} 个`,
|
|
1250
1256
|
...this.toMessages(execRedeems),
|
|
1251
|
-
""
|
|
1257
|
+
"\n"
|
|
1252
1258
|
);
|
|
1253
1259
|
}
|
|
1254
1260
|
if (pendingRedeems.length > 0) {
|
|
1255
1261
|
logLines.push(
|
|
1256
1262
|
`redeem 本轮未执行(等待下轮): ${pendingRedeems.length} 个`,
|
|
1257
1263
|
...this.toMessages(pendingRedeems),
|
|
1258
|
-
""
|
|
1264
|
+
"\n"
|
|
1259
1265
|
);
|
|
1260
1266
|
}
|
|
1261
|
-
logLines.push(`redeem 待确认总数: ${this.records.size} 个`, "");
|
|
1262
1267
|
if (successRedeem.length > 0) {
|
|
1263
1268
|
logLines.push(
|
|
1264
1269
|
`🟢 redeem 成功确认: ${successRedeem.length} 个`,
|
|
1265
1270
|
...this.toMessages(successRedeem),
|
|
1266
|
-
""
|
|
1271
|
+
"\n"
|
|
1267
1272
|
);
|
|
1268
1273
|
}
|
|
1269
1274
|
if (failedRedeems.length > 0) {
|
|
1270
1275
|
logLines.push(
|
|
1271
1276
|
`🔴 redeem 失败已放弃(重试超限): ${failedRedeems.length} 个`,
|
|
1272
1277
|
...this.toMessages(failedRedeems),
|
|
1273
|
-
""
|
|
1278
|
+
"\n"
|
|
1274
1279
|
);
|
|
1275
1280
|
}
|
|
1276
|
-
|
|
1277
|
-
|
|
1278
|
-
logLines.pop();
|
|
1279
|
-
}
|
|
1280
|
-
logger.info(logLines.join("\n"));
|
|
1281
|
-
}
|
|
1281
|
+
logLines.push(`redeem 待确认总数: ${this.records.size} 个`);
|
|
1282
|
+
for (const log of logLines) logger.info(log);
|
|
1282
1283
|
if (successRedeem.length > 0) {
|
|
1283
1284
|
this.options.onRedeemSuccess?.();
|
|
1284
1285
|
}
|