Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

app.py 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. from flask import request
  2. from flask_restful import Resource, marshal_with, reqparse
  3. from controllers.common import fields
  4. from controllers.web import api
  5. from controllers.web.error import AppUnavailableError
  6. from controllers.web.wraps import WebApiResource
  7. from core.app.app_config.common.parameters_mapping import get_parameters_from_feature_dict
  8. from libs.passport import PassportService
  9. from models.model import App, AppMode
  10. from services.app_service import AppService
  11. from services.enterprise.enterprise_service import EnterpriseService
  12. class AppParameterApi(WebApiResource):
  13. """Resource for app variables."""
  14. @marshal_with(fields.parameters_fields)
  15. def get(self, app_model: App, end_user):
  16. """Retrieve app parameters."""
  17. if app_model.mode in {AppMode.ADVANCED_CHAT.value, AppMode.WORKFLOW.value}:
  18. workflow = app_model.workflow
  19. if workflow is None:
  20. raise AppUnavailableError()
  21. features_dict = workflow.features_dict
  22. user_input_form = workflow.user_input_form(to_old_structure=True)
  23. else:
  24. app_model_config = app_model.app_model_config
  25. if app_model_config is None:
  26. raise AppUnavailableError()
  27. features_dict = app_model_config.to_dict()
  28. user_input_form = features_dict.get("user_input_form", [])
  29. return get_parameters_from_feature_dict(features_dict=features_dict, user_input_form=user_input_form)
  30. class AppMeta(WebApiResource):
  31. def get(self, app_model: App, end_user):
  32. """Get app meta"""
  33. return AppService().get_app_meta(app_model)
  34. class AppAccessMode(Resource):
  35. def get(self):
  36. parser = reqparse.RequestParser()
  37. parser.add_argument("appId", type=str, required=True, location="args")
  38. args = parser.parse_args()
  39. app_id = args["appId"]
  40. res = EnterpriseService.WebAppAuth.get_app_access_mode_by_id(app_id)
  41. return {"accessMode": res.access_mode}
  42. class AppWebAuthPermission(Resource):
  43. def get(self):
  44. user_id = "visitor"
  45. try:
  46. auth_header = request.headers.get("Authorization")
  47. if auth_header is None:
  48. raise
  49. if " " not in auth_header:
  50. raise
  51. auth_scheme, tk = auth_header.split(None, 1)
  52. auth_scheme = auth_scheme.lower()
  53. if auth_scheme != "bearer":
  54. raise
  55. decoded = PassportService().verify(tk)
  56. user_id = decoded.get("user_id", "visitor")
  57. except Exception as e:
  58. pass
  59. parser = reqparse.RequestParser()
  60. parser.add_argument("appId", type=str, required=True, location="args")
  61. args = parser.parse_args()
  62. app_id = args["appId"]
  63. app_code = AppService.get_app_code_by_id(app_id)
  64. res = EnterpriseService.WebAppAuth.is_user_allowed_to_access_webapp(str(user_id), app_code)
  65. return {"result": res}
  66. api.add_resource(AppParameterApi, "/parameters")
  67. api.add_resource(AppMeta, "/meta")
  68. # webapp auth apis
  69. api.add_resource(AppAccessMode, "/webapp/access-mode")
  70. api.add_resource(AppWebAuthPermission, "/webapp/permission")