|
|
|
|
@ -21,44 +21,40 @@ jobs:
|
|
|
|
|
id: get_version
|
|
|
|
|
uses: battila7/get-version-action@v2.0.0
|
|
|
|
|
|
|
|
|
|
- name: install buildx
|
|
|
|
|
id: buildx
|
|
|
|
|
uses: crazy-max/ghaction-docker-buildx@v1
|
|
|
|
|
with:
|
|
|
|
|
version: latest
|
|
|
|
|
- name: Install go-bindata and build migrations
|
|
|
|
|
env:
|
|
|
|
|
GOPATH: /home/runner/work/Geeksbot/
|
|
|
|
|
run: |
|
|
|
|
|
go get -u github.com/go-bindata/go-bindata/...
|
|
|
|
|
/home/runner/work/Geeksbot/bin/go-bindata -pkg migrations -prefix $GITHUB_WORKSPACE/pkg/database/migrations/ -o $GITHUB_WORKSPACE/pkg/database/migrations/bindata.go $GITHUB_WORKSPACE/pkg/database/migrations/
|
|
|
|
|
head $GITHUB_WORKSPACE/pkg/database/migrations/bindata.go
|
|
|
|
|
|
|
|
|
|
- name: Docker Login
|
|
|
|
|
# You may pin to the exact commit or the version.
|
|
|
|
|
# uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9
|
|
|
|
|
uses: docker/login-action@v1.10.0
|
|
|
|
|
- name: Build container image
|
|
|
|
|
env:
|
|
|
|
|
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
|
|
|
|
|
run: docker build -t registry.digitalocean.com/djpianalto/geeksbot:$IMAGE_TAG .
|
|
|
|
|
|
|
|
|
|
- name: Install doctl
|
|
|
|
|
uses: digitalocean/action-doctl@v2
|
|
|
|
|
with:
|
|
|
|
|
registry: ${{ secrets.DR_URL }}
|
|
|
|
|
# Username used to log against the Docker registry
|
|
|
|
|
username: ${{ secrets.DH_USERNAME }}
|
|
|
|
|
# Password or personal access token used to log against the Docker registry
|
|
|
|
|
password: ${{ secrets.DH_PASSWORD }}
|
|
|
|
|
# Log out from the Docker registry at the end of a job
|
|
|
|
|
logout: true
|
|
|
|
|
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }}
|
|
|
|
|
|
|
|
|
|
- name: Login to DigitalOcean Container Registry with short-lived credentials
|
|
|
|
|
run: doctl registry login --expiry-seconds 600
|
|
|
|
|
|
|
|
|
|
- name: Docker Build & Push
|
|
|
|
|
- name: Push image to DigitalOcean Container Registry
|
|
|
|
|
run: docker push registry.digitalocean.com/djpianalto/geeksbot:$IMAGE_TAG
|
|
|
|
|
env:
|
|
|
|
|
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
|
|
|
|
|
run: |
|
|
|
|
|
docker buildx build --push \
|
|
|
|
|
--tag ${{ secrets.DR_URL }}/geeksbot:$IMAGE_TAG \
|
|
|
|
|
--platform linux/amd64,linux/arm/v7,linux/arm64 .
|
|
|
|
|
|
|
|
|
|
- name: Update deployment file
|
|
|
|
|
run: TAG=${{ steps.get_version.outputs.version-without-v }} && sed -i 's|<IMAGE>|${{ secrets.DR_URL }}/geeksbot:'${TAG}'|' $GITHUB_WORKSPACE/deployment.yml
|
|
|
|
|
run: TAG=${{ steps.get_version.outputs.version-without-v }} && sed -i 's|<IMAGE>|registry.digitalocean.com/djpianalto/geeksbot:'${TAG}'|' $GITHUB_WORKSPACE/deployment.yml
|
|
|
|
|
|
|
|
|
|
- uses: azure/k8s-set-context@v1
|
|
|
|
|
with:
|
|
|
|
|
method: kubeconfig
|
|
|
|
|
kubeconfig: ${{ secrets.KUBE_CONFIG }}
|
|
|
|
|
id: setcontext
|
|
|
|
|
- name: Save DigitalOcean kubeconfig with short-lived credentials
|
|
|
|
|
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 discord-bots
|
|
|
|
|
|
|
|
|
|
- name: Deploy to Kubernetes
|
|
|
|
|
- name: Deploy to DigitalOcean Kubernetes
|
|
|
|
|
run: kubectl apply -f $GITHUB_WORKSPACE/deployment.yml
|
|
|
|
|
|
|
|
|
|
- name: Verify deployment
|
|
|
|
|
run: kubectl rollout status -n discord-bots deployment/geeksbot
|
|
|
|
|
run: kubectl rollout status deployment/geeksbot
|
|
|
|
|
|