Skip to content

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

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

v0.1.0

22 Dec 16:17
v0.1.0
a96695e
Compare
Choose a tag to compare

Freqenz Client Base Library Release Notes

Summary

First release of the Freqenz Client Base Library, that exposes a retry strategy implementations and a generic grpc streaming helper.

Upgrading

New Features

  • Imports retry strategies and the generic grpc streaming helper from the SDK.

Bug Fixes

What's Changed

  • Add a grpc streaming helper by @shsms in #4
  • Release preparation by @shsms in #6

New Contributors

  • @shsms made their first contribution in #4

Full Changelog: https://github.com/frequenz-floss/frequenz-client-base-python/commits/v0.1.0