Initial
This commit is contained in:
113
src_win/actions-iTunes-header/workflow_helper/iTunesDownload/get_header.py
Executable file
113
src_win/actions-iTunes-header/workflow_helper/iTunesDownload/get_header.py
Executable file
@@ -0,0 +1,113 @@
|
||||
# frida_rpc_player.py
|
||||
|
||||
'''
|
||||
POST /WebObjects/MZBuy.woa/wa/buyProduct HTTP/1.1
|
||||
Host: p46-buy.itunes.apple.com
|
||||
User-Agent: iTunes/12.6.5 (Windows; Microsoft Windows 10.0 x64 Enterprise Edition (Build 19042); x64) AppleWebKit/7605.1033.1002.2
|
||||
Content-Length: 1226
|
||||
Content-Type: application/x-apple-plist
|
||||
X-Dsid: 12263680861
|
||||
X-Apple-Tz: 28800
|
||||
X-Apple-MD: AAAABAAAABA3hIN/KYf4Ri4tdZAiwaB5
|
||||
Cookie: amp=JG7EpvImu+/h0yS5mTqQMLarQce6xuYNfyzC6cun/bRt+7VLQUqfUrDB4cdRyV6SLDGBRCG3Oz/PcY28nx94GdTGkdOYX83a54KHZTSq3jI=; amia-12263680861=dPQK5oK/9b6q7HeGIids4a6gE5oiE8yLcVjQO7EknSTERhI0OawL4FQcmJ60560H+PbZhCCt6Na8jLSDiU09aw==; mt-asn-12263680861=2; mt-tkn-12263680861=AmDauzfLChTup9vGq17bGVJvSurhbsyoCLyrpJG8t8uECuyAI3xr3o/vS9pVpKeg4dSlCxJtLUS8+H47Qtpou0VGgGBAn/dXAPozhdJKTyPdUqyT4My89dujXg48XNgIVUjFj2w4IhN1gg5wn3BfSg1bFChodxuHadsRibnYzkUPmR+TVTnivu9e4/QLJmh58Va8rmg=; mt-tkn-10255130069=Ala2nKdNzZWOlapGgvRzcNExINc8j4sbrcMn3ruJ9M3Cb17MGiGqvyTe9yUzh/fSNLEL+4s0j57Eht/AWXrG2e3+GptHZlTi1vZ4a+3PdD9dtfSP8no7s9/bMX6JTtnE+fwV1z8QudsvAs+kjEz0MqFgoxFZZntBKI1L81+CBTnmsBolRdk+wqqPGZ3AD5bdybUTwD4=; countryVerified=1; mzf_in=467080; itspod=46; vrep=CN3W49ctEgQIChAAEgQICBAAEgQIBxAAEgQIBBAAEgQIDRAAEgQIBhAAEgQIDBAAEgQIAxAAEgQICRAAEgQIEBAAEgQIDhAAEgQIARAAEgQIDxAAEgQIERAAEgQIBRAAEgQICxAAEgQIAhAA; wosid-lite=jRoFTHWbZZZkSOfvfDELf0; mz_at_ssl-12263680861=AwUAAAECAAHXHQAAAABgqAeMT5/7LbF5106/zxFn9xH4n7jgwEw=; mz_at0-12263680861=AwQAAAECAAHXHQAAAABgp/7Z1enk1z4615lhp9QKlDQfmo7Hq60=; pldfltcid=524b36a58d0d4249a127affd05921dab046; X-Dsid=12263680861; xp_ab=1#WqjkRLH+-2+TCEF_ea00#yNFpB6B+-2+c9imSgD01; xp_abc=TCEF_ea00; mz_at0-10255130069=AwQAAAECAAHXHQAAAABgnNBzeacT12/WPi/iSOROyaMVQrfmkqE=; mz_at_ssl-10255130069=AwUAAAECAAHXHQAAAABgnNBzNHT9PbcrsAARLEWi0+8ElnKZ54c=; xp_ci=3z3h6Y0vzFQQz4XtzB5DzZvQkYhyo
|
||||
X-Apple-AMD-M: rjK8HkwTcIoiOk6UoA9LXta0h/19+ss41RU7YLxGunAtLnl1Fus5i4VS56O71ifgDWwrEl/jIbPrDLfS
|
||||
X-Apple-AMD: AAAABAAAABCqItI0AgfIcPIc0+zGpNtr
|
||||
X-Apple-Store-Front: 143462-9,32
|
||||
Accept-Language: zh-cn
|
||||
Date: Fri, 21 May 2021 21:33:42 GMT
|
||||
X-Apple-MD-M: rjK8HkwTcIoiOk6UoA9LXta0h/2Qyn969daQuVAdJbkmCnWee7s+joaQ3fvc4v1JTJB0sUJcDwc0Q12z
|
||||
X-Apple-I-MD-RINFO: 50660608
|
||||
X-Apple-I-MD-M: rjK8HkwTcIoiOk6UoA9LXta0h/0W22FXNYql4KAM12/n20O3iVf54IK85PbrLb51CvEfn5/b6eoX5d1d
|
||||
X-Apple-I-MD: AAAABQAAABA+EMexoFPqOMeyQ5zIkQYPAAAAAg==
|
||||
Accept-Encoding: gzip, deflate
|
||||
Connection: close
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<plist version="1.0">
|
||||
<dict>
|
||||
<key>guid</key>
|
||||
<string>46994789.C2E39C5C.B1D62DC2.025D2569.3D6E49B5.AB7F7EB4.F6D17565</string>
|
||||
<key>kbsync</key>
|
||||
<data>
|
||||
AAQAA5+HiDofKn/iW9aKVsKo1XU0cRuzPrQGMfC57fQaA7YaZBWlSS+s4SS2Ay6pchYG
|
||||
x/h+cJccHMoA/NDtHcWsRl9nmDwzAnuW9WH7nHQAEt95wkj2eMQVBHyj3OSkSoEGFnS8
|
||||
r4irSIve3V4np1lvbEUgHdJmOEV6gAd8SFzItmgxFImn55qoUX/xt4pdXagPmhBXaYFI
|
||||
+B/uYLxOYLO4fM1fGpQQ8/1EIpzrbahFjpG8L8kMjhVIWpn2Ut30p2deyjcL47JbSjx7
|
||||
/RId4XZlSEqXf9SOETcsxCkVhDWTghGYRWKlEe7j32CVrxOkg2lvlQLHB1XBhTpQiLSm
|
||||
PR0hDIG5dQif0jaIeQJ9zGqq3kgkl9RlFHGbcvfMdrJsYGOgYMzXh1jfF/v21xPfauYh
|
||||
PIE9LQu/TTiAGDvS+BYrM2xVaPHZPNUpLaVlk/2zIqiWo/Zj2se4FXGOl4LAVKqrbOYN
|
||||
2YONkSY4CQOZTmNmoO6SBU2NJHBYtVVeIhOLGLoS9/xzPwMdFevvZJFD7iQvL0RDKCBt
|
||||
z5r7dnFz2WlZsdx0aMsbV3HRdnJtmBh7zA3AaO/4rJtWAQqAID2gAF8YMoNdJJp13Bdr
|
||||
f34iRpVYbsDxrBNJXtanTgDdNO3xXpyZhQTgOrBDcsv7mD68E1E6bE5ac97/z9R8cLf0
|
||||
8/X8/ie7tUBcqVThW81DiM4RGh3LSg==
|
||||
</data>
|
||||
<key>price</key>
|
||||
<string>0</string>
|
||||
<key>pricingParameters</key>
|
||||
<string>STDRDL</string>
|
||||
<key>productType</key>
|
||||
<string>C</string>
|
||||
<key>salableAdamId</key>
|
||||
<string>1234806557</string><key>appExtVrsId</key>
|
||||
<string>839637337</string>
|
||||
</dict>
|
||||
</plist>
|
||||
'''
|
||||
|
||||
import sys
|
||||
import codecs
|
||||
import frida
|
||||
import plistlib
|
||||
import os
|
||||
import base64
|
||||
|
||||
##### Frida Part
|
||||
|
||||
procName = os.environ.get('ITUNES_PROCESS_NAME', 'iTunes.exe')
|
||||
session = frida.attach(procName)
|
||||
#session = frida.attach('iTunesFucked.exe')
|
||||
|
||||
def eprint(*args, **kwargs):
|
||||
print(*args, file=sys.stderr, **kwargs)
|
||||
|
||||
with codecs.open(os.path.dirname(os.path.realpath(__file__)) + '/get_header_rpc.js', 'r', 'utf-8') as f:
|
||||
source = f.read()
|
||||
|
||||
script = session.create_script(source)
|
||||
script.load()
|
||||
|
||||
def on_message(message, data):
|
||||
if message['type'] == 'send':
|
||||
eprint("Frida: %s" % message['payload'])
|
||||
elif message['type'] == 'error':
|
||||
eprint("Frida error: %s" % message['stack'])
|
||||
|
||||
script.on('message', on_message)
|
||||
|
||||
rpc = script.exports
|
||||
|
||||
|
||||
##### Flask Part
|
||||
|
||||
from flask import Flask, request
|
||||
from flask import jsonify
|
||||
|
||||
app = Flask(__name__)
|
||||
|
||||
@app.route('/', methods=['GET', 'POST'])
|
||||
def getHeader():
|
||||
hdrUrl = request.args.get('url', "https://p46-buy.itunes.apple.com/WebObjects/MZBuy.woa/wa/buyProduct")
|
||||
retHdrs = rpc.get_header(hdrUrl)
|
||||
eprint("Got Headers: %s" % retHdrs)
|
||||
kbsync = retHdrs.pop('kbsync')
|
||||
guid = retHdrs.pop('X-Guid')
|
||||
return jsonify({
|
||||
"headers": retHdrs,
|
||||
"kbsync": kbsync,
|
||||
"guid": guid
|
||||
})
|
||||
|
||||
if __name__ == '__main__':
|
||||
app.run(host='0.0.0.0', port=9000)
|
||||
|
||||
session.detach()
|
||||
100
src_win/actions-iTunes-header/workflow_helper/iTunesDownload/get_header_rpc.js
Executable file
100
src_win/actions-iTunes-header/workflow_helper/iTunesDownload/get_header_rpc.js
Executable file
@@ -0,0 +1,100 @@
|
||||
var getHeader = null;
|
||||
function init() {
|
||||
var CFURLCreateWithBytes = new NativeFunction(Module.findExportByName('CoreFoundation','CFURLCreateWithBytes'), 'pointer', ['pointer', 'pointer', 'int64', 'int64', 'int64'])
|
||||
var CFDictionaryGetCount = new NativeFunction(Module.findExportByName('CoreFoundation','CFDictionaryGetCount'), 'int64', ['pointer'])
|
||||
var CFCopyDescription = new NativeFunction(Module.findExportByName('CoreFoundation','CFCopyDescription'), 'pointer', ['pointer'])
|
||||
var CFStringGetCStringPtr = new NativeFunction(Module.findExportByName('CoreFoundation','CFStringGetCStringPtr'), 'pointer', ['pointer', 'uint64'])
|
||||
var CFStringGetCString = new NativeFunction(Module.findExportByName('CoreFoundation','CFStringGetCString'), 'int8', ['pointer', 'pointer', 'int64', 'int64'])
|
||||
var CFStringGetLength = new NativeFunction(Module.findExportByName('CoreFoundation','CFStringGetLength'), 'int64', ['pointer'])
|
||||
var CFDictionaryGetCount = new NativeFunction(Module.findExportByName('CoreFoundation','CFDictionaryGetCount'), 'int64', ['pointer'])
|
||||
var CFDictionaryGetKeysAndValues = new NativeFunction(Module.findExportByName('CoreFoundation','CFDictionaryGetKeysAndValues'), 'void', ['pointer', 'pointer', 'pointer'])
|
||||
var CFDataGetBytePtr = new NativeFunction(Module.findExportByName('CoreFoundation','CFDataGetBytePtr'), 'pointer', ['pointer'])
|
||||
var CFDataGetLength = new NativeFunction(Module.findExportByName('CoreFoundation','CFDataGetLength'), 'uint64', ['pointer'])
|
||||
|
||||
var readCFStr = (cfs) => {
|
||||
var cfslen = CFStringGetLength(cfs)
|
||||
var cfsBuf = Memory.alloc(cfslen + 1)
|
||||
CFStringGetCString(cfs, cfsBuf, cfslen + 1, 134217984)
|
||||
return Memory.readUtf8String(cfsBuf, cfslen)
|
||||
}
|
||||
|
||||
var readCFDict = (cfdict) => {
|
||||
var dictCount = CFDictionaryGetCount(cfdict)
|
||||
var dictKeys = Memory.alloc(dictCount * 8)
|
||||
var dictValues = Memory.alloc(dictCount * 8)
|
||||
CFDictionaryGetKeysAndValues(cfdict, dictKeys, dictValues)
|
||||
var ret = {}
|
||||
for (var i = 0; i < dictCount; i++) {
|
||||
var k = readCFStr(dictKeys.add(8 * i).readPointer())
|
||||
var v = readCFStr(dictValues.add(8 * i).readPointer())
|
||||
ret[k] = v
|
||||
}
|
||||
return ret
|
||||
}
|
||||
|
||||
var readCFData = (cfd) => {
|
||||
var cfdlen = CFDataGetLength(cfd)
|
||||
var cfdbuf = CFDataGetBytePtr(cfd)
|
||||
return cfdbuf.readByteArray(cfdlen)
|
||||
}
|
||||
|
||||
var itunesBase = Process.enumerateModulesSync()[0].base
|
||||
var cfAllocator = itunesBase.add(0x22A8448).readPointer()
|
||||
var kbsyncContext = itunesBase.add(0x22A6BBC).readU32()
|
||||
var prepareAppleHdrWrap = new NativeFunction(itunesBase.add(0x87FFC0), 'pointer',['pointer','pointer','pointer']);
|
||||
var get_cookie_val = new NativeFunction(itunesBase.add(0xBDE500), 'pointer',['pointer']);
|
||||
var get_kbsync = new NativeFunction(itunesBase.add(0x74D210), 'pointer',['uint32', 'uint32', 'pointer']);
|
||||
|
||||
getHeader = function (url) {
|
||||
var GlobalContext = itunesBase.add(0x22A9B18).readPointer()
|
||||
var otpGlobalContext = GlobalContext
|
||||
if (!GlobalContext.isNull()) {
|
||||
otpGlobalContext = GlobalContext.add(62716).readPointer()
|
||||
}
|
||||
|
||||
var otpContext = Memory.alloc(128)
|
||||
otpContext.writePointer(otpGlobalContext)
|
||||
otpContext.add(8).writeU64(0)
|
||||
otpContext.add(16).writeU64(0)
|
||||
otpContext.add(24).writeU16(1)
|
||||
otpContext.add(26).writeU8(0)
|
||||
otpContext.add(27).writeU8(1) // include X-Guid
|
||||
otpContext.add(28).writeU8(1) // include ADIV1 Hdrs
|
||||
otpContext.add(32).writeU32(0)
|
||||
otpContext.add(36).writeU16(0)
|
||||
otpContext.add(40).writeU32(0)
|
||||
otpContext.add(48).writeU64(0)
|
||||
otpContext.add(64).writeU64(0)
|
||||
otpContext.add(72).writeU64(0)
|
||||
otpContext.add(84).writeU64(0)
|
||||
otpContext.add(112).writeU8(1)
|
||||
|
||||
var urlBuf = Memory.allocUtf8String(url)
|
||||
var urlData = CFURLCreateWithBytes(cfAllocator, urlBuf, url.length, 0x8000100, 0)
|
||||
|
||||
var kbsync = get_kbsync(kbsyncContext, 1, otpGlobalContext)
|
||||
|
||||
var cookieCFStr = get_cookie_val(urlData)
|
||||
var hdrDict = prepareAppleHdrWrap(NULL, urlData, otpContext)
|
||||
//hdrdesc = CFCopyDescription(hdrDict)
|
||||
//console.log(readCFStr(hdrdesc))
|
||||
|
||||
var cookieStr = readCFStr(cookieCFStr)
|
||||
var hdrOutput = readCFDict(hdrDict)
|
||||
hdrOutput['Cookie'] = cookieStr
|
||||
|
||||
var kbSyncData = readCFData(kbsync)
|
||||
hdrOutput['kbsync'] = [...new Uint8Array(kbSyncData)].map(x => x.toString(16).padStart(2, '0')).join('');
|
||||
|
||||
return hdrOutput
|
||||
};
|
||||
}
|
||||
|
||||
rpc.exports = {
|
||||
getHeader: (url) => {
|
||||
if (!getHeader) {
|
||||
init()
|
||||
}
|
||||
return getHeader(url);
|
||||
},
|
||||
};
|
||||
Reference in New Issue
Block a user