mazda_webservice.py 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. import json
  2. import os
  3. from dataclasses import dataclass
  4. from flask import Flask, redirect, request, session
  5. from oauthlib.oauth2.rfc6749.errors import OAuth2Error
  6. from requests_oauthlib import OAuth2Session
  7. import mazda_upload
  8. # from datetime import datetime
  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. PROD = True
  26. cfg: mazda_upload.MazdaConfig = mazda_upload.cfg_prod if PROD else mazda_upload.cfg_debug
  27. base_dir = "C:/projekte/mazda/"
  28. def token_save(token):
  29. session["oauth_token"] = token
  30. with open(base_dir + "temp/token.json", "w") as fwh:
  31. json.dump(token, fwh, indent=2)
  32. def token_load() -> Token:
  33. try:
  34. with open(base_dir + "temp/token.json", "r") as frh:
  35. return json.load(frh)
  36. except FileNotFoundError:
  37. return None
  38. def get_token() -> Token:
  39. if session.get("oauth_token") is None:
  40. session["oauth_token"] = token_load()
  41. # if session["oauth_token"] is not None and session["oauth_token"]["expires_at"] < datetime.now().timestamp():
  42. # session["oauth_token"] = None
  43. return session["oauth_token"]
  44. @app.route("/")
  45. def home():
  46. token = get_token()
  47. if token is None:
  48. return redirect("/login")
  49. oauth = OAuth2Session(cfg.client_id, token=token, auto_refresh_kwargs={"grant_type": "refresh_token"})
  50. if oauth.authorized:
  51. token_save(oauth.token)
  52. else:
  53. return redirect("/refresh")
  54. if oauth.authorized:
  55. return redirect("/profile")
  56. return redirect("/login")
  57. @app.route("/refresh")
  58. def refresh():
  59. token = get_token()
  60. oauth = OAuth2Session(cfg.client_id)
  61. new_token = oauth.refresh_token(token.iss, token.refresh_token)
  62. if new_token.authorized:
  63. token_save(new_token)
  64. if oauth.authorized:
  65. return redirect("/profile")
  66. return redirect("/")
  67. @app.route("/login")
  68. def login():
  69. redirect_uri = request.base_url.rsplit("/", 1)[0] + "/callback"
  70. print(redirect_uri)
  71. oauth = OAuth2Session(cfg.client_id, redirect_uri=redirect_uri)
  72. authorization_url, state = oauth.authorization_url(cfg.domain + cfg.auth_url)
  73. session["oauth_state"] = state
  74. return redirect(authorization_url)
  75. @app.route("/callback", methods=["GET"])
  76. def callback():
  77. state = session.get("oauth_state")
  78. if state is None:
  79. return redirect("/")
  80. print(state)
  81. redirect_uri = request.base_url
  82. print(redirect_uri)
  83. oauth = OAuth2Session(cfg.client_id, state=state, redirect_uri=redirect_uri)
  84. try:
  85. token = oauth.fetch_token(
  86. cfg.domain + cfg.token_url, client_secret=cfg.client_secret, authorization_response=request.url
  87. )
  88. token_save(token)
  89. session["oauth_token"] = token
  90. return redirect("/profile")
  91. except OAuth2Error as e:
  92. print(e)
  93. return redirect("/")
  94. @app.route("/profile", methods=["GET"])
  95. def profile():
  96. oauth = OAuth2Session(cfg.client_id, token=get_token(), auto_refresh_kwargs={"grant_type": "refresh_token"})
  97. if not oauth.authorized:
  98. return redirect("/")
  99. try:
  100. res = mazda_upload.upload_files(cfg, oauth)
  101. except OAuth2Error as e:
  102. print(e.error, e.description)
  103. return redirect("/")
  104. return app.response_class(response=json.dumps(res, indent=2), mimetype="application/json")
  105. if __name__ == "__main__":
  106. # os.environ['OAUTHLIB_INSECURE_TRANSPORT'] = "1"
  107. app.secret_key = os.urandom(24)
  108. app.run(
  109. host="0.0.0.0",
  110. port="8085",
  111. ssl_context=(
  112. "config/cert/global-cube.com.crt",
  113. "config/cert/global-cube.com.key",
  114. # "config/cert/intermediate.crt",
  115. ),
  116. debug=True,
  117. )