2 * ============LICENSE_START=======================================================
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
11 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
21 package org.openecomp.sdcrests.vendorlicense.rest.services;
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;
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;
51 import javax.inject.Named;
52 import javax.ws.rs.core.Response;
53 import java.util.Collection;
56 @Service("vendorLicenseModels")
57 @Scope(value = "prototype")
59 public class VendorLicenseModelsImpl implements VendorLicenseModels {
61 private static MdcDataDebugMessage mdcDataDebugMessage = new MdcDataDebugMessage();
63 private VendorLicenseManager vendorLicenseManager =
64 VendorLicenseManagerFactory.getInstance().createInterface();
66 private static final Logger logger =
67 LoggerFactory.getLogger(VendorLicenseModelsImpl.class);
70 public Response listLicenseModels(String versionFilter, String user) {
72 mdcDataDebugMessage.debugEntryMessage(null, null);
73 MdcUtil.initMdc(LoggerServiceName.List_VLM.toString());
74 Collection<VersionedVendorLicenseModel> versionedVendorLicenseModels =
75 vendorLicenseManager.listVendorLicenseModels(versionFilter, user);
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));
85 mdcDataDebugMessage.debugExitMessage(null, null);
87 return Response.ok(results).build();
91 public Response createLicenseModel(VendorLicenseModelRequestDto request, String user) {
93 mdcDataDebugMessage.debugEntryMessage(null, null);
95 logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.CREATE_VLM
96 + request.getVendorName());
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;
107 mdcDataDebugMessage.debugExitMessage(null, null);
109 return Response.ok(result).build();
113 public Response updateLicenseModel(VendorLicenseModelRequestDto request, String vlmId,
114 String versionId, String user) {
116 mdcDataDebugMessage.debugEntryMessage("VLM id", vlmId);
118 MdcUtil.initMdc(LoggerServiceName.Update_VLM.toString());
119 VendorLicenseModelEntity vendorLicenseModelEntity =
120 new MapVendorLicenseModelRequestDtoToVendorLicenseModelEntity()
121 .applyMapping(request, VendorLicenseModelEntity.class);
122 vendorLicenseModelEntity.setId(vlmId);
124 vendorLicenseManager.updateVendorLicenseModel(vendorLicenseModelEntity, user);
126 mdcDataDebugMessage.debugExitMessage("VLM id", vlmId);
128 return Response.ok().build();
132 public Response getLicenseModel(String vlmId, String versionId, String user) {
134 mdcDataDebugMessage.debugEntryMessage("VLM id", vlmId);
136 MdcUtil.initMdc(LoggerServiceName.Get_VLM.toString());
137 VersionedVendorLicenseModel versionedVlm =
138 vendorLicenseManager.getVendorLicenseModel(vlmId, Version.valueOf(versionId), user);
140 VendorLicenseModelEntityDto vlmDto = versionedVlm == null ? null :
141 new MapVersionedVendorLicenseModelToVendorLicenseModelEntityDto()
142 .applyMapping(versionedVlm, VendorLicenseModelEntityDto.class);
144 mdcDataDebugMessage.debugExitMessage("VLM id", vlmId);
146 return Response.ok(vlmDto).build();
150 public Response deleteLicenseModel(String vlmId, String versionId, String user) {
152 mdcDataDebugMessage.debugEntryMessage("VLM id", vlmId);
154 MdcUtil.initMdc(LoggerServiceName.Delete_VLM.toString());
155 vendorLicenseManager.deleteVendorLicenseModel(vlmId, user);
157 mdcDataDebugMessage.debugExitMessage("VLM id", vlmId);
159 return Response.ok().build();
163 public Response actOnLicenseModel(VendorLicenseModelActionRequestDto request, String vlmId,
164 String versionId, String user) {
166 switch (request.getAction()) {
168 MDC.put(LoggerConstants.SERVICE_NAME,
169 LoggerServiceName.Checkout_VLM.toString());
170 logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.CHECK_OUT_VLM
172 vendorLicenseManager.checkout(vlmId, user);
175 MDC.put(LoggerConstants.SERVICE_NAME,
176 LoggerServiceName.Undo_Checkout_VLM.toString());
177 vendorLicenseManager.undoCheckout(vlmId, user);
180 MDC.put(LoggerConstants.SERVICE_NAME,
181 LoggerServiceName.Checkin_VLM.toString());
182 logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.CHECK_IN_VLM
184 vendorLicenseManager.checkin(vlmId, user);
187 MDC.put(LoggerConstants.SERVICE_NAME,
188 LoggerServiceName.Submit_VLM.toString());
189 logger.audit(AuditMessages.AUDIT_MSG + AuditMessages.SUBMIT_VLM
191 vendorLicenseManager.submit(vlmId, user);
196 return Response.ok().build();