Updatecli: Dependency Management #505
  
    
      This file contains hidden or 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: "Updatecli: Dependency Management" | |
| on: | |
| schedule: | |
| # Runs at 06 PM UTC | |
| - cron: '0 18 * * *' | |
| # Allows you to run this workflow manually from the Actions tab | |
| workflow_dispatch: | |
| permissions: | |
| contents: write | |
| issues: write | |
| pull-requests: write | |
| id-token: write # for vault authentication | |
| jobs: | |
| updatecli: | |
| runs-on: ubuntu-latest | |
| # if you want to testupdatecli on another branch, you also need to modify updatecli/values.yaml | |
| if: ${{github.ref == 'refs/heads/main-source' && github.repository == 'rancher/rke2-charts'}} | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| - name: Install Go | |
| uses: actions/setup-go@v5 | |
| with: | |
| go-version: 'stable' | |
| - name: Install Updatecli | |
| uses: updatecli/updatecli-action@v2 | |
| - name: Read Secrets for the Github App | |
| uses: rancher-eio/read-vault-secrets@main | |
| with: | |
| secrets: | | |
| secret/data/github/repo/${{ github.repository }}/issues-manager/github/app-credentials appId | CREATE_ISSUE_APP_ID ; | |
| secret/data/github/repo/${{ github.repository }}/issues-manager/github/app-credentials privateKey | CREATE_ISSUE_PRIVATE_KEY | |
| - name: Get Github App token | |
| id: get_token | |
| uses: actions/create-github-app-token@c1a285145b9d317df6ced56c09f525b5c2b6f755 # v1.11.1 | |
| with: | |
| app-id: ${{ env.CREATE_ISSUE_APP_ID }} | |
| private-key: ${{ env.CREATE_ISSUE_PRIVATE_KEY }} | |
| owner: rancher | |
| repositories: | | |
| rke2 | |
| - name: Delete leftover UpdateCLI branches | |
| run: | | |
| gh pr list \ | |
| --search "is:closed is:pr head:updatecli_" \ | |
| --json headRefName \ | |
| --jq ".[].headRefName" | sort -u > closed_prs_branches.txt | |
| gh pr list \ | |
| --search "is:open is:pr head:updatecli_" \ | |
| --json headRefName \ | |
| --jq ".[].headRefName" | sort -u > open_prs_branches.txt | |
| for branch in $(comm -23 closed_prs_branches.txt open_prs_branches.txt); do | |
| if (git ls-remote --exit-code --heads origin "$branch"); then | |
| echo "Deleting leftover UpdateCLI branch - $branch"; | |
| git push origin --delete "$branch"; | |
| fi | |
| done | |
| env: | |
| GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Apply Updatecli | |
| # Never use '--debug' option, because it might leak the access tokens. | |
| run: "updatecli apply --clean --config ./updatecli/updatecli.d/ --values ./updatecli/values.yaml" | |
| env: | |
| UPDATECLI_GITHUB_ACTOR: ${{ github.actor }} | |
| UPDATECLI_GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| UPDATECLI_GITHUB_WORKFLOW_URL: "https://github.com/${{github.repository}}/actions/runs/${{github.run_id}}" | |
| GH_TOKEN: ${{ steps.get_token.outputs.token }} | |