Allow GWT plugins to invoke the REST API
The package 'com.google.gerrit' in 'gerrit-plugin-gwtui' is renamed to 'com.google.gerrit.plugin' since Eclipse doesn't like to have the RestApi and Natives classes once again in the same package as in 'gerrit-gwtui'. Change-Id: I37e28dfc52bce90204cf067b543ef91abead8e27 Signed-off-by: Edwin Kempin <edwin.kempin@sap.com>
This commit is contained in:
parent
fa3435ba3f
commit
1a31722152
@ -135,6 +135,14 @@ public class ActionContext extends JavaScriptObject {
|
||||
}
|
||||
|
||||
static final void post(RestApi api, JavaScriptObject in, JavaScriptObject cb) {
|
||||
if (NativeString.is(in)) {
|
||||
post(api, ((NativeString) in).asString(), cb);
|
||||
} else {
|
||||
api.post(in, wrap(cb));
|
||||
}
|
||||
}
|
||||
|
||||
static final void post(RestApi api, String in, JavaScriptObject cb) {
|
||||
api.post(in, wrap(cb));
|
||||
}
|
||||
|
||||
@ -143,6 +151,14 @@ public class ActionContext extends JavaScriptObject {
|
||||
}
|
||||
|
||||
static final void put(RestApi api, JavaScriptObject in, JavaScriptObject cb) {
|
||||
if (NativeString.is(in)) {
|
||||
put(api, ((NativeString) in).asString(), cb);
|
||||
} else {
|
||||
api.put(in, wrap(cb));
|
||||
}
|
||||
}
|
||||
|
||||
static final void put(RestApi api, String in, JavaScriptObject cb) {
|
||||
api.put(in, wrap(cb));
|
||||
}
|
||||
|
||||
|
@ -59,16 +59,24 @@ public class ApiGlue {
|
||||
|
||||
_api: function(u) {return @com.google.gerrit.client.rpc.RestApi::new(Ljava/lang/String;)(u)},
|
||||
get: function(u,b){@com.google.gerrit.client.api.ActionContext::get(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),b)},
|
||||
post: function(u,i,b){@com.google.gerrit.client.api.ActionContext::post(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),i,b)},
|
||||
post: function(u,i,b){
|
||||
if (typeof i=='string')
|
||||
@com.google.gerrit.client.api.ActionContext::post(Lcom/google/gerrit/client/rpc/RestApi;Ljava/lang/String;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),i,b);
|
||||
else
|
||||
@com.google.gerrit.client.api.ActionContext::post(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),i,b);
|
||||
},
|
||||
put: function(u,i,b){
|
||||
if(b){
|
||||
@com.google.gerrit.client.api.ActionContext::put(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),i,b)
|
||||
if(typeof i=='string')
|
||||
@com.google.gerrit.client.api.ActionContext::put(Lcom/google/gerrit/client/rpc/RestApi;Ljava/lang/String;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),i,b);
|
||||
else
|
||||
@com.google.gerrit.client.api.ActionContext::put(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),i,b);
|
||||
}else{
|
||||
b=i;
|
||||
@com.google.gerrit.client.api.ActionContext::put(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),b)
|
||||
@com.google.gerrit.client.api.ActionContext::put(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),i)
|
||||
}
|
||||
},
|
||||
'delete': function(u,b){@com.google.gerrit.client.api.ActionContext::delete(Lcom/google/gerrit/client/rpc/RestApi;Lcom/google/gwt/core/client/JavaScriptObject;)(this._api(u),b)},
|
||||
JsonString: @com.google.gerrit.client.rpc.NativeString::TYPE,
|
||||
};
|
||||
|
||||
Plugin.prototype = {
|
||||
|
@ -19,10 +19,15 @@ import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||
|
||||
/** Wraps a String that was returned from a JSON API. */
|
||||
public final class NativeString extends JavaScriptObject {
|
||||
private static final JavaScriptObject TYPE = init();
|
||||
public static final JavaScriptObject TYPE = init();
|
||||
|
||||
private static final native JavaScriptObject init()
|
||||
/*-{ return function(s){this.s=s} }-*/;
|
||||
private static final native JavaScriptObject init() /*-{
|
||||
var T = function(s){this.s=s};
|
||||
T.prototype = {
|
||||
get: function(){return this.s},
|
||||
};
|
||||
return T;
|
||||
}-*/;
|
||||
|
||||
static final NativeString wrap(String s) {
|
||||
return wrap0(TYPE, s);
|
||||
@ -32,7 +37,6 @@ public final class NativeString extends JavaScriptObject {
|
||||
/*-{ return new T(s) }-*/;
|
||||
|
||||
public final native String asString() /*-{ return this.s; }-*/;
|
||||
private final native void set(String v) /*-{ this.s = v; }-*/;
|
||||
|
||||
public static final AsyncCallback<NativeString>
|
||||
unwrap(final AsyncCallback<String> cb) {
|
||||
|
@ -336,6 +336,11 @@ public class RestApi {
|
||||
send(PUT, cb);
|
||||
}
|
||||
|
||||
public <T extends JavaScriptObject> void put(String content,
|
||||
AsyncCallback<T> cb) {
|
||||
sendRaw(PUT, content, cb);
|
||||
}
|
||||
|
||||
public <T extends JavaScriptObject> void put(
|
||||
JavaScriptObject content,
|
||||
AsyncCallback<T> cb) {
|
||||
|
@ -14,10 +14,10 @@
|
||||
limitations under the License.
|
||||
-->
|
||||
<module>
|
||||
<define-linker name="gerrit_plugin" class="com.google.gerrit.linker.GerritPluginLinker"/>
|
||||
<define-linker name="gerrit_plugin" class="com.google.gerrit.plugin.linker.GerritPluginLinker"/>
|
||||
<add-linker name="gerrit_plugin"/>
|
||||
<generate-with class="com.google.gerrit.rebind.PluginGenerator">
|
||||
<when-type-assignable class="com.google.gerrit.client.Plugin"/>
|
||||
<generate-with class="com.google.gerrit.plugin.rebind.PluginGenerator">
|
||||
<when-type-assignable class="com.google.gerrit.plugin.client.Plugin"/>
|
||||
</generate-with>
|
||||
<source path="client"/>
|
||||
<source path="plugin/client"/>
|
||||
</module>
|
||||
|
@ -12,7 +12,7 @@
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package com.google.gerrit.client;
|
||||
package com.google.gerrit.plugin.client;
|
||||
|
||||
import com.google.gwt.core.client.EntryPoint;
|
||||
|
@ -0,0 +1,54 @@
|
||||
// Copyright (C) 2013 The Android Open Source Project
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package com.google.gerrit.plugin.client.rpc;
|
||||
|
||||
import com.google.gwt.core.client.JavaScriptObject;
|
||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||
|
||||
/** Wraps a String that was returned from a JSON API. */
|
||||
public class NativeString extends JavaScriptObject {
|
||||
private static final JavaScriptObject TYPE = init();
|
||||
|
||||
private static final native JavaScriptObject init()
|
||||
/*-{ return $wnd.Gerrit.JsonString } }-*/;
|
||||
|
||||
public final native String asString()
|
||||
/*-{ return this.get(); }-*/;
|
||||
|
||||
public static final
|
||||
AsyncCallback<NativeString> unwrap(final AsyncCallback<String> cb) {
|
||||
return new AsyncCallback<NativeString>() {
|
||||
@Override
|
||||
public void onSuccess(NativeString result) {
|
||||
cb.onSuccess(result != null ? result.asString() : null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onFailure(Throwable caught) {
|
||||
cb.onFailure(caught);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
public static final boolean is(JavaScriptObject o) {
|
||||
return is(TYPE, o);
|
||||
}
|
||||
|
||||
private static final native boolean is(JavaScriptObject T, JavaScriptObject o)
|
||||
/*-{ return o instanceof T }-*/;
|
||||
|
||||
protected NativeString() {
|
||||
}
|
||||
}
|
@ -0,0 +1,71 @@
|
||||
// Copyright (C) 2012 The Android Open Source Project
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package com.google.gerrit.plugin.client.rpc;
|
||||
|
||||
import com.google.gwt.core.client.JavaScriptObject;
|
||||
import com.google.gwt.core.client.JsArray;
|
||||
import com.google.gwt.json.client.JSONObject;
|
||||
|
||||
import java.util.AbstractList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
public class Natives {
|
||||
/**
|
||||
* Get the names of defined properties on the object. The returned set
|
||||
* iterates in the native iteration order, which may match the source order.
|
||||
*/
|
||||
public static Set<String> keys(JavaScriptObject obj) {
|
||||
if (obj != null) {
|
||||
return new JSONObject(obj).keySet();
|
||||
}
|
||||
return Collections.emptySet();
|
||||
}
|
||||
|
||||
public static <T extends JavaScriptObject> List<T> asList(
|
||||
final JsArray<T> arr) {
|
||||
if (arr == null) {
|
||||
return null;
|
||||
}
|
||||
return new AbstractList<T>() {
|
||||
@Override
|
||||
public T set(int index, T element) {
|
||||
T old = arr.get(index);
|
||||
arr.set(index, element);
|
||||
return old;
|
||||
}
|
||||
|
||||
@Override
|
||||
public T get(int index) {
|
||||
return arr.get(index);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int size() {
|
||||
return arr.length();
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
public static <T extends JavaScriptObject> JsArray<T> arrayOf(T element) {
|
||||
JsArray<T> arr = JavaScriptObject.createArray().cast();
|
||||
arr.push(element);
|
||||
return arr;
|
||||
}
|
||||
|
||||
private Natives() {
|
||||
}
|
||||
}
|
@ -0,0 +1,22 @@
|
||||
// Copyright (C) 2013 The Android Open Source Project
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package com.google.gerrit.plugin.client.rpc;
|
||||
|
||||
import com.google.gwt.core.client.JavaScriptObject;
|
||||
|
||||
public class NoContent extends JavaScriptObject {
|
||||
protected NoContent() {
|
||||
}
|
||||
}
|
@ -0,0 +1,171 @@
|
||||
// Copyright (C) 2013 The Android Open Source Project
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package com.google.gerrit.plugin.client.rpc;
|
||||
|
||||
import com.google.gwt.core.client.JavaScriptObject;
|
||||
import com.google.gwt.http.client.URL;
|
||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||
|
||||
public class RestApi {
|
||||
private final StringBuilder path;
|
||||
private boolean hasQueryParams;
|
||||
|
||||
public RestApi(String name) {
|
||||
path = new StringBuilder();
|
||||
path.append(name);
|
||||
}
|
||||
|
||||
public RestApi view(String name) {
|
||||
return idRaw(name);
|
||||
}
|
||||
|
||||
public RestApi view(String pluginName, String name) {
|
||||
return idRaw(pluginName + "~" + name);
|
||||
}
|
||||
|
||||
public RestApi id(String id) {
|
||||
return idRaw(URL.encodeQueryString(id));
|
||||
}
|
||||
|
||||
public RestApi id(int id) {
|
||||
return idRaw(Integer.toString(id));
|
||||
}
|
||||
|
||||
public RestApi idRaw(String name) {
|
||||
if (hasQueryParams) {
|
||||
throw new IllegalStateException();
|
||||
}
|
||||
if (path.charAt(path.length() - 1) != '/') {
|
||||
path.append('/');
|
||||
}
|
||||
path.append(name);
|
||||
return this;
|
||||
}
|
||||
|
||||
public RestApi addParameter(String name, String value) {
|
||||
return addParameterRaw(name, URL.encodeQueryString(value));
|
||||
}
|
||||
|
||||
public RestApi addParameter(String name, String... value) {
|
||||
for (String val : value) {
|
||||
addParameter(name, val);
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
public RestApi addParameterTrue(String name) {
|
||||
return addParameterRaw(name, null);
|
||||
}
|
||||
|
||||
public RestApi addParameter(String name, boolean value) {
|
||||
return addParameterRaw(name, value ? "t" : "f");
|
||||
}
|
||||
|
||||
public RestApi addParameter(String name, int value) {
|
||||
return addParameterRaw(name, String.valueOf(value));
|
||||
}
|
||||
|
||||
public RestApi addParameter(String name, Enum<?> value) {
|
||||
return addParameterRaw(name, value.name());
|
||||
}
|
||||
|
||||
public RestApi addParameterRaw(String name, String value) {
|
||||
if (hasQueryParams) {
|
||||
path.append("&");
|
||||
} else {
|
||||
path.append("?");
|
||||
hasQueryParams = true;
|
||||
}
|
||||
path.append(name);
|
||||
if (value != null) {
|
||||
path.append("=").append(value);
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
public String path() {
|
||||
return path.toString();
|
||||
}
|
||||
|
||||
public <T extends JavaScriptObject>
|
||||
void get(AsyncCallback<T> cb) {
|
||||
get(path(), wrap(cb));
|
||||
}
|
||||
|
||||
public void getString(AsyncCallback<String> cb) {
|
||||
get(NativeString.unwrap(cb));
|
||||
}
|
||||
|
||||
private native static void get(String p, JavaScriptObject r)
|
||||
/*-{ $wnd.Gerrit.get(p, r) }-*/;
|
||||
|
||||
public <T extends JavaScriptObject>
|
||||
void put(AsyncCallback<T> cb) {
|
||||
put(path(), wrap(cb));
|
||||
}
|
||||
|
||||
private native static void put(String p, JavaScriptObject r)
|
||||
/*-{ $wnd.Gerrit.put(p, r) }-*/;
|
||||
|
||||
public <T extends JavaScriptObject>
|
||||
void put(String content, AsyncCallback<T> cb) {
|
||||
put(path(), content, wrap(cb));
|
||||
}
|
||||
|
||||
private native static
|
||||
void put(String p, String c, JavaScriptObject r)
|
||||
/*-{ $wnd.Gerrit.put(p, c, r) }-*/;
|
||||
|
||||
public <T extends JavaScriptObject>
|
||||
void put(JavaScriptObject content, AsyncCallback<T> cb) {
|
||||
put(path(), content, wrap(cb));
|
||||
}
|
||||
|
||||
private native static
|
||||
void put(String p, JavaScriptObject c, JavaScriptObject r)
|
||||
/*-{ $wnd.Gerrit.put(p, c, r) }-*/;
|
||||
|
||||
public <T extends JavaScriptObject>
|
||||
void post(String content, AsyncCallback<T> cb) {
|
||||
post(path(), content, wrap(cb));
|
||||
}
|
||||
|
||||
private native static
|
||||
void post(String p, String c, JavaScriptObject r)
|
||||
/*-{ $wnd.Gerrit.post(p, c, r) }-*/;
|
||||
|
||||
public <T extends JavaScriptObject>
|
||||
void post(JavaScriptObject content, AsyncCallback<T> cb) {
|
||||
post(path(), content, wrap(cb));
|
||||
}
|
||||
|
||||
private native static
|
||||
void post(String p, JavaScriptObject c, JavaScriptObject r)
|
||||
/*-{ $wnd.Gerrit.post(p, c, r) }-*/;
|
||||
|
||||
public void delete(AsyncCallback<NoContent> cb) {
|
||||
delete(path(), wrap(cb));
|
||||
}
|
||||
|
||||
private native static void delete(String p, JavaScriptObject r)
|
||||
/*-{ '$wnd.Gerrit.delete'(p, r) }-*/;
|
||||
|
||||
private native static <T extends JavaScriptObject>
|
||||
JavaScriptObject wrap(AsyncCallback<T> b) /*-{
|
||||
return function(r) {
|
||||
b.@com.google.gwt.user.client.rpc.AsyncCallback::onSuccess(Ljava/lang/Object;)(r)
|
||||
}
|
||||
}-*/;
|
||||
}
|
@ -12,7 +12,7 @@
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package com.google.gerrit.linker;
|
||||
package com.google.gerrit.plugin.linker;
|
||||
|
||||
import com.google.gwt.core.ext.LinkerContext;
|
||||
import com.google.gwt.core.linker.CrossSiteIframeLinker;
|
@ -13,7 +13,7 @@
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package com.google.gerrit.rebind;
|
||||
package com.google.gerrit.plugin.rebind;
|
||||
|
||||
import java.io.PrintWriter;
|
||||
|
Loading…
x
Reference in New Issue
Block a user