Remove unused logger,replace type specification
[so.git] / bpmn / so-bpmn-tasks / src / main / java / org / onap / so / client / sdnc / mapper / VfModuleTopologyOperationRequestMapper.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP - SO
4  * ================================================================================
5  * Copyright (C) 2017 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
12  * 
13  *      http://www.apache.org/licenses/LICENSE-2.0
14  * 
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=========================================================
21  */
22
23 package org.onap.so.client.sdnc.mapper;
24
25 import java.util.Map;
26 import java.util.UUID;
27 import org.onap.sdnc.northbound.client.model.GenericResourceApiParam;
28 import org.onap.sdnc.northbound.client.model.GenericResourceApiParamParam;
29 import org.onap.sdnc.northbound.client.model.GenericResourceApiRequestActionEnumeration;
30 import org.onap.sdnc.northbound.client.model.GenericResourceApiRequestinformationRequestInformation;
31 import org.onap.sdnc.northbound.client.model.GenericResourceApiSdncrequestheaderSdncRequestHeader;
32 import org.onap.sdnc.northbound.client.model.GenericResourceApiServiceinformationServiceInformation;
33 import org.onap.sdnc.northbound.client.model.GenericResourceApiSvcActionEnumeration;
34 import org.onap.sdnc.northbound.client.model.GenericResourceApiVfModuleOperationInformation;
35 import org.onap.sdnc.northbound.client.model.GenericResourceApiVfModuleResponseInformation;
36 import org.onap.sdnc.northbound.client.model.GenericResourceApiVfmoduleinformationVfModuleInformation;
37 import org.onap.sdnc.northbound.client.model.GenericResourceApiVfmodulerequestinputVfModuleRequestInput;
38 import org.onap.sdnc.northbound.client.model.GenericResourceApiVnfinformationVnfInformation;
39 import org.onap.so.bpmn.servicedecomposition.bbobjects.CloudRegion;
40 import org.onap.so.bpmn.servicedecomposition.bbobjects.Customer;
41 import org.onap.so.bpmn.servicedecomposition.bbobjects.GenericVnf;
42 import org.onap.so.bpmn.servicedecomposition.bbobjects.ServiceInstance;
43 import org.onap.so.bpmn.servicedecomposition.bbobjects.VfModule;
44 import org.onap.so.bpmn.servicedecomposition.bbobjects.VolumeGroup;
45 import org.onap.so.bpmn.servicedecomposition.generalobjects.RequestContext;
46 import org.onap.so.client.exception.MapperException;
47 import org.onap.so.client.sdnc.beans.SDNCSvcAction;
48 import org.onap.so.client.sdnc.beans.SDNCSvcOperation;
49 import org.onap.so.logger.ErrorCode;
50 import org.onap.so.logger.MessageEnum;
51 import org.slf4j.Logger;
52 import org.slf4j.LoggerFactory;
53 import org.springframework.beans.factory.annotation.Autowired;
54 import org.springframework.stereotype.Component;
55 import com.fasterxml.jackson.databind.ObjectMapper;
56
57 @Component
58 public class VfModuleTopologyOperationRequestMapper {
59     private static final Logger logger = LoggerFactory.getLogger(VfModuleTopologyOperationRequestMapper.class);
60
61     @Autowired
62     private GeneralTopologyObjectMapper generalTopologyObjectMapper;
63
64     public GenericResourceApiVfModuleOperationInformation reqMapper(SDNCSvcOperation svcOperation,
65             SDNCSvcAction svcAction, VfModule vfModule, VolumeGroup volumeGroup, GenericVnf vnf,
66             ServiceInstance serviceInstance, Customer customer, CloudRegion cloudRegion, RequestContext requestContext,
67             String sdncAssignResponse) throws MapperException {
68         GenericResourceApiVfModuleOperationInformation req = new GenericResourceApiVfModuleOperationInformation();
69
70         boolean includeModelInformation = false;
71
72         GenericResourceApiRequestActionEnumeration requestAction =
73                 GenericResourceApiRequestActionEnumeration.CREATEVFMODULEINSTANCE;
74         GenericResourceApiSvcActionEnumeration genericResourceApiSvcAction =
75                 GenericResourceApiSvcActionEnumeration.ASSIGN;
76
77         if (svcAction.equals(SDNCSvcAction.ACTIVATE)) {
78             genericResourceApiSvcAction = GenericResourceApiSvcActionEnumeration.ACTIVATE;
79             requestAction = GenericResourceApiRequestActionEnumeration.CREATEVFMODULEINSTANCE;
80             includeModelInformation = true;
81         } else if (svcAction.equals(SDNCSvcAction.ASSIGN)) {
82             genericResourceApiSvcAction = GenericResourceApiSvcActionEnumeration.ASSIGN;
83             requestAction = GenericResourceApiRequestActionEnumeration.CREATEVFMODULEINSTANCE;
84             includeModelInformation = true;
85         } else if (svcAction.equals(SDNCSvcAction.DEACTIVATE)) {
86             genericResourceApiSvcAction = GenericResourceApiSvcActionEnumeration.DEACTIVATE;
87             requestAction = GenericResourceApiRequestActionEnumeration.DELETEVFMODULEINSTANCE;
88             includeModelInformation = false;
89         } else if (svcAction.equals(SDNCSvcAction.DELETE)) {
90             genericResourceApiSvcAction = GenericResourceApiSvcActionEnumeration.DELETE;
91             requestAction = GenericResourceApiRequestActionEnumeration.DELETEVFMODULEINSTANCE;
92             includeModelInformation = false;
93         } else if (svcAction.equals(SDNCSvcAction.UNASSIGN)) {
94             genericResourceApiSvcAction = GenericResourceApiSvcActionEnumeration.UNASSIGN;
95             requestAction = GenericResourceApiRequestActionEnumeration.DELETEVFMODULEINSTANCE;
96             includeModelInformation = false;
97         }
98
99         String sdncReqId = UUID.randomUUID().toString();
100         String msoRequestId = UUID.randomUUID().toString();
101         if (requestContext != null && requestContext.getMsoRequestId() != null) {
102             msoRequestId = requestContext.getMsoRequestId();
103         }
104
105         GenericResourceApiRequestinformationRequestInformation requestInformation = generalTopologyObjectMapper
106                 .buildGenericResourceApiRequestinformationRequestInformation(msoRequestId, requestAction);
107         GenericResourceApiServiceinformationServiceInformation serviceInformation = generalTopologyObjectMapper
108                 .buildServiceInformation(serviceInstance, requestContext, customer, includeModelInformation);
109         GenericResourceApiVnfinformationVnfInformation vnfInformation =
110                 generalTopologyObjectMapper.buildVnfInformation(vnf, serviceInstance, includeModelInformation);
111         GenericResourceApiVfmoduleinformationVfModuleInformation vfModuleInformation = generalTopologyObjectMapper
112                 .buildVfModuleInformation(vfModule, vnf, serviceInstance, requestContext, includeModelInformation);
113         GenericResourceApiVfmodulerequestinputVfModuleRequestInput vfModuleRequestInput =
114                 buildVfModuleRequestInput(vfModule, volumeGroup, cloudRegion, requestContext);
115         GenericResourceApiSdncrequestheaderSdncRequestHeader sdncRequestHeader =
116                 buildVfModuleSdncRequestHeader(sdncReqId, genericResourceApiSvcAction);
117
118         req.setRequestInformation(requestInformation);
119         req.setSdncRequestHeader(sdncRequestHeader);
120         req.setServiceInformation(serviceInformation);
121         req.setVnfInformation(vnfInformation);
122         req.setVfModuleInformation(vfModuleInformation);
123         req.setVfModuleRequestInput(vfModuleRequestInput);
124
125         return req;
126     }
127
128     private GenericResourceApiVfmodulerequestinputVfModuleRequestInput buildVfModuleRequestInput(VfModule vfModule,
129             VolumeGroup volumeGroup, CloudRegion cloudRegion, RequestContext requestContext) {
130         GenericResourceApiVfmodulerequestinputVfModuleRequestInput vfModuleRequestInput =
131                 new GenericResourceApiVfmodulerequestinputVfModuleRequestInput();
132         if (cloudRegion != null) {
133             vfModuleRequestInput.setTenant(cloudRegion.getTenantId());
134             vfModuleRequestInput.setAicCloudRegion(cloudRegion.getLcpCloudRegionId());
135             vfModuleRequestInput.setCloudOwner(cloudRegion.getCloudOwner());
136         }
137         if (vfModule.getVfModuleName() != null && !vfModule.getVfModuleName().equals("")) {
138             vfModuleRequestInput.setVfModuleName(vfModule.getVfModuleName());
139         }
140         GenericResourceApiParam vfModuleInputParameters = new GenericResourceApiParam();
141
142         if (requestContext != null && requestContext.getUserParams() != null) {
143             for (Map.Entry<String, Object> entry : requestContext.getUserParams().entrySet()) {
144                 GenericResourceApiParamParam paramItem = new GenericResourceApiParamParam();
145                 paramItem.setName(entry.getKey());
146                 paramItem.setValue(generalTopologyObjectMapper.mapUserParamValue(entry.getValue()));
147                 vfModuleInputParameters.addParamItem(paramItem);
148             }
149         }
150
151         if (vfModule.getCloudParams() != null) {
152             for (Map.Entry<String, String> entry : vfModule.getCloudParams().entrySet()) {
153                 GenericResourceApiParamParam paramItem = new GenericResourceApiParamParam();
154                 paramItem.setName(entry.getKey());
155                 paramItem.setValue(entry.getValue());
156                 vfModuleInputParameters.addParamItem(paramItem);
157             }
158         }
159
160         if (volumeGroup != null) {
161             GenericResourceApiParamParam paramItem = new GenericResourceApiParamParam();
162             paramItem.setName("volume-group-id");
163             paramItem.setValue(volumeGroup.getVolumeGroupId());
164             vfModuleInputParameters.addParamItem(paramItem);
165         }
166         vfModuleRequestInput.setVfModuleInputParameters(vfModuleInputParameters);
167
168         return vfModuleRequestInput;
169     }
170
171     private GenericResourceApiSdncrequestheaderSdncRequestHeader buildVfModuleSdncRequestHeader(String sdncReqId,
172             GenericResourceApiSvcActionEnumeration svcAction) {
173         GenericResourceApiSdncrequestheaderSdncRequestHeader sdncRequestHeader =
174                 new GenericResourceApiSdncrequestheaderSdncRequestHeader();
175
176         sdncRequestHeader.setSvcRequestId(sdncReqId);
177         sdncRequestHeader.setSvcAction(svcAction);
178
179         return sdncRequestHeader;
180     }
181
182     public String buildObjectPath(String sdncAssignResponse) {
183         String objectPath = null;
184         if (sdncAssignResponse != null) {
185             ObjectMapper mapper = new ObjectMapper();
186             try {
187                 GenericResourceApiVfModuleResponseInformation assignResponseInfo =
188                         mapper.readValue(sdncAssignResponse, GenericResourceApiVfModuleResponseInformation.class);
189                 objectPath = assignResponseInfo.getVfModuleResponseInformation().getObjectPath();
190             } catch (Exception e) {
191                 logger.error("{} {} {} {} {}", MessageEnum.RA_RESPONSE_FROM_SDNC.toString(), e.getMessage(), "BPMN",
192                         ErrorCode.UnknownError.getValue(), e.getMessage());
193             }
194         }
195         return objectPath;
196     }
197 }