mirror of
https://github.com/deepset-ai/haystack.git
synced 2026-01-28 02:23:48 +00:00
2.9 KiB
2.9 KiB
| title | id | description | slug |
|---|---|---|---|
| Writers | experimental-writers-api | Writers for Haystack. | /experimental-writers-api |
Module haystack_experimental.components.writers.chat_message_writer
ChatMessageWriter
Writes chat messages to an underlying ChatMessageStore.
Usage example:
from haystack.dataclasses import ChatMessage
from haystack_experimental.components.writers import ChatMessageWriter
from haystack_experimental.chat_message_stores.in_memory import InMemoryChatMessageStore
messages = [
ChatMessage.from_assistant("Hello, how can I help you?"),
ChatMessage.from_user("I have a question about Python."),
]
message_store = InMemoryChatMessageStore()
writer = ChatMessageWriter(message_store)
writer.run(chat_history_id="user_456_session_123", messages=messages)
ChatMessageWriter.__init__
def __init__(chat_message_store: ChatMessageStore) -> None
Create a ChatMessageWriter component.
Arguments:
chat_message_store: The ChatMessageStore where the chat messages are to be written.
ChatMessageWriter.to_dict
def to_dict() -> dict[str, Any]
Serializes the component to a dictionary.
Returns:
Dictionary with serialized data.
ChatMessageWriter.from_dict
@classmethod
def from_dict(cls, data: dict[str, Any]) -> "ChatMessageWriter"
Deserializes the component from a dictionary.
Arguments:
data: The dictionary to deserialize from.
Raises:
DeserializationError: If the message store is not properly specified in the serialization data or its type cannot be imported.
Returns:
The deserialized component.
ChatMessageWriter.run
@component.output_types(messages_written=int)
def run(chat_history_id: str, messages: list[ChatMessage]) -> dict[str, int]
Run the ChatMessageWriter on the given input data.
Arguments:
chat_history_id: A unique identifier for the chat session or conversation whose messages should be retrieved. Eachchat_history_idcorresponds to a distinct chat history stored in the underlying ChatMessageStore. For example, use a session ID or conversation ID to isolate messages from different chat sessions.messages: A list of chat messages to write to the store.
Returns:
messages_written: Number of messages written to the ChatMessageStore.