--- /dev/null
+#!/usr/bin/env groovy\r
+\r
+\r
+properties([[$class: 'ParametersDefinitionProperty', parameterDefinitions: [ \r
+ [$class: 'hudson.model.StringParameterDefinition', name: 'PHASE', defaultValue: "BUILD"],\r
+ [$class: 'hudson.model.StringParameterDefinition', name: 'ENV', defaultValue: "dev"], \r
+ [$class: 'hudson.model.StringParameterDefinition', name: 'MECHID', defaultValue: "id"], \r
+ [$class: 'hudson.model.StringParameterDefinition', name: 'KUBE_CONFIG', defaultValue: "kubeConfig-dev"], \r
+ [$class: 'hudson.model.StringParameterDefinition', name: 'TILLER_NAMESPACE', defaultValue: "org-onap-otf"] \r
+]]]) \r
+\r
+\r
+echo "Build branch: ${env.BRANCH_NAME}"\r
+\r
+node("docker"){\r
+ stage 'Checkout'\r
+ checkout scm\r
+ PHASES=PHASE.tokenize( '_' );\r
+ echo "PHASES : " + PHASES\r
+ ARTIFACT_ID="otf-aaf-credential-generator"\r
+ echo "Tiller Namespace: " + TILLER_NAMESPACE\r
+\r
+ withEnv(["PATH=${env.PATH}:${tool 'jdk180'}:${env.WORKSPACE}/linux-amd64", "JAVA_HOME=${tool 'jdk180'}","HELM_HOME=${env.WORKSPACE}"]) { \r
+ \r
+ echo "PATH=${env.PATH}"\r
+ echo "JAVA_HOME=${env.JAVA_HOME}"\r
+ echo "HELM_HOME=${env.HELM_HOME}"\r
+\r
+ wrap([$class: 'ConfigFileBuildWrapper', managedFiles: [\r
+ [fileId: 'maven-settings.xml', variable: 'MAVEN_SETTINGS']\r
+ ]]) {\r
+\r
+ if (PHASES.contains("DEPLOY") || PHASES.contains("UNDEPLOY")) { \r
+ stage 'Init Helm'\r
+\r
+ //check if helm exists if not install\r
+ if(fileExists('linux-amd64/helm')){\r
+ sh """\r
+ echo "helm is already installed"\r
+ """\r
+ }\r
+ else{\r
+ //download helm\r
+ sh """\r
+ echo "installing helm"\r
+ wget https://storage.googleapis.com/kubernetes-helm/helm-v2.8.2-linux-amd64.tar.gz\r
+ tar -xf helm-v2.8.2-linux-amd64.tar.gz\r
+ rm helm-v2.8.2-linux-amd64.tar.gz\r
+ """\r
+ }\r
+\r
+ withCredentials([file(credentialsId: KUBE_CONFIG, variable: 'KUBECONFIG')]) {\r
+\r
+ dir('helm'){\r
+ //check if charts are valid, and then perform dry run, if successful then upgrade/install charts\r
+\r
+ if (PHASES.contains("UNDEPLOY") ) {\r
+ stage 'Undeploy'\r
+ \r
+ sh """\r
+ helm delete --tiller-namespace=$TILLER_NAMESPACE --purge $ARTIFACT_ID\r
+ """\r
+ }\r
+\r
+ //NOTE Double quotes are used below to access groovy variables like artifact_id and tiller_namespace\r
+ if (PHASES.contains("DEPLOY") ){\r
+ stage 'Deploy'\r
+ withCredentials([usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]) {\r
+\r
+ //Note: KEYFILE_PATH must be within helm/$ARTIFACT_ID and must be relative path starting from that directory\r
+ sh """\r
+\r
+ echo "Remove old key info"\r
+ rm -rf keyfile;\r
+ rm -rf digest.txt\r
+ rm -rf $ARTIFACT_ID/keyfile\r
+\r
+ ls\r
+ echo "Create keyfile and digest"\r
+ java -jar ../aaf_cadi_core_2.1.10_SNAPSHOT.jar keygen keyfile\r
+ java -jar ../aaf_cadi_core_2.1.10_SNAPSHOT.jar digest $PASSWORD keyfile > digest.txt 2>&1\r
+ \r
+ cp keyfile $ARTIFACT_ID\r
+ KEYFILE_PATH=keyfile\r
+ DIGEST="enc:"\r
+ DIGEST+=\$(cat digest.txt)\r
+ echo \$DIGEST\r
+ echo "Validate Yaml"\r
+ helm lint $ARTIFACT_ID\r
+\r
+ echo "View Helm Templates"\r
+ helm template $ARTIFACT_ID --set Secret.aafId=$USERNAME --set Secret.aafPassword=\$DIGEST --set Secret.aafMechPassword=$PASSWORD --set keyfilePath=\$KEYFILE_PATH\r
+\r
+ echo "Perform Dry Run Of Install"\r
+ helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install --dry-run $ARTIFACT_ID $ARTIFACT_ID --set Secret.aafId=$USERNAME --set Secret.aafPassword=\$DIGEST --set Secret.aafMechPassword=$PASSWORD --set keyfilePath=\$KEYFILE_PATH\r
+\r
+ echo "Helm Install/Upgrade"\r
+ helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install $ARTIFACT_ID $ARTIFACT_ID --set Secret.aafId=$USERNAME --set Secret.aafPassword=\$DIGEST --set Secret.aafMechPassword=$PASSWORD --set keyfilePath=\$KEYFILE_PATH\r
+\r
+ rm -rf $ARTIFACT_ID/keyfile\r
+ rm -rf keyfile\r
+ rm -rf digest.txt\r
+ """\r
+ }\r
+ }\r
+\r
+ }\r
+ }\r
+ } \r
+ }\r
+ }\r
+}
\ No newline at end of file