summaryrefslogtreecommitdiffstats
path: root/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
blob: a971782a15210bb64e4c610393a552b19d98757a (plain)
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();

  }
}