Struct gapi_grpc::google::rpc::context::AttributeContext[][src]

pub struct AttributeContext {
    pub origin: Option<Peer>,
    pub source: Option<Peer>,
    pub destination: Option<Peer>,
    pub request: Option<Request>,
    pub response: Option<Response>,
    pub resource: Option<Resource>,
    pub api: Option<Api>,
    pub extensions: Vec<Any>,
}

This message defines the standard attribute vocabulary for Google APIs.

An attribute is a piece of metadata that describes an activity on a network service. For example, the size of an HTTP request, or the status code of an HTTP response.

Each attribute has a type and a name, which is logically defined as a proto message field in AttributeContext. The field type becomes the attribute type, and the field path becomes the attribute name. For example, the attribute source.ip maps to field AttributeContext.source.ip.

This message definition is guaranteed not to have any wire breaking change. So you can use it directly for passing attributes across different systems.

NOTE: Different system may generate different subset of attributes. Please verify the system specification before relying on an attribute generated a system.

Fields

origin: Option<Peer>

The origin of a network activity. In a multi hop network activity, the origin represents the sender of the first hop. For the first hop, the source and the origin must have the same content.

source: Option<Peer>

The source of a network activity, such as starting a TCP connection. In a multi hop network activity, the source represents the sender of the last hop.

destination: Option<Peer>

The destination of a network activity, such as accepting a TCP connection. In a multi hop network activity, the destination represents the receiver of the last hop.

request: Option<Request>

Represents a network request, such as an HTTP request.

response: Option<Response>

Represents a network response, such as an HTTP response.

resource: Option<Resource>

Represents a target resource that is involved with a network activity. If multiple resources are involved with an activity, this must be the primary one.

api: Option<Api>

Represents an API operation that is involved to a network activity.

extensions: Vec<Any>

Supports extensions for advanced use cases, such as logs and metrics.

Trait Implementations

impl Clone for AttributeContext[src]

impl Debug for AttributeContext[src]

impl Default for AttributeContext[src]

impl Message for AttributeContext[src]

impl PartialEq<AttributeContext> for AttributeContext[src]

impl StructuralPartialEq for AttributeContext[src]

Auto Trait Implementations

impl RefUnwindSafe for AttributeContext

impl Send for AttributeContext

impl Sync for AttributeContext

impl Unpin for AttributeContext

impl UnwindSafe for AttributeContext

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T> Instrument for T[src]

impl<T> Instrument for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> IntoRequest<T> for T[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 
[src]

impl<T> WithSubscriber for T[src]