blob: b59fdfc61669992820f04281244efdaa692fec11 [file] [log] [blame]
Mårten Kongstad867a3492023-04-25 15:06:30 +02001// Copyright (C) 2023 The Android Open Source Project
2//
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
Mårten Kongstadfa23d292023-05-11 14:47:02 +020015// This is the schema definition for aconfig files. Modifications need to be
16// either backwards compatible, or include updates to all aconfig files in the
Mårten Kongstadbb520722023-04-26 13:16:41 +020017// Android tree.
Mårten Kongstad867a3492023-04-25 15:06:30 +020018
Mårten Kongstadbb520722023-04-26 13:16:41 +020019syntax = "proto2";
Mårten Kongstad867a3492023-04-25 15:06:30 +020020
21package android.aconfig;
22
Mårten Kongstad30950782023-05-09 13:31:29 +020023// messages used in both aconfig input and output
24
Mårten Kongstadc68c4ea2023-05-05 16:20:09 +020025enum flag_state {
26 ENABLED = 1;
27 DISABLED = 2;
28}
29
Mårten Kongstad30950782023-05-09 13:31:29 +020030enum flag_permission {
Mårten Kongstad416330b2023-05-05 11:10:01 +020031 READ_ONLY = 1;
32 READ_WRITE = 2;
33}
34
Mårten Kongstadfa23d292023-05-11 14:47:02 +020035// aconfig input messages: flag declarations and values
Mårten Kongstad30950782023-05-09 13:31:29 +020036
Mårten Kongstadfa23d292023-05-11 14:47:02 +020037message flag_declaration {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020038 optional string name = 1;
39 optional string namespace = 2;
40 optional string description = 3;
Mårten Kongstadbb520722023-04-26 13:16:41 +020041};
42
Mårten Kongstadfa23d292023-05-11 14:47:02 +020043message flag_declarations {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020044 optional string package = 1;
Mårten Kongstadfa23d292023-05-11 14:47:02 +020045 repeated flag_declaration flag = 2;
Mårten Kongstadbb520722023-04-26 13:16:41 +020046};
47
Mårten Kongstadfa23d292023-05-11 14:47:02 +020048message flag_value {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020049 optional string package = 1;
50 optional string name = 2;
51 optional flag_state state = 3;
52 optional flag_permission permission = 4;
Mårten Kongstadbb520722023-04-26 13:16:41 +020053};
54
Mårten Kongstadfa23d292023-05-11 14:47:02 +020055message flag_values {
56 repeated flag_value flag_value = 1;
Mårten Kongstadbb520722023-04-26 13:16:41 +020057};
Mårten Kongstada1029092023-05-08 11:51:59 +020058
Mårten Kongstadfa23d292023-05-11 14:47:02 +020059// aconfig output messages: parsed and verified flag declarations and values
Mårten Kongstada1029092023-05-08 11:51:59 +020060
Mårten Kongstad30950782023-05-09 13:31:29 +020061message tracepoint {
Mårten Kongstadfa23d292023-05-11 14:47:02 +020062 // path to declaration or value file relative to $TOP
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020063 optional string source = 1;
64 optional flag_state state = 2;
65 optional flag_permission permission = 3;
Mårten Kongstada1029092023-05-08 11:51:59 +020066}
67
Mårten Kongstad30950782023-05-09 13:31:29 +020068message parsed_flag {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020069 optional string package = 1;
70 optional string name = 2;
71 optional string namespace = 3;
72 optional string description = 4;
73 optional flag_state state = 5;
74 optional flag_permission permission = 6;
Mårten Kongstad066575b2023-06-07 16:29:25 +020075 repeated tracepoint trace = 7;
Mårten Kongstad30950782023-05-09 13:31:29 +020076}
77
78message parsed_flags {
79 repeated parsed_flag parsed_flag = 1;
Mårten Kongstada1029092023-05-08 11:51:59 +020080}