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
@@ -0,0 +1,115 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.getPreferenceSchemaByKeyOrName = exports.hasPreferenceSchemaByKeyOrName = exports.preferenceSchema = exports.preferenceKey = exports.UserPreferenceStore = void 0;
|
4
|
+
const lru_cache_1 = require("lru-cache");
|
5
|
+
// uid is key currently
|
6
|
+
const cache = new lru_cache_1.LRUCache({
|
7
|
+
max: 500,
|
8
|
+
// for use with tracking overall storage size
|
9
|
+
maxSize: 500,
|
10
|
+
sizeCalculation: (value, key) => 1,
|
11
|
+
// for use when you need to clean up something when objects
|
12
|
+
// are evicted from the cache
|
13
|
+
// dispose: (value, key) => {},
|
14
|
+
// how long to live in ms
|
15
|
+
ttl: 1000 * 60 * 60 * 24 * 7,
|
16
|
+
// return stale items before removing from cache?
|
17
|
+
allowStale: false,
|
18
|
+
updateAgeOnGet: true,
|
19
|
+
updateAgeOnHas: true,
|
20
|
+
});
|
21
|
+
class UserPreferenceStore {
|
22
|
+
db;
|
23
|
+
uid;
|
24
|
+
v = undefined;
|
25
|
+
constructor(db, uid) {
|
26
|
+
this.db = db;
|
27
|
+
this.uid = uid;
|
28
|
+
}
|
29
|
+
async getUserPreference(uid) {
|
30
|
+
return new UserPreferenceStore(this.db, uid);
|
31
|
+
}
|
32
|
+
async set(key, value) {
|
33
|
+
if (!this.v) {
|
34
|
+
this.v = (await this.db.getUserPreference(this.uid)) ?? {};
|
35
|
+
}
|
36
|
+
const cacheKey = `${this.uid}`;
|
37
|
+
const v = {
|
38
|
+
...this.v,
|
39
|
+
[key]: value,
|
40
|
+
};
|
41
|
+
await this.db.storeUserPreference(this.uid, v);
|
42
|
+
cache.set(cacheKey, v);
|
43
|
+
this.v = v;
|
44
|
+
return true;
|
45
|
+
}
|
46
|
+
async get(key) {
|
47
|
+
const cacheKey = `${this.uid}`;
|
48
|
+
const has = cache.has(cacheKey);
|
49
|
+
if (has) {
|
50
|
+
const v = cache.get(cacheKey);
|
51
|
+
return v?.[key] ?? exports.preferenceSchema[key]?.default;
|
52
|
+
}
|
53
|
+
const value = (await this.db.getUserPreference(this.uid)) ?? {};
|
54
|
+
cache.set(cacheKey, value);
|
55
|
+
return value?.[key] ?? exports.preferenceSchema[key]?.default;
|
56
|
+
}
|
57
|
+
async configEntries() {
|
58
|
+
await this.get('');
|
59
|
+
return cache.get(this.uid);
|
60
|
+
}
|
61
|
+
}
|
62
|
+
exports.UserPreferenceStore = UserPreferenceStore;
|
63
|
+
exports.preferenceKey = {
|
64
|
+
blProfileRenderImg: {
|
65
|
+
key: 'bl::profile::render::img',
|
66
|
+
i18nName: 'BLProfile背景图片',
|
67
|
+
},
|
68
|
+
ssProfileRenderImg: {
|
69
|
+
key: 'ss::profile::render::img',
|
70
|
+
i18nName: 'SSProfile背景图片',
|
71
|
+
},
|
72
|
+
blScoreImg: {
|
73
|
+
key: 'bl::score::render::img',
|
74
|
+
i18nName: 'BLScore背景图片',
|
75
|
+
},
|
76
|
+
};
|
77
|
+
exports.preferenceSchema = {
|
78
|
+
'bl::profile::render::img': {
|
79
|
+
key: 'bl::profile::render::img',
|
80
|
+
i18nName: 'BLProfile背景图片',
|
81
|
+
valueType: 'img-url',
|
82
|
+
default: 'https://www.loliapi.com/acg/pc/',
|
83
|
+
},
|
84
|
+
'ss::profile::render::img': {
|
85
|
+
key: 'ss::profile::render::img',
|
86
|
+
i18nName: 'SSProfile背景图片',
|
87
|
+
valueType: 'img-url',
|
88
|
+
default: 'https://www.loliapi.com/acg/pc/',
|
89
|
+
},
|
90
|
+
'bl::score::render::img': {
|
91
|
+
key: 'bl::score::render::img',
|
92
|
+
i18nName: 'BLScore背景图片',
|
93
|
+
valueType: 'img-url',
|
94
|
+
default: 'https://www.loliapi.com/acg/pc/',
|
95
|
+
},
|
96
|
+
};
|
97
|
+
const preferenceMap = new Map();
|
98
|
+
Object.entries(exports.preferenceSchema).forEach(([key, value]) => {
|
99
|
+
preferenceMap.set(value.i18nName, value);
|
100
|
+
});
|
101
|
+
const hasPreferenceSchemaByKeyOrName = (key) => {
|
102
|
+
if (key in exports.preferenceSchema) {
|
103
|
+
return true;
|
104
|
+
}
|
105
|
+
return preferenceMap.has(key);
|
106
|
+
};
|
107
|
+
exports.hasPreferenceSchemaByKeyOrName = hasPreferenceSchemaByKeyOrName;
|
108
|
+
const getPreferenceSchemaByKeyOrName = (key) => {
|
109
|
+
if (key in exports.preferenceSchema) {
|
110
|
+
return exports.preferenceSchema[key];
|
111
|
+
}
|
112
|
+
return preferenceMap.get(key);
|
113
|
+
};
|
114
|
+
exports.getPreferenceSchemaByKeyOrName = getPreferenceSchemaByKeyOrName;
|
115
|
+
//# sourceMappingURL=preference.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"preference.js","sourceRoot":"","sources":["../../src/utils/preference.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
/// <reference types="node" />
|
2
|
+
import { Browser, ScreenshotClip, ScreenshotOptions } from 'puppeteer-core';
|
3
|
+
import { Config } from '../config';
|
4
|
+
export interface PuppeteerProvider {
|
5
|
+
browser: () => Promise<Browser>;
|
6
|
+
ok: boolean;
|
7
|
+
}
|
8
|
+
export declare class RemotePuppeteerProvider implements PuppeteerProvider {
|
9
|
+
_browser: Browser;
|
10
|
+
endpoint: string;
|
11
|
+
_ok: boolean;
|
12
|
+
browser(): Promise<Browser>;
|
13
|
+
constructor(config: Config);
|
14
|
+
get ok(): boolean;
|
15
|
+
}
|
16
|
+
export declare class PuppeteerRender {
|
17
|
+
browserHolders: PuppeteerProvider[];
|
18
|
+
get browser(): Promise<Browser>;
|
19
|
+
get ok(): false | PuppeteerProvider;
|
20
|
+
constructor(providers: PuppeteerProvider[]);
|
21
|
+
renderHTML(html: string, selector: string, onStart?: () => void, screenShotOption?: (clip: ScreenshotClip) => ScreenshotOptions): Promise<Buffer>;
|
22
|
+
screenshotURL(url: string, selector: string, onStart?: () => void, screenShotOption?: (clip: ScreenshotClip) => ScreenshotOptions): Promise<Buffer>;
|
23
|
+
}
|
@@ -0,0 +1,92 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.PuppeteerRender = exports.RemotePuppeteerProvider = void 0;
|
7
|
+
const puppeteer_core_1 = __importDefault(require("puppeteer-core"));
|
8
|
+
const index_1 = require("./index");
|
9
|
+
class RemotePuppeteerProvider {
|
10
|
+
_browser;
|
11
|
+
endpoint;
|
12
|
+
_ok = true;
|
13
|
+
async browser() {
|
14
|
+
if (this._browser?.connected) {
|
15
|
+
return this._browser;
|
16
|
+
}
|
17
|
+
try {
|
18
|
+
this._browser = await puppeteer_core_1.default.connect({
|
19
|
+
browserWSEndpoint: this.endpoint,
|
20
|
+
});
|
21
|
+
return this._browser;
|
22
|
+
}
|
23
|
+
catch (e) {
|
24
|
+
this._ok = false;
|
25
|
+
}
|
26
|
+
}
|
27
|
+
constructor(config) {
|
28
|
+
this.endpoint = config.broswerlessWSEndpoint;
|
29
|
+
}
|
30
|
+
get ok() {
|
31
|
+
return this._ok;
|
32
|
+
}
|
33
|
+
}
|
34
|
+
exports.RemotePuppeteerProvider = RemotePuppeteerProvider;
|
35
|
+
class PuppeteerRender {
|
36
|
+
browserHolders;
|
37
|
+
get browser() {
|
38
|
+
const provider = this.browserHolders.find((it) => it.ok);
|
39
|
+
if (provider) {
|
40
|
+
return provider.browser();
|
41
|
+
}
|
42
|
+
throw Error('NoSuitablePuppeteerProviderFound');
|
43
|
+
}
|
44
|
+
get ok() {
|
45
|
+
return this.browserHolders.find((it) => it.ok) ?? false;
|
46
|
+
}
|
47
|
+
constructor(providers) {
|
48
|
+
this.browserHolders = providers;
|
49
|
+
}
|
50
|
+
async renderHTML(html, selector, onStart, screenShotOption) {
|
51
|
+
onStart?.();
|
52
|
+
const browser = await this.browser;
|
53
|
+
const page = await browser.newPage();
|
54
|
+
await page.setContent(html);
|
55
|
+
// await page.setViewport({
|
56
|
+
// width: 3840,
|
57
|
+
// height: 2160,
|
58
|
+
// deviceScaleFactor: 1,
|
59
|
+
// })
|
60
|
+
const elm = await page.waitForSelector(selector, { timeout: 5000 });
|
61
|
+
const clip = await elm.boundingBox();
|
62
|
+
const u8Arr = await elm.screenshot(screenShotOption
|
63
|
+
? screenShotOption(clip)
|
64
|
+
: {
|
65
|
+
clip: clip,
|
66
|
+
type: 'png',
|
67
|
+
});
|
68
|
+
await page.close();
|
69
|
+
return Buffer.from(u8Arr);
|
70
|
+
}
|
71
|
+
async screenshotURL(url, selector, onStart, screenShotOption) {
|
72
|
+
onStart?.();
|
73
|
+
const browser = await this.browser;
|
74
|
+
const page = await browser.newPage();
|
75
|
+
// await page.setViewport({
|
76
|
+
// width: 3840,
|
77
|
+
// height: 2160,
|
78
|
+
// deviceScaleFactor: 1,
|
79
|
+
// })
|
80
|
+
await page.goto(url, { timeout: 0, waitUntil: 'domcontentloaded' });
|
81
|
+
const elm = await page.waitForSelector(selector, { timeout: 10000 });
|
82
|
+
// wait for potential animation
|
83
|
+
await (0, index_1.sleep)(3000);
|
84
|
+
// const clip = await elm.boundingBox()
|
85
|
+
const buffer = await elm
|
86
|
+
.screenshot();
|
87
|
+
await page.close();
|
88
|
+
return Buffer.from(buffer);
|
89
|
+
}
|
90
|
+
}
|
91
|
+
exports.PuppeteerRender = PuppeteerRender;
|
92
|
+
//# sourceMappingURL=puppeteer.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"puppeteer.js","sourceRoot":"","sources":["../../src/utils/puppeteer.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
/// <reference types="node" />
|
2
|
+
import { Config } from '../config';
|
3
|
+
export declare class TmpFileStorage {
|
4
|
+
private s3Client;
|
5
|
+
private readonly bucket;
|
6
|
+
private readonly keyPrefix;
|
7
|
+
private readonly baseURL;
|
8
|
+
constructor(config: Config);
|
9
|
+
uploadImgWithUrl(url: string, mimeType?: string): Promise<string>;
|
10
|
+
uploadImg(buffer: Buffer, mimeType?: string): Promise<string>;
|
11
|
+
}
|
package/lib/utils/s3.js
ADDED
@@ -0,0 +1,60 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.TmpFileStorage = void 0;
|
7
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
8
|
+
const crypto_1 = __importDefault(require("crypto"));
|
9
|
+
class TmpFileStorage {
|
10
|
+
s3Client;
|
11
|
+
bucket;
|
12
|
+
keyPrefix = '';
|
13
|
+
baseURL = '';
|
14
|
+
// env sdk, env
|
15
|
+
constructor(config) {
|
16
|
+
const s3 = new client_s3_1.S3Client({
|
17
|
+
region: config.uploadImageToS3.region ?? 'auto',
|
18
|
+
endpoint: config.uploadImageToS3.endpoint,
|
19
|
+
credentials: {
|
20
|
+
accessKeyId: config.uploadImageToS3.s3AccessKey,
|
21
|
+
secretAccessKey: config.uploadImageToS3.s3SecretKey,
|
22
|
+
},
|
23
|
+
});
|
24
|
+
this.bucket = config.uploadImageToS3.bucketName;
|
25
|
+
this.keyPrefix = config.uploadImageToS3.keyPrefix;
|
26
|
+
this.baseURL = config.uploadImageToS3.baseURL;
|
27
|
+
this.s3Client = s3;
|
28
|
+
}
|
29
|
+
async uploadImgWithUrl(url, mimeType) {
|
30
|
+
const res = await fetch(url).then((it) => it.arrayBuffer());
|
31
|
+
const buf = Buffer.from(res);
|
32
|
+
const md5 = crypto_1.default.createHash('md5').update(buf).digest('hex');
|
33
|
+
const key = this.keyPrefix ? `${this.keyPrefix}-${md5}` : md5;
|
34
|
+
const params = {
|
35
|
+
Bucket: this.bucket,
|
36
|
+
Key: key,
|
37
|
+
Body: buf,
|
38
|
+
ContentType: mimeType ?? 'image/png',
|
39
|
+
};
|
40
|
+
const command = new client_s3_1.PutObjectCommand(params);
|
41
|
+
const data = await this.s3Client.send(command);
|
42
|
+
return `${this.baseURL}${key}`;
|
43
|
+
}
|
44
|
+
async uploadImg(buffer, mimeType) {
|
45
|
+
// md5 digest
|
46
|
+
const md5 = crypto_1.default.createHash('md5').update(buffer).digest('hex');
|
47
|
+
const key = this.keyPrefix ? `${this.keyPrefix}-${md5}` : md5;
|
48
|
+
const params = {
|
49
|
+
Bucket: this.bucket,
|
50
|
+
Key: key,
|
51
|
+
Body: buffer,
|
52
|
+
ContentType: mimeType ?? 'image/png',
|
53
|
+
};
|
54
|
+
const command = new client_s3_1.PutObjectCommand(params);
|
55
|
+
const data = await this.s3Client.send(command);
|
56
|
+
return `${this.baseURL}${key}`;
|
57
|
+
}
|
58
|
+
}
|
59
|
+
exports.TmpFileStorage = TmpFileStorage;
|
60
|
+
//# sourceMappingURL=s3.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"s3.js","sourceRoot":"","sources":["../../src/utils/s3.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA+D;AAC/D,oDAA2B;AAG3B,MAAa,cAAc;IACjB,QAAQ,CAAU;IACT,MAAM,CAAQ;IACd,SAAS,GAAW,EAAE,CAAA;IACtB,OAAO,GAAW,EAAE,CAAA;IACrC,eAAe;IACf,YAAY,MAAc;QACxB,MAAM,EAAE,GAAG,IAAI,oBAAQ,CAAC;YACtB,MAAM,EAAE,MAAM,CAAC,eAAe,CAAC,MAAM,IAAI,MAAM;YAC/C,QAAQ,EAAE,MAAM,CAAC,eAAe,CAAC,QAAQ;YACzC,WAAW,EAAE;gBACX,WAAW,EAAE,MAAM,CAAC,eAAe,CAAC,WAAW;gBAC/C,eAAe,EAAE,MAAM,CAAC,eAAe,CAAC,WAAW;aACpD;SACF,CAAC,CAAA;QACF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,eAAe,CAAC,UAAU,CAAA;QAC/C,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,eAAe,CAAC,SAAS,CAAA;QACjD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,eAAe,CAAC,OAAO,CAAA;QAC7C,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;IACpB,CAAC;IACD,KAAK,CAAC,gBAAgB,CAAC,GAAW,EAAE,QAAiB;QACnD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,CAAA;QAC3D,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC5B,MAAM,GAAG,GAAG,gBAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAC9D,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAA;QAC7D,MAAM,MAAM,GAAG;YACb,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,GAAG,EAAE,GAAG;YACR,IAAI,EAAE,GAAG;YACT,WAAW,EAAE,QAAQ,IAAI,WAAW;SACrC,CAAA;QACD,MAAM,OAAO,GAAG,IAAI,4BAAgB,CAAC,MAAM,CAAC,CAAA;QAC5C,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAC9C,OAAO,GAAG,IAAI,CAAC,OAAO,GAAG,GAAG,EAAE,CAAA;IAChC,CAAC;IACD,KAAK,CAAC,SAAS,CAAC,MAAc,EAAE,QAAiB;QAC/C,aAAa;QACb,MAAM,GAAG,GAAG,gBAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QACjE,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAA;QAC7D,MAAM,MAAM,GAAG;YACb,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,GAAG,EAAE,GAAG;YACR,IAAI,EAAE,MAAM;YACZ,WAAW,EAAE,QAAQ,IAAI,WAAW;SACrC,CAAA;QACD,MAAM,OAAO,GAAG,IAAI,4BAAgB,CAAC,MAAM,CAAC,CAAA;QAC5C,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAC9C,OAAO,GAAG,IAAI,CAAC,OAAO,GAAG,GAAG,EAAE,CAAA;IAChC,CAAC;CACF;AAjDD,wCAiDC"}
|
package/lib/ws/beatsaver.js
CHANGED
@@ -37,8 +37,12 @@ class BeatSaverWSHandler {
|
|
37
37
|
const userId = bsmap.uploader.id;
|
38
38
|
const subscriptions = await this.db.getAllSubScriptionByUIDAndPlatform(userId, 'beatsaver');
|
39
39
|
const restSub = subscriptions.filter((it) => it.subscribe.type == 'beatsaver-map' && it.subscribe.enable == true);
|
40
|
+
const gids = restSub.map((it) => it.groupChannel.id);
|
41
|
+
const groupSubs = await this.db.getIDSubscriptionByType('id-beatsaver-map');
|
42
|
+
const restGroupSubs = groupSubs.filter((it) => !gids.includes(it.groupChannel.id) &&
|
43
|
+
it.subscribe.data?.mapperId?.toString() === userId.toString());
|
40
44
|
// cacheService
|
41
|
-
if (restSub.length === 0)
|
45
|
+
if (restSub.length === 0 && restGroupSubs)
|
42
46
|
return;
|
43
47
|
const image = this.render.renderMap(bsmap);
|
44
48
|
for (const item of restSub) {
|
@@ -48,7 +52,17 @@ class BeatSaverWSHandler {
|
|
48
52
|
}
|
49
53
|
await session.send(`本群谱师 「<at id="${item.account.uid}"/> (${bsmap.uploader.name})」刚刚发布了新谱面,「${bsmap.name}」`);
|
50
54
|
// text + mention element
|
51
|
-
await session.
|
55
|
+
await session.sendImgBuffer(await image);
|
56
|
+
await session.sendAudioByUrl(bsmap.versions[0].previewURL);
|
57
|
+
}
|
58
|
+
for (const item of restGroupSubs) {
|
59
|
+
const session = this.botService.getSessionByChannelInfo(item.groupChannel);
|
60
|
+
if (!session) {
|
61
|
+
continue;
|
62
|
+
}
|
63
|
+
await session.send(`谱师「${bsmap.uploader.name}」刚刚发布了新谱面,「${bsmap.name}」`);
|
64
|
+
// text + mention element
|
65
|
+
await session.sendImgBuffer(await image);
|
52
66
|
await session.sendAudioByUrl(bsmap.versions[0].previewURL);
|
53
67
|
}
|
54
68
|
}
|
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,WAAW,CAAC,KAAK;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAqB,CAAA;IACzD,CAAC;IAED,WAAW,GAAG,CAAC,IAAsB,EAAE,EAAE;QACvC,OAAO,CACL,IAAI,CAAC,IAAI,KAAK,YAAY;YAC1B,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,IAAI,WAAW,CAAC;YACvD,IAAI,CAAC,GAAG,CAAC,UAAU,KAAK,MAAM,CAC/B,CAAA;IACH,CAAC,CAAA;IACD,eAAe,GAAG,CAAC,IAAsB,EAAE,EAAE,CAC3C,SAAS,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,CAAA;IAE7E,KAAK,CAAC,WAAW,CAAC,IAAsB;QACtC,2EAA2E;QAE3E,MAAM,KAAK,GAAG,IAAI,CAAC,GAAY,CAAA;QAC/B,MAAM,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAA;QAChC,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,kCAAkC,CACpE,MAAM,EACN,WAAW,CACZ,CAAA;
|
1
|
+
{"version":3,"file":"beatsaver.js","sourceRoot":"","sources":["../../src/ws/beatsaver.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "beatsaber-bot-core",
|
3
3
|
"description": "一个用于新版 Steam 家庭的库存监控 Bot 插件",
|
4
|
-
"version": "0.2.0-
|
4
|
+
"version": "0.2.0-rc.2",
|
5
5
|
"types": "lib/index.d.ts",
|
6
6
|
"files": [
|
7
7
|
"lib"
|
@@ -52,18 +52,26 @@
|
|
52
52
|
"access": "public"
|
53
53
|
},
|
54
54
|
"dependencies": {
|
55
|
-
"@
|
55
|
+
"@aws-sdk/client-s3": "^3.658.1",
|
56
|
+
"@ktfun/styled-qr-code-node": "^1.6.5",
|
56
57
|
"chart.js": "^4.4.3",
|
57
58
|
"country-flag-icons": "^1.5.11",
|
58
59
|
"dayjs": "^1.11.3",
|
59
60
|
"lru-cache": "^11.0.1",
|
60
61
|
"lucide-react": "^0.379.0",
|
62
|
+
"ofetch": "^1.4.1",
|
63
|
+
"puppeteer-core": "^23.8.0",
|
61
64
|
"react": "^18.3.1",
|
62
65
|
"react-dom": "^18.3.1"
|
63
66
|
},
|
64
|
-
"
|
67
|
+
"devDependencies": {
|
68
|
+
"tailwindcss": "^3.4.15",
|
69
|
+
"autoprefixer": "^10.4.20"
|
70
|
+
},
|
71
|
+
"optionalDependencies": {
|
65
72
|
"canvas": "^2.11.2",
|
66
|
-
"skia-canvas": "^1.0.
|
73
|
+
"skia-canvas": "^1.0.2",
|
74
|
+
"@napi-rs/canvas": "^0.1.62"
|
67
75
|
},
|
68
76
|
"typesVersions": {
|
69
77
|
"*": {
|
@@ -1,6 +0,0 @@
|
|
1
|
-
import { AioOauthTokenResponse } from '../interfaces/aiosaber';
|
2
|
-
import { Config } from '../../config';
|
3
|
-
export declare const aioRequest: (cfg: Config) => {
|
4
|
-
getBSOAuthToken: (key: string) => Promise<AioOauthTokenResponse>;
|
5
|
-
getBLOAuthToken: (key: string) => Promise<AioOauthTokenResponse>;
|
6
|
-
};
|
@@ -1,24 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.aioRequest = void 0;
|
4
|
-
const get = (...args) => fetch(args).then((res) => res.json());
|
5
|
-
const aioRequest = (cfg) => {
|
6
|
-
let host = 'https://aiobs.ktlab.io';
|
7
|
-
if (host.endsWith('/')) {
|
8
|
-
host = host.substring(0, host.length - 1);
|
9
|
-
}
|
10
|
-
const url = (path) => {
|
11
|
-
if (!path.startsWith('/')) {
|
12
|
-
path = '/' + path;
|
13
|
-
}
|
14
|
-
return host + path;
|
15
|
-
};
|
16
|
-
const getBSOAuthToken = async (key) => get(url(`/api/oauth/beatsaver/token/${key}`));
|
17
|
-
const getBLOAuthToken = async (key) => get(url(`/api/oauth/beatleader/token/${key}`));
|
18
|
-
return {
|
19
|
-
getBSOAuthToken,
|
20
|
-
getBLOAuthToken,
|
21
|
-
};
|
22
|
-
};
|
23
|
-
exports.aioRequest = aioRequest;
|
24
|
-
//# sourceMappingURL=aioRequest.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"aioRequest.js","sourceRoot":"","sources":["../../../src/api/base/aioRequest.ts"],"names":[],"mappings":";;;AAGA,MAAM,GAAG,GAAG,CAAI,GAAG,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,IAAW,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAO,CAAC,CAAA;AAEtE,MAAM,UAAU,GAAG,CAAC,GAAW,EAAE,EAAE;IACxC,IAAI,IAAI,GAAG,wBAAwB,CAAA;IACnC,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QACvB,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IAC3C,CAAC;IACD,MAAM,GAAG,GAAG,CAAC,IAAY,EAAE,EAAE;QAC3B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,IAAI,GAAG,GAAG,GAAG,IAAI,CAAA;QACnB,CAAC;QACD,OAAO,IAAI,GAAG,IAAI,CAAA;IACpB,CAAC,CAAA;IACD,MAAM,eAAe,GAAG,KAAK,EAAE,GAAW,EAAE,EAAE,CAC5C,GAAG,CAAwB,GAAG,CAAC,8BAA8B,GAAG,EAAE,CAAC,CAAC,CAAA;IACtE,MAAM,eAAe,GAAG,KAAK,EAAE,GAAW,EAAE,EAAE,CAC5C,GAAG,CAAwB,GAAG,CAAC,+BAA+B,GAAG,EAAE,CAAC,CAAC,CAAA;IACvE,OAAO;QACL,eAAe;QACf,eAAe;KAChB,CAAA;AACH,CAAC,CAAA;AAnBY,QAAA,UAAU,cAmBtB"}
|
@@ -1,12 +0,0 @@
|
|
1
|
-
import { BeadLeaderScoresResponse, BeatLeaderPlayerScoreRequest, Leaderboard, Score, BeatLeaderUser } from '../interfaces/beatleader';
|
2
|
-
import { Config } from '../../config';
|
3
|
-
import { OAuthTokenInfoResponse, OAuthTokenResponse } from './bsRequest';
|
4
|
-
export declare const blRequest: (cfg: Config) => {
|
5
|
-
getPlayerScore: (req: BeatLeaderPlayerScoreRequest) => Promise<Leaderboard>;
|
6
|
-
getPlayerScores: (accountId: string) => Promise<BeadLeaderScoresResponse>;
|
7
|
-
getPlayerInfo: (accountId: string) => Promise<BeatLeaderUser>;
|
8
|
-
getPlayerPinnedScores: (accountId: string) => Promise<Score[]>;
|
9
|
-
getTokenInfo: (accessToken: string) => Promise<OAuthTokenInfoResponse>;
|
10
|
-
refreshOAuthToken: (refreshToken: string) => Promise<OAuthTokenResponse>;
|
11
|
-
getBeatScore: (scoreId: string) => Promise<Score>;
|
12
|
-
};
|
@@ -1,68 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.blRequest = void 0;
|
4
|
-
const utils_1 = require("../../utils");
|
5
|
-
const blRequest = (cfg) => {
|
6
|
-
let host = 'https://api.beatleader.xyz';
|
7
|
-
if (host.endsWith('/')) {
|
8
|
-
host = host.substring(0, host.length - 1);
|
9
|
-
}
|
10
|
-
const url = (path) => {
|
11
|
-
if (!path.startsWith('/')) {
|
12
|
-
path = '/' + path;
|
13
|
-
}
|
14
|
-
return host + path;
|
15
|
-
};
|
16
|
-
const getPlayerScore = async (req) => {
|
17
|
-
const res = await (0, utils_1.fetchWithCache)(url(`/score/${req.leaderboardContext}/${req.playerID}/${req.hash}/${req.diff}/${req.mode}`));
|
18
|
-
return res;
|
19
|
-
};
|
20
|
-
const getTokenInfo = async (accessToken) => {
|
21
|
-
return (0, utils_1.fetchWithCache)(url(`/oauth2/identity`), {
|
22
|
-
headers: {
|
23
|
-
Authorization: `Bearer ${accessToken}`,
|
24
|
-
},
|
25
|
-
});
|
26
|
-
};
|
27
|
-
const refreshOAuthToken = async (refreshToken) => {
|
28
|
-
const form = new URLSearchParams();
|
29
|
-
form.append('client_id', cfg.blOauthClientId);
|
30
|
-
form.append('client_secret', cfg.blOauthClientSecret);
|
31
|
-
form.append('grant_type', 'refresh_token');
|
32
|
-
form.append('refresh_token', refreshToken);
|
33
|
-
const res = await fetch('https://beatsaver.com/api/oauth2/token', {
|
34
|
-
method: 'POST',
|
35
|
-
headers: {
|
36
|
-
'Content-Type': 'application/x-www-form-urlencoded',
|
37
|
-
},
|
38
|
-
body: form,
|
39
|
-
}).then((res) => res.json());
|
40
|
-
if (!res.access_token) {
|
41
|
-
throw new Error('refreshToken failed');
|
42
|
-
}
|
43
|
-
return res;
|
44
|
-
};
|
45
|
-
const getPlayerInfo = async (accountId) => {
|
46
|
-
return (0, utils_1.fetchWithCache)(url(`/player/${accountId}`));
|
47
|
-
};
|
48
|
-
const getPlayerScores = async (accountId) => {
|
49
|
-
return (0, utils_1.fetchWithCache)(url(`/player/${accountId}/scores?count=24&sortBy=pp`));
|
50
|
-
};
|
51
|
-
const getPlayerPinnedScores = async (accountId) => {
|
52
|
-
return (0, utils_1.fetchWithCache)(url(`/player/${accountId}/pinnedScores`));
|
53
|
-
};
|
54
|
-
const getBeatScore = async (scoreId) => {
|
55
|
-
return (0, utils_1.fetchWithCache)(url(`/score/${scoreId}`));
|
56
|
-
};
|
57
|
-
return {
|
58
|
-
getPlayerScore,
|
59
|
-
getPlayerScores,
|
60
|
-
getPlayerInfo,
|
61
|
-
getPlayerPinnedScores,
|
62
|
-
getTokenInfo,
|
63
|
-
refreshOAuthToken,
|
64
|
-
getBeatScore,
|
65
|
-
};
|
66
|
-
};
|
67
|
-
exports.blRequest = blRequest;
|
68
|
-
//# sourceMappingURL=blRequset.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"blRequset.js","sourceRoot":"","sources":["../../../src/api/base/blRequset.ts"],"names":[],"mappings":"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"}
|
@@ -1,24 +0,0 @@
|
|
1
|
-
import { Config } from '../../config';
|
2
|
-
import { BeatsaverAlert, BSMap, BSUserResponse, HashReqResponse } from '../interfaces/beatsaver';
|
3
|
-
export interface OAuthTokenResponse {
|
4
|
-
access_token: string;
|
5
|
-
token_type: string;
|
6
|
-
expires_in: number;
|
7
|
-
refresh_token: string;
|
8
|
-
scope?: string;
|
9
|
-
}
|
10
|
-
export interface OAuthTokenInfoResponse {
|
11
|
-
scope?: string[];
|
12
|
-
id: string;
|
13
|
-
name: string;
|
14
|
-
}
|
15
|
-
export declare const bsRequest: (cfg: Config) => {
|
16
|
-
refreshOAuthToken: (refreshToken: string) => Promise<OAuthTokenResponse>;
|
17
|
-
getBSMapperById: (userId: string) => Promise<BSUserResponse>;
|
18
|
-
getLatestMaps: (pageSize?: number) => Promise<BSMap[]>;
|
19
|
-
searchMapByKeyword: (key: string) => Promise<BSMap[]>;
|
20
|
-
searchMapById: (id: string) => Promise<BSMap>;
|
21
|
-
getUnreadAlertsByPage: (accessToken: string, page: number) => Promise<BeatsaverAlert[]>;
|
22
|
-
getTokenInfo: (accessToken: string) => Promise<OAuthTokenInfoResponse>;
|
23
|
-
getMapsByHashes: (hashes: string[]) => Promise<HashReqResponse>;
|
24
|
-
};
|
@@ -1,64 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.bsRequest = void 0;
|
4
|
-
const get = (...args) => fetch(args).then((res) => res.json());
|
5
|
-
const bsRequest = (cfg) => {
|
6
|
-
let host = cfg.beatSaverHost ?? 'https://api.beatsaver.com';
|
7
|
-
if (host.endsWith('/')) {
|
8
|
-
host = host.substring(0, host.length - 1);
|
9
|
-
}
|
10
|
-
const url = (path) => {
|
11
|
-
if (!path.startsWith('/')) {
|
12
|
-
path = '/' + path;
|
13
|
-
}
|
14
|
-
return host + path;
|
15
|
-
};
|
16
|
-
const getBSMapperById = async (userId) => get(url(`/users/id/${userId}`));
|
17
|
-
const getLatestMaps = async (pageSize = 5) => get(url(`/maps/latest?sort=FIRST_PUBLISHED&pageSize=${pageSize}`)).then((res) => res.docs);
|
18
|
-
const searchMapByKeyword = async (key) => get(url(`/search/text/0?q=${key}`)).then((res) => res.docs);
|
19
|
-
const searchMapById = async (id) => get(url(`/maps/id/${id}`));
|
20
|
-
const getAlertsStats = async (accessToken) => get(url(`/alerts/stats`), {
|
21
|
-
headers: { Authorization: `Bearer ${accessToken}` },
|
22
|
-
});
|
23
|
-
const getAlertsByPage = async (accessToken, type, page) => get(url(`/alerts/${type}/${page}`), {
|
24
|
-
headers: { Authorization: `Bearer ${accessToken}` },
|
25
|
-
});
|
26
|
-
const getUnreadAlertsByPage = (accessToken, page) => getAlertsByPage(accessToken, 'unread', page);
|
27
|
-
const getReadAlertsByPage = (accessToken, page) => getAlertsByPage(accessToken, 'read', page);
|
28
|
-
const refreshOAuthToken = async (refreshToken) => {
|
29
|
-
const form = new FormData();
|
30
|
-
form.append('client_id', cfg.bsOauthClientId);
|
31
|
-
form.append('client_secret', cfg.bsOauthClientSecret);
|
32
|
-
form.append('grant_type', 'refresh_token');
|
33
|
-
form.append('refresh_token', refreshToken);
|
34
|
-
const res = await fetch('https://beatsaver.com/api/oauth2/token', {
|
35
|
-
method: 'POST',
|
36
|
-
body: form,
|
37
|
-
}).then((res) => res.json());
|
38
|
-
if (!res.access_token) {
|
39
|
-
throw new Error('refreshToken failed');
|
40
|
-
}
|
41
|
-
return res;
|
42
|
-
};
|
43
|
-
//
|
44
|
-
const getTokenInfo = async (accessToken) => {
|
45
|
-
return get(url(`/oauth2/identity`), {
|
46
|
-
headers: {
|
47
|
-
Authorization: `Bearer ${accessToken}`,
|
48
|
-
},
|
49
|
-
});
|
50
|
-
};
|
51
|
-
const getMapsByHashes = async (hashes) => get(url(`/maps/hash/${hashes.join(',')}`));
|
52
|
-
return {
|
53
|
-
refreshOAuthToken,
|
54
|
-
getBSMapperById,
|
55
|
-
getLatestMaps,
|
56
|
-
searchMapByKeyword,
|
57
|
-
searchMapById,
|
58
|
-
getUnreadAlertsByPage,
|
59
|
-
getTokenInfo,
|
60
|
-
getMapsByHashes,
|
61
|
-
};
|
62
|
-
};
|
63
|
-
exports.bsRequest = bsRequest;
|
64
|
-
//# sourceMappingURL=bsRequest.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"bsRequest.js","sourceRoot":"","sources":["../../../src/api/base/bsRequest.ts"],"names":[],"mappings":"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"}
|
@@ -1,6 +0,0 @@
|
|
1
|
-
import { Config } from '../../config';
|
2
|
-
import { ScoreSaberUser, ScoreSaberUserResponse } from '../interfaces/scoresaber';
|
3
|
-
export declare const scRequest: (cfg: Config) => {
|
4
|
-
getScoreUserById: (userId: string) => Promise<ScoreSaberUser>;
|
5
|
-
getScoreItemsById: (userId: string, page: number, pageSize?: number) => Promise<ScoreSaberUserResponse>;
|
6
|
-
};
|