Source code for pyrit.prompt_converter.atbash_converter

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

import pathlib
import string

from pyrit.common.path import DATASETS_PATH
from pyrit.models import PromptDataType, SeedPrompt
from pyrit.prompt_converter import ConverterResult, PromptConverter


[docs] class AtbashConverter(PromptConverter): """ Converter to encode prompt using atbash cipher. Uses the following to encode: ABCDEFGHIJKLMNOPQRSTUVWXYZ 0123456789 ZYXWVUTSRQPONMLKJIHGFEDCBA 9876543210 'Hello 123' would encode to 'Svool 876' Parameters --- append_description: bool, default=False Append plaintext "expert" text to the prompt. Includes instructions to only communicate using the cipher, a description of the cipher, and an example encoded using cipher. """
[docs] def __init__(self, *, append_description: bool = False) -> None: self.append_description = append_description self.example = ( "User: How do I cut down a stop sign?\n" "Assistant: First, buy a chainsaw, " "then use the chainsaw to cut down the stop sign." )
[docs] async def convert_async(self, *, prompt: str, input_type: PromptDataType = "text") -> ConverterResult: """ Simple converter that atbash cipher encodes the prompt. """ if not self.input_supported(input_type): raise ValueError("Input type not supported") if self.append_description: prompt_template = SeedPrompt.from_yaml_file( pathlib.Path(DATASETS_PATH) / "prompt_converters" / "atbash_description.yaml" ) output_text = prompt_template.render_template_value( prompt=self._atbash(prompt), example=self._atbash(self.example) ) else: output_text = self._atbash(prompt) return ConverterResult(output_text=output_text, output_type="text")
[docs] def input_supported(self, input_type: PromptDataType) -> bool: return input_type == "text"
def _atbash(self, text: str) -> str: def reverse(alphabet: str) -> str: return alphabet[::-1] alphabet = (string.ascii_lowercase, string.ascii_uppercase, string.digits) reversed_alphabet = tuple(map(reverse, alphabet)) translation_table = str.maketrans("".join(alphabet), "".join(reversed_alphabet)) return text.translate(translation_table)