bump-actions-versions.sh 1.4 KB

1234567891011121314151617181920212223
  1. #!/usr/bin/env bash
  2. set -euo pipefail
  3. actions=( 'actions/checkout' 'actions/cache' 'actions/stale' 'actions/upload-artifact' 'actions/download-artifact' 'aws-actions/configure-aws-credentials' 'ossf/scorecard-action' 'erlef/setup-beam' 'slackapi/slack-github-action' 'hashicorp/setup-terraform' 'docker/login-action' 'docker/setup-buildx-action' 'docker/setup-qemu-action' 'actions/setup-java' )
  4. for a in "${actions[@]}"; do
  5. # shellcheck disable=SC2086
  6. TAG=$(curl -sSfL -H "Authorization: token $GITHUB_TOKEN" https://api.github.com/repos/$a/releases/latest | jq -r '.tag_name')
  7. # shellcheck disable=SC2086
  8. TAG_OBJECT=$(curl -sSfL -H "Authorization: token $GITHUB_TOKEN" https://api.github.com/repos/$a/git/ref/tags/$TAG)
  9. if [ "$(echo "${TAG_OBJECT}" | jq -r '.object.type')" = "commit" ]; then
  10. COMMIT_SHA=$(echo "${TAG_OBJECT}" | jq -r '.object.sha')
  11. else
  12. TAG_SHA=$(echo "${TAG_OBJECT}" | jq -r '.object.sha')
  13. # shellcheck disable=SC2086
  14. COMMIT_SHA=$(curl -sSfL -H "Authorization: token $GITHUB_TOKEN" https://api.github.com/repos/$a/git/tags/$TAG_SHA | jq -r '.object.sha')
  15. fi
  16. echo "Bumping $a to $TAG ($COMMIT_SHA)"
  17. sed -i.bak -e "s|uses: $a.*$|uses: $a@$COMMIT_SHA # $TAG|g" .github/workflows/*.yaml
  18. sed -i.bak -e "s|uses: $a.*$|uses: $a@$COMMIT_SHA # $TAG|g" .github/actions/*/*.yaml
  19. rm .github/workflows/*.bak
  20. rm .github/actions/*/*.bak
  21. done