Skip to content

ci-update-submodule

ci-update-submodule #3

# Distributed under the OSI-approved BSD 3-Clause License.
# See accompanying file LICENSE-BSD for details.
name: ci-update-submodule
on:
# Triggers the workflow based on a schedule.
schedule:
- cron: '0 0 * * 1'
# Triggers the workflow manually through the GitHub UI.
workflow_dispatch:
inputs:
SUBMODULE:
description: 'SUBMODULE input'
required: true
type: string
default: 'all'
jobs:
precondition:
if: ${{ ( github.repository == 'localizethedocs/rust-patterns-l10n' ) &&
( ( github.event_name == 'schedule' ) ||
( github.event_name == 'workflow_dispatch' ) ) }}
runs-on: ${{ vars.RUNNER }}
steps:
- name: Print Contexts/Inputs/Variables/Secrets
shell: bash
run: |
echo "[Contexts]"
echo "github.job = ${{ github.job }}"
echo "github.ref = ${{ github.ref }}"
echo "github.ref_name = ${{ github.ref_name }}"
echo "github.event_name = ${{ github.event_name }}"
echo "github.event.schedule = ${{ github.event.schedule }}"
echo "[Inputs]"
echo "[Variables]"
echo "vars.RUNNER = ${{ vars.RUNNER }}"
echo "vars.ACTOR_NAME = ${{ vars.ACTOR_NAME }}"
echo "vars.ACTOR_EMAIL = ${{ vars.ACTOR_EMAIL }}"
echo "vars.GPG_FINGERPRINT = ${{ vars.GPG_FINGERPRINT }}"
echo "[Secrets]"
echo "secrets.ACTOR_GITHUB_TOKEN = ${{ secrets.ACTOR_GITHUB_TOKEN }}"
echo "secrets.GPG_PRIVATE_KEY = ${{ secrets.GPG_PRIVATE_KEY }}"
echo "secrets.GPG_PASSPHRASE = ${{ secrets.GPG_PASSPHRASE }}"
- name: Check Required Variables
shell: bash
run: |
REQUIRED_VARIABLES_EXIST=true
if [[ -z "${{ vars.RUNNER }}" ]]; then
echo "vars.RUNNER is missing."
REQUIRED_VARIABLES_EXIST=false
fi
if [[ -z "${{ vars.ACTOR_NAME }}" ]]; then
echo "vars.ACTOR_NAME is missing."
REQUIRED_VARIABLES_EXIST=false
fi
if [[ -z "${{ vars.ACTOR_EMAIL }}" ]]; then
echo "vars.ACTOR_EMAIL is missing."
REQUIRED_VARIABLES_EXIST=false
fi
if [[ -z "${{ vars.GPG_FINGERPRINT }}" ]]; then
echo "vars.GPG_FINGERPRINT is missing."
REQUIRED_VARIABLES_EXIST=false
fi
if [[ "${REQUIRED_VARIABLES_EXIST}" == "false" ]]; then
echo "Error: Some variables are missing." >&2
exit 1
fi
- name: Check Required Secrets
shell: bash
run: |
REQUIRED_SECRETS_EXIST=true
if [[ -z "${{ secrets.ACTOR_GITHUB_TOKEN }}" ]]; then
echo "secrets.ACTOR_GITHUB_TOKEN is missing."
REQUIRED_SECRETS_EXIST=false
fi
if [[ -z "${{ secrets.GPG_PRIVATE_KEY }}" ]]; then
echo "secrets.GPG_PRIVATE_KEY is missing."
REQUIRED_SECRETS_EXIST=false
fi
if [[ -z "${{ secrets.GPG_PASSPHRASE }}" ]]; then
echo "secrets.GPG_PASSPHRASE is missing."
REQUIRED_SECRETS_EXIST=false
fi
if [[ "${REQUIRED_SECRETS_EXIST}" == "false" ]]; then
echo "Error: Some secrets are missing." >&2
exit 1
fi
get-matrix:
if: ${{ ( github.repository == 'localizethedocs/rust-patterns-l10n' ) &&
( ( github.event_name == 'schedule' ) ||
( github.event_name == 'workflow_dispatch' ) ) }}
runs-on: ${{ vars.RUNNER }}
outputs:
MATRIX: ${{ steps.gmja.outputs.MATRIX }}
MATRIX_NUM: ${{ steps.gmja.outputs.MATRIX_NUM }}
steps:
- name: Checkout to '${{ github.ref }}'
uses: actions/checkout@v4
with:
ref: ${{ github.ref }}
submodules: false
- name: Get SUBMODULE_ARRAY from .gitmodules
id: gsl
uses: localizethedocs/ci-common/.github/actions/get-submodule-array-from-gitmodules-file@main
with:
submodule: ${{ inputs.SUBMODULE || 'all' }}
- name: Get MATRIX from the JSON Arraies
id: gmja
uses: localizethedocs/ci-common/.github/actions/get-matrix-from-json-arraies@main
with:
matrix-type: 'submodule'
submodule-array: ${{ steps.gsl.outputs.SUBMODULE_ARRAY }}
caller:
needs: [ 'precondition', 'get-matrix' ]
if: ${{ ( github.repository == 'localizethedocs/rust-patterns-l10n' ) &&
( needs.get-matrix.outputs.MATRIX_NUM != '0' ) &&
( ( github.event_name == 'schedule' ) ||
( github.event_name == 'workflow_dispatch' ) ) }}
strategy:
matrix: ${{ fromJSON(needs.get-matrix.outputs.MATRIX) }}
fail-fast: false
concurrency:
group: ${{ github.workflow }}-${{ matrix.SUBMODULE }}
cancel-in-progress: true
uses: localizethedocs/ci-common/.github/workflows/use-update-submodule.yml@main
with:
ENABLE: true
RUNNER: ${{ vars.RUNNER }}
CHECKOUT: ${{ github.ref }}
SUBMODULE: ${{ matrix.SUBMODULE }}
ACTOR_NAME: ${{ vars.ACTOR_NAME }}
ACTOR_EMAIL: ${{ vars.ACTOR_EMAIL }}
GPG_FINGERPRINT: ${{ vars.GPG_FINGERPRINT }}
secrets:
ACTOR_GITHUB_TOKEN: ${{ secrets.ACTOR_GITHUB_TOKEN }}
GPG_PRIVATE_KEY: ${{ secrets.GPG_PRIVATE_KEY }}
GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }}
⚔