/*
* Copyright 2015 herd contributors
*
* 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.
*/
package org.finra.herd.tools.common.databridge;
import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.Reader;
import com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.apache.commons.io.Charsets;
import org.springframework.util.Assert;
import org.finra.herd.core.HerdFileUtils;
import org.finra.herd.model.dto.DataBridgeBaseManifestDto;
/**
* A base class for uploader and downloader manifest readers.
*/
public abstract class DataBridgeManifestReader<M extends DataBridgeBaseManifestDto>
{
/**
* Gets a manifest object from a reader and an object mapper. Sub-classes should override this method to read into their specific manifest object.
*
* @param reader the reader to read the file from.
* @param objectMapper the object mapper.
*
* @return the manifest object.
* @throws IOException if the input file could not be read.
*/
protected abstract M getManifestFromReader(Reader reader, ObjectMapper objectMapper) throws IOException;
/**
* Reads a JSON manifest file into a JSON manifest object.
*
* @param jsonManifestFile the JSON manifest file.
*
* @return the manifest object.
* @throws java.io.IOException if any errors were encountered reading the JSON file.
* @throws IllegalArgumentException if the manifest file has validation errors.
*/
public M readJsonManifest(File jsonManifestFile) throws IOException, IllegalArgumentException
{
// Verify that the file exists and can be read.
HerdFileUtils.verifyFileExistsAndReadable(jsonManifestFile);
// Deserialize the JSON manifest.
BufferedInputStream buffer = new BufferedInputStream(new FileInputStream(jsonManifestFile));
BufferedReader reader = new BufferedReader(new InputStreamReader(buffer, Charsets.UTF_8));
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setVisibility(PropertyAccessor.FIELD, Visibility.ANY);
objectMapper.setVisibility(PropertyAccessor.GETTER, Visibility.NONE);
objectMapper.setVisibility(PropertyAccessor.SETTER, Visibility.NONE);
M manifest = getManifestFromReader(reader, objectMapper);
// Validate the manifest and return it.
validateManifest(manifest);
return manifest;
}
/**
* Validates a manifest.
*
* @param manifest the manifest to validate.
*
* @throws IllegalArgumentException if the manifest is not valid.
*/
protected void validateManifest(M manifest) throws IllegalArgumentException
{
Assert.hasText(manifest.getBusinessObjectDefinitionName(), "Manifest business object definition name must be specified.");
Assert.hasText(manifest.getBusinessObjectFormatFileType(), "Manifest business object format file type must be specified.");
Assert.hasText(manifest.getBusinessObjectFormatUsage(), "Manifest business object format usage must be specified.");
Assert.hasText(manifest.getPartitionKey(), "Manifest business object format partition key must be specified.");
Assert.hasText(manifest.getPartitionValue(), "Manifest business object data partition value must be specified.");
}
}