Working version

This commit is contained in:
Joris Bertomeu
2025-08-26 09:08:04 +02:00
commit ac0dc8286b
63 changed files with 2741 additions and 0 deletions

10
python/schemes/Allente.py Normal file
View File

@@ -0,0 +1,10 @@
payload = {
'playerPayload': base64.b64encode(cdm.service_certificate_challenge).decode()
}
service_cert = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
service_cert = service_cert['license']
payload = {
'playerPayload': getChallenge('b64', service_cert)
}
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['license']

7
python/schemes/Amazon.py Normal file
View File

@@ -0,0 +1,7 @@
import urllib.parse
payload = f'widevine2Challenge={urllib.parse.quote(base64.b64encode(cdm.service_certificate_challenge).decode())}&includeHdcpTestKeyInLicense=true'
service_cert = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
service_cert = service_cert['widevine2License']['license']
payload = f'widevine2Challenge={urllib.parse.quote(getChallenge("b64", service_cert))}&includeHdcpTestKeyInLicense=true'
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['widevine2License']['license']

View File

@@ -0,0 +1,4 @@
payload = loadBody('json')
payload['ServiceRequest']['InData']['ChallengeInfo'] = getChallenge('b64', Cdm.common_privacy_cert)
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence["ServiceResponse"]["OutData"]["LicenseInfo"]

View File

@@ -0,0 +1,3 @@
import xml.etree.ElementTree as ET
licence = await corsFetch(licUrl, "POST", licHeaders, getChallenge('b64', Cdm.common_privacy_cert), "blob")
licence = ET.fromstring(licence).find('.//{http://www.canal-plus.com/DRM/V1}license').text

View File

@@ -0,0 +1,4 @@
payload = loadBody("json")
payload['licenseRequest'] = getChallenge("b64")
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['license']

View File

@@ -0,0 +1 @@
licence = await corsFetch(licUrl, "POST", licHeaders, getChallenge('blob'), "blob")

View File

@@ -0,0 +1,2 @@
licence = await corsFetch(licUrl, "POST", licHeaders, getChallenge('blob'), "json")
licence = licence['license']

3
python/schemes/Fantop.py Normal file
View File

@@ -0,0 +1,3 @@
payload = loadBody('json')
payload['payload'] = getChallenge('b64')
licence = await corsFetch (licUrl, "POST", licHeaders, payload, "blob")

View File

@@ -0,0 +1,3 @@
payload = loadBody("json")
payload['license_request_data'] = getChallenge('list')
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "blob")

View File

@@ -0,0 +1,61 @@
import re
def replaceRequest(payload):
challenge_blob = getChallenge('blob')
challengeB64 = getChallenge('b64')
challengeArr = str(getChallenge('list'))
# Trying decode payload, challenge might be raw bytes if it failed
try:
decodedPayload = payload.decode()
except:
return challenge_blob
# Challenge might be JSON/XML stored B64-encoded string
replaced = decodedPayload.replace(r"(?<=(\"|\'|>))CAES.*?(?=(\"|\'|<))", challengeB64).replace(r"(?<=(\"|\'|>))CAQ=(?=(\"|\'|<))", challengeB64)
if(decodedPayload != replaced):
return replaced
# Challenge might be raw B64-encoded string
replaced = decodedPayload.replace(r"^CAES.*?=$", challengeB64).replace(r"^CAQ=$", challengeB64)
if(decodedPayload != replaced):
return replaced
# Challenge might be Uint8Array
replaced = decodedPayload.replace(r"\[0?8 ?, ?0?1 ?, ?[0-9 ,]*?\]", challengeArr).replace(r"\[0?8 ?, ?0?4]", challengeArr)
if(decodedPayload != replaced):
return replaced
def findLicense(response):
# Trying decode response, license might be raw bytes if it failed
try:
decodedResponse = response.decode()
except:
return response
# License might be JSON/XML stored B64-encoded string
try:
return re.search(r"(?<=(\"|\'|>))CAIS.*?(?=(\"|\'|<))", decodedResponse).group()
except:
pass
# License might be raw B64-encoded string
try:
return re.search(r"^CAIS.*?=$", decodedResponse).group()
except:
pass
# License might be Uint8Array
try:
foundStr = re.search(r"\[0?8 ?, ?0?2 ?, ?[0-9 ,]*?\]", decodedResponse).group()
return bytes(json.loads(foundStr))
except:
pass
payload = loadBody("blob")
payload = replaceRequest(payload)
response = await corsFetch(licUrl, "POST", licHeaders, payload, "blob")
licence = findLicense(response)

5
python/schemes/NosTV.py Normal file
View File

@@ -0,0 +1,5 @@
payload = {
'challenge': getChallenge('b64')
}
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence["license"][0]

View File

@@ -0,0 +1,4 @@
payload = loadBody('json')
payload['params']['object'] = getChallenge('b64', Cdm.common_privacy_cert)
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['result']['object']['license']

4
python/schemes/RedBee.py Normal file
View File

@@ -0,0 +1,4 @@
payload = loadBody("json")
payload['message'] = getChallenge('b64')
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['license']

5
python/schemes/Sling.py Normal file
View File

@@ -0,0 +1,5 @@
payload = loadBody('json')
payload['message'] = list(cdm.service_certificate_challenge)
service_cert = await corsFetch(licUrl, "POST", licHeaders, payload, "blob")
payload['message'] = list(getChallenge('list', service_cert))
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "blob")

3
python/schemes/VUDRM.py Normal file
View File

@@ -0,0 +1,3 @@
payload = loadBody("json")
payload['drm_info'] = getChallenge('list')
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "blob")

View File

@@ -0,0 +1,10 @@
payload = loadBody("json")
decoded_token = json.loads(base64.b64decode(payload['token']).decode())
decoded_token['licenseRequest'] = base64.b64encode(cdm.service_certificate_challenge).decode('utf-8')
payload = {"token": base64.b64encode(json.dumps(decoded_token).encode()).decode()}
service_cert = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
service_cert = service_cert["license"]
decoded_token['licenseRequest'] = getChallenge('b64', service_cert)
payload = {"token": base64.b64encode(json.dumps(decoded_token).encode()).decode()}
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence["license"]

View File

@@ -0,0 +1,4 @@
payload = loadBody("json")
payload['requests'][3]['params']['challenge'] = getChallenge('b64')
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['license']

View File

@@ -0,0 +1,4 @@
payload = loadBody('json')
payload['licenseRequest'] = getChallenge('b64', Cdm.common_privacy_cert)
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['license'].replace("-", "+").replace("_", "/")

7
python/schemes/Youku.py Normal file
View File

@@ -0,0 +1,7 @@
import urllib.parse
payload = urllib.parse.parse_qs(loadBody("str"))
payload['licenseRequest'] = [getChallenge('b64')]
payload = {k: v[0] for k, v in payload.items()}
payload = urllib.parse.urlencode(payload)
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['data']

4
python/schemes/moTV.py Normal file
View File

@@ -0,0 +1,4 @@
payload = loadBody("json")
payload['rawLicense'] = getChallenge('b64')
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence['rawLicense']

4
python/schemes/oqee.py Normal file
View File

@@ -0,0 +1,4 @@
payload = loadBody("json")
payload['licenseRequest'] = getChallenge('b64')
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence["result"]["license"]

View File

@@ -0,0 +1,4 @@
payload = loadBody("json")
payload["getWidevineLicense"]["widevineChallenge"] = getChallenge('b64')
licence = await corsFetch(licUrl, "POST", licHeaders, payload, "json")
licence = licence["getWidevineLicenseResponse"]["license"]