blob: e93d0f4723464a9b44caa104b17972a7881dc219 [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
syntax = "proto2";
import "frameworks/proto_logging/stats/atoms.proto";
import "frameworks/proto_logging/stats/atom_field_options.proto";
package android.stats_log_api_gen;
message IntAtom {
optional int32 field1 = 1;
}
message AnotherIntAtom {
optional int32 field1 = 1;
}
message OutOfOrderAtom {
optional int32 field2 = 2;
optional int32 field1 = 1;
}
enum AnEnum {
VALUE0 = 0;
VALUE1 = 1;
}
message AllTypesAtom {
repeated android.os.statsd.AttributionNode attribution_chain = 1;
optional float float_field = 2;
optional int64 int64_field = 3;
optional uint64 uint64_field = 4;
optional int32 int32_field = 5;
optional bool bool_field = 6;
optional string string_field = 7;
optional uint32 uint32_field = 8;
optional AnEnum enum_field = 9;
repeated float repeated_float_field = 10;
repeated int64 repeated_int64_field = 11;
repeated int32 repeated_int32_field = 12;
repeated bool repeated_bool_field = 13;
repeated string repeated_string_field = 14;
}
// Separated from AllTypesAtom because tests can't properly check atoms with multiple enum type
// fields
message RepeatedEnumAtom {
repeated AnEnum repeated_enum_field = 1;
}
message Event {
oneof pushed {
OutOfOrderAtom out_of_order_atom = 2;
IntAtom int_atom = 1;
AnotherIntAtom another_int_atom = 3;
AllTypesAtom all_types_atom = 4;
RepeatedEnumAtom repeated_enum_atom = 5;
}
}
message BadTypesAtom {
optional IntAtom bad_int_atom = 1;
optional bytes bad_bytes = 2;
optional double double_field = 3;
optional fixed64 fixed64_field = 4;
optional fixed32 fixed32_field = 5;
optional sfixed64 sfixed64_field = 6;
optional sfixed32 sfixed32_field = 7;
optional sint64 sint64_field = 8;
optional sint32 sint32_field = 9;
repeated double double_repeated_field = 10;
repeated fixed64 fixed64_repeated_field = 11;
repeated fixed32 fixed32_repeated_field = 12;
repeated sfixed64 sfixed64_repeated_field = 13;
repeated sfixed32 sfixed32_repeated_field = 14;
repeated sint64 sint64_repeated_field = 15;
repeated sint32 sint32_repeated_field = 16;
repeated uint64 uint64_repeated_field = 17;
repeated uint32 uint32_repeated_field = 18;
repeated IntAtom bad_int_atom_repeated_field = 19;
repeated bytes bad_bytes_repeated_field = 20;
}
message BadTypesEvent {
oneof pushed {
BadTypesAtom bad_types_atom = 1;
}
}
message BadSkippedFieldSingleAtom {
optional int32 field2 = 2;
}
message BadSkippedFieldSingle {
oneof pushed {
BadSkippedFieldSingleAtom bad = 1;
}
}
message BadSkippedFieldMultipleAtom {
optional int32 field1 = 1;
optional int32 field3 = 3;
optional int32 field5 = 5;
}
message BadSkippedFieldMultiple {
oneof pushed {
BadSkippedFieldMultipleAtom bad = 1;
}
}
message BadAttributionNodePositionAtom {
optional int32 field1 = 1;
repeated android.os.statsd.AttributionNode attribution = 2;
}
message BadAttributionNodePosition {
oneof pushed { BadAttributionNodePositionAtom bad = 1; }
}
message GoodEventWithBinaryFieldAtom {
oneof pushed { GoodBinaryFieldAtom field1 = 1; }
}
message ComplexField {
optional string str = 1;
}
message GoodBinaryFieldAtom {
optional int32 field1 = 1;
optional ComplexField bf = 2 [(android.os.statsd.log_mode) = MODE_BYTES];
}
message BadEventWithBinaryFieldAtom {
oneof pushed { BadBinaryFieldAtom field1 = 1; }
}
message BadBinaryFieldAtom {
optional int32 field1 = 1;
optional ComplexField bf = 2;
}
message BadStateAtoms {
oneof pushed {
BadStateAtom1 bad1 = 1;
BadStateAtom2 bad2 = 2;
BadStateAtom3 bad3 = 3;
BadStateAtom4 bad4 = 4;
}
}
message GoodStateAtoms {
oneof pushed {
GoodStateAtom1 good1 = 1;
GoodStateAtom2 good2 = 2;
}
}
// The atom has only primary field but no exclusive state field.
message BadStateAtom1 {
optional int32 uid = 1 [(android.os.statsd.state_field_option).primary_field = true];
}
// Only primative types can be annotated.
message BadStateAtom2 {
repeated android.os.statsd.AttributionNode attribution = 1
[(android.os.statsd.state_field_option).primary_field = true];
optional int32 state = 2 [(android.os.statsd.state_field_option).exclusive_state = true];
}
// Having 2 exclusive state field in the atom means the atom is badly designed.
// E.g., putting bluetooth state and wifi state in the same atom.
message BadStateAtom3 {
optional int32 uid = 1 [(android.os.statsd.state_field_option).primary_field = true];
optional int32 state = 2 [(android.os.statsd.state_field_option).exclusive_state = true];
optional int32 state2 = 3 [(android.os.statsd.state_field_option).exclusive_state = true];
}
// Repeated fields can't have state annotations.
message BadStateAtom4 {
repeated int32 state = 1 [(android.os.statsd.state_field_option).exclusive_state = true];
}
message GoodStateAtom1 {
optional int32 uid = 1 [(android.os.statsd.state_field_option).primary_field = true];
optional int32 state = 2 [(android.os.statsd.state_field_option).exclusive_state = true];
}
// Atoms can have exclusive state field, but no primary field. That means
// the state is globally exclusive (e.g., DisplayState).
message GoodStateAtom2 {
optional int32 uid = 1;
optional int32 state = 2 [(android.os.statsd.state_field_option).exclusive_state = true];
}
// We can have more than one primary fields. That means their combination is a
// primary key.
message GoodStateAtom3 {
optional int32 uid = 1 [(android.os.statsd.state_field_option).primary_field = true];
optional int32 tid = 2 [(android.os.statsd.state_field_option).primary_field = true];
optional int32 state = 3 [(android.os.statsd.state_field_option).exclusive_state = true];
}
message BadUidAtoms {
oneof pushed {
BadUidAtom1 bad1 = 1;
BadUidAtom2 bad2 = 2;
}
}
message GoodUidAtoms {
oneof pushed {
GoodUidAtom1 good1 = 1;
GoodUidAtom2 good2 = 2;
}
}
// The only repeated field type that can have is_uid annotation is int32.
message BadUidAtom1 {
repeated int64 uid = 1 [(android.os.statsd.is_uid) = true];
}
message BadUidAtom2 {
optional string uid = 1 [(android.os.statsd.is_uid) = true];
}
message GoodUidAtom1 {
optional int32 uid = 1 [(android.os.statsd.is_uid) = true];
}
message GoodUidAtom2 {
repeated int32 uid = 1 [(android.os.statsd.is_uid) = true];
}
message ModuleOneAtom {
optional int32 field = 1 [(android.os.statsd.is_uid) = true];
}
message ModuleTwoAtom {
optional int32 field = 1;
}
message ModuleOneAndTwoAtom {
optional int32 field = 1 [(android.os.statsd.state_field_option).exclusive_state = true];
}
message NoModuleAtom {
optional string field = 1;
}
message ModuleAtoms {
oneof pushed {
ModuleOneAtom module_one_atom = 1 [(android.os.statsd.module) = "module1"];
ModuleTwoAtom module_two_atom = 2 [(android.os.statsd.module) = "module2"];
ModuleOneAndTwoAtom module_one_and_two_atom = 3 [
(android.os.statsd.module) = "module1", (android.os.statsd.module) = "module2"
];
NoModuleAtom no_module_atom = 4;
}
}
message NotAPushNorPullAtom {
oneof event {
IntAtom int_atom = 1;
}
}
message AtomNotInAOneof {
optional IntAtom int_atom = 1;
}
message PushedAndPulledAtoms {
oneof pushed {
IntAtom int_atom_1 = 1;
}
oneof pulled {
OutOfOrderAtom out_of_order_atom = 11;
AnotherIntAtom another_int_atom = 10;
}
}