mirror of
https://github.com/Sneed-Group/pypush-plus-plus
synced 2025-01-09 17:33:47 +00:00
Add ability for fake users.
Hack, but still ***should*** work
This commit is contained in:
parent
f44f2f32ac
commit
644930058a
3 changed files with 160 additions and 54 deletions
|
@ -145,33 +145,75 @@ def register(
|
||||||
"validation-data": b64decode(validation_data),
|
"validation-data": b64decode(validation_data),
|
||||||
}
|
}
|
||||||
|
|
||||||
body = plistlib.dumps(body)
|
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
"x-protocol-version": PROTOCOL_VERSION,
|
"x-protocol-version": PROTOCOL_VERSION,
|
||||||
"x-auth-user-id-0": user_id,
|
"x-auth-user-id-0": user_id,
|
||||||
}
|
}
|
||||||
add_auth_signature(headers, body, "id-register", auth_key, push_key, push_token, 0)
|
add_auth_signature(headers, bytes("""MIIC0DCCAbgCAQAwSDELMAkGA1UEBhMCVVMxDzANBgNVBAgMBkFsYXNrYTETMBEG
|
||||||
|
A1UEBwwKTm9ydGggUG9sZTETMBEGA1UECgwKQXBwbGUgSW5jLjCCASIwDQYJKoZI
|
||||||
|
hvcNAQEBBQADggEPADCCAQoCggEBANENQCvM8n5F9OPdH4GlB/EeQ2bQ7KFFEuL9
|
||||||
|
NL8DXlm9YRiyGza7KB7BR/P8cjIVuRHIehEcHOjXRhgSqey73JGFLCNZO9TYPJIu
|
||||||
|
OSMV/O99u2Si/9l1rZIlkWUnAQ1UtOQ94xsUp3Kh2aK3CrJCitHp1VwjGm27dojw
|
||||||
|
NwaGJq0f0Qi9j6p21pEO41VY7Q1W5wFFa5D2pjXAK4E/AnccI2KGnx+sGzniVMCr
|
||||||
|
RJG+A89VQYGN5H0YMCfu5T/IUDHTkOuJQWrDgW4D/NLy4ybXO80yQ9Vogk94LVdl
|
||||||
|
xPHkMHOCq1Va2KTMKLtnol8BKhzMEdJMHvMt2qRZ9HBdzFUwplUCAwEAAaBDMEEG
|
||||||
|
CSqGSIb3DQEJDjE0MDIwDgYDVR0PAQH/BAQDAgWgMCAGA1UdJQEB/wQWMBQGCCsG
|
||||||
|
AQUFBwMBBggrBgEFBQcDAjANBgkqhkiG9w0BAQsFAAOCAQEAS4wigV8i82EGChek
|
||||||
|
9MKrjjEQrw0ca7OC3PNo3UG+XYdgly7h1Tv8jEjppsPGbnpOOEV0lX7Xncc8GRvG
|
||||||
|
893/473Zekyzjo48KGnvTuTFARfn58Nh5LrrFtrOqEjoOjpSFuVuHDJI1MjQdMeX
|
||||||
|
3mzc1xAaH4nYwFxe5VhDDPNiz0OJ5YlrOmxLz25bGtPpPGQp+jKqYvaQolsuKjUE
|
||||||
|
x9oPpOGn/b3whTZrIz1KwN59n11l0AB2UUJA8jN7Rmk+w8htJYWobxAa/JwBSFzv
|
||||||
|
hj+/A2TVeYj/+xkdCy780HvZgRTW2+7nLytW6mvAowZzYTHGjJudzX9jivRUZNG9
|
||||||
|
dFwNRg==""","utf8"), "id-register", auth_key, push_key, push_token, 0)
|
||||||
|
|
||||||
r = requests.post(
|
r = requests.post(
|
||||||
"https://identity.ess.apple.com/WebObjects/TDIdentityService.woa/wa/register",
|
"https://identity.ess.apple.com/WebObjects/TDIdentityService.woa/wa/register",
|
||||||
headers=headers,
|
data=bytes("""MIIC0DCCAbgCAQAwSDELMAkGA1UEBhMCVVMxDzANBgNVBAgMBkFsYXNrYTETMBEG
|
||||||
data=body,
|
A1UEBwwKTm9ydGggUG9sZTETMBEGA1UECgwKQXBwbGUgSW5jLjCCASIwDQYJKoZI
|
||||||
|
hvcNAQEBBQADggEPADCCAQoCggEBANENQCvM8n5F9OPdH4GlB/EeQ2bQ7KFFEuL9
|
||||||
|
NL8DXlm9YRiyGza7KB7BR/P8cjIVuRHIehEcHOjXRhgSqey73JGFLCNZO9TYPJIu
|
||||||
|
OSMV/O99u2Si/9l1rZIlkWUnAQ1UtOQ94xsUp3Kh2aK3CrJCitHp1VwjGm27dojw
|
||||||
|
NwaGJq0f0Qi9j6p21pEO41VY7Q1W5wFFa5D2pjXAK4E/AnccI2KGnx+sGzniVMCr
|
||||||
|
RJG+A89VQYGN5H0YMCfu5T/IUDHTkOuJQWrDgW4D/NLy4ybXO80yQ9Vogk94LVdl
|
||||||
|
xPHkMHOCq1Va2KTMKLtnol8BKhzMEdJMHvMt2qRZ9HBdzFUwplUCAwEAAaBDMEEG
|
||||||
|
CSqGSIb3DQEJDjE0MDIwDgYDVR0PAQH/BAQDAgWgMCAGA1UdJQEB/wQWMBQGCCsG
|
||||||
|
AQUFBwMBBggrBgEFBQcDAjANBgkqhkiG9w0BAQsFAAOCAQEAS4wigV8i82EGChek
|
||||||
|
9MKrjjEQrw0ca7OC3PNo3UG+XYdgly7h1Tv8jEjppsPGbnpOOEV0lX7Xncc8GRvG
|
||||||
|
893/473Zekyzjo48KGnvTuTFARfn58Nh5LrrFtrOqEjoOjpSFuVuHDJI1MjQdMeX
|
||||||
|
3mzc1xAaH4nYwFxe5VhDDPNiz0OJ5YlrOmxLz25bGtPpPGQp+jKqYvaQolsuKjUE
|
||||||
|
x9oPpOGn/b3whTZrIz1KwN59n11l0AB2UUJA8jN7Rmk+w8htJYWobxAa/JwBSFzv
|
||||||
|
hj+/A2TVeYj/+xkdCy780HvZgRTW2+7nLytW6mvAowZzYTHGjJudzX9jivRUZNG9
|
||||||
|
dFwNRg==""","utf8"),
|
||||||
verify=False,
|
verify=False,
|
||||||
)
|
)
|
||||||
r = plistlib.loads(r.content)
|
r = plistlib.loads(r.content)
|
||||||
#print(f'Response code: {r["status"]}')
|
#print(f'Response code: {r["status"]}')
|
||||||
logger.debug(f"Recieved response to IDS registration: {r}")
|
logger.debug(f"Recieved response to IDS registration: {r}")
|
||||||
if "status" in r and r["status"] == 6004:
|
#if "status" in r and r["status"] == 6004:
|
||||||
raise Exception("Validation data expired!")
|
#raise Exception("Validation data expired!")
|
||||||
# TODO: Do validation of nested statuses
|
# TODO: Do validation of nested statuses
|
||||||
if "status" in r and r["status"] != 0:
|
#if "status" in r and r["status"] != 0:
|
||||||
raise Exception(f"Failed to register: {r}")
|
#raise Exception(f"Failed to register: {r}")
|
||||||
if not "services" in r:
|
#if not "services" in r:
|
||||||
raise Exception(f"No services in response: {r}")
|
#raise Exception(f"No services in response: {r}")
|
||||||
if not "users" in r["services"][0]:
|
#if not "users" in r["services"][0]:
|
||||||
raise Exception(f"No users in response: {r}")
|
#raise Exception(f"No users in response: {r}")
|
||||||
if not "cert" in r["services"][0]["users"][0]:
|
#if not "cert" in r["services"][0]["users"][0]:
|
||||||
raise Exception(f"No cert in response: {r}")
|
#raise Exception(f"No cert in response: {r}")
|
||||||
|
|
||||||
return armour_cert(r["services"][0]["users"][0]["cert"])
|
return armour_cert("".join(r["message"][0]).join("no@nope.nicetry").join("""MIIC0DCCAbgCAQAwSDELMAkGA1UEBhMCVVMxDzANBgNVBAgMBkFsYXNrYTETMBEG
|
||||||
|
A1UEBwwKTm9ydGggUG9sZTETMBEGA1UECgwKQXBwbGUgSW5jLjCCASIwDQYJKoZI
|
||||||
|
hvcNAQEBBQADggEPADCCAQoCggEBANENQCvM8n5F9OPdH4GlB/EeQ2bQ7KFFEuL9
|
||||||
|
NL8DXlm9YRiyGza7KB7BR/P8cjIVuRHIehEcHOjXRhgSqey73JGFLCNZO9TYPJIu
|
||||||
|
OSMV/O99u2Si/9l1rZIlkWUnAQ1UtOQ94xsUp3Kh2aK3CrJCitHp1VwjGm27dojw
|
||||||
|
NwaGJq0f0Qi9j6p21pEO41VY7Q1W5wFFa5D2pjXAK4E/AnccI2KGnx+sGzniVMCr
|
||||||
|
RJG+A89VQYGN5H0YMCfu5T/IUDHTkOuJQWrDgW4D/NLy4ybXO80yQ9Vogk94LVdl
|
||||||
|
xPHkMHOCq1Va2KTMKLtnol8BKhzMEdJMHvMt2qRZ9HBdzFUwplUCAwEAAaBDMEEG
|
||||||
|
CSqGSIb3DQEJDjE0MDIwDgYDVR0PAQH/BAQDAgWgMCAGA1UdJQEB/wQWMBQGCCsG
|
||||||
|
AQUFBwMBBggrBgEFBQcDAjANBgkqhkiG9w0BAQsFAAOCAQEAS4wigV8i82EGChek
|
||||||
|
9MKrjjEQrw0ca7OC3PNo3UG+XYdgly7h1Tv8jEjppsPGbnpOOEV0lX7Xncc8GRvG
|
||||||
|
893/473Zekyzjo48KGnvTuTFARfn58Nh5LrrFtrOqEjoOjpSFuVuHDJI1MjQdMeX
|
||||||
|
3mzc1xAaH4nYwFxe5VhDDPNiz0OJ5YlrOmxLz25bGtPpPGQp+jKqYvaQolsuKjUE
|
||||||
|
x9oPpOGn/b3whTZrIz1KwN59n11l0AB2UUJA8jN7Rmk+w8htJYWobxAa/JwBSFzv
|
||||||
|
hj+/A2TVeYj/+xkdCy780HvZgRTW2+7nLytW6mvAowZzYTHGjJudzX9jivRUZNG9
|
||||||
|
dFwNRg=="""))
|
||||||
|
|
122
ids/profile.py
122
ids/profile.py
|
@ -31,8 +31,8 @@ def _auth_token_request(username: str, password: str) -> any:
|
||||||
|
|
||||||
r = requests.post(
|
r = requests.post(
|
||||||
# TODO: Figure out which URL bag we can get this from
|
# TODO: Figure out which URL bag we can get this from
|
||||||
"https://profile.ess.apple.com/WebObjects/VCProfileService.woa/wa/authenticateUser",
|
#"https://profile.ess.apple.com/WebObjects/VCProfileService.woa/wa/authenticateUser",
|
||||||
#"https://setup.icloud.com/setup/prefpane/loginDelegates",
|
"https://setup.icloud.com/setup/prefpane/loginDelegates",
|
||||||
#auth=(username, password),
|
#auth=(username, password),
|
||||||
data=data,
|
data=data,
|
||||||
verify=False,
|
verify=False,
|
||||||
|
@ -49,20 +49,43 @@ def get_auth_token(
|
||||||
username: str, password: str, factor_gen: callable = None
|
username: str, password: str, factor_gen: callable = None
|
||||||
) -> tuple[str, str]:
|
) -> tuple[str, str]:
|
||||||
from sys import platform
|
from sys import platform
|
||||||
|
|
||||||
result = _auth_token_request(username, password)
|
result = _auth_token_request(username, password)
|
||||||
if result["status"] != 0:
|
|
||||||
if result["status"] == 5000:
|
|
||||||
if factor_gen is None:
|
|
||||||
password = password + input("Enter 2FA code: ")
|
|
||||||
else:
|
|
||||||
password = password + factor_gen()
|
|
||||||
result = _auth_token_request(username, password)
|
|
||||||
if result["status"] != 0:
|
|
||||||
raise Exception(f"Error: {result}")
|
|
||||||
|
|
||||||
auth_token = result["auth-token"]
|
|
||||||
realm_user_id = result["profile-id"]
|
auth_token = """
|
||||||
|
MIIEpAIBAAKCAQEAg9G5I12Rz4+MjZweEC5ErDEAT7pSZTT2pjB1lij/VCpErkWG
|
||||||
|
joCNK10yxVApSax41JKki33QwZSoIuOb7FcfV92fmDXQLwiuGm//YjDwc9X/08+W
|
||||||
|
MxCA934zlXFZx1Z0jUS6jCNRu5kvkQMc1kD3h/DuxIATf1JfShcdpodYor1JCxOZ
|
||||||
|
5VfTsmoDG88NuDQb/KoP46cRcSJPeKqdXHTVKmilJ0G/pCwHNJP7EibXT3nH4i5L
|
||||||
|
t/RLQsS0sh8OQYA/gRbJ0x4dVjYy+HbIaZNrJAh5cVmENLw3a+ZmLPb4EXz/YVsY
|
||||||
|
6gZn3U30HOmuYn+KkOCcjp/iqqDyNj173D1T+wIDAQABAoIBAQCAOZPEKRLbOqHY
|
||||||
|
ZlKAHuHCNfA9ndrkg/6hbmYTaVHlhzBD7XGUUMwBsKjgcreW6OSosvTIk9xrUbW0
|
||||||
|
Kn/UCHN+vyCtqTsXZXQmV2evFjfwFezDFxzeE2HAXczDw/03AIxjlsV36CtrNvmk
|
||||||
|
L8jvSUb/v4gjMQrGQVRb99xpzyKTOfPDlPxiSdTSMqJ4VPWSL0xya97xjh8t0wYx
|
||||||
|
/vLGcYPhM8be0LHdTkyPG6N0A/bATn8yGnt/w7FKMHAFR975Uv/seZv2sbxNvcQG
|
||||||
|
H6j70qAcY8E1AVkuzQbxAR0i5/We05XyhgiSEUqTJeBaCBGOKXIexyNnmdtVfT0P
|
||||||
|
YJysliQRAoGBALwxEXEiMfo9VsBYH945XJvTLn2/eCSrf9v3R7by+2rUSkJc/MGB
|
||||||
|
4+CDeoWaHc9EMvb7FgAgTVPccRypZo5FQ98U/widNBzGO+P5b3g44H7F4U1axL5e
|
||||||
|
19a6fN7n9f0z534qdydJLpoqmTe6zFK4Meuj6Gs7ETS3/nVwCCygOfnvAoGBALNQ
|
||||||
|
0lEEuR/R76ew1kQ+c2cxkarvvgA3V4jTGdf1Pjsb6q38SFjbNilSCAMxHt+pRdaU
|
||||||
|
F4q76sdx4oDXMRDd0CgsMGSp89pJeFZ7XQ9Mfz/uHaw3uXF7Pbxc7AWFy+ogAbNG
|
||||||
|
BYbTokmzYPqL5Ga3KlqaFKe2wXtw7P4DO198MEK1AoGBAIzO+gn4WASwmJRaW53e
|
||||||
|
tZgyLvsPpElruMNRBmuw6sVICjgVc1kmYua9+ZK1edB3atq5jACUKsewjUGwzndt
|
||||||
|
BBeKkjhTx4YwHOe63tjJVdAFJ0rFu6flNwIHjx8J2FiX2YHhLD5M132qmfHE5tSN
|
||||||
|
1WxGu8Rf8cPMV6xvIu6hBEApAoGAVffdnTIifvrrZv4E+9rlAQhmygj+kqP1t4dd
|
||||||
|
0IenOjd8H8Xf+Zm/Mbg+Vylpn9lLvkBpuP225b/X0+VXhLqTXW8yFFDWtESdCPlD
|
||||||
|
+F24dDH4z+Q3aAyp4HC8RzmKNcj6h7R+WdGE8MirKfN/oS8XgzBzzqRzxnaxaGas
|
||||||
|
RG8JxDECgYAbJcqfsZBzSTuW25jHSmLKvjQNfBE7eywbldG8y8EoT6LWqv+zQbj0
|
||||||
|
cGcS3ectMA6UVYSDfyaw6MOXv3YC5QPIMXFJsOYLwkpSM8J0cT4MdSXx1WHNSguO
|
||||||
|
eS1AVbX69JYcGEOIWMkdxXm0bxRNXq2Xaz1TlA3xOc6pYUKHtkFTcQ=="""
|
||||||
|
|
||||||
|
realm_user_id = """MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAg9G5I12Rz4+MjZweEC5E
|
||||||
|
rDEAT7pSZTT2pjB1lij/VCpErkWGjoCNK10yxVApSax41JKki33QwZSoIuOb7Fcf
|
||||||
|
V92fmDXQLwiuGm//YjDwc9X/08+WMxCA934zlXFZx1Z0jUS6jCNRu5kvkQMc1kD3
|
||||||
|
h/DuxIATf1JfShcdpodYor1JCxOZ5VfTsmoDG88NuDQb/KoP46cRcSJPeKqdXHTV
|
||||||
|
KmilJ0G/pCwHNJP7EibXT3nH4i5Lt/RLQsS0sh8OQYA/gRbJ0x4dVjYy+HbIaZNr
|
||||||
|
JAh5cVmENLw3a+ZmLPb4EXz/YVsY6gZn3U30HOmuYn+KkOCcjp/iqqDyNj173D1T
|
||||||
|
+wIDAQAB"""
|
||||||
# else:
|
# else:
|
||||||
# logger.debug("Using old-style authentication")
|
# logger.debug("Using old-style authentication")
|
||||||
# # Make the request without the 2FA code to make the prompt appear
|
# # Make the request without the 2FA code to make the prompt appear
|
||||||
|
@ -122,17 +145,26 @@ def get_auth_cert(user_id, token) -> KeyPair:
|
||||||
|
|
||||||
body = plistlib.dumps(body)
|
body = plistlib.dumps(body)
|
||||||
|
|
||||||
r = requests.post(
|
r = {"cert": """-----BEGIN CERTIFICATE REQUEST-----
|
||||||
bags.ids_bag()[BAG_KEY],
|
MIIC0DCCAbgCAQAwSDELMAkGA1UEBhMCVVMxDzANBgNVBAgMBkFsYXNrYTETMBEG
|
||||||
#"https://profile.ess.apple.com/WebObjects/VCProfileService.woa/wa/authenticateDS",
|
A1UEBwwKTm9ydGggUG9sZTETMBEGA1UECgwKQXBwbGUgSW5jLjCCASIwDQYJKoZI
|
||||||
data=body,
|
hvcNAQEBBQADggEPADCCAQoCggEBANENQCvM8n5F9OPdH4GlB/EeQ2bQ7KFFEuL9
|
||||||
headers={"x-protocol-version": "1630"},
|
NL8DXlm9YRiyGza7KB7BR/P8cjIVuRHIehEcHOjXRhgSqey73JGFLCNZO9TYPJIu
|
||||||
verify=False,
|
OSMV/O99u2Si/9l1rZIlkWUnAQ1UtOQ94xsUp3Kh2aK3CrJCitHp1VwjGm27dojw
|
||||||
)
|
NwaGJq0f0Qi9j6p21pEO41VY7Q1W5wFFa5D2pjXAK4E/AnccI2KGnx+sGzniVMCr
|
||||||
r = plistlib.loads(r.content)
|
RJG+A89VQYGN5H0YMCfu5T/IUDHTkOuJQWrDgW4D/NLy4ybXO80yQ9Vogk94LVdl
|
||||||
if r["status"] != 0:
|
xPHkMHOCq1Va2KTMKLtnol8BKhzMEdJMHvMt2qRZ9HBdzFUwplUCAwEAAaBDMEEG
|
||||||
raise (Exception(f"Failed to get auth cert: {r}"))
|
CSqGSIb3DQEJDjE0MDIwDgYDVR0PAQH/BAQDAgWgMCAGA1UdJQEB/wQWMBQGCCsG
|
||||||
cert = x509.load_der_x509_certificate(r["cert"])
|
AQUFBwMBBggrBgEFBQcDAjANBgkqhkiG9w0BAQsFAAOCAQEAS4wigV8i82EGChek
|
||||||
|
9MKrjjEQrw0ca7OC3PNo3UG+XYdgly7h1Tv8jEjppsPGbnpOOEV0lX7Xncc8GRvG
|
||||||
|
893/473Zekyzjo48KGnvTuTFARfn58Nh5LrrFtrOqEjoOjpSFuVuHDJI1MjQdMeX
|
||||||
|
3mzc1xAaH4nYwFxe5VhDDPNiz0OJ5YlrOmxLz25bGtPpPGQp+jKqYvaQolsuKjUE
|
||||||
|
x9oPpOGn/b3whTZrIz1KwN59n11l0AB2UUJA8jN7Rmk+w8htJYWobxAa/JwBSFzv
|
||||||
|
hj+/A2TVeYj/+xkdCy780HvZgRTW2+7nLytW6mvAowZzYTHGjJudzX9jivRUZNG9
|
||||||
|
dFwNRg==
|
||||||
|
-----END CERTIFICATE REQUEST-----"""}
|
||||||
|
|
||||||
|
cert = r["cert"]
|
||||||
logger.debug("Got auth cert from token")
|
logger.debug("Got auth cert from token")
|
||||||
return KeyPair(
|
return KeyPair(
|
||||||
private_key.private_bytes(
|
private_key.private_bytes(
|
||||||
|
@ -142,7 +174,7 @@ def get_auth_cert(user_id, token) -> KeyPair:
|
||||||
)
|
)
|
||||||
.decode("utf-8")
|
.decode("utf-8")
|
||||||
.strip(),
|
.strip(),
|
||||||
cert.public_bytes(serialization.Encoding.PEM).decode("utf-8").strip(),
|
cert.strip(),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -157,16 +189,34 @@ def get_handles(push_token, user_id: str, auth_key: KeyPair, push_key: KeyPair):
|
||||||
headers, None, BAG_KEY, auth_key, push_key, push_token
|
headers, None, BAG_KEY, auth_key, push_key, push_token
|
||||||
)
|
)
|
||||||
|
|
||||||
r = requests.get(
|
#r = requests.get(
|
||||||
bags.ids_bag()[BAG_KEY],
|
#bags.ids_bag()[BAG_KEY],
|
||||||
headers=headers,
|
#headers=headers,
|
||||||
verify=False,
|
#verify=False,
|
||||||
)
|
#)
|
||||||
|
|
||||||
r = plistlib.loads(r.content)
|
#r = plistlib.loads(r[cert])
|
||||||
|
|
||||||
if not "handles" in r:
|
#if not "handles" in r:
|
||||||
raise Exception("No handles in response: " + str(r))
|
#raise Exception("No handles in response: " + str(r))
|
||||||
|
|
||||||
logger.debug(f"User {user_id} has handles {r['handles']}")
|
#logger.debug(f"User {user_id} has handles {r['handles']}")
|
||||||
return [handle["uri"] for handle in r["handles"]]
|
#return [handle["uri"] for handle in r["handles"]]
|
||||||
|
return ["""-----BEGIN CERTIFICATE REQUEST-----
|
||||||
|
MIIC0DCCAbgCAQAwSDELMAkGA1UEBhMCVVMxDzANBgNVBAgMBkFsYXNrYTETMBEG
|
||||||
|
A1UEBwwKTm9ydGggUG9sZTETMBEGA1UECgwKQXBwbGUgSW5jLjCCASIwDQYJKoZI
|
||||||
|
hvcNAQEBBQADggEPADCCAQoCggEBANENQCvM8n5F9OPdH4GlB/EeQ2bQ7KFFEuL9
|
||||||
|
NL8DXlm9YRiyGza7KB7BR/P8cjIVuRHIehEcHOjXRhgSqey73JGFLCNZO9TYPJIu
|
||||||
|
OSMV/O99u2Si/9l1rZIlkWUnAQ1UtOQ94xsUp3Kh2aK3CrJCitHp1VwjGm27dojw
|
||||||
|
NwaGJq0f0Qi9j6p21pEO41VY7Q1W5wFFa5D2pjXAK4E/AnccI2KGnx+sGzniVMCr
|
||||||
|
RJG+A89VQYGN5H0YMCfu5T/IUDHTkOuJQWrDgW4D/NLy4ybXO80yQ9Vogk94LVdl
|
||||||
|
xPHkMHOCq1Va2KTMKLtnol8BKhzMEdJMHvMt2qRZ9HBdzFUwplUCAwEAAaBDMEEG
|
||||||
|
CSqGSIb3DQEJDjE0MDIwDgYDVR0PAQH/BAQDAgWgMCAGA1UdJQEB/wQWMBQGCCsG
|
||||||
|
AQUFBwMBBggrBgEFBQcDAjANBgkqhkiG9w0BAQsFAAOCAQEAS4wigV8i82EGChek
|
||||||
|
9MKrjjEQrw0ca7OC3PNo3UG+XYdgly7h1Tv8jEjppsPGbnpOOEV0lX7Xncc8GRvG
|
||||||
|
893/473Zekyzjo48KGnvTuTFARfn58Nh5LrrFtrOqEjoOjpSFuVuHDJI1MjQdMeX
|
||||||
|
3mzc1xAaH4nYwFxe5VhDDPNiz0OJ5YlrOmxLz25bGtPpPGQp+jKqYvaQolsuKjUE
|
||||||
|
x9oPpOGn/b3whTZrIz1KwN59n11l0AB2UUJA8jN7Rmk+w8htJYWobxAa/JwBSFzv
|
||||||
|
hj+/A2TVeYj/+xkdCy780HvZgRTW2+7nLytW6mvAowZzYTHGjJudzX9jivRUZNG9
|
||||||
|
dFwNRg==
|
||||||
|
-----END CERTIFICATE REQUEST-----"""]
|
||||||
|
|
|
@ -13,8 +13,22 @@ from ._helpers import KeyPair, dearmour
|
||||||
|
|
||||||
# TODO: Move this helper somewhere else
|
# TODO: Move this helper somewhere else
|
||||||
def armour_cert(cert: bytes) -> str:
|
def armour_cert(cert: bytes) -> str:
|
||||||
cert = x509.load_der_x509_certificate(cert)
|
return """MIIC0DCCAbgCAQAwSDELMAkGA1UEBhMCVVMxDzANBgNVBAgMBkFsYXNrYTETMBEG
|
||||||
return cert.public_bytes(serialization.Encoding.PEM).decode("utf-8").strip()
|
A1UEBwwKTm9ydGggUG9sZTETMBEGA1UECgwKQXBwbGUgSW5jLjCCASIwDQYJKoZI
|
||||||
|
hvcNAQEBBQADggEPADCCAQoCggEBANENQCvM8n5F9OPdH4GlB/EeQ2bQ7KFFEuL9
|
||||||
|
NL8DXlm9YRiyGza7KB7BR/P8cjIVuRHIehEcHOjXRhgSqey73JGFLCNZO9TYPJIu
|
||||||
|
OSMV/O99u2Si/9l1rZIlkWUnAQ1UtOQ94xsUp3Kh2aK3CrJCitHp1VwjGm27dojw
|
||||||
|
NwaGJq0f0Qi9j6p21pEO41VY7Q1W5wFFa5D2pjXAK4E/AnccI2KGnx+sGzniVMCr
|
||||||
|
RJG+A89VQYGN5H0YMCfu5T/IUDHTkOuJQWrDgW4D/NLy4ybXO80yQ9Vogk94LVdl
|
||||||
|
xPHkMHOCq1Va2KTMKLtnol8BKhzMEdJMHvMt2qRZ9HBdzFUwplUCAwEAAaBDMEEG
|
||||||
|
CSqGSIb3DQEJDjE0MDIwDgYDVR0PAQH/BAQDAgWgMCAGA1UdJQEB/wQWMBQGCCsG
|
||||||
|
AQUFBwMBBggrBgEFBQcDAjANBgkqhkiG9w0BAQsFAAOCAQEAS4wigV8i82EGChek
|
||||||
|
9MKrjjEQrw0ca7OC3PNo3UG+XYdgly7h1Tv8jEjppsPGbnpOOEV0lX7Xncc8GRvG
|
||||||
|
893/473Zekyzjo48KGnvTuTFARfn58Nh5LrrFtrOqEjoOjpSFuVuHDJI1MjQdMeX
|
||||||
|
3mzc1xAaH4nYwFxe5VhDDPNiz0OJ5YlrOmxLz25bGtPpPGQp+jKqYvaQolsuKjUE
|
||||||
|
x9oPpOGn/b3whTZrIz1KwN59n11l0AB2UUJA8jN7Rmk+w8htJYWobxAa/JwBSFzv
|
||||||
|
hj+/A2TVeYj/+xkdCy780HvZgRTW2+7nLytW6mvAowZzYTHGjJudzX9jivRUZNG9
|
||||||
|
dFwNRg=="""
|
||||||
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in a new issue