syntax = "proto3"; package envoy.data.tap.v3; import "envoy/config/core/v3/address.proto"; import "envoy/data/tap/v3/common.proto"; import "google/protobuf/timestamp.proto"; import "udpa/annotations/versioning.proto"; option java_package = "io.envoyproxy.envoy.data.tap.v3"; option java_outer_classname = "TransportProto"; option java_multiple_files = true; // [#protodoc-title: Transport tap data] // Trace format for the tap transport socket extension. This dumps plain text read/write // sequences on a socket. // Connection properties. message Connection { option (udpa.annotations.versioning).previous_message_type = "envoy.data.tap.v2alpha.Connection"; // Local address. config.core.v3.Address local_address = 2; // Remote address. config.core.v3.Address remote_address = 3; } // Event in a socket trace. message SocketEvent { option (udpa.annotations.versioning).previous_message_type = "envoy.data.tap.v2alpha.SocketEvent"; // Data read by Envoy from the transport socket. message Read { // TODO(htuch): Half-close for reads. option (udpa.annotations.versioning).previous_message_type = "envoy.data.tap.v2alpha.SocketEvent.Read"; // Binary data read. Body data = 1; } // Data written by Envoy to the transport socket. message Write { option (udpa.annotations.versioning).previous_message_type = "envoy.data.tap.v2alpha.SocketEvent.Write"; // Binary data written. Body data = 1; // Stream was half closed after this write. bool end_stream = 2; } // The connection was closed. message Closed { // TODO(mattklein123): Close event type. option (udpa.annotations.versioning).previous_message_type = "envoy.data.tap.v2alpha.SocketEvent.Closed"; } // Timestamp for event. google.protobuf.Timestamp timestamp = 1; // Read or write with content as bytes string. oneof event_selector { Read read = 2; Write write = 3; Closed closed = 4; } } // Sequence of read/write events that constitute a buffered trace on a socket. // [#next-free-field: 6] message SocketBufferedTrace { option (udpa.annotations.versioning).previous_message_type = "envoy.data.tap.v2alpha.SocketBufferedTrace"; // Trace ID unique to the originating Envoy only. Trace IDs can repeat and should not be used // for long term stable uniqueness. Matches connection IDs used in Envoy logs. uint64 trace_id = 1; // Connection properties. Connection connection = 2; // Sequence of observed events. repeated SocketEvent events = 3; // Set to true if read events were truncated due to the :ref:`max_buffered_rx_bytes // ` setting. bool read_truncated = 4; // Set to true if write events were truncated due to the :ref:`max_buffered_tx_bytes // ` setting. bool write_truncated = 5; } // A streamed socket trace segment. Multiple segments make up a full trace. message SocketStreamedTraceSegment { option (udpa.annotations.versioning).previous_message_type = "envoy.data.tap.v2alpha.SocketStreamedTraceSegment"; // Trace ID unique to the originating Envoy only. Trace IDs can repeat and should not be used // for long term stable uniqueness. Matches connection IDs used in Envoy logs. uint64 trace_id = 1; oneof message_piece { // Connection properties. Connection connection = 2; // Socket event. SocketEvent event = 3; } }