aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-gwt-api/src/main/java/org/sonar/gwt/JsonUtils.java137
-rw-r--r--sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/AbstractSimpleCallback.java65
-rw-r--r--sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/SimpleCallback.java28
-rw-r--r--sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/Sonar.java36
4 files changed, 53 insertions, 213 deletions
diff --git a/sonar-gwt-api/src/main/java/org/sonar/gwt/JsonUtils.java b/sonar-gwt-api/src/main/java/org/sonar/gwt/JsonUtils.java
index 020209e3eaa..ca64c74ca81 100644
--- a/sonar-gwt-api/src/main/java/org/sonar/gwt/JsonUtils.java
+++ b/sonar-gwt-api/src/main/java/org/sonar/gwt/JsonUtils.java
@@ -17,15 +17,13 @@
* License along with Sonar; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
*/
-
package org.sonar.gwt;
import com.google.gwt.core.client.JavaScriptException;
import com.google.gwt.core.client.JavaScriptObject;
-import com.google.gwt.http.client.*;
+import com.google.gwt.http.client.URL;
import com.google.gwt.i18n.client.DateTimeFormat;
import com.google.gwt.json.client.*;
-import org.sonar.wsclient.services.WSUtils;
import java.util.Date;
@@ -36,107 +34,70 @@ public final class JsonUtils {
// only static methods
}
- public interface SimpleHandler extends Handler {
- void onSuccess();
- }
-
- public interface JSONHandler extends Handler {
- void onResponse(JavaScriptObject json);
- }
+ public interface JSONHandler {
+ void onResponse(JavaScriptObject obj);
- public interface Handler {
void onTimeout();
void onError(int errorCode, String errorMessage);
}
- public static void request(String url, final SimpleHandler handler, RequestBuilder.Method method, String body) {
- RequestBuilder requestBuilder = new RequestBuilder(method, URL.encode(formatURL(url)));
- requestBuilder.setRequestData(body);
- requestBuilder.setTimeoutMillis(120000);
- requestBuilder.setCallback(new RequestCallback() {
- public void onResponseReceived(Request request, Response response) {
- if (!errorsHandled(response.getText(), handler)) {
- handler.onSuccess();
- }
- }
-
- public void onError(Request request, Throwable throwable) {
- handler.onError(-1, throwable.getMessage());
- }
- });
- try {
- requestBuilder.send();
- } catch (RequestException e) {
- handler.onError(-1, e.getMessage());
- }
- }
-
- public static void requestJson(String url, final JSONHandler handler, RequestBuilder.Method method, String body) {
- RequestBuilder requestBuilder = new RequestBuilder(method, URL.encode(formatURL(url)));
- requestBuilder.setRequestData(body);
- requestBuilder.setCallback(new RequestCallback() {
- public void onResponseReceived(Request request, Response response) {
- if (!errorsHandled(response.getText(), handler)) {
- dispatchJSON(response.getText(), handler);
- }
- }
-
- public void onError(Request request, Throwable throwable) {
- handler.onError(-1, throwable.getMessage());
- }
- });
- requestBuilder.setTimeoutMillis(120000);
- try {
- requestBuilder.send();
- } catch (RequestException e) {
- handler.onError(-1, e.getMessage());
- }
- }
-
- public static void requestJson(String url, final JSONHandler handler) {
- requestJson(url, handler, RequestBuilder.GET, null);
- }
-
- private static JavaScriptObject parseJSON(String json) {
- JSONValue value = JSONParser.parse(json);
- if (value.isObject() != null) {
- return value.isObject().getJavaScriptObject();
- }
- return value.isArray().getJavaScriptObject();
- }
-
- private static String formatURL(String url) {
+ public static void requestJson(String url, JSONHandler handler) {
if (!url.endsWith("&") && !url.endsWith("?")) {
url += "&";
}
if (!url.contains("format=json")) {
url += "format=json&";
}
- return url;
+ if (!url.contains("callback=")) {
+ // IMPORTANT : the url should ended with ?callback= or &callback= for JSONP calls
+ url += "callback=";
+ }
+ makeJSONRequest(requestId++, URL.encode(url), handler);
}
- public static native void log(String str)
- /*-{
- console.log(str);
- }-*/;
-
- private static boolean errorsHandled(String text, Handler handler) {
- if (text != null && !text.matches("^.*$")) {
- JSONObject obj = new JSONObject(parseJSON(text));
- if (obj.isObject() != null) {
- if (obj.containsKey("err_code")) {
- handler.onError(new Double(obj.get("err_code").isNumber().doubleValue()).intValue(),
- obj.get("err_msg").isString().stringValue());
- return true;
- }
- }
+ public static native void makeJSONRequest(int requestId, String url, JSONHandler handler)
+ /*-{
+ var callback = "callback" + requestId;
+
+ // create SCRIPT tag, and set SRC attribute equal to JSON feed URL + callback function name
+ var script = document.createElement("script");
+ script.setAttribute("src", url + callback);
+ script.setAttribute("type", "text/javascript");
+
+ window[callback] = function(jsonObj) {
+ @org.sonar.gwt.JsonUtils::dispatchJSON(Lcom/google/gwt/core/client/JavaScriptObject;Lorg/sonar/gwt/JsonUtils$JSONHandler;)(jsonObj, handler);
+ window[callback + "done"] = true;
}
- return false;
- }
- public static void dispatchJSON(String text, JSONHandler handler) {
- handler.onResponse(parseJSON(text));
+ setTimeout(function() {
+ if (!window[callback + "done"]) {
+ handler.@org.sonar.gwt.JsonUtils.JSONHandler::onTimeout();
+ }
+
+ // cleanup
+ document.body.removeChild(script);
+ if (window[callback]) {
+ delete window[callback];
+ }
+ if (window[callback + "done"]) {
+ delete window[callback + "done"];
+ }
+ }, 120000);
+
+ document.body.appendChild(script);
+ }-*/;
+
+ public static void dispatchJSON(JavaScriptObject jsonObj, JSONHandler handler) {
+ JSONObject obj = new JSONObject(jsonObj);
+ if (obj.isObject() != null) {
+ if (obj.containsKey("err_code")) {
+ handler.onError(new Double(obj.get("err_code").isNumber().doubleValue()).intValue(),
+ obj.get("err_msg").isString().stringValue());
+ return;
+ }
+ }
+ handler.onResponse(jsonObj);
}
public static String getString(JSONObject json, String field) {
diff --git a/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/AbstractSimpleCallback.java b/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/AbstractSimpleCallback.java
deleted file mode 100644
index 74bbd798cd7..00000000000
--- a/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/AbstractSimpleCallback.java
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2012 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-package org.sonar.wsclient.gwt;
-
-import com.google.gwt.user.client.ui.Widget;
-
-public abstract class AbstractSimpleCallback implements SimpleCallback {
-
- private Widget loadingWidget = null;
-
- protected AbstractSimpleCallback(Widget loadingWidget) {
- this.loadingWidget = loadingWidget;
- }
-
- protected AbstractSimpleCallback() {
- }
-
- public void onSuccess() {
- hideLoadingWidget();
- doOnSuccess();
- }
-
- protected abstract void doOnSuccess();
-
- public final void onTimeout() {
- doOnTimeout();
- hideLoadingWidget();
- }
-
- public final void onError(int errorCode, String errorMessage) {
- doOnError(errorCode, errorMessage);
- hideLoadingWidget();
- }
-
- protected void doOnError(int errorCode, String errorMessage) {
-
- }
-
- protected void doOnTimeout() {
-
- }
-
- private void hideLoadingWidget() {
- if (loadingWidget != null) {
- loadingWidget.removeFromParent();
- }
- }
-}
diff --git a/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/SimpleCallback.java b/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/SimpleCallback.java
deleted file mode 100644
index abb6e88fc23..00000000000
--- a/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/SimpleCallback.java
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2012 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-package org.sonar.wsclient.gwt;
-
-public interface SimpleCallback {
- void onSuccess();
-
- void onTimeout();
-
- void onError(int errorCode, String errorMessage);
-}
diff --git a/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/Sonar.java b/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/Sonar.java
index 046a4a6b91e..ee439203d2d 100644
--- a/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/Sonar.java
+++ b/sonar-gwt-api/src/main/java/org/sonar/wsclient/gwt/Sonar.java
@@ -17,15 +17,15 @@
* License along with Sonar; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
*/
-
package org.sonar.wsclient.gwt;
import com.google.gwt.core.client.JavaScriptObject;
-import com.google.gwt.http.client.RequestBuilder;
import com.google.gwt.i18n.client.Dictionary;
import com.google.gwt.json.client.JSONObject;
import org.sonar.gwt.JsonUtils;
-import org.sonar.wsclient.services.*;
+import org.sonar.wsclient.services.Model;
+import org.sonar.wsclient.services.Query;
+import org.sonar.wsclient.services.WSUtils;
import org.sonar.wsclient.unmarshallers.Unmarshaller;
import org.sonar.wsclient.unmarshallers.Unmarshallers;
@@ -89,35 +89,7 @@ public class Sonar {
});
}
- public void delete(final DeleteQuery query, final SimpleCallback callback) {
- createUpdate(query, callback, RequestBuilder.DELETE);
- }
-
- public <MODEL extends Model> void create(final CreateQuery<MODEL> query, final SimpleCallback callback) {
- createUpdate(query, callback, RequestBuilder.POST);
- }
-
- public <MODEL extends Model> void update(final UpdateQuery<MODEL> query, final SimpleCallback callback) {
- createUpdate(query, callback, RequestBuilder.PUT);
- }
-
- private void createUpdate(final AbstractQuery query, final SimpleCallback callback, RequestBuilder.Method method) {
- JsonUtils.request(getUrl(query), new JsonUtils.SimpleHandler() {
- public void onSuccess() {
- callback.onSuccess();
- }
-
- public void onTimeout() {
- callback.onTimeout();
- }
-
- public void onError(int errorCode, String errorMessage) {
- callback.onError(errorCode, errorMessage);
- }
- }, method, query.getBody());
- }
-
- private String getUrl(AbstractQuery query) {
+ private String getUrl(Query query) {
return host + query.getUrl();
}
}