pypush/bags.py

64 lines
1.5 KiB
Python
Raw Normal View History

2023-04-12 17:13:47 +00:00
import plistlib
import requests
2023-07-24 13:18:21 +00:00
import logging
logger = logging.getLogger("bags")
2023-04-12 17:13:47 +00:00
2023-05-10 00:01:22 +00:00
def apns_init_bag_old():
2023-04-12 17:13:47 +00:00
r = requests.get("https://init.push.apple.com/bag", verify=False)
if r.status_code != 200:
raise Exception("Failed to get APNs init bag")
# Parse the config as a plist
bag = plistlib.loads(r.content)
2023-07-24 13:18:21 +00:00
logger.debug("Received APNs old-style init bag")
2023-04-12 17:13:47 +00:00
return bag
# This is the same as the above, but the response has a signature which we unwrap
2023-05-10 00:01:22 +00:00
def apns_init_bag():
2023-04-12 17:13:47 +00:00
r = requests.get("http://init-p01st.push.apple.com/bag", verify=False)
if r.status_code != 200:
raise Exception("Failed to get APNs init bag 2")
content = plistlib.loads(r.content)
bag = plistlib.loads(content["bag"])
2023-07-24 13:18:21 +00:00
logger.debug("Received APNs new init bag")
2023-04-12 17:13:47 +00:00
return bag
def ids_bag():
r = requests.get(
"https://init.ess.apple.com/WebObjects/VCInit.woa/wa/getBag?ix=3", verify=False
)
if r.status_code != 200:
raise Exception("Failed to get IDS bag")
# Parse the config as a plist
content = plistlib.loads(r.content)
# Load the inner bag
bag = plistlib.loads(content["bag"])
2023-07-24 13:18:21 +00:00
logger.debug("Recieved IDS bag")
2023-04-12 17:13:47 +00:00
return bag
if __name__ == "__main__":
# config = get_config()
# print(config)
# print(apns_init_bag_2())
2023-05-03 00:53:18 +00:00
# print(apns_init_bag_2() == apns_init_bag())
2023-04-14 12:29:39 +00:00
bag = ids_bag()
for key in bag:
2023-05-03 00:53:18 +00:00
# print(key)
# print(bag[key])
2023-04-14 12:29:39 +00:00
if type(bag[key]) == str:
2023-05-03 00:53:18 +00:00
if "http" in bag[key]:
2023-04-14 12:29:39 +00:00
print(key, bag[key])