sca-auth-workflow #2
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: sca-auth-workflow | |
on: | |
workflow_dispatch: | |
inputs: | |
BUILD_BRANCH: | |
description: 'Branch to build' | |
required: true | |
OS: | |
description: 'OS to build on' | |
required: true | |
BUILD_VARS_JSON: | |
description: 'Build var json file' | |
required: true | |
workflow_run: | |
workflows: "Create Artifacts and pass runid" | |
branches: 'github-workflow' | |
types: | |
- completed | |
jobs: | |
build-sca-auth: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Capture start date and time | |
id: start_time | |
run: echo "start_time=$(date -u)" >> $GITHUB_ENV | |
- name: Add start time to build_vars.json | |
run: | | |
modified_json=$(echo '${{ github.event.inputs.BUILD_VARS_JSON }}' | jq '.buildstats += { "${{ github.event.repository.name }}-start": "${{ env.start_time }}" }' ) | |
BUILD_VARS_JSON=$(echo "$modified_json" | jq -c '.') | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" >> $GITHUB_ENV | |
echo "**** next next ****" | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" | |
- name: Check out Repo | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.event.inputs.BUILD_BRANCH}} | |
- name: Fetch workflow script from projects | |
env: | |
github-token: ${{ secrets.GIT_ACTIONS }} | |
run: | | |
git clone https://github.com/cs1867/project.git project | |
if [ "${{ github.event.inputs.OS }}" == 'ol8' ] || [ "${{ github.event.inputs.OS }}" == 'el9' ]; then | |
cp project/toolbox/workflows/github-workflow-el-skip-install.sh . | |
elif [ "${{ github.event.inputs.OS }}" == 'd11' ] || [ "${{ github.event.inputs.OS }}" == 'd12' ]; then | |
cp project/toolbox/workflows/github-db-workflow.sh . | |
fi | |
- name: Pretty-print BUILD_VARS_JSON | |
run: | | |
echo "$BUILD_VARS_JSON" | |
- name: Extract dependencies | |
id: extract_deps | |
run: | | |
echo "$BUILD_VARS_JSON" | jq -r '.repos[] | select(.name == "${{ github.event.repository.name }}") | .deps[]' > deps.txt | |
echo "Dependencies:" | |
cat deps.txt | |
- name: Download artifacts | |
run: | | |
mkdir -p artifacts | |
while IFS= read -r repo; do | |
echo "Downloading artifact for $repo" | |
run_id=$(echo "$BUILD_VARS_JSON" | jq -r ".buildids | .[\"$repo\"]") | |
echo "rund id $run_id" | |
gh run download $run_id --repo cs1867/$repo -D artifacts/$repo --name "$repo-${{ github.event.inputs.OS }}" | |
artifact_path="artifacts/$repo" | |
echo "list artifact path" | |
ls -al "$artifact_path" | |
mkdir -p artifacts/RPMS | |
echo "copy to the artifacts RPM dir" | |
cp "$artifact_path"/RPMS/*.rpm artifacts/RPMS | |
done < deps.txt | |
env: | |
GITHUB_TOKEN: ${{ secrets.GIT_ACTIONS }} | |
- name: run docker oneshot builder and github-actions-workflow.sh | |
run: | | |
if [ "${{ github.event.inputs.OS }}" == 'ol8' ] || [ "${{ github.event.inputs.OS }}" == 'el9' ]; then | |
curl -s https://raw.githubusercontent.com/perfsonar/docker-oneshot-builder/main/build | sh -s - --run github-workflow-el-skip-install.sh . '${{ github.event.inputs.OS }}' | |
elif [ "${{ github.event.inputs.OS }}" == 'd11' ] || [ "${{ github.event.inputs.OS }}" == 'd12' ]; then | |
curl -s https://raw.githubusercontent.com/perfsonar/docker-oneshot-builder/main/build | sh -s - --run github-db-workflow.sh . '${{ github.event.inputs.OS }}' | |
fi | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: ${{ github.event.repository.name }}-${{ github.event.inputs.OS }} | |
path: unibuild-repo | |
retention-days: 5 | |
- name: Delete current repo from build | |
id: modify_json | |
run: | | |
modified_json=$(echo "$BUILD_VARS_JSON" | jq 'del(.repos[0])') | |
echo "Modified JSON:" | |
echo "$modified_json" | jq . | |
BUILD_VARS_JSON=$(echo "$modified_json" | jq -c '.') | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" >> $GITHUB_ENV | |
echo "**** next next ****" | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: ${{ github.event.repository.name }}-${{ github.event.inputs.OS }} | |
path: unibuild-repo | |
retention-days: 5 | |
- name: Add GitHub run ID to buildids | |
id: add_run_id | |
run: | | |
GITHUB_RUN_ID=${{ github.run_id }} | |
modified_json=$(echo "$BUILD_VARS_JSON" | jq --arg run_id "$GITHUB_RUN_ID" '.buildids."${{ github.event.repository.name }}" = $run_id') | |
echo "Modified JSON with GitHub run ID:" | |
echo "$modified_json" | jq . | |
BUILD_VARS_JSON=$(echo "$modified_json" | jq -c '.') | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" >> $GITHUB_ENV | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" | |
- name: Look up the next repo name to build | |
id: extract_repo_name | |
run: | | |
echo "BUILD_VARS_JSON value is: $BUILD_VARS_JSON" | |
NEXTREPO=$(echo "$BUILD_VARS_JSON" | jq -r '.repos[0].name' ) | |
echo "NEXTREPO=$NEXTREPO" >> $GITHUB_ENV | |
- name: Display NEXTREPO value | |
run: echo "The value of NEXTREPO is $NEXTREPO" | |
- name: Capture end date and time | |
id: end_time | |
run: echo "end_time=$(date -u)" >> $GITHUB_ENV | |
- name: Add end time to build_vars.json | |
run: | | |
modified_json=$(echo "$BUILD_VARS_JSON" | jq '.buildstats += { "${{ github.event.repository.name }}-end": "${{ env.end_time }}" }' ) | |
BUILD_VARS_JSON=$(echo "$modified_json" | jq -c '.') | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" >> $GITHUB_ENV | |
echo "BUILD_VARS_JSON=$BUILD_VARS_JSON" | |
- name: Pass workflow | |
uses: actions/github-script@v6 | |
with: | |
github-token: ${{ secrets.GIT_ACTIONS }} | |
script: | | |
await github.rest.actions.createWorkflowDispatch({ | |
owner: 'cs1867', | |
repo: '${{ env.NEXTREPO}}', | |
workflow_id: '${{ env.NEXTREPO}}-workflow.yml', | |
ref: 'github-workflow', | |
inputs: { | |
OS: '${{ github.event.inputs.OS }}', | |
BUILD_VARS_JSON: '${{ env.BUILD_VARS_JSON}}', | |
BUILD_BRANCH: '${{ github.event.inputs.BUILD_BRANCH }}' | |
} | |
}) |