Skip to main content

Protocol Buffers at runtime

Project description

Protosaurus

Parse and create ProtoBuffer messages at runtime. Deserialize Protobuf from Kafka using kcat and a schema registry.

Pip Action Status Wheel Action Status PyPi

Installation

pip install protosaurus

Usage

Deserialize Protobuf from Kafka using a schema registry

If a schema registry is available, Protosaurus can deserialize Protobuf messages in Kafka automatically:

kcat -C -e -F <kafka.config> -t <topic> -f "%o\\n%k\\n%R%s" | protosaurus - --schema-registry <url>

Using pipx:

kcat -C -e -F <kafka.config> -t <topic> -f "%o\\n%k\\n%R%s" | pipx run protosaurus - --schema-registry <url>

Parse Proto in Python

Protosaurus can parse .proto definitions at runtime without using protoc. This allows Protobuf byte arrays to be converted to JSON and vice versa.

import json
from protosaurus import Context
from base64 import b64decode

# create a context which stores the proto schemas
ctx = Context()

# add protos by specifying name and content
ctx.add_proto('diet.proto',
    """
    syntax = "proto3";
    enum Diet {
        carnivorous = 0;
        herbivorous = 1;
    }
    """)

# the proto can be imported via the specified name
ctx.add_proto('animal.proto',
    """
    syntax = "proto3";
    import "diet.proto";
    message Animal {
        string name = 1;
        Diet diet = 2;
        double length = 3;
    }
    """)

# convert a message from base64 string...
data = ctx.to_json('Animal', b64decode('CglJZ3Vhbm9kb24QARkAAAAAAAAkQA=='))

# ...or hex string
data = ctx.to_json('Animal', bytes.fromhex('0a09496775616e6f646f6e1001190000000000002440'))

print(data)
# >>> '{"name":"Iguanodon","diet":"herbivorous","length":10}'


# convert json to protobuf
data = ctx.from_json('Animal', json.dumps({"name":"Iguanodon","diet":"herbivorous","length":10}))

print(data)
# >>> b'\n\tIguanodon\x10\x01\x19\x00\x00\x00\x00\x00\x00$@'

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

protosaurus-0.3.2.tar.gz (18.3 kB view hashes)

Uploaded Source

Built Distributions

protosaurus-0.3.2-pp310-pypy310_pp73-win_amd64.whl (667.8 kB view hashes)

Uploaded PyPy Windows x86-64

protosaurus-0.3.2-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-pp310-pypy310_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

protosaurus-0.3.2-pp310-pypy310_pp73-macosx_10_14_x86_64.whl (825.7 kB view hashes)

Uploaded PyPy macOS 10.14+ x86-64

protosaurus-0.3.2-pp39-pypy39_pp73-win_amd64.whl (667.7 kB view hashes)

Uploaded PyPy Windows x86-64

protosaurus-0.3.2-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-pp39-pypy39_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

protosaurus-0.3.2-pp39-pypy39_pp73-macosx_10_14_x86_64.whl (825.7 kB view hashes)

Uploaded PyPy macOS 10.14+ x86-64

protosaurus-0.3.2-pp38-pypy38_pp73-win_amd64.whl (667.8 kB view hashes)

Uploaded PyPy Windows x86-64

protosaurus-0.3.2-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-pp38-pypy38_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

protosaurus-0.3.2-pp38-pypy38_pp73-macosx_10_14_x86_64.whl (825.7 kB view hashes)

Uploaded PyPy macOS 10.14+ x86-64

protosaurus-0.3.2-cp312-abi3-win_amd64.whl (667.4 kB view hashes)

Uploaded CPython 3.12+ Windows x86-64

protosaurus-0.3.2-cp312-abi3-win32.whl (596.2 kB view hashes)

Uploaded CPython 3.12+ Windows x86

protosaurus-0.3.2-cp312-abi3-musllinux_1_1_x86_64.whl (1.6 MB view hashes)

Uploaded CPython 3.12+ musllinux: musl 1.1+ x86-64

protosaurus-0.3.2-cp312-abi3-musllinux_1_1_i686.whl (1.8 MB view hashes)

Uploaded CPython 3.12+ musllinux: musl 1.1+ i686

protosaurus-0.3.2-cp312-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded CPython 3.12+ manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-cp312-abi3-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.12+ manylinux: glibc 2.17+ i686

protosaurus-0.3.2-cp312-abi3-macosx_11_0_arm64.whl (795.9 kB view hashes)

Uploaded CPython 3.12+ macOS 11.0+ ARM64

protosaurus-0.3.2-cp312-abi3-macosx_10_14_x86_64.whl (825.9 kB view hashes)

Uploaded CPython 3.12+ macOS 10.14+ x86-64

protosaurus-0.3.2-cp311-cp311-win_amd64.whl (668.6 kB view hashes)

Uploaded CPython 3.11 Windows x86-64

protosaurus-0.3.2-cp311-cp311-win32.whl (597.9 kB view hashes)

Uploaded CPython 3.11 Windows x86

protosaurus-0.3.2-cp311-cp311-musllinux_1_1_x86_64.whl (1.6 MB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ x86-64

protosaurus-0.3.2-cp311-cp311-musllinux_1_1_i686.whl (1.8 MB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ i686

protosaurus-0.3.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ i686

protosaurus-0.3.2-cp311-cp311-macosx_11_0_arm64.whl (798.2 kB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

protosaurus-0.3.2-cp311-cp311-macosx_10_14_x86_64.whl (827.6 kB view hashes)

Uploaded CPython 3.11 macOS 10.14+ x86-64

protosaurus-0.3.2-cp310-cp310-win_amd64.whl (668.7 kB view hashes)

Uploaded CPython 3.10 Windows x86-64

protosaurus-0.3.2-cp310-cp310-win32.whl (598.0 kB view hashes)

Uploaded CPython 3.10 Windows x86

protosaurus-0.3.2-cp310-cp310-musllinux_1_1_x86_64.whl (1.6 MB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ x86-64

protosaurus-0.3.2-cp310-cp310-musllinux_1_1_i686.whl (1.8 MB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ i686

protosaurus-0.3.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ i686

protosaurus-0.3.2-cp310-cp310-macosx_11_0_arm64.whl (798.3 kB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

protosaurus-0.3.2-cp310-cp310-macosx_10_14_x86_64.whl (827.7 kB view hashes)

Uploaded CPython 3.10 macOS 10.14+ x86-64

protosaurus-0.3.2-cp39-cp39-win_amd64.whl (669.0 kB view hashes)

Uploaded CPython 3.9 Windows x86-64

protosaurus-0.3.2-cp39-cp39-win32.whl (598.5 kB view hashes)

Uploaded CPython 3.9 Windows x86

protosaurus-0.3.2-cp39-cp39-musllinux_1_1_x86_64.whl (1.6 MB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ x86-64

protosaurus-0.3.2-cp39-cp39-musllinux_1_1_i686.whl (1.8 MB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ i686

protosaurus-0.3.2-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ i686

protosaurus-0.3.2-cp39-cp39-macosx_11_0_arm64.whl (798.5 kB view hashes)

Uploaded CPython 3.9 macOS 11.0+ ARM64

protosaurus-0.3.2-cp39-cp39-macosx_10_14_x86_64.whl (827.9 kB view hashes)

Uploaded CPython 3.9 macOS 10.14+ x86-64

protosaurus-0.3.2-cp38-cp38-win_amd64.whl (668.9 kB view hashes)

Uploaded CPython 3.8 Windows x86-64

protosaurus-0.3.2-cp38-cp38-win32.whl (598.3 kB view hashes)

Uploaded CPython 3.8 Windows x86

protosaurus-0.3.2-cp38-cp38-musllinux_1_1_x86_64.whl (1.6 MB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ x86-64

protosaurus-0.3.2-cp38-cp38-musllinux_1_1_i686.whl (1.8 MB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ i686

protosaurus-0.3.2-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.3 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

protosaurus-0.3.2-cp38-cp38-manylinux_2_17_i686.manylinux2014_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ i686

protosaurus-0.3.2-cp38-cp38-macosx_11_0_arm64.whl (798.3 kB view hashes)

Uploaded CPython 3.8 macOS 11.0+ ARM64

protosaurus-0.3.2-cp38-cp38-macosx_10_14_x86_64.whl (827.8 kB view hashes)

Uploaded CPython 3.8 macOS 10.14+ x86-64

Supported by

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