org.everit.json.schema.ReferenceSchema Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of org.everit.json.schema Show documentation
Show all versions of org.everit.json.schema Show documentation
Implementation of the JSON Schema Core Draft v4 specification built with the org.json API
The newest version!
/*
* Copyright (C) 2011 Everit Kft. (http://www.everit.org)
*
* Licensed 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
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License 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 org.everit.json.schema;
import org.everit.json.schema.internal.JSONPrinter;
import java.util.Objects;
import static java.util.Objects.requireNonNull;
/**
* This class is used by {@link org.everit.json.schema.loader.SchemaLoader} to resolve JSON pointers
* during the construction of the schema. This class has been made mutable to permit the loading of
* recursive schemas.
*/
public class ReferenceSchema extends Schema {
/**
* Builder class for {@link ReferenceSchema}.
*/
public static class Builder extends Schema.Builder {
private ReferenceSchema retval;
/**
* The value of {@code "$ref"}
*/
private String refValue = "";
/**
* This method caches its result, so multiple invocations will return referentially the same
* {@link ReferenceSchema} instance.
*/
@Override
public ReferenceSchema build() {
if (retval == null) {
retval = new ReferenceSchema(this);
}
return retval;
}
public Builder refValue(String refValue) {
this.refValue = refValue;
return this;
}
}
public static Builder builder() {
return new Builder();
}
private Schema referredSchema;
private final String refValue;
public ReferenceSchema(final Builder builder) {
super(builder);
this.refValue = requireNonNull(builder.refValue, "refValue cannot be null");
}
@Override
public void validate(final Object subject) {
if (referredSchema == null) {
throw new IllegalStateException("referredSchema must be injected before validation");
}
referredSchema.validate(subject);
}
@Override
public boolean definesProperty(String field) {
if (referredSchema == null) {
throw new IllegalStateException("referredSchema must be injected before validation");
}
return referredSchema.definesProperty(field);
}
public Schema getReferredSchema() {
return referredSchema;
}
/**
* Called by {@link org.everit.json.schema.loader.SchemaLoader#load()} to set the referred root
* schema after completing the loading process of the entire schema document.
*
* @param referredSchema the referred schema
*/
public void setReferredSchema(final Schema referredSchema) {
if (this.referredSchema != null) {
throw new IllegalStateException("referredSchema can be injected only once");
}
this.referredSchema = referredSchema;
}
@Override
public boolean equals(Object o) {
if (this == o)
return true;
if (o instanceof ReferenceSchema) {
ReferenceSchema that = (ReferenceSchema) o;
return that.canEqual(this) &&
Objects.equals(refValue, that.refValue) &&
Objects.equals(referredSchema, that.referredSchema) &&
super.equals(that);
} else {
return false;
}
}
@Override
public int hashCode() {
return Objects.hash(super.hashCode(), referredSchema, refValue);
}
@Override
protected boolean canEqual(Object other) {
return other instanceof ReferenceSchema;
}
@Override void describePropertiesTo(JSONPrinter writer) {
writer.key("$ref");
writer.value(refValue);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy