Android Open Source - lightbox-android-webservices Operation






From Project

Back to project page lightbox-android-webservices.

License

The source code is released under:

Apache License

If you think the Android project lightbox-android-webservices 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 Lightbox/*from ww  w  .ja  v a 2  s . co 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 com.lightbox.android.operations;

import java.util.List;

import com.lightbox.android.webservices.requests.ApiRequest;


/** 
 * This is the high level interface representing an Operation. An Operation is a generic asynchronous action.
 * The abstract implementation {@link AbstractOperation}n-, and the subclasses like {@link RetrieveOperation}
 * will helps transparently performing action that requires both API calls and local data modification. Theses
 * implementation will gracefully fall-back to "marking" data as deleted/updated, or retrieving data locally 
 * if the network is not available. 
 * @author Fabien Devos
 * @param <T> the type of data to operate on
 */
public interface Operation<T> {

  /********************************
   * Universal representation of the order, useful in both SQL queries and API requests.
   */
  public enum Order {
    ASC(true, "asc"),
    DESC(false, "desc");
    
    private boolean mBoolValue;
    private String mStrValue;
    Order(boolean boolValue, String strValue) {
      mBoolValue = boolValue;
      mStrValue = strValue;
    }
    public boolean asBool() {
      return mBoolValue;
    }
    @Override
    public String toString() {
      return mStrValue;
    }
  }
  
  //----------------------------------------------
  // Operation interface
  
  public abstract boolean isRunning();
  
  public abstract void cancel();
  
  public abstract String getId();

  public abstract ApiRequest getApiRequest();
  
  public abstract Object getContext();

  /** Must be called from main thread.
   *  Most of the time, you won't need this method. It is provided as a convenient way to check if an operation is
   *  already running and re-attach to it if so, with a single line of code.
   *  <strong>Please note that the re-attachment is done automatically anyway if you simply call
   *  {@link #executeAsync(OperationListener)} as usual.</strong>
   *  Thus, this method is equivalent to call {@link #executeAsync(OperationListener)}
   *  only if {@link #isRunning()} is true.
   *  @return true if the Operation was already running and as been re-attached to the listener, false otherwise. */
  public abstract boolean reattachIfRunning(OperationListener<T> listener);

  /** <strong>Must be called from main thread.</strong> Start the asynchronous execution of this {@link Operation} 
   * @param listener the listener to call back when finished (usually an Activity). <strong>Note that the reference
   * to this listener will be kept weakly! It means that if you, or the system, do not hold a reference to this
   * listener, you won't be called back.</strong>*/
  public abstract void executeAsync(OperationListener<T> listener);
  
  /**
   * Execute this operation synchronously. Note that this will be called automatically by the
   * {@link #executeAsync(OperationListener)} method in a <strong>background thread</strong>.
   */
  public abstract List<T> executeSync() throws Exception;

  /**
   * Execute only the local operation (on database or file).
   */
  public abstract List<T> executeLocalOperationSync() throws Exception;

  /**
   * Execute only the server operation.
   */
  public abstract List<T> executeServerOperationSync() throws Exception;
  
}




Java Source Code List

com.lightbox.android.bitmap.BitmapFileCleanerTask.java
com.lightbox.android.bitmap.BitmapLoaderListener.java
com.lightbox.android.bitmap.BitmapLoaderTask.java
com.lightbox.android.bitmap.BitmapLoader.java
com.lightbox.android.bitmap.BitmapSize.java
com.lightbox.android.bitmap.BitmapSource.java
com.lightbox.android.bitmap.BitmapUtils.java
com.lightbox.android.cache.AbstractCache.java
com.lightbox.android.cache.ApiCache.java
com.lightbox.android.cache.BitmapCache.java
com.lightbox.android.cache.Cache.java
com.lightbox.android.data.ClearAndSaveBatchTask.java
com.lightbox.android.data.Data.java
com.lightbox.android.data.DatabaseCleanerTask.java
com.lightbox.android.data.DatabaseHelper.java
com.lightbox.android.data.DeleteBatchTask.java
com.lightbox.android.data.SaveBatchTask.java
com.lightbox.android.io.RandomAccessFileOutputStream.java
com.lightbox.android.lifecycle.LifeCycleListener.java
com.lightbox.android.lifecycle.ManagedLifeCycleActivity.java
com.lightbox.android.location.LocationHelper.java
com.lightbox.android.location.LocationListener.java
com.lightbox.android.network.HttpHelper.java
com.lightbox.android.network.NetworkUtils.java
com.lightbox.android.operations.AbstractOperation.java
com.lightbox.android.operations.CachedOperation.java
com.lightbox.android.operations.DeleteOperation.java
com.lightbox.android.operations.FailureOperation.java
com.lightbox.android.operations.ModificationNetworkOnlyOperation.java
com.lightbox.android.operations.NetworkOnlyOperation.java
com.lightbox.android.operations.OperationListener.java
com.lightbox.android.operations.OperationTask.java
com.lightbox.android.operations.Operation.java
com.lightbox.android.operations.Retrievable.java
com.lightbox.android.operations.RetrieveOperation.java
com.lightbox.android.operations.SaveOperation.java
com.lightbox.android.operations.Updatable.java
com.lightbox.android.tasks.BackgroundTaskWeak.java
com.lightbox.android.tasks.BackgroundTask.java
com.lightbox.android.tasks.DefaultExecutor.java
com.lightbox.android.utils.AndroidUtils.java
com.lightbox.android.utils.Base64.java
com.lightbox.android.utils.IntentUtils.java
com.lightbox.android.utils.MediaUtils.java
com.lightbox.android.utils.ResUtils.java
com.lightbox.android.utils.debug.DebugLifeCycleListener.java
com.lightbox.android.utils.debug.DebugLog.java
com.lightbox.android.views.RemoteImageView.java
com.lightbox.android.views.RemoteThumbImageView.java
com.lightbox.android.webservices.processors.GenerationException.java
com.lightbox.android.webservices.processors.JacksonProcessor.java
com.lightbox.android.webservices.processors.ParsingException.java
com.lightbox.android.webservices.processors.Processor.java
com.lightbox.android.webservices.requests.ApiRequestFactory.java
com.lightbox.android.webservices.requests.ApiRequestListener.java
com.lightbox.android.webservices.requests.ApiRequestTask.java
com.lightbox.android.webservices.requests.ApiRequest.java
com.lightbox.android.webservices.requests.ApiRequests.java
com.lightbox.android.webservices.requests.JacksonApiRequestFactory.java
com.lightbox.android.webservices.responses.ApiException.java
com.lightbox.android.webservices.responses.ApiResponse.java
com.lightbox.tweetsnearby.TweetsNearbyApplication.java
com.lightbox.tweetsnearby.activities.MainActivity.java
com.lightbox.tweetsnearby.activities.PickPlaceActivity.java
com.lightbox.tweetsnearby.model.Tweet.java
com.lightbox.tweetsnearby.model.Venue.java
com.lightbox.tweetsnearby.responses.foursquare.FoursquareApiResponse.java
com.lightbox.tweetsnearby.responses.foursquare.VenueListResponse.java
com.lightbox.tweetsnearby.responses.twitter.TweetListResponse.java
com.lightbox.tweetsnearby.responses.twitter.TwitterApiResponse.java