Skip to main content

HTTP/2 State-Machine based protocol implementation

Project description

This repository is a fork of the well known hyper/h2 package. We want to provide a cleaner and faster HTTP/2 state machine while keeping a pure Python implementation. We decided to embed the leaf dependencies as we want a neater dependency tree and along with that a easier maintenance burden. We believe it was a mistake to ship three packages (h2, hpack, and hyperframe).

Analysis shown that h2 spend a lot of time doing hpack encode and decode operations, this is why we decided to offer a complementary optimized build. The pure Python version will still be available.

This repository contains a pure-Python implementation of a HTTP/2 protocol stack. It’s written from the ground up to be embeddable in whatever program you choose to use, ensuring that you can speak HTTP/2 regardless of your programming paradigm.

You use it like this:

import jh2.connection
import jh2.config

config = jh2.config.H2Configuration()
conn = jh2.connection.H2Connection(config=config)
conn.send_headers(stream_id=stream_id, headers=headers)
conn.send_data(stream_id, data)
socket.sendall(conn.data_to_send())
events = conn.receive_data(socket_data)

This repository does not provide a parsing layer, a network layer, or any rules about concurrency. Instead, it’s a purely in-memory solution, defined in terms of data actions and HTTP/2 frames. This is one building block of a full Python HTTP implementation.

To install it, just run:

$ python -m pip install jh2

Documentation

Documentation is available at https://h2.readthedocs.io .

Contributing

jh2 welcomes contributions from anyone! Unlike many other projects we are happy to accept cosmetic contributions and small contributions, in addition to large feature requests and changes.

Before you contribute (either by opening an issue or filing a pull request), please read the contribution guidelines.

License

jh2 is made available under the MIT License. For more details, see the LICENSE file in the repository.

Authors

h2 was authored by Cory Benfield and is maintained by the Jawah OSS organization under the jh2 name.

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

jh2-5.0.3.tar.gz (7.3 MB view hashes)

Uploaded Source

Built Distributions

jh2-5.0.3-py3-none-any.whl (98.1 kB view hashes)

Uploaded Python 3

jh2-5.0.3-pp310-pypy310_pp73-win_amd64.whl (241.6 kB view hashes)

Uploaded PyPy Windows x86-64

jh2-5.0.3-pp310-pypy310_pp73-musllinux_1_1_x86_64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ x86-64

jh2-5.0.3-pp310-pypy310_pp73-musllinux_1_1_armv7l.whl (1.4 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARMv7l

jh2-5.0.3-pp310-pypy310_pp73-musllinux_1_1_aarch64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARM64

jh2-5.0.3-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

jh2-5.0.3-pp310-pypy310_pp73-manylinux_2_17_s390x.manylinux2014_s390x.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ s390x

jh2-5.0.3-pp310-pypy310_pp73-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.2 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64le

jh2-5.0.3-pp310-pypy310_pp73-manylinux_2_17_ppc64.manylinux2014_ppc64.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64

jh2-5.0.3-pp310-pypy310_pp73-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARMv7l

jh2-5.0.3-pp310-pypy310_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARM64

jh2-5.0.3-pp310-pypy310_pp73-macosx_11_0_arm64.whl (349.5 kB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

jh2-5.0.3-pp310-pypy310_pp73-macosx_10_12_x86_64.whl (352.4 kB view hashes)

Uploaded PyPy macOS 10.12+ x86-64

jh2-5.0.3-pp310-pypy310_pp73-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (604.3 kB view hashes)

Uploaded PyPy macOS 10.12+ universal2 (ARM64, x86-64) macOS 10.12+ x86-64 macOS 11.0+ ARM64

jh2-5.0.3-pp39-pypy39_pp73-win_amd64.whl (241.6 kB view hashes)

Uploaded PyPy Windows x86-64

jh2-5.0.3-pp39-pypy39_pp73-musllinux_1_1_x86_64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ x86-64

jh2-5.0.3-pp39-pypy39_pp73-musllinux_1_1_armv7l.whl (1.4 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARMv7l

jh2-5.0.3-pp39-pypy39_pp73-musllinux_1_1_aarch64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARM64

jh2-5.0.3-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

jh2-5.0.3-pp39-pypy39_pp73-manylinux_2_17_s390x.manylinux2014_s390x.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ s390x

jh2-5.0.3-pp39-pypy39_pp73-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.2 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64le

jh2-5.0.3-pp39-pypy39_pp73-manylinux_2_17_ppc64.manylinux2014_ppc64.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64

jh2-5.0.3-pp39-pypy39_pp73-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARMv7l

jh2-5.0.3-pp39-pypy39_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARM64

jh2-5.0.3-pp39-pypy39_pp73-macosx_11_0_arm64.whl (349.5 kB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

jh2-5.0.3-pp39-pypy39_pp73-macosx_10_12_x86_64.whl (352.3 kB view hashes)

Uploaded PyPy macOS 10.12+ x86-64

jh2-5.0.3-pp39-pypy39_pp73-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (604.1 kB view hashes)

Uploaded PyPy macOS 10.12+ universal2 (ARM64, x86-64) macOS 10.12+ x86-64 macOS 11.0+ ARM64

jh2-5.0.3-pp38-pypy38_pp73-win_amd64.whl (241.6 kB view hashes)

Uploaded PyPy Windows x86-64

jh2-5.0.3-pp38-pypy38_pp73-musllinux_1_1_x86_64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ x86-64

jh2-5.0.3-pp38-pypy38_pp73-musllinux_1_1_armv7l.whl (1.4 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARMv7l

jh2-5.0.3-pp38-pypy38_pp73-musllinux_1_1_aarch64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARM64

jh2-5.0.3-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

jh2-5.0.3-pp38-pypy38_pp73-manylinux_2_17_s390x.manylinux2014_s390x.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ s390x

jh2-5.0.3-pp38-pypy38_pp73-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.2 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64le

jh2-5.0.3-pp38-pypy38_pp73-manylinux_2_17_ppc64.manylinux2014_ppc64.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64

jh2-5.0.3-pp38-pypy38_pp73-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARMv7l

jh2-5.0.3-pp38-pypy38_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARM64

jh2-5.0.3-pp38-pypy38_pp73-macosx_11_0_arm64.whl (349.6 kB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

jh2-5.0.3-pp38-pypy38_pp73-macosx_10_12_x86_64.whl (352.6 kB view hashes)

Uploaded PyPy macOS 10.12+ x86-64

jh2-5.0.3-pp38-pypy38_pp73-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (604.6 kB view hashes)

Uploaded PyPy macOS 10.12+ universal2 (ARM64, x86-64) macOS 10.12+ x86-64 macOS 11.0+ ARM64

jh2-5.0.3-pp37-pypy37_pp73-win_amd64.whl (244.2 kB view hashes)

Uploaded PyPy Windows x86-64

jh2-5.0.3-pp37-pypy37_pp73-musllinux_1_1_x86_64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ x86-64

jh2-5.0.3-pp37-pypy37_pp73-musllinux_1_1_armv7l.whl (1.4 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARMv7l

jh2-5.0.3-pp37-pypy37_pp73-musllinux_1_1_aarch64.whl (1.3 MB view hashes)

Uploaded PyPy musllinux: musl 1.1+ ARM64

jh2-5.0.3-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

jh2-5.0.3-pp37-pypy37_pp73-manylinux_2_17_s390x.manylinux2014_s390x.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ s390x

jh2-5.0.3-pp37-pypy37_pp73-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.2 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64le

jh2-5.0.3-pp37-pypy37_pp73-manylinux_2_17_ppc64.manylinux2014_ppc64.whl (1.3 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ppc64

jh2-5.0.3-pp37-pypy37_pp73-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARMv7l

jh2-5.0.3-pp37-pypy37_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (1.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARM64

jh2-5.0.3-pp37-pypy37_pp73-macosx_11_0_arm64.whl (352.4 kB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

jh2-5.0.3-pp37-pypy37_pp73-macosx_10_12_x86_64.whl (355.7 kB view hashes)

Uploaded PyPy macOS 10.12+ x86-64

jh2-5.0.3-pp37-pypy37_pp73-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (611.1 kB view hashes)

Uploaded PyPy macOS 10.12+ universal2 (ARM64, x86-64) macOS 10.12+ x86-64 macOS 11.0+ ARM64

jh2-5.0.3-cp37-abi3-win_arm64.whl (237.1 kB view hashes)

Uploaded CPython 3.7+ Windows ARM64

jh2-5.0.3-cp37-abi3-win_amd64.whl (242.7 kB view hashes)

Uploaded CPython 3.7+ Windows x86-64

jh2-5.0.3-cp37-abi3-musllinux_1_1_x86_64.whl (1.3 MB view hashes)

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

jh2-5.0.3-cp37-abi3-musllinux_1_1_armv7l.whl (1.4 MB view hashes)

Uploaded CPython 3.7+ musllinux: musl 1.1+ ARMv7l

jh2-5.0.3-cp37-abi3-musllinux_1_1_aarch64.whl (1.3 MB view hashes)

Uploaded CPython 3.7+ musllinux: musl 1.1+ ARM64

jh2-5.0.3-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.1 MB view hashes)

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

jh2-5.0.3-cp37-abi3-manylinux_2_17_s390x.manylinux2014_s390x.whl (1.3 MB view hashes)

Uploaded CPython 3.7+ manylinux: glibc 2.17+ s390x

jh2-5.0.3-cp37-abi3-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl (1.2 MB view hashes)

Uploaded CPython 3.7+ manylinux: glibc 2.17+ ppc64le

jh2-5.0.3-cp37-abi3-manylinux_2_17_ppc64.manylinux2014_ppc64.whl (1.3 MB view hashes)

Uploaded CPython 3.7+ manylinux: glibc 2.17+ ppc64

jh2-5.0.3-cp37-abi3-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (1.1 MB view hashes)

Uploaded CPython 3.7+ manylinux: glibc 2.17+ ARMv7l

jh2-5.0.3-cp37-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (1.1 MB view hashes)

Uploaded CPython 3.7+ manylinux: glibc 2.17+ ARM64

jh2-5.0.3-cp37-abi3-macosx_11_0_arm64.whl (351.0 kB view hashes)

Uploaded CPython 3.7+ macOS 11.0+ ARM64

jh2-5.0.3-cp37-abi3-macosx_10_12_x86_64.whl (353.8 kB view hashes)

Uploaded CPython 3.7+ macOS 10.12+ x86-64

jh2-5.0.3-cp37-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (607.4 kB view hashes)

Uploaded CPython 3.7+ macOS 10.12+ universal2 (ARM64, x86-64) macOS 10.12+ x86-64 macOS 11.0+ ARM64

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