76 lines
2.1 KiB
Groovy
76 lines
2.1 KiB
Groovy
#!groovy
|
|
|
|
def podYaml (Map config) {
|
|
def output = """
|
|
---
|
|
apiVersion: v1
|
|
kind: Pod
|
|
metadata:
|
|
name: ${config.templateName}
|
|
spec:
|
|
containers:
|
|
"""
|
|
if (config.kaniko == true) {
|
|
output += """
|
|
- name: kaniko
|
|
imagePullPolicy: Always
|
|
image: ${config.repo}/library/kaniko:latest
|
|
tty: true
|
|
command:
|
|
- /busybox/sh
|
|
"""
|
|
}
|
|
if (config.alpine == true) {
|
|
output += """
|
|
- name: alpine
|
|
imagePullPolicy: Always
|
|
image: ${config.repo}/library/alpine:latest
|
|
tty: true
|
|
"""
|
|
}
|
|
|
|
return output
|
|
}
|
|
|
|
def deletePod (Map config) {
|
|
def ws = pwd()
|
|
stage ("Delete Pod") {
|
|
container ("alpine") {
|
|
sh """
|
|
apk add --no-cache curl
|
|
curl -L --silent https://storage.googleapis.com/kubernetes-release/release/\$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl -o /usr/local/bin/kubectl
|
|
chmod +x /usr/local/bin/kubectl
|
|
"""
|
|
|
|
withKubeConfig ([
|
|
credentialsId: config.kubeAuth,
|
|
serverUrl: config.kubeURL,
|
|
namespace: config.namespace,
|
|
]) {
|
|
sh "for i in \$(kubectl get pods --selector ${config.selector} -o name); do kubectl delete \${i}; done"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
def buildContainer (Map config) {
|
|
def ws = pwd()
|
|
stage ("Build Container") {
|
|
container ("kaniko") {
|
|
writeFile (file: ws + "/Dockerfile", text: config.dockerFile)
|
|
withCredentials([usernameColonPassword(
|
|
credentialsId: config.repoCreds,
|
|
variable: "dCreds",
|
|
)]) {
|
|
sh "set +x; printf '{\"auths\":{\"%s\":{\"auth\": \"%s\"}}}' \"${config.repository}\" \"${dcreds.bytes.encodeBase64().toString()}\" > /kaniko/.docker/config.json"
|
|
}
|
|
sh """
|
|
/kaniko/executor \\
|
|
--context "${ws}" \\
|
|
-f "${ws}/Dockerfile" \\
|
|
--destination "${config.imageDest}"
|
|
"""
|
|
}
|
|
}
|
|
}
|