Android Open Source - android-http Web Request Builder






From Project

Back to project page android-http.

License

The source code is released under:

Apache License

If you think the Android project android-http listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/*
 * Copyright (C) 2012, 2013 the diamond:dogs|group
 *// w w  w  . j av a 2s .c o  m
 * 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 at.diamonddogs.builder;

import java.net.URI;
import java.net.URL;

import android.net.Uri;
import at.diamonddogs.data.dataobjects.WebRequest;
import at.diamonddogs.data.dataobjects.WebRequest.Type;
import at.diamonddogs.service.processor.ServiceProcessor;

/**
 * This builder enables programmers to create uniform {@link WebRequest}s based
 * on the provided configuration. The builder's purpose is not to micro-manage
 * {@link WebRequest} creation but to provide a configured {@link WebRequest}
 * template.
 */
public class WebRequestBuilder {

  /**
   * The configuration used for {@link WebRequest} construction
   */
  private WebRequestBuilderConfiguration configuration;

  /**
   * The {@link WebRequest} that is currently build
   */
  private WebRequest webRequest;

  /**
   * This enum is an abstraction for read timeout durations. The exact
   * duration is controlled by the provided
   * {@link WebRequestBuilderConfiguration}
   */
  // @formatter:off
  @SuppressWarnings("javadoc")
  public enum ReadTimeout {
    SHORT, 
    MEDIUM, 
    LONG, 
    VERYLONG
  }
  // @formatter:on

  /**
   * This enum is an abstraction for connection timeout durations. The exact
   * duration is controlled by the provided
   * {@link WebRequestBuilderConfiguration}
   */
  // @formatter:off
  @SuppressWarnings("javadoc")
  public enum ConnectionTimeout {
    SHORT, 
    MEDIUM, 
    LONG, 
    VERYLONG
  }
  // @formatter:on

  /**
   * Constructor with configuration option
   * 
   * @param configuration
   *            the {@link WebRequestBuilderConfiguration} to use when
   *            building {@link WebRequest}s
   */
  public WebRequestBuilder(WebRequestBuilderConfiguration configuration) {
    this.configuration = configuration;
  }

  /**
   * This constructor utilzes {@link WebRequestBuilderDefaultConfig} to
   * configure {@link WebRequest}s
   */
  public WebRequestBuilder() {
    this.configuration = new WebRequestBuilderDefaultConfig();
  }

  /**
   * Creates a new {@link WebRequest}, must be called before attempting to do
   * anything else. Resets any existing {@link WebRequest} instances.
   * 
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder newWebRequest() {
    webRequest = new WebRequest();
    webRequest.setFollowRedirects(configuration.isFollowRedirectEnabled());
    webRequest.setUseOfflineCache(configuration.isOfflineCachingEnabled());
    webRequest.setCheckConnectivity(configuration.isConnectivityCheckEnabled());
    webRequest.setCheckConnectivityPing(configuration.isConnectivityPingEnabled());
    webRequest.setRetryInterval(configuration.getRetryInterval());
    webRequest.setNumberOfRetries(configuration.getRetryCount());
    webRequest.setCacheTime(configuration.getDefaultCacheTime());
    return this;
  }

  /**
   * Sets the target url of the {@link WebRequest}
   * 
   * @param url
   *            the url
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setUrl(String url) {
    throwOnError();
    webRequest.setUrl(url);
    return this;
  }

  /**
   * Sets the target url of the {@link WebRequest}
   * 
   * @param url
   *            the url
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setUrl(URL url) {
    throwOnError();
    webRequest.setUrl(url);
    return this;
  }

  /**
   * Sets the target url of the {@link WebRequest}
   * 
   * @param url
   *            the url
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setUrl(URI url) {
    throwOnError();
    webRequest.setUrl(url);
    return this;
  }

  /**
   * Sets the target url of the {@link WebRequest}
   * 
   * @param url
   *            the url
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setUrl(Uri url) {
    throwOnError();
    webRequest.setUrl(url);
    return this;
  }

  /**
   * Set the type of {@link WebRequest}
   * 
   * @param type
   *            the type
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setType(Type type) {
    throwOnError();
    webRequest.setRequestType(type);
    return this;
  }

  /**
   * Sets the abstracted read timeout
   * 
   * @param timeout
   *            the read timeout to be used in this {@link WebRequest}
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setReadTimeout(ReadTimeout timeout) {
    throwOnError();
    webRequest.setReadTimeout(getReadTimeout(timeout));
    return this;
  }

  private int getReadTimeout(ReadTimeout timeout) {
    switch (timeout) {
    case SHORT:
      return configuration.getReadTimeoutShort();
    case MEDIUM:
      return configuration.getReadTimeoutMedium();
    case LONG:
      return configuration.getReadTimeoutLong();
    case VERYLONG:
      return configuration.getReadTimeoutVeryLong();
    default:
      return 1000;
    }
  }

  /**
   * Sets the abstracted connection timeout
   * 
   * @param timeout
   *            the connection timeout to be used in this {@link WebRequest}
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setConnectionTimeout(ConnectionTimeout timeout) {
    throwOnError();
    webRequest.setConnectionTimeout(getConnectionTimeout(timeout));
    return this;
  }

  private int getConnectionTimeout(ConnectionTimeout timeout) {
    switch (timeout) {
    case SHORT:
      return configuration.getConnectionTimeoutShort();
    case MEDIUM:
      return configuration.getConnectionTimeoutMedium();
    case LONG:
      return configuration.getConnectionTimeoutLong();
    case VERYLONG:
      return configuration.getConnectionTimeoutVeryLong();
    default:
      return 1000;
    }
  }

  /**
   * Sets the ID of the {@link ServiceProcessor} that should handle the
   * {@link WebRequest}
   * 
   * @param processorid
   *            the processor's id
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder withProcessorId(int processorid) {
    throwOnError();
    webRequest.setProcessorId(processorid);
    return this;
  }

  /**
   * Sets a custom cache time. This method allows overriding the default cache
   * time which is provided by the {@link WebRequestBuilderConfiguration} used
   * by this {@link WebRequestBuilder}
   * 
   * @param time
   *            the cachetime
   * @return the {@link WebRequestBuilder} instance (allows chaining)
   */
  public WebRequestBuilder setCacheTime(long time) {
    throwOnError();
    webRequest.setCacheTime(time);
    return this;
  }

  /**
   * Returns the {@link WebRequest} that has been constructed so far
   * 
   * @return a {@link WebRequest}
   */
  public WebRequest getWebRequest() {
    throwOnError();
    return webRequest;
  }

  private void throwOnError() {
    if (configuration == null) {
      throw new IllegalStateException("configuration is null");
    }
    if (webRequest == null) {
      throw new IllegalStateException("request is null");
    }
  }
}




Java Source Code List

at.diamonddogs.android.support.v4.util.LruCache.java
at.diamonddogs.builder.WebRequestBuilderConfiguration.java
at.diamonddogs.builder.WebRequestBuilderDefaultConfig.java
at.diamonddogs.builder.WebRequestBuilder.java
at.diamonddogs.contentprovider.AbstractDefaultContentProvider.java
at.diamonddogs.contentprovider.CacheContentProvider.java
at.diamonddogs.data.adapter.ReplyAdapter.java
at.diamonddogs.data.adapter.database.DataBaseAdapterCacheInformation.java
at.diamonddogs.data.adapter.database.DatabaseAdapter.java
at.diamonddogs.data.adapter.database.Query.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapterTempFile.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapterWebReply.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapterWebRequest.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapter.java
at.diamonddogs.data.adapter.soap.SoapByteArrayAdapter.java
at.diamonddogs.data.adapter.soap.SoapReplyAdapter.java
at.diamonddogs.data.adapter.soap.SoapRequestAdapter.java
at.diamonddogs.data.dataobjects.CacheInformation.java
at.diamonddogs.data.dataobjects.NonTimeCriticalTaskQueueDefaultConfiguration.java
at.diamonddogs.data.dataobjects.NonTimeCriticalTask.java
at.diamonddogs.data.dataobjects.NonTimeCriticalWebRequest.java
at.diamonddogs.data.dataobjects.Reply.java
at.diamonddogs.data.dataobjects.Request.java
at.diamonddogs.data.dataobjects.SoapReply.java
at.diamonddogs.data.dataobjects.SoapRequest.java
at.diamonddogs.data.dataobjects.TempFile.java
at.diamonddogs.data.dataobjects.WebReply.java
at.diamonddogs.data.dataobjects.WebRequest.java
at.diamonddogs.data.parser.JSONArrayProxy.java
at.diamonddogs.data.parser.JSONObjectProxy.java
at.diamonddogs.data.parser.ParserProxy.java
at.diamonddogs.example.http.activity.CachingExampleActivity.java
at.diamonddogs.example.http.activity.HttpExampleActivity.java
at.diamonddogs.example.http.activity.HttpOrderedAsyncAssisiterExampleActivity.java
at.diamonddogs.example.http.activity.HttpServiceAssisterExampleActivity.java
at.diamonddogs.example.http.activity.ImageLoadingExampleListActivity.java
at.diamonddogs.example.http.activity.NonTimeCriticalExampleActivity.java
at.diamonddogs.example.http.activity.StartActivity.java
at.diamonddogs.example.http.dataobject.Example.java
at.diamonddogs.example.http.dataobject.NonTimeCriticalExampleConfiguration.java
at.diamonddogs.example.http.dataobject.Tripple.java
at.diamonddogs.example.http.dataobject.Weather.java
at.diamonddogs.example.http.dataobject.WebComic.java
at.diamonddogs.example.http.factory.NonTimeCriticalExampleConfigFactory.java
at.diamonddogs.example.http.processor.RssProcessor.java
at.diamonddogs.example.http.processor.WeatherProcessor.java
at.diamonddogs.example.http.processor.WebComicProcessor.java
at.diamonddogs.example.http.view.adapter.ImageLoadingExampleAdapter.java
at.diamonddogs.exception.CacheManagerException.java
at.diamonddogs.exception.DatabaseAdapterException.java
at.diamonddogs.exception.ProcessorExeception.java
at.diamonddogs.exception.ServiceException.java
at.diamonddogs.exception.WebClientException.java
at.diamonddogs.net.WebClientDefaultHttpClient.java
at.diamonddogs.net.WebClientFactory.java
at.diamonddogs.net.WebClientHttpURLConnection.java
at.diamonddogs.net.WebClient.java
at.diamonddogs.net.ssl.CustomSSLSocketFactory.java
at.diamonddogs.net.ssl.CustomX509TrustManager.java
at.diamonddogs.net.ssl.SSLHelper.java
at.diamonddogs.nontimecritical.NonTimeCriticalTaskManager.java
at.diamonddogs.nontimecritical.NonTimeCriticalTaskQueueConfigurationDefaultFactory.java
at.diamonddogs.nontimecritical.NonTimeCriticalTaskQueue.java
at.diamonddogs.service.CacheService.java
at.diamonddogs.service.importservice.GenericImportService.java
at.diamonddogs.service.importservice.ImportServiceContract.java
at.diamonddogs.service.importservice.ImportService.java
at.diamonddogs.service.importservice.OrderedImportServiceContract.java
at.diamonddogs.service.importservice.OrderedImportService.java
at.diamonddogs.service.net.HttpOrderedAsyncAssister.java
at.diamonddogs.service.net.HttpServiceAssister.java
at.diamonddogs.service.net.HttpService.java
at.diamonddogs.service.net.ServiceProcessorIdGenerator.java
at.diamonddogs.service.processor.AdjustableImageProcessor.java
at.diamonddogs.service.processor.DataProcessor.java
at.diamonddogs.service.processor.DummyProcessor.java
at.diamonddogs.service.processor.HeadRequestProcessor.java
at.diamonddogs.service.processor.ImageProcessor.java
at.diamonddogs.service.processor.JSONArrayProcessor.java
at.diamonddogs.service.processor.JSONProcessor.java
at.diamonddogs.service.processor.RawDataProcessor.java
at.diamonddogs.service.processor.ServiceProcessorMessageUtil.java
at.diamonddogs.service.processor.ServiceProcessor.java
at.diamonddogs.service.processor.SoapProcessor.java
at.diamonddogs.service.processor.StreamProcessor.java
at.diamonddogs.service.processor.SynchronousProcessor.java
at.diamonddogs.service.processor.SynchronousXmlProcessorNoDom.java
at.diamonddogs.service.processor.XMLProcessorNoDom.java
at.diamonddogs.service.processor.XMLProcessor.java
at.diamonddogs.service.processor.XMLXPathProcessor.java
at.diamonddogs.util.AndroidUtils.java
at.diamonddogs.util.CacheManager.java
at.diamonddogs.util.ConnectivityHelper.java
at.diamonddogs.util.SoapUtil.java
at.diamonddogs.util.Utils.java
at.diamonddogs.util.WorkerQueue.java
org.apache.commons.codec.CharEncoding.java
org.apache.commons.codec.binary.Hex.java
org.apache.commons.codec.binary.StringUtils.java