6d88e4cacb232612b5e29eeeca24e3948a4532a1
[sdc.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.openecomp.sdcrests.vendorlicense.rest.services;
22
23 import org.openecomp.sdc.logging.api.Logger;
24 import org.openecomp.sdc.logging.api.LoggerFactory;
25 import org.openecomp.sdc.logging.context.MdcUtil;
26 import org.openecomp.sdc.logging.context.impl.MdcDataDebugMessage;
27 import org.openecomp.sdc.logging.messages.AuditMessages;
28 import org.openecomp.sdc.logging.types.LoggerConstants;
29 import org.openecomp.sdc.logging.types.LoggerServiceName;
30 import org.openecomp.sdc.vendorlicense.VendorLicenseManager;
31 import org.openecomp.sdc.vendorlicense.VendorLicenseManagerFactory;
32 import org.openecomp.sdc.vendorlicense.dao.types.VendorLicenseModelEntity;
33 import org.openecomp.sdc.vendorlicense.types.VersionedVendorLicenseModel;
34 import org.openecomp.sdc.vendorsoftwareproduct.VendorSoftwareProductManager;
35 import org.openecomp.sdc.vendorsoftwareproduct.VspManagerFactory;
36 import org.openecomp.sdc.versioning.dao.types.Version;
37 import org.openecomp.sdcrests.vendorlicense.rest.VendorLicenseModels;
38 import org.openecomp.sdcrests.vendorlicense.rest.mapping.MapVendorLicenseModelRequestDtoToVendorLicenseModelEntity;
39 import org.openecomp.sdcrests.vendorlicense.rest.mapping.MapVersionedVendorLicenseModelToVendorLicenseModelEntityDto;
40 import org.openecomp.sdcrests.vendorlicense.types.VendorLicenseModelActionRequestDto;
41 import org.openecomp.sdcrests.vendorlicense.types.VendorLicenseModelEntityDto;
42 import org.openecomp.sdcrests.vendorlicense.types.VendorLicenseModelRequestDto;
43 import org.openecomp.sdcrests.wrappers.GenericCollectionWrapper;
44 import org.openecomp.sdcrests.wrappers.StringWrapperResponse;
45 import org.slf4j.MDC;
46 import org.springframework.beans.factory.annotation.Autowired;
47 import org.springframework.context.annotation.Scope;
48 import org.springframework.stereotype.Service;
49 import org.springframework.validation.annotation.Validated;
50
51 import javax.inject.Named;
52 import javax.ws.rs.core.Response;
53 import java.util.Collection;
54
55 @Named
56 @Service("vendorLicenseModels")
57 @Scope(value = "prototype")
58 @Validated
59 public class VendorLicenseModelsImpl implements VendorLicenseModels {
60
61   private static MdcDataDebugMessage mdcDataDebugMessage = new MdcDataDebugMessage();
62
63   private VendorLicenseManager vendorLicenseManager =
64       VendorLicenseManagerFactory.getInstance().createInterface();
65
66   private static final Logger logger =
67           LoggerFactory.getLogger(VendorLicenseModelsImpl.class);
68
69     @Override
70     public Response listLicenseModels(String versionFilter, String user) {
71
72         mdcDataDebugMessage.debugEntryMessage(null, null);
73         MdcUtil.initMdc(LoggerServiceName.List_VLM.toString());
74         Collection<VersionedVendorLicenseModel> versionedVendorLicenseModels =
75                 vendorLicenseManager.listVendorLicenseModels(versionFilter, user);
76
77         GenericCollectionWrapper<VendorLicenseModelEntityDto> results =
78                 new GenericCollectionWrapper<>();
79         MapVersionedVendorLicenseModelToVendorLicenseModelEntityDto outputMapper =
80                 new MapVersionedVendorLicenseModelToVendorLicenseModelEntityDto();
81         for (VersionedVendorLicenseModel versionedVlm : versionedVendorLicenseModels) {
82             results.add(outputMapper.applyMapping(versionedVlm, VendorLicenseModelEntityDto.class));
83         }
84
85         mdcDataDebugMessage.debugExitMessage(null, null);
86
87         return Response.ok(results).build();
88     }
89
90     @Override
91     public Response createLicenseModel(VendorLicenseModelRequestDto request, String user) {
92
93         mdcDataDebugMessage.debugEntryMessage(null, null);
94
95     logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.CREATE_VLM
96             + request.getVendorName());
97
98     MdcUtil.initMdc(LoggerServiceName.Create_VLM.toString());
99     VendorLicenseModelEntity vendorLicenseModelEntity =
100         new MapVendorLicenseModelRequestDtoToVendorLicenseModelEntity()
101             .applyMapping(request, VendorLicenseModelEntity.class);
102     VendorLicenseModelEntity createdVendorLicenseModel =
103         vendorLicenseManager.createVendorLicenseModel(vendorLicenseModelEntity, user);
104     StringWrapperResponse result = createdVendorLicenseModel != null ? new StringWrapperResponse(
105         createdVendorLicenseModel.getId()) : null;
106
107         mdcDataDebugMessage.debugExitMessage(null, null);
108
109         return Response.ok(result).build();
110     }
111
112     @Override
113     public Response updateLicenseModel(VendorLicenseModelRequestDto request, String vlmId,
114                                        String versionId, String user) {
115
116         mdcDataDebugMessage.debugEntryMessage("VLM id", vlmId);
117
118         MdcUtil.initMdc(LoggerServiceName.Update_VLM.toString());
119         VendorLicenseModelEntity vendorLicenseModelEntity =
120                 new MapVendorLicenseModelRequestDtoToVendorLicenseModelEntity()
121                         .applyMapping(request, VendorLicenseModelEntity.class);
122         vendorLicenseModelEntity.setId(vlmId);
123
124         vendorLicenseManager.updateVendorLicenseModel(vendorLicenseModelEntity, user);
125
126         mdcDataDebugMessage.debugExitMessage("VLM id", vlmId);
127
128         return Response.ok().build();
129     }
130
131     @Override
132     public Response getLicenseModel(String vlmId, String versionId, String user) {
133
134         mdcDataDebugMessage.debugEntryMessage("VLM id", vlmId);
135
136         MdcUtil.initMdc(LoggerServiceName.Get_VLM.toString());
137         VersionedVendorLicenseModel versionedVlm =
138                 vendorLicenseManager.getVendorLicenseModel(vlmId, Version.valueOf(versionId), user);
139
140         VendorLicenseModelEntityDto vlmDto = versionedVlm == null ? null :
141                 new MapVersionedVendorLicenseModelToVendorLicenseModelEntityDto()
142                         .applyMapping(versionedVlm, VendorLicenseModelEntityDto.class);
143
144         mdcDataDebugMessage.debugExitMessage("VLM id", vlmId);
145
146         return Response.ok(vlmDto).build();
147     }
148
149     @Override
150     public Response deleteLicenseModel(String vlmId, String versionId, String user) {
151
152         mdcDataDebugMessage.debugEntryMessage("VLM id", vlmId);
153
154         MdcUtil.initMdc(LoggerServiceName.Delete_VLM.toString());
155         vendorLicenseManager.deleteVendorLicenseModel(vlmId, user);
156
157         mdcDataDebugMessage.debugExitMessage("VLM id", vlmId);
158
159         return Response.ok().build();
160     }
161
162     @Override
163     public Response actOnLicenseModel(VendorLicenseModelActionRequestDto request, String vlmId,
164                                       String versionId, String user) {
165
166     switch (request.getAction()) {
167       case Checkout:
168         MDC.put(LoggerConstants.SERVICE_NAME,
169             LoggerServiceName.Checkout_VLM.toString());
170         logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.CHECK_OUT_VLM
171                 + vlmId);
172         vendorLicenseManager.checkout(vlmId, user);
173         break;
174       case Undo_Checkout:
175         MDC.put(LoggerConstants.SERVICE_NAME,
176             LoggerServiceName.Undo_Checkout_VLM.toString());
177         vendorLicenseManager.undoCheckout(vlmId, user);
178         break;
179       case Checkin:
180         MDC.put(LoggerConstants.SERVICE_NAME,
181             LoggerServiceName.Checkin_VLM.toString());
182         logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.CHECK_IN_VLM
183                 + vlmId);
184         vendorLicenseManager.checkin(vlmId, user);
185         break;
186       case Submit:
187         MDC.put(LoggerConstants.SERVICE_NAME,
188             LoggerServiceName.Submit_VLM.toString());
189         logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.SUBMIT_VLM
190                 + vlmId);
191         vendorLicenseManager.submit(vlmId, user);
192         break;
193       default:
194     }
195
196         return Response.ok().build();
197     }
198 }