| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 | 
							- import os
 
- from flask_login import current_user
 
- from flask_restful import Resource, reqparse
 
- from controllers.console import api
 
- from controllers.console.app.error import (
 
-     CompletionRequestError,
 
-     ProviderModelCurrentlyNotSupportError,
 
-     ProviderNotInitializeError,
 
-     ProviderQuotaExceededError,
 
- )
 
- from controllers.console.setup import setup_required
 
- from controllers.console.wraps import account_initialization_required
 
- from core.errors.error import ModelCurrentlyNotSupportError, ProviderTokenNotInitError, QuotaExceededError
 
- from core.llm_generator.llm_generator import LLMGenerator
 
- from core.model_runtime.errors.invoke import InvokeError
 
- from libs.login import login_required
 
- class RuleGenerateApi(Resource):
 
-     @setup_required
 
-     @login_required
 
-     @account_initialization_required
 
-     def post(self):
 
-         parser = reqparse.RequestParser()
 
-         parser.add_argument('instruction', type=str, required=True, nullable=False, location='json')
 
-         parser.add_argument('model_config', type=dict, required=True, nullable=False, location='json')
 
-         parser.add_argument('no_variable', type=bool, required=True, default=False, location='json')
 
-         args = parser.parse_args()
 
-         account = current_user
 
-         PROMPT_GENERATION_MAX_TOKENS = int(os.getenv('PROMPT_GENERATION_MAX_TOKENS', '512'))
 
-         try:
 
-             rules = LLMGenerator.generate_rule_config(
 
-                 tenant_id=account.current_tenant_id,
 
-                 instruction=args['instruction'],
 
-                 model_config=args['model_config'],
 
-                 no_variable=args['no_variable'],
 
-                 rule_config_max_tokens=PROMPT_GENERATION_MAX_TOKENS
 
-             )
 
-         except ProviderTokenNotInitError as ex:
 
-             raise ProviderNotInitializeError(ex.description)
 
-         except QuotaExceededError:
 
-             raise ProviderQuotaExceededError()
 
-         except ModelCurrentlyNotSupportError:
 
-             raise ProviderModelCurrentlyNotSupportError()
 
-         except InvokeError as e:
 
-             raise CompletionRequestError(e.description)
 
-         return rules
 
- api.add_resource(RuleGenerateApi, '/rule-generate')
 
 
  |