/*- * ============LICENSE_START======================================================= * ONAP - SO * ================================================================================ * Copyright (C) 2020 Nokia Intellectual Property. All rights reserved. * ================================================================================ * 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. * ============LICENSE_END========================================================= */ package org.onap.so.client.orchestration; import com.google.common.base.Strings; import java.util.Optional; import org.onap.aai.domain.yang.RelatedToProperty; import org.onap.aai.domain.yang.Relationship; import org.onap.aai.domain.yang.RelationshipData; import org.onap.so.bpmn.common.InjectionHelper; import org.onap.so.bpmn.servicedecomposition.bbobjects.Pnf; import org.onap.so.bpmn.servicedecomposition.bbobjects.ServiceInstance; import org.onap.aaiclient.client.aai.AAIObjectType; import org.onap.aaiclient.client.aai.entities.uri.AAIResourceUri; import org.onap.aaiclient.client.aai.entities.uri.AAIUriFactory; import org.onap.so.client.aai.mapper.AAIObjectMapper; import org.onap.so.db.catalog.beans.OrchestrationStatus; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @Component public class AAIPnfResources { private static final Logger logger = LoggerFactory.getLogger(AAIPnfResources.class); @Autowired private InjectionHelper injectionHelper; @Autowired private AAIObjectMapper aaiObjectMapper; public void createPnfAndConnectServiceInstance(Pnf pnf, ServiceInstance serviceInstance) { AAIResourceUri pnfURI = AAIUriFactory.createResourceUri(AAIObjectType.PNF, pnf.getPnfName()); pnf.setOrchestrationStatus(OrchestrationStatus.INVENTORIED); AAIResourceUri serviceInstanceURI = AAIUriFactory.createResourceUri(AAIObjectType.SERVICE_INSTANCE, serviceInstance.getServiceInstanceId()); injectionHelper.getAaiClient().createIfNotExists(pnfURI, Optional.of(aaiObjectMapper.mapPnf(pnf))) .connect(pnfURI, serviceInstanceURI); } public void updateOrchestrationStatusPnf(Pnf pnf, OrchestrationStatus orchestrationStatus) { AAIResourceUri pnfURI = AAIUriFactory.createResourceUri(AAIObjectType.PNF, pnf.getPnfName()); Pnf pnfCopy = pnf.shallowCopyId(); pnf.setOrchestrationStatus(orchestrationStatus); pnfCopy.setOrchestrationStatus(orchestrationStatus); injectionHelper.getAaiClient().update(pnfURI, aaiObjectMapper.mapPnf(pnfCopy)); } public void checkIfPnfExistsInAaiAndCanBeUsed(String pnfName) throws Exception { Optional pnfFromAai = injectionHelper.getAaiClient() .get(org.onap.aai.domain.yang.Pnf.class, AAIUriFactory.createResourceUri(AAIObjectType.PNF, pnfName)); if (pnfFromAai.isPresent()) { checkIfPnfCanBeUsed(pnfFromAai.get()); } } private void checkIfPnfCanBeUsed(org.onap.aai.domain.yang.Pnf pnfFromAai) throws Exception { isRelatedToService(pnfFromAai); if (isOrchestrationStatusSet(pnfFromAai)) { checkOrchestrationStatusOfExistingPnf(pnfFromAai); } } private boolean isOrchestrationStatusSet(org.onap.aai.domain.yang.Pnf pnfFromAai) { if (Strings.isNullOrEmpty(pnfFromAai.getOrchestrationStatus())) { logger.debug("pnf with name {} already exists with not set orchestration status and can be used", pnfFromAai.getPnfName()); return false; } return true; } private void checkOrchestrationStatusOfExistingPnf(org.onap.aai.domain.yang.Pnf pnfFromAai) throws Exception { if (OrchestrationStatus.INVENTORIED.toString().equals(pnfFromAai.getOrchestrationStatus())) { logger.debug("pnf with name {} already exists with orchestration status Inventoried and can be used", pnfFromAai.getPnfName()); } else { String errorMessage = String.format( "pnf with name %s already exists with orchestration status %s, existing pnf can be used only " + "if status is not set or set as Inventoried", pnfFromAai.getPnfName(), pnfFromAai.getOrchestrationStatus()); logger.error(errorMessage); throw new Exception(errorMessage); } } private void isRelatedToService(org.onap.aai.domain.yang.Pnf pnfFromAai) throws Exception { if (pnfFromAai.getRelationshipList() != null) { for (Relationship relationship : pnfFromAai.getRelationshipList().getRelationship()) { if (relationship.getRelatedTo().equals("service-instance")) { String errorMessage = prepareRelationErrorMessage(pnfFromAai, relationship); logger.error(errorMessage); throw new Exception(errorMessage); } } } } private String prepareRelationErrorMessage(org.onap.aai.domain.yang.Pnf pnfFromAai, Relationship relationship) { String serviceInstanceName = ""; String serviceInstanceId = ""; for (RelationshipData relationshipData : relationship.getRelationshipData()) { if (relationshipData.getRelationshipKey().equals("service-instance.service-instance-id")) { serviceInstanceId = relationshipData.getRelationshipValue(); break; } } for (RelatedToProperty relatedToProperty : relationship.getRelatedToProperty()) { if (relatedToProperty.getPropertyKey().equals("service-instance.service-instance-name")) { serviceInstanceName = relatedToProperty.getPropertyValue(); break; } } return String.format( "Pnf with name %s exist with orchestration status %s and is related to %s service with certain service-instance-id: %s", pnfFromAai.getPnfName(), pnfFromAai.getOrchestrationStatus(), serviceInstanceName, serviceInstanceId); } }