package org.onap.ccsdk.cds.blueprintsprocessor.functions.netconf.executor import org.onap.ccsdk.cds.blueprintsprocessor.services.execution.AbstractScriptComponentFunction import org.onap.ccsdk.cds.blueprintsprocessor.core.api.data.ExecutionServiceInput import org.onap.ccsdk.cds.blueprintsprocessor.functions.resource.resolution.storedContentFromResolvedArtifactNB import org.onap.ccsdk.cds.controllerblueprints.core.utils.JacksonUtils import org.slf4j.LoggerFactory open class ConfigDeploy : AbstractScriptComponentFunction() { private val log = LoggerFactory.getLogger(ConfigDeploy::class.java)!! override suspend fun processNB(executionRequest: ExecutionServiceInput) { val device = netconfDevice("netconf-connection") val client = device.netconfRpcService val session = device.netconfSession val payload=""" Regression-Mock """ val response: MutableMap = mutableMapOf("deploySuccess" to false) try { session.connect() client.lock() client.editConfig(payload) client.commit() client.unLock() session.disconnect() response["deploySuccess"] = true } catch (e: Exception) { e.message?.let { super.addError(it) } } super.setAttribute("response-data", JacksonUtils.jsonNodeFromObject(response)) } override suspend fun recoverNB(runtimeException: RuntimeException, executionRequest: ExecutionServiceInput) { log.info("Executing Recovery") } }