Skip to main content

HTTP/2 framing layer for Python

Project description

https://travis-ci.org/python-hyper/hyperframe.png?branch=master

This library contains the HTTP/2 framing code used in the hyper project. It provides a pure-Python codebase that is capable of decoding a binary stream into HTTP/2 frames.

This library is used directly by hyper and a number of other projects to provide HTTP/2 frame decoding logic.

Contributing

hyperframe 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

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

Authors

hyperframe is maintained by Cory Benfield, with contributions from others. For more details about the contributors, please see CONTRIBUTORS.rst.

Release History

3.2.0 (2016-02-02)

API Changes (Backward-compatible)

  • Invalid PING frame bodies now raise InvalidFrameError, not ValueError. Note that InvalidFrameError is a ValueError subclass.

  • Invalid RST_STREAM frame bodies now raise InvalidFramError, not ValueError. Note that InvalidFrameError is a ValueError subclass.

  • Canonicalized the names of SettingsFrame.SETTINGS_MAX_FRAME_SIZE and SettingsFrame.SETTINGS_MAX_HEADER_LIST_SIZE to match their peers, by adding new properties SettingsFrame.MAX_FRAME_SIZE and SettingsFrame.SETTINGS_MAX_HEADER_LIST_SIZE. The old names are still present, but will be deprecated in 4.0.0.

Bugfixes

  • The change in 3.1.0 that ensured that InvalidFrameError would be thrown did not affect certain invalid values in ALT_SVC frames. This has been fixed: ValueError will no longer be thrown from invalid ALT_SVC bodies.

3.1.1 (2016-01-18)

Bugfixes

  • Correctly error when receiving Ping frames that have insufficient data.

3.1.0 (2016-01-13)

API Changes

  • Added new InvalidFrameError that is thrown instead of struct.error when parsing a frame.

Bugfixes

  • Fixed error when trying to serialize frames that use Priority information with the defaults for that information.

  • Fixed errors when displaying the repr of frames with non-printable bodies.

3.0.1 (2016-01-08)

Bugfixes

  • Fix issue where unpadded DATA, PUSH_PROMISE and HEADERS frames that had empty bodies would raise InvalidPaddingError exceptions when parsed.

3.0.0 (2016-01-08)

Backwards Incompatible API Changes

  • Parsing padded frames that have invalid padding sizes now throws an InvalidPaddingError.

2.2.0 (2015-10-15)

API Changes

  • When an unknown frame is encountered, parse_frame_header now throws a ValueError subclass: UnknownFrameError. This subclass contains the frame type and the length of the frame body.

2.1.0 (2015-10-06)

API Changes

  • Frames parsed from binary data now carry a body_len attribute that matches the frame length (minus the frame header).

2.0.0 (2015-09-21)

API Changes

  • Attempting to parse unrecognised frames now throws ValueError instead of KeyError. Thanks to @Kriechi!

  • Flags are now validated for correctness, preventing setting flags that hyperframe does not recognise and that would not serialize. Thanks to @mhils!

  • Frame properties can now be initialized in the constructors. Thanks to @mhils and @Kriechi!

  • Frames that cannot be sent on a stream now have their stream ID defaulted to 0. Thanks to @Kriechi!

Other Changes

  • Frames have a more useful repr. Thanks to @mhils!

1.1.1 (2015-07-20)

  • Fix a bug where FRAME_MAX_LEN was one byte too small.

1.1.0 (2015-06-28)

  • Add body_len property to frames to enable introspection of the actual frame length. Thanks to @jdecuyper!

1.0.1 (2015-06-27)

  • Fix bug where the frame header would have an incorrect length added to it.

1.0.0 (2015-04-12)

  • Initial extraction from hyper.

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

hyperframe-3.2.0.tar.gz (16.2 kB view details)

Uploaded Source

Built Distribution

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

hyperframe-3.2.0-py2.py3-none-any.whl (13.6 kB view details)

Uploaded Python 2Python 3

File details

Details for the file hyperframe-3.2.0.tar.gz.

File metadata

  • Download URL: hyperframe-3.2.0.tar.gz
  • Upload date:
  • Size: 16.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for hyperframe-3.2.0.tar.gz
Algorithm Hash digest
SHA256 05f0e063e117c16fcdd13c12c93a4424a2c40668abfac3bb419a10f57698204e
MD5 ce7c8f96b6533f0350041ea90e55b1bb
BLAKE2b-256 50967080c938d2b06105365bae946c77c78a32d9e763eaa05d0e431b02d7bc12

See more details on using hashes here.

File details

Details for the file hyperframe-3.2.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for hyperframe-3.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 4dcab11967482d400853b396d042038e4c492a15a5d2f57259e2b5f89a32f755
MD5 82a3051da4d90d6a60e43ee3dff683d9
BLAKE2b-256 d88944ff46f15dba53a8c16cb8cab89ecb1e44f8aa211628b43d341004cfcf7a

See more details on using hashes here.

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