beatsaber-bot-core 0.2.0-dev.1 → 0.2.0-dev.10
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/blRequset.js +7 -7
- package/lib/api/base/blRequset.js.map +1 -1
- package/lib/api/composed/beatleader.d.ts +5 -0
- package/lib/api/composed/beatleader.js +22 -1
- package/lib/api/composed/beatleader.js.map +1 -1
- package/lib/api/interfaces/beatsaver/ws.d.ts +8 -2
- package/lib/cmd/bind/bind-beatleader.js.map +1 -1
- package/lib/cmd/bind/bind-beatsaver.js.map +1 -1
- package/lib/cmd/bind/bind-id-beatleader.js.map +1 -1
- package/lib/cmd/bind/bind-scoresaber.js.map +1 -1
- package/lib/cmd/bind/index.d.ts +2 -2
- package/lib/cmd/bsmap/id-search.d.ts +1 -1
- package/lib/cmd/bsmap/id-search.js +1 -1
- package/lib/cmd/bsmap/id-search.js.map +1 -1
- package/lib/cmd/bsmap/key-search.d.ts +1 -1
- package/lib/cmd/bsmap/latest.d.ts +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/deprecated/cmp.d.ts +1 -1
- package/lib/cmd/deprecated/me.d.ts +2 -2
- package/lib/cmd/deprecated/tmp.d.ts +1 -1
- package/lib/cmd/deprecated/whois.d.ts +2 -2
- package/lib/cmd/help.d.ts +1 -1
- package/lib/cmd/rank.d.ts +2 -2
- package/lib/cmd/rank.js +4 -2
- package/lib/cmd/rank.js.map +1 -1
- package/lib/cmd/score.d.ts +2 -2
- 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/db/index.d.ts +0 -34
- package/lib/db/index.js +0 -2
- package/lib/errors/index.d.ts +25 -41
- package/lib/errors/index.js +54 -59
- package/lib/errors/index.js.map +1 -1
- package/lib/img-render/components/RankDifficulty.d.ts +5 -0
- package/lib/img-render/components/RankDifficulty.js +11 -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/rankScoreItem.d.ts +15 -0
- package/lib/img-render/components/rankScoreItem.js +38 -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/index.js +6 -2
- package/lib/img-render/index.js.map +1 -1
- package/lib/img-render/render.js +26 -1
- package/lib/img-render/render.js.map +1 -1
- 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 +21 -0
- package/lib/img-render/result/bs-score-with-rank.js.map +1 -0
- package/lib/img-render/result/index.d.ts +1 -0
- package/lib/img-render/result/index.js +6 -1
- package/lib/img-render/result/index.js.map +1 -1
- package/lib/img-render/utils/format.d.ts +2 -0
- package/lib/img-render/utils/format.js +11 -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/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/{db.d.ts → db/index.d.ts} +2 -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 +34 -0
- package/lib/interface/{db.js → db/models.js} +1 -1
- 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/schedules/index.d.ts +3 -2
- package/lib/schedules/index.js +13 -16
- package/lib/schedules/index.js.map +1 -1
- package/lib/schedules/interface.d.ts +17 -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 +9 -9
- package/lib/schedules/oauthTokenRefreshTask.js.map +1 -1
- package/lib/schedules/temp.d.ts +1 -5
- package/lib/schedules/temp.js +25 -20
- package/lib/schedules/temp.js.map +1 -1
- package/lib/utils/cache.d.ts +2 -0
- package/lib/utils/cache.js +28 -0
- package/lib/utils/cache.js.map +1 -0
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/index.js +77 -0
- package/lib/utils/index.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 +2 -1
- package/lib/cmd/decrepeted/cmp.d.ts +0 -9
- package/lib/cmd/decrepeted/cmp.js +0 -15
- package/lib/cmd/decrepeted/cmp.js.map +0 -1
- package/lib/cmd/decrepeted/me.d.ts +0 -13
- package/lib/cmd/decrepeted/me.js +0 -66
- package/lib/cmd/decrepeted/me.js.map +0 -1
- package/lib/cmd/decrepeted/tmp.d.ts +0 -9
- package/lib/cmd/decrepeted/tmp.js +0 -21
- package/lib/cmd/decrepeted/tmp.js.map +0 -1
- package/lib/cmd/decrepeted/whois.d.ts +0 -11
- package/lib/cmd/decrepeted/whois.js +0 -40
- package/lib/cmd/decrepeted/whois.js.map +0 -1
- package/lib/cmd/subscribe/alert.d.ts +0 -0
- package/lib/cmd/subscribe/alert.js +0 -86
- package/lib/cmd/subscribe/alert.js.map +0 -1
- package/lib/cmd/subscribe/blfilters.d.ts +0 -0
- package/lib/cmd/subscribe/blfilters.js +0 -49
- package/lib/cmd/subscribe/blfilters.js.map +0 -1
- package/lib/cmd/subscribe/scoresaber.d.ts +0 -0
- package/lib/cmd/subscribe/scoresaber.js +0 -43
- package/lib/cmd/subscribe/scoresaber.js.map +0 -1
- package/lib/interface/db.js.map +0 -1
- package/lib/interface/tables.d.ts +0 -0
- 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
@@ -5,3 +5,4 @@ export declare const getBSMapComp: (bsMap: BSMap, bsMapQrUrl: string, previewQrU
|
|
5
5
|
export declare const getSSPlayerComp: (scores: ScoreSaberItem[], userInfo: ScoreSaberUser) => import("react/jsx-runtime").JSX.Element;
|
6
6
|
export declare const getBLPlayerComp: (scores: Score[], userInfo: BeatLeaderUser) => import("react/jsx-runtime").JSX.Element;
|
7
7
|
export declare const getBLScoreComp: (score: Score, bsMap: BSMap, statistic: any, bsor: any, qrcodeUrl: string) => import("react/jsx-runtime").JSX.Element;
|
8
|
+
export declare const getBLRankScoreComp: (score: any, aroundScores: any, regionTopScores: any, difficulties: any, bsMap: any, statistic: any, bsor: any) => import("react/jsx-runtime").JSX.Element;
|
@@ -3,12 +3,13 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
4
|
};
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
-
exports.getBLScoreComp = exports.getBLPlayerComp = exports.getSSPlayerComp = exports.getBSMapComp = void 0;
|
6
|
+
exports.getBLRankScoreComp = exports.getBLScoreComp = exports.getBLPlayerComp = exports.getSSPlayerComp = exports.getBSMapComp = void 0;
|
7
7
|
const jsx_runtime_1 = require("react/jsx-runtime");
|
8
8
|
const bs_map_1 = __importDefault(require("./bs-map"));
|
9
9
|
const ss_player_1 = __importDefault(require("./ss-player"));
|
10
10
|
const bl_player_1 = __importDefault(require("./bl-player"));
|
11
11
|
const bl_score_1 = require("./bl-score");
|
12
|
+
const bs_score_with_rank_1 = __importDefault(require("../../img-render/result/bs-score-with-rank"));
|
12
13
|
const getBSMapComp = (bsMap, bsMapQrUrl, previewQrUrl) => {
|
13
14
|
return ((0, jsx_runtime_1.jsx)(bs_map_1.default, { bsMap: bsMap, bsMapQrUrl: bsMapQrUrl, previewQrUrl: previewQrUrl }));
|
14
15
|
};
|
@@ -25,4 +26,8 @@ const getBLScoreComp = (score, bsMap, statistic, bsor, qrcodeUrl) => {
|
|
25
26
|
return ((0, jsx_runtime_1.jsx)(bl_score_1.BLScore, { score: score, bsMap: bsMap, statistic: statistic, bsor: bsor, qrcodeUrl: qrcodeUrl }));
|
26
27
|
};
|
27
28
|
exports.getBLScoreComp = getBLScoreComp;
|
29
|
+
const getBLRankScoreComp = (score, aroundScores, regionTopScores, difficulties, bsMap, statistic, bsor) => {
|
30
|
+
return ((0, jsx_runtime_1.jsx)(bs_score_with_rank_1.default, { score: score, bsMap: bsMap, aroundScores: aroundScores, regionTopScores: regionTopScores, difficulties: difficulties, statistic: statistic, bsor: bsor }));
|
31
|
+
};
|
32
|
+
exports.getBLRankScoreComp = getBLRankScoreComp;
|
28
33
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/img-render/result/index.tsx"],"names":[],"mappings":";;;;;;;AACA,sDAAiC;AACjC,4DAAsC;AACtC,4DAAsC;AACtC,yCAAoC;
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/img-render/result/index.tsx"],"names":[],"mappings":";;;;;;;AACA,sDAAiC;AACjC,4DAAsC;AACtC,4DAAsC;AACtC,yCAAoC;AAIpC,gGAAgE;AAEzD,MAAM,YAAY,GAAG,CAC1B,KAAY,EACZ,UAAkB,EAClB,YAAoB,EACpB,EAAE;IACF,OAAO,CACL,uBAAC,gBAAU,IACT,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,UAAU,EACtB,YAAY,EAAE,YAAY,GAC1B,CACH,CAAA;AACH,CAAC,CAAA;AAZY,QAAA,YAAY,gBAYxB;AACM,MAAM,eAAe,GAAG,CAC7B,MAAwB,EACxB,QAAwB,EACxB,EAAE;IACF,OAAO,uBAAC,mBAAY,IAAC,SAAS,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,GAAI,CAAA;AACnE,CAAC,CAAA;AALY,QAAA,eAAe,mBAK3B;AAEM,MAAM,eAAe,GAAG,CAAC,MAAe,EAAE,QAAwB,EAAE,EAAE;IAC3E,OAAO,uBAAC,mBAAY,IAAC,IAAI,EAAE,QAAQ,EAAE,eAAe,EAAE,MAAM,GAAI,CAAA;AAClE,CAAC,CAAA;AAFY,QAAA,eAAe,mBAE3B;AAEM,MAAM,cAAc,GAAG,CAC5B,KAAY,EACZ,KAAY,EACZ,SAAc,EACd,IAAS,EACT,SAAiB,EACjB,EAAE;IACF,OAAO,CACL,uBAAC,kBAAO,IACN,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,SAAS,EACpB,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,SAAS,GACpB,CACH,CAAA;AACH,CAAC,CAAA;AAhBY,QAAA,cAAc,kBAgB1B;AAEM,MAAM,kBAAkB,GAAG,CAChC,KAAK,EACL,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,KAAK,EACL,SAAS,EACT,IAAI,EACJ,EAAE;IACF,OAAO,CACL,uBAAC,4BAAW,IACV,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,YAAY,EAC1B,eAAe,EAAE,eAAe,EAChC,YAAY,EAAE,YAAY,EAC1B,SAAS,EAAE,SAAS,EACpB,IAAI,EAAE,IAAI,GACV,CACH,CAAA;AACH,CAAC,CAAA;AApBY,QAAA,kBAAkB,sBAoB9B"}
|
@@ -1,3 +1,5 @@
|
|
1
1
|
export declare const formatDuration: (duration: number) => string;
|
2
2
|
export declare const formatTime: (time: string) => string;
|
3
3
|
export declare const formatNumber: (number: number) => string;
|
4
|
+
export declare function numberWithCommas(x: number): string;
|
5
|
+
export declare const formatDate: (time: Date | undefined, template?: string) => string;
|
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
4
|
};
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
-
exports.formatNumber = exports.formatTime = exports.formatDuration = void 0;
|
6
|
+
exports.formatDate = exports.numberWithCommas = exports.formatNumber = exports.formatTime = exports.formatDuration = void 0;
|
7
7
|
const dayjs_1 = __importDefault(require("dayjs"));
|
8
8
|
const duration_1 = __importDefault(require("dayjs/plugin/duration"));
|
9
9
|
const relativeTime_1 = __importDefault(require("dayjs/plugin/relativeTime"));
|
@@ -39,4 +39,14 @@ const formatNumber = (number) => {
|
|
39
39
|
}
|
40
40
|
};
|
41
41
|
exports.formatNumber = formatNumber;
|
42
|
+
function numberWithCommas(x) {
|
43
|
+
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',');
|
44
|
+
}
|
45
|
+
exports.numberWithCommas = numberWithCommas;
|
46
|
+
const formatDate = (time, template) => {
|
47
|
+
if (!time)
|
48
|
+
return undefined;
|
49
|
+
return (0, dayjs_1.default)(time).format(template ?? 'YYYY-MM-DD');
|
50
|
+
};
|
51
|
+
exports.formatDate = formatDate;
|
42
52
|
//# sourceMappingURL=format.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"format.js","sourceRoot":"","sources":["../../../src/img-render/utils/format.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAyB;AACzB,qEAA4C;AAC5C,6EAAoD;AACpD,+DAAmC;AACnC,eAAK,CAAC,MAAM,CAAC,kBAAQ,CAAC,CAAA;AACtB,eAAK,CAAC,MAAM,CAAC,sBAAY,CAAC,CAAA;AACnB,MAAM,cAAc,GAAG,CAAC,QAAgB,EAAE,EAAE;IACjD,MAAM,CAAC,GAAG,eAAK,CAAC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;IAC5C,OAAO,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;AAC7B,CAAC,CAAA;AAHY,QAAA,cAAc,kBAG1B;AAED,wDAAwD;AACxD,8DAA8D;AAC9D,IAAI;AAEG,MAAM,UAAU,GAAG,CAAC,IAAY,EAAE,EAAE;IACzC,OAAO,IAAA,eAAK,EAAC,IAAI,CAAC,CAAC,MAAM,CAAC,eAAE,CAAC,CAAC,OAAO,EAAE,CAAA;AACzC,CAAC,CAAA;AAFY,QAAA,UAAU,cAEtB;AAEM,MAAM,YAAY,GAAG,CAAC,MAAc,EAAE,EAAE;IAC7C,QAAQ;IACR,IAAI,CAAC;QACH,IAAI,MAAM,GAAG,KAAK,EAAE,CAAC;YACnB,OAAO,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAA;QAC5C,CAAC;QACD,QAAQ;QACR,IAAI,MAAM,GAAG,IAAI,EAAE,CAAC;YAClB,OAAO,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAA;QAC3C,CAAC;QACD,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAA;IAC1B,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,GAAG,CAAA;IACZ,CAAC;AACH,CAAC,CAAA;AAdY,QAAA,YAAY,gBAcxB"}
|
1
|
+
{"version":3,"file":"format.js","sourceRoot":"","sources":["../../../src/img-render/utils/format.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAyB;AACzB,qEAA4C;AAC5C,6EAAoD;AACpD,+DAAmC;AACnC,eAAK,CAAC,MAAM,CAAC,kBAAQ,CAAC,CAAA;AACtB,eAAK,CAAC,MAAM,CAAC,sBAAY,CAAC,CAAA;AACnB,MAAM,cAAc,GAAG,CAAC,QAAgB,EAAE,EAAE;IACjD,MAAM,CAAC,GAAG,eAAK,CAAC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;IAC5C,OAAO,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;AAC7B,CAAC,CAAA;AAHY,QAAA,cAAc,kBAG1B;AAED,wDAAwD;AACxD,8DAA8D;AAC9D,IAAI;AAEG,MAAM,UAAU,GAAG,CAAC,IAAY,EAAE,EAAE;IACzC,OAAO,IAAA,eAAK,EAAC,IAAI,CAAC,CAAC,MAAM,CAAC,eAAE,CAAC,CAAC,OAAO,EAAE,CAAA;AACzC,CAAC,CAAA;AAFY,QAAA,UAAU,cAEtB;AAEM,MAAM,YAAY,GAAG,CAAC,MAAc,EAAE,EAAE;IAC7C,QAAQ;IACR,IAAI,CAAC;QACH,IAAI,MAAM,GAAG,KAAK,EAAE,CAAC;YACnB,OAAO,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAA;QAC5C,CAAC;QACD,QAAQ;QACR,IAAI,MAAM,GAAG,IAAI,EAAE,CAAC;YAClB,OAAO,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAA;QAC3C,CAAC;QACD,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAA;IAC1B,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,GAAG,CAAA;IACZ,CAAC;AACH,CAAC,CAAA;AAdY,QAAA,YAAY,gBAcxB;AAED,SAAgB,gBAAgB,CAAC,CAAS;IACxC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAA;AAC3D,CAAC;AAFD,4CAEC;AACM,MAAM,UAAU,GAAG,CAAC,IAAsB,EAAE,QAAiB,EAAE,EAAE;IACtE,IAAI,CAAC,IAAI;QAAE,OAAO,SAAS,CAAA;IAC3B,OAAO,IAAA,eAAK,EAAC,IAAI,CAAC,CAAC,MAAM,CAAC,QAAQ,IAAI,YAAY,CAAC,CAAA;AACrD,CAAC,CAAA;AAHY,QAAA,UAAU,cAGtB"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/img-render/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,2CAAwB;AACxB,+CAA4B;AAErB,MAAM,QAAQ,GAAG,CAAC,IAAY,EAAE,EAAE;IACvC,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;QAChC,OAAO,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/img-render/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,2CAAwB;AACxB,+CAA4B;AAErB,MAAM,QAAQ,GAAG,CAAC,IAAY,EAAE,EAAE;IACvC,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;QAChC,OAAO,KAAK,CAAA;IACd,CAAC;SAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;QACnC,OAAO,IAAI,CAAA;IACb,CAAC;SAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QACjC,OAAO,GAAG,CAAA;IACZ,CAAC;SAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;QACnC,OAAO,GAAG,CAAA;IACZ,CAAC;IACD,OAAO,GAAG,CAAA;AACZ,CAAC,CAAA;AAXY,QAAA,QAAQ,YAWpB"}
|
package/lib/index.d.ts
CHANGED
package/lib/index.js
CHANGED
@@ -15,11 +15,11 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
17
|
__exportStar(require("./interface"), exports);
|
18
|
-
__exportStar(require("./db"), exports);
|
19
18
|
__exportStar(require("./api"), exports);
|
20
19
|
__exportStar(require("./schedules"), exports);
|
21
20
|
__exportStar(require("./config"), exports);
|
22
21
|
__exportStar(require("./i18n"), exports);
|
23
22
|
__exportStar(require("./cmd"), exports);
|
24
23
|
__exportStar(require("./ws"), exports);
|
24
|
+
__exportStar(require("./utils"), exports);
|
25
25
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA2B;AAC3B,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA2B;AAC3B,wCAAqB;AACrB,8CAA2B;AAC3B,2CAAwB;AACxB,yCAAsB;AACtB,wCAAqB;AACrB,uCAAoB;AACpB,0CAAuB"}
|
package/lib/interface/bot.d.ts
CHANGED
@@ -1,4 +1,5 @@
|
|
1
|
-
import { RelateAccount, RelateChannelInfo, Subscribe, SubscribeMember } from '
|
1
|
+
import { RelateAccount, RelateChannelInfo, Subscribe, SubscribeMember } from './models';
|
2
|
+
export * from './models';
|
2
3
|
export interface SubInfoRes {
|
3
4
|
subscribe: Subscribe;
|
4
5
|
memberCount: number;
|
@@ -29,7 +30,6 @@ export interface DB<T> {
|
|
29
30
|
getSubscriptionInfoByUGID(gid: number, uid: number): Promise<SubInfoRes[]>;
|
30
31
|
getSubscriptionsByGID(gid: number): Promise<Record<string, Subscribe>>;
|
31
32
|
getAllSubScriptionByUIDAndPlatform(id: string | number, type: string): Promise<SubDetailWithGroupRes<T>[]>;
|
32
|
-
getSubscriptionInfoByType(type: string): Promise<SubWithGroupRes<T>[]>;
|
33
33
|
addSubscribeMember(data: Partial<SubscribeMember>): Promise<void>;
|
34
34
|
removeFromSubGroupBySubAndUid(subId: number, id: number): Promise<void>;
|
35
35
|
}
|
@@ -0,0 +1,18 @@
|
|
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
|
+
__exportStar(require("./models"), exports);
|
18
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/interface/db/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAOA,2CAAwB"}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
export interface RelateAccount {
|
2
|
+
id: number;
|
3
|
+
uid: number;
|
4
|
+
type: string;
|
5
|
+
platform: string;
|
6
|
+
platformUname: string;
|
7
|
+
platformUid: string;
|
8
|
+
platformScope: string;
|
9
|
+
accessToken: string;
|
10
|
+
refreshToken: string;
|
11
|
+
otherPlatformInfo: any;
|
12
|
+
lastModifiedAt: Date;
|
13
|
+
lastRefreshAt: Date;
|
14
|
+
status: string;
|
15
|
+
}
|
16
|
+
export interface SubscribeMember {
|
17
|
+
subscribeId: number;
|
18
|
+
memberUid: number;
|
19
|
+
subscribeData: any;
|
20
|
+
joinedAt: Date;
|
21
|
+
}
|
22
|
+
export interface Subscribe {
|
23
|
+
id: number;
|
24
|
+
gid: number;
|
25
|
+
type: string;
|
26
|
+
time: Date;
|
27
|
+
enable: boolean;
|
28
|
+
data: any;
|
29
|
+
}
|
30
|
+
export type RelateChannelInfo<CHANNEL> = {
|
31
|
+
id: number;
|
32
|
+
name: string;
|
33
|
+
type: 'user' | 'group' | string;
|
34
|
+
} & CHANNEL;
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../src/interface/db/models.ts"],"names":[],"mappings":""}
|
package/lib/interface/index.d.ts
CHANGED
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"}
|
package/lib/schedules/index.d.ts
CHANGED
@@ -1,2 +1,3 @@
|
|
1
|
-
|
2
|
-
|
1
|
+
import { ScheduleTask } from '../schedules/interface';
|
2
|
+
import { Config } from '../config';
|
3
|
+
export declare const getScheduleTasks: (config: Config) => ScheduleTask[];
|
package/lib/schedules/index.js
CHANGED
@@ -1,19 +1,16 @@
|
|
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 oauthTokenRefreshTask = {
|
6
|
+
name: 'oauthTokenRefreshTask',
|
7
|
+
// config
|
8
|
+
cron: '',
|
9
|
+
executor: oauthTokenRefreshTask_1.tokenRefreshTask,
|
10
|
+
};
|
11
|
+
const getScheduleTasks = (config) => {
|
12
|
+
// oauthTokenRefreshTask
|
13
|
+
return [];
|
14
|
+
};
|
15
|
+
exports.getScheduleTasks = getScheduleTasks;
|
19
16
|
//# 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;AAI1D,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,wBAAwB;IACxB,OAAO,EAAoB,CAAA;AAC7B,CAAC,CAAA;AAHY,QAAA,gBAAgB,oBAG5B"}
|
@@ -0,0 +1,17 @@
|
|
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
|
+
executor: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
|
17
|
+
};
|
@@ -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.wrapperResult().refreshOAuthToken(account.refreshToken);
|
17
|
+
const token = await c.api.BeatLeader.wrapperResult().refreshOAuthToken(account.refreshToken);
|
18
18
|
if (!token.isSuccess()) {
|
19
|
-
logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
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])
|
@@ -28,9 +28,9 @@ const tokenRefreshTask = async (config, db, render, api, logger, botService) =>
|
|
28
28
|
account.refreshToken = token.data.refresh_token;
|
29
29
|
}
|
30
30
|
else if (account.platform === 'beatsaver') {
|
31
|
-
const token = await api.BeatSaver.wrapperResult().refreshOAuthToken(account.refreshToken);
|
31
|
+
const token = await c.api.BeatSaver.wrapperResult().refreshOAuthToken(account.refreshToken);
|
32
32
|
if (!token.isSuccess()) {
|
33
|
-
logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
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])
|
@@ -45,9 +45,9 @@ const tokenRefreshTask = async (config, db, render, api, logger, botService) =>
|
|
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,aAAa,EAAE,CAAC,iBAAiB,CACpE,OAAO,CAAC,YAAY,CACrB,CAAA;YACD,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;gBACvB,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,IAAI,CAAC,YAAY,CAAA;YAC7C,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,aAAa,CAAA;QACjD,CAAC;aAAM,IAAI,OAAO,CAAC,QAAQ,KAAK,WAAW,EAAE,CAAC;YAC5C,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC,iBAAiB,CACnE,OAAO,CAAC,YAAY,CACrB,CAAA;YACD,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;gBACvB,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,IAAI,CAAC,YAAY,CAAA;YAC7C,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,aAAa,CAAA;QACjD,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 @@
|
|
1
|
-
|
2
|
-
import { BotService, DB, Logger, Session } from '../interface';
|
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
|
+
export {};
|
package/lib/schedules/temp.js
CHANGED
@@ -1,23 +1,28 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
3
|
+
// export const LBScoreMonitor = async <T>(
|
4
|
+
// config: Config,
|
5
|
+
// db: DB<T>,
|
6
|
+
// render: RenderService,
|
7
|
+
// api: APIService,
|
8
|
+
// logger: Logger,
|
9
|
+
// botService: BotService<T, Session<T>>
|
10
|
+
// ) => {
|
11
|
+
// const channels = await db.getSubscriptionInfoByType('lb-rank')
|
12
|
+
// if (channels.length <= 0) {
|
13
|
+
// return
|
14
|
+
// }
|
15
|
+
// const [hitbuf, scorebuf] = await Promise.all([
|
16
|
+
// render.renderUrl('https://aiobs.ktlab.io/tmp/lb/hitcnt'),
|
17
|
+
// render.renderUrl('https://aiobs.ktlab.io/tmp/lb/score'),
|
18
|
+
// ])
|
19
|
+
// for (const group of channels) {
|
20
|
+
// const session = botService.getSessionByChannelInfo(group.groupChannel)
|
21
|
+
// if (!session) {
|
22
|
+
// continue
|
23
|
+
// }
|
24
|
+
// await session.sendImgBuffer(hitbuf, 'image/png')
|
25
|
+
// await session.sendImgBuffer(scorebuf, 'image/png')
|
26
|
+
// }
|
27
|
+
// }
|
23
28
|
//# sourceMappingURL=temp.js.map
|
@@ -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":";;AAKA,2CAA2C;AAC3C,oBAAoB;AACpB,eAAe;AACf,2BAA2B;AAC3B,qBAAqB;AACrB,oBAAoB;AACpB,0CAA0C;AAC1C,SAAS;AACT,mEAAmE;AACnE,gCAAgC;AAChC,aAAa;AACb,MAAM;AACN,mDAAmD;AACnD,gEAAgE;AAChE,+DAA+D;AAC/D,OAAO;AACP,oCAAoC;AACpC,6EAA6E;AAC7E,sBAAsB;AACtB,iBAAiB;AACjB,QAAQ;AACR,uDAAuD;AACvD,yDAAyD;AACzD,MAAM;AACN,IAAI"}
|
@@ -0,0 +1,28 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
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
|
+
//# 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"}
|
@@ -0,0 +1,5 @@
|
|
1
|
+
export * from './cache';
|
2
|
+
export declare const fetchWithCache: <T>(...args: any[]) => Promise<T>;
|
3
|
+
export declare const handleWSEventWithCache: (fnThat: any, fn: any, ttl: any, eventParser: any, eventFilter: any, eventIdSelector: any) => (event: any) => Promise<void>;
|
4
|
+
export declare const sleep: (millsec?: number) => Promise<void>;
|
5
|
+
export declare const convertDiff: (diff: string | null) => any;
|
@@ -0,0 +1,77 @@
|
|
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
|
+
const fetchWithCache = async (...args) => {
|
22
|
+
const res = cache_1.cache.get(args);
|
23
|
+
if (res) {
|
24
|
+
return res;
|
25
|
+
}
|
26
|
+
const result = await fetch(args).then((res) => res.json());
|
27
|
+
cache_1.cache.set(args, result);
|
28
|
+
return result;
|
29
|
+
};
|
30
|
+
exports.fetchWithCache = fetchWithCache;
|
31
|
+
// export const fetch = async (...args) => {}
|
32
|
+
const handleWSEventWithCache = (fnThat, fn, ttl, eventParser, eventFilter, eventIdSelector) => {
|
33
|
+
const WSCache = new lru_cache_1.LRUCache({
|
34
|
+
max: 500,
|
35
|
+
size: 50,
|
36
|
+
sizeCalculation: (value, key) => 1,
|
37
|
+
// for use with tracking overall storage size
|
38
|
+
maxSize: 5000,
|
39
|
+
allowStale: false,
|
40
|
+
updateAgeOnGet: false,
|
41
|
+
noUpdateTTL: true,
|
42
|
+
ttl: ttl,
|
43
|
+
});
|
44
|
+
return async function (event) {
|
45
|
+
const data = eventParser(event);
|
46
|
+
const key = eventIdSelector(data);
|
47
|
+
if (eventFilter(data) || WSCache.get(key)) {
|
48
|
+
// console.log(`${key} hit cache, skip it, remainingTTL: `, WSCache.getRemainingTTL(key))
|
49
|
+
return;
|
50
|
+
}
|
51
|
+
WSCache.set(key, true);
|
52
|
+
await fn.apply(fnThat, [data]);
|
53
|
+
};
|
54
|
+
};
|
55
|
+
exports.handleWSEventWithCache = handleWSEventWithCache;
|
56
|
+
const sleep = async (millsec = 5000) => {
|
57
|
+
await new Promise((resolve, reject) => {
|
58
|
+
setTimeout(resolve, millsec);
|
59
|
+
});
|
60
|
+
};
|
61
|
+
exports.sleep = sleep;
|
62
|
+
const diffMap = {
|
63
|
+
E: 'Easy',
|
64
|
+
N: 'Normal',
|
65
|
+
H: 'Hard',
|
66
|
+
EX: 'Expert',
|
67
|
+
EP: 'ExpertPlus',
|
68
|
+
'EX+': 'ExpertPlus',
|
69
|
+
};
|
70
|
+
const convertDiff = (diff) => {
|
71
|
+
if (!diff) {
|
72
|
+
return diff;
|
73
|
+
}
|
74
|
+
return diffMap[diff.toUpperCase()];
|
75
|
+
};
|
76
|
+
exports.convertDiff = convertDiff;
|
77
|
+
//# 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;AAEhB,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,WAAW,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1C,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"}
|
package/lib/ws/beatleader.js
CHANGED
@@ -30,6 +30,7 @@ class BeatleaderWSHandler {
|
|
30
30
|
// return
|
31
31
|
// }
|
32
32
|
// logger.info('Received beatleader message',data.id, data.player.id);
|
33
|
+
// cache all playerId
|
33
34
|
const subscriptions = await this.db.getAllSubScriptionByUIDAndPlatform(playerId, 'beatleader');
|
34
35
|
// .filter(item=> {
|
35
36
|
// const channelFilters = item.sub.data as BLScoreFilter[]
|
package/lib/ws/beatleader.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"beatleader.js","sourceRoot":"","sources":["../../src/ws/beatleader.ts"],"names":[],"mappings":";;;AAKA,2CAA2D;AAG3D,MAAa,mBAAmB;IACb,MAAM,CAAQ;IACvB,MAAM,CAAe;IACrB,UAAU,CAA2B;IAC7C,KAAK,GAAW,yCAAyC,CAAA;IACjD,EAAE,CAAO;IACjB,MAAM,CAAQ;IACd,YACE,EAAS,EACT,MAAqB,EACrB,MAAc,EACd,MAAc,EACd,UAAqC;QAErC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAA;IACd,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;IACzC,CAAC;IAED,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;IACzC,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,KAAU;QACtB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAsB,CAAA;QAC9D,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAA;QAC/B,mEAAmE;QACnE,aAAa;QACb,WAAW;QACX,IAAI;QACJ,sEAAsE;QACtE,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,kCAAkC,CACpE,QAAQ,EACR,YAAY,CACb,CAAA;QACD,mBAAmB;QACnB,4DAA4D;QAC5D,oDAAoD;QACpD,uEAAuE;QACvE,KAAK;QACL,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,
|
1
|
+
{"version":3,"file":"beatleader.js","sourceRoot":"","sources":["../../src/ws/beatleader.ts"],"names":[],"mappings":";;;AAKA,2CAA2D;AAG3D,MAAa,mBAAmB;IACb,MAAM,CAAQ;IACvB,MAAM,CAAe;IACrB,UAAU,CAA2B;IAC7C,KAAK,GAAW,yCAAyC,CAAA;IACjD,EAAE,CAAO;IACjB,MAAM,CAAQ;IACd,YACE,EAAS,EACT,MAAqB,EACrB,MAAc,EACd,MAAc,EACd,UAAqC;QAErC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAA;IACd,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;IACzC,CAAC;IAED,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;IACzC,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,KAAU;QACtB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAsB,CAAA;QAC9D,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAA;QAC/B,mEAAmE;QACnE,aAAa;QACb,WAAW;QACX,IAAI;QACJ,sEAAsE;QACtE,qBAAqB;QACrB,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,kCAAkC,CACpE,QAAQ,EACR,YAAY,CACb,CAAA;QACD,mBAAmB;QACnB,4DAA4D;QAC5D,oDAAoD;QACpD,uEAAuE;QACvE,KAAK;QACL,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAClC,CAAC,EAAE,EAAE,EAAE,CACL,EAAE,CAAC,SAAS,CAAC,IAAI,IAAI,kBAAkB,IAAI,EAAE,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CACzE,CAAA;QACD,eAAe;QACf,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;YAAE,OAAM;QAChC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE,oBAAQ,CAAC,EAAE,CAAC,CAAA;QAE1E,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE,CAAC;YAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAC1E,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,SAAQ;YACV,CAAC;YACD,OAAO,CAAC,IAAI,CACV,cAAc,IAAI,CAAC,OAAO,CAAC,GAAG,aAAa,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CACvH,CAAA;YACD,MAAM,OAAO,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAA;QACxC,CAAC;IACH,CAAC;CACF;AAlED,kDAkEC"}
|