-/*
-* Copyright © 2019 TechMahindra
-*
-* Licensed under the Apache License, Version 2.0 (the "License");
-* you may not use this file except in compliance with the License.
-* You may obtain a copy of the License at
-*
-* http://www.apache.org/licenses/LICENSE-2.0
-*
-* Unless required by applicable law or agreed to in writing, software
-* distributed under the License is distributed on an "AS IS" BASIS,
-* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-* See the License for the specific language governing permissions and
-* limitations under the License.
-*/
-
-package org.onap.ccsdk.cds.blueprintsprocessor.services.execution.scripts
-
-import com.fasterxml.jackson.annotation.JsonIgnore
-import com.fasterxml.jackson.annotation.JsonProperty
-import com.fasterxml.jackson.databind.ObjectMapper
-import com.fasterxml.jackson.databind.node.ObjectNode
-import com.fasterxml.jackson.databind.JsonNode
-import com.fasterxml.jackson.module.kotlin.jacksonObjectMapper
-import java.io.File
-import java.nio.file.Path
-import java.nio.file.Paths
-import org.apache.commons.io.FilenameUtils
-import org.apache.commons.io.IOUtils
-import org.apache.http.client.ClientProtocolException
-import org.apache.http.client.entity.EntityBuilder
-import org.apache.http.client.methods.HttpPost
-import org.apache.http.client.methods.HttpUriRequest
-import org.apache.http.entity.ContentType
-import org.apache.http.message.BasicHeader
-import org.onap.ccsdk.cds.blueprintsprocessor.core.api.data.ExecutionServiceInput
-import org.onap.ccsdk.cds.blueprintsprocessor.rest.BasicAuthRestClientProperties
-import org.onap.ccsdk.cds.blueprintsprocessor.rest.RestClientProperties
-import org.onap.ccsdk.cds.blueprintsprocessor.rest.service.BasicAuthRestClientService
-import org.onap.ccsdk.cds.blueprintsprocessor.rest.service.BlueprintWebClientService
-import org.onap.ccsdk.cds.blueprintsprocessor.core.BluePrintPropertiesService
-import org.onap.ccsdk.cds.blueprintsprocessor.functions.k8s.definition.K8sPluginDefinitionApi
-import org.onap.ccsdk.cds.blueprintsprocessor.functions.k8s.K8sConnectionPluginConfiguration
-import org.onap.ccsdk.cds.blueprintsprocessor.functions.k8s.definition.K8sDefinitionRestClient
-import org.onap.ccsdk.cds.blueprintsprocessor.rest.service.RestLoggerService
-import org.onap.ccsdk.cds.blueprintsprocessor.services.execution.AbstractScriptComponentFunction
-import org.onap.ccsdk.cds.blueprintsprocessor.functions.resource.resolution.contentFromResolvedArtifactNB
-import org.onap.ccsdk.cds.controllerblueprints.core.BluePrintProcessorException
-import org.onap.ccsdk.cds.controllerblueprints.core.utils.ArchiveType
-import org.onap.ccsdk.cds.controllerblueprints.core.utils.BluePrintArchiveUtils
-import org.onap.ccsdk.cds.controllerblueprints.core.utils.JacksonUtils
-import org.onap.ccsdk.cds.blueprintsprocessor.functions.resource.resolution.storedContentFromResolvedArtifactNB
-import org.slf4j.LoggerFactory
-import org.springframework.http.HttpHeaders
-import org.springframework.http.HttpMethod
-import org.springframework.http.MediaType
-import org.springframework.web.client.RestTemplate
-import org.yaml.snakeyaml.Yaml
-import java.util.ArrayList
-import java.io.IOException
-
-import java.util.Base64
-import java.nio.charset.Charset
-import java.nio.file.Files
-import com.google.gson.Gson
-import com.google.gson.reflect.TypeToken
-
-open class DayOneConfig : AbstractScriptComponentFunction() {
-
- private val log = LoggerFactory.getLogger(DayOneConfig::class.java)!!
-
- override fun getName(): String {
- return "DayOneConfig"
- }
-
- override suspend fun processNB(executionRequest: ExecutionServiceInput) {
- log.info("DAY-1 Script excution Started")
-
- val prefix = "baseconfig"
-
- val baseK8sApiUrl = getDynamicProperties("api-access").get("url").asText()
- val k8sApiUsername = getDynamicProperties("api-access").get("username").asText()
- val k8sApiPassword = getDynamicProperties("api-access").get("password").asText()
-
- log.info("Multi-cloud params $baseK8sApiUrl")
-
- val aaiApiUrl = getDynamicProperties("aai-access").get("url").asText()
- val aaiApiUsername = getDynamicProperties("aai-access").get("username").asText()
- val aaiApiPassword = getDynamicProperties("aai-access").get("password").asText()
-
-
-
- log.info("AAI params $aaiApiUrl")
-
-
-
-
- val resolution_key = getDynamicProperties("resolution-key").asText()
-
- val sdnc_payload:String = contentFromResolvedArtifactNB("config-deploy-sdnc")
- //log.info("SDNC payload $sdnc_payload")
- val sdnc_payloadObject = JacksonUtils.jsonNode(sdnc_payload) as ObjectNode
-
-
- val aai_payload:String = contentFromResolvedArtifactNB("config-deploy-aai")
- //log.info("AAI payload $aai_payload")
- val aai_payloadObject = JacksonUtils.jsonNode(aai_payload) as ObjectNode
-
-
-
-
-
-
- try {
-
- for (item in sdnc_payloadObject.get("vf-modules")){
-
- var instanceID:String =""
- val modelTopology = item.get("vf-module-data").get("vf-module-topology")
-
-
-
- val moduleParameters = modelTopology.get("vf-module-parameters").get("param")
-
- val label: String? = getParamValueByName(moduleParameters, "vf-module-label")
- val modelInfo = modelTopology.get("onap-model-information")
- val vfModuleInvariantID = modelInfo.get("model-invariant-uuid").asText()
- log.info("VF MOdule Inavriant ID $vfModuleInvariantID")
- val vfModuleCustID=modelInfo.get("model-customization-uuid").asText()
- val vfModuleUUID=modelInfo.get("model-uuid").asText()
- val idInfo = modelTopology.get("vf-module-topology-identifier")
- val vfModuleID = idInfo.get("vf-module-id").asText()
- for (aai_item in aai_payloadObject.get("vf-modules"))
- {
- if (aai_item.get("vf-module-id").asText() == vfModuleID && aai_item.get("heat-stack-id") != null)
- {
- instanceID=aai_item.get("heat-stack-id").asText()
- break
- }
- }
-
-
-
- val k8sRbProfileName: String = "profile_" + vfModuleID
-
- val k8sConfigTemplateName: String = "template_" + vfModuleCustID
-
- val api = K8sConfigTemplateApi(k8sApiUsername, k8sApiPassword, baseK8sApiUrl, vfModuleInvariantID, vfModuleCustID, k8sConfigTemplateName)
-
- // Check if definition exists
- if (!api.hasDefinition()) {
- throw BluePrintProcessorException("K8S Definition ($vfModuleInvariantID/$vfModuleCustID) not found ")
- }
- val bluePrintPropertiesService: BluePrintPropertiesService =this.functionDependencyInstanceAsType("bluePrintPropertiesService")
- val k8sConfiguration = K8sConnectionPluginConfiguration(bluePrintPropertiesService)
- val rbDefinitionService = K8sDefinitionRestClient(k8sConfiguration,vfModuleInvariantID, vfModuleCustID)
-
-
- val def: BlueprintWebClientService.WebClientResponse<String> = rbDefinitionService.exchangeResource(HttpMethod.GET.name,"","")
- log.info(def.body.toString())
- val rbdef = JacksonUtils.jsonNode(def.body.toString()) as ObjectNode
- val chartName = rbdef.get("chart-name").asText()
-
- log.info("Config Template name: $k8sConfigTemplateName")
-
-
-
- var configTemplate = K8sConfigTemplate()
- configTemplate.templateName = k8sConfigTemplateName
- configTemplate.description = " "
- configTemplate.ChartName = chartName
- log.info("Chart name: ${configTemplate.ChartName}")
-
-
-
- if (!api.hasConfigTemplate(configTemplate)) {
-
-
- val configTemplateFile: Path = prepareConfigTemplateJson(k8sConfigTemplateName, vfModuleID, label)
-
- log.info("Config Template Upload Started")
- api.createConfigTemplate(configTemplate)
- api.uploadConfigTemplateContent(configTemplate, configTemplateFile)
- log.info("Config Template Upload Completed")
- }
- }
- log.info("DAY-1 Script excution completed")
-
-
- }
- catch (e: Exception) {
- log.info("Caught exception during config template preparation!!")
- throw BluePrintProcessorException("${e.message}")
- }
- }
- private fun getParamValueByName(params: JsonNode, paramName: String): String? {
- for (param in params) {
- if (param.get("name").asText() == paramName && param.get("value").asText() != "null") {
- return param.get("value").asText()
-
- }
- }
- return null
- }
-
- fun prepareConfigTemplateJson(configTemplateName: String, vfModuleID: String, label: String?): Path {
- val bluePrintContext = bluePrintRuntimeService.bluePrintContext()
- val bluePrintBasePath: String = bluePrintContext.rootPath
-
- var profileFilePath: Path = Paths.get(bluePrintBasePath.plus(File.separator).plus("Templates").plus(File.separator).plus("k8s-profiles").plus(File.separator).plus(label +"-config-template.tar.gz"))
- log.info("Reading K8s Config Template file: $profileFilePath")
-
- val profileFile = profileFilePath.toFile()
-
- if (!profileFile.exists())
- throw BluePrintProcessorException("K8s Config template file $profileFilePath does not exists")
-
- return profileFilePath
- }
-
-
- fun getResolvedParameter(payload: ObjectNode, keyName: String): String {
- for (node in payload.get("resource-accumulator-resolved-data").elements()) {
- if (node.get("param-name").asText().equals(keyName)) {
- return node.get("param-value").asText()
- }
- }
- return ""
- }
- override suspend fun recoverNB(runtimeException: RuntimeException, executionRequest: ExecutionServiceInput) {
- log.info("Recover function called!")
- log.info("Execution request : $executionRequest")
- log.error("Exception", runtimeException)
- addError(runtimeException.message!!)
- }
-
-
-
- inner class K8sConfigTemplateApi(
- val username: String,
- val password: String,
- val baseUrl: String,
- val definition: String,
- val definitionVersion: String,
- val configTemplateName: String
- ) {
- private val service: UploadConfigTemplateRestClientService // BasicAuthRestClientService
-
- init {
- var mapOfHeaders = hashMapOf<String, String>()
- mapOfHeaders.put("Accept", "application/json")
- mapOfHeaders.put("Content-Type", "application/json")
- mapOfHeaders.put("cache-control", " no-cache")
- mapOfHeaders.put("Accept", "application/json")
- var basicAuthRestClientProperties: BasicAuthRestClientProperties = BasicAuthRestClientProperties()
- basicAuthRestClientProperties.username = username
- basicAuthRestClientProperties.password = password
- basicAuthRestClientProperties.url = "$baseUrl/v1/rb/definition/$definition/$definitionVersion"
- basicAuthRestClientProperties.additionalHeaders = mapOfHeaders
-
- this.service = UploadConfigTemplateRestClientService(basicAuthRestClientProperties)
- }
-
- fun hasDefinition(): Boolean {
- try {
- val result: BlueprintWebClientService.WebClientResponse<String> = service.exchangeResource(HttpMethod.GET.name, "", "")
- print(result)
- if (result.status >= 200 && result.status < 300)
- return true
- else
- return false
- } catch (e: Exception) {
- log.info("Caught exception trying to get k8s config trmplate definition")
- throw BluePrintProcessorException("${e.message}")
- }
- }
-
- fun hasConfigTemplate(profile: K8sConfigTemplate): Boolean {
- try {
- val result: BlueprintWebClientService.WebClientResponse<String> = service.exchangeResource(HttpMethod.GET.name, "/config-template/${profile.templateName}", "")
- print(result)
- if (result.status >= 200 && result.status < 300) {
- log.info("ConfigTemplate already exists")
- return true
- } else
- return false
- } catch (e: Exception) {
- log.info("Caught exception trying to get k8s config trmplate definition")
- throw BluePrintProcessorException("${e.message}")
- }
- }
-
- fun createConfigTemplate(profile: K8sConfigTemplate) {
- val objectMapper = ObjectMapper()
- val profileJsonString: String = objectMapper.writeValueAsString(profile)
- try {
- val result: BlueprintWebClientService.WebClientResponse<String> = service.exchangeResource(
- HttpMethod.POST.name,
- "/config-template",
- profileJsonString
- )
-
- if (result.status >= 200 && result.status < 300) {
- log.info("Config template json info uploaded correctly")
- } else if (result.status < 200 || result.status >= 300) {
- log.info("Config template already exists")
- }
- } catch (e: Exception) {
- log.info("Caught exception trying to create k8s config template ${profile.templateName} - updated")
- // throw BluePrintProcessorException("${e.message}")
- }
- }
-
- fun uploadConfigTemplateContent(profile: K8sConfigTemplate, filePath: Path) {
- try {
- val result: BlueprintWebClientService.WebClientResponse<String> = service.uploadBinaryFile(
- "/config-template/${profile.templateName}/content",
- filePath
- )
- if (result.status < 200 || result.status >= 300) {
- throw Exception(result.body)
- }
- } catch (e: Exception) {
- log.info("Caught exception trying to upload k8s config template ${profile.templateName}")
- throw BluePrintProcessorException("${e.message}")
- }
- }
- }
-}
-
-class UploadConfigTemplateRestClientService(
- private val restClientProperties:
- BasicAuthRestClientProperties
-) : BlueprintWebClientService {
-
- override fun defaultHeaders(): Map<String, String> {
-
- val encodedCredentials = setBasicAuth(
- restClientProperties.username,
- restClientProperties.password
- )
- return mapOf(
- HttpHeaders.CONTENT_TYPE to MediaType.APPLICATION_JSON_VALUE,
- HttpHeaders.ACCEPT to MediaType.APPLICATION_JSON_VALUE,
- HttpHeaders.AUTHORIZATION to "Basic $encodedCredentials"
- )
- }
-
- override fun host(uri: String): String {
- return restClientProperties.url + uri
- }
-
- override fun convertToBasicHeaders(headers: Map<String, String>):
- Array<BasicHeader> {
- val customHeaders: MutableMap<String, String> = headers.toMutableMap()
- // inject additionalHeaders
- customHeaders.putAll(verifyAdditionalHeaders(restClientProperties))
-
- if (!headers.containsKey(HttpHeaders.AUTHORIZATION)) {
- val encodedCredentials = setBasicAuth(
- restClientProperties.username,
- restClientProperties.password
- )
- customHeaders[HttpHeaders.AUTHORIZATION] =
- "Basic $encodedCredentials"
- }
- return super.convertToBasicHeaders(customHeaders)
- }
-
- private fun setBasicAuth(username: String, password: String): String {
- val credentialsString = "$username:$password"
- return Base64.getEncoder().encodeToString(
- credentialsString.toByteArray(Charset.defaultCharset())
- )
- }
-
- @Throws(IOException::class, ClientProtocolException::class)
- private fun performHttpCall(httpUriRequest: HttpUriRequest): BlueprintWebClientService.WebClientResponse<String> {
- val httpResponse = httpClient().execute(httpUriRequest)
- val statusCode = httpResponse.statusLine.statusCode
- httpResponse.entity.content.use {
- val body = IOUtils.toString(it, Charset.defaultCharset())
- return BlueprintWebClientService.WebClientResponse(statusCode, body)
- }
- }
-
- fun uploadBinaryFile(path: String, filePath: Path): BlueprintWebClientService.WebClientResponse<String> {
- val convertedHeaders: Array<BasicHeader> = convertToBasicHeaders(defaultHeaders())
- val httpPost = HttpPost(host(path))
- val entity = EntityBuilder.create().setBinary(Files.readAllBytes(filePath)).build()
- httpPost.setEntity(entity)
- RestLoggerService.httpInvoking(convertedHeaders)
- httpPost.setHeaders(convertedHeaders)
- return performHttpCall(httpPost)
- }
-}
-
-class K8sConfigTemplate {
- @get:JsonProperty("template-name")
- var templateName: String? = null
- @get:JsonProperty("description")
- var description: String? = null
- @get:JsonProperty("ChartName")
- var ChartName: String? = null
-
- override fun equals(other: Any?): Boolean {
- if (this === other) return true
- if (javaClass != other?.javaClass) return false
- return true
- }
-
- override fun hashCode(): Int {
- return javaClass.hashCode()
- }
-}
-
-class K8sResources {
-
- var GVK: GVK? = null
- lateinit var Name: String
-
-}
-
-class GVK {
-
- var Group: String? = null
- var Version: String? = null
- var Kind: String? = null
-
-}
-
-fun main(args: Array<String>) {
-
- val kotlin = DayOneConfig()
-
-
-
-}
+/*\r
+* Copyright © 2019 TechMahindra\r
+*\r
+* Licensed under the Apache License, Version 2.0 (the "License");\r
+* you may not use this file except in compliance with the License.\r
+* You may obtain a copy of the License at\r
+*\r
+* http://www.apache.org/licenses/LICENSE-2.0\r
+*\r
+* Unless required by applicable law or agreed to in writing, software\r
+* distributed under the License is distributed on an "AS IS" BASIS,\r
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
+* See the License for the specific language governing permissions and\r
+* limitations under the License.\r
+*/\r
+\r
+package org.onap.ccsdk.cds.blueprintsprocessor.services.execution.scripts\r
+\r
+import com.fasterxml.jackson.annotation.JsonIgnore\r
+import com.fasterxml.jackson.annotation.JsonProperty\r
+import com.fasterxml.jackson.databind.ObjectMapper\r
+import com.fasterxml.jackson.databind.node.ObjectNode\r
+import com.fasterxml.jackson.databind.JsonNode\r
+import com.fasterxml.jackson.module.kotlin.jacksonObjectMapper\r
+import java.io.File\r
+import java.nio.file.Path\r
+import java.nio.file.Paths\r
+import org.apache.commons.io.FilenameUtils\r
+import org.apache.commons.io.IOUtils\r
+import org.apache.http.client.ClientProtocolException\r
+import org.apache.http.client.entity.EntityBuilder\r
+import org.apache.http.client.methods.HttpPost\r
+import org.apache.http.client.methods.HttpUriRequest\r
+import org.apache.http.entity.ContentType\r
+import org.apache.http.message.BasicHeader\r
+import org.onap.ccsdk.cds.blueprintsprocessor.core.api.data.ExecutionServiceInput\r
+import org.onap.ccsdk.cds.blueprintsprocessor.rest.BasicAuthRestClientProperties\r
+import org.onap.ccsdk.cds.blueprintsprocessor.rest.RestClientProperties\r
+import org.onap.ccsdk.cds.blueprintsprocessor.rest.service.BasicAuthRestClientService\r
+import org.onap.ccsdk.cds.blueprintsprocessor.rest.service.BlueprintWebClientService\r
+import org.onap.ccsdk.cds.blueprintsprocessor.core.BluePrintPropertiesService\r
+import org.onap.ccsdk.cds.blueprintsprocessor.functions.k8s.definition.K8sPluginDefinitionApi\r
+import org.onap.ccsdk.cds.blueprintsprocessor.functions.k8s.K8sConnectionPluginConfiguration\r
+import org.onap.ccsdk.cds.blueprintsprocessor.functions.k8s.definition.K8sDefinitionRestClient\r
+import org.onap.ccsdk.cds.blueprintsprocessor.rest.service.RestLoggerService\r
+import org.onap.ccsdk.cds.blueprintsprocessor.services.execution.AbstractScriptComponentFunction\r
+import org.onap.ccsdk.cds.blueprintsprocessor.functions.resource.resolution.contentFromResolvedArtifactNB\r
+import org.onap.ccsdk.cds.controllerblueprints.core.BluePrintProcessorException\r
+import org.onap.ccsdk.cds.controllerblueprints.core.utils.ArchiveType\r
+import org.onap.ccsdk.cds.controllerblueprints.core.utils.BluePrintArchiveUtils\r
+import org.onap.ccsdk.cds.controllerblueprints.core.utils.JacksonUtils\r
+import org.onap.ccsdk.cds.blueprintsprocessor.functions.resource.resolution.storedContentFromResolvedArtifactNB\r
+import org.slf4j.LoggerFactory\r
+import org.springframework.http.HttpHeaders\r
+import org.springframework.http.HttpMethod\r
+import org.springframework.http.MediaType\r
+import org.springframework.web.client.RestTemplate\r
+import org.yaml.snakeyaml.Yaml\r
+import java.util.ArrayList\r
+import java.io.IOException\r
+\r
+import java.util.Base64\r
+import java.nio.charset.Charset\r
+import java.nio.file.Files\r
+import com.google.gson.Gson\r
+import com.google.gson.reflect.TypeToken\r
+\r
+open class DayOneConfig : AbstractScriptComponentFunction() {\r
+\r
+ private val log = LoggerFactory.getLogger(DayOneConfig::class.java)!!\r
+\r
+ override fun getName(): String {\r
+ return "DayOneConfig"\r
+ }\r
+\r
+ override suspend fun processNB(executionRequest: ExecutionServiceInput) {\r
+ log.info("DAY-1 Script excution Started")\r
+\r
+ val prefix = "baseconfig"\r
+\r
+ val baseK8sApiUrl = getDynamicProperties("api-access").get("url").asText()\r
+ val k8sApiUsername = getDynamicProperties("api-access").get("username").asText()\r
+ val k8sApiPassword = getDynamicProperties("api-access").get("password").asText()\r
+\r
+ log.info("Multi-cloud params $baseK8sApiUrl")\r
+\r
+ val aaiApiUrl = getDynamicProperties("aai-access").get("url").asText()\r
+ val aaiApiUsername = getDynamicProperties("aai-access").get("username").asText()\r
+ val aaiApiPassword = getDynamicProperties("aai-access").get("password").asText()\r
+\r
+\r
+ \r
+ log.info("AAI params $aaiApiUrl")\r
+\r
+\r
+ \r
+\r
+ val resolution_key = getDynamicProperties("resolution-key").asText()\r
+\r
+ val sdnc_payload:String = contentFromResolvedArtifactNB("config-deploy-sdnc")\r
+ //log.info("SDNC payload $sdnc_payload")\r
+val sdnc_payloadObject = JacksonUtils.jsonNode(sdnc_payload) as ObjectNode\r
+\r
+\r
+ val aai_payload:String = contentFromResolvedArtifactNB("config-deploy-aai")\r
+ //log.info("AAI payload $aai_payload")\r
+val aai_payloadObject = JacksonUtils.jsonNode(aai_payload) as ObjectNode\r
+\r
+\r
+\r
+ \r
+ \r
+ \r
+ try {\r
+ \r
+ for (item in sdnc_payloadObject.get("vf-modules")){\r
+ \r
+ var instanceID:String =""\r
+ val modelTopology = item.get("vf-module-data").get("vf-module-topology")\r
+ \r
+ \r
+ \r
+ val moduleParameters = modelTopology.get("vf-module-parameters").get("param")\r
+ \r
+ val label: String? = getParamValueByName(moduleParameters, "vf-module-label")\r
+ val modelInfo = modelTopology.get("onap-model-information")\r
+ val vfModuleInvariantID = modelInfo.get("model-invariant-uuid").asText()\r
+ log.info("VF MOdule Inavriant ID $vfModuleInvariantID")\r
+ val vfModuleCustID=modelInfo.get("model-customization-uuid").asText()\r
+ val vfModuleUUID=modelInfo.get("model-uuid").asText()\r
+ val idInfo = modelTopology.get("vf-module-topology-identifier")\r
+ val vfModuleID = idInfo.get("vf-module-id").asText()\r
+ for (aai_item in aai_payloadObject.get("vf-modules")) \r
+ {\r
+ if (aai_item.get("vf-module-id").asText() == vfModuleID && aai_item.get("heat-stack-id") != null) \r
+ {\r
+ instanceID=aai_item.get("heat-stack-id").asText()\r
+ break \r
+ }\r
+ }\r
+ \r
+\r
+\r
+ val k8sRbProfileName: String = "profile_" + vfModuleID\r
+\r
+ val k8sConfigTemplateName: String = "template_" + vfModuleCustID \r
+\r
+ val api = K8sConfigTemplateApi(k8sApiUsername, k8sApiPassword, baseK8sApiUrl, vfModuleInvariantID, vfModuleCustID, k8sConfigTemplateName)\r
+\r
+ // Check if definition exists\r
+ if (!api.hasDefinition()) {\r
+ throw BluePrintProcessorException("K8S Definition ($vfModuleInvariantID/$vfModuleCustID) not found ")\r
+ }\r
+ val bluePrintPropertiesService: BluePrintPropertiesService =this.functionDependencyInstanceAsType("bluePrintPropertiesService")\r
+ val k8sConfiguration = K8sConnectionPluginConfiguration(bluePrintPropertiesService)\r
+ val rbDefinitionService = K8sDefinitionRestClient(k8sConfiguration,vfModuleInvariantID, vfModuleCustID)\r
+ \r
+ \r
+ val def: BlueprintWebClientService.WebClientResponse<String> = rbDefinitionService.exchangeResource(HttpMethod.GET.name,"","")\r
+ log.info(def.body.toString())\r
+ val rbdef = JacksonUtils.jsonNode(def.body.toString()) as ObjectNode\r
+ val chartName = rbdef.get("chart-name").asText()\r
+\r
+ log.info("Config Template name: $k8sConfigTemplateName")\r
+\r
+ \r
+ \r
+ var configTemplate = K8sConfigTemplate()\r
+ configTemplate.templateName = k8sConfigTemplateName\r
+ configTemplate.description = " "\r
+ configTemplate.ChartName = chartName\r
+ log.info("Chart name: ${configTemplate.ChartName}")\r
+\r
+ \r
+\r
+ if (!api.hasConfigTemplate(configTemplate)) {\r
+ \r
+\r
+ val configTemplateFile: Path = prepareConfigTemplateJson(k8sConfigTemplateName, vfModuleID, label)\r
+\r
+ log.info("Config Template Upload Started")\r
+ api.createConfigTemplate(configTemplate)\r
+ api.uploadConfigTemplateContent(configTemplate, configTemplateFile)\r
+ log.info("Config Template Upload Completed")\r
+ }\r
+ }\r
+ log.info("DAY-1 Script excution completed")\r
+ \r
+ \r
+ }\r
+ catch (e: Exception) {\r
+ log.info("Caught exception during config template preparation!!")\r
+ throw BluePrintProcessorException("${e.message}")\r
+ }\r
+ }\r
+ private fun getParamValueByName(params: JsonNode, paramName: String): String? {\r
+ for (param in params) {\r
+ if (param.get("name").asText() == paramName && param.get("value").asText() != "null") {\r
+ return param.get("value").asText()\r
+ \r
+ }\r
+ }\r
+ return null\r
+ }\r
+\r
+ fun prepareConfigTemplateJson(configTemplateName: String, vfModuleID: String, label: String?): Path {\r
+ val bluePrintContext = bluePrintRuntimeService.bluePrintContext()\r
+ val bluePrintBasePath: String = bluePrintContext.rootPath\r
+\r
+ var profileFilePath: Path = Paths.get(bluePrintBasePath.plus(File.separator).plus("Templates").plus(File.separator).plus("k8s-profiles").plus(File.separator).plus(label +"-config-template.tar.gz"))\r
+ log.info("Reading K8s Config Template file: $profileFilePath")\r
+\r
+ val profileFile = profileFilePath.toFile()\r
+\r
+ if (!profileFile.exists())\r
+ throw BluePrintProcessorException("K8s Config template file $profileFilePath does not exists")\r
+\r
+ return profileFilePath\r
+ }\r
+ \r
+\r
+ fun getResolvedParameter(payload: ObjectNode, keyName: String): String {\r
+ for (node in payload.get("resource-accumulator-resolved-data").elements()) {\r
+ if (node.get("param-name").asText().equals(keyName)) {\r
+ return node.get("param-value").asText()\r
+ }\r
+ }\r
+ return ""\r
+ }\r
+ override suspend fun recoverNB(runtimeException: RuntimeException, executionRequest: ExecutionServiceInput) {\r
+ log.info("Recover function called!")\r
+ log.info("Execution request : $executionRequest")\r
+ log.error("Exception", runtimeException)\r
+ addError(runtimeException.message!!)\r
+ }\r
+\r
+\r
+\r
+ inner class K8sConfigTemplateApi(\r
+ val username: String,\r
+ val password: String,\r
+ val baseUrl: String,\r
+ val definition: String,\r
+ val definitionVersion: String,\r
+ val configTemplateName: String\r
+ ) {\r
+ private val service: UploadConfigTemplateRestClientService // BasicAuthRestClientService\r
+\r
+ init {\r
+ var mapOfHeaders = hashMapOf<String, String>()\r
+ mapOfHeaders.put("Accept", "application/json")\r
+ mapOfHeaders.put("Content-Type", "application/json")\r
+ mapOfHeaders.put("cache-control", " no-cache")\r
+ mapOfHeaders.put("Accept", "application/json")\r
+ var basicAuthRestClientProperties: BasicAuthRestClientProperties = BasicAuthRestClientProperties()\r
+ basicAuthRestClientProperties.username = username\r
+ basicAuthRestClientProperties.password = password\r
+ basicAuthRestClientProperties.url = "$baseUrl/v1/rb/definition/$definition/$definitionVersion"\r
+ basicAuthRestClientProperties.additionalHeaders = mapOfHeaders\r
+\r
+ this.service = UploadConfigTemplateRestClientService(basicAuthRestClientProperties)\r
+ }\r
+\r
+ fun hasDefinition(): Boolean {\r
+ try {\r
+ val result: BlueprintWebClientService.WebClientResponse<String> = service.exchangeResource(HttpMethod.GET.name, "", "")\r
+ print(result)\r
+ if (result.status >= 200 && result.status < 300)\r
+ return true\r
+ else\r
+ return false\r
+ } catch (e: Exception) {\r
+ log.info("Caught exception trying to get k8s config trmplate definition")\r
+ throw BluePrintProcessorException("${e.message}")\r
+ }\r
+ }\r
+\r
+ fun hasConfigTemplate(profile: K8sConfigTemplate): Boolean {\r
+ try {\r
+ val result: BlueprintWebClientService.WebClientResponse<String> = service.exchangeResource(HttpMethod.GET.name, "/config-template/${profile.templateName}", "")\r
+ print(result)\r
+ if (result.status >= 200 && result.status < 300) {\r
+ log.info("ConfigTemplate already exists")\r
+ return true\r
+ } else\r
+ return false\r
+ } catch (e: Exception) {\r
+ log.info("Caught exception trying to get k8s config trmplate definition")\r
+ throw BluePrintProcessorException("${e.message}")\r
+ }\r
+ }\r
+\r
+ fun createConfigTemplate(profile: K8sConfigTemplate) {\r
+ val objectMapper = ObjectMapper()\r
+ val profileJsonString: String = objectMapper.writeValueAsString(profile)\r
+ try {\r
+ val result: BlueprintWebClientService.WebClientResponse<String> = service.exchangeResource(\r
+ HttpMethod.POST.name,\r
+ "/config-template",\r
+ profileJsonString\r
+ )\r
+\r
+ if (result.status >= 200 && result.status < 300) {\r
+ log.info("Config template json info uploaded correctly")\r
+ } else if (result.status < 200 || result.status >= 300) {\r
+ log.info("Config template already exists")\r
+ }\r
+ } catch (e: Exception) {\r
+ log.info("Caught exception trying to create k8s config template ${profile.templateName} - updated")\r
+ // throw BluePrintProcessorException("${e.message}")\r
+ }\r
+ }\r
+\r
+ fun uploadConfigTemplateContent(profile: K8sConfigTemplate, filePath: Path) {\r
+ try {\r
+ val result: BlueprintWebClientService.WebClientResponse<String> = service.uploadBinaryFile(\r
+ "/config-template/${profile.templateName}/content",\r
+ filePath\r
+ )\r
+ if (result.status < 200 || result.status >= 300) {\r
+ throw Exception(result.body)\r
+ }\r
+ } catch (e: Exception) {\r
+ log.info("Caught exception trying to upload k8s config template ${profile.templateName}")\r
+ throw BluePrintProcessorException("${e.message}")\r
+ }\r
+ }\r
+ }\r
+}\r
+\r
+class UploadConfigTemplateRestClientService(\r
+ private val restClientProperties:\r
+ BasicAuthRestClientProperties\r
+) : BlueprintWebClientService {\r
+\r
+ override fun defaultHeaders(): Map<String, String> {\r
+\r
+ val encodedCredentials = setBasicAuth(\r
+ restClientProperties.username,\r
+ restClientProperties.password\r
+ )\r
+ return mapOf(\r
+ HttpHeaders.CONTENT_TYPE to MediaType.APPLICATION_JSON_VALUE,\r
+ HttpHeaders.ACCEPT to MediaType.APPLICATION_JSON_VALUE,\r
+ HttpHeaders.AUTHORIZATION to "Basic $encodedCredentials"\r
+ )\r
+ }\r
+\r
+ override fun host(uri: String): String {\r
+ return restClientProperties.url + uri\r
+ }\r
+\r
+ override fun convertToBasicHeaders(headers: Map<String, String>):\r
+ Array<BasicHeader> {\r
+ val customHeaders: MutableMap<String, String> = headers.toMutableMap()\r
+ // inject additionalHeaders\r
+ customHeaders.putAll(verifyAdditionalHeaders(restClientProperties))\r
+\r
+ if (!headers.containsKey(HttpHeaders.AUTHORIZATION)) {\r
+ val encodedCredentials = setBasicAuth(\r
+ restClientProperties.username,\r
+ restClientProperties.password\r
+ )\r
+ customHeaders[HttpHeaders.AUTHORIZATION] =\r
+ "Basic $encodedCredentials"\r
+ }\r
+ return super.convertToBasicHeaders(customHeaders)\r
+ }\r
+\r
+ private fun setBasicAuth(username: String, password: String): String {\r
+ val credentialsString = "$username:$password"\r
+ return Base64.getEncoder().encodeToString(\r
+ credentialsString.toByteArray(Charset.defaultCharset())\r
+ )\r
+ }\r
+\r
+ @Throws(IOException::class, ClientProtocolException::class)\r
+ private fun performHttpCall(httpUriRequest: HttpUriRequest): BlueprintWebClientService.WebClientResponse<String> {\r
+ val httpResponse = httpClient().execute(httpUriRequest)\r
+ val statusCode = httpResponse.statusLine.statusCode\r
+ httpResponse.entity.content.use {\r
+ val body = IOUtils.toString(it, Charset.defaultCharset())\r
+ return BlueprintWebClientService.WebClientResponse(statusCode, body)\r
+ }\r
+ }\r
+\r
+ fun uploadBinaryFile(path: String, filePath: Path): BlueprintWebClientService.WebClientResponse<String> {\r
+ val convertedHeaders: Array<BasicHeader> = convertToBasicHeaders(defaultHeaders())\r
+ val httpPost = HttpPost(host(path))\r
+ val entity = EntityBuilder.create().setBinary(Files.readAllBytes(filePath)).build()\r
+ httpPost.setEntity(entity)\r
+ RestLoggerService.httpInvoking(convertedHeaders)\r
+ httpPost.setHeaders(convertedHeaders)\r
+ return performHttpCall(httpPost)\r
+ }\r
+}\r
+\r
+class K8sConfigTemplate {\r
+ @get:JsonProperty("template-name")\r
+ var templateName: String? = null\r
+ @get:JsonProperty("description")\r
+ var description: String? = null\r
+ @get:JsonProperty("ChartName")\r
+ var ChartName: String? = null\r
+\r
+ override fun equals(other: Any?): Boolean {\r
+ if (this === other) return true\r
+ if (javaClass != other?.javaClass) return false\r
+ return true\r
+ }\r
+\r
+ override fun hashCode(): Int {\r
+ return javaClass.hashCode()\r
+ }\r
+}\r
+\r
+class K8sResources {\r
+\r
+ var GVK: GVK? = null\r
+ lateinit var Name: String\r
+\r
+}\r
+\r
+class GVK {\r
+\r
+ var Group: String? = null\r
+ var Version: String? = null\r
+ var Kind: String? = null\r
+\r
+}\r
+\r
+fun main(args: Array<String>) {\r
+\r
+ val kotlin = DayOneConfig()\r
+\r
+ \r
+ \r
+}\r