From a58d5e3c8982f70c2d4eed78abcb8dae485566c8 Mon Sep 17 00:00:00 2001 From: SpaceSaver Date: Fri, 22 Sep 2023 15:44:25 -0400 Subject: [PATCH 1/4] Add gateway_fetch code --- gateway_fetch.py | 80 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 gateway_fetch.py diff --git a/gateway_fetch.py b/gateway_fetch.py new file mode 100644 index 0000000..17d421c --- /dev/null +++ b/gateway_fetch.py @@ -0,0 +1,80 @@ +import requests, random, plistlib, zipfile +from io import BytesIO + +appleplist = None + +def getMasterList(): + global appleplist + if (appleplist is None): + appleplist = plistlib.loads(requests.get("https://itunes.apple.com/WebObjects/MZStore.woa/wa/com.apple.jingle.appserver.client.MZITunesClientCheck/version?languageCode=en").content) + return appleplist + +def getGatewayMCCMNC(MCCMNC): + gateways = getGatewaysMCCMNC(MCCMNC) + if gateways is None: + return None + return gateways[random.randrange(0, len(gateways))] + +def getGatewaysMCCMNC(MCCMNC): + bundles = getBundlesMCCMNC(MCCMNC) + gateway = None + if bundles is None: + return + for bundle in bundles: + gateway = getGatewayFromBundle(parseBundle(bundle["Bundle"])) + if gateway is not None: + break + return gateway + +def getBundlesMCCMNC(MCCMNC): + appleplist = getMasterList() + bundlelist = [] + if MCCMNC in appleplist["MobileDeviceCarriersByMccMnc"]: + mmo = appleplist["MobileDeviceCarriersByMccMnc"][MCCMNC] + if "BundleName" in mmo: + bundle = getBundleByName(mmo["BundleName"]) + if bundle is not None: + bundlelist.append({"Name": mmo["BundleName"], "Bundle": bundle}) + if "MVNOs" in mmo: + for mv in mmo["MVNOs"]: + if "BundleName" in mv: + bundle = getBundleByName(mv["BundleName"]) + if bundle is not None: + bundlelist.append({"Name": mv["BundleName"], "Bundle": bundle}) + return bundlelist + else: + return None + +def getGatewayFromBundle(bundledict): + applecarrierplist = bundledict + if "PhoneNumberRegistrationGatewayAddress" in applecarrierplist: + regnum = applecarrierplist["PhoneNumberRegistrationGatewayAddress"] + if (type(regnum) == str): + regnum = [regnum] + return regnum + return None + +def parseBundle(bundle): + bundlebytes = BytesIO(bundle) + bundlezip = zipfile.ZipFile(bundlebytes) + carrierpath = [path for path in bundlezip.namelist() if path.startswith("Payload/") and path.endswith("/carrier.plist")][0] + applecarrierplist = plistlib.load(bundlezip.open(carrierpath, "r")) + return applecarrierplist + +def getBundleByName(BundleName): + appleplist = getMasterList() + if BundleName in appleplist["MobileDeviceCarrierBundlesByProductVersion"]: + x = BundleName + greatestver = "0" + for y in appleplist["MobileDeviceCarrierBundlesByProductVersion"][x]: + try: + inty = float(y) + except: + continue + if (inty > float(greatestver)): + greatestver = y + if greatestver != "0": + return requests.get(appleplist["MobileDeviceCarrierBundlesByProductVersion"][x][greatestver]["BundleURL"]).content + else: + return None + return None \ No newline at end of file From 4f7f0ada5150f80a0a3d7e6738961e69839e612e Mon Sep 17 00:00:00 2001 From: SpaceSaver Date: Fri, 22 Sep 2023 15:58:49 -0400 Subject: [PATCH 2/4] Implement in sms_registration.py --- sms_registration.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/sms_registration.py b/sms_registration.py index 0adadae..8071c63 100644 --- a/sms_registration.py +++ b/sms_registration.py @@ -2,6 +2,7 @@ import requests import random import apns import trio +import gateway_fetch from base64 import b64decode, b64encode import urllib3 @@ -14,7 +15,8 @@ GATEWAY = "22223333" def register(push_token: bytes, no_parse = False, gateway = None) -> tuple[str, bytes]: """Forwards a registration request to the phone and returns the phone number, signature for the provided push token""" if gateway is None: - gateway = GATEWAY + mccmnc = requests.get(f"http://{PHONE_IP}:{API_PORT}/info").text + gateway = gateway_fetch.getGatewayMCCMNC(mccmnc) token = push_token.hex().upper() req_id = random.randint(0, 2**32) sms = f"REG-REQ?v=3;t={token};r={req_id};" From cbb3a8f43b28625fedbd45b6a671519c88a34348 Mon Sep 17 00:00:00 2001 From: SpaceSaver Date: Fri, 22 Sep 2023 16:18:22 -0400 Subject: [PATCH 3/4] Add failsafe of using constant --- sms_registration.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/sms_registration.py b/sms_registration.py index 8071c63..bd6c8a3 100644 --- a/sms_registration.py +++ b/sms_registration.py @@ -17,6 +17,9 @@ def register(push_token: bytes, no_parse = False, gateway = None) -> tuple[str, if gateway is None: mccmnc = requests.get(f"http://{PHONE_IP}:{API_PORT}/info").text gateway = gateway_fetch.getGatewayMCCMNC(mccmnc) + if gateway is None: + print("Automatic gateway detection failed, switching to default...") + gateway = GATEWAY token = push_token.hex().upper() req_id = random.randint(0, 2**32) sms = f"REG-REQ?v=3;t={token};r={req_id};" From 7ea5949fcf96d757ace9368785c594c960210ce1 Mon Sep 17 00:00:00 2001 From: SpaceSaver Date: Fri, 22 Sep 2023 16:26:29 -0400 Subject: [PATCH 4/4] Add logging to the gateway detection process --- sms_registration.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/sms_registration.py b/sms_registration.py index bd6c8a3..fdf8ff6 100644 --- a/sms_registration.py +++ b/sms_registration.py @@ -15,8 +15,12 @@ GATEWAY = "22223333" def register(push_token: bytes, no_parse = False, gateway = None) -> tuple[str, bytes]: """Forwards a registration request to the phone and returns the phone number, signature for the provided push token""" if gateway is None: + print("Requesting device MCC+MNC for gateway detection...") mccmnc = requests.get(f"http://{PHONE_IP}:{API_PORT}/info").text + print("MCC+MNC received! " + mccmnc) + print("Determining gateway...") gateway = gateway_fetch.getGatewayMCCMNC(mccmnc) + print("Gateway found! " + gateway) if gateway is None: print("Automatic gateway detection failed, switching to default...") gateway = GATEWAY