[SDC] Onboarding 1710 rebase.
[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.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;
25
26 import javax.inject.Named;
27 import javax.ws.rs.core.Response;
28 import java.io.InputStream;
29
30 /**
31  * @author katyr
32  * @since June 26, 2017
33  */
34
35 @Named
36 @Service("componentMonitoringUploads")
37 @Scope(value = "prototype")
38 //@Validated
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);
47
48   @Override
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));
56
57     Version version = resolveVspVersion(vspId, null, user, VersionableEntityAction.Write);
58     componentManager.validateComponentExistence(vspId, version, componentId, user);
59
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);
64
65     mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
66     return Response.ok().build();
67   }
68
69   private MonitoringUploadType getMonitoringUploadType(String vspId, String componentId,
70                                                        String type) throws Exception {
71     MonitoringUploadType monitoringUploadType;
72     try {
73       monitoringUploadType = MonitoringUploadType.valueOf(type);
74     } catch (IllegalArgumentException exception) {
75       String errorWithParameters = ErrorMessagesFormatBuilder
76           .getErrorWithParameters(Messages.ILLEGAL_MONITORING_ARTIFACT_TYPE.getErrorMessage(),
77               componentId, vspId);
78       throw new Exception(errorWithParameters, exception);
79     }
80     return monitoringUploadType;
81   }
82
83   @Override
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());
88
89     MonitoringUploadType monitoringUploadType = getMonitoringUploadType(vspId, componentId, type);
90
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);
95
96     mdcDataDebugMessage.debugExitMessage("VSP id, component id", vspId + "," + componentId);
97     return Response.ok().build();
98   }
99
100   @Override
101   public Response list(String vspId, String versionId, String componentId,
102                        String user) {
103     MdcUtil.initMdc(LoggerServiceName.List_Monitoring_Artifacts.toString());
104
105     Version version = resolveVspVersion(vspId, versionId, user, VersionableEntityAction.Read);
106     componentManager.validateComponentExistence(vspId, version, componentId, user);
107
108     MonitoringUploadStatus response = monitoringUploadsManager
109         .listFilenames(vspId, version, componentId, user);
110
111     MonitoringUploadStatusDto returnEntity =
112         new MapMonitoringUploadStatusToDto()
113             .applyMapping(response, MonitoringUploadStatusDto.class);
114     return Response.status(Response.Status.OK).entity(returnEntity).build();
115
116   }
117 }