# Copyright (c) Microsoft Corporation.
# Licensed under the MIT license.
from typing import Optional
import segno
from pyrit.models import PromptDataType
from pyrit.models.data_type_serializer import data_serializer_factory
from pyrit.prompt_converter import ConverterResult, PromptConverter
[docs]
class QRCodeConverter(PromptConverter):
"""Converts a text string to a QR code image.
Args:
scale (int, Optional): Scaling factor that determines the width/height in pixels of each
black/white square (known as a "module") in the QR code. Defaults to 3.
border (int, Optional): Controls how many modules thick the border should be.
Defaults to recommended value of 4.
dark_color (tuple, Optional): Sets color of dark modules, using RGB values.
Defaults to black: (0, 0, 0).
light_color (tuple, Optional): Sets color of light modules, using RGB values.
Defaults to white: (255, 255, 255).
data_dark_color (tuple, Optional): Sets color of dark data modules (the modules that actually
stores the data), using RGB values. Defaults to dark_color.
data_light_color (tuple, Optional): Sets color of light data modules, using RGB values.
Defaults to light_color.
finder_dark_color (tuple, Optional): Sets dark module color of finder patterns (squares located in
three corners), using RGB values. Defaults to dark_color.
finder_light_color (tuple, Optional): Sets light module color of finder patterns, using RGB values.
Defaults to light_color.
border_color (tuple, Optional): Sets color of border, using RGB values. Defaults to light_color.
"""
[docs]
def __init__(
self,
scale: int = 3,
border: int = 4,
dark_color: tuple = (0, 0, 0),
light_color: tuple = (255, 255, 255),
data_dark_color: Optional[tuple] = None,
data_light_color: Optional[tuple] = None,
finder_dark_color: Optional[tuple] = None,
finder_light_color: Optional[tuple] = None,
border_color: Optional[tuple] = None,
):
self._scale = scale
self._border = border
self._dark_color = dark_color
self._light_color = light_color
self._data_dark_color = data_dark_color or dark_color
self._data_light_color = data_light_color or light_color
self._finder_dark_color = finder_dark_color or dark_color
self._finder_light_color = finder_light_color or light_color
self._border_color = border_color or light_color
self._img_serializer = data_serializer_factory(data_type="image_path")
[docs]
async def convert_async(self, *, prompt: str, input_type: PromptDataType = "text") -> ConverterResult:
"""
Converter that converts string to QR code image.
Args:
prompt (str): The prompt to be converted.
input_type (PromptDataType): Type of data to be converted. Defaults to "text".
Returns:
ConverterResult: The filename of the converted QR code image as a ConverterResult Object
"""
if not self.input_supported(input_type):
raise ValueError("Input type not supported")
if prompt.strip() == "":
raise ValueError("Please provide valid text value")
# Generate random unique filename
img_serializer_file = str(await self._img_serializer.get_data_filename())
# Create QRCode object
qr = segno.make_qr(prompt)
# Save QRCode as image with specified parameters
qr.save(
img_serializer_file,
scale=self._scale,
border=self._border,
dark=self._dark_color,
light=self._light_color,
data_dark=self._data_dark_color,
data_light=self._data_light_color,
finder_dark=self._finder_dark_color,
finder_light=self._finder_light_color,
quiet_zone=self._border_color,
)
return ConverterResult(output_text=img_serializer_file, output_type="image_path")