• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2024 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.app.appsearch.aidl;
18 
19 import android.annotation.ElapsedRealtimeLong;
20 import android.annotation.NonNull;
21 import android.app.appsearch.safeparcel.AbstractSafeParcelable;
22 import android.app.appsearch.safeparcel.SafeParcelable;
23 import android.os.Parcel;
24 import android.os.Parcelable;
25 import android.os.UserHandle;
26 
27 import java.util.Objects;
28 
29 /**
30  * Encapsulates a request to make a binder call to persist all update/delete requests to the disk.
31  *
32  * @hide
33  */
34 @SafeParcelable.Class(creator = "PersistToDiskAidlRequestCreator")
35 public class PersistToDiskAidlRequest extends AbstractSafeParcelable {
36     @NonNull
37     public static final Parcelable.Creator<PersistToDiskAidlRequest> CREATOR =
38             new PersistToDiskAidlRequestCreator();
39 
40     @NonNull
41     @Field(id = 1, getter = "getCallerAttributionSource")
42     private final AppSearchAttributionSource mCallerAttributionSource;
43 
44     @NonNull
45     @Field(id = 2, getter = "getUserHandle")
46     private final UserHandle mUserHandle;
47 
48     @ElapsedRealtimeLong
49     @Field(id = 3, getter = "getBinderCallStartTimeMillis")
50     private final long mBinderCallStartTimeMillis;
51 
52     /**
53      * Creates and initializes AppSearchImpl for the calling app.
54      *
55      * @param callerAttributionSource The permission identity of the package to initialize for.
56      * @param userHandle Handle of the calling user
57      * @param binderCallStartTimeMillis start timestamp of binder call in Millis
58      */
59     @Constructor
PersistToDiskAidlRequest( @aramid = 1) @onNull AppSearchAttributionSource callerAttributionSource, @Param(id = 2) @NonNull UserHandle userHandle, @Param(id = 3) @ElapsedRealtimeLong long binderCallStartTimeMillis)60     public PersistToDiskAidlRequest(
61             @Param(id = 1) @NonNull AppSearchAttributionSource callerAttributionSource,
62             @Param(id = 2) @NonNull UserHandle userHandle,
63             @Param(id = 3) @ElapsedRealtimeLong long binderCallStartTimeMillis) {
64         mCallerAttributionSource = Objects.requireNonNull(callerAttributionSource);
65         mUserHandle = Objects.requireNonNull(userHandle);
66         mBinderCallStartTimeMillis = binderCallStartTimeMillis;
67     }
68 
69     @NonNull
getCallerAttributionSource()70     public AppSearchAttributionSource getCallerAttributionSource() {
71         return mCallerAttributionSource;
72     }
73 
74     @NonNull
getUserHandle()75     public UserHandle getUserHandle() {
76         return mUserHandle;
77     }
78 
79     @ElapsedRealtimeLong
getBinderCallStartTimeMillis()80     public long getBinderCallStartTimeMillis() {
81         return mBinderCallStartTimeMillis;
82     }
83 
84     @Override
writeToParcel(@onNull Parcel dest, int flags)85     public void writeToParcel(@NonNull Parcel dest, int flags) {
86         PersistToDiskAidlRequestCreator.writeToParcel(this, dest, flags);
87     }
88 }
89