This repository contains multiple reusable actions for my projects
Builds a maven project w/o maven central and JDK 17
name: Maven Verify
on:
push: # Ignore releases and main dev branch
tags-ignore:
- 'v*'
branches-ignore:
- 'main'
pull_request:
types: [opened, synchronize, reopened]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
verify:
uses: dfuchss/actions/.github/workflows/maven.yml@main
with:
deploy: false
with-submodules: true
secrets:
OSSRH_USER: ${{secrets.OSSRH_USER}}
OSSRH_TOKEN: ${{secrets.OSSRH_TOKEN}}
GPG_KEY: ${{secrets.GPG_KEY}}
name: Maven Deploy
on:
push:
branches:
- 'main' # Build the latest develop-SNAPSHOT
paths:
- '**/src/**'
- '**/pom.xml'
- 'pom.xml'
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
publish:
uses: dfuchss/actions/.github/workflows/maven.yml@main
with:
deploy: true
secrets:
OSSRH_USER: ${{secrets.OSSRH_USER}}
OSSRH_TOKEN: ${{secrets.OSSRH_TOKEN}}
GPG_KEY: ${{secrets.GPG_KEY}}
Update Dependencies and Update Versions
name: Maven Dependency Updates
on:
schedule:
- cron: "00 11 * * 2"
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
update:
uses: dfuchss/actions/.github/workflows/maven-update.yml@main
secrets:
# Needs to be a personal access token to push as a certain user; otherwise actions won't be triggered.
PAT: ${{ secrets.PAT }}
Create a new GitHub Release (Aggregate logs from "Maven Dependency Updates" action)
name: Create Release
on:
workflow_dispatch:
push:
# Publish `v1.2.3` tags as releases.
tags:
- v*
jobs:
release:
uses: dfuchss/actions/.github/workflows/github-release.yml@main
Create new Maven Release (only commits tags & branch and updates versions)
name: Maven Release
on:
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
update:
uses: dfuchss/actions/.github/workflows/maven-release.yml@main
secrets:
# Needs to be a personal access token to push as a certain user; otherwise actions won't be triggered.
PAT: ${{ secrets.PAT }}
Verify a maven project via sonarcloud
name: Sonar Cloud
on:
push:
pull_request:
types: [opened, synchronize, reopened]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
sonarcloud:
if: ${{ github.actor != 'dependabot[bot]' }}
uses: dfuchss/actions/.github/workflows/sonarcloud.yml@main
with:
with-submodules: true
secrets:
SONAR_TOKEN: ${{secrets.SONAR_TOKEN}}
Build and Publish a Docker Image
name: Docker with Push
on:
push:
branches:
- 'main' # Build the latest develop-SNAPSHOT
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
publish:
uses: dfuchss/actions/.github/workflows/docker.yml@main
with:
image-name: "myimage"
push: true