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-pnf-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.pnf-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="request-id" value="`$tmp.return.generate.pnf-se-serv-uuid`"/>
\r
18 <parameter name="resource-type" value="`$pnf-topology-operation-input.pnf-details.pnf-type`" />
\r
19 <parameter name="resource-id" value="`$pnf-topology-operation-input.pnf-details.pnf-id`" />
\r
20 <parameter name="action-name" value="resource-assignment"/>
\r
21 <parameter name="responsePrefix" value="raAssign" />
\r
23 <switch test='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param_length`'>
\r
26 <parameter name='highnum' value='0' />
\r
27 <parameter name='prehighnum' value='0'/>
\r
30 <outcome value='Other'>
\r
32 <parameter name='highnum' value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param_length`' />
\r
33 <parameter name='prehighnum' value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param_length`' />
\r
37 <for silentFailure='true' index='i' start='0' end='`$pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.param_length`' >
\r
38 <block atomic="true">
\r
39 <switch test='`$pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.param[$i].name`'>
\r
40 <outcome value='sdnc_model_name'>
\r
42 <parameter name='tmp.sdnc-model-name' value='`$pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.param[$i].value`' />
\r
45 <outcome value='sdnc_model_version'>
\r
47 <parameter name='tmp.sdnc-model-version' value='`$pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.param[$i].value`' />
\r
50 <outcome value='sdnc_artifact_name'>
\r
52 <parameter name='tmp.sdnc-artifact-name' value='`$pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.param[$i].value`' />
\r
55 <outcome value='Other'>
\r
57 <parameter name="tmp.config-name-value-other-payload" value="`$tmp.config-name-value-other-payload + '"' + $pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.param[$i].name + '":"' + $pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.param[$i].value + '",'`"/>
\r
63 <switch test="`$tmp.sdnc-model-name == '' or $tmp.sdnc-model-version == '' or $tmp.sdnc-artifact-name == ''`">
\r
64 <outcome value='true'>
\r
65 <get-resource plugin='org.onap.ccsdk.sli.adaptors.resource.sql.SqlResource' resource='SQL'
\r
66 key='SELECT * from VF_MODEL WHERE customization_uuid = $pnf-topology-operation-input.pnf-details.onap-model-information.model-customization-uuid'
\r
68 <outcome value='failure'>
\r
69 <return status='failure'>
\r
70 <parameter name='ack-final' value='Y'/>
\r
71 <parameter name="error-code" value="500" />
\r
72 <parameter name="error-message" value="Error reading VF_MODEL table" />
\r
75 <outcome value='not-found'>
\r
76 <return status='failure'>
\r
77 <parameter name='ack-final' value='Y'/>
\r
78 <parameter name="error-code" value="500" />
\r
79 <parameter name="error-message" value="`'No VF_MODEL found where customization_uuid = ' + $pnf-topology-operation-input.pnf-details.onap-model-information.model-customization-uuid`" />
\r
82 <outcome value='success'>
\r
84 <parameter name='tmp.sdnc-model-name' value='`$db1.vf-model.sdnc-model-name`' />
\r
85 <parameter name='tmp.sdnc-model-version' value='`$db1.vf-model.sdnc-model-version`' />
\r
86 <parameter name='tmp.sdnc-artifact-name' value='`$db1.vf-model.sdnc-artifact-name`' />
\r
93 <parameter name="tmp.config-name-value-payload4" value="`$tmp.config-name-value-other-payload + '"service-instance-id":"' + $pnf-topology-operation-input.service-information.service-instance-id + '",'`"/>
\r
94 <parameter name="tmp.config-name-value-payload5" value="`$tmp.config-name-value-payload4 + '"pnf-model-customization-uuid":"' + $pnf-topology-operation-input.pnf-details.onap-model-information.model-customization-uuid + '",'`"/>
\r
95 <parameter name="tmp.config-name-value-payload6" value="`$tmp.config-name-value-payload5 + '"pnf-id":"' + $pnf-topology-operation-input.pnf-details.pnf-id + '",'`"/>
\r
96 <parameter name="tmp.config-name-value-payload7" value="`$tmp.config-name-value-payload6 + '"aic-cloud-region":"' + $pnf-topology-operation-input.pnf-request-input.aic-cloud-region + '"'`"/>
\r
97 <parameter name="tmp.json-payload" value="`'{' + $tmp.config-name-value-payload7 + '}'`" />
\r
99 <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
\r
100 <parameter name="logger" value="message-log"/>
\r
101 <parameter name="field1" value="BEFORE BlueprintProcessingClient"/>
\r
103 <execute plugin='org.onap.ccsdk.sli.adaptors.grpc.cds.BlueprintProcessingClient' method='sendRequest'>
\r
104 <parameter name='blueprint_name' value='`$tmp.sdnc-model-name`' />
\r
105 <parameter name='blueprint_version' value='`$tmp.sdnc-model-version`' />
\r
106 <parameter name='action' value='`$action-name`' />
\r
107 <parameter name='mode' value='sync' />
\r
108 <parameter name='force' value='false' />
\r
109 <parameter name='ttl' value='0' />
\r
110 <parameter name='prefix' value='`$responsePrefix`' />
\r
111 <parameter name='payload' value="`'{
\r
112 "resource-assignment-request": {
\r
113 "template-prefix": [
\r
114 "' + $tmp.sdnc-artifact-name + '"
\r
116 "resource-assignment-properties":
\r
117 ' + $tmp.json-payload + '
\r
120 <outcome value='failure'>
\r
121 <return status='failure'>
\r
122 <parameter name='ack-final' value='Y'/>
\r
123 <parameter name="error-code" value="500" />
\r
124 <parameter name="error-message" value="Error from BlueprintProcessingClient" />
\r
127 <outcome value='not-found'>
\r
128 <return status='failure'>
\r
129 <parameter name='ack-final' value='Y'/>
\r
130 <parameter name="error-code" value="500" />
\r
131 <parameter name="error-message" value="Error from BlueprintProcessingClient" />
\r
135 <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
\r
136 <parameter name="logger" value="message-log"/>
\r
137 <parameter name="field1" value="AFTER BlueprintProcessingClient"/>
\r
139 <execute plugin="org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils" method="jsonStringToCtx">
\r
140 <parameter name="source" value="`'raAssign.payload.resource-assignment-response.meshed-template.' + $tmp.sdnc-artifact-name`" />
\r
141 <parameter name="outputPath" value="jsonContextPrefix" />
\r
142 <parameter name="isEscaped" value="false" />
\r
144 <for silentFailure='true' index='i' start='0' end='`$jsonContextPrefix.resource-accumulator-resolved-data_length`' >
\r
145 <block atomic="true">
\r
147 <parameter name='tmp.mso.param.found' value='false' />
\r
149 <switch test='`$prehighnum > 0`'>
\r
150 <outcome value='true'>
\r
151 <for silentFailure='true' index='cnt' start='0' end='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param_length`' >
\r
152 <switch test='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$cnt].name == $jsonContextPrefix.resource-accumulator-resolved-data[$i].param-name`'>
\r
153 <outcome value='true'>
\r
155 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$cnt].value`' value='`$jsonContextPrefix.resource-accumulator-resolved-data[$i].param-value`'/>
\r
156 <parameter name='tmp.mso.param.found' value='true' />
\r
163 <switch test='`$tmp.mso.param.found`'>
\r
164 <outcome value='false'>
\r
165 <block atomic='true'>
\r
167 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].name`' value='`$jsonContextPrefix.resource-accumulator-resolved-data[$i].param-name`'/>
\r
168 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].value`' value='`$jsonContextPrefix.resource-accumulator-resolved-data[$i].param-value`'/>
\r
169 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].resource-resolution-data.capability-name`' value='RA Resolved'/>
\r
170 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].resource-resolution-data.status`' value='SUCCESS'/>
\r
173 <parameter name='highnum' value='`$highnum + 1`' />
\r
180 <for silentFailure='true' index='i' start='0' end='`$jsonContextPrefix.capability-data_length`' >
\r
181 <for silentFailure='true' index='j' start='0' end='`$jsonContextPrefix.capability-data[$i].key-mapping_length`' >
\r
182 <for silentFailure='true' index='l' start='0' end='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].output-key-mapping_length`' >
\r
183 <block atomic="true">
\r
185 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].name`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].output-key-mapping[$l].resource-name`'/>
\r
186 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].value`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].output-key-mapping[$l].resource-value`'/>
\r
187 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].resource-resolution-data.capability-name`' value='`$jsonContextPrefix.capability-data[$i].capability-name`'/>
\r
188 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].resource-resolution-data.status`' value='PENDING'/>
\r
189 <parameter name='num' value='0' />
\r
191 <switch test="`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload_length == ''`">
\r
192 <outcome value='true'></outcome>
\r
193 <outcome value='false'>
\r
194 <for silentFailure='true' index='k' start='0' end='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload_length`' >
\r
195 <block atomic="true">
\r
197 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].resource-resolution-data.resource-key[$num].name`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload[$k].param-name`'/>
\r
198 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].resource-resolution-data.resource-key[$num].value`' value='`$jsonContextPrefix.capability-data[$i].key-mapping[$j].payload[$k].param-value`'/>
\r
201 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$highnum].resource-resolution-data.resource-key_length`' value='`$num + 1`'/>
\r
204 <parameter name='num' value='`$num + 1`' />
\r
211 <parameter name='`service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param_length`' value='`$highnum + 1`'/>
\r
214 <parameter name='highnum' value='`$highnum + 1`' />
\r
220 <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
\r
221 <parameter name="logger" value="message-log"/>
\r
222 <parameter name="field1" value="DONE: pnf-ra-assignment"/>
\r
225 <parameter name='pathname'
\r
226 value="`'/var/tmp/ss-pnf-ra-assignment-' +
\r
227 $service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-details.pnf-id + '.log'`" />
\r
229 <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
\r
230 <parameter name='filename' value='`$pathname`' />
\r