Skip to main content

fast marshmallow multiplexing schema

Project description

An extension to marshmallow to support fast schema (de)multiplexing.

marshmallow is a fantastic library for serialization and deserialization of data. For more on that project see its GitHub page or its Documentation.

This library adds a special kind of schema that actually multiplexes other schemas based on object type. When serializing values, it uses get_obj_type() method to get object type name. Then it uses type_schemas name-to-Schema mapping to get schema for that particular object type, serializes object using that schema and adds an extra field with name of object type. Deserialization is reverse.

Installing

This fork is designed to be a drop‑in replacement for marshmallow-oneofschema.

Using uv:

$ uv add marshmallow-fastoneofschema

Using poetry:

$ poetry add marshmallow-fastoneofschema

pip:

$ pip install marshmallow-fastoneofschema

Note: If marshmallow-oneofschema remains installed alongside this fork, the library logs an error and uses the fast fork. For reliability, uninstall the upstream package to avoid any packaging/order surprises. This wheel also includes a small startup hook (.pth) that redirects imports of marshmallow_oneofschema to the fast fork, even if the upstream was installed later. You can disable this behavior by setting FASTONEOFSCHEMA_DISABLE_PTH=1.

Example

The code below demonstrates how to set up a polymorphic schema. For the full context check out the tests. Once setup the schema should act like any other schema. If it does not then please file an Issue.

import marshmallow
import marshmallow.fields
from marshmallow_fastoneofschema import OneOfSchema


class Foo:
    def __init__(self, foo):
        self.foo = foo


class Bar:
    def __init__(self, bar):
        self.bar = bar


class FooSchema(marshmallow.Schema):
    foo = marshmallow.fields.String(required=True)

    @marshmallow.post_load
    def make_foo(self, data, **kwargs):
        return Foo(**data)


class BarSchema(marshmallow.Schema):
    bar = marshmallow.fields.Integer(required=True)

    @marshmallow.post_load
    def make_bar(self, data, **kwargs):
        return Bar(**data)


class MyUberSchema(OneOfSchema):
    type_schemas = {"foo": FooSchema, "bar": BarSchema}

    def get_obj_type(self, obj):
        if isinstance(obj, Foo):
            return "foo"
        elif isinstance(obj, Bar):
            return "bar"
        else:
            raise Exception("Unknown object type: {}".format(obj.__class__.__name__))


MyUberSchema().dump([Foo(foo="hello"), Bar(bar=123)], many=True)
# => [{'type': 'foo', 'foo': 'hello'}, {'type': 'bar', 'bar': 123}]

MyUberSchema().load(
    [{"type": "foo", "foo": "hello"}, {"type": "bar", "bar": 123}], many=True
)
# => [Foo('hello'), Bar(123)]

By default get_obj_type() returns obj.__class__.__name__, so you can just reuse that to save some typing:

class MyUberSchema(OneOfSchema):
    type_schemas = {"Foo": FooSchema, "Bar": BarSchema}

You can customize type field with type_field class property:

class MyUberSchema(OneOfSchema):
    type_field = "object_type"
    type_schemas = {"Foo": FooSchema, "Bar": BarSchema}


MyUberSchema().dump([Foo(foo="hello"), Bar(bar=123)], many=True)
# => [{'object_type': 'Foo', 'foo': 'hello'}, {'object_type': 'Bar', 'bar': 123}]

You can use resulting schema everywhere marshmallow.Schema can be used, e.g.

import marshmallow as m
import marshmallow.fields as f


class MyOtherSchema(m.Schema):
    items = f.List(f.Nested(MyUberSchema))

License

MIT licensed. See the bundled LICENSE file for more details.

Performance & Compatibility Notes

  • This fork preserves the public API and error shapes of the upstream package.

  • Optimizations avoid unnecessary copies when type_field_remove is False and reduce overhead for many=True in default configurations.

  • Aggressive instance caching can be disabled via FOO_DISABLE_AGGRESSIVE_MODE=1 if needed.

  • Supported Python versions: 3.11+.

DeepFriedMarshmallow Plugin

This fork ships a DFM plugin that can enable JIT inlining for Nested(OneOfSchema) fields.

  • Discovery: via entry point group deepfriedmarshmallow.plugins or env DFM_PLUGINS.

  • Initial scope: Only engages when get_data_type/get_obj_type are default and all type_schemas keys are strings.

  • Fallback: If conditions aren’t met, DFM falls back to its standard generation.

Per‑Schema Controls & Flags

Migration

Basic usage stays the same (plug‑and‑play). For projects that want to migrate explicitly to the new names:

  • Replace dependency marshmallow-oneofschema with this fork.

  • Optionally switch imports to the new package/class names: - from marshmallow_fastoneofschema import FastOneOfSchema - Or keep from marshmallow_oneofschema import OneOfSchema (alias provided). - Existing code continues to work; new names are recommended for clarity.

  • Env flags: - FOO_DISABLE_AGGRESSIVE_MODE=1: disable instance caching. - FOO_CONTEXT_ISOLATION=1: enable per-task schema instance caching (ContextVars).

  • Per-schema overrides via class Meta: fastoneof = {...}: - aggressive_mode: bool - context_isolation: bool

  • Per-request overrides via ContextVars (advanced): - OneOfSchema._foo_aggressive_ctx.set(True|False) - OneOfSchema._foo_isolation_ctx.set(True|False)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file marshmallow_fastoneofschema-2025.9.2.1.dev5.tar.gz.

File metadata

File hashes

Hashes for marshmallow_fastoneofschema-2025.9.2.1.dev5.tar.gz
Algorithm Hash digest
SHA256 d235a69fe48d52f9e17b8c6af220d2f622ccf19091010a676c6ef9c60c040b72
MD5 c313e4b85f97205eb56561a2ccda7126
BLAKE2b-256 846daf40bb16236f6f2492f015feb6145cb1b14fbcff08cc32738b049bb19a88

See more details on using hashes here.

Provenance

The following attestation bundles were made for marshmallow_fastoneofschema-2025.9.2.1.dev5.tar.gz:

Publisher: ci.yml on Kalepa/marshmallow-fastoneofschema

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file marshmallow_fastoneofschema-2025.9.2.1.dev5-py3-none-any.whl.

File metadata

File hashes

Hashes for marshmallow_fastoneofschema-2025.9.2.1.dev5-py3-none-any.whl
Algorithm Hash digest
SHA256 da3b0c808f3118bb44d04e16d150e08de7141bce4d9fc86fedae480715865c85
MD5 6fc2d8035cb7284b03b5d485a10e0933
BLAKE2b-256 bac93dabe790163a0ac2c4135a51adf75c1546b5aee60f243aa6fb4db57a6c63

See more details on using hashes here.

Provenance

The following attestation bundles were made for marshmallow_fastoneofschema-2025.9.2.1.dev5-py3-none-any.whl:

Publisher: ci.yml on Kalepa/marshmallow-fastoneofschema

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page