summaryrefslogtreecommitdiffstats
path: root/java/com/android/voicemail/impl/scheduling/Task.java
blob: 2d08f5b039dd00da52175546bd21c1756e281651 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/*
 * Copyright (C) 2016 The Android Open Source Project
 *
 * 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.android.voicemail.impl.scheduling;

import android.content.Context;
import android.content.Intent;
import android.support.annotation.MainThread;
import android.support.annotation.WorkerThread;
import android.telecom.PhoneAccountHandle;
import java.util.Objects;

/**
 * A task for {@link TaskSchedulerService} to execute. Since the task is sent through a intent to
 * the scheduler, The task must be constructable with the intent. Specifically, It must have a
 * constructor with zero arguments, and have all relevant data packed inside the intent. Use {@link
 * TaskSchedulerService#createIntent(Context, Class)} to create a intent that will construct the
 * Task.
 *
 * <p>Only {@link #onExecuteInBackgroundThread()} is run on the worker thread.
 */
public interface Task {

  /**
   * TaskId to indicate it has not be set. If a task does not provide a default TaskId it should be
   * set before {@link Task#onCreate(Context, Intent, int, int) returns}
   */
  int TASK_INVALID = -1;

  /**
   * TaskId to indicate it should always be queued regardless of duplicates. {@link
   * Task#onDuplicatedTaskAdded(Task)} will never be called on tasks with this TaskId.
   */
  int TASK_ALLOW_DUPLICATES = -2;

  int TASK_UPLOAD = 1;
  int TASK_SYNC = 2;
  int TASK_ACTIVATION = 3;

  /**
   * Used to differentiate between types of tasks. If a task with the same TaskId is already in the
   * queue the new task will be rejected.
   */
  class TaskId {

    /** Indicates the operation type of the task. */
    public final int id;
    /**
     * Same operation for a different phoneAccountHandle is allowed. phoneAccountHandle is used to
     * differentiate phone accounts in multi-SIM scenario. For example, each SIM can queue a sync
     * task for their own.
     */
    public final PhoneAccountHandle phoneAccountHandle;

    public TaskId(int id, PhoneAccountHandle phoneAccountHandle) {
      this.id = id;
      this.phoneAccountHandle = phoneAccountHandle;
    }

    @Override
    public boolean equals(Object object) {
      if (!(object instanceof TaskId)) {
        return false;
      }
      TaskId other = (TaskId) object;
      return id == other.id && phoneAccountHandle.equals(other.phoneAccountHandle);
    }

    @Override
    public int hashCode() {
      return Objects.hash(id, phoneAccountHandle);
    }
  }

  TaskId getId();

  @MainThread
  void onCreate(Context context, Intent intent, int flags, int startId);

  /**
   * @return number of milliSeconds the scheduler should wait before running this task. A value less
   *     than {@link TaskSchedulerService#READY_TOLERANCE_MILLISECONDS} will be considered ready. If
   *     no tasks are ready, the scheduler will sleep for this amount of time before doing another
   *     check (it will still wake if a new task is added). The first task in the queue that is
   *     ready will be executed.
   */
  @MainThread
  long getReadyInMilliSeconds();

  /**
   * Called on the main thread when the scheduler is about to send the task into the worker thread,
   * calling {@link #onExecuteInBackgroundThread()}
   */
  @MainThread
  void onBeforeExecute();

  /** The actual payload of the task, executed on the worker thread. */
  @WorkerThread
  void onExecuteInBackgroundThread();

  /**
   * Called on the main thread when {@link #onExecuteInBackgroundThread()} has finished or thrown an
   * uncaught exception. The task is already removed from the queue at this point, and a same task
   * can be queued again.
   */
  @MainThread
  void onCompleted();

  /**
   * Another task with the same TaskId has been added. Necessary data can be retrieved from the
   * other task, and after this returns the task will be discarded.
   */
  @MainThread
  void onDuplicatedTaskAdded(Task task);
}