envoy.config.accesslog.v2.file.proto Maven / Gradle / Ivy
syntax = "proto3";
package envoy.config.accesslog.v2;
import "google/protobuf/struct.proto";
import "udpa/annotations/migrate.proto";
import "udpa/annotations/status.proto";
import "validate/validate.proto";
option java_package = "io.envoyproxy.envoy.config.accesslog.v2";
option java_outer_classname = "FileProto";
option java_multiple_files = true;
option go_package = "github.com/envoyproxy/go-control-plane/envoy/config/accesslog/v2;accesslogv2";
option (udpa.annotations.file_migrate).move_to_package = "envoy.extensions.access_loggers.file.v3";
option (udpa.annotations.file_status).package_version_status = FROZEN;
// [#protodoc-title: File access log]
// [#extension: envoy.access_loggers.file]
// Custom configuration for an :ref:`AccessLog `
// that writes log entries directly to a file. Configures the built-in *envoy.access_loggers.file*
// AccessLog.
message FileAccessLog {
// A path to a local file to which to write the access log entries.
string path = 1 [(validate.rules).string = {min_bytes: 1}];
oneof access_log_format {
// Access log :ref:`format string`.
// Envoy supports :ref:`custom access log formats ` as well as a
// :ref:`default format `.
string format = 2;
// Access log :ref:`format dictionary`. All values
// are rendered as strings.
google.protobuf.Struct json_format = 3;
// Access log :ref:`format dictionary`. Values are
// rendered as strings, numbers, or boolean values as appropriate. Nested JSON objects may
// be produced by some command operators (e.g.FILTER_STATE or DYNAMIC_METADATA). See the
// documentation for a specific command operator for details.
google.protobuf.Struct typed_json_format = 4;
}
}