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