koishi-plugin-node-async-bot-all 1.9.5 → 1.11.0
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/lib/fun.d.ts +1 -2
- package/lib/index.js +65 -55
- package/package.json +1 -1
package/lib/fun.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import { Context } from "koishi";
|
|
2
1
|
export declare function getSystemUsage(): Promise<object>;
|
|
3
2
|
export declare function getHongKongTime(): string;
|
|
4
|
-
export declare function fetchWithTimeout(url: string, options: {}, timeout: number,
|
|
3
|
+
export declare function fetchWithTimeout(url: string, options: {}, timeout: number, log: any): Promise<Response>;
|
|
5
4
|
export declare function readInfoFile(): Promise<string>;
|
|
6
5
|
export declare function getAudioPath(name: string): Promise<string>;
|
|
7
6
|
export declare function getAudioList(): Promise<string[]>;
|
package/lib/index.js
CHANGED
|
@@ -33,7 +33,7 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
33
33
|
// src/locales/zh-CN.yml
|
|
34
34
|
var require_zh_CN = __commonJS({
|
|
35
35
|
"src/locales/zh-CN.yml"(exports2, module2) {
|
|
36
|
-
module2.exports = { commands: { cx: { description: "查询服务器当前人数。", messages: { msg: "{time}\n【服务器当前人数】\n➣ {version}:{players}\n➣ 玩家列表:{list}\n➣ 协议版本:{protocol}\n进服指南请在群公告中查看。", msgNoPlayer: "{time}\n【服务器当前人数】\n➣ {version}:{players}\n➣ 协议版本:{protocol}\n进服指南请在群公告中查看。", forbidden: "{time}\n此指令不允许在本群使用。", failed: "{time}\n查询失败:{data}\n请稍后重试。", timeout: "请求超时。", close: "服务器已关闭。", error: "执行错误。", unknown: "未知错误。", host: "没有到主机的路由。" } }, status: { description: "查询机器人状态。", messages: { msg: "{time}\n系统名称:{name}\nCPU使用率:{cpu}\n内存使用率:{memory}", failed: "{time}\n状态获取失败。" } }, random: { description: "随机数生成器。", usage: "缺少参数时默认生成 0-10000 的随机数。\n使用示例:", examples: "random 1 128 生成1到128范围的随机数", messages: { msg: "{time}\n生成的随机数:{data}" } }, info: { description: "查询机器人信息。", messages: { msg: "{data}", failed: "{time}\n读取信息失败。" } }, rw: { description: "随机名言名句。", messages: { msg: "{time}\n{data}", failed1: "{time}\n获取失败(1)。", failed2: "{time}\n获取失败(2)。" } }, cassie: { description: "发送 C.A.S.S.I.E. 语音。", usage: "缺少参数时返回语音列表。\n使用示例:", examples: "cassie mtfSpawn 播放当机动特遣队重生并且SCP还活着时的语音。", messages: { msg: "{time}\n【播放列表】\n{data}", failed: "{time}\n发送失败,请稍后重试。", unknown: "{time}\n未知语音,发送 /cassie 查看播放列表。" } } } };
|
|
36
|
+
module2.exports = { commands: { cx: { description: "查询服务器当前人数。", messages: { msg: "{time}\n【服务器当前人数】\n➣ {version}:{players}\n➣ 玩家列表:{list}\n➣ 协议版本:{protocol}\n进服指南请在群公告中查看。", msgNoPlayer: "{time}\n【服务器当前人数】\n➣ {version}:{players}\n➣ 协议版本:{protocol}\n进服指南请在群公告中查看。", forbidden: "{time}\n此指令不允许在本群使用。", failed: "{time}\n查询失败:{data}\n请稍后重试。", timeout: "请求超时。", timeout2: "响应超时。", fewData: "服务端返回的数据过少。", close: "服务器已关闭。", error: "执行错误。", unknown: "未知错误。", host: "没有到主机的路由。" } }, status: { description: "查询机器人状态。", messages: { msg: "{time}\n系统名称:{name}\nCPU使用率:{cpu}\n内存使用率:{memory}", failed: "{time}\n状态获取失败。" } }, random: { description: "随机数生成器。", usage: "缺少参数时默认生成 0-10000 的随机数。\n使用示例:", examples: "random 1 128 生成1到128范围的随机数", messages: { msg: "{time}\n生成的随机数:{data}" } }, info: { description: "查询机器人信息。", messages: { msg: "{data}", failed: "{time}\n读取信息失败。" } }, rw: { description: "随机名言名句。", messages: { msg: "{time}\n{data}", failed1: "{time}\n获取失败(1)。", failed2: "{time}\n获取失败(2)。" } }, cassie: { description: "发送 C.A.S.S.I.E. 语音。", usage: "缺少参数时返回语音列表。\n使用示例:", examples: "cassie mtfSpawn 播放当机动特遣队重生并且SCP还活着时的语音。", messages: { msg: "{time}\n【播放列表】\n{data}", failed: "{time}\n发送失败,请稍后重试。", unknown: "{time}\n未知语音,发送 /cassie 查看播放列表。" } } } };
|
|
37
37
|
}
|
|
38
38
|
});
|
|
39
39
|
|
|
@@ -51,7 +51,7 @@ var import_koishi = require("koishi");
|
|
|
51
51
|
var import_os = __toESM(require("os"));
|
|
52
52
|
|
|
53
53
|
// package.json
|
|
54
|
-
var version = "1.
|
|
54
|
+
var version = "1.11.0";
|
|
55
55
|
|
|
56
56
|
// src/fun.ts
|
|
57
57
|
var import_fs = __toESM(require("fs"));
|
|
@@ -112,7 +112,7 @@ function getHongKongTime() {
|
|
|
112
112
|
].join(":");
|
|
113
113
|
}
|
|
114
114
|
__name(getHongKongTime, "getHongKongTime");
|
|
115
|
-
async function fetchWithTimeout(url, options = {}, timeout = 5e3,
|
|
115
|
+
async function fetchWithTimeout(url, options = {}, timeout = 5e3, log) {
|
|
116
116
|
const controller = new AbortController();
|
|
117
117
|
const timeoutId = setTimeout(() => {
|
|
118
118
|
controller.abort();
|
|
@@ -124,11 +124,11 @@ async function fetchWithTimeout(url, options = {}, timeout = 5e3, ctx) {
|
|
|
124
124
|
// 绑定终止信号
|
|
125
125
|
});
|
|
126
126
|
clearTimeout(timeoutId);
|
|
127
|
-
|
|
127
|
+
log.info(`Fetch code: ${response.status}`);
|
|
128
128
|
return response;
|
|
129
129
|
} catch (error) {
|
|
130
130
|
clearTimeout(timeoutId);
|
|
131
|
-
|
|
131
|
+
log.error(`${error.name}: ${error.message}`);
|
|
132
132
|
if (error.name === "AbortError") {
|
|
133
133
|
throw new Error("请求超时");
|
|
134
134
|
} else {
|
|
@@ -165,7 +165,8 @@ var import_fs2 = __toESM(require("fs"));
|
|
|
165
165
|
var inject = ["silk"];
|
|
166
166
|
var name = "node-async-bot-all";
|
|
167
167
|
async function getServer(ctx, session) {
|
|
168
|
-
ctx.logger
|
|
168
|
+
const log = ctx.logger("cx");
|
|
169
|
+
log.info(`Got: {"form":"${session.event.guild.id}","user":"${session.event.user.id}","timestamp":${session.event.timestamp},"messageId":"${session.event.message.id}"}`);
|
|
169
170
|
let msg;
|
|
170
171
|
let dataError;
|
|
171
172
|
let data;
|
|
@@ -173,10 +174,10 @@ async function getServer(ctx, session) {
|
|
|
173
174
|
const time = getHongKongTime();
|
|
174
175
|
if (session.event.guild.id == "757729218" || session.event.guild.id == "1047732162") {
|
|
175
176
|
try {
|
|
176
|
-
const response = await fetchWithTimeout("https://api.tasaed.top/get/minecraftServer/", {}, 8e3,
|
|
177
|
+
const response = await fetchWithTimeout("https://api.tasaed.top/get/minecraftServer/", {}, 8e3, log);
|
|
177
178
|
if (response.ok) {
|
|
178
179
|
data = await response.text();
|
|
179
|
-
|
|
180
|
+
log.info("Server data: " + data);
|
|
180
181
|
data = JSON.parse(data);
|
|
181
182
|
if (data["list"] == null) {
|
|
182
183
|
msg = {
|
|
@@ -186,8 +187,8 @@ async function getServer(ctx, session) {
|
|
|
186
187
|
"protocol": data["protocol"],
|
|
187
188
|
"success": 3
|
|
188
189
|
};
|
|
189
|
-
|
|
190
|
-
|
|
190
|
+
log.info("Sent:");
|
|
191
|
+
log.info(msg);
|
|
191
192
|
} else {
|
|
192
193
|
msg = {
|
|
193
194
|
"time": time,
|
|
@@ -197,8 +198,8 @@ async function getServer(ctx, session) {
|
|
|
197
198
|
"protocol": data["protocol"],
|
|
198
199
|
"success": 0
|
|
199
200
|
};
|
|
200
|
-
|
|
201
|
-
|
|
201
|
+
log.info("Sent:");
|
|
202
|
+
log.info(msg);
|
|
202
203
|
}
|
|
203
204
|
} else {
|
|
204
205
|
dataError = await response.text();
|
|
@@ -211,6 +212,10 @@ async function getServer(ctx, session) {
|
|
|
211
212
|
error = session.text(".host");
|
|
212
213
|
} else if (error.includes("Connection timed out")) {
|
|
213
214
|
error = session.text(".timeout");
|
|
215
|
+
} else if (error.includes("Server returned too few data")) {
|
|
216
|
+
error = session.text(".fewData");
|
|
217
|
+
} else if (error.includes("Server read timed out")) {
|
|
218
|
+
error = session.text(".timeout2");
|
|
214
219
|
}
|
|
215
220
|
} catch (e) {
|
|
216
221
|
if (dataError.includes("CDN节点请求源服务器超时")) {
|
|
@@ -219,43 +224,44 @@ async function getServer(ctx, session) {
|
|
|
219
224
|
error = session.text(".unknown");
|
|
220
225
|
}
|
|
221
226
|
}
|
|
222
|
-
|
|
227
|
+
log.error(`Error fetching data: ${dataError}`);
|
|
223
228
|
msg = {
|
|
224
229
|
"time": time,
|
|
225
230
|
"data": error,
|
|
226
231
|
"success": 1
|
|
227
232
|
};
|
|
228
|
-
|
|
229
|
-
|
|
233
|
+
log.info("Sent:");
|
|
234
|
+
log.info(msg);
|
|
230
235
|
}
|
|
231
236
|
} catch (err) {
|
|
232
|
-
|
|
237
|
+
log.error(`Request error: ${err.message}`);
|
|
233
238
|
msg = {
|
|
234
239
|
"time": time,
|
|
235
240
|
"data": session.text(".error"),
|
|
236
241
|
"success": 1
|
|
237
242
|
};
|
|
238
|
-
|
|
239
|
-
|
|
243
|
+
log.info("Sent:");
|
|
244
|
+
log.info(msg);
|
|
240
245
|
}
|
|
241
246
|
} else {
|
|
242
247
|
msg = {
|
|
243
248
|
"time": time,
|
|
244
249
|
"success": 2
|
|
245
250
|
};
|
|
246
|
-
|
|
247
|
-
|
|
251
|
+
log.info("Sent:");
|
|
252
|
+
log.info(msg);
|
|
248
253
|
}
|
|
249
254
|
return msg;
|
|
250
255
|
}
|
|
251
256
|
__name(getServer, "getServer");
|
|
252
257
|
async function getStatus(ctx, session) {
|
|
253
|
-
ctx.logger
|
|
258
|
+
const log = ctx.logger("status");
|
|
259
|
+
log.info(`Got: {"form":"${session.event.guild.id}","user":"${session.event.user.id}","timestamp":${session.event.timestamp},"messageId":"${session.event.message.id}"}`);
|
|
254
260
|
const time = getHongKongTime();
|
|
255
261
|
let msg;
|
|
256
262
|
const vMsg = await getSystemUsage();
|
|
257
263
|
if (vMsg["success"] == 1) {
|
|
258
|
-
|
|
264
|
+
log.error(vMsg);
|
|
259
265
|
msg = {
|
|
260
266
|
"time": time,
|
|
261
267
|
"data": vMsg["data"],
|
|
@@ -270,13 +276,14 @@ async function getStatus(ctx, session) {
|
|
|
270
276
|
"success": 0
|
|
271
277
|
};
|
|
272
278
|
}
|
|
273
|
-
|
|
274
|
-
|
|
279
|
+
log.info("Sent:");
|
|
280
|
+
log.info(msg);
|
|
275
281
|
return msg;
|
|
276
282
|
}
|
|
277
283
|
__name(getStatus, "getStatus");
|
|
278
284
|
async function getRandom(ctx, session, min, max) {
|
|
279
|
-
ctx.logger
|
|
285
|
+
const log = ctx.logger("random");
|
|
286
|
+
log.info(`Got: {"form":"${session.event.guild.id}","user":"${session.event.user.id}","timestamp":${session.event.timestamp},"messageId":"${session.event.message.id}"}`);
|
|
280
287
|
const time = getHongKongTime();
|
|
281
288
|
let msg;
|
|
282
289
|
let data;
|
|
@@ -292,18 +299,19 @@ async function getRandom(ctx, session, min, max) {
|
|
|
292
299
|
"data": data,
|
|
293
300
|
"success": 0
|
|
294
301
|
};
|
|
295
|
-
|
|
296
|
-
|
|
302
|
+
log.info("Sent:");
|
|
303
|
+
log.info(msg);
|
|
297
304
|
return msg;
|
|
298
305
|
}
|
|
299
306
|
__name(getRandom, "getRandom");
|
|
300
307
|
async function getInfo(ctx, session) {
|
|
301
|
-
ctx.logger
|
|
308
|
+
const log = ctx.logger("info");
|
|
309
|
+
log.info(`Got: {"form":"${session.event.guild.id}","user":"${session.event.user.id}","timestamp":${session.event.timestamp},"messageId":"${session.event.message.id}"}`);
|
|
302
310
|
const time = getHongKongTime();
|
|
303
311
|
let msg;
|
|
304
312
|
let data = await readInfoFile();
|
|
305
313
|
if (!data.includes("&time;")) {
|
|
306
|
-
|
|
314
|
+
log.error("Error: " + data);
|
|
307
315
|
msg = {
|
|
308
316
|
"time": time,
|
|
309
317
|
"data": data,
|
|
@@ -317,52 +325,54 @@ async function getInfo(ctx, session) {
|
|
|
317
325
|
"success": 0
|
|
318
326
|
};
|
|
319
327
|
}
|
|
320
|
-
|
|
321
|
-
|
|
328
|
+
log.info("Sent:");
|
|
329
|
+
log.info(msg);
|
|
322
330
|
return msg;
|
|
323
331
|
}
|
|
324
332
|
__name(getInfo, "getInfo");
|
|
325
333
|
async function getRW(ctx, session) {
|
|
326
|
-
ctx.logger
|
|
334
|
+
const log = ctx.logger("rw");
|
|
335
|
+
log.info(`Got: {"form":"${session.event.guild.id}","user":"${session.event.user.id}","timestamp":${session.event.timestamp},"messageId":"${session.event.message.id}"}`);
|
|
327
336
|
let msg;
|
|
328
337
|
let data;
|
|
329
338
|
const time = getHongKongTime();
|
|
330
339
|
try {
|
|
331
|
-
const response = await fetchWithTimeout("https://api.tasaed.top/rw/", {}, 8e3,
|
|
340
|
+
const response = await fetchWithTimeout("https://api.tasaed.top/rw/", {}, 8e3, log);
|
|
332
341
|
if (response.ok) {
|
|
333
342
|
data = await response.text();
|
|
334
|
-
|
|
343
|
+
log.info("Server data: " + data);
|
|
335
344
|
msg = {
|
|
336
345
|
"time": time,
|
|
337
346
|
"data": data,
|
|
338
347
|
"success": 0
|
|
339
348
|
};
|
|
340
|
-
|
|
341
|
-
|
|
349
|
+
log.info("Sent:");
|
|
350
|
+
log.info(msg);
|
|
342
351
|
} else {
|
|
343
352
|
data = await response.text();
|
|
344
|
-
|
|
353
|
+
log.error(`Error fetching data: ${data}`);
|
|
345
354
|
msg = {
|
|
346
355
|
"time": time,
|
|
347
356
|
"success": 1
|
|
348
357
|
};
|
|
349
|
-
|
|
350
|
-
|
|
358
|
+
log.info("Sent:");
|
|
359
|
+
log.info(msg);
|
|
351
360
|
}
|
|
352
361
|
} catch (err) {
|
|
353
|
-
|
|
362
|
+
log.error(`Request error: ${err.message}`);
|
|
354
363
|
msg = {
|
|
355
364
|
"time": time,
|
|
356
365
|
"success": 2
|
|
357
366
|
};
|
|
358
|
-
|
|
359
|
-
|
|
367
|
+
log.info("Sent:");
|
|
368
|
+
log.info(msg);
|
|
360
369
|
}
|
|
361
370
|
return msg;
|
|
362
371
|
}
|
|
363
372
|
__name(getRW, "getRW");
|
|
364
373
|
async function getCASSIE(ctx, session, name2) {
|
|
365
|
-
ctx.logger
|
|
374
|
+
const log = ctx.logger("cassie");
|
|
375
|
+
log.info(`Got: {"form":"${session.event.guild.id}","user":"${session.event.user.id}","timestamp":${session.event.timestamp},"messageId":"${session.event.message.id}"}`);
|
|
366
376
|
let msg;
|
|
367
377
|
const time = getHongKongTime();
|
|
368
378
|
const list = await getAudioList();
|
|
@@ -372,26 +382,26 @@ async function getCASSIE(ctx, session, name2) {
|
|
|
372
382
|
"data": list.map((fruit, index) => `${index + 1}. ${fruit}`).join("\n"),
|
|
373
383
|
"success": 1
|
|
374
384
|
};
|
|
375
|
-
|
|
376
|
-
|
|
385
|
+
log.info("Sent: .msg");
|
|
386
|
+
log.info(msg);
|
|
377
387
|
return msg;
|
|
378
388
|
} else if (list.includes(name2)) {
|
|
379
389
|
const fullPath = await getAudioPath(name2);
|
|
380
390
|
try {
|
|
381
391
|
const fileBuffer = await import_fs2.default.promises.readFile(fullPath);
|
|
382
|
-
|
|
392
|
+
log.info(fullPath);
|
|
383
393
|
const bufferToSend = Buffer.from(fileBuffer);
|
|
384
394
|
if (!ctx.silk.isSilk(fileBuffer)) {
|
|
385
395
|
msg = {
|
|
386
396
|
"time": time,
|
|
387
397
|
"success": 2
|
|
388
398
|
};
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
399
|
+
log.error("发送失败:非 .slk 文件");
|
|
400
|
+
log.info("Sent: .failed");
|
|
401
|
+
log.info(msg);
|
|
392
402
|
} else {
|
|
393
403
|
const base64Data = bufferToSend.toString("base64");
|
|
394
|
-
|
|
404
|
+
log.info("Sent: A audio file.");
|
|
395
405
|
msg = {
|
|
396
406
|
"time": time,
|
|
397
407
|
"data": base64Data,
|
|
@@ -404,9 +414,9 @@ async function getCASSIE(ctx, session, name2) {
|
|
|
404
414
|
"time": time,
|
|
405
415
|
"success": 2
|
|
406
416
|
};
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
417
|
+
log.error("发送失败:" + e.message);
|
|
418
|
+
log.info("Sent: .failed");
|
|
419
|
+
log.info(msg);
|
|
410
420
|
return msg;
|
|
411
421
|
}
|
|
412
422
|
} else {
|
|
@@ -414,8 +424,8 @@ async function getCASSIE(ctx, session, name2) {
|
|
|
414
424
|
"time": time,
|
|
415
425
|
"success": 3
|
|
416
426
|
};
|
|
417
|
-
|
|
418
|
-
|
|
427
|
+
log.info("Sent: .unknown");
|
|
428
|
+
log.info(msg);
|
|
419
429
|
return msg;
|
|
420
430
|
}
|
|
421
431
|
}
|