beatsaber-bot-core 0.2.0-dev.3 → 0.2.0-dev.31
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/api/base/aioclient.d.ts +11 -0
- package/lib/api/base/aioclient.js +34 -0
- package/lib/api/base/aioclient.js.map +1 -0
- package/lib/api/base/blRequset.js +7 -7
- package/lib/api/base/blRequset.js.map +1 -1
- package/lib/api/base/blclient.d.ts +17 -0
- package/lib/api/base/blclient.js +69 -0
- package/lib/api/base/blclient.js.map +1 -0
- package/lib/api/base/bsclient.d.ts +17 -0
- package/lib/api/base/bsclient.js +78 -0
- package/lib/api/base/bsclient.js.map +1 -0
- package/lib/api/base/index.d.ts +4 -12
- package/lib/api/base/index.js +4 -4
- package/lib/api/base/index.js.map +1 -1
- package/lib/api/base/scRequest.d.ts +2 -0
- package/lib/api/base/scRequest.js +28 -13
- package/lib/api/base/scRequest.js.map +1 -1
- package/lib/api/base/ssclient.d.ts +13 -0
- package/lib/api/base/ssclient.js +52 -0
- package/lib/api/base/ssclient.js.map +1 -0
- package/lib/api/composed/beatleader.d.ts +7 -2
- package/lib/api/composed/beatleader.js +26 -5
- package/lib/api/composed/beatleader.js.map +1 -1
- package/lib/api/composed/beatsaver.d.ts +2 -3
- package/lib/api/composed/beatsaver.js +2 -1
- package/lib/api/composed/beatsaver.js.map +1 -1
- package/lib/api/composed/scoresaber.js.map +1 -1
- package/lib/api/helper.d.ts +19 -0
- package/lib/api/helper.js +102 -0
- package/lib/api/helper.js.map +1 -0
- package/lib/api/index.d.ts +6 -23
- package/lib/api/index.js +22 -113
- package/lib/api/index.js.map +1 -1
- package/lib/api/interfaces/beatsaver/bsmap.d.ts +2 -0
- package/lib/api/interfaces/beatsaver/index.d.ts +2 -1
- package/lib/api/interfaces/beatsaver/ws.d.ts +8 -2
- package/lib/api/interfaces/index.d.ts +12 -0
- package/lib/{interface/db.js → api/interfaces/index.js} +1 -1
- package/lib/api/interfaces/index.js.map +1 -0
- package/lib/api/interfaces/scoresaber/item.d.ts +12 -3
- package/lib/api/interfaces/scoresaber/leaderboard.d.ts +10 -0
- package/lib/api/interfaces/scoresaber/leaderboard.js +3 -0
- package/lib/api/interfaces/scoresaber/leaderboard.js.map +1 -0
- package/lib/cmd/bind/bind-beatleader.js +14 -16
- package/lib/cmd/bind/bind-beatleader.js.map +1 -1
- package/lib/cmd/bind/bind-beatsaver.js +27 -21
- package/lib/cmd/bind/bind-beatsaver.js.map +1 -1
- package/lib/cmd/bind/bind-id-beatleader.js +2 -4
- package/lib/cmd/bind/bind-id-beatleader.js.map +1 -1
- package/lib/cmd/bind/bind-id-beatsaver.js +7 -9
- package/lib/cmd/bind/bind-id-beatsaver.js.map +1 -1
- package/lib/cmd/bind/bind-scoresaber.js +2 -4
- package/lib/cmd/bind/bind-scoresaber.js.map +1 -1
- package/lib/cmd/bind/index.d.ts +2 -2
- package/lib/cmd/bind/index.js +4 -0
- package/lib/cmd/bind/index.js.map +1 -1
- package/lib/cmd/bsmap/id-search.d.ts +1 -1
- package/lib/cmd/bsmap/id-search.js +4 -4
- package/lib/cmd/bsmap/id-search.js.map +1 -1
- package/lib/cmd/bsmap/key-search.d.ts +1 -1
- package/lib/cmd/bsmap/key-search.js +10 -10
- package/lib/cmd/bsmap/key-search.js.map +1 -1
- package/lib/cmd/bsmap/latest.d.ts +1 -1
- package/lib/cmd/bsmap/latest.js +13 -19
- package/lib/cmd/bsmap/latest.js.map +1 -1
- package/lib/cmd/builder.d.ts +2 -2
- package/lib/cmd/builder.js +20 -1
- package/lib/cmd/builder.js.map +1 -1
- package/lib/cmd/config/index.d.ts +12 -0
- package/lib/cmd/config/index.js +70 -0
- package/lib/cmd/config/index.js.map +1 -0
- package/lib/cmd/deprecated/cmp.d.ts +1 -1
- package/lib/cmd/deprecated/me.d.ts +3 -3
- package/lib/cmd/deprecated/me.js +6 -6
- package/lib/cmd/deprecated/me.js.map +1 -1
- package/lib/cmd/deprecated/tmp.d.ts +1 -1
- package/lib/cmd/deprecated/tmp.js +2 -0
- package/lib/cmd/deprecated/tmp.js.map +1 -1
- package/lib/cmd/deprecated/whois.d.ts +2 -2
- package/lib/cmd/deprecated/whois.js +2 -2
- package/lib/cmd/deprecated/whois.js.map +1 -1
- package/lib/cmd/help.d.ts +1 -1
- package/lib/cmd/index.js +3 -1
- package/lib/cmd/index.js.map +1 -1
- package/lib/cmd/rank.d.ts +2 -2
- package/lib/cmd/rank.js +16 -11
- package/lib/cmd/rank.js.map +1 -1
- package/lib/cmd/score.d.ts +3 -3
- package/lib/cmd/score.js +26 -10
- package/lib/cmd/score.js.map +1 -1
- package/lib/cmd/subscribe/index.d.ts +2 -2
- package/lib/cmd/subscribe/subjoin.d.ts +2 -2
- package/lib/cmd/subscribe/subleave.d.ts +2 -2
- package/lib/cmd/subscribe/unsubscribe.d.ts +2 -2
- package/lib/config.d.ts +21 -4
- package/lib/db/index.d.ts +0 -34
- package/lib/db/index.js +0 -2
- package/lib/errors/index.d.ts +43 -41
- package/lib/errors/index.js +108 -59
- package/lib/errors/index.js.map +1 -1
- package/lib/i18n/index.js +17 -11
- package/lib/i18n/index.js.map +1 -1
- package/lib/i18n/parser.d.ts +14 -0
- package/lib/i18n/parser.js +165 -0
- package/lib/i18n/parser.js.map +1 -0
- package/lib/i18n/zh-cn.json +1 -1
- package/lib/img-render/components/RankDifficulty.d.ts +6 -0
- package/lib/img-render/components/RankDifficulty.js +17 -0
- package/lib/img-render/components/RankDifficulty.js.map +1 -0
- package/lib/img-render/components/base/avatar.d.ts +7 -0
- package/lib/img-render/components/base/avatar.js +11 -0
- package/lib/img-render/components/base/avatar.js.map +1 -1
- package/lib/img-render/components/bl-rank-score-item.d.ts +18 -0
- package/lib/img-render/components/bl-rank-score-item.js +42 -0
- package/lib/img-render/components/bl-rank-score-item.js.map +1 -0
- package/lib/img-render/components/bl-score-item.d.ts +6 -0
- package/lib/img-render/components/bl-score-item.js +14 -0
- package/lib/img-render/components/bl-score-item.js.map +1 -0
- package/lib/img-render/components/blScoreItem.js +2 -2
- package/lib/img-render/components/blScoreItem.js.map +1 -1
- package/lib/img-render/components/rankScoreItem.d.ts +18 -0
- package/lib/img-render/components/rankScoreItem.js +42 -0
- package/lib/img-render/components/rankScoreItem.js.map +1 -0
- package/lib/img-render/components/scoregraph.d.ts +3 -1
- package/lib/img-render/components/scoregraph.js +5 -4
- package/lib/img-render/components/scoregraph.js.map +1 -1
- package/lib/img-render/components/ss-rank-score-item.d.ts +18 -0
- package/lib/img-render/components/ss-rank-score-item.js +42 -0
- package/lib/img-render/components/ss-rank-score-item.js.map +1 -0
- package/lib/img-render/components/ss-score-item.d.ts +4 -0
- package/lib/img-render/components/ss-score-item.js +14 -0
- package/lib/img-render/components/ss-score-item.js.map +1 -0
- package/lib/img-render/components/ssScoreItem.js +1 -1
- package/lib/img-render/components/ssScoreItem.js.map +1 -1
- package/lib/img-render/index.d.ts +13 -10
- package/lib/img-render/index.js +46 -23
- package/lib/img-render/index.js.map +1 -1
- package/lib/img-render/interfaces.d.ts +2 -0
- package/lib/img-render/render.js +26 -1
- package/lib/img-render/render.js.map +1 -1
- package/lib/img-render/result/bl-player.d.ts +2 -1
- package/lib/img-render/result/bl-player.js +3 -4
- package/lib/img-render/result/bl-player.js.map +1 -1
- package/lib/img-render/result/bl-score-with-rank.d.ts +14 -0
- package/lib/img-render/result/bl-score-with-rank.js +33 -0
- package/lib/img-render/result/bl-score-with-rank.js.map +1 -0
- package/lib/img-render/result/bl-score.js +1 -1
- package/lib/img-render/result/bl-score.js.map +1 -1
- package/lib/img-render/result/bs-score-with-rank.d.ts +13 -0
- package/lib/img-render/result/bs-score-with-rank.js +33 -0
- package/lib/img-render/result/bs-score-with-rank.js.map +1 -0
- package/lib/img-render/result/index.d.ts +3 -2
- package/lib/img-render/result/index.js +10 -5
- package/lib/img-render/result/index.js.map +1 -1
- package/lib/img-render/result/ss-player.d.ts +2 -1
- package/lib/img-render/result/ss-player.js +3 -4
- package/lib/img-render/result/ss-player.js.map +1 -1
- package/lib/img-render/result/ss-score-with-rank.js +277 -0
- package/lib/img-render/result/ss-score-with-rank.js.map +1 -0
- package/lib/img-render/utils/canvas.js +10 -4
- package/lib/img-render/utils/canvas.js.map +1 -1
- package/lib/img-render/utils/format.d.ts +3 -0
- package/lib/img-render/utils/format.js +25 -1
- package/lib/img-render/utils/format.js.map +1 -1
- package/lib/img-render/utils/index.d.ts +1 -1
- package/lib/img-render/utils/index.js +1 -1
- package/lib/img-render/utils/index.js.map +1 -1
- package/lib/img-render/utils/qrcode.js +8 -1
- package/lib/img-render/utils/qrcode.js.map +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/index.js.map +1 -1
- package/lib/interface/bot.d.ts +1 -1
- package/lib/interface/cmd.d.ts +3 -0
- package/lib/interface/{db.d.ts → db/index.d.ts} +5 -2
- package/lib/interface/db/index.js +18 -0
- package/lib/interface/db/index.js.map +1 -0
- package/lib/interface/db/models.d.ts +39 -0
- package/lib/interface/db/models.js +3 -0
- package/lib/interface/db/models.js.map +1 -0
- package/lib/interface/index.d.ts +0 -1
- package/lib/interface/index.js +0 -1
- package/lib/interface/index.js.map +1 -1
- package/lib/interface/render.d.ts +7 -5
- package/lib/schedules/index.d.ts +7 -2
- package/lib/schedules/index.js +20 -16
- package/lib/schedules/index.js.map +1 -1
- package/lib/schedules/interface.d.ts +18 -0
- package/lib/schedules/interface.js +3 -0
- package/lib/schedules/interface.js.map +1 -0
- package/lib/schedules/oauthTokenRefreshTask.d.ts +2 -5
- package/lib/schedules/oauthTokenRefreshTask.js +15 -15
- package/lib/schedules/oauthTokenRefreshTask.js.map +1 -1
- package/lib/schedules/temp.d.ts +2 -5
- package/lib/schedules/temp.js +5 -5
- package/lib/schedules/temp.js.map +1 -1
- package/lib/utils/cache.d.ts +3 -0
- package/lib/utils/cache.js +30 -0
- package/lib/utils/cache.js.map +1 -0
- package/lib/utils/fetch/index.d.ts +3 -0
- package/lib/utils/fetch/index.js +21 -0
- package/lib/utils/fetch/index.js.map +1 -0
- package/lib/utils/fetch/ofetch.d.ts +22 -0
- package/lib/utils/fetch/ofetch.js +87 -0
- package/lib/utils/fetch/ofetch.js.map +1 -0
- package/lib/utils/index.d.ts +8 -0
- package/lib/utils/index.js +80 -0
- package/lib/utils/index.js.map +1 -0
- package/lib/utils/preference.d.ts +35 -0
- package/lib/utils/preference.js +115 -0
- package/lib/utils/preference.js.map +1 -0
- package/lib/utils/puppeteer.d.ts +20 -0
- package/lib/utils/puppeteer.js +79 -0
- package/lib/utils/puppeteer.js.map +1 -0
- package/lib/utils/s3.d.ts +11 -0
- package/lib/utils/s3.js +60 -0
- package/lib/utils/s3.js.map +1 -0
- package/lib/ws/beatleader.js +1 -0
- package/lib/ws/beatleader.js.map +1 -1
- package/lib/ws/beatsaver.d.ts +6 -1
- package/lib/ws/beatsaver.js +28 -26
- package/lib/ws/beatsaver.js.map +1 -1
- package/package.json +9 -4
- package/lib/interface/db.js.map +0 -1
- package/lib/interface/tables.js +0 -1
- package/lib/interface/tables.js.map +0 -1
- package/lib/utils.d.ts +0 -2
- package/lib/utils.js +0 -25
- package/lib/utils.js.map +0 -1
- /package/lib/{interface/tables.d.ts → img-render/result/ss-score-with-rank.d.ts} +0 -0
package/lib/interface/index.js
CHANGED
@@ -16,7 +16,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
17
|
exports.ImgRenderMode = exports.Platform = void 0;
|
18
18
|
__exportStar(require("./db"), exports);
|
19
|
-
__exportStar(require("./db"), exports);
|
20
19
|
__exportStar(require("./logger"), exports);
|
21
20
|
__exportStar(require("./cmd"), exports);
|
22
21
|
__exportStar(require("./render"), exports);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/interface/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,uCAAoB;AACpB,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/interface/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,uCAAoB;AACpB,2CAAwB;AACxB,wCAAqB;AACrB,2CAAwB;AACxB,wCAAqB;AACrB,IAAY,QAIX;AAJD,WAAY,QAAQ;IAClB,6BAAiB,CAAA;IACjB,4BAAgB,CAAA;IAChB,6BAAiB,CAAA;AACnB,CAAC,EAJW,QAAQ,wBAAR,QAAQ,QAInB;AAED,IAAY,aAGX;AAHD,WAAY,aAAa;IACvB,gCAAe,CAAA;IACf,kCAAiB,CAAA;AACnB,CAAC,EAHW,aAAa,6BAAb,aAAa,QAGxB"}
|
@@ -1,8 +1,10 @@
|
|
1
|
+
/// <reference types="node" />
|
1
2
|
import { Config } from '../config';
|
2
3
|
import { APIService } from '../api';
|
3
4
|
import { RenderOption } from '../img-render/interfaces';
|
4
5
|
import { Platform } from '../interface';
|
5
6
|
import { BSMap } from '../api/interfaces/beatsaver';
|
7
|
+
import { UserPreferenceStore } from '../utils';
|
6
8
|
type HtmlToImgBufferConverter = (html: string, onRenderStart?: () => void, onRenderError?: (e: any) => void) => Promise<any>;
|
7
9
|
export interface ImgRender {
|
8
10
|
config: Config;
|
@@ -12,10 +14,10 @@ export interface ImgRender {
|
|
12
14
|
_renderRank: (accountId: string, platform: Platform, api: APIService, renderOpts: RenderOption) => Promise<any>;
|
13
15
|
_renderScore: (scoreId: string, platform: Platform, api: APIService, renderOpts: RenderOption) => Promise<any>;
|
14
16
|
_renderMap: (bsMap: BSMap, renderOpts: RenderOption) => Promise<any>;
|
15
|
-
renderRank(accountId: string, platform: Platform, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<
|
16
|
-
renderScore(scoreId: string, platform: Platform, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<
|
17
|
-
renderMapById(mapId: string, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<
|
18
|
-
renderMap(map: BSMap, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<
|
19
|
-
renderUrl(url: string, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<
|
17
|
+
renderRank(accountId: string, platform: Platform, userPreference?: UserPreferenceStore, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<Buffer>;
|
18
|
+
renderScore(scoreId: string, platform: Platform, userPreference?: UserPreferenceStore, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<Buffer>;
|
19
|
+
renderMapById(mapId: string, userPreference?: UserPreferenceStore, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<Buffer>;
|
20
|
+
renderMap(map: BSMap, userPreference?: UserPreferenceStore, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<Buffer>;
|
21
|
+
renderUrl(url: string, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<Buffer>;
|
20
22
|
}
|
21
23
|
export {};
|
package/lib/schedules/index.d.ts
CHANGED
@@ -1,2 +1,7 @@
|
|
1
|
-
|
2
|
-
export
|
1
|
+
import { Config } from '../config';
|
2
|
+
export declare const getScheduleTasks: (config: Config) => {
|
3
|
+
name: string;
|
4
|
+
handler: <T>(c: import("./interface").ScheduleTaskCtx<T>) => Promise<void>;
|
5
|
+
cron: string;
|
6
|
+
enable: boolean;
|
7
|
+
}[];
|
package/lib/schedules/index.js
CHANGED
@@ -1,19 +1,23 @@
|
|
1
1
|
"use strict";
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
-
if (k2 === undefined) k2 = k;
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
-
}
|
8
|
-
Object.defineProperty(o, k2, desc);
|
9
|
-
}) : (function(o, m, k, k2) {
|
10
|
-
if (k2 === undefined) k2 = k;
|
11
|
-
o[k2] = m[k];
|
12
|
-
}));
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
-
};
|
16
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
-
|
18
|
-
|
3
|
+
exports.getScheduleTasks = void 0;
|
4
|
+
const oauthTokenRefreshTask_1 = require("./oauthTokenRefreshTask");
|
5
|
+
const temp_1 = require("../schedules/temp");
|
6
|
+
const oauthTokenRefreshTask = {
|
7
|
+
name: 'oauthTokenRefreshTask',
|
8
|
+
// config
|
9
|
+
cron: '',
|
10
|
+
executor: oauthTokenRefreshTask_1.tokenRefreshTask,
|
11
|
+
};
|
12
|
+
const getScheduleTasks = (config) => {
|
13
|
+
return [
|
14
|
+
{
|
15
|
+
name: 'lb-rank-notifier',
|
16
|
+
handler: temp_1.LBScoreMonitor,
|
17
|
+
cron: config.tempCron.cron,
|
18
|
+
enable: config.tempCron.enable,
|
19
|
+
},
|
20
|
+
];
|
21
|
+
};
|
22
|
+
exports.getScheduleTasks = getScheduleTasks;
|
19
23
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/schedules/index.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/schedules/index.ts"],"names":[],"mappings":";;;AAAA,mEAA0D;AAE1D,2CAAiD;AAEjD,MAAM,qBAAqB,GAAG;IAC5B,IAAI,EAAE,uBAAuB;IAC7B,SAAS;IACT,IAAI,EAAE,EAAE;IACR,QAAQ,EAAE,wCAAgB;CAC3B,CAAA;AAEM,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAE,EAAE;IACjD,OAAO;QACL;YACE,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,qBAAc;YACvB,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI;YAC1B,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAM;SAC/B;KACF,CAAA;AACH,CAAC,CAAA;AATY,QAAA,gBAAgB,oBAS5B"}
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import { Config } from '../config';
|
2
|
+
import { BotService, DB, Logger, Session } from '../interface';
|
3
|
+
import { RenderService } from '../img-render';
|
4
|
+
import { APIService } from '../api';
|
5
|
+
export type ScheduleTaskCtx<T> = {
|
6
|
+
config: Config;
|
7
|
+
db: DB<T>;
|
8
|
+
render: RenderService;
|
9
|
+
api: APIService;
|
10
|
+
logger: Logger;
|
11
|
+
botService: BotService<T, Session<T>>;
|
12
|
+
};
|
13
|
+
export type ScheduleTask = {
|
14
|
+
name: string;
|
15
|
+
cron: string;
|
16
|
+
handler: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
|
17
|
+
enable: boolean;
|
18
|
+
};
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../src/schedules/interface.ts"],"names":[],"mappings":""}
|
@@ -1,5 +1,2 @@
|
|
1
|
-
import {
|
2
|
-
|
3
|
-
import { RenderService } from '../img-render';
|
4
|
-
import { APIService } from '../api';
|
5
|
-
export declare const tokenRefreshTask: <T>(config: Config, db: DB<T>, render: RenderService, api: APIService, logger: Logger, botService: BotService<T, Session<T>>) => Promise<void>;
|
1
|
+
import { ScheduleTaskCtx } from './interface';
|
2
|
+
export declare const tokenRefreshTask: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
|
@@ -1,8 +1,8 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.tokenRefreshTask = void 0;
|
4
|
-
const tokenRefreshTask = async (
|
5
|
-
logger.info('start token refresh task');
|
4
|
+
const tokenRefreshTask = async (c) => {
|
5
|
+
c.logger.info('start token refresh task');
|
6
6
|
// getAllOauthToken
|
7
7
|
const accounts = [];
|
8
8
|
// await db.getAllOAuthTokenNeedRefresh()
|
@@ -11,12 +11,12 @@ const tokenRefreshTask = async (config, db, render, api, logger, botService) =>
|
|
11
11
|
// type: 'oauth',
|
12
12
|
// })
|
13
13
|
for (const account of accounts) {
|
14
|
-
logger.info(`try to refresh ${account.platform} ${account.platformUid}'s token`);
|
14
|
+
c.logger.info(`try to refresh ${account.platform} ${account.platformUid}'s token`);
|
15
15
|
const now = new Date();
|
16
16
|
if (account.platform === 'beatleader') {
|
17
|
-
const token = await api.BeatLeader.
|
18
|
-
if (!token
|
19
|
-
logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
17
|
+
const token = await c.api.BeatLeader.refreshOAuthToken(account.refreshToken);
|
18
|
+
if (!token) {
|
19
|
+
c.logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
20
20
|
account.valid = 'invalid';
|
21
21
|
account.lastModifiedAt = now;
|
22
22
|
// await ctx.database.upsert('BSRelateOAuthAccount', [account])
|
@@ -24,13 +24,13 @@ const tokenRefreshTask = async (config, db, render, api, logger, botService) =>
|
|
24
24
|
// bot.sendMessage(item.sub.channelId, '似乎 BeatSaver 通知的 token 已经失效了,通过 bbbind 重新绑定吧')
|
25
25
|
continue;
|
26
26
|
}
|
27
|
-
account.accessToken = token.
|
28
|
-
account.refreshToken = token.
|
27
|
+
account.accessToken = token.access_token;
|
28
|
+
account.refreshToken = token.refresh_token;
|
29
29
|
}
|
30
30
|
else if (account.platform === 'beatsaver') {
|
31
|
-
const token = await api.BeatSaver.
|
32
|
-
if (!token
|
33
|
-
logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
31
|
+
const token = await c.api.BeatSaver.refreshOAuthToken(account.refreshToken);
|
32
|
+
if (!token) {
|
33
|
+
c.logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
34
34
|
account.valid = 'invalid';
|
35
35
|
account.lastModifiedAt = now;
|
36
36
|
// await ctx.database.upsert('BSRelateOAuthAccount', [account])
|
@@ -38,16 +38,16 @@ const tokenRefreshTask = async (config, db, render, api, logger, botService) =>
|
|
38
38
|
// bot.sendMessage(item.sub.channelId, '似乎 BeatSaver 通知的 token 已经失效了,通过 bbbind 重新绑定吧')
|
39
39
|
continue;
|
40
40
|
}
|
41
|
-
account.accessToken = token.
|
42
|
-
account.refreshToken = token.
|
41
|
+
account.accessToken = token.access_token;
|
42
|
+
account.refreshToken = token.refresh_token;
|
43
43
|
}
|
44
44
|
account.lastRefreshAt = now;
|
45
45
|
account.lastModifiedAt = now;
|
46
46
|
//
|
47
47
|
// await ctx.database.upsert('BSRelateOAuthAccount', [account])
|
48
|
-
logger.info(`refresh ${account.platform} token successfully ${account.platformUid}`);
|
48
|
+
c.logger.info(`refresh ${account.platform} token successfully ${account.platformUid}`);
|
49
49
|
}
|
50
|
-
logger.info(`token refresh task finished`);
|
50
|
+
c.logger.info(`token refresh task finished`);
|
51
51
|
};
|
52
52
|
exports.tokenRefreshTask = tokenRefreshTask;
|
53
53
|
//# sourceMappingURL=oauthTokenRefreshTask.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"oauthTokenRefreshTask.js","sourceRoot":"","sources":["../../src/schedules/oauthTokenRefreshTask.ts"],"names":[],"mappings":";;;
|
1
|
+
{"version":3,"file":"oauthTokenRefreshTask.js","sourceRoot":"","sources":["../../src/schedules/oauthTokenRefreshTask.ts"],"names":[],"mappings":";;;AAEO,MAAM,gBAAgB,GAAG,KAAK,EAAK,CAAqB,EAAE,EAAE;IACjE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAA;IACzC,mBAAmB;IACnB,MAAM,QAAQ,GAAG,EAAE,CAAA;IACnB,yCAAyC;IACzC,oEAAoE;IACpE,oBAAoB;IACpB,mBAAmB;IACnB,KAAK;IACL,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,CAAC,CAAC,MAAM,CAAC,IAAI,CACX,kBAAkB,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,WAAW,UAAU,CACpE,CAAA;QACD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAA;QACtB,IAAI,OAAO,CAAC,QAAQ,KAAK,YAAY,EAAE,CAAC;YACtC,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,iBAAiB,CACpD,OAAO,CAAC,YAAY,CACrB,CAAA;YACD,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,CAAC,CAAC,MAAM,CAAC,IAAI,CACX,qBAAqB,OAAO,CAAC,QAAQ,iCAAiC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAChG,CAAA;gBACD,OAAO,CAAC,KAAK,GAAG,SAAS,CAAA;gBACzB,OAAO,CAAC,cAAc,GAAG,GAAG,CAAA;gBAC5B,+DAA+D;gBAC/D,sCAAsC;gBACtC,sFAAsF;gBACtF,SAAQ;YACV,CAAC;YACD,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,YAAY,CAAA;YACxC,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC,aAAa,CAAA;QAC5C,CAAC;aAAM,IAAI,OAAO,CAAC,QAAQ,KAAK,WAAW,EAAE,CAAC;YAC5C,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,iBAAiB,CACnD,OAAO,CAAC,YAAY,CACrB,CAAA;YACD,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,CAAC,CAAC,MAAM,CAAC,IAAI,CACX,qBAAqB,OAAO,CAAC,QAAQ,iCAAiC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAChG,CAAA;gBACD,OAAO,CAAC,KAAK,GAAG,SAAS,CAAA;gBACzB,OAAO,CAAC,cAAc,GAAG,GAAG,CAAA;gBAC5B,+DAA+D;gBAC/D,sCAAsC;gBACtC,sFAAsF;gBACtF,SAAQ;YACV,CAAC;YACD,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,YAAY,CAAA;YACxC,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC,aAAa,CAAA;QAC5C,CAAC;QACD,OAAO,CAAC,aAAa,GAAG,GAAG,CAAA;QAC3B,OAAO,CAAC,cAAc,GAAG,GAAG,CAAA;QAC5B,EAAE;QACF,+DAA+D;QAC/D,CAAC,CAAC,MAAM,CAAC,IAAI,CACX,WAAW,OAAO,CAAC,QAAQ,uBAAuB,OAAO,CAAC,WAAW,EAAE,CACxE,CAAA;IACH,CAAC;IACD,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAA;AAC9C,CAAC,CAAA;AA1DY,QAAA,gBAAgB,oBA0D5B"}
|
package/lib/schedules/temp.d.ts
CHANGED
@@ -1,5 +1,2 @@
|
|
1
|
-
import {
|
2
|
-
|
3
|
-
import { RenderService } from '../img-render';
|
4
|
-
import { APIService } from '../api';
|
5
|
-
export declare const LBScoreMonitor: <T>(config: Config, db: DB<T>, render: RenderService, api: APIService, logger: Logger, botService: BotService<T, Session<T>>) => Promise<void>;
|
1
|
+
import { ScheduleTaskCtx } from '../schedules/interface';
|
2
|
+
export declare const LBScoreMonitor: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
|
package/lib/schedules/temp.js
CHANGED
@@ -1,17 +1,17 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.LBScoreMonitor = void 0;
|
4
|
-
const LBScoreMonitor = async (
|
5
|
-
const channels = await db.
|
4
|
+
const LBScoreMonitor = async (c) => {
|
5
|
+
const channels = await c.db.getSubscriptionsByType('lb-rank');
|
6
6
|
if (channels.length <= 0) {
|
7
7
|
return;
|
8
8
|
}
|
9
9
|
const [hitbuf, scorebuf] = await Promise.all([
|
10
|
-
render.renderUrl('https://aiobs.ktlab.io/tmp/lb/hitcnt'),
|
11
|
-
render.renderUrl('https://aiobs.ktlab.io/tmp/lb/score'),
|
10
|
+
c.render.renderUrl('https://aiobs.ktlab.io/tmp/lb/hitcnt'),
|
11
|
+
c.render.renderUrl('https://aiobs.ktlab.io/tmp/lb/score'),
|
12
12
|
]);
|
13
13
|
for (const group of channels) {
|
14
|
-
const session = botService.getSessionByChannelInfo(group.groupChannel);
|
14
|
+
const session = c.botService.getSessionByChannelInfo(group.groupChannel);
|
15
15
|
if (!session) {
|
16
16
|
continue;
|
17
17
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"temp.js","sourceRoot":"","sources":["../../src/schedules/temp.ts"],"names":[],"mappings":";;;
|
1
|
+
{"version":3,"file":"temp.js","sourceRoot":"","sources":["../../src/schedules/temp.ts"],"names":[],"mappings":";;;AAEO,MAAM,cAAc,GAAG,KAAK,EAAK,CAAqB,EAAE,EAAE;IAC/D,MAAM,QAAQ,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,sBAAsB,CAAC,SAAS,CAAC,CAAA;IAC7D,IAAI,QAAQ,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;QACzB,OAAM;IACR,CAAC;IACD,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QAC3C,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,sCAAsC,CAAC;QAC1D,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,qCAAqC,CAAC;KAC1D,CAAC,CAAA;IACF,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAG,CAAC,CAAC,UAAU,CAAC,uBAAuB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;QACxE,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,SAAQ;QACV,CAAC;QACD,MAAM,OAAO,CAAC,aAAa,CAAC,MAAM,EAAE,WAAW,CAAC,CAAA;QAChD,MAAM,OAAO,CAAC,aAAa,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;IACpD,CAAC;AACH,CAAC,CAAA;AAjBY,QAAA,cAAc,kBAiB1B"}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.createCache = exports.cache = void 0;
|
4
|
+
const lru_cache_1 = require("lru-cache");
|
5
|
+
const options = {
|
6
|
+
max: 500,
|
7
|
+
// for use with tracking overall storage size
|
8
|
+
maxSize: 5000,
|
9
|
+
sizeCalculation: (value, key) => 1,
|
10
|
+
// for use when you need to clean up something when objects
|
11
|
+
// are evicted from the cache
|
12
|
+
// dispose: (value, key) => {},
|
13
|
+
// how long to live in ms
|
14
|
+
ttl: 1000 * 60 * 5,
|
15
|
+
// return stale items before removing from cache?
|
16
|
+
allowStale: false,
|
17
|
+
updateAgeOnGet: true,
|
18
|
+
updateAgeOnHas: true,
|
19
|
+
// // async method to use for cache.fetch(), for
|
20
|
+
// // stale-while-revalidate type of behavior
|
21
|
+
// fetchMethod: async (
|
22
|
+
// key,
|
23
|
+
// staleValue,
|
24
|
+
// { options, signal, context }
|
25
|
+
// ) => {},
|
26
|
+
};
|
27
|
+
exports.cache = new lru_cache_1.LRUCache(options);
|
28
|
+
const createCache = (opt) => new lru_cache_1.LRUCache(opt);
|
29
|
+
exports.createCache = createCache;
|
30
|
+
//# sourceMappingURL=cache.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/utils/cache.ts"],"names":[],"mappings":";;;AAAA,yCAAoC;AAEpC,MAAM,OAAO,GAAG;IACd,GAAG,EAAE,GAAG;IAER,6CAA6C;IAC7C,OAAO,EAAE,IAAI;IACb,eAAe,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IAElC,2DAA2D;IAC3D,6BAA6B;IAC7B,+BAA+B;IAE/B,yBAAyB;IACzB,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,CAAC;IAElB,iDAAiD;IAEjD,UAAU,EAAE,KAAK;IAEjB,cAAc,EAAE,IAAI;IACpB,cAAc,EAAE,IAAI;IAEpB,gDAAgD;IAChD,6CAA6C;IAC7C,uBAAuB;IACvB,SAAS;IACT,gBAAgB;IAChB,iCAAiC;IACjC,WAAW;CACZ,CAAA;AAEY,QAAA,KAAK,GAAG,IAAI,oBAAQ,CAAC,OAAO,CAAC,CAAA;AAEnC,MAAM,WAAW,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,oBAAQ,CAAC,GAAG,CAAC,CAAA;AAAxC,QAAA,WAAW,eAA6B"}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
const ofetch_1 = require("./ofetch");
|
4
|
+
const rofetch = (0, ofetch_1.createFetch)({
|
5
|
+
defaults: {
|
6
|
+
retryStatusCodes: [400, 408, 409, 425, 429, 502, 503, 504],
|
7
|
+
retry: 2,
|
8
|
+
retryDelay: 800,
|
9
|
+
},
|
10
|
+
}).create({
|
11
|
+
onResponseError: (err) => {
|
12
|
+
// logger.error(err)
|
13
|
+
if (err.response._data) {
|
14
|
+
err.error = new Error(err.response._data?.error ?? err.response._data?.message);
|
15
|
+
}
|
16
|
+
},
|
17
|
+
});
|
18
|
+
// convert error info
|
19
|
+
const ofetch = new ofetch_1.Fetch(rofetch);
|
20
|
+
exports.default = ofetch;
|
21
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/fetch/index.ts"],"names":[],"mappings":";;AAAA,qCAA6C;AAE7C,MAAM,OAAO,GAAG,IAAA,oBAAW,EAAC;IAC1B,QAAQ,EAAE;QACR,gBAAgB,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;QAC1D,KAAK,EAAE,CAAC;QACR,UAAU,EAAE,GAAG;KAChB;CACF,CAAC,CAAC,MAAM,CAAC;IACR,eAAe,EAAE,CAAC,GAAG,EAAE,EAAE;QACvB,oBAAoB;QACpB,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;YACvB,GAAG,CAAC,KAAK,GAAG,IAAI,KAAK,CACnB,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CACzD,CAAA;QACH,CAAC;IACH,CAAC;CACF,CAAC,CAAA;AAEF,qBAAqB;AACrB,MAAM,MAAM,GAAG,IAAI,cAAK,CAAC,OAAO,CAAC,CAAA;AACjC,kBAAe,MAAM,CAAA"}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import { $Fetch, FetchOptions } from 'ofetch';
|
2
|
+
export declare const rofetch: $Fetch;
|
3
|
+
export type ExtendFetchOptions = {
|
4
|
+
form?: Record<string, any>;
|
5
|
+
json?: Record<string, any>;
|
6
|
+
searchParams?: Record<string, any>;
|
7
|
+
cache?: boolean;
|
8
|
+
} & FetchOptions;
|
9
|
+
export declare class Fetch {
|
10
|
+
private options?;
|
11
|
+
private ofetchInstance;
|
12
|
+
constructor(fetchInstance?: $Fetch, options?: FetchOptions);
|
13
|
+
private fetch;
|
14
|
+
get<T extends any = any>(request: string, options?: ExtendFetchOptions): Promise<T>;
|
15
|
+
post<T extends any = any>(request: string, options?: ExtendFetchOptions): Promise<T>;
|
16
|
+
put<T extends any = any>(request: string, options?: ExtendFetchOptions): Promise<T>;
|
17
|
+
patch<T extends any = any>(request: string, options?: ExtendFetchOptions): Promise<T>;
|
18
|
+
delete<T extends any = any>(request: string, options?: ExtendFetchOptions): Promise<T>;
|
19
|
+
head(request: string, options?: ExtendFetchOptions): Promise<any>;
|
20
|
+
extend(options: FetchOptions): Fetch;
|
21
|
+
}
|
22
|
+
export { createFetch } from 'ofetch';
|
@@ -0,0 +1,87 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.createFetch = exports.Fetch = exports.rofetch = void 0;
|
4
|
+
const ofetch_1 = require("ofetch");
|
5
|
+
//
|
6
|
+
// import { logger } from "./logger"
|
7
|
+
// import { isDebug } from "./env";
|
8
|
+
exports.rofetch = (0, ofetch_1.createFetch)({
|
9
|
+
defaults: {
|
10
|
+
retryStatusCodes: [400, 408, 409, 425, 429, 500, 502, 503, 504],
|
11
|
+
retry: 3,
|
12
|
+
retryDelay: 800,
|
13
|
+
},
|
14
|
+
}).create({
|
15
|
+
onResponseError({ request, response, options }) {
|
16
|
+
if (options.retry) {
|
17
|
+
// logger.warn(
|
18
|
+
// `external request ${request} with error ${response.status} remaining retry attempts: ${options.retry}`
|
19
|
+
// )
|
20
|
+
}
|
21
|
+
},
|
22
|
+
onRequestError({ request, error }) {
|
23
|
+
// logger.error(`external request ${request} fail: ${error}`)
|
24
|
+
},
|
25
|
+
});
|
26
|
+
class Fetch {
|
27
|
+
options;
|
28
|
+
ofetchInstance;
|
29
|
+
constructor(fetchInstance, options) {
|
30
|
+
this.options = options;
|
31
|
+
this.ofetchInstance = fetchInstance ?? exports.rofetch;
|
32
|
+
}
|
33
|
+
async fetch(request, options) {
|
34
|
+
if (options?.json && !options.body) {
|
35
|
+
options.body = options.json;
|
36
|
+
delete options.json;
|
37
|
+
}
|
38
|
+
if (options?.form && !options.body) {
|
39
|
+
options.body = new URLSearchParams(options.form).toString();
|
40
|
+
if (!options.headers) {
|
41
|
+
options.headers = {};
|
42
|
+
}
|
43
|
+
options.headers = {
|
44
|
+
...options.headers,
|
45
|
+
'content-type': 'application/x-www-form-urlencoded',
|
46
|
+
};
|
47
|
+
delete options.form;
|
48
|
+
}
|
49
|
+
if (options?.searchParams) {
|
50
|
+
request += '?' + new URLSearchParams(options.searchParams).toString();
|
51
|
+
delete options.searchParams;
|
52
|
+
}
|
53
|
+
// if (isDebug()) {
|
54
|
+
// logger.debug(`external request ${request}`)
|
55
|
+
// }
|
56
|
+
const res = await this.ofetchInstance(request, {
|
57
|
+
...this.options,
|
58
|
+
...options,
|
59
|
+
});
|
60
|
+
return res;
|
61
|
+
}
|
62
|
+
get(request, options) {
|
63
|
+
return this.fetch(request, { ...options, method: 'GET' });
|
64
|
+
}
|
65
|
+
post(request, options) {
|
66
|
+
return this.fetch(request, { ...options, method: 'POST' });
|
67
|
+
}
|
68
|
+
put(request, options) {
|
69
|
+
return this.fetch(request, { ...options, method: 'PUT' });
|
70
|
+
}
|
71
|
+
patch(request, options) {
|
72
|
+
return this.fetch(request, { ...options, method: 'PATCH' });
|
73
|
+
}
|
74
|
+
delete(request, options) {
|
75
|
+
return this.fetch(request, { ...options, method: 'DELETE' });
|
76
|
+
}
|
77
|
+
head(request, options) {
|
78
|
+
return this.fetch(request, { ...options, method: 'HEAD' });
|
79
|
+
}
|
80
|
+
extend(options) {
|
81
|
+
return new Fetch(this.ofetchInstance, { ...this.options, ...options });
|
82
|
+
}
|
83
|
+
}
|
84
|
+
exports.Fetch = Fetch;
|
85
|
+
var ofetch_2 = require("ofetch");
|
86
|
+
Object.defineProperty(exports, "createFetch", { enumerable: true, get: function () { return ofetch_2.createFetch; } });
|
87
|
+
//# sourceMappingURL=ofetch.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ofetch.js","sourceRoot":"","sources":["../../../src/utils/fetch/ofetch.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
export * from './cache';
|
2
|
+
export * from './s3';
|
3
|
+
export * from './preference';
|
4
|
+
export * from './puppeteer';
|
5
|
+
export declare const fetchWithCache: <T>(...args: any[]) => Promise<T>;
|
6
|
+
export declare const handleWSEventWithCache: (fnThat: any, fn: any, ttl: any, eventParser: any, eventFilter: any, eventIdSelector: any) => (event: any) => Promise<void>;
|
7
|
+
export declare const sleep: (millsec?: number) => Promise<void>;
|
8
|
+
export declare const convertDiff: (diff: string | null) => any;
|
@@ -0,0 +1,80 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
exports.convertDiff = exports.sleep = exports.handleWSEventWithCache = exports.fetchWithCache = void 0;
|
18
|
+
const cache_1 = require("../utils/cache");
|
19
|
+
const lru_cache_1 = require("lru-cache");
|
20
|
+
__exportStar(require("./cache"), exports);
|
21
|
+
__exportStar(require("./s3"), exports);
|
22
|
+
__exportStar(require("./preference"), exports);
|
23
|
+
__exportStar(require("./puppeteer"), exports);
|
24
|
+
const fetchWithCache = async (...args) => {
|
25
|
+
const res = cache_1.cache.get(args);
|
26
|
+
if (res) {
|
27
|
+
return res;
|
28
|
+
}
|
29
|
+
const result = await fetch(args).then((res) => res.json());
|
30
|
+
cache_1.cache.set(args, result);
|
31
|
+
return result;
|
32
|
+
};
|
33
|
+
exports.fetchWithCache = fetchWithCache;
|
34
|
+
// export const fetch = async (...args) => {}
|
35
|
+
const handleWSEventWithCache = (fnThat, fn, ttl, eventParser, eventFilter, eventIdSelector) => {
|
36
|
+
const WSCache = new lru_cache_1.LRUCache({
|
37
|
+
max: 500,
|
38
|
+
size: 50,
|
39
|
+
sizeCalculation: (value, key) => 1,
|
40
|
+
// for use with tracking overall storage size
|
41
|
+
maxSize: 5000,
|
42
|
+
allowStale: false,
|
43
|
+
updateAgeOnGet: false,
|
44
|
+
noUpdateTTL: true,
|
45
|
+
ttl: ttl,
|
46
|
+
});
|
47
|
+
return async function (event) {
|
48
|
+
const data = eventParser(event);
|
49
|
+
const key = eventIdSelector(data);
|
50
|
+
if (!eventFilter(data) || WSCache.get(key)) {
|
51
|
+
// console.log(`${key} hit cache, skip it, remainingTTL: `, WSCache.getRemainingTTL(key))
|
52
|
+
return;
|
53
|
+
}
|
54
|
+
WSCache.set(key, true);
|
55
|
+
await fn.apply(fnThat, [data]);
|
56
|
+
};
|
57
|
+
};
|
58
|
+
exports.handleWSEventWithCache = handleWSEventWithCache;
|
59
|
+
const sleep = async (millsec = 5000) => {
|
60
|
+
await new Promise((resolve, reject) => {
|
61
|
+
setTimeout(resolve, millsec);
|
62
|
+
});
|
63
|
+
};
|
64
|
+
exports.sleep = sleep;
|
65
|
+
const diffMap = {
|
66
|
+
E: 'Easy',
|
67
|
+
N: 'Normal',
|
68
|
+
H: 'Hard',
|
69
|
+
EX: 'Expert',
|
70
|
+
EP: 'ExpertPlus',
|
71
|
+
'EX+': 'ExpertPlus',
|
72
|
+
};
|
73
|
+
const convertDiff = (diff) => {
|
74
|
+
if (!diff) {
|
75
|
+
return diff;
|
76
|
+
}
|
77
|
+
return diffMap[diff.toUpperCase()];
|
78
|
+
};
|
79
|
+
exports.convertDiff = convertDiff;
|
80
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,yCAAqC;AACrC,yCAAoC;AAEpC,0CAAuB;AACvB,uCAAoB;AAEpB,+CAA4B;AAC5B,8CAA2B;AAEpB,MAAM,cAAc,GAAG,KAAK,EAAK,GAAG,IAAI,EAAc,EAAE;IAC7D,MAAM,GAAG,GAAG,aAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IAC3B,IAAI,GAAG,EAAE,CAAC;QACR,OAAO,GAAQ,CAAA;IACjB,CAAC;IACD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,IAAW,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAO,CAAC,CAAA;IACtE,aAAK,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;IACvB,OAAO,MAAW,CAAA;AACpB,CAAC,CAAA;AARY,QAAA,cAAc,kBAQ1B;AAED,6CAA6C;AAEtC,MAAM,sBAAsB,GAAG,CACpC,MAAM,EACN,EAAE,EACF,GAAG,EACH,WAAW,EACX,WAAW,EACX,eAAe,EACf,EAAE;IACF,MAAM,OAAO,GAAG,IAAI,oBAAQ,CAAC;QAC3B,GAAG,EAAE,GAAG;QACR,IAAI,EAAE,EAAE;QACR,eAAe,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;QAClC,6CAA6C;QAC7C,OAAO,EAAE,IAAI;QACb,UAAU,EAAE,KAAK;QACjB,cAAc,EAAE,KAAK;QACrB,WAAW,EAAE,IAAI;QACjB,GAAG,EAAE,GAAG;KACT,CAAC,CAAA;IAEF,OAAO,KAAK,WAAW,KAAU;QAC/B,MAAM,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,CAAA;QAC/B,MAAM,GAAG,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC3C,yFAAyF;YACzF,OAAM;QACR,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;QACtB,MAAM,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAChC,CAAC,CAAA;AACH,CAAC,CAAA;AA9BY,QAAA,sBAAsB,0BA8BlC;AAEM,MAAM,KAAK,GAAG,KAAK,EAAE,UAAkB,IAAI,EAAE,EAAE;IACpD,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC1C,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;IAC9B,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AAJY,QAAA,KAAK,SAIjB;AAED,MAAM,OAAO,GAAG;IACd,CAAC,EAAE,MAAM;IACT,CAAC,EAAE,QAAQ;IACX,CAAC,EAAE,MAAM;IACT,EAAE,EAAE,QAAQ;IACZ,EAAE,EAAE,YAAY;IAChB,KAAK,EAAE,YAAY;CACpB,CAAA;AAEM,MAAM,WAAW,GAAG,CAAC,IAAmB,EAAE,EAAE;IACjD,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,IAAI,CAAA;IACb,CAAC;IACD,OAAO,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;AACpC,CAAC,CAAA;AALY,QAAA,WAAW,eAKvB"}
|
@@ -0,0 +1,35 @@
|
|
1
|
+
import { DB } from '../interface';
|
2
|
+
export declare class UserPreferenceStore {
|
3
|
+
private db;
|
4
|
+
private uid;
|
5
|
+
v: any;
|
6
|
+
constructor(db: DB<any>, uid: number);
|
7
|
+
getUserPreference(uid: number): Promise<UserPreferenceStore>;
|
8
|
+
set<T extends string | number | boolean>(key: string, value: T): Promise<boolean>;
|
9
|
+
get<T extends string | number | boolean>(key: string): Promise<T | undefined>;
|
10
|
+
configEntries(): Promise<Record<string, any>>;
|
11
|
+
}
|
12
|
+
type PreferenceItem = {
|
13
|
+
key: string;
|
14
|
+
i18nName: string;
|
15
|
+
valueType: 'img-url' | 'string' | 'number' | 'boolean';
|
16
|
+
default: any;
|
17
|
+
};
|
18
|
+
export declare const preferenceKey: {
|
19
|
+
blProfileRenderImg: {
|
20
|
+
key: string;
|
21
|
+
i18nName: string;
|
22
|
+
};
|
23
|
+
ssProfileRenderImg: {
|
24
|
+
key: string;
|
25
|
+
i18nName: string;
|
26
|
+
};
|
27
|
+
blScoreImg: {
|
28
|
+
key: string;
|
29
|
+
i18nName: string;
|
30
|
+
};
|
31
|
+
};
|
32
|
+
export declare const preferenceSchema: Record<string, PreferenceItem>;
|
33
|
+
export declare const hasPreferenceSchemaByKeyOrName: (key: string) => boolean;
|
34
|
+
export declare const getPreferenceSchemaByKeyOrName: (key: string) => PreferenceItem;
|
35
|
+
export {};
|