/* * Copyright 2011 ArcBees Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */ package com.gwtplatform.dispatch.rpc.client.gin; import javax.inject.Singleton; import com.google.gwt.core.client.GWT; import com.google.inject.Provides; import com.gwtplatform.dispatch.client.DefaultSecurityCookieAccessor; import com.gwtplatform.dispatch.client.gin.AbstractDispatchAsyncModule; import com.gwtplatform.dispatch.rpc.client.DefaultExceptionHandler; import com.gwtplatform.dispatch.rpc.client.DefaultRpcDispatchCallFactory; import com.gwtplatform.dispatch.rpc.client.DefaultRpcDispatchHooks; import com.gwtplatform.dispatch.rpc.client.ExceptionHandler; import com.gwtplatform.dispatch.rpc.client.RpcBinding; import com.gwtplatform.dispatch.rpc.client.RpcDispatchAsync; import com.gwtplatform.dispatch.rpc.client.RpcDispatchCallFactory; import com.gwtplatform.dispatch.rpc.client.RpcDispatchHooks; import com.gwtplatform.dispatch.rpc.client.interceptor.DefaultRpcInterceptorRegistry; import com.gwtplatform.dispatch.rpc.client.interceptor.RpcInterceptorRegistry; import com.gwtplatform.dispatch.rpc.shared.DispatchAsync; import com.gwtplatform.dispatch.rpc.shared.DispatchService; import com.gwtplatform.dispatch.rpc.shared.DispatchServiceAsync; /** * An implementation of {@link AbstractDispatchAsyncModule} that uses Remote Procedure Calls (RPC). * <p/> * This gin module provides provides access to the {@link DispatchAsync} singleton, which is used to make calls to the * server over RPC. * <p/> * If you want to prevent XSRF attack (you use secured {@link com.gwtplatform.dispatch.rpc.shared.Action}s) the empty * {@link DefaultSecurityCookieAccessor} could leave your application vulnerable to XSRF attacks. * * @see <a href="http://www.gwtproject.org/articles/security_for_gwt_applications.html#xsrf">This document</a>. */ public class RpcDispatchAsyncModule extends AbstractDispatchAsyncModule { /** * A {@link RpcDispatchAsyncModule} builder. */ public static class Builder extends AbstractDispatchAsyncModule.Builder<Builder> { protected Class<? extends DispatchAsync> dispatchAsync = RpcDispatchAsync.class; private Class<? extends ExceptionHandler> exceptionHandler = DefaultExceptionHandler.class; private Class<? extends RpcDispatchCallFactory> dispatchCallFactory = DefaultRpcDispatchCallFactory.class; private Class<? extends RpcDispatchHooks> dispatchHooks = DefaultRpcDispatchHooks.class; private Class<? extends RpcInterceptorRegistry> interceptorRegistry = DefaultRpcInterceptorRegistry.class; @Override public RpcDispatchAsyncModule build() { return new RpcDispatchAsyncModule(this); } public Class<? extends ExceptionHandler> getExceptionHandler() { return exceptionHandler; } public Class<? extends RpcDispatchHooks> getDispatchHooks() { return dispatchHooks; } public Class<? extends RpcInterceptorRegistry> getInterceptorRegistry() { return interceptorRegistry; } public Class<? extends DispatchAsync> getDispatchAsync() { return dispatchAsync; } public Class<? extends RpcDispatchCallFactory> getDispatchCallFactory() { return dispatchCallFactory; } /** * Specify an alternative exception handler. * * @param exceptionHandler The {@link ExceptionHandler} class. * * @return a {@link Builder} object. */ public Builder exceptionHandler(Class<? extends ExceptionHandler> exceptionHandler) { this.exceptionHandler = exceptionHandler; return this; } /** * Supply your own implementation of {@link com.gwtplatform.dispatch.rpc.client.RpcDispatchHooks}. * Default is {@link com.gwtplatform.dispatch.rpc.client.DefaultRpcDispatchHooks} * * @param dispatchHooks The {@link com.gwtplatform.dispatch.rpc.client.RpcDispatchHooks} implementation. * @return this {@link RpcDispatchAsyncModule.Builder} object. */ public Builder dispatchHooks(Class<? extends RpcDispatchHooks> dispatchHooks) { this.dispatchHooks = dispatchHooks; return this; } /** * Supply your own implementation of {@link com.gwtplatform.dispatch.rpc.shared.DispatchAsync}. * Default is {@link com.gwtplatform.dispatch.rpc.client.RpcDispatchAsync} * * @param dispatchAsync The {@link com.gwtplatform.dispatch.rpc.shared.DispatchAsync} implementation. * @return this {@link RpcDispatchAsyncModule.Builder} object. */ public Builder dispatchAsync(Class<? extends DispatchAsync> dispatchAsync) { this.dispatchAsync = dispatchAsync; return this; } /** * Supply your own implementation of {@link com.gwtplatform.dispatch.rpc.client.RpcDispatchCallFactory}. * Default is {@link com.gwtplatform.dispatch.rpc.client.DefaultRpcDispatchCallFactory} * * @param dispatchCallFactory The {@link com.gwtplatform.dispatch.rpc.client.RpcDispatchCallFactory} * implementation. * @return this {@link RpcDispatchAsyncModule.Builder} object. */ public Builder dispatchCallFactory(Class<? extends RpcDispatchCallFactory> dispatchCallFactory) { this.dispatchCallFactory = dispatchCallFactory; return this; } /** * Specify an alternate RPC interceptor registry. * * @param interceptorRegistry A {@link RpcInterceptorRegistry} class. * * @return this {@link RpcDispatchAsyncModule.Builder builder} object. */ public Builder interceptorRegistry(Class<? extends RpcInterceptorRegistry> interceptorRegistry) { this.interceptorRegistry = interceptorRegistry; return this; } @Override protected Builder self() { return this; } } private final Builder builder; public RpcDispatchAsyncModule() { this(new Builder()); } protected RpcDispatchAsyncModule(Builder builder) { super(builder, RpcBinding.class); this.builder = builder; } @Override protected void configureDispatch() { bind(RpcDispatchCallFactory.class).to(builder.getDispatchCallFactory()).in(Singleton.class); bind(DispatchAsync.class).to(builder.getDispatchAsync()).in(Singleton.class); bind(RpcInterceptorRegistry.class).to(builder.getInterceptorRegistry()).in(Singleton.class); bind(RpcDispatchHooks.class).to(builder.getDispatchHooks()).in(Singleton.class); bindAnnotated(ExceptionHandler.class).to(builder.getExceptionHandler()); } @Provides @Singleton DispatchServiceAsync provideDispatchServiceAsync() { return GWT.create(DispatchService.class); } }