summaryrefslogtreecommitdiffstats
path: root/openecomp-be/tools/zusammen-tools/src/main/java/org/openecomp/core/tools/exportinfo/ExportDataCommand.java
blob: 5dcc72de595ae74e39529555a9a5b124a2a49836 (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
118
119
120
121
122
123
124
125
/**
 * Copyright © 2016-2017 European Support Limited.
 */
package org.openecomp.core.tools.exportinfo;

import com.amdocs.zusammen.datatypes.SessionContext;
import com.datastax.driver.core.ResultSet;
import com.datastax.driver.core.ResultSetFuture;
import com.datastax.driver.core.Session;
import com.google.common.collect.Sets;
import com.google.common.util.concurrent.FutureCallback;
import com.google.common.util.concurrent.Futures;
import org.apache.commons.io.FileUtils;
import org.openecomp.core.nosqldb.impl.cassandra.CassandraSessionFactory;
import org.openecomp.core.tools.importinfo.ImportProperties;
import org.openecomp.core.tools.util.Utils;
import org.openecomp.core.tools.util.ZipUtils;
import org.openecomp.core.zusammen.impl.CassandraConnectionInitializer;
import org.openecomp.sdc.logging.api.Logger;
import org.openecomp.sdc.logging.api.LoggerFactory;
import org.yaml.snakeyaml.Yaml;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.CountDownLatch;
import java.util.stream.Collectors;

import static java.nio.file.Files.createDirectories;


public class ExportDataCommand {
    private static final Logger logger = LoggerFactory.getLogger(ExportDataCommand.class);
    public static final String JOIN_DELIMITER = "$#";
    public static final String JOIN_DELIMITER_SPILTTER = "\\$\\#";
    public static final String MAP_DELIMITER = "!@";
    public static final String MAP_DELIMITER_SPLITTER = "\\!\\@";
    public static final String EXPORT_FILE_NAME = "ITEM_EXPORT";

    public static void exportData(SessionContext sessionContext, String filterItem) {
        try {
            CassandraConnectionInitializer.setCassandraConnectionPropertiesToSystem();
            final Set<String> filteredItems = Sets.newHashSet(filterItem);
            Path rootDir = Paths.get(ImportProperties.ROOT_DIRECTORY);
            initDir(rootDir);
            Set<String> fis = filteredItems.stream().map(fi -> fi.replaceAll("\\r", "")).collect(Collectors.toSet());

            Map<String, List<String>> queries;
            Yaml yaml = new Yaml();
            try (InputStream is = ExportDataCommand.class.getResourceAsStream("/queries.yaml")) {
                queries = (Map<String, List<String>>) yaml.load(is);
            }
            List<String> queriesList = queries.get("queries");
            List<String> itempsColumns = queries.get("item_columns");
            Set<String> vlms = new HashSet<>();
            CountDownLatch doneQueries = new CountDownLatch(queriesList.size());
            for (int i = 0; i < queriesList.size(); i++) {
                executeQuery(queriesList.get(i), fis, itempsColumns.get(i), vlms, doneQueries);
            }
            doneQueries.await();
            if (!vlms.isEmpty()) {
                CountDownLatch doneVmls = new CountDownLatch(queriesList.size());

                for (int i = 0; i < queriesList.size(); i++) {
                    executeQuery(queriesList.get(i), vlms, itempsColumns.get(i), null, doneVmls);
                }

                doneVmls.await();
            }
            zipPath(rootDir);
            FileUtils.forceDelete(rootDir.toFile());
        } catch (Exception ex) {
            Utils.logError(logger, ex);
        }

    }


    private static boolean executeQuery(final String query, final Set<String> filteredItems, final String filteredColumn,
                                        final Set<String> vlms, final CountDownLatch donequerying) {
        Session session = CassandraSessionFactory.getSession();
        ResultSetFuture resultSetFuture = session.executeAsync(query);
        Futures.addCallback(resultSetFuture, new FutureCallback<ResultSet>() {
            @Override
            public void onSuccess(ResultSet resultSet) {
                new ExportSerializer().serializeResult(resultSet, filteredItems, filteredColumn, vlms);
                donequerying.countDown();
            }

            @Override
            public void onFailure(Throwable t) {
                Utils.logError(logger, "Query failed :" + query, t);
                donequerying.countDown();
            }
        });
        return true;
    }

    private static void zipPath(Path rootDir) throws Exception {
        LocalDateTime date = LocalDateTime.now();
        DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
        String dateStr = date.format(formatter);
        dateStr = dateStr.replaceAll(":", "_");
        String zipFile = System.getProperty("user.home") + File.separatorChar + "onboarding_import" + dateStr + ".zip";
        ZipUtils.createZip(zipFile, rootDir);
        Utils.printMessage(logger, "Exported file :" + zipFile);
    }


    public static void initDir(Path rootDir) throws IOException {
        if (rootDir.toFile().exists()) {
            FileUtils.forceDelete(rootDir.toFile());
        }
        createDirectories(rootDir);
    }

}