/**
* OrbisGIS is a java GIS application dedicated to research in GIScience.
* OrbisGIS is developed by the GIS group of the DECIDE team of the
* Lab-STICC CNRS laboratory, see <http://www.lab-sticc.fr/>.
*
* The GIS group of the DECIDE team is located at :
*
* Laboratoire Lab-STICC – CNRS UMR 6285
* Equipe DECIDE
* UNIVERSITÉ DE BRETAGNE-SUD
* Institut Universitaire de Technologie de Vannes
* 8, Rue Montaigne - BP 561 56017 Vannes Cedex
*
* OrbisGIS is distributed under GPL 3 license.
*
* Copyright (C) 2007-2014 CNRS (IRSTV FR CNRS 2488)
* Copyright (C) 2015-2017 CNRS (Lab-STICC UMR CNRS 6285)
*
* This file is part of OrbisGIS.
*
* OrbisGIS 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.
*
* OrbisGIS 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
* OrbisGIS. If not, see <http://www.gnu.org/licenses/>.
*
* For more information, please consult: <http://www.orbisgis.org/>
* or contact directly:
* info_at_ orbisgis.org
*/
package org.orbisgis.dbjobs.jobs;
import org.apache.commons.io.FilenameUtils;
import org.h2gis.api.DriverFunction;
import org.h2gis.utilities.JDBCUtilities;
import org.h2gis.utilities.TableLocation;
import org.orbisgis.commons.progress.SwingWorkerPM;
import org.orbisgis.corejdbc.DataManager;
import org.orbisgis.commons.progress.ProgressMonitor;
import org.orbisgis.commons.utils.FileUtils;
import org.orbisgis.corejdbc.H2GISProgressMonitor;
import org.orbisgis.dbjobs.api.DatabaseView;
import org.orbisgis.dbjobs.api.DriverFunctionContainer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.xnap.commons.i18n.I18n;
import org.xnap.commons.i18n.I18nFactory;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
/**
* This job load a bunch of files into a DataSource
* @author Nicolas Fortin
*/
public class ImportFiles extends SwingWorkerPM {
private static final I18n I18N = I18nFactory.getI18n(ImportFiles.class);
private static Logger LOGGER = LoggerFactory.getLogger(ImportFiles.class);
private DatabaseView dbView;
private List<File> files;
private DriverFunctionContainer driverFunctionContainer;
private DataManager dataManager;
private DriverFunction.IMPORT_DRIVER_TYPE driverType;
private String schema;
/**
* Import file into database into the default schema
* @param dbView GUI to refresh when the operation is done
* @param driverFunctionContainer Container of file drivers.
* @param files Files to import
* @param dataManager DataManager that hold datasource
* @param driverType Type of import
*/
public ImportFiles(DatabaseView dbView, DriverFunctionContainer driverFunctionContainer, List<File> files, DataManager dataManager, DriverFunction.IMPORT_DRIVER_TYPE driverType) {
this.dbView = dbView;
this.driverFunctionContainer = driverFunctionContainer;
this.files = files;
this.dataManager = dataManager;
this.driverType = driverType;
setTaskName(I18N.tr("Import file"));
schema = "";
}
/**
* Import file into database into the specified schema
* @param dbView GUI to refresh when the operation is done
* @param driverFunctionContainer Container of file drivers.
* @param files Files to import
* @param dataManager DataManager that hold datasource
* @param driverType Type of import
* @param schema Schema name where to create tables
*/
public ImportFiles(DatabaseView dbView, DriverFunctionContainer driverFunctionContainer, List<File> files, DataManager dataManager, DriverFunction.IMPORT_DRIVER_TYPE driverType, String schema) {
this.dbView = dbView;
this.driverFunctionContainer = driverFunctionContainer;
this.files = files;
this.dataManager = dataManager;
this.driverType = driverType;
this.schema = schema;
setTaskName(I18N.tr("Import file"));
}
@Override
protected Object doInBackground() throws Exception {
long deb = System.currentTimeMillis();
try(Connection connection = dataManager.getDataSource().getConnection()) {
ProgressMonitor filePm = this.getProgressMonitor().startTask(files.size());
boolean isH2 = JDBCUtilities.isH2DataBase(connection.getMetaData());
for(File file : files) {
String ext = FilenameUtils.getExtension(file.getName());
DriverFunction driverFunction = driverFunctionContainer.getImportDriverFromExt(ext, driverType);
if(driverFunction != null) {
String tableNameTest = TableLocation.capsIdentifier(FileUtils.getNameFromURI(file.toURI()), isH2);
if(tableNameTest == null) {
tableNameTest = FileUtils.getNameFromURI(file.toURI());
}
String tableName = dataManager.findUniqueTableName(new TableLocation("", schema ,tableNameTest)
.toString(isH2));
driverFunction.importFile(connection, tableName ,file, new H2GISProgressMonitor(filePm));
} else {
LOGGER.error(I18N.tr("No driver found for {0} extension", ext));
}
}
} catch (SQLException ex) {
LOGGER.error(I18N.tr("Cannot import the file.\nCause : {0}", ex.getMessage()), ex);
// Print additional information
while((ex = ex.getNextException()) != null) {
LOGGER.error(ex.getLocalizedMessage());
}
} catch (IOException ex) {
LOGGER.error(I18N.tr("Cannot import the file.\nCause : {0}", ex.getMessage()), ex);
}
LOGGER.info(I18N.tr("Importation done in {0} sec", (System.currentTimeMillis() - deb) / 1000d));
dbView.onDatabaseUpdate(DatabaseView.DB_ENTITY.SCHEMA.name(), "PUBLIC");
return null;
}
@Override
public String toString() {
return super.toString(); //To change body of generated methods, choose Tools | Templates.
}
}