A scratch-built, modern Maven plugin for seamless protoc integration. Features include:
- Running
protocfrom Maven Central, the system path, or URLs - Running
protocplugins from binaries on the system path, Maven Central, or from various URLs- This includes when packaged within tarballs or ZIP files!
- Running
protocplugins that are packaged as regular JARs - Building from descriptor files
- Building from dependencies
- Generating descriptor files
- Discovering
*.protosources from your project dependencies - Filtering sources based upon globs
- Injecting custom arguments and environment variables into
protoc - Incremental analysis to avoid rebuilding large projects when no changes have been made
- Digest verification of
protocand any plugins - Running any executables from an optional sanctioned path, for corporate users in tightly-locked-down build environments
- Ability to dynamically skip plugins if not resolved on certain platforms (e.g. if working with plugins that are only packaged for Linux)
Full documentation with usage examples can be found within the plugin documentation, and examples are present in the integration tests.
Note
The v4 release of this plugin requires a minimum of Java 17 and Maven 3.9 to operate. If you require the ability to use Maven 3.8 or Java 11, please use the latest v3 release from Maven Central!
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>
<protoc>${protobuf-java.version}</protoc>
</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 (JVM), Python, Python typeshed stubs, and Ruby.
The following will generate Java classes and corresponding Kotlin wrappers:
<plugin>
<groupId>io.github.ascopes</groupId>
<artifactId>protobuf-maven-plugin</artifactId>
<configuration>
<javaEnabled>true</javaEnabled>
<kotlinEnabled>true</kotlinEnabled>
<protoc>${protobuf-java.version}</protoc>
</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>
<protoc>${protobuf-java.version}</protoc>
</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>
<protoc>${protobuf-java.version}</protoc>
<!-- 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>
</binaryMavenPlugin>
</binaryMavenPlugins>
<!-- JVM plugins are distributed as JARs rather than native system
executables. The protobuf-maven-plugin will automatically bootstrap
them for you, without the need for additional
tooling for your platform. It should "just work". -->
<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>