// Code generated by protoc-gen-go. DO NOT EDIT.
// versions:
// 	protoc-gen-go v1.36.6
// 	protoc        v5.29.2
// source: core/peer/pb/peer_record.proto

package pb

import (
	protoreflect 
	protoimpl 
	reflect 
	sync 
	unsafe 
)

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)
)

// PeerRecord messages contain information that is useful to share with other peers.
// Currently, a PeerRecord contains the public listen addresses for a peer, but this
// is expected to expand to include other information in the future.
//
// PeerRecords are designed to be serialized to bytes and placed inside of
// SignedEnvelopes before sharing with other peers.
// See https://github.com/libp2p/go-libp2p/blob/master/core/record/pb/envelope.proto for
// the SignedEnvelope definition.
type PeerRecord struct {
	state protoimpl.MessageState `protogen:"open.v1"`
	// peer_id contains a libp2p peer id in its binary representation.
	PeerId []byte `protobuf:"bytes,1,opt,name=peer_id,json=peerId,proto3" json:"peer_id,omitempty"`
	// seq contains a monotonically-increasing sequence counter to order PeerRecords in time.
	Seq uint64 `protobuf:"varint,2,opt,name=seq,proto3" json:"seq,omitempty"`
	// addresses is a list of public listen addresses for the peer.
	Addresses     []*PeerRecord_AddressInfo `protobuf:"bytes,3,rep,name=addresses,proto3" json:"addresses,omitempty"`
	unknownFields protoimpl.UnknownFields
	sizeCache     protoimpl.SizeCache
}

func ( *PeerRecord) () {
	* = PeerRecord{}
	 := &file_core_peer_pb_peer_record_proto_msgTypes[0]
	 := protoimpl.X.MessageStateOf(protoimpl.Pointer())
	.StoreMessageInfo()
}

func ( *PeerRecord) () string {
	return protoimpl.X.MessageStringOf()
}

func (*PeerRecord) () {}

func ( *PeerRecord) () protoreflect.Message {
	 := &file_core_peer_pb_peer_record_proto_msgTypes[0]
	if  != nil {
		 := protoimpl.X.MessageStateOf(protoimpl.Pointer())
		if .LoadMessageInfo() == nil {
			.StoreMessageInfo()
		}
		return 
	}
	return .MessageOf()
}

// Deprecated: Use PeerRecord.ProtoReflect.Descriptor instead.
func (*PeerRecord) () ([]byte, []int) {
	return file_core_peer_pb_peer_record_proto_rawDescGZIP(), []int{0}
}

func ( *PeerRecord) () []byte {
	if  != nil {
		return .PeerId
	}
	return nil
}

func ( *PeerRecord) () uint64 {
	if  != nil {
		return .Seq
	}
	return 0
}

func ( *PeerRecord) () []*PeerRecord_AddressInfo {
	if  != nil {
		return .Addresses
	}
	return nil
}

// AddressInfo is a wrapper around a binary multiaddr. It is defined as a
// separate message to allow us to add per-address metadata in the future.
type PeerRecord_AddressInfo struct {
	state         protoimpl.MessageState `protogen:"open.v1"`
	Multiaddr     []byte                 `protobuf:"bytes,1,opt,name=multiaddr,proto3" json:"multiaddr,omitempty"`
	unknownFields protoimpl.UnknownFields
	sizeCache     protoimpl.SizeCache
}

func ( *PeerRecord_AddressInfo) () {
	* = PeerRecord_AddressInfo{}
	 := &file_core_peer_pb_peer_record_proto_msgTypes[1]
	 := protoimpl.X.MessageStateOf(protoimpl.Pointer())
	.StoreMessageInfo()
}

func ( *PeerRecord_AddressInfo) () string {
	return protoimpl.X.MessageStringOf()
}

func (*PeerRecord_AddressInfo) () {}

func ( *PeerRecord_AddressInfo) () protoreflect.Message {
	 := &file_core_peer_pb_peer_record_proto_msgTypes[1]
	if  != nil {
		 := protoimpl.X.MessageStateOf(protoimpl.Pointer())
		if .LoadMessageInfo() == nil {
			.StoreMessageInfo()
		}
		return 
	}
	return .MessageOf()
}

// Deprecated: Use PeerRecord_AddressInfo.ProtoReflect.Descriptor instead.
func (*PeerRecord_AddressInfo) () ([]byte, []int) {
	return file_core_peer_pb_peer_record_proto_rawDescGZIP(), []int{0, 0}
}

func ( *PeerRecord_AddressInfo) () []byte {
	if  != nil {
		return .Multiaddr
	}
	return nil
}

var File_core_peer_pb_peer_record_proto protoreflect.FileDescriptor

const file_core_peer_pb_peer_record_proto_rawDesc = "" +
	"\n" +
	"\x1ecore/peer/pb/peer_record.proto\x12\apeer.pb\"\xa3\x01\n" +
	"\n" +
	"PeerRecord\x12\x17\n" +
	"\apeer_id\x18\x01 \x01(\fR\x06peerId\x12\x10\n" +
	"\x03seq\x18\x02 \x01(\x04R\x03seq\x12=\n" +
	"\taddresses\x18\x03 \x03(\v2\x1f.peer.pb.PeerRecord.AddressInfoR\taddresses\x1a+\n" +
	"\vAddressInfo\x12\x1c\n" +
	"\tmultiaddr\x18\x01 \x01(\fR\tmultiaddrB*Z(github.com/libp2p/go-libp2p/core/peer/pbb\x06proto3"

var (
	file_core_peer_pb_peer_record_proto_rawDescOnce sync.Once
	file_core_peer_pb_peer_record_proto_rawDescData []byte
)

func file_core_peer_pb_peer_record_proto_rawDescGZIP() []byte {
	file_core_peer_pb_peer_record_proto_rawDescOnce.Do(func() {
		file_core_peer_pb_peer_record_proto_rawDescData = protoimpl.X.CompressGZIP(unsafe.Slice(unsafe.StringData(file_core_peer_pb_peer_record_proto_rawDesc), len(file_core_peer_pb_peer_record_proto_rawDesc)))
	})
	return file_core_peer_pb_peer_record_proto_rawDescData
}

var file_core_peer_pb_peer_record_proto_msgTypes = make([]protoimpl.MessageInfo, 2)
var file_core_peer_pb_peer_record_proto_goTypes = []any{
	(*PeerRecord)(nil),             // 0: peer.pb.PeerRecord
	(*PeerRecord_AddressInfo)(nil), // 1: peer.pb.PeerRecord.AddressInfo
}
var file_core_peer_pb_peer_record_proto_depIdxs = []int32{
	1, // 0: peer.pb.PeerRecord.addresses:type_name -> peer.pb.PeerRecord.AddressInfo
	1, // [1:1] is the sub-list for method output_type
	1, // [1:1] is the sub-list for method input_type
	1, // [1:1] is the sub-list for extension type_name
	1, // [1:1] is the sub-list for extension extendee
	0, // [0:1] is the sub-list for field type_name
}

func init() { file_core_peer_pb_peer_record_proto_init() }
func file_core_peer_pb_peer_record_proto_init() {
	if File_core_peer_pb_peer_record_proto != nil {
		return
	}
	type  struct{}
	 := protoimpl.TypeBuilder{
		File: protoimpl.DescBuilder{
			GoPackagePath: reflect.TypeOf({}).PkgPath(),
			RawDescriptor: unsafe.Slice(unsafe.StringData(file_core_peer_pb_peer_record_proto_rawDesc), len(file_core_peer_pb_peer_record_proto_rawDesc)),
			NumEnums:      0,
			NumMessages:   2,
			NumExtensions: 0,
			NumServices:   0,
		},
		GoTypes:           file_core_peer_pb_peer_record_proto_goTypes,
		DependencyIndexes: file_core_peer_pb_peer_record_proto_depIdxs,
		MessageInfos:      file_core_peer_pb_peer_record_proto_msgTypes,
	}.Build()
	File_core_peer_pb_peer_record_proto = .File
	file_core_peer_pb_peer_record_proto_goTypes = nil
	file_core_peer_pb_peer_record_proto_depIdxs = nil
}