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