com.cloudera.science.avro.common.SchemaLoader.java Source code

Java tutorial

Introduction

Here is the source code for com.cloudera.science.avro.common.SchemaLoader.java

Source

/**
 * Copyright (c) 2013, Cloudera, Inc. All Rights Reserved.
 *
 * Cloudera, Inc. licenses this file to you 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
 *
 * This software 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 com.cloudera.science.avro.common;

import java.io.IOException;
import java.io.InputStream;
import java.net.URL;

import org.apache.avro.Schema;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FSDataInputStream;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;

import eu.dnetlib.iis.core.common.AvroUtils;

/**
 * Some changes introduced in the original code by Mateusz Kobos
 */
public class SchemaLoader {

    private final Configuration conf;
    private final Schema.Parser parser = new Schema.Parser();

    public SchemaLoader(Configuration conf) {
        this.conf = conf;
    }

    public Schema load(String schemaJson, String schemaUrl, String typeName) throws IOException {
        if (schemaJson != null && !"none".equals(schemaJson)) {
            return loadLiteral(schemaJson);
        } else if (schemaUrl != null && !"none".equals(schemaUrl)) {
            return loadFromUrl(schemaUrl);
        } else if (typeName != null && !"none".equals(typeName)) {
            return loadFromTypeName(typeName);
        } else {
            throw new IllegalArgumentException("No valid schema information provided");
        }
    }

    public Schema loadLiteral(String schemaJson) throws IOException {
        return parser.parse(schemaJson);
    }

    public Schema loadFromUrl(String schemaUrl) throws IOException {
        if (schemaUrl.toLowerCase().startsWith("hdfs://")) {
            FileSystem fs = FileSystem.get(conf);
            FSDataInputStream input = null;
            try {
                input = fs.open(new Path(schemaUrl));
                return parser.parse(input);
            } finally {
                if (input != null) {
                    input.close();
                }
            }
        } else {
            InputStream is = null;
            try {
                is = new URL(schemaUrl).openStream();
                return parser.parse(is);
            } finally {
                if (is != null) {
                    is.close();
                }
            }
        }
    }

    public Schema loadFromTypeName(String typeName) {
        return AvroUtils.toSchema(typeName);
    }
}