beatsaber-bot-core 0.2.0-dev.2 → 0.2.0-dev.21
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/aioRequest.d.ts +6 -0
- package/lib/api/base/aioRequest.js +24 -0
- package/lib/api/base/aioRequest.js.map +1 -0
- package/lib/api/base/aioclient.d.ts +10 -0
- package/lib/api/base/aioclient.js +25 -0
- package/lib/api/base/aioclient.js.map +1 -0
- package/lib/api/base/blRequset.d.ts +12 -0
- package/lib/api/base/blRequset.js +68 -0
- package/lib/api/base/blRequset.js.map +1 -0
- package/lib/api/base/blclient.d.ts +16 -0
- package/lib/api/base/blclient.js +60 -0
- package/lib/api/base/blclient.js.map +1 -0
- package/lib/api/base/bsRequest.d.ts +24 -0
- package/lib/api/base/bsRequest.js +64 -0
- package/lib/api/base/bsRequest.js.map +1 -0
- package/lib/api/base/bsclient.d.ts +16 -0
- package/lib/api/base/bsclient.js +69 -0
- package/lib/api/base/bsclient.js.map +1 -0
- package/lib/api/base/index.d.ts +4 -0
- package/lib/api/base/index.js +21 -0
- package/lib/api/base/index.js.map +1 -0
- package/lib/api/base/scRequest.d.ts +8 -0
- package/lib/api/base/scRequest.js +43 -0
- package/lib/api/base/scRequest.js.map +1 -0
- package/lib/api/base/ssclient.d.ts +12 -0
- package/lib/api/base/ssclient.js +43 -0
- package/lib/api/base/ssclient.js.map +1 -0
- package/lib/api/composed/aiosaber.d.ts +7 -0
- package/lib/api/composed/aiosaber.js +16 -0
- package/lib/api/composed/aiosaber.js.map +1 -0
- package/lib/api/composed/beatleader.d.ts +32 -0
- package/lib/api/composed/beatleader.js +112 -0
- package/lib/api/composed/beatleader.js.map +1 -0
- package/lib/api/composed/beatsaver.d.ts +11 -0
- package/lib/api/composed/beatsaver.js +19 -0
- package/lib/api/composed/beatsaver.js.map +1 -0
- package/lib/api/composed/scoresaber.d.ts +14 -0
- package/lib/api/composed/scoresaber.js +67 -0
- package/lib/api/composed/scoresaber.js.map +1 -0
- package/lib/api/helper.d.ts +19 -0
- package/lib/api/helper.js +99 -0
- package/lib/api/helper.js.map +1 -0
- package/lib/api/index.d.ts +14 -0
- package/lib/api/index.js +44 -0
- package/lib/api/index.js.map +1 -0
- package/lib/api/interfaces/aiosaber/index.d.ts +7 -0
- package/lib/api/interfaces/aiosaber/index.js +3 -0
- package/lib/api/interfaces/aiosaber/index.js.map +1 -0
- package/lib/api/interfaces/beatleader/bsor.d.ts +112 -0
- package/lib/api/interfaces/beatleader/bsor.js +3 -0
- package/lib/api/interfaces/beatleader/bsor.js.map +1 -0
- package/lib/api/interfaces/beatleader/index.d.ts +5 -0
- package/lib/api/interfaces/beatleader/index.js +22 -0
- package/lib/api/interfaces/beatleader/index.js.map +1 -0
- package/lib/api/interfaces/beatleader/req.d.ts +19 -0
- package/lib/api/interfaces/beatleader/req.js +3 -0
- package/lib/api/interfaces/beatleader/req.js.map +1 -0
- package/lib/api/interfaces/beatleader/score.d.ts +162 -0
- package/lib/api/interfaces/beatleader/score.js +3 -0
- package/lib/api/interfaces/beatleader/score.js.map +1 -0
- package/lib/api/interfaces/beatleader/user.d.ts +171 -0
- package/lib/api/interfaces/beatleader/user.js +3 -0
- package/lib/api/interfaces/beatleader/user.js.map +1 -0
- package/lib/api/interfaces/beatleader/ws.d.ts +87 -0
- package/lib/api/interfaces/beatleader/ws.js +3 -0
- package/lib/api/interfaces/beatleader/ws.js.map +1 -0
- package/lib/api/interfaces/beatsaver/alert.d.ts +18 -0
- package/lib/api/interfaces/beatsaver/alert.js +3 -0
- package/lib/api/interfaces/beatsaver/alert.js.map +1 -0
- package/lib/api/interfaces/beatsaver/bsmap.d.ts +68 -0
- package/lib/api/interfaces/beatsaver/bsmap.js +3 -0
- package/lib/api/interfaces/beatsaver/bsmap.js.map +1 -0
- package/lib/api/interfaces/beatsaver/index.d.ts +10 -0
- package/lib/api/interfaces/beatsaver/index.js +22 -0
- package/lib/api/interfaces/beatsaver/index.js.map +1 -0
- package/lib/api/interfaces/beatsaver/resp.d.ts +8 -0
- package/lib/api/interfaces/beatsaver/resp.js +3 -0
- package/lib/api/interfaces/beatsaver/resp.js.map +1 -0
- package/lib/api/interfaces/beatsaver/user.d.ts +8 -0
- package/lib/api/interfaces/beatsaver/user.js +3 -0
- package/lib/api/interfaces/beatsaver/user.js.map +1 -0
- package/lib/api/interfaces/beatsaver/ws.d.ts +11 -0
- package/lib/api/interfaces/beatsaver/ws.js +3 -0
- package/lib/api/interfaces/beatsaver/ws.js.map +1 -0
- 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/index.d.ts +3 -0
- package/lib/api/interfaces/scoresaber/index.js +20 -0
- package/lib/api/interfaces/scoresaber/index.js.map +1 -0
- package/lib/api/interfaces/scoresaber/item.d.ts +66 -0
- package/lib/api/interfaces/scoresaber/item.js +3 -0
- package/lib/api/interfaces/scoresaber/item.js.map +1 -0
- 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/api/interfaces/scoresaber/resp.d.ts +9 -0
- package/lib/api/interfaces/scoresaber/resp.js +3 -0
- package/lib/api/interfaces/scoresaber/resp.js.map +1 -0
- package/lib/api/interfaces/scoresaber/user.d.ts +33 -0
- package/lib/api/interfaces/scoresaber/user.js +3 -0
- package/lib/api/interfaces/scoresaber/user.js.map +1 -0
- package/lib/api/interfaces/scoresaber/ws.d.ts +78 -0
- package/lib/api/interfaces/scoresaber/ws.js +3 -0
- package/lib/api/interfaces/scoresaber/ws.js.map +1 -0
- package/lib/api/netResult.d.ts +18 -0
- package/lib/api/netResult.js +42 -0
- package/lib/api/netResult.js.map +1 -0
- package/lib/api/sortScore.d.ts +2 -0
- package/lib/api/sortScore.js +31 -0
- package/lib/api/sortScore.js.map +1 -0
- package/lib/cmd/bind/bind-beatleader.d.ts +2 -0
- package/lib/cmd/bind/bind-beatleader.js +53 -0
- package/lib/cmd/bind/bind-beatleader.js.map +1 -0
- package/lib/cmd/bind/bind-beatsaver.d.ts +2 -0
- package/lib/cmd/bind/bind-beatsaver.js +55 -0
- package/lib/cmd/bind/bind-beatsaver.js.map +1 -0
- package/lib/cmd/bind/bind-id-beatleader.d.ts +2 -0
- package/lib/cmd/bind/bind-id-beatleader.js +55 -0
- package/lib/cmd/bind/bind-id-beatleader.js.map +1 -0
- package/lib/cmd/bind/bind-id-beatsaver.d.ts +2 -0
- package/lib/cmd/bind/bind-id-beatsaver.js +55 -0
- package/lib/cmd/bind/bind-id-beatsaver.js.map +1 -0
- package/lib/cmd/bind/bind-scoresaber.d.ts +2 -0
- package/lib/cmd/bind/bind-scoresaber.js +61 -0
- package/lib/cmd/bind/bind-scoresaber.js.map +1 -0
- package/lib/cmd/bind/index.d.ts +11 -0
- package/lib/cmd/bind/index.js +56 -0
- package/lib/cmd/bind/index.js.map +1 -0
- package/lib/cmd/bsmap/id-search.d.ts +9 -0
- package/lib/cmd/bsmap/id-search.js +35 -0
- package/lib/cmd/bsmap/id-search.js.map +1 -0
- package/lib/cmd/bsmap/key-search.d.ts +9 -0
- package/lib/cmd/bsmap/key-search.js +41 -0
- package/lib/cmd/bsmap/key-search.js.map +1 -0
- package/lib/cmd/bsmap/latest.d.ts +9 -0
- package/lib/cmd/bsmap/latest.js +44 -0
- package/lib/cmd/bsmap/latest.js.map +1 -0
- package/lib/cmd/builder.d.ts +27 -0
- package/lib/cmd/builder.js +60 -0
- package/lib/cmd/builder.js.map +1 -0
- 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/cmp.d.ts +9 -0
- package/lib/cmd/deprecated/cmp.js +15 -0
- package/lib/cmd/deprecated/cmp.js.map +1 -0
- package/lib/cmd/deprecated/me.d.ts +13 -0
- package/lib/cmd/deprecated/me.js +66 -0
- package/lib/cmd/deprecated/me.js.map +1 -0
- package/lib/cmd/deprecated/tmp.d.ts +9 -0
- package/lib/cmd/deprecated/tmp.js +23 -0
- package/lib/cmd/deprecated/tmp.js.map +1 -0
- package/lib/cmd/deprecated/whois.d.ts +11 -0
- package/lib/cmd/deprecated/whois.js +40 -0
- package/lib/cmd/deprecated/whois.js.map +1 -0
- package/lib/cmd/help.d.ts +9 -0
- package/lib/cmd/help.js +14 -0
- package/lib/cmd/help.js.map +1 -0
- package/lib/cmd/index.d.ts +2 -0
- package/lib/cmd/index.js +25 -0
- package/lib/cmd/index.js.map +1 -0
- package/lib/cmd/rank.d.ts +11 -0
- package/lib/cmd/rank.js +56 -0
- package/lib/cmd/rank.js.map +1 -0
- package/lib/cmd/score.d.ts +13 -0
- package/lib/cmd/score.js +48 -0
- package/lib/cmd/score.js.map +1 -0
- package/lib/cmd/subscribe/beatleader.d.ts +2 -0
- package/lib/cmd/subscribe/beatleader.js +27 -0
- package/lib/cmd/subscribe/beatleader.js.map +1 -0
- package/lib/cmd/subscribe/beatsaver.d.ts +2 -0
- package/lib/cmd/subscribe/beatsaver.js +27 -0
- package/lib/cmd/subscribe/beatsaver.js.map +1 -0
- package/lib/cmd/subscribe/deprecated/alert.d.ts +0 -0
- package/lib/cmd/subscribe/deprecated/alert.js +86 -0
- package/lib/cmd/subscribe/deprecated/alert.js.map +1 -0
- package/lib/cmd/subscribe/deprecated/blfilters.d.ts +0 -0
- package/lib/cmd/subscribe/deprecated/blfilters.js +49 -0
- package/lib/cmd/subscribe/deprecated/blfilters.js.map +1 -0
- package/lib/cmd/subscribe/deprecated/scoresaber.d.ts +0 -0
- package/lib/cmd/subscribe/deprecated/scoresaber.js +43 -0
- package/lib/cmd/subscribe/deprecated/scoresaber.js.map +1 -0
- package/lib/cmd/subscribe/index.d.ts +11 -0
- package/lib/cmd/subscribe/index.js +45 -0
- package/lib/cmd/subscribe/index.js.map +1 -0
- package/lib/cmd/subscribe/subjoin.d.ts +11 -0
- package/lib/cmd/subscribe/subjoin.js +42 -0
- package/lib/cmd/subscribe/subjoin.js.map +1 -0
- package/lib/cmd/subscribe/subleave.d.ts +11 -0
- package/lib/cmd/subscribe/subleave.js +35 -0
- package/lib/cmd/subscribe/subleave.js.map +1 -0
- package/lib/cmd/subscribe/unsubscribe.d.ts +11 -0
- package/lib/cmd/subscribe/unsubscribe.js +41 -0
- package/lib/cmd/subscribe/unsubscribe.js.map +1 -0
- package/lib/config.d.ts +40 -0
- package/lib/config.js +3 -0
- package/lib/config.js.map +1 -0
- package/lib/db/index.d.ts +0 -0
- package/lib/db/index.js +1 -0
- package/lib/db/index.js.map +1 -0
- package/lib/errors/index.d.ts +55 -0
- package/lib/errors/index.js +162 -0
- package/lib/errors/index.js.map +1 -0
- package/lib/i18n/index.d.ts +2 -0
- package/lib/i18n/index.js +118 -0
- package/lib/i18n/index.js.map +1 -0
- 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 -0
- 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 +12 -0
- package/lib/img-render/components/base/avatar.js.map +1 -0
- 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.d.ts +6 -0
- package/lib/img-render/components/blScoreItem.js +14 -0
- package/lib/img-render/components/blScoreItem.js.map +1 -0
- package/lib/img-render/components/characteristic.d.ts +5 -0
- package/lib/img-render/components/characteristic.js +27 -0
- package/lib/img-render/components/characteristic.js.map +1 -0
- package/lib/img-render/components/flag.d.ts +5 -0
- package/lib/img-render/components/flag.js +39 -0
- package/lib/img-render/components/flag.js.map +1 -0
- package/lib/img-render/components/icons/BeatLeader.d.ts +3 -0
- package/lib/img-render/components/icons/BeatLeader.js +10 -0
- package/lib/img-render/components/icons/BeatLeader.js.map +1 -0
- package/lib/img-render/components/icons/RankIcon.d.ts +4 -0
- package/lib/img-render/components/icons/RankIcon.js +14 -0
- package/lib/img-render/components/icons/RankIcon.js.map +1 -0
- package/lib/img-render/components/icons/ScoreSaberIcon.d.ts +3 -0
- package/lib/img-render/components/icons/ScoreSaberIcon.js +8 -0
- package/lib/img-render/components/icons/ScoreSaberIcon.js.map +1 -0
- package/lib/img-render/components/progressbar.d.ts +4 -0
- package/lib/img-render/components/progressbar.js +9 -0
- package/lib/img-render/components/progressbar.js.map +1 -0
- 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/scoreItem.d.ts +4 -0
- package/lib/img-render/components/scoreItem.js +29 -0
- package/lib/img-render/components/scoreItem.js.map +1 -0
- package/lib/img-render/components/scoregraph.d.ts +10 -0
- package/lib/img-render/components/scoregraph.js +301 -0
- package/lib/img-render/components/scoregraph.js.map +1 -0
- package/lib/img-render/components/skill-graph.d.ts +5 -0
- package/lib/img-render/components/skill-graph.js +50 -0
- package/lib/img-render/components/skill-graph.js.map +1 -0
- package/lib/img-render/components/socre-badge.d.ts +5 -0
- package/lib/img-render/components/socre-badge.js +10 -0
- package/lib/img-render/components/socre-badge.js.map +1 -0
- 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.d.ts +4 -0
- package/lib/img-render/components/ssScoreItem.js +14 -0
- package/lib/img-render/components/ssScoreItem.js.map +1 -0
- package/lib/img-render/index.d.ts +25 -0
- package/lib/img-render/index.js +142 -0
- package/lib/img-render/index.js.map +1 -0
- package/lib/img-render/interfaces.d.ts +19 -0
- package/lib/img-render/interfaces.js +3 -0
- package/lib/img-render/interfaces.js.map +1 -0
- package/lib/img-render/remote/index.d.ts +0 -0
- package/lib/img-render/remote/index.js +56 -0
- package/lib/img-render/remote/index.js.map +1 -0
- package/lib/img-render/render.d.ts +7 -0
- package/lib/img-render/render.js +65 -0
- package/lib/img-render/render.js.map +1 -0
- package/lib/img-render/renderImg.d.ts +0 -0
- package/lib/img-render/renderImg.js +1 -0
- package/lib/img-render/renderImg.js.map +1 -0
- package/lib/img-render/result/bl-player.d.ts +8 -0
- package/lib/img-render/result/bl-player.js +43 -0
- package/lib/img-render/result/bl-player.js.map +1 -0
- package/lib/img-render/result/bl-score-with-rank.d.ts +14 -0
- package/lib/img-render/result/bl-score-with-rank.js +32 -0
- package/lib/img-render/result/bl-score-with-rank.js.map +1 -0
- package/lib/img-render/result/bl-score.d.ts +11 -0
- package/lib/img-render/result/bl-score.js +18 -0
- package/lib/img-render/result/bl-score.js.map +1 -0
- package/lib/img-render/result/bs-map.d.ts +8 -0
- package/lib/img-render/result/bs-map.js +26 -0
- package/lib/img-render/result/bs-map.js.map +1 -0
- 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 +8 -0
- package/lib/img-render/result/index.js +33 -0
- package/lib/img-render/result/index.js.map +1 -0
- package/lib/img-render/result/ss-player.d.ts +9 -0
- package/lib/img-render/result/ss-player.js +38 -0
- package/lib/img-render/result/ss-player.js.map +1 -0
- 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/bl/beatleader.d.ts +13 -0
- package/lib/img-render/utils/bl/beatleader.js +38 -0
- package/lib/img-render/utils/bl/beatleader.js.map +1 -0
- package/lib/img-render/utils/bl/blheadset.d.ts +273 -0
- package/lib/img-render/utils/bl/blheadset.js +281 -0
- package/lib/img-render/utils/bl/blheadset.js.map +1 -0
- package/lib/img-render/utils/bl/bsorDecoder.d.ts +68 -0
- package/lib/img-render/utils/bl/bsorDecoder.js +286 -0
- package/lib/img-render/utils/bl/bsorDecoder.js.map +1 -0
- package/lib/img-render/utils/bl/bsorReplayAcc.d.ts +35 -0
- package/lib/img-render/utils/bl/bsorReplayAcc.js +590 -0
- package/lib/img-render/utils/bl/bsorReplayAcc.js.map +1 -0
- package/lib/img-render/utils/bl/getPart.d.ts +7 -0
- package/lib/img-render/utils/bl/getPart.js +31 -0
- package/lib/img-render/utils/bl/getPart.js.map +1 -0
- package/lib/img-render/utils/bl/stastic.d.ts +2 -0
- package/lib/img-render/utils/bl/stastic.js +53 -0
- package/lib/img-render/utils/bl/stastic.js.map +1 -0
- package/lib/img-render/utils/canvas.d.ts +5 -0
- package/lib/img-render/utils/canvas.js +70 -0
- package/lib/img-render/utils/canvas.js.map +1 -0
- package/lib/img-render/utils/format.d.ts +6 -0
- package/lib/img-render/utils/format.js +66 -0
- package/lib/img-render/utils/format.js.map +1 -0
- package/lib/img-render/utils/getMods.d.ts +2 -0
- package/lib/img-render/utils/getMods.js +22 -0
- package/lib/img-render/utils/getMods.js.map +1 -0
- package/lib/img-render/utils/index.d.ts +3 -0
- package/lib/img-render/utils/index.js +36 -0
- package/lib/img-render/utils/index.js.map +1 -0
- package/lib/img-render/utils/qrcode.d.ts +1 -0
- package/lib/img-render/utils/qrcode.js +43 -0
- package/lib/img-render/utils/qrcode.js.map +1 -0
- package/lib/img-render/utils/sleep.d.ts +1 -0
- package/lib/img-render/utils/sleep.js +10 -0
- package/lib/img-render/utils/sleep.js.map +1 -0
- package/lib/img-render/utils/tag-format.d.ts +1 -0
- package/lib/img-render/utils/tag-format.js +225 -0
- package/lib/img-render/utils/tag-format.js.map +1 -0
- package/lib/img-render/utils/tw-join.d.ts +4 -0
- package/lib/img-render/utils/tw-join.js +36 -0
- package/lib/img-render/utils/tw-join.js.map +1 -0
- package/lib/index.d.ts +8 -0
- package/lib/index.js +25 -0
- package/lib/index.js.map +1 -0
- package/lib/interface/bot.d.ts +20 -0
- package/lib/interface/bot.js +3 -0
- package/lib/interface/bot.js.map +1 -0
- package/lib/interface/cmd.d.ts +39 -0
- package/lib/interface/cmd.js +3 -0
- package/lib/interface/cmd.js.map +1 -0
- package/lib/interface/db/index.d.ts +38 -0
- package/lib/interface/db/index.js +18 -0
- package/lib/interface/db/index.js.map +1 -0
- package/lib/interface/db/models.d.ts +39 -0
- package/lib/interface/db/models.js +3 -0
- package/lib/interface/db/models.js.map +1 -0
- package/lib/interface/index.d.ts +14 -0
- package/lib/interface/index.js +34 -0
- package/lib/interface/index.js.map +1 -0
- package/lib/interface/logger.d.ts +6 -0
- package/lib/interface/logger.js +3 -0
- package/lib/interface/logger.js.map +1 -0
- package/lib/interface/render.d.ts +23 -0
- package/lib/interface/render.js +3 -0
- package/lib/interface/render.js.map +1 -0
- package/lib/schedules/BeatSaverAlertMonitor.d.ts +0 -0
- package/lib/schedules/BeatSaverAlertMonitor.js +231 -0
- package/lib/schedules/BeatSaverAlertMonitor.js.map +1 -0
- package/lib/schedules/index.d.ts +7 -0
- package/lib/schedules/index.js +23 -0
- package/lib/schedules/index.js.map +1 -0
- package/lib/schedules/interface.d.ts +18 -0
- package/lib/schedules/interface.js +3 -0
- package/lib/schedules/interface.js.map +1 -0
- package/lib/schedules/oauthTokenRefreshTask.d.ts +2 -0
- package/lib/schedules/oauthTokenRefreshTask.js +53 -0
- package/lib/schedules/oauthTokenRefreshTask.js.map +1 -0
- package/lib/schedules/temp.d.ts +2 -0
- package/lib/schedules/temp.js +23 -0
- package/lib/schedules/temp.js.map +1 -0
- package/lib/utils/cache.d.ts +3 -0
- package/lib/utils/cache.js +30 -0
- package/lib/utils/cache.js.map +1 -0
- package/lib/utils/fetch/index.d.ts +3 -0
- package/lib/utils/fetch/index.js +21 -0
- package/lib/utils/fetch/index.js.map +1 -0
- package/lib/utils/fetch/ofetch.d.ts +22 -0
- package/lib/utils/fetch/ofetch.js +87 -0
- package/lib/utils/fetch/ofetch.js.map +1 -0
- package/lib/utils/index.d.ts +8 -0
- package/lib/utils/index.js +80 -0
- package/lib/utils/index.js.map +1 -0
- package/lib/utils/preference.d.ts +34 -0
- package/lib/utils/preference.js +112 -0
- package/lib/utils/preference.js.map +1 -0
- package/lib/utils/puppeteer.d.ts +20 -0
- package/lib/utils/puppeteer.js +79 -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/beatleader.d.ts +18 -0
- package/lib/ws/beatleader.js +56 -0
- package/lib/ws/beatleader.js.map +1 -0
- package/lib/ws/beatsaver.d.ts +23 -0
- package/lib/ws/beatsaver.js +58 -0
- package/lib/ws/beatsaver.js.map +1 -0
- package/lib/ws/bl-filter.d.ts +0 -0
- package/lib/ws/bl-filter.js +64 -0
- package/lib/ws/bl-filter.js.map +1 -0
- package/lib/ws/handler.d.ts +6 -0
- package/lib/ws/handler.js +3 -0
- package/lib/ws/handler.js.map +1 -0
- package/lib/ws/index.d.ts +4 -0
- package/lib/ws/index.js +21 -0
- package/lib/ws/index.js.map +1 -0
- package/lib/ws/scoresaber.d.ts +18 -0
- package/lib/ws/scoresaber.js +37 -0
- package/lib/ws/scoresaber.js.map +1 -0
- package/package.json +5 -1
@@ -0,0 +1,53 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.tokenRefreshTask = void 0;
|
4
|
+
const tokenRefreshTask = async (c) => {
|
5
|
+
c.logger.info('start token refresh task');
|
6
|
+
// getAllOauthToken
|
7
|
+
const accounts = [];
|
8
|
+
// await db.getAllOAuthTokenNeedRefresh()
|
9
|
+
// const accounts = await ctx.database.get('BSRelateOAuthAccount', {
|
10
|
+
// valid: 'valid',
|
11
|
+
// type: 'oauth',
|
12
|
+
// })
|
13
|
+
for (const account of accounts) {
|
14
|
+
c.logger.info(`try to refresh ${account.platform} ${account.platformUid}'s token`);
|
15
|
+
const now = new Date();
|
16
|
+
if (account.platform === 'beatleader') {
|
17
|
+
const token = await c.api.BeatLeader.wrapperResult().refreshOAuthToken(account.refreshToken);
|
18
|
+
if (!token.isSuccess()) {
|
19
|
+
c.logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
20
|
+
account.valid = 'invalid';
|
21
|
+
account.lastModifiedAt = now;
|
22
|
+
// await ctx.database.upsert('BSRelateOAuthAccount', [account])
|
23
|
+
// get subscribe info and notify renew
|
24
|
+
// bot.sendMessage(item.sub.channelId, '似乎 BeatSaver 通知的 token 已经失效了,通过 bbbind 重新绑定吧')
|
25
|
+
continue;
|
26
|
+
}
|
27
|
+
account.accessToken = token.data.access_token;
|
28
|
+
account.refreshToken = token.data.refresh_token;
|
29
|
+
}
|
30
|
+
else if (account.platform === 'beatsaver') {
|
31
|
+
const token = await c.api.BeatSaver.wrapperResult().refreshOAuthToken(account.refreshToken);
|
32
|
+
if (!token.isSuccess()) {
|
33
|
+
c.logger.info(`failed to refresh ${account.platform} token, invalid this account, ${JSON.stringify(account)}`);
|
34
|
+
account.valid = 'invalid';
|
35
|
+
account.lastModifiedAt = now;
|
36
|
+
// await ctx.database.upsert('BSRelateOAuthAccount', [account])
|
37
|
+
// get subscribe info and notify renew
|
38
|
+
// bot.sendMessage(item.sub.channelId, '似乎 BeatSaver 通知的 token 已经失效了,通过 bbbind 重新绑定吧')
|
39
|
+
continue;
|
40
|
+
}
|
41
|
+
account.accessToken = token.data.access_token;
|
42
|
+
account.refreshToken = token.data.refresh_token;
|
43
|
+
}
|
44
|
+
account.lastRefreshAt = now;
|
45
|
+
account.lastModifiedAt = now;
|
46
|
+
//
|
47
|
+
// await ctx.database.upsert('BSRelateOAuthAccount', [account])
|
48
|
+
c.logger.info(`refresh ${account.platform} token successfully ${account.platformUid}`);
|
49
|
+
}
|
50
|
+
c.logger.info(`token refresh task finished`);
|
51
|
+
};
|
52
|
+
exports.tokenRefreshTask = tokenRefreshTask;
|
53
|
+
//# sourceMappingURL=oauthTokenRefreshTask.js.map
|
@@ -0,0 +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"}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
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;
|
23
|
+
//# sourceMappingURL=temp.js.map
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.createCache = exports.cache = void 0;
|
4
|
+
const lru_cache_1 = require("lru-cache");
|
5
|
+
const options = {
|
6
|
+
max: 500,
|
7
|
+
// for use with tracking overall storage size
|
8
|
+
maxSize: 5000,
|
9
|
+
sizeCalculation: (value, key) => 1,
|
10
|
+
// for use when you need to clean up something when objects
|
11
|
+
// are evicted from the cache
|
12
|
+
// dispose: (value, key) => {},
|
13
|
+
// how long to live in ms
|
14
|
+
ttl: 1000 * 60 * 5,
|
15
|
+
// return stale items before removing from cache?
|
16
|
+
allowStale: false,
|
17
|
+
updateAgeOnGet: true,
|
18
|
+
updateAgeOnHas: true,
|
19
|
+
// // async method to use for cache.fetch(), for
|
20
|
+
// // stale-while-revalidate type of behavior
|
21
|
+
// fetchMethod: async (
|
22
|
+
// key,
|
23
|
+
// staleValue,
|
24
|
+
// { options, signal, context }
|
25
|
+
// ) => {},
|
26
|
+
};
|
27
|
+
exports.cache = new lru_cache_1.LRUCache(options);
|
28
|
+
const createCache = (opt) => new lru_cache_1.LRUCache(opt);
|
29
|
+
exports.createCache = createCache;
|
30
|
+
//# sourceMappingURL=cache.js.map
|
@@ -0,0 +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;AAEnC,MAAM,WAAW,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,oBAAQ,CAAC,GAAG,CAAC,CAAA;AAAxC,QAAA,WAAW,eAA6B"}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
const ofetch_1 = require("./ofetch");
|
4
|
+
const rofetch = (0, ofetch_1.createFetch)({
|
5
|
+
defaults: {
|
6
|
+
retryStatusCodes: [400, 408, 409, 425, 429, 502, 503, 504],
|
7
|
+
retry: 2,
|
8
|
+
retryDelay: 800,
|
9
|
+
},
|
10
|
+
}).create({
|
11
|
+
onResponseError: (err) => {
|
12
|
+
// logger.error(err)
|
13
|
+
if (err.response._data) {
|
14
|
+
err.error = new Error(err.response._data?.error ?? err.response._data?.message);
|
15
|
+
}
|
16
|
+
},
|
17
|
+
});
|
18
|
+
// convert error info
|
19
|
+
const ofetch = new ofetch_1.Fetch(rofetch);
|
20
|
+
exports.default = ofetch;
|
21
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/fetch/index.ts"],"names":[],"mappings":";;AAAA,qCAA6C;AAE7C,MAAM,OAAO,GAAG,IAAA,oBAAW,EAAC;IAC1B,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,CAAC,MAAM,CAAC;IACR,eAAe,EAAE,CAAC,GAAG,EAAE,EAAE;QACvB,oBAAoB;QACpB,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;YACvB,GAAG,CAAC,KAAK,GAAG,IAAI,KAAK,CACnB,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CACzD,CAAA;QACH,CAAC;IACH,CAAC;CACF,CAAC,CAAA;AAEF,qBAAqB;AACrB,MAAM,MAAM,GAAG,IAAI,cAAK,CAAC,OAAO,CAAC,CAAA;AACjC,kBAAe,MAAM,CAAA"}
|
@@ -0,0 +1,22 @@
|
|
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
|
+
}
|
22
|
+
export { createFetch } from 'ofetch';
|
@@ -0,0 +1,87 @@
|
|
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
|
+
//
|
6
|
+
// import { logger } from "./logger"
|
7
|
+
// import { isDebug } from "./env";
|
8
|
+
exports.rofetch = (0, ofetch_1.createFetch)({
|
9
|
+
defaults: {
|
10
|
+
retryStatusCodes: [400, 408, 409, 425, 429, 500, 502, 503, 504],
|
11
|
+
retry: 3,
|
12
|
+
retryDelay: 800,
|
13
|
+
},
|
14
|
+
}).create({
|
15
|
+
onResponseError({ request, response, options }) {
|
16
|
+
if (options.retry) {
|
17
|
+
// logger.warn(
|
18
|
+
// `external request ${request} with error ${response.status} remaining retry attempts: ${options.retry}`
|
19
|
+
// )
|
20
|
+
}
|
21
|
+
},
|
22
|
+
onRequestError({ request, error }) {
|
23
|
+
// logger.error(`external request ${request} fail: ${error}`)
|
24
|
+
},
|
25
|
+
});
|
26
|
+
class Fetch {
|
27
|
+
options;
|
28
|
+
ofetchInstance;
|
29
|
+
constructor(fetchInstance, options) {
|
30
|
+
this.options = options;
|
31
|
+
this.ofetchInstance = fetchInstance ?? exports.rofetch;
|
32
|
+
}
|
33
|
+
async fetch(request, options) {
|
34
|
+
if (options?.json && !options.body) {
|
35
|
+
options.body = options.json;
|
36
|
+
delete options.json;
|
37
|
+
}
|
38
|
+
if (options?.form && !options.body) {
|
39
|
+
options.body = new URLSearchParams(options.form).toString();
|
40
|
+
if (!options.headers) {
|
41
|
+
options.headers = {};
|
42
|
+
}
|
43
|
+
options.headers = {
|
44
|
+
...options.headers,
|
45
|
+
'content-type': 'application/x-www-form-urlencoded',
|
46
|
+
};
|
47
|
+
delete options.form;
|
48
|
+
}
|
49
|
+
if (options?.searchParams) {
|
50
|
+
request += '?' + new URLSearchParams(options.searchParams).toString();
|
51
|
+
delete options.searchParams;
|
52
|
+
}
|
53
|
+
// if (isDebug()) {
|
54
|
+
// logger.debug(`external request ${request}`)
|
55
|
+
// }
|
56
|
+
const res = await this.ofetchInstance(request, {
|
57
|
+
...this.options,
|
58
|
+
...options,
|
59
|
+
});
|
60
|
+
return res;
|
61
|
+
}
|
62
|
+
get(request, options) {
|
63
|
+
return this.fetch(request, { ...options, method: 'GET' });
|
64
|
+
}
|
65
|
+
post(request, options) {
|
66
|
+
return this.fetch(request, { ...options, method: 'POST' });
|
67
|
+
}
|
68
|
+
put(request, options) {
|
69
|
+
return this.fetch(request, { ...options, method: 'PUT' });
|
70
|
+
}
|
71
|
+
patch(request, options) {
|
72
|
+
return this.fetch(request, { ...options, method: 'PATCH' });
|
73
|
+
}
|
74
|
+
delete(request, options) {
|
75
|
+
return this.fetch(request, { ...options, method: 'DELETE' });
|
76
|
+
}
|
77
|
+
head(request, options) {
|
78
|
+
return this.fetch(request, { ...options, method: 'HEAD' });
|
79
|
+
}
|
80
|
+
extend(options) {
|
81
|
+
return new Fetch(this.ofetchInstance, { ...this.options, ...options });
|
82
|
+
}
|
83
|
+
}
|
84
|
+
exports.Fetch = Fetch;
|
85
|
+
var ofetch_2 = require("ofetch");
|
86
|
+
Object.defineProperty(exports, "createFetch", { enumerable: true, get: function () { return ofetch_2.createFetch; } });
|
87
|
+
//# 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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"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
export * from './cache';
|
2
|
+
export * from './s3';
|
3
|
+
export * from './preference';
|
4
|
+
export * from './puppeteer';
|
5
|
+
export declare const fetchWithCache: <T>(...args: any[]) => Promise<T>;
|
6
|
+
export declare const handleWSEventWithCache: (fnThat: any, fn: any, ttl: any, eventParser: any, eventFilter: any, eventIdSelector: any) => (event: any) => Promise<void>;
|
7
|
+
export declare const sleep: (millsec?: number) => Promise<void>;
|
8
|
+
export declare const convertDiff: (diff: string | null) => any;
|
@@ -0,0 +1,80 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
exports.convertDiff = exports.sleep = exports.handleWSEventWithCache = exports.fetchWithCache = void 0;
|
18
|
+
const cache_1 = require("../utils/cache");
|
19
|
+
const lru_cache_1 = require("lru-cache");
|
20
|
+
__exportStar(require("./cache"), exports);
|
21
|
+
__exportStar(require("./s3"), exports);
|
22
|
+
__exportStar(require("./preference"), exports);
|
23
|
+
__exportStar(require("./puppeteer"), exports);
|
24
|
+
const fetchWithCache = async (...args) => {
|
25
|
+
const res = cache_1.cache.get(args);
|
26
|
+
if (res) {
|
27
|
+
return res;
|
28
|
+
}
|
29
|
+
const result = await fetch(args).then((res) => res.json());
|
30
|
+
cache_1.cache.set(args, result);
|
31
|
+
return result;
|
32
|
+
};
|
33
|
+
exports.fetchWithCache = fetchWithCache;
|
34
|
+
// export const fetch = async (...args) => {}
|
35
|
+
const handleWSEventWithCache = (fnThat, fn, ttl, eventParser, eventFilter, eventIdSelector) => {
|
36
|
+
const WSCache = new lru_cache_1.LRUCache({
|
37
|
+
max: 500,
|
38
|
+
size: 50,
|
39
|
+
sizeCalculation: (value, key) => 1,
|
40
|
+
// for use with tracking overall storage size
|
41
|
+
maxSize: 5000,
|
42
|
+
allowStale: false,
|
43
|
+
updateAgeOnGet: false,
|
44
|
+
noUpdateTTL: true,
|
45
|
+
ttl: ttl,
|
46
|
+
});
|
47
|
+
return async function (event) {
|
48
|
+
const data = eventParser(event);
|
49
|
+
const key = eventIdSelector(data);
|
50
|
+
if (!eventFilter(data) || WSCache.get(key)) {
|
51
|
+
// console.log(`${key} hit cache, skip it, remainingTTL: `, WSCache.getRemainingTTL(key))
|
52
|
+
return;
|
53
|
+
}
|
54
|
+
WSCache.set(key, true);
|
55
|
+
await fn.apply(fnThat, [data]);
|
56
|
+
};
|
57
|
+
};
|
58
|
+
exports.handleWSEventWithCache = handleWSEventWithCache;
|
59
|
+
const sleep = async (millsec = 5000) => {
|
60
|
+
await new Promise((resolve, reject) => {
|
61
|
+
setTimeout(resolve, millsec);
|
62
|
+
});
|
63
|
+
};
|
64
|
+
exports.sleep = sleep;
|
65
|
+
const diffMap = {
|
66
|
+
E: 'Easy',
|
67
|
+
N: 'Normal',
|
68
|
+
H: 'Hard',
|
69
|
+
EX: 'Expert',
|
70
|
+
EP: 'ExpertPlus',
|
71
|
+
'EX+': 'ExpertPlus',
|
72
|
+
};
|
73
|
+
const convertDiff = (diff) => {
|
74
|
+
if (!diff) {
|
75
|
+
return diff;
|
76
|
+
}
|
77
|
+
return diffMap[diff.toUpperCase()];
|
78
|
+
};
|
79
|
+
exports.convertDiff = convertDiff;
|
80
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
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,34 @@
|
|
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
|
+
set<T extends string | number | boolean>(key: string, value: T): Promise<boolean>;
|
8
|
+
get<T extends string | number | boolean>(key: string): Promise<T | undefined>;
|
9
|
+
configEntries(): Promise<Record<string, any>>;
|
10
|
+
}
|
11
|
+
type PreferenceItem = {
|
12
|
+
key: string;
|
13
|
+
i18nName: string;
|
14
|
+
valueType: 'img-url' | 'string' | 'number' | 'boolean';
|
15
|
+
default: any;
|
16
|
+
};
|
17
|
+
export declare const preferenceKey: {
|
18
|
+
blProfileRenderImg: {
|
19
|
+
key: string;
|
20
|
+
i18nName: string;
|
21
|
+
};
|
22
|
+
ssProfileRenderImg: {
|
23
|
+
key: string;
|
24
|
+
i18nName: string;
|
25
|
+
};
|
26
|
+
blScoreImg: {
|
27
|
+
key: string;
|
28
|
+
i18nName: string;
|
29
|
+
};
|
30
|
+
};
|
31
|
+
export declare const preferenceSchema: Record<string, PreferenceItem>;
|
32
|
+
export declare const hasPreferenceSchemaByKeyOrName: (key: string) => boolean;
|
33
|
+
export declare const getPreferenceSchemaByKeyOrName: (key: string) => PreferenceItem;
|
34
|
+
export {};
|
@@ -0,0 +1,112 @@
|
|
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 set(key, value) {
|
30
|
+
if (!this.v) {
|
31
|
+
this.v = (await this.db.getUserPreference(this.uid)) ?? {};
|
32
|
+
}
|
33
|
+
const cacheKey = `${this.uid}`;
|
34
|
+
const v = {
|
35
|
+
...this.v,
|
36
|
+
[key]: value,
|
37
|
+
};
|
38
|
+
await this.db.storeUserPreference(this.uid, v);
|
39
|
+
cache.set(cacheKey, v);
|
40
|
+
this.v = v;
|
41
|
+
return true;
|
42
|
+
}
|
43
|
+
async get(key) {
|
44
|
+
const cacheKey = `${this.uid}`;
|
45
|
+
const has = cache.has(cacheKey);
|
46
|
+
if (has) {
|
47
|
+
const v = cache.get(cacheKey);
|
48
|
+
return v?.[key] ?? exports.preferenceSchema[key]?.default;
|
49
|
+
}
|
50
|
+
const value = (await this.db.getUserPreference(this.uid)) ?? {};
|
51
|
+
cache.set(cacheKey, value);
|
52
|
+
return value?.[key] ?? exports.preferenceSchema[key]?.default;
|
53
|
+
}
|
54
|
+
async configEntries() {
|
55
|
+
await this.get('');
|
56
|
+
return cache.get(this.uid);
|
57
|
+
}
|
58
|
+
}
|
59
|
+
exports.UserPreferenceStore = UserPreferenceStore;
|
60
|
+
exports.preferenceKey = {
|
61
|
+
blProfileRenderImg: {
|
62
|
+
key: 'bl::profile::render::img',
|
63
|
+
i18nName: 'BLProfile背景图片',
|
64
|
+
},
|
65
|
+
ssProfileRenderImg: {
|
66
|
+
key: 'ss::profile::render::img',
|
67
|
+
i18nName: 'SSProfile背景图片',
|
68
|
+
},
|
69
|
+
blScoreImg: {
|
70
|
+
key: 'bl::score::render::img',
|
71
|
+
i18nName: 'BLScore背景图片',
|
72
|
+
},
|
73
|
+
};
|
74
|
+
exports.preferenceSchema = {
|
75
|
+
'bl::profile::render::img': {
|
76
|
+
key: 'bl::profile::render::img',
|
77
|
+
i18nName: 'BLProfile背景图片',
|
78
|
+
valueType: 'img-url',
|
79
|
+
default: 'https://www.loliapi.com/acg/pc/',
|
80
|
+
},
|
81
|
+
'ss::profile::render::img': {
|
82
|
+
key: 'ss::profile::render::img',
|
83
|
+
i18nName: 'SSProfile背景图片',
|
84
|
+
valueType: 'img-url',
|
85
|
+
default: 'https://www.loliapi.com/acg/pc/',
|
86
|
+
},
|
87
|
+
'bl::score::render::img': {
|
88
|
+
key: 'bl::score::render::img',
|
89
|
+
i18nName: 'BLScore背景图片',
|
90
|
+
valueType: 'img-url',
|
91
|
+
default: 'https://www.loliapi.com/acg/pc/',
|
92
|
+
},
|
93
|
+
};
|
94
|
+
const preferenceMap = new Map();
|
95
|
+
Object.entries(exports.preferenceSchema).forEach(([key, value]) => {
|
96
|
+
preferenceMap.set(value.i18nName, value);
|
97
|
+
});
|
98
|
+
const hasPreferenceSchemaByKeyOrName = (key) => {
|
99
|
+
if (key in exports.preferenceSchema) {
|
100
|
+
return true;
|
101
|
+
}
|
102
|
+
return preferenceMap.has(key);
|
103
|
+
};
|
104
|
+
exports.hasPreferenceSchemaByKeyOrName = hasPreferenceSchemaByKeyOrName;
|
105
|
+
const getPreferenceSchemaByKeyOrName = (key) => {
|
106
|
+
if (key in exports.preferenceSchema) {
|
107
|
+
return exports.preferenceSchema[key];
|
108
|
+
}
|
109
|
+
return preferenceMap.get(key);
|
110
|
+
};
|
111
|
+
exports.getPreferenceSchemaByKeyOrName = getPreferenceSchemaByKeyOrName;
|
112
|
+
//# 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,20 @@
|
|
1
|
+
/// <reference types="node" />
|
2
|
+
import { Browser, ScreenshotClip, ScreenshotOptions } from 'puppeteer-core';
|
3
|
+
import { Config } from '../config';
|
4
|
+
export interface PuppeteerProvider {
|
5
|
+
browser: Browser;
|
6
|
+
ok: boolean;
|
7
|
+
}
|
8
|
+
export declare class RemotePuppeteerProvider implements PuppeteerProvider {
|
9
|
+
browser: Browser;
|
10
|
+
constructor(config: Config);
|
11
|
+
get ok(): boolean;
|
12
|
+
}
|
13
|
+
export declare class PuppeteerRender {
|
14
|
+
browserHolders: PuppeteerProvider[];
|
15
|
+
get browser(): Browser;
|
16
|
+
get ok(): false | PuppeteerProvider;
|
17
|
+
constructor(providers: PuppeteerProvider[]);
|
18
|
+
renderHTML(html: string, selector: string, onStart?: () => void, screenShotOption?: (clip: ScreenshotClip) => ScreenshotOptions): Promise<Buffer>;
|
19
|
+
screenshotURL(url: string, selector: string, onStart?: () => void, screenShotOption?: (clip: ScreenshotClip) => ScreenshotOptions): Promise<Buffer>;
|
20
|
+
}
|
@@ -0,0 +1,79 @@
|
|
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
|
+
constructor(config) {
|
12
|
+
puppeteer_core_1.default
|
13
|
+
.connect({ browserWSEndpoint: config.broswerlessWSEndpoint })
|
14
|
+
.then((res) => {
|
15
|
+
console.log('connect to browser successful');
|
16
|
+
this.browser = res;
|
17
|
+
})
|
18
|
+
.catch((e) => {
|
19
|
+
console.error('connection error', e);
|
20
|
+
});
|
21
|
+
}
|
22
|
+
get ok() {
|
23
|
+
return this.browser != null || this.browser != undefined;
|
24
|
+
}
|
25
|
+
}
|
26
|
+
exports.RemotePuppeteerProvider = RemotePuppeteerProvider;
|
27
|
+
class PuppeteerRender {
|
28
|
+
browserHolders;
|
29
|
+
get browser() {
|
30
|
+
const provider = this.browserHolders.find((it) => it.ok);
|
31
|
+
if (provider) {
|
32
|
+
return provider.browser;
|
33
|
+
}
|
34
|
+
throw Error('NoSuitablePuppeteerProviderFound');
|
35
|
+
}
|
36
|
+
get ok() {
|
37
|
+
return this.browserHolders.find((it) => it.ok) ?? false;
|
38
|
+
}
|
39
|
+
constructor(providers) {
|
40
|
+
// unsafe singleton, but enough for now
|
41
|
+
this.browserHolders = providers;
|
42
|
+
}
|
43
|
+
async renderHTML(html, selector, onStart, screenShotOption) {
|
44
|
+
onStart?.();
|
45
|
+
const page = await this.browser.newPage();
|
46
|
+
await page.setContent(html);
|
47
|
+
await page.setViewport({
|
48
|
+
width: 3840,
|
49
|
+
height: 2160,
|
50
|
+
deviceScaleFactor: 1,
|
51
|
+
});
|
52
|
+
const elm = await page.waitForSelector(selector, { timeout: 5000 });
|
53
|
+
// const clip = await elm.boundingBox()、
|
54
|
+
const u8Arr = await elm
|
55
|
+
.screenshot();
|
56
|
+
await page.close();
|
57
|
+
return Buffer.from(u8Arr);
|
58
|
+
}
|
59
|
+
async screenshotURL(url, selector, onStart, screenShotOption) {
|
60
|
+
onStart?.();
|
61
|
+
const page = await this.browser.newPage();
|
62
|
+
await page.setViewport({
|
63
|
+
width: 3840,
|
64
|
+
height: 2160,
|
65
|
+
deviceScaleFactor: 1,
|
66
|
+
});
|
67
|
+
await page.goto(url, { timeout: 0, waitUntil: 'domcontentloaded' });
|
68
|
+
const elm = await page.waitForSelector(selector, { timeout: 20000 });
|
69
|
+
// wait for potential animation
|
70
|
+
await (0, index_1.sleep)(3000);
|
71
|
+
// const clip = await elm.boundingBox()
|
72
|
+
const buffer = await elm
|
73
|
+
.screenshot();
|
74
|
+
await page.close();
|
75
|
+
return Buffer.from(buffer);
|
76
|
+
}
|
77
|
+
}
|
78
|
+
exports.PuppeteerRender = PuppeteerRender;
|
79
|
+
//# 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
|
+
}
|