mazda_webservice.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. from dataclasses import dataclass
  2. from requests_oauthlib import OAuth2Session
  3. from oauthlib.oauth2.rfc6749.errors import OAuth2Error
  4. from flask import Flask, redirect, request, session
  5. from datetime import datetime
  6. import json
  7. import os
  8. import mazda_upload
  9. @dataclass
  10. class Token:
  11. access_token: str
  12. token_type: str
  13. refresh_token: str
  14. expires_in: int
  15. sub: str
  16. iss: str
  17. iat: int
  18. defaultDomain: str
  19. userGuid: str
  20. organisations: list[str]
  21. jti: str
  22. scope: list[str]
  23. expires_at: float
  24. app = Flask(__name__)
  25. cfg: mazda_upload.MazdaConfig = mazda_upload.cfg
  26. base_dir = '/home/robert/projekte/python/mazda/'
  27. def token_save(token):
  28. session['oauth_token'] = token
  29. with open(base_dir + 'token.json', 'w') as fwh:
  30. json.dump(token, fwh, indent=2)
  31. def token_load() -> Token:
  32. try:
  33. with open(base_dir + 'token.json', 'r') as frh:
  34. return json.load(frh)
  35. except FileNotFoundError:
  36. return None
  37. def get_token() -> Token:
  38. if session.get('oauth_token') is None:
  39. session['oauth_token'] = token_load()
  40. if session['oauth_token'] is not None and session['oauth_token']['expires_at'] < datetime.now().timestamp():
  41. session['oauth_token'] = None
  42. return session['oauth_token']
  43. @app.route("/")
  44. def demo():
  45. # if token := get_token() is not None:
  46. oauth = OAuth2Session(cfg.client_id, token=get_token())
  47. if oauth.authorized:
  48. return redirect('/profile')
  49. redirect_uri = request.base_url + 'callback'
  50. print(redirect_uri)
  51. oauth = OAuth2Session(cfg.client_id, redirect_uri=redirect_uri)
  52. authorization_url, state = oauth.authorization_url(cfg.domain + cfg.auth_url)
  53. session['oauth_state'] = state
  54. return redirect(authorization_url)
  55. @app.route("/callback", methods=["GET"])
  56. def callback():
  57. state = session.get('oauth_state')
  58. if state is None:
  59. return redirect('/')
  60. print(state)
  61. redirect_uri = request.base_url
  62. print(redirect_uri)
  63. oauth = OAuth2Session(cfg.client_id, state=state, redirect_uri=redirect_uri)
  64. try:
  65. token = oauth.fetch_token(cfg.domain + cfg.token_url, client_secret=cfg.client_secret, authorization_response=request.url)
  66. token_save(token)
  67. session['oauth_token'] = token
  68. return redirect('/profile')
  69. except OAuth2Error as e:
  70. print(e)
  71. return redirect('/')
  72. @app.route("/profile", methods=["GET"])
  73. def profile():
  74. oauth = OAuth2Session(cfg.client_id, token=session.get('oauth_token'))
  75. data = mazda_upload.convert_csv(base_dir + 'Workshop_Order_Report.csv', base_dir + 'mazda_export.json', 2021, 6)
  76. mazda_upload.upload(oauth, data)
  77. return app.response_class(
  78. response=json.dumps(data, indent=2),
  79. mimetype='application/json'
  80. )
  81. if __name__ == "__main__":
  82. # os.environ['OAUTHLIB_INSECURE_TRANSPORT'] = "1"
  83. app.secret_key = os.urandom(24)
  84. app.run(host='0.0.0.0', port='8085', ssl_context=('cert.pem', 'key.pem'), debug=True)