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.
Files changed (196) hide show
  1. package/lib/api/base/aioclient.d.ts +11 -0
  2. package/lib/api/base/aioclient.js +20 -0
  3. package/lib/api/base/aioclient.js.map +1 -0
  4. package/lib/api/base/blclient.d.ts +18 -0
  5. package/lib/api/base/blclient.js +60 -0
  6. package/lib/api/base/blclient.js.map +1 -0
  7. package/lib/api/base/bsclient.d.ts +17 -0
  8. package/lib/api/base/bsclient.js +75 -0
  9. package/lib/api/base/bsclient.js.map +1 -0
  10. package/lib/api/base/index.d.ts +4 -12
  11. package/lib/api/base/index.js +4 -4
  12. package/lib/api/base/index.js.map +1 -1
  13. package/lib/api/base/ssclient.d.ts +13 -0
  14. package/lib/api/base/ssclient.js +48 -0
  15. package/lib/api/base/ssclient.js.map +1 -0
  16. package/lib/api/composed/beatleader.d.ts +3 -3
  17. package/lib/api/composed/beatleader.js +22 -9
  18. package/lib/api/composed/beatleader.js.map +1 -1
  19. package/lib/api/composed/beatsaver.d.ts +2 -3
  20. package/lib/api/composed/beatsaver.js +2 -1
  21. package/lib/api/composed/beatsaver.js.map +1 -1
  22. package/lib/api/composed/scoresaber.js +5 -1
  23. package/lib/api/composed/scoresaber.js.map +1 -1
  24. package/lib/api/helper.d.ts +19 -0
  25. package/lib/api/helper.js +102 -0
  26. package/lib/api/helper.js.map +1 -0
  27. package/lib/api/index.d.ts +6 -23
  28. package/lib/api/index.js +22 -113
  29. package/lib/api/index.js.map +1 -1
  30. package/lib/api/interfaces/beatsaver/bsmap.d.ts +2 -0
  31. package/lib/api/interfaces/beatsaver/index.d.ts +2 -1
  32. package/lib/api/interfaces/index.d.ts +12 -0
  33. package/lib/api/interfaces/index.js +3 -0
  34. package/lib/{db → api/interfaces}/index.js.map +1 -1
  35. package/lib/api/interfaces/scoresaber/item.d.ts +12 -3
  36. package/lib/api/interfaces/scoresaber/leaderboard.d.ts +10 -0
  37. package/lib/api/interfaces/scoresaber/leaderboard.js +3 -0
  38. package/lib/api/interfaces/scoresaber/leaderboard.js.map +1 -0
  39. package/lib/cmd/bind/bind-beatleader.js +15 -17
  40. package/lib/cmd/bind/bind-beatleader.js.map +1 -1
  41. package/lib/cmd/bind/bind-beatsaver.js +27 -21
  42. package/lib/cmd/bind/bind-beatsaver.js.map +1 -1
  43. package/lib/cmd/bind/bind-id-beatleader.js +8 -10
  44. package/lib/cmd/bind/bind-id-beatleader.js.map +1 -1
  45. package/lib/cmd/bind/bind-id-beatsaver.js +8 -10
  46. package/lib/cmd/bind/bind-id-beatsaver.js.map +1 -1
  47. package/lib/cmd/bind/bind-scoresaber.js +7 -9
  48. package/lib/cmd/bind/bind-scoresaber.js.map +1 -1
  49. package/lib/cmd/bind/index.js +6 -3
  50. package/lib/cmd/bind/index.js.map +1 -1
  51. package/lib/cmd/bsmap/id-search.js +5 -6
  52. package/lib/cmd/bsmap/id-search.js.map +1 -1
  53. package/lib/cmd/bsmap/key-search.js +10 -10
  54. package/lib/cmd/bsmap/key-search.js.map +1 -1
  55. package/lib/cmd/bsmap/latest.js +13 -19
  56. package/lib/cmd/bsmap/latest.js.map +1 -1
  57. package/lib/cmd/config/index.d.ts +12 -0
  58. package/lib/cmd/config/index.js +70 -0
  59. package/lib/cmd/config/index.js.map +1 -0
  60. package/lib/cmd/deprecated/me.d.ts +1 -1
  61. package/lib/cmd/deprecated/me.js +6 -6
  62. package/lib/cmd/deprecated/me.js.map +1 -1
  63. package/lib/cmd/deprecated/tmp.js +2 -0
  64. package/lib/cmd/deprecated/tmp.js.map +1 -1
  65. package/lib/cmd/deprecated/whois.js +2 -2
  66. package/lib/cmd/deprecated/whois.js.map +1 -1
  67. package/lib/cmd/help.js +2 -2
  68. package/lib/cmd/index.js +3 -1
  69. package/lib/cmd/index.js.map +1 -1
  70. package/lib/cmd/rank.js +13 -18
  71. package/lib/cmd/rank.js.map +1 -1
  72. package/lib/cmd/score.d.ts +1 -1
  73. package/lib/cmd/score.js +20 -12
  74. package/lib/cmd/score.js.map +1 -1
  75. package/lib/cmd/subscribe/id-beatleader-score.d.ts +2 -0
  76. package/lib/cmd/subscribe/id-beatleader-score.js +41 -0
  77. package/lib/cmd/subscribe/id-beatleader-score.js.map +1 -0
  78. package/lib/cmd/subscribe/id-beatsaver-mapper.d.ts +2 -0
  79. package/lib/cmd/subscribe/id-beatsaver-mapper.js +42 -0
  80. package/lib/cmd/subscribe/id-beatsaver-mapper.js.map +1 -0
  81. package/lib/cmd/subscribe/index.js +22 -6
  82. package/lib/cmd/subscribe/index.js.map +1 -1
  83. package/lib/cmd/subscribe/unsubscribe.d.ts +4 -3
  84. package/lib/cmd/subscribe/unsubscribe.js +38 -0
  85. package/lib/cmd/subscribe/unsubscribe.js.map +1 -1
  86. package/lib/config.d.ts +21 -4
  87. package/lib/errors/index.d.ts +30 -0
  88. package/lib/errors/index.js +94 -1
  89. package/lib/errors/index.js.map +1 -1
  90. package/lib/i18n/index.js +17 -11
  91. package/lib/i18n/index.js.map +1 -1
  92. package/lib/i18n/parser.d.ts +14 -0
  93. package/lib/i18n/parser.js +165 -0
  94. package/lib/i18n/parser.js.map +1 -0
  95. package/lib/i18n/zh-cn.json +1 -1
  96. package/lib/img-render/components/RankDifficulty.d.ts +3 -2
  97. package/lib/img-render/components/RankDifficulty.js +8 -2
  98. package/lib/img-render/components/RankDifficulty.js.map +1 -1
  99. package/lib/img-render/components/{rankScoreItem.d.ts → bl-rank-score-item.d.ts} +4 -1
  100. package/lib/img-render/components/bl-rank-score-item.js +42 -0
  101. package/lib/img-render/components/bl-rank-score-item.js.map +1 -0
  102. package/lib/img-render/components/{blScoreItem.js → bl-score-item.js} +3 -3
  103. package/lib/img-render/components/bl-score-item.js.map +1 -0
  104. package/lib/img-render/components/scoregraph.js +1 -1
  105. package/lib/img-render/components/scoregraph.js.map +1 -1
  106. package/lib/img-render/components/ss-rank-score-item.d.ts +18 -0
  107. package/lib/img-render/components/ss-rank-score-item.js +42 -0
  108. package/lib/img-render/components/ss-rank-score-item.js.map +1 -0
  109. package/lib/img-render/components/{ssScoreItem.js → ss-score-item.js} +2 -2
  110. package/lib/img-render/components/ss-score-item.js.map +1 -0
  111. package/lib/img-render/index.d.ts +13 -10
  112. package/lib/img-render/index.js +61 -38
  113. package/lib/img-render/index.js.map +1 -1
  114. package/lib/img-render/interfaces.d.ts +2 -0
  115. package/lib/img-render/render.js +1 -1
  116. package/lib/img-render/render.js.map +1 -1
  117. package/lib/img-render/result/bl-player.d.ts +2 -1
  118. package/lib/img-render/result/bl-player.js +7 -4
  119. package/lib/img-render/result/bl-player.js.map +1 -1
  120. package/lib/img-render/result/{bs-score-with-rank.d.ts → bl-score-with-rank.d.ts} +2 -1
  121. package/lib/img-render/result/{bs-score-with-rank.js → bl-score-with-rank.js} +19 -7
  122. package/lib/img-render/result/bl-score-with-rank.js.map +1 -0
  123. package/lib/img-render/result/index.d.ts +3 -3
  124. package/lib/img-render/result/index.js +7 -7
  125. package/lib/img-render/result/index.js.map +1 -1
  126. package/lib/img-render/result/ss-player.d.ts +2 -1
  127. package/lib/img-render/result/ss-player.js +3 -4
  128. package/lib/img-render/result/ss-player.js.map +1 -1
  129. package/lib/img-render/utils/canvas.js +9 -3
  130. package/lib/img-render/utils/canvas.js.map +1 -1
  131. package/lib/img-render/utils/format.d.ts +1 -0
  132. package/lib/img-render/utils/format.js +16 -2
  133. package/lib/img-render/utils/format.js.map +1 -1
  134. package/lib/img-render/utils/qrcode.js +8 -1
  135. package/lib/img-render/utils/qrcode.js.map +1 -1
  136. package/lib/interface/cmd.d.ts +3 -0
  137. package/lib/interface/db/index.d.ts +7 -0
  138. package/lib/interface/db/models.d.ts +5 -0
  139. package/lib/interface/render.d.ts +7 -5
  140. package/lib/schedules/index.d.ts +6 -2
  141. package/lib/schedules/index.js +9 -2
  142. package/lib/schedules/index.js.map +1 -1
  143. package/lib/schedules/interface.d.ts +2 -1
  144. package/lib/schedules/oauthTokenRefreshTask.js +8 -8
  145. package/lib/schedules/oauthTokenRefreshTask.js.map +1 -1
  146. package/lib/schedules/temp.d.ts +2 -1
  147. package/lib/schedules/temp.js +20 -25
  148. package/lib/schedules/temp.js.map +1 -1
  149. package/lib/utils/cache.d.ts +1 -0
  150. package/lib/utils/cache.js +3 -1
  151. package/lib/utils/cache.js.map +1 -1
  152. package/lib/utils/fetch/error.d.ts +9 -0
  153. package/lib/utils/fetch/error.js +27 -0
  154. package/lib/utils/fetch/error.js.map +1 -0
  155. package/lib/utils/fetch/index.d.ts +4 -0
  156. package/lib/utils/fetch/index.js +34 -0
  157. package/lib/utils/fetch/index.js.map +1 -0
  158. package/lib/utils/fetch/ofetch.d.ts +23 -0
  159. package/lib/utils/fetch/ofetch.js +85 -0
  160. package/lib/utils/fetch/ofetch.js.map +1 -0
  161. package/lib/utils/index.d.ts +3 -0
  162. package/lib/utils/index.js +4 -1
  163. package/lib/utils/index.js.map +1 -1
  164. package/lib/utils/preference.d.ts +35 -0
  165. package/lib/utils/preference.js +115 -0
  166. package/lib/utils/preference.js.map +1 -0
  167. package/lib/utils/puppeteer.d.ts +23 -0
  168. package/lib/utils/puppeteer.js +92 -0
  169. package/lib/utils/puppeteer.js.map +1 -0
  170. package/lib/utils/s3.d.ts +11 -0
  171. package/lib/utils/s3.js +60 -0
  172. package/lib/utils/s3.js.map +1 -0
  173. package/lib/ws/beatsaver.js +16 -2
  174. package/lib/ws/beatsaver.js.map +1 -1
  175. package/package.json +12 -4
  176. package/lib/api/base/aioRequest.d.ts +0 -6
  177. package/lib/api/base/aioRequest.js +0 -24
  178. package/lib/api/base/aioRequest.js.map +0 -1
  179. package/lib/api/base/blRequset.d.ts +0 -12
  180. package/lib/api/base/blRequset.js +0 -68
  181. package/lib/api/base/blRequset.js.map +0 -1
  182. package/lib/api/base/bsRequest.d.ts +0 -24
  183. package/lib/api/base/bsRequest.js +0 -64
  184. package/lib/api/base/bsRequest.js.map +0 -1
  185. package/lib/api/base/scRequest.d.ts +0 -6
  186. package/lib/api/base/scRequest.js +0 -28
  187. package/lib/api/base/scRequest.js.map +0 -1
  188. package/lib/db/index.d.ts +0 -0
  189. package/lib/db/index.js +0 -1
  190. package/lib/img-render/components/blScoreItem.js.map +0 -1
  191. package/lib/img-render/components/rankScoreItem.js +0 -38
  192. package/lib/img-render/components/rankScoreItem.js.map +0 -1
  193. package/lib/img-render/components/ssScoreItem.js.map +0 -1
  194. package/lib/img-render/result/bs-score-with-rank.js.map +0 -1
  195. /package/lib/img-render/components/{blScoreItem.d.ts → bl-score-item.d.ts} +0 -0
  196. /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("@loskir/styled-qr-code-node");
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":";;AAAA,qEAMoC;AAErB,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,CAAe;YAC3B,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,SAAoB;SAC3B;QACD,iBAAiB,EAAE;YACjB,KAAK,EAAE,cAAc;SACtB;QACD,oBAAoB,EAAE;YACpB,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,eAAmC;SAC1C;QACD,iBAAiB,EAAE;YACjB,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,KAAsB;SAC7B;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"}
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"}
@@ -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
  }
@@ -32,3 +32,8 @@ export type RelateChannelInfo<CHANNEL> = {
32
32
  name: string;
33
33
  type: 'user' | 'group' | string;
34
34
  } & CHANNEL;
35
+ export type UserPreference<T = any> = {
36
+ uid: number;
37
+ gid: number;
38
+ data: T;
39
+ };
@@ -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<any>;
16
- renderScore(scoreId: string, platform: Platform, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<any>;
17
- renderMapById(mapId: string, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<any>;
18
- renderMap(map: BSMap, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<any>;
19
- renderUrl(url: string, onRenderStart?: () => void, onRenderError?: (e: any) => void): Promise<any>;
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 {};
@@ -1,3 +1,7 @@
1
- import { ScheduleTask } from '../schedules/interface';
2
1
  import { Config } from '../config';
3
- export declare const getScheduleTasks: (config: Config) => ScheduleTask[];
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
+ }[];
@@ -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
- // oauthTokenRefreshTask
13
- return [];
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;AAI1D,MAAM,qBAAqB,GAAG;IAC5B,IAAI,EAAE,uBAAuB;IAC7B,SAAS;IACT,IAAI,EAAE,EAAE;IACR,QAAQ,EAAE,wCAAgB;CAC3B,CAAA;AAEM,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAE,EAAE;IACjD,wBAAwB;IACxB,OAAO,EAAoB,CAAA;AAC7B,CAAC,CAAA;AAHY,QAAA,gBAAgB,oBAG5B"}
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"}
@@ -13,5 +13,6 @@ export type ScheduleTaskCtx<T> = {
13
13
  export type ScheduleTask = {
14
14
  name: string;
15
15
  cron: string;
16
- executor: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
16
+ handler: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
17
+ enable: boolean;
17
18
  };
@@ -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.wrapperResult().refreshOAuthToken(account.refreshToken);
18
- if (!token.isSuccess()) {
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.data.access_token;
28
- account.refreshToken = token.data.refresh_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.wrapperResult().refreshOAuthToken(account.refreshToken);
32
- if (!token.isSuccess()) {
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.data.access_token;
42
- account.refreshToken = token.data.refresh_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,aAAa,EAAE,CAAC,iBAAiB,CACpE,OAAO,CAAC,YAAY,CACrB,CAAA;YACD,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;gBACvB,CAAC,CAAC,MAAM,CAAC,IAAI,CACX,qBAAqB,OAAO,CAAC,QAAQ,iCAAiC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAChG,CAAA;gBACD,OAAO,CAAC,KAAK,GAAG,SAAS,CAAA;gBACzB,OAAO,CAAC,cAAc,GAAG,GAAG,CAAA;gBAC5B,+DAA+D;gBAC/D,sCAAsC;gBACtC,sFAAsF;gBACtF,SAAQ;YACV,CAAC;YACD,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,YAAY,CAAA;YAC7C,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,aAAa,CAAA;QACjD,CAAC;aAAM,IAAI,OAAO,CAAC,QAAQ,KAAK,WAAW,EAAE,CAAC;YAC5C,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC,iBAAiB,CACnE,OAAO,CAAC,YAAY,CACrB,CAAA;YACD,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;gBACvB,CAAC,CAAC,MAAM,CAAC,IAAI,CACX,qBAAqB,OAAO,CAAC,QAAQ,iCAAiC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAChG,CAAA;gBACD,OAAO,CAAC,KAAK,GAAG,SAAS,CAAA;gBACzB,OAAO,CAAC,cAAc,GAAG,GAAG,CAAA;gBAC5B,+DAA+D;gBAC/D,sCAAsC;gBACtC,sFAAsF;gBACtF,SAAQ;YACV,CAAC;YACD,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,YAAY,CAAA;YAC7C,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,aAAa,CAAA;QACjD,CAAC;QACD,OAAO,CAAC,aAAa,GAAG,GAAG,CAAA;QAC3B,OAAO,CAAC,cAAc,GAAG,GAAG,CAAA;QAC5B,EAAE;QACF,+DAA+D;QAC/D,CAAC,CAAC,MAAM,CAAC,IAAI,CACX,WAAW,OAAO,CAAC,QAAQ,uBAAuB,OAAO,CAAC,WAAW,EAAE,CACxE,CAAA;IACH,CAAC;IACD,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAA;AAC9C,CAAC,CAAA;AA1DY,QAAA,gBAAgB,oBA0D5B"}
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"}
@@ -1 +1,2 @@
1
- export {};
1
+ import { ScheduleTaskCtx } from '../schedules/interface';
2
+ export declare const LBScoreMonitor: <T>(c: ScheduleTaskCtx<T>) => Promise<void>;
@@ -1,28 +1,23 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- // export const LBScoreMonitor = async <T>(
4
- // config: Config,
5
- // db: DB<T>,
6
- // render: RenderService,
7
- // api: APIService,
8
- // logger: Logger,
9
- // botService: BotService<T, Session<T>>
10
- // ) => {
11
- // const channels = await db.getSubscriptionInfoByType('lb-rank')
12
- // if (channels.length <= 0) {
13
- // return
14
- // }
15
- // const [hitbuf, scorebuf] = await Promise.all([
16
- // render.renderUrl('https://aiobs.ktlab.io/tmp/lb/hitcnt'),
17
- // render.renderUrl('https://aiobs.ktlab.io/tmp/lb/score'),
18
- // ])
19
- // for (const group of channels) {
20
- // const session = botService.getSessionByChannelInfo(group.groupChannel)
21
- // if (!session) {
22
- // continue
23
- // }
24
- // await session.sendImgBuffer(hitbuf, 'image/png')
25
- // await session.sendImgBuffer(scorebuf, 'image/png')
26
- // }
27
- // }
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":";;AAKA,2CAA2C;AAC3C,oBAAoB;AACpB,eAAe;AACf,2BAA2B;AAC3B,qBAAqB;AACrB,oBAAoB;AACpB,0CAA0C;AAC1C,SAAS;AACT,mEAAmE;AACnE,gCAAgC;AAChC,aAAa;AACb,MAAM;AACN,mDAAmD;AACnD,gEAAgE;AAChE,+DAA+D;AAC/D,OAAO;AACP,oCAAoC;AACpC,6EAA6E;AAC7E,sBAAsB;AACtB,iBAAiB;AACjB,QAAQ;AACR,uDAAuD;AACvD,yDAAyD;AACzD,MAAM;AACN,IAAI"}
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"}
@@ -1,2 +1,3 @@
1
1
  import { LRUCache } from 'lru-cache';
2
2
  export declare const cache: LRUCache<any, any, unknown>;
3
+ export declare const createCache: <K extends {}, V extends {}, FC = unknown>(opt: any) => LRUCache<K, V, FC>;
@@ -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
@@ -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,4 @@
1
+ import { Fetch } from './ofetch';
2
+ import { Logger } from '../../interface';
3
+ export declare const createFetch: (logger: Logger) => Fetch;
4
+ export { Fetch } from './ofetch';
@@ -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":"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"}
@@ -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>;
@@ -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
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,yCAAqC;AACrC,yCAAoC;AAEpC,0CAAuB;AAEhB,MAAM,cAAc,GAAG,KAAK,EAAK,GAAG,IAAI,EAAc,EAAE;IAC7D,MAAM,GAAG,GAAG,aAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IAC3B,IAAI,GAAG,EAAE,CAAC;QACR,OAAO,GAAQ,CAAA;IACjB,CAAC;IACD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,IAAW,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAO,CAAC,CAAA;IACtE,aAAK,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;IACvB,OAAO,MAAW,CAAA;AACpB,CAAC,CAAA;AARY,QAAA,cAAc,kBAQ1B;AAED,6CAA6C;AAEtC,MAAM,sBAAsB,GAAG,CACpC,MAAM,EACN,EAAE,EACF,GAAG,EACH,WAAW,EACX,WAAW,EACX,eAAe,EACf,EAAE;IACF,MAAM,OAAO,GAAG,IAAI,oBAAQ,CAAC;QAC3B,GAAG,EAAE,GAAG;QACR,IAAI,EAAE,EAAE;QACR,eAAe,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;QAClC,6CAA6C;QAC7C,OAAO,EAAE,IAAI;QACb,UAAU,EAAE,KAAK;QACjB,cAAc,EAAE,KAAK;QACrB,WAAW,EAAE,IAAI;QACjB,GAAG,EAAE,GAAG;KACT,CAAC,CAAA;IAEF,OAAO,KAAK,WAAW,KAAU;QAC/B,MAAM,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,CAAA;QAC/B,MAAM,GAAG,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;QACjC,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1C,yFAAyF;YACzF,OAAM;QACR,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;QACtB,MAAM,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAChC,CAAC,CAAA;AACH,CAAC,CAAA;AA9BY,QAAA,sBAAsB,0BA8BlC;AAEM,MAAM,KAAK,GAAG,KAAK,EAAE,UAAkB,IAAI,EAAE,EAAE;IACpD,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC1C,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;IAC9B,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AAJY,QAAA,KAAK,SAIjB;AAED,MAAM,OAAO,GAAG;IACd,CAAC,EAAE,MAAM;IACT,CAAC,EAAE,QAAQ;IACX,CAAC,EAAE,MAAM;IACT,EAAE,EAAE,QAAQ;IACZ,EAAE,EAAE,YAAY;IAChB,KAAK,EAAE,YAAY;CACpB,CAAA;AAEM,MAAM,WAAW,GAAG,CAAC,IAAmB,EAAE,EAAE;IACjD,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,IAAI,CAAA;IACb,CAAC;IACD,OAAO,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;AACpC,CAAC,CAAA;AALY,QAAA,WAAW,eAKvB"}
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 {};