xref: /aosp_15_r20/system/apex/apexd/apex_blocklist.h (revision 33f3758387333dbd2962d7edbd98681940d895da)
1*33f37583SAndroid Build Coastguard Worker /*
2*33f37583SAndroid Build Coastguard Worker  * Copyright (C) 2024 The Android Open Source Project
3*33f37583SAndroid Build Coastguard Worker  *
4*33f37583SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*33f37583SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*33f37583SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*33f37583SAndroid Build Coastguard Worker  *
8*33f37583SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*33f37583SAndroid Build Coastguard Worker  *
10*33f37583SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*33f37583SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*33f37583SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*33f37583SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*33f37583SAndroid Build Coastguard Worker  * limitations under the License.
15*33f37583SAndroid Build Coastguard Worker  */
16*33f37583SAndroid Build Coastguard Worker 
17*33f37583SAndroid Build Coastguard Worker #pragma once
18*33f37583SAndroid Build Coastguard Worker 
19*33f37583SAndroid Build Coastguard Worker #include <android-base/result.h>
20*33f37583SAndroid Build Coastguard Worker 
21*33f37583SAndroid Build Coastguard Worker #include <string>
22*33f37583SAndroid Build Coastguard Worker 
23*33f37583SAndroid Build Coastguard Worker #include "apex_blocklist.pb.h"
24*33f37583SAndroid Build Coastguard Worker 
25*33f37583SAndroid Build Coastguard Worker namespace android::apex {
26*33f37583SAndroid Build Coastguard Worker // Parses and validates APEX blocklist. The blocklist is used only to block
27*33f37583SAndroid Build Coastguard Worker // brand-new APEX. A brand-new APEX is blocked when the name exactly matches the
28*33f37583SAndroid Build Coastguard Worker // block item and the version is smaller than or equal to the configured
29*33f37583SAndroid Build Coastguard Worker // version.
30*33f37583SAndroid Build Coastguard Worker android::base::Result<::apex::proto::ApexBlocklist> ParseBlocklist(
31*33f37583SAndroid Build Coastguard Worker     const std::string& content);
32*33f37583SAndroid Build Coastguard Worker // Reads and parses APEX blocklist from the file on disk.
33*33f37583SAndroid Build Coastguard Worker android::base::Result<::apex::proto::ApexBlocklist> ReadBlocklist(
34*33f37583SAndroid Build Coastguard Worker     const std::string& path);
35*33f37583SAndroid Build Coastguard Worker }  // namespace android::apex
36