/* * Copyright (c) 2014, Francis Galiegue (fgaliegue@gmail.com) * * This software is dual-licensed under: * * - the Lesser General Public License (LGPL) version 3.0 or, at your option, any * later version; * - the Apache Software License (ASL) version 2.0. * * The text of both licenses is available under the src/resources/ directory of * this project (under the names LGPL-3.0.txt and ASL-2.0.txt respectively). * * Direct link to the sources: * * - LGPL 3.0: https://www.gnu.org/licenses/lgpl-3.0.txt * - ASL 2.0: http://www.apache.org/licenses/LICENSE-2.0.txt */ package com.github.fge.jsonschema2avro; import com.github.fge.jsonschema.core.exceptions.ProcessingException; import com.github.fge.jsonschema.core.processing.Processor; import com.github.fge.jsonschema.core.processing.ProcessorSelector; import com.github.fge.jsonschema.core.report.ProcessingReport; import com.github.fge.jsonschema.core.tree.SchemaTree; import com.github.fge.jsonschema.core.util.ValueHolder; import com.github.fge.jsonschema2avro.writers.ArrayWriter; import com.github.fge.jsonschema2avro.writers.EnumWriter; import com.github.fge.jsonschema2avro.writers.MapWriter; import com.github.fge.jsonschema2avro.writers.RecordWriter; import com.github.fge.jsonschema2avro.writers.SimpleTypeWriter; import com.github.fge.jsonschema2avro.writers.SimpleUnionWriter; import com.github.fge.jsonschema2avro.writers.TypeUnionWriter; import org.apache.avro.Schema; import static com.github.fge.jsonschema2avro.predicates.AvroPredicates.*; public final class AvroWriterProcessor implements Processor<ValueHolder<SchemaTree>, ValueHolder<Schema>> { private final Processor<AvroPayload, ValueHolder<Schema>> processor; public AvroWriterProcessor() { processor = new ProcessorSelector<AvroPayload, ValueHolder<Schema>>() .when(simpleType()).then(SimpleTypeWriter.getInstance()) .when(array()).then(ArrayWriter.getInstance()) .when(map()).then(MapWriter.getInstance()) .when(isEnum()).then(new EnumWriter()) .when(record()).then(new RecordWriter()) .when(simpleUnion()).then(SimpleUnionWriter.getInstance()) .when(typeUnion()).then(TypeUnionWriter.getInstance()) .getProcessor(); } @Override public ValueHolder<Schema> process(final ProcessingReport report, final ValueHolder<SchemaTree> input) throws ProcessingException { final AvroPayload payload = new AvroPayload(input.getValue(), this); return processor.process(report, payload); } }