@azimiao/koishi-plugin-cafe-bot-exp 0.0.12 → 0.0.13
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/draw/config.d.ts +1 -0
- package/lib/index.js +41 -24
- package/package.json +1 -1
package/lib/draw/config.d.ts
CHANGED
package/lib/index.js
CHANGED
|
@@ -37,6 +37,9 @@ __export(src_exports, {
|
|
|
37
37
|
});
|
|
38
38
|
module.exports = __toCommonJS(src_exports);
|
|
39
39
|
|
|
40
|
+
// package.json
|
|
41
|
+
var version = "0.0.13";
|
|
42
|
+
|
|
40
43
|
// src/draw/index.ts
|
|
41
44
|
var draw_exports = {};
|
|
42
45
|
__export(draw_exports, {
|
|
@@ -260,6 +263,7 @@ var CafeBotDrawConfig = import_koishi.Schema.object({
|
|
|
260
263
|
forceUpdateDataWhenLoad: import_koishi.Schema.boolean().description("插件加载时强制刷新数据").default(false),
|
|
261
264
|
ImageServer: import_koishi.Schema.string().description("图像生成服务器").default("http://127.0.0.1:3000/screenshot"),
|
|
262
265
|
ImageServerAuth: import_koishi.Schema.string().description("图像生成服务器密码").default(""),
|
|
266
|
+
ImageNoCache: import_koishi.Schema.boolean().description("每次都重新生成图片(一般仅用于Debug)").default(false),
|
|
263
267
|
MinCount: import_koishi.Schema.number().description("最小抽取次数").default(0),
|
|
264
268
|
MaxCount: import_koishi.Schema.number().description("最大抽取次数").default(8),
|
|
265
269
|
Star1Name: import_koishi.Schema.string().description("1星名称").default("N"),
|
|
@@ -307,11 +311,12 @@ var downloadTool_default = downloadFileIfNotExist;
|
|
|
307
311
|
|
|
308
312
|
// src/draw/index.ts
|
|
309
313
|
var name = "cafe-bot-exp.draw";
|
|
310
|
-
var inject = ["http"];
|
|
314
|
+
var inject = ["http", "logger"];
|
|
311
315
|
var Config = CafeBotDrawConfig;
|
|
312
316
|
var animals = ["瑟蕾奴", "可鲁贝洛斯", "捷欧", "基库", "蔡特", "柯贝", "古利亚诺斯", "小星", "影良", "fio", "xeros"];
|
|
313
317
|
var starEnum = [5, 4, 3, 2, 1];
|
|
314
318
|
var cafebotCardData = [];
|
|
319
|
+
var logger = null;
|
|
315
320
|
function shuffleWithCustomRandom(array, rand) {
|
|
316
321
|
for (let i = array.length - 1; i > 0; i--) {
|
|
317
322
|
const a = rand();
|
|
@@ -395,16 +400,17 @@ async function getCards(seed, ctx, config) {
|
|
|
395
400
|
}
|
|
396
401
|
__name(getCards, "getCards");
|
|
397
402
|
async function apply(ctx, config) {
|
|
403
|
+
logger = ctx.logger(name);
|
|
398
404
|
await downloadCardDataIfNotExist(ctx, config, config.forceUpdateDataWhenLoad);
|
|
399
405
|
ctx.command("轨迹抽卡", `抽取你的每日轨迹人物卡吧~`);
|
|
400
406
|
ctx.command("轨迹抽卡/给我抽", "进行每日抽卡").action(async (argv, _) => {
|
|
401
407
|
let seed = DailySeededName(argv.session.userId);
|
|
402
|
-
|
|
408
|
+
logger?.info(`getcard for ${seed}`);
|
|
403
409
|
let randomer = new PseudoRandom_default(seed);
|
|
404
410
|
let result = await getCards(seed, ctx, config);
|
|
405
411
|
if (result.length <= 0) {
|
|
406
412
|
let msg2 = "你并不是本群限定非酋, 只不过抽到的卡牌被" + animals[randomer.nextInt(0, animals.length - 1)] + "叼走了~\n";
|
|
407
|
-
|
|
413
|
+
logger?.info(`getcard for ${seed} is empty,send it`);
|
|
408
414
|
await argv.session?.send(`${At(argv)}${msg2}`);
|
|
409
415
|
return;
|
|
410
416
|
}
|
|
@@ -428,36 +434,37 @@ async function apply(ctx, config) {
|
|
|
428
434
|
}
|
|
429
435
|
});
|
|
430
436
|
await argv.session?.send(msg);
|
|
431
|
-
|
|
437
|
+
logger?.info(`getcard for ${seed} send ok`);
|
|
432
438
|
return;
|
|
433
439
|
});
|
|
434
440
|
const requestWebCache = {};
|
|
435
441
|
ctx.command("轨迹抽卡/给我抽图", "进行抽卡并显示卡牌图片").action(async (argv, _) => {
|
|
436
442
|
let seed = DailySeededName(argv.session.userId);
|
|
437
|
-
|
|
443
|
+
logger?.info(`getcard img for ${seed}`);
|
|
438
444
|
let randomer = new PseudoRandom_default(seed);
|
|
439
445
|
let result = await getCards(seed, ctx, config);
|
|
440
446
|
if (result.length <= 0) {
|
|
441
447
|
let msg = "你并不是本群限定非酋, 只不过抽到的卡牌被" + animals[randomer.nextInt(0, animals.length - 1)] + "叼走了~\n";
|
|
442
448
|
await argv.session?.send(`${At(argv)} ${msg}`);
|
|
443
|
-
|
|
449
|
+
logger?.info(`getcard img for ${seed} is empty`);
|
|
444
450
|
return;
|
|
445
451
|
}
|
|
446
452
|
if (requestWebCache[seed]) {
|
|
447
453
|
await argv.session?.send(`${At(argv)} 请等待上次抽取完成哦~`);
|
|
448
|
-
|
|
454
|
+
logger?.info(`getcard img for ${seed}, another request is processing, send please wait`);
|
|
449
455
|
return;
|
|
450
456
|
}
|
|
451
457
|
requestWebCache[seed] = "waiting";
|
|
452
458
|
await argv.session?.sendQueued(`${At(argv)} 抽取中,请稍候...`);
|
|
453
|
-
|
|
459
|
+
logger?.info(`getcard img for ${seed} is processing, send please wait`);
|
|
454
460
|
var a = html_default(result);
|
|
455
461
|
await ctx.http.post(
|
|
456
462
|
config.ImageServer,
|
|
457
463
|
{
|
|
458
464
|
html: a,
|
|
459
465
|
auth: config.ImageServerAuth,
|
|
460
|
-
filename: seed
|
|
466
|
+
filename: seed,
|
|
467
|
+
nocache: config.ImageNoCache
|
|
461
468
|
},
|
|
462
469
|
{
|
|
463
470
|
responseType: "json"
|
|
@@ -466,13 +473,13 @@ async function apply(ctx, config) {
|
|
|
466
473
|
delete requestWebCache[seed];
|
|
467
474
|
await argv.session?.sendQueued(`${At(argv)}<img src="${res.data}"/>`);
|
|
468
475
|
await argv.session?.cancelQueued();
|
|
469
|
-
|
|
476
|
+
logger?.info(`getcard img for ${seed} send ok~`);
|
|
470
477
|
}).catch(async (e) => {
|
|
471
|
-
|
|
478
|
+
logger?.error(`getcard img for ${seed} is failed, send create failed`);
|
|
479
|
+
logger?.error(e);
|
|
472
480
|
delete requestWebCache[seed];
|
|
473
|
-
await argv.session?.sendQueued(`${At(argv)}
|
|
481
|
+
await argv.session?.sendQueued(`${At(argv)}超级计算机『卡佩尔』发生核心故障😵(A...D...)`);
|
|
474
482
|
await argv.session?.cancelQueued();
|
|
475
|
-
console.log(`getcard img for ${seed} is failed, send create failed`);
|
|
476
483
|
});
|
|
477
484
|
return;
|
|
478
485
|
});
|
|
@@ -592,7 +599,7 @@ var CafeTimeTools_default = CafeTimeTools;
|
|
|
592
599
|
|
|
593
600
|
// src/quiz/index.ts
|
|
594
601
|
var name3 = "cafe-bot-exp.quiz";
|
|
595
|
-
var inject2 = ["http", "cache"];
|
|
602
|
+
var inject2 = ["http", "cache", "logger"];
|
|
596
603
|
var Config3 = CafeBotQuizConfig;
|
|
597
604
|
var validOptions = {
|
|
598
605
|
"A": 0,
|
|
@@ -608,6 +615,7 @@ var validOptions = {
|
|
|
608
615
|
"3": 2,
|
|
609
616
|
"4": 3
|
|
610
617
|
};
|
|
618
|
+
var logger2 = null;
|
|
611
619
|
var quizDataIds = [];
|
|
612
620
|
var quizDataSet = {};
|
|
613
621
|
async function downloadQuitDataIfNotExist(ctx, config, forceUpdate) {
|
|
@@ -627,6 +635,8 @@ async function downloadQuitDataIfNotExist(ctx, config, forceUpdate) {
|
|
|
627
635
|
quizDataSet[element.question.id] = element;
|
|
628
636
|
});
|
|
629
637
|
} catch (error) {
|
|
638
|
+
logger2?.error("get quiz data failed");
|
|
639
|
+
logger2?.error(error);
|
|
630
640
|
throw new Error("quiz read error");
|
|
631
641
|
}
|
|
632
642
|
return;
|
|
@@ -643,26 +653,27 @@ async function answerHandler(ctx, config, argv, answer) {
|
|
|
643
653
|
if (answer in validOptions) {
|
|
644
654
|
selectNumber = validOptions[answer];
|
|
645
655
|
} else {
|
|
646
|
-
await argv.session?.send(`${At(argv)}
|
|
656
|
+
await argv.session?.send(`${At(argv)}输入选项无效哦,请重新输入~`);
|
|
647
657
|
return;
|
|
648
658
|
}
|
|
649
659
|
await ctx.cache.delete("question", argv.session.userId);
|
|
650
660
|
if (quizDataIds == null || quizDataIds.length <= 0) {
|
|
651
|
-
await argv.session?.send(`${At(argv)}
|
|
661
|
+
await argv.session?.send(`${At(argv)}超级计算机『卡佩尔』发生核心故障😵(导力网络异常波动)`);
|
|
652
662
|
return;
|
|
653
663
|
}
|
|
654
664
|
var qItem = quizDataSet[lastQuestion.question];
|
|
655
|
-
|
|
665
|
+
logger2?.info(`${argv.session.userId} try answer quiz(id:${lastQuestion.question}): right answer:${lastQuestion.answer}, input answer:${selectNumber}`);
|
|
656
666
|
if (qItem && lastQuestion.answer == selectNumber) {
|
|
657
|
-
await argv.session?.send(`${At(argv)}回答正确😊${qItem.explain.length > 0 ? "
|
|
667
|
+
await argv.session?.send(`${At(argv)}回答正确😊${qItem.explain.length > 0 ? "," + qItem.explain : ""}`);
|
|
658
668
|
return;
|
|
659
669
|
} else {
|
|
660
|
-
await argv.session?.send(`${At(argv)}回答错误😟${qItem.explain2.length > 0 ? "
|
|
670
|
+
await argv.session?.send(`${At(argv)}回答错误😟${qItem.explain2.length > 0 ? "," + qItem.explain2 : ""}`);
|
|
661
671
|
return;
|
|
662
672
|
}
|
|
663
673
|
}
|
|
664
674
|
__name(answerHandler, "answerHandler");
|
|
665
675
|
async function apply3(ctx, config) {
|
|
676
|
+
logger2 = ctx.logger(name3);
|
|
666
677
|
await downloadQuitDataIfNotExist(ctx, config, config.forceUpdateWhenLoad);
|
|
667
678
|
ctx.command("轨迹答题/出题").action(async (argv, _) => {
|
|
668
679
|
await downloadQuitDataIfNotExist(ctx, config, false);
|
|
@@ -673,7 +684,7 @@ async function apply3(ctx, config) {
|
|
|
673
684
|
}
|
|
674
685
|
var dailyNameKey = DailySeededName(argv.session.userId);
|
|
675
686
|
if (quizDataIds == null || quizDataIds.length <= 0) {
|
|
676
|
-
await argv.session?.send(`${At(argv)}
|
|
687
|
+
await argv.session?.send(`${At(argv)}超级计算机『卡佩尔』发生核心故障😵(导力网络异常波动)`);
|
|
677
688
|
return;
|
|
678
689
|
}
|
|
679
690
|
var todayCount = await ctx.cache.get("todayCache", dailyNameKey);
|
|
@@ -686,12 +697,13 @@ async function apply3(ctx, config) {
|
|
|
686
697
|
}
|
|
687
698
|
todayCount++;
|
|
688
699
|
var cacheTimeoutTime = CafeTimeTools_default.getRemainingSecondsToBeijingMidnight();
|
|
700
|
+
logger2?.debug(`try set cache ${dailyNameKey}, ${todayCount}`);
|
|
689
701
|
await ctx.cache.set("todayCache", dailyNameKey, todayCount, cacheTimeoutTime * 1e3);
|
|
690
702
|
var randomId = import_koishi6.Random.pick(quizDataIds);
|
|
691
703
|
var qItem = quizDataSet[randomId];
|
|
692
704
|
var qOptions = import_koishi6.Random.shuffle(qItem.options);
|
|
693
705
|
var answerIndex = -1;
|
|
694
|
-
|
|
706
|
+
logger2?.info(`${argv.session.userId} get a new quiz(id:${randomId})`);
|
|
695
707
|
for (var i = 0; i < qOptions.length; i++) {
|
|
696
708
|
if (qOptions[i].oid === qItem.a) {
|
|
697
709
|
answerIndex = i;
|
|
@@ -728,7 +740,7 @@ D. ${qOptions[3].s}`;
|
|
|
728
740
|
await answerHandler(ctx, config, argv, "D");
|
|
729
741
|
return;
|
|
730
742
|
});
|
|
731
|
-
ctx.command("轨迹答题/答题分数").action(async (argv, _) => {
|
|
743
|
+
ctx.command("轨迹答题/答题分数", "查看答题总分数").action(async (argv, _) => {
|
|
732
744
|
await argv.session?.send(`${At(argv)}正在开发中哦~`);
|
|
733
745
|
return;
|
|
734
746
|
});
|
|
@@ -745,13 +757,18 @@ var Config4 = import_koishi7.Schema.intersect([
|
|
|
745
757
|
|
|
746
758
|
// src/index.ts
|
|
747
759
|
var name4 = "cafe-bot-exp";
|
|
748
|
-
var inject3 = ["http", "cache"];
|
|
760
|
+
var inject3 = ["http", "cache", "logger"];
|
|
749
761
|
async function apply4(ctx, config) {
|
|
750
762
|
ctx.plugin(draw_exports, config);
|
|
751
763
|
ctx.plugin(quiz_exports, config);
|
|
752
764
|
ctx.plugin(cat_exports, config);
|
|
753
765
|
ctx.command("关于", "about").action(async (argv, _) => {
|
|
754
|
-
argv.session?.send(
|
|
766
|
+
argv.session?.send(
|
|
767
|
+
`我是运行在超级计算机『卡佩尔』上的轨迹CafeBot概念版v${version}🎉~
|
|
768
|
+
- 我提供轨迹抽卡🎴和轨迹问答🙋功能
|
|
769
|
+
- 另外我还有一些隐藏功能待你探索哦🎁
|
|
770
|
+
多多与我聊天吧~`
|
|
771
|
+
);
|
|
755
772
|
});
|
|
756
773
|
}
|
|
757
774
|
__name(apply4, "apply");
|