/*
* 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.writers;
import com.fasterxml.jackson.databind.JsonNode;
import com.github.fge.jackson.jsonpointer.JsonPointer;
import com.github.fge.jsonschema.core.exceptions.ProcessingException;
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.AvroWriterProcessor;
import com.google.common.collect.Lists;
import org.apache.avro.Schema;
import java.util.List;
public final class SimpleUnionWriter
extends AvroWriter
{
private static final AvroWriter INSTANCE = new SimpleUnionWriter();
private SimpleUnionWriter()
{
}
public static AvroWriter getInstance()
{
return INSTANCE;
}
@Override
protected Schema generate(final AvroWriterProcessor writer,
final ProcessingReport report, final SchemaTree tree)
throws ProcessingException
{
final JsonNode node = tree.getNode();
final String keyword = node.has("oneOf") ? "oneOf" : "anyOf";
final int size = node.get(keyword).size();
JsonPointer ptr;
ValueHolder<SchemaTree> holder;
Schema subSchema;
final List<Schema> schemas = Lists.newArrayList();
for (int index = 0; index < size; index++) {
ptr = JsonPointer.of(keyword, index);
holder = ValueHolder.hold("schema", tree.append(ptr));
subSchema = writer.process(report, holder).getValue();
if (subSchema.getType() == Schema.Type.UNION)
throw new ProcessingException("union within union is illegal");
schemas.add(subSchema);
}
return Schema.createUnion(schemas);
}
}