<service-logic
    xmlns='http://www.onap.org/sdnc/svclogic'
    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}'>
    <method rpc='self-serve-pnf-assign' mode='sync'>
        <block atomic='true'>
            <set>
                <parameter name='is-new-pnf' value='true' />
            </set>
            <switch test='`$service-data.pnfs.pnf_length`'>
                <outcome value=''>
                    <block>
                        <set>
                            <parameter name='pnf-index' value='0' />
                        </set>
                        <set>
                            <parameter name='service-data.pnfs.pnf_length' value='1' />
                        </set>
                    </block>
                </outcome>
                <outcome value='0'>
                    <block>
                        <set>
                            <parameter name='pnf-index' value='0' />
                        </set>
                        <set>
                            <parameter name='service-data.pnfs.pnf_length' value='1' />
                        </set>
                    </block>
                </outcome>
                <outcome value='Other'>
                    <block>
                        <for index='idx' start='0' end='`$service-data.pnfs.pnf_length`' >
                            <switch test='`$pf-topology-operation-input.pnf-details.pnf-id == $service-data.pnfs.pnf[$idx].pnf-id`'>
                                <outcome value='true'>
                                    <block>
                                        <set>
                                            <parameter name='is-new-pnf' value='false' />
                                        </set>
                                        <set>
                                            <parameter name='pnf-index' value='`$idx`' />
                                        </set>
                                        <break/>
                                    </block>
                                </outcome>
                            </switch>
                        </for>
                        <switch test='`$is-new-pnf`'>
                            <outcome value='true'>
                                <block>
                                    <set>
                                        <parameter name='pnf-index' value='`$service-data.pnfs.pnf_length`' />
                                    </set>
                                    <set>
                                        <parameter name='service-data.pnfs.pnf_length' value='`$service-data.pnfs.pnf_length + 1`' />
                                    </set>
                                </block>
                            </outcome>
                        </switch>
                    </block>
                </outcome>
            </switch>
            <switch test='`$is-new-pnf`'>
                <outcome value='true'>
                    <block>
                        <set>
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-topology-identifier-structure.pnf-id'
 value='`$pnf-topology-operation-input.pnf-details.pnf-id`' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-topology-identifier-structure.pnf-type'
 value='`$pnf-topology-operation-input.pnf-details.pnf-type`' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.tenant'
 value='`$pnf-topology-operation-input.pnf-request-input.tenant`' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.aic-cloud-region'
 value='`$pnf-topology-operation-input.pnf-request-input.aic-cloud-region`' />
                        </set>
                        <set>
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-id'
   value='`$pnf-topology-operation-input.pnf-details.pnf-id`' />
                        </set>
                        <switch test='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-invariant-uuid`'>
                            <outcome value=''>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-invariant-uuid'
  value='`$db.pnf-model.invariant-uuid`' />
                                </set>
                            </outcome>
                            <outcome value='Other'>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-invariant-uuid'
  value='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-invariant-uuid`' />
                                </set>
                            </outcome>
                        </switch>
                        <switch test='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-uuid`'>
                            <outcome value=''>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-uuid'
  value='`$db.pnf-model.uuid`' />
                                </set>
                            </outcome>
                            <outcome value='Other'>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-uuid'
  value='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-uuid`' />
                                </set>
                            </outcome>
                        </switch>
                        <switch test='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-version`'>
                            <outcome value=''>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-version'
  value='`$db.pnf-model.version`' />
                                </set>
                            </outcome>
                            <outcome value='Other'>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-version'
  value='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-version`' />
                                </set>
                            </outcome>
                        </switch>
                        <switch test='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-name`'>
                            <outcome value=''>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-name'
  value='`$db.pnf-model.name`' />
                                </set>
                            </outcome>
                            <outcome value='Other'>
                                <set>
                                    <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-name'
  value='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-name`' />
                                </set>
                            </outcome>
                        </switch>
                        <set>
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.onap-model-information.model-customization-uuid' 
  value='`$pnf-topology-operation-input.pnf-details.onap-model-information.model-customization-uuid`' />
                        </set>
                        <set>
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.sdnc-request-header.'
        value='$pnf-topology-operation-input.sdnc-request-header.' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.request-information.'
        value='$pnf-topology-operation-input.request-information.' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.service-information.'
        value='$pnf-topology-operation-input.service-information.' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-details.'
        value='$pnf-topology-operation-input.pnf-details.' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.'
        value='$pnf-topology-operation-input.pnf-request-input.' />
                        </set>
                        <set>
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-level-oper-status.order-status' value='PendingCreate' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-level-oper-status.last-rpc-action' value='`$pnf-topology-operation-input.sdnc-request-header.svc-action`' />
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-level-oper-status.last-action' value='`$pnf-topology-operation-input.request-information.request-action`' />
                        </set>
                    </block>
                </outcome>
            </switch>
            <set>
                <parameter name='ss.capability.execution-order[0]' value='aai-get' />
                <parameter name='ss.capability.execution-order[1]' value='generate-name' />
                <parameter name='ss.capability.execution-order[2]' value='alts-entitlement-assign' />
                <parameter name='ss.capability.execution-order[3]' value='alts-license-assign' />
                <parameter name='ss.capability.execution-order[4]' value='vlan-tag-assign' />
                <parameter name='ss.capability.execution-order[5]' value='mS-vlan-tag-assign' />
                <parameter name='ss.capability.execution-order[6]' value='eipam-ip-assignment' />
                <parameter name='ss.capability.execution-order[7]' value='eipam-create-pool' />
                <parameter name='ss.capability.execution-order[8]' value='netbox-ip-assign' />
                <parameter name='ss.capability.execution-order[9]' value='mac-address-assign' />
                <parameter name='ss.capability.execution-order[10]' value='mS-mac-address-assign' />
                <parameter name='ss.capability.execution-order[11]' value='create-vpe-pool' />
                <parameter name='ss.capability.execution-order[12]' value='unresolved-composite-data' />
                <parameter name='ss.capability.execution-order[13]' value='aai-pnf-put' />
                <parameter name='ss.capability.execution-order_length' value='14' />
            </set>
            <set>
                <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.sdnc-generated-cloud-resources' value='true' />
            </set>
            <set>
                <parameter name='ss.capability-type' value='pnf' />
            </set>
            <switch test='`$prop.controller.user`'>
                <outcome value=''>
                    <execute plugin='org.onap.ccsdk.sli.plugins.prop.PropertiesNode' method='readProperties' >
                        <parameter name='fileName' value='%SDNC_CONFIG_DIR%/generic-resource-api-dg.properties' />
                        <parameter name='contextPrefix' value='prop' />
                    </execute>
                </outcome>
            </switch>
            <switch test='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param_length`'>
                <outcome value=''>
                    <block atomic='true'>
                        <set>
                            <parameter name='service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.'
  value='pnf-topology-operation-input.pnf-request-input.pnf-input-parameters.' />
                        </set>
                        <call module='GENERIC-RESOURCE-API' rpc='self-serve-pnf-ra-assignment' mode='sync' >
                            <outcome value='failure'>
                                <return status='failure'>
                                    <parameter name='error-code' value='500' />
                                    <parameter name='error-message' value="`'Failed to get RA assignments: ' + $error-message`" />
                                </return>
                            </outcome>
                        </call>
                        <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
                            <parameter name="logger" value="message-log"/>
                            <parameter name="field1" value="DONE with pnf-ra-assigment"/>
                        </record>
                    </block>
                </outcome>
            </switch>
            <for index='cidx' start='0' end='`$ss.capability.execution-order_length`' >
                <set>
                    <parameter name='ss.capability-name' value='`$ss.capability.execution-order[$cidx]`' />
                    <!--
ss.capability.execution-order[]
-->
                </set>
                <set>
                    <parameter name='ss.capability-action' value='assign' />
                </set>
                <set>
                    <parameter name='ss.capability-dg' value="`'self-serve-' + $ss.capability.execution-order[$cidx]`" />
                </set>
                <for index='pidx' start='0' end='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param_length`' >
                    <set>
                        <parameter name='tmp.param.capability-name' 
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$pidx].resource-resolution-data.capability-name`' />
                    </set>
                    <switch test='`$ss.capability-name == $tmp.param.capability-name`'>
                        <outcome value='true'>
                            <block atomic='true'>
                                <switch test='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.pnf-parameters-data.param[$pidx].resource-resolution-data.status`'>
                                    <outcome value='PENDING'>
                                        <call module='GENERIC-RESOURCE-API' rpc='`$ss.capability-dg`' mode='sync' >
                                            <outcome value='failure'>
                                                <block atomic='true'>
                                                    <set>
                                                        <parameter name='pf.pnf-id'
    value='`$service-data.pnfs.pnf[$pnf-index].pnf-id`' />
                                                        <parameter name='pf.pnf-data.sdnc-request-header.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.sdnc-request-header.`' />
                                                        <parameter name='pf.pnf-data.request-information.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.request-information.`' />
                                                        <parameter name='pf.pnf-data.service-information.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.service-information.`' />
                                                        <parameter name='pf.pnf-data.pnf-details.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-details.`' />
                                                        <parameter name='pf.pnf-data.pnf-topology.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.`' />
                                                        <parameter name='pf.pnf-data.pnf-level-oper-status.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-level-oper-status.`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.pnf-input-parameters.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.pnf-input-parameters.`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.request-version'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.request-version`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.pnf-name'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.pnf-name`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.tenant'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.tenant`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.aic-cloud-region'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.aic-cloud-region`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.aic-clli'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.aic-clli`' />
                                                    </set>
                                                    <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
                                                        <parameter name="source" value="`$prop.restapi.ss-pnf-assignments`"/>
                                                        <parameter name="outputPath" value="tmp.ss-pnf-url"/>
                                                        <parameter name="target" value="{service-instance-id}"/>
                                                        <parameter name="replacement" value="`$service-data.pnfs.pnf[$pnf-index].pnf-data.service-information.service-instance-id`"/>
                                                    </execute>
                                                    <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
                                                        <parameter name="source" value="`$tmp.ss-pnf-url`"/>
                                                        <parameter name="outputPath" value="tmp.ss-pnf-url"/>
                                                        <parameter name="target" value="{pnf-id}"/>
                                                        <parameter name="replacement" value="`$service-data.pnfs.pnf[$pnf-index].pnf-id`"/>
                                                    </execute>
                                                    <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
                                                        <parameter name='templateFileName' value="`$prop.restapi.templateDir + '/' + $prop.restapi.ss.pnf.templatefile`" />
                                                        <parameter name='restapiUrl' value='`$prop.controller.url + $tmp.ss-pnf-url`' />
                                                        <parameter name='restapiUser' value='`$prop.controller.user`' />
                                                        <parameter name='restapiPassword' value='`$prop.controller.pwd`' />
                                                        <parameter name='format' value='json' />
                                                        <parameter name='httpMethod' value='PUT' />
                                                        <parameter name="responsePrefix" value="mdsal-ss-pnf" />
                                                        <outcome value='failure'>
                                                            <set>
                                                                <parameter name="error-message" value="Failed to persist self-serve pnf assignments during assign in MD-SAL" />
                                                            </set>
                                                        </outcome>
                                                        <outcome value='not-found'>
                                                            <set>
                                                                <parameter name="error-message" value="Failed to persist self-serve pnf assignments during assign in MD-SAL" />
                                                            </set>
                                                        </outcome>
                                                    </execute>
                                                    <return status='failure'>
                                                        <parameter name='error-code' value='500' />
                                                        <parameter name='error-message' value="`'Encountered error from capability: '+ $ss.capability-dg + ', with error: '+ $error-message`" />
                                                    </return>
                                                </block>
                                            </outcome>
                                            <outcome value='success'>
                                                <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
                                                    <parameter name="logger" value="message-log"/>
                                                    <parameter name="field1" value="`'EXECUTION DONE: ' + $ss.capability-dg`"/>
                                                </record>
                                            </outcome>
                                        </call>
                                    </outcome>
                                    <outcome value='FAILED'>
                                        <call module='GENERIC-RESOURCE-API' rpc='`$ss.capability-dg`' mode='sync' >
                                            <outcome value='failure'>
                                                <block atomic='true'>
                                                    <set>
                                                        <parameter name='pf.pnf-id'
    value='`$service-data.pnfs.pnf[$pnf-index].pnf-id`' />
                                                        <parameter name='pf.pnf-data.sdnc-request-header.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.sdnc-request-header.`' />
                                                        <parameter name='pf.pnf-data.request-information.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.request-information.`' />
                                                        <parameter name='pf.pnf-data.service-information.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.service-information.`' />
                                                        <parameter name='pf.pnf-data.pnf-details.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-details.`' />
                                                        <parameter name='pf.pnf-data.pnf-topology.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-topology.`' />
                                                        <parameter name='pf.pnf-data.pnf-level-oper-status.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-level-oper-status.`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.pnf-input-parameters.'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.pnf-input-parameters.`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.request-version'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.request-version`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.pnf-name'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.pnf-name`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.tenant'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.tenant`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.aic-cloud-region'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.aic-cloud-region`' />
                                                        <parameter name='pf.pnf-data.pnf-request-input.aic-clli'
  value='`$service-data.pnfs.pnf[$pnf-index].pnf-data.pnf-request-input.aic-clli`' />
                                                    </set>
                                                    <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
                                                        <parameter name="source" value="`$prop.restapi.ss-pnf-assignments`"/>
                                                        <parameter name="outputPath" value="tmp.ss-pnf-url"/>
                                                        <parameter name="target" value="{service-instance-id}"/>
                                                        <parameter name="replacement" value="`$service-data.pnfs.pnf[$pnf-index].pnf-data.service-information.service-instance-id`"/>
                                                    </execute>
                                                    <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliStringUtils' method='replace' >
                                                        <parameter name="source" value="`$tmp.ss-pnf-url`"/>
                                                        <parameter name="outputPath" value="tmp.ss-pnf-url"/>
                                                        <parameter name="target" value="{pnf-id}"/>
                                                        <parameter name="replacement" value="`$service-data.pnfs.pnf[$pnf-index].pnf-id`"/>
                                                    </execute>
                                                    <execute plugin='org.onap.ccsdk.sli.plugins.restapicall.RestapiCallNode' method='sendRequest' >
                                                        <parameter name='templateFileName' value="`$prop.restapi.templateDir + '/' + $prop.restapi.ss.pnf.templatefile`" />
                                                        <parameter name='restapiUrl' value='`$prop.controller.url + $tmp.ss-pnf-url`' />
                                                        <parameter name='restapiUser' value='`$prop.controller.user`' />
                                                        <parameter name='restapiPassword' value='`$prop.controller.pwd`' />
                                                        <parameter name='format' value='json' />
                                                        <parameter name='httpMethod' value='PUT' />
                                                        <parameter name="responsePrefix" value="mdsal-ss-pnf" />
                                                        <outcome value='failure'>
                                                            <set>
                                                                <parameter name="error-message" value="Failed to persist self-serve pnf assignments during assign in MD-SAL" />
                                                            </set>
                                                        </outcome>
                                                        <outcome value='not-found'>
                                                            <set>
                                                                <parameter name="error-message" value="Failed to persist self-serve pnf assignments during assign in MD-SAL" />
                                                            </set>
                                                        </outcome>
                                                    </execute>
                                                    <return status='failure'>
                                                        <parameter name='error-code' value='500' />
                                                        <parameter name='error-message' value="`'Encountered error from capability: '+ $ss.capability-dg + ', with error: '+ $error-message`" />
                                                    </return>
                                                </block>
                                            </outcome>
                                            <outcome value='success'>
                                                <record plugin="org.onap.ccsdk.sli.core.sli.recording.Slf4jRecorder">
                                                    <parameter name="logger" value="message-log"/>
                                                    <parameter name="field1" value="`'EXECUTION DONE: ' + $ss.capability-dg`"/>
                                                </record>
                                            </outcome>
                                        </call>
                                    </outcome>
                                </switch>
                                <break/>
                            </block>
                        </outcome>
                    </switch>
                </for>
            </for>
            <execute plugin='org.onap.ccsdk.sli.core.slipluginutils.SliPluginUtils' method='printContext' >
                <parameter name='filename' value='/var/tmp/ss-pnf-assign.log' />
            </execute>
        </block>
    </method>
</service-logic>