beatsaber-bot-core 0.2.0-dev.9 → 0.2.0-rc.2
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 +20 -0
- package/lib/api/base/aioclient.js.map +1 -0
- package/lib/api/base/blclient.d.ts +18 -0
- package/lib/api/base/blclient.js +60 -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 +75 -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/ssclient.d.ts +13 -0
- package/lib/api/base/ssclient.js +48 -0
- package/lib/api/base/ssclient.js.map +1 -0
- package/lib/api/composed/beatleader.d.ts +3 -3
- package/lib/api/composed/beatleader.js +22 -9
- 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 +5 -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/index.d.ts +12 -0
- package/lib/api/interfaces/index.js +3 -0
- package/lib/{db → api/interfaces}/index.js.map +1 -1
- 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 +15 -17
- 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 +8 -10
- package/lib/cmd/bind/bind-id-beatleader.js.map +1 -1
- package/lib/cmd/bind/bind-id-beatsaver.js +8 -10
- package/lib/cmd/bind/bind-id-beatsaver.js.map +1 -1
- package/lib/cmd/bind/bind-scoresaber.js +7 -9
- package/lib/cmd/bind/bind-scoresaber.js.map +1 -1
- package/lib/cmd/bind/index.js +6 -3
- package/lib/cmd/bind/index.js.map +1 -1
- package/lib/cmd/bsmap/id-search.js +5 -6
- package/lib/cmd/bsmap/id-search.js.map +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.js +13 -19
- package/lib/cmd/bsmap/latest.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/me.d.ts +1 -1
- package/lib/cmd/deprecated/me.js +6 -6
- package/lib/cmd/deprecated/me.js.map +1 -1
- package/lib/cmd/deprecated/tmp.js +2 -0
- package/lib/cmd/deprecated/tmp.js.map +1 -1
- package/lib/cmd/deprecated/whois.js +2 -2
- package/lib/cmd/deprecated/whois.js.map +1 -1
- package/lib/cmd/help.js +2 -2
- package/lib/cmd/index.js +3 -1
- package/lib/cmd/index.js.map +1 -1
- package/lib/cmd/rank.js +13 -18
- package/lib/cmd/rank.js.map +1 -1
- package/lib/cmd/score.d.ts +1 -1
- package/lib/cmd/score.js +20 -12
- package/lib/cmd/score.js.map +1 -1
- package/lib/cmd/subscribe/id-beatleader-score.d.ts +2 -0
- package/lib/cmd/subscribe/id-beatleader-score.js +41 -0
- package/lib/cmd/subscribe/id-beatleader-score.js.map +1 -0
- package/lib/cmd/subscribe/id-beatsaver-mapper.d.ts +2 -0
- package/lib/cmd/subscribe/id-beatsaver-mapper.js +42 -0
- package/lib/cmd/subscribe/id-beatsaver-mapper.js.map +1 -0
- package/lib/cmd/subscribe/index.js +22 -6
- package/lib/cmd/subscribe/index.js.map +1 -1
- package/lib/cmd/subscribe/unsubscribe.d.ts +4 -3
- package/lib/cmd/subscribe/unsubscribe.js +38 -0
- package/lib/cmd/subscribe/unsubscribe.js.map +1 -1
- package/lib/config.d.ts +21 -4
- package/lib/errors/index.d.ts +30 -0
- package/lib/errors/index.js +94 -1
- 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 +3 -2
- package/lib/img-render/components/RankDifficulty.js +8 -2
- package/lib/img-render/components/RankDifficulty.js.map +1 -1
- package/lib/img-render/components/{rankScoreItem.d.ts → bl-rank-score-item.d.ts} +4 -1
- 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/{blScoreItem.js → bl-score-item.js} +3 -3
- package/lib/img-render/components/bl-score-item.js.map +1 -0
- package/lib/img-render/components/scoregraph.js +1 -1
- 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/{ssScoreItem.js → ss-score-item.js} +2 -2
- package/lib/img-render/components/ss-score-item.js.map +1 -0
- package/lib/img-render/index.d.ts +13 -10
- package/lib/img-render/index.js +61 -38
- package/lib/img-render/index.js.map +1 -1
- package/lib/img-render/interfaces.d.ts +2 -0
- package/lib/img-render/render.js +1 -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 +7 -4
- package/lib/img-render/result/bl-player.js.map +1 -1
- package/lib/img-render/result/{bs-score-with-rank.d.ts → bl-score-with-rank.d.ts} +2 -1
- package/lib/img-render/result/{bs-score-with-rank.js → bl-score-with-rank.js} +19 -7
- package/lib/img-render/result/bl-score-with-rank.js.map +1 -0
- package/lib/img-render/result/index.d.ts +3 -3
- package/lib/img-render/result/index.js +7 -7
- 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/utils/canvas.js +9 -3
- package/lib/img-render/utils/canvas.js.map +1 -1
- package/lib/img-render/utils/format.d.ts +1 -0
- package/lib/img-render/utils/format.js +16 -2
- package/lib/img-render/utils/format.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/interface/cmd.d.ts +3 -0
- package/lib/interface/db/index.d.ts +7 -0
- package/lib/interface/db/models.d.ts +5 -0
- package/lib/interface/render.d.ts +7 -5
- package/lib/schedules/index.d.ts +6 -2
- package/lib/schedules/index.js +9 -2
- package/lib/schedules/index.js.map +1 -1
- package/lib/schedules/interface.d.ts +2 -1
- package/lib/schedules/oauthTokenRefreshTask.js +8 -8
- package/lib/schedules/oauthTokenRefreshTask.js.map +1 -1
- package/lib/schedules/temp.d.ts +2 -1
- package/lib/schedules/temp.js +20 -25
- package/lib/schedules/temp.js.map +1 -1
- package/lib/utils/cache.d.ts +1 -0
- package/lib/utils/cache.js +3 -1
- package/lib/utils/cache.js.map +1 -1
- package/lib/utils/fetch/error.d.ts +9 -0
- package/lib/utils/fetch/error.js +27 -0
- package/lib/utils/fetch/error.js.map +1 -0
- package/lib/utils/fetch/index.d.ts +4 -0
- package/lib/utils/fetch/index.js +34 -0
- package/lib/utils/fetch/index.js.map +1 -0
- package/lib/utils/fetch/ofetch.d.ts +23 -0
- package/lib/utils/fetch/ofetch.js +85 -0
- package/lib/utils/fetch/ofetch.js.map +1 -0
- package/lib/utils/index.d.ts +3 -0
- package/lib/utils/index.js +4 -1
- package/lib/utils/index.js.map +1 -1
- 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 +23 -0
- package/lib/utils/puppeteer.js +92 -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/beatsaver.js +16 -2
- package/lib/ws/beatsaver.js.map +1 -1
- package/package.json +12 -4
- package/lib/api/base/aioRequest.d.ts +0 -6
- package/lib/api/base/aioRequest.js +0 -24
- package/lib/api/base/aioRequest.js.map +0 -1
- package/lib/api/base/blRequset.d.ts +0 -12
- package/lib/api/base/blRequset.js +0 -68
- package/lib/api/base/blRequset.js.map +0 -1
- package/lib/api/base/bsRequest.d.ts +0 -24
- package/lib/api/base/bsRequest.js +0 -64
- package/lib/api/base/bsRequest.js.map +0 -1
- package/lib/api/base/scRequest.d.ts +0 -6
- package/lib/api/base/scRequest.js +0 -28
- package/lib/api/base/scRequest.js.map +0 -1
- package/lib/db/index.d.ts +0 -0
- package/lib/db/index.js +0 -1
- package/lib/img-render/components/blScoreItem.js.map +0 -1
- package/lib/img-render/components/rankScoreItem.js +0 -38
- package/lib/img-render/components/rankScoreItem.js.map +0 -1
- package/lib/img-render/components/ssScoreItem.js.map +0 -1
- package/lib/img-render/result/bs-score-with-rank.js.map +0 -1
- /package/lib/img-render/components/{blScoreItem.d.ts → bl-score-item.d.ts} +0 -0
- /package/lib/img-render/components/{ssScoreItem.d.ts → ss-score-item.d.ts} +0 -0
@@ -1,6 +1,13 @@
|
|
1
1
|
"use strict";
|
2
|
+
// import {
|
3
|
+
// CornerDotType,
|
4
|
+
// CornerSquareType,
|
5
|
+
// DotType,
|
6
|
+
// QRCodeCanvas,
|
7
|
+
// TypeNumber,
|
8
|
+
// } from '@loskir/styled-qr-code-node'
|
2
9
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
const styled_qr_code_node_1 = require("@
|
10
|
+
const styled_qr_code_node_1 = require("@ktfun/styled-qr-code-node");
|
4
11
|
async function createQrcode(url, width = 300, height = 300) {
|
5
12
|
const options = {
|
6
13
|
width: width ?? 300,
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"qrcode.js","sourceRoot":"","sources":["../../../src/img-render/utils/qrcode.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"qrcode.js","sourceRoot":"","sources":["../../../src/img-render/utils/qrcode.ts"],"names":[],"mappings":";AAAA,WAAW;AACX,mBAAmB;AACnB,sBAAsB;AACtB,aAAa;AACb,kBAAkB;AAClB,gBAAgB;AAChB,uCAAuC;;AAEvC,oEAAyD;AAE1C,KAAK,UAAU,YAAY,CACxC,GAAW,EACX,QAAgB,GAAG,EACnB,SAAiB,GAAG;IAEpB,MAAM,OAAO,GAAG;QACd,KAAK,EAAE,KAAK,IAAI,GAAG;QACnB,MAAM,EAAE,MAAM,IAAI,GAAG;QACrB,IAAI,EAAE,QAAe;QACrB,IAAI,EAAE,GAAG;QACT,MAAM,EAAE,CAAC;QACT,SAAS,EAAE;YACT,UAAU,EAAE,CAAU;YACtB,IAAI,EAAE,MAAa;YACnB,oBAAoB,EAAE,GAAU;SACjC;QACD,YAAY,EAAE;YACZ,kBAAkB,EAAE,IAAI;YACxB,SAAS,EAAE,GAAG;YACd,MAAM,EAAE,EAAE;YACV,WAAW,EAAE,WAAW;SACzB;QACD,WAAW,EAAE;YACX,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,SAAkB;SACzB;QACD,iBAAiB,EAAE;YACjB,KAAK,EAAE,cAAc;SACtB;QACD,oBAAoB,EAAE;YACpB,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,eAAwB;SAC/B;QACD,iBAAiB,EAAE;YACjB,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,KAAc;SACrB;KACF,CAAA;IACD,MAAM,MAAM,GAAG,IAAI,kCAAY,CAAC,OAAO,CAAC,CAAA;IAExC,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;IACzC,OAAO,GAAG,CAAA;AACZ,CAAC;AA1CD,+BA0CC"}
|
package/lib/interface/cmd.d.ts
CHANGED
@@ -4,6 +4,7 @@ import { Logger } from './logger';
|
|
4
4
|
import { APIService } from '../api';
|
5
5
|
import { DB } from '../interface/db';
|
6
6
|
import { Config } from '../config';
|
7
|
+
import { TmpFileStorage, UserPreferenceStore } from '../utils';
|
7
8
|
export interface CmdContext<CHANNEL, OPT> {
|
8
9
|
render: ImgRender;
|
9
10
|
api: APIService;
|
@@ -11,6 +12,8 @@ export interface CmdContext<CHANNEL, OPT> {
|
|
11
12
|
db: DB<CHANNEL>;
|
12
13
|
config: Config;
|
13
14
|
session: Session;
|
15
|
+
userPreference: UserPreferenceStore;
|
16
|
+
s3: TmpFileStorage;
|
14
17
|
options: OPT;
|
15
18
|
input: string;
|
16
19
|
}
|
@@ -22,6 +22,8 @@ export interface SubWithGroupRes<T> {
|
|
22
22
|
groupChannel: RelateChannelInfo<T>;
|
23
23
|
}
|
24
24
|
export interface DB<T> {
|
25
|
+
storeUserPreference<V = any>(uid: number, value: V): Promise<boolean>;
|
26
|
+
getUserPreference<V = any>(uid: number): Promise<V>;
|
25
27
|
getUserAccountsByUid(id: number): Promise<Record<string, RelateAccount>>;
|
26
28
|
batchGetOrCreateUBySessionInfo(s: T[]): Promise<RelateChannelInfo<T>[]>;
|
27
29
|
getUAndGBySessionInfo(s: T): Promise<[RelateChannelInfo<T>, RelateChannelInfo<T>]>;
|
@@ -29,7 +31,12 @@ export interface DB<T> {
|
|
29
31
|
upsertSubscription(data: Partial<Subscribe>): Promise<void>;
|
30
32
|
getSubscriptionInfoByUGID(gid: number, uid: number): Promise<SubInfoRes[]>;
|
31
33
|
getSubscriptionsByGID(gid: number): Promise<Record<string, Subscribe>>;
|
34
|
+
getIDSubscriptionByGID(gid: number): Promise<Subscribe[]>;
|
35
|
+
getIDSubscriptionByType(type: string): Promise<SubWithGroupRes<T>[]>;
|
36
|
+
removeIDSubscriptionByID(id: number): Promise<void>;
|
37
|
+
getIDSubscriptionByGIDAndType(gid: number, type: string): Promise<Subscribe[]>;
|
32
38
|
getAllSubScriptionByUIDAndPlatform(id: string | number, type: string): Promise<SubDetailWithGroupRes<T>[]>;
|
39
|
+
getSubscriptionsByType(type: string): Promise<SubDetailWithGroupRes<T>[]>;
|
33
40
|
addSubscribeMember(data: Partial<SubscribeMember>): Promise<void>;
|
34
41
|
removeFromSubGroupBySubAndUid(subId: number, id: number): Promise<void>;
|
35
42
|
}
|
@@ -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,3 +1,7 @@
|
|
1
|
-
import { ScheduleTask } from '../schedules/interface';
|
2
1
|
import { Config } from '../config';
|
3
|
-
export declare const getScheduleTasks: (config: 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
@@ -2,6 +2,7 @@
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.getScheduleTasks = void 0;
|
4
4
|
const oauthTokenRefreshTask_1 = require("./oauthTokenRefreshTask");
|
5
|
+
const temp_1 = require("../schedules/temp");
|
5
6
|
const oauthTokenRefreshTask = {
|
6
7
|
name: 'oauthTokenRefreshTask',
|
7
8
|
// config
|
@@ -9,8 +10,14 @@ const oauthTokenRefreshTask = {
|
|
9
10
|
executor: oauthTokenRefreshTask_1.tokenRefreshTask,
|
10
11
|
};
|
11
12
|
const getScheduleTasks = (config) => {
|
12
|
-
|
13
|
-
|
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
|
+
];
|
14
21
|
};
|
15
22
|
exports.getScheduleTasks = getScheduleTasks;
|
16
23
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/schedules/index.ts"],"names":[],"mappings":";;;AAAA,mEAA0D;
|
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"}
|
@@ -14,8 +14,8 @@ const tokenRefreshTask = async (c) => {
|
|
14
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 c.api.BeatLeader.
|
18
|
-
if (!token
|
17
|
+
const token = await c.api.BeatLeader.refreshOAuthToken(account.refreshToken);
|
18
|
+
if (!token) {
|
19
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;
|
@@ -24,12 +24,12 @@ const tokenRefreshTask = async (c) => {
|
|
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 c.api.BeatSaver.
|
32
|
-
if (!token
|
31
|
+
const token = await c.api.BeatSaver.refreshOAuthToken(account.refreshToken);
|
32
|
+
if (!token) {
|
33
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;
|
@@ -38,8 +38,8 @@ const tokenRefreshTask = async (c) => {
|
|
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;
|
@@ -1 +1 @@
|
|
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,
|
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 +1,2 @@
|
|
1
|
-
|
1
|
+
import { ScheduleTaskCtx } from '../schedules/interface';
|
2
|
+
export declare const LBScoreMonitor: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
|
package/lib/schedules/temp.js
CHANGED
@@ -1,28 +1,23 @@
|
|
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
|
-
|
23
|
-
// }
|
24
|
-
// await session.sendImgBuffer(hitbuf, 'image/png')
|
25
|
-
// await session.sendImgBuffer(scorebuf, 'image/png')
|
26
|
-
// }
|
27
|
-
// }
|
3
|
+
exports.LBScoreMonitor = void 0;
|
4
|
+
const LBScoreMonitor = async (c) => {
|
5
|
+
const channels = await c.db.getSubscriptionsByType('lb-rank');
|
6
|
+
if (channels.length <= 0) {
|
7
|
+
return;
|
8
|
+
}
|
9
|
+
const [hitbuf, scorebuf] = await Promise.all([
|
10
|
+
c.render.renderUrl('https://aiobs.ktlab.io/tmp/lb/hitcnt'),
|
11
|
+
c.render.renderUrl('https://aiobs.ktlab.io/tmp/lb/score'),
|
12
|
+
]);
|
13
|
+
for (const group of channels) {
|
14
|
+
const session = c.botService.getSessionByChannelInfo(group.groupChannel);
|
15
|
+
if (!session) {
|
16
|
+
continue;
|
17
|
+
}
|
18
|
+
await session.sendImgBuffer(hitbuf, 'image/png');
|
19
|
+
await session.sendImgBuffer(scorebuf, 'image/png');
|
20
|
+
}
|
21
|
+
};
|
22
|
+
exports.LBScoreMonitor = LBScoreMonitor;
|
28
23
|
//# 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":";;;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"}
|
package/lib/utils/cache.d.ts
CHANGED
package/lib/utils/cache.js
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.cache = void 0;
|
3
|
+
exports.createCache = exports.cache = void 0;
|
4
4
|
const lru_cache_1 = require("lru-cache");
|
5
5
|
const options = {
|
6
6
|
max: 500,
|
@@ -25,4 +25,6 @@ const options = {
|
|
25
25
|
// ) => {},
|
26
26
|
};
|
27
27
|
exports.cache = new lru_cache_1.LRUCache(options);
|
28
|
+
const createCache = (opt) => new lru_cache_1.LRUCache(opt);
|
29
|
+
exports.createCache = createCache;
|
28
30
|
//# sourceMappingURL=cache.js.map
|
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,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"}
|
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,CAA2C,GAAG,EAAE,EAAE,CAC3E,IAAI,oBAAQ,CAAW,GAAG,CAAC,CAAA;AADhB,QAAA,WAAW,eACK"}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
export declare class RequestError extends Error {
|
2
|
+
constructor(message?: string);
|
3
|
+
}
|
4
|
+
export declare class NotFoundError extends Error {
|
5
|
+
constructor(message?: string);
|
6
|
+
}
|
7
|
+
export declare class RatelimitError extends Error {
|
8
|
+
constructor(message?: string);
|
9
|
+
}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.RatelimitError = exports.NotFoundError = exports.RequestError = void 0;
|
4
|
+
class RequestError extends Error {
|
5
|
+
constructor(message) {
|
6
|
+
super(message);
|
7
|
+
this.name = 'RequestError';
|
8
|
+
}
|
9
|
+
}
|
10
|
+
exports.RequestError = RequestError;
|
11
|
+
// create request error for external request
|
12
|
+
// 404, 429, 401 ...
|
13
|
+
class NotFoundError extends Error {
|
14
|
+
constructor(message) {
|
15
|
+
super(message);
|
16
|
+
this.name = 'NotFoundError';
|
17
|
+
}
|
18
|
+
}
|
19
|
+
exports.NotFoundError = NotFoundError;
|
20
|
+
class RatelimitError extends Error {
|
21
|
+
constructor(message) {
|
22
|
+
super(message);
|
23
|
+
this.name = 'RatelimitError';
|
24
|
+
}
|
25
|
+
}
|
26
|
+
exports.RatelimitError = RatelimitError;
|
27
|
+
//# sourceMappingURL=error.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../../src/utils/fetch/error.ts"],"names":[],"mappings":";;;AAAA,MAAa,YAAa,SAAQ,KAAK;IACrC,YAAY,OAAgB;QAC1B,KAAK,CAAC,OAAO,CAAC,CAAA;QACd,IAAI,CAAC,IAAI,GAAG,cAAc,CAAA;IAC5B,CAAC;CACF;AALD,oCAKC;AAED,4CAA4C;AAC5C,oBAAoB;AAEpB,MAAa,aAAc,SAAQ,KAAK;IACtC,YAAY,OAAgB;QAC1B,KAAK,CAAC,OAAO,CAAC,CAAA;QACd,IAAI,CAAC,IAAI,GAAG,eAAe,CAAA;IAC7B,CAAC;CACF;AALD,sCAKC;AAED,MAAa,cAAe,SAAQ,KAAK;IACvC,YAAY,OAAgB;QAC1B,KAAK,CAAC,OAAO,CAAC,CAAA;QACd,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAA;IAC9B,CAAC;CACF;AALD,wCAKC"}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Fetch = exports.createFetch = void 0;
|
4
|
+
const ofetch_1 = require("./ofetch");
|
5
|
+
const error_1 = require("./error");
|
6
|
+
const rofetch = (0, ofetch_1.createFetch)({
|
7
|
+
defaults: {
|
8
|
+
retryStatusCodes: [400, 408, 409, 425, 429, 502, 503, 504],
|
9
|
+
retry: 2,
|
10
|
+
retryDelay: 400,
|
11
|
+
},
|
12
|
+
});
|
13
|
+
const ofetch = new ofetch_1.Fetch(rofetch);
|
14
|
+
const createFetch = (logger) => {
|
15
|
+
return ofetch.extend({
|
16
|
+
onRequest: (context) => {
|
17
|
+
logger.debug(`[fetch -->] ${context.options.baseURL}${context.request}`);
|
18
|
+
},
|
19
|
+
onResponse: (context) => {
|
20
|
+
logger.debug(`[fetch <--] ${context.request} ${context.response.status}`);
|
21
|
+
},
|
22
|
+
onResponseError: (context) => {
|
23
|
+
if (context.response.status === 404) {
|
24
|
+
throw new error_1.NotFoundError();
|
25
|
+
}
|
26
|
+
throw context.error;
|
27
|
+
},
|
28
|
+
ignoreResponseError: false,
|
29
|
+
});
|
30
|
+
};
|
31
|
+
exports.createFetch = createFetch;
|
32
|
+
var ofetch_2 = require("./ofetch");
|
33
|
+
Object.defineProperty(exports, "Fetch", { enumerable: true, get: function () { return ofetch_2.Fetch; } });
|
34
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/fetch/index.ts"],"names":[],"mappings":";;;AAAA,qCAAkD;AAElD,mCAAuC;AAEvC,MAAM,OAAO,GAAG,IAAA,oBAAC,EAAC;IAChB,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,CAAA;AAEF,MAAM,MAAM,GAAG,IAAI,cAAK,CAAC,OAAO,CAAC,CAAA;AAE1B,MAAM,WAAW,GAAG,CAAC,MAAc,EAAE,EAAE;IAC5C,OAAO,MAAM,CAAC,MAAM,CAAC;QACnB,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;YACrB,MAAM,CAAC,KAAK,CAAC,eAAe,OAAO,CAAC,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAAA;QAC1E,CAAC;QACD,UAAU,EAAE,CAAC,OAAO,EAAE,EAAE;YACtB,MAAM,CAAC,KAAK,CAAC,eAAe,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAA;QAC3E,CAAC;QACD,eAAe,EAAE,CAAC,OAAO,EAAE,EAAE;YAC3B,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;gBACpC,MAAM,IAAI,qBAAa,EAAE,CAAA;YAC3B,CAAC;YACD,MAAM,OAAO,CAAC,KAAK,CAAA;QACrB,CAAC;QACD,mBAAmB,EAAE,KAAK;KAC3B,CAAC,CAAA;AACJ,CAAC,CAAA;AAhBY,QAAA,WAAW,eAgBvB;AAED,mCAAgC;AAAvB,+FAAA,KAAK,OAAA"}
|
@@ -0,0 +1,23 @@
|
|
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
|
+
baseUrl(url: string): Fetch;
|
22
|
+
}
|
23
|
+
export { createFetch } from 'ofetch';
|
@@ -0,0 +1,85 @@
|
|
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
|
+
const error_1 = require("./error");
|
6
|
+
exports.rofetch = (0, ofetch_1.createFetch)({
|
7
|
+
defaults: {
|
8
|
+
retryStatusCodes: [400, 408, 409, 425, 429, 500, 502, 503, 504],
|
9
|
+
retry: 3,
|
10
|
+
retryDelay: 800,
|
11
|
+
},
|
12
|
+
}).create({
|
13
|
+
onResponseError({ request, response, options }) {
|
14
|
+
if (response.status === 404) {
|
15
|
+
throw new error_1.NotFoundError();
|
16
|
+
}
|
17
|
+
},
|
18
|
+
onRequestError({ request, error }) { },
|
19
|
+
});
|
20
|
+
class Fetch {
|
21
|
+
options;
|
22
|
+
ofetchInstance;
|
23
|
+
constructor(fetchInstance, options) {
|
24
|
+
this.options = options;
|
25
|
+
this.ofetchInstance = fetchInstance ?? exports.rofetch;
|
26
|
+
}
|
27
|
+
async fetch(request, options) {
|
28
|
+
if (options?.json && !options.body) {
|
29
|
+
options.body = options.json;
|
30
|
+
delete options.json;
|
31
|
+
}
|
32
|
+
if (options?.form && !options.body) {
|
33
|
+
options.body = new URLSearchParams(options.form).toString();
|
34
|
+
if (!options.headers) {
|
35
|
+
options.headers = {};
|
36
|
+
}
|
37
|
+
options.headers = {
|
38
|
+
...options.headers,
|
39
|
+
'content-type': 'application/x-www-form-urlencoded',
|
40
|
+
};
|
41
|
+
delete options.form;
|
42
|
+
}
|
43
|
+
if (options?.searchParams) {
|
44
|
+
request += '?' + new URLSearchParams(options.searchParams).toString();
|
45
|
+
delete options.searchParams;
|
46
|
+
}
|
47
|
+
const res = await this.ofetchInstance(request, {
|
48
|
+
...this.options,
|
49
|
+
...options,
|
50
|
+
}).catch((e) => {
|
51
|
+
if (e instanceof error_1.NotFoundError)
|
52
|
+
return null;
|
53
|
+
throw e;
|
54
|
+
});
|
55
|
+
return res;
|
56
|
+
}
|
57
|
+
get(request, options) {
|
58
|
+
return this.fetch(request, { ...options, method: 'GET' });
|
59
|
+
}
|
60
|
+
post(request, options) {
|
61
|
+
return this.fetch(request, { ...options, method: 'POST' });
|
62
|
+
}
|
63
|
+
put(request, options) {
|
64
|
+
return this.fetch(request, { ...options, method: 'PUT' });
|
65
|
+
}
|
66
|
+
patch(request, options) {
|
67
|
+
return this.fetch(request, { ...options, method: 'PATCH' });
|
68
|
+
}
|
69
|
+
delete(request, options) {
|
70
|
+
return this.fetch(request, { ...options, method: 'DELETE' });
|
71
|
+
}
|
72
|
+
head(request, options) {
|
73
|
+
return this.fetch(request, { ...options, method: 'HEAD' });
|
74
|
+
}
|
75
|
+
extend(options) {
|
76
|
+
return new Fetch(this.ofetchInstance, { ...this.options, ...options });
|
77
|
+
}
|
78
|
+
baseUrl(url) {
|
79
|
+
return this.extend({ baseURL: url });
|
80
|
+
}
|
81
|
+
}
|
82
|
+
exports.Fetch = Fetch;
|
83
|
+
var ofetch_2 = require("ofetch");
|
84
|
+
Object.defineProperty(exports, "createFetch", { enumerable: true, get: function () { return ofetch_2.createFetch; } });
|
85
|
+
//# sourceMappingURL=ofetch.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ofetch.js","sourceRoot":"","sources":["../../../src/utils/fetch/ofetch.ts"],"names":[],"mappings":";;;AAAA,mCAA0D;AAC1D,mCAAuC;AAE1B,QAAA,OAAO,GAAG,IAAA,oBAAW,EAAC;IACjC,QAAQ,EAAE;QACR,gBAAgB,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;QAC/D,KAAK,EAAE,CAAC;QACR,UAAU,EAAE,GAAG;KAChB;CACF,CAAC,CAAC,MAAM,CAAC;IACR,eAAe,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE;QAC5C,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;YAC5B,MAAM,IAAI,qBAAa,EAAE,CAAA;QAC3B,CAAC;IACH,CAAC;IACD,cAAc,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,IAAG,CAAC;CACtC,CAAC,CAAA;AASF,MAAa,KAAK;IACR,OAAO,CAAe;IACtB,cAAc,CAAQ;IAC9B,YAAY,aAAsB,EAAE,OAAsB;QACxD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,cAAc,GAAG,aAAa,IAAI,eAAO,CAAA;IAChD,CAAC;IACO,KAAK,CAAC,KAAK,CAAC,OAAe,EAAE,OAA4B;QAC/D,IAAI,OAAO,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAA;YAC3B,OAAO,OAAO,CAAC,IAAI,CAAA;QACrB,CAAC;QACD,IAAI,OAAO,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,GAAG,IAAI,eAAe,CAChC,OAAO,CAAC,IAA8B,CACvC,CAAC,QAAQ,EAAE,CAAA;YACZ,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;gBACrB,OAAO,CAAC,OAAO,GAAG,EAAE,CAAA;YACtB,CAAC;YACD,OAAO,CAAC,OAAO,GAAG;gBAChB,GAAG,OAAO,CAAC,OAAO;gBAClB,cAAc,EAAE,mCAAmC;aACpD,CAAA;YACD,OAAO,OAAO,CAAC,IAAI,CAAA;QACrB,CAAC;QAED,IAAI,OAAO,EAAE,YAAY,EAAE,CAAC;YAC1B,OAAO,IAAI,GAAG,GAAG,IAAI,eAAe,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAA;YACrE,OAAO,OAAO,CAAC,YAAY,CAAA;QAC7B,CAAC;QACD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE;YAC7C,GAAG,IAAI,CAAC,OAAO;YACf,GAAG,OAAO;SACX,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;YACb,IAAI,CAAC,YAAY,qBAAa;gBAAE,OAAO,IAAI,CAAA;YAC3C,MAAM,CAAC,CAAA;QACT,CAAC,CAAC,CAAA;QACF,OAAO,GAAG,CAAA;IACZ,CAAC;IACD,GAAG,CACD,OAAe,EACf,OAA4B;QAE5B,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAe,CAAA;IACzE,CAAC;IACD,IAAI,CACF,OAAe,EACf,OAA4B;QAE5B,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,CAAe,CAAA;IAC1E,CAAC;IACD,GAAG,CACD,OAAe,EACf,OAA4B;QAE5B,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAe,CAAA;IACzE,CAAC;IACD,KAAK,CACH,OAAe,EACf,OAA4B;QAE5B,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,CAAe,CAAA;IAC3E,CAAC;IACD,MAAM,CACJ,OAAe,EACf,OAA4B;QAE5B,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAe,CAAA;IAC5E,CAAC;IACD,IAAI,CAAC,OAAe,EAAE,OAA4B;QAChD,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAA;IAC5D,CAAC;IAED,MAAM,CAAC,OAAqB;QAC1B,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,GAAG,OAAO,EAAE,CAAC,CAAA;IACxE,CAAC;IACD,OAAO,CAAC,GAAW;QACjB,OAAO,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,CAAA;IACtC,CAAC;CACF;AA/ED,sBA+EC;AAED,iCAAoC;AAA3B,qGAAA,WAAW,OAAA"}
|
package/lib/utils/index.d.ts
CHANGED
@@ -1,4 +1,7 @@
|
|
1
1
|
export * from './cache';
|
2
|
+
export * from './s3';
|
3
|
+
export * from './preference';
|
4
|
+
export * from './puppeteer';
|
2
5
|
export declare const fetchWithCache: <T>(...args: any[]) => Promise<T>;
|
3
6
|
export declare const handleWSEventWithCache: (fnThat: any, fn: any, ttl: any, eventParser: any, eventFilter: any, eventIdSelector: any) => (event: any) => Promise<void>;
|
4
7
|
export declare const sleep: (millsec?: number) => Promise<void>;
|
package/lib/utils/index.js
CHANGED
@@ -18,6 +18,9 @@ exports.convertDiff = exports.sleep = exports.handleWSEventWithCache = exports.f
|
|
18
18
|
const cache_1 = require("../utils/cache");
|
19
19
|
const lru_cache_1 = require("lru-cache");
|
20
20
|
__exportStar(require("./cache"), exports);
|
21
|
+
__exportStar(require("./s3"), exports);
|
22
|
+
__exportStar(require("./preference"), exports);
|
23
|
+
__exportStar(require("./puppeteer"), exports);
|
21
24
|
const fetchWithCache = async (...args) => {
|
22
25
|
const res = cache_1.cache.get(args);
|
23
26
|
if (res) {
|
@@ -44,7 +47,7 @@ const handleWSEventWithCache = (fnThat, fn, ttl, eventParser, eventFilter, event
|
|
44
47
|
return async function (event) {
|
45
48
|
const data = eventParser(event);
|
46
49
|
const key = eventIdSelector(data);
|
47
|
-
if (eventFilter(data) || WSCache.get(key)) {
|
50
|
+
if (!eventFilter(data) || WSCache.get(key)) {
|
48
51
|
// console.log(`${key} hit cache, skip it, remainingTTL: `, WSCache.getRemainingTTL(key))
|
49
52
|
return;
|
50
53
|
}
|
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;
|
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 {};
|