optimize: .kgm
mask loading
This commit is contained in:
parent
71862538b7
commit
6737e8c11b
@ -8,6 +8,7 @@ import {
|
|||||||
} from "@/decrypt/utils.ts";
|
} from "@/decrypt/utils.ts";
|
||||||
import {parseBlob as metaParseBlob} from "music-metadata-browser";
|
import {parseBlob as metaParseBlob} from "music-metadata-browser";
|
||||||
import {DecryptResult} from "@/decrypt/entity";
|
import {DecryptResult} from "@/decrypt/entity";
|
||||||
|
import config from "@/../package.json"
|
||||||
|
|
||||||
const VprHeader = [
|
const VprHeader = [
|
||||||
0x05, 0x28, 0xBC, 0x96, 0xE9, 0xE4, 0x5A, 0x43,
|
0x05, 0x28, 0xBC, 0x96, 0xE9, 0xE4, 0x5A, 0x43,
|
||||||
@ -22,9 +23,6 @@ const VprMaskDiff = [
|
|||||||
|
|
||||||
|
|
||||||
export async function Decrypt(file: File, raw_filename: string, raw_ext: string): Promise<DecryptResult> {
|
export async function Decrypt(file: File, raw_filename: string, raw_ext: string): Promise<DecryptResult> {
|
||||||
if (self.location.protocol === "file:") {
|
|
||||||
throw Error("请使用 <a target='_blank' href='https://github.com/unlock-music/cli'>CLI版本</a> 进行解锁")
|
|
||||||
}
|
|
||||||
|
|
||||||
const oriData = new Uint8Array(await GetArrayBuffer(file));
|
const oriData = new Uint8Array(await GetArrayBuffer(file));
|
||||||
if (raw_ext === "vpr") {
|
if (raw_ext === "vpr") {
|
||||||
@ -84,8 +82,16 @@ function GetMask(pos: number) {
|
|||||||
let MaskV2: Uint8Array = new Uint8Array(0);
|
let MaskV2: Uint8Array = new Uint8Array(0);
|
||||||
|
|
||||||
async function LoadMaskV2(): Promise<boolean> {
|
async function LoadMaskV2(): Promise<boolean> {
|
||||||
|
let mask_url = `https://cdn.jsdelivr.net/gh/unlock-music/unlock-music@${config.version}/public/static/kgm.mask`
|
||||||
|
if (["http:", "https:"].some(v => v == self.location.protocol)) {
|
||||||
|
if (!!self.document) {// using Web Worker
|
||||||
|
mask_url = "./static/kgm.mask"
|
||||||
|
} else {// using Main thread
|
||||||
|
mask_url = "../static/kgm.mask"
|
||||||
|
}
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
const resp = await fetch(process.env.NODE_ENV !== 'production'?"./static/kgm.mask":"../static/kgm.mask", {method: "GET"})
|
const resp = await fetch(mask_url, {method: "GET"})
|
||||||
MaskV2 = new Uint8Array(await resp.arrayBuffer());
|
MaskV2 = new Uint8Array(await resp.arrayBuffer());
|
||||||
return true
|
return true
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
@ -26,7 +26,8 @@
|
|||||||
"dom",
|
"dom",
|
||||||
"dom.iterable",
|
"dom.iterable",
|
||||||
"scripthost"
|
"scripthost"
|
||||||
]
|
],
|
||||||
|
"resolveJsonModule": true
|
||||||
},
|
},
|
||||||
"include": [
|
"include": [
|
||||||
"src/**/*.ts",
|
"src/**/*.ts",
|
||||||
|
Loading…
Reference in New Issue
Block a user