blob: c04d103c7ff5b52d21a03f0665d312ee772569fa [file] [log] [blame]
Andrii Kulian446e8242017-10-26 15:17:29 -07001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package com.android.server.am;
18
19import android.annotation.NonNull;
20import android.app.IApplicationThread;
21import android.app.servertransaction.ClientTransaction;
22import android.app.servertransaction.ClientTransactionItem;
23import android.app.servertransaction.ActivityLifecycleItem;
24import android.os.IBinder;
25import android.os.RemoteException;
26
27/**
28 * Class that is able to combine multiple client lifecycle transition requests and/or callbacks,
29 * and execute them as a single transaction.
30 *
31 * @see ClientTransaction
32 */
33class ClientLifecycleManager {
34 // TODO(lifecycler): Implement building transactions or global transaction.
35 // TODO(lifecycler): Use object pools for transactions and transaction items.
36
37 /**
38 * Schedule a transaction, which may consist of multiple callbacks and a lifecycle request.
39 * @param transaction A sequence of client transaction items.
40 * @throws RemoteException
41 *
42 * @see ClientTransaction
43 */
44 void scheduleTransaction(ClientTransaction transaction) throws RemoteException {
45 transaction.schedule();
46 }
47
48 /**
49 * Schedule a single lifecycle request or callback to client activity.
50 * @param client Target client.
51 * @param activityToken Target activity token.
52 * @param stateRequest A request to move target activity to a desired lifecycle state.
53 * @throws RemoteException
54 *
55 * @see ClientTransactionItem
56 */
57 void scheduleTransaction(@NonNull IApplicationThread client, @NonNull IBinder activityToken,
58 @NonNull ActivityLifecycleItem stateRequest) throws RemoteException {
59 final ClientTransaction clientTransaction = transactionWithState(client, activityToken,
60 stateRequest);
61 scheduleTransaction(clientTransaction);
62 }
63
64 /**
65 * Schedule a single callback delivery to client activity.
66 * @param client Target client.
67 * @param activityToken Target activity token.
68 * @param callback A request to deliver a callback.
69 * @throws RemoteException
70 *
71 * @see ClientTransactionItem
72 */
73 void scheduleTransaction(@NonNull IApplicationThread client, @NonNull IBinder activityToken,
74 @NonNull ClientTransactionItem callback) throws RemoteException {
75 final ClientTransaction clientTransaction = transactionWithCallback(client, activityToken,
76 callback);
77 scheduleTransaction(clientTransaction);
78 }
79
80 /**
81 * Schedule a single callback delivery to client application.
82 * @param client Target client.
83 * @param callback A request to deliver a callback.
84 * @throws RemoteException
85 *
86 * @see ClientTransactionItem
87 */
88 void scheduleTransaction(@NonNull IApplicationThread client,
89 @NonNull ClientTransactionItem callback) throws RemoteException {
90 final ClientTransaction clientTransaction = transactionWithCallback(client,
91 null /* activityToken */, callback);
92 scheduleTransaction(clientTransaction);
93 }
94
95 /**
96 * @return A new instance of {@link ClientTransaction} with a single lifecycle state request.
97 *
98 * @see ClientTransaction
99 * @see ClientTransactionItem
100 */
101 private static ClientTransaction transactionWithState(@NonNull IApplicationThread client,
102 @NonNull IBinder activityToken, @NonNull ActivityLifecycleItem stateRequest) {
103 final ClientTransaction clientTransaction = new ClientTransaction(client, activityToken);
104 clientTransaction.setLifecycleStateRequest(stateRequest);
105 return clientTransaction;
106 }
107
108 /**
109 * @return A new instance of {@link ClientTransaction} with a single callback invocation.
110 *
111 * @see ClientTransaction
112 * @see ClientTransactionItem
113 */
114 private static ClientTransaction transactionWithCallback(@NonNull IApplicationThread client,
115 IBinder activityToken, @NonNull ClientTransactionItem callback) {
116 final ClientTransaction clientTransaction = new ClientTransaction(client, activityToken);
117 clientTransaction.addCallback(callback);
118 return clientTransaction;
119 }
120}