|
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 | | - ENDPOINT: "linuxserver/mods" |
7 | | - BASEIMAGE: "swag" |
8 | | - MODNAME: "maxmind" |
| 6 | + GITHUB_REPO: "linuxserver/docker-mods" #don't modify |
| 7 | + ENDPOINT: "linuxserver/mods" #don't modify |
| 8 | + BASEIMAGE: "swag" #replace |
| 9 | + MODNAME: "maxmind" #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 | | - docker build --no-cache -t ${{ github.sha }} . |
19 | | -
|
20 | | - - name: Tag image |
21 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) }} |
22 | | - run: | |
23 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
24 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
25 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
26 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
27 | | -
|
28 | | - - name: Credential check |
29 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) }} |
30 | | - run: | |
31 | | - echo "CR_USER=${{ secrets.CR_USER }}" >> $GITHUB_ENV |
32 | | - echo "CR_PAT=${{ secrets.CR_PAT }}" >> $GITHUB_ENV |
33 | | - echo "DOCKERUSER=${{ secrets.DOCKERUSER }}" >> $GITHUB_ENV |
34 | | - echo "DOCKERPASS=${{ secrets.DOCKERPASS }}" >> $GITHUB_ENV |
35 | | - if [[ "${{ secrets.CR_USER }}" == "" && "${{ secrets.CR_PAT }}" == "" && "${{ secrets.DOCKERUSER }}" == "" && "${{ secrets.DOCKERPASS }}" == "" ]]; then |
36 | | - echo "::error::Push credential secrets missing." |
37 | | - echo "::error::You must set either CR_USER & CR_PAT or DOCKERUSER & DOCKERPASS as secrets in your repo settings." |
38 | | - echo "::error::See https://github.com/linuxserver/docker-mods/blob/master/README.md for more information/instructions." |
39 | | - exit 1 |
40 | | - fi |
41 | | -
|
42 | | - - name: Login to GitHub Container Registry |
43 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.CR_USER && env.CR_PAT }} |
44 | | - run: | |
45 | | - echo "${{ secrets.CR_PAT }}" | docker login ghcr.io -u ${{ secrets.CR_USER }} --password-stdin |
46 | | -
|
47 | | - - name: Push tags to GitHub Container Registry |
48 | | - 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 |
49 | 17 | run: | |
50 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
51 | | - 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="" |
| 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 }} |
52 | 31 |
|
53 | | - - name: Login to DockerHub |
54 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.DOCKERUSER && env.DOCKERPASS }} |
55 | | - run: | |
56 | | - echo ${{ secrets.DOCKERPASS }} | docker login -u ${{ secrets.DOCKERUSER }} --password-stdin |
57 | | -
|
58 | | - - name: Push tags to DockerHub |
59 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.DOCKERUSER && env.DOCKERPASS }} |
60 | | - run: | |
61 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
62 | | - 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