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