BaseTextImporter.java
package org.dynamoframework.importer.impl;
/*-
* #%L
* Dynamo Framework
* %%
* Copyright (C) 2014 - 2024 Open Circle Solutions
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
import org.apache.commons.lang3.StringUtils;
import org.dynamoframework.exception.OCSImportException;
import org.dynamoframework.importer.ImportField;
import org.dynamoframework.configuration.DynamoPropertiesHolder;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
/**
* Base class for importers that read data from a text file
*
* @author bas.rutten
*/
public abstract class BaseTextImporter extends BaseImporter<String[], String> {
/**
* Tries to convert a String value to a Boolean (empty String or null
* resolves to false)
*
* @param unit the String
* @return the Boolean value
*/
protected Boolean getBooleanValue(String unit) {
if (StringUtils.isEmpty(unit)) {
return Boolean.FALSE;
}
return Boolean.valueOf(unit);
}
/**
* {@inheritDoc}
*/
@Override
protected Boolean getBooleanValueWithDefault(String unit, ImportField field) {
Boolean result = getBooleanValue(unit);
if (result == null && !StringUtils.isEmpty(field.defaultValue())) {
return Boolean.valueOf(field.defaultValue());
}
return result;
}
/**
* Tries to convert a String value to a Date
*
* @param unit the String value to convert
* @return the LocalDate value
*/
protected LocalDate getDateValue(String unit) {
if (!StringUtils.isEmpty(unit)) {
return LocalDate.parse(unit, DateTimeFormatter.ofPattern("dd-MM-yyyy"));
}
return null;
}
/**
* {@inheritDoc}
*/
@Override
protected LocalDate getDateValueWithDefault(String unit, ImportField field) {
LocalDate value = getDateValue(unit);
if (value == null && field.defaultValue() != null) {
return getDateValue(field.defaultValue());
}
return value;
}
/**
* Tries to convert a String to a numeric value
*
* @param unit the String value to convert
* @return the Double value
*/
protected Double getNumericValue(String unit) {
if (StringUtils.isEmpty(unit)) {
return null;
}
try {
return Double.valueOf(unit);
} catch (NumberFormatException ex) {
throw new OCSImportException(unit + " cannot be converted to a number");
}
}
/**
* {@inheritDoc}
*/
@Override
protected Double getNumericValueWithDefault(String unit, ImportField field) {
Double value = getNumericValue(unit);
if (value == null && !StringUtils.isEmpty(field.defaultValue())) {
value = Double.valueOf(field.defaultValue());
}
return value;
}
/**
* {@inheritDoc}
*/
@Override
protected String getStringValueWithDefault(String unit, ImportField field) {
String result = unit;
if (StringUtils.isEmpty(result) && !StringUtils.isEmpty(field.defaultValue())) {
result = field.defaultValue();
}
return result;
}
/**
* {@inheritDoc}
*/
@Override
protected String getUnit(String[] row, ImportField field) {
return row[field.index()];
}
/**
* {@inheritDoc}
*/
@Override
public boolean isPercentageCorrectionSupported() {
return false;
}
/**
* {@inheritDoc}
*/
@Override
protected boolean isWithinRange(String[] row, ImportField field) {
return field.index() < row.length;
}
}