A scratch-built, modern Maven plugin for seamless protoc integration. Provides support for native and JVM-based protoc plugins, as well as automatic dependency resolution and incremental code generation.
Note
Full documentation with usage examples can be found within the plugin documentation, and examples are present in the integration tests.
Getting started is very simple. The following will compile any sources that are found in
src/main/protobuf
to Java classes and pop them in target/generated-sources
where Maven
will automatically discover them and compile them to Java bytecode.
<plugin>
<groupId>io.github.ascopes</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<configuration>
<protocVersion>${protobuf-java.version}</protocVersion>
</configuration>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
</plugin>
Tip
Any *.proto
files that are discovered in project dependencies will be made available
to protoc
,
so you can import them in exactly the same way you would with Java classes
Other language generation targets are also available. This plugin provides support for generating all the languages that protoc supports out of the box, including Kotlin, Python, Python typeshed stubs, Ruby, PHP, C#, C++, and Rust.
The following will generate Java classes and corresponding Kotlin wrappers:
<plugin>
<groupId>io.github.ascopes</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<configuration>
<kotlinEnabled>true</kotlinEnabled>
<protocVersion>${protobuf-java.version}</protocVersion>
</configuration>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
</plugin>
Native Maven dependency management is supported out of the box, allowing you to use Maven as an artifact registry for bundles of Proto files seamlessly.
<project>
...
<dependencies>
<dependency>
<groupId>org.example.protos</groupId>
<artifactId>user-protos</artifactId>
<version>1.2.3</version>
<type>zip</type>
</dependency>
</dependencies>
<plugins>
<plugin>
<groupId>io.github.ascopes</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<configuration>
<protocVersion>${protobuf-java.version}</protocVersion>
</configuration>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</project>
The following snippet will compile any protobuf sources in src/main/protobuf
to Java source code,
and then proceed to generate gRPC wrappers and Reactor gRPC wrappers.
<plugin>
<groupId>io.github.ascopes</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<configuration>
<protocVersion>${protobuf-java.version}</protocVersion>
<!-- Vanilla protoc plugins - these are platform specific executables
just like protoc is. -->
<binaryMavenPlugins>
<binaryMavenPlugin>
<groupId>io.grpc</groupId>
<artifactId>protoc-gen-grpc-java</artifactId>
<version>${grpc.version}</version>
<options>@generated=omit</options>
</binaryMavenPlugin>
</binaryMavenPlugins>
<!-- JVM plugins are distributed as JARs rather than native system
executables. The protobuf-maven-plugin will automatically bootstrap
them for you. -->
<jvmMavenPlugins>
<jvmMavenPlugin>
<groupId>com.salesforce.servicelibs</groupId>
<artifactId>reactor-grpc</artifactId>
<version>${reactor-grpc.version}</version>
</jvmMavenPlugin>
</jvmMavenPlugins>
</configuration>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
</plugin>