Skip to content

Releases: frequenz-floss/frequenz-client-base-python

v0.8.1

19 Nov 13:38
v0.8.1
b9cb307
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

This release adds some arguments that were missing in the parse_grpc_uri() function's documentation.

What's Changed

  • Clear release notes by @llucax in #97
  • Remove unnecessary --platform flag in Dockerfile by @llucax in #98
  • Update parse_grpc_uri docs with keep-alive params by @shsms in #99

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

v0.8.0

19 Nov 08:49
v0.8.0
f03d3e5
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Upgrading

The BaseApiClient class is generic again. There was too many issues with the new approach, so it was rolled back.

  • If you are upgrading from v0.7.x, you should be able to roll back your changes with the upgrade and just keep the new stub property.

    # Old
    from __future__ import annotations
    import my_service_pb2_grpc
    class MyApiClient(BaseApiClient):
       def __init__(self, server_url: str, *, ...) -> None:
           super().__init__(server_url, ...)
           stub = my_service_pb2_grpc.MyServiceStub(self.channel)
           self._stub: my_service_pb2_grpc.MyServiceAsyncStub = stub  # type: ignore
           ...
    
       @property
       def stub(self) -> my_service_pb2_grpc.MyServiceAsyncStub:
           if self.channel is None:
               raise ClientNotConnected(server_url=self.server_url, operation="stub")
           return self._stub
    
    # New
    from __future__ import annotations
    import my_service_pb2_grpc
    from my_service_pb2_grpc import MyServiceStub
    class MyApiClient(BaseApiClient[MyServiceStub]):
       def __init__(self, server_url: str, *, ...) -> None:
           super().__init__(server_url, MyServiceStub, ...)
           ...
    
       @property
       def stub(self) -> my_service_pb2_grpc.MyServiceAsyncStub:
           """The gRPC stub for the API."""
           if self.channel is None or self._stub is None:
               raise ClientNotConnected(server_url=self.server_url, operation="stub")
           # This type: ignore is needed because we need to cast the sync stub to
           # the async stub, but we can't use cast because the async stub doesn't
           # actually exists to the eyes of the interpreter, it only exists for the
           # type-checker, so it can only be used for type hints.
           return self._stub  # type: ignore
  • If you are upgrading from v0.6.x, you should only need to add the stub property to your client class and then use that property instead of _stub in your code.

       @property
       def stub(self) -> my_service_pb2_grpc.MyServiceAsyncStub:
           """The gRPC stub for the API."""
           if self.channel is None or self._stub is None:
               raise ClientNotConnected(server_url=self.server_url, operation="stub")
           # This type: ignore is needed because we need to cast the sync stub to
           # the async stub, but we can't use cast because the async stub doesn't
           # actually exists to the eyes of the interpreter, it only exists for the
           # type-checker, so it can only be used for type hints.
           return self._stub  # type: ignore

What's Changed

  • Clear release notes by @shsms in #94
  • Bump the required group with 9 updates by @dependabot in #95
  • Revert "Remove generic type from BaseApiClient" by @llucax in #96

Full Changelog: v0.7.0...v0.8.0

v0.7.0

29 Oct 13:30
v0.7.0
3d35fe7
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

This release improves the BaseApiClient interface and introduces HTTP2 keep-alive, among other changes.

Upgrading

  • GrpcStreamBroadcaster now takes a AsyncIterable instead of a AsyncIterator as the stream_method. This is to match the type of streaming methods generated by grpc, so no conversion to an AsyncIterator is needed.

  • GrpcStreamBroadcaster no longer tries to reconnect when a server closes a connection. This behaviour can be overridden by passing retry_on_exhausted_stream=True when constructing GrpcStreamBroadcaster instances.

  • gRPC URLs don't have a default port anymore, unless a default is set via ChannelOptions. If you want to set a default port for URLs, please pass custom ChannelOptions as defaults to parse_grpc_uri or as channel_defaults to BaseApiClient.

  • The ExponentialBackoff and LinearBackoff classes now require keyword arguments for their constructor. This change was made to make the classes easier to use and to avoid confusion with the order of the arguments.
  • HTTP2 keep-alive is now enabled by default, with an interval of 60 seconds between pings, and a 20 second timeout for responses from the service. These values are configurable and may be updated based on specific requirements.
  • The BaseApiClient class is not generic anymore, and doesn't take a function to create the stub. Instead, subclasses should create their own stub right after calling the parent constructor. This enables subclasses to cast the stub to the generated XxxAsyncStub class, which have proper async type hints. To convert you client:

    # Old
    from my_service_pb2_grpc import MyServiceStub
    class MyApiClient(BaseApiClient[MyServiceStub]):
        def __init__(self, server_url: str, *, ...) -> None:
            super().__init__(server_url, MyServiceStub, ...)
            ...
    
    # New
    from __future__ import annotations
    import my_service_pb2_grpc
    class MyApiClient(BaseApiClient):
        def __init__(self, server_url: str, *, ...) -> None:
            super().__init__(server_url, connect=connect)
            stub = my_service_pb2_grpc.MyServiceStub(self.channel)
            # We need the type: ignore here because the generated async stub only lives in
            # the .pyi file (the interpreter doesn't know anything about it) so we can't use
            # a proper `cast()`, we can only use the async stub as a type hint.
            self._stub: my_service_pb2_grpc.MyServiceAsyncStub = stub  # type: ignore
            ...
    
        @property
        def stub(self) -> my_service_pb2_grpc.MyServiceAsyncStub:
            if self.channel is None:
                raise ClientNotConnected(server_url=self.server_url, operation="stub")
            return self._stub

    You probably also need to ignore the no-member check from pylint, as pylint doesn't read *.pyi files, so it won't find the async stub and complain.

    [tool.pylint.messages_control]
    disable = [
      # [..]
      # Checked by mypy
      "no-member",
      # [..]
    ]

    After this, you should be able to remove a lot of casts or type: ignore from the code when calling the stub async methods.

New Features

  • Added support for HTTP2 keep-alive.

What's Changed

  • Clear release notes by @shsms in #83
  • Replace the stream_method return to AsyncIterable by @llucax in #87
  • Don't allow a default port in URLs by default by @llucax in #85
  • Bump the required group with 9 updates by @dependabot in #89
  • Don't retry by default when the stream is exhausted by @shsms in #91
  • Support http2 keep-alive by @shsms in #90
  • Remove generic type from BaseApiClient by @llucax in #92
  • Prepare for v0.7.0 by @shsms in #93

Full Changelog: v0.6.1...v0.7.0

v0.6.1

03 Sep 09:47
v0.6.1
1eec18a
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Bug Fixes

  • Fixes a bug in creating grpc channels from ipv6 URIs.

What's Changed

  • Clear release notes by @llucax in #76
  • Bump the required group with 9 updates by @dependabot in #78
  • Use netloc from urlparse to specify the host by @shsms in #79
  • Prepare release notes for v0.6.1 by @shsms in #82

Full Changelog: v0.6.0...v0.6.1

v0.6.0

26 Aug 10:41
v0.6.0
e1c02e5
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

This version removes grpclib support and adds new SSL options to the connection URI.

Upgrading

  • grpclib was removed, if you used grpclib you should switch to grpcio instead.

    You should also update your dependency to frequenz-client-base (without any [grpclib] or [grpcio] suffix). Also, now there is no need to pass around the channel type to the BaseApiClient or the parse_grpc_uri function.

  • The parse_grpc_uri function (and BaseApiClient constructor) now enables SSL by default (ssl=false should be passed to disable it).

  • The parse_grpc_uri and BaseApiClient function now accepts a set of defaults to use when the URI does not specify a value for a given option.

New Features

  • The connection URI can now have a few new SSL options:

    • ssl_root_certificates_path to specify the path to the root certificates file.
    • ssl_private_key_path to specify the path to the private key file.
    • ssl_certificate_chain_path to specify the path to the certificate chain file.

What's Changed

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

v0.5.0

26 Jul 08:29
v0.5.0
0553ddc
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

The main features of this release is the new base class for API clients, gRPC exception wrappers and a new utility function to call stub methods.

Upgrading

  • channel.parse_grpc_uri() takes an extra argument, the channel type (which can be either grpclib.client.Channel or grpcio.aio.Channel).

New Features

  • Add a exception module to provide client exceptions, including gRPC errors with one subclass per gRPC error status code.
  • channel.parse_grpc_uri() can now be used with grpcio too.
  • A new BaseApiClient class is introduced to provide a base class for API clients. It is strongly recommended to use this class as a base class for all API clients.
  • A new call_stub_method() function to simplify calling stub methods, converting gRPC errors to ApiClientErrors, checking if the client is connected and optionally wrapping the response.

What's Changed

  • Clear the release notes by @llucax in #53
  • Add client exceptions by @llucax in #55
  • Bump the required group with 7 updates by @dependabot in #57
  • Add grpcio support to parse_grpc_uri() by @llucax in #54
  • Add a BaseApiClient class by @llucax in #56
  • Improve type-checking for _grpchacks by @llucax in #59
  • Add a function to call gRPC stubs and wrap errors by @llucax in #58
  • Bump docker/build-push-action from 5 to 6 by @dependabot in #61
  • Bump the required group with 9 updates by @dependabot in #60
  • Bump brettcannon/check-for-changed-files from 1.2.0 to 1.2.1 by @dependabot in #62
  • Prepare release notes for the 0.5 release by @llucax in #63

Full Changelog: v0.4.0...v0.5.0

v0.4.0

14 May 13:50
v0.4.0
63d0589
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

Upgrading

  • You should now install the dependency using frequenz-client-base[grpcio] (or frequenz-client-base[grpclib]) if you want to migrate to grpclib).
  • GrpcStreamBroadcaster's stream_method callback now should return an AsyncIterator instead of a grpc.aio.UnaryStreamCall, this is so it is compatible with both grpcio and grpclib. Normally no changes should be needed, as a grpc.aio.UnaryStreamCall should be a AsyncIterator, but since grpcio doesn't have correct type hints, you might need to adjust the cast() if you are using one.

New Features

  • GrpcStreamBroadcaster is now compatible with both grpcio and grpclib implementations of gRPC. Just install frequenz-client-base[grpcio] or frequenz-client-base[grpclib] to use the desired implementation and everything should work as expected.
  • A new module channel with a function to parse URIs to create grpclib client Channel instances.

Bug Fixes

  • Fixed retrying for GrpcStreamBroadcaster when the retry interval is set to 0 (before it would stop retrying if the interval was set to 0).

What's Changed

  • Clear RELEASE_NOTES.md by @shsms in #36
  • Bump types-protobuf from 4.24.0.20240129 to 4.24.0.20240311 by @dependabot in #39
  • Bump nox from 2023.4.22 to 2024.3.2 by @dependabot in #38
  • Update protobuf requirement from <5,>=4.21.6 to >=4.21.6,<6 by @dependabot in #40
  • Bump the optional group with 10 updates by @dependabot in #43
  • Bump the required group with 7 updates by @dependabot in #44
  • Bump types-protobuf from 4.24.0.20240311 to 5.26.0.20240422 by @dependabot in #45
  • Remove TODOs by @llucax in #46
  • Bump repo-config to v0.9.2 by @llucax in #47
  • Fix the condition to run the nox-(cross-arch-)?all jobs by @llucax in #48
  • ci: Fix pip cache post step by @llucax in #50
  • Make GrpcStreamBroadcaster compatible with both grpcio and grpclib by @llucax in #49
  • Fix GrpcStreamBroadcaster retry with a 0 interval by @llucax in #52
  • Add parsing of gRPC channel URIs by @llucax in #51

Full Changelog: v0.3.0...v0.4.0

v0.3.0

11 Mar 11:43
v0.3.0
6230161
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

This release updates the minimum required frequenz-channels version is updated
to v1.0.0-rc1. This is a breaking change, because the channels API has changed.

Upgrading

Follow the upgrading instructions from the new channel release: v1.0.0-rc1.

What's Changed

  • Don't create nox sessions twice in cross-arch tests by @llucax in #34
  • Clear release notes by @llucax in #33
  • Update minimum frequenz-channels version to v1.0.0-rc1 by @shsms in #35

Full Changelog: v0.2.1...v0.3.0

v0.2.1

05 Mar 08:33
v0.2.1
59c0330
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

  • The generated docs now show the type of symbol in the table of contents and have cross-linking to the protobuf and channels documentation.
  • The minimum supported version of protobuf was downgraded to 4.21.6, so downstream projects having this older version as minimum requirements can still use this release.

What's Changed

Full Changelog: v0.2.0...v0.2.1

v0.2.0

01 Mar 12:01
v0.2.0
427cbf6
Compare
Choose a tag to compare

Frequenz Client Base Library Release Notes

Summary

This release does a bit of restructuring and renaming of classes and modules. It also adds some new features and fixes some bugs.

Upgrading

The project structure was updated to use more consistent and shorter modules and class names.

  • frequenz.client.base.grpc_streaming_helper was renamed to frequenz.client.base.streaming.

    • The GrpcStreamingHelper class was renamed to GrpcStreamBroadcaster.

      • The constructor argument retry_spec was renamed to retry_strategy.
  • frequenz.client.base.retry_strategy was renamed to frequenz.client.base.retry.

    • The RetryStrategy class was renamed to Strategy.

New Features

  • Functions to convert to datetime and protobufs Timestamp have been added.
  • The generated documentation was improved to include information on defaults and generic parameters.

Bug Fixes

  • When copying RetryStrategys, the type now will be correctly set to the original type.

What's Changed

New Contributors

Full Changelog: v0.1.0...v0.2.0