Add files via upload #34
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
# merge submission on the main branch after a pullrequest approval | |
name: ValidateSurveillance | |
on: | |
pull_request_target: | |
branches: [ main ] | |
paths: | |
- 'sorveglianza/**' | |
- '!**README**' | |
jobs: | |
validate_request: | |
runs-on: ubuntu-latest | |
outputs: | |
is_valid: ${{ steps.authenticate.outputs.authenticate == 'success' }} | |
changed_files: ${{ steps.get_changed_files.outputs.all_changed_files }} | |
authenticate_error_msg: ${{ steps.authenticate.outputs.message }} | |
steps: | |
# Check out the submission repo | |
# ------------------------------------------- | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
ref: ${{ github.event.pull_request.head.sha }} | |
# Checkout the python tools repo | |
# used to authenticate and validate the PR | |
# ------------------------------------------- | |
- name: checkout python tools repo | |
uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
repository: 'Predizioni-Epidemiologiche-Italia/hub-tools' | |
ref: 'main' | |
path: './tools' | |
# Get changes from pull request | |
# -------------------------------- | |
- name: Get changes | |
id: get_changed_files | |
uses: tj-actions/changed-files@v36 | |
# Authenticate the pull_request | |
# returns as output authentication = { True / False } | |
# ------------------------------- | |
- name: Execute Authentication script | |
id: authenticate | |
env: | |
calling_actor: ${{ github.actor }} | |
changed_files: ${{ steps.get_changed_files.outputs.all_changed_files }} | |
run: python ./tools/.github/scripts/request_authentication/authenticate_surveillance.py | |
# ------------------------------------------- | |
# SUCCESS | |
# ------------------------------------------- | |
on_successful_validation: | |
runs-on: ubuntu-latest | |
needs: validate_request | |
if: needs.validate_request.outputs.is_valid == 'true' | |
steps: | |
- name: DEBUG | |
run: | | |
echo "Is_Valid: ${{ needs.validate_request.outputs.is_valid }}" | |
# Checkout the forecast repo | |
# --------------------------- | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
ref: "${{ github.event.pull_request.head.sha }}" | |
# Approve pull request | |
# --------------------------- | |
- name: Approve Pull Request | |
uses: juliangruber/[email protected] | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
number: ${{ github.event.pull_request.number }} | |
# Eventually comment on it | |
- name: Comment PR | |
uses: thollander/actions-comment-pull-request@v2 | |
with: | |
message: | | |
All checks completed successfully ! :wave: | |
pr_number: ${{ github.event.pull_request.number }} | |
# Merge changes | |
# --------------------------- | |
- name: Merge the pull request | |
id: merge_pr | |
run: | | |
gh pr merge --auto --squash $PR_URL | |
echo "status=true" >> $GITHUB_OUTPUT | |
env: | |
PR_URL: ${{ github.event.pull_request.html_url }} | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
# Save changes to artifact for later persisting | |
- name: Save changes to artifact | |
env: | |
changed_files: ${{ needs.validate_request.outputs.changed_files }} | |
run: | | |
echo "{ \"pr-changes\" : \"$changed_files\" }" > pr_changes.json | |
- name: Upload changes | |
uses: actions/upload-artifact@v4 | |
with: | |
name: pr_changes | |
path: ./pr_changes.json | |
# ------------------------------------------- | |
# FAILED | |
# ------------------------------------------- | |
on_validation_failed: | |
runs-on: ubuntu-latest | |
needs: validate_request | |
if: needs.validate_request.outputs.is_valid == 'false' | |
steps: | |
# DEBUG ONLY | |
- name: DEBUG - DUMP INFO | |
env: | |
changed-files: ${{ needs.validate_request.outputs.changed_files }} | |
run: | | |
echo ">>> Is_Valid: ${{ needs.validate_request.outputs.is_valid }}" | |
echo ">>> FAILED JOB " | |
echo ">>> Changes: $changed-files" | |
echo ">>> Repo: ${{ github.repository }}" | |
echo ">>> SrcPath: $GITHUB_WORKSPACE" | |
echo ">>> Pull request number: ${{ github.event.pull_request.number }}" | |
echo ">>> Git hub actor: ${{ github.actor }}" | |
echo ">>> Authenticate Error Message ${{ needs.validate_request.outputs.authenticate_error_msg }}" | |
# Inform the user about what went wrong | |
- name: Comment PR | |
uses: thollander/actions-comment-pull-request@v2 | |
with: | |
message: | | |
An error occurred during authentication: ${{ needs.validate_request.outputs.authenticate_error_msg }} | |
pr_number: ${{ github.event.pull_request.number }} | |