diff --git a/.github/workflows/actions.yaml b/.github/workflows/actions.yaml index 5c5df98..378ea5c 100644 --- a/.github/workflows/actions.yaml +++ b/.github/workflows/actions.yaml @@ -10,29 +10,29 @@ env: jobs: converge: - name: Converge - runs-on: ubuntu-latest - steps: - + name: Skaffold Build To Github + runs-on: ubuntu-22.04 + steps: - name: Checkout code uses: actions/checkout@v3 with: fetch-depth: 0 - - name: Install werf - uses: werf/actions/install@v1.2 - - name: Log in to registry # This is where you will update the personal access token to GITHUB_TOKEN run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u $ --password-stdin - - name: Run echo - run: | - werf version - docker version - echo $GITHUB_REPOSITORY - echo $GITHUB_SHA - - name: Run Build - run: | - . $(werf ci-env github --as-file) - werf export service --tag ghcr.io/$GITHUB_REPOSITORY:$GITHUB_SHA + - name: Cache layers + uses: actions/cache@v3 + with: + path: "${{ github.workspace }}/.skaffold/cache" + key: skaffold-${{ hashFiles('**/cache') }} + restore-keys: | + skaffold- + + - name: Run Skaffold pipeline as command + uses: hiberbee/github-action-skaffold@latest + id: build + with: + command: build --tag ${{ github.sha }} + repository: ghcr.io/${{ github.repository_owner }} diff --git a/.github/workflows/tag.yaml b/.github/workflows/tag.yaml index 0a471f7..4209fd2 100644 --- a/.github/workflows/tag.yaml +++ b/.github/workflows/tag.yaml @@ -10,29 +10,29 @@ env: jobs: converge: - name: Converge - runs-on: ubuntu-latest - steps: - + name: Skaffold Build To Github + runs-on: ubuntu-22.04 + steps: - name: Checkout code uses: actions/checkout@v3 with: fetch-depth: 0 - - name: Install werf - uses: werf/actions/install@v1.2 - - name: Log in to registry # This is where you will update the personal access token to GITHUB_TOKEN run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u $ --password-stdin - - name: Run echo - run: | - werf version - docker version - echo $GITHUB_REPOSITORY - echo $GITHUB_REF_NAME - - name: Run Build - run: | - . $(werf ci-env github --as-file) - werf export service --tag ghcr.io/$GITHUB_REPOSITORY:$GITHUB_REF_NAME + - name: Cache layers + uses: actions/cache@v3 + with: + path: "${{ github.workspace }}/.skaffold/cache" + key: skaffold-${{ hashFiles('**/cache') }} + restore-keys: | + skaffold- + + - name: Run Skaffold pipeline as command + uses: hiberbee/github-action-skaffold@latest + id: build + with: + command: build --tag ${{ github.ref_name }} + repository: ghcr.io/${{ github.repository_owner }} diff --git a/Dockerfile b/Dockerfile index eb84eb2..de67695 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,17 +1,24 @@ -FROM golang:1.20-alpine as buildbase +FROM golang:1.22.2-alpine as buildbase -RUN apk add git build-base +ARG CI_JOB_TOKEN +RUN apk add git build-base ca-certificates WORKDIR /go/src/github.com/rarimo/geo-forms-svc -COPY vendor . COPY . . -RUN GOOS=linux go build -o /usr/local/bin/geo-forms-svc /go/src/github.com/rarimo/geo-forms-svc +RUN git config --global url."https://gitlab-ci-token:${CI_JOB_TOKEN}@gitlab.com".insteadOf https://gitlab.com +RUN git config --global url."https://${CI_JOB_TOKEN}@github.com/".insteadOf https://github.com/ +RUN go env -w GOPRIVATE=github.com/*,gitlab.com/* +RUN go mod tidy && go mod vendor +RUN CGO_ENABLED=1 GO111MODULE=on GOOS=linux go build -o /usr/local/bin/geo-forms-svc /go/src/github.com/rarimo/geo-forms-svc -FROM alpine:3.9 +FROM scratch +COPY --from=alpine:3.9 /bin/sh /bin/sh +COPY --from=alpine:3.9 /usr /usr +COPY --from=alpine:3.9 /lib /lib COPY --from=buildbase /usr/local/bin/geo-forms-svc /usr/local/bin/geo-forms-svc -RUN apk add --no-cache ca-certificates +COPY --from=buildbase /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ -ENTRYPOINT ["geo-forms-svc"] +ENTRYPOINT ["geo-forms-svc"] \ No newline at end of file diff --git a/skaffold.yaml b/skaffold.yaml new file mode 100644 index 0000000..49a3069 --- /dev/null +++ b/skaffold.yaml @@ -0,0 +1,76 @@ +apiVersion: skaffold/v2beta28 +kind: Config +build: + artifacts: + - image: geo-forms-svc # Change it on your own repo-name + docker: + buildArgs: + CI_JOB_TOKEN: "{{.CI_JOB_TOKEN}}" + + +# Uncomment the following lines if you want to deploy your application +# profiles: +# - name: dev +# deploy: +# helm: +# releases: +# - name: backend # Change it on your own repo-name +# setValueTemplates: +# image.repository: "{{.IMAGE_REPO_backend}}" +# image.tag: "{{.IMAGE_TAG_backend}}" +# namespace: dev # Change it on your own namespace +# createNamespace: true +# chartPath: ./backend # Change it on your own path to helm chart +# valuesFiles: +# - ./backend/values.yaml # Change it on your own path to helm chart values.yaml file +# skipBuildDependencies: true +# flags: +# upgrade: +# - -i +# portForward: +# - resourceType: deployment +# resourceName: backend # Change it on your own name in Chart.yaml +# port: 8000 +# localPort: 8000 + +# - name: stage +# patches: +# - op: remove +# path: /build +# deploy: +# helm: +# releases: +# - name: backend # Change it on your own repo-name +# setValueTemplates: +# image.repository: "{{.SKAFFOLD_DEFAULT_REPO}}/{{.GITHUB_REPOSITORY}}" +# image.tag: "{{.GITHUB_SHA}}" +# namespace: stage # Change it on your own namespace +# createNamespace: true +# chartPath: ./backend # Change it on your own path to helm chart +# valuesFiles: +# - ./backend/values.yaml # Change it on your own path to helm chart values.yaml file +# skipBuildDependencies: true +# flags: +# upgrade: +# - -i + +# - name: prod +# patches: +# - op: remove +# path: /build +# deploy: +# helm: +# releases: +# - name: backend # Change it on your own repo-name +# setValueTemplates: +# image.repository: "{{.SKAFFOLD_DEFAULT_REPO}}/{{.GITHUB_REPOSITORY}}" +# image.tag: "{{.GITHUB_REF_NAME}}" +# namespace: prod # Change it on your own namespace +# createNamespace: true +# chartPath: ./backend # Change it on your own path to helm chart +# valuesFiles: +# - ./backend/values.yaml # Change it on your own path to helm chart values.yaml file +# skipBuildDependencies: true +# flags: +# upgrade: +# - -i \ No newline at end of file diff --git a/werf-giterminism.yaml b/werf-giterminism.yaml deleted file mode 100644 index 30f1fdc..0000000 --- a/werf-giterminism.yaml +++ /dev/null @@ -1,4 +0,0 @@ -giterminismConfigVersion: 1 -config: - goTemplateRendering: - allowEnvVariables: ["CI_JOB_TOKEN"] diff --git a/werf.yaml b/werf.yaml deleted file mode 100644 index 8c0e7f2..0000000 --- a/werf.yaml +++ /dev/null @@ -1,45 +0,0 @@ -configVersion: 1 -project: 'backend' ---- -image: builder -from: golang:1.22.2-alpine -docker: - WORKDIR: /go/src/github.com/rarimo/geo-forms-svc -git: - - add: / - to: /go/src/github.com/rarimo/geo-forms-svc - stageDependencies: - install: - - go.mod - - go.sum - setup: - - "**/*" -shell: - beforeInstall: - - apk add git build-base - install: - - git config --global url."https://gitlab-ci-token:{{ env "CI_JOB_TOKEN" }}@gitlab.com/".insteadOf https://gitlab.com/ - - git config --global url."https://{{ env "CI_JOB_TOKEN" }}@github.com/".insteadOf https://github.com/ - - go env -w GOPRIVATE=github.com/*,gitlab.com/* - setup: - - export CGO_ENABLED=1 - - export GO111MODULE=on - - export GOOS=linux - - cd /go/src/github.com/rarimo/geo-forms-svc - - go mod tidy - - go mod vendor - - go build -o /usr/local/bin/geo-forms-svc /go/src/github.com/rarimo/geo-forms-svc - ---- -image: service -from: alpine:3.9 -docker: - ENTRYPOINT: geo-forms-svc -shell: - setup: - - apk add --no-cache ca-certificates -import: - - image: builder - add: /usr/local/bin/geo-forms-svc - to: /usr/local/bin/geo-forms-svc - after: setup