gitea-actions/.github/workflows/maven-publish.yml
2025-02-27 12:25:08 +01:00

64 lines
1.9 KiB
YAML

# This workflow will build a package using Maven and then publish it to GitHub packages when a release is created
# For more information see: https://github.com/actions/setup-java/blob/main/docs/advanced-usage.md#apache-maven-with-a-settings-path
name: Maven Publish
on:
workflow_call:
secrets:
AWS_CA_USER:
required: true
AWS_CA_PASSWORD:
required: true
jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- uses: actions/checkout@v4
- name: Set up Maven
uses: stCarolas/setup-maven@v5
with:
maven-version: '3.9.9'
- name: Set up JDK 8
uses: actions/setup-java@v4
with:
java-version: '8'
distribution: 'corretto'
cache: maven
overwrite-settings: false
run: echo -e "$MVN_SETTINGS_XML" > ~/.m2/settings.xml
env:
MVN_SETTINGS_XML: ${{ secrets.MVN_SETTINGS_XML }}
- name: Set up AWS Cli
run: |
curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip"
unzip -q awscliv2.zip
./aws/install
export TOKEN=`aws codeartifact get-authorization-token --region eu-west-1 --domain pravila --domain-owner 867459752380 --query authorizationToken --output text`
echo "CODEARTIFACT_AUTH_TOKEN=$TOKEN" >> $GITHUB_ENV
env:
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_CA_USER }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_CA_PASSWORD }}
- name: Build with Maven
run: |
mvn -B clean package --file pom.xml -s mvn-settings.xml
- name: Deploy artifacts
run: |
mvn deploy --file pom.xml -s mvn-settings.xml -DrepositoryId=deploy
env:
GITHUB_TOKEN: ${{ github.token }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_CA_USER }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_CA_PASSWORD }}