com.gwtplatform.dispatch.rpc.client.gin.RpcDispatchAsyncModule Maven / Gradle / Ivy
/*
* 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.actionhandler.ClientActionHandlerRegistry;
import com.gwtplatform.dispatch.client.actionhandler.DefaultClientActionHandlerRegistry;
import com.gwtplatform.dispatch.client.gin.AbstractDispatchAsyncModule;
import com.gwtplatform.dispatch.rpc.client.DefaultRpcDispatchCallFactory;
import com.gwtplatform.dispatch.rpc.client.DefaultRpcDispatchHooks;
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).
*
* This gin module provides provides access to the {@link DispatchAsync} singleton, which is used to make calls to the
* server over RPC.
*
* 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 This document.
*/
public class RpcDispatchAsyncModule extends AbstractDispatchAsyncModule {
/**
* A {@link RpcDispatchAsyncModule} builder.
*/
public static class Builder extends AbstractDispatchAsyncModule.Builder {
protected Class extends DispatchAsync> dispatchAsync = RpcDispatchAsync.class;
private Class extends RpcDispatchCallFactory> dispatchCallFactory = DefaultRpcDispatchCallFactory.class;
private Class extends RpcDispatchHooks> dispatchHooks = DefaultRpcDispatchHooks.class;
private Class extends RpcInterceptorRegistry> interceptorRegistry = DefaultRpcInterceptorRegistry.class;
@Deprecated
private Class extends ClientActionHandlerRegistry> clientActionHandlerRegistryType =
DefaultClientActionHandlerRegistry.class;
@Override
public RpcDispatchAsyncModule build() {
return new RpcDispatchAsyncModule(this);
}
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;
}
/**
* 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;
}
/**
* Specify an alternate client action handler registry.
*
* @param clientActionHandlerRegistryType A {@link ClientActionHandlerRegistry} class.
*
* @deprecated use {@link Builder#interceptorRegistry}
*
* @return a {@link Builder} object.
*/
@Deprecated
public Builder clientActionHandlerRegistry(
Class extends ClientActionHandlerRegistry> clientActionHandlerRegistryType) {
this.clientActionHandlerRegistryType = clientActionHandlerRegistryType;
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(ClientActionHandlerRegistry.class).to(builder.clientActionHandlerRegistryType).asEagerSingleton();
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);
}
@Provides
@Singleton
DispatchServiceAsync provideDispatchServiceAsync() {
return GWT.create(DispatchService.class);
}
}