| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 | 
							- import logging
 - 
 - from flask import request
 - from flask_restx import Resource, marshal_with, reqparse
 - from werkzeug.exceptions import Unauthorized
 - 
 - from controllers.common import fields
 - from controllers.web import web_ns
 - from controllers.web.error import AppUnavailableError
 - from controllers.web.wraps import WebApiResource
 - from core.app.app_config.common.parameters_mapping import get_parameters_from_feature_dict
 - from libs.passport import PassportService
 - from models.model import App, AppMode
 - from services.app_service import AppService
 - from services.enterprise.enterprise_service import EnterpriseService
 - from services.feature_service import FeatureService
 - from services.webapp_auth_service import WebAppAuthService
 - 
 - logger = logging.getLogger(__name__)
 - 
 - 
 - @web_ns.route("/parameters")
 - class AppParameterApi(WebApiResource):
 -     """Resource for app variables."""
 - 
 -     @web_ns.doc("Get App Parameters")
 -     @web_ns.doc(description="Retrieve the parameters for a specific app.")
 -     @web_ns.doc(
 -         responses={
 -             200: "Success",
 -             400: "Bad Request",
 -             401: "Unauthorized",
 -             403: "Forbidden",
 -             404: "App Not Found",
 -             500: "Internal Server Error",
 -         }
 -     )
 -     @marshal_with(fields.parameters_fields)
 -     def get(self, app_model: App, end_user):
 -         """Retrieve app parameters."""
 -         if app_model.mode in {AppMode.ADVANCED_CHAT, AppMode.WORKFLOW}:
 -             workflow = app_model.workflow
 -             if workflow is None:
 -                 raise AppUnavailableError()
 - 
 -             features_dict = workflow.features_dict
 -             user_input_form = workflow.user_input_form(to_old_structure=True)
 -         else:
 -             app_model_config = app_model.app_model_config
 -             if app_model_config is None:
 -                 raise AppUnavailableError()
 - 
 -             features_dict = app_model_config.to_dict()
 - 
 -             user_input_form = features_dict.get("user_input_form", [])
 - 
 -         return get_parameters_from_feature_dict(features_dict=features_dict, user_input_form=user_input_form)
 - 
 - 
 - @web_ns.route("/meta")
 - class AppMeta(WebApiResource):
 -     @web_ns.doc("Get App Meta")
 -     @web_ns.doc(description="Retrieve the metadata for a specific app.")
 -     @web_ns.doc(
 -         responses={
 -             200: "Success",
 -             400: "Bad Request",
 -             401: "Unauthorized",
 -             403: "Forbidden",
 -             404: "App Not Found",
 -             500: "Internal Server Error",
 -         }
 -     )
 -     def get(self, app_model: App, end_user):
 -         """Get app meta"""
 -         return AppService().get_app_meta(app_model)
 - 
 - 
 - @web_ns.route("/webapp/access-mode")
 - class AppAccessMode(Resource):
 -     @web_ns.doc("Get App Access Mode")
 -     @web_ns.doc(description="Retrieve the access mode for a web application (public or restricted).")
 -     @web_ns.doc(
 -         params={
 -             "appId": {"description": "Application ID", "type": "string", "required": False},
 -             "appCode": {"description": "Application code", "type": "string", "required": False},
 -         }
 -     )
 -     @web_ns.doc(
 -         responses={
 -             200: "Success",
 -             400: "Bad Request",
 -             500: "Internal Server Error",
 -         }
 -     )
 -     def get(self):
 -         parser = reqparse.RequestParser()
 -         parser.add_argument("appId", type=str, required=False, location="args")
 -         parser.add_argument("appCode", type=str, required=False, location="args")
 -         args = parser.parse_args()
 - 
 -         features = FeatureService.get_system_features()
 -         if not features.webapp_auth.enabled:
 -             return {"accessMode": "public"}
 - 
 -         app_id = args.get("appId")
 -         if args.get("appCode"):
 -             app_code = args["appCode"]
 -             app_id = AppService.get_app_id_by_code(app_code)
 - 
 -         if not app_id:
 -             raise ValueError("appId or appCode must be provided")
 - 
 -         res = EnterpriseService.WebAppAuth.get_app_access_mode_by_id(app_id)
 - 
 -         return {"accessMode": res.access_mode}
 - 
 - 
 - @web_ns.route("/webapp/permission")
 - class AppWebAuthPermission(Resource):
 -     @web_ns.doc("Check App Permission")
 -     @web_ns.doc(description="Check if user has permission to access a web application.")
 -     @web_ns.doc(params={"appId": {"description": "Application ID", "type": "string", "required": True}})
 -     @web_ns.doc(
 -         responses={
 -             200: "Success",
 -             400: "Bad Request",
 -             401: "Unauthorized",
 -             500: "Internal Server Error",
 -         }
 -     )
 -     def get(self):
 -         user_id = "visitor"
 -         try:
 -             auth_header = request.headers.get("Authorization")
 -             if auth_header is None:
 -                 raise Unauthorized("Authorization header is missing.")
 -             if " " not in auth_header:
 -                 raise Unauthorized("Invalid Authorization header format. Expected 'Bearer <api-key>' format.")
 - 
 -             auth_scheme, tk = auth_header.split(None, 1)
 -             auth_scheme = auth_scheme.lower()
 -             if auth_scheme != "bearer":
 -                 raise Unauthorized("Authorization scheme must be 'Bearer'")
 - 
 -             decoded = PassportService().verify(tk)
 -             user_id = decoded.get("user_id", "visitor")
 -         except Unauthorized:
 -             raise
 -         except Exception:
 -             logger.exception("Unexpected error during auth verification")
 -             raise
 - 
 -         features = FeatureService.get_system_features()
 -         if not features.webapp_auth.enabled:
 -             return {"result": True}
 - 
 -         parser = reqparse.RequestParser()
 -         parser.add_argument("appId", type=str, required=True, location="args")
 -         args = parser.parse_args()
 - 
 -         app_id = args["appId"]
 -         app_code = AppService.get_app_code_by_id(app_id)
 - 
 -         res = True
 -         if WebAppAuthService.is_app_require_permission_check(app_id=app_id):
 -             res = EnterpriseService.WebAppAuth.is_user_allowed_to_access_webapp(str(user_id), app_code)
 -         return {"result": res}
 
 
  |