pypush/courier.py

33 lines
978 B
Python
Raw Normal View History

2023-04-05 23:52:14 +00:00
import albert
import tlslite
import socket
COURIER_HOST = "10-courier.push.apple.com"
COURIER_PORT = 5223
2023-04-06 16:49:27 +00:00
ALPN = [b"apns-security-v2"]
#ALPN = None
2023-04-05 23:52:14 +00:00
2023-04-06 01:01:07 +00:00
def connect(private_key=None, cert=None):
# If we don't have a private key or certificate, generate one
if private_key is None or cert is None:
2023-04-05 23:52:14 +00:00
private_key, cert = albert.generate_push_cert()
# Connect to the courier server
sock = socket.create_connection((COURIER_HOST, COURIER_PORT))
# Wrap the socket in TLS
sock = tlslite.TLSConnection(sock)
# Parse the certificate and private key
2023-04-06 01:04:41 +00:00
cert_parsed = tlslite.X509CertChain([tlslite.X509().parse(cert)])
private_key_parsed = tlslite.parsePEMKey(private_key, private=True)
2023-04-05 23:52:14 +00:00
# Handshake with the server
2023-04-06 01:04:41 +00:00
sock.handshakeClientCert(cert_parsed, private_key_parsed, alpn=ALPN)
2023-04-05 23:52:14 +00:00
2023-04-06 01:01:07 +00:00
return sock, private_key, cert
2023-04-05 23:52:14 +00:00
if __name__ == "__main__":
sock = connect()
sock.write(b"Hello World!")
print(sock.read())
sock.close()