mirror of
https://github.com/Sneed-Group/pypush-plus-plus
synced 2025-01-09 17:33:47 +00:00
yay inspection repl
This commit is contained in:
parent
33c30ffdc5
commit
f30178a70c
2 changed files with 83 additions and 4 deletions
|
@ -164,12 +164,12 @@ def pretty_print_payload(prefix, payload: tuple[int, list[tuple[int, bytes]]]) -
|
||||||
if payload[1][i][0] == 0x4:
|
if payload[1][i][0] == 0x4:
|
||||||
payload[1][i] = (0x4, (int.from_bytes(payload[1][i][1]) + 1).to_bytes(4, "big"))
|
payload[1][i] = (0x4, (int.from_bytes(payload[1][i][1]) + 1).to_bytes(4, "big"))
|
||||||
payload3 = apns._serialize_payload(payload[0], payload[1])
|
payload3 = apns._serialize_payload(payload[0], payload[1])
|
||||||
return (payload1 + payload2 + payload3)
|
#return (payload1 + payload2 + payload3)
|
||||||
else:
|
else:
|
||||||
print(f"{bcolors.OKGREEN}{prefix}{bcolors.ENDC}: {bcolors.OKCYAN}Notification{bcolors.ENDC}")
|
print(f"{bcolors.OKGREEN}{prefix}{bcolors.ENDC}: {bcolors.OKCYAN}Notification{bcolors.ENDC}")
|
||||||
for field in payload[1]:
|
#for field in payload[1]:
|
||||||
print(f"Field ID: {field[0]}")
|
# print(f"Field ID: {field[0]}")
|
||||||
print(f"Field Value: {field[1]}")
|
# print(f"Field Value: {field[1]}")
|
||||||
elif id == 0xb:
|
elif id == 0xb:
|
||||||
print(f"{bcolors.OKGREEN}{prefix}{bcolors.ENDC}: {bcolors.OKCYAN}Notification Ack{bcolors.ENDC} {bcolors.OKBLUE}{_get_field(payload[1], 8).hex()}{bcolors.ENDC}")
|
print(f"{bcolors.OKGREEN}{prefix}{bcolors.ENDC}: {bcolors.OKCYAN}Notification Ack{bcolors.ENDC} {bcolors.OKBLUE}{_get_field(payload[1], 8).hex()}{bcolors.ENDC}")
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -46,6 +46,9 @@ key:str = None
|
||||||
import apns
|
import apns
|
||||||
import printer
|
import printer
|
||||||
|
|
||||||
|
outgoing_list = []
|
||||||
|
incoming_list = []
|
||||||
|
#last_outgoing = b""
|
||||||
|
|
||||||
def proxy(conn1: tlslite.TLSConnection, conn2: tlslite.TLSConnection, prefix: str = ""):
|
def proxy(conn1: tlslite.TLSConnection, conn2: tlslite.TLSConnection, prefix: str = ""):
|
||||||
try:
|
try:
|
||||||
|
@ -64,6 +67,17 @@ def proxy(conn1: tlslite.TLSConnection, conn2: tlslite.TLSConnection, prefix: st
|
||||||
print("OVERRIDE: ", end="")
|
print("OVERRIDE: ", end="")
|
||||||
printer.pretty_print_payload(prefix, apns._deserialize_payload_from_buffer(data))
|
printer.pretty_print_payload(prefix, apns._deserialize_payload_from_buffer(data))
|
||||||
|
|
||||||
|
if "apsd -> APNs" in prefix:
|
||||||
|
global outgoing_list
|
||||||
|
outgoing_list.insert(0, data)
|
||||||
|
if len(outgoing_list) > 100:
|
||||||
|
outgoing_list.pop()
|
||||||
|
elif "APNs -> apsd" in prefix:
|
||||||
|
global incoming_list
|
||||||
|
incoming_list.insert(0, data)
|
||||||
|
if len(incoming_list) > 100:
|
||||||
|
incoming_list.pop()
|
||||||
|
|
||||||
#print(prefix, data)
|
#print(prefix, data)
|
||||||
# Write the data to the second connection
|
# Write the data to the second connection
|
||||||
conn2.write(data)
|
conn2.write(data)
|
||||||
|
@ -80,6 +94,69 @@ def proxy(conn1: tlslite.TLSConnection, conn2: tlslite.TLSConnection, prefix: st
|
||||||
conn1.close()
|
conn1.close()
|
||||||
conn2.close()
|
conn2.close()
|
||||||
|
|
||||||
|
def repl(conn: tlslite.TLSConnection):
|
||||||
|
while True:
|
||||||
|
i = input(">>> ")
|
||||||
|
if "ro" in i:
|
||||||
|
print("Replaying last outgoing packet")
|
||||||
|
try:
|
||||||
|
index = int(i[2:])
|
||||||
|
except ValueError:
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
if index >= len(outgoing_list):
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
print("Replaying outgoing packet")
|
||||||
|
conn.write(outgoing_list[index])
|
||||||
|
# Print the packet
|
||||||
|
printer.pretty_print_payload("[REPLAY] apsd -> APNs", apns._deserialize_payload_from_buffer(outgoing_list[index]))
|
||||||
|
|
||||||
|
elif "io" in i:
|
||||||
|
try:
|
||||||
|
index = int(i[2:])
|
||||||
|
except ValueError:
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
if index >= len(outgoing_list):
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
print("Inspecting outgoing packet")
|
||||||
|
payload = apns._deserialize_payload_from_buffer(outgoing_list[index])
|
||||||
|
print(f"ID: {payload[0]}")
|
||||||
|
for i in range(len(payload[1])):
|
||||||
|
print(f" {payload[1][i][0]}: {payload[1][i][1]}")
|
||||||
|
|
||||||
|
elif "ri" in i:
|
||||||
|
print("Replaying last outgoing packet")
|
||||||
|
try:
|
||||||
|
index = int(i[2:])
|
||||||
|
except ValueError:
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
if index >= len(incoming_list):
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
print("Replaying outgoing packet")
|
||||||
|
conn.write(incoming_list[index])
|
||||||
|
# Print the packet
|
||||||
|
printer.pretty_print_payload("[REPLAY] APNs -> apsd", apns._deserialize_payload_from_buffer(incoming_list[index]))
|
||||||
|
|
||||||
|
elif "ii" in i:
|
||||||
|
try:
|
||||||
|
index = int(i[2:])
|
||||||
|
except ValueError:
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
if index >= len(incoming_list):
|
||||||
|
print("Invalid index")
|
||||||
|
continue
|
||||||
|
print("Inspecting incoming packet")
|
||||||
|
payload = apns._deserialize_payload_from_buffer(incoming_list[index])
|
||||||
|
print(f"ID: {payload[0]}")
|
||||||
|
for i in range(len(payload[1])):
|
||||||
|
print(f" {payload[1][i][0]}: {payload[1][i][1]}")
|
||||||
|
|
||||||
def handle(conn: socket.socket):
|
def handle(conn: socket.socket):
|
||||||
# Wrap the socket in TLS
|
# Wrap the socket in TLS
|
||||||
s_conn = tlslite.TLSConnection(conn)
|
s_conn = tlslite.TLSConnection(conn)
|
||||||
|
@ -97,6 +174,8 @@ def handle(conn: socket.socket):
|
||||||
apns = connect()
|
apns = connect()
|
||||||
print("Connected to APNs")
|
print("Connected to APNs")
|
||||||
|
|
||||||
|
threading.Thread(target=repl, args=(s_conn,)).start()
|
||||||
|
|
||||||
global global_cnt
|
global global_cnt
|
||||||
global_cnt += 1
|
global_cnt += 1
|
||||||
# Proxy data between the connections
|
# Proxy data between the connections
|
||||||
|
|
Loading…
Reference in a new issue