forked from ONSdigital/onse-banking-app-infrastructure
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJenkinsfile
48 lines (43 loc) · 1.65 KB
/
Jenkinsfile
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
def github_id = 'stevescorfield'
def git_repository = "https://github.com/${github_id}/onse-banking-app-infrastructure"
def namespace = github_id.toLowerCase()
def rabbitmq_host = "${namespace}-rabbit.apps.onse-training.co.uk"
def app_host = "${namespace}-app.apps.onse-training.co.uk"
def kubectl_image = 'aklearning/onse-eks-kubectl-deployer:0.0.1'
def label = "build-${UUID.randomUUID().toString()}"
def build_pod_template = """
kind: Pod
metadata:
name: build-pod
spec:
containers:
- name: kubectl
image: ${kubectl_image}
imagePullPolicy: Always
tty: true
"""
podTemplate(name: "${namespace}-app-infrastructure-build", label: label, yaml: build_pod_template) {
node(label) {
git git_repository
stage('Deploy to Kubernetes') {
withCredentials([
string(credentialsId: 'AWS_ACCESS_KEY_ID', variable: 'AWS_ACCESS_KEY_ID'),
string(credentialsId: 'AWS_SECRET_ACCESS_KEY', variable: 'AWS_SECRET_ACCESS_KEY'),
string(credentialsId: 'KUBERNETES_SERVER', variable: 'KUBERNETES_SERVER'),
file(credentialsId: 'KUBERNETES_CA', variable: 'KUBERNETES_CA')
]) {
container(name: 'kubectl', shell: '/bin/sh') {
sh '''kubectl config \
set-cluster kubernetes \
--server=$KUBERNETES_SERVER \
--certificate-authority=$KUBERNETES_CA
'''
sh "yq.v2 w -i kubernetes/ingress.yml 'spec.rules[0].host' ${rabbitmq_host}"
sh "yq.v2 w -i kubernetes/ingress.yml 'spec.rules[1].host' ${app_host}"
sh "kubectl create namespace ${namespace} || true"
sh "kubectl apply -n ${namespace} -f kubernetes/"
}
}
}
}
}