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.sdc.versioning.types.VersionableEntityAction;
20 import org.openecomp.sdcrests.vendorsoftwareproducts.types.MonitoringUploadStatusDto;
21 import org.openecomp.sdcrests.vsp.rest.ComponentMonitoringUploads;
22 import org.openecomp.sdcrests.vsp.rest.mapping.MapMonitoringUploadStatusToDto;
23 import org.springframework.context.annotation.Scope;
24 import org.springframework.stereotype.Service;
26 import javax.inject.Named;
27 import javax.ws.rs.core.Response;
28 import java.io.InputStream;
32 * @since June 26, 2017
36 @Service("componentMonitoringUploads")
37 @Scope(value = "prototype")
39 public class ComponentMonitoringUploadsImpl implements ComponentMonitoringUploads {
40 private static MdcDataDebugMessage mdcDataDebugMessage = new MdcDataDebugMessage();
41 private MonitoringUploadsManager
42 monitoringUploadsManager = MonitoringUploadsManagerFactory.getInstance().createInterface();
43 private ComponentManager componentManager =
44 ComponentManagerFactory.getInstance().createInterface();
45 private static final Logger logger =
46 LoggerFactory.getLogger(ComponentMonitoringUploadsImpl.class);
49 public Response upload(Attachment attachment,
50 String vspId, String versionId, String componentId, String type,
51 String user) throws Exception {
52 mdcDataDebugMessage.debugEntryMessage("VSP id, component id", vspId + "," + componentId);
53 MdcUtil.initMdc(LoggerServiceName.Upload_Monitoring_Artifact.toString());
54 logger.audit(AuditMessages.AUDIT_MSG + String.format(AuditMessages
55 .UPLOAD_MONITORING_FILE, type, vspId, componentId));
57 Version version = resolveVspVersion(vspId, null, user, VersionableEntityAction.Write);
58 componentManager.validateComponentExistence(vspId, version, componentId, user);
60 MonitoringUploadType monitoringUploadType = getMonitoringUploadType(vspId, componentId, type);
61 monitoringUploadsManager.upload(attachment.getObject(InputStream.class),
62 attachment.getContentDisposition().getParameter("filename"), vspId, version, componentId,
63 monitoringUploadType, user);
65 mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
66 return Response.ok().build();
69 private MonitoringUploadType getMonitoringUploadType(String vspId, String componentId,
70 String type) throws Exception {
71 MonitoringUploadType monitoringUploadType;
73 monitoringUploadType = MonitoringUploadType.valueOf(type);
74 } catch (IllegalArgumentException exception) {
75 String errorWithParameters = ErrorMessagesFormatBuilder
76 .getErrorWithParameters(Messages.ILLEGAL_MONITORING_ARTIFACT_TYPE.getErrorMessage(),
78 throw new Exception(errorWithParameters, exception);
80 return monitoringUploadType;
84 public Response delete(String vspId, String versionId, String componentId,
85 String type, String user) throws Exception {
86 mdcDataDebugMessage.debugEntryMessage("VSP id, component id", vspId + "," + componentId);
87 MdcUtil.initMdc(LoggerServiceName.Delete_Monitoring_Artifact.toString());
89 MonitoringUploadType monitoringUploadType = getMonitoringUploadType(vspId, componentId, type);
91 Version version = resolveVspVersion(vspId, null, user, VersionableEntityAction.Write);
92 componentManager.validateComponentExistence(vspId, version, componentId, user);
93 monitoringUploadsManager
94 .delete(vspId, version, componentId, monitoringUploadType, user);
96 mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
97 return Response.ok().build();
101 public Response list(String vspId, String versionId, String componentId,
103 MdcUtil.initMdc(LoggerServiceName.List_Monitoring_Artifacts.toString());
105 Version version = resolveVspVersion(vspId, versionId, user, VersionableEntityAction.Read);
106 componentManager.validateComponentExistence(vspId, version, componentId, user);
108 MonitoringUploadStatus response = monitoringUploadsManager
109 .listFilenames(vspId, version, componentId, user);
111 MonitoringUploadStatusDto returnEntity =
112 new MapMonitoringUploadStatusToDto()
113 .applyMapping(response, MonitoringUploadStatusDto.class);
114 return Response.status(Response.Status.OK).entity(returnEntity).build();