summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/deployment/src/main/release/etc/vnfpkginfo/vnfpkginfo.json76
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/docker/Dockerfile2
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/pom.xml40
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/DownloadCsarManager.java72
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ExceptionArgs.java15
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ServiceException.java32
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/adapter/impl/AdapterResourceManager.java66
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapter2DriverMgrService.java44
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapterMgrService.java44
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/Constant.java4
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/UrlConstant.java2
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/connect/AbstractSslContext.java71
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/vnf/VnfMgrVnfm.java24
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/AuthMgr.java1
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfMgr.java27
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfResourceMgr.java2
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/AuthRoa.java8
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/SwaggerRoa.java1
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfAdapterResourceRoa.java1
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java82
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/resources/spring/Vnfmadapter/services.xml56
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/ResultRequestUtilTest.java45
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapter2DriverMgrServiceTest.java22
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapterMgrServiceTest.java25
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoaTest.java55
-rwxr-xr-xnokia/vnfmdriver/vfcadaptorservice/docker/Dockerfile2
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/pom.xml38
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/VfcadaptorApplication.java5
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/Cbam2DriverResponseConverter.java102
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnable.java160
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnable.java46
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/OperateTaskProgress.java98
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnable.java170
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TerminateVnfContinueRunnable.java47
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImpl.java242
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionRequest.java59
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionResponse.java41
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionRequest.java21
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionResponse.java49
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationRequest.java71
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationResponse.java42
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Subscription.java78
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionAuthentication.java91
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionFilter.java97
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Type.java24
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/VnfNotificationType.java22
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImpl.java479
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/MultipartUtility.java5
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/inf/CbamMgmrInf.java13
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/common/bo/AdaptorEnv.java84
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonConstants.java6
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonEnum.java2
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmJobExecutionInfo.java64
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmResourceInfo.java30
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmSubscriptionInfo.java55
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfcResourceInfoMapper.java47
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmJobExecutionMapper.java76
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmSubscriptionsMapper.java52
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmJobExecutionRepository.java6
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmResourceRepository.java6
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmSubscriptionsRepository.java24
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/CbamNofiticationSubscription.java93
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/EnvVariablesInitialization.java2
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/MsbServiceRegister.java (renamed from nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegister.java)4
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImpl.java56
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nslcm/bo/entity/AffectedVnfc.java12
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/controller/VnfmDriverController.java38
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/impl/VnfContinueProcessorImpl.java33
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/inf/VnfContinueProcessorInf.java11
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/application.properties30
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/logback.xml31
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/webapp/WEB-INF/web.xml10
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnableTest.java84
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnableTest.java115
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnableTest.java83
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TermiateVnfContinueRunnableTest.java110
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImplTest.java11
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImplTest.java65
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImplTest.java1
-rw-r--r--nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegisterTest.java1
-rw-r--r--nokiav2/.gitignore7
-rw-r--r--nokiav2/deployment/pom.xml51
-rw-r--r--nokiav2/deployment/src/assembly/assembly.xml38
-rw-r--r--nokiav2/deployment/src/main/resources/.gitignore1
-rwxr-xr-xnokiav2/deployment/src/main/resources/Dockerfile17
-rw-r--r--nokiav2/deployment/src/main/resources/LICENSE473
-rw-r--r--nokiav2/deployment/src/main/resources/application.properties75
-rwxr-xr-xnokiav2/deployment/src/main/resources/build_image.sh86
-rwxr-xr-xnokiav2/deployment/src/main/resources/docker-entrypoint.sh85
-rwxr-xr-xnokiav2/deployment/src/main/resources/test_xmlstarlet.sh7
-rw-r--r--nokiav2/docs/.gitignore3
-rw-r--r--nokiav2/docs/Makefile20
-rw-r--r--nokiav2/docs/conf.py155
-rw-r--r--nokiav2/docs/index.rst20
-rw-r--r--nokiav2/docs/integration.rst156
-rw-r--r--nokiav2/docs/onboarding.rst125
-rw-r--r--nokiav2/docs/sample/aai.create.customer.request.json21
-rw-r--r--nokiav2/docs/sample/aai.create.tenant.request.json6
-rw-r--r--nokiav2/docs/sample/cbam.collectConnectionPoints.js57
-rw-r--r--nokiav2/docs/sample/cbam.post.collectConnectionPoints.js4
-rw-r--r--nokiav2/docs/sample/cbam.pre.collectConnectionPoints.js1
-rw-r--r--nokiav2/docs/sampleVnfs/simple/cbam.instantiation.request.json60
-rw-r--r--nokiav2/docs/sampleVnfs/simple/simple.csarbin0 -> 12044 bytes
-rw-r--r--nokiav2/docs/sampleVnfs/simple/vfc.ns.create.request.json9
-rw-r--r--nokiav2/docs/sampleVnfs/simple/vfc.ns.instantiation.request.json41
-rw-r--r--nokiav2/docs/sampleVnfs/simpleDual/cbam.instantiation.request.json60
-rw-r--r--nokiav2/docs/sampleVnfs/simpleDual/sample/vfc.to.cbam.instantiation.json65
-rw-r--r--nokiav2/docs/sampleVnfs/simpleDual/simpleDual.csarbin0 -> 11367 bytes
-rw-r--r--nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.create.request.json9
-rw-r--r--nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.heal.request.json13
-rw-r--r--nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.instantiation.request.json41
-rw-r--r--nokiav2/docs/sampleVnfs/simpleDual/vfc.vnf.scale.request.json9
-rw-r--r--nokiav2/docs/samplevnf.rst19
-rw-r--r--nokiav2/docs/vnfintegration.rst51
-rw-r--r--nokiav2/driver/pom.xml121
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/NokiaSvnfmApplication.java98
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IGrantManager.java81
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/INotificationSender.java39
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IPackageProvider.java36
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VimInfoProvider.java31
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VnfmInfoProvider.java31
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/package-info.java21
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/GenericExternalSystemInfoProvider.java91
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/IpMappingProvider.java65
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/MsbApiProvider.java88
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/SelfRegistrationManager.java191
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/package-info.java20
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIExternalSystemInfoProvider.java120
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIRestApiProvider.java183
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/GrantlessGrantManager.java65
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/SdcPackageProvider.java105
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AAINotificationProcessor.java146
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AbstractManager.java143
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/GenericVnfManager.java114
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/L3NetworkManager.java104
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/LInterfaceManager.java101
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VnfcManager.java90
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VserverManager.java132
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/package-info.java20
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/package-info.java20
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/package-info.java20
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcExternalSystemInfoProvider.java64
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcGrantManager.java243
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcNotificationSender.java217
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcPackageProvider.java103
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcRestApiProvider.java76
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfPackageBuilder.java72
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfdBuilder.java100
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfPackageBuilder.java86
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfdBuilder.java279
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/package-info.java20
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/ConverterApi.java96
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcmApi.java154
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcnApi.java75
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/SwaggerApi.java64
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/package-info.java20
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/Conditions.java68
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/RealConfig.java49
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/ServletInitializer.java33
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/package-info.java20
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/CbamUtils.java93
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/StoreLoader.java163
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/SystemFunctions.java165
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserInvisibleError.java39
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserVisibleError.java39
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/AdditionalParameters.java216
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CatalogManager.java177
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamRestApiProvider.java115
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamTokenProvider.java248
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/DriverProperties.java108
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/ILifecycleChangeNotificationManager.java38
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/JobManager.java318
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/LifecycleManager.java640
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/LifecycleChangeNotificationManager.java232
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ProcessedNotification.java87
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedConnectionPoints.java85
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedCp.java214
-rw-r--r--nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/package-info.java20
-rw-r--r--nokiav2/driver/src/main/resources/MainServiceTemplate.meta7
-rw-r--r--nokiav2/driver/src/main/resources/TOSCA.meta4
-rw-r--r--nokiav2/driver/src/main/resources/cbam.collectConnectionPoints.js57
-rw-r--r--nokiav2/driver/src/main/resources/cbam.post.collectConnectionPoints.js4
-rw-r--r--nokiav2/driver/src/main/resources/cbam.pre.collectConnectionPoints.js1
-rw-r--r--nokiav2/driver/src/main/resources/self.swagger.json798
-rw-r--r--nokiav2/driver/src/main/resources/upload.html12
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/FullUnitTestSuite.java105
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/TestNokiaSvnfmApplication.java162
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTDirectReal.java100
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTReal.java41
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestCbamRestApiProvider.java235
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestGenericExternalSystemInfoProvider.java136
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestIpMappingProvider.java61
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestMsbApiProvider.java173
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIExternalSystemInfoProvider.java189
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIRestApiProvider.java238
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestGrantlessGrantManager.java80
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestSdcPackageProvider.java130
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAAINotificationProcessor.java253
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAbstractManager.java230
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestGenericVnfManager.java250
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestL3NetworkManager.java143
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestLInterfaceManager.java230
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVnfcManager.java108
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVserverManager.java253
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcExternalSystemInfoProvider.java100
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcGrantManager.java417
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcNotificationSender.java863
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcPackageProvider.java156
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcRestApiProvider.java64
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfPackageBuilder.java54
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfdBuilder.java47
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfPackageBuilder.java74
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfdBuilder.java86
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestConverterApi.java152
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcmApi.java131
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcnApi.java65
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerApi.java62
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerDefinitionConsistency.java82
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestConditions.java75
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestRealConfig.java43
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestServletInitializer.java40
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestCbamUtils.java128
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestStoreLoader.java346
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestSystemFunctions.java118
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserInvisibleError.java38
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserVisibleError.java38
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUtil.java57
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestAdditionalParams.java61
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestBase.java178
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamCatalogManager.java261
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamTokenProvider.java452
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestDriverProperties.java35
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestJobManager.java543
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestLifecycleManager.java1483
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestSelfRegistrationManager.java345
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestLifecycleChangeNotificationManager.java567
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestProcessedNotification.java28
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedConnectionPoints.java30
-rw-r--r--nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedCp.java30
-rw-r--r--nokiav2/driver/src/test/resources/.gitignore1
-rw-r--r--nokiav2/driver/src/test/resources/application-direct.properties73
-rw-r--r--nokiav2/driver/src/test/resources/application.properties66
-rw-r--r--nokiav2/driver/src/test/resources/test.jksbin0 -> 1949 bytes
-rw-r--r--nokiav2/driver/src/test/resources/unittests/TestCbamCatalogManager.sample.csarbin0 -> 2321 bytes
-rw-r--r--nokiav2/driver/src/test/resources/unittests/cbam.package.zipbin0 -> 759 bytes
-rw-r--r--nokiav2/driver/src/test/resources/unittests/empty.zipbin0 -> 22 bytes
-rw-r--r--nokiav2/driver/src/test/resources/unittests/lcn.json9
-rw-r--r--nokiav2/driver/src/test/resources/unittests/localhost.cert.pem73
-rw-r--r--nokiav2/driver/src/test/resources/unittests/localhost.jksbin0 -> 2254 bytes
-rw-r--r--nokiav2/driver/src/test/resources/unittests/maria.vnfd.scalable.tosca.nated.yaml593
-rw-r--r--nokiav2/driver/src/test/resources/unittests/missing.vnfd.zipbin0 -> 448 bytes
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.modified.vnfd.yaml87
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.original.vnfd.yaml33
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.modified.vnfd.yaml46
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.original.vnfd.yaml9
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zipbin0 -> 1288 bytes
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zip.vnfd17
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.cbam.yaml11
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.onap.yaml14
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.cbam.yaml153
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.inconsistent.cbam.yaml18
-rw-r--r--nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.onap.yaml95
-rw-r--r--nokiav2/driver/src/test/resources/unittests/sample.cert.pem14
-rw-r--r--nokiav2/driver/src/test/resources/unittests/vnfd.full.yaml24
-rw-r--r--nokiav2/driver/src/test/resources/unittests/vnfd.instantiation.yaml16
-rw-r--r--nokiav2/driver/src/test/resources/unittests/vnfd.scale.yaml23
-rw-r--r--nokiav2/driverwar/pom.xml86
-rw-r--r--nokiav2/generatedapis/pom.xml209
-rw-r--r--nokiav2/generatedapis/src/main/resources/nokia.catalog.json525
-rw-r--r--nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcm.json4112
-rw-r--r--nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcn.subscription.json499
-rw-r--r--nokiav2/generatedapis/src/main/resources/patch56
-rw-r--r--nokiav2/generatedapis/src/main/resources/resource.manager.json1100
-rw-r--r--nokiav2/generatedapis/src/main/resources/sdc.internal.json9902
-rw-r--r--nokiav2/generatedapis/src/main/resources/sdc.json8099
-rw-r--r--nokiav2/generatedapis/src/main/resources/vfc.catalog.swagger.json751
-rw-r--r--nokiav2/generatedapis/src/main/resources/vfc.vnfdriver.swagger.json1385
-rw-r--r--nokiav2/generatedapis/src/test/java/TestInhertence.java113
-rw-r--r--nokiav2/pom.xml43
-rw-r--r--pom.xml1
-rw-r--r--zte/vmanager/driver/interfaces/serializers.py435
-rw-r--r--zte/vmanager/driver/interfaces/tests.py1262
-rw-r--r--zte/vmanager/driver/interfaces/urls.py34
-rw-r--r--zte/vmanager/driver/interfaces/views.py922
-rw-r--r--zte/vmanager/driver/settings.py69
-rw-r--r--zte/vmanager/driver/swagger/swagger.json4
-rw-r--r--zte/vmanager/driver/swagger/urls.py26
-rw-r--r--zte/vmanager/driver/swagger/views.py3
-rw-r--r--zte/vmanager/pom.xml12
-rw-r--r--zte/vmanager/requirements.txt9
-rw-r--r--zte/vmanager/tox.ini3
291 files changed, 53125 insertions, 2117 deletions
diff --git a/huawei/vnfmadapter/VnfmadapterService/deployment/src/main/release/etc/vnfpkginfo/vnfpkginfo.json b/huawei/vnfmadapter/VnfmadapterService/deployment/src/main/release/etc/vnfpkginfo/vnfpkginfo.json
index 432889d0..82fcb480 100644
--- a/huawei/vnfmadapter/VnfmadapterService/deployment/src/main/release/etc/vnfpkginfo/vnfpkginfo.json
+++ b/huawei/vnfmadapter/VnfmadapterService/deployment/src/main/release/etc/vnfpkginfo/vnfpkginfo.json
@@ -1,40 +1,42 @@
{
- "1": {
- "template": {
- "name": "vCPE",
- "ftp_server_ip": "192.168.237.179",
- "ftp_server_port": "21",
- "ftp_username": "ftpsuser",
- "ftp_password": "ftpsuser",
- "csar_file_path": "/home/ftpsuser/files/",
- "csar_file_name": "VCPE_VNF.csar",
- "vnfd_file_path": "/files/SoftwareImages/",
- "vnfd_file_name": "vCPE.zip",
- "image_file_path": "/files/SoftwareImages/",
- "image_file_name": "ar_img.zip",
- "software_file_path": "",
- "software_file_name": "",
- "catalog": "",
- "vim_id": "NE=34603199"
- }
- },
- "2": {
- "template": {
- "name": "vCPE",
- "ftp_server_ip": "192.168.237.179",
- "ftp_server_port": "21",
- "ftp_username": "ftpsuser",
- "ftp_password": "ftpsuser",
- "csar_file_path": "/home/ftpsuser/files/",
- "csar_file_name": "VCPE_VNF.csar",
- "vnfd_file_path": "/files/SoftwareImages/",
- "vnfd_file_name": "vCPE.zip",
- "image_file_path": "/files/SoftwareImages/",
- "image_file_name": "ar_img.zip",
- "software_file_path": "",
- "software_file_name": "",
- "catalog": "",
- "vim_id": "NE=34603199"
- }
+ "1": {
+ "template": {
+ "name": "vCPE",
+ "ftp_server_ip": "192.168.237.179",
+ "ftp_server_port": "21",
+ "ftp_username": "ftpsuser",
+ "ftp_password": "ftpsuser",
+ "csar_file_path": "/home/ftpsuser/files/",
+ "csar_file_name": "VCPE_VNF.csar",
+ "vnfd_file_path": "/files/SoftwareImages/",
+ "vnfd_file_name": "vCPE.zip",
+ "image_file_path": "/files/SoftwareImages/",
+ "image_file_name": "ar_img.zip",
+ "software_file_path": "",
+ "software_file_name": "",
+ "catalog": "",
+ "vim_id": "NE=34603199"
}
+ },
+ "2": {
+ "template": {
+ "name": "vCPE",
+ "ftp_server_ip": "192.168.237.179",
+ "ftp_server_port": "21",
+ "ftp_username": "ftpsuser",
+ "ftp_password": "ftpsuser",
+ "csar_file_path": "/home/ftpsuser/files/",
+ "csar_file_name": "VCPE_VNF.csar",
+ "vnfd_file_path": "/files/SoftwareImages/",
+ "vnfd_file_name": "vCPE.zip",
+ "image_file_path": "/files/SoftwareImages/",
+ "image_file_name": "ar_img.zip",
+ "software_file_path": "",
+ "software_file_name": "",
+ "catalog": "",
+ "vim_id": "NE=34603199"
+ }
+ },
+ "vnfmid": "",
+ "vimid": ""
} \ No newline at end of file
diff --git a/huawei/vnfmadapter/VnfmadapterService/docker/Dockerfile b/huawei/vnfmadapter/VnfmadapterService/docker/Dockerfile
index 67ac2bb5..4b24b490 100644
--- a/huawei/vnfmadapter/VnfmadapterService/docker/Dockerfile
+++ b/huawei/vnfmadapter/VnfmadapterService/docker/Dockerfile
@@ -29,7 +29,7 @@ COPY init-mysql.sh .
# 30-tomcat.txt - AUTOGENERATED, DO NOT MODIFY MANUALLY
# Set up tomcat
-RUN wget -q http://mirrors.ocf.berkeley.edu/apache/tomcat/tomcat-8/v8.5.27/bin/apache-tomcat-8.5.27.tar.gz && tar --strip-components=1 -xf apache-tomcat-8.5.27.tar.gz && rm -f apache-tomcat-8.5.27.tar.gz && rm -rf webapps && mkdir -p webapps/ROOT
+RUN wget -q http://mirrors.ocf.berkeley.edu/apache/tomcat/tomcat-8/v8.5.28/bin/apache-tomcat-8.5.28.tar.gz && tar --strip-components=1 -xf apache-tomcat-8.5.28.tar.gz && rm -f apache-tomcat-8.5.28.tar.gz && rm -rf webapps && mkdir -p webapps/ROOT
RUN echo 'export CATALINA_OPTS="$CATALINA_OPTS -Xms64m -Xmx256m -XX:MaxPermSize=64m"' > /service/bin/setenv.sh
ENV CATALINA_HOME /service
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/pom.xml b/huawei/vnfmadapter/VnfmadapterService/service/pom.xml
index a8fabc2f..a18c043c 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/pom.xml
+++ b/huawei/vnfmadapter/VnfmadapterService/service/pom.xml
@@ -14,7 +14,8 @@
See the License for the specific language governing permissions and
limitations under the License.
-->
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.huawei.vnfmadapter</groupId>
@@ -26,7 +27,7 @@
<name>vfc/nfvo/drivers/vnfm/svnfm/huawei/vnfmadapter/VnfmadapterService/service</name>
<packaging>war</packaging>
-<dependencies>
+ <dependencies>
<dependency>
<groupId>org.powermock</groupId>
<artifactId>powermock-core</artifactId>
@@ -58,9 +59,9 @@
<version>2.5.0</version>
</dependency>
<dependency>
- <groupId>org.apache.commons</groupId>
- <artifactId>commons-lang3</artifactId>
- <version>3.1</version>
+ <groupId>org.apache.commons</groupId>
+ <artifactId>commons-lang3</artifactId>
+ <version>3.1</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
@@ -94,25 +95,32 @@
<artifactId>jetty-all</artifactId>
<version>8.1.16.v20140903</version>
</dependency>
+ <!--
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.36</version>
</dependency>
+ -->
+ <dependency>
+ <groupId>org.mariadb.jdbc</groupId>
+ <artifactId>mariadb-java-client</artifactId>
+ <version>2.2.2</version>
+ </dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxrs</artifactId>
<version>3.1.6</version>
</dependency>
<dependency>
- <groupId>org.mybatis</groupId>
- <artifactId>mybatis-spring</artifactId>
- <version>1.2.0</version>
- </dependency>
- <dependency>
- <groupId>org.mybatis</groupId>
- <artifactId>mybatis</artifactId>
- <version>3.2.7</version>
+ <groupId>org.mybatis</groupId>
+ <artifactId>mybatis-spring</artifactId>
+ <version>1.2.0</version>
+ </dependency>
+ <dependency>
+ <groupId>org.mybatis</groupId>
+ <artifactId>mybatis</artifactId>
+ <version>3.2.7</version>
</dependency>
<dependency>
@@ -176,7 +184,7 @@
<version>1.12</version>
</dependency>
<dependency>
- <groupId>org.springframework</groupId>
+ <groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
@@ -232,7 +240,7 @@
</dependency>
<!-- UT coverage dependency start -->
- <dependency>
+ <dependency>
<groupId>org.jmockit</groupId>
<artifactId>jmockit</artifactId>
<version>1.19</version>
@@ -253,7 +261,5 @@
<!-- UT coverage dependency end -->
-
-
</dependencies>
</project>
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/DownloadCsarManager.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/DownloadCsarManager.java
index 24d6ed11..b09c50d7 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/DownloadCsarManager.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/DownloadCsarManager.java
@@ -57,7 +57,7 @@ public class DownloadCsarManager {
/**
* Download from given URL.
- *
+ *
* @param url String
* @return
*/
@@ -67,49 +67,53 @@ public class DownloadCsarManager {
/**
* Download from given URL to given file location.
- *
+ *
* @param url String
* @param filepath String
* @return
*/
public static String download(String url, String filepath) {
String status = "";
- try {
- CloseableHttpClient client = HttpClients.createDefault();
+ try (CloseableHttpClient client = HttpClients.createDefault()){
HttpGet httpget = new HttpGet(url);
CloseableHttpResponse response = client.execute(httpget);
HttpEntity entity = response.getEntity();
- InputStream is = entity.getContent();
- if(filepath == null) {
- filepath = getFilePath(response); // NOSONAR
- }
+ try(InputStream is = entity.getContent()) {
+ if(filepath == null) {
+ filepath = getFilePath(response); // NOSONAR
+ }
- File file = new File(filepath);
- file.getParentFile().mkdirs();
- FileOutputStream fileout = new FileOutputStream(file);
+ File file = new File(filepath);
+ file.getParentFile().mkdirs();
+ try(FileOutputStream fileout = new FileOutputStream(file)){
- byte[] buffer = new byte[CACHE];
- int ch;
- while((ch = is.read(buffer)) != -1) {
- fileout.write(buffer, 0, ch);
+ byte[] buffer = new byte[CACHE];
+ int ch;
+ while((ch = is.read(buffer)) != -1) {
+ fileout.write(buffer, 0, ch);
+ }
+ fileout.flush();
+ status = Constant.DOWNLOADCSAR_SUCCESS;
+ } catch(Exception e) {
+ status = Constant.DOWNLOADCSAR_FAIL;
+ LOG.error("Download csar file failed! " + e.getMessage(), e);
+ }
+ } catch(Exception e) {
+ status = Constant.DOWNLOADCSAR_FAIL;
+ LOG.error("Download csar file failed! " + e.getMessage(), e);
}
- is.close();
- fileout.flush();
- fileout.close();
- client.close();
- status = Constant.DOWNLOADCSAR_SUCCESS;
-
} catch(Exception e) {
status = Constant.DOWNLOADCSAR_FAIL;
LOG.error("Download csar file failed! " + e.getMessage(), e);
}
+
return status;
}
/**
* Retrieve file path from given response.
- *
+ *
* @param response HttpResponse
* @return
*/
@@ -127,7 +131,7 @@ public class DownloadCsarManager {
/**
* Retrieve file name from given response.
- *
+ *
* @param response HttpResponse
* @return
*/
@@ -152,7 +156,7 @@ public class DownloadCsarManager {
/**
* Provides random file name.
- *
+ *
* @return
*/
public static String getRandomFileName() {
@@ -161,7 +165,7 @@ public class DownloadCsarManager {
/**
* unzip CSAR packge
- *
+ *
* @param fileName filePath
* @return
* @throws IOException
@@ -188,17 +192,17 @@ public class DownloadCsarManager {
if(parent != null && (!parent.exists())) {
parent.mkdirs();
}
- FileOutputStream fos = new FileOutputStream(file);
- BufferedOutputStream bos = new BufferedOutputStream(fos, BUFFER);
+ try(FileOutputStream fos = new FileOutputStream(file)){
+ try(BufferedOutputStream bos = new BufferedOutputStream(fos, BUFFER)){
- int count;
- byte data[] = new byte[BUFFER];
- while((count = bis.read(data, 0, BUFFER)) != -1) {
- bos.write(data, 0, count);
+ int count;
+ byte data[] = new byte[BUFFER];
+ while((count = bis.read(data, 0, BUFFER)) != -1) {
+ bos.write(data, 0, count);
+ }
+ bos.flush();
+ }
}
- bos.flush();
- bos.close();
- bis.close();
}
status = Constant.UNZIP_SUCCESS;
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ExceptionArgs.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ExceptionArgs.java
index 49e9500f..73c6548b 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ExceptionArgs.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ExceptionArgs.java
@@ -16,16 +16,23 @@
package org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.restclient;
+import java.io.Serializable;
+
/**
* ROA exception handling parameters.
* <br/>
* <p>
* </p>
- *
+ *
* @author
* @version 28-May-2016
*/
-public class ExceptionArgs {
+public class ExceptionArgs implements Serializable {
+
+ /**
+ *
+ */
+ private static final long serialVersionUID = 7411730460834659138L;
/**
* Exception descriptions.
@@ -51,7 +58,7 @@ public class ExceptionArgs {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
*/
public ExceptionArgs() {
@@ -62,7 +69,7 @@ public class ExceptionArgs {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param descArgs: descriptions.
* @param reasonArgs: reasons.
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ServiceException.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ServiceException.java
index af8086b7..136df51c 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ServiceException.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/restclient/ServiceException.java
@@ -22,7 +22,7 @@ import java.text.MessageFormat;
* The base class for all common exception.<br/>
* <p>
* </p>
- *
+ *
* @author
* @version 28-May-2016
*/
@@ -43,7 +43,7 @@ public class ServiceException extends Exception {
*/
private String id = DEFAULT_ID;
- private Object[] args = null;
+ private Object[] args = null; // NOSONAR
private int httpCode = 500;
@@ -54,7 +54,7 @@ public class ServiceException extends Exception {
* <p>
* This method is only used as deserialized, in other cases, use parameterized constructor.
* </p>
- *
+ *
* @since
*/
public ServiceException() {
@@ -65,7 +65,7 @@ public class ServiceException extends Exception {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param id: details.
* @param cause: reason.
@@ -79,7 +79,7 @@ public class ServiceException extends Exception {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param message: details.
*/
@@ -91,7 +91,7 @@ public class ServiceException extends Exception {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param id: exception id.
* @param message: details.
@@ -105,7 +105,7 @@ public class ServiceException extends Exception {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param id: exception id.
* @param httpCode: http status code.
@@ -121,7 +121,7 @@ public class ServiceException extends Exception {
* <p>
* the exception include the httpcode and message.
* </p>
- *
+ *
* @since
* @param httpCode http code.
* @param message details.
@@ -135,7 +135,7 @@ public class ServiceException extends Exception {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param id: exception id.
* @param httpCode: http code.
@@ -153,7 +153,7 @@ public class ServiceException extends Exception {
* <p>
* Have a placeholder exception, use args formatted message.
* </p>
- *
+ *
* @since
* @param id: exception id.
* @param message: details.
@@ -170,7 +170,7 @@ public class ServiceException extends Exception {
* <p>
* Have a placeholder exception, use args formatted message
* </p>
- *
+ *
* @since
* @param id: exception id.
* @param message: details.
@@ -187,7 +187,7 @@ public class ServiceException extends Exception {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param id: exception id.
* @param message: details.
@@ -202,7 +202,7 @@ public class ServiceException extends Exception {
* Constructor<br/>
* <p>
* </p>
- *
+ *
* @since
* @param cause: reason.
*/
@@ -212,7 +212,7 @@ public class ServiceException extends Exception {
/**
* Get exceptoin id.<br/>
- *
+ *
* @return
* @since
*/
@@ -237,7 +237,7 @@ public class ServiceException extends Exception {
/**
* Obtain the ROA exception handling framework parameters<br/>
- *
+ *
* @return exception args.
* @since
*/
@@ -251,7 +251,7 @@ public class ServiceException extends Exception {
/**
* Gets the parameter information<br/>
- *
+ *
* @return parameter list.
* @since
*/
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/adapter/impl/AdapterResourceManager.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/adapter/impl/AdapterResourceManager.java
index 68bc7f9e..53e51de7 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/adapter/impl/AdapterResourceManager.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/adapter/impl/AdapterResourceManager.java
@@ -308,12 +308,15 @@ public class AdapterResourceManager implements IResourceManager {
LOG.info("changeWorkingDirectory: " + ftpClient.changeWorkingDirectory(vnfpkg.getString(VNFD_FILE_PATH)));
String vnfdPath = csarfilepath + "Artifacts/Deployment/OTHER/";
LOG.info("vnfd_file_name: " + vnfdPath + vnfpkg.getString("vnfd_file_name"));
- InputStream inputStream = new FileInputStream(new File(vnfdPath + vnfpkg.getString("vnfd_file_name")));
- flag = ftpClient.storeFile(vnfpkg.getString("vnfd_file_name"), inputStream);
- if(flag) {
- resJson.put("message", "upload Csar success!");
+ try(InputStream inputStream = new FileInputStream(new File(vnfdPath + vnfpkg.getString("vnfd_file_name")))){
+ flag = ftpClient.storeFile(vnfpkg.getString("vnfd_file_name"), inputStream);
+ if(flag) {
+ resJson.put("message", "upload Csar success!");
+ }
+ } catch(Exception e) {
+ LOG.error("Exception: " + e);
}
- inputStream.close();
+
ftpClient.logout();
} catch(Exception e) {
LOG.error("Exception: " + e);
@@ -607,33 +610,23 @@ public class AdapterResourceManager implements IResourceManager {
* @since VFC 1.0
*/
public static String readVfnPkgInfoFromJson() throws IOException {
- InputStream ins = null;
- BufferedInputStream bins = null;
String fileContent = "";
String fileName = SystemEnvVariablesFactory.getInstance().getAppRoot()
+ System.getProperty(Constant.FILE_SEPARATOR) + "etc" + System.getProperty(Constant.FILE_SEPARATOR)
+ "vnfpkginfo" + System.getProperty(Constant.FILE_SEPARATOR) + Constant.VNFPKGINFO;
- try {
- ins = new FileInputStream(fileName);
- bins = new BufferedInputStream(ins);
+ try (InputStream ins = new FileInputStream(fileName)) {
+ try(BufferedInputStream bins = new BufferedInputStream(ins)){
+ byte[] contentByte = new byte[ins.available()];
+ int num = bins.read(contentByte);
- byte[] contentByte = new byte[ins.available()];
- int num = bins.read(contentByte);
-
- if(num > 0) {
- fileContent = new String(contentByte);
+ if(num > 0) {
+ fileContent = new String(contentByte);
+ }
}
} catch(FileNotFoundException e) {
LOG.error(fileName + "is not found!", e);
- } finally {
- if(ins != null) {
- ins.close();
- }
- if(bins != null) {
- bins.close();
- }
}
return fileContent;
@@ -641,35 +634,28 @@ public class AdapterResourceManager implements IResourceManager {
private static JSONObject readVnfdIdInfoFromJson() {
JSONObject jsonObject = new JSONObject();
- InputStream ins = null;
- BufferedInputStream bins = null;
+
String fileContent = "";
String fileName = SystemEnvVariablesFactory.getInstance().getAppRoot()
+ System.getProperty(Constant.FILE_SEPARATOR) + "etc" + System.getProperty(Constant.FILE_SEPARATOR)
+ "vnfpkginfo" + System.getProperty(Constant.FILE_SEPARATOR) + "vnfd_ids.json";
- try {
- ins = new FileInputStream(fileName);
- bins = new BufferedInputStream(ins);
-
- byte[] contentByte = new byte[ins.available()];
- int num = bins.read(contentByte);
+ try (InputStream ins = new FileInputStream(fileName)) {
+ try (BufferedInputStream bins = new BufferedInputStream(ins)){
+ byte[] contentByte = new byte[ins.available()];
+ int num = bins.read(contentByte);
- if(num > 0) {
- fileContent = new String(contentByte);
- }
- if(fileContent != null) {
- jsonObject = JSONObject.fromObject(fileContent).getJSONObject("vnfdIds");
+ if(num > 0) {
+ fileContent = new String(contentByte);
+ }
+ if(fileContent != null) {
+ jsonObject = JSONObject.fromObject(fileContent).getJSONObject("vnfdIds");
+ }
}
- ins.close();
- bins.close();
} catch(Exception e) {
LOG.error(fileName + " read error!", e);
- } finally {
-
}
-
return jsonObject;
}
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapter2DriverMgrService.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapter2DriverMgrService.java
index fb5e5b81..b3ba1760 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapter2DriverMgrService.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapter2DriverMgrService.java
@@ -40,7 +40,7 @@ import net.sf.json.JSONObject;
* <br>
* <p>
* </p>
- *
+ *
* @author
* @version VFC 1.0 Jan 23, 2017
*/
@@ -77,38 +77,33 @@ public class VnfmAdapter2DriverMgrService implements IVnfmAdapter2DriverMgrServi
/**
* Retrieve VIM driver information.
- *
+ *
* @return
* @throws IOException
*/
public static String readVnfmAdapterInfoFromJson() throws IOException {
- InputStream ins = null;
- BufferedInputStream bins = null;
- String fileContent = "";
-
String fileName = SystemEnvVariablesFactory.getInstance().getAppRoot()
+ System.getProperty(Constant.FILE_SEPARATOR) + "etc" + System.getProperty(Constant.FILE_SEPARATOR)
+ "adapterInfo" + System.getProperty(Constant.FILE_SEPARATOR) + VNFMADAPTER2DRIVERMGR;
- try {
- ins = new FileInputStream(fileName);
- bins = new BufferedInputStream(ins);
+ return readJson(fileName);
+ }
+
+ public static String readJson(String fileName) throws IOException {
+ String fileContent = "";
+
+ try (InputStream ins = new FileInputStream(fileName)){
+ try(BufferedInputStream bins = new BufferedInputStream(ins)){
- byte[] contentByte = new byte[ins.available()];
- int num = bins.read(contentByte);
+ byte[] contentByte = new byte[ins.available()];
+ int num = bins.read(contentByte);
- if(num > 0) {
- fileContent = new String(contentByte);
+ if(num > 0) {
+ fileContent = new String(contentByte);
+ }
}
} catch(FileNotFoundException e) {
LOG.error(fileName + "is not found!", e);
- } finally {
- if(ins != null) {
- ins.close();
- }
- if(bins != null) {
- bins.close();
- }
}
return fileContent;
@@ -116,9 +111,6 @@ public class VnfmAdapter2DriverMgrService implements IVnfmAdapter2DriverMgrServi
private static class RegisterVnfm2DriverMgrThread implements Runnable {
- // Thread lock Object
- private final Object lockObject = new Object();
-
private IVnfmAdapter2DriverManager adapter2DriverMgr = new VnfmAdapter2DriverManager();
// url and mothedtype
@@ -162,11 +154,11 @@ public class VnfmAdapter2DriverMgrService implements IVnfmAdapter2DriverMgrServi
// if registration fails,wait one minute and try again
try {
- synchronized(lockObject) {
- lockObject.wait(Constant.REPEAT_REG_TIME);
- }
+ Thread.sleep(Constant.REPEAT_REG_TIME);
} catch(InterruptedException e) {
LOG.error(e.getMessage(), e);
+ // Restore interrupted state...
+ Thread.currentThread().interrupt();
}
sendRequest(this.paramsMap, this.adapterInfo);
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapterMgrService.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapterMgrService.java
index 3afdafeb..8df2c796 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapterMgrService.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/api/internalsvc/impl/VnfmAdapterMgrService.java
@@ -76,47 +76,41 @@ public class VnfmAdapterMgrService implements IVnfmAdapterMgrService {
/**
* Retrieve VIM driver information.
- *
+ *
* @return
* @throws IOException
*/
public String readVnfmAdapterInfoFromJson() throws IOException {
- InputStream ins = null;
- BufferedInputStream bins = null;
- String fileContent = "";
-
String fileName = SystemEnvVariablesFactory.getInstance().getAppRoot()
+ System.getProperty(Constant.FILE_SEPARATOR) + "etc" + System.getProperty(Constant.FILE_SEPARATOR)
+ "adapterInfo" + System.getProperty(Constant.FILE_SEPARATOR) + VNFMADAPTERINFO;
- try {
- ins = new FileInputStream(fileName);
- bins = new BufferedInputStream(ins);
- byte[] contentByte = new byte[ins.available()];
- int num = bins.read(contentByte);
+ return readJson(fileName);
+ }
+
+ public static String readJson(String fileName) throws IOException {
+ String fileContent = "";
+
+ try (InputStream ins = new FileInputStream(fileName)){
+ try(BufferedInputStream bins = new BufferedInputStream(ins)){
- if(num > 0) {
- fileContent = new String(contentByte);
+ byte[] contentByte = new byte[ins.available()];
+ int num = bins.read(contentByte);
+
+ if(num > 0) {
+ fileContent = new String(contentByte);
+ }
}
} catch(FileNotFoundException e) {
LOG.error(fileName + "is not found!", e);
- } finally {
- if(ins != null) {
- ins.close();
- }
- if(bins != null) {
- bins.close();
- }
}
return fileContent;
}
- private static class RegisterVnfmAdapterThread implements Runnable {
- // Thread lock Object
- private final Object lockObject = new Object();
+ private static class RegisterVnfmAdapterThread implements Runnable {
private IDriver2MSBManager adapter2MSBMgr = new Driver2MSBManager();
@@ -161,11 +155,11 @@ public class VnfmAdapterMgrService implements IVnfmAdapterMgrService {
// if registration fails,wait one minute and try again
try {
- synchronized(lockObject) {
- lockObject.wait(Constant.REPEAT_REG_TIME);
- }
+ Thread.sleep(Constant.REPEAT_REG_TIME);
} catch(InterruptedException e) {
LOG.error(e.getMessage(), e);
+ // Restore interrupted state...
+ Thread.currentThread().interrupt();
}
sendRequest(this.paramsMap, this.adapterInfo);
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/Constant.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/Constant.java
index 3b1036e2..d26f849d 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/Constant.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/Constant.java
@@ -152,11 +152,11 @@ public class Constant {
public static final String FILE_SEPARATOR = "file.separator";
- public static final String PASSWORD = "password";
+ public static final String PASSWORD = "password"; // NOSONAR
public static final String USERNAME = "userName";
- public static final String LOCAL_HOST = "127.0.0.1";
+ public static final String LOCAL_HOST = "127.0.0.1"; // NOSONAR
private Constant() {
// private constructor
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/UrlConstant.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/UrlConstant.java
index 72ebb267..782163c7 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/UrlConstant.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/UrlConstant.java
@@ -42,6 +42,8 @@ public class UrlConstant {
public static final String URL_VNFDPLANINFO_GET = "/v2/vapps/templates/%s/plans";
+ public static final String URL_JOBSTATUS_GET = "/v2/vapps/jobs/%s";
+
public static final String PORT_COMMON = "31943";
public static final String PORT_UPLOADVNFPKG = "30001";
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/connect/AbstractSslContext.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/connect/AbstractSslContext.java
index 61c1f8fa..bccf4815 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/connect/AbstractSslContext.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/connect/AbstractSslContext.java
@@ -82,7 +82,7 @@ public class AbstractSslContext {
KeyManager[] kms = null;
try {
String CERT_STORE = "etc/conf/server.p12";
- String CERT_STORE_PASSWORD = "Changeme_123";
+ String CERT_STORE_PASSWORD = "Changeme_123"; // NOSONAR
String KEY_STORE_TYPE = "PKCS12";
if(sslConf != null) {
CERT_STORE = sslConf.getString("keyStore");
@@ -90,17 +90,17 @@ public class AbstractSslContext {
KEY_STORE_TYPE = sslConf.getString("keyStoreType");
}
// load jks file
- FileInputStream f_certStore = new FileInputStream(CERT_STORE);
- KeyStore ks = KeyStore.getInstance(KEY_STORE_TYPE);
- ks.load(f_certStore, CERT_STORE_PASSWORD.toCharArray());
- f_certStore.close();
+ try(FileInputStream f_certStore = new FileInputStream(CERT_STORE)) {
+ KeyStore ks = KeyStore.getInstance(KEY_STORE_TYPE);
+ ks.load(f_certStore, CERT_STORE_PASSWORD.toCharArray());
- // init and create
- String alg = KeyManagerFactory.getDefaultAlgorithm();
- KeyManagerFactory kmFact = KeyManagerFactory.getInstance(alg);
- kmFact.init(ks, CERT_STORE_PASSWORD.toCharArray());
+ // init and create
+ String alg = KeyManagerFactory.getDefaultAlgorithm();
+ KeyManagerFactory kmFact = KeyManagerFactory.getInstance(alg);
+ kmFact.init(ks, CERT_STORE_PASSWORD.toCharArray());
- kms = kmFact.getKeyManagers();
+ kms = kmFact.getKeyManagers();
+ }
} catch(Exception e) {
LOG.error("create KeyManager fail!", e);
}
@@ -112,23 +112,22 @@ public class AbstractSslContext {
try {
String TRUST_STORE = "etc/conf/trust.jks";
- String TRUST_STORE_PASSWORD = "Changeme_123";
+ String TRUST_STORE_PASSWORD = "Changeme_123"; // NOSONAR
String TRUST_STORE_TYPE = "jks";
if(sslConf != null) {
TRUST_STORE = sslConf.getString("trustStore");
TRUST_STORE_PASSWORD = sslConf.getString("trustStorePass");
TRUST_STORE_TYPE = sslConf.getString("trustStoreType");
}
- FileInputStream f_trustStore = new FileInputStream(TRUST_STORE);
- KeyStore ks = KeyStore.getInstance(TRUST_STORE_TYPE);
- ks.load(f_trustStore, TRUST_STORE_PASSWORD.toCharArray());
- f_trustStore.close();
-
- String alg = TrustManagerFactory.getDefaultAlgorithm();
- TrustManagerFactory tmFact = TrustManagerFactory.getInstance(alg);
- tmFact.init(ks);
- tms = tmFact.getTrustManagers();
-
+ try(FileInputStream f_trustStore = new FileInputStream(TRUST_STORE)) {
+ KeyStore ks = KeyStore.getInstance(TRUST_STORE_TYPE);
+ ks.load(f_trustStore, TRUST_STORE_PASSWORD.toCharArray());
+
+ String alg = TrustManagerFactory.getDefaultAlgorithm();
+ TrustManagerFactory tmFact = TrustManagerFactory.getInstance(alg);
+ tmFact.init(ks);
+ tms = tmFact.getTrustManagers();
+ }
} catch(Exception e) {
LOG.error("create TrustManager fail!", e);
}
@@ -137,43 +136,35 @@ public class AbstractSslContext {
/**
* readSSLConfToJson
- *
+ *
* @return
* @throws IOException
* @since VFC 1.0
*/
public static JSONObject readSSLConfToJson() throws IOException {
JSONObject sslJson = null;
- InputStream ins = null;
- BufferedInputStream bins = null;
+
String fileContent = "";
String fileName = SystemEnvVariablesFactory.getInstance().getAppRoot()
+ System.getProperty(Constant.FILE_SEPARATOR) + "etc" + System.getProperty(Constant.FILE_SEPARATOR)
+ "conf" + System.getProperty(Constant.FILE_SEPARATOR) + "sslconf.json";
- try {
- ins = new FileInputStream(fileName);
- bins = new BufferedInputStream(ins);
+ try (InputStream ins = new FileInputStream(fileName)) {
+ try(BufferedInputStream bins = new BufferedInputStream(ins)) {
- byte[] contentByte = new byte[ins.available()];
- int num = bins.read(contentByte);
+ byte[] contentByte = new byte[ins.available()];
+ int num = bins.read(contentByte);
- if(num > 0) {
- fileContent = new String(contentByte);
+ if(num > 0) {
+ fileContent = new String(contentByte);
+ }
+ sslJson = JSONObject.fromObject(fileContent);
}
- sslJson = JSONObject.fromObject(fileContent);
} catch(FileNotFoundException e) {
LOG.error(fileName + "is not found!", e);
} catch(Exception e) {
- LOG.error("read sslconf file fail.please check if the 'sslconf.json' is exist.");
- } finally {
- if(ins != null) {
- ins.close();
- }
- if(bins != null) {
- bins.close();
- }
+ LOG.error("read sslconf file fail.please check if the 'sslconf.json' is exist.", e);
}
return sslJson;
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/vnf/VnfMgrVnfm.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/vnf/VnfMgrVnfm.java
index d1508ba0..fae1e98d 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/vnf/VnfMgrVnfm.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/csm/vnf/VnfMgrVnfm.java
@@ -19,6 +19,7 @@ package org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.csm.vnf;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.ResultRequestUtil;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.Constant;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.ParamConstants;
+import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.UrlConstant;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.csm.inf.InterfaceVnfMgr;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@@ -265,4 +266,27 @@ public class VnfMgrVnfm implements InterfaceVnfMgr {
return restJson;
}
+
+ public JSONObject getJobFromVnfm(JSONObject vnfmObjcet, String jobId) {
+ LOG.warn("function=getJobFromVnfm, jobId: {}", jobId);
+ JSONObject restJson = new JSONObject();
+ restJson.put(Constant.RETCODE, Constant.REST_FAIL);
+
+ JSONObject queryResult = ResultRequestUtil.call(vnfmObjcet, String.format(UrlConstant.URL_JOBSTATUS_GET, jobId),
+ Constant.GET, null, Constant.CERTIFICATE);
+
+ int statusCode = queryResult.getInt(Constant.RETCODE);
+ if(statusCode == Constant.HTTP_OK || statusCode == Constant.HTTP_CREATED) {
+ if((queryResult.get("data")) == null) {
+ LOG.warn("function=getJobFromVnfm, msg=query is null {}", queryResult.get("data"));
+ return restJson;
+ }
+ restJson.put(Constant.RETCODE, Constant.REST_SUCCESS);
+ restJson.put("data", JSONObject.fromObject(queryResult.getString("data")));
+ } else {
+ LOG.error("function=getJobFromVnfm, msg=query job from vnfm wrong status: {}", statusCode);
+ }
+
+ return restJson;
+ }
}
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/AuthMgr.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/AuthMgr.java
index d0a06a25..1a93f281 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/AuthMgr.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/AuthMgr.java
@@ -47,7 +47,6 @@ public class AuthMgr {
restJson.put(Constant.RETCODE, Constant.REST_FAIL);
try {
String userName = params.getString(Constant.USERNAME);
-
restJson = getStatusResult(userName);
} catch(JSONException e) {
LOG.error("function=login, msg=Params error occurs, e={}.", e);
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfMgr.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfMgr.java
index 9e58d6bb..a4f0a697 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfMgr.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfMgr.java
@@ -319,4 +319,31 @@ public class VnfMgr {
restJson = (new VnfMgrVnfm()).healVnf(jsonObject, vnfmObjcet, vnfmId, vnfInstanceId);
return restJson;
}
+
+ public JSONObject getJobFromVnfm(String jobId, String vnfmId) {
+ LOG.warn("function=getJobFromVnfm, jobId:{}, vnfmId:{}", jobId, vnfmId);
+ JSONObject restJson = new JSONObject();
+ JSONObject vnfmObjcet = VnfmUtil.getVnfmById(vnfmId);
+ if(vnfmObjcet.isNullObject()) {
+ LOG.error("function=getJobFromVnfm, msg=vnfm not exists, vnfmId: {}", vnfmId);
+ return restJson;
+ }
+ restJson = (new VnfMgrVnfm()).getJobFromVnfm(vnfmObjcet, jobId);
+ return restJson;
+ }
+
+ public String transferToLcm(JSONObject restJson) {
+ LOG.warn("function=transferToLcm, restJson: {}", restJson);
+ JSONObject responseJson = new JSONObject();
+ JSONObject jobInfoJson = new JSONObject();
+ JSONObject jobInfo = restJson.getJSONObject("data").getJSONObject("job_info");
+ jobInfoJson.put("jobId", jobInfo.getString("job_id"));
+ responseJson.put("progress", jobInfo.getString("task_progress_rate"));
+ responseJson.put("status", jobInfo.getString("task_status"));
+ responseJson.put("errorCode", jobInfo.getString("error_code"));
+ responseJson.put("responseId", jobInfo.getString("task_progress_rate"));
+ jobInfoJson.put("responsedescriptor", responseJson);
+ LOG.warn("function=getJobBody, jobInfoJson: {}", jobInfoJson);
+ return jobInfoJson.toString();
+ }
}
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfResourceMgr.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfResourceMgr.java
index f31d5a5d..858df17d 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfResourceMgr.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/process/VnfResourceMgr.java
@@ -110,7 +110,7 @@ public class VnfResourceMgr {
RestfulResponse rsp = VnfmRestfulUtil.getRemoteResponse(ParamConstants.GRANT_RES_URL, VnfmRestfulUtil.TYPE_PUT,
grantParam.toString());
if(rsp == null || rsp.getStatus() != Constant.HTTP_OK) {
- return null;
+ return new JSONObject();
}
LOG.error("funtion=sendGrantToResmgr, status={}", rsp.getStatus());
return JSONObject.fromObject(rsp.getResponseContent());
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/AuthRoa.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/AuthRoa.java
index 34943770..f90126c8 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/AuthRoa.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/AuthRoa.java
@@ -43,6 +43,9 @@ import net.sf.json.JSONObject;
* Provide interfaces for authInfo
* <br/>
* <p>
+ * auth tokens interface is provided by platform
+ * not in nfvo for vnfm
+ * differences from other interface
* </p>
*
* @author
@@ -88,16 +91,13 @@ public class AuthRoa {
LOG.warn("authResult: {}", authResult);
if(authResult.getInt(Constant.RETCODE) == Constant.REST_SUCCESS) {
JSONObject data = authResult.getJSONObject("data");
-
resp.setStatus(Constant.HTTP_OK);
return data.toString();
} else if(authResult.getInt(Constant.RETCODE) == Constant.HTTP_INNERERROR) {
Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(authResult.getString("data")).build();
-
return String.format(ParamConstants.GET_TOKEN_FAIL_RESP, authResult.getString("data"));
} else {
Response.status(Response.Status.UNAUTHORIZED).entity(authResult.getString("data")).build();
-
return String.format(ParamConstants.GET_TOKEN_FAIL_RESP, authResult.getString("data"));
}
}
@@ -106,7 +106,6 @@ public class AuthRoa {
* Provide interface for delete authInfo
* <br/>
*
- * @param context
* @param userName
* @param roarand
* @return
@@ -129,7 +128,6 @@ public class AuthRoa {
* Provide interface for handshake authInfo
* <br/>
*
- * @param context
* @param roattr
* @return
* @since VFC 1.0
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/SwaggerRoa.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/SwaggerRoa.java
index 27a5ae3e..f0934c91 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/SwaggerRoa.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/SwaggerRoa.java
@@ -38,7 +38,6 @@ public class SwaggerRoa {
/**
* API doc.
*
- * @param filename
* @return
* @throws IOException
*/
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfAdapterResourceRoa.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfAdapterResourceRoa.java
index fe9f9530..6ad35f6a 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfAdapterResourceRoa.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfAdapterResourceRoa.java
@@ -46,7 +46,6 @@ public class VnfAdapterResourceRoa {
* Provide function of grant resource.
* <br/>
*
- * @param context
* @return
* @since VFC 1.0
*/
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java
index f40f741d..ad963e75 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java
@@ -36,7 +36,6 @@ import org.apache.commons.lang3.StringUtils;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.ResultRequestUtil;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.VnfmJsonUtil;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.VnfmUtil;
-import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.restclient.ServiceException;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.Constant;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.VnfMgr;
import org.slf4j.Logger;
@@ -87,28 +86,27 @@ public class VnfRoa {
/**
* Scale VNF
- *
+ *
+ * @param vnfmId
+ * @param vnfInstanceId
+ * @param resp
* @param context
- * * {
+ * {
* "vnfInstanceId":"5",
* "type":"SCALE_OUT",
* "aspectId":"101",
* "numberOfSteps":"1",
* "additionalParam":{}
* }
- * @param resp
- * @param vnfmId
* @return
* {
* "jobId":"1"
* }
- * @throws ServiceException
*/
@POST
@Path("/{vnfmId}/vnfs/{vnfInstanceId}/scale")
public String scaleVnf(@Context HttpServletRequest context, @Context HttpServletResponse resp,
- @PathParam("vnfmId") String vnfmId, @PathParam("vnfInstanceId") String vnfInstanceId)
- throws ServiceException {
+ @PathParam("vnfmId") String vnfmId, @PathParam("vnfInstanceId") String vnfInstanceId) {
JSONObject jsonObject = VnfmJsonUtil.getJsonFromContexts(context);
LOG.info("function=scaleVNF, msg=enter to scale a vnf. request body:" + jsonObject);
JSONObject result = new JSONObject();
@@ -138,13 +136,12 @@ public class VnfRoa {
* @param resp
* @param vnfmId
* @return
- * @throws ServiceException
* @since VFC 1.0
*/
@POST
@Path("/{vnfmId}/vnfs")
public String addVnf(@Context HttpServletRequest context, @Context HttpServletResponse resp,
- @PathParam("vnfmId") String vnfmId) throws ServiceException {
+ @PathParam("vnfmId") String vnfmId) {
LOG.warn("function=addVnf, msg=enter to add a vnf");
JSONObject subJsonObject = VnfmJsonUtil.getJsonFromContexts(context);
JSONObject restJson = new JSONObject();
@@ -175,14 +172,12 @@ public class VnfRoa {
* @param vnfInstanceId
* @param context
* @return
- * @throws ServiceException
* @since VFC 1.0
*/
@POST
@Path("/{vnfmId}/vnfs/{vnfInstanceId}/terminate")
public String delVnf(@PathParam("vnfmId") String vnfmId, @Context HttpServletResponse resp,
- @PathParam("vnfInstanceId") String vnfInstanceId, @Context HttpServletRequest context)
- throws ServiceException {
+ @PathParam("vnfInstanceId") String vnfInstanceId, @Context HttpServletRequest context) {
LOG.warn("function=delVnf, msg=enter to delete a vnf: vnfInstanceId: {}, vnfmId: {}", vnfInstanceId, vnfmId);
JSONObject vnfObject = VnfmJsonUtil.getJsonFromContexts(context);
JSONObject restJson = new JSONObject();
@@ -211,13 +206,12 @@ public class VnfRoa {
* @param vnfInstanceId
* @param context
* @return
- * @throws ServiceException
* @since VFC 1.0
*/
@GET
@Path("/{vnfmId}/vnfs/{vnfInstanceId}")
public String getVnf(@PathParam("vnfmId") String vnfmId, @Context HttpServletResponse resp,
- @PathParam("vnfInstanceId") String vnfInstanceId) throws ServiceException {
+ @PathParam("vnfInstanceId") String vnfInstanceId) {
LOG.warn("function=getVnf, msg=enter to get a vnf: vnfInstanceId: {}, vnfmId: {}", vnfInstanceId, vnfmId);
JSONObject restJson = new JSONObject();
@@ -243,13 +237,11 @@ public class VnfRoa {
* @param vnfmId
* @param resp
* @return
- * @throws ServiceException
* @since VFC 1.0
*/
@GET
@Path("/{vnfmId}")
- public String getVnfmById(@PathParam("vnfmId") String vnfmId, @Context HttpServletResponse resp)
- throws ServiceException {
+ public String getVnfmById(@PathParam("vnfmId") String vnfmId, @Context HttpServletResponse resp) {
LOG.warn("function=getVnfmById, vnfmId: {}", vnfmId);
return VnfmUtil.getVnfmById(vnfmId).toString();
}
@@ -263,13 +255,12 @@ public class VnfRoa {
* @param resp
* @param responseId
* @return
- * @throws ServiceException
* @since VFC 1.0
*/
@GET
@Path("/{vnfmId}/jobs/{jobId}")
public String getJob(@PathParam("jobId") String jobId, @PathParam("vnfmId") String vnfmId,
- @Context HttpServletResponse resp, @QueryParam("@responseId") String responseId) throws ServiceException {
+ @Context HttpServletResponse resp, @QueryParam("@responseId") String responseId) {
LOG.warn("function=getJob, msg=enter to get a job: jobId: {}, responseId: {}", jobId, responseId);
JSONObject restJson = new JSONObject();
@@ -290,28 +281,26 @@ public class VnfRoa {
/**
* <br>
- *
+ *
* @param context
* {
- * �action�: �vmReset�,
- * �affectedvm�: {
- * �vmid�: �804cca71 - 9ae9 - 4511 - 8e30 - d1387718caff�,
- * �vduid�: �vdu_100�,
- * �vmname�: �ZTE_SSS_111_PP_2_L�
+ * "action": "vmReset",
+ * "affectedvm": {
+ * "vmid": "804cca71 - 9ae9 - 4511 - 8e30 - d1387718caff",
+ * "vduid": "vdu_100",
+ * "vmname": "ZTE_SSS_111_PP_2_L"
* }
* }
* @param resp
* @param vnfmId
* @param vnfInstanceId
* @return
- * @throws ServiceException
* @since VFC 1.0
*/
@POST
@Path("/{vnfmId}/vnfs/{vnfInstanceId}/heal")
public String healVnf(@Context HttpServletRequest context, @Context HttpServletResponse resp,
- @PathParam("vnfmId") String vnfmId, @PathParam("vnfInstanceId") String vnfInstanceId)
- throws ServiceException {
+ @PathParam("vnfmId") String vnfmId, @PathParam("vnfInstanceId") String vnfInstanceId) {
LOG.warn("function=healVnf, msg=enter to heal a vnf: vnfInstanceId: {}, vnfmId: {}", vnfInstanceId, vnfmId);
JSONObject restJson = new JSONObject();
JSONObject jsonObject = VnfmJsonUtil.getJsonFromContexts(context);
@@ -355,10 +344,17 @@ public class VnfRoa {
return jobInfoJson.toString();
}
+ /**
+ * <br>
+ * Query vms info from vnfm
+ *
+ * @param vnfmId
+ * @param resp
+ * @return
+ */
@GET
@Path("/{vnfmId}/vms")
- public String getVms(@PathParam("vnfmId") String vnfmId, @Context HttpServletResponse resp)
- throws ServiceException {
+ public String getVms(@PathParam("vnfmId") String vnfmId, @Context HttpServletResponse resp) {
LOG.info("function=getVms, msg=enter to get vms: vnfmId: {}", vnfmId);
JSONObject restJson = new JSONObject();
JSONObject vnfmObjcet = VnfmUtil.getVnfmById(vnfmId);
@@ -372,4 +368,28 @@ public class VnfRoa {
LOG.info("function=getVms, restJson: {}", restJson);
return restJson.getString("data");
}
+
+ /**
+ * <br>
+ * Query job status from vnfm version 18.1
+ *
+ * @param jobId
+ * @param vnfmId
+ * @param responseId
+ * @return
+ * @since VFC 1.0
+ */
+ public String getJobFromVnfm(@PathParam("jobId") String jobId, @PathParam("vnfmId") String vnfmId,
+ @Context HttpServletResponse resp, @QueryParam("@responseId") String responseId) {
+ LOG.warn("function=getJobFromVnfm, msg=enter to get a job: jobId: {}, responseId: {}", jobId, responseId);
+ JSONObject restJson = vnfMgr.getJobFromVnfm(jobId, vnfmId);
+
+ if(restJson.getInt(Constant.RETCODE) == Constant.REST_FAIL) {
+ LOG.error("function=getJobFromVnfm, msg=getJobFromVnfm fail");
+ resp.setStatus(Constant.HTTP_INNERERROR);
+ return restJson.toString();
+ }
+
+ return vnfMgr.transferToLcm(restJson);
+ }
}
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/resources/spring/Vnfmadapter/services.xml b/huawei/vnfmadapter/VnfmadapterService/service/src/main/resources/spring/Vnfmadapter/services.xml
index 58240744..e14a37f4 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/resources/spring/Vnfmadapter/services.xml
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/resources/spring/Vnfmadapter/services.xml
@@ -16,11 +16,12 @@
-->
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:osgi="http://www.springframework.org/schema/osgi" xmlns:osgix="http://www.springframework.org/schema/osgi-compendium"
- xmlns:ctx="http://www.springframework.org/schema/context"
- xmlns:jaxrs="http://cxf.apache.org/jaxrs"
- xmlns:http-conf="http://cxf.apache.org/transports/http/configuration"
- xsi:schemaLocation="
+ xmlns:osgi="http://www.springframework.org/schema/osgi"
+ xmlns:osgix="http://www.springframework.org/schema/osgi-compendium"
+ xmlns:ctx="http://www.springframework.org/schema/context"
+ xmlns:jaxrs="http://cxf.apache.org/jaxrs"
+ xmlns:http-conf="http://cxf.apache.org/transports/http/configuration"
+ xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/osgi
@@ -37,35 +38,38 @@
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">
<!-- these are included in the dependency jar -->
- <import resource="classpath:META-INF/cxf/cxf.xml" />
+ <import resource="classpath:META-INF/cxf/cxf.xml"/>
<import resource="classpath:META-INF/cxf/cxf-servlet.xml"/>
- <bean id="jsonProvider" class="org.codehaus.jackson.jaxrs.JacksonJsonProvider" />
+ <bean id="jsonProvider" class="org.codehaus.jackson.jaxrs.JacksonJsonProvider"/>
- <bean id="source" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
- <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
- <property name="url" value="jdbc:mysql://localhost:3306/vnfmdb" />
+ <bean id="source" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
+ <!-- <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
+ <property name="url" value="jdbc:mysql://localhost:3306/vnfmdb"/>
+ Change mysql-connector to mariadb -->
+ <property name="driverClassName" value="org.mariadb.jdbc.Driver"/>
+ <property name="url" value="jdbc:mariadb://localhost:3306/vnfmdb"/>
<property name="username" value="root"/>
<property name="password" value="rootpass"/>
</bean>
- <bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
- <property name="dataSource" ref="source" />
- <property name="mapperLocations" value="classpath*:mybatis/mysql/*.xml" />
+ <bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
+ <property name="dataSource" ref="source"/>
+ <property name="mapperLocations" value="classpath*:mybatis/mysql/*.xml"/>
<!-- <property name="configLocation" value="classpath:mybatis-config.xml" /> -->
</bean>
<bean id="session" class="org.mybatis.spring.SqlSessionTemplate">
- <constructor-arg index="0" ref="sessionFactory" />
+ <constructor-arg index="0" ref="sessionFactory"/>
</bean>
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="source" />
+ <property name="dataSource" ref="source"/>
</bean>
<bean id="vnfmDao"
- class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.dao.impl.VnfmDaoImpl">
+ class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.dao.impl.VnfmDaoImpl">
<property name="session" ref="session"></property>
</bean>
@@ -78,14 +82,14 @@
</bean>
<bean id="vnfResourceMgr"
- class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.VnfResourceMgr">
+ class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.VnfResourceMgr">
</bean>
<bean id="VnfResourceRoa" class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.rest.VnfResourceRoa">
<property name="vnfResourceMgr" ref="vnfResourceMgr"></property>
</bean>
- <bean id="authMgr" class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.AuthMgr" />
+ <bean id="authMgr" class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.AuthMgr"/>
<bean id="AuthRoa" class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.rest.AuthRoa">
<property name="authMgr" ref="authMgr"></property>
@@ -102,16 +106,16 @@
<jaxrs:server id="restContainer" address="/">
<jaxrs:serviceBeans>
- <ref bean="AuthRoa" />
- <ref bean="VnfResourceRoa" />
- <ref bean="VnfRoa" />
- <ref bean="VnfAdaResRoa" />
- <ref bean="SwaggerRoa" />
+ <ref bean="AuthRoa"/>
+ <ref bean="VnfResourceRoa"/>
+ <ref bean="VnfRoa"/>
+ <ref bean="VnfAdaResRoa"/>
+ <ref bean="SwaggerRoa"/>
</jaxrs:serviceBeans>
<jaxrs:providers>
- <ref bean="jsonProvider" />
- <bean class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.rest.exceptionmapper.ServiceExceptionMapper" />
- <bean class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.rest.exceptionmapper.GenericExceptionMapper" />
+ <ref bean="jsonProvider"/>
+ <bean class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.rest.exceptionmapper.ServiceExceptionMapper"/>
+ <bean class="org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.rest.exceptionmapper.GenericExceptionMapper"/>
</jaxrs:providers>
</jaxrs:server>
</beans>
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/ResultRequestUtilTest.java b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/ResultRequestUtilTest.java
index 0dc6751b..3e93f2c2 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/ResultRequestUtilTest.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/ResultRequestUtilTest.java
@@ -16,10 +16,9 @@
package org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common;
-import static org.junit.Assert.*;
+import static org.junit.Assert.assertTrue;
import org.junit.Test;
-import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.ResultRequestUtil;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.csm.connect.ConnectMgrVnfm;
import mockit.Mock;
@@ -29,14 +28,15 @@ import net.sf.json.JSONObject;
public class ResultRequestUtilTest {
@Test
- public void callTestInternalError(){
- new MockUp<ConnectMgrVnfm>(){
+ public void callTestInternalError() {
+ new MockUp<ConnectMgrVnfm>() {
+
@Mock
public int connect(JSONObject vnfmObj) {
return 500;
}
};
- JSONObject vnfmObject = new JSONObject();;
+ JSONObject vnfmObject = new JSONObject();
String path = "http://localhost:8080";
String methodName = "get";
String paramsJson = "";
@@ -45,8 +45,9 @@ public class ResultRequestUtilTest {
}
@Test
- public void callTestConnectionErrot(){
- new MockUp<ConnectMgrVnfm>(){
+ public void callTestConnectionErrot() {
+ new MockUp<ConnectMgrVnfm>() {
+
@Mock
public int connect(JSONObject vnfmObj) {
return 200;
@@ -61,4 +62,34 @@ public class ResultRequestUtilTest {
assertTrue(resp.get("data").equals("get connection error"));
}
+ @Test
+ public void callTest() {
+ new MockUp<ConnectMgrVnfm>() {
+
+ @Mock
+ public int connect(JSONObject vnfmObj) {
+ return 200;
+ }
+
+ @Mock
+ public String getRoaRand() {
+ return "1234";
+ }
+
+ @Mock
+ public String getAccessSession() {
+ return "1234";
+ }
+
+ };
+
+ JSONObject vnfmObject = new JSONObject();
+ vnfmObject.put("url", "/test/123");
+ String path = "https://localhost:8080/%s";
+ String methodName = "get";
+ String paramsJson = "";
+ JSONObject resp = ResultRequestUtil.call(vnfmObject, path, methodName, paramsJson);
+ assertTrue(resp.get("data").equals("get connection error"));
+ }
+
}
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapter2DriverMgrServiceTest.java b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapter2DriverMgrServiceTest.java
index 12910c8e..d61c3b1c 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapter2DriverMgrServiceTest.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapter2DriverMgrServiceTest.java
@@ -16,12 +16,15 @@
package org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.ai.internalsvc.impl;
-import mockit.Mock;
-import mockit.MockUp;
+import java.io.File;
+import java.io.IOException;
+
import org.junit.Test;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.api.internalsvc.impl.VnfmAdapter2DriverMgrService;
-import java.io.IOException;
+import junit.framework.Assert;
+import mockit.Mock;
+import mockit.MockUp;
/**
* Created by QuanZhong on 2017/3/20.
@@ -48,4 +51,17 @@ public class VnfmAdapter2DriverMgrServiceTest {
mgr.register();
mgr.unregister();
}
+
+ @Test
+ public void testReadJson() {
+ File file = new File("./demo.json");
+ try {
+ file.createNewFile();
+ String content = VnfmAdapter2DriverMgrService.readJson("./demo.json");
+ Assert.assertEquals(content, "");
+ file.delete();
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ }
}
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapterMgrServiceTest.java b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapterMgrServiceTest.java
index 84a7c914..56e1eea3 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapterMgrServiceTest.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/ai/internalsvc/impl/VnfmAdapterMgrServiceTest.java
@@ -16,14 +16,15 @@
package org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.ai.internalsvc.impl;
-import mockit.Mock;
-import mockit.MockUp;
-import net.sf.json.JSONObject;
+import java.io.File;
+import java.io.IOException;
+
import org.junit.Test;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.api.internalsvc.impl.VnfmAdapterMgrService;
-import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.VnfMgr;
-import java.io.IOException;
+import junit.framework.Assert;
+import mockit.Mock;
+import mockit.MockUp;
/**
* Created by QuanZhong on 2017/3/20.
@@ -42,4 +43,18 @@ public class VnfmAdapterMgrServiceTest {
mgr.register();
}
+
+
+ @Test
+ public void testReadJson() {
+ File file = new File("./demo.json");
+ try {
+ file.createNewFile();
+ String content = VnfmAdapterMgrService.readJson("./demo.json");
+ Assert.assertEquals(content, "");
+ file.delete();
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ }
}
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoaTest.java b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoaTest.java
index b82c26af..8012b5cb 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoaTest.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/test/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoaTest.java
@@ -26,6 +26,7 @@ import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.VnfmJsonUtil;
+import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.VnfmUtil;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.restclient.ServiceException;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.Constant;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.VnfMgr;
@@ -577,4 +578,58 @@ public class VnfRoaTest {
}
+ @Test
+ public void testGetVnfmById() throws ServiceException {
+ new MockUp<VnfmUtil>() {
+
+ @Mock
+ public JSONObject getVnfmById(String vnfmId) {
+ JSONObject json = new JSONObject();
+ json.put("vnfm", "1234");
+ return json;
+ }
+ };
+ String result = vnfRoa.getVnfmById("1234", null);
+ assertNotNull(result);
+ }
+
+ @Test
+ public void testGetJobFromVnfm() throws ServiceException {
+ new MockUp<VnfMgr>() {
+
+ @Mock
+ public JSONObject getJobFromVnfm(String jobId, String vnfmId) {
+ JSONObject json = new JSONObject();
+ json.put("retCode", "1");
+ return json;
+ }
+
+ @Mock
+ public String transferToLcm(JSONObject restJson) {
+ return "success";
+ }
+ };
+ String result = vnfRoa.getJobFromVnfm("jobId", "vnfmId", null, "responseId");
+ assertNotNull(result);
+ }
+
+ @Test
+ public void testGetJobFromVnfmFail() throws ServiceException {
+
+ new MockUp<VnfMgr>() {
+
+ @Mock
+ public JSONObject getJobFromVnfm(String jobId, String vnfmId) {
+ JSONObject json = new JSONObject();
+ json.put("retCode", "-1");
+ return json;
+ }
+
+ };
+ MockUp<HttpServletResponse> proxyResStub = new MockUp<HttpServletResponse>() {};
+ HttpServletResponse mockResInstance = proxyResStub.getMockInstance();
+ String result = vnfRoa.getJobFromVnfm("jobId", "vnfmId", mockResInstance, "responseId");
+ assertNotNull(result);
+ }
+
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/docker/Dockerfile b/nokia/vnfmdriver/vfcadaptorservice/docker/Dockerfile
index 71b7fa32..7ed32757 100755
--- a/nokia/vnfmdriver/vfcadaptorservice/docker/Dockerfile
+++ b/nokia/vnfmdriver/vfcadaptorservice/docker/Dockerfile
@@ -31,7 +31,7 @@ COPY init-mysql.sh .
# 30-tomcat.txt - AUTOGENERATED, DO NOT MODIFY MANUALLY
# Set up tomcat
-RUN wget -q http://mirrors.ocf.berkeley.edu/apache/tomcat/tomcat-8/v8.5.27/bin/apache-tomcat-8.5.27.tar.gz && tar --strip-components=1 -xf apache-tomcat-8.5.27.tar.gz && rm -f apache-tomcat-8.5.27.tar.gz && rm -rf webapps && mkdir -p webapps/ROOT
+RUN wget -q http://mirrors.ocf.berkeley.edu/apache/tomcat/tomcat-8/v8.5.28/bin/apache-tomcat-8.5.28.tar.gz && tar --strip-components=1 -xf apache-tomcat-8.5.28.tar.gz && rm -f apache-tomcat-8.5.28.tar.gz && rm -rf webapps && mkdir -p webapps/ROOT
RUN echo 'export CATALINA_OPTS="$CATALINA_OPTS -Xms64m -Xmx256m -XX:MaxPermSize=64m"' > /service/bin/setenv.sh
ENV CATALINA_HOME /service
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/pom.xml b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/pom.xml
index 410c2e97..b7887a61 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/pom.xml
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/pom.xml
@@ -41,10 +41,12 @@
</properties>
<dependencies>
+ <!--
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
+ -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
@@ -76,32 +78,40 @@
</exclusion>
</exclusions>
</dependency>
- -->
+
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
+
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
- <groupId>org.apache.tomcat.embed</groupId>
- <artifactId>tomcat-embed-jasper</artifactId>
- <scope>provided</scope>
- </dependency>
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-test</artifactId>
- <scope>test</scope>
+ <groupId>org.apache.tomcat.embed</groupId>
+ <artifactId>tomcat-embed-jasper</artifactId>
+ <scope>provided</scope>
+ </dependency>
+ -->
+
+ <dependency>
+ <groupId>org.mariadb.jdbc</groupId>
+ <artifactId>mariadb-java-client</artifactId>
+ <version>2.2.2</version>
+ </dependency>
+ <dependency>
+ <groupId>org.springframework.boot</groupId>
+ <artifactId>spring-boot-starter-test</artifactId>
+ <scope>test</scope>
</dependency>
- <dependency>
+ <dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.5</version>
- </dependency>
+ </dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
@@ -137,6 +147,12 @@
<artifactId>zt-zip</artifactId>
<version>1.12</version>
</dependency>
+
+ <dependency>
+ <groupId>org.mybatis.spring.boot</groupId>
+ <artifactId>mybatis-spring-boot-starter</artifactId>
+ <version>1.3.1</version>
+ </dependency>
<dependency>
<groupId>ca.juliusdavies</groupId>
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/VfcadaptorApplication.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/VfcadaptorApplication.java
index c93b107b..d88b5d7e 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/VfcadaptorApplication.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/VfcadaptorApplication.java
@@ -16,6 +16,8 @@
package org.onap.vfc.nfvo.driver.vnfm.svnfm;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
@@ -28,8 +30,9 @@ import org.springframework.context.support.PropertySourcesPlaceholderConfigurer;
@ComponentScan
@SuppressWarnings(value="all")
public class VfcadaptorApplication {
+ private static final Logger logger = LoggerFactory.getLogger(VfcadaptorApplication.class);
- public final static void main(String[] args) {
+ public static void main(String[] args) {
SpringApplication.run(VfcadaptorApplication.class, args);
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/Cbam2DriverResponseConverter.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/Cbam2DriverResponseConverter.java
index 7bb18efd..c153095b 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/Cbam2DriverResponseConverter.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/Cbam2DriverResponseConverter.java
@@ -15,9 +15,6 @@
*/
package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
-import java.util.ArrayList;
-import java.util.List;
-
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryVnfResponse;
@@ -25,10 +22,12 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OperationExecution;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OperationExecution.OperationType;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.ScaleType;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.OperStatusVnfResponse;
@@ -36,15 +35,19 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.QueryVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.entity.ResponseDescriptor;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.entity.ResponseHistoryList;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
@Component
public class Cbam2DriverResponseConverter {
+ private static final Logger logger = LoggerFactory.getLogger(Cbam2DriverResponseConverter.class);
+ @Autowired
+ private VnfmJobExecutionMapper jobDbManager;
@Autowired
- private VnfmJobExecutionRepository jobDbManager;
+ private AdaptorEnv adaptorEnv;
public InstantiateVnfResponse createRspConvert(CBAMCreateVnfResponse cbamResponse, Long jobId) {
@@ -61,7 +64,8 @@ public class Cbam2DriverResponseConverter {
jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_TERMINATE);
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
- VnfmJobExecutionInfo jobInfo1 = (VnfmJobExecutionInfo) jobDbManager.save(jobInfo);
+ jobDbManager.insert(jobInfo);
+ VnfmJobExecutionInfo jobInfo1 = (VnfmJobExecutionInfo) jobDbManager.findNewestJobInfo();
Long jobId = jobInfo1.getJobId();
TerminateVnfResponse response = new TerminateVnfResponse();
response.setJobId(jobId.longValue() + "");
@@ -82,51 +86,37 @@ public class Cbam2DriverResponseConverter {
return vnf;
}
- public OperStatusVnfResponse operRspConvert(OperationExecution oper) {
-
+ public OperStatusVnfResponse operRspConvert(OperationExecution oper, String jobId) {
OperStatusVnfResponse response = new OperStatusVnfResponse();
-
ResponseDescriptor er = new ResponseDescriptor();
- if (oper.getStatus() == CommonEnum.OperationStatus.STARTED ) {
+ if (oper.getStatus() == CommonEnum.OperationStatus.STARTED) {
er.setStatusDescription("Vim is processing");
er.setStatus("started");
- int progress;
- if(OperationType.INSTANTIATE == oper.getOperationType())
- {
- progress = OperateTaskProgress.getInstantiateProgress();
- } else {
- progress = OperateTaskProgress.getTerminateProgress();
- }
-
+ int progress = calculateProgress(oper, jobId);
+
er.setProgress("" + progress);
- er.setResponseId("" + + progress);
+ er.setResponseId("" + +progress);
} else if (oper.getStatus() == CommonEnum.OperationStatus.FINISHED) {
er.setStatus("finished");
er.setProgress("100");
er.setResponseId("100");
-
- } else if (oper.getStatus() == CommonEnum.OperationStatus.OTHER) {
+
+ } else if (oper.getStatus() == CommonEnum.OperationStatus.OTHER) {
er.setStatus("processing");
er.setStatusDescription("Vim is processing");
-
- int progress;
- if(OperationType.INSTANTIATE == oper.getOperationType())
- {
- progress = OperateTaskProgress.getInstantiateProgress();
- } else {
- progress = OperateTaskProgress.getTerminateProgress();
- }
-
+
+ int progress = calculateProgress(oper, jobId);
+
er.setProgress("" + progress);
- er.setResponseId("" + + progress);
-
+ er.setResponseId("" + +progress);
+
} else {
- er.setStatus("error");
+ er.setStatus("error");
er.setStatus("finished");
er.setProgress("100");
er.setResponseId("100");
}
-
+
er.setErrorCode("null");
response.setResponseDescriptor(er);
@@ -139,9 +129,47 @@ public class Cbam2DriverResponseConverter {
return response;
}
- public ScaleVnfResponse scaleRspConvert(CBAMScaleVnfResponse cbamResponse) {
+ public ScaleVnfResponse scaleRspConvert(CBAMScaleVnfResponse cbamResponse,ScaleType type) {
+ VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
+ jobInfo.setVnfInstanceId(cbamResponse.getId());
+ if (type.equals(ScaleType.SCALE_OUT)) {
+ jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_SCALE_OUT);
+ } else {
+ jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_SCALE_IN);
+ }
+ jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
+
+ jobDbManager.insert(jobInfo);
+ VnfmJobExecutionInfo jobInfo1 = (VnfmJobExecutionInfo) jobDbManager.findNewestJobInfo();
+ Long jobId = jobInfo1.getJobId();
ScaleVnfResponse response = new ScaleVnfResponse();
- response.setJobId("1");
+
+ response.setJobId(jobId.longValue() + "");
return response;
}
+
+ public int calculateProgress(OperationExecution oper, String jobId) {
+ long nowTime = System.currentTimeMillis();
+ VnfmJobExecutionInfo jobInfo = jobDbManager.findOne(Long.parseLong(jobId));
+ int initialProgress = adaptorEnv.getInitialProgress();
+
+ if (OperationType.INSTANTIATE == oper.getOperationType()) {
+ double instantiateProgress = (nowTime - jobInfo.getOperateStartTime())
+ / adaptorEnv.getInstantiateTimeInterval();
+ initialProgress = (int) (instantiateProgress + initialProgress);
+ } else if (OperationType.TERMINATE == oper.getOperationType()) {
+ double terminateProgress = (nowTime - jobInfo.getOperateStartTime())
+ / adaptorEnv.getTerminateTimeInterval();
+ initialProgress = (int) (terminateProgress + initialProgress);
+ } else {
+ initialProgress = 0;
+ }
+ return initialProgress;
+
+ }
+
+ public void setAdaptorEnv(AdaptorEnv adaptorEnv) {
+ this.adaptorEnv = adaptorEnv;
+ }
+
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnable.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnable.java
new file mode 100644
index 00000000..9338a056
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnable.java
@@ -0,0 +1,160 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum.LifecycleOperation;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.AddResource;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.ResourceDefinition;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+
+public class HealVnfContinueRunnable implements Runnable {
+ private static final Logger logger = LoggerFactory.getLogger(HealVnfContinueRunnable.class);
+
+ @Autowired
+ private CbamMgmrInf cbamMgmr;
+ @Autowired
+ private NslcmMgmrInf nslcmMgmr;
+
+ private HealVnfRequest driverRequest;
+ private String vnfInstanceId;
+ private String jobId;
+ private String vnfmId;
+ @Autowired
+ private VnfmJobExecutionMapper jobDbMgmr;
+
+ private Driver2CbamRequestConverter requestConverter;
+
+
+ public HealVnfContinueRunnable(String vnfmId, HealVnfRequest driverRequest, String vnfInstanceId, String jobId,
+ NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper dbManager)
+ {
+ this.driverRequest = driverRequest;
+ this.vnfInstanceId = vnfInstanceId;
+ this.nslcmMgmr = nslcmMgmr;
+ this.cbamMgmr = cbamMgmr;
+ this.requestConverter = requestConverter;
+ this.jobId = jobId;
+ this.jobDbMgmr = dbManager;
+ this.vnfmId = vnfmId;
+ }
+
+ private void handleGrant(){
+ try {
+ NslcmGrantVnfRequest grantRequest = buildNslcmGrantVnfRequest();
+ nslcmMgmr.grantVnf(grantRequest);
+ } catch (Exception e) {
+ logger.error("HealVnfContinueRunnable --> handleGrant error.", e);
+ }
+ }
+
+ public void run() {
+ handleGrant();
+ handleHeal();
+ }
+
+
+
+ private CBAMHealVnfResponse handleHeal() {
+ CBAMHealVnfResponse cbamResponse = null;
+ try {
+ CBAMHealVnfRequest modifyReq = requestConverter.healReqConvert(driverRequest);
+ cbamResponse = cbamMgmr.healVnf(modifyReq, vnfInstanceId);
+ handleCbamHealResponse(cbamResponse, jobId);
+ } catch (Exception e) {
+ logger.error("HealVnfContinueRunnable --> handleHeal error.", e);
+ }
+
+ return cbamResponse;
+ }
+
+ private void handleCbamHealResponse(CBAMHealVnfResponse cbamResponse, String jobId) {
+ VnfmJobExecutionInfo jobInfo = jobDbMgmr.findOne(Long.parseLong(jobId));
+
+ jobInfo.setVnfmExecutionId(cbamResponse.getId());
+ if(CommonEnum.OperationStatus.FAILED == cbamResponse.getStatus()) {
+ jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_ERROR);
+ }
+ else {
+ jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_PROCESSING);
+ }
+ jobDbMgmr.update(jobInfo);
+ }
+
+ private NslcmGrantVnfRequest buildNslcmGrantVnfRequest() {
+ NslcmGrantVnfRequest request = new NslcmGrantVnfRequest();
+
+ request.setVnfInstanceId(vnfInstanceId);
+ request.setLifecycleOperation(LifecycleOperation.Heal);
+ request.setJobId(jobId);
+
+ ResourceDefinition resource = getFreeVnfResource();
+ List<ResourceDefinition> resourceList = new ArrayList<ResourceDefinition>();
+ resourceList.add(resource);
+ request.setRemoveResource(resourceList);
+
+ return request;
+ }
+
+ private ResourceDefinition getFreeVnfResource() {
+ ResourceDefinition def = new ResourceDefinition();
+ def.setVnfInstanceId(vnfInstanceId);
+ def.setVimId("001");
+ List<AddResource> resources = new ArrayList<>();
+ AddResource res = new AddResource();
+ res.setVdu("1");
+ res.setType("vdu");
+ res.setResourceDefinitionId(2);
+ resources.add(res);
+ def.setAddResource(resources);
+ return def;
+ }
+
+ public void setDriverRequest(HealVnfRequest driverRequest) {
+ this.driverRequest = driverRequest;
+ }
+
+ public void setVnfInstanceId(String vnfInstanceId) {
+ this.vnfInstanceId = vnfInstanceId;
+ }
+
+ public void setJobId(String jobId) {
+ this.jobId = jobId;
+ }
+
+ public void setRequestConverter(Driver2CbamRequestConverter requestConverter) {
+ this.requestConverter = requestConverter;
+ }
+
+ public void setVnfmId(String vnfmId) {
+ this.vnfmId = vnfmId;
+ }
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnable.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnable.java
index b3c8bfe1..07c15c0e 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnable.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnable.java
@@ -35,7 +35,8 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum.LifecycleOperation;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfcResourceInfoMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.http.client.HttpClientProcessorImpl;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmNotifyLCMEventsRequest;
@@ -46,14 +47,18 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
import com.google.gson.Gson;
public class InstantiateVnfContinueRunnable implements Runnable {
private static final Logger logger = LoggerFactory.getLogger(InstantiateVnfContinueRunnable.class);
+ @Autowired
private CbamMgmrInf cbamMgmr;
+ @Autowired
private CatalogMgmrInf catalogMgmr;
+ @Autowired
private NslcmMgmrInf nslcmMgmr;
private InstantiateVnfRequest driverRequest;
@@ -61,14 +66,18 @@ public class InstantiateVnfContinueRunnable implements Runnable {
private String jobId;
private String vnfmId;
- private VnfmJobExecutionRepository jobDbMgmr;
+// private VnfmJobExecutionRepository jobDbMgmr;
+ @Autowired
+ private VnfmJobExecutionMapper jobDbMgmr;
+ @Autowired
+ private VnfcResourceInfoMapper vnfcDbMgmr;
private Driver2CbamRequestConverter requestConverter;
private Gson gson = new Gson();
public InstantiateVnfContinueRunnable(String vnfmId, InstantiateVnfRequest driverRequest, String vnfInstanceId, String jobId,
- NslcmMgmrInf nslcmMgmr, CatalogMgmrInf catalogMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionRepository dbManager)
+ NslcmMgmrInf nslcmMgmr, CatalogMgmrInf catalogMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper dbManager, VnfcResourceInfoMapper vnfcDbMgmr)
{
this.driverRequest = driverRequest;
this.vnfInstanceId = vnfInstanceId;
@@ -79,6 +88,7 @@ public class InstantiateVnfContinueRunnable implements Runnable {
this.requestConverter = requestConverter;
this.jobDbMgmr = dbManager;
this.vnfmId = vnfmId;
+ this.vnfcDbMgmr = vnfcDbMgmr;
}
public void run() {
@@ -109,7 +119,6 @@ public class InstantiateVnfContinueRunnable implements Runnable {
{
instantiateFinished = true;
handleCbamInstantiateResponse(exeResponse, jobId);
- OperateTaskProgress.stopInstantiateTimerTask();
if (exeResponse.getStatus() == CommonEnum.OperationStatus.FINISHED)
{
@@ -132,7 +141,7 @@ public class InstantiateVnfContinueRunnable implements Runnable {
logger.info("Start to notify LCM the instantiation result");
NslcmNotifyLCMEventsRequest nslcmNotifyReq = buildNslcmNotifyLCMEventsRequest(vnfcResources);
- OperateTaskProgress.setAffectedVnfc(nslcmNotifyReq.getAffectedVnfc());
+// OperateTaskProgress.setAffectedVnfc(nslcmNotifyReq.getAffectedVnfc());
nslcmMgmr.notifyVnf(nslcmNotifyReq, vnfmId, vnfInstanceId);
logger.info("End to notify LCM the instantiation result");
@@ -236,6 +245,8 @@ public class InstantiateVnfContinueRunnable implements Runnable {
vnfc.setVmid(resource.getComputeResource().getResourceId());
vnfcs.add(vnfc);
+
+ vnfcDbMgmr.insert(vnfc);
}
}
return vnfcs;
@@ -274,6 +285,7 @@ public class InstantiateVnfContinueRunnable implements Runnable {
VnfmJobExecutionInfo jobInfo = jobDbMgmr.findOne(Long.parseLong(jobId));
jobInfo.setVnfmExecutionId(cbamInstantiateResponse.getId());
+ long nowTime = System.currentTimeMillis();
if(CommonEnum.OperationStatus.FAILED == cbamInstantiateResponse.getStatus()){
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_ERROR);
// jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_FINISH);
@@ -281,12 +293,34 @@ public class InstantiateVnfContinueRunnable implements Runnable {
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_PROCESSING);
} else if(CommonEnum.OperationStatus.FINISHED == cbamInstantiateResponse.getStatus()){
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_FINISH);
+ jobInfo.setOperateEndTime(nowTime);
+
}
else{
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
}
- jobDbMgmr.save(jobInfo);
+ jobDbMgmr.update(jobInfo);
+ }
+
+ public void setDriverRequest(InstantiateVnfRequest driverRequest) {
+ this.driverRequest = driverRequest;
+ }
+
+ public void setVnfInstanceId(String vnfInstanceId) {
+ this.vnfInstanceId = vnfInstanceId;
+ }
+
+ public void setJobId(String jobId) {
+ this.jobId = jobId;
+ }
+
+ public void setVnfmId(String vnfmId) {
+ this.vnfmId = vnfmId;
+ }
+
+ public void setRequestConverter(Driver2CbamRequestConverter requestConverter) {
+ this.requestConverter = requestConverter;
}
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/OperateTaskProgress.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/OperateTaskProgress.java
deleted file mode 100644
index 37e38e63..00000000
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/OperateTaskProgress.java
+++ /dev/null
@@ -1,98 +0,0 @@
-/*
- * Copyright 2016-2017, Nokia Corporation
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
-
-import java.util.List;
-import java.util.Timer;
-import java.util.TimerTask;
-import java.util.concurrent.atomic.AtomicInteger;
-
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.AffectedVnfc;
-
-public class OperateTaskProgress {
- private static AtomicInteger instantiate_progress = new AtomicInteger(10);
- private static AtomicInteger terminate_progress = new AtomicInteger(20);
-
- private static Timer instantiateTimer;
- private static Timer terminateTimer;
-
- private static List<AffectedVnfc> affectedVnfc;
-
- public static int getInstantiateProgress() {
- return instantiate_progress.intValue();
- }
-
- public static int getTerminateProgress() {
- return terminate_progress.intValue();
- }
-
- public static void incrementInstantiateProgress() {
- instantiate_progress.incrementAndGet();
- }
-
- public static void incrementTerminateProgress() {
- terminate_progress.incrementAndGet();
- }
-
- public static void startInstantiateTimerTask() {
- instantiateTimer = new Timer();
- instantiate_progress.set(10);
- instantiateTimer.schedule(new TimerTask() {
-
- @Override
- public void run() {
- if(instantiate_progress.intValue() < 96) {
- instantiate_progress.incrementAndGet();
- }
- }
-
- }, 1000, 60000);
- }
-
- public static void startTerminateTimerTask() {
- terminateTimer = new Timer();
- terminate_progress.set(20);
- terminateTimer.schedule(new TimerTask() {
-
- @Override
- public void run() {
- if(terminate_progress.intValue() < 96) {
- terminate_progress.incrementAndGet();
- }
- }
-
- }, 1000, 8000);
- }
-
- public static void stopTerminateTimerTask() {
- terminateTimer.cancel();
- terminate_progress.set(100);
- }
-
- public static void stopInstantiateTimerTask() {
- instantiateTimer.cancel();
- instantiate_progress.set(100);
- }
-
- public static List<AffectedVnfc> getAffectedVnfc() {
- return affectedVnfc;
- }
-
- public static void setAffectedVnfc(List<AffectedVnfc> affectedVnfc) {
- OperateTaskProgress.affectedVnfc = affectedVnfc;
- }
-}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnable.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnable.java
new file mode 100644
index 00000000..1f6caf83
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnable.java
@@ -0,0 +1,170 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum.LifecycleOperation;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.ScaleType;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.AddResource;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.ResourceDefinition;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfRequest;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+
+public class ScaleVnfContinueRunnable implements Runnable {
+ private static final Logger logger = LoggerFactory.getLogger(ScaleVnfContinueRunnable.class);
+
+ @Autowired
+ private CbamMgmrInf cbamMgmr;
+ @Autowired
+ private NslcmMgmrInf nslcmMgmr;
+
+ private ScaleVnfRequest driverRequest;
+ private String vnfInstanceId;
+ private String jobId;
+ private String vnfmId;
+ private ScaleType type;
+ @Autowired
+ private VnfmJobExecutionMapper jobDbMgmr;
+
+ private Driver2CbamRequestConverter requestConverter;
+
+ public ScaleVnfContinueRunnable(String vnfmId, ScaleVnfRequest driverRequest, String vnfInstanceId, String jobId,
+ NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper dbManager)
+ {
+ this.driverRequest = driverRequest;
+ this.vnfInstanceId = vnfInstanceId;
+ this.nslcmMgmr = nslcmMgmr;
+ this.cbamMgmr = cbamMgmr;
+ this.requestConverter = requestConverter;
+ this.jobId = jobId;
+ this.jobDbMgmr = dbManager;
+ this.vnfmId = vnfmId;
+ }
+
+ private void handleGrant(){
+ try {
+ NslcmGrantVnfRequest grantRequest = buildNslcmGrantVnfRequest();
+ nslcmMgmr.grantVnf(grantRequest);
+ } catch (Exception e) {
+ logger.error("ScaleVnfContinueRunnable --> handleGrant error.", e);
+ }
+ }
+
+ public void run() {
+ handleGrant();
+ handleScale();
+ }
+
+
+
+ private CBAMScaleVnfResponse handleScale() {
+ CBAMScaleVnfResponse cbamResponse = null;
+ try {
+ CBAMScaleVnfRequest scaleReq = requestConverter.scaleReqconvert(driverRequest);
+ cbamResponse = cbamMgmr.scaleVnf(scaleReq, vnfInstanceId);
+ handleCbamScaleResponse(cbamResponse, jobId);
+ } catch (Exception e) {
+ logger.error("ScaleVnfContinueRunnable --> handleScale error.", e);
+ }
+
+ return cbamResponse;
+ }
+
+ private void handleCbamScaleResponse(CBAMScaleVnfResponse cbamResponse, String jobId) {
+ VnfmJobExecutionInfo jobInfo = jobDbMgmr.findOne(Long.parseLong(jobId));
+
+ jobInfo.setVnfmExecutionId(cbamResponse.getId());
+ if(CommonEnum.OperationStatus.FAILED == cbamResponse.getStatus()) {
+ jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_ERROR);
+ }
+ else {
+ jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_PROCESSING);
+ }
+ jobDbMgmr.update(jobInfo);
+ }
+
+ private NslcmGrantVnfRequest buildNslcmGrantVnfRequest() {
+ NslcmGrantVnfRequest request = new NslcmGrantVnfRequest();
+
+ request.setVnfInstanceId(vnfInstanceId);
+ if(type.equals(ScaleType.SCALE_OUT)) {
+ request.setLifecycleOperation(LifecycleOperation.Scaleout);
+ }else {
+ request.setLifecycleOperation(LifecycleOperation.Scalein);
+ }
+ request.setJobId(jobId);
+
+ ResourceDefinition resource = getFreeVnfResource();
+ List<ResourceDefinition> resourceList = new ArrayList<ResourceDefinition>();
+ resourceList.add(resource);
+ request.setRemoveResource(resourceList);
+
+ return request;
+ }
+
+ private ResourceDefinition getFreeVnfResource() {
+ ResourceDefinition def = new ResourceDefinition();
+ def.setVnfInstanceId(vnfInstanceId);
+ def.setVimId("001");
+ List<AddResource> resources = new ArrayList<>();
+ AddResource res = new AddResource();
+ res.setVdu("1");
+ res.setType("vdu");
+ res.setResourceDefinitionId(2);
+ resources.add(res);
+ def.setAddResource(resources);
+ return def;
+ }
+
+ public void setDriverRequest(ScaleVnfRequest driverRequest) {
+ this.driverRequest = driverRequest;
+ }
+
+ public void setVnfInstanceId(String vnfInstanceId) {
+ this.vnfInstanceId = vnfInstanceId;
+ }
+
+ public void setJobId(String jobId) {
+ this.jobId = jobId;
+ }
+
+ public void setVnfmId(String vnfmId) {
+ this.vnfmId = vnfmId;
+ }
+
+ public void setType(ScaleType type) {
+ this.type = type;
+ }
+
+ public void setRequestConverter(Driver2CbamRequestConverter requestConverter) {
+ this.requestConverter = requestConverter;
+ }
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TerminateVnfContinueRunnable.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TerminateVnfContinueRunnable.java
index 13e4e3c6..e152c4b5 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TerminateVnfContinueRunnable.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TerminateVnfContinueRunnable.java
@@ -27,7 +27,8 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum.LifecycleOperation;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfcResourceInfoMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmNotifyLCMEventsRequest;
@@ -38,23 +39,29 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfRequest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
public class TerminateVnfContinueRunnable implements Runnable {
private static final Logger logger = LoggerFactory.getLogger(TerminateVnfContinueRunnable.class);
+ @Autowired
private CbamMgmrInf cbamMgmr;
+ @Autowired
private NslcmMgmrInf nslcmMgmr;
private TerminateVnfRequest driverRequest;
private String vnfInstanceId;
private String jobId;
private String vnfmId;
- private VnfmJobExecutionRepository jobDbMgmr;
+ @Autowired
+ private VnfmJobExecutionMapper jobDbMgmr;
+ @Autowired
+ private VnfcResourceInfoMapper vnfcDbMgmr;
private Driver2CbamRequestConverter requestConverter;
public TerminateVnfContinueRunnable(String vnfmId, TerminateVnfRequest driverRequest, String vnfInstanceId, String jobId,
- NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionRepository dbManager)
+ NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper dbManager, VnfcResourceInfoMapper vnfcDbMgmr)
{
this.driverRequest = driverRequest;
this.vnfInstanceId = vnfInstanceId;
@@ -64,6 +71,7 @@ public class TerminateVnfContinueRunnable implements Runnable {
this.jobId = jobId;
this.jobDbMgmr = dbManager;
this.vnfmId = vnfmId;
+ this.vnfcDbMgmr = vnfcDbMgmr;
}
private void handleGrant(){
@@ -104,11 +112,11 @@ public class TerminateVnfContinueRunnable implements Runnable {
}
private void prepareDelete(String jobId) {
- OperateTaskProgress.stopTerminateTimerTask();
-
+ long nowTime = System.currentTimeMillis();
VnfmJobExecutionInfo jobInfo = jobDbMgmr.findOne(Long.parseLong(jobId));
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_FINISH);
- jobDbMgmr.save(jobInfo);
+ jobInfo.setOperateEndTime(nowTime);
+ jobDbMgmr.update(jobInfo);
try {
NslcmNotifyLCMEventsRequest nslcmNotifyReq = buildNslcmNotifyLCMEventsRequest();
@@ -141,7 +149,7 @@ public class TerminateVnfContinueRunnable implements Runnable {
else {
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_PROCESSING);
}
- jobDbMgmr.save(jobInfo);
+ jobDbMgmr.update(jobInfo);
}
private NslcmGrantVnfRequest buildNslcmGrantVnfRequest() {
@@ -176,8 +184,8 @@ public class TerminateVnfContinueRunnable implements Runnable {
private NslcmNotifyLCMEventsRequest buildNslcmNotifyLCMEventsRequest() {
NslcmNotifyLCMEventsRequest request = new NslcmNotifyLCMEventsRequest();
request.setStatus(CommonEnum.status.result);
-
- List<AffectedVnfc> vnfcs = modifyResourceTypeAsRemove(OperateTaskProgress.getAffectedVnfc());
+ List<AffectedVnfc> vnfcsFromDb = vnfcDbMgmr.getAllByInstanceId(vnfInstanceId);
+ List<AffectedVnfc> vnfcs = modifyResourceTypeAsRemove(vnfcsFromDb);
request.setAffectedVnfc(vnfcs);
request.setVnfInstanceId(vnfInstanceId);
@@ -202,8 +210,23 @@ public class TerminateVnfContinueRunnable implements Runnable {
return vnfcs;
}
- private void handleNslcmGrantResponse(NslcmGrantVnfResponse grantResponse) {
- // TODO Auto-generated method stub
-
+ public void setDriverRequest(TerminateVnfRequest driverRequest) {
+ this.driverRequest = driverRequest;
+ }
+
+ public void setVnfInstanceId(String vnfInstanceId) {
+ this.vnfInstanceId = vnfInstanceId;
+ }
+
+ public void setJobId(String jobId) {
+ this.jobId = jobId;
+ }
+
+ public void setVnfmId(String vnfmId) {
+ this.vnfmId = vnfmId;
+ }
+
+ public void setRequestConverter(Driver2CbamRequestConverter requestConverter) {
+ this.requestConverter = requestConverter;
}
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImpl.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImpl.java
index dac64b7b..251c4638 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImpl.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImpl.java
@@ -26,19 +26,17 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.aai.inf.AaiMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.catalog.inf.CatalogMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfResponse;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryVnfResponse;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OperationExecution;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OperationExecution.OperationType;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.ScaleType;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfcResourceInfoMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.exception.VnfmDriverException;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
@@ -60,80 +58,85 @@ import org.springframework.stereotype.Component;
import com.google.gson.Gson;
-
@Component
-public class VnfmDriverMgmrImpl implements VnfmDriverMgmrInf{
+public class VnfmDriverMgmrImpl implements VnfmDriverMgmrInf {
private static final Logger logger = LoggerFactory.getLogger(VnfmDriverMgmrImpl.class);
-
+
@Autowired
Driver2CbamRequestConverter requestConverter;
-
+
@Autowired
Cbam2DriverResponseConverter responseConverter;
-
+
@Autowired
private CbamMgmrInf cbamMgmr;
-
+
@Autowired
private CatalogMgmrInf catalogMgmr;
-
+
@Autowired
private NslcmMgmrInf nslcmMgmr;
-
+
@Autowired
private AaiMgmrInf aaiMgmr;
-
+
@Autowired
- private VnfmJobExecutionRepository jobDbManager;
-
+ private VnfmJobExecutionMapper jobDbManager;
+
+ @Autowired
+ private VnfcResourceInfoMapper vnfcDbMgmr;
+
@Autowired
AdaptorEnv adaptorEnv;
-
+
@Autowired
private VnfContinueProcessorInf vnfContinueProcessorInf;
-
+
private Gson gson = new Gson();
-
- public InstantiateVnfResponse instantiateVnf(InstantiateVnfRequest driverRequest, String vnfmId) throws VnfmDriverException {
+
+ public InstantiateVnfResponse instantiateVnf(InstantiateVnfRequest driverRequest, String vnfmId)
+ throws VnfmDriverException {
InstantiateVnfResponse driverResponse;
try {
driverRequest.setVnfdId(adaptorEnv.getVnfdId());
buildVnfmHttpPathById(vnfmId);
-
-// String dirPath = "/etc/vnfmpkg";
-// String cbamDirName = CommonUtil.getAppRoot() + dirPath;
-// File cbamDirFile = new File(cbamDirName);
-// String cbamPackageName = cbamDirFile.listFiles()[0].getAbsolutePath();
-// cbamMgmr.uploadVnfPackage(cbamPackageName);
-
- //step 3: create vnf
+
+ // String dirPath = "/etc/vnfmpkg";
+ // String cbamDirName = CommonUtil.getAppRoot() + dirPath;
+ // File cbamDirFile = new File(cbamDirName);
+ // String cbamPackageName = cbamDirFile.listFiles()[0].getAbsolutePath();
+ // cbamMgmr.uploadVnfPackage(cbamPackageName);
+
+ // step 3: create vnf
CBAMCreateVnfRequest cbamRequest = requestConverter.createReqConvert(driverRequest);
+ logger.info("VnfmDriverMgmrImpl --> instantiateVnf, ready to create vnf on CBAM. ");
CBAMCreateVnfResponse cbamResponse = cbamMgmr.createVnf(cbamRequest);
String vnfInstanceId = cbamResponse.getId();
-
+ logger.info("VnfmDriverMgmrImpl --> instantiateVnf, vnfInstanceId is " + vnfInstanceId);
Long jobId = saveCreateVnfJob(vnfInstanceId);
driverResponse = responseConverter.createRspConvert(cbamResponse, jobId);
-
- //start the timer
- OperateTaskProgress.startInstantiateTimerTask();
-
- vnfContinueProcessorInf.continueInstantiateVnf(vnfmId, driverRequest, vnfInstanceId, jobId.toString(), nslcmMgmr, catalogMgmr, cbamMgmr, requestConverter, jobDbManager);
-
+
+ vnfContinueProcessorInf.continueInstantiateVnf(vnfmId, driverRequest, vnfInstanceId, jobId.toString(),
+ nslcmMgmr, catalogMgmr, cbamMgmr, requestConverter, jobDbManager, vnfcDbMgmr);
+
} catch (Exception e) {
logger.error("error VnfmDriverMgmrImpl --> instantiateVnf. ", e);
throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
}
-
- return driverResponse;
+
+ return driverResponse;
}
-
+
private Long saveCreateVnfJob(String vnfInstanceId) {
VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
+ long nowTime = System.currentTimeMillis();
jobInfo.setVnfInstanceId(vnfInstanceId);
jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_INSTANTIATE);
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
+ jobInfo.setOperateStartTime(nowTime);
- VnfmJobExecutionInfo jobInfo1 = (VnfmJobExecutionInfo) jobDbManager.save(jobInfo);
+ jobDbManager.insert(jobInfo);
+ VnfmJobExecutionInfo jobInfo1 = (VnfmJobExecutionInfo) jobDbManager.findNewestJobInfo();
Long jobId = jobInfo1.getJobId();
return jobId;
}
@@ -144,28 +147,29 @@ public class VnfmDriverMgmrImpl implements VnfmDriverMgmrInf{
buildVnfmHttpPathById(vnfmId);
driverResponse = generateTerminateVnfResponse(vnfInstanceId);
String jobId = driverResponse.getJobId();
-
- //start the timer
- OperateTaskProgress.startTerminateTimerTask();
- vnfContinueProcessorInf.continueTerminateVnf(vnfmId, driverRequest, vnfInstanceId, jobId, nslcmMgmr, cbamMgmr, requestConverter, jobDbManager);
-
+
+ vnfContinueProcessorInf.continueTerminateVnf(vnfmId, driverRequest, vnfInstanceId, jobId, nslcmMgmr,
+ cbamMgmr, requestConverter, jobDbManager, vnfcDbMgmr);
+
} catch (Exception e) {
logger.error("error VnfmDriverMgmrImpl --> terminateVnf. ", e);
throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
}
-
- return driverResponse;
+
+ return driverResponse;
}
private TerminateVnfResponse generateTerminateVnfResponse(String vnfInstanceId) {
VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
+ long nowTime = System.currentTimeMillis();
jobInfo.setVnfInstanceId(vnfInstanceId);
jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_TERMINATE);
jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
-
- VnfmJobExecutionInfo jobInfo1= jobDbManager.save(jobInfo);
+ jobInfo.setOperateStartTime(nowTime);
+ jobDbManager.insert(jobInfo);
+ VnfmJobExecutionInfo jobInfo1 = jobDbManager.findNewestJobInfo();
Long jobId = jobInfo1.getJobId();
-
+
TerminateVnfResponse response = new TerminateVnfResponse();
response.setJobId("" + jobId);
return response;
@@ -181,82 +185,124 @@ public class VnfmDriverMgmrImpl implements VnfmDriverMgmrInf{
logger.error("error VnfmDriverMgmrImpl --> queryVnf. ", e);
throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
}
-
- return driverResponse;
+
+ return driverResponse;
}
- public OperStatusVnfResponse getOperStatus(String vnfmId, String jobId) throws VnfmDriverException {
-
+ public OperStatusVnfResponse getOperStatus(String vnfmId, String jobId) throws VnfmDriverException {
+
OperationExecution cbamResponse = null;
-
+
try {
buildVnfmHttpPathById(vnfmId);
-
+
VnfmJobExecutionInfo jobInfo = jobDbManager.findOne(Long.parseLong(jobId));
cbamResponse = new OperationExecution();
-
- if("Instantiate".equalsIgnoreCase(jobInfo.getVnfmInterfceName())) {
+
+ if ("Instantiate".equalsIgnoreCase(jobInfo.getVnfmInterfceName())) {
cbamResponse.setOperationType(OperationType.INSTANTIATE);
- }
- else
- {
+ } else if ("Terminal".equalsIgnoreCase(jobInfo.getVnfmInterfceName())) {
cbamResponse.setOperationType(OperationType.TERMINATE);
+ } else if ("Scalein".equalsIgnoreCase(jobInfo.getVnfmInterfceName())
+ || "Scaleout".equalsIgnoreCase(jobInfo.getVnfmInterfceName())) {
+ cbamResponse.setOperationType(OperationType.SCALE);
+ } else {
+ cbamResponse.setOperationType(OperationType.HEAL);
}
-
- if(jobInfo.getStatus().equalsIgnoreCase(CommonConstants.CBAM_OPERATION_STATUS_FINISH))
- {
+
+ if (jobInfo.getStatus().equalsIgnoreCase(CommonConstants.CBAM_OPERATION_STATUS_FINISH)) {
cbamResponse.setStatus(CommonEnum.OperationStatus.FINISHED);
- } else if(jobInfo.getStatus().equalsIgnoreCase(CommonConstants.CBAM_OPERATION_STATUS_ERROR))
- {
+ } else if (jobInfo.getStatus().equalsIgnoreCase(CommonConstants.CBAM_OPERATION_STATUS_ERROR)) {
cbamResponse.setStatus(CommonEnum.OperationStatus.FINISHED);
- }
- else
- {
+ } else {
cbamResponse.setStatus(CommonEnum.OperationStatus.OTHER);
-// String execId = jobInfo.getVnfmExecutionId();
-// logger.info(" VnfmDriverMgmrImpl --> getOperStatus execId is " + execId);
-// cbamResponse = cbamMgmr.queryOperExecution(execId);
+ // String execId = jobInfo.getVnfmExecutionId();
+ // logger.info(" VnfmDriverMgmrImpl --> getOperStatus execId is " + execId);
+ // cbamResponse = cbamMgmr.queryOperExecution(execId);
}
-
+
} catch (Exception e) {
logger.error("error VnfmDriverMgmrImpl --> getOperStatus. ", e);
throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
}
-
- OperStatusVnfResponse response = responseConverter.operRspConvert(cbamResponse);
+
+ OperStatusVnfResponse response = responseConverter.operRspConvert(cbamResponse, jobId);
response.setJobId(jobId);
-
+
return response;
}
- public ScaleVnfResponse scaleVnf(ScaleVnfRequest driverRequest, String vnfmId, String vnfInstanceId) throws VnfmDriverException {
+ public ScaleVnfResponse scaleVnf(ScaleVnfRequest driverRequest, String vnfmId, String vnfInstanceId)
+ throws VnfmDriverException {
ScaleVnfResponse driverResponse;
try {
buildVnfmHttpPathById(vnfmId);
- CBAMScaleVnfRequest cbamRequest = requestConverter.scaleReqconvert(driverRequest);
- CBAMScaleVnfResponse cbamResponse = cbamMgmr.scaleVnf(cbamRequest, vnfInstanceId);
- driverResponse = responseConverter.scaleRspConvert(cbamResponse);
+ driverResponse = generateScaleVnfResponse(vnfInstanceId, driverRequest.getType());
+ String jobId = driverResponse.getJobId();
+
+ vnfContinueProcessorInf.continueScaleVnf(vnfmId, driverRequest, vnfInstanceId, jobId, nslcmMgmr, cbamMgmr,
+ requestConverter, jobDbManager);
} catch (Exception e) {
logger.error("error VnfmDriverMgmrImpl --> scaleVnf. ", e);
throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
}
-
- return driverResponse;
+
+ return driverResponse;
}
- public HealVnfResponse healVnf(HealVnfRequest driverRequest, String vnfmId, String vnfInstanceId) throws VnfmDriverException {
+ private ScaleVnfResponse generateScaleVnfResponse(String vnfInstanceId, ScaleType type) {
+ VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
+ long nowTime = System.currentTimeMillis();
+ jobInfo.setVnfInstanceId(vnfInstanceId);
+ if (type.equals(ScaleType.SCALE_OUT)) {
+ jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_SCALE_OUT);
+ } else {
+ jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_SCALE_IN);
+ }
+ jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
+ jobInfo.setOperateStartTime(nowTime);
+ jobDbManager.insert(jobInfo);
+ VnfmJobExecutionInfo jobInfo1 = jobDbManager.findNewestJobInfo();
+ Long jobId = jobInfo1.getJobId();
+
+ ScaleVnfResponse response = new ScaleVnfResponse();
+ response.setJobId("" + jobId);
+ return response;
+
+ }
+
+ public HealVnfResponse healVnf(HealVnfRequest driverRequest, String vnfmId, String vnfInstanceId)
+ throws VnfmDriverException {
HealVnfResponse driverResponse;
try {
buildVnfmHttpPathById(vnfmId);
- CBAMHealVnfRequest cbamRequest = requestConverter.healReqConvert(driverRequest);
- CBAMHealVnfResponse cbamResponse = cbamMgmr.healVnf(cbamRequest, vnfInstanceId);
- driverResponse = responseConverter.healRspConvert(cbamResponse);
+ driverResponse = generateHealVnfResponse(vnfInstanceId);
+ String jobId = driverResponse.getJobId();
+
+ vnfContinueProcessorInf.continueHealVnf(vnfmId, driverRequest, vnfInstanceId, jobId, nslcmMgmr, cbamMgmr,
+ requestConverter, jobDbManager);
} catch (Exception e) {
logger.error("error VnfmDriverMgmrImpl --> healVnf. ", e);
throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
}
-
- return driverResponse;
+
+ return driverResponse;
+ }
+
+ private HealVnfResponse generateHealVnfResponse(String vnfInstanceId) {
+ VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
+ long nowTime = System.currentTimeMillis();
+ jobInfo.setVnfInstanceId(vnfInstanceId);
+ jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_HEAL);
+ jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
+ jobInfo.setOperateStartTime(nowTime);
+ jobDbManager.insert(jobInfo);
+ VnfmJobExecutionInfo jobInfo1 = jobDbManager.findNewestJobInfo();
+ Long jobId = jobInfo1.getJobId();
+
+ HealVnfResponse response = new HealVnfResponse();
+ response.setJobId("" + jobId);
+ return response;
}
public String buildVnfmHttpPathById(String vnfmId) {
@@ -268,22 +314,22 @@ public class VnfmDriverMgmrImpl implements VnfmDriverMgmrInf{
}
return result;
}
-
- public String buildVnfmHttpPathByRealId(String vnfmId) throws ClientProtocolException, IOException, VnfmDriverException {
+
+ public String buildVnfmHttpPathByRealId(String vnfmId)
+ throws ClientProtocolException, IOException, VnfmDriverException {
AaiVnfmInfo vnfmInfo = aaiMgmr.queryVnfm(vnfmId);
logger.info("vnfmInfo in AAI is " + gson.toJson(vnfmInfo));
- if(isVnfmInfoValid(vnfmId, vnfmInfo))
- {
+ if (isVnfmInfoValid(vnfmId, vnfmInfo)) {
throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
}
-
+
EsrSystemInfo systemInfo = vnfmInfo.getEsrSystemInfoList().get(0);
-
+
String urlHead = systemInfo.getServiceUrl();
-// adaptorEnv.setCbamApiUriFront(urlHead);
-// adaptorEnv.setCbamUserName(systemInfo.getUserName());
-// adaptorEnv.setCbamPassword(systemInfo.getPassword());
-
+ // adaptorEnv.setCbamApiUriFront(urlHead);
+ // adaptorEnv.setCbamUserName(systemInfo.getUserName());
+ // adaptorEnv.setCbamPassword(systemInfo.getPassword());
+
return urlHead;
}
@@ -298,5 +344,5 @@ public class VnfmDriverMgmrImpl implements VnfmDriverMgmrInf{
public void setResponseConverter(Cbam2DriverResponseConverter responseConverter) {
this.responseConverter = responseConverter;
}
-
+
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionRequest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionRequest.java
new file mode 100644
index 00000000..29085c14
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionRequest.java
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.SubscriptionAuthentication;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.SubscriptionFilter;
+
+import com.fasterxml.jackson.annotation.JsonProperty;
+
+public class CBAMCreateSubscriptionRequest {
+ @JsonProperty("filter")
+ private SubscriptionFilter filter;
+
+ @JsonProperty("callbackUrl")
+ private String callbackUrl;
+
+ @JsonProperty("description")
+ private SubscriptionAuthentication authentication;
+
+ public SubscriptionFilter getFilter() {
+ return filter;
+ }
+
+ public void setFilter(SubscriptionFilter filter) {
+ this.filter = filter;
+ }
+
+ public String getCallbackUrl() {
+ return callbackUrl;
+ }
+
+ public void setCallbackUrl(String callbackUrl) {
+ this.callbackUrl = callbackUrl;
+ }
+
+ public SubscriptionAuthentication getAuthentication() {
+ return authentication;
+ }
+
+ public void setAuthentication(SubscriptionAuthentication authentication) {
+ this.authentication = authentication;
+ }
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionResponse.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionResponse.java
new file mode 100644
index 00000000..78cd9ce0
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMCreateSubscriptionResponse.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.Subscription;
+
+public class CBAMCreateSubscriptionResponse extends Subscription{
+/*
+
+ @JsonProperty("problemDetails")
+ private ProblemDetails problemDetails;
+
+
+ public ProblemDetails getProblemDetails() {
+ return problemDetails;
+ }
+
+ public void setProblemDetails(ProblemDetails problemDetails) {
+ this.problemDetails = problemDetails;
+ }
+*/
+
+
+
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionRequest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionRequest.java
new file mode 100644
index 00000000..1ff5e556
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionRequest.java
@@ -0,0 +1,21 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo;
+
+public class CBAMGetSubscriptionRequest {
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionResponse.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionResponse.java
new file mode 100644
index 00000000..5b6f2e17
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMGetSubscriptionResponse.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OperationExecution;
+
+public class CBAMGetSubscriptionResponse extends OperationExecution{
+/* @JsonProperty("operationExecution")
+ private OperationExecution operationExecution;
+
+ @JsonProperty("problemDetails")
+ private ProblemDetails problemDetails;
+
+ public OperationExecution getOperationExecution() {
+ return operationExecution;
+ }
+
+ public void setOperationExecution(OperationExecution operationExecution) {
+ this.operationExecution = operationExecution;
+ }
+
+ public ProblemDetails getProblemDetails() {
+ return problemDetails;
+ }
+
+ public void setProblemDetails(ProblemDetails problemDetails) {
+ this.problemDetails = problemDetails;
+ }
+*/
+
+
+
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationRequest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationRequest.java
new file mode 100644
index 00000000..436be6e0
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationRequest.java
@@ -0,0 +1,71 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VnfNotificationType;
+
+import com.fasterxml.jackson.annotation.JsonProperty;
+
+public class CBAMVnfNotificationRequest {
+ @JsonProperty("notificationType")
+ private VnfNotificationType notificationType;
+
+ @JsonProperty("subscriptionId")
+ private String subscriptionId;
+
+ @JsonProperty("timestamp")
+ private String timestamp;
+
+ @JsonProperty("vnfInstanceId")
+ private String vnfInstanceId;
+
+ public VnfNotificationType getNotificationType() {
+ return notificationType;
+ }
+
+ public void setNotificationType(VnfNotificationType notificationType) {
+ this.notificationType = notificationType;
+ }
+
+ public String getSubscriptionId() {
+ return subscriptionId;
+ }
+
+ public void setSubscriptionId(String subscriptionId) {
+ this.subscriptionId = subscriptionId;
+ }
+
+ public String getTimestamp() {
+ return timestamp;
+ }
+
+ public void setTimestamp(String timestamp) {
+ this.timestamp = timestamp;
+ }
+
+ public String getVnfInstanceId() {
+ return vnfInstanceId;
+ }
+
+ public void setVnfInstanceId(String vnfInstanceId) {
+ this.vnfInstanceId = vnfInstanceId;
+ }
+
+
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationResponse.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationResponse.java
new file mode 100644
index 00000000..814324bb
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/CBAMVnfNotificationResponse.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo;
+
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.ProblemDetails;
+
+public class CBAMVnfNotificationResponse extends ProblemDetails{
+/*
+
+ @JsonProperty("problemDetails")
+ private ProblemDetails problemDetails;
+
+
+ public ProblemDetails getProblemDetails() {
+ return problemDetails;
+ }
+
+ public void setProblemDetails(ProblemDetails problemDetails) {
+ this.problemDetails = problemDetails;
+ }
+*/
+
+
+
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Subscription.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Subscription.java
new file mode 100644
index 00000000..1345d72f
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Subscription.java
@@ -0,0 +1,78 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity;
+
+import com.fasterxml.jackson.annotation.JsonProperty;
+
+public class Subscription {
+ @JsonProperty("id")
+ private String id;
+
+ @JsonProperty("lcnApiVersion")
+ private String lcnApiVersion;
+
+ @JsonProperty("filter")
+ private SubscriptionFilter filter;
+
+ @JsonProperty("callbackUrl")
+ private String callbackUrl;
+
+ @JsonProperty("_links")
+ private _links _links;
+
+ public String getId() {
+ return id;
+ }
+
+ public void setId(String id) {
+ this.id = id;
+ }
+
+ public String getLcnApiVersion() {
+ return lcnApiVersion;
+ }
+
+ public void setLcnApiVersion(String lcnApiVersion) {
+ this.lcnApiVersion = lcnApiVersion;
+ }
+
+ public SubscriptionFilter getFilter() {
+ return filter;
+ }
+
+ public void setFilter(SubscriptionFilter filter) {
+ this.filter = filter;
+ }
+
+ public String getCallbackUrl() {
+ return callbackUrl;
+ }
+
+ public void setCallbackUrl(String callbackUrl) {
+ this.callbackUrl = callbackUrl;
+ }
+
+ public _links get_links() {
+ return _links;
+ }
+
+ public void set_links(_links _links) {
+ this._links = _links;
+ }
+
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionAuthentication.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionAuthentication.java
new file mode 100644
index 00000000..976987a1
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionAuthentication.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity;
+
+import com.fasterxml.jackson.annotation.JsonProperty;
+
+public class SubscriptionAuthentication {
+
+
+ @JsonProperty("type")
+ private Type type;
+
+ @JsonProperty("userName")
+ private String userName;
+
+ @JsonProperty("password")
+ private String password;
+
+ @JsonProperty("clientName")
+ private String clientName;
+
+ @JsonProperty("clientPassword")
+ private String clientPassword;
+
+ @JsonProperty("tokenUrl")
+ private String tokenUrl;
+
+ public Type getType() {
+ return type;
+ }
+
+ public void setType(Type type) {
+ this.type = type;
+ }
+
+ public String getUserName() {
+ return userName;
+ }
+
+ public void setUserName(String userName) {
+ this.userName = userName;
+ }
+
+ public String getPassword() {
+ return password;
+ }
+
+ public void setPassword(String password) {
+ this.password = password;
+ }
+
+ public String getClientName() {
+ return clientName;
+ }
+
+ public void setClientName(String clientName) {
+ this.clientName = clientName;
+ }
+
+ public String getClientPassword() {
+ return clientPassword;
+ }
+
+ public void setClientPassword(String clientPassword) {
+ this.clientPassword = clientPassword;
+ }
+
+ public String getTokenUrl() {
+ return tokenUrl;
+ }
+
+ public void setTokenUrl(String tokenUrl) {
+ this.tokenUrl = tokenUrl;
+ }
+
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionFilter.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionFilter.java
new file mode 100644
index 00000000..188419ad
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/SubscriptionFilter.java
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity;
+
+import java.util.List;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OperationExecution.OperationType;
+
+import com.fasterxml.jackson.annotation.JsonProperty;
+
+public class SubscriptionFilter {
+
+ @JsonProperty("vnfdId")
+ private String vnfdId;
+
+ @JsonProperty("vnfProductName")
+ private String vnfProductName;
+
+ @JsonProperty("vnfSoftwareVersion")
+ private String vnfSoftwareVersion;
+
+ @JsonProperty("vnfInstanceId")
+ private String vnfInstanceId;
+
+ @JsonProperty("notificationTypes")
+ private List<VnfNotificationType> notificationTypes;
+
+ @JsonProperty("operationType")
+ private List<OperationType> operationType;
+
+ public String getVnfdId() {
+ return vnfdId;
+ }
+
+ public void setVnfdId(String vnfdId) {
+ this.vnfdId = vnfdId;
+ }
+
+ public String getVnfProductName() {
+ return vnfProductName;
+ }
+
+ public void setVnfProductName(String vnfProductName) {
+ this.vnfProductName = vnfProductName;
+ }
+
+ public String getVnfSoftwareVersion() {
+ return vnfSoftwareVersion;
+ }
+
+ public void setVnfSoftwareVersion(String vnfSoftwareVersion) {
+ this.vnfSoftwareVersion = vnfSoftwareVersion;
+ }
+
+ public String getVnfInstanceId() {
+ return vnfInstanceId;
+ }
+
+ public void setVnfInstanceId(String vnfInstanceId) {
+ this.vnfInstanceId = vnfInstanceId;
+ }
+
+ public List<VnfNotificationType> getNotificationTypes() {
+ return notificationTypes;
+ }
+
+ public void setNotificationTypes(List<VnfNotificationType> notificationTypes) {
+ this.notificationTypes = notificationTypes;
+ }
+
+ public List<OperationType> getOperationType() {
+ return operationType;
+ }
+
+ public void setOperationType(List<OperationType> operationType) {
+ this.operationType = operationType;
+ }
+
+
+
+
+
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Type.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Type.java
new file mode 100644
index 00000000..5faaba1a
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/Type.java
@@ -0,0 +1,24 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity;
+
+public enum Type {
+ NONE,
+ BASIC,
+ OAUTH2_PASSWD,
+ OAUTH2_CLIENT
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/VnfNotificationType.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/VnfNotificationType.java
new file mode 100644
index 00000000..a5690eab
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/bo/entity/VnfNotificationType.java
@@ -0,0 +1,22 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity;
+
+public enum VnfNotificationType {
+ VnfIdentifierCreationNotification, VnfIdentifierDeletionNotification,
+ VnfLifecycleChangeNotification, VnfInfoAttributeValueChangeNotification, OtherNotification
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImpl.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImpl.java
index d312a867..4211dee3 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImpl.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImpl.java
@@ -24,9 +24,10 @@ import java.util.HashMap;
import java.util.List;
import org.apache.http.client.ClientProtocolException;
-import org.apache.log4j.Logger;
import org.json.JSONException;
import org.json.JSONObject;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
@@ -41,12 +42,17 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMVnfNotificationRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMVnfNotificationResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.Subscription;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VnfcResourceInfo;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.http.client.HttpClientProcessorInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.http.client.HttpResult;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Component;
@@ -57,244 +63,258 @@ import com.google.gson.Gson;
@Component
public class CbamMgmrImpl implements CbamMgmrInf {
- private static final Logger logger = Logger.getLogger(CbamMgmrImpl.class);
+ private static final Logger logger = LoggerFactory.getLogger(CbamMgmrImpl.class);
private Gson gson = new Gson();
-
- @Autowired
+
+ @Autowired
private AdaptorEnv adaptorEnv;
-
+
@Autowired
HttpClientProcessorInf httpClientProcessor;
-
+
public String retrieveToken() throws ClientProtocolException, IOException, JSONException {
String result = null;
- String url= adaptorEnv.getCbamApiUriFront() + CommonConstants.CbamRetrieveTokenPath;
+ String url = adaptorEnv.getCbamApiUriFront() + CommonConstants.CbamRetrieveTokenPath;
HashMap<String, String> map = new HashMap<>();
map.put(CommonConstants.ACCEPT, "*/*");
map.put(CommonConstants.CONTENT_TYPE, MediaType.APPLICATION_FORM_URLENCODED_VALUE);
-
- String bodyPostStr = String.format(CommonConstants.CbamRetrieveTokenPostStr, adaptorEnv.getClientId(), adaptorEnv.getClientSecret(), adaptorEnv.getCbamUserName(), adaptorEnv.getCbamPassword());
-
+
+ String bodyPostStr = String.format(CommonConstants.CbamRetrieveTokenPostStr, adaptorEnv.getClientId(),
+ adaptorEnv.getClientSecret(), adaptorEnv.getCbamUserName(), adaptorEnv.getCbamPassword());
+
logger.debug("CbamMgmrImpl -> retrieveToken, url is " + url);
logger.debug("CbamMgmrImpl -> retrieveToken, bodyPostStr is " + bodyPostStr);
-
+
String responseStr = httpClientProcessor.process(url, RequestMethod.POST, map, bodyPostStr).getContent();
-
+
logger.info("CbamMgmrImpl -> retrieveToken, responseStr is " + responseStr);
-
+
JSONObject tokenJsonObject = new JSONObject(responseStr);
-
+
result = tokenJsonObject.getString(CommonConstants.CBAM_TOKEN_KEY);
-
+
return result;
}
-
- public CBAMCreateVnfResponse createVnf(CBAMCreateVnfRequest cbamRequest) throws ClientProtocolException, IOException {
+
+ public CBAMCreateVnfResponse createVnf(CBAMCreateVnfRequest cbamRequest)
+ throws ClientProtocolException, IOException {
String httpPath = CommonConstants.CbamCreateVnfPath;
RequestMethod method = RequestMethod.POST;
-
+
HttpResult httpResult = operateCbamHttpTask(cbamRequest, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> createVnf, responseStr is " + responseStr);
int code = httpResult.getStatusCode();
- if(code == 201) {
+ if (code == 201) {
logger.info("CbamMgmrImpl -> createVnf success");
- }else {
+ } else {
logger.error("CbamMgmrImpl -> createVnf error ");
}
CBAMCreateVnfResponse response = gson.fromJson(responseStr, CBAMCreateVnfResponse.class);
-
+
return response;
}
-
+
public CBAMModifyVnfResponse modifyVnf(CBAMModifyVnfRequest cbamRequest, String vnfInstanceId)
throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamModifyVnfPath, vnfInstanceId);
-
+
RequestMethod method = RequestMethod.PATCH;
-
+
HttpResult httpResult = operateCbamHttpTask(cbamRequest, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> modifyVnf, responseStr is " + responseStr);
int code = httpResult.getStatusCode();
- if(code == 201) {
+
+ if(code == 202) {
logger.info("CbamMgmrImpl -> modifyVnf success");
- }else {
- logger.error("CbamMgmrImpl -> modifyVnf error ");
+ } else {
+ logger.error("CbamMgmrImpl -> modifyVnf error, statusCode = " + code);
}
CBAMModifyVnfResponse response = gson.fromJson(responseStr, CBAMModifyVnfResponse.class);
return response;
}
-
- /* (non-Javadoc)
- * @see com.nokia.vfcadaptor.cbam.impl.CbamMgmrInf#instantiateVnf(com.nokia.vfcadaptor.cbam.bo.CBAMInstantiateVnfRequest, java.lang.String)
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.nokia.vfcadaptor.cbam.impl.CbamMgmrInf#instantiateVnf(com.nokia.
+ * vfcadaptor.cbam.bo.CBAMInstantiateVnfRequest, java.lang.String)
*/
- public CBAMInstantiateVnfResponse instantiateVnf(CBAMInstantiateVnfRequest cbamRequest, String vnfInstanceId) throws ClientProtocolException, IOException {
+ public CBAMInstantiateVnfResponse instantiateVnf(CBAMInstantiateVnfRequest cbamRequest, String vnfInstanceId)
+ throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamInstantiateVnfPath, vnfInstanceId);
RequestMethod method = RequestMethod.POST;
-
+
HttpResult httpResult = operateCbamHttpTask(cbamRequest, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> instantiateVnf, responseStr is " + responseStr);
int code = httpResult.getStatusCode();
- if(code == 202) {
- logger.info("CbamMgmrImpl -> instantiateVnf success " );
- }else {
- logger.error("CbamMgmrImpl -> instantiateVnf error " );
+ if (code == 202) {
+ logger.info("CbamMgmrImpl -> instantiateVnf success ");
+ } else {
+ logger.error("CbamMgmrImpl -> instantiateVnf error ");
}
CBAMInstantiateVnfResponse response = gson.fromJson(responseStr, CBAMInstantiateVnfResponse.class);
-
+
return response;
}
-
- public CBAMTerminateVnfResponse terminateVnf(CBAMTerminateVnfRequest cbamRequest, String vnfInstanceId) throws ClientProtocolException, IOException {
+
+ public CBAMTerminateVnfResponse terminateVnf(CBAMTerminateVnfRequest cbamRequest, String vnfInstanceId)
+ throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamTerminateVnfPath, vnfInstanceId);
RequestMethod method = RequestMethod.POST;
-
+
HttpResult httpResult = operateCbamHttpTask(cbamRequest, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> terminateVnf, responseStr is " + responseStr);
int code = httpResult.getStatusCode();
- if(code == 202) {
- logger.info("CbamMgmrImpl -> terminateVnf sucess " );
- }else {
- logger.error("CbamMgmrImpl -> terminateVnf error " );
+ if (code == 202) {
+ logger.info("CbamMgmrImpl -> terminateVnf sucess ");
+ } else {
+ logger.error("CbamMgmrImpl -> terminateVnf error ");
}
CBAMTerminateVnfResponse response = gson.fromJson(responseStr, CBAMTerminateVnfResponse.class);
-
+
return response;
}
-
+
public void deleteVnf(String vnfInstanceId) throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamDeleteVnfPath, vnfInstanceId);
RequestMethod method = RequestMethod.DELETE;
HttpResult httpResult = operateCbamHttpTask(null, httpPath, method);
-
+
int code = httpResult.getStatusCode();
- if(code == 204) {
+ if (code == 204) {
logger.info("CbamMgmrImpl -> deleteVnf success.");
- }else {
- logger.error("CbamMgmrImpl -> deleteVnf error. detail info is " + httpResult.getContent());
+ } else {
+ logger.error("CbamMgmrImpl -> deleteVnf error. detail info is " + httpResult.getContent());
}
-
+
}
-
- public CBAMScaleVnfResponse scaleVnf(CBAMScaleVnfRequest cbamRequest, String vnfInstanceId) throws ClientProtocolException, IOException {
+
+ public CBAMScaleVnfResponse scaleVnf(CBAMScaleVnfRequest cbamRequest, String vnfInstanceId)
+ throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamScaleVnfPath, vnfInstanceId);
RequestMethod method = RequestMethod.POST;
-
+
HttpResult httpResult = operateCbamHttpTask(cbamRequest, httpPath, method);
String responseStr = httpResult.getContent();
int code = httpResult.getStatusCode();
- if(code == 202) {
+ if (code == 202) {
logger.info("CbamMgmrImpl -> scaleVnf success.");
- }else {
- logger.error("CbamMgmrImpl -> scaleVnf error. " );
+ } else {
+ logger.error("CbamMgmrImpl -> scaleVnf error. ");
}
CBAMScaleVnfResponse response = gson.fromJson(responseStr, CBAMScaleVnfResponse.class);
-
+
return response;
}
- public CBAMHealVnfResponse healVnf(CBAMHealVnfRequest cbamRequest, String vnfInstanceId) throws ClientProtocolException, IOException {
+ public CBAMHealVnfResponse healVnf(CBAMHealVnfRequest cbamRequest, String vnfInstanceId)
+ throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamHealVnfPath, vnfInstanceId);
RequestMethod method = RequestMethod.POST;
-
+
HttpResult httpResult = operateCbamHttpTask(cbamRequest, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> healVnf, responseStr is " + responseStr);
int code = httpResult.getStatusCode();
- if(code == 202) {
+ if (code == 202) {
logger.info("CbamMgmrImpl -> healVnf success.");
- }else {
- logger.error("CbamMgmrImpl -> healVnf error. " );
+ } else {
+ logger.error("CbamMgmrImpl -> healVnf error. ");
}
CBAMHealVnfResponse response = gson.fromJson(responseStr, CBAMHealVnfResponse.class);
-
+
return response;
}
-
+
public CBAMQueryVnfResponse queryVnf(String vnfInstanceId) throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamQueryVnfPath, vnfInstanceId);
RequestMethod method = RequestMethod.GET;
-
+
HttpResult httpResult = operateCbamHttpTask(null, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> queryVnf, responseStr is " + responseStr);
int code = httpResult.getStatusCode();
- if(code == 200) {
+ if (code == 200) {
logger.info("CbamMgmrImpl -> queryVnf success.");
- }else {
- logger.error("CbamMgmrImpl -> queryVnf error. " );
+ } else {
+ logger.error("CbamMgmrImpl -> queryVnf error. ");
}
-
+
CBAMQueryVnfResponse response = gson.fromJson(responseStr, CBAMQueryVnfResponse.class);
-
+
return response;
}
-
+
public List<VnfcResourceInfo> queryVnfcResource(String vnfInstanceId) throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamQueryVnfcResourcePath, vnfInstanceId);
RequestMethod method = RequestMethod.GET;
-
+
HttpResult httpResult = operateCbamHttpTask(null, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> queryVnfcResource, responseStr is " + responseStr);
int code = httpResult.getStatusCode();
- if(code == 200) {
+ if (code == 200) {
logger.info("CbamMgmrImpl -> queryVnfcResource success.");
- }else {
- logger.error("CbamMgmrImpl -> queryVnfcResource error. " );
+ } else {
+ logger.error("CbamMgmrImpl -> queryVnfcResource error. ");
}
- List<VnfcResourceInfo> response = gson.fromJson(responseStr, new TypeToken<List<VnfcResourceInfo>>(){}.getType());;
-
+ List<VnfcResourceInfo> response = gson.fromJson(responseStr, new TypeToken<List<VnfcResourceInfo>>() {
+ }.getType());
+ ;
+
return response;
}
- public HttpResult operateCbamHttpTask(Object httpBodyObj, String httpPath, RequestMethod method) throws ClientProtocolException, IOException {
+ public HttpResult operateCbamHttpTask(Object httpBodyObj, String httpPath, RequestMethod method)
+ throws ClientProtocolException, IOException {
String token = null;
try {
token = retrieveToken();
} catch (JSONException e) {
logger.error("retrieveTokenError ", e);
}
-
- String url= adaptorEnv.getCbamApiUriFront() + httpPath;
-
+
+ String url = adaptorEnv.getCbamApiUriFront() + httpPath;
+
HashMap<String, String> map = new HashMap<>();
map.put(CommonConstants.AUTHORIZATION, "bearer " + token);
map.put(CommonConstants.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE);
-
+
return httpClientProcessor.process(url, method, map, gson.toJson(httpBodyObj));
}
- public CBAMQueryOperExecutionResponse queryOperExecution(String execId) throws ClientProtocolException, IOException{
+ public CBAMQueryOperExecutionResponse queryOperExecution(String execId)
+ throws ClientProtocolException, IOException {
String httpPath = String.format(CommonConstants.CbamGetOperStatusPath, execId);
RequestMethod method = RequestMethod.GET;
-
+
HttpResult httpResult = operateCbamHttpTask(null, httpPath, method);
String responseStr = httpResult.getContent();
-
+
logger.info("CbamMgmrImpl -> CBAMQueryOperExecutionResponse, responseStr is " + responseStr);
-
+
int code = httpResult.getStatusCode();
- if(code == 200) {
- logger.info("CbamMgmrImpl -> CBAMQueryOperExecutionResponse, success" );
- }else if(code == 202) {
- logger.info("CbamMgmrImpl -> CBAMQueryOperExecutionResponse, ongoing" );
- }else {
- logger.error("CbamMgmrImpl -> CBAMQueryOperExecutionResponse, error" );
+ if (code == 200) {
+ logger.info("CbamMgmrImpl -> CBAMQueryOperExecutionResponse, success");
+ } else if (code == 202) {
+ logger.info("CbamMgmrImpl -> CBAMQueryOperExecutionResponse, ongoing");
+ } else {
+ logger.error("CbamMgmrImpl -> CBAMQueryOperExecutionResponse, error");
}
-
+
CBAMQueryOperExecutionResponse response = gson.fromJson(responseStr, CBAMQueryOperExecutionResponse.class);
-
+
return response;
}
@@ -306,22 +326,24 @@ public class CbamMgmrImpl implements CbamMgmrInf {
public void uploadVnfPackage(String cbamPackageFilePath) throws ClientProtocolException, IOException {
String httpPath = CommonConstants.CbamUploadVnfPackagePath;
RequestMethod method = RequestMethod.POST;
-
+
HttpResult httpResult = operateCbamHttpUploadTask(cbamPackageFilePath, httpPath, method);
String responseStr = httpResult.getContent();
-
- logger.info("CbamMgmrImpl -> uploadVnfPackage, statusCode is " + httpResult.getStatusCode() + ", cause is " + httpResult.getStatusCause() + ". responseStr is " + responseStr);
-
+
+ logger.info("CbamMgmrImpl -> uploadVnfPackage, statusCode is " + httpResult.getStatusCode() + ", cause is "
+ + httpResult.getStatusCause() + ". responseStr is " + responseStr);
+
int code = httpResult.getStatusCode();
- if(code == 200) {
- logger.info("CbamMgmrImpl -> uploadVnfPackage, success" );
+ if (code == 200) {
+ logger.info("CbamMgmrImpl -> uploadVnfPackage, success");
logger.info("Upload vnf package " + cbamPackageFilePath + " to CBAM is successful.");
- }else {
- logger.error("CbamMgmrImpl -> uploadVnfPackage, error" );
+ } else {
+ logger.error("CbamMgmrImpl -> uploadVnfPackage, error");
}
}
- public HttpResult operateCbamHttpUploadTask(String filePath, String httpPath, RequestMethod method) throws ClientProtocolException, IOException {
+ public HttpResult operateCbamHttpUploadTask(String filePath, String httpPath, RequestMethod method)
+ throws ClientProtocolException, IOException {
String token = null;
try {
token = retrieveToken();
@@ -330,107 +352,111 @@ public class CbamMgmrImpl implements CbamMgmrInf {
}
String url = adaptorEnv.getCbamApiUriFront() + httpPath;
logger.info("start to upload file.");
- String command = "/usr/bin/curl --insecure -X POST -H \"Authorization: bearer " + token + "\" --form content=@" + filePath + " " + url;
+ String command = "/usr/bin/curl --insecure -X POST -H \"Authorization: bearer " + token + "\" --form content=@"
+ + filePath + " " + url;
StringBuffer respStr = execCommand(command);
-
-// HashMap<String, String> map = new HashMap<>();
-// map.put(CommonConstants.AUTHORIZATION, "bearer " + token);
-// map.put(CommonConstants.CONTENT_TYPE, "multipart/form-data, boundary=---CFSGSSGGSGdssdfsdhd---");
-// byte[] fileBytes = CommonUtil.getBytes(filePath);
-// logger.info("CbamMgmrImpl -> operateCbamHttpUploadTask, url is " + url);
-// logger.info("CbamMgmrImpl -> operateCbamHttpUploadTask, token is " + token);
-// logger.info("CbamMgmrImpl -> operateCbamHttpUploadTask, bodyPostStr byte lenth is " + fileBytes.length);
-
-// return httpClientProcessor.processBytes(url, method, map, fileBytes);
-
+
+ // HashMap<String, String> map = new HashMap<>();
+ // map.put(CommonConstants.AUTHORIZATION, "bearer " + token);
+ // map.put(CommonConstants.CONTENT_TYPE, "multipart/form-data,
+ // boundary=---CFSGSSGGSGdssdfsdhd---");
+ // byte[] fileBytes = CommonUtil.getBytes(filePath);
+ // logger.info("CbamMgmrImpl -> operateCbamHttpUploadTask, url is " + url);
+ // logger.info("CbamMgmrImpl -> operateCbamHttpUploadTask, token is " + token);
+ // logger.info("CbamMgmrImpl -> operateCbamHttpUploadTask, bodyPostStr byte
+ // lenth is " + fileBytes.length);
+
+ // return httpClientProcessor.processBytes(url, method, map, fileBytes);
+
HttpResult hResult = new HttpResult();
hResult.setStatusCause(respStr.toString());
hResult.setContent(respStr.toString());
hResult.setStatusCode(200);
return hResult;
-
-// String charset = "UTF-8";
-// File uploadFile1 = new File(filePath);
-// String requestURL = url;
-// HttpResult result = new HttpResult();
-//
-// try {
-// MultipartUtility multipart = new MultipartUtility(requestURL, charset);
-//
-// multipart.addHeaderField("User-Agent", "CodeJava");
-// multipart.addHeaderField(CommonConstants.AUTHORIZATION, "bearer " + token);
-//
-// multipart.addFilePart("fileUpload", uploadFile1);
-//
-// List<String> response = multipart.finish();
-//
-// result.setContent(Arrays.deepToString(response.toArray(new String[0])));
-// result.setStatusCode(200);
-// } catch (Exception ex) {
-// logger.error("CbamMgmrImpl -> operateCbamHttpUploadTask, error ", ex);
-// result.setStatusCode(500);
-// }
-//
-// return result;
+
+ // String charset = "UTF-8";
+ // File uploadFile1 = new File(filePath);
+ // String requestURL = url;
+ // HttpResult result = new HttpResult();
+ //
+ // try {
+ // MultipartUtility multipart = new MultipartUtility(requestURL, charset);
+ //
+ // multipart.addHeaderField("User-Agent", "CodeJava");
+ // multipart.addHeaderField(CommonConstants.AUTHORIZATION, "bearer " + token);
+ //
+ // multipart.addFilePart("fileUpload", uploadFile1);
+ //
+ // List<String> response = multipart.finish();
+ //
+ // result.setContent(Arrays.deepToString(response.toArray(new String[0])));
+ // result.setStatusCode(200);
+ // } catch (Exception ex) {
+ // logger.error("CbamMgmrImpl -> operateCbamHttpUploadTask, error ", ex);
+ // result.setStatusCode(500);
+ // }
+ //
+ // return result;
}
private StringBuffer execCommand(String command) {
logger.info("CbamMgmrImpl -> execCommand, command is " + command);
StringBuffer respStr = new StringBuffer("\r\n");
try {
- String os = System.getProperty("os.name");
- String[] cmd = {"cmd", "/c", command};
- if(!os.toLowerCase().startsWith("win")){
- cmd = new String[]{"/bin/sh","-c", command};
- }
+ String os = System.getProperty("os.name");
+ String[] cmd = { "cmd", "/c", command };
+ if (!os.toLowerCase().startsWith("win")) {
+ cmd = new String[] { "/bin/sh", "-c", command };
+ }
Process process = Runtime.getRuntime().exec(cmd);
- Thread t=new Thread(new InputStreamRunnable(process.getErrorStream(),"ErrorStream"));
- t.start();
- Thread.sleep(3000);
- InputStream fis=process.getInputStream();
- InputStreamReader isr=new InputStreamReader(fis);
-
- BufferedReader br=new BufferedReader(isr);
- String line = null;
- while((line = br.readLine())!=null)
- {
- respStr.append(line + "\r\n");
- }
- respStr.append("\r\n");
- process.waitFor();
- fis.close();
- isr.close();
- process.destroy();
- logger.info("operateCbamHttpUploadTask respStr is: " + respStr);
+ Thread t = new Thread(new InputStreamRunnable(process.getErrorStream(), "ErrorStream"));
+ t.start();
+ Thread.sleep(3000);
+ InputStream fis = process.getInputStream();
+ InputStreamReader isr = new InputStreamReader(fis);
+
+ BufferedReader br = new BufferedReader(isr);
+ String line = null;
+ while ((line = br.readLine()) != null) {
+ respStr.append(line + "\r\n");
+ }
+ respStr.append("\r\n");
+ process.waitFor();
+ fis.close();
+ isr.close();
+ process.destroy();
+ logger.info("operateCbamHttpUploadTask respStr is: " + respStr);
} catch (Exception e) {
logger.error("operateCbamHttpUploadTask error", e);
}
return respStr;
}
-
-// public static String postByHttps(String url, String body, Object contentType) {
-// String result = "";
-// Protocol https = new Protocol("https", new HTTPSSecureProtocolSocketFactory(), 443);
-// Protocol.registerProtocol("https", https);
-// PostMethod post = new PostMethod(url);
-// HttpClient client = new HttpClient();
-// try {
-// post.setRequestHeader("Content-Type", contentType);
-// post.setRequestBody(body);
-// client.executeMethod(post);
-// result = post.getResponseBodyAsString();
-// Protocol.unregisterProtocol("https");
-// return result;
-// } catch (HttpException e) {
-// e.printStackTrace();
-// } catch (IOException e) {
-// e.printStackTrace();
-// } catch(Exception e) {
-// e.printStackTrace();
-// }
-//
-// return "error";
-// }
+
+ // public static String postByHttps(String url, String body, Object contentType)
+ // {
+ // String result = "";
+ // Protocol https = new Protocol("https", new
+ // HTTPSSecureProtocolSocketFactory(), 443);
+ // Protocol.registerProtocol("https", https);
+ // PostMethod post = new PostMethod(url);
+ // HttpClient client = new HttpClient();
+ // try {
+ // post.setRequestHeader("Content-Type", contentType);
+ // post.setRequestBody(body);
+ // client.executeMethod(post);
+ // result = post.getResponseBodyAsString();
+ // Protocol.unregisterProtocol("https");
+ // return result;
+ // } catch (HttpException e) {
+ // e.printStackTrace();
+ // } catch (IOException e) {
+ // e.printStackTrace();
+ // } catch(Exception e) {
+ // e.printStackTrace();
+ // }
+ //
+ // return "error";
+ // }
public HttpClientProcessorInf getHttpClientProcessor() {
return httpClientProcessor;
@@ -439,4 +465,69 @@ public class CbamMgmrImpl implements CbamMgmrInf {
public void setHttpClientProcessor(HttpClientProcessorInf httpClientProcessor) {
this.httpClientProcessor = httpClientProcessor;
}
+
+ @Override
+ public CBAMCreateSubscriptionResponse createSubscription(CBAMCreateSubscriptionRequest subscriptionRequest)
+ throws ClientProtocolException, IOException {
+ String httpPath = String.format(CommonConstants.CbamCreateSubscriptionPath);
+ RequestMethod method = RequestMethod.POST;
+ logger.info("CbamMgmrImpl -> createSubscription, requestStr is " + gson.toJson(subscriptionRequest));
+ HttpResult httpResult = operateCbamHttpTask(subscriptionRequest, httpPath, method);
+ String responseStr = httpResult.getContent();
+
+ logger.info("CbamMgmrImpl -> createSubscription, responseStr is " + responseStr);
+ int code = httpResult.getStatusCode();
+ if (code == 201) {
+ logger.info("CbamMgmrImpl -> createSubscription success ");
+ } else {
+ logger.error("CbamMgmrImpl -> createSubscription error , statusCode = " + code);
+ }
+ CBAMCreateSubscriptionResponse response = gson.fromJson(responseStr, CBAMCreateSubscriptionResponse.class);
+
+ return response;
+ }
+
+ @Override
+ public Subscription getSubscription(String subscriptionId) throws ClientProtocolException, IOException {
+ String httpPath = String.format(CommonConstants.CbamGetSubscriptionPath, subscriptionId);
+ RequestMethod method = RequestMethod.GET;
+
+ HttpResult httpResult = operateCbamHttpTask(null, httpPath, method);
+ String responseStr = httpResult.getContent();
+
+ logger.info("CbamMgmrImpl -> getSubscription, responseStr is " + responseStr);
+ int code = httpResult.getStatusCode();
+ if (code == 200) {
+ logger.info("CbamMgmrImpl -> getSubscription success ");
+ } else {
+ logger.error("CbamMgmrImpl -> getSubscription error , statusCode = " + code);
+ }
+ Subscription response = gson.fromJson(responseStr, Subscription.class);
+
+ return response;
+ }
+
+ @Override
+ public CBAMVnfNotificationResponse getNotification(CBAMVnfNotificationRequest getNotificationRequest)
+ throws ClientProtocolException, IOException {
+ String httpPath = String.format(CommonConstants.CbamGetNotificationPath);
+ RequestMethod method = RequestMethod.GET;
+
+ HttpResult httpResult = operateCbamHttpTask(getNotificationRequest, httpPath, method);
+ String responseStr = httpResult.getContent();
+
+ logger.info("CbamMgmrImpl -> getNotification, responseStr is " + responseStr);
+ int code = httpResult.getStatusCode();
+ if (code == 200) {
+ logger.info("CbamMgmrImpl -> getNotification success ");
+ } else {
+ logger.error("CbamMgmrImpl -> getNotification error , statusCode = " + code);
+ }
+ CBAMVnfNotificationResponse response = gson.fromJson(responseStr, CBAMVnfNotificationResponse.class);
+ return response;
+ }
+
+
+
+
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/MultipartUtility.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/MultipartUtility.java
index d9203137..f8f0c400 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/MultipartUtility.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/MultipartUtility.java
@@ -43,7 +43,8 @@ import javax.net.ssl.TrustManager;
import javax.net.ssl.TrustManagerFactory;
import javax.net.ssl.X509TrustManager;
-import org.apache.log4j.Logger;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.SslConfInfo;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.util.CommonUtil;
@@ -56,7 +57,7 @@ import com.google.gson.Gson;
*
*/
public class MultipartUtility {
- private static final Logger logger = Logger.getLogger(MultipartUtility.class);
+ private static final Logger logger = LoggerFactory.getLogger(MultipartUtility.class);
private final String boundary;
private static final String LINE_FEED = "\r\n";
private HttpsURLConnection httpConn;
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/inf/CbamMgmrInf.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/inf/CbamMgmrInf.java
index fb1fd8bd..cb62689d 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/inf/CbamMgmrInf.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/inf/CbamMgmrInf.java
@@ -20,6 +20,8 @@ import java.io.IOException;
import java.util.List;
import org.apache.http.client.ClientProtocolException;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
@@ -34,6 +36,9 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMVnfNotificationRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMVnfNotificationResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.Subscription;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VnfcResourceInfo;
public interface CbamMgmrInf {
@@ -44,6 +49,12 @@ public interface CbamMgmrInf {
public CBAMInstantiateVnfResponse instantiateVnf(CBAMInstantiateVnfRequest cbamRequest, String vnfInstanceId)
throws ClientProtocolException, IOException;
+ public CBAMCreateSubscriptionResponse createSubscription(CBAMCreateSubscriptionRequest subscriptionRequest)
+ throws ClientProtocolException, IOException;
+ public Subscription getSubscription(String subscriptionId)
+ throws ClientProtocolException, IOException;
+ public CBAMVnfNotificationResponse getNotification(CBAMVnfNotificationRequest getNotificationRequest)
+ throws ClientProtocolException, IOException;
public CBAMTerminateVnfResponse terminateVnf(CBAMTerminateVnfRequest cbamRequest, String vnfInstanceId)
throws ClientProtocolException, IOException;
@@ -52,7 +63,7 @@ public interface CbamMgmrInf {
throws ClientProtocolException, IOException;
public CBAMHealVnfResponse healVnf(CBAMHealVnfRequest cbamRequest, String vnfInstanceId)
- throws ClientProtocolException, IOException;
+ throws ClientProtocolException, IOException;
public CBAMQueryVnfResponse queryVnf(String vnfInstanceId) throws ClientProtocolException, IOException;
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/common/bo/AdaptorEnv.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/common/bo/AdaptorEnv.java
index de8e9004..72e17898 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/common/bo/AdaptorEnv.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/common/bo/AdaptorEnv.java
@@ -23,8 +23,9 @@ import org.springframework.stereotype.Component;
public class AdaptorEnv {
private String msbIp;
private int msbPort;
-
- // service name and version of MSB services AAI/LCM/Catalog configured in application.properties
+
+ // service name and version of MSB services AAI/LCM/Catalog configured in
+ // application.properties
@Value("${aaiServiceNameInMsb}")
private String aaiServiceNameInMsb;
@@ -43,30 +44,29 @@ public class AdaptorEnv {
@Value("${catalogVersionInMsb}")
private String catalogVersionInMsb;
- //Following uriFront is from msb query
-
+ // Following uriFront is from msb query
+
private String aaiUrlInMsb;
private String aaiApiUriFront;
-
+
private String lcmUrlInMsb;
private String lcmApiUriFront;
-
+
private String catalogUrlInMsb;
private String catalogApiUriFront;
-
- //cbamApiFront is from aai query
+
+ // cbamApiFront is from aai query
@Value("${cbamApiUriFront}")
private String cbamApiUriFront;
-
+
@Value("${cbamUserName}")
private String cbamUserName;
-
+
@Value("${cbamPassword}")
private String cbamPassword;
-
-
+
private String msbApiUriFront;
-
+
// for retrieving token from CBAM, configured in application.properties
@Value("${grantType}")
private String grantType;
@@ -76,23 +76,37 @@ public class AdaptorEnv {
@Value("${clientSecret}")
private String clientSecret;
-
+
// for granting
@Value("${type}")
private String type;
-
+
@Value("${sizeOfStorage}")
private String sizeOfStorage;
-
+
@Value("${virtualMemSize}")
private String virtualMemSize;
-
+
@Value("${numVirtualCpu}")
private String numVirtualCpu;
-
+
@Value("${vnfdId}")
private String vnfdId;
+ // for OperateTaskProcess
+ @Value("${initialProgress}")
+ private int initialProgress;
+
+ @Value("${instantiateTimeInterval}")
+ private int instantiateTimeInterval;
+
+ @Value("${terminateTimeInterval}")
+ private int terminateTimeInterval;
+
+ //
+ @Value("${driverApiUriFront}")
+ private String driverApiUriFront;
+
public String getAaiServiceNameInMsb() {
return aaiServiceNameInMsb;
}
@@ -301,5 +315,39 @@ public class AdaptorEnv {
this.vnfdId = vnfdId;
}
+ public int getInitialProgress() {
+ return initialProgress;
+ }
+
+ public void setInitialProgress(int initialProgress) {
+ this.initialProgress = initialProgress;
+ }
+
+ public int getInstantiateTimeInterval() {
+ return instantiateTimeInterval;
+ }
+ public void setInstantiateTimeInterval(int instantiateTimeInterval) {
+ this.instantiateTimeInterval = instantiateTimeInterval;
+ }
+
+ public int getTerminateTimeInterval() {
+ return terminateTimeInterval;
+ }
+
+ public void setTerminateTimeInterval(int terminateTimeInterval) {
+ this.terminateTimeInterval = terminateTimeInterval;
+ }
+
+ public String getDriverApiUriFront() {
+ return driverApiUriFront;
+ }
+
+ public void setDriverApiUriFront(String driverApiUriFront) {
+ this.driverApiUriFront = driverApiUriFront;
+ }
+
+
+
+
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonConstants.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonConstants.java
index e9387475..a047fd78 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonConstants.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonConstants.java
@@ -54,6 +54,9 @@ public class CommonConstants {
public static final String CbamScaleVnfPath = "/vnfm/lcm/v3/vnfs/%s/scale";
public static final String CbamHealVnfPath="/vnfm/lcm/v3/vnfs/%s/heal";
public static final String CbamQueryVnfcResourcePath="/vnfm/lcm/v3/vnfs/%s/vnfc_resource_info";
+ public static final String CbamCreateSubscriptionPath="/vnfm/lcn/v3/subscriptions";
+ public static final String CbamGetSubscriptionPath="/vnfm/lcn/v3/subscriptions/%s";
+ public static final String CbamGetNotificationPath="/vnfm/lcn/v3/notifications";
public static final String CbamUploadVnfPackagePath="/api/catalog/adapter/vnfpackages";
@@ -64,10 +67,11 @@ public class CommonConstants {
public static final String NSLCM_OPERATION_SCALE_IN = "Scalein";
public static final String NSLCM_OPERATION_SCALE_UP = "Scaleup";
public static final String NSLCM_OPERATION_SCALE_DOWN = "Scaledown";
+ public static final String NSLCM_OPERATION_HEAL = "Heal";
public static final String CBAM_OPERATION_STATUS_START = "started";
public static final String CBAM_OPERATION_STATUS_PROCESSING = "processing";
- public static final String CBAM_OPERATION_STATUS_FINISH = "finished";
+ public static final String CBAM_OPERATION_STATUS_FINISH = "finished";
public static final String CBAM_OPERATION_STATUS_ERROR = "error";
//MSB
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonEnum.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonEnum.java
index 06d20dec..52dbfb0e 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonEnum.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/constant/CommonEnum.java
@@ -44,7 +44,7 @@ public class CommonEnum {
// GrantVnf
public enum LifecycleOperation {
- Instantiate, Scaleout, Scalein, Scaleup, Scaledown, Terminal
+ Instantiate, Scaleout, Scalein, Scaleup, Scaledown, Terminal,Heal
}
public enum type {
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmJobExecutionInfo.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmJobExecutionInfo.java
index cf79b052..d8058b97 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmJobExecutionInfo.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmJobExecutionInfo.java
@@ -18,35 +18,41 @@ package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean;
import java.io.Serializable;
-import javax.persistence.Column;
-import javax.persistence.Entity;
-import javax.persistence.GeneratedValue;
-import javax.persistence.GenerationType;
-import javax.persistence.Id;
-import javax.persistence.Table;
+//import javax.persistence.Column;
+//import javax.persistence.Entity;
+//import javax.persistence.GeneratedValue;
+//import javax.persistence.GenerationType;
+//import javax.persistence.Id;
+//import javax.persistence.Table;
-@Entity
-@Table(name = "vnfm_job_execution_info")
+//@Entity
+//@Table(name = "vnfm_job_execution_info")
public class VnfmJobExecutionInfo implements Serializable {
private static final long serialVersionUID = -288015953900428312L;
- @Id
- @GeneratedValue(strategy=GenerationType.AUTO)
- @Column(name = "job_id")
+// @Id
+// @GeneratedValue(strategy=GenerationType.AUTO)
+// @Column(name = "job_id")
private long jobId;
- @Column(name = "vnfm_execution_id")
+// @Column(name = "vnfm_execution_id")
private String vnfmExecutionId;
- @Column(name = "vnf_instance_id")
+// @Column(name = "vnf_instance_id")
private String vnfInstanceId;
- @Column(name = "vnfm_interface_name")
+// @Column(name = "vnfm_interface_name")
private String vnfmInterfceName;
- @Column(name = "status")
+// @Column(name = "status")
private String status;
+
+// @Column(name = "operate_start_time")
+ private long operateStartTime;
+
+// @Column(name = "operate_end_time")
+ private long operateEndTime;
public long getJobId() {
return jobId;
@@ -88,6 +94,30 @@ public class VnfmJobExecutionInfo implements Serializable {
this.status = status;
}
+
+
+
+ public static long getSerialversionuid() {
+ return serialVersionUID;
+ }
+
+
+ public long getOperateStartTime() {
+ return operateStartTime;
+ }
+
+ public void setOperateStartTime(long operateStartTime) {
+ this.operateStartTime = operateStartTime;
+ }
+
+ public long getOperateEndTime() {
+ return operateEndTime;
+ }
+
+ public void setOperateEndTime(long operateEndTime) {
+ this.operateEndTime = operateEndTime;
+ }
+
@Override
public String toString()
{
@@ -97,7 +127,9 @@ public class VnfmJobExecutionInfo implements Serializable {
+ ", vnfInstanceId = " + vnfInstanceId
+ ", vnfmExecutionId = " + vnfmExecutionId
+ ", vnfmInterfceName = " + vnfmInterfceName
- + ", status = " + status
+ + ", status = " + status
+ + ", operateStartTime = "+ operateStartTime
+ + ", operateEndTime = "+ operateEndTime
+ "]";
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmResourceInfo.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmResourceInfo.java
index dadb2b9f..c40fe91d 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmResourceInfo.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmResourceInfo.java
@@ -18,31 +18,31 @@ package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean;
import java.io.Serializable;
-import javax.persistence.Column;
-import javax.persistence.Entity;
-import javax.persistence.GeneratedValue;
-import javax.persistence.GenerationType;
-import javax.persistence.Id;
-import javax.persistence.Table;
-
-@Entity
-@Table(name="vnfm_resource_info")
+//import javax.persistence.Column;
+//import javax.persistence.Entity;
+//import javax.persistence.GeneratedValue;
+//import javax.persistence.GenerationType;
+//import javax.persistence.Id;
+//import javax.persistence.Table;
+
+//@Entity
+//@Table(name="vnfm_resource_info")
public class VnfmResourceInfo implements Serializable {
private static final long serialVersionUID = -288015953900428312L;
- @Id
- @GeneratedValue(strategy = GenerationType.AUTO)
+// @Id
+// @GeneratedValue(strategy = GenerationType.AUTO)
private int id;
- @Column(name = "type")
+// @Column(name = "type")
private ResourceType type;
- @Column(name = "resource_definition_id")
+// @Column(name = "resource_definition_id")
private String resourceDefinitionId;
- @Column(name = "vdu")
+// @Column(name = "vdu")
private String vdu;
- @Column(name = "status")
+// @Column(name = "status")
private String status;
public int getId() {
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmSubscriptionInfo.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmSubscriptionInfo.java
new file mode 100644
index 00000000..b517657d
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/bean/VnfmSubscriptionInfo.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean;
+
+import java.io.Serializable;
+
+//import javax.persistence.Column;
+//import javax.persistence.Entity;
+//import javax.persistence.GeneratedValue;
+//import javax.persistence.GenerationType;
+//import javax.persistence.Id;
+//import javax.persistence.Table;
+
+//@Entity
+//@Table(name = "vnfm_subscription_info")
+public class VnfmSubscriptionInfo implements Serializable {
+ private static final long serialVersionUID = -288015953900428312L;
+
+// @Id
+// @Column(name = "id")
+ private String id;
+
+ public static long getSerialversionuid() {
+ return serialVersionUID;
+ }
+
+ public String getId() {
+ return id;
+ }
+
+ public void setId(String id) {
+ this.id = id;
+ }
+
+ @Override
+ public String toString() {
+ return " VnfmSubscriptionInfo: [ " + super.toString() + ", id = " + id + "]";
+
+ }
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfcResourceInfoMapper.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfcResourceInfoMapper.java
new file mode 100644
index 00000000..74eb3cb7
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfcResourceInfoMapper.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper;
+
+import java.util.List;
+
+import org.apache.ibatis.annotations.Delete;
+import org.apache.ibatis.annotations.Insert;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Result;
+import org.apache.ibatis.annotations.Results;
+import org.apache.ibatis.annotations.Select;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.AffectedVnfc;
+
+@Mapper
+public interface VnfcResourceInfoMapper {
+ @Select("SELECT * FROM vnfm_vnfc_resource_info where vnf_instance_id = #{vnfInstanceId}")
+ @Results({
+ @Result(property = "vnfInstanceId", column = "vnf_instance_id"),
+ @Result(property = "vnfcInstanceId", column = "vnfc_instance_id"),
+ @Result(property = "vduId", column = "vdu_id"),
+ @Result(property = "vimid", column = "vim_id"),
+ @Result(property = "vmid", column = "vm_id"),
+ @Result(property = "changeType", column = "change_type")
+ })
+ List<AffectedVnfc> getAllByInstanceId(String vnfInstanceId);
+
+ @Insert("INSERT INTO vnfm_vnfc_resource_info(vnf_instance_id,vnfc_instance_id,vdu_id,vim_id, vm_id, change_type) VALUES(#{vnfInstanceId}, #{vnfcInstanceId}, #{vduId}, #{vimid}, #{vmid}, #{changeType})")
+ void insert(AffectedVnfc resource);
+
+ @Delete("DELETE FROM vnfm_vnfc_resource_info WHERE vnf_instance_id = #{vnfcInstanceId}")
+ void deleteByInstanceId(String vnfcInstanceId);
+} \ No newline at end of file
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmJobExecutionMapper.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmJobExecutionMapper.java
new file mode 100644
index 00000000..c95c49c2
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmJobExecutionMapper.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper;
+
+import java.util.List;
+
+import org.apache.ibatis.annotations.Delete;
+import org.apache.ibatis.annotations.Insert;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Result;
+import org.apache.ibatis.annotations.Results;
+import org.apache.ibatis.annotations.Select;
+import org.apache.ibatis.annotations.Update;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+
+@Mapper
+public interface VnfmJobExecutionMapper {
+ @Select("SELECT * FROM vnfm_job_execution_info")
+ @Results({
+ @Result(property = "jobId", column = "job_id"),
+ @Result(property = "vnfmExecutionId", column = "vnfm_execution_id"),
+ @Result(property = "vnfInstanceId", column = "vnf_instance_id"),
+ @Result(property = "vnfmInterfceName", column = "vnfm_interface_name"),
+ @Result(property = "status", column = "status"),
+ @Result(property = "operateStartTime", column = "operate_start_time"),
+ @Result(property = "operateEndTime", column = "operate_end_time")
+ })
+ List<VnfmJobExecutionInfo> getAll();
+
+ @Select("SELECT * FROM vnfm_job_execution_info WHERE job_id = #{jobId}")
+ @Results({
+ @Result(property = "jobId", column = "job_id"),
+ @Result(property = "vnfmExecutionId", column = "vnfm_execution_id"),
+ @Result(property = "vnfInstanceId", column = "vnf_instance_id"),
+ @Result(property = "vnfmInterfceName", column = "vnfm_interface_name"),
+ @Result(property = "status", column = "status"),
+ @Result(property = "operateStartTime", column = "operate_start_time"),
+ @Result(property = "operateEndTime", column = "operate_end_time")
+ })
+ VnfmJobExecutionInfo findOne(Long jobId);
+
+ @Insert("INSERT INTO vnfm_job_execution_info(vnfm_execution_id,vnf_instance_id,vnfm_interface_name,status,operate_start_time, operate_end_time) VALUES(#{vnfmExecutionId}, #{vnfInstanceId}, #{vnfmInterfceName}, #{status}, #{operateStartTime}, #{operateEndTime})")
+ void insert(VnfmJobExecutionInfo user);
+
+ @Update("UPDATE vnfm_job_execution_info SET vnfm_execution_id=#{vnfmExecutionId},vnf_instance_id=#{vnfInstanceId},vnfm_interface_name=#{vnfmInterfceName},status=#{status},operate_start_time=#{operateStartTime}, operate_end_time=#{operateEndTime} WHERE job_id =#{jobId}")
+ void update(VnfmJobExecutionInfo user);
+
+ @Delete("DELETE FROM vnfm_job_execution_info WHERE id =#{id}")
+ void delete(Long id);
+
+ @Select("select * from vnfm_job_execution_info where job_id = (select max(job_id) from vnfm_job_execution_info)")
+ @Results({
+ @Result(property = "jobId", column = "job_id"),
+ @Result(property = "vnfmExecutionId", column = "vnfm_execution_id"),
+ @Result(property = "vnfInstanceId", column = "vnf_instance_id"),
+ @Result(property = "vnfmInterfceName", column = "vnfm_interface_name"),
+ @Result(property = "status", column = "status"),
+ @Result(property = "operateStartTime", column = "operate_start_time"),
+ @Result(property = "operateEndTime", column = "operate_end_time")
+ })
+ VnfmJobExecutionInfo findNewestJobInfo();
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmSubscriptionsMapper.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmSubscriptionsMapper.java
new file mode 100644
index 00000000..6840cf39
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/mapper/VnfmSubscriptionsMapper.java
@@ -0,0 +1,52 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper;
+
+import java.util.List;
+
+import org.apache.ibatis.annotations.Delete;
+import org.apache.ibatis.annotations.Insert;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Result;
+import org.apache.ibatis.annotations.Results;
+import org.apache.ibatis.annotations.Select;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmSubscriptionInfo;
+
+@Mapper
+public interface VnfmSubscriptionsMapper {
+ @Select("SELECT * FROM vnfm_subscription_info")
+ @Results({
+ @Result(property = "id", column = "id"),
+ })
+ List<VnfmSubscriptionInfo> getAll();
+
+ @Select("SELECT * FROM vnfm_subscription_info WHERE id = #{id}")
+ @Results({
+ @Result(property = "id", column = "id"),
+ })
+ VnfmSubscriptionInfo findOne(String id);
+
+// @Insert("INSERT INTO vnfm_subscription_info(id) VALUES(#{id})")
+// void insert(VnfmJobExecutionInfo user);
+
+ @Insert("INSERT INTO vnfm_subscription_info(id) VALUES(#{id})")
+ void insert(String id);
+
+ @Delete("DELETE FROM vnfm_subscription_info WHERE id =#{id}")
+ void delete(String id);
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmJobExecutionRepository.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmJobExecutionRepository.java
index a499f452..4726d9c2 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmJobExecutionRepository.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmJobExecutionRepository.java
@@ -15,9 +15,7 @@
*/
package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
-import org.springframework.data.repository.CrudRepository;
-
-public interface VnfmJobExecutionRepository extends CrudRepository< VnfmJobExecutionInfo, Long> {
+public interface VnfmJobExecutionRepository //extends CrudRepository< VnfmJobExecutionInfo, Long>
+{
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmResourceRepository.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmResourceRepository.java
index 52d41927..1c8456bd 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmResourceRepository.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmResourceRepository.java
@@ -15,9 +15,7 @@
*/
package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmResourceInfo;
-import org.springframework.data.repository.CrudRepository;
-
-public interface VnfmResourceRepository extends CrudRepository<VnfmResourceInfo, Integer> {
+public interface VnfmResourceRepository //extends CrudRepository<VnfmResourceInfo, Integer>
+{
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmSubscriptionsRepository.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmSubscriptionsRepository.java
new file mode 100644
index 00000000..e5d3bd7d
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/db/repository/VnfmSubscriptionsRepository.java
@@ -0,0 +1,24 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmSubscriptionInfo;
+//import org.springframework.data.repository.CrudRepository;
+
+public interface VnfmSubscriptionsRepository //extends CrudRepository<VnfmSubscriptionInfo, Integer>
+{
+
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/CbamNofiticationSubscription.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/CbamNofiticationSubscription.java
new file mode 100644
index 00000000..32cb2fa0
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/CbamNofiticationSubscription.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.init;
+
+import java.io.IOException;
+import java.util.List;
+
+import org.apache.http.client.ClientProtocolException;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.Subscription;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmSubscriptionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmSubscriptionsMapper;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.ApplicationArguments;
+import org.springframework.boot.ApplicationRunner;
+import org.springframework.core.annotation.Order;
+import org.springframework.stereotype.Component;
+
+//@Order(3)
+//@Component
+public class CbamNofiticationSubscription implements ApplicationRunner {
+ private static final Logger logger = LoggerFactory.getLogger(CbamNofiticationSubscription.class);
+
+ @Autowired
+ AdaptorEnv adaptorEnv;
+
+ @Autowired
+ private CbamMgmrInf cbamMgmr;
+
+ @Autowired
+ private VnfmSubscriptionsMapper subscriptionsMapper;
+
+ @Override
+ public void run(ApplicationArguments args){
+ boolean subscribed = false;
+ List<VnfmSubscriptionInfo> allSubscripions = subscriptionsMapper.getAll();
+ if(allSubscripions != null && !allSubscripions.isEmpty())
+ {
+ for(VnfmSubscriptionInfo subscriptionInfo : allSubscripions)
+ {
+ try {
+ Subscription subscription = cbamMgmr.getSubscription(subscriptionInfo.getId());
+ if(subscription != null)
+ {
+ subscribed = true;
+ logger.info("CBAM Notification has already been subscribed with id = " + subscriptionInfo.getId());
+ }
+ else
+ {
+ subscriptionsMapper.delete(subscriptionInfo.getId());
+ }
+ } catch (Exception e) {
+ logger.error("Query or delete subscription error.", e);
+ }
+ }
+ }
+
+ if(!subscribed)
+ {
+ CBAMCreateSubscriptionRequest subscriptionRequest = new CBAMCreateSubscriptionRequest();
+ subscriptionRequest.setCallbackUrl(adaptorEnv.getDriverApiUriFront() + "/api/nokiavnfmdriver/v1/notifications");
+ try {
+ CBAMCreateSubscriptionResponse createSubscription = cbamMgmr.createSubscription(subscriptionRequest);
+ if(createSubscription != null)
+ {
+ subscriptionsMapper.insert(createSubscription.getId());
+ logger.info("CBAM Notification is successfully subscribed with id = " + createSubscription.getId());
+ }
+ } catch (Exception e) {
+ logger.error("Subscribe notification error.", e);
+ }
+ }
+ }
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/EnvVariablesInitialization.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/EnvVariablesInitialization.java
index 81cc281d..b9d4e878 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/EnvVariablesInitialization.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/EnvVariablesInitialization.java
@@ -30,8 +30,10 @@ import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
+import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
+@Order(1)
@Component
public class EnvVariablesInitialization implements ApplicationRunner {
private static final Logger logger = LoggerFactory.getLogger(EnvVariablesInitialization.class);
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegister.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/MsbServiceRegister.java
index d9a36e08..4358fb05 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegister.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/init/MsbServiceRegister.java
@@ -14,7 +14,7 @@
* limitations under the License.
*/
-package org.onap.vfc.nfvo.driver.vnfm.svnfm.msb.service;
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.init;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@@ -22,8 +22,10 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.msb.inf.IMsbMgmr;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
+import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
+@Order(2)
@Component
public class MsbServiceRegister implements ApplicationRunner{
private static final Logger logger = LoggerFactory.getLogger(MsbServiceRegister.class);
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImpl.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImpl.java
index e89eabe1..74fb4395 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImpl.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImpl.java
@@ -18,6 +18,8 @@ package org.onap.vfc.nfvo.driver.vnfm.svnfm.msb.impl;
import java.io.IOException;
import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
import org.apache.http.client.ClientProtocolException;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
@@ -35,6 +37,9 @@ import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RequestMethod;
import com.google.gson.Gson;
+import com.google.gson.JsonArray;
+import com.google.gson.JsonObject;
+import com.google.gson.JsonParser;
@Component
public class MsbMgmrImpl implements IMsbMgmr {
@@ -82,32 +87,31 @@ public class MsbMgmrImpl implements IMsbMgmr {
private String readVfcAdaptorInfoFromJsonFile() throws IOException {
String filePath = "/etc/adapterInfo/vnfmadapterinfo.json";
- String fileContent = CommonUtil.getJsonStrFromFile(filePath);
-
+ String fileContent = CommonUtil.getJsonStrFromFile(filePath);
return fileContent;
}
@Override
public void unregister() {
- try {
- String url = adaptorEnv.getMsbApiUriFront() + String.format(CommonConstants.MSB_UNREGISTER_SERVICE_PATH);
-
- HttpResult httpResult = httpClientProcessor.process(url, RequestMethod.DELETE, null, null);
- String responseStr = httpResult.getContent();
-
- logger.info("MsbMgmrImpl -> unregister, responseStr is " + responseStr);
- if(httpResult.getStatusCode() == 204)
- {
- logger.info("MsbMgmrImpl -> register, Successfully ");
- }
- else
- {
- logger.error("MsbMgmrImpl -> register Error, statusCode = " + httpResult.getStatusCode());
- }
-
- } catch (Exception e) {
- logger.error("IOException Failed to unregister nokia vnfm driver! ", e);
- }
+// try {
+// String url = adaptorEnv.getMsbApiUriFront() + String.format(CommonConstants.MSB_UNREGISTER_SERVICE_PATH);
+//
+// HttpResult httpResult = httpClientProcessor.process(url, RequestMethod.DELETE, null, null);
+// String responseStr = httpResult.getContent();
+//
+// logger.info("MsbMgmrImpl -> unregister, responseStr is " + responseStr);
+// if(httpResult.getStatusCode() == 204)
+// {
+// logger.info("MsbMgmrImpl -> register, Successfully ");
+// }
+// else
+// {
+// logger.error("MsbMgmrImpl -> register Error, statusCode = " + httpResult.getStatusCode());
+// }
+//
+// } catch (Exception e) {
+// logger.error("IOException Failed to unregister nokia vnfm driver! ", e);
+// }
}
@@ -142,9 +146,11 @@ public class MsbMgmrImpl implements IMsbMgmr {
this.adaptorEnv = env;
}
- public static final void main(String[] args) {
- MsbMgmrImpl impl = new MsbMgmrImpl();
- impl.register();
- }
+// public static final void main(String[] args) {
+//// MsbMgmrImpl impl = new MsbMgmrImpl();
+//// impl.register();
+// System.setProperty("catalina.base", "D:\\Install\\apache-tomcat-9.0.0.M26");
+// System.out.println(System.getProperty("catalina.base"));
+// }
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nslcm/bo/entity/AffectedVnfc.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nslcm/bo/entity/AffectedVnfc.java
index a586cfc4..c8e1c917 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nslcm/bo/entity/AffectedVnfc.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nslcm/bo/entity/AffectedVnfc.java
@@ -17,9 +17,13 @@ package org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
+import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;
public class AffectedVnfc {
+ @JsonIgnore
+ private String vnfInstanceId;
+
@JsonProperty("vnfcInstanceId")
private String vnfcInstanceId;
@@ -74,6 +78,14 @@ public class AffectedVnfc {
public void setVmid(String vmid) {
this.vmid = vmid;
}
+
+ public String getVnfInstanceId() {
+ return vnfInstanceId;
+ }
+
+ public void setVnfInstanceId(String vnfInstanceId) {
+ this.vnfInstanceId = vnfInstanceId;
+ }
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/controller/VnfmDriverController.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/controller/VnfmDriverController.java
index c51717d8..b6bf3eb0 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/controller/VnfmDriverController.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/controller/VnfmDriverController.java
@@ -18,10 +18,13 @@ package org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.controller;
import java.io.IOException;
+import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.io.IOUtils;
import org.apache.http.HttpStatus;
+import org.apache.http.client.ClientProtocolException;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.exception.VnfmDriverException;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfResponse;
@@ -36,6 +39,7 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.inf.VnfmDriverMgmrInf;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
+import org.slf4j.MDC;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Controller;
@@ -55,19 +59,24 @@ public class VnfmDriverController {
@Autowired
private VnfmDriverMgmrInf vnfmDriverMgmr;
+ @Autowired
+ private CbamMgmrInf cbamMgmr;
+
private Gson gson = new Gson();
@RequestMapping(value = "/swagger.json", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
@ResponseBody
public String apidoc() throws IOException {
- ClassLoader classLoader = getClass().getClassLoader();
+// String client = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest().getRemoteAddr();
+ ClassLoader classLoader = getClass().getClassLoader();
return IOUtils.toString(classLoader.getResourceAsStream("swagger.json"));
}
@RequestMapping(value = "/{vnfmId}/vnfs", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE, consumes = MediaType.APPLICATION_JSON_VALUE)
- @ResponseBody
+ @ResponseBody
public InstantiateVnfResponse instantiateVnf(@RequestBody InstantiateVnfRequest request, @PathVariable("vnfmId") String vnfmId, HttpServletResponse httpResponse)
{
+ MDC.put("MDCtest", "MDCtest_001");
String jsonString = gson.toJson(request);
logger.info("instantiateVnf request: vnfmId = " + vnfmId + ", bodyMessage is " + jsonString);
@@ -186,6 +195,31 @@ public class VnfmDriverController {
return null;
}
+
+// @RequestMapping(value = "/notifications", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE, consumes = MediaType.APPLICATION_JSON_VALUE)
+// public CBAMVnfNotificationResponse notificationVnf(@RequestBody CBAMVnfNotificationRequest request, HttpServletResponse httpResponse) throws ClientProtocolException, Exception
+ @RequestMapping(value = "/notifications")
+// @ResponseBody
+ public void notificationVnf(HttpServletRequest request, HttpServletResponse httpResponse) throws ClientProtocolException, Exception
+ {
+
+// String jsonString = gson.toJson(request);
+// logger.info("notificationVnf request: bodyMessage is " + jsonString);
+ logger.info("notificationVnf request: bodyMessage is " + request.getMethod() + ",");
+
+ try {
+// CBAMVnfNotificationResponse response = cbamMgmr.getNotification(request);
+ httpResponse.setStatus(204);
+// logger.info("cbamController --> notificationVnf response is " + gson.toJson(response));
+// return response;
+ }
+ catch(VnfmDriverException e)
+ {
+ processControllerException(httpResponse, e);
+ }
+
+// return null;
+ }
private void processControllerException(HttpServletResponse httpResponse, VnfmDriverException e) {
try {
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/impl/VnfContinueProcessorImpl.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/impl/VnfContinueProcessorImpl.java
index 93c52b07..b9fb3e81 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/impl/VnfContinueProcessorImpl.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/impl/VnfContinueProcessorImpl.java
@@ -19,13 +19,18 @@ package org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.impl;
import java.util.concurrent.Executors;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor.Driver2CbamRequestConverter;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor.HealVnfContinueRunnable;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor.InstantiateVnfContinueRunnable;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor.ScaleVnfContinueRunnable;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor.TerminateVnfContinueRunnable;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.catalog.inf.CatalogMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfcResourceInfoMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.inf.VnfContinueProcessorInf;
import org.springframework.stereotype.Component;
@@ -34,19 +39,39 @@ import org.springframework.stereotype.Component;
public class VnfContinueProcessorImpl implements VnfContinueProcessorInf{
@Override
- public void continueInstantiateVnf(String vnfmId, InstantiateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CatalogMgmrInf catalogMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionRepository jobDbManager) {
+ public void continueInstantiateVnf(String vnfmId, InstantiateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CatalogMgmrInf catalogMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper jobDbManager, VnfcResourceInfoMapper vnfcDbMgmr) {
InstantiateVnfContinueRunnable task = new InstantiateVnfContinueRunnable(vnfmId, driverRequest, vnfInstanceId, jobId,
- nslcmMgmr, catalogMgmr, cbamMgmr, requestConverter, jobDbManager);
+ nslcmMgmr, catalogMgmr, cbamMgmr, requestConverter, jobDbManager, vnfcDbMgmr);
Executors.newSingleThreadExecutor().submit(task);
}
@Override
- public void continueTerminateVnf(String vnfmId, TerminateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionRepository jobDbManager) {
+ public void continueTerminateVnf(String vnfmId, TerminateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper jobDbManager, VnfcResourceInfoMapper vnfcDbMgmr) {
TerminateVnfContinueRunnable task = new TerminateVnfContinueRunnable(vnfmId, driverRequest, vnfInstanceId, jobId,
+ nslcmMgmr, cbamMgmr, requestConverter, jobDbManager, vnfcDbMgmr);
+
+ Executors.newSingleThreadExecutor().submit(task);
+ }
+
+ @Override
+ public void continueScaleVnf(String vnfmId, ScaleVnfRequest driverRequest, String vnfInstanceId, String jobId,
+ NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter,
+ VnfmJobExecutionMapper jobDbManager) {
+ ScaleVnfContinueRunnable task = new ScaleVnfContinueRunnable(vnfmId, driverRequest, vnfInstanceId, jobId,
nslcmMgmr, cbamMgmr, requestConverter, jobDbManager);
+ Executors.newSingleThreadExecutor().submit(task);
+ }
+
+ @Override
+ public void continueHealVnf(String vnfmId, HealVnfRequest driverRequest, String vnfInstanceId, String jobId,
+ NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter,
+ VnfmJobExecutionMapper jobDbManager) {
+ HealVnfContinueRunnable task = new HealVnfContinueRunnable(vnfmId, driverRequest, vnfInstanceId, jobId,
+ nslcmMgmr, cbamMgmr, requestConverter, jobDbManager);
Executors.newSingleThreadExecutor().submit(task);
+
}
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/inf/VnfContinueProcessorInf.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/inf/VnfContinueProcessorInf.java
index 6f9eb036..e0c1b6d0 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/inf/VnfContinueProcessorInf.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/vnfmdriver/inf/VnfContinueProcessorInf.java
@@ -19,12 +19,17 @@ package org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.inf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor.Driver2CbamRequestConverter;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.catalog.inf.CatalogMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfcResourceInfoMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfRequest;
public interface VnfContinueProcessorInf {
- public void continueInstantiateVnf(String vnfmId, InstantiateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CatalogMgmrInf catalogMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionRepository jobDbManager);
- public void continueTerminateVnf(String vnfmId, TerminateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionRepository jobDbManager);
+ public void continueInstantiateVnf(String vnfmId, InstantiateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CatalogMgmrInf catalogMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper jobDbManager, VnfcResourceInfoMapper vnfcDbMgmr);
+ public void continueTerminateVnf(String vnfmId, TerminateVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper jobDbManager, VnfcResourceInfoMapper vnfcDbMgmr);
+ public void continueScaleVnf(String vnfmId, ScaleVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper jobDbManager);
+ public void continueHealVnf(String vnfmId, HealVnfRequest driverRequest, String vnfInstanceId, String jobId, NslcmMgmrInf nslcmMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionMapper jobDbManager);
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/application.properties b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/application.properties
index 5665ff0b..2b870c0a 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/application.properties
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/application.properties
@@ -16,21 +16,26 @@
server.error.whitelabel.enabled=false
## for MySql Database begin ##
-spring.jpa.show-sql=true
-spring.jpa.generate-ddl=true
-spring.jpa.hibernate.ddl-auto=update
-spring.jpa.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
+#spring.jpa.show-sql=true
+#spring.jpa.generate-ddl=true
+#spring.jpa.hibernate.ddl-auto=update
+#spring.jpa.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
spring.jackson.serialization.indent_output=false
+#mybatis configuration
+mybatis.type-aliases-package=org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean
+#spring.datasource.driverClassName = com.mysql.jdbc.Driver
+spring.datasource.driverClassName = org.mariadb.jdbc.Driver
spring.datasource.username=vnfm
spring.datasource.password=vnfmpass
-spring.datasource.url=jdbc:mysql://127.0.0.1:3306/vnfm_db?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=round&useSSL=false
+#spring.datasource.url=jdbc:mysql://127.0.0.1:3306/vnfm_db?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=round&useSSL=false
+spring.datasource.url=jdbc:mariadb://127.0.0.1:3306/vnfm_db?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=round&useSSL=false
-spring.datasource.driver-class-name=com.mysql.jdbc.Driver
-spring.datasource.tomcat.max-wait=30000
-spring.datasource.tomcat.max-active=20
-spring.datasource.tomcat.test-on-borrow=true
+#spring.datasource.driver-class-name=com.mysql.jdbc.Driver
+#spring.datasource.tomcat.max-wait=30000
+#spring.datasource.tomcat.max-active=20
+#spring.datasource.tomcat.test-on-borrow=true
## for MySql Database end ##
## for logging begin ##
@@ -64,3 +69,10 @@ type=vdu
sizeOfStorage=40
virtualMemSize=8192
numVirtualCpu=4
+
+##OperateTaskProgress
+initialProgress=10
+instantiateTimeInterval=60000
+terminateTimeInterval=8000
+
+driverApiUriFront=http://127.0.0.1:8486
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/logback.xml b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/logback.xml
new file mode 100644
index 00000000..d1be476b
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/resources/logback.xml
@@ -0,0 +1,31 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<configuration>
+ <include resource="org/springframework/boot/logging/logback/defaults.xml" />
+ <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
+ <encoder>
+ <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{35} - %msg %n</pattern>
+ <charset>UTF-8</charset>
+ </encoder>
+ </appender>
+ <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
+ <file>${catalina.base}/logs/vfcadaptor.log</file>
+ <rollingPolicy
+ class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
+ <fileNamePattern>${catalina.base}/logs/vfcadaptor.%i.log.zip
+ </fileNamePattern>
+ <minIndex>1</minIndex>
+ <maxIndex>9</maxIndex>
+ </rollingPolicy>
+ <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
+ <maxFileSize>10MB</maxFileSize>
+ </triggeringPolicy>
+ <encoder>
+ <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %X{req.method} %X{req.remoteHost} %X{req.requestURI} [%t] %-5level %logger{50} %line - %m%n</pattern>
+ <charset>UTF-8</charset> <!-- 此处设置字符集 -->
+ </encoder>
+ </appender>
+ <root level="INFO">
+ <appender-ref ref="CONSOLE"></appender-ref>
+ <appender-ref ref="FILE"></appender-ref>
+ </root>
+</configuration> \ No newline at end of file
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/webapp/WEB-INF/web.xml b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/webapp/WEB-INF/web.xml
index e6aa9856..c2a984b8 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/webapp/WEB-INF/web.xml
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/main/webapp/WEB-INF/web.xml
@@ -11,6 +11,16 @@
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
-->
+ <filter>
+ <filter-name>MDCInsertingServletFilter</filter-name>
+ <filter-class>
+ ch.qos.logback.classic.helpers.MDCInsertingServletFilter
+ </filter-class>
+ </filter>
+ <filter-mapping>
+ <filter-name>MDCInsertingServletFilter</filter-name>
+ <url-pattern>/*</url-pattern>
+ </filter-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnableTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnableTest.java
new file mode 100644
index 00000000..e2d431f1
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/HealVnfContinueRunnableTest.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
+
+import static org.mockito.Mockito.doNothing;
+import static org.mockito.Mockito.when;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.MockitoAnnotations;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
+
+public class HealVnfContinueRunnableTest {
+ @InjectMocks
+ private HealVnfContinueRunnable healVnfContinueRunnable;
+
+ @Mock
+ private CbamMgmrInf cbamMgmr;
+
+ @Mock
+ private NslcmMgmrInf nslcmMgmr;
+
+ @Mock
+ private VnfmJobExecutionMapper jobDbMgmr;
+
+ @Before
+ public void setUp() throws Exception {
+ MockitoAnnotations.initMocks(this);
+ HealVnfRequest driverRequest = new HealVnfRequest();
+ Driver2CbamRequestConverter requestConverter = new Driver2CbamRequestConverter();
+ String vnfInstanceId = "vnfInstanceId_001";
+ String jobId = "001";
+ String vnfmId = "vnfmId_001";
+
+ healVnfContinueRunnable.setDriverRequest(driverRequest);
+ healVnfContinueRunnable.setRequestConverter(requestConverter);
+ healVnfContinueRunnable.setVnfInstanceId(vnfInstanceId);
+ healVnfContinueRunnable.setJobId(jobId);
+ healVnfContinueRunnable.setVnfmId(vnfmId);
+
+ NslcmGrantVnfResponse grantResponse = new NslcmGrantVnfResponse();
+ CBAMHealVnfResponse cbamResponse = new CBAMHealVnfResponse();
+ cbamResponse.setId("1");
+ VnfmJobExecutionInfo execInfo = new VnfmJobExecutionInfo();
+ execInfo.setJobId(1L);
+
+ when(nslcmMgmr.grantVnf(Mockito.any(NslcmGrantVnfRequest.class))).thenReturn(grantResponse);
+ when(cbamMgmr.healVnf(Mockito.any(CBAMHealVnfRequest.class), Mockito.anyString())).thenReturn(cbamResponse);
+ when(jobDbMgmr.findOne(Mockito.anyLong())).thenReturn(execInfo);
+ doNothing().when(jobDbMgmr).update(Mockito.any(VnfmJobExecutionInfo.class));
+
+ }
+
+ @Test
+ public void testRun()
+ {
+ healVnfContinueRunnable.run();
+ }
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnableTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnableTest.java
new file mode 100644
index 00000000..d4d13458
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/InstantiateVnfContinueRunnableTest.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
+
+import static org.mockito.Mockito.doNothing;
+import static org.mockito.Mockito.when;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.MockitoAnnotations;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMInstantiateVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMInstantiateVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMModifyVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMModifyVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryOperExecutionResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.ComputeResource;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VnfcResourceInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum.OperationStatus;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfcResourceInfoMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.AffectedVnfc;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
+
+public class InstantiateVnfContinueRunnableTest{
+ @InjectMocks
+ private InstantiateVnfContinueRunnable instantiateVnfContinueRunnable;
+
+ @Mock
+ private CbamMgmrInf cbamMgmr;
+
+ @Mock
+ private NslcmMgmrInf nslcmMgmr;
+
+ @Mock
+ private VnfmJobExecutionMapper jobDbMgmr;
+
+ @Mock
+ private VnfcResourceInfoMapper vnfcDbMgmr;
+
+ @Before
+ public void setUp() throws Exception {
+ MockitoAnnotations.initMocks(this);
+ InstantiateVnfRequest driverRequest = new InstantiateVnfRequest();
+ Driver2CbamRequestConverter requestConverter = new Driver2CbamRequestConverter();
+
+ instantiateVnfContinueRunnable.setDriverRequest(driverRequest);
+ instantiateVnfContinueRunnable.setJobId("1");
+ instantiateVnfContinueRunnable.setVnfInstanceId("001");
+ instantiateVnfContinueRunnable.setVnfmId("001");
+ instantiateVnfContinueRunnable.setRequestConverter(requestConverter);
+
+ NslcmGrantVnfResponse grantResponse = new NslcmGrantVnfResponse();
+ CBAMInstantiateVnfResponse cbamResponse = new CBAMInstantiateVnfResponse();
+ cbamResponse.setId("1");
+ CBAMModifyVnfResponse modifyResponse = new CBAMModifyVnfResponse();
+ modifyResponse.setId("2");
+ VnfmJobExecutionInfo execInfo = new VnfmJobExecutionInfo();
+ execInfo.setJobId(1L);
+
+ CBAMQueryOperExecutionResponse exeResponse = new CBAMQueryOperExecutionResponse();
+ exeResponse.setStatus(OperationStatus.FINISHED);
+
+ List<VnfcResourceInfo> vnfcResources = new ArrayList<>();
+ VnfcResourceInfo res = new VnfcResourceInfo();
+ res.setId("1");
+ res.setVduId("vduId");
+ ComputeResource computeResource = new ComputeResource();
+ computeResource.setResourceId("resourceId");
+ computeResource.setResourceType("OS::Nova::Server");
+ computeResource.setVimId("vimId");
+ res.setComputeResource(computeResource);
+
+ vnfcResources.add(res);
+
+ when(nslcmMgmr.grantVnf(Mockito.any(NslcmGrantVnfRequest.class))).thenReturn(grantResponse);
+ when(cbamMgmr.instantiateVnf(Mockito.any(CBAMInstantiateVnfRequest.class), Mockito.anyString())).thenReturn(cbamResponse);
+ when(cbamMgmr.modifyVnf(Mockito.any(CBAMModifyVnfRequest.class), Mockito.anyString())).thenReturn(modifyResponse);
+ when(cbamMgmr.queryOperExecution(Mockito.anyString())).thenReturn(exeResponse);
+ when(cbamMgmr.queryVnfcResource(Mockito.anyString())).thenReturn(vnfcResources);
+ when(jobDbMgmr.findOne(Mockito.anyLong())).thenReturn(execInfo);
+ doNothing().when(jobDbMgmr).update(Mockito.any(VnfmJobExecutionInfo.class));
+ doNothing().when(vnfcDbMgmr).insert(Mockito.any(AffectedVnfc.class));
+ }
+
+ @Test
+ public void testRun()
+ {
+ instantiateVnfContinueRunnable.run();
+ }
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnableTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnableTest.java
new file mode 100644
index 00000000..b2109a13
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/ScaleVnfContinueRunnableTest.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
+
+import static org.mockito.Mockito.doNothing;
+import static org.mockito.Mockito.when;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.MockitoAnnotations;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.ScaleType;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfRequest;
+
+public class ScaleVnfContinueRunnableTest{
+ @InjectMocks
+ private ScaleVnfContinueRunnable scaleVnfContinueRunnable;
+
+ @Mock
+ private CbamMgmrInf cbamMgmr;
+
+ @Mock
+ private NslcmMgmrInf nslcmMgmr;
+
+ @Mock
+ private VnfmJobExecutionMapper jobDbMgmr;
+
+ @Before
+ public void setUp() throws Exception {
+ MockitoAnnotations.initMocks(this);
+ ScaleVnfRequest driverRequest = new ScaleVnfRequest();
+ driverRequest.setType(ScaleType.SCALE_IN);
+ Driver2CbamRequestConverter requestConverter = new Driver2CbamRequestConverter();
+
+ scaleVnfContinueRunnable.setDriverRequest(driverRequest);
+ scaleVnfContinueRunnable.setJobId("1");
+ scaleVnfContinueRunnable.setType(ScaleType.SCALE_IN);
+ scaleVnfContinueRunnable.setVnfInstanceId("001");
+ scaleVnfContinueRunnable.setVnfmId("001");
+ scaleVnfContinueRunnable.setRequestConverter(requestConverter);
+
+ NslcmGrantVnfResponse grantResponse = new NslcmGrantVnfResponse();
+ CBAMScaleVnfResponse cbamResponse = new CBAMScaleVnfResponse();
+ cbamResponse.setId("1");
+ VnfmJobExecutionInfo execInfo = new VnfmJobExecutionInfo();
+ execInfo.setJobId(1L);
+
+ when(nslcmMgmr.grantVnf(Mockito.any(NslcmGrantVnfRequest.class))).thenReturn(grantResponse);
+ when(cbamMgmr.scaleVnf(Mockito.any(CBAMScaleVnfRequest.class), Mockito.anyString())).thenReturn(cbamResponse);
+ when(jobDbMgmr.findOne(Mockito.anyLong())).thenReturn(execInfo);
+ doNothing().when(jobDbMgmr).update(Mockito.any(VnfmJobExecutionInfo.class));
+ }
+
+ @Test
+ public void testRun()
+ {
+ scaleVnfContinueRunnable.run();
+ }
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TermiateVnfContinueRunnableTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TermiateVnfContinueRunnableTest.java
new file mode 100644
index 00000000..96808ad7
--- /dev/null
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/TermiateVnfContinueRunnableTest.java
@@ -0,0 +1,110 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
+
+import static org.mockito.Mockito.doNothing;
+import static org.mockito.Mockito.when;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.MockitoAnnotations;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMModifyVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryOperExecutionResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.ComputeResource;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VnfcResourceInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum.OperationStatus;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfcResourceInfoMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.AffectedVnfc;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfRequest;
+
+public class TermiateVnfContinueRunnableTest{
+ @InjectMocks
+ private TerminateVnfContinueRunnable terminateVnfContinueRunnable;
+
+ @Mock
+ private CbamMgmrInf cbamMgmr;
+
+ @Mock
+ private NslcmMgmrInf nslcmMgmr;
+
+ @Mock
+ private VnfmJobExecutionMapper jobDbMgmr;
+
+ @Mock
+ private VnfcResourceInfoMapper vnfcDbMgmr;;
+
+ @Before
+ public void setUp() throws Exception {
+ MockitoAnnotations.initMocks(this);
+ TerminateVnfRequest driverRequest = new TerminateVnfRequest();
+ Driver2CbamRequestConverter requestConverter = new Driver2CbamRequestConverter();
+
+ terminateVnfContinueRunnable.setDriverRequest(driverRequest);
+ terminateVnfContinueRunnable.setJobId("1");
+ terminateVnfContinueRunnable.setVnfInstanceId("001");
+ terminateVnfContinueRunnable.setVnfmId("001");
+ terminateVnfContinueRunnable.setRequestConverter(requestConverter);
+
+ NslcmGrantVnfResponse grantResponse = new NslcmGrantVnfResponse();
+ CBAMTerminateVnfResponse cbamResponse = new CBAMTerminateVnfResponse();
+ cbamResponse.setId("1");
+ CBAMModifyVnfResponse modifyResponse = new CBAMModifyVnfResponse();
+ modifyResponse.setId("2");
+ VnfmJobExecutionInfo execInfo = new VnfmJobExecutionInfo();
+ execInfo.setJobId(1L);
+
+ CBAMQueryOperExecutionResponse exeResponse = new CBAMQueryOperExecutionResponse();
+ exeResponse.setStatus(OperationStatus.FINISHED);
+
+ List<AffectedVnfc> vnfcResources = new ArrayList<>();
+
+ CBAMQueryVnfResponse cQueryVnfResponse = new CBAMQueryVnfResponse();
+ cQueryVnfResponse.setInstantiationState(CommonEnum.InstantiationState.NOT_INSTANTIATED);
+
+ when(nslcmMgmr.grantVnf(Mockito.any(NslcmGrantVnfRequest.class))).thenReturn(grantResponse);
+ when(cbamMgmr.terminateVnf(Mockito.any(CBAMTerminateVnfRequest.class), Mockito.anyString())).thenReturn(cbamResponse);
+ when(cbamMgmr.queryVnf(Mockito.anyString())).thenReturn(cQueryVnfResponse);
+ doNothing().when(cbamMgmr).deleteVnf(Mockito.anyString());
+
+ when(vnfcDbMgmr.getAllByInstanceId(Mockito.anyString())).thenReturn(vnfcResources);
+ when(cbamMgmr.queryOperExecution(Mockito.anyString())).thenReturn(exeResponse);
+ when(jobDbMgmr.findOne(Mockito.anyLong())).thenReturn(execInfo);
+ doNothing().when(jobDbMgmr).update(Mockito.any(VnfmJobExecutionInfo.class));
+ }
+
+ @Test
+ public void testRun()
+ {
+ terminateVnfContinueRunnable.run();
+ }
+}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImplTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImplTest.java
index b47cc4db..f3fb6f3b 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImplTest.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/adaptor/VnfmDriverMgmrImplTest.java
@@ -49,7 +49,7 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.ScaleType;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.mapper.VnfmJobExecutionMapper;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.exception.VnfmDriverException;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
@@ -82,7 +82,7 @@ public class VnfmDriverMgmrImplTest {
private NslcmMgmrInf nslcmMgmr;;
@Mock
- private VnfmJobExecutionRepository jobDbManager;
+ private VnfmJobExecutionMapper jobDbManager;
@Mock
private VnfContinueProcessorInf vnfContinueProcessorInf;
@@ -96,6 +96,8 @@ public class VnfmDriverMgmrImplTest {
private String vnfmId = "vnfmId_001";
private String vnfInstanceId = "vnfInstanceId_001";
+ private ScaleType type;
+
private String protocol = "https";
private String ip = "139.234.34.43";
private String port = "99";
@@ -135,7 +137,7 @@ public class VnfmDriverMgmrImplTest {
execInfo.setVnfmExecutionId("executionId_001");
execInfo.setVnfInstanceId(vnfInstanceId);
- when(jobDbManager.save(Mockito.any(VnfmJobExecutionInfo.class))).thenReturn(execInfo);
+ when(jobDbManager.findNewestJobInfo()).thenReturn(execInfo);
}
@Test
@@ -200,6 +202,7 @@ public class VnfmDriverMgmrImplTest {
VnfmJobExecutionInfo execInfo = new VnfmJobExecutionInfo();
execInfo.setJobId(1L);
execInfo.setVnfmExecutionId("executionId_001");
+ execInfo.setStatus("finished");
when(jobDbManager.findOne(Mockito.anyLong())).thenReturn(execInfo);
CBAMQueryOperExecutionResponse cbamResponse = new CBAMQueryOperExecutionResponse();
@@ -208,7 +211,7 @@ public class VnfmDriverMgmrImplTest {
cbamResponse.setGrantId("001002001");
// when(cbamMgmr.queryOperExecution(Mockito.anyString())).thenReturn(cbamResponse);
-// OperStatusVnfResponse response = vnfmDriverMgmr.getOperStatus(vnfmId, "1");
+ OperStatusVnfResponse response = vnfmDriverMgmr.getOperStatus(vnfmId, "1");
//
// Assert.assertEquals("executionId_001", response.getJobId());
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImplTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImplTest.java
index 900e7021..aba3d88b 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImplTest.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/cbam/impl/CbamMgmrImplTest.java
@@ -20,6 +20,7 @@ import static org.mockito.Mockito.when;
import java.io.IOException;
import java.util.HashMap;
+import java.util.List;
import org.apache.http.client.ClientProtocolException;
import org.junit.Before;
@@ -28,17 +29,26 @@ import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.Mockito;
import org.mockito.MockitoAnnotations;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateSubscriptionResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMInstantiateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMInstantiateVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMModifyVnfRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMModifyVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryOperExecutionResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfRequest;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMVnfNotificationRequest;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMVnfNotificationResponse;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.Subscription;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VnfcResourceInfo;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.http.client.HttpClientProcessorInf;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.http.client.HttpResult;
@@ -61,6 +71,7 @@ public class CbamMgmrImplTest {
String json = "{\"access_token\":\"1234567\"}";
HttpResult httpResult = new HttpResult();
+ httpResult.setStatusCode(200);
httpResult.setContent(json);
when(httpClientProcessor.process(Mockito.anyString(), Mockito.any(RequestMethod.class), Mockito.any(HashMap.class), Mockito.anyString())).thenReturn(httpResult);
@@ -81,6 +92,13 @@ public class CbamMgmrImplTest {
}
@Test
+ public void testModifyVnf() throws ClientProtocolException, IOException
+ {
+ CBAMModifyVnfRequest cbamRequest = new CBAMModifyVnfRequest();
+ CBAMModifyVnfResponse response = cbamMgmr.modifyVnf(cbamRequest, vnfInstanceId);
+ }
+
+ @Test
public void testTerminateVnf() throws ClientProtocolException, IOException
{
CBAMTerminateVnfRequest cbamRequest = new CBAMTerminateVnfRequest();
@@ -112,4 +130,51 @@ public class CbamMgmrImplTest {
{
CBAMQueryVnfResponse response = cbamMgmr.queryVnf(vnfInstanceId);
}
+
+ @Test
+ public void testCreateSubscription() throws ClientProtocolException, IOException
+ {
+ CBAMCreateSubscriptionRequest cbamRequest = new CBAMCreateSubscriptionRequest();
+ CBAMCreateSubscriptionResponse response = cbamMgmr.createSubscription(cbamRequest);
+ }
+
+ @Test
+ public void testGetNotification() throws ClientProtocolException, IOException
+ {
+ CBAMVnfNotificationRequest cbamRequest = new CBAMVnfNotificationRequest();
+ CBAMVnfNotificationResponse response = cbamMgmr.getNotification(cbamRequest);
+ }
+
+ @Test
+ public void testGetSubscription() throws ClientProtocolException, IOException
+ {
+ String subscriptionId = "subscriptionId_001";
+ Subscription response = cbamMgmr.getSubscription(subscriptionId);
+ }
+
+ @Test
+ public void testQueryVnfcResource() throws ClientProtocolException, IOException
+ {
+ String json = "[{'id':'id_001'}]";
+ HttpResult httpResult = new HttpResult();
+ httpResult.setStatusCode(200);
+ httpResult.setContent(json);
+
+ when(httpClientProcessor.process(Mockito.anyString(), Mockito.any(RequestMethod.class), Mockito.any(HashMap.class), Mockito.anyString())).thenReturn(httpResult);
+ List<VnfcResourceInfo> response = cbamMgmr.queryVnfcResource(vnfInstanceId);
+ }
+
+ @Test
+ public void testQueryOperExecution() throws ClientProtocolException, IOException
+ {
+ String execId = "execId_001";
+ CBAMQueryOperExecutionResponse response = cbamMgmr.queryOperExecution(execId);
+ }
+
+ @Test
+ public void testUploadVnfPackage() throws ClientProtocolException, IOException
+ {
+ String cbamPackageFilePath = "cbamPackageFilePath_001";
+ cbamMgmr.uploadVnfPackage(cbamPackageFilePath);
+ }
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImplTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImplTest.java
index aa1a0217..1b9be3b4 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImplTest.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/impl/MsbMgmrImplTest.java
@@ -52,6 +52,7 @@ public class MsbMgmrImplTest {
String json = "{\"serviceName\":\"catalog\", \"url\":\"/api/catalog/v1\"}";
HttpResult httpResult = new HttpResult();
httpResult.setContent(json);
+ httpResult.setStatusCode(200);
when(httpClientProcessor.process(Mockito.anyString(), Mockito.any(RequestMethod.class), Mockito.any(HashMap.class), Mockito.anyString())).thenReturn(httpResult);
}
diff --git a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegisterTest.java b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegisterTest.java
index 8741bc80..0319735a 100644
--- a/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegisterTest.java
+++ b/nokia/vnfmdriver/vfcadaptorservice/vfcadaptor/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/msb/service/MsbServiceRegisterTest.java
@@ -24,6 +24,7 @@ import org.junit.Test;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.init.MsbServiceRegister;
import org.onap.vfc.nfvo.driver.vnfm.svnfm.msb.inf.IMsbMgmr;
import org.springframework.boot.ApplicationArguments;
diff --git a/nokiav2/.gitignore b/nokiav2/.gitignore
new file mode 100644
index 00000000..88783a3b
--- /dev/null
+++ b/nokiav2/.gitignore
@@ -0,0 +1,7 @@
+.idea
+bin
+*.iml
+.DS_Store
+tmp
+logs
+debug-logs
diff --git a/nokiav2/deployment/pom.xml b/nokiav2/deployment/pom.xml
new file mode 100644
index 00000000..ff9bc505
--- /dev/null
+++ b/nokiav2/deployment/pom.xml
@@ -0,0 +1,51 @@
+<?xml version="1.0"?>
+<!--
+ Copyright 2016-2017, Nokia Corporation
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+ -->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+ <artifactId>deployment</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ <packaging>pom</packaging>
+ <name>vfc/nfvo/driver/vnfm/svnfm/nokiav2/deployment</name>
+ <description>Nokia SVNFM driver deployment files</description>
+ <parent>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm-nokiav2</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </parent>
+ <build>
+ <plugins>
+ <!-- fail the bulid if xmlstarlet is not present in Jenkins env -->
+ <plugin>
+ <groupId>org.codehaus.mojo</groupId>
+ <artifactId>exec-maven-plugin</artifactId>
+ <version>1.6.0</version>
+ <configuration>
+ <executable>${project.basedir}/src/main/resources/test_xmlstarlet.sh</executable>
+ <workingDirectory>${project.build.directory}</workingDirectory>
+ </configuration>
+ <executions>
+ <execution>
+ <phase>compile</phase>
+ <goals>
+ <goal>exec</goal>
+ </goals>
+ </execution>
+ </executions>
+ </plugin>
+ </plugins>
+ </build>
+</project>
diff --git a/nokiav2/deployment/src/assembly/assembly.xml b/nokiav2/deployment/src/assembly/assembly.xml
new file mode 100644
index 00000000..fe3ec527
--- /dev/null
+++ b/nokiav2/deployment/src/assembly/assembly.xml
@@ -0,0 +1,38 @@
+<?xml version="1.0"?>
+<!--
+ Copyright 2016-2017, Nokia Corporation
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+ -->
+<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.0.0 http://maven.apache.org/xsd/assembly-2.0.0.xsd">
+ <id>src</id>
+ <formats>
+ <format>zip</format>
+ </formats>
+ <includeBaseDirectory>false</includeBaseDirectory>
+ <fileSets>
+ <fileSet>
+ <directory>${project.basedir}/src/main/resources</directory>
+ <outputDirectory>/</outputDirectory>
+ <includes>
+ <include>Dockerfile</include>
+ <include>LICENSE</include>
+ <include>application.properties</include>
+ <include>build_image.sh</include>
+ <include>docker-entrypoint.sh</include>
+ <include>driver.war</include>
+ </includes>
+ <useDefaultExcludes>false</useDefaultExcludes>
+ </fileSet>
+ </fileSets>
+</assembly>
diff --git a/nokiav2/deployment/src/main/resources/.gitignore b/nokiav2/deployment/src/main/resources/.gitignore
new file mode 100644
index 00000000..9fd62b53
--- /dev/null
+++ b/nokiav2/deployment/src/main/resources/.gitignore
@@ -0,0 +1 @@
+driver.war
diff --git a/nokiav2/deployment/src/main/resources/Dockerfile b/nokiav2/deployment/src/main/resources/Dockerfile
new file mode 100755
index 00000000..2ad7209c
--- /dev/null
+++ b/nokiav2/deployment/src/main/resources/Dockerfile
@@ -0,0 +1,17 @@
+FROM centos:7
+WORKDIR /service
+ARG VERSION
+COPY docker-entrypoint.sh .
+COPY LICENSE ./ONAP_LICENSE
+COPY application.properties .
+RUN sed -i 's/enabled=1/enabled=0/' /etc/yum/pluginconf.d/fastestmirror.conf
+RUN sed -i 's|#baseurl=http://mirror.centos.org/centos|baseurl=http://mirrors.ocf.berkeley.edu/centos|' /etc/yum.repos.d/*.repo
+RUN yum -y update
+RUN yum -y install java-1.8.0-openjdk-headless wget
+# Debugging tools withing the container
+RUN yum -y install mc vim tcpdump net-tools nc strace telnet unzip xmlstarlet
+RUN wget -q -O driver.war "https://nexus.onap.org/service/local/artifact/maven/redirect?r=staging&g=org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2&a=driverwar&v=${VERSION}&e=war"
+ENV JAVA_HOME /usr/lib/jvm/jre
+RUN yum clean all
+EXPOSE 8089
+ENTRYPOINT /service/docker-entrypoint.sh
diff --git a/nokiav2/deployment/src/main/resources/LICENSE b/nokiav2/deployment/src/main/resources/LICENSE
new file mode 100644
index 00000000..dd08487b
--- /dev/null
+++ b/nokiav2/deployment/src/main/resources/LICENSE
@@ -0,0 +1,473 @@
+THIS LICENSE FILE CONTAINS THE LICENSE APPLICABLE DEPENDING ON THE TYPE OF CONTRIBUTIONS.
+
+APACHE LICENSE 2 IS APPLICABLE FOR SOURCE CODE, CREATIVE COMMONS ATTRIBUTION 4.0 INTERNATIONAL FOR DOCUMENTATION
+
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+
+
+Apache License
+Version 2.0, January 2004
+http://www.apache.org/licenses/
+
+TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+1. Definitions.
+
+"License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document.
+
+"Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License.
+
+"Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity.
+
+"You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License.
+
+"Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files.
+
+"Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types.
+
+"Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below).
+
+"Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof.
+
+"Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution."
+
+"Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work.
+
+2. Grant of Copyright License.
+
+Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form.
+
+3. Grant of Patent License.
+
+Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed.
+
+4. Redistribution.
+
+You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions:
+
+You must give any other recipients of the Work or Derivative Works a copy of this License; and
+You must cause any modified files to carry prominent notices stating that You changed the files; and
+You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and
+If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License.
+You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License.
+
+5. Submission of Contributions.
+
+Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions.
+
+6. Trademarks.
+
+This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file.
+
+7. Disclaimer of Warranty.
+
+Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License.
+
+8. Limitation of Liability.
+
+In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages.
+
+9. Accepting Warranty or Additional Liability.
+
+While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability.
+
+END OF TERMS AND CONDITIONS
+
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+
+Attribution 4.0 International
+
+https://creativecommons.org/licenses/by/4.0/legalcode
+
+---------------------------------------------------------------------------------------
+
+Creative Commons Corporation ("Creative Commons") is not a law firm and
+does not provide legal services or legal advice. Distribution of
+Creative Commons public licenses does not create a lawyer-client or
+other relationship. Creative Commons makes its licenses and related
+information available on an "as-is" basis. Creative Commons gives no
+warranties regarding its licenses, any material licensed under their
+terms and conditions, or any related information. Creative Commons
+disclaims all liability for damages resulting from their use to the
+fullest extent possible.
+
+Using Creative Commons Public Licenses
+
+Creative Commons public licenses provide a standard set of terms and
+conditions that creators and other rights holders may use to share
+original works of authorship and other material subject to copyright
+and certain other rights specified in the public license below. The
+following considerations are for informational purposes only, are not
+exhaustive, and do not form part of our licenses.
+
+ Considerations for licensors: Our public licenses are
+ intended for use by those authorized to give the public
+ permission to use material in ways otherwise restricted by
+ copyright and certain other rights. Our licenses are
+ irrevocable. Licensors should read and understand the terms
+ and conditions of the license they choose before applying it.
+ Licensors should also secure all rights necessary before
+ applying our licenses so that the public can reuse the
+ material as expected. Licensors should clearly mark any
+ material not subject to the license. This includes other CC-
+ licensed material, or material used under an exception or
+ limitation to copyright. More considerations for licensors:
+ wiki.creativecommons.org/Considerations_for_licensors
+
+ Considerations for the public: By using one of our public
+ licenses, a licensor grants the public permission to use the
+ licensed material under specified terms and conditions. If
+ the licensor's permission is not necessary for any reason--for
+ example, because of any applicable exception or limitation to
+ copyright--then that use is not regulated by the license. Our
+ licenses grant only permissions under copyright and certain
+ other rights that a licensor has authority to grant. Use of
+ the licensed material may still be restricted for other
+ reasons, including because others have copyright or other
+ rights in the material. A licensor may make special requests,
+ such as asking that all changes be marked or described.
+ Although not required by our licenses, you are encouraged to
+ respect those requests where reasonable. More_considerations
+ for the public:
+ wiki.creativecommons.org/Considerations_for_licensees
+
+---------------------------------------------------------------------------------------
+
+Creative Commons Attribution 4.0 International Public License
+
+By exercising the Licensed Rights (defined below), You accept and agree
+to be bound by the terms and conditions of this Creative Commons
+Attribution 4.0 International Public License ("Public License"). To the
+extent this Public License may be interpreted as a contract, You are
+granted the Licensed Rights in consideration of Your acceptance of
+these terms and conditions, and the Licensor grants You such rights in
+consideration of benefits the Licensor receives from making the
+Licensed Material available under these terms and conditions.
+
+
+Section 1 -- Definitions.
+
+ a. Adapted Material means material subject to Copyright and Similar
+ Rights that is derived from or based upon the Licensed Material
+ and in which the Licensed Material is translated, altered,
+ arranged, transformed, or otherwise modified in a manner requiring
+ permission under the Copyright and Similar Rights held by the
+ Licensor. For purposes of this Public License, where the Licensed
+ Material is a musical work, performance, or sound recording,
+ Adapted Material is always produced where the Licensed Material is
+ synched in timed relation with a moving image.
+
+ b. Adapter's License means the license You apply to Your Copyright
+ and Similar Rights in Your contributions to Adapted Material in
+ accordance with the terms and conditions of this Public License.
+
+ c. Copyright and Similar Rights means copyright and/or similar rights
+ closely related to copyright including, without limitation,
+ performance, broadcast, sound recording, and Sui Generis Database
+ Rights, without regard to how the rights are labeled or
+ categorized. For purposes of this Public License, the rights
+ specified in Section 2(b)(1)-(2) are not Copyright and Similar
+ Rights.
+
+ d. Effective Technological Measures means those measures that, in the
+ absence of proper authority, may not be circumvented under laws
+ fulfilling obligations under Article 11 of the WIPO Copyright
+ Treaty adopted on December 20, 1996, and/or similar international
+ agreements.
+
+ e. Exceptions and Limitations means fair use, fair dealing, and/or
+ any other exception or limitation to Copyright and Similar Rights
+ that applies to Your use of the Licensed Material.
+
+ f. Licensed Material means the artistic or literary work, database,
+ or other material to which the Licensor applied this Public
+ License.
+
+ g. Licensed Rights means the rights granted to You subject to the
+ terms and conditions of this Public License, which are limited to
+ all Copyright and Similar Rights that apply to Your use of the
+ Licensed Material and that the Licensor has authority to license.
+
+ h. Licensor means the individual(s) or entity(ies) granting rights
+ under this Public License.
+
+ i. Share means to provide material to the public by any means or
+ process that requires permission under the Licensed Rights, such
+ as reproduction, public display, public performance, distribution,
+ dissemination, communication, or importation, and to make material
+ available to the public including in ways that members of the
+ public may access the material from a place and at a time
+ individually chosen by them.
+
+ j. Sui Generis Database Rights means rights other than copyright
+ resulting from Directive 96/9/EC of the European Parliament and of
+ the Council of 11 March 1996 on the legal protection of databases,
+ as amended and/or succeeded, as well as other essentially
+ equivalent rights anywhere in the world.
+
+ k. You means the individual or entity exercising the Licensed Rights
+ under this Public License. Your has a corresponding meaning.
+
+
+Section 2 -- Scope.
+
+ a. License grant.
+
+ 1. Subject to the terms and conditions of this Public License,
+ the Licensor hereby grants You a worldwide, royalty-free,
+ non-sublicensable, non-exclusive, irrevocable license to
+ exercise the Licensed Rights in the Licensed Material to:
+
+ a. reproduce and Share the Licensed Material, in whole or
+ in part; and
+
+ b. produce, reproduce, and Share Adapted Material.
+
+ 2. Exceptions and Limitations. For the avoidance of doubt, where
+ Exceptions and Limitations apply to Your use, this Public
+ License does not apply, and You do not need to comply with
+ its terms and conditions.
+
+ 3. Term. The term of this Public License is specified in Section
+ 6(a).
+
+ 4. Media and formats; technical modifications allowed. The
+ Licensor authorizes You to exercise the Licensed Rights in
+ all media and formats whether now known or hereafter created,
+ and to make technical modifications necessary to do so. The
+ Licensor waives and/or agrees not to assert any right or
+ authority to forbid You from making technical modifications
+ necessary to exercise the Licensed Rights, including
+ technical modifications necessary to circumvent Effective
+ Technological Measures. For purposes of this Public License,
+ simply making modifications authorized by this Section 2(a)
+ (4) never produces Adapted Material.
+
+ 5. Downstream recipients.
+
+ a. Offer from the Licensor -- Licensed Material. Every
+ recipient of the Licensed Material automatically
+ receives an offer from the Licensor to exercise the
+ Licensed Rights under the terms and conditions of this
+ Public License.
+
+ b. No downstream restrictions. You may not offer or impose
+ any additional or different terms or conditions on, or
+ apply any Effective Technological Measures to, the
+ Licensed Material if doing so restricts exercise of the
+ Licensed Rights by any recipient of the Licensed
+ Material.
+
+ 6. No endorsement. Nothing in this Public License constitutes or
+ may be construed as permission to assert or imply that You
+ are, or that Your use of the Licensed Material is, connected
+ with, or sponsored, endorsed, or granted official status by,
+ the Licensor or others designated to receive attribution as
+ provided in Section 3(a)(1)(A)(i).
+
+ b. Other rights.
+
+ 1. Moral rights, such as the right of integrity, are not
+ licensed under this Public License, nor are publicity,
+ privacy, and/or other similar personality rights; however, to
+ the extent possible, the Licensor waives and/or agrees not to
+ assert any such rights held by the Licensor to the limited
+ extent necessary to allow You to exercise the Licensed
+ Rights, but not otherwise.
+
+ 2. Patent and trademark rights are not licensed under this
+ Public License.
+
+ 3. To the extent possible, the Licensor waives any right to
+ collect royalties from You for the exercise of the Licensed
+ Rights, whether directly or through a collecting society
+ under any voluntary or waivable statutory or compulsory
+ licensing scheme. In all other cases the Licensor expressly
+ reserves any right to collect such royalties.
+
+
+Section 3 -- License Conditions.
+
+Your exercise of the Licensed Rights is expressly made subject to the
+following conditions.
+
+ a. Attribution.
+
+ 1. If You Share the Licensed Material (including in modified
+ form), You must:
+
+ a. retain the following if it is supplied by the Licensor
+ with the Licensed Material:
+
+ i. identification of the creator(s) of the Licensed
+ Material and any others designated to receive
+ attribution, in any reasonable manner requested by
+ the Licensor (including by pseudonym if
+ designated);
+
+ ii. a copyright notice;
+
+ iii. a notice that refers to this Public License;
+
+ iv. a notice that refers to the disclaimer of
+ warranties;
+
+ v. a URI or hyperlink to the Licensed Material to the
+ extent reasonably practicable;
+
+ b. indicate if You modified the Licensed Material and
+ retain an indication of any previous modifications; and
+
+ c. indicate the Licensed Material is licensed under this
+ Public License, and include the text of, or the URI or
+ hyperlink to, this Public License.
+
+ 2. You may satisfy the conditions in Section 3(a)(1) in any
+ reasonable manner based on the medium, means, and context in
+ which You Share the Licensed Material. For example, it may be
+ reasonable to satisfy the conditions by providing a URI or
+ hyperlink to a resource that includes the required
+ information.
+
+ 3. If requested by the Licensor, You must remove any of the
+ information required by Section 3(a)(1)(A) to the extent
+ reasonably practicable.
+
+ 4. If You Share Adapted Material You produce, the Adapter's
+ License You apply must not prevent recipients of the Adapted
+ Material from complying with this Public License.
+
+
+Section 4 -- Sui Generis Database Rights.
+
+Where the Licensed Rights include Sui Generis Database Rights that
+apply to Your use of the Licensed Material:
+
+ a. for the avoidance of doubt, Section 2(a)(1) grants You the right
+ to extract, reuse, reproduce, and Share all or a substantial
+ portion of the contents of the database;
+
+ b. if You include all or a substantial portion of the database
+ contents in a database in which You have Sui Generis Database
+ Rights, then the database in which You have Sui Generis Database
+ Rights (but not its individual contents) is Adapted Material; and
+
+ c. You must comply with the conditions in Section 3(a) if You Share
+ all or a substantial portion of the contents of the database.
+
+For the avoidance of doubt, this Section 4 supplements and does not
+replace Your obligations under this Public License where the Licensed
+Rights include other Copyright and Similar Rights.
+
+
+Section 5 -- Disclaimer of Warranties and Limitation of Liability.
+
+ a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE
+ EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS
+ AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF
+ ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS,
+ IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION,
+ WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR
+ PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS,
+ ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT
+ KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT
+ ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU.
+
+ b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE
+ TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION,
+ NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT,
+ INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES,
+ COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR
+ USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN
+ ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR
+ DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR
+ IN PART, THIS LIMITATION MAY NOT APPLY TO YOU.
+
+ c. The disclaimer of warranties and limitation of liability provided
+ above shall be interpreted in a manner that, to the extent
+ possible, most closely approximates an absolute disclaimer and
+ waiver of all liability.
+
+
+Section 6 -- Term and Termination.
+
+ a. This Public License applies for the term of the Copyright and
+ Similar Rights licensed here. However, if You fail to comply with
+ this Public License, then Your rights under this Public License
+ terminate automatically.
+
+ b. Where Your right to use the Licensed Material has terminated under
+ Section 6(a), it reinstates:
+
+ 1. automatically as of the date the violation is cured, provided
+ it is cured within 30 days of Your discovery of the
+ violation; or
+
+ 2. upon express reinstatement by the Licensor.
+
+ For the avoidance of doubt, this Section 6(b) does not affect any
+ right the Licensor may have to seek remedies for Your violations
+ of this Public License.
+
+ c. For the avoidance of doubt, the Licensor may also offer the
+ Licensed Material under separate terms or conditions or stop
+ distributing the Licensed Material at any time; however, doing so
+ will not terminate this Public License.
+
+ d. Sections 1, 5, 6, 7, and 8 survive termination of this Public
+ License.
+
+
+Section 7 -- Other Terms and Conditions.
+
+ a. The Licensor shall not be bound by any additional or different
+ terms or conditions communicated by You unless expressly agreed.
+
+ b. Any arrangements, understandings, or agreements regarding the
+ Licensed Material not stated herein are separate from and
+ independent of the terms and conditions of this Public License.
+
+
+Section 8 -- Interpretation.
+
+ a. For the avoidance of doubt, this Public License does not, and
+ shall not be interpreted to, reduce, limit, restrict, or impose
+ conditions on any use of the Licensed Material that could lawfully
+ be made without permission under this Public License.
+
+ b. To the extent possible, if any provision of this Public License is
+ deemed unenforceable, it shall be automatically reformed to the
+ minimum extent necessary to make it enforceable. If the provision
+ cannot be reformed, it shall be severed from this Public License
+ without affecting the enforceability of the remaining terms and
+ conditions.
+
+ c. No term or condition of this Public License will be waived and no
+ failure to comply consented to unless expressly agreed to by the
+ Licensor.
+
+ d. Nothing in this Public License constitutes or may be interpreted
+ as a limitation upon, or waiver of, any privileges and immunities
+ that apply to the Licensor or You, including from the legal
+ processes of any jurisdiction or authority.
+
+---------------------------------------------------------------------------------------
+
+Creative Commons is not a party to its public
+licenses. Notwithstanding, Creative Commons may elect to apply one of
+its public licenses to material it publishes and in those instances
+will be considered the "Licensor." The text of the Creative Commons
+public licenses is dedicated to the public domain under the CC0 Public
+Domain Dedication. Except for the limited purpose of indicating that
+material is shared under a Creative Commons public license or as
+otherwise permitted by the Creative Commons policies published at
+creativecommons.org/policies, Creative Commons does not authorize the
+use of the trademark "Creative Commons" or any other trademark or logo
+of Creative Commons without its prior written consent including,
+without limitation, in connection with any unauthorized modifications
+to any of its public licenses or any other arrangements,
+understandings, or agreements concerning use of licensed material. For
+the avoidance of doubt, this paragraph does not form part of the
+public licenses.
+
+Creative Commons may be contacted at creativecommons.org.
diff --git a/nokiav2/deployment/src/main/resources/application.properties b/nokiav2/deployment/src/main/resources/application.properties
new file mode 100644
index 00000000..c9c86a02
--- /dev/null
+++ b/nokiav2/deployment/src/main/resources/application.properties
@@ -0,0 +1,75 @@
+###############################################################################
+# Copyright 2016, Nokia Corporation
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+###############################################################################
+server.error.whitelabel.enabled=false
+###############################################################################
+# Begining of mandatory properties #
+###############################################################################
+###############################################################################
+# The following section contains the variables set during container creation #
+# - all values must be replaced with non sample data #
+###############################################################################
+
+# the IP address of the server reported to the micro service bus
+driverMsbExternalIp=127.0.0.1
+# the IP address of the server reported to the VNFM
+driverVnfmExternalIp=127.0.0.1
+# the IP address of the message bus
+messageBusIp=127.0.0.1
+# the URL of the CBAM catalog service
+cbamCatalogUrl=https://127.0.0.1:443/api/catalog/adapter
+# the URL of the CBAM LCN service
+cbamLcnUrl=https://127.0.0.1:443/vnfm/lcn/v3
+# the URL of the CBAM authentication service
+cbamKeyCloakBaseUrl=https://127.0.0.1:443/auth
+# the username to be used for requesing a token on CBAM authorization interface
+cbamUsername=kukuUser
+# the password to be used for requesing a token on CBAM authorization interface
+cbamPassword=kukuPassword
+# the identifier of the VNFM in A&AI external system registry
+vnfmId=5e65fe25-bdad-46dc-bba8-b7878fcee264
+
+###############################################################################
+# The following section holds the default valued that may be chaged
+###############################################################################
+# The TCP port of the server
+server.port=8089
+# the base path of the server
+server.context-path=
+# the IP address to which the erver binds to
+server.address=0.0.0.0
+# the TCP port of the message bus
+messageBusPort=80
+# skip hostname verification during SSL on CBAM LCN, LCM and authorization interface
+skipHostnameVerification=true
+# skip certificate verification during SSL on CBAM LCN, LCM and authorization interface
+skipCertificateVerification=true
+# the collection of trusted certificates for SSL on CBAM LCN, LCM and authorization interface
+# in PEM format encoded in BASE64 to a single line
+trustedCertificates=
+
+###############################################################################
+# End of mandatory properties for driver #
+###############################################################################
+ipMap=
+vnfmInfoCacheEvictionInMs=600000
+
+## for logging begin ##
+com.fasterxml.jackson.core=jackson-databind
+#logging.file=${catalina.base}/logs/vfcadaptor.log
+logging.level.org.springframework=INFO
+logging.level.org.hibernate=OFF
+logging.level.org.springframework.web=DEBUG
+## for logging end ##
diff --git a/nokiav2/deployment/src/main/resources/build_image.sh b/nokiav2/deployment/src/main/resources/build_image.sh
new file mode 100755
index 00000000..384c213a
--- /dev/null
+++ b/nokiav2/deployment/src/main/resources/build_image.sh
@@ -0,0 +1,86 @@
+#!/bin/bash
+#
+# Copyright 2017, Nokia Corporation
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+if [ "a$1" != "abuildDocker" ] ; then
+ echo "Skipping building Docker image"
+ echo "If you would like to build the docker image by script execute $0 buildDocker"
+ echo "If you would like to build and push the docker image by script execute $0 buildDocker pushImage"
+ echo "If you would like to build the docker image by maven execute mvn package -Dexec.args=\"buildDocker\""
+ echo "If you would like to push the docker image by maven execute mvn package -Dexec.args=\"buildDocker pushImage\""
+ exit
+fi
+
+DIRNAME=`dirname $0`
+DOCKER_BUILD_DIR=`cd $DIRNAME/; pwd`
+echo "----- Build directory ${DOCKER_BUILD_DIR}"
+cd ${DOCKER_BUILD_DIR}
+
+VERSION=`xmlstarlet sel -t -v "/_:project/_:version" ../../../pom.xml | sed 's/-SNAPSHOT//g'`
+echo "------ Detected version: $VERSION"
+
+PROJECT="vfc"
+IMAGE="nfvo/svnfm/nokiav2"
+DOCKER_REPOSITORY="nexus3.onap.org:10003"
+ORG="onap"
+BUILD_ARGS="--no-cache"
+# it looks like that ONAP jenkins does not support squash
+#BUILD_ARGS="--no-cache --squash"
+
+IMAGE_NAME="${DOCKER_REPOSITORY}/${ORG}/${PROJECT}/${IMAGE}"
+TIMESTAMP=$(date +"%Y%m%dT%H%M%S")
+
+if [ $HTTP_PROXY ]; then
+ echo "----- Using HTTP proxy ${HTTP_PROXY}"
+ BUILD_ARGS+=" --build-arg HTTP_PROXY=${HTTP_PROXY}"
+fi
+
+if [ $HTTPS_PROXY ]; then
+ echo "----- Using HTTPS proxy ${HTTPS_PROXY}"
+ BUILD_ARGS+=" --build-arg HTTPS_PROXY=${HTTPS_PROXY}"
+fi
+
+function build_image {
+ echo "Start build docker image: ${IMAGE_NAME}"
+ echo "docker build --build-arg VERSION=${VERSION} ${BUILD_ARGS} -t ${IMAGE_NAME}:latest ."
+ docker build --build-arg VERSION=${VERSION} ${BUILD_ARGS} -t ${IMAGE_NAME}:latest .
+}
+
+function push_image_tag {
+ TAG_NAME=$1
+ echo "Start push ${TAG_NAME}"
+ docker tag ${IMAGE_NAME}:latest ${TAG_NAME}
+ docker push ${TAG_NAME}
+}
+
+function push_image {
+ echo "Start push ${IMAGE_NAME}:latest"
+ docker push ${IMAGE_NAME}:latest
+
+ push_image_tag ${IMAGE_NAME}:${VERSION}-SNAPSHOT-latest
+ push_image_tag ${IMAGE_NAME}:${VERSION}-STAGING-latest
+ push_image_tag ${IMAGE_NAME}:${VERSION}-STAGING-${TIMESTAMP}
+}
+
+build_image
+
+if [ "a$2" != "apushImage" ]; then
+ echo "Skipping image pushing"
+ echo "If you would like to push the docker image by maven execute mvn package -Dexec.args=\"buildDocker pushImage\""
+else
+ echo "Pushing image"
+ push_image
+fi
diff --git a/nokiav2/deployment/src/main/resources/docker-entrypoint.sh b/nokiav2/deployment/src/main/resources/docker-entrypoint.sh
new file mode 100755
index 00000000..bd36b617
--- /dev/null
+++ b/nokiav2/deployment/src/main/resources/docker-entrypoint.sh
@@ -0,0 +1,85 @@
+#!/bin/bash
+#
+# Copyright 2017, Nokia Corporation
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+#
+
+CONFIG_LOCATION=/service/application.properties
+
+function shutdown(){
+ echo "Recieved sutdown signal"
+ if [ ! -e /proc/$PID ] ; then
+ echo "The process already exited $PID"
+ exit
+ fi
+ echo "Sending shutdown signal to $PID"
+ kill -15 $PID
+ for i in `seq 0 20`; do
+ if [ ! -e /proc/$PID ] ; then
+ echo "The driver exited normally $PID"
+ exit 0
+ fi
+ sleep 10
+ done
+ echo "Terminating the driver forcefully $PID"
+ kill -9 $PID
+}
+
+function switchLine(){
+ PATTERN=$1
+ REPLACEMENT=$2
+ if [ ! -z $REPLACEMENT ]; then
+ sed -i "s/${PATTERN}.*/${PATTERN}/g" $CONFIG_LOCATION
+ sed -i "s|${PATTERN}|${PATTERN}=${REPLACEMENT}|g" $CONFIG_LOCATION
+ fi
+}
+
+function configure(){
+ if [ ! -z "$CONFIGURE" ] ; then
+ switchLine driverMsbExternalIp $EXTERNAL_IP
+ switchLine driverVnfmExternalIp $EXTERNAL_IP
+ switchLine messageBusIp $MSB_IP
+ switchLine cbamCatalogUrl $CBAM_CATALOG_URL
+ switchLine cbamLcnUrl $CBAM_LCN_URL
+ switchLine cbamKeyCloakBaseUrl $CBAM_KEYCLOAK_URL
+ switchLine cbamLcnUrl $CBAM_LCN_URL
+ switchLine cbamUsername $CBAM_USERNAME
+ switchLine cbamPassword $CBAM_PASSWORD
+ switchLine vnfmId $VNFM_ID
+ switchLine ipMap $IP_MAP
+ fi
+}
+
+
+#during shutdown signal the ervice to stop
+trap shutdown SIGINT SIGTERM
+
+#configure if required
+configure
+
+#start the service
+cd /service
+
+while true ; do
+ echo "Starting server"
+ java -jar driver.war --spring.config.location=file:/service/application.properties &>> /service/service.log &
+ export PID=$!
+ echo "Server process started in background with id $PID"
+ while test -e /proc/$PID; do
+ sleep 10
+ done
+ echo "Server quit (unexpected)"
+done
+
diff --git a/nokiav2/deployment/src/main/resources/test_xmlstarlet.sh b/nokiav2/deployment/src/main/resources/test_xmlstarlet.sh
new file mode 100755
index 00000000..f5ee03d3
--- /dev/null
+++ b/nokiav2/deployment/src/main/resources/test_xmlstarlet.sh
@@ -0,0 +1,7 @@
+#!/bin/bash
+
+DIRNAME=`dirname $0`
+BUILD_DIR=`cd $DIRNAME/; pwd`
+
+#If xmlstarlet is not present build will fail
+xmlstarlet ed ${BUILD_DIR}/../../../pom.xml
diff --git a/nokiav2/docs/.gitignore b/nokiav2/docs/.gitignore
new file mode 100644
index 00000000..589cdd01
--- /dev/null
+++ b/nokiav2/docs/.gitignore
@@ -0,0 +1,3 @@
+_build
+.DS_Store
+
diff --git a/nokiav2/docs/Makefile b/nokiav2/docs/Makefile
new file mode 100644
index 00000000..d05caa83
--- /dev/null
+++ b/nokiav2/docs/Makefile
@@ -0,0 +1,20 @@
+# Minimal makefile for Sphinx documentation
+#
+
+# You can set these variables from the command line.
+SPHINXOPTS =
+SPHINXBUILD = sphinx-build
+SPHINXPROJ = NokiaSVNFMdocumentation
+SOURCEDIR = .
+BUILDDIR = _build
+
+# Put it first so that "make" without argument is like "make help".
+help:
+ @$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
+
+.PHONY: help Makefile
+
+# Catch-all target: route all unknown targets to Sphinx using the new
+# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS).
+%: Makefile
+ @$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) \ No newline at end of file
diff --git a/nokiav2/docs/conf.py b/nokiav2/docs/conf.py
new file mode 100644
index 00000000..8bf537b6
--- /dev/null
+++ b/nokiav2/docs/conf.py
@@ -0,0 +1,155 @@
+# -*- coding: utf-8 -*-
+#
+# Configuration file for the Sphinx documentation builder.
+#
+# This file does only contain a selection of the most common options. For a
+# full list see the documentation:
+# http://www.sphinx-doc.org/en/stable/config
+
+# -- Path setup --------------------------------------------------------------
+
+# If extensions (or modules to document with autodoc) are in another directory,
+# add these directories to sys.path here. If the directory is relative to the
+# documentation root, use os.path.abspath to make it absolute, like shown here.
+#
+# import os
+# import sys
+# sys.path.insert(0, os.path.abspath('.'))
+
+
+# -- Project information -----------------------------------------------------
+
+project = u'Nokia SVNFM documentation'
+copyright = u'2018, Denes Nemeth'
+author = u'Denes Nemeth'
+
+# The short X.Y version
+version = u''
+# The full version, including alpha/beta/rc tags
+release = u'1.1.0-SNAPSHOT'
+
+
+# -- General configuration ---------------------------------------------------
+
+# If your documentation needs a minimal Sphinx version, state it here.
+#
+# needs_sphinx = '1.0'
+
+# Add any Sphinx extension module names here, as strings. They can be
+# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
+# ones.
+extensions = [
+]
+
+# Add any paths that contain templates here, relative to this directory.
+templates_path = ['_templates']
+
+# The suffix(es) of source filenames.
+# You can specify multiple suffix as a list of string:
+#
+# source_suffix = ['.rst', '.md']
+source_suffix = '.rst'
+
+# The master toctree document.
+master_doc = 'index'
+
+# The language for content autogenerated by Sphinx. Refer to documentation
+# for a list of supported languages.
+#
+# This is also used if you do content translation via gettext catalogs.
+# Usually you set "language" from the command line for these cases.
+language = None
+
+# List of patterns, relative to source directory, that match files and
+# directories to ignore when looking for source files.
+# This pattern also affects html_static_path and html_extra_path .
+exclude_patterns = [u'_build', 'Thumbs.db', '.DS_Store']
+
+# The name of the Pygments (syntax highlighting) style to use.
+pygments_style = 'sphinx'
+
+
+# -- Options for HTML output -------------------------------------------------
+
+# The theme to use for HTML and HTML Help pages. See the documentation for
+# a list of builtin themes.
+#
+html_theme = 'alabaster'
+
+# Theme options are theme-specific and customize the look and feel of a theme
+# further. For a list of options available for each theme, see the
+# documentation.
+#
+# html_theme_options = {}
+
+# Add any paths that contain custom static files (such as style sheets) here,
+# relative to this directory. They are copied after the builtin static files,
+# so a file named "default.css" will overwrite the builtin "default.css".
+html_static_path = ['_static']
+
+# Custom sidebar templates, must be a dictionary that maps document names
+# to template names.
+#
+# The default sidebars (for documents that don't match any pattern) are
+# defined by theme itself. Builtin themes are using these templates by
+# default: ``['localtoc.html', 'relations.html', 'sourcelink.html',
+# 'searchbox.html']``.
+#
+# html_sidebars = {}
+
+
+# -- Options for HTMLHelp output ---------------------------------------------
+
+# Output file base name for HTML help builder.
+htmlhelp_basename = 'NokiaSVNFMdocumentationdoc'
+
+
+# -- Options for LaTeX output ------------------------------------------------
+
+latex_elements = {
+ # The paper size ('letterpaper' or 'a4paper').
+ #
+ # 'papersize': 'letterpaper',
+
+ # The font size ('10pt', '11pt' or '12pt').
+ #
+ # 'pointsize': '10pt',
+
+ # Additional stuff for the LaTeX preamble.
+ #
+ # 'preamble': '',
+
+ # Latex figure (float) alignment
+ #
+ # 'figure_align': 'htbp',
+}
+
+# Grouping the document tree into LaTeX files. List of tuples
+# (source start file, target name, title,
+# author, documentclass [howto, manual, or own class]).
+latex_documents = [
+ (master_doc, 'NokiaSVNFMdocumentation.tex', u'Nokia SVNFM documentation Documentation',
+ u'Denes Nemeth', 'manual'),
+]
+
+
+# -- Options for manual page output ------------------------------------------
+
+# One entry per manual page. List of tuples
+# (source start file, name, description, authors, manual section).
+man_pages = [
+ (master_doc, 'nokiasvnfmdocumentation', u'Nokia SVNFM documentation Documentation',
+ [author], 1)
+]
+
+
+# -- Options for Texinfo output ----------------------------------------------
+
+# Grouping the document tree into Texinfo files. List of tuples
+# (source start file, target name, title, author,
+# dir menu entry, description, category)
+texinfo_documents = [
+ (master_doc, 'NokiaSVNFMdocumentation', u'Nokia SVNFM documentation Documentation',
+ author, 'NokiaSVNFMdocumentation', 'One line description of project.',
+ 'Miscellaneous'),
+] \ No newline at end of file
diff --git a/nokiav2/docs/index.rst b/nokiav2/docs/index.rst
new file mode 100644
index 00000000..b9a98466
--- /dev/null
+++ b/nokiav2/docs/index.rst
@@ -0,0 +1,20 @@
+.. This work is licensed under a Creative Commons Attribution 4.0 International License.
+.. http://creativecommons.org/licenses/by/4.0
+.. Copyright 2018 Nokia
+
+Welcome to Nokia SVNFM documentation!
+=====================================================
+
+.. toctree::
+ :maxdepth: 1
+ :caption: Contents:
+
+ integration.rst
+ samplevnf.rst
+ vnfintegration.rst
+ onboarding.rst
+
+Indices and tables
+==================
+
+* :ref:`search`
diff --git a/nokiav2/docs/integration.rst b/nokiav2/docs/integration.rst
new file mode 100644
index 00000000..c2722c57
--- /dev/null
+++ b/nokiav2/docs/integration.rst
@@ -0,0 +1,156 @@
+Integrate ONAP with Nokia VNFM
+==============================
+
+Prepare CBAM
+------------
+
+* Start CBAM in ONAP network
+
+ - via image: (read the CBAM installation guide)
+
+* Register driver in CBAM
+
+ - Log into CBAM via SSH and get keycloak admin password
+
+ - ectl get /cbam/cluster/components/keycloak/admin_credentials/password
+
+ - Log into keycloak https://<cbamIp>/auth/admin with admin username and password from previous step and change password (save the changed password)
+ - Add a new client
+
+ - set client id to onapClient
+ - change credential type to confidental
+ - enable Standard Flow Enabled, Direct Access Grants Enabled, Service Accounts Enabled
+ - add * for redirect URL
+ - save
+ - note the client id <clientId>
+ - add new credential
+ - note the client secret <clientSecret>
+
+ - Add a new user
+
+ - note the username <onapUsername>
+ - reset password
+ - assign the "user" role to the created user
+
+ - Log into CBAM GUI usin the created user
+
+ - change and note the password <onapPassword>
+
+ - Add SSL certificates for all VIM connection or disable certificate verification
+
+ - For insecure
+
+ - sudo su -
+ - ectl set /cbam/cluster/components/tlm/insecure_vim_connection true
+ - ectl set /actions/reconfigure start
+ - journalctl -fu cbam-reconfigure.service
+ - (wait for "Started cbam-reconfigure.service.")
+
+ - For secure: (read CBAM documentation)
+
+Prepare /ets/hosts file on your machine (optional easier to copy paste URLs)
+----------------------------------------------------------------------------
+
++--------------+---------------------------------+
+| IP address | DNS entry |
++==============+=================================+
+| 1.2.3.4 | portal.api.simpledemo.onap.org |
++--------------+---------------------------------+
+| 1.2.3.4 | policy.api.simpledemo.onap.org |
++--------------+---------------------------------+
+| 1.2.3.4 | sdc.api.simpledemo.onap.org |
++--------------+---------------------------------+
+| 1.2.3.4 | vid.api.simpledemo.onap.org |
++--------------+---------------------------------+
+| 1.2.3.4 | aai.api.simpledemo.onap.org |
++--------------+---------------------------------+
+| 1.2.3.4 | msb.api.simpledemo.onap.org |
++--------------+---------------------------------+
+| 1.2.3.4 | robot.api.simpledemo.onap.org |
++--------------+---------------------------------+
+
+
+Add the VNFM driver to ONAP
+---------------------------
+
+- Locate the IP address of the MSB (MSB_IP). Look at the VM instances of ONAP and search one with vm1-multi-service name. This is where the MSB is located
+- Create VIM in A&AI (may already exist) (repeat for all clouds planed to be used)
+
+ - http://msb.api.simpledemo.onap.org/iui/aai-esr-gui/extsys/vim/vimView.html
+
+- Determine the tenant id to be used (log into the cloud) (repeat for all tenants planed to be used within the cloud)
+
+ - http://<horizonUrl>/project/access_and_security/ Intentity / Projects
+
+- Create tenant (may already exist) (repeat for all tenants planed to be used within the cloud)
+
+ + tool: Postman
+ + change tenant id, region id owner id
+ + method: PUT
+ + url: https://aai.api.simpledemo.onap.org:8443/aai/v11/cloud-infrastructure/cloud-regions/cloud-region/<cloudOwner>/<cloudRegion>/tenants/tenant/<tenantId>
+ + Headers
+
+ - basic auth AAI:AAI
+ - X-FromAppId : any
+ - Content-type: application/json
+ - Accept: application/json
+
+ - Content: :download:`aai.create.tenant.request.json <sample/aai.create.tenant.request.json>`
+
+ - change tenant id, region id owner id and tenant name
+
+- Register the VNFM as external system (repeat for all cloud planed to be used)
+
+ - Visit MSB http://msb.api.simpledemo.onap.org:9518/api/aai-esr-server/v1/vims
+
+ - note the cloud owner field <cloudOwner>
+ - note the region id field <cloudRegionId>
+
+ - Visit MSB http://msb.api.simpledemo.onap.org/iui/aai-esr-gui/extsys/vnfm/vnfmView.html and click on register button
+
++-----------------+-----------------------------------+
+| key | Value |
++-----------------+-----------------------------------+
+| Name | CbamVnfm |
++-----------------+-----------------------------------+
+| type | NokiaSVNFM |
++-----------------+-----------------------------------+
+| Vendor | Nokia |
++-----------------+-----------------------------------+
+| version | v1 |
++-----------------+-----------------------------------+
+| URL | https://<cbamIp>:443/vnfm/lcm/v3 |
++-----------------+-----------------------------------+
+| VIM | <cloudOwner>_<cloudRegionId> |
++-----------------+-----------------------------------+
+| certificate URL | |
++-----------------+-----------------------------------+
+| Username | <clientId> |
++-----------------+-----------------------------------+
+| Password | <clientSecret> |
++-----------------+-----------------------------------+
+
+ - Determine the UUID of the VNFM (if the VNFM was registered multiple times select one at random)
+
+ - visit http://msb.api.simpledemo.onap.org:9518/api/aai-esr-server/v1/vnfms and search for the previously registered VNFM
+ - note the id field <vnfmId>
+
+ - Download the cbam driver into ONAP multi service node
+ - Load the image into docker and note the image identifier <imageId>
+
+.. code-block:: console
+
+ docker load -i /tmp/nokia.img
+
+Start the driver (fill in values)
+
+.. code-block:: console
+
+ export CBAM_IP=<cbamIp>
+ export MULTI_NODE_IP=<multiNodeIp>
+ export VNFM_ID=<vnfmId>
+ export IMAGE_ID=<imageId>
+ export CBAM_PASSWORD=<onapPassword>
+ export CBAM_USERNAME=<onapUsername>
+ docker run --name vfc_nokia -p 8089:8089 -e "MSB_IP=$MULTI_NODE_IP" -e "CONFIGURE=kuku" -e "EXTERNAL_IP=$MULTI_NODE_IP" -e "CBAM_CATALOG_URL=https://$CBAM_IP:443/api/catalog/adapter" -e "CBAM_LCN_URL=https://$CBAM_IP:443/vnfm/lcn/v3" -e "CBAM_KEYCLOAK_URL=https://$CBAM_IP:443/auth" -e "CBAM_USERNAME=$CBAM_USERNAME" -e "CBAM_PASSWORD=$CBAM_PASSWORD" -e "VNFM_ID=$VNFM_ID" -d --stop-timeout 300 $IMAGE_ID
+
diff --git a/nokiav2/docs/onboarding.rst b/nokiav2/docs/onboarding.rst
new file mode 100644
index 00000000..6e3ade3c
--- /dev/null
+++ b/nokiav2/docs/onboarding.rst
@@ -0,0 +1,125 @@
+Onboard NS
+==========
+
+Prepare environment
+-------------------
+- Create customer in A&AI
+
+ - tool: Postman
+ - method: PUT
+ - URL: https://aai.api.simpledemo.onap.org:8443/aai/v11/business/customers/customer/123456
+ - Headers
+
+ - basic auth AAI:AAI
+ - X-FromAppId : any
+ - Content-type: application/json
+ - Accept: application/json
+
+ - body: :download:`aai.create.customer.request.json <sample/aai.create.customer.request.json>`
+
+ - Edit tenant id, cloud owner, cloud region
+
+- Log into ONAP portal with designer role (cs0008)
+
+ - Create License model
+
+ - ONBOARD / Create new VLP
+
+ - name = select a name easy to remember
+
+ - Entitlement pool / add new Entitlement pool
+
+ - name = any
+
+ - License key group / add new licencse key group
+
+ - name = any
+ - type = universal
+
+ - Feature groups / add feature group
+
+ - name = any
+ - part number = 123456
+ - manufacturer reference number = 123456
+ - entitlement pool (add any with arrow button)
+ - license key group (add any with arrow button)
+ - save
+
+ - License agreements / Add license agreement
+
+ - name = any
+ - license term unlimited
+ - feature groups (add any with arrow button)
+
+ - Check in (lock icon at top)
+ - Submit (tick icon at top)
+
+ - On-board / Create new VSP (vendor software package)
+
+ - Create VSP
+
+ - name = select a name easy to remember
+ - vendor = name of the license model
+ - category = Database (IMPORTANT NOT TO CHANGE THIS (linked to the global customer))
+ - onboarding procedure = network package
+ - description = any
+
+ - Upload CSAR
+
+ - overview / software product attachments / select file
+
+ - Select licence
+
+ - overview / software product details / license agreement
+ - licenses
+ - set license version, license agreement, feature groups
+ - click on save icon at top
+ - commit & submit using icons at top
+
+ - Create VF
+
+ - home / import / import vsp (select VSP from list)
+
+ - set General / Vendor model number to CBAM package VNFD ID
+
+ - set sVNFM property assignment / inputs / nf_type set NokiaSVNFM
+ - commit
+ - submit for testing
+
+ - Test VF
+
+ - Log in as tester role
+ - Select VF
+ - Start testing button
+ - Accept testing
+
+ - Create Service
+
+ - Log in as designer role
+ - home / add / add service
+ - name = select a name easy to remember
+ - project code = 123456
+ - Check in & check out (required to save a safe point to restore to if something goes wrong)
+
+ - Add created VF (Composition)
+
+ - drag icon to main picture (be patient only drag once, if multiple icons appear restart procedure )
+ - Check in
+ - Open service again and verify that the VF is part of the service under composition
+
+ - Submit for testing
+ - Test Service
+
+ - Log in as tester role (jm0007)
+ - start testing & accept
+
+ - Approve service
+
+ - Log in as governence user (gv0001)
+ - Select service and press approve
+
+ - Distribute the service
+
+ - Log in as operations personen (op0001)
+ - Select service and push distribute
+ - Click on monitor (verify that the state of the service is distributed)
diff --git a/nokiav2/docs/sample/aai.create.customer.request.json b/nokiav2/docs/sample/aai.create.customer.request.json
new file mode 100644
index 00000000..35773843
--- /dev/null
+++ b/nokiav2/docs/sample/aai.create.customer.request.json
@@ -0,0 +1,21 @@
+{
+ "global-customer-id": "123456",
+ "subscriber-name": "CbamCustomer",
+ "subscriber-type": "INFRA",
+ "service-subscriptions": {
+ "service-subscription": [
+ {
+ "service-type": "Database",
+ "relationship-list": {
+ "relationship": [{
+ "related-to": "tenant",
+ "relationship-data": [
+ {"relationship-key": "cloud-region.cloud-owner", "relationship-value": "Nokia"},
+ {"relationship-key": "cloud-region.cloud-region-id", "relationship-value": "RegionOne"},
+ {"relationship-key": "tenant.tenant-id", "relationship-value": "2ca57d2dbeda4e8a84739319bab769f4"}
+ ]
+ }]
+ }
+ }
+ ]}
+} \ No newline at end of file
diff --git a/nokiav2/docs/sample/aai.create.tenant.request.json b/nokiav2/docs/sample/aai.create.tenant.request.json
new file mode 100644
index 00000000..afe2f546
--- /dev/null
+++ b/nokiav2/docs/sample/aai.create.tenant.request.json
@@ -0,0 +1,6 @@
+ {
+ "cloud-owner": "Nokia",
+ "cloud-region-id": "RegionOne",
+ "tenant-id": "2ca57d2dbeda4e8a84739319bab769f4",
+ "tenant-name": "VFC"
+ } \ No newline at end of file
diff --git a/nokiav2/docs/sample/cbam.collectConnectionPoints.js b/nokiav2/docs/sample/cbam.collectConnectionPoints.js
new file mode 100644
index 00000000..c721c935
--- /dev/null
+++ b/nokiav2/docs/sample/cbam.collectConnectionPoints.js
@@ -0,0 +1,57 @@
+var collectConnectionPoints = function(resourceModel, diff) {
+ return collectPorts(resourceModel, diff)
+};
+
+function collectPorts(resourceModel, diff){
+ pathToResource = {}
+ collectResources('', resourceModel, pathToResource, true);
+ transformedPorts = []
+ Object.keys(pathToResource).forEach(function (path) {
+ var port = pathToResource[path];
+ transformedPort = {}
+ transformedPort.name = port.attributes.name;
+ transformedPort.providerId = port.attributes.id;
+ transformedPort.cpId = path;
+ var managedPort = false;
+ if(port.hasOwnProperty('externalConnectionPoint')){
+ transformedPort.ecpdId = port.externalConnectionPoint;
+ managedPort = true;
+ }
+ if(port.hasOwnProperty('connectionPoint')){
+ transformedPort.cpdId = port.connectionPoint;
+ managedPort = true;
+ }
+ transformedPort.tenantId = port.attributes.tenant_id;
+ transformedPort.ipAddress = port.attributes.fixed_ips[0].ip_address;
+ transformedPort.macAddress = port.attributes.mac_address;
+ transformedPort.serverProviderId = port.attributes.device_id;
+ transformedPort.networkProviderId = port.attributes.network_id;
+ if(managedPort){
+ transformedPorts.push(transformedPort)
+ }
+ })
+ return transformedPorts;
+};
+
+function contains(resourceChanges, path){
+ var keys = Object.keys(resourceChanges);
+ return keys.indexOf(path) !== -1;
+}
+
+function collectResources(path, root, pathToResouceMap, onResources){
+ root && Object.keys(root).forEach(function(item) {
+ if(item == 'resource_type' && root[item] == 'OS::Neutron::Port'){
+ pathToResouceMap[path] = root
+ }
+ else if(typeof root[item] === "object"){
+ var newItem = onResources ? "" : item;
+ var newPath = path;
+ if('' != newItem && path != ''){
+ newPath += ".";
+ }
+ newPath += newItem;
+ collectResources(newPath, root[item], pathToResouceMap, !onResources)
+ }
+ });
+};
+
diff --git a/nokiav2/docs/sample/cbam.post.collectConnectionPoints.js b/nokiav2/docs/sample/cbam.post.collectConnectionPoints.js
new file mode 100644
index 00000000..c70d36ed
--- /dev/null
+++ b/nokiav2/docs/sample/cbam.post.collectConnectionPoints.js
@@ -0,0 +1,4 @@
+return {
+ "cbam_post" : collectConnectionPoints($.resource_model, $.model_diff),
+ "cbam_pre" : $.operation_result.cbam_pre
+ }
diff --git a/nokiav2/docs/sample/cbam.pre.collectConnectionPoints.js b/nokiav2/docs/sample/cbam.pre.collectConnectionPoints.js
new file mode 100644
index 00000000..64153a20
--- /dev/null
+++ b/nokiav2/docs/sample/cbam.pre.collectConnectionPoints.js
@@ -0,0 +1 @@
+return { "cbam_pre" : collectConnectionPoints($.resource_model, $.model_diff) }
diff --git a/nokiav2/docs/sampleVnfs/simple/cbam.instantiation.request.json b/nokiav2/docs/sampleVnfs/simple/cbam.instantiation.request.json
new file mode 100644
index 00000000..5ec6acbc
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simple/cbam.instantiation.request.json
@@ -0,0 +1,60 @@
+{
+ "apiVersion":"3.1",
+ "computeResourceFlavours": [
+ {
+ "vnfdVirtualComputeDescId": "server_compute",
+ "resourceId": "m1.small"
+ }
+ ],
+ "extVirtualLinks": [
+ {
+ "extCps": [
+ {
+ "cpdId": "commisioning_ecp"
+ }
+ ],
+ "resourceId": "pub_net"
+ },
+ {
+ "extCps": [
+ {
+ "cpdId": "vnftovnf_ecp"
+ }
+ ],
+ "resourceId": "preservedNetwork"
+ }
+ ],
+ "zones": [
+ {
+ "resourceId": "compute-a",
+ "id": "zoneInfoId"
+ }
+ ],
+ "flavourId": "scalable",
+ "grantlessMode": true,
+ "softwareImages": [
+ {
+ "resourceId": "ubuntu.16.04",
+ "vnfdSoftwareImageId": "server_image"
+ }
+ ],
+ "vims": [
+ {
+ "accessInfo": {
+ "username": "develadm",
+ "tenant": "devel",
+ "password": "develpass",
+ "region": "RegionOne"
+ },
+ "interfaceInfo": {
+ "endpoint": "https://10.41.49.107:5000/v2.0/",
+ "trustedCertificates": [],
+ "skipCertificateVerification": true,
+ "skipCertificateHostnameCheck": true
+ },
+ "vimInfoType": "OPENSTACK_V2_INFO",
+ "id": "vim_id"
+ }
+ ],
+ "instantiationLevelId": "default"
+}
diff --git a/nokiav2/docs/sampleVnfs/simple/simple.csar b/nokiav2/docs/sampleVnfs/simple/simple.csar
new file mode 100644
index 00000000..13d35620
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simple/simple.csar
Binary files differ
diff --git a/nokiav2/docs/sampleVnfs/simple/vfc.ns.create.request.json b/nokiav2/docs/sampleVnfs/simple/vfc.ns.create.request.json
new file mode 100644
index 00000000..81e9abc4
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simple/vfc.ns.create.request.json
@@ -0,0 +1,9 @@
+{
+ "nsName": "cbam_ns_dual_2",
+ "csarId": "0479b45c-85cb-4dae-979a-e44618b1a49f",
+ "context": {
+ "globalCustomerId" : "123456",
+ "serviceType" : "Database"
+ },
+ "description": "string"
+}
diff --git a/nokiav2/docs/sampleVnfs/simple/vfc.ns.instantiation.request.json b/nokiav2/docs/sampleVnfs/simple/vfc.ns.instantiation.request.json
new file mode 100644
index 00000000..30efc96e
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simple/vfc.ns.instantiation.request.json
@@ -0,0 +1,41 @@
+{
+ "nsInstanceId": "e7d79bd8-8e97-48fa-bbb8-fe2e8166b61c",
+ "additionalParamForNs": {
+ "location": "Nokia_RegionOne",
+ "vnfs": {
+ "669e8f94-b3a4-47ff-9245-c023c9fd5657": {
+ "computeResourceFlavours": [
+ {
+ "vnfdVirtualComputeDescId": "server_compute",
+ "resourceId": "m1.small"
+ }
+ ],
+ "extVirtualLinks": [
+ {
+ "extCps": [
+ {
+ "cpdId": "comuniversal_ecp"
+ }
+ ],
+ "resourceId": "external"
+ }
+ ],
+ "zones": [
+ {
+ "resourceId": "nova",
+ "id": "zoneInfoId"
+ }
+ ],
+ "flavourId": "scalable",
+ "vimType": "OPENSTACK_V2_INFO",
+ "instantiationLevel": "default",
+ "softwareImages": [
+ {
+ "resourceId": "ubuntu-16.04",
+ "vnfdSoftwareImageId": "server_image"
+ }
+ ]
+ }
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/docs/sampleVnfs/simpleDual/cbam.instantiation.request.json b/nokiav2/docs/sampleVnfs/simpleDual/cbam.instantiation.request.json
new file mode 100644
index 00000000..5ec6acbc
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simpleDual/cbam.instantiation.request.json
@@ -0,0 +1,60 @@
+{
+ "apiVersion":"3.1",
+ "computeResourceFlavours": [
+ {
+ "vnfdVirtualComputeDescId": "server_compute",
+ "resourceId": "m1.small"
+ }
+ ],
+ "extVirtualLinks": [
+ {
+ "extCps": [
+ {
+ "cpdId": "commisioning_ecp"
+ }
+ ],
+ "resourceId": "pub_net"
+ },
+ {
+ "extCps": [
+ {
+ "cpdId": "vnftovnf_ecp"
+ }
+ ],
+ "resourceId": "preservedNetwork"
+ }
+ ],
+ "zones": [
+ {
+ "resourceId": "compute-a",
+ "id": "zoneInfoId"
+ }
+ ],
+ "flavourId": "scalable",
+ "grantlessMode": true,
+ "softwareImages": [
+ {
+ "resourceId": "ubuntu.16.04",
+ "vnfdSoftwareImageId": "server_image"
+ }
+ ],
+ "vims": [
+ {
+ "accessInfo": {
+ "username": "develadm",
+ "tenant": "devel",
+ "password": "develpass",
+ "region": "RegionOne"
+ },
+ "interfaceInfo": {
+ "endpoint": "https://10.41.49.107:5000/v2.0/",
+ "trustedCertificates": [],
+ "skipCertificateVerification": true,
+ "skipCertificateHostnameCheck": true
+ },
+ "vimInfoType": "OPENSTACK_V2_INFO",
+ "id": "vim_id"
+ }
+ ],
+ "instantiationLevelId": "default"
+}
diff --git a/nokiav2/docs/sampleVnfs/simpleDual/sample/vfc.to.cbam.instantiation.json b/nokiav2/docs/sampleVnfs/simpleDual/sample/vfc.to.cbam.instantiation.json
new file mode 100644
index 00000000..504c7f11
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simpleDual/sample/vfc.to.cbam.instantiation.json
@@ -0,0 +1,65 @@
+{
+ "vnfInstanceName": "vnf669e8f94-b3a4-47ff-9245-c02",
+ "extVirtualLink": [
+ {
+ "resourceSubnetId": "23abdbc0-7c16-4dbc-a879-2d68f87c0ecf",
+ "resourceId": "da9a2d26-e70b-4402-b343-d0060f2ab298",
+ "vlInstanceId": "c1d78629-7121-400d-9ced-84340508feec",
+ "cpdId": "vnftovnf_cp",
+ "vim": {
+ "vimid": "Nokia_RegionOne"
+ }
+ }
+ ],
+ "vnfPackageId": "669e8f94-b3a4-47ff-9245-c023c9fd5657",
+ "additionalParam": {
+ "inputs": {
+ "vnfs": {
+ "669e8f94-b3a4-47ff-9245-c023c9fd5657": {
+ "extVirtualLinks": [
+ {
+ "resourceId": "external",
+ "extCps": [
+ {
+ "cpdId": "commisioning_ecp"
+ }
+ ]
+ }
+ ],
+ "vimType": "OPENSTACK_V2_INFO",
+ "instantiationLevel": "default",
+ "softwareImages": [
+ {
+ "vnfdSoftwareImageId": "server_image",
+ "resourceId": "ubuntu-16.04"
+ }
+ ],
+ "flavourId": "scalable",
+ "zones": [
+ {
+ "resourceId": "nova",
+ "id": "zoneInfoId"
+ }
+ ],
+ "computeResourceFlavours": [
+ {
+ "resourceId": "m1.small",
+ "vnfdVirtualComputeDescId": "server_compute"
+ }
+ ]
+ }
+ },
+ "location": "Nokia_RegionOne"
+ },
+ "extVirtualLinks": [
+ {
+ "key_name": "vnftovnf_cp.virtual_link",
+ "vl_instance_id": "c1d78629-7121-400d-9ced-84340508feec",
+ "network_name": "myNetworkName",
+ "subnetwork_name": "mySubnetName"
+ }
+ ],
+ "vimId": "Nokia_RegionOne"
+ },
+ "vnfDescriptorId": "669e8f94-b3a4-47ff-9245-c023c9fd5657"
+} \ No newline at end of file
diff --git a/nokiav2/docs/sampleVnfs/simpleDual/simpleDual.csar b/nokiav2/docs/sampleVnfs/simpleDual/simpleDual.csar
new file mode 100644
index 00000000..3545d237
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simpleDual/simpleDual.csar
Binary files differ
diff --git a/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.create.request.json b/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.create.request.json
new file mode 100644
index 00000000..fd2f724b
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.create.request.json
@@ -0,0 +1,9 @@
+{
+ "nsName": "cbam_ns_dual_20180125_1",
+ "csarId": "96ea0048-b91d-4478-ab18-b88d15bcd1aa",
+ "context": {
+ "globalCustomerId" : "123456",
+ "serviceType" : "Database"
+ },
+ "description": "string"
+} \ No newline at end of file
diff --git a/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.heal.request.json b/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.heal.request.json
new file mode 100644
index 00000000..e62665db
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.heal.request.json
@@ -0,0 +1,13 @@
+{
+ "healVnfData": {
+ "vnfInstanceId": "05901205-622e-495b-9673-25c433c1c35a",
+ "cause": "cause",
+ "additionalParams": {
+ "action": "restartvm",
+ "actionvminfo": {
+ "vmid": "vmId",
+ "vmname": "vmname"
+ }
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.instantiation.request.json b/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.instantiation.request.json
new file mode 100644
index 00000000..4b0ce8fd
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simpleDual/vfc.ns.instantiation.request.json
@@ -0,0 +1,41 @@
+{
+ "nsInstanceId": "b65572a1-4f2e-4787-950d-bb489e970623",
+ "additionalParamForNs": {
+ "location": "Nokia_RegionOne",
+ "vnfs": {
+ "f85f054f-0928-4fab-ac76-b47b8fba0d6d": {
+ "computeResourceFlavours": [
+ {
+ "vnfdVirtualComputeDescId": "server_compute",
+ "resourceId": "m1.small"
+ }
+ ],
+ "extVirtualLinks": [
+ {
+ "extCps": [
+ {
+ "cpdId": "commisioning_ecp"
+ }
+ ],
+ "resourceId": "pub_net"
+ }
+ ],
+ "zones": [
+ {
+ "resourceId": "compute-a",
+ "id": "zoneInfoId"
+ }
+ ],
+ "flavourId": "scalable",
+ "vimType": "OPENSTACK_V2_INFO",
+ "instantiationLevel": "default",
+ "softwareImages": [
+ {
+ "resourceId": "ubuntu.16.04",
+ "vnfdSoftwareImageId": "server_image"
+ }
+ ]
+ }
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/docs/sampleVnfs/simpleDual/vfc.vnf.scale.request.json b/nokiav2/docs/sampleVnfs/simpleDual/vfc.vnf.scale.request.json
new file mode 100644
index 00000000..af194c88
--- /dev/null
+++ b/nokiav2/docs/sampleVnfs/simpleDual/vfc.vnf.scale.request.json
@@ -0,0 +1,9 @@
+{
+ "scaleVnfData" : [
+ {
+ "type" : "SCALE_OUT",
+ "aspectId" : "simpleAspect",
+ "numberOfSteps" : "1"
+ }
+ ]
+} \ No newline at end of file
diff --git a/nokiav2/docs/samplevnf.rst b/nokiav2/docs/samplevnf.rst
new file mode 100644
index 00000000..6561575a
--- /dev/null
+++ b/nokiav2/docs/samplevnf.rst
@@ -0,0 +1,19 @@
+Sample VNFs
+===========
+
+Simple
+------
+
+- CSAR: :download:`csar <sampleVnfs/simple/simple.csar>`
+- NS creation request on VF-C API :download:`create.json <sampleVnfs/simple/vfc.ns.create.request.json>` (several fields must be changed to fit actual environment)
+- NS instantiation request on VF-C API :download:`instantiate.json <sampleVnfs/simple/vfc.ns.instantiation.request.json>` (several fields must be changed to fit actual environment)
+
+Simple Dual
+-----------
+
+- CSAR: :download:`csar <sampleVnfs/simpleDual/simpleDual.csar>`
+- NS creation request on VF-C API :download:`create.json <sampleVnfs/simpleDual/vfc.ns.create.request.json>` (several fields must be changed to fit actual environment)
+- NS instantiation request on VF-C API :download:`instantiate.json <sampleVnfs/simpleDual/vfc.ns.instantiation.request.json>` (several fields must be changed to fit actual environment)
+- NS heal request on VF-C API: :download:`heal.json <sampleVnfs/simpleDual/vfc.ns.heal.request.json>` (several fields must be changed to fit actual environment)
+- VNF scale request on VF-C API: :download:`scale.json <sampleVnfs/simpleDual/vfc.vnf.scale.request.json>` (several fields must be changed to fit actual environment)
+
diff --git a/nokiav2/docs/vnfintegration.rst b/nokiav2/docs/vnfintegration.rst
new file mode 100644
index 00000000..62674e53
--- /dev/null
+++ b/nokiav2/docs/vnfintegration.rst
@@ -0,0 +1,51 @@
+Prepare a ONAP VNF package
+==========================
+
+Automatic
+---------
+
+- Visit http://msb.api.simpledemo.onap.org/api/NokiaSVNFM/v1/convert
+- Select the CBAM package to be converted into an ONAP package
+- Click on upload button and the ONAP package will be donwloaded
+
+
+Manual
+------
+
+- the VNF must declare the externalVnfmId and onapCsarId as modifyable attribute in CBAM package (value will be filled out by CBAM)
+- each operation must declare a jobId additional parameter in CBAM package (value will be filled out by CBAM)
+- the heal operation must declare the jobId, vmName and action parameters in CBAM package (values will be filled out by CBAM)
+- each operation (including built-in) must include the following section as the last pre_action (all JS are provided by CBAM)
+
+.. code-block:: console
+
+ - javascript: javascript/cbam.pre.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+
+- each operation must include the following section as the last post_action (all JS are provided by CBAM)
+
+.. code-block:: console
+
+ - javascript: javascript/cbam.post.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+
+- CBAM supplied JavaScrips
+
+ - :download:`cbam.post.collectConnectionPoints.js <sample/cbam.post.collectConnectionPoints.js>`
+ - :download:`cbam.pre.collectConnectionPoints.js <sample/cbam.pre.collectConnectionPoints.js>`
+ - :download:`cbam.collectConnectionPoints.js <sample/cbam.collectConnectionPoints.js>`
+
+- the ONAP package must be written so that the VDU.Compute, VDU.VirtualStorage, VnfVirtualLinkDesc, VduCpd has exactly the same name as in CBAM package
+- the metadata section of the ONAP package must be the following
+
+ - the vendor must be the same as in Nokia package vendor field
+ - the vnfdVersion must be the same as in Nokia package the descriptor_version field
+ - the name must be the same as in Nokia package the product_info_name field
+ - the version must be the same as in Nokia package the software_version field
+ - the vnfmType must be NokiaSVNFM
+
+- the complete CBAM package must be placed in the in Artifacts/OTHER/cbam.package.zip file
diff --git a/nokiav2/driver/pom.xml b/nokiav2/driver/pom.xml
new file mode 100644
index 00000000..46dfe936
--- /dev/null
+++ b/nokiav2/driver/pom.xml
@@ -0,0 +1,121 @@
+<?xml version="1.0"?>
+<!--
+ Copyright 2016-2017, Nokia Corporation
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+ -->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+ <artifactId>driver</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ <packaging>jar</packaging>
+ <name>vfc/nfvo/driver/vnfm/svnfm/nokiav2/driver</name>
+ <description>svnfm vnfm driver</description>
+ <parent>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm-nokiav2</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </parent>
+ <properties>
+ <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+ <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
+ <java.version>1.8</java.version>
+ </properties>
+ <dependencies>
+ <dependency>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm-nokiav2-clients</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.springframework.boot</groupId>
+ <artifactId>spring-boot-starter-web</artifactId>
+ <version>1.5.10.RELEASE</version>
+ <scope>provided</scope>
+ </dependency>
+ <dependency>
+ <groupId>org.springframework.boot</groupId>
+ <artifactId>spring-boot-starter-test</artifactId>
+ <version>1.5.10.RELEASE</version>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
+ <groupId>com.google.guava</groupId>
+ <artifactId>guava</artifactId>
+ <version>24.0-jre</version>
+ </dependency>
+ <dependency>
+ <!-- parsing VNFDs -->
+ <groupId>org.yaml</groupId>
+ <artifactId>snakeyaml</artifactId>
+ <version>1.19</version>
+ </dependency>
+ <dependency>
+ <!-- this does not have a compile time dependency, but is required to be able to deserialize the date to joda time -->
+ <groupId>com.fasterxml.jackson.dataformat</groupId>
+ <artifactId>jackson-dataformat-yaml</artifactId>
+ <!-- this version must be in sync with the dependency comming from spring boot -->
+ <version>2.8.10</version>
+ </dependency>
+ <!-- access MSB during registration -->
+ <dependency>
+ <groupId>org.onap.msb.java-sdk</groupId>
+ <artifactId>msb-java-sdk</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>pl.pojo</groupId>
+ <artifactId>pojo-tester</artifactId>
+ <version>0.7.6</version>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
+ <groupId>org.eclipse.jetty</groupId>
+ <artifactId>jetty-server</artifactId>
+ <version>9.4.8.v20171121</version>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
+ <groupId>org.jetbrains</groupId>
+ <artifactId>annotations</artifactId>
+ <version>RELEASE</version>
+ </dependency>
+ <dependency>
+ <groupId>org.onap.aai.aai-common</groupId>
+ <artifactId>aai-schema</artifactId>
+ <version>1.2.0</version>
+ </dependency>
+ <dependency>
+ <groupId>org.onap.aai</groupId>
+ <artifactId>rest-client</artifactId>
+ <version>1.2.0</version>
+ </dependency>
+ </dependencies>
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-compiler-plugin</artifactId>
+ <version>3.5</version>
+ <configuration>
+ <source>1.8</source>
+ <target>1.8</target>
+ </configuration>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-surefire-plugin</artifactId>
+ </plugin>
+ </plugins>
+ </build>
+</project>
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/NokiaSvnfmApplication.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/NokiaSvnfmApplication.java
new file mode 100644
index 00000000..e75159f6
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/NokiaSvnfmApplication.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia;
+
+import org.apache.log4j.Logger;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.JobManager;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.context.event.ApplicationReadyEvent;
+import org.springframework.context.ApplicationListener;
+import org.springframework.context.annotation.Profile;
+import org.springframework.context.event.ContextClosedEvent;
+import org.springframework.stereotype.Component;
+
+/**
+ * Represents the spring boot application
+ */
+@SpringBootApplication
+public class NokiaSvnfmApplication {
+ private static Logger logger = Logger.getLogger(NokiaSvnfmApplication.class);
+
+ /**
+ * Entry point for the Spring boot application
+ *
+ * @param args arguments for the application (not used)
+ */
+ public static void main(String[] args) {
+ SpringApplication.run(NokiaSvnfmApplication.class, args);
+ }
+
+ /**
+ * Responsible for starting the self registration process after the servlet has been started
+ * and is ready to answer REST request
+ * - has been disabled in the test because the application that provides the ONAP simulator
+ * has already not yet been started (can not answer REST requests)
+ */
+ @Component
+ @Profile("!test")
+ public static class SelfRegistrationTrigger implements ApplicationListener<ApplicationReadyEvent> {
+ @Autowired
+ private SelfRegistrationManager selfRegistrationManager;
+
+ @Override
+ public void onApplicationEvent(ApplicationReadyEvent contextRefreshedEvent) {
+ logger.info("Self registration started");
+ try {
+ selfRegistrationManager.register();
+ logger.info("Self registration finished");
+ } catch (RuntimeException e) {
+ logger.error("Self registration failed", e);
+ throw e;
+ }
+ }
+ }
+
+ /**
+ * Responsible for starting the un-registration process after the service has been ramped down
+ * - has been disabled in test because the same application that provides the ONAP simulator
+ * has already been ramped down (can not answer REST requests)
+ */
+ @Component
+ @Profile("!test")
+ public static class SelfDeRegistrationTrigger implements ApplicationListener<ContextClosedEvent> {
+ @Autowired
+ private SelfRegistrationManager selfRegistrationManager;
+ @Autowired
+ private JobManager jobManager;
+
+ @Override
+ public void onApplicationEvent(ContextClosedEvent contextClosedEvent) {
+ logger.info("Self de-registration started");
+ try {
+ jobManager.prepareForShutdown();
+ selfRegistrationManager.deRegister();
+ } catch (RuntimeException e) {
+ logger.error("Self de-registration failed", e);
+ throw e;
+ }
+ logger.info("Self de-registration finished");
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IGrantManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IGrantManager.java
new file mode 100644
index 00000000..d851215d
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IGrantManager.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api;
+
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import org.onap.vnfmdriver.model.GrantVNFResponseVim;
+import org.onap.vnfmdriver.model.VnfHealRequest;
+import org.onap.vnfmdriver.model.VnfScaleRequest;
+
+/**
+ * Responsible for requesting grants during various LCM operations
+ */
+public interface IGrantManager {
+
+ /**
+ * Request grant for healing
+ * - the affected virtual machine is added twice to the grant request (add & remove) to
+ * signal that it is temporary removed
+ * - the grant response is only used make a binary decision
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @param vimId the identifier of the VIM
+ * @param request the heal request
+ * @param jobId the identifier of the job that triggered the grant
+ */
+ void requestGrantForHeal(String vnfmId, String vnfId, String vimId, String onapCsarId, VnfHealRequest request, String jobId);
+
+ /**
+ * Request grant for scaling
+ * - the affected virtual machines are calculated from the Heat mapping section of the corresponding aspect
+ * - the grant response is only used make a binary decision
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @param vimId the identifier of the VIM
+ * @param onapCsarId the CSAR ID of the ONAP
+ * @param request the scaling request
+ * @param jobId the identifier of the job that triggered the grant
+ */
+ void requestGrantForScale(String vnfmId, String vnfId, String vimId, String onapCsarId, VnfScaleRequest request, String jobId);
+
+ /**
+ * Request grant for termination
+ * - the resources removed is the previously deployed resources based on VNF query
+ * - the grant response is only used make a binary decision
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @param vimId the identifier of the VIM
+ */
+ void requestGrantForTerminate(String vnfmId, String vnfId, String vimId, String onapVnfdId, VnfInfo vnf, String jobId);
+
+ /**
+ * Request grant for instantiation
+ * - the added resources are calculated from the VNFD by counting the VDUs in the selected the instantiation level
+ * - the only parameter used from the grant response in the VIM to which the VNF is to be deployed to
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @param vimId the identifier of the VIM
+ * @param onapVnfdId the identifier of the VNF package in ONAP
+ * @param instantiationLevelId the instantiation level
+ * @param cbamVnfdContent the content of the CBAM VNFD
+ * @return the grant response
+ */
+ GrantVNFResponseVim requestGrantForInstantiate(String vnfmId, String vnfId, String vimId, String onapVnfdId, String instantiationLevelId, String cbamVnfdContent, String jobId);
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/INotificationSender.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/INotificationSender.java
new file mode 100644
index 00000000..55e9cca2
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/INotificationSender.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api;
+
+import com.nokia.cbam.lcm.v32.model.OperationExecution;
+import com.nokia.cbam.lcm.v32.model.VnfLifecycleChangeNotification;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedConnectionPoints;
+
+import java.util.Optional;
+
+/**
+ * Responsible for processing the preprocessed notification from CBAM and making the changes
+ * based on the notification in various ONAP sub systems.
+ */
+@FunctionalInterface
+public interface INotificationSender {
+ /**
+ * Execute changes in the ONAP subsystem based on the received notification
+ *
+ * @param receivedNotification the notification from CBAM
+ * @param operationExecution the executed operation that triggered the LCN
+ * @param affectedConnectionPoints the affected connection points during the operation
+ * @param vimId the identifier of the VIM in ONAP
+ */
+ void processNotification(VnfLifecycleChangeNotification receivedNotification, OperationExecution operationExecution, Optional<ReportedAffectedConnectionPoints> affectedConnectionPoints, String vimId);
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IPackageProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IPackageProvider.java
new file mode 100644
index 00000000..2011118f
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/IPackageProvider.java
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api;
+
+/**
+ * Provides a VNF package from ONAP repositories
+ */
+public interface IPackageProvider {
+
+ /**
+ * Download the package from ONAP
+ *
+ * @param csarId the CSAR identifier of the package in ONAP
+ * @return the binary content of the package
+ */
+ byte[] getPackage(String csarId);
+
+ /**
+ * @param csarId the CSAR identifier of the package in ONAP
+ * @return the identifier of the package in CBAM
+ */
+ String getCbamVnfdId(String csarId);
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VimInfoProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VimInfoProvider.java
new file mode 100644
index 00000000..ec783a4c
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VimInfoProvider.java
@@ -0,0 +1,31 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api;
+
+import org.onap.vnfmdriver.model.VimInfo;
+
+/**
+ * Responsible for providing information from the VIM to be used for the VNF
+ */
+@FunctionalInterface
+public interface VimInfoProvider {
+
+ /**
+ * @param vimId the identifier of the VIM
+ * @return the description of the VIM
+ */
+ VimInfo getVimInfo(String vimId);
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VnfmInfoProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VnfmInfoProvider.java
new file mode 100644
index 00000000..c659b91d
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/VnfmInfoProvider.java
@@ -0,0 +1,31 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api;
+
+import org.onap.vnfmdriver.model.VnfmInfo;
+
+/**
+ * Responsible for providing information from the VNFM itself
+ */
+@FunctionalInterface
+public interface VnfmInfoProvider {
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ * @return the description of the VNFM
+ */
+ VnfmInfo getVnfmInfo(String vnfmId);
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/package-info.java
new file mode 100644
index 00000000..4463b26a
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/api/package-info.java
@@ -0,0 +1,21 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * The collection of interfaces to connect to core systems. The
+ * driver is able to interface with VF-C xor with SDC, A&AI directly.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/GenericExternalSystemInfoProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/GenericExternalSystemInfoProvider.java
new file mode 100644
index 00000000..13b070a7
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/GenericExternalSystemInfoProvider.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import com.google.common.cache.CacheLoader;
+import com.google.common.cache.LoadingCache;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VimInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VnfmInfoProvider;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.InitializingBean;
+import org.springframework.core.env.Environment;
+
+import java.util.concurrent.TimeUnit;
+
+import static com.google.common.cache.CacheBuilder.newBuilder;
+import static java.lang.Long.valueOf;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for providing access to core systems
+ */
+public abstract class GenericExternalSystemInfoProvider extends IpMappingProvider implements VnfmInfoProvider, VimInfoProvider, InitializingBean {
+ /**
+ * The name of the VNFM info cache eviction in the properties file
+ */
+ public static final String VNFM_INFO_CACHE_EVICTION_IN_MS = "vnfmInfoCacheEvictionInMs";
+ /**
+ * The default VNFM info cache eviction in milliseconds
+ */
+ public static final int DEFAULT_CACHE_EVICTION_TIMEOUT_IN_MS = 10 * 60 * 1000;
+ private static Logger logger = getLogger(GenericExternalSystemInfoProvider.class);
+ private final Environment environment;
+ private LoadingCache<String, VnfmInfo> vnfmInfoCache;
+
+ public GenericExternalSystemInfoProvider(Environment environment) {
+ super(environment);
+ this.environment = environment;
+ }
+
+ /**
+ * After the Bean has been initialized the IP mapping and the VMFM cache is initialized
+ * It is done in this phase because the logic requires the the @Value anoted fields to
+ * be specified
+ */
+ @Override
+ public void afterPropertiesSet() throws Exception {
+ super.afterPropertiesSet();
+ vnfmInfoCache = newBuilder().expireAfterWrite(environment.getProperty(VNFM_INFO_CACHE_EVICTION_IN_MS, Long.class, valueOf(DEFAULT_CACHE_EVICTION_TIMEOUT_IN_MS)), TimeUnit.MILLISECONDS).concurrencyLevel(1).build(new CacheLoader<String, VnfmInfo>() {
+ @Override
+ public VnfmInfo load(String vnfmId) throws Exception {
+ logger.info("Querying VNFM info from source with " + vnfmId + " identifier");
+ return queryVnfmInfoFromSource(vnfmId);
+ }
+ });
+ }
+
+ /*
+ * @param vnfmId the identifier of the VNFM
+ * @return the cached VNFM
+ */
+ public VnfmInfo getVnfmInfo(String vnfmId) {
+ try {
+ return vnfmInfoCache.get(vnfmId);
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to query VNFM info for " + vnfmId, e);
+ }
+ }
+
+ /**
+ * Load the information related to the VNFM from the remote source
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @return the description of the VNFM
+ */
+ public abstract VnfmInfo queryVnfmInfoFromSource(String vnfmId);
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/IpMappingProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/IpMappingProvider.java
new file mode 100644
index 00000000..ec6db5e4
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/IpMappingProvider.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import org.springframework.beans.factory.InitializingBean;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.core.env.Environment;
+import org.springframework.stereotype.Component;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Map;
+
+import static com.google.common.base.Splitter.on;
+import static com.google.common.collect.Lists.newArrayList;
+
+/**
+ * Responsible for remapping IP/DNS names in URLs based on property file
+ */
+@Component
+public class IpMappingProvider implements InitializingBean {
+ public static final String IP_MAP = "ipMap";
+ private final Environment environment;
+ private final Map<String, String> ipMap = new HashMap<>();
+
+ @Autowired
+ IpMappingProvider(Environment environment) {
+ this.environment = environment;
+ }
+
+ /**
+ * After the Bean has been initialized the IP mapping and the VMFM cache is initialized
+ * It is done in this phase because it requires the environment to be initialized
+ */
+ @Override
+ public void afterPropertiesSet() throws Exception {
+ on(",").trimResults().omitEmptyStrings().split(environment.getProperty(IP_MAP, String.class, "")).forEach(item -> {
+ ArrayList<String> ip = newArrayList(on("->").trimResults().split(item));
+ ipMap.put(ip.get(0), ip.get(1));
+ });
+ }
+
+ /**
+ * Map IP addresses based on configuration parameter ipMap
+ *
+ * @param ip the original IP address
+ * @return the mapped IP address
+ */
+ public String mapPrivateIpToPublicIp(String ip) {
+ return ipMap.getOrDefault(ip, ip);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/MsbApiProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/MsbApiProvider.java
new file mode 100644
index 00000000..64a418de
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/MsbApiProvider.java
@@ -0,0 +1,88 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import org.onap.msb.sdk.discovery.common.RouteException;
+import org.onap.msb.sdk.discovery.entity.MicroServiceFullInfo;
+import org.onap.msb.sdk.discovery.entity.NodeInfo;
+import org.onap.msb.sdk.httpclient.msb.MSBServiceClient;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.core.env.Environment;
+import org.springframework.stereotype.Component;
+
+import static java.lang.Integer.valueOf;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for providing REST client to access MSB API
+ */
+@Component
+public class MsbApiProvider extends IpMappingProvider {
+ private static Logger logger = getLogger(MsbApiProvider.class);
+ @Value("${messageBusIp}")
+ private String messageBusIp;
+ @Value("${messageBusPort}")
+ private String messageBusPort;
+
+ @Autowired
+ MsbApiProvider(Environment environment) {
+ super(environment);
+ }
+
+ /**
+ * @return API to access ONAP MSB
+ */
+ public MSBServiceClient getMsbClient() {
+ return new MSBServiceClient(messageBusIp, valueOf(messageBusPort));
+ }
+
+ /**
+ * @param name the name of the micro service
+ * @param version the version of the micro service
+ * @return the base URL of the micro service (ex. https://1.2.3.4/path )
+ */
+ public String getMicroServiceUrl(String name, String version) {
+ MicroServiceFullInfo microServiceFullInfo = getMicroServiceInfo(name, version);
+ String ipAnPort = getNodeIpAnPort(microServiceFullInfo);
+ String protocol = microServiceFullInfo.isEnable_ssl() ? "https://" : "http://";
+ //the field name in A&AI is misleading the URL is relative path postfixed to http(s)://ip:port
+ return protocol + ipAnPort + microServiceFullInfo.getUrl();
+ }
+
+ private MicroServiceFullInfo getMicroServiceInfo(String name, String version) {
+ try {
+ return getMsbClient().queryMicroServiceInfo(name, version);
+ } catch (RouteException e) {
+ throw buildFatalFailure(logger, "Unable to get micro service URL for " + name + " with version " + version, e);
+ }
+ }
+
+ private String getNodeIpAnPort(MicroServiceFullInfo microServiceFullInfo) {
+ for (NodeInfo nodeInfo : microServiceFullInfo.getNodes()) {
+ if (isADokcerInternalAddress(nodeInfo)) {
+ return mapPrivateIpToPublicIp(nodeInfo.getIp()) + ":" + nodeInfo.getPort();
+ }
+ }
+ throw buildFatalFailure(logger, "The " + microServiceFullInfo.getServiceName() + " service with " + microServiceFullInfo.getVersion() + " does not have any valid nodes" + microServiceFullInfo.getNodes());
+ }
+
+ private boolean isADokcerInternalAddress(NodeInfo nodeInfo) {
+ return !nodeInfo.getIp().startsWith("172.");
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/SelfRegistrationManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/SelfRegistrationManager.java
new file mode 100644
index 00000000..a9e11653
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/SelfRegistrationManager.java
@@ -0,0 +1,191 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import com.nokia.cbam.lcn.v32.ApiException;
+import com.nokia.cbam.lcn.v32.api.SubscriptionsApi;
+import com.nokia.cbam.lcn.v32.model.*;
+import org.onap.msb.sdk.discovery.common.RouteException;
+import org.onap.msb.sdk.discovery.entity.MicroServiceFullInfo;
+import org.onap.msb.sdk.discovery.entity.MicroServiceInfo;
+import org.onap.msb.sdk.discovery.entity.Node;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.stereotype.Component;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+
+import static com.nokia.cbam.lcn.v32.model.SubscriptionAuthentication.TypeEnum.NONE;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCN_API_VERSION;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for registering the driver in the core systems.
+ */
+@Component
+public class SelfRegistrationManager {
+ public static final String DRIVER_VERSION = "v1";
+ public static final String SERVICE_NAME = "NokiaSVNFM";
+ // 1 means internal 0 means core :)
+ public static final String INTERNAL_SERVICE = "1";
+ public static final String SWAGGER_API_DEFINITION = "self.swagger.json";
+ private static Logger logger = getLogger(SelfRegistrationManager.class);
+ private final DriverProperties driverProperties;
+ private final MsbApiProvider msbApiProvider;
+ private final CbamRestApiProvider cbamRestApiProvider;
+
+ @Value("${driverMsbExternalIp}")
+ private String driverMsbExternalIp;
+ @Value("${driverVnfmExternalIp}")
+ private String driverVnfmExternalIp;
+ @Value("${server.port}")
+ private String driverPort;
+ private volatile boolean ready = false;
+
+ @Autowired
+ SelfRegistrationManager(DriverProperties driverProperties, MsbApiProvider msbApiProvider, CbamRestApiProvider cbamRestApiProvider) {
+ this.cbamRestApiProvider = cbamRestApiProvider;
+ this.msbApiProvider = msbApiProvider;
+ this.driverProperties = driverProperties;
+ }
+
+ /**
+ * Register the driver in micro-service bus and subscribe to LCNs from CBAM
+ */
+ public void register() {
+ //the order is important (only publish it's existence after the subscription has been created)
+ subscribeToLcn(driverProperties.getVnfmId());
+ try {
+ registerMicroService();
+ } catch (RuntimeException e) {
+ deleteSubscription(driverProperties.getVnfmId());
+ throw e;
+ }
+ ready = true;
+ }
+
+ /**
+ * De-register the VNFM driver from the micro-service bus
+ */
+ public void deRegister() {
+ try {
+ logger.info("Cancelling micro service registration");
+ msbApiProvider.getMsbClient().cancelMicroServiceInfo(SERVICE_NAME, DRIVER_VERSION);
+ } catch (RouteException e) {
+ //ONAP throws 500 internal server error, but deletes the micro service
+ try {
+ msbApiProvider.getMsbClient().queryMicroServiceInfo(SERVICE_NAME, DRIVER_VERSION);
+ //the micro service still exists
+ throw buildFatalFailure(logger, "Unable to deRegister Nokia VNFM driver", e);
+ } catch (RouteException e1) {
+ logger.info("Unable to query " + SERVICE_NAME + " from MSB (so the service was successfully deleted)", e1);
+ // the micro service was deleted (even though 500 HTTP code was reported)
+ }
+ }
+ deleteSubscription(driverProperties.getVnfmId());
+ }
+
+ /**
+ * @return the swagger API definition
+ */
+ public byte[] getSwaggerApiDefinition() {
+ return SystemFunctions.systemFunctions().loadFile(SWAGGER_API_DEFINITION);
+ }
+
+ private String getDriverVnfmUrl() {
+ return "http://" + driverVnfmExternalIp + ":" + driverPort + DriverProperties.BASE_URL;
+ }
+
+ private void deleteSubscription(String vnfmId) {
+ logger.info("Deleting CBAM LCN subscription");
+ SubscriptionsApi lcnApi = cbamRestApiProvider.getCbamLcnApi(vnfmId);
+ try {
+ String callbackUrl = getDriverVnfmUrl() + DriverProperties.LCN_URL;
+ for (Subscription subscription : lcnApi.subscriptionsGet(NOKIA_LCN_API_VERSION)) {
+ if (subscription.getCallbackUrl().equals(callbackUrl)) {
+ lcnApi.subscriptionsSubscriptionIdDelete(subscription.getId(), NOKIA_LCN_API_VERSION);
+ }
+ }
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to delete CBAM LCN subscription", e);
+ }
+ }
+
+ private MicroServiceFullInfo registerMicroService() {
+ logger.info("Registering micro service");
+ MicroServiceInfo microServiceInfo = new MicroServiceInfo();
+ microServiceInfo.setUrl(DriverProperties.BASE_URL);
+ //the PATH should not be set
+ microServiceInfo.setProtocol("REST");
+ microServiceInfo.setVisualRange(INTERNAL_SERVICE);
+ microServiceInfo.setServiceName(SERVICE_NAME);
+ microServiceInfo.setVersion(DRIVER_VERSION);
+ microServiceInfo.setEnable_ssl(true);
+ Node node = new Node();
+ microServiceInfo.setNodes(new HashSet<>());
+ microServiceInfo.getNodes().add(node);
+ node.setIp(driverMsbExternalIp);
+ node.setPort(driverPort);
+ node.setTtl("0");
+ try {
+ return msbApiProvider.getMsbClient().registerMicroServiceInfo(microServiceInfo);
+ } catch (RouteException e) {
+ throw buildFatalFailure(logger, "Unable to register Nokia VNFM driver", e);
+ }
+ }
+
+ private void subscribeToLcn(String vnfmId) {
+ String callbackUrl = getDriverVnfmUrl() + DriverProperties.LCN_URL;
+ logger.info("Subscribing to CBAM LCN {} with callback to {}", driverProperties.getCbamLcnUrl(), callbackUrl);
+ SubscriptionsApi lcnApi = cbamRestApiProvider.getCbamLcnApi(vnfmId);
+ try {
+ for (Subscription subscription : lcnApi.subscriptionsGet(NOKIA_LCN_API_VERSION)) {
+ if (subscription.getCallbackUrl().equals(callbackUrl)) {
+ return;
+ }
+ }
+ CreateSubscriptionRequest request = new CreateSubscriptionRequest();
+ request.setFilter(new SubscriptionFilter());
+ request.getFilter().setNotificationTypes(new ArrayList<>());
+ request.getFilter().getNotificationTypes().add(VnfNotificationType.VNFLIFECYCLECHANGENOTIFICATION);
+ request.setCallbackUrl(callbackUrl);
+ request.getFilter().addOperationTypesItem(OperationType.HEAL);
+ request.getFilter().addOperationTypesItem(OperationType.INSTANTIATE);
+ request.getFilter().addOperationTypesItem(OperationType.SCALE);
+ request.getFilter().addOperationTypesItem(OperationType.TERMINATE);
+ SubscriptionAuthentication subscriptionAuthentication = new SubscriptionAuthentication();
+ subscriptionAuthentication.setType(NONE);
+ request.setAuthentication(subscriptionAuthentication);
+ lcnApi.subscriptionsPost(request, NOKIA_LCN_API_VERSION);
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to subscribe to CBAM LCN", e);
+ }
+ }
+
+ /**
+ * @return is the component ready to serve requests
+ */
+ public boolean isReady() {
+ return ready;
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/package-info.java
new file mode 100644
index 00000000..67bdef8a
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Handles communication with ONAP core functions
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIExternalSystemInfoProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIExternalSystemInfoProvider.java
new file mode 100644
index 00000000..f5656f75
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIExternalSystemInfoProvider.java
@@ -0,0 +1,120 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import org.onap.aai.domain.yang.v11.EsrSystemInfo;
+import org.onap.aai.domain.yang.v11.EsrSystemInfoList;
+import org.onap.aai.domain.yang.v11.EsrVnfm;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.GenericExternalSystemInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vnfmdriver.model.VimInfo;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.core.env.Environment;
+import org.springframework.stereotype.Component;
+
+import static java.lang.String.format;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.CLOUD;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.ESR;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getCloudOwner;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getRegionName;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for providing information related to the VNFM from VF-C source
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+public class AAIExternalSystemInfoProvider extends GenericExternalSystemInfoProvider {
+ private static final String VNFM_URL = "/esr-vnfm-list/esr-vnfm/%s?depth=all";
+ private static final String VIM_URL = "/cloud-regions/cloud-region/%s/%s/esr-system-info-list";
+ private static Logger logger = getLogger(AAIExternalSystemInfoProvider.class);
+ private final AAIRestApiProvider aaiRestApiProvider;
+
+ @Autowired
+ AAIExternalSystemInfoProvider(Environment environment, AAIRestApiProvider aaiRestApiProvider) {
+ super(environment);
+ this.aaiRestApiProvider = aaiRestApiProvider;
+ }
+
+ @Override
+ public VnfmInfo queryVnfmInfoFromSource(String vnfmId) {
+ try {
+ return convertEsrToVnfmInfo(aaiRestApiProvider.get(logger, ESR, format(VNFM_URL, vnfmId), EsrVnfm.class));
+ } catch (RuntimeException e) {
+ throw buildFatalFailure(logger, "Unable to query VNFM with " + vnfmId + " identifier from AAI", e);
+ }
+ }
+
+ @Override
+ public VimInfo getVimInfo(String vimId) {
+ try {
+ return convertEsrToVim(getEsrSystemInfo(vimId), vimId);
+ } catch (RuntimeException e) {
+ throw buildFatalFailure(logger, "Unable to query VIM with " + vimId + " identifier from AAI", e);
+ }
+ }
+
+ /**
+ * @param vimId the identifier of the VIM
+ * @return the VIM details
+ */
+ public EsrSystemInfo getEsrSystemInfo(String vimId) {
+ String url = format(VIM_URL, getCloudOwner(vimId), getRegionName(vimId));
+ return aaiRestApiProvider.get(logger, CLOUD, url, EsrSystemInfoList.class).getEsrSystemInfo().get(0);
+ }
+
+ private VimInfo convertEsrToVim(EsrSystemInfo esrSystemInfo, String vimId) {
+ VimInfo vimInfo = new VimInfo();
+ vimInfo.setDescription(esrSystemInfo.getSystemName());
+ vimInfo.setName(esrSystemInfo.getSystemName());
+ vimInfo.setPassword(esrSystemInfo.getPassword());
+ vimInfo.setStatus(esrSystemInfo.getSystemStatus());
+ vimInfo.setType(esrSystemInfo.getType());
+ vimInfo.setUrl(esrSystemInfo.getServiceUrl());
+ vimInfo.setVersion(esrSystemInfo.getVersion());
+ if (esrSystemInfo.getSslCacert() == null) {
+ vimInfo.setSslInsecure("true");
+ } else {
+ vimInfo.setSslInsecure("false");
+ vimInfo.setSslCacert(esrSystemInfo.getSslCacert());
+ }
+ vimInfo.setUserName(esrSystemInfo.getUserName());
+ vimInfo.setVendor(esrSystemInfo.getVendor());
+ vimInfo.setVimId(vimId);
+ return vimInfo;
+ }
+
+
+ private VnfmInfo convertEsrToVnfmInfo(EsrVnfm vnfmInAai) {
+ EsrSystemInfo esrSystemInfo = vnfmInAai.getEsrSystemInfoList().getEsrSystemInfo().get(0);
+ VnfmInfo vnfmInfo = new VnfmInfo();
+ vnfmInfo.setPassword(esrSystemInfo.getPassword());
+ vnfmInfo.setDescription(esrSystemInfo.getEsrSystemInfoId());
+ vnfmInfo.setName(esrSystemInfo.getSystemName());
+ vnfmInfo.setType(esrSystemInfo.getType());
+ vnfmInfo.setUrl(esrSystemInfo.getServiceUrl());
+ vnfmInfo.setVersion(esrSystemInfo.getVersion());
+ vnfmInfo.setVimId(vnfmInAai.getVimId());
+ vnfmInfo.setVendor(esrSystemInfo.getVendor());
+ vnfmInfo.setUserName(esrSystemInfo.getUserName());
+ vnfmInfo.setVnfmId(vnfmInAai.getVnfmId());
+ return vnfmInfo;
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIRestApiProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIRestApiProvider.java
new file mode 100644
index 00000000..141ba847
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/AAIRestApiProvider.java
@@ -0,0 +1,183 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import com.google.common.annotations.VisibleForTesting;
+import org.onap.aai.restclient.client.Headers;
+import org.onap.aai.restclient.client.OperationResult;
+import org.onap.aai.restclient.client.RestClient;
+import org.onap.aai.restclient.enums.RestAuthenticationMode;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.MsbApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.http.MediaType;
+import org.springframework.stereotype.Component;
+
+import javax.xml.bind.JAXBContext;
+import java.io.ByteArrayOutputStream;
+import java.io.StringReader;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.NoSuchElementException;
+
+import static com.google.common.collect.Lists.newArrayList;
+import static javax.ws.rs.core.MediaType.APPLICATION_XML_TYPE;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager.SERVICE_NAME;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for providing access to AAI APIs.
+ * Handles authentication and mandatory parameters.
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+public class AAIRestApiProvider {
+ private static final String AAI_VERSION = "v11";
+ private static Logger logger = getLogger(AAIRestApiProvider.class);
+ private final MsbApiProvider msbApiProvider;
+ @Value("${aaiUsername}")
+ private String aaiUsername;
+ @Value("${aaiPassword}")
+ private String aaiPassword;
+
+ @Autowired
+ AAIRestApiProvider(MsbApiProvider msbApiProvider) {
+ this.msbApiProvider = msbApiProvider;
+ }
+
+ /**
+ * @param logger the logger of the class that requests unmarshalling
+ * @param service the AAI service of the request
+ * @param url the URL of the request after the base URL (ex. /cloud-infrastructure/...)
+ * @param clazz the class of the result
+ * @param <T> the type of the result
+ * @return the result of the GET request
+ */
+ public <T> T get(Logger logger, AAIService service, String url, Class<T> clazz) {
+ return expectSuccess(logger, buildClient().get(getBaseUrl(service.getServiceName()) + url, buildCommonHeaders(), APPLICATION_XML_TYPE), clazz, url);
+ }
+
+ /**
+ * @param logger the logger of the class that requests unmarshalling
+ * @param service the AAI service of the request
+ * @param url the URL of the request after the base URL (ex. /cloud-infrastructure/...)
+ * @param payload the payload of the request (non serialized)
+ * @param clazz the class of the result
+ * @param <T> the type of the result
+ * @return the result of the PUT request
+ */
+ public <T, S> T put(Logger logger, AAIService service, String url, S payload, Class<T> clazz) {
+ String marshalledContent = marshall(payload);
+ OperationResult result = buildClient().put(getBaseUrl(service.getServiceName()) + url, marshalledContent, buildCommonHeaders(), APPLICATION_XML_TYPE, APPLICATION_XML_TYPE);
+ return expectSuccess(logger, result, clazz, url);
+ }
+
+ /**
+ * Execute a delete request on the given URL
+ *
+ * @param logger the logger of the class that requests unmarshalling
+ * @param service the AAI service of the request
+ * @param url the URL of the request after the base URL (ex. /cloud-infrastructure/...)
+ */
+ public void delete(Logger logger, AAIService service, String url) {
+ buildClient().delete(getBaseUrl(service.getServiceName()) + url, buildCommonHeaders(), APPLICATION_XML_TYPE);
+ }
+
+ /**
+ * @param serviceName the name of the AAI service on MSB
+ * @return the base URL of the service
+ */
+ private String getBaseUrl(String serviceName) {
+ return msbApiProvider.getMicroServiceUrl(serviceName, AAI_VERSION);
+ }
+
+ private <T> T expectSuccess(Logger logger, OperationResult result, Class<T> clazz, String url) {
+ if (!result.wasSuccessful()) {
+ if (result.getResultCode() == 404) {
+ logger.debug("The resource at " + url + " does not exists");
+ throw new NoSuchElementException("The resource at " + url + " does not exists");
+ }
+ throw buildFatalFailure(logger, "Bad response. Code: " + result.getResultCode() + " cause: " + result.getFailureCause());
+ }
+ if (clazz.isAssignableFrom(Void.class)) {
+ return null;
+ }
+ return unmarshal(result.getResult(), clazz);
+ }
+
+ private <T> T unmarshal(String content, Class<T> clazz) {
+ try {
+ return (T) JAXBContext.newInstance(clazz).createUnmarshaller().unmarshal(new StringReader(content));
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to unmarshal content", e);
+ }
+ }
+
+ private String marshall(Object object) {
+ try {
+ ByteArrayOutputStream bos = new ByteArrayOutputStream();
+ JAXBContext.newInstance(object.getClass()).createMarshaller().marshal(object, bos);
+ return bos.toString();
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to marshal content", e);
+ }
+ }
+
+ /**
+ * @return the common mandatory headers for AAI requests
+ */
+ private Map<String, List<String>> buildCommonHeaders() {
+ Map<String, List<String>> headers = new HashMap<>();
+ headers.put(Headers.ACCEPT, newArrayList(MediaType.APPLICATION_XML_VALUE));
+ headers.put(Headers.FROM_APP_ID, newArrayList(SERVICE_NAME));
+ return headers;
+ }
+
+
+ private RestClient buildClient() {
+ return buildRawClient().basicAuthUsername(aaiUsername).basicAuthPassword(aaiPassword).authenticationMode(RestAuthenticationMode.SSL_BASIC);
+ }
+
+ @VisibleForTesting
+ RestClient buildRawClient() {
+ return new RestClient();
+ }
+
+ public enum AAIService {
+ NETWORK {
+ String getServiceName() {
+ return "aai-network";
+ }
+ },
+ ESR {
+ String getServiceName() {
+ return "aai-externalSystem";
+ }
+ },
+ CLOUD {
+ String getServiceName() {
+ return "aai-cloudInfrastructure";
+ }
+ };
+
+ abstract String getServiceName();
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/GrantlessGrantManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/GrantlessGrantManager.java
new file mode 100644
index 00000000..a113405a
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/GrantlessGrantManager.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.IGrantManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vnfmdriver.model.GrantVNFResponseVim;
+import org.onap.vnfmdriver.model.VnfHealRequest;
+import org.onap.vnfmdriver.model.VnfScaleRequest;
+import org.slf4j.Logger;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for handling granting before the execution of a VNF operation in case of direct integration
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+public class GrantlessGrantManager implements IGrantManager {
+ private static Logger logger = getLogger(GrantlessGrantManager.class);
+
+ @Override
+ public void requestGrantForHeal(String vnfmId, String vnfId, String vimId, String onapCsarId, VnfHealRequest request, String jobId) {
+ noGrantRequested();
+ }
+
+ @Override
+ public void requestGrantForScale(String vnfmId, String vnfId, String vimId, String onapCsarId, VnfScaleRequest request, String jobId) {
+ noGrantRequested();
+ }
+
+ @Override
+ public void requestGrantForTerminate(String vnfmId, String vnfId, String vimId, String onapVnfdId, VnfInfo vnf, String jobId) {
+ noGrantRequested();
+ }
+
+ @Override
+ public GrantVNFResponseVim requestGrantForInstantiate(String vnfmId, String vnfId, String vimId, String onapVnfdId, String instantiationLevelId, String cbamVnfdContent, String jobId) {
+ noGrantRequested();
+ GrantVNFResponseVim grantResponse = new GrantVNFResponseVim();
+ grantResponse.setVimId(vimId);
+ return grantResponse;
+ }
+
+ private void noGrantRequested() {
+ logger.info("No grant is requested in direct mode");
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/SdcPackageProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/SdcPackageProvider.java
new file mode 100644
index 00000000..8a165478
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/SdcPackageProvider.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import com.google.gson.Gson;
+import com.google.gson.JsonObject;
+import org.apache.http.HttpEntity;
+import org.apache.http.client.methods.CloseableHttpResponse;
+import org.apache.http.client.methods.HttpGet;
+import org.apache.http.impl.client.CloseableHttpClient;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.IPackageProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.MsbApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+import org.yaml.snakeyaml.Yaml;
+
+import java.io.ByteArrayInputStream;
+import java.io.InputStream;
+
+import static com.google.common.io.ByteStreams.toByteArray;
+import static java.lang.String.format;
+import static org.apache.http.HttpHeaders.ACCEPT;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager.SERVICE_NAME;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getFileInZip;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getVnfdLocation;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.http.MediaType.APPLICATION_OCTET_STREAM_VALUE;
+
+/**
+ * Responsible for providing access to AAI APIs.
+ * Handles authentication and mandatory parameters.
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+public class SdcPackageProvider implements IPackageProvider {
+ private static final String SDC_MSB_NAME = "sdc";
+ private static final String SDC_MSB_VERSION = "v1";
+ private static final String GET_PACKAGE_URL = "%s/sdc/v1/catalog/resources/%s/toscaModel";
+ private static Logger logger = getLogger(SdcPackageProvider.class);
+ private final MsbApiProvider msbApiProvider;
+ private final DriverProperties driverProperties;
+ @Value("${sdcUsername}")
+ private String sdcUsername;
+ @Value("${sdcPassword}")
+ private String sdcPassword;
+
+ @Autowired
+ SdcPackageProvider(MsbApiProvider msbApiProvider, DriverProperties driverProperties) {
+ this.msbApiProvider = msbApiProvider;
+ this.driverProperties = driverProperties;
+ }
+
+ @Override
+ public byte[] getPackage(String csarId) {
+ String baseUrl = msbApiProvider.getMicroServiceUrl(SDC_MSB_NAME, SDC_MSB_VERSION);
+ try {
+ CloseableHttpClient client = systemFunctions().getHttpClient();
+ HttpGet httpget = new HttpGet(format(GET_PACKAGE_URL, baseUrl, csarId));
+ httpget.setHeader(ACCEPT, APPLICATION_OCTET_STREAM_VALUE);
+ httpget.setHeader("X-ECOMP-InstanceID", driverProperties.getVnfmId());
+ httpget.setHeader("X-FromAppId", SERVICE_NAME);
+ CloseableHttpResponse response = client.execute(httpget);
+ HttpEntity entity = response.getEntity();
+ InputStream is = entity.getContent();
+ byte[] bytes = toByteArray(is);
+ client.close();
+ return bytes;
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to download " + csarId + " package from SDC", e);
+ }
+ }
+
+ @Override
+ public String getCbamVnfdId(String csarId) {
+ byte[] onapPackage = getPackage(csarId);
+ try {
+ String vnfdLocation = getVnfdLocation(new ByteArrayInputStream(onapPackage));
+ String onapVnfdContent = getFileInZip(new ByteArrayInputStream(onapPackage), vnfdLocation).toString();
+ JsonObject root = new Gson().toJsonTree(new Yaml().load(onapVnfdContent)).getAsJsonObject();
+ return childElement(child(root, "metadata"), "resourceVendorModelNumber").getAsString();
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to extract CBAM VNFD id from ONAP package", e);
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AAINotificationProcessor.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AAINotificationProcessor.java
new file mode 100644
index 00000000..ff2bde8a
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AAINotificationProcessor.java
@@ -0,0 +1,146 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.nokia.cbam.lcm.v32.model.AffectedVirtualLink;
+import com.nokia.cbam.lcm.v32.model.OperationExecution;
+import com.nokia.cbam.lcm.v32.model.VnfLifecycleChangeNotification;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.INotificationSender;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedConnectionPoints;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedCp;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.Optional;
+import java.util.Set;
+
+import static com.google.common.collect.Iterables.filter;
+import static com.google.common.collect.Iterables.tryFind;
+import static com.nokia.cbam.lcm.v32.model.ChangeType.*;
+import static com.nokia.cbam.lcm.v32.model.OperationStatus.STARTED;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.LInterfaceManager.buildUrl;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.util.StringUtils.isEmpty;
+
+/**
+ * Responsible for providing information related to the VNFM from VF-C source
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+public class AAINotificationProcessor implements INotificationSender {
+ private static Logger logger = getLogger(AAINotificationProcessor.class);
+ private final GenericVnfManager genericVnfManager;
+ private final L3NetworkManager l3NetworkManager;
+ private final LInterfaceManager lInterfaceManager;
+ private final VnfcManager vnfcManager;
+ private final VserverManager vserverManager;
+
+ @Autowired
+ AAINotificationProcessor(GenericVnfManager genericVnfManager, L3NetworkManager l3NetworkManager, LInterfaceManager lInterfaceManager, VnfcManager vnfcManager, VserverManager vserverManager) {
+ this.genericVnfManager = genericVnfManager;
+ this.l3NetworkManager = l3NetworkManager;
+ this.lInterfaceManager = lInterfaceManager;
+ this.vnfcManager = vnfcManager;
+ this.vserverManager = vserverManager;
+ }
+
+ @Override
+ public void processNotification(VnfLifecycleChangeNotification receivedNotification, OperationExecution operationExecution, Optional<ReportedAffectedConnectionPoints> affectedConnectionPoints, String vimId) {
+ boolean inMaintenance = STARTED.equals(receivedNotification.getStatus());
+ genericVnfManager.createOrUpdate(receivedNotification.getVnfInstanceId(), inMaintenance);
+ addOrUpdateVls(receivedNotification, vimId);
+ addOrUpdateVnfcs(receivedNotification, vimId, inMaintenance);
+ processCps(receivedNotification, affectedConnectionPoints, vimId, inMaintenance);
+ removeVnfcs(receivedNotification, vimId);
+ removeVls(receivedNotification);
+ logger.info("Notification processed successfully");
+ }
+
+ private void removeVls(VnfLifecycleChangeNotification receivedNotification) {
+ for (AffectedVirtualLink removedVl : filter(receivedNotification.getAffectedVirtualLinks(), affectedVirtualLink -> affectedVirtualLink.getChangeType().equals(REMOVED))) {
+ l3NetworkManager.delete(receivedNotification.getVnfInstanceId(), removedVl);
+ }
+ }
+
+ private void removeVnfcs(VnfLifecycleChangeNotification receivedNotification, String vimId) {
+ for (com.nokia.cbam.lcm.v32.model.AffectedVnfc removedVnfc : filter(receivedNotification.getAffectedVnfcs(), vnfc -> REMOVED.equals(vnfc.getChangeType()))) {
+ vnfcManager.delete(receivedNotification.getVnfInstanceId(), removedVnfc);
+ vserverManager.delete(vimId, removedVnfc);
+ }
+ }
+
+ private void processCps(VnfLifecycleChangeNotification receivedNotification, Optional<ReportedAffectedConnectionPoints> affectedConnectionPoints, String vimId, boolean inMaintenance) {
+ if (affectedConnectionPoints.isPresent()) {
+ for (ReportedAffectedCp removedCp : collectCpsToBeDeleted(vimId, affectedConnectionPoints.get())) {
+ lInterfaceManager.delete(vimId, removedCp);
+ }
+ //these can only be added or modified because if something is in the post CPS it can not be removed
+ //since it is present after the operation
+ for (ReportedAffectedCp affectedCp : affectedConnectionPoints.get().getPost()) {
+ if (!isEmpty(affectedCp.getServerProviderId())) {
+ lInterfaceManager.update(receivedNotification.getVnfInstanceId(), vimId, affectedCp, inMaintenance);
+ }
+ else{
+ logger.warn("The changed {} connection point is not linked to any server", affectedCp.getCpId());
+ }
+ }
+ }
+ else{
+ logger.warn("The changed connection points are not present in VNF with {} identifier", receivedNotification.getVnfInstanceId());
+ }
+ }
+
+ private void addOrUpdateVnfcs(VnfLifecycleChangeNotification receivedNotification, String vimId, boolean inMaintenance) {
+ for (com.nokia.cbam.lcm.v32.model.AffectedVnfc affectedVnfc : receivedNotification.getAffectedVnfcs()) {
+ if (affectedVnfc.getChangeType() == MODIFIED || affectedVnfc.getChangeType() == ADDED) {
+ vserverManager.update(vimId, receivedNotification.getVnfInstanceId(), affectedVnfc, receivedNotification.getAffectedVirtualStorages(), inMaintenance);
+ vnfcManager.update(vimId, VserverManager.getTenantId(affectedVnfc), receivedNotification.getVnfInstanceId(), affectedVnfc, inMaintenance);
+ }
+ }
+ }
+
+ private void addOrUpdateVls(VnfLifecycleChangeNotification receivedNotification, String vimId) {
+ for (AffectedVirtualLink affectedVirtualLink : receivedNotification.getAffectedVirtualLinks()) {
+ if ((affectedVirtualLink.getChangeType() == MODIFIED) || (affectedVirtualLink.getChangeType() == ADDED)) {
+ l3NetworkManager.update(vimId, receivedNotification.getVnfInstanceId(), affectedVirtualLink);
+ }
+ }
+ }
+
+ /**
+ * The ports that are present in the pre, but not present in the post are
+ * removed regardless of the "removed" flag being present in the pre, because
+ * that only signals the remove intention, but does not actually mean that
+ * the resource have been removed
+ */
+ private Collection<ReportedAffectedCp> collectCpsToBeDeleted(String vimId, ReportedAffectedConnectionPoints cps) {
+ Set<ReportedAffectedCp> cpsToRemove = new HashSet<>();
+ for (ReportedAffectedCp cpBeforeOperation : cps.getPre()) {
+ if (!isEmpty(cpBeforeOperation.getServerProviderId())) {
+ String originalResource = buildUrl(vimId, cpBeforeOperation);
+ if (!tryFind(cps.getPost(), cpAfterOperation -> originalResource.equals(buildUrl(vimId, cpAfterOperation))).isPresent()) {
+ cpsToRemove.add(cpBeforeOperation);
+ }
+ }
+ }
+ return cpsToRemove;
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AbstractManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AbstractManager.java
new file mode 100644
index 00000000..c8008f38
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/AbstractManager.java
@@ -0,0 +1,143 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.google.gson.Gson;
+import org.onap.aai.domain.yang.v11.ObjectFactory;
+import org.onap.aai.domain.yang.v11.Relationship;
+import org.onap.aai.domain.yang.v11.RelationshipData;
+import org.onap.aai.domain.yang.v11.RelationshipList;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.slf4j.Logger;
+
+import java.util.HashSet;
+import java.util.List;
+import java.util.NoSuchElementException;
+import java.util.Set;
+
+import static com.google.common.collect.Iterables.find;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.SEPARATOR;
+
+/**
+ * Handles the common management of changing entities in AAI
+ */
+abstract class AbstractManager {
+ protected static final ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ protected final AAIRestApiProvider aaiRestApiProvider;
+ protected final CbamRestApiProvider cbamRestApiProvider;
+ protected final DriverProperties driverProperties;
+
+ AbstractManager(AAIRestApiProvider aaiRestApiProvider, CbamRestApiProvider cbamRestApiProvider, DriverProperties driverProperties) {
+ this.aaiRestApiProvider = aaiRestApiProvider;
+ this.cbamRestApiProvider = cbamRestApiProvider;
+ this.driverProperties = driverProperties;
+ }
+
+ /**
+ * @param key the key of the relationship
+ * @param value the value of the relationship
+ * @return the relationship
+ */
+ protected static RelationshipData buildRelationshipData(String key, String value) {
+ RelationshipData data = new RelationshipData();
+ data.setRelationshipKey(key);
+ data.setRelationshipValue(value);
+ return data;
+ }
+
+ /**
+ * Extract mandatory value from the additional data on LCN resources
+ *
+ * @param additionalData the additional data
+ * @param key the key of the additional data
+ * @return the value of the additional data
+ */
+ protected static String extractMandatoryValue(Object additionalData, String key) {
+ return new Gson().toJsonTree(additionalData).getAsJsonObject().get(key).getAsString();
+ }
+
+ /**
+ * Create or update the singleton relationship. Singleton means that relationships can only have a
+ * single {@link Relationship} with the given {@link Relationship#getRelatedTo} value
+ *
+ * @param relationships the list of relationships
+ * @param relationship the expected relationship
+ */
+ protected static void addSingletonRelation(RelationshipList relationships, Relationship relationship) {
+ boolean found = false;
+ for (Relationship currentRelationShip : relationships.getRelationship()) {
+ if (relationship.getRelatedTo().equals(currentRelationShip.getRelatedTo())) {
+ found = true;
+ }
+ }
+ if (!found) {
+ relationships.getRelationship().add(relationship);
+ } else {
+ Relationship existingRelationShip = find(relationships.getRelationship(), currentRelationShip -> currentRelationShip.getRelatedTo().equals(relationship.getRelatedTo()));
+ existingRelationShip.getRelationshipData().clear();
+ existingRelationShip.getRelationshipData().addAll(relationship.getRelationshipData());
+ }
+ }
+
+ /**
+ * Add the given relationship if it is already not part of the relationships
+ *
+ * @param relationships the relationships
+ * @param relationship the relationship to be added
+ */
+ protected static void addMissingRelation(RelationshipList relationships, Relationship relationship) {
+ for (Relationship currentRelationShip : relationships.getRelationship()) {
+ if (currentRelationShip.getRelatedTo().equals(relationship.getRelatedTo())
+ && compositeKeys(currentRelationShip.getRelationshipData()).equals(compositeKeys(relationship.getRelationshipData()))) {
+ return;
+ }
+ }
+ relationships.getRelationship().add(relationship);
+ }
+
+ private static Set<String> compositeKeys(List<RelationshipData> data) {
+ Set<String> keys = new HashSet<>();
+ for (RelationshipData relationshipData : data) {
+ keys.add(relationshipData.getRelationshipKey() + SEPARATOR + relationshipData.getRelationshipValue());
+ }
+ return keys;
+ }
+
+ /**
+ * @return the concrete logger to be used
+ */
+ protected abstract Logger getLogger();
+
+ /**
+ * Creates or returns a REST resource instance
+ *
+ * @param service the type of the service
+ * @param url the URL of the resource without the service prefix
+ * @param newInstance the empty instance if the resource does not exists
+ * @param <T> the type of the resource
+ * @return the created or queried resource
+ */
+ protected <T> T createOrGet(AAIRestApiProvider.AAIService service, String url, T newInstance) {
+ try {
+ return (T) aaiRestApiProvider.get(getLogger(), service, url, newInstance.getClass());
+ } catch (NoSuchElementException e) {
+ getLogger().debug("The resource on " + url + " URL was not found in AAI", e);
+ return newInstance;
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/GenericVnfManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/GenericVnfManager.java
new file mode 100644
index 00000000..959177c1
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/GenericVnfManager.java
@@ -0,0 +1,114 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import org.onap.aai.domain.yang.v11.GenericVnf;
+import org.onap.aai.domain.yang.v11.Relationship;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import java.util.NoSuchElementException;
+
+import static java.lang.String.format;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.NETWORK;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+
+/**
+ * Responsible for managing the {@link GenericVnf} in AAI
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+class GenericVnfManager extends AbstractManager {
+ private static final String VNF_URL = "/generic-vnfs/generic-vnf/%s";
+ private static final long MAX_MS_TO_WAIT_FOR_VNF_TO_APPEAR = 30 * 1000L;
+ private static Logger logger = org.slf4j.LoggerFactory.getLogger(GenericVnfManager.class);
+
+ @Autowired
+ GenericVnfManager(AAIRestApiProvider aaiRestApiProvider, CbamRestApiProvider cbamRestApiProvider, DriverProperties driverProperties) {
+ super(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ }
+
+ static Relationship linkTo(String vnfId) {
+ Relationship relationship = new Relationship();
+ relationship.setRelatedTo("generic-vnf");
+ relationship.getRelationshipData().add(buildRelationshipData("generic-vnf.vnf-id", vnfId));
+ return relationship;
+ }
+
+ @Override
+ protected Logger getLogger() {
+ return logger;
+ }
+
+ void createOrUpdate(String vnfId, boolean inMaintenance) {
+ try {
+ GenericVnf vnf = waitForVnfToAppearInAai(vnfId);
+ updateFields(vnf, vnfId, inMaintenance);
+ } catch (NoSuchElementException e) {
+ try {
+ logger.warn("The VNF with " + vnfId + " identifier did not appear in time", e);
+ updateFields(OBJECT_FACTORY.createGenericVnf(), vnfId, inMaintenance);
+ } catch (Exception e2) {
+ logger.warn("The VNF with " + vnfId + " identifier has been created since after the maximal wait for VNF to appear timeout", e2);
+ //the VNF might have been created since the last poll
+ updateFields(getExistingVnf(vnfId), vnfId, inMaintenance);
+ }
+ }
+ }
+
+ GenericVnf getExistingVnf(String vnfId) {
+ return aaiRestApiProvider.get(logger, NETWORK, format(VNF_URL, vnfId), GenericVnf.class);
+ }
+
+ private void updateFields(GenericVnf vnf, String vnfId, boolean inMaintenance) {
+ try {
+ VnfInfo vnfInfo = cbamRestApiProvider.getCbamLcmApi(driverProperties.getVnfmId()).vnfsVnfInstanceIdGet(vnfId, CbamRestApiProvider.NOKIA_LCM_API_VERSION);
+ vnf.setVnfName(vnfInfo.getName());
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to query VNF with " + vnfId + " identifier from CBAM", e);
+ }
+ vnf.setVnfId(vnfId);
+ vnf.setInMaint(inMaintenance);
+ vnf.setVnfInstanceId(vnfId);
+ //FIXME whould be good to know if this parameter is relevant or not? (mandatory)
+ vnf.setVnfType("NokiaVNF");
+ vnf.setIsClosedLoopDisabled(inMaintenance);
+ aaiRestApiProvider.put(logger, NETWORK, format(VNF_URL, vnf.getVnfId()), vnf, Void.class);
+ }
+
+ private GenericVnf waitForVnfToAppearInAai(String vnfId) {
+ long timeoutInMs = systemFunctions().currentTimeMillis() + MAX_MS_TO_WAIT_FOR_VNF_TO_APPEAR;
+ while (timeoutInMs - systemFunctions().currentTimeMillis() > 0) {
+ try {
+ return aaiRestApiProvider.get(logger, NETWORK, format(VNF_URL, vnfId), GenericVnf.class);
+ } catch (NoSuchElementException e) {
+ logger.debug("Unable to get VNF with " + vnfId + " identifier", e);
+ }
+ systemFunctions().sleep(3 * 1000L);
+ }
+ throw new NoSuchElementException();
+ }
+
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/L3NetworkManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/L3NetworkManager.java
new file mode 100644
index 00000000..6d2b42bc
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/L3NetworkManager.java
@@ -0,0 +1,104 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.nokia.cbam.lcm.v32.model.AffectedVirtualLink;
+import org.onap.aai.domain.yang.v11.L3Network;
+import org.onap.aai.domain.yang.v11.Relationship;
+import org.onap.aai.domain.yang.v11.RelationshipList;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import static java.lang.String.format;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.NETWORK;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.SEPARATOR;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getCloudOwner;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getRegionName;
+
+/**
+ * Responsible for managing the {@link L3Network} in AAI
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+class L3NetworkManager extends AbstractManager {
+ private static final String NETWORK_URL = "/l3-networks/l3-network/%s";
+ private static Logger logger = org.slf4j.LoggerFactory.getLogger(L3NetworkManager.class);
+
+ @Autowired
+ L3NetworkManager(AAIRestApiProvider aaiRestApiProvider, CbamRestApiProvider cbamRestApiProvider, DriverProperties driverProperties) {
+ super(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ }
+
+ @Override
+ protected Logger getLogger() {
+ return logger;
+ }
+
+ void update(String vimId, String vnfId, AffectedVirtualLink affectedVirtualLink) {
+ L3Network l3Network = createOrGet(NETWORK, format(NETWORK_URL, buildNetworkId(vnfId, affectedVirtualLink)), OBJECT_FACTORY.createL3Network());
+ updateNetworkFields(vimId, vnfId, affectedVirtualLink, l3Network);
+ }
+
+ void delete(String vnfId, AffectedVirtualLink removedVl) {
+ aaiRestApiProvider.delete(logger, NETWORK, format(NETWORK_URL, buildNetworkId(vnfId, removedVl)));
+ }
+
+ private void updateNetworkFields(String vimId, String vnfId, AffectedVirtualLink affectedVirtualLink, L3Network network) {
+ network.setNetworkId(buildNetworkId(vnfId, affectedVirtualLink));
+ network.setNetworkName(extractMandatoryValue(affectedVirtualLink.getResource().getAdditionalData(), "name"));
+ network.setNeutronNetworkId(affectedVirtualLink.getResource().getResourceId());
+ network.setIsBoundToVpn(false);
+ network.setIsExternalNetwork(false);
+ network.setIsProviderNetwork(false);
+ network.setIsSharedNetwork(false);
+ network.setOperationalStatus("active");
+ network.setOrchestrationStatus("active");
+ if (network.getRelationshipList() == null) {
+ network.setRelationshipList(new RelationshipList());
+ }
+ addMissingRelation(network.getRelationshipList(), GenericVnfManager.linkTo(vnfId));
+ addSingletonRelation(network.getRelationshipList(), getRegionLink(vimId));
+ addSingletonRelation(network.getRelationshipList(), getTenantLink(vimId, extractMandatoryValue(affectedVirtualLink.getResource().getAdditionalData(), "tenantId")));
+ aaiRestApiProvider.put(logger, NETWORK, format(NETWORK_URL, network.getNetworkId()), network, Void.class);
+ }
+
+ private String buildNetworkId(String vnfId, AffectedVirtualLink affectedVirtualLink) {
+ return vnfId + SEPARATOR + affectedVirtualLink.getId();
+ }
+
+ private Relationship getRegionLink(String vimId) {
+ Relationship relationship = new Relationship();
+ relationship.setRelatedTo("cloud-region");
+ relationship.getRelationshipData().add(buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(vimId)));
+ relationship.getRelationshipData().add(buildRelationshipData("cloud-region.cloud-region-id", getRegionName(vimId)));
+ return relationship;
+ }
+
+ private Relationship getTenantLink(String vimId, String tenantId) {
+ Relationship relationship = new Relationship();
+ relationship.setRelatedTo("tenant");
+ relationship.getRelationshipData().add(buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(vimId)));
+ relationship.getRelationshipData().add(buildRelationshipData("cloud-region.cloud-region-id", getRegionName(vimId)));
+ relationship.getRelationshipData().add(buildRelationshipData("tenant.tenant-id", tenantId));
+ return relationship;
+ }
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/LInterfaceManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/LInterfaceManager.java
new file mode 100644
index 00000000..229fe679
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/LInterfaceManager.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import org.onap.aai.domain.yang.v11.L3InterfaceIpv4AddressList;
+import org.onap.aai.domain.yang.v11.L3InterfaceIpv6AddressList;
+import org.onap.aai.domain.yang.v11.LInterface;
+import org.onap.aai.domain.yang.v11.RelationshipList;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedCp;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import static java.lang.String.format;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.CLOUD;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getCloudOwner;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getRegionName;
+
+/**
+ * Responsible for managing the {@link LInterface} in AAI
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+class LInterfaceManager extends AbstractManager {
+ private static Logger logger = org.slf4j.LoggerFactory.getLogger(LInterfaceManager.class);
+
+ @Autowired
+ LInterfaceManager(AAIRestApiProvider aaiRestApiProvider, CbamRestApiProvider cbamRestApiProvider, DriverProperties driverProperties) {
+ super(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ }
+
+ static String buildUrl(String vimId, ReportedAffectedCp affectedCp) {
+ String cloudOwner = getCloudOwner(vimId);
+ String regionName = getRegionName(vimId);
+ String tenantId = affectedCp.getTenantId();
+ String vServerId = affectedCp.getServerProviderId();
+ String cpId = affectedCp.getCpId();
+ return format("/cloud-regions/cloud-region/%s/%s/tenants/tenant/%s/vservers/vserver/%s/l-interfaces/l-interface/%s", cloudOwner, regionName, tenantId, vServerId, cpId);
+ }
+
+ @Override
+ protected Logger getLogger() {
+ return logger;
+ }
+
+ void update(String vnfId, String vimId, ReportedAffectedCp affectedCp, boolean inMaintenance) {
+ LInterface lInterface = createOrGet(CLOUD, buildUrl(vimId, affectedCp), OBJECT_FACTORY.createLInterface());
+ updateFields(lInterface, affectedCp, vnfId, buildUrl(vimId, affectedCp), inMaintenance);
+ }
+
+ void delete(String vimId, ReportedAffectedCp removedCp) {
+ aaiRestApiProvider.delete(logger, AAIRestApiProvider.AAIService.CLOUD, buildUrl(vimId, removedCp));
+ }
+
+ private void updateFields(LInterface logicalInterface, ReportedAffectedCp affectedCp, String vnfId, String url, boolean inMaintenance) {
+ logicalInterface.setInMaint(inMaintenance);
+ logicalInterface.setIsIpUnnumbered(false);
+ logicalInterface.setIsPortMirrored(false);
+ logicalInterface.setInterfaceName(affectedCp.getName());
+ logicalInterface.setInterfaceId(affectedCp.getCpId());
+ logicalInterface.setInterfaceRole(affectedCp.getCpdId());
+ logicalInterface.setMacaddr(affectedCp.getMacAddress());
+ logicalInterface.setProvStatus("active");
+ if (affectedCp.getIpAddress() != null) {
+ if (affectedCp.getIpAddress().contains(":")) {
+ L3InterfaceIpv6AddressList ipv6Address = OBJECT_FACTORY.createL3InterfaceIpv6AddressList();
+ ipv6Address.setL3InterfaceIpv6Address(affectedCp.getIpAddress());
+ ipv6Address.setNeutronNetworkId(affectedCp.getNetworkProviderId());
+ logicalInterface.getL3InterfaceIpv6AddressList().add(ipv6Address);
+ } else {
+ L3InterfaceIpv4AddressList ipv4Address = OBJECT_FACTORY.createL3InterfaceIpv4AddressList();
+ ipv4Address.setL3InterfaceIpv4Address(affectedCp.getIpAddress());
+ ipv4Address.setNeutronNetworkId(affectedCp.getNetworkProviderId());
+ logicalInterface.getL3InterfaceIpv4AddressList().add(ipv4Address);
+ }
+ }
+ if (logicalInterface.getRelationshipList() == null) {
+ logicalInterface.setRelationshipList(new RelationshipList());
+ }
+ addSingletonRelation(logicalInterface.getRelationshipList(), GenericVnfManager.linkTo(vnfId));
+ aaiRestApiProvider.put(logger, CLOUD, url, logicalInterface, Void.class);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VnfcManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VnfcManager.java
new file mode 100644
index 00000000..976e283d
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VnfcManager.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.google.common.base.Splitter;
+import com.nokia.cbam.lcm.v32.model.AffectedVnfc;
+import org.onap.aai.domain.yang.v11.RelationshipList;
+import org.onap.aai.domain.yang.v11.Vnfc;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import static java.lang.String.format;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.NETWORK;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.SEPARATOR;
+
+/**
+ * Responsible for managing {@link Vnfc} in AAI
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+public class VnfcManager extends AbstractManager {
+ private static Logger logger = org.slf4j.LoggerFactory.getLogger(VnfcManager.class);
+
+ @Autowired
+ VnfcManager(AAIRestApiProvider aaiRestApiProvider, CbamRestApiProvider cbamRestApiProvider, DriverProperties driverProperties) {
+ super(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ }
+
+ public static String buildUrl(String vnfId, String cbamVnfcId) {
+ return format("/vnfcs/vnfc/%s", buildId(vnfId, cbamVnfcId));
+ }
+
+ public static String getCbamVnfcId(String vnfcId){
+ String vnfId = Splitter.on(CbamUtils.SEPARATOR).split(vnfcId).iterator().next();
+ return vnfcId.replaceFirst(vnfId + SEPARATOR, "");
+ }
+
+ private static String buildId(String vnfId, String cbamVnfcId) {
+ return vnfId + SEPARATOR + cbamVnfcId;
+ }
+
+ @Override
+ protected Logger getLogger() {
+ return logger;
+ }
+
+ void delete(String vnfId, com.nokia.cbam.lcm.v32.model.AffectedVnfc cbamVnfc) {
+ aaiRestApiProvider.delete(logger, NETWORK, buildUrl(vnfId, cbamVnfc.getId()));
+ }
+
+ void update(String vimId, String tenantId, String vnfId, com.nokia.cbam.lcm.v32.model.AffectedVnfc cbamVnfc, boolean inMaintenance) {
+ String url = buildUrl(vnfId, cbamVnfc.getId());
+ Vnfc vnfc = createOrGet(NETWORK, url, OBJECT_FACTORY.createVnfc());
+ updateFields(vimId, tenantId, vnfc, cbamVnfc, vnfId, url, inMaintenance);
+ }
+
+ private void updateFields(String vimId, String tenantId, Vnfc aaiVnfc, com.nokia.cbam.lcm.v32.model.AffectedVnfc cbamVnfc, String vnfId, String url, boolean inMaintenance) {
+ aaiVnfc.setInMaint(inMaintenance);
+ aaiVnfc.setIsClosedLoopDisabled(inMaintenance);
+ //FIXME would be good to know what is this mandatory parameter
+ aaiVnfc.setNfcFunction(cbamVnfc.getId());
+ //FIXME would be good to know what is this mandatory parameter
+ aaiVnfc.setNfcNamingCode(cbamVnfc.getId());
+ aaiVnfc.setVnfcName(buildId(vnfId, cbamVnfc.getId()));
+ aaiVnfc.setRelationshipList(new RelationshipList());
+ addSingletonRelation(aaiVnfc.getRelationshipList(), VserverManager.linkTo(vimId, tenantId, cbamVnfc.getComputeResource().getResourceId()));
+ addSingletonRelation(aaiVnfc.getRelationshipList(), GenericVnfManager.linkTo(vnfId));
+ aaiRestApiProvider.put(logger, NETWORK, url, aaiVnfc, Void.class);
+ }
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VserverManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VserverManager.java
new file mode 100644
index 00000000..cec779a4
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/VserverManager.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.google.gson.Gson;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.model.AffectedVirtualStorage;
+import com.nokia.cbam.lcm.v32.model.AffectedVnfc;
+import org.onap.aai.domain.yang.v11.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import java.util.List;
+
+import static com.google.common.collect.Iterables.find;
+import static java.lang.String.format;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.CLOUD;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.childElement;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getCloudOwner;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getRegionName;
+
+/**
+ * Responsible for managing {@link Vserver} in AAI
+ */
+@Component
+@Conditional(value = Conditions.UseForDirect.class)
+class VserverManager extends AbstractManager {
+ private static Logger logger = org.slf4j.LoggerFactory.getLogger(VserverManager.class);
+
+ @Autowired
+ VserverManager(AAIRestApiProvider aaiRestApiProvider, CbamRestApiProvider cbamRestApiProvider, DriverProperties driverProperties) {
+ super(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ }
+
+ static Relationship linkTo(String vimId, String tenantId, String serverProviderId) {
+ Relationship relationship = new Relationship();
+ relationship.setRelatedTo("vserver");
+ relationship.getRelationshipData().add(buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(vimId)));
+ relationship.getRelationshipData().add(buildRelationshipData("cloud-region.cloud-region-id", getRegionName(vimId)));
+ relationship.getRelationshipData().add(buildRelationshipData("tenant.tenant-id", tenantId));
+ relationship.getRelationshipData().add(buildRelationshipData("vserver.vserver-id", serverProviderId));
+ return relationship;
+ }
+
+ static String getTenantId(AffectedVnfc cbamVnfc) {
+ return extractMandatoryValue(cbamVnfc.getComputeResource().getAdditionalData(), "tenantId");
+ }
+
+ @Override
+ protected Logger getLogger() {
+ return logger;
+ }
+
+ void update(String vimId, String vnfId, AffectedVnfc cbamVnfc, List<AffectedVirtualStorage> affectedVirtualStorages, boolean inMaintenance) {
+ String url = buildUrl(vimId, cbamVnfc);
+ Vserver vserver = createOrGet(CLOUD, url, OBJECT_FACTORY.createVserver());
+ updateFields(vserver, cbamVnfc, vnfId, affectedVirtualStorages, url, inMaintenance);
+ }
+
+ void delete(String vimId, com.nokia.cbam.lcm.v32.model.AffectedVnfc deletedVnfc) {
+ aaiRestApiProvider.delete(logger, CLOUD, buildUrl(vimId, deletedVnfc));
+ }
+
+ private String buildUrl(String vimId, AffectedVnfc cbamVnfc) {
+ String tenantId = getTenantId(cbamVnfc);
+ String cloudOwner = getCloudOwner(vimId);
+ String regionName = getRegionName(vimId);
+ return format("/cloud-regions/cloud-region/%s/%s/tenants/tenant/%s/vservers/vserver/%s", cloudOwner, regionName, tenantId, cbamVnfc.getComputeResource().getResourceId());
+ }
+
+ private void updateFields(Vserver server, AffectedVnfc cbamVnfc, String vnfId, List<AffectedVirtualStorage> affectedVirtualStorages, String url, boolean inMaintenance) {
+ server.setInMaint(inMaintenance);
+ server.setIsClosedLoopDisabled(inMaintenance);
+ JsonElement additionalData = new Gson().toJsonTree(cbamVnfc.getComputeResource().getAdditionalData());
+ server.setVserverName(additionalData.getAsJsonObject().get("name").getAsString());
+ server.setVserverId(cbamVnfc.getComputeResource().getResourceId());
+ server.setProvStatus("active");
+ server.setRelationshipList(new RelationshipList());
+ server.setVserverId(cbamVnfc.getComputeResource().getResourceId());
+ server.setVserverSelflink(extractSelfLink(cbamVnfc.getComputeResource().getAdditionalData()));
+ addSingletonRelation(server.getRelationshipList(), GenericVnfManager.linkTo(vnfId));
+ if (server.getVolumes() == null) {
+ server.setVolumes(new Volumes());
+ }
+ if (cbamVnfc.getStorageResourceIds() != null) {
+ for (String virtualStorageId : cbamVnfc.getStorageResourceIds()) {
+ Volume volume = new Volume();
+ AffectedVirtualStorage affectedStorage = find(affectedVirtualStorages, storage -> virtualStorageId.equals(storage.getId()));
+ volume.setVolumeId(affectedStorage.getResource().getResourceId());
+ server.getVolumes().getVolume().add(volume);
+ }
+ } else {
+ server.setVolumes(OBJECT_FACTORY.createVolumes());
+ }
+ aaiRestApiProvider.put(logger, CLOUD, url, server, Void.class);
+ }
+
+ private String extractSelfLink(Object additionalData) {
+ try {
+ JsonObject root = new Gson().toJsonTree(additionalData).getAsJsonObject();
+ for (JsonElement link : childElement(root, "links").getAsJsonArray()) {
+ if (link.getAsJsonObject().has("rel") && "self".equals(link.getAsJsonObject().get("rel").getAsString())) {
+ return link.getAsJsonObject().get("href").getAsString();
+ }
+ }
+ return "unknown";
+ } catch (Exception e) {
+ logger.debug("Missing links in the server", e);
+ return "unknown";
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/package-info.java
new file mode 100644
index 00000000..7b1cca56
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Handles notification processing in case of direct SO integration
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/package-info.java
new file mode 100644
index 00000000..39fc82d5
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Handles information exchange with ONAP components directly instead of routing request through VF-C
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/package-info.java
new file mode 100644
index 00000000..eea0066b
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Handles information exchange with ONAP components
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcExternalSystemInfoProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcExternalSystemInfoProvider.java
new file mode 100644
index 00000000..416367d7
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcExternalSystemInfoProvider.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.GenericExternalSystemInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vnfmdriver.ApiException;
+import org.onap.vnfmdriver.model.VimInfo;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.core.env.Environment;
+import org.springframework.stereotype.Component;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for providing information related to the VNFM from VF-C source
+ */
+@Component
+@Conditional(value = Conditions.UseForVfc.class)
+public class VfcExternalSystemInfoProvider extends GenericExternalSystemInfoProvider {
+ private static Logger logger = getLogger(VfcExternalSystemInfoProvider.class);
+ private final VfcRestApiProvider vfcRestApiProvider;
+
+ @Autowired
+ VfcExternalSystemInfoProvider(Environment environment, VfcRestApiProvider vfcRestApiProvider) {
+ super(environment);
+ this.vfcRestApiProvider = vfcRestApiProvider;
+ }
+
+ @Override
+ public VnfmInfo queryVnfmInfoFromSource(String vnfmId) {
+ try {
+ return vfcRestApiProvider.getNsLcmApi().queryVnfmInfo(vnfmId);
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to query VNFM from VF-C with " + vnfmId + " identifier", e);
+ }
+ }
+
+ @Override
+ public VimInfo getVimInfo(String vimId) {
+ try {
+ return vfcRestApiProvider.getNsLcmApi().queryVIMInfo(vimId);
+ } catch (org.onap.vnfmdriver.ApiException e) {
+ throw buildFatalFailure(logger, "Unable to query VIM from VF-C with " + vimId + " identifier", e);
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcGrantManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcGrantManager.java
new file mode 100644
index 00000000..1d9ef8dc
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcGrantManager.java
@@ -0,0 +1,243 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import com.google.common.annotations.VisibleForTesting;
+import com.google.gson.Gson;
+import com.google.gson.JsonArray;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import com.nokia.cbam.lcm.v32.model.VnfcResourceInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.IGrantManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vnfmdriver.model.*;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+import org.yaml.snakeyaml.Yaml;
+
+import java.util.*;
+
+import static com.nokia.cbam.lcm.v32.model.InstantiationState.INSTANTIATED;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.child;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.onap.vnfmdriver.model.OperationType.TERMINAL;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for handling granting before the execution of a VNF operation
+ */
+@Component
+@Conditional(value = Conditions.UseForVfc.class)
+public class VfcGrantManager implements IGrantManager {
+ private static Logger logger = getLogger(VfcGrantManager.class);
+ private final CatalogManager catalogManager;
+ private final CbamRestApiProvider cbamRestApiProvider;
+ private final VfcRestApiProvider vfcRestApiProvider;
+
+ @Autowired
+ VfcGrantManager(CatalogManager catalogManager, CbamRestApiProvider cbamRestApiProvider, VfcRestApiProvider vfcRestApiProvider) {
+ this.catalogManager = catalogManager;
+ this.cbamRestApiProvider = cbamRestApiProvider;
+ this.vfcRestApiProvider = vfcRestApiProvider;
+ }
+
+ @Override
+ public void requestGrantForHeal(String vnfmId, String vnfId, String vimId, String onapCsarId, VnfHealRequest request, String jobId) {
+ GrantVNFRequest grantRequest = buildGrantRequest(vnfmId, vimId, onapCsarId, jobId, OperationType.HEAL);
+ ResourceChange resourceChange = new ResourceChange();
+ resourceChange.setType(ChangeType.VDU);
+ resourceChange.setVdu(request.getAffectedvm().getVduid());
+ resourceChange.setResourceDefinitionId(UUID.randomUUID().toString());
+ grantRequest.getRemoveResource().add(resourceChange);
+ grantRequest.getAddResource().add(resourceChange);
+ grantRequest.setVnfInstanceId(vnfId);
+ requestGrant(grantRequest);
+ }
+
+ @Override
+ public void requestGrantForScale(String vnfmId, String vnfId, String vimId, String onapCsarId, VnfScaleRequest request, String jobId) {
+ try {
+ OperationType operationType = ScaleDirection.IN.equals(request.getType()) ? OperationType.SCALEIN : OperationType.SCALEOUT;
+ GrantVNFRequest grantRequest = buildGrantRequest(vnfmId, vimId, onapCsarId, jobId, operationType);
+ com.nokia.cbam.lcm.v32.model.VnfInfo vnf = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdGet(vnfId, NOKIA_LCM_API_VERSION);
+ String vnfdContent = catalogManager.getCbamVnfdContent(vnfmId, vnf.getVnfdId());
+ Set<ResourceChange> resourceChanges = calculateResourceChangeDuringScaling(vnfdContent, request.getAspectId(), Integer.parseInt(request.getNumberOfSteps()));
+ if (request.getType() == ScaleDirection.IN) {
+ grantRequest.getRemoveResource().addAll(resourceChanges);
+
+ } else {
+ grantRequest.getAddResource().addAll(resourceChanges);
+ }
+ grantRequest.setVnfInstanceId(vnfId);
+ requestGrant(grantRequest);
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to query VNF " + vnfId, e);
+ }
+ }
+
+ @Override
+ public void requestGrantForTerminate(String vnfmId, String vnfId, String vimId, String onapVnfdId, VnfInfo vnf, String jobId) {
+ if (vnf.getInstantiationState() == INSTANTIATED) {
+ GrantVNFRequest grantRequest;
+ try {
+ grantRequest = buildGrantRequest(vnfmId, vimId, onapVnfdId, jobId, TERMINAL);
+ grantRequest.setVnfInstanceId(vnfId);
+ addVnfcsToGrant(vnf, grantRequest);
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to prepare grant request for termination", e);
+ }
+ requestGrant(grantRequest);
+ }
+ }
+
+ private void addVnfcsToGrant(VnfInfo vnf, GrantVNFRequest grantRequest) {
+ //VNF is instantiated but has no VNFC
+ if (vnf.getInstantiatedVnfInfo().getVnfcResourceInfo() != null) {
+ for (VnfcResourceInfo vnfc : vnf.getInstantiatedVnfInfo().getVnfcResourceInfo()) {
+ ResourceChange resourceChange = new ResourceChange();
+ grantRequest.getRemoveResource().add(resourceChange);
+ resourceChange.setVdu(vnfc.getVduId());
+ resourceChange.setType(ChangeType.VDU);
+ resourceChange.setResourceDefinitionId(UUID.randomUUID().toString());
+ }
+ }
+ }
+
+ @Override
+ public GrantVNFResponseVim requestGrantForInstantiate(String vnfmId, String vnfId, String vimId, String onapVnfdId, String instantiationLevelId, String cbamVnfdContent, String jobId) {
+ GrantVNFRequest grantRequest;
+ try {
+ grantRequest = buildGrantRequest(vnfmId, vimId, onapVnfdId, jobId, OperationType.INSTANTIATE);
+ grantRequest.setVnfInstanceId(vnfId);
+ grantRequest.setAddResource(new ArrayList<>());
+ grantRequest.getAddResource().addAll(calculateResourceChangeDuringInstantiate(cbamVnfdContent, instantiationLevelId));
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to prepare grant request for instantiation", e);
+ }
+ return requestGrant(grantRequest);
+ }
+
+ private GrantVNFRequest buildGrantRequest(String vnfmId, String vimId, String onapCsarId, String jobId, OperationType operationType) {
+ GrantVNFRequest grantVNFRequest = new GrantVNFRequest();
+ //FIXME
+ //Currently the grant request sent to VF-C must contain the VIM identifier in the
+ //grant response (normally in ETSI VIM identifier is received in the grant response
+ //from ETSI orchestrator the vimId parameter should be removed from this POJO
+ //to be able to fix this https://jira.onap.org/browse/VFC-603 must be solved
+ //the vimId should be removed from the AdditionalGrantParams structure
+ grantVNFRequest.setAdditionalParam(new AdditionalGrantParams(vnfmId, vimId));
+ grantVNFRequest.setVnfDescriptorId(onapCsarId);
+ grantVNFRequest.setJobId(jobId);
+ grantVNFRequest.setLifecycleOperation(operationType);
+ grantVNFRequest.setAddResource(new ArrayList<>());
+ grantVNFRequest.setRemoveResource(new ArrayList<>());
+ return grantVNFRequest;
+ }
+
+ private GrantVNFResponseVim requestGrant(GrantVNFRequest grantRequest) {
+ try {
+ return vfcRestApiProvider.getNsLcmApi().grantvnf(grantRequest).getVim();
+ } catch (org.onap.vnfmdriver.ApiException e) {
+ throw buildFatalFailure(logger, "Unable to request grant", e);
+ }
+ }
+
+ private Set<ResourceChange> calculateResourceChangeDuringInstantiate(String vnfdContent, String instantiationLevelId) {
+ JsonObject root = new Gson().toJsonTree(new Yaml().load(vnfdContent)).getAsJsonObject();
+ JsonObject capabilities = child(child(child(root, "topology_template"), "substitution_mappings"), "capabilities");
+ JsonObject deploymentFlavorProperties = child(child(capabilities, "deployment_flavour"), "properties");
+ JsonObject instantiationLevels = child(deploymentFlavorProperties, "instantiation_levels");
+ Set<ResourceChange> resourceChanges = new HashSet<>();
+ for (Map.Entry<String, JsonElement> vdu_level : child(child(instantiationLevels, instantiationLevelId), ("vdu_levels")).entrySet()) {
+ JsonElement numberOfInstances = vdu_level.getValue().getAsJsonObject().get("number_of_instances");
+ for (int i = 0; i < numberOfInstances.getAsLong(); i++) {
+ ResourceChange resourceChange = new ResourceChange();
+ resourceChanges.add(resourceChange);
+ resourceChange.setVdu(vdu_level.getKey());
+ resourceChange.setType(ChangeType.VDU);
+ resourceChange.setResourceDefinitionId(UUID.randomUUID().toString());
+ }
+ }
+ return resourceChanges;
+ }
+
+ private Set<ResourceChange> calculateResourceChangeDuringScaling(String vnfdContent, String aspectId, int steps) {
+ JsonObject root = new Gson().toJsonTree(new Yaml().load(vnfdContent)).getAsJsonObject();
+ Set<ResourceChange> resourceChanges = new HashSet<>();
+ JsonArray policies = child(root, "topology_template").getAsJsonObject().get("policies").getAsJsonArray();
+ for (JsonElement policy : policies) {
+ if ("heat_mapping".equals(policy.getAsJsonObject().entrySet().iterator().next().getKey())) {
+ JsonObject aspects = policy.getAsJsonObject().entrySet().iterator().next().getValue().getAsJsonObject().get("properties").getAsJsonObject().get("aspects").getAsJsonObject();
+ JsonObject aspect = child(aspects, aspectId);
+ if (aspect.has("vdus")) {
+ addChangesForAspect(steps, resourceChanges, aspect);
+ }
+ }
+ }
+ return resourceChanges;
+ }
+
+ private void addChangesForAspect(int steps, Set<ResourceChange> resourceChanges, JsonObject aspect) {
+ for (Map.Entry<String, JsonElement> vdu : aspect.get("vdus").getAsJsonObject().entrySet()) {
+ String vduId = vdu.getKey();
+ for (int step = 0; step < steps; step++) {
+ for (int i = 0; i < vdu.getValue().getAsJsonArray().size(); i++) {
+ ResourceChange resourceChange = new ResourceChange();
+ resourceChange.setVdu(vduId);
+ resourceChange.setType(ChangeType.VDU);
+ resourceChange.setResourceDefinitionId(UUID.randomUUID().toString());
+ resourceChanges.add(resourceChange);
+ }
+ }
+ }
+ }
+
+ /**
+ * Represents the mandatory parameters that must be sent during grant request to VF-C
+ */
+ @VisibleForTesting
+ static class AdditionalGrantParams {
+ private final String vnfmId;
+ private final String vimId;
+
+ AdditionalGrantParams(String vnfmId, String vimId) {
+ this.vnfmId = vnfmId;
+ this.vimId = vimId;
+ }
+
+ /**
+ * @return the identifier of the VNFM requesting the grant
+ */
+ public String getVnfmId() {
+ return vnfmId;
+ }
+
+ /**
+ * @return the identifier of the VIM for which the grant is requested
+ */
+ public String getVimId() {
+ return vimId;
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcNotificationSender.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcNotificationSender.java
new file mode 100644
index 00000000..50f6221b
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcNotificationSender.java
@@ -0,0 +1,217 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import com.google.gson.Gson;
+import com.nokia.cbam.lcm.v32.model.OperationExecution;
+import com.nokia.cbam.lcm.v32.model.ScaleVnfRequest;
+import com.nokia.cbam.lcm.v32.model.VnfLifecycleChangeNotification;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.INotificationSender;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.LifecycleChangeNotificationManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedConnectionPoints;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedCp;
+import org.onap.vnfmdriver.model.*;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import java.util.ArrayList;
+import java.util.Optional;
+
+import static com.google.common.collect.Iterables.tryFind;
+import static com.nokia.cbam.lcm.v32.model.ScaleDirection.IN;
+import static java.util.Optional.of;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.SEPARATOR;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.JobManager.extractOnapJobId;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for sending notifications to VF-C
+ */
+@Component
+@Conditional(value = Conditions.UseForVfc.class)
+public class VfcNotificationSender implements INotificationSender {
+ private static Logger logger = getLogger(VfcNotificationSender.class);
+ private final DriverProperties driverProperties;
+ private final VfcRestApiProvider vfcRestApiProvider;
+
+ @Autowired
+ VfcNotificationSender(DriverProperties driverProperties, VfcRestApiProvider vfcRestApiProvider) {
+ this.driverProperties = driverProperties;
+ this.vfcRestApiProvider = vfcRestApiProvider;
+ }
+
+ @Override
+ public void processNotification(VnfLifecycleChangeNotification recievedNotification, OperationExecution operationExecution, Optional<ReportedAffectedConnectionPoints> affectedCps, String vimId) {
+ VNFLCMNotification notificationToSend = new VNFLCMNotification();
+ notificationToSend.setJobId(extractOnapJobId(operationExecution.getOperationParams()));
+ notificationToSend.setOperation(getOperation(operationExecution, recievedNotification.getOperation()));
+ notificationToSend.setVnfInstanceId(recievedNotification.getVnfInstanceId());
+ if (LifecycleChangeNotificationManager.isTerminal(recievedNotification.getStatus())) {
+ notificationToSend.setStatus(VnfLcmNotificationStatus.RESULT);
+ addAffectedVirtualLinks(recievedNotification, notificationToSend);
+ addAffectedVnfcs(vimId, recievedNotification.getVnfInstanceId(), notificationToSend, recievedNotification);
+ addAffectedCps(vimId, notificationToSend, affectedCps);
+ } else {
+ notificationToSend.setStatus(VnfLcmNotificationStatus.START);
+ }
+ sendNotification(notificationToSend);
+ }
+
+ private void sendNotification(VNFLCMNotification notification) {
+ try {
+ if (logger.isInfoEnabled()) {
+ logger.info("Sending LCN: {}", new Gson().toJson(notification));
+ }
+ vfcRestApiProvider.getNsLcmApi().vNFLCMNotification(driverProperties.getVnfmId(), notification.getVnfInstanceId(), notification);
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to send LCN to VF-C", e);
+ }
+ }
+
+ private AffectedCp buildAffectedCp(String vimId, String vnfId, VnfCpNotificationType changeType, ReportedAffectedCp affectedCp) {
+ AffectedCp onapAffectedCp = new AffectedCp();
+ AffectedCpPortResource port = new AffectedCpPortResource();
+ port.setInstId(affectedCp.getServerProviderId());
+ port.setIpAddress(affectedCp.getIpAddress());
+ port.setMacAddress(affectedCp.getMacAddress());
+ port.setResourceid(affectedCp.getProviderId());
+ port.setResourceName(affectedCp.getName());
+ port.setTenant(affectedCp.getTenantId());
+ port.setVimid(vimId);
+ onapAffectedCp.setPortResource(port);
+ onapAffectedCp.setCpdid(affectedCp.getCpId());
+ onapAffectedCp.setCpinstanceid(vnfId + SEPARATOR + affectedCp.getCpId());
+ onapAffectedCp.setVirtualLinkInstanceId(affectedCp.getNetworkProviderId());
+ onapAffectedCp.setChangeType(changeType);
+ //owner id & type can be left empty it will default to VNF id on VF-C
+ return onapAffectedCp;
+ }
+
+
+ private void addAffectedVnfcs(String vimId, String vnfId, VNFLCMNotification notificationToSend, VnfLifecycleChangeNotification request) {
+ if (request.getAffectedVnfcs() != null) {
+ notificationToSend.setAffectedVnfc(new ArrayList<>());
+ for (com.nokia.cbam.lcm.v32.model.AffectedVnfc affectedVnfc : request.getAffectedVnfcs()) {
+ org.onap.vnfmdriver.model.AffectedVnfc onapVnfc = new org.onap.vnfmdriver.model.AffectedVnfc();
+ onapVnfc.setChangeType(getChangeType(affectedVnfc.getChangeType()));
+ onapVnfc.setVduId(affectedVnfc.getVduId());
+ onapVnfc.setVmid(affectedVnfc.getComputeResource().getResourceId());
+ onapVnfc.setVmname(extractServerName(affectedVnfc.getComputeResource().getAdditionalData()));
+ onapVnfc.setVnfcInstanceId(vnfId + SEPARATOR + affectedVnfc.getId());
+ onapVnfc.setVimid(vimId);
+ notificationToSend.getAffectedVnfc().add(onapVnfc);
+ }
+ }
+ }
+
+ private void addAffectedVirtualLinks(VnfLifecycleChangeNotification request, VNFLCMNotification notification) {
+ if (request.getAffectedVirtualLinks() != null) {
+ notification.setAffectedVl(new ArrayList<>());
+ for (com.nokia.cbam.lcm.v32.model.AffectedVirtualLink affectedVirtualLink : request.getAffectedVirtualLinks()) {
+ org.onap.vnfmdriver.model.AffectedVirtualLink onapVirtualLink = new org.onap.vnfmdriver.model.AffectedVirtualLink();
+ onapVirtualLink.setVlInstanceId(request.getVnfInstanceId() + SEPARATOR + affectedVirtualLink.getId());
+ onapVirtualLink.setChangeType(getChangeType(affectedVirtualLink.getChangeType()));
+ onapVirtualLink.setVldid(affectedVirtualLink.getVirtualLinkDescId());
+ AffectedVirtualLinkNetworkResource networkResource = new AffectedVirtualLinkNetworkResource();
+ onapVirtualLink.setNetworkResource(networkResource);
+ networkResource.setResourceId(affectedVirtualLink.getResource().getResourceId());
+ networkResource.setResourceType(AffectedVirtualLinkType.NETWORK);
+ notification.getAffectedVl().add(onapVirtualLink);
+ }
+ }
+ }
+
+ private Optional<VnfCpNotificationType> getChangeType(ReportedAffectedConnectionPoints affectedCps, ReportedAffectedCp affectedCp) {
+ com.google.common.base.Optional<ReportedAffectedCp> cpBeforeOperation = tryFind(affectedCps.getPre(), pre -> affectedCp.getCpId().equals(pre.getCpId()));
+ com.google.common.base.Optional<ReportedAffectedCp> cpAfterOperation = tryFind(affectedCps.getPost(), post -> affectedCp.getCpId().equals(post.getCpId()));
+ if (cpBeforeOperation.isPresent() && cpAfterOperation.isPresent()) {
+ return cpAfterOperation.get().equals(cpBeforeOperation.get()) ? Optional.empty() : of(VnfCpNotificationType.CHANGED);
+ } else {
+ //the affected CP must be present in the pre or post
+ return of((cpAfterOperation.isPresent() ? VnfCpNotificationType.ADDED : VnfCpNotificationType.REMOVED));
+ }
+ }
+
+ private void addAffectedCps(String vimId, VNFLCMNotification notificationToSend, Optional<ReportedAffectedConnectionPoints> affectedCps) {
+ if (affectedCps.isPresent()) {
+ notificationToSend.setAffectedCp(new ArrayList<>());
+ for (ReportedAffectedCp pre : affectedCps.get().getPre()) {
+ Optional<VnfCpNotificationType> changeType = getChangeType(affectedCps.get(), pre);
+ if (of(VnfCpNotificationType.REMOVED).equals(changeType)) {
+ addModifiedCp(vimId, notificationToSend, pre, changeType);
+ }
+ }
+ for (ReportedAffectedCp post : affectedCps.get().getPost()) {
+ Optional<VnfCpNotificationType> changeType = getChangeType(affectedCps.get(), post);
+ if (of(VnfCpNotificationType.ADDED).equals(changeType)) {
+ addModifiedCp(vimId, notificationToSend, post, changeType);
+ }
+ if (of(VnfCpNotificationType.CHANGED).equals(changeType)) {
+ addModifiedCp(vimId, notificationToSend, post, changeType);
+ }
+ }
+ }
+ }
+
+ private void addModifiedCp(String vimId, VNFLCMNotification notificationToSend, ReportedAffectedCp post, Optional<VnfCpNotificationType> changeType) {
+ if (post.getCpdId() != null) {
+ AffectedCp onapAffectedCp = buildAffectedCp(vimId, notificationToSend.getVnfInstanceId(), changeType.get(), post);
+ onapAffectedCp.setCpdid(post.getCpdId());
+ notificationToSend.getAffectedCp().add(onapAffectedCp);
+ }
+ if (post.getEcpdId() != null) {
+ AffectedCp onapAffectedCp = buildAffectedCp(vimId, notificationToSend.getVnfInstanceId(), changeType.get(), post);
+ onapAffectedCp.setCpdid(post.getEcpdId());
+ notificationToSend.getAffectedCp().add(onapAffectedCp);
+ }
+ }
+
+ private org.onap.vnfmdriver.model.OperationType getOperation(OperationExecution operationExecution, com.nokia.cbam.lcm.v32.model.OperationType type) {
+ if (type == com.nokia.cbam.lcm.v32.model.OperationType.TERMINATE) {
+ return OperationType.TERMINAL;
+ } else if (type == com.nokia.cbam.lcm.v32.model.OperationType.INSTANTIATE) {
+ return OperationType.INSTANTIATE;
+ } else if (type == com.nokia.cbam.lcm.v32.model.OperationType.SCALE) {
+ if (IN == new Gson().fromJson(new Gson().toJson(operationExecution.getOperationParams()), ScaleVnfRequest.class).getType()) {
+ return OperationType.SCALEIN;
+ } else {
+ return OperationType.SCALEOUT;
+ }
+ } else {
+ return OperationType.HEAL;
+ }
+ }
+
+ private String extractServerName(Object additionalData) {
+ return new Gson().toJsonTree(additionalData).getAsJsonObject().get("name").getAsString();
+ }
+
+ private org.onap.vnfmdriver.model.VnfNotificationType getChangeType(com.nokia.cbam.lcm.v32.model.ChangeType changeType) {
+ if (changeType == com.nokia.cbam.lcm.v32.model.ChangeType.ADDED) {
+ return VnfNotificationType.ADDED;
+ } else if (changeType == com.nokia.cbam.lcm.v32.model.ChangeType.REMOVED) {
+ return VnfNotificationType.REMOVED;
+ } else {
+ return VnfNotificationType.MODIFIED;
+ }
+ }
+
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcPackageProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcPackageProvider.java
new file mode 100644
index 00000000..71880d0b
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcPackageProvider.java
@@ -0,0 +1,103 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import com.google.common.io.ByteStreams;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonParser;
+import org.apache.http.HttpEntity;
+import org.apache.http.HttpHeaders;
+import org.apache.http.client.methods.CloseableHttpResponse;
+import org.apache.http.client.methods.HttpGet;
+import org.apache.http.impl.client.CloseableHttpClient;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.IPackageProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.IpMappingProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfccatalog.api.VnfpackageApi;
+import org.onap.vfccatalog.model.VnfPkgDetailInfo;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.net.URL;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.http.MediaType.APPLICATION_OCTET_STREAM_VALUE;
+
+/**
+ * Retrieves a package from VF-C
+ */
+@Component
+@Conditional(value = Conditions.UseForVfc.class)
+public class VfcPackageProvider implements IPackageProvider {
+ private static Logger logger = getLogger(VfcPackageProvider.class);
+ private final VfcRestApiProvider restApiProvider;
+ private final IpMappingProvider ipMappingProvider;
+
+ @Autowired
+ VfcPackageProvider(VfcRestApiProvider restApiProvider, IpMappingProvider ipMappingProvider) {
+ this.restApiProvider = restApiProvider;
+ this.ipMappingProvider = ipMappingProvider;
+ }
+
+ @Override
+ public String getCbamVnfdId(String csarId) {
+ try {
+ VnfpackageApi onapCatalogApi = restApiProvider.getOnapCatalogApi();
+ VnfPkgDetailInfo vnfPackageDetails = onapCatalogApi.queryVnfPackage(csarId);
+ JsonElement vnfdModel = new JsonParser().parse(vnfPackageDetails.getPackageInfo().getVnfdModel());
+ return vnfdModel.getAsJsonObject().get("metadata").getAsJsonObject().get("resourceVendorModelNumber").getAsString();
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to query VNF package with " + csarId, e);
+ }
+ }
+
+ @Override
+ public byte[] getPackage(String csarId) {
+ String downloadUrl;
+ try {
+ VnfpackageApi onapCatalogApi = restApiProvider.getOnapCatalogApi();
+ VnfPkgDetailInfo vnfPackageDetails = onapCatalogApi.queryVnfPackage(csarId);
+ String urlFromVfc = vnfPackageDetails.getPackageInfo().getDownloadUrl();
+ String host = new URL(urlFromVfc).getHost();
+ downloadUrl = urlFromVfc.replaceFirst("://" + host, "://" + ipMappingProvider.mapPrivateIpToPublicIp(host));
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to query VNF package with " + csarId, e);
+ }
+ try {
+ return downloadCbamVnfPackage(downloadUrl);
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to download package from " + downloadUrl, e);
+ }
+ }
+
+ private byte[] downloadCbamVnfPackage(String downloadUri) throws IOException {
+ CloseableHttpClient client = systemFunctions().getHttpClient();
+ HttpGet httpget = new HttpGet(downloadUri);
+ httpget.setHeader(HttpHeaders.ACCEPT, APPLICATION_OCTET_STREAM_VALUE);
+ CloseableHttpResponse response = client.execute(httpget);
+ HttpEntity entity = response.getEntity();
+ InputStream is = entity.getContent();
+ byte[] bytes = ByteStreams.toByteArray(is);
+ client.close();
+ return bytes;
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcRestApiProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcRestApiProvider.java
new file mode 100644
index 00000000..baa61f75
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/VfcRestApiProvider.java
@@ -0,0 +1,76 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.MsbApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.Conditions;
+import org.onap.vfccatalog.api.VnfpackageApi;
+import org.onap.vnfmdriver.api.NslcmApi;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.stereotype.Component;
+
+/**
+ * Responsible for providing access to VF-C REST APIs
+ */
+@Component
+@Conditional(value = Conditions.UseForVfc.class)
+public class VfcRestApiProvider {
+ static final String NSLCM_API_SERVICE_NAME = "nslcm";
+ static final String NSLCM_API_VERION = "v1";
+ static final String NSCATALOG_SERVICE_NAME = "catalog";
+ static final String NSCATALOG_API_VERSION = "v1";
+ private final MsbApiProvider msbApiProvider;
+
+ @Autowired
+ VfcRestApiProvider(MsbApiProvider msbApiProvider) {
+ this.msbApiProvider = msbApiProvider;
+ }
+
+ /**
+ * @return API to access VF-C for granting & LCN API
+ */
+ public NslcmApi getNsLcmApi() {
+ org.onap.vnfmdriver.ApiClient apiClient = new org.onap.vnfmdriver.ApiClient();
+ String correctedUrl = fixIncorrectUrl();
+ apiClient.setBasePath(correctedUrl);
+ return new NslcmApi(apiClient);
+ }
+
+ /**
+ * @return API to access VF-C catalog API
+ */
+ public VnfpackageApi getOnapCatalogApi() {
+ org.onap.vfccatalog.ApiClient vfcApiClient = new org.onap.vfccatalog.ApiClient();
+ vfcApiClient.setBasePath(msbApiProvider.getMicroServiceUrl(NSCATALOG_SERVICE_NAME, NSCATALOG_API_VERSION));
+ return new VnfpackageApi(vfcApiClient);
+ }
+
+ /**
+ * The swagger schema definition is not consistent with MSB info. The MSB reports
+ * the base path /restapi/nsclm/v1 (correct) and the paths defined in swagger is
+ * /nsclm/v1 making all API calls /restapi/nsclm/v1/nsclm/v1 (incorrect)
+ *
+ * @return
+ */
+ private String fixIncorrectUrl() {
+ String urlInMsb = msbApiProvider.getMicroServiceUrl(NSLCM_API_SERVICE_NAME, NSLCM_API_VERION);
+ //FIXME VF-C exposes multiple APIs in the single swagger definition, since the base path of different
+ //API is different the some API calls are incorrectly prefixed
+ //VF-C team refuses to fix this in Amsterdam https://jira.onap.org/browse/VFC-597?filter=-2
+ return urlInMsb.replaceFirst("/nslcm/v1", "");
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfPackageBuilder.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfPackageBuilder.java
new file mode 100644
index 00000000..5f9f6341
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfPackageBuilder.java
@@ -0,0 +1,72 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import com.google.common.io.ByteStreams;
+
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipInputStream;
+import java.util.zip.ZipOutputStream;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+
+/**
+ * Builds a CBAM VNF package capable to be deployed on ONAP from a CBAM package
+ */
+public class CbamVnfPackageBuilder {
+
+ /**
+ * @param originalCbamVnfPackage the original CBAM VNF package
+ * @param vnfdLocation the location of the VNFD within the CBAM VNF package
+ * @param modifiedCbamVnfdContent the modified CBAM VNFD content
+ * @return the mod
+ */
+ public byte[] toModifiedCbamVnfPackage(byte[] originalCbamVnfPackage, String vnfdLocation, String modifiedCbamVnfdContent) throws IOException {
+ ZipInputStream zipInputStream = new ZipInputStream(new ByteArrayInputStream(originalCbamVnfPackage));
+ ByteArrayOutputStream result = new ByteArrayOutputStream();
+ ZipOutputStream out = new ZipOutputStream(result);
+ ZipEntry zipEntry;
+ while ((zipEntry = zipInputStream.getNextEntry()) != null) {
+ if (zipEntry.getName().matches(vnfdLocation)) {
+ out.putNextEntry(new ZipEntry(vnfdLocation));
+ out.write(modifiedCbamVnfdContent.getBytes());
+ out.closeEntry();
+ } else {
+ out.putNextEntry(new ZipEntry(zipEntry.getName()));
+ ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
+ ByteStreams.copy(zipInputStream, byteArrayOutputStream);
+ out.write(byteArrayOutputStream.toByteArray());
+ out.closeEntry();
+ }
+ }
+ out.putNextEntry(new ZipEntry("javascript/cbam.pre.collectConnectionPoints.js"));
+ out.write(systemFunctions().loadFile("cbam.pre.collectConnectionPoints.js"));
+ out.closeEntry();
+ out.putNextEntry(new ZipEntry("javascript/cbam.collectConnectionPoints.js"));
+ out.write(systemFunctions().loadFile("cbam.collectConnectionPoints.js"));
+ out.closeEntry();
+ out.putNextEntry(new ZipEntry("javascript/cbam.post.collectConnectionPoints.js"));
+ out.write(systemFunctions().loadFile("cbam.post.collectConnectionPoints.js"));
+ out.closeEntry();
+ out.close();
+ zipInputStream.close();
+ return result.toByteArray();
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfdBuilder.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfdBuilder.java
new file mode 100644
index 00000000..83b93518
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/CbamVnfdBuilder.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import com.fasterxml.jackson.databind.JsonNode;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.fasterxml.jackson.dataformat.yaml.YAMLMapper;
+import com.google.gson.*;
+import org.yaml.snakeyaml.Yaml;
+
+import java.io.IOException;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.child;
+
+/**
+ * Modifies a CBAM VNFD to fit ONAP
+ */
+public class CbamVnfdBuilder {
+
+ /**
+ * @param cbamVnfdContent the original CBAM VNFD
+ * @return the modified content CBAM VNFD
+ */
+ public String build(String cbamVnfdContent) throws IOException {
+ JsonObject root = new Gson().toJsonTree(new Yaml().load(cbamVnfdContent)).getAsJsonObject();
+ JsonObject substitutionMappings = child(child(root, "topology_template"), "substitution_mappings");
+ JsonObject extensions = addChild(addChild(addChild(addChild(addChild(substitutionMappings, "capabilities"), "vnf"), "properties"), "modifiable_attributes"), "extensions");
+ JsonObject onapCsarId = addChild(extensions, "onapCsarId");
+ onapCsarId.add("default", new JsonPrimitive("kuku"));
+ JsonObject vimId = addChild(extensions, "vimId");
+ vimId.add("default", new JsonPrimitive("kuku"));
+ JsonObject interfaces = child(substitutionMappings, "interfaces");
+ JsonObject basic = addChild(interfaces, "Basic");
+ addOperationParams(addChild(basic, "instantiate"));
+ addOperationParams(addChild(basic, "terminate"));
+ if (interfaces.has("Scalable")) {
+ addOperationParams(addChild(child(interfaces, "Scalable"), "scale"));
+ }
+ if (interfaces.has("Healable")) {
+ addOperationParams(addChild(child(interfaces, "Healable"), "heal"));
+ }
+ JsonNode jsonNodeTree = new ObjectMapper().readTree(new GsonBuilder().setPrettyPrinting().create().toJson(root));
+ return new YAMLMapper().writeValueAsString(jsonNodeTree);
+ }
+
+ private void addOperationParams(JsonObject operation) {
+ JsonObject inputs = addChild(operation, "inputs");
+ JsonObject extensions = addChild(inputs, "extensions");
+ JsonArray preActions = addChildArray(extensions, "pre_actions");
+ preActions.add(addAction("javascript/cbam.pre.collectConnectionPoints.js"));
+ JsonArray postActions = addChildArray(extensions, "post_actions");
+ postActions.add(addAction("javascript/cbam.post.collectConnectionPoints.js"));
+ JsonObject additionalParameters = addChild(inputs, "additional_parameters");
+ additionalParameters.addProperty("jobId", "kuku");
+ }
+
+ private JsonElement addAction(String jsAction) {
+ JsonObject action = new JsonObject();
+ action.addProperty("javascript", jsAction);
+ JsonArray myInclude = new JsonArray();
+ myInclude.add("javascript/cbam.collectConnectionPoints.js");
+ action.add("include", myInclude);
+ action.addProperty("output", "operation_result");
+ return action;
+ }
+
+ private JsonArray addChildArray(JsonObject root, String name) {
+ if (root.has(name)) {
+ return root.get(name).getAsJsonArray();
+ } else {
+ JsonArray child = new JsonArray();
+ root.add(name, child);
+ return child;
+ }
+ }
+
+ private JsonObject addChild(JsonObject root, String name) {
+ if (root.has(name)) {
+ return root.get(name).getAsJsonObject();
+ } else {
+ JsonObject child = new JsonObject();
+ root.add(name, child);
+ return child;
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfPackageBuilder.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfPackageBuilder.java
new file mode 100644
index 00000000..9fe4a298
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfPackageBuilder.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import com.google.common.io.ByteStreams;
+
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.nio.charset.StandardCharsets;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipOutputStream;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getFileInZip;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getVnfdLocation;
+
+/**
+ * Transforms a CBAM package into an ONAP package
+ */
+
+public class OnapVnfPackageBuilder {
+
+ /**
+ * Entry point for the command line package transformer
+ *
+ * @param args not used (required due to signature)
+ */
+ public static void main(String[] args) throws Exception {
+ byte[] covert = new OnapVnfPackageBuilder().covert(systemFunctions().in());
+ systemFunctions().out().write(covert);
+ }
+
+ /**
+ * @param zip the original CBAM package
+ * @return the converted ONAP package
+ */
+ public byte[] covert(InputStream zip) throws IOException {
+ byte[] cbamVnfPackage = ByteStreams.toByteArray(zip);
+ String vnfdLocation = getVnfdLocation(new ByteArrayInputStream(cbamVnfPackage));
+ ByteArrayOutputStream vnfdContent = getFileInZip(new ByteArrayInputStream(cbamVnfPackage), vnfdLocation);
+ byte[] cbamVnfdContent = vnfdContent.toByteArray();
+ String onapVnfd = new OnapVnfdBuilder().toOnapVnfd(new String(cbamVnfdContent, StandardCharsets.UTF_8));
+ byte[] modifiedCbamPackage = new CbamVnfPackageBuilder().toModifiedCbamVnfPackage(cbamVnfPackage, vnfdLocation, new CbamVnfdBuilder().build(new String(cbamVnfdContent)));
+ return buildNewOnapPackage(modifiedCbamPackage, onapVnfd);
+ }
+
+ private byte[] buildNewOnapPackage(byte[] modifiedCbamPackage, String onapVnfd) throws IOException {
+ ByteArrayOutputStream result = new ByteArrayOutputStream();
+ ZipOutputStream out = new ZipOutputStream(result);
+ out.putNextEntry(new ZipEntry("Artifacts/Deployment/OTHER/cbam.package.zip"));
+ out.write(modifiedCbamPackage);
+ out.closeEntry();
+ out.putNextEntry(new ZipEntry("TOSCA-Metadata/TOSCA.meta"));
+ out.write(systemFunctions().loadFile("TOSCA.meta"));
+ out.closeEntry();
+ out.putNextEntry(new ZipEntry("MainServiceTemplate.yaml"));
+ out.write(onapVnfd.getBytes());
+ out.closeEntry();
+ out.putNextEntry(new ZipEntry("Definitions/MainServiceTemplate.yaml"));
+ out.write(onapVnfd.getBytes());
+ out.closeEntry();
+ out.putNextEntry(new ZipEntry("MainServiceTemplate.meta"));
+ out.write(systemFunctions().loadFile("MainServiceTemplate.meta"));
+ out.closeEntry();
+ out.close();
+ return result.toByteArray();
+ }
+
+
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfdBuilder.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfdBuilder.java
new file mode 100644
index 00000000..8d658310
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/OnapVnfdBuilder.java
@@ -0,0 +1,279 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import com.google.common.annotations.VisibleForTesting;
+import com.google.gson.Gson;
+import com.google.gson.JsonArray;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonObject;
+import org.slf4j.Logger;
+import org.yaml.snakeyaml.Yaml;
+
+import java.util.Map;
+import java.util.NoSuchElementException;
+import java.util.Set;
+import java.util.regex.Pattern;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.child;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.childElement;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Transforms a CBAM package into an ONAP package
+ */
+public class OnapVnfdBuilder {
+ public static final String DESCRIPTION = "description";
+ public static final String PROPERTIES = "properties";
+ public static final String REQUIREMENTS = "requirements";
+ private static Logger logger = getLogger(OnapVnfdBuilder.class);
+
+ @VisibleForTesting
+ static String indent(String content, int prefixSize) {
+ StringBuilder sb = new StringBuilder();
+ for (int i = 0; i < prefixSize; i++) {
+ sb.append(" ");
+ }
+ Pattern pattern = Pattern.compile("^(.*)$", Pattern.MULTILINE);
+ return pattern.matcher(content).replaceAll(sb.toString() + "$1");
+ }
+
+ /**
+ * @param cbamVnfd the CBAM VNFD
+ * @return the converted ONAP VNFD
+ */
+ public String toOnapVnfd(String cbamVnfd) {
+ JsonObject root = new Gson().toJsonTree(new Yaml().load(cbamVnfd)).getAsJsonObject();
+ JsonObject topologyTemplate = child(root, "topology_template");
+ if (topologyTemplate.has("node_templates")) {
+ Set<Map.Entry<String, JsonElement>> nodeTemplates = child(topologyTemplate, "node_templates").entrySet();
+ StringBuilder body = new StringBuilder();
+ for (Map.Entry<String, JsonElement> node : nodeTemplates) {
+ String type = childElement(node.getValue().getAsJsonObject(), "type").getAsString();
+ switch (type) {
+ case "tosca.nodes.nfv.VDU":
+ body.append(buildVdu(node.getKey(), node.getValue().getAsJsonObject(), nodeTemplates));
+ break;
+ case "tosca.nodes.nfv.VirtualStorage":
+ body.append(buildVolume(node.getKey(), node.getValue().getAsJsonObject()));
+ break;
+ case "tosca.nodes.nfv.VL":
+ body.append(buildVl(node.getKey()));
+ break;
+ case "tosca.nodes.nfv.ICP":
+ body.append(buildIcp(node.getKey(), node.getValue().getAsJsonObject()));
+ break;
+ case "tosca.nodes.nfv.ECP":
+ body.append(buildEcp(node.getKey(), node.getValue(), nodeTemplates));
+ break;
+ default:
+ logger.warn("The {} type is not converted", type);
+ }
+ }
+ return buildHeader(topologyTemplate) + body.toString();
+ }
+ return buildHeader(topologyTemplate);
+ }
+
+ private String buildHeader(JsonObject toplogyTemplate) {
+ JsonObject properties = child(child(toplogyTemplate, "substitution_mappings"), PROPERTIES);
+ String descriptorVersion = properties.get("descriptor_version").getAsString();
+ return "tosca_definitions_version: tosca_simple_yaml_1_0\n" +
+ "\n" +
+ "metadata:\n" +
+ " vendor: Nokia\n" +
+ " csarVersion: " + descriptorVersion + "\n" +
+ " csarProvider: " + properties.get("provider").getAsString() + "\n" +
+ " id: Simple\n" +
+ " version: " + properties.get("software_version").getAsString() + "\n" +
+ " csarType: NFAR\n" +
+ " name: " + properties.get("product_name").getAsString() + "\n" +
+ " vnfdVersion: " + descriptorVersion + "\n\n" +
+ "topology_template:\n" +
+ " node_templates:\n";
+ }
+
+ private JsonElement get(String name, Set<Map.Entry<String, JsonElement>> nodes) {
+ for (Map.Entry<String, JsonElement> node : nodes) {
+ if (name.equals(node.getKey())) {
+ return node.getValue();
+ }
+ }
+ throw new NoSuchElementException("The VNFD does not have a node called " + name + " but required by an other node");
+ }
+
+ private String buildVdu(String name, JsonObject vdu, Set<Map.Entry<String, JsonElement>> nodes) {
+ String memorySize = "";
+ String cpuCount = "";
+ StringBuilder body = new StringBuilder();
+ JsonArray vduRequirements = childElement(vdu.getAsJsonObject(), REQUIREMENTS).getAsJsonArray();
+ for (int i = 0; i < vduRequirements.size(); i++) {
+ JsonObject requirement = vduRequirements.get(i).getAsJsonObject();
+ Map.Entry<String, JsonElement> next = requirement.entrySet().iterator().next();
+ String s = next.getKey();
+ if ("virtual_compute".equals(s)) {
+ JsonObject virtualCompute = get(next.getValue().getAsString(), nodes).getAsJsonObject();
+ cpuCount = childElement(child(child(virtualCompute, PROPERTIES), "virtual_cpu"), "num_virtual_cpu").getAsString();
+ memorySize = childElement(child(child(virtualCompute, PROPERTIES), "virtual_memory"), "virtual_mem_size").getAsString();
+
+ } else if ("virtual_storage".equals(s)) {
+ String item = indent(
+ "- virtual_storage:\n" +
+ " capability: tosca.capabilities.nfv.VirtualStorage\n" +
+ " node: " + next.getValue().getAsString() + "\n", 4);
+ body.append(item);
+
+ }
+ next.getValue();
+ }
+ String header = indent(name + ":\n" +
+ " type: tosca.nodes.nfv.VDU.Compute\n" +
+ " capabilities:\n" +
+ " virtual_compute:\n" +
+ indent(
+ "properties:\n" +
+ " virtual_memory:\n" +
+ " virtual_mem_size: " + memorySize + "\n" +
+ " virtual_cpu:\n" +
+ " num_virtual_cpu: " + cpuCount + "\n", 3) +
+ " " + REQUIREMENTS + ":\n", 2);
+ return header + body.toString();
+ }
+
+ private String buildEcp(String name, JsonElement ecp, Set<Map.Entry<String, JsonElement>> nodes) {
+ if (ecp.getAsJsonObject().has(REQUIREMENTS)) {
+ String icpName = getIcpName(ecp.getAsJsonObject().get(REQUIREMENTS).getAsJsonArray());
+ if (icpName != null) {
+ return buildEcpInternal(name, icpName, nodes);
+ } else {
+ logger.warn("The {} ecp does not have an internal connection point", name);
+ }
+ } else {
+ logger.warn("The {} ecp does not have an requirements section", name);
+ }
+ return "";
+ }
+
+ private String buildEcpInternal(String ecpName, String icpName, Set<Map.Entry<String, JsonElement>> nodes) {
+ JsonObject icpNode = get(icpName, nodes).getAsJsonObject();
+ if (icpNode.has(REQUIREMENTS)) {
+ String vdu = getVduOfIcp(icpNode.getAsJsonObject().get(REQUIREMENTS).getAsJsonArray());
+ //internal connection point is bound to VDU
+ if (vdu != null) {
+ return buildVduCpd(ecpName, vdu, child(icpNode, PROPERTIES));
+ } else {
+ logger.warn("The {} internal connection point of the {} ecp does not have a VDU", icpName, ecpName);
+ }
+ } else {
+ logger.warn("The {} internal connection point of the {} ecp does not have a requirements section", icpName, ecpName);
+ }
+ return "";
+ }
+
+ private String getVduOfIcp(JsonArray icpRequirements) {
+ String vdu = null;
+ for (int i = 0; i < icpRequirements.size(); i++) {
+ JsonElement requirement = icpRequirements.get(i);
+ Map.Entry<String, JsonElement> next = requirement.getAsJsonObject().entrySet().iterator().next();
+ String s = next.getKey();
+ if ("virtual_binding".equals(s)) {
+ vdu = next.getValue().getAsString();
+ }
+ }
+ return vdu;
+ }
+
+ private String getIcpName(JsonArray requirements) {
+ String icpName = null;
+ for (int i = 0; i < requirements.size(); i++) {
+ JsonElement requirement = requirements.get(i);
+ Map.Entry<String, JsonElement> next = requirement.getAsJsonObject().entrySet().iterator().next();
+ String s = next.getKey();
+ if ("internal_connection_point".equals(s)) {
+ icpName = next.getValue().getAsString();
+ }
+ }
+ return icpName;
+ }
+
+ private String buildIcp(String name, JsonObject icp) {
+ if (icp.has(REQUIREMENTS)) {
+ JsonArray requirements = icp.get(REQUIREMENTS).getAsJsonArray();
+ String vdu = null;
+ String vl = null;
+ for (int i = 0; i < requirements.size(); i++) {
+ JsonElement requirement = requirements.get(i);
+ Map.Entry<String, JsonElement> next = requirement.getAsJsonObject().entrySet().iterator().next();
+ String s = next.getKey();
+ if ("virtual_binding".equals(s)) {
+ vdu = next.getValue().getAsString();
+ } else if ("virtual_link".equals(s)) {
+ vl = next.getValue().getAsString();
+ }
+ }
+ if (vdu == null) {
+ logger.warn("The {} internal connection point does not have a VDU", name);
+ } else if (vl == null) {
+ logger.warn("The {} internal connection point does not have a VL", name);
+ } else {
+ JsonObject properties = child(icp, PROPERTIES);
+ return indent(name + ":\n" +
+ " type: tosca.nodes.nfv.VduCpd\n" +
+ " " + PROPERTIES + ":\n" +
+ " layer_protocol: " + childElement(properties, "layer_protocol").getAsString() + "\n" +
+ " role: leaf\n" + (properties.has(DESCRIPTION) ?
+ " description: " + childElement(properties, DESCRIPTION).getAsString() + "\n" : "") +
+ " requirements:\n" +
+ " - virtual_binding: " + vdu + "\n" +
+ " - virtual_link: " + vl + "\n", 2);
+ }
+ } else {
+ logger.warn("The {} internal connection point does not have a requirements section", name);
+ }
+ return "";
+ }
+
+ private String buildVduCpd(String name, String vdu, JsonObject properties) {
+ return indent(name + ":\n" +
+ " type: tosca.nodes.nfv.VduCpd\n" +
+ " " + PROPERTIES + ":\n" +
+ " layer_protocol: " + childElement(properties, "layer_protocol").getAsString() + "\n" +
+ " role: leaf\n" +
+ (properties.has(DESCRIPTION) ?
+ " description: " + childElement(properties, DESCRIPTION).getAsString() + "\n" : "") +
+ " requirements:\n" +
+ " - virtual_binding: " + vdu + "\n", 2);
+ }
+
+ private String buildVolume(String nodeName, JsonObject volume) {
+ return indent(nodeName + ":\n" +
+ " type: tosca.nodes.nfv.VDU.VirtualStorage\n" +
+ " properties:\n" +
+ " id: " + nodeName + "\n" +
+ " type_of_storage: volume\n" +
+ " size_of_storage: " + childElement(child(volume, PROPERTIES), "size_of_storage").getAsString() + "\n", 2);
+ }
+
+ private String buildVl(String name) {
+ return indent(name + ":\n" +
+ " type: tosca.nodes.nfv.VnfVirtualLinkDesc\n" +
+ " properties:\n" +
+ " vl_flavours:\n" +
+ " flavours:\n" +
+ " flavourId: notUsed\n", 2);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/package-info.java
new file mode 100644
index 00000000..7a94ee79
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Converts a CBAM package into an ONAP package
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/ConverterApi.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/ConverterApi.java
new file mode 100644
index 00000000..790ac054
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/ConverterApi.java
@@ -0,0 +1,96 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import com.google.common.io.ByteStreams;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.OnapVnfPackageBuilder;
+import org.slf4j.Logger;
+import org.springframework.stereotype.Controller;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.ResponseBody;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import javax.servlet.http.Part;
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+
+import static org.apache.http.entity.ContentType.APPLICATION_OCTET_STREAM;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties.BASE_URL;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.http.HttpHeaders.*;
+import static org.springframework.http.HttpStatus.OK;
+import static org.springframework.http.MediaType.TEXT_HTML_VALUE;
+import static org.springframework.web.bind.annotation.RequestMethod.GET;
+import static org.springframework.web.bind.annotation.RequestMethod.POST;
+
+/**
+ * Responsible for providing the converter utilities for CBAM package format
+ */
+@Controller
+@RequestMapping(value = BASE_URL)
+public class ConverterApi {
+ private static Logger logger = getLogger(ConverterApi.class);
+ private OnapVnfPackageBuilder vnfPackageConverter = new OnapVnfPackageBuilder();
+
+ /**
+ * Return the converted ONAP package
+ *
+ * @param httpResponse the HTTP response
+ * @return the converted ONAP package
+ */
+ @RequestMapping(value = "/convert", method = POST)
+ @ResponseBody
+ public void convert(HttpServletResponse httpResponse, HttpServletRequest request) throws IOException {
+ logger.info("REST: convert package");
+ byte[] content;
+ try {
+ Part part = request.getParts().iterator().next();
+ content = ByteStreams.toByteArray(part.getInputStream());
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to extract package from REST parameters", e);
+ }
+ byte[] convertedPackage;
+ try {
+ convertedPackage = vnfPackageConverter.covert(new ByteArrayInputStream(content));
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to convert VNF package", e);
+ }
+ httpResponse.addHeader(CONTENT_TYPE, APPLICATION_OCTET_STREAM.getMimeType());
+ httpResponse.setStatus(OK.value());
+ httpResponse.addHeader(CONTENT_LENGTH, Integer.toString(convertedPackage.length));
+ httpResponse.addHeader(CONTENT_DISPOSITION, "attachment; filename=\"" + "core.csar" + "\"");
+ httpResponse.getOutputStream().write(convertedPackage);
+ httpResponse.getOutputStream().flush();
+ }
+
+ /**
+ * Return the HTTP page to upload the package
+ * Can be removed after the generated swagger API in ONAP is fixed.
+ *
+ * @param httpResponse the HTTP response
+ */
+ @RequestMapping(value = "/convert", method = GET, produces = TEXT_HTML_VALUE)
+ @ResponseBody
+ public void getUploadPageForConvertingVnfd(HttpServletResponse httpResponse) throws IOException {
+ logger.info("REST: get converter main page");
+ byte[] bytes = systemFunctions().loadFile("upload.html");
+ httpResponse.addHeader(CONTENT_LENGTH, Integer.toString(bytes.length));
+ httpResponse.getOutputStream().write(bytes);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcmApi.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcmApi.java
new file mode 100644
index 00000000..7f63a1a4
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcmApi.java
@@ -0,0 +1,154 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.JobManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager;
+import org.onap.vnfmdriver.model.*;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Controller;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.ResponseBody;
+
+import javax.servlet.http.HttpServletResponse;
+
+import java.util.Optional;
+
+import static java.util.Optional.empty;
+import static org.apache.http.HttpStatus.SC_CREATED;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties.BASE_URL;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.http.MediaType.APPLICATION_JSON_VALUE;
+import static org.springframework.web.bind.annotation.RequestMethod.GET;
+import static org.springframework.web.bind.annotation.RequestMethod.POST;
+
+/**
+ * Responsible for providing the Nokia sVNFM REST APIs
+ */
+@Controller
+@RequestMapping(value = BASE_URL)
+public class LcmApi {
+ private static Logger logger = getLogger(LcmApi.class);
+
+ private final LifecycleManager lifecycleManager;
+ private final JobManager jobManager;
+
+ @Autowired
+ LcmApi(LifecycleManager lifecycleManager, JobManager jobManager) {
+ this.lifecycleManager = lifecycleManager;
+ this.jobManager = jobManager;
+ }
+
+ /**
+ * Instantiate the VNF (defined further in the VF-C driver integration documentation)
+ *
+ * @param request the instantiation request
+ * @param vnfmId the identifier of the VNFM
+ * @param httpResponse the HTTP response
+ * @return the instantiated VNF info
+ */
+ @RequestMapping(value = "/{vnfmId}/vnfs", method = POST, produces = APPLICATION_JSON_VALUE, consumes = APPLICATION_JSON_VALUE)
+ @ResponseBody
+ public VnfInstantiateResponse instantiateVnf(@RequestBody VnfInstantiateRequest request, @PathVariable("vnfmId") String vnfmId, HttpServletResponse httpResponse) {
+ logger.info("REST: Instantiate VNF");
+ //FIXME
+
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(vnfmId, request, httpResponse);
+ httpResponse.setStatus(SC_CREATED);
+ return response;
+ }
+
+ /**
+ * Terminate the VNF (defined further in the VF-C driver integration documentation)
+ *
+ * @param request the instantiation request
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfInstanceId the identifer of the VNF
+ * @param httpResponse the HTTP response
+ * @return the job representing the VNF termination operation
+ */
+ @RequestMapping(value = "/{vnfmId}/vnfs/{vnfId}/terminate", method = POST, produces = APPLICATION_JSON_VALUE)
+ @ResponseBody
+ public JobInfo terminateVnf(@RequestBody VnfTerminateRequest request, @PathVariable("vnfmId") String vnfmId, @PathVariable("vnfId") String vnfInstanceId, HttpServletResponse httpResponse) {
+ logger.info("REST: Terminate VNF");
+ return lifecycleManager.terminateVnf(vnfmId, vnfInstanceId, request, httpResponse);
+ }
+
+ /**
+ * Query the VNF (defined further in the VF-C driver integration documentation)
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfInstanceId the identifer of the VNF
+ * @param httpResponse the HTTP response
+ * @return the VNF info
+ */
+ @RequestMapping(value = "/{vnfmId}/vnfs/{vnfId}", method = GET, produces = APPLICATION_JSON_VALUE, consumes = APPLICATION_JSON_VALUE)
+ @ResponseBody
+ public VnfInfo queryVnf(@PathVariable("vnfmId") String vnfmId, @PathVariable("vnfId") String vnfInstanceId, HttpServletResponse httpResponse) {
+ logger.info("REST: Query VNF");
+ return lifecycleManager.queryVnf(vnfmId, vnfInstanceId);
+ }
+
+ /**
+ * Query the job (defined further in the VF-C driver integration documentation)
+ *
+ * @param jobId the identifer of the job
+ * @param vnfmId the identifier of the VNFM
+ * @param httpResponse the HTTP response
+ * @return the instantiated VNF info
+ */
+ @RequestMapping(value = "/{vnfmId}/jobs/{jobId}", method = GET, produces = APPLICATION_JSON_VALUE)
+ @ResponseBody
+ public JobDetailInfo getJob(@PathVariable("vnfmId") String vnfmId, @PathVariable("jobId") String jobId, HttpServletResponse httpResponse) {
+ logger.debug("REST: Query job");
+ return jobManager.getJob(vnfmId, jobId);
+ }
+
+ /**
+ * Scale the VNF (defined further in the VF-C driver integration documentation)
+ *
+ * @param request the scaling request
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfInstanceId the identifier of the VNF
+ * @param httpResponse the HTTP response
+ * @return the job representing the scaling operation
+ */
+ @RequestMapping(value = "/{vnfmId}/vnfs/{vnfId}/scale", method = POST, produces = APPLICATION_JSON_VALUE, consumes = APPLICATION_JSON_VALUE)
+ @ResponseBody
+ public JobInfo scaleVnf(@RequestBody VnfScaleRequest request, @PathVariable("vnfmId") String vnfmId, @PathVariable("vnfId") String vnfInstanceId, HttpServletResponse httpResponse) {
+ logger.info("REST: Scale VNF");
+ return lifecycleManager.scaleVnf(vnfmId, vnfInstanceId, request, httpResponse);
+ }
+
+ /**
+ * Heal the VNF (defined further in the VF-C driver integration documentation)
+ *
+ * @param request the healing request
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfInstanceId the identifier of the VNF
+ * @param httpResponse the HTTP response
+ * @return the job representing the healing operation
+ */
+ @RequestMapping(value = "/{vnfmId}/vnfs/{vnfId}/heal", method = POST, produces = APPLICATION_JSON_VALUE, consumes = APPLICATION_JSON_VALUE)
+ @ResponseBody
+ public JobInfo healVnf(@RequestBody VnfHealRequest request, @PathVariable("vnfmId") String vnfmId, @PathVariable("vnfId") String vnfInstanceId, HttpServletResponse httpResponse) {
+ logger.info("REST: Heal VNF");
+ return lifecycleManager.healVnf(vnfmId, vnfInstanceId, request, empty(), httpResponse);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcnApi.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcnApi.java
new file mode 100644
index 00000000..df871b09
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/LcnApi.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import com.nokia.cbam.lcm.v32.model.VnfLifecycleChangeNotification;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.LifecycleChangeNotificationManager;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Controller;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.ResponseBody;
+import org.springframework.web.bind.annotation.ResponseStatus;
+
+import javax.servlet.http.HttpServletResponse;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties.BASE_URL;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties.LCN_URL;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.http.HttpStatus.NO_CONTENT;
+import static org.springframework.http.MediaType.APPLICATION_JSON_VALUE;
+import static org.springframework.web.bind.annotation.RequestMethod.GET;
+import static org.springframework.web.bind.annotation.RequestMethod.POST;
+
+/**
+ * Responsible for providing the Nokia CBAM REST API for recieving LCNs from CBAM
+ */
+@Controller
+@RequestMapping(value = BASE_URL)
+public class LcnApi {
+ private static Logger logger = getLogger(LcnApi.class);
+ private final LifecycleChangeNotificationManager lcnManager;
+
+ @Autowired
+ LcnApi(LifecycleChangeNotificationManager lcnManager) {
+ this.lcnManager = lcnManager;
+ }
+
+ /**
+ * Provides a probe for CBAM VNFM to test LCN registration
+ *
+ * @param httpResponse the HTTP response
+ */
+ @RequestMapping(value = LCN_URL, method = GET)
+ public void testLcnConnectivity(HttpServletResponse httpResponse) {
+ //used to test connectivity from CBAM to driver
+ }
+
+ /**
+ * Handle the LCN sent by CBAM
+ *
+ * @param lcn the LCN notification
+ * @param httpResponse the HTTP response
+ */
+ @RequestMapping(value = LCN_URL, method = POST, consumes = APPLICATION_JSON_VALUE)
+ @ResponseBody
+ @ResponseStatus(code = NO_CONTENT)
+ public void handleLcn(@RequestBody VnfLifecycleChangeNotification lcn, HttpServletResponse httpResponse) {
+ logger.info("REST: handle LCN");
+ lcnManager.handleLcn(lcn);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/SwaggerApi.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/SwaggerApi.java
new file mode 100644
index 00000000..15c8dc36
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/SwaggerApi.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Controller;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.ResponseBody;
+
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties.BASE_URL;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.http.HttpHeaders.CONTENT_LENGTH;
+import static org.springframework.http.HttpHeaders.CONTENT_TYPE;
+import static org.springframework.http.MediaType.APPLICATION_JSON_VALUE;
+import static org.springframework.web.bind.annotation.RequestMethod.GET;
+
+/**
+ * Responsible for providing the Nokia S-VNFM REST APIs for accessing the swagger definitions
+ */
+@Controller
+@RequestMapping(value = BASE_URL)
+public class SwaggerApi {
+ private static Logger logger = getLogger(SwaggerApi.class);
+ private final SelfRegistrationManager selfRegistrationManager;
+
+ @Autowired
+ SwaggerApi(SelfRegistrationManager selfRegistrationManager) {
+ this.selfRegistrationManager = selfRegistrationManager;
+ }
+
+ /**
+ * Return the swagger definition
+ *
+ * @param httpResponse the HTTP response
+ * @return the job representing the healing operation
+ */
+ @RequestMapping(value = "/swagger.json", method = GET)
+ @ResponseBody
+ public void getSwaggerApiDefinition(HttpServletResponse httpResponse) throws IOException {
+ logger.info("REST: get swagger definition");
+ httpResponse.addHeader(CONTENT_TYPE, APPLICATION_JSON_VALUE);
+ byte[] bytes = selfRegistrationManager.getSwaggerApiDefinition();
+ httpResponse.addHeader(CONTENT_LENGTH, Integer.toString(bytes.length));
+ httpResponse.getOutputStream().write(bytes);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/package-info.java
new file mode 100644
index 00000000..4436d722
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * The provided REST interfaces.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/Conditions.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/Conditions.java
new file mode 100644
index 00000000..defa340a
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/Conditions.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring;
+
+import com.google.common.collect.Sets;
+import org.springframework.context.annotation.Condition;
+import org.springframework.context.annotation.ConditionContext;
+import org.springframework.core.type.AnnotatedTypeMetadata;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import static com.google.common.collect.Sets.newHashSet;
+
+/**
+ * Collects the possibilities of sources
+ */
+public class Conditions {
+ private static final String USE_DIRECT_INTEGRATION = "direct";
+
+ private Conditions() {
+ //use static way
+ }
+
+ /**
+ * Represents the condition for using VF-C
+ */
+ public static class UseForVfc implements Condition {
+ private static Set<Condition> getAllSources() {
+ return newHashSet(new UseForVfc(), new UseForDirect());
+ }
+
+ @Override
+ public boolean matches(ConditionContext conditionContext, AnnotatedTypeMetadata annotatedTypeMetadata) {
+ boolean anyOtherSourceAvailable = false;
+ for (Condition condition : UseForVfc.getAllSources()) {
+ if (!(condition instanceof UseForVfc) && condition.matches(conditionContext, annotatedTypeMetadata)) {
+ anyOtherSourceAvailable = true;
+ }
+ }
+ return !anyOtherSourceAvailable;
+ }
+ }
+
+ /**
+ * Represents the condition for using ONAP components directly
+ */
+ public static class UseForDirect implements Condition {
+ @Override
+ public boolean matches(ConditionContext conditionContext, AnnotatedTypeMetadata annotatedTypeMetadata) {
+ HashSet<String> activeProfiles = Sets.newHashSet(conditionContext.getEnvironment().getActiveProfiles());
+ return activeProfiles.contains(USE_DIRECT_INTEGRATION);
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/RealConfig.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/RealConfig.java
new file mode 100644
index 00000000..26a3156f
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/RealConfig.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring;
+
+import com.nokia.cbam.lcm.v32.ApiClient;
+import org.springframework.boot.autoconfigure.web.HttpMessageConverters;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.http.converter.HttpMessageConverter;
+import org.springframework.http.converter.json.GsonHttpMessageConverter;
+
+import java.util.ArrayList;
+import java.util.Collection;
+
+/**
+ * Responsible for configuring the raw REST input conversion
+ */
+@Configuration
+public class RealConfig {
+
+ /**
+ * Responsible for registering the RAW to POJO message converters.
+ * This is required since the generated POJOs are annotated with google GSON
+ * compatible annotations Jackson can not deserialize the stream.
+ *
+ * @return the message converter
+ */
+ @Bean
+ public HttpMessageConverters customConverters() {
+ Collection<HttpMessageConverter<?>> messageConverters = new ArrayList<>();
+ GsonHttpMessageConverter gsonHttpMessageConverter = new GsonHttpMessageConverter();
+ gsonHttpMessageConverter.setGson(new ApiClient().getJSON().getGson());
+ messageConverters.add(gsonHttpMessageConverter);
+ return new HttpMessageConverters(true, messageConverters);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/ServletInitializer.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/ServletInitializer.java
new file mode 100644
index 00000000..fe1bb183
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/ServletInitializer.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.NokiaSvnfmApplication;
+import org.springframework.boot.builder.SpringApplicationBuilder;
+import org.springframework.boot.web.support.SpringBootServletInitializer;
+
+/**
+ * Responsible for initializing the Spring application
+ */
+public class ServletInitializer extends SpringBootServletInitializer {
+
+ @Override
+ protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
+ return application.sources(NokiaSvnfmApplication.class);
+ }
+
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/package-info.java
new file mode 100644
index 00000000..93f991fa
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Bootstraps the Spring environments
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring;
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/CbamUtils.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/CbamUtils.java
new file mode 100644
index 00000000..b4e59151
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/CbamUtils.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import com.google.gson.JsonElement;
+import com.google.gson.JsonObject;
+import org.slf4j.Logger;
+
+/**
+ * Collection of utility functions
+ */
+public class CbamUtils {
+
+ /**
+ * Separator for multiple keys concatenated into a single string
+ */
+ public static final String SEPARATOR = "_";
+
+ private CbamUtils() {
+ //use static way
+ }
+
+ /**
+ * @param parent the parent JSON object
+ * @param name the name of the child
+ * @return the child JSON object of parent with given name
+ */
+ public static JsonObject child(JsonObject parent, String name) {
+ return childElement(parent, name).getAsJsonObject();
+ }
+
+ /**
+ * @param parent the parent JSON object
+ * @param name the name of the child
+ * @return the child JSON object of parent with given name
+ */
+ public static JsonElement childElement(JsonObject parent, String name) {
+ JsonElement child = parent.get(name);
+ if (child == null) {
+ throw new OperationMustBeAborted("Missing child " + name);
+ }
+ return child;
+ }
+
+ /**
+ * Logs and returns a runtime exception
+ *
+ * @param logger the logger
+ * @param msg the error message
+ * @param e the exception to be wrapped
+ * @return never reached (runtime exception is thrown)
+ */
+ public static RuntimeException buildFatalFailure(Logger logger, String msg, Exception e) {
+ logger.error(msg, e);
+ return new OperationMustBeAborted(e, msg);
+ }
+
+ /**
+ * Logs and returns a runtime exception
+ *
+ * @param logger the logger
+ * @param msg the error message
+ * @return never reached (runtime exception is thrown)
+ */
+ public static RuntimeException buildFatalFailure(Logger logger, String msg) {
+ logger.error(msg);
+ return new OperationMustBeAborted(msg);
+ }
+
+ private static class OperationMustBeAborted extends RuntimeException {
+ OperationMustBeAborted(String msg) {
+ super(msg);
+ }
+
+ OperationMustBeAborted(Exception e, String msg) {
+ super(msg, e);
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/StoreLoader.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/StoreLoader.java
new file mode 100644
index 00000000..643d0286
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/StoreLoader.java
@@ -0,0 +1,163 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import org.apache.commons.codec.binary.Base64;
+
+import java.io.ByteArrayInputStream;
+import java.io.InputStream;
+import java.security.KeyFactory;
+import java.security.KeyStore;
+import java.security.KeyStore.TrustedCertificateEntry;
+import java.security.PrivateKey;
+import java.security.cert.Certificate;
+import java.security.cert.CertificateFactory;
+import java.security.spec.PKCS8EncodedKeySpec;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.Optional;
+import java.util.Set;
+
+import static java.util.Optional.empty;
+import static java.util.Optional.of;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Create Truststore from the given certificates and keys
+ */
+public final class StoreLoader {
+
+ public static final String PASS_ALIAS = "password";
+ private static final String RSA = "RSA";
+ private static final String X_509 = "X.509";
+ private static final String SUN = "SUN";
+ private static final String JKS = "JKS";
+ private static final String RSA_PRIVATE_KEY = "RSA PRIVATE KEY";
+ private static final String CERTIFICATE = "CERTIFICATE";
+ private static org.slf4j.Logger logger = getLogger(StoreLoader.class);
+
+ private StoreLoader() {
+ }
+
+ private static String getScope(String content, String scope) {
+ int rindex = content.indexOf(begin(scope));
+ int lindex = content.indexOf(end(scope));
+ if (rindex == -1 || lindex == -1) {
+ return "";
+ }
+ return content.substring(rindex, lindex) + end(scope);
+ }
+
+ /**
+ * @param content the content of the PEM ( a PEM may contain multiple certificates)
+ * @return the collection of certificates in the PEM
+ */
+ public static Set<String> getCertifacates(String content) {
+ String lastCertificate = "";
+ Set<String> certificates = new HashSet<>();
+ do {
+ lastCertificate = getScope(content, CERTIFICATE);
+ content = content.replace(lastCertificate, "");
+ if (!"".equals(lastCertificate)) {
+ certificates.add(lastCertificate);
+ }
+ } while (!"".equals(lastCertificate));
+ return certificates;
+ }
+
+ private static byte[] toDer(String pem, String scope) {
+ return Base64.decodeBase64(pem
+ .replace(begin(scope), "")
+ .replace(end(scope), "")
+ .replaceAll("\\s", ""));
+ }
+
+ private static String begin(String scope) {
+ return "-----BEGIN " + scope + "-----";
+ }
+
+ private static String end(String scope) {
+ return "-----END " + scope + "-----";
+ }
+
+ /**
+ * Create new truststore from the given certificate
+ *
+ * @param pem the certificate which used to create the store
+ * @param storePassword the password to protect the store
+ * @param keyPassword the password to protect the key
+ * @return the created key store
+ */
+ public static KeyStore loadStore(String pem, String storePassword, String keyPassword) {
+ Optional<PrivateKey> privateKey = generatePrivateKey(pem);
+ Optional<Certificate[]> certs = createCertificates(pem);
+ try {
+ KeyStore ks = KeyStore.getInstance(JKS, SUN);
+ ks.load(null, storePassword.toCharArray());
+ if (privateKey.isPresent()) {
+ ks.setKeyEntry(PASS_ALIAS, privateKey.get(), keyPassword.toCharArray(), certs.orElse(null));
+ } else if (certs.isPresent()) {
+ int index = 0;
+ for (Certificate cert : certs.get()) {
+ TrustedCertificateEntry ts = new TrustedCertificateEntry(cert);
+ ks.setEntry(PASS_ALIAS + index, ts, null);
+ index++;
+ }
+ }
+ return ks;
+ } catch (Exception e) {
+ throw new UserInvisibleError("Unable to create keystore", e);
+ }
+ }
+
+ private static Optional<Certificate[]> createCertificates(String pem) {
+ Set<Certificate> certificates = new HashSet<>();
+ try {
+ for (String certificate : getCertifacates(pem)) {
+ CertificateFactory certFactory = CertificateFactory.getInstance(X_509);
+
+ InputStream is = new ByteArrayInputStream(toDer(certificate, CERTIFICATE));
+ Collection<? extends Certificate> c = certFactory.generateCertificates(is);
+ certificates.addAll(c);
+ }
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to load certificates", e);
+ }
+
+ if (!certificates.isEmpty()) {
+ return of(certificates.toArray(new Certificate[certificates.size()]));
+ } else {
+ return empty();
+ }
+ }
+
+ private static Optional<PrivateKey> generatePrivateKey(String pem) {
+ try {
+ String key = getScope(pem, RSA_PRIVATE_KEY);
+ if (!key.isEmpty()) {
+ KeyFactory keyFactory = KeyFactory.getInstance(RSA);
+ PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(toDer(key, RSA_PRIVATE_KEY));
+ return of(keyFactory.generatePrivate(keySpec));
+ }
+ return empty();
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to load key", e);
+ }
+ }
+
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/SystemFunctions.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/SystemFunctions.java
new file mode 100644
index 00000000..0bb63039
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/SystemFunctions.java
@@ -0,0 +1,165 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import com.google.common.io.ByteStreams;
+import org.apache.http.impl.client.CloseableHttpClient;
+import org.apache.http.impl.client.HttpClients;
+
+import java.io.InputStream;
+import java.io.PrintStream;
+
+/**
+ * Wrapper class for static method calls to core or core libraries.
+ * Calls to static methods in core or core libraries are wrapped to be able to test
+ * the classes that uses static calls.
+ */
+public class SystemFunctions {
+ private static SystemFunctions singletonInstance;
+
+ /**
+ * @return singleton instance
+ */
+ public static SystemFunctions systemFunctions() {
+ if (singletonInstance != null) {
+ return singletonInstance;
+ } else {
+ synchronized (SystemFunctions.class) {
+ singletonInstance = new SystemFunctions();
+ }
+ return singletonInstance;
+ }
+ }
+
+ /**
+ * Causes the currently executing thread to sleep (temporarily cease
+ * execution) for the specified number of milliseconds, subject to
+ * the precision and accuracy of system timers and schedulers. The thread
+ * does not lose ownership of any monitors.
+ *
+ * @param millis the length of time to sleep in milliseconds
+ */
+ public void sleep(long millis) {
+ try {
+ Thread.sleep(millis);
+ } catch (InterruptedException e) {
+ Thread.currentThread().interrupt();
+ throw new UserInvisibleError("Interrupted while sleep", e);
+ }
+ }
+
+ /**
+ * Returns the current time in milliseconds. Note that
+ * while the unit of time of the return value is a millisecond,
+ * the granularity of the value depends on the underlying
+ * operating system and may be larger. For example, many
+ * operating systems measure time in units of tens of
+ * milliseconds.
+ * <p>
+ * <p> See the description of the class <code>Date</code> for
+ * a discussion of slight discrepancies that may arise between
+ * Unable to load /unittests/missing * "computer time" and coordinated universal time (UTC).
+ *
+ * @return the difference, measured in milliseconds, between
+ * the current time and midnight, January 1, 1970 UTC.
+ * @see java.util.Date
+ */
+ public long currentTimeMillis() {
+ return System.currentTimeMillis();
+ }
+
+ /**
+ * Loads a file from the class path
+ *
+ * @param url the URL of the file
+ * @return the content of the file
+ */
+ public byte[] loadFile(String url) {
+ try {
+ InputStream stream = SystemFunctions.class.getClassLoader().getResourceAsStream(url);
+ return ByteStreams.toByteArray(stream);
+ } catch (Exception e) {
+ throw new UserVisibleError("Unable to load " + url, e);
+ }
+ }
+
+ /**
+ * The "standard" error output stream. This stream is already
+ * open and ready to accept output data.
+ * <p>
+ * Typically this stream corresponds to display output or another
+ * output destination specified by the host environment or user. By
+ * convention, this output stream is used to display error messages
+ * or other information that should come to the immediate attention
+ * of a user even if the principal output stream, the value of the
+ * variable <code>out</code>, has been redirected to a file or other
+ * destination that is typically not continuously monitored.
+ */
+ @SuppressWarnings("squid:S106") // (intentional wrapping of system err)
+ public PrintStream err() {
+ return System.err;
+ }
+
+ /**
+ * The "standard" output stream. This stream is already
+ * open and ready to accept output data. Typically this stream
+ * corresponds to display output or another output destination
+ * specified by the host environment or user.
+ * <p>
+ * For simple stand-alone Java applications, a typical way to write
+ * a line of output data is:
+ * <blockquote><pre>
+ * System.out.println(data)
+ * </pre></blockquote>
+ * <p>
+ * See the <code>println</code> methods in class <code>PrintStream</code>.
+ *
+ * @see java.io.PrintStream#println()
+ * @see java.io.PrintStream#println(boolean)
+ * @see java.io.PrintStream#println(char)
+ * @see java.io.PrintStream#println(char[])
+ * @see java.io.PrintStream#println(double)
+ * @see java.io.PrintStream#println(float)
+ * @see java.io.PrintStream#println(int)
+ * @see java.io.PrintStream#println(long)
+ * @see java.io.PrintStream#println(java.lang.Object)
+ * @see java.io.PrintStream#println(java.lang.String)
+ */
+ @SuppressWarnings("squid:S106") // (intentional wrapping of system err)
+ public PrintStream out() {
+ return System.out;
+ }
+
+ /**
+ * The "standard" input stream. This stream is already
+ * open and ready to supply input data. Typically this stream
+ * corresponds to keyboard input or another input source specified by
+ * the host environment or user.
+ */
+ public InputStream in() {
+ return System.in; //NO SONAR (intentional wrapping of system in)
+ }
+
+ /**
+ * Wraps the static call (required for being able to test)
+ *
+ * @return the default HTTP client
+ */
+ public CloseableHttpClient getHttpClient() {
+ return HttpClients.createDefault();
+ }
+
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserInvisibleError.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserInvisibleError.java
new file mode 100644
index 00000000..95e64256
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserInvisibleError.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+/**
+ * Represents an error that should not be visible for the end user
+ * using the REST API
+ */
+public class UserInvisibleError extends RuntimeException {
+
+ /**
+ * @param message the error message
+ */
+ public UserInvisibleError(String message) {
+ super(message);
+ }
+
+ /**
+ * @param message the error message
+ * @param cause the cause of the error
+ */
+ public UserInvisibleError(String message, Exception cause) {
+ super(message, cause);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserVisibleError.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserVisibleError.java
new file mode 100644
index 00000000..afc54305
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/UserVisibleError.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+/**
+ * Represents an error that is meaningful for an end user
+ * using the REST interface
+ */
+public class UserVisibleError extends RuntimeException {
+
+ /**
+ * @param message the error message
+ */
+ public UserVisibleError(String message) {
+ super(message);
+ }
+
+ /**
+ * @param message the error message
+ * @param cause the cause of the error
+ */
+ public UserVisibleError(String message, Exception cause) {
+ super(message, cause);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/AdditionalParameters.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/AdditionalParameters.java
new file mode 100644
index 00000000..dfb7adaf
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/AdditionalParameters.java
@@ -0,0 +1,216 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.nokia.cbam.lcm.v32.model.*;
+import com.nokia.cbam.lcm.v32.model.VimInfo.VimInfoTypeEnum;
+
+import java.util.*;
+
+/**
+ * Represents the additional parameters to be sent during instantiation from VF-C to the driver
+ */
+public class AdditionalParameters {
+ private VimInfoTypeEnum vimType;
+ private String domain;
+ private String instantiationLevel;
+ private List<VimComputeResourceFlavour> computeResourceFlavours = new ArrayList<>();
+ private List<ZoneInfo> zones = new ArrayList<>();
+ private List<VimSoftwareImage> softwareImages = new ArrayList<>();
+ private List<ExtManagedVirtualLinkData> extManagedVirtualLinks = new ArrayList<>();
+ private Map<String, List<NetworkAddress>> externalConnectionPointAddresses = new HashMap<>();
+ private List<ExtVirtualLinkData> extVirtualLinks = new ArrayList<>();
+ private Object additionalParams;
+
+ public AdditionalParameters() {
+ //only used through reflection (gson)
+ }
+
+ /**
+ * @return the additional parameters of the instantiation
+ */
+ public Object getAdditionalParams() {
+ return additionalParams;
+ }
+
+ /**
+ * @param additionalParams the additional parameters of the instantiation
+ */
+ public void setAdditionalParams(Object additionalParams) {
+ this.additionalParams = additionalParams;
+ }
+
+ /**
+ * @return the type of the VIM
+ */
+ public VimInfoTypeEnum getVimType() {
+ return vimType;
+ }
+
+ /**
+ * @param vimType the type of the VIM
+ */
+ public void setVimType(VimInfoTypeEnum vimType) {
+ this.vimType = vimType;
+ }
+
+ /**
+ * @return the domain of the OpenStack (required for v3 API)
+ */
+ public String getDomain() {
+ return domain;
+ }
+
+ /**
+ * @param domain the domain of the OpenStack (required for v3 API)
+ */
+ public void setDomain(String domain) {
+ this.domain = domain;
+ }
+
+ /**
+ * @return the flavours to be used for the VNF
+ */
+ public List<VimComputeResourceFlavour> getComputeResourceFlavours() {
+ return computeResourceFlavours;
+ }
+
+ /**
+ * @param computeResourceFlavours the flavours to be used for the VNF
+ */
+ public void setComputeResourceFlavours(List<VimComputeResourceFlavour> computeResourceFlavours) {
+ this.computeResourceFlavours = computeResourceFlavours;
+ }
+
+ /**
+ * @return the images to be used
+ */
+ public List<VimSoftwareImage> getSoftwareImages() {
+ return softwareImages;
+ }
+
+ /**
+ * @param softwareImages the images to be used
+ */
+ public void setSoftwareImages(List<VimSoftwareImage> softwareImages) {
+ this.softwareImages = softwareImages;
+ }
+
+ /**
+ * @return the zones to be used for the VNF
+ */
+ public List<ZoneInfo> getZones() {
+ return zones;
+ }
+
+ /**
+ * @param zones the zones to be used for the VNF
+ */
+ public void setZones(List<ZoneInfo> zones) {
+ this.zones = zones;
+ }
+
+ /**
+ * @return the instantiation level of the VNF
+ */
+ public String getInstantiationLevel() {
+ return instantiationLevel;
+ }
+
+ /**
+ * @param instantiationLevel the instantiation level of the VNF
+ */
+ public void setInstantiationLevel(String instantiationLevel) {
+ this.instantiationLevel = instantiationLevel;
+ }
+
+ /**
+ * @return the externally managed internal virtual links
+ */
+ public List<ExtManagedVirtualLinkData> getExtManagedVirtualLinks() {
+ return extManagedVirtualLinks;
+ }
+
+ /**
+ * @param extManagedVirtualLinks the externally managed internal virtual links
+ */
+ public void setExtManagedVirtualLinks(List<ExtManagedVirtualLinkData> extManagedVirtualLinks) {
+ this.extManagedVirtualLinks = extManagedVirtualLinks;
+ }
+
+ /**
+ * @return a binding of the extenal connection points by identifier to it's network addresses to be used
+ */
+ public Map<String, List<NetworkAddress>> getExternalConnectionPointAddresses() {
+ return externalConnectionPointAddresses;
+ }
+
+ /**
+ * @param externalConnectionPointAddresses a binding of the extenal connection points by identifier to it's network addresses to be used
+ */
+ public void setExternalConnectionPointAddresses(Map<String, List<NetworkAddress>> externalConnectionPointAddresses) {
+ this.externalConnectionPointAddresses = externalConnectionPointAddresses;
+ }
+
+ public List<ExtVirtualLinkData> getExtVirtualLinks() {
+ return extVirtualLinks;
+ }
+
+ public void setExtVirtualLinks(List<ExtVirtualLinkData> extVirtualLinks) {
+ this.extVirtualLinks = extVirtualLinks;
+ }
+
+ @Override
+ //generated code. This is the recommended way to formulate equals
+ @SuppressWarnings({"squid:S00122", "squid:S1067"})
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ AdditionalParameters that = (AdditionalParameters) o;
+ return vimType == that.vimType &&
+ Objects.equals(domain, that.domain) &&
+ Objects.equals(instantiationLevel, that.instantiationLevel) &&
+ Objects.equals(computeResourceFlavours, that.computeResourceFlavours) &&
+ Objects.equals(zones, that.zones) &&
+ Objects.equals(softwareImages, that.softwareImages) &&
+ Objects.equals(extManagedVirtualLinks, that.extManagedVirtualLinks) &&
+ Objects.equals(externalConnectionPointAddresses, that.externalConnectionPointAddresses) &&
+ Objects.equals(extVirtualLinks, that.extVirtualLinks) &&
+ Objects.equals(additionalParams, that.additionalParams);
+ }
+
+ @Override
+ public int hashCode() {
+
+ return Objects.hash(vimType, domain, instantiationLevel, computeResourceFlavours, zones, softwareImages, extManagedVirtualLinks, externalConnectionPointAddresses, extVirtualLinks, additionalParams);
+ }
+
+ @Override
+ public String toString() {
+ return "AdditionalParameters{" +
+ "vimType=" + vimType +
+ ", domain='" + domain + '\'' +
+ ", instantiationLevel='" + instantiationLevel + '\'' +
+ ", computeResourceFlavours=" + computeResourceFlavours +
+ ", zones=" + zones +
+ ", softwareImages=" + softwareImages +
+ ", extManagedVirtualLinks=" + extManagedVirtualLinks +
+ ", externalConnectionPointAddresses=" + externalConnectionPointAddresses +
+ ", extVirtualLinks=" + extVirtualLinks +
+ ", additionalParams=" + additionalParams +
+ '}';
+ }
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CatalogManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CatalogManager.java
new file mode 100644
index 00000000..6a35d8e2
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CatalogManager.java
@@ -0,0 +1,177 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.io.ByteStreams;
+import com.nokia.cbam.catalog.v1.ApiException;
+import com.nokia.cbam.catalog.v1.api.DefaultApi;
+import com.nokia.cbam.catalog.v1.model.CatalogAdapterVnfpackage;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.IPackageProvider;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import java.io.*;
+import java.nio.file.Path;
+import java.util.HashSet;
+import java.util.NoSuchElementException;
+import java.util.Set;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipInputStream;
+
+import static com.google.common.base.Splitter.on;
+import static com.google.common.collect.Iterables.filter;
+import static java.nio.file.Files.createTempFile;
+import static java.nio.file.Files.write;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.slf4j.LoggerFactory.getLogger;
+
+
+/**
+ * Responsible for handling the CBAM catalog
+ * - the VNF package is uploaded as part of the instantiation
+ * - the VNF package is not deleted after VNF deletion
+ */
+@Component
+public class CatalogManager {
+ /**
+ * The location of the CBAM package within the ONAP package
+ */
+ public static final String CBAM_PACKAGE_NAME_IN_ZIP = "Artifacts/Deployment/OTHER/cbam.package.zip";
+ private static final String TOSCA_META_PATH = "TOSCA-Metadata/TOSCA.meta";
+ private static final String TOSCA_VNFD_KEY = "Entry-Definitions";
+ private static Logger logger = getLogger(CatalogManager.class);
+ private final CbamRestApiProvider cbamRestApiProvider;
+ private final IPackageProvider packageProvider;
+
+ @Autowired
+ CatalogManager(CbamRestApiProvider cbamRestApiProvider, IPackageProvider packageProvider) {
+ this.cbamRestApiProvider = cbamRestApiProvider;
+ this.packageProvider = packageProvider;
+ }
+
+ /**
+ * @param zip the zip
+ * @param path the path of the file to be returned
+ * @return the file in the zip
+ */
+ public static ByteArrayOutputStream getFileInZip(InputStream zip, String path) throws IOException {
+ ZipInputStream zipInputStream = new ZipInputStream(zip);
+ ByteArrayOutputStream fileContent = getFileInZip(zipInputStream, path);
+ zipInputStream.close();
+ return fileContent;
+ }
+
+ /**
+ * @param stream the CBAM VNF package
+ * @return the location of the VNFD within the CBAM package
+ */
+ public static String getVnfdLocation(InputStream stream) throws IOException {
+ String toscaMetadata = new String(getFileInZip(stream, TOSCA_META_PATH).toByteArray());
+ String toscaVnfdLine = filter(on("\n").split(toscaMetadata), line -> line.contains(TOSCA_VNFD_KEY)).iterator().next();
+ return toscaVnfdLine.replace(TOSCA_VNFD_KEY + ":", "").trim();
+ }
+
+ private static ByteArrayOutputStream getFileInZip(ZipInputStream zipInputStream, String path) throws IOException {
+ ZipEntry zipEntry;
+ Set<String> items = new HashSet<>();
+ while ((zipEntry = zipInputStream.getNextEntry()) != null) {
+ items.add(zipEntry.getName());
+ if (zipEntry.getName().matches(path)) {
+ ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
+ ByteStreams.copy(zipInputStream, byteArrayOutputStream);
+ return byteArrayOutputStream;
+ }
+ }
+ logger.error("Unable to find the {} in archive found: {}", path, items);
+ throw new NoSuchElementException("Unable to find the " + path + " in archive found: " + items);
+ }
+
+ /**
+ * Prepare the VNF package in CBAM. If the package is not available in the catalog it is uploaded.
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param csarId the CSAR identifier of the package in ONAP catalog
+ * @return the package in CBAM catalog
+ */
+ public CatalogAdapterVnfpackage preparePackageInCbam(String vnfmId, String csarId) {
+ String cbamVnfdId = packageProvider.getCbamVnfdId(csarId);
+ DefaultApi cbamCatalogApi = cbamRestApiProvider.getCbamCatalogApi(vnfmId);
+ if (!isPackageReplicated(cbamVnfdId, cbamCatalogApi)) {
+ try {
+ Path tempFile = createTempFile("cbam", "zip");
+ ByteArrayOutputStream cbamPackage = getFileInZip(new ByteArrayInputStream(packageProvider.getPackage(csarId)), CBAM_PACKAGE_NAME_IN_ZIP);
+ write(tempFile, cbamPackage.toByteArray());
+ //FIXME delete file
+ return cbamCatalogApi.create(tempFile.toFile());
+ } catch (Exception e) {
+ logger.debug("Probably concurrent package uploads", e);
+ //retest if the VNF package exists in CBAM. It might happen that an other operation
+ //triggered the replication making this API fail. The replication is considered to be
+ //successful if the package exist in CBAM even if the current package transfer failed
+ if (isPackageReplicated(cbamVnfdId, cbamCatalogApi)) {
+ return queryPackageFromCBAM(cbamVnfdId, cbamCatalogApi);
+ } else {
+ throw buildFatalFailure(logger, "Unable to create VNF with " + csarId + " CSAR identifier in package in CBAM", e);
+ }
+ }
+ }
+ return queryPackageFromCBAM(cbamVnfdId, cbamCatalogApi);
+ }
+
+ /**
+ * Gets the content of the VNFD from the CBAM package uploaded to CBAM
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfdId the identifier of the VNFD
+ * @return the content of the CBAM VNFD
+ */
+ public String getCbamVnfdContent(String vnfmId, String vnfdId) {
+ try {
+ File content = cbamRestApiProvider.getCbamCatalogApi(vnfmId).content(vnfdId);
+ String vnfdPath = getVnfdLocation(new FileInputStream(content));
+ return new String(getFileInZip(new FileInputStream(content), vnfdPath).toByteArray());
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to get package with (" + vnfdId + ")", e);
+ }
+ }
+
+ private boolean isPackageReplicated(String cbamVnfdId, DefaultApi cbamCatalogApi) {
+ try {
+ return isPackageReplicatedToCbam(cbamVnfdId, cbamCatalogApi);
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to determine if the VNF package has been replicated in CBAM", e);
+ }
+ }
+
+ private CatalogAdapterVnfpackage queryPackageFromCBAM(String cbamVnfdId, DefaultApi cbamCatalogApi) {
+ try {
+ return cbamCatalogApi.getById(cbamVnfdId);
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to query VNF package with " + cbamVnfdId + " from CBAM", e);
+ }
+ }
+
+ private boolean isPackageReplicatedToCbam(String cbamVnfdId, DefaultApi cbamCatalogApi) throws ApiException {
+ for (CatalogAdapterVnfpackage vnfPackage : cbamCatalogApi.list()) {
+ if (vnfPackage.getVnfdId().equals(cbamVnfdId)) {
+ return true;
+ }
+ }
+ return false;
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamRestApiProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamRestApiProvider.java
new file mode 100644
index 00000000..5fdc919a
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamRestApiProvider.java
@@ -0,0 +1,115 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.io.BaseEncoding;
+import com.nokia.cbam.catalog.v1.api.DefaultApi;
+import com.nokia.cbam.lcm.v32.ApiClient;
+import com.nokia.cbam.lcm.v32.api.OperationExecutionsApi;
+import com.nokia.cbam.lcm.v32.api.VnfsApi;
+import com.nokia.cbam.lcn.v32.api.SubscriptionsApi;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VnfmInfoProvider;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.stereotype.Component;
+
+import java.io.ByteArrayInputStream;
+
+/**
+ * Responsible for providing client to access CBAM REST API
+ */
+@Component
+public class CbamRestApiProvider {
+ public static final String NOKIA_LCN_API_VERSION = "3.2";
+ public static final String NOKIA_LCM_API_VERSION = "3.2";
+ private final DriverProperties driverProperties;
+ private final CbamTokenProvider tokenProvider;
+ private final VnfmInfoProvider vnfmInfoProvider;
+
+ @Value("${trustedCertificates}")
+ private String trustedCertificates;
+ @Value("${skipCertificateVerification}")
+ private boolean skipCertificateVerification;
+
+ @Autowired
+ public CbamRestApiProvider(DriverProperties driverProperties, CbamTokenProvider cbamTokenProvider, VnfmInfoProvider vnfmInfoProvider) {
+ this.driverProperties = driverProperties;
+ this.tokenProvider = cbamTokenProvider;
+ this.vnfmInfoProvider = vnfmInfoProvider;
+ }
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ * @return API to access CBAM LCM API
+ */
+ public VnfsApi getCbamLcmApi(String vnfmId) {
+ return new VnfsApi(getLcmApiClient(vnfmId));
+ }
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ * @return API to access the operation executions
+ */
+ public OperationExecutionsApi getCbamOperationExecutionApi(String vnfmId) {
+ return new OperationExecutionsApi(getLcmApiClient(vnfmId));
+ }
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ * @return API to access CBAM LCN subscription API
+ */
+ public SubscriptionsApi getCbamLcnApi(String vnfmId) {
+ com.nokia.cbam.lcn.v32.ApiClient apiClient = new com.nokia.cbam.lcn.v32.ApiClient();
+ if (!skipCertificateVerification) {
+ apiClient.setSslCaCert(new ByteArrayInputStream(BaseEncoding.base64().decode(trustedCertificates)));
+ } else {
+ apiClient.setVerifyingSsl(false);
+ }
+ apiClient.setBasePath(driverProperties.getCbamLcnUrl());
+ apiClient.setAccessToken(tokenProvider.getToken(vnfmId));
+ return new SubscriptionsApi(apiClient);
+ }
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ * @return API to access CBAM catalog API
+ */
+ public DefaultApi getCbamCatalogApi(String vnfmId) {
+ com.nokia.cbam.catalog.v1.ApiClient apiClient = new com.nokia.cbam.catalog.v1.ApiClient();
+ if (!skipCertificateVerification) {
+ apiClient.setSslCaCert(new ByteArrayInputStream(BaseEncoding.base64().decode(trustedCertificates)));
+ } else {
+ apiClient.setVerifyingSsl(false);
+ }
+ apiClient.setBasePath(driverProperties.getCbamCatalogUrl());
+ apiClient.setAccessToken(tokenProvider.getToken(vnfmId));
+ return new DefaultApi(apiClient);
+ }
+
+ private ApiClient getLcmApiClient(String vnfmId) {
+ VnfmInfo vnfmInfo = vnfmInfoProvider.getVnfmInfo(vnfmId);
+ ApiClient apiClient = new ApiClient();
+ if (!skipCertificateVerification) {
+ apiClient.setSslCaCert(new ByteArrayInputStream(BaseEncoding.base64().decode(trustedCertificates)));
+ } else {
+ apiClient.setVerifyingSsl(false);
+ }
+ apiClient.setAccessToken(tokenProvider.getToken(vnfmId));
+ apiClient.setBasePath(vnfmInfo.getUrl());
+ return apiClient;
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamTokenProvider.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamTokenProvider.java
new file mode 100644
index 00000000..a8c7ca04
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/CbamTokenProvider.java
@@ -0,0 +1,248 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.annotations.VisibleForTesting;
+import com.google.common.base.Joiner;
+import com.google.common.io.BaseEncoding;
+import com.google.gson.Gson;
+import com.google.gson.annotations.SerializedName;
+import okhttp3.*;
+import org.apache.http.conn.ssl.DefaultHostnameVerifier;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VnfmInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.StoreLoader;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.UserVisibleError;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.stereotype.Component;
+import org.springframework.util.StringUtils;
+
+import javax.net.ssl.*;
+import java.io.IOException;
+import java.nio.charset.StandardCharsets;
+import java.security.*;
+import java.security.cert.CertificateException;
+import java.security.cert.X509Certificate;
+import java.util.Set;
+
+import static java.util.UUID.randomUUID;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.http.HttpHeaders.CONTENT_TYPE;
+import static org.springframework.http.MediaType.APPLICATION_FORM_URLENCODED_VALUE;
+
+/**
+ * Responsible for providing a token to access CBAM APIs
+ */
+@Component
+//even if the value for grant type an user password is the same they do not mean the same thing
+//the duplication of this is intentional
+@SuppressWarnings("squid:S1192")
+public class CbamTokenProvider {
+ public static final int MAX_RETRY_COUNT = 5;
+ public static final String GRANT_TYPE = "password";
+ public static final String CLIENT_SECRET = "password";
+ private static final String CBAM_TOKEN_URL = "/realms/cbam/protocol/openid-connect/token";
+ private static Logger logger = getLogger(CbamTokenProvider.class);
+ private final VnfmInfoProvider vnfmInfoProvider;
+ @Value("${cbamKeyCloakBaseUrl}")
+ private String cbamKeyCloakBaseUrl;
+ @Value("${cbamUsername}")
+ private String username;
+ @Value("${cbamPassword}")
+ private String password;
+ @Value("${trustedCertificates}")
+ private String trustedCertificates;
+ @Value("${skipCertificateVerification}")
+ private boolean skipCertificateVerification;
+ @Value("${skipHostnameVerification}")
+ private boolean skipHostnameVerification;
+ private volatile CurrentToken token;
+
+ @Autowired
+ CbamTokenProvider(VnfmInfoProvider vnfmInfoProvider) {
+ this.vnfmInfoProvider = vnfmInfoProvider;
+ }
+
+ /**
+ * @return the token to access CBAM APIs (ex. 123456)
+ */
+ public String getToken(String vnfmId) {
+ VnfmInfo vnfmInfo = vnfmInfoProvider.getVnfmInfo(vnfmId);
+ return getToken(vnfmInfo.getUserName(), vnfmInfo.getPassword());
+ }
+
+ private String getToken(String clientId, String clientSecret) {
+ logger.trace("Requesting token for accessing CBAM API");
+ synchronized (this) {
+ long now = SystemFunctions.systemFunctions().currentTimeMillis();
+ if (token == null || token.refreshAfter < now) {
+ if (token == null) {
+ logger.debug("No token: getting first token");
+ } else {
+ logger.debug("Token expired {} ms ago", (now - token.refreshAfter));
+ }
+ refresh(clientId, clientSecret);
+ } else {
+ logger.debug("Token will expire in {} ms", (now - token.refreshAfter));
+ }
+ }
+ return token.token.accessToken;
+ }
+
+ private void refresh(String clientId, String clientSecret) {
+ FormBody body = new FormBody.Builder()
+ .add("grant_type", GRANT_TYPE)
+ .add("client_id", clientId)
+ .add("client_secret", clientSecret)
+ .add("username", username)
+ .add(CLIENT_SECRET, password).build();
+ Request request = new Request.Builder().url(cbamKeyCloakBaseUrl + CBAM_TOKEN_URL).addHeader(CONTENT_TYPE, APPLICATION_FORM_URLENCODED_VALUE).post(body).build();
+ OkHttpClient.Builder builder = new OkHttpClient.Builder();
+ SSLSocketFactory sslSocketFac = buildSSLSocketFactory();
+ HostnameVerifier hostnameVerifier = buildHostnameVerifier();
+ OkHttpClient client = builder.sslSocketFactory(sslSocketFac).hostnameVerifier(hostnameVerifier).build();
+ Exception lastException = null;
+ for (int i = 0; i < MAX_RETRY_COUNT; i++) {
+ try {
+ Response response = execute(client.newCall(request));
+ if (response.isSuccessful()) {
+ String json = response.body().string();
+ TokenResponse tokenResponse = new Gson().fromJson(json, TokenResponse.class);
+ //token is scheduled to be refreshed in the half time before expiring
+ token = new CurrentToken(tokenResponse, getTokenRefreshTime(tokenResponse));
+ return;
+ } else {
+ throw buildFatalFailure(logger, "Bad response from CBAM KeyStone");
+ }
+ } catch (Exception e) {
+ lastException = e;
+ logger.warn("Unable to get token to access CBAM API (" + (i + 1) + "/" + MAX_RETRY_COUNT + ")", e);
+ }
+ }
+ throw buildFatalFailure(logger, "Unable to get token to access CBAM API (giving up retries)", lastException);
+ }
+
+ @VisibleForTesting
+ Response execute(Call call) throws IOException {
+ return call.execute();
+ }
+
+ /**
+ * - a new token is requested after the half of the time has expired till which the currently
+ * used token is valid
+ *
+ * @param token the currently held token
+ * @return the point in time after which a new token must be requested
+ */
+ private long getTokenRefreshTime(TokenResponse token) {
+ return SystemFunctions.systemFunctions().currentTimeMillis() + token.expiresIn * (1000 / 2);
+ }
+
+ private HostnameVerifier buildHostnameVerifier() {
+ if (skipHostnameVerification) {
+ return (hostname, session) -> true;
+ } else {
+ return new DefaultHostnameVerifier();
+ }
+ }
+
+ @VisibleForTesting
+ SSLSocketFactory buildSSLSocketFactory() {
+ try {
+ TrustManager[] trustManagers = buildTrustManager();
+ SSLContext sslContext = SSLContext.getInstance("TLS");
+ sslContext.init(null, trustManagers, new SecureRandom());
+ return sslContext.getSocketFactory();
+ } catch (GeneralSecurityException e) {
+ throw buildFatalFailure(logger, "Unable to create SSL socket factory", e);
+ }
+ }
+
+ @VisibleForTesting
+ TrustManager[] buildTrustManager() throws KeyStoreException, NoSuchAlgorithmException {
+ if (skipCertificateVerification) {
+ return new TrustManager[]{new AllTrustedTrustManager()};
+ } else {
+ if (StringUtils.isEmpty(trustedCertificates)) {
+ throw new IllegalArgumentException("If the skipCertificateVerification is set to false (default) the trustedCertificates can not be empty");
+ }
+ Set<String> trustedPems;
+ try {
+ trustedPems = StoreLoader.getCertifacates(new String(BaseEncoding.base64().decode(trustedCertificates), StandardCharsets.UTF_8));
+ } catch (Exception e) {
+ throw new UserVisibleError("The trustedCertificates must be a base64 encoded collection of PEM certificates", e);
+ }
+ KeyStore keyStore = StoreLoader.loadStore(Joiner.on("\n").join(trustedPems), randomUUID().toString(), randomUUID().toString());
+ TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
+ trustManagerFactory.init(keyStore);
+ return trustManagerFactory.getTrustManagers();
+
+ }
+ }
+
+ private static class CurrentToken {
+ private final TokenResponse token;
+ private final long refreshAfter;
+
+ CurrentToken(TokenResponse token, long refreshAfter) {
+ this.refreshAfter = refreshAfter;
+ this.token = token;
+ }
+ }
+
+ static class AllTrustedTrustManager implements X509TrustManager {
+ @Override
+ public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
+ //no need to check certificates if everything is trusted
+ }
+
+ @Override
+ public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
+ //no need to check certificates if everything is trusted
+ }
+
+ @Override
+ public X509Certificate[] getAcceptedIssuers() {
+ return new X509Certificate[0];
+ }
+ }
+
+ /**
+ * Represents the token received from CBAM
+ */
+ private static class TokenResponse {
+ @SerializedName("access_token")
+ String accessToken;
+ @SerializedName("expires_in")
+ int expiresIn;
+ @SerializedName("id_token")
+ String tokenId;
+ @SerializedName("not-before-policy")
+ int notBeforePolicy;
+ @SerializedName("refresh_expires_in")
+ int refreshExpiresIn;
+ @SerializedName("refresh_token")
+ String refreshToken;
+ @SerializedName("session_state")
+ String sessionState;
+ @SerializedName("token_type")
+ String tokenType;
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/DriverProperties.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/DriverProperties.java
new file mode 100644
index 00000000..d510ba25
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/DriverProperties.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.stereotype.Component;
+
+import java.util.Objects;
+
+/**
+ * Wraps the properties supplied to the servlet
+ */
+@Component
+public class DriverProperties {
+ public static final String BASE_SUFFIX = "/" + SelfRegistrationManager.SERVICE_NAME + "/v1";
+ public static final String BASE_URL = "/api" + BASE_SUFFIX;
+ public static final String LCN_URL = "/lcn";
+
+ @Value("${cbamCatalogUrl}")
+ private String cbamCatalogUrl;
+ @Value("${cbamLcnUrl}")
+ private String cbamLcnUrl;
+ @Value("${vnfmId}")
+ private String vnfmId;
+
+ /**
+ * @return the URL on which the CBAM catalog API can be accessed (ex. https://1.2.3.4:443/api/catalog/adapter )
+ */
+ public String getCbamCatalogUrl() {
+ return cbamCatalogUrl;
+ }
+
+ /**
+ * @param cbamCatalogUrl the URL on which the CBAM catalog API can be accessed (ex. https://1.2.3.4:443/api/catalog/adapter )
+ */
+ public void setCbamCatalogUrl(String cbamCatalogUrl) {
+ this.cbamCatalogUrl = cbamCatalogUrl;
+ }
+
+ /**
+ * @return the URL on which the CBAM LCN subscription API can be accessed (ex. https://1.2.3.4:443/vnfm/lcn/v3 )
+ */
+ public String getCbamLcnUrl() {
+ return cbamLcnUrl;
+ }
+
+ /**
+ * @param cbamLcnUrl the URL on which the CBAM LCN subscription API can be accessed (ex. https://1.2.3.4:443/vnfm/lcn/v3 )
+ */
+ public void setCbamLcnUrl(String cbamLcnUrl) {
+ this.cbamLcnUrl = cbamLcnUrl;
+ }
+
+ /**
+ * @return the identifier of the VNFM
+ */
+ public String getVnfmId() {
+ return vnfmId;
+ }
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ */
+ public void setVnfmId(String vnfmId) {
+ this.vnfmId = vnfmId;
+ }
+
+ @Override
+ public String toString() {
+ return "DriverProperties{" +
+ ", cbamCatalogUrl='" + cbamCatalogUrl + '\'' +
+ ", cbamLcnUrl='" + cbamLcnUrl + '\'' +
+ ", vnfmId='" + vnfmId + '\'' +
+ '}';
+ }
+
+ @Override
+ //generated code. This is the recommended way to formulate equals
+ @SuppressWarnings({"squid:S00122", "squid:S1067"})
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ DriverProperties that = (DriverProperties) o;
+ return Objects.equals(cbamCatalogUrl, that.cbamCatalogUrl) &&
+ Objects.equals(cbamLcnUrl, that.cbamLcnUrl) &&
+ Objects.equals(vnfmId, that.vnfmId);
+ }
+
+ @Override
+ public int hashCode() {
+ return Objects.hash(cbamCatalogUrl, cbamLcnUrl, vnfmId);
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/ILifecycleChangeNotificationManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/ILifecycleChangeNotificationManager.java
new file mode 100644
index 00000000..d31633dd
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/ILifecycleChangeNotificationManager.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.nokia.cbam.lcm.v32.model.VnfLifecycleChangeNotification;
+
+/**
+ * Responsible for handling CBAM notifications
+ */
+public interface ILifecycleChangeNotificationManager {
+
+ /**
+ * Transform a CBAM LCN into ONAP LCN
+ *
+ * @param receivedNotification the CBAM LCN
+ */
+ void handleLcn(VnfLifecycleChangeNotification receivedNotification);
+
+ /**
+ * Wait for the termination finish notification to be processed
+ *
+ * @param operationExecutionId the identifier of the termination operation
+ */
+ void waitForTerminationToBeProcessed(String operationExecutionId);
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/JobManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/JobManager.java
new file mode 100644
index 00000000..94cb404c
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/JobManager.java
@@ -0,0 +1,318 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.collect.Ordering;
+import com.google.common.collect.Sets;
+import com.google.gson.Gson;
+import com.google.gson.JsonElement;
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.api.OperationExecutionsApi;
+import com.nokia.cbam.lcm.v32.api.VnfsApi;
+import com.nokia.cbam.lcm.v32.model.OperationExecution;
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import org.apache.http.HttpStatus;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager;
+import org.onap.vnfmdriver.model.JobDetailInfo;
+import org.onap.vnfmdriver.model.JobDetailInfoResponseDescriptor;
+import org.onap.vnfmdriver.model.JobResponseInfo;
+import org.onap.vnfmdriver.model.JobStatus;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import javax.servlet.http.HttpServletResponse;
+import java.util.*;
+
+import static com.google.common.base.Splitter.on;
+import static com.google.common.collect.Iterables.find;
+import static com.google.common.collect.Iterables.tryFind;
+import static com.google.common.collect.Lists.newArrayList;
+import static com.nokia.cbam.lcm.v32.model.OperationStatus.FAILED;
+import static com.nokia.cbam.lcm.v32.model.OperationStatus.STARTED;
+import static java.util.Optional.empty;
+import static java.util.Optional.of;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.SEPARATOR;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.LifecycleChangeNotificationManager.NEWEST_OPERATIONS_FIRST;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.util.StringUtils.isEmpty;
+
+/**
+ * Responsible for providing the status of jobs
+ * The job id is a composite field of the VNF identifier and an UUID.
+ * The second UUID is passed as mandatory parameter to each executed operation.
+ * This UUID is used to locate the operation execution from the ONAP job identifier
+ */
+@Component
+public class JobManager {
+ public static final String OPERATION_STARTED_DESCRIPTION = "Operation started";
+ private static final Ordering<JobResponseInfo> OLDEST_FIRST = new Ordering<JobResponseInfo>() {
+ @Override
+ public int compare(JobResponseInfo left, JobResponseInfo right) {
+ return Long.valueOf(left.getResponseId()).compareTo(Long.valueOf(right.getResponseId()));
+ }
+ };
+ private static Logger logger = getLogger(JobManager.class);
+ private final Set<String> ongoingJobs = Sets.newConcurrentHashSet();
+ private final CbamRestApiProvider cbamRestApiProvider;
+ private final SelfRegistrationManager selfRegistrationManager;
+ private volatile boolean preparingForShutDown = false;
+
+ @Autowired
+ JobManager(CbamRestApiProvider cbamRestApiProvider, SelfRegistrationManager selfRegistrationManager) {
+ this.cbamRestApiProvider = cbamRestApiProvider;
+ this.selfRegistrationManager = selfRegistrationManager;
+ }
+
+ /**
+ * @param operationParams the operation execution
+ * @return the ONAP job identifier of belonging to the operation execution
+ */
+ public static String extractOnapJobId(Object operationParams) {
+ JsonElement operationParamsAsJson = new Gson().toJsonTree(operationParams);
+ JsonElement additionalParams = operationParamsAsJson.getAsJsonObject().get("additionalParams");
+ if (additionalParams == null) {
+ throw new NoSuchElementException("The operation result " + operationParamsAsJson + " does not contain the mandatory additionalParams structure");
+ }
+ JsonElement jobId = additionalParams.getAsJsonObject().get("jobId");
+ if (jobId == null) {
+ throw new NoSuchElementException("The operation result " + operationParamsAsJson + " does not contain the mandatory jobId in the additionalParams structure");
+ }
+ return jobId.getAsString();
+ }
+
+ /**
+ * Throws an exception in case the service is not ready to serve requests due to
+ * not being able to register to MSB or to subscribe to CBAM LCNs
+ *
+ * @param vnfId the identifier of the VNF
+ * @param response the HTTP response of the current sVNFM incomming request
+ * @return the identifier of the job
+ */
+ public String spawnJob(String vnfId, HttpServletResponse response) {
+ String jobId = vnfId + SEPARATOR + UUID.randomUUID().toString();
+ synchronized (this) {
+ if (preparingForShutDown) {
+ response.setStatus(HttpStatus.SC_SERVICE_UNAVAILABLE);
+ throw buildFatalFailure(logger, "The service is preparing to shut down");
+ }
+ if (!selfRegistrationManager.isReady()) {
+ response.setStatus(HttpStatus.SC_SERVICE_UNAVAILABLE);
+ throw buildFatalFailure(logger, "The service is not yet ready");
+ }
+ }
+ ongoingJobs.add(jobId);
+ return jobId;
+ }
+
+ /**
+ * Signal that a job has finished
+ *
+ * @param jobId the identifier of the job
+ */
+ public void jobFinished(String jobId) {
+ ongoingJobs.remove(jobId);
+ }
+
+ /**
+ * @return the system has any ongoing jobs
+ */
+ public boolean hasOngoingJobs() {
+ return !ongoingJobs.isEmpty();
+ }
+
+
+ /**
+ * Wait for all jobs to be cleared from the system the refuses to let additional request in
+ */
+ public void prepareForShutdown() {
+ preparingForShutDown = true;
+ while (true) {
+ synchronized (this) {
+ if (!hasOngoingJobs()) {
+ return;
+ }
+ }
+ systemFunctions().sleep(500L);
+ }
+ }
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ * @param jobId the identifier of the job
+ * @return detailed information of the job
+ */
+ public JobDetailInfo getJob(String vnfmId, String jobId) {
+ logger.debug("Retrieving the details for job with {} identifier", jobId);
+ ArrayList<String> jobParts = newArrayList(on(SEPARATOR).split(jobId));
+ if (jobParts.size() != 2) {
+ throw new IllegalArgumentException("The jobId should be in the <vnfId>" + SEPARATOR + "<UUID> format, but was " + jobId);
+ }
+ String vnfId = jobParts.get(0);
+ if (isEmpty(vnfId)) {
+ throw new IllegalArgumentException("The vnfId in the jobId (" + jobId + ") can not be empty");
+ }
+ String operationExecutionId = jobParts.get(1);
+ if (isEmpty(operationExecutionId)) {
+ throw new IllegalArgumentException("The UUID in the jobId (" + jobId + ") can not be empty");
+ }
+ Optional<VnfInfo> vnf = getVnf(vnfmId, vnfId);
+ if (!vnf.isPresent()) {
+ return getJobDetailInfoForMissingVnf(jobId);
+ } else {
+ return getJobInfoForExistingVnf(vnfmId, jobId, vnfId, vnf.get());
+ }
+ }
+
+ private JobDetailInfo getJobDetailInfoForMissingVnf(String jobId) {
+ if (ongoingJobs.contains(jobId)) {
+ return reportOngoing(jobId);
+ } else {
+ return reportFinished(jobId);
+ }
+ }
+
+ private JobDetailInfo getJobInfoForExistingVnf(String vnfmId, String jobId, String vnfId, VnfInfo vnf) {
+ try {
+ OperationExecution operation = findOperationByJobId(vnfmId, vnf, jobId);
+ return getJobDetailInfo(vnfmId, jobId, vnfId, operation);
+ } catch (NoSuchElementException e) {
+ logger.warn("No operation could be identified for job with {} identifier", jobId, e);
+ if (ongoingJobs.contains(jobId)) {
+ return reportOngoing(jobId);
+ } else {
+ return reportFailed(jobId, "The requested operation was not able to start on CBAM");
+ }
+ }
+ }
+
+ private JobDetailInfo getJobDetailInfo(String vnfmId, String jobId, String vnfId, OperationExecution operation) {
+ if (operation.getStatus() == STARTED) {
+ return reportOngoing(jobId);
+ } else if (operation.getStatus() == FAILED) {
+ return reportFailed(jobId, operation.getError().getTitle() + ": " + operation.getError().getDetail());
+ } else {
+ return getJobForTerminalOperationState(vnfmId, jobId, vnfId, operation);
+ }
+ }
+
+ private JobDetailInfo getJobForTerminalOperationState(String vnfmId, String jobId, String vnfId, OperationExecution operation) {
+ //termination includes VNF deletion in ONAP terminology
+ if (operation.getOperationType() == com.nokia.cbam.lcm.v32.model.OperationType.TERMINATE) {
+ if (ongoingJobs.contains(jobId)) {
+ return reportOngoing(jobId);
+ } else {
+ //the VNF must be queried again since it could have been deleted since the VNF has been terminated
+ if (getVnf(vnfmId, vnfId).isPresent()) {
+ return reportFailed(jobId, "unable to delete VNF");
+ } else {
+ return reportFinished(jobId);
+ }
+ }
+ } else {
+ return reportFinished(jobId);
+ }
+ }
+
+ private JobDetailInfo buildJob(String jobId, JobResponseInfo... history) {
+ JobDetailInfo job = new JobDetailInfo();
+ job.setJobId(jobId);
+ JobDetailInfoResponseDescriptor jobDetailInfoResponseDescriptor = new JobDetailInfoResponseDescriptor();
+ job.setResponseDescriptor(jobDetailInfoResponseDescriptor);
+ List<JobResponseInfo> oldestFirst = OLDEST_FIRST.sortedCopy(newArrayList(history));
+ JobResponseInfo newestJob = oldestFirst.get(oldestFirst.size() - 1);
+ jobDetailInfoResponseDescriptor.setResponseId(newestJob.getResponseId());
+ jobDetailInfoResponseDescriptor.setStatus(JobStatus.valueOf(newestJob.getStatus()));
+ jobDetailInfoResponseDescriptor.setProgress(newestJob.getProgress());
+ jobDetailInfoResponseDescriptor.setStatusDescription(newestJob.getStatusDescription());
+ jobDetailInfoResponseDescriptor.setErrorCode(newestJob.getErrorCode());
+ jobDetailInfoResponseDescriptor.setResponseHistoryList(oldestFirst);
+ return job;
+ }
+
+ private JobResponseInfo buildJobPart(String description, JobStatus status, Integer progress, Integer responseId) {
+ JobResponseInfo currentJob = new JobResponseInfo();
+ currentJob.setProgress(progress.toString());
+ currentJob.setResponseId(responseId.toString());
+ currentJob.setStatus(status.name());
+ currentJob.setStatusDescription(description);
+ return currentJob;
+ }
+
+ private JobDetailInfo reportOngoing(String jobId) {
+ return buildJob(jobId, buildJobPart(OPERATION_STARTED_DESCRIPTION, JobStatus.STARTED, 50, 1));
+ }
+
+ private JobDetailInfo reportFailed(String jobId, String reason) {
+ return buildJob(jobId,
+ buildJobPart(OPERATION_STARTED_DESCRIPTION, JobStatus.STARTED, 50, 1),
+ buildJobPart("Operation failed due to " + reason, JobStatus.ERROR, 100, 2)
+ );
+ }
+
+ private JobDetailInfo reportFinished(String jobId) {
+ return buildJob(jobId,
+ buildJobPart(OPERATION_STARTED_DESCRIPTION, JobStatus.STARTED, 50, 1),
+ buildJobPart("Operation finished", JobStatus.FINISHED, 100, 2)
+ );
+ }
+
+ private OperationExecution findOperationByJobId(String vnfmId, VnfInfo vnf, String jobId) {
+ OperationExecutionsApi cbamOperationExecutionApi = cbamRestApiProvider.getCbamOperationExecutionApi(vnfmId);
+ //the operations are sorted so that the newest operations are queried first
+ //performance optimization that usually the core system is interested in the operations executed last
+ if (vnf.getOperationExecutions() != null) {
+ List<OperationExecution> sortedOperation = NEWEST_OPERATIONS_FIRST.sortedCopy(vnf.getOperationExecutions());
+ return find(sortedOperation, operation -> isCurrentOperationTriggeredByJob(jobId, cbamOperationExecutionApi, operation));
+ }
+ throw new NoSuchElementException();
+ }
+
+ private boolean isCurrentOperationTriggeredByJob(String jobId, OperationExecutionsApi cbamOperationExecutionApi, OperationExecution operationExecution) {
+ try {
+ Object operationParams = cbamOperationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(operationExecution.getId(), NOKIA_LCM_API_VERSION);
+ if (extractOnapJobId(operationParams).equals(jobId)) {
+ return true;
+ }
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to retrieve operation parameters", e);
+ }
+ return false;
+ }
+
+ private Optional<VnfInfo> getVnf(String vnfmId, String vnfId) {
+ try {
+ //test if the VNF exists (required to be able to distingush between failed request )
+ VnfsApi cbamLcmApi = cbamRestApiProvider.getCbamLcmApi(vnfmId);
+ logger.debug("Listing VNFs");
+ List<VnfInfo> vnfs = cbamLcmApi.vnfsGet(NOKIA_LCM_API_VERSION);
+ com.google.common.base.Optional<VnfInfo> vnf = tryFind(vnfs, vnfInfo -> vnfId.equals(vnfInfo.getId()));
+ if (!vnf.isPresent()) {
+ logger.debug("VNF with {} identifier is missing", vnfId);
+ return empty();
+ } else {
+ logger.debug("VNF with {} identifier still exists", vnfId);
+ //query the VNF again to get operation execution result
+ return of(cbamLcmApi.vnfsVnfInstanceIdGet(vnfId, NOKIA_LCM_API_VERSION));
+ }
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to retrieve VNF", e);
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/LifecycleManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/LifecycleManager.java
new file mode 100644
index 00000000..79e9487d
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/LifecycleManager.java
@@ -0,0 +1,640 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+
+import com.google.gson.Gson;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonObject;
+import com.nokia.cbam.catalog.v1.model.CatalogAdapterVnfpackage;
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.model.*;
+import com.nokia.cbam.lcm.v32.model.ScaleDirection;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.IGrantManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VimInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.StoreLoader;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.UserVisibleError;
+import org.onap.vnfmdriver.model.ExtVirtualLinkInfo;
+import org.onap.vnfmdriver.model.*;
+import org.onap.vnfmdriver.model.VimInfo;
+import org.onap.vnfmdriver.model.VnfInfo;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+import org.yaml.snakeyaml.Yaml;
+
+import javax.servlet.http.HttpServletResponse;
+import java.util.*;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+
+import static com.google.common.base.Splitter.on;
+import static com.google.common.collect.Iterables.find;
+import static com.google.common.collect.Lists.newArrayList;
+import static com.google.common.collect.Sets.newHashSet;
+import static com.nokia.cbam.lcm.v32.model.InstantiationState.INSTANTIATED;
+import static com.nokia.cbam.lcm.v32.model.OperationStatus.FINISHED;
+import static com.nokia.cbam.lcm.v32.model.OperationType.INSTANTIATE;
+import static com.nokia.cbam.lcm.v32.model.VimInfo.VimInfoTypeEnum.*;
+import static java.lang.Integer.parseInt;
+import static java.nio.charset.StandardCharsets.UTF_8;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.LifecycleChangeNotificationManager.NEWEST_OPERATIONS_FIRST;
+import static org.slf4j.LoggerFactory.getLogger;
+import static org.springframework.util.StringUtils.isEmpty;
+
+/**
+ * Responsible for executing lifecycle operation on the VNF
+ */
+@Component
+public class LifecycleManager {
+ public static final String ONAP_CSAR_ID = "onapCsarId";
+ public static final long OPERATION_STATUS_POLLING_INTERVAL_IN_MS = 5000L;
+ /**
+ * The key of the CBAM VNF extension for the identifier of the VNFM in ONAP
+ */
+ public static final String EXTERNAL_VNFM_ID = "externalVnfmId";
+ public static final String SCALE_OPERATION_NAME = "scale";
+ private static Logger logger = getLogger(LifecycleManager.class);
+ private final CatalogManager catalogManager;
+ private final IGrantManager grantManager;
+ private final JobManager jobManager;
+ private final ILifecycleChangeNotificationManager notificationManager;
+ private final CbamRestApiProvider cbamRestApiProvider;
+ private final VimInfoProvider vimInfoProvider;
+
+ /**
+ * Runs asynchronous operations in the background
+ */
+ private ExecutorService executorService = Executors.newCachedThreadPool();
+
+ @Autowired
+ LifecycleManager(CatalogManager catalogManager, IGrantManager grantManager, CbamRestApiProvider restApiProvider, VimInfoProvider vimInfoProvider, JobManager jobManager, ILifecycleChangeNotificationManager notificationManager) {
+ this.vimInfoProvider = vimInfoProvider;
+ this.grantManager = grantManager;
+ this.cbamRestApiProvider = restApiProvider;
+ this.jobManager = jobManager;
+ this.notificationManager = notificationManager;
+ this.catalogManager = catalogManager;
+ }
+
+ /**
+ * @param vimId the VIM identifier
+ * @return the name of the region
+ */
+ public static String getRegionName(String vimId) {
+ return newArrayList(on(SEPARATOR).split(vimId)).get(1);
+ }
+
+ /**
+ * @param vimId the VIM identifier
+ * @return the owner of the cloud
+ */
+ public static String getCloudOwner(String vimId) {
+ return newArrayList(on(SEPARATOR).split(vimId)).get(0);
+ }
+
+ private static OperationExecution findLastInstantiation(List<OperationExecution> operationExecutions) {
+ return find(NEWEST_OPERATIONS_FIRST.sortedCopy(operationExecutions), op -> INSTANTIATE.equals(op.getOperationType()));
+ }
+
+ /**
+ * Create the VNF. It consists of the following steps
+ * <ul>
+ * <li>upload the VNF package to CBAM package (if not already there)</li>
+ * <li>create the VNF on CBAM</li>
+ * <li>modify attributes of the VNF (add onapCsarId field)</li>
+ * </ul>
+ * The rollback of the failed operation is not implemented
+ * <ul>
+ * <li>delete the VNF if error occurs before instantiation</li>
+ * <li>terminate & delete VNF if error occurs after instantiation</li>
+ * </ul>
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param csarId the identifier of the VNF package
+ * @param vnfName the name of the VNF
+ * @param description the description of the VNF
+ * @return the VNF creation result
+ */
+ public VnfCreationResult create(String vnfmId, String csarId, String vnfName, String description) {
+ logOperationInput("not yet specified", "creation", csarId);
+ try {
+ CatalogAdapterVnfpackage cbamPackage = catalogManager.preparePackageInCbam(vnfmId, csarId);
+ CreateVnfRequest vnfCreateRequest = new CreateVnfRequest();
+ vnfCreateRequest.setVnfdId(cbamPackage.getVnfdId());
+ vnfCreateRequest.setName(vnfName);
+ vnfCreateRequest.setDescription(description);
+ com.nokia.cbam.lcm.v32.model.VnfInfo vnfInfo = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsPost(vnfCreateRequest, NOKIA_LCM_API_VERSION);
+ addVnfdIdToVnfModifyableAttributeExtensions(vnfmId, vnfInfo.getId(), csarId);
+ return new VnfCreationResult(vnfInfo, cbamPackage.getVnfdId());
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to create the VNF", e);
+ }
+ }
+
+ private void logOperationInput(String vnfId, String operationName, Object payload) {
+ if (logger.isInfoEnabled()) {
+ logger.info("Starting {} operation on VNF with {} identifier with {} parameter", operationName, vnfId, new Gson().toJson(payload));
+ }
+ }
+
+ /**
+ * Instantiate the VNF
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param request the VNF instantiation request
+ * @param httpResponse the HTTP response that corresponds to the VNF instantiation request
+ * @param additionalParameters additional parameters
+ * @param vnfId thr identifier of the VNF
+ * @param vnfdId the identifier of the VNF package in CBAM
+ * @return the instantiation response
+ */
+ public VnfInstantiateResponse instantiate(String vnfmId, VnfInstantiateRequest request, HttpServletResponse httpResponse, AdditionalParameters additionalParameters, String vnfId, String vnfdId) {
+ logOperationInput(vnfId, "instantiation", request);
+ validateVimType(additionalParameters.getVimType());
+ VnfInstantiateResponse response = new VnfInstantiateResponse();
+ response.setVnfInstanceId(vnfId);
+ String vimId = getVimId(request.getAdditionalParam());
+ JobInfo spawnJob = scheduleExecution(vnfId, httpResponse, "instantiate", jobInfo ->
+ instantiateVnf(vnfmId, request, additionalParameters, vnfdId, vnfId, vimId, jobInfo)
+ );
+ response.setJobId(spawnJob.getJobId());
+ return response;
+ }
+
+ /**
+ * Instantiate (VF-C terminology) the VNF. It consists of the following steps
+ * <ul>
+ * <li>upload the VNF package to CBAM package (if not already there)</li>
+ * <li>create the VNF on CBAM</li>
+ * <li>modify attributes of the VNF (add onapCsarId field)</li>
+ * <li>asynchronously</li>
+ * <li>request grant from VF-C</li>
+ * <li>instantiate VNF on CBAM</li>
+ * <li>return VNF & job id (after create VNF on CBAM)</li>
+ * <li></li>
+ * </ul>
+ * The rollback of the failed operation is not implemented
+ * <ul>
+ * <li>delete the VNF if error occurs before instantiation</li>
+ * <li>terminate & delete VNf if error occurs after instantiation</li>
+ * </ul>
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param request the instantiation request
+ * @param httpResponse the HTTP response
+ * @return the instantiation response
+ */
+ public VnfInstantiateResponse createAndInstantiate(String vnfmId, VnfInstantiateRequest request, HttpServletResponse httpResponse) {
+ AdditionalParameters additionalParameters = convertInstantiationAdditionalParams(request.getVnfPackageId(), request.getAdditionalParam());
+ validateVimType(additionalParameters.getVimType());
+ VnfCreationResult creationResult = create(vnfmId, request.getVnfDescriptorId(), request.getVnfInstanceName(), request.getVnfInstanceDescription());
+ return instantiate(vnfmId, request, httpResponse, additionalParameters, creationResult.vnfInfo.getId(), creationResult.vnfdId);
+ }
+
+ private void instantiateVnf(String vnfmId, VnfInstantiateRequest request, AdditionalParameters additionalParameters, String vnfdId, String vnfId, String vimId, JobInfo jobInfo) throws ApiException {
+ String vnfdContent = catalogManager.getCbamVnfdContent(vnfmId, vnfdId);
+ GrantVNFResponseVim vim = grantManager.requestGrantForInstantiate(vnfmId, vnfId, vimId, request.getVnfPackageId(), additionalParameters.getInstantiationLevel(), vnfdContent, jobInfo.getJobId());
+ if (vim.getVimId() == null) {
+ throw buildFatalFailure(logger, "VF-C did not send VIM identifier in grant response");
+ }
+ VimInfo vimInfo = vimInfoProvider.getVimInfo(vim.getVimId());
+ InstantiateVnfRequest instantiationRequest = new InstantiateVnfRequest();
+ addExternalLinksToRequest(request.getExtVirtualLink(), additionalParameters, instantiationRequest, vimId);
+ instantiationRequest.getVims().add(addVim(additionalParameters, vimId, vim, vimInfo));
+ instantiationRequest.setFlavourId(getFlavorId(vnfdContent));
+ instantiationRequest.setComputeResourceFlavours(additionalParameters.getComputeResourceFlavours());
+ instantiationRequest.setGrantlessMode(true);
+ instantiationRequest.setInstantiationLevelId(additionalParameters.getInstantiationLevel());
+ instantiationRequest.setSoftwareImages(additionalParameters.getSoftwareImages());
+ instantiationRequest.setZones(additionalParameters.getZones());
+ instantiationRequest.setExtManagedVirtualLinks(additionalParameters.getExtManagedVirtualLinks());
+ for (ExtVirtualLinkData extVirtualLinkData : additionalParameters.getExtVirtualLinks()) {
+ instantiationRequest.addExtVirtualLinksItem(extVirtualLinkData);
+ }
+ JsonObject root = new Gson().toJsonTree(jobInfo).getAsJsonObject();
+ if (additionalParameters.getAdditionalParams() != null) {
+ for (Map.Entry<String, JsonElement> item : new Gson().toJsonTree(additionalParameters.getAdditionalParams()).getAsJsonObject().entrySet()) {
+ root.add(item.getKey(), item.getValue());
+ }
+ } else {
+ logger.warn("No additional parameters were specified for the operation");
+ }
+ instantiationRequest.setAdditionalParams(root);
+ OperationExecution operationExecution = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdInstantiatePost(vnfId, instantiationRequest, NOKIA_LCM_API_VERSION);
+ waitForOperationToFinish(vnfmId, vnfId, operationExecution.getId());
+ }
+
+ private com.nokia.cbam.lcm.v32.model.VimInfo addVim(AdditionalParameters additionalParameters, String vimId, GrantVNFResponseVim vim, VimInfo vimInfo) {
+ if (additionalParameters.getVimType() == OPENSTACK_V2_INFO) {
+ return buildOpenStackV2INFO(vimId, vim, vimInfo);
+
+ } else if (additionalParameters.getVimType() == OPENSTACK_V3_INFO) {
+ return buildOpenStackV3INFO(vimId, additionalParameters, vim, vimInfo);
+
+ } else {
+ //OTHER VIM TYPE is not possible
+ return buildVcloudInfo(vimId, vimInfo);
+ }
+ }
+
+ private void validateVimType(com.nokia.cbam.lcm.v32.model.VimInfo.VimInfoTypeEnum vimType) {
+ if (com.nokia.cbam.lcm.v32.model.VimInfo.VimInfoTypeEnum.OTHER_VIM_INFO.equals(vimType)) {
+ throw buildFatalFailure(logger, "Only " + OPENSTACK_V2_INFO + ", " + OPENSTACK_V3_INFO + " and " + VMWARE_VCLOUD_INFO + " is the supported VIM types");
+ }
+ }
+
+ private String getVimId(Object additionalParams) {
+ return childElement(new Gson().toJsonTree(additionalParams).getAsJsonObject(), "vimId").getAsString();
+ }
+
+ private AdditionalParameters convertInstantiationAdditionalParams(String csarId, Object additionalParams) {
+ JsonObject vnfParameters = child(child(new Gson().toJsonTree(additionalParams).getAsJsonObject(), "inputs"), "vnfs");
+ if (!vnfParameters.has(csarId)) {
+ throw buildFatalFailure(logger, "The additional parameter section does not contain setting for VNF with " + csarId + " CSAR id");
+ }
+ JsonElement additionalParamsForVnf = vnfParameters.get(csarId);
+ return new Gson().fromJson(additionalParamsForVnf, AdditionalParameters.class);
+ }
+
+ private String getFlavorId(String vnfdContent) {
+ JsonObject root = new Gson().toJsonTree(new Yaml().load(vnfdContent)).getAsJsonObject();
+ JsonObject capabilities = child(child(child(root, "topology_template"), "substitution_mappings"), "capabilities");
+ JsonObject deploymentFlavorProperties = child(child(capabilities, "deployment_flavour"), "properties");
+ return childElement(deploymentFlavorProperties, "flavour_id").getAsString();
+ }
+
+ private Set<String> getAcceptableOperationParameters(String vnfdContent, String categroryOfOperation, String operationName) {
+ JsonObject root = new Gson().toJsonTree(new Yaml().load(vnfdContent)).getAsJsonObject();
+ JsonObject interfaces = child(child(child(root, "topology_template"), "substitution_mappings"), "interfaces");
+ JsonObject additionalParameters = child(child(child(child(interfaces, categroryOfOperation), operationName), "inputs"), "additional_parameters");
+ return additionalParameters.keySet();
+ }
+
+ private void addExternalLinksToRequest(List<ExtVirtualLinkInfo> extVirtualLinks, AdditionalParameters additionalParameters, InstantiateVnfRequest instantiationRequest, String vimId) {
+ for (ExtVirtualLinkInfo extVirtualLink : extVirtualLinks) {
+ ExtVirtualLinkData cbamExternalVirtualLink = new ExtVirtualLinkData();
+ cbamExternalVirtualLink.setVimId(vimId);
+ cbamExternalVirtualLink.setResourceId(extVirtualLink.getResourceId());
+ VnfExtCpData ecp = new VnfExtCpData();
+ cbamExternalVirtualLink.setExtVirtualLinkId(extVirtualLink.getVlInstanceId());
+ cbamExternalVirtualLink.getExtCps().add(ecp);
+ ecp.setCpdId(extVirtualLink.getCpdId());
+ List<NetworkAddress> addresses = additionalParameters.getExternalConnectionPointAddresses().get(extVirtualLink.getCpdId());
+ ecp.setAddresses(addresses);
+ instantiationRequest.addExtVirtualLinksItem(cbamExternalVirtualLink);
+ }
+ }
+
+ private void addVnfdIdToVnfModifyableAttributeExtensions(String vnfmId, String vnfId, String onapCsarId) {
+ ModifyVnfInfoRequest request = new ModifyVnfInfoRequest();
+ VnfProperty onapCsarIdProperty = new VnfProperty();
+ onapCsarIdProperty.setName(ONAP_CSAR_ID);
+ onapCsarIdProperty.setValue(onapCsarId);
+ request.setExtensions(new ArrayList<>());
+ request.getExtensions().add(onapCsarIdProperty);
+ VnfProperty externalVnfmIdProperty = new VnfProperty();
+ externalVnfmIdProperty.setName(EXTERNAL_VNFM_ID);
+ externalVnfmIdProperty.setValue(vnfmId);
+ request.getExtensions().add(externalVnfmIdProperty);
+ request.setVnfConfigurableProperties(null);
+ try {
+ OperationExecution operationExecution = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdPatch(vnfId, request, NOKIA_LCM_API_VERSION);
+ waitForOperationToFinish(vnfmId, vnfId, operationExecution.getId());
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to set the " + ONAP_CSAR_ID + " property on the VNF", e);
+ }
+ }
+
+ private OPENSTACKV3INFO buildOpenStackV3INFO(String vimId, AdditionalParameters additionalParameters, GrantVNFResponseVim vim, org.onap.vnfmdriver.model.VimInfo vimInfo) {
+ OPENSTACKV3INFO openstackv3INFO = new OPENSTACKV3INFO();
+ openstackv3INFO.setVimInfoType(OPENSTACK_V3_INFO);
+ OpenStackAccessInfoV3 accessInfov3 = new OpenStackAccessInfoV3();
+ openstackv3INFO.accessInfo(accessInfov3);
+ accessInfov3.setPassword(vimInfo.getPassword());
+ accessInfov3.setDomain(additionalParameters.getDomain());
+ accessInfov3.setProject(vim.getAccessInfo().getTenant());
+ accessInfov3.setRegion(getRegionName(vimId));
+ accessInfov3.setUsername(vimInfo.getUserName());
+ EndpointInfo interfaceInfoV3 = new EndpointInfo();
+ interfaceInfoV3.setEndpoint(vimInfo.getUrl());
+ if (!isEmpty(vimInfo.getSslInsecure())) {
+ interfaceInfoV3.setSkipCertificateVerification(Boolean.parseBoolean(vimInfo.getSslInsecure()));
+ interfaceInfoV3.setSkipCertificateHostnameCheck(Boolean.parseBoolean(vimInfo.getSslInsecure()));
+ } else {
+ interfaceInfoV3.setSkipCertificateHostnameCheck(true);
+ interfaceInfoV3.setSkipCertificateVerification(true);
+ }
+ if (!interfaceInfoV3.isSkipCertificateVerification()) {
+ interfaceInfoV3.setTrustedCertificates(new ArrayList<>());
+ for (String trustedCertificate : StoreLoader.getCertifacates(vimInfo.getSslCacert())) {
+ interfaceInfoV3.getTrustedCertificates().add(trustedCertificate.getBytes(UTF_8));
+ }
+ }
+ openstackv3INFO.setInterfaceInfo(interfaceInfoV3);
+ openstackv3INFO.setId(vimId);
+ return openstackv3INFO;
+ }
+
+ private OPENSTACKV2INFO buildOpenStackV2INFO(String vimId, GrantVNFResponseVim vim, org.onap.vnfmdriver.model.VimInfo vimInfo) {
+ OPENSTACKV2INFO openstackv2INFO = new OPENSTACKV2INFO();
+ openstackv2INFO.setVimInfoType(OPENSTACK_V2_INFO);
+ OpenStackAccessInfoV2 accessInfo = new OpenStackAccessInfoV2();
+ openstackv2INFO.setAccessInfo(accessInfo);
+ accessInfo.setPassword(vimInfo.getPassword());
+ accessInfo.setTenant(vim.getAccessInfo().getTenant());
+ accessInfo.setUsername(vimInfo.getUserName());
+ accessInfo.setRegion(getRegionName(vimId));
+ EndpointInfo interfaceEndpoint = new EndpointInfo();
+ if (!isEmpty(vimInfo.getSslInsecure())) {
+ interfaceEndpoint.setSkipCertificateHostnameCheck(Boolean.parseBoolean(vimInfo.getSslInsecure()));
+ interfaceEndpoint.setSkipCertificateVerification(Boolean.parseBoolean(vimInfo.getSslInsecure()));
+ } else {
+ interfaceEndpoint.setSkipCertificateHostnameCheck(true);
+ interfaceEndpoint.setSkipCertificateVerification(true);
+ }
+ interfaceEndpoint.setEndpoint(vimInfo.getUrl());
+ if (!interfaceEndpoint.isSkipCertificateVerification()) {
+ interfaceEndpoint.setTrustedCertificates(new ArrayList<>());
+ for (String trustedCertificate : StoreLoader.getCertifacates(vimInfo.getSslCacert())) {
+ interfaceEndpoint.getTrustedCertificates().add(trustedCertificate.getBytes(UTF_8));
+ }
+ }
+ openstackv2INFO.setInterfaceInfo(interfaceEndpoint);
+ openstackv2INFO.setId(vimId);
+ return openstackv2INFO;
+ }
+
+ private VMWAREVCLOUDINFO buildVcloudInfo(String vimId, org.onap.vnfmdriver.model.VimInfo vimInfo) {
+ VMWAREVCLOUDINFO vcloudInfo = new VMWAREVCLOUDINFO();
+ vcloudInfo.setVimInfoType(VMWARE_VCLOUD_INFO);
+ VCloudAccessInfo accessInfo = new VCloudAccessInfo();
+ vcloudInfo.setAccessInfo(accessInfo);
+ accessInfo.setPassword(vimInfo.getPassword());
+ accessInfo.setUsername(vimInfo.getUserName());
+ accessInfo.setOrganization(getRegionName(vimId));
+ EndpointInfo interfaceEndpoint = new EndpointInfo();
+ if (!isEmpty(vimInfo.getSslInsecure())) {
+ interfaceEndpoint.setSkipCertificateHostnameCheck(Boolean.parseBoolean(vimInfo.getSslInsecure()));
+ interfaceEndpoint.setSkipCertificateVerification(Boolean.parseBoolean(vimInfo.getSslInsecure()));
+ } else {
+ interfaceEndpoint.setSkipCertificateHostnameCheck(true);
+ interfaceEndpoint.setSkipCertificateVerification(true);
+ }
+ interfaceEndpoint.setEndpoint(vimInfo.getUrl());
+ if (!interfaceEndpoint.isSkipCertificateVerification()) {
+ interfaceEndpoint.setTrustedCertificates(new ArrayList<>());
+ for (String trustedCertificate : StoreLoader.getCertifacates(vimInfo.getSslCacert())) {
+ interfaceEndpoint.getTrustedCertificates().add(trustedCertificate.getBytes(UTF_8));
+ }
+ }
+ vcloudInfo.setInterfaceInfo(interfaceEndpoint);
+ vcloudInfo.setId(vimId);
+ return vcloudInfo;
+ }
+
+ /**
+ * Terminates and deletes the VNF
+ * <ul>
+ * <li>fails if the VNF does not exist</li>
+ * <li>terminates if instantiated</li>
+ * <li>deletes the VNF</li>
+ * </ul>
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @param request the termination request
+ * @param httpResponse the HTTP response
+ * @return the job for polling the progress of the termination
+ */
+ public JobInfo terminateVnf(String vnfmId, String vnfId, VnfTerminateRequest request, HttpServletResponse httpResponse) {
+ logOperationInput(vnfId, "termination", request);
+ return scheduleExecution(vnfId, httpResponse, "terminate", jobInfo -> {
+ TerminateVnfRequest cbamRequest = new TerminateVnfRequest();
+ cbamRequest.setAdditionalParams(jobInfo);
+ if (request.getTerminationType() == null) {
+ cbamRequest.setTerminationType(TerminationType.FORCEFUL);
+ } else {
+ if (request.getTerminationType().equals(VnfTerminationType.GRACEFUL)) {
+ cbamRequest.setTerminationType(TerminationType.GRACEFUL);
+ cbamRequest.setGracefulTerminationTimeout(parseInt(request.getGracefulTerminationTimeout()));
+ } else {
+ cbamRequest.setTerminationType(TerminationType.FORCEFUL);
+ }
+ }
+ com.nokia.cbam.lcm.v32.model.VnfInfo vnf = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdGet(vnfId, NOKIA_LCM_API_VERSION);
+ if (vnf.getInstantiationState() == INSTANTIATED) {
+ terminateVnf(vnfmId, vnfId, jobInfo, cbamRequest, vnf);
+ } else {
+ cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdDelete(vnfId, NOKIA_LCM_API_VERSION);
+ }
+ });
+ }
+
+ private void terminateVnf(String vnfmId, String vnfId, JobInfo jobInfo, TerminateVnfRequest cbamRequest, com.nokia.cbam.lcm.v32.model.VnfInfo vnf) throws ApiException {
+ String vimId = getVimIdFromInstantiationRequest(vnfmId, vnf);
+ grantManager.requestGrantForTerminate(vnfmId, vnfId, vimId, getVnfdIdFromModifyableAttributes(vnf), vnf, jobInfo.getJobId());
+ OperationExecution terminationOperation = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdTerminatePost(vnfId, cbamRequest, NOKIA_LCM_API_VERSION);
+ OperationExecution finishedOperation = waitForOperationToFinish(vnfmId, vnfId, terminationOperation.getId());
+ if (finishedOperation.getStatus() == FINISHED) {
+ notificationManager.waitForTerminationToBeProcessed(finishedOperation.getId());
+ logger.info("Deleting VNF with {}", vnfId);
+ cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdDelete(vnfId, NOKIA_LCM_API_VERSION);
+ logger.info("VNF with {} has been deleted", vnfId);
+
+ } else {
+ logger.error("Unable to terminate VNF the operation did not finish with success");
+ }
+ }
+
+ private String getVimIdFromInstantiationRequest(String vnfmId, com.nokia.cbam.lcm.v32.model.VnfInfo vnf) throws ApiException {
+ OperationExecution lastInstantiation = findLastInstantiation(vnf.getOperationExecutions());
+ Object operationParameters = cbamRestApiProvider.getCbamOperationExecutionApi(vnfmId).operationExecutionsOperationExecutionIdOperationParamsGet(lastInstantiation.getId(), NOKIA_LCM_API_VERSION);
+ JsonObject root = new Gson().toJsonTree(operationParameters).getAsJsonObject();
+ return childElement(childElement(root, "vims").getAsJsonArray().get(0).getAsJsonObject(), "id").getAsString();
+ }
+
+ private String getVnfdIdFromModifyableAttributes(com.nokia.cbam.lcm.v32.model.VnfInfo vnf) {
+ return find(vnf.getExtensions(), p -> p.getName().equals(ONAP_CSAR_ID)).getValue().toString();
+ }
+
+ /**
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @return the current state of the VNF
+ */
+ public VnfInfo queryVnf(String vnfmId, String vnfId) {
+ try {
+ com.nokia.cbam.lcm.v32.model.VnfInfo cbamVnfInfo = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdGet(vnfId, NOKIA_LCM_API_VERSION);
+ VnfInfo vnfInfo = new VnfInfo();
+ vnfInfo.setVersion(cbamVnfInfo.getVnfSoftwareVersion());
+ vnfInfo.setVnfInstanceId(vnfId);
+ String onapCsarId = getVnfdIdFromModifyableAttributes(cbamVnfInfo);
+ vnfInfo.setVnfdId(onapCsarId);
+ vnfInfo.setVnfPackageId(onapCsarId);
+ vnfInfo.setVnfInstanceDescription(cbamVnfInfo.getDescription());
+ vnfInfo.setVnfInstanceName(cbamVnfInfo.getName());
+ vnfInfo.setVnfProvider(cbamVnfInfo.getVnfProvider());
+ vnfInfo.setVnfStatus("ACTIVE");
+ vnfInfo.setVnfType("Kuku");
+ return vnfInfo;
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to query VNF (" + vnfId + ")", e);
+ }
+ }
+
+ private ScaleDirection convert(org.onap.vnfmdriver.model.ScaleDirection direction) {
+ if (org.onap.vnfmdriver.model.ScaleDirection.IN.equals(direction)) {
+ return ScaleDirection.IN;
+ } else {
+ return ScaleDirection.OUT;
+ }
+ }
+
+ /**
+ * Scale the VNF
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @param request the scale request
+ * @param httpResponse the HTTP response
+ * @return the job for tracking the scale
+ */
+ public JobInfo scaleVnf(String vnfmId, String vnfId, VnfScaleRequest request, HttpServletResponse httpResponse) {
+ logOperationInput(vnfId, SCALE_OPERATION_NAME, request);
+ return scheduleExecution(vnfId, httpResponse, SCALE_OPERATION_NAME, jobInfo -> {
+ ScaleVnfRequest cbamRequest = new ScaleVnfRequest();
+ cbamRequest.setAspectId(request.getAspectId());
+ cbamRequest.setNumberOfSteps(Integer.valueOf(request.getNumberOfSteps()));
+ cbamRequest.setType(convert(request.getType()));
+ com.nokia.cbam.lcm.v32.model.VnfInfo vnf = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdGet(vnfId, NOKIA_LCM_API_VERSION);
+ JsonObject root = new Gson().toJsonTree(jobInfo).getAsJsonObject();
+ com.nokia.cbam.lcm.v32.model.VnfInfo cbamVnfInfo = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdGet(vnfId, NOKIA_LCM_API_VERSION);
+ String vnfdContent = catalogManager.getCbamVnfdContent(vnfmId, cbamVnfInfo.getVnfdId());
+ Set<String> acceptableOperationParameters = getAcceptableOperationParameters(vnfdContent, "Basic", SCALE_OPERATION_NAME);
+ buildAdditionalParameters(request, root, acceptableOperationParameters);
+ cbamRequest.setAdditionalParams(root);
+ grantManager.requestGrantForScale(vnfmId, vnfId, getVimIdFromInstantiationRequest(vnfmId, vnf), getVnfdIdFromModifyableAttributes(vnf), request, jobInfo.getJobId());
+ OperationExecution operationExecution = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdScalePost(vnfId, cbamRequest, NOKIA_LCM_API_VERSION);
+ waitForOperationToFinish(vnfmId, vnfId, operationExecution.getId());
+ });
+ }
+
+ private void buildAdditionalParameters(VnfScaleRequest request, JsonObject root, Set<String> acceptableOperationParameters) {
+ if (request.getAdditionalParam() != null) {
+ for (Map.Entry<String, JsonElement> item : new Gson().toJsonTree(request.getAdditionalParam()).getAsJsonObject().entrySet()) {
+ if (acceptableOperationParameters.contains(item.getKey())) {
+ root.add(item.getKey(), item.getValue());
+ }
+ }
+ } else {
+ logger.warn("No additional parameters were passed for scaling");
+ }
+ }
+
+ /**
+ * Heal the VNF
+ *
+ * @param vnfmId the identifier of the VNFM
+ * @param vnfId the identifier of the VNF
+ * @param request the heal request
+ * @param httpResponse the HTTP response
+ * @param vnfcId the identifer of thr VNFC to be healed
+ * @return the job for tracking the heal
+ */
+ public JobInfo healVnf(String vnfmId, String vnfId, VnfHealRequest request, Optional<String> vnfcId, HttpServletResponse httpResponse) {
+ logOperationInput(vnfId, "heal", request);
+ return scheduleExecution(vnfId, httpResponse, "heal", job -> {
+ HealVnfRequest cbamHealRequest = new HealVnfRequest();
+ Map<String, String> additionalParams = new HashMap<>();
+ additionalParams.put("vmName", request.getAffectedvm().getVmname());
+ additionalParams.put("action", request.getAction());
+ additionalParams.put("jobId", job.getJobId());
+ additionalParams.put("vnfcId", vnfcId.orElse("unknown"));
+ cbamHealRequest.setAdditionalParams(additionalParams);
+ com.nokia.cbam.lcm.v32.model.VnfInfo vnf = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdGet(vnfId, NOKIA_LCM_API_VERSION);
+ String vimId = getVimIdFromInstantiationRequest(vnfmId, vnf);
+ grantManager.requestGrantForHeal(vnfmId, vnfId, vimId, getVnfdIdFromModifyableAttributes(vnf), request, job.getJobId());
+ OperationExecution operationExecution = cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdHealPost(vnfId, cbamHealRequest, NOKIA_LCM_API_VERSION);
+ waitForOperationToFinish(vnfmId, vnfId, operationExecution.getId());
+ });
+ }
+
+ private JobInfo scheduleExecution(String vnfId, HttpServletResponse httpResponse, String operation, AsynchronousExecution asynchronExecution) {
+ JobInfo jobInfo = new JobInfo();
+ jobInfo.setJobId(jobManager.spawnJob(vnfId, httpResponse));
+ executorService.submit(() -> {
+ try {
+ asynchronExecution.execute(jobInfo);
+ } catch (RuntimeException e) {
+ logger.error("Unable to " + operation + " VNF with " + vnfId + " identifier", e);
+ jobManager.jobFinished(jobInfo.getJobId());
+ throw e;
+ } catch (Exception e) {
+ String msg = "Unable to " + operation + " VNF with " + vnfId + " identifier";
+ logger.error(msg, e);
+ //the job can only be signaled to be finished after the error is logged
+ jobManager.jobFinished(jobInfo.getJobId());
+ throw new UserVisibleError(msg, e);
+ }
+ jobManager.jobFinished(jobInfo.getJobId());
+ });
+ return jobInfo;
+ }
+
+ private OperationExecution waitForOperationToFinish(String vnfmId, String vnfId, String operationExecutionId) {
+ while (true) {
+ try {
+ OperationExecution operationExecution = find(cbamRestApiProvider.getCbamLcmApi(vnfmId).vnfsVnfInstanceIdOperationExecutionsGet(vnfId, NOKIA_LCM_API_VERSION), opEx -> operationExecutionId.equals(opEx.getId()));
+ if (hasOperationFinished(operationExecution)) {
+ logger.debug("Operation finished with " + operationExecution.getId());
+ return operationExecution;
+ }
+ } catch (Exception e) {
+ //swallow exception and retry
+ logger.warn("Unable to retrieve operations details", e);
+ }
+ systemFunctions().sleep(OPERATION_STATUS_POLLING_INTERVAL_IN_MS);
+ }
+ }
+
+ private boolean hasOperationFinished(OperationExecution operationExecution) {
+ return newHashSet(FINISHED, OperationStatus.FAILED).contains(operationExecution.getStatus());
+ }
+
+ @FunctionalInterface
+ private interface AsynchronousExecution {
+ void execute(JobInfo job) throws ApiException;
+
+ }
+ public static class VnfCreationResult {
+ private final com.nokia.cbam.lcm.v32.model.VnfInfo vnfInfo;
+ private final String vnfdId;
+ VnfCreationResult(com.nokia.cbam.lcm.v32.model.VnfInfo vnfInfo, String vnfdId) {
+ this.vnfInfo = vnfInfo;
+ this.vnfdId = vnfdId;
+ }
+
+ public com.nokia.cbam.lcm.v32.model.VnfInfo getVnfInfo() {
+ return vnfInfo;
+ }
+
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/LifecycleChangeNotificationManager.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/LifecycleChangeNotificationManager.java
new file mode 100644
index 00000000..6a31e833
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/LifecycleChangeNotificationManager.java
@@ -0,0 +1,232 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import com.google.common.annotations.VisibleForTesting;
+import com.google.common.collect.Ordering;
+import com.google.gson.Gson;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.api.OperationExecutionsApi;
+import com.nokia.cbam.lcm.v32.api.VnfsApi;
+import com.nokia.cbam.lcm.v32.model.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.INotificationSender;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.ILifecycleChangeNotificationManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import java.util.List;
+import java.util.Optional;
+import java.util.Set;
+
+import static com.google.common.collect.Iterables.find;
+import static com.google.common.collect.Iterables.tryFind;
+import static com.google.common.collect.Sets.newConcurrentHashSet;
+import static com.google.common.collect.Sets.newHashSet;
+import static com.nokia.cbam.lcm.v32.model.OperationType.INSTANTIATE;
+import static java.util.Optional.empty;
+import static java.util.Optional.of;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.buildFatalFailure;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.childElement;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCN_API_VERSION;
+import static org.slf4j.LoggerFactory.getLogger;
+
+/**
+ * Responsible for handling lifecycle change notifications from CBAM.
+ * The received LCNs are transformed into ONAP LCNs.
+ * The following CBAM LCNs are processed:
+ * - HEAL
+ * - INSTANTIATE
+ * - SCALE
+ * - TERMINATE
+ * The current limitations
+ * - if a LCN can not be be processed due to VNF having been deleted the problem is logged and CBAM is notified that
+ * the LCN has been processed (even if not in reality) because the signaling of failed LCN delivery blocks the delivery
+ * on all LCN deliveries. The consequence of this is that the information known by VF-C / A&AI may be inconsistent with
+ * reality (VNF having been deleted)
+ */
+@Component
+public class LifecycleChangeNotificationManager implements ILifecycleChangeNotificationManager {
+
+ public static final String PROBLEM = "All operations must return the { \"operationResult\" : { \"cbam_pre\" : [<fillMeOut>], \"cbam_post\" : [<fillMeOut>] } } structure";
+ /**
+ * Order the operations by start time (latest first)
+ */
+ public static final Ordering<OperationExecution> NEWEST_OPERATIONS_FIRST = new Ordering<OperationExecution>() {
+ @Override
+ public int compare(OperationExecution left, OperationExecution right) {
+ return right.getStartTime().toLocalDate().compareTo(left.getStartTime().toLocalDate());
+ }
+ };
+ /**
+ * < Separates the VNF id and the resource id within a VNF
+ */
+ private static final Set<OperationStatus> terminalStatus = newHashSet(OperationStatus.FINISHED, OperationStatus.FAILED);
+ private static Logger logger = getLogger(LifecycleChangeNotificationManager.class);
+
+ private final CbamRestApiProvider restApiProvider;
+ private final DriverProperties driverProperties;
+ private final INotificationSender notificationSender;
+ private Set<ProcessedNotification> processedNotifications = newConcurrentHashSet();
+
+ @Autowired
+ LifecycleChangeNotificationManager(CbamRestApiProvider restApiProvider, DriverProperties driverProperties, INotificationSender notificationSender) {
+ this.notificationSender = notificationSender;
+ this.driverProperties = driverProperties;
+ this.restApiProvider = restApiProvider;
+ }
+
+ /**
+ * @param status the status of the operation
+ * @return has the operation finished
+ */
+ public static boolean isTerminal(OperationStatus status) {
+ return terminalStatus.contains(status);
+ }
+
+ @VisibleForTesting
+ static OperationExecution findLastInstantiationBefore(List<OperationExecution> operationExecutions, OperationExecution currentOperation) {
+ return find(NEWEST_OPERATIONS_FIRST.sortedCopy(operationExecutions), (OperationExecution opex2) ->
+ !opex2.getStartTime().isAfter(currentOperation.getStartTime())
+ && INSTANTIATE.equals(opex2.getOperationType()));
+ }
+
+ @Override
+ public void handleLcn(VnfLifecycleChangeNotification receivedNotification) {
+ if (logger.isInfoEnabled()) {
+ logger.info("Received LCN: {}", new Gson().toJson(receivedNotification));
+ }
+ VnfsApi cbamLcmApi = restApiProvider.getCbamLcmApi(driverProperties.getVnfmId());
+ try {
+ List<VnfInfo> vnfs = cbamLcmApi.vnfsGet(NOKIA_LCM_API_VERSION);
+ com.google.common.base.Optional<VnfInfo> currentVnf = tryFind(vnfs, vnf -> vnf.getId().equals(receivedNotification.getVnfInstanceId()));
+ String vnfHeader = "The VNF with " + receivedNotification.getVnfInstanceId() + " identifier";
+ if (!currentVnf.isPresent()) {
+ logger.warn(vnfHeader + " disappeared before being able to process the LCN");
+ //swallow LCN
+ return;
+ } else {
+ VnfInfo vnf = cbamLcmApi.vnfsVnfInstanceIdGet(receivedNotification.getVnfInstanceId(), NOKIA_LCN_API_VERSION);
+ com.google.common.base.Optional<VnfProperty> externalVnfmId = tryFind(vnf.getExtensions(), prop -> prop.getName().equals(LifecycleManager.EXTERNAL_VNFM_ID));
+ if (!externalVnfmId.isPresent()) {
+ logger.warn(vnfHeader + " is not a managed VNF");
+ return;
+ }
+ if (!externalVnfmId.get().getValue().equals(driverProperties.getVnfmId())) {
+ logger.warn(vnfHeader + " is not a managed by the VNFM with id " + externalVnfmId.get().getValue());
+ return;
+ }
+ }
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to list VNFs / query VNF", e);
+ }
+ OperationExecutionsApi cbamOperationExecutionApi = restApiProvider.getCbamOperationExecutionApi(driverProperties.getVnfmId());
+ try {
+ List<OperationExecution> operationExecutions = cbamLcmApi.vnfsVnfInstanceIdOperationExecutionsGet(receivedNotification.getVnfInstanceId(), NOKIA_LCM_API_VERSION);
+ OperationExecution operationExecution = cbamOperationExecutionApi.operationExecutionsOperationExecutionIdGet(receivedNotification.getLifecycleOperationOccurrenceId(), NOKIA_LCM_API_VERSION);
+ OperationExecution closestInstantiationToOperation = findLastInstantiationBefore(operationExecutions, operationExecution);
+ String vimId = getVimId(cbamOperationExecutionApi, closestInstantiationToOperation);
+ notificationSender.processNotification(receivedNotification, operationExecution, buildAffectedCps(operationExecution), vimId);
+ if (isTerminationFinished(receivedNotification)) {
+ //signal LifecycleManager to continue the deletion of the VNF
+ processedNotifications.add(new ProcessedNotification(receivedNotification.getLifecycleOperationOccurrenceId(), receivedNotification.getStatus()));
+ }
+ } catch (ApiException e) {
+ throw buildFatalFailure(logger, "Unable to retrieve the current VNF " + receivedNotification.getVnfInstanceId(), e);
+ }
+ }
+
+ private boolean isTerminationFinished(VnfLifecycleChangeNotification receivedNotification) {
+ return OperationType.TERMINATE.equals(receivedNotification.getOperation()) && terminalStatus.contains(receivedNotification.getStatus());
+ }
+
+ private String getVimId(OperationExecutionsApi cbamOperationExecutionApi, OperationExecution closestInstantiationToOperation) {
+ try {
+ Object operationParams = cbamOperationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(closestInstantiationToOperation.getId(), NOKIA_LCM_API_VERSION);
+ return getVimId(operationParams);
+ } catch (Exception e) {
+ throw buildFatalFailure(logger, "Unable to detect last instantiation operation", e);
+ }
+ }
+
+ @Override
+ public void waitForTerminationToBeProcessed(String operationExecutionId) {
+ while (true) {
+ com.google.common.base.Optional<ProcessedNotification> notification = tryFind(processedNotifications, processedNotification -> processedNotification.getOperationExecutionId().equals(operationExecutionId));
+ if (notification.isPresent()) {
+ processedNotifications.remove(notification.get());
+ return;
+ }
+ SystemFunctions.systemFunctions().sleep(500);
+ }
+ }
+
+ private String getVimId(Object instantiationParameters) {
+ InstantiateVnfRequest request = new Gson().fromJson(new Gson().toJson(instantiationParameters), InstantiateVnfRequest.class);
+ return request.getVims().get(0).getId();
+ }
+
+ private Optional<ReportedAffectedConnectionPoints> buildAffectedCps(OperationExecution operationExecution) {
+ if (operationExecution.getOperationType() == OperationType.TERMINATE) {
+ String terminationType = childElement(new Gson().toJsonTree(operationExecution.getOperationParams()).getAsJsonObject(), "terminationType").getAsString();
+ if (TerminationType.FORCEFUL.name().equals(terminationType)) {
+ //in case of force full termination the Ansible is not executed, so the connection points can not be
+ //calculated from operation execution result
+ logger.warn("Unable to send information related to affected connection points during forceful termination");
+ return empty();
+ }
+ }
+ try {
+ JsonElement root = new Gson().toJsonTree(operationExecution.getAdditionalData());
+ if (root.getAsJsonObject().has("operationResult")) {
+ JsonObject operationResult = root.getAsJsonObject().get("operationResult").getAsJsonObject();
+ if (isAbsent(operationResult, "cbam_pre") ||
+ isAbsent(operationResult, "cbam_post")) {
+ return handleFailure(operationExecution, null);
+ } else {
+ return of(new Gson().fromJson(operationResult, ReportedAffectedConnectionPoints.class));
+ }
+ } else {
+ return handleFailure(operationExecution, null);
+ }
+ } catch (Exception e) {
+ return handleFailure(operationExecution, e);
+ }
+ }
+
+ private boolean isAbsent(JsonObject operationResult, String key) {
+ return !operationResult.has(key) || !operationResult.get(key).isJsonArray();
+ }
+
+ private Optional<ReportedAffectedConnectionPoints> handleFailure(OperationExecution operationExecution, Exception e) {
+ if (operationExecution.getStatus() == OperationStatus.FAILED) {
+ logger.warn("The operation failed and the affected connection points were not reported");
+ return empty();
+ } else {
+ if (e != null) {
+ throw buildFatalFailure(logger, PROBLEM, e);
+ }
+ throw buildFatalFailure(logger, PROBLEM);
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ProcessedNotification.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ProcessedNotification.java
new file mode 100644
index 00000000..8f91604e
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ProcessedNotification.java
@@ -0,0 +1,87 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import com.nokia.cbam.lcm.v32.model.OperationStatus;
+
+import java.util.Objects;
+
+/**
+ * Represents a notification successfully processed by the {@link LifecycleChangeNotificationManager}
+ */
+class ProcessedNotification {
+ private String operationExecutionId;
+ //do not remove field the {@link LifecycleChangeNotificationManager} uses the equals
+ // method to compare notifications
+ private OperationStatus status;
+
+ ProcessedNotification(String operationExecutionId, OperationStatus status) {
+ this.operationExecutionId = operationExecutionId;
+ this.status = status;
+ }
+
+ /**
+ * @return the identifier of the operation
+ */
+ public String getOperationExecutionId() {
+ return operationExecutionId;
+ }
+
+ /**
+ * @param operationExecutionId the identifier of the operation
+ */
+ public void setOperationExecutionId(String operationExecutionId) {
+ this.operationExecutionId = operationExecutionId;
+ }
+
+ /**
+ * @return the status of the operation
+ */
+ public OperationStatus getStatus() {
+ return status;
+ }
+
+ /**
+ * @param status the status of the operation
+ */
+ public void setStatus(OperationStatus status) {
+ this.status = status;
+ }
+
+ @Override
+ //generated code. This is the recommended way to formulate equals
+ @SuppressWarnings({"squid:S00122", "squid:S1067"})
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ ProcessedNotification that = (ProcessedNotification) o;
+ return Objects.equals(operationExecutionId, that.operationExecutionId) &&
+ status == that.status;
+ }
+
+ @Override
+ public int hashCode() {
+ return Objects.hash(operationExecutionId, status);
+ }
+
+ @Override
+ public String toString() {
+ return "ProcessedNotification{" +
+ "operationExecutionId=" + operationExecutionId + '"' +
+ ", status=" + status +
+ '}';
+ }
+}
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedConnectionPoints.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedConnectionPoints.java
new file mode 100644
index 00000000..7bd79435
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedConnectionPoints.java
@@ -0,0 +1,85 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import com.google.gson.annotations.SerializedName;
+
+import java.util.HashSet;
+import java.util.Objects;
+import java.util.Set;
+
+/**
+ * The connection points reported by each operation
+ */
+public class ReportedAffectedConnectionPoints {
+ @SerializedName("cbam_pre")
+ private Set<ReportedAffectedCp> pre = new HashSet<>();
+ @SerializedName("cbam_post")
+ private Set<ReportedAffectedCp> post = new HashSet<>();
+
+ /**
+ * @return the connection points that were present after the operation has finished
+ */
+ public Set<ReportedAffectedCp> getPost() {
+ return post;
+ }
+
+ /**
+ * @param post the connection points that were present after the operation has finished
+ */
+ public void setPost(Set<ReportedAffectedCp> post) {
+ this.post = post;
+ }
+
+ /**
+ * @return the connection points that were present before the operation was started
+ */
+ public Set<ReportedAffectedCp> getPre() {
+ return pre;
+ }
+
+ /**
+ * @param pre the connection points that were present before the operation was started
+ */
+ public void setPre(Set<ReportedAffectedCp> pre) {
+ this.pre = pre;
+ }
+
+ @Override
+ //generated code. This is the recommended way to formulate equals
+ @SuppressWarnings({"squid:S00122", "squid:S1067"})
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ ReportedAffectedConnectionPoints that = (ReportedAffectedConnectionPoints) o;
+ return Objects.equals(pre, that.pre) &&
+ Objects.equals(post, that.post);
+ }
+
+ @Override
+ public int hashCode() {
+
+ return Objects.hash(pre, post);
+ }
+
+ @Override
+ public String toString() {
+ return "ReportedAffectedConnectionPoints{" +
+ "pre=" + pre +
+ ", post=" + post +
+ '}';
+ }
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedCp.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedCp.java
new file mode 100644
index 00000000..c9d87bfa
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/ReportedAffectedCp.java
@@ -0,0 +1,214 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import java.util.Objects;
+
+/**
+ * Represent a single port change in the VNF
+ */
+public class ReportedAffectedCp {
+ private String providerId;
+ private String cpdId;
+ private String ecpdId;
+ private String cpId; //the location of the resource in the Heat stack
+ private String tenantId;
+ private String ipAddress;
+ private String macAddress;
+ private String serverProviderId;
+ private String name;
+ private String networkProviderId;
+
+ /**
+ * @return the provider id of the port
+ */
+ public String getProviderId() {
+ return providerId;
+ }
+
+ /**
+ * @param providerId the provider id of the port
+ */
+ public void setProviderId(String providerId) {
+ this.providerId = providerId;
+ }
+
+ /**
+ * @return the identifier of the connection point of the port (may be null)
+ */
+ public String getCpdId() {
+ return cpdId;
+ }
+
+ /**
+ * @param cpdId the identifier of the connection point of the port (may be null)
+ */
+ public void setCpdId(String cpdId) {
+ this.cpdId = cpdId;
+ }
+
+ /**
+ * @return the identifier of the external connection point of the port (may be null)
+ */
+ public String getEcpdId() {
+ return ecpdId;
+ }
+
+ /**
+ * @param ecpdId the identifier of the connection point of the port (may be null)
+ */
+ public void setEcpdId(String ecpdId) {
+ this.ecpdId = ecpdId;
+ }
+
+ /**
+ * @return the identifier of the connection point instance of the port
+ */
+ public String getCpId() {
+ return cpId;
+ }
+
+ /**
+ * @param cpId the identifier of the connection point instance of the port
+ */
+ public void setCpId(String cpId) {
+ this.cpId = cpId;
+ }
+
+ /**
+ * @return the identifier of the tenant owning the port
+ */
+ public String getTenantId() {
+ return tenantId;
+ }
+
+ /**
+ * @param tenantId the identifier of the tenant owning the port
+ */
+ public void setTenantId(String tenantId) {
+ this.tenantId = tenantId;
+ }
+
+ /**
+ * @return the IP address of the port (may be null)
+ */
+ public String getIpAddress() {
+ return ipAddress;
+ }
+
+ /**
+ * @param ipAddress the IP address of the port (may be null)
+ */
+ public void setIpAddress(String ipAddress) {
+ this.ipAddress = ipAddress;
+ }
+
+ /**
+ * @return the MAC address of the port
+ */
+ public String getMacAddress() {
+ return macAddress;
+ }
+
+ /**
+ * @param macAddress the MAC address of the port
+ */
+ public void setMacAddress(String macAddress) {
+ this.macAddress = macAddress;
+ }
+
+ /**
+ * @return the provider id of the server to which the port is attached to (may be null)
+ */
+ public String getServerProviderId() {
+ return serverProviderId;
+ }
+
+ /**
+ * @param serverProviderId the provider id of the server to which the port is attached to (may be null)
+ */
+ public void setServerProviderId(String serverProviderId) {
+ this.serverProviderId = serverProviderId;
+ }
+
+ /**
+ * @return the name of the port (may be null)
+ */
+ public String getName() {
+ return name;
+ }
+
+ /**
+ * @param name the name of the port
+ */
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ /**
+ * @return the provider id of the network of the port
+ */
+ public String getNetworkProviderId() {
+ return networkProviderId;
+ }
+
+ /**
+ * @param networkProviderId the provider id of the network of the port
+ */
+ public void setNetworkProviderId(String networkProviderId) {
+ this.networkProviderId = networkProviderId;
+ }
+
+ @Override
+ public String toString() {
+ return "ReportedAffectedCp{" +
+ "providerId='" + providerId + '\'' +
+ ", cpdId='" + cpdId + '\'' +
+ ", ecpdId='" + ecpdId + '\'' +
+ ", cpId='" + cpId + '\'' +
+ ", tenantId='" + tenantId + '\'' +
+ ", ipAddress='" + ipAddress + '\'' +
+ ", macAddress='" + macAddress + '\'' +
+ ", serverProviderId='" + serverProviderId + '\'' +
+ ", name='" + name + '\'' +
+ ", networkProviderId='" + networkProviderId + '\'' +
+ '}';
+ }
+
+ @Override
+ //generated code. This is the recommended way to formulate equals
+ @SuppressWarnings({"squid:S00122", "squid:S1067"})
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ ReportedAffectedCp that = (ReportedAffectedCp) o;
+ return Objects.equals(providerId, that.providerId) &&
+ Objects.equals(cpdId, that.cpdId) &&
+ Objects.equals(ecpdId, that.ecpdId) &&
+ Objects.equals(cpId, that.cpId) &&
+ Objects.equals(tenantId, that.tenantId) &&
+ Objects.equals(ipAddress, that.ipAddress) &&
+ Objects.equals(macAddress, that.macAddress) &&
+ Objects.equals(serverProviderId, that.serverProviderId) &&
+ Objects.equals(name, that.name) &&
+ Objects.equals(networkProviderId, that.networkProviderId);
+ }
+
+ @Override
+ public int hashCode() {
+ return Objects.hash(providerId, cpdId, ecpdId, cpId, tenantId, ipAddress, macAddress, serverProviderId, name, networkProviderId);
+ }
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/package-info.java b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/package-info.java
new file mode 100644
index 00000000..eb4ca242
--- /dev/null
+++ b/nokiav2/driver/src/main/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/package-info.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/**
+ * Handles the interactions with the VNFM.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
diff --git a/nokiav2/driver/src/main/resources/MainServiceTemplate.meta b/nokiav2/driver/src/main/resources/MainServiceTemplate.meta
new file mode 100644
index 00000000..01f85b17
--- /dev/null
+++ b/nokiav2/driver/src/main/resources/MainServiceTemplate.meta
@@ -0,0 +1,7 @@
+metadata:
+ vnf_product_name: VNF_PRODUCT_NAME
+ vnf_provider_id: Nokia
+ vnf_package_version: VNF_PACKAGE_VERSION
+ vnf_release_data_time: 2017.01.01T10:00+03:00
+
+source: MainServiceTemplate.yaml \ No newline at end of file
diff --git a/nokiav2/driver/src/main/resources/TOSCA.meta b/nokiav2/driver/src/main/resources/TOSCA.meta
new file mode 100644
index 00000000..5cb64478
--- /dev/null
+++ b/nokiav2/driver/src/main/resources/TOSCA.meta
@@ -0,0 +1,4 @@
+TOSCA-Meta-Version: 1.0
+CSAR-Version: 1.0
+Created-By: Kuku
+Entry-Definitions: Definitions/MainServiceTemplate.yaml
diff --git a/nokiav2/driver/src/main/resources/cbam.collectConnectionPoints.js b/nokiav2/driver/src/main/resources/cbam.collectConnectionPoints.js
new file mode 100644
index 00000000..c721c935
--- /dev/null
+++ b/nokiav2/driver/src/main/resources/cbam.collectConnectionPoints.js
@@ -0,0 +1,57 @@
+var collectConnectionPoints = function(resourceModel, diff) {
+ return collectPorts(resourceModel, diff)
+};
+
+function collectPorts(resourceModel, diff){
+ pathToResource = {}
+ collectResources('', resourceModel, pathToResource, true);
+ transformedPorts = []
+ Object.keys(pathToResource).forEach(function (path) {
+ var port = pathToResource[path];
+ transformedPort = {}
+ transformedPort.name = port.attributes.name;
+ transformedPort.providerId = port.attributes.id;
+ transformedPort.cpId = path;
+ var managedPort = false;
+ if(port.hasOwnProperty('externalConnectionPoint')){
+ transformedPort.ecpdId = port.externalConnectionPoint;
+ managedPort = true;
+ }
+ if(port.hasOwnProperty('connectionPoint')){
+ transformedPort.cpdId = port.connectionPoint;
+ managedPort = true;
+ }
+ transformedPort.tenantId = port.attributes.tenant_id;
+ transformedPort.ipAddress = port.attributes.fixed_ips[0].ip_address;
+ transformedPort.macAddress = port.attributes.mac_address;
+ transformedPort.serverProviderId = port.attributes.device_id;
+ transformedPort.networkProviderId = port.attributes.network_id;
+ if(managedPort){
+ transformedPorts.push(transformedPort)
+ }
+ })
+ return transformedPorts;
+};
+
+function contains(resourceChanges, path){
+ var keys = Object.keys(resourceChanges);
+ return keys.indexOf(path) !== -1;
+}
+
+function collectResources(path, root, pathToResouceMap, onResources){
+ root && Object.keys(root).forEach(function(item) {
+ if(item == 'resource_type' && root[item] == 'OS::Neutron::Port'){
+ pathToResouceMap[path] = root
+ }
+ else if(typeof root[item] === "object"){
+ var newItem = onResources ? "" : item;
+ var newPath = path;
+ if('' != newItem && path != ''){
+ newPath += ".";
+ }
+ newPath += newItem;
+ collectResources(newPath, root[item], pathToResouceMap, !onResources)
+ }
+ });
+};
+
diff --git a/nokiav2/driver/src/main/resources/cbam.post.collectConnectionPoints.js b/nokiav2/driver/src/main/resources/cbam.post.collectConnectionPoints.js
new file mode 100644
index 00000000..c70d36ed
--- /dev/null
+++ b/nokiav2/driver/src/main/resources/cbam.post.collectConnectionPoints.js
@@ -0,0 +1,4 @@
+return {
+ "cbam_post" : collectConnectionPoints($.resource_model, $.model_diff),
+ "cbam_pre" : $.operation_result.cbam_pre
+ }
diff --git a/nokiav2/driver/src/main/resources/cbam.pre.collectConnectionPoints.js b/nokiav2/driver/src/main/resources/cbam.pre.collectConnectionPoints.js
new file mode 100644
index 00000000..64153a20
--- /dev/null
+++ b/nokiav2/driver/src/main/resources/cbam.pre.collectConnectionPoints.js
@@ -0,0 +1 @@
+return { "cbam_pre" : collectConnectionPoints($.resource_model, $.model_diff) }
diff --git a/nokiav2/driver/src/main/resources/self.swagger.json b/nokiav2/driver/src/main/resources/self.swagger.json
new file mode 100644
index 00000000..f8d24a0b
--- /dev/null
+++ b/nokiav2/driver/src/main/resources/self.swagger.json
@@ -0,0 +1,798 @@
+{
+ "basePath": "/api/NokiaSVNFM/v1",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "schemes": [
+ "http"
+ ],
+ "swagger": "2.0",
+ "info": {
+ "contact": {
+ "email": "onap-discuss@lists.onap.org",
+ "name": "Nokia team",
+ "url": "https://gerrit.onap.org/r/#/admin/projects/vfc/nfvo/lcm"
+ },
+ "description": "ONAP Nokia CBAM Driver API.",
+ "title": "ONAP Nokia CBAM Driver API",
+ "version": "1.0.0"
+ },
+ "definitions": {
+ "JobDetailInfo": {
+ "properties": {
+ "jobId": {
+ "type": "string"
+ },
+ "responseDescriptor": {
+ "properties": {
+ "errorCode": {
+ "type": "string"
+ },
+ "progress": {
+ "description": "The progress of the job. Value between 0 and 100.",
+ "type": "string"
+ },
+ "responseHistoryList": {
+ "items": {
+ "$ref": "#/definitions/jobResponseInfo"
+ },
+ "type": "array"
+ },
+ "responseId": {
+ "type": "string"
+ },
+ "status": {
+ "$ref": "#/definitions/JobStatus",
+ "description": "The status of the job"
+ },
+ "statusDescription": {
+ "description": "The reason of the current status of the job.",
+ "type": "string"
+ }
+ },
+ "type": "object"
+ }
+ },
+ "type": "object"
+ },
+ "JobInfo": {
+ "properties": {
+ "jobId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "JobStatus": {
+ "description": "The status of the job",
+ "enum": [
+ "started",
+ "processing",
+ "finished",
+ "error",
+ "timeout"
+ ],
+ "type": "string"
+ },
+ "ScaleDirection": {
+ "description": "The direction of the scaling",
+ "enum": [
+ "SCALE_IN",
+ "SCALE_OUT"
+ ],
+ "type": "string"
+ },
+ "VimInfo": {
+ "properties": {
+ "createTime": {
+ "description": "vim info createTime",
+ "type": "string"
+ },
+ "description": {
+ "description": "vim description",
+ "type": "string"
+ },
+ "name": {
+ "description": "vim name",
+ "type": "string"
+ },
+ "password": {
+ "description": "vim login password",
+ "type": "string"
+ },
+ "sslCacert": {
+ "description": "The collection of trusted certificates towards the VIM connection.",
+ "type": "string"
+ },
+ "sslInsecure": {
+ "description": "Whether to verify VIM's certificate",
+ "type": "string"
+ },
+ "status": {
+ "description": "The status of external system",
+ "type": "string"
+ },
+ "type": {
+ "description": "vim type",
+ "type": "string"
+ },
+ "url": {
+ "description": "vim url",
+ "type": "string"
+ },
+ "userName": {
+ "description": "vim login username",
+ "type": "string"
+ },
+ "vendor": {
+ "description": "vendor name",
+ "type": "string"
+ },
+ "version": {
+ "description": "vim version",
+ "type": "string"
+ },
+ "vimId": {
+ "description": "vim Id",
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "VnfHealRequest": {
+ "properties": {
+ "action": {
+ "type": "string"
+ },
+ "affectedvm": {
+ "properties": {
+ "vduid": {
+ "type": "string"
+ },
+ "vimid": {
+ "type": "string"
+ },
+ "vmname": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ }
+ },
+ "type": "object"
+ },
+ "VnfInfo": {
+ "properties": {
+ "version": {
+ "type": "string"
+ },
+ "vnfInstanceDescription": {
+ "type": "string"
+ },
+ "vnfId": {
+ "type": "string"
+ },
+ "vnfInstanceName": {
+ "type": "string"
+ },
+ "vnfPackageId": {
+ "type": "string"
+ },
+ "vnfProvider": {
+ "type": "string"
+ },
+ "vnfStatus": {
+ "type": "string"
+ },
+ "vnfType": {
+ "type": "string"
+ },
+ "vnfdId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "VnfInstInfo": {
+ "properties": {
+ "vnfId": {
+ "description": "VNF instance ID",
+ "type": "string"
+ },
+ "vnfInstanceName": {
+ "description": "VNF instance name",
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "VnfInstListInfo": {
+ "items": {
+ "$ref": "#/definitions/VnfInstInfo"
+ },
+ "type": "array"
+ },
+ "VnfInstantiateRequest": {
+ "properties": {
+ "additionalParam": {
+ "type": "object"
+ },
+ "extVirtualLink": {
+ "items": {
+ "$ref": "#/definitions/extVirtualLinkInfo"
+ },
+ "type": "array"
+ },
+ "vnfDescriptorId": {
+ "type": "string"
+ },
+ "vnfInstanceDescription": {
+ "type": "string"
+ },
+ "vnfInstanceName": {
+ "type": "string"
+ },
+ "vnfPackageId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "VnfInstantiateResponse": {
+ "properties": {
+ "jobId": {
+ "type": "string"
+ },
+ "vnfId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "VnfScaleRequest": {
+ "properties": {
+ "additionalParam": {
+ "description": "Additional parameters passed by the NFVO as input to the scaling process, specific to the VNF being scaled",
+ "type": "object"
+ },
+ "aspectId": {
+ "description": "Identifies the aspect of the VNF that is requested to be scaled",
+ "type": "string"
+ },
+ "numberOfSteps": {
+ "description": "Number of scaling steps to be executed as part of this ScaleVnf operation. It shall be a positive number",
+ "type": "string"
+ },
+ "type": {
+ "$ref": "#/definitions/ScaleDirection",
+ "description": "The direction of the scaling."
+ }
+ },
+ "type": "object"
+ },
+ "VnfTerminateRequest": {
+ "properties": {
+ "gracefulTerminationTimeout": {
+ "description": "The time interval(second) to wait for the VNF to be taken out of service during graceful termination.",
+ "type": "string"
+ },
+ "terminationType": {
+ "$ref": "#/definitions/VnfTerminationType",
+ "description": "The type of the termination"
+ }
+ },
+ "type": "object"
+ },
+ "VnfTerminationType": {
+ "description": "The type of the termination.",
+ "enum": [
+ "graceful",
+ "forceful"
+ ],
+ "type": "string"
+ },
+ "extVirtualLinkInfo":{
+ "type": "object",
+ "properties": {
+ "resourceSubnetId": {
+ "type": "string",
+ "description": "The provider id of the subnet"
+ },
+ "vlInstanceId": {
+ "type": "string",
+ "description" : "The identifier of the virtual link"
+ },
+ "resourceId": {
+ "type": "string",
+ "description": "The provider id of the network"
+ },
+ "cpdId": {
+ "type": "string",
+ "description": "The identifier of the connection point descriptor"
+ },
+ "vim": {
+ "type": "object",
+ "properties": {
+ "vimid": {
+ "type": "string",
+ "description": "The identifier of the VIM"
+ }
+ }
+ }
+ }
+ },
+ "jobResponseInfo": {
+ "properties": {
+ "errorCode": {
+ "type": "string"
+ },
+ "progress": {
+ "type": "string"
+ },
+ "responseId": {
+ "type": "string"
+ },
+ "status": {
+ "type": "string"
+ },
+ "statusDescription": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "vimInfo": {
+ "properties": {
+ "accessInfo": {
+ "properties": {
+ "password": {
+ "description": "Password of login user",
+ "type": "string"
+ },
+ "tenant": {
+ "description": "Tenant Name of tenant",
+ "type": "string"
+ },
+ "username": {
+ "description": "Username for login",
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "interfaceEndpoint": {
+ "description": "Information about the interface endpoint. It is a URL",
+ "type": "string"
+ },
+ "interfaceInfo": {
+ "properties": {
+ "apiVersion": {
+ "description": "The api Version Type value will be ",
+ "type": "string"
+ },
+ "protocolType": {
+ "description": "The protocol Type value will be http or https",
+ "type": "string"
+ },
+ "vimType": {
+ "description": "The vim Type value wil be openstack",
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "vimId": {
+ "type": "string"
+ },
+ "vimInfoId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "VnfLifecycleChangeNotification": {
+ "type": "object",
+ "description": "The lifecycle change notifications send from CBAM"
+ }
+ },
+ "paths": {
+ "/{vnfmId}/vnfs": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "VNF create&instantiate Rest API should be provided by the VNFM Driver",
+ "operationId": "vnf_instantiate",
+ "parameters": [
+ {
+ "description": "The value of vnfmid should be the VNFM Instantiate ID",
+ "in": "path",
+ "name": "vnfmId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "instantiate request param",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfInstantiateRequest"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/VnfInstantiateResponse"
+ }
+ }
+ },
+ "summary": "vnf create&instantiate",
+ "tags": [
+ "VNFMDriver"
+ ]
+ }
+ },
+ "/{vnfmId}/vnfs/{vnfId}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "",
+ "operationId": "query_vnf",
+ "parameters": [
+ {
+ "description": "The value of vnfmId should be the VNFM Instantiate ID",
+ "in": "path",
+ "name": "vnfmId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "The value of vnfId should be the VNF Instantiate ID",
+ "in": "path",
+ "name": "vnfId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/VnfInfo"
+ }
+ },
+ "404": {
+ "description": "the vnf instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ },
+ "summary": "query the specified vnf info",
+ "tags": [
+ "VNFMDriver"
+ ]
+ }
+ },
+ "/{vnfmId}/vnfs/{vnfId}/heal": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "VNF Heal Rest API should be provided by the VNFM Driver",
+ "operationId": "vnf_heal",
+ "parameters": [
+ {
+ "description": "The value of vnfmId should be the VNFM Instantiate ID",
+ "in": "path",
+ "name": "vnfmId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "The value of vnfId should be the VNF Instantiate ID",
+ "in": "path",
+ "name": "vnfId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "instantiate request param",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfHealRequest"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/JobInfo"
+ }
+ },
+ "404": {
+ "description": "the VNF instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ },
+ "summary": "vnf heal",
+ "tags": [
+ "VNFMDriver"
+ ]
+ }
+ },
+ "/{vnfmId}/vnfs/{vnfId}/scale": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "VNF Scale Rest API should be provided by the VNFM Driver",
+ "operationId": "vnf_scale",
+ "parameters": [
+ {
+ "description": "The value of vnfmId should be the VNFM Instantiate ID",
+ "in": "path",
+ "name": "vnfmId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "The value of vnfId should be the VNF Instantiate ID",
+ "in": "path",
+ "name": "vnfId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "instantiate request param",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfScaleRequest"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/JobInfo"
+ }
+ },
+ "404": {
+ "description": "the VNF instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ },
+ "summary": "vnf Scale",
+ "tags": [
+ "VNFMDriver"
+ ]
+ }
+ },
+ "/{vnfmId}/vnfs/{vnfId}/terminate": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "VNF terminate&delete Rest API should be provided by the VNFM Driver",
+ "operationId": "terminate_vnf",
+ "parameters": [
+ {
+ "description": "The value of vnfmId should be the VNFM Instantiate ID",
+ "in": "path",
+ "name": "vnfmId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "The value of vnfId should be the VNF Instantiate ID",
+ "in": "path",
+ "name": "vnfId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "instantiate request param",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfTerminateRequest"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "204": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/JobInfo"
+ }
+ },
+ "404": {
+ "description": "the VNF instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ },
+ "summary": "terminate&delete vnf",
+ "tags": [
+ "VNFMDriver"
+ ]
+ }
+ },
+ "/{vnfmId}/jobs/{jobId}": {
+ "get": {
+ "tags": [
+ "VNFMDriver"
+ ],
+ "summary": "jobstatus",
+ "description": "Job Infomation API should be provided by VNFM Driver",
+ "operationId": "get_jobstatus",
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "job Id",
+ "name": "jobId",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmId should be the VNFM Instantiate ID",
+ "name": "vnfmId",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "job response message id",
+ "name": "responseId",
+ "in": "query"
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/JobDetailInfo"
+ }
+ }
+ }
+ }
+ },
+ "/lcn":{
+ "get": {
+ "tags": [
+ "SBI"
+ ],
+ "summary": "Test LCN connectivity from CBAM to driver",
+ "description": "Test LCN connectivity from CBAM to driver",
+ "responses": {
+ "204": {
+ "description": "Used for connectivity test"
+ }
+ }
+ },
+ "post": {
+ "tags": [
+ "SBI"
+ ],
+ "consumes": [
+ "application/json"
+ ],
+ "summary": "Send LCN from CBAM",
+ "description": "Test LCN connectivity from CBAM to driver",
+ "parameters": [
+ {
+ "description": "The life cycle change notification",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfLifecycleChangeNotification"
+ }
+ }
+ ],
+ "responses": {
+ "204": {
+ "description": "Used for connectivity test"
+ }
+ }
+ }
+ },
+ "/swagger.json": {
+ "get": {
+ "tags": [
+ "Utilities"
+ ],
+ "summary": "The Nokia SVNFM API definition",
+ "description": "The Nokia SVNFM API definition",
+ "responses": {
+ "202": {
+ "description": "The swagger API definition"
+ }
+ }
+ }
+ },
+ "/convert": {
+ "post": {
+ "tags": [
+ "Utilities"
+ ],
+ "consumes":[
+ "multipart/form-data"
+ ],
+ "produces":[
+ "application/octet-stream"
+ ],
+ "parameters" : [
+ {
+ "description": "The CBAM VNF package",
+ "in": "formData",
+ "name": "upfile",
+ "type": "file"
+ }
+ ],
+ "summary": "Converts the Nokia CBAM package to ONAP package",
+ "description": "Converts the Nokia CBAM package to ONAP package",
+ "responses": {
+ "200": {
+ "description": "The converted package",
+ "schema":{
+ "type": "file"
+ }
+ }
+ }
+ },
+ "get": {
+ "tags": [
+ "Utilities"
+ ],
+ "produces":[
+ "text/html"
+ ],
+ "summary": "UI to convert the Nokia CBAM package to ONAP package",
+ "description": "UI to convert the Nokia CBAM package to ONAP package",
+ "responses": {
+ "200": {
+ "description": "The converted package"
+ }
+ }
+ }
+
+ }
+ }
+}
diff --git a/nokiav2/driver/src/main/resources/upload.html b/nokiav2/driver/src/main/resources/upload.html
new file mode 100644
index 00000000..a5c686f4
--- /dev/null
+++ b/nokiav2/driver/src/main/resources/upload.html
@@ -0,0 +1,12 @@
+<!DOCTYPE html>
+<html>
+<body>
+
+<form action="/api/NokiaSVNFM/v1/convert" method="post" enctype="multipart/form-data">
+ Select CBAM package to upload:
+ <input type="file" name="fileToUpload" id="fileToUpload">
+ <input type="submit" value="Upload" name="submit">
+</form>
+
+</body>
+</html> \ No newline at end of file
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/FullUnitTestSuite.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/FullUnitTestSuite.java
new file mode 100644
index 00000000..4ed4bf27
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/FullUnitTestSuite.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia;
+
+import org.junit.runner.RunWith;
+import org.junit.runners.Suite;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.TestCbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.TestGenericExternalSystemInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.TestIpMappingProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.TestMsbApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.TestCbamVnfPackageBuilder;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.TestCbamVnfdBuilder;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.TestOnapVnfPackageBuilder;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.TestOnapVnfdBuilder;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.TestConditions;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.TestRealConfig;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring.TestServletInitializer;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.TestLifecycleChangeNotificationManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.TestProcessedNotification;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.TestReportedAffectedConnectionPoints;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.TestReportedAffectedCp;
+
+@RunWith(Suite.class)
+@Suite.SuiteClasses({
+
+ TestCbamRestApiProvider.class,
+ TestGenericExternalSystemInfoProvider.class,
+ TestIpMappingProvider.class,
+ TestMsbApiProvider.class,
+
+ TestVfcExternalSystemInfoProvider.class,
+ TestVfcGrantManager.class,
+ TestVfcPackageProvider.class,
+ TestVfcRestApiProvider.class,
+ TestVfcNotificationSender.class,
+
+ TestCbamVnfdBuilder.class,
+ TestOnapVnfdBuilder.class,
+ TestCbamVnfPackageBuilder.class,
+ TestOnapVnfPackageBuilder.class,
+
+ TestConverterApi.class,
+ TestLcmApi.class,
+ TestLcnApi.class,
+ TestSwaggerApi.class,
+ TestSwaggerDefinitionConsistency.class,
+
+ TestConditions.class,
+ TestServletInitializer.class,
+ TestRealConfig.class,
+
+ TestCbamUtils.class,
+ TestStoreLoader.class,
+ TestSystemFunctions.class,
+ TestUserInvisibleError.class,
+ TestUserVisibleError.class,
+
+ TestLifecycleChangeNotificationManager.class,
+ TestProcessedNotification.class,
+ TestReportedAffectedConnectionPoints.class,
+ TestReportedAffectedCp.class,
+
+ TestAdditionalParams.class,
+ TestCbamCatalogManager.class,
+ TestCbamTokenProvider.class,
+ TestDriverProperties.class,
+ TestJobManager.class,
+ TestVfcGrantManager.class,
+ TestLifecycleManager.class,
+ TestSelfRegistrationManager.class,
+ TestNokiaSvnfmApplication.class,
+
+})
+public class FullUnitTestSuite {
+}
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/TestNokiaSvnfmApplication.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/TestNokiaSvnfmApplication.java
new file mode 100644
index 00000000..249e16c9
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/TestNokiaSvnfmApplication.java
@@ -0,0 +1,162 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia;
+
+import junit.framework.TestCase;
+import org.apache.log4j.Logger;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.JobManager;
+import org.springframework.boot.context.event.ApplicationReadyEvent;
+import org.springframework.context.event.ContextClosedEvent;
+import org.springframework.test.util.ReflectionTestUtils;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.assertTrue;
+import static org.mockito.Mockito.verify;
+
+
+public class TestNokiaSvnfmApplication {
+ @Mock
+ private SelfRegistrationManager selfRegistrationManager;
+ @Mock
+ private JobManager jobManager;
+ @Mock
+ private Logger logger;
+ @InjectMocks
+ private NokiaSvnfmApplication.SelfRegistrationTrigger selfRegistrationTriggerer;
+ @InjectMocks
+ private NokiaSvnfmApplication.SelfDeRegistrationTrigger selfUnregistrationTriggerer;
+
+
+ @Before
+ public void initMocks() throws Exception {
+ MockitoAnnotations.initMocks(this);
+ ReflectionTestUtils.setField(NokiaSvnfmApplication.class, "logger", logger);
+ }
+
+ /**
+ * Assert that the entry point of the application does not change
+ */
+ @Test
+ public void doNotRename() {
+ //verify
+ //1. if the entry point is renamed the main class of spring boot in the driverwar must also be changed
+ //2. all classes that use @Autowrire must be in a subpackage relative to this class
+ assertEquals("org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.NokiaSvnfmApplication", NokiaSvnfmApplication.class.getCanonicalName());
+ }
+
+ /**
+ * Assert that the self registration process is started after the servlet is up and is able to answer REST requests.
+ */
+ @Test
+ public void testRegistrationIsCalledAfterComponentIsUp() throws Exception {
+ //given
+ ApplicationReadyEvent event = Mockito.mock(ApplicationReadyEvent.class);
+ //when
+ selfRegistrationTriggerer.onApplicationEvent(event);
+ //verify
+ verify(selfRegistrationManager).register();
+ verify(logger).info("Self registration started");
+ verify(logger).info("Self registration finished");
+ // this forces the event to be fired after the servlet is up (prevents refactor)
+ assertTrue(ApplicationReadyEvent.class.isAssignableFrom(event.getClass()));
+ }
+
+ /**
+ * Assert that the self de-registration process is started after the servlet has been ramped down
+ */
+ @Test
+ public void testUnRegistrationIsCalledAfterComponentIsUp() throws Exception {
+ //given
+ ContextClosedEvent event = Mockito.mock(ContextClosedEvent.class);
+ //when
+ selfUnregistrationTriggerer.onApplicationEvent(event);
+ //verify
+ InOrder inOrder = Mockito.inOrder(jobManager, selfRegistrationManager);
+ inOrder.verify(jobManager).prepareForShutdown();
+ inOrder.verify(selfRegistrationManager).deRegister();
+ verify(logger).info("Self de-registration started");
+ verify(logger).info("Self de-registration finished");
+ // this forces the event to be fired after the servlet is down (prevents refactor)
+ assertTrue(ContextClosedEvent.class.isAssignableFrom(event.getClass()));
+ }
+
+ /**
+ * Failures in registration is logged and propagated
+ */
+ @Test
+ public void failedRegistration() {
+ //given
+ RuntimeException expectedException = new RuntimeException();
+ Mockito.doThrow(expectedException).when(selfRegistrationManager).register();
+ ApplicationReadyEvent event = Mockito.mock(ApplicationReadyEvent.class);
+ //when
+ try {
+ selfRegistrationTriggerer.onApplicationEvent(event);
+ //verify
+ TestCase.fail();
+ } catch (RuntimeException e) {
+ assertEquals(e, expectedException);
+ }
+ verify(logger).error("Self registration failed", expectedException);
+ }
+
+ /**
+ * Failures in de-registration is logged and propagated
+ */
+ @Test
+ public void failedDeRegistration() {
+ //given
+ RuntimeException expectedException = new RuntimeException();
+ Mockito.doThrow(expectedException).when(selfRegistrationManager).deRegister();
+ ContextClosedEvent event = Mockito.mock(ContextClosedEvent.class);
+ //when
+ try {
+ selfUnregistrationTriggerer.onApplicationEvent(event);
+ //verify
+ TestCase.fail();
+ } catch (RuntimeException e) {
+ assertEquals(e, expectedException);
+ }
+ verify(logger).error("Self de-registration failed", expectedException);
+ }
+
+ /**
+ * Spring will instantiate using reflection
+ */
+ @Test
+ public void testUseStaticWay() throws Exception {
+ //verify
+ //the constructor is public even if has no private fields
+ new NokiaSvnfmApplication();
+ }
+
+ /**
+ * static entry point calling an other static entry point can not be tested
+ */
+ @Test
+ public void useless() throws Exception {
+ try {
+ NokiaSvnfmApplication.main(null);
+ } catch (Exception e) {
+
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTDirectReal.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTDirectReal.java
new file mode 100644
index 00000000..a428ee90
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTDirectReal.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.ct;
+
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.model.*;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.NokiaSvnfmApplication;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIExternalSystemInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.AAINotificationProcessor;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedConnectionPoints;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedCp;
+import org.onap.vnfmdriver.model.VimInfo;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.test.context.SpringBootTest;
+import org.springframework.test.context.ActiveProfiles;
+import org.springframework.test.context.junit4.SpringRunner;
+
+import java.util.ArrayList;
+
+import static java.util.Optional.of;
+
+@RunWith(value = SpringRunner.class)
+@SpringBootTest(classes = NokiaSvnfmApplication.class, webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT)
+@ActiveProfiles("direct")
+public class CTDirectReal {
+ @Autowired
+ private AAIExternalSystemInfoProvider externalSystemInfoProvider;
+ @Autowired
+ private AAINotificationProcessor notificationProcessor;
+
+ /**
+ * The following is not a real test, but only start the driver locally.
+ * It takes parameters from application-real.properties
+ */
+ @Test
+ public void testBasicWorkflow() throws Exception {
+ VimInfo nokia_regionOne = externalSystemInfoProvider.getVimInfo("Nokia_RegionOne");
+
+ VnfLifecycleChangeNotification recievedNot = new VnfLifecycleChangeNotification();
+ recievedNot.setVnfInstanceId("CBAM-d8deb02a7a51449dba576ac9eabb55b8");
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ recievedNot.setAffectedVirtualLinks(new ArrayList<>());
+ AffectedVirtualLink link = new AffectedVirtualLink();
+ recievedNot.getAffectedVirtualLinks().add(link);
+ link.setId("vlid1");
+ link.setChangeType(ChangeType.REMOVED);
+ link.setVirtualLinkDescId("vldId1");
+ link.setResource(new ResourceHandle());
+ link.getResource().setResourceId("netProviderId1");
+ link.getResource().setAdditionalData(additionalData("name", "networkName"));
+ recievedNot.setAffectedVnfcs(new ArrayList<>());
+ AffectedVnfc vnfc = new AffectedVnfc();
+ vnfc.setId("myVnfcId1");
+ vnfc.setChangeType(ChangeType.ADDED);
+ vnfc.setVduId("myVduId");
+ vnfc.setStorageResourceIds(new ArrayList<>());
+ vnfc.setComputeResource(new ResourceHandle());
+ vnfc.getComputeResource().setResourceId("serverProvId1");
+ JsonObject additionalData = additionalData("name", "serverName");
+ additionalData.addProperty("tenantId", "de8fd0d1d5874503a47b920c10f4322a");
+ vnfc.getComputeResource().setAdditionalData(additionalData);
+ recievedNot.getAffectedVnfcs().add(vnfc);
+ ReportedAffectedCp addedCp = new ReportedAffectedCp();
+ addedCp.setCpId("cpId");
+ addedCp.setIpAddress("1.2.3.4");
+ addedCp.setMacAddress("a:b:c:d:e:f");
+ addedCp.setNetworkProviderId("netProviderId1");
+ addedCp.setServerProviderId("serverProvId1");
+ addedCp.setProviderId("portId");
+ addedCp.setTenantId("de8fd0d1d5874503a47b920c10f4322a");
+ addedCp.setCpdId("cpdId");
+ affectedConnectionPoints.getPost().add(addedCp);
+ notificationProcessor.processNotification(recievedNot, null, of(affectedConnectionPoints), "Nokia_RegionOne");
+ Thread.sleep(10000000 * 1000L);
+ }
+
+ JsonObject additionalData(String key, String value) {
+ JsonObject jsonObject = new JsonObject();
+ jsonObject.addProperty(key, value);
+ return jsonObject;
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTReal.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTReal.java
new file mode 100644
index 00000000..c40dcfb1
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/ct/CTReal.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.ct;
+
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.NokiaSvnfmApplication;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions;
+import org.springframework.boot.test.context.SpringBootTest;
+import org.springframework.test.context.ActiveProfiles;
+import org.springframework.test.context.junit4.SpringRunner;
+
+@RunWith(value = SpringRunner.class)
+@SpringBootTest(classes = NokiaSvnfmApplication.class, webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT)
+@ActiveProfiles("real")
+public class CTReal {
+
+ /**
+ * The following is not a real test, but only start the driver locally.
+ * It takes parameters from application-real.properties
+ */
+ @Test
+ public void testBasicWorkflow() {
+ SystemFunctions.systemFunctions().sleep(10000000 * 1000L);
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestCbamRestApiProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestCbamRestApiProvider.java
new file mode 100644
index 00000000..0d036a63
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestCbamRestApiProvider.java
@@ -0,0 +1,235 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import com.nokia.cbam.catalog.v1.api.DefaultApi;
+import com.nokia.cbam.lcm.v32.ApiClient;
+import com.nokia.cbam.lcm.v32.api.OperationExecutionsApi;
+import com.nokia.cbam.lcm.v32.api.VnfsApi;
+import com.nokia.cbam.lcn.v32.api.SubscriptionsApi;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mock;
+import org.onap.msb.sdk.discovery.entity.MicroServiceFullInfo;
+import org.onap.msb.sdk.discovery.entity.NodeInfo;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamTokenProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.springframework.core.env.Environment;
+
+import java.util.Base64;
+import java.util.HashSet;
+import java.util.Set;
+
+import static junit.framework.TestCase.*;
+import static org.mockito.Mockito.spy;
+import static org.mockito.Mockito.when;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestCbamRestApiProvider extends TestBase {
+ @Mock
+ private Environment environment;
+ @Mock
+ private CbamTokenProvider cbamTokenProvider;
+ private MicroServiceFullInfo microServiceInfo = new MicroServiceFullInfo();
+ private Set<NodeInfo> nodes = new HashSet<>();
+
+ private CbamRestApiProvider cbamRestApiProvider;
+
+ @Before
+ public void init() {
+ microServiceInfo.setNodes(nodes);
+ CbamRestApiProvider real = new CbamRestApiProvider(driverProperties, cbamTokenProvider, vnfmInfoProvider);
+ setField(real, "trustedCertificates", "mytrustedCertificates");
+ setField(real, "skipCertificateVerification", true);
+ cbamRestApiProvider = spy(real);
+ when(environment.getProperty(IpMappingProvider.IP_MAP, String.class, "")).thenReturn("");
+ when(environment.getProperty(GenericExternalSystemInfoProvider.VNFM_INFO_CACHE_EVICTION_IN_MS, Long.class, Long.valueOf(10 * 60 * 1000))).thenReturn(10 * 60 * 1000L);
+ }
+
+ /**
+ * test CBAM LCM API retrieval without SSL verification
+ */
+ @Test
+ public void testCbamLcmApi() throws Exception {
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ expectedVnfmInfo.setUrl("https://cbamUrl:123/d");
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ //when
+ VnfsApi cbamLcmApi = cbamRestApiProvider.getCbamLcmApi(VNFM_ID);
+ //verify
+ ApiClient apiClient = cbamLcmApi.getApiClient();
+ assertEquals("https://cbamUrl:123/d", apiClient.getBasePath());
+ assertNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.lcm.v32.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamLcmApi.getApiClient().getAuthentications().size());
+ assertTrue(!cbamLcmApi.getApiClient().isVerifyingSsl());
+ }
+
+ /**
+ * test CBAM LCM API retrieval with SSL verification
+ */
+ @Test
+ public void testCbamLcmApiWithSslVerfy() throws Exception {
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ expectedVnfmInfo.setUrl("https://cbamUrl:123/d");
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ setField(cbamRestApiProvider, "skipCertificateVerification", false);
+ setField(cbamRestApiProvider, "trustedCertificates", Base64.getEncoder().encodeToString(TestUtil.loadFile("unittests/sample.cert.pem")));
+ //when
+ VnfsApi cbamLcmApi = cbamRestApiProvider.getCbamLcmApi(VNFM_ID);
+ //verify
+ ApiClient apiClient = cbamLcmApi.getApiClient();
+ assertEquals("https://cbamUrl:123/d", apiClient.getBasePath());
+ assertNotNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.lcm.v32.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamLcmApi.getApiClient().getAuthentications().size());
+ assertTrue(cbamLcmApi.getApiClient().isVerifyingSsl());
+ }
+
+ /**
+ * test CBAM Catalog API retrieval without SSL verification
+ */
+ @Test
+ public void testCbamCatalogApi() throws Exception {
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ when(driverProperties.getCbamCatalogUrl()).thenReturn("https://1.2.3.4/path");
+ //when
+ DefaultApi cbamCatalogApi = cbamRestApiProvider.getCbamCatalogApi(VNFM_ID);
+ //verify
+ com.nokia.cbam.catalog.v1.ApiClient apiClient = cbamCatalogApi.getApiClient();
+ assertEquals("https://1.2.3.4/path", apiClient.getBasePath());
+ assertNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.catalog.v1.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamCatalogApi.getApiClient().getAuthentications().size());
+ assertTrue(!cbamCatalogApi.getApiClient().isVerifyingSsl());
+ }
+
+ /**
+ * test CBAM Catalog API retrieval with SSL verification
+ */
+ @Test
+ public void testCbamCatalogApiWithSslVerfy() throws Exception {
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ when(driverProperties.getCbamCatalogUrl()).thenReturn("https://1.2.3.4/path");
+ setField(cbamRestApiProvider, "skipCertificateVerification", false);
+ setField(cbamRestApiProvider, "trustedCertificates", Base64.getEncoder().encodeToString(TestUtil.loadFile("unittests/sample.cert.pem")));
+ //when
+ DefaultApi cbamLcmApi = cbamRestApiProvider.getCbamCatalogApi(VNFM_ID);
+ //verify
+ com.nokia.cbam.catalog.v1.ApiClient apiClient = cbamLcmApi.getApiClient();
+ assertEquals("https://1.2.3.4/path", apiClient.getBasePath());
+ assertNotNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.catalog.v1.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamLcmApi.getApiClient().getAuthentications().size());
+ assertTrue(cbamLcmApi.getApiClient().isVerifyingSsl());
+ }
+
+ /**
+ * test CBAM Lcn API retrieval without SSL verification
+ */
+ @Test
+ public void testCbamLcnApi() throws Exception {
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ when(driverProperties.getCbamLcnUrl()).thenReturn("https://1.2.3.4/path");
+ //when
+ SubscriptionsApi cbamLcnApi = cbamRestApiProvider.getCbamLcnApi(VNFM_ID);
+ //verify
+ com.nokia.cbam.lcn.v32.ApiClient apiClient = cbamLcnApi.getApiClient();
+ assertEquals("https://1.2.3.4/path", apiClient.getBasePath());
+ assertNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.lcn.v32.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamLcnApi.getApiClient().getAuthentications().size());
+ assertTrue(!cbamLcnApi.getApiClient().isVerifyingSsl());
+ }
+
+ /**
+ * test CBAM Lcn API retrieval with SSL verification
+ */
+ @Test
+ public void testCbamLcnApiWithSslVerfy() throws Exception {
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ when(driverProperties.getCbamLcnUrl()).thenReturn("https://1.2.3.4/path");
+ setField(cbamRestApiProvider, "skipCertificateVerification", false);
+ setField(cbamRestApiProvider, "trustedCertificates", Base64.getEncoder().encodeToString(TestUtil.loadFile("unittests/sample.cert.pem")));
+ //when
+ SubscriptionsApi cbamLcnApi = cbamRestApiProvider.getCbamLcnApi(VNFM_ID);
+ //verify
+ com.nokia.cbam.lcn.v32.ApiClient apiClient = cbamLcnApi.getApiClient();
+ assertEquals("https://1.2.3.4/path", apiClient.getBasePath());
+ assertNotNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.lcn.v32.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamLcnApi.getApiClient().getAuthentications().size());
+ assertTrue(cbamLcnApi.getApiClient().isVerifyingSsl());
+ }
+
+ /**
+ * test CBAM operation exeution API retrieval without SSL verification
+ */
+ @Test
+ public void testCbamOpexApi() throws Exception {
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ when(nsLcmApi.queryVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ expectedVnfmInfo.setUrl("https://cbamUrl:123/d");
+ //when
+ OperationExecutionsApi cbamLcnApi = cbamRestApiProvider.getCbamOperationExecutionApi(VNFM_ID);
+ //verify
+ ApiClient apiClient = cbamLcnApi.getApiClient();
+ assertEquals("https://cbamUrl:123/d", apiClient.getBasePath());
+ assertNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.lcm.v32.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamLcnApi.getApiClient().getAuthentications().size());
+ assertTrue(!cbamLcnApi.getApiClient().isVerifyingSsl());
+ }
+
+ /**
+ * test CBAM operation execution API retrieval with SSL verification
+ */
+ @Test
+ public void testCbamOpexApiWithSslVerfy() throws Exception {
+ when(cbamTokenProvider.getToken(VNFM_ID)).thenReturn("myToken");
+ setField(cbamRestApiProvider, "skipCertificateVerification", false);
+ setField(cbamRestApiProvider, "trustedCertificates", Base64.getEncoder().encodeToString(TestUtil.loadFile("unittests/sample.cert.pem")));
+ VnfmInfo expectedVnfmInfo = new VnfmInfo();
+ when(nsLcmApi.queryVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ expectedVnfmInfo.setUrl("https://cbamUrl:123/d");
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ //when
+ OperationExecutionsApi cbamLcnApi = cbamRestApiProvider.getCbamOperationExecutionApi(VNFM_ID);
+ //verify
+ ApiClient apiClient = cbamLcnApi.getApiClient();
+ assertEquals("https://cbamUrl:123/d", apiClient.getBasePath());
+ assertNotNull(apiClient.getSslCaCert());
+ assertEquals("myToken", ((com.nokia.cbam.lcm.v32.auth.OAuth) apiClient.getAuthentication("OauthClient")).getAccessToken());
+ assertEquals(2, cbamLcnApi.getApiClient().getAuthentications().size());
+ assertTrue(cbamLcnApi.getApiClient().isVerifyingSsl());
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestGenericExternalSystemInfoProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestGenericExternalSystemInfoProvider.java
new file mode 100644
index 00000000..a0d4ea4d
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestGenericExternalSystemInfoProvider.java
@@ -0,0 +1,136 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vnfmdriver.model.VimInfo;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.springframework.core.env.Environment;
+import org.springframework.test.util.ReflectionTestUtils;
+
+import static java.lang.Long.valueOf;
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Mockito.*;
+
+public class TestGenericExternalSystemInfoProvider extends TestBase {
+
+ private GenericExternalSystemInfoProvider genericExternalSystemInfoProvider;
+
+ @Before
+ public void init() {
+ when(environment.getProperty(IpMappingProvider.IP_MAP, String.class, "")).thenReturn("");
+ ReflectionTestUtils.setField(GenericExternalSystemInfoProvider.class, "logger", logger);
+ genericExternalSystemInfoProvider = Mockito.spy(new TestClass(environment));
+ }
+
+ /**
+ * the VNFM info is not retrieved within the cache eviction period
+ */
+ @Test
+ public void testQueryVnfmInfoWithin() throws Exception {
+ VnfmInfo expectedVnfmInfo = Mockito.mock(VnfmInfo.class);
+ when(genericExternalSystemInfoProvider.queryVnfmInfoFromSource(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ when(environment.getProperty(GenericExternalSystemInfoProvider.VNFM_INFO_CACHE_EVICTION_IN_MS, Long.class, valueOf(GenericExternalSystemInfoProvider.DEFAULT_CACHE_EVICTION_TIMEOUT_IN_MS))).thenReturn(Long.valueOf(1234));
+ genericExternalSystemInfoProvider.afterPropertiesSet();
+ //when
+ VnfmInfo vnfmInfo = genericExternalSystemInfoProvider.getVnfmInfo(VNFM_ID);
+ //verify
+ verify(logger).info("Querying VNFM info from source with " + VNFM_ID + " identifier");
+ assertEquals(expectedVnfmInfo, vnfmInfo);
+ //when
+ VnfmInfo vnfmInfo2 = genericExternalSystemInfoProvider.getVnfmInfo(VNFM_ID);
+ //verify source system not called again
+ verify(logger).info("Querying VNFM info from source with " + VNFM_ID + " identifier");
+ verify(genericExternalSystemInfoProvider, Mockito.times(1)).queryVnfmInfoFromSource(VNFM_ID);
+ }
+
+ /**
+ * the VNFM info is retrieved without the cache eviction period
+ */
+ @Test
+ //sleeping is required to make time pass (for cache to notice the change)
+ //cache is configured with 1 ms cache eviction without sleep it is not
+ //deterministic that at least 1 ms time will pass between calls
+ @SuppressWarnings("squid:S2925")
+ public void testQueryVnfmInfoOutside() throws Exception {
+ VnfmInfo expectedVnfmInfo = Mockito.mock(VnfmInfo.class);
+ when(genericExternalSystemInfoProvider.queryVnfmInfoFromSource(VNFM_ID)).thenReturn(expectedVnfmInfo);
+ when(environment.getProperty(GenericExternalSystemInfoProvider.VNFM_INFO_CACHE_EVICTION_IN_MS, Long.class, valueOf(GenericExternalSystemInfoProvider.DEFAULT_CACHE_EVICTION_TIMEOUT_IN_MS))).thenReturn(Long.valueOf(1));
+ genericExternalSystemInfoProvider.afterPropertiesSet();
+ //when
+ VnfmInfo vnfmInfo = genericExternalSystemInfoProvider.getVnfmInfo(VNFM_ID);
+ //verify
+ assertEquals(expectedVnfmInfo, vnfmInfo);
+ //when
+ Thread.sleep(10);
+ VnfmInfo vnfmInfo2 = genericExternalSystemInfoProvider.getVnfmInfo(VNFM_ID);
+ //verify source system called again
+ verify(logger, times(2)).info("Querying VNFM info from source with " + VNFM_ID + " identifier");
+ verify(genericExternalSystemInfoProvider, Mockito.times(2)).queryVnfmInfoFromSource(VNFM_ID);
+ }
+
+ /**
+ * Unable to query VNFM results is propagated
+ */
+ @Test
+ public void testUnableToQueryVnfmInfoProvider() throws Exception {
+ class TestClass extends GenericExternalSystemInfoProvider {
+
+ TestClass(Environment environment) {
+ super(environment);
+ }
+
+ @Override
+ public VnfmInfo queryVnfmInfoFromSource(String vnfmId) {
+ throw new RuntimeException();
+ }
+
+ @Override
+ public VimInfo getVimInfo(String vimId) {
+ return null;
+ }
+ }
+ try {
+ new TestClass(null).getVnfmInfo(VNFM_ID);
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to query VNFM info for myVnfmId", e.getMessage());
+ verify(logger).error(eq("Unable to query VNFM info for myVnfmId"), any(RuntimeException.class));
+ }
+ }
+
+ class TestClass extends GenericExternalSystemInfoProvider {
+
+ TestClass(Environment environment) {
+ super(environment);
+ }
+
+ @Override
+ public VnfmInfo queryVnfmInfoFromSource(String vnfmId) {
+ return null;
+ }
+
+ @Override
+ public VimInfo getVimInfo(String vimId) {
+ return null;
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestIpMappingProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestIpMappingProvider.java
new file mode 100644
index 00000000..a1f91855
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestIpMappingProvider.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.springframework.core.env.Environment;
+
+import static junit.framework.TestCase.assertEquals;
+import static org.mockito.Mockito.when;
+
+public class TestIpMappingProvider extends TestBase {
+
+ private IpMappingProvider ipMappingProvider;
+
+ @Before
+ public void init() {
+ ipMappingProvider = new TestClass(environment);
+ }
+
+ /**
+ * the IP addresses are correctly mapped
+ */
+ @Test
+ public void testIpMapping() throws Exception {
+ when(environment.getProperty(IpMappingProvider.IP_MAP, String.class, "")).thenReturn(" 1.2.3.4 -> 2.3.4.5 , 1.2.3.5 -> 3.4.5.6");
+ //when
+ ipMappingProvider.afterPropertiesSet();
+ //verify
+ assertEquals("2.3.4.5", ipMappingProvider.mapPrivateIpToPublicIp("1.2.3.4"));
+ assertEquals(".......", ipMappingProvider.mapPrivateIpToPublicIp("......."));
+ assertEquals("3.4.5.6", ipMappingProvider.mapPrivateIpToPublicIp("1.2.3.5"));
+ assertEquals("1.2.3.5.", ipMappingProvider.mapPrivateIpToPublicIp("1.2.3.5."));
+
+ }
+
+ class TestClass extends IpMappingProvider {
+
+ TestClass(Environment environment) {
+ super(environment);
+ }
+
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestMsbApiProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestMsbApiProvider.java
new file mode 100644
index 00000000..eb3674c3
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/core/TestMsbApiProvider.java
@@ -0,0 +1,173 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mock;
+import org.onap.msb.sdk.discovery.common.RouteException;
+import org.onap.msb.sdk.discovery.entity.MicroServiceFullInfo;
+import org.onap.msb.sdk.discovery.entity.NodeInfo;
+import org.onap.msb.sdk.httpclient.msb.MSBServiceClient;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamTokenProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.springframework.core.env.Environment;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestMsbApiProvider extends TestBase {
+ @Mock
+ private Environment environment;
+ @Mock
+ private CbamTokenProvider cbamTokenProvider;
+ private MicroServiceFullInfo microServiceInfo = new MicroServiceFullInfo();
+ private Set<NodeInfo> nodes = new HashSet<>();
+ private MsbApiProvider msbApiProvider;
+
+ @Before
+ public void init() {
+ setField(MsbApiProvider.class, "logger", logger);
+ msbApiProvider = new MsbApiProvider(environment);
+ microServiceInfo.setNodes(nodes);
+ }
+
+ /**
+ * test MSB client is created based on driver properties
+ */
+ @Test
+ public void testMsbClient() {
+ setFieldWithPropertyAnnotation(msbApiProvider, "${messageBusIp}", "mymessageBusIp");
+ setFieldWithPropertyAnnotation(msbApiProvider, "${messageBusPort}", "123");
+ //when
+ MSBServiceClient msbClient = msbApiProvider.getMsbClient();
+ //verify
+ assertEquals("mymessageBusIp:123", msbClient.getMsbSvrAddress());
+ }
+
+ /**
+ * error is propagated if no suitable micro service endpoint is found
+ */
+ @Test
+ public void testNoSuitableMicroService() throws Exception {
+ NodeInfo dockerAccessPoint = new NodeInfo();
+ dockerAccessPoint.setIp("172.1.2.3");
+ microServiceInfo.setServiceName("serviceName");
+ microServiceInfo.setVersion("v1");
+ microServiceInfo.setUrl("/lead/nslcm/v1");
+ when(environment.getProperty(IpMappingProvider.IP_MAP, String.class, "")).thenReturn("");
+ nodes.add(dockerAccessPoint);
+ msbApiProvider = new MsbApiProvider(environment) {
+ @Override
+ public MSBServiceClient getMsbClient() {
+ return msbClient;
+ }
+ };
+ when(msbClient.queryMicroServiceInfo("serviceName", "v1")).thenReturn(microServiceInfo);
+ //when
+ try {
+ msbApiProvider.getMicroServiceUrl("serviceName", "v1");
+ fail();
+ } catch (Exception e) {
+ assertEquals("The serviceName service with v1 does not have any valid nodes[172.1.2.3:null ttl:]", e.getMessage());
+ verify(logger).error("The serviceName service with v1 does not have any valid nodes[172.1.2.3:null ttl:]");
+ }
+ }
+
+ /**
+ * non Docker endpoint is selected
+ */
+ @Test
+ public void testExistingValidEndpoint() throws Exception {
+ NodeInfo nonDocker = new NodeInfo();
+ nonDocker.setIp("173.1.2.3");
+ nonDocker.setPort("234");
+ microServiceInfo.setServiceName("serviceName");
+ microServiceInfo.setVersion("v1");
+ microServiceInfo.setUrl("/lead/nslcm/v1");
+ when(environment.getProperty(IpMappingProvider.IP_MAP, String.class, "")).thenReturn("173.1.2.3->1.2.3.4");
+ nodes.add(nonDocker);
+ msbApiProvider = new MsbApiProvider(environment) {
+ @Override
+ public MSBServiceClient getMsbClient() {
+ return msbClient;
+ }
+ };
+ when(msbClient.queryMicroServiceInfo("serviceName", "v1")).thenReturn(microServiceInfo);
+ msbApiProvider.afterPropertiesSet();
+ //when
+ assertEquals("http://1.2.3.4:234/lead/nslcm/v1", msbApiProvider.getMicroServiceUrl("serviceName", "v1"));
+ }
+
+
+ /**
+ * use HTTPS for known ports
+ */
+ @Test
+ public void testMsbServiceOverssl() throws Exception {
+ NodeInfo nonDocker = new NodeInfo();
+ nonDocker.setIp("173.1.2.3");
+ nonDocker.setPort("123");
+ microServiceInfo.setServiceName("serviceName");
+ microServiceInfo.setVersion("v1");
+ microServiceInfo.setUrl("/lead/nslcm/v1");
+ microServiceInfo.setEnable_ssl(true);
+ when(environment.getProperty(IpMappingProvider.IP_MAP, String.class, "")).thenReturn("173.1.2.3->1.2.3.4");
+ nodes.add(nonDocker);
+ msbApiProvider = new MsbApiProvider(environment) {
+ @Override
+ public MSBServiceClient getMsbClient() {
+ return msbClient;
+ }
+ };
+ when(msbClient.queryMicroServiceInfo("serviceName", "v1")).thenReturn(microServiceInfo);
+ msbApiProvider.afterPropertiesSet();
+ //when
+ assertEquals("https://1.2.3.4:123/lead/nslcm/v1", msbApiProvider.getMicroServiceUrl("serviceName", "v1"));
+ }
+
+ /**
+ * if unable to get micro service info the error is propagated
+ */
+ @Test
+ public void testUnableQueryMicroserviInfo() throws Exception {
+ msbApiProvider = new MsbApiProvider(environment) {
+ @Override
+ public MSBServiceClient getMsbClient() {
+ return msbClient;
+ }
+ };
+ RouteException expectedException = new RouteException();
+ when(msbClient.queryMicroServiceInfo("serviceName", "v1")).thenThrow(expectedException);
+
+ //when
+ try {
+ msbApiProvider.getMicroServiceUrl("serviceName", "v1");
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to get micro service URL for serviceName with version v1", e.getMessage());
+ verify(logger).error("Unable to get micro service URL for serviceName with version v1", expectedException);
+ }
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIExternalSystemInfoProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIExternalSystemInfoProvider.java
new file mode 100644
index 00000000..c1da617e
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIExternalSystemInfoProvider.java
@@ -0,0 +1,189 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mock;
+import org.onap.aai.domain.yang.v11.EsrSystemInfo;
+import org.onap.aai.domain.yang.v11.EsrSystemInfoList;
+import org.onap.aai.domain.yang.v11.EsrVnfm;
+import org.onap.aai.domain.yang.v11.ObjectFactory;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vnfmdriver.model.VimInfo;
+import org.onap.vnfmdriver.model.VnfmInfo;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestAAIExternalSystemInfoProvider extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ private AAIExternalSystemInfoProvider aaiExternalSystemInfoProvider;
+ @Mock
+ private AAIRestApiProvider aaiRestApiProvider;
+
+ @Before
+ public void init() {
+ aaiExternalSystemInfoProvider = new AAIExternalSystemInfoProvider(environment, aaiRestApiProvider);
+ setField(AAIExternalSystemInfoProvider.class, "logger", logger);
+ }
+
+ /**
+ * test query VIM success scenario
+ */
+ @Test
+ public void testVim() throws Exception {
+ EsrSystemInfoList vims = OBJECT_FACTORY.createEsrSystemInfoList();
+ EsrSystemInfo vim = OBJECT_FACTORY.createEsrSystemInfo();
+ vims.getEsrSystemInfo().add(vim);
+ vim.setPassword("myPassword");
+ vim.setUserName("myUsername");
+ vim.setServiceUrl("http://1.2.3.4:1234/a");
+ vim.setVersion("v123");
+ vim.setSystemStatus("active");
+ vim.setSystemName("name");
+ vim.setType("type");
+ vim.setSslInsecure(true);
+ vim.setVendor("vendor");
+ when(aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/esr-system-info-list", EsrSystemInfoList.class)).thenReturn(vims);
+ //when
+ VimInfo vimInfo = aaiExternalSystemInfoProvider.getVimInfo(VIM_ID);
+ assertEquals("myPassword", vimInfo.getPassword());
+ assertEquals("true", vimInfo.getSslInsecure());
+ assertEquals(null, vimInfo.getSslCacert());
+ assertEquals("myUsername", vimInfo.getUserName());
+ assertEquals("name", vimInfo.getDescription());
+ assertEquals("name", vimInfo.getName());
+ assertEquals("http://1.2.3.4:1234/a", vimInfo.getUrl());
+ assertEquals("active", vimInfo.getStatus());
+ assertEquals("type", vimInfo.getType());
+ assertEquals("v123", vimInfo.getVersion());
+ assertEquals(VIM_ID, vimInfo.getVimId());
+ assertEquals(null, vimInfo.getCreateTime());
+
+ }
+
+ /**
+ * test query VIM success scenario for SSL
+ */
+ @Test
+ public void testVimSsl() throws Exception {
+ EsrSystemInfoList vims = OBJECT_FACTORY.createEsrSystemInfoList();
+ EsrSystemInfo vim = OBJECT_FACTORY.createEsrSystemInfo();
+ vims.getEsrSystemInfo().add(vim);
+ vim.setPassword("myPassword");
+ vim.setUserName("myUsername");
+ vim.setServiceUrl("https://1.2.3.4:1234/a");
+ vim.setVersion("v123");
+ vim.setSystemStatus("active");
+ vim.setSystemName("name");
+ vim.setType("type");
+ vim.setSslInsecure(false);
+ vim.setSslCacert("cert");
+ vim.setVendor("vendor");
+ when(aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/esr-system-info-list", EsrSystemInfoList.class)).thenReturn(vims);
+ //when
+ VimInfo vimInfo = aaiExternalSystemInfoProvider.getVimInfo(VIM_ID);
+ assertEquals("myPassword", vimInfo.getPassword());
+ assertEquals("false", vimInfo.getSslInsecure());
+ assertEquals("cert", vimInfo.getSslCacert());
+ assertEquals("myUsername", vimInfo.getUserName());
+ assertEquals("name", vimInfo.getDescription());
+ assertEquals("name", vimInfo.getName());
+ assertEquals("https://1.2.3.4:1234/a", vimInfo.getUrl());
+ assertEquals("active", vimInfo.getStatus());
+ assertEquals("type", vimInfo.getType());
+ assertEquals("v123", vimInfo.getVersion());
+ assertEquals(VIM_ID, vimInfo.getVimId());
+ assertEquals(null, vimInfo.getCreateTime());
+ }
+
+ /**
+ * unable to query VIM from AAI results in error
+ */
+ @Test
+ public void testVimUnableToQuery() throws Exception {
+ RuntimeException expectedException = new RuntimeException();
+ when(aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/esr-system-info-list", EsrSystemInfoList.class)).thenThrow(expectedException);
+ //when
+ try {
+ aaiExternalSystemInfoProvider.getVimInfo(VIM_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to query VIM with myCloudOwnerId_myRegionName identifier from AAI", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * test VNFM query success scenario
+ */
+ @Test
+ public void testVnfmQuery() throws Exception {
+ EsrVnfm vnfm = OBJECT_FACTORY.createEsrVnfm();
+ vnfm.setVimId(VIM_ID);
+ vnfm.setEsrSystemInfoList(OBJECT_FACTORY.createEsrSystemInfoList());
+ EsrSystemInfo esrInfo = OBJECT_FACTORY.createEsrSystemInfo();
+ vnfm.getEsrSystemInfoList().getEsrSystemInfo().add(esrInfo);
+ esrInfo.setPassword("myPassword");
+ esrInfo.setUserName("myUsername");
+ esrInfo.setServiceUrl("https://1.2.3.4:1234/a");
+ esrInfo.setVersion("v123");
+ esrInfo.setSystemStatus("active");
+ esrInfo.setSystemName("name");
+ esrInfo.setType("type");
+ esrInfo.setSslInsecure(false);
+ esrInfo.setSslCacert("cert");
+ esrInfo.setVendor("vendor");
+ vnfm.setVnfmId(VNFM_ID);
+ when(aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.ESR, "/esr-vnfm-list/esr-vnfm/" + VNFM_ID + "?depth=all", EsrVnfm.class)).thenReturn(vnfm);
+
+ //when
+ VnfmInfo actualVnfmInfo = aaiExternalSystemInfoProvider.queryVnfmInfoFromSource(VNFM_ID);
+ //verify
+ assertEquals("myPassword", actualVnfmInfo.getPassword());
+ assertEquals("https://1.2.3.4:1234/a", actualVnfmInfo.getUrl());
+ assertEquals("myUsername", actualVnfmInfo.getUserName());
+ assertEquals(null, actualVnfmInfo.getCreateTime());
+ assertEquals(null, actualVnfmInfo.getDescription());
+ assertEquals("name", actualVnfmInfo.getName());
+ assertEquals("type", actualVnfmInfo.getType());
+ assertEquals("vendor", actualVnfmInfo.getVendor());
+ assertEquals("v123", actualVnfmInfo.getVersion());
+ assertEquals(VIM_ID, actualVnfmInfo.getVimId());
+ assertEquals(VNFM_ID, actualVnfmInfo.getVnfmId());
+ }
+
+ /**
+ * unable to query VNFM from AAI results in error
+ */
+ @Test
+ public void testVnfmUnableToQuery() throws Exception {
+ RuntimeException expectedException = new RuntimeException();
+ when(aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.ESR, "/esr-vnfm-list/esr-vnfm/" + VNFM_ID + "?depth=all", EsrVnfm.class)).thenThrow(expectedException);
+ //when
+ try {
+ aaiExternalSystemInfoProvider.queryVnfmInfoFromSource(VNFM_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to query VNFM with " + VNFM_ID + " identifier from AAI", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIRestApiProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIRestApiProvider.java
new file mode 100644
index 00000000..953f7da0
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestAAIRestApiProvider.java
@@ -0,0 +1,238 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.onap.aai.domain.yang.v11.GenericVnf;
+import org.onap.aai.domain.yang.v11.L3Network;
+import org.onap.aai.domain.yang.v11.ObjectFactory;
+import org.onap.aai.restclient.client.OperationResult;
+import org.onap.aai.restclient.client.RestClient;
+import org.onap.aai.restclient.enums.RestAuthenticationMode;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import javax.xml.bind.JAXBContext;
+import java.io.ByteArrayOutputStream;
+import java.io.StringReader;
+import java.util.List;
+import java.util.Map;
+import java.util.NoSuchElementException;
+
+import static com.google.common.collect.Lists.newArrayList;
+import static java.util.Base64.getEncoder;
+import static javax.ws.rs.core.MediaType.APPLICATION_XML_TYPE;
+import static junit.framework.TestCase.*;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestAAIRestApiProvider extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ @Mock
+ private RestClient restClient;
+ private AAIRestApiProvider aaiRestApiProvider;
+ private ArgumentCaptor<Map> headers = ArgumentCaptor.forClass(Map.class);
+ private ArgumentCaptor<String> payload = ArgumentCaptor.forClass(String.class);
+
+ private OperationResult result = new OperationResult();
+
+ public static String marshall(Object object) throws Exception {
+ ByteArrayOutputStream bos = new ByteArrayOutputStream();
+ JAXBContext.newInstance(object.getClass()).createMarshaller().marshal(object, bos);
+ return bos.toString();
+ }
+
+ public static <T> T unmarshal(String content, Class<T> clazz) {
+ try {
+ return (T) JAXBContext.newInstance(clazz).createUnmarshaller().unmarshal(new StringReader(content));
+ } catch (Exception e) {
+ throw new RuntimeException();
+ }
+ }
+
+ @Before
+ public void init() {
+ //MockitoAnnotations.initMocks(this);
+ AAIRestApiProvider real = new AAIRestApiProvider(msbApiProvider);
+ setField(AAIRestApiProvider.class, "logger", logger);
+ setFieldWithPropertyAnnotation(real, "${aaiUsername}", "aaiUsername");
+ setFieldWithPropertyAnnotation(real, "${aaiPassword}", "aaiPassword");
+ aaiRestApiProvider = Mockito.spy(real);
+ when(aaiRestApiProvider.buildRawClient()).thenReturn(restClient);
+ when(restClient.basicAuthPassword("aaiPassword")).thenReturn(restClient);
+ when(restClient.basicAuthUsername("aaiUsername")).thenReturn(restClient);
+ when(restClient.authenticationMode(RestAuthenticationMode.SSL_BASIC)).thenReturn(restClient);
+ when(msbApiProvider.getMicroServiceUrl(AAIRestApiProvider.AAIService.CLOUD.getServiceName(), "v11")).thenReturn("x://1.2.3.4:4/a");
+ result.setResultCode(201);
+ }
+
+ /**
+ * test HTTP GET success scenario
+ */
+ @Test
+ public void testGetSuccess() throws Exception {
+ GenericVnf vnf = OBJECT_FACTORY.createGenericVnf();
+ vnf.setVnfId("myVnfId");
+ when(restClient.get(eq("x://1.2.3.4:4/a/myurl"), headers.capture(), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ result.setResult(marshall(vnf));
+ //when
+ GenericVnf actualVnf = aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl", GenericVnf.class);
+ //verify
+ assertEquals(vnf.getVnfId(), actualVnf.getVnfId());
+ assertHeaders();
+ }
+
+ /**
+ * HTTP GET on non existing resource results in {@link java.util.NoSuchElementException}
+ */
+ @Test
+ public void testGetMissingResource() throws Exception {
+ when(restClient.get(eq("x://1.2.3.4:4/a/myurl"), headers.capture(), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ result.setResultCode(404);
+ //when
+ try {
+ aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl", GenericVnf.class);
+ fail();
+ } catch (NoSuchElementException e) {
+ verify(logger).debug("The resource at /myurl does not exists");
+ assertEquals("The resource at /myurl does not exists", e.getMessage());
+ }
+ }
+
+ /**
+ * Non known HTTP response code is propagated
+ */
+ @Test
+ public void testUnknownErroCode() throws Exception {
+ when(restClient.get(eq("x://1.2.3.4:4/a/myurl"), headers.capture(), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ result.setResultCode(502);
+ result.setFailureCause("myFail");
+ //when
+ try {
+ aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl", GenericVnf.class);
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error("Bad response. Code: 502 cause: myFail");
+ assertEquals("Bad response. Code: 502 cause: myFail", e.getMessage());
+ }
+ }
+
+ /**
+ * response content is not used when not requesting result
+ */
+ @Test
+ public void testNoResult() throws Exception {
+ when(restClient.get(eq("x://1.2.3.4:4/a/myurl"), headers.capture(), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ result.setResultCode(202);
+ //when
+ Void result = aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl", Void.class);
+ //verify
+ assertNull(result);
+ }
+
+ /**
+ * test HTTP PUT success scenario
+ */
+ @Test
+ public void putSuccess() throws Exception {
+ when(restClient.put(eq("x://1.2.3.4:4/a/myurl"), payload.capture(), headers.capture(), eq(APPLICATION_XML_TYPE), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ GenericVnf request = OBJECT_FACTORY.createGenericVnf();
+ request.setVnfId("myVnfId");
+ L3Network response = OBJECT_FACTORY.createL3Network();
+ response.setNetworkId("myNetworkId");
+ result.setResult(marshall(response));
+ //when
+ L3Network actualResponse = aaiRestApiProvider.put(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl", request, L3Network.class);
+ //verify
+ GenericVnf actualValue = unmarshal(payload.getValue(), GenericVnf.class);
+ assertEquals("myVnfId", actualValue.getVnfId());
+ assertEquals("myNetworkId", actualResponse.getNetworkId());
+ assertHeaders();
+ }
+
+ /**
+ * test HTTP delete success scenario
+ */
+ @Test
+ public void deleteSuccess() throws Exception {
+ when(restClient.delete(eq("x://1.2.3.4:4/a/myurl"), headers.capture(), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ //when
+ aaiRestApiProvider.delete(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl");
+ //verify
+ assertHeaders();
+ //the when above is the verify
+ }
+
+ /**
+ * invalid request content results in error
+ */
+ @Test
+ public void testInvalidInput() throws Exception {
+ when(restClient.put(eq("x://1.2.3.4:4/a/myurl"), payload.capture(), headers.capture(), eq(APPLICATION_XML_TYPE), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ //when
+ try {
+ aaiRestApiProvider.put(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl", "Invalid content", L3Network.class);
+ //verify
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to marshal content", e.getMessage());
+ verify(logger).error("Unable to marshal content", e.getCause());
+ }
+ }
+
+ /**
+ * invalid response content results in error
+ */
+ @Test
+ public void testInvalidResponse() throws Exception {
+ when(restClient.put(eq("x://1.2.3.4:4/a/myurl"), payload.capture(), headers.capture(), eq(APPLICATION_XML_TYPE), eq(APPLICATION_XML_TYPE))).thenReturn(result);
+ GenericVnf request = OBJECT_FACTORY.createGenericVnf();
+ request.setVnfId("myVnfId");
+ result.setResult("invalid");
+ //when
+ try {
+ aaiRestApiProvider.put(logger, AAIRestApiProvider.AAIService.CLOUD, "/myurl", request, L3Network.class);
+ //verify
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to unmarshal content", e.getMessage());
+ verify(logger).error("Unable to unmarshal content", e.getCause());
+ }
+ }
+
+ /**
+ * test AAI service names in AAI
+ */
+ @Test
+ public void testServiceNames() {
+ //the names have been base64-ed to prevent "smart" IDEs (idea) to refactor the tests too for the otherwise known fix constants in external systems
+ assertEquals("YWFpLWNsb3VkSW5mcmFzdHJ1Y3R1cmU=", getEncoder().encodeToString(AAIRestApiProvider.AAIService.CLOUD.getServiceName().getBytes()));
+ assertEquals("YWFpLW5ldHdvcms=", getEncoder().encodeToString(AAIRestApiProvider.AAIService.NETWORK.getServiceName().getBytes()));
+ assertEquals("YWFpLWV4dGVybmFsU3lzdGVt", getEncoder().encodeToString(AAIRestApiProvider.AAIService.ESR.getServiceName().getBytes()));
+ }
+
+ private void assertHeaders() {
+ Map<String, List<String>> actualHeaders = headers.getValue();
+ assertEquals(2, actualHeaders.size());
+ assertEquals(newArrayList("NokiaSVNFM"), actualHeaders.get("X-FromAppId"));
+ assertEquals(newArrayList("application/xml"), actualHeaders.get("Accept"));
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestGrantlessGrantManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestGrantlessGrantManager.java
new file mode 100644
index 00000000..ad9b7fc8
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestGrantlessGrantManager.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vnfmdriver.model.GrantVNFResponseVim;
+
+import static junit.framework.TestCase.assertEquals;
+import static org.mockito.Mockito.verify;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestGrantlessGrantManager extends TestBase {
+ private GrantlessGrantManager grantlessGrantManager;
+
+ @Before
+ public void init() {
+ grantlessGrantManager = new GrantlessGrantManager();
+ setField(GrantlessGrantManager.class, "logger", logger);
+ }
+
+ /**
+ * grant is only logged for healing
+ */
+ @Test
+ public void testGrantForHeal() throws Exception {
+ //when
+ grantlessGrantManager.requestGrantForHeal(null, null, null, null, null, null);
+ //verify
+ verify(logger).info("No grant is requested in direct mode");
+ }
+
+ /**
+ * grant is only logged for instantiation
+ */
+ @Test
+ public void testGrantForInstantiate() throws Exception {
+ //when
+ GrantVNFResponseVim grant = grantlessGrantManager.requestGrantForInstantiate(null, null, VIM_ID, null, null, null, null);
+ //verify
+ verify(logger).info("No grant is requested in direct mode");
+ assertEquals(VIM_ID, grant.getVimId());
+ }
+
+ /**
+ * grant is only logged for scaling
+ */
+ @Test
+ public void testGrantForScaling() throws Exception {
+ //when
+ grantlessGrantManager.requestGrantForScale(null, null, null, null, null, null);
+ //verify
+ verify(logger).info("No grant is requested in direct mode");
+ }
+
+ /**
+ * grant is only logged for termination
+ */
+ @Test
+ public void testGrantForTerminate() throws Exception {
+ //when
+ grantlessGrantManager.requestGrantForTerminate(null, null, null, null, null, null);
+ //verify
+ verify(logger).info("No grant is requested in direct mode");
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestSdcPackageProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestSdcPackageProvider.java
new file mode 100644
index 00000000..199f7255
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/TestSdcPackageProvider.java
@@ -0,0 +1,130 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct;
+
+import org.apache.http.client.methods.HttpGet;
+import org.junit.Before;
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+import java.util.NoSuchElementException;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.apache.http.HttpHeaders.ACCEPT;
+import static org.mockito.Matchers.any;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager.SERVICE_NAME;
+import static org.springframework.http.MediaType.APPLICATION_OCTET_STREAM_VALUE;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestSdcPackageProvider extends TestBase {
+ private SdcPackageProvider sdcPackageProvider;
+
+ @Before
+ public void init() {
+ sdcPackageProvider = new SdcPackageProvider(msbApiProvider, driverProperties);
+ setField(SdcPackageProvider.class, "logger", logger);
+ setFieldWithPropertyAnnotation(sdcPackageProvider, "${sdcUsername}", "sdcUsername");
+ setFieldWithPropertyAnnotation(sdcPackageProvider, "${sdcPassword}", "sdcPassword");
+ when(msbApiProvider.getMicroServiceUrl("sdc", "v1")).thenReturn("https://1.2.3.4:456/g");
+ }
+
+ /**
+ * test package download from SDC
+ */
+ @Test
+ public void testPackageDownload() throws Exception {
+ when(entity.getContent()).thenReturn(new ByteArrayInputStream("test".getBytes()));
+ //when
+ byte[] result = sdcPackageProvider.getPackage("csarId");
+ //verify
+ assertEquals("test", new String("test"));
+ HttpGet httpGet = (HttpGet) request.getValue();
+ assertEquals(VNFM_ID, httpGet.getFirstHeader("X-ECOMP-InstanceID").getValue());
+ assertEquals(SERVICE_NAME, httpGet.getFirstHeader("X-FromAppId").getValue());
+ assertEquals(APPLICATION_OCTET_STREAM_VALUE, httpGet.getFirstHeader(ACCEPT).getValue());
+ assertEquals("https://1.2.3.4:456/g/sdc/v1/catalog/resources/csarId/toscaModel", httpGet.getURI().toASCIIString());
+ }
+
+ /**
+ * failure to download package from SDC is propagated
+ */
+ @Test
+ public void testFailedPackageDownload() throws Exception {
+ IOException expectedException = new IOException();
+ when(httpClient.execute(any())).thenThrow(expectedException);
+ try {
+ sdcPackageProvider.getPackage("csarId");
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to download csarId package from SDC", e.getMessage());
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to download csarId package from SDC", expectedException);
+ }
+ }
+
+ /**
+ * get VNFD from ONAP package
+ */
+ @Test
+ public void testGetVnfd() throws Exception {
+ byte[] onapPackageContent = TestUtil.loadFile("unittests/TestCbamCatalogManager.sample.csar");
+ when(entity.getContent()).thenReturn(new ByteArrayInputStream(onapPackageContent));
+ //when
+ String cbamVnfdId = sdcPackageProvider.getCbamVnfdId("csarId");
+ //verify
+ assertEquals("Nokia~SimpleDual_scalable~1.0~1.0", cbamVnfdId);
+ }
+
+ /**
+ * unable to download package from SDC during get CBAM VNFD id
+ */
+ @Test
+ public void testUnableToDownloadPackageDuringVnfdIdGet() throws Exception {
+ IOException expectedException = new IOException();
+ when(httpClient.execute(any())).thenThrow(expectedException);
+ try {
+ sdcPackageProvider.getCbamVnfdId("csarId");
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to download csarId package from SDC", e.getMessage());
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to download csarId package from SDC", expectedException);
+ }
+ }
+
+ /**
+ * invalid VNF package results in error
+ */
+ @Test
+ public void testInvalidVNFDContent() throws Exception {
+ byte[] onapPackageContent = "invalidZip".getBytes();
+ when(entity.getContent()).thenReturn(new ByteArrayInputStream(onapPackageContent));
+ try {
+ sdcPackageProvider.getCbamVnfdId("csarId");
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to extract CBAM VNFD id from ONAP package", e.getMessage());
+ verify(logger).error(eq("Unable to extract CBAM VNFD id from ONAP package"), any(NoSuchElementException.class));
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAAINotificationProcessor.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAAINotificationProcessor.java
new file mode 100644
index 00000000..bc8f7835
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAAINotificationProcessor.java
@@ -0,0 +1,253 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.model.*;
+import org.jetbrains.annotations.NotNull;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InOrder;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedConnectionPoints;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedCp;
+
+import java.util.ArrayList;
+import java.util.UUID;
+
+import static com.nokia.cbam.lcm.v32.model.ChangeType.*;
+import static java.util.Optional.empty;
+import static java.util.Optional.of;
+import static org.mockito.Mockito.never;
+import static org.mockito.Mockito.verify;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestAAINotificationProcessor extends TestBase {
+ @Mock
+ private GenericVnfManager genericVnfManager;
+ @Mock
+ private L3NetworkManager l3NetworkManager;
+ @Mock
+ private LInterfaceManager lInterfaceManager;
+ @Mock
+ private VnfcManager vnfcManager;
+ @Mock
+ private VserverManager vserverManager;
+ private AAINotificationProcessor aaiNotificationProcessor;
+
+ @Before
+ public void init() {
+ aaiNotificationProcessor = new AAINotificationProcessor(genericVnfManager, l3NetworkManager, lInterfaceManager, vnfcManager, vserverManager);
+ setField(AAINotificationProcessor.class, "logger", logger);
+ }
+
+ /**
+ * test objects are manipulated in correct order in AAA
+ * (other is dependency between the objects though relations)
+ */
+ @Test
+ public void testObjectManipulationOrder() throws Exception {
+ VnfLifecycleChangeNotification recievenNotification = new VnfLifecycleChangeNotification();
+ recievenNotification.setAffectedVnfcs(new ArrayList<>());
+ recievenNotification.setAffectedVirtualLinks(new ArrayList<>());
+ ArrayList<AffectedVirtualStorage> affectedVirtualStorages = new ArrayList<>();
+ recievenNotification.setAffectedVirtualStorages(affectedVirtualStorages);
+ recievenNotification.setVnfInstanceId(VNF_ID);
+ recievenNotification.setStatus(OperationStatus.STARTED);
+ AffectedVirtualLink addedLink = buildVl(recievenNotification, ADDED);
+ AffectedVirtualLink removedLink = buildVl(recievenNotification, REMOVED);
+ AffectedVirtualLink modifiedLink = buildVl(recievenNotification, MODIFIED);
+ AffectedVnfc addedVnfc = buildVnfc(recievenNotification, ADDED, "tenantId1");
+ AffectedVnfc removedVnfc = buildVnfc(recievenNotification, REMOVED, "tenantId2");
+ AffectedVnfc modifedVnfc = buildVnfc(recievenNotification, MODIFIED, "tenantId3");
+ boolean inMaintenance = true;
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+
+ ReportedAffectedCp removedCp = buildCp();
+ removedCp.setServerProviderId("serverId");
+ affectedConnectionPoints.getPre().add(removedCp);
+
+ ReportedAffectedCp removedCpWithoutServer = buildCp();
+ removedCpWithoutServer.setServerProviderId(null);
+ affectedConnectionPoints.getPre().add(removedCpWithoutServer);
+
+ ReportedAffectedCp addedCp = buildCp();
+ addedCp.setServerProviderId("serverId");
+ affectedConnectionPoints.getPost().add(addedCp);
+ //when
+ aaiNotificationProcessor.processNotification(recievenNotification, null, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ InOrder inOrder = Mockito.inOrder(genericVnfManager, l3NetworkManager, lInterfaceManager, vnfcManager, vserverManager);
+ inOrder.verify(l3NetworkManager).update(VIM_ID, VNF_ID, addedLink);
+ inOrder.verify(l3NetworkManager).update(VIM_ID, VNF_ID, modifiedLink);
+ inOrder.verify(vserverManager).update(VIM_ID, VNF_ID, addedVnfc, affectedVirtualStorages, inMaintenance);
+ inOrder.verify(vnfcManager).update(VIM_ID, "tenantId1", VNF_ID, addedVnfc, inMaintenance);
+ inOrder.verify(vserverManager).update(VIM_ID, VNF_ID, modifedVnfc, affectedVirtualStorages, inMaintenance);
+ inOrder.verify(vnfcManager).update(VIM_ID, "tenantId3", VNF_ID, modifedVnfc, inMaintenance);
+ inOrder.verify(lInterfaceManager).delete(VIM_ID, removedCp);
+ inOrder.verify(lInterfaceManager).update(VNF_ID, VIM_ID, addedCp, inMaintenance);
+ inOrder.verify(vnfcManager).delete(VNF_ID, removedVnfc);
+ inOrder.verify(vserverManager).delete(VIM_ID, removedVnfc);
+ inOrder.verify(l3NetworkManager).delete(VNF_ID, removedLink);
+ verify(lInterfaceManager, never()).update(VNF_ID, VIM_ID, removedCpWithoutServer, inMaintenance);
+ verify(lInterfaceManager, never()).delete(VIM_ID, removedCpWithoutServer);
+ }
+
+ /**
+ * - unchanged CP is updated
+ * - changed CP is updated
+ */
+ @Test
+ public void testCps() throws Exception {
+ VnfLifecycleChangeNotification recievenNotification = new VnfLifecycleChangeNotification();
+ recievenNotification.setAffectedVnfcs(new ArrayList<>());
+ recievenNotification.setAffectedVirtualLinks(new ArrayList<>());
+ recievenNotification.setVnfInstanceId(VNF_ID);
+ recievenNotification.setStatus(OperationStatus.STARTED);
+ ArrayList<AffectedVirtualStorage> affectedVirtualStorages = new ArrayList<>();
+ recievenNotification.setAffectedVirtualStorages(affectedVirtualStorages);
+ boolean inMaintenance = true;
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+
+ ReportedAffectedCp unchangedCp = buildCp();
+ unchangedCp.setCpId("unchanged");
+ affectedConnectionPoints.getPre().add(unchangedCp);
+ affectedConnectionPoints.getPost().add(unchangedCp);
+
+ ReportedAffectedCp changedCpBefore = buildCp();
+ changedCpBefore.setCpId("changedBefore");
+ ReportedAffectedCp changedCpAfter = buildCp();
+ changedCpAfter.setCpId("changedAfter");
+ changedCpAfter.setCpId(changedCpBefore.getCpId());
+ affectedConnectionPoints.getPre().add(changedCpBefore);
+ affectedConnectionPoints.getPost().add(changedCpAfter);
+
+ //when
+ aaiNotificationProcessor.processNotification(recievenNotification, null, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ verify(lInterfaceManager).update(VNF_ID, VIM_ID, unchangedCp, inMaintenance);
+ verify(lInterfaceManager, never()).update(VNF_ID, VIM_ID, changedCpBefore, inMaintenance);
+ verify(lInterfaceManager).update(VNF_ID, VIM_ID, changedCpAfter, inMaintenance);
+ }
+
+ /**
+ * the end notification calls resource managers with not in maintenance state
+ */
+ @Test
+ public void testEndNotification() throws Exception {
+ VnfLifecycleChangeNotification recievenNotification = new VnfLifecycleChangeNotification();
+ recievenNotification.setAffectedVnfcs(new ArrayList<>());
+ recievenNotification.setAffectedVirtualLinks(new ArrayList<>());
+ ArrayList<AffectedVirtualStorage> affectedVirtualStorages = new ArrayList<>();
+ recievenNotification.setAffectedVirtualStorages(affectedVirtualStorages);
+ recievenNotification.setVnfInstanceId(VNF_ID);
+ recievenNotification.setStatus(OperationStatus.FINISHED);
+ AffectedVirtualLink addedLink = buildVl(recievenNotification, ADDED);
+ AffectedVirtualLink removedLink = buildVl(recievenNotification, REMOVED);
+ AffectedVirtualLink modifiedLink = buildVl(recievenNotification, MODIFIED);
+ AffectedVnfc addedVnfc = buildVnfc(recievenNotification, ADDED, "tenantId1");
+ AffectedVnfc removedVnfc = buildVnfc(recievenNotification, REMOVED, "tenantId2");
+ AffectedVnfc modifedVnfc = buildVnfc(recievenNotification, MODIFIED, "tenantId3");
+ boolean inMaintenance = false;
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+
+ ReportedAffectedCp removedCp = buildCp();
+ removedCp.setServerProviderId("serverId");
+ affectedConnectionPoints.getPre().add(removedCp);
+
+ ReportedAffectedCp removedCpWithoutServer = buildCp();
+ removedCpWithoutServer.setServerProviderId(null);
+ affectedConnectionPoints.getPre().add(removedCpWithoutServer);
+
+ ReportedAffectedCp addedCp = buildCp();
+ addedCp.setServerProviderId("serverId");
+ affectedConnectionPoints.getPost().add(addedCp);
+
+ ReportedAffectedCp cpWithoutServer = buildCp();
+ cpWithoutServer.setServerProviderId(null);
+ affectedConnectionPoints.getPost().add(cpWithoutServer);
+
+ //when
+ aaiNotificationProcessor.processNotification(recievenNotification, null, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ InOrder inOrder = Mockito.inOrder(genericVnfManager, l3NetworkManager, lInterfaceManager, vnfcManager, vserverManager);
+ inOrder.verify(l3NetworkManager).update(VIM_ID, VNF_ID, addedLink);
+ inOrder.verify(l3NetworkManager).update(VIM_ID, VNF_ID, modifiedLink);
+ inOrder.verify(vserverManager).update(VIM_ID, VNF_ID, addedVnfc, affectedVirtualStorages, inMaintenance);
+ inOrder.verify(vnfcManager).update(VIM_ID, "tenantId1", VNF_ID, addedVnfc, inMaintenance);
+ inOrder.verify(vserverManager).update(VIM_ID, VNF_ID, modifedVnfc, affectedVirtualStorages, inMaintenance);
+ inOrder.verify(vnfcManager).update(VIM_ID, "tenantId3", VNF_ID, modifedVnfc, inMaintenance);
+ inOrder.verify(lInterfaceManager).delete(VIM_ID, removedCp);
+ inOrder.verify(lInterfaceManager).update(VNF_ID, VIM_ID, addedCp, inMaintenance);
+ inOrder.verify(vnfcManager).delete(VNF_ID, removedVnfc);
+ inOrder.verify(vserverManager).delete(VIM_ID, removedVnfc);
+ inOrder.verify(l3NetworkManager).delete(VNF_ID, removedLink);
+ verify(lInterfaceManager, never()).update(VNF_ID, VIM_ID, removedCpWithoutServer, inMaintenance);
+ verify(lInterfaceManager, never()).delete(VIM_ID, removedCpWithoutServer);
+ verify(logger).warn("The changed {} connection point is not linked to any server", cpWithoutServer.getCpId());
+ }
+
+
+
+ /**
+ * if changes connection points are not present a warning is logged
+ */
+ @Test
+ public void testMissingChangedConnectionPoints() throws Exception {
+ VnfLifecycleChangeNotification recievenNotification = new VnfLifecycleChangeNotification();
+ recievenNotification.setAffectedVnfcs(new ArrayList<>());
+ recievenNotification.setAffectedVirtualLinks(new ArrayList<>());
+ recievenNotification.setVnfInstanceId(VNF_ID);
+ //when
+ aaiNotificationProcessor.processNotification(recievenNotification, null, empty(), VIM_ID);
+ //verify
+ verify(logger).warn("The changed connection points are not present in VNF with {} identifier", VNF_ID);
+ }
+
+ @NotNull
+ private ReportedAffectedCp buildCp() {
+ ReportedAffectedCp cp = new ReportedAffectedCp();
+ cp.setServerProviderId(UUID.randomUUID().toString());
+ cp.setName(UUID.randomUUID().toString());
+ cp.setEcpdId(UUID.randomUUID().toString());
+ cp.setMacAddress(UUID.randomUUID().toString());
+ cp.setNetworkProviderId(UUID.randomUUID().toString());
+ cp.setCpdId(UUID.randomUUID().toString());
+ cp.setCpId(UUID.randomUUID().toString());
+ cp.setTenantId(UUID.randomUUID().toString());
+ return cp;
+ }
+
+ private AffectedVirtualLink buildVl(VnfLifecycleChangeNotification recievenNotification, ChangeType changeType) {
+ AffectedVirtualLink affectedVirtualLink = new AffectedVirtualLink();
+ affectedVirtualLink.setChangeType(changeType);
+ recievenNotification.getAffectedVirtualLinks().add(affectedVirtualLink);
+ return affectedVirtualLink;
+ }
+
+ private AffectedVnfc buildVnfc(VnfLifecycleChangeNotification recievenNotification, ChangeType changeType, String tenantId) {
+ AffectedVnfc addedVnfc = new AffectedVnfc();
+ addedVnfc.setChangeType(changeType);
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("tenantId", tenantId);
+ addedVnfc.setComputeResource(new ResourceHandle());
+ addedVnfc.getComputeResource().setAdditionalData(additionalData);
+ recievenNotification.getAffectedVnfcs().add(addedVnfc);
+ return addedVnfc;
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAbstractManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAbstractManager.java
new file mode 100644
index 00000000..2495daf1
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestAbstractManager.java
@@ -0,0 +1,230 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.google.gson.JsonObject;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mock;
+import org.onap.aai.domain.yang.v11.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.DriverProperties;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.slf4j.Logger;
+
+import java.util.NoSuchElementException;
+
+import static junit.framework.TestCase.assertEquals;
+import static org.mockito.Mockito.when;
+
+public class TestAbstractManager extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ @Mock
+ private AAIRestApiProvider aaiRestApiProvider;
+ private DummyManager dummyManager;
+
+ @Before
+ public void init() {
+ dummyManager = new DummyManager(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ }
+
+ /**
+ * if the REST resource does not exists the provided instance is used
+ */
+ @Test
+ public void testIfResourceDoesNotExists() throws Exception {
+ GenericVnf newInstance = OBJECT_FACTORY.createGenericVnf();
+ when(aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "url", GenericVnf.class)).thenThrow(new NoSuchElementException());
+ //when
+ GenericVnf actualInstance = dummyManager.createOrGet(AAIRestApiProvider.AAIService.CLOUD, "url", newInstance);
+ //verify
+ assertEquals(newInstance, actualInstance);
+ }
+
+ /**
+ * if the REST resource exists it is not recreated
+ */
+ @Test
+ public void testIfResourceExists() throws Exception {
+ GenericVnf newInstance = OBJECT_FACTORY.createGenericVnf();
+ GenericVnf existingInstance = OBJECT_FACTORY.createGenericVnf();
+ existingInstance.setVnfId("id");
+ when(aaiRestApiProvider.get(logger, AAIRestApiProvider.AAIService.CLOUD, "url", GenericVnf.class)).thenReturn(existingInstance);
+ //when
+ GenericVnf actualInstance = dummyManager.createOrGet(AAIRestApiProvider.AAIService.CLOUD, "url", newInstance);
+ //verify
+ assertEquals(existingInstance, actualInstance);
+ }
+
+ @Test
+ public void testBuildRelationshipData() {
+ RelationshipData relationshipData = AbstractManager.buildRelationshipData("key", "value");
+ assertEquals("key", relationshipData.getRelationshipKey());
+ assertEquals("value", relationshipData.getRelationshipValue());
+ }
+
+ @Test
+ public void testExtractMandatoryValue() {
+ JsonObject object = new JsonObject();
+ object.addProperty("key", "value");
+ assertEquals("value", AbstractManager.extractMandatoryValue(object, "key"));
+ }
+
+ /**
+ * the same relation is replaced
+ */
+ @Test
+ public void testAddSingletonRelationForExisting() {
+ RelationshipList relations = OBJECT_FACTORY.createRelationshipList();
+ Relationship relation = OBJECT_FACTORY.createRelationship();
+ relation.setRelatedTo("unknownRelation");
+ relations.getRelationship().add(relation);
+ Relationship sameRelation = OBJECT_FACTORY.createRelationship();
+ sameRelation.setRelatedTo("relatedTo");
+ relations.getRelationship().add(sameRelation);
+ RelationshipData data = OBJECT_FACTORY.createRelationshipData();
+ data.setRelationshipValue("v");
+ data.setRelationshipKey("k");
+ sameRelation.getRelationshipData().add(data);
+
+ Relationship newRelation = OBJECT_FACTORY.createRelationship();
+ newRelation.setRelatedTo("relatedTo");
+ RelationshipData data2 = OBJECT_FACTORY.createRelationshipData();
+ data2.setRelationshipValue("v2");
+ data2.setRelationshipKey("k2");
+ newRelation.getRelationshipData().add(data2);
+
+ //when
+ AbstractManager.addSingletonRelation(relations, newRelation);
+ //verify
+
+ assertEquals(2, relations.getRelationship().size());
+ assertEquals(1, relations.getRelationship().get(1).getRelationshipData().size());
+ assertEquals("k2", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipKey());
+ assertEquals("v2", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipValue());
+ }
+
+ /**
+ * the missing relation is created
+ */
+ @Test
+ public void testAddSingletonRelation() {
+ RelationshipList relations = OBJECT_FACTORY.createRelationshipList();
+ Relationship relation = OBJECT_FACTORY.createRelationship();
+ relation.setRelatedTo("unknownRelation");
+ relations.getRelationship().add(relation);
+
+ Relationship newRelation = OBJECT_FACTORY.createRelationship();
+ newRelation.setRelatedTo("relatedTo");
+ RelationshipData data2 = OBJECT_FACTORY.createRelationshipData();
+ data2.setRelationshipValue("v2");
+ data2.setRelationshipKey("k2");
+ newRelation.getRelationshipData().add(data2);
+
+ //when
+ AbstractManager.addSingletonRelation(relations, newRelation);
+ //verify
+ assertEquals(2, relations.getRelationship().size());
+ assertEquals(1, relations.getRelationship().get(1).getRelationshipData().size());
+ assertEquals("k2", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipKey());
+ assertEquals("v2", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipValue());
+ }
+
+ /**
+ * the same relation is replaced
+ */
+ @Test
+ public void testAddMissingRelationForExisting() {
+ RelationshipList relations = OBJECT_FACTORY.createRelationshipList();
+ Relationship relation = OBJECT_FACTORY.createRelationship();
+ relation.setRelatedTo("unknownRelation");
+ relations.getRelationship().add(relation);
+ Relationship sameRelation = OBJECT_FACTORY.createRelationship();
+ sameRelation.setRelatedTo("relatedTo");
+ relations.getRelationship().add(sameRelation);
+ RelationshipData data = OBJECT_FACTORY.createRelationshipData();
+ data.setRelationshipValue("v");
+ data.setRelationshipKey("k");
+ sameRelation.getRelationshipData().add(data);
+
+ Relationship newRelation = OBJECT_FACTORY.createRelationship();
+ newRelation.setRelatedTo("relatedTo");
+ RelationshipData data2 = OBJECT_FACTORY.createRelationshipData();
+ data2.setRelationshipValue("v2");
+ data2.setRelationshipKey("k2");
+ newRelation.getRelationshipData().add(data2);
+
+ //when
+ AbstractManager.addMissingRelation(relations, newRelation);
+ //verify
+
+ assertEquals(3, relations.getRelationship().size());
+ assertEquals(1, relations.getRelationship().get(1).getRelationshipData().size());
+ assertEquals("k", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipKey());
+ assertEquals("v", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipValue());
+ assertEquals("k2", relations.getRelationship().get(2).getRelationshipData().get(0).getRelationshipKey());
+ assertEquals("v2", relations.getRelationship().get(2).getRelationshipData().get(0).getRelationshipValue());
+ }
+
+ /**
+ * adding the same relation is not duplicated
+ */
+ @Test
+ public void testAddMissingRelation() {
+ RelationshipList relations = OBJECT_FACTORY.createRelationshipList();
+ Relationship relation = OBJECT_FACTORY.createRelationship();
+ relation.setRelatedTo("unknownRelation");
+ relations.getRelationship().add(relation);
+
+ Relationship sameRelation = OBJECT_FACTORY.createRelationship();
+ sameRelation.setRelatedTo("relatedTo");
+ relations.getRelationship().add(sameRelation);
+ RelationshipData data = OBJECT_FACTORY.createRelationshipData();
+ data.setRelationshipValue("v");
+ data.setRelationshipKey("k");
+ sameRelation.getRelationshipData().add(data);
+
+ Relationship newRelation = OBJECT_FACTORY.createRelationship();
+ newRelation.setRelatedTo("relatedTo");
+ RelationshipData data2 = OBJECT_FACTORY.createRelationshipData();
+ data2.setRelationshipValue("v");
+ data2.setRelationshipKey("k");
+ newRelation.getRelationshipData().add(data2);
+
+ //when
+ AbstractManager.addMissingRelation(relations, newRelation);
+ //verify
+ assertEquals(2, relations.getRelationship().size());
+ assertEquals(1, relations.getRelationship().get(1).getRelationshipData().size());
+ assertEquals("k", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipKey());
+ assertEquals("v", relations.getRelationship().get(1).getRelationshipData().get(0).getRelationshipValue());
+ }
+
+ class DummyManager extends AbstractManager {
+
+ DummyManager(AAIRestApiProvider aaiRestApiProvider, CbamRestApiProvider cbamRestApiProvider, DriverProperties driverProperties) {
+ super(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ }
+
+ @Override
+ protected Logger getLogger() {
+ return logger;
+ }
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestGenericVnfManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestGenericVnfManager.java
new file mode 100644
index 00000000..861966f3
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestGenericVnfManager.java
@@ -0,0 +1,250 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
+import org.onap.aai.domain.yang.v11.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import java.util.HashSet;
+import java.util.NoSuchElementException;
+import java.util.Set;
+import java.util.concurrent.atomic.AtomicLong;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Matchers.anyLong;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.NETWORK;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestGenericVnfManager extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ private ArgumentCaptor<GenericVnf> payload = ArgumentCaptor.forClass(GenericVnf.class);
+
+ @Mock
+ private AAIRestApiProvider aaiRestApiProvider;
+ private GenericVnfManager genericVnfManager;
+ private VnfInfo vnfInfo = new VnfInfo();
+
+ static void assertRelation(RelationshipList relationShips, String relatedTo, RelationshipData... data) {
+ for (Relationship relationship : relationShips.getRelationship()) {
+ if (relationship.getRelatedTo().equals(relatedTo)) {
+ assertEquals(data.length, relationship.getRelationshipData().size());
+ int i = 0;
+ for (RelationshipData c : data) {
+ assertEquals(c.getRelationshipKey(), relationship.getRelationshipData().get(i).getRelationshipKey());
+ assertEquals(c.getRelationshipValue(), relationship.getRelationshipData().get(i).getRelationshipValue());
+ i++;
+ }
+ return;
+ }
+ }
+ fail();
+ }
+
+ @Before
+ public void init() {
+ genericVnfManager = new GenericVnfManager(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ setField(GenericVnfManager.class, "logger", logger);
+ AtomicLong currentTime = new AtomicLong(0L);
+ when(systemFunctions.currentTimeMillis()).thenAnswer(new Answer<Long>() {
+ @Override
+ public Long answer(InvocationOnMock invocation) throws Throwable {
+ return currentTime.get();
+ }
+ });
+ Mockito.doAnswer(new Answer() {
+ @Override
+ public Object answer(InvocationOnMock invocation) throws Throwable {
+ currentTime.addAndGet((Long) invocation.getArguments()[0] + 1);
+ return null;
+ }
+ }).when(systemFunctions).sleep(anyLong());
+ }
+
+ /**
+ * retrieving an existing VNF
+ */
+ @Test
+ public void testGetExistingVnf() throws Exception {
+ GenericVnf aaiVnf = OBJECT_FACTORY.createGenericVnf();
+ when(aaiRestApiProvider.get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class)).thenReturn(aaiVnf);
+ //when
+ GenericVnf vnf = genericVnfManager.getExistingVnf(VNF_ID);
+ //verify
+ assertEquals(aaiVnf, vnf);
+ }
+
+ /**
+ * if the VNF does not exist it is created
+ */
+ @Test
+ public void createNonExistingVnf() throws Exception {
+ GenericVnf vnfInAaai = OBJECT_FACTORY.createGenericVnf();
+ Set<GenericVnf> vnfs = new HashSet<>();
+ when(aaiRestApiProvider.get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class)).thenAnswer((Answer<GenericVnf>) invocation -> {
+ if (vnfs.size() == 0) {
+ throw new NoSuchElementException();
+ }
+ return vnfs.iterator().next();
+ });
+ when(cbamRestApiProvider.getCbamLcmApi(VNFM_ID).vnfsVnfInstanceIdGet(VNF_ID, CbamRestApiProvider.NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/generic-vnfs/generic-vnf/" + VNF_ID), payload.capture(), eq(Void.class))).thenAnswer(invocation -> {
+ vnfs.add(vnfInAaai);
+ return null;
+ });
+ vnfInfo.setName("vnfName");
+ //when
+ genericVnfManager.createOrUpdate(VNF_ID, true);
+ //verify
+ GenericVnf vnfSentToAai = payload.getValue();
+ assertEquals(VNF_ID, vnfSentToAai.getVnfId());
+ assertEquals(VNF_ID, vnfSentToAai.getVnfInstanceId());
+ assertEquals("NokiaVNF", vnfSentToAai.getVnfType());
+ assertEquals(true, vnfSentToAai.isInMaint());
+ assertEquals(true, vnfSentToAai.isIsClosedLoopDisabled());
+ assertEquals("vnfName", vnfSentToAai.getVnfName());
+ verify(systemFunctions, times(10)).sleep(3000);
+ verify(aaiRestApiProvider, times(10)).get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class);
+ }
+
+ /**
+ * if the VNF exist it is updated
+ */
+ @Test
+ public void testUpdateExistingVnf() throws Exception {
+ GenericVnf vnfInAaai = OBJECT_FACTORY.createGenericVnf();
+ vnfInAaai.setResourceVersion("v1");
+ when(aaiRestApiProvider.get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class)).thenReturn(vnfInAaai);
+ when(cbamRestApiProvider.getCbamLcmApi(VNFM_ID).vnfsVnfInstanceIdGet(VNF_ID, CbamRestApiProvider.NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/generic-vnfs/generic-vnf/" + VNF_ID), payload.capture(), eq(Void.class))).thenReturn(null);
+ vnfInfo.setName("vnfName");
+ //when
+ genericVnfManager.createOrUpdate(VNF_ID, true);
+ //verify
+ GenericVnf vnfSentToAai = payload.getValue();
+ assertEquals(VNF_ID, vnfSentToAai.getVnfId());
+ assertEquals(VNF_ID, vnfSentToAai.getVnfInstanceId());
+ assertEquals("NokiaVNF", vnfSentToAai.getVnfType());
+ assertEquals(true, vnfSentToAai.isInMaint());
+ assertEquals(true, vnfSentToAai.isIsClosedLoopDisabled());
+ assertEquals("vnfName", vnfSentToAai.getVnfName());
+ verify(systemFunctions, never()).sleep(anyLong());
+ verify(aaiRestApiProvider, times(1)).get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class);
+ }
+
+ /**
+ * error is propagated if unable to query VNF from CBAM
+ */
+ @Test
+ public void testUnableToQueryVnfFromCBAM() throws Exception {
+ GenericVnf vnfInAaai = OBJECT_FACTORY.createGenericVnf();
+ vnfInAaai.setResourceVersion("v1");
+ when(aaiRestApiProvider.get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class)).thenReturn(vnfInAaai);
+ ApiException expectedException = new ApiException();
+ when(cbamRestApiProvider.getCbamLcmApi(VNFM_ID).vnfsVnfInstanceIdGet(VNF_ID, CbamRestApiProvider.NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/generic-vnfs/generic-vnf/" + VNF_ID), payload.capture(), eq(Void.class))).thenAnswer(invocation -> {
+ vnfInAaai.setResourceVersion("v2");
+ return null;
+ });
+ vnfInfo.setName("vnfName");
+ //when
+ try {
+ genericVnfManager.createOrUpdate(VNF_ID, true);
+ } catch (Exception e) {
+ verify(logger).error("Unable to query VNF with myVnfId identifier from CBAM", expectedException);
+ assertEquals("Unable to query VNF with myVnfId identifier from CBAM", e.getMessage());
+ }
+ }
+
+ /**
+ * if the VNF is created after the last attempt to query VNF, but before the
+ * the driver creates the VNF it is not created but updated
+ */
+ @Test
+ public void testConcurency1() throws Exception {
+ GenericVnf vnfInAaai = OBJECT_FACTORY.createGenericVnf();
+ vnfInAaai.setResourceVersion("v3");
+ Set<Integer> queryCount = new HashSet<>();
+ when(aaiRestApiProvider.get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class)).thenAnswer((Answer<GenericVnf>) invocation -> {
+ queryCount.add(queryCount.size());
+ if (queryCount.size() >= 11) {
+ return vnfInAaai;
+ }
+ throw new NoSuchElementException();
+ });
+ when(cbamRestApiProvider.getCbamLcmApi(VNFM_ID).vnfsVnfInstanceIdGet(VNF_ID, CbamRestApiProvider.NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ RuntimeException runtimeException = new RuntimeException();
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/generic-vnfs/generic-vnf/" + VNF_ID), payload.capture(), eq(Void.class))).thenAnswer(invocation -> {
+ GenericVnf vnfSentToAAi = (GenericVnf) invocation.getArguments()[3];
+ if (vnfSentToAAi.getResourceVersion() == null) {
+ throw runtimeException;
+ }
+ return null;
+ });
+ vnfInfo.setName("vnfName");
+ //when
+ genericVnfManager.createOrUpdate(VNF_ID, true);
+ //verify
+ GenericVnf vnfSentToAai = payload.getValue();
+ assertEquals(VNF_ID, vnfSentToAai.getVnfId());
+ assertEquals(VNF_ID, vnfSentToAai.getVnfInstanceId());
+ assertEquals("NokiaVNF", vnfSentToAai.getVnfType());
+ assertEquals(true, vnfSentToAai.isInMaint());
+ assertEquals(true, vnfSentToAai.isIsClosedLoopDisabled());
+ assertEquals("vnfName", vnfSentToAai.getVnfName());
+ assertEquals("v3", vnfSentToAai.getResourceVersion());
+ verify(systemFunctions, times(10)).sleep(3000);
+ verify(aaiRestApiProvider, times(11)).get(logger, NETWORK, "/generic-vnfs/generic-vnf/" + VNF_ID, GenericVnf.class);
+ verify(aaiRestApiProvider, times(2)).put(eq(logger), eq(NETWORK), eq("/generic-vnfs/generic-vnf/" + VNF_ID), anyString(), eq(Void.class));
+ verify(logger).warn(eq("The VNF with myVnfId identifier did not appear in time"), any(NoSuchElementException.class));
+ verify(logger).warn("The VNF with myVnfId identifier has been created since after the maximal wait for VNF to appear timeout", runtimeException);
+ }
+
+ /**
+ * test how entities can refer to a VNF
+ */
+ @Test
+ public void testRelations() {
+ //when
+ Relationship relationship = GenericVnfManager.linkTo(VNF_ID);
+ //verify
+ assertEquals("generic-vnf", relationship.getRelatedTo());
+ assertEquals(1, relationship.getRelationshipData().size());
+ assertEquals("generic-vnf.vnf-id", relationship.getRelationshipData().get(0).getRelationshipKey());
+ assertEquals(VNF_ID, relationship.getRelationshipData().get(0).getRelationshipValue());
+ }
+
+ /**
+ * test inheritence
+ */
+ @Test
+ public void testInheritence() {
+ assertEquals(logger, genericVnfManager.getLogger());
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestL3NetworkManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestL3NetworkManager.java
new file mode 100644
index 00000000..159d6e63
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestL3NetworkManager.java
@@ -0,0 +1,143 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.model.AffectedVirtualLink;
+import com.nokia.cbam.lcm.v32.model.ResourceHandle;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.onap.aai.domain.yang.v11.L3Network;
+import org.onap.aai.domain.yang.v11.ObjectFactory;
+import org.onap.aai.domain.yang.v11.RelationshipList;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import java.util.NoSuchElementException;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.assertFalse;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.NETWORK;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.AbstractManager.buildRelationshipData;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.TestGenericVnfManager.assertRelation;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getCloudOwner;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getRegionName;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestL3NetworkManager extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ private ArgumentCaptor<L3Network> payload = ArgumentCaptor.forClass(L3Network.class);
+ private AffectedVirtualLink affectedVirtualLink = new AffectedVirtualLink();
+ @Mock
+ private AAIRestApiProvider aaiRestApiProvider;
+ private L3NetworkManager l3NetworkManager;
+
+ @Before
+ public void init() {
+ l3NetworkManager = new L3NetworkManager(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ setField(L3NetworkManager.class, "logger", logger);
+ }
+
+ /**
+ * test L3 network creation
+ */
+ @Test
+ public void testUpdate() throws Exception {
+ affectedVirtualLink.setId("vlId");
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("name", "netName");
+ additionalData.addProperty("tenantId", "myTenantId");
+ affectedVirtualLink.setResource(new ResourceHandle());
+ affectedVirtualLink.getResource().setAdditionalData(additionalData);
+ affectedVirtualLink.getResource().setResourceId("netProviderId");
+ when(aaiRestApiProvider.get(logger, NETWORK, "/l3-networks/l3-network/myVnfId_vlId", L3Network.class)).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/l3-networks/l3-network/myVnfId_vlId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ l3NetworkManager.update(VIM_ID, VNF_ID, affectedVirtualLink);
+ //verify
+ assertEquals("myVnfId_vlId", payload.getValue().getNetworkId());
+ assertEquals("netName", payload.getValue().getNetworkName());
+ assertEquals("netProviderId", payload.getValue().getNeutronNetworkId());
+ assertFalse(payload.getValue().isIsBoundToVpn());
+ assertFalse(payload.getValue().isIsProviderNetwork());
+ assertFalse(payload.getValue().isIsSharedNetwork());
+ assertFalse(payload.getValue().isIsExternalNetwork());
+ assertEquals("active", payload.getValue().getOperationalStatus());
+ assertRelation(payload.getValue().getRelationshipList(), "cloud-region", buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(VIM_ID)), buildRelationshipData("cloud-region.cloud-region-id", getRegionName(VIM_ID)));
+ assertRelation(payload.getValue().getRelationshipList(), "tenant", buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(VIM_ID)), buildRelationshipData("cloud-region.cloud-region-id", getRegionName(VIM_ID)), buildRelationshipData("tenant.tenant-id", "myTenantId"));
+ assertRelation(payload.getValue().getRelationshipList(), "generic-vnf", buildRelationshipData("generic-vnf.vnf-id", VNF_ID));
+ }
+
+ /**
+ * Test existing resource update
+ */
+ @Test
+ public void testExistingUpdate() throws Exception {
+ affectedVirtualLink.setId("vlId");
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("name", "netName");
+ additionalData.addProperty("tenantId", "myTenantId");
+ affectedVirtualLink.setResource(new ResourceHandle());
+ affectedVirtualLink.getResource().setAdditionalData(additionalData);
+ affectedVirtualLink.getResource().setResourceId("netProviderId");
+ L3Network l3Network = OBJECT_FACTORY.createL3Network();
+ l3Network.setResourceVersion("v3");
+ l3Network.setRelationshipList(new RelationshipList());
+ when(aaiRestApiProvider.get(logger, NETWORK, "/l3-networks/l3-network/myVnfId_vlId", L3Network.class)).thenReturn(l3Network);
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/l3-networks/l3-network/myVnfId_vlId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ l3NetworkManager.update(VIM_ID, VNF_ID, affectedVirtualLink);
+ //verify
+ assertEquals("myVnfId_vlId", payload.getValue().getNetworkId());
+ assertEquals("netName", payload.getValue().getNetworkName());
+ assertEquals("netProviderId", payload.getValue().getNeutronNetworkId());
+ assertFalse(payload.getValue().isIsBoundToVpn());
+ assertFalse(payload.getValue().isIsProviderNetwork());
+ assertFalse(payload.getValue().isIsSharedNetwork());
+ assertFalse(payload.getValue().isIsExternalNetwork());
+ assertEquals("active", payload.getValue().getOperationalStatus());
+ assertEquals("v3", payload.getValue().getResourceVersion());
+ assertRelation(payload.getValue().getRelationshipList(), "cloud-region", buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(VIM_ID)), buildRelationshipData("cloud-region.cloud-region-id", getRegionName(VIM_ID)));
+ assertRelation(payload.getValue().getRelationshipList(), "tenant", buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(VIM_ID)), buildRelationshipData("cloud-region.cloud-region-id", getRegionName(VIM_ID)), buildRelationshipData("tenant.tenant-id", "myTenantId"));
+ assertRelation(payload.getValue().getRelationshipList(), "generic-vnf", buildRelationshipData("generic-vnf.vnf-id", VNF_ID));
+ }
+ /**
+ * test L3 network deletion
+ */
+ @Test
+ public void testDelete() throws Exception {
+ affectedVirtualLink.setId("vlId");
+ //when
+ l3NetworkManager.delete(VNF_ID, affectedVirtualLink);
+ //verify
+ verify(aaiRestApiProvider).delete(logger, NETWORK, "/l3-networks/l3-network/myVnfId_vlId");
+ }
+
+ /**
+ * test inheritence
+ */
+ @Test
+ public void testInheritence() {
+ assertEquals(logger, l3NetworkManager.getLogger());
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestLInterfaceManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestLInterfaceManager.java
new file mode 100644
index 00000000..ef9f569e
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestLInterfaceManager.java
@@ -0,0 +1,230 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.onap.aai.domain.yang.v11.LInterface;
+import org.onap.aai.domain.yang.v11.ObjectFactory;
+import org.onap.aai.domain.yang.v11.RelationshipList;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedCp;
+
+import java.util.NoSuchElementException;
+
+import static junit.framework.TestCase.assertEquals;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.CLOUD;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.AbstractManager.buildRelationshipData;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.TestGenericVnfManager.assertRelation;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestLInterfaceManager extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ private ArgumentCaptor<LInterface> payload = ArgumentCaptor.forClass(LInterface.class);
+
+ @Mock
+ private AAIRestApiProvider aaiRestApiProvider;
+ private LInterfaceManager lInterfaceManager;
+
+ @Before
+ public void init() {
+ lInterfaceManager = new LInterfaceManager(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ setField(LInterfaceManager.class, "logger", logger);
+ }
+
+ /**
+ * test update success scenario
+ */
+ @Test
+ public void testUpdate() throws Exception {
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpdId");
+ affectedCp.setTenantId("myTenantId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setMacAddress("mac");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setEcpdId("ecpdId");
+ affectedCp.setName("name");
+ affectedCp.setCpId("cpId");
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), eq(LInterface.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ lInterfaceManager.update(VNF_ID, VIM_ID, affectedCp, true);
+ //verify
+ LInterface actualInterface = payload.getValue();
+ assertEquals(true, actualInterface.isInMaint());
+ assertEquals(false, actualInterface.isIsIpUnnumbered());
+ assertEquals(false, actualInterface.isIsPortMirrored());
+ assertEquals("name", actualInterface.getInterfaceName());
+ assertEquals("cpId", actualInterface.getInterfaceId());
+ assertEquals("cpdId", actualInterface.getInterfaceRole());
+ assertEquals("mac", actualInterface.getMacaddr());
+ assertEquals("active", actualInterface.getProvStatus());
+ assertEquals(1, actualInterface.getL3InterfaceIpv4AddressList().size());
+ assertEquals(0, actualInterface.getL3InterfaceIpv6AddressList().size());
+ assertEquals("networkProviderId", actualInterface.getL3InterfaceIpv4AddressList().get(0).getNeutronNetworkId());
+ assertEquals("1.2.3.4", actualInterface.getL3InterfaceIpv4AddressList().get(0).getL3InterfaceIpv4Address());
+ assertRelation(actualInterface.getRelationshipList(), "generic-vnf", buildRelationshipData("generic-vnf.vnf-id", VNF_ID));
+ }
+
+ /**
+ * test update success scenario without IP
+ */
+ @Test
+ public void testUpdateWithoutIp() throws Exception {
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpdId");
+ affectedCp.setTenantId("myTenantId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setMacAddress("mac");
+ affectedCp.setEcpdId("ecpdId");
+ affectedCp.setName("name");
+ affectedCp.setCpId("cpId");
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), eq(LInterface.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ lInterfaceManager.update(VNF_ID, VIM_ID, affectedCp, true);
+ //verify
+ LInterface actualInterface = payload.getValue();
+ assertEquals(true, actualInterface.isInMaint());
+ assertEquals(false, actualInterface.isIsIpUnnumbered());
+ assertEquals(false, actualInterface.isIsPortMirrored());
+ assertEquals("name", actualInterface.getInterfaceName());
+ assertEquals("cpId", actualInterface.getInterfaceId());
+ assertEquals("cpdId", actualInterface.getInterfaceRole());
+ assertEquals("mac", actualInterface.getMacaddr());
+ assertEquals("active", actualInterface.getProvStatus());
+ assertEquals(0, actualInterface.getL3InterfaceIpv6AddressList().size());
+ assertEquals(0, actualInterface.getL3InterfaceIpv4AddressList().size());
+ assertRelation(actualInterface.getRelationshipList(), "generic-vnf", buildRelationshipData("generic-vnf.vnf-id", VNF_ID));
+ }
+
+ /**
+ * test update success scenario
+ */
+ @Test
+ public void testExistingUpdate() throws Exception {
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpdId");
+ affectedCp.setTenantId("myTenantId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setMacAddress("mac");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setEcpdId("ecpdId");
+ affectedCp.setName("name");
+ affectedCp.setCpId("cpId");
+ LInterface lInterface = OBJECT_FACTORY.createLInterface();
+ lInterface.setResourceVersion("v3");
+ lInterface.setRelationshipList(new RelationshipList());
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), eq(LInterface.class))).thenReturn(lInterface);
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ lInterfaceManager.update(VNF_ID, VIM_ID, affectedCp, true);
+ //verify
+ LInterface actualInterface = payload.getValue();
+ assertEquals(true, actualInterface.isInMaint());
+ assertEquals(false, actualInterface.isIsIpUnnumbered());
+ assertEquals(false, actualInterface.isIsPortMirrored());
+ assertEquals("name", actualInterface.getInterfaceName());
+ assertEquals("cpId", actualInterface.getInterfaceId());
+ assertEquals("cpdId", actualInterface.getInterfaceRole());
+ assertEquals("mac", actualInterface.getMacaddr());
+ assertEquals("active", actualInterface.getProvStatus());
+ assertEquals(1, actualInterface.getL3InterfaceIpv4AddressList().size());
+ assertEquals(0, actualInterface.getL3InterfaceIpv6AddressList().size());
+ assertEquals("networkProviderId", actualInterface.getL3InterfaceIpv4AddressList().get(0).getNeutronNetworkId());
+ assertEquals("1.2.3.4", actualInterface.getL3InterfaceIpv4AddressList().get(0).getL3InterfaceIpv4Address());
+ assertEquals("v3", lInterface.getResourceVersion());
+ assertRelation(actualInterface.getRelationshipList(), "generic-vnf", buildRelationshipData("generic-vnf.vnf-id", VNF_ID));
+ }
+
+ /**
+ * test update success scenario for IPv6 address
+ */
+ @Test
+ public void testUpdateForIpv6() throws Exception {
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpdId");
+ affectedCp.setTenantId("myTenantId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setMacAddress("mac");
+ affectedCp.setIpAddress("::");
+ affectedCp.setEcpdId("ecpdId");
+ affectedCp.setName("name");
+ affectedCp.setCpId("cpId");
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), eq(LInterface.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq("/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ lInterfaceManager.update(VNF_ID, VIM_ID, affectedCp, false);
+ //verify
+ LInterface actualInterface = payload.getValue();
+ assertEquals(false, actualInterface.isInMaint());
+ assertEquals(false, actualInterface.isIsIpUnnumbered());
+ assertEquals(false, actualInterface.isIsPortMirrored());
+ assertEquals("name", actualInterface.getInterfaceName());
+ assertEquals("cpId", actualInterface.getInterfaceId());
+ assertEquals("cpdId", actualInterface.getInterfaceRole());
+ assertEquals("mac", actualInterface.getMacaddr());
+ assertEquals("active", actualInterface.getProvStatus());
+ assertEquals(0, actualInterface.getL3InterfaceIpv4AddressList().size());
+ assertEquals(1, actualInterface.getL3InterfaceIpv6AddressList().size());
+ assertEquals("networkProviderId", actualInterface.getL3InterfaceIpv6AddressList().get(0).getNeutronNetworkId());
+ assertEquals("::", actualInterface.getL3InterfaceIpv6AddressList().get(0).getL3InterfaceIpv6Address());
+ assertRelation(actualInterface.getRelationshipList(), "generic-vnf", buildRelationshipData("generic-vnf.vnf-id", VNF_ID));
+ }
+
+ /**
+ * test L3 network deletion
+ */
+ @Test
+ public void testDelete() throws Exception {
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpId("cpId");
+ affectedCp.setCpdId("cpdId");
+ affectedCp.setTenantId("myTenantId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ //when
+ lInterfaceManager.delete(VIM_ID, affectedCp);
+ //verify
+ verify(aaiRestApiProvider).delete(logger, CLOUD, "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId/l-interfaces/l-interface/cpId");
+ }
+
+ /**
+ * test inheritence
+ */
+ @Test
+ public void testInheritence() {
+ assertEquals(logger, lInterfaceManager.getLogger());
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVnfcManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVnfcManager.java
new file mode 100644
index 00000000..87a1149b
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVnfcManager.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.nokia.cbam.lcm.v32.model.AffectedVnfc;
+import com.nokia.cbam.lcm.v32.model.ResourceHandle;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.onap.aai.domain.yang.v11.ObjectFactory;
+import org.onap.aai.domain.yang.v11.Vnfc;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import java.util.NoSuchElementException;
+
+import static junit.framework.TestCase.assertEquals;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.NETWORK;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.AbstractManager.buildRelationshipData;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.TestGenericVnfManager.assertRelation;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getCloudOwner;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getRegionName;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestVnfcManager extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ private ArgumentCaptor<Vnfc> payload = ArgumentCaptor.forClass(Vnfc.class);
+
+ @Mock
+ private AAIRestApiProvider aaiRestApiProvider;
+ private VnfcManager vnfcManager;
+
+ @Before
+ public void init() {
+ vnfcManager = new VnfcManager(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ setField(VnfcManager.class, "logger", logger);
+ }
+
+ /**
+ * test update
+ */
+ @Test
+ public void testUpdate() throws Exception {
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.setId("vnfcId");
+ when(aaiRestApiProvider.get(eq(logger), eq(NETWORK), eq("/vnfcs/vnfc/myVnfId_vnfcId"), eq(Vnfc.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/vnfcs/vnfc/myVnfId_vnfcId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ vnfcManager.update(VIM_ID, "myTenantPrivderId", VNF_ID, affectedVnfc, true);
+ //verify
+ Vnfc vnfc = payload.getValue();
+ assertEquals("myVnfId_vnfcId", vnfc.getVnfcName());
+ assertEquals("vnfcId", vnfc.getNfcFunction());
+ assertEquals("vnfcId", vnfc.getNfcNamingCode());
+ assertRelation(payload.getValue().getRelationshipList(), "generic-vnf", buildRelationshipData("generic-vnf.vnf-id", VNF_ID));
+
+ assertRelation(vnfc.getRelationshipList(), "vserver",
+ buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(VIM_ID)),
+ buildRelationshipData("cloud-region.cloud-region-id", getRegionName(VIM_ID)),
+ buildRelationshipData("tenant.tenant-id", "myTenantPrivderId"),
+ buildRelationshipData("vserver.vserver-id", "serverProviderId"));
+ }
+
+ /**
+ * test delete
+ */
+ @Test
+ public void testDelete() throws Exception {
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.setId("vnfcId");
+ when(aaiRestApiProvider.get(eq(logger), eq(NETWORK), eq("/vnfcs/vnfc/myVnfId_vnfcId"), eq(Vnfc.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(NETWORK), eq("/vnfcs/vnfc/myVnfId_vnfcId"), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ vnfcManager.delete(VNF_ID, affectedVnfc);
+ //verify
+ aaiRestApiProvider.delete(logger, NETWORK, "/vnfcs/vnfc/myVnfId_vnfcId");
+ }
+
+ /**
+ * test inheritence
+ */
+ @Test
+ public void testInheritence() {
+ assertEquals(logger, vnfcManager.getLogger());
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVserverManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVserverManager.java
new file mode 100644
index 00000000..bb5d1d3d
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/direct/notification/TestVserverManager.java
@@ -0,0 +1,253 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification;
+
+import com.google.gson.JsonArray;
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.model.AffectedVirtualStorage;
+import com.nokia.cbam.lcm.v32.model.AffectedVnfc;
+import com.nokia.cbam.lcm.v32.model.ResourceHandle;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.onap.aai.domain.yang.v11.*;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.NoSuchElementException;
+
+import static junit.framework.TestCase.assertEquals;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.AAIRestApiProvider.AAIService.CLOUD;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.AbstractManager.buildRelationshipData;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.direct.notification.TestGenericVnfManager.assertRelation;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getCloudOwner;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager.getRegionName;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestVserverManager extends TestBase {
+ private ObjectFactory OBJECT_FACTORY = new ObjectFactory();
+ private ArgumentCaptor<Vserver> payload = ArgumentCaptor.forClass(Vserver.class);
+
+ @Mock
+ private AAIRestApiProvider aaiRestApiProvider;
+ private VserverManager vserverManager;
+
+ @Before
+ public void init() {
+ vserverManager = new VserverManager(aaiRestApiProvider, cbamRestApiProvider, driverProperties);
+ setField(VserverManager.class, "logger", logger);
+ }
+
+ /**
+ * test update
+ */
+ @Test
+ public void testUpdate() throws Exception {
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("name", "serverName");
+ additionalData.addProperty("tenantId", "myTenantId");
+ JsonArray links = new JsonArray();
+ links.add(new JsonObject());
+ JsonObject nonRelSelfink = new JsonObject();
+ nonRelSelfink.addProperty("rel", "self2");
+ nonRelSelfink.addProperty("href", "url");
+ links.add(nonRelSelfink);
+
+ JsonObject link = new JsonObject();
+ link.addProperty("rel", "self");
+ link.addProperty("href", "url");
+ links.add(link);
+ additionalData.add("links", links);
+ affectedVnfc.getComputeResource().setAdditionalData(additionalData);
+ affectedVnfc.setId("vnfcId");
+ List<AffectedVirtualStorage> affectedStorages = new ArrayList<>();
+ affectedStorages.add(new AffectedVirtualStorage());
+ affectedStorages.get(0).setId("sId");
+ affectedStorages.get(0).setResource(new ResourceHandle());
+ affectedStorages.get(0).getResource().setResourceId("storageProviderId");
+ affectedVnfc.setStorageResourceIds(new ArrayList<>());
+ affectedVnfc.getStorageResourceIds().add("sId");
+
+ String url = "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId";
+
+ Vserver existingVserver = OBJECT_FACTORY.createVserver();
+ existingVserver.setVolumes(new Volumes());
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq(url), eq(Vserver.class))).thenReturn(existingVserver);
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq(url), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ vserverManager.update(VIM_ID, VNF_ID, affectedVnfc, affectedStorages, true);
+ //verify
+ Vserver vserver = payload.getValue();
+ assertEquals("serverProviderId", vserver.getVserverId());
+ assertEquals("active", vserver.getProvStatus());
+ assertEquals("serverName", vserver.getVserverName());
+ assertEquals("url", vserver.getVserverSelflink());
+ assertEquals(1, vserver.getVolumes().getVolume().size());
+ assertEquals("storageProviderId", vserver.getVolumes().getVolume().get(0).getVolumeId());
+ }
+
+ /**
+ * test missing links
+ */
+ @Test
+ public void testUpdateEmptyLinks() throws Exception {
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("name", "serverName");
+ additionalData.addProperty("tenantId", "myTenantId");
+ JsonArray links = new JsonArray();
+ additionalData.add("links", links);
+ affectedVnfc.getComputeResource().setAdditionalData(additionalData);
+ affectedVnfc.setId("vnfcId");
+ List<AffectedVirtualStorage> affectedStorages = new ArrayList<>();
+ affectedStorages.add(new AffectedVirtualStorage());
+ affectedStorages.get(0).setId("sId");
+ affectedStorages.get(0).setResource(new ResourceHandle());
+ affectedStorages.get(0).getResource().setResourceId("storageProviderId");
+ affectedVnfc.setStorageResourceIds(new ArrayList<>());
+ affectedVnfc.getStorageResourceIds().add("sId");
+
+ String url = "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId";
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq(url), eq(Vserver.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq(url), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ vserverManager.update(VIM_ID, VNF_ID, affectedVnfc, affectedStorages, true);
+ //verify
+ Vserver vserver = payload.getValue();
+ assertEquals("serverProviderId", vserver.getVserverId());
+ assertEquals("active", vserver.getProvStatus());
+ assertEquals("serverName", vserver.getVserverName());
+ assertEquals("unknown", vserver.getVserverSelflink());
+ assertEquals(1, vserver.getVolumes().getVolume().size());
+ assertEquals("storageProviderId", vserver.getVolumes().getVolume().get(0).getVolumeId());
+ }
+
+ /**
+ * test update when links is not present on vServer
+ */
+ @Test
+ public void testUpdateWithNoLinks() throws Exception {
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("name", "serverName");
+ additionalData.addProperty("tenantId", "myTenantId");
+ affectedVnfc.getComputeResource().setAdditionalData(additionalData);
+ affectedVnfc.setId("vnfcId");
+ List<AffectedVirtualStorage> affectedStorages = new ArrayList<>();
+ affectedStorages.add(new AffectedVirtualStorage());
+ affectedStorages.get(0).setId("sId");
+ affectedStorages.get(0).setResource(new ResourceHandle());
+ affectedStorages.get(0).getResource().setResourceId("storageProviderId");
+ affectedVnfc.setStorageResourceIds(new ArrayList<>());
+ affectedVnfc.getStorageResourceIds().add("sId");
+
+ String url = "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId";
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq(url), eq(Vserver.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq(url), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ vserverManager.update(VIM_ID, VNF_ID, affectedVnfc, affectedStorages, true);
+ //verify
+ Vserver vserver = payload.getValue();
+ assertEquals("serverProviderId", vserver.getVserverId());
+ assertEquals("active", vserver.getProvStatus());
+ assertEquals("serverName", vserver.getVserverName());
+ assertEquals("unknown", vserver.getVserverSelflink());
+ assertEquals(1, vserver.getVolumes().getVolume().size());
+ assertEquals("storageProviderId", vserver.getVolumes().getVolume().get(0).getVolumeId());
+ }
+
+ /**
+ * test update when removing volumes
+ */
+ @Test
+ public void testUpdateWithRemovingVolumes() throws Exception {
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("name", "serverName");
+ additionalData.addProperty("tenantId", "myTenantId");
+ affectedVnfc.getComputeResource().setAdditionalData(additionalData);
+ affectedVnfc.setId("vnfcId");
+ List<AffectedVirtualStorage> affectedStorages = new ArrayList<>();
+ String url = "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId";
+ when(aaiRestApiProvider.get(eq(logger), eq(CLOUD), eq(url), eq(Vserver.class))).thenThrow(new NoSuchElementException());
+ when(aaiRestApiProvider.put(eq(logger), eq(CLOUD), eq(url), payload.capture(), eq(Void.class))).thenReturn(null);
+ //when
+ vserverManager.update(VIM_ID, VNF_ID, affectedVnfc, affectedStorages, true);
+ //verify
+ Vserver vserver = payload.getValue();
+ assertEquals("serverProviderId", vserver.getVserverId());
+ assertEquals("active", vserver.getProvStatus());
+ assertEquals("serverName", vserver.getVserverName());
+ assertEquals("unknown", vserver.getVserverSelflink());
+ assertEquals(0, vserver.getVolumes().getVolume().size());
+ }
+
+ /**
+ * test delete
+ */
+ @Test
+ public void testDelete() throws Exception {
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ JsonObject additionalData = new JsonObject();
+ additionalData.addProperty("name", "serverName");
+ additionalData.addProperty("tenantId", "myTenantId");
+ affectedVnfc.getComputeResource().setAdditionalData(additionalData);
+ affectedVnfc.setId("vnfcId");
+ //when
+ vserverManager.delete(VIM_ID, affectedVnfc);
+ //verify
+ String url = "/cloud-regions/cloud-region/myCloudOwnerId/myRegionName/tenants/tenant/myTenantId/vservers/vserver/serverProviderId";
+ aaiRestApiProvider.delete(logger, CLOUD, url);
+ }
+
+ @Test
+ public void testLinks() {
+ Relationship relationship = VserverManager.linkTo(VIM_ID, "myTenantPrivderId", "serverProviderId");
+ RelationshipList relationships = new RelationshipList();
+ relationships.getRelationship().add(relationship);
+ assertRelation(relationships, "vserver",
+ buildRelationshipData("cloud-region.cloud-owner", getCloudOwner(VIM_ID)),
+ buildRelationshipData("cloud-region.cloud-region-id", getRegionName(VIM_ID)),
+ buildRelationshipData("tenant.tenant-id", "myTenantPrivderId"),
+ buildRelationshipData("vserver.vserver-id", "serverProviderId"));
+ }
+
+ /**
+ * test inheritence
+ */
+ @Test
+ public void testInheritence() {
+ assertEquals(logger, vserverManager.getLogger());
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcExternalSystemInfoProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcExternalSystemInfoProvider.java
new file mode 100644
index 00000000..537093c3
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcExternalSystemInfoProvider.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vnfmdriver.ApiException;
+import org.onap.vnfmdriver.model.VimInfo;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.springframework.test.util.ReflectionTestUtils;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+
+public class TestVfcExternalSystemInfoProvider extends TestBase {
+ private VfcExternalSystemInfoProvider vfcExternalSystemInfoProvider;
+
+ @Before
+ public void init() {
+ vfcExternalSystemInfoProvider = new VfcExternalSystemInfoProvider(environment, vfcRestApiProvider);
+ ReflectionTestUtils.setField(VfcExternalSystemInfoProvider.class, "logger", logger);
+ }
+
+ /**
+ * VIM is queried using VF-C APIs
+ */
+ @Test
+ public void testVimRetrieval() throws Exception {
+ VimInfo expectedVimInfo = new VimInfo();
+ when(nsLcmApi.queryVIMInfo(VIM_ID)).thenReturn(expectedVimInfo);
+ //when
+ VimInfo vimInfo = vfcExternalSystemInfoProvider.getVimInfo(VIM_ID);
+ //verify
+ assertEquals(expectedVimInfo, vimInfo);
+ }
+
+ /**
+ * failure to retrieve VIM from VF-C is propagated
+ */
+ @Test
+ public void testUnableToQueryVim() throws Exception {
+ ApiException expectedException = new ApiException();
+ when(nsLcmApi.queryVIMInfo(VIM_ID)).thenThrow(expectedException);
+ //when
+ try {
+ vfcExternalSystemInfoProvider.getVimInfo(VIM_ID);
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to query VIM from VF-C with " + VIM_ID + " identifier", e.getMessage());
+ verify(logger).error("Unable to query VIM from VF-C with " + VIM_ID + " identifier", expectedException);
+ }
+ }
+
+ /**
+ * VNFM is queried using VF-C APIs
+ */
+ @Test
+ public void testVnfmRetrieval() throws Exception {
+ VnfmInfo expectedVimInfo = new VnfmInfo();
+ when(nsLcmApi.queryVnfmInfo(VNFM_ID)).thenReturn(expectedVimInfo);
+ //when
+ VnfmInfo vimInfo = vfcExternalSystemInfoProvider.queryVnfmInfoFromSource(VNFM_ID);
+ //verify
+ assertEquals(expectedVimInfo, vimInfo);
+ }
+
+ /**
+ * failure to retrieve VNFM from VF-C is propagated
+ */
+ @Test
+ public void testUnableToQueryVnfm() throws Exception {
+ ApiException expectedException = new ApiException();
+ when(nsLcmApi.queryVnfmInfo(VNFM_ID)).thenThrow(expectedException);
+ //when
+ try {
+ vfcExternalSystemInfoProvider.queryVnfmInfoFromSource(VNFM_ID);
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to query VNFM from VF-C with myVnfmId identifier", e.getMessage());
+ verify(logger).error("Unable to query VNFM from VF-C with myVnfmId identifier", expectedException);
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcGrantManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcGrantManager.java
new file mode 100644
index 00000000..4bbf0764
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcGrantManager.java
@@ -0,0 +1,417 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import com.google.common.collect.Lists;
+import com.google.gson.Gson;
+import com.google.gson.JsonObject;
+import com.nokia.cbam.lcm.v32.model.*;
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vnfmdriver.ApiException;
+import org.onap.vnfmdriver.model.*;
+import org.onap.vnfmdriver.model.ScaleDirection;
+
+import java.nio.file.Paths;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+
+import static java.nio.file.Files.readAllBytes;
+import static junit.framework.TestCase.*;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestVfcGrantManager extends TestBase {
+
+ private ArgumentCaptor<GrantVNFRequest> grantRequest = ArgumentCaptor.forClass(GrantVNFRequest.class);
+ private GrantVNFResponseVim vim = new GrantVNFResponseVim();
+ private GrantVNFResponse grantResponse = new GrantVNFResponse();
+ @Mock
+ private CatalogManager cbamCatalogManager;
+ @InjectMocks
+ private VfcGrantManager vfcGrantManager;
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(VfcGrantManager.class, "logger", logger);
+ when(nsLcmApi.grantvnf(grantRequest.capture())).thenReturn(grantResponse);
+ grantResponse.setVim(vim);
+ }
+
+ /**
+ * test grant request for instantiation
+ */
+ @Test
+ public void testGrantDuringInstantiation() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.instantiation.yaml").toURI())));
+ //when
+ vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, "level1", cbamVnfdContent, JOB_ID);
+ //verify
+ assertEquals(1, grantRequest.getAllValues().size());
+ GrantVNFRequest request = grantRequest.getValue();
+ assertVduInGrant(request.getAddResource(), "vdu1", 1);
+ assertVduInGrant(request.getAddResource(), "vdu2", 2);
+ assertEquals(0, request.getRemoveResource().size());
+ assertBasicGrantAttributes(request, org.onap.vnfmdriver.model.OperationType.INSTANTIATE);
+ }
+
+ /**
+ * test failure logging & propagation during grant request for instantiation
+ */
+ @Test
+ public void testFailureDuringGrantPreparation() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.instantiation.yaml").toURI())));
+ //when
+ try {
+ vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, "missingLevel", cbamVnfdContent, JOB_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error(Mockito.eq("Unable to prepare grant request for instantiation"), Mockito.any(RuntimeException.class));
+ verifyNoMoreInteractions(nsLcmApi);
+ }
+ }
+
+ /**
+ * test grant request for instantiation
+ */
+ @Test
+ public void testFailureDuringGrantRequest() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.instantiation.yaml").toURI())));
+ ApiException expectedException = new ApiException("a");
+ when(nsLcmApi.grantvnf(Mockito.any())).thenThrow(expectedException);
+ //when
+ try {
+ vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, "level1", cbamVnfdContent, JOB_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error("Unable to request grant", expectedException);
+ }
+ }
+
+ /**
+ * No grant is requested for termination if the the VNF is not instantiated
+ */
+ @Test
+ public void testNoGrantIsRequestedIfNotInstantiated() {
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnf.setInstantiationState(InstantiationState.NOT_INSTANTIATED);
+ //when
+ vfcGrantManager.requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnf, JOB_ID);
+ //verify
+ verifyNoMoreInteractions(nsLcmApi);
+ }
+
+ /**
+ * grant is requested for termination if the the VNF is instantiated
+ */
+ @Test
+ public void testGrantIsRequestedIfInstantiated() {
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnf.setInstantiationState(InstantiationState.INSTANTIATED);
+ InstantiatedVnfInfo instantiatedVnfInfo = new InstantiatedVnfInfo();
+ VnfcResourceInfo vnfc = new VnfcResourceInfo();
+ vnfc.setId("vnfcId1");
+ vnfc.setVduId("vdu1");
+ instantiatedVnfInfo.setVnfcResourceInfo(new ArrayList<>());
+ instantiatedVnfInfo.getVnfcResourceInfo().add(vnfc);
+ vnf.setInstantiatedVnfInfo(instantiatedVnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ prop.setValue(ONAP_CSAR_ID);
+ vnf.setVnfConfigurableProperties(new ArrayList<>());
+ vnf.getVnfConfigurableProperties().add(prop);
+ //when
+ vfcGrantManager.requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnf, JOB_ID);
+ //verify
+ assertEquals(1, grantRequest.getAllValues().size());
+ GrantVNFRequest request = grantRequest.getValue();
+ assertVduInGrant(request.getRemoveResource(), "vdu1", 1);
+ assertVduInGrant(request.getRemoveResource(), "vdu2", 0);
+ assertEquals(0, request.getAddResource().size());
+ assertBasicGrantAttributes(request, org.onap.vnfmdriver.model.OperationType.TERMINAL);
+ }
+
+ /**
+ * grant is requested for termination if the the VNF is instantiated even if has no VNFCs
+ */
+ @Test
+ public void testGrantIsRequestedIfInstantiatedWithNoVnfcs() {
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnf.setInstantiationState(InstantiationState.INSTANTIATED);
+ InstantiatedVnfInfo instantiatedVnfInfo = new InstantiatedVnfInfo();
+ vnf.setInstantiatedVnfInfo(instantiatedVnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ prop.setValue(ONAP_CSAR_ID);
+ vnf.setVnfConfigurableProperties(new ArrayList<>());
+ vnf.getVnfConfigurableProperties().add(prop);
+ //when
+ vfcGrantManager.requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnf, JOB_ID);
+ //verify
+ assertEquals(1, grantRequest.getAllValues().size());
+ GrantVNFRequest request = grantRequest.getValue();
+ assertVduInGrant(request.getRemoveResource(), "vdu1", 0);
+ assertVduInGrant(request.getRemoveResource(), "vdu2", 0);
+ assertEquals(0, request.getAddResource().size());
+ assertBasicGrantAttributes(request, org.onap.vnfmdriver.model.OperationType.TERMINAL);
+ }
+
+ /**
+ * test failure logging & propagation during grant request for instantiation
+ */
+ @Test
+ public void testFailureDuringTerminationGrantPreparation() throws Exception {
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnf.setInstantiatedVnfInfo(null);
+ vnf.setInstantiationState(InstantiationState.INSTANTIATED);
+ //when
+ try {
+ vfcGrantManager.requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnf, JOB_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error(Mockito.eq("Unable to prepare grant request for termination"), Mockito.any(RuntimeException.class));
+ verifyNoMoreInteractions(nsLcmApi);
+ }
+ }
+
+ /**
+ * failure is to request grant is logged
+ */
+ @Test
+ public void testFailureToRequestGrantIsLogged() throws Exception {
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnf.setInstantiationState(InstantiationState.INSTANTIATED);
+ InstantiatedVnfInfo instantiatedVnfInfo = new InstantiatedVnfInfo();
+ VnfcResourceInfo vnfc = new VnfcResourceInfo();
+ vnfc.setId("vnfcId1");
+ vnfc.setVduId("vdu1");
+ instantiatedVnfInfo.setVnfcResourceInfo(new ArrayList<>());
+ instantiatedVnfInfo.getVnfcResourceInfo().add(vnfc);
+ vnf.setInstantiatedVnfInfo(instantiatedVnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ prop.setValue(ONAP_CSAR_ID);
+ vnf.setVnfConfigurableProperties(new ArrayList<>());
+ vnf.getVnfConfigurableProperties().add(prop);
+ ApiException expectedException = new ApiException();
+ when(nsLcmApi.grantvnf(Mockito.any())).thenThrow(expectedException);
+ //when
+ try {
+ vfcGrantManager.requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnf, JOB_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error(Mockito.eq("Unable to request grant"), Mockito.eq(expectedException));
+ }
+ }
+
+ /**
+ * failure is to request grant is logged
+ */
+ @Test
+ public void testFailureToRequestGrantForScaleIsLogged() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.scale.yaml").toURI())));
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setType(ScaleDirection.OUT);
+ scaleRequest.setAspectId("aspect1");
+ scaleRequest.setNumberOfSteps("2");
+ com.nokia.cbam.lcm.v32.ApiException expectedException = new com.nokia.cbam.lcm.v32.ApiException();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ try {
+ vfcGrantManager.requestGrantForScale(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, scaleRequest, JOB_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error(Mockito.eq("Unable to query VNF myVnfId"), Mockito.eq(expectedException));
+ assertEquals(e.getCause(), expectedException);
+ }
+ }
+
+ /**
+ * test grant request for scale out
+ */
+ @Test
+ public void testGrantDuringScaleOut() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.scale.yaml").toURI())));
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setType(ScaleDirection.OUT);
+ scaleRequest.setAspectId("aspect1");
+ scaleRequest.setNumberOfSteps("2");
+ VnfInfo vnf = new VnfInfo();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnf);
+ vnf.setVnfdId(CBAM_VNFD_ID);
+ when(cbamCatalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID)).thenReturn(cbamVnfdContent);
+ //when
+ vfcGrantManager.requestGrantForScale(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, scaleRequest, JOB_ID);
+ //verify
+ assertEquals(1, grantRequest.getAllValues().size());
+ GrantVNFRequest request = grantRequest.getValue();
+ assertVduInGrant(request.getAddResource(), "vdu1", 4);
+ assertVduInGrant(request.getAddResource(), "vdu2", 2);
+ assertEquals(0, request.getRemoveResource().size());
+ assertBasicGrantAttributes(request, org.onap.vnfmdriver.model.OperationType.SCALEOUT);
+ }
+
+ /**
+ * test grant request for scale out without VDUs
+ */
+ @Test
+ public void testGrantDuringScaleOutWithoutVdus() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.scale.yaml").toURI())));
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setType(ScaleDirection.OUT);
+ scaleRequest.setAspectId("aspectWithOutVdu");
+ scaleRequest.setNumberOfSteps("2");
+ VnfInfo vnf = new VnfInfo();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnf);
+ vnf.setVnfdId(CBAM_VNFD_ID);
+ when(cbamCatalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID)).thenReturn(cbamVnfdContent);
+ //when
+ vfcGrantManager.requestGrantForScale(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, scaleRequest, JOB_ID);
+ //verify
+ assertEquals(1, grantRequest.getAllValues().size());
+ GrantVNFRequest request = grantRequest.getValue();
+ assertVduInGrant(request.getAddResource(), "vdu1", 0);
+ assertVduInGrant(request.getAddResource(), "vdu2", 0);
+ assertEquals(0, request.getRemoveResource().size());
+ assertBasicGrantAttributes(request, org.onap.vnfmdriver.model.OperationType.SCALEOUT);
+ }
+
+ /**
+ * test grant request for scale out without resources
+ */
+ @Test
+ public void testGrantDuringScaleOutForEmptyAspect() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.scale.yaml").toURI())));
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setType(ScaleDirection.OUT);
+ scaleRequest.setAspectId("emptyAspect");
+ scaleRequest.setNumberOfSteps("2");
+ VnfInfo vnf = new VnfInfo();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnf);
+ vnf.setVnfdId(CBAM_VNFD_ID);
+ when(cbamCatalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID)).thenReturn(cbamVnfdContent);
+ //when
+ try {
+ vfcGrantManager.requestGrantForScale(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, scaleRequest, JOB_ID);
+ fail();
+ } catch (Exception e) {
+ assertEquals("Missing child emptyAspect", e.getMessage());
+ }
+ }
+
+ /**
+ * test grant request for scale in
+ */
+ @Test
+ public void testGrantDuringScaleIn() throws Exception {
+ String cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.scale.yaml").toURI())));
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setType(ScaleDirection.IN);
+ scaleRequest.setAspectId("aspect1");
+ scaleRequest.setNumberOfSteps("2");
+ VnfInfo vnf = new VnfInfo();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnf);
+ vnf.setVnfdId(CBAM_VNFD_ID);
+ when(cbamCatalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID)).thenReturn(cbamVnfdContent);
+ //when
+ vfcGrantManager.requestGrantForScale(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, scaleRequest, JOB_ID);
+ //verify
+ assertEquals(1, grantRequest.getAllValues().size());
+ GrantVNFRequest request = grantRequest.getValue();
+ assertVduInGrant(request.getRemoveResource(), "vdu1", 4);
+ assertVduInGrant(request.getRemoveResource(), "vdu2", 2);
+ assertEquals(0, request.getAddResource().size());
+ assertBasicGrantAttributes(request, org.onap.vnfmdriver.model.OperationType.SCALEIN);
+ }
+
+ /**
+ * test grant request for healing
+ */
+ @Test
+ public void testGrantDuringHealing() throws Exception {
+ //when
+ VnfHealRequest healRequest = new VnfHealRequest();
+ VnfHealRequestAffectedvm affectedVm = new VnfHealRequestAffectedvm();
+ affectedVm.setVduid("vdu1");
+ healRequest.setAffectedvm(affectedVm);
+ vfcGrantManager.requestGrantForHeal(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, healRequest, JOB_ID);
+ //verify
+ assertEquals(1, grantRequest.getAllValues().size());
+ GrantVNFRequest request = grantRequest.getValue();
+ assertVduInGrant(request.getAddResource(), "vdu1", 1);
+ assertVduInGrant(request.getRemoveResource(), "vdu1", 1);
+ assertBasicGrantAttributes(request, org.onap.vnfmdriver.model.OperationType.HEAL);
+ }
+
+ @Test
+ public void testPOJO() {
+ VfcGrantManager.AdditionalGrantParams additionalGrantParams = new VfcGrantManager.AdditionalGrantParams(VNFM_ID, VIM_ID);
+ assertEquals(VNFM_ID, additionalGrantParams.getVnfmId());
+ assertEquals(VIM_ID, additionalGrantParams.getVimId());
+ }
+
+ private void assertBasicGrantAttributes(GrantVNFRequest request, org.onap.vnfmdriver.model.OperationType type) {
+ assertEquals(JOB_ID, request.getJobId());
+ assertEquals(type, request.getLifecycleOperation());
+ assertEquals(ONAP_CSAR_ID, request.getVnfDescriptorId());
+ assertEquals(VNF_ID, request.getVnfInstanceId());
+ JsonObject additionalParams = new Gson().toJsonTree(request.getAdditionalParam()).getAsJsonObject();
+ assertEquals(VIM_ID, additionalParams.get("vimId").getAsString());
+ assertEquals(VNFM_ID, additionalParams.get("vnfmId").getAsString());
+ }
+
+ private void assertVduInGrant(List<ResourceChange> changes, String vduName, int count) {
+ ArrayList<ResourceChange> clonedChanges = Lists.newArrayList(changes);
+ for (int i = 0; i < count + 1; i++) {
+ Iterator<ResourceChange> iter = clonedChanges.iterator();
+ boolean found = false;
+ while (iter.hasNext()) {
+ ResourceChange change = iter.next();
+ if (change.getVdu().equals(vduName)) {
+ iter.remove();
+ found = true;
+ break;
+ }
+ }
+ if (i >= count) {
+ assertFalse(found);
+ } else {
+ assertTrue(found);
+ }
+ }
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcNotificationSender.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcNotificationSender.java
new file mode 100644
index 00000000..d28e224f
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcNotificationSender.java
@@ -0,0 +1,863 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import com.google.common.collect.Lists;
+import com.google.gson.Gson;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonParser;
+import com.nokia.cbam.lcm.v32.model.AffectedVirtualLink;
+import com.nokia.cbam.lcm.v32.model.AffectedVirtualStorage;
+import com.nokia.cbam.lcm.v32.model.AffectedVnfc;
+import com.nokia.cbam.lcm.v32.model.ChangeType;
+import com.nokia.cbam.lcm.v32.model.*;
+import com.nokia.cbam.lcm.v32.model.OperationType;
+import com.nokia.cbam.lcm.v32.model.ScaleDirection;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedConnectionPoints;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.ReportedAffectedCp;
+import org.onap.vnfmdriver.ApiException;
+import org.onap.vnfmdriver.model.*;
+import org.threeten.bp.OffsetDateTime;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import static java.util.Optional.empty;
+import static java.util.Optional.of;
+import static junit.framework.TestCase.*;
+import static org.mockito.Matchers.any;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestVfcNotificationSender extends TestBase {
+ private VfcNotificationSender vfcNotificationSender;
+ private ArgumentCaptor<VNFLCMNotification> sentLcnToVfc = ArgumentCaptor.forClass(VNFLCMNotification.class);
+ private VnfLifecycleChangeNotification recievedLcn = new VnfLifecycleChangeNotification();
+ private List<OperationExecution> operationExecutions = new ArrayList<>();
+ private OperationExecution instantiationOperation = new OperationExecution();
+ private OperationExecution scaleOperation = new OperationExecution();
+ private OperationExecution healOperation = new OperationExecution();
+ private OperationExecution terminationOperation = new OperationExecution();
+ private ReportedAffectedConnectionPoints affectedCp;
+
+
+ @Before
+ public void init() throws Exception {
+ vfcNotificationSender = new VfcNotificationSender(driverProperties, vfcRestApiProvider);
+ setField(VfcNotificationSender.class, "logger", logger);
+ Mockito.doNothing().when(nsLcmApi).vNFLCMNotification(eq(VNFM_ID), eq(VNF_ID), sentLcnToVfc.capture());
+ instantiationOperation.setId("instantiationOperationExecutionId");
+ instantiationOperation.setStartTime(OffsetDateTime.now());
+ instantiationOperation.setOperationType(OperationType.INSTANTIATE);
+ scaleOperation.setId("scaleOperationExecutionId");
+ scaleOperation.setStartTime(OffsetDateTime.now().plusDays(1));
+ scaleOperation.setOperationType(OperationType.SCALE);
+ terminationOperation.setId("terminationExecutionId");
+ terminationOperation.setStartTime(OffsetDateTime.now().plusDays(1));
+ terminationOperation.setOperationType(OperationType.TERMINATE);
+ healOperation.setId("healOperaitonExecutionId");
+ healOperation.setOperationType(OperationType.HEAL);
+ healOperation.setStartTime(OffsetDateTime.now().plusDays(1));
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(operationExecutions);
+ prepOperation(instantiationOperation);
+ prepOperation(scaleOperation);
+ prepOperation(healOperation);
+ prepOperation(terminationOperation);
+ recievedLcn.setVnfInstanceId(VNF_ID);
+ }
+
+ private void prepOperation(OperationExecution operationExecution) throws com.nokia.cbam.lcm.v32.ApiException {
+ addEmptyModifiedConnectionPoints(operationExecution);
+ JsonElement root = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + JOB_ID + "\"}}");
+ operationExecution.setOperationParams(root);
+ switch (operationExecution.getOperationType()) {
+ case TERMINATE:
+ root.getAsJsonObject().addProperty("terminationType", "GRACEFULL");
+ }
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdGet(operationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(operationExecution);
+ operationExecutions.add(operationExecution);
+ }
+
+ private void addEmptyModifiedConnectionPoints(OperationExecution operationExecution) {
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = new ReportedAffectedConnectionPoints();
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ operationExecution.setAdditionalData(additionalData);
+ }
+
+ /**
+ * test start notification success scenario
+ * - the affected resources are not processed even if present
+ * - LCN is sent to VF-C
+ */
+ @Test
+ public void testStartLcn() {
+ recievedLcn.setStatus(OperationStatus.STARTED);
+ recievedLcn.setOperation(OperationType.INSTANTIATE);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, instantiationOperation, empty(), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+ assertNull(sentLcnToVfc.getValue().getAffectedVl());
+ assertNull(sentLcnToVfc.getValue().getAffectedVnfc());
+ assertNull(sentLcnToVfc.getValue().getAffectedCp());
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.INSTANTIATE, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.START, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ }
+
+ /**
+ * test end notification success scenario
+ * - LCN is sent to VF-C
+ */
+ @Test
+ public void testFinishLcn() {
+ //given
+ recievedLcn.setOperation(OperationType.INSTANTIATE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setChangeType(ChangeType.ADDED);
+ affectedVnfc.setId("myVnfcId");
+ affectedVnfc.setVduId("myVduId");
+ affectedVnfc.setStorageResourceIds(Lists.newArrayList("storageId1"));
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.getComputeResource().setVimId(VIM_ID);
+ affectedVnfc.getComputeResource().setAdditionalData(new JsonParser().parse("{ \"name\" : \"myVmName\" } "));
+ recievedLcn.setAffectedVnfcs(new ArrayList<>());
+ recievedLcn.getAffectedVnfcs().add(affectedVnfc);
+
+ AffectedVirtualLink affectedVirtualLink = new AffectedVirtualLink();
+ affectedVirtualLink.setChangeType(ChangeType.ADDED);
+ affectedVirtualLink.setId("vlId");
+ affectedVirtualLink.setVirtualLinkDescId("vlVnfdId");
+ affectedVirtualLink.setResource(new ResourceHandle());
+ affectedVirtualLink.getResource().setVimId(VIM_ID);
+ affectedVirtualLink.getResource().setResourceId("networkProviderId");
+ recievedLcn.setAffectedVirtualLinks(new ArrayList<>());
+ recievedLcn.getAffectedVirtualLinks().add(affectedVirtualLink);
+
+ AffectedVirtualStorage affectedStorage = new AffectedVirtualStorage();
+ affectedStorage.setChangeType(ChangeType.ADDED);
+ affectedStorage.setId("storageId");
+ affectedStorage.setVirtualStorageDescId("storageVnfdId");
+ affectedStorage.setResource(new ResourceHandle());
+ affectedStorage.getResource().setVimId(VIM_ID);
+ affectedStorage.getResource().setResourceId("storageProviderId");
+ recievedLcn.setAffectedVirtualStorages(new ArrayList<>());
+ recievedLcn.getAffectedVirtualStorages().add(affectedStorage);
+
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpVnfdId");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setMacAddress("myMac");
+ affectedCp.setName("myPortName");
+ affectedCp.setCpId("cpId");
+
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setTenantId("tenantId");
+ affectedConnectionPoints.getPost().add(affectedCp);
+
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = affectedConnectionPoints;
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ instantiationOperation.setAdditionalData(additionalData);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, instantiationOperation, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVl().size());
+ org.onap.vnfmdriver.model.AffectedVirtualLink actualAffectedVl = sentLcnToVfc.getValue().getAffectedVl().get(0);
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.ADDED, actualAffectedVl.getChangeType());
+ assertEquals("vlVnfdId", actualAffectedVl.getVldid());
+ assertEquals("myVnfId_vlId", actualAffectedVl.getVlInstanceId());
+ assertEquals("networkProviderId", actualAffectedVl.getNetworkResource().getResourceId());
+ assertEquals(AffectedVirtualLinkType.NETWORK, actualAffectedVl.getNetworkResource().getResourceType());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVnfc().size());
+ org.onap.vnfmdriver.model.AffectedVnfc actualAffectdVnfc = sentLcnToVfc.getValue().getAffectedVnfc().get(0);
+ assertEquals("myVduId", actualAffectdVnfc.getVduId());
+ assertEquals(VIM_ID, actualAffectdVnfc.getVimid());
+ assertEquals("myVmName", actualAffectdVnfc.getVmname());
+ assertEquals("serverProviderId", actualAffectdVnfc.getVmid());
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.ADDED, actualAffectdVnfc.getChangeType());
+ assertEquals("myVnfId_myVnfcId", actualAffectdVnfc.getVnfcInstanceId());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedCp().size());
+ AffectedCp actualAffectedCp = sentLcnToVfc.getValue().getAffectedCp().get(0);
+ assertEquals("cpVnfdId", actualAffectedCp.getCpdid());
+ assertEquals("myVnfId_cpId", actualAffectedCp.getCpinstanceid());
+ assertEquals(null, actualAffectedCp.getOwnerId());
+ assertEquals(null, actualAffectedCp.getOwnerType());
+ assertEquals("networkProviderId", actualAffectedCp.getVirtualLinkInstanceId());
+ assertEquals("1.2.3.4", actualAffectedCp.getPortResource().getIpAddress());
+ assertEquals("myMac", actualAffectedCp.getPortResource().getMacAddress());
+ assertEquals("tenantId", actualAffectedCp.getPortResource().getTenant());
+ assertEquals(VIM_ID, actualAffectedCp.getPortResource().getVimid());
+ assertEquals("serverProviderId", actualAffectedCp.getPortResource().getInstId());
+ assertEquals("portProviderId", actualAffectedCp.getPortResource().getResourceid());
+ assertEquals("myPortName", actualAffectedCp.getPortResource().getResourceName());
+ assertEquals(VnfCpNotificationType.ADDED, actualAffectedCp.getChangeType());
+
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.INSTANTIATE, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.RESULT, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ }
+
+ /**
+ * test end notification success scenario for ECP
+ */
+ @Test
+ public void testFinishLcnForEcp() {
+ //given
+ recievedLcn.setOperation(OperationType.INSTANTIATE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setChangeType(ChangeType.ADDED);
+ affectedVnfc.setId("myVnfcId");
+ affectedVnfc.setVduId("myVduId");
+ affectedVnfc.setStorageResourceIds(Lists.newArrayList("storageId1"));
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.getComputeResource().setVimId(VIM_ID);
+ affectedVnfc.getComputeResource().setAdditionalData(new JsonParser().parse("{ \"name\" : \"myVmName\" } "));
+ recievedLcn.setAffectedVnfcs(new ArrayList<>());
+ recievedLcn.getAffectedVnfcs().add(affectedVnfc);
+
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ //affectedCp.setCpdId("cpVnfdId");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setMacAddress("myMac");
+ affectedCp.setName("myPortName");
+ affectedCp.setCpId("cpId");
+ affectedCp.setEcpdId("ecpdId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setTenantId("tenantId");
+ affectedConnectionPoints.getPost().add(affectedCp);
+
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = affectedConnectionPoints;
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ instantiationOperation.setAdditionalData(additionalData);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, instantiationOperation, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedCp().size());
+ AffectedCp actualAffectedCp = sentLcnToVfc.getValue().getAffectedCp().get(0);
+ assertEquals("ecpdId", actualAffectedCp.getCpdid());
+ assertEquals("myVnfId_cpId", actualAffectedCp.getCpinstanceid());
+ assertEquals(null, actualAffectedCp.getOwnerId());
+ assertEquals(null, actualAffectedCp.getOwnerType());
+ assertEquals("networkProviderId", actualAffectedCp.getVirtualLinkInstanceId());
+ assertEquals("1.2.3.4", actualAffectedCp.getPortResource().getIpAddress());
+ assertEquals("myMac", actualAffectedCp.getPortResource().getMacAddress());
+ assertEquals("tenantId", actualAffectedCp.getPortResource().getTenant());
+ assertEquals(VIM_ID, actualAffectedCp.getPortResource().getVimid());
+ assertEquals("serverProviderId", actualAffectedCp.getPortResource().getInstId());
+ assertEquals("portProviderId", actualAffectedCp.getPortResource().getResourceid());
+ assertEquals("myPortName", actualAffectedCp.getPortResource().getResourceName());
+ assertEquals(VnfCpNotificationType.ADDED, actualAffectedCp.getChangeType());
+ }
+
+ /**
+ * test end notification success scenario with termination
+ */
+ @Test
+ public void testFinishLcnWithTerminate() {
+ //given
+ recievedLcn.setOperation(OperationType.TERMINATE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setChangeType(ChangeType.REMOVED);
+ affectedVnfc.setId("myVnfcId");
+ affectedVnfc.setVduId("myVduId");
+ affectedVnfc.setStorageResourceIds(Lists.newArrayList("storageId1"));
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.getComputeResource().setVimId(VIM_ID);
+ affectedVnfc.getComputeResource().setAdditionalData(new JsonParser().parse("{ \"name\" : \"myVmName\" } "));
+ recievedLcn.setAffectedVnfcs(new ArrayList<>());
+ recievedLcn.getAffectedVnfcs().add(affectedVnfc);
+
+ AffectedVirtualLink affectedVirtualLink = new AffectedVirtualLink();
+ affectedVirtualLink.setChangeType(ChangeType.REMOVED);
+ affectedVirtualLink.setId("vlId");
+ affectedVirtualLink.setVirtualLinkDescId("vlVnfdId");
+ affectedVirtualLink.setResource(new ResourceHandle());
+ affectedVirtualLink.getResource().setVimId(VIM_ID);
+ affectedVirtualLink.getResource().setResourceId("networkProviderId");
+ recievedLcn.setAffectedVirtualLinks(new ArrayList<>());
+ recievedLcn.getAffectedVirtualLinks().add(affectedVirtualLink);
+
+ AffectedVirtualStorage affectedStorage = new AffectedVirtualStorage();
+ affectedStorage.setChangeType(ChangeType.REMOVED);
+ affectedStorage.setId("storageId");
+ affectedStorage.setVirtualStorageDescId("storageVnfdId");
+ affectedStorage.setResource(new ResourceHandle());
+ affectedStorage.getResource().setVimId(VIM_ID);
+ affectedStorage.getResource().setResourceId("storageProviderId");
+ recievedLcn.setAffectedVirtualStorages(new ArrayList<>());
+ recievedLcn.getAffectedVirtualStorages().add(affectedStorage);
+
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpVnfdId");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setMacAddress("myMac");
+ affectedCp.setName("myPortName");
+ affectedCp.setCpId("cpId");
+
+ // affectedCp.setEcpdId("ecpdId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setTenantId("tenantId");
+ affectedConnectionPoints.getPre().add(affectedCp);
+
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = affectedConnectionPoints;
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ instantiationOperation.setAdditionalData(additionalData);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, terminationOperation, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVl().size());
+ org.onap.vnfmdriver.model.AffectedVirtualLink actualAffectedVl = sentLcnToVfc.getValue().getAffectedVl().get(0);
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.REMOVED, actualAffectedVl.getChangeType());
+ assertEquals("vlVnfdId", actualAffectedVl.getVldid());
+ assertEquals("myVnfId_vlId", actualAffectedVl.getVlInstanceId());
+ assertEquals("networkProviderId", actualAffectedVl.getNetworkResource().getResourceId());
+ assertEquals(AffectedVirtualLinkType.NETWORK, actualAffectedVl.getNetworkResource().getResourceType());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVnfc().size());
+ org.onap.vnfmdriver.model.AffectedVnfc actualAffectdVnfc = sentLcnToVfc.getValue().getAffectedVnfc().get(0);
+ assertEquals("myVduId", actualAffectdVnfc.getVduId());
+ assertEquals(VIM_ID, actualAffectdVnfc.getVimid());
+ assertEquals("myVmName", actualAffectdVnfc.getVmname());
+ assertEquals("serverProviderId", actualAffectdVnfc.getVmid());
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.REMOVED, actualAffectdVnfc.getChangeType());
+ assertEquals("myVnfId_myVnfcId", actualAffectdVnfc.getVnfcInstanceId());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedCp().size());
+ AffectedCp actualAffectedCp = sentLcnToVfc.getValue().getAffectedCp().get(0);
+ assertEquals("cpVnfdId", actualAffectedCp.getCpdid());
+ assertEquals("myVnfId_cpId", actualAffectedCp.getCpinstanceid());
+ assertEquals(null, actualAffectedCp.getOwnerId());
+ assertEquals(null, actualAffectedCp.getOwnerType());
+ assertEquals("networkProviderId", actualAffectedCp.getVirtualLinkInstanceId());
+ assertEquals("1.2.3.4", actualAffectedCp.getPortResource().getIpAddress());
+ assertEquals("myMac", actualAffectedCp.getPortResource().getMacAddress());
+ assertEquals("tenantId", actualAffectedCp.getPortResource().getTenant());
+ assertEquals(VnfCpNotificationType.REMOVED, actualAffectedCp.getChangeType());
+ assertEquals(VIM_ID, actualAffectedCp.getPortResource().getVimid());
+ assertEquals("serverProviderId", actualAffectedCp.getPortResource().getInstId());
+ assertEquals("portProviderId", actualAffectedCp.getPortResource().getResourceid());
+ assertEquals("myPortName", actualAffectedCp.getPortResource().getResourceName());
+
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.TERMINAL, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.RESULT, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ }
+
+ /**
+ * test end notification success scenario for modifiction (heal)
+ * - LCN is sent to VF-C
+ */
+ @Test
+ public void testFinishLcnForModification() {
+ //given
+ recievedLcn.setOperation(OperationType.HEAL);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setChangeType(ChangeType.MODIFIED);
+ affectedVnfc.setId("myVnfcId");
+ affectedVnfc.setVduId("myVduId");
+ affectedVnfc.setStorageResourceIds(Lists.newArrayList("storageId1"));
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.getComputeResource().setVimId(VIM_ID);
+ affectedVnfc.getComputeResource().setAdditionalData(new JsonParser().parse("{ \"name\" : \"myVmName\" } "));
+ recievedLcn.setAffectedVnfcs(new ArrayList<>());
+ recievedLcn.getAffectedVnfcs().add(affectedVnfc);
+
+ AffectedVirtualLink affectedVirtualLink = new AffectedVirtualLink();
+ affectedVirtualLink.setChangeType(ChangeType.MODIFIED);
+ affectedVirtualLink.setId("vlId");
+ affectedVirtualLink.setVirtualLinkDescId("vlVnfdId");
+ affectedVirtualLink.setResource(new ResourceHandle());
+ affectedVirtualLink.getResource().setVimId(VIM_ID);
+ affectedVirtualLink.getResource().setResourceId("networkProviderId");
+ recievedLcn.setAffectedVirtualLinks(new ArrayList<>());
+ recievedLcn.getAffectedVirtualLinks().add(affectedVirtualLink);
+
+
+ AffectedVirtualStorage affectedStorage = new AffectedVirtualStorage();
+ affectedStorage.setChangeType(ChangeType.MODIFIED);
+ affectedStorage.setId("storageId");
+ affectedStorage.setVirtualStorageDescId("storageVnfdId");
+ affectedStorage.setResource(new ResourceHandle());
+ affectedStorage.getResource().setVimId(VIM_ID);
+ affectedStorage.getResource().setResourceId("storageProviderId");
+ recievedLcn.setAffectedVirtualStorages(new ArrayList<>());
+ recievedLcn.getAffectedVirtualStorages().add(affectedStorage);
+
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpVnfdId");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setMacAddress("myMac");
+ affectedCp.setName("myPortName");
+ affectedCp.setCpId("cpId");
+
+ // affectedCp.setEcpdId("ecpdId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setTenantId("tenantId");
+ affectedConnectionPoints.getPre().add(affectedCp);
+
+ ReportedAffectedCp after = new ReportedAffectedCp();
+ after.setCpdId("cpVnfdId");
+ after.setIpAddress("1.2.3.5");
+ after.setMacAddress("myMac");
+ after.setName("myPortName");
+ after.setCpId("cpId");
+
+ // affectedCp.setEcpdId("ecpdId");
+ after.setNetworkProviderId("networkProviderId");
+ after.setProviderId("portProviderId");
+ after.setServerProviderId("serverProviderId");
+ after.setTenantId("tenantId");
+ affectedConnectionPoints.getPost().add(after);
+
+
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = affectedConnectionPoints;
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ instantiationOperation.setAdditionalData(additionalData);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, healOperation, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVl().size());
+ org.onap.vnfmdriver.model.AffectedVirtualLink actualAffectedVl = sentLcnToVfc.getValue().getAffectedVl().get(0);
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.MODIFIED, actualAffectedVl.getChangeType());
+ assertEquals("vlVnfdId", actualAffectedVl.getVldid());
+ assertEquals("myVnfId_vlId", actualAffectedVl.getVlInstanceId());
+ assertEquals("networkProviderId", actualAffectedVl.getNetworkResource().getResourceId());
+ assertEquals(AffectedVirtualLinkType.NETWORK, actualAffectedVl.getNetworkResource().getResourceType());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVnfc().size());
+ org.onap.vnfmdriver.model.AffectedVnfc actualAffectdVnfc = sentLcnToVfc.getValue().getAffectedVnfc().get(0);
+ assertEquals("myVduId", actualAffectdVnfc.getVduId());
+ assertEquals(VIM_ID, actualAffectdVnfc.getVimid());
+ assertEquals("myVmName", actualAffectdVnfc.getVmname());
+ assertEquals("serverProviderId", actualAffectdVnfc.getVmid());
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.MODIFIED, actualAffectdVnfc.getChangeType());
+ assertEquals("myVnfId_myVnfcId", actualAffectdVnfc.getVnfcInstanceId());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedCp().size());
+ AffectedCp actualAffectedCp = sentLcnToVfc.getValue().getAffectedCp().get(0);
+ assertEquals("cpVnfdId", actualAffectedCp.getCpdid());
+ assertEquals("myVnfId_cpId", actualAffectedCp.getCpinstanceid());
+ assertEquals(null, actualAffectedCp.getOwnerId());
+ assertEquals(null, actualAffectedCp.getOwnerType());
+ assertEquals("networkProviderId", actualAffectedCp.getVirtualLinkInstanceId());
+ assertEquals("1.2.3.5", actualAffectedCp.getPortResource().getIpAddress());
+ assertEquals("myMac", actualAffectedCp.getPortResource().getMacAddress());
+ assertEquals("tenantId", actualAffectedCp.getPortResource().getTenant());
+ assertEquals(VIM_ID, actualAffectedCp.getPortResource().getVimid());
+ assertEquals("serverProviderId", actualAffectedCp.getPortResource().getInstId());
+ assertEquals("portProviderId", actualAffectedCp.getPortResource().getResourceid());
+ assertEquals("myPortName", actualAffectedCp.getPortResource().getResourceName());
+ assertEquals(VnfCpNotificationType.CHANGED, actualAffectedCp.getChangeType());
+
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.HEAL, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.RESULT, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ }
+
+ /**
+ * test end notification success scenario for scale-out
+ * - LCN is sent to VF-C
+ */
+ @Test
+ public void testFinishLcnForScaleout() {
+ //given
+ recievedLcn.setOperation(OperationType.SCALE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ recievedLcn.setLifecycleOperationOccurrenceId(scaleOperation.getId());
+ ScaleVnfRequest request = new ScaleVnfRequest();
+ request.setAdditionalParams(new JsonParser().parse("{ \"jobId\" : \"" + JOB_ID + "\" }"));
+ request.setType(ScaleDirection.OUT);
+ scaleOperation.setOperationParams(request);
+ scaleOperation.setOperationType(OperationType.SCALE);
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setChangeType(ChangeType.ADDED);
+ affectedVnfc.setId("myVnfcId");
+ affectedVnfc.setVduId("myVduId");
+ affectedVnfc.setStorageResourceIds(Lists.newArrayList("storageId1"));
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.getComputeResource().setVimId(VIM_ID);
+ affectedVnfc.getComputeResource().setAdditionalData(new JsonParser().parse("{ \"name\" : \"myVmName\" } "));
+ recievedLcn.setAffectedVnfcs(new ArrayList<>());
+ recievedLcn.getAffectedVnfcs().add(affectedVnfc);
+
+ AffectedVirtualLink affectedVirtualLink = new AffectedVirtualLink();
+ affectedVirtualLink.setChangeType(ChangeType.ADDED);
+ affectedVirtualLink.setId("vlId");
+ affectedVirtualLink.setVirtualLinkDescId("vlVnfdId");
+ affectedVirtualLink.setResource(new ResourceHandle());
+ affectedVirtualLink.getResource().setVimId(VIM_ID);
+ affectedVirtualLink.getResource().setResourceId("networkProviderId");
+ recievedLcn.setAffectedVirtualLinks(new ArrayList<>());
+ recievedLcn.getAffectedVirtualLinks().add(affectedVirtualLink);
+
+
+ AffectedVirtualStorage affectedStorage = new AffectedVirtualStorage();
+ affectedStorage.setChangeType(ChangeType.ADDED);
+ affectedStorage.setId("storageId");
+ affectedStorage.setVirtualStorageDescId("storageVnfdId");
+ affectedStorage.setResource(new ResourceHandle());
+ affectedStorage.getResource().setVimId(VIM_ID);
+ affectedStorage.getResource().setResourceId("storageProviderId");
+ recievedLcn.setAffectedVirtualStorages(new ArrayList<>());
+ recievedLcn.getAffectedVirtualStorages().add(affectedStorage);
+
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpVnfdId");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setMacAddress("myMac");
+ affectedCp.setName("myPortName");
+ affectedCp.setCpId("cpId");
+
+ // affectedCp.setEcpdId("ecpdId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setTenantId("tenantId");
+ affectedConnectionPoints.getPost().add(affectedCp);
+
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = affectedConnectionPoints;
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ scaleOperation.setAdditionalData(additionalData);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, scaleOperation, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVl().size());
+ org.onap.vnfmdriver.model.AffectedVirtualLink actualAffectedVl = sentLcnToVfc.getValue().getAffectedVl().get(0);
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.ADDED, actualAffectedVl.getChangeType());
+ assertEquals("vlVnfdId", actualAffectedVl.getVldid());
+ assertEquals("myVnfId_vlId", actualAffectedVl.getVlInstanceId());
+ assertEquals("networkProviderId", actualAffectedVl.getNetworkResource().getResourceId());
+ assertEquals(AffectedVirtualLinkType.NETWORK, actualAffectedVl.getNetworkResource().getResourceType());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVnfc().size());
+ org.onap.vnfmdriver.model.AffectedVnfc actualAffectdVnfc = sentLcnToVfc.getValue().getAffectedVnfc().get(0);
+ assertEquals("myVduId", actualAffectdVnfc.getVduId());
+ assertEquals(VIM_ID, actualAffectdVnfc.getVimid());
+ assertEquals("myVmName", actualAffectdVnfc.getVmname());
+ assertEquals("serverProviderId", actualAffectdVnfc.getVmid());
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.ADDED, actualAffectdVnfc.getChangeType());
+ assertEquals("myVnfId_myVnfcId", actualAffectdVnfc.getVnfcInstanceId());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedCp().size());
+ AffectedCp actualAffectedCp = sentLcnToVfc.getValue().getAffectedCp().get(0);
+ assertEquals("cpVnfdId", actualAffectedCp.getCpdid());
+ assertEquals("myVnfId_cpId", actualAffectedCp.getCpinstanceid());
+ assertEquals(null, actualAffectedCp.getOwnerId());
+ assertEquals(null, actualAffectedCp.getOwnerType());
+ assertEquals("networkProviderId", actualAffectedCp.getVirtualLinkInstanceId());
+ assertEquals("1.2.3.4", actualAffectedCp.getPortResource().getIpAddress());
+ assertEquals("myMac", actualAffectedCp.getPortResource().getMacAddress());
+ assertEquals("tenantId", actualAffectedCp.getPortResource().getTenant());
+ assertEquals(VIM_ID, actualAffectedCp.getPortResource().getVimid());
+ assertEquals("serverProviderId", actualAffectedCp.getPortResource().getInstId());
+ assertEquals("portProviderId", actualAffectedCp.getPortResource().getResourceid());
+ assertEquals("myPortName", actualAffectedCp.getPortResource().getResourceName());
+ assertEquals(VnfCpNotificationType.ADDED, actualAffectedCp.getChangeType());
+
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.SCALEOUT, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.RESULT, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ }
+
+ /**
+ * test end notification success scenario for scale-out
+ * - LCN is sent to VF-C
+ */
+ @Test
+ public void testFinishLcnForScaleIn() {
+ //given
+ recievedLcn.setOperation(OperationType.SCALE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ recievedLcn.setLifecycleOperationOccurrenceId(scaleOperation.getId());
+ ScaleVnfRequest request = new ScaleVnfRequest();
+ request.setAdditionalParams(new JsonParser().parse("{ \"jobId\" : \"" + JOB_ID + "\" }"));
+ request.setType(ScaleDirection.IN);
+ scaleOperation.setOperationParams(request);
+ AffectedVnfc affectedVnfc = new AffectedVnfc();
+ affectedVnfc.setChangeType(ChangeType.REMOVED);
+ affectedVnfc.setId("myVnfcId");
+ affectedVnfc.setVduId("myVduId");
+ affectedVnfc.setStorageResourceIds(Lists.newArrayList("storageId1"));
+ affectedVnfc.setComputeResource(new ResourceHandle());
+ affectedVnfc.getComputeResource().setResourceId("serverProviderId");
+ affectedVnfc.getComputeResource().setVimId(VIM_ID);
+ affectedVnfc.getComputeResource().setAdditionalData(new JsonParser().parse("{ \"name\" : \"myVmName\" } "));
+ recievedLcn.setAffectedVnfcs(new ArrayList<>());
+ recievedLcn.getAffectedVnfcs().add(affectedVnfc);
+
+ AffectedVirtualLink affectedVirtualLink = new AffectedVirtualLink();
+ affectedVirtualLink.setChangeType(ChangeType.REMOVED);
+ affectedVirtualLink.setId("vlId");
+ affectedVirtualLink.setVirtualLinkDescId("vlVnfdId");
+ affectedVirtualLink.setResource(new ResourceHandle());
+ affectedVirtualLink.getResource().setVimId(VIM_ID);
+ affectedVirtualLink.getResource().setResourceId("networkProviderId");
+ recievedLcn.setAffectedVirtualLinks(new ArrayList<>());
+ recievedLcn.getAffectedVirtualLinks().add(affectedVirtualLink);
+
+
+ AffectedVirtualStorage affectedStorage = new AffectedVirtualStorage();
+ affectedStorage.setChangeType(ChangeType.REMOVED);
+ affectedStorage.setId("storageId");
+ affectedStorage.setVirtualStorageDescId("storageVnfdId");
+ affectedStorage.setResource(new ResourceHandle());
+ affectedStorage.getResource().setVimId(VIM_ID);
+ affectedStorage.getResource().setResourceId("storageProviderId");
+ recievedLcn.setAffectedVirtualStorages(new ArrayList<>());
+ recievedLcn.getAffectedVirtualStorages().add(affectedStorage);
+
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpVnfdId");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setMacAddress("myMac");
+ affectedCp.setName("myPortName");
+ affectedCp.setCpId("cpId");
+
+ // affectedCp.setEcpdId("ecpdId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setTenantId("tenantId");
+ affectedConnectionPoints.getPre().add(affectedCp);
+
+
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = affectedConnectionPoints;
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ scaleOperation.setAdditionalData(additionalData);
+ scaleOperation.setOperationType(OperationType.SCALE);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, scaleOperation, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVl().size());
+ org.onap.vnfmdriver.model.AffectedVirtualLink actualAffectedVl = sentLcnToVfc.getValue().getAffectedVl().get(0);
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.REMOVED, actualAffectedVl.getChangeType());
+ assertEquals("vlVnfdId", actualAffectedVl.getVldid());
+ assertEquals("myVnfId_vlId", actualAffectedVl.getVlInstanceId());
+ assertEquals("networkProviderId", actualAffectedVl.getNetworkResource().getResourceId());
+ assertEquals(AffectedVirtualLinkType.NETWORK, actualAffectedVl.getNetworkResource().getResourceType());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedVnfc().size());
+ org.onap.vnfmdriver.model.AffectedVnfc actualAffectdVnfc = sentLcnToVfc.getValue().getAffectedVnfc().get(0);
+ assertEquals("myVduId", actualAffectdVnfc.getVduId());
+ assertEquals(VIM_ID, actualAffectdVnfc.getVimid());
+ assertEquals("myVmName", actualAffectdVnfc.getVmname());
+ assertEquals("serverProviderId", actualAffectdVnfc.getVmid());
+ assertEquals(org.onap.vnfmdriver.model.VnfNotificationType.REMOVED, actualAffectdVnfc.getChangeType());
+ assertEquals("myVnfId_myVnfcId", actualAffectdVnfc.getVnfcInstanceId());
+
+ assertEquals(1, sentLcnToVfc.getValue().getAffectedCp().size());
+ AffectedCp actualAffectedCp = sentLcnToVfc.getValue().getAffectedCp().get(0);
+ assertEquals("cpVnfdId", actualAffectedCp.getCpdid());
+ assertEquals("myVnfId_cpId", actualAffectedCp.getCpinstanceid());
+ assertEquals(null, actualAffectedCp.getOwnerId());
+ assertEquals(null, actualAffectedCp.getOwnerType());
+ assertEquals("networkProviderId", actualAffectedCp.getVirtualLinkInstanceId());
+ assertEquals("1.2.3.4", actualAffectedCp.getPortResource().getIpAddress());
+ assertEquals("myMac", actualAffectedCp.getPortResource().getMacAddress());
+ assertEquals("tenantId", actualAffectedCp.getPortResource().getTenant());
+ assertEquals(VIM_ID, actualAffectedCp.getPortResource().getVimid());
+ assertEquals("serverProviderId", actualAffectedCp.getPortResource().getInstId());
+ assertEquals("portProviderId", actualAffectedCp.getPortResource().getResourceid());
+ assertEquals("myPortName", actualAffectedCp.getPortResource().getResourceName());
+ assertEquals(VnfCpNotificationType.REMOVED, actualAffectedCp.getChangeType());
+
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.SCALEIN, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.RESULT, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ }
+
+
+ /**
+ * en empty LCN is sent even if nothing has changed
+ */
+ @Test
+ public void testNothingChanged() {
+ //given
+ recievedLcn.setOperation(OperationType.SCALE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ recievedLcn.setLifecycleOperationOccurrenceId(scaleOperation.getId());
+ ScaleVnfRequest request = new ScaleVnfRequest();
+ request.setAdditionalParams(new JsonParser().parse("{ \"jobId\" : \"" + JOB_ID + "\" }"));
+ request.setType(ScaleDirection.IN);
+ scaleOperation.setOperationParams(request);
+ OperationResult operationResult = new OperationResult();
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ scaleOperation.setAdditionalData(additionalData);
+ scaleOperation.setOperationType(OperationType.SCALE);
+ when(logger.isInfoEnabled()).thenReturn(false);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, scaleOperation, empty(), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertNull(sentLcnToVfc.getValue().getAffectedVl());
+ assertNull(sentLcnToVfc.getValue().getAffectedVnfc());
+ assertNull(sentLcnToVfc.getValue().getAffectedCp());
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.SCALEIN, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.RESULT, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ verify(logger, never()).info(eq("Sending LCN: {}"), anyString());
+ }
+
+ /**
+ * If a connection point is not modified it is not contained in the LCN
+ */
+ @Test
+ public void testNonModifiedCP() {
+ //given
+ recievedLcn.setOperation(OperationType.HEAL);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+
+ ReportedAffectedConnectionPoints affectedConnectionPoints = new ReportedAffectedConnectionPoints();
+ ReportedAffectedCp affectedCp = new ReportedAffectedCp();
+ affectedCp.setCpdId("cpVnfdId");
+ affectedCp.setIpAddress("1.2.3.4");
+ affectedCp.setMacAddress("myMac");
+ affectedCp.setName("myPortName");
+ affectedCp.setCpId("cpId");
+
+ // affectedCp.setEcpdId("ecpdId");
+ affectedCp.setNetworkProviderId("networkProviderId");
+ affectedCp.setProviderId("portProviderId");
+ affectedCp.setServerProviderId("serverProviderId");
+ affectedCp.setTenantId("tenantId");
+ affectedConnectionPoints.getPre().add(affectedCp);
+
+ ReportedAffectedCp after = new ReportedAffectedCp();
+ after.setCpdId("cpVnfdId");
+ after.setIpAddress("1.2.3.4");
+ after.setMacAddress("myMac");
+ after.setName("myPortName");
+ after.setCpId("cpId");
+
+ // affectedCp.setEcpdId("ecpdId");
+ after.setNetworkProviderId("networkProviderId");
+ after.setProviderId("portProviderId");
+ after.setServerProviderId("serverProviderId");
+ after.setTenantId("tenantId");
+ affectedConnectionPoints.getPost().add(after);
+
+
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = affectedConnectionPoints;
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ instantiationOperation.setAdditionalData(additionalData);
+ //when
+ vfcNotificationSender.processNotification(recievedLcn, healOperation, of(affectedConnectionPoints), VIM_ID);
+ //verify
+ assertEquals(1, sentLcnToVfc.getAllValues().size());
+
+ assertNull(sentLcnToVfc.getValue().getAffectedVl());
+ assertNull(sentLcnToVfc.getValue().getAffectedVnfc());
+ assertEquals(0, sentLcnToVfc.getValue().getAffectedCp().size());
+ assertNull(sentLcnToVfc.getValue().getAffectedVirtualStorage());
+ assertEquals(JOB_ID, sentLcnToVfc.getValue().getJobId());
+ assertEquals(org.onap.vnfmdriver.model.OperationType.HEAL, sentLcnToVfc.getValue().getOperation());
+ assertEquals(VnfLcmNotificationStatus.RESULT, sentLcnToVfc.getValue().getStatus());
+ assertEquals(VNF_ID, sentLcnToVfc.getValue().getVnfInstanceId());
+ }
+
+ /**
+ * Unable to send notification to VF-C results in error
+ */
+ @Test
+ public void testUnableToSendNotificationToVfc() throws Exception {
+ ApiException expectedException = new ApiException();
+ doThrow(expectedException).when(nsLcmApi).vNFLCMNotification(any(), any(), any());
+ recievedLcn.setStatus(OperationStatus.STARTED);
+ recievedLcn.setOperation(OperationType.INSTANTIATE);
+ //when
+ try {
+ vfcNotificationSender.processNotification(recievedLcn, instantiationOperation, empty(), VIM_ID);
+ //verify
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to send LCN to VF-C", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ class OperationResult {
+ ReportedAffectedConnectionPoints operationResult;
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcPackageProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcPackageProvider.java
new file mode 100644
index 00000000..b027ccad
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcPackageProvider.java
@@ -0,0 +1,156 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import org.apache.http.HttpHeaders;
+import org.apache.http.client.methods.HttpGet;
+import org.junit.Assert;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.IpMappingProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vfccatalog.ApiException;
+import org.onap.vfccatalog.model.VnfPkgDetailInfo;
+import org.onap.vfccatalog.model.VnfPkgInfo;
+
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestVfcPackageProvider extends TestBase {
+
+ private static final String CSAR_ID = "csarId";
+ private static final String CBAM_VNFD_ID = "CBAM_VNFD_ID";
+ @Mock
+ private IpMappingProvider ipMappingProvider;
+
+ @Mock
+ private VfcPackageProvider vfcPackageProvider;
+
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(VfcPackageProvider.class, "logger", logger);
+ vfcPackageProvider = new VfcPackageProvider(vfcRestApiProvider, ipMappingProvider);
+ }
+
+ /**
+ * query CBAM VNFD identifier from VF-C catalog
+ */
+ @Test
+ public void testGetCbamVnfd() throws Exception {
+ VnfPkgDetailInfo vnfPackageDetails = new VnfPkgDetailInfo();
+ vnfPackageDetails.setCsarId(CSAR_ID);
+ vnfPackageDetails.setPackageInfo(new VnfPkgInfo());
+ vnfPackageDetails.getPackageInfo().setVnfdModel("{ \"metadata\" : { \"resourceVendorModelNumber\" : \"" + CBAM_VNFD_ID + "\" }}");
+ vnfPackageDetails.getPackageInfo().setDownloadUrl("http://127.0.0.1/a.csar");
+ when(vfcCatalogApi.queryVnfPackage(CSAR_ID)).thenReturn(vnfPackageDetails);
+ //when
+ String cbamVnfdId = vfcPackageProvider.getCbamVnfdId(CSAR_ID);
+ //verify
+ assertEquals(CBAM_VNFD_ID, cbamVnfdId);
+ }
+
+ /**
+ * download ONAP VNFD from VF-C catalog
+ */
+ @Test
+ public void testDownload() throws Exception {
+ VnfPkgDetailInfo vnfPackageDetails = new VnfPkgDetailInfo();
+ vnfPackageDetails.setCsarId(CSAR_ID);
+ vnfPackageDetails.setPackageInfo(new VnfPkgInfo());
+ vnfPackageDetails.getPackageInfo().setVnfdModel("{ \"metadata\" : { \"resourceVendorModelNumber\" : \"" + CBAM_VNFD_ID + "\" }}");
+ vnfPackageDetails.getPackageInfo().setDownloadUrl("http://127.0.0.1/a.csar");
+ when(vfcCatalogApi.queryVnfPackage(CSAR_ID)).thenReturn(vnfPackageDetails);
+ byte[] onapPackageContent = TestUtil.loadFile("unittests/TestCbamCatalogManager.sample.csar");
+ when(ipMappingProvider.mapPrivateIpToPublicIp("127.0.0.1")).thenReturn("1.2.3.4");
+ when(entity.getContent()).thenReturn(new ByteArrayInputStream(onapPackageContent));
+ //when
+ byte[] actualContent = vfcPackageProvider.getPackage(CSAR_ID);
+ //verify
+ Assert.assertArrayEquals(onapPackageContent, actualContent);
+ assertEquals(HttpGet.class, request.getValue().getClass());
+ assertEquals("http://1.2.3.4/a.csar", request.getValue().getURI().toString());
+ assertEquals("application/octet-stream", request.getValue().getFirstHeader(HttpHeaders.ACCEPT).getValue());
+ }
+
+ /**
+ * failure to query package from VF-C is propagated
+ */
+ @Test
+ public void unableToGetCbamVnfdFromCatalog() throws Exception {
+ ApiException expectedException = new ApiException();
+ when(vfcCatalogApi.queryVnfPackage(CSAR_ID)).thenThrow(expectedException);
+ //when
+ try {
+ vfcPackageProvider.getCbamVnfdId(CSAR_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to query VNF package with csarId", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * failure to download package from VF-C is propagated
+ */
+ @Test
+ public void unableToDownloadFromCatalog() throws Exception {
+ VnfPkgDetailInfo vnfPackageDetails = new VnfPkgDetailInfo();
+ vnfPackageDetails.setCsarId(CSAR_ID);
+ vnfPackageDetails.setPackageInfo(new VnfPkgInfo());
+ vnfPackageDetails.getPackageInfo().setVnfdModel("{ \"metadata\" : { \"resourceVendorModelNumber\" : \"" + CBAM_VNFD_ID + "\" }}");
+ vnfPackageDetails.getPackageInfo().setDownloadUrl("http://127.0.0.1/a.csar");
+ when(vfcCatalogApi.queryVnfPackage(CSAR_ID)).thenReturn(vnfPackageDetails);
+ byte[] onapPackageContent = TestUtil.loadFile("unittests/TestCbamCatalogManager.sample.csar");
+ when(ipMappingProvider.mapPrivateIpToPublicIp("127.0.0.1")).thenReturn("1.2.3.4");
+ IOException expectedException = new IOException();
+ when(httpClient.execute(Mockito.any())).thenThrow(expectedException);
+ //when
+ try {
+ vfcPackageProvider.getPackage(CSAR_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to download package from http://1.2.3.4/a.csar", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * failure to query package for download package from VF-C is propagated
+ */
+ @Test
+ public void unableToQueryPackageForDownloadFromCatalog() throws Exception {
+ ApiException expectedException = new ApiException();
+ when(vfcCatalogApi.queryVnfPackage(CSAR_ID)).thenThrow(expectedException);
+ //when
+ try {
+ vfcPackageProvider.getPackage(CSAR_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to query VNF package with csarId", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcRestApiProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcRestApiProvider.java
new file mode 100644
index 00000000..a527b568
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/onap/vfc/TestVfcRestApiProvider.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vfccatalog.api.VnfpackageApi;
+import org.onap.vnfmdriver.api.NslcmApi;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.assertNull;
+import static org.mockito.Mockito.when;
+
+public class TestVfcRestApiProvider extends TestBase {
+ private VfcRestApiProvider vfcRestApiProvider;
+
+ @Before
+ public void init() {
+ vfcRestApiProvider = new VfcRestApiProvider(msbApiProvider);
+ }
+
+ /**
+ * test VF-C NSLCM API retrieval
+ */
+ @Test
+ public void testNsLcmApi() throws Exception {
+ when(msbApiProvider.getMicroServiceUrl(VfcRestApiProvider.NSLCM_API_SERVICE_NAME, VfcRestApiProvider.NSLCM_API_VERION)).thenReturn("http://1.2.3.4:1234/nslcm/v1/lead");
+ //when
+ NslcmApi nsLcmApi = vfcRestApiProvider.getNsLcmApi();
+ //verify
+ assertEquals("http://1.2.3.4:1234/lead", nsLcmApi.getApiClient().getBasePath());
+ assertNull(nsLcmApi.getApiClient().getSslCaCert());
+ assertEquals(0, nsLcmApi.getApiClient().getAuthentications().size());
+ }
+
+ /**
+ * test VF-C catalog API retrieval
+ */
+ @Test
+ public void testNsCatalogApi() throws Exception {
+ when(msbApiProvider.getMicroServiceUrl(VfcRestApiProvider.NSCATALOG_SERVICE_NAME, VfcRestApiProvider.NSCATALOG_API_VERSION)).thenReturn("http://1.2.3.4:1234/lead");
+ //when
+ VnfpackageApi nsCatalogApi = vfcRestApiProvider.getOnapCatalogApi();
+ //verify
+ assertEquals("http://1.2.3.4:1234/lead", nsCatalogApi.getApiClient().getBasePath());
+ assertNull(nsCatalogApi.getApiClient().getSslCaCert());
+ assertEquals(0, nsCatalogApi.getApiClient().getAuthentications().size());
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfPackageBuilder.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfPackageBuilder.java
new file mode 100644
index 00000000..3b80eca0
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfPackageBuilder.java
@@ -0,0 +1,54 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import static org.mockito.Mockito.when;
+
+
+public class TestCbamVnfPackageBuilder extends TestBase {
+ private CbamVnfPackageBuilder cbamVnfPackageBuilder = new CbamVnfPackageBuilder();
+
+ /**
+ *
+ */
+ @Test
+ public void testEmpty() throws Exception {
+ byte[] zipContent = TestUtil.loadFile("unittests/packageconverter/cbam.package.zip");
+ when(systemFunctions.loadFile("cbam.pre.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("cbam.post.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("cbam.collectConnectionPoints.js")).thenCallRealMethod();
+
+ //when
+ byte[] modifiedContent = cbamVnfPackageBuilder.toModifiedCbamVnfPackage(zipContent, "vnfdloc/a.yaml", "modifiedContent");
+ //verify
+ assertFileInZip(modifiedContent, "keep/me", "kuku\n".getBytes());
+ assertFileInZip(modifiedContent, "TOSCA-Metadata/TOSCA.meta", ("TOSCA-Meta-File-Version: 1.0\n" +
+ "CSAR-Version: 1.1\n" +
+ "Created-By: Nokia\n" +
+ "Entry-Definitions: vnfdloc/a.yaml\n").getBytes());
+ assertFileInZip(modifiedContent, "javascript/cbam.pre.collectConnectionPoints.js", TestUtil.loadFile("cbam.pre.collectConnectionPoints.js"));
+ assertFileInZip(modifiedContent, "javascript/cbam.post.collectConnectionPoints.js", TestUtil.loadFile("cbam.post.collectConnectionPoints.js"));
+ assertFileInZip(modifiedContent, "javascript/cbam.collectConnectionPoints.js", TestUtil.loadFile("cbam.collectConnectionPoints.js"));
+
+
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfdBuilder.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfdBuilder.java
new file mode 100644
index 00000000..5840ef4e
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestCbamVnfdBuilder.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import static junit.framework.TestCase.assertEquals;
+
+
+public class TestCbamVnfdBuilder extends TestBase {
+ private CbamVnfdBuilder packageTransformer = new CbamVnfdBuilder();
+
+ /**
+ * test package conversion on the most mininal VNFD possible
+ */
+ @Test
+ public void testEmpty() throws Exception {
+ String out = packageTransformer.build(new String(TestUtil.loadFile("unittests/packageconverter/cbam.minimal.original.vnfd.yaml")));
+ String expected = new String(TestUtil.loadFile("unittests/packageconverter/cbam.minimal.modified.vnfd.yaml"));
+ assertEquals(expected, out);
+ }
+
+ /**
+ * test package conversion on the most full VNFD possible
+ */
+ @Test
+ public void testFull() throws Exception {
+ String out = packageTransformer.build(new String(TestUtil.loadFile("unittests/packageconverter/cbam.full.original.vnfd.yaml")));
+ String expected = new String(TestUtil.loadFile("unittests/packageconverter/cbam.full.modified.vnfd.yaml"));
+ assertEquals(expected, out);
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfPackageBuilder.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfPackageBuilder.java
new file mode 100644
index 00000000..9c9f7958
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfPackageBuilder.java
@@ -0,0 +1,74 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.PrintStream;
+
+import static junit.framework.TestCase.assertEquals;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getFileInZip;
+
+
+public class TestOnapVnfPackageBuilder extends TestBase {
+
+ /**
+ * The the main reads from standard in and writes to standard out
+ */
+ @Test
+ public void testInputStreams() throws Exception {
+ ByteArrayOutputStream bos = new ByteArrayOutputStream();
+ PrintStream actualOut = new PrintStream(bos, true);
+ when(systemFunctions.out()).thenReturn(actualOut);
+ when(systemFunctions.in()).thenReturn(new ByteArrayInputStream(TestUtil.loadFile("unittests/packageconverter/cbam.package.zip")));
+ when(systemFunctions.loadFile("cbam.pre.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("cbam.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("cbam.post.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("TOSCA.meta")).thenCallRealMethod();
+ when(systemFunctions.loadFile("MainServiceTemplate.meta")).thenCallRealMethod();
+
+
+ String cbamVnfd = new String(TestUtil.loadFile("unittests/packageconverter/cbam.package.zip.vnfd"));
+ String expectedOnapVnfd = new OnapVnfdBuilder().toOnapVnfd(cbamVnfd);
+
+ //when
+ OnapVnfPackageBuilder.main(null);
+ //verify
+ assertFileInZip(bos.toByteArray(), "TOSCA-Metadata/TOSCA.meta", TestUtil.loadFile("TOSCA.meta"));
+ assertFileInZip(bos.toByteArray(), "Definitions/MainServiceTemplate.yaml", expectedOnapVnfd.getBytes());
+ assertFileInZip(bos.toByteArray(), "MainServiceTemplate.yaml", expectedOnapVnfd.getBytes());
+ assertFileInZip(bos.toByteArray(), "MainServiceTemplate.meta", TestUtil.loadFile("MainServiceTemplate.meta"));
+ ByteArrayOutputStream actualModifiedCbamVnfPackage = getFileInZip(new ByteArrayInputStream(bos.toByteArray()), "Artifacts/Deployment/OTHER/cbam.package.zip");
+ byte[] expectedModifiedCbamPackage = new CbamVnfPackageBuilder().toModifiedCbamVnfPackage(TestUtil.loadFile("unittests/packageconverter/cbam.package.zip"), "vnfdloc/a.yaml", new CbamVnfdBuilder().build(cbamVnfd));
+ assertItenticalZips(expectedModifiedCbamPackage, actualModifiedCbamVnfPackage.toByteArray());
+ }
+
+
+ /**
+ * Prevents moving the class (customer documentation) must be updated
+ */
+ @Test
+ public void testPreventMove() {
+ assertEquals("org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.OnapVnfPackageBuilder", OnapVnfPackageBuilder.class.getCanonicalName());
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfdBuilder.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfdBuilder.java
new file mode 100644
index 00000000..2cd0aa1e
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/packagetransformer/TestOnapVnfdBuilder.java
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import java.util.NoSuchElementException;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Mockito.verify;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+
+public class TestOnapVnfdBuilder extends TestBase {
+ private OnapVnfdBuilder packageTransformer = new OnapVnfdBuilder();
+
+
+ @Before
+ public void init() {
+ setField(OnapVnfdBuilder.class, "logger", logger);
+ }
+
+ @Test
+ public void indent() {
+ assertEquals(" x", packageTransformer.indent("x", 2));
+ assertEquals(" x\n", packageTransformer.indent("x\n", 2));
+ assertEquals(" x\n y", packageTransformer.indent("x\ny", 2));
+ assertEquals(" x\n y\n", packageTransformer.indent("x\ny\n", 2));
+ assertEquals(" \n", packageTransformer.indent("\n", 2));
+ }
+
+ /**
+ * Test empty VNFD conversion
+ */
+ @Test
+ public void testEmpty() {
+ assertEquals(new String(TestUtil.loadFile("unittests/packageconverter/empty.vnfd.onap.yaml")), packageTransformer.toOnapVnfd(new String(TestUtil.loadFile("unittests/packageconverter/empty.vnfd.cbam.yaml"))));
+ }
+
+ /**
+ * Test all Tosca nodes conversions for successful scenario
+ */
+ @Test
+ public void testNodes() {
+ assertEquals(new String(TestUtil.loadFile("unittests/packageconverter/nodes.vnfd.onap.yaml")), packageTransformer.toOnapVnfd(new String(TestUtil.loadFile("unittests/packageconverter/nodes.vnfd.cbam.yaml"))));
+ verify(logger).warn("The {} ecp does not have an internal connection point", "myEcpWithoutIcp");
+ verify(logger).warn("The {} ecp does not have an requirements section", "ecpWithIcpWithOutRequirements");
+ verify(logger).warn("The {} internal connection point of the {} ecp does not have a VDU", "icpWithoutVdu", "myEcpWithoutIcpWithoutVdu");
+ verify(logger).warn("The {} internal connection point of the {} ecp does not have a requirements section", "icpWithOutRequiements", "myEcpWithoutIcpWithoutIcpReq");
+ verify(logger).warn("The {} internal connection point does not have a VDU", "icpWithOutVdu");
+ verify(logger).warn("The {} internal connection point does not have a requirements section", "icpWithOutRequiements");
+ verify(logger).warn("The {} internal connection point does not have a VL", "icpWithOutVl");
+ verify(logger).warn("The {} type is not converted", "tosca.nodes.nfv.Unknown");
+ }
+
+ /**
+ * if a node refers to a non existing node it results in a failure
+ */
+ @Test
+ public void testInconsitentVnfd() {
+ try {
+ packageTransformer.toOnapVnfd(new String(TestUtil.loadFile("unittests/packageconverter/nodes.vnfd.inconsistent.cbam.yaml")));
+ fail();
+ } catch (NoSuchElementException e) {
+ assertEquals("The VNFD does not have a node called myComputeMissing but required by an other node", e.getMessage());
+ }
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestConverterApi.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestConverterApi.java
new file mode 100644
index 00000000..218c478e
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestConverterApi.java
@@ -0,0 +1,152 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import com.google.common.collect.Lists;
+import org.apache.http.entity.ContentType;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.CbamVnfPackageBuilder;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.CbamVnfdBuilder;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.packagetransformer.OnapVnfdBuilder;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.springframework.http.HttpHeaders;
+import org.springframework.http.HttpStatus;
+import org.springframework.mock.web.DelegatingServletOutputStream;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.Part;
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.PrintStream;
+import java.util.Arrays;
+
+import static junit.framework.TestCase.*;
+import static org.mockito.Matchers.any;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getFileInZip;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+
+public class TestConverterApi extends TestBase {
+
+ @InjectMocks
+ private ConverterApi converterApi;
+ @Mock
+ private HttpServletRequest httpRequest;
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(ConverterApi.class, "logger", logger);
+ }
+
+ /**
+ * test VNF package conversion success scenario
+ */
+ @Test
+ public void testConversion() throws Exception {
+ ByteArrayOutputStream bos = new ByteArrayOutputStream();
+ PrintStream actualOut = new PrintStream(bos, true);
+ when(systemFunctions.out()).thenReturn(actualOut);
+ when(systemFunctions.loadFile("cbam.pre.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("cbam.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("cbam.post.collectConnectionPoints.js")).thenCallRealMethod();
+ when(systemFunctions.loadFile("TOSCA.meta")).thenCallRealMethod();
+ when(systemFunctions.loadFile("MainServiceTemplate.meta")).thenCallRealMethod();
+ when(httpResponse.getOutputStream()).thenReturn(new DelegatingServletOutputStream(actualOut));
+ Part part = Mockito.mock(Part.class);
+ when(part.getInputStream()).thenReturn(new ByteArrayInputStream(TestUtil.loadFile("unittests/packageconverter/cbam.package.zip")));
+ when(httpRequest.getParts()).thenReturn(Lists.newArrayList(part));
+ //when
+ converterApi.convert(httpResponse, httpRequest);
+ //verify
+ verifyVnfPackageWritterToOutputStream(bos);
+ verify(httpResponse).addHeader(HttpHeaders.CONTENT_TYPE, ContentType.APPLICATION_OCTET_STREAM.getMimeType());
+ verify(httpResponse).setStatus(HttpStatus.OK.value());
+ verify(httpResponse).addHeader(HttpHeaders.CONTENT_LENGTH, Integer.toString(bos.toByteArray().length));
+ verify(httpResponse).addHeader(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + "core.csar" + "\"");
+ }
+
+ private void verifyVnfPackageWritterToOutputStream(ByteArrayOutputStream bos) throws Exception {
+ String cbamVnfd = new String(TestUtil.loadFile("unittests/packageconverter/cbam.package.zip.vnfd"));
+ String expectedOnapVnfd = new OnapVnfdBuilder().toOnapVnfd(cbamVnfd);
+ assertFileInZip(bos.toByteArray(), "TOSCA-Metadata/TOSCA.meta", TestUtil.loadFile("TOSCA.meta"));
+ assertFileInZip(bos.toByteArray(), "Definitions/MainServiceTemplate.yaml", expectedOnapVnfd.getBytes());
+ assertFileInZip(bos.toByteArray(), "MainServiceTemplate.yaml", expectedOnapVnfd.getBytes());
+ assertFileInZip(bos.toByteArray(), "MainServiceTemplate.meta", TestUtil.loadFile("MainServiceTemplate.meta"));
+ ByteArrayOutputStream actualModifiedCbamVnfPackage = getFileInZip(new ByteArrayInputStream(bos.toByteArray()), "Artifacts/Deployment/OTHER/cbam.package.zip");
+ byte[] expectedModifiedCbamPackage = new CbamVnfPackageBuilder().toModifiedCbamVnfPackage(TestUtil.loadFile("unittests/packageconverter/cbam.package.zip"), "vnfdloc/a.yaml", new CbamVnfdBuilder().build(cbamVnfd));
+ assertItenticalZips(expectedModifiedCbamPackage, actualModifiedCbamVnfPackage.toByteArray());
+ }
+
+ /**
+ * the HTML based converted page works
+ */
+ @Test
+ public void testConverterPage() throws Exception {
+ ByteArrayOutputStream bos = new ByteArrayOutputStream();
+ PrintStream actualOut = new PrintStream(bos, true);
+ when(httpResponse.getOutputStream()).thenReturn(new DelegatingServletOutputStream(actualOut));
+ when(systemFunctions.loadFile("upload.html")).thenCallRealMethod();
+ //when
+ converterApi.getUploadPageForConvertingVnfd(httpResponse);
+ //verify
+ assertTrue(Arrays.equals(TestUtil.loadFile("upload.html"), bos.toByteArray()));
+ verify(httpResponse).addHeader(HttpHeaders.CONTENT_LENGTH, Integer.toString(bos.toByteArray().length));
+ }
+
+ /**
+ * error is propagated if unable to extract package from HTTP request
+ */
+ @Test
+ public void testUnableToExtractPackageToBeConverted() throws Exception {
+ IOException expectedException = new IOException();
+ when(httpRequest.getParts()).thenThrow(expectedException);
+ try {
+ converterApi.convert(httpResponse, httpRequest);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to extract package from REST parameters", expectedException);
+ assertEquals("Unable to extract package from REST parameters", e.getMessage());
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * error is propagated if unable to extract package from HTTP request
+ */
+ @Test
+ public void testUnableToConvertPackage() throws Exception {
+ Part part = Mockito.mock(Part.class);
+ when(part.getInputStream()).thenReturn(new ByteArrayInputStream(TestUtil.loadFile("unittests/packageconverter/cbam.package.zip")));
+ when(httpRequest.getParts()).thenReturn(Lists.newArrayList(part));
+ try {
+ converterApi.convert(httpResponse, httpRequest);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error(eq("Unable to convert VNF package"), any(RuntimeException.class));
+ assertEquals("Unable to convert VNF package", e.getMessage());
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcmApi.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcmApi.java
new file mode 100644
index 00000000..6b04d69d
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcmApi.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.JobManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vnfmdriver.model.VnfHealRequest;
+import org.onap.vnfmdriver.model.VnfInstantiateRequest;
+import org.onap.vnfmdriver.model.VnfScaleRequest;
+import org.onap.vnfmdriver.model.VnfTerminateRequest;
+
+import static java.util.Optional.empty;
+import static org.apache.http.HttpStatus.SC_CREATED;
+import static org.mockito.Mockito.verify;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+
+public class TestLcmApi extends TestBase {
+
+ @Mock
+ private LifecycleManager lifecycleManager;
+ @Mock
+ private JobManager jobManager;
+ @InjectMocks
+ private LcmApi lcmApi;
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(LcmApi.class, "logger", logger);
+ }
+
+ /**
+ * test instantiation handled by LCM
+ */
+ @Test
+ public void testInstantiation() {
+ VnfInstantiateRequest req = new VnfInstantiateRequest();
+ //when
+ lcmApi.instantiateVnf(req, VNFM_ID, httpResponse);
+ //verify
+ verify(lifecycleManager).createAndInstantiate(VNFM_ID, req, httpResponse);
+ verify(httpResponse).setStatus(SC_CREATED);
+ verify(logger).info("REST: Instantiate VNF");
+ }
+
+ /**
+ * test heal handled by LCM
+ */
+ @Test
+ public void testHeal() {
+ VnfHealRequest req = new VnfHealRequest();
+ //when
+ lcmApi.healVnf(req, VNFM_ID, VNF_ID, httpResponse);
+ //verify
+ verify(lifecycleManager).healVnf(VNFM_ID, VNF_ID, req, empty(), httpResponse);
+ verify(logger).info("REST: Heal VNF");
+ }
+
+ /**
+ * test query handled by LCM
+ */
+ @Test
+ public void testQuery() {
+ //when
+ lcmApi.queryVnf(VNFM_ID, VNF_ID, httpResponse);
+ //verify
+ verify(lifecycleManager).queryVnf(VNFM_ID, VNF_ID);
+ verify(logger).info("REST: Query VNF");
+
+ }
+
+ /**
+ * test scale handled by LCM
+ */
+ @Test
+ public void testScale() {
+ VnfScaleRequest req = new VnfScaleRequest();
+ //when
+ lcmApi.scaleVnf(req, VNFM_ID, VNF_ID, httpResponse);
+ //verify
+ verify(lifecycleManager).scaleVnf(VNFM_ID, VNF_ID, req, httpResponse);
+ verify(logger).info("REST: Scale VNF");
+
+ }
+
+ /**
+ * test terminate handled by LCM
+ */
+ @Test
+ public void testTerminate() {
+ VnfTerminateRequest req = new VnfTerminateRequest();
+ //when
+ lcmApi.terminateVnf(req, VNFM_ID, VNF_ID, httpResponse);
+ //verify
+ verify(lifecycleManager).terminateVnf(VNFM_ID, VNF_ID, req, httpResponse);
+ verify(logger).info("REST: Terminate VNF");
+
+ }
+
+ /**
+ * test job query handled by job manager
+ */
+ @Test
+ public void testJob() {
+ //when
+ lcmApi.getJob(VNFM_ID, JOB_ID, httpResponse);
+ //verify
+ verify(jobManager).getJob(VNFM_ID, JOB_ID);
+ verify(logger).debug("REST: Query job");
+
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcnApi.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcnApi.java
new file mode 100644
index 00000000..fc6b97b4
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestLcnApi.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import com.nokia.cbam.lcm.v32.model.VnfLifecycleChangeNotification;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.LifecycleChangeNotificationManager;
+
+import static org.mockito.Mockito.verify;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+
+public class TestLcnApi extends TestBase {
+
+ @Mock
+ private VnfLifecycleChangeNotification lcn;
+ @Mock
+ private LifecycleChangeNotificationManager lcnManager;
+ @InjectMocks
+ private LcnApi lcnApi;
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(LcnApi.class, "logger", logger);
+ }
+
+ /**
+ * test REST "ping" from CBAM to driver
+ */
+ @Test
+ public void testPing() {
+ lcnApi.testLcnConnectivity(null);
+ //verify no exception is thrown
+ }
+
+ /**
+ * test LCN is handled by LCN manager
+ */
+ @Test
+ public void testHandleLcn() {
+ //when
+ lcnApi.handleLcn(lcn, httpResponse);
+ //verify
+ verify(lcnManager).handleLcn(lcn);
+ verify(logger).info("REST: handle LCN");
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerApi.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerApi.java
new file mode 100644
index 00000000..638f7237
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerApi.java
@@ -0,0 +1,62 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.springframework.http.HttpHeaders;
+import org.springframework.http.MediaType;
+
+import javax.servlet.ServletOutputStream;
+
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+
+public class TestSwaggerApi extends TestBase {
+
+ @InjectMocks
+ private SwaggerApi swaggerApi;
+
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(SwaggerApi.class, "logger", logger);
+ }
+
+ /**
+ * test swagger definition get
+ */
+ @Test
+ public void testSwaggerRetrieval() throws Exception {
+ byte[] bytes = new byte[]{1, 2};
+ when(selfRegistrationManager.getSwaggerApiDefinition()).thenReturn(bytes);
+ ServletOutputStream os = Mockito.mock(ServletOutputStream.class);
+ when(httpResponse.getOutputStream()).thenReturn(os);
+ //when
+ swaggerApi.getSwaggerApiDefinition(httpResponse);
+ //verify
+ verify(httpResponse).addHeader(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE);
+ verify(httpResponse).addHeader(HttpHeaders.CONTENT_LENGTH, Integer.toString(bytes.length));
+ verify(os).write(bytes);
+ verify(logger).info("REST: get swagger definition");
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerDefinitionConsistency.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerDefinitionConsistency.java
new file mode 100644
index 00000000..eeb79be8
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/restapi/TestSwaggerDefinitionConsistency.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.restapi;
+
+import com.google.common.collect.HashMultimap;
+import com.google.common.collect.Sets;
+import com.google.gson.JsonObject;
+import com.google.gson.JsonParser;
+import junit.framework.TestCase;
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestMethod;
+
+import java.lang.reflect.Method;
+import java.util.HashSet;
+import java.util.NoSuchElementException;
+import java.util.Set;
+
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.child;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil.loadFile;
+
+public class TestSwaggerDefinitionConsistency extends TestBase {
+
+ public static final HashSet<Class<?>> CLASSES = Sets.newHashSet(LcmApi.class, LcnApi.class, SwaggerApi.class, ConverterApi.class);
+
+ @Test
+ public void test() throws Exception {
+ JsonObject root = new JsonParser().parse(new String(loadFile("self.swagger.json"))).getAsJsonObject();
+ String basePath = root.get("basePath").getAsString();
+ HashMultimap<String, RequestMethod> expectedPaths = HashMultimap.create();
+ for (String pathName : child(root, "paths").keySet()) {
+ JsonObject path = child(child(root, "paths"), pathName);
+ for (String method : path.keySet()) {
+ locate(basePath + pathName);
+ expectedPaths.put(basePath + pathName, RequestMethod.valueOf(method.toUpperCase()));
+ }
+ }
+
+ for (Class<?> clazz : CLASSES) {
+ RequestMapping currentBasePath = clazz.getAnnotation(RequestMapping.class);
+ for (Method method : clazz.getMethods()) {
+ RequestMapping methodMapping = method.getAnnotation(RequestMapping.class);
+ if (methodMapping != null) {
+ String fPath = currentBasePath.value()[0] + methodMapping.value()[0];
+ RequestMethod restMethod = methodMapping.method()[0];
+ Set<RequestMethod> currentMethods = expectedPaths.get(fPath);
+ if (!currentMethods.contains(restMethod)) {
+ TestCase.fail("Not documented REST API" + fPath + " " + restMethod + " current " + currentMethods);
+ }
+ }
+ }
+ }
+ }
+
+ private void locate(String path) {
+ for (Class<?> clazz : CLASSES) {
+ RequestMapping basePath = clazz.getAnnotation(RequestMapping.class);
+ for (Method method : clazz.getMethods()) {
+ RequestMapping methodMapping = method.getAnnotation(RequestMapping.class);
+ if (methodMapping != null && path.equals(basePath.value()[0] + methodMapping.value()[0])) {
+ return;
+ }
+ }
+ }
+ throw new NoSuchElementException(path);
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestConditions.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestConditions.java
new file mode 100644
index 00000000..7a525b37
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestConditions.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring;
+
+import junit.framework.TestCase;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mock;
+import org.mockito.MockitoAnnotations;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+import org.springframework.context.annotation.ConditionContext;
+import org.springframework.core.env.Environment;
+
+import static org.mockito.Mockito.when;
+
+public class TestConditions {
+
+ @Mock
+ private ConditionContext conditionContext;
+ @Mock
+ private Environment environment;
+
+ private String[] activeProfiles = new String[]{"a", "b"};
+
+ @Before
+ public void init() {
+ MockitoAnnotations.initMocks(this);
+ when(conditionContext.getEnvironment()).thenReturn(environment);
+ when(environment.getActiveProfiles()).thenReturn(activeProfiles);
+ }
+
+ /**
+ * if direct integration is not specified VF-C based integration is used
+ */
+ @Test
+ public void testVfcBased() throws Exception {
+ //verify
+ TestCase.assertTrue(new Conditions.UseForVfc().matches(conditionContext, null));
+ TestCase.assertFalse(new Conditions.UseForDirect().matches(conditionContext, null));
+ }
+
+ /**
+ * if direct integration is not specified VF-C based integration is used
+ */
+ @Test
+ public void testDirectBased() throws Exception {
+ activeProfiles[1] = "direct";
+ //verify
+ TestCase.assertFalse(new Conditions.UseForVfc().matches(conditionContext, null));
+ TestCase.assertTrue(new Conditions.UseForDirect().matches(conditionContext, null));
+ }
+
+ /**
+ * use class in a static way
+ */
+ @Test
+ public void useStaticway(){
+ TestUtil.coveragePrivateConstructorForClassesWithStaticMethodsOnly(Conditions.class);
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestRealConfig.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestRealConfig.java
new file mode 100644
index 00000000..1c92a75a
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestRealConfig.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring;
+
+import com.nokia.cbam.lcm.v32.model.VnfIdentifierCreationNotification;
+import com.nokia.cbam.lcm.v32.model.VnfIdentifierDeletionNotification;
+import com.nokia.cbam.lcm.v32.model.VnfInfoAttributeValueChangeNotification;
+import com.nokia.cbam.lcm.v32.model.VnfLifecycleChangeNotification;
+import org.junit.Test;
+import org.springframework.boot.autoconfigure.web.HttpMessageConverters;
+import org.springframework.http.MediaType;
+
+public class TestRealConfig {
+
+ /**
+ * test that the converter can transform the inherited classes
+ */
+ @Test
+ public void test() throws Exception {
+ HttpMessageConverters converters = new RealConfig().customConverters();
+ //verify
+ converters.getConverters().get(0).canRead(VnfIdentifierCreationNotification.class, MediaType.APPLICATION_JSON);
+ converters.getConverters().get(0).canRead(VnfIdentifierDeletionNotification.class, MediaType.APPLICATION_JSON);
+ converters.getConverters().get(0).canRead(VnfInfoAttributeValueChangeNotification.class, MediaType.APPLICATION_JSON);
+ converters.getConverters().get(0).canRead(VnfLifecycleChangeNotification.class, MediaType.APPLICATION_JSON);
+ converters.getConverters().get(0).canRead(String.class, MediaType.APPLICATION_JSON);
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestServletInitializer.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestServletInitializer.java
new file mode 100644
index 00000000..75c68959
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/spring/TestServletInitializer.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.spring;
+
+import org.junit.Test;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.NokiaSvnfmApplication;
+import org.springframework.boot.builder.SpringApplicationBuilder;
+
+import static org.mockito.Mockito.verify;
+
+public class TestServletInitializer {
+
+ /**
+ * test that the Nokia application is added to the Spring context
+ */
+ @Test
+ public void testSpringBootApplicationInit() throws Exception {
+ SpringApplicationBuilder springApplicationBuilder = Mockito.mock(SpringApplicationBuilder.class);
+ //when
+ new ServletInitializer().configure(springApplicationBuilder);
+ //verify
+ verify(springApplicationBuilder).sources(NokiaSvnfmApplication.class);
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestCbamUtils.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestCbamUtils.java
new file mode 100644
index 00000000..360e1d7c
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestCbamUtils.java
@@ -0,0 +1,128 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import com.google.gson.JsonObject;
+import com.google.gson.JsonPrimitive;
+import org.junit.Test;
+import org.mockito.Mockito;
+import org.slf4j.Logger;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.fail;
+import static org.mockito.Mockito.verify;
+
+public class TestCbamUtils {
+
+ /**
+ * test child of json object
+ */
+ @Test
+ public void testChild() throws Exception {
+ JsonObject parent = new JsonObject();
+ JsonObject child = new JsonObject();
+ parent.add("x", child);
+ assertEquals(child, CbamUtils.child(parent, "x"));
+ }
+
+ /**
+ * if child is not a json object error is propagated
+ */
+ @Test
+ public void testNonJsonObjectChild() throws Exception {
+ JsonObject parent = new JsonObject();
+ JsonPrimitive child = new JsonPrimitive("y");
+ parent.add("x", child);
+ try {
+ CbamUtils.child(parent, "x");
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals("Not a JSON Object: \"y\"", e.getMessage());
+ }
+ }
+
+ /**
+ * if no child is present error is propagated
+ */
+ @Test
+ public void testMissingChild() throws Exception {
+ JsonObject parent = new JsonObject();
+ try {
+ CbamUtils.child(parent, "z");
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals("Missing child z", e.getMessage());
+ }
+ }
+
+ /**
+ * test child of json object
+ */
+ @Test
+ public void testChildElement() throws Exception {
+ JsonObject parent = new JsonObject();
+ JsonPrimitive child = new JsonPrimitive("y");
+ parent.add("x", child);
+ assertEquals(child, CbamUtils.childElement(parent, "x"));
+ }
+
+ /**
+ * if no child is present error is propagated
+ */
+ @Test
+ public void testMissingChildElement() throws Exception {
+ JsonObject parent = new JsonObject();
+ try {
+ CbamUtils.childElement(parent, "z");
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals("Missing child z", e.getMessage());
+ }
+ }
+
+
+ /**
+ * test fatal failure handling
+ */
+ @Test
+ public void testFatalFailure() throws Exception {
+ Exception expectedException = new Exception();
+ Logger logger = Mockito.mock(Logger.class);
+ RuntimeException e = CbamUtils.buildFatalFailure(logger, "msg", expectedException);
+ assertEquals("msg", e.getMessage());
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("msg", expectedException);
+ }
+
+ /**
+ * test fatal failure handling with no wrapped exception
+ */
+ @Test
+ public void testFatalFailureWithNoException() throws Exception {
+ Logger logger = Mockito.mock(Logger.class);
+ RuntimeException e = CbamUtils.buildFatalFailure(logger, "msg");
+ assertEquals("msg", e.getMessage());
+ verify(logger).error("msg");
+ }
+
+ @Test
+ public void useStaticWay() {
+ TestUtil.coveragePrivateConstructorForClassesWithStaticMethodsOnly(CbamUtils.class);
+ }
+
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestStoreLoader.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestStoreLoader.java
new file mode 100644
index 00000000..2dc33f3b
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestStoreLoader.java
@@ -0,0 +1,346 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import org.junit.BeforeClass;
+import org.junit.Test;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.net.URL;
+import java.security.KeyStore;
+import java.security.KeyStoreException;
+import java.security.NoSuchAlgorithmException;
+import java.security.NoSuchProviderException;
+import java.security.cert.CertificateException;
+import java.util.Arrays;
+import java.util.HashSet;
+import java.util.Set;
+
+import static com.google.common.collect.Sets.newHashSet;
+import static org.junit.Assert.*;
+
+public class TestStoreLoader {
+
+ private static final String PASSWORD = "password";
+ private static final String SUN = "SUN";
+ private static final String JKS = "JKS";
+ private static final String TEST_JKS = "test.jks";
+ private static final String PEM_WITHOUT_BEGIN = "" +
+ "INVALID\n" +
+ "-----END RSA PRIVATE KEY-----";
+ private static final String PEM_WITHOUT_END = "-----BEGIN RSA PRIVATE KEY-----\n" +
+ "INVALID\n" +
+ "";
+ private static final String PEMS_WITHOUT_PRIVATE_KEY = "-----BEGIN CERTIFICATE-----\n" +
+ "MIICUTCCAfugAwIBAgIBADANBgkqhkiG9w0BAQQFADBXMQswCQYDVQQGEwJDTjEL\n" +
+ "MAkGA1UECBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMC\n" +
+ "VU4xFDASBgNVBAMTC0hlcm9uZyBZYW5nMB4XDTA1MDcxNTIxMTk0N1oXDTA1MDgx\n" +
+ "NDIxMTk0N1owVzELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAlBOMQswCQYDVQQHEwJD\n" +
+ "TjELMAkGA1UEChMCT04xCzAJBgNVBAsTAlVOMRQwEgYDVQQDEwtIZXJvbmcgWWFu\n" +
+ "ZzBcMA0GCSqGSIb3DQEBAQUAA0sAMEgCQQCp5hnG7ogBhtlynpOS21cBewKE/B7j\n" +
+ "V14qeyslnr26xZUsSVko36ZnhiaO/zbMOoRcKK9vEcgMtcLFuQTWDl3RAgMBAAGj\n" +
+ "gbEwga4wHQYDVR0OBBYEFFXI70krXeQDxZgbaCQoR4jUDncEMH8GA1UdIwR4MHaA\n" +
+ "FFXI70krXeQDxZgbaCQoR4jUDncEoVukWTBXMQswCQYDVQQGEwJDTjELMAkGA1UE\n" +
+ "CBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMCVU4xFDAS\n" +
+ "BgNVBAMTC0hlcm9uZyBZYW5nggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEE\n" +
+ "BQADQQA/ugzBrjjK9jcWnDVfGHlk3icNRq0oV7Ri32z/+HQX67aRfgZu7KWdI+Ju\n" +
+ "Wm7DCfrPNGVwFWUQOmsPue9rZBgO\n" +
+ "-----END CERTIFICATE-----\n" +
+ "-----BEGIN CERTIFICATE-----\n" +
+ "MIICUTCCAfugAwIBAgIBADANBgkqhkiG9w0BAQQFADBXMQswCQYDVQQGEwJDTjEL\n" +
+ "MAkGA1UECBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMC\n" +
+ "VU4xFDASBgNVBAMTC0hlcm9uZyBZYW5nMB4XDTA1MDcxNTIxMTk0N1oXDTA1MDgx\n" +
+ "NDIxMTk0N1owVzELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAlBOMQswCQYDVQQHEwJD\n" +
+ "TjELMAkGA1UEChMCT04xCzAJBgNVBAsTAlVOMRQwEgYDVQQDEwtIZXJvbmcgWWFu\n" +
+ "ZzBcMA0GCSqGSIb3DQEBAQUAA0sAMEgCQQCp5hnG7ogBhtlynpOS21cBewKE/B7j\n" +
+ "V14qeyslnr26xZUsSVko36ZnhiaO/zbMOoRcKK9vEcgMtcLFuQTWDl3RAgMBAAGj\n" +
+ "gbEwga4wHQYDVR0OBBYEFFXI70krXeQDxZgbaCQoR4jUDncEMH8GA1UdIwR4MHaA\n" +
+ "FFXI70krXeQDxZgbaCQoR4tUDncEoVukWTBXMQswCQYDVQQGEwJDTjELMAkGA1UE\n" +
+ "CBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMCVU4xFDAS\n" +
+ "BgNVBAMTC0hlcm9uZyBZYW5nggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEE\n" +
+ "BQADQQA/ugzBrjjK9jcWnDVfGHlk3icNRq0oV7Ri32z/+HQX67aRfgZu7KWdI+Ju\n" +
+ "Wm7DCfrPNGVwFWUQOmsPue9rZBgO\n" +
+ "-----END CERTIFICATE-----";
+ private static final String PEMS = "-----BEGIN CERTIFICATE-----\n" +
+ "MIICUTCCAfugAwIBAgIBADANBgkqhkiG9w0BAQQFADBXMQswCQYDVQQGEwJDTjEL\n" +
+ "MAkGA1UECBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMC\n" +
+ "VU4xFDASBgNVBAMTC0hlcm9uZyBZYW5nMB4XDTA1MDcxNTIxMTk0N1oXDTA1MDgx\n" +
+ "NDIxMTk0N1owVzELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAlBOMQswCQYDVQQHEwJD\n" +
+ "TjELMAkGA1UEChMCT04xCzAJBgNVBAsTAlVOMRQwEgYDVQQDEwtIZXJvbmcgWWFu\n" +
+ "ZzBcMA0GCSqGSIb3DQEBAQUAA0sAMEgCQQCp5hnG7ogBhtlynpOS21cBewKE/B7j\n" +
+ "V14qeyslnr26xZUsSVko36ZnhiaO/zbMOoRcKK9vEcgMtcLFuQTWDl3RAgMBAAGj\n" +
+ "gbEwga4wHQYDVR0OBBYEFFXI70krXeQDxZgbaCQoR4jUDncEMH8GA1UdIwR4MHaA\n" +
+ "FFXI70krXeQDxZgbaCQoR4jUDncEoVukWTBXMQswCQYDVQQGEwJDTjELMAkGA1UE\n" +
+ "CBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMCVU4xFDAS\n" +
+ "BgNVBAMTC0hlcm9uZyBZYW5nggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEE\n" +
+ "BQADQQA/ugzBrjjK9jcWnDVfGHlk3icNRq0oV7Ri32z/+HQX67aRfgZu7KWdI+Ju\n" +
+ "Wm7DCfrPNGVwFWUQOmsPue9rZBgO\n" +
+ "-----END CERTIFICATE-----\n" +
+ "-----BEGIN CERTIFICATE-----\n" +
+ "MIICUTCCAfugAwIBAgIBADANBgkqhkiG9w0BAQQFADBXMQswCQYDVQQGEwJDTjEL\n" +
+ "MAkGA1UECBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMC\n" +
+ "VU4xFDASBgNVBAMTC0hlcm9uZyBZYW5nMB4XDTA1MDcxNTIxMTk0N1oXDTA1MDgx\n" +
+ "NDIxMTk0N1owVzELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAlBOMQswCQYDVQQHEwJD\n" +
+ "TjELMAkGA1UEChMCT04xCzAJBgNVBAsTAlVOMRQwEgYDVQQDEwtIZXJvbmcgWWFu\n" +
+ "ZzBcMA0GCSqGSIb3DQEBAQUAA0sAMEgCQQCp5hnG7ogBhtlynpOS21cBewKE/B7j\n" +
+ "V14qeyslnr26xZUsSVko36ZnhiaO/zbMOoRcKK9vEcgMtcLFuQTWDl3RAgMBAAGj\n" +
+ "gbEwga4wHQYDVR0OBBYEFFXI70krXeQDxZgbaCQoR4jUDncEMH8GA1UdIwR4MHaA\n" +
+ "FFXI70krXeQDxZgbaCQoR4tUDncEoVukWTBXMQswCQYDVQQGEwJDTjELMAkGA1UE\n" +
+ "CBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMCVU4xFDAS\n" +
+ "BgNVBAMTC0hlcm9uZyBZYW5nggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEE\n" +
+ "BQADQQA/ugzBrjjK9jcWnDVfGHlk3icNRq0oV7Ri32z/+HQX67aRfgZu7KWdI+Ju\n" +
+ "Wm7DCfrPNGVwFWUQOmsPue9rZBgO\n" +
+ "-----END CERTIFICATE-----\n" +
+ "-----BEGIN RSA PRIVATE KEY-----\n" +
+ "MIIEuwIBADANBgkqhkiG9w0BAQEFAASCBKUwggShAgEAAoIBAF53wUbKmDHtvfOb8u1HPqEBFNNF\n" +
+ "csnOMjIcSEhAwIQMbgrOuQ+vH/YgXuuDJaURS85H8P4UTt6lYOJn+SFnXvS82E7LHJpVrWwQzbh2\n" +
+ "QKh13/akPe90DlNTUGEYO7rHaPLqTlld0jkLFSytwqfwqn9yrYpM1ncUOpCciK5j8t8MzO71LJoJ\n" +
+ "g24CFxpjIS0tBrJvKzrRNcxWSRDLmu2kNmtsh7yyJouE6XoizVmBmNVltHhFaDMmqjugMQA2CZfL\n" +
+ "rxiR1ep8TH8IBvPqysqZI1RIpB/e0engP4/1KLrOt+6gGS0JEDh1kG2fJObl+N4n3sCOtgaz5Uz8\n" +
+ "8jpwbmZ3Se8CAwEAAQKCAQAdOsSs2MbavAsIM3qo/GBehO0iqdxooMpbQvECmjZ3JTlvUqNkPPWQ\n" +
+ "vFdiW8PsHTvtackhdLsqnNUreKxXL5rr8vqi9qm0/0mXpGNi7gP3m/FeaVdYnfpIwgCe6lag5k6M\n" +
+ "yv7PG/6N8+XrWyBdwlOe96bGohvB4Jp2YFjSTM67QONQ8CdmfqokqJ8/3RyrpDvGN3iX3yzBqXGO\n" +
+ "jPkoJQv3I4lsYdR0nl4obHHnMSeWCQCYvJoZ7ZOliu/Dd0ksItlodG6s8r/ujkSa8VIhe0fnXTf0\n" +
+ "i7lqa55CAByGN4MOR0bAkJwIB7nZzQKurBPcTAYJFFvAc5hgMnWT0XW83TehAoGBALVPGnznScUw\n" +
+ "O50OXKI5yhxGf/XDT8g28L8Oc4bctRzI+8YfIFfLJ57uDGuojO/BpqtYmXmgORru0jYR8idEkZrx\n" +
+ "gf62czOiJrCWTkBCEMtrNfFHQJQCQrjfbHofp7ODnEHbHFm7zdlbfNnEBBaKXxd2rVv4UTEhgftv\n" +
+ "wsHcimbXAoGBAIViWrHWElMeQT0datqlThE/u51mcK4VlV7iRWXVa1/gAP85ZAu44VvvDlkpYVkF\n" +
+ "zSRR+lHSOzsubDMN45OBQW6UA3RPg4TCvrTOmhQUeF5XPuSdcD0R2At6pdaLwAKnOtILg13Ha6ym\n" +
+ "Igjv8glodvem3hWLmpHIhNBiaXtf8wqpAoGADH5a8OhvKOtd8EChGXyp9LDW+HRw9vbyN/gi9dQX\n" +
+ "ltgyoUBb1jDllgoJSRHgRFUvyvbb/ImR5c03JwqtiQ8siWTC9G5WGeS+jcSNt9fVmG7W1L14MbrG\n" +
+ "Jj8fFns/7xrOlasnlPdgA+5N+CONtI/sZY2D/KZr0drhPhZBcWJlFxkCgYAn+4SOPEo/6hjKNhA6\n" +
+ "vER7fSxDEVsDg+rDh3YgAWpvUdlaqBxqOyAqi600YugQZGHK2lv7vNYOdmrunuIx7BPuDqY+bjtR\n" +
+ "R4Mc9bVQAZbXSLXMl7j2RWwKfNhLSJbk9LX4EoVtTgLjvOUE4tAdq9fFgpqdwLwzqPTO9kECP4++\n" +
+ "CQKBgH6tO/xcNxG/uXUideluAn3H2KeyyznZMJ7oCvzf26/XpTAMI243OoeftiKVMgxuZ7hjwqfn\n" +
+ "/VHXABc4i5gchr9RzSb1hZ/IqFzq2YGmbppg5Ok2cgwalDoDBi21bRf8aDRweL62mO+7aPnCQZ58\n" +
+ "j5W72PB8BAr6xg0Oro25O4os\n" +
+ "-----END RSA PRIVATE KEY-----";
+ private static final String PEM = "-----BEGIN CERTIFICATE-----\n" +
+ "MIICUTCCAfugAwIBAgIBADANBgkqhkiG9w0BAQQFADBXMQswCQYDVQQGEwJDTjEL\n" +
+ "MAkGA1UECBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMC\n" +
+ "VU4xFDASBgNVBAMTC0hlcm9uZyBZYW5nMB4XDTA1MDcxNTIxMTk0N1oXDTA1MDgx\n" +
+ "NDIxMTk0N1owVzELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAlBOMQswCQYDVQQHEwJD\n" +
+ "TjELMAkGA1UEChMCT04xCzAJBgNVBAsTAlVOMRQwEgYDVQQDEwtIZXJvbmcgWWFu\n" +
+ "ZzBcMA0GCSqGSIb3DQEBAQUAA0sAMEgCQQCp5hnG7ogBhtlynpOS21cBewKE/B7j\n" +
+ "V14qeyslnr26xZUsSVko36ZnhiaO/zbMOoRcKK9vEcgMtcLFuQTWDl3RAgMBAAGj\n" +
+ "gbEwga4wHQYDVR0OBBYEFFXI70krXeQDxZgbaCQoR4jUDncEMH8GA1UdIwR4MHaA\n" +
+ "FFXI70krXeQDxZgbaCQoR4jUDncEoVukWTBXMQswCQYDVQQGEwJDTjELMAkGA1UE\n" +
+ "CBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMCVU4xFDAS\n" +
+ "BgNVBAMTC0hlcm9uZyBZYW5nggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEE\n" +
+ "BQADQQA/ugzBrjjK9jcWnDVfGHlk3icNRq0oV7Ri32z/+HQX67aRfgZu7KWdI+Ju\n" +
+ "Wm7DCfrPNGVwFWUQOmsPue9rZBgO\n" +
+ "-----END CERTIFICATE-----\n" +
+ "-----BEGIN RSA PRIVATE KEY-----\n" +
+ "MIIEuwIBADANBgkqhkiG9w0BAQEFAASCBKUwggShAgEAAoIBAF53wUbKmDHtvfOb8u1HPqEBFNNF\n" +
+ "csnOMjIcSEhAwIQMbgrOuQ+vH/YgXuuDJaURS85H8P4UTt6lYOJn+SFnXvS82E7LHJpVrWwQzbh2\n" +
+ "QKh13/akPe90DlNTUGEYO7rHaPLqTlld0jkLFSytwqfwqn9yrYpM1ncUOpCciK5j8t8MzO71LJoJ\n" +
+ "g24CFxpjIS0tBrJvKzrRNcxWSRDLmu2kNmtsh7yyJouE6XoizVmBmNVltHhFaDMmqjugMQA2CZfL\n" +
+ "rxiR1ep8TH8IBvPqysqZI1RIpB/e0engP4/1KLrOt+6gGS0JEDh1kG2fJObl+N4n3sCOtgaz5Uz8\n" +
+ "8jpwbmZ3Se8CAwEAAQKCAQAdOsSs2MbavAsIM3qo/GBehO0iqdxooMpbQvECmjZ3JTlvUqNkPPWQ\n" +
+ "vFdiW8PsHTvtackhdLsqnNUreKxXL5rr8vqi9qm0/0mXpGNi7gP3m/FeaVdYnfpIwgCe6lag5k6M\n" +
+ "yv7PG/6N8+XrWyBdwlOe96bGohvB4Jp2YFjSTM67QONQ8CdmfqokqJ8/3RyrpDvGN3iX3yzBqXGO\n" +
+ "jPkoJQv3I4lsYdR0nl4obHHnMSeWCQCYvJoZ7ZOliu/Dd0ksItlodG6s8r/ujkSa8VIhe0fnXTf0\n" +
+ "i7lqa55CAByGN4MOR0bAkJwIB7nZzQKurBPcTAYJFFvAc5hgMnWT0XW83TehAoGBALVPGnznScUw\n" +
+ "O50OXKI5yhxGf/XDT8g28L8Oc4bctRzI+8YfIFfLJ57uDGuojO/BpqtYmXmgORru0jYR8idEkZrx\n" +
+ "gf62czOiJrCWTkBCEMtrNfFHQJQCQrjfbHofp7ODnEHbHFm7zdlbfNnEBBaKXxd2rVv4UTEhgftv\n" +
+ "wsHcimbXAoGBAIViWrHWElMeQT0datqlThE/u51mcK4VlV7iRWXVa1/gAP85ZAu44VvvDlkpYVkF\n" +
+ "zSRR+lHSOzsubDMN45OBQW6UA3RPg4TCvrTOmhQUeF5XPuSdcD0R2At6pdaLwAKnOtILg13Ha6ym\n" +
+ "Igjv8glodvem3hWLmpHIhNBiaXtf8wqpAoGADH5a8OhvKOtd8EChGXyp9LDW+HRw9vbyN/gi9dQX\n" +
+ "ltgyoUBb1jDllgoJSRHgRFUvyvbb/ImR5c03JwqtiQ8siWTC9G5WGeS+jcSNt9fVmG7W1L14MbrG\n" +
+ "Jj8fFns/7xrOlasnlPdgA+5N+CONtI/sZY2D/KZr0drhPhZBcWJlFxkCgYAn+4SOPEo/6hjKNhA6\n" +
+ "vER7fSxDEVsDg+rDh3YgAWpvUdlaqBxqOyAqi600YugQZGHK2lv7vNYOdmrunuIx7BPuDqY+bjtR\n" +
+ "R4Mc9bVQAZbXSLXMl7j2RWwKfNhLSJbk9LX4EoVtTgLjvOUE4tAdq9fFgpqdwLwzqPTO9kECP4++\n" +
+ "CQKBgH6tO/xcNxG/uXUideluAn3H2KeyyznZMJ7oCvzf26/XpTAMI243OoeftiKVMgxuZ7hjwqfn\n" +
+ "/VHXABc4i5gchr9RzSb1hZ/IqFzq2YGmbppg5Ok2cgwalDoDBi21bRf8aDRweL62mO+7aPnCQZ58\n" +
+ "j5W72PB8BAr6xg0Oro25O4os\n" +
+ "-----END RSA PRIVATE KEY-----";
+ private static final String PEM_WITHOUT_PRIVATE_KEY =
+ "-----BEGIN CERTIFICATE-----\n" +
+ "MIICUTCCAfugAwIBAgIBADANBgkqhkiG9w0BAQQFADBXMQswCQYDVQQGEwJDTjEL\n" +
+ "MAkGA1UECBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMC\n" +
+ "VU4xFDASBgNVBAMTC0hlcm9uZyBZYW5nMB4XDTA1MDcxNTIxMTk0N1oXDTA1MDgx\n" +
+ "NDIxMTk0N1owVzELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAlBOMQswCQYDVQQHEwJD\n" +
+ "TjELMAkGA1UEChMCT04xCzAJBgNVBAsTAlVOMRQwEgYDVQQDEwtIZXJvbmcgWWFu\n" +
+ "ZzBcMA0GCSqGSIb3DQEBAQUAA0sAMEgCQQCp5hnG7ogBhtlynpOS21cBewKE/B7j\n" +
+ "V14qeyslnr26xZUsSVko36ZnhiaO/zbMOoRcKK9vEcgMtcLFuQTWDl3RAgMBAAGj\n" +
+ "gbEwga4wHQYDVR0OBBYEFFXI70krXeQDxZgbaCQoR4jUDncEMH8GA1UdIwR4MHaA\n" +
+ "FFXI70krXeQDxZgbaCQoR4jUDncEoVukWTBXMQswCQYDVQQGEwJDTjELMAkGA1UE\n" +
+ "CBMCUE4xCzAJBgNVBAcTAkNOMQswCQYDVQQKEwJPTjELMAkGA1UECxMCVU4xFDAS\n" +
+ "BgNVBAMTC0hlcm9uZyBZYW5nggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEE\n" +
+ "BQADQQA/ugzBrjjK9jcWnDVfGHlk3icNRq0oV7Ri32z/+HQX67aRfgZu7KWdI+Ju\n" +
+ "Wm7DCfrPNGVwFWUQOmsPue9rZBgO\n" +
+ "-----END CERTIFICATE-----";
+ private static final String INVALID_CERT =
+ "-----BEGIN CERTIFICATE-----\n" +
+ "MIIC" +
+ "-----END CERTIFICATE-----";
+ private static final String PEM_WITH_INVALID_PRIVATE_KEY = "-----BEGIN RSA PRIVATE KEY-----\n" +
+ "INVALID\n" +
+ "-----END RSA PRIVATE KEY-----";
+ private static final String EMPTY_PEM = "";
+ private static KeyStore testStore;
+
+ @BeforeClass
+ public static void setUpBefore() throws NoSuchProviderException, KeyStoreException, CertificateException, NoSuchAlgorithmException, IOException {
+ testStore = KeyStore.getInstance(JKS, SUN);
+ ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
+ URL url = classLoader.getResource(TEST_JKS);
+ String jksFileName = url.getFile();
+ File jks = new File(jksFileName);
+ FileInputStream fos = new FileInputStream(jks);
+ testStore.load(fos, PASSWORD.toCharArray());
+ }
+
+ @Test
+ public void useInStaticWay() {
+ TestUtil.coveragePrivateConstructorForClassesWithStaticMethodsOnly(StoreLoader.class);
+ }
+
+ /**
+ * test certificate extraction from PEM
+ */
+ @Test
+ public void testCertifate() {
+ assertEquals(new HashSet<>(), StoreLoader.getCertifacates(""));
+ String pem = "-----BEGIN CERTIFICATE-----\ncontent1\n-----END CERTIFICATE-----\n-----BEGIN CERTIFICATE-----\ncontent2\n-----END CERTIFICATE-----";
+ Set<String> certifacates = StoreLoader.getCertifacates(pem);
+ assertEquals(newHashSet("-----BEGIN CERTIFICATE-----\ncontent1\n-----END CERTIFICATE-----", "-----BEGIN CERTIFICATE-----\ncontent2\n-----END CERTIFICATE-----"), certifacates);
+ }
+
+ /**
+ * test keystore loading from PEM with single certificate & key
+ */
+ @Test
+ public void loadStrore() throws Exception {
+ //when
+ KeyStore ks = StoreLoader.loadStore(PEM, PASSWORD, PASSWORD);
+
+ //then
+ assertNotNull(ks.getCertificate(PASSWORD));
+ assertTrue(Arrays.equals(testStore.getCertificate(PASSWORD).getPublicKey().getEncoded(), ks.getCertificate(PASSWORD).getPublicKey().getEncoded()));
+ }
+
+ /**
+ * test keystore loading from PEM with multiple certifcates
+ */
+ @Test
+ public void loadStroreWithCerts() throws Exception {
+ //when
+ KeyStore ks = StoreLoader.loadStore(PEMS, PASSWORD, PASSWORD);
+
+ //then
+ assertNotNull(ks.getCertificate(PASSWORD));
+ assertTrue(Arrays.equals(testStore.getCertificate(PASSWORD).getPublicKey().getEncoded(), ks.getCertificate(PASSWORD).getPublicKey().getEncoded()));
+ }
+
+ /**
+ * test keystore loading from PEM without a private key
+ */
+ @Test
+ public void loadStroreWithCertsWithoutPrivateKey() throws Exception {
+ //when
+ KeyStore ks = StoreLoader.loadStore(PEMS_WITHOUT_PRIVATE_KEY, PASSWORD, PASSWORD);
+
+ //then
+ assertNotNull(ks);
+ String alias = PASSWORD + "0";
+ assertNotNull(ks.getCertificate(alias));
+ assertTrue(Arrays.equals(testStore.getCertificate(PASSWORD).getPublicKey().getEncoded(), ks.getCertificate(alias).getPublicKey().getEncoded()));
+ }
+
+ /**
+ * non closed BEGIN CERTIFICATE pattern results in empty keystore
+ */
+ @Test
+ public void loadStroreWithPemWithoutBegin() throws Exception {
+ //when
+ KeyStore ks = StoreLoader.loadStore(PEM_WITHOUT_BEGIN, PASSWORD, PASSWORD);
+
+ //then
+ assertNull(ks.getCertificate(PASSWORD));
+ }
+
+ /**
+ * non closed END CERTIFICATE pattern results in empty keystore
+ */
+ @Test
+ public void loadStroreWithPemWithoutEnd() throws Exception {
+ //when
+ KeyStore ks = StoreLoader.loadStore(PEM_WITHOUT_END, PASSWORD, PASSWORD);
+
+ //then
+ assertNull(ks.getCertificate(PASSWORD));
+ }
+
+ /**
+ * empty PEM results in empty keystore
+ */
+ @Test
+ public void loadStroreWithPemWithoutBeginAndEnd() throws Exception {
+ //when
+ KeyStore ks = StoreLoader.loadStore(EMPTY_PEM, PASSWORD, PASSWORD);
+
+ //then
+ assertNull(ks.getCertificate(PASSWORD));
+ }
+
+ /**
+ * invalid private key results in an error
+ */
+ @Test
+ public void loadStroreWithPemWithInvalidKey() throws Exception {
+ //when
+ try {
+ StoreLoader.loadStore(PEM_WITH_INVALID_PRIVATE_KEY, PASSWORD, PASSWORD);
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to load key", e.getMessage());
+
+ }
+ }
+
+ /**
+ * invalid password results in error
+ */
+ @Test
+ public void testInvlaidPassword() throws Exception {
+ //when
+ try {
+ StoreLoader.loadStore(PEM, null, null);
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to create keystore", e.getMessage());
+ }
+ }
+
+ /**
+ * invalid certificate results in error
+ */
+ @Test
+ public void testInvlaidCertificate() throws Exception {
+ //when
+ try {
+ StoreLoader.loadStore(INVALID_CERT, null, null);
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to load certificates", e.getMessage());
+
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestSystemFunctions.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestSystemFunctions.java
new file mode 100644
index 00000000..ec1ebd78
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestSystemFunctions.java
@@ -0,0 +1,118 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import org.junit.Test;
+
+import java.util.Base64;
+import java.util.HashSet;
+import java.util.Set;
+
+import static org.junit.Assert.*;
+
+public class TestSystemFunctions {
+
+ /**
+ * test sleep
+ */
+ @Test
+ public void testSleep() throws Exception {
+ long start = System.currentTimeMillis();
+ SystemFunctions.systemFunctions().sleep(123);
+ long end = System.currentTimeMillis();
+ assertTrue(end - start >= 123);
+ }
+
+ /**
+ * test interrupted sleep
+ */
+ @Test
+ public void testInterruptedSleep() throws Exception {
+ long start = System.currentTimeMillis();
+ Set<RuntimeException> exceptions = new HashSet<>();
+ class Inter extends Thread {
+ @Override
+ public void run() {
+ try {
+ SystemFunctions.systemFunctions().sleep(10000);
+ } catch (RuntimeException e) {
+ exceptions.add(e);
+ }
+ }
+ }
+ Inter inter = new Inter();
+ inter.start();
+ //when
+ inter.interrupt();
+
+ //verify
+ while (exceptions.size() != 1) {
+
+ }
+ }
+
+ /**
+ * test current time
+ */
+ @Test
+ public void testCurrentTime() {
+ long now = System.currentTimeMillis();
+ long now2 = SystemFunctions.systemFunctions().currentTimeMillis();
+ assertTrue(Math.abs(now2 - now) < 1000);
+ }
+
+ /**
+ * test file load
+ */
+ @Test
+ public void testFileLoad() {
+ byte[] bytes = SystemFunctions.systemFunctions().loadFile("unittests/empty.zip");
+ assertEquals("UEsFBgAAAAAAAAAAAAAAAAAAAAAAAA==", Base64.getEncoder().encodeToString(bytes));
+ }
+
+ /**
+ * missing file results in error
+ */
+ @Test
+ public void testMissingFileLoad() {
+ try {
+ SystemFunctions.systemFunctions().loadFile("unittests/missing");
+ fail();
+ } catch (Exception e) {
+ assertEquals("Unable to load unittests/missing", e.getMessage());
+ }
+ }
+
+ /**
+ * Test standard stream wrapping
+ */
+ @Test
+ public void testStandardStreams() {
+ assertEquals(System.err, SystemFunctions.systemFunctions().err());
+ assertEquals(System.out, SystemFunctions.systemFunctions().out());
+ assertEquals(System.in, SystemFunctions.systemFunctions().in());
+ }
+
+ /**
+ * Test HTTP client wrapping
+ * (semi useless test)
+ */
+ @Test
+ public void testHttp() {
+ assertNotNull(SystemFunctions.systemFunctions().getHttpClient());
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserInvisibleError.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserInvisibleError.java
new file mode 100644
index 00000000..214c1ca9
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserInvisibleError.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import org.junit.Test;
+
+import static org.junit.Assert.assertEquals;
+
+public class TestUserInvisibleError {
+
+ /**
+ * test POJO
+ */
+ @Test
+ public void testPojo() throws Exception {
+ UserInvisibleError e = new UserInvisibleError("msg");
+ assertEquals("msg", e.getMessage());
+ Exception cause = new Exception();
+ UserInvisibleError e2 = new UserInvisibleError("msg", cause);
+ assertEquals("msg", e2.getMessage());
+ assertEquals(cause, e2.getCause());
+ }
+
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserVisibleError.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserVisibleError.java
new file mode 100644
index 00000000..0a107640
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUserVisibleError.java
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import org.junit.Test;
+
+import static org.junit.Assert.assertEquals;
+
+public class TestUserVisibleError {
+
+ /**
+ * test POJO
+ */
+ @Test
+ public void testPojo() throws Exception {
+ UserVisibleError e = new UserVisibleError("msg");
+ assertEquals("msg", e.getMessage());
+ Exception cause = new Exception();
+ UserVisibleError e2 = new UserVisibleError("msg", cause);
+ assertEquals("msg", e2.getMessage());
+ assertEquals(cause, e2.getCause());
+ }
+
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUtil.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUtil.java
new file mode 100644
index 00000000..f5d9cc41
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/util/TestUtil.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util;
+
+import com.google.common.io.ByteStreams;
+
+import java.io.InputStream;
+import java.lang.reflect.Constructor;
+
+public class TestUtil {
+ /**
+ * Due to sonar issue you have to create a private constructor for classes
+ * that only have static methods to prevent the creation of instances. This
+ * constructor can not be coveraged / tested since it is private.
+ *
+ * @param clazz
+ */
+ public static void coveragePrivateConstructorForClassesWithStaticMethodsOnly(Class<?> clazz) {
+ for (Constructor<?> constructor : clazz.getDeclaredConstructors()) {
+ if (constructor.getParameterTypes().length == 0) {
+ constructor.setAccessible(true);
+ try {
+ constructor.newInstance();
+ } catch (Exception e) {
+ throw new IllegalStateException(e);
+ }
+ } else {
+ throw new IllegalStateException("This should only be used if the class has a singe private constructor");
+ }
+ }
+ }
+
+ public static byte[] loadFile(String url) {
+ try {
+ InputStream stream = SystemFunctions.class.getClassLoader().getResourceAsStream(url);
+ byte[] bytes = ByteStreams.toByteArray(stream);
+ return bytes;
+ } catch (Exception e) {
+ throw new RuntimeException("Unable to load " + url, e);
+ }
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestAdditionalParams.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestAdditionalParams.java
new file mode 100644
index 00000000..d1afeac4
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestAdditionalParams.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.collect.Maps;
+import com.nokia.cbam.lcm.v32.model.NetworkAddress;
+import org.junit.Test;
+import pl.pojo.tester.internal.field.AbstractFieldValueChanger;
+import pl.pojo.tester.internal.field.DefaultFieldValueChanger;
+import pl.pojo.tester.internal.field.collections.map.AbstractMapFieldValueChanger;
+
+import java.util.List;
+import java.util.Map;
+import java.util.UUID;
+
+import static pl.pojo.tester.api.assertion.Assertions.assertPojoMethodsFor;
+
+
+public class TestAdditionalParams {
+
+ /**
+ * Test basic POJO behaviour
+ */
+ @Test
+ public void test() {
+
+ class MapValueChanger extends AbstractMapFieldValueChanger<Map<String, List<NetworkAddress>>> {
+ @Override
+ protected Map<String, List<NetworkAddress>> increaseValue(Map<String, List<NetworkAddress>> stringListMap, Class<?> aClass) {
+ if (stringListMap == null) {
+ return Maps.newHashMap();
+ } else {
+ stringListMap.put(UUID.randomUUID().toString(), null);
+ return stringListMap;
+ }
+ }
+
+ @Override
+ protected boolean canChange(Class<?> type) {
+ return type.getCanonicalName().contains("Map");
+ }
+ }
+
+ final AbstractFieldValueChanger valueChanger = new MapValueChanger().attachNext(DefaultFieldValueChanger.INSTANCE);
+ assertPojoMethodsFor(AdditionalParameters.class).using(valueChanger).areWellImplemented();
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestBase.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestBase.java
new file mode 100644
index 00000000..7a1bf7f2
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestBase.java
@@ -0,0 +1,178 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.io.ByteStreams;
+import com.nokia.cbam.catalog.v1.api.DefaultApi;
+import com.nokia.cbam.lcm.v32.api.OperationExecutionsApi;
+import com.nokia.cbam.lcm.v32.api.VnfsApi;
+import com.nokia.cbam.lcn.v32.api.SubscriptionsApi;
+import org.apache.commons.lang3.ArrayUtils;
+import org.apache.http.HttpEntity;
+import org.apache.http.client.methods.CloseableHttpResponse;
+import org.apache.http.client.methods.HttpUriRequest;
+import org.apache.http.impl.client.CloseableHttpClient;
+import org.assertj.core.util.Lists;
+import org.junit.After;
+import org.junit.Before;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.mockito.MockitoAnnotations;
+import org.onap.msb.sdk.httpclient.msb.MSBServiceClient;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.INotificationSender;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VnfmInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.MsbApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc.VfcRestApiProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions;
+import org.onap.vfccatalog.api.VnfpackageApi;
+import org.onap.vnfmdriver.api.NslcmApi;
+import org.slf4j.Logger;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.core.env.Environment;
+import org.springframework.test.util.ReflectionTestUtils;
+
+import javax.servlet.http.HttpServletResponse;
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.lang.reflect.Field;
+import java.util.Arrays;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipInputStream;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.assertTrue;
+import static org.mockito.Mockito.when;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getFileInZip;
+
+public class TestBase {
+ public static final String VNF_ID = "myVnfId";
+ public static final String VNFM_ID = "myVnfmId";
+ public static final String ONAP_CSAR_ID = "myOnapCsarId";
+ public static final String VIM_ID = "myCloudOwnerId_myRegionName";
+ public static final String JOB_ID = "myJobId";
+ public static final String CBAM_VNFD_ID = "cbamVnfdId";
+ @Mock
+ protected CbamRestApiProvider cbamRestApiProvider;
+ @Mock
+ protected VfcRestApiProvider vfcRestApiProvider;
+ @Mock
+ protected MsbApiProvider msbApiProvider;
+ @Mock
+ protected VnfmInfoProvider vnfmInfoProvider;
+ @Mock
+ protected VnfsApi vnfApi;
+ @Mock
+ protected OperationExecutionsApi operationExecutionApi;
+ @Mock
+ protected SelfRegistrationManager selfRegistrationManager;
+ @Mock
+ protected Logger logger;
+ @Mock
+ protected SubscriptionsApi lcnApi;
+ @Mock
+ protected MSBServiceClient msbClient;
+ @Mock
+ protected DriverProperties driverProperties;
+ @Mock
+ protected NslcmApi nsLcmApi;
+ @Mock
+ protected INotificationSender notificationSender;
+ @Mock
+ protected SystemFunctions systemFunctions;
+ @Mock
+ protected VnfpackageApi vfcCatalogApi;
+ @Mock
+ protected DefaultApi cbamCatalogApi;
+ @Mock
+ protected CloseableHttpClient httpClient;
+ @Mock
+ protected CloseableHttpResponse response;
+ protected ArgumentCaptor<HttpUriRequest> request = ArgumentCaptor.forClass(HttpUriRequest.class);
+ @Mock
+ protected HttpEntity entity;
+ @Mock
+ protected HttpServletResponse httpResponse;
+ @Mock
+ protected Environment environment;
+
+ @Before
+ public void genericSetup() throws Exception {
+ MockitoAnnotations.initMocks(this);
+ ReflectionTestUtils.setField(SystemFunctions.class, "singletonInstance", systemFunctions);
+ when(cbamRestApiProvider.getCbamLcmApi(VNFM_ID)).thenReturn(vnfApi);
+ when(cbamRestApiProvider.getCbamOperationExecutionApi(VNFM_ID)).thenReturn(operationExecutionApi);
+ when(cbamRestApiProvider.getCbamLcnApi(VNFM_ID)).thenReturn(lcnApi);
+ when(cbamRestApiProvider.getCbamCatalogApi(VNFM_ID)).thenReturn(cbamCatalogApi);
+ when(msbApiProvider.getMsbClient()).thenReturn(msbClient);
+ when(vfcRestApiProvider.getNsLcmApi()).thenReturn(nsLcmApi);
+ when(vfcRestApiProvider.getOnapCatalogApi()).thenReturn(vfcCatalogApi);
+ when(systemFunctions.getHttpClient()).thenReturn(httpClient);
+ when(httpClient.execute(request.capture())).thenReturn(response);
+ when(response.getEntity()).thenReturn(entity);
+ when(driverProperties.getVnfmId()).thenReturn(VNFM_ID);
+ when(systemFunctions.getHttpClient()).thenReturn(httpClient);
+ when(logger.isInfoEnabled()).thenReturn(true);
+ when(logger.isDebugEnabled()).thenReturn(true);
+ when(logger.isWarnEnabled()).thenReturn(true);
+ when(logger.isErrorEnabled()).thenReturn(true);
+ }
+
+ @After
+ public void tearGeneric() {
+ ReflectionTestUtils.setField(SystemFunctions.class, "singletonInstance", null);
+ }
+
+ protected void assertFileInZip(byte[] zip, String path, byte[] expectedContent) throws Exception {
+ assertTrue(Arrays.equals(expectedContent, getFileInZip(new ByteArrayInputStream(zip), path).toByteArray()));
+ }
+
+ protected void assertItenticalZips(byte[] expected, byte[] actual) throws Exception {
+ assertEquals(build(expected), build(actual));
+ }
+
+ private Map<String, List<Byte>> build(byte[] zip) throws Exception {
+ Map<String, List<Byte>> files = new HashMap<>();
+ ZipInputStream zipInputStream = new ZipInputStream(new ByteArrayInputStream(zip));
+ ZipEntry zipEntry;
+ while ((zipEntry = zipInputStream.getNextEntry()) != null) {
+ ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
+ ByteStreams.copy(zipInputStream, byteArrayOutputStream);
+ files.put(zipEntry.getName(), Lists.newArrayList(ArrayUtils.toObject(byteArrayOutputStream.toByteArray())));
+ }
+ zipInputStream.close();
+ return files;
+ }
+
+ protected void setFieldWithPropertyAnnotation(Object obj, String key, String value) {
+ for (Field field : obj.getClass().getDeclaredFields()) {
+ for (Value fieldValue : field.getAnnotationsByType(Value.class)) {
+ if (fieldValue.value().equals(key)) {
+ try {
+ field.setAccessible(true);
+ field.set(obj, value);
+ } catch (IllegalAccessException e) {
+ throw new RuntimeException(e);
+ }
+ }
+ }
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamCatalogManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamCatalogManager.java
new file mode 100644
index 00000000..f38758f0
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamCatalogManager.java
@@ -0,0 +1,261 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.nokia.cbam.catalog.v1.model.CatalogAdapterVnfpackage;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.IPackageProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+
+import java.io.ByteArrayInputStream;
+import java.io.File;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+import java.util.UUID;
+
+import static junit.framework.TestCase.*;
+import static org.junit.Assert.assertArrayEquals;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CatalogManager.getFileInZip;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestCbamCatalogManager extends TestBase {
+
+ private static final String CSAR_ID = "csarId";
+ private static final String CBAM_VNFD_ID = "CBAM_VNFD_ID";
+ private CatalogManager cbamCatalogManager;
+ @Mock
+ private IPackageProvider packageProvider;
+
+ private List<CatalogAdapterVnfpackage> existingVnfPackages = new ArrayList<>();
+ private ArgumentCaptor<File> uploadedFile = ArgumentCaptor.forClass(File.class);
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(CatalogManager.class, "logger", logger);
+ when(cbamCatalogApi.list()).thenReturn(existingVnfPackages);
+ cbamCatalogManager = new CatalogManager(cbamRestApiProvider, packageProvider);
+ }
+
+ /**
+ * the package is transferred from source to CBAM catalog
+ */
+ @Test
+ public void testPackageTransfer() throws Exception {
+ CatalogAdapterVnfpackage existingPackage = new CatalogAdapterVnfpackage();
+ existingPackage.setVnfdId("unknownId");
+ existingVnfPackages.add(existingPackage);
+ CatalogAdapterVnfpackage createdPackage = new CatalogAdapterVnfpackage();
+ createdPackage.setVnfdId(CBAM_VNFD_ID);
+ when(cbamCatalogApi.create(uploadedFile.capture())).thenAnswer(new Answer<CatalogAdapterVnfpackage>() {
+ @Override
+ public CatalogAdapterVnfpackage answer(InvocationOnMock invocationOnMock) throws Throwable {
+ return createdPackage;
+ }
+ });
+ byte[] onapPackageContent = TestUtil.loadFile("unittests/TestCbamCatalogManager.sample.csar");
+ when(packageProvider.getPackage(CSAR_ID)).thenReturn(onapPackageContent);
+ when(packageProvider.getCbamVnfdId(CSAR_ID)).thenReturn(CBAM_VNFD_ID);
+ //when
+ CatalogAdapterVnfpackage cbamPackage = cbamCatalogManager.preparePackageInCbam(VNFM_ID, CSAR_ID);
+ //verify
+ byte[] a2 = Files.readAllBytes(uploadedFile.getValue().toPath());
+ assertArrayEquals(getFileInZip(new ByteArrayInputStream(onapPackageContent), "Artifacts/Deployment/OTHER/cbam.package.zip").toByteArray(), a2);
+ assertEquals(createdPackage, cbamPackage);
+ }
+
+ /**
+ * the package is transfer fails, but the package has been uploaded (possibly by other thread / work flow)
+ * the transfer succeeds
+ */
+ @Test
+ public void testPackageTransferConcurrency() throws Exception {
+ CatalogAdapterVnfpackage existingPackage = new CatalogAdapterVnfpackage();
+ existingPackage.setVnfdId("unknownId");
+ existingVnfPackages.add(existingPackage);
+ CatalogAdapterVnfpackage createdPackage = new CatalogAdapterVnfpackage();
+ createdPackage.setVnfdId(CBAM_VNFD_ID);
+ byte[] onapPackageContent = TestUtil.loadFile("unittests/TestCbamCatalogManager.sample.csar");
+ when(packageProvider.getPackage(CSAR_ID)).thenReturn(onapPackageContent);
+ when(packageProvider.getCbamVnfdId(CSAR_ID)).thenReturn(CBAM_VNFD_ID);
+ RuntimeException can_not_upload_package = new RuntimeException("Can not upload package");
+ when(cbamCatalogApi.create(uploadedFile.capture())).thenAnswer(new Answer<CatalogAdapterVnfpackage>() {
+ @Override
+ public CatalogAdapterVnfpackage answer(InvocationOnMock invocationOnMock) throws Throwable {
+ //this is done by an other thread
+ existingVnfPackages.add(createdPackage);
+ when(cbamCatalogApi.getById(CBAM_VNFD_ID)).thenReturn(createdPackage);
+ throw can_not_upload_package;
+ }
+ });
+ //when
+ CatalogAdapterVnfpackage cbamPackage = cbamCatalogManager.preparePackageInCbam(VNFM_ID, CSAR_ID);
+ //verify
+ //the correct portion of the package is extracted and uploaded to CBAM
+ byte[] expectedContentToUpload = getFileInZip(new ByteArrayInputStream(onapPackageContent), "Artifacts/Deployment/OTHER/cbam.package.zip").toByteArray();
+ assertTrue(Arrays.equals(expectedContentToUpload, Files.readAllBytes(uploadedFile.getValue().toPath())));
+ assertEquals(createdPackage, cbamPackage);
+ verify(logger).debug("Probably concurrent package uploads", can_not_upload_package);
+ }
+
+ /**
+ * If the package already exists in CBAM catalog it is not re-uploaded
+ */
+ @Test
+ public void testIdempotentPackageUpload() throws Exception {
+ CatalogAdapterVnfpackage createdPackage = new CatalogAdapterVnfpackage();
+ createdPackage.setVnfdId(CBAM_VNFD_ID);
+ when(cbamCatalogApi.create(uploadedFile.capture())).thenAnswer(new Answer<CatalogAdapterVnfpackage>() {
+ @Override
+ public CatalogAdapterVnfpackage answer(InvocationOnMock invocationOnMock) throws Throwable {
+ return createdPackage;
+ }
+ });
+ when(packageProvider.getCbamVnfdId(CSAR_ID)).thenReturn(CBAM_VNFD_ID);
+ CatalogAdapterVnfpackage existingPackage = new CatalogAdapterVnfpackage();
+ existingPackage.setVnfdId(CBAM_VNFD_ID);
+ existingVnfPackages.add(existingPackage);
+ when(cbamCatalogApi.getById(CBAM_VNFD_ID)).thenReturn(existingPackage);
+ //when
+ CatalogAdapterVnfpackage cbamPackage = cbamCatalogManager.preparePackageInCbam(VNFM_ID, CSAR_ID);
+ //verify
+ verify(cbamCatalogApi, never()).create(Mockito.any());
+ assertEquals(existingPackage, cbamPackage);
+ verify(packageProvider, never()).getPackage(CSAR_ID);
+ }
+
+ /**
+ * failure to list package in CBAM results in error
+ */
+ @Test
+ public void testFailureToListVnfPackagesInCbam() throws Exception {
+ when(packageProvider.getCbamVnfdId(CSAR_ID)).thenReturn(CBAM_VNFD_ID);
+ com.nokia.cbam.catalog.v1.ApiException expectedException = new com.nokia.cbam.catalog.v1.ApiException();
+ when(cbamCatalogApi.list()).thenThrow(expectedException);
+ //when
+ try {
+ cbamCatalogManager.preparePackageInCbam(VNFM_ID, CSAR_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to determine if the VNF package has been replicated in CBAM", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * failure to query package from CBAM results in error
+ */
+ @Test
+ public void testFailureToQueryVnfPackagesFromCbam() throws Exception {
+ when(packageProvider.getCbamVnfdId(CSAR_ID)).thenReturn(CBAM_VNFD_ID);
+ CatalogAdapterVnfpackage existingPackage = new CatalogAdapterVnfpackage();
+ existingPackage.setVnfdId(CBAM_VNFD_ID);
+ existingVnfPackages.add(existingPackage);
+ com.nokia.cbam.catalog.v1.ApiException expectedException = new com.nokia.cbam.catalog.v1.ApiException();
+ when(cbamCatalogApi.getById(CBAM_VNFD_ID)).thenThrow(expectedException);
+ //when
+ try {
+ cbamCatalogManager.preparePackageInCbam(VNFM_ID, CSAR_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to query VNF package with CBAM_VNFD_ID from CBAM", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * failure to create package in CBAM results in error
+ */
+ @Test
+ public void testFailureToCreatePackageInCbam() throws Exception {
+ CatalogAdapterVnfpackage existingPackage = new CatalogAdapterVnfpackage();
+ existingPackage.setVnfdId("unknownId");
+ existingVnfPackages.add(existingPackage);
+ when(packageProvider.getCbamVnfdId(CSAR_ID)).thenReturn(CBAM_VNFD_ID);
+ byte[] onapPackageContent = TestUtil.loadFile("unittests/TestCbamCatalogManager.sample.csar");
+ when(packageProvider.getPackage(CSAR_ID)).thenReturn(onapPackageContent);
+ com.nokia.cbam.catalog.v1.ApiException expectedException = new com.nokia.cbam.catalog.v1.ApiException();
+ when(cbamCatalogApi.create(Mockito.any())).thenThrow(expectedException);
+ try {
+ cbamCatalogManager.preparePackageInCbam(VNFM_ID, CSAR_ID);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to create VNF with csarId CSAR identifier in package in CBAM", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * the VNFD is extracted from zip
+ */
+ @Test
+ public void testExtractVnfdFromPackage() throws Exception {
+ Path csar = Files.createTempFile(UUID.randomUUID().toString(), "csar");
+ Files.write(csar, TestUtil.loadFile("unittests/cbam.package.zip"));
+ when(cbamCatalogApi.content(CBAM_VNFD_ID)).thenReturn(csar.toFile());
+ //when
+ String content = cbamCatalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID);
+ //verify
+ assertEquals("dummy vnfd\n", content);
+ }
+
+ /**
+ * if VNFD the Tosca meta can not be extracted sensible error is returned
+ */
+ @Test
+ public void testEmptyCbamPackage() throws Exception {
+ Path csar = Files.createTempFile(UUID.randomUUID().toString(), "csar");
+ Files.write(csar, TestUtil.loadFile("unittests/empty.zip"));
+ when(cbamCatalogApi.content(CBAM_VNFD_ID)).thenReturn(csar.toFile());
+ //when
+ try {
+ cbamCatalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID);
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error("Unable to get package with (CBAM_VNFD_ID)", e.getCause());
+ assertEquals("Unable to find the TOSCA-Metadata/TOSCA.meta in archive found: []", e.getCause().getMessage());
+ }
+ }
+
+ /**
+ * if VNFD can not be extracted sensible error is returned
+ */
+ @Test
+ public void testMissingVnfdCbamPackage() throws Exception {
+ Path csar = Files.createTempFile(UUID.randomUUID().toString(), "csar");
+ Files.write(csar, TestUtil.loadFile("unittests/missing.vnfd.zip"));
+ when(cbamCatalogApi.content(CBAM_VNFD_ID)).thenReturn(csar.toFile());
+ //when
+ try {
+ cbamCatalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID);
+ fail();
+ } catch (RuntimeException e) {
+ verify(logger).error("Unable to get package with (" + CBAM_VNFD_ID + ")", e.getCause());
+ assertTrue("Unable to find the vnfdloc/a.yaml in archive found: [TOSCA-Metadata/, TOSCA-Metadata/TOSCA.meta]".equals(e.getCause().getMessage())
+ || "Unable to find the vnfdloc/a.yaml in archive found: [TOSCA-Metadata/TOSCA.meta, TOSCA-Metadata/]".equals(e.getCause().getMessage())
+ );
+ }
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamTokenProvider.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamTokenProvider.java
new file mode 100644
index 00000000..4b35f2ff
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestCbamTokenProvider.java
@@ -0,0 +1,452 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.io.ByteStreams;
+import org.eclipse.jetty.server.NetworkTrafficServerConnector;
+import org.eclipse.jetty.server.Server;
+import org.eclipse.jetty.server.handler.AbstractHandler;
+import org.eclipse.jetty.util.ssl.SslContextFactory;
+import org.junit.After;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.InjectMocks;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VnfmInfoProvider;
+import org.onap.vnfmdriver.model.VnfmInfo;
+import org.springframework.http.HttpStatus;
+
+import javax.net.ssl.*;
+import javax.servlet.ServletException;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+import java.net.URI;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
+import java.security.GeneralSecurityException;
+import java.security.KeyStoreException;
+import java.util.ArrayList;
+import java.util.Base64;
+import java.util.List;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+import java.util.concurrent.Future;
+import java.util.concurrent.TimeUnit;
+
+import static junit.framework.TestCase.*;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+class HttpTestServer {
+ Server _server;
+ volatile List<String> requests = new ArrayList<>();
+ volatile List<Integer> codes = new ArrayList<>();
+ volatile List<String> respones = new ArrayList<>();
+ ExecutorService executorService = Executors.newCachedThreadPool();
+ public void start() throws Exception {
+ configureServer();
+ startServer();
+ }
+
+ private void startServer() throws Exception {
+ requests.clear();
+ codes.clear();
+ _server.start();
+ Future<?> serverStarted = executorService.submit(() -> {
+ while(true){
+ try {
+ Thread.sleep(10);
+ if(_server.isStarted()){
+ return;
+ }
+ } catch (InterruptedException e) {
+ }
+ }
+ });
+ serverStarted.get(30, TimeUnit.SECONDS);
+ }
+
+ protected void configureServer() throws Exception {
+ Path jksPath = Paths.get(TestCbamTokenProvider.class.getResource("/unittests/localhost.jks").toURI());
+ String path = jksPath.normalize().toAbsolutePath().toUri().toString();
+ _server = new Server();
+ SslContextFactory factory = new SslContextFactory(path);
+ factory.setKeyStorePassword("changeit");
+ NetworkTrafficServerConnector connector = new NetworkTrafficServerConnector(_server, factory);
+ connector.setHost("127.0.0.1");
+ _server.addConnector(connector);
+ _server.setHandler(new AbstractHandler() {
+ @Override
+ public void handle(String target, org.eclipse.jetty.server.Request request, HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws IOException, ServletException {
+ requests.add(new String(ByteStreams.toByteArray(request.getInputStream())));
+ httpServletResponse.getWriter().write(respones.remove(0));
+ httpServletResponse.setStatus(codes.remove(0));
+ request.setHandled(true);
+ }
+ });
+ }
+
+ public void stop() throws Exception {
+ _server.stop();
+ }
+}
+
+public class TestCbamTokenProvider extends TestBase {
+
+ private static String GOOD_RESPONSE = "{ \"access_token\" : \"myToken\", \"expires_in\" : 1000 }";
+ @InjectMocks
+ private CbamTokenProvider cbamTokenProvider;
+ private VnfmInfo vnfmInfo = new VnfmInfo();
+ private ArgumentCaptor<SSLSocketFactory> sslSocketFactory = ArgumentCaptor.forClass(SSLSocketFactory.class);
+ private ArgumentCaptor<HostnameVerifier> hostnameVerifier = ArgumentCaptor.forClass(HostnameVerifier.class);
+ private HttpTestServer testServer;
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(CbamTokenProvider.class, "logger", logger);
+ setField(cbamTokenProvider, "username", "myUserName");
+ setField(cbamTokenProvider, "password", "myPassword");
+ setField(cbamTokenProvider, "skipCertificateVerification", true);
+ setField(cbamTokenProvider, "skipHostnameVerification", true);
+ when(vnfmInfoProvider.getVnfmInfo(VNFM_ID)).thenReturn(vnfmInfo);
+ vnfmInfo.setPassword("vnfmPassword");
+ vnfmInfo.setUserName("vnfmUserName");
+ vnfmInfo.setUrl("http://127.0.0.3:12345");
+ testServer = new HttpTestServer();
+ testServer.start();
+ URI uri = testServer._server.getURI();
+ setField(cbamTokenProvider, "cbamKeyCloakBaseUrl", uri.toString());
+
+
+ }
+
+ private void addGoodTokenResponse() {
+ testServer.respones.add(GOOD_RESPONSE);
+ testServer.codes.add(HttpStatus.OK.value());
+ }
+
+ @After
+ public void testServer() throws Exception {
+ testServer.stop();
+ }
+
+ /**
+ * a new token is requested no token has been requested before
+ */
+ @Test
+ public void testBasicTokenRequest() throws Exception {
+ //given
+ addGoodTokenResponse();
+ //when
+ String token = cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ assertEquals(1, testServer.requests.size());
+ assertTokenRequest(testServer.requests.get(0));
+ assertEquals("myToken", token);
+
+ }
+
+ /**
+ * a new token is requested if the previous token has expired
+ */
+ @Test
+ public void testTokenIsRequestedIfPreviousExpired() throws Exception {
+ //given
+ addGoodTokenResponse();
+ String firstToken = cbamTokenProvider.getToken(VNFM_ID);
+ testServer.respones.add("{ \"access_token\" : \"myToken2\", \"expires_in\" : 2000 }");
+ testServer.codes.add(HttpStatus.OK.value());
+ when(systemFunctions.currentTimeMillis()).thenReturn(500L * 1000 + 1L);
+ //when
+ String token = cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ assertEquals(2, testServer.requests.size());
+ assertTokenRequest(testServer.requests.get(0));
+ assertTokenRequest(testServer.requests.get(1));
+ assertEquals("myToken2", token);
+ }
+
+ /**
+ * a new token is not requested if the previous token has not expired
+ */
+ @Test
+ public void testTokenIsNotRequestedIfPreviousHasNotExpired() throws Exception {
+ //given
+ addGoodTokenResponse();
+ String firstToken = cbamTokenProvider.getToken(VNFM_ID);
+ testServer.respones.add("{ \"access_token\" : \"myToken2\", \"expires_in\" : 2000 }");
+ testServer.codes.add(HttpStatus.OK.value());
+ when(systemFunctions.currentTimeMillis()).thenReturn(500L * 1000);
+ //when
+ String token = cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ assertEquals(1, testServer.requests.size());
+ assertTokenRequest(testServer.requests.get(0));
+ assertEquals("myToken", token);
+ }
+
+ /**
+ * failed token requests are retried for a fixed number amount of times
+ */
+ @Test
+ public void testRetry() throws Exception {
+ //given
+ addFailedResponse();
+ addFailedResponse();
+ addFailedResponse();
+ addFailedResponse();
+ addGoodTokenResponse();
+ //cbamTokenProvider.failOnRequestNumber = 5;
+ //when
+ String token = cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ assertEquals(5, testServer.requests.size());
+ assertTokenRequest(testServer.requests.get(0));
+ assertTokenRequest(testServer.requests.get(1));
+ assertTokenRequest(testServer.requests.get(2));
+ assertTokenRequest(testServer.requests.get(3));
+ assertTokenRequest(testServer.requests.get(4));
+ verify(logger).warn(eq("Unable to get token to access CBAM API (1/5)"), Mockito.<RuntimeException>any());
+ verify(logger).warn(eq("Unable to get token to access CBAM API (2/5)"), Mockito.<RuntimeException>any());
+ verify(logger).warn(eq("Unable to get token to access CBAM API (3/5)"), Mockito.<RuntimeException>any());
+ verify(logger).warn(eq("Unable to get token to access CBAM API (4/5)"), Mockito.<RuntimeException>any());
+ assertEquals("myToken", token);
+ }
+
+ /**
+ * failed token requests are retried for a fixed number amount of times (reacing maximal number or retries)
+ */
+ @Test
+ public void testNoMoreRetry() throws Exception {
+ //given
+ addFailedResponse();
+ addFailedResponse();
+ addFailedResponse();
+ addFailedResponse();
+ addFailedResponse();
+ //when
+ try {
+ cbamTokenProvider.getToken(VNFM_ID);
+ fail();
+ } catch (RuntimeException e) {
+ assertNotNull(e.getCause());
+ }
+ //verify
+ assertEquals(5, testServer.requests.size());
+ assertTokenRequest(testServer.requests.get(0));
+ assertTokenRequest(testServer.requests.get(1));
+ assertTokenRequest(testServer.requests.get(2));
+ assertTokenRequest(testServer.requests.get(3));
+ assertTokenRequest(testServer.requests.get(4));
+ verify(logger).warn(eq("Unable to get token to access CBAM API (1/5)"), Mockito.<RuntimeException>any());
+ verify(logger).warn(eq("Unable to get token to access CBAM API (2/5)"), Mockito.<RuntimeException>any());
+ verify(logger).warn(eq("Unable to get token to access CBAM API (3/5)"), Mockito.<RuntimeException>any());
+ verify(logger).warn(eq("Unable to get token to access CBAM API (4/5)"), Mockito.<RuntimeException>any());
+ verify(logger).error(eq("Unable to get token to access CBAM API (giving up retries)"), Mockito.<RuntimeException>any());
+ }
+
+ private void addFailedResponse() {
+ testServer.codes.add(HttpStatus.UNAUTHORIZED.value());
+ testServer.respones.add(new String());
+ }
+
+ /**
+ * the SSL connection is established without certificate & hostname verification
+ */
+ @Test
+ public void noSslVerification() throws Exception {
+ //given
+ //the default settings is no SSL & hostname check
+ addGoodTokenResponse();
+ //when
+ cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ //no exception is thrown
+ }
+
+ /**
+ * if SSL is verified the certificates must be defined
+ */
+ @Test
+ public void testInvalidCombinationOfSettings() throws Exception {
+ //given
+ setField(cbamTokenProvider, "skipCertificateVerification", false);
+ //when
+ try {
+ cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals("If the skipCertificateVerification is set to false (default) the trustedCertificates can not be empty", e.getMessage());
+ }
+ }
+
+ /**
+ * if SSL is verified the certificates must be defined
+ */
+ @Test
+ public void testInvalidCombinationOfSettings2() throws Exception {
+ //given
+ setField(cbamTokenProvider, "skipCertificateVerification", false);
+ setField(cbamTokenProvider, "trustedCertificates", "xx\nxx");
+ //when
+ try {
+ cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals("The trustedCertificates must be a base64 encoded collection of PEM certificates", e.getMessage());
+ assertNotNull(e.getCause());
+ }
+ }
+
+ /**
+ * the SSL connection is established without certificate & hostname verification
+ */
+ @Test
+ public void testNotTrustedSslConnection() throws Exception {
+ //given
+ setField(cbamTokenProvider, "skipCertificateVerification", false);
+ Path caPem = Paths.get(TestCbamTokenProvider.class.getResource("/unittests/sample.cert.pem").toURI());
+ setField(cbamTokenProvider, "trustedCertificates", Base64.getEncoder().encodeToString(Files.readAllBytes(caPem)));
+ addGoodTokenResponse();
+ //when
+ try {
+ cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertTrue(e.getCause().getCause().getMessage().contains("unable to find valid certification path"));
+ assertTrue(e.getCause() instanceof SSLHandshakeException);
+ }
+ }
+
+ /**
+ * the SSL connection is established with certificate & hostname verification
+ */
+ @Test
+ public void testHostnameVerificationSucceeds() throws Exception {
+ //given
+ setField(cbamTokenProvider, "skipCertificateVerification", false);
+ Path caPem = Paths.get(TestCbamTokenProvider.class.getResource("/unittests/localhost.cert.pem").toURI());
+ setField(cbamTokenProvider, "trustedCertificates", Base64.getEncoder().encodeToString(Files.readAllBytes(caPem)));
+ setField(cbamTokenProvider, "cbamKeyCloakBaseUrl", testServer._server.getURI().toString().replace("127.0.0.1", "localhost"));
+ setField(cbamTokenProvider, "skipHostnameVerification", false);
+ addGoodTokenResponse();
+ //when
+ cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ //no seception is thrown
+ }
+
+ /**
+ * the SSL connection is dropped with certificate & hostname verification due to invalid hostname
+ */
+ @Test
+ public void testHostnameverifcationfail() throws Exception {
+ //given
+ setField(cbamTokenProvider, "skipCertificateVerification", false);
+ Path caPem = Paths.get(TestCbamTokenProvider.class.getResource("/unittests/localhost.cert.pem").toURI());
+ setField(cbamTokenProvider, "trustedCertificates", Base64.getEncoder().encodeToString(Files.readAllBytes(caPem)));
+ setField(cbamTokenProvider, "skipHostnameVerification", false);
+ addGoodTokenResponse();
+ //when
+ try {
+ cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertTrue(e.getCause().getMessage().contains("Hostname 127.0.0.1 not verified"));
+ assertTrue(e.getCause() instanceof SSLPeerUnverifiedException);
+ }
+ }
+
+ /**
+ * invalid certificate content
+ */
+ @Test
+ public void testInvalidCerificateContent() throws Exception {
+ //given
+ setField(cbamTokenProvider, "skipCertificateVerification", false);
+ setField(cbamTokenProvider, "trustedCertificates", Base64.getEncoder().encodeToString("-----BEGIN CERTIFICATE-----\nkuku\n-----END CERTIFICATE-----\n".getBytes()));
+ setField(cbamTokenProvider, "skipHostnameVerification", false);
+ addGoodTokenResponse();
+ //when
+ try {
+ cbamTokenProvider.getToken(VNFM_ID);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals("Unable to load certificates", e.getMessage());
+ assertTrue(e.getCause() instanceof GeneralSecurityException);
+ }
+ }
+
+ /**
+ * Verify client certificates are not verified
+ * \
+ */
+ @Test
+ public void testClientCertificates() throws Exception {
+ //when
+ new CbamTokenProvider.AllTrustedTrustManager().checkClientTrusted(null, null);
+ //verify
+ //no security exception is thrown
+ }
+
+ /**
+ * Exception during keystore creation is logged (semi-useless)
+ */
+ @Test
+ public void testKeystoreCreationFailure() {
+ KeyStoreException expectedException = new KeyStoreException();
+ class X extends CbamTokenProvider {
+ X(VnfmInfoProvider vnfmInfoProvider) {
+ super(vnfmInfoProvider);
+ }
+
+ @Override
+ TrustManager[] buildTrustManager() throws KeyStoreException {
+ throw expectedException;
+ }
+ }
+ try {
+ new X(null).buildSSLSocketFactory();
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to create SSL socket factory", expectedException);
+ }
+ }
+
+ private void assertTokenRequest(String body) {
+ assertContains(body, "grant_type", "password");
+ assertContains(body, "client_id", "vnfmUserName");
+ assertContains(body, "client_secret", "vnfmPassword");
+ assertContains(body, "username", "myUserName");
+ assertContains(body, "password", "myPassword");
+ }
+
+ private void assertContains(String content, String key, String value) {
+ assertTrue(content.contains(key + "=" + value));
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestDriverProperties.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestDriverProperties.java
new file mode 100644
index 00000000..22db05b2
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestDriverProperties.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import org.junit.Test;
+
+import static pl.pojo.tester.api.assertion.Assertions.assertPojoMethodsFor;
+
+
+public class TestDriverProperties {
+
+ /**
+ * Test basic POJO behaviour
+ */
+ @Test
+ public void test() {
+
+
+ assertPojoMethodsFor(DriverProperties.class).areWellImplemented();
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestJobManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestJobManager.java
new file mode 100644
index 00000000..4b59eeb3
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestJobManager.java
@@ -0,0 +1,543 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.collect.Lists;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonParser;
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.model.*;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
+import org.onap.vnfmdriver.model.JobDetailInfo;
+import org.onap.vnfmdriver.model.JobResponseInfo;
+import org.onap.vnfmdriver.model.JobStatus;
+import org.springframework.test.util.ReflectionTestUtils;
+import org.threeten.bp.OffsetDateTime;
+
+import javax.servlet.http.HttpServletResponse;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.NoSuchElementException;
+import java.util.UUID;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+import java.util.concurrent.Future;
+
+import static junit.framework.TestCase.*;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.SEPARATOR;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.JobManager.extractOnapJobId;
+import static org.onap.vnfmdriver.model.JobStatus.*;
+
+public class TestJobManager extends TestBase {
+
+ @Mock
+ private HttpServletResponse httpResponse;
+
+ @InjectMocks
+ private JobManager jobManager;
+ private List<VnfInfo> vnfs = new ArrayList<>();
+
+ @Before
+ public void initMocks() throws Exception {
+ ReflectionTestUtils.setField(JobManager.class, "logger", logger);
+ when(vnfApi.vnfsGet(NOKIA_LCM_API_VERSION)).thenReturn(vnfs);
+ when(selfRegistrationManager.isReady()).thenReturn(true);
+ }
+
+ /**
+ * Only the _ can be used as separator
+ * . / % & handled specially in URLs
+ * - used in CBAM for separation
+ */
+ @Test
+ public void testSeparator() {
+ assertEquals("_", SEPARATOR);
+ }
+
+ /**
+ * The operation result must contain the ONAP job identifier under the jobId field
+ */
+ @Test
+ public void testJobIdExtractionFromOperationResult() {
+ assertEquals("1234", extractOnapJobId(new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"1234\"}}")));
+ try {
+ extractOnapJobId(new JsonParser().parse("{ }"));
+ fail();
+ } catch (NoSuchElementException e) {
+ assertEquals("The operation result {} does not contain the mandatory additionalParams structure", e.getMessage());
+ }
+ try {
+ extractOnapJobId(new JsonParser().parse("{ \"additionalParams\" : { } }"));
+ fail();
+ } catch (NoSuchElementException e) {
+ assertEquals("The operation result {\"additionalParams\":{}} does not contain the mandatory jobId in the additionalParams structure", e.getMessage());
+ }
+ }
+
+ /**
+ * If the VNF does not exists but the job manager still runs the VNF manipulation process the job is reported to be running
+ */
+ @Test
+ public void testJobForNonExistingVnfReportedRunningIfJobIsOngoing() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ //when
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, STARTED, "50", "Operation started");
+ }
+
+ /**
+ * If the VNF does not exists and the internal job is not running the job is reported to be finished
+ */
+ @Test
+ public void testJobForExistingVnfReportedRunningIfJobIsFinished() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ jobManager.jobFinished(jobId);
+ //when
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, JobStatus.FINISHED, "100", "Operation finished");
+ }
+
+ /**
+ * Spawning jobs after preparing for shutdown results in error
+ */
+ @Test
+ public void testNoMoreJobsAreAllowedAfterPrepareForShutdown() throws Exception {
+ jobManager.prepareForShutdown();
+ //when
+ try {
+ jobManager.spawnJob(JOB_ID, httpResponse);
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("The service is preparing to shut down");
+ }
+ }
+
+ /**
+ * Verify if the jobId has valid format
+ */
+ @Test
+ public void testJobIdValidation() throws Exception {
+ try {
+ //when
+ jobManager.getJob(VNFM_ID, "bad");
+ //verify
+ fail();
+ } catch (IllegalArgumentException e) {
+ assertEquals("The jobId should be in the <vnfId>_<UUID> format, but was bad", e.getMessage());
+ }
+ try {
+ //when
+ jobManager.getJob(VNFM_ID, "vnfId_");
+ //verify
+ fail();
+ } catch (IllegalArgumentException e) {
+ assertEquals("The UUID in the jobId (vnfId_) can not be empty", e.getMessage());
+ }
+ try {
+ //when
+ jobManager.getJob(VNFM_ID, "_UUID");
+ //verify
+ fail();
+ } catch (IllegalArgumentException e) {
+ assertEquals("The vnfId in the jobId (_UUID) can not be empty", e.getMessage());
+ }
+ }
+
+ /**
+ * If the VNF exists but no operation execution is present with given internalJobId, than the state of the
+ * job is ongoing if the internal job is ongoing
+ */
+ @Test
+ public void testExistingVnfWithNotYetStartedOperation() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, STARTED, "50", "Operation started");
+ assertTrue(jobManager.hasOngoingJobs());
+ }
+
+ /**
+ * If the VNF exists but no operation execution is present with given internalJobId, than the state of the
+ * job is failed if the internal job is finished (the operation on CBAM was not able to start)
+ */
+ @Test
+ public void testExistingVnfWithNotUnableToStartOperation() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ jobManager.jobFinished(jobId);
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, ERROR, "100", "Operation failed due to The requested operation was not able to start on CBAM");
+ assertFalse(jobManager.hasOngoingJobs());
+ }
+
+ /**
+ * If the VNF exists but and the operation execution is present with given internalJobId, than the state of the
+ * job is ongoing if the operation is ongoing
+ */
+ @Test
+ public void testExistingVnfWithStartedOperation() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ OperationExecution operation = new OperationExecution();
+ operation.setId(UUID.randomUUID().toString());
+ operation.setStartTime(OffsetDateTime.now());
+ operation.setStatus(OperationStatus.STARTED);
+ detailedVnf.setOperationExecutions(new ArrayList<>());
+ detailedVnf.getOperationExecutions().add(operation);
+ JsonElement operationParams = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + jobId + "\"}}");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(operation.getId(), NOKIA_LCM_API_VERSION)).thenReturn(operationParams);
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, STARTED, "50", "Operation started");
+ assertTrue(jobManager.hasOngoingJobs());
+ }
+
+ /**
+ * If the VNF does not exists till the time the job queries the status of the operation
+ */
+ @Test
+ public void testTerminatedVnf() throws Exception {
+ //ddd
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ List<Integer> vnfQueryCallCounter = new ArrayList<>();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenAnswer(new Answer<VnfInfo>() {
+ @Override
+ public VnfInfo answer(InvocationOnMock invocation) throws Throwable {
+ vnfs.clear();
+ return detailedVnf;
+ }
+ });
+
+ jobManager.jobFinished(jobId);
+
+ OperationExecution operation = new OperationExecution();
+ operation.setId(UUID.randomUUID().toString());
+ operation.setStartTime(OffsetDateTime.now());
+ operation.setStatus(OperationStatus.FINISHED);
+ operation.setOperationType(OperationType.TERMINATE);
+ detailedVnf.setOperationExecutions(new ArrayList<>());
+ detailedVnf.getOperationExecutions().add(operation);
+
+ JsonElement operationParams = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + jobId + "\"}}");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(operation.getId(), NOKIA_LCM_API_VERSION)).thenReturn(operationParams);
+ //when
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, FINISHED, "100", "Operation finished");
+ }
+
+ /**
+ * If the VNF exists but and the operation execution is present with given internalJobId, than the state of the
+ * job is error if the operation is failed
+ */
+ @Test
+ public void testExistingVnfWithFailedOperation() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ List<Integer> vnfCounter = new ArrayList<>();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ OperationExecution operation = new OperationExecution();
+ operation.setId(UUID.randomUUID().toString());
+ operation.setStartTime(OffsetDateTime.now());
+ operation.setStatus(OperationStatus.FAILED);
+ ProblemDetails errorDetails = new ProblemDetails();
+ errorDetails.setTitle("Title");
+ errorDetails.setDetail("detail");
+ operation.setError(errorDetails);
+ detailedVnf.setOperationExecutions(new ArrayList<>());
+ detailedVnf.getOperationExecutions().add(operation);
+ JsonElement operationParams = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + jobId + "\"}}");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(operation.getId(), NOKIA_LCM_API_VERSION)).thenReturn(operationParams);
+ //when
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, ERROR, "100", "Operation failed due to Title: detail");
+ assertTrue(jobManager.hasOngoingJobs());
+ }
+
+ private void assertResult(String jobId, JobDetailInfo job, JobStatus status, String progress, String descriptor) {
+ assertEquals(jobId, job.getJobId());
+ assertEquals(status, job.getResponseDescriptor().getStatus());
+ assertEquals(progress, job.getResponseDescriptor().getProgress());
+ assertNull(job.getResponseDescriptor().getErrorCode());
+ boolean finalState = JobStatus.ERROR.equals(status) || JobStatus.FINISHED.equals(status);
+ if (finalState) {
+ assertEquals(2, job.getResponseDescriptor().getResponseHistoryList().size());
+ JobResponseInfo startEvent = job.getResponseDescriptor().getResponseHistoryList().get(0);
+ JobResponseInfo endEvent = job.getResponseDescriptor().getResponseHistoryList().get(1);
+ assertNull(startEvent.getErrorCode());
+ assertEquals("50", startEvent.getProgress());
+ assertEquals(JobStatus.STARTED.name(), startEvent.getStatus());
+ assertEquals("1", startEvent.getResponseId());
+ assertEquals("Operation started", startEvent.getStatusDescription());
+
+ assertNull(endEvent.getErrorCode());
+ assertEquals("100", endEvent.getProgress());
+ assertEquals(job.getResponseDescriptor().getStatus().name(), endEvent.getStatus());
+ assertEquals("2", endEvent.getResponseId());
+ assertEquals(descriptor, endEvent.getStatusDescription());
+ } else {
+ assertEquals(1, job.getResponseDescriptor().getResponseHistoryList().size());
+ assertNull(job.getResponseDescriptor().getResponseHistoryList().get(0).getErrorCode());
+ assertEquals(progress, job.getResponseDescriptor().getResponseHistoryList().get(0).getProgress());
+ assertEquals(job.getResponseDescriptor().getStatus().name(), job.getResponseDescriptor().getResponseHistoryList().get(0).getStatus());
+ assertEquals("1", job.getResponseDescriptor().getResponseHistoryList().get(0).getResponseId());
+ assertEquals(descriptor, job.getResponseDescriptor().getResponseHistoryList().get(0).getStatusDescription());
+ }
+ assertEquals(Integer.toString(job.getResponseDescriptor().getResponseHistoryList().size()), job.getResponseDescriptor().getResponseId());
+ assertEquals(descriptor, job.getResponseDescriptor().getStatusDescription());
+ }
+
+ /**
+ * If the VNF exists but and the operation execution is present with given internalJobId, than the state of the
+ * job is finished if the operation is finished, but is not a termination
+ */
+ @Test
+ public void testExistingVnfWithFinishedOperation() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ OperationExecution operation = new OperationExecution();
+ operation.setId(UUID.randomUUID().toString());
+ operation.setStartTime(OffsetDateTime.now());
+ operation.setStatus(OperationStatus.FINISHED);
+ operation.setOperationType(OperationType.SCALE);
+ detailedVnf.setOperationExecutions(new ArrayList<>());
+ detailedVnf.getOperationExecutions().add(operation);
+ JsonElement operationParams = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + jobId + "\"}}");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(operation.getId(), NOKIA_LCM_API_VERSION)).thenReturn(operationParams);
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, JobStatus.FINISHED, "100", "Operation finished");
+ assertTrue(jobManager.hasOngoingJobs());
+ }
+
+ /**
+ * If the VNF exists but and the operation execution is present with given internalJobId, than the state of the
+ * job is ongoing if the termination operation is finished. In ONAP terminology the termination includes
+ * delete, so the ONAP operation is ongoing since the VNF is not yet deleted
+ */
+ @Test
+ public void testExistingVnfWithFinishedTerminationOperation() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ OperationExecution operation = new OperationExecution();
+ operation.setId(UUID.randomUUID().toString());
+ operation.setStartTime(OffsetDateTime.now());
+ operation.setStatus(OperationStatus.FINISHED);
+ operation.setOperationType(OperationType.TERMINATE);
+ detailedVnf.setOperationExecutions(new ArrayList<>());
+ detailedVnf.getOperationExecutions().add(operation);
+ JsonElement operationParams = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + jobId + "\"}}");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(operation.getId(), NOKIA_LCM_API_VERSION)).thenReturn(operationParams);
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, STARTED, "50", "Operation started");
+ //when
+ jobManager.jobFinished(jobId);
+ job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertResult(jobId, job, ERROR, "100", "Operation failed due to unable to delete VNF");
+ assertFalse(jobManager.hasOngoingJobs());
+
+ }
+
+ /**
+ * Failuire to retrieve operation parameters (CBAM REST API fail) is logged and propagated
+ */
+ @Test
+ public void failuresDuringOperationExecutionRetrievalIsLoggedAndPropagated() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ OperationExecution operation = new OperationExecution();
+ operation.setId(UUID.randomUUID().toString());
+ detailedVnf.setOperationExecutions(new ArrayList<>());
+ detailedVnf.getOperationExecutions().add(operation);
+ ApiException expectedException = new ApiException();
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(operation.getId(), NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //verify
+ try {
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to retrieve operation parameters", expectedException);
+ }
+ assertTrue(jobManager.hasOngoingJobs());
+ }
+
+ /**
+ * Failure to retrieve VNF (CBAM REST API fail) is logged and propagated
+ */
+ @Test
+ public void failuresDuringVnfRetrievalIsLoggedAndPropagated() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //verify
+ try {
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to retrieve VNF", expectedException);
+ }
+ assertTrue(jobManager.hasOngoingJobs());
+ }
+
+ /**
+ * When searching for the ONAP job by iterating the operation executions. The newest jobs
+ * are inspected first (performance optimalization)
+ */
+ @Test
+ public void testNewestOperationAreInspectedFirst() throws Exception {
+ String jobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ VnfInfo vnf = new VnfInfo();
+ vnf.setId(VNF_ID);
+ vnfs.add(vnf);
+ VnfInfo detailedVnf = new VnfInfo();
+ detailedVnf.setId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(detailedVnf);
+ OperationExecution olderOperation = new OperationExecution();
+ olderOperation.setId(UUID.randomUUID().toString());
+ olderOperation.setStartTime(OffsetDateTime.now());
+ olderOperation.setStatus(OperationStatus.FINISHED);
+ olderOperation.setOperationType(OperationType.TERMINATE);
+ OperationExecution newerOperation = new OperationExecution();
+ newerOperation.setId(UUID.randomUUID().toString());
+ newerOperation.setStartTime(OffsetDateTime.now().plusDays(1));
+ newerOperation.setStatus(OperationStatus.FINISHED);
+ newerOperation.setOperationType(OperationType.TERMINATE);
+ detailedVnf.setOperationExecutions(new ArrayList<>());
+ detailedVnf.getOperationExecutions().add(olderOperation);
+ detailedVnf.getOperationExecutions().add(newerOperation);
+ JsonElement operationParams = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + jobId + "\"}}");
+ List<String> queriedOperaionsInOrder = new ArrayList<>();
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(Mockito.anyString(), Mockito.eq(NOKIA_LCM_API_VERSION)))
+ .then(new Answer<Object>() {
+ @Override
+ public Object answer(InvocationOnMock invocationOnMock) throws Throwable {
+ queriedOperaionsInOrder.add(invocationOnMock.getArguments()[0].toString());
+ if (invocationOnMock.getArguments()[0].equals(olderOperation.getId())) {
+ return new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + jobId + "\"}}");
+ } else {
+ return new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + "nonMatching" + "\"}}");
+ }
+ }
+ });
+ JobDetailInfo job = jobManager.getJob(VNFM_ID, jobId);
+ //verify
+ assertEquals(Lists.newArrayList(newerOperation.getId(), olderOperation.getId()), queriedOperaionsInOrder);
+ assertTrue(jobManager.hasOngoingJobs());
+ }
+
+ /**
+ * if the registration process has not finished it is prevented to spawn jobs
+ */
+ @Test
+ public void noJobCanBeStartedIfRegistrationNotFinished() throws Exception {
+ //given
+ when(selfRegistrationManager.isReady()).thenReturn(false);
+ //when
+ try {
+ jobManager.spawnJob(VNF_ID, httpResponse);
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals("The service is not yet ready", e.getMessage());
+ }
+ }
+
+ /**
+ * Ongoing job are out waited during the the preparation for shutdown
+ */
+ @Test
+ //need to wait for an asynchronous execution to finish
+ //this is the most optimal way to do it
+ @SuppressWarnings("squid:S2925")
+ public void onGoingJobsAreOutwaitedDuringShutdown() throws Exception {
+ String firstJobId = jobManager.spawnJob(VNF_ID, httpResponse);
+ ExecutorService executorService = Executors.newCachedThreadPool();
+ ArgumentCaptor<Integer> sleeps = ArgumentCaptor.forClass(Integer.class);
+ doNothing().when(systemFunctions).sleep(sleeps.capture());
+ //when prepare job manager for shutdown
+ Future<?> shutDown = executorService.submit(() -> jobManager.prepareForShutdown());
+ while (sleeps.getAllValues().size() == 0) {
+ try {
+ Thread.sleep(1);
+ } catch (InterruptedException e) {
+ }
+ }
+ assertFalse(shutDown.isDone());
+ jobManager.jobFinished(firstJobId);
+ //verify
+ shutDown.get();
+ verify(systemFunctions, times(sleeps.getAllValues().size())).sleep(500L);
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestLifecycleManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestLifecycleManager.java
new file mode 100644
index 00000000..c6e76ef6
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestLifecycleManager.java
@@ -0,0 +1,1483 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.gson.Gson;
+import com.google.gson.JsonElement;
+import com.google.gson.JsonObject;
+import com.google.gson.JsonParser;
+import com.nokia.cbam.catalog.v1.model.CatalogAdapterVnfpackage;
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.model.*;
+import com.nokia.cbam.lcm.v32.model.OperationType;
+import com.nokia.cbam.lcm.v32.model.VimInfo;
+import com.nokia.cbam.lcm.v32.model.VnfInfo;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.InOrder;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.api.VimInfoProvider;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc.TestVfcGrantManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.vfc.VfcGrantManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.StoreLoader;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification.LifecycleChangeNotificationManager;
+import org.onap.vnfmdriver.model.ExtVirtualLinkInfo;
+import org.onap.vnfmdriver.model.*;
+import org.onap.vnfmdriver.model.ScaleDirection;
+import org.threeten.bp.OffsetDateTime;
+
+import javax.servlet.http.HttpServletResponse;
+import java.nio.file.Paths;
+import java.util.*;
+
+import static java.lang.Boolean.parseBoolean;
+import static java.nio.file.Files.readAllBytes;
+import static java.util.Optional.empty;
+import static junit.framework.TestCase.*;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.CbamUtils.child;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.SystemFunctions.systemFunctions;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestLifecycleManager extends TestBase {
+ public static final String JOB_ID = "myJobId";
+ public static final String CBAM_VNFD_ID = "cbamVnfdId";
+ public static final String TENANT = "myTenant";
+ public static final String OPERATION_EXECUTION_ID = "operationExecutionId";
+ private static final String ONAP_CSAR_ID = "myOnapCsarId";
+ private static final String VIM_ID = "ownerId_regionId";
+ private GrantVNFResponseVim vim = new GrantVNFResponseVim();
+ @Mock
+ private CatalogManager catalogManager;
+ @Mock
+ private VfcGrantManager vfcGrantManager;
+ @Mock
+ private CbamTokenProvider tokenProvider;
+ @Mock
+ private JobManager jobManager;
+ @Mock
+ private LifecycleChangeNotificationManager notificationManager;
+ @Mock
+ private HttpServletResponse restResponse;
+ @Mock
+ private VimInfoProvider vimInfoProvider;
+
+ private ArgumentCaptor<CreateVnfRequest> createRequest = ArgumentCaptor.forClass(CreateVnfRequest.class);
+ private AdditionalParameters additionalParam = new AdditionalParameters();
+ private String INSTANTIATION_LEVEL = "level1";
+ private GrantVNFResponseVim grantResponse = new GrantVNFResponseVim();
+ private String cbamVnfdContent;
+ private OperationExecution instantiationOperationExecution = new OperationExecution();
+ private OperationExecution modifyPropertyoperationExecution = new OperationExecution();
+ private OperationExecution scaleOperationExecution = new OperationExecution();
+ private OperationExecution healOperationExecution = new OperationExecution();
+
+ private VnfInfo vnfInfo = new VnfInfo();
+ private List<OperationExecution> operationExecutions = new ArrayList<>();
+ private org.onap.vnfmdriver.model.VimInfo vimInfo = new org.onap.vnfmdriver.model.VimInfo();
+ private ExtVirtualLinkInfo externalVirtualLink = new ExtVirtualLinkInfo();
+ private ExtManagedVirtualLinkData extManVl = new ExtManagedVirtualLinkData();
+ private ArgumentCaptor<ModifyVnfInfoRequest> actualVnfModifyRequest = ArgumentCaptor.forClass(ModifyVnfInfoRequest.class);
+ private Set<Boolean> finished = new HashSet<>();
+ private ArgumentCaptor<ScaleVnfRequest> actualScaleRequest = ArgumentCaptor.forClass(ScaleVnfRequest.class);
+ private ArgumentCaptor<HealVnfRequest> actualHealRequest = ArgumentCaptor.forClass(HealVnfRequest.class);
+
+ private LifecycleManager lifecycleManager;
+
+ @Before
+ public void initMocks() throws Exception {
+ vnfInfo.setExtensions(new ArrayList<>());
+ vnfInfo.setOperationExecutions(new ArrayList<>());
+ lifecycleManager = new LifecycleManager(catalogManager, vfcGrantManager, cbamRestApiProvider, vimInfoProvider, jobManager, notificationManager);
+ cbamVnfdContent = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/vnfd.full.yaml").toURI())));
+ setField(LifecycleManager.class, "logger", logger);
+ CatalogAdapterVnfpackage cbamPackage = new CatalogAdapterVnfpackage();
+ when(catalogManager.preparePackageInCbam(VNFM_ID, ONAP_CSAR_ID)).thenReturn(cbamPackage);
+ cbamPackage.setVnfdId(CBAM_VNFD_ID);
+ vnfInfo.setVnfdId(CBAM_VNFD_ID);
+ vnfInfo.setId(VNF_ID);
+ when(jobManager.spawnJob(VNF_ID, restResponse)).thenReturn(JOB_ID);
+ when(catalogManager.getCbamVnfdContent(VNFM_ID, CBAM_VNFD_ID)).thenReturn(cbamVnfdContent);
+ cbamPackage.setId(CBAM_VNFD_ID);
+ vimInfo.setUrl("cloudUrl");
+ vimInfo.setPassword("vimPassword");
+ vimInfo.setUserName("vimUsername");
+ vimInfo.setSslInsecure("true");
+ vimInfo.setVimId(VIM_ID);
+ vimInfo.setName("vimName");
+ when(vimInfoProvider.getVimInfo((VIM_ID))).thenReturn(vimInfo);
+ instantiationOperationExecution.setId(OPERATION_EXECUTION_ID);
+ instantiationOperationExecution.setOperationType(OperationType.INSTANTIATE);
+ instantiationOperationExecution.setStartTime(OffsetDateTime.now());
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(operationExecutions);
+ operationExecutions.add(modifyPropertyoperationExecution);
+ modifyPropertyoperationExecution.setStartTime(OffsetDateTime.now());
+ modifyPropertyoperationExecution.setOperationType(OperationType.MODIFY_INFO);
+ operationExecutions.add(instantiationOperationExecution);
+ instantiationOperationExecution.setStatus(OperationStatus.FINISHED);
+ modifyPropertyoperationExecution.setStatus(OperationStatus.FINISHED);
+ modifyPropertyoperationExecution.setId(UUID.randomUUID().toString());
+ scaleOperationExecution.setId(UUID.randomUUID().toString());
+ healOperationExecution.setId(UUID.randomUUID().toString());
+ when(vnfApi.vnfsVnfInstanceIdPatch(eq(VNF_ID), actualVnfModifyRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(modifyPropertyoperationExecution);
+ doAnswer(new Answer() {
+ @Override
+ public Object answer(InvocationOnMock invocation) throws Throwable {
+ finished.add(Boolean.TRUE);
+ return null;
+ }
+ }).when(jobManager).jobFinished(JOB_ID);
+ when(vnfApi.vnfsVnfInstanceIdScalePost(eq(VNF_ID), actualScaleRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ operationExecutions.add(scaleOperationExecution);
+ return scaleOperationExecution;
+ }
+ });
+ when(vnfApi.vnfsVnfInstanceIdHealPost(eq(VNF_ID), actualHealRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ operationExecutions.add(healOperationExecution);
+ return healOperationExecution;
+ }
+ });
+ }
+
+ /**
+ * test instantiation
+ */
+ @Test
+ public void testInstantiation() throws Exception {
+ //given
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ //verify
+ assertEquals(VNF_ID, response.getVnfInstanceId());
+ assertEquals(JOB_ID, response.getJobId());
+ assertEquals(createRequest.getAllValues().size(), 1);
+ assertEquals("myDescription", createRequest.getValue().getDescription());
+ assertEquals("vnfName", createRequest.getValue().getName());
+ assertEquals(CBAM_VNFD_ID, createRequest.getValue().getVnfdId());
+ assertEquals(1, actualInstantiationRequest.getAllValues().size());
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ OPENSTACKV2INFO actualVim = (OPENSTACKV2INFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(VIM_ID, actualVim.getId());
+ assertEquals(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO, actualVim.getVimInfoType());
+ assertEquals(Boolean.valueOf(parseBoolean(vimInfo.getSslInsecure())), actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertEquals("cloudUrl", actualVim.getInterfaceInfo().getEndpoint());
+ //FIXME assertEquals();actualVim.getInterfaceInfo().getTrustedCertificates());
+ assertEquals("vimPassword", actualVim.getAccessInfo().getPassword());
+ assertEquals("regionId", actualVim.getAccessInfo().getRegion());
+ assertEquals("myTenant", actualVim.getAccessInfo().getTenant());
+ assertEquals("vimUsername", actualVim.getAccessInfo().getUsername());
+ assertEquals(1, actualInstantiationRequest.getValue().getComputeResourceFlavours().size());
+ assertEquals("flavourProviderId", actualInstantiationRequest.getValue().getComputeResourceFlavours().get(0).getResourceId());
+ assertEquals(VIM_ID, actualInstantiationRequest.getValue().getComputeResourceFlavours().get(0).getVimId());
+ assertEquals("virtualComputeDescId", actualInstantiationRequest.getValue().getComputeResourceFlavours().get(0).getVnfdVirtualComputeDescId());
+ assertEquals(1, actualInstantiationRequest.getValue().getExtManagedVirtualLinks().size());
+ assertEquals(extManVl, actualInstantiationRequest.getValue().getExtManagedVirtualLinks().get(0));
+ assertEquals(2, actualInstantiationRequest.getValue().getExtVirtualLinks().size());
+
+ assertEquals("myNetworkProviderId", actualInstantiationRequest.getValue().getExtVirtualLinks().get(0).getResourceId());
+ assertEquals("myEVlId", actualInstantiationRequest.getValue().getExtVirtualLinks().get(0).getExtVirtualLinkId());
+ assertEquals(1, actualInstantiationRequest.getValue().getExtVirtualLinks().get(0).getExtCps().size());
+ assertEquals("myCpdId", actualInstantiationRequest.getValue().getExtVirtualLinks().get(0).getExtCps().get(0).getCpdId());
+
+ assertEquals(VIM_ID, actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getVimId());
+ assertEquals("evlId1", actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtVirtualLinkId());
+ assertEquals("networkProviderId1", actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getResourceId());
+ assertEquals(1, actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtCps().size());
+
+
+ assertEquals(Integer.valueOf(2), actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtCps().get(0).getNumDynamicAddresses());
+ assertEquals("cpdId3", actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtCps().get(0).getCpdId());
+ assertEquals(1, actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtCps().get(0).getAddresses().size());
+ assertEquals("1.2.3.4", actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtCps().get(0).getAddresses().get(0).getIp());
+ assertEquals("mac", actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtCps().get(0).getAddresses().get(0).getMac());
+ assertEquals("subnetId", actualInstantiationRequest.getValue().getExtVirtualLinks().get(1).getExtCps().get(0).getAddresses().get(0).getSubnetId());
+
+ assertEquals("myFlavorId", actualInstantiationRequest.getValue().getFlavourId());
+ assertEquals(Boolean.TRUE, actualInstantiationRequest.getValue().isGrantlessMode());
+ assertEquals("level1", actualInstantiationRequest.getValue().getInstantiationLevelId());
+ assertEquals(1, actualInstantiationRequest.getValue().getZones().size());
+ assertEquals(VIM_ID, actualInstantiationRequest.getValue().getZones().get(0).getVimId());
+ assertEquals("zoneProviderId", actualInstantiationRequest.getValue().getZones().get(0).getResourceId());
+ assertEquals("zoneId", actualInstantiationRequest.getValue().getZones().get(0).getId());
+ assertEquals(1, actualInstantiationRequest.getValue().getSoftwareImages().size());
+ assertEquals(VIM_ID, actualInstantiationRequest.getValue().getSoftwareImages().get(0).getVimId());
+ assertEquals("imageProviderId", actualInstantiationRequest.getValue().getSoftwareImages().get(0).getResourceId());
+ assertEquals("imageId", actualInstantiationRequest.getValue().getSoftwareImages().get(0).getVnfdSoftwareImageId());
+ String actualEmbeddedAdditionParams = new Gson().toJson(actualInstantiationRequest.getValue().getAdditionalParams());
+ assertTrue("{\"jobId\":\"myJobId\",\"a\":\"b\"}".equals(actualEmbeddedAdditionParams) || "{\"a\":\"b\",\"jobId\":\"myJobId\"}".equals(actualEmbeddedAdditionParams));
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+
+ assertEquals(1, actualVnfModifyRequest.getAllValues().size());
+ assertEquals(2, actualVnfModifyRequest.getValue().getExtensions().size());
+ assertEquals(LifecycleManager.ONAP_CSAR_ID, actualVnfModifyRequest.getValue().getExtensions().get(0).getName());
+ assertEquals(ONAP_CSAR_ID, actualVnfModifyRequest.getValue().getExtensions().get(0).getValue());
+ assertEquals(LifecycleManager.EXTERNAL_VNFM_ID, actualVnfModifyRequest.getValue().getExtensions().get(1).getName());
+ assertEquals(VNFM_ID, actualVnfModifyRequest.getValue().getExtensions().get(1).getValue());
+
+ //the 3.2 API does not accept empty array
+ assertNull(actualVnfModifyRequest.getValue().getVnfConfigurableProperties());
+ verify(jobManager).spawnJob(VNF_ID, restResponse);
+ verify(logger).info(eq("Starting {} operation on VNF with {} identifier with {} parameter"), eq("creation"), eq("not yet specified"), anyString());
+ verify(logger).info(eq("Starting {} operation on VNF with {} identifier with {} parameter"), eq("instantiation"), eq(VNF_ID), anyString());
+ }
+
+ /**
+ * invalid VIM type results in failure
+ */
+ @Test
+ public void testInstantiationWithInvalidVimType() throws Exception {
+ //given
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OTHER_VIM_INFO);
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ when(logger.isInfoEnabled()).thenReturn(false);
+ //when
+ try {
+ lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ //verify
+ fail();
+ } catch (Exception e) {
+ assertEquals("Only OPENSTACK_V2_INFO, OPENSTACK_V3_INFO and VMWARE_VCLOUD_INFO is the supported VIM types", e.getMessage());
+ }
+ verify(vnfApi, never()).vnfsPost(Mockito.any(), Mockito.any());
+ verify(logger, never()).info(eq("Starting {} operation on VNF with {} identifier with {} parameter"), eq("creation"), eq("not yet specified"), anyString());
+ verify(logger, never()).info(eq("Starting {} operation on VNF with {} identifier with {} parameter"), eq("instantiation"), eq(VNF_ID), anyString());
+ verify(logger).error("Only OPENSTACK_V2_INFO, OPENSTACK_V3_INFO and VMWARE_VCLOUD_INFO is the supported VIM types");
+ }
+
+ /**
+ * test instantiation with KeyStone V2 based with SSL
+ */
+ @Test
+ public void testInstantiationV2WithSsl() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ String caCert = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/localhost.cert.pem").toURI())));
+ vimInfo.setSslInsecure("false");
+ vimInfo.setSslCacert(caCert);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ JsonObject inputs = child((JsonObject) instantiationRequest.getAdditionalParam(), "inputs");
+ JsonObject vnfs = child(child(inputs, "vnfs"), ONAP_CSAR_ID);
+ vnfs.remove("additionalParams");
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ OPENSTACKV2INFO actualVim = (OPENSTACKV2INFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(StoreLoader.getCertifacates(caCert).iterator().next(), new String(actualVim.getInterfaceInfo().getTrustedCertificates().get(0)));
+ assertTrue(!actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(!actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ verify(logger).warn("No additional parameters were specified for the operation");
+ }
+
+ /**
+ * non specified SSL verification means not verified
+ */
+ @Test
+ public void testInstantiationV2WithoutSsl() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ vimInfo.setSslInsecure(null);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ OPENSTACKV2INFO actualVim = (OPENSTACKV2INFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ }
+
+ /**
+ * test instantiation with KeyStone V3 based
+ */
+ @Test
+ public void testInstantiationV3() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ OPENSTACKV3INFO actualVim = (OPENSTACKV3INFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(VIM_ID, actualVim.getId());
+ assertEquals(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO, actualVim.getVimInfoType());
+ assertEquals(Boolean.valueOf(parseBoolean(vimInfo.getSslInsecure())), actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertEquals("cloudUrl", actualVim.getInterfaceInfo().getEndpoint());
+ //FIXME assertEquals();actualVim.getInterfaceInfo().getTrustedCertificates());
+ assertEquals("vimPassword", actualVim.getAccessInfo().getPassword());
+ assertEquals("regionId", actualVim.getAccessInfo().getRegion());
+ assertEquals("myTenant", actualVim.getAccessInfo().getProject());
+ assertEquals("myDomain", actualVim.getAccessInfo().getDomain());
+ assertEquals("vimUsername", actualVim.getAccessInfo().getUsername());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ }
+
+ /**
+ * test instantiation with KeyStone V3 based with SSL
+ */
+ @Test
+ public void testInstantiationV3WithSsl() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ String caCert = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/localhost.cert.pem").toURI())));
+ vimInfo.setSslInsecure("false");
+ vimInfo.setSslCacert(caCert);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ OPENSTACKV3INFO actualVim = (OPENSTACKV3INFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(VIM_ID, actualVim.getId());
+ assertEquals(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO, actualVim.getVimInfoType());
+ assertEquals(Boolean.valueOf(parseBoolean(vimInfo.getSslInsecure())), actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertEquals("cloudUrl", actualVim.getInterfaceInfo().getEndpoint());
+ //FIXME assertEquals();actualVim.getInterfaceInfo().getTrustedCertificates());
+ assertEquals("vimPassword", actualVim.getAccessInfo().getPassword());
+ assertEquals("regionId", actualVim.getAccessInfo().getRegion());
+ assertEquals("myTenant", actualVim.getAccessInfo().getProject());
+ assertEquals("myDomain", actualVim.getAccessInfo().getDomain());
+ assertEquals("vimUsername", actualVim.getAccessInfo().getUsername());
+ assertEquals(StoreLoader.getCertifacates(caCert).iterator().next(), new String(actualVim.getInterfaceInfo().getTrustedCertificates().get(0)));
+ assertTrue(!actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(!actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ }
+
+ /**
+ * non specified SSL verification meams not verified for KeyStone V3 based
+ */
+ @Test
+ public void testInstantiationV3WithNonSpecifiedSsl() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ vimInfo.setSslInsecure(null);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ OPENSTACKV3INFO actualVim = (OPENSTACKV3INFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(VIM_ID, actualVim.getId());
+ assertEquals(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO, actualVim.getVimInfoType());
+ assertEquals("cloudUrl", actualVim.getInterfaceInfo().getEndpoint());
+ //FIXME assertEquals();actualVim.getInterfaceInfo().getTrustedCertificates());
+ assertEquals("vimPassword", actualVim.getAccessInfo().getPassword());
+ assertEquals("regionId", actualVim.getAccessInfo().getRegion());
+ assertEquals("myTenant", actualVim.getAccessInfo().getProject());
+ assertEquals("myDomain", actualVim.getAccessInfo().getDomain());
+ assertEquals("vimUsername", actualVim.getAccessInfo().getUsername());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ }
+
+ /**
+ * test instantiation with vcloud
+ */
+ @Test
+ public void testInstantiationVcloud() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ VMWAREVCLOUDINFO actualVim = (VMWAREVCLOUDINFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(VIM_ID, actualVim.getId());
+ assertEquals(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO, actualVim.getVimInfoType());
+ assertEquals(Boolean.valueOf(parseBoolean(vimInfo.getSslInsecure())), actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertEquals("cloudUrl", actualVim.getInterfaceInfo().getEndpoint());
+ //FIXME assertEquals();actualVim.getInterfaceInfo().getTrustedCertificates());
+ assertEquals("vimPassword", actualVim.getAccessInfo().getPassword());
+ assertEquals("regionId", actualVim.getAccessInfo().getOrganization());
+ assertEquals("vimUsername", actualVim.getAccessInfo().getUsername());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ }
+
+ /**
+ * test instantiation with vCloud with SSL
+ */
+ @Test
+ public void testInstantiationVcloudWithSsl() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ String caCert = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/localhost.cert.pem").toURI())));
+ vimInfo.setSslInsecure("false");
+ vimInfo.setSslCacert(caCert);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ VMWAREVCLOUDINFO actualVim = (VMWAREVCLOUDINFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(VIM_ID, actualVim.getId());
+ assertEquals(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO, actualVim.getVimInfoType());
+ assertEquals(Boolean.valueOf(parseBoolean(vimInfo.getSslInsecure())), actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertEquals("cloudUrl", actualVim.getInterfaceInfo().getEndpoint());
+ //FIXME assertEquals();actualVim.getInterfaceInfo().getTrustedCertificates());
+ assertEquals("vimPassword", actualVim.getAccessInfo().getPassword());
+ assertEquals("regionId", actualVim.getAccessInfo().getOrganization());
+ assertEquals("vimUsername", actualVim.getAccessInfo().getUsername());
+ assertEquals(StoreLoader.getCertifacates(caCert).iterator().next(), new String(actualVim.getInterfaceInfo().getTrustedCertificates().get(0)));
+ assertTrue(!actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(!actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ }
+
+ /**
+ * test instantiation with vCloud with SSL
+ */
+ @Test
+ public void testInstantiationVcloudWithNonSecifedSSl() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ vimInfo.setSslInsecure(null);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualInstantiationRequest.getValue().getVims().size());
+ //verify
+ VMWAREVCLOUDINFO actualVim = (VMWAREVCLOUDINFO) actualInstantiationRequest.getValue().getVims().get(0);
+ assertEquals(VIM_ID, actualVim.getId());
+ assertEquals(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO, actualVim.getVimInfoType());
+ assertEquals("cloudUrl", actualVim.getInterfaceInfo().getEndpoint());
+ //FIXME assertEquals();actualVim.getInterfaceInfo().getTrustedCertificates());
+ assertEquals("vimPassword", actualVim.getAccessInfo().getPassword());
+ assertEquals("regionId", actualVim.getAccessInfo().getOrganization());
+ assertEquals("vimUsername", actualVim.getAccessInfo().getUsername());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateVerification());
+ assertTrue(actualVim.getInterfaceInfo().isSkipCertificateHostnameCheck());
+ }
+
+ /**
+ * test failure in the instantiation request marks the job to be finished in job manager
+ */
+ @Test
+ public void testFailureInTheInstantiationRequest() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenThrow(expectedException);
+
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ //verfiy
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(VNF_ID, response.getVnfInstanceId());
+ assertEquals(JOB_ID, response.getJobId());
+ verify(logger).error("Unable to instantiate VNF with myVnfId identifier", expectedException);
+ }
+
+ /**
+ * instantiation fails if VF-C does not send vim identifier in grant response
+ */
+ @Test
+ public void testVfcFailsToSendVimId() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ //grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ String caCert = new String(readAllBytes(Paths.get(TestVfcGrantManager.class.getResource("/unittests/localhost.cert.pem").toURI())));
+ vimInfo.setSslInsecure("false");
+ vimInfo.setSslCacert(caCert);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(0, actualInstantiationRequest.getAllValues().size());
+ //verify
+ verify(logger).error("VF-C did not send VIM identifier in grant response");
+
+ }
+
+ /**
+ * test operation execution polling is retried in case of failures
+ */
+ @Test
+ public void testFailureInTheOperationExecutionPollingDuringInstantiationRequest() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ additionalParam.setInstantiationLevel(INSTANTIATION_LEVEL);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ grantResponse.setAccessInfo(accessInfo);
+ ArgumentCaptor<InstantiateVnfRequest> actualInstantiationRequest = ArgumentCaptor.forClass(InstantiateVnfRequest.class);
+ ApiException expectedException = new ApiException();
+ List<ApiException> polling = new ArrayList<>();
+ when(vnfApi.vnfsVnfInstanceIdInstantiatePost(eq(VNF_ID), actualInstantiationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(instantiationOperationExecution);
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).then(new Answer<List<OperationExecution>>() {
+ @Override
+ public List<OperationExecution> answer(InvocationOnMock invocation) throws Throwable {
+ if (polling.size() > 2) {
+ return operationExecutions;
+ }
+ ApiException apiException = new ApiException();
+ polling.add(apiException);
+ throw apiException;
+ }
+ });
+ //when
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ //verfiy
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(VNF_ID, response.getVnfInstanceId());
+ assertEquals(JOB_ID, response.getJobId());
+ assertEquals(3, polling.size());
+ for (ApiException e : polling) {
+ verify(logger).warn("Unable to retrieve operations details", e);
+ }
+ verify(systemFunctions, Mockito.times(3)).sleep(5000);
+ }
+
+ /**
+ * failure in VNF creation is logged an proagated
+ */
+ @Test
+ public void failureInVnfCreationIsPropagated() throws Exception {
+ //given
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenThrow(expectedException);
+ //when
+ try {
+ lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to create the VNF", expectedException);
+ }
+ }
+
+ /**
+ * failure in updating the modifyable attributes of the VNF is logged an proagated
+ */
+ @Test
+ public void failureInVnfModificationIsPropagated() throws Exception {
+ //given
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ when(vnfApi.vnfsVnfInstanceIdPatch(eq(VNF_ID), actualVnfModifyRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenThrow(expectedException);
+
+ //when
+ try {
+ lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals(expectedException, e.getCause().getCause());
+ verify(logger).error("Unable to set the onapCsarId property on the VNF", expectedException);
+ }
+ }
+
+ /**
+ * if the VIM info can not be queried the VNF is not instantiated and
+ * error propagated through job
+ */
+ @Test
+ public void testFailureInQueryVimInfo() throws Exception {
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+ when(vnfApi.vnfsPost(createRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenReturn(vnfInfo);
+ when(vfcGrantManager.requestGrantForInstantiate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, INSTANTIATION_LEVEL, cbamVnfdContent, JOB_ID)).thenReturn(grantResponse);
+ grantResponse.setVimId(VIM_ID);
+ GrantVNFResponseVimAccessInfo accessInfo = new GrantVNFResponseVimAccessInfo();
+ accessInfo.setTenant(TENANT);
+ grantResponse.setAccessInfo(accessInfo);
+
+ when(vimInfoProvider.getVimInfo(VIM_ID)).thenThrow(new RuntimeException());
+ //when
+ lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ verify(vnfApi, never()).vnfsVnfInstanceIdInstantiatePost(Mockito.any(), Mockito.any(), Mockito.any());
+ }
+
+ /**
+ * test termination basic success scenario
+ * - the VNF is not deleted before the notifications are processed
+ */
+ @Test
+ public void testTermination() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ vnfInfo.setInstantiationState(InstantiationState.INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ ArgumentCaptor<TerminateVnfRequest> actualTerminationRequest = ArgumentCaptor.forClass(TerminateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdTerminatePost(eq(VNF_ID), actualTerminationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ OperationExecution terminationOperation = new OperationExecution();
+ terminationOperation.setId("terminationId");
+ operationExecutions.add(terminationOperation);
+ terminationOperation.setStatus(OperationStatus.FINISHED);
+ return terminationOperation;
+ }
+ });
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualTerminationRequest.getAllValues().size());
+ assertEquals(TerminationType.FORCEFUL, actualTerminationRequest.getValue().getTerminationType());
+ InOrder notificationIsProcessedBeforeDeletingTheVnf = Mockito.inOrder(vfcGrantManager, notificationManager, vnfApi);
+ notificationIsProcessedBeforeDeletingTheVnf.verify(vfcGrantManager).requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnfInfo, JOB_ID);
+ notificationIsProcessedBeforeDeletingTheVnf.verify(notificationManager).waitForTerminationToBeProcessed("terminationId");
+ notificationIsProcessedBeforeDeletingTheVnf.verify(vnfApi).vnfsVnfInstanceIdDelete(VNF_ID, NOKIA_LCM_API_VERSION);
+ verify(jobManager).spawnJob(VNF_ID, restResponse);
+ verify(logger).info(eq("Starting {} operation on VNF with {} identifier with {} parameter"), eq("termination"), eq(VNF_ID), anyString());
+ }
+
+ /**
+ * test termination of a non instantiated VNF
+ * - the VNF is not terminated (only deleted)
+ */
+ @Test
+ public void testTerminationOfNonInstantiated() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ vnfInfo.setInstantiationState(InstantiationState.NOT_INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ boolean deleted = false;
+ while (!deleted) {
+ try {
+ Mockito.
+ verify(vnfApi).vnfsVnfInstanceIdDelete(VNF_ID, NOKIA_LCM_API_VERSION);
+ deleted = true;
+ } catch (Error e) {
+ }
+ }
+ verify(vfcGrantManager, never()).requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnfInfo, JOB_ID);
+ verify(notificationManager, never()).waitForTerminationToBeProcessed("terminationId");
+ }
+
+ /**
+ * test that the VNF deletion is not started before the termination finishes
+ */
+ @Test
+ public void testTerminationOperationIsOutwaited() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ vnfInfo.setInstantiationState(InstantiationState.INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ ArgumentCaptor<TerminateVnfRequest> actualTerminationRequest = ArgumentCaptor.forClass(TerminateVnfRequest.class);
+ OperationExecution terminationOperation = new OperationExecution();
+ when(vnfApi.vnfsVnfInstanceIdTerminatePost(eq(VNF_ID), actualTerminationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ terminationOperation.setId("terminationId");
+ operationExecutions.add(terminationOperation);
+ terminationOperation.setStatus(OperationStatus.STARTED);
+ return terminationOperation;
+ }
+ });
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ Set<Integer> calls = new HashSet<>();
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenAnswer(new Answer<List<OperationExecution>>() {
+ @Override
+ public List<OperationExecution> answer(InvocationOnMock invocation) throws Throwable {
+ if (calls.size() == 1000) {
+ terminationOperation.setStatus(OperationStatus.FINISHED);
+ }
+ calls.add(calls.size());
+ return operationExecutions;
+ }
+ });
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ verify(vnfApi, times(1001)).vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION);
+ verify(systemFunctions, times(1000)).sleep(5000);
+ }
+
+
+ /**
+ * test that failured during waiting for the operation to finish is tolerated (idefineiatelly)
+ */
+ @Test
+ public void testTerminationOperationIsOutwaitedWithErrors() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ vnfInfo.setInstantiationState(InstantiationState.INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ ArgumentCaptor<TerminateVnfRequest> actualTerminationRequest = ArgumentCaptor.forClass(TerminateVnfRequest.class);
+ OperationExecution terminationOperation = new OperationExecution();
+ when(vnfApi.vnfsVnfInstanceIdTerminatePost(eq(VNF_ID), actualTerminationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ terminationOperation.setId("terminationId");
+ operationExecutions.add(terminationOperation);
+ terminationOperation.setStatus(OperationStatus.STARTED);
+ return terminationOperation;
+ }
+ });
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ Set<Integer> calls = new HashSet<>();
+ List<ApiException> expectedExceptions = new ArrayList<>();
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenAnswer(new Answer<List<OperationExecution>>() {
+ @Override
+ public List<OperationExecution> answer(InvocationOnMock invocation) throws Throwable {
+ if (calls.size() >= 100) {
+ terminationOperation.setStatus(OperationStatus.FINISHED);
+ return operationExecutions;
+ }
+ calls.add(calls.size());
+ ApiException apiException = new ApiException();
+ expectedExceptions.add(apiException);
+ throw apiException;
+ }
+ });
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ verify(vnfApi, times(101)).vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION);
+ verify(systemFunctions, times(100)).sleep(5000);
+ for (ApiException expectedException : expectedExceptions) {
+ verify(logger).warn("Unable to retrieve operations details", expectedException);
+ }
+ }
+
+ /**
+ * test gracefull termination
+ */
+ @Test
+ public void testGracefullTermination() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ terminationRequest.setTerminationType(VnfTerminationType.GRACEFUL);
+ terminationRequest.setGracefulTerminationTimeout("1234");
+ vnfInfo.setInstantiationState(InstantiationState.INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ ArgumentCaptor<TerminateVnfRequest> actualTerminationRequest = ArgumentCaptor.forClass(TerminateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdTerminatePost(eq(VNF_ID), actualTerminationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ OperationExecution terminationOperation = new OperationExecution();
+ terminationOperation.setId("terminationId");
+ operationExecutions.add(terminationOperation);
+ terminationOperation.setStatus(OperationStatus.FINISHED);
+ return terminationOperation;
+ }
+ });
+ doAnswer(invocation -> {
+ verify(jobManager, Mockito.never()).jobFinished(JOB_ID);
+ return null;
+ }).when(vnfApi).vnfsVnfInstanceIdDelete(VNF_ID, NOKIA_LCM_API_VERSION);
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualTerminationRequest.getAllValues().size());
+ assertEquals(TerminationType.GRACEFUL, actualTerminationRequest.getValue().getTerminationType());
+ assertEquals(Integer.valueOf(1234), actualTerminationRequest.getValue().getGracefulTerminationTimeout());
+ InOrder notificationIsProcessedBeforeDeletingTheVnf = Mockito.inOrder(vfcGrantManager, notificationManager, vnfApi);
+ notificationIsProcessedBeforeDeletingTheVnf.verify(vfcGrantManager).requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnfInfo, JOB_ID);
+ notificationIsProcessedBeforeDeletingTheVnf.verify(notificationManager).waitForTerminationToBeProcessed("terminationId");
+ notificationIsProcessedBeforeDeletingTheVnf.verify(vnfApi).vnfsVnfInstanceIdDelete(VNF_ID, NOKIA_LCM_API_VERSION);
+ }
+
+ /**
+ * instantiation with missing ONAP csarId to instantiation extra param result in failure
+ */
+ @Test
+ public void testMissingVnfParameters() throws Exception {
+ //given
+ VnfInstantiateRequest instantiationRequest = prepareInstantiationRequest(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+ String src = "{ \"inputs\" : { \"vnfs\" : { \"" + ONAP_CSAR_ID + "invalid" + "\" : {}}}, \"vimId\" : \"" + VIM_ID + "\"}";
+ instantiationRequest.setAdditionalParam(new JsonParser().parse(src));
+ //when
+ try {
+ VnfInstantiateResponse response = lifecycleManager.createAndInstantiate(VNFM_ID, instantiationRequest, restResponse);
+ fail();
+ } catch (Exception e) {
+ assertEquals("The additional parameter section does not contain setting for VNF with myOnapCsarId CSAR id", e.getMessage());
+ verify(logger).error("The additional parameter section does not contain setting for VNF with myOnapCsarId CSAR id");
+ }
+ }
+
+ /**
+ * test explicit forceful termination
+ */
+ @Test
+ public void testExplicitForcefulTermination() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ terminationRequest.setTerminationType(VnfTerminationType.FORCEFUL);
+ terminationRequest.setGracefulTerminationTimeout("1234");
+ vnfInfo.setInstantiationState(InstantiationState.INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ ArgumentCaptor<TerminateVnfRequest> actualTerminationRequest = ArgumentCaptor.forClass(TerminateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdTerminatePost(eq(VNF_ID), actualTerminationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ OperationExecution terminationOperation = new OperationExecution();
+ terminationOperation.setId("terminationId");
+ operationExecutions.add(terminationOperation);
+ terminationOperation.setStatus(OperationStatus.FINISHED);
+ return terminationOperation;
+ }
+ });
+ doAnswer(invocation -> {
+ verify(jobManager, Mockito.never()).jobFinished(JOB_ID);
+ return null;
+ }).when(vnfApi).vnfsVnfInstanceIdDelete(VNF_ID, NOKIA_LCM_API_VERSION);
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualTerminationRequest.getAllValues().size());
+ assertEquals(TerminationType.FORCEFUL, actualTerminationRequest.getValue().getTerminationType());
+ assertNull(actualTerminationRequest.getValue().getGracefulTerminationTimeout());
+ InOrder notificationIsProcessedBeforeDeletingTheVnf = Mockito.inOrder(vfcGrantManager, notificationManager, vnfApi);
+ notificationIsProcessedBeforeDeletingTheVnf.verify(vfcGrantManager).requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnfInfo, JOB_ID);
+ notificationIsProcessedBeforeDeletingTheVnf.verify(notificationManager).waitForTerminationToBeProcessed("terminationId");
+ notificationIsProcessedBeforeDeletingTheVnf.verify(vnfApi).vnfsVnfInstanceIdDelete(VNF_ID, NOKIA_LCM_API_VERSION);
+ }
+
+ /**
+ * test failure in the termination workflow finishes the job
+ */
+ @Test
+ public void testFailureInTheTerminationFinishesTheManagedJob() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ terminationRequest.setTerminationType(VnfTerminationType.FORCEFUL);
+ terminationRequest.setGracefulTerminationTimeout("1234");
+ vnfInfo.setInstantiationState(InstantiationState.INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ ArgumentCaptor<TerminateVnfRequest> actualTerminationRequest = ArgumentCaptor.forClass(TerminateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdTerminatePost(eq(VNF_ID), actualTerminationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ OperationExecution terminationOperation = new OperationExecution();
+ terminationOperation.setId("terminationId");
+ operationExecutions.add(terminationOperation);
+ terminationOperation.setStatus(OperationStatus.FINISHED);
+ return terminationOperation;
+ }
+ });
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(0, actualTerminationRequest.getAllValues().size());
+ Mockito.verifyZeroInteractions(vfcGrantManager);
+ }
+
+ /**
+ * if termination fails the VNF is not deleted
+ */
+ @Test
+ public void testFailedTerminationAbortsTerminationWorkflow() throws Exception {
+ //given
+ VnfTerminateRequest terminationRequest = new VnfTerminateRequest();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ vnfInfo.setInstantiationState(InstantiationState.INSTANTIATED);
+ vnfInfo.setOperationExecutions(operationExecutions);
+ VnfProperty vnfdId = new VnfProperty();
+ vnfdId.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfdId.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(vnfdId);
+ ArgumentCaptor<TerminateVnfRequest> actualTerminationRequest = ArgumentCaptor.forClass(TerminateVnfRequest.class);
+ when(vnfApi.vnfsVnfInstanceIdTerminatePost(eq(VNF_ID), actualTerminationRequest.capture(), eq(NOKIA_LCM_API_VERSION))).thenAnswer(new Answer<OperationExecution>() {
+ @Override
+ public OperationExecution answer(InvocationOnMock invocation) throws Throwable {
+ OperationExecution terminationOperation = new OperationExecution();
+ terminationOperation.setId("terminationId");
+ operationExecutions.add(terminationOperation);
+ terminationOperation.setStatus(OperationStatus.FAILED);
+ return terminationOperation;
+ }
+ });
+ JsonElement instantiationParameters = new JsonParser().parse("{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] } ");
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet("operationExecutionId", NOKIA_LCM_API_VERSION)).thenReturn(instantiationParameters);
+ //when
+ JobInfo jobInfo = lifecycleManager.terminateVnf(VNFM_ID, VNF_ID, terminationRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualTerminationRequest.getAllValues().size());
+ assertEquals(TerminationType.FORCEFUL, actualTerminationRequest.getValue().getTerminationType());
+ verify(vfcGrantManager).requestGrantForTerminate(VNFM_ID, VNF_ID, VIM_ID, ONAP_CSAR_ID, vnfInfo, JOB_ID);
+ verify(vnfApi, never()).vnfsVnfInstanceIdDelete(VNF_ID, NOKIA_LCM_API_VERSION);
+ verify(logger).error("Unable to terminate VNF the operation did not finish with success");
+ }
+
+ /**
+ * test VNF query basic success scenario
+ */
+ @Test
+ public void testQuery() throws Exception {
+ vnfInfo.setDescription("myDescription");
+ vnfInfo.setName("myName");
+ vnfInfo.setVnfSoftwareVersion("vnfSoftwareVersion");
+ vnfInfo.setVnfProvider("myProvider");
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ prop.setValue(ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(prop);
+ //when
+ org.onap.vnfmdriver.model.VnfInfo vnf = lifecycleManager.queryVnf(VNFM_ID, VNF_ID);
+ //verify
+ assertEquals(VNF_ID, vnf.getVnfInstanceId());
+ //FIXME ? (do not know what exactly the vnf version mean in core terminology)
+ assertEquals("vnfSoftwareVersion", vnf.getVersion());
+ assertEquals(ONAP_CSAR_ID, vnf.getVnfdId());
+ assertEquals("myDescription", vnf.getVnfInstanceDescription());
+ assertEquals("myName", vnf.getVnfInstanceName());
+ assertEquals(ONAP_CSAR_ID, vnf.getVnfPackageId());
+ assertEquals("myProvider", vnf.getVnfProvider());
+ //FIXME (in swagger schema )
+ assertEquals("ACTIVE", vnf.getVnfStatus());
+ assertEquals("Kuku", vnf.getVnfType());
+ }
+
+ /**
+ * error is propagated and logged if the queried VNF does not exist
+ */
+ @Test
+ public void testQueryForNonExistingVnf() throws Exception {
+
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ try {
+ lifecycleManager.queryVnf(VNFM_ID, VNF_ID);
+ //verify
+ fail();
+ } catch (Exception e) {
+ verify(logger).error("Unable to query VNF (myVnfId)", expectedException);
+ assertEquals(expectedException, e.getCause());
+ }
+ }
+
+ /**
+ * test scale basic scenario
+ */
+ @Test
+ public void testScale() throws Exception {
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setNumberOfSteps("2");
+ scaleRequest.setAspectId("myAspect");
+ scaleRequest.setType(ScaleDirection.IN);
+ scaleRequest.setAdditionalParam(new JsonParser().parse("{ \"a\" : \"b\", \"c\" : \"d\" }"));
+ scaleOperationExecution.setStatus(OperationStatus.FINISHED);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setValue(ONAP_CSAR_ID);
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(prop);
+ vnfInfo.getOperationExecutions().add(instantiationOperationExecution);
+ String instantiationParams = "{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] }";
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(new JsonParser().parse(instantiationParams));
+ //when
+ JobInfo job = lifecycleManager.scaleVnf(VNFM_ID, VNF_ID, scaleRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualScaleRequest.getAllValues().size());
+ ScaleVnfRequest sRequest = actualScaleRequest.getValue();
+ InOrder workflowOrder = Mockito.inOrder(vfcGrantManager, vnfApi);
+ workflowOrder.verify(vfcGrantManager).requestGrantForScale(eq(VNFM_ID), eq(VNF_ID), eq(VIM_ID), eq(ONAP_CSAR_ID), eq(scaleRequest), eq(JOB_ID));
+ workflowOrder.verify(vnfApi).vnfsVnfInstanceIdScalePost(VNF_ID, sRequest, NOKIA_LCM_API_VERSION);
+ assertEquals("myAspect", sRequest.getAspectId());
+ assertEquals(com.nokia.cbam.lcm.v32.model.ScaleDirection.IN, sRequest.getType());
+ assertEquals(Integer.valueOf(2), sRequest.getNumberOfSteps());
+ assertTrue("{\"jobId\":\"myJobId\",\"a\":\"b\"}".equals(new Gson().toJson(sRequest.getAdditionalParams())) || "{\"a\":\"b\",\"jobId\":\"myJobId\"}".equals(new Gson().toJson(sRequest.getAdditionalParams())));
+ verify(jobManager).spawnJob(VNF_ID, restResponse);
+ verify(logger).info(eq("Starting {} operation on VNF with {} identifier with {} parameter"), eq("scale"), eq(VNF_ID), anyString());
+
+ }
+
+ /**
+ * the VNFM should tolerate that no additional params were supplied
+ */
+ @Test
+ public void testScaleWithoutAddtionalParams() throws Exception {
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setNumberOfSteps("2");
+ scaleRequest.setAspectId("myAspect");
+ scaleRequest.setType(ScaleDirection.IN);
+ scaleRequest.setAdditionalParam(null);
+ scaleOperationExecution.setStatus(OperationStatus.FINISHED);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setValue(ONAP_CSAR_ID);
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(prop);
+ vnfInfo.getOperationExecutions().add(instantiationOperationExecution);
+ String instantiationParams = "{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] }";
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(new JsonParser().parse(instantiationParams));
+ //when
+ JobInfo job = lifecycleManager.scaleVnf(VNFM_ID, VNF_ID, scaleRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualScaleRequest.getAllValues().size());
+ ScaleVnfRequest sRequest = actualScaleRequest.getValue();
+ InOrder workflowOrder = Mockito.inOrder(vfcGrantManager, vnfApi);
+ workflowOrder.verify(vfcGrantManager).requestGrantForScale(eq(VNFM_ID), eq(VNF_ID), eq(VIM_ID), eq(ONAP_CSAR_ID), eq(scaleRequest), eq(JOB_ID));
+ workflowOrder.verify(vnfApi).vnfsVnfInstanceIdScalePost(VNF_ID, sRequest, NOKIA_LCM_API_VERSION);
+ assertEquals("myAspect", sRequest.getAspectId());
+ assertEquals(com.nokia.cbam.lcm.v32.model.ScaleDirection.IN, sRequest.getType());
+ assertEquals(Integer.valueOf(2), sRequest.getNumberOfSteps());
+ assertEquals("{\"jobId\":\"myJobId\"}", new Gson().toJson(sRequest.getAdditionalParams()));
+ verify(jobManager).spawnJob(VNF_ID, restResponse);
+ }
+
+ /**
+ * test scale out basic scenario
+ */
+ @Test
+ public void testScaleOut() throws Exception {
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setNumberOfSteps("2");
+ scaleRequest.setAspectId("myAspect");
+ scaleRequest.setType(ScaleDirection.OUT);
+ scaleRequest.setAdditionalParam(new JsonParser().parse("{ \"a\" : \"b\" }"));
+ scaleOperationExecution.setStatus(OperationStatus.FINISHED);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setValue(ONAP_CSAR_ID);
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(prop);
+ vnfInfo.getOperationExecutions().add(instantiationOperationExecution);
+ String instantiationParams = "{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] }";
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(new JsonParser().parse(instantiationParams));
+ //when
+ JobInfo job = lifecycleManager.scaleVnf(VNFM_ID, VNF_ID, scaleRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualScaleRequest.getAllValues().size());
+ ScaleVnfRequest sRequest = actualScaleRequest.getValue();
+ InOrder workflowOrder = Mockito.inOrder(vfcGrantManager, vnfApi);
+ workflowOrder.verify(vfcGrantManager).requestGrantForScale(eq(VNFM_ID), eq(VNF_ID), eq(VIM_ID), eq(ONAP_CSAR_ID), eq(scaleRequest), eq(JOB_ID));
+ workflowOrder.verify(vnfApi).vnfsVnfInstanceIdScalePost(VNF_ID, sRequest, NOKIA_LCM_API_VERSION);
+ assertEquals("myAspect", sRequest.getAspectId());
+ assertEquals(com.nokia.cbam.lcm.v32.model.ScaleDirection.OUT, sRequest.getType());
+ assertEquals(Integer.valueOf(2), sRequest.getNumberOfSteps());
+ assertTrue("{\"jobId\":\"myJobId\",\"a\":\"b\"}".equals(new Gson().toJson(sRequest.getAdditionalParams())) || "{\"a\":\"b\",\"jobId\":\"myJobId\"}".equals(new Gson().toJson(sRequest.getAdditionalParams())));
+ }
+
+ /**
+ * test scale operation is out waited
+ */
+ @Test
+ public void testScaleOutwait() throws Exception {
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setNumberOfSteps("2");
+ scaleRequest.setAspectId("myAspect");
+ scaleRequest.setType(ScaleDirection.IN);
+ scaleRequest.setAdditionalParam(new JsonParser().parse("{ \"a\" : \"b\" }"));
+ scaleOperationExecution.setStatus(OperationStatus.STARTED);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setValue(ONAP_CSAR_ID);
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(prop);
+ vnfInfo.getOperationExecutions().add(instantiationOperationExecution);
+ String instantiationParams = "{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] }";
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(new JsonParser().parse(instantiationParams));
+ List<ApiException> expectedExceptions = new ArrayList<>();
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenAnswer((Answer<List<OperationExecution>>) invocation -> {
+ if (expectedExceptions.size() >= 100) {
+ scaleOperationExecution.setStatus(OperationStatus.FINISHED);
+ return operationExecutions;
+ }
+ ApiException apiException = new ApiException();
+ expectedExceptions.add(apiException);
+ // when(operationExecutionApi.operationExecutionsOperationExecutionIdGet(scaleOperationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(scaleOperationExecution);
+ throw apiException;
+ });
+
+ //when
+ JobInfo job = lifecycleManager.scaleVnf(VNFM_ID, VNF_ID, scaleRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(100, expectedExceptions.size());
+ for (ApiException expectedException : expectedExceptions) {
+ verify(logger).warn("Unable to retrieve operations details", expectedException);
+ }
+ verify(systemFunctions, times(100)).sleep(5000);
+ }
+
+ /**
+ * test scale failure propagation
+ */
+ @Test
+ public void testScaleFailurePropagation() throws Exception {
+ ApiException expectedException = new ApiException();
+ VnfScaleRequest scaleRequest = new VnfScaleRequest();
+ scaleRequest.setNumberOfSteps("2");
+ scaleRequest.setAspectId("myAspect");
+ scaleRequest.setType(ScaleDirection.IN);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ lifecycleManager.scaleVnf(VNFM_ID, VNF_ID, scaleRequest, restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ verify(logger).error("Unable to scale VNF with myVnfId identifier", expectedException);
+ }
+
+ /**
+ * test heal basic scenario
+ */
+ @Test
+ public void testHeal() throws Exception {
+ VnfHealRequest healRequest = new VnfHealRequest();
+ healRequest.setAction("myAction");
+ VnfHealRequestAffectedvm affectedVm = new VnfHealRequestAffectedvm();
+ affectedVm.setVmname("vmName");
+ healRequest.setAffectedvm(affectedVm);
+ healOperationExecution.setStatus(OperationStatus.FINISHED);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setValue(ONAP_CSAR_ID);
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(prop);
+ vnfInfo.getOperationExecutions().add(instantiationOperationExecution);
+ String instantiationParams = "{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] }";
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(new JsonParser().parse(instantiationParams));
+ //when
+ JobInfo job = lifecycleManager.healVnf(VNFM_ID, VNF_ID, healRequest, empty(), restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(1, actualHealRequest.getAllValues().size());
+ HealVnfRequest sRequest = actualHealRequest.getValue();
+ InOrder workflowOrder = Mockito.inOrder(vfcGrantManager, vnfApi);
+ workflowOrder.verify(vfcGrantManager).requestGrantForHeal(eq(VNFM_ID), eq(VNF_ID), eq(VIM_ID), eq(ONAP_CSAR_ID), eq(healRequest), eq(JOB_ID));
+ workflowOrder.verify(vnfApi).vnfsVnfInstanceIdHealPost(VNF_ID, sRequest, NOKIA_LCM_API_VERSION);
+ JsonObject root = new Gson().toJsonTree(sRequest.getAdditionalParams()).getAsJsonObject();
+ assertEquals("myAction", root.get("action").getAsString());
+ assertEquals("vmName", root.get("vmName").getAsString());
+ assertEquals(JOB_ID, root.get("jobId").getAsString());
+ verify(jobManager).spawnJob(VNF_ID, restResponse);
+ verify(logger).info(eq("Starting {} operation on VNF with {} identifier with {} parameter"), eq("heal"), eq(VNF_ID), anyString());
+ }
+
+ /**
+ * test heal operation is out waited
+ */
+ @Test
+ public void testHealOutwait() throws Exception {
+ VnfHealRequest healRequest = new VnfHealRequest();
+ healRequest.setAction("myAction");
+ VnfHealRequestAffectedvm affectedVm = new VnfHealRequestAffectedvm();
+ affectedVm.setVmname("vmName");
+ healRequest.setAffectedvm(affectedVm);
+ healOperationExecution.setStatus(OperationStatus.FINISHED);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnfInfo);
+ VnfProperty prop = new VnfProperty();
+ prop.setValue(ONAP_CSAR_ID);
+ prop.setName(LifecycleManager.ONAP_CSAR_ID);
+ vnfInfo.getExtensions().add(prop);
+ vnfInfo.getOperationExecutions().add(instantiationOperationExecution);
+ String instantiationParams = "{ \"vims\" : [ { \"id\" : \"" + VIM_ID + "\" } ] }";
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(new JsonParser().parse(instantiationParams));
+ List<ApiException> expectedExceptions = new ArrayList<>();
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenAnswer(new Answer<List<OperationExecution>>() {
+ @Override
+ public List<OperationExecution> answer(InvocationOnMock invocation) throws Throwable {
+ if (expectedExceptions.size() >= 100) {
+ scaleOperationExecution.setStatus(OperationStatus.FINISHED);
+ return operationExecutions;
+ }
+ ApiException apiException = new ApiException();
+ expectedExceptions.add(apiException);
+ throw apiException;
+ }
+ });
+ //when
+ JobInfo job = lifecycleManager.healVnf(VNFM_ID, VNF_ID, healRequest, empty(), restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ assertEquals(100, expectedExceptions.size());
+ for (ApiException expectedException : expectedExceptions) {
+ verify(logger).warn("Unable to retrieve operations details", expectedException);
+ }
+ verify(systemFunctions, times(100)).sleep(5000);
+ }
+
+ /**
+ * failure in heal propagates in error
+ */
+ @Test
+ public void testHealFailurePropagation() throws Exception {
+ ApiException expectedException = new ApiException();
+ VnfHealRequest healRequest = new VnfHealRequest();
+ healRequest.setAction("myAction");
+ VnfHealRequestAffectedvm affectedVm = new VnfHealRequestAffectedvm();
+ affectedVm.setVmname("vmName");
+ healRequest.setAffectedvm(affectedVm);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ JobInfo job = lifecycleManager.healVnf(VNFM_ID, VNF_ID, healRequest, empty(), restResponse);
+ //verify
+ waitForJobToFinishInJobManager(finished);
+ verify(logger).error("Unable to heal VNF with myVnfId identifier", expectedException);
+ }
+
+ private void waitForJobToFinishInJobManager(Set<Boolean> finished) throws InterruptedException {
+ while (finished.size() == 0) {
+ systemFunctions().sleep(100);
+ }
+ }
+
+ private VnfInstantiateRequest prepareInstantiationRequest(VimInfo.VimInfoTypeEnum cloudType) {
+ VnfInstantiateRequest instantiationRequest = new VnfInstantiateRequest();
+ instantiationRequest.setVnfPackageId(ONAP_CSAR_ID);
+ instantiationRequest.setVnfDescriptorId(ONAP_CSAR_ID);
+ instantiationRequest.setVnfInstanceDescription("myDescription");
+ instantiationRequest.setVnfInstanceName("vnfName");
+ additionalParam.setInstantiationLevel("level1");
+ switch (cloudType) {
+ case OPENSTACK_V2_INFO:
+ additionalParam.setVimType(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+ break;
+ case OPENSTACK_V3_INFO:
+ additionalParam.setVimType(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO);
+ additionalParam.setDomain("myDomain");
+ break;
+ case VMWARE_VCLOUD_INFO:
+ additionalParam.setVimType(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO);
+ break;
+ default:
+ additionalParam.setVimType(VimInfo.VimInfoTypeEnum.OTHER_VIM_INFO);
+ }
+
+ Map<String, List<NetworkAddress>> exteranalConnectionPointAddresses = new HashMap<>();
+ exteranalConnectionPointAddresses.put("ecp1", new ArrayList<>());
+ NetworkAddress networkAddress = new NetworkAddress();
+ networkAddress.setIp("1.2.3.4");
+ networkAddress.setMac("mac");
+ networkAddress.setSubnetId("subnetId");
+ exteranalConnectionPointAddresses.get("ecp1").add(networkAddress);
+ additionalParam.setExternalConnectionPointAddresses(exteranalConnectionPointAddresses);
+ VimComputeResourceFlavour flavor = new VimComputeResourceFlavour();
+ flavor.setResourceId("flavourProviderId");
+ flavor.setVimId(VIM_ID);
+ flavor.setVnfdVirtualComputeDescId("virtualComputeDescId");
+ additionalParam.getComputeResourceFlavours().add(flavor);
+ ExtVirtualLinkData evl = new ExtVirtualLinkData();
+ evl.setResourceId("networkProviderId1");
+ evl.setVimId(VIM_ID);
+ evl.setExtVirtualLinkId("evlId1");
+ VnfExtCpData ecp2 = new VnfExtCpData();
+ ecp2.setCpdId("cpdId3");
+ ecp2.setAddresses(new ArrayList<>());
+ ecp2.getAddresses().add(networkAddress);
+ ecp2.setNumDynamicAddresses(2);
+ evl.getExtCps().add(ecp2);
+ additionalParam.getExtVirtualLinks().add(evl);
+ externalVirtualLink.setCpdId("myCpdId");
+ externalVirtualLink.setResourceId("myNetworkProviderId");
+ externalVirtualLink.setVlInstanceId("myEVlId");
+ externalVirtualLink.setResourceSubnetId("notUsedSubnetId");
+ instantiationRequest.setExtVirtualLink(new ArrayList<>());
+ instantiationRequest.getExtVirtualLink().add(externalVirtualLink);
+ additionalParam.getExtManagedVirtualLinks().add(extManVl);
+ ZoneInfo zone = new ZoneInfo();
+ zone.setId("zoneId");
+ zone.setResourceId("zoneProviderId");
+ zone.setVimId(VIM_ID);
+ additionalParam.getZones().add(zone);
+ VimSoftwareImage image = new VimSoftwareImage();
+ image.setResourceId("imageProviderId");
+ image.setVimId(VIM_ID);
+ image.setVnfdSoftwareImageId("imageId");
+ additionalParam.getSoftwareImages().add(image);
+ additionalParam.setAdditionalParams(new JsonParser().parse("{ \"a\" : \"b\" }"));
+ String params = new Gson().toJson(additionalParam);
+ String src = "{ \"inputs\" : { \"vnfs\" : { \"" + ONAP_CSAR_ID + "\" : " + params + "}}, \"vimId\" : \"" + VIM_ID + "\"}";
+ instantiationRequest.setAdditionalParam(new JsonParser().parse(src));
+ return instantiationRequest;
+ }
+
+ /**
+ * Test vimId decomposition
+ */
+ @Test
+ public void testVimIdSplitting() {
+ assertEquals("regionId", LifecycleManager.getRegionName("cloudOwner_regionId"));
+ assertEquals("cloudOwner", LifecycleManager.getCloudOwner("cloudOwner_regionId"));
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestSelfRegistrationManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestSelfRegistrationManager.java
new file mode 100644
index 00000000..79ec1a83
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/TestSelfRegistrationManager.java
@@ -0,0 +1,345 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm;
+
+import com.google.common.collect.Lists;
+import com.nokia.cbam.lcn.v32.ApiException;
+import com.nokia.cbam.lcn.v32.model.CreateSubscriptionRequest;
+import com.nokia.cbam.lcn.v32.model.Subscription;
+import com.nokia.cbam.lcn.v32.model.SubscriptionAuthentication;
+import com.nokia.cbam.lcn.v32.model.VnfNotificationType;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.*;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
+import org.onap.msb.sdk.discovery.common.RouteException;
+import org.onap.msb.sdk.discovery.entity.MicroServiceFullInfo;
+import org.onap.msb.sdk.discovery.entity.MicroServiceInfo;
+import org.onap.msb.sdk.discovery.entity.Node;
+import org.onap.msb.sdk.discovery.entity.RouteResult;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.onap.core.SelfRegistrationManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.util.TestUtil;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+import java.util.UUID;
+
+import static com.nokia.cbam.lcn.v32.model.OperationType.*;
+import static junit.framework.TestCase.*;
+import static org.mockito.Matchers.any;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCN_API_VERSION;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestSelfRegistrationManager extends TestBase {
+ @Mock
+ private JobManager jobManager;
+ private List<Subscription> subscriptions = new ArrayList<>();
+ private ArgumentCaptor<MicroServiceInfo> registeredMicroservice = ArgumentCaptor.forClass(MicroServiceInfo.class);
+ private ArgumentCaptor<CreateSubscriptionRequest> subscriptionToCreate = ArgumentCaptor.forClass(CreateSubscriptionRequest.class);
+ @InjectMocks
+ private SelfRegistrationManager selfRegistrationManager;
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(SelfRegistrationManager.class, "logger", logger);
+ when(lcnApi.subscriptionsGet(NOKIA_LCN_API_VERSION)).thenReturn(subscriptions);
+ when(driverProperties.getVnfmId()).thenReturn(VNFM_ID);
+ setField(selfRegistrationManager, "driverMsbExternalIp", "1.2.3.4");
+ setField(selfRegistrationManager, "driverVnfmExternalIp", "5.6.7.8");
+ setField(selfRegistrationManager, "driverPort", "12345");
+ Subscription unknownSubscription = new Subscription();
+ unknownSubscription.setId(UUID.randomUUID().toString());
+ unknownSubscription.setCallbackUrl("unknown");
+ subscriptions.add(unknownSubscription);
+ }
+
+ /**
+ * test the basic registration process
+ * - first subscribe to CBAM LCNs
+ * - second publish it's existence on MSB
+ */
+ @Test
+ public void testRegistration() throws Exception {
+ //given
+ Subscription subscription = new Subscription();
+ when(lcnApi.subscriptionsPost(subscriptionToCreate.capture(), Mockito.eq(NOKIA_LCN_API_VERSION))).thenReturn(subscription);
+ MicroServiceFullInfo returnedMicroService = new MicroServiceFullInfo();
+ when(msbClient.registerMicroServiceInfo(registeredMicroservice.capture())).thenReturn(returnedMicroService);
+ //when
+ selfRegistrationManager.register();
+ //verify
+ InOrder registrationOrder = Mockito.inOrder(lcnApi, msbClient);
+ registrationOrder.verify(lcnApi).subscriptionsPost(any(), any());
+ registrationOrder.verify(msbClient).registerMicroServiceInfo(any());
+
+ assertMicroserviceRegistered();
+ assertNewLcnSubscription();
+ assertServiceUp();
+ }
+
+ private void assertNewLcnSubscription() {
+ CreateSubscriptionRequest subscriptionCreation = subscriptionToCreate.getValue();
+ assertEquals("http://5.6.7.8:12345/api/NokiaSVNFM/v1/lcn", subscriptionCreation.getCallbackUrl());
+ assertEquals(SubscriptionAuthentication.TypeEnum.NONE, subscriptionCreation.getAuthentication().getType());
+ assertNull(subscriptionCreation.getAuthentication().getUserName());
+ assertNull(subscriptionCreation.getAuthentication().getClientName());
+ assertNull(subscriptionCreation.getAuthentication().getClientPassword());
+ assertNull(subscriptionCreation.getAuthentication().getPassword());
+ assertNull(subscriptionCreation.getAuthentication().getTokenUrl());
+ assertNull(subscriptionCreation.getFilter().getVnfdId());
+ assertNull(subscriptionCreation.getFilter().getVnfInstanceId());
+ assertNull(subscriptionCreation.getFilter().getVnfProductName());
+ assertNull(subscriptionCreation.getFilter().getVnfSoftwareVersion());
+ assertEquals(Lists.newArrayList(VnfNotificationType.VNFLIFECYCLECHANGENOTIFICATION), subscriptionCreation.getFilter().getNotificationTypes());
+ assertTrue(subscriptionCreation.getFilter().getOperationTypes().contains(HEAL));
+ assertTrue(subscriptionCreation.getFilter().getOperationTypes().contains(SCALE));
+ assertTrue(subscriptionCreation.getFilter().getOperationTypes().contains(TERMINATE));
+ assertTrue(subscriptionCreation.getFilter().getOperationTypes().contains(INSTANTIATE));
+ assertEquals(4, subscriptionCreation.getFilter().getOperationTypes().size());
+ }
+
+ private void assertMicroserviceRegistered() {
+ MicroServiceInfo microserviceRequest = registeredMicroservice.getValue();
+ assertEquals(1, microserviceRequest.getNodes().size());
+ Node node = microserviceRequest.getNodes().iterator().next();
+ assertEquals("0", node.getTtl());
+ assertEquals("1.2.3.4", node.getIp());
+ assertEquals("12345", node.getPort());
+ assertEquals("REST", microserviceRequest.getProtocol());
+ assertNull(microserviceRequest.getMetadata());
+ //very strange, but it should be null for ONAP to work
+ assertEquals("", microserviceRequest.getPath());
+ assertEquals(SelfRegistrationManager.SERVICE_NAME, microserviceRequest.getServiceName());
+ assertEquals("/api/NokiaSVNFM/v1", microserviceRequest.getUrl());
+ assertEquals("v1", microserviceRequest.getVersion());
+ //1 means internal service to ONAP
+ assertEquals("1", microserviceRequest.getVisualRange());
+ }
+
+ /**
+ * If the subscription already exists the subscription is not recreated
+ */
+ @Test
+ public void testResubscription() throws Exception {
+ //given
+ MicroServiceFullInfo returnedMicroService = new MicroServiceFullInfo();
+ when(msbClient.registerMicroServiceInfo(registeredMicroservice.capture())).thenReturn(returnedMicroService);
+ Subscription existingSubscription = new Subscription();
+ existingSubscription.setId(UUID.randomUUID().toString());
+ existingSubscription.setCallbackUrl("http://5.6.7.8:12345/api/NokiaSVNFM/v1/lcn");
+ subscriptions.add(existingSubscription);
+ //when
+ selfRegistrationManager.register();
+ //verify
+ assertMicroserviceRegistered();
+ verify(lcnApi, never()).subscriptionsPost(any(), any());
+ assertServiceUp();
+ }
+
+ /**
+ * If the LCN subscription fails the microservice is not registered
+ */
+ @Test
+ public void testFailedLcnSubscription() throws Exception {
+ //given
+ ApiException expectedException = new ApiException();
+ when(lcnApi.subscriptionsPost(any(), any())).thenThrow(expectedException);
+ //when
+ try {
+ selfRegistrationManager.register();
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals(expectedException, e.getCause());
+ }
+ //verify
+ verify(msbClient, never()).registerMicroServiceInfo(any());
+ verify(logger).error("Unable to subscribe to CBAM LCN", expectedException);
+ assertServiceDown();
+ }
+
+ /**
+ * If the registration to MSB fails the subscription is deleted
+ */
+ @Test
+ public void testFailedMsbPublish() throws Exception {
+ //given
+ Subscription subscription = new Subscription();
+ when(lcnApi.subscriptionsPost(subscriptionToCreate.capture(), Mockito.eq(NOKIA_LCN_API_VERSION))).thenAnswer(new Answer<Subscription>() {
+ @Override
+ public Subscription answer(InvocationOnMock invocationOnMock) throws Throwable {
+ subscription.setCallbackUrl("http://5.6.7.8:12345/api/NokiaSVNFM/v1/lcn");
+ subscription.setId(UUID.randomUUID().toString());
+ subscriptions.add(subscription);
+ return subscription;
+ }
+ });
+ MicroServiceFullInfo returnedMicroService = new MicroServiceFullInfo();
+ RouteException expectedException = new RouteException();
+ when(msbClient.registerMicroServiceInfo(registeredMicroservice.capture())).thenThrow(expectedException);
+ //when
+ try {
+ selfRegistrationManager.register();
+ //verify
+ fail();
+ } catch (RuntimeException e) {
+ assertEquals(expectedException, e.getCause());
+ }
+ assertNewLcnSubscription();
+ verify(lcnApi).subscriptionsSubscriptionIdDelete(subscription.getId(), NOKIA_LCN_API_VERSION);
+ assertServiceDown();
+ }
+
+ /**
+ * basic service unregistration
+ * - ongoing jobs are outwaited
+ * - first the service is removed from MSB
+ * - second unregistration
+ */
+ @Test
+ public void testUnregistration() throws Exception {
+ //given
+ Subscription subscription = new Subscription();
+ subscription.setCallbackUrl("http://5.6.7.8:12345/api/NokiaSVNFM/v1/lcn");
+ subscription.setId(UUID.randomUUID().toString());
+ subscriptions.add(subscription);
+ when(jobManager.hasOngoingJobs()).thenReturn(false);
+ MicroServiceFullInfo returnedMicroService = new MicroServiceFullInfo();
+ //when
+ selfRegistrationManager.deRegister();
+ //verify
+ InOrder inOrder = Mockito.inOrder(jobManager, msbClient, lcnApi);
+ inOrder.verify(msbClient).cancelMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION);
+ inOrder.verify(lcnApi).subscriptionsSubscriptionIdDelete(subscription.getId(), NOKIA_LCN_API_VERSION);
+ assertServiceDown();
+ }
+
+ /**
+ * if the MSB reports that it could not cancel the service, but the service has
+ * disappeared from MSB the cancellation is considered to be successful
+ */
+ @Test
+ public void testPartiallyFailedMsbCancel() throws Exception {
+ //given
+ Subscription subscription = new Subscription();
+ subscription.setCallbackUrl("http://5.6.7.8:12345/api/NokiaSVNFM/v1/lcn");
+ subscription.setId(UUID.randomUUID().toString());
+ subscriptions.add(subscription);
+ when(jobManager.hasOngoingJobs()).thenReturn(false);
+ when(msbClient.cancelMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION)).then(new Answer<RouteResult>() {
+ @Override
+ public RouteResult answer(InvocationOnMock invocationOnMock) throws Throwable {
+ when(msbClient.queryMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION)).thenThrow(new RouteException());
+ throw new RouteException();
+ }
+ });
+ MicroServiceFullInfo returnedMicroService = new MicroServiceFullInfo();
+ //when
+ selfRegistrationManager.deRegister();
+ //verify
+ InOrder inOrder = Mockito.inOrder(jobManager, msbClient, lcnApi);
+ inOrder.verify(msbClient).cancelMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION);
+ inOrder.verify(msbClient).queryMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION);
+ inOrder.verify(lcnApi).subscriptionsSubscriptionIdDelete(subscription.getId(), NOKIA_LCN_API_VERSION);
+ assertServiceDown();
+ }
+
+ /**
+ * failure of unregistration from MSB should be propagated
+ */
+ @Test
+ public void testUnregistrationFailure() throws Exception {
+ //given
+ Subscription subscription = new Subscription();
+ subscription.setCallbackUrl("http://5.6.7.8:12345/api/NokiaSVNFM/v1/lcn");
+ subscription.setId(UUID.randomUUID().toString());
+ subscriptions.add(subscription);
+ when(msbClient.cancelMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION)).then(new Answer<RouteResult>() {
+ @Override
+ public RouteResult answer(InvocationOnMock invocationOnMock) throws Throwable {
+ throw new RouteException();
+ }
+ });
+ MicroServiceFullInfo returnedMicroService = new MicroServiceFullInfo();
+ //when
+ try {
+ selfRegistrationManager.deRegister();
+ fail();
+ } catch (RuntimeException e) {
+
+ }
+ //verify
+ InOrder inOrder = Mockito.inOrder(jobManager, msbClient, lcnApi);
+ inOrder.verify(msbClient).cancelMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION);
+ inOrder.verify(msbClient).queryMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION);
+ verify(lcnApi, Mockito.never()).subscriptionsSubscriptionIdDelete(subscription.getId(), NOKIA_LCN_API_VERSION);
+ assertServiceDown();
+ }
+
+ /**
+ * failure of subscription deletion from MSB should be propagated
+ */
+ @Test
+ public void testSubscriptionFailure() throws Exception {
+ //given
+ Subscription subscription = new Subscription();
+ subscription.setCallbackUrl("http://5.6.7.8:12345/api/NokiaSVNFM/v1/lcn");
+ subscription.setId(UUID.randomUUID().toString());
+ subscriptions.add(subscription);
+ when(jobManager.hasOngoingJobs()).thenReturn(false);
+ ApiException expectedException = new ApiException();
+ doThrow(expectedException).when(lcnApi).subscriptionsSubscriptionIdDelete(subscription.getId(), NOKIA_LCN_API_VERSION);
+ //when
+ try {
+ selfRegistrationManager.deRegister();
+ fail();
+ } catch (RuntimeException e) {
+
+ }
+ //verify
+ InOrder inOrder = Mockito.inOrder(jobManager, msbClient, lcnApi);
+ inOrder.verify(msbClient).cancelMicroServiceInfo(SelfRegistrationManager.SERVICE_NAME, SelfRegistrationManager.DRIVER_VERSION);
+ inOrder.verify(lcnApi).subscriptionsSubscriptionIdDelete(subscription.getId(), NOKIA_LCN_API_VERSION);
+ assertServiceDown();
+ }
+
+ /**
+ * the swagger API definitions embedded in the code
+ */
+ @Test
+ public void testSwaggerApi() throws Exception {
+ //no idea how to test this except repeat implementation
+ byte[] a = TestUtil.loadFile(SelfRegistrationManager.SWAGGER_API_DEFINITION);
+ tearGeneric();
+ //when
+ assertTrue(Arrays.equals(a, selfRegistrationManager.getSwaggerApiDefinition()));
+ }
+
+ public void assertServiceUp() throws Exception {
+ assertTrue(selfRegistrationManager.isReady());
+ }
+
+ /**
+ * if there are ongoing jobs then the guard thros exception
+ */
+ public void assertServiceDown() {
+ assertFalse(selfRegistrationManager.isReady());
+
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestLifecycleChangeNotificationManager.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestLifecycleChangeNotificationManager.java
new file mode 100644
index 00000000..7121bea6
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestLifecycleChangeNotificationManager.java
@@ -0,0 +1,567 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import com.google.gson.*;
+import com.nokia.cbam.lcm.v32.ApiException;
+import com.nokia.cbam.lcm.v32.model.*;
+import org.joda.time.DateTime;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.ArgumentCaptor;
+import org.mockito.InjectMocks;
+import org.mockito.Mockito;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.LifecycleManager;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+import org.threeten.bp.OffsetDateTime;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.NoSuchElementException;
+import java.util.Optional;
+import java.util.concurrent.*;
+
+import static com.nokia.cbam.lcm.v32.model.OperationType.*;
+import static junit.framework.TestCase.*;
+import static org.mockito.Mockito.*;
+import static org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.CbamRestApiProvider.NOKIA_LCM_API_VERSION;
+import static org.springframework.test.util.ReflectionTestUtils.setField;
+
+public class TestLifecycleChangeNotificationManager extends TestBase {
+
+ public static final String OPERATION_EXECUTION_ID = "myOperationExecutionId";
+
+ @InjectMocks
+ private LifecycleChangeNotificationManager lifecycleChangeNotificationManager;
+ private VnfLifecycleChangeNotification recievedLcn = new VnfLifecycleChangeNotification();
+ private List<OperationExecution> operationExecutions = new ArrayList<>();
+ private OperationExecution instantiationOperation = new OperationExecution();
+ private OperationExecution scaleOperation = new OperationExecution();
+ private OperationExecution healOperation = new OperationExecution();
+ private OperationExecution terminationOperation = new OperationExecution();
+
+ private ArgumentCaptor<OperationExecution> currentOperationExecution = ArgumentCaptor.forClass(OperationExecution.class);
+ private ArgumentCaptor<Optional> affectedConnectionPoints = ArgumentCaptor.forClass(Optional.class);
+
+ private List<VnfInfo> vnfs = new ArrayList<>();
+ private VnfInfo vnf = new VnfInfo();
+
+ @Before
+ public void initMocks() throws Exception {
+ setField(LifecycleChangeNotificationManager.class, "logger", logger);
+ instantiationOperation.setId("instantiationOperationExecutionId");
+ instantiationOperation.setStartTime(OffsetDateTime.now());
+ instantiationOperation.setOperationType(OperationType.INSTANTIATE);
+ scaleOperation.setId("scaleOperationExecutionId");
+ scaleOperation.setStartTime(OffsetDateTime.now().plusDays(1));
+ scaleOperation.setOperationType(OperationType.SCALE);
+ terminationOperation.setId("terminationExecutionId");
+ terminationOperation.setStartTime(OffsetDateTime.now().plusDays(1));
+ terminationOperation.setOperationType(OperationType.TERMINATE);
+ healOperation.setId("healOperaitonExecutionId");
+ healOperation.setOperationType(OperationType.HEAL);
+ recievedLcn.setLifecycleOperationOccurrenceId("instantiationOperationExecutionId");
+ healOperation.setStartTime(OffsetDateTime.now().plusDays(1));
+ recievedLcn.setVnfInstanceId(VNF_ID);
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(operationExecutions);
+ prepOperation(instantiationOperation);
+ prepOperation(scaleOperation);
+ prepOperation(healOperation);
+ prepOperation(terminationOperation);
+ doNothing().when(notificationSender).processNotification(eq(recievedLcn), currentOperationExecution.capture(), affectedConnectionPoints.capture(), eq(VIM_ID));
+ InstantiateVnfRequest instantiateVnfRequest = new InstantiateVnfRequest();
+ VimInfo vimInfo = new VimInfo();
+ vimInfo.setId(VIM_ID);
+ instantiateVnfRequest.getVims().add(vimInfo);
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperation.getId(), NOKIA_LCM_API_VERSION)).thenReturn(new Gson().toJsonTree(instantiateVnfRequest));
+ when(vnfApi.vnfsGet(NOKIA_LCM_API_VERSION)).thenReturn(vnfs);
+ vnfs.add(vnf);
+ vnf.setId(VNF_ID);
+ VnfProperty prop = new VnfProperty();
+ prop.setName(LifecycleManager.EXTERNAL_VNFM_ID);
+ prop.setValue(VNFM_ID);
+ vnf.setExtensions(new ArrayList<>());
+ vnf.getExtensions().add(prop);
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenReturn(vnf);
+ }
+
+ private void prepOperation(OperationExecution operationExecution) throws ApiException {
+ addEmptyModifiedConnectionPoints(operationExecution);
+ JsonElement root = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + JOB_ID + "\"}}");
+ operationExecution.setOperationParams(root);
+ switch (operationExecution.getOperationType()) {
+ case TERMINATE:
+ root.getAsJsonObject().addProperty("terminationType", "GRACEFULL");
+ }
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdGet(operationExecution.getId(), NOKIA_LCM_API_VERSION)).thenReturn(operationExecution);
+ operationExecutions.add(operationExecution);
+ }
+
+ private void addEmptyModifiedConnectionPoints(OperationExecution operationExecution) {
+ OperationResult operationResult = new OperationResult();
+ operationResult.operationResult = new ReportedAffectedConnectionPoints();
+ JsonElement additionalData = new Gson().toJsonTree(operationResult);
+ operationExecution.setAdditionalData(additionalData);
+ }
+
+ /**
+ * The first instantiation before the current operation is selected
+ */
+ @Test
+ public void testLastInstantiationSelection() {
+ List<OperationExecution> operations = new ArrayList<>();
+
+ OperationExecution operation = buildOperation(OffsetDateTime.now(), TERMINATE);
+ OperationExecution operationScale = buildOperation(OffsetDateTime.now().minusDays(1), SCALE);
+ OperationExecution operationClosestInstantiate = buildOperation(OffsetDateTime.now().minusDays(2), INSTANTIATE);
+ OperationExecution operationFurthers = buildOperation(OffsetDateTime.now().minusDays(3), INSTANTIATE);
+
+ operations.add(operation);
+ operations.add(operationScale);
+ operations.add(operationClosestInstantiate);
+ operations.add(operationFurthers);
+ assertEquals(operationClosestInstantiate, LifecycleChangeNotificationManager.findLastInstantiationBefore(operations, operation));
+ }
+
+ /**
+ * The instantiation operation itself is valid as the last instantiation operation
+ */
+ @Test
+ public void testInstantiationSufficesTheLastInstantiation() {
+ DateTime baseTime = DateTime.now();
+ List<OperationExecution> operations = new ArrayList<>();
+
+ OperationExecution operation = buildOperation(OffsetDateTime.now(), INSTANTIATE);
+ OperationExecution operationScale = buildOperation(OffsetDateTime.now().minusDays(1), SCALE);
+ OperationExecution operationFurthers = buildOperation(OffsetDateTime.now().minusDays(2), INSTANTIATE);
+
+ operations.add(operation);
+ operations.add(operationScale);
+ operations.add(operationFurthers);
+ assertEquals(operation, LifecycleChangeNotificationManager.findLastInstantiationBefore(operations, operation));
+ }
+
+ /**
+ * If no instantiation operation is found for before the selected operation
+ */
+ @Test
+ public void testNoInstantiation() {
+ DateTime baseTime = DateTime.now();
+ List<OperationExecution> operations = new ArrayList<>();
+
+ OperationExecution operation = buildOperation(OffsetDateTime.now(), TERMINATE);
+ OperationExecution operationScale = buildOperation(OffsetDateTime.now().minusDays(1), SCALE);
+
+ operations.add(operation);
+ operations.add(operationScale);
+ try {
+ LifecycleChangeNotificationManager.findLastInstantiationBefore(operations, operation);
+ fail();
+ } catch (NoSuchElementException e) {
+
+ }
+ }
+
+ /**
+ * the operations are ordered from newest (first) to oldest (last)
+ */
+ @Test
+ public void testOperationOrdering() {
+ List<OperationExecution> operationExecutions = new ArrayList<>();
+ OperationExecution before = buildOperation(OffsetDateTime.now(), OperationType.INSTANTIATE);
+ operationExecutions.add(before);
+ OperationExecution after = buildOperation(OffsetDateTime.now().plusDays(1), OperationType.SCALE);
+ operationExecutions.add(after);
+ List<OperationExecution> sorted1 = LifecycleChangeNotificationManager.NEWEST_OPERATIONS_FIRST.sortedCopy(operationExecutions);
+ assertEquals(after, sorted1.get(0));
+ assertEquals(before, sorted1.get(1));
+ }
+
+ /**
+ * if VNF listing fails the processing of the notifications is aborted
+ */
+ @Test
+ public void testUnableToListVnfs() throws Exception {
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsGet(NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ try {
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ fail();
+ } catch (Exception e) {
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to list VNFs / query VNF", expectedException);
+ }
+ }
+
+ /**
+ * if VNF query fails the processing of the notifications is aborted
+ */
+ @Test
+ public void testUnableToQueryVnf() throws Exception {
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsVnfInstanceIdGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ try {
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ fail();
+ } catch (Exception e) {
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to list VNFs / query VNF", expectedException);
+ }
+ }
+
+ /**
+ * if the VNF is not managed by this VNFM the LCN is dropped
+ */
+ @Test
+ public void testNonManagedVnf() throws Exception {
+ vnf.getExtensions().clear();
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ Mockito.verifyZeroInteractions(operationExecutionApi);
+ verify(logger).warn("The VNF with " + VNF_ID + " identifier is not a managed VNF");
+ }
+
+ /**
+ * LCN is not logged in case of non info log level
+ */
+ @Test
+ public void testNoLogging() throws Exception {
+ vnf.getExtensions().clear();
+ when(logger.isInfoEnabled()).thenReturn(false);
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ verify(logger, never()).info(eq("Received LCN: {}"), anyString());
+ }
+
+ /**
+ * if the VNF is not managed by this VNFM the LCN is dropped
+ */
+ @Test
+ public void testManagedByOtherVnf() throws Exception {
+ vnf.getExtensions().get(0).setValue("unknownVnfmId");
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ Mockito.verifyZeroInteractions(operationExecutionApi);
+ verify(logger).warn("The VNF with " + VNF_ID + " identifier is not a managed by the VNFM with id unknownVnfmId");
+ }
+
+ /**
+ * if the VNF disappeared before processing the LCN
+ */
+ @Test
+ public void testDisappearedVnf() throws Exception {
+ vnfs.clear();
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ Mockito.verifyZeroInteractions(operationExecutionApi);
+ verify(logger).warn("The VNF with " + VNF_ID + " identifier disappeared before being able to process the LCN");
+ }
+
+ /**
+ * if the operation parameters of the last instantiation is non querieable error is propagated
+ */
+ @Test
+ public void testUnableToQueryOperationParams() throws Exception {
+ recievedLcn.setOperation(OperationType.TERMINATE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ RuntimeException expectedException = new RuntimeException();
+ when(operationExecutionApi.operationExecutionsOperationExecutionIdOperationParamsGet(instantiationOperation.getId(), NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ try {
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ fail();
+ } catch (Exception e) {
+ //verify
+ Mockito.verifyZeroInteractions(nsLcmApi);
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to detect last instantiation operation", e.getCause());
+ }
+ }
+
+ /**
+ * if unable to send LCN to VF-C the error is propagated
+ */
+ @Test
+ public void testUnableToQueryCurrentOperation() throws Exception {
+ recievedLcn.setOperation(OperationType.TERMINATE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ ApiException expectedException = new ApiException();
+ when(vnfApi.vnfsVnfInstanceIdOperationExecutionsGet(VNF_ID, NOKIA_LCM_API_VERSION)).thenThrow(expectedException);
+ //when
+ try {
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ fail();
+ } catch (Exception e) {
+ //verify
+ assertEquals(expectedException, e.getCause());
+ verify(logger).error("Unable to retrieve the current VNF myVnfId", e.getCause());
+ }
+ }
+
+ /**
+ * test that waitForTerminationToBeProcessed outwaits the successfull processing of the termination notification
+ */
+ @Test
+ public void testWaitForTermination() throws Exception {
+ //given
+ //add an non processed notification
+ VnfLifecycleChangeNotification nonProcessedEvent = new VnfLifecycleChangeNotification();
+ nonProcessedEvent.setStatus(OperationStatus.FINISHED);
+ nonProcessedEvent.setOperation(OperationType.TERMINATE);
+ OperationExecution secondTerminationOperationExecution = new OperationExecution();
+ secondTerminationOperationExecution.setOperationType(OperationType.TERMINATE);
+ secondTerminationOperationExecution.setId("secondId");
+ secondTerminationOperationExecution.setOperationParams(buildTerminationParams());
+ nonProcessedEvent.setLifecycleOperationOccurrenceId(secondTerminationOperationExecution.getId());
+ lifecycleChangeNotificationManager.handleLcn(nonProcessedEvent);
+ //add second termination
+ recievedLcn.setOperation(OperationType.TERMINATE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ recievedLcn.setLifecycleOperationOccurrenceId(terminationOperation.getId());
+ ExecutorService executorService = Executors.newCachedThreadPool();
+ Future<Boolean> waitExitedWithSuccess = executorService.submit(new Callable<Boolean>() {
+ @Override
+ public Boolean call() throws Exception {
+ try {
+ lifecycleChangeNotificationManager.waitForTerminationToBeProcessed(terminationOperation.getId());
+ return true;
+ } catch (Exception e) {
+ return false;
+ }
+ }
+ });
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ assertTrue(waitExitedWithSuccess.get());
+ }
+
+ /**
+ * the processing of the start notification does not trigger the deletion of the VNF
+ */
+ @Test
+ public void testStartLcnForTerminate() throws Exception {
+ recievedLcn.setOperation(OperationType.TERMINATE);
+ recievedLcn.setStatus(OperationStatus.STARTED);
+ recievedLcn.setLifecycleOperationOccurrenceId(terminationOperation.getId());
+ ExecutorService executorService = Executors.newCachedThreadPool();
+ Future<Boolean> waitExitedWithSuccess = executorService.submit(() -> {
+ try {
+ lifecycleChangeNotificationManager.waitForTerminationToBeProcessed(terminationOperation.getId());
+ return true;
+ } catch (Exception e) {
+ return false;
+ }
+ });
+ //processing the start notification
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ try {
+ waitExitedWithSuccess.get(10, TimeUnit.MILLISECONDS);
+ fail();
+ } catch (Exception e) {
+ }
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ assertTrue(waitExitedWithSuccess.get());
+ }
+
+ /**
+ * Forceful termination results in an empty affected connection points
+ */
+ @Test
+ public void testMissingPreResultForForcefullTermination() {
+ //given
+ recievedLcn.setOperation(OperationType.INSTANTIATE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ recievedLcn.setLifecycleOperationOccurrenceId(terminationOperation.getId());
+ JsonObject additionalData = new JsonObject();
+ additionalData.add("operationResult", new JsonObject());
+ ((JsonObject) terminationOperation.getOperationParams()).addProperty("terminationType", "FORCEFUL");
+ terminationOperation.setAdditionalData(additionalData);
+ terminationOperation.setStatus(OperationStatus.FINISHED);
+ terminationOperation.setOperationType(OperationType.TERMINATE);
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ assertFalse(affectedConnectionPoints.getValue().isPresent());
+ verify(logger).warn("Unable to send information related to affected connection points during forceful termination");
+ }
+
+ /**
+ * Failures in affected connection point processing are tolerated for failed operation
+ * (because the POST script was not able to run)
+ */
+ @Test
+ public void testFailedOperations() throws Exception {
+ //given
+ recievedLcn.setOperation(OperationType.INSTANTIATE);
+ recievedLcn.setStatus(OperationStatus.FAILED);
+ recievedLcn.setLifecycleOperationOccurrenceId(instantiationOperation.getId());
+ instantiationOperation.setAdditionalData(null);
+ instantiationOperation.setStatus(OperationStatus.FAILED);
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ assertFalse(affectedConnectionPoints.getValue().isPresent());
+ verify(logger).warn("The operation failed and the affected connection points were not reported");
+ }
+
+ /**
+ * Failures in affected connection point processing are tolerated for failed operation
+ * (because the POST script was not able to run)
+ */
+ @Test
+ public void testMissingOperationResult() throws Exception {
+ //given
+ recievedLcn.setOperation(OperationType.INSTANTIATE);
+ recievedLcn.setStatus(OperationStatus.FAILED);
+ recievedLcn.setLifecycleOperationOccurrenceId(instantiationOperation.getId());
+ instantiationOperation.setStatus(OperationStatus.FAILED);
+ JsonObject additionalData = (JsonObject) instantiationOperation.getAdditionalData();
+ additionalData.remove("operationResult");
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ //verify
+ assertFalse(affectedConnectionPoints.getValue().isPresent());
+ verify(logger).warn("The operation failed and the affected connection points were not reported");
+ }
+
+ /**
+ * test end notification scenario for failed scale-out
+ * - LCN is sent to VF-C, but the
+ */
+ @Test
+ public void testMissingPreResultForFailedOperation() {
+ //given
+ recievedLcn.setOperation(OperationType.SCALE);
+ recievedLcn.setStatus(OperationStatus.FAILED);
+ recievedLcn.setLifecycleOperationOccurrenceId(scaleOperation.getId());
+ ScaleVnfRequest request = new ScaleVnfRequest();
+ request.setAdditionalParams(new JsonParser().parse("{ \"type\" : \"IN\", \"jobId\" : \"" + JOB_ID + "\" }"));
+ request.setType(ScaleDirection.OUT);
+ scaleOperation.setOperationParams(request);
+ scaleOperation.setAdditionalData(null);
+ scaleOperation.setStatus(OperationStatus.FAILED);
+ scaleOperation.setOperationType(OperationType.SCALE);
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ assertFalse(affectedConnectionPoints.getValue().isPresent());
+ verify(logger).warn("The operation failed and the affected connection points were not reported");
+ }
+
+ /**
+ * if the cbam_post is missing error handling should be applied
+ */
+ @Test
+ public void testMissingPostResultForFailedOperation() {
+ //given
+ recievedLcn.setOperation(OperationType.SCALE);
+ recievedLcn.setStatus(OperationStatus.FAILED);
+ recievedLcn.setLifecycleOperationOccurrenceId(scaleOperation.getId());
+ ScaleVnfRequest request = new ScaleVnfRequest();
+ request.setAdditionalParams(new JsonParser().parse("{ \"type\" : \"IN\", \"jobId\" : \"" + JOB_ID + "\" }"));
+ request.setType(ScaleDirection.OUT);
+ scaleOperation.setOperationParams(request);
+ scaleOperation.setStatus(OperationStatus.FAILED);
+ ((JsonObject) scaleOperation.getAdditionalData()).get("operationResult").getAsJsonObject().remove("cbam_post");
+ scaleOperation.setOperationType(OperationType.SCALE);
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ assertFalse(affectedConnectionPoints.getValue().isPresent());
+ verify(logger).warn("The operation failed and the affected connection points were not reported");
+ }
+
+ /**
+ * if invalid type is specified for cbam_post error handling should be applied
+ */
+ @Test
+ public void testInvalidPost() {
+ //given
+ recievedLcn.setOperation(OperationType.SCALE);
+ recievedLcn.setStatus(OperationStatus.FAILED);
+ recievedLcn.setLifecycleOperationOccurrenceId(scaleOperation.getId());
+ ScaleVnfRequest request = new ScaleVnfRequest();
+ request.setAdditionalParams(new JsonParser().parse("{ \"type\" : \"IN\", \"jobId\" : \"" + JOB_ID + "\" }"));
+ request.setType(ScaleDirection.OUT);
+ scaleOperation.setOperationParams(request);
+ scaleOperation.setStatus(OperationStatus.FAILED);
+ JsonObject operationResult = ((JsonObject) scaleOperation.getAdditionalData()).get("operationResult").getAsJsonObject();
+ operationResult.remove("cbam_post");
+ operationResult.addProperty("cbam_post", "");
+ scaleOperation.setOperationType(OperationType.SCALE);
+ //when
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ assertFalse(affectedConnectionPoints.getValue().isPresent());
+ verify(logger).warn("The operation failed and the affected connection points were not reported");
+ }
+
+
+ /**
+ * test end notification success scenario for scale-out
+ * - LCN is sent to VF-C
+ */
+ @Test
+ public void testMissingPreResult() {
+ //given
+ recievedLcn.setOperation(OperationType.SCALE);
+ recievedLcn.setStatus(OperationStatus.FINISHED);
+ recievedLcn.setLifecycleOperationOccurrenceId(scaleOperation.getId());
+ ScaleVnfRequest request = new ScaleVnfRequest();
+ request.setAdditionalParams(new JsonParser().parse("{ \"type\" : \"IN\", \"jobId\" : \"" + JOB_ID + "\" }"));
+ request.setType(ScaleDirection.OUT);
+ scaleOperation.setOperationParams(request);
+ JsonObject additionalData = new JsonObject();
+ additionalData.add("operationResult", new JsonObject());
+ scaleOperation.setAdditionalData(additionalData);
+ scaleOperation.setStatus(OperationStatus.FINISHED);
+ scaleOperation.setOperationType(OperationType.SCALE);
+ JsonElement root = new JsonParser().parse("{ \"additionalParams\" : { \"jobId\" : \"" + JOB_ID + "\"}}");
+ JsonObject operationParams = new JsonObject();
+ //when
+ try {
+ lifecycleChangeNotificationManager.handleLcn(recievedLcn);
+ fail();
+ } catch (Exception e) {
+ assertEquals("All operations must return the { \"operationResult\" : { \"cbam_pre\" : [<fillMeOut>], \"cbam_post\" : [<fillMeOut>] } } structure", e.getMessage());
+ }
+ }
+
+ private JsonObject buildTerminationParams() {
+ JsonObject root = new JsonObject();
+ root.add("terminationType", new JsonPrimitive("GRACEFULL"));
+ return root;
+ }
+
+ private OperationExecution buildOperation(OffsetDateTime baseTime, OperationType operationType) {
+ OperationExecution operation = new OperationExecution();
+ operation.setStartTime(baseTime);
+ operation.setOperationType(operationType);
+ return operation;
+ }
+
+ class OperationResult {
+ ReportedAffectedConnectionPoints operationResult;
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestProcessedNotification.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestProcessedNotification.java
new file mode 100644
index 00000000..bbe660a0
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestProcessedNotification.java
@@ -0,0 +1,28 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import static pl.pojo.tester.api.assertion.Assertions.assertPojoMethodsFor;
+
+public class TestProcessedNotification extends TestBase {
+ @Test
+ public void testPojo() {
+ assertPojoMethodsFor(ProcessedNotification.class).areWellImplemented();
+ }
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedConnectionPoints.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedConnectionPoints.java
new file mode 100644
index 00000000..83699723
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedConnectionPoints.java
@@ -0,0 +1,30 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import static pl.pojo.tester.api.assertion.Assertions.assertPojoMethodsFor;
+
+public class TestReportedAffectedConnectionPoints extends TestBase {
+ @Test
+ public void testPojo() {
+ assertPojoMethodsFor(ReportedAffectedConnectionPoints.class).areWellImplemented();
+
+ }
+
+}
diff --git a/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedCp.java b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedCp.java
new file mode 100644
index 00000000..cb4d7e1c
--- /dev/null
+++ b/nokiav2/driver/src/test/java/org/onap/vfc/nfvo/driver/vnfm/svnfm/nokia/vnfm/notification/TestReportedAffectedCp.java
@@ -0,0 +1,30 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.notification;
+
+import org.junit.Test;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.vnfm.TestBase;
+
+import static pl.pojo.tester.api.assertion.Assertions.assertPojoMethodsFor;
+
+public class TestReportedAffectedCp extends TestBase {
+ @Test
+ public void testPojo() {
+ assertPojoMethodsFor(ReportedAffectedCp.class).areWellImplemented();
+
+ }
+
+}
diff --git a/nokiav2/driver/src/test/resources/.gitignore b/nokiav2/driver/src/test/resources/.gitignore
new file mode 100644
index 00000000..03941911
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/.gitignore
@@ -0,0 +1 @@
+application-real.properties
diff --git a/nokiav2/driver/src/test/resources/application-direct.properties b/nokiav2/driver/src/test/resources/application-direct.properties
new file mode 100644
index 00000000..f933db94
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/application-direct.properties
@@ -0,0 +1,73 @@
+###############################################################################
+# Copyright 2016, Nokia Corporation
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+###############################################################################
+server.error.whitelabel.enabled=false
+###############################################################################
+# Beginning of mandatory properties #
+###############################################################################
+# The TCP port of the server
+server.port=8089
+# the base path of the server
+server.context-path=
+# the IP address to which the server binds to
+server.address=127.0.0.1
+# the IP address of the server reported to the micro service bus
+driverMsbExternalIp=10.41.63.151
+# the IP address of the server reported to the VNFM
+driverVnfmExternalIp=10.41.63.151
+# the IP address of the message bus
+messageBusIp=msb.api.simpledemo.onap.org
+# the TCP port of the message bus
+messageBusPort=80
+# the URL of the CBAM catalog service
+cbamCatalogUrl=https://10.41.63.149:443/api/catalog/adapter
+# the URL of the CBAM LCN service
+cbamLcnUrl=https://10.41.63.149:443/vnfm/lcn/v3
+# the URL of the CBAM authentication service
+cbamKeyCloakBaseUrl=https://10.41.63.149:443/auth
+# skip hostname verification during SSL on CBAM LCN, LCM and authorization interface
+skipHostnameVerification=true
+# skip certificate verification during SSL on CBAM LCN, LCM and authorization interface
+skipCertificateVerification=true
+# the collection of trusted certificates for SSL on CBAM LCN, LCM and authorization interface
+# in PEM format encoded in BASE64 to a single line
+trustedCertificates=
+# the username to be used for requesting a token on CBAM authorization interface
+cbamUsername=onap
+# the password to be used for requesting a token on CBAM authorization interface
+cbamPassword=Admin@123
+# the identifier of the VNFM in A&AI core system registry
+vnfmId=7c267318-2a6a-4d47-b039-a7cce5fea38b
+aaiUsername=AAI
+aaiPassword=AAI
+sdcUsername=SDC
+sdcPassword=SDC
+
+###############################################################################
+# End of mandatory properties for driver #
+###############################################################################
+ipMap=10.0.14.1->msb.api.simpledemo.onap.org,172.17.0.15->msb.api.simpledemo.onap.org,10.0.1.1->aai.api.simpledemo.onap.org
+vnfmInfoCacheEvictionInMs=600000
+
+## for logging begin ##
+com.fasterxml.jackson.core=jackson-databind
+#logging.file=${catalina.base}/logs/vfcadaptor.log
+logging.level.org.springframework=INFO
+logging.level.org.hibernate=OFF
+logging.level.org.springframework.web=DEBUG
+## for logging end ##
+
+spring.http.multipart.max-file-size=50000KB
+spring.http.multipart.max-request-size=50000KB
diff --git a/nokiav2/driver/src/test/resources/application.properties b/nokiav2/driver/src/test/resources/application.properties
new file mode 100644
index 00000000..f5c42fc0
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/application.properties
@@ -0,0 +1,66 @@
+###############################################################################
+# Copyright 2016, Nokia Corporation
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+###############################################################################
+server.error.whitelabel.enabled=false
+###############################################################################
+# Beginning of mandatory properties #
+###############################################################################
+# The TCP port of the server
+server.port=8089
+# the base path of the server
+server.context-path=
+# the IP address to which the server binds to
+server.address=127.0.0.1
+# the IP address of the server reported to the micro service bus
+driverMsbExternalIp=127.0.0.1
+# the IP address of the server reported to VNFM
+driverVnfmExternalIp=127.0.0.1
+# the IP address of the message bus
+messageBusIp=127.0.0.1
+# the TCP port of the message bus
+messageBusPort=8089
+# the URL of the CBAM catalog service
+cbamCatalogUrl=https://127.0.0.1:443/api/catalog/adapter
+# the URL of the CBAM LCN service
+cbamLcnUrl=https://127.0.0.0.1:443/vnfm/lcn/v3
+# the URL of the CBAM authentication service
+cbamKeyCloakBaseUrl=https://127.0.0.0.1:443/auth
+# skip hostname verification during SSL on CBAM LCN, LCM and authorization interface
+skipHostnameVerification=true
+# skip certificate verification during SSL on CBAM LCN, LCM and authorization interface
+skipCertificateVerification=true
+# the collection of trusted certificates for SSL on CBAM LCN, LCM and authorization interface
+# in PEM format encoded in BASE64 to a single line
+trustedCertificates=
+# the username to be used for requesting a token on CBAM authorization interface
+cbamUsername=onap
+# the password to be used for requesting a token on CBAM authorization interface
+cbamPassword=myPassword
+# the identifier of the VNFM in A&AI core system registry
+vnfmId=53fbba58-464e-4cc4-8d33-aaaf072f0a27
+###############################################################################
+# End of mandatory properties for driver #
+###############################################################################
+
+
+spring.autoconfigure.exclude=org.springframework.boot.autoconfigure.security.oauth2.OAuth2AutoConfiguration,org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration
+vnfmInfoCacheEvictionInMs=600000
+
+## for logging begin ##
+com.fasterxml.jackson.core=jackson-databind
+#logging.file=${catalina.base}/logs/vfcadaptor.log
+logging.level.org.springframework.web=TRACE
+logging.level.org.hibernate=OFF
+## for logging end ##
diff --git a/nokiav2/driver/src/test/resources/test.jks b/nokiav2/driver/src/test/resources/test.jks
new file mode 100644
index 00000000..5506b9a8
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/test.jks
Binary files differ
diff --git a/nokiav2/driver/src/test/resources/unittests/TestCbamCatalogManager.sample.csar b/nokiav2/driver/src/test/resources/unittests/TestCbamCatalogManager.sample.csar
new file mode 100644
index 00000000..1a179166
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/TestCbamCatalogManager.sample.csar
Binary files differ
diff --git a/nokiav2/driver/src/test/resources/unittests/cbam.package.zip b/nokiav2/driver/src/test/resources/unittests/cbam.package.zip
new file mode 100644
index 00000000..d7c6a673
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/cbam.package.zip
Binary files differ
diff --git a/nokiav2/driver/src/test/resources/unittests/empty.zip b/nokiav2/driver/src/test/resources/unittests/empty.zip
new file mode 100644
index 00000000..15cb0ecb
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/empty.zip
Binary files differ
diff --git a/nokiav2/driver/src/test/resources/unittests/lcn.json b/nokiav2/driver/src/test/resources/unittests/lcn.json
new file mode 100644
index 00000000..1ed3f5f4
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/lcn.json
@@ -0,0 +1,9 @@
+{
+ "status": "STARTED",
+ "vnfInstanceId": "CBAM-d59f413228af4a35b00eb168d636f567",
+ "timestamp": "2018-01-02T10:50:54.903260Z",
+ "notificationType": "VnfLifecycleChangeNotification",
+ "lifecycleOperationOccurrenceId": "CBAM-9b7dd0c2591d463b890021c38ead3f24",
+ "subscriptionId": "CBAM-1b89306bcd494879b7cb02369d2b2503",
+ "operation": "TERMINATE"
+} \ No newline at end of file
diff --git a/nokiav2/driver/src/test/resources/unittests/localhost.cert.pem b/nokiav2/driver/src/test/resources/unittests/localhost.cert.pem
new file mode 100644
index 00000000..879a6a5a
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/localhost.cert.pem
@@ -0,0 +1,73 @@
+Certificate:
+ Data:
+ Version: 3 (0x2)
+ Serial Number: 878178886 (0x3457f246)
+ Signature Algorithm: sha256WithRSAEncryption
+ Issuer: C=Unknown, ST=Unknown, L=Unknown, O=Unknown, OU=Unknown, CN=localhost
+ Validity
+ Not Before: Dec 16 01:51:53 2017 GMT
+ Not After : Mar 16 01:51:53 2018 GMT
+ Subject: C=Unknown, ST=Unknown, L=Unknown, O=Unknown, OU=Unknown, CN=localhost
+ Subject Public Key Info:
+ Public Key Algorithm: rsaEncryption
+ Public-Key: (2048 bit)
+ Modulus:
+ 00:85:90:1e:2e:d5:b6:55:c4:56:ac:f7:3d:fb:12:
+ c3:a5:be:30:bb:56:03:e7:b2:cb:0e:e5:27:d2:82:
+ 41:11:09:ff:3b:1c:aa:bc:3d:97:0e:2f:c1:b5:bf:
+ de:ed:fe:36:e9:71:d6:3d:3d:ca:00:b0:3b:69:b0:
+ b8:0a:ef:e3:df:91:2e:8f:f7:92:9d:29:0c:5d:15:
+ ad:47:10:db:34:8c:10:01:ad:68:dc:df:80:d5:42:
+ 1f:55:be:06:7c:b0:c7:0a:04:87:9a:0a:57:ba:67:
+ 43:39:a4:91:09:91:bb:6f:00:dc:ff:ff:4c:53:e0:
+ 38:37:de:50:2f:a7:04:e7:c3:bc:a8:56:cd:d6:a7:
+ 99:51:43:14:00:32:85:46:3d:92:31:f6:5b:de:74:
+ de:11:4f:23:c2:0d:c6:65:0d:1d:d5:66:d8:bb:79:
+ 21:0e:b8:b9:0c:75:6e:7b:35:de:1e:a1:35:00:2e:
+ 74:84:7d:a9:b6:55:f8:58:c4:a9:8e:cf:ae:3e:17:
+ 12:71:05:b8:8a:50:05:7a:e9:55:db:68:26:e9:02:
+ 0c:1d:43:7f:bd:00:ab:4b:6e:cf:3f:1a:68:a8:52:
+ a2:b8:36:19:ca:fb:37:f8:79:54:6a:b4:7b:41:54:
+ af:bc:6a:49:2d:15:6d:14:95:18:b1:37:b2:9a:52:
+ 21:47
+ Exponent: 65537 (0x10001)
+ X509v3 extensions:
+ X509v3 Subject Key Identifier:
+ B4:A1:34:DA:34:7F:52:3E:76:AB:81:A4:5C:7E:10:3E:FD:84:9A:3E
+ Signature Algorithm: sha256WithRSAEncryption
+ 6b:9f:d7:de:1b:38:f0:46:7a:40:df:47:b1:1c:5c:05:2c:9a:
+ 4a:ad:5e:81:84:d1:ac:d4:8d:27:4b:8f:92:2e:02:18:7a:84:
+ 2f:bb:68:f5:ea:2b:ae:cc:3f:21:f7:d0:47:ea:6d:21:73:db:
+ 35:f0:e4:27:ba:95:db:2b:99:93:aa:a1:ab:23:bd:78:4f:7c:
+ e1:63:cb:2b:e8:2c:fb:e1:ad:af:2d:01:1d:67:d8:7c:bb:82:
+ 00:30:1a:de:b2:1c:d3:25:b0:de:b1:b5:3c:dc:42:4b:ae:b9:
+ 1c:e2:f4:dd:45:6c:87:75:d8:9e:bd:1d:27:05:e7:8c:63:ec:
+ de:87:aa:95:d7:65:64:80:42:95:88:14:16:6b:43:22:0f:e7:
+ c0:06:36:0d:93:14:be:d6:22:24:c0:43:c4:fa:83:bd:6c:5b:
+ 24:7f:ac:a5:f5:ea:a7:61:fd:5d:67:e3:9d:d1:59:b5:e6:d6:
+ 9b:20:ca:23:44:44:b7:65:a7:f9:74:34:de:68:87:fd:1c:2f:
+ 32:d7:48:c0:10:ba:7e:83:06:a4:21:05:d5:6b:b0:9e:9c:dc:
+ 12:5a:5a:45:b7:84:94:96:a4:29:e6:05:47:1f:f5:a5:93:db:
+ 21:fc:2e:2a:4d:55:09:54:38:0c:56:ba:59:5b:b2:36:85:c6:
+ 63:78:93:0c
+-----BEGIN CERTIFICATE-----
+MIIDezCCAmOgAwIBAgIENFfyRjANBgkqhkiG9w0BAQsFADBuMRAwDgYDVQQGEwdV
+bmtub3duMRAwDgYDVQQIEwdVbmtub3duMRAwDgYDVQQHEwdVbmtub3duMRAwDgYD
+VQQKEwdVbmtub3duMRAwDgYDVQQLEwdVbmtub3duMRIwEAYDVQQDEwlsb2NhbGhv
+c3QwHhcNMTcxMjE2MDE1MTUzWhcNMTgwMzE2MDE1MTUzWjBuMRAwDgYDVQQGEwdV
+bmtub3duMRAwDgYDVQQIEwdVbmtub3duMRAwDgYDVQQHEwdVbmtub3duMRAwDgYD
+VQQKEwdVbmtub3duMRAwDgYDVQQLEwdVbmtub3duMRIwEAYDVQQDEwlsb2NhbGhv
+c3QwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCFkB4u1bZVxFas9z37
+EsOlvjC7VgPnsssO5SfSgkERCf87HKq8PZcOL8G1v97t/jbpcdY9PcoAsDtpsLgK
+7+PfkS6P95KdKQxdFa1HENs0jBABrWjc34DVQh9VvgZ8sMcKBIeaCle6Z0M5pJEJ
+kbtvANz//0xT4Dg33lAvpwTnw7yoVs3Wp5lRQxQAMoVGPZIx9lvedN4RTyPCDcZl
+DR3VZti7eSEOuLkMdW57Nd4eoTUALnSEfam2VfhYxKmOz64+FxJxBbiKUAV66VXb
+aCbpAgwdQ3+9AKtLbs8/GmioUqK4NhnK+zf4eVRqtHtBVK+8akktFW0UlRixN7Ka
+UiFHAgMBAAGjITAfMB0GA1UdDgQWBBS0oTTaNH9SPnargaRcfhA+/YSaPjANBgkq
+hkiG9w0BAQsFAAOCAQEAa5/X3hs48EZ6QN9HsRxcBSyaSq1egYTRrNSNJ0uPki4C
+GHqEL7to9eorrsw/IffQR+ptIXPbNfDkJ7qV2yuZk6qhqyO9eE984WPLK+gs++Gt
+ry0BHWfYfLuCADAa3rIc0yWw3rG1PNxCS665HOL03UVsh3XYnr0dJwXnjGPs3oeq
+lddlZIBClYgUFmtDIg/nwAY2DZMUvtYiJMBDxPqDvWxbJH+spfXqp2H9XWfjndFZ
+tebWmyDKI0REt2Wn+XQ03miH/RwvMtdIwBC6foMGpCEF1WuwnpzcElpaRbeElJak
+KeYFRx/1pZPbIfwuKk1VCVQ4DFa6WVuyNoXGY3iTDA==
+-----END CERTIFICATE-----
diff --git a/nokiav2/driver/src/test/resources/unittests/localhost.jks b/nokiav2/driver/src/test/resources/unittests/localhost.jks
new file mode 100644
index 00000000..80b72992
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/localhost.jks
Binary files differ
diff --git a/nokiav2/driver/src/test/resources/unittests/maria.vnfd.scalable.tosca.nated.yaml b/nokiav2/driver/src/test/resources/unittests/maria.vnfd.scalable.tosca.nated.yaml
new file mode 100644
index 00000000..76ed67ce
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/maria.vnfd.scalable.tosca.nated.yaml
@@ -0,0 +1,593 @@
+tosca_definitions_version: tosca_simple_profile_for_nfv_1_0_0_nokia
+
+topology_template:
+ substitution_mappings:
+ node_type: tosca.nodes.nfv.VNF
+ properties:
+ descriptor_id: Nokia~Maria DB~1.0~1.0
+ descriptor_version: '1.0'
+ provider: Nokia
+ product_name: Maria DB
+ software_version: '1.0'
+ product_info_name: Maria DB
+ product_info_description: Relational database, non-scalable
+ vnfm_info:
+ - CBAM
+ requirements:
+ - virtual_link: [ dbBackendIpv4, external_virtual_link ] # IPv4 for SQL
+ - virtual_link: [ dbBackendIpv6, external_virtual_link ] # IPv6 for SQL
+ - virtual_link: [ serviceNodeIpv4, external_virtual_link ] # IPv4 for SSH
+ - virtual_link: [ loadBalancer, external_virtual_link ] # IPv4 for SQL (load balanced)
+ capabilities:
+ deployment_flavour:
+ properties:
+ flavour_id: scalable
+ description: ..
+ scaling_aspects:
+ dbBackendAspect:
+ name: ..
+ description: ..
+ associated_group: dbBackendScalingGroup
+ max_scale_level: 8
+ serviceNodeAspect:
+ name: ..
+ description: ..
+ associated_group: serviceNodeScalingGroup
+ max_scale_level: 3
+ instantiation_levels:
+ small:
+ description: ..
+ vdu_levels:
+ dbBackend:
+ number_of_instances: 3
+ serviceNode:
+ number_of_instances: 2
+ scale_info:
+ dbBackendAspect:
+ scale_level: 0
+ serviceNodeAspect:
+ scale_level: 1
+ medium:
+ description: ..
+ vdu_levels:
+ dbBackend:
+ number_of_instances: 4
+ serviceNode:
+ number_of_instances: 2
+ scale_info:
+ dbBackendAspect:
+ scale_level: 1
+ serviceNodeAspect:
+ scale_level: 1
+ large:
+ description: ..
+ vdu_levels:
+ dbBackend:
+ number_of_instances: 5
+ serviceNode:
+ number_of_instances: 4
+ scale_info:
+ dbBackendAspect:
+ scale_level: 2
+ serviceNodeAspect:
+ scale_level: 2
+ default_instantiation_level_id: small
+ vdu_profile:
+ dbBackend:
+ min_number_of_instances: 3
+ max_number_of_instances: 11
+ serviceNode:
+ min_number_of_instances: 0
+ max_number_of_instances: 6
+ vnf:
+ properties:
+ modifiable_attributes:
+ extensions:
+ http_proxy:
+ default: "http://87.254.212.120:8080"
+ https_proxy:
+ default: "https://87.254.212.120:8080"
+ no_proxy:
+ default: "10.41.49.231,10.41.49.5"
+ mysqlPassword:
+ default: "password"
+ mysqlUsername:
+ default: "mysql"
+ loginUsername:
+ default: "ubuntu"
+ rhel_yum_repository_host:
+ default: "http://10.41.49.231/mirror/rhel-7-server-rpms/"
+ ubuntu_repository_host:
+ default: "deb [arch=amd64] http://10.41.49.5/cobbler/repo_mirror/ubuntu-16.04-x86_64/ xenial main universe"
+ mariadb_rhel_repo_host:
+# default: "http://yum.mariadb.org/10.0/rhel7-amd64"
+ default: "http://10.41.49.5/cobbler/repo_mirror/mariadb-10.0-el7-x86_64/"
+ mariadb_ubuntu_repo_host:
+# default: "deb http://mirror.netinch.com/pub/mariadb/repo/10.0/ubuntu trusty main"
+ default: "deb [arch=amd64] http://10.41.49.5/cobbler/repo_mirror/ubuntu-mariadb-10.0-x86_64/ xenial main"
+ custom_backend_root_volume_size:
+ default: "10"
+ dry_run:
+ default: "false"
+ interfaces:
+ Basic:
+ instantiate:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: javascript/scalable_instantiate_hot_params.js
+ include:
+ - javascript/scalable_prepare_cbam_include.js
+ output: stack_parameters
+ - javascript: javascript/cbam.pre.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ post_actions:
+ - javascript: javascript/workaround_inventory_on_kilo.js
+ output: ansible_inventory
+ - ansible: ansible/playbook-scalable.yml
+ - javascript: javascript/cbam.post.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ additional_parameters:
+ jobId: onapJobId
+ terminate:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: javascript/cbam.pre.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ post_actions:
+ - javascript: javascript/cbam.post.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ additional_parameters:
+ jobId: onapJobId
+ Scalable:
+ scale:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: javascript/scalable_instantiate_hot_params.js
+ include:
+ - javascript/scalable_prepare_cbam_include.js
+ output: stack_parameters
+ - ansible: ansible/playbook-scalable-scale-in.yml
+ - javascript: javascript/cbam.pre.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ post_actions:
+ - javascript: javascript/workaround_inventory_on_kilo.js
+ output: ansible_inventory
+ - ansible: ansible/playbook-scalable.yml
+ - javascript: javascript/cbam.post.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ additional_parameters:
+ jobId: onapJobId
+ Healable:
+ heal:
+ implementation: mistral-workbooks/heal_workbook.yaml
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: javascript/cbam.pre.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ post_actions:
+ - javascript: javascript/cbam.post.collectConnectionPoints.js
+ include:
+ - javascript/cbam.collectConnectionPoints.js
+ output: operation_result
+ additional_parameters:
+ vmName: null
+ action: null
+ jobId: onapJobId
+ Custom:
+ upgrade:
+ implementation: mistral-workbooks/upgrade_workbook.yaml
+ inputs:
+ additional_parameters:
+ imageId: ubuntu.16.04
+ jobId: onapJobId
+ node_templates:
+ dbBackend:
+ type: tosca.nodes.nfv.VDU
+ properties:
+ description: ..
+ configurable_properties:
+ additional_vnfc_configurable_properties: {}
+ boot_order:
+ - rootVolume
+ requirements:
+ - virtual_compute: dbBackendCompute
+ - virtual_storage: rootVolume
+ - virtual_storage: dataVolume
+ - sw_image: mariaDbImage #FIXME
+
+ serviceNode:
+ type: tosca.nodes.nfv.VDU
+ properties:
+ description: ..
+ configurable_properties:
+ additional_vnfc_configurable_properties: {}
+ requirements:
+ - virtual_compute: serviceNodeCompute
+ - sw_image: mariaDbImage
+
+ dbBackendCompute:
+ type: tosca.nodes.nfv.VirtualCompute
+ properties:
+ virtual_memory:
+ virtual_mem_size: 8096 MB
+ virtual_cpu:
+ cpu_architecture: x86
+ num_virtual_cpu: 2
+ virtual_cpu_clock: 1800 MHz
+
+ serviceNodeCompute:
+ type: tosca.nodes.nfv.VirtualCompute
+ properties:
+ virtual_memory:
+ virtual_mem_size: 8096 MB
+ virtual_cpu:
+ cpu_architecture: x86
+ num_virtual_cpu: 2
+ virtual_cpu_clock: 1800 MHz
+
+ rootVolume:
+ type: tosca.nodes.nfv.VirtualStorage
+ properties:
+ type_of_storage: volume
+ size_of_storage: 10 GB
+ #rdma_enabled: false
+ requirements:
+ - sw_image: mariaDbImage
+
+ dataVolume:
+ type: tosca.nodes.nfv.VirtualStorage
+ properties:
+ type_of_storage: volume
+ size_of_storage: 1 GB
+ #rdma_enabled: false
+ requirements:
+ - sw_image: mariaDbImage
+
+ mariaDbImage:
+ type: tosca.nodes.nfv.SwImage
+ properties:
+ name: Software of Maria Db
+ version: 1.0
+ checksum: 9af30fce37a4c5c831e095745744d6d2
+ container_format: qcow2
+ disk_format: bare
+ # the ubuntu image is minimum 4GB the Centos is minimum 8 GB ?
+ min_disk: 10 GB
+ min_ram: 8096 MB
+ size: 10 GB
+ sw_image: maria.db.image.v1.0.qcow2
+ operating_system: Linux
+ supported_virtualisation_environments:
+ - KVM
+
+ dbBackendCpOnIpv4:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: Connection point to access the DB on IPv4 externally
+ requirements:
+ - virtual_binding: dbBackend
+ - virtual_link: internalNetworkForFloatingIp
+
+ dbBackendCpOnIpv6:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv6
+ role: leaf
+ description: Connection point to access the DB on IPv6 externally
+ requirements:
+ - virtual_binding: dbBackend
+ #- virtual_link: the CP is connected to the core network (IPv6)
+
+ dbBackendCpOnIpv4Redundancy1:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: Connection point for DB replication
+ requirements:
+ - virtual_binding: dbBackend
+ - virtual_link: internalReplicationNetwork1
+
+ dbBackendCpOnIpv4Redundancy2:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: Connection point for DB replication
+ requirements:
+ - virtual_binding: dbBackend
+ - virtual_link: internalReplicationNetwork2
+
+ dbBackendExternallyManagedCp:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv6
+ role: leaf
+ description: Connection point to access the DB on IPv6 externally
+ requirements:
+ - virtual_binding: dbBackend
+ - virtual_link: extManagedVl
+
+ serviceNodeCp:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: Connection point to access the DB on IPv4 externally
+ requirements:
+ - virtual_binding: serviceNode
+ - virtual_link: internalNetworkForFloatingIp
+
+ serviceNodeExternallyManagedCp:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: External connection point to access the DB on IPv4
+ requirements:
+ - virtual_binding: dbBackend
+ - virtual_link: extManagedVl
+
+ movingIpCp:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: Moving IP
+ requirements:
+ #- virtual_binding: # no corresponding VDU
+ - virtual_link: internalNetworkForFloatingIp
+ internalNetworkForFloatingIp:
+ type: tosca.nodes.nfv.VL
+ properties:
+ connectivity_type:
+ layer_protocol: ipv4
+ flow_pattern: mesh
+ vl_flavours: {}
+
+ internalReplicationNetwork1:
+ type: tosca.nodes.nfv.VL
+ properties:
+ connectivity_type:
+ layer_protocol: ipv4
+ flow_pattern: mesh
+ test_access: []
+ description: ..
+ vl_flavours: {}
+
+ internalReplicationNetwork2:
+ type: tosca.nodes.nfv.VL
+ properties:
+ connectivity_type:
+ layer_protocol: ipv4
+ flow_pattern: mesh
+ test_access: []
+ description: ..
+ vl_flavours: {}
+
+ extManagedVl:
+ type: tosca.nodes.nfv.VL
+ properties:
+ connectivity_type:
+ layer_protocol: ipv4
+ flow_pattern: mesh
+ test_access: []
+ description: ..
+ vl_flavours: {}
+
+ dbBackendIpv4:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: dbBackendCpOnIpv4
+ #- external_virtual_link: # exposed on VNF boundary
+
+ dbBackendIpv6:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv6
+ requirements:
+ - internal_connection_point: dbBackendCpOnIpv6
+ #- external_virtual_link: # exposed on VNF boundary
+
+ serviceNodeIpv4:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: serviceNodeCp
+ #- external_virtual_link: # exposed on VNF boundary
+
+ loadBalancer:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: movingIpCp
+ #- external_virtual_link: # exposed on VNF boundary
+
+ groups:
+ dbBackendScalingGroup:
+ type: tosca.groups.nfv.ElementGroup
+ description: ..
+ members: [ dbBackend ]
+
+ serviceNodeScalingGroup:
+ type: tosca.groups.nfv.ElementGroup
+ description: ..
+ members: [ serviceNode ]
+
+ policies:
+ - service_node_anti_affinity:
+ type: tosca.policies.nfv.ScalingStepLocalAntiAffinity
+ targets: [ serviceNode ]
+ properties:
+ scope: nfvi_node
+
+ - backend_node_anti_affinity:
+ type: tosca.policies.nfv.LocalAntiAffinity
+ targets: [ dbBackend ]
+ properties:
+ scope: nfvi_node
+
+ - nfvi_affinity:
+ type: tosca.policies.nfv.LocalAffinity
+ targets: [ dbBackend ]
+ properties:
+ scope: nfvi
+
+ - zone_affinity:
+ type: tosca.policies.nfv.LocalAffinity
+ targets: [ dbBackend ]
+ properties:
+ scope: resource_zone_group
+
+ - commissioning:
+ type: tosca.policies.nfv.Commissioning #FIXME
+ properties:
+ connection_points:
+ - dbBackendIpv6
+ - serviceNodeIpv4
+
+ - heat_mapping:
+ type: tosca.policies.nfv.HeatMapping
+ properties:
+ template:
+ hotPath: hot/
+ main: maria.hot.scalable.main.nated.yaml
+ nested:
+ - maria.hot.common.nated.yaml
+ - maria.hot.scalable.service.scaling.nated.yaml
+ - maria.hot.scalable.service.static.nated.yaml
+ - maria.hot.scalable.service.nated.yaml
+ - maria.hot.scalable.backend.static.nated.yaml
+ - maria.hot.scalable.backend.single.nated.yaml
+ - maria.hot.scalable.backend.nated.yaml
+ - maria.hot.scalable.backend.single.wrapper.nated.yaml
+ - maria.hot.scalable.backend.wrapper.nated.yaml
+# environment:
+ static:
+ virtualLinks:
+ internalReplicationNetwork1: db_backend_static.replication_network_1
+ internalReplicationNetwork2: db_backend_static.replication_network_2
+ internalNetworkForFloatingIp: common_resources.internal_network_for_floatingip
+ vdus:
+ dbBackend:
+ - heatResource: db_backend_static.static_node_0.wrapper_rg.0.server
+ connectionPoints:
+ dbBackendCpOnIpv4: db_backend_static.static_node_0.wrapper_rg.0.port_ipv4_nated
+ dbBackendCpOnIpv6: db_backend_static.static_node_0.wrapper_rg.0.port_ipv6
+ dbBackendCpOnIpv4Redundancy1: db_backend_static.static_node_0.wrapper_rg.0.port_replication_1
+ dbBackendCpOnIpv4Redundancy2: db_backend_static.static_node_0.wrapper_rg.0.port_replication_2
+ dbBackendExternallyManagedCp: db_backend_static.static_node_0.wrapper_rg.0.port_internal_ext_managed
+ virtualStorages:
+ rootVolume: db_backend_static.static_node_0.wrapper_rg.0.volume_root
+ dataVolume: db_backend_static.static_node_0.wrapper_rg.0.volume_data
+ externalConnectionPoints:
+ dbBackendIpv4:
+ - db_backend_static.static_node_0.wrapper_rg.0.floating_ip
+ dbBackendIpv6:
+ - db_backend_static.static_node_0.wrapper_rg.0.port_ipv6
+ - heatResource: db_backend_static.static_node_1.wrapper_rg.0.server
+ connectionPoints:
+ dbBackendCpOnIpv4: db_backend_static.static_node_1.wrapper_rg.0.port_ipv4_nated
+ dbBackendCpOnIpv6: db_backend_static.static_node_1.wrapper_rg.0.port_ipv6
+ dbBackendCpOnIpv4Redundancy1: db_backend_static.static_node_1.wrapper_rg.0.port_replication_1
+ dbBackendCpOnIpv4Redundancy2: db_backend_static.static_node_1.wrapper_rg.0.port_replication_2
+ dbBackendExternallyManagedCp: db_backend_static.static_node_1.wrapper_rg.0.port_internal_ext_managed
+ virtualStorages:
+ rootVolume: db_backend_static.static_node_1.wrapper_rg.0.volume_root
+ dataVolume: db_backend_static.static_node_1.wrapper_rg.0.volume_data
+ externalConnectionPoints:
+ dbBackendIpv4:
+ - db_backend_static.static_node_1.wrapper_rg.0.floating_ip
+ dbBackendIpv6:
+ - db_backend_static.static_node_1.wrapper_rg.0.port_ipv6
+ - heatResource: db_backend_static.static_node_2.wrapper_rg.0.server
+ connectionPoints:
+ dbBackendCpOnIpv4: db_backend_static.static_node_2.wrapper_rg.0.port_ipv4_nated
+ dbBackendCpOnIpv6: db_backend_static.static_node_2.wrapper_rg.0.port_ipv6
+ dbBackendCpOnIpv4Redundancy1: db_backend_static.static_node_2.wrapper_rg.0.port_replication_1
+ dbBackendCpOnIpv4Redundancy2: db_backend_static.static_node_2.wrapper_rg.0.port_replication_2
+ dbBackendExternallyManagedCp: db_backend_static.static_node_2.wrapper_rg.0.port_internal_ext_managed
+ virtualStorages:
+ rootVolume: db_backend_static.static_node_2.wrapper_rg.0.volume_root
+ dataVolume: db_backend_static.static_node_2.wrapper_rg.0.volume_data
+ externalConnectionPoints:
+ dbBackendIpv4:
+ - db_backend_static.static_node_2.wrapper_rg.0.floating_ip
+ dbBackendIpv6:
+ - db_backend_static.static_node_2.wrapper_rg.0.port_ipv6
+ externalConnectionPoints:
+ loadBalancer:
+ - service_node_static.moving_ip_floating_ip
+ aspects:
+ dbBackendAspect:
+ heatResource: db_backend_aspect_group
+ vdus:
+ dbBackend:
+ - heatResource: wrapper_rg.0.server
+ connectionPoints:
+ dbBackendCpOnIpv4: wrapper_rg.0.port_ipv4_nated
+ dbBackendCpOnIpv6: wrapper_rg.0.port_ipv6
+ dbBackendCpOnIpv4Redundancy1: wrapper_rg.0.port_replication_1
+ dbBackendCpOnIpv4Redundancy2: wrapper_rg.0.port_replication_2
+ dbBackendExternallyManagedCp: wrapper_rg.0.port_internal_ext_managed
+ virtualStorages:
+ rootVolume: wrapper_rg.0.volume_root
+ dataVolume: wrapper_rg.0.volume_data
+ externalConnectionPoints:
+ dbBackendIpv4:
+ - wrapper_rg.0.floating_ip
+ dbBackendIpv6:
+ - wrapper_rg.0.port_ipv6
+ serviceNodeAspect:
+ heatResource: service_node_aspect_group
+ affinity:
+ local:
+ - type: same
+ place: vim
+ resources: [node_a.server, node_b.server]
+ - type: same
+ place: zone
+ resources: [node_a.server, node_b.server]
+ - type: different
+ place: host
+ resources: [node_a.server, node_b.server]
+ vdus:
+ serviceNode:
+ - heatResource: node_a.server
+ connectionPoints:
+ serviceNodeCp: node_a.port_ipv4_nated
+ serviceNodeExternallyManagedCp: node_a.port_internal_ext_managed
+ externalConnectionPoints:
+ serviceNodeIpv4:
+ - node_a.floating_ip
+ - heatResource: node_b.server
+ connectionPoints:
+ serviceNodeCp: node_b.port_ipv4_nated
+ serviceNodeExternallyManagedCp: node_b.port_internal_ext_managed
+ externalConnectionPoints:
+ serviceNodeIpv4:
+ - node_b.floating_ip
diff --git a/nokiav2/driver/src/test/resources/unittests/missing.vnfd.zip b/nokiav2/driver/src/test/resources/unittests/missing.vnfd.zip
new file mode 100644
index 00000000..cfabc407
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/missing.vnfd.zip
Binary files differ
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.modified.vnfd.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.modified.vnfd.yaml
new file mode 100644
index 00000000..83f1ea35
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.modified.vnfd.yaml
@@ -0,0 +1,87 @@
+---
+tosca_definitions_version: "tosca_simple_profile_for_nfv_1_0_0_nokia"
+topology_template:
+ substitution_mappings:
+ node_type: "tosca.nodes.nfv.VNF"
+ capabilities:
+ vnf:
+ properties:
+ modifiable_attributes:
+ extensions:
+ existingAttribute:
+ default: "value"
+ onapCsarId:
+ default: "kuku"
+ vimId:
+ default: "kuku"
+ interfaces:
+ Basic:
+ instantiate:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: "pre"
+ include:
+ - "javascript/scalable_prepare_cbam_include.js"
+ output: "stack_parameters"
+ - javascript: "javascript/cbam.pre.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ post_actions:
+ - javascript: "post"
+ output: "ansible_inventory"
+ - javascript: "javascript/cbam.post.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ additional_parameters:
+ kuku: "muku"
+ jobId: "kuku"
+ terminate:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: "javascript/cbam.pre.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ post_actions:
+ - javascript: "javascript/cbam.post.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ additional_parameters:
+ jobId: "kuku"
+ Scalable:
+ scale:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: "javascript/cbam.pre.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ post_actions:
+ - javascript: "javascript/cbam.post.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ additional_parameters:
+ jobId: "kuku"
+ Healable:
+ heal:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: "javascript/cbam.pre.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ post_actions:
+ - javascript: "javascript/cbam.post.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ additional_parameters:
+ jobId: "kuku"
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.original.vnfd.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.original.vnfd.yaml
new file mode 100644
index 00000000..42569b04
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.full.original.vnfd.yaml
@@ -0,0 +1,33 @@
+tosca_definitions_version: tosca_simple_profile_for_nfv_1_0_0_nokia
+
+topology_template:
+ substitution_mappings:
+ node_type: tosca.nodes.nfv.VNF
+ capabilities:
+ vnf:
+ properties:
+ modifiable_attributes:
+ extensions:
+ existingAttribute:
+ default: "value"
+ interfaces:
+ Basic:
+ instantiate:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: pre
+ include:
+ - javascript/scalable_prepare_cbam_include.js
+ output: stack_parameters
+ post_actions:
+ - javascript: post
+ output: ansible_inventory
+ additional_parameters:
+ kuku: muku
+ terminate:
+ Scalable:
+ scale:
+ Healable:
+ heal:
+
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.modified.vnfd.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.modified.vnfd.yaml
new file mode 100644
index 00000000..2b05ecf1
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.modified.vnfd.yaml
@@ -0,0 +1,46 @@
+---
+tosca_definitions_version: "tosca_simple_profile_for_nfv_1_0_0_nokia"
+topology_template:
+ substitution_mappings:
+ node_type: "tosca.nodes.nfv.VNF"
+ interfaces:
+ Basic:
+ instantiate:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: "javascript/cbam.pre.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ post_actions:
+ - javascript: "javascript/cbam.post.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ additional_parameters:
+ jobId: "kuku"
+ terminate:
+ inputs:
+ extensions:
+ pre_actions:
+ - javascript: "javascript/cbam.pre.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ post_actions:
+ - javascript: "javascript/cbam.post.collectConnectionPoints.js"
+ include:
+ - "javascript/cbam.collectConnectionPoints.js"
+ output: "operation_result"
+ additional_parameters:
+ jobId: "kuku"
+ capabilities:
+ vnf:
+ properties:
+ modifiable_attributes:
+ extensions:
+ onapCsarId:
+ default: "kuku"
+ vimId:
+ default: "kuku"
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.original.vnfd.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.original.vnfd.yaml
new file mode 100644
index 00000000..7709793c
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.minimal.original.vnfd.yaml
@@ -0,0 +1,9 @@
+tosca_definitions_version: tosca_simple_profile_for_nfv_1_0_0_nokia
+
+topology_template:
+ substitution_mappings:
+ node_type: tosca.nodes.nfv.VNF
+ interfaces:
+ Basic:
+ instantiate:
+ terminate:
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zip b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zip
new file mode 100644
index 00000000..ac555dff
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zip
Binary files differ
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zip.vnfd b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zip.vnfd
new file mode 100644
index 00000000..3c121386
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/cbam.package.zip.vnfd
@@ -0,0 +1,17 @@
+tosca_definitions_version: tosca_simple_profile_for_nfv_1_0_0_nokia
+
+topology_template:
+ substitution_mappings:
+ node_type: tosca.nodes.nfv.VNF
+ properties:
+ descriptor_id: Nokia~Maria DB~1.0~1.0
+ descriptor_version: '1.0'
+ provider: Nokia
+ product_name: Maria DB
+ software_version: '1.0'
+ product_info_name: Maria DB
+ product_info_description: Relational database, non-scalable
+ interfaces:
+ Basic:
+ instantiate:
+ terminate:
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.cbam.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.cbam.yaml
new file mode 100644
index 00000000..45bfb73f
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.cbam.yaml
@@ -0,0 +1,11 @@
+tosca_definitions_version: tosca_simple_profile_for_nfv_1_0_0_nokia
+
+topology_template:
+ substitution_mappings:
+ node_type: tosca.nodes.nfv.VNF
+ properties:
+ descriptor_version: '1.0'
+ provider: myProvider
+ product_name: 'myName'
+ software_version: '2.0'
+ product_info_name: product_info_name \ No newline at end of file
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.onap.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.onap.yaml
new file mode 100644
index 00000000..1cbc8ef7
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/empty.vnfd.onap.yaml
@@ -0,0 +1,14 @@
+tosca_definitions_version: tosca_simple_yaml_1_0
+
+metadata:
+ vendor: Nokia
+ csarVersion: 1.0
+ csarProvider: myProvider
+ id: Simple
+ version: 2.0
+ csarType: NFAR
+ name: myName
+ vnfdVersion: 1.0
+
+topology_template:
+ node_templates:
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.cbam.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.cbam.yaml
new file mode 100644
index 00000000..985ab276
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.cbam.yaml
@@ -0,0 +1,153 @@
+tosca_definitions_version: tosca_simple_profile_for_nfv_1_0_0_nokia
+
+topology_template:
+ substitution_mappings:
+ node_type: tosca.nodes.nfv.VNF
+ properties:
+ descriptor_version: '1.0'
+ provider: myProvider
+ product_name: 'myName'
+ software_version: '2.0'
+ product_info_name: product_info_name
+ node_templates:
+ vduNode:
+ type: tosca.nodes.nfv.VDU
+ properties:
+ description: myVduDesc
+ requirements:
+ - virtual_compute: myCompute
+ - virtual_storage: myStorage1
+ - virtual_storage: myStorage2
+ - unhandled_type: unknown
+
+ unknownType:
+ type: tosca.nodes.nfv.Unknown
+
+ myCompute:
+ type: tosca.nodes.nfv.VirtualCompute
+ properties:
+ virtual_memory:
+ virtual_mem_size: 8192 MB
+ virtual_cpu:
+ num_virtual_cpu: 4
+ virtual_cpu_clock: 1234 Mhz
+ myStorage1:
+ type: tosca.nodes.nfv.VirtualStorage
+ properties:
+ id: myStorage1
+ size_of_storage: 1G
+
+ myStorage2:
+ type: tosca.nodes.nfv.VirtualStorage
+ properties:
+ id: myStorage2
+ size_of_storage: 2G
+
+ myNetwork1:
+ type: tosca.nodes.nfv.VL
+
+ myNetwork2:
+ type: tosca.nodes.nfv.VL
+
+ icpWithOutEcp:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ description: myDescription
+ requirements:
+ - virtual_binding: vduNode
+ - virtual_link: myNetwork1
+
+ icpWithEcp:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ description: myDescription
+ requirements:
+ - virtual_binding: vduNode
+ - virtual_link: myNetwork1
+
+ icpWithOutDescription:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - virtual_binding: vduNode
+ - virtual_link: myNetwork1
+
+ icpWithoutVdu:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ description: myDescription
+ requirements:
+ - virtual_link: myNetwork1
+
+ icpWithOutVl:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ description: myDescription
+ requirements:
+ - virtual_binding: vduNode
+
+ myEcp:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: icpWithEcp
+
+ myEcpWithDescription:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: icpWithOutDescription
+
+ myEcpWithoutIcpWithoutVdu:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: icpWithoutVdu
+
+ myEcpWithoutIcpWithoutIcpReq:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: icpWithOutRequiements
+
+ myEcpWithoutIcp:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - not_valid: d
+
+ icpWithOutVdu:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ description: myDescription
+ requirements:
+ - not_valid: a
+
+ icpWithOutRequiements:
+ type: tosca.nodes.nfv.ICP
+ properties:
+ layer_protocol: ipv4
+ description: myDescription
+
+ ecpWithIcpWithOutVdu:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4
+ requirements:
+ - internal_connection_point: icpWithOutVdu
+
+ ecpWithIcpWithOutRequirements:
+ type: tosca.nodes.nfv.ECP
+ properties:
+ layer_protocol: ipv4 \ No newline at end of file
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.inconsistent.cbam.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.inconsistent.cbam.yaml
new file mode 100644
index 00000000..abb1243f
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.inconsistent.cbam.yaml
@@ -0,0 +1,18 @@
+tosca_definitions_version: tosca_simple_profile_for_nfv_1_0_0_nokia
+
+topology_template:
+ substitution_mappings:
+ node_type: tosca.nodes.nfv.VNF
+ properties:
+ descriptor_version: '1.0'
+ provider: myProvider
+ product_name: 'myName'
+ software_version: '2.0'
+ product_info_name: product_info_name
+ node_templates:
+ vduNode:
+ type: tosca.nodes.nfv.VDU
+ properties:
+ description: myVduDesc
+ requirements:
+ - virtual_compute: myComputeMissing
diff --git a/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.onap.yaml b/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.onap.yaml
new file mode 100644
index 00000000..51842a87
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/packageconverter/nodes.vnfd.onap.yaml
@@ -0,0 +1,95 @@
+tosca_definitions_version: tosca_simple_yaml_1_0
+
+metadata:
+ vendor: Nokia
+ csarVersion: 1.0
+ csarProvider: myProvider
+ id: Simple
+ version: 2.0
+ csarType: NFAR
+ name: myName
+ vnfdVersion: 1.0
+
+topology_template:
+ node_templates:
+ vduNode:
+ type: tosca.nodes.nfv.VDU.Compute
+ capabilities:
+ virtual_compute:
+ properties:
+ virtual_memory:
+ virtual_mem_size: 8192 MB
+ virtual_cpu:
+ num_virtual_cpu: 4
+ requirements:
+ - virtual_storage:
+ capability: tosca.capabilities.nfv.VirtualStorage
+ node: myStorage1
+ - virtual_storage:
+ capability: tosca.capabilities.nfv.VirtualStorage
+ node: myStorage2
+ myStorage1:
+ type: tosca.nodes.nfv.VDU.VirtualStorage
+ properties:
+ id: myStorage1
+ type_of_storage: volume
+ size_of_storage: 1G
+ myStorage2:
+ type: tosca.nodes.nfv.VDU.VirtualStorage
+ properties:
+ id: myStorage2
+ type_of_storage: volume
+ size_of_storage: 2G
+ myNetwork1:
+ type: tosca.nodes.nfv.VnfVirtualLinkDesc
+ properties:
+ vl_flavours:
+ flavours:
+ flavourId: notUsed
+ myNetwork2:
+ type: tosca.nodes.nfv.VnfVirtualLinkDesc
+ properties:
+ vl_flavours:
+ flavours:
+ flavourId: notUsed
+ icpWithOutEcp:
+ type: tosca.nodes.nfv.VduCpd
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: myDescription
+ requirements:
+ - virtual_binding: vduNode
+ - virtual_link: myNetwork1
+ icpWithEcp:
+ type: tosca.nodes.nfv.VduCpd
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: myDescription
+ requirements:
+ - virtual_binding: vduNode
+ - virtual_link: myNetwork1
+ icpWithOutDescription:
+ type: tosca.nodes.nfv.VduCpd
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ requirements:
+ - virtual_binding: vduNode
+ - virtual_link: myNetwork1
+ myEcp:
+ type: tosca.nodes.nfv.VduCpd
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ description: myDescription
+ requirements:
+ - virtual_binding: vduNode
+ myEcpWithDescription:
+ type: tosca.nodes.nfv.VduCpd
+ properties:
+ layer_protocol: ipv4
+ role: leaf
+ requirements:
+ - virtual_binding: vduNode
diff --git a/nokiav2/driver/src/test/resources/unittests/sample.cert.pem b/nokiav2/driver/src/test/resources/unittests/sample.cert.pem
new file mode 100644
index 00000000..0e41d269
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/sample.cert.pem
@@ -0,0 +1,14 @@
+-----BEGIN CERTIFICATE-----
+MIICEjCCAXsCAg36MA0GCSqGSIb3DQEBBQUAMIGbMQswCQYDVQQGEwJKUDEOMAwG
+A1UECBMFVG9reW8xEDAOBgNVBAcTB0NodW8ta3UxETAPBgNVBAoTCEZyYW5rNERE
+MRgwFgYDVQQLEw9XZWJDZXJ0IFN1cHBvcnQxGDAWBgNVBAMTD0ZyYW5rNEREIFdl
+YiBDQTEjMCEGCSqGSIb3DQEJARYUc3VwcG9ydEBmcmFuazRkZC5jb20wHhcNMTIw
+ODIyMDUyNjU0WhcNMTcwODIxMDUyNjU0WjBKMQswCQYDVQQGEwJKUDEOMAwGA1UE
+CAwFVG9reW8xETAPBgNVBAoMCEZyYW5rNEREMRgwFgYDVQQDDA93d3cuZXhhbXBs
+ZS5jb20wXDANBgkqhkiG9w0BAQEFAANLADBIAkEAm/xmkHmEQrurE/0re/jeFRLl
+8ZPjBop7uLHhnia7lQG/5zDtZIUC3RVpqDSwBuw/NTweGyuP+o8AG98HxqxTBwID
+AQABMA0GCSqGSIb3DQEBBQUAA4GBABS2TLuBeTPmcaTaUW/LCB2NYOy8GMdzR1mx
+8iBIu2H6/E2tiY3RIevV2OW61qY2/XRQg7YPxx3ffeUugX9F4J/iPnnu1zAxxyBy
+2VguKv4SWjRFoRkIfIlHX0qVviMhSlNy2ioFLy7JcPZb+v3ftDGywUqcBiVDoea0
+Hn+GmxZA
+-----END CERTIFICATE----- \ No newline at end of file
diff --git a/nokiav2/driver/src/test/resources/unittests/vnfd.full.yaml b/nokiav2/driver/src/test/resources/unittests/vnfd.full.yaml
new file mode 100644
index 00000000..460f7f10
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/vnfd.full.yaml
@@ -0,0 +1,24 @@
+topology_template:
+ substitution_mappings:
+ capabilities:
+ deployment_flavour:
+ properties:
+ flavour_id: myFlavorId
+ instantiation_levels:
+ level1:
+ vdu_levels:
+ vdu1:
+ number_of_instances: 1
+ vdu2:
+ number_of_instances: 2
+ level2:
+ vdu_levels:
+ vdu1:
+ number_of_instances: 2
+ interfaces:
+ Basic:
+ scale:
+ inputs:
+ additional_parameters:
+ jobId: kuku
+ a: valueInVnfd \ No newline at end of file
diff --git a/nokiav2/driver/src/test/resources/unittests/vnfd.instantiation.yaml b/nokiav2/driver/src/test/resources/unittests/vnfd.instantiation.yaml
new file mode 100644
index 00000000..ef858dbc
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/vnfd.instantiation.yaml
@@ -0,0 +1,16 @@
+topology_template:
+ substitution_mappings:
+ capabilities:
+ deployment_flavour:
+ properties:
+ instantiation_levels:
+ level1:
+ vdu_levels:
+ vdu1:
+ number_of_instances: 1
+ vdu2:
+ number_of_instances: 2
+ level2:
+ vdu_levels:
+ vdu1:
+ number_of_instances: 2
diff --git a/nokiav2/driver/src/test/resources/unittests/vnfd.scale.yaml b/nokiav2/driver/src/test/resources/unittests/vnfd.scale.yaml
new file mode 100644
index 00000000..87493f58
--- /dev/null
+++ b/nokiav2/driver/src/test/resources/unittests/vnfd.scale.yaml
@@ -0,0 +1,23 @@
+topology_template:
+ policies:
+ - unkown_policy:
+ properties:
+ aspects:
+ aspect1:
+ vdus:
+ vdu1:
+ - heatResource: wrapper_rg.0.server
+ - heatResource: wrapper_rg.1.server
+ - heat_mapping:
+ properties:
+ aspects:
+ aspect1:
+ vdus:
+ vdu1:
+ - heatResource: wrapper_rg.0.server
+ - heatResource: wrapper_rg.1.server
+ vdu2:
+ - heatResource: wrapper_rg2.0.server
+ emptyAspect: # does not make sense
+ aspectWithOutVdu: # does not make sense
+ network: \ No newline at end of file
diff --git a/nokiav2/driverwar/pom.xml b/nokiav2/driverwar/pom.xml
new file mode 100644
index 00000000..a9a5c13c
--- /dev/null
+++ b/nokiav2/driverwar/pom.xml
@@ -0,0 +1,86 @@
+<?xml version="1.0"?>
+<!--
+ Copyright 2016-2017, Nokia Corporation
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+ -->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>driverwar</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ <packaging>war</packaging>
+ <name>vfc/nfvo/driver/vnfm/svnfm/nokiav2/driverwar</name>
+ <description>svnfm vnfm driver</description>
+ <parent>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm-nokiav2</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </parent>
+ <properties>
+ <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+ <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
+ <java.version>1.8</java.version>
+ </properties>
+ <dependencies>
+ <dependency>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>driver</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.springframework.boot</groupId>
+ <artifactId>spring-boot-starter-web</artifactId>
+ <version>1.5.10.RELEASE</version>
+ </dependency>
+ </dependencies>
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-war-plugin</artifactId>
+ <configuration>
+ <failOnMissingWebXml>false</failOnMissingWebXml>
+ <archive>
+ <manifest>
+ <mainClass>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.NokiaSvnfmApplication</mainClass>
+ <addDefaultImplementationEntries>true</addDefaultImplementationEntries>
+ </manifest>
+ </archive>
+ </configuration>
+ </plugin>
+ <plugin>
+ <groupId>org.springframework.boot</groupId>
+ <artifactId>spring-boot-maven-plugin</artifactId>
+ <version>1.5.10.RELEASE</version>
+ <configuration>
+ <mainClass>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokia.NokiaSvnfmApplication</mainClass>
+ <layout>ZIP</layout>
+ </configuration>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-compiler-plugin</artifactId>
+ <version>3.5</version>
+ <configuration>
+ <source>1.8</source>
+ <target>1.8</target>
+ </configuration>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-surefire-plugin</artifactId>
+ </plugin>
+ </plugins>
+ </build>
+</project>
diff --git a/nokiav2/generatedapis/pom.xml b/nokiav2/generatedapis/pom.xml
new file mode 100644
index 00000000..1e2c7d98
--- /dev/null
+++ b/nokiav2/generatedapis/pom.xml
@@ -0,0 +1,209 @@
+<?xml version="1.0"?>
+<!--
+ Copyright 2017 Nokia Corporation.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <parent>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm-nokiav2</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </parent>
+ <modelVersion>4.0.0</modelVersion>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm-nokiav2-clients</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ <packaging>jar</packaging>
+ <name>vfc/nfvo/driver/vnfm/svnfm/nokiav2/generatedapis</name>
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>io.swagger</groupId>
+ <artifactId>swagger-codegen-maven-plugin</artifactId>
+ <version>2.3.1</version>
+ <executions>
+ <execution>
+ <id>cbamlcm</id>
+ <goals>
+ <goal>generate</goal>
+ </goals>
+ <configuration>
+ <inputSpec>${basedir}/src/main/resources/nokia.vnfm.api.v3.lcm.json</inputSpec>
+ <language>java</language>
+ <output>${project.build.directory}/generated-sources/cbam</output>
+ <apiPackage>com.nokia.cbam.lcm.v32.api</apiPackage>
+ <modelPackage>com.nokia.cbam.lcm.v32.model</modelPackage>
+ <configOptions>
+ <jackson>true</jackson>
+ <sourceFolder>src/gen/java/main</sourceFolder>
+ <withXml>true</withXml>
+ <useRxJava2>true</useRxJava2>
+ </configOptions>
+ </configuration>
+ </execution>
+ <execution>
+ <id>cbamlcn</id>
+ <goals>
+ <goal>generate</goal>
+ </goals>
+ <configuration>
+ <inputSpec>${basedir}/src/main/resources/nokia.vnfm.api.v3.lcn.subscription.json</inputSpec>
+ <language>java</language>
+ <output>${project.build.directory}/generated-sources/cbam</output>
+ <apiPackage>com.nokia.cbam.lcn.v32.api</apiPackage>
+ <modelPackage>com.nokia.cbam.lcn.v32.model</modelPackage>
+ <configOptions>
+ <generateSupportingFiles>false</generateSupportingFiles>
+ <sourceFolder>src/gen/java/main</sourceFolder>
+ </configOptions>
+ </configuration>
+ </execution>
+ <execution>
+ <id>cbamcatalog</id>
+ <goals>
+ <goal>generate</goal>
+ </goals>
+ <configuration>
+ <inputSpec>${basedir}/src/main/resources/nokia.catalog.json</inputSpec>
+ <language>java</language>
+ <output>${project.build.directory}/generated-sources/cbam</output>
+ <apiPackage>com.nokia.cbam.catalog.v1.api</apiPackage>
+ <modelPackage>com.nokia.cbam.catalog.v1.model</modelPackage>
+ <configOptions>
+ <generateSupportingFiles>false</generateSupportingFiles>
+ <sourceFolder>src/gen/java/main</sourceFolder>
+ </configOptions>
+ </configuration>
+ </execution>
+ <execution>
+ <id>catalog</id>
+ <goals>
+ <goal>generate</goal>
+ </goals>
+ <configuration>
+ <inputSpec>${basedir}/src/main/resources/vfc.catalog.swagger.json</inputSpec>
+ <language>java</language>
+ <output>${project.build.directory}/generated-sources/vfccatalog</output>
+ <apiPackage>org.onap.vfccatalog.api</apiPackage>
+ <modelPackage>org.onap.vfccatalog.model</modelPackage>
+ <configOptions>
+ <generateSupportingFiles>false</generateSupportingFiles>
+ <sourceFolder>src/gen/java/main</sourceFolder>
+ </configOptions>
+ </configuration>
+ </execution>
+ <execution>
+ <id>svnfm</id>
+ <goals>
+ <goal>generate</goal>
+ </goals>
+ <configuration>
+ <inputSpec>${basedir}/src/main/resources/vfc.vnfdriver.swagger.json</inputSpec>
+ <language>java</language>
+ <output>${project.build.directory}/generated-sources/vnfmdriver</output>
+ <apiPackage>org.onap.vnfmdriver.api</apiPackage>
+ <modelPackage>org.onap.vnfmdriver.model</modelPackage>
+ <configOptions>
+ <generateSupportingFiles>false</generateSupportingFiles>
+ <sourceFolder>src/gen/java/main</sourceFolder>
+ </configOptions>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-patch-plugin</artifactId>
+ <version>1.2</version>
+ <configuration>
+ <targetDirectory>${project.build.directory}/generated-sources</targetDirectory>
+ <skipApplication>false</skipApplication>
+ </configuration>
+ <executions>
+ <execution>
+ <id>bugfix-patches</id>
+ <configuration>
+ <patchFile>src/main/resources/patch</patchFile>
+ <strip>1</strip>
+ </configuration>
+ <phase>process-sources</phase>
+ <goals>
+ <goal>apply</goal>
+ </goals>
+ </execution>
+ </executions>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-compiler-plugin</artifactId>
+ <version>3.7.0</version>
+ <configuration>
+ <source>1.8</source>
+ <target>1.8</target>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+ <dependencies>
+ <dependency>
+ <groupId>com.google.code.gson</groupId>
+ <artifactId>gson</artifactId>
+ <version>2.8.2</version>
+ </dependency>
+ <dependency>
+ <groupId>io.swagger</groupId>
+ <artifactId>swagger-annotations</artifactId>
+ <version>1.5.16</version>
+ </dependency>
+ <dependency>
+ <groupId>joda-time</groupId>
+ <artifactId>joda-time</artifactId>
+ <version>2.9.9</version>
+ </dependency>
+ <dependency>
+ <!-- this does not have a compile time dependency, but is required to be able to deserialize the date to joda time -->
+ <groupId>com.fasterxml.jackson.datatype</groupId>
+ <artifactId>jackson-datatype-joda</artifactId>
+ <!-- this version must be in sync with the dependency comming from spring boot -->
+ <version>2.8.10</version>
+ </dependency>
+ <dependency>
+ <groupId>com.squareup.okhttp</groupId>
+ <artifactId>okhttp</artifactId>
+ <version>2.7.5</version>
+ </dependency>
+ <dependency>
+ <groupId>com.squareup.okhttp</groupId>
+ <artifactId>logging-interceptor</artifactId>
+ <version>2.7.5</version>
+ </dependency>
+ <dependency>
+ <groupId>junit</groupId>
+ <artifactId>junit</artifactId>
+ <version>4.12</version>
+ <!-- the test code is generated into the main source code :( -->
+ <scope>provided</scope>
+ </dependency>
+ <dependency>
+ <groupId>io.gsonfire</groupId>
+ <artifactId>gson-fire</artifactId>
+ <version>1.8.2</version>
+ </dependency>
+ <dependency>
+ <groupId>org.threeten</groupId>
+ <artifactId>threetenbp</artifactId>
+ <version>1.3.6</version>
+ </dependency>
+ </dependencies>
+</project>
diff --git a/nokiav2/generatedapis/src/main/resources/nokia.catalog.json b/nokiav2/generatedapis/src/main/resources/nokia.catalog.json
new file mode 100644
index 00000000..3f495393
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/nokia.catalog.json
@@ -0,0 +1,525 @@
+{
+ "swagger": "2.0",
+ "info": {
+ "version": "v1",
+ "title": "Catalog adapter service"
+ },
+ "basePath": "/adapter",
+ "securityDefinitions": {
+ "OauthPassword": {
+ "description": "OAuth 2.0 resource owner password credentials grant (https://tools.ietf.org/html/rfc6749#section-4.3) with bearer token type. Note: the given tokenUrl does not inherit from the basePath\n",
+ "type": "oauth2",
+ "tokenUrl": "/auth/realms/cbam/protocol/openid-connect/token",
+ "flow": "password",
+ "scopes": {
+ "default": "default scope"
+ }
+ },
+ "OauthClient": {
+ "description": "OAuth 2.0 client credentials grant (https://tools.ietf.org/html/rfc6749#section-4.4) with bearer token type. Note: the given tokenUrl does not inherit from the basePath\n",
+ "type": "oauth2",
+ "tokenUrl": "/auth/realms/cbam/protocol/openid-connect/token",
+ "flow": "application",
+ "scopes": {
+ "default": "default scope"
+ }
+ }
+ },
+ "security": [
+ {
+ "OauthPassword": [
+ "default"
+ ]
+ },
+ {
+ "OauthClient": [
+ "default"
+ ]
+ }
+ ],
+ "paths": {
+ "/vnfpackages": {
+ "get": {
+ "description": "List the available vnf packages",
+ "operationId": "list",
+ "produces": [
+ "application/json",
+ "application/xml"
+ ],
+ "parameters": [],
+ "responses": {
+ "200": {
+ "description": "List of available vnf packages",
+ "schema": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/catalog_adapter_vnfpackage"
+ }
+ }
+ }
+ }
+ },
+ "post": {
+ "description": "Create a new vnf package",
+ "operationId": "create",
+ "produces": [
+ "application/json",
+ "application/xml"
+ ],
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "parameters": [
+ {
+ "name": "content",
+ "in": "formData",
+ "required": true,
+ "x-is-map": false,
+ "type": "file",
+ "format": "file",
+ "description": "Content of the created package"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "The created vnf package",
+ "schema": {
+ "$ref": "#/definitions/catalog_adapter_vnfpackage"
+ }
+ }
+ }
+ }
+ },
+ "/vnfpackages/{id}": {
+ "get": {
+ "description": "Returns a vnf package",
+ "operationId": "getById",
+ "produces": [
+ "application/json",
+ "application/xml"
+ ],
+ "parameters": [
+ {
+ "name": "id",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "ID of the queried vnf package"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "The queried vnf package",
+ "schema": {
+ "$ref": "#/definitions/catalog_adapter_vnfpackage"
+ }
+ }
+ }
+ },
+ "delete": {
+ "description": "Delete an existing vnf package",
+ "operationId": "delete",
+ "parameters": [
+ {
+ "name": "id",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "ID of the vnf package to be deleted"
+ }
+ ]
+ }
+ },
+ "/vnfpackages/{vnfdId}/getbyversion": {
+ "get": {
+ "description": "Returns a vnf package",
+ "operationId": "getByVersion",
+ "produces": [
+ "application/json",
+ "application/xml"
+ ],
+ "parameters": [
+ {
+ "name": "vnfdId",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "VNFD ID of the queried vnf package"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "The queried vnf package",
+ "schema": {
+ "$ref": "#/definitions/catalog_adapter_vnfpackage"
+ }
+ }
+ }
+ }
+ },
+ "/vnfpackages/{vnfdId}/addusagereference": {
+ "post": {
+ "description": "Add a usage reference to the specified vnf package",
+ "operationId": "addUsageReference",
+ "consumes": [
+ "application/json",
+ "application/xml"
+ ],
+ "parameters": [
+ {
+ "name": "vnfdId",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "VNFD ID of the used vnf package"
+ },
+ {
+ "name": "reference",
+ "in": "header",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "the usage reference"
+ }
+ ]
+ }
+ },
+ "/vnfpackages/{vnfdId}/removeusagereference": {
+ "post": {
+ "description": "Remove a usage reference from the specified vnf package",
+ "operationId": "removeUsageReference",
+ "consumes": [
+ "application/json",
+ "application/xml`"
+ ],
+ "parameters": [
+ {
+ "name": "vnfdId",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "VNFD ID of the vnf package"
+ },
+ {
+ "name": "reference",
+ "in": "header",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "the usage reference"
+ }
+ ]
+ }
+ },
+ "/vnfpackages/{vnfdId}/artifacts/{filePath}": {
+ "get": {
+ "description": "Download a file from a vnf package",
+ "operationId": "viewArtifact",
+ "produces": [
+ "application/octet-stream"
+ ],
+ "parameters": [
+ {
+ "name": "vnfdId",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "VNFD ID of the vnf package"
+ },
+ {
+ "name": "filePath",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "Path of the requested file"
+ }
+ ],
+ "responses": {
+ "200": {
+ "schema": {
+ "type": "file"
+ },
+ "description": "Content of the requested file"
+ }
+ }
+ }
+ },
+ "/vnfpackages/{vnfdId}/content": {
+ "get": {
+ "description": "Download a vnf package",
+ "operationId": "content",
+ "produces": [
+ "application/octet-stream"
+ ],
+ "parameters": [
+ {
+ "name": "vnfdId",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "VNFD ID of the vnf package to download"
+ }
+ ],
+ "responses": {
+ "200": {
+ "schema": {
+ "type": "file"
+ },
+ "description": "Content of the vnf package"
+ }
+ }
+ }
+ },
+ "/vnfpackages/{id}/vnfversions": {
+ "get": {
+ "description": "List the available versions of a vnf package",
+ "operationId": "vnfversions",
+ "produces": [
+ "application/json",
+ "application/xml"
+ ],
+ "parameters": [
+ {
+ "name": "id",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "ID of the vnf package"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "The list of available versions (with full representations)",
+ "schema": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/catalog_adapter_vnfpackage"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/vnfpackages/{id}/versions": {
+ "get": {
+ "description": "List the available versions of a vnf package",
+ "operationId": "versions",
+ "produces": [
+ "application/json",
+ "application/xml"
+ ],
+ "parameters": [
+ {
+ "name": "id",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "ID of the vnf package"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "The list of available versions",
+ "schema": {
+ "$ref": "#/definitions/catalog_adapter_vnf_package_versions"
+ }
+ }
+ }
+ }
+ },
+ "/export": {
+ "get": {
+ "description": "Export all vnf packages",
+ "operationId": "exportAllVnfs",
+ "produces": [
+ "application/octet-stream"
+ ],
+ "parameters": [],
+ "responses": {
+ "200": {
+ "schema": {
+ "type": "file"
+ },
+ "description": "Content of the vnf packages"
+ }
+ }
+ }
+ },
+ "/export/{id}": {
+ "get": {
+ "description": "Export a vnf package",
+ "operationId": "exportOneVnf",
+ "produces": [
+ "application/octet-stream"
+ ],
+ "parameters": [
+ {
+ "name": "id",
+ "in": "path",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "ID of the vnf package to export"
+ }
+ ],
+ "responses": {
+ "200": {
+ "schema": {
+ "type": "file"
+ },
+ "description": "Content of the vnf package"
+ }
+ }
+ }
+ },
+ "/import": {
+ "post": {
+ "description": "Import vnf packages",
+ "operationId": "importVnf",
+ "produces": [
+ "application/json",
+ "application/xml"
+ ],
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "parameters": [
+ {
+ "name": "content",
+ "in": "formData",
+ "required": true,
+ "x-is-map": false,
+ "type": "file",
+ "format": "file",
+ "description": "Content of the imported packages"
+ },
+ {
+ "name": "Content-MD5",
+ "in": "header",
+ "required": true,
+ "x-is-map": false,
+ "type": "string",
+ "description": "The checksum of content"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "List of vnf packages",
+ "schema": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/catalog_adapter_vnfpackage"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "definitions": {
+ "catalog_adapter_vnf_package_versions": {
+ "title": "catalog_adapter_vnf_package_versions",
+ "type": "object",
+ "properties": {
+ "result": {
+ "description": "Result of the versions query operation",
+ "type": "array",
+ "items": {
+ "type": "string"
+ }
+ }
+ },
+ "required": [
+ "result"
+ ]
+ },
+ "catalog_adapter_artifact": {
+ "title": "catalog_adapter_artifact",
+ "type": "object",
+ "properties": {
+ "name": {
+ "description": "The name of artifact element. It shall match with the full file path in the ZIP.",
+ "type": "string"
+ },
+ "type": {
+ "description": "The type of artifact element. Default is other."
+ }
+ },
+ "required": [
+ "name"
+ ]
+ },
+ "catalog_adapter_vnfpackage": {
+ "title": "catalog_adapter_vnfpackage",
+ "type": "object",
+ "properties": {
+ "id": {
+ "description": "The ID of the vnf package, which is composed of provider~productName~swVersion",
+ "type": "string"
+ },
+ "vnfdId": {
+ "description": "The VNFD ID of the vnf package, which is composed of provider~productName~swVersion~version",
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "version": {
+ "description": "The VNFD version of vnf package",
+ "type": "string"
+ },
+ "allVersions": {
+ "description": "List of available versions of the package",
+ "type": "array",
+ "items": {
+ "type": "string"
+ }
+ },
+ "provider": {
+ "description": "Provider of the vnf package",
+ "type": "string"
+ },
+ "productName": {
+ "description": "Product name of the vnf package",
+ "type": "string"
+ },
+ "swVersion": {
+ "description": "Software version of the vnf package",
+ "type": "string"
+ },
+ "vimType": {
+ "description": "Vim type of the vnf package. Can be openstack or vmware.",
+ "type": "string"
+ },
+ "references": {
+ "description": "references attribute",
+ "type": "array",
+ "items": {
+ "type": "string"
+ }
+ },
+ "artifacts": {
+ "description": "The list of files in the vnf package zip",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/catalog_adapter_artifact"
+ }
+ }
+ },
+ "required": [
+ "references",
+ "artifacts"
+ ]
+ }
+ }
+}
diff --git a/nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcm.json b/nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcm.json
new file mode 100644
index 00000000..4f2966f7
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcm.json
@@ -0,0 +1,4112 @@
+{
+ "swagger": "2.0",
+ "info": {
+ "version": "v3.2",
+ "title": "Nokia VNFM API version 3.2 WIP - VNF Lifecycle Management interface"
+ },
+ "basePath": "/vnfm/lcm/v3",
+ "schemes": [
+ "https"
+ ],
+ "securityDefinitions": {
+ "OauthPassword": {
+ "description": "OAuth 2.0 resource owner password credentials grant (https://tools.ietf.org/html/rfc6749#section-4.3) with bearer token type. Note: the given tokenUrl does not inherit from the basePath\n",
+ "type": "oauth2",
+ "tokenUrl": "/auth/realms/cbam/protocol/openid-connect/token",
+ "flow": "password",
+ "scopes": {
+ "default": "default scope"
+ }
+ },
+ "OauthClient": {
+ "description": "OAuth 2.0 client credentials grant (https://tools.ietf.org/html/rfc6749#section-4.4) with bearer token type. Note: the given tokenUrl does not inherit from the basePath\n",
+ "type": "oauth2",
+ "tokenUrl": "/auth/realms/cbam/protocol/openid-connect/token",
+ "flow": "application",
+ "scopes": {
+ "default": "default scope"
+ }
+ }
+ },
+ "security": [
+ {
+ "OauthPassword": [
+ "default"
+ ]
+ },
+ {
+ "OauthClient": [
+ "default"
+ ]
+ }
+ ],
+ "produces": [
+ "application/json",
+ "application/problem+json"
+ ],
+ "consumes": [
+ "application/json"
+ ],
+ "tags": [
+ {
+ "name": "vnfs"
+ },
+ {
+ "name": "operation_executions"
+ }
+ ],
+ "paths": {
+ "/versions": {
+ "get": {
+ "description": "Gets the supported microversions for this base url\n",
+ "responses": {
+ "200": {
+ "description": "Microversion information",
+ "schema": {
+ "type": "object",
+ "required": [
+ "version",
+ "minVersion"
+ ],
+ "properties": {
+ "version": {
+ "description": "The most recent version",
+ "type": "string"
+ },
+ "minVersion": {
+ "description": "The oldest supported version\n",
+ "type": "string"
+ },
+ "defaultVersion": {
+ "description": "The version that is served automatically if no version header is provided. Defaults to the minVersion if not given.\n",
+ "type": "string"
+ }
+ }
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "versions"
+ ],
+ "parameters": [
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ]
+ }
+ },
+ "/operation_executions/{operationExecutionId}": {
+ "get": {
+ "description": "Gets a single operation execution resource.",
+ "parameters": [
+ {
+ "$ref": "#/parameters/operationExecutionId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response, the operation is not executing.",
+ "schema": {
+ "$ref": "#/definitions/OperationExecution"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "202": {
+ "description": "Successful response, the operation is still ongoing.",
+ "schema": {
+ "$ref": "#/definitions/OperationExecution"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "operation_executions"
+ ]
+ }
+ },
+ "/operation_executions/{operationExecutionId}/end_notification": {
+ "get": {
+ "description": "Gets the lifecycle change notification correponding to the result of the operation if the execution has finished. **Nokia extension to ETSI NFV IFA007.**\n",
+ "parameters": [
+ {
+ "$ref": "#/parameters/operationExecutionId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response, the operation is finished",
+ "schema": {
+ "$ref": "#/definitions/AbstractVnfNotification"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "operation_executions"
+ ]
+ }
+ },
+ "/operation_executions/{operationExecutionId}/operation_params": {
+ "get": {
+ "description": "Gets the operation parameters correponding to the respective operation execution. **Nokia extension to ETSI NFV IFA007.**\n",
+ "parameters": [
+ {
+ "$ref": "#/parameters/operationExecutionId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "schema": {
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "operation_executions"
+ ]
+ }
+ },
+ "/operation_executions/{operationExecutionId}/additional_data": {
+ "get": {
+ "description": "Gets the implementation specific data corresponding to the respective operation execution. **Nokia extension to ETSI NFV IFA007.**\n",
+ "parameters": [
+ {
+ "$ref": "#/parameters/operationExecutionId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "schema": {
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "operation_executions"
+ ]
+ }
+ },
+ "/operation_executions/{operationExecutionId}/cancel": {
+ "post": {
+ "description": "Cancel the operation execution (if the operation supports it). This has no effect if the operation is not running. The state of the operation execution will change to FAILED when it has been canceled. **Nokia extension to ETSI NFV IFA007.**\n",
+ "parameters": [
+ {
+ "$ref": "#/parameters/operationExecutionId"
+ },
+ {
+ "name": "cancelOperationRequest",
+ "required": true,
+ "description": "Input parameters for the cancelling of an operation execution",
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/CancelOperationRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Operation execution canceled",
+ "schema": {
+ "$ref": "#/definitions/OperationExecution"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "202": {
+ "description": "Cancel is pending",
+ "schema": {
+ "$ref": "#/definitions/OperationExecution"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "400": {
+ "description": "Cancel for the given operation is not supported or not meaningful",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "operation_executions"
+ ]
+ }
+ },
+ "/vnfs": {
+ "post": {
+ "description": "Creates VNF object",
+ "parameters": [
+ {
+ "name": "createVnfRequest",
+ "description": "Parameters for the creation of a VNF instance",
+ "in": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/CreateVnfRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "Created VNF instance",
+ "headers": {
+ "Location": {
+ "description": "The url of the VNF instance",
+ "type": "string",
+ "format": "url"
+ },
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "schema": {
+ "$ref": "#/definitions/VnfInfo"
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ },
+ "get": {
+ "description": "Gets the list of VNF objects.\n",
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "schema": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfInfo"
+ }
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ],
+ "parameters": [
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}": {
+ "get": {
+ "description": "Gets VNF object",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/VnfInfo"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ },
+ "delete": {
+ "description": "Delete VNF instance from VNFM database. This can only be done if the VNF is not currently instantiated\n",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "204": {
+ "description": "Successful response",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ },
+ "patch": {
+ "description": "Modifies the VnfInfo. This corresponds to the ModifyVnfInfo operation in IFA007. **Due to the ongoing discussions in ETSI regarding the implementation of this operation, this operation specification should not be considered stable**\n",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "name": "modifyVnfInfoRequest",
+ "description": "Input parameters for VNF info modification",
+ "required": true,
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/ModifyVnfInfoRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "202": {
+ "$ref": "#/responses/operationExecutionCreated",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}/instantiate": {
+ "post": {
+ "description": "Instantiates VNF with the given parameters",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "name": "instantiateVnfRequest",
+ "required": true,
+ "description": "Input parameters for the instantiation of the VNF instance",
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/InstantiateVnfRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "202": {
+ "$ref": "#/responses/operationExecutionCreated",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}/scale": {
+ "post": {
+ "description": "Scales the VNF according to the given parameters",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "name": "scaleVnfRequest",
+ "description": "Input parameters for the scaling operation",
+ "required": true,
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/ScaleVnfRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "202": {
+ "$ref": "#/responses/operationExecutionCreated",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}/terminate": {
+ "post": {
+ "description": "Terminates the VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "name": "terminateVnfRequest",
+ "description": "Input parameters for VNF termination",
+ "required": true,
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/TerminateVnfRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "202": {
+ "$ref": "#/responses/operationExecutionCreated",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}/heal": {
+ "post": {
+ "description": "Heals the VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "name": "healVnfRequest",
+ "description": "Input parameters for VNF healing",
+ "required": true,
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/HealVnfRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "202": {
+ "$ref": "#/responses/operationExecutionCreated",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}/upgrade": {
+ "post": {
+ "description": "Upgrades the VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "name": "upgradeVnfRequest",
+ "description": "Input parameters for VNF upgrade",
+ "required": true,
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/UpgradeVnfRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "202": {
+ "$ref": "#/responses/operationExecutionCreated",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}/custom/{customOperationName}": {
+ "post": {
+ "description": "Executes custom operation. **Nokia VNFM proprietary extension.**\n",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "name": "customOperationName",
+ "in": "path",
+ "description": "The identifier of the custom operation",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "name": "customOperationRequest",
+ "description": "Input parameters for custom operation",
+ "required": true,
+ "in": "body",
+ "schema": {
+ "$ref": "#/definitions/CustomOperationRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "202": {
+ "$ref": "#/responses/operationExecutionCreated",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "vnfs"
+ ]
+ }
+ },
+ "/vnfs/{vnfInstanceId}/instantiated_vnf_info": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the requested instantiated info resource of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/InstantiatedVnfInfo"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/operation_executions": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the operation execution resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/OperationExecution"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/vnfc_resource_info": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the VNFC resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/VnfcResourceInfo"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/vnfc_resource_info/{vnfcId}": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the requested VNFC resource of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "description": "The identifier of the VNFC",
+ "required": true,
+ "type": "string",
+ "name": "vnfcId",
+ "in": "path"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/VnfcResourceInfo"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/virtual_link_resource_info": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the virtual link resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/VirtualLinkResourceInfo"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/virtual_link_resource_info/{virtualLinkId}": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the requested virtual link resource of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "description": "The identifier of the virtual link",
+ "required": true,
+ "type": "string",
+ "name": "virtualLinkId",
+ "in": "path"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/VirtualLinkResourceInfo"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/virtual_storage_resource_info": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the virtual storage resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/VirtualStorageResourceInfo"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/virtual_storage_resource_info/{virtualStorageId}": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the requested virtual storage resource of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "description": "The identifier of the virtual storage",
+ "required": true,
+ "type": "string",
+ "name": "virtualStorageId",
+ "in": "path"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/VirtualStorageResourceInfo"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/ext_cp_info": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the external connection points resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/VnfExtCpInfo"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/ext_cp_info/{extCpId}": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the requested external connection points resource of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "description": "The identifier of the external connection points",
+ "required": true,
+ "type": "string",
+ "name": "extCpId",
+ "in": "path"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/VnfExtCpInfo"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/ext_virtual_link_info": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the external virtual links resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/ExtVirtualLinkInfo"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/extensions": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the extension resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/VnfProperty"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/vnf_configurable_properties": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the configurable porperties resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/VnfProperty"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/scale_status": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the scaling aspect resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/ScaleInfo"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/scale_status/{scalingAspectId}": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the requested scaling aspect resource of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "description": "The identifier of the scaling aspect",
+ "required": true,
+ "type": "string",
+ "name": "scalingAspectId",
+ "in": "path"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/ScaleInfo"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/vim_info": {
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the vim info resources of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "items": {
+ "$ref": "#/definitions/VimInfo"
+ },
+ "type": "array"
+ }
+ }
+ }
+ }
+ },
+ "/vnfs/{vnfInstanceId}/vim_info/{vimId}": {
+ "put": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Updates the specific vim info resource",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "description": "The identifier of the vim info",
+ "required": true,
+ "type": "string",
+ "name": "vimId",
+ "in": "path"
+ },
+ {
+ "schema": {
+ "$ref": "#/definitions/VimInfo"
+ },
+ "required": true,
+ "name": "updated resource",
+ "in": "body"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/VimInfo"
+ }
+ }
+ }
+ },
+ "get": {
+ "tags": [
+ "vnfs"
+ ],
+ "description": "Gets the requested vim info resource of a VNF",
+ "parameters": [
+ {
+ "$ref": "#/parameters/vnfInstanceId"
+ },
+ {
+ "description": "The identifier of the vim info",
+ "required": true,
+ "type": "string",
+ "name": "vimId",
+ "in": "path"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ },
+ "200": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/VimInfo"
+ }
+ }
+ }
+ }
+ }
+ },
+ "parameters": {
+ "vnfInstanceId": {
+ "name": "vnfInstanceId",
+ "in": "path",
+ "description": "The identifier of the VNF instance",
+ "required": true,
+ "type": "string"
+ },
+ "operationExecutionId": {
+ "name": "operationExecutionId",
+ "in": "path",
+ "description": "The identifier of the operation execution",
+ "required": true,
+ "type": "string"
+ }
+ },
+ "responses": {
+ "operationExecutionCreated": {
+ "description": "Created operation execution",
+ "headers": {
+ "Location": {
+ "description": "The url of the operation execution",
+ "type": "string",
+ "format": "url"
+ }
+ },
+ "schema": {
+ "$ref": "#/definitions/OperationExecution"
+ }
+ }
+ },
+ "definitions": {
+ "CreateVnfRequest": {
+ "type": "object",
+ "required": [
+ "vnfdId"
+ ],
+ "properties": {
+ "vnfdId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "name": {
+ "description": "The name of the vnf instance\n",
+ "type": "string"
+ },
+ "description": {
+ "description": "The description string of the vnf instance\n",
+ "type": "string"
+ }
+ }
+ },
+ "InstantiateVnfRequest": {
+ "type": "object",
+ "required": [
+ "flavourId",
+ "vims",
+ "extVirtualLinks"
+ ],
+ "properties": {
+ "flavourId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "instantiationLevelId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "vims": {
+ "description": "Vim information given for instantiation (in this API version only one VIM per VNF is supported). **Nokia extension to ETSI NFV IFA007.** **The vim information is factored out from the external virtual link data structure.**\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VimInfo"
+ }
+ },
+ "extVirtualLinks": {
+ "description": "References to external virtual links to connect the VNF to.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtVirtualLinkData"
+ }
+ },
+ "extManagedVirtualLinks": {
+ "description": "References to internal virtual links that are managed by other entities than the VNFM\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtManagedVirtualLinkData"
+ }
+ },
+ "localizationLanguage": {
+ "type": "string"
+ },
+ "additionalParams": {
+ "description": "Additional parameters passed by the NFVO as input to the instantiation process, specific to the VNF being instantiated.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "grantlessMode": {
+ "description": "**Nokia VNFM proprietary property.** The NOKIA VNFM API may be used in an environment without an NFVO. This switch determines whether the VNFM should operate without requesting grants from an NFVO. In this case all information that would be passed in the grant responses needs to be passed with the instantiation parameters. The value of this switch applies to all subsequent operations until the VNF is terminated. **Note: Actual grant support is not currently part of the NOKIA VNFM API specification**\n",
+ "type": "boolean",
+ "default": false
+ },
+ "computeResourceFlavours": {
+ "description": "**Nokia VNFM proprietary property.** Mappings between VirtualComputeDescriptors defined in the VNFD and compute resource flavours managed in the VIM. **Only used in grantless operation mode.**\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VimComputeResourceFlavour"
+ }
+ },
+ "softwareImages": {
+ "description": "**Nokia VNFM proprietary property.** Mappings between software images defined in the VNFD and software images managed in the VIM. **Only used in grantless operation mode.**\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VimSoftwareImage"
+ }
+ },
+ "zones": {
+ "description": "**Nokia VNFM proprietary property.** Identifies resource zones where the resources are approved to be allocated by the VNFM. **Only used in grantless operation mode.**\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ZoneInfo"
+ }
+ }
+ }
+ },
+ "OperationExecution": {
+ "description": "**Apart from id and status, all other fields represent Nokia extensions to IFA007.** The operation end notification can be retrieved as sub-resource of the operation execution resource itself. Additionally all the input parameters for the operation are stored.\n",
+ "type": "object",
+ "required": [
+ "vnfInstanceId",
+ "operationType",
+ "status",
+ "id",
+ "startTime",
+ "isCancelPending"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "vnfInstanceId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "operationType": {
+ "description": "Type of the operation that this structure is related to\n",
+ "$ref": "#/definitions/OperationType"
+ },
+ "operationName": {
+ "description": "Name of the operation (mostly useful for distinguishing custom operations)\n",
+ "type": "string"
+ },
+ "status": {
+ "description": "Execution status of the operation that this structure is related to\n",
+ "$ref": "#/definitions/OperationStatus"
+ },
+ "isCancelPending": {
+ "description": "If the LCM operation occurrence is in executing state and the operation is being cancelled, this attribute shall be set to true. Otherwise, it shall be set to false.\n",
+ "type": "boolean"
+ },
+ "cancelMode": {
+ "$ref": "#/definitions/CancelMode"
+ },
+ "error": {
+ "description": "If the status of the notification is \"finished\" and there was error during the execution, then it will be reported in this field\n",
+ "$ref": "#/definitions/ProblemDetails"
+ },
+ "startTime": {
+ "description": "Date-time of the beginning of the operation execution (formatted according to RFC-3339)\n",
+ "type": "string",
+ "format": "date-time"
+ },
+ "finishTime": {
+ "description": "Date-time of the end of the operation execution (formatted according to RFC-3339)\n",
+ "type": "string",
+ "format": "date-time"
+ },
+ "grantId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "operationParams": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Original input parameters for the operation.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "additionalData": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Implementation-specific data for the execution, e.g. internal workflow id.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "metadata": {
+ "description": "Additional metadata related to the operation execution.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "operationParams": {
+ "$ref": "#/definitions/Link"
+ },
+ "additionalData": {
+ "$ref": "#/definitions/Link"
+ },
+ "list": {
+ "$ref": "#/definitions/Link"
+ },
+ "cancel": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnf": {
+ "$ref": "#/definitions/Link"
+ },
+ "endNotification": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ },
+ "CancelMode": {
+ "type": "string",
+ "description": "Cancellation mode.\n",
+ "enum": [
+ "GRACEFUL",
+ "FORCEFUL"
+ ]
+ },
+ "CancelOperationRequest": {
+ "type": "object",
+ "required": [
+ "cancelMode"
+ ],
+ "properties": {
+ "cancelMode": {
+ "$ref": "#/definitions/CancelMode"
+ }
+ }
+ },
+ "TerminateVnfRequest": {
+ "type": "object",
+ "required": [
+ "terminationType"
+ ],
+ "properties": {
+ "terminationType": {
+ "description": "Signals whether forceful or graceful termination is requested. In case of forceful termination, the VNF is shut down immediately, and resources are released. Note that if the VNF is still in service, this may adversely impact network service, and therefore, operator policies apply to determine if forceful termination is allowed in the particular situation. In case of graceful termination, the VNFM first arranges to take the VNF out of service (by means out of scope of the present specification, e.g. involving interaction with EM, if required). Once this was successful, or after a timeout, the VNFM shuts down the VNF and releases the resources.\n",
+ "$ref": "#/definitions/TerminationType"
+ },
+ "gracefulTerminationTimeout": {
+ "description": "The time interval (in seconds) to wait for the VNF to be taken out of service during graceful termination, before shutting down the VNF and releasing the resources. If not given, it is expected that the VNFM waits for the successful taking out of service of the VNF, no matter how long it takes, before shutting down the VNF and releasing the resources (see note). Minimum timeout or timeout range are specified by the VNF Provider (e.g. defined in the VNFD or communicated by other means). Not relevant in case of forceful termination.\n",
+ "type": "integer"
+ },
+ "additionalParams": {
+ "description": "Additional parameters passed by the NFVO as input to the scaling process. **Nokia extension to ETSI NFV IFA007.**\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ }
+ }
+ },
+ "TerminationType": {
+ "type": "string",
+ "enum": [
+ "GRACEFUL",
+ "FORCEFUL"
+ ]
+ },
+ "ScaleVnfRequest": {
+ "type": "object",
+ "required": [
+ "type",
+ "aspectId"
+ ],
+ "properties": {
+ "type": {
+ "description": "Defines the type of the scale operation requested (scale out, scale in). The set of types actually supported depends on the capabilities of the VNF being managed, as declared in the VNFD.\n",
+ "$ref": "#/definitions/ScaleDirection"
+ },
+ "aspectId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "numberOfSteps": {
+ "description": "Number of scaling steps to be executed as part of this ScaleVnf operation. It shall be a positive number. Defaults to 1.\n",
+ "type": "integer",
+ "default": 1
+ },
+ "additionalParams": {
+ "description": "Additional parameters passed by the NFVO as input to the scaling process.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ }
+ }
+ },
+ "ScaleDirection": {
+ "type": "string",
+ "enum": [
+ "OUT",
+ "IN"
+ ]
+ },
+ "HealVnfRequest": {
+ "type": "object",
+ "properties": {
+ "cause": {
+ "description": "Indicates the reason why a healing procedure is required.\n",
+ "type": "string"
+ },
+ "additionalParams": {
+ "description": "Additional parameters passed by the NFVO as input to the healing process, specific to the VNF being healed.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ }
+ }
+ },
+ "UpgradeVnfRequest": {
+ "description": "**Nokia extension to ETSI NFV IFA007**\n",
+ "type": "object",
+ "required": [
+ "vnfdId"
+ ],
+ "properties": {
+ "vnfdId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "add": {
+ "description": "New external resource information to be added (to the usable set of external resources for the VNF) according to the requirements of the new VNFD.\n",
+ "$ref": "#/definitions/UpgradeAddResources"
+ },
+ "remove": {
+ "description": "External resource information to be removed (from the usable set of external resources for the VNF) according to the requirements of the new VNFD. Resources currently used by the VNF cannot be removed.\n",
+ "$ref": "#/definitions/UpgradeRemoveResources"
+ },
+ "modify": {
+ "description": "External resource information and parameters to be modified according to the requirements of the new VNFD\n",
+ "$ref": "#/definitions/UpgradeModifyResources"
+ },
+ "additionalParams": {
+ "description": "Additional parameters passed to the upgrade process, specific to the VNF being upgraded and the new VNFD.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ }
+ }
+ },
+ "UpgradeAddResources": {
+ "type": "object",
+ "properties": {
+ "extVirtualLinks": {
+ "description": "External virtual link information and external connection point information to add (including new addresses to use)\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtVirtualLinkData"
+ }
+ },
+ "extManagedVirtualLinks": {
+ "description": "External managed virtual links to add.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtManagedVirtualLinkData"
+ }
+ },
+ "zones": {
+ "description": "Zones to add. Only used in grantless mode.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ZoneInfo"
+ }
+ }
+ }
+ },
+ "UpgradeRemoveResources": {
+ "type": "object",
+ "properties": {
+ "extVirtualLinks": {
+ "description": "External virtual link information and external connection point information to remove (including addresses to remove)\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtVirtualLinkData"
+ }
+ },
+ "extManagedVirtualLinks": {
+ "description": "External managed virtual links to remove.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtManagedVirtualLinkData"
+ }
+ },
+ "zones": {
+ "description": "Zones to remove. Only used in grantless mode.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ZoneInfo"
+ }
+ }
+ }
+ },
+ "UpgradeModifyResources": {
+ "type": "object",
+ "properties": {
+ "computeResourceFlavours": {
+ "description": "Mappings between VirtualComputeDescriptors defined in the (new) VNFD and compute resource flavours managed in the VIM. If applicable, existing VNFCs should be changed to use these compute resource flavours.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VimComputeResourceFlavour"
+ }
+ },
+ "softwareImages": {
+ "description": "Mappings between software images defined in the (new) VNFD and software images managed in the VIM. If applicable, existing VNFCs should be changed to use these software images.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VimSoftwareImage"
+ }
+ },
+ "extensions": {
+ "description": "The new extension values that should be set. These extensions may affect the upgrade and should take into consideration the extension set provided by the new VNFD\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfProperty"
+ }
+ }
+ }
+ },
+ "CustomOperationRequest": {
+ "type": "object",
+ "properties": {
+ "additionalParams": {
+ "description": "Additional parameters passed by the NFVO as input to the custom operation.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ }
+ }
+ },
+ "VnfInfo": {
+ "description": "Information about a VNF instance.\n",
+ "type": "object",
+ "required": [
+ "id",
+ "vnfdId",
+ "vnfSoftwareVersion",
+ "vnfdVersion",
+ "onboardedVnfPkgInfoId",
+ "instantiationState"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "name": {
+ "description": "VNF instance name.\n",
+ "type": "string"
+ },
+ "description": {
+ "description": "Human-readable description of the VNF instance.\n",
+ "type": "string"
+ },
+ "vnfdId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "vnfProvider": {
+ "description": "Name of the person or company providing the VNF.\n",
+ "type": "string"
+ },
+ "vnfProductName": {
+ "description": "Name of the Vnf prodct.\n",
+ "type": "string"
+ },
+ "vnfSoftwareVersion": {
+ "type": "string"
+ },
+ "vnfdVersion": {
+ "type": "string"
+ },
+ "onboardedVnfPkgInfoId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "instantiationState": {
+ "description": "Current state of the instantiation of the VNF\n",
+ "$ref": "#/definitions/InstantiationState"
+ },
+ "operationExecutions": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Operations executed on the VNF instance\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/OperationExecution"
+ }
+ },
+ "instantiatedVnfInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Information specific to an instantiated VNF instance.\n",
+ "$ref": "#/definitions/InstantiatedVnfInfo"
+ },
+ "vnfConfigurableProperties": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Current values of the configurable properties of the VNF instance.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfProperty"
+ }
+ },
+ "extensions": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** VNF-specific attributes.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfProperty"
+ }
+ },
+ "metadata": {
+ "description": "Additional metadata describing the VNF instance.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "operationExecutions": {
+ "$ref": "#/definitions/Link"
+ },
+ "instantiatedVnfInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnfConfigurableProperties": {
+ "$ref": "#/definitions/Link"
+ },
+ "extensions": {
+ "$ref": "#/definitions/Link"
+ },
+ "list": {
+ "$ref": "#/definitions/Link"
+ },
+ "delete": {
+ "$ref": "#/definitions/Link"
+ },
+ "instantiate": {
+ "$ref": "#/definitions/Link"
+ },
+ "scale": {
+ "$ref": "#/definitions/Link"
+ },
+ "terminate": {
+ "$ref": "#/definitions/Link"
+ },
+ "modifyInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "heal": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ },
+ "InstantiationState": {
+ "type": "string",
+ "enum": [
+ "NOT_INSTANTIATED",
+ "INSTANTIATED"
+ ]
+ },
+ "InstantiatedVnfInfo": {
+ "type": "object",
+ "required": [
+ "flavourId",
+ "vnfState"
+ ],
+ "properties": {
+ "flavourId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "localizationLanguage": {
+ "type": "string"
+ },
+ "vnfState": {
+ "description": "The state of the VNF instance.\n",
+ "$ref": "#/definitions/VnfState"
+ },
+ "scaleStatus": {
+ "description": "Scale status of the VNF, one entry per aspect. Shall be present if the VNF supports scaling.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ScaleInfo"
+ }
+ },
+ "extCpInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** External connection points exposed by the VNF instance.\n",
+ "type": "array",
+ "minItems": 1,
+ "items": {
+ "$ref": "#/definitions/VnfExtCpInfo"
+ }
+ },
+ "extVirtualLinkInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** External virtual links the VNF instance is connected to.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtVirtualLinkInfo"
+ }
+ },
+ "extManagedVirtualLinkInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** External virtual links the VNF instance is connected to.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ExtManagedVirtualLinkInfo"
+ }
+ },
+ "vimInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Information about VIM(s) that manage resources for the VNF instance.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VimInfo"
+ }
+ },
+ "vnfcResourceInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Information on the virtualised compute and storage resource(s) used by the VNFCs of the VNF instance.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfcResourceInfo"
+ }
+ },
+ "virtualLinkResourceInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Information on the virtualised network resource(s) used by the VLs of the VNF instance.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VirtualLinkResourceInfo"
+ }
+ },
+ "virtualStorageResourceInfo": {
+ "description": "**This property is only returned when the containing resource is queried by id and not listed.** Information on the virtualised storage resource(s) used as storage for the VNF instance.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VirtualStorageResourceInfo"
+ }
+ },
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "extCpInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "extVirtualLinkInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "extManagedVirtualLinkInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "vimInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnfcResourceInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "virtualLinkResourceInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "virtualStorageResourceInfo": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnf": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ },
+ "VnfcResourceInfo": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVnfcResourceInfo"
+ },
+ {
+ "type": "object",
+ "properties": {
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnf": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ }
+ ]
+ },
+ "VirtualLinkResourceInfo": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVirtualLinkResourceInfo"
+ },
+ {
+ "type": "object",
+ "properties": {
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnf": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ }
+ ]
+ },
+ "VirtualStorageResourceInfo": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVirtualStorageResourceInfo"
+ },
+ {
+ "type": "object",
+ "properties": {
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnf": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ }
+ ]
+ },
+ "ExtVirtualLinkInfo": {
+ "type": "object",
+ "required": [
+ "resource"
+ ],
+ "properties": {
+ "extVirtualLinkId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "resource": {
+ "description": "The resource realizing this VL.\n",
+ "$ref": "#/definitions/ResourceInfo"
+ },
+ "linkPorts": {
+ "description": "Link ports of this VL.\n",
+ "type": "array",
+ "minItems": 1,
+ "items": {
+ "$ref": "#/definitions/VnfLinkPort"
+ }
+ }
+ }
+ },
+ "ExtManagedVirtualLinkInfo": {
+ "type": "object",
+ "required": [
+ "virtualLinkResourceInfoId"
+ ],
+ "properties": {
+ "extManagedVirtualLinkId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "virtualLinkResourceInfoId": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ },
+ "linkPorts": {
+ "description": "Link ports of this VL. This is optional even if there are linkports allocated to this VL.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfLinkPort"
+ }
+ }
+ }
+ },
+ "VnfLinkPort": {
+ "type": "object",
+ "required": [
+ "resource"
+ ],
+ "properties": {
+ "resource": {
+ "description": "Identifier of the virtualised network resource realizing this link port.\n",
+ "$ref": "#/definitions/ResourceHandle"
+ },
+ "cpInstanceId": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ }
+ }
+ },
+ "VnfExtCpInfo": {
+ "type": "object",
+ "required": [
+ "id",
+ "cpdId"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ },
+ "cpdId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "addresses": {
+ "description": "List of network addresses configured on the connection point instance.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/NetworkAddress"
+ }
+ },
+ "metadata": {
+ "description": "**Nokia extension to ETSI NFV IFA007.** Metadata for the external connection point.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnf": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ },
+ "VnfState": {
+ "type": "string",
+ "enum": [
+ "STARTED",
+ "STOPPED",
+ "ERROR"
+ ]
+ },
+ "ScaleInfo": {
+ "required": [
+ "aspect",
+ "scaleLevel"
+ ],
+ "type": "object",
+ "properties": {
+ "aspect": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "scaleLevel": {
+ "description": "Current level of the scaling aspect.\n",
+ "type": "integer"
+ },
+ "maxScaleLevel": {
+ "description": "**Nokia VNFM proprietary property.** The maximum level that the scaling aspect can have.\n",
+ "type": "integer"
+ },
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "vnf": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ },
+ "Link": {
+ "type": "object",
+ "required": [
+ "href"
+ ],
+ "properties": {
+ "href": {
+ "description": "The URL that references the target resource.\n",
+ "type": "string",
+ "format": "url"
+ }
+ }
+ },
+ "AbstractVnfNotification": {
+ "description": "This is a base type that has derivatives. In all places where it is referenced the following types should be expected: ['VnfIdentifierCreationNotification', 'VnfIdentifierDeletionNotification', 'OtherNotification', 'VnfInfoAttributeValueChangeNotification', 'VnfLifecycleChangeNotification']. The actual type is determined by the field 'notificationType' which contains the type name.",
+ "type": "object",
+ "required": [
+ "notificationType",
+ "vnfInstanceId",
+ "timestamp"
+ ],
+ "discriminator": "notificationType",
+ "properties": {
+ "notificationType": {
+ "description": "discriminator type for different notifications",
+ "$ref": "#/definitions/VnfNotificationType"
+ },
+ "subscriptionId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "timestamp": {
+ "description": "Date-time of the generation of the notification (formatted according to RFC-3339)\n",
+ "type": "string",
+ "format": "date-time"
+ },
+ "vnfInstanceId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ }
+ }
+ },
+ "VnfIdentifierCreationNotification": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVnfNotification"
+ }
+ ]
+ },
+ "VnfIdentifierDeletionNotification": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVnfNotification"
+ }
+ ]
+ },
+ "OtherNotification": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVnfNotification"
+ },
+ {
+ "type": "object"
+ }
+ ]
+ },
+ "VnfProperty": {
+ "type": "object",
+ "required": [
+ "name",
+ "value"
+ ],
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ },
+ "properties": {
+ "name": {
+ "description": "The name of the respective property\n",
+ "type": "string"
+ },
+ "description": {
+ "description": "The description of the respective property\n",
+ "type": "string"
+ },
+ "value": {
+ "description": "Any json value\n",
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ],
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ }
+ }
+ },
+ "ModifyVnfInfoRequest": {
+ "description": "Contents of the ModifyVnfInfoRequest will be merged with VnfInfo according to JSON Merge Patch (RFC 7396) with the following extensions: VnfProperty arrays can be selectively updated with the given properties, also extensions and vnfConfigurableProperties cannot be deleted or added\n",
+ "type": "object",
+ "properties": {
+ "name": {
+ "description": "The new name to be set for the VNF instance\n",
+ "type": "string"
+ },
+ "description": {
+ "description": "The new description to be set for the VNF instance\n",
+ "type": "string"
+ },
+ "metadata": {
+ "description": "The new metadata to be set for the VNF instance.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "vnfConfigurableProperties": {
+ "description": "The new configurable properties that should be set. (Configurable properties that are not provided won't be modified.)\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfProperty"
+ }
+ },
+ "extensions": {
+ "description": "New extension values that should be set. (Extensions that are not provided won't be modified.)\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfProperty"
+ }
+ }
+ }
+ },
+ "AttributeValueChanges": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/ModifyVnfInfoRequest"
+ },
+ {
+ "type": "object",
+ "properties": {
+ "vnfdId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "vnfProvider": {
+ "description": "Name of the person or company providing the VNF. **Inclusion of this field means that the respective value changed as a result of a template package update on the VNF instance.**\n",
+ "type": "string"
+ },
+ "vnfProductName": {
+ "description": "Name of the Vnf prodct. **Inclusion of this field means that the respective value changed as a result of a template package update on the VNF instance.**\n",
+ "type": "string"
+ },
+ "vnfSoftwareVersion": {
+ "type": "string"
+ },
+ "vnfdVersion": {
+ "type": "string"
+ },
+ "onboardedVnfPkgInfoId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "VnfInfoAttributeValueChangeNotification": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVnfNotification"
+ },
+ {
+ "type": "object",
+ "required": [
+ "changedInfo"
+ ],
+ "properties": {
+ "changedInfo": {
+ "$ref": "#/definitions/AttributeValueChanges"
+ }
+ }
+ }
+ ]
+ },
+ "VnfLifecycleChangeNotification": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVnfNotification"
+ },
+ {
+ "type": "object",
+ "required": [
+ "operation",
+ "status",
+ "lifecycleOperationOccurrenceId"
+ ],
+ "properties": {
+ "lifecycleOperationOccurrenceId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "operation": {
+ "description": "Type of the operation that this structure is related to\n",
+ "$ref": "#/definitions/OperationType"
+ },
+ "status": {
+ "description": "Execution status of the operation that this structure is related to\n",
+ "$ref": "#/definitions/OperationStatus"
+ },
+ "error": {
+ "description": "If the status of the notification is \"finished\" and there was error during the execution, then it will be reported in this field\n",
+ "$ref": "#/definitions/ProblemDetails"
+ },
+ "affectedVnfcs": {
+ "description": "Information about VNFC instances that were affected during the lifecycle operation, if this notification represents the result of a lifecycle operation.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/AffectedVnfc"
+ }
+ },
+ "affectedVirtualLinks": {
+ "description": "Information about VL instances that were affected during the lifecycle operation, if this notification represents the result of a lifecycle operation.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/AffectedVirtualLink"
+ }
+ },
+ "affectedVirtualStorages": {
+ "description": "Information about virtualised storage instances that were affected during the lifecycle operation, if this notification represents the result of a lifecycle operation.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/AffectedVirtualStorage"
+ }
+ }
+ }
+ }
+ ]
+ },
+ "OperationStatus": {
+ "description": "**FINISHED** means successful completion as opposed to FAILED, which means unsuccessful completion of the operation. **OTHER** is reserved for forward compatibility with later microversions.\n",
+ "type": "string",
+ "enum": [
+ "STARTED",
+ "FINISHED",
+ "FAILED",
+ "OTHER"
+ ]
+ },
+ "AbstractVnfcResourceInfo": {
+ "description": "Abstract type, not used in itself\n",
+ "type": "object",
+ "required": [
+ "id",
+ "vduId",
+ "computeResource"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ },
+ "vduId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "computeResource": {
+ "description": "The compute resource in the VIM\n",
+ "$ref": "#/definitions/ResourceHandle"
+ },
+ "storageResourceIds": {
+ "description": "Instance identifiers of associated storage resources\n",
+ "type": "array",
+ "items": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ }
+ }
+ }
+ },
+ "AbstractVirtualLinkResourceInfo": {
+ "description": "Abstract type, not used in itself\n",
+ "type": "object",
+ "required": [
+ "id",
+ "virtualLinkDescId"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ },
+ "virtualLinkDescId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "resource": {
+ "description": "The network resource in the VIM\n",
+ "$ref": "#/definitions/ResourceHandle"
+ }
+ }
+ },
+ "AbstractVirtualStorageResourceInfo": {
+ "description": "Abstract type, not used in itself\n",
+ "type": "object",
+ "required": [
+ "id",
+ "virtualStorageDescId"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ },
+ "virtualStorageDescId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "resource": {
+ "description": "The storage resource in the VIM\n",
+ "$ref": "#/definitions/ResourceHandle"
+ }
+ }
+ },
+ "ChangedResource": {
+ "type": "object",
+ "required": [
+ "changeType"
+ ],
+ "properties": {
+ "changeType": {
+ "description": "The type of change of the resource\n",
+ "$ref": "#/definitions/ChangeType"
+ }
+ }
+ },
+ "AffectedVnfc": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVnfcResourceInfo"
+ },
+ {
+ "$ref": "#/definitions/ChangedResource"
+ }
+ ]
+ },
+ "AffectedVirtualLink": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVirtualLinkResourceInfo"
+ },
+ {
+ "$ref": "#/definitions/ChangedResource"
+ }
+ ]
+ },
+ "AffectedVirtualStorage": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/AbstractVirtualStorageResourceInfo"
+ },
+ {
+ "$ref": "#/definitions/ChangedResource"
+ }
+ ]
+ },
+ "ChangeType": {
+ "type": "string",
+ "enum": [
+ "ADDED",
+ "REMOVED",
+ "MODIFIED"
+ ]
+ },
+ "EndpointInfo": {
+ "type": "object",
+ "required": [
+ "endpoint"
+ ],
+ "properties": {
+ "endpoint": {
+ "description": "The url representing the interface endpoint.\n",
+ "type": "string",
+ "format": "url"
+ },
+ "trustedCertificates": {
+ "description": "A collection of base64 encoded certificates to be trusted in relation to the endpoint.\n",
+ "type": "array",
+ "items": {
+ "type": "string",
+ "format": "byte"
+ }
+ },
+ "skipCertificateVerification": {
+ "description": "Certificate verification for the endpoint can be skipped by setting this field to true. (Only meaningful for connections with certificate exchange)\n",
+ "type": "boolean",
+ "default": false
+ },
+ "skipCertificateHostnameCheck": {
+ "description": "Certificate hostname check for the endpoint can be skipped by setting this field to true. (Only meaningful for connections with certificate exchange)\n",
+ "type": "boolean",
+ "default": false
+ }
+ }
+ },
+ "UsernamePassword": {
+ "type": "object",
+ "required": [
+ "username"
+ ],
+ "properties": {
+ "username": {
+ "description": "the username to use for access\n",
+ "type": "string"
+ },
+ "password": {
+ "description": "the password to use for access. **Note: required for input, not returned on output**\n",
+ "type": "string",
+ "format": "password"
+ }
+ }
+ },
+ "VimInfo": {
+ "type": "object",
+ "required": [
+ "id",
+ "vimInfoType"
+ ],
+ "discriminator": "vimInfoType",
+ "properties": {
+ "id": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "vimInfoType": {
+ "description": "**Nokia extension to ETSI NFV IFA007.** Type of the VIM info structure. This field will be used as a discriminator for different types of VIMs. OTHER_VIM_INFO is provided for forward compatibility with later microversions of the API.\n",
+ "type": "string",
+ "enum": [
+ "OPENSTACK_V2_INFO",
+ "OPENSTACK_V3_INFO",
+ "VMWARE_VCLOUD_INFO",
+ "OTHER_VIM_INFO"
+ ]
+ }
+ },
+ "description": "This is a base type that has derivatives. In all places where it is referenced the following types should be expected: ['OPENSTACK_V2_INFO', 'OPENSTACK_V3_INFO', 'VMWARE_VCLOUD_INFO', 'OTHER_VIM_INFO']. The actual type is determined by the field 'vimInfoType' which contains the type name."
+ },
+ "OPENSTACK_V2_INFO": {
+ "description": "OpenStack connection information for Keystone V2\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/VimInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "interfaceInfo",
+ "accessInfo"
+ ],
+ "properties": {
+ "interfaceInfo": {
+ "description": "The Keystone endpoint information\n",
+ "$ref": "#/definitions/EndpointInfo"
+ },
+ "accessInfo": {
+ "description": "Access information for Keystone V2\n",
+ "$ref": "#/definitions/OpenStackAccessInfoV2"
+ }
+ }
+ }
+ ]
+ },
+ "OPENSTACK_V3_INFO": {
+ "description": "OpenStack connection information for Keystone V3\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/VimInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "interfaceInfo",
+ "accessInfo"
+ ],
+ "properties": {
+ "interfaceInfo": {
+ "description": "The Keystone endpoint information\n",
+ "$ref": "#/definitions/EndpointInfo"
+ },
+ "accessInfo": {
+ "description": "Access information for Keystone V3\n",
+ "$ref": "#/definitions/OpenStackAccessInfoV3"
+ }
+ }
+ }
+ ]
+ },
+ "OpenStackAccessInfoV2": {
+ "description": "OpenStack access information for Keystone V2\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/UsernamePassword"
+ },
+ {
+ "type": "object",
+ "required": [
+ "region",
+ "tenant"
+ ],
+ "properties": {
+ "region": {
+ "description": "The OpenStack region to use for the VIM connection\n",
+ "type": "string"
+ },
+ "tenant": {
+ "description": "The OpenStack tenant to use for the VIM connection\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "OpenStackAccessInfoV3": {
+ "description": "OpenStack access information for Keystone V3\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/UsernamePassword"
+ },
+ {
+ "type": "object",
+ "required": [
+ "region",
+ "project",
+ "domain"
+ ],
+ "properties": {
+ "region": {
+ "description": "The OpenStack region to use for the VIM connection\n",
+ "type": "string"
+ },
+ "project": {
+ "description": "The OpenStack project to use for the VIM connection\n",
+ "type": "string"
+ },
+ "domain": {
+ "description": "The OpenStack domain to use for the VIM connection\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "VMWARE_VCLOUD_INFO": {
+ "description": "Connection information for a VMware vCloud with optional vROPS support\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/VimInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "interfaceInfo",
+ "accessInfo"
+ ],
+ "properties": {
+ "interfaceInfo": {
+ "description": "Interface information for the vCloud endpoint\n",
+ "$ref": "#/definitions/EndpointInfo"
+ },
+ "accessInfo": {
+ "$ref": "#/definitions/VCloudAccessInfo"
+ }
+ }
+ }
+ ]
+ },
+ "VCloudAccessInfo": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/UsernamePassword"
+ },
+ {
+ "type": "object",
+ "required": [
+ "organization"
+ ],
+ "properties": {
+ "organization": {
+ "description": "The organization to use for the VIM connection\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "OTHER_VIM_INFO": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/VimInfo"
+ },
+ {
+ "type": "object"
+ }
+ ]
+ },
+ "ZoneInfo": {
+ "description": "**Nokia change to ETSI NFV IFA007: zoneInfoId and zoneId merged into id.**\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/ResourceInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "id"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier that is unique for the respective type within a VNF instance, but may not be globally unique.\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "VimComputeResourceFlavour": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/ResourceInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "vnfdVirtualComputeDescId"
+ ],
+ "properties": {
+ "vnfdVirtualComputeDescId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "VimSoftwareImage": {
+ "allOf": [
+ {
+ "$ref": "#/definitions/ResourceInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "vnfdSoftwareImageId"
+ ],
+ "properties": {
+ "vnfdSoftwareImageId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "ExtManagedVirtualLinkData": {
+ "description": "**Nokia change to ETSI NFV IFA007: factored out vim info.**\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/ResourceInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "virtualLinkDescId"
+ ],
+ "properties": {
+ "extManagedVirtualLinkId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "virtualLinkDescId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ }
+ }
+ }
+ ]
+ },
+ "ExtVirtualLinkData": {
+ "description": "**Nokia change to ETSI NFV IFA007: factored out vim info.**\n",
+ "allOf": [
+ {
+ "$ref": "#/definitions/ResourceInfo"
+ },
+ {
+ "type": "object",
+ "required": [
+ "extCps"
+ ],
+ "properties": {
+ "extVirtualLinkId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "extCps": {
+ "description": "External connection points of the VNF to be connected to this virtual link.\n",
+ "type": "array",
+ "minItems": 1,
+ "items": {
+ "$ref": "#/definitions/VnfExtCpData"
+ }
+ }
+ }
+ }
+ ]
+ },
+ "VnfExtCpData": {
+ "type": "object",
+ "required": [
+ "cpdId"
+ ],
+ "properties": {
+ "cpdId": {
+ "description": "An identifier that is unique within a VNF descriptor.\n",
+ "type": "string"
+ },
+ "addresses": {
+ "description": "List of (fixed) network addresses that need to be configured on the connection point. It shall be provided for configuring fixed addresses.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/NetworkAddress"
+ }
+ },
+ "numDynamicAddresses": {
+ "description": "Number of dynamic addresses that may be allocated for the external connection point\n",
+ "type": "integer"
+ }
+ }
+ },
+ "NetworkAddress": {
+ "description": "A type representing network addresses",
+ "type": "object",
+ "properties": {
+ "subnetId": {
+ "type": "string"
+ },
+ "ip": {
+ "type": "string"
+ },
+ "mac": {
+ "type": "string"
+ }
+ }
+ },
+ "OperationType": {
+ "type": "string",
+ "enum": [
+ "INSTANTIATE",
+ "SCALE",
+ "SCALE_TO_LEVEL",
+ "MODIFY_INFO",
+ "CHANGE_FLAVOUR",
+ "OPERATE",
+ "HEAL",
+ "UPGRADE",
+ "TERMINATE",
+ "OTHER"
+ ]
+ },
+ "ResourceInfo": {
+ "required": [
+ "resourceId"
+ ],
+ "type": "object",
+ "description": "VIM and VIM-related identification for resources. Only direct mode is supported.\n",
+ "properties": {
+ "vimId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "resourceId": {
+ "description": "An identifier maintained by the VIM or other resource provider. It is expected to be unique within the VIM instance.\n",
+ "type": "string"
+ }
+ }
+ },
+ "ResourceHandle": {
+ "required": [
+ "resourceId"
+ ],
+ "type": "object",
+ "description": "VIM and VIM-related identification for resources. **Nokia VNFM specific change: only direct mode is supported, so resourceProviderId is removed.**\n",
+ "properties": {
+ "vimId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "resourceId": {
+ "description": "An identifier maintained by the VIM or other resource provider. It is expected to be unique within the VIM instance.\n",
+ "type": "string"
+ },
+ "resourceType": {
+ "description": "**Nokia extension to ETSI NFV IFA007.** Type of the resource on the VIM. Possible values are implementation dependent and not detailed in this API.\n",
+ "type": "string"
+ },
+ "additionalData": {
+ "description": "**Nokia extension to ETSI NFV IFA007.** VIM-specific resource representation. Intended for debugging and presentational purposes. Contents of this property are VIM- and implementation specific and should not be relied upon.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ },
+ "metadata": {
+ "description": "**Nokia extension to ETSI NFV IFA007.** VNF-specific metadata related to the resource.\n",
+ "type": "object",
+ "additionalProperties": {
+ "type": [
+ "string",
+ "number",
+ "boolean",
+ "array",
+ "object"
+ ]
+ }
+ }
+ }
+ },
+ "ProblemDetails": {
+ "description": "Problem detail object based on RFC7807\n",
+ "type": "object",
+ "required": [
+ "status",
+ "detail"
+ ],
+ "properties": {
+ "type": {
+ "description": "A URI reference [RFC3986] that identifies the problem type. This specification encourages that, when dereferenced, it provide human-readable documentation for the problem type (e.g., using HTML [W3C.REC-html5-20141028]). When this member is not present, its value is assumed to be \"about:blank\".\n",
+ "type": "string",
+ "format": "URI"
+ },
+ "title": {
+ "description": "A short, human-readable summary of the problem type. It SHOULD NOT change from occurrence to occurrence of the problem, except for purposes of localization (e.g., using proactive content negotiation; see [RFC7231], Section 3.4).\n",
+ "type": "string"
+ },
+ "status": {
+ "description": "The HTTP status code ([RFC7231], Section 6) generated by the origin server for this occurrence of the problem.\n",
+ "type": "integer"
+ },
+ "detail": {
+ "description": "A human-readable explanation specific to this occurrence of the problem.\n",
+ "type": "string"
+ },
+ "instance": {
+ "description": "A URI reference that identifies the specific occurrence of the problem. It may or may not yield further information if dereferenced.\n",
+ "type": "string",
+ "format": "URI"
+ }
+ }
+ },
+ "VnfNotificationType": {
+ "description": "**OtherNotification** is provided for forward compatibility with subsequent API microversions.\n",
+ "type": "string",
+ "enum": [
+ "VnfIdentifierCreationNotification",
+ "VnfIdentifierDeletionNotification",
+ "VnfLifecycleChangeNotification",
+ "VnfInfoAttributeValueChangeNotification",
+ "OtherNotification"
+ ]
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcn.subscription.json b/nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcn.subscription.json
new file mode 100644
index 00000000..8c19b383
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/nokia.vnfm.api.v3.lcn.subscription.json
@@ -0,0 +1,499 @@
+{
+ "swagger": "2.0",
+ "info": {
+ "version": "v3.2",
+ "title": "Nokia VNFM API version 3.2 WIP - VNF Lifecycle Change Notification - Subscription interface"
+ },
+ "basePath": "/vnfm/lcn/v3",
+ "schemes": [
+ "https"
+ ],
+ "securityDefinitions": {
+ "OauthPassword": {
+ "description": "OAuth 2.0 resource owner password credentials grant (https://tools.ietf.org/html/rfc6749#section-4.3) with bearer token type. Note: the given tokenUrl does not inherit from the basePath\n",
+ "type": "oauth2",
+ "tokenUrl": "/auth/realms/cbam/protocol/openid-connect/token",
+ "flow": "password",
+ "scopes": {
+ "default": "default scope"
+ }
+ },
+ "OauthClient": {
+ "description": "OAuth 2.0 client credentials grant (https://tools.ietf.org/html/rfc6749#section-4.4) with bearer token type. Note: the given tokenUrl does not inherit from the basePath\n",
+ "type": "oauth2",
+ "tokenUrl": "/auth/realms/cbam/protocol/openid-connect/token",
+ "flow": "application",
+ "scopes": {
+ "default": "default scope"
+ }
+ }
+ },
+ "security": [
+ {
+ "OauthPassword": [
+ "default"
+ ]
+ },
+ {
+ "OauthClient": [
+ "default"
+ ]
+ }
+ ],
+ "produces": [
+ "application/json",
+ "application/problem+json"
+ ],
+ "consumes": [
+ "application/json"
+ ],
+ "paths": {
+ "/subscriptions": {
+ "post": {
+ "description": "Creates subscription to notifications.\n",
+ "parameters": [
+ {
+ "name": "subscriptionRequest",
+ "description": "Parameters for the subscription to be created",
+ "in": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/CreateSubscriptionRequest"
+ }
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "Created subscription",
+ "headers": {
+ "Location": {
+ "description": "The url of the subscription",
+ "type": "string",
+ "format": "url"
+ },
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "schema": {
+ "$ref": "#/definitions/Subscription"
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "subscriptions"
+ ]
+ },
+ "get": {
+ "description": "Lists subscriptions",
+ "parameters": [
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "schema": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/Subscription"
+ }
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "subscriptions"
+ ]
+ }
+ },
+ "/subscriptions/{subscriptionId}": {
+ "get": {
+ "description": "Gets specific subscription data",
+ "parameters": [
+ {
+ "name": "subscriptionId",
+ "in": "path",
+ "description": "The identifier of the subscription",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "schema": {
+ "$ref": "#/definitions/Subscription"
+ },
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "subscriptions"
+ ]
+ },
+ "delete": {
+ "description": "Delete the subscription\n",
+ "parameters": [
+ {
+ "name": "subscriptionId",
+ "in": "path",
+ "description": "The identifier of the subscription",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "enum": [
+ "3.2"
+ ],
+ "name": "Nokia-VNFM-API-Version",
+ "required": true,
+ "in": "header",
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ ],
+ "responses": {
+ "204": {
+ "description": "Successful response",
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ }
+ },
+ "default": {
+ "headers": {
+ "Nokia-VNFM-API-Version": {
+ "enum": [
+ "3.2"
+ ],
+ "type": "string",
+ "description": "The microversion corresponding to the version of the current specification"
+ }
+ },
+ "description": "Error payload",
+ "schema": {
+ "$ref": "#/definitions/ProblemDetails"
+ }
+ }
+ },
+ "tags": [
+ "subscriptions"
+ ]
+ }
+ }
+ },
+ "definitions": {
+ "CreateSubscriptionRequest": {
+ "type": "object",
+ "required": [
+ "callbackUrl"
+ ],
+ "properties": {
+ "filter": {
+ "description": "Filter settings for this subscription. Omitting this field indicates that all notifications should be sent to the subscriber.\n",
+ "$ref": "#/definitions/SubscriptionFilter"
+ },
+ "callbackUrl": {
+ "description": "The URL to use as endpoint when sending notifications corresponding to this subscription request. **Nokia extension to ETSI NFV IFA007.**\n",
+ "type": "string"
+ },
+ "authentication": {
+ "description": "Authentication parameters to use when sending notifications corresponding to this subscription. **Nokia extension to ETSI NFV IFA007.**\n",
+ "$ref": "#/definitions/SubscriptionAuthentication"
+ }
+ }
+ },
+ "OperationType": {
+ "type": "string",
+ "enum": [
+ "INSTANTIATE",
+ "SCALE",
+ "SCALE_TO_LEVEL",
+ "MODIFY_INFO",
+ "CHANGE_FLAVOUR",
+ "OPERATE",
+ "HEAL",
+ "UPGRADE",
+ "TERMINATE",
+ "OTHER"
+ ]
+ },
+ "SubscriptionFilter": {
+ "description": "Filter settings for subscriptions. Multiple filter options mean that all should be satisfied (AND relation). **Options may be expanded in later API specification updates.**\n",
+ "type": "object",
+ "properties": {
+ "vnfdId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "vnfProductName": {
+ "description": "Subscribe to notifications of VNFs with the given product name\n",
+ "type": "string"
+ },
+ "vnfSoftwareVersion": {
+ "description": "Subscribe to notifications of VNFs with the given software version (to be used in conjunction with vnfProductName)\n",
+ "type": "string"
+ },
+ "vnfInstanceId": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "notificationTypes": {
+ "description": "Only send notifications of the included types. If no types are given, all notifications will be sent.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfNotificationType"
+ }
+ },
+ "operationTypes": {
+ "description": "Only send notifications of the included operation types. Only valid for VnfLifecycleChangeNotification notification type.\n",
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/OperationType"
+ }
+ }
+ }
+ },
+ "SubscriptionAuthentication": {
+ "description": "Authentication parameters to use when sending notifications for subscriptions. **Options may be expanded in later API specification updates.**\n",
+ "type": "object",
+ "required": [
+ "type"
+ ],
+ "properties": {
+ "type": {
+ "description": "type of authentication. OAUTH2_PASSWD means the \"resource owner password credentials grant\" flow. OAUTH2_CLIENT means the \"client credentials grant\" flow.\n",
+ "type": "string",
+ "enum": [
+ "NONE",
+ "BASIC",
+ "OAUTH2_PASSWD",
+ "OAUTH2_CLIENT"
+ ]
+ },
+ "userName": {
+ "description": "The name of the user to authenticate with. Used for basic- and OAUTH2_PASSWD authentication. This corresponds to the \"resource owner\" user in case of Oauth 2.\n",
+ "type": "string"
+ },
+ "password": {
+ "description": "The password of the user to authenticate with. Used for basic- and OAUTH2_PASSWD authentication.\n",
+ "type": "string",
+ "format": "password"
+ },
+ "clientName": {
+ "description": "The client designation to be used for Oauth 2 authentication (both flows)\n",
+ "type": "string"
+ },
+ "clientPassword": {
+ "description": "The client password to be used for Oauth 2 authentication (both flows)\n",
+ "type": "string"
+ },
+ "tokenUrl": {
+ "description": "The endpoint where the authentication token can be obtained. Used for Oauth 2 authentication (both flows)\n",
+ "type": "string"
+ }
+ }
+ },
+ "Subscription": {
+ "type": "object",
+ "required": [
+ "id",
+ "callbackUrl"
+ ],
+ "properties": {
+ "id": {
+ "description": "An identifier with the intention of being globally unique.\n",
+ "type": "string"
+ },
+ "lcnApiVersion": {
+ "description": "Version of the API on which the subscription was created. This may influence the occurrence and contents and of the LCN notifications sent to the subscriber.\n",
+ "type": "string"
+ },
+ "filter": {
+ "description": "Filter settings for this subscription.\n",
+ "$ref": "#/definitions/SubscriptionFilter"
+ },
+ "callbackUrl": {
+ "description": "The URL to use as endpoint when sending notifications corresponding to this subscription\n",
+ "type": "string"
+ },
+ "_links": {
+ "required": [
+ "self"
+ ],
+ "type": "object",
+ "description": "Link relations for this object",
+ "properties": {
+ "self": {
+ "$ref": "#/definitions/Link"
+ },
+ "list": {
+ "$ref": "#/definitions/Link"
+ },
+ "create": {
+ "$ref": "#/definitions/Link"
+ },
+ "delete": {
+ "$ref": "#/definitions/Link"
+ }
+ }
+ }
+ }
+ },
+ "Link": {
+ "type": "object",
+ "required": [
+ "href"
+ ],
+ "properties": {
+ "href": {
+ "description": "The URL that references the target resource.\n",
+ "type": "string",
+ "format": "url"
+ }
+ }
+ },
+ "ProblemDetails": {
+ "description": "Problem detail object based on RFC7807\n",
+ "type": "object",
+ "required": [
+ "status",
+ "detail"
+ ],
+ "properties": {
+ "type": {
+ "description": "A URI reference [RFC3986] that identifies the problem type. This specification encourages that, when dereferenced, it provide human-readable documentation for the problem type (e.g., using HTML [W3C.REC-html5-20141028]). When this member is not present, its value is assumed to be \"about:blank\".\n",
+ "type": "string",
+ "format": "URI"
+ },
+ "title": {
+ "description": "A short, human-readable summary of the problem type. It SHOULD NOT change from occurrence to occurrence of the problem, except for purposes of localization (e.g., using proactive content negotiation; see [RFC7231], Section 3.4).\n",
+ "type": "string"
+ },
+ "status": {
+ "description": "The HTTP status code ([RFC7231], Section 6) generated by the origin server for this occurrence of the problem.\n",
+ "type": "integer"
+ },
+ "detail": {
+ "description": "A human-readable explanation specific to this occurrence of the problem.\n",
+ "type": "string"
+ },
+ "instance": {
+ "description": "A URI reference that identifies the specific occurrence of the problem. It may or may not yield further information if dereferenced.\n",
+ "type": "string",
+ "format": "URI"
+ }
+ }
+ },
+ "VnfNotificationType": {
+ "description": "**OtherNotification** is provided for forward compatibility with subsequent API microversions.\n",
+ "type": "string",
+ "enum": [
+ "VnfIdentifierCreationNotification",
+ "VnfIdentifierDeletionNotification",
+ "VnfLifecycleChangeNotification",
+ "VnfInfoAttributeValueChangeNotification",
+ "OtherNotification"
+ ]
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/generatedapis/src/main/resources/patch b/nokiav2/generatedapis/src/main/resources/patch
new file mode 100644
index 00000000..562c7a1d
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/patch
@@ -0,0 +1,56 @@
+diff -Naur old/cbam/src/gen/java/main/com/nokia/cbam/lcm/v32/model/VnfProperty.java new/cbam/src/gen/java/main/com/nokia/cbam/lcm/v32/model/VnfProperty.java
+--- old/cbam/src/gen/java/main/com/nokia/cbam/lcm/v32/model/VnfProperty.java 2018-02-19 17:32:33.000000000 +0100
++++ new/cbam/src/gen/java/main/com/nokia/cbam/lcm/v32/model/VnfProperty.java 2018-02-19 17:38:08.000000000 +0100
+@@ -40,6 +40,10 @@
+ @SerializedName("description")
+ private String description = null;
+
++ @XmlElement(name = "value")
++ @SerializedName("value")
++ private Object value = null;
++
+ public VnfProperty name(String name) {
+ this.name = name;
+ return this;
+@@ -76,6 +80,18 @@
+ this.description = description;
+ }
+
++ /**
++ * The value of the respective property
++ * @return value
++ **/
++ @ApiModelProperty(value = "The value of the respective property ")
++ public Object getValue() {
++ return value;
++ }
++
++ public void setValue(Object value) {
++ this.value = value;
++ }
+
+ @Override
+ public boolean equals(java.lang.Object o) {
+@@ -87,12 +103,13 @@
+ }
+ VnfProperty vnfProperty = (VnfProperty) o;
+ return Objects.equals(this.name, vnfProperty.name) &&
++ Objects.equals(this.value, vnfProperty.value) &&
+ Objects.equals(this.description, vnfProperty.description);
+ }
+
+ @Override
+ public int hashCode() {
+- return Objects.hash(name, description);
++ return Objects.hash(name, description, value);
+ }
+
+
+@@ -102,6 +119,7 @@
+ sb.append("class VnfProperty {\n");
+
+ sb.append(" name: ").append(toIndentedString(name)).append("\n");
++ sb.append(" value: ").append(toIndentedString(value)).append("\n");
+ sb.append(" description: ").append(toIndentedString(description)).append("\n");
+ sb.append("}");
+ return sb.toString();
diff --git a/nokiav2/generatedapis/src/main/resources/resource.manager.json b/nokiav2/generatedapis/src/main/resources/resource.manager.json
new file mode 100644
index 00000000..6a315916
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/resource.manager.json
@@ -0,0 +1,1100 @@
+{
+ "swagger": "2.0",
+ "info": {
+ "title": "Resource Management API",
+ "description": "Resource Management API",
+ "version": "1.0.0"
+ },
+ "tags": [
+ {
+ "name": "Resource Management services"
+ }
+ ],
+ "basePath": "/api/resmgr/v1",
+ "paths": {
+ "/limits": {
+ "get": {
+ "summary": "Query limits information",
+ "description": "Query limits information",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "vimId",
+ "in": "query",
+ "description": "vim Id",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successfully Query limits information",
+ "schema": {
+ "$ref": "#/definitions/QueryLimts"
+ }
+ },
+ "401": {
+ "description": "Unauthorized"
+ },
+ "404": {
+ "description": "Limits Not Found"
+ },
+ "500": {
+ "description": "Limits failed to process the request",
+ "schema": {
+ "$ref": "#/definitions/Error"
+ }
+ }
+ }
+ }
+ },
+ "/resource/grant": {
+ "put": {
+ "summary": "Grant VNF Life Cycle Operation",
+ "description": "Grant Resource",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "open-o",
+ "description": "OPEN-O Interface.",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/GrantResource"
+ }
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "VNF Resource Response",
+ "schema": {
+ "$ref": "#/definitions/GrantResourceResponse"
+ }
+ },
+ "401": {
+ "description": "Unauthorized"
+ },
+ "404": {
+ "description": "VNF Resource Not Found"
+ },
+ "500": {
+ "description": "VNF resource failed to process the request",
+ "schema": {
+ "$ref": "#/definitions/Error"
+ }
+ }
+ }
+ }
+ },
+ "/vl": {
+ "post": {
+ "summary": "Create virtual link resource",
+ "description": "virtual link Resource",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "open-o",
+ "description": "OPEN-O Interface.",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VirtualLink"
+ }
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "Successfully Created VNF Resource",
+ "schema": {
+ "$ref": "#/definitions/VirtualLinkResponse"
+ }
+ },
+ "401": {
+ "description": "Unauthorized"
+ },
+ "404": {
+ "description": "VNF Resource Not Found"
+ },
+ "500": {
+ "description": "VNF resource failed to process the request",
+ "schema": {
+ "$ref": "#/definitions/Error"
+ }
+ }
+ }
+ }
+ },
+ "/vl/{id}": {
+ "delete": {
+ "summary": "Delete virtual link resource",
+ "description": "Delete virtual link Resource",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "id",
+ "in": "path",
+ "description": "VNF Resource Id",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successfully Deleted VNF Resource"
+ },
+ "401": {
+ "description": "Unauthorized"
+ },
+ "404": {
+ "description": "VNF Resource Not Found"
+ },
+ "500": {
+ "description": "VNF resource failed to process the request",
+ "schema": {
+ "$ref": "#/definitions/Error"
+ }
+ }
+ }
+ }
+ },
+ "/vnf": {
+ "post": {
+ "summary": "Create VNF instance resource",
+ "description": "Create VNF Resource",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "open-o",
+ "description": "OPEN-O Interface.",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/CreateVNFResource"
+ }
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "Successfully Created VNF Resource",
+ "schema": {
+ "$ref": "#/definitions/CreateVNFResponse"
+ }
+ },
+ "401": {
+ "description": "Unauthorized"
+ },
+ "404": {
+ "description": "VNF Resource Not Found"
+ },
+ "500": {
+ "description": "VNF resource failed to process the request",
+ "schema": {
+ "$ref": "#/definitions/Error"
+ }
+ }
+ }
+ }
+ },
+ "/vnfinfo": {
+ "post": {
+ "summary": "Write VNF status information",
+ "description": "VNF Status",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "open-o",
+ "description": "OPEN-O Interface.",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VNFStatusInfo"
+ }
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "Successfully write VNF status"
+ },
+ "401": {
+ "description": "Unauthorized"
+ },
+ "404": {
+ "description": "VNF Resource Not Found"
+ },
+ "500": {
+ "description": "VNF resource failed to process the request",
+ "schema": {
+ "$ref": "#/definitions/Error"
+ }
+ }
+ }
+ }
+ },
+ "/vnfdetailinfo": {
+ "post": {
+ "summary": "Write VNF detail information",
+ "description": "VNF detail info",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "open-o",
+ "description": "OPEN-O Interface",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VNFDetailInfo"
+ }
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "Successfully write VNF detail Info"
+ },
+ "401": {
+ "description": "Unauthorized"
+ },
+ "404": {
+ "description": "VNF Resource Not Found"
+ },
+ "500": {
+ "description": "VNF resource failed to process the request",
+ "schema": {
+ "$ref": "#/definitions/Error"
+ }
+ }
+ }
+ }
+ }
+ },
+ "definitions": {
+ "QueryLimts": {
+ "type": "object",
+ "description": "Query Limits Response.",
+ "required": [
+ "vimId",
+ "vimName",
+ "totalCPU",
+ "totalMemory",
+ "totalDisk",
+ "usedCPU",
+ "usedMemory",
+ "usedDisk"
+ ],
+ "properties": {
+ "vimId": {
+ "type": "string",
+ "description": "Identifier of vimId."
+ },
+ "vimName": {
+ "type": "string",
+ "description": "Name."
+ },
+ "totalCPU": {
+ "type": "string"
+ },
+ "totalMemory": {
+ "type": "string"
+ },
+ "totalDisk": {
+ "type": "string"
+ },
+ "usedCPU": {
+ "type": "string"
+ },
+ "usedMemory": {
+ "type": "string"
+ },
+ "usedDisk": {
+ "type": "string"
+ }
+ }
+ },
+ "VirtualLinkResponse": {
+ "type": "object",
+ "description": "Virtual Link Response.",
+ "required": [
+ "Id",
+ "Name"
+ ],
+ "properties": {
+ "Id": {
+ "type": "string",
+ "description": "Identifier of VL."
+ },
+ "Name": {
+ "type": "string",
+ "description": "Name of VL."
+ }
+ }
+ },
+ "CreateVNFResponse": {
+ "type": "object",
+ "description": "Create VNF Response.",
+ "required": [
+ "Id",
+ "Name"
+ ],
+ "properties": {
+ "Id": {
+ "type": "string",
+ "description": "UUID."
+ },
+ "Name": {
+ "type": "string",
+ "description": "Instance Name."
+ }
+ }
+ },
+ "VNFDetailInfo": {
+ "type": "object",
+ "description": "List of Vm to be added or deleted",
+ "required": [
+ "vnfInstanceId",
+ "nsId",
+ "vnfmId",
+ "Vms"
+ ],
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string",
+ "description": "The id of VNF instance"
+ },
+ "nsId": {
+ "type": "string",
+ "description": "NS ID"
+ },
+ "vnfmId": {
+ "type": "string",
+ "description": "VNFM ID"
+ },
+ "Vms": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/Vm"
+ }
+ }
+ }
+ },
+ "VNFStatusInfo": {
+ "type": "object",
+ "description": "Write VNF Status.",
+ "required": [
+ "vnfInstanceId",
+ "jobId",
+ "nsId",
+ "vnfmId",
+ "responseDescriptor",
+ "status",
+ "progress",
+ "sStatusDescription",
+ "errorCode",
+ "responseId",
+ "responseHistoryList",
+ "addVm",
+ "delVm"
+ ],
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string",
+ "description": "The Id of VNF Instance."
+ },
+ "jobId": {
+ "type": "string",
+ "description": "The ID of workflow."
+ },
+ "nsId": {
+ "type": "string",
+ "description": "NS ID."
+ },
+ "vnfmId": {
+ "type": "string",
+ "description": "The VNFM ID."
+ },
+ "responseDescriptor": {
+ "type": "string",
+ "description": "The name of VNFM."
+ },
+ "status": {
+ "type": "string",
+ "description": "Status of VNF - started processing finished error."
+ },
+ "progress": {
+ "type": "integer",
+ "description": "progress (1-100)."
+ },
+ "sStatusDescription": {
+ "type": "string",
+ "description": "current Progress Description."
+ },
+ "errorCode": {
+ "type": "integer",
+ "description": "Error code."
+ },
+ "responseId": {
+ "type": "integer",
+ "description": "Message Number."
+ },
+ "responseHistoryList": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/progressInfo"
+ }
+ },
+ "addVm": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/Vm"
+ }
+ },
+ "delVm": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/Vm"
+ }
+ }
+ }
+ },
+ "progressInfo": {
+ "type": "object",
+ "description": "List of Vm to be added or deleted",
+ "required": [
+ "progress",
+ "status",
+ "statusDescription",
+ "errorCode",
+ "responseId",
+ "responseHistoryList"
+ ],
+ "properties": {
+ "progress": {
+ "type": "integer",
+ "description": "progress (1 - 100)"
+ },
+ "status": {
+ "type": "string",
+ "description": "status"
+ },
+ "statusDescription": {
+ "type": "string",
+ "description": "status description"
+ },
+ "errorCode": {
+ "type": "integer",
+ "description": "Error Code"
+ },
+ "responseId": {
+ "type": "integer",
+ "description": "Id"
+ },
+ "responseHistoryList": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/historyInfo"
+ }
+ }
+ }
+ },
+ "historyInfo": {
+ "type": "object",
+ "description": "List of Vm to be added or deleted",
+ "required": [
+ "progress",
+ "status",
+ "statusDescription",
+ "errorCode",
+ "responseId"
+ ],
+ "properties": {
+ "progress": {
+ "type": "integer",
+ "description": "progress (1 - 100)"
+ },
+ "status": {
+ "type": "string",
+ "description": "status"
+ },
+ "statusDescription": {
+ "type": "string",
+ "description": "status description"
+ },
+ "errorCode": {
+ "type": "integer",
+ "description": "Error Code"
+ },
+ "responseId": {
+ "type": "integer",
+ "description": "Id"
+ }
+ }
+ },
+ "Vm": {
+ "type": "object",
+ "description": "List of Vm to be added or deleted",
+ "required": [
+ "vmId",
+ "vmName",
+ "vmStatus"
+ ],
+ "properties": {
+ "vmId": {
+ "type": "string",
+ "description": "The ID of VM"
+ },
+ "vmName": {
+ "type": "string",
+ "description": "The name of VM"
+ },
+ "vmStatus": {
+ "type": "string",
+ "description": "The Status of VM"
+ }
+ }
+ },
+ "CreateVNFResource": {
+ "type": "object",
+ "description": "Create VNF Resource.",
+ "required": [
+ "vnfInstanceId",
+ "vnfInstanceName",
+ "nsId",
+ "nsName",
+ "vnfmId",
+ "vnfmName",
+ "vnfPackageName",
+ "vnfDescriptorName",
+ "vimId",
+ "vimName",
+ "vimTenant",
+ "jobId",
+ "vnfStatus",
+ "vnfType",
+ "maxVm",
+ "maxCpu",
+ "maxDisk",
+ "maxRam",
+ "maxShd",
+ "maxNet"
+ ],
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string",
+ "description": "The Identifier of VNF Instance."
+ },
+ "vnfInstanceName": {
+ "type": "string",
+ "description": "The name of VNF."
+ },
+ "nsId": {
+ "type": "string",
+ "description": "NS ID."
+ },
+ "nsName": {
+ "type": "string",
+ "description": "NS name."
+ },
+ "vnfmId": {
+ "type": "string",
+ "description": "The ID of VNFM."
+ },
+ "vnfmName": {
+ "type": "string",
+ "description": "The name of VNFM."
+ },
+ "vnfPackageName": {
+ "type": "string",
+ "description": "The description of VNF Package."
+ },
+ "vnfDescriptorName": {
+ "type": "string",
+ "description": "The Description of VNFD."
+ },
+ "vimId": {
+ "type": "string",
+ "description": "Vim ID."
+ },
+ "vimName": {
+ "type": "string",
+ "description": "The Name of VIM."
+ },
+ "vimTenant": {
+ "type": "string",
+ "description": "The tenant of VIM."
+ },
+ "jobId": {
+ "type": "string",
+ "description": "The ID of workflow."
+ },
+ "vnfStatus": {
+ "type": "string",
+ "description": "The status of VNF."
+ },
+ "vnfType": {
+ "type": "string",
+ "description": "The type of VNF."
+ },
+ "maxVm": {
+ "type": "integer",
+ "description": "Max Vm in this VNF."
+ },
+ "maxCpu": {
+ "type": "integer",
+ "description": "Max CPU in this VNF."
+ },
+ "maxDisk": {
+ "type": "integer",
+ "description": "Max Disk in this VNF."
+ },
+ "maxRam": {
+ "type": "integer",
+ "description": "Max Memory in this VNF."
+ },
+ "maxShd": {
+ "type": "integer",
+ "description": "Max Share Disk in this VNF."
+ },
+ "maxNet": {
+ "type": "integer",
+ "description": "Max logical Network in this VNF."
+ }
+ }
+ },
+ "VirtualLink": {
+ "type": "object",
+ "description": "Virtual Link Resource.",
+ "required": [
+ "name",
+ "backendId",
+ "isPublic",
+ "dcName",
+ "vimId",
+ "vimName",
+ "physicialNet",
+ "nsId",
+ "nsName",
+ "description",
+ "networkType",
+ "segmentation",
+ "mtu",
+ "vlanTransparent",
+ "routerExternal",
+ "resourceProviderType",
+ "resourceProviderId"
+ ],
+ "properties": {
+ "name": {
+ "type": "string",
+ "description": "Logical Network Name."
+ },
+ "backendId": {
+ "type": "string",
+ "description": "The backend id on VIM."
+ },
+ "isPublic": {
+ "type": "string",
+ "description": "Sharable - True or False."
+ },
+ "dcName": {
+ "type": "string",
+ "description": "The DataCenter name."
+ },
+ "vimId": {
+ "type": "string",
+ "description": "vim Id."
+ },
+ "vimName": {
+ "type": "string",
+ "description": "The name of VIM."
+ },
+ "physicialNet": {
+ "type": "string",
+ "description": "Physicial Network."
+ },
+ "nsId": {
+ "type": "string",
+ "description": "NsId."
+ },
+ "nsName": {
+ "type": "string",
+ "description": "The name of NS."
+ },
+ "description": {
+ "type": "string",
+ "description": "Description."
+ },
+ "networkType": {
+ "type": "string",
+ "description": "Network Type - gre/vlan/vxlan."
+ },
+ "segmentation": {
+ "type": "string",
+ "description": "Segmentation Id just like vlan id."
+ },
+ "mtu": {
+ "type": "string",
+ "description": "MTU value."
+ },
+ "vlanTransparent": {
+ "type": "string",
+ "description": "Support vlan transparent- True/False."
+ },
+ "routerExternal": {
+ "type": "string",
+ "description": "Support External Router - True / False."
+ },
+ "resourceProviderType": {
+ "type": "string",
+ "description": "The location to be deployed in one of the list - VIM/DC/Zone/Host."
+ },
+ "resourceProviderId": {
+ "type": "string",
+ "description": "The location ID to be deployed."
+ }
+ }
+ },
+ "GrantResourceResponse": {
+ "type": "object",
+ "description": "Resource Response.",
+ "required": [
+ "vim",
+ "zone",
+ "zoneGroup",
+ "addResource",
+ "tempResource",
+ "removeResource",
+ "updateResource",
+ "vimAssets",
+ "additionalParam"
+ ],
+ "properties": {
+ "vim": {
+ "$ref": "#/definitions/VimInfo"
+ },
+ "zone": {
+ "type": "string"
+ },
+ "zoneGroup": {
+ "type": "string"
+ },
+ "addResource": {
+ "$ref": "#/definitions/GrantInfo"
+ },
+ "tempResource": {
+ "$ref": "#/definitions/GrantInfo"
+ },
+ "removeResource": {
+ "$ref": "#/definitions/GrantInfo"
+ },
+ "updateResource": {
+ "$ref": "#/definitions/GrantInfo"
+ },
+ "vimAssets": {
+ "type": "string"
+ },
+ "additionalParam": {
+ "type": "string"
+ }
+ }
+ },
+ "VimInfo": {
+ "type": "object",
+ "description": "Information about the VIM that manages this resource.",
+ "required": [
+ "vimInfoId",
+ "vimId",
+ "interfaceInfo",
+ "accessInfo",
+ "interfaceEndpoint"
+ ],
+ "properties": {
+ "vimInfoId": {
+ "type": "string",
+ "description": "The identifier of this VimInfo instance, for the purpose of referencing it from other information elements."
+ },
+ "vimId": {
+ "type": "string",
+ "description": "The identifier of the VIM.."
+ },
+ "interfaceInfo": {
+ "$ref": "#/definitions/interfaceInfo"
+ },
+ "accessInfo": {
+ "$ref": "#/definitions/accessInfo"
+ },
+ "interfaceEndpoint": {
+ "type": "string",
+ "description": "Information about the interface endpoint. An example is a URL."
+ }
+ }
+ },
+ "interfaceInfo": {
+ "type": "object",
+ "description": "Information about the interface to the VIM, including VIM provider type, API version, and protocol type..",
+ "required": [
+ "vimType",
+ "apiVersion",
+ "protocolType"
+ ],
+ "properties": {
+ "vimType": {
+ "type": "string",
+ "description": "vim"
+ },
+ "apiVersion": {
+ "type": "string",
+ "description": "api version"
+ },
+ "protocolType": {
+ "type": "string",
+ "description": "Type of the protocol"
+ }
+ }
+ },
+ "accessInfo": {
+ "type": "object",
+ "description": "Authentication credentials for accessing the VIM. Examples may include those to support different authentication schemes, e.g., OAuth, Token, etc..",
+ "required": [
+ "tenant",
+ "username",
+ "password"
+ ],
+ "properties": {
+ "tenant": {
+ "type": "string",
+ "description": "Tenant Name of tenant"
+ },
+ "username": {
+ "type": "string",
+ "description": "Username for login"
+ },
+ "password": {
+ "type": "string",
+ "description": "Password of login user"
+ }
+ }
+ },
+ "GrantInfo": {
+ "type": "object",
+ "description": "Grant Information.",
+ "required": [
+ "resourceDefinitionId",
+ "reservationId",
+ "vimId",
+ "resourceProviderId",
+ "zoneId"
+ ],
+ "properties": {
+ "resourceDefinitionId": {
+ "type": "string",
+ "description": "Identifier of the related ResourceDefinition information from Grant Request"
+ },
+ "reservationId": {
+ "type": "string",
+ "description": "Reservation Identifier applicable to the VNFC/VL."
+ },
+ "vimId": {
+ "type": "string",
+ "description": "Reference to the identifier of the VimInfo information element defining the VIM under whose control this resource to be placed."
+ },
+ "resourceProviderId": {
+ "type": "string",
+ "description": "Identifies the entity responsible for the management of the virtualized resource."
+ },
+ "zoneId": {
+ "type": "string",
+ "description": "Reference of the identifier of the zoneInfo information element defining the resource zone in which resource to be placed."
+ }
+ }
+ },
+ "GrantResource": {
+ "type": "object",
+ "description": "Grant Resource Request Body.",
+ "required": [
+ "vnfInstanceId",
+ "addResource",
+ "vimId",
+ "additionalParam"
+ ],
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string",
+ "description": "Identifier Instance."
+ },
+ "vimId": {
+ "type": "string",
+ "description": "Identifier vim."
+ },
+ "addResource": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ResourceDefinition"
+ },
+ "description": "Information sufficient to identify the VNF Descriptor which defines the VNF to be created."
+ },
+ "removeResource": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ResourceDefinition"
+ }
+ },
+ "additionalParam": {
+ "type": "object",
+ "description": "additionalParam.",
+ "required": [
+ "vnfmid"
+ ],
+ "properties": {
+ "vnfmid": {
+ "type": "string"
+ },
+ "vimid": {
+ "type": "string"
+ },
+ "tenant": {
+ "type": "string"
+ }
+ }
+ }
+ }
+ },
+ "ResourceDefinition": {
+ "type": "object",
+ "description": "List of resources to be added / deleted / updated.",
+ "required": [
+ "resourceDefinitionId",
+ "resourceTemplate",
+ "type",
+ "vdu"
+ ],
+ "properties": {
+ "resourceDefinitionId": {
+ "type": "string",
+ "description": "Identifier of this ResourceDefinition information element, unique at least within the scope of the Grant request."
+ },
+ "resourceTemplate": {
+ "$ref": "#/definitions/ResourceTemplate"
+ },
+ "type": {
+ "default": "compute",
+ "enum": [
+ "compute",
+ "VL",
+ "CP",
+ "Storage"
+ ],
+ "description": "Currently only support tosca.nodes.nfv.VDU."
+ },
+ "vdu": {
+ "type": "string",
+ "description": "Reference to the related Vdu applicable to this resource in the VNFD."
+ }
+ }
+ },
+ "ResourceTemplate": {
+ "type": "object",
+ "description": "Resource templates.",
+ "required": [
+ "VirtualComputeDescriptor",
+ "VirtualStorageDescriptor"
+ ],
+ "properties": {
+ "VirtualComputeDescriptor": {
+ "$ref": "#/definitions/VirtualComputeDescriptor"
+ },
+ "VirtualStorageDescriptor": {
+ "$ref": "#/definitions/VirtualStorageDescriptor"
+ }
+ }
+ },
+ "VirtualComputeDescriptor": {
+ "type": "object",
+ "description": "Reference to a resource template.",
+ "required": [
+ "virtualCpu",
+ "virtualMemory"
+ ],
+ "properties": {
+ "virtualCpu": {
+ "type": "integer",
+ "format": "int32",
+ "description": "Number of virtual CPUs"
+ },
+ "virtualMemory": {
+ "type": "integer",
+ "format": "int32",
+ "description": "Amount of virtual Memory"
+ }
+ }
+ },
+ "VirtualStorageDescriptor": {
+ "type": "object",
+ "description": "Reference to a resource template.",
+ "required": [
+ "typeOfStorage",
+ "sizeOfStorage",
+ "swImageDescriptor"
+ ],
+ "properties": {
+ "typeOfStorage": {
+ "type": "string",
+ "description": "Type of virtualized storage resource"
+ },
+ "sizeOfStorage": {
+ "type": "integer",
+ "format": "int32",
+ "description": "Size of virtualized storage resource"
+ },
+ "swImageDescriptor": {
+ "type": "string",
+ "description": "Software image to be loaded on the Virtual Storage"
+ }
+ }
+ },
+ "Error": {
+ "type": "object",
+ "properties": {
+ "code": {
+ "type": "integer",
+ "format": "int32"
+ },
+ "message": {
+ "type": "string"
+ }
+ }
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/generatedapis/src/main/resources/sdc.internal.json b/nokiav2/generatedapis/src/main/resources/sdc.internal.json
new file mode 100644
index 00000000..9791daac
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/sdc.internal.json
@@ -0,0 +1,9902 @@
+{
+ "basePath": "/sdc2/rest",
+ "definitions": {
+ "AdditionalInfoParameterInfo": {
+ "properties": {
+ "empty": {
+ "type": "boolean"
+ },
+ "key": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "value": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "AdditionalInformationDefinition": {
+ "properties": {
+ "creationTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "lastCreatedCounter": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "modificationTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "parameters": {
+ "items": {
+ "$ref": "#/definitions/AdditionalInfoParameterInfo"
+ },
+ "type": "array"
+ },
+ "parentUniqueId": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "ArtifactDataDefinition": {
+ "properties": {
+ "apiUrl": {
+ "type": "string"
+ },
+ "artifactChecksum": {
+ "type": "string"
+ },
+ "artifactCreator": {
+ "type": "string"
+ },
+ "artifactDisplayName": {
+ "type": "string"
+ },
+ "artifactGroupType": {
+ "enum": [
+ "INFORMATIONAL",
+ "DEPLOYMENT",
+ "LIFE_CYCLE",
+ "SERVICE_API",
+ "TOSCA",
+ "OTHER"
+ ],
+ "type": "string"
+ },
+ "artifactLabel": {
+ "type": "string"
+ },
+ "artifactName": {
+ "type": "string"
+ },
+ "artifactRef": {
+ "type": "string"
+ },
+ "artifactRepository": {
+ "type": "string"
+ },
+ "artifactType": {
+ "type": "string"
+ },
+ "artifactUUID": {
+ "type": "string"
+ },
+ "artifactVersion": {
+ "type": "string"
+ },
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "creatorFullName": {
+ "type": "string"
+ },
+ "description": {
+ "type": "string"
+ },
+ "duplicated": {
+ "type": "boolean"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "esId": {
+ "type": "string"
+ },
+ "generated": {
+ "type": "boolean"
+ },
+ "generatedFromId": {
+ "type": "string"
+ },
+ "heatParameters": {
+ "items": {
+ "$ref": "#/definitions/HeatParameterDataDefinition"
+ },
+ "type": "array"
+ },
+ "heatParamsUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "mandatory": {
+ "type": "boolean"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "payloadUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "requiredArtifacts": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "serviceApi": {
+ "type": "boolean"
+ },
+ "timeout": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "updaterFullName": {
+ "type": "string"
+ },
+ "userIdCreator": {
+ "type": "string"
+ },
+ "userIdLastUpdater": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "ArtifactDefinition": {
+ "properties": {
+ "apiUrl": {
+ "type": "string"
+ },
+ "artifactChecksum": {
+ "type": "string"
+ },
+ "artifactCreator": {
+ "type": "string"
+ },
+ "artifactDisplayName": {
+ "type": "string"
+ },
+ "artifactGroupType": {
+ "enum": [
+ "INFORMATIONAL",
+ "DEPLOYMENT",
+ "LIFE_CYCLE",
+ "SERVICE_API",
+ "TOSCA",
+ "OTHER"
+ ],
+ "type": "string"
+ },
+ "artifactLabel": {
+ "type": "string"
+ },
+ "artifactName": {
+ "type": "string"
+ },
+ "artifactRef": {
+ "type": "string"
+ },
+ "artifactRepository": {
+ "type": "string"
+ },
+ "artifactType": {
+ "type": "string"
+ },
+ "artifactUUID": {
+ "type": "string"
+ },
+ "artifactVersion": {
+ "type": "string"
+ },
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "creatorFullName": {
+ "type": "string"
+ },
+ "description": {
+ "type": "string"
+ },
+ "duplicated": {
+ "type": "boolean"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "esId": {
+ "type": "string"
+ },
+ "generated": {
+ "type": "boolean"
+ },
+ "generatedFromId": {
+ "type": "string"
+ },
+ "heatParameters": {
+ "items": {
+ "$ref": "#/definitions/HeatParameterDataDefinition"
+ },
+ "type": "array"
+ },
+ "heatParamsUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "listHeatParameters": {
+ "items": {
+ "$ref": "#/definitions/HeatParameterDefinition"
+ },
+ "type": "array"
+ },
+ "mandatory": {
+ "type": "boolean"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "payloadData": {
+ "items": {
+ "format": "byte",
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "payloadUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "requiredArtifacts": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "serviceApi": {
+ "type": "boolean"
+ },
+ "timeout": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "updaterFullName": {
+ "type": "string"
+ },
+ "userIdCreator": {
+ "type": "string"
+ },
+ "userIdLastUpdater": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "CapabilityDefinition": {
+ "properties": {
+ "capabilitySources": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "leftOccurrences": {
+ "type": "string"
+ },
+ "maxOccurrences": {
+ "type": "string"
+ },
+ "minOccurrences": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "ownerName": {
+ "type": "string"
+ },
+ "parentName": {
+ "type": "string"
+ },
+ "path": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "properties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "source": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "validSourceTypes": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ }
+ },
+ "type": "object"
+ },
+ "Category": {
+ "properties": {
+ "name": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "CategoryDefinition": {
+ "properties": {
+ "empty": {
+ "type": "boolean"
+ },
+ "icons": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "subcategories": {
+ "items": {
+ "$ref": "#/definitions/SubCategoryDefinition"
+ },
+ "type": "array"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "ComponentInstance": {
+ "properties": {
+ "artifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "attributeValueCounter": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "capabilities": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/CapabilityDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentName": {
+ "type": "string"
+ },
+ "componentUid": {
+ "type": "string"
+ },
+ "componentVersion": {
+ "type": "string"
+ },
+ "creationTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "customizationUUID": {
+ "type": "string"
+ },
+ "deploymentArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "groupInstances": {
+ "items": {
+ "$ref": "#/definitions/GroupInstance"
+ },
+ "type": "array"
+ },
+ "icon": {
+ "type": "string"
+ },
+ "inputValueCounter": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "invariantName": {
+ "type": "string"
+ },
+ "modificationTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "originType": {
+ "enum": [
+ "PRODUCT",
+ "SERVICE",
+ "VF",
+ "VFC",
+ "CP",
+ "VL",
+ "VFCMT",
+ "CVFC",
+ "PNF"
+ ],
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "posX": {
+ "type": "string"
+ },
+ "posY": {
+ "type": "string"
+ },
+ "propertyValueCounter": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "requirements": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/RequirementDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "toscaComponentName": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "ComponentInstanceInput": {
+ "properties": {
+ "componentInstanceId": {
+ "type": "string"
+ },
+ "componentInstanceName": {
+ "type": "string"
+ },
+ "constraints": {
+ "items": {
+ "$ref": "#/definitions/PropertyConstraint"
+ },
+ "type": "array"
+ },
+ "defaultValue": {
+ "type": "string"
+ },
+ "definition": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "getInputValues": {
+ "items": {
+ "$ref": "#/definitions/GetInputValueDataDefinition"
+ },
+ "type": "array"
+ },
+ "hidden": {
+ "type": "boolean"
+ },
+ "immutable": {
+ "type": "boolean"
+ },
+ "inputId": {
+ "type": "string"
+ },
+ "inputPath": {
+ "type": "string"
+ },
+ "inputs": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceInput"
+ },
+ "type": "array"
+ },
+ "instanceUniqueId": {
+ "type": "string"
+ },
+ "label": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "parentUniqueId": {
+ "type": "string"
+ },
+ "password": {
+ "type": "boolean"
+ },
+ "path": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "properties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "propertyId": {
+ "type": "string"
+ },
+ "required": {
+ "type": "boolean"
+ },
+ "rules": {
+ "items": {
+ "$ref": "#/definitions/PropertyRule"
+ },
+ "type": "array"
+ },
+ "schema": {
+ "$ref": "#/definitions/SchemaDefinition"
+ },
+ "status": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "value": {
+ "type": "string"
+ },
+ "valueUniqueUid": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "ComponentInstanceProperty": {
+ "properties": {
+ "componentInstanceId": {
+ "type": "string"
+ },
+ "componentInstanceName": {
+ "type": "string"
+ },
+ "constraints": {
+ "items": {
+ "$ref": "#/definitions/PropertyConstraint"
+ },
+ "type": "array"
+ },
+ "defaultValue": {
+ "type": "string"
+ },
+ "definition": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "getInputValues": {
+ "items": {
+ "$ref": "#/definitions/GetInputValueDataDefinition"
+ },
+ "type": "array"
+ },
+ "hidden": {
+ "type": "boolean"
+ },
+ "immutable": {
+ "type": "boolean"
+ },
+ "inputId": {
+ "type": "string"
+ },
+ "inputPath": {
+ "type": "string"
+ },
+ "instanceUniqueId": {
+ "type": "string"
+ },
+ "label": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "parentUniqueId": {
+ "type": "string"
+ },
+ "password": {
+ "type": "boolean"
+ },
+ "path": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "propertyId": {
+ "type": "string"
+ },
+ "required": {
+ "type": "boolean"
+ },
+ "rules": {
+ "items": {
+ "$ref": "#/definitions/PropertyRule"
+ },
+ "type": "array"
+ },
+ "schema": {
+ "$ref": "#/definitions/SchemaDefinition"
+ },
+ "status": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "value": {
+ "type": "string"
+ },
+ "valueUniqueUid": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "ComponentMetadataDataDefinition": {
+ "properties": {
+ "allVersions": {
+ "additionalProperties": {
+ "type": "string"
+ },
+ "type": "object"
+ },
+ "componentType": {
+ "enum": [
+ "RESOURCE",
+ "SERVICE",
+ "RESOURCE_INSTANCE",
+ "PRODUCT",
+ "SERVICE_INSTANCE"
+ ],
+ "type": "string"
+ },
+ "conformanceLevel": {
+ "type": "string"
+ },
+ "contactId": {
+ "type": "string"
+ },
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "creatorFullName": {
+ "type": "string"
+ },
+ "creatorUserId": {
+ "type": "string"
+ },
+ "csarUUID": {
+ "type": "string"
+ },
+ "csarVersion": {
+ "type": "string"
+ },
+ "deleted": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "highestVersion": {
+ "type": "boolean"
+ },
+ "icon": {
+ "type": "string"
+ },
+ "importedToscaChecksum": {
+ "type": "string"
+ },
+ "invariantUUID": {
+ "type": "string"
+ },
+ "isDeleted": {
+ "type": "boolean"
+ },
+ "isHighestVersion": {
+ "type": "boolean"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "lastUpdaterFullName": {
+ "type": "string"
+ },
+ "lastUpdaterUserId": {
+ "type": "string"
+ },
+ "lifecycleState": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "projectCode": {
+ "type": "string"
+ },
+ "state": {
+ "type": "string"
+ },
+ "systemName": {
+ "type": "string"
+ },
+ "tags": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "uuid": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "ComponentMetadataDefinition": {
+ "properties": {
+ "metadataDataDefinition": {
+ "$ref": "#/definitions/ComponentMetadataDataDefinition"
+ }
+ },
+ "type": "object"
+ },
+ "ConsumerDefinition": {
+ "properties": {
+ "consumerDetailsLastupdatedtime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "consumerLastAuthenticationTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "consumerName": {
+ "type": "string"
+ },
+ "consumerPassword": {
+ "type": "string"
+ },
+ "consumerSalt": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "lastModfierAtuid": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "DistributionStatusInfo": {
+ "properties": {
+ "errorReason": {
+ "type": "string"
+ },
+ "omfComponentID": {
+ "type": "string"
+ },
+ "status": {
+ "type": "string"
+ },
+ "timestamp": {
+ "type": "string"
+ },
+ "url": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "DistributionStatusListResponse": {
+ "properties": {
+ "distributionStatusList": {
+ "items": {
+ "$ref": "#/definitions/DistributionStatusInfo"
+ },
+ "type": "array"
+ }
+ },
+ "type": "object"
+ },
+ "GetInputValueDataDefinition": {
+ "properties": {
+ "empty": {
+ "type": "boolean"
+ },
+ "getInputIndex": {
+ "$ref": "#/definitions/GetInputValueDataDefinition"
+ },
+ "indexValue": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "inputId": {
+ "type": "string"
+ },
+ "inputName": {
+ "type": "string"
+ },
+ "list": {
+ "type": "boolean"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "propName": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "GroupDefinition": {
+ "properties": {
+ "artifacts": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "artifactsUuid": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "groupUUID": {
+ "type": "string"
+ },
+ "invariantUUID": {
+ "type": "string"
+ },
+ "members": {
+ "additionalProperties": {
+ "type": "string"
+ },
+ "type": "object"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "properties": {
+ "items": {
+ "$ref": "#/definitions/PropertyDataDefinition"
+ },
+ "type": "array"
+ },
+ "propertyValueCounter": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "type": {
+ "type": "string"
+ },
+ "typeUid": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "GroupInstance": {
+ "properties": {
+ "artifacts": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "artifactsUuid": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "creationTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "customizationUUID": {
+ "type": "string"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "groupInstanceArtifacts": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "groupInstanceArtifactsUuid": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "groupName": {
+ "type": "string"
+ },
+ "groupUUID": {
+ "type": "string"
+ },
+ "groupUid": {
+ "type": "string"
+ },
+ "invariantUUID": {
+ "type": "string"
+ },
+ "modificationTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "posX": {
+ "type": "string"
+ },
+ "posY": {
+ "type": "string"
+ },
+ "properties": {
+ "items": {
+ "$ref": "#/definitions/PropertyDataDefinition"
+ },
+ "type": "array"
+ },
+ "propertyValueCounter": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "GroupingDefinition": {
+ "properties": {
+ "empty": {
+ "type": "boolean"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "HeatParameterDataDefinition": {
+ "properties": {
+ "currentValue": {
+ "type": "string"
+ },
+ "defaultValue": {
+ "type": "string"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "HeatParameterDefinition": {
+ "properties": {
+ "currentValue": {
+ "type": "string"
+ },
+ "defaultValue": {
+ "type": "string"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "InputDefinition": {
+ "properties": {
+ "constraints": {
+ "items": {
+ "$ref": "#/definitions/PropertyConstraint"
+ },
+ "type": "array"
+ },
+ "defaultValue": {
+ "type": "string"
+ },
+ "definition": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "getInputValues": {
+ "items": {
+ "$ref": "#/definitions/GetInputValueDataDefinition"
+ },
+ "type": "array"
+ },
+ "hidden": {
+ "type": "boolean"
+ },
+ "immutable": {
+ "type": "boolean"
+ },
+ "inputId": {
+ "type": "string"
+ },
+ "inputPath": {
+ "type": "string"
+ },
+ "inputs": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceInput"
+ },
+ "type": "array"
+ },
+ "instanceUniqueId": {
+ "type": "string"
+ },
+ "label": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "parentUniqueId": {
+ "type": "string"
+ },
+ "password": {
+ "type": "boolean"
+ },
+ "properties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "propertyId": {
+ "type": "string"
+ },
+ "required": {
+ "type": "boolean"
+ },
+ "schema": {
+ "$ref": "#/definitions/SchemaDefinition"
+ },
+ "status": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "value": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "InterfaceDefinition": {
+ "properties": {
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "definition": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "operations": {
+ "additionalProperties": {
+ "$ref": "#/definitions/OperationDataDefinition"
+ },
+ "type": "object"
+ },
+ "operationsMap": {
+ "additionalProperties": {
+ "$ref": "#/definitions/Operation"
+ },
+ "type": "object"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "LifecycleChangeInfoWithAction": {
+ "properties": {
+ "action": {
+ "enum": [
+ "CREATE_FROM_CSAR",
+ "UPDATE_FROM_EXTERNAL_API"
+ ],
+ "type": "string"
+ },
+ "userRemarks": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "Operation": {
+ "properties": {
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "definition": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "implementation": {
+ "$ref": "#/definitions/ArtifactDataDefinition"
+ },
+ "implementationArtifact": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "inputs": {
+ "additionalProperties": {
+ "$ref": "#/definitions/PropertyDataDefinition"
+ },
+ "type": "object"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "OperationDataDefinition": {
+ "properties": {
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "implementation": {
+ "$ref": "#/definitions/ArtifactDataDefinition"
+ },
+ "inputs": {
+ "additionalProperties": {
+ "$ref": "#/definitions/PropertyDataDefinition"
+ },
+ "type": "object"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "Product": {
+ "properties": {
+ "additionalInformation": {
+ "items": {
+ "$ref": "#/definitions/AdditionalInformationDefinition"
+ },
+ "type": "array"
+ },
+ "allArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "allVersions": {
+ "additionalProperties": {
+ "type": "string"
+ },
+ "type": "object"
+ },
+ "artifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "capabilities": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/CapabilityDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "categories": {
+ "items": {
+ "$ref": "#/definitions/CategoryDefinition"
+ },
+ "type": "array"
+ },
+ "componentInstances": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstance"
+ },
+ "type": "array"
+ },
+ "componentInstancesAttributes": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesInputs": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceInput"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesProperties": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesRelations": {
+ "items": {
+ "$ref": "#/definitions/RequirementCapabilityRelDef"
+ },
+ "type": "array"
+ },
+ "componentMetadataDefinition": {
+ "$ref": "#/definitions/ComponentMetadataDefinition"
+ },
+ "componentType": {
+ "enum": [
+ "RESOURCE",
+ "SERVICE",
+ "RESOURCE_INSTANCE",
+ "PRODUCT",
+ "SERVICE_INSTANCE"
+ ],
+ "type": "string"
+ },
+ "conformanceLevel": {
+ "type": "string"
+ },
+ "contactId": {
+ "type": "string"
+ },
+ "contacts": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "creatorFullName": {
+ "type": "string"
+ },
+ "creatorUserId": {
+ "type": "string"
+ },
+ "csarUUID": {
+ "type": "string"
+ },
+ "csarVersion": {
+ "type": "string"
+ },
+ "deploymentArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "derivedFromGenericType": {
+ "type": "string"
+ },
+ "derivedFromGenericVersion": {
+ "type": "string"
+ },
+ "description": {
+ "type": "string"
+ },
+ "fullName": {
+ "type": "string"
+ },
+ "groups": {
+ "items": {
+ "$ref": "#/definitions/GroupDefinition"
+ },
+ "type": "array"
+ },
+ "highestVersion": {
+ "type": "boolean"
+ },
+ "icon": {
+ "type": "string"
+ },
+ "importedToscaChecksum": {
+ "type": "string"
+ },
+ "inputs": {
+ "items": {
+ "$ref": "#/definitions/InputDefinition"
+ },
+ "type": "array"
+ },
+ "invariantUUID": {
+ "type": "string"
+ },
+ "isActive": {
+ "type": "boolean"
+ },
+ "isDeleted": {
+ "type": "boolean"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "lastUpdaterFullName": {
+ "type": "string"
+ },
+ "lastUpdaterUserId": {
+ "type": "string"
+ },
+ "lifecycleState": {
+ "enum": [
+ "READY_FOR_CERTIFICATION",
+ "CERTIFICATION_IN_PROGRESS",
+ "CERTIFIED",
+ "NOT_CERTIFIED_CHECKIN",
+ "NOT_CERTIFIED_CHECKOUT"
+ ],
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "projectCode": {
+ "type": "string"
+ },
+ "requirements": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/RequirementDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "systemName": {
+ "type": "string"
+ },
+ "tags": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "toscaArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "toscaType": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "uuid": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "PropertyConstraint": {
+ "type": "object"
+ },
+ "PropertyDataDefinition": {
+ "properties": {
+ "defaultValue": {
+ "type": "string"
+ },
+ "definition": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "getInputValues": {
+ "items": {
+ "$ref": "#/definitions/GetInputValueDataDefinition"
+ },
+ "type": "array"
+ },
+ "hidden": {
+ "type": "boolean"
+ },
+ "immutable": {
+ "type": "boolean"
+ },
+ "inputId": {
+ "type": "string"
+ },
+ "inputPath": {
+ "type": "string"
+ },
+ "instanceUniqueId": {
+ "type": "string"
+ },
+ "label": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "parentUniqueId": {
+ "type": "string"
+ },
+ "password": {
+ "type": "boolean"
+ },
+ "propertyId": {
+ "type": "string"
+ },
+ "required": {
+ "type": "boolean"
+ },
+ "schema": {
+ "$ref": "#/definitions/SchemaDefinition"
+ },
+ "status": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "value": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "PropertyDefinition": {
+ "properties": {
+ "constraints": {
+ "items": {
+ "$ref": "#/definitions/PropertyConstraint"
+ },
+ "type": "array"
+ },
+ "defaultValue": {
+ "type": "string"
+ },
+ "definition": {
+ "type": "boolean"
+ },
+ "description": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "getInputValues": {
+ "items": {
+ "$ref": "#/definitions/GetInputValueDataDefinition"
+ },
+ "type": "array"
+ },
+ "hidden": {
+ "type": "boolean"
+ },
+ "immutable": {
+ "type": "boolean"
+ },
+ "inputId": {
+ "type": "string"
+ },
+ "inputPath": {
+ "type": "string"
+ },
+ "instanceUniqueId": {
+ "type": "string"
+ },
+ "label": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "parentUniqueId": {
+ "type": "string"
+ },
+ "password": {
+ "type": "boolean"
+ },
+ "propertyId": {
+ "type": "string"
+ },
+ "required": {
+ "type": "boolean"
+ },
+ "schema": {
+ "$ref": "#/definitions/SchemaDefinition"
+ },
+ "status": {
+ "type": "string"
+ },
+ "type": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "value": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "PropertyRule": {
+ "properties": {
+ "empty": {
+ "type": "boolean"
+ },
+ "firstToken": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "rule": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "ruleSize": {
+ "format": "int32",
+ "type": "integer"
+ },
+ "value": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "RelationshipImpl": {
+ "properties": {
+ "type": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "RequirementAndRelationshipPair": {
+ "properties": {
+ "capability": {
+ "type": "string"
+ },
+ "capabilityOwnerId": {
+ "type": "string"
+ },
+ "capabilityUid": {
+ "type": "string"
+ },
+ "id": {
+ "type": "string"
+ },
+ "relationship": {
+ "$ref": "#/definitions/RelationshipImpl"
+ },
+ "requirement": {
+ "type": "string"
+ },
+ "requirementOwnerId": {
+ "type": "string"
+ },
+ "requirementUid": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "RequirementCapabilityRelDef": {
+ "properties": {
+ "fromNode": {
+ "type": "string"
+ },
+ "relationships": {
+ "items": {
+ "$ref": "#/definitions/RequirementAndRelationshipPair"
+ },
+ "type": "array"
+ },
+ "toNode": {
+ "type": "string"
+ },
+ "uid": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "RequirementDefinition": {
+ "properties": {
+ "capability": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "leftOccurrences": {
+ "type": "string"
+ },
+ "maxOccurrences": {
+ "type": "string"
+ },
+ "minOccurrences": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "node": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "ownerName": {
+ "type": "string"
+ },
+ "parentName": {
+ "type": "string"
+ },
+ "path": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "relationship": {
+ "type": "string"
+ },
+ "source": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "Resource": {
+ "properties": {
+ "abstract": {
+ "type": "boolean"
+ },
+ "additionalInformation": {
+ "items": {
+ "$ref": "#/definitions/AdditionalInformationDefinition"
+ },
+ "type": "array"
+ },
+ "allArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "allVersions": {
+ "additionalProperties": {
+ "type": "string"
+ },
+ "type": "object"
+ },
+ "artifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "attributes": {
+ "items": {
+ "$ref": "#/definitions/PropertyDefinition"
+ },
+ "type": "array"
+ },
+ "capabilities": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/CapabilityDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "categories": {
+ "items": {
+ "$ref": "#/definitions/CategoryDefinition"
+ },
+ "type": "array"
+ },
+ "componentInstances": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstance"
+ },
+ "type": "array"
+ },
+ "componentInstancesAttributes": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesInputs": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceInput"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesProperties": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesRelations": {
+ "items": {
+ "$ref": "#/definitions/RequirementCapabilityRelDef"
+ },
+ "type": "array"
+ },
+ "componentMetadataDefinition": {
+ "$ref": "#/definitions/ComponentMetadataDefinition"
+ },
+ "componentType": {
+ "enum": [
+ "RESOURCE",
+ "SERVICE",
+ "RESOURCE_INSTANCE",
+ "PRODUCT",
+ "SERVICE_INSTANCE"
+ ],
+ "type": "string"
+ },
+ "conformanceLevel": {
+ "type": "string"
+ },
+ "contactId": {
+ "type": "string"
+ },
+ "cost": {
+ "type": "string"
+ },
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "creatorFullName": {
+ "type": "string"
+ },
+ "creatorUserId": {
+ "type": "string"
+ },
+ "csarUUID": {
+ "type": "string"
+ },
+ "csarVersion": {
+ "type": "string"
+ },
+ "defaultCapabilities": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "deploymentArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "derivedFrom": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "derivedFromGenericType": {
+ "type": "string"
+ },
+ "derivedFromGenericVersion": {
+ "type": "string"
+ },
+ "derivedList": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "description": {
+ "type": "string"
+ },
+ "groups": {
+ "items": {
+ "$ref": "#/definitions/GroupDefinition"
+ },
+ "type": "array"
+ },
+ "highestVersion": {
+ "type": "boolean"
+ },
+ "icon": {
+ "type": "string"
+ },
+ "importedToscaChecksum": {
+ "type": "string"
+ },
+ "inputs": {
+ "items": {
+ "$ref": "#/definitions/InputDefinition"
+ },
+ "type": "array"
+ },
+ "interfaces": {
+ "additionalProperties": {
+ "$ref": "#/definitions/InterfaceDefinition"
+ },
+ "type": "object"
+ },
+ "invariantUUID": {
+ "type": "string"
+ },
+ "isDeleted": {
+ "type": "boolean"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "lastUpdaterFullName": {
+ "type": "string"
+ },
+ "lastUpdaterUserId": {
+ "type": "string"
+ },
+ "licenseType": {
+ "type": "string"
+ },
+ "lifecycleState": {
+ "enum": [
+ "READY_FOR_CERTIFICATION",
+ "CERTIFICATION_IN_PROGRESS",
+ "CERTIFIED",
+ "NOT_CERTIFIED_CHECKIN",
+ "NOT_CERTIFIED_CHECKOUT"
+ ],
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "projectCode": {
+ "type": "string"
+ },
+ "properties": {
+ "items": {
+ "$ref": "#/definitions/PropertyDefinition"
+ },
+ "type": "array"
+ },
+ "requirements": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/RequirementDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "resourceType": {
+ "enum": [
+ "VFC",
+ "VF",
+ "CP",
+ "PNF",
+ "CVFC",
+ "VL",
+ "VFCMT",
+ "ABSTRACT"
+ ],
+ "type": "string"
+ },
+ "resourceVendorModelNumber": {
+ "type": "string"
+ },
+ "systemName": {
+ "type": "string"
+ },
+ "tags": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "toscaArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "toscaResourceName": {
+ "type": "string"
+ },
+ "toscaType": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "uuid": {
+ "type": "string"
+ },
+ "vendorName": {
+ "type": "string"
+ },
+ "vendorRelease": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "SchemaDefinition": {
+ "properties": {
+ "constraints": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "derivedFrom": {
+ "type": "string"
+ },
+ "empty": {
+ "type": "boolean"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "properties": {
+ "additionalProperties": {
+ "$ref": "#/definitions/PropertyDataDefinition"
+ },
+ "type": "object"
+ },
+ "property": {
+ "$ref": "#/definitions/PropertyDataDefinition"
+ }
+ },
+ "type": "object"
+ },
+ "Service": {
+ "properties": {
+ "additionalInformation": {
+ "items": {
+ "$ref": "#/definitions/AdditionalInformationDefinition"
+ },
+ "type": "array"
+ },
+ "allArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "allVersions": {
+ "additionalProperties": {
+ "type": "string"
+ },
+ "type": "object"
+ },
+ "artifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "capabilities": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/CapabilityDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "categories": {
+ "items": {
+ "$ref": "#/definitions/CategoryDefinition"
+ },
+ "type": "array"
+ },
+ "componentInstances": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstance"
+ },
+ "type": "array"
+ },
+ "componentInstancesAttributes": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesInputs": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceInput"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesProperties": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/ComponentInstanceProperty"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "componentInstancesRelations": {
+ "items": {
+ "$ref": "#/definitions/RequirementCapabilityRelDef"
+ },
+ "type": "array"
+ },
+ "componentMetadataDefinition": {
+ "$ref": "#/definitions/ComponentMetadataDefinition"
+ },
+ "componentType": {
+ "enum": [
+ "RESOURCE",
+ "SERVICE",
+ "RESOURCE_INSTANCE",
+ "PRODUCT",
+ "SERVICE_INSTANCE"
+ ],
+ "type": "string"
+ },
+ "conformanceLevel": {
+ "type": "string"
+ },
+ "contactId": {
+ "type": "string"
+ },
+ "creationDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "creatorFullName": {
+ "type": "string"
+ },
+ "creatorUserId": {
+ "type": "string"
+ },
+ "csarUUID": {
+ "type": "string"
+ },
+ "csarVersion": {
+ "type": "string"
+ },
+ "deploymentArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "derivedFromGenericType": {
+ "type": "string"
+ },
+ "derivedFromGenericVersion": {
+ "type": "string"
+ },
+ "description": {
+ "type": "string"
+ },
+ "distributionStatus": {
+ "enum": [
+ "DISTRIBUTION_NOT_APPROVED",
+ "DISTRIBUTION_APPROVED",
+ "DISTRIBUTED",
+ "DISTRIBUTION_REJECTED"
+ ],
+ "type": "string"
+ },
+ "ecompGeneratedNaming": {
+ "type": "boolean"
+ },
+ "groups": {
+ "items": {
+ "$ref": "#/definitions/GroupDefinition"
+ },
+ "type": "array"
+ },
+ "highestVersion": {
+ "type": "boolean"
+ },
+ "icon": {
+ "type": "string"
+ },
+ "importedToscaChecksum": {
+ "type": "string"
+ },
+ "inputs": {
+ "items": {
+ "$ref": "#/definitions/InputDefinition"
+ },
+ "type": "array"
+ },
+ "invariantUUID": {
+ "type": "string"
+ },
+ "isDeleted": {
+ "type": "boolean"
+ },
+ "lastUpdateDate": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "lastUpdaterFullName": {
+ "type": "string"
+ },
+ "lastUpdaterUserId": {
+ "type": "string"
+ },
+ "lifecycleState": {
+ "enum": [
+ "READY_FOR_CERTIFICATION",
+ "CERTIFICATION_IN_PROGRESS",
+ "CERTIFIED",
+ "NOT_CERTIFIED_CHECKIN",
+ "NOT_CERTIFIED_CHECKOUT"
+ ],
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "namingPolicy": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "projectCode": {
+ "type": "string"
+ },
+ "requirements": {
+ "additionalProperties": {
+ "items": {
+ "$ref": "#/definitions/RequirementDefinition"
+ },
+ "type": "array"
+ },
+ "type": "object"
+ },
+ "serviceApiArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "serviceRole": {
+ "type": "string"
+ },
+ "serviceType": {
+ "type": "string"
+ },
+ "systemName": {
+ "type": "string"
+ },
+ "tags": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "toscaArtifacts": {
+ "additionalProperties": {
+ "$ref": "#/definitions/ArtifactDefinition"
+ },
+ "type": "object"
+ },
+ "toscaType": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ },
+ "uuid": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "SubCategoryDefinition": {
+ "properties": {
+ "empty": {
+ "type": "boolean"
+ },
+ "groupings": {
+ "items": {
+ "$ref": "#/definitions/GroupingDefinition"
+ },
+ "type": "array"
+ },
+ "icons": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ },
+ "name": {
+ "type": "string"
+ },
+ "normalizedName": {
+ "type": "string"
+ },
+ "ownerId": {
+ "type": "string"
+ },
+ "uniqueId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ },
+ "User": {
+ "properties": {
+ "email": {
+ "type": "string"
+ },
+ "firstName": {
+ "type": "string"
+ },
+ "fullName": {
+ "type": "string"
+ },
+ "lastLoginTime": {
+ "format": "int64",
+ "type": "integer"
+ },
+ "lastName": {
+ "type": "string"
+ },
+ "role": {
+ "type": "string"
+ },
+ "status": {
+ "enum": [
+ "ACTIVE",
+ "INACTIVE"
+ ],
+ "type": "string"
+ },
+ "userId": {
+ "type": "string"
+ }
+ },
+ "type": "object"
+ }
+ },
+ "info": {
+ "title": "Internal API's",
+ "version": "1.0.0"
+ },
+ "paths": {
+ "/healthCheck": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "return BE health check",
+ "operationId": "getHealthCheck",
+ "parameters": [],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Titan, ES and BE are all up"
+ },
+ "500": {
+ "description": "One or more BE components (Titan, ES, BE) are down"
+ }
+ },
+ "summary": "return aggregate BE health check of Titan, ES and BE",
+ "tags": [
+ "BE Monitoring"
+ ]
+ }
+ },
+ "/monitoring": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "operationId": "processMonitoringMetrics",
+ "parameters": [
+ {
+ "in": "body",
+ "name": "body",
+ "required": false,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "BE Monitoring"
+ ]
+ }
+ },
+ "/v1/artifactTypes": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve all artifactTypes",
+ "operationId": "getArtifactTypes",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns artifactTypes Ok"
+ },
+ "404": {
+ "description": "No artifactTypes were found"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve all artifactTypes",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/audit-records/{componentType}/{componentUniqueId}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "get audit records for a service or a resource",
+ "operationId": "getComponentAuditRecords",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "get component audit records",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/dataTypes": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns data types",
+ "operationId": "getAllDataTypesServlet",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "datatypes"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Data types not found"
+ }
+ },
+ "summary": "Get data types",
+ "tags": [
+ "Types Fetch Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/products": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created product",
+ "operationId": "createProduct",
+ "parameters": [
+ {
+ "description": "Product object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "description": "USER_ID of product strategist user",
+ "in": "header",
+ "name": "USER_ID",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/Product"
+ }
+ },
+ "201": {
+ "description": "Product created"
+ },
+ "400": {
+ "description": "Invalid/missing content"
+ },
+ "403": {
+ "description": "Restricted operation / Empty USER_ID header"
+ },
+ "409": {
+ "description": "Product already exists / User not found / Wrong user role"
+ }
+ },
+ "summary": "Create product",
+ "tags": [
+ "Product Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/products/productName/{productName}/productVersion/{productVersion}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns product according to name and version",
+ "operationId": "getServiceByNameAndVersion",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "productName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "productVersion",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Product found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Product not found"
+ }
+ },
+ "summary": "Retrieve Service",
+ "tags": [
+ "Product Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/products/validate-name/{productName}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "checks if the chosen product name is available ",
+ "operationId": "validateServiceName",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "productName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "validate product name",
+ "tags": [
+ "Product Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/products/{productId}": {
+ "delete": {
+ "operationId": "deleteProduct",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "productId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Product Catalog"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns product according to productId",
+ "operationId": "getProductById",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "productId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Product found"
+ },
+ "403": {
+ "description": "Missing information"
+ },
+ "404": {
+ "description": "Product not found"
+ },
+ "409": {
+ "description": "Restricted operation"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve product",
+ "tags": [
+ "Product Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/products/{productId}/metadata": {
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated product",
+ "operationId": "updateProductMetadata",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "productId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Product object to be Updated",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Product Updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Product Metadata",
+ "tags": [
+ "Product Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created resource",
+ "operationId": "createResource",
+ "parameters": [
+ {
+ "description": "Resource object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/Resource"
+ }
+ },
+ "201": {
+ "description": "Resource created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Resource already exist"
+ }
+ },
+ "summary": "Create Resource",
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/certified/abstract": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "operationId": "getCertifiedAbstractResources",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/certified/notabstract": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "operationId": "getCertifiedNotAbstractResources",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/csar/{csaruuid}": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns resource created from csar uuid",
+ "operationId": "getResourceFromCsar",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "csaruuid",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/Resource"
+ }
+ },
+ "201": {
+ "description": "Resource retrieced"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Create Resource",
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/resourceName/{resourceName}/resourceVersion/{resourceVersion}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns resource according to resourceId",
+ "operationId": "getResourceByNameAndVersion",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "resourceVersion",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Resource not found"
+ }
+ },
+ "summary": "Retrieve Resource by name and version",
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/validate-name/{resourceName}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "checks if the chosen resource name is available ",
+ "operationId": "validateResourceName",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "query",
+ "name": "subtype",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "validate resource name",
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}": {
+ "delete": {
+ "operationId": "deleteResource",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Resources Catalog"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns resource according to resourceId",
+ "operationId": "getResourceById",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Resource not found"
+ }
+ },
+ "summary": "Retrieve Resource",
+ "tags": [
+ "Resources Catalog"
+ ]
+ },
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource",
+ "operationId": "updateResource",
+ "parameters": [
+ {
+ "description": "Resource object to be updated",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Resource already exist"
+ }
+ },
+ "summary": "Update Resource",
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/additionalinfo": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Additional Inforamtion property",
+ "operationId": "getAllResourceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "resource id to update with new property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "list of additional information"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Get all Additional Information under resource",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ },
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created Additional Inforamtion property",
+ "operationId": "createResourceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "resource id to update with new property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Additional information key value to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Additional information created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Create Additional Information Label and Value",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/additionalinfo/{labelId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted Additional Inforamtion property",
+ "operationId": "updateResourceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "resource id to update with new property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "label id",
+ "in": "path",
+ "name": "labelId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Additional information deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Create Additional Information Label and Value",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Additional Inforamtion property",
+ "operationId": "getResourceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "resource id to update with new property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "label id",
+ "in": "path",
+ "name": "labelId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "fetched additional information"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Get Additional Information by id",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ },
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated Additional Inforamtion property",
+ "operationId": "updateResourceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "resource id to update with new property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "label id",
+ "in": "path",
+ "name": "labelId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Additional information key value to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Additional information updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Update Additional Information Label and Value",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/artifacts": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created ArtifactDefinition",
+ "operationId": "loadArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Artifact already exist"
+ }
+ },
+ "summary": "Create Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/artifacts/{artifactId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns delete artifact",
+ "operationId": "deleteArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Delete Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns downloaded artifact",
+ "operationId": "downloadResourceArtifactBase64",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource artifact downloaded"
+ },
+ "404": {
+ "description": "Resource/Artifact not found"
+ }
+ },
+ "summary": "Download resource Artifact in Base64",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ },
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated artifact",
+ "operationId": "updateArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/attributes": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created resource attribute",
+ "operationId": "createAttribute",
+ "parameters": [
+ {
+ "description": "resource id to update with new attribute",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Resource attribute to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource property created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Resource attribute already exist"
+ }
+ },
+ "summary": "Create Resource Attribute",
+ "tags": [
+ "Resource Attribute Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/attributes/{attributeId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted attribute",
+ "operationId": "deleteAttribute",
+ "parameters": [
+ {
+ "description": "resource id of attribute",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Attribute id to delete",
+ "in": "path",
+ "name": "attributeId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "204": {
+ "description": "deleted attribute"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Resource property not found"
+ }
+ },
+ "summary": "Create Resource Attribute",
+ "tags": [
+ "Resource Attribute Servlet"
+ ]
+ },
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated attribute",
+ "operationId": "updateAttribute",
+ "parameters": [
+ {
+ "description": "resource id to update with new attribute",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "attribute id to update",
+ "in": "path",
+ "name": "attributeId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Resource attribute to update",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource attribute updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Resource Attribute",
+ "tags": [
+ "Resource Attribute Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/metadata": {
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource metadata",
+ "operationId": "updateResourceMetadata",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Resource metadata to be updated",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource metadata updated"
+ },
+ "400": {
+ "description": "Invalid content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Resource Metadata",
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/properties": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created resource property",
+ "operationId": "createProperty",
+ "parameters": [
+ {
+ "description": "resource id to update with new property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Resource property to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource property created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Resource property already exist"
+ }
+ },
+ "summary": "Create Resource Property",
+ "tags": [
+ "Resource Property Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/properties/{propertyId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted property",
+ "operationId": "deleteProperty",
+ "parameters": [
+ {
+ "description": "resource id of property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Property id to delete",
+ "in": "path",
+ "name": "propertyId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "204": {
+ "description": "deleted property"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Resource property not found"
+ }
+ },
+ "summary": "Create Resource Property",
+ "tags": [
+ "Resource Property Servlet"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns property of resource",
+ "operationId": "getProperty",
+ "parameters": [
+ {
+ "description": "resource id of property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "proerty id to get",
+ "in": "path",
+ "name": "propertyId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "property"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Resource property not found"
+ }
+ },
+ "summary": "Create Resource Property",
+ "tags": [
+ "Resource Property Servlet"
+ ]
+ },
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated property",
+ "operationId": "updateProperty",
+ "parameters": [
+ {
+ "description": "resource id to update with new property",
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "proerty id to update",
+ "in": "path",
+ "name": "propertyId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Resource property to update",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource property updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Resource Property",
+ "tags": [
+ "Resource Property Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/{interfaceType}/{operation}/artifacts": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created resource",
+ "operationId": "loadArtifactToInterface",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "interfaceType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "operation",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "Content-MD5",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Artifact already exist"
+ }
+ },
+ "summary": "Create Artifact and Attach to interface",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceId}/{interfaceType}/{operation}/artifacts/{artifactId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "delete matching artifact from interface",
+ "operationId": "deleteArtifactToInterface",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "interfaceType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "operation",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "delete artifact under interface deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Artifact already exist"
+ }
+ },
+ "summary": "delete Artifact from interface",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ },
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "updates artifact by interface",
+ "operationId": "updateArtifactToInterface",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "interfaceType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "operation",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "Content-MD5",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "delete artifact under interface deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Artifact already exist"
+ }
+ },
+ "summary": "update Artifact Attach to interface",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/resources/{resourceName}/{version}": {
+ "delete": {
+ "operationId": "deleteResourceByNameAndVersion",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "resourceName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "version",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Resources Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created service",
+ "operationId": "createService",
+ "parameters": [
+ {
+ "description": "Service object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/Service"
+ }
+ },
+ "201": {
+ "description": "Service created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Service already exist"
+ }
+ },
+ "summary": "Create Service",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/distribution/{did}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Return the list of distribution status objects",
+ "operationId": "getListOfDistributionStatuses",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "did",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Status not found"
+ }
+ },
+ "summary": "Retrieve Distributions",
+ "tags": [
+ "Distribution Service Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/services/serviceName/{serviceName}/serviceVersion/{serviceVersion}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns service according to name and version",
+ "operationId": "getServiceByNameAndVersion",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "serviceVersion",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Service not found"
+ }
+ },
+ "summary": "Retrieve Service",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/toscatoheat/{artifactName}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns downloaded artifact",
+ "operationId": "downloadServiceArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "artifactName",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/octet-stream"
+ ],
+ "responses": {
+ "200": {
+ "description": "Artifact downloaded"
+ },
+ "401": {
+ "description": "Authorization required"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Artifact not found"
+ }
+ },
+ "summary": "Download service artifact",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/validate-name/{serviceName}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "checks if the chosen service name is available ",
+ "operationId": "validateServiceName",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "validate service name",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{componentId}/inputs": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Inputs list",
+ "operationId": "getComponentInputs",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "query",
+ "name": "fromId",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "format": "int32",
+ "in": "query",
+ "name": "amount",
+ "required": false,
+ "type": "integer"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get Inputs only",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}": {
+ "delete": {
+ "operationId": "deleteService",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Service Catalog"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns service according to serviceId",
+ "operationId": "getServiceById",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Service not found"
+ }
+ },
+ "summary": "Retrieve Service",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/additionalinfo": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Additional Inforamtion property",
+ "operationId": "getAllServiceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "service id to update with new property",
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "list of additional information"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Get all Additional Information under service",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ },
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created Additional Inforamtion property",
+ "operationId": "createServiceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "service id to update with new property",
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Additional information key value to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Additional information created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Create Additional Information Label and Value",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/additionalinfo/{labelId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted Additional Inforamtion property",
+ "operationId": "deleteServiceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "service id to update with new property",
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "label id",
+ "in": "path",
+ "name": "labelId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Additional information deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Create Additional Information Label and Value",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Additional Inforamtion property",
+ "operationId": "getServiceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "service id to update with new property",
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "label id",
+ "in": "path",
+ "name": "labelId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "fetched additional information"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Get Additional Information by id",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ },
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated Additional Inforamtion property",
+ "operationId": "updateServiceAdditionalInformationLabel",
+ "parameters": [
+ {
+ "description": "service id to update with new property",
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "label id",
+ "in": "path",
+ "name": "labelId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Additional information key value to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Additional information updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Additional information key already exist"
+ }
+ },
+ "summary": "Update Additional Information Label and Value",
+ "tags": [
+ "Additional Information Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/artifacts": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created ArtifactDefinition",
+ "operationId": "loadInformationArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Artifact already exist"
+ }
+ },
+ "summary": "Create Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/artifacts/api/{artifactId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Deleted ArtifactDefinition",
+ "operationId": "deleteApiArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "Content-MD5",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "204": {
+ "description": "Api Artifact deleted"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Delete Api Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ },
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created ArtifactDefinition",
+ "operationId": "updateApiArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "Content-MD5",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Api Artifact Updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Api Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/artifacts/{artifactId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns delete artifact",
+ "operationId": "deleteInformationalArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Service artifact deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Delete Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns downloaded artifact",
+ "operationId": "downloadServiceArtifactBase64",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service artifact downloaded"
+ },
+ "404": {
+ "description": "Service/Artifact not found"
+ }
+ },
+ "summary": "Download service Artifact in Base64",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ },
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated artifact",
+ "operationId": "updateInformationArtifact",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Service artifact created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/distribution-state/{state}": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "service with the changed distribution status",
+ "operationId": "updateServiceDistributionState",
+ "parameters": [
+ {
+ "description": "DistributionChangeInfo - get comment out of body",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/LifecycleChangeInfoWithAction"
+ }
+ },
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "enum": [
+ "approve",
+ "reject"
+ ],
+ "in": "path",
+ "name": "state",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service distribution state changed"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Service is not available for distribution"
+ },
+ "404": {
+ "description": "Requested service was not found"
+ },
+ "409": {
+ "description": "Restricted operation"
+ },
+ "500": {
+ "description": "Internal Server Error. Please try again later."
+ }
+ },
+ "summary": "Update Service Distribution State",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/distribution/{did}/markDeployed": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "relevant audit record will be created",
+ "operationId": "markDistributionAsDeployed",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "did",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service was marked as deployed"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Service is not available"
+ },
+ "404": {
+ "description": "Requested service was not found"
+ },
+ "409": {
+ "description": "Restricted operation"
+ },
+ "500": {
+ "description": "Internal Server Error. Please try again later."
+ }
+ },
+ "summary": "Mark distribution as deployed",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/distribution/{env}/activate": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "activate distribution",
+ "operationId": "activateDistribution",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "env",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "OK"
+ },
+ "404": {
+ "description": "Requested service was not found"
+ },
+ "409": {
+ "description": "Service cannot be distributed due to missing deployment artifacts"
+ },
+ "500": {
+ "description": "Internal Server Error. Please try again later."
+ }
+ },
+ "summary": "Activate distribution",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/metadata": {
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated service",
+ "operationId": "updateServiceMetadata",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Service object to be Updated",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service Updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Service Metadata",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceId}/tempUrlToBeDeleted": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "operationId": "tempUrlToBeDeleted",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "OK"
+ },
+ "500": {
+ "description": "Internal Server Error. Please try again later."
+ }
+ },
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceName}/{version}": {
+ "delete": {
+ "operationId": "deleteServiceByNameAndVersion",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceName",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "version",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/services/{serviceUUID}/distribution": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns list bases on the information extracted from Auditing Records according to service uuid",
+ "operationId": "getServiceById",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceUUID",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Service found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Service not found"
+ }
+ },
+ "summary": "Retrieve Distributions",
+ "tags": [
+ "Distribution Service Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/upload/{resourceAuthority}": {
+ "post": {
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "description": "Returns created resource",
+ "operationId": "uploadMultipart",
+ "parameters": [
+ {
+ "description": "validValues: normative-resource / user-resource",
+ "enum": [
+ "multipart",
+ "user-resource",
+ "user-resource-ui-import"
+ ],
+ "in": "path",
+ "name": "resourceAuthority",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "FileInputStream",
+ "in": "formData",
+ "name": "resourceZip",
+ "required": false,
+ "type": "file"
+ },
+ {
+ "description": "resourceMetadata",
+ "in": "formData",
+ "name": "resourceMetadata",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "default": true,
+ "in": "query",
+ "name": "createNewVersion",
+ "required": false,
+ "type": "boolean"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Resource already exist"
+ }
+ },
+ "summary": "Create Resource from yaml",
+ "tags": [
+ "Resources Catalog Upload"
+ ]
+ }
+ },
+ "/v1/catalog/uploadType/capability": {
+ "post": {
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "description": "Returns created Capability Type",
+ "operationId": "uploadCapabilityType",
+ "parameters": [
+ {
+ "description": "FileInputStream",
+ "in": "formData",
+ "name": "capabilityTypeZip",
+ "required": false,
+ "type": "file"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Capability Type created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Capability Type already exist"
+ }
+ },
+ "summary": "Create Capability Type from yaml",
+ "tags": [
+ "Catalog Types Upload"
+ ]
+ }
+ },
+ "/v1/catalog/uploadType/categories": {
+ "post": {
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "description": "Returns created categories",
+ "operationId": "uploadCategories",
+ "parameters": [
+ {
+ "description": "FileInputStream",
+ "in": "formData",
+ "name": "categoriesZip",
+ "required": false,
+ "type": "file"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Categories created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Category already exist"
+ }
+ },
+ "summary": "Create Categories from yaml",
+ "tags": [
+ "Catalog Types Upload"
+ ]
+ }
+ },
+ "/v1/catalog/uploadType/datatypes": {
+ "post": {
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "description": "Returns created data types",
+ "operationId": "uploadDataTypes",
+ "parameters": [
+ {
+ "description": "FileInputStream",
+ "in": "formData",
+ "name": "dataTypesZip",
+ "required": false,
+ "type": "file"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Data types created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Data types already exist"
+ }
+ },
+ "summary": "Create Categories from yaml",
+ "tags": [
+ "Catalog Types Upload"
+ ]
+ }
+ },
+ "/v1/catalog/uploadType/grouptypes": {
+ "post": {
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "description": "Returns created group types",
+ "operationId": "uploadGroupTypes",
+ "parameters": [
+ {
+ "description": "FileInputStream",
+ "in": "formData",
+ "name": "groupTypesZip",
+ "required": false,
+ "type": "file"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "group types created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "group types already exist"
+ }
+ },
+ "summary": "Create GroupTypes from yaml",
+ "tags": [
+ "Catalog Types Upload"
+ ]
+ }
+ },
+ "/v1/catalog/uploadType/interfaceLifecycle": {
+ "post": {
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "description": "Returns created Interface Lifecycle Type",
+ "operationId": "uploadInterfaceLifecycleType",
+ "parameters": [
+ {
+ "description": "FileInputStream",
+ "in": "formData",
+ "name": "interfaceLifecycleTypeZip",
+ "required": false,
+ "type": "file"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Interface Lifecycle Type created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Interface Lifecycle Type already exist"
+ }
+ },
+ "summary": "Create Interface Lyfecycle Type from yaml",
+ "tags": [
+ "Catalog Types Upload"
+ ]
+ }
+ },
+ "/v1/catalog/uploadType/policytypes": {
+ "post": {
+ "consumes": [
+ "multipart/form-data"
+ ],
+ "description": "Returns created policy types",
+ "operationId": "uploadPolicyTypes",
+ "parameters": [
+ {
+ "description": "FileInputStream",
+ "in": "formData",
+ "name": "policyTypesZip",
+ "required": false,
+ "type": "file"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "policy types created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "policy types already exist"
+ }
+ },
+ "summary": "Create PolicyTypes from yaml",
+ "tags": [
+ "Catalog Types Upload"
+ ]
+ }
+ },
+ "/v1/catalog/{componentCollection}/{componentId}/lifecycleState/{lifecycleOperation}": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "",
+ "operationId": "changeResourceState",
+ "parameters": [
+ {
+ "description": "LifecycleChangeInfo - relevant for checkin, failCertification, cancelCertification",
+ "in": "body",
+ "name": "body",
+ "required": false,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "description": "validValues: resources / services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "componentCollection",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "enum": [
+ "checkout",
+ "undoCheckout",
+ "checkin",
+ "certificationRequest",
+ "startCertification",
+ "failCertification",
+ "cancelCertification",
+ "certify"
+ ],
+ "in": "path",
+ "name": "lifecycleOperation",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "id of component to be changed",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "id of user initiating the operation",
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource state changed"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Resource already exist"
+ }
+ },
+ "summary": "Change Resource lifecycle State",
+ "tags": [
+ "Lifecycle Actions Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/latestversion/notabstract": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Requirments And Capabilities according to componentId",
+ "operationId": "getLatestVersionNotAbstractCheckoutComponentsByBody",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "query",
+ "name": "internalComponentType",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "Consumer Object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "items": {
+ "type": "string"
+ },
+ "type": "array"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get Component Requirments And Capabilities",
+ "tags": [
+ "Component Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/latestversion/notabstract/metadata": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns componentId",
+ "operationId": "getLatestVersionNotAbstractCheckoutComponentsIdesOnly",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "query",
+ "name": "internalComponentType",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "uid list",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get Component uid only",
+ "tags": [
+ "Component Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/componentInstances": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns component instances",
+ "operationId": "getComponentInstancesFilteredByPropertiesAndInputs",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "query",
+ "name": "searchText",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "uid list",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get Component instances",
+ "tags": [
+ "Component Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/componentInstances/{instanceId}/{inputId}/properties": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns properties list",
+ "operationId": "getInputPropertiesForComponentInstance",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "instanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "inputId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get properties",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/componentInstances/{instanceId}/{originComponentUid}/inputs": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Inputs list",
+ "operationId": "getComponentInstanceInputs",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "instanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "originComponentUid",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get Inputs only",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/create/inputs": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Return inputs list",
+ "operationId": "createMultipleInputs",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "ComponentIns Inputs Object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Create inputs on service",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/delete/{inputId}/input": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Delete service input",
+ "operationId": "deleteInput",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "inputId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "Service Input to be deleted",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Input deleted"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Input not found"
+ }
+ },
+ "summary": "Delete input from service",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/filteredDataByParams": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns resource according to resourceId",
+ "operationId": "getComponentDataFilteredByParams",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "collectionFormat": "multi",
+ "in": "query",
+ "items": {
+ "type": "string"
+ },
+ "name": "include",
+ "required": false,
+ "type": "array"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Resource not found"
+ }
+ },
+ "summary": "Retrieve Resource",
+ "tags": [
+ "Component Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/filteredproperties/{propertyNameFragment}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns properties belonging to component instances of specific component by name and optionally resource type",
+ "operationId": "getFilteredComponentInstanceProperties",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "propertyNameFragment",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "collectionFormat": "multi",
+ "in": "query",
+ "items": {
+ "type": "string"
+ },
+ "name": "resourceType",
+ "required": false,
+ "type": "array"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Retrieve properties belonging to component instances of specific component by name and optionally resource type",
+ "tags": [
+ "Component Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/inputs/{inputId}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns inputs list",
+ "operationId": "getInputsAndPropertiesForComponentInput",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "inputId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get inputs",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/inputs/{inputId}/inputs": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns inputs list",
+ "operationId": "getInputsForComponentInput",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "inputId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get inputs",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentId}/requirmentsCapabilities": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns Requirements And Capabilities according to componentId",
+ "operationId": "getRequirementAndCapabilities",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Get Component Requirments And Capabilities",
+ "tags": [
+ "Component Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{componentType}/{componentUuid}/conformanceLevelValidation": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns the result according to conformance level in BE config",
+ "operationId": "conformanceLevelValidation",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentUuid",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component not found"
+ }
+ },
+ "summary": "Validate Component Conformance Level",
+ "tags": [
+ "Component Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/artifactsByType/{artifactGroupType}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns artifacts",
+ "operationId": "getComponentArtifacts",
+ "parameters": [
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactGroupType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component artifacts"
+ },
+ "404": {
+ "description": "Resource/Artifact not found"
+ }
+ },
+ "summary": "Get component Artifacts",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/groups/{groupId}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns artifacts metadata according to groupId",
+ "operationId": "getGroupArtifactById",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "groupId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "group found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Group not found"
+ }
+ },
+ "summary": "Get group artifacts ",
+ "tags": [
+ "Resource Group Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/groups/{groupUniqueId}/metadata": {
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated group definition",
+ "operationId": "updateGroupMetadata",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "groupUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Service object to be Updated",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Group Updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Group Metadata",
+ "tags": [
+ "Resource Group Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/groups/{groupUniqueId}/properties": {
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated list of properties",
+ "operationId": "updateGroupProperties",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "groupUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Service object to be Updated",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Group Updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Updates List of properties on a group (only values)",
+ "tags": [
+ "Resource Group Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created ComponentInstance",
+ "operationId": "createComponentInstance",
+ "parameters": [
+ {
+ "description": "RI object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "USER_ID of modifier user",
+ "in": "header",
+ "name": "USER_ID",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Component created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Component instance already exist"
+ }
+ },
+ "summary": "Create ComponentInstance",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/associate": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created RelationshipInfo",
+ "operationId": "associateRIToRI",
+ "parameters": [
+ {
+ "description": "unique id of the container component",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "allowed values are resources /services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "RelationshipInfo",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Relationship created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Missing information"
+ },
+ "409": {
+ "description": "Relationship already exist"
+ }
+ },
+ "summary": "Associate RI to RI",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/createAndAssociate": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created RI and RelationshipInfo",
+ "operationId": "createAndAssociateRIToRI",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "RI created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Relationship already exist"
+ }
+ },
+ "summary": "Create RI and associate RI to RI",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/dissociate": {
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted RelationshipInfo",
+ "operationId": "dissociateRIFromRI",
+ "parameters": [
+ {
+ "description": "allowed values are resources /services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "unique id of the container component",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "RelationshipInfo",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Relationship deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Missing information"
+ }
+ },
+ "summary": "Dissociate RI from RI",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/multipleComponentInstance": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource instance",
+ "operationId": "updateMultipleComponentInstance",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Component Instance JSON Array",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource instance updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance multiple component",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource instance",
+ "operationId": "updateComponentInstanceMetadata",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Resource instance updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/artifacts": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated artifact",
+ "operationId": "loadComponentInstanceArtifact",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "Content-MD5",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Artifact updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Load Resource Instance artifact payload",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/artifacts/{artifactId}": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted artifact",
+ "operationId": "deleteComponentInstanceArtifact",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "Content-MD5",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Artifact updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Delete Resource Instance artifact",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/artifacts/{artifactId}/heatParams": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated artifact",
+ "operationId": "updateRIArtifact",
+ "parameters": [
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the artifact",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Artifact updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Resource Instance HEAT_ENV parameters",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/attribute": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource instance attribute",
+ "operationId": "updateResourceInstanceAttribute",
+ "parameters": [
+ {
+ "description": "service id",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "resource instance id",
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "id of user initiating the operation",
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource instance created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance attribute",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/changeVersion": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource instance",
+ "operationId": "changeResourceInstanceVersion",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource instance created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/groupInstance/{groupInstId}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns artifacts metadata according to groupInstId",
+ "operationId": "getGroupArtifactById",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "groupInstId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "group found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Group not found"
+ }
+ },
+ "summary": "Get group artifacts ",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/groupInstance/{groupInstanceId}/property": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource instance property",
+ "operationId": "updateGroupInstanceProperty",
+ "parameters": [
+ {
+ "description": "service id",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "resource instance id",
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "group instance id",
+ "in": "path",
+ "name": "groupInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "id of user initiating the operation",
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource instance created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance property",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/input": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource instance property",
+ "operationId": "updateResourceInstanceInput",
+ "parameters": [
+ {
+ "description": "service id",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "resource instance id",
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "id of user initiating the operation",
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource instance created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance property",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/property": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated resource instance property",
+ "operationId": "updateResourceInstanceProperty",
+ "parameters": [
+ {
+ "description": "service id",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "resource instance id",
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "id of user initiating the operation",
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource instance created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance property",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{componentInstanceId}/property/{propertyId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted resource instance property",
+ "operationId": "deleteResourceInstanceProperty",
+ "parameters": [
+ {
+ "description": "service id",
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "resource instance id",
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "property id",
+ "in": "path",
+ "name": "propertyId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "id of user initiating the operation",
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Resource instance created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource instance",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstance/{resourceInstanceId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns delete resourceInstance",
+ "operationId": "deleteResourceInstance",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "resourceInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "ResourceInstance deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Delete ResourceInstance",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstances/{componentInstanceId}/artifacts/{artifactId}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns downloaded artifact",
+ "operationId": "downloadResourceInstanceArtifactBase64",
+ "parameters": [
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "ResourceInstance artifact downloaded"
+ },
+ "404": {
+ "description": "ResourceInstance/Artifact not found"
+ }
+ },
+ "summary": "Download component Artifact in Base64",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/resourceInstances/{componentInstanceId}/artifactsByType/{artifactGroupType}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns artifacts",
+ "operationId": "getComponentInstanceArtifacts",
+ "parameters": [
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "artifactGroupType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Component artifacts"
+ },
+ "404": {
+ "description": "Resource/Artifact not found"
+ }
+ },
+ "summary": "Get component Artifacts",
+ "tags": [
+ "Resource Artifact Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{componentId}/update/inputs": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated input",
+ "operationId": "updateComponentInputs",
+ "parameters": [
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the input",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Input updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update resource inputs",
+ "tags": [
+ "Input Catalog"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{containerComponentId}/componentInstances/{componentInstanceUniqueId}/properties": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns component instance properties",
+ "operationId": "getInstancePropertiesById",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "containerComponentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Properties found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Component/Component Instance - not found"
+ }
+ },
+ "summary": "Get component instance properties",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{containerComponentId}/serviceProxy": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created service proxy",
+ "operationId": "createServiceProxy",
+ "parameters": [
+ {
+ "description": "RI object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "path",
+ "name": "containerComponentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "USER_ID of modifier user",
+ "in": "header",
+ "name": "USER_ID",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Service proxy created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "409": {
+ "description": "Service proxy already exist"
+ }
+ },
+ "summary": "Create service proxy",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{containerComponentId}/serviceProxy/{serviceProxyId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns delete service proxy",
+ "operationId": "deleteServiceProxy",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "containerComponentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "serviceProxyId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Service proxy deleted"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Delete service proxy",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{containerComponentId}/serviceProxy/{serviceProxyId}/changeVersion/{newServiceId}": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated service proxy",
+ "operationId": "changeServiceProxyVersion",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "containerComponentId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "serviceProxyId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "valid values: resources / services",
+ "enum": [
+ "resources",
+ "services"
+ ],
+ "in": "path",
+ "name": "containerComponentType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Service proxy created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update service proxy with new version",
+ "tags": [
+ "Resource Instance Servlet"
+ ]
+ }
+ },
+ "/v1/catalog/{containerComponentType}/{serviceId}/resourceInstance/{componentInstanceId}/groupInstance/{groupInstanceId}": {
+ "put": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns updated group instance",
+ "operationId": "updateGroupInstancePropertyValues",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "serviceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "groupInstanceId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Group instance object to be Updated",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Group Instance Property Values Updated"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Update Group Instance Property Values",
+ "tags": [
+ "Service Catalog"
+ ]
+ }
+ },
+ "/v1/categories": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve the all resource, service and product categories",
+ "operationId": "getAllCategories",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns categories Ok"
+ },
+ "403": {
+ "description": "Missing information"
+ },
+ "409": {
+ "description": "Restricted operation"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve the all resource, service and product categories",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/categories/{componentType}": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve the list of all resource/service/product categories/sub-categories/groupings.",
+ "operationId": "getComponentCategories",
+ "parameters": [
+ {
+ "description": "allowed values are resources / services/ products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns categories Ok"
+ },
+ "400": {
+ "description": "Invalid component type"
+ },
+ "403": {
+ "description": "Missing information"
+ },
+ "409": {
+ "description": "Restricted operation"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve the list of all resource/service/product categories/sub-categories/groupings",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/category/{componentType}": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Create new component category",
+ "operationId": "createComponentCategory",
+ "parameters": [
+ {
+ "description": "allowed values are resources /services / products",
+ "enum": [
+ "resources",
+ "services",
+ "products"
+ ],
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Category to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Category created"
+ },
+ "400": {
+ "description": "Invalid category data"
+ },
+ "403": {
+ "description": "USER_ID header is missing"
+ },
+ "409": {
+ "description": "Category already exists / User not permitted to perform the action"
+ },
+ "500": {
+ "description": "General Error"
+ }
+ },
+ "summary": "Create new component category",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/category/{componentType}/{categoryId}/subCategory": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Create new component sub-category for existing category",
+ "operationId": "createComponentSubCategory",
+ "parameters": [
+ {
+ "description": "allowed values are resources / products",
+ "enum": [
+ "resources",
+ "products"
+ ],
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Parent category unique ID",
+ "in": "path",
+ "name": "categoryId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Subcategory to be created. \ne.g. {\"name\":\"Resource-subcat\"}",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Subcategory created"
+ },
+ "400": {
+ "description": "Invalid subcategory data"
+ },
+ "403": {
+ "description": "USER_ID header is missing"
+ },
+ "404": {
+ "description": "Parent category wasn't found"
+ },
+ "409": {
+ "description": "Subcategory already exists / User not permitted to perform the action"
+ },
+ "500": {
+ "description": "General Error"
+ }
+ },
+ "summary": "Create new component sub-category",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/category/{componentType}/{categoryId}/subCategory/{subCategoryId}/grouping": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Create new component grouping for existing sub-category",
+ "operationId": "createComponentGrouping",
+ "parameters": [
+ {
+ "description": "allowed values are products",
+ "enum": [
+ "products"
+ ],
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Parent category unique ID",
+ "in": "path",
+ "name": "categoryId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Parent sub-category unique ID",
+ "in": "path",
+ "name": "subCategoryId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "Subcategory to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Grouping created"
+ },
+ "400": {
+ "description": "Invalid grouping data"
+ },
+ "403": {
+ "description": "USER_ID header is missing"
+ },
+ "404": {
+ "description": "Parent category or subcategory were not found"
+ },
+ "409": {
+ "description": "Grouping already exists / User not permitted to perform the action"
+ },
+ "500": {
+ "description": "General Error"
+ }
+ },
+ "summary": "Create new component grouping",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/category/{componentType}/{categoryUniqueId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Delete component category",
+ "operationId": "deleteComponentCategory",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "categoryUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/Category"
+ }
+ },
+ "204": {
+ "description": "Category deleted"
+ },
+ "403": {
+ "description": "USER_ID header is missing"
+ },
+ "404": {
+ "description": "Category not found"
+ },
+ "409": {
+ "description": "User not permitted to perform the action"
+ },
+ "500": {
+ "description": "General Error"
+ }
+ },
+ "summary": "Delete component category",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/category/{componentType}/{categoryUniqueId}/subCategory/{subCategoryUniqueId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Delete component category",
+ "operationId": "deleteComponentSubCategory",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "categoryUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "subCategoryUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/Category"
+ }
+ },
+ "204": {
+ "description": "Category deleted"
+ },
+ "403": {
+ "description": "USER_ID header is missing"
+ },
+ "404": {
+ "description": "Category not found"
+ },
+ "409": {
+ "description": "User not permitted to perform the action"
+ },
+ "500": {
+ "description": "General Error"
+ }
+ },
+ "summary": "Delete component category",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/category/{componentType}/{categoryUniqueId}/subCategory/{subCategoryUniqueId}/grouping/{groupingUniqueId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Delete component category",
+ "operationId": "deleteComponentGrouping",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "categoryUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "subCategoryUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "groupingUniqueId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/Category"
+ }
+ },
+ "204": {
+ "description": "Category deleted"
+ },
+ "403": {
+ "description": "USER_ID header is missing"
+ },
+ "404": {
+ "description": "Category not found"
+ },
+ "409": {
+ "description": "User not permitted to perform the action"
+ },
+ "500": {
+ "description": "General Error"
+ }
+ },
+ "summary": "Delete component category",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/configuration/ui": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve all artifactTypes",
+ "operationId": "getConfiguration",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns artifactTypes Ok"
+ },
+ "404": {
+ "description": "No artifactTypes were found"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve all artifactTypes",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/consumers": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns created ONAP consumer credentials",
+ "operationId": "createConsumer",
+ "parameters": [
+ {
+ "description": "Consumer Object to be created",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "201": {
+ "description": "Consumer credentials created"
+ },
+ "400": {
+ "description": "Invalid content / Missing content"
+ },
+ "403": {
+ "description": "Restricted operation"
+ }
+ },
+ "summary": "Consumer credentials",
+ "tags": [
+ "Consumer Servlet"
+ ]
+ }
+ },
+ "/v1/consumers/{consumerId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns deleted consumer according to ConsumerID",
+ "operationId": "deleteConsumer",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "consumerId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/ConsumerDefinition"
+ }
+ },
+ "204": {
+ "description": "Consumer deleted"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Consumer not found"
+ }
+ },
+ "summary": "Deletes Consumer",
+ "tags": [
+ "Consumer Servlet"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns consumer according to ConsumerID",
+ "operationId": "getConsumer",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "consumerId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Consumer found"
+ },
+ "403": {
+ "description": "Restricted operation"
+ },
+ "404": {
+ "description": "Consumer not found"
+ }
+ },
+ "summary": "Retrieve Consumer",
+ "tags": [
+ "Consumer Servlet"
+ ]
+ }
+ },
+ "/v1/ecompPortalMenu": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve ONAP portal menu",
+ "operationId": "getListOfCsars",
+ "parameters": [],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Retrieve ONAP portal menu"
+ }
+ },
+ "summary": "Retrieve ONAP portal menu - MOC",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/followed": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve all followed",
+ "operationId": "getFollowedResourcesServices",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns followed Ok"
+ },
+ "404": {
+ "description": "User not found"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve all followed",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/inactiveComponents/{componentType}": {
+ "delete": {
+ "operationId": "deleteMarkedResources",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "componentType",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "default": {
+ "description": "successful operation"
+ }
+ },
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/propertyScopes": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve all propertyScopes",
+ "operationId": "getPropertyScopes",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns propertyScopes Ok"
+ },
+ "404": {
+ "description": "No propertyScopes were found"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve all propertyScopes",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/screen": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve catalog resources and services",
+ "operationId": "getCatalogComponents",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "collectionFormat": "multi",
+ "in": "query",
+ "items": {
+ "enum": [
+ "PRODUCT",
+ "SERVICE",
+ "VF",
+ "VFC",
+ "CP",
+ "VL",
+ "VFCMT",
+ "CVFC",
+ "PNF"
+ ],
+ "type": "string"
+ },
+ "name": "excludeTypes",
+ "required": false,
+ "type": "array"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns resources and services Ok"
+ },
+ "404": {
+ "description": "User not found"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve catalog resources and services",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/tags": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Retrieve all tags",
+ "operationId": "getTags",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns tags Ok"
+ },
+ "404": {
+ "description": "No tags were found"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve all tags",
+ "tags": [
+ "Element Servlet"
+ ]
+ }
+ },
+ "/v1/user": {
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Provision new user",
+ "operationId": "createUser",
+ "parameters": [
+ {
+ "description": "json describe the user",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/User"
+ }
+ },
+ "201": {
+ "description": "New user created"
+ },
+ "400": {
+ "description": "Invalid Content."
+ },
+ "403": {
+ "description": "Missing information"
+ },
+ "405": {
+ "description": "Method Not Allowed"
+ },
+ "409": {
+ "description": "User already exists"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "add user",
+ "tags": [
+ "User Administration"
+ ]
+ }
+ },
+ "/v1/user/admins": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns all administrators",
+ "operationId": "getAdminsUser",
+ "parameters": [
+ {
+ "in": "path",
+ "name": "userId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns user Ok"
+ },
+ "405": {
+ "description": "Method Not Allowed"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "retrieve all administrators",
+ "tags": [
+ "User Administration"
+ ]
+ }
+ },
+ "/v1/user/authorize": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "authorize user",
+ "operationId": "authorize",
+ "parameters": [
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "HTTP_CSP_FIRSTNAME",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "HTTP_CSP_LASTNAME",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "HTTP_CSP_EMAIL",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns user Ok"
+ },
+ "403": {
+ "description": "Restricted Access"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "authorize",
+ "tags": [
+ "User Administration"
+ ]
+ }
+ },
+ "/v1/user/users": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns list of users with the specified roles, or all of users in the case of empty 'roles' header",
+ "operationId": "getUsersList",
+ "parameters": [
+ {
+ "description": "Any active user's USER_ID ",
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ },
+ {
+ "description": "TESTER,DESIGNER,PRODUCT_STRATEGIST,OPS,PRODUCT_MANAGER,GOVERNOR, ADMIN OR all users by not typing anything",
+ "in": "query",
+ "name": "roles",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns users Ok"
+ },
+ "204": {
+ "description": "No provisioned ASDC users of requested role"
+ },
+ "400": {
+ "description": "Missing content"
+ },
+ "403": {
+ "description": "Restricted Access"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "Retrieve the list of all active ASDC users or only group of users having specific roles.",
+ "tags": [
+ "User Administration"
+ ]
+ }
+ },
+ "/v1/user/{userId}": {
+ "delete": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Delete user",
+ "operationId": "deActivateUser",
+ "parameters": [
+ {
+ "description": "userId of user to get",
+ "in": "path",
+ "name": "userId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Update deleted OK"
+ },
+ "400": {
+ "description": "Invalid Content."
+ },
+ "403": {
+ "description": "Missing information"
+ },
+ "404": {
+ "description": "User not found"
+ },
+ "405": {
+ "description": "Method Not Allowed"
+ },
+ "409": {
+ "description": "Restricted operation"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "delete user",
+ "tags": [
+ "User Administration"
+ ]
+ },
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns user details according to userId",
+ "operationId": "get",
+ "parameters": [
+ {
+ "description": "userId of user to get",
+ "in": "path",
+ "name": "userId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns user Ok"
+ },
+ "404": {
+ "description": "User not found"
+ },
+ "405": {
+ "description": "Method Not Allowed"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "retrieve user details",
+ "tags": [
+ "User Administration"
+ ]
+ }
+ },
+ "/v1/user/{userId}/role": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Returns user role according to userId",
+ "operationId": "getRole",
+ "parameters": [
+ {
+ "description": "userId of user to get",
+ "in": "path",
+ "name": "userId",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Returns user role Ok"
+ },
+ "404": {
+ "description": "User not found"
+ },
+ "405": {
+ "description": "Method Not Allowed"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "retrieve user role",
+ "tags": [
+ "User Administration"
+ ]
+ },
+ "post": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "Update user role",
+ "operationId": "updateUserRole",
+ "parameters": [
+ {
+ "description": "userId of user to get",
+ "in": "path",
+ "name": "userId",
+ "required": true,
+ "type": "string"
+ },
+ {
+ "description": "json describe the update role",
+ "in": "body",
+ "name": "body",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "in": "header",
+ "name": "USER_ID",
+ "required": false,
+ "type": "string"
+ }
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "Update user OK"
+ },
+ "400": {
+ "description": "Invalid Content."
+ },
+ "403": {
+ "description": "Missing information/Restricted operation"
+ },
+ "404": {
+ "description": "User not found"
+ },
+ "405": {
+ "description": "Method Not Allowed"
+ },
+ "409": {
+ "description": "User already exists"
+ },
+ "500": {
+ "description": "Internal Server Error"
+ }
+ },
+ "summary": "update user role",
+ "tags": [
+ "User Administration"
+ ]
+ }
+ },
+ "/version": {
+ "get": {
+ "consumes": [
+ "application/json"
+ ],
+ "description": "return the ASDC application version",
+ "operationId": "getSdcVersion",
+ "parameters": [],
+ "produces": [
+ "application/json"
+ ],
+ "responses": {
+ "200": {
+ "description": "return ASDC version"
+ },
+ "500": {
+ "description": "Internal Error"
+ }
+ },
+ "summary": "return the ASDC application version",
+ "tags": [
+ "BE Monitoring"
+ ]
+ }
+ }
+ },
+ "swagger": "2.0",
+ "tags": [
+ {
+ "name": "Additional Information Servlet"
+ },
+ {
+ "name": "Resource Artifact Servlet"
+ },
+ {
+ "name": "Resource Attribute Servlet"
+ },
+ {
+ "name": "BE Monitoring"
+ },
+ {
+ "name": "Resource Instance Servlet"
+ },
+ {
+ "name": "Component Servlet"
+ },
+ {
+ "name": "Consumer Servlet"
+ },
+ {
+ "name": "Distribution Service Servlet"
+ },
+ {
+ "name": "Element Servlet"
+ },
+ {
+ "name": "Resource Group Servlet"
+ },
+ {
+ "name": "Input Catalog"
+ },
+ {
+ "name": "Lifecycle Actions Servlet"
+ },
+ {
+ "name": "Product Catalog"
+ },
+ {
+ "name": "Resource Property Servlet"
+ },
+ {
+ "name": "Resources Catalog Upload"
+ },
+ {
+ "name": "Resources Catalog"
+ },
+ {
+ "name": "Service Catalog"
+ },
+ {
+ "name": "Types Fetch Servlet"
+ },
+ {
+ "name": "Catalog Types Upload"
+ },
+ {
+ "name": "User Administration"
+ }
+ ]
+}
diff --git a/nokiav2/generatedapis/src/main/resources/sdc.json b/nokiav2/generatedapis/src/main/resources/sdc.json
new file mode 100644
index 00000000..cd149c8b
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/sdc.json
@@ -0,0 +1,8099 @@
+{
+ "swagger" : "2.0",
+ "info" : {
+ "description" : "Rest API Documentation",
+ "version" : "v1.0, build #${buildNumber}",
+ "title" : "Rest API",
+ "termsOfService" : "http://www.github.com/kongchen/swagger-maven-plugin"
+ },
+ "basePath" : "/onboarding-api",
+ "tags" : [ {
+ "name" : "Item Permissions"
+ }, {
+ "name" : "Validation"
+ }, {
+ "name" : "Vendor License Model - License Key Group Limits"
+ }, {
+ "name" : "Notifications"
+ }, {
+ "name" : "Vendor License Model - Entitlement Pool Limits"
+ }, {
+ "name" : "Vendor Software Product Component NICs"
+ }, {
+ "name" : "Vendor License Model - Entitlement Pools"
+ }, {
+ "name" : "Actions"
+ }, {
+ "name" : "Vendor License Model - License Agreements"
+ }, {
+ "name" : "Vendor Software Product Component Dependencies"
+ }, {
+ "name" : "Vendor Software Product Images"
+ }, {
+ "name" : "Vendor Software Product Processes"
+ }, {
+ "name" : "Vendor Software Product Networks"
+ }, {
+ "name" : "Vendor License Models"
+ }, {
+ "name" : "Vendor Software Products"
+ }, {
+ "name" : "Vendor Software Product Component Processes"
+ }, {
+ "name" : "Item Versions"
+ }, {
+ "name" : "Orchestration Template Candidate"
+ }, {
+ "name" : "Item Version Conflicts"
+ }, {
+ "name" : "Vendor Software Product deployment-flavors"
+ }, {
+ "name" : "Vendor License Model - Feature Groups"
+ }, {
+ "name" : "Vendor Software Product Component Uploads"
+ }, {
+ "name" : "Vendor Software Product Components"
+ }, {
+ "name" : "Application Configuration"
+ }, {
+ "name" : "Vendor Software Product Component Compute-flavors"
+ }, {
+ "name" : "Health Check"
+ }, {
+ "name" : "Vendor License Model - License Key Groups"
+ } ],
+ "schemes" : [ "http" ],
+ "paths" : {
+ "/v1.0/application-configuration" : {
+ "post" : {
+ "tags" : [ "Application Configuration" ],
+ "summary" : "Insert JSON schema into application config table",
+ "description" : "",
+ "operationId" : "insertToTable",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "namespace",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "key",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/InputStream"
+ }
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/application-configuration/{namespace}" : {
+ "get" : {
+ "tags" : [ "Application Configuration" ],
+ "summary" : "Get List of keys and values by namespace",
+ "description" : "",
+ "operationId" : "getListOfConfigurationByNamespaceFromTable",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "namespace",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/application-configuration/{namespace}/{key}" : {
+ "get" : {
+ "tags" : [ "Application Configuration" ],
+ "summary" : "Get JSON schema by namespace and key",
+ "description" : "",
+ "operationId" : "getFromTable",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "namespace",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "key",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ConfigurationDataDto"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/healthcheck" : {
+ "get" : {
+ "tags" : [ "Health Check" ],
+ "summary" : "Perform health check",
+ "description" : "",
+ "operationId" : "checkHealth",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/HealthInfoDtos"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/permissions" : {
+ "get" : {
+ "tags" : [ "Item Permissions" ],
+ "summary" : "List users permissions assigned on item",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "itemId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ItemPermissionsDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/permissions/{permission}" : {
+ "put" : {
+ "tags" : [ "Item Permissions" ],
+ "summary" : "Update useres permission on item",
+ "description" : "",
+ "operationId" : "updatePermissions",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ItemPermissionsRequest"
+ }
+ }, {
+ "name" : "itemId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "permission",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/versions" : {
+ "get" : {
+ "tags" : [ "Item Versions" ],
+ "summary" : "Lists item versions",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "itemId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/VersionDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/versions/{versionId}" : {
+ "get" : {
+ "tags" : [ "Item Versions" ],
+ "summary" : "Gets item version",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "itemId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/VersionDto"
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Item Versions" ],
+ "summary" : "Creates a new item version",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VersionRequestDto"
+ }
+ }, {
+ "name" : "itemId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/versions/{versionId}/actions" : {
+ "put" : {
+ "tags" : [ "Item Versions" ],
+ "summary" : "Acts on item version",
+ "description" : "",
+ "operationId" : "actOn",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VersionActionRequestDto"
+ }
+ }, {
+ "name" : "itemId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/versions/{versionId}/activity-logs" : {
+ "get" : {
+ "tags" : [ "Item Versions" ],
+ "summary" : "Gets item version activity log",
+ "description" : "",
+ "operationId" : "getActivityLog",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "itemId",
+ "in" : "path",
+ "description" : "Item Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ActivityLogDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/versions/{versionId}/conflicts" : {
+ "get" : {
+ "tags" : [ "Item Version Conflicts" ],
+ "summary" : "item version conflicts",
+ "description" : "Item version private copy conflicts against its public copy",
+ "operationId" : "getConflict",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "itemId",
+ "in" : "path",
+ "description" : "Item Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ItemVersionConflictDto"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/versions/{versionId}/conflicts/{conflictId}" : {
+ "get" : {
+ "tags" : [ "Item Version Conflicts" ],
+ "summary" : "Gets item version conflict",
+ "description" : "Gets an item version private copy conflict against its public copy",
+ "operationId" : "getConflict",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "itemId",
+ "in" : "path",
+ "description" : "Item Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "conflictId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ConflictDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Item Version Conflicts" ],
+ "summary" : "Resolves item version conflict",
+ "description" : "Resolves an item version private copy conflict against its public copy",
+ "operationId" : "resolveConflict",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ConflictResolutionDto"
+ }
+ }, {
+ "name" : "itemId",
+ "in" : "path",
+ "description" : "Item Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "conflictId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/items/{itemId}/versions/{versionId}/revisions" : {
+ "get" : {
+ "tags" : [ "Item Versions" ],
+ "summary" : "Gets item version revisions",
+ "description" : "",
+ "operationId" : "listRevisions",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "itemId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/RevisionDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/notifications" : {
+ "get" : {
+ "tags" : [ "Notifications" ],
+ "summary" : "Retrive all user notifications",
+ "description" : "",
+ "operationId" : "getNotifications",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ }, {
+ "name" : "LAST_DELIVERED_EVENT_ID",
+ "in" : "query",
+ "required" : false,
+ "type" : "string",
+ "format" : "uuid"
+ }, {
+ "name" : "END_OF_PAGE_EVENT_ID",
+ "in" : "query",
+ "required" : false,
+ "type" : "string",
+ "format" : "uuid"
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/NotificationsStatusDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/notifications/last-seen/{notificationId}" : {
+ "put" : {
+ "tags" : [ "Notifications" ],
+ "summary" : "Update Last Seen Notification",
+ "description" : "",
+ "operationId" : "updateLastSeenNotification",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "notificationId",
+ "in" : "path",
+ "description" : "Notification Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/UpdateNotificationResponseStatus"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/notifications/worker" : {
+ "get" : {
+ "tags" : [ "Notifications" ],
+ "summary" : "Retrive user not delivered notifications",
+ "description" : "",
+ "operationId" : "getNewNotificationsByOwnerId",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ }, {
+ "name" : "LAST_DELIVERED_EVENT_ID",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "NOTIFICATION_ROWS_LIMIT",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/NotificationsStatusDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/notifications/{notificationId}" : {
+ "put" : {
+ "tags" : [ "Notifications" ],
+ "summary" : "Mark notification as read",
+ "description" : "",
+ "operationId" : "markAsRead",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "notificationId",
+ "in" : "path",
+ "description" : "Notification Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/UpdateNotificationResponseStatus"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/validation/{type}/validate" : {
+ "post" : {
+ "tags" : [ "Validation" ],
+ "summary" : "Validate a package",
+ "description" : "",
+ "operationId" : "validateFile",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "type",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "validate",
+ "in" : "formData",
+ "required" : false,
+ "type" : "file"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models" : {
+ "get" : {
+ "tags" : [ "Vendor License Models" ],
+ "summary" : "List vendor license models",
+ "description" : "",
+ "operationId" : "listLicenseModels",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "versionFilter",
+ "in" : "query",
+ "description" : "Currently supported value: 'Certified' - only vendor License models with final versions will be return - with their latest final version",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ItemDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor License Models" ],
+ "summary" : "Create vendor license model",
+ "description" : "",
+ "operationId" : "createLicenseModel",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VendorLicenseModelRequest"
+ }
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}" : {
+ "delete" : {
+ "tags" : [ "Vendor License Models" ],
+ "summary" : "Delete vendor license model",
+ "description" : "",
+ "operationId" : "deleteLicenseModel",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}" : {
+ "get" : {
+ "tags" : [ "Vendor License Models" ],
+ "summary" : "Get vendor license model",
+ "description" : "",
+ "operationId" : "getLicenseModel",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/VendorLicenseModelEntity"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor License Models" ],
+ "summary" : "Update vendor license model",
+ "description" : "",
+ "operationId" : "updateLicenseModel",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VendorLicenseModelRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/actions" : {
+ "put" : {
+ "tags" : [ "Vendor License Models" ],
+ "summary" : "Update vendor license model",
+ "description" : "",
+ "operationId" : "actOnLicenseModel",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VendorLicenseModelActionRequestDto"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/entitlement-pools" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - Entitlement Pools" ],
+ "summary" : "List vendor entitlement pools",
+ "description" : "",
+ "operationId" : "listEntitlementPools",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/EntitlementPoolEntity"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor License Model - Entitlement Pools" ],
+ "summary" : "Create vendor entitlement pool",
+ "description" : "",
+ "operationId" : "createEntitlementPool",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/EntitlementPoolRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/entitlement-pools/{entitlementPoolId}" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - Entitlement Pools" ],
+ "summary" : "Get vendor entitlement pool",
+ "description" : "",
+ "operationId" : "getEntitlementPool",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/EntitlementPoolEntity"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor License Model - Entitlement Pools" ],
+ "summary" : "Update vendor entitlement pool",
+ "description" : "",
+ "operationId" : "updateEntitlementPool",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/EntitlementPoolRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor License Model - Entitlement Pools" ],
+ "summary" : "Delete vendor entitlement pool",
+ "description" : "",
+ "operationId" : "deleteEntitlementPool",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/entitlement-pools/{entitlementPoolId}/limits" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - Entitlement Pool Limits" ],
+ "summary" : "List vendor entitlement pool limits",
+ "description" : "",
+ "operationId" : "listLimits",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "description" : "Vendor license model Entitlement Pool Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/LimitRequest"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor License Model - Entitlement Pool Limits" ],
+ "summary" : "Create vendor entitlement pool limits",
+ "description" : "",
+ "operationId" : "createLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LimitRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "description" : "Vendor license model Entitlement Pool Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/entitlement-pools/{entitlementPoolId}/limits/{limitId}" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - Entitlement Pool Limits" ],
+ "summary" : "Get vendor entitlement pool limit",
+ "description" : "",
+ "operationId" : "getLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "description" : "Vendor license model Entitlement Pool Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "limitId",
+ "in" : "path",
+ "description" : "Vendor license model Entitlement Pool Limit Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/LimitEntityDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor License Model - Entitlement Pool Limits" ],
+ "summary" : "Update vendor entitlement pool limit",
+ "description" : "",
+ "operationId" : "updateLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LimitRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "description" : "Vendor license model Entitlement Pool Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "limitId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor License Model - Entitlement Pool Limits" ],
+ "summary" : "Delete vendor entitlement pool limit",
+ "description" : "",
+ "operationId" : "deleteLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "entitlementPoolId",
+ "in" : "path",
+ "description" : "Vendor license model Entitlement pool Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "limitId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/feature-groups" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - Feature Groups" ],
+ "summary" : "List vendor feature groups",
+ "description" : "",
+ "operationId" : "listFeatureGroups",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/FeatureGroupEntity"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor License Model - Feature Groups" ],
+ "summary" : "Create vendor feature group",
+ "description" : "",
+ "operationId" : "createFeatureGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/FeatureGroupRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/feature-groups/{featureGroupId}" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - Feature Groups" ],
+ "summary" : "Get vendor feature group",
+ "description" : "",
+ "operationId" : "getFeatureGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "featureGroupId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/FeatureGroupModel"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor License Model - Feature Groups" ],
+ "summary" : "Update vendor feature group",
+ "description" : "",
+ "operationId" : "updateFeatureGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/FeatureGroupUpdateRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "featureGroupId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor License Model - Feature Groups" ],
+ "summary" : "Delete vendor feature group",
+ "description" : "",
+ "operationId" : "deleteFeatureGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "featureGroupId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/license-agreements" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - License Agreements" ],
+ "summary" : "List vendor license agreements",
+ "description" : "",
+ "operationId" : "listLicenseAgreements",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/LicenseAgreementEntity"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor License Model - License Agreements" ],
+ "summary" : "Create vendor license agreement",
+ "description" : "",
+ "operationId" : "createLicenseAgreement",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LicenseAgreementRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/license-agreements/{licenseAgreementId}" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - License Agreements" ],
+ "summary" : "Get vendor license agreement",
+ "description" : "",
+ "operationId" : "getLicenseAgreement",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseAgreementId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/LicenseAgreementModel"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor License Model - License Agreements" ],
+ "summary" : "Update vendor license agreement",
+ "description" : "",
+ "operationId" : "updateLicenseAgreement",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LicenseAgreementUpdateRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseAgreementId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor License Model - License Agreements" ],
+ "summary" : "Delete vendor license agreement",
+ "description" : "",
+ "operationId" : "deleteLicenseAgreement",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseAgreementId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/license-key-groups" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - License Key Groups" ],
+ "summary" : "List vendor license key groups",
+ "description" : "",
+ "operationId" : "listLicenseKeyGroups",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/LicenseKeyGroupEntityDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor License Model - License Key Groups" ],
+ "summary" : "Create vendor license key group",
+ "description" : "",
+ "operationId" : "createLicenseKeyGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LicenseKeyGroupRequestDto"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/license-key-groups/{licenseKeyGroupId}" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - License Key Groups" ],
+ "summary" : "Get vendor license key group",
+ "description" : "",
+ "operationId" : "getLicenseKeyGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/LicenseKeyGroupEntityDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor License Model - License Key Groups" ],
+ "summary" : "Update vendor license key group",
+ "description" : "",
+ "operationId" : "updateLicenseKeyGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LicenseKeyGroupRequestDto"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor License Model - License Key Groups" ],
+ "summary" : "Delete vendor license key group",
+ "description" : "",
+ "operationId" : "deleteLicenseKeyGroup",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/license-key-groups/{licenseKeyGroupId}/limits" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - License Key Group Limits" ],
+ "summary" : "List vendor license key group limits",
+ "description" : "",
+ "operationId" : "listLimits",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "description" : "Vendor license model License Key Group Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/LimitEntityDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor License Model - License Key Group Limits" ],
+ "summary" : "Create vendor license key group limit",
+ "description" : "",
+ "operationId" : "createLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LimitRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "description" : "Vendor license model License Key Group Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-license-models/{vlmId}/versions/{versionId}/license-key-groups/{licenseKeyGroupId}/limits/{limitId}" : {
+ "get" : {
+ "tags" : [ "Vendor License Model - License Key Group Limits" ],
+ "summary" : "Get vendor entitlement pool limit",
+ "description" : "",
+ "operationId" : "getLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "description" : "Vendor license model License Key Group",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "limitId",
+ "in" : "path",
+ "description" : "Vendor license model License Key Group Limit Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/LimitEntityDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor License Model - License Key Group Limits" ],
+ "summary" : "Update vendor license key group limit",
+ "description" : "",
+ "operationId" : "updateLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/LimitRequest"
+ }
+ }, {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "description" : "Vendor license model License Key Group Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "limitId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor License Model - License Key Group Limits" ],
+ "summary" : "Delete vendor license key group limit",
+ "description" : "",
+ "operationId" : "deleteLimit",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vlmId",
+ "in" : "path",
+ "description" : "Vendor license model Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor license model version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "licenseKeyGroupId",
+ "in" : "path",
+ "description" : "Vendor license model license key group Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "limitId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get list of vendor software products and their description",
+ "description" : "",
+ "operationId" : "listVsps",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "versionFilter",
+ "in" : "query",
+ "description" : "Currently supported values: 'Certified' - only vendor software products with final version will be return - with their latest final version",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Create a new vendor software product",
+ "description" : "",
+ "operationId" : "createVsp",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VspRequestDto"
+ }
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ItemCreationDto"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/packages" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get list of translated CSAR files details",
+ "description" : "",
+ "operationId" : "listPackages",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "category",
+ "in" : "query",
+ "description" : "Category",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "subCategory",
+ "in" : "query",
+ "description" : "Sub-category",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/PackageInfoDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/packages/{vspId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get translated CSAR file",
+ "description" : "Exports translated file to a zip file",
+ "operationId" : "getTranslatedFile",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/octet-stream" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/File"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}" : {
+ "delete" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Deletes vendor software product by given id",
+ "description" : "",
+ "operationId" : "deleteVsp",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get details of a vendor software product",
+ "description" : "",
+ "operationId" : "getVsp",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Update an existing vendor software product",
+ "description" : "",
+ "operationId" : "updateVsp",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VspDescriptionDto"
+ }
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/actions" : {
+ "put" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Actions on a vendor software product",
+ "description" : "Performs one of the following actions on a vendor software product: |Checkout: Locks it for edits by other users. Only the locking user sees the edited version.|Undo_Checkout: Unlocks it and deletes the edits that were done.|Checkin: Unlocks it and activates the edited version to all users.| Submit: Finalize its active version.|Create_Package: Creates a CSAR zip file.|",
+ "operationId" : "actOnVendorSoftwareProduct",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/VersionSoftwareProductActionRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/component-dependencies" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Dependencies" ],
+ "summary" : "Get component dependencies for vendor software product",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ComponentDependencyResponseDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Component Dependencies" ],
+ "summary" : "Create a vendor software product component dependency",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ComponentDependencyModel"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/component-dependencies/{dependencyId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Dependencies" ],
+ "summary" : "Get component dependency for vendor software product",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "dependencyId",
+ "in" : "path",
+ "description" : "Vendor software product Component Dependency Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ComponentDependencyResponseDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Component Dependencies" ],
+ "summary" : "Update component dependency for vendor software product",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ComponentDependencyModel"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "dependencyId",
+ "in" : "path",
+ "description" : "Vendor software product Component Dependency Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Component Dependencies" ],
+ "summary" : "Delete component dependency for vendor software product",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "dependencyId",
+ "in" : "path",
+ "description" : "Vendor software product Component Dependency Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "List vendor software product components",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ComponentDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "Create a vendor software product component",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ComponentRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "Delete vendor software product components",
+ "description" : "",
+ "operationId" : "deleteList",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "Get vendor software product component",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ComponentData"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "Update vendor software product component",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ComponentRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "Delete vendor software product component",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/compute-flavors" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Compute-flavors" ],
+ "summary" : "Get list of vendor software product component compute-flavors",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ComputeDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Component Compute-flavors" ],
+ "summary" : "Create a vendor software product component compute-flavor",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ComputeDetailsDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/compute-flavors/{computeFlavorId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Compute-flavors" ],
+ "summary" : "Get vendor software product component compute-flavor",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "computeFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product compute-flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ComputeDetailsDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Component Compute-flavors" ],
+ "summary" : "Update vendor software product component compute-flavor",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ComputeDetailsDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "computeFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product compute-flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Component Compute-flavors" ],
+ "summary" : "Delete vendor software product component compute-flavor",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "computeFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product compute-flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/compute-flavors/{computeFlavorId}/questionnaire" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Compute-flavors" ],
+ "summary" : "Get vendor software product component compute-flavor questionnaire",
+ "description" : "",
+ "operationId" : "getQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "computeFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product compute-flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/QuestionnaireResponseDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Component Compute-flavors" ],
+ "summary" : "Update vendor software product component compute-flavor questionnaire",
+ "description" : "",
+ "operationId" : "updateQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "computeFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product compute-flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/images" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Images" ],
+ "summary" : "List vendor software product component images",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ImageDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Images" ],
+ "summary" : "Create a vendor software product component image",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ImageRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/images/{imageId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Images" ],
+ "summary" : "Get vendor software product component Image",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "imageId",
+ "in" : "path",
+ "description" : "Vendor software product Image Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ImageDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Images" ],
+ "summary" : "Update vendor software product Image",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ImageRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "imageId",
+ "in" : "path",
+ "description" : "Vendor software product Image Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Images" ],
+ "summary" : "Delete vendor software product Image",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "imageId",
+ "in" : "path",
+ "description" : "Vendor software product Image Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/images/{imageId}/questionnaire" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Images" ],
+ "summary" : "Get vendor software product component image questionnaire",
+ "description" : "",
+ "operationId" : "getQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "imageId",
+ "in" : "path",
+ "description" : "Vendor software product image Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/QuestionnaireResponseDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Images" ],
+ "summary" : "Update vendor software product component image questionnaire",
+ "description" : "",
+ "operationId" : "updateQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "imageId",
+ "in" : "path",
+ "description" : "Vendor software product image Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/nics" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component NICs" ],
+ "summary" : "List vendor software product component NICs",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/NicDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Component NICs" ],
+ "summary" : "Create a vendor software product NIC",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/NicRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/nics/{nicId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component NICs" ],
+ "summary" : "Get vendor software product NIC",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "nicId",
+ "in" : "path",
+ "description" : "Vendor software product NIC Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/NicDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Component NICs" ],
+ "summary" : "Update vendor software product NIC",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/NicRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "nicId",
+ "in" : "path",
+ "description" : "Vendor software product NIC Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Component NICs" ],
+ "summary" : "Delete vendor software product NIC",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "nicId",
+ "in" : "path",
+ "description" : "Vendor software product NIC Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/nics/{nicId}/questionnaire" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component NICs" ],
+ "summary" : "Get vendor software product component NIC questionnaire",
+ "description" : "",
+ "operationId" : "getQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "nicId",
+ "in" : "path",
+ "description" : "Vendor software product NIC Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/QuestionnaireResponseDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Component NICs" ],
+ "summary" : "Update vendor software product component NIC questionnaire",
+ "description" : "",
+ "operationId" : "updateQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "nicId",
+ "in" : "path",
+ "description" : "Vendor software product NIC Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/processes" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "List vendor software product component processes",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ProcessEntityDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Create a vendor software product process",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ProcessRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Delete vendor software product processes",
+ "description" : "",
+ "operationId" : "deleteList",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/processes/{processId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Get vendor software product process",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ProcessEntityDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Update vendor software product process",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ProcessRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Delete vendor software product process",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/processes/{processId}/upload" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Get vendor software product process uploaded file",
+ "description" : "",
+ "operationId" : "getUploadedFile",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/octet-stream" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Update vendor software product process upload",
+ "description" : "",
+ "operationId" : "uploadFile",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/Attachment"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Component Processes" ],
+ "summary" : "Delete vendor software product process uploaded file",
+ "description" : "",
+ "operationId" : "deleteUploadedFile",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/questionnaire" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "Get vendor software product component questionnaire",
+ "description" : "",
+ "operationId" : "getQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/QuestionnaireResponseDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Components" ],
+ "summary" : "Update vendor software product component questionnaire",
+ "description" : "",
+ "operationId" : "updateQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/uploads" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Component Uploads" ],
+ "summary" : "Get the filenames of uploaded files by type",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Vendor software product component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/MonitoringUploadStatusDto"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/components/{componentId}/uploads/types/{type}" : {
+ "post" : {
+ "tags" : [ "Vendor Software Product Component Uploads" ],
+ "summary" : "Upload file for component by type",
+ "description" : "",
+ "operationId" : "upload",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/Attachment"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "type",
+ "in" : "path",
+ "description" : "Upload Type",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Component Uploads" ],
+ "summary" : "Delete file uploaded for component",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "path",
+ "description" : "Component Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "type",
+ "in" : "path",
+ "description" : "Upload Type",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/compute-flavors" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get list of vendor software product compute-flavors",
+ "description" : "",
+ "operationId" : "listComputes",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/VspComputeDto"
+ }
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/deployment-flavors" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product deployment-flavors" ],
+ "summary" : "List vendor software product Deployment Flavor",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/DeploymentFlavorListResponseDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product deployment-flavors" ],
+ "summary" : "Create a vendor software product Deployment Flavor",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/DeploymentFlavorRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/deployment-flavors/{deploymentFlavorId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product deployment-flavors" ],
+ "summary" : "Get vendor software product Deployment Flavor",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "deploymentFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product Deployment Flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/DeploymentFlavorDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product deployment-flavors" ],
+ "summary" : "Update vendor software product Deployment Flavor",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/DeploymentFlavorRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "deploymentFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product Deployment Flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product deployment-flavors" ],
+ "summary" : "Delete vendor software product Deployment Flavor",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "deploymentFlavorId",
+ "in" : "path",
+ "description" : "Vendor software product Deployment Flavor Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/heal" : {
+ "put" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Checkout and heal vendor software product questionnaire",
+ "description" : "",
+ "operationId" : "heal",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/QuestionnaireResponseDto"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/networks" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Networks" ],
+ "summary" : "List vendor software product networks",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/NetworkDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Networks" ],
+ "summary" : "Create a vendor software product network",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/NetworkRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/networks/{networkId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Networks" ],
+ "summary" : "Get vendor software product network",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "networkId",
+ "in" : "path",
+ "description" : "Vendor software product network Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/NetworkDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Networks" ],
+ "summary" : "Update vendor software product network",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/NetworkRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "networkId",
+ "in" : "path",
+ "description" : "Vendor software product network Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Networks" ],
+ "summary" : "Delete vendor software product network",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "networkId",
+ "in" : "path",
+ "description" : "Vendor software product network Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/orchestration-template" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get Orchestration Template (HEAT) file",
+ "description" : "Downloads the latest HEAT package",
+ "operationId" : "getOrchestrationTemplate",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/octet-stream" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/File"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/orchestration-template-candidate" : {
+ "get" : {
+ "tags" : [ "Orchestration Template Candidate" ],
+ "summary" : "Get uploaded candidate HEAT file",
+ "description" : "Downloads in process candidate HEAT file",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/octet-stream" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/File"
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Uploads a HEAT package to translate",
+ "description" : "",
+ "operationId" : "uploadOrchestrationTemplateCandidate",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "upload",
+ "in" : "formData",
+ "required" : false,
+ "type" : "file"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/UploadFileResponseDto"
+ }
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Orchestration Template Candidate" ],
+ "summary" : "Delete orchestration template candidate file and its files data structure",
+ "description" : "",
+ "operationId" : "abort",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/orchestration-template-candidate/manifest" : {
+ "get" : {
+ "tags" : [ "Orchestration Template Candidate" ],
+ "summary" : "Get uploaded HEAT file files data structure",
+ "description" : "Downloads the latest HEAT package",
+ "operationId" : "getFilesDataStructure",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/FileDataStructureDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Orchestration Template Candidate" ],
+ "summary" : "Update an existing vendor software product",
+ "description" : "",
+ "operationId" : "updateFilesDataStructure",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/FileDataStructureDto"
+ }
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/orchestration-template-candidate/process" : {
+ "put" : {
+ "tags" : [ "Orchestration Template Candidate" ],
+ "summary" : "process Orchestration Template Candidate",
+ "description" : "",
+ "operationId" : "process",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/UploadFileResponseDto"
+ }
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/processes" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "List vendor software product processes",
+ "description" : "",
+ "operationId" : "list",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ProcessEntityDto"
+ }
+ }
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Create a vendor software product process",
+ "description" : "",
+ "operationId" : "create",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ProcessRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Delete vendor software product processes",
+ "description" : "",
+ "operationId" : "deleteList",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/processes/{processId}" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Get vendor software product process",
+ "description" : "",
+ "operationId" : "get",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/ProcessEntityDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Update vendor software product process",
+ "description" : "",
+ "operationId" : "update",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/ProcessRequestDto"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Delete vendor software product process",
+ "description" : "",
+ "operationId" : "delete",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/processes/{processId}/upload" : {
+ "get" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Get vendor software product process uploaded file",
+ "description" : "",
+ "operationId" : "getUploadedFile",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/octet-stream" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Update vendor software product process upload",
+ "description" : "",
+ "operationId" : "uploadFile",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "$ref" : "#/definitions/Attachment"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Vendor Software Product Processes" ],
+ "summary" : "Delete vendor software product process uploaded file",
+ "description" : "",
+ "operationId" : "deleteUploadedFile",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "description" : "Vendor software product Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "description" : "Vendor software product version Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "processId",
+ "in" : "path",
+ "description" : "Vendor software product process Id",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/questionnaire" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get vendor software product questionnaire",
+ "description" : "",
+ "operationId" : "getQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/QuestionnaireResponseDto"
+ }
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Update vendor software product questionnaire",
+ "description" : "",
+ "operationId" : "updateQuestionnaire",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/v1.0/vendor-software-products/{vspId}/versions/{versionId}/vspInformationArtifact" : {
+ "get" : {
+ "tags" : [ "Vendor Software Products" ],
+ "summary" : "Get vendor software product information artifact for specified version",
+ "description" : "",
+ "operationId" : "getVspInformationArtifact",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "text/plain" ],
+ "parameters" : [ {
+ "name" : "vspId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "versionId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "USER_ID",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ } ],
+ "responses" : {
+ "200" : {
+ "description" : "successful operation",
+ "schema" : {
+ "$ref" : "#/definitions/File"
+ }
+ }
+ }
+ }
+ },
+ "/workflow/v1.0/actions" : {
+ "get" : {
+ "tags" : [ "Actions" ],
+ "summary" : "List Filtered Actions ",
+ "description" : "Get list of actions based on a filter criteria | If no filter is sent all actions will be returned",
+ "operationId" : "getFilteredActions",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "vendor",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "category",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "name",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "modelId",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ }, {
+ "name" : "componentId",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Create a new Action",
+ "description" : "",
+ "operationId" : "createAction",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/workflow/v1.0/actions/components" : {
+ "get" : {
+ "tags" : [ "Actions" ],
+ "summary" : "List OPENECOMP Components supported by Action Library",
+ "description" : "",
+ "operationId" : "getOpenEcompComponents",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/workflow/v1.0/actions/{actionInvariantUuId}" : {
+ "get" : {
+ "tags" : [ "Actions" ],
+ "summary" : "List Actions For Given Action Invariant UuId",
+ "description" : "",
+ "operationId" : "getActionsByActionInvariantUuId",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "actionInvariantUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "version",
+ "in" : "query",
+ "required" : false,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "post" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Actions on a action",
+ "description" : "Performs one of the following actions on a action: |Checkout: Locks it for edits by other users. Only the locking user sees the edited version.|Undo_Checkout: Unlocks it and deletes the edits that were done.|Checkin: Unlocks it and activates the edited version to all users.| Submit: Finalize its active version.|",
+ "operationId" : "actOnAction",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "actionInvariantUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "put" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Update an existing action",
+ "description" : "",
+ "operationId" : "updateAction",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "actionInvariantUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Delete Action",
+ "description" : "",
+ "operationId" : "deleteAction",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "actionInvariantUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/workflow/v1.0/actions/{actionInvariantUuId}/artifacts" : {
+ "post" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Upload new Artifact",
+ "description" : "",
+ "operationId" : "uploadArtifact",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "actionInvariantUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "name" : "Content-MD5",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ }, {
+ "name" : "uploadArtifact",
+ "in" : "formData",
+ "required" : false,
+ "type" : "file"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/workflow/v1.0/actions/{actionInvariantUuId}/artifacts/{artifactUuId}" : {
+ "put" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Update an existing artifact",
+ "description" : "",
+ "operationId" : "updateArtifact",
+ "consumes" : [ "multipart/form-data" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "actionInvariantUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "artifactUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "in" : "body",
+ "name" : "body",
+ "required" : false,
+ "schema" : {
+ "type" : "string"
+ }
+ }, {
+ "name" : "Content-MD5",
+ "in" : "header",
+ "required" : false,
+ "type" : "string",
+ "default" : ""
+ }, {
+ "name" : "updateArtifact",
+ "in" : "formData",
+ "required" : false,
+ "type" : "file"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ },
+ "delete" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Delete Artifact",
+ "description" : "",
+ "operationId" : "deleteArtifact",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/json" ],
+ "parameters" : [ {
+ "name" : "actionInvariantUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "artifactUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ },
+ "/workflow/v1.0/actions/{actionUuId}/artifacts/{artifactUuId}" : {
+ "get" : {
+ "tags" : [ "Actions" ],
+ "summary" : "Downloads artifact for action",
+ "description" : "",
+ "operationId" : "downloadArtifact",
+ "consumes" : [ "application/json" ],
+ "produces" : [ "application/octet-stream" ],
+ "parameters" : [ {
+ "name" : "actionUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ }, {
+ "name" : "artifactUuId",
+ "in" : "path",
+ "required" : true,
+ "type" : "string"
+ } ],
+ "responses" : {
+ "default" : {
+ "description" : "successful operation"
+ }
+ }
+ }
+ }
+ },
+ "definitions" : {
+ "ActivityLogDto" : {
+ "type" : "object",
+ "properties" : {
+ "id" : {
+ "type" : "string"
+ },
+ "timestamp" : {
+ "type" : "string",
+ "format" : "date-time"
+ },
+ "type" : {
+ "type" : "string"
+ },
+ "comment" : {
+ "type" : "string"
+ },
+ "user" : {
+ "type" : "string"
+ },
+ "status" : {
+ "$ref" : "#/definitions/ActivityStatus"
+ }
+ }
+ },
+ "ActivityStatus" : {
+ "type" : "object",
+ "properties" : {
+ "success" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "message" : {
+ "type" : "string"
+ }
+ }
+ },
+ "Attachment" : {
+ "type" : "object",
+ "properties" : {
+ "headers" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "array",
+ "items" : {
+ "type" : "string"
+ }
+ }
+ },
+ "object" : {
+ "type" : "object"
+ },
+ "contentType" : {
+ "$ref" : "#/definitions/MediaType"
+ },
+ "contentDisposition" : {
+ "$ref" : "#/definitions/ContentDisposition"
+ },
+ "dataHandler" : {
+ "$ref" : "#/definitions/DataHandler"
+ },
+ "contentId" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ChoiceOrOtherDtoLicenseTerm" : {
+ "type" : "object",
+ "required" : [ "choice", "other" ],
+ "properties" : {
+ "choice" : {
+ "type" : "string",
+ "enum" : [ "Fixed_Term", "Perpetual", "Unlimited", "Other" ]
+ },
+ "other" : {
+ "type" : "string"
+ }
+ }
+ },
+ "CommandInfo" : {
+ "type" : "object",
+ "properties" : {
+ "commandName" : {
+ "type" : "string"
+ },
+ "commandClass" : {
+ "type" : "string"
+ }
+ }
+ },
+ "CommitRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "message" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ComponentComputeAssociation" : {
+ "type" : "object",
+ "properties" : {
+ "componentId" : {
+ "type" : "string"
+ },
+ "computeFlavorId" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ComponentData" : {
+ "type" : "object",
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "displayName" : {
+ "type" : "string"
+ },
+ "vfcCode" : {
+ "type" : "string"
+ },
+ "nfcCode" : {
+ "type" : "string"
+ },
+ "nfcFunction" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ComponentDependencyModel" : {
+ "type" : "object",
+ "properties" : {
+ "sourceId" : {
+ "type" : "string"
+ },
+ "targetId" : {
+ "type" : "string"
+ },
+ "relationType" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ComponentDependencyResponseDto" : {
+ "type" : "object",
+ "properties" : {
+ "sourceId" : {
+ "type" : "string"
+ },
+ "targetId" : {
+ "type" : "string"
+ },
+ "relationType" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ComponentDto" : {
+ "type" : "object",
+ "required" : [ "displayName" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "displayName" : {
+ "type" : "string",
+ "minLength" : 1,
+ "maxLength" : 30
+ },
+ "vfcCode" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "nfcCode" : {
+ "type" : "string"
+ },
+ "nfcFunction" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ComponentRequestDto" : {
+ "type" : "object",
+ "required" : [ "displayName" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "displayName" : {
+ "type" : "string",
+ "minLength" : 1,
+ "maxLength" : 30
+ },
+ "vfcCode" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "nfcCode" : {
+ "type" : "string"
+ },
+ "nfcFunction" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ComputeDetailsDto" : {
+ "type" : "object",
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 30
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 300
+ }
+ }
+ },
+ "ComputeDto" : {
+ "type" : "object",
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "associatedToDeploymentFlavor" : {
+ "type" : "boolean",
+ "default" : false
+ }
+ }
+ },
+ "ConfigurationDataDto" : {
+ "type" : "object",
+ "properties" : {
+ "value" : {
+ "type" : "string"
+ },
+ "timeStamp" : {
+ "type" : "integer",
+ "format" : "int64"
+ }
+ }
+ },
+ "ConflictDto" : {
+ "type" : "object",
+ "properties" : {
+ "id" : {
+ "type" : "string"
+ },
+ "type" : {
+ "type" : "string",
+ "enum" : [ "itemVersion", "VendorLicenseModel", "LicenseAgreements", "LicenseAgreement", "FeatureGroups", "FeatureGroup", "LicenseKeyGroups", "LicenseKeyGroup", "EntitlementPools", "EntitlementPool", "Limits", "Limit", "VendorSoftwareProduct", "VSPQuestionnaire", "VspModel", "NetworkPackage", "OrchestrationTemplateCandidate", "OrchestrationTemplateCandidateContent", "OrchestrationTemplateCandidateValidationData", "OrchestrationTemplateStructure", "OrchestrationTemplate", "OrchestrationTemplateValidationData", "OrchestrationTemplateContent", "Networks", "Network", "Components", "Component", "ComponentQuestionnaire", "ComponentDependencies", "ComponentDependency", "Nics", "Nic", "NicQuestionnaire", "Mibs", "SNMP_POLL", "SNMP_TRAP", "VES_EVENTS", "Processes", "Process", "DeploymentFlavors", "DeploymentFlavor", "Computes", "Compute", "ComputeQuestionnaire", "Images", "Image", "ImageQuestionnaire", "ServiceModel", "EnrichedServiceModel", "ServiceTemplate", "Templates", "Artifact", "Artifacts", "test" ]
+ },
+ "name" : {
+ "type" : "string"
+ },
+ "yours" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "object"
+ }
+ },
+ "theirs" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "object"
+ }
+ }
+ }
+ },
+ "ConflictInfoDto" : {
+ "type" : "object",
+ "properties" : {
+ "id" : {
+ "type" : "string"
+ },
+ "type" : {
+ "type" : "string",
+ "enum" : [ "itemVersion", "VendorLicenseModel", "LicenseAgreements", "LicenseAgreement", "FeatureGroups", "FeatureGroup", "LicenseKeyGroups", "LicenseKeyGroup", "EntitlementPools", "EntitlementPool", "Limits", "Limit", "VendorSoftwareProduct", "VSPQuestionnaire", "VspModel", "NetworkPackage", "OrchestrationTemplateCandidate", "OrchestrationTemplateCandidateContent", "OrchestrationTemplateCandidateValidationData", "OrchestrationTemplateStructure", "OrchestrationTemplate", "OrchestrationTemplateValidationData", "OrchestrationTemplateContent", "Networks", "Network", "Components", "Component", "ComponentQuestionnaire", "ComponentDependencies", "ComponentDependency", "Nics", "Nic", "NicQuestionnaire", "Mibs", "SNMP_POLL", "SNMP_TRAP", "VES_EVENTS", "Processes", "Process", "DeploymentFlavors", "DeploymentFlavor", "Computes", "Compute", "ComputeQuestionnaire", "Images", "Image", "ImageQuestionnaire", "ServiceModel", "EnrichedServiceModel", "ServiceTemplate", "Templates", "Artifact", "Artifacts", "test" ]
+ },
+ "name" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ConflictResolutionDto" : {
+ "type" : "object",
+ "properties" : {
+ "resolution" : {
+ "type" : "string",
+ "enum" : [ "THEIRS", "YOURS", "OTHER" ]
+ },
+ "otherResolution" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "object"
+ }
+ }
+ }
+ },
+ "ContentDisposition" : {
+ "type" : "object",
+ "properties" : {
+ "type" : {
+ "type" : "string"
+ },
+ "parameters" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "string"
+ }
+ },
+ "filename" : {
+ "type" : "string"
+ }
+ }
+ },
+ "DataFlavor" : {
+ "type" : "object",
+ "properties" : {
+ "mimeType" : {
+ "type" : "string"
+ },
+ "humanPresentableName" : {
+ "type" : "string"
+ },
+ "subType" : {
+ "type" : "string"
+ },
+ "primaryType" : {
+ "type" : "string"
+ },
+ "mimeTypeSerializedObject" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "defaultRepresentationClassAsString" : {
+ "type" : "string"
+ },
+ "representationClassInputStream" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "representationClassReader" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "representationClassCharBuffer" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "representationClassByteBuffer" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "representationClassSerializable" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "representationClassRemote" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "flavorSerializedObjectType" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "flavorRemoteObjectType" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "flavorJavaFileListType" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "flavorTextType" : {
+ "type" : "boolean",
+ "default" : false
+ }
+ }
+ },
+ "DataHandler" : {
+ "type" : "object",
+ "properties" : {
+ "dataSource" : {
+ "$ref" : "#/definitions/DataSource"
+ },
+ "name" : {
+ "type" : "string"
+ },
+ "inputStream" : {
+ "$ref" : "#/definitions/InputStream"
+ },
+ "content" : {
+ "type" : "object"
+ },
+ "contentType" : {
+ "type" : "string"
+ },
+ "outputStream" : {
+ "$ref" : "#/definitions/OutputStream"
+ },
+ "transferDataFlavors" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/DataFlavor"
+ }
+ },
+ "preferredCommands" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/CommandInfo"
+ }
+ },
+ "allCommands" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/CommandInfo"
+ }
+ }
+ }
+ },
+ "DataSource" : {
+ "type" : "object",
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "inputStream" : {
+ "$ref" : "#/definitions/InputStream"
+ },
+ "contentType" : {
+ "type" : "string"
+ },
+ "outputStream" : {
+ "$ref" : "#/definitions/OutputStream"
+ }
+ }
+ },
+ "DeploymentFlavorDto" : {
+ "type" : "object",
+ "properties" : {
+ "model" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 30
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 300
+ },
+ "featureGroupId" : {
+ "type" : "string"
+ },
+ "componentComputeAssociations" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ComponentComputeAssociation"
+ }
+ },
+ "id" : {
+ "type" : "string"
+ }
+ }
+ },
+ "DeploymentFlavorListResponseDto" : {
+ "type" : "object",
+ "properties" : {
+ "model" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ }
+ }
+ },
+ "DeploymentFlavorRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "model" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 30
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 300
+ },
+ "featureGroupId" : {
+ "type" : "string"
+ },
+ "componentComputeAssociations" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ComponentComputeAssociation"
+ }
+ }
+ }
+ },
+ "EntitlementPoolEntity" : {
+ "type" : "object",
+ "required" : [ "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "thresholdValue" : {
+ "type" : "integer",
+ "format" : "int32"
+ },
+ "thresholdUnits" : {
+ "type" : "string",
+ "enum" : [ "Absolute", "Percentage" ]
+ },
+ "increments" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "operationalScope" : {
+ "$ref" : "#/definitions/MultiChoiceOrOtherDtoOperationalScope"
+ },
+ "startDate" : {
+ "type" : "string"
+ },
+ "expiryDate" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "referencingFeatureGroups" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "EntitlementPoolRequest" : {
+ "type" : "object",
+ "required" : [ "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "thresholdValue" : {
+ "type" : "integer",
+ "format" : "int32"
+ },
+ "thresholdUnits" : {
+ "type" : "string",
+ "enum" : [ "Absolute", "Percentage" ]
+ },
+ "increments" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "operationalScope" : {
+ "$ref" : "#/definitions/MultiChoiceOrOtherDtoOperationalScope"
+ },
+ "startDate" : {
+ "type" : "string"
+ },
+ "expiryDate" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ErrorMessage" : {
+ "type" : "object",
+ "properties" : {
+ "level" : {
+ "type" : "string",
+ "enum" : [ "ERROR", "WARNING", "INFO" ]
+ },
+ "message" : {
+ "type" : "string"
+ }
+ }
+ },
+ "FeatureGroupEntity" : {
+ "type" : "object",
+ "required" : [ "name", "partNumber" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "partNumber" : {
+ "type" : "string"
+ },
+ "manufacturerReferenceNumber" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 100
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "licenseKeyGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "entitlementPoolsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "referencingLicenseAgreements" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "FeatureGroupModel" : {
+ "type" : "object",
+ "required" : [ "name", "partNumber" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "partNumber" : {
+ "type" : "string"
+ },
+ "manufacturerReferenceNumber" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 100
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "referencingLicenseAgreements" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "licenseKeyGroups" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/LicenseKeyGroupEntityDto"
+ }
+ },
+ "entitlementPools" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/EntitlementPoolEntity"
+ }
+ }
+ }
+ },
+ "FeatureGroupRequest" : {
+ "type" : "object",
+ "required" : [ "name", "partNumber" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "partNumber" : {
+ "type" : "string"
+ },
+ "manufacturerReferenceNumber" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 100
+ },
+ "addedLicenseKeyGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "addedEntitlementPoolsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "FeatureGroupUpdateRequest" : {
+ "type" : "object",
+ "required" : [ "name", "partNumber" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "partNumber" : {
+ "type" : "string"
+ },
+ "manufacturerReferenceNumber" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 100
+ },
+ "addedLicenseKeyGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "addedEntitlementPoolsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "removedLicenseKeyGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "removedEntitlementPoolsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "File" : {
+ "type" : "object",
+ "properties" : {
+ "path" : {
+ "type" : "string"
+ },
+ "name" : {
+ "type" : "string"
+ },
+ "parent" : {
+ "type" : "string"
+ },
+ "absolute" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "canonicalPath" : {
+ "type" : "string"
+ },
+ "parentFile" : {
+ "$ref" : "#/definitions/File"
+ },
+ "absolutePath" : {
+ "type" : "string"
+ },
+ "absoluteFile" : {
+ "$ref" : "#/definitions/File"
+ },
+ "canonicalFile" : {
+ "$ref" : "#/definitions/File"
+ },
+ "directory" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "file" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "hidden" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "totalSpace" : {
+ "type" : "integer",
+ "format" : "int64"
+ },
+ "freeSpace" : {
+ "type" : "integer",
+ "format" : "int64"
+ },
+ "usableSpace" : {
+ "type" : "integer",
+ "format" : "int64"
+ }
+ }
+ },
+ "FileDataStructureDto" : {
+ "type" : "object",
+ "properties" : {
+ "modules" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/Module"
+ }
+ },
+ "unassigned" : {
+ "type" : "array",
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "artifacts" : {
+ "type" : "array",
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "nested" : {
+ "type" : "array",
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "HealthInfoDto" : {
+ "type" : "object",
+ "properties" : {
+ "healthCheckComponent" : {
+ "type" : "string",
+ "enum" : [ "BE", "CAS", "ZU" ]
+ },
+ "healthStatus" : {
+ "type" : "string",
+ "enum" : [ "UP", "DOWN" ]
+ },
+ "version" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ }
+ }
+ },
+ "HealthInfoDtos" : {
+ "type" : "object",
+ "properties" : {
+ "healthInfos" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/HealthInfoDto"
+ }
+ }
+ }
+ },
+ "ImageDto" : {
+ "type" : "object",
+ "properties" : {
+ "fileName" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ImageRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "fileName" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ }
+ }
+ },
+ "InputStream" : {
+ "type" : "object"
+ },
+ "ItemCreationDto" : {
+ "type" : "object",
+ "properties" : {
+ "itemId" : {
+ "type" : "string"
+ },
+ "version" : {
+ "$ref" : "#/definitions/VersionDto"
+ }
+ }
+ },
+ "ItemDto" : {
+ "type" : "object",
+ "properties" : {
+ "id" : {
+ "type" : "string"
+ },
+ "type" : {
+ "type" : "string"
+ },
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "owner" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ItemPermissionsDto" : {
+ "type" : "object",
+ "properties" : {
+ "userId" : {
+ "type" : "string"
+ },
+ "permission" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ItemPermissionsRequest" : {
+ "type" : "object",
+ "properties" : {
+ "addedUsersIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "removedUsersIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "ItemVersionConflictDto" : {
+ "type" : "object",
+ "properties" : {
+ "conflict" : {
+ "$ref" : "#/definitions/ConflictDto"
+ },
+ "conflictInfoList" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ConflictInfoDto"
+ }
+ }
+ }
+ },
+ "LicenseAgreementEntity" : {
+ "type" : "object",
+ "required" : [ "licenseTerm", "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "licenseTerm" : {
+ "$ref" : "#/definitions/ChoiceOrOtherDtoLicenseTerm"
+ },
+ "requirementsAndConstrains" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "featureGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "LicenseAgreementModel" : {
+ "type" : "object",
+ "required" : [ "licenseTerm", "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "licenseTerm" : {
+ "$ref" : "#/definitions/ChoiceOrOtherDtoLicenseTerm"
+ },
+ "requirementsAndConstrains" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "featureGroups" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "$ref" : "#/definitions/FeatureGroupEntity"
+ }
+ }
+ }
+ },
+ "LicenseAgreementRequest" : {
+ "type" : "object",
+ "required" : [ "licenseTerm", "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "licenseTerm" : {
+ "$ref" : "#/definitions/ChoiceOrOtherDtoLicenseTerm"
+ },
+ "requirementsAndConstrains" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "addedFeatureGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "LicenseAgreementUpdateRequest" : {
+ "type" : "object",
+ "required" : [ "licenseTerm", "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "licenseTerm" : {
+ "$ref" : "#/definitions/ChoiceOrOtherDtoLicenseTerm"
+ },
+ "requirementsAndConstrains" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "addedFeatureGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ },
+ "removedFeatureGroupsIds" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "LicenseKeyGroupEntityDto" : {
+ "type" : "object",
+ "required" : [ "name", "type" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "type" : {
+ "type" : "string",
+ "enum" : [ "Universal", "Unique", "One_Time" ]
+ },
+ "operationalScope" : {
+ "$ref" : "#/definitions/MultiChoiceOrOtherDtoOperationalScope"
+ },
+ "startDate" : {
+ "type" : "string"
+ },
+ "expiryDate" : {
+ "type" : "string"
+ },
+ "thresholdValue" : {
+ "type" : "integer",
+ "format" : "int32"
+ },
+ "thresholdUnits" : {
+ "type" : "string",
+ "enum" : [ "Absolute", "Percentage" ]
+ },
+ "increments" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "referencingFeatureGroups" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "LicenseKeyGroupRequestDto" : {
+ "type" : "object",
+ "required" : [ "name", "type" ],
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "type" : {
+ "type" : "string",
+ "enum" : [ "Universal", "Unique", "One_Time" ]
+ },
+ "operationalScope" : {
+ "$ref" : "#/definitions/MultiChoiceOrOtherDtoOperationalScope"
+ },
+ "startDate" : {
+ "type" : "string"
+ },
+ "expiryDate" : {
+ "type" : "string"
+ },
+ "thresholdValue" : {
+ "type" : "integer",
+ "format" : "int32"
+ },
+ "thresholdUnits" : {
+ "type" : "string",
+ "enum" : [ "Absolute", "Percentage" ]
+ },
+ "increments" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ }
+ }
+ },
+ "LicensingData" : {
+ "type" : "object",
+ "properties" : {
+ "licenseAgreement" : {
+ "type" : "string"
+ },
+ "featureGroups" : {
+ "type" : "array",
+ "items" : {
+ "type" : "string"
+ }
+ }
+ }
+ },
+ "LimitEntityDto" : {
+ "type" : "object",
+ "properties" : {
+ "id" : {
+ "type" : "string"
+ },
+ "name" : {
+ "type" : "string"
+ },
+ "type" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "metric" : {
+ "type" : "string"
+ },
+ "value" : {
+ "type" : "string"
+ },
+ "unit" : {
+ "type" : "string"
+ },
+ "aggregationFunction" : {
+ "type" : "string"
+ },
+ "time" : {
+ "type" : "string"
+ }
+ }
+ },
+ "LimitRequest" : {
+ "type" : "object",
+ "properties" : {
+ "name" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 120
+ },
+ "type" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "metric" : {
+ "type" : "string"
+ },
+ "value" : {
+ "type" : "string"
+ },
+ "unit" : {
+ "type" : "string"
+ },
+ "aggregationFunction" : {
+ "type" : "string"
+ },
+ "time" : {
+ "type" : "string"
+ }
+ }
+ },
+ "MediaType" : {
+ "type" : "object",
+ "properties" : {
+ "type" : {
+ "type" : "string"
+ },
+ "subtype" : {
+ "type" : "string"
+ },
+ "parameters" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "string"
+ }
+ },
+ "wildcardType" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "wildcardSubtype" : {
+ "type" : "boolean",
+ "default" : false
+ }
+ }
+ },
+ "Module" : {
+ "type" : "object",
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "isBase" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "yaml" : {
+ "type" : "string"
+ },
+ "env" : {
+ "type" : "string"
+ },
+ "vol" : {
+ "type" : "string"
+ },
+ "volEnv" : {
+ "type" : "string"
+ }
+ }
+ },
+ "MonitoringUploadStatusDto" : {
+ "type" : "object",
+ "properties" : {
+ "snmpTrap" : {
+ "type" : "string"
+ },
+ "snmpPoll" : {
+ "type" : "string"
+ },
+ "vesEvent" : {
+ "type" : "string"
+ }
+ }
+ },
+ "MultiChoiceOrOtherDtoOperationalScope" : {
+ "type" : "object",
+ "required" : [ "choices", "other" ],
+ "properties" : {
+ "choices" : {
+ "type" : "array",
+ "uniqueItems" : true,
+ "items" : {
+ "type" : "string",
+ "enum" : [ "Network_Wide", "Availability_Zone", "Data_Center", "Tenant", "VM", "CPU", "Core", "Other" ]
+ }
+ },
+ "other" : {
+ "type" : "string"
+ }
+ }
+ },
+ "NetworkDto" : {
+ "type" : "object",
+ "required" : [ "dhcp", "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "dhcp" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "id" : {
+ "type" : "string"
+ }
+ }
+ },
+ "NetworkRequestDto" : {
+ "type" : "object",
+ "required" : [ "dhcp", "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "dhcp" : {
+ "type" : "boolean",
+ "default" : false
+ }
+ }
+ },
+ "NicDto" : {
+ "type" : "object",
+ "required" : [ "networkType" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "networkId" : {
+ "type" : "string"
+ },
+ "networkType" : {
+ "type" : "string"
+ },
+ "networkDescription" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "networkName" : {
+ "type" : "string"
+ }
+ }
+ },
+ "NicRequestDto" : {
+ "type" : "object",
+ "required" : [ "networkType" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "networkId" : {
+ "type" : "string"
+ },
+ "networkType" : {
+ "type" : "string"
+ },
+ "networkDescription" : {
+ "type" : "string"
+ }
+ }
+ },
+ "NotificationEntityDto" : {
+ "type" : "object",
+ "properties" : {
+ "read" : {
+ "type" : "boolean",
+ "default" : false
+ },
+ "eventId" : {
+ "type" : "string",
+ "format" : "uuid"
+ },
+ "dateTime" : {
+ "type" : "string"
+ },
+ "eventType" : {
+ "type" : "string"
+ },
+ "eventAttributes" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "object"
+ }
+ }
+ }
+ },
+ "NotificationsStatusDto" : {
+ "type" : "object",
+ "properties" : {
+ "notifications" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/NotificationEntityDto"
+ }
+ },
+ "newEntries" : {
+ "type" : "array",
+ "items" : {
+ "type" : "string",
+ "format" : "uuid"
+ }
+ },
+ "lastScanned" : {
+ "type" : "string",
+ "format" : "uuid"
+ },
+ "endOfPage" : {
+ "type" : "string",
+ "format" : "uuid"
+ },
+ "numOfNotSeenNotifications" : {
+ "type" : "integer",
+ "format" : "int64"
+ }
+ }
+ },
+ "OutputStream" : {
+ "type" : "object"
+ },
+ "PackageInfoDto" : {
+ "type" : "object",
+ "properties" : {
+ "displayName" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "vspName" : {
+ "type" : "string"
+ },
+ "version" : {
+ "type" : "string"
+ },
+ "packageId" : {
+ "type" : "string"
+ },
+ "category" : {
+ "type" : "string"
+ },
+ "subCategory" : {
+ "type" : "string"
+ },
+ "vendorName" : {
+ "type" : "string"
+ },
+ "vendorRelease" : {
+ "type" : "string"
+ },
+ "packageChecksum" : {
+ "type" : "string"
+ },
+ "packageType" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ProcessEntityDto" : {
+ "type" : "object",
+ "required" : [ "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "type" : {
+ "type" : "string",
+ "enum" : [ "Lifecycle_Operations", "Other" ]
+ },
+ "id" : {
+ "type" : "string"
+ },
+ "artifactName" : {
+ "type" : "string"
+ }
+ }
+ },
+ "ProcessRequestDto" : {
+ "type" : "object",
+ "required" : [ "name" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "type" : {
+ "type" : "string",
+ "enum" : [ "Lifecycle_Operations", "Other" ]
+ }
+ }
+ },
+ "QuestionnaireResponseDto" : {
+ "type" : "object",
+ "properties" : {
+ "schema" : {
+ "type" : "string"
+ },
+ "data" : {
+ "type" : "string"
+ },
+ "errorMessage" : {
+ "$ref" : "#/definitions/ErrorMessage"
+ }
+ }
+ },
+ "RevisionDto" : {
+ "type" : "object",
+ "properties" : {
+ "id" : {
+ "type" : "string"
+ },
+ "message" : {
+ "type" : "string"
+ },
+ "time" : {
+ "type" : "string",
+ "format" : "date-time"
+ },
+ "user" : {
+ "type" : "string"
+ }
+ }
+ },
+ "RevisionRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "revisionId" : {
+ "type" : "string"
+ }
+ }
+ },
+ "SubmitRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "message" : {
+ "type" : "string"
+ }
+ }
+ },
+ "UpdateNotificationResponseStatus" : {
+ "type" : "object",
+ "properties" : {
+ "errors" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ErrorMessage"
+ }
+ }
+ },
+ "status" : {
+ "type" : "string",
+ "enum" : [ "Success", "Failure" ]
+ }
+ }
+ },
+ "UploadFileResponseDto" : {
+ "type" : "object",
+ "properties" : {
+ "errors" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "array",
+ "items" : {
+ "$ref" : "#/definitions/ErrorMessage"
+ }
+ }
+ },
+ "status" : {
+ "type" : "string",
+ "enum" : [ "Success", "Failure" ]
+ },
+ "onboardingOrigin" : {
+ "type" : "string"
+ },
+ "networkPackageName" : {
+ "type" : "string"
+ }
+ }
+ },
+ "VendorLicenseModelActionRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "action" : {
+ "type" : "string",
+ "enum" : [ "Submit" ]
+ },
+ "submitRequest" : {
+ "$ref" : "#/definitions/SubmitRequestDto"
+ }
+ }
+ },
+ "VendorLicenseModelEntity" : {
+ "type" : "object",
+ "required" : [ "description", "iconRef", "vendorName" ],
+ "properties" : {
+ "vendorName" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 25
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "iconRef" : {
+ "type" : "string"
+ },
+ "id" : {
+ "type" : "string"
+ }
+ }
+ },
+ "VendorLicenseModelRequest" : {
+ "type" : "object",
+ "required" : [ "description", "iconRef", "vendorName" ],
+ "properties" : {
+ "vendorName" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 25
+ },
+ "description" : {
+ "type" : "string",
+ "minLength" : 0,
+ "maxLength" : 1000
+ },
+ "iconRef" : {
+ "type" : "string"
+ }
+ }
+ },
+ "VersionActionRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "action" : {
+ "type" : "string",
+ "enum" : [ "Sync", "Commit", "Revert", "Reset" ]
+ },
+ "commitRequest" : {
+ "$ref" : "#/definitions/CommitRequestDto"
+ },
+ "revisionRequest" : {
+ "$ref" : "#/definitions/RevisionRequestDto"
+ }
+ }
+ },
+ "VersionDto" : {
+ "type" : "object",
+ "properties" : {
+ "id" : {
+ "type" : "string"
+ },
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "baseId" : {
+ "type" : "string"
+ },
+ "status" : {
+ "type" : "string",
+ "enum" : [ "Draft", "Locked", "Certified" ]
+ },
+ "state" : {
+ "$ref" : "#/definitions/VersionState"
+ },
+ "creationTime" : {
+ "type" : "string",
+ "format" : "date-time"
+ },
+ "modificationTime" : {
+ "type" : "string",
+ "format" : "date-time"
+ },
+ "additionalInfo" : {
+ "type" : "object",
+ "additionalProperties" : {
+ "type" : "object"
+ }
+ }
+ }
+ },
+ "VersionRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "description" : {
+ "type" : "string"
+ },
+ "creationMethod" : {
+ "type" : "string",
+ "enum" : [ "major", "minor" ]
+ }
+ }
+ },
+ "VersionSoftwareProductActionRequestDto" : {
+ "type" : "object",
+ "properties" : {
+ "action" : {
+ "type" : "string",
+ "enum" : [ "Submit", "Create_Package" ]
+ },
+ "submitRequest" : {
+ "$ref" : "#/definitions/SubmitRequestDto"
+ }
+ }
+ },
+ "VersionState" : {
+ "type" : "object",
+ "properties" : {
+ "synchronizationState" : {
+ "type" : "string",
+ "enum" : [ "UpToDate", "OutOfSync", "Merging" ]
+ },
+ "dirty" : {
+ "type" : "boolean",
+ "default" : false
+ }
+ }
+ },
+ "VspComputeDto" : {
+ "type" : "object",
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "componentId" : {
+ "type" : "string"
+ },
+ "computeFlavorId" : {
+ "type" : "string"
+ }
+ }
+ },
+ "VspDescriptionDto" : {
+ "type" : "object",
+ "required" : [ "category", "description", "name", "subCategory", "vendorId", "vendorName" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "icon" : {
+ "type" : "string"
+ },
+ "category" : {
+ "type" : "string"
+ },
+ "subCategory" : {
+ "type" : "string"
+ },
+ "vendorName" : {
+ "type" : "string"
+ },
+ "vendorId" : {
+ "type" : "string"
+ },
+ "licensingVersion" : {
+ "type" : "string"
+ },
+ "licensingData" : {
+ "$ref" : "#/definitions/LicensingData"
+ }
+ }
+ },
+ "VspRequestDto" : {
+ "type" : "object",
+ "required" : [ "category", "description", "name", "onboardingMethod", "subCategory", "vendorId", "vendorName" ],
+ "properties" : {
+ "name" : {
+ "type" : "string"
+ },
+ "description" : {
+ "type" : "string"
+ },
+ "icon" : {
+ "type" : "string"
+ },
+ "category" : {
+ "type" : "string"
+ },
+ "subCategory" : {
+ "type" : "string"
+ },
+ "vendorName" : {
+ "type" : "string"
+ },
+ "vendorId" : {
+ "type" : "string"
+ },
+ "licensingVersion" : {
+ "type" : "string"
+ },
+ "licensingData" : {
+ "$ref" : "#/definitions/LicensingData"
+ },
+ "onboardingMethod" : {
+ "type" : "string"
+ }
+ }
+ }
+ }
+} \ No newline at end of file
diff --git a/nokiav2/generatedapis/src/main/resources/vfc.catalog.swagger.json b/nokiav2/generatedapis/src/main/resources/vfc.catalog.swagger.json
new file mode 100644
index 00000000..f5079ec6
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/vfc.catalog.swagger.json
@@ -0,0 +1,751 @@
+{
+ "swagger": "2.0",
+ "info": {
+ "version": "1.0.0",
+ "title": "ONAP VFC Catalog Rest API",
+ "description": "VFC Catalog Management API.",
+ "contact": {
+ "name": "ONAP VFC team",
+ "email": "onap-discuss@lists.onap.org",
+ "url": "https://gerrit.onap.org/r/#/admin/projects/vfc/nfvo/catalog"
+ }
+ },
+ "basePath": "/api/catalog/v1",
+ "schemes": [
+ "http",
+ "https"
+ ],
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "paths": {
+ "/nspackages": {
+ "get": {
+ "tags": [
+ "nspackage"
+ ],
+ "summary": "query ns packages info",
+ "description": "query ns packages info",
+ "operationId": "query_ns_packages",
+ "parameters": [],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/NsPkgListInfo"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ },
+ "post": {
+ "tags": [
+ "nspackage"
+ ],
+ "summary": "ns package distribute",
+ "description": "ns package distribute",
+ "operationId": "ns_pkg_distribute",
+ "parameters": [
+ {
+ "in": "body",
+ "name": "body",
+ "description": "distribute request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/NsPkgDistributeRequest"
+ }
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/NsPkgDistributeResponse"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/nspackages/{csarId}": {
+ "get": {
+ "tags": [
+ "nspackage"
+ ],
+ "summary": "query ns package info",
+ "description": "query ns package info via ns package csarId",
+ "operationId": "query_ns_package",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "csarId",
+ "in": "path",
+ "description": "csar id of ns package",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/NsPkgDetailInfo"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ },
+ "delete": {
+ "tags": [
+ "nspackage"
+ ],
+ "summary": "delete ns pkg",
+ "description": "delete ns pkg",
+ "operationId": "delete_ns_pkg",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "csarId",
+ "in": "path",
+ "description": "csar id of ns package",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/NsPkgDelResponse"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/parsernsd": {
+ "post": {
+ "tags": [
+ "model"
+ ],
+ "summary": "ns package model",
+ "description": "ns package model",
+ "operationId": "ms_model_parser",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "body",
+ "description": "distribute request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/modelParserRequest"
+ }
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/modelParserResponse"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/vnfpackages": {
+ "get": {
+ "tags": [
+ "vnfpackage"
+ ],
+ "summary": "query vnf packages info",
+ "description": "query vnf packages info",
+ "operationId": "query_vnf_packages",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/VnfPkgListInfo"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ },
+ "post": {
+ "tags": [
+ "vnfpackage"
+ ],
+ "summary": "vnf package distribute",
+ "description": "vnf package distribute",
+ "operationId": "vnf_pkg_distribute",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "body",
+ "description": "distribute request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfPkgDistributeRequest"
+ }
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/VnfPkgDistributeResponse"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/vnfpackages/{csarId}": {
+ "get": {
+ "tags": [
+ "vnfpackage"
+ ],
+ "summary": "query vnf package info",
+ "description": "query one vnf package info via vnf package csarId",
+ "operationId": "query_vnf_package",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "csarId",
+ "in": "path",
+ "description": "csar id of vnf package",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/VnfPkgDetailInfo"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ },
+ "delete": {
+ "tags": [
+ "vnfpackage"
+ ],
+ "summary": "delete vnf package",
+ "description": "delete vnf package",
+ "operationId": "delete_vnf_package",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "csarId",
+ "in": "path",
+ "description": "csar id of vnf package",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/VnfPkgDelResponse"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/parservnfd": {
+ "post": {
+ "tags": [
+ "model"
+ ],
+ "summary": "vnf package model",
+ "description": "vnf package model",
+ "operationId": "vnf_model_parser",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "in": "body",
+ "name": "body",
+ "description": "distribute request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/modelParserRequest"
+ }
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/modelParserResponse"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/jobs/{jobId}": {
+ "get": {
+ "tags": [
+ "job"
+ ],
+ "summary": "jobstatus",
+ "description": "",
+ "operationId": "get_jobstatus",
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "job Id",
+ "name": "jobId",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "job response message id",
+ "name": "responseId",
+ "in": "query"
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/JobDetailInfo"
+ }
+ }
+ }
+ }
+ }
+ },
+ "definitions": {
+ "NsPkgDistributeRequest": {
+ "type": "object",
+ "properties": {
+ "csarId": {
+ "type": "string",
+ "description": "network service package id, UUID"
+ }
+ }
+ },
+ "NsPkgDistributeResponse": {
+ "type": "object",
+ "properties": {
+ "status": {
+ "type": "string",
+ "description": "Operation status. value is success or failed"
+ },
+ "statusDescription": {
+ "type": "string",
+ "description": "description about the operation result"
+ },
+ "errorCode": {
+ "type": "string",
+ "description": "If the status is failed, the errorcode will be returned"
+ }
+ }
+ },
+ "NsPkgDelResponse": {
+ "type": "object",
+ "properties": {
+ "status": {
+ "type": "string",
+ "description": "Operation status. value is success or failed"
+ },
+ "statusDescription": {
+ "type": "string",
+ "description": "description about the operation result"
+ },
+ "errorCode": {
+ "type": "string",
+ "description": "If the status is failed, the errorcode will be returned"
+ }
+ }
+ },
+ "NsPkgListInfo": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/NsPkgInfo"
+ }
+ },
+ "NsPkgDetailInfo": {
+ "type": "object",
+ "properties": {
+ "csarId": {
+ "type": "string"
+ },
+ "packageInfo": {
+ "$ref": "#/definitions/NsPkgInfo"
+ },
+ "instanceInfo": {
+ "$ref": "#/definitions/NsInstListInfo"
+ }
+ }
+ },
+ "NsPkgInfo": {
+ "type": "object",
+ "properties": {
+ "nsPackageId": {
+ "type": "string",
+ "description": "The identifer of the NS (csarId)"
+ },
+ "nsdId": {
+ "type": "string",
+ "description": "network service descriptor identifer (same as csarId)"
+ },
+ "csarName": {
+ "type": "string",
+ "description": "The name of the CSAR"
+ },
+ "nsdProvider": {
+ "type": "string",
+ "description": "network service designer name"
+ },
+ "nsdVersion": {
+ "type": "string",
+ "description": "network service descriptor version"
+ },
+ "downloadUrl": {
+ "type": "string",
+ "description": "The URL from which the NSD package can be downloaded from"
+ },
+ "nsdModel": {
+ "type": "string",
+ "description": "The parsed model of the NSD (JSON encoded into string)"
+ }
+ }
+ },
+ "NsInstListInfo": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/NsInstInfo"
+ }
+ },
+ "NsInstInfo": {
+ "type": "object",
+ "properties": {
+ "nsInstanceId": {
+ "type": "string",
+ "description": "network service instance ID"
+ },
+ "nsInstanceName": {
+ "type": "string",
+ "description": "network service instance name"
+ }
+ }
+ },
+ "VnfPkgDistributeRequest": {
+ "type": "object",
+ "properties": {
+ "csarId": {
+ "type": "string",
+ "description": "vnf package id, UUID"
+ }
+ }
+ },
+ "VnfPkgDistributeResponse": {
+ "type": "object",
+ "properties": {
+ "jobId": {
+ "type": "string",
+ "description": "VNF package distribute job ID"
+ }
+ }
+ },
+ "VnfPkgDelResponse": {
+ "type": "object",
+ "properties": {
+ "status": {
+ "type": "string",
+ "description": "Operation status. value is success or failed"
+ },
+ "statusDescription": {
+ "type": "string",
+ "description": "description about the operation result"
+ },
+ "errorCode": {
+ "type": "string",
+ "description": "If the status is failed, the errorcode will be returned"
+ }
+ }
+ },
+ "VnfPkgListInfo": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfPkgInfo"
+ }
+ },
+ "VnfPkgDetailInfo": {
+ "type": "object",
+ "properties": {
+ "csarId": {
+ "type": "string",
+ "description": "vnf package id, UUID"
+ },
+ "packageInfo": {
+ "$ref": "#/definitions/VnfPkgInfo"
+ },
+ "imageInfo": {
+ "$ref": "#/definitions/VnfPkgImgListInfo"
+ },
+ "vnfInstanceInfo": {
+ "$ref": "#/definitions/VnfInstListInfo"
+ }
+ }
+ },
+ "VnfPkgInfo": {
+ "type": "object",
+ "description": "vnf package infomation",
+ "properties": {
+ "vnfPackageId": {
+ "type": "string",
+ "description": "The identifier of the VNF package (csarId)"
+ },
+ "csarName": {
+ "type": "string",
+ "description": "The name of the CSAR"
+ },
+ "vnfdId": {
+ "type": "string",
+ "description": "VNF descriptor ID (same as CSAR ID)"
+ },
+ "vnfdProvider": {
+ "type": "string",
+ "description": "VNF descriptor vendor ID"
+ },
+ "vnfdVersion": {
+ "type": "string",
+ "description": "VNF descriptor version"
+ },
+ "vnfVersion": {
+ "type": "string",
+ "description": "VNF Software version"
+ },
+ "vnfdModel":{
+ "type": "string",
+ "description": "The model of the VNFD (JSON encoded into string)"
+ },
+ "downloadUrl":{
+ "type": "string",
+ "description": "The URL from which the package can be downloaded from"
+ }
+ }
+ },
+ "VnfInstListInfo": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfInstInfo"
+ }
+ },
+ "VnfInstInfo": {
+ "type": "object",
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string",
+ "description": "VNF instance ID"
+ },
+ "vnfInstanceName": {
+ "type": "string",
+ "description": "VNF instance name"
+ }
+ }
+ },
+ "VnfPkgImgListInfo": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfPkgImgInfo"
+ }
+ },
+ "VnfPkgImgInfo": {
+ "type": "object",
+ "properties": {
+ "fileName": {
+ "type": "string",
+ "description": "image file name"
+ },
+ "imageUrl": {
+ "type": "string",
+ "description": "image file path in the csar or image url in external repository"
+ }
+ }
+ },
+ "modelParserRequest":{
+ "type": "object",
+ "properties": {
+ "csarId": {
+ "type": "string",
+ "description": "csar Package Id"
+ },
+ "inputs": {
+ "type": "object",
+ "description": "csar package json inputs"
+ }
+ }
+ },
+ "modelParserResponse":{
+ "type": "object",
+ "properties": {
+ "model": {
+ "type": "object",
+ "description": "csar model json data"
+ }
+ }
+ },
+ "jobResponseInfo": {
+ "type": "object",
+ "properties": {
+ "status": {
+ "type": "string"
+ },
+ "progress":{
+ "type": "string"
+ },
+ "statusDescription": {
+ "type": "string"
+ },
+ "errorCode": {
+ "type": "string"
+ },
+ "responseId": {
+ "type": "string"
+ }
+ }
+ },
+ "JobDetailInfo":{
+ "type": "object",
+ "properties": {
+ "jobId": {
+ "type": "string"
+ },
+ "responseDescriptor":
+ {
+ "type":"object",
+ "properties": {
+ "status": {
+ "type": "string"
+ },
+ "progress":{
+ "type": "string"
+ },
+ "statusDescription": {
+ "type": "string"
+ },
+ "errorCode": {
+ "type": "string"
+ },
+ "responseId": {
+ "type": "string"
+ },
+ "responseHistoryList": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/jobResponseInfo"
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+}
diff --git a/nokiav2/generatedapis/src/main/resources/vfc.vnfdriver.swagger.json b/nokiav2/generatedapis/src/main/resources/vfc.vnfdriver.swagger.json
new file mode 100644
index 00000000..0670ea98
--- /dev/null
+++ b/nokiav2/generatedapis/src/main/resources/vfc.vnfdriver.swagger.json
@@ -0,0 +1,1385 @@
+{
+ "swagger": "2.0",
+ "info": {
+ "version": "1.0.0",
+ "title": "ONAP VNFM Driver Development Related API",
+ "description": "ONAP VNFM Driver Development Related Rest API.",
+ "contact": {
+ "name": "ONAP VFC team",
+ "email": "onap-discuss@lists.onap.org",
+ "url": "https://gerrit.onap.org/r/#/admin/projects/vfc/nfvo/lcm"
+ }
+ },
+ "basePath": "/api",
+ "schemes": [
+ "http",
+ "https"
+ ],
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "paths": {
+ "/{vnfmtype}/v1/{vnfmid}/vnfs": {
+ "post": {
+ "tags": [
+ "VnfmDriver"
+ ],
+ "summary": "vnf create&instantiate",
+ "description": "VNF create&instantiate Rest API should be provided by the VNFM Driver",
+ "operationId": "vnf_instantiate",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmtype should be the SVNFM driver service name",
+ "name": "vnfmtype",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmid should be the VNFM Instantiate ID",
+ "name": "vnfmid",
+ "in": "path"
+ },
+ {
+ "in": "body",
+ "name": "body",
+ "description": "instantiate request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfInstantiateRequest"
+ }
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/VnfInstantiateResponse"
+ }
+ }
+ }
+ }
+ },
+ "/{vnfmtype}/v1/{vnfmid}/vnfs/{vnfInstanceId}/scale": {
+ "post": {
+ "tags": [
+ "VnfmDriver"
+ ],
+ "summary": "vnf Scale",
+ "description": "VNF Scale Rest API should be provided by the VNFM Driver",
+ "operationId": "vnf_scale",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmtype should be the SVNFM driver service name",
+ "name": "vnfmtype",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmid should be the VNFM Instantiate ID",
+ "name": "vnfmid",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfInstanceId should be the VNF Instantiate ID",
+ "name": "vnfInstanceId",
+ "in": "path"
+ },
+ {
+ "in": "body",
+ "name": "body",
+ "description": "instantiate request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfScaleRequest"
+ }
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/JobInfo"
+ }
+ },
+ "404": {
+ "description": "the VNF instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ }
+ }
+ },
+ "/{vnfmtype}/v1/{vnfmid}/vnfs/{vnfInstanceId}/heal": {
+ "post": {
+ "tags": [
+ "VnfmDriver"
+ ],
+ "summary": "vnf heal",
+ "description": "VNF Heal Rest API should be provided by the VNFM Driver",
+ "operationId": "vnf_heal",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmtype should be the SVNFM driver service name",
+ "name": "vnfmtype",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmid should be the VNFM Instantiate ID",
+ "name": "vnfmid",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfInstanceId should be the VNF Instantiate ID",
+ "name": "vnfInstanceId",
+ "in": "path"
+ },
+ {
+ "in": "body",
+ "name": "body",
+ "description": "instantiate request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfHealRequest"
+ }
+ }
+ ],
+ "responses": {
+ "201": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/JobInfo"
+ }
+ },
+ "404": {
+ "description": "the VNF instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ }
+ }
+ },
+ "/{vnfmtype}/v1/{vnfmid}/vnfs/{vnfInstanceId}/terminate": {
+ "post": {
+ "tags": [
+ "VnfmDriver"
+ ],
+ "summary": "terminate&delete vnf",
+ "description": "VNF terminate&delete Rest API should be provided by the VNFM Driver",
+ "operationId": "terminate_vnf",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmtype should be the SVNFM driver service name",
+ "name": "vnfmtype",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmid should be the VNFM Instantiate ID",
+ "name": "vnfmid",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfInstanceId should be the VNF Instantiate ID",
+ "name": "vnfInstanceId",
+ "in": "path"
+ },
+ {
+ "in": "body",
+ "name": "body",
+ "description": "instantiate request param",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VnfTerminateRequest"
+ }
+ }
+ ],
+ "responses": {
+ "204": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/JobInfo"
+ }
+ },
+ "404": {
+ "description": "the VNF instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ }
+ }
+ },
+ "/{vnfmtype}/v1/{vnfmid}/vnfs/{vnfInstanceId}": {
+ "get": {
+ "tags": [
+ "VnfmDriver"
+ ],
+ "summary": "query the specified vnf info",
+ "description": "",
+ "operationId": "query_vnf",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmtype should be the SVNFM driver service name",
+ "name": "vnfmtype",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmid should be the VNFM Instantiate ID",
+ "name": "vnfmid",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfInstanceId should be the VNF Instantiate ID",
+ "name": "vnfInstanceId",
+ "in": "path"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/VnfInfo"
+ }
+ },
+ "404": {
+ "description": "the vnf instance id is wrong"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ }
+ }
+ },
+ "/nslcm/v1/ns/grantvnf": {
+ "post": {
+ "tags": [
+ "Nslcm"
+ ],
+ "summary": "grantvnf",
+ "description": "Grant VNF, provived by the Nslcm component",
+ "operationId": "grantvnf",
+ "parameters": [
+ {
+ "in": "body",
+ "name": "grantvnf",
+ "description": "Grant VNF Request",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/GrantVNFRequest"
+ }
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/GrantVNFResponse"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ }
+ }
+ },
+ "/nslcm/v1/ns/{vnfmid}/vnfs/{vnfInstanceId}/Notify": {
+ "post": {
+ "tags": [
+ "Nslcm"
+ ],
+ "summary": "VNF LCM Notification",
+ "description": "VNF LCM Notification API should be provided by Nslcm component",
+ "operationId": "VNF_LCM_Notification",
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "VNFM Instance Id",
+ "name": "vnfmid",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "VNF Instance Id",
+ "name": "vnfInstanceId",
+ "in": "path"
+ },
+ {
+ "in": "body",
+ "name": "vnf Notification",
+ "description": "VNF LCM Notification",
+ "required": true,
+ "schema": {
+ "$ref": "#/definitions/VNFLCMNotification"
+ }
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": ""
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "the url is invalid"
+ }
+ }
+ }
+ },
+ "/{vnfmid}/jobs/{jobid}": {
+ "get": {
+ "tags": [
+ "VnfmDriver"
+ ],
+ "summary": "jobstatus",
+ "description": "Job Infomation API should be provided by VNFM Driver",
+ "operationId": "get_jobstatus",
+ "parameters": [
+ {
+ "required": true,
+ "type": "string",
+ "description": "job Id",
+ "name": "jobid",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "The value of vnfmid should be the VNFM Instantiate ID",
+ "name": "vnfmid",
+ "in": "path"
+ },
+ {
+ "required": true,
+ "type": "string",
+ "description": "job response message id",
+ "name": "responseId",
+ "in": "query"
+ }
+ ],
+ "responses": {
+ "202": {
+ "description": "",
+ "schema": {
+ "$ref": "#/definitions/JobDetailInfo"
+ }
+ }
+ }
+ }
+ },
+ "/catalog/v1/vnfpackages/{csarId}": {
+ "get": {
+ "tags": [
+ "Catalog"
+ ],
+ "summary": "query vnf package info",
+ "description": "query one vnf package info via vnf package csarId",
+ "operationId": "query_vnf_package",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "csarId",
+ "in": "path",
+ "description": "csar id of vnf package",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/VnfPkgDetailInfo"
+ }
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/nslcm/v1/vnfms/{vnfmid}":{
+ "get": {
+ "tags": [
+ "Nslcm"
+ ],
+ "summary": "Query VNFM register info",
+ "description": "query VNFM register info",
+ "operationId": "query_vnfm_info",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "vnfmid",
+ "in": "path",
+ "description": "vnfm id",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/VnfmInfo"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ },
+ "/nslcm/v1/vims/{vimid}":{
+ "get": {
+ "tags": [
+ "Nslcm"
+ ],
+ "summary": "Query VIM register info",
+ "description": "query VIM register info",
+ "operationId": "query_VIM_info",
+ "consumes": [
+ "application/json"
+ ],
+ "produces": [
+ "application/json"
+ ],
+ "parameters": [
+ {
+ "name": "vimid",
+ "in": "path",
+ "description": "vim id",
+ "required": true,
+ "type": "string"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "successful operation",
+ "schema": {
+ "$ref": "#/definitions/VimInfo"
+ }
+ },
+ "404": {
+ "description": "URL not found"
+ },
+ "500": {
+ "description": "internal error"
+ }
+ }
+ }
+ }
+ },
+ "definitions": {
+ "jobResponseInfo": {
+ "type": "object",
+ "properties": {
+ "status": {
+ "type": "string"
+ },
+ "progress": {
+ "type": "string"
+ },
+ "statusDescription": {
+ "type": "string"
+ },
+ "errorCode": {
+ "type": "string"
+ },
+ "responseId": {
+ "type": "string"
+ }
+ }
+ },
+ "JobStatus" : {
+ "description": "The status of the job",
+ "type": "string",
+ "enum": [
+ "started",
+ "processing",
+ "finished",
+ "error",
+ "timeout"
+ ]
+ },
+ "JobDetailInfo": {
+ "type": "object",
+ "properties": {
+ "jobId": {
+ "type": "string"
+ },
+ "responseDescriptor": {
+ "type": "object",
+ "properties": {
+ "status": {
+ "$ref": "#/definitions/JobStatus",
+ "description": "The status of the job"
+ },
+ "progress": {
+ "type": "string",
+ "description": "The progress of the job. Value between 0 and 100."
+ },
+ "statusDescription": {
+ "type": "string",
+ "description": "The reason of the current status of the job."
+ },
+ "errorCode": {
+ "type": "string"
+ },
+ "responseId": {
+ "type": "string"
+ },
+ "responseHistoryList": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/jobResponseInfo"
+ }
+ }
+ }
+ }
+ }
+ },
+ "ChangeType" : {
+ "description": "The type of the change",
+ "type": "string",
+ "enum": [
+ "VDU"
+ ]
+ },
+ "ResourceChange" : {
+ "type": "object",
+ "properties": {
+ "type": {
+ "$ref": "#/definitions/ChangeType",
+ "description": "The type of the resource."
+ },
+ "resourceDefinitionId": {
+ "description": "The identifier of the resource within the grant request.",
+ "type": "string"
+ },
+ "vdu": {
+ "description": "The identifier of the VDU.",
+ "type": "string"
+ }
+ }
+ },
+ "OperationType" : {
+ "description": "The type of operation",
+ "type": "string",
+ "enum": [
+ "Terminal",
+ "Instantiate",
+ "Scalein",
+ "Scaleout",
+ "Scaledown",
+ "Scaleup",
+ "Heal"
+ ]
+ },
+ "GrantVNFRequest": {
+ "type": "object",
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string"
+ },
+ "vnfDescriptorId": {
+ "type": "string"
+ },
+ "lifecycleOperation": {
+ "description" : "The type of the operation.",
+ "$ref": "#/definitions/OperationType"
+ },
+ "jobId": {
+ "type": "string"
+ },
+ "addResource": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ResourceChange"
+ }
+ },
+ "removeResource": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/ResourceChange"
+ }
+ },
+ "additionalParam": {
+ "type": "object",
+ "description": "The data type is KeyValuePair. Additional parameters passed by the NFVO, specific to the VNF and the LCM operation."
+ }
+ }
+ },
+ "GrantVNFResponse": {
+ "type": "object",
+ "properties": {
+ "vim": {
+ "type": "object",
+ "properties": {
+ "vimInfoId": {
+ "type": "string"
+ },
+ "vimId": {
+ "type": "string"
+ },
+ "interfaceInfo": {
+ "type": "object",
+ "properties": {
+ "vimType": {
+ "type": "string",
+ "description": "The vim Type value wil be openstack"
+ },
+ "apiVersion": {
+ "type": "string",
+ "description": "The api Version Type value will be "
+ },
+ "protocolType": {
+ "type": "string",
+ "description": "The protocol Type value will be http or https"
+ }
+ }
+ },
+ "accessInfo": {
+ "type": "object",
+ "properties": {
+ "tenant": {
+ "type": "string",
+ "description": "Tenant Name of tenant"
+ },
+ "username": {
+ "type": "string",
+ "description": "Username for login"
+ },
+ "password": {
+ "type": "string",
+ "description": "Password of login user"
+ }
+ }
+ },
+ "interfaceEndpoint": {
+ "type": "string",
+ "description": "Information about the interface endpoint. It is a URL"
+ }
+ }
+ }
+ }
+ },
+ "VnfNotificationType": {
+ "description": "The type of the notification",
+ "type": "string",
+ "enum": [
+ "added",
+ "removed",
+ "modified"
+ ]
+ },
+ "AffectedVnfc": {
+ "type": "object",
+ "properties": {
+ "vnfcInstanceId": {
+ "type": "string",
+ "description": "Identifier of the VNFC instance"
+ },
+ "vduId": {
+ "type": "string",
+ "description": "Identifier of the VDU in the VNFD"
+ },
+ "changeType": {
+ "$ref": "#/definitions/VnfNotificationType",
+ "description": "The type of the change"
+ },
+ "vimid": {
+ "type": "string",
+ "description": "Identifier of vim"
+ },
+ "vmid": {
+ "type": "string",
+ "description": "Identifier of virtual machine"
+ },
+ "vmname": {
+ "type": "string",
+ "description": "Name of virtual machine"
+ }
+ }
+ },
+ "AffectedVirtualLinkType": {
+ "description": "The type of the affected virtual link",
+ "type": "string",
+ "enum": [
+ "network",
+ "port"
+ ]
+ },
+ "AffectedVirtualLink":{
+ "type": "object",
+ "properties": {
+ "vlInstanceId": {
+ "type": "string",
+ "description": "Identifier of the VL instance"
+ },
+ "vldid": {
+ "type": "string",
+ "description": "Identifier of the VLD in the VNFD"
+ },
+ "changeType": {
+ "$ref": "#/definitions/VnfNotificationType",
+ "description": "The type of the change"
+ },
+ "networkResource": {
+ "type": "object",
+ "description": "network Resource",
+ "properties": {
+ "resourceType": {
+ "$ref": "#/definitions/AffectedVirtualLinkType",
+ "description": "Must be network"
+ },
+ "resourceId": {
+ "type": "string",
+ "description": "Identifier of the resource in the scope of the VIM"
+ }
+ }
+ }
+ }
+ },
+ "VnfCpNotificationType": {
+ "description": "The type of the notification for connection points",
+ "type": "string",
+ "enum": [
+ "added",
+ "removed",
+ "changed"
+ ]
+ },
+ "AffectedCp": {
+ "type": "object",
+ "properties": {
+ "virtualLinkInstanceId": {
+ "type": "string",
+ "description": "Identifier of the VL instance"
+ },
+ "cpinstanceid": {
+ "type": "string",
+ "description": "Identifier of the connection point"
+ },
+ "cpdid": {
+ "type": "string",
+ "description": "Identifier of the connection point in the VNFD"
+ },
+ "ownerType": {
+ "type": "string",
+ "description": "The type of the owner."
+ },
+ "ownerId": {
+ "type": "string",
+ "description": "Identifier of the owner. Mandatory if ownerType is specified."
+ },
+ "changeType": {
+ "$ref": "#/definitions/VnfCpNotificationType",
+ "description": "The type of the change"
+ },
+ "portResource": {
+ "type": "object",
+ "description": "port Resource",
+ "properties": {
+ "vimid": {
+ "type": "string",
+ "description": "Identifier of the VIM"
+ },
+ "resourceid": {
+ "type": "string",
+ "description": "Identifier of the resource in the scope of the VIM"
+ },
+ "resourceName": {
+ "type": "string",
+ "description": "Resource name in the vim"
+ },
+ "tenant": {
+ "type": "string",
+ "description": "The identifier of the tenant"
+ },
+ "ipAddress": {
+ "type": "string",
+ "description": "The IP address of the port"
+ },
+ "macAddress": {
+ "type": "string",
+ "description": "The MAC address of the port"
+ },
+ "instId": {
+ "type": "string",
+ "description": "The instance id of the server to which the port is attached to"
+ }
+ }
+ }
+ }
+ },
+ "AffectedVirtualStorage" : {
+ "type": "object"
+ },
+ "VnfLcmNotificationStatus" : {
+ "description": "The status of the operation",
+ "type": "string",
+ "enum": [
+ "result",
+ "start"
+ ]
+ },
+ "VNFLCMNotification": {
+ "type": "object",
+ "properties": {
+ "status": {
+ "description" : "The status of the operation that triggered the LCN.",
+ "$ref": "#/definitions/VnfLcmNotificationStatus"
+ },
+ "vnfInstanceId": {
+ "type": "string"
+ },
+ "operation": {
+ "description" : "The type of the operation that tiggered the LCN.",
+ "$ref": "#/definitions/OperationType"
+ },
+ "jobId": {
+ "description" : "The identifier fo the job that triggered the LCN.",
+ "type": "string"
+ },
+ "affectedVnfc": {
+ "type": "array",
+ "description": "The affected VNFCs",
+ "items": {
+ "$ref": "#/definitions/AffectedVnfc"
+ }
+ },
+ "affectedCp": {
+ "type": "array",
+ "description": "The affected Connected Points",
+ "items": {
+ "$ref": "#/definitions/AffectedCp"
+ }
+ },
+ "affectedVl": {
+ "type": "array",
+ "description": "The affected virtual links",
+ "items": {
+ "$ref": "#/definitions/AffectedVirtualLink"
+ }
+ },
+ "affectedVirtualStorage": {
+ "type": "array",
+ "description": "The affected virtual storages. (Not supported)",
+ "items": {
+ "$ref": "#/definitions/AffectedVirtualStorage"
+ }
+ }
+ }
+ },
+ "VnfInstantiateRequest": {
+ "type": "object",
+ "properties": {
+ "vnfInstanceName": {
+ "type": "string"
+ },
+ "vnfPackageId": {
+ "type": "string"
+ },
+ "vnfDescriptorId": {
+ "type": "string"
+ },
+ "vnfInstanceDescription": {
+ "type": "string"
+ },
+ "extVirtualLink": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/extVirtualLinkInfo"
+ }
+ },
+ "additionalParam": {
+ "type": "object"
+ }
+ }
+ },
+ "extVirtualLinkInfo":{
+ "type": "object",
+ "properties": {
+ "resourceSubnetId": {
+ "type": "string",
+ "description": "The provider id of the subnet"
+ },
+ "vlInstanceId": {
+ "type": "string",
+ "description" : "The identifier of the virtual link"
+ },
+ "resourceId": {
+ "type": "string",
+ "description": "The provider id of the network"
+ },
+ "cpdId": {
+ "type": "string",
+ "description": "The identifier of the connection point descriptor"
+ },
+ "vim": {
+ "type": "object",
+ "properties": {
+ "vimid": {
+ "type": "string",
+ "description": "The identifier of the VIM"
+ }
+ }
+ }
+ }
+ },
+ "VnfInstantiateResponse": {
+ "type": "object",
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string"
+ },
+ "jobId": {
+ "type": "string"
+ }
+ }
+ },
+ "ScaleDirection" : {
+ "description": "The direction of the scaling",
+ "type": "string",
+ "enum": [
+ "SCALE_IN",
+ "SCALE_OUT"
+ ]
+ },
+ "VnfScaleRequest":{
+ "type": "object",
+ "properties": {
+ "type": {
+ "description" : "The direction of the scaling.",
+ "$ref": "#/definitions/ScaleDirection"
+ },
+ "aspectId":{
+ "type": "string",
+ "description": "Identifies the aspect of the VNF that is requested to be scaled"
+ },
+ "numberOfSteps": {
+ "type": "string",
+ "description": "Number of scaling steps to be executed as part of this ScaleVnf operation. It shall be a positive number"
+ },
+ "additionalParam":{
+ "type": "object",
+ "description": "Additional parameters passed by the NFVO as input to the scaling process, specific to the VNF being scaled"
+ }
+ }
+ },
+ "VnfHealRequest":{
+ "type": "object",
+ "properties": {
+ "action": {
+ "type": "string"
+ },
+ "affectedvm": {
+ "type": "object",
+ "properties": {
+ "vimid":{
+ "type": "string"
+ },
+ "vduid": {
+ "type": "string"
+ },
+ "vmname":{
+ "type": "string"
+ }
+ }
+ }
+ }
+ },
+ "VnfTerminationType": {
+ "description": "The type of the termination.",
+ "type": "string",
+ "enum": [
+ "graceful",
+ "forceful"
+ ]
+ },
+ "VnfTerminateRequest":{
+ "type": "object",
+ "properties": {
+ "terminationType": {
+ "description" : "The type of the termination",
+ "$ref": "#/definitions/VnfTerminationType"
+ },
+ "gracefulTerminationTimeout": {
+ "description": "The time interval(second) to wait for the VNF to be taken out of service during graceful termination.",
+ "type": "string"
+ }
+ }
+ },
+ "JobInfo": {
+ "type": "object",
+ "properties": {
+ "jobId": {
+ "type": "string"
+ }
+ }
+ },
+ "VnfInfo": {
+ "type": "object",
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string"
+ },
+ "vnfInstanceName": {
+ "type": "string"
+ },
+ "vnfInstanceDescription": {
+ "type": "string"
+ },
+ "vnfdId": {
+ "type": "string"
+ },
+ "vnfPackageId": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ },
+ "vnfProvider": {
+ "type": "string"
+ },
+ "vnfType": {
+ "type": "string"
+ },
+ "vnfStatus": {
+ "type": "string"
+ }
+ }
+ },
+ "vimInfo": {
+ "type": "object",
+ "properties": {
+ "vimInfoId": {
+ "type": "string"
+ },
+ "vimId": {
+ "type": "string"
+ },
+ "interfaceInfo": {
+ "type": "object",
+ "properties": {
+ "vimType": {
+ "type": "string",
+ "description": "The vim Type value wil be openstack"
+ },
+ "apiVersion": {
+ "type": "string",
+ "description": "The api Version Type value will be "
+ },
+ "protocolType": {
+ "type": "string",
+ "description": "The protocol Type value will be http or https"
+ }
+ }
+ },
+ "accessInfo": {
+ "type": "object",
+ "properties": {
+ "tenant": {
+ "type": "string",
+ "description": "Tenant Name of tenant"
+ },
+ "username": {
+ "type": "string",
+ "description": "Username for login"
+ },
+ "password": {
+ "type": "string",
+ "description": "Password of login user"
+ }
+ }
+ },
+ "interfaceEndpoint": {
+ "type": "string",
+ "description": "Information about the interface endpoint. It is a URL"
+ }
+ }
+ },
+ "VnfPkgDetailInfo": {
+ "type": "object",
+ "properties": {
+ "csarId": {
+ "type": "string",
+ "description": "vnf package id, UUID"
+ },
+ "packageInfo": {
+ "$ref": "#/definitions/VnfPkgInfo"
+ },
+ "imageInfo": {
+ "$ref": "#/definitions/VnfPkgImgListInfo"
+ },
+ "vnfInstanceInfo": {
+ "$ref": "#/definitions/VnfInstListInfo"
+ }
+ }
+ },
+ "VnfPkgInfo": {
+ "type": "object",
+ "description": "vnf package infomation",
+ "properties": {
+ "vnfPackageId": {
+ "type": "string",
+ "description": "vnf package id (csarId)"
+ },
+ "csarName": {
+ "type": "string",
+ "description": "The name of the csar"
+ },
+ "vnfdId": {
+ "type": "string",
+ "description": "VNF descriptor ID"
+ },
+ "vnfdProvider": {
+ "type": "string",
+ "description": "VNF descriptor vendor ID"
+ },
+ "vnfdModel": {
+ "type": "string",
+ "description": "The model of the VNF (JSON) encoded to string"
+ },
+ "vnfdVersion": {
+ "type": "string",
+ "description": "VNF descriptor version"
+ },
+ "vnfVersion": {
+ "type": "string",
+ "description": "VNF Software version"
+ },
+ "downloadUrl":{
+ "type": "string",
+ "description": "The URL from which the VNF package can be downloaded"
+ }
+ }
+ },
+ "VnfInstListInfo": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfInstInfo"
+ }
+ },
+ "VnfInstInfo": {
+ "type": "object",
+ "properties": {
+ "vnfInstanceId": {
+ "type": "string",
+ "description": "VNF instance ID"
+ },
+ "vnfInstanceName": {
+ "type": "string",
+ "description": "VNF instance name"
+ }
+ }
+ },
+ "VnfPkgImgListInfo": {
+ "type": "array",
+ "items": {
+ "$ref": "#/definitions/VnfPkgImgInfo"
+ }
+ },
+ "VnfPkgImgInfo": {
+ "type": "object",
+ "properties": {
+ "fileName": {
+ "type": "string",
+ "description": "image file name"
+ },
+ "imageUrl": {
+ "type": "string",
+ "description": "image file path in the csar or image url in external repository"
+ }
+ }
+ },
+ "VnfmInfo": {
+ "type": "object",
+ "properties": {
+ "vnfmId": {
+ "type": "string",
+ "description": "vnfm Id"
+ },
+ "name": {
+ "type": "string",
+ "description": "vnfm name"
+ },
+ "type": {
+ "type": "string",
+ "description": "vnfm type"
+ },
+ "url": {
+ "type": "string",
+ "description": "vnfm url"
+ },
+ "userName": {
+ "type": "string",
+ "description": "vnfm login username"
+ },
+ "password": {
+ "type": "string",
+ "description": "vnfm login password"
+ },
+ "vimId": {
+ "type": "string",
+ "description": "vim Id"
+ },
+ "vendor": {
+ "type": "string",
+ "description": "vendor name"
+ },
+ "version": {
+ "type": "string",
+ "description": "vnfm version"
+ },
+ "description": {
+ "type": "string",
+ "description": "vnfm description"
+ },
+ "certificateUrl": {
+ "type": "string",
+ "description": "vnfm certificate Url"
+ },
+ "createTime": {
+ "type": "string",
+ "description": "vnfm info createTime"
+ }
+ }
+ },
+ "VimInfo": {
+ "type": "object",
+ "properties": {
+ "vimId": {
+ "type": "string",
+ "description": "vim Id"
+ },
+ "name": {
+ "type": "string",
+ "description": "vim name"
+ },
+ "type": {
+ "type": "string",
+ "description": "vim type"
+ },
+ "url": {
+ "type": "string",
+ "description": "vim url"
+ },
+ "userName": {
+ "type": "string",
+ "description": "vim login username"
+ },
+ "password": {
+ "type": "string",
+ "description": "vim login password"
+ },
+ "vendor": {
+ "type": "string",
+ "description": "vendor name"
+ },
+ "version": {
+ "type": "string",
+ "description": "vim version"
+ },
+ "description": {
+ "type": "string",
+ "description": "vim description"
+ },
+ "createTime": {
+ "type": "string",
+ "description": "vim info createTime"
+ },
+ "sslCacert": {
+ "type": "string",
+ "description": "The collection of trusted certificates towards the VIM connection."
+ },
+ "sslInsecure": {
+ "type": "string",
+ "description": "Whether to verify VIM's certificate"
+ },
+ "status": {
+ "type": "string",
+ "description": "The status of external system"
+ }
+ }
+ }
+ }
+}
diff --git a/nokiav2/generatedapis/src/test/java/TestInhertence.java b/nokiav2/generatedapis/src/test/java/TestInhertence.java
new file mode 100644
index 00000000..8e7d551e
--- /dev/null
+++ b/nokiav2/generatedapis/src/test/java/TestInhertence.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright 2016-2017, Nokia Corporation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import com.nokia.cbam.lcm.v32.ApiClient;
+import com.nokia.cbam.lcm.v32.model.*;
+import org.junit.Test;
+
+import static junit.framework.TestCase.assertEquals;
+import static junit.framework.TestCase.assertNull;
+import static junit.framework.TestCase.assertTrue;
+
+public class TestInhertence {
+
+ /**
+ * test OpenStack v2 inheritence handling in serialization and deserialization
+ */
+ @Test
+ public void testOpenStackV2(){
+ InstantiateVnfRequest req = new InstantiateVnfRequest();
+ OPENSTACKV2INFO vim = new OPENSTACKV2INFO();
+ req.getVims().add(vim);
+ vim.setVimInfoType(VimInfo.VimInfoTypeEnum.OPENSTACK_V2_INFO);
+ OpenStackAccessInfoV2 accessInfo = new OpenStackAccessInfoV2();
+ accessInfo.setPassword("myPassword");
+ vim.setAccessInfo(accessInfo);
+ String serialize = new ApiClient().getJSON().serialize(req);
+ assertTrue(serialize.contains("myPassword"));
+ InstantiateVnfRequest deserialize = new ApiClient().getJSON().deserialize(serialize, InstantiateVnfRequest.class);
+ assertEquals(1, deserialize.getVims().size());
+ OPENSTACKV2INFO deserializedVim = (OPENSTACKV2INFO) deserialize.getVims().get(0);
+ assertEquals("myPassword", deserializedVim.getAccessInfo().getPassword());
+ }
+
+ /**
+ * test OpenStack v3 inheritence handling in serialization and deserialization
+ */
+ @Test
+ public void testOpenStackV3(){
+ InstantiateVnfRequest req = new InstantiateVnfRequest();
+ OPENSTACKV3INFO vim = new OPENSTACKV3INFO();
+ req.getVims().add(vim);
+ vim.setVimInfoType(VimInfo.VimInfoTypeEnum.OPENSTACK_V3_INFO);
+ OpenStackAccessInfoV3 accessInfo = new OpenStackAccessInfoV3();
+ accessInfo.setPassword("myPassword");
+ vim.setAccessInfo(accessInfo);
+ String serialize = new ApiClient().getJSON().serialize(req);
+ assertTrue(serialize.contains("myPassword"));
+ InstantiateVnfRequest deserialize = new ApiClient().getJSON().deserialize(serialize, InstantiateVnfRequest.class);
+ assertEquals(1, deserialize.getVims().size());
+ OPENSTACKV3INFO deserializedVim = (OPENSTACKV3INFO) deserialize.getVims().get(0);
+ assertEquals("myPassword", deserializedVim.getAccessInfo().getPassword());
+ }
+
+ /**
+ * test vCloud inheritence handling in serialization and deserialization
+ */
+ @Test
+ public void testVCloud(){
+ InstantiateVnfRequest req = new InstantiateVnfRequest();
+ VMWAREVCLOUDINFO vim = new VMWAREVCLOUDINFO();
+ req.getVims().add(vim);
+ vim.setVimInfoType(VimInfo.VimInfoTypeEnum.VMWARE_VCLOUD_INFO);
+ VCloudAccessInfo accessInfo = new VCloudAccessInfo();
+ accessInfo.setPassword("myPassword");
+ vim.setAccessInfo(accessInfo);
+ String serialize = new ApiClient().getJSON().serialize(req);
+ assertTrue(serialize.contains("myPassword"));
+ InstantiateVnfRequest deserialize = new ApiClient().getJSON().deserialize(serialize, InstantiateVnfRequest.class);
+ assertEquals(1, deserialize.getVims().size());
+ VMWAREVCLOUDINFO deserializedVim = (VMWAREVCLOUDINFO) deserialize.getVims().get(0);
+ assertEquals("myPassword", deserializedVim.getAccessInfo().getPassword());
+ }
+
+ /**
+ * test LCN serialization and deserialization
+ */
+ @Test
+ public void testLcn() throws Exception{
+ VnfLifecycleChangeNotification vnfLifecycleChangeNotification = new VnfLifecycleChangeNotification();
+ vnfLifecycleChangeNotification.setNotificationType(VnfNotificationType.VNFLIFECYCLECHANGENOTIFICATION);
+ vnfLifecycleChangeNotification.setVnfInstanceId("myId");
+ String serialize = new ApiClient().getJSON().serialize(vnfLifecycleChangeNotification);
+ VnfLifecycleChangeNotification deserialize = new ApiClient().getJSON().deserialize(serialize, VnfLifecycleChangeNotification.class);
+ assertEquals("myId", deserialize.getVnfInstanceId());
+ }
+
+ /**
+ * test arrays are not initialized to empty arrays
+ */
+ @Test
+ public void testArrayBehaviour() throws Exception{
+ VnfLifecycleChangeNotification vnfLifecycleChangeNotification = new VnfLifecycleChangeNotification();
+ vnfLifecycleChangeNotification.setNotificationType(VnfNotificationType.VNFLIFECYCLECHANGENOTIFICATION);
+ vnfLifecycleChangeNotification.setVnfInstanceId("myId");
+ String serialize = new ApiClient().getJSON().serialize(vnfLifecycleChangeNotification);
+ VnfLifecycleChangeNotification deserialize = new ApiClient().getJSON().deserialize(serialize, VnfLifecycleChangeNotification.class);
+ assertNull(deserialize.getAffectedVirtualLinks());
+ }
+
+}
diff --git a/nokiav2/pom.xml b/nokiav2/pom.xml
new file mode 100644
index 00000000..42adcf03
--- /dev/null
+++ b/nokiav2/pom.xml
@@ -0,0 +1,43 @@
+<?xml version="1.0"?>
+<!--
+ Copyright 2017 Nokia Corporation.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <parent>
+ <!--<groupId>org.onap.oparent</groupId>
+ <artifactId>oparent</artifactId>
+ <version>0.1.1</version>
+ -->
+<!-- FIXME this artifact is not available in nexus-->
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ </parent>
+ <modelVersion>4.0.0</modelVersion>
+ <groupId>org.onap.vfc.nfvo.driver.vnfm.svnfm.nokiav2</groupId>
+ <artifactId>vfc-nfvo-driver-vnfm-svnfm-nokiav2</artifactId>
+ <version>1.1.0-SNAPSHOT</version>
+ <packaging>pom</packaging>
+ <name>vfc-nfvo-driver-vnfm-svnfm-nokiav2</name>
+ <properties>
+ <jacoco.version>0.8.0</jacoco.version>
+ </properties>
+<modules>
+ <module>generatedapis</module>
+ <module>driver</module>
+ <module>driverwar</module>
+ <module>deployment</module>
+ </modules>
+</project>
diff --git a/pom.xml b/pom.xml
index 2b1a9b9e..ffe5bc6a 100644
--- a/pom.xml
+++ b/pom.xml
@@ -31,5 +31,6 @@
<module>zte</module>
<module>huawei</module>
<module>nokia</module>
+ <module>nokiav2</module>
</modules>
</project>
diff --git a/zte/vmanager/driver/interfaces/serializers.py b/zte/vmanager/driver/interfaces/serializers.py
new file mode 100644
index 00000000..eafe0939
--- /dev/null
+++ b/zte/vmanager/driver/interfaces/serializers.py
@@ -0,0 +1,435 @@
+# Copyright 2018 ZTE Corporation.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+from rest_framework import serializers
+
+
+class AdditionalParamSerializer(serializers.Serializer):
+ sdncontroller = serializers.CharField(
+ help_text="sdncontroller",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ NatIpRange = serializers.CharField(
+ help_text="NatIpRange",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ m6000_mng_ip = serializers.CharField(
+ help_text="m6000_mng_ip",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ externalPluginManageNetworkName = serializers.CharField(
+ help_text="externalPluginManageNetworkName",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ location = serializers.CharField(
+ help_text="location",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ externalManageNetworkName = serializers.CharField(
+ help_text="externalManageNetworkName",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ sfc_data_network = serializers.CharField(
+ help_text="sfc_data_network",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ externalDataNetworkName = serializers.CharField(
+ help_text="externalDataNetworkName",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ inputs = serializers.DictField(
+ help_text='inputs',
+ child=serializers.CharField(allow_blank=True),
+ required=False,
+ allow_null=True)
+
+
+class InstantiateVnfRequestSerializer(serializers.Serializer):
+ vnfInstanceName = serializers.CharField(
+ help_text="vnfInstanceName",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ vnfPackageId = serializers.CharField(
+ help_text="vnfPackageId",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ vnfDescriptorId = serializers.CharField(
+ help_text="vnfDescriptorId",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ additionalParam = AdditionalParamSerializer(
+ help_text="additionalParam",
+ required=True,
+ allow_null=True)
+
+
+class TerminateVnfRequestSerializer(serializers.Serializer):
+ terminationType = serializers.CharField(
+ help_text="terminationType",
+ required=True,
+ max_length=255,
+ allow_null=True)
+ gracefulTerminationTimeout = serializers.IntegerField(
+ help_text="gracefulTerminationTimeout",
+ default=120,
+ required=False)
+
+
+class VnfInfoSerializer(serializers.Serializer):
+ vnfStatus = serializers.CharField(
+ help_text="vnfStatus",
+ required=True,
+ max_length=255,
+ allow_null=True)
+
+
+class QueryVnfResponseSerializer(serializers.Serializer):
+ vnfInfo = VnfInfoSerializer(
+ help_text="vnfInfo",
+ required=True)
+
+
+class JobHistorySerializer(serializers.Serializer):
+ status = serializers.CharField(
+ help_text="Status of job",
+ required=True,
+ allow_null=False)
+ progress = serializers.IntegerField(
+ help_text="Progress of job",
+ required=True,
+ allow_null=False)
+ statusDescription = serializers.CharField(
+ help_text="Description of job",
+ required=False,
+ allow_null=True)
+ errorCode = serializers.CharField(
+ help_text="Error code of job",
+ required=False,
+ allow_blank=True)
+ responseId = serializers.IntegerField(
+ help_text="Response index of job",
+ required=True,
+ allow_null=False)
+
+
+class JobDescriptorSerializer(serializers.Serializer):
+ status = serializers.CharField(
+ help_text="Status of job",
+ required=True,
+ allow_null=False)
+ progress = serializers.IntegerField(
+ help_text="Progress of job",
+ required=True,
+ allow_null=False)
+ statusDescription = serializers.CharField(
+ help_text="Description of job",
+ required=False,
+ allow_null=True)
+ errorCode = serializers.CharField(
+ help_text="Error code of job",
+ required=False,
+ allow_blank=True)
+ responseId = serializers.IntegerField(
+ help_text="Response index of job",
+ required=True,
+ allow_null=False)
+ responseHistoryList = JobHistorySerializer(
+ help_text="History of job",
+ many=True)
+
+
+class JobQueryRespSerializer(serializers.Serializer):
+ jobId = serializers.CharField(
+ help_text="UUID of job",
+ required=True,
+ allow_null=False)
+ responseDescriptor = JobDescriptorSerializer(
+ help_text="Descriptor of job",
+ required=False)
+
+
+class GrantVmlistSerializer(serializers.Serializer):
+ VMNumber = serializers.CharField(
+ help_text="VMNumber",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ VMFlavor = serializers.CharField(
+ help_text="VMFlavor",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ vimid = serializers.CharField(
+ help_text="vimid",
+ max_length=255,
+ required=True,
+ allow_blank=True)
+ tenant = serializers.CharField(
+ help_text="tenant",
+ max_length=255,
+ required=False,
+ allow_blank=True)
+
+
+class GrantReqSerializer(serializers.Serializer):
+ nfvoid = serializers.CharField(
+ help_text="nfvoid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ vnfmid = serializers.CharField(
+ help_text="vnfmid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ vimid = serializers.CharField(
+ help_text="vimid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ tenant = serializers.CharField(
+ help_text="tenant",
+ max_length=255,
+ required=False,
+ allow_blank=True)
+ vnfinstanceid = serializers.CharField(
+ help_text="vnfinstanceid",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ operationright = serializers.CharField(
+ help_text="operationright",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ vmlist = GrantVmlistSerializer(
+ help_text='vmlist',
+ required=False,
+ many=True)
+ exvimidlist = serializers.ListSerializer(
+ help_text='exvimidlist',
+ child=serializers.CharField(allow_null=True),
+ required=False)
+
+
+class GrantRespSerializer(serializers.Serializer):
+ vimid = serializers.CharField(
+ help_text="vimid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ tenant = serializers.CharField(
+ help_text="tenant",
+ max_length=255,
+ required=True,
+ allow_null=True)
+
+
+class VMIDlistSerializer(serializers.Serializer):
+ VMID = serializers.CharField(
+ help_text="VMID",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ VMName = serializers.CharField(
+ help_text="VMName",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ vimid = serializers.CharField(
+ help_text="vimid",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ tenant = serializers.CharField(
+ help_text="tenant",
+ max_length=255,
+ required=False,
+ allow_null=True)
+
+
+class NotifyVmlistSerializer(serializers.Serializer):
+ VMNumber = serializers.CharField(
+ help_text="VMNumber",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ vdutype = serializers.CharField(
+ help_text="vdutype",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ VMFlavor = serializers.CharField(
+ help_text="VMFlavor",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ VMIDlist = serializers.ListSerializer(
+ help_text='VMIDlist',
+ child=VMIDlistSerializer(help_text='VMIDlist', required=True, allow_null=True),
+ required=False,
+ allow_null=True)
+
+
+class NotifyReqSerializer(serializers.Serializer):
+ nfvoid = serializers.CharField(
+ help_text="nfvoid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ vnfmid = serializers.CharField(
+ help_text="vnfmid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ vimid = serializers.CharField(
+ help_text="vimid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ timestamp = serializers.CharField(
+ help_text="timestamp",
+ max_length=255,
+ required=False,
+ allow_blank=True)
+ vnfinstanceid = serializers.CharField(
+ help_text="vnfinstanceid",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ eventtype = serializers.CharField(
+ help_text="eventtype",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ vmlist = NotifyVmlistSerializer(
+ help_text='vmlist',
+ required=False,
+ many=True)
+ extension = serializers.DictField(
+ help_text="extension",
+ child=serializers.DictField(allow_null=True),
+ required=False,
+ allow_null=True)
+ affectedcp = serializers.ListSerializer(
+ help_text='affectedcp',
+ child=serializers.DictField(allow_null=True),
+ required=False)
+ affectedvirtuallink = serializers.ListSerializer(
+ help_text='affectedvirtuallink',
+ child=serializers.DictField(allow_null=True),
+ required=False)
+
+
+class ScaleReqSerializer(serializers.Serializer):
+ type = serializers.CharField(
+ help_text="type",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ aspectId = serializers.CharField(
+ help_text="aspectId",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ numberOfSteps = serializers.CharField(
+ help_text="numberOfSteps",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ additionalParam = serializers.DictField(
+ help_text="additionalParam",
+ child=serializers.DictField(allow_null=True),
+ required=False,
+ allow_null=True)
+
+
+class AffectedvmSerializer(serializers.Serializer):
+ extention = serializers.CharField(
+ help_text="extention",
+ max_length=255,
+ required=True,
+ allow_blank=True)
+ vmid = serializers.CharField(
+ help_text="vmid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ changtype = serializers.CharField(
+ help_text="changtype",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ vduid = serializers.CharField(
+ help_text="vduid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ vmname = serializers.CharField(
+ help_text="vmname",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ flavour = serializers.DictField(
+ help_text="flavour",
+ child=serializers.CharField(allow_blank=True),
+ required=False,
+ allow_null=True)
+
+
+class HealReqSerializer(serializers.Serializer):
+ action = serializers.CharField(
+ help_text="action",
+ max_length=255,
+ required=True,
+ allow_null=False)
+ lifecycleoperation = serializers.CharField(
+ help_text="lifecycleoperation",
+ max_length=255,
+ required=True,
+ allow_null=False)
+ isgrace = serializers.CharField(
+ help_text="isgrace",
+ max_length=255,
+ required=False,
+ allow_null=True)
+ affectedvm = serializers.ListSerializer(
+ help_text='affectedvm',
+ child=AffectedvmSerializer(help_text='affectedvm', required=True, allow_null=True),
+ required=True,
+ allow_null=True)
+
+
+class InstScaleHealRespSerializer(serializers.Serializer):
+ jobId = serializers.CharField(
+ help_text="jobid",
+ max_length=255,
+ required=True,
+ allow_null=True)
+ vnfInstanceId = serializers.CharField(
+ help_text="nfInstanceId",
+ max_length=255,
+ required=True,
+ allow_null=True)
diff --git a/zte/vmanager/driver/interfaces/tests.py b/zte/vmanager/driver/interfaces/tests.py
index d46f9a73..c0c062c8 100644
--- a/zte/vmanager/driver/interfaces/tests.py
+++ b/zte/vmanager/driver/interfaces/tests.py
@@ -148,10 +148,14 @@ class InterfacesTest(TestCase):
}
}
- response = self.client.post("/api/ztevnfmdriver/v1/ztevnfmid/vnfs",
- data=json.dumps(req_data), content_type="application/json")
- self.assertEqual(str(status.HTTP_200_OK), response.status_code)
- expect_resp_data = {"jobId": "NF-CREATE-8-b384535c-9f45-11e6-8749-fa163e91c2f9", "vnfInstanceId": "8"}
+ response = self.client.post(
+ "/api/ztevnfmdriver/v1/ztevnfmid/vnfs",
+ data=json.dumps(req_data),
+ content_type="application/json")
+ self.assertEqual(status.HTTP_200_OK, response.status_code)
+ expect_resp_data = {
+ "jobId": "NF-CREATE-8-b384535c-9f45-11e6-8749-fa163e91c2f9",
+ "vnfInstanceId": "8"}
self.assertEqual(expect_resp_data, response.data)
@mock.patch.object(restcall, 'call_req')
@@ -172,10 +176,14 @@ class InterfacesTest(TestCase):
r2 = [0, json.JSONEncoder().encode({"vnfInstanceId": "1", "jobId": "1"}), "200"]
mock_call_req.side_effect = [r1, r2]
+ req_data = {
+ "terminationType": "GRACEFUL",
+ "gracefulTerminationTimeout": 120
+ }
+ response = self.client.post(
+ "/api/ztevnfmdriver/v1/ztevnfmid/vnfs/vbras_innstance_id/terminate", data=req_data)
- response = self.client.post("/api/ztevnfmdriver/v1/ztevnfmid/vnfs/vbras_innstance_id/terminate")
-
- self.assertEqual(str(status.HTTP_200_OK), response.status_code)
+ self.assertEqual(status.HTTP_200_OK, response.status_code)
expect_resp_data = {"jobId": "1", "vnfInstanceId": "1"}
self.assertEqual(expect_resp_data, response.data)
@@ -198,9 +206,10 @@ class InterfacesTest(TestCase):
r2 = [0, json.JSONEncoder().encode({"vnfinstancestatus": "1"}), "200"]
mock_call_req.side_effect = [r1, r2]
- response = self.client.get("/api/ztevnfmdriver/v1/ztevnfmid/vnfs/vbras_innstance_id")
+ response = self.client.get(
+ "/api/ztevnfmdriver/v1/ztevnfmid/vnfs/vbras_innstance_id")
- self.assertEqual(str(status.HTTP_200_OK), response.status_code)
+ self.assertEqual(status.HTTP_200_OK, response.status_code)
expect_resp_data = {"vnfInfo": {"vnfStatus": "1"}}
self.assertEqual(expect_resp_data, response.data)
@@ -222,37 +231,32 @@ class InterfacesTest(TestCase):
"description": ""
}
resp_body = {
- "responsedescriptor": {
+ "responseDescriptor": {
"status": "processing",
- "responsehistorylist": [
+ "responseHistoryList": [
{
"status": "error",
"progress": 255,
- "errorcode": "",
- "responseid": 20,
- "statusdescription": "'JsonParser' object has no attribute 'parser_info'"
- }
- ],
- "responseid": 21,
- "errorcode": "",
+ "errorCode": "",
+ "responseId": 20,
+ "statusDescription": "'JsonParser' object has no attribute 'parser_info'"}],
+ "responseId": 21,
+ "errorCode": "",
"progress": 40,
- "statusdescription": "Create nf apply resource failed"
- },
- "jobid": "NF-CREATE-11-ec6c2f2a-9f48-11e6-9405-fa163e91c2f9"
- }
+ "statusDescription": "Create nf apply resource failed"},
+ "jobId": "NF-CREATE-11-ec6c2f2a-9f48-11e6-9405-fa163e91c2f9"}
r1 = [0, json.JSONEncoder().encode(vnfm_info), '200']
r2 = [0, json.JSONEncoder().encode(resp_body), '200']
mock_call_req.side_effect = [r1, r2]
- response = self.client.get("/api/ztevnfmdriver/v1/{vnfmid}/jobs/{jobid}?responseId={responseId}".format(
- vnfmid=vnfm_info["vnfmId"],
- jobid=resp_body["jobid"],
- responseId=resp_body["responsedescriptor"]["responseid"])
- )
+ response = self.client.get(
+ "/api/ztevnfmdriver/v1/{vnfmid}/jobs/{jobid}?responseId={responseId}".format(
+ vnfmid=vnfm_info["vnfmId"],
+ jobid=resp_body["jobId"],
+ responseId=resp_body["responseDescriptor"]["responseId"]))
- self.assertEqual(str(status.HTTP_200_OK), response.status_code)
+ self.assertEqual(status.HTTP_200_OK, response.status_code)
- expect_resp_data = resp_body
- self.assertDictEqual(expect_resp_data, response.data)
+ self.assertDictEqual(resp_body, response.data)
@mock.patch.object(restcall, 'call_req')
def test_grantvnf_005(self, mock_call_req):
@@ -278,21 +282,26 @@ class InterfacesTest(TestCase):
"operationright": "0",
"vmlist": [
{
- "vmflavor": "SMP",
- "vmnumber": "3"
- },
- {
- "vmflavor": "CMP",
- "vmnumber": "3"
+ "VMNumber": 1,
+ "VMFlavor": "VDU_S_CDB_51",
+ "vimid": "",
+ "tenant": ""
+ }, {
+ "VMNumber": 1,
+ "VMFlavor": "VDU_M_SLB_42",
+ "vimid": "",
+ "tenant": ""
}
]
}
mock_call_req.return_value = ret
- response = self.client.put("/api/ztevnfmdriver/v1/resource/grant",
- data=json.dumps(req_data), content_type='application/json')
+ response = self.client.put(
+ "/api/ztevnfmdriver/v1/resource/grant",
+ data=json.dumps(req_data),
+ content_type='application/json')
- self.assertEqual(str(status.HTTP_201_CREATED), response.status_code)
+ self.assertEqual(status.HTTP_201_CREATED, response.status_code)
expect_resp_data = {
"vimid": "516cee95-e8ca-4d26-9268-38e343c2e31e",
@@ -334,17 +343,22 @@ class InterfacesTest(TestCase):
}), "200"]
mock_call_req.side_effect = [r1]
- response = self.client.post("/api/ztevnfmdriver/v1/vnfs/lifecyclechangesnotification",
- data=json.dumps(notify_req_data), content_type='application/json')
+ response = self.client.post(
+ "/api/ztevnfmdriver/v1/vnfs/lifecyclechangesnotification",
+ data=json.dumps(notify_req_data),
+ content_type='application/json')
- self.assertEqual(str(status.HTTP_200_OK), response.status_code)
+ self.assertEqual(status.HTTP_200_OK, response.status_code)
expect_resp_data = None
self.assertEqual(expect_resp_data, response.data)
@mock.patch.object(restcall, 'call_req')
def test_scale(self, mock_call_req):
- job_info = {"jobid": "801", "nfInstanceId": "101"}
+ job_info = {
+ "jobId": "801",
+ "vnfInstanceId": "101"
+ }
vnfm_info = {
"userName": "admin",
"vendor": "ZTE",
@@ -418,16 +432,18 @@ class InterfacesTest(TestCase):
}
}
- response = self.client.post("/api/ztevnfmdriver/v1/100/vnfs/101/scale",
- data=json.dumps(scale_vnf_data), content_type='application/json')
- self.assertEqual(str(status.HTTP_202_ACCEPTED), response.status_code)
+ response = self.client.post(
+ "/api/ztevnfmdriver/v1/100/vnfs/101/scale",
+ data=json.dumps(scale_vnf_data),
+ content_type='application/json')
+ self.assertEqual(status.HTTP_202_ACCEPTED, response.status_code)
self.assertDictEqual(job_info, response.data)
@mock.patch.object(restcall, 'call_req')
def test_heal(self, mock_call_req):
job_info = {
- "jobid": "12234455",
- "nfInstanceId": "10144445666"
+ "jobId": "12234455",
+ "vnfInstanceId": "10144445666"
}
vnfm_info = {
"userName": "admin",
@@ -464,730 +480,434 @@ class InterfacesTest(TestCase):
'isgrace': 'force'
}
- response = self.client.post("/api/ztevnfmdriver/v1/200/vnfs/201/heal",
- data=json.dumps(heal_vnf_data), content_type='application/json')
+ response = self.client.post("/api/ztevnfmdriver/v1/200/vnfs/201/heal", data=json.dumps(heal_vnf_data),
+ content_type='application/json')
- self.assertEqual(str(status.HTTP_202_ACCEPTED), response.status_code)
+ self.assertEqual(status.HTTP_202_ACCEPTED, response.status_code)
self.assertDictEqual(job_info, response.data)
-notify_req_data = {
- "vnfinstanceid": "1",
- "nfvoid": "3",
- "extension": {
- "openo_notification": {
- "status": "finished",
- "affectedService": [
-
- ],
- "affectedVnfc": [
- {
- "changeType": "added",
- "computeResource": {
- "resourceId": "e8ccc55a-3ebb-4e46-8260-dc4a1646ef4f",
- "tenant": "ZTE_ONAP_PRO",
- "vimId": "vmware_vio",
- "resourceName": "ZTE_xGW_39_CDB_1"
- },
- "storageResource": [
-
- ],
- "vnfcInstanceId": "17502154-c5bf-11e7-904d-fa163eee1ffe",
- "vduType": "CDB",
- "vduId": "VDU_S_CDB_51"
- },
- {
- "changeType": "added",
- "computeResource": {
- "resourceId": "a9dd6a73-76ee-4d07-9554-08f14c17261f",
- "tenant": "ZTE_ONAP_PRO",
- "vimId": "vmware_vio",
- "resourceName": "ZTE_xGW_39_SLB_1"
- },
- "storageResource": [
-
- ],
- "vnfcInstanceId": "1750d540-c5bf-11e7-904d-fa163eee1ffe",
- "vduType": "SLB",
- "vduId": "VDU_M_SLB_42"
- }
- ],
- "nfvoInstanceId": "3",
- "affectedVirtualLink": [
- {
- "changeType": "added",
- "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe",
- "networkResource": {
- "resourceId": "c55e0788-3683-48a1-b88a-a0cb5e05bd44",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_MGT_NET39"
- },
- "virtualLinkDescId": "ZTE_VGW_MGT_NET39_virtualLink",
- "tenant": "ZTE_ONAP_PRO",
- "subnetworkResource": {
- "resourceId": "33c8a03d-00c9-4c57-a348-26dae462b473",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_MGT_NET39_s"
- }
- },
- {
- "changeType": "added",
- "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe",
- "networkResource": {
- "resourceId": "2d22b6e4-340b-45a8-8757-5206aa056b92",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_SERVICE_NET39"
- },
- "virtualLinkDescId": "ZTE_VGW_SERVICE_NET39_virtualLink",
- "tenant": "ZTE_ONAP_PRO",
- "subnetworkResource": {
- "resourceId": "2ea2acc0-a4ed-44f8-9d31-9cdc9e3ebe62",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_SERVICE_NET39_s"
- }
- }
- ],
- "affectedVirtualStorage": [
-
- ],
- "jobId": "",
- "affectedcapacity": {
- "vcp": "72",
- "vm": "9",
- "localStorage": "0",
- "sharedStorage": "288",
- "vMemory": "233472",
- "port": "27"
- },
- "additionalParam": {
- "vmList": [
- {
- "vmName": "ZTE_xGW_39_CDB_1",
- "vduId": "VDU_S_CDB_51"
- },
- {
- "vmName": "ZTE_xGW_39_CDB_2",
- "vduId": "VDU_S_CDB_51"
- },
- {
- "vmName": "ZTE_xGW_39_SLB_1",
- "vduId": "VDU_M_SLB_42"
- },
- {
- "vmName": "ZTE_xGW_39_SLB_2",
- "vduId": "VDU_M_SLB_42"
- },
- {
- "vmName": "ZTE_xGW_39_GSU_1",
- "vduId": "VDU_M_GSU_22"
- },
- {
- "vmName": "ZTE_xGW_39_GSU_2",
- "vduId": "VDU_M_GSU_22"
- },
- {
- "vmName": "ZTE_xGW_39_MPU_1",
- "vduId": "VDU_M_MPU_12"
- },
- {
- "vmName": "ZTE_xGW_39_PFU_1",
- "vduId": "VDU_M_PFU_32"
- },
- {
- "vmName": "ZTE_xGW_39_PFU_2",
- "vduId": "VDU_M_PFU_32"
- }
- ]
- },
- "nfInstanceId": "1",
- "affectedCp": [
- {
- "changeType": "added",
- "cPInstanceId": "175767d4-c5bf-11e7-904d-fa163eee1ffe",
- "ownertype": 3,
- "cpdId": "CP_NO_0_CDB_ZTE_VGW_MGT_NET39",
- "portResource": {
- "resourceId": "3296b6d8-ebca-4d33-98f4-68d1bc63a3d0",
- "tenant": "ZTE_ONAP_PRO",
- "vimId": "vmware_vio",
- "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1"
- },
- "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
- "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
- "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe"
- },
- {
- "changeType": "added",
- "cPInstanceId": "1758181e-c5bf-11e7-904d-fa163eee1ffe",
- "ownertype": 3,
- "cpdId": "CP_NO_1_CDB_ZTE_VGW_SERVICE_NET39",
- "portResource": {
- "resourceId": "5e277a18-94de-469a-a336-2c01ab46387e",
- "tenant": "ZTE_ONAP_PRO",
- "vimId": "vmware_vio",
- "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2"
- },
- "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2",
- "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
- "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe"
- }
- ],
- "vnfdmodule": {
- "volume_storages": [
-
- ],
- "inputs": {
-
- },
- "vdus": [
- {
- "volume_storages": [
-
- ],
- "description": "CDB",
- "vdu_id": "VDU_S_CDB_51",
- "local_storages": [
- "local_disk_root_10GB",
- "local_disk_ephemeral_14GB"
- ],
- "nfv_compute": {
- "flavor_extra_specs": {
- "hw:cpu_policy": "dedicated",
- "hw:mem_page_size": "large",
- "hw:numa_nodes": 1,
- "hw:cpu_max_sockets": 1
- },
- "mem_size": 8192,
- "num_cpus": 2
- },
- "artifacts": [
-
- ],
- "dependencies": [
-
- ],
- "vls": [
- "ZTE_VGW_MGT_NET39_virtualLink",
- "ZTE_VGW_SERVICE_NET39_virtualLink"
- ],
- "image_file": "image_51",
- "cps": [
- "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
- "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2"
- ],
- "properties": {
- "key_vd": True,
- "support_scaling": True,
- "vdu_type": "CDB",
- "name": "ZTE_xGW_39_CDB_1",
- "storage_policy": "Share_Service",
- "inject_network_address": True,
- "is_predefined": False,
- "location_info": {
- "vimid": "",
- "availability_zone": "",
- "vdc": "OG_OrganizationDC",
- "host": "",
- "tenant": "",
- "vapp": "xgw"
- },
- "use_shared_vm": False,
- "inject_data_list": [
-
- ],
- "allow_scale_updown": True,
- "action": "ADD",
- "watchdog": {
-
- },
- "template_id": 51,
- "manual_scale_select_vim": False,
- "config_drive": True
- }
- },
- {
- "volume_storages": [
-
- ],
- "description": "SLB",
- "vdu_id": "VDU_M_SLB_42",
- "local_storages": [
- "local_disk_root_10GB",
- "local_disk_ephemeral_14GB"
- ],
- "nfv_compute": {
- "flavor_extra_specs": {
- "hw:cpu_policy": "dedicated",
- "hw:mem_page_size": "large",
- "hw:numa_nodes": 1,
- "hw:cpu_max_sockets": 1
- },
- "mem_size": 24576,
- "num_cpus": 8
- },
- "artifacts": [
-
- ],
- "dependencies": [
-
- ],
- "vls": [
- "ZTE_VGW_MGT_NET39_virtualLink",
- "ZTE_VGW_SERVICE_NET39_virtualLink",
- "ZTE_NET39_virtualLink",
- "ZTE_VGW_GTP_NET39_virtualLink"
- ],
- "image_file": "image_51",
- "cps": [
- "CP_ZTE_xGW_39_SLB_1_ZTE_VGW_MGT_NET39_su1",
- "CP_ZTE_xGW_39_SLB_1_ZTE_VGW_SERVICE_NET39_su2",
- "CP_ZTE_xGW_39_SLB_1_zte-net-subnet393",
- "CP_ZTE_xGW_39_SLB_1_ZTE_VGW_GTP_NET39_su4"
- ],
- "properties": {
- "key_vd": True,
- "support_scaling": False,
- "vdu_type": "SLB",
- "name": "ZTE_xGW_39_SLB_1",
- "storage_policy": "Share_Service",
- "inject_network_address": True,
- "is_predefined": False,
- "location_info": {
- "vimid": "",
- "availability_zone": "",
- "vdc": "OG_OrganizationDC",
- "host": "",
- "tenant": "",
- "vapp": "xgw"
- },
- "use_shared_vm": False,
- "inject_data_list": [
-
- ],
- "allow_scale_updown": True,
- "action": "ADD",
- "watchdog": {
-
- },
- "template_id": 42,
- "manual_scale_select_vim": False,
- "config_drive": True
- }
- }
- ],
- "vcloud": [
-
- ],
- "extvirtuallink": "",
- "server_groups": [
-
- ],
- "image_files": [
- {
- "properties": {
- "vendor": "zte",
- "name": "ZXUN_xGW_CGSL_QCOW2_OP_V6.17.10.B17.ova",
- "image_extra_specs": {
-
- },
- "disk_format": "vmdk",
- "file_url": "SoftwareImages/ZXUN-xGW-CGSL-QCOW2-V6.17.10.B17-image.tar.gz",
- "container_type": "bare",
- "version": "V6.17.10.B17.ova"
- },
- "image_file_id": "image_51",
- "description": "xgw image file"
- }
- ],
- "routers": [
-
- ],
- "local_storages": [
- {
- "local_storage_id": "local_disk_ephemeral_38GB",
- "description": "local_disk_ephemeral_38GB",
- "properties": {
- "disk_type": "ephemeral",
- "size": 38
- }
- },
- {
- "local_storage_id": "local_disk_root_10GB",
- "description": "local_disk_root_10GB",
- "properties": {
- "disk_type": "root",
- "size": 10
- }
- },
- {
- "local_storage_id": "local_disk_ephemeral_14GB",
- "description": "local_disk_ephemeral_14GB",
- "properties": {
- "disk_type": "ephemeral",
- "size": 14
- }
- }
- ],
- "vnf_flavours": [
-
- ],
- "vnf_exposed": {
- "external_cps": [
- {
- "key_name": "ZTE_NET39_virtualLink",
- "cpd_id": "CP_NO_3_PFU_ZTE_NET39"
- },
- {
- "key_name": "ZTE_NET39_virtualLink1",
- "cpd_id": "CP_NO_2_PFU_ZTE_NET39"
- },
- {
- "key_name": "ZTE_VGW_GTP_NET39_virtualLink",
- "cpd_id": "CP_NO_3_SLB_ZTE_VGW_GTP_NET39"
- },
- {
- "key_name": "ZTE_NET39_virtualLink2",
- "cpd_id": "CP_NO_2_SLB_ZTE_NET39"
- },
- {
- "key_name": "provider-zte_virtualLink",
- "cpd_id": "CP_NO_2_MPU_provider-zte"
- }
- ],
- "forward_cps": [
- {
- "key_name": "ZTE_VGW_GTP_NET39_forwarder",
- "cpd_id": "CP_NO_3_SLB_ZTE_VGW_GTP_NET39"
- },
- {
- "key_name": "ZTE_NET39_forwarder1",
- "cpd_id": "CP_NO_2_PFU_ZTE_NET39"
- },
- {
- "key_name": "ZTE_NET39_forwarder2",
- "cpd_id": "CP_NO_3_PFU_ZTE_NET39"
- },
- {
- "key_name": "provider-zte_forwarder",
- "cpd_id": "CP_NO_2_MPU_provider-zte"
- },
- {
- "key_name": "ZTE_NET39_forwarder",
- "cpd_id": "CP_NO_2_SLB_ZTE_NET39"
- }
- ]
- },
- "reserved_total": {
- "portnum": 27,
- "vcpunum": 72,
- "memorysize": 233472,
- "shdsize": 288,
- "isreserve": 0,
- "vmnum": 9
- },
- "policies": [
- {
- "scaling": [
- {
- "description": "zte vgw vnf policy",
- "policy_id": "Policy_1",
- "targets": [
- "VDU_S_CDB_51",
- "VDU_M_CDB_52",
- "VDU_M_SLB_42",
- "VDU_M_GSU_22",
- "VDU_M_MPU_12",
- "VDU_L_MPU_13",
- "VDU_M_PFU_32",
- "VDU_L_PFU_33"
- ],
- "properties": {
- "policy_file": "Policies/zte-vcn-vnf-policy.xml"
- }
- }
- ],
- "healing": [
-
- ]
- }
- ],
- "plugins": [
-
- ],
- "services": [
-
- ],
- "vcenter": [
-
- ],
- "cps": [
- {
- "vl_id": "ZTE_VGW_MGT_NET39_virtualLink",
- "description": "ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_s",
- "vdu_id": "VDU_S_CDB_51",
- "properties": {
- "service_port_created": False,
- "name": "ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_s",
- "allowed_address_pairs": [
-
- ],
- "bandwidth": 0,
- "is_virtual": False,
- "guest_os_mt": 1400,
- "vnic_type": "normal",
- "floating_ip_address": {
-
- },
- "mac_address": "",
- "port_security_enabled": False,
- "ip_address": "192.168.39.247",
- "order": 1,
- "security_groups": [
-
- ],
- "bond": "none"
- },
- "cp_id": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
- "cpd_id": "CP_NO_0_CDB_ZTE_VGW_MGT_NET39"
- },
- {
- "vl_id": "ZTE_VGW_SERVICE_NET39_virtualLink",
- "description": "ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_s",
- "vdu_id": "VDU_S_CDB_51",
- "properties": {
- "service_port_created": False,
- "name": "ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_s",
- "allowed_address_pairs": [
-
- ],
- "bandwidth": 0,
- "is_virtual": False,
- "guest_os_mt": 1400,
- "vnic_type": "normal",
- "floating_ip_address": {
-
- },
- "mac_address": "",
- "port_security_enabled": False,
- "ip_address": "192.168.40.247",
- "order": 2,
- "security_groups": [
-
- ],
- "bond": "none"
- },
- "cp_id": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2",
- "cpd_id": "CP_NO_1_CDB_ZTE_VGW_SERVICE_NET39"
- }
- ],
- "vls": [
- {
- "route_external": False,
- "route_id": "",
- "vl_id": "ZTE_VGW_MGT_NET39_virtualLink",
- "description": "ZTE_VGW_MGT_NET39_s",
- "properties": {
- "gateway_ip": "",
- "vendor": "ZTE",
- "name": "ZTE_VGW_MGT_NET39_s",
- "location_info": {
- "vdc": "OG_OrganizationDC",
- "vimid": 1,
- "tenant": "",
- "vapp": "xgw"
- },
- "start_ip": "",
- "segmentation_id": "142",
- "dns_nameservers": [
-
- ],
- "vds_name": "",
- "mt": 1400,
- "is_predefined": True,
- "ip_version": 4,
- "netmask": "255.255.255.0",
- "end_ip": "",
- "host_routes": [
-
- ],
- "vlan_transparent": False,
- "physical_network": "physnet1",
- "cidr": "192.168.39.0/24",
- "dhcp_enabled": False,
- "network_name": "ZTE_VGW_MGT_NET39",
- "network_type": "vlan"
- }
- },
- {
- "route_external": False,
- "route_id": "",
- "vl_id": "ZTE_VGW_SERVICE_NET39_virtualLink",
- "description": "ZTE_VGW_SERVICE_NET39_s",
- "properties": {
- "gateway_ip": "",
- "vendor": "ZTE",
- "name": "ZTE_VGW_SERVICE_NET39_s",
- "location_info": {
- "vdc": "OG_OrganizationDC",
- "vimid": 1,
- "tenant": "",
- "vapp": "xgw"
- },
- "start_ip": "",
- "segmentation_id": "128",
- "dns_nameservers": [
-
- ],
- "vds_name": "",
- "mt": 1400,
- "is_predefined": True,
- "ip_version": 4,
- "netmask": "255.255.255.0",
- "end_ip": "",
- "host_routes": [
-
- ],
- "vlan_transparent": False,
- "physical_network": "physnet1",
- "cidr": "192.168.40.0/24",
- "dhcp_enabled": False,
- "network_name": "ZTE_VGW_SERVICE_NET39",
- "network_type": "vlan"
- }
- }
- ],
- "element_groups": [
-
- ],
- "metadata": {
- "plugin_info": "cn_plugin_3.0",
- "vendor": "ZTE",
- "is_shared": False,
- "adjust_vnf_capacity": True,
- "paas_project": "",
- "description": "VMware",
- "vnf_extend_type": "driver",
- "domain_type": "CN",
- "resview": "dync",
- "script_info": "",
- "service_category": "EPC",
- "version": "ZTE",
- "vnf_type": "SAE-GW",
- "cross_dc": False,
- "vmnumber_overquota_alarm": True,
- "vnfd_version": "V00000001",
- "id": "NFAR-ZTE-40-ZTE",
- "name": 40
- }
- },
- "operation": "instantiate",
- "vnfmInstanceId": "31f8934e-c785-4fa5-9205-c5f374ada982"
- }
- },
- "vimid": "vmware_vio",
- "timestamp": "20171110105828",
- "affectedcp": [
- {
- "changeType": "added",
- "cPInstanceId": "175767d4-c5bf-11e7-904d-fa163eee1ffe",
- "ownertype": 3,
- "cpdId": "CP_NO_0_CDB_ZTE_VGW_MGT_NET39",
- "portResource": {
- "resourceId": "3296b6d8-ebca-4d33-98f4-68d1bc63a3d0",
- "tenant": "ZTE_ONAP_PRO",
- "vimId": "vmware_vio",
- "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1"
- },
- "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
- "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
- "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe"
- },
- {
- "changeType": "added",
- "cPInstanceId": "1758181e-c5bf-11e7-904d-fa163eee1ffe",
- "ownertype": 3,
- "cpdId": "CP_NO_1_CDB_ZTE_VGW_SERVICE_NET39",
- "portResource": {
- "resourceId": "5e277a18-94de-469a-a336-2c01ab46387e",
- "tenant": "ZTE_ONAP_PRO",
- "vimId": "vmware_vio",
- "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2"
- },
- "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2",
- "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
- "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe"
- }
- ],
- "vmlist": [
- {
- "VMNumber": 1,
- "vdutype": "CDB",
- "VMFlavor": "VDU_S_CDB_51",
- "VMIDlist": [
- {
- "VMID": "e8ccc55a-3ebb-4e46-8260-dc4a1646ef4f",
- "VMName": "ZTE_xGW_39_CDB_1",
- "vimid": "vmware_vio",
- "tenant": "ZTE_ONAP_PRO"
- }
- ]
- },
- {
- "VMNumber": 1,
- "vdutype": "SLB",
- "VMFlavor": "VDU_M_SLB_42",
- "VMIDlist": [
- {
- "VMID": "a9dd6a73-76ee-4d07-9554-08f14c17261f",
- "VMName": "ZTE_xGW_39_SLB_1",
- "vimid": "vmware_vio",
- "tenant": "ZTE_ONAP_PRO"
- }
- ]
- }
- ],
- "EventType": 1,
- "vnfmid": "31f8934e-c785-4fa5-9205-c5f374ada982",
- "affectedvirtuallink ": [
- {
- "changeType": "added",
- "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe",
- "networkResource": {
- "resourceId": "c55e0788-3683-48a1-b88a-a0cb5e05bd44",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_MGT_NET39"
- },
- "virtualLinkDescId": "ZTE_VGW_MGT_NET39_virtualLink",
- "tenant": "ZTE_ONAP_PRO",
- "subnetworkResource": {
- "resourceId": "33c8a03d-00c9-4c57-a348-26dae462b473",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_MGT_NET39_s"
- }
- },
- {
- "changeType": "added",
- "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe",
- "networkResource": {
- "resourceId": "2d22b6e4-340b-45a8-8757-5206aa056b92",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_SERVICE_NET39"
- },
- "virtualLinkDescId": "ZTE_VGW_SERVICE_NET39_virtualLink",
- "tenant": "ZTE_ONAP_PRO",
- "subnetworkResource": {
- "resourceId": "2ea2acc0-a4ed-44f8-9d31-9cdc9e3ebe62",
- "tenant": None,
- "vimId": "vmware_vio",
- "resourceName": "ZTE_VGW_SERVICE_NET39_s"
- }
- }
- ]
-}
+notify_req_data = {"vnfinstanceid": "1",
+ "nfvoid": "3",
+ "extension": {"openo_notification": {"status": "finished",
+ "affectedService": [],
+ "affectedVnfc": [{"changeType": "added",
+ "computeResource": {"resourceId": "e8ccc55a-3ebb-4e46-8260-dc4a1646ef4f",
+ "tenant": "ZTE_ONAP_PRO",
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_xGW_39_CDB_1"},
+ "storageResource": [],
+ "vnfcInstanceId": "17502154-c5bf-11e7-904d-fa163eee1ffe",
+ "vduType": "CDB",
+ "vduId": "VDU_S_CDB_51"},
+ {"changeType": "added",
+ "computeResource": {"resourceId": "a9dd6a73-76ee-4d07-9554-08f14c17261f",
+ "tenant": "ZTE_ONAP_PRO",
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_xGW_39_SLB_1"},
+ "storageResource": [],
+ "vnfcInstanceId": "1750d540-c5bf-11e7-904d-fa163eee1ffe",
+ "vduType": "SLB",
+ "vduId": "VDU_M_SLB_42"}],
+ "nfvoInstanceId": "3",
+ "affectedVirtualLink": [{"changeType": "added",
+ "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe",
+ "networkResource": {"resourceId": "c55e0788-3683-48a1-b88a-a0cb5e05bd44",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_MGT_NET39"},
+ "virtualLinkDescId": "ZTE_VGW_MGT_NET39_virtualLink",
+ "tenant": "ZTE_ONAP_PRO",
+ "subnetworkResource": {"resourceId": "33c8a03d-00c9-4c57-a348-26dae462b473",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_MGT_NET39_s"}},
+ {"changeType": "added",
+ "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe",
+ "networkResource": {"resourceId": "2d22b6e4-340b-45a8-8757-5206aa056b92",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_SERVICE_NET39"},
+ "virtualLinkDescId": "ZTE_VGW_SERVICE_NET39_virtualLink",
+ "tenant": "ZTE_ONAP_PRO",
+ "subnetworkResource": {"resourceId": "2ea2acc0-a4ed-44f8-9d31-9cdc9e3ebe62",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_SERVICE_NET39_s"}}],
+ "affectedVirtualStorage": [],
+ "jobId": "",
+ "affectedcapacity": {"vcp": "72",
+ "vm": "9",
+ "localStorage": "0",
+ "sharedStorage": "288",
+ "vMemory": "233472",
+ "port": "27"},
+ "additionalParam": {"vmList": [{"vmName": "ZTE_xGW_39_CDB_1",
+ "vduId": "VDU_S_CDB_51"},
+ {"vmName": "ZTE_xGW_39_CDB_2",
+ "vduId": "VDU_S_CDB_51"},
+ {"vmName": "ZTE_xGW_39_SLB_1",
+ "vduId": "VDU_M_SLB_42"},
+ {"vmName": "ZTE_xGW_39_SLB_2",
+ "vduId": "VDU_M_SLB_42"},
+ {"vmName": "ZTE_xGW_39_GSU_1",
+ "vduId": "VDU_M_GSU_22"},
+ {"vmName": "ZTE_xGW_39_GSU_2",
+ "vduId": "VDU_M_GSU_22"},
+ {"vmName": "ZTE_xGW_39_MPU_1",
+ "vduId": "VDU_M_MPU_12"},
+ {"vmName": "ZTE_xGW_39_PFU_1",
+ "vduId": "VDU_M_PFU_32"},
+ {"vmName": "ZTE_xGW_39_PFU_2",
+ "vduId": "VDU_M_PFU_32"}]},
+ "nfInstanceId": "1",
+ "affectedCp": [{"changeType": "added",
+ "cPInstanceId": "175767d4-c5bf-11e7-904d-fa163eee1ffe",
+ "ownertype": 3,
+ "cpdId": "CP_NO_0_CDB_ZTE_VGW_MGT_NET39",
+ "portResource": {"resourceId": "3296b6d8-ebca-4d33-98f4-68d1bc63a3d0",
+ "tenant": "ZTE_ONAP_PRO",
+ "vimId": "vmware_vio",
+ "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1"},
+ "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
+ "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
+ "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe"},
+ {"changeType": "added",
+ "cPInstanceId": "1758181e-c5bf-11e7-904d-fa163eee1ffe",
+ "ownertype": 3,
+ "cpdId": "CP_NO_1_CDB_ZTE_VGW_SERVICE_NET39",
+ "portResource": {"resourceId": "5e277a18-94de-469a-a336-2c01ab46387e",
+ "tenant": "ZTE_ONAP_PRO",
+ "vimId": "vmware_vio",
+ "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2"},
+ "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2",
+ "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
+ "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe"}],
+ "vnfdmodule": {"volume_storages": [],
+ "inputs": {},
+ "vdus": [{"volume_storages": [],
+ "description": "CDB",
+ "vdu_id": "VDU_S_CDB_51",
+ "local_storages": ["local_disk_root_10GB",
+ "local_disk_ephemeral_14GB"],
+ "nfv_compute": {"flavor_extra_specs": {"hw:cpu_policy": "dedicated",
+ "hw:mem_page_size": "large",
+ "hw:numa_nodes": 1,
+ "hw:cpu_max_sockets": 1},
+ "mem_size": 8192,
+ "num_cpus": 2},
+ "artifacts": [],
+ "dependencies": [],
+ "vls": ["ZTE_VGW_MGT_NET39_virtualLink",
+ "ZTE_VGW_SERVICE_NET39_virtualLink"],
+ "image_file": "image_51",
+ "cps": ["CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
+ "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2"],
+ "properties": {"key_vd": True,
+ "support_scaling": True,
+ "vdu_type": "CDB",
+ "name": "ZTE_xGW_39_CDB_1",
+ "storage_policy": "Share_Service",
+ "inject_network_address": True,
+ "is_predefined": False,
+ "location_info": {"vimid": "",
+ "availability_zone": "",
+ "vdc": "OG_OrganizationDC",
+ "host": "",
+ "tenant": "",
+ "vapp": "xgw"},
+ "use_shared_vm": False,
+ "inject_data_list": [],
+ "allow_scale_updown": True,
+ "action": "ADD",
+ "watchdog": {},
+ "template_id": 51,
+ "manual_scale_select_vim": False,
+ "config_drive": True}},
+ {"volume_storages": [],
+ "description": "SLB",
+ "vdu_id": "VDU_M_SLB_42",
+ "local_storages": ["local_disk_root_10GB",
+ "local_disk_ephemeral_14GB"],
+ "nfv_compute": {"flavor_extra_specs": {"hw:cpu_policy": "dedicated",
+ "hw:mem_page_size": "large",
+ "hw:numa_nodes": 1,
+ "hw:cpu_max_sockets": 1},
+ "mem_size": 24576,
+ "num_cpus": 8},
+ "artifacts": [],
+ "dependencies": [],
+ "vls": ["ZTE_VGW_MGT_NET39_virtualLink",
+ "ZTE_VGW_SERVICE_NET39_virtualLink",
+ "ZTE_NET39_virtualLink",
+ "ZTE_VGW_GTP_NET39_virtualLink"],
+ "image_file": "image_51",
+ "cps": ["CP_ZTE_xGW_39_SLB_1_ZTE_VGW_MGT_NET39_su1",
+ "CP_ZTE_xGW_39_SLB_1_ZTE_VGW_SERVICE_NET39_su2",
+ "CP_ZTE_xGW_39_SLB_1_zte-net-subnet393",
+ "CP_ZTE_xGW_39_SLB_1_ZTE_VGW_GTP_NET39_su4"],
+ "properties": {"key_vd": True,
+ "support_scaling": False,
+ "vdu_type": "SLB",
+ "name": "ZTE_xGW_39_SLB_1",
+ "storage_policy": "Share_Service",
+ "inject_network_address": True,
+ "is_predefined": False,
+ "location_info": {"vimid": "",
+ "availability_zone": "",
+ "vdc": "OG_OrganizationDC",
+ "host": "",
+ "tenant": "",
+ "vapp": "xgw"},
+ "use_shared_vm": False,
+ "inject_data_list": [],
+ "allow_scale_updown": True,
+ "action": "ADD",
+ "watchdog": {},
+ "template_id": 42,
+ "manual_scale_select_vim": False,
+ "config_drive": True}}],
+ "vcloud": [],
+ "extvirtuallink": "",
+ "server_groups": [],
+ "image_files": [{"properties": {"vendor": "zte",
+ "name": "ZXUN_xGW_CGSL_QCOW2_OP_V6.17.10.B17.ova",
+ "image_extra_specs": {},
+ "disk_format": "vmdk",
+ "file_url": "SoftwareImages/ZXUN-xGW-CGSL-QCOW2-V6.17.10.B17-image.tar.gz",
+ "container_type": "bare",
+ "version": "V6.17.10.B17.ova"},
+ "image_file_id": "image_51",
+ "description": "xgw image file"}],
+ "routers": [],
+ "local_storages": [{"local_storage_id": "local_disk_ephemeral_38GB",
+ "description": "local_disk_ephemeral_38GB",
+ "properties": {"disk_type": "ephemeral",
+ "size": 38}},
+ {"local_storage_id": "local_disk_root_10GB",
+ "description": "local_disk_root_10GB",
+ "properties": {"disk_type": "root",
+ "size": 10}},
+ {"local_storage_id": "local_disk_ephemeral_14GB",
+ "description": "local_disk_ephemeral_14GB",
+ "properties": {"disk_type": "ephemeral",
+ "size": 14}}],
+ "vnf_flavours": [],
+ "vnf_exposed": {"external_cps": [{"key_name": "ZTE_NET39_virtualLink",
+ "cpd_id": "CP_NO_3_PFU_ZTE_NET39"},
+ {"key_name": "ZTE_NET39_virtualLink1",
+ "cpd_id": "CP_NO_2_PFU_ZTE_NET39"},
+ {"key_name": "ZTE_VGW_GTP_NET39_virtualLink",
+ "cpd_id": "CP_NO_3_SLB_ZTE_VGW_GTP_NET39"},
+ {"key_name": "ZTE_NET39_virtualLink2",
+ "cpd_id": "CP_NO_2_SLB_ZTE_NET39"},
+ {"key_name": "provider-zte_virtualLink",
+ "cpd_id": "CP_NO_2_MPU_provider-zte"}],
+ "forward_cps": [{"key_name": "ZTE_VGW_GTP_NET39_forwarder",
+ "cpd_id": "CP_NO_3_SLB_ZTE_VGW_GTP_NET39"},
+ {"key_name": "ZTE_NET39_forwarder1",
+ "cpd_id": "CP_NO_2_PFU_ZTE_NET39"},
+ {"key_name": "ZTE_NET39_forwarder2",
+ "cpd_id": "CP_NO_3_PFU_ZTE_NET39"},
+ {"key_name": "provider-zte_forwarder",
+ "cpd_id": "CP_NO_2_MPU_provider-zte"},
+ {"key_name": "ZTE_NET39_forwarder",
+ "cpd_id": "CP_NO_2_SLB_ZTE_NET39"}]},
+ "reserved_total": {"portnum": 27,
+ "vcpunum": 72,
+ "memorysize": 233472,
+ "shdsize": 288,
+ "isreserve": 0,
+ "vmnum": 9},
+ "policies": [{"scaling": [{"description": "zte vgw vnf policy",
+ "policy_id": "Policy_1",
+ "targets": ["VDU_S_CDB_51",
+ "VDU_M_CDB_52",
+ "VDU_M_SLB_42",
+ "VDU_M_GSU_22",
+ "VDU_M_MPU_12",
+ "VDU_L_MPU_13",
+ "VDU_M_PFU_32",
+ "VDU_L_PFU_33"],
+ "properties": {"policy_file": "Policies/zte-vcn-vnf-policy.xml"}}],
+ "healing": []}],
+ "plugins": [],
+ "services": [],
+ "vcenter": [],
+ "cps": [{"vl_id": "ZTE_VGW_MGT_NET39_virtualLink",
+ "description": "ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_s",
+ "vdu_id": "VDU_S_CDB_51",
+ "properties": {"service_port_created": False,
+ "name": "ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_s",
+ "allowed_address_pairs": [],
+ "bandwidth": 0,
+ "is_virtual": False,
+ "guest_os_mt": 1400,
+ "vnic_type": "normal",
+ "floating_ip_address": {},
+ "mac_address": "",
+ "port_security_enabled": False,
+ "ip_address": "192.168.39.247",
+ "order": 1,
+ "security_groups": [],
+ "bond": "none"},
+ "cp_id": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
+ "cpd_id": "CP_NO_0_CDB_ZTE_VGW_MGT_NET39"},
+ {"vl_id": "ZTE_VGW_SERVICE_NET39_virtualLink",
+ "description": "ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_s",
+ "vdu_id": "VDU_S_CDB_51",
+ "properties": {"service_port_created": False,
+ "name": "ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_s",
+ "allowed_address_pairs": [],
+ "bandwidth": 0,
+ "is_virtual": False,
+ "guest_os_mt": 1400,
+ "vnic_type": "normal",
+ "floating_ip_address": {},
+ "mac_address": "",
+ "port_security_enabled": False,
+ "ip_address": "192.168.40.247",
+ "order": 2,
+ "security_groups": [],
+ "bond": "none"},
+ "cp_id": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2",
+ "cpd_id": "CP_NO_1_CDB_ZTE_VGW_SERVICE_NET39"}],
+ "vls": [{"route_external": False,
+ "route_id": "",
+ "vl_id": "ZTE_VGW_MGT_NET39_virtualLink",
+ "description": "ZTE_VGW_MGT_NET39_s",
+ "properties": {"gateway_ip": "",
+ "vendor": "ZTE",
+ "name": "ZTE_VGW_MGT_NET39_s",
+ "location_info": {"vdc": "OG_OrganizationDC",
+ "vimid": 1,
+ "tenant": "",
+ "vapp": "xgw"},
+ "start_ip": "",
+ "segmentation_id": "142",
+ "dns_nameservers": [],
+ "vds_name": "",
+ "mt": 1400,
+ "is_predefined": True,
+ "ip_version": 4,
+ "netmask": "255.255.255.0",
+ "end_ip": "",
+ "host_routes": [],
+ "vlan_transparent": False,
+ "physical_network": "physnet1",
+ "cidr": "192.168.39.0/24",
+ "dhcp_enabled": False,
+ "network_name": "ZTE_VGW_MGT_NET39",
+ "network_type": "vlan"}},
+ {"route_external": False,
+ "route_id": "",
+ "vl_id": "ZTE_VGW_SERVICE_NET39_virtualLink",
+ "description": "ZTE_VGW_SERVICE_NET39_s",
+ "properties": {"gateway_ip": "",
+ "vendor": "ZTE",
+ "name": "ZTE_VGW_SERVICE_NET39_s",
+ "location_info": {"vdc": "OG_OrganizationDC",
+ "vimid": 1,
+ "tenant": "",
+ "vapp": "xgw"},
+ "start_ip": "",
+ "segmentation_id": "128",
+ "dns_nameservers": [],
+ "vds_name": "",
+ "mt": 1400,
+ "is_predefined": True,
+ "ip_version": 4,
+ "netmask": "255.255.255.0",
+ "end_ip": "",
+ "host_routes": [],
+ "vlan_transparent": False,
+ "physical_network": "physnet1",
+ "cidr": "192.168.40.0/24",
+ "dhcp_enabled": False,
+ "network_name": "ZTE_VGW_SERVICE_NET39",
+ "network_type": "vlan"}}],
+ "element_groups": [],
+ "metadata": {"plugin_info": "cn_plugin_3.0",
+ "vendor": "ZTE",
+ "is_shared": False,
+ "adjust_vnf_capacity": True,
+ "paas_project": "",
+ "description": "VMware",
+ "vnf_extend_type": "driver",
+ "domain_type": "CN",
+ "resview": "dync",
+ "script_info": "",
+ "service_category": "EPC",
+ "version": "ZTE",
+ "vnf_type": "SAE-GW",
+ "cross_dc": False,
+ "vmnumber_overquota_alarm": True,
+ "vnfd_version": "V00000001",
+ "id": "NFAR-ZTE-40-ZTE",
+ "name": 40}},
+ "operation": "instantiate",
+ "vnfmInstanceId": "31f8934e-c785-4fa5-9205-c5f374ada982"}},
+ "vimid": "vmware_vio",
+ "timestamp": "20171110105828",
+ "affectedcp": [{"changeType": "added",
+ "cPInstanceId": "175767d4-c5bf-11e7-904d-fa163eee1ffe",
+ "ownertype": 3,
+ "cpdId": "CP_NO_0_CDB_ZTE_VGW_MGT_NET39",
+ "portResource": {"resourceId": "3296b6d8-ebca-4d33-98f4-68d1bc63a3d0",
+ "tenant": "ZTE_ONAP_PRO",
+ "vimId": "vmware_vio",
+ "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1"},
+ "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_MGT_NET39_su1",
+ "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
+ "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe"},
+ {"changeType": "added",
+ "cPInstanceId": "1758181e-c5bf-11e7-904d-fa163eee1ffe",
+ "ownertype": 3,
+ "cpdId": "CP_NO_1_CDB_ZTE_VGW_SERVICE_NET39",
+ "portResource": {"resourceId": "5e277a18-94de-469a-a336-2c01ab46387e",
+ "tenant": "ZTE_ONAP_PRO",
+ "vimId": "vmware_vio",
+ "resourceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2"},
+ "cpInstanceName": "CP_ZTE_xGW_39_CDB_1_ZTE_VGW_SERVICE_NET39_su2",
+ "ownerid": "17502154-c5bf-11e7-904d-fa163eee1ffe",
+ "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe"}],
+ "vmlist": [{"VMNumber": 1,
+ "vdutype": "CDB",
+ "VMFlavor": "VDU_S_CDB_51",
+ "VMIDlist": [{"VMID": "e8ccc55a-3ebb-4e46-8260-dc4a1646ef4f",
+ "VMName": "ZTE_xGW_39_CDB_1",
+ "vimid": "vmware_vio",
+ "tenant": "ZTE_ONAP_PRO"}]},
+ {"VMNumber": 1,
+ "vdutype": "SLB",
+ "VMFlavor": "VDU_M_SLB_42",
+ "VMIDlist": [{"VMID": "a9dd6a73-76ee-4d07-9554-08f14c17261f",
+ "VMName": "ZTE_xGW_39_SLB_1",
+ "vimid": "vmware_vio",
+ "tenant": "ZTE_ONAP_PRO"}]}],
+ "EventType": 1,
+ "vnfmid": "31f8934e-c785-4fa5-9205-c5f374ada982",
+ "affectedvirtuallink ": [{"changeType": "added",
+ "virtualLinkInstanceId": "1753b60c-c5bf-11e7-904d-fa163eee1ffe",
+ "networkResource": {"resourceId": "c55e0788-3683-48a1-b88a-a0cb5e05bd44",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_MGT_NET39"},
+ "virtualLinkDescId": "ZTE_VGW_MGT_NET39_virtualLink",
+ "tenant": "ZTE_ONAP_PRO",
+ "subnetworkResource": {"resourceId": "33c8a03d-00c9-4c57-a348-26dae462b473",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_MGT_NET39_s"}},
+ {"changeType": "added",
+ "virtualLinkInstanceId": "175472a4-c5bf-11e7-904d-fa163eee1ffe",
+ "networkResource": {"resourceId": "2d22b6e4-340b-45a8-8757-5206aa056b92",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_SERVICE_NET39"},
+ "virtualLinkDescId": "ZTE_VGW_SERVICE_NET39_virtualLink",
+ "tenant": "ZTE_ONAP_PRO",
+ "subnetworkResource": {"resourceId": "2ea2acc0-a4ed-44f8-9d31-9cdc9e3ebe62",
+ "tenant": None,
+ "vimId": "vmware_vio",
+ "resourceName": "ZTE_VGW_SERVICE_NET39_s"}}]}
diff --git a/zte/vmanager/driver/interfaces/urls.py b/zte/vmanager/driver/interfaces/urls.py
index fe70e460..e32e53ea 100644
--- a/zte/vmanager/driver/interfaces/urls.py
+++ b/zte/vmanager/driver/interfaces/urls.py
@@ -17,22 +17,18 @@ from django.conf.urls import url
from driver.interfaces import views
urlpatterns = [
- url(r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs$', views.instantiate_vnf,
- name='instantiate_vnf'),
- url(
- r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>'
- r'[0-9a-zA-Z\-\_]+)/terminate$',
- views.terminate_vnf, name='terminate_vnf'),
- url(
- r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>'
- r'[0-9a-zA-Z\-\_]+)$',
- views.query_vnf, name='query_vnf'),
- url(r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/jobs/(?P<jobid>[0-9a-zA-Z\-\_]+)$',
- views.operation_status, name='operation_status'),
- url(r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/resource/grant$', views.grantvnf, name='grantvnf'),
- url(r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/vnfs/lifecyclechangesnotification$', views.notify, name='notify'),
- url(r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>[0-9a-zA-Z\-\_]+)/scale$',
- views.scale, name='scale'),
- url(r'^api/(?P<vnfmtype>[0-9a-zA-Z\-\_]+)/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>[0-9a-zA-Z\-\_]+)/heal$',
- views.heal, name='heal'),
- url(r'^samples/$', views.samples, name='samples'), ]
+ url(r'^api/ztevnfmdriver/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs$', views.InstamtiateVnf.as_view(), name='instantiate_vnf'),
+ url(r'^api/ztevnfmdriver/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>[0-9a-zA-Z\-\_]+)/terminate$',
+ views.TerminateVnf.as_view(), name='terminate_vnf'),
+ url(r'^api/ztevnfmdriver/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>[0-9a-zA-Z\-\_]+)$',
+ views.QueryVnf.as_view(), name='query_vnf'),
+ url(r'^api/ztevnfmdriver/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/jobs/(?P<jobid>[0-9a-zA-Z\-\_]+)$',
+ views.JobView.as_view(), name='operation_status'),
+ url(r'^api/ztevnfmdriver/v1/resource/grant$', views.GrantVnf.as_view(), name='grantvnf'),
+ url(r'^api/ztevnfmdriver/v1/vnfs/lifecyclechangesnotification$', views.Notify.as_view(), name='notify'),
+ url(r'^api/ztevnfmdriver/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>[0-9a-zA-Z\-\_]+)/scale$',
+ views.Scale.as_view(), name='scale'),
+ url(r'^api/ztevnfmdriver/v1/(?P<vnfmid>[0-9a-zA-Z\-\_]+)/vnfs/(?P<vnfInstanceId>[0-9a-zA-Z\-\_]+)/heal$',
+ views.Heal.as_view(), name='heal'),
+ url(r'^samples/$', views.SampleList.as_view(), name='samples')
+]
diff --git a/zte/vmanager/driver/interfaces/views.py b/zte/vmanager/driver/interfaces/views.py
index 27b57c7a..5a978c63 100644
--- a/zte/vmanager/driver/interfaces/views.py
+++ b/zte/vmanager/driver/interfaces/views.py
@@ -15,15 +15,21 @@
import inspect
import json
import logging
-import traceback
import os
+import traceback
-from rest_framework.decorators import api_view
+from drf_yasg import openapi
+from drf_yasg.utils import swagger_auto_schema
+from rest_framework import status
from rest_framework.response import Response
+from rest_framework.views import APIView
+from driver.interfaces.serializers import HealReqSerializer, InstScaleHealRespSerializer, ScaleReqSerializer, \
+ NotifyReqSerializer, GrantRespSerializer, GrantReqSerializer, JobQueryRespSerializer, TerminateVnfRequestSerializer, \
+ InstantiateVnfRequestSerializer, QueryVnfResponseSerializer
+from driver.pub.config.config import VNF_FTP
from driver.pub.utils import restcall
from driver.pub.utils.restcall import req_by_msb
-from driver.pub.config.config import VNF_FTP
logger = logging.getLogger(__name__)
@@ -53,14 +59,6 @@ def ignorcase_get(args, key):
return ""
-def mapping_conv(keyword_map, rest_return):
- resp_data = {}
- for param in keyword_map:
- if keyword_map[param]:
- resp_data[keyword_map[param]] = ignorcase_get(rest_return, param)
- return resp_data
-
-
# Query vnfm_info from nslcm
def get_vnfminfo_from_nslcm(vnfmid):
ret = req_by_msb("api/nslcm/v1/vnfms/%s" % vnfmid, "GET")
@@ -79,402 +77,516 @@ def vnfpackage_get(csarid):
return ret
-@api_view(http_method_names=['POST'])
-def instantiate_vnf(request, *args, **kwargs):
- try:
- logger.debug("[%s] request.data=%s", fun_name(), request.data)
- vnfm_id = ignorcase_get(kwargs, "vnfmid")
- ret = get_vnfminfo_from_nslcm(vnfm_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnfm_info = json.JSONDecoder().decode(ret[1])
- logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
- vnf_package_id = ignorcase_get(request.data, "vnfPackageId")
- ret = vnfd_get(vnf_package_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnfd_info = json.JSONDecoder().decode(ret[1])
- logger.debug("[%s] vnfd_info=%s", fun_name(), vnfd_info)
- csar_id = ignorcase_get(vnfd_info, "csarId")
- ret = vnfpackage_get(csar_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnf_package_info = json.JSONDecoder().decode(ret[1])
- packageInfo = ignorcase_get(vnf_package_info, "packageInfo")
- logger.debug("[%s] packageInfo=%s", fun_name(), packageInfo)
- data = {}
- data["NFVOID"] = 1
- data["VNFMID"] = vnfm_id
- vnfdModel = json.loads(ignorcase_get(packageInfo, "vnfdModel"))
- metadata = ignorcase_get(vnfdModel, "metadata")
- vnfd_name = ignorcase_get(metadata, "name")
- # TODO convert sdc vnf package to vnf vender package
- inputs = []
- if "SPGW" in vnfd_name.upper():
- data["VNFD"] = VNF_FTP + "SPGW"
- inputs = load_json_file("SPGW" + "_inputs.json")
- elif "MME" in vnfd_name.upper():
- data["VNFD"] = VNF_FTP + "MME"
- inputs = load_json_file("MME" + "_inputs.json")
- else:
- data["VNFD"] = ignorcase_get(packageInfo, "downloadUri")
-
- data["VNFURL"] = data["VNFD"]
-
- data["extension"] = {}
- for name, value in ignorcase_get(ignorcase_get(request.data, "additionalParam"), "inputs").items():
- inputs.append({"name": name, "value": value})
-
- data["extension"]["inputs"] = json.dumps(inputs)
- additionalParam = ignorcase_get(request.data, "additionalParam")
- data["extension"]["extVirtualLinks"] = ignorcase_get(additionalParam, "extVirtualLinks")
- data["extension"]["vnfinstancename"] = ignorcase_get(request.data, "vnfInstanceName")
- data["extension"]["vnfid"] = data["VNFD"]
- data["extension"]["multivim"] = 0
- logger.debug("[%s] call_req data=%s", fun_name(), data)
-
- ret = restcall.call_req(
- base_url=ignorcase_get(vnfm_info, "url"),
- user=ignorcase_get(vnfm_info, "userName"),
- passwd=ignorcase_get(vnfm_info, "password"),
- auth_type=restcall.rest_no_auth,
- resource="v1/vnfs",
- method='post',
- content=json.JSONEncoder().encode(data))
-
- logger.debug("[%s] call_req ret=%s", fun_name(), ret)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- resp = json.JSONDecoder().decode(ret[1])
- resp_data = {
- "vnfInstanceId": ignorcase_get(resp, "VNFInstanceID"),
- "jobId": ignorcase_get(resp, "JobId")
+class InstamtiateVnf(APIView):
+ @swagger_auto_schema(
+ request_body=InstantiateVnfRequestSerializer(),
+ responses={
+ status.HTTP_200_OK: InstScaleHealRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
}
- logger.info("[%s]resp_data=%s", fun_name(), resp_data)
- except Exception as e:
- logger.error("Error occurred when instantiating VNF")
- raise e
- return Response(data=resp_data, status=ret[2])
-
-
-@api_view(http_method_names=['POST'])
-def terminate_vnf(request, *args, **kwargs):
- try:
- logger.debug("[%s] request.data=%s", fun_name(), request.data)
- vnfm_id = ignorcase_get(kwargs, "vnfmid")
- ret = get_vnfminfo_from_nslcm(vnfm_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnfm_info = json.JSONDecoder().decode(ret[1])
- logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
- ret = restcall.call_req(
- base_url=ignorcase_get(vnfm_info, "url"),
- user=ignorcase_get(vnfm_info, "userName"),
- passwd=ignorcase_get(vnfm_info, "password"),
- auth_type=restcall.rest_no_auth,
- resource="v1/vnfs/%s" % (ignorcase_get(kwargs, "vnfInstanceID")),
- method='delete',
- content=json.JSONEncoder().encode(request.data))
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- resp = json.JSONDecoder().decode(ret[1])
- resp_data = {
- "vnfInstanceId": ignorcase_get(resp, "VNFInstanceID"),
- "jobId": ignorcase_get(resp, "JobId")
+ )
+ def post(self, request, vnfmid):
+ try:
+ logger.debug("[%s] request.data=%s", fun_name(), request.data)
+ instantiateVnfRequestSerializer = InstantiateVnfRequestSerializer(data=request.data)
+ if not instantiateVnfRequestSerializer.is_valid():
+ raise Exception(instantiateVnfRequestSerializer.errors)
+
+ ret = get_vnfminfo_from_nslcm(vnfmid)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfm_info = json.JSONDecoder().decode(ret[1])
+ logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
+ vnf_package_id = ignorcase_get(instantiateVnfRequestSerializer.data, "vnfPackageId")
+ ret = vnfd_get(vnf_package_id)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfd_info = json.JSONDecoder().decode(ret[1])
+ logger.debug("[%s] vnfd_info=%s", fun_name(), vnfd_info)
+ csar_id = ignorcase_get(vnfd_info, "csarId")
+ ret = vnfpackage_get(csar_id)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnf_package_info = json.JSONDecoder().decode(ret[1])
+ packageInfo = ignorcase_get(vnf_package_info, "packageInfo")
+ logger.debug("[%s] packageInfo=%s", fun_name(), packageInfo)
+ data = {
+ "NFVOID": 1,
+ "VNFMID": vnfmid,
+ "extension": {},
+ }
+ vnfdModel = json.loads(ignorcase_get(packageInfo, "vnfdModel"))
+ metadata = ignorcase_get(vnfdModel, "metadata")
+ vnfd_name = ignorcase_get(metadata, "name")
+ # TODO convert sdc vnf package to vnf vender package
+ inputs = []
+ if "SPGW" in vnfd_name.upper():
+ data["VNFD"] = VNF_FTP + "SPGW"
+ inputs = load_json_file("SPGW" + "_inputs.json")
+ elif "MME" in vnfd_name.upper():
+ data["VNFD"] = VNF_FTP + "MME"
+ inputs = load_json_file("MME" + "_inputs.json")
+ else:
+ data["VNFD"] = ignorcase_get(packageInfo, "downloadUri")
+
+ data["VNFURL"] = data["VNFD"]
+
+ additionalParam = ignorcase_get(instantiateVnfRequestSerializer.data, "additionalParam")
+ for name, value in ignorcase_get(additionalParam, "inputs").items():
+ inputs.append({"name": name, "value": value})
+
+ data["extension"]["inputs"] = json.dumps(inputs)
+ data["extension"]["extVirtualLinks"] = ignorcase_get(additionalParam, "extVirtualLinks")
+ data["extension"]["vnfinstancename"] = ignorcase_get(instantiateVnfRequestSerializer.data, "vnfInstanceName")
+ data["extension"]["vnfid"] = data["VNFD"]
+ data["extension"]["multivim"] = 0
+ logger.debug("[%s] call_req data=%s", fun_name(), data)
+
+ ret = restcall.call_req(
+ base_url=ignorcase_get(vnfm_info, "url"),
+ user=ignorcase_get(vnfm_info, "userName"),
+ passwd=ignorcase_get(vnfm_info, "password"),
+ auth_type=restcall.rest_no_auth,
+ resource="v1/vnfs",
+ method='post',
+ content=json.JSONEncoder().encode(data))
+
+ logger.debug("[%s] call_req ret=%s", fun_name(), ret)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ resp = json.JSONDecoder().decode(ret[1])
+ resp_data = {
+ "vnfInstanceId": ignorcase_get(resp, "VNFInstanceID"),
+ "jobId": ignorcase_get(resp, "JobId")
+ }
+ logger.debug("[%s]resp_data=%s", fun_name(), resp_data)
+ instRespSerializer = InstScaleHealRespSerializer(data=resp_data)
+ if not instRespSerializer.is_valid():
+ raise Exception(instRespSerializer.errors)
+
+ logger.debug("[%s] instRespSerializer.data=%s", fun_name(), instRespSerializer.data)
+ return Response(data=instRespSerializer.data, status=status.HTTP_200_OK)
+ except Exception as e:
+ logger.error("Error occurred when instantiating VNF,error:%s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'InstantiateVnf expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+
+class TerminateVnf(APIView):
+ @swagger_auto_schema(
+ request_body=TerminateVnfRequestSerializer(),
+ responses={
+ status.HTTP_200_OK: InstScaleHealRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
}
- logger.debug("[%s]resp_data=%s", fun_name(), resp_data)
- except Exception as e:
- logger.error("Error occurred when terminating VNF")
- raise e
- return Response(data=resp_data, status=ret[2])
-
-
-@api_view(http_method_names=['GET'])
-def query_vnf(request, *args, **kwargs):
- try:
- logger.debug("[%s] request.data=%s", fun_name(), request.data)
- vnfm_id = ignorcase_get(kwargs, "vnfmid")
- ret = get_vnfminfo_from_nslcm(vnfm_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnfm_info = json.JSONDecoder().decode(ret[1])
- logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
- ret = restcall.call_req(
- base_url=ignorcase_get(vnfm_info, "url"),
- user=ignorcase_get(vnfm_info, "userName"),
- passwd=ignorcase_get(vnfm_info, "password"),
- auth_type=restcall.rest_no_auth,
- resource="v1/vnfs/%s" % (ignorcase_get(kwargs, "vnfInstanceID")),
- method='get',
- content=json.JSONEncoder().encode({}))
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- resp = json.JSONDecoder().decode(ret[1])
- vnf_status = ignorcase_get(resp, "vnfinstancestatus")
- resp_data = {"vnfInfo": {"vnfStatus": vnf_status}}
- logger.debug("[%s]resp_data=%s", fun_name(), resp_data)
- except Exception as e:
- logger.error("Error occurred when querying VNF information.")
- raise e
- return Response(data=resp_data, status=ret[2])
-
-
-@api_view(http_method_names=['GET'])
-def operation_status(request, *args, **kwargs):
- data = {}
- try:
- logger.debug("[%s] request.data=%s", fun_name(), request.data)
- vnfm_id = ignorcase_get(kwargs, "vnfmid")
- ret = get_vnfminfo_from_nslcm(vnfm_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnfm_info = json.JSONDecoder().decode(ret[1])
- logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
- operation_status_url = '/v1/jobs/{jobId}?NFVOID={nfvoId}&VNFMID={vnfmId}&ResponseID={responseId}'
- ret = restcall.call_req(
- base_url=ignorcase_get(vnfm_info, 'url'),
- user=ignorcase_get(vnfm_info, 'userName'),
- passwd=ignorcase_get(vnfm_info, 'password'),
- auth_type=restcall.rest_no_auth,
- resource=operation_status_url.format(jobId=ignorcase_get(kwargs, 'jobid'), nfvoId=1,
- vnfmId=ignorcase_get(kwargs, 'vnfmid'),
- responseId=ignorcase_get(request.GET, 'responseId')),
- method='get',
- content=json.JSONEncoder().encode(data))
-
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- resp_data = json.JSONDecoder().decode(ret[1])
- logger.info("[%s]resp_data=%s", fun_name(), resp_data)
- except Exception as e:
- logger.error("Error occurred when getting operation status information.")
- raise e
- return Response(data=resp_data, status=ret[2])
-
-
-@api_view(http_method_names=['PUT'])
-def grantvnf(request, *args, **kwargs):
- logger.info("=====grantvnf=====")
- try:
- logger.info("req_data = %s", request.data)
- grant_vnf_param_map = {
- "VNFMID": "",
- "NFVOID": "",
- "VIMID": "",
- "ExVIMIDList": "",
- "ExVIMID": "",
- "Tenant": "",
- "VNFInstanceID": "vnfInstanceId",
- "OperationRight": "",
- "VMList": "",
- "VMFlavor": "",
- "VMNumber": ""
+ )
+ def post(self, request, vnfmid, vnfInstanceId):
+ try:
+ logger.debug("[%s] request.data=%s", fun_name(), request.data)
+ terminate_vnf_request_serializer = TerminateVnfRequestSerializer(data=request.data)
+ if not terminate_vnf_request_serializer.is_valid():
+ raise Exception(terminate_vnf_request_serializer.errors)
+
+ ret = get_vnfminfo_from_nslcm(vnfmid)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfm_info = json.JSONDecoder().decode(ret[1])
+ logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
+ ret = restcall.call_req(
+ base_url=ignorcase_get(vnfm_info, "url"),
+ user=ignorcase_get(vnfm_info, "userName"),
+ passwd=ignorcase_get(vnfm_info, "password"),
+ auth_type=restcall.rest_no_auth,
+ resource="v1/vnfs/%s" % vnfInstanceId,
+ method='delete',
+ content=json.JSONEncoder().encode(terminate_vnf_request_serializer.data))
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ resp = json.JSONDecoder().decode(ret[1])
+ resp_data = {
+ "vnfInstanceId": ignorcase_get(resp, "VNFInstanceID"),
+ "jobId": ignorcase_get(resp, "JobId")
+ }
+ logger.debug("[%s]resp_data=%s", fun_name(), resp_data)
+ terminateRespSerializer = InstScaleHealRespSerializer(data=resp_data)
+ if not terminateRespSerializer.is_valid():
+ raise Exception(terminateRespSerializer.errors)
+ return Response(data=terminateRespSerializer.data, status=status.HTTP_200_OK)
+ except Exception as e:
+ logger.error("Error occurred when terminating VNF,error: %s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'TerminateVnf expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+
+class QueryVnf(APIView):
+ @swagger_auto_schema(
+ responses={
+ status.HTTP_200_OK: QueryVnfResponseSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
}
- data = mapping_conv(grant_vnf_param_map, request.data)
- data["vnfDescriptorId"] = ""
- if ignorcase_get(request.data, "operationright") == 0:
- data["lifecycleOperation"] = "Instantiate"
- data["addresource"] = []
- for vm in ignorcase_get(request.data, "vmlist"):
- for i in range(int(ignorcase_get(vm, "vmnumber"))):
- data["addresource"].append(
- {
- "type": "vdu",
- "resourceDefinitionId": i,
- "vdu": ignorcase_get(vm, "vmflavor"),
- "vimid": ignorcase_get(vm, "vimid"),
- "tenant": ignorcase_get(vm, "tenant")})
-
- data["additionalparam"] = {}
- data["additionalparam"]["vnfmid"] = ignorcase_get(request.data, "vnfmid")
- data["additionalparam"]["vimid"] = ignorcase_get(request.data, "vimid")
- data["additionalparam"]["tenant"] = ignorcase_get(request.data, "tenant")
-
- ret = req_by_msb('api/nslcm/v1/ns/grantvnf', "POST", content=json.JSONEncoder().encode(data))
- logger.info("ret = %s", ret)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- resp = json.JSONDecoder().decode(ret[1])
- resp_data = {
- 'vimid': ignorcase_get(resp['vim'], 'vimid'),
- 'tenant': ignorcase_get(ignorcase_get(resp['vim'], 'accessinfo'), 'tenant')
+ )
+ def get(self, request, vnfmid, vnfInstanceId):
+ try:
+ logger.debug("[%s] request.data=%s", fun_name(), request.data)
+ ret = get_vnfminfo_from_nslcm(vnfmid)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfm_info = json.JSONDecoder().decode(ret[1])
+ logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
+ ret = restcall.call_req(
+ base_url=ignorcase_get(vnfm_info, "url"),
+ user=ignorcase_get(vnfm_info, "userName"),
+ passwd=ignorcase_get(vnfm_info, "password"),
+ auth_type=restcall.rest_no_auth,
+ resource="v1/vnfs/%s" % vnfInstanceId,
+ method='get',
+ content=json.JSONEncoder().encode({}))
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ resp = json.JSONDecoder().decode(ret[1])
+ vnf_status = ignorcase_get(resp, "vnfinstancestatus")
+ resp_data = {"vnfInfo": {"vnfStatus": vnf_status}}
+ logger.debug("[%s]resp_data=%s", fun_name(), resp_data)
+ queryVnfResponseSerializer = QueryVnfResponseSerializer(data=resp_data)
+ if not queryVnfResponseSerializer.is_valid():
+ raise Exception(queryVnfResponseSerializer.errors)
+ return Response(data=queryVnfResponseSerializer.data, status=status.HTTP_200_OK)
+ except Exception as e:
+ logger.error("Error occurred when querying VNF information,error:%s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'QueryVnf expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+
+class JobView(APIView):
+ @swagger_auto_schema(
+ manual_parameters=[
+ openapi.Parameter('responseId',
+ openapi.IN_QUERY,
+ "responseId",
+ type=openapi.TYPE_INTEGER
+ ),
+ ],
+ responses={
+ status.HTTP_200_OK: JobQueryRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
}
- logger.info("[%s]resp_data=%s", fun_name(), resp_data)
- except Exception as e:
- logger.error("Error occurred in Grant VNF.")
- raise e
- return Response(data=resp_data, status=ret[2])
-
-
-@api_view(http_method_names=['POST'])
-def notify(request, *args, **kwargs):
- try:
- logger.info("[%s]req_data = %s", fun_name(), request.data)
- notify_param_map = {
- "NFVOID": "",
- "VNFMID": "VNFMID",
- "VIMID": "vimid",
- "VNFInstanceID": "vnfInstanceId",
- "TimeStamp": "",
- "EventType": "operation",
- "VMList": "",
- "VMFlavor": "",
- "VMNumber": "",
- "VMIDlist": "",
- "VMUUID": ""
+ )
+ def get(self, request, vnfmid, jobid):
+ try:
+ logger.debug("[%s] request.data=%s", fun_name(), request.data)
+ ret = get_vnfminfo_from_nslcm(vnfmid)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfm_info = json.JSONDecoder().decode(ret[1])
+ logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
+ operation_status_url = '/v1/jobs/{jobId}?NFVOID={nfvoId}&VNFMID={vnfmId}&ResponseID={responseId}'
+ responseId = ignorcase_get(request.GET, 'responseId')
+ query_url = operation_status_url.format(jobId=jobid, nfvoId=1, vnfmId=vnfmid, responseId=responseId)
+ ret = restcall.call_req(
+ base_url=ignorcase_get(vnfm_info, 'url'),
+ user=ignorcase_get(vnfm_info, 'userName'),
+ passwd=ignorcase_get(vnfm_info, 'password'),
+ auth_type=restcall.rest_no_auth,
+ resource=query_url,
+ method='get',
+ content={})
+
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ resp_data = json.JSONDecoder().decode(ret[1])
+ logger.debug("[%s]resp_data=%s", fun_name(), resp_data)
+ jobQueryRespSerializer = JobQueryRespSerializer(data=resp_data)
+ if not jobQueryRespSerializer.is_valid():
+ raise Exception(jobQueryRespSerializer.errors)
+
+ return Response(data=jobQueryRespSerializer.data, status=status.HTTP_200_OK)
+ except Exception as e:
+ logger.error("Error occurred when getting operation status information,error:%s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'QueryJob expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+
+class GrantVnf(APIView):
+ @swagger_auto_schema(
+ request_body=GrantReqSerializer(),
+ responses={
+ status.HTTP_201_CREATED: GrantRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: 'Internal error'
}
- data = mapping_conv(notify_param_map, request.data)
- logger.info("[%s]data = %s", fun_name(), data)
-
- data["status"] = "result"
- data["jobId"] = "notMust"
- data["affectedVnfc"] = []
- data["affectedVl"] = []
- data["affectedVirtualStorage"] = []
- data["affectedCp"] = []
-
- extension = ignorcase_get(request.data, "extension")
- openo_notification = ignorcase_get(extension, "openo_notification")
- if openo_notification:
- affectedvnfcs = ignorcase_get(openo_notification, "affectedVnfc")
- affectedvls = ignorcase_get(openo_notification, "affectedvirtuallink")
- affectedcps = ignorcase_get(openo_notification, "affectedCp")
- vnfdmodule = ignorcase_get(openo_notification, "vnfdmodule")
- else:
- affectedvnfcs = ignorcase_get(ignorcase_get(request.data, "extension"), "affectedvnfc")
- affectedvls = ignorcase_get(ignorcase_get(request.data, "extension"), "affectedvl")
- affectedcps = ignorcase_get(ignorcase_get(request.data, "extension"), "affectedcp")
- vnfdmodule = ignorcase_get(ignorcase_get(request.data, "extension"), "vnfdmodule")
-
- data["vnfdmodule"] = vnfdmodule
-
- for affectedvnfc in affectedvnfcs:
- data["affectedVnfc"].append({
- "vnfcInstanceId": ignorcase_get(affectedvnfc, "vnfcInstanceId"),
- "vduId": ignorcase_get(affectedvnfc, "vduId"),
- "changeType": ignorcase_get(affectedvnfc, "changeType"),
- "vimId": ignorcase_get(ignorcase_get(affectedvnfc, "computeResource"), "vimId"),
- "vmId": ignorcase_get(ignorcase_get(affectedvnfc, "computeResource"), "resourceId"),
- "vmName": ignorcase_get(ignorcase_get(affectedvnfc, "computeResource"), "resourceName")
- })
-
- for affectedvl in affectedvls:
- data["affectedVl"].append({
- "vlInstanceId": ignorcase_get(affectedvl, "virtualLinkInstanceId"),
- "changeType": ignorcase_get(affectedvl, "changeType"),
- "vimId": ignorcase_get(ignorcase_get(affectedvl, "networkResource"), "vimId"),
- "vldId": ignorcase_get(affectedvl, "virtuallinkdescid"),
- "networkResource": {
- "resourceType": "network",
- "resourceId": ignorcase_get(ignorcase_get(affectedvl, "networkresource"), "resourceid"),
- "resourceName": ignorcase_get(ignorcase_get(affectedvl, "networkresource"), "resourcename")
+ )
+ def put(self, request):
+ logger.debug("=====GrantVnf=====")
+ try:
+ logger.debug("request.data = %s", request.data)
+ grantReqSerializer = GrantReqSerializer(data=request.data)
+ if not grantReqSerializer.is_valid():
+ raise Exception(grantReqSerializer.errors)
+
+ logger.debug("grantReqSerializer.data = %s", grantReqSerializer.data)
+ req_data = {
+ "vnfInstanceId": ignorcase_get(grantReqSerializer.data, "vnfistanceid"),
+ "vnfDescriptorId": "",
+ "addresource": [],
+ "additionalparam": {
+ "vnfmid": ignorcase_get(grantReqSerializer.data, "vnfmid"),
+ "vimid": ignorcase_get(grantReqSerializer.data, "vimid"),
+ "tenant": ignorcase_get(grantReqSerializer.data, "tenant")
}
- })
-
- for affectedcp in affectedcps:
- data["affectedCp"].append(affectedcp)
-
- notify_url = 'api/nslcm/v1/ns/{vnfmid}/vnfs/{vnfInstanceId}/Notify'
- ret = req_by_msb(notify_url.format(vnfmid=ignorcase_get(data, 'VNFMID'),
- vnfInstanceId=ignorcase_get(data, 'vnfinstanceid')),
- "POST", content=json.JSONEncoder().encode(data))
-
- logger.info("[%s]data = %s", fun_name(), ret)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- except Exception as e:
- logger.error("Error occurred in LCM notification.")
- logger.error(traceback.format_exc())
- raise e
- return Response(data=None, status=ret[2])
-
-
-@api_view(http_method_names=['POST'])
-def scale(request, *args, **kwargs):
- logger.info("====scale_vnf===")
- try:
- logger.info("request.data = %s", request.data)
- logger.info("requested_url = %s", request.get_full_path())
- vnfm_id = ignorcase_get(kwargs, "vnfmid")
- nf_instance_id = ignorcase_get(kwargs, "vnfInstanceId")
- ret = get_vnfminfo_from_nslcm(vnfm_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnfm_info = json.JSONDecoder().decode(ret[1])
- scale_type = ignorcase_get(request.data, "type")
- aspect_id = ignorcase_get(request.data, "aspectId")
- number_of_steps = ignorcase_get(request.data, "numberOfSteps")
- data = {
- 'vnfmid': vnfm_id,
- 'nfvoid': 1,
- 'scaletype': '0' if scale_type == 'SCALE_OUT' else '1',
- 'vmlist': [{'VMNumber': number_of_steps, 'VMFlavor': aspect_id}],
- 'extension': ''
+ }
+ if ignorcase_get(grantReqSerializer.data, "operationright") == 0:
+ req_data["lifecycleOperation"] = "Instantiate"
+ for vm in ignorcase_get(grantReqSerializer.data, "vmlist"):
+ for i in range(int(ignorcase_get(vm, "VMNumber"))):
+ req_data["addresource"].append(
+ {
+ "type": "vdu",
+ "resourceDefinitionId": i,
+ "vdu": ignorcase_get(vm, "VMFlavor"),
+ "vimid": ignorcase_get(vm, "vimid"),
+ "tenant": ignorcase_get(vm, "tenant")})
+
+ logger.debug("req_data=%s", req_data)
+ ret = req_by_msb('api/nslcm/v1/ns/grantvnf', "POST", content=json.JSONEncoder().encode(req_data))
+ logger.info("ret = %s", ret)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ resp = json.JSONDecoder().decode(ret[1])
+ resp_data = {
+ 'vimid': ignorcase_get(resp['vim'], 'vimid'),
+ 'tenant': ignorcase_get(ignorcase_get(resp['vim'], 'accessinfo'), 'tenant')
+ }
+ logger.debug("[%s]resp_data=%s", fun_name(), resp_data)
+ grantRespSerializer = GrantRespSerializer(data=resp_data)
+ if not grantRespSerializer.is_valid():
+ raise Exception(grantRespSerializer.errors)
+
+ logger.debug("grantRespSerializer.data=%s", grantRespSerializer.data)
+ return Response(data=grantRespSerializer.data, status=status.HTTP_201_CREATED)
+ except Exception as e:
+ logger.error("Error occurred in Grant VNF, error: %s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'Grant expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+
+class Notify(APIView):
+ @swagger_auto_schema(
+ request_body=NotifyReqSerializer(),
+ responses={
+ status.HTTP_200_OK: 'Successfully',
+ status.HTTP_500_INTERNAL_SERVER_ERROR: 'Internal error'
}
-
- logger.info("data = %s", data)
- ret = restcall.call_req(
- base_url=ignorcase_get(vnfm_info, "url"),
- user=ignorcase_get(vnfm_info, "userName"),
- passwd=ignorcase_get(vnfm_info, "password"),
- auth_type=restcall.rest_no_auth,
- resource='/v1/vnfs/{vnfInstanceID}/scale'.format(vnfInstanceID=nf_instance_id),
- method='put', # POST
- content=json.JSONEncoder().encode(data))
- logger.info("ret=%s", ret)
- if ret[0] != 0:
- return Response(data={'error': 'scale error'}, status=ret[2])
- resp_data = json.JSONDecoder().decode(ret[1])
- logger.info("resp_data=%s", resp_data)
- except Exception as e:
- logger.error("Error occurred when scaling VNF,error:%s", e.message)
- logger.error(traceback.format_exc())
- return Response(data={'error': 'scale expection'}, status='500')
- return Response(data=resp_data, status=ret[2])
-
-
-@api_view(http_method_names=['POST'])
-def heal(request, *args, **kwargs):
- logger.info("====heal_vnf===")
- try:
- logger.info("request.data = %s", request.data)
- logger.info("requested_url = %s", request.get_full_path())
- vnfm_id = ignorcase_get(kwargs, "vnfmid")
- nf_instance_id = ignorcase_get(kwargs, "vnfInstanceId")
- ret = get_vnfminfo_from_nslcm(vnfm_id)
- if ret[0] != 0:
- return Response(data={'error': ret[1]}, status=ret[2])
- vnfm_info = json.JSONDecoder().decode(ret[1])
- data = {}
- data['action'] = ignorcase_get(request.data, 'action')
- affectedvm = ignorcase_get(request.data, 'affectedvm')
- data['affectedvm'] = []
- if isinstance(affectedvm, list):
- data['affectedvm'] = affectedvm
- else:
- data['affectedvm'].append(affectedvm)
- data['lifecycleoperation'] = 'operate'
- data['isgrace'] = 'force'
-
- logger.info("data = %s", data)
- ret = restcall.call_req(
- base_url=ignorcase_get(vnfm_info, "url"),
- user=ignorcase_get(vnfm_info, "userName"),
- passwd=ignorcase_get(vnfm_info, "password"),
- auth_type=restcall.rest_no_auth,
- resource='/api/v1/nf_m_i/nfs/{vnfInstanceID}/vms/operation'.format(vnfInstanceID=nf_instance_id),
- method='post',
- content=json.JSONEncoder().encode(data))
- logger.info("ret=%s", ret)
- if ret[0] != 0:
- return Response(data={'error': 'heal error'}, status=ret[2])
- resp_data = json.JSONDecoder().decode(ret[1])
- logger.info("resp_data=%s", resp_data)
- except Exception as e:
- logger.error("Error occurred when healing VNF,error:%s", e.message)
- logger.error(traceback.format_exc())
- return Response(data={'error': 'heal expection'}, status='500')
- return Response(data=resp_data, status=ret[2])
+ )
+ def post(self, request):
+ try:
+ logger.debug("[%s]request.data = %s", fun_name(), request.data)
+ notifyReqSerializer = NotifyReqSerializer(data=request.data)
+ if not notifyReqSerializer.is_valid():
+ raise Exception(notifyReqSerializer.errors)
+
+ logger.debug("[%s]notifyReqSerializer.data = %s", fun_name(), notifyReqSerializer.data)
+ req_data = {
+ "status": "result",
+ "vnfInstanceId": ignorcase_get(notifyReqSerializer.data, "vnfinstanceid"),
+ "vnfmId": ignorcase_get(notifyReqSerializer.data, "vnfmid"),
+ "vimId": ignorcase_get(notifyReqSerializer.data, "vimid"),
+ "operation": ignorcase_get(notifyReqSerializer.data, "EventType"),
+ "jobId": "notMust",
+ "affectedVl": [],
+ "affectedCp": [],
+ "affectedVirtualStorage": [],
+ "affectedVnfc": [],
+ }
+
+ extension = ignorcase_get(notifyReqSerializer.data, "extension")
+ openo_notification = ignorcase_get(extension, "openo_notification")
+ if openo_notification:
+ affectedvnfcs = ignorcase_get(openo_notification, "affectedVnfc")
+ affectedvls = ignorcase_get(openo_notification, "affectedvirtuallink")
+ affectedcps = ignorcase_get(openo_notification, "affectedCp")
+ vnfdmodule = ignorcase_get(openo_notification, "vnfdmodule")
+ else:
+ affectedvnfcs = ignorcase_get(ignorcase_get(notifyReqSerializer.data, "extension"), "affectedvnfc")
+ affectedvls = ignorcase_get(ignorcase_get(notifyReqSerializer.data, "extension"), "affectedvl")
+ affectedcps = ignorcase_get(ignorcase_get(notifyReqSerializer.data, "extension"), "affectedcp")
+ vnfdmodule = ignorcase_get(ignorcase_get(notifyReqSerializer.data, "extension"), "vnfdmodule")
+
+ req_data["vnfdmodule"] = vnfdmodule
+
+ for affectedvnfc in affectedvnfcs:
+ req_data["affectedVnfc"].append({
+ "vnfcInstanceId": ignorcase_get(affectedvnfc, "vnfcInstanceId"),
+ "vduId": ignorcase_get(affectedvnfc, "vduId"),
+ "changeType": ignorcase_get(affectedvnfc, "changeType"),
+ "vimId": ignorcase_get(ignorcase_get(affectedvnfc, "computeResource"), "vimId"),
+ "vmId": ignorcase_get(ignorcase_get(affectedvnfc, "computeResource"), "resourceId"),
+ "vmName": ignorcase_get(ignorcase_get(affectedvnfc, "computeResource"), "resourceName")
+ })
+
+ for affectedvl in affectedvls:
+ req_data["affectedVl"].append({
+ "vlInstanceId": ignorcase_get(affectedvl, "virtualLinkInstanceId"),
+ "changeType": ignorcase_get(affectedvl, "changeType"),
+ "vimId": ignorcase_get(ignorcase_get(affectedvl, "networkResource"), "vimId"),
+ "vldId": ignorcase_get(affectedvl, "virtuallinkdescid"),
+ "networkResource": {
+ "resourceType": "network",
+ "resourceId": ignorcase_get(ignorcase_get(affectedvl, "networkresource"), "resourceid"),
+ "resourceName": ignorcase_get(ignorcase_get(affectedvl, "networkresource"), "resourcename")
+ }
+ })
+
+ for affectedcp in affectedcps:
+ req_data["affectedCp"].append(affectedcp)
+
+ vnfmid = ignorcase_get(req_data, 'vnfmId')
+ vnfInstanceId = ignorcase_get(req_data, 'vnfinstanceid')
+ notify_url = 'api/nslcm/v1/ns/%s/vnfs/%s/Notify' % (vnfmid, vnfInstanceId)
+ logger.debug("notify_url = %s", notify_url)
+ logger.debug("req_data = %s", req_data)
+ ret = req_by_msb(notify_url, "POST", content=json.JSONEncoder().encode(req_data))
+
+ logger.debug("[%s]data = %s", fun_name(), ret)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ return Response(data=None, status=status.HTTP_200_OK)
+ except Exception as e:
+ logger.error("Error occurred in LCM notification,error: %s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'Notify expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+
+class Scale(APIView):
+ @swagger_auto_schema(
+ request_body=ScaleReqSerializer(),
+ responses={
+ status.HTTP_202_ACCEPTED: InstScaleHealRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
+ }
+ )
+ def post(self, request, vnfmid, vnfInstanceId):
+ logger.debug("====scale_vnf===")
+ try:
+ logger.debug("request.data = %s", request.data)
+ logger.debug("requested_url = %s", request.get_full_path())
+ scaleReqSerializer = ScaleReqSerializer(data=request.data)
+ if not scaleReqSerializer.is_valid():
+ raise Exception(scaleReqSerializer.errors)
+
+ ret = get_vnfminfo_from_nslcm(vnfmid)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfm_info = json.JSONDecoder().decode(ret[1])
+ scale_type = ignorcase_get(scaleReqSerializer.data, "type")
+ aspect_id = ignorcase_get(scaleReqSerializer.data, "aspectId")
+ number_of_steps = ignorcase_get(scaleReqSerializer.data, "numberOfSteps")
+ data = {
+ 'vnfmid': vnfmid,
+ 'nfvoid': 1,
+ 'scaletype': '0' if scale_type == 'SCALE_OUT' else '1',
+ 'vmlist': [{
+ 'VMNumber': number_of_steps,
+ 'VMFlavor': aspect_id
+ }],
+ 'extension': ''
+ }
+
+ logger.debug("data = %s", data)
+ ret = restcall.call_req(
+ base_url=ignorcase_get(vnfm_info, "url"),
+ user=ignorcase_get(vnfm_info, "userName"),
+ passwd=ignorcase_get(vnfm_info, "password"),
+ auth_type=restcall.rest_no_auth,
+ resource='/v1/vnfs/{vnfInstanceID}/scale'.format(vnfInstanceID=vnfInstanceId),
+ method='put', # POST
+ content=json.JSONEncoder().encode(data))
+ logger.debug("ret=%s", ret)
+ if ret[0] != 0:
+ raise Exception('scale error')
+
+ scaleRespSerializer = InstScaleHealRespSerializer(data=json.JSONDecoder().decode(ret[1]))
+ if not scaleRespSerializer.is_valid():
+ raise Exception(scaleRespSerializer.errors)
+
+ logger.debug("scaleRespSerializer.data=%s", scaleRespSerializer.data)
+ return Response(data=scaleRespSerializer.data, status=status.HTTP_202_ACCEPTED)
+ except Exception as e:
+ logger.error("Error occurred when scaling VNF,error:%s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'Scale expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+
+class Heal(APIView):
+ @swagger_auto_schema(
+ request_body=HealReqSerializer(),
+ responses={
+ status.HTTP_202_ACCEPTED: InstScaleHealRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
+ }
+ )
+ def post(self, request, vnfmid, vnfInstanceId):
+ logger.debug("====heal_vnf===")
+ try:
+ logger.debug("request.data = %s", request.data)
+ logger.debug("requested_url = %s", request.get_full_path())
+ healReqSerializer = HealReqSerializer(data=request.data)
+ if not healReqSerializer.is_valid():
+ raise Exception(healReqSerializer.errors)
+
+ logger.debug("healReqSerializer.data = %s", healReqSerializer.data)
+ logger.debug("vnfmid = %s", vnfmid)
+ ret = get_vnfminfo_from_nslcm(vnfmid)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfm_info = json.JSONDecoder().decode(ret[1])
+ req_data = {
+ "action": ignorcase_get(healReqSerializer.data, 'action'),
+ "lifecycleoperation": "operate",
+ "isgrace": "force",
+ "affectedvm": [],
+ }
+ affectedvm = ignorcase_get(healReqSerializer.data, 'affectedvm')
+ if isinstance(affectedvm, list):
+ req_data['affectedvm'] = affectedvm
+ else:
+ req_data['affectedvm'].append(affectedvm)
+
+ logger.debug("req_data = %s", req_data)
+ ret = restcall.call_req(
+ base_url=ignorcase_get(vnfm_info, "url"),
+ user=ignorcase_get(vnfm_info, "userName"),
+ passwd=ignorcase_get(vnfm_info, "password"),
+ auth_type=restcall.rest_no_auth,
+ resource='/api/v1/nf_m_i/nfs/{vnfInstanceID}/vms/operation'.format(vnfInstanceID=vnfInstanceId),
+ method='post',
+ content=json.JSONEncoder().encode(req_data))
+ logger.debug("ret=%s", ret)
+ if ret[0] != 0:
+ raise Exception('heal error')
+
+ healRespSerializer = InstScaleHealRespSerializer(data=json.JSONDecoder().decode(ret[1]))
+ if not healRespSerializer.is_valid():
+ raise Exception(healRespSerializer.errors)
+
+ logger.debug("healRespSerializer.data=%s", healRespSerializer.data)
+ return Response(data=healRespSerializer.data, status=status.HTTP_202_ACCEPTED)
+ except Exception as e:
+ logger.error("Error occurred when healing VNF,error:%s", e.message)
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'Heal expection'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
def get_vdus(nf_model, aspect_id):
@@ -499,6 +611,10 @@ def get_vdus(nf_model, aspect_id):
return members
-@api_view(http_method_names=['GET'])
-def samples(request, *args, **kwargs):
- return Response(data={"status": "ok"})
+class SampleList(APIView):
+ @swagger_auto_schema(
+ responses={
+ status.HTTP_200_OK: 'Successfully'})
+ def get(self, request):
+ logger.debug("get")
+ return Response({"status": "active"})
diff --git a/zte/vmanager/driver/settings.py b/zte/vmanager/driver/settings.py
index f5923e22..c9fe74c2 100644
--- a/zte/vmanager/driver/settings.py
+++ b/zte/vmanager/driver/settings.py
@@ -16,7 +16,6 @@ import os
import sys
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
-from driver.pub.config import config
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
@@ -30,7 +29,7 @@ SECRET_KEY = '3o-wney!99y)^h3v)0$j16l9=fdjxcb+a8g+q3tfbahcnu2b0o'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
-ALLOWED_HOSTS = []
+ALLOWED_HOSTS = ['*']
# Application definition
@@ -43,7 +42,8 @@ INSTALLED_APPS = [
'django.contrib.staticfiles',
'rest_framework',
'driver.pub.database',
- 'driver.interfaces'
+ 'driver.interfaces',
+ 'drf_yasg',
]
MIDDLEWARE_CLASSES = [
@@ -64,28 +64,45 @@ WSGI_APPLICATION = 'driver.wsgi.application'
REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': (
- 'rest_framework.renderers.JSONRenderer',),
+ 'rest_framework.renderers.JSONRenderer',
+ ),
'DEFAULT_PARSER_CLASSES': (
+ 'rest_framework.parsers.JSONParser',
'rest_framework.parsers.MultiPartParser',
- 'rest_framework.parsers.JSONParser')}
-"""
-DATABASES = {
- 'default': {
- 'ENGINE': 'django.db.backends.mysql',
- 'NAME': 'vmanager',
- 'HOST': 'localhost',
- 'USER': 'root',
- 'PASSWORD':'password',
+ )
+}
+
+# drf-yasg
+TEMPLATES = [
+ {
+ 'BACKEND': 'django.template.backends.django.DjangoTemplates',
+ 'DIRS': [],
+ 'APP_DIRS': True,
+ 'OPTIONS': {
+ 'context_processors': [
+ 'django.template.context_processors.debug',
+ 'django.template.context_processors.request',
+ 'django.contrib.auth.context_processors.auth',
+ 'django.contrib.messages.context_processors.messages',
+ ],
+ },
},
+]
+
+SWAGGER_SETTINGS = {
+ 'LOGIN_URL': '/admin/login',
+ 'LOGOUT_URL': '/admin/logout',
+
+ 'DEFAULT_INFO': 'driver.swagger.urls.swagger_info'
}
-redis_client = redis.StrictRedis(host='127.0.0.1', port=6379, password='', db=1)
-"""
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
- 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), }}
+ 'NAME': ':memory:',
+ },
+}
TIME_ZONE = 'UTC'
@@ -99,24 +116,32 @@ LOGGING = {
'disable_existing_loggers': True,
'formatters': {
'standard': {
- 'format': '%(asctime)s:[%(name)s]:[%(filename)s]-[%(lineno)d] [%(levelname)s]:%(message)s', }, },
- 'filters': {},
+ 'format': '%(asctime)s:[%(name)s]:[%(filename)s]-[%(lineno)d] [%(levelname)s]:%(message)s',
+ },
+ },
+ 'filters': {
+ },
'handlers': {
'driver_handler': {
'level': 'DEBUG',
'class': 'logging.handlers.RotatingFileHandler',
- 'filename': os.path.join(BASE_DIR, 'logs/runtime_driver.log'),
+ 'filename': os.path.join(
+ BASE_DIR,
+ 'logs/runtime_driver.log'),
'formatter': 'standard',
'maxBytes': 1024 * 1024 * 50,
- 'backupCount': 5, }, },
-
+ 'backupCount': 5,
+ },
+ },
'loggers': {
'driver': {
'handlers': ['driver_handler'],
'level': 'DEBUG',
- 'propagate': False}, }}
+ 'propagate': False},
+ }}
if 'test' in sys.argv:
+ from driver.pub.config import config
config.REG_TO_MSB_WHEN_START = False
REST_FRAMEWORK = {}
import platform
diff --git a/zte/vmanager/driver/swagger/swagger.json b/zte/vmanager/driver/swagger/swagger.json
index 0378e6ec..dfe53df9 100644
--- a/zte/vmanager/driver/swagger/swagger.json
+++ b/zte/vmanager/driver/swagger/swagger.json
@@ -4,7 +4,7 @@
"version": "1.0.0",
"title": "ZTE VNFM Driver Service rest API"
},
- "basePath": "/api/{vnfmtype}/v1",
+ "basePath": "/api/ztevnfmdriver/v1",
"tags": [
{
"name": "ztevnfmdriver"
@@ -395,7 +395,7 @@
"vnfInstanceId": {
"type": "string"
},
- "jobid": {
+ "jobId": {
"type": "string"
}
}
diff --git a/zte/vmanager/driver/swagger/urls.py b/zte/vmanager/driver/swagger/urls.py
index d2ee8110..dc377d31 100644
--- a/zte/vmanager/driver/swagger/urls.py
+++ b/zte/vmanager/driver/swagger/urls.py
@@ -13,8 +13,30 @@
# limitations under the License.
from django.conf.urls import url
-from driver.swagger import views
+from drf_yasg import openapi
+from drf_yasg.views import get_schema_view
+from rest_framework import permissions
+
+swagger_info = openapi.Info(
+ title="vfc-ztevnfmdriver API",
+ default_version='v1',
+ description="""
+
+The `swagger-ui` view can be found [here](/api/ztevnfmdriver/v1/swagger).
+The `ReDoc` view can be found [here](/api/ztevnfmdriver/v1/redoc).
+The swagger YAML document can be found [here](/api/ztevnfmdriver/v1/swagger.yaml).
+The swagger JSON document can be found [here](/api/ztevnfmdriver/v1/swagger.json)."""
+)
+
+SchemaView = get_schema_view(
+ validators=['ssv', 'flex'],
+ public=True,
+ permission_classes=(permissions.AllowAny,),
+)
urlpatterns = [
- url(r'^api/ztevnfmdriver/v1/swagger.json$', views.SwaggerView.as_view()),
+ # url(r'^api/ztevnfmdriver/v1/swagger.json$', views.SwaggerView.as_view()),
+ url(r'^api/ztevnfmdriver/v1/swagger(?P<format>.json|.yaml)$', SchemaView.without_ui(cache_timeout=0), name='schema-json'),
+ url(r'^api/ztevnfmdriver/v1/swagger$', SchemaView.with_ui('swagger', cache_timeout=0), name='schema-swagger-ui'),
+ url(r'^api/ztevnfmdriver/v1/redoc$', SchemaView.with_ui('redoc', cache_timeout=0), name='schema-redoc')
]
diff --git a/zte/vmanager/driver/swagger/views.py b/zte/vmanager/driver/swagger/views.py
index e9c96043..400d6dd1 100644
--- a/zte/vmanager/driver/swagger/views.py
+++ b/zte/vmanager/driver/swagger/views.py
@@ -18,9 +18,6 @@ from rest_framework.response import Response
class SwaggerView(APIView):
- """
- Show rest api swagger.
- """
def get(self, request, format=None):
json_file = os.path.join(os.path.dirname(__file__), 'swagger.json')
f = open(json_file)
diff --git a/zte/vmanager/pom.xml b/zte/vmanager/pom.xml
index fd8ed693..f6a20dcf 100644
--- a/zte/vmanager/pom.xml
+++ b/zte/vmanager/pom.xml
@@ -25,7 +25,17 @@
<artifactId>vfc-nfvo-driver-vnfm-svnfm-zte-vmanager</artifactId>
<version>1.1.0-SNAPSHOT</version>
<packaging>pom</packaging>
- <name>vfc/nfvo/driver/vnfm/svnfm/zte/vmanager</name>
+ <name>vfc-nfvo-driver-vnfm-svnfm-zte</name>
+ <properties>
+ <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+ <sonar.sources>.</sonar.sources>
+ <sonar.junit.reportsPath>xunit-results.xml</sonar.junit.reportsPath>
+ <sonar.python.coverage.reportPath>coverage.xml</sonar.python.coverage.reportPath>
+ <sonar.language>py</sonar.language>
+ <sonar.pluginname>python</sonar.pluginname>
+ <sonar.inclusions>**/**.py</sonar.inclusions>
+ <sonar.exclusions>**/tests/**.py,**/test*.py,**/__init__.py,setup.py</sonar.exclusions>
+ </properties>
<description>vfc nfvo driver-vnfm-svnfm-zte-vmanager</description>
<build>
<plugins>
diff --git a/zte/vmanager/requirements.txt b/zte/vmanager/requirements.txt
index 49f0e42e..8b15738c 100644
--- a/zte/vmanager/requirements.txt
+++ b/zte/vmanager/requirements.txt
@@ -1,6 +1,6 @@
# rest framework
-Django==1.9.6
-djangorestframework==3.3.3
+Django==1.11.9
+djangorestframework==3.7.7
# for call rest api
httplib2==0.9.2
@@ -9,3 +9,8 @@ httplib2==0.9.2
coverage==4.2
mock==2.0.0
unittest_xml_reporting==1.12.0
+
+# for auto swagger
+drf-yasg>=1.2.2
+flex>=6.11.1
+swagger-spec-validator>=2.1.0 \ No newline at end of file
diff --git a/zte/vmanager/tox.ini b/zte/vmanager/tox.ini
index 2d18a624..98d17830 100644
--- a/zte/vmanager/tox.ini
+++ b/zte/vmanager/tox.ini
@@ -8,6 +8,7 @@ commands = coverage run --branch manage.py test
[flake8]
ignore = E501,E722
+exclude = ./venv-tox,./.tox
max-complexity = 12
[testenv:pep8]
@@ -19,4 +20,4 @@ commands =
{[testenv]commands}
[testenv:cov]
-commands = coverage html --omit="*test_*,*__init__.py,*site-packages*" -d htmlcov \ No newline at end of file
+commands = coverage xml --omit="*test*,*__init__.py,*site-packages*" \ No newline at end of file