Merge branch 'master' of https://e.coding.net/ctcdevteam/ehs/ehs_server
This commit is contained in:
		
						commit
						2ca9b3ce02
					
				|  | @ -1,12 +1,8 @@ | |||
| 
 | ||||
| from django.urls import path | ||||
| from apps.ichat.views import QueryLLMview | ||||
| from django.urls import path, include | ||||
| from rest_framework.routers import DefaultRouter | ||||
| 
 | ||||
| API_BASE_URL = 'api/hrm/' | ||||
| HTML_BASE_URL = 'dhtml/hrm/' | ||||
| 
 | ||||
| router = DefaultRouter() | ||||
| router.register('llm/query/', QueryLLMview, basename='llm_query') | ||||
| API_BASE_URL = 'api/llm/ichat/' | ||||
| urlpatterns = [ | ||||
|     path(API_BASE_URL, include(router.urls)), | ||||
|     path(API_BASE_URL + 'query/', QueryLLMview.as_view(), name='llm_query'), | ||||
| ] | ||||
|  | @ -1,23 +1,20 @@ | |||
| import requests | ||||
| from pydantic import Field | ||||
| from langchain_core.language_models import LLM | ||||
| from langchain_core.outputs import LLMResult, Generation | ||||
| from langchain_experimental.sql import SQLDatabaseChain | ||||
| from langchain_community.utilities import SQLDatabase | ||||
| from server.conf import DATABASES | ||||
| from serializers import CustomLLMrequestSerializer | ||||
| from apps.ichat.serializers import CustomLLMrequestSerializer | ||||
| from rest_framework.views import APIView | ||||
| from urllib.parse import quote_plus | ||||
| # fastapi | ||||
| from fastapi import FastAPI | ||||
| from pydantic import BaseModel | ||||
| from rest_framework.response import Response | ||||
| 
 | ||||
| 
 | ||||
| db_conf = DATABASES['default'] | ||||
| # 密码需要 URL 编码(因为有特殊字符如 @) | ||||
| password_encodeed = quote_plus(db_conf['password']) | ||||
| password_encodeed = quote_plus(db_conf['PASSWORD']) | ||||
| 
 | ||||
| db = SQLDatabase.from_uri(f"postgresql+psycopg2://{db_conf['user']}:{password_encodeed}@{db_conf['host']}/{db_conf['name']}", include_tables=["enm_mpoint", "enm_mpointstat"]) | ||||
| db = SQLDatabase.from_uri(f"postgresql+psycopg2://{db_conf['USER']}:{password_encodeed}@{db_conf['HOST']}/{db_conf['NAME']}", include_tables=["enm_mpoint", "enm_mpointstat"]) | ||||
| # model_url = "http://14.22.88.72:11025/v1/chat/completions" | ||||
| model_url = "http://139.159.180.64:11434/v1/chat/completions" | ||||
| 
 | ||||
|  | @ -74,6 +71,6 @@ class QueryLLMview(APIView): | |||
|         serializer.is_valid(raise_exception=True) | ||||
|         prompt = serializer.validated_data['prompt'] | ||||
|         llm = CustomLLM(model_url=model_url) | ||||
|         chain = SQLDatabaseChain(llm=llm, database=db, verbose=True) | ||||
|         chain = SQLDatabaseChain.from_llm(llm, db, verbose=True) | ||||
|         result = chain.invoke(prompt) | ||||
|         return result | ||||
|         return Response({"result": result}) | ||||
|  | @ -126,7 +126,7 @@ class WMaterial(CommonBDModel): | |||
|     @classmethod | ||||
|     def mat_in_qs(cls, mtask: Mtask, qs=None): | ||||
|         """ | ||||
|         可用于该子任务的queryset | ||||
|         TN: 可用于该子任务的queryset | ||||
|         """ | ||||
|         if qs is None: | ||||
|             qs = cls.objects | ||||
|  |  | |||
|  | @ -44,6 +44,7 @@ urlpatterns = [ | |||
| 
 | ||||
|     # api | ||||
|     path('', include('apps.auth1.urls')), | ||||
|     path('', include('apps.ichat.urls')), | ||||
|     path('', include('apps.system.urls')), | ||||
|     path('', include('apps.monitor.urls')), | ||||
|     path('', include('apps.wf.urls')), | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue