aboutsummaryrefslogtreecommitdiffhomepage
path: root/third_party/googleapis/google/devtools/cloudtrace/v1/trace.proto
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/googleapis/google/devtools/cloudtrace/v1/trace.proto')
-rw-r--r--third_party/googleapis/google/devtools/cloudtrace/v1/trace.proto220
1 files changed, 220 insertions, 0 deletions
diff --git a/third_party/googleapis/google/devtools/cloudtrace/v1/trace.proto b/third_party/googleapis/google/devtools/cloudtrace/v1/trace.proto
new file mode 100644
index 0000000000..7344e47d0c
--- /dev/null
+++ b/third_party/googleapis/google/devtools/cloudtrace/v1/trace.proto
@@ -0,0 +1,220 @@
+// Copyright 2016 Google Inc.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+syntax = "proto3";
+
+package google.devtools.cloudtrace.v1;
+
+import "google/api/annotations.proto";
+import "google/protobuf/empty.proto";
+import "google/protobuf/timestamp.proto";
+
+option csharp_namespace = "Google.Cloud.Trace.V1";
+option go_package = "google.golang.org/genproto/googleapis/devtools/cloudtrace/v1;cloudtrace";
+option java_multiple_files = true;
+option java_outer_classname = "TraceProto";
+option java_package = "com.google.devtools.cloudtrace.v1";
+
+
+// This file describes an API for collecting and viewing traces and spans
+// within a trace. A Trace is a collection of spans corresponding to a single
+// operation or set of operations for an application. A span is an individual
+// timed event which forms a node of the trace tree. Spans for a single trace
+// may span multiple services.
+service TraceService {
+ // Returns of a list of traces that match the specified filter conditions.
+ rpc ListTraces(ListTracesRequest) returns (ListTracesResponse) {
+ option (google.api.http) = { get: "/v1/projects/{project_id}/traces" };
+ }
+
+ // Gets a single trace by its ID.
+ rpc GetTrace(GetTraceRequest) returns (Trace) {
+ option (google.api.http) = { get: "/v1/projects/{project_id}/traces/{trace_id}" };
+ }
+
+ // Sends new traces to Stackdriver Trace or updates existing traces. If the ID
+ // of a trace that you send matches that of an existing trace, any fields
+ // in the existing trace and its spans are overwritten by the provided values,
+ // and any new fields provided are merged with the existing trace data. If the
+ // ID does not match, a new trace is created.
+ rpc PatchTraces(PatchTracesRequest) returns (google.protobuf.Empty) {
+ option (google.api.http) = { patch: "/v1/projects/{project_id}/traces" body: "traces" };
+ }
+}
+
+// A trace describes how long it takes for an application to perform an
+// operation. It consists of a set of spans, each of which represent a single
+// timed event within the operation.
+message Trace {
+ // Project ID of the Cloud project where the trace data is stored.
+ string project_id = 1;
+
+ // Globally unique identifier for the trace. This identifier is a 128-bit
+ // numeric value formatted as a 32-byte hex string.
+ string trace_id = 2;
+
+ // Collection of spans in the trace.
+ repeated TraceSpan spans = 3;
+}
+
+// List of new or updated traces.
+message Traces {
+ // List of traces.
+ repeated Trace traces = 1;
+}
+
+// A span represents a single timed event within a trace. Spans can be nested
+// and form a trace tree. Often, a trace contains a root span that describes the
+// end-to-end latency of an operation and, optionally, one or more subspans for
+// its suboperations. Spans do not need to be contiguous. There may be gaps
+// between spans in a trace.
+message TraceSpan {
+ // Type of span. Can be used to specify additional relationships between spans
+ // in addition to a parent/child relationship.
+ enum SpanKind {
+ // Unspecified.
+ SPAN_KIND_UNSPECIFIED = 0;
+
+ // Indicates that the span covers server-side handling of an RPC or other
+ // remote network request.
+ RPC_SERVER = 1;
+
+ // Indicates that the span covers the client-side wrapper around an RPC or
+ // other remote request.
+ RPC_CLIENT = 2;
+ }
+
+ // Identifier for the span. Must be a 64-bit integer other than 0 and
+ // unique within a trace.
+ fixed64 span_id = 1;
+
+ // Distinguishes between spans generated in a particular context. For example,
+ // two spans with the same name may be distinguished using `RPC_CLIENT`
+ // and `RPC_SERVER` to identify queueing latency associated with the span.
+ SpanKind kind = 2;
+
+ // Name of the trace. The trace name is sanitized and displayed in the
+ // Stackdriver Trace tool in the Google Developers Console.
+ // The name may be a method name or some other per-call site name.
+ // For the same executable and the same call point, a best practice is
+ // to use a consistent name, which makes it easier to correlate
+ // cross-trace spans.
+ string name = 3;
+
+ // Start time of the span in nanoseconds from the UNIX epoch.
+ google.protobuf.Timestamp start_time = 4;
+
+ // End time of the span in nanoseconds from the UNIX epoch.
+ google.protobuf.Timestamp end_time = 5;
+
+ // ID of the parent span, if any. Optional.
+ fixed64 parent_span_id = 6;
+
+ // Collection of labels associated with the span.
+ map<string, string> labels = 7;
+}
+
+// The request message for the `ListTraces` method. All fields are required
+// unless specified.
+message ListTracesRequest {
+ // Type of data returned for traces in the list.
+ enum ViewType {
+ // Default is `MINIMAL` if unspecified.
+ VIEW_TYPE_UNSPECIFIED = 0;
+
+ // Minimal view of the trace record that contains only the project
+ // and trace IDs.
+ MINIMAL = 1;
+
+ // Root span view of the trace record that returns the root spans along
+ // with the minimal trace data.
+ ROOTSPAN = 2;
+
+ // Complete view of the trace record that contains the actual trace data.
+ // This is equivalent to calling the REST `get` or RPC `GetTrace` method
+ // using the ID of each listed trace.
+ COMPLETE = 3;
+ }
+
+ // ID of the Cloud project where the trace data is stored.
+ string project_id = 1;
+
+ // Type of data returned for traces in the list. Optional. Default is
+ // `MINIMAL`.
+ ViewType view = 2;
+
+ // Maximum number of traces to return. If not specified or <= 0, the
+ // implementation selects a reasonable value. The implementation may
+ // return fewer traces than the requested page size. Optional.
+ int32 page_size = 3;
+
+ // Token identifying the page of results to return. If provided, use the
+ // value of the `next_page_token` field from a previous request. Optional.
+ string page_token = 4;
+
+ // End of the time interval (inclusive) during which the trace data was
+ // collected from the application.
+ google.protobuf.Timestamp start_time = 5;
+
+ // Start of the time interval (inclusive) during which the trace data was
+ // collected from the application.
+ google.protobuf.Timestamp end_time = 6;
+
+ // An optional filter for the request.
+ string filter = 7;
+
+ // Field used to sort the returned traces. Optional.
+ // Can be one of the following:
+ //
+ // * `trace_id`
+ // * `name` (`name` field of root span in the trace)
+ // * `duration` (difference between `end_time` and `start_time` fields of
+ // the root span)
+ // * `start` (`start_time` field of the root span)
+ //
+ // Descending order can be specified by appending `desc` to the sort field
+ // (for example, `name desc`).
+ //
+ // Only one sort field is permitted.
+ string order_by = 8;
+}
+
+// The response message for the `ListTraces` method.
+message ListTracesResponse {
+ // List of trace records returned.
+ repeated Trace traces = 1;
+
+ // If defined, indicates that there are more traces that match the request
+ // and that this value should be passed to the next request to continue
+ // retrieving additional traces.
+ string next_page_token = 2;
+}
+
+// The request message for the `GetTrace` method.
+message GetTraceRequest {
+ // ID of the Cloud project where the trace data is stored.
+ string project_id = 1;
+
+ // ID of the trace to return.
+ string trace_id = 2;
+}
+
+// The request message for the `PatchTraces` method.
+message PatchTracesRequest {
+ // ID of the Cloud project where the trace data is stored.
+ string project_id = 1;
+
+ // The body of the message.
+ Traces traces = 2;
+}