mazda_webservice.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  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/mazda/"
  27. def token_save(token):
  28. session["oauth_token"] = token
  29. with open(base_dir + "temp/token.json", "w") as fwh:
  30. json.dump(token, fwh, indent=2)
  31. def token_load() -> Token:
  32. try:
  33. with open(base_dir + "temp/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(
  66. cfg.domain + cfg.token_url, client_secret=cfg.client_secret, authorization_response=request.url
  67. )
  68. token_save(token)
  69. session["oauth_token"] = token
  70. return redirect("/profile")
  71. except OAuth2Error as e:
  72. print(e)
  73. return redirect("/")
  74. @app.route("/profile", methods=["GET"])
  75. def profile():
  76. oauth = OAuth2Session(cfg.client_id, token=session.get("oauth_token"))
  77. data = mazda_upload.convert_csv(
  78. base_dir + "data/Workshop_Order_Report.csv", base_dir + "temp/mazda_export.json", 2021, 6
  79. )
  80. mazda_upload.upload(oauth, data)
  81. return app.response_class(response=json.dumps(data, indent=2), mimetype="application/json")
  82. if __name__ == "__main__":
  83. # os.environ['OAUTHLIB_INSECURE_TRANSPORT'] = "1"
  84. app.secret_key = os.urandom(24)
  85. app.run(host="0.0.0.0", port="8085", ssl_context=("config/cert/cert.pem", "config/cert/key.pem"), debug=True)