Spaces:
Build error
Build error
from flask_restful import Resource, reqparse | |
from werkzeug.exceptions import Forbidden | |
from controllers.console import api | |
from controllers.console.wraps import account_initialization_required, setup_required | |
from core.model_runtime.entities.model_entities import ModelType | |
from core.model_runtime.errors.validate import CredentialsValidateFailedError | |
from libs.login import current_user, login_required | |
from models.account import TenantAccountRole | |
from services.model_load_balancing_service import ModelLoadBalancingService | |
class LoadBalancingCredentialsValidateApi(Resource): | |
def post(self, provider: str): | |
if not TenantAccountRole.is_privileged_role(current_user.current_tenant.current_role): | |
raise Forbidden() | |
tenant_id = current_user.current_tenant_id | |
parser = reqparse.RequestParser() | |
parser.add_argument("model", type=str, required=True, nullable=False, location="json") | |
parser.add_argument( | |
"model_type", | |
type=str, | |
required=True, | |
nullable=False, | |
choices=[mt.value for mt in ModelType], | |
location="json", | |
) | |
parser.add_argument("credentials", type=dict, required=True, nullable=False, location="json") | |
args = parser.parse_args() | |
# validate model load balancing credentials | |
model_load_balancing_service = ModelLoadBalancingService() | |
result = True | |
error = None | |
try: | |
model_load_balancing_service.validate_load_balancing_credentials( | |
tenant_id=tenant_id, | |
provider=provider, | |
model=args["model"], | |
model_type=args["model_type"], | |
credentials=args["credentials"], | |
) | |
except CredentialsValidateFailedError as ex: | |
result = False | |
error = str(ex) | |
response = {"result": "success" if result else "error"} | |
if not result: | |
response["error"] = error | |
return response | |
class LoadBalancingConfigCredentialsValidateApi(Resource): | |
def post(self, provider: str, config_id: str): | |
if not TenantAccountRole.is_privileged_role(current_user.current_tenant.current_role): | |
raise Forbidden() | |
tenant_id = current_user.current_tenant_id | |
parser = reqparse.RequestParser() | |
parser.add_argument("model", type=str, required=True, nullable=False, location="json") | |
parser.add_argument( | |
"model_type", | |
type=str, | |
required=True, | |
nullable=False, | |
choices=[mt.value for mt in ModelType], | |
location="json", | |
) | |
parser.add_argument("credentials", type=dict, required=True, nullable=False, location="json") | |
args = parser.parse_args() | |
# validate model load balancing config credentials | |
model_load_balancing_service = ModelLoadBalancingService() | |
result = True | |
error = None | |
try: | |
model_load_balancing_service.validate_load_balancing_credentials( | |
tenant_id=tenant_id, | |
provider=provider, | |
model=args["model"], | |
model_type=args["model_type"], | |
credentials=args["credentials"], | |
config_id=config_id, | |
) | |
except CredentialsValidateFailedError as ex: | |
result = False | |
error = str(ex) | |
response = {"result": "success" if result else "error"} | |
if not result: | |
response["error"] = error | |
return response | |
# Load Balancing Config | |
api.add_resource( | |
LoadBalancingCredentialsValidateApi, | |
"/workspaces/current/model-providers/<string:provider>/models/load-balancing-configs/credentials-validate", | |
) | |
api.add_resource( | |
LoadBalancingConfigCredentialsValidateApi, | |
"/workspaces/current/model-providers/<string:provider>/models/load-balancing-configs/<string:config_id>/credentials-validate", | |
) | |