beatsaber-bot-core 0.2.0-dev.7 → 0.2.0-dev.9
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/composed/beatleader.d.ts +5 -0
- package/lib/api/composed/beatleader.js +21 -0
- 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 +4 -3
- 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 -1
- 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/utils/cache.d.ts +1 -1
- package/lib/utils/cache.js +1 -3
- package/lib/utils/cache.js.map +1 -1
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +3 -5
- package/lib/utils/index.js.map +1 -1
- package/lib/ws/beatsaver.d.ts +3 -0
- package/lib/ws/beatsaver.js +26 -25
- package/lib/ws/beatsaver.js.map +1 -1
- package/package.json +1 -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
@@ -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,CAAC;AAC5D,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;
|
@@ -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/utils/cache.d.ts
CHANGED
@@ -1,2 +1,2 @@
|
|
1
1
|
import { LRUCache } from 'lru-cache';
|
2
|
-
export declare const cache: LRUCache<
|
2
|
+
export declare const cache: LRUCache<any, any, unknown>;
|
package/lib/utils/cache.js
CHANGED
@@ -6,9 +6,7 @@ const options = {
|
|
6
6
|
max: 500,
|
7
7
|
// for use with tracking overall storage size
|
8
8
|
maxSize: 5000,
|
9
|
-
|
10
|
-
// return 1
|
11
|
-
// },
|
9
|
+
sizeCalculation: (value, key) => 1,
|
12
10
|
// for use when you need to clean up something when objects
|
13
11
|
// are evicted from the cache
|
14
12
|
// dispose: (value, key) => {},
|
package/lib/utils/cache.js.map
CHANGED
@@ -1 +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,
|
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"}
|
package/lib/utils/index.d.ts
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
export * from './cache';
|
2
2
|
export declare const fetchWithCache: <T>(...args: any[]) => Promise<T>;
|
3
|
-
export declare const handleWSEventWithCache: (fnThat: any, fn: any, ttl: any,
|
3
|
+
export declare const handleWSEventWithCache: (fnThat: any, fn: any, ttl: any, eventParser: any, eventFilter: any, eventIdSelector: any) => (event: any) => Promise<void>;
|
4
4
|
export declare const sleep: (millsec?: number) => Promise<void>;
|
5
5
|
export declare const convertDiff: (diff: string | null) => any;
|
package/lib/utils/index.js
CHANGED
@@ -29,13 +29,11 @@ const fetchWithCache = async (...args) => {
|
|
29
29
|
};
|
30
30
|
exports.fetchWithCache = fetchWithCache;
|
31
31
|
// export const fetch = async (...args) => {}
|
32
|
-
const handleWSEventWithCache = (fnThat, fn, ttl,
|
32
|
+
const handleWSEventWithCache = (fnThat, fn, ttl, eventParser, eventFilter, eventIdSelector) => {
|
33
33
|
const WSCache = new lru_cache_1.LRUCache({
|
34
34
|
max: 500,
|
35
35
|
size: 50,
|
36
|
-
sizeCalculation: (value, key) =>
|
37
|
-
return 1;
|
38
|
-
},
|
36
|
+
sizeCalculation: (value, key) => 1,
|
39
37
|
// for use with tracking overall storage size
|
40
38
|
maxSize: 5000,
|
41
39
|
allowStale: false,
|
@@ -46,7 +44,7 @@ const handleWSEventWithCache = (fnThat, fn, ttl, eventIdSelector, eventParser) =
|
|
46
44
|
return async function (event) {
|
47
45
|
const data = eventParser(event);
|
48
46
|
const key = eventIdSelector(data);
|
49
|
-
if (WSCache.get(key)) {
|
47
|
+
if (eventFilter(data) || WSCache.get(key)) {
|
50
48
|
// console.log(`${key} hit cache, skip it, remainingTTL: `, WSCache.getRemainingTTL(key))
|
51
49
|
return;
|
52
50
|
}
|
package/lib/utils/index.js.map
CHANGED
@@ -1 +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,
|
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/beatsaver.d.ts
CHANGED
@@ -15,6 +15,9 @@ export declare class BeatSaverWSHandler<T> implements WSHandler {
|
|
15
15
|
constructor(db: DB<T>, render: RenderService, logger: Logger, config: Config, botService: BotService<T, Session<T>>);
|
16
16
|
onOpen(): void;
|
17
17
|
onClose(): void;
|
18
|
+
eventParser(event: any): BeatSaverWSEvent;
|
19
|
+
eventFilter: (data: BeatSaverWSEvent) => boolean;
|
20
|
+
eventIdSelector: (data: BeatSaverWSEvent) => string;
|
18
21
|
BSWSHandler(data: BeatSaverWSEvent): Promise<void>;
|
19
22
|
onEvent: (event: any) => Promise<void>;
|
20
23
|
}
|
package/lib/ws/beatsaver.js
CHANGED
@@ -22,36 +22,37 @@ class BeatSaverWSHandler {
|
|
22
22
|
onClose() {
|
23
23
|
this.logger.info('BeatsaverWS closed');
|
24
24
|
}
|
25
|
+
eventParser(event) {
|
26
|
+
return JSON.parse(event.toString());
|
27
|
+
}
|
28
|
+
eventFilter = (data) => {
|
29
|
+
return (data.type === 'MAP_UPDATE' &&
|
30
|
+
data.msg.versions.some((it) => it.state == 'Published') &&
|
31
|
+
data.msg.declaredAi === 'None');
|
32
|
+
};
|
33
|
+
eventIdSelector = (data) => `ws.bs.${data.type === 'MAP_DELETE' ? data.msg : data.msg.id}.${data.type}`;
|
25
34
|
async BSWSHandler(data) {
|
26
35
|
// this.logger.info('Beatsaver message received', data.type, data?.msg?.id)
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
const
|
37
|
-
|
38
|
-
|
39
|
-
if (restSub.length === 0)
|
40
|
-
return;
|
41
|
-
const image = this.render.renderMap(bsmap);
|
42
|
-
for (const item of restSub) {
|
43
|
-
const session = this.botService.getSessionByChannelInfo(item.groupChannel);
|
44
|
-
if (!session) {
|
45
|
-
continue;
|
46
|
-
}
|
47
|
-
await session.send(`本群谱师 「<at id="${item.account.uid}"/> (${bsmap.uploader.name})」刚刚发布了新谱面,「${bsmap.name}」`);
|
48
|
-
// text + mention element
|
49
|
-
await session.send(await image);
|
50
|
-
await session.sendAudioByUrl(bsmap.versions[0].previewURL);
|
36
|
+
const bsmap = data.msg;
|
37
|
+
const userId = bsmap.uploader.id;
|
38
|
+
const subscriptions = await this.db.getAllSubScriptionByUIDAndPlatform(userId, 'beatsaver');
|
39
|
+
const restSub = subscriptions.filter((it) => it.subscribe.type == 'beatsaver-map' && it.subscribe.enable == true);
|
40
|
+
// cacheService
|
41
|
+
if (restSub.length === 0)
|
42
|
+
return;
|
43
|
+
const image = this.render.renderMap(bsmap);
|
44
|
+
for (const item of restSub) {
|
45
|
+
const session = this.botService.getSessionByChannelInfo(item.groupChannel);
|
46
|
+
if (!session) {
|
47
|
+
continue;
|
51
48
|
}
|
49
|
+
await session.send(`本群谱师 「<at id="${item.account.uid}"/> (${bsmap.uploader.name})」刚刚发布了新谱面,「${bsmap.name}」`);
|
50
|
+
// text + mention element
|
51
|
+
await session.send(await image);
|
52
|
+
await session.sendAudioByUrl(bsmap.versions[0].previewURL);
|
52
53
|
}
|
53
54
|
}
|
54
|
-
onEvent = (0, utils_1.handleWSEventWithCache)(this, this.BSWSHandler, 1000 * 60 * 15,
|
55
|
+
onEvent = (0, utils_1.handleWSEventWithCache)(this, this.BSWSHandler, 1000 * 60 * 15, this.eventParser, this.eventFilter, this.eventIdSelector);
|
55
56
|
}
|
56
57
|
exports.BeatSaverWSHandler = BeatSaverWSHandler;
|
57
58
|
//# sourceMappingURL=beatsaver.js.map
|
package/lib/ws/beatsaver.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"beatsaver.js","sourceRoot":"","sources":["../../src/ws/beatsaver.ts"],"names":[],"mappings":";;;AAOA,mCAAuD;AAEvD,MAAa,kBAAkB;IACZ,MAAM,CAAQ;IACvB,MAAM,CAAe;IACrB,UAAU,CAA2B;IAC7C,KAAK,GAAW,6BAA6B,CAAA;IACrC,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,oBAAoB,CAAC,CAAA;IACxC,CAAC;IAED,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAA;IACxC,CAAC;IAED,
|
1
|
+
{"version":3,"file":"beatsaver.js","sourceRoot":"","sources":["../../src/ws/beatsaver.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/lib/interface/db.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/interface/db.ts"],"names":[],"mappings":""}
|
File without changes
|
package/lib/interface/tables.js
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
//# sourceMappingURL=tables.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"tables.js","sourceRoot":"","sources":["../../src/interface/tables.ts"],"names":[],"mappings":""}
|