new multi-destination function.
This commit is contained in:
parent
06a91a4bf0
commit
dfb29711b0
@ -1,4 +1,5 @@
|
|||||||
#!groovy
|
#!groovy
|
||||||
|
import groovy.json.JsonOutput
|
||||||
|
|
||||||
def podYaml (Map config, List customImages = [[:]]) {
|
def podYaml (Map config, List customImages = [[:]]) {
|
||||||
def output = """
|
def output = """
|
||||||
@ -15,7 +16,6 @@ spec:
|
|||||||
imagePullPolicy: Always
|
imagePullPolicy: Always
|
||||||
image: ${config.repo}/library/kaniko:latest
|
image: ${config.repo}/library/kaniko:latest
|
||||||
tty: true
|
tty: true
|
||||||
stdin_open: true
|
|
||||||
command:
|
command:
|
||||||
- /busybox/sh"""
|
- /busybox/sh"""
|
||||||
}
|
}
|
||||||
@ -109,7 +109,7 @@ def buildContainer (Map config, List buildArg = []) {
|
|||||||
credentialsId: config.repoCreds,
|
credentialsId: config.repoCreds,
|
||||||
variable: "dCreds"
|
variable: "dCreds"
|
||||||
)]) {
|
)]) {
|
||||||
sh "printf '{\"auths\":{\"%s\":{\"auth\": \"%s\"}}}' \"${config.repository}\" \"${dcreds.bytes.encodeBase64().toString()}\" > /kaniko/.docker/config.json"
|
sh "set +x; printf '{\"auths\":{\"%s\":{\"auth\": \"%s\"}}}' \"${config.repository}\" \"${dcreds.bytes.encodeBase64().toString()}\" > /kaniko/.docker/config.json"
|
||||||
}
|
}
|
||||||
def buildArguments = ""
|
def buildArguments = ""
|
||||||
for (i in buildArg) {
|
for (i in buildArg) {
|
||||||
@ -126,6 +126,39 @@ def buildContainer (Map config, List buildArg = []) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def buildContainerMultipleDestinations (Map config, List buildArg = []) {
|
||||||
|
def ws = pwd()
|
||||||
|
stage ("Build Containers") {
|
||||||
|
container ("kaniko") {
|
||||||
|
writeFile (file: ws + "/Dockerfile", text: config.dockerFile)
|
||||||
|
|
||||||
|
def buildArguments = ""
|
||||||
|
def repoAuth = ["auths": [:]]
|
||||||
|
for (i in config.repositoryAccess) {
|
||||||
|
withCredentials([usernameColonPassword(
|
||||||
|
credentialsId: i.credentials,
|
||||||
|
variable: "dCreds"
|
||||||
|
)]) {
|
||||||
|
repoAuth."auths"[i.repository] = ["auth": dCreds.bytes.encodeBase64().toString()]
|
||||||
|
}
|
||||||
|
buildArguments += " --destination \"${i.repository}${i.destination}\""
|
||||||
|
}
|
||||||
|
sh "set +x; printf '${JsonOutput.toJson(repoAuth)}' > /kaniko/.docker/config.json"
|
||||||
|
|
||||||
|
for (i in buildArg) {
|
||||||
|
buildArguments += " --build-arg ${i}"
|
||||||
|
}
|
||||||
|
|
||||||
|
sh """
|
||||||
|
/kaniko/executor \\
|
||||||
|
--context "${ws}" \\
|
||||||
|
-f "${ws}/Dockerfile" \\
|
||||||
|
${buildArguments}
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
def pushArtifact (Map config) {
|
def pushArtifact (Map config) {
|
||||||
def ws = pwd()
|
def ws = pwd()
|
||||||
stage ("Push Artifact: " + config.fileName) {
|
stage ("Push Artifact: " + config.fileName) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user