Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

activate.py 4.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. from flask import request
  2. from flask_restx import Resource, fields, reqparse
  3. from constants.languages import supported_language
  4. from controllers.console import api, console_ns
  5. from controllers.console.error import AlreadyActivateError
  6. from extensions.ext_database import db
  7. from libs.datetime_utils import naive_utc_now
  8. from libs.helper import StrLen, email, extract_remote_ip, timezone
  9. from models.account import AccountStatus
  10. from services.account_service import AccountService, RegisterService
  11. active_check_parser = reqparse.RequestParser()
  12. active_check_parser.add_argument(
  13. "workspace_id", type=str, required=False, nullable=True, location="args", help="Workspace ID"
  14. )
  15. active_check_parser.add_argument(
  16. "email", type=email, required=False, nullable=True, location="args", help="Email address"
  17. )
  18. active_check_parser.add_argument(
  19. "token", type=str, required=True, nullable=False, location="args", help="Activation token"
  20. )
  21. @console_ns.route("/activate/check")
  22. class ActivateCheckApi(Resource):
  23. @api.doc("check_activation_token")
  24. @api.doc(description="Check if activation token is valid")
  25. @api.expect(active_check_parser)
  26. @api.response(
  27. 200,
  28. "Success",
  29. api.model(
  30. "ActivationCheckResponse",
  31. {
  32. "is_valid": fields.Boolean(description="Whether token is valid"),
  33. "data": fields.Raw(description="Activation data if valid"),
  34. },
  35. ),
  36. )
  37. def get(self):
  38. args = active_check_parser.parse_args()
  39. workspaceId = args["workspace_id"]
  40. reg_email = args["email"]
  41. token = args["token"]
  42. invitation = RegisterService.get_invitation_if_token_valid(workspaceId, reg_email, token)
  43. if invitation:
  44. data = invitation.get("data", {})
  45. tenant = invitation.get("tenant", None)
  46. workspace_name = tenant.name if tenant else None
  47. workspace_id = tenant.id if tenant else None
  48. invitee_email = data.get("email") if data else None
  49. return {
  50. "is_valid": invitation is not None,
  51. "data": {"workspace_name": workspace_name, "workspace_id": workspace_id, "email": invitee_email},
  52. }
  53. else:
  54. return {"is_valid": False}
  55. active_parser = reqparse.RequestParser()
  56. active_parser.add_argument("workspace_id", type=str, required=False, nullable=True, location="json")
  57. active_parser.add_argument("email", type=email, required=False, nullable=True, location="json")
  58. active_parser.add_argument("token", type=str, required=True, nullable=False, location="json")
  59. active_parser.add_argument("name", type=StrLen(30), required=True, nullable=False, location="json")
  60. active_parser.add_argument(
  61. "interface_language", type=supported_language, required=True, nullable=False, location="json"
  62. )
  63. active_parser.add_argument("timezone", type=timezone, required=True, nullable=False, location="json")
  64. @console_ns.route("/activate")
  65. class ActivateApi(Resource):
  66. @api.doc("activate_account")
  67. @api.doc(description="Activate account with invitation token")
  68. @api.expect(active_parser)
  69. @api.response(
  70. 200,
  71. "Account activated successfully",
  72. api.model(
  73. "ActivationResponse",
  74. {
  75. "result": fields.String(description="Operation result"),
  76. "data": fields.Raw(description="Login token data"),
  77. },
  78. ),
  79. )
  80. @api.response(400, "Already activated or invalid token")
  81. def post(self):
  82. args = active_parser.parse_args()
  83. invitation = RegisterService.get_invitation_if_token_valid(args["workspace_id"], args["email"], args["token"])
  84. if invitation is None:
  85. raise AlreadyActivateError()
  86. RegisterService.revoke_token(args["workspace_id"], args["email"], args["token"])
  87. account = invitation["account"]
  88. account.name = args["name"]
  89. account.interface_language = args["interface_language"]
  90. account.timezone = args["timezone"]
  91. account.interface_theme = "light"
  92. account.status = AccountStatus.ACTIVE.value
  93. account.initialized_at = naive_utc_now()
  94. db.session.commit()
  95. token_pair = AccountService.login(account, ip_address=extract_remote_ip(request))
  96. return {"result": "success", "data": token_pair.model_dump()}