xref: /aosp_15_r20/frameworks/base/cmds/incidentd/src/Privacy.h (revision d57664e9bc4670b3ecf6748a746a57c557b6bc9e)
1*d57664e9SAndroid Build Coastguard Worker /*
2*d57664e9SAndroid Build Coastguard Worker  * Copyright (C) 2017 The Android Open Source Project
3*d57664e9SAndroid Build Coastguard Worker  *
4*d57664e9SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*d57664e9SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*d57664e9SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*d57664e9SAndroid Build Coastguard Worker  *
8*d57664e9SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*d57664e9SAndroid Build Coastguard Worker  *
10*d57664e9SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*d57664e9SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*d57664e9SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*d57664e9SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*d57664e9SAndroid Build Coastguard Worker  * limitations under the License.
15*d57664e9SAndroid Build Coastguard Worker  */
16*d57664e9SAndroid Build Coastguard Worker #pragma once
17*d57664e9SAndroid Build Coastguard Worker 
18*d57664e9SAndroid Build Coastguard Worker #ifndef PRIVACY_H
19*d57664e9SAndroid Build Coastguard Worker #define PRIVACY_H
20*d57664e9SAndroid Build Coastguard Worker 
21*d57664e9SAndroid Build Coastguard Worker #include <android/os/IncidentReportArgs.h>
22*d57664e9SAndroid Build Coastguard Worker 
23*d57664e9SAndroid Build Coastguard Worker #include <stdint.h>
24*d57664e9SAndroid Build Coastguard Worker 
25*d57664e9SAndroid Build Coastguard Worker namespace android {
26*d57664e9SAndroid Build Coastguard Worker namespace os {
27*d57664e9SAndroid Build Coastguard Worker namespace incidentd {
28*d57664e9SAndroid Build Coastguard Worker 
29*d57664e9SAndroid Build Coastguard Worker using namespace android::os;
30*d57664e9SAndroid Build Coastguard Worker 
31*d57664e9SAndroid Build Coastguard Worker /*
32*d57664e9SAndroid Build Coastguard Worker  * In order to NOT auto-generate large chuck of code by proto compiler in incidentd,
33*d57664e9SAndroid Build Coastguard Worker  * privacy options's data structure are explicitly redefined here and
34*d57664e9SAndroid Build Coastguard Worker  * the values are populated by incident_section_gen tool.
35*d57664e9SAndroid Build Coastguard Worker  *
36*d57664e9SAndroid Build Coastguard Worker  * Each proto field will have a Privacy when it is different from its parent, otherwise
37*d57664e9SAndroid Build Coastguard Worker  * it uses its parent's tag. A message type will have an array of Privacy.
38*d57664e9SAndroid Build Coastguard Worker  */
39*d57664e9SAndroid Build Coastguard Worker struct Privacy {
40*d57664e9SAndroid Build Coastguard Worker     // The field number
41*d57664e9SAndroid Build Coastguard Worker     uint32_t field_id;
42*d57664e9SAndroid Build Coastguard Worker 
43*d57664e9SAndroid Build Coastguard Worker     // The field type, see external/protobuf/src/google/protobuf/descriptor.h
44*d57664e9SAndroid Build Coastguard Worker     uint8_t type;
45*d57664e9SAndroid Build Coastguard Worker 
46*d57664e9SAndroid Build Coastguard Worker     // If children is null, it is a primitive field,
47*d57664e9SAndroid Build Coastguard Worker     // otherwise it is a message field which could have overridden privacy tags here.
48*d57664e9SAndroid Build Coastguard Worker     // This array is NULL-terminated.
49*d57664e9SAndroid Build Coastguard Worker     Privacy** children;
50*d57664e9SAndroid Build Coastguard Worker 
51*d57664e9SAndroid Build Coastguard Worker     // DESTINATION Enum in frameworks/base/core/proto/android/privacy.proto.
52*d57664e9SAndroid Build Coastguard Worker     uint8_t policy;
53*d57664e9SAndroid Build Coastguard Worker 
54*d57664e9SAndroid Build Coastguard Worker     // A list of regexp rules for stripping string fields in proto.
55*d57664e9SAndroid Build Coastguard Worker     const char** patterns;
56*d57664e9SAndroid Build Coastguard Worker 
57*d57664e9SAndroid Build Coastguard Worker     string toString() const;
58*d57664e9SAndroid Build Coastguard Worker };
59*d57664e9SAndroid Build Coastguard Worker 
60*d57664e9SAndroid Build Coastguard Worker // Encode field id used by ProtoOutputStream.
61*d57664e9SAndroid Build Coastguard Worker uint64_t encode_field_id(const Privacy* p);
62*d57664e9SAndroid Build Coastguard Worker 
63*d57664e9SAndroid Build Coastguard Worker // Look up the child with given fieldId, if not found, return NULL.
64*d57664e9SAndroid Build Coastguard Worker const Privacy* lookup(const Privacy* p, uint32_t fieldId);
65*d57664e9SAndroid Build Coastguard Worker 
66*d57664e9SAndroid Build Coastguard Worker /**
67*d57664e9SAndroid Build Coastguard Worker  * PrivacySpec defines the request has what level of privacy authorization.
68*d57664e9SAndroid Build Coastguard Worker  * For example, a device without user consent should only be able to upload AUTOMATIC fields.
69*d57664e9SAndroid Build Coastguard Worker  * PRIVACY_POLICY_UNSET are treated as PRIVACY_POLICY_EXPLICIT.
70*d57664e9SAndroid Build Coastguard Worker  */
71*d57664e9SAndroid Build Coastguard Worker class PrivacySpec {
72*d57664e9SAndroid Build Coastguard Worker public:
73*d57664e9SAndroid Build Coastguard Worker     explicit PrivacySpec(uint8_t argPolicy);
74*d57664e9SAndroid Build Coastguard Worker 
75*d57664e9SAndroid Build Coastguard Worker     bool operator<(const PrivacySpec& other) const;
76*d57664e9SAndroid Build Coastguard Worker 
77*d57664e9SAndroid Build Coastguard Worker     // check permission of a policy, if returns true, don't strip the data.
78*d57664e9SAndroid Build Coastguard Worker     bool CheckPremission(const Privacy* privacy,
79*d57664e9SAndroid Build Coastguard Worker                          const uint8_t defaultPrivacyPolicy = PRIVACY_POLICY_UNSET) const;
80*d57664e9SAndroid Build Coastguard Worker 
81*d57664e9SAndroid Build Coastguard Worker     // if returns true, no data need to be stripped.
82*d57664e9SAndroid Build Coastguard Worker     bool RequireAll() const;
83*d57664e9SAndroid Build Coastguard Worker 
84*d57664e9SAndroid Build Coastguard Worker     uint8_t getPolicy() const;
85*d57664e9SAndroid Build Coastguard Worker 
86*d57664e9SAndroid Build Coastguard Worker private:
87*d57664e9SAndroid Build Coastguard Worker     // unimplemented constructors
88*d57664e9SAndroid Build Coastguard Worker     explicit PrivacySpec();
89*d57664e9SAndroid Build Coastguard Worker 
90*d57664e9SAndroid Build Coastguard Worker     uint8_t mPolicy;
91*d57664e9SAndroid Build Coastguard Worker };
92*d57664e9SAndroid Build Coastguard Worker 
93*d57664e9SAndroid Build Coastguard Worker /**
94*d57664e9SAndroid Build Coastguard Worker  * If a privacy policy is other than the defined values, update it to a real one.
95*d57664e9SAndroid Build Coastguard Worker  */
96*d57664e9SAndroid Build Coastguard Worker uint8_t cleanup_privacy_policy(uint8_t policy);
97*d57664e9SAndroid Build Coastguard Worker 
98*d57664e9SAndroid Build Coastguard Worker }  // namespace incidentd
99*d57664e9SAndroid Build Coastguard Worker }  // namespace os
100*d57664e9SAndroid Build Coastguard Worker }  // namespace android
101*d57664e9SAndroid Build Coastguard Worker 
102*d57664e9SAndroid Build Coastguard Worker #endif  // PRIVACY_H
103