Source code for pyrit.prompt_converter.text_jailbreak_converter
# Copyright (c) Microsoft Corporation.
# Licensed under the MIT license.
from pyrit.datasets import TextJailBreak
from pyrit.models import PromptDataType
from pyrit.prompt_converter import ConverterResult, PromptConverter
[docs]
class TextJailbreakConverter(PromptConverter):
"""
Uses a jailbreak template to create a prompt.
"""
[docs]
def __init__(self, *, jailbreak_template: TextJailBreak):
"""
Initializes the converter with the specified jailbreak template.
Args:
jailbreak_template (TextJailBreak): The jailbreak template to use for conversion.
"""
self.jail_break_template = jailbreak_template
[docs]
async def convert_async(self, *, prompt: str, input_type: PromptDataType = "text") -> ConverterResult:
"""
Converts the given prompt using the jailbreak template.
"""
if not self.input_supported(input_type):
raise ValueError("Input type not supported")
jailbreak_prompt = self.jail_break_template.get_jailbreak(prompt=prompt)
return ConverterResult(output_text=jailbreak_prompt, output_type="text")
[docs]
def input_supported(self, input_type: PromptDataType) -> bool:
return input_type == "text"
[docs]
def output_supported(self, output_type: PromptDataType) -> bool:
return output_type == "text"