Skip to content

Commit

Permalink
Merge pull request #17 from admiralAwkbar/release
Browse files Browse the repository at this point in the history
Create cd-release.yml
  • Loading branch information
admiralAwkbar authored May 11, 2021
2 parents 922705c + c64d578 commit 92e93bf
Showing 1 changed file with 120 additions and 0 deletions.
120 changes: 120 additions & 0 deletions .github/workflows/cd-release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
# This is a basic workflow to help you get started with Actions

name: Docker Publish Release

# Controls when the action will run.
on:
release:
# Want to run the automation when a release is created
types: ['created']

# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
# This workflow contains a single job called "build"
docker-prod-release:
# The type of runner that the job will run on
runs-on: ubuntu-latest
# You could use the following lines to help make sure only X people start the workflow
# if: github.actor == 'admiralawkbar' || github.actor == 'jwiebalk'

# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- name: Checkout source code
uses: actions/checkout@v2

#########################
# Install Docker BuildX #
#########################
- name: Install Docker BuildX
uses: docker/setup-buildx-action@v1

######################################
# Login to GitHub Container Registry #
######################################
- name: Login to GitHub Container registry
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ secrets.GCR_USERNAME }}
password: ${{ secrets.GCR_TOKEN }}

# Update deployment API
- name: start deployment
uses: bobheadxi/[email protected]
id: deployment
with:
step: start
token: ${{ secrets.GITHUB_TOKEN }}
env: Release

# Create a GitHub Issue with the info from this build
- name: Create GitHub Issue
uses: actions/[email protected]
id: create-issue
with:
# https://octokit.github.io/rest.js/v18#issues-create
github-token: ${{secrets.GITHUB_TOKEN}}
script: |
const create = await github.issues.create({
owner: context.repo.owner,
repo: context.repo.repo,
title: "Deploying to production",
body: 'Currently deploying a release...'
})
console.log('create', create)
return create.data.number
###########################################
# Build and Push containers to registries #
###########################################
- name: Build and push
uses: docker/build-push-action@v2
with:
context: .
file: ./Dockerfile
push: true
tags: |
ghcr.io/lukaspersonal/containers:latest
ghcr.io/lukaspersonal/containers:${{ github.event.release.tag_name }}
# Update Deployment API
- name: update deployment status
uses: bobheadxi/[email protected]
if: always()
with:
step: finish
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
deployment_id: ${{ steps.deployment.outputs.deployment_id }}
env_url: https://github.com/orgs/${{github.repository_owner}}/packages?repo_name=${{github.repository.name}}

- name: Update issue success
uses: actions/[email protected]
if: success()
with:
# https://octokit.github.io/rest.js/v18#issues-create
github-token: ${{secrets.GITHUB_TOKEN}}
script: |
github.issues.createComment({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: "${{ steps.create-issue.outputs.result }}",
title: "New issue created",
body: "Successful!y deployed production"
})
- name: Update issue failure
uses: actions/[email protected]
if: failure()
with:
# https://octokit.github.io/rest.js/v18#issues-create
github-token: ${{secrets.GITHUB_TOKEN}}
script: |
github.issues.createComment({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: "${{ steps.create-issue.outputs.result }}",
title: "New issue created",
body: "Failed to deploy to production"
})

0 comments on commit 92e93bf

Please sign in to comment.