Moved deezer api over to deezer-py pipy package; Version bump to 2.0.1
This commit is contained in:
@ -1,6 +1,6 @@
|
||||
import re
|
||||
import string
|
||||
from deemix.api.deezer import TrackFormats
|
||||
from deezer import TrackFormats
|
||||
import os
|
||||
|
||||
def generateReplayGainString(trackGain):
|
||||
|
26
deemix/utils/decryption.py
Normal file
26
deemix/utils/decryption.py
Normal file
@ -0,0 +1,26 @@
|
||||
import binascii
|
||||
from Cryptodome.Cipher import Blowfish, AES
|
||||
from Cryptodome.Hash import MD5
|
||||
from Cryptodome.Util.Padding import pad
|
||||
|
||||
def _md5(data):
|
||||
h = MD5.new()
|
||||
h.update(str.encode(data) if isinstance(data, str) else data)
|
||||
return h.hexdigest()
|
||||
|
||||
def generateBlowfishKey(trackId):
|
||||
SECRET = 'g4el58wc' + '0zvf9na1'
|
||||
idMd5 = _md5(trackId)
|
||||
bfKey = ""
|
||||
for i in range(16):
|
||||
bfKey += chr(ord(idMd5[i]) ^ ord(idMd5[i + 16]) ^ ord(SECRET[i]))
|
||||
return bfKey
|
||||
|
||||
def generateStreamURL(sng_id, md5, media_version, format):
|
||||
urlPart = b'\xa4'.join(
|
||||
[str.encode(md5), str.encode(str(format)), str.encode(str(sng_id)), str.encode(str(media_version))])
|
||||
md5val = _md5(urlPart)
|
||||
step2 = str.encode(md5val) + b'\xa4' + urlPart + b'\xa4'
|
||||
step2 = pad(step2, 16)
|
||||
urlPart = binascii.hexlify(AES.new(b'jo6aey6haid2Teih', AES.MODE_ECB).encrypt(step2))
|
||||
return "https://e-cdns-proxy-" + md5[0] + ".dzcdn.net/mobile/1/" + urlPart.decode("utf-8")
|
@ -2,7 +2,7 @@ import re
|
||||
from os.path import sep as pathSep
|
||||
from pathlib import Path
|
||||
from unicodedata import normalize
|
||||
from deemix.api.deezer import TrackFormats
|
||||
from deezer import TrackFormats
|
||||
|
||||
bitrateLabels = {
|
||||
TrackFormats.MP4_RA3: "360 HQ",
|
||||
|
Reference in New Issue
Block a user