Source code for pyrit.prompt_converter.suffix_append_converter

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

from pyrit.models import PromptDataType
from pyrit.prompt_converter import PromptConverter, ConverterResult


[docs] class SuffixAppendConverter(PromptConverter):
[docs] def __init__(self, *, suffix: str): if not suffix: raise ValueError("Please specify a suffix (str) to be appended to the prompt.") self.suffix = suffix
[docs] async def convert_async(self, *, prompt: str, input_type: PromptDataType = "text") -> ConverterResult: """ Simple converter that appends a given suffix to the prompt. E.g. with a suffix `!!!`, it converts a prompt of `test` to `test !!!` See PyRIT/pyrit/auxiliary_attacks/gcg for adversarial suffix generation Args: prompt (str): The prompt to be converted. Returns: list[str]: The converted prompts. """ if not self.input_supported(input_type): raise ValueError("Input type not supported") return ConverterResult(output_text=prompt + " " + self.suffix, output_type="text")
[docs] def input_supported(self, input_type: PromptDataType) -> bool: return input_type == "text"