-
Notifications
You must be signed in to change notification settings - Fork 1
117 lines (105 loc) · 4.23 KB
/
web.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
name: 🔨 Push Web Image to Artifactory and Deploy to OpenShift
concurrency:
group: ${{ github.workflow }}-github.ref }}
cancel-in-progress: false
env:
APP: web
USER: ${{ github.actor }}
on:
workflow_call:
push:
branches:
- dev
#- test
#- prod
paths:
- 'PHP.Dockerfile'
- '**/config/nginx/**'
- '**/workflows/web.yml'
- '**/**.env'
pull_request:
branches:
- dev
#- test
#- prod
paths:
- 'PHP.Dockerfile'
- '**/config/nginx/**'
- '**/workflows/web.yml'
- '**/**.env'
jobs:
#Print variables for logging and debugging purposes
checkEnv:
name: 📋 Environment Check
runs-on: ubuntu-latest
steps:
- name: Check Env Vars
run: |
echo Building ${{ env.WEB_DEPLOYMENT_NAME }}:${{ env.OPENSHIFT_DEPLOY_PROJECT }}-${{ github.ref_name }}
# Build Images
build-images:
name: '🔨 Build Moodle and PHP images'
needs: [checkEnv]
runs-on: ubuntu-latest
if: ${{ needs.checkEnv.SKIP_BUILDS != 'YES' }} && (github.ref_name == 'dev' || github.ref_name == 'test' || github.ref_name == 'prod')
steps:
# Checkout the PR branch
- name: 📤 Checkout Target Branch
uses: actions/checkout@v2
# Login to Artifactory
- name: 🔑 Login to Artifactory
uses: docker/login-action@v3
with:
registry: ${{ secrets.ARTIFACTORY_URL }}
username: ${{ secrets.ARTIFACTORY_USER }}
password: ${{ secrets.ARTIFACTORY_PASSWORD }}
- name: Setup Env Vars
id: dotenv
uses: falti/dotenv-action@v1
with:
path: example.env
export-variables: true
keys-case: upper
- name: Setup Versions Env Vars
id: dotenv_versions
uses: falti/dotenv-action@v1
with:
path: example.versions.env
export-variables: true
keys-case: upper
# Pull latest WEB image and push to Artifactory
- name: 🛠️ Pull WEB base image and push to Artifactory
run: |
docker pull ${{ env.WEB_IMAGE }}
docker tag ${{ env.WEB_IMAGE }} ${{ secrets.ARTIFACTORY_URL }}/${{ env.WEB_IMAGE }}
docker push ${{ secrets.ARTIFACTORY_URL }}/${{ env.WEB_IMAGE }}
# Log in to OpenShift.
# Note: The secrets needed to log in are NOT available if the PR comes from a FORK.
# PR's must originate from a branch off the original repo or else all openshift `oc` commands will fail.
- name: 🔑 Log in to OpenShift ( ${{ github.ref_name }} )
run: |
server=https://api.silver.devops.gov.bc.ca:6443
if [[ ${{ github.ref_name == 'test' }} ]]; then
oc login --token=${{ secrets.AUTH_TOKEN_DEV }} --server=$server
elif [[ ${{ github.ref_name == 'test' }} ]]; then
oc login --token=${{ secrets.AUTH_TOKEN_TEST }} --server=$server
elif [[ ${{ github.ref_name == 'prod' }} ]]; then
oc login --token=${{ secrets.AUTH_TOKEN_PROD }} --server=$server
else
echo "No AUTH_TOKEN found for ${{ github.ref_name }} branch"
fi
# For a graceful termination, set the replica count of the Pods in the mariadb-galera StatefulSet to 0:
# oc scale dc ${{ env.WEB_DEPLOYMENT_NAME }} --replicas=0
# To uninstall/delete the my-release release:
# helm delete --purge ${{ env.WEB_DEPLOYMENT_NAME }}
- name: 🚀 Deploy ${{ env.WEB_DEPLOYMENT_NAME }} to ${{ env.OPENSHIFT_DEPLOY_PROJECT }}-${{ github.ref_name }}
if: success()
run: |
if [[ `oc describe dc ${{ env.WEB_DEPLOYMENT_NAME }} 2>&1` =~ "NotFound" ]]; then
echo "${{ env.WEB_DEPLOYMENT_NAME }} NOT FOUND: Beginning deployment..."
oc create configmap ${{ env.WEB_DEPLOYMENT_NAME }}-config --from-file=./config/nginx/default.conf -n ${{ env.OPENSHIFT_DEPLOY_PROJECT }}-${{ github.ref_name }}
else
echo "${{ env.WEB_DEPLOYMENT_NAME }} Installation FOUND...UPDATING..."
oc annotate --overwrite dc/${{ env.WEB_DEPLOYMENT_NAME }} kubectl.kubernetes.io/restartedAt=`date +%FT%T` -n ${{ env.OPENSHIFT_DEPLOY_PROJECT }}-${{ github.ref_name }}
oc rollout latest dc/${{ env.WEB_DEPLOYMENT_NAME }}
fi