Skip to main content

Pydantic models for implementing JSON Patch.

Project description

Pydantic JSON Patch

Pydantic models for implementing JSON Patch.

Installation

Pydantic JSON Patch is published to PyPI, and can be installed with e.g.:

pip install pydantic-json-patch

Models

A model is provided for each of the six JSON Patch operations:

  • AddOp
  • CopyOp
  • MoveOp
  • RemoveOp
  • ReplaceOp
  • TestOp

As repeating the op is a bit awkward (CopyOp(op="copy", ...)), a create factory method is available:

>>> from pydantic_json_patch import AddOp
>>> op = AddOp.create(path="/foo/bar", value=123)
>>> op
AddOp(op='add', path='/foo/bar', value=123)
>>> op.model_dump_json()
'{"op":"add","path":"/foo/bar","value":123}'

Additionally, there are two compound models:

  • Operation is the union of all the operators; and
  • JsonPatch represents a list of that union type.

Pointer tokens

The path property (and from property, where present) of an operation is a JSON Pointer. This means that any ~ or / characters in property names need to be properly encoded. To aid working with these, the models expose a read-only path_tokens property (and, where appropriate, from_tokens):

>>> from pydantic_json_patch import CopyOp
>>> op = CopyOp.model_validate_json('{"op":"copy","path":"/foo/bar~1new","from":"/foo/bar~0old"}')
>>> op
CopyOp(op='copy', path='/foo/bar~1new', from_='/foo/bar~0old')
>>> op.path_tokens
('foo', 'bar/new')
>>> op.from_tokens
('foo', 'bar~old')

Similarly, the create factory methods can accept tuples of tokens, and will encode them appropriately:

>>> from pydantic_json_patch import TestOp
>>> op = TestOp.create(path=("annotations", "scope/value"), value=None)
>>> op
TestOp(op='test', path='/annotations/scope~1value', value=None)
>>> op.model_dump_json()
'{"op":"test","path":"/annotations/scope~1value","value":null}'

FastAPI

You can use this package to validate a JSON Patch endpoint in a FastAPI application, for example:

import typing as tp
from uuid import UUID

from fastapi import Body, FastAPI

from pydantic_json_patch import JsonPatch

app = FastAPI()


@app.patch("/resource/{resource_id}")
def _(resource_id: UUID, operations: tp.Annotated[JsonPatch, Body()]) -> ...:
    ...

This will provide a sensible example of the request body:

Screenshot of Swagger UI request body example

and list the models along with the other schemas:

Screenshot of Swagger UI schema list

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

pydantic_json_patch-0.1.1.tar.gz (3.7 kB view details)

Uploaded Source

Built Distribution

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

pydantic_json_patch-0.1.1-py3-none-any.whl (4.7 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_json_patch-0.1.1.tar.gz.

File metadata

  • Download URL: pydantic_json_patch-0.1.1.tar.gz
  • Upload date:
  • Size: 3.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pydantic_json_patch-0.1.1.tar.gz
Algorithm Hash digest
SHA256 b1a8eff5664092d2f7e3b9ef6a9bd413dda8b6e698309a50562878b7df1cdfbb
MD5 423ad4a46c40cde10a58377a28108934
BLAKE2b-256 c7e8f93c474ffe9becf3d0c4a02e55a8296bdd32608873018603cc58f37ea831

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydantic_json_patch-0.1.1.tar.gz:

Publisher: push.yml on textbook/pydantic_json_patch

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

File details

Details for the file pydantic_json_patch-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pydantic_json_patch-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 38997828ca2d9aeae87324839966c678d2c17b414e7333fad89fec2143061b2d
MD5 8ede72c31b6ca90f378805b4b9ab291f
BLAKE2b-256 8baa0b1af8b9da409157d2900e3b434f6eaa016f51b6cd6bf993b71aaf1a2b8b

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydantic_json_patch-0.1.1-py3-none-any.whl:

Publisher: push.yml on textbook/pydantic_json_patch

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