Index
- AttributeContext(message)
- AttributeContext.Api(message)
- AttributeContext.Auth(message)
- AttributeContext.Peer(message)
- AttributeContext.Request(message)
- AttributeContext.Resource(message)
- AttributeContext.Response(message)
AttributeContext
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 | 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 | 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 | 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 | Represents a network request, such as an HTTP request. | 
| response | Represents a network response, such as an HTTP response. | 
| 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 | Represents an API operation that is involved to a network activity. | 
| extensions[] | Supports extensions for advanced use cases, such as logs and metrics. | 
Api
This message defines attributes associated with API operations, such as a network API request. The terminology is based on the conventions used by Google APIs, Istio, and OpenAPI.
| Fields | |
|---|---|
| service | 
 The API service name. It is a logical identifier for a networked API, such as "pubsub.googleapis.com". The naming syntax depends on the API management system being used for handling the request. | 
| operation | 
 The API operation name. For gRPC requests, it is the fully qualified API method name, such as "google.pubsub.v1.Publisher.Publish". For OpenAPI requests, it is the  | 
| protocol | 
 The API protocol used for sending the request, such as "http", "https", "grpc", or "internal". | 
| version | 
 The API version associated with the API operation above, such as "v1" or "v1alpha1". | 
Auth
This message defines request authentication attributes. Terminology is based on the JSON Web Token (JWT) standard, but the terms also correlate to concepts in other standards.
| Fields | |
|---|---|
| principal | 
 The authenticated principal. Reflects the issuer ( | 
| audiences[] | 
 The intended audience(s) for this authentication information. Reflects the audience ( 
 Consult the documentation for the credential issuer to determine the information provided. | 
| presenter | 
 The authorized presenter of the credential. Reflects the optional Authorized Presenter ( | 
| claims | Structured claims presented with the credential. JWTs include  {'iss': 'accounts.google.com', 'sub': '113289723416554971153', 'aud': ['123456789012', 'pubsub.googleapis.com'], 'azp': '123456789012.apps.googleusercontent.com', 'email': 'jsmith@example.com', 'iat': 1353601026, 'exp': 1353604926} SAML assertions are similarly specified, but with an identity provider dependent structure. | 
| access_levels[] | 
 A list of access level resource names that allow resources to be accessed by authenticated requester. It is part of Secure GCP processing for the incoming request. An access level string has the format: "//{api_service_name}/accessPolicies/{policy_id}/accessLevels/{short_name}" Example: "//accesscontextmanager.googleapis.com/accessPolicies/MY_POLICY_ID/accessLevels/MY_LEVEL" | 
Peer
This message defines attributes for a node that handles a network request. The node can be either a service or an application that sends, forwards, or receives the request. Service peers should fill in principal and labels as appropriate.
| Fields | |
|---|---|
| ip | 
 The IP address of the peer. | 
| port | 
 The network port of the peer. | 
| labels | 
 The labels associated with the peer. | 
| principal | 
 The identity of this peer. Similar to  | 
| region_code | 
 The CLDR country/region code associated with the above IP address. If the IP address is private, the  | 
Request
This message defines attributes for an HTTP request. If the actual request is not an HTTP request, the runtime system should try to map the actual request to an equivalent HTTP request.
| Fields | |
|---|---|
| id | 
 The unique ID for a request, which can be propagated to downstream systems. The ID should have low probability of collision within a single day for a specific service. | 
| method | 
 The HTTP request method, such as  | 
| headers | 
 The HTTP request headers. If multiple headers share the same key, they must be merged according to the HTTP spec. All header keys must be lowercased, because HTTP header keys are case-insensitive. | 
| path | 
 The HTTP URL path. | 
| host | 
 The HTTP request  | 
| scheme | 
 The HTTP URL scheme, such as  | 
| query | 
 The HTTP URL query in the format of  | 
| time | The timestamp when the  | 
| size | 
 The HTTP request size in bytes. If unknown, it must be -1. | 
| protocol | 
 The network protocol used with the request, such as "http/1.1", "spdy/3", "h2", "h2c", "webrtc", "tcp", "udp", "quic". See https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids for details. | 
| reason | 
 A special parameter for request reason. It is used by security systems to associate auditing information with a request. | 
| auth | The request authentication. May be absent for unauthenticated requests. Derived from the HTTP request  | 
Resource
This message defines core attributes for a resource. A resource is an addressable (named) entity provided by the destination service. For example, a file stored on a network storage service.
| Fields | |
|---|---|
| service | 
 The name of the service that this resource belongs to, such as  | 
| name | 
 The stable identifier (name) of a resource on the  
 See https://cloud.google.com/apis/design/resource_names for details. | 
| type | 
 The type of the resource. The syntax is platform-specific because different platforms define their resources differently. For Google APIs, the type format must be "{service}/{kind}". | 
| labels | 
 The labels or tags on the resource, such as AWS resource tags and Kubernetes resource labels. | 
| uid | 
 The unique identifier of the resource. UID is unique in the time and space for this resource within the scope of the service. It is typically generated by the server on successful creation of a resource and must not be changed. UID is used to uniquely identify resources with resource name reuses. This should be a UUID4. | 
| annotations | 
 Annotations is an unstructured key-value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata. They are not queryable and should be preserved when modifying objects. More info: https://kubernetes.io/docs/user-guide/annotations | 
| display_name | 
 Mutable. The display name set by clients. Must be <= 63 characters. | 
| create_time | Output only. The timestamp when the resource was created. This may be either the time creation was initiated or when it was completed. | 
| update_time | Output only. The timestamp when the resource was last updated. Any change to the resource made by users must refresh this value. Changes to a resource made by the service should refresh this value. | 
| delete_time | Output only. The timestamp when the resource was deleted. If the resource is not deleted, this must be empty. | 
| etag | 
 Output only. An opaque value that uniquely identifies a version or generation of a resource. It can be used to confirm that the client and server agree on the ordering of a resource being written. | 
| location | 
 Immutable. The location of the resource. The location encoding is specific to the service provider, and new encoding may be introduced as the service evolves. For Google Cloud products, the encoding is what is used by Google Cloud APIs, such as  | 
Response
This message defines attributes for a typical network response. It generally models semantics of an HTTP response.
| Fields | |
|---|---|
| code | 
 The HTTP response status code, such as  | 
| size | 
 The HTTP response size in bytes. If unknown, it must be -1. | 
| headers | 
 The HTTP response headers. If multiple headers share the same key, they must be merged according to HTTP spec. All header keys must be lowercased, because HTTP header keys are case-insensitive. | 
| time | The timestamp when the  |