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

package pb

import (
	pb 
	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)
)

// Envelope encloses a signed payload produced by a peer, along with the public
// key of the keypair it was signed with so that it can be statelessly validated
// by the receiver.
//
// The payload is prefixed with a byte string that determines the type, so it
// can be deserialized deterministically. Often, this byte string is a
// multicodec.
type Envelope struct {
	state protoimpl.MessageState `protogen:"open.v1"`
	// public_key is the public key of the keypair the enclosed payload was
	// signed with.
	PublicKey *pb.PublicKey `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"`
	// payload_type encodes the type of payload, so that it can be deserialized
	// deterministically.
	PayloadType []byte `protobuf:"bytes,2,opt,name=payload_type,json=payloadType,proto3" json:"payload_type,omitempty"`
	// payload is the actual payload carried inside this envelope.
	Payload []byte `protobuf:"bytes,3,opt,name=payload,proto3" json:"payload,omitempty"`
	// signature is the signature produced by the private key corresponding to
	// the enclosed public key, over the payload, prefixing a domain string for
	// additional security.
	Signature     []byte `protobuf:"bytes,5,opt,name=signature,proto3" json:"signature,omitempty"`
	unknownFields protoimpl.UnknownFields
	sizeCache     protoimpl.SizeCache
}

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

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

func (*Envelope) () {}

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

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

func ( *Envelope) () *pb.PublicKey {
	if  != nil {
		return .PublicKey
	}
	return nil
}

func ( *Envelope) () []byte {
	if  != nil {
		return .PayloadType
	}
	return nil
}

func ( *Envelope) () []byte {
	if  != nil {
		return .Payload
	}
	return nil
}

func ( *Envelope) () []byte {
	if  != nil {
		return .Signature
	}
	return nil
}

var File_core_record_pb_envelope_proto protoreflect.FileDescriptor

const file_core_record_pb_envelope_proto_rawDesc = "" +
	"\n" +
	"\x1dcore/record/pb/envelope.proto\x12\trecord.pb\x1a\x1bcore/crypto/pb/crypto.proto\"\x9a\x01\n" +
	"\bEnvelope\x123\n" +
	"\n" +
	"public_key\x18\x01 \x01(\v2\x14.crypto.pb.PublicKeyR\tpublicKey\x12!\n" +
	"\fpayload_type\x18\x02 \x01(\fR\vpayloadType\x12\x18\n" +
	"\apayload\x18\x03 \x01(\fR\apayload\x12\x1c\n" +
	"\tsignature\x18\x05 \x01(\fR\tsignatureB,Z*github.com/libp2p/go-libp2p/core/record/pbb\x06proto3"

var (
	file_core_record_pb_envelope_proto_rawDescOnce sync.Once
	file_core_record_pb_envelope_proto_rawDescData []byte
)

func file_core_record_pb_envelope_proto_rawDescGZIP() []byte {
	file_core_record_pb_envelope_proto_rawDescOnce.Do(func() {
		file_core_record_pb_envelope_proto_rawDescData = protoimpl.X.CompressGZIP(unsafe.Slice(unsafe.StringData(file_core_record_pb_envelope_proto_rawDesc), len(file_core_record_pb_envelope_proto_rawDesc)))
	})
	return file_core_record_pb_envelope_proto_rawDescData
}

var file_core_record_pb_envelope_proto_msgTypes = make([]protoimpl.MessageInfo, 1)
var file_core_record_pb_envelope_proto_goTypes = []any{
	(*Envelope)(nil),     // 0: record.pb.Envelope
	(*pb.PublicKey)(nil), // 1: crypto.pb.PublicKey
}
var file_core_record_pb_envelope_proto_depIdxs = []int32{
	1, // 0: record.pb.Envelope.public_key:type_name -> crypto.pb.PublicKey
	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_record_pb_envelope_proto_init() }
func file_core_record_pb_envelope_proto_init() {
	if File_core_record_pb_envelope_proto != nil {
		return
	}
	type  struct{}
	 := protoimpl.TypeBuilder{
		File: protoimpl.DescBuilder{
			GoPackagePath: reflect.TypeOf({}).PkgPath(),
			RawDescriptor: unsafe.Slice(unsafe.StringData(file_core_record_pb_envelope_proto_rawDesc), len(file_core_record_pb_envelope_proto_rawDesc)),
			NumEnums:      0,
			NumMessages:   1,
			NumExtensions: 0,
			NumServices:   0,
		},
		GoTypes:           file_core_record_pb_envelope_proto_goTypes,
		DependencyIndexes: file_core_record_pb_envelope_proto_depIdxs,
		MessageInfos:      file_core_record_pb_envelope_proto_msgTypes,
	}.Build()
	File_core_record_pb_envelope_proto = .File
	file_core_record_pb_envelope_proto_goTypes = nil
	file_core_record_pb_envelope_proto_depIdxs = nil
}