added svcapi ui and camunda code
[it/otf.git] / otf-frontend / Jenkinsfile
diff --git a/otf-frontend/Jenkinsfile b/otf-frontend/Jenkinsfile
new file mode 100644 (file)
index 0000000..0cc1a01
--- /dev/null
@@ -0,0 +1,153 @@
+#!/usr/bin/env groovy\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: "username"],\r
+[$class: 'hudson.model.StringParameterDefinition', name: 'KUBE_CONFIG', defaultValue: "kubeConfig-dev"],\r
+[$class: 'hudson.model.StringParameterDefinition', name: 'OTF_MONGO_DB', defaultValue: "otf_mongo_dev_db"],\r
+[$class: 'hudson.model.StringParameterDefinition', name: 'OTF_CAMUNDA_DB', defaultValue: "otf_camunda_dev_db"],\r
+[$class: 'hudson.model.StringParameterDefinition', name: 'TILLER_NAMESPACE', defaultValue: ""]\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
+\r
+\r
+       ARTIFACT_ID="otf-frontend";\r
+       VERSION="Camille.1.0.3";\r
+       //TODO: deal with namespace and docker registry\r
+       NAMESPACE=""\r
+       DOCKER_REGISTRY=""\r
+\r
+       if( ENV.equalsIgnoreCase("dev") ){\r
+               IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + "/" + ARTIFACT_ID +  ":" + VERSION\r
+       }\r
+       if( ENV.equalsIgnoreCase("prod") || ENV.equalsIgnoreCase("prod-dr")){\r
+               IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + ".prod" + "/" + ARTIFACT_ID +  ":" + VERSION\r
+       }\r
+       if( ENV.equalsIgnoreCase("st") ){\r
+               IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + ".st" + "/" + ARTIFACT_ID +  ":" + VERSION\r
+       }\r
+       echo "Artifact: " + IMAGE_NAME\r
+\r
+       withEnv(["PATH=${env.PATH}:${env.WORKSPACE}/linux-amd64", "HELM_HOME=${env.WORKSPACE}"]) {\r
+\r
+               echo "PATH=${env.PATH}"\r
+               echo "HELM_HOME=${env.HELM_HOME}"\r
+\r
+               withCredentials([usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]) {\r
+\r
+                       // sh """\r
+                       //      docker login $DOCKER_REGISTRY --username $USERNAME --password $PASSWORD\r
+                       // """\r
+\r
+                       if (PHASES.contains("BUILD")){\r
+                               stage 'Publish Artifact'\r
+\r
+\r
+                                       echo "Artifact: " + IMAGE_NAME\r
+\r
+                                       sh """\r
+                                               docker login $DOCKER_REGISTRY --username $USERNAME --password $PASSWORD\r
+                                               docker build --no-cache -t $IMAGE_NAME .\r
+                                               docker push $IMAGE_NAME\r
+                                       """\r
+\r
+\r
+                       }\r
+               }\r
+\r
+               if (PHASES.contains("DEPLOY") || PHASES.contains("UNDEPLOY")) {\r
+\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([\r
+                                                               usernamePassword(credentialsId: OTF_MONGO_DB, usernameVariable: 'USERNAME_MONGO', passwordVariable: 'PASSWORD_MONGO'),\r
+                                                               usernamePassword(credentialsId: 'FEATHERS_AUTH', usernameVariable: 'USER', passwordVariable: 'AUTHENTICATION_SECRET')\r
+                                                               ]) {\r
+\r
+                                                               sh """\r
+                                                                       echo "Validate Yaml"\r
+                                                                       helm lint $ARTIFACT_ID\r
+\r
+                                                                       echo "View Helm Templates"\r
+                                                                       helm template $ARTIFACT_ID \\r
+                                                                               --set appName=$ARTIFACT_ID \\r
+                                                                               --set version=$VERSION \\r
+                                                                               --set image=$IMAGE_NAME \\r
+                                                                               --set namespace=$TILLER_NAMESPACE \\r
+                                                                         --set env=$ENV \\r
+                                                                               --set AUTHENTICATION_SECRET=$AUTHENTICATION_SECRET \\r
+                                                                               --set mongo.username=$USERNAME_MONGO \\r
+                                                                               --set mongo.password=$PASSWORD_MONGO\r
+\r
+                                                                       echo "Perform Dry Run Of Install"\r
+                                                                       helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install --dry-run $ARTIFACT_ID $ARTIFACT_ID \\r
+                                                                               --set appName=$ARTIFACT_ID \\r
+                                                                               --set version=$VERSION \\r
+                                                                               --set image=$IMAGE_NAME \\r
+                                                                               --set namespace=$TILLER_NAMESPACE \\r
+                                                                         --set env=$ENV \\r
+                                                                               --set AUTHENTICATION_SECRET=$AUTHENTICATION_SECRET \\r
+                                                                               --set mongo.username=$USERNAME_MONGO \\r
+                                                                               --set mongo.password=$PASSWORD_MONGO\r
+\r
+                                                                       echo "Helm Install/Upgrade"\r
+                                                               helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install --timeout 1000 $ARTIFACT_ID $ARTIFACT_ID \\r
+                                                                               --set appName=$ARTIFACT_ID \\r
+                                                                               --set version=$VERSION \\r
+                                                                               --set image=$IMAGE_NAME \\r
+                                                                               --set namespace=$TILLER_NAMESPACE \\r
+                                                                               --set env=$ENV \\r
+                                                                               --set AUTHENTICATION_SECRET=$AUTHENTICATION_SECRET \\r
+                                                                               --set mongo.username=$USERNAME_MONGO \\r
+                                                                               --set mongo.password=$PASSWORD_MONGO\r
+\r
+                                                               """\r
+                                                       }\r
+                       }\r
+\r
+                               }\r
+                       }\r
+       }\r
+\r
+       }\r
+}\r