1 /** 2 * Copyright (c) 2018, 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 17 package android.content.rollback; 18 19 import android.content.pm.ParceledListSlice; 20 import android.content.rollback.RollbackInfo; 21 import android.content.IntentSender; 22 23 /** {@hide} */ 24 interface IRollbackManager { 25 getAvailableRollbacks()26 ParceledListSlice getAvailableRollbacks(); getRecentlyCommittedRollbacks()27 ParceledListSlice getRecentlyCommittedRollbacks(); 28 commitRollback(int rollbackId, in ParceledListSlice causePackages, String callerPackageName, in IntentSender statusReceiver)29 void commitRollback(int rollbackId, in ParceledListSlice causePackages, 30 String callerPackageName, in IntentSender statusReceiver); 31 32 // Exposed for use from the system server only. Callback from the package 33 // manager during the install flow when user data can be backed up and restored for a given 34 // package. snapshotAndRestoreUserData(String packageName, in int[] userIds, int appId, long ceDataInode, String seInfo, int token)35 void snapshotAndRestoreUserData(String packageName, in int[] userIds, int appId, long ceDataInode, 36 String seInfo, int token); 37 38 // Exposed for test purposes only. reloadPersistedData()39 void reloadPersistedData(); 40 41 // Exposed for test purposes only. expireRollbackForPackage(String packageName)42 void expireRollbackForPackage(String packageName); 43 44 // Used by the staging manager to notify the RollbackManager that a session is 45 // being staged. In the case of multi-package sessions, the specified sessionId 46 // is that of the parent session. 47 // Returns the rollback id if rollback was enabled successfully, or -1 if not. 48 // 49 // NOTE: This call is synchronous. notifyStagedSession(int sessionId)50 int notifyStagedSession(int sessionId); 51 52 // Used by the staging manager to notify the RollbackManager of the apk 53 // session for a staged session. notifyStagedApkSession(int originalSessionId, int apkSessionId)54 void notifyStagedApkSession(int originalSessionId, int apkSessionId); 55 56 // For test purposes only. blockRollbackManager(long millis)57 void blockRollbackManager(long millis); 58 } 59