|
1 | 1 | name: Build Image |
2 | 2 |
|
3 | | -on: [push, pull_request, workflow_dispatch] |
| 3 | +on: [push, pull_request_target, workflow_dispatch] |
4 | 4 |
|
5 | 5 | env: |
| 6 | + GITHUB_REPO: "linuxserver/docker-mods" #don't modify |
6 | 7 | ENDPOINT: "linuxserver/mods" #don't modify |
7 | 8 | BASEIMAGE: "universal" #replace |
8 | 9 | MODNAME: "cloudflared" #replace |
9 | 10 |
|
10 | 11 | jobs: |
11 | | - build: |
| 12 | + set-vars: |
12 | 13 | runs-on: ubuntu-latest |
13 | 14 | steps: |
14 | | - |
15 | | - |
16 | | - - name: Build image |
17 | | - run: | |
18 | | - CLOUDFLARED_TAG=$(curl -s https://api.github.com/repos/cloudflare/cloudflared/releases/latest | jq -rc ".tag_name") |
19 | | - echo "CLOUDFLARED_TAG=${CLOUDFLARED_TAG}" >> $GITHUB_ENV |
20 | | - docker build --no-cache --build-arg CLOUDFLARED_TAG=${CLOUDFLARED_TAG} -t ${{ github.sha }} . |
21 | | -
|
22 | | - - name: Tag image |
23 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) }} |
24 | | - run: | |
25 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
26 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG} |
27 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG}-${{ github.sha }} |
28 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
29 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
30 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG} |
31 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG}-${{ github.sha }} |
32 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
33 | | -
|
34 | | - - name: Credential check |
35 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) }} |
36 | | - run: | |
37 | | - echo "CR_USER=${{ secrets.CR_USER }}" >> $GITHUB_ENV |
38 | | - echo "CR_PAT=${{ secrets.CR_PAT }}" >> $GITHUB_ENV |
39 | | - echo "DOCKERUSER=${{ secrets.DOCKERUSER }}" >> $GITHUB_ENV |
40 | | - echo "DOCKERPASS=${{ secrets.DOCKERPASS }}" >> $GITHUB_ENV |
41 | | - if [[ "${{ secrets.CR_USER }}" == "" && "${{ secrets.CR_PAT }}" == "" && "${{ secrets.DOCKERUSER }}" == "" && "${{ secrets.DOCKERPASS }}" == "" ]]; then |
42 | | - echo "::error::Push credential secrets missing." |
43 | | - echo "::error::You must set either CR_USER & CR_PAT or DOCKERUSER & DOCKERPASS as secrets in your repo settings." |
44 | | - echo "::error::See https://github.com/linuxserver/docker-mods/blob/master/README.md for more information/instructions." |
45 | | - exit 1 |
46 | | - fi |
47 | | -
|
48 | | - - name: Login to GitHub Container Registry |
49 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.CR_USER && env.CR_PAT }} |
50 | | - run: | |
51 | | - echo "${{ secrets.CR_PAT }}" | docker login ghcr.io -u ${{ secrets.CR_USER }} --password-stdin |
52 | | -
|
53 | | - - name: Push tags to GitHub Container Registry |
54 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.CR_USER && env.CR_PAT }} |
| 15 | + - name: Set Vars |
| 16 | + id: outputs |
55 | 17 | run: | |
56 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
57 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG}-${{ github.sha }} |
58 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG} |
59 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
| 18 | + echo "GITHUB_REPO=${{ env.GITHUB_REPO }}" >> $GITHUB_OUTPUT |
| 19 | + echo "ENDPOINT=${{ env.ENDPOINT }}" >> $GITHUB_OUTPUT |
| 20 | + echo "BASEIMAGE=${{ env.BASEIMAGE }}" >> $GITHUB_OUTPUT |
| 21 | + echo "MODNAME=${{ env.MODNAME }}" >> $GITHUB_OUTPUT |
| 22 | + # **** If the mod needs to be versioned, set the versioning logic below. Otherwise leave as is. **** |
| 23 | + MOD_VERSION=$(curl -s https://api.github.com/repos/cloudflare/cloudflared/releases/latest | jq -rc ".tag_name") |
| 24 | + echo "MOD_VERSION=${MOD_VERSION}" >> $GITHUB_OUTPUT |
| 25 | + outputs: |
| 26 | + GITHUB_REPO: ${{ steps.outputs.outputs.GITHUB_REPO }} |
| 27 | + ENDPOINT: ${{ steps.outputs.outputs.ENDPOINT }} |
| 28 | + BASEIMAGE: ${{ steps.outputs.outputs.BASEIMAGE }} |
| 29 | + MODNAME: ${{ steps.outputs.outputs.MODNAME }} |
| 30 | + MOD_VERSION: ${{ steps.outputs.outputs.MOD_VERSION }} |
60 | 31 |
|
61 | | - - name: Login to DockerHub |
62 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.DOCKERUSER && env.DOCKERPASS }} |
63 | | - run: | |
64 | | - echo ${{ secrets.DOCKERPASS }} | docker login -u ${{ secrets.DOCKERUSER }} --password-stdin |
65 | | -
|
66 | | - - name: Push tags to DockerHub |
67 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.DOCKERUSER && env.DOCKERPASS }} |
68 | | - run: | |
69 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
70 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG}-${{ github.sha }} |
71 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${CLOUDFLARED_TAG} |
72 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
| 32 | + build: |
| 33 | + uses: linuxserver/github-workflows/.github/workflows/docker-mod-builder.yml@v1 |
| 34 | + needs: set-vars |
| 35 | + secrets: |
| 36 | + CR_USER: ${{ secrets.CR_USER }} |
| 37 | + CR_PAT: ${{ secrets.CR_PAT }} |
| 38 | + DOCKERUSER: ${{ secrets.DOCKERUSER }} |
| 39 | + DOCKERPASS: ${{ secrets.DOCKERPASS }} |
| 40 | + with: |
| 41 | + GITHUB_REPO: ${{ needs.set-vars.outputs.GITHUB_REPO }} |
| 42 | + ENDPOINT: ${{ needs.set-vars.outputs.ENDPOINT }} |
| 43 | + BASEIMAGE: ${{ needs.set-vars.outputs.BASEIMAGE }} |
| 44 | + MODNAME: ${{ needs.set-vars.outputs.MODNAME }} |
| 45 | + MOD_VERSION: ${{ needs.set-vars.outputs.MOD_VERSION }} |
0 commit comments