org.jboss.errai.enterprise.client.jaxrs.api.RestClient.java Source code

Java tutorial

Introduction

Here is the source code for org.jboss.errai.enterprise.client.jaxrs.api.RestClient.java

Source

/*
 * Copyright (C) 2011 Red Hat, Inc. and/or its affiliates.
 *
 * 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 org.jboss.errai.enterprise.client.jaxrs.api;

import org.jboss.errai.common.client.api.Assert;
import org.jboss.errai.common.client.api.RemoteCallback;
import org.jboss.errai.common.client.framework.ProxyFactory;
import org.jboss.errai.common.client.framework.RemoteServiceProxyFactory;
import org.jboss.errai.enterprise.client.jaxrs.AbstractJaxrsProxy;

import com.google.common.collect.Lists;
import com.google.gwt.dom.client.AnchorElement;
import com.google.gwt.dom.client.Document;
import com.google.gwt.user.client.Cookies;

/**
 * API for communicating with REST endpoints based on JAX-RS interfaces.
 * 
 * @author Christian Sadilek <csadilek@redhat.com>
 */
public class RestClient {
    private static ProxyFactory proxyProvider = new RemoteServiceProxyFactory();

    /**
     * Creates a client/proxy for the provided JAX-RS resource interface.
     * 
     * @param remoteService
     *          the JAX-RS resource interface. Must not be null.
     * @param callback
     *          the asynchronous callback to use. Must not be null.
     * @param successCodes
     *          optional HTTP status codes used to determine whether the request
     *          was successful. If omitted, all 2xx status codes are interpreted
     *          as success for this request.
     * @return proxy of the specified remote service type
     */
    public static <T, R> T create(final Class<T> remoteService, final RemoteCallback<R> callback,
            Integer... successCodes) {
        return create(remoteService, null, callback, null, successCodes);
    }

    /**
     * Creates a client/proxy for the provided JAX-RS resource interface.
     * 
     * @param remoteService
     *          the JAX-RS resource interface. Must not be null.
     * @param callback
     *          the asynchronous callback to use. Must not be null.
     * @param requestCallback
     *          the request callback that provides access to the
     *          {@link com.google.gwt.http.client.Request}.
     * @param successCodes
     *          optional HTTP status codes used to determine whether the request
     *          was successful. If omitted, all 2xx status codes are interpreted
     *          as success for this request.
     * @return proxy of the specified remote service type
     */
    public static <T, R> T create(final Class<T> remoteService, final RemoteCallback<R> callback,
            final RequestCallback requestCallback, Integer... successCodes) {
        return create(remoteService, null, callback, null, requestCallback, successCodes);
    }

    /**
     * Creates a client/proxy for the provided JAX-RS resource interface.
     * 
     * @param remoteService
     *          the JAX-RS resource interface. Must not be null.
     * @param baseUrl
     *          the base URL overriding the default application root path
     * @param callback
     *          the asynchronous callback to use. Must not be null.
     * @param successCodes
     *          optional HTTP status codes used to determine whether the request
     *          was successful. If omitted, all 2xx status codes are interpreted
     *          as success for this request.
     * @return proxy of the specified remote service type
     */
    public static <T, R> T create(final Class<T> remoteService, String baseUrl, final RemoteCallback<R> callback,
            Integer... successCodes) {
        return create(remoteService, baseUrl, callback, null, successCodes);
    }

    /**
     * Creates a client/proxy for the provided JAX-RS resource interface.
     * 
     * @param remoteService
     *          the JAX-RS resource interface. Must not be null.
     * @param callback
     *          the asynchronous callback to use. Must not be null.
     * @param errorCallback
     *          the error callback to use
     * @param successCodes
     *          optional HTTP status codes used to determine whether the request
     *          was successful. If omitted, all 2xx status codes are interpreted
     *          as success for this request.
     * @return proxy of the specified remote service type
     */
    public static <T, R> T create(final Class<T> remoteService, final RemoteCallback<R> callback,
            final RestErrorCallback errorCallback, Integer... successCodes) {
        return create(remoteService, null, callback, errorCallback, successCodes);
    }

    /**
     * Creates a client/proxy for the provided JAX-RS resource interface.
     * 
     * @param remoteService
     *          the JAX-RS resource interface. Must not be null.
     * @param callback
     *          the asynchronous callback to use. Must not be null.
     * @param errorCallback
     *          the error callback to use
     * @param requestCallback
     *          the request callback that provides access to the
     *          {@link com.google.gwt.http.client.Request}.
     * @param successCodes
     *          optional HTTP status codes used to determine whether the request
     *          was successful. If omitted, all 2xx status codes are interpreted
     *          as success for this request.
     * @return proxy of the specified remote service type
     */
    public static <T, R> T create(final Class<T> remoteService, final RemoteCallback<R> callback,
            final RestErrorCallback errorCallback, final RequestCallback requestCallback, Integer... successCodes) {
        return create(remoteService, null, callback, errorCallback, requestCallback, successCodes);
    }

    /**
     * Creates a client/proxy for the provided JAX-RS resource interface.
     * 
     * @param remoteService
     *          the JAX-RS resource interface. Must not be null.
     * @param baseUrl
     *          the base URL overriding the default application root path
     * @param callback
     *          the asynchronous callback to use. Must not be null.
     * @param errorCallback
     *          the error callback to use
     * @param successCodes
     *          optional HTTP status codes used to determine whether the request
     *          was successful. If omitted, all 2xx status codes are interpreted
     *          as success for this request.
     * @return proxy of the specified remote service type
     */
    public static <T, R> T create(final Class<T> remoteService, String baseUrl, final RemoteCallback<R> callback,
            final RestErrorCallback errorCallback, Integer... successCodes) {
        return create(remoteService, baseUrl, callback, errorCallback, null, successCodes);
    }

    /**
     * Creates a client/proxy for the provided JAX-RS resource interface.
     * 
     * @param remoteService
     *          the JAX-RS resource interface. Must not be null.
     * @param baseUrl
     *          the base URL overriding the default application root path
     * @param callback
     *          the asynchronous callback to use. Must not be null.
     * @param errorCallback
     *          the error callback to use
     * @param requestCallback
     *          the request callback that provides access to the
     *          {@link com.google.gwt.http.client.Request}.
     * @param successCodes
     *          optional HTTP status codes used to determine whether the request
     *          was successful. If omitted, all 2xx status codes are interpreted
     *          as success for this request.
     * @return proxy of the specified remote service type
     */
    public static <T, R> T create(final Class<T> remoteService, String baseUrl, final RemoteCallback<R> callback,
            final RestErrorCallback errorCallback, final RequestCallback requestCallback, Integer... successCodes) {

        Assert.notNull(remoteService);
        Assert.notNull(callback);
        if (baseUrl != null && !baseUrl.endsWith("/"))
            baseUrl += "/";

        T proxy = proxyProvider.getRemoteProxy(remoteService);

        if (successCodes.length > 0) {
            ((AbstractJaxrsProxy) proxy).setSuccessCodes(Lists.newArrayList(successCodes));
        }

        ((AbstractJaxrsProxy) proxy).setRemoteCallback(callback);
        ((AbstractJaxrsProxy) proxy).setErrorCallback(errorCallback);
        ((AbstractJaxrsProxy) proxy).setRequestCallback(requestCallback);
        ((AbstractJaxrsProxy) proxy).setBaseUrl(baseUrl);
        return proxy;
    }

    /**
     * Returns the configured JAX-RS default application root path.
     * 
     * @return path with trailing slash, or empty string if undefined or
     *         explicitly set to empty
     */
    public static native String getApplicationRoot() /*-{
                                                     if ($wnd.erraiJaxRsApplicationRoot === undefined || $wnd.erraiJaxRsApplicationRoot.length === 0) {
                                                     return ""; 
                                                     } 
                                                     else {
                                                     if ($wnd.erraiJaxRsApplicationRoot.substr(-1) !== "/") {
                                                     return $wnd.erraiJaxRsApplicationRoot + "/";
                                                     }
                                                     return $wnd.erraiJaxRsApplicationRoot;
                                                     }
                                                     }-*/;

    /**
     * Configures the JAX-RS default application root path.
     * 
     * @param path
     *          path to use when sending requests to the JAX-RS endpoint
     */
    public static native void setApplicationRoot(String path) /*-{
                                                              if (path == null) {
                                                              $wnd.erraiJaxRsApplicationRoot = undefined;
                                                              }
                                                              else {
                                                              $wnd.erraiJaxRsApplicationRoot = path;
                                                              }
                                                              }-*/;

    /**
     * Checks if a jackson compatible JSON format should be used instead of Errai
     * JSON.
     * 
     * @return true, if jackson marshalling should be used, otherwise false.
     */
    public static native boolean isJacksonMarshallingActive() /*-{
                                                              if ($wnd.erraiJaxRsJacksonMarshallingActive === undefined) {
                                                              return false; 
                                                              } 
                                                              else {
                                                              return $wnd.erraiJaxRsJacksonMarshallingActive;
                                                              }
                                                              }-*/;

    /**
     * Activates/Deactivates jackson conform JSON marshalling.
     * 
     * @param active
     *          true if jackson marshalling should be activated, otherwise false.
     */
    public static native void setJacksonMarshallingActive(boolean active) /*-{
                                                                          $wnd.erraiJaxRsJacksonMarshallingActive = active;
                                                                          }-*/;

    /**
     * Set a cookie for the domain and path returned by
     * {@link #getApplicationRoot()}.
     * 
     * @param cookieName
     *          The name of the cookie to set.
     * @param cookieValue
     *          The value of the cookie to set.
     */
    public static void setCookie(final String cookieName, final String cookieValue) {
        final AnchorElement anchorElement = Document.get().createAnchorElement();
        anchorElement.setHref(RestClient.getApplicationRoot());
        final String path = anchorElement.getPropertyString("pathname");
        final String domain = anchorElement.getPropertyString("domain");

        Cookies.setCookie(cookieName, cookieValue, null, domain, path, false);
    }
}