asphalt-framework/asphalt-serialization

View on GitHub
src/asphalt/serialization/serializers/yaml.py

Summary

Maintainability
A
0 mins
Test Coverage
from __future__ import annotations

from io import StringIO
from typing import Any

from ruamel.yaml import YAML

from ..api import Serializer


class YAMLSerializer(Serializer):
    """
    Serializes objects to and from YAML format.

    To use this serializer backend, the ``ruamel.yaml`` library must be installed.
    A convenient way to do this is to install ``asphalt-serialization`` with the
    ``yaml`` extra:

    .. code-block:: shell

        $ pip install asphalt-serialization[yaml]

    .. warning:: This serializer is insecure in unsafe mode because it allows execution
      of arbitrary code when deserializing.

    .. seealso:: `ruamel.yaml documentation <https://yaml.readthedocs.io/en/latest/>`_

    :param safe: ``True`` to (de)serialize in safe mode, ``False`` to enable extended
        tags
    """

    __slots__ = "_yaml"

    def __init__(self, safe: bool = True):
        self._yaml = YAML(typ="safe" if safe else "unsafe")

    def serialize(self, obj: Any) -> bytes:
        buffer = StringIO()
        self._yaml.dump(obj, buffer)
        return buffer.getvalue().encode("utf-8")

    def deserialize(self, payload: bytes) -> Any:
        return self._yaml.load(payload)

    @property
    def mimetype(self) -> str:
        return "text/yaml"

    @property
    def safe(self) -> bool:
        """Returns ``True`` if the safe mode is being used with (de)serialization."""
        return "safe" in self._yaml.typ