Skip to content

Update main.yml

Update main.yml #33

Workflow file for this run

# This is a basic workflow to help you get started with Actions
name: CI
concurrency:
group: ci
cancel-in-progress: true
# Controls when the workflow will run
on:
# Triggers the workflow on push or pull request events but only for the master branch
push:
branches: [master]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# 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"
build:
# The type of runner that the job will run on
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Ensure latest version of git.
- name: Ensure latests version of git
run: |
sudo apt-get install -y software-properties-common \
&& sudo apt-get update \
&& sudo add-apt-repository -y ppa:git-core/ppa \
&& sudo apt-get update \
&& sudo apt-get install -y git
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v3
# fetch all history for all branches and tags, so that our `make` targets can get tags
with:
fetch-depth: 0
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
# Builds docker images and pushes them to GHCR
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: gal
password: ${{ secrets.GITHUB_TOKEN }}
# - name: Build and push dev-env image
# uses: docker/[email protected]
# with:
# push: true
# context: .
# tags: ghcr.io/uccnetsoc/whodis:dev-env, ghcr.io/uccnetsoc/whodis:${{ github.sha }}-dev-env
# target: dev
- name: Build and push prod image
uses: docker/build-push-action@v5
with:
push: true
context: .
tags: ghcr.io/uccnetsoc/whodis:latest, ghcr.io/uccnetsoc/whodis:${{ github.sha }}
deploy:
needs: [build]
runs-on: ubuntu-latest
steps:
- name: Ansible playbook runner via SSH Action
uses: UCCNetsoc/ansible-action@main
with:
tags: "whodis"
control_host: ${{ secrets.CONTROL_HOST }}
control_user: ${{ secrets.CONTROL_USER }}
control_ssh_key: ${{ secrets.SSH_KEY }}
directory: ${{ secrets.CONTROL_DIRECTORY }}
vault_pass: ${{ secrets.VAULT_PASS }}
port: ${{ secrets.CONTROL_PORT }}