Source code for pyrit.prompt_converter.malicious_question_generator_converter
# Copyright (c) Microsoft Corporation.
# Licensed under the MIT license.
import logging
import pathlib
from pyrit.common.path import DATASETS_PATH
from pyrit.models import PromptDataType, SeedPrompt
from pyrit.prompt_converter import ConverterResult, LLMGenericTextConverter
from pyrit.prompt_target import PromptChatTarget
logger = logging.getLogger(__name__)
[docs]
class MaliciousQuestionGeneratorConverter(LLMGenericTextConverter):
"""
A PromptConverter that generates malicious questions using an LLM via an existing PromptTarget (like Azure OpenAI).
"""
[docs]
def __init__(self, *, converter_target: PromptChatTarget, prompt_template: SeedPrompt = None):
"""
Initializes the converter with a specific target and template.
Args:
converter_target (PromptChatTarget): The endpoint that converts the prompt.
prompt_template (SeedPrompt): The seed prompt template to use.
"""
# set to default strategy if not provided
prompt_template = (
prompt_template
if prompt_template
else SeedPrompt.from_yaml_file(
pathlib.Path(DATASETS_PATH) / "prompt_converters" / "malicious_question_generator_converter.yaml"
)
)
super().__init__(converter_target=converter_target, prompt_template=prompt_template)
[docs]
async def convert_async(self, *, prompt: str, input_type: PromptDataType = "text") -> ConverterResult:
# Add the prompt to _prompt_kwargs before calling the base method
self._prompt_kwargs["prompt"] = prompt
return await super().convert_async(prompt=prompt, input_type=input_type)