Source code for pyrit.chat_message_normalizer.generic_system_squash

# Copyright (c) Microsoft Corporation.
# Licensed under the MIT license.

from pyrit.chat_message_normalizer import ChatMessageNormalizer
from pyrit.models import ChatMessage, ChatMessageRole


[docs] class GenericSystemSquash(ChatMessageNormalizer[list[ChatMessage]]):
[docs] def normalize(self, messages: list[ChatMessage]) -> list[ChatMessage]: """ Returns the first system message combined with the first user message using a format that uses generic instruction tags """ normalized_messages = ChatMessageNormalizer.squash_system_message( messages=messages, squash_function=GenericSystemSquash.combine_system_user_message ) return normalized_messages
[docs] @staticmethod def combine_system_user_message( system_message: ChatMessage, user_message: ChatMessage, msg_type: ChatMessageRole = "user" ) -> ChatMessage: """Combines the system message with the user message. Args: system_message (str): The system message. user_message (str): The user message. Returns: ChatMessage: The combined message. """ content = f"### Instructions ###\n\n{system_message.content}\n\n######\n\n{user_message.content}" return ChatMessage(role=msg_type, content=content)