beatsaber-bot-core 0.2.0-dev.8 → 0.2.0-rc.1
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/scRequest.d.ts +2 -0
- package/lib/api/base/scRequest.js +28 -13
- package/lib/api/base/scRequest.js.map +1 -1
- package/lib/api/base/ssclient.d.ts +13 -0
- package/lib/api/base/ssclient.js +48 -0
- package/lib/api/base/ssclient.js.map +1 -0
- package/lib/api/composed/beatleader.d.ts +8 -3
- package/lib/api/composed/beatleader.js +39 -5
- package/lib/api/composed/beatleader.js.map +1 -1
- package/lib/api/composed/beatsaver.d.ts +2 -3
- package/lib/api/composed/beatsaver.js +2 -1
- package/lib/api/composed/beatsaver.js.map +1 -1
- package/lib/api/composed/scoresaber.js +5 -1
- package/lib/api/composed/scoresaber.js.map +1 -1
- package/lib/api/error.d.ts +9 -0
- package/lib/api/error.js +27 -0
- package/lib/api/error.js.map +1 -0
- 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/api/interfaces/index.js.map +1 -0
- package/lib/api/interfaces/scoresaber/item.d.ts +12 -3
- package/lib/api/interfaces/scoresaber/leaderboard.d.ts +10 -0
- package/lib/api/interfaces/scoresaber/leaderboard.js +3 -0
- package/lib/api/interfaces/scoresaber/leaderboard.js.map +1 -0
- package/lib/cmd/bind/bind-beatleader.js +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 +12 -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/group-beatleader-score.d.ts +2 -0
- package/lib/cmd/subscribe/group-beatleader-score.js +41 -0
- package/lib/cmd/subscribe/group-beatleader-score.js.map +1 -0
- package/lib/cmd/subscribe/group-beatsaver-mapper.d.ts +2 -0
- package/lib/cmd/subscribe/group-beatsaver-mapper.js +42 -0
- package/lib/cmd/subscribe/group-beatsaver-mapper.js.map +1 -0
- 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 +6 -0
- package/lib/img-render/components/RankDifficulty.js +17 -0
- package/lib/img-render/components/RankDifficulty.js.map +1 -0
- package/lib/img-render/components/base/avatar.d.ts +7 -0
- package/lib/img-render/components/base/avatar.js +11 -0
- package/lib/img-render/components/base/avatar.js.map +1 -1
- package/lib/img-render/components/bl-rank-score-item.d.ts +18 -0
- package/lib/img-render/components/bl-rank-score-item.js +42 -0
- package/lib/img-render/components/bl-rank-score-item.js.map +1 -0
- package/lib/img-render/components/bl-score-item.d.ts +6 -0
- package/lib/img-render/components/bl-score-item.js +14 -0
- package/lib/img-render/components/bl-score-item.js.map +1 -0
- package/lib/img-render/components/blScoreItem.js +2 -2
- package/lib/img-render/components/blScoreItem.js.map +1 -1
- package/lib/img-render/components/rankScoreItem.d.ts +18 -0
- package/lib/img-render/components/rankScoreItem.js +42 -0
- package/lib/img-render/components/rankScoreItem.js.map +1 -0
- package/lib/img-render/components/scoregraph.d.ts +3 -1
- package/lib/img-render/components/scoregraph.js +5 -4
- package/lib/img-render/components/scoregraph.js.map +1 -1
- package/lib/img-render/components/ss-rank-score-item.d.ts +18 -0
- package/lib/img-render/components/ss-rank-score-item.js +42 -0
- package/lib/img-render/components/ss-rank-score-item.js.map +1 -0
- package/lib/img-render/components/ss-score-item.d.ts +4 -0
- package/lib/img-render/components/ss-score-item.js +14 -0
- package/lib/img-render/components/ss-score-item.js.map +1 -0
- package/lib/img-render/components/ssScoreItem.js +1 -1
- package/lib/img-render/components/ssScoreItem.js.map +1 -1
- package/lib/img-render/index.d.ts +13 -10
- package/lib/img-render/index.js +61 -34
- package/lib/img-render/index.js.map +1 -1
- package/lib/img-render/interfaces.d.ts +2 -0
- package/lib/img-render/render.js +26 -1
- package/lib/img-render/render.js.map +1 -1
- package/lib/img-render/result/bl-player.d.ts +2 -1
- package/lib/img-render/result/bl-player.js +7 -4
- package/lib/img-render/result/bl-player.js.map +1 -1
- package/lib/img-render/result/bl-score-with-rank.d.ts +14 -0
- package/lib/img-render/result/bl-score-with-rank.js +33 -0
- package/lib/img-render/result/bl-score-with-rank.js.map +1 -0
- package/lib/img-render/result/bl-score.js +1 -1
- package/lib/img-render/result/bl-score.js.map +1 -1
- package/lib/img-render/result/bs-score-with-rank.d.ts +13 -0
- package/lib/img-render/result/bs-score-with-rank.js +33 -0
- package/lib/img-render/result/bs-score-with-rank.js.map +1 -0
- package/lib/img-render/result/index.d.ts +3 -2
- package/lib/img-render/result/index.js +10 -5
- package/lib/img-render/result/index.js.map +1 -1
- package/lib/img-render/result/ss-player.d.ts +2 -1
- package/lib/img-render/result/ss-player.js +3 -4
- package/lib/img-render/result/ss-player.js.map +1 -1
- package/lib/img-render/result/ss-score-with-rank.d.ts +0 -0
- package/lib/img-render/result/ss-score-with-rank.js +277 -0
- package/lib/img-render/result/ss-score-with-rank.js.map +1 -0
- package/lib/img-render/utils/canvas.js +9 -3
- package/lib/img-render/utils/canvas.js.map +1 -1
- package/lib/img-render/utils/format.d.ts +3 -0
- package/lib/img-render/utils/format.js +25 -1
- package/lib/img-render/utils/format.js.map +1 -1
- package/lib/img-render/utils/index.d.ts +1 -1
- package/lib/img-render/utils/index.js +1 -1
- package/lib/img-render/utils/index.js.map +1 -1
- package/lib/img-render/utils/qrcode.js +8 -1
- package/lib/img-render/utils/qrcode.js.map +1 -1
- package/lib/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 +2 -1
- package/lib/utils/cache.js +4 -4
- 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/error.js
ADDED
@@ -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/api/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,19 @@
|
|
1
|
+
import { NetReqResult } from '../api/netResult';
|
2
|
+
type Res<Base, T> = Base extends true ? NetReqResult<T> : T;
|
3
|
+
export declare class APIHelper<API, Base extends boolean = false> {
|
4
|
+
constructor();
|
5
|
+
private retryTime;
|
6
|
+
private _wrapper;
|
7
|
+
private _onRetry;
|
8
|
+
withRetry(times?: number, onRetry?: (retryTime: number, e?: any) => void): this;
|
9
|
+
onRetry(func: (times: number, e: any) => void): this;
|
10
|
+
call<T>(block: () => Promise<T>): Promise<Res<Base, T>>;
|
11
|
+
wrapperResult(): ServiceWithAPIHelper<API, true>;
|
12
|
+
}
|
13
|
+
export type ServiceWithAPIHelper<API, Wrap extends boolean = false> = Wrapped<API, Wrap> & APIHelper<API, Wrap>;
|
14
|
+
type Wrapping<T, I extends boolean = false> = T extends (...args: infer Args) => infer R ? <Wrap extends boolean = false>(...args: Args) => R extends Promise<infer R1> ? I extends true ? Promise<NetReqResult<R1>> : Wrap extends true ? Promise<NetReqResult<R1>> : Promise<R1> : R : T;
|
15
|
+
type Wrapped<T, Wrap extends boolean = false> = {
|
16
|
+
[K in keyof T]: Wrapping<T[K], Wrap>;
|
17
|
+
};
|
18
|
+
export declare function createProxiedAPIService<T extends object>(instance: T): ServiceWithAPIHelper<T>;
|
19
|
+
export {};
|
@@ -0,0 +1,102 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.createProxiedAPIService = exports.APIHelper = void 0;
|
4
|
+
const netResult_1 = require("../api/netResult");
|
5
|
+
const utils_1 = require("../utils");
|
6
|
+
const errors_1 = require("../errors");
|
7
|
+
class APIHelper {
|
8
|
+
constructor() { }
|
9
|
+
retryTime = 1;
|
10
|
+
_wrapper = false;
|
11
|
+
_onRetry = () => { };
|
12
|
+
withRetry(times = 1, onRetry) {
|
13
|
+
this.retryTime = times;
|
14
|
+
this._onRetry = onRetry;
|
15
|
+
return this;
|
16
|
+
}
|
17
|
+
onRetry(func) {
|
18
|
+
this._onRetry = func;
|
19
|
+
return this;
|
20
|
+
}
|
21
|
+
async call(block) {
|
22
|
+
let result;
|
23
|
+
let times = Math.min(this.retryTime, 3);
|
24
|
+
let retryTime = 0;
|
25
|
+
const wrap = this._wrapper;
|
26
|
+
while (times > 0) {
|
27
|
+
try {
|
28
|
+
result = await block();
|
29
|
+
if (wrap) {
|
30
|
+
return netResult_1.NetReqResult.success(result);
|
31
|
+
}
|
32
|
+
return result;
|
33
|
+
}
|
34
|
+
catch (e) {
|
35
|
+
if (e instanceof errors_1.BizError) {
|
36
|
+
throw e;
|
37
|
+
}
|
38
|
+
retryTime += 1;
|
39
|
+
if (times-- > 1) {
|
40
|
+
this._onRetry?.(retryTime, e);
|
41
|
+
continue;
|
42
|
+
}
|
43
|
+
await (0, utils_1.sleep)(300);
|
44
|
+
if (wrap) {
|
45
|
+
return netResult_1.NetReqResult.failed(`retry times reached, ${e}`);
|
46
|
+
}
|
47
|
+
throw new errors_1.ReachNetworkRetryLimitError();
|
48
|
+
}
|
49
|
+
}
|
50
|
+
if (result) {
|
51
|
+
return (wrap ? netResult_1.NetReqResult.success(result) : result);
|
52
|
+
}
|
53
|
+
if (wrap) {
|
54
|
+
return netResult_1.NetReqResult.failed('unknown error');
|
55
|
+
}
|
56
|
+
throw new errors_1.RequestError();
|
57
|
+
}
|
58
|
+
wrapperResult() {
|
59
|
+
this._wrapper = true;
|
60
|
+
return this;
|
61
|
+
}
|
62
|
+
}
|
63
|
+
exports.APIHelper = APIHelper;
|
64
|
+
function createProxiedAPIService(instance) {
|
65
|
+
;
|
66
|
+
instance.helper = new APIHelper();
|
67
|
+
return new Proxy(instance, {
|
68
|
+
get(target, prop, receiver) {
|
69
|
+
const method = target[prop];
|
70
|
+
// target func
|
71
|
+
if (typeof method === 'function') {
|
72
|
+
return async function (...args) {
|
73
|
+
const result = await target.helper.call(() => method.apply(this, args));
|
74
|
+
return result;
|
75
|
+
};
|
76
|
+
}
|
77
|
+
if (prop in target) {
|
78
|
+
return Reflect.get(target, prop, receiver);
|
79
|
+
}
|
80
|
+
// helper func
|
81
|
+
if (prop in target.helper) {
|
82
|
+
const v = Reflect.get(target.helper, prop);
|
83
|
+
if (typeof v === 'function') {
|
84
|
+
return v;
|
85
|
+
}
|
86
|
+
return v;
|
87
|
+
}
|
88
|
+
return undefined;
|
89
|
+
},
|
90
|
+
set(target, property, value, receiver) {
|
91
|
+
if (property in target) {
|
92
|
+
return Reflect.set(target, property, value, receiver);
|
93
|
+
}
|
94
|
+
if (property in target.helper) {
|
95
|
+
return Reflect.set(target.helper, property, value);
|
96
|
+
}
|
97
|
+
return false;
|
98
|
+
},
|
99
|
+
});
|
100
|
+
}
|
101
|
+
exports.createProxiedAPIService = createProxiedAPIService;
|
102
|
+
//# sourceMappingURL=helper.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"helper.js","sourceRoot":"","sources":["../../src/api/helper.ts"],"names":[],"mappings":"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"}
|
package/lib/api/index.d.ts
CHANGED
@@ -3,29 +3,12 @@ import { BeatLeaderService } from './composed/beatleader';
|
|
3
3
|
import { BeatSaverService } from './composed/beatsaver';
|
4
4
|
import { ScoreSaberService } from './composed/scoresaber';
|
5
5
|
import { AIOSaberService } from './composed/aiosaber';
|
6
|
-
import {
|
7
|
-
type ServiceWithAPIHelper<API, Wrap extends boolean = false> = Wrapped<API, Wrap> & APIHelper<API, Wrap>;
|
8
|
-
type Wrapping<T, I extends boolean = false> = T extends (...args: infer Args) => infer R ? <Wrap extends boolean = false>(...args: Args) => R extends Promise<infer R1> ? I extends true ? Promise<NetReqResult<R1>> : Wrap extends true ? Promise<NetReqResult<R1>> : Promise<R1> : R : T;
|
9
|
-
type Wrapped<T, Wrap extends boolean = false> = {
|
10
|
-
[K in keyof T]: Wrapping<T[K], Wrap>;
|
11
|
-
};
|
6
|
+
import { Logger } from '../interface';
|
12
7
|
export declare class APIService {
|
13
|
-
BeatLeader:
|
14
|
-
ScoreSaber:
|
15
|
-
BeatSaver:
|
16
|
-
AIOSaber:
|
8
|
+
BeatLeader: BeatLeaderService;
|
9
|
+
ScoreSaber: ScoreSaberService;
|
10
|
+
BeatSaver: BeatSaverService;
|
11
|
+
AIOSaber: AIOSaberService;
|
17
12
|
private constructor();
|
18
|
-
static create(cfg: Config): APIService;
|
13
|
+
static create(cfg: Config, logger: Logger): APIService;
|
19
14
|
}
|
20
|
-
type Res<Base, T> = Base extends true ? NetReqResult<T> : T;
|
21
|
-
declare class APIHelper<API, Base extends boolean = false> {
|
22
|
-
constructor();
|
23
|
-
private retryTime;
|
24
|
-
private _wrapper;
|
25
|
-
private _onRetry;
|
26
|
-
withRetry(times?: number, onRetry?: (retryTime: number, e?: any) => void): this;
|
27
|
-
onRetry(func: (times: number, e: any) => void): this;
|
28
|
-
call<T>(block: () => Promise<T>): Promise<Res<Base, T>>;
|
29
|
-
wrapperResult(): ServiceWithAPIHelper<API, true>;
|
30
|
-
}
|
31
|
-
export {};
|
package/lib/api/index.js
CHANGED
@@ -2,133 +2,42 @@
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.APIService = void 0;
|
4
4
|
const beatleader_1 = require("./composed/beatleader");
|
5
|
-
const base_1 = require("./base");
|
6
5
|
const beatsaver_1 = require("./composed/beatsaver");
|
7
6
|
const scoresaber_1 = require("./composed/scoresaber");
|
8
7
|
const aiosaber_1 = require("./composed/aiosaber");
|
9
|
-
const
|
10
|
-
const utils_1 = require("../utils");
|
11
|
-
function createProxiedAPIService(instance) {
|
12
|
-
;
|
13
|
-
instance.helper = new APIHelper();
|
14
|
-
return new Proxy(instance, {
|
15
|
-
get(target, prop, receiver) {
|
16
|
-
const method = target[prop];
|
17
|
-
// target func
|
18
|
-
if (typeof method === 'function') {
|
19
|
-
return async function (...args) {
|
20
|
-
const result = await target.helper.call(() => method.apply(this, args));
|
21
|
-
return result;
|
22
|
-
};
|
23
|
-
}
|
24
|
-
if (prop in target) {
|
25
|
-
return Reflect.get(target, prop, receiver);
|
26
|
-
}
|
27
|
-
// helper func
|
28
|
-
if (prop in target.helper) {
|
29
|
-
const v = Reflect.get(target.helper, prop);
|
30
|
-
if (typeof v === 'function') {
|
31
|
-
return v;
|
32
|
-
}
|
33
|
-
return v;
|
34
|
-
}
|
35
|
-
return undefined;
|
36
|
-
},
|
37
|
-
set(target, property, value, receiver) {
|
38
|
-
if (property in target) {
|
39
|
-
return Reflect.set(target, property, value, receiver);
|
40
|
-
}
|
41
|
-
if (property in target.helper) {
|
42
|
-
return Reflect.set(target.helper, property, value);
|
43
|
-
}
|
44
|
-
return false;
|
45
|
-
},
|
46
|
-
});
|
47
|
-
}
|
8
|
+
const base_1 = require("../api/base");
|
48
9
|
class APIService {
|
49
10
|
BeatLeader;
|
50
11
|
ScoreSaber;
|
51
12
|
BeatSaver;
|
52
13
|
AIOSaber;
|
53
|
-
constructor(cfg) {
|
54
|
-
const bsClient =
|
55
|
-
const blClient =
|
56
|
-
const scClient =
|
57
|
-
const aioClient =
|
14
|
+
constructor(cfg, logger) {
|
15
|
+
const bsClient = new base_1.BeatSaverClient(cfg, logger);
|
16
|
+
const blClient = new base_1.BeatLeaderClient(cfg, logger);
|
17
|
+
const scClient = new base_1.ScoreSaberClient(cfg, logger);
|
18
|
+
const aioClient = new base_1.AIOSaberClient(cfg, logger);
|
58
19
|
this.BeatLeader = new beatleader_1.BeatLeaderService(bsClient, blClient);
|
59
20
|
this.BeatSaver = new beatsaver_1.BeatSaverService(bsClient);
|
60
21
|
this.ScoreSaber = new scoresaber_1.ScoreSaberService(bsClient, scClient);
|
61
22
|
this.AIOSaber = new aiosaber_1.AIOSaberService(aioClient);
|
62
23
|
}
|
63
|
-
static create(cfg) {
|
64
|
-
|
65
|
-
const
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
}
|
77
|
-
|
24
|
+
static create(cfg, logger) {
|
25
|
+
return new APIService(cfg, logger);
|
26
|
+
// const ins = new APIService(cfg)
|
27
|
+
// const proxied = new Proxy<APIService>(ins, {
|
28
|
+
// get(target, prop, receiver) {
|
29
|
+
// const member = target[prop]
|
30
|
+
// if (member) {
|
31
|
+
// return createProxiedAPIService(member)
|
32
|
+
// }
|
33
|
+
// return undefined
|
34
|
+
// },
|
35
|
+
// set(target, property, value, receiver) {
|
36
|
+
// return false
|
37
|
+
// },
|
38
|
+
// })
|
39
|
+
// return proxied
|
78
40
|
}
|
79
41
|
}
|
80
42
|
exports.APIService = APIService;
|
81
|
-
class APIHelper {
|
82
|
-
constructor() { }
|
83
|
-
retryTime = 1;
|
84
|
-
_wrapper = false;
|
85
|
-
_onRetry = () => { };
|
86
|
-
withRetry(times = 1, onRetry) {
|
87
|
-
this.retryTime = times;
|
88
|
-
this._onRetry = onRetry;
|
89
|
-
return this;
|
90
|
-
}
|
91
|
-
onRetry(func) {
|
92
|
-
this._onRetry = func;
|
93
|
-
return this;
|
94
|
-
}
|
95
|
-
async call(block) {
|
96
|
-
let result;
|
97
|
-
let times = Math.min(this.retryTime, 3);
|
98
|
-
let retryTime = 0;
|
99
|
-
const wrap = this._wrapper;
|
100
|
-
while (times > 0) {
|
101
|
-
try {
|
102
|
-
result = await block();
|
103
|
-
if (wrap) {
|
104
|
-
return netResult_1.NetReqResult.success(result);
|
105
|
-
}
|
106
|
-
return result;
|
107
|
-
}
|
108
|
-
catch (e) {
|
109
|
-
retryTime += 1;
|
110
|
-
if (times-- > 1) {
|
111
|
-
this._onRetry?.(retryTime, e);
|
112
|
-
continue;
|
113
|
-
}
|
114
|
-
await (0, utils_1.sleep)(300);
|
115
|
-
if (wrap) {
|
116
|
-
return netResult_1.NetReqResult.failed(`retry times reached, ${e}`);
|
117
|
-
}
|
118
|
-
throw Error('retry times reached', e);
|
119
|
-
}
|
120
|
-
}
|
121
|
-
if (result) {
|
122
|
-
return (wrap ? netResult_1.NetReqResult.success(result) : result);
|
123
|
-
}
|
124
|
-
if (wrap) {
|
125
|
-
return netResult_1.NetReqResult.failed('unknown error');
|
126
|
-
}
|
127
|
-
throw Error('unknown error');
|
128
|
-
}
|
129
|
-
wrapperResult() {
|
130
|
-
this._wrapper = true;
|
131
|
-
return this;
|
132
|
-
}
|
133
|
-
}
|
134
43
|
//# sourceMappingURL=index.js.map
|
package/lib/api/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":";;;AACA,sDAAyD;AACzD,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":";;;AACA,sDAAyD;AACzD,oDAAuD;AACvD,sDAAyD;AACzD,kDAAqD;AACrD,qCAKmB;AAGnB,MAAa,UAAU;IACrB,UAAU,CAAmB;IAC7B,UAAU,CAAmB;IAC7B,SAAS,CAAkB;IAC3B,QAAQ,CAAiB;IACzB,YAAoB,GAAW,EAAE,MAAc;QAC7C,MAAM,QAAQ,GAAG,IAAI,sBAAe,CAAC,GAAG,EAAE,MAAM,CAAC,CAAA;QACjD,MAAM,QAAQ,GAAG,IAAI,uBAAgB,CAAC,GAAG,EAAE,MAAM,CAAC,CAAA;QAClD,MAAM,QAAQ,GAAG,IAAI,uBAAgB,CAAC,GAAG,EAAE,MAAM,CAAC,CAAA;QAClD,MAAM,SAAS,GAAG,IAAI,qBAAc,CAAC,GAAG,EAAE,MAAM,CAAC,CAAA;QACjD,IAAI,CAAC,UAAU,GAAG,IAAI,8BAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;QAC3D,IAAI,CAAC,SAAS,GAAG,IAAI,4BAAgB,CAAC,QAAQ,CAAC,CAAA;QAC/C,IAAI,CAAC,UAAU,GAAG,IAAI,8BAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;QAC3D,IAAI,CAAC,QAAQ,GAAG,IAAI,0BAAe,CAAC,SAAS,CAAC,CAAA;IAChD,CAAC;IAED,MAAM,CAAC,MAAM,CAAC,GAAW,EAAE,MAAc;QACvC,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC,CAAA;QAClC,kCAAkC;QAClC,+CAA+C;QAC/C,kCAAkC;QAClC,kCAAkC;QAClC,oBAAoB;QACpB,+CAA+C;QAC/C,QAAQ;QACR,uBAAuB;QACvB,OAAO;QACP,6CAA6C;QAC7C,mBAAmB;QACnB,OAAO;QACP,KAAK;QACL,iBAAiB;IACnB,CAAC;CACF;AAjCD,gCAiCC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/api/interfaces/index.ts"],"names":[],"mappings":""}
|
@@ -1,11 +1,11 @@
|
|
1
1
|
export interface ScoreSaberItem {
|
2
|
-
score:
|
2
|
+
score: SSScore;
|
3
3
|
leaderboard: LeaderBoard;
|
4
4
|
mapId?: string;
|
5
5
|
}
|
6
|
-
interface
|
6
|
+
export interface SSScore {
|
7
7
|
id: number;
|
8
|
-
leaderboardPlayerInfo:
|
8
|
+
leaderboardPlayerInfo: LeaderboardPlayerInfo;
|
9
9
|
rank: number;
|
10
10
|
baseScore: number;
|
11
11
|
modifiedScore: number;
|
@@ -24,6 +24,15 @@ interface BeatScore {
|
|
24
24
|
deviceControllerLeft: string;
|
25
25
|
deviceControllerRight: string;
|
26
26
|
}
|
27
|
+
export interface LeaderboardPlayerInfo {
|
28
|
+
id: string;
|
29
|
+
name: string;
|
30
|
+
profilePicture: string;
|
31
|
+
country: string;
|
32
|
+
permissions: number;
|
33
|
+
badges?: string;
|
34
|
+
role?: string;
|
35
|
+
}
|
27
36
|
interface LeaderBoard {
|
28
37
|
id: number;
|
29
38
|
songHash: string;
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"leaderboard.js","sourceRoot":"","sources":["../../../../src/api/interfaces/scoresaber/leaderboard.ts"],"names":[],"mappings":""}
|
@@ -2,24 +2,22 @@
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.handleBeatLeaderBind = void 0;
|
4
4
|
const handleBeatLeaderBind = async (c) => {
|
5
|
-
const tokenInfo = await c.api.AIOSaber.
|
6
|
-
if (!tokenInfo
|
7
|
-
c.session.sendQuote(c.session.text('commands.bsbot.
|
5
|
+
const tokenInfo = await c.api.AIOSaber.getBLOAuthToken(c.input);
|
6
|
+
if (!tokenInfo) {
|
7
|
+
c.session.sendQuote(c.session.text('commands.bsbot.bl.account.not-found'));
|
8
8
|
return;
|
9
9
|
}
|
10
|
-
let token = tokenInfo
|
11
|
-
let self = await c.api.BeatLeader.
|
12
|
-
if (!self
|
13
|
-
const refreshToken = await c.api.BeatLeader.
|
14
|
-
if (!refreshToken
|
10
|
+
let token = tokenInfo;
|
11
|
+
let self = await c.api.BeatLeader.getTokenInfo(token.access_token);
|
12
|
+
if (!self) {
|
13
|
+
const refreshToken = await c.api.BeatLeader.refreshOAuthToken(token.refresh_token);
|
14
|
+
if (!refreshToken) {
|
15
15
|
c.session.sendQuote(c.session.text('commands.bsbot.bind.bl.invalid-token'));
|
16
16
|
return;
|
17
17
|
}
|
18
|
-
token = refreshToken
|
19
|
-
self = await c.api.BeatLeader.
|
20
|
-
|
21
|
-
.getTokenInfo(token.access_token);
|
22
|
-
if (!self.isSuccess()) {
|
18
|
+
token = refreshToken;
|
19
|
+
self = await c.api.BeatLeader.getTokenInfo(token.access_token);
|
20
|
+
if (!self) {
|
23
21
|
c.session.sendQuote(c.session.text('commands.bsbot.bind.bl.unknown-error'));
|
24
22
|
return;
|
25
23
|
}
|
@@ -30,8 +28,8 @@ const handleBeatLeaderBind = async (c) => {
|
|
30
28
|
uid: c.session.u.id,
|
31
29
|
platform: 'beatleader',
|
32
30
|
platformScope: 'profile clan offline_access',
|
33
|
-
platformUid: self.
|
34
|
-
platformUname: self.
|
31
|
+
platformUid: self.id,
|
32
|
+
platformUname: self.name,
|
35
33
|
otherPlatformInfo: {},
|
36
34
|
accessToken: token.access_token,
|
37
35
|
refreshToken: token.refresh_token,
|
@@ -45,8 +43,8 @@ const handleBeatLeaderBind = async (c) => {
|
|
45
43
|
}
|
46
44
|
await c.db.addUserBindingInfo(account);
|
47
45
|
c.session.sendQuote(c.session.text('commands.bsbot.bind.bl.success', {
|
48
|
-
name: self.
|
49
|
-
id: self.
|
46
|
+
name: self.name,
|
47
|
+
id: self.id,
|
50
48
|
}));
|
51
49
|
};
|
52
50
|
exports.handleBeatLeaderBind = handleBeatLeaderBind;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"bind-beatleader.js","sourceRoot":"","sources":["../../../src/cmd/bind/bind-beatleader.ts"],"names":[],"mappings":";;;AAEO,MAAM,oBAAoB,GAAG,KAAK,EAAQ,CAAmB,EAAE,EAAE;IACtE,MAAM,SAAS,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,
|
1
|
+
{"version":3,"file":"bind-beatleader.js","sourceRoot":"","sources":["../../../src/cmd/bind/bind-beatleader.ts"],"names":[],"mappings":";;;AAEO,MAAM,oBAAoB,GAAG,KAAK,EAAQ,CAAmB,EAAE,EAAE;IACtE,MAAM,SAAS,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;IAC/D,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC,CAAA;QAC1E,OAAM;IACR,CAAC;IACD,IAAI,KAAK,GAAG,SAAS,CAAA;IACrB,IAAI,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;IAClE,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,iBAAiB,CAC3D,KAAK,CAAC,aAAa,CACpB,CAAA;QACD,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,CAAC,CAAC,OAAO,CAAC,SAAS,CACjB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,sCAAsC,CAAC,CACvD,CAAA;YACD,OAAM;QACR,CAAC;QACD,KAAK,GAAG,YAAY,CAAA;QACpB,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;QAC9D,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,CAAC,CAAC,OAAO,CAAC,SAAS,CACjB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,sCAAsC,CAAC,CACvD,CAAA;YACD,OAAM;QACR,CAAC;IACH,CAAC;IACD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAA;IACtB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;IACrE,MAAM,OAAO,GAA2B;QACtC,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;QACnB,QAAQ,EAAE,YAAY;QACtB,aAAa,EAAE,6BAA6B;QAC5C,WAAW,EAAE,IAAI,CAAC,EAAE;QACpB,aAAa,EAAE,IAAI,CAAC,IAAI;QACxB,iBAAiB,EAAE,EAAE;QACrB,WAAW,EAAE,KAAK,CAAC,YAAY;QAC/B,YAAY,EAAE,KAAK,CAAC,aAAa;QACjC,cAAc,EAAE,GAAG;QACnB,aAAa,EAAE,GAAG;QAClB,IAAI,EAAE,OAAO;QACb,MAAM,EAAE,IAAI;KACb,CAAA;IACD,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,CAAC,EAAE,GAAG,SAAS,CAAC,EAAE,CAAA;IAC3B,CAAC;IAED,MAAM,CAAC,CAAC,EAAE,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAA;IACtC,CAAC,CAAC,OAAO,CAAC,SAAS,CACjB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,gCAAgC,EAAE;QAC/C,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,EAAE,EAAE,IAAI,CAAC,EAAE;KACZ,CAAC,CACH,CAAA;AACH,CAAC,CAAA;AAtDY,QAAA,oBAAoB,wBAsDhC"}
|
@@ -2,37 +2,43 @@
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.handleBeatSaverBind = void 0;
|
4
4
|
const handleBeatSaverBind = async (c) => {
|
5
|
-
const tokenInfo = await c.api.AIOSaber.
|
6
|
-
|
7
|
-
.getBSOAuthToken(c.input);
|
8
|
-
if (!tokenInfo.isSuccess()) {
|
5
|
+
const tokenInfo = await c.api.AIOSaber.getBSOAuthToken(c.input);
|
6
|
+
if (!tokenInfo) {
|
9
7
|
c.session.sendQuote(c.session.text('commands.bsbot.bind.bs.not-found'));
|
10
8
|
return;
|
11
9
|
}
|
12
|
-
let token = tokenInfo
|
13
|
-
let self = await c.api.BeatSaver.
|
14
|
-
|
15
|
-
|
16
|
-
|
10
|
+
let token = tokenInfo;
|
11
|
+
let self = await c.api.BeatSaver.getTokenInfo(token.access_token);
|
12
|
+
// .catch((e) => {
|
13
|
+
// return c.api.BeatSaver.refreshOAuthToken(token.refresh_token)
|
14
|
+
// })
|
15
|
+
// .catch((e) =>
|
16
|
+
// c.session.sendQuote(
|
17
|
+
// c.session.text('commands.bsbot.bind.bs.invalid-token')
|
18
|
+
// )
|
19
|
+
// )
|
20
|
+
if (!self) {
|
21
|
+
const refreshToken = await c.api.BeatSaver.refreshOAuthToken(token.refresh_token);
|
22
|
+
if (!refreshToken) {
|
17
23
|
c.session.sendQuote(c.session.text('commands.bsbot.bind.bs.invalid-token'));
|
18
24
|
return;
|
19
25
|
}
|
20
|
-
token = refreshToken
|
21
|
-
self = await c.api.BeatSaver.
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
}
|
26
|
+
token = refreshToken;
|
27
|
+
self = await c.api.BeatSaver.getTokenInfo(token.access_token);
|
28
|
+
// if (!self.isSuccess()) {
|
29
|
+
// c.session.sendQuote(
|
30
|
+
// c.session.text('commands.bsbot.bind.bs.unknown-error')
|
31
|
+
// )
|
32
|
+
// return
|
33
|
+
// }
|
28
34
|
}
|
29
35
|
const now = new Date();
|
30
36
|
const { bsAccount } = await c.db.getUserAccountsByUid(c.session.u.id);
|
31
37
|
const account = {
|
32
38
|
uid: c.session.u.id,
|
33
39
|
platform: 'beatsaver',
|
34
|
-
platformUid: self.
|
35
|
-
platformUname: self.
|
40
|
+
platformUid: self.id,
|
41
|
+
platformUname: self.name,
|
36
42
|
otherPlatformInfo: {},
|
37
43
|
platformScope: 'identity,alerts',
|
38
44
|
accessToken: token.access_token,
|
@@ -47,8 +53,8 @@ const handleBeatSaverBind = async (c) => {
|
|
47
53
|
}
|
48
54
|
await c.db.addUserBindingInfo(account);
|
49
55
|
c.session.sendQuote(c.session.text('commands.bsbot.bind.bs.success', {
|
50
|
-
name: self.
|
51
|
-
id: self.
|
56
|
+
name: self.name,
|
57
|
+
id: self.id,
|
52
58
|
}));
|
53
59
|
};
|
54
60
|
exports.handleBeatSaverBind = handleBeatSaverBind;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"bind-beatsaver.js","sourceRoot":"","sources":["../../../src/cmd/bind/bind-beatsaver.ts"],"names":[],"mappings":";;;AAEO,MAAM,mBAAmB,GAAG,KAAK,EAAQ,CAAmB,EAAE,EAAE;IACrE,MAAM,SAAS,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,
|
1
|
+
{"version":3,"file":"bind-beatsaver.js","sourceRoot":"","sources":["../../../src/cmd/bind/bind-beatsaver.ts"],"names":[],"mappings":";;;AAEO,MAAM,mBAAmB,GAAG,KAAK,EAAQ,CAAmB,EAAE,EAAE;IACrE,MAAM,SAAS,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;IAC/D,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC,CAAA;QACvE,OAAM;IACR,CAAC;IACD,IAAI,KAAK,GAAG,SAAS,CAAA;IACrB,IAAI,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;IACjE,kBAAkB;IAClB,kEAAkE;IAClE,KAAK;IACL,gBAAgB;IAChB,yBAAyB;IACzB,6DAA6D;IAC7D,MAAM;IACN,IAAI;IACJ,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,iBAAiB,CAC1D,KAAK,CAAC,aAAa,CACpB,CAAA;QACD,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,CAAC,CAAC,OAAO,CAAC,SAAS,CACjB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,sCAAsC,CAAC,CACvD,CAAA;YACD,OAAM;QACR,CAAC;QACD,KAAK,GAAG,YAAY,CAAA;QACpB,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;QAC7D,2BAA2B;QAC3B,yBAAyB;QACzB,6DAA6D;QAC7D,MAAM;QACN,WAAW;QACX,IAAI;IACN,CAAC;IACD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAA;IACtB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;IACrE,MAAM,OAAO,GAA2B;QACtC,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;QACnB,QAAQ,EAAE,WAAW;QACrB,WAAW,EAAE,IAAI,CAAC,EAAE;QACpB,aAAa,EAAE,IAAI,CAAC,IAAI;QACxB,iBAAiB,EAAE,EAAE;QACrB,aAAa,EAAE,iBAAiB;QAChC,WAAW,EAAE,KAAK,CAAC,YAAY;QAC/B,YAAY,EAAE,KAAK,CAAC,aAAa;QACjC,cAAc,EAAE,GAAG;QACnB,aAAa,EAAE,GAAG;QAClB,IAAI,EAAE,OAAO;QACb,MAAM,EAAE,IAAI;KACb,CAAA;IACD,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,CAAC,EAAE,GAAG,SAAS,CAAC,EAAE,CAAA;IAC3B,CAAC;IACD,MAAM,CAAC,CAAC,EAAE,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAA;IACtC,CAAC,CAAC,OAAO,CAAC,SAAS,CACjB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,gCAAgC,EAAE;QAC/C,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,EAAE,EAAE,IAAI,CAAC,EAAE;KACZ,CAAC,CACH,CAAA;AACH,CAAC,CAAA;AA7DY,QAAA,mBAAmB,uBA6D/B"}
|