Add collaboration feature
[sdc.git] / openecomp-be / api / openecomp-sdc-rest-webapp / vendor-software-products-rest / vendor-software-products-rest-services / src / main / java / org / openecomp / sdcrests / vsp / rest / services / ComponentMonitoringUploadsImpl.java
1 package org.openecomp.sdcrests.vsp.rest.services;
2
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;
24
25 import javax.inject.Named;
26 import javax.ws.rs.core.Response;
27 import java.io.InputStream;
28
29 /**
30  * @author katyr
31  * @since June 26, 2017
32  */
33
34 @Named
35 @Service("componentMonitoringUploads")
36 @Scope(value = "prototype")
37 //@Validated
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);
46
47   @Override
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));
55
56     Version version = new Version(versionId);
57     componentManager.validateComponentExistence(vspId, version, componentId);
58
59     MonitoringUploadType monitoringUploadType = getMonitoringUploadType(vspId, componentId, type);
60     monitoringUploadsManager.upload(attachment.getObject(InputStream.class),
61         attachment.getContentDisposition().getParameter("filename"), vspId, version, componentId,
62         monitoringUploadType);
63
64     mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
65     return Response.ok().build();
66   }
67
68   private MonitoringUploadType getMonitoringUploadType(String vspId, String componentId,
69                                                        String type) throws Exception {
70     MonitoringUploadType monitoringUploadType;
71     try {
72       monitoringUploadType = MonitoringUploadType.valueOf(type);
73     } catch (IllegalArgumentException exception) {
74       String errorWithParameters = ErrorMessagesFormatBuilder
75           .getErrorWithParameters(Messages.ILLEGAL_MONITORING_ARTIFACT_TYPE.getErrorMessage(),
76               componentId, vspId);
77       throw new Exception(errorWithParameters, exception);
78     }
79     return monitoringUploadType;
80   }
81
82   @Override
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());
87
88     MonitoringUploadType monitoringUploadType = getMonitoringUploadType(vspId, componentId, type);
89
90     Version version = new Version(versionId);
91     componentManager.validateComponentExistence(vspId, version, componentId);
92     monitoringUploadsManager.delete(vspId, version, componentId, monitoringUploadType);
93
94     mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
95     return Response.ok().build();
96   }
97
98   @Override
99   public Response list(String vspId, String versionId, String componentId,
100                        String user) {
101     MdcUtil.initMdc(LoggerServiceName.List_Monitoring_Artifacts.toString());
102
103     Version version = new Version(versionId);
104     componentManager.validateComponentExistence(vspId, version, componentId);
105
106     MonitoringUploadStatus response =
107         monitoringUploadsManager.listFilenames(vspId, version, componentId);
108
109     MonitoringUploadStatusDto returnEntity =
110         new MapMonitoringUploadStatusToDto()
111             .applyMapping(response, MonitoringUploadStatusDto.class);
112     return Response.status(Response.Status.OK).entity(returnEntity).build();
113   }
114 }