Files
dragonpilot/selfdrive/registration.py

104 lines
3.2 KiB
Python
Raw Normal View History

2019-06-06 04:38:45 +00:00
import os
2016-11-29 18:34:21 -08:00
import json
2019-10-09 18:43:53 +00:00
import binascii
2016-11-29 18:34:21 -08:00
import subprocess
2019-10-09 18:43:53 +00:00
import itertools
2016-11-29 18:34:21 -08:00
2019-06-06 04:38:45 +00:00
from datetime import datetime, timedelta
2016-11-29 18:34:21 -08:00
from selfdrive.swaglog import cloudlog
2019-07-22 19:17:47 +00:00
from selfdrive.version import version, terms_version, training_version, get_git_commit, get_git_branch, get_git_remote
2016-11-29 18:34:21 -08:00
from common.api import api_get
2017-05-11 12:41:17 -07:00
from common.params import Params
2019-06-06 04:38:45 +00:00
2016-11-29 18:34:21 -08:00
def get_imei():
2019-10-09 18:43:53 +00:00
ret = subprocess.check_output(["getprop", "oem.device.imeicache"], encoding='utf8').strip() # pylint: disable=unexpected-keyword-arg
2018-10-21 15:00:31 -07:00
if ret == "":
ret = "000000000000000"
return ret
2016-11-29 18:34:21 -08:00
2019-06-06 04:38:45 +00:00
2016-11-29 18:34:21 -08:00
def get_serial():
2019-10-09 18:43:53 +00:00
return subprocess.check_output(["getprop", "ro.serialno"], encoding='utf8').strip() # pylint: disable=unexpected-keyword-arg
2016-11-29 18:34:21 -08:00
2017-05-11 12:41:17 -07:00
2019-06-06 04:38:45 +00:00
# TODO: move this to a library
def parse_service_call(call):
2019-10-09 18:43:53 +00:00
ret = subprocess.check_output(call, encoding='utf8').strip() # pylint: disable=unexpected-keyword-arg
2019-06-06 04:38:45 +00:00
if 'Parcel' not in ret:
return None
2019-10-09 18:43:53 +00:00
2019-06-06 04:38:45 +00:00
try:
2019-10-09 18:43:53 +00:00
r = b""
for line in ret.split("\n")[1:]: # Skip 'Parcel('
line_hex = line[14:49].replace(' ', '')
r += binascii.unhexlify(line_hex)
r = r[8:] # Cut off length field
r = r.decode('utf_16_be')
# All pairs of two characters seem to be swapped. Not sure why
result = ""
for a, b, in itertools.zip_longest(r[::2], r[1::2], fillvalue='\x00'):
result += b + a
result = result.replace('\x00', '')
return result
2019-06-06 04:38:45 +00:00
except Exception:
return None
def get_subscriber_info():
ret = parse_service_call(["service", "call", "iphonesubinfo", "7"])
if ret is None or len(ret) < 8:
return ""
2019-10-09 18:43:53 +00:00
return ret
2017-05-11 12:41:17 -07:00
2017-12-23 17:15:27 -08:00
2016-11-29 18:34:21 -08:00
def register():
2017-05-11 12:41:17 -07:00
params = Params()
2017-12-23 17:15:27 -08:00
params.put("Version", version)
2019-07-22 19:17:47 +00:00
params.put("TermsVersion", terms_version)
2018-04-28 09:44:39 +00:00
params.put("TrainingVersion", training_version)
2017-12-23 17:15:27 -08:00
params.put("GitCommit", get_git_commit())
params.put("GitBranch", get_git_branch())
params.put("GitRemote", get_git_remote())
2019-06-06 04:38:45 +00:00
params.put("SubscriberInfo", get_subscriber_info())
2019-08-13 01:36:45 +00:00
# make key readable by app users (ai.comma.plus.offroad)
os.chmod('/persist/comma/', 0o755)
os.chmod('/persist/comma/id_rsa', 0o744)
2019-10-09 18:43:53 +00:00
dongle_id, access_token = params.get("DongleId", encoding='utf8'), params.get("AccessToken", encoding='utf8')
2019-06-06 04:38:45 +00:00
public_key = open("/persist/comma/id_rsa.pub").read()
# create registration token
# in the future, this key will make JWTs directly
private_key = open("/persist/comma/id_rsa").read()
2019-06-28 21:11:30 +00:00
# late import
import jwt
2019-06-06 04:38:45 +00:00
register_token = jwt.encode({'register':True, 'exp': datetime.utcnow() + timedelta(hours=1)}, private_key, algorithm='RS256')
2017-12-23 17:15:27 -08:00
try:
2019-06-06 04:38:45 +00:00
cloudlog.info("getting pilotauth")
resp = api_get("v2/pilotauth/", method='POST', timeout=15,
imei=get_imei(), serial=get_serial(), public_key=public_key, register_token=register_token)
dongleauth = json.loads(resp.text)
2019-10-09 18:43:53 +00:00
dongle_id, access_token = dongleauth["dongle_id"], dongleauth["access_token"]
2019-06-06 04:38:45 +00:00
params.put("DongleId", dongle_id)
params.put("AccessToken", access_token)
2017-05-11 12:41:17 -07:00
return dongle_id, access_token
2016-11-29 18:34:21 -08:00
except Exception:
cloudlog.exception("failed to authenticate")
2019-06-06 04:38:45 +00:00
if dongle_id is not None and access_token is not None:
return dongle_id, access_token
else:
return None
2016-11-29 18:34:21 -08:00
if __name__ == "__main__":
2018-07-12 18:52:06 -07:00
print(api_get("").text)
print(register())