2     xmlns='http://www.onap.org/sdnc/svclogic'
\r 
   3     xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://www.onap.org/sdnc/svclogic ./svclogic.xsd' module='GENERIC-RESOURCE-API' version='${project.version}'>
\r 
   4     <method rpc='self-serve-vfmodule-ra-assignment' mode='sync'>
\r 
   5         <block atomic="true">
\r 
   6             <execute plugin="org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils" method="generateUUID" >
\r 
   7                 <parameter name="ctx-destination" value="tmp.return.generate.vnf-se-serv-uuid" />
\r 
   8                 <outcome value='failure'>
\r 
   9                     <return status='failure'>
\r 
  10                         <parameter name='ack-final' value='Y'/>
\r 
  11                         <parameter name="error-code" value="500" />
\r 
  12                         <parameter name="error-message" value="generateUUID is failed" />
\r 
  17                 <parameter name="cds" value="execution-service_process."/>
\r 
  18                 <parameter name="`$cds + 'commonHeader.requestId'`" value="`$tmp.return.generate.vnf-se-serv-uuid`"/>
\r 
  19                 <parameter name="resource-type" value="`$vf-module-topology-operation-input.vf-module-information.vf-module-type`" />
\r 
  20                 <parameter name="`$cds + 'commonHeader.subRequestId'`" value="`$vf-module-topology-operation-input.vf-module-information.vf-module-id`" />
\r 
  21                 <parameter name="`$cds + 'actionIdentifiers.actionName'`" value="resource-assignment"/>
\r 
  22                 <parameter name="responsePrefix" value="raAssign" />
\r 
  23                 <parameter name="`$cds + 'isNonAppend'`" value="true"/>
\r 
  24                 <parameter name="`$cds + 'commonHeader.originatorId'`" value="SDNC_DG"/>
\r 
  25                 <parameter name="`$cds + 'actionIdentifiers.mode'`" value="sync"/>
\r 
  27             <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param_length`'>
\r 
  30                         <parameter name='highnum' value='0' />
\r 
  31                         <parameter name='prehighnum' value='0'/>
\r 
  34                 <outcome value='Other'>
\r 
  36                         <parameter name='highnum' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param_length`' />
\r 
  37                         <parameter name='prehighnum' value='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param_length`' />
\r 
  41             <for silentFailure='true' index='i' start='0' end='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param_length`' >
\r 
  42                 <switch test='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$i].name`'>
\r 
  43                     <outcome value='sdnc_model_name'>
\r 
  45                             <parameter name='tmp.sdnc-model-name' value='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$i].value`' />
\r 
  48                     <outcome value='sdnc_model_version'>
\r 
  50                             <parameter name='tmp.sdnc-model-version' value='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$i].value`' />
\r 
  53                     <outcome value='vf_module_label'>
\r 
  55                             <parameter name='tmp.vf-module-label' value='`$vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$i].value`' />
\r 
  58                     <outcome value='Other'>
\r 
  60                             <parameter name="tmp.config-name-value-other-payload" value="`$tmp.config-name-value-other-payload + '"' + $vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$i].name + '":"' + $vf-module-topology-operation-input.vf-module-request-input.vf-module-input-parameters.param[$i].value + '",'`"/>
\r 
  65             <switch test="`$tmp.sdnc-model-name == '' or $tmp.sdnc-model-version == '' or $tmp.vf-module-label == ''`">
\r 
  66                 <outcome value='true'>
\r 
  67                     <block atomic="true">
\r 
  68                         <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'
\r 
  69   key='SELECT * from VF_MODEL WHERE customization_uuid = $vf-module-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid'
\r 
  71                             <outcome value='failure'>
\r 
  72                                 <return status='failure'>
\r 
  73                                     <parameter name='ack-final' value='Y'/>
\r 
  74                                     <parameter name="error-code" value="500" />
\r 
  75                                     <parameter name="error-message" value="Error reading VF_MODEL table" />
\r 
  78                             <outcome value='not-found'>
\r 
  79                                 <return status='failure'>
\r 
  80                                     <parameter name='ack-final' value='Y'/>
\r 
  81                                     <parameter name="error-code" value="500" />
\r 
  82                                     <parameter name="error-message" value="`'No VF_MODEL found with customization_uuid = ' + $vf-module-topology-operation-input.vnf-information.onap-model-information.model-customization-uuid`" />
\r 
  85                             <outcome value='success'>
\r 
  87                                     <parameter name='tmp.sdnc-model-name' value='`$db1.vf-model.sdnc-model-name`' />
\r 
  88                                     <parameter name='tmp.sdnc-model-version' value='`$db1.vf-model.sdnc-model-version`' />
\r 
  92                         <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'
\r 
  93   key='SELECT vf_module_label from VF_MODULE_MODEL WHERE customization_uuid = $vf-module-topology-operation-input.vf-module-information.onap-model-information.model-customization-uuid 
\r 
  94         AND vf_module_label is not null'
\r 
  95   pfx='db1.vf-module-model'>
\r 
  96                             <outcome value='failure'>
\r 
  97                                 <return status='failure'>
\r 
  98                                     <parameter name='ack-final' value='Y'/>
\r 
  99                                     <parameter name="error-code" value="500" />
\r 
 100                                     <parameter name="error-message" value="Error reading VF_MODULE_MODEL table" />
\r 
 103                             <outcome value='not-found'>
\r 
 104                                 <return status='failure'>
\r 
 105                                     <parameter name='ack-final' value='Y'/>
\r 
 106                                     <parameter name="error-code" value="500" />
\r 
 107                                     <parameter name="error-message" value="`'vf_module_label not found in VF_MODULE_MODEL WHERE customization_uuid = ' + $vf-module-topology-operation-input.vf-module-information.onap-model-information.model-customization-uuid`" />
\r 
 110                             <outcome value='success'>
\r 
 112                                     <parameter name='tmp.vf-module-label' value='`$db1.vf-module-model.vf-module-label`' />
\r 
 120                 <parameter name="tmp.config-name-value-payload4" value="`$tmp.config-name-value-other-payload + '"service-instance-id":"' + $vf-module-topology-operation-input.service-information.service-instance-id + '",'`"/>
\r 
 121                 <parameter name="tmp.config-name-value-payload5" value="`$tmp.config-name-value-payload4 + '"vnf-id":"' + $vf-module-topology-operation-input.vnf-information.vnf-id + '",'`"/>
\r 
 122                 <parameter name="tmp.config-name-value-payload6" value="`$tmp.config-name-value-payload5 + '"vf-module-model-customization-uuid":"' + $vf-module-topology-operation-input.vf-module-information.onap-model-information.model-customization-uuid + '",'`"/>
\r 
 123                 <parameter name="tmp.config-name-value-payload7" value="`$tmp.config-name-value-payload6 + '"vnf-model-customization-uuid":"' + $service-data.vnfs.vnf[$vnf-index].vnf-data.vnf-information.onap-model-information.model-customization-uuid + '",'`"/>
\r 
 124                 <parameter name="tmp.config-name-value-payload8" value="`$tmp.config-name-value-payload7 + '"vf-module-id":"' + $vf-module-topology-operation-input.vf-module-information.vf-module-id + '",'`"/>
\r 
 125                 <parameter name="tmp.config-name-value-payload9" value="`$tmp.config-name-value-payload8 + '"aic-cloud-region":"' + $vf-module-topology-operation-input.vf-module-request-input.aic-cloud-region + '"'`"/>
\r 
 128                 <parameter name="tmp.json-payload" value="`'{' + $tmp.config-name-value-payload9 + '}'`" />
\r 
 129                 <parameter name="`$cds + 'actionIdentifiers.blueprintName'`" value='`$tmp.sdnc-model-name`' />
\r 
 130                 <parameter name="`$cds + 'actionIdentifiers.blueprintVersion'`" value='`$tmp.sdnc-model-version`' />
\r 
 131                 <parameter name="`$cds + 'payload.resource-assignment-request.template-prefix[0]'`" value='`$tmp.sdnc-artifact-name`' />
\r 
 132                 <parameter name="`$cds + 'payload.resource-assignment-request.resource-assignment-properties'`" value='`$tmp.json-payload`' />
\r 
 134             <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
\r 
 135                 <parameter name="logger" value="message-log"/>
\r 
 136                 <parameter name="field1" value="BEFORE BlueprintProcessingClient"/>
\r 
 138             <execute plugin='org.onap.ccsdk.sli.plugins.restconfapicall.RestconfApiCallNode' method='sendRequest' >
\r 
 139                 <parameter name='restapiUrl' value="`$prop.cds.url + '/api/v1/execution-service/process'`" />
\r 
 140                 <parameter name='restapiUser' value='`$prop.cds.user`' />
\r 
 141                 <parameter name='restapiPassword' value='`$prop.cds.pwd`' />
\r 
 142                 <parameter name='dirPath' value="/opt/onap/sdnc/restconfapi/yang" />
\r 
 143                 <parameter name='format' value='json' />
\r 
 144                 <parameter name='httpMethod' value='POST' />
\r 
 145                 <parameter name="responsePrefix" value="`$responsePrefix`" />
\r 
 146                 <outcome value='failure'>
\r 
 147                     <return status='failure'>
\r 
 148                         <parameter name='ack-final' value='Y'/>
\r 
 149                         <parameter name="error-code" value="500" />
\r 
 150                         <parameter name="error-message" value="Error from ConfigAssignmentNode" />
\r 
 153                 <outcome value='not-found'>
\r 
 154                     <return status='failure'>
\r 
 155                         <parameter name='ack-final' value='Y'/>
\r 
 156                         <parameter name="error-code" value="500" />
\r 
 157                         <parameter name="error-message" value="Error from ConfigAssignmentNode" />
\r 
 161             <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
\r 
 162                 <parameter name="logger" value="message-log"/>
\r 
 163                 <parameter name="field1" value="AFTER BlueprintProcessingClient"/>
\r 
 165             <execute plugin="org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils" method="jsonStringToCtx">
\r 
 166                 <parameter name="source" value="`'raAssign.payload.resource-assignment-response.meshed-template.' + $tmp.vf-module-label`" />
\r 
 167                 <parameter name="outputPath" value="jsonContextPrefix" />
\r 
 168                 <parameter name="isEscaped" value="false" />
\r 
 170             <for silentFailure='true' index='i' start='0' end='`$jsonContextPrefix.resource-accumulator-resolved-data_length`' >
\r 
 171                 <block atomic="true">
\r 
 173                         <parameter name='tmp.mso.param.found' value='false' />
\r 
 175                     <switch test='`$prehighnum > 0`'>
\r 
 176                         <outcome value='true'>
\r 
 177                             <for silentFailure='true' index='cnt' start='0' end='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param_length`' >
\r 
 178                                 <switch test='`$service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$cnt].name == $jsonContextPrefix.resource-accumulator-resolved-data[$i].param-name`'>
\r 
 179                                     <outcome value='true'>
\r 
 181                                             <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$cnt].value`' value='`$jsonContextPrefix.resource-accumulator-resolved-data[$i].param-value`'/>
\r 
 182                                             <parameter name='tmp.mso.param.found' value='true' />
\r 
 189                     <switch test='`$tmp.mso.param.found`'>
\r 
 190                         <outcome value='false'>
\r 
 191                             <block atomic='true'>
\r 
 193                                     <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].name`' value='`$jsonContextPrefix.resource-accumulator-resolved-data[$i].param-name`'/>
\r 
 194                                     <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].value`' value='`$jsonContextPrefix.resource-accumulator-resolved-data[$i].param-value`'/>
\r 
 195                                     <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].resource-resolution-data.capability-name`' value='RA Resolved'/>
\r 
 196                                     <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].resource-resolution-data.status`' value='SUCCESS'/>
\r 
 199                                     <parameter name='highnum' value='`$highnum + 1`' />
\r 
 206             <for silentFailure='true' index='i' start='0' end='`$jsonContextPrefix.capability-data_length`' >
\r 
 207                 <for silentFailure='true' index='j' start='0' end='`$jsonContextPrefix.capability-data[$i].key-mapping_length`' >
\r 
 208                     <for silentFailure='true' index='l' start='0' end='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].output-key-mapping_length`' >
\r 
 209                         <block atomic="true">
\r 
 211                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].name`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].output-key-mapping[$l].resource-name`'/>
\r 
 212                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].value`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].output-key-mapping[$l].resource-value`'/>
\r 
 213                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].resource-resolution-data.capability-name`' value='`$jsonContextPrefix.capability-data[$i].capability-name`'/>
\r 
 214                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].resource-resolution-data.status`' value='PENDING'/>
\r 
 215                                 <parameter name='num' value='0' />
\r 
 217                             <switch test="`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload_length == ''`">
\r 
 218                                 <outcome value='true'></outcome>
\r 
 219                                 <outcome value='false'>
\r 
 220                                     <for index='k' start='0' end='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload_length`' >
\r 
 221                                         <block atomic='true'>
\r 
 223                                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].resource-resolution-data.resource-key[$num].name`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload[$k].param-name`'/>
\r 
 224                                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].resource-resolution-data.resource-key[$num].value`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload[$k].param-value`'/>
\r 
 227                                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param[$highnum].resource-resolution-data.resource-key_length`' value='`$num + 1`'/>
\r 
 230                                                 <parameter name='num' value='`$num + 1`' />
\r 
 237                                 <parameter name='`service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-topology.vf-module-parameters.param_length`' value='`$highnum + 1`'/>
\r 
 240                                 <parameter name='highnum' value='`$highnum + 1`' />
\r 
 246             <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
\r 
 247                 <parameter name="logger" value="message-log"/>
\r 
 248                 <parameter name="field1" value="DONE: vfmodule-ra-assignment"/>
\r 
 251                 <parameter name='pathname' 
\r 
 252         value="`'/var/tmp/ss-vfmodule-ra-assignment-' + 
\r 
 253         $service-data.vnfs.vnf[$vnf-index].vnf-data.vf-modules.vf-module[$vf-module-index].vf-module-data.vf-module-information.vf-module-id + '.log'`" />
\r 
 255             <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r 
 256                 <parameter name='filename' value='`$pathname`' />
\r