com.couchbase.client.java.json.JsonValue Maven / Gradle / Ivy
/*
* Copyright (c) 2016 Couchbase, Inc.
*
* 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 com.couchbase.client.java.json;
import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.error.InvalidArgumentException;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.List;
import java.util.Map;
/**
* Represents a JSON value (either a {@link JsonObject} or a {@link JsonArray}.
*
* @since 2.0
*/
public abstract class JsonValue {
/**
* Represents a Json "null".
*/
public static final JsonNull NULL = JsonNull.INSTANCE;
/**
* Static factory method to create an empty {@link JsonObject}.
*
* @return an empty {@link JsonObject}.
*/
public static JsonObject jo() {
return JsonObject.create();
}
/**
* Static factory method to create an empty {@link JsonArray}.
*
* @return an empty {@link JsonArray}.
*/
public static JsonArray ja() {
return JsonArray.create();
}
/**
* Helper method to check if the given item is a supported JSON item.
*
* @param item the value to check.
* @return true if supported, false otherwise.
*/
public static boolean checkType(Object item) {
return item == null
|| item instanceof String
|| item instanceof Integer
|| item instanceof Long
|| item instanceof Double
|| item instanceof Boolean
|| item instanceof BigInteger
|| item instanceof BigDecimal
|| item instanceof JsonObject
|| item instanceof JsonArray;
}
/**
* Returns the given value converted to a type that passes the {@link #checkType} test.
* @throws InvalidArgumentException if conversion is not possible.
*/
@SuppressWarnings("unchecked")
@Stability.Internal
public static Object coerce(Object value) {
if (checkType(value)) {
return value;
}
if (value instanceof Map) {
return JsonObject.from((Map) value);
}
if (value instanceof List) {
return JsonArray.from((List>) value);
}
if (value instanceof Iterable) {
return JsonArray.fromIterable((Iterable>) value);
}
if (value instanceof JsonNull) {
return null;
}
throw InvalidArgumentException.fromMessage("Unsupported type for JSON value: " + value.getClass());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy