Pydantic Support#

phantom-types supports pydantic out of the box by providing a __get_validators__() hook on the base Phantom class. Most of the shipped types also implements full JSON Schema and OpenAPI support.

To make a phantom type compatible with pydantic, all you need to do is override Phantom.__schema__():

from phantom import Phantom
from phantom.schema import Schema


class Name(str, Phantom, predicate=...):
    @classmethod
    def __schema__(cls) -> Schema:
        return super().__schema__() | Schema(
            description="A type for names",
            format="name-format",
        )

As can be seen in the example, __schema__() implementations are expected to return a dict extending its super().__schema__(), however this is not a requirement and any Schema-compatible dict can be returned.