data-plane-api 0.1.1

Envoy xDS protobuf and gRPC definitions
Documentation
# Releasing PGV Java components

These steps are for releasing the Java components of PGV:

- pgv-java-stub
- pgv-java-grpc
- pgv-artifacts

## Releasing using CI

Releasing from main is fully automated by CI:

Releasing from versioned tags is similar. To release version `vX.Y.Z`, first
create a Git tag called `vX.Y.Z` (preferably through the GitHub release flow),
then run the following to kick off a release build:

The [`Maven Deploy`](../.github/workflows/maven-publish.yaml) CI flow will use the version number from the tag to deploy
to the Maven repository.

## Manually releasing from git history

Manually releasing from git history is a more involved process, but allows you
to release from any point in the history.

1. Create a new `release/x.y.z` branch at the point you want to release.
1. Copy `java/settings.xml` to a scratch location.
1. Fill out the parameters in `settings.xml`. You will need a published GPG key
   for code signing and the EnvoyReleaseBot sonatype username and password.
1. Execute the release command, substituting the path to `settings.xml`, the
   `releaseVersion`, and the next `developmentVersion` (-SNAPSHOT).
1. Merge the release branch back into master.

```shell
mvn -B -s /path/to/settings.xml clean release:prepare release:perform \
  -Darguments="-s /path/to/settings.xml" \
  -DreleaseVersion=x.y.z \
  -DdevelopmentVersion=x.y.z-SNAPSHOT \
  -DscmCommentPrefix="java release: "
```