
com.github.fge.jsonschema.cfg.ValidationConfigurationBuilder Maven / Gradle / Ivy
/*
* Copyright (c) 2013, Francis Galiegue
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the Lesser GNU General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* Lesser GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package com.github.fge.jsonschema.cfg;
import com.github.fge.Thawed;
import com.github.fge.jsonschema.SchemaVersion;
import com.github.fge.jsonschema.exceptions.JsonReferenceException;
import com.github.fge.jsonschema.exceptions.unchecked.JsonReferenceError;
import com.github.fge.jsonschema.library.DraftV3Library;
import com.github.fge.jsonschema.library.DraftV4Library;
import com.github.fge.jsonschema.library.Library;
import com.github.fge.jsonschema.messages.JsonSchemaConfigurationBundle;
import com.github.fge.jsonschema.messages.JsonSchemaCoreMessageBundle;
import com.github.fge.jsonschema.messages.JsonSchemaValidationBundle;
import com.github.fge.jsonschema.ref.JsonRef;
import com.github.fge.jsonschema.report.ProcessingMessage;
import com.github.fge.jsonschema.syntax.SyntaxMessageBundle;
import com.github.fge.msgsimple.bundle.MessageBundle;
import com.github.fge.msgsimple.serviceloader.MessageBundleFactory;
import com.google.common.collect.Maps;
import java.util.Map;
/**
* Validation configuration (mutable instance)
*
* @see ValidationConfiguration
*/
public final class ValidationConfigurationBuilder
implements Thawed
{
private static final MessageBundle BUNDLE
= MessageBundleFactory.getBundle(JsonSchemaConfigurationBundle.class);
private static final MessageBundle CORE_BUNDLE
= MessageBundleFactory.getBundle(JsonSchemaCoreMessageBundle.class);
/**
* Default libraries to use
*
* Those are the libraries for draft v3 core and draft v4 core.
*
* @see SchemaVersion
* @see DraftV3Library
* @see DraftV4Library
*/
private static final Map DEFAULT_LIBRARIES;
static {
DEFAULT_LIBRARIES = Maps.newEnumMap(SchemaVersion.class);
DEFAULT_LIBRARIES.put(SchemaVersion.DRAFTV3, DraftV3Library.get());
DEFAULT_LIBRARIES.put(SchemaVersion.DRAFTV4, DraftV4Library.get());
}
/**
* The set of libraries to use
*/
final Map libraries;
/**
* The default library to use (draft v4 by default)
*/
Library defaultLibrary = DEFAULT_LIBRARIES.get(SchemaVersion.DRAFTV4);
/**
* Whether to use {@code format} ({@code true} by default)
*/
boolean useFormat = true;
/**
* The set of syntax messages
*/
MessageBundle syntaxMessages;
/**
* The set of validation messages
*/
MessageBundle validationMessages;
ValidationConfigurationBuilder()
{
libraries = Maps.newHashMap();
JsonRef ref;
Library library;
for (final Map.Entry entry:
DEFAULT_LIBRARIES.entrySet()) {
ref = JsonRef.fromURI(entry.getKey().getLocation());
library = entry.getValue();
libraries.put(ref, library);
}
syntaxMessages = SyntaxMessageBundle.get();
validationMessages = MessageBundleFactory
.getBundle(JsonSchemaValidationBundle.class);
}
/**
* Constructor from a frozen instance
*
* @param cfg the frozen configuration
* @see ValidationConfiguration#thaw()
*/
ValidationConfigurationBuilder(final ValidationConfiguration cfg)
{
libraries = Maps.newHashMap(cfg.libraries);
defaultLibrary = cfg.defaultLibrary;
useFormat = cfg.useFormat;
syntaxMessages = cfg.syntaxMessages;
validationMessages = cfg.validationMessages;
}
/**
* Add a {@code $schema} and matching library to this configuration
*
* @param uri the value for {@code $schema}
* @param library the library
* @return this
* @throws NullPointerException URI us null or library is null
* @throws IllegalArgumentException a library already exists for that URI
* @throws JsonReferenceError string is not a URI, or not an absolute JSON
* Reference
*/
public ValidationConfigurationBuilder addLibrary(final String uri,
final Library library)
{
final JsonRef ref;
try {
ref = JsonRef.fromString(uri);
if (!ref.isAbsolute())
throw new JsonReferenceError(new ProcessingMessage()
.setMessage(CORE_BUNDLE.getMessage("uriNotAbsolute"))
.put("ref", ref));
} catch (JsonReferenceException e) {
throw new JsonReferenceError(e.getProcessingMessage());
}
BUNDLE.checkNotNull(library, "nullLibrary");
BUNDLE.checkArgumentPrintf(libraries.put(ref, library) == null,
"dupLibrary", ref);
return this;
}
/**
* Set the default schema version for this configuration
*
* This will set the default library to use to the one registered for
* this schema version.
*
* @param version the version
* @return this
* @throws NullPointerException version is null
*/
public ValidationConfigurationBuilder setDefaultVersion(
final SchemaVersion version)
{
BUNDLE.checkNotNull(version, "nullVersion");
/*
* They are always in, so this is safe
*/
defaultLibrary = DEFAULT_LIBRARIES.get(version);
return this;
}
/**
* Add a library and sets it as the default
*
* @param uri the value for {@code $schema}
* @param library the library
* @return this
* @see #addLibrary(String, Library)
*/
public ValidationConfigurationBuilder setDefaultLibrary(final String uri,
final Library library)
{
addLibrary(uri, library);
defaultLibrary = library;
return this;
}
/**
* Tell whether the resulting configuration has support for {@code format}
*
* @param useFormat {@code true} if it must be used
* @return this
*/
public ValidationConfigurationBuilder setUseFormat(final boolean useFormat)
{
this.useFormat = useFormat;
return this;
}
public ValidationConfigurationBuilder setSyntaxMessages(
final MessageBundle syntaxMessages)
{
BUNDLE.checkNotNull(syntaxMessages, "nullMessageBundle");
this.syntaxMessages = syntaxMessages;
return this;
}
public ValidationConfigurationBuilder setValidationMessages(
final MessageBundle validationMessages)
{
BUNDLE.checkNotNull(validationMessages, "nullMessageBundle");
this.validationMessages = validationMessages;
return this;
}
/**
* Return a frozen version of this configuration
*
* @return a {@link ValidationConfiguration}
* @see ValidationConfiguration#ValidationConfiguration(ValidationConfigurationBuilder)
*/
@Override
public ValidationConfiguration freeze()
{
return new ValidationConfiguration(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy