Android Open Source - Mamytas Timers Processor






From Project

Back to project page Mamytas.

License

The source code is released under:

GNU General Public License

If you think the Android project Mamytas 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

package mn.aug.restfulandroid.service;
//from w ww  .  j av  a  2  s  .  c o m
import android.content.Context;

import mn.aug.restfulandroid.provider.OwnershipDBAccess;
import mn.aug.restfulandroid.provider.TasksDBAccess;
import mn.aug.restfulandroid.rest.RestMethod;
import mn.aug.restfulandroid.rest.RestMethodFactory;
import mn.aug.restfulandroid.rest.RestMethodFactory.Method;
import mn.aug.restfulandroid.rest.RestMethodResult;
import mn.aug.restfulandroid.rest.resource.Timer;
import mn.aug.restfulandroid.rest.resource.Timers;

/**
 * The TaskProcessor is a POJO for processing timeline requests.
 * For this pattern, there is one Processor for each resource type.
 *
 * @author Peter Pascale
 */
public class TimersProcessor {


    private ProcessorCallback mCallback;
    private Context mContext;
    private OwnershipDBAccess ownershipDBAccess;
    private TasksDBAccess tasksDBAccess;


    public TimersProcessor(Context context) {

        mContext = context;
        ownershipDBAccess = new OwnershipDBAccess(mContext);
        tasksDBAccess = new TasksDBAccess(mContext);
    }


    void getTimers(ProcessorCallback callback,Long task_id) {

    /*
        Processor is a POJO
      - Processor for each resource type
      - Processor can handle each method on the resource that is supported.
      - Processor needs a callback (which is how the request gets back to the service)
      - Processor uses a RESTMethod - created through a RESTMethodFactory.create(parameterized) or .createGetTask()
      
      First iteration had a callback that updated the content provider
      with the resources. But the eventual implementation simply block 
      for the response and do the update.
     */

        // (4) Insert-Update the ContentProvider with a status column and
        // results column
        // Look at ContentProvider example, and build a content provider
        // that tracks the necessary data.


        // (5) Call the REST method
        // Create a RESTMethod class that knows how to assemble the URL,
        // and performs the HTTP operation.

        RestMethod<Timers> getTimersMethod = RestMethodFactory.getInstance(mContext).getRestMethod(
                Timers.CONTENT_URI, Method.GET, null, null,task_id);
        RestMethodResult<Timers> result = getTimersMethod.execute();

        /*
                 * (8) Insert-Update the ContentProvider status, and insert the result
         * on success Parsing the JSON response (on success) and inserting into
         * the content provider
         */


        // (9) Operation complete callback to Service
        callback.send(result.getStatusCode(),result.getResource());

    }

    public void postTimer(ProcessorCallback callback, long task_id, byte[] body,long timer_id) {

           /*
        Processor is a POJO
      - Processor for each resource type
      - Processor can handle each method on the resource that is supported.
      - Processor needs a callback (which is how the request gets back to the service)
      - Processor uses a RESTMethod - created through a RESTMethodFactory.create(parameterized) or .createGetTask()

      First iteration had a callback that updated the content provider
      with the resources. But the eventual implementation simply block
      for the response and do the update.
     */

        // (4) Insert-Update the ContentProvider with a status column and
        // results column
        // Look at ContentProvider example, and build a content provider
        // that tracks the necessary data.

        // (5) Call the REST method
        // Create a RESTMethod class that knows how to assemble the URL,
        // and performs the HTTP operation.


        RestMethod<Timer> postTaskMethod = RestMethodFactory.getInstance(mContext).getRestMethod(
                Timers.CONTENT_URI, Method.POST, null, body, task_id);
        RestMethodResult<Timer> result = postTaskMethod.execute();

        /*
                 * (8) Insert-Update the ContentProvider status, and insert the result
         * on success Parsing the JSON response (on success) and inserting into
         * the content provider
         */


        if (result.getStatusCode() == 200) {



            ownershipDBAccess.open();
            ownershipDBAccess.deleteTimer(timer_id);
            Timer timer = result.getResource();
            ownershipDBAccess.storeTimerWithId(timer);
            tasksDBAccess.close();
            callback.send(result.getStatusCode(),timer);
        }else {

            callback.send(result.getStatusCode());
        }


    }

    public void putTimer(ProcessorCallback callback, long task_id, byte[] body,long timer_id) {

          /*
        Processor is a POJO
      - Processor for each resource type
      - Processor can handle each method on the resource that is supported.
      - Processor needs a callback (which is how the request gets back to the service)
      - Processor uses a RESTMethod - created through a RESTMethodFactory.create(parameterized) or .createGetTask()

      First iteration had a callback that updated the content provider
      with the resources. But the eventual implementation simply block
      for the response and do the update.
     */

        // (4) Insert-Update the ContentProvider with a status column and
        // results column
        // Look at ContentProvider example, and build a content provider
        // that tracks the necessary data.

        // (5) Call the REST method
        // Create a RESTMethod class that knows how to assemble the URL,
        // and performs the HTTP operation.
        RestMethod<Timer> putTaskMethod = RestMethodFactory.getInstance(mContext).getRestMethod(
                Timers.CONTENT_URI, RestMethodFactory.Method.PUT, null, body, task_id);
        RestMethodResult<Timer> result = putTaskMethod.execute();

        /*
                 * (8) Insert-Update the ContentProvider status, and insert the result
         * on success Parsing the JSON response (on success) and inserting into
         * the content provider
         */

        if (result.getStatusCode() == 200 ) {




        }

        // (9) Operation complete callback to Service

        callback.send(result.getStatusCode());

    }
}




Java Source Code List

mn.aug.restfulandroid.activity.AboutActivity.java
mn.aug.restfulandroid.activity.LoginActivity.java
mn.aug.restfulandroid.activity.ProjectEditor.java
mn.aug.restfulandroid.activity.ProjectsActivity.java
mn.aug.restfulandroid.activity.ProjectsArrayAdapter.java
mn.aug.restfulandroid.activity.TaskActivity.java
mn.aug.restfulandroid.activity.TaskEditor.java
mn.aug.restfulandroid.activity.TasksActivity.java
mn.aug.restfulandroid.activity.TasksArrayAdapter.java
mn.aug.restfulandroid.activity.TimerServiceHelper.java
mn.aug.restfulandroid.activity.TimerService.java
mn.aug.restfulandroid.activity.TimersArrayAdapter.java
mn.aug.restfulandroid.activity.base.RESTfulActivity.java
mn.aug.restfulandroid.activity.base.RESTfulListActivity.java
mn.aug.restfulandroid.activity.base.UndoBarController.java
mn.aug.restfulandroid.provider.CommentsDBAccess.java
mn.aug.restfulandroid.provider.ListsDBAccess.java
mn.aug.restfulandroid.provider.OwnershipDBAccess.java
mn.aug.restfulandroid.provider.ProviderDbHelper.java
mn.aug.restfulandroid.provider.RemindersDBAccess.java
mn.aug.restfulandroid.provider.TasksDBAccess.java
mn.aug.restfulandroid.provider.UsersDBAccess.java
mn.aug.restfulandroid.rest.AbstractRestMethod.java
mn.aug.restfulandroid.rest.DeleteListRestMethod.java
mn.aug.restfulandroid.rest.DeleteTaskRestMethod.java
mn.aug.restfulandroid.rest.GetListsRestMethod.java
mn.aug.restfulandroid.rest.GetTasksRestMethod.java
mn.aug.restfulandroid.rest.GetTimersRestMethod.java
mn.aug.restfulandroid.rest.LoginRestMethod.java
mn.aug.restfulandroid.rest.PostListRestMethod.java
mn.aug.restfulandroid.rest.PostTaskRestMethod.java
mn.aug.restfulandroid.rest.PostTimerRestMethod.java
mn.aug.restfulandroid.rest.PutListRestMethod.java
mn.aug.restfulandroid.rest.PutTaskRestMethod.java
mn.aug.restfulandroid.rest.PutTimerRestMethod.java
mn.aug.restfulandroid.rest.Request.java
mn.aug.restfulandroid.rest.Response.java
mn.aug.restfulandroid.rest.RestClient.java
mn.aug.restfulandroid.rest.RestMethodFactory.java
mn.aug.restfulandroid.rest.RestMethodResult.java
mn.aug.restfulandroid.rest.RestMethod.java
mn.aug.restfulandroid.rest.ShareListRestMethod.java
mn.aug.restfulandroid.rest.resource.Comment.java
mn.aug.restfulandroid.rest.resource.Lists.java
mn.aug.restfulandroid.rest.resource.Listw.java
mn.aug.restfulandroid.rest.resource.Login.java
mn.aug.restfulandroid.rest.resource.Reminder.java
mn.aug.restfulandroid.rest.resource.Resource.java
mn.aug.restfulandroid.rest.resource.TaskList.java
mn.aug.restfulandroid.rest.resource.Task.java
mn.aug.restfulandroid.rest.resource.Tasks.java
mn.aug.restfulandroid.rest.resource.Timer.java
mn.aug.restfulandroid.rest.resource.Timers.java
mn.aug.restfulandroid.security.AuthorizationManager.java
mn.aug.restfulandroid.security.RequestSigner.java
mn.aug.restfulandroid.service.ListProcessor.java
mn.aug.restfulandroid.service.ListsProcessor.java
mn.aug.restfulandroid.service.LoginProcessor.java
mn.aug.restfulandroid.service.ProcessorCallback.java
mn.aug.restfulandroid.service.ShareProcessor.java
mn.aug.restfulandroid.service.TaskProcessor.java
mn.aug.restfulandroid.service.TasksProcessor.java
mn.aug.restfulandroid.service.TimersProcessor.java
mn.aug.restfulandroid.service.WunderlistServiceHelper.java
mn.aug.restfulandroid.service.WunderlistService.java
mn.aug.restfulandroid.util.DateHelper.java
mn.aug.restfulandroid.util.DatePickerFragment.java
mn.aug.restfulandroid.util.Logger.java
mn.aug.restfulandroid.util.TimePickerFragment.java