2  * ============LICENSE_START=======================================================
 
   4  * ================================================================================
 
   5  * Copyright (C) 2017 - 2019 AT&T Intellectual Property. All rights reserved.
 
   6  * ================================================================================
 
   7  * Modifications Copyright (c) 2019 Samsung
 
   8  * ================================================================================
 
   9  * Licensed under the Apache License, Version 2.0 (the "License");
 
  10  * you may not use this file except in compliance with the License.
 
  11  * You may obtain a copy of the License at
 
  13  *      http://www.apache.org/licenses/LICENSE-2.0
 
  15  * Unless required by applicable law or agreed to in writing, software
 
  16  * distributed under the License is distributed on an "AS IS" BASIS,
 
  17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  18  * See the License for the specific language governing permissions and
 
  19  * limitations under the License.
 
  20  * ============LICENSE_END=========================================================
 
  23 package org.onap.so.apihandlerinfra.infra.rest;
 
  25 import javax.transaction.Transactional;
 
  26 import javax.ws.rs.Consumes;
 
  27 import javax.ws.rs.DELETE;
 
  28 import javax.ws.rs.Path;
 
  29 import javax.ws.rs.PathParam;
 
  30 import javax.ws.rs.Produces;
 
  31 import javax.ws.rs.container.ContainerRequestContext;
 
  32 import javax.ws.rs.core.Context;
 
  33 import javax.ws.rs.core.MediaType;
 
  34 import javax.ws.rs.core.Response;
 
  35 import org.onap.logging.ref.slf4j.ONAPLogConstants;
 
  36 import org.onap.so.apihandler.filters.ResponseUpdater;
 
  37 import org.onap.so.apihandlerinfra.infra.rest.handler.VnfRestHandler;
 
  38 import org.onap.so.db.catalog.beans.Recipe;
 
  39 import org.onap.so.db.request.beans.InfraActiveRequests;
 
  40 import org.onap.so.serviceinstancebeans.ServiceInstancesRequest;
 
  41 import org.onap.so.serviceinstancebeans.ServiceInstancesResponse;
 
  43 import org.springframework.beans.factory.annotation.Autowired;
 
  44 import org.springframework.http.HttpStatus;
 
  45 import org.springframework.stereotype.Component;
 
  46 import io.swagger.v3.oas.annotations.Operation;
 
  47 import io.swagger.v3.oas.annotations.media.ArraySchema;
 
  48 import io.swagger.v3.oas.annotations.media.Content;
 
  49 import io.swagger.v3.oas.annotations.media.Schema;
 
  50 import io.swagger.v3.oas.annotations.responses.ApiResponse;
 
  53 @Path("/onap/so/infra/serviceInstantiation")
 
  57     private BpmnRequestBuilder requestBuilder;
 
  60     private VnfRestHandler vnfRestHandler;
 
  64     @Path("/{version:[vV][8]}/serviceInstances/{serviceInstanceId}/vnfs/{vnfInstanceId}")
 
  65     @Consumes(MediaType.APPLICATION_JSON)
 
  66     @Produces(MediaType.APPLICATION_JSON)
 
  67     @Operation(description = "Delete a Vnf instance", responses = @ApiResponse(content = @Content(
 
  68             array = @ArraySchema(schema = @Schema(implementation = ServiceInstancesResponse.class)))))
 
  70     public Response deleteVnfInstance(@PathParam("version") String version,
 
  71             @PathParam("serviceInstanceId") String serviceInstanceId, @PathParam("vnfInstanceId") String vnfInstanceId,
 
  72             @Context ContainerRequestContext requestContext) throws Exception {
 
  73         InfraActiveRequests currentRequest = null;
 
  74         String requestId = vnfRestHandler.getRequestId(requestContext);
 
  75         String requestorId = "Unknown";
 
  76         String source = MDC.get(ONAPLogConstants.MDCs.PARTNER_NAME);
 
  77         String requestURL = requestContext.getUriInfo().getAbsolutePath().toString();
 
  78         currentRequest = vnfRestHandler.createInfraActiveRequestForDelete(requestId, serviceInstanceId, vnfInstanceId,
 
  79                 requestorId, source, requestURL);
 
  80         ServiceInstancesRequest request = requestBuilder.buildVnfDeleteRequest(vnfInstanceId);
 
  81         vnfRestHandler.saveInstanceName(request, currentRequest);
 
  82         vnfRestHandler.checkDuplicateRequest(serviceInstanceId, vnfInstanceId,
 
  83                 request.getRequestDetails().getRequestInfo().getInstanceName(), currentRequest.getRequestId());
 
  84         Recipe recipe = vnfRestHandler.findVnfModuleRecipe(
 
  85                 request.getRequestDetails().getModelInfo().getModelCustomizationId(), "vnf", "deleteInstance");
 
  86         vnfRestHandler.callWorkflowEngine(vnfRestHandler.buildRequestParams(request,
 
  87                 vnfRestHandler.getRequestUri(requestContext), requestId, serviceInstanceId, vnfInstanceId),
 
  88                 recipe.getOrchestrationUri());
 
  89         ServiceInstancesResponse response = vnfRestHandler.createResponse(vnfInstanceId, requestId, requestContext);
 
  90         return Response.status(HttpStatus.ACCEPTED.value()).entity(response).build();