1 package org.openecomp.sdcrests.vsp.rest.services;
3 import org.apache.cxf.jaxrs.ext.multipart.Attachment;
4 import org.openecomp.core.enrichment.types.MonitoringUploadType;
5 import org.openecomp.core.validation.errors.ErrorMessagesFormatBuilder;
6 import org.openecomp.sdc.common.errors.Messages;
7 import org.openecomp.sdc.logging.api.Logger;
8 import org.openecomp.sdc.logging.api.LoggerFactory;
9 import org.openecomp.sdc.logging.context.MdcUtil;
10 import org.openecomp.sdc.logging.context.impl.MdcDataDebugMessage;
11 import org.openecomp.sdc.logging.messages.AuditMessages;
12 import org.openecomp.sdc.logging.types.LoggerServiceName;
13 import org.openecomp.sdc.vendorsoftwareproduct.ComponentManager;
14 import org.openecomp.sdc.vendorsoftwareproduct.ComponentManagerFactory;
15 import org.openecomp.sdc.vendorsoftwareproduct.MonitoringUploadsManager;
16 import org.openecomp.sdc.vendorsoftwareproduct.MonitoringUploadsManagerFactory;
17 import org.openecomp.sdc.vendorsoftwareproduct.types.schemagenerator.MonitoringUploadStatus;
18 import org.openecomp.sdc.versioning.dao.types.Version;
19 import org.openecomp.sdcrests.vendorsoftwareproducts.types.MonitoringUploadStatusDto;
20 import org.openecomp.sdcrests.vsp.rest.ComponentMonitoringUploads;
21 import org.openecomp.sdcrests.vsp.rest.mapping.MapMonitoringUploadStatusToDto;
22 import org.springframework.context.annotation.Scope;
23 import org.springframework.stereotype.Service;
25 import javax.inject.Named;
26 import javax.ws.rs.core.Response;
27 import java.io.InputStream;
31 * @since June 26, 2017
35 @Service("componentMonitoringUploads")
36 @Scope(value = "prototype")
38 public class ComponentMonitoringUploadsImpl implements ComponentMonitoringUploads {
39 private static MdcDataDebugMessage mdcDataDebugMessage = new MdcDataDebugMessage();
40 private MonitoringUploadsManager
41 monitoringUploadsManager = MonitoringUploadsManagerFactory.getInstance().createInterface();
42 private ComponentManager componentManager =
43 ComponentManagerFactory.getInstance().createInterface();
44 private static final Logger logger =
45 LoggerFactory.getLogger(ComponentMonitoringUploadsImpl.class);
48 public Response upload(Attachment attachment,
49 String vspId, String versionId, String componentId, String type,
50 String user) throws Exception {
51 mdcDataDebugMessage.debugEntryMessage("VSP id, component id", vspId + "," + componentId);
52 MdcUtil.initMdc(LoggerServiceName.Upload_Monitoring_Artifact.toString());
53 logger.audit(AuditMessages.AUDIT_MSG + String.format(AuditMessages
54 .UPLOAD_MONITORING_FILE, type, vspId, componentId));
56 Version version = new Version(versionId);
57 componentManager.validateComponentExistence(vspId, version, componentId);
59 MonitoringUploadType monitoringUploadType = getMonitoringUploadType(vspId, componentId, type);
60 monitoringUploadsManager.upload(attachment.getObject(InputStream.class),
61 attachment.getContentDisposition().getParameter("filename"), vspId, version, componentId,
62 monitoringUploadType);
64 mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
65 return Response.ok().build();
68 private MonitoringUploadType getMonitoringUploadType(String vspId, String componentId,
69 String type) throws Exception {
70 MonitoringUploadType monitoringUploadType;
72 monitoringUploadType = MonitoringUploadType.valueOf(type);
73 } catch (IllegalArgumentException exception) {
74 String errorWithParameters = ErrorMessagesFormatBuilder
75 .getErrorWithParameters(Messages.ILLEGAL_MONITORING_ARTIFACT_TYPE.getErrorMessage(),
77 throw new Exception(errorWithParameters, exception);
79 return monitoringUploadType;
83 public Response delete(String vspId, String versionId, String componentId,
84 String type, String user) throws Exception {
85 mdcDataDebugMessage.debugEntryMessage("VSP id, component id", vspId + "," + componentId);
86 MdcUtil.initMdc(LoggerServiceName.Delete_Monitoring_Artifact.toString());
88 MonitoringUploadType monitoringUploadType = getMonitoringUploadType(vspId, componentId, type);
90 Version version = new Version(versionId);
91 componentManager.validateComponentExistence(vspId, version, componentId);
92 monitoringUploadsManager.delete(vspId, version, componentId, monitoringUploadType);
94 mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
95 return Response.ok().build();
99 public Response list(String vspId, String versionId, String componentId,
101 MdcUtil.initMdc(LoggerServiceName.List_Monitoring_Artifacts.toString());
103 Version version = new Version(versionId);
104 componentManager.validateComponentExistence(vspId, version, componentId);
106 MonitoringUploadStatus response =
107 monitoringUploadsManager.listFilenames(vspId, version, componentId);
109 MonitoringUploadStatusDto returnEntity =
110 new MapMonitoringUploadStatusToDto()
111 .applyMapping(response, MonitoringUploadStatusDto.class);
112 return Response.status(Response.Status.OK).entity(returnEntity).build();