This repository stores templates used to set up workflows for new repositories.
Clone this repository to your disk and run setup-workflows.sh
. It copies the necessary files to the correct
locations in your new repository.
./update-workflows.sh <path-to-new-repository> <type>
Search for TODO
in the copied files and replace the placeholders with the correct values. The same script can be used to update
all files in case of major changes in the templates.
main
branch to get the most recent templates.
- Release management is done with semantic-release. Releases are automatically tagged and published on GitHub. Special releases for Maven Central and Terraform modules are supported.
- stale issue and PR management
- welcome message for contributors
- linters for all files
- PRs are checked for semantic commit titles to ensure an automatic release
- ChatOps to run workflows from comments
- a
.config/dictionaries/project.txt
file for the spell checker exceptions
- Add all workflows to
.github/workflows/
, otherwise they can't be referenced from the repositories. - Workflows with
this_
prefix are used for this repository only. - Workflows with
default_
prefix are added to every new repository. Otherwise, use the correct prefix for the project type.
The script to set up the workflows for new repositories is update-workflows.sh
. It copies the necessary files to the new
repository. It starts with the default workflows and adds the specific ones based on the project type. In case of a filename clash,
the specific template overwrites the default one (exception: .gitignore
These files are concatenated).
Use
# USE_REPOSITORY
# push:
# branches:
# - main
# /USE_REPOSITORY
in the file to describe the triggers which should be used in the repository. The script will automatically replace the triggers
marked with USE_WORKFLOW
which are valid within this repository only.
- Add the words to the
.config/dictionaries/workflow.txt
file. .config/dictionaries/project.txt
file is used for the project specific words of the project being set up.- All other dictionaries are managed by the
Repository-Template-*
repositories.