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='sdwan-vnf-topology-operation-device-activate' mode='sync'>
\r 
   5         <block atomic="true">
\r 
   6             <for index='vidx' start='0' end='`$service-data.vnfs.vnf_length`' >
\r 
   8                     <switch test="`$service-data.vnfs.vnf[$vidx].vnf-id == $vnf-topology-operation-input.vnf-information.vnf-id`">
\r 
   9                         <outcome value='true'>
\r 
  10                             <block atomic="true">
\r 
  12                                     <parameter name='tmp.vidx' value='`$vidx`' />
\r 
  13                                     <parameter name='ctx.vnf-data.' value='`$service-data.vnfs.vnf[$vidx].`' />
\r 
  16                                     <parameter name='vnf-request-input.' value='`$ctx.vnf-data.vnf-data.vnf-request-input.`' />
\r 
  18                                 <call module='GENERIC-RESOURCE-API' rpc='sdwan-get-device-param' mode='sync' ></call>
\r 
  24             <switch test="`$tmp.vidx`">
\r 
  26                     <return status='failure'>
\r 
  27                         <parameter name='ack-final' value='Y'/>
\r 
  28                         <parameter name="error-code" value="500" />
\r 
  29                         <parameter name="error-message" value="vnf-topology-operation-input.vnf-request-input.vnf-id not found in service-data" />
\r 
  33             <record plugin="org.onap.ccsdk.sli.core.sli.recording.FileRecorder">
\r 
  34                 <parameter name="file" value="/opt/opendaylight/current/data/log/svclogic.log"/>
\r 
  35                 <parameter name="field1" value="__TIMESTAMP__"/>
\r 
  36                 <parameter name="field2" value="Provided alloted resource length"/>
\r 
  37                 <parameter name="field3" value="'parameters length'"/>
\r 
  38                 <parameter name="field4" value='`$vnf-topology-operation-input.vnf-request-input.vnf-input-parameters.param_length`'/>
\r 
  40             <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >
\r 
  41                 <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />
\r 
  42                 <parameter name='contextPrefix' value='prop' />
\r 
  44             <get-resource plugin="org.onap.ccsdk.sli.adaptors.aai.AAIService" 
\r 
  45                 resource="esr-thirdparty-sdnc" 
\r 
  46                 key="esr-thirdparty-sdnc.thirdparty-sdnc-id = SDWANController AND 
\r 
  48         pfx='tmp.aai.esr-thirdparty-sdnc' local-only='false' >
\r 
  49                 <outcome value='success'>
\r 
  51                         <parameter name='prop.sdncRestApi.thirdpartySdnc.url' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].service-url`" />
\r 
  52                         <parameter name='prop.sdncRestApi.thirdpartySdnc.user' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].user-name`" />
\r 
  53                         <parameter name='prop.sdncRestApi.thirdpartySdnc.password' value="`$tmp.aai.esr-thirdparty-sdnc.esr-system-info-list.esr-system-info[0].password`" />
\r 
  56                 <outcome value='not-found'>
\r 
  57                     <return status='failure'>
\r 
  58                         <parameter name='ack-final' value='Y'/>
\r 
  59                         <parameter name="error-code" value="500" />
\r 
  60                         <parameter name="error-message" value="`'An error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />
\r 
  63                 <outcome value='Other'>
\r 
  64                     <return status='failure'>
\r 
  65                         <parameter name='ack-final' value='Y'/>
\r 
  66                         <parameter name="error-code" value="500" />
\r 
  67                         <parameter name="error-message" value="`'Unexpected error occurred while querying esr-thirdparty-sdnc from AnAI with thirdparty-sdnc-id = ' + $tmp.thirdparty-sdnc-id`" />
\r 
  71             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
\r 
  72                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/actokentemplate.json'`" />
\r 
  73                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/v2/tokens'`" />
\r 
  74                 <parameter name="format" value="json"/>
\r 
  75                 <parameter name="httpMethod" value="post"/>
\r 
  76                 <parameter name="responsePrefix" value="token-result"/>
\r 
  77                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.openecomp.client.jks"/>
\r 
  78                 <parameter name="trustStorePassword" value="adminadmin"/>
\r 
  79                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>
\r 
  80                 <parameter name="keyStorePassword" value="adminadmin"/>
\r 
  81                 <outcome value='success'>
\r 
  83                         <parameter name='prop.sdncRestApi.token_id' value='`$token-result.data.token_id`' />
\r 
  86                 <outcome value='failure'>
\r 
  90             <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
\r 
  91                 <parameter name="templateFileName" value="`$prop.restapi.templateDir + '/sdwan-device.json'`" />
\r 
  92                 <parameter name="restapiUrl" value="`$prop.sdncRestApi.thirdpartySdnc.url + '/controller/campus/v3/devices'`" />
\r 
  93                 <parameter name="restapiUser" value="`$prop.sdncRestApi.thirdpartySdnc.user`" />
\r 
  94                 <parameter name="restapiPassword" value="`$prop.sdncRestApi.thirdpartySdnc.password`" />
\r 
  95                 <parameter name="format" value="json"/>
\r 
  96                 <parameter name="httpMethod" value="put"/>
\r 
  97                 <parameter name="responsePrefix" value="deviceResp"/>
\r 
  98                 <parameter name="trustStoreFileName" value="/opt/onap/sdnc/data/stores/truststore.openecomp.client.jks"/>
\r 
  99                 <parameter name="trustStorePassword" value="adminadmin"/>
\r 
 100                 <parameter name="keyStoreFileName" value="/opt/onap/sdnc/data/stores/sdnc.p12"/>
\r 
 101                 <parameter name="keyStorePassword" value="adminadmin"/>
\r 
 102                 <parameter name='customHttpHeaders' value="`'X-ACCESS-TOKEN=' + $prop.sdncRestApi.token_id`" />
\r 
 103                 <outcome value='success'>
\r 
 104                     <block atomic="true"></block>
\r 
 106                 <outcome value='failure'>
\r 
 107                     <return status='failure'>
\r 
 108                         <parameter name='ack-final' value='Y'/>
\r 
 109                         <parameter name="error-code" value="500" />
\r 
 110                         <parameter name="error-message" value="Error executing Activate Device rest api" />
\r 
 115                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param[$service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length].name' value="deviceId" />
\r 
 116                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param[$service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length].value' value='`$deviceResp.success[0].id`' />
\r 
 117                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length' value='`$service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-request-input.vnf-input-parameters.param_length + 1`' />
\r 
 120                 <parameter name='vnfId' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r 
 121                 <parameter name="vnf-object-path" value="`'restconf/config/GENERIC-RESOURCE-API:services/service/'  + $vnf-topology-operation-input.service-information.service-instance-id  + '/service-data/vnfs/vnf/'  + $vnf-topology-operation-input.vnf-information.vnf-id  + '/vnf-data/'` " />
\r 
 124                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-level-oper-status.order-status' value='Active' />
\r 
 125                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-level-oper-status.last-rpc-action' value='`$vnf-topology-operation-input.sdnc-request-header.svc-action`' />
\r 
 126                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-level-oper-status.last-action' value='`$vnf-topology-operation-input.request-information.request-action`' />
\r 
 129                 <!--parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' /-->
\r 
 130                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.sdnc-request-header.' value='`$vnf-topology-operation-input.sdnc-request-header.`' />
\r 
 131                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.request-information.' value='`$vnf-topology-operation-input.request-information.`' />
\r 
 132                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.service-information.' value='`$vnf-topology-operation-input.service-information.`' />
\r 
 133                 <parameter name='service-data.vnfs.vnf[$tmp.vidx].vnf-data.vnf-information.' value='`$vnf-topology-operation-input.vnf-information.`' />
\r 
 135             <save plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='device' 
\r 
 136       key='device.id = $vnf-topology-operation-input.vnf-information.vnf-id' >
\r 
 137                 <parameter name='id' value='`$vnf-topology-operation-input.vnf-information.vnf-id`' />
\r 
 138                 <parameter name='device-id' value='`$deviceResp.success[0].id`' />
\r 
 139                 <parameter name='operational-status' value='Active' />
\r 
 141             <save plugin='org.onap.ccsdk.sli.adaptors.aai.AAIService' resource='service-instance:relationship-list' 
\r 
 142       key='service-instance.service-instance-id = $service-data.service-information.service-instance-id 
\r 
 143          AND customer.global-customer-id = $service-data.vnfs.vnf[$vnf-index].vnf-data.service-information.global-customer-id 
\r 
 144          AND service-subscription.service-type = $service-data.vnfs.vnf[$vnf-index].vnf-data.service-information.subscription-service-type' 
\r 
 145       force="true" pfx="tmp.AnAI-data">
\r 
 146                 <parameter name="relationship-list.relationship[0].related-to" value="device" />
\r 
 147                 <parameter name="relationship-list.relationship[0].related-link" value="`'/network/devices/device/' + $vnf-topology-operation-input.vnf-information.vnf-id`" />
\r 
 148                 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-key" value="device.id" />
\r 
 149                 <parameter name="relationship-list.relationship[0].relationship-data[0].relationship-value" value="`$vnf-topology-operation-input.vnf-information.vnf-id`" />
\r 
 151             <return status='success'>
\r 
 152                 <parameter name="ack-final-indicator" value="Y" />
\r 
 153                 <parameter name="error-code" value="200" />
\r 
 154                 <parameter name="error-message" value="`$error-message`" />
\r