2017-05-11 14:39:54 +00:00
// Package tracing provides access to the Google Tracing API.
//
// See https://cloud.google.com/trace
//
// Usage example:
//
// import "google.golang.org/api/tracing/v2"
// ...
// tracingService, err := tracing.New(oauthHttpClient)
package tracing // import "google.golang.org/api/tracing/v2"
import (
"bytes"
"encoding/json"
"errors"
"fmt"
context "golang.org/x/net/context"
ctxhttp "golang.org/x/net/context/ctxhttp"
gensupport "google.golang.org/api/gensupport"
googleapi "google.golang.org/api/googleapi"
"io"
"net/http"
"net/url"
"strconv"
"strings"
)
// Always reference these packages, just in case the auto-generated code
// below doesn't.
var _ = bytes . NewBuffer
var _ = strconv . Itoa
var _ = fmt . Sprintf
var _ = json . NewDecoder
var _ = io . Copy
var _ = url . Parse
var _ = gensupport . MarshalJSON
var _ = googleapi . Version
var _ = errors . New
var _ = strings . Replace
var _ = context . Canceled
var _ = ctxhttp . Do
const apiId = "tracing:v2"
const apiName = "tracing"
const apiVersion = "v2"
const basePath = "https://tracing.googleapis.com/"
// OAuth2 scopes used by this API.
const (
// View and manage your data across Google Cloud Platform services
CloudPlatformScope = "https://www.googleapis.com/auth/cloud-platform"
// Write Trace data for a project or application
TraceAppendScope = "https://www.googleapis.com/auth/trace.append"
// Read Trace data for a project or application
TraceReadonlyScope = "https://www.googleapis.com/auth/trace.readonly"
)
func New ( client * http . Client ) ( * Service , error ) {
if client == nil {
return nil , errors . New ( "client is nil" )
}
s := & Service { client : client , BasePath : basePath }
s . Projects = NewProjectsService ( s )
return s , nil
}
type Service struct {
client * http . Client
BasePath string // API endpoint base URL
UserAgent string // optional additional User-Agent fragment
Projects * ProjectsService
}
func ( s * Service ) userAgent ( ) string {
if s . UserAgent == "" {
return googleapi . UserAgent
}
return googleapi . UserAgent + " " + s . UserAgent
}
func NewProjectsService ( s * Service ) * ProjectsService {
rs := & ProjectsService { s : s }
rs . Traces = NewProjectsTracesService ( s )
return rs
}
type ProjectsService struct {
s * Service
Traces * ProjectsTracesService
}
func NewProjectsTracesService ( s * Service ) * ProjectsTracesService {
rs := & ProjectsTracesService { s : s }
rs . Spans = NewProjectsTracesSpansService ( s )
return rs
}
type ProjectsTracesService struct {
s * Service
Spans * ProjectsTracesSpansService
}
func NewProjectsTracesSpansService ( s * Service ) * ProjectsTracesSpansService {
rs := & ProjectsTracesSpansService { s : s }
return rs
}
type ProjectsTracesSpansService struct {
s * Service
}
// Annotation: Text annotation with a set of attributes. A maximum of 32
// annotations are
// allowed per Span.
type Annotation struct {
// Attributes: A set of attributes on the annotation. A maximum of 4
// attributes are
// allowed per Annotation.
Attributes * Attributes ` json:"attributes,omitempty" `
// Description: A user-supplied message describing the event. The
// maximum length for
// the description is 256 bytes.
Description * TruncatableString ` json:"description,omitempty" `
// ForceSendFields is a list of field names (e.g. "Attributes") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "Attributes") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Annotation ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Annotation
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// AttributeValue: The allowed types for the value side of an attribute
// key:value pair.
type AttributeValue struct {
// BoolValue: A boolean value.
BoolValue bool ` json:"boolValue,omitempty" `
// IntValue: An integer value.
IntValue int64 ` json:"intValue,omitempty,string" `
// StringValue: A string value (up to 256 bytes).
StringValue * TruncatableString ` json:"stringValue,omitempty" `
// ForceSendFields is a list of field names (e.g. "BoolValue") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "BoolValue") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * AttributeValue ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod AttributeValue
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Attributes: Attributes of a span with a key:value format.
type Attributes struct {
// AttributeMap: The maximum key length is 128 bytes (attributes are
// dropped if the
// key size is larger than the maximum allowed). The value can be a
// string
// (up to 256 bytes), integer, or boolean (true/false). Some common
// pair
// examples:
//
// "/instance_id": "my-instance"
// "/zone": "us-central1-a"
// "/grpc/peer_address": "ip:port" (dns, etc.)
// "/grpc/deadline": "Duration"
// "/http/user_agent"
// "/http/request_bytes": 300
// "/http/response_bytes": 1200
// "/http/url": google.com/apis
// "abc.com/myattribute": true
AttributeMap map [ string ] AttributeValue ` json:"attributeMap,omitempty" `
// DroppedAttributesCount: The number of dropped attributes after the
// maximum size was enforced. If
// 0 then no attributes were dropped.
DroppedAttributesCount int64 ` json:"droppedAttributesCount,omitempty" `
// ForceSendFields is a list of field names (e.g. "AttributeMap") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "AttributeMap") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Attributes ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Attributes
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// BatchWriteSpansRequest: The request message for the `BatchWriteSpans`
// method.
type BatchWriteSpansRequest struct {
// Spans: A collection of spans.
Spans [ ] * Span ` json:"spans,omitempty" `
// ForceSendFields is a list of field names (e.g. "Spans") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "Spans") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * BatchWriteSpansRequest ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod BatchWriteSpansRequest
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Empty: A generic empty message that you can re-use to avoid defining
// duplicated
// empty messages in your APIs. A typical example is to use it as the
// request
// or the response type of an API method. For instance:
//
// service Foo {
// rpc Bar(google.protobuf.Empty) returns
// (google.protobuf.Empty);
// }
//
// The JSON representation for `Empty` is empty JSON object `{}`.
type Empty struct {
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi . ServerResponse ` json:"-" `
}
// Link: A pointer from this span to another span in a different `Trace`
// within
// the same service project or within a different service project.
// Used
// (for example) in batching operations, where a single batch
// handler
// processes multiple requests from different traces or when receives
// a
// request from a different service project.
type Link struct {
// SpanId: `SPAN_ID` is a unique identifier for a span within a trace.
// It is a
// base16-encoded, case-insensitive string of a 8-bytes array and
// is
// required to be 16 char long.
SpanId string ` json:"spanId,omitempty" `
// TraceId: `TRACE_ID` is a unique identifier for a trace within a
// project. It is
// a base16-encoded, case-insensitive string of a 16-bytes array and
// is
// required to be 32 char long.
TraceId string ` json:"traceId,omitempty" `
// Type: The relationship of the current span relative to the linked
// span.
//
// Possible values:
// "TYPE_UNSPECIFIED" - The relationship of the two spans is unknown.
// "CHILD" - The current span is a child of the linked span.
// "PARENT" - The current span is the parent of the linked span.
Type string ` json:"type,omitempty" `
// ForceSendFields is a list of field names (e.g. "SpanId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "SpanId") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Link ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Link
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Links: A collection of links, which are references from this span to
// a span
// in the same or different trace.
type Links struct {
// DroppedLinksCount: The number of dropped links after the maximum size
// was enforced. If
// 0 then no links were dropped.
DroppedLinksCount int64 ` json:"droppedLinksCount,omitempty" `
// Link: A collection of links.
Link [ ] * Link ` json:"link,omitempty" `
// ForceSendFields is a list of field names (e.g. "DroppedLinksCount")
// to unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "DroppedLinksCount") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Links ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Links
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// ListSpansResponse: The response message for the `ListSpans` method.
type ListSpansResponse struct {
// NextPageToken: If defined, indicates that there are more spans that
// match the request.
// Pass this as the value of `pageToken` in a subsequent request to
// retrieve
// additional spans.
NextPageToken string ` json:"nextPageToken,omitempty" `
// Spans: The requested spans if there are any in the specified trace.
Spans [ ] * Span ` json:"spans,omitempty" `
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi . ServerResponse ` json:"-" `
// ForceSendFields is a list of field names (e.g. "NextPageToken") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "NextPageToken") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * ListSpansResponse ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod ListSpansResponse
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// ListTracesResponse: The response message for the `ListTraces` method.
type ListTracesResponse struct {
// NextPageToken: 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.
NextPageToken string ` json:"nextPageToken,omitempty" `
// Traces: List of trace records returned.
Traces [ ] * Trace ` json:"traces,omitempty" `
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi . ServerResponse ` json:"-" `
// ForceSendFields is a list of field names (e.g. "NextPageToken") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "NextPageToken") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * ListTracesResponse ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod ListTracesResponse
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Module: Binary module.
type Module struct {
// BuildId: Build_id is a unique identifier for the module, usually a
// hash of its
// contents (up to 128 characters).
BuildId * TruncatableString ` json:"buildId,omitempty" `
// Module: E.g. main binary, kernel modules, and dynamic libraries
// such as libc.so, sharedlib.so (up to 256 characters).
Module * TruncatableString ` json:"module,omitempty" `
// ForceSendFields is a list of field names (e.g. "BuildId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "BuildId") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Module ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Module
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// NetworkEvent: An event describing an RPC message sent/received on the
// network. A
// maximum of 128 network events are allowed per Span.
type NetworkEvent struct {
// MessageId: An identifier for the message, which must be unique in
// this span.
MessageId uint64 ` json:"messageId,omitempty,string" `
// MessageSize: The number of bytes sent or received.
MessageSize uint64 ` json:"messageSize,omitempty,string" `
// Time: If available, this is the kernel time:
//
// * For sent messages, this is the time at which the first bit was
// sent.
// * For received messages, this is the time at which the last bit was
// received.
Time string ` json:"time,omitempty" `
// Type: Type of NetworkEvent. Indicates whether the RPC message was
// sent or
// received.
//
// Possible values:
// "TYPE_UNSPECIFIED" - Unknown event type.
// "SENT" - Indicates a sent RPC message.
// "RECV" - Indicates a received RPC message.
Type string ` json:"type,omitempty" `
// ForceSendFields is a list of field names (e.g. "MessageId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "MessageId") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * NetworkEvent ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod NetworkEvent
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Span: A span represents a single operation within a trace. Spans can
// be nested
// to form a trace tree. Often, a trace contains a root span
// that
// describes the end-to-end latency and, optionally, one or more
// subspans for
// its sub-operations. (A trace could alternatively contain multiple
// root spans,
// or none at all.) Spans do not need to be contiguous. There may be
// gaps
// and/or overlaps between spans in a trace.
type Span struct {
// Attributes: A set of attributes on the span. A maximum of 32
// attributes are allowed per
// Span.
Attributes * Attributes ` json:"attributes,omitempty" `
// DisplayName: Description of the operation in the span. It is
// sanitized and displayed in
// the Stackdriver Trace tool in the
// {% dynamic print site_values.console_name %}.
// The display_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 operation name, which makes it easier to
// correlate
// cross-trace spans.
// The maximum length for the display_name is 128 bytes.
DisplayName * TruncatableString ` json:"displayName,omitempty" `
// EndTime: End time of the span.
// On the client side, this is the local machine clock time at which the
// span
// execution was ended; on the server
// side, this is the time at which the server application handler
// stopped
// running.
EndTime string ` json:"endTime,omitempty" `
// Links: A maximum of 128 links are allowed per Span.
Links * Links ` json:"links,omitempty" `
// Name: The resource name of Span in the
// format
// `projects/PROJECT_ID/traces/TRACE_ID/spans/SPAN_ID`.
// `TRACE_ID`
// is a unique identifier for a trace within a project and is
// a
// base16-encoded, case-insensitive string and is required to be 32 char
// long.
// `SPAN_ID` is a unique identifier for a span within a trace. It is
// a
// base 16-encoded, case-insensitive string of a 8-bytes array and is
// required
// to be 16 char long.
Name string ` json:"name,omitempty" `
// ParentSpanId: ID of parent span which is a base 16-encoded,
// case-insensitive string of
// a 8-bytes array and is required to be 16 char long. If this is a root
// span,
// the value must be empty.
ParentSpanId string ` json:"parentSpanId,omitempty" `
// SpanId: Unique identifier for a span within a trace. It is a base
// 16-encoded,
// case-insensitive string of a 8-bytes array and is required.
SpanId string ` json:"spanId,omitempty" `
// StackTrace: Stack trace captured at the start of the span.
StackTrace * StackTrace ` json:"stackTrace,omitempty" `
// StartTime: Start time of the span.
// On the client side, this is the local machine clock time at which the
// span
// execution was started; on the server
// side, this is the time at which the server application handler
// started
// running.
StartTime string ` json:"startTime,omitempty" `
// Status: An optional final status for this span.
Status * Status ` json:"status,omitempty" `
// TimeEvents: A maximum of 32 annotations and 128 network events are
// allowed per Span.
TimeEvents * TimeEvents ` json:"timeEvents,omitempty" `
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi . ServerResponse ` json:"-" `
// ForceSendFields is a list of field names (e.g. "Attributes") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "Attributes") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Span ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Span
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// StackFrame: Represents a single stack frame in a stack trace.
type StackFrame struct {
// ColumnNumber: Column number is important in JavaScript (anonymous
// functions).
// May not be available in some languages.
ColumnNumber int64 ` json:"columnNumber,omitempty,string" `
// FileName: The filename of the file containing this frame (up to 256
// characters).
FileName * TruncatableString ` json:"fileName,omitempty" `
// FunctionName: The fully-qualified name that uniquely identifies this
// function or
// method (up to 1024 characters).
FunctionName * TruncatableString ` json:"functionName,omitempty" `
// LineNumber: Line number of the frame.
LineNumber int64 ` json:"lineNumber,omitempty,string" `
// LoadModule: Binary module the code is loaded from.
LoadModule * Module ` json:"loadModule,omitempty" `
// OriginalFunctionName: Used when the function name
// is
// [mangled](http://www.avabodh.com/cxxin/namemangling.html). May
// be
// fully-qualified (up to 1024 characters).
OriginalFunctionName * TruncatableString ` json:"originalFunctionName,omitempty" `
// SourceVersion: The version of the deployed source code (up to 128
// characters).
SourceVersion * TruncatableString ` json:"sourceVersion,omitempty" `
// ForceSendFields is a list of field names (e.g. "ColumnNumber") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "ColumnNumber") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * StackFrame ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod StackFrame
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// StackFrames: Represents collection of StackFrames that can be
// truncated.
type StackFrames struct {
// DroppedFramesCount: The number of dropped stack frames after the
// maximum size was enforced.
// If 0 then no frames were dropped.
DroppedFramesCount int64 ` json:"droppedFramesCount,omitempty" `
// Frame: Stack frames in this stack trace.
Frame [ ] * StackFrame ` json:"frame,omitempty" `
// ForceSendFields is a list of field names (e.g. "DroppedFramesCount")
// to unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "DroppedFramesCount") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields [ ] string ` json:"-" `
}
func ( s * StackFrames ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod StackFrames
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// StackTrace: StackTrace collected in a trace.
type StackTrace struct {
// StackFrames: Stack frames in this stack trace. A maximum of 128
// frames are allowed.
StackFrames * StackFrames ` json:"stackFrames,omitempty" `
// StackTraceHashId: The hash ID is used to conserve network bandwidth
// for duplicate
// stack traces within a single trace.
//
// Often multiple spans will have identical stack traces.
2017-07-23 07:51:42 +00:00
// The first occurrence of a stack trace should contain both
2017-05-11 14:39:54 +00:00
// the
// `stackFrame` content and a value in `stackTraceHashId`.
//
// Subsequent spans within the same request can refer
// to that stack trace by only setting `stackTraceHashId`.
StackTraceHashId uint64 ` json:"stackTraceHashId,omitempty,string" `
// ForceSendFields is a list of field names (e.g. "StackFrames") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "StackFrames") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * StackTrace ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod StackTrace
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Status: The `Status` type defines a logical error model that is
// suitable for different
// programming environments, including REST APIs and RPC APIs. It is
// used by
// [gRPC](https://github.com/grpc). The error model is designed to
// be:
//
// - Simple to use and understand for most users
// - Flexible enough to meet unexpected needs
//
// # Overview
//
// The `Status` message contains three pieces of data: error code, error
// message,
// and error details. The error code should be an enum value
// of
// google.rpc.Code, but it may accept additional error codes if needed.
// The
// error message should be a developer-facing English message that
// helps
// developers *understand* and *resolve* the error. If a localized
// user-facing
// error message is needed, put the localized message in the error
// details or
// localize it in the client. The optional error details may contain
// arbitrary
// information about the error. There is a predefined set of error
// detail types
2017-07-23 07:51:42 +00:00
// in the package `google.rpc` that can be used for common error
2017-05-11 14:39:54 +00:00
// conditions.
//
// # Language mapping
//
// The `Status` message is the logical representation of the error
// model, but it
// is not necessarily the actual wire format. When the `Status` message
// is
// exposed in different client libraries and different wire protocols,
// it can be
// mapped differently. For example, it will likely be mapped to some
// exceptions
// in Java, but more likely mapped to some error codes in C.
//
// # Other uses
//
// The error model and the `Status` message can be used in a variety
// of
// environments, either with or without APIs, to provide a
// consistent developer experience across different
// environments.
//
// Example uses of this error model include:
//
// - Partial errors. If a service needs to return partial errors to the
// client,
// it may embed the `Status` in the normal response to indicate the
// partial
// errors.
//
// - Workflow errors. A typical workflow has multiple steps. Each step
// may
2017-07-23 07:51:42 +00:00
// have a `Status` message for error reporting.
2017-05-11 14:39:54 +00:00
//
// - Batch operations. If a client uses batch request and batch
// response, the
// `Status` message should be used directly inside batch response,
// one for
// each error sub-response.
//
// - Asynchronous operations. If an API call embeds asynchronous
// operation
// results in its response, the status of those operations should
// be
// represented directly using the `Status` message.
//
// - Logging. If some API errors are stored in logs, the message
// `Status` could
// be used directly after any stripping needed for security/privacy
// reasons.
type Status struct {
// Code: The status code, which should be an enum value of
// google.rpc.Code.
Code int64 ` json:"code,omitempty" `
// Details: A list of messages that carry the error details. There will
// be a
// common set of message types for APIs to use.
Details [ ] googleapi . RawMessage ` json:"details,omitempty" `
// Message: A developer-facing error message, which should be in
// English. Any
// user-facing error message should be localized and sent in
// the
// google.rpc.Status.details field, or localized by the client.
Message string ` json:"message,omitempty" `
// ForceSendFields is a list of field names (e.g. "Code") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "Code") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Status ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Status
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// TimeEvent: A time-stamped annotation in the Span.
type TimeEvent struct {
// Annotation: One or more key:value pairs.
Annotation * Annotation ` json:"annotation,omitempty" `
// NetworkEvent: An event describing an RPC message sent/received on the
// network.
NetworkEvent * NetworkEvent ` json:"networkEvent,omitempty" `
// Time: The timestamp indicating the time the event occurred.
Time string ` json:"time,omitempty" `
// ForceSendFields is a list of field names (e.g. "Annotation") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "Annotation") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * TimeEvent ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod TimeEvent
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// TimeEvents: A collection of `TimeEvent`s. A `TimeEvent` is a
// time-stamped annotation
// on the span, consisting of either user-supplied key:value pairs,
// or
// details of an RPC message sent/received on the network.
type TimeEvents struct {
// DroppedAnnotationsCount: The number of dropped annotations after the
// maximum size was enforced. If
// 0 then no annotations were dropped.
DroppedAnnotationsCount int64 ` json:"droppedAnnotationsCount,omitempty" `
// DroppedNetworkEventsCount: The number of dropped network events after
// the maximum size was enforced.
// If 0 then no annotations were dropped.
DroppedNetworkEventsCount int64 ` json:"droppedNetworkEventsCount,omitempty" `
// TimeEvent: A collection of `TimeEvent`s.
TimeEvent [ ] * TimeEvent ` json:"timeEvent,omitempty" `
// ForceSendFields is a list of field names (e.g.
// "DroppedAnnotationsCount") to unconditionally include in API
// requests. By default, fields with empty values are omitted from API
// requests. However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "DroppedAnnotationsCount")
// to include in API requests with the JSON null value. By default,
// fields with empty values are omitted from API requests. However, any
// field with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields [ ] string ` json:"-" `
}
func ( s * TimeEvents ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod TimeEvents
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Trace: A trace describes how long it takes for an application to
// perform some
// operations. It consists of a set of spans, each representing
// an operation and including time information and operation details.
type Trace struct {
// Name: The resource name of Trace in the
// format
// `projects/PROJECT_ID/traces/TRACE_ID`. `TRACE_ID` is a unique
// identifier
// for a trace within a project and is a base16-encoded,
// case-insensitive
// string and is required to be 32 char long.
Name string ` json:"name,omitempty" `
// ForceSendFields is a list of field names (e.g. "Name") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "Name") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields [ ] string ` json:"-" `
}
func ( s * Trace ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod Trace
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// TruncatableString: Represents a string value that might be truncated.
type TruncatableString struct {
// TruncatedCharacterCount: The number of characters truncated from the
// original string value. If 0 it
// means that the string value was not truncated.
TruncatedCharacterCount int64 ` json:"truncatedCharacterCount,omitempty" `
// Value: The truncated string value. E.g. for a string attribute this
// may have up to
// 256 bytes.
Value string ` json:"value,omitempty" `
// ForceSendFields is a list of field names (e.g.
// "TruncatedCharacterCount") to unconditionally include in API
// requests. By default, fields with empty values are omitted from API
// requests. However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields [ ] string ` json:"-" `
// NullFields is a list of field names (e.g. "TruncatedCharacterCount")
// to include in API requests with the JSON null value. By default,
// fields with empty values are omitted from API requests. However, any
// field with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields [ ] string ` json:"-" `
}
func ( s * TruncatableString ) MarshalJSON ( ) ( [ ] byte , error ) {
type noMethod TruncatableString
raw := noMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// method id "tracing.projects.traces.batchWrite":
type ProjectsTracesBatchWriteCall struct {
s * Service
name string
batchwritespansrequest * BatchWriteSpansRequest
urlParams_ gensupport . URLParams
ctx_ context . Context
header_ http . Header
}
// BatchWrite: Sends new spans to Stackdriver Trace or updates existing
// traces. If the
// name of a trace that you send matches that of an existing trace, new
// spans
// are added to the existing trace. Attempt to update existing spans
// results
// undefined behavior. If the name does not match, a new trace is
// created
// with given set of spans.
func ( r * ProjectsTracesService ) BatchWrite ( name string , batchwritespansrequest * BatchWriteSpansRequest ) * ProjectsTracesBatchWriteCall {
c := & ProjectsTracesBatchWriteCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . name = name
c . batchwritespansrequest = batchwritespansrequest
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * ProjectsTracesBatchWriteCall ) Fields ( s ... googleapi . Field ) * ProjectsTracesBatchWriteCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func ( c * ProjectsTracesBatchWriteCall ) Context ( ctx context . Context ) * ProjectsTracesBatchWriteCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * ProjectsTracesBatchWriteCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * ProjectsTracesBatchWriteCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
var body io . Reader = nil
body , err := googleapi . WithoutDataWrapper . JSONReader ( c . batchwritespansrequest )
if err != nil {
return nil , err
}
reqHeaders . Set ( "Content-Type" , "application/json" )
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v2/{+name}/traces:batchWrite" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "POST" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"name" : c . name ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// Do executes the "tracing.projects.traces.batchWrite" call.
// Exactly one of *Empty or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Empty.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func ( c * ProjectsTracesBatchWriteCall ) Do ( opts ... googleapi . CallOption ) ( * Empty , error ) {
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
ret := & Empty {
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
if err := json . NewDecoder ( res . Body ) . Decode ( target ) ; err != nil {
return nil , err
}
return ret , nil
// {
// "description": "Sends new spans to Stackdriver Trace or updates existing traces. If the\nname of a trace that you send matches that of an existing trace, new spans\nare added to the existing trace. Attempt to update existing spans results\nundefined behavior. If the name does not match, a new trace is created\nwith given set of spans.",
// "flatPath": "v2/projects/{projectsId}/traces:batchWrite",
// "httpMethod": "POST",
// "id": "tracing.projects.traces.batchWrite",
// "parameterOrder": [
// "name"
// ],
// "parameters": {
// "name": {
// "description": "Name of the project where the spans belong to. Format is\n`projects/PROJECT_ID`.",
// "location": "path",
// "pattern": "^projects/[^/]+$",
// "required": true,
// "type": "string"
// }
// },
// "path": "v2/{+name}/traces:batchWrite",
// "request": {
// "$ref": "BatchWriteSpansRequest"
// },
// "response": {
// "$ref": "Empty"
// },
// "scopes": [
// "https://www.googleapis.com/auth/cloud-platform",
// "https://www.googleapis.com/auth/trace.append"
// ]
// }
}
// method id "tracing.projects.traces.list":
type ProjectsTracesListCall struct {
s * Service
parent string
urlParams_ gensupport . URLParams
ifNoneMatch_ string
ctx_ context . Context
header_ http . Header
}
// List: Returns of a list of traces that match the specified filter
// conditions.
func ( r * ProjectsTracesService ) List ( parent string ) * ProjectsTracesListCall {
c := & ProjectsTracesListCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . parent = parent
return c
}
// EndTime sets the optional parameter "endTime": End of the time
// interval (inclusive) during which the trace data was
// collected from the application.
func ( c * ProjectsTracesListCall ) EndTime ( endTime string ) * ProjectsTracesListCall {
c . urlParams_ . Set ( "endTime" , endTime )
return c
}
// Filter sets the optional parameter "filter": An optional filter for
// the request.
// Example:
// `version_label_key:a some_label:some_label_key`
// returns traces from version `a` and has `some_label` with
// `some_label_key`.
func ( c * ProjectsTracesListCall ) Filter ( filter string ) * ProjectsTracesListCall {
c . urlParams_ . Set ( "filter" , filter )
return c
}
// OrderBy sets the optional parameter "orderBy": Field used to sort the
// returned traces.
// 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.
func ( c * ProjectsTracesListCall ) OrderBy ( orderBy string ) * ProjectsTracesListCall {
c . urlParams_ . Set ( "orderBy" , orderBy )
return c
}
// PageSize sets the optional parameter "pageSize": 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.
func ( c * ProjectsTracesListCall ) PageSize ( pageSize int64 ) * ProjectsTracesListCall {
c . urlParams_ . Set ( "pageSize" , fmt . Sprint ( pageSize ) )
return c
}
// PageToken sets the optional parameter "pageToken": Token identifying
// the page of results to return. If provided, use the
// value of the `next_page_token` field from a previous request.
func ( c * ProjectsTracesListCall ) PageToken ( pageToken string ) * ProjectsTracesListCall {
c . urlParams_ . Set ( "pageToken" , pageToken )
return c
}
// StartTime sets the optional parameter "startTime": Start of the time
// interval (inclusive) during which the trace data was
// collected from the application.
func ( c * ProjectsTracesListCall ) StartTime ( startTime string ) * ProjectsTracesListCall {
c . urlParams_ . Set ( "startTime" , startTime )
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * ProjectsTracesListCall ) Fields ( s ... googleapi . Field ) * ProjectsTracesListCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func ( c * ProjectsTracesListCall ) IfNoneMatch ( entityTag string ) * ProjectsTracesListCall {
c . ifNoneMatch_ = entityTag
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func ( c * ProjectsTracesListCall ) Context ( ctx context . Context ) * ProjectsTracesListCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * ProjectsTracesListCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * ProjectsTracesListCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
if c . ifNoneMatch_ != "" {
reqHeaders . Set ( "If-None-Match" , c . ifNoneMatch_ )
}
var body io . Reader = nil
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v2/{+parent}/traces" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "GET" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"parent" : c . parent ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// Do executes the "tracing.projects.traces.list" call.
// Exactly one of *ListTracesResponse or error will be non-nil. Any
// non-2xx status code is an error. Response headers are in either
// *ListTracesResponse.ServerResponse.Header or (if a response was
// returned at all) in error.(*googleapi.Error).Header. Use
// googleapi.IsNotModified to check whether the returned error was
// because http.StatusNotModified was returned.
func ( c * ProjectsTracesListCall ) Do ( opts ... googleapi . CallOption ) ( * ListTracesResponse , error ) {
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
ret := & ListTracesResponse {
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
if err := json . NewDecoder ( res . Body ) . Decode ( target ) ; err != nil {
return nil , err
}
return ret , nil
// {
// "description": "Returns of a list of traces that match the specified filter conditions.",
// "flatPath": "v2/projects/{projectsId}/traces",
// "httpMethod": "GET",
// "id": "tracing.projects.traces.list",
// "parameterOrder": [
// "parent"
// ],
// "parameters": {
// "endTime": {
// "description": "End of the time interval (inclusive) during which the trace data was\ncollected from the application.",
// "format": "google-datetime",
// "location": "query",
// "type": "string"
// },
// "filter": {
// "description": "An optional filter for the request.\nExample:\n`version_label_key:a some_label:some_label_key`\nreturns traces from version `a` and has `some_label` with `some_label_key`.",
// "location": "query",
// "type": "string"
// },
// "orderBy": {
// "description": "Field used to sort the returned traces. Optional.\nCan be one of the following:\n\n* `trace_id`\n* `name` (`name` field of root span in the trace)\n* `duration` (difference between `end_time` and `start_time` fields of\n the root span)\n* `start` (`start_time` field of the root span)\n\nDescending order can be specified by appending `desc` to the sort field\n(for example, `name desc`).\n\nOnly one sort field is permitted.",
// "location": "query",
// "type": "string"
// },
// "pageSize": {
// "description": "Maximum number of traces to return. If not specified or \u003c= 0, the\nimplementation selects a reasonable value. The implementation may\nreturn fewer traces than the requested page size. Optional.",
// "format": "int32",
// "location": "query",
// "type": "integer"
// },
// "pageToken": {
// "description": "Token identifying the page of results to return. If provided, use the\nvalue of the `next_page_token` field from a previous request. Optional.",
// "location": "query",
// "type": "string"
// },
// "parent": {
// "description": "ID of the Cloud project where the trace data is stored which is\n`projects/PROJECT_ID`.",
// "location": "path",
// "pattern": "^projects/[^/]+$",
// "required": true,
// "type": "string"
// },
// "startTime": {
// "description": "Start of the time interval (inclusive) during which the trace data was\ncollected from the application.",
// "format": "google-datetime",
// "location": "query",
// "type": "string"
// }
// },
// "path": "v2/{+parent}/traces",
// "response": {
// "$ref": "ListTracesResponse"
// },
// "scopes": [
// "https://www.googleapis.com/auth/cloud-platform",
// "https://www.googleapis.com/auth/trace.readonly"
// ]
// }
}
// Pages invokes f for each page of results.
// A non-nil error returned from f will halt the iteration.
// The provided context supersedes any context provided to the Context method.
func ( c * ProjectsTracesListCall ) Pages ( ctx context . Context , f func ( * ListTracesResponse ) error ) error {
c . ctx_ = ctx
defer c . PageToken ( c . urlParams_ . Get ( "pageToken" ) ) // reset paging to original point
for {
x , err := c . Do ( )
if err != nil {
return err
}
if err := f ( x ) ; err != nil {
return err
}
if x . NextPageToken == "" {
return nil
}
c . PageToken ( x . NextPageToken )
}
}
// method id "tracing.projects.traces.listSpans":
type ProjectsTracesListSpansCall struct {
s * Service
parent string
urlParams_ gensupport . URLParams
ifNoneMatch_ string
ctx_ context . Context
header_ http . Header
}
// ListSpans: Returns a list of spans within a trace.
func ( r * ProjectsTracesService ) ListSpans ( parent string ) * ProjectsTracesListSpansCall {
c := & ProjectsTracesListSpansCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . parent = parent
return c
}
// PageToken sets the optional parameter "pageToken": Token identifying
// the page of results to return. If provided, use the
// value of the `nextPageToken` field from a previous request.
func ( c * ProjectsTracesListSpansCall ) PageToken ( pageToken string ) * ProjectsTracesListSpansCall {
c . urlParams_ . Set ( "pageToken" , pageToken )
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * ProjectsTracesListSpansCall ) Fields ( s ... googleapi . Field ) * ProjectsTracesListSpansCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func ( c * ProjectsTracesListSpansCall ) IfNoneMatch ( entityTag string ) * ProjectsTracesListSpansCall {
c . ifNoneMatch_ = entityTag
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func ( c * ProjectsTracesListSpansCall ) Context ( ctx context . Context ) * ProjectsTracesListSpansCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * ProjectsTracesListSpansCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * ProjectsTracesListSpansCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
if c . ifNoneMatch_ != "" {
reqHeaders . Set ( "If-None-Match" , c . ifNoneMatch_ )
}
var body io . Reader = nil
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v2/{+parent}:listSpans" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "GET" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"parent" : c . parent ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// Do executes the "tracing.projects.traces.listSpans" call.
// Exactly one of *ListSpansResponse or error will be non-nil. Any
// non-2xx status code is an error. Response headers are in either
// *ListSpansResponse.ServerResponse.Header or (if a response was
// returned at all) in error.(*googleapi.Error).Header. Use
// googleapi.IsNotModified to check whether the returned error was
// because http.StatusNotModified was returned.
func ( c * ProjectsTracesListSpansCall ) Do ( opts ... googleapi . CallOption ) ( * ListSpansResponse , error ) {
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
ret := & ListSpansResponse {
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
if err := json . NewDecoder ( res . Body ) . Decode ( target ) ; err != nil {
return nil , err
}
return ret , nil
// {
// "description": "Returns a list of spans within a trace.",
// "flatPath": "v2/projects/{projectsId}/traces/{tracesId}:listSpans",
// "httpMethod": "GET",
// "id": "tracing.projects.traces.listSpans",
// "parameterOrder": [
// "parent"
// ],
// "parameters": {
// "pageToken": {
// "description": "Token identifying the page of results to return. If provided, use the\nvalue of the `nextPageToken` field from a previous request. Optional.",
// "location": "query",
// "type": "string"
// },
// "parent": {
// "description": "ID of the trace for which to list child spans. Format is\n`projects/PROJECT_ID/traces/TRACE_ID`.",
// "location": "path",
// "pattern": "^projects/[^/]+/traces/[^/]+$",
// "required": true,
// "type": "string"
// }
// },
// "path": "v2/{+parent}:listSpans",
// "response": {
// "$ref": "ListSpansResponse"
// },
// "scopes": [
// "https://www.googleapis.com/auth/cloud-platform",
// "https://www.googleapis.com/auth/trace.readonly"
// ]
// }
}
// Pages invokes f for each page of results.
// A non-nil error returned from f will halt the iteration.
// The provided context supersedes any context provided to the Context method.
func ( c * ProjectsTracesListSpansCall ) Pages ( ctx context . Context , f func ( * ListSpansResponse ) error ) error {
c . ctx_ = ctx
defer c . PageToken ( c . urlParams_ . Get ( "pageToken" ) ) // reset paging to original point
for {
x , err := c . Do ( )
if err != nil {
return err
}
if err := f ( x ) ; err != nil {
return err
}
if x . NextPageToken == "" {
return nil
}
c . PageToken ( x . NextPageToken )
}
}
// method id "tracing.projects.traces.spans.create":
type ProjectsTracesSpansCreateCall struct {
s * Service
nameid string
span * Span
urlParams_ gensupport . URLParams
ctx_ context . Context
header_ http . Header
}
// Create: Creates a new Span.
func ( r * ProjectsTracesSpansService ) Create ( nameid string , span * Span ) * ProjectsTracesSpansCreateCall {
c := & ProjectsTracesSpansCreateCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . nameid = nameid
c . span = span
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * ProjectsTracesSpansCreateCall ) Fields ( s ... googleapi . Field ) * ProjectsTracesSpansCreateCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func ( c * ProjectsTracesSpansCreateCall ) Context ( ctx context . Context ) * ProjectsTracesSpansCreateCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * ProjectsTracesSpansCreateCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * ProjectsTracesSpansCreateCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
var body io . Reader = nil
body , err := googleapi . WithoutDataWrapper . JSONReader ( c . span )
if err != nil {
return nil , err
}
reqHeaders . Set ( "Content-Type" , "application/json" )
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v2/{+name}" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "PUT" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"name" : c . nameid ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// Do executes the "tracing.projects.traces.spans.create" call.
// Exactly one of *Span or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Span.ServerResponse.Header or (if a response was returned at all) in
// error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check
// whether the returned error was because http.StatusNotModified was
// returned.
func ( c * ProjectsTracesSpansCreateCall ) Do ( opts ... googleapi . CallOption ) ( * Span , error ) {
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
ret := & Span {
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
if err := json . NewDecoder ( res . Body ) . Decode ( target ) ; err != nil {
return nil , err
}
return ret , nil
// {
// "description": "Creates a new Span.",
// "flatPath": "v2/projects/{projectsId}/traces/{tracesId}/spans/{spansId}",
// "httpMethod": "PUT",
// "id": "tracing.projects.traces.spans.create",
// "parameterOrder": [
// "name"
// ],
// "parameters": {
// "name": {
// "description": "The resource name of Span in the format\n`projects/PROJECT_ID/traces/TRACE_ID/spans/SPAN_ID`.\n`TRACE_ID` is a unique identifier for a trace within a project and is a\nbase16-encoded, case-insensitive string and is required to be 32 char long.\n`SPAN_ID` is a unique identifier for a span within a trace. It is a\nbase 16-encoded, case-insensitive string of a 8-bytes array and is required\nto be 16 char long.",
// "location": "path",
// "pattern": "^projects/[^/]+/traces/[^/]+/spans/[^/]+$",
// "required": true,
// "type": "string"
// }
// },
// "path": "v2/{+name}",
// "request": {
// "$ref": "Span"
// },
// "response": {
// "$ref": "Span"
// },
// "scopes": [
// "https://www.googleapis.com/auth/cloud-platform",
// "https://www.googleapis.com/auth/trace.append"
// ]
// }
}