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)