|
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: "docker" #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 | | - # Set version |
19 | | - if [ -z ${COMPOSE_RELEASE+x} ]; then COMPOSE_RELEASE=$(curl -sX GET "https://api.github.com/repos/docker/compose/releases/latest" | awk '/tag_name/{print $4;exit}' FS='[""]' | sed 's|^v||'); fi |
20 | | - if [ -z ${DOCKER_RELEASE+x} ]; then DOCKER_RELEASE=$(curl -sX GET "https://api.github.com/repos/moby/moby/releases/latest" | awk '/tag_name/{print $4;exit}' FS='[""]' | sed 's|^v||'); fi |
21 | | - COMBINED_VERSION=${DOCKER_RELEASE}-${COMPOSE_RELEASE} |
22 | | - echo "**** Combined version is ${COMBINED_VERSION} ****" |
23 | | - echo "COMBINED_VERSION=${COMBINED_VERSION}" >> $GITHUB_ENV |
24 | | - if curl -fSsL "https://download.docker.com/linux/static/stable/x86_64/docker-${DOCKER_RELEASE}.tgz" >/dev/null && curl -fSsL "https://download.docker.com/linux/static/stable/armhf/docker-${DOCKER_RELEASE}.tgz" >/dev/null && curl -fSsL "https://download.docker.com/linux/static/stable/aarch64/docker-${DOCKER_RELEASE}.tgz" >/dev/null; then echo "Docker tarballs exist, proceeding"; else echo "Docker tarballs are missing, exiting!" && exit 1; fi |
25 | | - # Build image |
26 | | - docker build --no-cache --build-arg COMPOSE_RELEASE=${COMPOSE_RELEASE} --build-arg DOCKER_RELEASE=${DOCKER_RELEASE} -t ${{ github.sha }} . |
27 | | -
|
28 | | - - name: Tag image |
29 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) }} |
30 | | - run: | |
31 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
32 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }} |
33 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }}-${{ github.sha }} |
34 | | - docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
35 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
36 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }} |
37 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }}-${{ github.sha }} |
38 | | - docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
39 | | -
|
40 | | - - name: Credential check |
41 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) }} |
42 | | - run: | |
43 | | - echo "CR_USER=${{ secrets.CR_USER }}" >> $GITHUB_ENV |
44 | | - echo "CR_PAT=${{ secrets.CR_PAT }}" >> $GITHUB_ENV |
45 | | - echo "DOCKERUSER=${{ secrets.DOCKERUSER }}" >> $GITHUB_ENV |
46 | | - echo "DOCKERPASS=${{ secrets.DOCKERPASS }}" >> $GITHUB_ENV |
47 | | - if [[ "${{ secrets.CR_USER }}" == "" && "${{ secrets.CR_PAT }}" == "" && "${{ secrets.DOCKERUSER }}" == "" && "${{ secrets.DOCKERPASS }}" == "" ]]; then |
48 | | - echo "::error::Push credential secrets missing." |
49 | | - echo "::error::You must set either CR_USER & CR_PAT or DOCKERUSER & DOCKERPASS as secrets in your repo settings." |
50 | | - echo "::error::See https://github.com/linuxserver/docker-mods/blob/master/README.md for more information/instructions." |
51 | | - exit 1 |
52 | | - fi |
53 | | -
|
54 | | - - name: Login to GitHub Container Registry |
55 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.CR_USER && env.CR_PAT }} |
56 | | - run: | |
57 | | - echo "${{ secrets.CR_PAT }}" | docker login ghcr.io -u ${{ secrets.CR_USER }} --password-stdin |
58 | | -
|
59 | | - - name: Push tags to GitHub Container Registry |
60 | | - 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 |
61 | 17 | run: | |
62 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }} |
63 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }}-${{ github.sha }} |
64 | | - docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
65 | | - 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 | + COMPOSE_RELEASE=$(curl -sX GET "https://api.github.com/repos/docker/compose/releases/latest" | awk '/tag_name/{print $4;exit}' FS='[""]' | sed 's|^v||') |
| 24 | + DOCKER_RELEASE=$(curl -sX GET "https://api.github.com/repos/moby/moby/releases/latest" | awk '/tag_name/{print $4;exit}' FS='[""]' | sed 's|^v||') |
| 25 | + MOD_VERSION="${DOCKER_RELEASE}-${COMPOSE_RELEASE}" |
| 26 | + echo "MOD_VERSION=${MOD_VERSION}" >> $GITHUB_OUTPUT |
| 27 | + outputs: |
| 28 | + GITHUB_REPO: ${{ steps.outputs.outputs.GITHUB_REPO }} |
| 29 | + ENDPOINT: ${{ steps.outputs.outputs.ENDPOINT }} |
| 30 | + BASEIMAGE: ${{ steps.outputs.outputs.BASEIMAGE }} |
| 31 | + MODNAME: ${{ steps.outputs.outputs.MODNAME }} |
| 32 | + MOD_VERSION: ${{ steps.outputs.outputs.MOD_VERSION }} |
66 | 33 |
|
67 | | - - name: Login to DockerHub |
68 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.DOCKERUSER && env.DOCKERPASS }} |
69 | | - run: | |
70 | | - echo ${{ secrets.DOCKERPASS }} | docker login -u ${{ secrets.DOCKERUSER }} --password-stdin |
71 | | -
|
72 | | - - name: Push tags to DockerHub |
73 | | - if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.DOCKERUSER && env.DOCKERPASS }} |
74 | | - run: | |
75 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }} |
76 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.COMBINED_VERSION }}-${{ github.sha }} |
77 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }} |
78 | | - docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME} |
| 34 | + build: |
| 35 | + uses: linuxserver/github-workflows/.github/workflows/docker-mod-builder.yml@v1 |
| 36 | + needs: set-vars |
| 37 | + secrets: |
| 38 | + CR_USER: ${{ secrets.CR_USER }} |
| 39 | + CR_PAT: ${{ secrets.CR_PAT }} |
| 40 | + DOCKERUSER: ${{ secrets.DOCKERUSER }} |
| 41 | + DOCKERPASS: ${{ secrets.DOCKERPASS }} |
| 42 | + with: |
| 43 | + GITHUB_REPO: ${{ needs.set-vars.outputs.GITHUB_REPO }} |
| 44 | + ENDPOINT: ${{ needs.set-vars.outputs.ENDPOINT }} |
| 45 | + BASEIMAGE: ${{ needs.set-vars.outputs.BASEIMAGE }} |
| 46 | + MODNAME: ${{ needs.set-vars.outputs.MODNAME }} |
| 47 | + MOD_VERSION: ${{ needs.set-vars.outputs.MOD_VERSION }} |
0 commit comments