fix docker
Some checks failed
docker / build (push) Failing after 1m52s

This commit is contained in:
Elijah McMorris 2025-08-21 14:26:43 -07:00
parent a40a9a44ea
commit b68e41ed91
Signed by: NexVeridian
SSH key fingerprint: SHA256:bsA1SKZxuEcEVHAy3gY1HUeM5ykRJl0U0kQHQn0hMg8

View file

@ -48,21 +48,13 @@ jobs:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- name: Install Docker - name: Install skopeo
run: | run: |
mkdir -p ~/.local/bin mkdir -p ~/.local/bin
nix build -I nixpkgs=channel:nixos-unstable nixpkgs#docker -o ~/.local/docker nix build -I nixpkgs=channel:nixos-unstable nixpkgs#skopeo -o ~/.local/skopeo
ln -sf ~/.local/docker/bin/docker ~/.local/bin/docker ln -sf ~/.local/skopeo/bin/skopeo ~/.local/bin/skopeo
echo "$HOME/.local/bin" >> $GITHUB_PATH echo "$HOME/.local/bin" >> $GITHUB_PATH
- name: Log into registry ${{ env.REGISTRY }}
if: github.event_name != 'pull_request'
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ env.GITHUB_ACTOR }}
password: ${{ env.GITHUB_TOKEN }}
- name: Extract Docker metadata - name: Extract Docker metadata
id: meta id: meta
uses: docker/metadata-action@v5 uses: docker/metadata-action@v5
@ -72,7 +64,13 @@ jobs:
- name: Build Nix package - name: Build Nix package
run: nix build .#my-docker run: nix build .#my-docker
# https://github.com/orgs/community/discussions/25768#discussioncomment-3249183 - name: Verify built image
run: |
export TMPDIR=/tmp
mkdir -p $TMPDIR
echo "Verifying image structure..."
skopeo inspect docker-archive:$(readlink -f result)
- name: Downcase REPO - name: Downcase REPO
run: | run: |
echo "REPO=${GITHUB_REPOSITORY,,}" >> ${GITHUB_ENV} echo "REPO=${GITHUB_REPOSITORY,,}" >> ${GITHUB_ENV}
@ -82,12 +80,20 @@ jobs:
STRIP_REPO_USERNAME=${REPO#nexveridian/} STRIP_REPO_USERNAME=${REPO#nexveridian/}
echo "STRIP_REPO_USERNAME=${STRIP_REPO_USERNAME}" >> ${GITHUB_ENV} echo "STRIP_REPO_USERNAME=${STRIP_REPO_USERNAME}" >> ${GITHUB_ENV}
# https://github.com/docker/build-push-action/issues/538 - name: Push Docker image with skopeo
- name: Push and tag Docker image
run: | run: |
docker load < result export TMPDIR=/tmp
docker tag ${{ env.STRIP_REPO_USERNAME }}:latest ${{ env.REGISTRY }}/${{ env.REPO }}:latest mkdir -p $TMPDIR
docker push ${{ env.REGISTRY }}/${{ env.REPO }}:latest IMAGE_PATH=$(readlink -f result)
echo "Pushing image from: $IMAGE_PATH"
echo "Target registry: ${{ env.REGISTRY }}/${{ env.REPO }}:latest"
echo "Using actor: ${{ github.actor }}"
echo "Token length: ${#GITHUB_TOKEN}"
skopeo copy \
--insecure-policy \
--dest-creds "${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}" \
"docker-archive://$IMAGE_PATH" \
"docker://${{ env.REGISTRY }}/${{ env.REPO }}:latest"
- name: Push to attic - name: Push to attic
if: always() if: always()