envoy.extensions.access_loggers.file.v3.file.proto Maven / Gradle / Ivy
syntax = "proto3";
package envoy.extensions.access_loggers.file.v3;
import "envoy/config/core/v3/substitution_format_string.proto";
import "google/protobuf/struct.proto";
import "envoy/annotations/deprecation.proto";
import "udpa/annotations/status.proto";
import "udpa/annotations/versioning.proto";
import "validate/validate.proto";
option java_package = "io.envoyproxy.envoy.extensions.access_loggers.file.v3";
option java_outer_classname = "FileProto";
option java_multiple_files = true;
option go_package = "github.com/envoyproxy/go-control-plane/envoy/extensions/access_loggers/file/v3;filev3";
option (udpa.annotations.file_status).package_version_status = ACTIVE;
// [#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.
// [#next-free-field: 6]
message FileAccessLog {
option (udpa.annotations.versioning).previous_message_type =
"envoy.config.accesslog.v2.FileAccessLog";
// A path to a local file to which to write the access log entries.
string path = 1 [(validate.rules).string = {min_len: 1}];
oneof access_log_format {
// Access log :ref:`format string`.
// Envoy supports :ref:`custom access log formats ` as well as a
// :ref:`default format `.
// This field is deprecated.
// Please use :ref:`log_format `.
string format = 2 [deprecated = true, (envoy.annotations.deprecated_at_minor_version) = "3.0"];
// Access log :ref:`format dictionary`. All values
// are rendered as strings.
// This field is deprecated.
// Please use :ref:`log_format `.
google.protobuf.Struct json_format = 3
[deprecated = true, (envoy.annotations.deprecated_at_minor_version) = "3.0"];
// 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.
// This field is deprecated.
// Please use :ref:`log_format `.
google.protobuf.Struct typed_json_format = 4
[deprecated = true, (envoy.annotations.deprecated_at_minor_version) = "3.0"];
// Configuration to form access log data and format.
// If not specified, use :ref:`default format `.
config.core.v3.SubstitutionFormatString log_format = 5
[(validate.rules).message = {required: true}];
}
}