You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							4563 lines
						
					
					
						
							164 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							4563 lines
						
					
					
						
							164 KiB
						
					
					
				| // Code generated by protoc-gen-go. DO NOT EDIT. | |
| // versions: | |
| // 	protoc-gen-go v1.24.0 | |
| // 	protoc        v3.12.3 | |
| // source: master.proto | |
|  | |
| package master_pb | |
| 
 | |
| import ( | |
| 	context "context" | |
| 	proto "github.com/golang/protobuf/proto" | |
| 	grpc "google.golang.org/grpc" | |
| 	codes "google.golang.org/grpc/codes" | |
| 	status "google.golang.org/grpc/status" | |
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | |
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | |
| 	reflect "reflect" | |
| 	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) | |
| ) | |
| 
 | |
| // This is a compile-time assertion that a sufficiently up-to-date version | |
| // of the legacy proto package is being used. | |
| const _ = proto.ProtoPackageIsVersion4 | |
| 
 | |
| type Heartbeat struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Ip             string                      `protobuf:"bytes,1,opt,name=ip,proto3" json:"ip,omitempty"` | |
| 	Port           uint32                      `protobuf:"varint,2,opt,name=port,proto3" json:"port,omitempty"` | |
| 	PublicUrl      string                      `protobuf:"bytes,3,opt,name=public_url,json=publicUrl,proto3" json:"public_url,omitempty"` | |
| 	MaxVolumeCount uint32                      `protobuf:"varint,4,opt,name=max_volume_count,json=maxVolumeCount,proto3" json:"max_volume_count,omitempty"` | |
| 	MaxFileKey     uint64                      `protobuf:"varint,5,opt,name=max_file_key,json=maxFileKey,proto3" json:"max_file_key,omitempty"` | |
| 	DataCenter     string                      `protobuf:"bytes,6,opt,name=data_center,json=dataCenter,proto3" json:"data_center,omitempty"` | |
| 	Rack           string                      `protobuf:"bytes,7,opt,name=rack,proto3" json:"rack,omitempty"` | |
| 	AdminPort      uint32                      `protobuf:"varint,8,opt,name=admin_port,json=adminPort,proto3" json:"admin_port,omitempty"` | |
| 	Volumes        []*VolumeInformationMessage `protobuf:"bytes,9,rep,name=volumes,proto3" json:"volumes,omitempty"` | |
| 	// delta volumes | |
| 	NewVolumes     []*VolumeShortInformationMessage `protobuf:"bytes,10,rep,name=new_volumes,json=newVolumes,proto3" json:"new_volumes,omitempty"` | |
| 	DeletedVolumes []*VolumeShortInformationMessage `protobuf:"bytes,11,rep,name=deleted_volumes,json=deletedVolumes,proto3" json:"deleted_volumes,omitempty"` | |
| 	HasNoVolumes   bool                             `protobuf:"varint,12,opt,name=has_no_volumes,json=hasNoVolumes,proto3" json:"has_no_volumes,omitempty"` | |
| 	// erasure coding | |
| 	EcShards []*VolumeEcShardInformationMessage `protobuf:"bytes,16,rep,name=ec_shards,json=ecShards,proto3" json:"ec_shards,omitempty"` | |
| 	// delta erasure coding shards | |
| 	NewEcShards     []*VolumeEcShardInformationMessage `protobuf:"bytes,17,rep,name=new_ec_shards,json=newEcShards,proto3" json:"new_ec_shards,omitempty"` | |
| 	DeletedEcShards []*VolumeEcShardInformationMessage `protobuf:"bytes,18,rep,name=deleted_ec_shards,json=deletedEcShards,proto3" json:"deleted_ec_shards,omitempty"` | |
| 	HasNoEcShards   bool                               `protobuf:"varint,19,opt,name=has_no_ec_shards,json=hasNoEcShards,proto3" json:"has_no_ec_shards,omitempty"` | |
| } | |
| 
 | |
| func (x *Heartbeat) Reset() { | |
| 	*x = Heartbeat{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[0] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *Heartbeat) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*Heartbeat) ProtoMessage() {} | |
| 
 | |
| func (x *Heartbeat) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 Heartbeat.ProtoReflect.Descriptor instead. | |
| func (*Heartbeat) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{0} | |
| } | |
| 
 | |
| func (x *Heartbeat) GetIp() string { | |
| 	if x != nil { | |
| 		return x.Ip | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *Heartbeat) GetPort() uint32 { | |
| 	if x != nil { | |
| 		return x.Port | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *Heartbeat) GetPublicUrl() string { | |
| 	if x != nil { | |
| 		return x.PublicUrl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *Heartbeat) GetMaxVolumeCount() uint32 { | |
| 	if x != nil { | |
| 		return x.MaxVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *Heartbeat) GetMaxFileKey() uint64 { | |
| 	if x != nil { | |
| 		return x.MaxFileKey | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *Heartbeat) GetDataCenter() string { | |
| 	if x != nil { | |
| 		return x.DataCenter | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *Heartbeat) GetRack() string { | |
| 	if x != nil { | |
| 		return x.Rack | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *Heartbeat) GetAdminPort() uint32 { | |
| 	if x != nil { | |
| 		return x.AdminPort | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *Heartbeat) GetVolumes() []*VolumeInformationMessage { | |
| 	if x != nil { | |
| 		return x.Volumes | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *Heartbeat) GetNewVolumes() []*VolumeShortInformationMessage { | |
| 	if x != nil { | |
| 		return x.NewVolumes | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *Heartbeat) GetDeletedVolumes() []*VolumeShortInformationMessage { | |
| 	if x != nil { | |
| 		return x.DeletedVolumes | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *Heartbeat) GetHasNoVolumes() bool { | |
| 	if x != nil { | |
| 		return x.HasNoVolumes | |
| 	} | |
| 	return false | |
| } | |
| 
 | |
| func (x *Heartbeat) GetEcShards() []*VolumeEcShardInformationMessage { | |
| 	if x != nil { | |
| 		return x.EcShards | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *Heartbeat) GetNewEcShards() []*VolumeEcShardInformationMessage { | |
| 	if x != nil { | |
| 		return x.NewEcShards | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *Heartbeat) GetDeletedEcShards() []*VolumeEcShardInformationMessage { | |
| 	if x != nil { | |
| 		return x.DeletedEcShards | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *Heartbeat) GetHasNoEcShards() bool { | |
| 	if x != nil { | |
| 		return x.HasNoEcShards | |
| 	} | |
| 	return false | |
| } | |
| 
 | |
| type HeartbeatResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	VolumeSizeLimit        uint64            `protobuf:"varint,1,opt,name=volume_size_limit,json=volumeSizeLimit,proto3" json:"volume_size_limit,omitempty"` | |
| 	Leader                 string            `protobuf:"bytes,2,opt,name=leader,proto3" json:"leader,omitempty"` | |
| 	MetricsAddress         string            `protobuf:"bytes,3,opt,name=metrics_address,json=metricsAddress,proto3" json:"metrics_address,omitempty"` | |
| 	MetricsIntervalSeconds uint32            `protobuf:"varint,4,opt,name=metrics_interval_seconds,json=metricsIntervalSeconds,proto3" json:"metrics_interval_seconds,omitempty"` | |
| 	StorageBackends        []*StorageBackend `protobuf:"bytes,5,rep,name=storage_backends,json=storageBackends,proto3" json:"storage_backends,omitempty"` | |
| } | |
| 
 | |
| func (x *HeartbeatResponse) Reset() { | |
| 	*x = HeartbeatResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[1] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *HeartbeatResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*HeartbeatResponse) ProtoMessage() {} | |
| 
 | |
| func (x *HeartbeatResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 HeartbeatResponse.ProtoReflect.Descriptor instead. | |
| func (*HeartbeatResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{1} | |
| } | |
| 
 | |
| func (x *HeartbeatResponse) GetVolumeSizeLimit() uint64 { | |
| 	if x != nil { | |
| 		return x.VolumeSizeLimit | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *HeartbeatResponse) GetLeader() string { | |
| 	if x != nil { | |
| 		return x.Leader | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *HeartbeatResponse) GetMetricsAddress() string { | |
| 	if x != nil { | |
| 		return x.MetricsAddress | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *HeartbeatResponse) GetMetricsIntervalSeconds() uint32 { | |
| 	if x != nil { | |
| 		return x.MetricsIntervalSeconds | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *HeartbeatResponse) GetStorageBackends() []*StorageBackend { | |
| 	if x != nil { | |
| 		return x.StorageBackends | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type VolumeInformationMessage struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Id                uint32 `protobuf:"varint,1,opt,name=id,proto3" json:"id,omitempty"` | |
| 	Size              uint64 `protobuf:"varint,2,opt,name=size,proto3" json:"size,omitempty"` | |
| 	Collection        string `protobuf:"bytes,3,opt,name=collection,proto3" json:"collection,omitempty"` | |
| 	FileCount         uint64 `protobuf:"varint,4,opt,name=file_count,json=fileCount,proto3" json:"file_count,omitempty"` | |
| 	DeleteCount       uint64 `protobuf:"varint,5,opt,name=delete_count,json=deleteCount,proto3" json:"delete_count,omitempty"` | |
| 	DeletedByteCount  uint64 `protobuf:"varint,6,opt,name=deleted_byte_count,json=deletedByteCount,proto3" json:"deleted_byte_count,omitempty"` | |
| 	ReadOnly          bool   `protobuf:"varint,7,opt,name=read_only,json=readOnly,proto3" json:"read_only,omitempty"` | |
| 	ReplicaPlacement  uint32 `protobuf:"varint,8,opt,name=replica_placement,json=replicaPlacement,proto3" json:"replica_placement,omitempty"` | |
| 	Version           uint32 `protobuf:"varint,9,opt,name=version,proto3" json:"version,omitempty"` | |
| 	Ttl               uint32 `protobuf:"varint,10,opt,name=ttl,proto3" json:"ttl,omitempty"` | |
| 	CompactRevision   uint32 `protobuf:"varint,11,opt,name=compact_revision,json=compactRevision,proto3" json:"compact_revision,omitempty"` | |
| 	ModifiedAtSecond  int64  `protobuf:"varint,12,opt,name=modified_at_second,json=modifiedAtSecond,proto3" json:"modified_at_second,omitempty"` | |
| 	RemoteStorageName string `protobuf:"bytes,13,opt,name=remote_storage_name,json=remoteStorageName,proto3" json:"remote_storage_name,omitempty"` | |
| 	RemoteStorageKey  string `protobuf:"bytes,14,opt,name=remote_storage_key,json=remoteStorageKey,proto3" json:"remote_storage_key,omitempty"` | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) Reset() { | |
| 	*x = VolumeInformationMessage{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[2] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*VolumeInformationMessage) ProtoMessage() {} | |
| 
 | |
| func (x *VolumeInformationMessage) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 VolumeInformationMessage.ProtoReflect.Descriptor instead. | |
| func (*VolumeInformationMessage) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{2} | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetId() uint32 { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetSize() uint64 { | |
| 	if x != nil { | |
| 		return x.Size | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetCollection() string { | |
| 	if x != nil { | |
| 		return x.Collection | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetFileCount() uint64 { | |
| 	if x != nil { | |
| 		return x.FileCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetDeleteCount() uint64 { | |
| 	if x != nil { | |
| 		return x.DeleteCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetDeletedByteCount() uint64 { | |
| 	if x != nil { | |
| 		return x.DeletedByteCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetReadOnly() bool { | |
| 	if x != nil { | |
| 		return x.ReadOnly | |
| 	} | |
| 	return false | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetReplicaPlacement() uint32 { | |
| 	if x != nil { | |
| 		return x.ReplicaPlacement | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetVersion() uint32 { | |
| 	if x != nil { | |
| 		return x.Version | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetTtl() uint32 { | |
| 	if x != nil { | |
| 		return x.Ttl | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetCompactRevision() uint32 { | |
| 	if x != nil { | |
| 		return x.CompactRevision | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetModifiedAtSecond() int64 { | |
| 	if x != nil { | |
| 		return x.ModifiedAtSecond | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetRemoteStorageName() string { | |
| 	if x != nil { | |
| 		return x.RemoteStorageName | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *VolumeInformationMessage) GetRemoteStorageKey() string { | |
| 	if x != nil { | |
| 		return x.RemoteStorageKey | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type VolumeShortInformationMessage struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Id               uint32 `protobuf:"varint,1,opt,name=id,proto3" json:"id,omitempty"` | |
| 	Collection       string `protobuf:"bytes,3,opt,name=collection,proto3" json:"collection,omitempty"` | |
| 	ReplicaPlacement uint32 `protobuf:"varint,8,opt,name=replica_placement,json=replicaPlacement,proto3" json:"replica_placement,omitempty"` | |
| 	Version          uint32 `protobuf:"varint,9,opt,name=version,proto3" json:"version,omitempty"` | |
| 	Ttl              uint32 `protobuf:"varint,10,opt,name=ttl,proto3" json:"ttl,omitempty"` | |
| } | |
| 
 | |
| func (x *VolumeShortInformationMessage) Reset() { | |
| 	*x = VolumeShortInformationMessage{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[3] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *VolumeShortInformationMessage) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*VolumeShortInformationMessage) ProtoMessage() {} | |
| 
 | |
| func (x *VolumeShortInformationMessage) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 VolumeShortInformationMessage.ProtoReflect.Descriptor instead. | |
| func (*VolumeShortInformationMessage) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{3} | |
| } | |
| 
 | |
| func (x *VolumeShortInformationMessage) GetId() uint32 { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeShortInformationMessage) GetCollection() string { | |
| 	if x != nil { | |
| 		return x.Collection | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *VolumeShortInformationMessage) GetReplicaPlacement() uint32 { | |
| 	if x != nil { | |
| 		return x.ReplicaPlacement | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeShortInformationMessage) GetVersion() uint32 { | |
| 	if x != nil { | |
| 		return x.Version | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeShortInformationMessage) GetTtl() uint32 { | |
| 	if x != nil { | |
| 		return x.Ttl | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type VolumeEcShardInformationMessage struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Id          uint32 `protobuf:"varint,1,opt,name=id,proto3" json:"id,omitempty"` | |
| 	Collection  string `protobuf:"bytes,2,opt,name=collection,proto3" json:"collection,omitempty"` | |
| 	EcIndexBits uint32 `protobuf:"varint,3,opt,name=ec_index_bits,json=ecIndexBits,proto3" json:"ec_index_bits,omitempty"` | |
| } | |
| 
 | |
| func (x *VolumeEcShardInformationMessage) Reset() { | |
| 	*x = VolumeEcShardInformationMessage{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[4] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *VolumeEcShardInformationMessage) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*VolumeEcShardInformationMessage) ProtoMessage() {} | |
| 
 | |
| func (x *VolumeEcShardInformationMessage) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 VolumeEcShardInformationMessage.ProtoReflect.Descriptor instead. | |
| func (*VolumeEcShardInformationMessage) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{4} | |
| } | |
| 
 | |
| func (x *VolumeEcShardInformationMessage) GetId() uint32 { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *VolumeEcShardInformationMessage) GetCollection() string { | |
| 	if x != nil { | |
| 		return x.Collection | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *VolumeEcShardInformationMessage) GetEcIndexBits() uint32 { | |
| 	if x != nil { | |
| 		return x.EcIndexBits | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type StorageBackend struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Type       string            `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"` | |
| 	Id         string            `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"` | |
| 	Properties map[string]string `protobuf:"bytes,3,rep,name=properties,proto3" json:"properties,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` | |
| } | |
| 
 | |
| func (x *StorageBackend) Reset() { | |
| 	*x = StorageBackend{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[5] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *StorageBackend) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*StorageBackend) ProtoMessage() {} | |
| 
 | |
| func (x *StorageBackend) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 StorageBackend.ProtoReflect.Descriptor instead. | |
| func (*StorageBackend) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{5} | |
| } | |
| 
 | |
| func (x *StorageBackend) GetType() string { | |
| 	if x != nil { | |
| 		return x.Type | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StorageBackend) GetId() string { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StorageBackend) GetProperties() map[string]string { | |
| 	if x != nil { | |
| 		return x.Properties | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type Empty struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| } | |
| 
 | |
| func (x *Empty) Reset() { | |
| 	*x = Empty{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[6] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *Empty) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*Empty) ProtoMessage() {} | |
| 
 | |
| func (x *Empty) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 Empty.ProtoReflect.Descriptor instead. | |
| func (*Empty) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{6} | |
| } | |
| 
 | |
| type SuperBlockExtra struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	ErasureCoding *SuperBlockExtra_ErasureCoding `protobuf:"bytes,1,opt,name=erasure_coding,json=erasureCoding,proto3" json:"erasure_coding,omitempty"` | |
| } | |
| 
 | |
| func (x *SuperBlockExtra) Reset() { | |
| 	*x = SuperBlockExtra{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[7] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *SuperBlockExtra) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*SuperBlockExtra) ProtoMessage() {} | |
| 
 | |
| func (x *SuperBlockExtra) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_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 SuperBlockExtra.ProtoReflect.Descriptor instead. | |
| func (*SuperBlockExtra) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{7} | |
| } | |
| 
 | |
| func (x *SuperBlockExtra) GetErasureCoding() *SuperBlockExtra_ErasureCoding { | |
| 	if x != nil { | |
| 		return x.ErasureCoding | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type KeepConnectedRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Name     string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` | |
| 	GrpcPort uint32 `protobuf:"varint,2,opt,name=grpc_port,json=grpcPort,proto3" json:"grpc_port,omitempty"` | |
| } | |
| 
 | |
| func (x *KeepConnectedRequest) Reset() { | |
| 	*x = KeepConnectedRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[8] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *KeepConnectedRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*KeepConnectedRequest) ProtoMessage() {} | |
| 
 | |
| func (x *KeepConnectedRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[8] | |
| 	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 KeepConnectedRequest.ProtoReflect.Descriptor instead. | |
| func (*KeepConnectedRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{8} | |
| } | |
| 
 | |
| func (x *KeepConnectedRequest) GetName() string { | |
| 	if x != nil { | |
| 		return x.Name | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *KeepConnectedRequest) GetGrpcPort() uint32 { | |
| 	if x != nil { | |
| 		return x.GrpcPort | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type VolumeLocation struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Url         string   `protobuf:"bytes,1,opt,name=url,proto3" json:"url,omitempty"` | |
| 	PublicUrl   string   `protobuf:"bytes,2,opt,name=public_url,json=publicUrl,proto3" json:"public_url,omitempty"` | |
| 	NewVids     []uint32 `protobuf:"varint,3,rep,packed,name=new_vids,json=newVids,proto3" json:"new_vids,omitempty"` | |
| 	DeletedVids []uint32 `protobuf:"varint,4,rep,packed,name=deleted_vids,json=deletedVids,proto3" json:"deleted_vids,omitempty"` | |
| 	Leader      string   `protobuf:"bytes,5,opt,name=leader,proto3" json:"leader,omitempty"` // optional when leader is not itself | |
| } | |
| 
 | |
| func (x *VolumeLocation) Reset() { | |
| 	*x = VolumeLocation{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[9] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *VolumeLocation) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*VolumeLocation) ProtoMessage() {} | |
| 
 | |
| func (x *VolumeLocation) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[9] | |
| 	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 VolumeLocation.ProtoReflect.Descriptor instead. | |
| func (*VolumeLocation) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{9} | |
| } | |
| 
 | |
| func (x *VolumeLocation) GetUrl() string { | |
| 	if x != nil { | |
| 		return x.Url | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *VolumeLocation) GetPublicUrl() string { | |
| 	if x != nil { | |
| 		return x.PublicUrl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *VolumeLocation) GetNewVids() []uint32 { | |
| 	if x != nil { | |
| 		return x.NewVids | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *VolumeLocation) GetDeletedVids() []uint32 { | |
| 	if x != nil { | |
| 		return x.DeletedVids | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *VolumeLocation) GetLeader() string { | |
| 	if x != nil { | |
| 		return x.Leader | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type LookupVolumeRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	VolumeIds  []string `protobuf:"bytes,1,rep,name=volume_ids,json=volumeIds,proto3" json:"volume_ids,omitempty"` | |
| 	Collection string   `protobuf:"bytes,2,opt,name=collection,proto3" json:"collection,omitempty"` // optional, a bit faster if provided. | |
| } | |
| 
 | |
| func (x *LookupVolumeRequest) Reset() { | |
| 	*x = LookupVolumeRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[10] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LookupVolumeRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LookupVolumeRequest) ProtoMessage() {} | |
| 
 | |
| func (x *LookupVolumeRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[10] | |
| 	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 LookupVolumeRequest.ProtoReflect.Descriptor instead. | |
| func (*LookupVolumeRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{10} | |
| } | |
| 
 | |
| func (x *LookupVolumeRequest) GetVolumeIds() []string { | |
| 	if x != nil { | |
| 		return x.VolumeIds | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *LookupVolumeRequest) GetCollection() string { | |
| 	if x != nil { | |
| 		return x.Collection | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type LookupVolumeResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	VolumeIdLocations []*LookupVolumeResponse_VolumeIdLocation `protobuf:"bytes,1,rep,name=volume_id_locations,json=volumeIdLocations,proto3" json:"volume_id_locations,omitempty"` | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse) Reset() { | |
| 	*x = LookupVolumeResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[11] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LookupVolumeResponse) ProtoMessage() {} | |
| 
 | |
| func (x *LookupVolumeResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[11] | |
| 	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 LookupVolumeResponse.ProtoReflect.Descriptor instead. | |
| func (*LookupVolumeResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{11} | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse) GetVolumeIdLocations() []*LookupVolumeResponse_VolumeIdLocation { | |
| 	if x != nil { | |
| 		return x.VolumeIdLocations | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type Location struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Url       string `protobuf:"bytes,1,opt,name=url,proto3" json:"url,omitempty"` | |
| 	PublicUrl string `protobuf:"bytes,2,opt,name=public_url,json=publicUrl,proto3" json:"public_url,omitempty"` | |
| } | |
| 
 | |
| func (x *Location) Reset() { | |
| 	*x = Location{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[12] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *Location) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*Location) ProtoMessage() {} | |
| 
 | |
| func (x *Location) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[12] | |
| 	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 Location.ProtoReflect.Descriptor instead. | |
| func (*Location) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{12} | |
| } | |
| 
 | |
| func (x *Location) GetUrl() string { | |
| 	if x != nil { | |
| 		return x.Url | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *Location) GetPublicUrl() string { | |
| 	if x != nil { | |
| 		return x.PublicUrl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type AssignRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Count               uint64 `protobuf:"varint,1,opt,name=count,proto3" json:"count,omitempty"` | |
| 	Replication         string `protobuf:"bytes,2,opt,name=replication,proto3" json:"replication,omitempty"` | |
| 	Collection          string `protobuf:"bytes,3,opt,name=collection,proto3" json:"collection,omitempty"` | |
| 	Ttl                 string `protobuf:"bytes,4,opt,name=ttl,proto3" json:"ttl,omitempty"` | |
| 	DataCenter          string `protobuf:"bytes,5,opt,name=data_center,json=dataCenter,proto3" json:"data_center,omitempty"` | |
| 	Rack                string `protobuf:"bytes,6,opt,name=rack,proto3" json:"rack,omitempty"` | |
| 	DataNode            string `protobuf:"bytes,7,opt,name=data_node,json=dataNode,proto3" json:"data_node,omitempty"` | |
| 	MemoryMapMaxSizeMb  uint32 `protobuf:"varint,8,opt,name=memory_map_max_size_mb,json=memoryMapMaxSizeMb,proto3" json:"memory_map_max_size_mb,omitempty"` | |
| 	WritableVolumeCount uint32 `protobuf:"varint,9,opt,name=Writable_volume_count,json=WritableVolumeCount,proto3" json:"Writable_volume_count,omitempty"` | |
| } | |
| 
 | |
| func (x *AssignRequest) Reset() { | |
| 	*x = AssignRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[13] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *AssignRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*AssignRequest) ProtoMessage() {} | |
| 
 | |
| func (x *AssignRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[13] | |
| 	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 AssignRequest.ProtoReflect.Descriptor instead. | |
| func (*AssignRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{13} | |
| } | |
| 
 | |
| func (x *AssignRequest) GetCount() uint64 { | |
| 	if x != nil { | |
| 		return x.Count | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *AssignRequest) GetReplication() string { | |
| 	if x != nil { | |
| 		return x.Replication | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignRequest) GetCollection() string { | |
| 	if x != nil { | |
| 		return x.Collection | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignRequest) GetTtl() string { | |
| 	if x != nil { | |
| 		return x.Ttl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignRequest) GetDataCenter() string { | |
| 	if x != nil { | |
| 		return x.DataCenter | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignRequest) GetRack() string { | |
| 	if x != nil { | |
| 		return x.Rack | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignRequest) GetDataNode() string { | |
| 	if x != nil { | |
| 		return x.DataNode | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignRequest) GetMemoryMapMaxSizeMb() uint32 { | |
| 	if x != nil { | |
| 		return x.MemoryMapMaxSizeMb | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *AssignRequest) GetWritableVolumeCount() uint32 { | |
| 	if x != nil { | |
| 		return x.WritableVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type AssignResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Fid       string `protobuf:"bytes,1,opt,name=fid,proto3" json:"fid,omitempty"` | |
| 	Url       string `protobuf:"bytes,2,opt,name=url,proto3" json:"url,omitempty"` | |
| 	PublicUrl string `protobuf:"bytes,3,opt,name=public_url,json=publicUrl,proto3" json:"public_url,omitempty"` | |
| 	Count     uint64 `protobuf:"varint,4,opt,name=count,proto3" json:"count,omitempty"` | |
| 	Error     string `protobuf:"bytes,5,opt,name=error,proto3" json:"error,omitempty"` | |
| 	Auth      string `protobuf:"bytes,6,opt,name=auth,proto3" json:"auth,omitempty"` | |
| } | |
| 
 | |
| func (x *AssignResponse) Reset() { | |
| 	*x = AssignResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[14] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *AssignResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*AssignResponse) ProtoMessage() {} | |
| 
 | |
| func (x *AssignResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[14] | |
| 	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 AssignResponse.ProtoReflect.Descriptor instead. | |
| func (*AssignResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{14} | |
| } | |
| 
 | |
| func (x *AssignResponse) GetFid() string { | |
| 	if x != nil { | |
| 		return x.Fid | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignResponse) GetUrl() string { | |
| 	if x != nil { | |
| 		return x.Url | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignResponse) GetPublicUrl() string { | |
| 	if x != nil { | |
| 		return x.PublicUrl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignResponse) GetCount() uint64 { | |
| 	if x != nil { | |
| 		return x.Count | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *AssignResponse) GetError() string { | |
| 	if x != nil { | |
| 		return x.Error | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *AssignResponse) GetAuth() string { | |
| 	if x != nil { | |
| 		return x.Auth | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type StatisticsRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Replication string `protobuf:"bytes,1,opt,name=replication,proto3" json:"replication,omitempty"` | |
| 	Collection  string `protobuf:"bytes,2,opt,name=collection,proto3" json:"collection,omitempty"` | |
| 	Ttl         string `protobuf:"bytes,3,opt,name=ttl,proto3" json:"ttl,omitempty"` | |
| } | |
| 
 | |
| func (x *StatisticsRequest) Reset() { | |
| 	*x = StatisticsRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[15] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *StatisticsRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*StatisticsRequest) ProtoMessage() {} | |
| 
 | |
| func (x *StatisticsRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[15] | |
| 	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 StatisticsRequest.ProtoReflect.Descriptor instead. | |
| func (*StatisticsRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{15} | |
| } | |
| 
 | |
| func (x *StatisticsRequest) GetReplication() string { | |
| 	if x != nil { | |
| 		return x.Replication | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StatisticsRequest) GetCollection() string { | |
| 	if x != nil { | |
| 		return x.Collection | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StatisticsRequest) GetTtl() string { | |
| 	if x != nil { | |
| 		return x.Ttl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type StatisticsResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Replication string `protobuf:"bytes,1,opt,name=replication,proto3" json:"replication,omitempty"` | |
| 	Collection  string `protobuf:"bytes,2,opt,name=collection,proto3" json:"collection,omitempty"` | |
| 	Ttl         string `protobuf:"bytes,3,opt,name=ttl,proto3" json:"ttl,omitempty"` | |
| 	TotalSize   uint64 `protobuf:"varint,4,opt,name=total_size,json=totalSize,proto3" json:"total_size,omitempty"` | |
| 	UsedSize    uint64 `protobuf:"varint,5,opt,name=used_size,json=usedSize,proto3" json:"used_size,omitempty"` | |
| 	FileCount   uint64 `protobuf:"varint,6,opt,name=file_count,json=fileCount,proto3" json:"file_count,omitempty"` | |
| } | |
| 
 | |
| func (x *StatisticsResponse) Reset() { | |
| 	*x = StatisticsResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[16] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *StatisticsResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*StatisticsResponse) ProtoMessage() {} | |
| 
 | |
| func (x *StatisticsResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[16] | |
| 	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 StatisticsResponse.ProtoReflect.Descriptor instead. | |
| func (*StatisticsResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{16} | |
| } | |
| 
 | |
| func (x *StatisticsResponse) GetReplication() string { | |
| 	if x != nil { | |
| 		return x.Replication | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StatisticsResponse) GetCollection() string { | |
| 	if x != nil { | |
| 		return x.Collection | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StatisticsResponse) GetTtl() string { | |
| 	if x != nil { | |
| 		return x.Ttl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StatisticsResponse) GetTotalSize() uint64 { | |
| 	if x != nil { | |
| 		return x.TotalSize | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *StatisticsResponse) GetUsedSize() uint64 { | |
| 	if x != nil { | |
| 		return x.UsedSize | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *StatisticsResponse) GetFileCount() uint64 { | |
| 	if x != nil { | |
| 		return x.FileCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type StorageType struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Replication string `protobuf:"bytes,1,opt,name=replication,proto3" json:"replication,omitempty"` | |
| 	Ttl         string `protobuf:"bytes,2,opt,name=ttl,proto3" json:"ttl,omitempty"` | |
| } | |
| 
 | |
| func (x *StorageType) Reset() { | |
| 	*x = StorageType{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[17] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *StorageType) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*StorageType) ProtoMessage() {} | |
| 
 | |
| func (x *StorageType) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[17] | |
| 	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 StorageType.ProtoReflect.Descriptor instead. | |
| func (*StorageType) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{17} | |
| } | |
| 
 | |
| func (x *StorageType) GetReplication() string { | |
| 	if x != nil { | |
| 		return x.Replication | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *StorageType) GetTtl() string { | |
| 	if x != nil { | |
| 		return x.Ttl | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type Collection struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` | |
| } | |
| 
 | |
| func (x *Collection) Reset() { | |
| 	*x = Collection{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[18] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *Collection) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*Collection) ProtoMessage() {} | |
| 
 | |
| func (x *Collection) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[18] | |
| 	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 Collection.ProtoReflect.Descriptor instead. | |
| func (*Collection) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{18} | |
| } | |
| 
 | |
| func (x *Collection) GetName() string { | |
| 	if x != nil { | |
| 		return x.Name | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type CollectionListRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	IncludeNormalVolumes bool `protobuf:"varint,1,opt,name=include_normal_volumes,json=includeNormalVolumes,proto3" json:"include_normal_volumes,omitempty"` | |
| 	IncludeEcVolumes     bool `protobuf:"varint,2,opt,name=include_ec_volumes,json=includeEcVolumes,proto3" json:"include_ec_volumes,omitempty"` | |
| } | |
| 
 | |
| func (x *CollectionListRequest) Reset() { | |
| 	*x = CollectionListRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[19] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *CollectionListRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*CollectionListRequest) ProtoMessage() {} | |
| 
 | |
| func (x *CollectionListRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[19] | |
| 	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 CollectionListRequest.ProtoReflect.Descriptor instead. | |
| func (*CollectionListRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{19} | |
| } | |
| 
 | |
| func (x *CollectionListRequest) GetIncludeNormalVolumes() bool { | |
| 	if x != nil { | |
| 		return x.IncludeNormalVolumes | |
| 	} | |
| 	return false | |
| } | |
| 
 | |
| func (x *CollectionListRequest) GetIncludeEcVolumes() bool { | |
| 	if x != nil { | |
| 		return x.IncludeEcVolumes | |
| 	} | |
| 	return false | |
| } | |
| 
 | |
| type CollectionListResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Collections []*Collection `protobuf:"bytes,1,rep,name=collections,proto3" json:"collections,omitempty"` | |
| } | |
| 
 | |
| func (x *CollectionListResponse) Reset() { | |
| 	*x = CollectionListResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[20] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *CollectionListResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*CollectionListResponse) ProtoMessage() {} | |
| 
 | |
| func (x *CollectionListResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[20] | |
| 	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 CollectionListResponse.ProtoReflect.Descriptor instead. | |
| func (*CollectionListResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{20} | |
| } | |
| 
 | |
| func (x *CollectionListResponse) GetCollections() []*Collection { | |
| 	if x != nil { | |
| 		return x.Collections | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type CollectionDeleteRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` | |
| } | |
| 
 | |
| func (x *CollectionDeleteRequest) Reset() { | |
| 	*x = CollectionDeleteRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[21] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *CollectionDeleteRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*CollectionDeleteRequest) ProtoMessage() {} | |
| 
 | |
| func (x *CollectionDeleteRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[21] | |
| 	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 CollectionDeleteRequest.ProtoReflect.Descriptor instead. | |
| func (*CollectionDeleteRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{21} | |
| } | |
| 
 | |
| func (x *CollectionDeleteRequest) GetName() string { | |
| 	if x != nil { | |
| 		return x.Name | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type CollectionDeleteResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| } | |
| 
 | |
| func (x *CollectionDeleteResponse) Reset() { | |
| 	*x = CollectionDeleteResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[22] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *CollectionDeleteResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*CollectionDeleteResponse) ProtoMessage() {} | |
| 
 | |
| func (x *CollectionDeleteResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[22] | |
| 	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 CollectionDeleteResponse.ProtoReflect.Descriptor instead. | |
| func (*CollectionDeleteResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{22} | |
| } | |
| 
 | |
| // | |
| // volume related | |
| // | |
| type DataNodeInfo struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Id                string                             `protobuf:"bytes,1,opt,name=id,proto3" json:"id,omitempty"` | |
| 	VolumeCount       uint64                             `protobuf:"varint,2,opt,name=volume_count,json=volumeCount,proto3" json:"volume_count,omitempty"` | |
| 	MaxVolumeCount    uint64                             `protobuf:"varint,3,opt,name=max_volume_count,json=maxVolumeCount,proto3" json:"max_volume_count,omitempty"` | |
| 	FreeVolumeCount   uint64                             `protobuf:"varint,4,opt,name=free_volume_count,json=freeVolumeCount,proto3" json:"free_volume_count,omitempty"` | |
| 	ActiveVolumeCount uint64                             `protobuf:"varint,5,opt,name=active_volume_count,json=activeVolumeCount,proto3" json:"active_volume_count,omitempty"` | |
| 	VolumeInfos       []*VolumeInformationMessage        `protobuf:"bytes,6,rep,name=volume_infos,json=volumeInfos,proto3" json:"volume_infos,omitempty"` | |
| 	EcShardInfos      []*VolumeEcShardInformationMessage `protobuf:"bytes,7,rep,name=ec_shard_infos,json=ecShardInfos,proto3" json:"ec_shard_infos,omitempty"` | |
| 	RemoteVolumeCount uint64                             `protobuf:"varint,8,opt,name=remote_volume_count,json=remoteVolumeCount,proto3" json:"remote_volume_count,omitempty"` | |
| } | |
| 
 | |
| func (x *DataNodeInfo) Reset() { | |
| 	*x = DataNodeInfo{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[23] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *DataNodeInfo) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*DataNodeInfo) ProtoMessage() {} | |
| 
 | |
| func (x *DataNodeInfo) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[23] | |
| 	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 DataNodeInfo.ProtoReflect.Descriptor instead. | |
| func (*DataNodeInfo) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{23} | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetId() string { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.VolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetMaxVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.MaxVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetFreeVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.FreeVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetActiveVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.ActiveVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetVolumeInfos() []*VolumeInformationMessage { | |
| 	if x != nil { | |
| 		return x.VolumeInfos | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetEcShardInfos() []*VolumeEcShardInformationMessage { | |
| 	if x != nil { | |
| 		return x.EcShardInfos | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *DataNodeInfo) GetRemoteVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.RemoteVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type RackInfo struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Id                string          `protobuf:"bytes,1,opt,name=id,proto3" json:"id,omitempty"` | |
| 	VolumeCount       uint64          `protobuf:"varint,2,opt,name=volume_count,json=volumeCount,proto3" json:"volume_count,omitempty"` | |
| 	MaxVolumeCount    uint64          `protobuf:"varint,3,opt,name=max_volume_count,json=maxVolumeCount,proto3" json:"max_volume_count,omitempty"` | |
| 	FreeVolumeCount   uint64          `protobuf:"varint,4,opt,name=free_volume_count,json=freeVolumeCount,proto3" json:"free_volume_count,omitempty"` | |
| 	ActiveVolumeCount uint64          `protobuf:"varint,5,opt,name=active_volume_count,json=activeVolumeCount,proto3" json:"active_volume_count,omitempty"` | |
| 	DataNodeInfos     []*DataNodeInfo `protobuf:"bytes,6,rep,name=data_node_infos,json=dataNodeInfos,proto3" json:"data_node_infos,omitempty"` | |
| 	RemoteVolumeCount uint64          `protobuf:"varint,7,opt,name=remote_volume_count,json=remoteVolumeCount,proto3" json:"remote_volume_count,omitempty"` | |
| } | |
| 
 | |
| func (x *RackInfo) Reset() { | |
| 	*x = RackInfo{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[24] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *RackInfo) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*RackInfo) ProtoMessage() {} | |
| 
 | |
| func (x *RackInfo) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[24] | |
| 	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 RackInfo.ProtoReflect.Descriptor instead. | |
| func (*RackInfo) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{24} | |
| } | |
| 
 | |
| func (x *RackInfo) GetId() string { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *RackInfo) GetVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.VolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *RackInfo) GetMaxVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.MaxVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *RackInfo) GetFreeVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.FreeVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *RackInfo) GetActiveVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.ActiveVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *RackInfo) GetDataNodeInfos() []*DataNodeInfo { | |
| 	if x != nil { | |
| 		return x.DataNodeInfos | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *RackInfo) GetRemoteVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.RemoteVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type DataCenterInfo struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Id                string      `protobuf:"bytes,1,opt,name=id,proto3" json:"id,omitempty"` | |
| 	VolumeCount       uint64      `protobuf:"varint,2,opt,name=volume_count,json=volumeCount,proto3" json:"volume_count,omitempty"` | |
| 	MaxVolumeCount    uint64      `protobuf:"varint,3,opt,name=max_volume_count,json=maxVolumeCount,proto3" json:"max_volume_count,omitempty"` | |
| 	FreeVolumeCount   uint64      `protobuf:"varint,4,opt,name=free_volume_count,json=freeVolumeCount,proto3" json:"free_volume_count,omitempty"` | |
| 	ActiveVolumeCount uint64      `protobuf:"varint,5,opt,name=active_volume_count,json=activeVolumeCount,proto3" json:"active_volume_count,omitempty"` | |
| 	RackInfos         []*RackInfo `protobuf:"bytes,6,rep,name=rack_infos,json=rackInfos,proto3" json:"rack_infos,omitempty"` | |
| 	RemoteVolumeCount uint64      `protobuf:"varint,7,opt,name=remote_volume_count,json=remoteVolumeCount,proto3" json:"remote_volume_count,omitempty"` | |
| } | |
| 
 | |
| func (x *DataCenterInfo) Reset() { | |
| 	*x = DataCenterInfo{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[25] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *DataCenterInfo) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*DataCenterInfo) ProtoMessage() {} | |
| 
 | |
| func (x *DataCenterInfo) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[25] | |
| 	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 DataCenterInfo.ProtoReflect.Descriptor instead. | |
| func (*DataCenterInfo) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{25} | |
| } | |
| 
 | |
| func (x *DataCenterInfo) GetId() string { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *DataCenterInfo) GetVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.VolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataCenterInfo) GetMaxVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.MaxVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataCenterInfo) GetFreeVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.FreeVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataCenterInfo) GetActiveVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.ActiveVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *DataCenterInfo) GetRackInfos() []*RackInfo { | |
| 	if x != nil { | |
| 		return x.RackInfos | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *DataCenterInfo) GetRemoteVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.RemoteVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type TopologyInfo struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Id                string            `protobuf:"bytes,1,opt,name=id,proto3" json:"id,omitempty"` | |
| 	VolumeCount       uint64            `protobuf:"varint,2,opt,name=volume_count,json=volumeCount,proto3" json:"volume_count,omitempty"` | |
| 	MaxVolumeCount    uint64            `protobuf:"varint,3,opt,name=max_volume_count,json=maxVolumeCount,proto3" json:"max_volume_count,omitempty"` | |
| 	FreeVolumeCount   uint64            `protobuf:"varint,4,opt,name=free_volume_count,json=freeVolumeCount,proto3" json:"free_volume_count,omitempty"` | |
| 	ActiveVolumeCount uint64            `protobuf:"varint,5,opt,name=active_volume_count,json=activeVolumeCount,proto3" json:"active_volume_count,omitempty"` | |
| 	DataCenterInfos   []*DataCenterInfo `protobuf:"bytes,6,rep,name=data_center_infos,json=dataCenterInfos,proto3" json:"data_center_infos,omitempty"` | |
| 	RemoteVolumeCount uint64            `protobuf:"varint,7,opt,name=remote_volume_count,json=remoteVolumeCount,proto3" json:"remote_volume_count,omitempty"` | |
| } | |
| 
 | |
| func (x *TopologyInfo) Reset() { | |
| 	*x = TopologyInfo{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[26] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *TopologyInfo) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*TopologyInfo) ProtoMessage() {} | |
| 
 | |
| func (x *TopologyInfo) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[26] | |
| 	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 TopologyInfo.ProtoReflect.Descriptor instead. | |
| func (*TopologyInfo) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{26} | |
| } | |
| 
 | |
| func (x *TopologyInfo) GetId() string { | |
| 	if x != nil { | |
| 		return x.Id | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *TopologyInfo) GetVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.VolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *TopologyInfo) GetMaxVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.MaxVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *TopologyInfo) GetFreeVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.FreeVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *TopologyInfo) GetActiveVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.ActiveVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *TopologyInfo) GetDataCenterInfos() []*DataCenterInfo { | |
| 	if x != nil { | |
| 		return x.DataCenterInfos | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *TopologyInfo) GetRemoteVolumeCount() uint64 { | |
| 	if x != nil { | |
| 		return x.RemoteVolumeCount | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type VolumeListRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| } | |
| 
 | |
| func (x *VolumeListRequest) Reset() { | |
| 	*x = VolumeListRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[27] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *VolumeListRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*VolumeListRequest) ProtoMessage() {} | |
| 
 | |
| func (x *VolumeListRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[27] | |
| 	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 VolumeListRequest.ProtoReflect.Descriptor instead. | |
| func (*VolumeListRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{27} | |
| } | |
| 
 | |
| type VolumeListResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	TopologyInfo      *TopologyInfo `protobuf:"bytes,1,opt,name=topology_info,json=topologyInfo,proto3" json:"topology_info,omitempty"` | |
| 	VolumeSizeLimitMb uint64        `protobuf:"varint,2,opt,name=volume_size_limit_mb,json=volumeSizeLimitMb,proto3" json:"volume_size_limit_mb,omitempty"` | |
| } | |
| 
 | |
| func (x *VolumeListResponse) Reset() { | |
| 	*x = VolumeListResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[28] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *VolumeListResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*VolumeListResponse) ProtoMessage() {} | |
| 
 | |
| func (x *VolumeListResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[28] | |
| 	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 VolumeListResponse.ProtoReflect.Descriptor instead. | |
| func (*VolumeListResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{28} | |
| } | |
| 
 | |
| func (x *VolumeListResponse) GetTopologyInfo() *TopologyInfo { | |
| 	if x != nil { | |
| 		return x.TopologyInfo | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *VolumeListResponse) GetVolumeSizeLimitMb() uint64 { | |
| 	if x != nil { | |
| 		return x.VolumeSizeLimitMb | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type LookupEcVolumeRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	VolumeId uint32 `protobuf:"varint,1,opt,name=volume_id,json=volumeId,proto3" json:"volume_id,omitempty"` | |
| } | |
| 
 | |
| func (x *LookupEcVolumeRequest) Reset() { | |
| 	*x = LookupEcVolumeRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[29] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LookupEcVolumeRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LookupEcVolumeRequest) ProtoMessage() {} | |
| 
 | |
| func (x *LookupEcVolumeRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[29] | |
| 	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 LookupEcVolumeRequest.ProtoReflect.Descriptor instead. | |
| func (*LookupEcVolumeRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{29} | |
| } | |
| 
 | |
| func (x *LookupEcVolumeRequest) GetVolumeId() uint32 { | |
| 	if x != nil { | |
| 		return x.VolumeId | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type LookupEcVolumeResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	VolumeId         uint32                                      `protobuf:"varint,1,opt,name=volume_id,json=volumeId,proto3" json:"volume_id,omitempty"` | |
| 	ShardIdLocations []*LookupEcVolumeResponse_EcShardIdLocation `protobuf:"bytes,2,rep,name=shard_id_locations,json=shardIdLocations,proto3" json:"shard_id_locations,omitempty"` | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse) Reset() { | |
| 	*x = LookupEcVolumeResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[30] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LookupEcVolumeResponse) ProtoMessage() {} | |
| 
 | |
| func (x *LookupEcVolumeResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[30] | |
| 	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 LookupEcVolumeResponse.ProtoReflect.Descriptor instead. | |
| func (*LookupEcVolumeResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{30} | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse) GetVolumeId() uint32 { | |
| 	if x != nil { | |
| 		return x.VolumeId | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse) GetShardIdLocations() []*LookupEcVolumeResponse_EcShardIdLocation { | |
| 	if x != nil { | |
| 		return x.ShardIdLocations | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type GetMasterConfigurationRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationRequest) Reset() { | |
| 	*x = GetMasterConfigurationRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[31] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*GetMasterConfigurationRequest) ProtoMessage() {} | |
| 
 | |
| func (x *GetMasterConfigurationRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[31] | |
| 	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 GetMasterConfigurationRequest.ProtoReflect.Descriptor instead. | |
| func (*GetMasterConfigurationRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{31} | |
| } | |
| 
 | |
| type GetMasterConfigurationResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	MetricsAddress         string            `protobuf:"bytes,1,opt,name=metrics_address,json=metricsAddress,proto3" json:"metrics_address,omitempty"` | |
| 	MetricsIntervalSeconds uint32            `protobuf:"varint,2,opt,name=metrics_interval_seconds,json=metricsIntervalSeconds,proto3" json:"metrics_interval_seconds,omitempty"` | |
| 	StorageBackends        []*StorageBackend `protobuf:"bytes,3,rep,name=storage_backends,json=storageBackends,proto3" json:"storage_backends,omitempty"` | |
| 	DefaultReplication     string            `protobuf:"bytes,4,opt,name=default_replication,json=defaultReplication,proto3" json:"default_replication,omitempty"` | |
| 	Leader                 string            `protobuf:"bytes,5,opt,name=leader,proto3" json:"leader,omitempty"` | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationResponse) Reset() { | |
| 	*x = GetMasterConfigurationResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[32] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*GetMasterConfigurationResponse) ProtoMessage() {} | |
| 
 | |
| func (x *GetMasterConfigurationResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[32] | |
| 	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 GetMasterConfigurationResponse.ProtoReflect.Descriptor instead. | |
| func (*GetMasterConfigurationResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{32} | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationResponse) GetMetricsAddress() string { | |
| 	if x != nil { | |
| 		return x.MetricsAddress | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationResponse) GetMetricsIntervalSeconds() uint32 { | |
| 	if x != nil { | |
| 		return x.MetricsIntervalSeconds | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationResponse) GetStorageBackends() []*StorageBackend { | |
| 	if x != nil { | |
| 		return x.StorageBackends | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationResponse) GetDefaultReplication() string { | |
| 	if x != nil { | |
| 		return x.DefaultReplication | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *GetMasterConfigurationResponse) GetLeader() string { | |
| 	if x != nil { | |
| 		return x.Leader | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type ListMasterClientsRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	ClientType string `protobuf:"bytes,1,opt,name=client_type,json=clientType,proto3" json:"client_type,omitempty"` | |
| } | |
| 
 | |
| func (x *ListMasterClientsRequest) Reset() { | |
| 	*x = ListMasterClientsRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[33] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *ListMasterClientsRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*ListMasterClientsRequest) ProtoMessage() {} | |
| 
 | |
| func (x *ListMasterClientsRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[33] | |
| 	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 ListMasterClientsRequest.ProtoReflect.Descriptor instead. | |
| func (*ListMasterClientsRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{33} | |
| } | |
| 
 | |
| func (x *ListMasterClientsRequest) GetClientType() string { | |
| 	if x != nil { | |
| 		return x.ClientType | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type ListMasterClientsResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	GrpcAddresses []string `protobuf:"bytes,1,rep,name=grpc_addresses,json=grpcAddresses,proto3" json:"grpc_addresses,omitempty"` | |
| } | |
| 
 | |
| func (x *ListMasterClientsResponse) Reset() { | |
| 	*x = ListMasterClientsResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[34] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *ListMasterClientsResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*ListMasterClientsResponse) ProtoMessage() {} | |
| 
 | |
| func (x *ListMasterClientsResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[34] | |
| 	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 ListMasterClientsResponse.ProtoReflect.Descriptor instead. | |
| func (*ListMasterClientsResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{34} | |
| } | |
| 
 | |
| func (x *ListMasterClientsResponse) GetGrpcAddresses() []string { | |
| 	if x != nil { | |
| 		return x.GrpcAddresses | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type LeaseAdminTokenRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	PreviousToken    int64  `protobuf:"varint,1,opt,name=previous_token,json=previousToken,proto3" json:"previous_token,omitempty"` | |
| 	PreviousLockTime int64  `protobuf:"varint,2,opt,name=previous_lock_time,json=previousLockTime,proto3" json:"previous_lock_time,omitempty"` | |
| 	LockName         string `protobuf:"bytes,3,opt,name=lock_name,json=lockName,proto3" json:"lock_name,omitempty"` | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenRequest) Reset() { | |
| 	*x = LeaseAdminTokenRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[35] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LeaseAdminTokenRequest) ProtoMessage() {} | |
| 
 | |
| func (x *LeaseAdminTokenRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[35] | |
| 	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 LeaseAdminTokenRequest.ProtoReflect.Descriptor instead. | |
| func (*LeaseAdminTokenRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{35} | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenRequest) GetPreviousToken() int64 { | |
| 	if x != nil { | |
| 		return x.PreviousToken | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenRequest) GetPreviousLockTime() int64 { | |
| 	if x != nil { | |
| 		return x.PreviousLockTime | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenRequest) GetLockName() string { | |
| 	if x != nil { | |
| 		return x.LockName | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type LeaseAdminTokenResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Token    int64 `protobuf:"varint,1,opt,name=token,proto3" json:"token,omitempty"` | |
| 	LockTsNs int64 `protobuf:"varint,2,opt,name=lock_ts_ns,json=lockTsNs,proto3" json:"lock_ts_ns,omitempty"` | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenResponse) Reset() { | |
| 	*x = LeaseAdminTokenResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[36] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LeaseAdminTokenResponse) ProtoMessage() {} | |
| 
 | |
| func (x *LeaseAdminTokenResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[36] | |
| 	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 LeaseAdminTokenResponse.ProtoReflect.Descriptor instead. | |
| func (*LeaseAdminTokenResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{36} | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenResponse) GetToken() int64 { | |
| 	if x != nil { | |
| 		return x.Token | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *LeaseAdminTokenResponse) GetLockTsNs() int64 { | |
| 	if x != nil { | |
| 		return x.LockTsNs | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| type ReleaseAdminTokenRequest struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	PreviousToken    int64  `protobuf:"varint,1,opt,name=previous_token,json=previousToken,proto3" json:"previous_token,omitempty"` | |
| 	PreviousLockTime int64  `protobuf:"varint,2,opt,name=previous_lock_time,json=previousLockTime,proto3" json:"previous_lock_time,omitempty"` | |
| 	LockName         string `protobuf:"bytes,3,opt,name=lock_name,json=lockName,proto3" json:"lock_name,omitempty"` | |
| } | |
| 
 | |
| func (x *ReleaseAdminTokenRequest) Reset() { | |
| 	*x = ReleaseAdminTokenRequest{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[37] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *ReleaseAdminTokenRequest) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*ReleaseAdminTokenRequest) ProtoMessage() {} | |
| 
 | |
| func (x *ReleaseAdminTokenRequest) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[37] | |
| 	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 ReleaseAdminTokenRequest.ProtoReflect.Descriptor instead. | |
| func (*ReleaseAdminTokenRequest) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{37} | |
| } | |
| 
 | |
| func (x *ReleaseAdminTokenRequest) GetPreviousToken() int64 { | |
| 	if x != nil { | |
| 		return x.PreviousToken | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *ReleaseAdminTokenRequest) GetPreviousLockTime() int64 { | |
| 	if x != nil { | |
| 		return x.PreviousLockTime | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *ReleaseAdminTokenRequest) GetLockName() string { | |
| 	if x != nil { | |
| 		return x.LockName | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type ReleaseAdminTokenResponse struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| } | |
| 
 | |
| func (x *ReleaseAdminTokenResponse) Reset() { | |
| 	*x = ReleaseAdminTokenResponse{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[38] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *ReleaseAdminTokenResponse) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*ReleaseAdminTokenResponse) ProtoMessage() {} | |
| 
 | |
| func (x *ReleaseAdminTokenResponse) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[38] | |
| 	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 ReleaseAdminTokenResponse.ProtoReflect.Descriptor instead. | |
| func (*ReleaseAdminTokenResponse) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{38} | |
| } | |
| 
 | |
| type SuperBlockExtra_ErasureCoding struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	Data      uint32   `protobuf:"varint,1,opt,name=data,proto3" json:"data,omitempty"` | |
| 	Parity    uint32   `protobuf:"varint,2,opt,name=parity,proto3" json:"parity,omitempty"` | |
| 	VolumeIds []uint32 `protobuf:"varint,3,rep,packed,name=volume_ids,json=volumeIds,proto3" json:"volume_ids,omitempty"` | |
| } | |
| 
 | |
| func (x *SuperBlockExtra_ErasureCoding) Reset() { | |
| 	*x = SuperBlockExtra_ErasureCoding{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[40] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *SuperBlockExtra_ErasureCoding) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*SuperBlockExtra_ErasureCoding) ProtoMessage() {} | |
| 
 | |
| func (x *SuperBlockExtra_ErasureCoding) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[40] | |
| 	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 SuperBlockExtra_ErasureCoding.ProtoReflect.Descriptor instead. | |
| func (*SuperBlockExtra_ErasureCoding) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{7, 0} | |
| } | |
| 
 | |
| func (x *SuperBlockExtra_ErasureCoding) GetData() uint32 { | |
| 	if x != nil { | |
| 		return x.Data | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *SuperBlockExtra_ErasureCoding) GetParity() uint32 { | |
| 	if x != nil { | |
| 		return x.Parity | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *SuperBlockExtra_ErasureCoding) GetVolumeIds() []uint32 { | |
| 	if x != nil { | |
| 		return x.VolumeIds | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| type LookupVolumeResponse_VolumeIdLocation struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	VolumeId  string      `protobuf:"bytes,1,opt,name=volume_id,json=volumeId,proto3" json:"volume_id,omitempty"` | |
| 	Locations []*Location `protobuf:"bytes,2,rep,name=locations,proto3" json:"locations,omitempty"` | |
| 	Error     string      `protobuf:"bytes,3,opt,name=error,proto3" json:"error,omitempty"` | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse_VolumeIdLocation) Reset() { | |
| 	*x = LookupVolumeResponse_VolumeIdLocation{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[41] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse_VolumeIdLocation) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LookupVolumeResponse_VolumeIdLocation) ProtoMessage() {} | |
| 
 | |
| func (x *LookupVolumeResponse_VolumeIdLocation) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[41] | |
| 	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 LookupVolumeResponse_VolumeIdLocation.ProtoReflect.Descriptor instead. | |
| func (*LookupVolumeResponse_VolumeIdLocation) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{11, 0} | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse_VolumeIdLocation) GetVolumeId() string { | |
| 	if x != nil { | |
| 		return x.VolumeId | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse_VolumeIdLocation) GetLocations() []*Location { | |
| 	if x != nil { | |
| 		return x.Locations | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| func (x *LookupVolumeResponse_VolumeIdLocation) GetError() string { | |
| 	if x != nil { | |
| 		return x.Error | |
| 	} | |
| 	return "" | |
| } | |
| 
 | |
| type LookupEcVolumeResponse_EcShardIdLocation struct { | |
| 	state         protoimpl.MessageState | |
| 	sizeCache     protoimpl.SizeCache | |
| 	unknownFields protoimpl.UnknownFields | |
| 
 | |
| 	ShardId   uint32      `protobuf:"varint,1,opt,name=shard_id,json=shardId,proto3" json:"shard_id,omitempty"` | |
| 	Locations []*Location `protobuf:"bytes,2,rep,name=locations,proto3" json:"locations,omitempty"` | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse_EcShardIdLocation) Reset() { | |
| 	*x = LookupEcVolumeResponse_EcShardIdLocation{} | |
| 	if protoimpl.UnsafeEnabled { | |
| 		mi := &file_master_proto_msgTypes[42] | |
| 		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) | |
| 		ms.StoreMessageInfo(mi) | |
| 	} | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse_EcShardIdLocation) String() string { | |
| 	return protoimpl.X.MessageStringOf(x) | |
| } | |
| 
 | |
| func (*LookupEcVolumeResponse_EcShardIdLocation) ProtoMessage() {} | |
| 
 | |
| func (x *LookupEcVolumeResponse_EcShardIdLocation) ProtoReflect() protoreflect.Message { | |
| 	mi := &file_master_proto_msgTypes[42] | |
| 	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 LookupEcVolumeResponse_EcShardIdLocation.ProtoReflect.Descriptor instead. | |
| func (*LookupEcVolumeResponse_EcShardIdLocation) Descriptor() ([]byte, []int) { | |
| 	return file_master_proto_rawDescGZIP(), []int{30, 0} | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse_EcShardIdLocation) GetShardId() uint32 { | |
| 	if x != nil { | |
| 		return x.ShardId | |
| 	} | |
| 	return 0 | |
| } | |
| 
 | |
| func (x *LookupEcVolumeResponse_EcShardIdLocation) GetLocations() []*Location { | |
| 	if x != nil { | |
| 		return x.Locations | |
| 	} | |
| 	return nil | |
| } | |
| 
 | |
| var File_master_proto protoreflect.FileDescriptor | |
| 
 | |
| var file_master_proto_rawDesc = []byte{ | |
| 	0x0a, 0x0c, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x09, | |
| 	0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x22, 0x8b, 0x06, 0x0a, 0x09, 0x48, 0x65, | |
| 	0x61, 0x72, 0x74, 0x62, 0x65, 0x61, 0x74, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x70, 0x18, 0x01, 0x20, | |
| 	0x01, 0x28, 0x09, 0x52, 0x02, 0x69, 0x70, 0x12, 0x12, 0x0a, 0x04, 0x70, 0x6f, 0x72, 0x74, 0x18, | |
| 	0x02, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x04, 0x70, 0x6f, 0x72, 0x74, 0x12, 0x1d, 0x0a, 0x0a, 0x70, | |
| 	0x75, 0x62, 0x6c, 0x69, 0x63, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, | |
| 	0x09, 0x70, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x55, 0x72, 0x6c, 0x12, 0x28, 0x0a, 0x10, 0x6d, 0x61, | |
| 	0x78, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x04, | |
| 	0x20, 0x01, 0x28, 0x0d, 0x52, 0x0e, 0x6d, 0x61, 0x78, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, | |
| 	0x6f, 0x75, 0x6e, 0x74, 0x12, 0x20, 0x0a, 0x0c, 0x6d, 0x61, 0x78, 0x5f, 0x66, 0x69, 0x6c, 0x65, | |
| 	0x5f, 0x6b, 0x65, 0x79, 0x18, 0x05, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0a, 0x6d, 0x61, 0x78, 0x46, | |
| 	0x69, 0x6c, 0x65, 0x4b, 0x65, 0x79, 0x12, 0x1f, 0x0a, 0x0b, 0x64, 0x61, 0x74, 0x61, 0x5f, 0x63, | |
| 	0x65, 0x6e, 0x74, 0x65, 0x72, 0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0a, 0x64, 0x61, 0x74, | |
| 	0x61, 0x43, 0x65, 0x6e, 0x74, 0x65, 0x72, 0x12, 0x12, 0x0a, 0x04, 0x72, 0x61, 0x63, 0x6b, 0x18, | |
| 	0x07, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x72, 0x61, 0x63, 0x6b, 0x12, 0x1d, 0x0a, 0x0a, 0x61, | |
| 	0x64, 0x6d, 0x69, 0x6e, 0x5f, 0x70, 0x6f, 0x72, 0x74, 0x18, 0x08, 0x20, 0x01, 0x28, 0x0d, 0x52, | |
| 	0x09, 0x61, 0x64, 0x6d, 0x69, 0x6e, 0x50, 0x6f, 0x72, 0x74, 0x12, 0x3d, 0x0a, 0x07, 0x76, 0x6f, | |
| 	0x6c, 0x75, 0x6d, 0x65, 0x73, 0x18, 0x09, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x23, 0x2e, 0x6d, 0x61, | |
| 	0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x6e, | |
| 	0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, | |
| 	0x52, 0x07, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x12, 0x49, 0x0a, 0x0b, 0x6e, 0x65, 0x77, | |
| 	0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x18, 0x0a, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x28, | |
| 	0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x53, 0x68, 0x6f, 0x72, 0x74, 0x49, 0x6e, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, 0x6f, | |
| 	0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x52, 0x0a, 0x6e, 0x65, 0x77, 0x56, 0x6f, 0x6c, | |
| 	0x75, 0x6d, 0x65, 0x73, 0x12, 0x51, 0x0a, 0x0f, 0x64, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x64, 0x5f, | |
| 	0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x18, 0x0b, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x28, 0x2e, | |
| 	0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x53, 0x68, 0x6f, 0x72, 0x74, 0x49, 0x6e, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, 0x6f, 0x6e, | |
| 	0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x52, 0x0e, 0x64, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x64, | |
| 	0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x12, 0x24, 0x0a, 0x0e, 0x68, 0x61, 0x73, 0x5f, 0x6e, | |
| 	0x6f, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x18, 0x0c, 0x20, 0x01, 0x28, 0x08, 0x52, | |
| 	0x0c, 0x68, 0x61, 0x73, 0x4e, 0x6f, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x12, 0x47, 0x0a, | |
| 	0x09, 0x65, 0x63, 0x5f, 0x73, 0x68, 0x61, 0x72, 0x64, 0x73, 0x18, 0x10, 0x20, 0x03, 0x28, 0x0b, | |
| 	0x32, 0x2a, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, | |
| 	0x75, 0x6d, 0x65, 0x45, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x49, 0x6e, 0x66, 0x6f, 0x72, 0x6d, | |
| 	0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x52, 0x08, 0x65, 0x63, | |
| 	0x53, 0x68, 0x61, 0x72, 0x64, 0x73, 0x12, 0x4e, 0x0a, 0x0d, 0x6e, 0x65, 0x77, 0x5f, 0x65, 0x63, | |
| 	0x5f, 0x73, 0x68, 0x61, 0x72, 0x64, 0x73, 0x18, 0x11, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x2a, 0x2e, | |
| 	0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x45, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x49, 0x6e, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, | |
| 	0x6f, 0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x52, 0x0b, 0x6e, 0x65, 0x77, 0x45, 0x63, | |
| 	0x53, 0x68, 0x61, 0x72, 0x64, 0x73, 0x12, 0x56, 0x0a, 0x11, 0x64, 0x65, 0x6c, 0x65, 0x74, 0x65, | |
| 	0x64, 0x5f, 0x65, 0x63, 0x5f, 0x73, 0x68, 0x61, 0x72, 0x64, 0x73, 0x18, 0x12, 0x20, 0x03, 0x28, | |
| 	0x0b, 0x32, 0x2a, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, | |
| 	0x6c, 0x75, 0x6d, 0x65, 0x45, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x49, 0x6e, 0x66, 0x6f, 0x72, | |
| 	0x6d, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x52, 0x0f, 0x64, | |
| 	0x65, 0x6c, 0x65, 0x74, 0x65, 0x64, 0x45, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x73, 0x12, 0x27, | |
| 	0x0a, 0x10, 0x68, 0x61, 0x73, 0x5f, 0x6e, 0x6f, 0x5f, 0x65, 0x63, 0x5f, 0x73, 0x68, 0x61, 0x72, | |
| 	0x64, 0x73, 0x18, 0x13, 0x20, 0x01, 0x28, 0x08, 0x52, 0x0d, 0x68, 0x61, 0x73, 0x4e, 0x6f, 0x45, | |
| 	0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x73, 0x22, 0x80, 0x02, 0x0a, 0x11, 0x48, 0x65, 0x61, 0x72, | |
| 	0x74, 0x62, 0x65, 0x61, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x2a, 0x0a, | |
| 	0x11, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x73, 0x69, 0x7a, 0x65, 0x5f, 0x6c, 0x69, 0x6d, | |
| 	0x69, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x53, 0x69, 0x7a, 0x65, 0x4c, 0x69, 0x6d, 0x69, 0x74, 0x12, 0x16, 0x0a, 0x06, 0x6c, 0x65, 0x61, | |
| 	0x64, 0x65, 0x72, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x06, 0x6c, 0x65, 0x61, 0x64, 0x65, | |
| 	0x72, 0x12, 0x27, 0x0a, 0x0f, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x61, 0x64, 0x64, | |
| 	0x72, 0x65, 0x73, 0x73, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0e, 0x6d, 0x65, 0x74, 0x72, | |
| 	0x69, 0x63, 0x73, 0x41, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x12, 0x38, 0x0a, 0x18, 0x6d, 0x65, | |
| 	0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x5f, 0x73, | |
| 	0x65, 0x63, 0x6f, 0x6e, 0x64, 0x73, 0x18, 0x04, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x16, 0x6d, 0x65, | |
| 	0x74, 0x72, 0x69, 0x63, 0x73, 0x49, 0x6e, 0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x53, 0x65, 0x63, | |
| 	0x6f, 0x6e, 0x64, 0x73, 0x12, 0x44, 0x0a, 0x10, 0x73, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x5f, | |
| 	0x62, 0x61, 0x63, 0x6b, 0x65, 0x6e, 0x64, 0x73, 0x18, 0x05, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x19, | |
| 	0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x53, 0x74, 0x6f, 0x72, 0x61, | |
| 	0x67, 0x65, 0x42, 0x61, 0x63, 0x6b, 0x65, 0x6e, 0x64, 0x52, 0x0f, 0x73, 0x74, 0x6f, 0x72, 0x61, | |
| 	0x67, 0x65, 0x42, 0x61, 0x63, 0x6b, 0x65, 0x6e, 0x64, 0x73, 0x22, 0xfb, 0x03, 0x0a, 0x18, 0x56, | |
| 	0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x6e, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, 0x6f, 0x6e, | |
| 	0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, 0x20, | |
| 	0x01, 0x28, 0x0d, 0x52, 0x02, 0x69, 0x64, 0x12, 0x12, 0x0a, 0x04, 0x73, 0x69, 0x7a, 0x65, 0x18, | |
| 	0x02, 0x20, 0x01, 0x28, 0x04, 0x52, 0x04, 0x73, 0x69, 0x7a, 0x65, 0x12, 0x1e, 0x0a, 0x0a, 0x63, | |
| 	0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, | |
| 	0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x1d, 0x0a, 0x0a, 0x66, | |
| 	0x69, 0x6c, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x04, 0x20, 0x01, 0x28, 0x04, 0x52, | |
| 	0x09, 0x66, 0x69, 0x6c, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x21, 0x0a, 0x0c, 0x64, 0x65, | |
| 	0x6c, 0x65, 0x74, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x05, 0x20, 0x01, 0x28, 0x04, | |
| 	0x52, 0x0b, 0x64, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2c, 0x0a, | |
| 	0x12, 0x64, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x64, 0x5f, 0x62, 0x79, 0x74, 0x65, 0x5f, 0x63, 0x6f, | |
| 	0x75, 0x6e, 0x74, 0x18, 0x06, 0x20, 0x01, 0x28, 0x04, 0x52, 0x10, 0x64, 0x65, 0x6c, 0x65, 0x74, | |
| 	0x65, 0x64, 0x42, 0x79, 0x74, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x1b, 0x0a, 0x09, 0x72, | |
| 	0x65, 0x61, 0x64, 0x5f, 0x6f, 0x6e, 0x6c, 0x79, 0x18, 0x07, 0x20, 0x01, 0x28, 0x08, 0x52, 0x08, | |
| 	0x72, 0x65, 0x61, 0x64, 0x4f, 0x6e, 0x6c, 0x79, 0x12, 0x2b, 0x0a, 0x11, 0x72, 0x65, 0x70, 0x6c, | |
| 	0x69, 0x63, 0x61, 0x5f, 0x70, 0x6c, 0x61, 0x63, 0x65, 0x6d, 0x65, 0x6e, 0x74, 0x18, 0x08, 0x20, | |
| 	0x01, 0x28, 0x0d, 0x52, 0x10, 0x72, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x50, 0x6c, 0x61, 0x63, | |
| 	0x65, 0x6d, 0x65, 0x6e, 0x74, 0x12, 0x18, 0x0a, 0x07, 0x76, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, | |
| 	0x18, 0x09, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x07, 0x76, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, 0x12, | |
| 	0x10, 0x0a, 0x03, 0x74, 0x74, 0x6c, 0x18, 0x0a, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x03, 0x74, 0x74, | |
| 	0x6c, 0x12, 0x29, 0x0a, 0x10, 0x63, 0x6f, 0x6d, 0x70, 0x61, 0x63, 0x74, 0x5f, 0x72, 0x65, 0x76, | |
| 	0x69, 0x73, 0x69, 0x6f, 0x6e, 0x18, 0x0b, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x0f, 0x63, 0x6f, 0x6d, | |
| 	0x70, 0x61, 0x63, 0x74, 0x52, 0x65, 0x76, 0x69, 0x73, 0x69, 0x6f, 0x6e, 0x12, 0x2c, 0x0a, 0x12, | |
| 	0x6d, 0x6f, 0x64, 0x69, 0x66, 0x69, 0x65, 0x64, 0x5f, 0x61, 0x74, 0x5f, 0x73, 0x65, 0x63, 0x6f, | |
| 	0x6e, 0x64, 0x18, 0x0c, 0x20, 0x01, 0x28, 0x03, 0x52, 0x10, 0x6d, 0x6f, 0x64, 0x69, 0x66, 0x69, | |
| 	0x65, 0x64, 0x41, 0x74, 0x53, 0x65, 0x63, 0x6f, 0x6e, 0x64, 0x12, 0x2e, 0x0a, 0x13, 0x72, 0x65, | |
| 	0x6d, 0x6f, 0x74, 0x65, 0x5f, 0x73, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x5f, 0x6e, 0x61, 0x6d, | |
| 	0x65, 0x18, 0x0d, 0x20, 0x01, 0x28, 0x09, 0x52, 0x11, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, 0x53, | |
| 	0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x4e, 0x61, 0x6d, 0x65, 0x12, 0x2c, 0x0a, 0x12, 0x72, 0x65, | |
| 	0x6d, 0x6f, 0x74, 0x65, 0x5f, 0x73, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x5f, 0x6b, 0x65, 0x79, | |
| 	0x18, 0x0e, 0x20, 0x01, 0x28, 0x09, 0x52, 0x10, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, 0x53, 0x74, | |
| 	0x6f, 0x72, 0x61, 0x67, 0x65, 0x4b, 0x65, 0x79, 0x22, 0xa8, 0x01, 0x0a, 0x1d, 0x56, 0x6f, 0x6c, | |
| 	0x75, 0x6d, 0x65, 0x53, 0x68, 0x6f, 0x72, 0x74, 0x49, 0x6e, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, | |
| 	0x69, 0x6f, 0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, | |
| 	0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x02, 0x69, 0x64, 0x12, 0x1e, 0x0a, 0x0a, 0x63, 0x6f, | |
| 	0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0a, | |
| 	0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x2b, 0x0a, 0x11, 0x72, 0x65, | |
| 	0x70, 0x6c, 0x69, 0x63, 0x61, 0x5f, 0x70, 0x6c, 0x61, 0x63, 0x65, 0x6d, 0x65, 0x6e, 0x74, 0x18, | |
| 	0x08, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x10, 0x72, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x50, 0x6c, | |
| 	0x61, 0x63, 0x65, 0x6d, 0x65, 0x6e, 0x74, 0x12, 0x18, 0x0a, 0x07, 0x76, 0x65, 0x72, 0x73, 0x69, | |
| 	0x6f, 0x6e, 0x18, 0x09, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x07, 0x76, 0x65, 0x72, 0x73, 0x69, 0x6f, | |
| 	0x6e, 0x12, 0x10, 0x0a, 0x03, 0x74, 0x74, 0x6c, 0x18, 0x0a, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x03, | |
| 	0x74, 0x74, 0x6c, 0x22, 0x75, 0x0a, 0x1f, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x45, 0x63, 0x53, | |
| 	0x68, 0x61, 0x72, 0x64, 0x49, 0x6e, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4d, | |
| 	0x65, 0x73, 0x73, 0x61, 0x67, 0x65, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, | |
| 	0x28, 0x0d, 0x52, 0x02, 0x69, 0x64, 0x12, 0x1e, 0x0a, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, | |
| 	0x74, 0x69, 0x6f, 0x6e, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, | |
| 	0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x22, 0x0a, 0x0d, 0x65, 0x63, 0x5f, 0x69, 0x6e, 0x64, | |
| 	0x65, 0x78, 0x5f, 0x62, 0x69, 0x74, 0x73, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x0b, 0x65, | |
| 	0x63, 0x49, 0x6e, 0x64, 0x65, 0x78, 0x42, 0x69, 0x74, 0x73, 0x22, 0xbe, 0x01, 0x0a, 0x0e, 0x53, | |
| 	0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x42, 0x61, 0x63, 0x6b, 0x65, 0x6e, 0x64, 0x12, 0x12, 0x0a, | |
| 	0x04, 0x74, 0x79, 0x70, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x74, 0x79, 0x70, | |
| 	0x65, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x02, 0x69, | |
| 	0x64, 0x12, 0x49, 0x0a, 0x0a, 0x70, 0x72, 0x6f, 0x70, 0x65, 0x72, 0x74, 0x69, 0x65, 0x73, 0x18, | |
| 	0x03, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x29, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, | |
| 	0x62, 0x2e, 0x53, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x42, 0x61, 0x63, 0x6b, 0x65, 0x6e, 0x64, | |
| 	0x2e, 0x50, 0x72, 0x6f, 0x70, 0x65, 0x72, 0x74, 0x69, 0x65, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, | |
| 	0x52, 0x0a, 0x70, 0x72, 0x6f, 0x70, 0x65, 0x72, 0x74, 0x69, 0x65, 0x73, 0x1a, 0x3d, 0x0a, 0x0f, | |
| 	0x50, 0x72, 0x6f, 0x70, 0x65, 0x72, 0x74, 0x69, 0x65, 0x73, 0x45, 0x6e, 0x74, 0x72, 0x79, 0x12, | |
| 	0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x6b, 0x65, | |
| 	0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, | |
| 	0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x3a, 0x02, 0x38, 0x01, 0x22, 0x07, 0x0a, 0x05, 0x45, | |
| 	0x6d, 0x70, 0x74, 0x79, 0x22, 0xbe, 0x01, 0x0a, 0x0f, 0x53, 0x75, 0x70, 0x65, 0x72, 0x42, 0x6c, | |
| 	0x6f, 0x63, 0x6b, 0x45, 0x78, 0x74, 0x72, 0x61, 0x12, 0x4f, 0x0a, 0x0e, 0x65, 0x72, 0x61, 0x73, | |
| 	0x75, 0x72, 0x65, 0x5f, 0x63, 0x6f, 0x64, 0x69, 0x6e, 0x67, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, | |
| 	0x32, 0x28, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x53, 0x75, 0x70, | |
| 	0x65, 0x72, 0x42, 0x6c, 0x6f, 0x63, 0x6b, 0x45, 0x78, 0x74, 0x72, 0x61, 0x2e, 0x45, 0x72, 0x61, | |
| 	0x73, 0x75, 0x72, 0x65, 0x43, 0x6f, 0x64, 0x69, 0x6e, 0x67, 0x52, 0x0d, 0x65, 0x72, 0x61, 0x73, | |
| 	0x75, 0x72, 0x65, 0x43, 0x6f, 0x64, 0x69, 0x6e, 0x67, 0x1a, 0x5a, 0x0a, 0x0d, 0x45, 0x72, 0x61, | |
| 	0x73, 0x75, 0x72, 0x65, 0x43, 0x6f, 0x64, 0x69, 0x6e, 0x67, 0x12, 0x12, 0x0a, 0x04, 0x64, 0x61, | |
| 	0x74, 0x61, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x12, 0x16, | |
| 	0x0a, 0x06, 0x70, 0x61, 0x72, 0x69, 0x74, 0x79, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x06, | |
| 	0x70, 0x61, 0x72, 0x69, 0x74, 0x79, 0x12, 0x1d, 0x0a, 0x0a, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x5f, 0x69, 0x64, 0x73, 0x18, 0x03, 0x20, 0x03, 0x28, 0x0d, 0x52, 0x09, 0x76, 0x6f, 0x6c, 0x75, | |
| 	0x6d, 0x65, 0x49, 0x64, 0x73, 0x22, 0x47, 0x0a, 0x14, 0x4b, 0x65, 0x65, 0x70, 0x43, 0x6f, 0x6e, | |
| 	0x6e, 0x65, 0x63, 0x74, 0x65, 0x64, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x12, 0x0a, | |
| 	0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, | |
| 	0x65, 0x12, 0x1b, 0x0a, 0x09, 0x67, 0x72, 0x70, 0x63, 0x5f, 0x70, 0x6f, 0x72, 0x74, 0x18, 0x02, | |
| 	0x20, 0x01, 0x28, 0x0d, 0x52, 0x08, 0x67, 0x72, 0x70, 0x63, 0x50, 0x6f, 0x72, 0x74, 0x22, 0x97, | |
| 	0x01, 0x0a, 0x0e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, | |
| 	0x6e, 0x12, 0x10, 0x0a, 0x03, 0x75, 0x72, 0x6c, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, | |
| 	0x75, 0x72, 0x6c, 0x12, 0x1d, 0x0a, 0x0a, 0x70, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x5f, 0x75, 0x72, | |
| 	0x6c, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x09, 0x70, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x55, | |
| 	0x72, 0x6c, 0x12, 0x19, 0x0a, 0x08, 0x6e, 0x65, 0x77, 0x5f, 0x76, 0x69, 0x64, 0x73, 0x18, 0x03, | |
| 	0x20, 0x03, 0x28, 0x0d, 0x52, 0x07, 0x6e, 0x65, 0x77, 0x56, 0x69, 0x64, 0x73, 0x12, 0x21, 0x0a, | |
| 	0x0c, 0x64, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x64, 0x5f, 0x76, 0x69, 0x64, 0x73, 0x18, 0x04, 0x20, | |
| 	0x03, 0x28, 0x0d, 0x52, 0x0b, 0x64, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x64, 0x56, 0x69, 0x64, 0x73, | |
| 	0x12, 0x16, 0x0a, 0x06, 0x6c, 0x65, 0x61, 0x64, 0x65, 0x72, 0x18, 0x05, 0x20, 0x01, 0x28, 0x09, | |
| 	0x52, 0x06, 0x6c, 0x65, 0x61, 0x64, 0x65, 0x72, 0x22, 0x54, 0x0a, 0x13, 0x4c, 0x6f, 0x6f, 0x6b, | |
| 	0x75, 0x70, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, | |
| 	0x1d, 0x0a, 0x0a, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x69, 0x64, 0x73, 0x18, 0x01, 0x20, | |
| 	0x03, 0x28, 0x09, 0x52, 0x09, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x64, 0x73, 0x12, 0x1e, | |
| 	0x0a, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x02, 0x20, 0x01, | |
| 	0x28, 0x09, 0x52, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x22, 0xf2, | |
| 	0x01, 0x0a, 0x14, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x52, | |
| 	0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x60, 0x0a, 0x13, 0x76, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x5f, 0x69, 0x64, 0x5f, 0x6c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x18, 0x01, | |
| 	0x20, 0x03, 0x28, 0x0b, 0x32, 0x30, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, | |
| 	0x2e, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x73, | |
| 	0x70, 0x6f, 0x6e, 0x73, 0x65, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x64, 0x4c, 0x6f, | |
| 	0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x11, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x64, | |
| 	0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x1a, 0x78, 0x0a, 0x10, 0x56, 0x6f, 0x6c, | |
| 	0x75, 0x6d, 0x65, 0x49, 0x64, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x1b, 0x0a, | |
| 	0x09, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, | |
| 	0x52, 0x08, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x64, 0x12, 0x31, 0x0a, 0x09, 0x6c, 0x6f, | |
| 	0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x18, 0x02, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x13, 0x2e, | |
| 	0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, | |
| 	0x6f, 0x6e, 0x52, 0x09, 0x6c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x12, 0x14, 0x0a, | |
| 	0x05, 0x65, 0x72, 0x72, 0x6f, 0x72, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x65, 0x72, | |
| 	0x72, 0x6f, 0x72, 0x22, 0x3b, 0x0a, 0x08, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, | |
| 	0x10, 0x0a, 0x03, 0x75, 0x72, 0x6c, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x75, 0x72, | |
| 	0x6c, 0x12, 0x1d, 0x0a, 0x0a, 0x70, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x5f, 0x75, 0x72, 0x6c, 0x18, | |
| 	0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x09, 0x70, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x55, 0x72, 0x6c, | |
| 	0x22, 0xb3, 0x02, 0x0a, 0x0d, 0x41, 0x73, 0x73, 0x69, 0x67, 0x6e, 0x52, 0x65, 0x71, 0x75, 0x65, | |
| 	0x73, 0x74, 0x12, 0x14, 0x0a, 0x05, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, | |
| 	0x04, 0x52, 0x05, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x20, 0x0a, 0x0b, 0x72, 0x65, 0x70, 0x6c, | |
| 	0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0b, 0x72, | |
| 	0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x1e, 0x0a, 0x0a, 0x63, 0x6f, | |
| 	0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0a, | |
| 	0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x10, 0x0a, 0x03, 0x74, 0x74, | |
| 	0x6c, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x74, 0x74, 0x6c, 0x12, 0x1f, 0x0a, 0x0b, | |
| 	0x64, 0x61, 0x74, 0x61, 0x5f, 0x63, 0x65, 0x6e, 0x74, 0x65, 0x72, 0x18, 0x05, 0x20, 0x01, 0x28, | |
| 	0x09, 0x52, 0x0a, 0x64, 0x61, 0x74, 0x61, 0x43, 0x65, 0x6e, 0x74, 0x65, 0x72, 0x12, 0x12, 0x0a, | |
| 	0x04, 0x72, 0x61, 0x63, 0x6b, 0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x72, 0x61, 0x63, | |
| 	0x6b, 0x12, 0x1b, 0x0a, 0x09, 0x64, 0x61, 0x74, 0x61, 0x5f, 0x6e, 0x6f, 0x64, 0x65, 0x18, 0x07, | |
| 	0x20, 0x01, 0x28, 0x09, 0x52, 0x08, 0x64, 0x61, 0x74, 0x61, 0x4e, 0x6f, 0x64, 0x65, 0x12, 0x32, | |
| 	0x0a, 0x16, 0x6d, 0x65, 0x6d, 0x6f, 0x72, 0x79, 0x5f, 0x6d, 0x61, 0x70, 0x5f, 0x6d, 0x61, 0x78, | |
| 	0x5f, 0x73, 0x69, 0x7a, 0x65, 0x5f, 0x6d, 0x62, 0x18, 0x08, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x12, | |
| 	0x6d, 0x65, 0x6d, 0x6f, 0x72, 0x79, 0x4d, 0x61, 0x70, 0x4d, 0x61, 0x78, 0x53, 0x69, 0x7a, 0x65, | |
| 	0x4d, 0x62, 0x12, 0x32, 0x0a, 0x15, 0x57, 0x72, 0x69, 0x74, 0x61, 0x62, 0x6c, 0x65, 0x5f, 0x76, | |
| 	0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x09, 0x20, 0x01, 0x28, | |
| 	0x0d, 0x52, 0x13, 0x57, 0x72, 0x69, 0x74, 0x61, 0x62, 0x6c, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x22, 0x93, 0x01, 0x0a, 0x0e, 0x41, 0x73, 0x73, 0x69, 0x67, | |
| 	0x6e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x10, 0x0a, 0x03, 0x66, 0x69, 0x64, | |
| 	0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x66, 0x69, 0x64, 0x12, 0x10, 0x0a, 0x03, 0x75, | |
| 	0x72, 0x6c, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x75, 0x72, 0x6c, 0x12, 0x1d, 0x0a, | |
| 	0x0a, 0x70, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x5f, 0x75, 0x72, 0x6c, 0x18, 0x03, 0x20, 0x01, 0x28, | |
| 	0x09, 0x52, 0x09, 0x70, 0x75, 0x62, 0x6c, 0x69, 0x63, 0x55, 0x72, 0x6c, 0x12, 0x14, 0x0a, 0x05, | |
| 	0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x04, 0x20, 0x01, 0x28, 0x04, 0x52, 0x05, 0x63, 0x6f, 0x75, | |
| 	0x6e, 0x74, 0x12, 0x14, 0x0a, 0x05, 0x65, 0x72, 0x72, 0x6f, 0x72, 0x18, 0x05, 0x20, 0x01, 0x28, | |
| 	0x09, 0x52, 0x05, 0x65, 0x72, 0x72, 0x6f, 0x72, 0x12, 0x12, 0x0a, 0x04, 0x61, 0x75, 0x74, 0x68, | |
| 	0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x61, 0x75, 0x74, 0x68, 0x22, 0x67, 0x0a, 0x11, | |
| 	0x53, 0x74, 0x61, 0x74, 0x69, 0x73, 0x74, 0x69, 0x63, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, | |
| 	0x74, 0x12, 0x20, 0x0a, 0x0b, 0x72, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, | |
| 	0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0b, 0x72, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, | |
| 	0x69, 0x6f, 0x6e, 0x12, 0x1e, 0x0a, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, | |
| 	0x6e, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, | |
| 	0x69, 0x6f, 0x6e, 0x12, 0x10, 0x0a, 0x03, 0x74, 0x74, 0x6c, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, | |
| 	0x52, 0x03, 0x74, 0x74, 0x6c, 0x22, 0xc3, 0x01, 0x0a, 0x12, 0x53, 0x74, 0x61, 0x74, 0x69, 0x73, | |
| 	0x74, 0x69, 0x63, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x20, 0x0a, 0x0b, | |
| 	0x72, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x01, 0x20, 0x01, 0x28, | |
| 	0x09, 0x52, 0x0b, 0x72, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x1e, | |
| 	0x0a, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x02, 0x20, 0x01, | |
| 	0x28, 0x09, 0x52, 0x0a, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x10, | |
| 	0x0a, 0x03, 0x74, 0x74, 0x6c, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x74, 0x74, 0x6c, | |
| 	0x12, 0x1d, 0x0a, 0x0a, 0x74, 0x6f, 0x74, 0x61, 0x6c, 0x5f, 0x73, 0x69, 0x7a, 0x65, 0x18, 0x04, | |
| 	0x20, 0x01, 0x28, 0x04, 0x52, 0x09, 0x74, 0x6f, 0x74, 0x61, 0x6c, 0x53, 0x69, 0x7a, 0x65, 0x12, | |
| 	0x1b, 0x0a, 0x09, 0x75, 0x73, 0x65, 0x64, 0x5f, 0x73, 0x69, 0x7a, 0x65, 0x18, 0x05, 0x20, 0x01, | |
| 	0x28, 0x04, 0x52, 0x08, 0x75, 0x73, 0x65, 0x64, 0x53, 0x69, 0x7a, 0x65, 0x12, 0x1d, 0x0a, 0x0a, | |
| 	0x66, 0x69, 0x6c, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x06, 0x20, 0x01, 0x28, 0x04, | |
| 	0x52, 0x09, 0x66, 0x69, 0x6c, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x22, 0x41, 0x0a, 0x0b, 0x53, | |
| 	0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x54, 0x79, 0x70, 0x65, 0x12, 0x20, 0x0a, 0x0b, 0x72, 0x65, | |
| 	0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, | |
| 	0x0b, 0x72, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x10, 0x0a, 0x03, | |
| 	0x74, 0x74, 0x6c, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03, 0x74, 0x74, 0x6c, 0x22, 0x20, | |
| 	0x0a, 0x0a, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x12, 0x0a, 0x04, | |
| 	0x6e, 0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, | |
| 	0x22, 0x7b, 0x0a, 0x15, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x4c, 0x69, | |
| 	0x73, 0x74, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x34, 0x0a, 0x16, 0x69, 0x6e, 0x63, | |
| 	0x6c, 0x75, 0x64, 0x65, 0x5f, 0x6e, 0x6f, 0x72, 0x6d, 0x61, 0x6c, 0x5f, 0x76, 0x6f, 0x6c, 0x75, | |
| 	0x6d, 0x65, 0x73, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, 0x52, 0x14, 0x69, 0x6e, 0x63, 0x6c, 0x75, | |
| 	0x64, 0x65, 0x4e, 0x6f, 0x72, 0x6d, 0x61, 0x6c, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x12, | |
| 	0x2c, 0x0a, 0x12, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x5f, 0x65, 0x63, 0x5f, 0x76, 0x6f, | |
| 	0x6c, 0x75, 0x6d, 0x65, 0x73, 0x18, 0x02, 0x20, 0x01, 0x28, 0x08, 0x52, 0x10, 0x69, 0x6e, 0x63, | |
| 	0x6c, 0x75, 0x64, 0x65, 0x45, 0x63, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x73, 0x22, 0x51, 0x0a, | |
| 	0x16, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x4c, 0x69, 0x73, 0x74, 0x52, | |
| 	0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x37, 0x0a, 0x0b, 0x63, 0x6f, 0x6c, 0x6c, 0x65, | |
| 	0x63, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x15, 0x2e, 0x6d, | |
| 	0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, | |
| 	0x69, 0x6f, 0x6e, 0x52, 0x0b, 0x63, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x73, | |
| 	0x22, 0x2d, 0x0a, 0x17, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x44, 0x65, | |
| 	0x6c, 0x65, 0x74, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x12, 0x0a, 0x04, 0x6e, | |
| 	0x61, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x22, | |
| 	0x1a, 0x0a, 0x18, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x44, 0x65, 0x6c, | |
| 	0x65, 0x74, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x91, 0x03, 0x0a, 0x0c, | |
| 	0x44, 0x61, 0x74, 0x61, 0x4e, 0x6f, 0x64, 0x65, 0x49, 0x6e, 0x66, 0x6f, 0x12, 0x0e, 0x0a, 0x02, | |
| 	0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x02, 0x69, 0x64, 0x12, 0x21, 0x0a, 0x0c, | |
| 	0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x02, 0x20, 0x01, | |
| 	0x28, 0x04, 0x52, 0x0b, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, | |
| 	0x28, 0x0a, 0x10, 0x6d, 0x61, 0x78, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, | |
| 	0x75, 0x6e, 0x74, 0x18, 0x03, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0e, 0x6d, 0x61, 0x78, 0x56, 0x6f, | |
| 	0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2a, 0x0a, 0x11, 0x66, 0x72, 0x65, | |
| 	0x65, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x04, | |
| 	0x20, 0x01, 0x28, 0x04, 0x52, 0x0f, 0x66, 0x72, 0x65, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2e, 0x0a, 0x13, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x5f, | |
| 	0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x05, 0x20, 0x01, | |
| 	0x28, 0x04, 0x52, 0x11, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x46, 0x0a, 0x0c, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, | |
| 	0x69, 0x6e, 0x66, 0x6f, 0x73, 0x18, 0x06, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x23, 0x2e, 0x6d, 0x61, | |
| 	0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x6e, | |
| 	0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65, | |
| 	0x52, 0x0b, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x6e, 0x66, 0x6f, 0x73, 0x12, 0x50, 0x0a, | |
| 	0x0e, 0x65, 0x63, 0x5f, 0x73, 0x68, 0x61, 0x72, 0x64, 0x5f, 0x69, 0x6e, 0x66, 0x6f, 0x73, 0x18, | |
| 	0x07, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x2a, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, | |
| 	0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x45, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x49, | |
| 	0x6e, 0x66, 0x6f, 0x72, 0x6d, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x4d, 0x65, 0x73, 0x73, 0x61, 0x67, | |
| 	0x65, 0x52, 0x0c, 0x65, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x49, 0x6e, 0x66, 0x6f, 0x73, 0x12, | |
| 	0x2e, 0x0a, 0x13, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x08, 0x20, 0x01, 0x28, 0x04, 0x52, 0x11, 0x72, 0x65, | |
| 	0x6d, 0x6f, 0x74, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x22, | |
| 	0xb4, 0x02, 0x0a, 0x08, 0x52, 0x61, 0x63, 0x6b, 0x49, 0x6e, 0x66, 0x6f, 0x12, 0x0e, 0x0a, 0x02, | |
| 	0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x02, 0x69, 0x64, 0x12, 0x21, 0x0a, 0x0c, | |
| 	0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x02, 0x20, 0x01, | |
| 	0x28, 0x04, 0x52, 0x0b, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, | |
| 	0x28, 0x0a, 0x10, 0x6d, 0x61, 0x78, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, | |
| 	0x75, 0x6e, 0x74, 0x18, 0x03, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0e, 0x6d, 0x61, 0x78, 0x56, 0x6f, | |
| 	0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2a, 0x0a, 0x11, 0x66, 0x72, 0x65, | |
| 	0x65, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x04, | |
| 	0x20, 0x01, 0x28, 0x04, 0x52, 0x0f, 0x66, 0x72, 0x65, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2e, 0x0a, 0x13, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x5f, | |
| 	0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x05, 0x20, 0x01, | |
| 	0x28, 0x04, 0x52, 0x11, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, | |
| 	0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x3f, 0x0a, 0x0f, 0x64, 0x61, 0x74, 0x61, 0x5f, 0x6e, 0x6f, | |
| 	0x64, 0x65, 0x5f, 0x69, 0x6e, 0x66, 0x6f, 0x73, 0x18, 0x06, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x17, | |
| 	0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x44, 0x61, 0x74, 0x61, 0x4e, | |
| 	0x6f, 0x64, 0x65, 0x49, 0x6e, 0x66, 0x6f, 0x52, 0x0d, 0x64, 0x61, 0x74, 0x61, 0x4e, 0x6f, 0x64, | |
| 	0x65, 0x49, 0x6e, 0x66, 0x6f, 0x73, 0x12, 0x2e, 0x0a, 0x13, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, | |
| 	0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x07, 0x20, | |
| 	0x01, 0x28, 0x04, 0x52, 0x11, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x22, 0xad, 0x02, 0x0a, 0x0e, 0x44, 0x61, 0x74, 0x61, 0x43, | |
| 	0x65, 0x6e, 0x74, 0x65, 0x72, 0x49, 0x6e, 0x66, 0x6f, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, | |
| 	0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x02, 0x69, 0x64, 0x12, 0x21, 0x0a, 0x0c, 0x76, 0x6f, 0x6c, | |
| 	0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x02, 0x20, 0x01, 0x28, 0x04, 0x52, | |
| 	0x0b, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x28, 0x0a, 0x10, | |
| 	0x6d, 0x61, 0x78, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, | |
| 	0x18, 0x03, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0e, 0x6d, 0x61, 0x78, 0x56, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2a, 0x0a, 0x11, 0x66, 0x72, 0x65, 0x65, 0x5f, 0x76, | |
| 	0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x04, 0x20, 0x01, 0x28, | |
| 	0x04, 0x52, 0x0f, 0x66, 0x72, 0x65, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, | |
| 	0x6e, 0x74, 0x12, 0x2e, 0x0a, 0x13, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x5f, 0x76, 0x6f, 0x6c, | |
| 	0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x05, 0x20, 0x01, 0x28, 0x04, 0x52, | |
| 	0x11, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, | |
| 	0x6e, 0x74, 0x12, 0x32, 0x0a, 0x0a, 0x72, 0x61, 0x63, 0x6b, 0x5f, 0x69, 0x6e, 0x66, 0x6f, 0x73, | |
| 	0x18, 0x06, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x13, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, | |
| 	0x70, 0x62, 0x2e, 0x52, 0x61, 0x63, 0x6b, 0x49, 0x6e, 0x66, 0x6f, 0x52, 0x09, 0x72, 0x61, 0x63, | |
| 	0x6b, 0x49, 0x6e, 0x66, 0x6f, 0x73, 0x12, 0x2e, 0x0a, 0x13, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, | |
| 	0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x07, 0x20, | |
| 	0x01, 0x28, 0x04, 0x52, 0x11, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x22, 0xbe, 0x02, 0x0a, 0x0c, 0x54, 0x6f, 0x70, 0x6f, 0x6c, | |
| 	0x6f, 0x67, 0x79, 0x49, 0x6e, 0x66, 0x6f, 0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, 0x20, | |
| 	0x01, 0x28, 0x09, 0x52, 0x02, 0x69, 0x64, 0x12, 0x21, 0x0a, 0x0c, 0x76, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x02, 0x20, 0x01, 0x28, 0x04, 0x52, 0x0b, 0x76, | |
| 	0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x28, 0x0a, 0x10, 0x6d, 0x61, | |
| 	0x78, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x03, | |
| 	0x20, 0x01, 0x28, 0x04, 0x52, 0x0e, 0x6d, 0x61, 0x78, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, | |
| 	0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2a, 0x0a, 0x11, 0x66, 0x72, 0x65, 0x65, 0x5f, 0x76, 0x6f, 0x6c, | |
| 	0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x04, 0x20, 0x01, 0x28, 0x04, 0x52, | |
| 	0x0f, 0x66, 0x72, 0x65, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, | |
| 	0x12, 0x2e, 0x0a, 0x13, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x05, 0x20, 0x01, 0x28, 0x04, 0x52, 0x11, 0x61, | |
| 	0x63, 0x74, 0x69, 0x76, 0x65, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, | |
| 	0x12, 0x45, 0x0a, 0x11, 0x64, 0x61, 0x74, 0x61, 0x5f, 0x63, 0x65, 0x6e, 0x74, 0x65, 0x72, 0x5f, | |
| 	0x69, 0x6e, 0x66, 0x6f, 0x73, 0x18, 0x06, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x6d, 0x61, | |
| 	0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x44, 0x61, 0x74, 0x61, 0x43, 0x65, 0x6e, 0x74, | |
| 	0x65, 0x72, 0x49, 0x6e, 0x66, 0x6f, 0x52, 0x0f, 0x64, 0x61, 0x74, 0x61, 0x43, 0x65, 0x6e, 0x74, | |
| 	0x65, 0x72, 0x49, 0x6e, 0x66, 0x6f, 0x73, 0x12, 0x2e, 0x0a, 0x13, 0x72, 0x65, 0x6d, 0x6f, 0x74, | |
| 	0x65, 0x5f, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x07, | |
| 	0x20, 0x01, 0x28, 0x04, 0x52, 0x11, 0x72, 0x65, 0x6d, 0x6f, 0x74, 0x65, 0x56, 0x6f, 0x6c, 0x75, | |
| 	0x6d, 0x65, 0x43, 0x6f, 0x75, 0x6e, 0x74, 0x22, 0x13, 0x0a, 0x11, 0x56, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x4c, 0x69, 0x73, 0x74, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x22, 0x83, 0x01, 0x0a, | |
| 	0x12, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x4c, 0x69, 0x73, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, | |
| 	0x6e, 0x73, 0x65, 0x12, 0x3c, 0x0a, 0x0d, 0x74, 0x6f, 0x70, 0x6f, 0x6c, 0x6f, 0x67, 0x79, 0x5f, | |
| 	0x69, 0x6e, 0x66, 0x6f, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x17, 0x2e, 0x6d, 0x61, 0x73, | |
| 	0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x54, 0x6f, 0x70, 0x6f, 0x6c, 0x6f, 0x67, 0x79, 0x49, | |
| 	0x6e, 0x66, 0x6f, 0x52, 0x0c, 0x74, 0x6f, 0x70, 0x6f, 0x6c, 0x6f, 0x67, 0x79, 0x49, 0x6e, 0x66, | |
| 	0x6f, 0x12, 0x2f, 0x0a, 0x14, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x73, 0x69, 0x7a, 0x65, | |
| 	0x5f, 0x6c, 0x69, 0x6d, 0x69, 0x74, 0x5f, 0x6d, 0x62, 0x18, 0x02, 0x20, 0x01, 0x28, 0x04, 0x52, | |
| 	0x11, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x53, 0x69, 0x7a, 0x65, 0x4c, 0x69, 0x6d, 0x69, 0x74, | |
| 	0x4d, 0x62, 0x22, 0x34, 0x0a, 0x15, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x45, 0x63, 0x56, 0x6f, | |
| 	0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x1b, 0x0a, 0x09, 0x76, | |
| 	0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x08, | |
| 	0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x64, 0x22, 0xfb, 0x01, 0x0a, 0x16, 0x4c, 0x6f, 0x6f, | |
| 	0x6b, 0x75, 0x70, 0x45, 0x63, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, | |
| 	0x6e, 0x73, 0x65, 0x12, 0x1b, 0x0a, 0x09, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x5f, 0x69, 0x64, | |
| 	0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x08, 0x76, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x49, 0x64, | |
| 	0x12, 0x61, 0x0a, 0x12, 0x73, 0x68, 0x61, 0x72, 0x64, 0x5f, 0x69, 0x64, 0x5f, 0x6c, 0x6f, 0x63, | |
| 	0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x18, 0x02, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x33, 0x2e, 0x6d, | |
| 	0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x45, | |
| 	0x63, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x2e, | |
| 	0x45, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x49, 0x64, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, | |
| 	0x6e, 0x52, 0x10, 0x73, 0x68, 0x61, 0x72, 0x64, 0x49, 0x64, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, | |
| 	0x6f, 0x6e, 0x73, 0x1a, 0x61, 0x0a, 0x11, 0x45, 0x63, 0x53, 0x68, 0x61, 0x72, 0x64, 0x49, 0x64, | |
| 	0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x19, 0x0a, 0x08, 0x73, 0x68, 0x61, 0x72, | |
| 	0x64, 0x5f, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x07, 0x73, 0x68, 0x61, 0x72, | |
| 	0x64, 0x49, 0x64, 0x12, 0x31, 0x0a, 0x09, 0x6c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, | |
| 	0x18, 0x02, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x13, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, | |
| 	0x70, 0x62, 0x2e, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x09, 0x6c, 0x6f, 0x63, | |
| 	0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x22, 0x1f, 0x0a, 0x1d, 0x47, 0x65, 0x74, 0x4d, 0x61, 0x73, | |
| 	0x74, 0x65, 0x72, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, | |
| 	0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x22, 0x92, 0x02, 0x0a, 0x1e, 0x47, 0x65, 0x74, 0x4d, | |
| 	0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x75, 0x72, 0x61, 0x74, 0x69, | |
| 	0x6f, 0x6e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x27, 0x0a, 0x0f, 0x6d, 0x65, | |
| 	0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x18, 0x01, 0x20, | |
| 	0x01, 0x28, 0x09, 0x52, 0x0e, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x41, 0x64, 0x64, 0x72, | |
| 	0x65, 0x73, 0x73, 0x12, 0x38, 0x0a, 0x18, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x5f, 0x69, | |
| 	0x6e, 0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x5f, 0x73, 0x65, 0x63, 0x6f, 0x6e, 0x64, 0x73, 0x18, | |
| 	0x02, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x16, 0x6d, 0x65, 0x74, 0x72, 0x69, 0x63, 0x73, 0x49, 0x6e, | |
| 	0x74, 0x65, 0x72, 0x76, 0x61, 0x6c, 0x53, 0x65, 0x63, 0x6f, 0x6e, 0x64, 0x73, 0x12, 0x44, 0x0a, | |
| 	0x10, 0x73, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x5f, 0x62, 0x61, 0x63, 0x6b, 0x65, 0x6e, 0x64, | |
| 	0x73, 0x18, 0x03, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, | |
| 	0x5f, 0x70, 0x62, 0x2e, 0x53, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x42, 0x61, 0x63, 0x6b, 0x65, | |
| 	0x6e, 0x64, 0x52, 0x0f, 0x73, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x42, 0x61, 0x63, 0x6b, 0x65, | |
| 	0x6e, 0x64, 0x73, 0x12, 0x2f, 0x0a, 0x13, 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x5f, 0x72, | |
| 	0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, | |
| 	0x52, 0x12, 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x52, 0x65, 0x70, 0x6c, 0x69, 0x63, 0x61, | |
| 	0x74, 0x69, 0x6f, 0x6e, 0x12, 0x16, 0x0a, 0x06, 0x6c, 0x65, 0x61, 0x64, 0x65, 0x72, 0x18, 0x05, | |
| 	0x20, 0x01, 0x28, 0x09, 0x52, 0x06, 0x6c, 0x65, 0x61, 0x64, 0x65, 0x72, 0x22, 0x3b, 0x0a, 0x18, | |
| 	0x4c, 0x69, 0x73, 0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6c, 0x69, 0x65, 0x6e, 0x74, | |
| 	0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x1f, 0x0a, 0x0b, 0x63, 0x6c, 0x69, 0x65, | |
| 	0x6e, 0x74, 0x5f, 0x74, 0x79, 0x70, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0a, 0x63, | |
| 	0x6c, 0x69, 0x65, 0x6e, 0x74, 0x54, 0x79, 0x70, 0x65, 0x22, 0x42, 0x0a, 0x19, 0x4c, 0x69, 0x73, | |
| 	0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x73, 0x52, 0x65, | |
| 	0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x25, 0x0a, 0x0e, 0x67, 0x72, 0x70, 0x63, 0x5f, 0x61, | |
| 	0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x65, 0x73, 0x18, 0x01, 0x20, 0x03, 0x28, 0x09, 0x52, 0x0d, | |
| 	0x67, 0x72, 0x70, 0x63, 0x41, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73, 0x65, 0x73, 0x22, 0x8a, 0x01, | |
| 	0x0a, 0x16, 0x4c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, 0x6b, 0x65, | |
| 	0x6e, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x25, 0x0a, 0x0e, 0x70, 0x72, 0x65, 0x76, | |
| 	0x69, 0x6f, 0x75, 0x73, 0x5f, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x01, 0x20, 0x01, 0x28, 0x03, | |
| 	0x52, 0x0d, 0x70, 0x72, 0x65, 0x76, 0x69, 0x6f, 0x75, 0x73, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x12, | |
| 	0x2c, 0x0a, 0x12, 0x70, 0x72, 0x65, 0x76, 0x69, 0x6f, 0x75, 0x73, 0x5f, 0x6c, 0x6f, 0x63, 0x6b, | |
| 	0x5f, 0x74, 0x69, 0x6d, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x03, 0x52, 0x10, 0x70, 0x72, 0x65, | |
| 	0x76, 0x69, 0x6f, 0x75, 0x73, 0x4c, 0x6f, 0x63, 0x6b, 0x54, 0x69, 0x6d, 0x65, 0x12, 0x1b, 0x0a, | |
| 	0x09, 0x6c, 0x6f, 0x63, 0x6b, 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, | |
| 	0x52, 0x08, 0x6c, 0x6f, 0x63, 0x6b, 0x4e, 0x61, 0x6d, 0x65, 0x22, 0x4d, 0x0a, 0x17, 0x4c, 0x65, | |
| 	0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x52, 0x65, 0x73, | |
| 	0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x14, 0x0a, 0x05, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x01, | |
| 	0x20, 0x01, 0x28, 0x03, 0x52, 0x05, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x12, 0x1c, 0x0a, 0x0a, 0x6c, | |
| 	0x6f, 0x63, 0x6b, 0x5f, 0x74, 0x73, 0x5f, 0x6e, 0x73, 0x18, 0x02, 0x20, 0x01, 0x28, 0x03, 0x52, | |
| 	0x08, 0x6c, 0x6f, 0x63, 0x6b, 0x54, 0x73, 0x4e, 0x73, 0x22, 0x8c, 0x01, 0x0a, 0x18, 0x52, 0x65, | |
| 	0x6c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x52, | |
| 	0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x25, 0x0a, 0x0e, 0x70, 0x72, 0x65, 0x76, 0x69, 0x6f, | |
| 	0x75, 0x73, 0x5f, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x01, 0x20, 0x01, 0x28, 0x03, 0x52, 0x0d, | |
| 	0x70, 0x72, 0x65, 0x76, 0x69, 0x6f, 0x75, 0x73, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x12, 0x2c, 0x0a, | |
| 	0x12, 0x70, 0x72, 0x65, 0x76, 0x69, 0x6f, 0x75, 0x73, 0x5f, 0x6c, 0x6f, 0x63, 0x6b, 0x5f, 0x74, | |
| 	0x69, 0x6d, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x03, 0x52, 0x10, 0x70, 0x72, 0x65, 0x76, 0x69, | |
| 	0x6f, 0x75, 0x73, 0x4c, 0x6f, 0x63, 0x6b, 0x54, 0x69, 0x6d, 0x65, 0x12, 0x1b, 0x0a, 0x09, 0x6c, | |
| 	0x6f, 0x63, 0x6b, 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x08, | |
| 	0x6c, 0x6f, 0x63, 0x6b, 0x4e, 0x61, 0x6d, 0x65, 0x22, 0x1b, 0x0a, 0x19, 0x52, 0x65, 0x6c, 0x65, | |
| 	0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x52, 0x65, 0x73, | |
| 	0x70, 0x6f, 0x6e, 0x73, 0x65, 0x32, 0xf7, 0x08, 0x0a, 0x07, 0x53, 0x65, 0x61, 0x77, 0x65, 0x65, | |
| 	0x64, 0x12, 0x49, 0x0a, 0x0d, 0x53, 0x65, 0x6e, 0x64, 0x48, 0x65, 0x61, 0x72, 0x74, 0x62, 0x65, | |
| 	0x61, 0x74, 0x12, 0x14, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x48, | |
| 	0x65, 0x61, 0x72, 0x74, 0x62, 0x65, 0x61, 0x74, 0x1a, 0x1c, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, | |
| 	0x72, 0x5f, 0x70, 0x62, 0x2e, 0x48, 0x65, 0x61, 0x72, 0x74, 0x62, 0x65, 0x61, 0x74, 0x52, 0x65, | |
| 	0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x28, 0x01, 0x30, 0x01, 0x12, 0x51, 0x0a, 0x0d, | |
| 	0x4b, 0x65, 0x65, 0x70, 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x65, 0x64, 0x12, 0x1f, 0x2e, | |
| 	0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x4b, 0x65, 0x65, 0x70, 0x43, 0x6f, | |
| 	0x6e, 0x6e, 0x65, 0x63, 0x74, 0x65, 0x64, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x19, | |
| 	0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, | |
| 	0x65, 0x4c, 0x6f, 0x63, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x22, 0x00, 0x28, 0x01, 0x30, 0x01, 0x12, | |
| 	0x51, 0x0a, 0x0c, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x12, | |
| 	0x1e, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x6f, 0x6f, 0x6b, | |
| 	0x75, 0x70, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, | |
| 	0x1f, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x6f, 0x6f, 0x6b, | |
| 	0x75, 0x70, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, | |
| 	0x22, 0x00, 0x12, 0x3f, 0x0a, 0x06, 0x41, 0x73, 0x73, 0x69, 0x67, 0x6e, 0x12, 0x18, 0x2e, 0x6d, | |
| 	0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x41, 0x73, 0x73, 0x69, 0x67, 0x6e, 0x52, | |
| 	0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x19, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, | |
| 	0x70, 0x62, 0x2e, 0x41, 0x73, 0x73, 0x69, 0x67, 0x6e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, | |
| 	0x65, 0x22, 0x00, 0x12, 0x4b, 0x0a, 0x0a, 0x53, 0x74, 0x61, 0x74, 0x69, 0x73, 0x74, 0x69, 0x63, | |
| 	0x73, 0x12, 0x1c, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x53, 0x74, | |
| 	0x61, 0x74, 0x69, 0x73, 0x74, 0x69, 0x63, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, | |
| 	0x1d, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x53, 0x74, 0x61, 0x74, | |
| 	0x69, 0x73, 0x74, 0x69, 0x63, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, | |
| 	0x12, 0x57, 0x0a, 0x0e, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x4c, 0x69, | |
| 	0x73, 0x74, 0x12, 0x20, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x43, | |
| 	0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x4c, 0x69, 0x73, 0x74, 0x52, 0x65, 0x71, | |
| 	0x75, 0x65, 0x73, 0x74, 0x1a, 0x21, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, | |
| 	0x2e, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x4c, 0x69, 0x73, 0x74, 0x52, | |
| 	0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x5d, 0x0a, 0x10, 0x43, 0x6f, 0x6c, | |
| 	0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x12, 0x22, 0x2e, | |
| 	0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x43, 0x6f, 0x6c, 0x6c, 0x65, 0x63, | |
| 	0x74, 0x69, 0x6f, 0x6e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, | |
| 	0x74, 0x1a, 0x23, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x43, 0x6f, | |
| 	0x6c, 0x6c, 0x65, 0x63, 0x74, 0x69, 0x6f, 0x6e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x52, 0x65, | |
| 	0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x4b, 0x0a, 0x0a, 0x56, 0x6f, 0x6c, 0x75, | |
| 	0x6d, 0x65, 0x4c, 0x69, 0x73, 0x74, 0x12, 0x1c, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, | |
| 	0x70, 0x62, 0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x4c, 0x69, 0x73, 0x74, 0x52, 0x65, 0x71, | |
| 	0x75, 0x65, 0x73, 0x74, 0x1a, 0x1d, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, | |
| 	0x2e, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x4c, 0x69, 0x73, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, | |
| 	0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x57, 0x0a, 0x0e, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x45, | |
| 	0x63, 0x56, 0x6f, 0x6c, 0x75, 0x6d, 0x65, 0x12, 0x20, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, | |
| 	0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x45, 0x63, 0x56, 0x6f, 0x6c, 0x75, | |
| 	0x6d, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x21, 0x2e, 0x6d, 0x61, 0x73, 0x74, | |
| 	0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x6f, 0x6f, 0x6b, 0x75, 0x70, 0x45, 0x63, 0x56, 0x6f, | |
| 	0x6c, 0x75, 0x6d, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x6f, | |
| 	0x0a, 0x16, 0x47, 0x65, 0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6f, 0x6e, 0x66, 0x69, | |
| 	0x67, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x28, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, | |
| 	0x72, 0x5f, 0x70, 0x62, 0x2e, 0x47, 0x65, 0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6f, | |
| 	0x6e, 0x66, 0x69, 0x67, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x65, 0x71, 0x75, 0x65, | |
| 	0x73, 0x74, 0x1a, 0x29, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x47, | |
| 	0x65, 0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x75, 0x72, | |
| 	0x61, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, | |
| 	0x60, 0x0a, 0x11, 0x4c, 0x69, 0x73, 0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6c, 0x69, | |
| 	0x65, 0x6e, 0x74, 0x73, 0x12, 0x23, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, | |
| 	0x2e, 0x4c, 0x69, 0x73, 0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x43, 0x6c, 0x69, 0x65, 0x6e, | |
| 	0x74, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x24, 0x2e, 0x6d, 0x61, 0x73, 0x74, | |
| 	0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x69, 0x73, 0x74, 0x4d, 0x61, 0x73, 0x74, 0x65, 0x72, | |
| 	0x43, 0x6c, 0x69, 0x65, 0x6e, 0x74, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, | |
| 	0x00, 0x12, 0x5a, 0x0a, 0x0f, 0x4c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, | |
| 	0x6f, 0x6b, 0x65, 0x6e, 0x12, 0x21, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, | |
| 	0x2e, 0x4c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, 0x6b, 0x65, 0x6e, | |
| 	0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x22, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, | |
| 	0x5f, 0x70, 0x62, 0x2e, 0x4c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, | |
| 	0x6b, 0x65, 0x6e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x60, 0x0a, | |
| 	0x11, 0x52, 0x65, 0x6c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, 0x6b, | |
| 	0x65, 0x6e, 0x12, 0x23, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, 0x5f, 0x70, 0x62, 0x2e, 0x52, | |
| 	0x65, 0x6c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, 0x54, 0x6f, 0x6b, 0x65, 0x6e, | |
| 	0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x24, 0x2e, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, | |
| 	0x5f, 0x70, 0x62, 0x2e, 0x52, 0x65, 0x6c, 0x65, 0x61, 0x73, 0x65, 0x41, 0x64, 0x6d, 0x69, 0x6e, | |
| 	0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x42, | |
| 	0x32, 0x5a, 0x30, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x63, 0x68, | |
| 	0x72, 0x69, 0x73, 0x6c, 0x75, 0x73, 0x66, 0x2f, 0x73, 0x65, 0x61, 0x77, 0x65, 0x65, 0x64, 0x66, | |
| 	0x73, 0x2f, 0x77, 0x65, 0x65, 0x64, 0x2f, 0x70, 0x62, 0x2f, 0x6d, 0x61, 0x73, 0x74, 0x65, 0x72, | |
| 	0x5f, 0x70, 0x62, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, | |
| } | |
| 
 | |
| var ( | |
| 	file_master_proto_rawDescOnce sync.Once | |
| 	file_master_proto_rawDescData = file_master_proto_rawDesc | |
| ) | |
| 
 | |
| func file_master_proto_rawDescGZIP() []byte { | |
| 	file_master_proto_rawDescOnce.Do(func() { | |
| 		file_master_proto_rawDescData = protoimpl.X.CompressGZIP(file_master_proto_rawDescData) | |
| 	}) | |
| 	return file_master_proto_rawDescData | |
| } | |
| 
 | |
| var file_master_proto_msgTypes = make([]protoimpl.MessageInfo, 43) | |
| var file_master_proto_goTypes = []interface{}{ | |
| 	(*Heartbeat)(nil),                                // 0: master_pb.Heartbeat | |
| 	(*HeartbeatResponse)(nil),                        // 1: master_pb.HeartbeatResponse | |
| 	(*VolumeInformationMessage)(nil),                 // 2: master_pb.VolumeInformationMessage | |
| 	(*VolumeShortInformationMessage)(nil),            // 3: master_pb.VolumeShortInformationMessage | |
| 	(*VolumeEcShardInformationMessage)(nil),          // 4: master_pb.VolumeEcShardInformationMessage | |
| 	(*StorageBackend)(nil),                           // 5: master_pb.StorageBackend | |
| 	(*Empty)(nil),                                    // 6: master_pb.Empty | |
| 	(*SuperBlockExtra)(nil),                          // 7: master_pb.SuperBlockExtra | |
| 	(*KeepConnectedRequest)(nil),                     // 8: master_pb.KeepConnectedRequest | |
| 	(*VolumeLocation)(nil),                           // 9: master_pb.VolumeLocation | |
| 	(*LookupVolumeRequest)(nil),                      // 10: master_pb.LookupVolumeRequest | |
| 	(*LookupVolumeResponse)(nil),                     // 11: master_pb.LookupVolumeResponse | |
| 	(*Location)(nil),                                 // 12: master_pb.Location | |
| 	(*AssignRequest)(nil),                            // 13: master_pb.AssignRequest | |
| 	(*AssignResponse)(nil),                           // 14: master_pb.AssignResponse | |
| 	(*StatisticsRequest)(nil),                        // 15: master_pb.StatisticsRequest | |
| 	(*StatisticsResponse)(nil),                       // 16: master_pb.StatisticsResponse | |
| 	(*StorageType)(nil),                              // 17: master_pb.StorageType | |
| 	(*Collection)(nil),                               // 18: master_pb.Collection | |
| 	(*CollectionListRequest)(nil),                    // 19: master_pb.CollectionListRequest | |
| 	(*CollectionListResponse)(nil),                   // 20: master_pb.CollectionListResponse | |
| 	(*CollectionDeleteRequest)(nil),                  // 21: master_pb.CollectionDeleteRequest | |
| 	(*CollectionDeleteResponse)(nil),                 // 22: master_pb.CollectionDeleteResponse | |
| 	(*DataNodeInfo)(nil),                             // 23: master_pb.DataNodeInfo | |
| 	(*RackInfo)(nil),                                 // 24: master_pb.RackInfo | |
| 	(*DataCenterInfo)(nil),                           // 25: master_pb.DataCenterInfo | |
| 	(*TopologyInfo)(nil),                             // 26: master_pb.TopologyInfo | |
| 	(*VolumeListRequest)(nil),                        // 27: master_pb.VolumeListRequest | |
| 	(*VolumeListResponse)(nil),                       // 28: master_pb.VolumeListResponse | |
| 	(*LookupEcVolumeRequest)(nil),                    // 29: master_pb.LookupEcVolumeRequest | |
| 	(*LookupEcVolumeResponse)(nil),                   // 30: master_pb.LookupEcVolumeResponse | |
| 	(*GetMasterConfigurationRequest)(nil),            // 31: master_pb.GetMasterConfigurationRequest | |
| 	(*GetMasterConfigurationResponse)(nil),           // 32: master_pb.GetMasterConfigurationResponse | |
| 	(*ListMasterClientsRequest)(nil),                 // 33: master_pb.ListMasterClientsRequest | |
| 	(*ListMasterClientsResponse)(nil),                // 34: master_pb.ListMasterClientsResponse | |
| 	(*LeaseAdminTokenRequest)(nil),                   // 35: master_pb.LeaseAdminTokenRequest | |
| 	(*LeaseAdminTokenResponse)(nil),                  // 36: master_pb.LeaseAdminTokenResponse | |
| 	(*ReleaseAdminTokenRequest)(nil),                 // 37: master_pb.ReleaseAdminTokenRequest | |
| 	(*ReleaseAdminTokenResponse)(nil),                // 38: master_pb.ReleaseAdminTokenResponse | |
| 	nil,                                              // 39: master_pb.StorageBackend.PropertiesEntry | |
| 	(*SuperBlockExtra_ErasureCoding)(nil),            // 40: master_pb.SuperBlockExtra.ErasureCoding | |
| 	(*LookupVolumeResponse_VolumeIdLocation)(nil),    // 41: master_pb.LookupVolumeResponse.VolumeIdLocation | |
| 	(*LookupEcVolumeResponse_EcShardIdLocation)(nil), // 42: master_pb.LookupEcVolumeResponse.EcShardIdLocation | |
| } | |
| var file_master_proto_depIdxs = []int32{ | |
| 	2,  // 0: master_pb.Heartbeat.volumes:type_name -> master_pb.VolumeInformationMessage | |
| 	3,  // 1: master_pb.Heartbeat.new_volumes:type_name -> master_pb.VolumeShortInformationMessage | |
| 	3,  // 2: master_pb.Heartbeat.deleted_volumes:type_name -> master_pb.VolumeShortInformationMessage | |
| 	4,  // 3: master_pb.Heartbeat.ec_shards:type_name -> master_pb.VolumeEcShardInformationMessage | |
| 	4,  // 4: master_pb.Heartbeat.new_ec_shards:type_name -> master_pb.VolumeEcShardInformationMessage | |
| 	4,  // 5: master_pb.Heartbeat.deleted_ec_shards:type_name -> master_pb.VolumeEcShardInformationMessage | |
| 	5,  // 6: master_pb.HeartbeatResponse.storage_backends:type_name -> master_pb.StorageBackend | |
| 	39, // 7: master_pb.StorageBackend.properties:type_name -> master_pb.StorageBackend.PropertiesEntry | |
| 	40, // 8: master_pb.SuperBlockExtra.erasure_coding:type_name -> master_pb.SuperBlockExtra.ErasureCoding | |
| 	41, // 9: master_pb.LookupVolumeResponse.volume_id_locations:type_name -> master_pb.LookupVolumeResponse.VolumeIdLocation | |
| 	18, // 10: master_pb.CollectionListResponse.collections:type_name -> master_pb.Collection | |
| 	2,  // 11: master_pb.DataNodeInfo.volume_infos:type_name -> master_pb.VolumeInformationMessage | |
| 	4,  // 12: master_pb.DataNodeInfo.ec_shard_infos:type_name -> master_pb.VolumeEcShardInformationMessage | |
| 	23, // 13: master_pb.RackInfo.data_node_infos:type_name -> master_pb.DataNodeInfo | |
| 	24, // 14: master_pb.DataCenterInfo.rack_infos:type_name -> master_pb.RackInfo | |
| 	25, // 15: master_pb.TopologyInfo.data_center_infos:type_name -> master_pb.DataCenterInfo | |
| 	26, // 16: master_pb.VolumeListResponse.topology_info:type_name -> master_pb.TopologyInfo | |
| 	42, // 17: master_pb.LookupEcVolumeResponse.shard_id_locations:type_name -> master_pb.LookupEcVolumeResponse.EcShardIdLocation | |
| 	5,  // 18: master_pb.GetMasterConfigurationResponse.storage_backends:type_name -> master_pb.StorageBackend | |
| 	12, // 19: master_pb.LookupVolumeResponse.VolumeIdLocation.locations:type_name -> master_pb.Location | |
| 	12, // 20: master_pb.LookupEcVolumeResponse.EcShardIdLocation.locations:type_name -> master_pb.Location | |
| 	0,  // 21: master_pb.Seaweed.SendHeartbeat:input_type -> master_pb.Heartbeat | |
| 	8,  // 22: master_pb.Seaweed.KeepConnected:input_type -> master_pb.KeepConnectedRequest | |
| 	10, // 23: master_pb.Seaweed.LookupVolume:input_type -> master_pb.LookupVolumeRequest | |
| 	13, // 24: master_pb.Seaweed.Assign:input_type -> master_pb.AssignRequest | |
| 	15, // 25: master_pb.Seaweed.Statistics:input_type -> master_pb.StatisticsRequest | |
| 	19, // 26: master_pb.Seaweed.CollectionList:input_type -> master_pb.CollectionListRequest | |
| 	21, // 27: master_pb.Seaweed.CollectionDelete:input_type -> master_pb.CollectionDeleteRequest | |
| 	27, // 28: master_pb.Seaweed.VolumeList:input_type -> master_pb.VolumeListRequest | |
| 	29, // 29: master_pb.Seaweed.LookupEcVolume:input_type -> master_pb.LookupEcVolumeRequest | |
| 	31, // 30: master_pb.Seaweed.GetMasterConfiguration:input_type -> master_pb.GetMasterConfigurationRequest | |
| 	33, // 31: master_pb.Seaweed.ListMasterClients:input_type -> master_pb.ListMasterClientsRequest | |
| 	35, // 32: master_pb.Seaweed.LeaseAdminToken:input_type -> master_pb.LeaseAdminTokenRequest | |
| 	37, // 33: master_pb.Seaweed.ReleaseAdminToken:input_type -> master_pb.ReleaseAdminTokenRequest | |
| 	1,  // 34: master_pb.Seaweed.SendHeartbeat:output_type -> master_pb.HeartbeatResponse | |
| 	9,  // 35: master_pb.Seaweed.KeepConnected:output_type -> master_pb.VolumeLocation | |
| 	11, // 36: master_pb.Seaweed.LookupVolume:output_type -> master_pb.LookupVolumeResponse | |
| 	14, // 37: master_pb.Seaweed.Assign:output_type -> master_pb.AssignResponse | |
| 	16, // 38: master_pb.Seaweed.Statistics:output_type -> master_pb.StatisticsResponse | |
| 	20, // 39: master_pb.Seaweed.CollectionList:output_type -> master_pb.CollectionListResponse | |
| 	22, // 40: master_pb.Seaweed.CollectionDelete:output_type -> master_pb.CollectionDeleteResponse | |
| 	28, // 41: master_pb.Seaweed.VolumeList:output_type -> master_pb.VolumeListResponse | |
| 	30, // 42: master_pb.Seaweed.LookupEcVolume:output_type -> master_pb.LookupEcVolumeResponse | |
| 	32, // 43: master_pb.Seaweed.GetMasterConfiguration:output_type -> master_pb.GetMasterConfigurationResponse | |
| 	34, // 44: master_pb.Seaweed.ListMasterClients:output_type -> master_pb.ListMasterClientsResponse | |
| 	36, // 45: master_pb.Seaweed.LeaseAdminToken:output_type -> master_pb.LeaseAdminTokenResponse | |
| 	38, // 46: master_pb.Seaweed.ReleaseAdminToken:output_type -> master_pb.ReleaseAdminTokenResponse | |
| 	34, // [34:47] is the sub-list for method output_type | |
| 	21, // [21:34] is the sub-list for method input_type | |
| 	21, // [21:21] is the sub-list for extension type_name | |
| 	21, // [21:21] is the sub-list for extension extendee | |
| 	0,  // [0:21] is the sub-list for field type_name | |
| } | |
| 
 | |
| func init() { file_master_proto_init() } | |
| func file_master_proto_init() { | |
| 	if File_master_proto != nil { | |
| 		return | |
| 	} | |
| 	if !protoimpl.UnsafeEnabled { | |
| 		file_master_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*Heartbeat); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*HeartbeatResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*VolumeInformationMessage); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*VolumeShortInformationMessage); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[4].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*VolumeEcShardInformationMessage); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[5].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*StorageBackend); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[6].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*Empty); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[7].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*SuperBlockExtra); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[8].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*KeepConnectedRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[9].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*VolumeLocation); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[10].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LookupVolumeRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[11].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LookupVolumeResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[12].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*Location); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[13].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*AssignRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[14].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*AssignResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[15].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*StatisticsRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[16].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*StatisticsResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[17].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*StorageType); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[18].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*Collection); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[19].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*CollectionListRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[20].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*CollectionListResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[21].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*CollectionDeleteRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[22].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*CollectionDeleteResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[23].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*DataNodeInfo); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[24].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*RackInfo); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[25].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*DataCenterInfo); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[26].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*TopologyInfo); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[27].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*VolumeListRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[28].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*VolumeListResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[29].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LookupEcVolumeRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[30].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LookupEcVolumeResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[31].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*GetMasterConfigurationRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[32].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*GetMasterConfigurationResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[33].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*ListMasterClientsRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[34].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*ListMasterClientsResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[35].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LeaseAdminTokenRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[36].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LeaseAdminTokenResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[37].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*ReleaseAdminTokenRequest); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[38].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*ReleaseAdminTokenResponse); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[40].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*SuperBlockExtra_ErasureCoding); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[41].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LookupVolumeResponse_VolumeIdLocation); i { | |
| 			case 0: | |
| 				return &v.state | |
| 			case 1: | |
| 				return &v.sizeCache | |
| 			case 2: | |
| 				return &v.unknownFields | |
| 			default: | |
| 				return nil | |
| 			} | |
| 		} | |
| 		file_master_proto_msgTypes[42].Exporter = func(v interface{}, i int) interface{} { | |
| 			switch v := v.(*LookupEcVolumeResponse_EcShardIdLocation); 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_master_proto_rawDesc, | |
| 			NumEnums:      0, | |
| 			NumMessages:   43, | |
| 			NumExtensions: 0, | |
| 			NumServices:   1, | |
| 		}, | |
| 		GoTypes:           file_master_proto_goTypes, | |
| 		DependencyIndexes: file_master_proto_depIdxs, | |
| 		MessageInfos:      file_master_proto_msgTypes, | |
| 	}.Build() | |
| 	File_master_proto = out.File | |
| 	file_master_proto_rawDesc = nil | |
| 	file_master_proto_goTypes = nil | |
| 	file_master_proto_depIdxs = nil | |
| } | |
| 
 | |
| // Reference imports to suppress errors if they are not otherwise used. | |
| var _ context.Context | |
| var _ grpc.ClientConnInterface | |
| 
 | |
| // This is a compile-time assertion to ensure that this generated file | |
| // is compatible with the grpc package it is being compiled against. | |
| const _ = grpc.SupportPackageIsVersion6 | |
| 
 | |
| // SeaweedClient is the client API for Seaweed service. | |
| // | |
| // For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. | |
| type SeaweedClient interface { | |
| 	SendHeartbeat(ctx context.Context, opts ...grpc.CallOption) (Seaweed_SendHeartbeatClient, error) | |
| 	KeepConnected(ctx context.Context, opts ...grpc.CallOption) (Seaweed_KeepConnectedClient, error) | |
| 	LookupVolume(ctx context.Context, in *LookupVolumeRequest, opts ...grpc.CallOption) (*LookupVolumeResponse, error) | |
| 	Assign(ctx context.Context, in *AssignRequest, opts ...grpc.CallOption) (*AssignResponse, error) | |
| 	Statistics(ctx context.Context, in *StatisticsRequest, opts ...grpc.CallOption) (*StatisticsResponse, error) | |
| 	CollectionList(ctx context.Context, in *CollectionListRequest, opts ...grpc.CallOption) (*CollectionListResponse, error) | |
| 	CollectionDelete(ctx context.Context, in *CollectionDeleteRequest, opts ...grpc.CallOption) (*CollectionDeleteResponse, error) | |
| 	VolumeList(ctx context.Context, in *VolumeListRequest, opts ...grpc.CallOption) (*VolumeListResponse, error) | |
| 	LookupEcVolume(ctx context.Context, in *LookupEcVolumeRequest, opts ...grpc.CallOption) (*LookupEcVolumeResponse, error) | |
| 	GetMasterConfiguration(ctx context.Context, in *GetMasterConfigurationRequest, opts ...grpc.CallOption) (*GetMasterConfigurationResponse, error) | |
| 	ListMasterClients(ctx context.Context, in *ListMasterClientsRequest, opts ...grpc.CallOption) (*ListMasterClientsResponse, error) | |
| 	LeaseAdminToken(ctx context.Context, in *LeaseAdminTokenRequest, opts ...grpc.CallOption) (*LeaseAdminTokenResponse, error) | |
| 	ReleaseAdminToken(ctx context.Context, in *ReleaseAdminTokenRequest, opts ...grpc.CallOption) (*ReleaseAdminTokenResponse, error) | |
| } | |
| 
 | |
| type seaweedClient struct { | |
| 	cc grpc.ClientConnInterface | |
| } | |
| 
 | |
| func NewSeaweedClient(cc grpc.ClientConnInterface) SeaweedClient { | |
| 	return &seaweedClient{cc} | |
| } | |
| 
 | |
| func (c *seaweedClient) SendHeartbeat(ctx context.Context, opts ...grpc.CallOption) (Seaweed_SendHeartbeatClient, error) { | |
| 	stream, err := c.cc.NewStream(ctx, &_Seaweed_serviceDesc.Streams[0], "/master_pb.Seaweed/SendHeartbeat", opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	x := &seaweedSendHeartbeatClient{stream} | |
| 	return x, nil | |
| } | |
| 
 | |
| type Seaweed_SendHeartbeatClient interface { | |
| 	Send(*Heartbeat) error | |
| 	Recv() (*HeartbeatResponse, error) | |
| 	grpc.ClientStream | |
| } | |
| 
 | |
| type seaweedSendHeartbeatClient struct { | |
| 	grpc.ClientStream | |
| } | |
| 
 | |
| func (x *seaweedSendHeartbeatClient) Send(m *Heartbeat) error { | |
| 	return x.ClientStream.SendMsg(m) | |
| } | |
| 
 | |
| func (x *seaweedSendHeartbeatClient) Recv() (*HeartbeatResponse, error) { | |
| 	m := new(HeartbeatResponse) | |
| 	if err := x.ClientStream.RecvMsg(m); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return m, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) KeepConnected(ctx context.Context, opts ...grpc.CallOption) (Seaweed_KeepConnectedClient, error) { | |
| 	stream, err := c.cc.NewStream(ctx, &_Seaweed_serviceDesc.Streams[1], "/master_pb.Seaweed/KeepConnected", opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	x := &seaweedKeepConnectedClient{stream} | |
| 	return x, nil | |
| } | |
| 
 | |
| type Seaweed_KeepConnectedClient interface { | |
| 	Send(*KeepConnectedRequest) error | |
| 	Recv() (*VolumeLocation, error) | |
| 	grpc.ClientStream | |
| } | |
| 
 | |
| type seaweedKeepConnectedClient struct { | |
| 	grpc.ClientStream | |
| } | |
| 
 | |
| func (x *seaweedKeepConnectedClient) Send(m *KeepConnectedRequest) error { | |
| 	return x.ClientStream.SendMsg(m) | |
| } | |
| 
 | |
| func (x *seaweedKeepConnectedClient) Recv() (*VolumeLocation, error) { | |
| 	m := new(VolumeLocation) | |
| 	if err := x.ClientStream.RecvMsg(m); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return m, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) LookupVolume(ctx context.Context, in *LookupVolumeRequest, opts ...grpc.CallOption) (*LookupVolumeResponse, error) { | |
| 	out := new(LookupVolumeResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/LookupVolume", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) Assign(ctx context.Context, in *AssignRequest, opts ...grpc.CallOption) (*AssignResponse, error) { | |
| 	out := new(AssignResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/Assign", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) Statistics(ctx context.Context, in *StatisticsRequest, opts ...grpc.CallOption) (*StatisticsResponse, error) { | |
| 	out := new(StatisticsResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/Statistics", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) CollectionList(ctx context.Context, in *CollectionListRequest, opts ...grpc.CallOption) (*CollectionListResponse, error) { | |
| 	out := new(CollectionListResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/CollectionList", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) CollectionDelete(ctx context.Context, in *CollectionDeleteRequest, opts ...grpc.CallOption) (*CollectionDeleteResponse, error) { | |
| 	out := new(CollectionDeleteResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/CollectionDelete", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) VolumeList(ctx context.Context, in *VolumeListRequest, opts ...grpc.CallOption) (*VolumeListResponse, error) { | |
| 	out := new(VolumeListResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/VolumeList", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) LookupEcVolume(ctx context.Context, in *LookupEcVolumeRequest, opts ...grpc.CallOption) (*LookupEcVolumeResponse, error) { | |
| 	out := new(LookupEcVolumeResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/LookupEcVolume", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) GetMasterConfiguration(ctx context.Context, in *GetMasterConfigurationRequest, opts ...grpc.CallOption) (*GetMasterConfigurationResponse, error) { | |
| 	out := new(GetMasterConfigurationResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/GetMasterConfiguration", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) ListMasterClients(ctx context.Context, in *ListMasterClientsRequest, opts ...grpc.CallOption) (*ListMasterClientsResponse, error) { | |
| 	out := new(ListMasterClientsResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/ListMasterClients", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) LeaseAdminToken(ctx context.Context, in *LeaseAdminTokenRequest, opts ...grpc.CallOption) (*LeaseAdminTokenResponse, error) { | |
| 	out := new(LeaseAdminTokenResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/LeaseAdminToken", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| func (c *seaweedClient) ReleaseAdminToken(ctx context.Context, in *ReleaseAdminTokenRequest, opts ...grpc.CallOption) (*ReleaseAdminTokenResponse, error) { | |
| 	out := new(ReleaseAdminTokenResponse) | |
| 	err := c.cc.Invoke(ctx, "/master_pb.Seaweed/ReleaseAdminToken", in, out, opts...) | |
| 	if err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return out, nil | |
| } | |
| 
 | |
| // SeaweedServer is the server API for Seaweed service. | |
| type SeaweedServer interface { | |
| 	SendHeartbeat(Seaweed_SendHeartbeatServer) error | |
| 	KeepConnected(Seaweed_KeepConnectedServer) error | |
| 	LookupVolume(context.Context, *LookupVolumeRequest) (*LookupVolumeResponse, error) | |
| 	Assign(context.Context, *AssignRequest) (*AssignResponse, error) | |
| 	Statistics(context.Context, *StatisticsRequest) (*StatisticsResponse, error) | |
| 	CollectionList(context.Context, *CollectionListRequest) (*CollectionListResponse, error) | |
| 	CollectionDelete(context.Context, *CollectionDeleteRequest) (*CollectionDeleteResponse, error) | |
| 	VolumeList(context.Context, *VolumeListRequest) (*VolumeListResponse, error) | |
| 	LookupEcVolume(context.Context, *LookupEcVolumeRequest) (*LookupEcVolumeResponse, error) | |
| 	GetMasterConfiguration(context.Context, *GetMasterConfigurationRequest) (*GetMasterConfigurationResponse, error) | |
| 	ListMasterClients(context.Context, *ListMasterClientsRequest) (*ListMasterClientsResponse, error) | |
| 	LeaseAdminToken(context.Context, *LeaseAdminTokenRequest) (*LeaseAdminTokenResponse, error) | |
| 	ReleaseAdminToken(context.Context, *ReleaseAdminTokenRequest) (*ReleaseAdminTokenResponse, error) | |
| } | |
| 
 | |
| // UnimplementedSeaweedServer can be embedded to have forward compatible implementations. | |
| type UnimplementedSeaweedServer struct { | |
| } | |
| 
 | |
| func (*UnimplementedSeaweedServer) SendHeartbeat(Seaweed_SendHeartbeatServer) error { | |
| 	return status.Errorf(codes.Unimplemented, "method SendHeartbeat not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) KeepConnected(Seaweed_KeepConnectedServer) error { | |
| 	return status.Errorf(codes.Unimplemented, "method KeepConnected not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) LookupVolume(context.Context, *LookupVolumeRequest) (*LookupVolumeResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method LookupVolume not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) Assign(context.Context, *AssignRequest) (*AssignResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method Assign not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) Statistics(context.Context, *StatisticsRequest) (*StatisticsResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method Statistics not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) CollectionList(context.Context, *CollectionListRequest) (*CollectionListResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method CollectionList not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) CollectionDelete(context.Context, *CollectionDeleteRequest) (*CollectionDeleteResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method CollectionDelete not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) VolumeList(context.Context, *VolumeListRequest) (*VolumeListResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method VolumeList not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) LookupEcVolume(context.Context, *LookupEcVolumeRequest) (*LookupEcVolumeResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method LookupEcVolume not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) GetMasterConfiguration(context.Context, *GetMasterConfigurationRequest) (*GetMasterConfigurationResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method GetMasterConfiguration not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) ListMasterClients(context.Context, *ListMasterClientsRequest) (*ListMasterClientsResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method ListMasterClients not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) LeaseAdminToken(context.Context, *LeaseAdminTokenRequest) (*LeaseAdminTokenResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method LeaseAdminToken not implemented") | |
| } | |
| func (*UnimplementedSeaweedServer) ReleaseAdminToken(context.Context, *ReleaseAdminTokenRequest) (*ReleaseAdminTokenResponse, error) { | |
| 	return nil, status.Errorf(codes.Unimplemented, "method ReleaseAdminToken not implemented") | |
| } | |
| 
 | |
| func RegisterSeaweedServer(s *grpc.Server, srv SeaweedServer) { | |
| 	s.RegisterService(&_Seaweed_serviceDesc, srv) | |
| } | |
| 
 | |
| func _Seaweed_SendHeartbeat_Handler(srv interface{}, stream grpc.ServerStream) error { | |
| 	return srv.(SeaweedServer).SendHeartbeat(&seaweedSendHeartbeatServer{stream}) | |
| } | |
| 
 | |
| type Seaweed_SendHeartbeatServer interface { | |
| 	Send(*HeartbeatResponse) error | |
| 	Recv() (*Heartbeat, error) | |
| 	grpc.ServerStream | |
| } | |
| 
 | |
| type seaweedSendHeartbeatServer struct { | |
| 	grpc.ServerStream | |
| } | |
| 
 | |
| func (x *seaweedSendHeartbeatServer) Send(m *HeartbeatResponse) error { | |
| 	return x.ServerStream.SendMsg(m) | |
| } | |
| 
 | |
| func (x *seaweedSendHeartbeatServer) Recv() (*Heartbeat, error) { | |
| 	m := new(Heartbeat) | |
| 	if err := x.ServerStream.RecvMsg(m); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return m, nil | |
| } | |
| 
 | |
| func _Seaweed_KeepConnected_Handler(srv interface{}, stream grpc.ServerStream) error { | |
| 	return srv.(SeaweedServer).KeepConnected(&seaweedKeepConnectedServer{stream}) | |
| } | |
| 
 | |
| type Seaweed_KeepConnectedServer interface { | |
| 	Send(*VolumeLocation) error | |
| 	Recv() (*KeepConnectedRequest, error) | |
| 	grpc.ServerStream | |
| } | |
| 
 | |
| type seaweedKeepConnectedServer struct { | |
| 	grpc.ServerStream | |
| } | |
| 
 | |
| func (x *seaweedKeepConnectedServer) Send(m *VolumeLocation) error { | |
| 	return x.ServerStream.SendMsg(m) | |
| } | |
| 
 | |
| func (x *seaweedKeepConnectedServer) Recv() (*KeepConnectedRequest, error) { | |
| 	m := new(KeepConnectedRequest) | |
| 	if err := x.ServerStream.RecvMsg(m); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	return m, nil | |
| } | |
| 
 | |
| func _Seaweed_LookupVolume_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(LookupVolumeRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).LookupVolume(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/LookupVolume", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).LookupVolume(ctx, req.(*LookupVolumeRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_Assign_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(AssignRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).Assign(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/Assign", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).Assign(ctx, req.(*AssignRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_Statistics_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(StatisticsRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).Statistics(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/Statistics", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).Statistics(ctx, req.(*StatisticsRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_CollectionList_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(CollectionListRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).CollectionList(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/CollectionList", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).CollectionList(ctx, req.(*CollectionListRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_CollectionDelete_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(CollectionDeleteRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).CollectionDelete(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/CollectionDelete", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).CollectionDelete(ctx, req.(*CollectionDeleteRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_VolumeList_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(VolumeListRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).VolumeList(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/VolumeList", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).VolumeList(ctx, req.(*VolumeListRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_LookupEcVolume_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(LookupEcVolumeRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).LookupEcVolume(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/LookupEcVolume", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).LookupEcVolume(ctx, req.(*LookupEcVolumeRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_GetMasterConfiguration_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(GetMasterConfigurationRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).GetMasterConfiguration(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/GetMasterConfiguration", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).GetMasterConfiguration(ctx, req.(*GetMasterConfigurationRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_ListMasterClients_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(ListMasterClientsRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).ListMasterClients(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/ListMasterClients", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).ListMasterClients(ctx, req.(*ListMasterClientsRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_LeaseAdminToken_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(LeaseAdminTokenRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).LeaseAdminToken(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/LeaseAdminToken", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).LeaseAdminToken(ctx, req.(*LeaseAdminTokenRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| func _Seaweed_ReleaseAdminToken_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { | |
| 	in := new(ReleaseAdminTokenRequest) | |
| 	if err := dec(in); err != nil { | |
| 		return nil, err | |
| 	} | |
| 	if interceptor == nil { | |
| 		return srv.(SeaweedServer).ReleaseAdminToken(ctx, in) | |
| 	} | |
| 	info := &grpc.UnaryServerInfo{ | |
| 		Server:     srv, | |
| 		FullMethod: "/master_pb.Seaweed/ReleaseAdminToken", | |
| 	} | |
| 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | |
| 		return srv.(SeaweedServer).ReleaseAdminToken(ctx, req.(*ReleaseAdminTokenRequest)) | |
| 	} | |
| 	return interceptor(ctx, in, info, handler) | |
| } | |
| 
 | |
| var _Seaweed_serviceDesc = grpc.ServiceDesc{ | |
| 	ServiceName: "master_pb.Seaweed", | |
| 	HandlerType: (*SeaweedServer)(nil), | |
| 	Methods: []grpc.MethodDesc{ | |
| 		{ | |
| 			MethodName: "LookupVolume", | |
| 			Handler:    _Seaweed_LookupVolume_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "Assign", | |
| 			Handler:    _Seaweed_Assign_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "Statistics", | |
| 			Handler:    _Seaweed_Statistics_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "CollectionList", | |
| 			Handler:    _Seaweed_CollectionList_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "CollectionDelete", | |
| 			Handler:    _Seaweed_CollectionDelete_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "VolumeList", | |
| 			Handler:    _Seaweed_VolumeList_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "LookupEcVolume", | |
| 			Handler:    _Seaweed_LookupEcVolume_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "GetMasterConfiguration", | |
| 			Handler:    _Seaweed_GetMasterConfiguration_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "ListMasterClients", | |
| 			Handler:    _Seaweed_ListMasterClients_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "LeaseAdminToken", | |
| 			Handler:    _Seaweed_LeaseAdminToken_Handler, | |
| 		}, | |
| 		{ | |
| 			MethodName: "ReleaseAdminToken", | |
| 			Handler:    _Seaweed_ReleaseAdminToken_Handler, | |
| 		}, | |
| 	}, | |
| 	Streams: []grpc.StreamDesc{ | |
| 		{ | |
| 			StreamName:    "SendHeartbeat", | |
| 			Handler:       _Seaweed_SendHeartbeat_Handler, | |
| 			ServerStreams: true, | |
| 			ClientStreams: true, | |
| 		}, | |
| 		{ | |
| 			StreamName:    "KeepConnected", | |
| 			Handler:       _Seaweed_KeepConnected_Handler, | |
| 			ServerStreams: true, | |
| 			ClientStreams: true, | |
| 		}, | |
| 	}, | |
| 	Metadata: "master.proto", | |
| }
 |