Skip to content

Commit

Permalink
Merge pull request #1 from pvbouwel/main
Browse files Browse the repository at this point in the history
Add workflow to release container images
  • Loading branch information
pvbouwel authored Oct 10, 2024
2 parents 7ac0954 + af9e0d9 commit c6d0400
Show file tree
Hide file tree
Showing 4 changed files with 53 additions and 2 deletions.
46 changes: 46 additions & 0 deletions .github/workflows/container_build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
name: Push new version

# This workflow runs when any of the following occur:
# - A push is made to a branch called `main` or `seed`
# - A tag starting with "v" is created
# - A pull request is created or updated
on:
push:
tags:
- v*
env:
IMAGE_NAME: fakes3pp

jobs:
# This pushes the image to GitHub Packages.
push:
runs-on: ubuntu-latest
permissions:
packages: write
contents: read

steps:
- uses: actions/checkout@v4

- name: Build image
run: docker build . --file Dockerfile --tag $IMAGE_NAME --label "runnumber=${GITHUB_RUN_ID}"

- name: Log in to registry
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin
#
- name: Push image
run: |
IMAGE_ID=ghcr.io/${{ github.repository_owner }}/$IMAGE_NAME
# This changes all uppercase characters to lowercase.
IMAGE_ID=$(echo $IMAGE_ID | tr '[A-Z]' '[a-z]')
# This strips the git ref prefix from the version.
VERSION=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,')
# This strips the "v" prefix from the tag name.
[[ "${{ github.ref }}" == "refs/tags/"* ]] && VERSION=$(echo $VERSION | sed -e 's/^v//')
# This uses the Docker `latest` tag convention.
[ "$VERSION" == "main" ] && VERSION=latest
echo IMAGE_ID=$IMAGE_ID
echo VERSION=$VERSION
docker tag $IMAGE_NAME $IMAGE_ID:$VERSION
docker push $IMAGE_ID:$VERSION
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
# Changelog
See [releases](https://github.com/VITObelgium/fakes3pp/releases)
5 changes: 4 additions & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
# Doing a multi-stage build to make sure to have passing of unittests enforced
FROM docker.io/golang:1.22 AS base

# Credit check tests
LABEL org.opencontainers.image.source=https://github.com/VITObelgium/fakes3pp
LABEL org.opencontainers.image.description="FakeS3++ proxies S3 compatible APIs and augment them with extra functionality."
LABEL org.opencontainers.image.licenses=AGPL-3.0

COPY go.mod /usr/src/fakes3pp/go.mod
COPY go.sum /usr/src/fakes3pp/go.sum
WORKDIR /usr/src/fakes3pp
Expand Down
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
module github.com/VITObelgium/fakes3pp

go 1.22
go 1.22.3

require (
github.com/aws/aws-sdk-go-v2 v1.30.5
Expand Down

0 comments on commit c6d0400

Please sign in to comment.