blob: c5e3ba4554801257b5ae56a7b2c1f9818a8615e3 [file] [log] [blame]
// Describes the proto schema for HTTP flags.
//
// IMPORTANT: a copy of the proto schema described here is used by the HTTP
// flags producer, which is the responsibility of the host system. Be very
// careful about backward compatibility implications of any changes made in this
// file.
syntax = "proto2";
package org.chromium.net.httpflags;
option java_package = "org.chromium.net.httpflags";
option java_multiple_files = true;
// Describes the value that an HTTP flag should have, based on various criteria
// depending on the context in which the flag is used.
message FlagValue {
// A possible value for this flag, along with a set of constraints that have
// to be met for that value to be used.
message ConstrainedValue {
// App selector: only apply this value to applications whose package ID
// matches the value of this field, e.g. "com.google.foo".
// If not set, matches all apps.
optional string app_id = 1;
// Only apply this value to client libraries running at least this version.
//
// Currently this refers to Cronet versions, which are in the form
// <MAJOR>.<MINOR>.<BUILD>.<PATCH>.
//
// The comparison is done in the usual way version numbers are compared,
// i.e. they are treated as numeric tuples and compared
// lexicographically. If the tuple dimensions differ, the smallest tuple is
// zero-extended to match. For example, a `min_version` of 4.5.6.0 (or
// just 4.5.6) will match 4.5.6.0, 4.5.6.1, 4.5.7.0, 4.5.10.0, 4.6.0.0,
// 5.0.0.0, etc. but will not match 4.5.5.99, 4.4.7.0, 3.6.7.1, etc.
//
// If not set, matches all versions. The empty string is not a valid value.
optional string min_version = 2;
// If set to true, Cronet will consider this flag value even if telemetry is
// disabled. By default, flags are NOT applied if telemetry is disabled, to
// avoid "blindly" pushing flags to apps that cannot tell us about
// regressions in Cronet metrics.
//
// Note that in the case of the Cronet API layer, if the app does not
// explicitly opt in or out of telemetry through its manifest, then it is
// not possible to know in advance if telemetry is going to be enabled or
// disabled, because that depends on the source which is not yet known. In
// this case, we use a heuristic where we treat telemetry as disabled if the
// app happens to bundle native Cronet.
//
// Note: this field was introduced in July 2025; older versions of Cronet
// will not honor this flag, and will behave as if it is set to true.
optional bool apply_even_if_cronet_telemetry_disabled = 8;
// If none of these fields are set, the flag is deemed to be unset.
oneof value {
bool bool_value = 3;
int64 int_value = 4;
float float_value = 5;
string string_value = 6;
bytes bytes_value = 7;
}
}
// Each entry in this list is tried in turn, and the first entry to match
// determines the flag value. If no entries match, the flag is deemed to be
// unset.
repeated ConstrainedValue constrained_values = 8;
}
// The format of the HTTP flags file is defined as the binary representation of
// an instance of this proto.
message Flags {
// The key is the name of the flag. For example, "Cronet_log_me".
map<string, FlagValue> flags = 1;
}