deemix-js/deemix/utils/crypto.js
2021-07-25 13:22:17 +02:00

57 lines
1.8 KiB
JavaScript

const crypto = require('crypto')
let Blowfish
try {
Blowfish = require('egoroof-blowfish')
} catch (e) { /* empty */ }
function _md5 (data, type = 'binary') {
let md5sum = crypto.createHash('md5')
md5sum.update(Buffer.from(data, type))
return md5sum.digest('hex')
}
function _ecbCrypt (key, data) {
let cipher = crypto.createCipheriv("aes-128-ecb", Buffer.from(key), Buffer.from(""));
cipher.setAutoPadding(false)
return Buffer.concat([cipher.update(data, 'binary'), cipher.final()]).toString("hex").toLowerCase();
}
function _ecbDecrypt (key, data) {
let cipher = crypto.createDecipheriv("aes-128-ecb", Buffer.from(key), Buffer.from(""));
cipher.setAutoPadding(false)
return Buffer.concat([cipher.update(data, 'binary'), cipher.final()]).toString("hex").toLowerCase();
}
function generateBlowfishKey(trackId) {
const SECRET = 'g4el58wc0zvf9na1';
const idMd5 = _md5(trackId.toString(), 'ascii')
let bfKey = ''
for (let i = 0; i < 16; i++) {
bfKey += String.fromCharCode(idMd5.charCodeAt(i) ^ idMd5.charCodeAt(i + 16) ^ SECRET.charCodeAt(i))
}
return String(bfKey);
}
function decryptChunk(chunk, blowFishKey){
let ciphers = crypto.getCiphers()
if (ciphers.includes('bf-cbc')){
let cipher = crypto.createDecipheriv('bf-cbc', blowFishKey, Buffer.from([0, 1, 2, 3, 4, 5, 6, 7]))
cipher.setAutoPadding(false)
return Buffer.concat([cipher.update(chunk), cipher.final()])
}
if (Blowfish){
let cipher = new Blowfish(blowFishKey, Blowfish.MODE.CBC, Blowfish.PADDING.NULL)
cipher.setIv(Buffer.from([0, 1, 2, 3, 4, 5, 6, 7]))
return Buffer.from(cipher.decode(chunk, Blowfish.TYPE.UINT8_ARRAY))
}
throw new Error("Can't find a way to decrypt chunks")
}
module.exports = {
_md5,
_ecbCrypt,
_ecbDecrypt,
generateBlowfishKey,
decryptChunk
}