/* AWE - Amanzi Wireless Explorer
* http://awe.amanzi.org
* (C) 2008-2009, AmanziTel AB
*
* This library is provided under the terms of the Eclipse Public License
* as described at http://www.eclipse.org/legal/epl-v10.html. Any use,
* reproduction or distribution of the library constitutes recipient's
* acceptance of this agreement.
*
* This library is distributed WITHOUT ANY WARRANTY; without even the
* implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*/
package org.amanzi.neo.loader.core.validator.impl.drive;
import java.io.File;
import java.util.Iterator;
import org.amanzi.neo.loader.core.IMultiFileConfiguration;
import org.amanzi.neo.loader.core.internal.LoaderCorePlugin;
import org.amanzi.neo.loader.core.internal.Messages;
import org.amanzi.neo.loader.core.saver.impl.AbstractDriveSaver;
import org.amanzi.neo.loader.core.validator.IValidationResult;
import org.amanzi.neo.loader.core.validator.IValidationResult.Result;
import org.amanzi.neo.loader.core.validator.ValidationResult;
import org.amanzi.neo.loader.core.validator.impl.internal.AbstractHeadersValidator;
import org.amanzi.neo.models.exceptions.ModelException;
import org.amanzi.neo.models.project.IProjectModel;
import org.amanzi.neo.providers.IDriveModelProvider;
import org.amanzi.neo.providers.IProjectModelProvider;
import org.apache.log4j.Logger;
/**
* TODO Purpose of
* <p>
* </p>
*
* @author Nikolay Lagutko (nikolay.lagutko@amanzitel.com)
* @since 1.0.0
*/
public abstract class DriveValidator extends AbstractHeadersValidator<IMultiFileConfiguration> {
private static final Logger LOGGER = Logger.getLogger(DriveValidator.class);
private final IDriveModelProvider driveModelProvider;
private final IProjectModelProvider projectModelProvider;
public DriveValidator() {
this(LoaderCorePlugin.getInstance().getProjectModelProvider(), LoaderCorePlugin.getInstance().getDriveModelProvider());
}
protected DriveValidator(final IProjectModelProvider projectModelProvider, final IDriveModelProvider driveModelProvider) {
super();
this.driveModelProvider = driveModelProvider;
this.projectModelProvider = projectModelProvider;
}
@Override
protected IValidationResult checkModelExists(final IMultiFileConfiguration configuration) {
LOGGER.info("Validating Configuration to load Drive"); //$NON-NLS-1$
try {
IProjectModel currentProject = projectModelProvider.getActiveProjectModel();
if (driveModelProvider.findByName(currentProject, configuration.getDatasetName()) != null) {
return new ValidationResult(Result.UNKNOWN, Messages.format(Messages.DriveValidator_DuplicatedDriveName,
configuration.getDatasetName()));
}
} catch (ModelException e) {
LOGGER.error("Database error on Drive Validation", e); //$NON-NLS-1$
}
return IValidationResult.SUCCESS;
}
@Override
protected Iterator<File> getFilesFromConfiguration(final IMultiFileConfiguration configuration) {
return configuration.getFileIterator();
}
@Override
protected String getSynonyms() {
return AbstractDriveSaver.DRIVE_SYNONYMS;
}
}