fix: get file url

This commit is contained in:
Xmader 2020-11-13 18:27:28 -05:00
parent d31678d3e6
commit d2956ad9d5
No known key found for this signature in database
GPG key ID: A20B97FB9EB730E4
2 changed files with 36 additions and 33 deletions

View file

@ -1,11 +1,10 @@
/* eslint-disable no-extend-native */ /* eslint-disable no-extend-native */
import scoreinfo from './scoreinfo' import scoreinfo from './scoreinfo'
import { webpackHook, webpackGlobalOverride, ALL } from './webpack-hook' import { webpackHook, webpackGlobalOverride } from './webpack-hook'
const FILE_URL_MODULE_ID = 'iNJA' const AUTH_MODULE_ID = 'UeBv'
const ARG_NUMBER = 4 const MAGIC_ARG_INDEX = 1
const MAGIC_ARG_INDEX = 3
type FileType = 'img' | 'mp3' | 'midi' type FileType = 'img' | 'mp3' | 'midi'
@ -14,35 +13,23 @@ type FileType = 'img' | 'mp3' | 'midi'
*/ */
let magic: Promise<string> | string = new Promise((resolve) => { let magic: Promise<string> | string = new Promise((resolve) => {
// todo: hook module by what it does, not what it is called // todo: hook module by what it does, not what it is called
webpackGlobalOverride(ALL, (_, r, t) => { // override webpackGlobalOverride(AUTH_MODULE_ID, (n, r, t) => { // override
const fn = r.a const fn = n.exports
if (typeof fn === 'function' && fn.length === ARG_NUMBER) { n.exports = (...args) => {
t.d(r, 'a', () => {
return (...args) => {
if (magic instanceof Promise) { if (magic instanceof Promise) {
if (args.every(a => typeof a === 'number' || typeof a === 'string')) {
magic = args[MAGIC_ARG_INDEX] magic = args[MAGIC_ARG_INDEX]
resolve(magic) resolve(magic)
} }
}
return fn(...args) as string return fn(...args) as string
} }
}) })
})
const getApiUrl = (type: FileType, index: number): string => {
return `/api/jmuse?id=${scoreinfo.id}&type=${type}&index=${index}`
} }
})
})
export const getFileUrl = async (type: FileType, index = 0): Promise<string> => {
const fileUrlModule = webpackHook(FILE_URL_MODULE_ID, {
'6Ulw' (_, r, t) { // override
t.d(r, 'a', () => {
return type
})
},
})
const fn: (_, id: number, index: number, cb: (url: string) => any, magic: string) => string = fileUrlModule.a
const getApiAuth = async (type: FileType, index: number): Promise<string> => {
if (magic instanceof Promise) { if (magic instanceof Promise) {
// force to retrieve the MAGIC // force to retrieve the MAGIC
const el = document.querySelectorAll('.SD7H- > button')[3] as HTMLButtonElement const el = document.querySelectorAll('.SD7H- > button')[3] as HTMLButtonElement
@ -50,7 +37,23 @@ export const getFileUrl = async (type: FileType, index = 0): Promise<string> =>
magic = await magic magic = await magic
} }
return new Promise((resolve) => { const str = String(scoreinfo.id) + type + String(index)
return fn(undefined, scoreinfo.id, index, resolve, magic as string)
}) const fn: (str: string, magic: string) => string = webpackHook(AUTH_MODULE_ID)
return fn(str, magic)
}
export const getFileUrl = async (type: FileType, index = 0): Promise<string> => {
const url = getApiUrl(type, index)
const auth = await getApiAuth(type, index)
const r = await fetch(url, {
headers: {
Authorization: auth,
},
})
const { info } = await r.json()
return info.url as string
} }

View file

@ -3,7 +3,7 @@
import { hookNative } from './anti-detection' import { hookNative } from './anti-detection'
const CHUNK_PUSH_FN = 'function a(a){' const CHUNK_PUSH_FN = /^function [^r]\(\w\){/
interface Module { interface Module {
(module, exports, __webpack_require__): void; (module, exports, __webpack_require__): void;
@ -88,7 +88,7 @@ export const webpackGlobalOverride = (() => {
get () { return jsonp }, get () { return jsonp },
set (v: WebpackJson) { set (v: WebpackJson) {
jsonp = v jsonp = v
if (!hooked && v.push.toString().includes(CHUNK_PUSH_FN)) { if (!hooked && v.push.toString().match(CHUNK_PUSH_FN)) {
hooked = true hooked = true
hookNative(v, 'push', (_fn) => { hookNative(v, 'push', (_fn) => {
return function (pack) { return function (pack) {