adding vth code as well as aaf and cert config
[it/otf.git] / otf-aaf-credential-generator / Jenkinsfile
diff --git a/otf-aaf-credential-generator/Jenkinsfile b/otf-aaf-credential-generator/Jenkinsfile
new file mode 100644 (file)
index 0000000..c2d0b5c
--- /dev/null
@@ -0,0 +1,112 @@
+#!/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