97197cf90305a5131a152b9e098c91ea62605f11
[oam/nf-oam-adopter.git] / ves-nf-oam-adopter / ves-nf-oam-adopter-pm-manager / src / main / java / org / o / ran / oam / nf / oam / adopter / pm / rest / manager / mapper / PerformanceManagementFile2VesMapper.java
1 /*
2  *  ============LICENSE_START=======================================================
3  *  O-RAN-SC
4  *  ================================================================================
5  *  Copyright © 2021 AT&T Intellectual Property. All rights reserved.
6  *  ================================================================================
7  *  Licensed under the Apache License, Version 2.0 (the "License");
8  *  you may not use this file except in compliance with the License.
9  *  You may obtain a copy of the License at
10  *        http://www.apache.org/licenses/LICENSE-2.0
11  *
12  *  Unless required by applicable law or agreed to in writing, software
13  *  distributed under the License is distributed on an "AS IS" BASIS,
14  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  *  See the License for the specific language governing permissions and
16  *  limitations under the License.
17  *  ============LICENSE_END=========================================================
18  */
19
20 package org.o.ran.oam.nf.oam.adopter.pm.rest.manager.mapper;
21
22 import com.fasterxml.jackson.core.JsonParser;
23 import com.fasterxml.jackson.dataformat.csv.CsvMapper;
24 import com.fasterxml.jackson.dataformat.csv.CsvSchema;
25 import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
26 import io.reactivex.rxjava3.core.Single;
27 import java.io.IOException;
28 import java.util.ArrayList;
29 import java.util.Iterator;
30 import java.util.List;
31 import java.util.Map;
32 import java.util.zip.ZipEntry;
33 import java.util.zip.ZipInputStream;
34 import org.o.ran.oam.nf.oam.adopter.api.CommonEventFormat302ONAP;
35 import org.o.ran.oam.nf.oam.adopter.api.Event;
36 import org.o.ran.oam.nf.oam.adopter.pm.rest.manager.PerformanceManagementMapperConfigProvider;
37 import org.o.ran.oam.nf.oam.adopter.pm.rest.manager.pojos.CsvConfiguration;
38 import org.o.ran.oam.nf.oam.adopter.pm.rest.manager.pojos.VesMappingConfiguration;
39 import org.slf4j.Logger;
40 import org.slf4j.LoggerFactory;
41 import org.springframework.beans.factory.annotation.Autowired;
42 import org.springframework.stereotype.Service;
43
44 @Service
45 public class PerformanceManagementFile2VesMapper {
46     private static final Logger LOG = LoggerFactory.getLogger(PerformanceManagementFile2VesMapper.class);
47
48     private static final String CSV_EXTENSION = ".csv";
49     private final PerformanceManagementMapperConfigProvider pmConfigProvider;
50     private static final int THRESHOLD_SIZE  = 1000000000; // 1 GB
51
52     @Autowired
53     public PerformanceManagementFile2VesMapper(final PerformanceManagementMapperConfigProvider pmConfigProvider) {
54         this.pmConfigProvider = pmConfigProvider;
55     }
56
57     /**
58      * Translate CSV in ZipInputStream format to list of CommonEventFormat302ONAP events.
59      *
60      * @param zipInputStream csv
61      * @param hostIp source Ip Address
62      * @return CommonEventFormat302ONAP events
63      */
64     @SuppressFBWarnings("REC_CATCH_EXCEPTION")
65     public Single<List<CommonEventFormat302ONAP>> map(final ZipInputStream zipInputStream, final String hostIp) {
66         LOG.info("Converting ZIP files to VES Message started");
67         final List<CommonEventFormat302ONAP> listOfNotifications = new ArrayList<>();
68         final CsvSchema schema = CsvSchema.emptySchema().withHeader();
69         final var mapper = new CsvMapper();
70         mapper.configure(JsonParser.Feature.AUTO_CLOSE_SOURCE, false);
71         try {
72             ZipEntry entry;
73             final var mappingConfiguration = pmConfigProvider.getVesMappingConfiguration();
74             while ((entry = zipInputStream.getNextEntry()) != null) {
75                 if (entry.getSize() > THRESHOLD_SIZE  || entry.getSize() == -1) {
76                     throw new IllegalStateException("File to be unzipped too big.");
77                 }
78                 final String entryName = entry.getName();
79                 if (!entryName.endsWith(CSV_EXTENSION)) {
80                     return Single.error(new Exception("Wrong file type :" + entryName));
81                 }
82
83                 final Iterator<Map<String, String>> iterator =
84                         mapper.readerFor(Map.class).with(schema).readValues(zipInputStream);
85                 final List<List<Event>> mappedEvents = toEvent(mappingConfiguration, hostIp, iterator);
86
87                 mappedEvents.forEach(mapped -> {
88                     final var eventFormat = new CommonEventFormat302ONAP();
89                     eventFormat.setEventList(mapped);
90                     listOfNotifications.add(eventFormat);
91                 });
92             }
93         } catch (final Exception e) {
94             return Single.error(new Exception("Failed to process file", e));
95         } finally {
96             try {
97                 zipInputStream.closeEntry();
98             } catch (final IOException e) {
99                 LOG.warn("Failed to close zip stream", e);
100             }
101         }
102         LOG.info("Converting ZIP files to VES Message finished");
103         return Single.just(listOfNotifications);
104     }
105
106     private static List<List<Event>> toEvent(final VesMappingConfiguration mappingConfiguration, final String hostIp,
107             final Iterator<Map<String, String>> iterator) {
108         final List<List<Event>> globalList = new ArrayList<>();
109         final int batchSize = mappingConfiguration.getBatchSize();
110         var sequence = 0;
111         List<Event> events = new ArrayList<>();
112         final CsvConfiguration csv = mappingConfiguration.getCsv();
113         while (iterator.hasNext()) {
114             final var event = new Event();
115             final Map<String, String> recordMap = iterator.next();
116             event.setCommonEventHeader(CommonEventHeaderHandler.toCommonEventHeader(mappingConfiguration, hostIp, csv,
117                 recordMap,  sequence));
118             event.setMeasurementFields(MeasurementFieldsHandler.toMeasurementFields(mappingConfiguration, recordMap));
119             events.add(event);
120             sequence++;
121             if (sequence % batchSize == 0) {
122                 globalList.add(events);
123                 events = new ArrayList<>();
124             }
125         }
126         if (!events.isEmpty()) {
127             globalList.add(events);
128         }
129         return globalList;
130     }
131 }