GeoStore is an open source Java enterprise application for storing, searching and retrieving data on the fly.
GeoStore performs authentication internally (auth framework shall be pluggable), and internal authorization rules grant permissions on single Resources or whole Categories.
A comprehensive REST API allows an easy handling of internal resources, so that client side applications can easily query the store, while remote server side application can integrate with GeoStore using the GeoStoreClient, an utility java class that hides the REST communications complexities.
For more information check the GeoStore wiki .
The release procedure is essentially made of 2 steps:
- Cut major branch
- Effective Release
The project is developed on the main (master) branch, containing the latest -SNAPSHOT
version of the modules of the project. When a major release starts the validation process, a new release branch is created (see Cut-Release, named <major-version>.xx
.
After this on the main (master) branch the -SNAPSHOT
version of the modules is increased and from this point the main branch will include commits for the next major version of the project.
When the validation process is completed and all the fixes have been applied to the release branch, the version of the java modules is fixed, commit is tagged with the number of the release and the Github release is published. See Release.
After this on the release brach the -SNAPSHOT
version of the modules is restored so that it is possible to continue applying fixes and minor improvements, creating more releases on it with the same procedure, until end of maintainance.
Here the steps to follow for executing the 2 procedures :
- Run the workflow Cut Release branch passing
- Branch Master
- current version
- next version
- main branch (keep
master
) - other options (can be left as default)
- Merge the PR that is generated, if not merged automatically
- Run the workflow Release with the folling parameters:
- select the branch to use (e.g.
2.1.x
) - version to release (e.g.
2.1.0
) - base version (e.g.
2.1
)
- select the branch to use (e.g.
The release will be automatically published on GitHub. Packages will be automatically deployed on maven repository.
- CI: Automatically does tests for pull request or commits on
master
. For commits on the main repo (e.g. when PR are merged onmaster
or stable branches, the workflow publish also the artifacts on GeoSolutions Maven Repository - Cut release branch: (
cut-major-branch.yml
): Manually triggered workflow that allows to create a stable branch named<current-version>.x
and create a pull request for updatingmaster
branch-SNAPSHOT
version with the new data. - Release: (
cut-major-branch.yml
): Manually triggered workflow to apply to the stable branch that fixes the maven modules versions, tags the commit, build and deploy artifacts, restores snapshot versions and publish a Github release on the tagged commit.
GeoStore core modules are free and Open Source software, released under the GPL v3 license.
GeoStore is being developed by GeoSolutions hence you can talk to us for professional support. Anyway the project is a real Open Source project hence you can contribute to it (see section below).
We welcome contributions in any form:
- pull requests for new features
- pull requests for bug fixes
- pull requests for documentation
- funding for any combination of the above