Releases ยท connectrpc/connect-python

v0.9.0

BREAKING CHANGE: PyPI package renamed to connectrpc

This is the last version being published as the connect-python package - we are migrated to connectrpc as part of this release to match the same code you write with it and will only publish future versions to connectrpc. We will update these release notes after it's complete, and them make sure to update your dependency specifications to connectrpc.


This release includes a significant rework to compression handling - now, it is possible to implement custom compression methods or configure defaults with custom parameters. This release also allows configuring the supported compression methods for a server rather than automatically inspecting from application dependencies. Defaults now match other Connect implementations, only enabling gzip by default.

We have also added some other small enhancements like gRPC-Web support and improved debugging.

โ˜ข๏ธ Breaking changes

Pass compressions rather than strings when configuring the client

Before:

GreeterClient("http://localhost", accept_compressions=["zstd", "br", "gzip"])

After:

from connectrpc.compression.brotli import BrotliCompression
from connectrpc.compression.gzip import GzipCompression
from connectrpc.compression.zstd import ZstdCompression

GreeterClient("http://localhost", accept_compressions=[
    ZstdCompression(), BrotliCompression(), GzipCompression()
])

To configure a client to use gRPC protocol, pass protocol=ProtocolType.GRPC instead of grpc=True

Before:

GreeterClient("http://localhost", grpc=True)

After:

from connectrpc.protocol import ProtocolType

GreeterClient("http://localhost", protocol=ProtocolType.GRPC)

Metadata interceptors now accept Error | None in on_end

Before:

class MyInterceptor:
    def on_end(self, token, ctx):
        ...

After:

class MyInterceptor:
    def on_end(self, token, ctx, error):
        ...

๐Ÿ“ˆ Enhancements

๐Ÿ› ๏ธ Bug fixes

  • Process GET params for empty request messages by @Zaczero in #121

New Contributors

Full Changelog: v0.8.1...v0.9.0

v0.8.1

This hotfix fixes the default compression level used with gzip, which previously was set too high causing performance issues.

๐Ÿ› ๏ธ Bug fixes

๐Ÿ™‡ Thank you

This release was possible thanks to the following contributors who shared their brilliant ideas

@Zaczero

Full Changelog: v0.8.0...v0.8.1

v0.8.0

This is a big release - the client now supports bidirectional streaming and the gRPC protocol. With this, connect-python is now a full-featured Connect implementation!

This is enabled by switching our HTTP client transport to pyqwest, a Python interface to the Rust HTTP client reqwest. This client supports all features of HTTP, allowing us to also support bidirectional streaming and gRPC (via HTTP trailers) in turn.

Keep in mind though that this is a very new project, built specifically to push connect-python forward. The underlying reqwest library has been in use for some time and should be battle-tested, but the Python wrapper is new - let us know if you run into any issues so we can fix them.

โ˜ข๏ธ Breaking changes

  • The HTTP transport for clients has been changed to pyqwest. If you created connect clients with default parameters, this will not need any further changes, but if passing a custom session, you will now need to pass a pyqwest client.

Before:

ctx = ssl.create_default_context(cafile="ca.path")
async with (
  httpx.AsyncClient(verify=ctx, http2=True) as session,
  GreeterClient("http://localhost", session=session) as client:
)

After:

async with (
  pyqwest.HTTPTransport(
    tls_ca_cert=Path("ca.path").read(), 
    http_version=pyqwest.HTTPVersion.HTTP2
  ) as transport,
  GreeterClient("http://localhost", http_client=pyqwest.Client(transport)
)

If you have unit tests using httpx.ASGITransport / httpx.WSGITransport, you also will need to migrate to pyqwest.testing.ASGITransport / pyqwest.testing.WSGITransport.

๐Ÿ“ˆ Enhancements

๐Ÿ› ๏ธ Bug fixes

  • Avoid yielding messages on GeneratorExit in sync server by @anuraaga in #90
  • Drain request body in all error cases in WSGI by @anuraaga in #94

Full Changelog: v0.7.1...v0.8.0

v0.7.1

This release fixes a conflict preventing using this library along with grpc-python, possibly from dependencies.

๐Ÿ› ๏ธ Bug fixes

  • Use custom package for grpc status.proto by @anuraaga in #76

๐Ÿ™‡ Thank you

This release was possible thanks to the following contributors who shared their brilliant ideas

@gibsondan

Full Changelog: v0.7.0...v0.7.1

v0.7.0

This release includes initial support for the gRPC protocol in connect-python. It is currently only supported on the server side and requires using pyvoy for its support for HTTP/2 trailers.

๐Ÿ“ˆ Enhancements

๐Ÿ› ๏ธ Bug fixes

  • Set default accept-encoding to compression algorithms supported by the client by @achille-roussel in #71

๐Ÿ™‡ Thank you

This release was possible thanks to the following contributors who shared their brilliant ideas and pull requests

@achille-roussel

Full Changelog: v0.6.0...v0.7.0

v0.6.0

Since the first release of the current codebase, we have been focused on fleshing out docs and our conformance testing suite. We hope to have the new docs out on connectrpc.com soon so it's even easier to get started. Feature-wise, we have integration with ASGI lifespan to allow declaring async initialization logic and some improvement to the WSGI implementation.

๐Ÿ“ˆ Enhancements

๐Ÿ› ๏ธ Bug fixes

  • Do multiple reads for WSGI even with content length by @anuraaga in #37

๐Ÿ™‡ Thank you

This release was possible thanks to the following contributors who shared their brilliant ideas

@maaft
@rockwotj

Full Changelog: v0.5.0...v0.6.0

v0.5.0