-
-
Notifications
You must be signed in to change notification settings - Fork 36
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
616e2d6
commit 479dd8a
Showing
7 changed files
with
263 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
name: Build and Publish | ||
|
||
on: | ||
# run it on push to the default repository branch | ||
push: | ||
branches: | ||
- main | ||
# run it during pull request | ||
pull_request: | ||
|
||
jobs: | ||
# define job to build and publish docker image | ||
build-and-push-docker-image: | ||
name: Build Docker image and push to repositories | ||
# run only when code is compiling and tests are passing | ||
runs-on: ubuntu-latest | ||
# steps to perform in job | ||
steps: | ||
- name: Checkout code | ||
uses: actions/checkout@v2 | ||
|
||
- name: Docker meta | ||
id: meta | ||
uses: docker/metadata-action@v3 | ||
with: | ||
# list of Docker images to use as base name for tags | ||
images: | | ||
buddyspencer/gickup | ||
ghcr.io/${{ github.actor }}/gickup | ||
# generate Docker tags based on the following events/attributes | ||
tags: | | ||
type=raw,value=ubuntu-dev | ||
# setup Docker buld action | ||
- name: Set up Docker Buildx | ||
id: buildx | ||
uses: docker/setup-buildx-action@v1 | ||
|
||
- name: Login to DockerHub | ||
if: github.event_name != 'pull_request' | ||
uses: docker/login-action@v1 | ||
with: | ||
username: ${{ secrets.DOCKERHUB_USERNAME }} | ||
password: ${{ secrets.DOCKERHUB_TOKEN }} | ||
|
||
- name: Login to Github Packages | ||
if: github.event_name != 'pull_request' | ||
uses: docker/login-action@v1 | ||
with: | ||
registry: ghcr.io | ||
username: ${{ github.actor }} | ||
password: ${{ secrets.GHCR_PAT }} | ||
|
||
- name: Build image and push to Docker Hub and GitHub Container Registry | ||
uses: docker/build-push-action@v2 | ||
with: | ||
# relative path to the place where source code with Dockerfile is located | ||
context: . | ||
file: Dockerfile.ubuntu | ||
tags: ${{ steps.meta.outputs.tags }} | ||
labels: ${{ steps.meta.outputs.labels }} | ||
# build on feature branches, push only on main branch | ||
push: ${{ github.event_name != 'pull_request' }} | ||
platforms: linux/amd64, linux/arm64/v8, linux/arm/v7, linux/arm/v6 | ||
|
||
- name: Image digest | ||
run: echo ${{ steps.docker_build.outputs.digest }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
name: Build and Publish | ||
|
||
on: | ||
# run it on push to the default repository branch | ||
push: | ||
tags: | ||
- "v*.*.*" | ||
# run it during pull request | ||
pull_request: | ||
|
||
jobs: | ||
# define job to build and publish docker image | ||
build-and-push-docker-image: | ||
name: Build Docker image and push to repositories | ||
# run only when code is compiling and tests are passing | ||
runs-on: ubuntu-latest | ||
|
||
# steps to perform in job | ||
steps: | ||
- name: Checkout code | ||
uses: actions/checkout@v2 | ||
|
||
- name: Docker meta | ||
id: meta | ||
uses: docker/metadata-action@v3 | ||
with: | ||
# list of Docker images to use as base name for tags | ||
images: | | ||
buddyspencer/gickup | ||
ghcr.io/${{ github.actor }}/gickup | ||
# generate Docker tags based on the following events/attributes | ||
tags: | | ||
type=schedule | ||
type=ref,event=pr | ||
type=semver,pattern=ubuntu-{{version}} | ||
type=semver,pattern=ubuntu-{{major}}.{{minor}} | ||
type=semver,pattern=ubuntu-{{major}} | ||
type=raw,value=ubuntu-latest | ||
# setup Docker buld action | ||
- name: Set up Docker Buildx | ||
id: buildx | ||
uses: docker/setup-buildx-action@v1 | ||
|
||
- name: Login to DockerHub | ||
if: github.event_name != 'pull_request' | ||
uses: docker/login-action@v1 | ||
with: | ||
username: ${{ secrets.DOCKERHUB_USERNAME }} | ||
password: ${{ secrets.DOCKERHUB_TOKEN }} | ||
|
||
- name: Login to Github Packages | ||
if: github.event_name != 'pull_request' | ||
uses: docker/login-action@v1 | ||
with: | ||
registry: ghcr.io | ||
username: ${{ github.actor }} | ||
password: ${{ secrets.GHCR_PAT }} | ||
|
||
- name: Build image and push to Docker Hub and GitHub Container Registry | ||
uses: docker/build-push-action@v2 | ||
with: | ||
# relative path to the place where source code with Dockerfile is located | ||
context: . | ||
tags: ${{ steps.meta.outputs.tags }} | ||
labels: ${{ steps.meta.outputs.labels }} | ||
# build on feature branches, push only on main branch | ||
push: ${{ github.event_name != 'pull_request' }} | ||
platforms: linux/amd64, linux/arm64/v8, linux/arm/v7, linux/arm/v6 | ||
|
||
- name: Image digest | ||
run: echo ${{ steps.docker_build.outputs.digest }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
FROM golang:1.17-alpine as builder | ||
|
||
# Install dependencies for copy | ||
RUN apk add -U --no-cache ca-certificates tzdata git | ||
|
||
# Use an valid GOPATH and copy the files | ||
WORKDIR /go/src/github.com/cooperspencer/gickup | ||
COPY go.mod . | ||
COPY go.sum . | ||
RUN go mod tidy | ||
COPY . . | ||
|
||
# Fetching dependencies and build the app | ||
RUN go get -d -v ./... | ||
RUN CGO_ENABLED=0 go build -a -installsuffix cgo -o gickup . | ||
|
||
# Use ubuntu as production environment | ||
FROM ubuntu as production | ||
WORKDIR / | ||
RUN apt update && DEBIAN_FRONTEND=noninteractive TZ=Etc/UTC apt install -y git git-lfs ssl-cert tzdata && rm -rf /var/lib/apt/lists/* | ||
RUN git lfs install | ||
# Copy the main executable from the builder | ||
COPY --from=builder /go/src/github.com/cooperspencer/gickup/gickup /gickup/gickup | ||
|
||
ENTRYPOINT [ "/gickup/gickup" ] | ||
CMD [ "/gickup/conf.yml" ] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
package gitcmd | ||
|
||
import ( | ||
"errors" | ||
"os/exec" | ||
) | ||
|
||
type GitCmd struct { | ||
CMD string | ||
} | ||
|
||
func New() (GitCmd, error) { | ||
cmd := exec.Command("git", "lfs") | ||
err := cmd.Run() | ||
if err != nil { | ||
return GitCmd{}, errors.New("git lfs is not installed") | ||
} | ||
|
||
return GitCmd{CMD: "git"}, nil | ||
} | ||
|
||
func (g GitCmd) Clone(url, path string, bare bool) error { | ||
cmd := exec.Command(g.CMD, "clone", url, path) | ||
if bare { | ||
cmd.Args = append(cmd.Args, "--bare") | ||
} | ||
err := cmd.Run() | ||
if err != nil { | ||
return err | ||
} | ||
return nil | ||
} | ||
|
||
func (g GitCmd) Pull(bare bool) error { | ||
var args = []string{} | ||
if bare { | ||
args = []string{"fetch", "--all"} | ||
} else { | ||
args = []string{"pull"} | ||
} | ||
cmd := exec.Command(g.CMD, args...) | ||
err := cmd.Run() | ||
if err != nil { | ||
return err | ||
} | ||
return nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters