Skip to content

Releases: grpc/grpc-swift

2.0.0-beta.3

17 Jan 15:52
ebcac53
Compare
Choose a tag to compare

What's Changed

💥 API changes

  • The transport protocols are now generic over a bag-of-bytes type which the MessageSerializer and MessageDeserializer protocols are now defined in terms of. This allows for the transport and serialization layers to avoid copying incoming and outgoing bytes via intermediate types. This also means that GRPCServer and GRPCClient are now generic over a transport which may impact your code. You will also be required to regenerate your code. (#2155)
  • The interceptor pipeline operation types have been replaced with a ConditonalInterceptor to deduplicate the types used. (#2157)
  • GRPCClient.run() was deprecated and renamed to GRPCClient.runConnections(). run() will be removed in a future release. (#2156)
  • The ClientContext and ServerContext added new properties for remote and local peer information. These should only be breaking changes for transport implementations.

✨ New APIs

  • Add remote/local peer info to the ClientContext and have the ClientTransport provide it. This is also a breaking change for transport implementations. (#2158)
  • Add local info to the ServerContext. This is also a breaking change for transport implementations. (#2161)

⚙️ Code generation

  • Make empty generated source files descriptive by (#2151, #2152)
  • Extend structured swift to support generic structs (#2154)

🔧 Other changes

Full Changelog: 2.0.0-beta.2...2.0.0-beta.3

2.0.0-beta.2

20 Dec 15:33
0696e0a
Compare
Choose a tag to compare

What's Changed

✨ New APIs

  • The RPCErrorConvertible protocol was added in #2143 which allows the gRPC server runtime to convert conforming types to an appropriate status code and message to send back to the client.

💡 Examples

Two new examples have been added:

  1. reflection-server demonstrates the gRPC Reflection Service which has been added to grpc/grpc-swift-extras. (Added in #2149)
  2. error-details demonstrates the detailed error model which is made available via the grpc/grpc-swift-protobuf package. (Added in #2145)

🔧 Other Changes

Full Changelog: 2.0.0-beta.1...2.0.0-beta.2

2.0.0-beta.1

05 Dec 14:34
e390c85
Compare
Choose a tag to compare

What's Changed

2.0.0-beta.1 includes a number of API breaking changes from 2.0.0-alpha.1, including changes to the generated code.

⚙️ Code generation

The generated code has had a number of changes:

  • Nested protocols and types. The various protocols generated for each service are now nested within the namespace of each service. This is a breaking change. If your generated service was previously called FooService_ServiceProtocol then it will now be nested within the FooService enum and will be FooService.ServiceProtocol. This also applies to the client protocol, client struct, and streaming service protocol.
  • Simple service protocol. Another simpler protocol is now generated (SimpleServiceProtocol) making it easier to implement services. This is the recommended protocol to implement if you don't need access to metadata.
  • Documentation. Generated code now includes documentation on how to use it and includes any documentation from the source IDL.

These changes were done in #2114, #2115, #2116, #2117, #2122, #2125, #2126, #2128, #2129, #2131, #2132, #2133, #2134, #2137, #2138, #2139, and #2141.

🔄 Interceptors

Interceptors can now be registered per-service and per-method in addition to being applied to all methods. This work was done in #2096 and #2113.

✨ Other notable changes

  • RPC cancellation handler. Service implementers can use withRPCCancellationHandler(operation:onCancelRPC:) to register a callback which is invoked when the RPC is cancelled. (#2090)
  • Remote peer information. The server context now contains information about the identity of the remote peer. (#2136)
  • "with-" methods for client and server allow you to more easily run a client and server. (#2121)
  • MethodDescriptor now uses ServiceDescriptor to represent the fully qualified service name. (#2127)
  • Allow metadata to be mutated on server responses. Metadata can now be mutated in place on server responses. (#2120)
  • GRPCCore is no longer @_exported, this is a breaking change and requires you to add an explicit dependency on GRPCCore and import it where appropriate. (#2109)
  • Flatten RPCError cause to avoid deeply nested errors of the same type. (#2083)

🐛 Bug fixes

  • Fix decoding of durations in MethodConfig (#2093)
  • Fix route guide tutorial (#2094)

🔧 Other Changes

Full Changelog: 2.0.0-alpha.1...2.0.0-beta.1

gRPC Swift 1.24.2

11 Nov 15:38
8c5e99d
Compare
Choose a tag to compare

SemVer Patch

  • Bump min version of swift-nio-extras (#2101)
  • Remove underscored v2 code from v1 (#2110)
  • Bump version number to 1.24.2 (#2111)

gRPC Swift 1.24.1

08 Oct 06:32
3ef3a9f
Compare
Choose a tag to compare

SemVer Minor

  • Raise minimum Swift version to 5.9 (#2064)

SemVer Patch

  • Ensure file path isn't percent encoded in the plugin (#2086)
  • Bump version number to 1.24.0 (#2088)

Other Changes

  • Update branch name in CI (#2087)

gRPC Swift 1.24.0

07 Oct 19:02
d5e0d70
Compare
Choose a tag to compare

⚠️ This release was incorrectly tagged. Please use 1.24.1.

gRPC Swift 2.0.0-alpha.1

01 Oct 13:58
432c955
Compare
Choose a tag to compare

🚀 The gRPC Swift team is excited to announce the first alpha release of gRPC Swift v2! 🚀

Highlights 🌟

  • An async/await implementation from the ground up. The new library is built on top of Swift's native concurrency features and takes advantage of structured concurrency to make it easier to reason about your RPCs. It's also built from the ground up to support the Swift 6 language mode.
  • Expressive and easy to use APIs. Our APIs have been designed to be simple to use for newcomers and flexible enough for expert users.
  • Pluggable transport layer. The underlying transport for clients and servers have been abstracted away to a transport layer; SwiftNIO is now an implementation detail and brought in via a separate package, grpc/grpc-swift-nio-transport.
  • Pluggable serialisation. The serialisation layer is also pluggable, support for Swift Protobuf is made available via grpc/grpc-swift-protobuf.
  • Better performance than v1. Benchmarks show that the SwiftNIO based transport for v2 is up to 80% faster than the equivalent benchmarks for gRPC Swift v1.

Getting started 📚

Please note that this is pre-release software, we don't guarantee any API stability and this shouldn't be considered production ready.

To get started with gRPC Swift v2, take a look at our examples and documentation:

Feedback 💬

If you have any questions or feedback be it good, bad, big, or small please let us know by opening an issue.

gRPC Swift 1.23.1

18 Sep 14:52
07123ed
Compare
Choose a tag to compare

SemVer Patch

  • Swift 6-ify the package manifest (#1955)
  • Fix warnings in SwiftPM plugin (#1958)
  • Update to protobuf 1.27.0 (#1973)
  • Improve error message for missing reflection data (#2038)
  • Use SwiftProtobuf's new CodeGenerator interface (#2043)
  • Stop using deprecated protobuf API (#2045)
  • Bump version number to 1.23.1 (#2062)

Other Changes

  • Manually cleanup unix domain socket path in NIOTS test (#1951)
  • Add integ test for SwiftPM plugin (#1956)
  • Move v1 examples to v1 subdirectory (#1963)
  • Update test certs (#1966)
  • Fix broken symlinks (#1988)
  • Update test certs (#1998)
  • Fix tests to work with unreleased swift-nio changes (#2001)
  • Add check that generated code is up-to-date (#2013)
  • Add docc docs for grpc core (#2016)
  • Use Swift 6 to build docs on Swift Package Index (#2020)
  • Move examples to top-level (#2024)
  • Regenerate protos (#2039)
  • Update plugin bundling script (#2053)

gRPC Swift 1.23.0

22 Apr 12:54
6a90b7e
Compare
Choose a tag to compare

SemVer Minor

SemVer Patch

  • Remove GRPCLogger (#1853)
  • Bump version number to 1.23.0 (#1863)

Other Changes

  • Update formatting script (#1845)
  • Update release GitHub workflow action (#1847, #1848)

gRPC Swift 1.22.0

02 Apr 14:14
393b02b
Compare
Choose a tag to compare

SemVer Minor

  • Add a minimum connections configuration to the ConnectionPool (#1822)
  • Raise minimum swift version to 5.8 (#1825)

SemVer Patch

  • Log connection age when closing a connection (#1799)
  • Notify of quiescing when there are no open streams on graceful shutdown (#1819)
  • Update Version.swift (#1846)

Other Changes