Skip to content

Merge branch 'main' into prod #36

Merge branch 'main' into prod

Merge branch 'main' into prod #36

Workflow file for this run

name: CI/CD matomo-noi
on:
push:
paths:
- "data-collectors/matomo-noi/**"
- ".github/workflows/ci-matomo-noi.yml"
env:
WORKING_DIRECTORY: data-collectors/matomo-noi
PROJECT_NAME: odh-mobility-dc-matomo-noi
DOCKER_IMAGE: ghcr.io/${{ github.repository }}/odh-mobility-dc-matomo-noi
DOCKER_TAG: ${{ github.sha }}
JAVA_VERSION: '17'
ODH_ORIGIN: noibzit
ODH_PERIOD: 72000
ODH_STATIONTYPE: Website
jobs:
test:
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v2
- name: REUSE Compliance Check
uses: fsfe/reuse-action@v1
- name: Test code
uses: noi-techpark/github-actions/maven-test@v2
with:
java-version: ${{ env.JAVA_VERSION }}
working-directory: ${{ env.WORKING_DIRECTORY }}
test-command: 'mvn -B -U clean compile test'
# Deploy Test
deploy-test-matomo-noi:
runs-on: ubuntu-20.04
if: github.ref == 'refs/heads/main'
environment: test
needs: test
concurrency: deploy-test-matomo-noi
env:
KEYCLOAK_URL: https://auth.opendatahub.testingmachine.eu
steps:
- name: Checkout source code
uses: actions/checkout@v2
- name: Create .env file
uses: noi-techpark/github-actions/env-file@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}
env:
# General deployment options
X_COMPOSE_PROJECT_NAME: ${{ env.PROJECT_NAME }}
X_DOCKER_IMAGE: ${{ env.DOCKER_IMAGE }}
X_DOCKER_TAG: ${{ env.DOCKER_TAG }}
X_JAVA_OPTIONS: -Xms128m -Xmx512m
# Open Data Hub Writer Connectivity
X_OAUTH_AUTH_URI: ${{ env.KEYCLOAK_URL }}/auth
X_OAUTH_TOKEN_URI: ${{ env.KEYCLOAK_URL }}/auth/realms/noi/protocol/openid-connect/token
X_OAUTH_CLIENT_ID: odh-mobility-datacollector
X_OAUTH_CLIENT_NAME: odh-mobility-datacollector
X_OAUTH_CLIENT_SECRET: ${{ secrets.DATACOLLECTORS_CLIENT_SECRET_TEST }}
X_OAUTH_BASE_URI: https://mobility.share.opendatahub.testingmachine.eu/json
# Data writer settings
X_ODH_CLIENT_PROVENANCE_NAME: ${{ env.PROJECT_NAME }}
X_ODH_CLIENT_PROVENANCE_VERSION: ${{ github.sha }}
X_ODH_CLIENT_PROVENANCE_ORIGIN: ${{ env.ODH_ORIGIN }}
X_ODH_CLIENT_STATIONTYPE: ${{ env.ODH_STATIONTYPE}}
X_ODH_CLIENT_PERIOD: ${{ env.ODH_PERIOD }}
# Matomo API docs https://developer.matomo.org/api-reference/reporting-api
X_MATOMO_API_TOKEN: ${{ secrets.MATOMO_NOI_TOKEN }}
X_MATOMO_BASE_URL: https://noi.matomo.cloud/
X_MATOMO_SITE_ID: 1
# put 0 to disable custom reports
X_MATOMO_REPORT_ID: 0
X_MATOMO_PAGES: https://noi.bz.it/de/ueber-uns/transparente-verwaltung/allgemeine-bestimmungen,https://noi.bz.it/it/chi-siamo/societa-trasparente/disposizioni-generali,https://noi.bz.it/de/ueber-uns/transparente-verwaltung,https://noi.bz.it/it/chi-siamo/societa-trasparente,https://noi.bz.it/de/transparente-verwaltung,https://noi.bz.it/it/societa-trasparente,https://noi.bz.it/it/amministrazione-trasparente
# Logging
X_LOG_LEVEL: info
X_LOG_STYLE: json
# Task scheduler
X_SCHEDULER_JOB_DATA: "0 0 0 * * *"
X_SCHEDULER_POOL_SIZE: 1
- name: Build project
uses: noi-techpark/github-actions/maven-build@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}
java-version: ${{ env.JAVA_VERSION }}
build-command: 'mvn -B -DskipTests -DfinalName=ROOT clean package'
- name: Build and push images
uses: noi-techpark/github-actions/docker-build-and-push@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}/infrastructure
docker-username: ${{ github.actor }}
docker-password: ${{ secrets.GITHUB_TOKEN }}
- name: Deploy application
uses: noi-techpark/github-actions/docker-deploy@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}/infrastructure/ansible
hosts: 'test'
ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}
docker-username: 'noi-techpark-bot'
docker-password: ${{ secrets.GH_PERSONAL_ACCESS_TOKEN }}
project-name: ${{ env.PROJECT_NAME }}
# Deploy Production
deploy-prod-matomo-noi:
runs-on: ubuntu-20.04
if: github.ref == 'refs/heads/prod'
needs: test
concurrency: deploy-prod-matomo-noi
env:
KEYCLOAK_URL: https://auth.opendatahub.com
steps:
- name: Checkout source code
uses: actions/checkout@v2
- name: Create .env file
uses: noi-techpark/github-actions/env-file@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}
env:
# General deployment options
X_COMPOSE_PROJECT_NAME: ${{ env.PROJECT_NAME }}
X_DOCKER_IMAGE: ${{ env.DOCKER_IMAGE }}
X_DOCKER_TAG: ${{ env.DOCKER_TAG }}
X_JAVA_OPTIONS: -Xms128m -Xmx512m
# Open Data Hub Writer Connectivity
X_authorizationUri: ${{ env.KEYCLOAK_URL }}/auth
X_tokenUri: ${{ env.KEYCLOAK_URL }}/auth/realms/noi/protocol/openid-connect/token
X_clientId: odh-mobility-datacollector
X_clientName: odh-mobility-datacollector
X_clientSecret: ${{ secrets.DATACOLLECTORS_CLIENT_SECRET_PROD }}
X_scope: openid
X_BASE_URI: https://mobility.share.opendatahub.bz.it/json
# Matomo API docs https://developer.matomo.org/api-reference/reporting-api
X_MATOMO_API_TOKEN: ${{ secrets.MATOMO_NOI_TOKEN }}
X_MATOMO_BASE_URL: https://noi.matomo.cloud/
X_MATOMO_SITE_ID: 1
# put 0 to disable custom reports
X_MATOMO_REPORT_ID: 0
X_MATOMO_PAGES: https://noi.bz.it/de/ueber-uns/transparente-verwaltung/allgemeine-bestimmungen,https://noi.bz.it/it/chi-siamo/societa-trasparente/disposizioni-generali,https://noi.bz.it/de/ueber-uns/transparente-verwaltung,https://noi.bz.it/it/chi-siamo/societa-trasparente,https://noi.bz.it/de/transparente-verwaltung,https://noi.bz.it/it/societa-trasparente,https://noi.bz.it/it/amministrazione-trasparente
# Logging
X_LOG_LEVEL: info
X_LOG_STYLE: json
# Task scheduler
X_SCHEDULER_JOB_DATA: "0 0 0 * * *"
X_SCHEDULER_POOL_SIZE: 1
- name: Build project
uses: noi-techpark/github-actions/maven-build@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}
java-version: ${{ env.JAVA_VERSION }}
build-command: 'mvn -B -DskipTests -DfinalName=ROOT clean package'
- name: Build and push images
uses: noi-techpark/github-actions/docker-build-and-push@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}/infrastructure
docker-username: ${{ github.actor }}
docker-password: ${{ secrets.GITHUB_TOKEN }}
- name: Deploy application
uses: noi-techpark/github-actions/docker-deploy@v2
with:
working-directory: ${{ env.WORKING_DIRECTORY }}/infrastructure/ansible
hosts: 'prod'
ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}
docker-username: 'noi-techpark-bot'
docker-password: ${{ secrets.GH_PERSONAL_ACCESS_TOKEN }}
project-name: ${{ env.PROJECT_NAME }}