1 /*
2  * Copyright (c) 2022 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "permission_used_record_parcel.h"
17 #include "refbase.h"
18 #include "parcel_utils.h"
19 #include "permission_used_type.h"
20 #include "used_record_detail_parcel.h"
21 
22 namespace OHOS {
23 namespace Security {
24 namespace AccessToken {
Marshalling(Parcel & out) const25 bool PermissionUsedRecordParcel::Marshalling(Parcel& out) const
26 {
27     RETURN_IF_FALSE(out.WriteString(this->permissionRecord.permissionName));
28     RETURN_IF_FALSE(out.WriteInt32(this->permissionRecord.accessCount));
29     RETURN_IF_FALSE(out.WriteInt32(this->permissionRecord.rejectCount));
30     RETURN_IF_FALSE(out.WriteInt64(this->permissionRecord.lastAccessTime));
31     RETURN_IF_FALSE(out.WriteInt64(this->permissionRecord.lastRejectTime));
32     RETURN_IF_FALSE(out.WriteInt64(this->permissionRecord.lastAccessDuration));
33 
34     RETURN_IF_FALSE(out.WriteUint32(this->permissionRecord.accessRecords.size()));
35     for (const auto& accRecord : this->permissionRecord.accessRecords) {
36         UsedRecordDetailParcel detailParcel;
37         detailParcel.detail = accRecord;
38         out.WriteParcelable(&detailParcel);
39     }
40 
41     RETURN_IF_FALSE(out.WriteUint32(this->permissionRecord.rejectRecords.size()));
42     for (const auto& rejRecord : this->permissionRecord.rejectRecords) {
43         UsedRecordDetailParcel detailParcel;
44         detailParcel.detail = rejRecord;
45         out.WriteParcelable(&detailParcel);
46     }
47     return true;
48 }
49 
Unmarshalling(Parcel & in)50 PermissionUsedRecordParcel* PermissionUsedRecordParcel::Unmarshalling(Parcel& in)
51 {
52     auto* permissionRecordParcel = new (std::nothrow) PermissionUsedRecordParcel();
53     if (permissionRecordParcel == nullptr) {
54         return nullptr;
55     }
56 
57     RELEASE_IF_FALSE(in.ReadString(permissionRecordParcel->permissionRecord.permissionName), permissionRecordParcel);
58     RELEASE_IF_FALSE(in.ReadInt32(permissionRecordParcel->permissionRecord.accessCount), permissionRecordParcel);
59     RELEASE_IF_FALSE(in.ReadInt32(permissionRecordParcel->permissionRecord.rejectCount), permissionRecordParcel);
60     RELEASE_IF_FALSE(in.ReadInt64(permissionRecordParcel->permissionRecord.lastAccessTime), permissionRecordParcel);
61     RELEASE_IF_FALSE(in.ReadInt64(permissionRecordParcel->permissionRecord.lastRejectTime), permissionRecordParcel);
62     RELEASE_IF_FALSE(in.ReadInt64(permissionRecordParcel->permissionRecord.lastAccessDuration), permissionRecordParcel);
63 
64     uint32_t accRecordSize = 0;
65     RELEASE_IF_FALSE(in.ReadUint32(accRecordSize), permissionRecordParcel);
66     RELEASE_IF_FALSE(accRecordSize <= MAX_ACCESS_RECORD_SIZE, permissionRecordParcel);
67 
68     for (uint32_t i = 0; i < accRecordSize; i++) {
69         sptr<UsedRecordDetailParcel> detailParcel = in.ReadParcelable<UsedRecordDetailParcel>();
70         RELEASE_IF_FALSE(detailParcel != nullptr, permissionRecordParcel);
71         permissionRecordParcel->permissionRecord.accessRecords.emplace_back(detailParcel->detail);
72     }
73 
74     uint32_t rejRecordSize = 0;
75     RELEASE_IF_FALSE(in.ReadUint32(rejRecordSize), permissionRecordParcel);
76     RELEASE_IF_FALSE(rejRecordSize <= MAX_ACCESS_RECORD_SIZE, permissionRecordParcel);
77 
78     uint32_t totalCount = accRecordSize + rejRecordSize;
79     RELEASE_IF_FALSE(totalCount <= MAX_ACCESS_RECORD_SIZE, permissionRecordParcel);
80 
81     for (uint32_t i = 0; i < rejRecordSize; i++) {
82         sptr<UsedRecordDetailParcel> detailParcel = in.ReadParcelable<UsedRecordDetailParcel>();
83         RELEASE_IF_FALSE(detailParcel != nullptr, permissionRecordParcel);
84         permissionRecordParcel->permissionRecord.rejectRecords.emplace_back(detailParcel->detail);
85     }
86     return permissionRecordParcel;
87 }
88 } // namespace AccessToken
89 } // namespace Security
90 } // namespace OHOS
91