fix: get auth magics

using fetch hook
This commit is contained in:
Xmader 2020-11-21 01:22:35 -05:00
parent 6b0a04b152
commit c6eeb4d881
No known key found for this signature in database
GPG key ID: A20B97FB9EB730E4

View file

@ -1,56 +1,51 @@
/* eslint-disable no-extend-native */ /* eslint-disable no-extend-native */
/* eslint-disable @typescript-eslint/no-unsafe-return */
import scoreinfo from './scoreinfo' import scoreinfo from './scoreinfo'
import { onPackLoad, getObfuscationCtx, OBFUSCATED_REG } from './webpack-hook' import { ALL, webpackGlobalOverride } from './webpack-hook'
import { console } from './utils'
type FileType = 'img' | 'mp3' | 'midi' type FileType = 'img' | 'mp3' | 'midi'
const AUTH_REG = `(\\+?${OBFUSCATED_REG.source}?)+` const TYPE_REG = /id=(\d+)&type=(img|mp3|midi)/
const AUTH_CTX_REG = `,(${AUTH_REG})\\)(\\[|\\.then)`
enum PACK_HINT {
img = 'getImageRef',
midi = 'midi:',
mp3 = 'setVolume:',
}
/** /**
* I know this is super hacky. * I know this is super hacky.
*/ */
const magicHookConstr = async (type: FileType) => { const magicHookConstr = (() => {
// request pack const l = {}
// await loadAllPacks()
return new Promise<string>((resolve) => { webpackGlobalOverride(ALL, (n, r, t) => { // override
onPackLoad((pack) => { const e = n.exports
Object.values(pack[1]).forEach((mod) => { if (typeof e === 'object' && e.fetch) {
const str = mod.toString() const fn = e.fetch
if (!str.includes(PACK_HINT[type])) { t.d(e, 'fetch', () => {
return return function (...args) {
} const [url, init] = args
const token = init?.headers?.Authorization
const m = str.match(AUTH_CTX_REG) if (typeof url === 'string' && token) {
if (m) { const m = url.match(TYPE_REG)
try { if (m) {
const deObf = getObfuscationCtx(mod) const type = m[2]
const authExp = m[1] // eslint-disable-next-line no-unused-expressions
l[type]?.(token)
const reg = new RegExp(OBFUSCATED_REG)
let magic = ''
let r: RegExpMatchArray | null
while ((r = reg.exec(authExp)) !== null) {
magic += deObf(+r[2], r[3])
} }
resolve(magic)
} catch (err) {
console.error(err)
} }
return fn(...args)
} }
}) })
}) }
}) })
}
return async (type: FileType) => {
return new Promise<string>((resolve) => {
l[type] = (token) => {
resolve(token)
magics[type] = token
}
})
}
})()
const magics: Record<FileType, Promise<string>> = { const magics: Record<FileType, Promise<string>> = {
img: magicHookConstr('img'), img: magicHookConstr('img'),
@ -65,7 +60,31 @@ const getApiUrl = (type: FileType, index: number): string => {
const getApiAuth = async (type: FileType, index: number): Promise<string> => { const getApiAuth = async (type: FileType, index: number): Promise<string> => {
// eslint-disable-next-line no-void // eslint-disable-next-line no-void
void index void index
return magics[type]
const magic = magics[type]
if (magic instanceof Promise) {
// force to retrieve the MAGIC
switch (type) {
case 'midi': {
const el = document.querySelectorAll('.SD7H- > button')[3] as HTMLButtonElement
el.click()
break
}
case 'mp3': {
const el = document.querySelector('#playerBtnExprt') as HTMLButtonElement
el.click()
break
}
case 'img': {
const imgE = document.querySelector('img[src*=score_]')
const nextE = imgE?.parentElement?.nextElementSibling
if (nextE) nextE.scrollIntoView()
break
}
}
}
return magic
} }
export const getFileUrl = async (type: FileType, index = 0): Promise<string> => { export const getFileUrl = async (type: FileType, index = 0): Promise<string> => {