org.everit.json.schema.loader.internal.JSONPointer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of everit-json-schema Show documentation
Show all versions of everit-json-schema Show documentation
Implementation of the JSON Schema Core Draft v4 specification built with the org.json API
package org.everit.json.schema.loader.internal;
import static java.util.Objects.requireNonNull;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UncheckedIOException;
import java.nio.charset.Charset;
import java.util.function.Supplier;
import org.everit.json.schema.SchemaException;
import org.everit.json.schema.loader.SchemaClient;
import org.json.JSONException;
import org.json.JSONObject;
import org.json.JSONPointerException;
import org.json.JSONTokener;
/**
* JSON pointer implementation.
*/
@Deprecated
public class JSONPointer {
/**
* Data-transfer object for holding the result of a JSON pointer query.
*/
public static class QueryResult {
private final JSONObject containingDocument;
private final JSONObject queryResult;
/**
* Constructor.
*
* @param containingDocument
* the JSON document which contains the query result.
* @param queryResult
* the JSON object being the result of the query execution.
*/
public QueryResult(final JSONObject containingDocument, final JSONObject queryResult) {
this.containingDocument = requireNonNull(containingDocument, "containingDocument cannot be null");
this.queryResult = requireNonNull(queryResult, "queryResult cannot be null");
}
/**
* Getter for {@link #containingDocument}.
*
* @return the JSON document which contains the query result.
*/
public JSONObject getContainingDocument() {
return containingDocument;
}
/**
* Getter for {@link #queryResult}.
*
* @return the JSON object being the result of the query execution.
*/
public JSONObject getQueryResult() {
return queryResult;
}
}
private static JSONObject executeWith(final SchemaClient client, final String url) {
String resp = null;
BufferedReader buffReader = null;
InputStreamReader reader = null;
try {
InputStream responseStream = client.get(url);
reader = new InputStreamReader(responseStream, Charset.defaultCharset());
buffReader = new BufferedReader(reader);
String line;
StringBuilder strBuilder = new StringBuilder();
while ((line = buffReader.readLine()) != null) {
strBuilder.append(line);
}
resp = strBuilder.toString();
return new JSONObject(new JSONTokener(resp));
} catch (IOException e) {
throw new UncheckedIOException(e);
} catch (JSONException e) {
throw new SchemaException("failed to parse " + resp, e);
} finally {
try {
if (buffReader != null) {
buffReader.close();
}
if (reader != null) {
reader.close();
}
} catch (IOException e) {
throw new UncheckedIOException(e);
}
}
}
@Deprecated
public static final JSONPointer forDocument(final JSONObject document, final String fragment) {
return new JSONPointer(() -> document, fragment);
}
/**
* Static factory method.
*
* @param schemaClient
* the client implementation to be used for obtaining the remote raw JSON schema
* @param url
* a complete URL (including protocol definition like "http://"). It may also contain a
* fragment
* @return a JSONPointer instance with a document provider created for the URL and the optional
* fragment specified by the {@code url}
*/
@Deprecated
public static final JSONPointer forURL(final SchemaClient schemaClient, final String url) {
int poundIdx = url.indexOf('#');
String fragment;
String toBeQueried;
if (poundIdx == -1) {
toBeQueried = url;
fragment = "";
} else {
fragment = url.substring(poundIdx);
toBeQueried = url.substring(0, poundIdx);
}
return new JSONPointer(() -> JSONPointer.executeWith(schemaClient, toBeQueried), fragment);
}
private final Supplier documentProvider;
private final String fragment;
@Deprecated
public JSONPointer(final Supplier documentProvider, final String fragment) {
this.documentProvider = documentProvider;
this.fragment = fragment;
}
/**
* Queries from {@code document} based on this pointer.
*
* @return a DTO containing the query result and the root document containing the query result.
* @throws IllegalArgumentException
* if the pointer does not start with {@code '#'}.
*/
public QueryResult query() {
JSONObject document = documentProvider.get();
if (fragment.isEmpty()) {
return new QueryResult(document, document);
}
String[] path = fragment.split("/");
if ((path[0] == null) || !path[0].startsWith("#")) {
throw new IllegalArgumentException("JSON pointers must start with a '#'");
}
try {
JSONObject result = queryFrom(document);
return new QueryResult(document, result);
} catch (JSONPointerException e) {
throw new SchemaException(e.getMessage());
}
}
private JSONObject queryFrom(final JSONObject document) {
JSONObject result; // temporary workaround
if ("#".equals(fragment)) {
result = document;
} else {
result = (JSONObject) new org.json.JSONPointer(fragment).queryFrom(document);
}
if (result == null) {
throw new JSONPointerException(
String.format("could not query schema document by pointer [%s]", fragment));
}
return result;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy