mirror of
https://github.com/langgenius/dify.git
synced 2024-11-16 11:42:29 +08:00
13be84e4d4
Some checks are pending
Build and Push API & Web / build (api, DIFY_API_IMAGE_NAME, linux/amd64, build-api-amd64) (push) Waiting to run
Build and Push API & Web / build (api, DIFY_API_IMAGE_NAME, linux/arm64, build-api-arm64) (push) Waiting to run
Build and Push API & Web / build (web, DIFY_WEB_IMAGE_NAME, linux/amd64, build-web-amd64) (push) Waiting to run
Build and Push API & Web / build (web, DIFY_WEB_IMAGE_NAME, linux/arm64, build-web-arm64) (push) Waiting to run
Build and Push API & Web / create-manifest (api, DIFY_API_IMAGE_NAME, merge-api-images) (push) Blocked by required conditions
Build and Push API & Web / create-manifest (web, DIFY_WEB_IMAGE_NAME, merge-web-images) (push) Blocked by required conditions
75 lines
3.0 KiB
Python
75 lines
3.0 KiB
Python
from flask_login import current_user
|
|
from flask_restful import Resource, reqparse
|
|
from werkzeug.exceptions import Forbidden
|
|
|
|
from controllers.console import api
|
|
from controllers.console.auth.error import ApiKeyAuthFailedError
|
|
from libs.login import login_required
|
|
from services.auth.api_key_auth_service import ApiKeyAuthService
|
|
|
|
from ..setup import setup_required
|
|
from ..wraps import account_initialization_required
|
|
|
|
|
|
class ApiKeyAuthDataSource(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
def get(self):
|
|
data_source_api_key_bindings = ApiKeyAuthService.get_provider_auth_list(current_user.current_tenant_id)
|
|
if data_source_api_key_bindings:
|
|
return {
|
|
"sources": [
|
|
{
|
|
"id": data_source_api_key_binding.id,
|
|
"category": data_source_api_key_binding.category,
|
|
"provider": data_source_api_key_binding.provider,
|
|
"disabled": data_source_api_key_binding.disabled,
|
|
"created_at": int(data_source_api_key_binding.created_at.timestamp()),
|
|
"updated_at": int(data_source_api_key_binding.updated_at.timestamp()),
|
|
}
|
|
for data_source_api_key_binding in data_source_api_key_bindings
|
|
]
|
|
}
|
|
return {"sources": []}
|
|
|
|
|
|
class ApiKeyAuthDataSourceBinding(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
def post(self):
|
|
# The role of the current user in the table must be admin or owner
|
|
if not current_user.is_admin_or_owner:
|
|
raise Forbidden()
|
|
parser = reqparse.RequestParser()
|
|
parser.add_argument("category", type=str, required=True, nullable=False, location="json")
|
|
parser.add_argument("provider", type=str, required=True, nullable=False, location="json")
|
|
parser.add_argument("credentials", type=dict, required=True, nullable=False, location="json")
|
|
args = parser.parse_args()
|
|
ApiKeyAuthService.validate_api_key_auth_args(args)
|
|
try:
|
|
ApiKeyAuthService.create_provider_auth(current_user.current_tenant_id, args)
|
|
except Exception as e:
|
|
raise ApiKeyAuthFailedError(str(e))
|
|
return {"result": "success"}, 200
|
|
|
|
|
|
class ApiKeyAuthDataSourceBindingDelete(Resource):
|
|
@setup_required
|
|
@login_required
|
|
@account_initialization_required
|
|
def delete(self, binding_id):
|
|
# The role of the current user in the table must be admin or owner
|
|
if not current_user.is_admin_or_owner:
|
|
raise Forbidden()
|
|
|
|
ApiKeyAuthService.delete_provider_auth(current_user.current_tenant_id, binding_id)
|
|
|
|
return {"result": "success"}, 200
|
|
|
|
|
|
api.add_resource(ApiKeyAuthDataSource, "/api-key-auth/data-source")
|
|
api.add_resource(ApiKeyAuthDataSourceBinding, "/api-key-auth/data-source/binding")
|
|
api.add_resource(ApiKeyAuthDataSourceBindingDelete, "/api-key-auth/data-source/<uuid:binding_id>")
|