124 lines
6.2 KiB
Groovy
124 lines
6.2 KiB
Groovy
// Global Variables
|
|
def NAMESPACE
|
|
def DEPLOYMENT_TYPE
|
|
def K8S_SERVER_URL
|
|
|
|
// Initialize the varaibles
|
|
def initialize(){
|
|
env.NAMESPACE = "${params.DATAPLANE_NAME.toLowerCase()}"
|
|
env.DEPLOYMENT_TYPE = "${params.K8S_CLUSTER}" + "-" + "${params.DATAPLANE_NAME.toUpperCase()}"
|
|
env.K8S_SERVER_URL = "https://" + "${params.K8S_CLUSTER}" + ".**masked**"
|
|
|
|
echo "Namespace: ${env.NAMESPACE}, Deployment Type: ${env.DEPLOYMENT_TYPE}, K8S Server URL: ${env.K8S_SERVER_URL}"
|
|
}
|
|
|
|
// Deploy the chart
|
|
def registerCluster(){
|
|
def helm_chart_name = "dp-core-infrastructure"
|
|
def release_name = "${helm_chart_name}"
|
|
def values_file = "values_" + "${helm_chart_name}" + ".yaml"
|
|
echo "Deploying release ${release_name} on cluster ${params.K8S_CLUSTER} in namespace ${env.NAMESPACE} using values file: ${values_file}"
|
|
withKubeConfig(caCertificate: '', clusterName: env.K8S_CLUSTER, contextName: env.K8S_CLUSTER, credentialsId: 'kubeconfig', namespace: env.NAMESPACE, serverUrl: env.K8S_SERVER_URL) {
|
|
sh label: '', script: """
|
|
kubectl config set-context --current --namespace ${env.NAMESPACE}
|
|
kubectl annotate --insecure-skip-tls-verify --overwrite ingress provisioner-agent -n ${env.NAMESPACE} helm.sh/hook-delete-policy- helm.sh/hook- meta.helm.sh/release-name=dp-core-infrastructure meta.helm.sh/release-namespace=${env.NAMESPACE}
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify repo add eai-tibco-platform https://tibcosoftware.github.io/tp-helm-charts
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify repo list
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify repo update
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify list
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify upgrade -i ${release_name} ${params.REPO}/${helm_chart_name} --set namespace=${env.NAMESPACE} --version ${params.HELM_DP_CORE_INFRA_CHART_VERSION} --reset-then-reuse-values -f deployments/${env.DEPLOYMENT_TYPE}/${values_file}
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify list
|
|
"""
|
|
}
|
|
}
|
|
|
|
// Deploy the chart
|
|
def configureNamespace(){
|
|
def helm_chart_name = "dp-configure-namespace"
|
|
def release_name = "${helm_chart_name}"
|
|
def values_file = "values_" + "${helm_chart_name}" + ".yaml"
|
|
echo "Deploying release ${release_name} on cluster ${params.K8S_CLUSTER} in namespace ${env.NAMESPACE} using values file: ${values_file}"
|
|
withKubeConfig(caCertificate: '', clusterName: env.K8S_CLUSTER, contextName: env.K8S_CLUSTER, credentialsId: 'kubeconfig', namespace: env.NAMESPACE, serverUrl: env.K8S_SERVER_URL) {
|
|
sh label: '', script: """
|
|
kubectl config set-context --current --namespace ${env.NAMESPACE}
|
|
echo "Applying DataPlane Label"
|
|
kubectl --insecure-skip-tls-verify=true label namespaces ${env.NAMESPACE} platform.tibco.com/dataplane-id=${params.HELM_DP_CONFIG_NAMESPACE_DATAPLANE_ID} --overwrite=true
|
|
echo "DataPlane Label applied"
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify repo add eai-tibco-platform https://tibcosoftware.github.io/tp-helm-charts
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify repo list
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify version
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify repo update
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify list
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify upgrade -i ${release_name} ${params.REPO}/${helm_chart_name} --set namespace=${env.NAMESPACE} --version ${params.HELM_DP_CONFIG_NAMESPACE_CHART_VERSION} --reset-then-reuse-values -f deployments/${env.DEPLOYMENT_TYPE}/${values_file}
|
|
${HELM_HOME} --kube-insecure-skip-tls-verify list
|
|
"""
|
|
}
|
|
}
|
|
|
|
pipeline {
|
|
agent any
|
|
|
|
environment{
|
|
HELM_HOME=tool name: 'HELM3', type: 'com.cloudbees.jenkins.plugins.customtools.CustomTool'
|
|
}
|
|
parameters{
|
|
string(name: 'SOURCE_TAG', defaultValue: 'main', description: 'Please enter the GIT branch', trim: true)
|
|
choice(name: 'DATAPLANE_NAME', choices: ['test-dp','test-dp2','poc','devhub','dev', 'sit','uat', 'prod'], description: 'Please select the correct dataplane envrionment name')
|
|
choice(name: 'K8S_CLUSTER', choices: ['minikube','IAH-WEST', 'IAH-EAST','EUDC-WEST', 'EUDC-EAST', 'USDC-WEST', 'USDC-EAST' ], description: 'Pick the right k8s cluster')
|
|
choice(name: 'REPO', choices: ['eai-tibco-platform','stable', 'incubator'], description: 'repository type')
|
|
string(name: 'HELM_DP_CONFIG_NAMESPACE_DATAPLANE_ID', description: 'DataPlane ID used for labeling the namespaces', trim: true)
|
|
string(name: 'HELM_DP_CONFIG_NAMESPACE_CHART_VERSION', description: 'Version of the DP configure namespace to be deployed', trim: true)
|
|
string(name: 'HELM_DP_CORE_INFRA_CHART_VERSION', description: 'Version of the DP Core Infrastructure to be deployed', trim: true)
|
|
}
|
|
stages {
|
|
stage('Initialize') {
|
|
steps {
|
|
// cleanup workspace before every build
|
|
deleteDir()
|
|
|
|
script{
|
|
// set the displayName for the build
|
|
currentBuild.displayName = "#" + env.BUILD_NUMBER + " " + params.K8S_CLUSTER + " " + params.DATAPLANE_NAME + " " + params.HELM_DP_CONFIG_NAMESPACE_CHART_VERSION + " " + params.HELM_DP_CORE_INFRA_CHART_VERSION
|
|
}
|
|
// Set the variables
|
|
initialize()
|
|
}
|
|
}
|
|
stage('Checkout') {
|
|
steps {
|
|
sh 'printenv'
|
|
checkout([
|
|
$class: 'GitSCM',
|
|
branches : [[name: "origin/${params.SOURCE_TAG}"]],
|
|
doGenerateSubmoduleConfigurations: false,
|
|
extensions: [[$class: 'LocalBranch', localBranch: "**"]],
|
|
submoduleCfg: [],
|
|
userRemoteConfigs: [
|
|
[
|
|
url: 'http://192.168.1.20:3000/tibco/tibco-platform.git',
|
|
credentialsId: '16371a65-35d0-414c-9b58-44b24e1b47ed'
|
|
]
|
|
]
|
|
])
|
|
sh "git branch"
|
|
}
|
|
}
|
|
|
|
stage('Deploy') {
|
|
steps {
|
|
|
|
|
|
registerCluster()
|
|
configureNamespace()
|
|
|
|
}
|
|
}
|
|
|
|
}
|
|
post {
|
|
always {
|
|
cleanWs()
|
|
}
|
|
}
|
|
}
|