All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.graphaware.importer.FileBatchImporter Maven / Gradle / Ivy

Go to download

Importer high-performance multi-threaded initial data load into Neo4j from CSV/SQL with custom logic

The newest version!
/*
 * Copyright (c) 2013-2016 GraphAware
 *
 * This file is part of the GraphAware Framework.
 *
 * GraphAware Framework is free software: you can redistribute it and/or modify it under the terms
 * of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License,
 * or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU General Public License for more details. You should have received a copy of the
 * GNU General Public License along with this program.  If not, see .
 */

package com.graphaware.importer;

import com.graphaware.importer.cli.CommandLineParser;
import com.graphaware.importer.cli.CsvCommandLineParser;
import com.graphaware.importer.config.FileImportConfig;
import com.graphaware.importer.data.Data;
import com.graphaware.importer.data.DynamicData;
import com.graphaware.importer.data.location.DataLocator;
import com.graphaware.importer.data.location.InputFileLocator;
import com.graphaware.importer.importer.Importer;

import java.util.HashSet;
import java.util.Map;
import java.util.Set;

/**
 * {@link com.graphaware.importer.BatchImporter} for file-based imports.
 */
public abstract class FileBatchImporter extends BatchImporter {

    /**
     * {@inheritDoc}
     */
    @Override
    protected CommandLineParser commandLineParser() {
        return new CsvCommandLineParser();
    }

    /**
     * {@inheritDoc}
     */
    @Override
    protected DataLocator createInputDataLocator(FileImportConfig config) {
        return new InputFileLocator(config.getInputDir(), input());
    }

    /**
     * Get input data to logical file name mapping.
     *
     * @return mapping. One-to-one mapping of all importers' input data names by default.
     */
    protected Map input() {
        Set inputs = new HashSet<>();

        for (Importer importer : importers()) {
            inputs.add(importer.inputData().name());
        }

        return DynamicData.oneToOne(inputs.toArray(new String[inputs.size()]));
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy