/* * 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); } }