mirror of
https://github.com/StanGirard/quivr.git
synced 2025-01-07 11:39:00 +03:00
feat: Update langchain.prompts and langchain_core.messages modules (#2326)
This pull request updates the langchain.prompts and langchain_core.messages modules. It includes changes to the code that improve functionality and fix any existing issues.
This commit is contained in:
parent
ff9e67e9b4
commit
4e42882f41
@ -6,10 +6,10 @@ from langchain.chains import ConversationalRetrievalChain
|
|||||||
from langchain.embeddings.ollama import OllamaEmbeddings
|
from langchain.embeddings.ollama import OllamaEmbeddings
|
||||||
from langchain.llms.base import BaseLLM
|
from langchain.llms.base import BaseLLM
|
||||||
from langchain.memory import ConversationBufferMemory
|
from langchain.memory import ConversationBufferMemory
|
||||||
from langchain.prompts import HumanMessagePromptTemplate
|
from langchain.prompts import HumanMessagePromptTemplate, SystemMessagePromptTemplate
|
||||||
from langchain.schema import format_document
|
from langchain.schema import format_document
|
||||||
from langchain_community.chat_models import ChatLiteLLM
|
from langchain_community.chat_models import ChatLiteLLM
|
||||||
from langchain_core.messages import SystemMessage, get_buffer_string
|
from langchain_core.messages import get_buffer_string
|
||||||
from langchain_core.output_parsers import StrOutputParser
|
from langchain_core.output_parsers import StrOutputParser
|
||||||
from langchain_core.prompts import ChatPromptTemplate, PromptTemplate
|
from langchain_core.prompts import ChatPromptTemplate, PromptTemplate
|
||||||
from langchain_core.runnables import RunnableLambda, RunnablePassthrough
|
from langchain_core.runnables import RunnableLambda, RunnablePassthrough
|
||||||
@ -42,17 +42,21 @@ template_answer = """
|
|||||||
Context:
|
Context:
|
||||||
{context}
|
{context}
|
||||||
|
|
||||||
User Instructions to follow when answering, default to none: {custom_instructions}
|
|
||||||
User Question: {question}
|
User Question: {question}
|
||||||
Answer:
|
Answer:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
system_message_template = """
|
||||||
|
When answering use markdown to make it concise and neat.
|
||||||
|
Use the following pieces of context from files provided by the user that are store in a brain to answer the users question in the same language as the user question. Your name is Quivr. You're a helpful assistant.
|
||||||
|
If you don't know the answer with the context provided from the files, just say that you don't know, don't try to make up an answer.
|
||||||
|
User instruction to follow if provided to answer: {custom_instructions}
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
ANSWER_PROMPT = ChatPromptTemplate.from_messages(
|
ANSWER_PROMPT = ChatPromptTemplate.from_messages(
|
||||||
[
|
[
|
||||||
SystemMessage(
|
SystemMessagePromptTemplate.from_template(system_message_template),
|
||||||
content=(
|
|
||||||
"When answering use markdown or any other techniques to display the content in a nice and aerated way. Use the following pieces of context from files provided by the user to answer the users question in the same language as the user question. Your name is Quivr. You're a helpful assistant. If you don't know the answer with the context provided from the files, just say that you don't know, don't try to make up an answer."
|
|
||||||
)
|
|
||||||
),
|
|
||||||
HumanMessagePromptTemplate.from_template(template_answer),
|
HumanMessagePromptTemplate.from_template(template_answer),
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
@ -246,7 +250,9 @@ class QuivrRAG(BaseModel):
|
|||||||
answer = {
|
answer = {
|
||||||
"answer": final_inputs
|
"answer": final_inputs
|
||||||
| ANSWER_PROMPT
|
| ANSWER_PROMPT
|
||||||
| ChatLiteLLM(max_tokens=self.max_tokens, model=self.model, api_base=api_base),
|
| ChatLiteLLM(
|
||||||
|
max_tokens=self.max_tokens, model=self.model, api_base=api_base
|
||||||
|
),
|
||||||
"docs": itemgetter("docs"),
|
"docs": itemgetter("docs"),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,9 +42,13 @@ async def process_file(
|
|||||||
for doc in file.documents: # pyright: ignore reportPrivateUsage=none
|
for doc in file.documents: # pyright: ignore reportPrivateUsage=none
|
||||||
new_metadata = metadata.copy()
|
new_metadata = metadata.copy()
|
||||||
len_chunk = len(enc.encode(doc.page_content))
|
len_chunk = len(enc.encode(doc.page_content))
|
||||||
|
page_content_encoded = doc.page_content.encode("unicode_escape").decode(
|
||||||
|
"ascii", "replace"
|
||||||
|
)
|
||||||
|
|
||||||
new_metadata["chunk_size"] = len_chunk
|
new_metadata["chunk_size"] = len_chunk
|
||||||
doc_with_metadata = DocumentSerializable(
|
doc_with_metadata = DocumentSerializable(
|
||||||
page_content=doc.page_content, metadata=new_metadata
|
page_content=page_content_encoded, metadata=new_metadata
|
||||||
)
|
)
|
||||||
docs.append(doc_with_metadata)
|
docs.append(doc_with_metadata)
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ port = 54329
|
|||||||
# Configure one of the supported pooler modes: `transaction`, `session`.
|
# Configure one of the supported pooler modes: `transaction`, `session`.
|
||||||
pool_mode = "transaction"
|
pool_mode = "transaction"
|
||||||
# How many server connections to allow per user/database pair.
|
# How many server connections to allow per user/database pair.
|
||||||
default_pool_size = 15
|
default_pool_size = 20
|
||||||
# Maximum number of client connections allowed.
|
# Maximum number of client connections allowed.
|
||||||
max_client_conn = 100
|
max_client_conn = 100
|
||||||
|
|
||||||
@ -40,6 +40,8 @@ max_client_conn = 100
|
|||||||
enabled = true
|
enabled = true
|
||||||
# Bind realtime via either IPv4 or IPv6. (default: IPv6)
|
# Bind realtime via either IPv4 or IPv6. (default: IPv6)
|
||||||
# ip_version = "IPv6"
|
# ip_version = "IPv6"
|
||||||
|
# The maximum length in bytes of HTTP request headers. (default: 4096)
|
||||||
|
# max_header_length = 4096
|
||||||
|
|
||||||
[studio]
|
[studio]
|
||||||
enabled = true
|
enabled = true
|
||||||
@ -47,6 +49,8 @@ enabled = true
|
|||||||
port = 54323
|
port = 54323
|
||||||
# External URL of the API server that frontend connects to.
|
# External URL of the API server that frontend connects to.
|
||||||
api_url = "http://localhost"
|
api_url = "http://localhost"
|
||||||
|
# OpenAI API Key to use for Supabase AI in the Supabase Studio.
|
||||||
|
openai_api_key = "env(OPENAI_API_KEY)"
|
||||||
|
|
||||||
# Email testing server. Emails sent with the local dev setup are not actually sent - rather, they
|
# Email testing server. Emails sent with the local dev setup are not actually sent - rather, they
|
||||||
# are monitored, and you can view the emails that would have been sent from the web interface.
|
# are monitored, and you can view the emails that would have been sent from the web interface.
|
||||||
@ -71,7 +75,7 @@ site_url = "http://localhost:3000"
|
|||||||
# A list of *exact* URLs that auth providers are permitted to redirect to post authentication.
|
# A list of *exact* URLs that auth providers are permitted to redirect to post authentication.
|
||||||
additional_redirect_urls = ["https://localhost:3000"]
|
additional_redirect_urls = ["https://localhost:3000"]
|
||||||
# How long tokens are valid for, in seconds. Defaults to 3600 (1 hour), maximum 604,800 (1 week).
|
# How long tokens are valid for, in seconds. Defaults to 3600 (1 hour), maximum 604,800 (1 week).
|
||||||
jwt_expiry = 604800
|
jwt_expiry = 3600
|
||||||
# If disabled, the refresh token will never expire.
|
# If disabled, the refresh token will never expire.
|
||||||
enable_refresh_token_rotation = true
|
enable_refresh_token_rotation = true
|
||||||
# Allows refresh tokens to be reused after expiry, up to the specified interval in seconds.
|
# Allows refresh tokens to be reused after expiry, up to the specified interval in seconds.
|
||||||
@ -79,6 +83,8 @@ enable_refresh_token_rotation = true
|
|||||||
refresh_token_reuse_interval = 10
|
refresh_token_reuse_interval = 10
|
||||||
# Allow/disallow new user signups to your project.
|
# Allow/disallow new user signups to your project.
|
||||||
enable_signup = true
|
enable_signup = true
|
||||||
|
# Allow/disallow testing manual linking of accounts
|
||||||
|
enable_manual_linking = false
|
||||||
|
|
||||||
[auth.email]
|
[auth.email]
|
||||||
# Allow/disallow new user signups via email to your project.
|
# Allow/disallow new user signups via email to your project.
|
||||||
@ -100,12 +106,18 @@ enable_signup = true
|
|||||||
# If enabled, users need to confirm their phone number before signing in.
|
# If enabled, users need to confirm their phone number before signing in.
|
||||||
enable_confirmations = false
|
enable_confirmations = false
|
||||||
# Template for sending OTP to users
|
# Template for sending OTP to users
|
||||||
template = "Your code is {{ .Code }} ."
|
template = "Your code is {{ `{{ .Code }}` }} ."
|
||||||
|
|
||||||
# Use pre-defined map of phone number to OTP for testing.
|
# Use pre-defined map of phone number to OTP for testing.
|
||||||
[auth.sms.test_otp]
|
[auth.sms.test_otp]
|
||||||
# 4152127777 = "123456"
|
# 4152127777 = "123456"
|
||||||
|
|
||||||
|
# This hook runs before a token is issued and allows you to add additional claims based on the authentication method used.
|
||||||
|
[auth.hook.custom_access_token]
|
||||||
|
# enabled = true
|
||||||
|
# uri = "pg-functions://<database>/<schema>/<hook_name>"
|
||||||
|
|
||||||
|
|
||||||
# Configure one of the supported SMS providers: `twilio`, `twilio_verify`, `messagebird`, `textlocal`, `vonage`.
|
# Configure one of the supported SMS providers: `twilio`, `twilio_verify`, `messagebird`, `textlocal`, `vonage`.
|
||||||
[auth.sms.twilio]
|
[auth.sms.twilio]
|
||||||
enabled = false
|
enabled = false
|
||||||
@ -115,7 +127,7 @@ message_service_sid = ""
|
|||||||
auth_token = "env(SUPABASE_AUTH_SMS_TWILIO_AUTH_TOKEN)"
|
auth_token = "env(SUPABASE_AUTH_SMS_TWILIO_AUTH_TOKEN)"
|
||||||
|
|
||||||
# Use an external OAuth provider. The full list of providers are: `apple`, `azure`, `bitbucket`,
|
# Use an external OAuth provider. The full list of providers are: `apple`, `azure`, `bitbucket`,
|
||||||
# `discord`, `facebook`, `github`, `gitlab`, `google`, `keycloak`, `linkedin`, `notion`, `twitch`,
|
# `discord`, `facebook`, `github`, `gitlab`, `google`, `keycloak`, `linkedin_oidc`, `notion`, `twitch`,
|
||||||
# `twitter`, `slack`, `spotify`, `workos`, `zoom`.
|
# `twitter`, `slack`, `spotify`, `workos`, `zoom`.
|
||||||
[auth.external.apple]
|
[auth.external.apple]
|
||||||
enabled = false
|
enabled = false
|
||||||
@ -146,4 +158,4 @@ s3_region = "env(S3_REGION)"
|
|||||||
# Configures AWS_ACCESS_KEY_ID for S3 bucket
|
# Configures AWS_ACCESS_KEY_ID for S3 bucket
|
||||||
s3_access_key = "env(S3_ACCESS_KEY)"
|
s3_access_key = "env(S3_ACCESS_KEY)"
|
||||||
# Configures AWS_SECRET_ACCESS_KEY for S3 bucket
|
# Configures AWS_SECRET_ACCESS_KEY for S3 bucket
|
||||||
s3_secret_key = "env(S3_SECRET_KEY)"
|
s3_secret_key = "env(S3_SECRET_KEY)"
|
Loading…
Reference in New Issue
Block a user