collect/language/agent/v3/Tracing.pb.go (1,061 lines of code) (raw):

// // Licensed to the Apache Software Foundation (ASF) under one or more // contributor license agreements. See the NOTICE file distributed with // this work for additional information regarding copyright ownership. // The ASF licenses this file to You 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. // // Code generated by protoc-gen-go. DO NOT EDIT. // versions: // protoc-gen-go v1.28.1 // protoc v3.14.0 // source: language-agent/Tracing.proto package v3 import ( protoreflect "google.golang.org/protobuf/reflect/protoreflect" protoimpl "google.golang.org/protobuf/runtime/protoimpl" reflect "reflect" v3 "skywalking.apache.org/repo/goapi/collect/common/v3" sync "sync" ) const ( // Verify that this generated code is sufficiently up-to-date. _ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion) // Verify that runtime/protoimpl is sufficiently up-to-date. _ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20) ) // Map to the type of span type SpanType int32 const ( // Server side of RPC. Consumer side of MQ. SpanType_Entry SpanType = 0 // Client side of RPC. Producer side of MQ. SpanType_Exit SpanType = 1 // A common local code execution. SpanType_Local SpanType = 2 ) // Enum value maps for SpanType. var ( SpanType_name = map[int32]string{ 0: "Entry", 1: "Exit", 2: "Local", } SpanType_value = map[string]int32{ "Entry": 0, "Exit": 1, "Local": 2, } ) func (x SpanType) Enum() *SpanType { p := new(SpanType) *p = x return p } func (x SpanType) String() string { return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x)) } func (SpanType) Descriptor() protoreflect.EnumDescriptor { return file_language_agent_Tracing_proto_enumTypes[0].Descriptor() } func (SpanType) Type() protoreflect.EnumType { return &file_language_agent_Tracing_proto_enumTypes[0] } func (x SpanType) Number() protoreflect.EnumNumber { return protoreflect.EnumNumber(x) } // Deprecated: Use SpanType.Descriptor instead. func (SpanType) EnumDescriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{0} } // Type of the reference type RefType int32 const ( // Map to the reference targeting the segment in another OS process. RefType_CrossProcess RefType = 0 // Map to the reference targeting the segment in the same process of the current one, just across thread. // This is only used when the coding language has the thread concept. RefType_CrossThread RefType = 1 ) // Enum value maps for RefType. var ( RefType_name = map[int32]string{ 0: "CrossProcess", 1: "CrossThread", } RefType_value = map[string]int32{ "CrossProcess": 0, "CrossThread": 1, } ) func (x RefType) Enum() *RefType { p := new(RefType) *p = x return p } func (x RefType) String() string { return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x)) } func (RefType) Descriptor() protoreflect.EnumDescriptor { return file_language_agent_Tracing_proto_enumTypes[1].Descriptor() } func (RefType) Type() protoreflect.EnumType { return &file_language_agent_Tracing_proto_enumTypes[1] } func (x RefType) Number() protoreflect.EnumNumber { return protoreflect.EnumNumber(x) } // Deprecated: Use RefType.Descriptor instead. func (RefType) EnumDescriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{1} } // Map to the layer of span type SpanLayer int32 const ( // Unknown layer. Could be anything. SpanLayer_Unknown SpanLayer = 0 // A database layer, used in tracing the database client component. SpanLayer_Database SpanLayer = 1 // A RPC layer, used in both client and server sides of RPC component. SpanLayer_RPCFramework SpanLayer = 2 // HTTP is a more specific RPCFramework. SpanLayer_Http SpanLayer = 3 // A MQ layer, used in both producer and consuer sides of the MQ component. SpanLayer_MQ SpanLayer = 4 // A cache layer, used in tracing the cache client component. SpanLayer_Cache SpanLayer = 5 // A FAAS layer, used in function-as-a-Service platform. SpanLayer_FAAS SpanLayer = 6 ) // Enum value maps for SpanLayer. var ( SpanLayer_name = map[int32]string{ 0: "Unknown", 1: "Database", 2: "RPCFramework", 3: "Http", 4: "MQ", 5: "Cache", 6: "FAAS", } SpanLayer_value = map[string]int32{ "Unknown": 0, "Database": 1, "RPCFramework": 2, "Http": 3, "MQ": 4, "Cache": 5, "FAAS": 6, } ) func (x SpanLayer) Enum() *SpanLayer { p := new(SpanLayer) *p = x return p } func (x SpanLayer) String() string { return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x)) } func (SpanLayer) Descriptor() protoreflect.EnumDescriptor { return file_language_agent_Tracing_proto_enumTypes[2].Descriptor() } func (SpanLayer) Type() protoreflect.EnumType { return &file_language_agent_Tracing_proto_enumTypes[2] } func (x SpanLayer) Number() protoreflect.EnumNumber { return protoreflect.EnumNumber(x) } // Deprecated: Use SpanLayer.Descriptor instead. func (SpanLayer) EnumDescriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{2} } type SpanAttachedEvent_SpanReferenceType int32 const ( SpanAttachedEvent_SKYWALKING SpanAttachedEvent_SpanReferenceType = 0 SpanAttachedEvent_ZIPKIN SpanAttachedEvent_SpanReferenceType = 1 ) // Enum value maps for SpanAttachedEvent_SpanReferenceType. var ( SpanAttachedEvent_SpanReferenceType_name = map[int32]string{ 0: "SKYWALKING", 1: "ZIPKIN", } SpanAttachedEvent_SpanReferenceType_value = map[string]int32{ "SKYWALKING": 0, "ZIPKIN": 1, } ) func (x SpanAttachedEvent_SpanReferenceType) Enum() *SpanAttachedEvent_SpanReferenceType { p := new(SpanAttachedEvent_SpanReferenceType) *p = x return p } func (x SpanAttachedEvent_SpanReferenceType) String() string { return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x)) } func (SpanAttachedEvent_SpanReferenceType) Descriptor() protoreflect.EnumDescriptor { return file_language_agent_Tracing_proto_enumTypes[3].Descriptor() } func (SpanAttachedEvent_SpanReferenceType) Type() protoreflect.EnumType { return &file_language_agent_Tracing_proto_enumTypes[3] } func (x SpanAttachedEvent_SpanReferenceType) Number() protoreflect.EnumNumber { return protoreflect.EnumNumber(x) } // Deprecated: Use SpanAttachedEvent_SpanReferenceType.Descriptor instead. func (SpanAttachedEvent_SpanReferenceType) EnumDescriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{6, 0} } // The segment is a collection of spans. It includes all collected spans in a simple one request context, such as a HTTP request process. // // We recommend the agent/SDK report all tracked data of one request once for all. // Typically, such as in Java, one segment represent all tracked operations(spans) of one request context in the same thread. // At the same time, in some language there is not a clear `thread` concept like golang. // Then, it could represent all tracked operations of one request context cross threads/goroutines. type SegmentObject struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields // A string id represents the whole trace. TraceId string `protobuf:"bytes,1,opt,name=traceId,proto3" json:"traceId,omitempty"` // A unique id represents this segment. Other segments could use this id to reference as a child segment. TraceSegmentId string `protobuf:"bytes,2,opt,name=traceSegmentId,proto3" json:"traceSegmentId,omitempty"` // Span collections included in this segment. Spans []*SpanObject `protobuf:"bytes,3,rep,name=spans,proto3" json:"spans,omitempty"` // **Service**. Represents a set/group of workloads which provide the same behaviours for incoming requests. // // The logic name represents the service. This would show as a separate node in the topology. // The metrics analyzed from the spans, would be aggregated for this entity as the service level. Service string `protobuf:"bytes,4,opt,name=service,proto3" json:"service,omitempty"` // **Service Instance**. Each individual workload in the Service group is known as an instance. Like `pods` in Kubernetes, it // doesn't need to be a single OS process, however, if you are using instrument agents, an instance is actually a real OS process. // // The logic name represents the service instance. This would show as a separate node in the instance relationship. // The metrics analyzed from the spans, would be aggregated for this entity as the service instance level. ServiceInstance string `protobuf:"bytes,5,opt,name=serviceInstance,proto3" json:"serviceInstance,omitempty"` // Whether the segment includes all tracked spans. // In the production environment tracked, some tasks could include too many spans for one request context, such as a batch update for a cache, or an async job. // The agent/SDK could optimize or ignore some tracked spans for better performance. // In this case, the value should be flagged as TRUE. IsSizeLimited bool `protobuf:"varint,6,opt,name=isSizeLimited,proto3" json:"isSizeLimited,omitempty"` } func (x *SegmentObject) Reset() { *x = SegmentObject{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[0] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *SegmentObject) String() string { return protoimpl.X.MessageStringOf(x) } func (*SegmentObject) ProtoMessage() {} func (x *SegmentObject) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[0] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use SegmentObject.ProtoReflect.Descriptor instead. func (*SegmentObject) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{0} } func (x *SegmentObject) GetTraceId() string { if x != nil { return x.TraceId } return "" } func (x *SegmentObject) GetTraceSegmentId() string { if x != nil { return x.TraceSegmentId } return "" } func (x *SegmentObject) GetSpans() []*SpanObject { if x != nil { return x.Spans } return nil } func (x *SegmentObject) GetService() string { if x != nil { return x.Service } return "" } func (x *SegmentObject) GetServiceInstance() string { if x != nil { return x.ServiceInstance } return "" } func (x *SegmentObject) GetIsSizeLimited() bool { if x != nil { return x.IsSizeLimited } return false } // Segment reference represents the link between two existing segment. type SegmentReference struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields // Represent the reference type. It could be across thread or across process. // Across process means there is a downstream RPC call for this. // Typically, refType == CrossProcess means SpanObject#spanType = entry. RefType RefType `protobuf:"varint,1,opt,name=refType,proto3,enum=skywalking.v3.RefType" json:"refType,omitempty"` // A string id represents the whole trace. TraceId string `protobuf:"bytes,2,opt,name=traceId,proto3" json:"traceId,omitempty"` // Another segment id as the parent. ParentTraceSegmentId string `protobuf:"bytes,3,opt,name=parentTraceSegmentId,proto3" json:"parentTraceSegmentId,omitempty"` // The span id in the parent trace segment. ParentSpanId int32 `protobuf:"varint,4,opt,name=parentSpanId,proto3" json:"parentSpanId,omitempty"` // The service logic name of the parent segment. // If refType == CrossThread, this name is as same as the trace segment. ParentService string `protobuf:"bytes,5,opt,name=parentService,proto3" json:"parentService,omitempty"` // The service logic name instance of the parent segment. // If refType == CrossThread, this name is as same as the trace segment. ParentServiceInstance string `protobuf:"bytes,6,opt,name=parentServiceInstance,proto3" json:"parentServiceInstance,omitempty"` // The endpoint name of the parent segment. // **Endpoint**. A path in a service for incoming requests, such as an HTTP URI path or a gRPC service class + method signature. // In a trace segment, the endpoint name is the name of first entry span. ParentEndpoint string `protobuf:"bytes,7,opt,name=parentEndpoint,proto3" json:"parentEndpoint,omitempty"` // The network address, including ip/hostname and port, which is used in the client side. // Such as Client --> use 127.0.11.8:913 -> Server // then, in the reference of entry span reported by Server, the value of this field is 127.0.11.8:913. // This plays the important role in the SkyWalking STAM(Streaming Topology Analysis Method) // For more details, read https://wu-sheng.github.io/STAM/ NetworkAddressUsedAtPeer string `protobuf:"bytes,8,opt,name=networkAddressUsedAtPeer,proto3" json:"networkAddressUsedAtPeer,omitempty"` } func (x *SegmentReference) Reset() { *x = SegmentReference{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[1] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *SegmentReference) String() string { return protoimpl.X.MessageStringOf(x) } func (*SegmentReference) ProtoMessage() {} func (x *SegmentReference) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[1] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use SegmentReference.ProtoReflect.Descriptor instead. func (*SegmentReference) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{1} } func (x *SegmentReference) GetRefType() RefType { if x != nil { return x.RefType } return RefType_CrossProcess } func (x *SegmentReference) GetTraceId() string { if x != nil { return x.TraceId } return "" } func (x *SegmentReference) GetParentTraceSegmentId() string { if x != nil { return x.ParentTraceSegmentId } return "" } func (x *SegmentReference) GetParentSpanId() int32 { if x != nil { return x.ParentSpanId } return 0 } func (x *SegmentReference) GetParentService() string { if x != nil { return x.ParentService } return "" } func (x *SegmentReference) GetParentServiceInstance() string { if x != nil { return x.ParentServiceInstance } return "" } func (x *SegmentReference) GetParentEndpoint() string { if x != nil { return x.ParentEndpoint } return "" } func (x *SegmentReference) GetNetworkAddressUsedAtPeer() string { if x != nil { return x.NetworkAddressUsedAtPeer } return "" } // Span represents a execution unit in the system, with duration and many other attributes. // Span could be a method, a RPC, MQ message produce or consume. // In the practice, the span should be added when it is really necessary, to avoid payload overhead. // We recommend to creating spans in across process(client/server of RPC/MQ) and across thread cases only. type SpanObject struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields // The number id of the span. Should be unique in the whole segment. // Starting at 0. SpanId int32 `protobuf:"varint,1,opt,name=spanId,proto3" json:"spanId,omitempty"` // The number id of the parent span in the whole segment. // -1 represents no parent span. // Also, be known as the root/first span of the segment. ParentSpanId int32 `protobuf:"varint,2,opt,name=parentSpanId,proto3" json:"parentSpanId,omitempty"` // Start timestamp in milliseconds of this span, // measured between the current time and midnight, January 1, 1970 UTC. StartTime int64 `protobuf:"varint,3,opt,name=startTime,proto3" json:"startTime,omitempty"` // End timestamp in milliseconds of this span, // measured between the current time and midnight, January 1, 1970 UTC. EndTime int64 `protobuf:"varint,4,opt,name=endTime,proto3" json:"endTime,omitempty"` // <Optional> // In the across thread and across process, these references targeting the parent segments. // The references usually have only one element, but in batch consumer case, such as in MQ or async batch process, it could be multiple. Refs []*SegmentReference `protobuf:"bytes,5,rep,name=refs,proto3" json:"refs,omitempty"` // A logic name represents this span. // // We don't recommend to include the parameter, such as HTTP request parameters, as a part of the operation, especially this is the name of the entry span. // All statistic for the endpoints are aggregated base on this name. Those parameters should be added in the tags if necessary. // If in some cases, it have to be a part of the operation name, // users should use the Group Parameterized Endpoints capability at the backend to get the meaningful metrics. // Read https://github.com/apache/skywalking/blob/master/docs/en/setup/backend/endpoint-grouping-rules.md OperationName string `protobuf:"bytes,6,opt,name=operationName,proto3" json:"operationName,omitempty"` // Remote address of the peer in RPC/MQ case. // This is required when spanType = Exit, as it is a part of the SkyWalking STAM(Streaming Topology Analysis Method). // For more details, read https://wu-sheng.github.io/STAM/ Peer string `protobuf:"bytes,7,opt,name=peer,proto3" json:"peer,omitempty"` // Span type represents the role in the RPC context. SpanType SpanType `protobuf:"varint,8,opt,name=spanType,proto3,enum=skywalking.v3.SpanType" json:"spanType,omitempty"` // Span layer represent the component tech stack, related to the network tech. SpanLayer SpanLayer `protobuf:"varint,9,opt,name=spanLayer,proto3,enum=skywalking.v3.SpanLayer" json:"spanLayer,omitempty"` // Component id is a predefinited number id in the SkyWalking. // It represents the framework, tech stack used by this tracked span, such as Spring. // All IDs are defined in the https://github.com/apache/skywalking/blob/master/oap-server/server-bootstrap/src/main/resources/component-libraries.yml // Send a pull request if you want to add languages, components or mapping defintions, // all public components could be accepted. // Follow this doc for more details, https://github.com/apache/skywalking/blob/master/docs/en/guides/Component-library-settings.md ComponentId int32 `protobuf:"varint,10,opt,name=componentId,proto3" json:"componentId,omitempty"` // The status of the span. False means the tracked execution ends in the unexpected status. // This affects the successful rate statistic in the backend. // Exception or error code happened in the tracked process doesn't mean isError == true, the implementations of agent plugin and tracing SDK make the final decision. IsError bool `protobuf:"varint,11,opt,name=isError,proto3" json:"isError,omitempty"` // String key, String value pair. // Tags provides more informance, includes parameters. // // In the OAP backend analysis, some special tag or tag combination could provide other advanced features. // https://github.com/apache/skywalking/blob/master/docs/en/guides/Java-Plugin-Development-Guide.md#special-span-tags Tags []*v3.KeyStringValuePair `protobuf:"bytes,12,rep,name=tags,proto3" json:"tags,omitempty"` // String key, String value pair with an accurate timestamp. // Logging some events happening in the context of the span duration. Logs []*Log `protobuf:"bytes,13,rep,name=logs,proto3" json:"logs,omitempty"` // Force the backend don't do analysis, if the value is TRUE. // The backend has its own configurations to follow or override this. // // Use this mostly because the agent/SDK could know more context of the service role. SkipAnalysis bool `protobuf:"varint,14,opt,name=skipAnalysis,proto3" json:"skipAnalysis,omitempty"` } func (x *SpanObject) Reset() { *x = SpanObject{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[2] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *SpanObject) String() string { return protoimpl.X.MessageStringOf(x) } func (*SpanObject) ProtoMessage() {} func (x *SpanObject) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[2] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use SpanObject.ProtoReflect.Descriptor instead. func (*SpanObject) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{2} } func (x *SpanObject) GetSpanId() int32 { if x != nil { return x.SpanId } return 0 } func (x *SpanObject) GetParentSpanId() int32 { if x != nil { return x.ParentSpanId } return 0 } func (x *SpanObject) GetStartTime() int64 { if x != nil { return x.StartTime } return 0 } func (x *SpanObject) GetEndTime() int64 { if x != nil { return x.EndTime } return 0 } func (x *SpanObject) GetRefs() []*SegmentReference { if x != nil { return x.Refs } return nil } func (x *SpanObject) GetOperationName() string { if x != nil { return x.OperationName } return "" } func (x *SpanObject) GetPeer() string { if x != nil { return x.Peer } return "" } func (x *SpanObject) GetSpanType() SpanType { if x != nil { return x.SpanType } return SpanType_Entry } func (x *SpanObject) GetSpanLayer() SpanLayer { if x != nil { return x.SpanLayer } return SpanLayer_Unknown } func (x *SpanObject) GetComponentId() int32 { if x != nil { return x.ComponentId } return 0 } func (x *SpanObject) GetIsError() bool { if x != nil { return x.IsError } return false } func (x *SpanObject) GetTags() []*v3.KeyStringValuePair { if x != nil { return x.Tags } return nil } func (x *SpanObject) GetLogs() []*Log { if x != nil { return x.Logs } return nil } func (x *SpanObject) GetSkipAnalysis() bool { if x != nil { return x.SkipAnalysis } return false } type Log struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields // The timestamp in milliseconds of this event., // measured between the current time and midnight, January 1, 1970 UTC. Time int64 `protobuf:"varint,1,opt,name=time,proto3" json:"time,omitempty"` // String key, String value pair. Data []*v3.KeyStringValuePair `protobuf:"bytes,2,rep,name=data,proto3" json:"data,omitempty"` } func (x *Log) Reset() { *x = Log{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[3] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *Log) String() string { return protoimpl.X.MessageStringOf(x) } func (*Log) ProtoMessage() {} func (x *Log) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[3] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use Log.ProtoReflect.Descriptor instead. func (*Log) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{3} } func (x *Log) GetTime() int64 { if x != nil { return x.Time } return 0 } func (x *Log) GetData() []*v3.KeyStringValuePair { if x != nil { return x.Data } return nil } // A ID could be represented by multiple string sections. type ID struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields Id []string `protobuf:"bytes,1,rep,name=id,proto3" json:"id,omitempty"` } func (x *ID) Reset() { *x = ID{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[4] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *ID) String() string { return protoimpl.X.MessageStringOf(x) } func (*ID) ProtoMessage() {} func (x *ID) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[4] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use ID.ProtoReflect.Descriptor instead. func (*ID) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{4} } func (x *ID) GetId() []string { if x != nil { return x.Id } return nil } // The segment collections for trace report in batch and sync mode. type SegmentCollection struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields Segments []*SegmentObject `protobuf:"bytes,1,rep,name=segments,proto3" json:"segments,omitempty"` } func (x *SegmentCollection) Reset() { *x = SegmentCollection{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[5] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *SegmentCollection) String() string { return protoimpl.X.MessageStringOf(x) } func (*SegmentCollection) ProtoMessage() {} func (x *SegmentCollection) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[5] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use SegmentCollection.ProtoReflect.Descriptor instead. func (*SegmentCollection) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{5} } func (x *SegmentCollection) GetSegments() []*SegmentObject { if x != nil { return x.Segments } return nil } // SpanAttachedEvent represents an attached event for a traced RPC. // // When an RPC is being traced by the in-process language agent, a span would be reported by the client-side agent. // And the rover would be aware of this RPC due to the existing tracing header. // Then, the rover agent collects extra information from the OS level to provide assistance information to diagnose network performance. type SpanAttachedEvent struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields // The nanosecond timestamp of the event's start time. // Notice, most unit of timestamp in SkyWalking is milliseconds, but NANO-SECOND is required here. // Because the attached event happens in the OS syscall level, most of them are executed rapidly. StartTime *v3.Instant `protobuf:"bytes,1,opt,name=startTime,proto3" json:"startTime,omitempty"` // The official event name. // For example, the event name is a method signature from syscall stack. Event string `protobuf:"bytes,2,opt,name=event,proto3" json:"event,omitempty"` // [Optional] The nanosecond timestamp of the event's end time. EndTime *v3.Instant `protobuf:"bytes,3,opt,name=endTime,proto3" json:"endTime,omitempty"` // The tags for this event includes some extra OS level information, // such as // 1. net_device used for this exit span. // 2. network L7 protocol Tags []*v3.KeyStringValuePair `protobuf:"bytes,4,rep,name=tags,proto3" json:"tags,omitempty"` // The summary of statistics during this event. // Each statistic provides a name(metric name) to represent the name, and an int64/long as the value. Summary []*v3.KeyIntValuePair `protobuf:"bytes,5,rep,name=summary,proto3" json:"summary,omitempty"` // Refer to a trace context decoded from `sw8` header through network, such as HTTP header, MQ metadata // https://skywalking.apache.org/docs/main/next/en/protocols/skywalking-cross-process-propagation-headers-protocol-v3/#standard-header-item TraceContext *SpanAttachedEvent_SpanReference `protobuf:"bytes,6,opt,name=traceContext,proto3" json:"traceContext,omitempty"` } func (x *SpanAttachedEvent) Reset() { *x = SpanAttachedEvent{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[6] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *SpanAttachedEvent) String() string { return protoimpl.X.MessageStringOf(x) } func (*SpanAttachedEvent) ProtoMessage() {} func (x *SpanAttachedEvent) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[6] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use SpanAttachedEvent.ProtoReflect.Descriptor instead. func (*SpanAttachedEvent) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{6} } func (x *SpanAttachedEvent) GetStartTime() *v3.Instant { if x != nil { return x.StartTime } return nil } func (x *SpanAttachedEvent) GetEvent() string { if x != nil { return x.Event } return "" } func (x *SpanAttachedEvent) GetEndTime() *v3.Instant { if x != nil { return x.EndTime } return nil } func (x *SpanAttachedEvent) GetTags() []*v3.KeyStringValuePair { if x != nil { return x.Tags } return nil } func (x *SpanAttachedEvent) GetSummary() []*v3.KeyIntValuePair { if x != nil { return x.Summary } return nil } func (x *SpanAttachedEvent) GetTraceContext() *SpanAttachedEvent_SpanReference { if x != nil { return x.TraceContext } return nil } type SpanAttachedEvent_SpanReference struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields Type SpanAttachedEvent_SpanReferenceType `protobuf:"varint,1,opt,name=type,proto3,enum=skywalking.v3.SpanAttachedEvent_SpanReferenceType" json:"type,omitempty"` // [Optional] A string id represents the whole trace. TraceId string `protobuf:"bytes,2,opt,name=traceId,proto3" json:"traceId,omitempty"` // A unique id represents this segment. Other segments could use this id to reference as a child segment. // [Optional] when this span reference TraceSegmentId string `protobuf:"bytes,3,opt,name=traceSegmentId,proto3" json:"traceSegmentId,omitempty"` // If type == SKYWALKING // The number id of the span. Should be unique in the whole segment. // Starting at 0 // // If type == ZIPKIN // The type of span ID is string. SpanId string `protobuf:"bytes,4,opt,name=spanId,proto3" json:"spanId,omitempty"` } func (x *SpanAttachedEvent_SpanReference) Reset() { *x = SpanAttachedEvent_SpanReference{} if protoimpl.UnsafeEnabled { mi := &file_language_agent_Tracing_proto_msgTypes[7] ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) ms.StoreMessageInfo(mi) } } func (x *SpanAttachedEvent_SpanReference) String() string { return protoimpl.X.MessageStringOf(x) } func (*SpanAttachedEvent_SpanReference) ProtoMessage() {} func (x *SpanAttachedEvent_SpanReference) ProtoReflect() protoreflect.Message { mi := &file_language_agent_Tracing_proto_msgTypes[7] if protoimpl.UnsafeEnabled && x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) } return ms } return mi.MessageOf(x) } // Deprecated: Use SpanAttachedEvent_SpanReference.ProtoReflect.Descriptor instead. func (*SpanAttachedEvent_SpanReference) Descriptor() ([]byte, []int) { return file_language_agent_Tracing_proto_rawDescGZIP(), []int{6, 0} } func (x *SpanAttachedEvent_SpanReference) GetType() SpanAttachedEvent_SpanReferenceType { if x != nil { return x.Type } return SpanAttachedEvent_SKYWALKING } func (x *SpanAttachedEvent_SpanReference) GetTraceId() string { if x != nil { return x.TraceId } return "" } func (x *SpanAttachedEvent_SpanReference) GetTraceSegmentId() string { if x != nil { return x.TraceSegmentId } return "" } func (x *SpanAttachedEvent_SpanReference) GetSpanId() string { if x != nil { return x.SpanId } return "" } var File_language_agent_Tracing_proto protoreflect.FileDescriptor var file_language_agent_Tracing_proto_rawDesc = []byte{ 0x0a, 0x1c, 0x6c, 0x61, 0x6e, 0x67, 0x75, 0x61, 0x67, 0x65, 0x2d, 0x61, 0x67, 0x65, 0x6e, 0x74, 0x2f, 0x54, 0x72, 0x61, 0x63, 0x69, 0x6e, 0x67, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x0d, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x1a, 0x13, 0x63, 0x6f, 0x6d, 0x6d, 0x6f, 0x6e, 0x2f, 0x43, 0x6f, 0x6d, 0x6d, 0x6f, 0x6e, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x1a, 0x14, 0x63, 0x6f, 0x6d, 0x6d, 0x6f, 0x6e, 0x2f, 0x43, 0x6f, 0x6d, 0x6d, 0x61, 0x6e, 0x64, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x22, 0xec, 0x01, 0x0a, 0x0d, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x4f, 0x62, 0x6a, 0x65, 0x63, 0x74, 0x12, 0x18, 0x0a, 0x07, 0x74, 0x72, 0x61, 0x63, 0x65, 0x49, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x74, 0x72, 0x61, 0x63, 0x65, 0x49, 0x64, 0x12, 0x26, 0x0a, 0x0e, 0x74, 0x72, 0x61, 0x63, 0x65, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0e, 0x74, 0x72, 0x61, 0x63, 0x65, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x12, 0x2f, 0x0a, 0x05, 0x73, 0x70, 0x61, 0x6e, 0x73, 0x18, 0x03, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x4f, 0x62, 0x6a, 0x65, 0x63, 0x74, 0x52, 0x05, 0x73, 0x70, 0x61, 0x6e, 0x73, 0x12, 0x18, 0x0a, 0x07, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12, 0x28, 0x0a, 0x0f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x49, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x63, 0x65, 0x18, 0x05, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0f, 0x73, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x49, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x63, 0x65, 0x12, 0x24, 0x0a, 0x0d, 0x69, 0x73, 0x53, 0x69, 0x7a, 0x65, 0x4c, 0x69, 0x6d, 0x69, 0x74, 0x65, 0x64, 0x18, 0x06, 0x20, 0x01, 0x28, 0x08, 0x52, 0x0d, 0x69, 0x73, 0x53, 0x69, 0x7a, 0x65, 0x4c, 0x69, 0x6d, 0x69, 0x74, 0x65, 0x64, 0x22, 0xf6, 0x02, 0x0a, 0x10, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, 0x6e, 0x63, 0x65, 0x12, 0x30, 0x0a, 0x07, 0x72, 0x65, 0x66, 0x54, 0x79, 0x70, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x16, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x52, 0x65, 0x66, 0x54, 0x79, 0x70, 0x65, 0x52, 0x07, 0x72, 0x65, 0x66, 0x54, 0x79, 0x70, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x74, 0x72, 0x61, 0x63, 0x65, 0x49, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x74, 0x72, 0x61, 0x63, 0x65, 0x49, 0x64, 0x12, 0x32, 0x0a, 0x14, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x54, 0x72, 0x61, 0x63, 0x65, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x14, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x54, 0x72, 0x61, 0x63, 0x65, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x12, 0x22, 0x0a, 0x0c, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x18, 0x04, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0c, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x12, 0x24, 0x0a, 0x0d, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x18, 0x05, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0d, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12, 0x34, 0x0a, 0x15, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x49, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x63, 0x65, 0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x52, 0x15, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x49, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x63, 0x65, 0x12, 0x26, 0x0a, 0x0e, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x45, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x18, 0x07, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0e, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x45, 0x6e, 0x64, 0x70, 0x6f, 0x69, 0x6e, 0x74, 0x12, 0x3a, 0x0a, 0x18, 0x6e, 0x65, 0x74, 0x77, 0x6f, 0x72, 0x6b, 0x41, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x55, 0x73, 0x65, 0x64, 0x41, 0x74, 0x50, 0x65, 0x65, 0x72, 0x18, 0x08, 0x20, 0x01, 0x28, 0x09, 0x52, 0x18, 0x6e, 0x65, 0x74, 0x77, 0x6f, 0x72, 0x6b, 0x41, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x55, 0x73, 0x65, 0x64, 0x41, 0x74, 0x50, 0x65, 0x65, 0x72, 0x22, 0x9b, 0x04, 0x0a, 0x0a, 0x53, 0x70, 0x61, 0x6e, 0x4f, 0x62, 0x6a, 0x65, 0x63, 0x74, 0x12, 0x16, 0x0a, 0x06, 0x73, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x05, 0x52, 0x06, 0x73, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x12, 0x22, 0x0a, 0x0c, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0c, 0x70, 0x61, 0x72, 0x65, 0x6e, 0x74, 0x53, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x12, 0x1c, 0x0a, 0x09, 0x73, 0x74, 0x61, 0x72, 0x74, 0x54, 0x69, 0x6d, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x03, 0x52, 0x09, 0x73, 0x74, 0x61, 0x72, 0x74, 0x54, 0x69, 0x6d, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x65, 0x6e, 0x64, 0x54, 0x69, 0x6d, 0x65, 0x18, 0x04, 0x20, 0x01, 0x28, 0x03, 0x52, 0x07, 0x65, 0x6e, 0x64, 0x54, 0x69, 0x6d, 0x65, 0x12, 0x33, 0x0a, 0x04, 0x72, 0x65, 0x66, 0x73, 0x18, 0x05, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x1f, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, 0x6e, 0x63, 0x65, 0x52, 0x04, 0x72, 0x65, 0x66, 0x73, 0x12, 0x24, 0x0a, 0x0d, 0x6f, 0x70, 0x65, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4e, 0x61, 0x6d, 0x65, 0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0d, 0x6f, 0x70, 0x65, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4e, 0x61, 0x6d, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x70, 0x65, 0x65, 0x72, 0x18, 0x07, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x70, 0x65, 0x65, 0x72, 0x12, 0x33, 0x0a, 0x08, 0x73, 0x70, 0x61, 0x6e, 0x54, 0x79, 0x70, 0x65, 0x18, 0x08, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x17, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x54, 0x79, 0x70, 0x65, 0x52, 0x08, 0x73, 0x70, 0x61, 0x6e, 0x54, 0x79, 0x70, 0x65, 0x12, 0x36, 0x0a, 0x09, 0x73, 0x70, 0x61, 0x6e, 0x4c, 0x61, 0x79, 0x65, 0x72, 0x18, 0x09, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x18, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x4c, 0x61, 0x79, 0x65, 0x72, 0x52, 0x09, 0x73, 0x70, 0x61, 0x6e, 0x4c, 0x61, 0x79, 0x65, 0x72, 0x12, 0x20, 0x0a, 0x0b, 0x63, 0x6f, 0x6d, 0x70, 0x6f, 0x6e, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x18, 0x0a, 0x20, 0x01, 0x28, 0x05, 0x52, 0x0b, 0x63, 0x6f, 0x6d, 0x70, 0x6f, 0x6e, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x12, 0x18, 0x0a, 0x07, 0x69, 0x73, 0x45, 0x72, 0x72, 0x6f, 0x72, 0x18, 0x0b, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x69, 0x73, 0x45, 0x72, 0x72, 0x6f, 0x72, 0x12, 0x35, 0x0a, 0x04, 0x74, 0x61, 0x67, 0x73, 0x18, 0x0c, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x21, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x4b, 0x65, 0x79, 0x53, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x56, 0x61, 0x6c, 0x75, 0x65, 0x50, 0x61, 0x69, 0x72, 0x52, 0x04, 0x74, 0x61, 0x67, 0x73, 0x12, 0x26, 0x0a, 0x04, 0x6c, 0x6f, 0x67, 0x73, 0x18, 0x0d, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x12, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x4c, 0x6f, 0x67, 0x52, 0x04, 0x6c, 0x6f, 0x67, 0x73, 0x12, 0x22, 0x0a, 0x0c, 0x73, 0x6b, 0x69, 0x70, 0x41, 0x6e, 0x61, 0x6c, 0x79, 0x73, 0x69, 0x73, 0x18, 0x0e, 0x20, 0x01, 0x28, 0x08, 0x52, 0x0c, 0x73, 0x6b, 0x69, 0x70, 0x41, 0x6e, 0x61, 0x6c, 0x79, 0x73, 0x69, 0x73, 0x22, 0x50, 0x0a, 0x03, 0x4c, 0x6f, 0x67, 0x12, 0x12, 0x0a, 0x04, 0x74, 0x69, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x03, 0x52, 0x04, 0x74, 0x69, 0x6d, 0x65, 0x12, 0x35, 0x0a, 0x04, 0x64, 0x61, 0x74, 0x61, 0x18, 0x02, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x21, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x4b, 0x65, 0x79, 0x53, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x56, 0x61, 0x6c, 0x75, 0x65, 0x50, 0x61, 0x69, 0x72, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0x14, 0x0a, 0x02, 0x49, 0x44, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, 0x20, 0x03, 0x28, 0x09, 0x52, 0x02, 0x69, 0x64, 0x22, 0x4d, 0x0a, 0x11, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x38, 0x0a, 0x08, 0x73, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x1c, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x4f, 0x62, 0x6a, 0x65, 0x63, 0x74, 0x52, 0x08, 0x73, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x73, 0x22, 0xbb, 0x04, 0x0a, 0x11, 0x53, 0x70, 0x61, 0x6e, 0x41, 0x74, 0x74, 0x61, 0x63, 0x68, 0x65, 0x64, 0x45, 0x76, 0x65, 0x6e, 0x74, 0x12, 0x34, 0x0a, 0x09, 0x73, 0x74, 0x61, 0x72, 0x74, 0x54, 0x69, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x16, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x49, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x74, 0x52, 0x09, 0x73, 0x74, 0x61, 0x72, 0x74, 0x54, 0x69, 0x6d, 0x65, 0x12, 0x14, 0x0a, 0x05, 0x65, 0x76, 0x65, 0x6e, 0x74, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x65, 0x76, 0x65, 0x6e, 0x74, 0x12, 0x30, 0x0a, 0x07, 0x65, 0x6e, 0x64, 0x54, 0x69, 0x6d, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x16, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x49, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x74, 0x52, 0x07, 0x65, 0x6e, 0x64, 0x54, 0x69, 0x6d, 0x65, 0x12, 0x35, 0x0a, 0x04, 0x74, 0x61, 0x67, 0x73, 0x18, 0x04, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x21, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x4b, 0x65, 0x79, 0x53, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x56, 0x61, 0x6c, 0x75, 0x65, 0x50, 0x61, 0x69, 0x72, 0x52, 0x04, 0x74, 0x61, 0x67, 0x73, 0x12, 0x38, 0x0a, 0x07, 0x73, 0x75, 0x6d, 0x6d, 0x61, 0x72, 0x79, 0x18, 0x05, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x1e, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x4b, 0x65, 0x79, 0x49, 0x6e, 0x74, 0x56, 0x61, 0x6c, 0x75, 0x65, 0x50, 0x61, 0x69, 0x72, 0x52, 0x07, 0x73, 0x75, 0x6d, 0x6d, 0x61, 0x72, 0x79, 0x12, 0x52, 0x0a, 0x0c, 0x74, 0x72, 0x61, 0x63, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x78, 0x74, 0x18, 0x06, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x2e, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x41, 0x74, 0x74, 0x61, 0x63, 0x68, 0x65, 0x64, 0x45, 0x76, 0x65, 0x6e, 0x74, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, 0x6e, 0x63, 0x65, 0x52, 0x0c, 0x74, 0x72, 0x61, 0x63, 0x65, 0x43, 0x6f, 0x6e, 0x74, 0x65, 0x78, 0x74, 0x1a, 0xb1, 0x01, 0x0a, 0x0d, 0x53, 0x70, 0x61, 0x6e, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, 0x6e, 0x63, 0x65, 0x12, 0x46, 0x0a, 0x04, 0x74, 0x79, 0x70, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x32, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x41, 0x74, 0x74, 0x61, 0x63, 0x68, 0x65, 0x64, 0x45, 0x76, 0x65, 0x6e, 0x74, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, 0x6e, 0x63, 0x65, 0x54, 0x79, 0x70, 0x65, 0x52, 0x04, 0x74, 0x79, 0x70, 0x65, 0x12, 0x18, 0x0a, 0x07, 0x74, 0x72, 0x61, 0x63, 0x65, 0x49, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x74, 0x72, 0x61, 0x63, 0x65, 0x49, 0x64, 0x12, 0x26, 0x0a, 0x0e, 0x74, 0x72, 0x61, 0x63, 0x65, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0e, 0x74, 0x72, 0x61, 0x63, 0x65, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x49, 0x64, 0x12, 0x16, 0x0a, 0x06, 0x73, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x52, 0x06, 0x73, 0x70, 0x61, 0x6e, 0x49, 0x64, 0x22, 0x2f, 0x0a, 0x11, 0x53, 0x70, 0x61, 0x6e, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, 0x6e, 0x63, 0x65, 0x54, 0x79, 0x70, 0x65, 0x12, 0x0e, 0x0a, 0x0a, 0x53, 0x4b, 0x59, 0x57, 0x41, 0x4c, 0x4b, 0x49, 0x4e, 0x47, 0x10, 0x00, 0x12, 0x0a, 0x0a, 0x06, 0x5a, 0x49, 0x50, 0x4b, 0x49, 0x4e, 0x10, 0x01, 0x2a, 0x2a, 0x0a, 0x08, 0x53, 0x70, 0x61, 0x6e, 0x54, 0x79, 0x70, 0x65, 0x12, 0x09, 0x0a, 0x05, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x10, 0x00, 0x12, 0x08, 0x0a, 0x04, 0x45, 0x78, 0x69, 0x74, 0x10, 0x01, 0x12, 0x09, 0x0a, 0x05, 0x4c, 0x6f, 0x63, 0x61, 0x6c, 0x10, 0x02, 0x2a, 0x2c, 0x0a, 0x07, 0x52, 0x65, 0x66, 0x54, 0x79, 0x70, 0x65, 0x12, 0x10, 0x0a, 0x0c, 0x43, 0x72, 0x6f, 0x73, 0x73, 0x50, 0x72, 0x6f, 0x63, 0x65, 0x73, 0x73, 0x10, 0x00, 0x12, 0x0f, 0x0a, 0x0b, 0x43, 0x72, 0x6f, 0x73, 0x73, 0x54, 0x68, 0x72, 0x65, 0x61, 0x64, 0x10, 0x01, 0x2a, 0x5f, 0x0a, 0x09, 0x53, 0x70, 0x61, 0x6e, 0x4c, 0x61, 0x79, 0x65, 0x72, 0x12, 0x0b, 0x0a, 0x07, 0x55, 0x6e, 0x6b, 0x6e, 0x6f, 0x77, 0x6e, 0x10, 0x00, 0x12, 0x0c, 0x0a, 0x08, 0x44, 0x61, 0x74, 0x61, 0x62, 0x61, 0x73, 0x65, 0x10, 0x01, 0x12, 0x10, 0x0a, 0x0c, 0x52, 0x50, 0x43, 0x46, 0x72, 0x61, 0x6d, 0x65, 0x77, 0x6f, 0x72, 0x6b, 0x10, 0x02, 0x12, 0x08, 0x0a, 0x04, 0x48, 0x74, 0x74, 0x70, 0x10, 0x03, 0x12, 0x06, 0x0a, 0x02, 0x4d, 0x51, 0x10, 0x04, 0x12, 0x09, 0x0a, 0x05, 0x43, 0x61, 0x63, 0x68, 0x65, 0x10, 0x05, 0x12, 0x08, 0x0a, 0x04, 0x46, 0x41, 0x41, 0x53, 0x10, 0x06, 0x32, 0xaf, 0x01, 0x0a, 0x19, 0x54, 0x72, 0x61, 0x63, 0x65, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x52, 0x65, 0x70, 0x6f, 0x72, 0x74, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12, 0x44, 0x0a, 0x07, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x12, 0x1c, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x4f, 0x62, 0x6a, 0x65, 0x63, 0x74, 0x1a, 0x17, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x43, 0x6f, 0x6d, 0x6d, 0x61, 0x6e, 0x64, 0x73, 0x22, 0x00, 0x28, 0x01, 0x12, 0x4c, 0x0a, 0x0d, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x49, 0x6e, 0x53, 0x79, 0x6e, 0x63, 0x12, 0x20, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x65, 0x67, 0x6d, 0x65, 0x6e, 0x74, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x1a, 0x17, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x43, 0x6f, 0x6d, 0x6d, 0x61, 0x6e, 0x64, 0x73, 0x22, 0x00, 0x32, 0x6a, 0x0a, 0x1e, 0x53, 0x70, 0x61, 0x6e, 0x41, 0x74, 0x74, 0x61, 0x63, 0x68, 0x65, 0x64, 0x45, 0x76, 0x65, 0x6e, 0x74, 0x52, 0x65, 0x70, 0x6f, 0x72, 0x74, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12, 0x48, 0x0a, 0x07, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x12, 0x20, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x53, 0x70, 0x61, 0x6e, 0x41, 0x74, 0x74, 0x61, 0x63, 0x68, 0x65, 0x64, 0x45, 0x76, 0x65, 0x6e, 0x74, 0x1a, 0x17, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x76, 0x33, 0x2e, 0x43, 0x6f, 0x6d, 0x6d, 0x61, 0x6e, 0x64, 0x73, 0x22, 0x00, 0x28, 0x01, 0x42, 0x93, 0x01, 0x0a, 0x33, 0x6f, 0x72, 0x67, 0x2e, 0x61, 0x70, 0x61, 0x63, 0x68, 0x65, 0x2e, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x61, 0x70, 0x6d, 0x2e, 0x6e, 0x65, 0x74, 0x77, 0x6f, 0x72, 0x6b, 0x2e, 0x6c, 0x61, 0x6e, 0x67, 0x75, 0x61, 0x67, 0x65, 0x2e, 0x61, 0x67, 0x65, 0x6e, 0x74, 0x2e, 0x76, 0x33, 0x50, 0x01, 0x5a, 0x3a, 0x73, 0x6b, 0x79, 0x77, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x61, 0x70, 0x61, 0x63, 0x68, 0x65, 0x2e, 0x6f, 0x72, 0x67, 0x2f, 0x72, 0x65, 0x70, 0x6f, 0x2f, 0x67, 0x6f, 0x61, 0x70, 0x69, 0x2f, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x2f, 0x6c, 0x61, 0x6e, 0x67, 0x75, 0x61, 0x67, 0x65, 0x2f, 0x61, 0x67, 0x65, 0x6e, 0x74, 0x2f, 0x76, 0x33, 0xaa, 0x02, 0x1d, 0x53, 0x6b, 0x79, 0x57, 0x61, 0x6c, 0x6b, 0x69, 0x6e, 0x67, 0x2e, 0x4e, 0x65, 0x74, 0x77, 0x6f, 0x72, 0x6b, 0x50, 0x72, 0x6f, 0x74, 0x6f, 0x63, 0x6f, 0x6c, 0x2e, 0x56, 0x33, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, } var ( file_language_agent_Tracing_proto_rawDescOnce sync.Once file_language_agent_Tracing_proto_rawDescData = file_language_agent_Tracing_proto_rawDesc ) func file_language_agent_Tracing_proto_rawDescGZIP() []byte { file_language_agent_Tracing_proto_rawDescOnce.Do(func() { file_language_agent_Tracing_proto_rawDescData = protoimpl.X.CompressGZIP(file_language_agent_Tracing_proto_rawDescData) }) return file_language_agent_Tracing_proto_rawDescData } var file_language_agent_Tracing_proto_enumTypes = make([]protoimpl.EnumInfo, 4) var file_language_agent_Tracing_proto_msgTypes = make([]protoimpl.MessageInfo, 8) var file_language_agent_Tracing_proto_goTypes = []interface{}{ (SpanType)(0), // 0: skywalking.v3.SpanType (RefType)(0), // 1: skywalking.v3.RefType (SpanLayer)(0), // 2: skywalking.v3.SpanLayer (SpanAttachedEvent_SpanReferenceType)(0), // 3: skywalking.v3.SpanAttachedEvent.SpanReferenceType (*SegmentObject)(nil), // 4: skywalking.v3.SegmentObject (*SegmentReference)(nil), // 5: skywalking.v3.SegmentReference (*SpanObject)(nil), // 6: skywalking.v3.SpanObject (*Log)(nil), // 7: skywalking.v3.Log (*ID)(nil), // 8: skywalking.v3.ID (*SegmentCollection)(nil), // 9: skywalking.v3.SegmentCollection (*SpanAttachedEvent)(nil), // 10: skywalking.v3.SpanAttachedEvent (*SpanAttachedEvent_SpanReference)(nil), // 11: skywalking.v3.SpanAttachedEvent.SpanReference (*v3.KeyStringValuePair)(nil), // 12: skywalking.v3.KeyStringValuePair (*v3.Instant)(nil), // 13: skywalking.v3.Instant (*v3.KeyIntValuePair)(nil), // 14: skywalking.v3.KeyIntValuePair (*v3.Commands)(nil), // 15: skywalking.v3.Commands } var file_language_agent_Tracing_proto_depIdxs = []int32{ 6, // 0: skywalking.v3.SegmentObject.spans:type_name -> skywalking.v3.SpanObject 1, // 1: skywalking.v3.SegmentReference.refType:type_name -> skywalking.v3.RefType 5, // 2: skywalking.v3.SpanObject.refs:type_name -> skywalking.v3.SegmentReference 0, // 3: skywalking.v3.SpanObject.spanType:type_name -> skywalking.v3.SpanType 2, // 4: skywalking.v3.SpanObject.spanLayer:type_name -> skywalking.v3.SpanLayer 12, // 5: skywalking.v3.SpanObject.tags:type_name -> skywalking.v3.KeyStringValuePair 7, // 6: skywalking.v3.SpanObject.logs:type_name -> skywalking.v3.Log 12, // 7: skywalking.v3.Log.data:type_name -> skywalking.v3.KeyStringValuePair 4, // 8: skywalking.v3.SegmentCollection.segments:type_name -> skywalking.v3.SegmentObject 13, // 9: skywalking.v3.SpanAttachedEvent.startTime:type_name -> skywalking.v3.Instant 13, // 10: skywalking.v3.SpanAttachedEvent.endTime:type_name -> skywalking.v3.Instant 12, // 11: skywalking.v3.SpanAttachedEvent.tags:type_name -> skywalking.v3.KeyStringValuePair 14, // 12: skywalking.v3.SpanAttachedEvent.summary:type_name -> skywalking.v3.KeyIntValuePair 11, // 13: skywalking.v3.SpanAttachedEvent.traceContext:type_name -> skywalking.v3.SpanAttachedEvent.SpanReference 3, // 14: skywalking.v3.SpanAttachedEvent.SpanReference.type:type_name -> skywalking.v3.SpanAttachedEvent.SpanReferenceType 4, // 15: skywalking.v3.TraceSegmentReportService.collect:input_type -> skywalking.v3.SegmentObject 9, // 16: skywalking.v3.TraceSegmentReportService.collectInSync:input_type -> skywalking.v3.SegmentCollection 10, // 17: skywalking.v3.SpanAttachedEventReportService.collect:input_type -> skywalking.v3.SpanAttachedEvent 15, // 18: skywalking.v3.TraceSegmentReportService.collect:output_type -> skywalking.v3.Commands 15, // 19: skywalking.v3.TraceSegmentReportService.collectInSync:output_type -> skywalking.v3.Commands 15, // 20: skywalking.v3.SpanAttachedEventReportService.collect:output_type -> skywalking.v3.Commands 18, // [18:21] is the sub-list for method output_type 15, // [15:18] is the sub-list for method input_type 15, // [15:15] is the sub-list for extension type_name 15, // [15:15] is the sub-list for extension extendee 0, // [0:15] is the sub-list for field type_name } func init() { file_language_agent_Tracing_proto_init() } func file_language_agent_Tracing_proto_init() { if File_language_agent_Tracing_proto != nil { return } if !protoimpl.UnsafeEnabled { file_language_agent_Tracing_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*SegmentObject); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } file_language_agent_Tracing_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*SegmentReference); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } file_language_agent_Tracing_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*SpanObject); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } file_language_agent_Tracing_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*Log); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } file_language_agent_Tracing_proto_msgTypes[4].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*ID); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } file_language_agent_Tracing_proto_msgTypes[5].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*SegmentCollection); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } file_language_agent_Tracing_proto_msgTypes[6].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*SpanAttachedEvent); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } file_language_agent_Tracing_proto_msgTypes[7].Exporter = func(v interface{}, i int) interface{} { switch v := v.(*SpanAttachedEvent_SpanReference); i { case 0: return &v.state case 1: return &v.sizeCache case 2: return &v.unknownFields default: return nil } } } type x struct{} out := protoimpl.TypeBuilder{ File: protoimpl.DescBuilder{ GoPackagePath: reflect.TypeOf(x{}).PkgPath(), RawDescriptor: file_language_agent_Tracing_proto_rawDesc, NumEnums: 4, NumMessages: 8, NumExtensions: 0, NumServices: 2, }, GoTypes: file_language_agent_Tracing_proto_goTypes, DependencyIndexes: file_language_agent_Tracing_proto_depIdxs, EnumInfos: file_language_agent_Tracing_proto_enumTypes, MessageInfos: file_language_agent_Tracing_proto_msgTypes, }.Build() File_language_agent_Tracing_proto = out.File file_language_agent_Tracing_proto_rawDesc = nil file_language_agent_Tracing_proto_goTypes = nil file_language_agent_Tracing_proto_depIdxs = nil }