1 /*
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 
17 package android.app.usage;
18 
19 import android.annotation.NonNull;
20 import android.annotation.Nullable;
21 import android.annotation.SystemApi;
22 import android.os.Parcel;
23 import android.os.Parcelable;
24 
25 import com.android.internal.util.Preconditions;
26 
27 import java.util.Objects;
28 
29 /**
30  * CacheQuotaHint represents a triplet of a uid, the volume UUID it is stored upon, and
31  * its usage stats. When processed, it obtains a cache quota as defined by the system which
32  * allows apps to understand how much cache to use.
33  * {@hide}
34  */
35 @SystemApi
36 public final class CacheQuotaHint implements Parcelable {
37     public static final long QUOTA_NOT_SET = -1;
38     private final String mUuid;
39     private final int mUid;
40     private final UsageStats mUsageStats;
41     private final long mQuota;
42 
43     /**
44      * Create a new request.
45      * @param builder A builder for this object.
46      */
CacheQuotaHint(@onNull Builder builder)47     public CacheQuotaHint(@NonNull Builder builder) {
48         this.mUuid = builder.mUuid;
49         this.mUid = builder.mUid;
50         this.mUsageStats = builder.mUsageStats;
51         this.mQuota = builder.mQuota;
52     }
53 
getVolumeUuid()54     @Nullable public String getVolumeUuid() {
55         return mUuid;
56     }
57 
getUid()58     public int getUid() {
59         return mUid;
60     }
61 
getQuota()62     public long getQuota() {
63         return mQuota;
64     }
65 
getUsageStats()66     @Nullable public UsageStats getUsageStats() {
67         return mUsageStats;
68     }
69 
70     @Override
writeToParcel(@onNull Parcel dest, int flags)71     public void writeToParcel(@NonNull Parcel dest, int flags) {
72         dest.writeString(mUuid);
73         dest.writeInt(mUid);
74         dest.writeLong(mQuota);
75         dest.writeParcelable(mUsageStats, 0);
76     }
77 
78     @Override
describeContents()79     public int describeContents() {
80         return 0;
81     }
82 
83     @Override
equals(@ullable Object o)84     public boolean equals(@Nullable Object o) {
85         if (o instanceof CacheQuotaHint) {
86             final CacheQuotaHint other = (CacheQuotaHint) o;
87             return Objects.equals(mUuid, other.mUuid)
88                     && Objects.equals(mUsageStats, other.mUsageStats)
89                     && mUid == other.mUid && mQuota == other.mQuota;
90         }
91 
92         return false;
93     }
94 
95     @Override
hashCode()96     public int hashCode() {
97         return Objects.hash(this.mUuid, this.mUid, this.mUsageStats, this.mQuota);
98     }
99 
100     public static final class Builder {
101         private String mUuid;
102         private int mUid;
103         private UsageStats mUsageStats;
104         private long mQuota;
105 
Builder()106         public Builder() {
107         }
108 
Builder(@onNull CacheQuotaHint hint)109         public Builder(@NonNull CacheQuotaHint hint) {
110             setVolumeUuid(hint.getVolumeUuid());
111             setUid(hint.getUid());
112             setUsageStats(hint.getUsageStats());
113             setQuota(hint.getQuota());
114         }
115 
setVolumeUuid(@ullable String uuid)116         public @NonNull Builder setVolumeUuid(@Nullable String uuid) {
117             mUuid = uuid;
118             return this;
119         }
120 
setUid(int uid)121         public @NonNull Builder setUid(int uid) {
122             Preconditions.checkArgumentNonnegative(uid, "Proposed uid was negative.");
123             mUid = uid;
124             return this;
125         }
126 
setUsageStats(@ullable UsageStats stats)127         public @NonNull Builder setUsageStats(@Nullable UsageStats stats) {
128             mUsageStats = stats;
129             return this;
130         }
131 
setQuota(long quota)132         public @NonNull Builder setQuota(long quota) {
133             Preconditions.checkArgument((quota >= QUOTA_NOT_SET));
134             mQuota = quota;
135             return this;
136         }
137 
build()138         public @NonNull CacheQuotaHint build() {
139             return new CacheQuotaHint(this);
140         }
141     }
142 
143     public static final @android.annotation.NonNull Parcelable.Creator<CacheQuotaHint> CREATOR =
144             new Creator<CacheQuotaHint>() {
145                 @Override
146                 public CacheQuotaHint createFromParcel(Parcel in) {
147                     final Builder builder = new Builder();
148                     return builder.setVolumeUuid(in.readString())
149                             .setUid(in.readInt())
150                             .setQuota(in.readLong())
151                             .setUsageStats(in.readParcelable(UsageStats.class.getClassLoader(), android.app.usage.UsageStats.class))
152                             .build();
153                 }
154 
155                 @Override
156                 public CacheQuotaHint[] newArray(int size) {
157                     return new CacheQuotaHint[size];
158                 }
159             };
160 }
161