The Buf Schema Registry’s generated SDKs make it easy for developers to download generated code just like any other package, without needing a local Protobuf toolchain. The BSR already has support for Go modules via its Go module proxy, and JavaScript and TypeScript packages with its NPM registry. Today we’re adding to that lineup, by launching the Buf Maven repository, supporting Java and Kotlin plugins (including connect-kotlin!).
The Buf Maven repository allows developers to consume SDKs generated from Protobuf schemas with their favorite build tools, like Maven and Gradle.
As an example, we can create a small project that uses gradle
to pull in a package from the Buf Maven repository, and then use Connect-Kotlin to call the Connect Demo API.
First, ensure that gradle
is installed and on your $PATH
. Then, create a new directory for the example:
mkdir buf-maven-example
cd buf-maven-example
And create the following build.gradle.kts
file inside it:
plugins {
kotlin("jvm") version "1.8.21"
application
}
repositories {
mavenCentral()
maven {
url = uri("https://buf.build/gen/maven")
}
}
dependencies {
// This dependency has been remotely generated!
implementation("build.buf.gen:connectrpc_eliza_bufbuild_connect-kotlin:0.1.7.1.20230727062025.d8fbf2620c60")
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:1.6.4")
implementation("build.buf:connect-kotlin-okhttp:0.1.7")
}
application {
mainClass.set("MainKt")
}
Next, create a src/main/kotlin
directory:
$ mkdir -p src/main/kotlin
And create a file within it called Main.kt
with the following content:
src/main/kotlin/Main.kt
import build.buf.connect.ProtocolClientConfig
import build.buf.connect.extensions.GoogleJavaProtobufStrategy
import build.buf.connect.impl.ProtocolClient
import build.buf.connect.okhttp.ConnectOkHttpClient
import build.buf.connect.protocols.NetworkProtocol
// These two are from our generated package!
import build.buf.gen.connectrpc.eliza.v1.ElizaServiceClient
import build.buf.gen.connectrpc.eliza.v1.sayRequest
import kotlinx.coroutines.runBlocking
import okhttp3.OkHttpClient
fun main(): Unit = runBlocking {
val okHttpClient = OkHttpClient()
val client = ProtocolClient(
httpClient = ConnectOkHttpClient(okHttpClient),
ProtocolClientConfig(
host = "https://demo.connectrpc.com/",
serializationStrategy = GoogleJavaProtobufStrategy(),
networkProtocol = NetworkProtocol.CONNECT,
),
)
val elizaClient = ElizaServiceClient(client)
try {
println(elizaSay(elizaClient, "hello"))
} finally {
okHttpClient.dispatcher.executorService.shutdown()
}
}
private suspend fun elizaSay(client: ElizaServiceClient, message: String): String {
val response = client.say(sayRequest { sentence = message })
response.failure<Void> { throw RuntimeException("failed with ${it.code}: ${it.error}") }
val sentence = response.success { it.message.sentence }
return sentence!!
}
From there, you should be able to gradle run
to download dependencies, build the project and run it:
$ gradle run
Output
> Task :run
Hello...I'm glad you could drop by today.
The output listed below > Task :run
is the response from Eliza, meaning that we’ve successfully interacted with the Connect Demo API!
The Buf Maven repository is similar to the BSR’s NPM registry and Go module proxy, in that it supports all the BSR features our users have come to rely on in their workflows, like private repositories and branches. It also has support for the Protobuf Lite Runtime.
We’ve updated the SDKs tab with instructions for using Maven and Gradle. As an example, check out buf.build/connectrpc/eliza/sdks/main and select “Maven” in the Platform dropdown.
The syntax for versions in the Buf Maven repository may look familiar if you’ve seen them used in the NPM registry and Go module proxy. For Maven, it is:
{pluginVersion}.{pluginRevision}.{moduleTimestamp}.{moduleCommit}
This syntax allows tools like Dependabot to pick up new versions of the package whenever a new version of a plugin is available or new versions are pushed to the module.
Similar to NPM and Go, using the Buf Maven repository with private repositories requires a little more setup, but we’ve also updated the SDKs tab and our docs for generated SDKs with instructions.
The Buf Maven repository has support for staged commits—again, the SDKs tab is your friend here! Select a branch from the dropdown, and navigate to the Generated SDKs tab.
One thing you’ll notice about commit versions on branches is that they always contain 00000000000000
for their timestamp component—this makes it easier to determine visually when a dependency is on a branch, and also ensures that a branch commit will never sort higher than a main
commit.
The Buf Maven repository has support for creating packages based on the Protobuf Lite Runtime, ideal for mobile applications. Simply append _lite
to the package name to get a package compiled with lite runtime support (for plugins that support the Lite Runtime—which currently is all of them).
We’re already planning to add a Swift package registry to remote packages, as a backbone for Connect-Swift. As always, we’d love to hear from you—feedback and questions are welcome on the Buf Slack!