summaryrefslogtreecommitdiffstats
path: root/server/src/com/vaadin
diff options
context:
space:
mode:
Diffstat (limited to 'server/src/com/vaadin')
-rw-r--r--server/src/com/vaadin/server/AbstractClientConnector.java6
-rw-r--r--server/src/com/vaadin/server/BootstrapHandler.java59
-rw-r--r--server/src/com/vaadin/server/ClientConnector.java7
-rw-r--r--server/src/com/vaadin/server/ClientMethodInvocation.java15
-rw-r--r--server/src/com/vaadin/server/DragAndDropService.java6
-rw-r--r--server/src/com/vaadin/server/EncodeResult.java18
-rw-r--r--server/src/com/vaadin/server/JavaScriptCallbackHelper.java15
-rw-r--r--server/src/com/vaadin/server/JsonCodec.java313
-rw-r--r--server/src/com/vaadin/server/LegacyCommunicationManager.java15
-rw-r--r--server/src/com/vaadin/server/VaadinService.java24
-rw-r--r--server/src/com/vaadin/server/communication/ClientRpcWriter.java33
-rw-r--r--server/src/com/vaadin/server/communication/ConnectorHierarchyWriter.java20
-rw-r--r--server/src/com/vaadin/server/communication/ConnectorTypeWriter.java14
-rw-r--r--server/src/com/vaadin/server/communication/DateSerializer.java12
-rw-r--r--server/src/com/vaadin/server/communication/JsonSerializer.java (renamed from server/src/com/vaadin/server/communication/JSONSerializer.java)18
-rw-r--r--server/src/com/vaadin/server/communication/PortletBootstrapHandler.java12
-rw-r--r--server/src/com/vaadin/server/communication/PushHandler.java4
-rw-r--r--server/src/com/vaadin/server/communication/ServerRpcHandler.java77
-rw-r--r--server/src/com/vaadin/server/communication/SharedStateWriter.java18
-rw-r--r--server/src/com/vaadin/server/communication/UIInitHandler.java18
-rw-r--r--server/src/com/vaadin/server/communication/UidlRequestHandler.java8
-rw-r--r--server/src/com/vaadin/server/communication/UidlWriter.java24
-rw-r--r--server/src/com/vaadin/ui/Button.java10
-rw-r--r--server/src/com/vaadin/ui/CheckBox.java10
-rw-r--r--server/src/com/vaadin/ui/ConnectorTracker.java33
-rw-r--r--server/src/com/vaadin/ui/JavaScript.java12
-rw-r--r--server/src/com/vaadin/ui/JavaScriptFunction.java10
-rw-r--r--server/src/com/vaadin/ui/Slider.java10
28 files changed, 411 insertions, 410 deletions
diff --git a/server/src/com/vaadin/server/AbstractClientConnector.java b/server/src/com/vaadin/server/AbstractClientConnector.java
index 03300b20e2..19796af48d 100644
--- a/server/src/com/vaadin/server/AbstractClientConnector.java
+++ b/server/src/com/vaadin/server/AbstractClientConnector.java
@@ -32,9 +32,6 @@ import java.util.Map;
import java.util.NoSuchElementException;
import java.util.logging.Logger;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.event.EventRouter;
import com.vaadin.event.MethodEventSource;
import com.vaadin.shared.communication.ClientRpc;
@@ -46,6 +43,7 @@ import com.vaadin.ui.Component.Event;
import com.vaadin.ui.HasComponents;
import com.vaadin.ui.LegacyComponent;
import com.vaadin.ui.UI;
+import elemental.json.JsonObject;
/**
* An abstract base class for ClientConnector implementations. This class
@@ -243,7 +241,7 @@ public abstract class AbstractClientConnector implements ClientConnector,
}
@Override
- public JSONObject encodeState() throws JSONException {
+ public JsonObject encodeState() {
return LegacyCommunicationManager.encodeState(this, getState(false));
}
diff --git a/server/src/com/vaadin/server/BootstrapHandler.java b/server/src/com/vaadin/server/BootstrapHandler.java
index fb54b5c879..0605d6a2b8 100644
--- a/server/src/com/vaadin/server/BootstrapHandler.java
+++ b/server/src/com/vaadin/server/BootstrapHandler.java
@@ -30,8 +30,6 @@ import java.util.Set;
import javax.servlet.http.HttpServletResponse;
-import org.json.JSONException;
-import org.json.JSONObject;
import org.jsoup.nodes.DataNode;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.DocumentType;
@@ -44,6 +42,11 @@ import com.vaadin.shared.Version;
import com.vaadin.shared.communication.PushMode;
import com.vaadin.ui.UI;
+import elemental.json.Json;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+import elemental.json.impl.JsonUtil;
+
/**
*
* @author Vaadin Ltd
@@ -191,7 +194,7 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
String html = getBootstrapHtml(context);
writeBootstrapPage(response, html);
- } catch (JSONException e) {
+ } catch (JsonException e) {
writeError(response, e);
}
@@ -340,10 +343,8 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
* @param context
*
* @throws IOException
- * @throws JSONException
*/
- private void setupMainDiv(BootstrapContext context) throws IOException,
- JSONException {
+ private void setupMainDiv(BootstrapContext context) throws IOException {
String style = getMainDivStyle(context);
/*- Add classnames;
@@ -399,8 +400,8 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
StringBuilder builder = new StringBuilder();
builder.append("//<![CDATA[\n");
builder.append("if (!window.vaadin) alert("
- + JSONObject.quote("Failed to load the bootstrap javascript: "
- + bootstrapLocation) + ");\n");
+ + JsonUtil.quote("Failed to load the bootstrap javascript: "
+ + bootstrapLocation) + ");\n");
appendMainScriptTagContents(context, builder);
@@ -412,8 +413,8 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
}
protected void appendMainScriptTagContents(BootstrapContext context,
- StringBuilder builder) throws JSONException, IOException {
- JSONObject appConfig = getApplicationParameters(context);
+ StringBuilder builder) throws IOException {
+ JsonObject appConfig = getApplicationParameters(context);
boolean isDebug = !context.getSession().getConfiguration()
.isProductionMode();
@@ -438,21 +439,21 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
}
private static void appendJsonObject(StringBuilder builder,
- JSONObject jsonObject, boolean isDebug) throws JSONException {
+ JsonObject jsonObject, boolean isDebug) {
if (isDebug) {
- builder.append(jsonObject.toString(4));
+ builder.append(JsonUtil.stringify(jsonObject, 4));
} else {
- builder.append(jsonObject.toString());
+ builder.append(JsonUtil.stringify(jsonObject));
}
}
- protected JSONObject getApplicationParameters(BootstrapContext context)
- throws JSONException, PaintException {
+ protected JsonObject getApplicationParameters(BootstrapContext context)
+ throws PaintException {
VaadinRequest request = context.getRequest();
VaadinSession session = context.getSession();
VaadinService vaadinService = request.getService();
- JSONObject appConfig = new JSONObject();
+ JsonObject appConfig = Json.createObject();
String themeName = context.getThemeName();
if (themeName != null) {
@@ -465,7 +466,7 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
appConfig.put("extraParams", "&" + IGNORE_RESTART_PARAM + "=1");
}
- JSONObject versionInfo = new JSONObject();
+ JsonObject versionInfo = Json.createObject();
versionInfo.put("vaadinVersion", Version.getFullVersion());
appConfig.put("versionInfo", versionInfo);
@@ -479,30 +480,42 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
request);
if (systemMessages != null) {
// Write the CommunicationError -message to client
- JSONObject comErrMsg = new JSONObject();
+ JsonObject comErrMsg = Json.createObject();
comErrMsg.put("caption",
systemMessages.getCommunicationErrorCaption());
comErrMsg.put("message",
systemMessages.getCommunicationErrorMessage());
- comErrMsg.put("url", systemMessages.getCommunicationErrorURL());
+ if (systemMessages.getCommunicationErrorURL() == null) {
+ comErrMsg.put("url", Json.createNull());
+ } else {
+ comErrMsg.put("url", systemMessages.getCommunicationErrorURL());
+ }
appConfig.put("comErrMsg", comErrMsg);
- JSONObject authErrMsg = new JSONObject();
+ JsonObject authErrMsg = Json.createObject();
authErrMsg.put("caption",
systemMessages.getAuthenticationErrorCaption());
authErrMsg.put("message",
systemMessages.getAuthenticationErrorMessage());
- authErrMsg.put("url", systemMessages.getAuthenticationErrorURL());
+ if (systemMessages.getAuthenticationErrorURL() == null) {
+ authErrMsg.put("url", Json.createNull());
+ } else {
+ authErrMsg.put("url", systemMessages.getAuthenticationErrorURL());
+ }
appConfig.put("authErrMsg", authErrMsg);
- JSONObject sessExpMsg = new JSONObject();
+ JsonObject sessExpMsg = Json.createObject();
sessExpMsg
.put("caption", systemMessages.getSessionExpiredCaption());
sessExpMsg
.put("message", systemMessages.getSessionExpiredMessage());
- sessExpMsg.put("url", systemMessages.getSessionExpiredURL());
+ if (systemMessages.getSessionExpiredURL() == null) {
+ sessExpMsg.put("url", Json.createNull());
+ } else {
+ sessExpMsg.put("url", systemMessages.getSessionExpiredURL());
+ }
appConfig.put("sessExpMsg", sessExpMsg);
}
diff --git a/server/src/com/vaadin/server/ClientConnector.java b/server/src/com/vaadin/server/ClientConnector.java
index e61ba50a3a..50ce2754cb 100644
--- a/server/src/com/vaadin/server/ClientConnector.java
+++ b/server/src/com/vaadin/server/ClientConnector.java
@@ -20,15 +20,13 @@ import java.lang.reflect.Method;
import java.util.Collection;
import java.util.List;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.event.ConnectorEvent;
import com.vaadin.event.ConnectorEventListener;
import com.vaadin.shared.Connector;
import com.vaadin.shared.communication.SharedState;
import com.vaadin.ui.UI;
import com.vaadin.util.ReflectTools;
+import elemental.json.JsonObject;
/**
* Interface implemented by all connectors that are capable of communicating
@@ -279,10 +277,9 @@ public interface ClientConnector extends Connector {
* .
*
* @return a JSON object with the encoded connector state
- * @throws JSONException
* if the state can not be encoded
*/
- public JSONObject encodeState() throws JSONException;
+ public JsonObject encodeState() ;
/**
* Handle a request directed to this connector. This can be used by
diff --git a/server/src/com/vaadin/server/ClientMethodInvocation.java b/server/src/com/vaadin/server/ClientMethodInvocation.java
index e51138d7bf..97caa7614a 100644
--- a/server/src/com/vaadin/server/ClientMethodInvocation.java
+++ b/server/src/com/vaadin/server/ClientMethodInvocation.java
@@ -23,8 +23,9 @@ import java.io.Serializable;
import java.lang.reflect.Method;
import java.lang.reflect.Type;
-import org.json.JSONArray;
-import org.json.JSONException;
+import elemental.json.JsonArray;
+import elemental.json.JsonException;
+import elemental.json.impl.JsonUtil;
/**
* Internal class for keeping track of pending server to client method
@@ -107,8 +108,8 @@ public class ClientMethodInvocation implements Serializable,
Type type = parameterTypes[i];
if (type instanceof Class<?>) {
Class<?> clazz = (Class<?>) type;
- if (JSONArray.class.isAssignableFrom(clazz)) {
- parameters[i] = ((JSONArray) parameters[i]).toString();
+ if (JsonArray.class.isAssignableFrom(clazz)) {
+ parameters[i] = JsonUtil.stringify((JsonArray) parameters[i]);
}
}
}
@@ -124,10 +125,10 @@ public class ClientMethodInvocation implements Serializable,
Type type = parameterTypes[i];
if (type instanceof Class<?>) {
Class<?> clazz = (Class<?>) type;
- if (JSONArray.class.isAssignableFrom(clazz)) {
+ if (JsonArray.class.isAssignableFrom(clazz)) {
try {
- parameters[i] = new JSONArray(((String) parameters[i]));
- } catch (JSONException e) {
+ parameters[i] = JsonUtil.<JsonArray>parse((String) parameters[i]);
+ } catch (JsonException e) {
throw new IOException(e);
}
}
diff --git a/server/src/com/vaadin/server/DragAndDropService.java b/server/src/com/vaadin/server/DragAndDropService.java
index 087a670b5b..c21f27de97 100644
--- a/server/src/com/vaadin/server/DragAndDropService.java
+++ b/server/src/com/vaadin/server/DragAndDropService.java
@@ -24,9 +24,6 @@ import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.event.Transferable;
import com.vaadin.event.TransferableImpl;
import com.vaadin.event.dd.DragAndDropEvent;
@@ -41,6 +38,7 @@ import com.vaadin.shared.communication.SharedState;
import com.vaadin.shared.ui.dd.DragEventType;
import com.vaadin.ui.Component;
import com.vaadin.ui.UI;
+import elemental.json.JsonObject;
public class DragAndDropService implements VariableOwner, ClientConnector {
@@ -352,7 +350,7 @@ public class DragAndDropService implements VariableOwner, ClientConnector {
}
@Override
- public JSONObject encodeState() throws JSONException {
+ public JsonObject encodeState() {
// TODO Auto-generated method stub
return null;
}
diff --git a/server/src/com/vaadin/server/EncodeResult.java b/server/src/com/vaadin/server/EncodeResult.java
index 55a97aa829..bf4fd48438 100644
--- a/server/src/com/vaadin/server/EncodeResult.java
+++ b/server/src/com/vaadin/server/EncodeResult.java
@@ -18,29 +18,31 @@ package com.vaadin.server;
import java.io.Serializable;
+import elemental.json.JsonValue;
+
public class EncodeResult implements Serializable {
- private final Object encodedValue;
- private final Object diff;
+ private final JsonValue encodedValue;
+ private final JsonValue diff;
- public EncodeResult(Object encodedValue) {
+ public EncodeResult(JsonValue encodedValue) {
this(encodedValue, null);
}
- public EncodeResult(Object encodedValue, Object diff) {
+ public EncodeResult(JsonValue encodedValue, JsonValue diff) {
this.encodedValue = encodedValue;
this.diff = diff;
}
- public Object getEncodedValue() {
+ public JsonValue getEncodedValue() {
return encodedValue;
}
- public Object getDiff() {
+ public JsonValue getDiff() {
return diff;
}
- public Object getDiffOrValue() {
- Object diff = getDiff();
+ public JsonValue getDiffOrValue() {
+ JsonValue diff = getDiff();
if (diff != null) {
return diff;
} else {
diff --git a/server/src/com/vaadin/server/JavaScriptCallbackHelper.java b/server/src/com/vaadin/server/JavaScriptCallbackHelper.java
index 53fb1f838b..2552db6d13 100644
--- a/server/src/com/vaadin/server/JavaScriptCallbackHelper.java
+++ b/server/src/com/vaadin/server/JavaScriptCallbackHelper.java
@@ -18,21 +18,20 @@ package com.vaadin.server;
import java.io.Serializable;
import java.lang.reflect.Method;
-import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
-import org.json.JSONArray;
-import org.json.JSONException;
-
import com.vaadin.shared.JavaScriptConnectorState;
import com.vaadin.ui.AbstractJavaScriptComponent;
import com.vaadin.ui.JavaScript.JavaScriptCallbackRpc;
import com.vaadin.ui.JavaScriptFunction;
import com.vaadin.util.ReflectTools;
+import elemental.json.JsonArray;
+import elemental.json.JsonException;
+
/**
* Internal helper class used to implement functionality common to
* {@link AbstractJavaScriptComponent} and {@link AbstractJavaScriptExtension}.
@@ -47,7 +46,7 @@ import com.vaadin.util.ReflectTools;
public class JavaScriptCallbackHelper implements Serializable {
private static final Method CALL_METHOD = ReflectTools.findMethod(
- JavaScriptCallbackRpc.class, "call", String.class, JSONArray.class);
+ JavaScriptCallbackRpc.class, "call", String.class, JsonArray.class);
private AbstractClientConnector connector;
private Map<String, JavaScriptFunction> callbacks = new HashMap<String, JavaScriptFunction>();
@@ -75,11 +74,11 @@ public class JavaScriptCallbackHelper implements Serializable {
if (javascriptCallbackRpc == null) {
javascriptCallbackRpc = new JavaScriptCallbackRpc() {
@Override
- public void call(String name, JSONArray arguments) {
+ public void call(String name, JsonArray arguments) {
JavaScriptFunction callback = callbacks.get(name);
try {
callback.call(arguments);
- } catch (JSONException e) {
+ } catch (JsonException e) {
throw new IllegalArgumentException(e);
}
}
@@ -95,7 +94,7 @@ public class JavaScriptCallbackHelper implements Serializable {
+ name
+ " on the client because a callback with the same name is registered on the server.");
}
- JSONArray args = new JSONArray(Arrays.asList(arguments));
+ JsonArray args = (JsonArray) JsonCodec.encode(arguments, null, Object[].class, null).getEncodedValue();
connector.addMethodInvocationToQueue(
JavaScriptCallbackRpc.class.getName(), CALL_METHOD,
new Object[] { name, args });
diff --git a/server/src/com/vaadin/server/JsonCodec.java b/server/src/com/vaadin/server/JsonCodec.java
index 34b05f73bf..1e933ab1f3 100644
--- a/server/src/com/vaadin/server/JsonCodec.java
+++ b/server/src/com/vaadin/server/JsonCodec.java
@@ -28,12 +28,10 @@ import java.lang.reflect.Modifier;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.ArrayList;
-import java.util.Arrays;
import java.util.Collection;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
-import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
@@ -41,18 +39,24 @@ import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
-import org.json.JSONArray;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.communication.DateSerializer;
-import com.vaadin.server.communication.JSONSerializer;
+import com.vaadin.server.communication.JsonSerializer;
import com.vaadin.shared.Connector;
import com.vaadin.shared.JsonConstants;
import com.vaadin.shared.communication.UidlValue;
import com.vaadin.ui.Component;
import com.vaadin.ui.ConnectorTracker;
+import elemental.json.Json;
+import elemental.json.JsonArray;
+import elemental.json.JsonException;
+import elemental.json.JsonNull;
+import elemental.json.JsonObject;
+import elemental.json.JsonString;
+import elemental.json.JsonType;
+import elemental.json.JsonValue;
+import elemental.json.impl.JreJsonArray;
+
/**
* Decoder for converting RPC parameters and other values from JSON in transfer
* between the client and the server and vice versa.
@@ -62,21 +66,32 @@ import com.vaadin.ui.ConnectorTracker;
public class JsonCodec implements Serializable {
/* Immutable Encode Result representing null */
- private static final EncodeResult ENCODE_RESULT_NULL = new EncodeResult(
- JSONObject.NULL);
+ private static final EncodeResult ENCODE_RESULT_NULL = new EncodeResult(Json.createNull());
/* Immutable empty JSONArray */
- private static final JSONArray EMPTY_JSON_ARRAY = new JSONArray() {
+ private static final JsonArray EMPTY_JSON_ARRAY = new JreJsonArray(Json.instance()) {
@Override
- public JSONArray put(Object value) {
+ public void set(int index, JsonValue value) {
throw new UnsupportedOperationException(
- "Immutable empty JSONArray.");
+ "Immutable empty JsonArray.");
}
@Override
- public JSONArray put(int index, Object value) {
+ public void set(int index, String string) {
throw new UnsupportedOperationException(
- "Immutable empty JSONArray.");
+ "Immutable empty JsonArray.");
+ }
+
+ @Override
+ public void set(int index, double number) {
+ throw new UnsupportedOperationException(
+ "Immutable empty JsonArray.");
+ }
+
+ @Override
+ public void set(int index, boolean bool) {
+ throw new UnsupportedOperationException(
+ "Immutable empty JsonArray.");
}
};
@@ -197,7 +212,7 @@ public class JsonCodec implements Serializable {
*/
private static Map<String, Class<?>> transportTypeToType = new HashMap<String, Class<?>>();
- private static Map<Class<?>, JSONSerializer<?>> customSerializers = new HashMap<Class<?>, JSONSerializer<?>>();
+ private static Map<Class<?>, JsonSerializer<?>> customSerializers = new HashMap<Class<?>, JsonSerializer<?>>();
static {
customSerializers.put(Date.class, new DateSerializer());
}
@@ -266,8 +281,7 @@ public class JsonCodec implements Serializable {
}
public static Object decodeInternalOrCustomType(Type targetType,
- Object value, ConnectorTracker connectorTracker)
- throws JSONException {
+ JsonValue value, ConnectorTracker connectorTracker) {
if (isInternalType(targetType)) {
return decodeInternalType(targetType, false, value,
connectorTracker);
@@ -276,50 +290,49 @@ public class JsonCodec implements Serializable {
}
}
- public static Object decodeCustomType(Type targetType, Object value,
- ConnectorTracker connectorTracker) throws JSONException {
+ public static Object decodeCustomType(Type targetType, JsonValue value,
+ ConnectorTracker connectorTracker) {
if (isInternalType(targetType)) {
- throw new JSONException("decodeCustomType cannot be used for "
+ throw new JsonException("decodeCustomType cannot be used for "
+ targetType + ", which is an internal type");
}
// Try to decode object using fields
- if (value == JSONObject.NULL) {
+ if (value.getType() == JsonType.NULL) {
return null;
} else if (targetType == byte.class || targetType == Byte.class) {
- return Byte.valueOf(String.valueOf(value));
+ return Byte.valueOf((byte) value.asNumber());
} else if (targetType == char.class || targetType == Character.class) {
- return Character.valueOf(String.valueOf(value).charAt(0));
+ return Character.valueOf(value.asString().charAt(0));
} else if (targetType instanceof Class<?>
&& ((Class<?>) targetType).isArray()) {
// Legacy Object[] and String[] handled elsewhere, this takes care
// of generic arrays
Class<?> componentType = ((Class<?>) targetType).getComponentType();
- return decodeArray(componentType, (JSONArray) value,
+ return decodeArray(componentType, (JsonArray) value,
connectorTracker);
} else if (targetType instanceof GenericArrayType) {
Type componentType = ((GenericArrayType) targetType)
.getGenericComponentType();
- return decodeArray(componentType, (JSONArray) value,
+ return decodeArray(componentType, (JsonArray) value,
connectorTracker);
- } else if (targetType == JSONObject.class
- || targetType == JSONArray.class) {
+ } else if (JsonValue.class.isAssignableFrom(getClassForType(targetType))) {
return value;
} else if (Enum.class.isAssignableFrom(getClassForType(targetType))) {
Class<?> classForType = getClassForType(targetType);
return decodeEnum(classForType.asSubclass(Enum.class),
- (String) value);
+ (JsonString) value);
} else if (customSerializers.containsKey(getClassForType(targetType))) {
return customSerializers.get(getClassForType(targetType))
.deserialize(targetType, value, connectorTracker);
} else {
- return decodeObject(targetType, (JSONObject) value,
+ return decodeObject(targetType, (JsonObject) value,
connectorTracker);
}
}
- private static Object decodeArray(Type componentType, JSONArray value,
- ConnectorTracker connectorTracker) throws JSONException {
+ private static Object decodeArray(Type componentType, JsonArray value,
+ ConnectorTracker connectorTracker) {
Class<?> componentClass = getClassForType(componentType);
Object array = Array.newInstance(componentClass, value.length());
for (int i = 0; i < value.length(); i++) {
@@ -352,37 +365,36 @@ public class JsonCodec implements Serializable {
* true if generics should be enforce, false to only allow
* internal types in collections
* @return
- * @throws JSONException
*/
public static Object decodeInternalType(Type targetType,
- boolean restrictToInternalTypes, Object encodedJsonValue,
- ConnectorTracker connectorTracker) throws JSONException {
+ boolean restrictToInternalTypes, JsonValue encodedJsonValue,
+ ConnectorTracker connectorTracker) {
if (!isInternalType(targetType)) {
- throw new JSONException("Type " + targetType
+ throw new JsonException("Type " + targetType
+ " is not a supported internal type.");
}
String transportType = getInternalTransportType(targetType);
- if (encodedJsonValue == JSONObject.NULL) {
+ if (encodedJsonValue.getType() == JsonType.NULL) {
return null;
} else if (targetType == Void.class) {
- throw new JSONException(
+ throw new JsonException(
"Something other than null was encoded for a null type");
}
// UidlValue
if (targetType == UidlValue.class) {
- return decodeUidlValue((JSONArray) encodedJsonValue,
+ return decodeUidlValue((JsonArray) encodedJsonValue,
connectorTracker);
}
// Collections
if (JsonConstants.VTYPE_LIST.equals(transportType)) {
return decodeList(targetType, restrictToInternalTypes,
- (JSONArray) encodedJsonValue, connectorTracker);
+ (JsonArray) encodedJsonValue, connectorTracker);
} else if (JsonConstants.VTYPE_SET.equals(transportType)) {
return decodeSet(targetType, restrictToInternalTypes,
- (JSONArray) encodedJsonValue, connectorTracker);
+ (JsonArray) encodedJsonValue, connectorTracker);
} else if (JsonConstants.VTYPE_MAP.equals(transportType)) {
return decodeMap(targetType, restrictToInternalTypes,
encodedJsonValue, connectorTracker);
@@ -391,42 +403,40 @@ public class JsonCodec implements Serializable {
// Arrays
if (JsonConstants.VTYPE_ARRAY.equals(transportType)) {
- return decodeObjectArray(targetType, (JSONArray) encodedJsonValue,
+ return decodeObjectArray(targetType, (JsonArray) encodedJsonValue,
connectorTracker);
} else if (JsonConstants.VTYPE_STRINGARRAY.equals(transportType)) {
- return decodeStringArray((JSONArray) encodedJsonValue);
+ return decodeStringArray((JsonArray) encodedJsonValue);
}
// Special Vaadin types
- String stringValue = String.valueOf(encodedJsonValue);
-
if (JsonConstants.VTYPE_CONNECTOR.equals(transportType)) {
- return connectorTracker.getConnector(stringValue);
+ return connectorTracker.getConnector(encodedJsonValue.asString());
}
// Legacy types
if (JsonConstants.VTYPE_STRING.equals(transportType)) {
- return stringValue;
+ return encodedJsonValue.asString();
} else if (JsonConstants.VTYPE_INTEGER.equals(transportType)) {
- return Integer.valueOf(stringValue);
+ return (int) encodedJsonValue.asNumber();
} else if (JsonConstants.VTYPE_LONG.equals(transportType)) {
- return Long.valueOf(stringValue);
+ return (long) encodedJsonValue.asNumber();
} else if (JsonConstants.VTYPE_FLOAT.equals(transportType)) {
- return Float.valueOf(stringValue);
+ return (float) encodedJsonValue.asNumber();
} else if (JsonConstants.VTYPE_DOUBLE.equals(transportType)) {
- return Double.valueOf(stringValue);
+ return encodedJsonValue.asNumber();
} else if (JsonConstants.VTYPE_BOOLEAN.equals(transportType)) {
- return Boolean.valueOf(stringValue);
+ return encodedJsonValue.asBoolean();
}
- throw new JSONException("Unknown type " + transportType);
+ throw new JsonException("Unknown type " + transportType);
}
- private static UidlValue decodeUidlValue(JSONArray encodedJsonValue,
- ConnectorTracker connectorTracker) throws JSONException {
+ private static UidlValue decodeUidlValue(JsonArray encodedJsonValue,
+ ConnectorTracker connectorTracker) {
String type = encodedJsonValue.getString(0);
Object decodedValue = decodeInternalType(getType(type), true,
@@ -435,13 +445,13 @@ public class JsonCodec implements Serializable {
}
private static Map<Object, Object> decodeMap(Type targetType,
- boolean restrictToInternalTypes, Object jsonMap,
- ConnectorTracker connectorTracker) throws JSONException {
- if (jsonMap instanceof JSONArray) {
+ boolean restrictToInternalTypes, JsonValue jsonMap,
+ ConnectorTracker connectorTracker) {
+ if (jsonMap.getType() == JsonType.ARRAY) {
// Client-side has no declared type information to determine
// encoding method for empty maps, so these are handled separately.
// See #8906.
- JSONArray jsonArray = (JSONArray) jsonMap;
+ JsonArray jsonArray = (JsonArray) jsonMap;
if (jsonArray.length() == 0) {
return new HashMap<Object, Object>();
}
@@ -453,27 +463,27 @@ public class JsonCodec implements Serializable {
Type valueType = ((ParameterizedType) targetType)
.getActualTypeArguments()[1];
if (keyType == String.class) {
- return decodeStringMap(valueType, (JSONObject) jsonMap,
+ return decodeStringMap(valueType, (JsonObject) jsonMap,
connectorTracker);
} else if (keyType == Connector.class) {
- return decodeConnectorMap(valueType, (JSONObject) jsonMap,
+ return decodeConnectorMap(valueType, (JsonObject) jsonMap,
connectorTracker);
} else {
- return decodeObjectMap(keyType, valueType, (JSONArray) jsonMap,
+ return decodeObjectMap(keyType, valueType, (JsonArray) jsonMap,
connectorTracker);
}
} else {
- return decodeStringMap(UidlValue.class, (JSONObject) jsonMap,
+ return decodeStringMap(UidlValue.class, (JsonObject) jsonMap,
connectorTracker);
}
}
private static Map<Object, Object> decodeObjectMap(Type keyType,
- Type valueType, JSONArray jsonMap, ConnectorTracker connectorTracker)
- throws JSONException {
+ Type valueType, JsonArray jsonMap, ConnectorTracker connectorTracker)
+ {
- JSONArray keys = jsonMap.getJSONArray(0);
- JSONArray values = jsonMap.getJSONArray(1);
+ JsonArray keys = jsonMap.getArray(0);
+ JsonArray values = jsonMap.getArray(1);
assert (keys.length() == values.length());
@@ -491,12 +501,10 @@ public class JsonCodec implements Serializable {
}
private static Map<Object, Object> decodeConnectorMap(Type valueType,
- JSONObject jsonMap, ConnectorTracker connectorTracker)
- throws JSONException {
+ JsonObject jsonMap, ConnectorTracker connectorTracker) {
Map<Object, Object> map = new HashMap<Object, Object>();
- for (Iterator<?> iter = jsonMap.keys(); iter.hasNext();) {
- String key = (String) iter.next();
+ for (String key : jsonMap.keys()) {
Object value = decodeInternalOrCustomType(valueType,
jsonMap.get(key), connectorTracker);
if (valueType == UidlValue.class) {
@@ -509,12 +517,10 @@ public class JsonCodec implements Serializable {
}
private static Map<Object, Object> decodeStringMap(Type valueType,
- JSONObject jsonMap, ConnectorTracker connectorTracker)
- throws JSONException {
+ JsonObject jsonMap, ConnectorTracker connectorTracker) {
Map<Object, Object> map = new HashMap<Object, Object>();
- for (Iterator<?> iter = jsonMap.keys(); iter.hasNext();) {
- String key = (String) iter.next();
+ for (String key : jsonMap.keys()) {
Object value = decodeInternalOrCustomType(valueType,
jsonMap.get(key), connectorTracker);
if (valueType == UidlValue.class) {
@@ -535,11 +541,10 @@ public class JsonCodec implements Serializable {
* @param encodedValueAndType
* @param application
* @return
- * @throws JSONException
*/
private static Object decodeParametrizedType(Type targetType,
- boolean restrictToInternalTypes, int typeIndex, Object value,
- ConnectorTracker connectorTracker) throws JSONException {
+ boolean restrictToInternalTypes, int typeIndex, JsonValue value,
+ ConnectorTracker connectorTracker) {
if (!restrictToInternalTypes && targetType instanceof ParameterizedType) {
Type childType = ((ParameterizedType) targetType)
.getActualTypeArguments()[typeIndex];
@@ -555,12 +560,11 @@ public class JsonCodec implements Serializable {
}
}
- private static Object decodeEnum(Class<? extends Enum> cls, String value) {
- return Enum.valueOf(cls, value);
+ private static Object decodeEnum(Class<? extends Enum> cls, JsonString value) {
+ return Enum.valueOf(cls, value.getString());
}
- private static String[] decodeStringArray(JSONArray jsonArray)
- throws JSONException {
+ private static String[] decodeStringArray(JsonArray jsonArray) {
int length = jsonArray.length();
List<String> tokens = new ArrayList<String>(length);
for (int i = 0; i < length; ++i) {
@@ -570,21 +574,20 @@ public class JsonCodec implements Serializable {
}
private static Object[] decodeObjectArray(Type targetType,
- JSONArray jsonArray, ConnectorTracker connectorTracker)
- throws JSONException {
+ JsonArray jsonArray, ConnectorTracker connectorTracker) {
List<Object> list = decodeList(List.class, true, jsonArray,
connectorTracker);
return list.toArray(new Object[list.size()]);
}
private static List<Object> decodeList(Type targetType,
- boolean restrictToInternalTypes, JSONArray jsonArray,
- ConnectorTracker connectorTracker) throws JSONException {
+ boolean restrictToInternalTypes, JsonArray jsonArray,
+ ConnectorTracker connectorTracker) {
int arrayLength = jsonArray.length();
List<Object> list = new ArrayList<Object>(arrayLength);
for (int i = 0; i < arrayLength; ++i) {
// each entry always has two elements: type and value
- Object encodedValue = jsonArray.get(i);
+ JsonValue encodedValue = jsonArray.get(i);
Object decodedChild = decodeParametrizedType(targetType,
restrictToInternalTypes, 0, encodedValue, connectorTracker);
list.add(decodedChild);
@@ -593,8 +596,8 @@ public class JsonCodec implements Serializable {
}
private static Set<Object> decodeSet(Type targetType,
- boolean restrictToInternalTypes, JSONArray jsonArray,
- ConnectorTracker connectorTracker) throws JSONException {
+ boolean restrictToInternalTypes, JsonArray jsonArray,
+ ConnectorTracker connectorTracker) {
HashSet<Object> set = new HashSet<Object>();
set.addAll(decodeList(targetType, restrictToInternalTypes, jsonArray,
connectorTracker));
@@ -602,8 +605,7 @@ public class JsonCodec implements Serializable {
}
private static Object decodeObject(Type targetType,
- JSONObject serializedObject, ConnectorTracker connectorTracker)
- throws JSONException {
+ JsonObject serializedObject, ConnectorTracker connectorTracker) {
Class<?> targetClass = getClassForType(targetType);
@@ -612,7 +614,7 @@ public class JsonCodec implements Serializable {
for (BeanProperty property : getProperties(targetClass)) {
String fieldName = property.getName();
- Object encodedFieldValue = serializedObject.get(fieldName);
+ JsonValue encodedFieldValue = serializedObject.get(fieldName);
Type fieldType = property.getType();
Object decodedFieldValue = decodeInternalOrCustomType(
fieldType, encodedFieldValue, connectorTracker);
@@ -622,13 +624,12 @@ public class JsonCodec implements Serializable {
return decodedObject;
} catch (Exception e) {
- throw new JSONException(e.getMessage());
+ throw new RuntimeException(e);
}
}
- public static EncodeResult encode(Object value, Object diffState,
- Type valueType, ConnectorTracker connectorTracker)
- throws JSONException {
+ public static EncodeResult encode(Object value, JsonValue diffState,
+ Type valueType, ConnectorTracker connectorTracker) {
if (null == value) {
return ENCODE_RESULT_NULL;
@@ -636,13 +637,19 @@ public class JsonCodec implements Serializable {
// Storing a single reference and only returning the EncodeResult at the
// end the method is much shorter in bytecode which allows inlining
- Object toReturn;
+ JsonValue toReturn;
- if (value instanceof String || value instanceof Boolean
- || value instanceof Number || value instanceof Character
- || value instanceof JSONArray || value instanceof JSONObject) {
+ if (value instanceof JsonValue) {
// all JSON compatible types are returned as is.
- toReturn = value;
+ toReturn = (JsonValue) value;
+ } else if (value instanceof String) {
+ toReturn = Json.create((String) value);
+ } else if (value instanceof Boolean) {
+ toReturn = Json.create((Boolean) value);
+ } else if (value instanceof Number) {
+ toReturn = Json.create(((Number) value).doubleValue());
+ } else if (value instanceof Character) {
+ toReturn = Json.create(Character.toString((Character) value));
} else if (value instanceof String[]) {
toReturn = toJsonArray((String[]) value);
} else if (value instanceof Collection) {
@@ -658,9 +665,9 @@ public class JsonCodec implements Serializable {
return ENCODE_RESULT_NULL;
}
// Connectors are simply serialized as ID.
- toReturn = ((Connector) value).getConnectorId();
+ toReturn = Json.create(((Connector) value).getConnectorId());
} else if (value instanceof Enum) {
- toReturn = ((Enum<?>) value).name();
+ toReturn = Json.create(((Enum<?>) value).name());
} else if (customSerializers.containsKey(value.getClass())) {
toReturn = serializeJson(value, connectorTracker);
} else if (valueType instanceof GenericArrayType) {
@@ -677,10 +684,10 @@ public class JsonCodec implements Serializable {
// needs to return it directly rather than assigning it to
// toReturn.
return encodeObject(value, (Class<?>) valueType,
- (JSONObject) diffState, connectorTracker);
+ (JsonObject) diffState, connectorTracker);
}
} else {
- throw new JSONException("Can not encode type " + valueType);
+ throw new JsonException("Can not encode type " + valueType);
}
return new EncodeResult(toReturn);
}
@@ -706,10 +713,9 @@ public class JsonCodec implements Serializable {
* Loops through the fields of value and encodes them.
*/
private static EncodeResult encodeObject(Object value, Class<?> valueType,
- JSONObject referenceValue, ConnectorTracker connectorTracker)
- throws JSONException {
- JSONObject encoded = new JSONObject();
- JSONObject diff = new JSONObject();
+ JsonObject referenceValue, ConnectorTracker connectorTracker) {
+ JsonObject encoded = Json.createObject();
+ JsonObject diff = Json.createObject();
try {
for (BeanProperty property : getProperties(valueType)) {
@@ -719,7 +725,7 @@ public class JsonCodec implements Serializable {
Type fieldType = property.getType();
Object fieldValue = property.getValue(value);
- if (encoded.has(fieldName)) {
+ if (encoded.hasKey(fieldName)) {
throw new RuntimeException(
"Can't encode "
+ valueType.getName()
@@ -728,10 +734,10 @@ public class JsonCodec implements Serializable {
+ ". This can happen if there are getters and setters for a public field (the framework can't know which to ignore) or if there are properties with only casing distinguishing between the names (e.g. getFoo() and getFOO())");
}
- Object fieldReference;
+ JsonValue fieldReference;
if (referenceValue != null) {
fieldReference = referenceValue.get(fieldName);
- if (JSONObject.NULL.equals(fieldReference)) {
+ if (fieldReference instanceof JsonNull) {
fieldReference = null;
}
} else {
@@ -748,7 +754,7 @@ public class JsonCodec implements Serializable {
}
} catch (Exception e) {
// TODO: Should exceptions be handled in a different way?
- throw new JSONException(e.getMessage());
+ throw new RuntimeException(e);
}
return new EncodeResult(encoded, diff);
}
@@ -760,8 +766,8 @@ public class JsonCodec implements Serializable {
* @param referenceValue
* @return
*/
- private static boolean jsonEquals(Object fieldValue, Object referenceValue) {
- if (fieldValue == JSONObject.NULL) {
+ private static boolean jsonEquals(JsonValue fieldValue, JsonValue referenceValue) {
+ if (fieldValue instanceof JsonNull) {
fieldValue = null;
}
@@ -769,41 +775,33 @@ public class JsonCodec implements Serializable {
return true;
} else if (fieldValue == null || referenceValue == null) {
return false;
- } else if (fieldValue instanceof Integer
- && referenceValue instanceof Integer) {
- return ((Integer) fieldValue).equals(referenceValue);
- } else if (fieldValue instanceof Boolean
- && referenceValue instanceof Boolean) {
- return ((Boolean) fieldValue).equals(referenceValue);
} else {
- return fieldValue.toString().equals(referenceValue.toString());
+ return fieldValue.jsEquals(referenceValue);
}
}
- private static JSONArray encodeArrayContents(Type componentType,
- Object array, ConnectorTracker connectorTracker)
- throws JSONException {
- JSONArray jsonArray = new JSONArray();
+ private static JsonArray encodeArrayContents(Type componentType,
+ Object array, ConnectorTracker connectorTracker) {
+ JsonArray jsonArray = Json.createArray();
for (int i = 0; i < Array.getLength(array); i++) {
EncodeResult encodeResult = encode(Array.get(array, i), null,
componentType, connectorTracker);
- jsonArray.put(encodeResult.getEncodedValue());
+ jsonArray.set(i, encodeResult.getEncodedValue());
}
return jsonArray;
}
- private static JSONArray encodeCollection(Type targetType,
- Collection<?> collection, ConnectorTracker connectorTracker)
- throws JSONException {
- JSONArray jsonArray = new JSONArray();
+ private static JsonArray encodeCollection(Type targetType,
+ Collection<?> collection, ConnectorTracker connectorTracker) {
+ JsonArray jsonArray = Json.createArray();
for (Object o : collection) {
- jsonArray.put(encodeChild(targetType, 0, o, connectorTracker));
+ jsonArray.set(jsonArray.length(), encodeChild(targetType, 0, o, connectorTracker));
}
return jsonArray;
}
- private static Object encodeChild(Type targetType, int typeIndex, Object o,
- ConnectorTracker connectorTracker) throws JSONException {
+ private static JsonValue encodeChild(Type targetType, int typeIndex, Object o,
+ ConnectorTracker connectorTracker) {
if (targetType instanceof ParameterizedType) {
Type childType = ((ParameterizedType) targetType)
.getActualTypeArguments()[typeIndex];
@@ -812,19 +810,19 @@ public class JsonCodec implements Serializable {
connectorTracker);
return encodeResult.getEncodedValue();
} else {
- throw new JSONException("Collection is missing generics");
+ throw new JsonException("Collection is missing generics");
}
}
- private static Object encodeMap(Type mapType, Map<?, ?> map,
- ConnectorTracker connectorTracker) throws JSONException {
+ private static JsonValue encodeMap(Type mapType, Map<?, ?> map,
+ ConnectorTracker connectorTracker) {
Type keyType, valueType;
if (mapType instanceof ParameterizedType) {
keyType = ((ParameterizedType) mapType).getActualTypeArguments()[0];
valueType = ((ParameterizedType) mapType).getActualTypeArguments()[1];
} else {
- throw new JSONException("Map is missing generics");
+ throw new JsonException("Map is missing generics");
}
if (map.isEmpty()) {
@@ -842,11 +840,10 @@ public class JsonCodec implements Serializable {
}
}
- private static JSONArray encodeObjectMap(Type keyType, Type valueType,
- Map<?, ?> map, ConnectorTracker connectorTracker)
- throws JSONException {
- JSONArray keys = new JSONArray();
- JSONArray values = new JSONArray();
+ private static JsonArray encodeObjectMap(Type keyType, Type valueType,
+ Map<?, ?> map, ConnectorTracker connectorTracker) {
+ JsonArray keys = Json.createArray();
+ JsonArray values = Json.createArray();
for (Entry<?, ?> entry : map.entrySet()) {
EncodeResult encodedKey = encode(entry.getKey(), null, keyType,
@@ -854,19 +851,23 @@ public class JsonCodec implements Serializable {
EncodeResult encodedValue = encode(entry.getValue(), null,
valueType, connectorTracker);
- keys.put(encodedKey.getEncodedValue());
- values.put(encodedValue.getEncodedValue());
+ keys.set(keys.length(), encodedKey.getEncodedValue());
+ values.set(values.length(), encodedValue.getEncodedValue());
}
- return new JSONArray(Arrays.asList(keys, values));
+ JsonArray jsonMap = Json.createArray();
+ jsonMap.set(0, keys);
+ jsonMap.set(1, values);
+
+ return jsonMap;
}
/*
* Encodes a connector map. Invisible connectors are skipped.
*/
- private static JSONObject encodeConnectorMap(Type valueType, Map<?, ?> map,
- ConnectorTracker connectorTracker) throws JSONException {
- JSONObject jsonMap = new JSONObject();
+ private static JsonObject encodeConnectorMap(Type valueType, Map<?, ?> map,
+ ConnectorTracker connectorTracker) {
+ JsonObject jsonMap = Json.createObject();
for (Entry<?, ?> entry : map.entrySet()) {
ClientConnector key = (ClientConnector) entry.getKey();
@@ -881,9 +882,9 @@ public class JsonCodec implements Serializable {
return jsonMap;
}
- private static JSONObject encodeStringMap(Type valueType, Map<?, ?> map,
- ConnectorTracker connectorTracker) throws JSONException {
- JSONObject jsonMap = new JSONObject();
+ private static JsonObject encodeStringMap(Type valueType, Map<?, ?> map,
+ ConnectorTracker connectorTracker) {
+ JsonObject jsonMap = Json.createObject();
for (Entry<?, ?> entry : map.entrySet()) {
String key = (String) entry.getKey();
@@ -904,16 +905,16 @@ public class JsonCodec implements Serializable {
return typeToTransportType.get(getClassForType(valueType));
}
- private static Object serializeJson(Object value,
+ private static JsonValue serializeJson(Object value,
ConnectorTracker connectorTracker) {
- JSONSerializer serializer = customSerializers.get(value.getClass());
+ JsonSerializer serializer = customSerializers.get(value.getClass());
return serializer.serialize(value, connectorTracker);
}
- private static JSONArray toJsonArray(String[] array) {
- JSONArray jsonArray = new JSONArray();
+ private static JsonArray toJsonArray(String[] array) {
+ JsonArray jsonArray = Json.createArray();
for (int i = 0; i < array.length; ++i) {
- jsonArray.put(array[i]);
+ jsonArray.set(i, array[i]);
}
return jsonArray;
}
diff --git a/server/src/com/vaadin/server/LegacyCommunicationManager.java b/server/src/com/vaadin/server/LegacyCommunicationManager.java
index 0dda5661bd..e1beb1153c 100644
--- a/server/src/com/vaadin/server/LegacyCommunicationManager.java
+++ b/server/src/com/vaadin/server/LegacyCommunicationManager.java
@@ -27,9 +27,6 @@ import java.util.Set;
import java.util.logging.Level;
import java.util.logging.Logger;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.ClientConnector.ConnectorErrorEvent;
import com.vaadin.shared.ApplicationConstants;
import com.vaadin.shared.JavaScriptConnectorState;
@@ -40,6 +37,9 @@ import com.vaadin.ui.HasComponents;
import com.vaadin.ui.SelectiveRenderer;
import com.vaadin.ui.UI;
+import elemental.json.JsonObject;
+import elemental.json.JsonValue;
+
/**
* This is a common base class for the server-side implementations of the
* communication system between the client code (compiled with GWT into
@@ -85,12 +85,11 @@ public class LegacyCommunicationManager implements Serializable {
* @deprecated As of 7.1. See #11411.
*/
@Deprecated
- public static JSONObject encodeState(ClientConnector connector,
- SharedState state) throws JSONException {
+ public static JsonObject encodeState(ClientConnector connector, SharedState state) {
UI uI = connector.getUI();
ConnectorTracker connectorTracker = uI.getConnectorTracker();
Class<? extends SharedState> stateType = connector.getStateType();
- Object diffState = connectorTracker.getDiffState(connector);
+ JsonValue diffState = connectorTracker.getDiffState(connector);
boolean supportsDiffState = !JavaScriptConnectorState.class
.isAssignableFrom(stateType);
if (diffState == null && supportsDiffState) {
@@ -113,9 +112,9 @@ public class LegacyCommunicationManager implements Serializable {
stateType, uI.getConnectorTracker());
if (supportsDiffState) {
connectorTracker.setDiffState(connector,
- (JSONObject) encodeResult.getEncodedValue());
+ (JsonObject) encodeResult.getEncodedValue());
}
- return (JSONObject) encodeResult.getDiff();
+ return (JsonObject) encodeResult.getDiff();
}
/**
diff --git a/server/src/com/vaadin/server/VaadinService.java b/server/src/com/vaadin/server/VaadinService.java
index 8d44ff74ed..cf50ba7210 100644
--- a/server/src/com/vaadin/server/VaadinService.java
+++ b/server/src/com/vaadin/server/VaadinService.java
@@ -48,9 +48,6 @@ import javax.servlet.Servlet;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletResponse;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.annotations.PreserveOnRefresh;
import com.vaadin.event.EventRouter;
import com.vaadin.server.VaadinSession.FutureAccess;
@@ -67,6 +64,11 @@ import com.vaadin.ui.UI;
import com.vaadin.util.CurrentInstance;
import com.vaadin.util.ReflectTools;
+import elemental.json.Json;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+import elemental.json.impl.JsonUtil;
+
/**
* Provide deployment specific settings that are required outside terminal
* specific code.
@@ -1574,22 +1576,22 @@ public abstract class VaadinService implements Serializable {
message += "<br/><br/>" + details;
}
- JSONObject appError = new JSONObject();
+ JsonObject appError = Json.createObject();
appError.put("caption", caption);
appError.put("message", message);
appError.put("url", url);
- JSONObject meta = new JSONObject();
+ JsonObject meta = Json.createObject();
meta.put("appError", appError);
- JSONObject json = new JSONObject();
- json.put("changes", new JSONObject());
- json.put("resources", new JSONObject());
- json.put("locales", new JSONObject());
+ JsonObject json = Json.createObject();
+ json.put("changes", Json.createObject());
+ json.put("resources", Json.createObject());
+ json.put("locales", Json.createObject());
json.put("meta", meta);
json.put(ApplicationConstants.SERVER_SYNC_ID, -1);
- returnString = json.toString();
- } catch (JSONException e) {
+ returnString = JsonUtil.stringify(json);
+ } catch (JsonException e) {
getLogger().log(Level.WARNING,
"Error creating critical notification JSON message", e);
}
diff --git a/server/src/com/vaadin/server/communication/ClientRpcWriter.java b/server/src/com/vaadin/server/communication/ClientRpcWriter.java
index 1090fdbab9..6631f6176d 100644
--- a/server/src/com/vaadin/server/communication/ClientRpcWriter.java
+++ b/server/src/com/vaadin/server/communication/ClientRpcWriter.java
@@ -24,9 +24,6 @@ import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
-import org.json.JSONArray;
-import org.json.JSONException;
-
import com.vaadin.server.ClientConnector;
import com.vaadin.server.ClientMethodInvocation;
import com.vaadin.server.EncodeResult;
@@ -35,6 +32,12 @@ import com.vaadin.server.PaintException;
import com.vaadin.shared.communication.ClientRpc;
import com.vaadin.ui.UI;
+import elemental.json.Json;
+import elemental.json.JsonArray;
+import elemental.json.JsonException;
+import elemental.json.JsonValue;
+import elemental.json.impl.JsonUtil;
+
/**
* Serializes {@link ClientRpc client RPC} invocations to JSON.
*
@@ -59,18 +62,18 @@ public class ClientRpcWriter implements Serializable {
Collection<ClientMethodInvocation> pendingInvocations = collectPendingRpcCalls(ui
.getConnectorTracker().getDirtyVisibleConnectors());
- JSONArray rpcCalls = new JSONArray();
+ JsonArray rpcCalls = Json.createArray();
for (ClientMethodInvocation invocation : pendingInvocations) {
// add invocation to rpcCalls
try {
- JSONArray invocationJson = new JSONArray();
- invocationJson.put(invocation.getConnector().getConnectorId());
- invocationJson.put(invocation.getInterfaceName());
- invocationJson.put(invocation.getMethodName());
- JSONArray paramJson = new JSONArray();
+ JsonArray invocationJson = Json.createArray();
+ invocationJson.set(0, invocation.getConnector().getConnectorId());
+ invocationJson.set(1, invocation.getInterfaceName());
+ invocationJson.set(2, invocation.getMethodName());
+ JsonArray paramJson = Json.createArray();
for (int i = 0; i < invocation.getParameterTypes().length; ++i) {
Type parameterType = invocation.getParameterTypes()[i];
- Object referenceParameter = null;
+ JsonValue referenceParameter = null;
// TODO Use default values for RPC parameter types
// if (!JsonCodec.isInternalType(parameterType)) {
// try {
@@ -84,11 +87,11 @@ public class ClientRpcWriter implements Serializable {
EncodeResult encodeResult = JsonCodec.encode(
invocation.getParameters()[i], referenceParameter,
parameterType, ui.getConnectorTracker());
- paramJson.put(encodeResult.getEncodedValue());
+ paramJson.set(i, encodeResult.getEncodedValue());
}
- invocationJson.put(paramJson);
- rpcCalls.put(invocationJson);
- } catch (JSONException e) {
+ invocationJson.set(3, paramJson);
+ rpcCalls.set(rpcCalls.length(), invocationJson);
+ } catch (JsonException e) {
throw new PaintException(
"Failed to serialize RPC method call parameters for connector "
+ invocation.getConnector().getConnectorId()
@@ -97,7 +100,7 @@ public class ClientRpcWriter implements Serializable {
+ e.getMessage(), e);
}
}
- writer.write(rpcCalls.toString());
+ writer.write(JsonUtil.stringify(rpcCalls));
}
/**
diff --git a/server/src/com/vaadin/server/communication/ConnectorHierarchyWriter.java b/server/src/com/vaadin/server/communication/ConnectorHierarchyWriter.java
index 653048b930..1c1a220b5d 100644
--- a/server/src/com/vaadin/server/communication/ConnectorHierarchyWriter.java
+++ b/server/src/com/vaadin/server/communication/ConnectorHierarchyWriter.java
@@ -21,16 +21,18 @@ import java.io.Serializable;
import java.io.Writer;
import java.util.Collection;
-import org.json.JSONArray;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.AbstractClientConnector;
import com.vaadin.server.ClientConnector;
import com.vaadin.server.LegacyCommunicationManager;
import com.vaadin.server.PaintException;
import com.vaadin.ui.UI;
+import elemental.json.Json;
+import elemental.json.JsonArray;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+import elemental.json.impl.JsonUtil;
+
/**
* Serializes a connector hierarchy to JSON.
*
@@ -55,27 +57,27 @@ public class ConnectorHierarchyWriter implements Serializable {
Collection<ClientConnector> dirtyVisibleConnectors = ui
.getConnectorTracker().getDirtyVisibleConnectors();
- JSONObject hierarchyInfo = new JSONObject();
+ JsonObject hierarchyInfo = Json.createObject();
for (ClientConnector connector : dirtyVisibleConnectors) {
String connectorId = connector.getConnectorId();
- JSONArray children = new JSONArray();
+ JsonArray children = Json.createArray();
for (ClientConnector child : AbstractClientConnector
.getAllChildrenIterable(connector)) {
if (LegacyCommunicationManager
.isConnectorVisibleToClient(child)) {
- children.put(child.getConnectorId());
+ children.set(children.length(), child.getConnectorId());
}
}
try {
hierarchyInfo.put(connectorId, children);
- } catch (JSONException e) {
+ } catch (JsonException e) {
throw new PaintException(
"Failed to send hierarchy information about "
+ connectorId + " to the client: "
+ e.getMessage(), e);
}
}
- writer.write(hierarchyInfo.toString());
+ writer.write(JsonUtil.stringify(hierarchyInfo));
}
}
diff --git a/server/src/com/vaadin/server/communication/ConnectorTypeWriter.java b/server/src/com/vaadin/server/communication/ConnectorTypeWriter.java
index 0bafd20a81..d534987061 100644
--- a/server/src/com/vaadin/server/communication/ConnectorTypeWriter.java
+++ b/server/src/com/vaadin/server/communication/ConnectorTypeWriter.java
@@ -21,14 +21,16 @@ import java.io.Serializable;
import java.io.Writer;
import java.util.Collection;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.ClientConnector;
import com.vaadin.server.PaintException;
import com.vaadin.server.PaintTarget;
import com.vaadin.ui.UI;
+import elemental.json.Json;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+import elemental.json.impl.JsonUtil;
+
/**
* Serializes connector type mappings to JSON.
*
@@ -56,18 +58,18 @@ public class ConnectorTypeWriter implements Serializable {
Collection<ClientConnector> dirtyVisibleConnectors = ui
.getConnectorTracker().getDirtyVisibleConnectors();
- JSONObject connectorTypes = new JSONObject();
+ JsonObject connectorTypes = Json.createObject();
for (ClientConnector connector : dirtyVisibleConnectors) {
String connectorType = target.getTag(connector);
try {
connectorTypes.put(connector.getConnectorId(), connectorType);
- } catch (JSONException e) {
+ } catch (JsonException e) {
throw new PaintException(
"Failed to send connector type for connector "
+ connector.getConnectorId() + ": "
+ e.getMessage(), e);
}
}
- writer.write(connectorTypes.toString());
+ writer.write(JsonUtil.stringify(connectorTypes));
}
}
diff --git a/server/src/com/vaadin/server/communication/DateSerializer.java b/server/src/com/vaadin/server/communication/DateSerializer.java
index 429941abfd..b66e46bc96 100644
--- a/server/src/com/vaadin/server/communication/DateSerializer.java
+++ b/server/src/com/vaadin/server/communication/DateSerializer.java
@@ -19,6 +19,8 @@ import java.lang.reflect.Type;
import java.util.Date;
import com.vaadin.ui.ConnectorTracker;
+import elemental.json.Json;
+import elemental.json.JsonValue;
/**
* Server side serializer/deserializer for java.util.Date
@@ -26,17 +28,17 @@ import com.vaadin.ui.ConnectorTracker;
* @since 7.2
* @author Vaadin Ltd
*/
-public class DateSerializer implements JSONSerializer<Date> {
+public class DateSerializer implements JsonSerializer<Date> {
@Override
- public Date deserialize(Type type, Object jsonValue,
+ public Date deserialize(Type type, JsonValue jsonValue,
ConnectorTracker connectorTracker) {
- return new Date(Long.valueOf(String.valueOf(jsonValue)));
+ return new Date((long) jsonValue.asNumber());
}
@Override
- public Object serialize(Date value, ConnectorTracker connectorTracker) {
- return value.getTime();
+ public JsonValue serialize(Date value, ConnectorTracker connectorTracker) {
+ return Json.create(value.getTime());
}
}
diff --git a/server/src/com/vaadin/server/communication/JSONSerializer.java b/server/src/com/vaadin/server/communication/JsonSerializer.java
index 91105d6ffd..39d145ec1b 100644
--- a/server/src/com/vaadin/server/communication/JSONSerializer.java
+++ b/server/src/com/vaadin/server/communication/JsonSerializer.java
@@ -18,17 +18,18 @@ package com.vaadin.server.communication;
import java.lang.reflect.Type;
import com.vaadin.ui.ConnectorTracker;
+import elemental.json.JsonValue;
/**
* Implementors of this interface knows how to serialize an Object of a given
* type to JSON and how to deserialize the JSON back into an object.
* <p>
* The {@link #serialize(Object, ConnectorTracker)} and
- * {@link #deserialize(Type, Object, ConnectorTracker)} methods must be
+ * {@link #deserialize(Type, JsonValue, ConnectorTracker)} methods must be
* symmetric so they can be chained and produce the original result (or an equal
* result).
* <p>
- * Each {@link JSONSerializer} implementation can handle an object of a single
+ * Each {@link JsonSerializer} implementation can handle an object of a single
* type.
* <p>
* This is the server side interface, see
@@ -37,15 +38,12 @@ import com.vaadin.ui.ConnectorTracker;
* @since 7.2
* @author Vaadin Ltd
*/
-public interface JSONSerializer<T> {
+public interface JsonSerializer<T> {
/**
* Creates and deserializes an object received from the client. Must be
* compatible with {@link #serialize(Object, ConnectorTracker)} and also
* with the client side com.vaadin.client.communication.JSONSerializer.
- * <p>
- * The json parameter is of type Object as org.json JSON classes have no
- * other common super class
- *
+ *
* @param type
* The expected return type
* @param jsonValue
@@ -54,11 +52,11 @@ public interface JSONSerializer<T> {
* the connector tracker instance for the UI
* @return A deserialized object
*/
- T deserialize(Type type, Object jsonValue, ConnectorTracker connectorTracker);
+ T deserialize(Type type, JsonValue jsonValue, ConnectorTracker connectorTracker);
/**
* Serialize the given object into JSON. Must be compatible with
- * {@link #deserialize(Object, connectorTracker)} and the client side
+ * {@link #deserialize(Type, JsonValue, ConnectorTracker)} and the client side
* com.vaadin.client.communication.JSONSerializer
*
* @param value
@@ -67,6 +65,6 @@ public interface JSONSerializer<T> {
* The connector tracker instance for the UI
* @return A JSON serialized version of the object
*/
- Object serialize(T value, ConnectorTracker connectorTracker);
+ JsonValue serialize(T value, ConnectorTracker connectorTracker);
}
diff --git a/server/src/com/vaadin/server/communication/PortletBootstrapHandler.java b/server/src/com/vaadin/server/communication/PortletBootstrapHandler.java
index 66b08fdadd..1d1a300cd1 100644
--- a/server/src/com/vaadin/server/communication/PortletBootstrapHandler.java
+++ b/server/src/com/vaadin/server/communication/PortletBootstrapHandler.java
@@ -25,9 +25,6 @@ import javax.portlet.RenderRequest;
import javax.portlet.RenderResponse;
import javax.portlet.ResourceURL;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.BootstrapHandler;
import com.vaadin.server.PaintException;
import com.vaadin.server.VaadinPortlet;
@@ -39,6 +36,7 @@ import com.vaadin.server.VaadinResponse;
import com.vaadin.server.VaadinService;
import com.vaadin.server.VaadinSession;
import com.vaadin.shared.ApplicationConstants;
+import elemental.json.JsonObject;
public class PortletBootstrapHandler extends BootstrapHandler {
@Override
@@ -71,7 +69,7 @@ public class PortletBootstrapHandler extends BootstrapHandler {
@Override
protected void appendMainScriptTagContents(BootstrapContext context,
- StringBuilder builder) throws JSONException, IOException {
+ StringBuilder builder) throws IOException {
// fixed base theme to use - all portal pages with Vaadin
// applications will load this exactly once
String portalTheme = ((VaadinPortletRequest) context.getRequest())
@@ -94,9 +92,9 @@ public class PortletBootstrapHandler extends BootstrapHandler {
}
@Override
- protected JSONObject getApplicationParameters(BootstrapContext context)
- throws JSONException, PaintException {
- JSONObject parameters = super.getApplicationParameters(context);
+ protected JsonObject getApplicationParameters(BootstrapContext context)
+ throws PaintException {
+ JsonObject parameters = super.getApplicationParameters(context);
VaadinPortletResponse response = (VaadinPortletResponse) context
.getResponse();
VaadinPortletRequest request = (VaadinPortletRequest) context
diff --git a/server/src/com/vaadin/server/communication/PushHandler.java b/server/src/com/vaadin/server/communication/PushHandler.java
index 67e5f87153..6ee81270cd 100644
--- a/server/src/com/vaadin/server/communication/PushHandler.java
+++ b/server/src/com/vaadin/server/communication/PushHandler.java
@@ -29,7 +29,6 @@ import org.atmosphere.cpr.AtmosphereResource.TRANSPORT;
import org.atmosphere.cpr.AtmosphereResourceEvent;
import org.atmosphere.cpr.AtmosphereResourceEventListenerAdapter;
import org.atmosphere.handler.AbstractReflectorAtmosphereHandler;
-import org.json.JSONException;
import com.vaadin.server.ErrorEvent;
import com.vaadin.server.ErrorHandler;
@@ -46,6 +45,7 @@ import com.vaadin.server.VaadinSession;
import com.vaadin.shared.ApplicationConstants;
import com.vaadin.shared.communication.PushMode;
import com.vaadin.ui.UI;
+import elemental.json.JsonException;
/**
* Establishes bidirectional ("push") communication channels
@@ -173,7 +173,7 @@ public class PushHandler extends AtmosphereResourceEventListenerAdapter {
try {
new ServerRpcHandler().handleRpc(ui, reader, vaadinRequest);
connection.push(false);
- } catch (JSONException e) {
+ } catch (JsonException e) {
getLogger().log(Level.SEVERE, "Error writing JSON to response",
e);
// Refresh on client side
diff --git a/server/src/com/vaadin/server/communication/ServerRpcHandler.java b/server/src/com/vaadin/server/communication/ServerRpcHandler.java
index ae076e0856..d1b1be6b97 100644
--- a/server/src/com/vaadin/server/communication/ServerRpcHandler.java
+++ b/server/src/com/vaadin/server/communication/ServerRpcHandler.java
@@ -28,10 +28,6 @@ import java.util.Set;
import java.util.logging.Level;
import java.util.logging.Logger;
-import org.json.JSONArray;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.ClientConnector;
import com.vaadin.server.JsonCodec;
import com.vaadin.server.LegacyCommunicationManager;
@@ -52,6 +48,12 @@ import com.vaadin.ui.Component;
import com.vaadin.ui.ConnectorTracker;
import com.vaadin.ui.UI;
+import elemental.json.JsonArray;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+import elemental.json.JsonValue;
+import elemental.json.impl.JsonUtil;
+
/**
* Handles a client-to-server message containing serialized {@link ServerRpc
* server RPC} invocations.
@@ -71,28 +73,31 @@ public class ServerRpcHandler implements Serializable {
public static class RpcRequest implements Serializable {
private final String csrfToken;
- private final JSONArray invocations;
+ private final JsonArray invocations;
private final int syncId;
- private final JSONObject json;
+ private final JsonObject json;
- public RpcRequest(String jsonString, VaadinRequest request)
- throws JSONException {
- json = new JSONObject(jsonString);
+ public RpcRequest(String jsonString, VaadinRequest request) {
+ json = JsonUtil.parse(jsonString);
- String csrfToken = json.optString(ApplicationConstants.CSRF_TOKEN);
- if (csrfToken.equals("")) {
- csrfToken = ApplicationConstants.CSRF_TOKEN_DEFAULT_VALUE;
+ JsonValue token = json.get(ApplicationConstants.CSRF_TOKEN);
+ if (token == null) {
+ this.csrfToken = ApplicationConstants.CSRF_TOKEN_DEFAULT_VALUE;
+ } else {
+ String csrfToken = token.asString();
+ if (csrfToken.equals("")) {
+ csrfToken = ApplicationConstants.CSRF_TOKEN_DEFAULT_VALUE;
+ }
+ this.csrfToken = csrfToken;
}
- this.csrfToken = csrfToken;
if (request.getService().getDeploymentConfiguration()
.isSyncIdCheckEnabled()) {
- syncId = json.getInt(ApplicationConstants.SERVER_SYNC_ID);
+ syncId = (int) json.getNumber(ApplicationConstants.SERVER_SYNC_ID);
} else {
syncId = -1;
}
- invocations = json
- .getJSONArray(ApplicationConstants.RPC_INVOCATIONS);
+ invocations = json.getArray(ApplicationConstants.RPC_INVOCATIONS);
}
/**
@@ -110,7 +115,7 @@ public class ServerRpcHandler implements Serializable {
* @return the data describing which RPC should be made, and all their
* data
*/
- public JSONArray getRpcInvocationsData() {
+ public JsonArray getRpcInvocationsData() {
return invocations;
}
@@ -134,7 +139,7 @@ public class ServerRpcHandler implements Serializable {
* @return the raw JSON object that was received from the client
*
*/
- public JSONObject getRawJson() {
+ public JsonObject getRawJson() {
return json;
}
}
@@ -155,11 +160,9 @@ public class ServerRpcHandler implements Serializable {
* @throws InvalidUIDLSecurityKeyException
* If the received security key does not match the one stored in
* the session.
- * @throws JSONException
- * If deserializing the JSON fails.
*/
public void handleRpc(UI ui, Reader reader, VaadinRequest request)
- throws IOException, InvalidUIDLSecurityKeyException, JSONException {
+ throws IOException, InvalidUIDLSecurityKeyException {
ui.getSession().setLastRequestTimestamp(System.currentTimeMillis());
String changeMessage = getMessage(reader);
@@ -205,7 +208,7 @@ public class ServerRpcHandler implements Serializable {
* requested RPC calls.
*/
private void handleInvocations(UI uI, int lastSyncIdSeenByClient,
- JSONArray invocationsData) {
+ JsonArray invocationsData) {
// TODO PUSH Refactor so that this is not needed
LegacyCommunicationManager manager = uI.getSession()
.getCommunicationManager();
@@ -314,7 +317,7 @@ public class ServerRpcHandler implements Serializable {
}
}
}
- } catch (JSONException e) {
+ } catch (JsonException e) {
getLogger().warning(
"Unable to parse RPC call from the client: "
+ e.getMessage());
@@ -334,11 +337,10 @@ public class ServerRpcHandler implements Serializable {
* the most recent sync id the client has seen at the time the
* request was sent
* @return list of MethodInvocation to perform
- * @throws JSONException
*/
private List<MethodInvocation> parseInvocations(
- ConnectorTracker connectorTracker, JSONArray invocationsJson,
- int lastSyncIdSeenByClient) throws JSONException {
+ ConnectorTracker connectorTracker, JsonArray invocationsJson,
+ int lastSyncIdSeenByClient) {
int invocationCount = invocationsJson.length();
ArrayList<MethodInvocation> invocations = new ArrayList<MethodInvocation>(
invocationCount);
@@ -347,7 +349,7 @@ public class ServerRpcHandler implements Serializable {
// parse JSON to MethodInvocations
for (int i = 0; i < invocationCount; ++i) {
- JSONArray invocationJson = invocationsJson.getJSONArray(i);
+ JsonArray invocationJson = invocationsJson.getArray(i);
MethodInvocation invocation = parseInvocation(invocationJson,
previousInvocation, connectorTracker,
@@ -363,17 +365,15 @@ public class ServerRpcHandler implements Serializable {
return invocations;
}
- private MethodInvocation parseInvocation(JSONArray invocationJson,
+ private MethodInvocation parseInvocation(JsonArray invocationJson,
MethodInvocation previousInvocation,
- ConnectorTracker connectorTracker, long lastSyncIdSeenByClient)
- throws JSONException {
+ ConnectorTracker connectorTracker, long lastSyncIdSeenByClient) {
String connectorId = invocationJson.getString(0);
String interfaceName = invocationJson.getString(1);
String methodName = invocationJson.getString(2);
if (connectorTracker.getConnector(connectorId) == null
- && !connectorId
- .equals(ApplicationConstants.DRAG_AND_DROP_CONNECTOR_ID)) {
+ && !connectorId.equals(ApplicationConstants.DRAG_AND_DROP_CONNECTOR_ID)) {
if (!connectorTracker.connectorWasPresentAsRequestWasSent(
connectorId, lastSyncIdSeenByClient)) {
@@ -393,7 +393,7 @@ public class ServerRpcHandler implements Serializable {
return null;
}
- JSONArray parametersJson = invocationJson.getJSONArray(3);
+ JsonArray parametersJson = invocationJson.getArray(3);
if (LegacyChangeVariablesInvocation.isLegacyVariableChange(
interfaceName, methodName)) {
@@ -415,10 +415,9 @@ public class ServerRpcHandler implements Serializable {
private LegacyChangeVariablesInvocation parseLegacyChangeVariablesInvocation(
String connectorId, String interfaceName, String methodName,
LegacyChangeVariablesInvocation previousInvocation,
- JSONArray parametersJson, ConnectorTracker connectorTracker)
- throws JSONException {
+ JsonArray parametersJson, ConnectorTracker connectorTracker) {
if (parametersJson.length() != 2) {
- throw new JSONException(
+ throw new JsonException(
"Invalid parameters in legacy change variables call. Expected 2, was "
+ parametersJson.length());
}
@@ -440,8 +439,8 @@ public class ServerRpcHandler implements Serializable {
private ServerRpcMethodInvocation parseServerRpcInvocation(
String connectorId, String interfaceName, String methodName,
- JSONArray parametersJson, ConnectorTracker connectorTracker)
- throws JSONException {
+ JsonArray parametersJson, ConnectorTracker connectorTracker)
+ throws JsonException {
ClientConnector connector = connectorTracker.getConnector(connectorId);
ServerRpcManager<?> rpcManager = connector.getRpcManager(interfaceName);
@@ -471,7 +470,7 @@ public class ServerRpcHandler implements Serializable {
.getGenericParameterTypes();
for (int j = 0; j < parametersJson.length(); ++j) {
- Object parameterValue = parametersJson.get(j);
+ JsonValue parameterValue = parametersJson.get(j);
Type parameterType = declaredRpcMethodParameterTypes[j];
parameters[j] = JsonCodec.decodeInternalOrCustomType(parameterType,
parameterValue, connectorTracker);
diff --git a/server/src/com/vaadin/server/communication/SharedStateWriter.java b/server/src/com/vaadin/server/communication/SharedStateWriter.java
index 6a318f0758..6ef02955f7 100644
--- a/server/src/com/vaadin/server/communication/SharedStateWriter.java
+++ b/server/src/com/vaadin/server/communication/SharedStateWriter.java
@@ -21,14 +21,16 @@ import java.io.Serializable;
import java.io.Writer;
import java.util.Collection;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.ClientConnector;
import com.vaadin.server.PaintException;
import com.vaadin.shared.communication.SharedState;
import com.vaadin.ui.UI;
+import elemental.json.Json;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+import elemental.json.impl.JsonUtil;
+
/**
* Serializes {@link SharedState shared state} changes to JSON.
*
@@ -53,16 +55,16 @@ public class SharedStateWriter implements Serializable {
Collection<ClientConnector> dirtyVisibleConnectors = ui
.getConnectorTracker().getDirtyVisibleConnectors();
- JSONObject sharedStates = new JSONObject();
+ JsonObject sharedStates = Json.createObject();
for (ClientConnector connector : dirtyVisibleConnectors) {
// encode and send shared state
try {
- JSONObject stateJson = connector.encodeState();
+ JsonObject stateJson = connector.encodeState();
- if (stateJson != null && stateJson.length() != 0) {
+ if (stateJson != null && stateJson.keys().length != 0) {
sharedStates.put(connector.getConnectorId(), stateJson);
}
- } catch (JSONException e) {
+ } catch (JsonException e) {
throw new PaintException(
"Failed to serialize shared state for connector "
+ connector.getClass().getName() + " ("
@@ -70,6 +72,6 @@ public class SharedStateWriter implements Serializable {
+ e.getMessage(), e);
}
}
- writer.write(sharedStates.toString());
+ writer.write(JsonUtil.stringify(sharedStates));
}
}
diff --git a/server/src/com/vaadin/server/communication/UIInitHandler.java b/server/src/com/vaadin/server/communication/UIInitHandler.java
index cf0de8e9ee..356ad25219 100644
--- a/server/src/com/vaadin/server/communication/UIInitHandler.java
+++ b/server/src/com/vaadin/server/communication/UIInitHandler.java
@@ -23,9 +23,6 @@ import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.annotations.PreserveOnRefresh;
import com.vaadin.server.LegacyApplicationUIProvider;
import com.vaadin.server.SynchronizedRequestHandler;
@@ -43,6 +40,11 @@ import com.vaadin.shared.ui.ui.Transport;
import com.vaadin.shared.ui.ui.UIConstants;
import com.vaadin.ui.UI;
+import elemental.json.Json;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+import elemental.json.impl.JsonUtil;
+
/**
* Handles an initial request from the client to initialize a {@link UI}.
*
@@ -75,13 +77,13 @@ public abstract class UIInitHandler extends SynchronizedRequestHandler {
session.getCommunicationManager().repaintAll(uI);
- JSONObject params = new JSONObject();
+ JsonObject params = Json.createObject();
params.put(UIConstants.UI_ID_PARAMETER, uI.getUIId());
String initialUIDL = getInitialUidl(request, uI);
params.put("uidl", initialUIDL);
- stringWriter.write(params.toString());
- } catch (JSONException e) {
+ stringWriter.write(JsonUtil.stringify(params));
+ } catch (JsonException e) {
throw new IOException("Error producing initial UIDL", e);
} finally {
stringWriter.close();
@@ -278,12 +280,10 @@ public abstract class UIInitHandler extends SynchronizedRequestHandler {
* @param uI
* the UI for which the UIDL should be generated
* @return a string with the initial UIDL message
- * @throws JSONException
- * if an exception occurs while encoding output
* @throws IOException
*/
protected String getInitialUidl(VaadinRequest request, UI uI)
- throws JSONException, IOException {
+ throws IOException {
StringWriter writer = new StringWriter();
try {
writer.write("{");
diff --git a/server/src/com/vaadin/server/communication/UidlRequestHandler.java b/server/src/com/vaadin/server/communication/UidlRequestHandler.java
index 0d8ddb7bc7..d28107e8f8 100644
--- a/server/src/com/vaadin/server/communication/UidlRequestHandler.java
+++ b/server/src/com/vaadin/server/communication/UidlRequestHandler.java
@@ -22,8 +22,6 @@ import java.io.Writer;
import java.util.logging.Level;
import java.util.logging.Logger;
-import org.json.JSONException;
-
import com.vaadin.server.Constants;
import com.vaadin.server.LegacyCommunicationManager.InvalidUIDLSecurityKeyException;
import com.vaadin.server.ServletPortletHelper;
@@ -38,6 +36,7 @@ import com.vaadin.shared.ApplicationConstants;
import com.vaadin.shared.JsonConstants;
import com.vaadin.shared.Version;
import com.vaadin.ui.UI;
+import elemental.json.JsonException;
/**
* Processes a UIDL request from the client.
@@ -97,7 +96,7 @@ public class UidlRequestHandler extends SynchronizedRequestHandler implements
}
writeUidl(request, response, uI, stringWriter, repaintAll);
- } catch (JSONException e) {
+ } catch (JsonException e) {
getLogger().log(Level.SEVERE, "Error writing JSON to response", e);
// Refresh on client side
response.getWriter().write(
@@ -144,8 +143,7 @@ public class UidlRequestHandler extends SynchronizedRequestHandler implements
}
private void writeUidl(VaadinRequest request, VaadinResponse response,
- UI ui, Writer writer, boolean repaintAll) throws IOException,
- JSONException {
+ UI ui, Writer writer, boolean repaintAll) throws IOException {
openJsonMessage(writer, response);
new UidlWriter().write(ui, writer, repaintAll, false);
diff --git a/server/src/com/vaadin/server/communication/UidlWriter.java b/server/src/com/vaadin/server/communication/UidlWriter.java
index 9d55f7e197..3b2caba55b 100644
--- a/server/src/com/vaadin/server/communication/UidlWriter.java
+++ b/server/src/com/vaadin/server/communication/UidlWriter.java
@@ -27,9 +27,6 @@ import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
-import org.json.JSONArray;
-import org.json.JSONException;
-
import com.vaadin.annotations.JavaScript;
import com.vaadin.annotations.StyleSheet;
import com.vaadin.server.ClientConnector;
@@ -43,6 +40,10 @@ import com.vaadin.shared.ApplicationConstants;
import com.vaadin.ui.ConnectorTracker;
import com.vaadin.ui.UI;
+import elemental.json.Json;
+import elemental.json.JsonArray;
+import elemental.json.impl.JsonUtil;
+
/**
* Serializes pending server-side changes to UI state to JSON. This includes
* shared state, client RPC invocations, connector hierarchy changes, connector
@@ -70,11 +71,9 @@ public class UidlWriter implements Serializable {
*
* @throws IOException
* If the writing fails.
- * @throws JSONException
- * If the JSON serialization fails.
*/
public void write(UI ui, Writer writer, boolean repaintAll, boolean async)
- throws IOException, JSONException {
+ throws IOException {
VaadinSession session = ui.getSession();
VaadinService service = session.getService();
@@ -282,13 +281,13 @@ public class UidlWriter implements Serializable {
// Include script dependencies in output if there are any
if (!scriptDependencies.isEmpty()) {
writer.write(", \"scriptDependencies\": "
- + new JSONArray(scriptDependencies).toString());
+ + JsonUtil.stringify(toJsonArray(scriptDependencies)));
}
// Include style dependencies in output if there are any
if (!styleDependencies.isEmpty()) {
writer.write(", \"styleDependencies\": "
- + new JSONArray(styleDependencies).toString());
+ + JsonUtil.stringify(toJsonArray(styleDependencies)));
}
session.getDragAndDropService().printJSONResponse(writer);
@@ -306,6 +305,15 @@ public class UidlWriter implements Serializable {
}
}
+ private JsonArray toJsonArray(List<String> list) {
+ JsonArray result = Json.createArray();
+ for (int i = 0; i < list.size(); i++) {
+ result.set(i, list.get(i));
+ }
+
+ return result;
+ }
+
/**
* Adds the performance timing data (used by TestBench 3) to the UIDL
* response.
diff --git a/server/src/com/vaadin/ui/Button.java b/server/src/com/vaadin/ui/Button.java
index 58b6f9de81..76b82aa034 100644
--- a/server/src/com/vaadin/ui/Button.java
+++ b/server/src/com/vaadin/ui/Button.java
@@ -19,8 +19,6 @@ package com.vaadin.ui;
import java.io.Serializable;
import java.lang.reflect.Method;
-import org.json.JSONException;
-
import com.vaadin.event.Action;
import com.vaadin.event.FieldEvents;
import com.vaadin.event.FieldEvents.BlurEvent;
@@ -63,12 +61,8 @@ public class Button extends AbstractComponent implements
// Makes sure the enabled=false state is noticed at once - otherwise
// a following setEnabled(true) call might have no effect. see
// ticket #10030
- try {
- getUI().getConnectorTracker().getDiffState(Button.this)
- .put("enabled", false);
- } catch (JSONException e) {
- throw new RuntimeException(e);
- }
+ getUI().getConnectorTracker().getDiffState(Button.this)
+ .put("enabled", false);
}
};
diff --git a/server/src/com/vaadin/ui/CheckBox.java b/server/src/com/vaadin/ui/CheckBox.java
index 3c4ce1c528..7d9da30f29 100644
--- a/server/src/com/vaadin/ui/CheckBox.java
+++ b/server/src/com/vaadin/ui/CheckBox.java
@@ -16,8 +16,6 @@
package com.vaadin.ui;
-import org.json.JSONException;
-
import com.vaadin.data.Property;
import com.vaadin.event.FieldEvents.BlurEvent;
import com.vaadin.event.FieldEvents.BlurListener;
@@ -47,12 +45,8 @@ public class CheckBox extends AbstractField<Boolean> {
*
* See #11028, #10030.
*/
- try {
- getUI().getConnectorTracker().getDiffState(CheckBox.this)
- .put("checked", checked);
- } catch (JSONException e) {
- throw new RuntimeException(e);
- }
+ getUI().getConnectorTracker().getDiffState(CheckBox.this)
+ .put("checked", checked);
final Boolean oldValue = getValue();
final Boolean newValue = checked;
diff --git a/server/src/com/vaadin/ui/ConnectorTracker.java b/server/src/com/vaadin/ui/ConnectorTracker.java
index 9b8729f779..5386eb9d64 100644
--- a/server/src/com/vaadin/ui/ConnectorTracker.java
+++ b/server/src/com/vaadin/ui/ConnectorTracker.java
@@ -30,9 +30,6 @@ import java.util.UUID;
import java.util.logging.Level;
import java.util.logging.Logger;
-import org.json.JSONException;
-import org.json.JSONObject;
-
import com.vaadin.server.AbstractClientConnector;
import com.vaadin.server.ClientConnector;
import com.vaadin.server.DragAndDropService;
@@ -40,6 +37,10 @@ import com.vaadin.server.GlobalResourceHandler;
import com.vaadin.server.LegacyCommunicationManager;
import com.vaadin.server.StreamVariable;
+import elemental.json.Json;
+import elemental.json.JsonException;
+import elemental.json.JsonObject;
+
/**
* A class which takes care of book keeping of {@link ClientConnector}s for a
* UI.
@@ -76,7 +77,7 @@ public class ConnectorTracker implements Serializable {
private boolean writingResponse = false;
private UI uI;
- private transient Map<ClientConnector, JSONObject> diffStates = new HashMap<ClientConnector, JSONObject>();
+ private transient Map<ClientConnector, JsonObject> diffStates = new HashMap<ClientConnector, JsonObject>();
/** Maps connectorIds to a map of named StreamVariables */
private Map<String, Map<String, StreamVariable>> pidToNameToStreamVariable;
@@ -556,12 +557,12 @@ public class ConnectorTracker implements Serializable {
return dirtyVisibleConnectors;
}
- public JSONObject getDiffState(ClientConnector connector) {
+ public JsonObject getDiffState(ClientConnector connector) {
assert getConnector(connector.getConnectorId()) == connector;
return diffStates.get(connector);
}
- public void setDiffState(ClientConnector connector, JSONObject diffState) {
+ public void setDiffState(ClientConnector connector, JsonObject diffState) {
assert getConnector(connector.getConnectorId()) == connector;
diffStates.put(connector, diffState);
}
@@ -621,11 +622,11 @@ public class ConnectorTracker implements Serializable {
this.writingResponse = writingResponse;
}
- /* Special serialization to JSONObjects which are not serializable */
+ /* Special serialization to JsonObjects which are not serializable */
private void writeObject(java.io.ObjectOutputStream out) throws IOException {
out.defaultWriteObject();
- // Convert JSONObjects in diff state to String representation as
- // JSONObject is not serializable
+ // Convert JsonObjects in diff state to String representation as
+ // JsonObject is not serializable
HashMap<ClientConnector, String> stringDiffStates = new HashMap<ClientConnector, String>(
diffStates.size() * 2);
for (ClientConnector key : diffStates.keySet()) {
@@ -634,23 +635,23 @@ public class ConnectorTracker implements Serializable {
out.writeObject(stringDiffStates);
}
- /* Special serialization to JSONObjects which are not serializable */
+ /* Special serialization to JsonObjects which are not serializable */
private void readObject(java.io.ObjectInputStream in) throws IOException,
ClassNotFoundException {
in.defaultReadObject();
- // Read String versions of JSONObjects and parse into JSONObjects as
- // JSONObject is not serializable
- diffStates = new HashMap<ClientConnector, JSONObject>();
+ // Read String versions of JsonObjects and parse into JsonObjects as
+ // JsonObject is not serializable
+ diffStates = new HashMap<ClientConnector, JsonObject>();
@SuppressWarnings("unchecked")
HashMap<ClientConnector, String> stringDiffStates = (HashMap<ClientConnector, String>) in
.readObject();
- diffStates = new HashMap<ClientConnector, JSONObject>(
+ diffStates = new HashMap<ClientConnector, JsonObject>(
stringDiffStates.size() * 2);
for (ClientConnector key : stringDiffStates.keySet()) {
try {
- diffStates.put(key, new JSONObject(stringDiffStates.get(key)));
- } catch (JSONException e) {
+ diffStates.put(key, Json.parse(stringDiffStates.get(key)));
+ } catch (JsonException e) {
throw new IOException(e);
}
}
diff --git a/server/src/com/vaadin/ui/JavaScript.java b/server/src/com/vaadin/ui/JavaScript.java
index 68c8c9a6e4..668ae67056 100644
--- a/server/src/com/vaadin/ui/JavaScript.java
+++ b/server/src/com/vaadin/ui/JavaScript.java
@@ -19,15 +19,15 @@ package com.vaadin.ui;
import java.util.HashMap;
import java.util.Map;
-import org.json.JSONArray;
-import org.json.JSONException;
-
import com.vaadin.server.AbstractExtension;
import com.vaadin.server.Page;
import com.vaadin.shared.communication.ServerRpc;
import com.vaadin.shared.extension.javascriptmanager.ExecuteJavaScriptRpc;
import com.vaadin.shared.extension.javascriptmanager.JavaScriptManagerState;
+import elemental.json.JsonArray;
+import elemental.json.JsonException;
+
/**
* Provides access to JavaScript functionality in the web browser. To get an
* instance of JavaScript, either use Page.getJavaScript() or
@@ -43,7 +43,7 @@ public class JavaScript extends AbstractExtension {
// Can not be defined in client package as this JSONArray is not available
// in GWT
public interface JavaScriptCallbackRpc extends ServerRpc {
- public void call(String name, JSONArray arguments);
+ public void call(String name, JsonArray arguments);
}
/**
@@ -54,12 +54,12 @@ public class JavaScript extends AbstractExtension {
public JavaScript() {
registerRpc(new JavaScriptCallbackRpc() {
@Override
- public void call(String name, JSONArray arguments) {
+ public void call(String name, JsonArray arguments) {
JavaScriptFunction function = functions.get(name);
// TODO handle situation if name is not registered
try {
function.call(arguments);
- } catch (JSONException e) {
+ } catch (JsonException e) {
throw new IllegalArgumentException(e);
}
}
diff --git a/server/src/com/vaadin/ui/JavaScriptFunction.java b/server/src/com/vaadin/ui/JavaScriptFunction.java
index 2c026abd1a..c006a36d58 100644
--- a/server/src/com/vaadin/ui/JavaScriptFunction.java
+++ b/server/src/com/vaadin/ui/JavaScriptFunction.java
@@ -18,14 +18,12 @@ package com.vaadin.ui;
import java.io.Serializable;
-import org.json.JSONArray;
-import org.json.JSONException;
-
import com.vaadin.server.AbstractJavaScriptExtension;
+import elemental.json.JsonArray;
/**
* Defines a method that is called by a client-side JavaScript function. When
- * the corresponding JavaScript function is called, the {@link #call(JSONArray)}
+ * the corresponding JavaScript function is called, the {@link #call(JsonArray)}
* method is invoked.
*
* @see JavaScript#addFunction(String, JavaScriptCallback)
@@ -46,8 +44,6 @@ public interface JavaScriptFunction extends Serializable {
* @param arguments
* an array with JSON representations of the arguments with which
* the JavaScript function was called.
- * @throws JSONException
- * if the arguments can not be interpreted
*/
- public void call(JSONArray arguments) throws JSONException;
+ public void call(JsonArray arguments);
}
diff --git a/server/src/com/vaadin/ui/Slider.java b/server/src/com/vaadin/ui/Slider.java
index ff6c955e47..66ed1a48f4 100644
--- a/server/src/com/vaadin/ui/Slider.java
+++ b/server/src/com/vaadin/ui/Slider.java
@@ -16,8 +16,6 @@
package com.vaadin.ui;
-import org.json.JSONException;
-
import com.vaadin.shared.ui.slider.SliderOrientation;
import com.vaadin.shared.ui.slider.SliderServerRpc;
import com.vaadin.shared.ui.slider.SliderState;
@@ -42,12 +40,8 @@ public class Slider extends AbstractField<Double> {
*
* See #12133.
*/
- try {
- getUI().getConnectorTracker().getDiffState(Slider.this)
- .put("value", value);
- } catch (JSONException e) {
- throw new RuntimeException(e);
- }
+ getUI().getConnectorTracker().getDiffState(Slider.this)
+ .put("value", value);
try {
setValue(value, true);