| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- name: "Update dependencies"
- on:
- schedule:
- # Monday, 10AM UTC
- - cron: "0 10 * * 1"
- workflow_dispatch:
- inputs: {}
- permissions:
- contents: read
- jobs:
- branches:
- name: get branch data
- runs-on: ubuntu-latest
- outputs:
- branches: ${{ steps.branches.outputs.branches }}
- steps:
- - name: Checkout
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- with:
- fetch-depth: 0
- ref: ${{ github.event.inputs.ref }}
- - name: set branches output
- id: branches
- # outputs the second to most recent `release-x.y` branches plus `main` as JSON
- run: |
- echo "branches=$(git branch -a | grep -E "remotes/origin/(main|release-)" | sed 's/ remotes\/origin\///' | sort -V | tail -2 | head -1 | jq -R -s -c 'split("\n") | map(select(length > 0)) | . + ["main"]')" >> $GITHUB_OUTPUT
- update-dependencies:
- permissions:
- contents: write # for Git to git push
- runs-on: ubuntu-latest
- needs: branches
- strategy:
- matrix:
- branch: ${{ fromJson(needs.branches.outputs.branches) }}
- steps:
- - name: Setup Go
- uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0
- with:
- go-version: "1.21"
- # we can not use the default GHA token, as it prevents subsequent GHA
- # from running: we can create a PR but the tests won't run :/
- - name: Generate token
- id: generate_token
- uses: tibdex/github-app-token@3beb63f4bd073e61482598c45c71c1019b59b73a # v2.1.0
- with:
- app_id: ${{ secrets.APP_ID }}
- private_key: ${{ secrets.PRIVATE_KEY }}
- - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- with:
- token: ${{ steps.generate_token.outputs.token }}
- ref: ${{ matrix.branch }}
- fetch-depth: 0
- - name: create pull request
- run: |
- git config --global user.email "ExternalSecretsOperator@users.noreply.github.com"
- git config --global user.name "External Secrets Operator"
- BRANCH=update-deps-$(date "+%s")
- make update-deps || true
- if git diff-index --quiet HEAD --; then
- echo "nothing changed. skipping."
- exit 0;
- fi
- git checkout -b $BRANCH
- git add -A
- git commit -m "update dependencies" -s
- git push origin $BRANCH
- gh pr create -B ${{ matrix.branch }} -H ${BRANCH} --title 'chore: update dependencies' --body 'Update dependencies'
- env:
- GITHUB_TOKEN: ${{ steps.generate_token.outputs.token }}
|