// Code generated by protoc-gen-go. DO NOT EDIT. // source: rpc.proto package lnrpc // import "github.com/lightningnetwork/lnd/lnrpc" import proto "github.com/golang/protobuf/proto" import fmt "fmt" import math "math" import _ "google.golang.org/genproto/googleapis/api/annotations" import ( context "golang.org/x/net/context" grpc "google.golang.org/grpc" ) // Reference imports to suppress errors if they are not otherwise used. var _ = proto.Marshal var _ = fmt.Errorf var _ = math.Inf // This is a compile-time assertion to ensure that this generated file // is compatible with the proto package it is being compiled against. // A compilation error at this line likely means your copy of the // proto package needs to be updated. const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package // * // `AddressType` has to be one of: // // - `p2wkh`: Pay to witness key hash (`WITNESS_PUBKEY_HASH` = 0) // - `np2wkh`: Pay to nested witness key hash (`NESTED_PUBKEY_HASH` = 1) type AddressType int32 const ( AddressType_WITNESS_PUBKEY_HASH AddressType = 0 AddressType_NESTED_PUBKEY_HASH AddressType = 1 ) var AddressType_name = map[int32]string{ 0: "WITNESS_PUBKEY_HASH", 1: "NESTED_PUBKEY_HASH", } var AddressType_value = map[string]int32{ "WITNESS_PUBKEY_HASH": 0, "NESTED_PUBKEY_HASH": 1, } func (x AddressType) String() string { return proto.EnumName(AddressType_name, int32(x)) } func (AddressType) EnumDescriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{0} } type ChannelCloseSummary_ClosureType int32 const ( ChannelCloseSummary_COOPERATIVE_CLOSE ChannelCloseSummary_ClosureType = 0 ChannelCloseSummary_LOCAL_FORCE_CLOSE ChannelCloseSummary_ClosureType = 1 ChannelCloseSummary_REMOTE_FORCE_CLOSE ChannelCloseSummary_ClosureType = 2 ChannelCloseSummary_BREACH_CLOSE ChannelCloseSummary_ClosureType = 3 ChannelCloseSummary_FUNDING_CANCELED ChannelCloseSummary_ClosureType = 4 ChannelCloseSummary_ABANDONED ChannelCloseSummary_ClosureType = 5 ) var ChannelCloseSummary_ClosureType_name = map[int32]string{ 0: "COOPERATIVE_CLOSE", 1: "LOCAL_FORCE_CLOSE", 2: "REMOTE_FORCE_CLOSE", 3: "BREACH_CLOSE", 4: "FUNDING_CANCELED", 5: "ABANDONED", } var ChannelCloseSummary_ClosureType_value = map[string]int32{ "COOPERATIVE_CLOSE": 0, "LOCAL_FORCE_CLOSE": 1, "REMOTE_FORCE_CLOSE": 2, "BREACH_CLOSE": 3, "FUNDING_CANCELED": 4, "ABANDONED": 5, } func (x ChannelCloseSummary_ClosureType) String() string { return proto.EnumName(ChannelCloseSummary_ClosureType_name, int32(x)) } func (ChannelCloseSummary_ClosureType) EnumDescriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{39, 0} } type ChannelEventUpdate_UpdateType int32 const ( ChannelEventUpdate_OPEN_CHANNEL ChannelEventUpdate_UpdateType = 0 ChannelEventUpdate_CLOSED_CHANNEL ChannelEventUpdate_UpdateType = 1 ChannelEventUpdate_ACTIVE_CHANNEL ChannelEventUpdate_UpdateType = 2 ChannelEventUpdate_INACTIVE_CHANNEL ChannelEventUpdate_UpdateType = 3 ) var ChannelEventUpdate_UpdateType_name = map[int32]string{ 0: "OPEN_CHANNEL", 1: "CLOSED_CHANNEL", 2: "ACTIVE_CHANNEL", 3: "INACTIVE_CHANNEL", } var ChannelEventUpdate_UpdateType_value = map[string]int32{ "OPEN_CHANNEL": 0, "CLOSED_CHANNEL": 1, "ACTIVE_CHANNEL": 2, "INACTIVE_CHANNEL": 3, } func (x ChannelEventUpdate_UpdateType) String() string { return proto.EnumName(ChannelEventUpdate_UpdateType_name, int32(x)) } func (ChannelEventUpdate_UpdateType) EnumDescriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{60, 0} } type Invoice_InvoiceState int32 const ( Invoice_OPEN Invoice_InvoiceState = 0 Invoice_SETTLED Invoice_InvoiceState = 1 Invoice_CANCELED Invoice_InvoiceState = 2 ) var Invoice_InvoiceState_name = map[int32]string{ 0: "OPEN", 1: "SETTLED", 2: "CANCELED", } var Invoice_InvoiceState_value = map[string]int32{ "OPEN": 0, "SETTLED": 1, "CANCELED": 2, } func (x Invoice_InvoiceState) String() string { return proto.EnumName(Invoice_InvoiceState_name, int32(x)) } func (Invoice_InvoiceState) EnumDescriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{89, 0} } type GenSeedRequest struct { // * // aezeed_passphrase is an optional user provided passphrase that will be used // to encrypt the generated aezeed cipher seed. AezeedPassphrase []byte `protobuf:"bytes,1,opt,name=aezeed_passphrase,json=aezeedPassphrase,proto3" json:"aezeed_passphrase,omitempty"` // * // seed_entropy is an optional 16-bytes generated via CSPRNG. If not // specified, then a fresh set of randomness will be used to create the seed. SeedEntropy []byte `protobuf:"bytes,2,opt,name=seed_entropy,json=seedEntropy,proto3" json:"seed_entropy,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *GenSeedRequest) Reset() { *m = GenSeedRequest{} } func (m *GenSeedRequest) String() string { return proto.CompactTextString(m) } func (*GenSeedRequest) ProtoMessage() {} func (*GenSeedRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{0} } func (m *GenSeedRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GenSeedRequest.Unmarshal(m, b) } func (m *GenSeedRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_GenSeedRequest.Marshal(b, m, deterministic) } func (dst *GenSeedRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_GenSeedRequest.Merge(dst, src) } func (m *GenSeedRequest) XXX_Size() int { return xxx_messageInfo_GenSeedRequest.Size(m) } func (m *GenSeedRequest) XXX_DiscardUnknown() { xxx_messageInfo_GenSeedRequest.DiscardUnknown(m) } var xxx_messageInfo_GenSeedRequest proto.InternalMessageInfo func (m *GenSeedRequest) GetAezeedPassphrase() []byte { if m != nil { return m.AezeedPassphrase } return nil } func (m *GenSeedRequest) GetSeedEntropy() []byte { if m != nil { return m.SeedEntropy } return nil } type GenSeedResponse struct { // * // cipher_seed_mnemonic is a 24-word mnemonic that encodes a prior aezeed // cipher seed obtained by the user. This field is optional, as if not // provided, then the daemon will generate a new cipher seed for the user. // Otherwise, then the daemon will attempt to recover the wallet state linked // to this cipher seed. CipherSeedMnemonic []string `protobuf:"bytes,1,rep,name=cipher_seed_mnemonic,json=cipherSeedMnemonic,proto3" json:"cipher_seed_mnemonic,omitempty"` // * // enciphered_seed are the raw aezeed cipher seed bytes. This is the raw // cipher text before run through our mnemonic encoding scheme. EncipheredSeed []byte `protobuf:"bytes,2,opt,name=enciphered_seed,json=encipheredSeed,proto3" json:"enciphered_seed,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *GenSeedResponse) Reset() { *m = GenSeedResponse{} } func (m *GenSeedResponse) String() string { return proto.CompactTextString(m) } func (*GenSeedResponse) ProtoMessage() {} func (*GenSeedResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{1} } func (m *GenSeedResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GenSeedResponse.Unmarshal(m, b) } func (m *GenSeedResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_GenSeedResponse.Marshal(b, m, deterministic) } func (dst *GenSeedResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_GenSeedResponse.Merge(dst, src) } func (m *GenSeedResponse) XXX_Size() int { return xxx_messageInfo_GenSeedResponse.Size(m) } func (m *GenSeedResponse) XXX_DiscardUnknown() { xxx_messageInfo_GenSeedResponse.DiscardUnknown(m) } var xxx_messageInfo_GenSeedResponse proto.InternalMessageInfo func (m *GenSeedResponse) GetCipherSeedMnemonic() []string { if m != nil { return m.CipherSeedMnemonic } return nil } func (m *GenSeedResponse) GetEncipheredSeed() []byte { if m != nil { return m.EncipheredSeed } return nil } type InitWalletRequest struct { // * // wallet_password is the passphrase that should be used to encrypt the // wallet. This MUST be at least 8 chars in length. After creation, this // password is required to unlock the daemon. WalletPassword []byte `protobuf:"bytes,1,opt,name=wallet_password,json=walletPassword,proto3" json:"wallet_password,omitempty"` // * // cipher_seed_mnemonic is a 24-word mnemonic that encodes a prior aezeed // cipher seed obtained by the user. This may have been generated by the // GenSeed method, or be an existing seed. CipherSeedMnemonic []string `protobuf:"bytes,2,rep,name=cipher_seed_mnemonic,json=cipherSeedMnemonic,proto3" json:"cipher_seed_mnemonic,omitempty"` // * // aezeed_passphrase is an optional user provided passphrase that will be used // to encrypt the generated aezeed cipher seed. AezeedPassphrase []byte `protobuf:"bytes,3,opt,name=aezeed_passphrase,json=aezeedPassphrase,proto3" json:"aezeed_passphrase,omitempty"` // * // recovery_window is an optional argument specifying the address lookahead // when restoring a wallet seed. The recovery window applies to each // invdividual branch of the BIP44 derivation paths. Supplying a recovery // window of zero indicates that no addresses should be recovered, such after // the first initialization of the wallet. RecoveryWindow int32 `protobuf:"varint,4,opt,name=recovery_window,json=recoveryWindow,proto3" json:"recovery_window,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *InitWalletRequest) Reset() { *m = InitWalletRequest{} } func (m *InitWalletRequest) String() string { return proto.CompactTextString(m) } func (*InitWalletRequest) ProtoMessage() {} func (*InitWalletRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{2} } func (m *InitWalletRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_InitWalletRequest.Unmarshal(m, b) } func (m *InitWalletRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_InitWalletRequest.Marshal(b, m, deterministic) } func (dst *InitWalletRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_InitWalletRequest.Merge(dst, src) } func (m *InitWalletRequest) XXX_Size() int { return xxx_messageInfo_InitWalletRequest.Size(m) } func (m *InitWalletRequest) XXX_DiscardUnknown() { xxx_messageInfo_InitWalletRequest.DiscardUnknown(m) } var xxx_messageInfo_InitWalletRequest proto.InternalMessageInfo func (m *InitWalletRequest) GetWalletPassword() []byte { if m != nil { return m.WalletPassword } return nil } func (m *InitWalletRequest) GetCipherSeedMnemonic() []string { if m != nil { return m.CipherSeedMnemonic } return nil } func (m *InitWalletRequest) GetAezeedPassphrase() []byte { if m != nil { return m.AezeedPassphrase } return nil } func (m *InitWalletRequest) GetRecoveryWindow() int32 { if m != nil { return m.RecoveryWindow } return 0 } type InitWalletResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *InitWalletResponse) Reset() { *m = InitWalletResponse{} } func (m *InitWalletResponse) String() string { return proto.CompactTextString(m) } func (*InitWalletResponse) ProtoMessage() {} func (*InitWalletResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{3} } func (m *InitWalletResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_InitWalletResponse.Unmarshal(m, b) } func (m *InitWalletResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_InitWalletResponse.Marshal(b, m, deterministic) } func (dst *InitWalletResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_InitWalletResponse.Merge(dst, src) } func (m *InitWalletResponse) XXX_Size() int { return xxx_messageInfo_InitWalletResponse.Size(m) } func (m *InitWalletResponse) XXX_DiscardUnknown() { xxx_messageInfo_InitWalletResponse.DiscardUnknown(m) } var xxx_messageInfo_InitWalletResponse proto.InternalMessageInfo type UnlockWalletRequest struct { // * // wallet_password should be the current valid passphrase for the daemon. This // will be required to decrypt on-disk material that the daemon requires to // function properly. WalletPassword []byte `protobuf:"bytes,1,opt,name=wallet_password,json=walletPassword,proto3" json:"wallet_password,omitempty"` // * // recovery_window is an optional argument specifying the address lookahead // when restoring a wallet seed. The recovery window applies to each // invdividual branch of the BIP44 derivation paths. Supplying a recovery // window of zero indicates that no addresses should be recovered, such after // the first initialization of the wallet. RecoveryWindow int32 `protobuf:"varint,2,opt,name=recovery_window,json=recoveryWindow,proto3" json:"recovery_window,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *UnlockWalletRequest) Reset() { *m = UnlockWalletRequest{} } func (m *UnlockWalletRequest) String() string { return proto.CompactTextString(m) } func (*UnlockWalletRequest) ProtoMessage() {} func (*UnlockWalletRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{4} } func (m *UnlockWalletRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_UnlockWalletRequest.Unmarshal(m, b) } func (m *UnlockWalletRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_UnlockWalletRequest.Marshal(b, m, deterministic) } func (dst *UnlockWalletRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_UnlockWalletRequest.Merge(dst, src) } func (m *UnlockWalletRequest) XXX_Size() int { return xxx_messageInfo_UnlockWalletRequest.Size(m) } func (m *UnlockWalletRequest) XXX_DiscardUnknown() { xxx_messageInfo_UnlockWalletRequest.DiscardUnknown(m) } var xxx_messageInfo_UnlockWalletRequest proto.InternalMessageInfo func (m *UnlockWalletRequest) GetWalletPassword() []byte { if m != nil { return m.WalletPassword } return nil } func (m *UnlockWalletRequest) GetRecoveryWindow() int32 { if m != nil { return m.RecoveryWindow } return 0 } type UnlockWalletResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *UnlockWalletResponse) Reset() { *m = UnlockWalletResponse{} } func (m *UnlockWalletResponse) String() string { return proto.CompactTextString(m) } func (*UnlockWalletResponse) ProtoMessage() {} func (*UnlockWalletResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{5} } func (m *UnlockWalletResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_UnlockWalletResponse.Unmarshal(m, b) } func (m *UnlockWalletResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_UnlockWalletResponse.Marshal(b, m, deterministic) } func (dst *UnlockWalletResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_UnlockWalletResponse.Merge(dst, src) } func (m *UnlockWalletResponse) XXX_Size() int { return xxx_messageInfo_UnlockWalletResponse.Size(m) } func (m *UnlockWalletResponse) XXX_DiscardUnknown() { xxx_messageInfo_UnlockWalletResponse.DiscardUnknown(m) } var xxx_messageInfo_UnlockWalletResponse proto.InternalMessageInfo type ChangePasswordRequest struct { // * // current_password should be the current valid passphrase used to unlock the // daemon. CurrentPassword []byte `protobuf:"bytes,1,opt,name=current_password,json=currentPassword,proto3" json:"current_password,omitempty"` // * // new_password should be the new passphrase that will be needed to unlock the // daemon. NewPassword []byte `protobuf:"bytes,2,opt,name=new_password,json=newPassword,proto3" json:"new_password,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChangePasswordRequest) Reset() { *m = ChangePasswordRequest{} } func (m *ChangePasswordRequest) String() string { return proto.CompactTextString(m) } func (*ChangePasswordRequest) ProtoMessage() {} func (*ChangePasswordRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{6} } func (m *ChangePasswordRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChangePasswordRequest.Unmarshal(m, b) } func (m *ChangePasswordRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChangePasswordRequest.Marshal(b, m, deterministic) } func (dst *ChangePasswordRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ChangePasswordRequest.Merge(dst, src) } func (m *ChangePasswordRequest) XXX_Size() int { return xxx_messageInfo_ChangePasswordRequest.Size(m) } func (m *ChangePasswordRequest) XXX_DiscardUnknown() { xxx_messageInfo_ChangePasswordRequest.DiscardUnknown(m) } var xxx_messageInfo_ChangePasswordRequest proto.InternalMessageInfo func (m *ChangePasswordRequest) GetCurrentPassword() []byte { if m != nil { return m.CurrentPassword } return nil } func (m *ChangePasswordRequest) GetNewPassword() []byte { if m != nil { return m.NewPassword } return nil } type ChangePasswordResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChangePasswordResponse) Reset() { *m = ChangePasswordResponse{} } func (m *ChangePasswordResponse) String() string { return proto.CompactTextString(m) } func (*ChangePasswordResponse) ProtoMessage() {} func (*ChangePasswordResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{7} } func (m *ChangePasswordResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChangePasswordResponse.Unmarshal(m, b) } func (m *ChangePasswordResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChangePasswordResponse.Marshal(b, m, deterministic) } func (dst *ChangePasswordResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ChangePasswordResponse.Merge(dst, src) } func (m *ChangePasswordResponse) XXX_Size() int { return xxx_messageInfo_ChangePasswordResponse.Size(m) } func (m *ChangePasswordResponse) XXX_DiscardUnknown() { xxx_messageInfo_ChangePasswordResponse.DiscardUnknown(m) } var xxx_messageInfo_ChangePasswordResponse proto.InternalMessageInfo type Utxo struct { // / The type of address Type AddressType `protobuf:"varint,1,opt,name=type,json=address_type,proto3,enum=lnrpc.AddressType" json:"type,omitempty"` // / The address Address string `protobuf:"bytes,2,opt,name=address,proto3" json:"address,omitempty"` // / The value of the unspent coin in satoshis AmountSat int64 `protobuf:"varint,3,opt,name=amount_sat,proto3" json:"amount_sat,omitempty"` // / The pkscript in hex PkScript string `protobuf:"bytes,4,opt,name=pk_script,proto3" json:"pk_script,omitempty"` // / The outpoint in format txid:n Outpoint *OutPoint `protobuf:"bytes,5,opt,name=outpoint,proto3" json:"outpoint,omitempty"` // / The number of confirmations for the Utxo Confirmations int64 `protobuf:"varint,6,opt,name=confirmations,proto3" json:"confirmations,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Utxo) Reset() { *m = Utxo{} } func (m *Utxo) String() string { return proto.CompactTextString(m) } func (*Utxo) ProtoMessage() {} func (*Utxo) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{8} } func (m *Utxo) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Utxo.Unmarshal(m, b) } func (m *Utxo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Utxo.Marshal(b, m, deterministic) } func (dst *Utxo) XXX_Merge(src proto.Message) { xxx_messageInfo_Utxo.Merge(dst, src) } func (m *Utxo) XXX_Size() int { return xxx_messageInfo_Utxo.Size(m) } func (m *Utxo) XXX_DiscardUnknown() { xxx_messageInfo_Utxo.DiscardUnknown(m) } var xxx_messageInfo_Utxo proto.InternalMessageInfo func (m *Utxo) GetType() AddressType { if m != nil { return m.Type } return AddressType_WITNESS_PUBKEY_HASH } func (m *Utxo) GetAddress() string { if m != nil { return m.Address } return "" } func (m *Utxo) GetAmountSat() int64 { if m != nil { return m.AmountSat } return 0 } func (m *Utxo) GetPkScript() string { if m != nil { return m.PkScript } return "" } func (m *Utxo) GetOutpoint() *OutPoint { if m != nil { return m.Outpoint } return nil } func (m *Utxo) GetConfirmations() int64 { if m != nil { return m.Confirmations } return 0 } type Transaction struct { // / The transaction hash TxHash string `protobuf:"bytes,1,opt,name=tx_hash,proto3" json:"tx_hash,omitempty"` // / The transaction amount, denominated in satoshis Amount int64 `protobuf:"varint,2,opt,name=amount,proto3" json:"amount,omitempty"` // / The number of confirmations NumConfirmations int32 `protobuf:"varint,3,opt,name=num_confirmations,proto3" json:"num_confirmations,omitempty"` // / The hash of the block this transaction was included in BlockHash string `protobuf:"bytes,4,opt,name=block_hash,proto3" json:"block_hash,omitempty"` // / The height of the block this transaction was included in BlockHeight int32 `protobuf:"varint,5,opt,name=block_height,proto3" json:"block_height,omitempty"` // / Timestamp of this transaction TimeStamp int64 `protobuf:"varint,6,opt,name=time_stamp,proto3" json:"time_stamp,omitempty"` // / Fees paid for this transaction TotalFees int64 `protobuf:"varint,7,opt,name=total_fees,proto3" json:"total_fees,omitempty"` // / Addresses that received funds for this transaction DestAddresses []string `protobuf:"bytes,8,rep,name=dest_addresses,proto3" json:"dest_addresses,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Transaction) Reset() { *m = Transaction{} } func (m *Transaction) String() string { return proto.CompactTextString(m) } func (*Transaction) ProtoMessage() {} func (*Transaction) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{9} } func (m *Transaction) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Transaction.Unmarshal(m, b) } func (m *Transaction) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Transaction.Marshal(b, m, deterministic) } func (dst *Transaction) XXX_Merge(src proto.Message) { xxx_messageInfo_Transaction.Merge(dst, src) } func (m *Transaction) XXX_Size() int { return xxx_messageInfo_Transaction.Size(m) } func (m *Transaction) XXX_DiscardUnknown() { xxx_messageInfo_Transaction.DiscardUnknown(m) } var xxx_messageInfo_Transaction proto.InternalMessageInfo func (m *Transaction) GetTxHash() string { if m != nil { return m.TxHash } return "" } func (m *Transaction) GetAmount() int64 { if m != nil { return m.Amount } return 0 } func (m *Transaction) GetNumConfirmations() int32 { if m != nil { return m.NumConfirmations } return 0 } func (m *Transaction) GetBlockHash() string { if m != nil { return m.BlockHash } return "" } func (m *Transaction) GetBlockHeight() int32 { if m != nil { return m.BlockHeight } return 0 } func (m *Transaction) GetTimeStamp() int64 { if m != nil { return m.TimeStamp } return 0 } func (m *Transaction) GetTotalFees() int64 { if m != nil { return m.TotalFees } return 0 } func (m *Transaction) GetDestAddresses() []string { if m != nil { return m.DestAddresses } return nil } type GetTransactionsRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *GetTransactionsRequest) Reset() { *m = GetTransactionsRequest{} } func (m *GetTransactionsRequest) String() string { return proto.CompactTextString(m) } func (*GetTransactionsRequest) ProtoMessage() {} func (*GetTransactionsRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{10} } func (m *GetTransactionsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetTransactionsRequest.Unmarshal(m, b) } func (m *GetTransactionsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_GetTransactionsRequest.Marshal(b, m, deterministic) } func (dst *GetTransactionsRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_GetTransactionsRequest.Merge(dst, src) } func (m *GetTransactionsRequest) XXX_Size() int { return xxx_messageInfo_GetTransactionsRequest.Size(m) } func (m *GetTransactionsRequest) XXX_DiscardUnknown() { xxx_messageInfo_GetTransactionsRequest.DiscardUnknown(m) } var xxx_messageInfo_GetTransactionsRequest proto.InternalMessageInfo type TransactionDetails struct { // / The list of transactions relevant to the wallet. Transactions []*Transaction `protobuf:"bytes,1,rep,name=transactions,proto3" json:"transactions,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *TransactionDetails) Reset() { *m = TransactionDetails{} } func (m *TransactionDetails) String() string { return proto.CompactTextString(m) } func (*TransactionDetails) ProtoMessage() {} func (*TransactionDetails) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{11} } func (m *TransactionDetails) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_TransactionDetails.Unmarshal(m, b) } func (m *TransactionDetails) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_TransactionDetails.Marshal(b, m, deterministic) } func (dst *TransactionDetails) XXX_Merge(src proto.Message) { xxx_messageInfo_TransactionDetails.Merge(dst, src) } func (m *TransactionDetails) XXX_Size() int { return xxx_messageInfo_TransactionDetails.Size(m) } func (m *TransactionDetails) XXX_DiscardUnknown() { xxx_messageInfo_TransactionDetails.DiscardUnknown(m) } var xxx_messageInfo_TransactionDetails proto.InternalMessageInfo func (m *TransactionDetails) GetTransactions() []*Transaction { if m != nil { return m.Transactions } return nil } type FeeLimit struct { // Types that are valid to be assigned to Limit: // *FeeLimit_Fixed // *FeeLimit_Percent Limit isFeeLimit_Limit `protobuf_oneof:"limit"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *FeeLimit) Reset() { *m = FeeLimit{} } func (m *FeeLimit) String() string { return proto.CompactTextString(m) } func (*FeeLimit) ProtoMessage() {} func (*FeeLimit) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{12} } func (m *FeeLimit) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_FeeLimit.Unmarshal(m, b) } func (m *FeeLimit) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_FeeLimit.Marshal(b, m, deterministic) } func (dst *FeeLimit) XXX_Merge(src proto.Message) { xxx_messageInfo_FeeLimit.Merge(dst, src) } func (m *FeeLimit) XXX_Size() int { return xxx_messageInfo_FeeLimit.Size(m) } func (m *FeeLimit) XXX_DiscardUnknown() { xxx_messageInfo_FeeLimit.DiscardUnknown(m) } var xxx_messageInfo_FeeLimit proto.InternalMessageInfo type isFeeLimit_Limit interface { isFeeLimit_Limit() } type FeeLimit_Fixed struct { Fixed int64 `protobuf:"varint,1,opt,name=fixed,proto3,oneof"` } type FeeLimit_Percent struct { Percent int64 `protobuf:"varint,2,opt,name=percent,proto3,oneof"` } func (*FeeLimit_Fixed) isFeeLimit_Limit() {} func (*FeeLimit_Percent) isFeeLimit_Limit() {} func (m *FeeLimit) GetLimit() isFeeLimit_Limit { if m != nil { return m.Limit } return nil } func (m *FeeLimit) GetFixed() int64 { if x, ok := m.GetLimit().(*FeeLimit_Fixed); ok { return x.Fixed } return 0 } func (m *FeeLimit) GetPercent() int64 { if x, ok := m.GetLimit().(*FeeLimit_Percent); ok { return x.Percent } return 0 } // XXX_OneofFuncs is for the internal use of the proto package. func (*FeeLimit) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _FeeLimit_OneofMarshaler, _FeeLimit_OneofUnmarshaler, _FeeLimit_OneofSizer, []interface{}{ (*FeeLimit_Fixed)(nil), (*FeeLimit_Percent)(nil), } } func _FeeLimit_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { m := msg.(*FeeLimit) // limit switch x := m.Limit.(type) { case *FeeLimit_Fixed: b.EncodeVarint(1<<3 | proto.WireVarint) b.EncodeVarint(uint64(x.Fixed)) case *FeeLimit_Percent: b.EncodeVarint(2<<3 | proto.WireVarint) b.EncodeVarint(uint64(x.Percent)) case nil: default: return fmt.Errorf("FeeLimit.Limit has unexpected type %T", x) } return nil } func _FeeLimit_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { m := msg.(*FeeLimit) switch tag { case 1: // limit.fixed if wire != proto.WireVarint { return true, proto.ErrInternalBadWireType } x, err := b.DecodeVarint() m.Limit = &FeeLimit_Fixed{int64(x)} return true, err case 2: // limit.percent if wire != proto.WireVarint { return true, proto.ErrInternalBadWireType } x, err := b.DecodeVarint() m.Limit = &FeeLimit_Percent{int64(x)} return true, err default: return false, nil } } func _FeeLimit_OneofSizer(msg proto.Message) (n int) { m := msg.(*FeeLimit) // limit switch x := m.Limit.(type) { case *FeeLimit_Fixed: n += 1 // tag and wire n += proto.SizeVarint(uint64(x.Fixed)) case *FeeLimit_Percent: n += 1 // tag and wire n += proto.SizeVarint(uint64(x.Percent)) case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) } return n } type SendRequest struct { // / The identity pubkey of the payment recipient Dest []byte `protobuf:"bytes,1,opt,name=dest,proto3" json:"dest,omitempty"` // / The hex-encoded identity pubkey of the payment recipient DestString string `protobuf:"bytes,2,opt,name=dest_string,json=destString,proto3" json:"dest_string,omitempty"` // / Number of satoshis to send. Amt int64 `protobuf:"varint,3,opt,name=amt,proto3" json:"amt,omitempty"` // / The hash to use within the payment's HTLC PaymentHash []byte `protobuf:"bytes,4,opt,name=payment_hash,json=paymentHash,proto3" json:"payment_hash,omitempty"` // / The hex-encoded hash to use within the payment's HTLC PaymentHashString string `protobuf:"bytes,5,opt,name=payment_hash_string,json=paymentHashString,proto3" json:"payment_hash_string,omitempty"` // * // A bare-bones invoice for a payment within the Lightning Network. With the // details of the invoice, the sender has all the data necessary to send a // payment to the recipient. PaymentRequest string `protobuf:"bytes,6,opt,name=payment_request,json=paymentRequest,proto3" json:"payment_request,omitempty"` // * // The CLTV delta from the current height that should be used to set the // timelock for the final hop. FinalCltvDelta int32 `protobuf:"varint,7,opt,name=final_cltv_delta,json=finalCltvDelta,proto3" json:"final_cltv_delta,omitempty"` // * // The maximum number of satoshis that will be paid as a fee of the payment. // This value can be represented either as a percentage of the amount being // sent, or as a fixed amount of the maximum fee the user is willing the pay to // send the payment. FeeLimit *FeeLimit `protobuf:"bytes,8,opt,name=fee_limit,json=feeLimit,proto3" json:"fee_limit,omitempty"` // * // The channel id of the channel that must be taken to the first hop. If zero, // any channel may be used. OutgoingChanId uint64 `protobuf:"varint,9,opt,name=outgoing_chan_id,json=outgoingChanId,proto3" json:"outgoing_chan_id,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SendRequest) Reset() { *m = SendRequest{} } func (m *SendRequest) String() string { return proto.CompactTextString(m) } func (*SendRequest) ProtoMessage() {} func (*SendRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{13} } func (m *SendRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SendRequest.Unmarshal(m, b) } func (m *SendRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SendRequest.Marshal(b, m, deterministic) } func (dst *SendRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_SendRequest.Merge(dst, src) } func (m *SendRequest) XXX_Size() int { return xxx_messageInfo_SendRequest.Size(m) } func (m *SendRequest) XXX_DiscardUnknown() { xxx_messageInfo_SendRequest.DiscardUnknown(m) } var xxx_messageInfo_SendRequest proto.InternalMessageInfo func (m *SendRequest) GetDest() []byte { if m != nil { return m.Dest } return nil } func (m *SendRequest) GetDestString() string { if m != nil { return m.DestString } return "" } func (m *SendRequest) GetAmt() int64 { if m != nil { return m.Amt } return 0 } func (m *SendRequest) GetPaymentHash() []byte { if m != nil { return m.PaymentHash } return nil } func (m *SendRequest) GetPaymentHashString() string { if m != nil { return m.PaymentHashString } return "" } func (m *SendRequest) GetPaymentRequest() string { if m != nil { return m.PaymentRequest } return "" } func (m *SendRequest) GetFinalCltvDelta() int32 { if m != nil { return m.FinalCltvDelta } return 0 } func (m *SendRequest) GetFeeLimit() *FeeLimit { if m != nil { return m.FeeLimit } return nil } func (m *SendRequest) GetOutgoingChanId() uint64 { if m != nil { return m.OutgoingChanId } return 0 } type SendResponse struct { PaymentError string `protobuf:"bytes,1,opt,name=payment_error,proto3" json:"payment_error,omitempty"` PaymentPreimage []byte `protobuf:"bytes,2,opt,name=payment_preimage,proto3" json:"payment_preimage,omitempty"` PaymentRoute *Route `protobuf:"bytes,3,opt,name=payment_route,proto3" json:"payment_route,omitempty"` PaymentHash []byte `protobuf:"bytes,4,opt,name=payment_hash,proto3" json:"payment_hash,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SendResponse) Reset() { *m = SendResponse{} } func (m *SendResponse) String() string { return proto.CompactTextString(m) } func (*SendResponse) ProtoMessage() {} func (*SendResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{14} } func (m *SendResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SendResponse.Unmarshal(m, b) } func (m *SendResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SendResponse.Marshal(b, m, deterministic) } func (dst *SendResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_SendResponse.Merge(dst, src) } func (m *SendResponse) XXX_Size() int { return xxx_messageInfo_SendResponse.Size(m) } func (m *SendResponse) XXX_DiscardUnknown() { xxx_messageInfo_SendResponse.DiscardUnknown(m) } var xxx_messageInfo_SendResponse proto.InternalMessageInfo func (m *SendResponse) GetPaymentError() string { if m != nil { return m.PaymentError } return "" } func (m *SendResponse) GetPaymentPreimage() []byte { if m != nil { return m.PaymentPreimage } return nil } func (m *SendResponse) GetPaymentRoute() *Route { if m != nil { return m.PaymentRoute } return nil } func (m *SendResponse) GetPaymentHash() []byte { if m != nil { return m.PaymentHash } return nil } type SendToRouteRequest struct { // / The payment hash to use for the HTLC. PaymentHash []byte `protobuf:"bytes,1,opt,name=payment_hash,json=paymentHash,proto3" json:"payment_hash,omitempty"` // / An optional hex-encoded payment hash to be used for the HTLC. PaymentHashString string `protobuf:"bytes,2,opt,name=payment_hash_string,json=paymentHashString,proto3" json:"payment_hash_string,omitempty"` // * // Deprecated. The set of routes that should be used to attempt to complete the // payment. The possibility to pass in multiple routes is deprecated and // instead the single route field below should be used in combination with the // streaming variant of SendToRoute. Routes []*Route `protobuf:"bytes,3,rep,name=routes,proto3" json:"routes,omitempty"` // Deprecated: Do not use. // / Route that should be used to attempt to complete the payment. Route *Route `protobuf:"bytes,4,opt,name=route,proto3" json:"route,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SendToRouteRequest) Reset() { *m = SendToRouteRequest{} } func (m *SendToRouteRequest) String() string { return proto.CompactTextString(m) } func (*SendToRouteRequest) ProtoMessage() {} func (*SendToRouteRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{15} } func (m *SendToRouteRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SendToRouteRequest.Unmarshal(m, b) } func (m *SendToRouteRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SendToRouteRequest.Marshal(b, m, deterministic) } func (dst *SendToRouteRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_SendToRouteRequest.Merge(dst, src) } func (m *SendToRouteRequest) XXX_Size() int { return xxx_messageInfo_SendToRouteRequest.Size(m) } func (m *SendToRouteRequest) XXX_DiscardUnknown() { xxx_messageInfo_SendToRouteRequest.DiscardUnknown(m) } var xxx_messageInfo_SendToRouteRequest proto.InternalMessageInfo func (m *SendToRouteRequest) GetPaymentHash() []byte { if m != nil { return m.PaymentHash } return nil } func (m *SendToRouteRequest) GetPaymentHashString() string { if m != nil { return m.PaymentHashString } return "" } // Deprecated: Do not use. func (m *SendToRouteRequest) GetRoutes() []*Route { if m != nil { return m.Routes } return nil } func (m *SendToRouteRequest) GetRoute() *Route { if m != nil { return m.Route } return nil } type ChannelPoint struct { // Types that are valid to be assigned to FundingTxid: // *ChannelPoint_FundingTxidBytes // *ChannelPoint_FundingTxidStr FundingTxid isChannelPoint_FundingTxid `protobuf_oneof:"funding_txid"` // / The index of the output of the funding transaction OutputIndex uint32 `protobuf:"varint,3,opt,name=output_index,proto3" json:"output_index,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelPoint) Reset() { *m = ChannelPoint{} } func (m *ChannelPoint) String() string { return proto.CompactTextString(m) } func (*ChannelPoint) ProtoMessage() {} func (*ChannelPoint) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{16} } func (m *ChannelPoint) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelPoint.Unmarshal(m, b) } func (m *ChannelPoint) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelPoint.Marshal(b, m, deterministic) } func (dst *ChannelPoint) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelPoint.Merge(dst, src) } func (m *ChannelPoint) XXX_Size() int { return xxx_messageInfo_ChannelPoint.Size(m) } func (m *ChannelPoint) XXX_DiscardUnknown() { xxx_messageInfo_ChannelPoint.DiscardUnknown(m) } var xxx_messageInfo_ChannelPoint proto.InternalMessageInfo type isChannelPoint_FundingTxid interface { isChannelPoint_FundingTxid() } type ChannelPoint_FundingTxidBytes struct { FundingTxidBytes []byte `protobuf:"bytes,1,opt,name=funding_txid_bytes,proto3,oneof"` } type ChannelPoint_FundingTxidStr struct { FundingTxidStr string `protobuf:"bytes,2,opt,name=funding_txid_str,proto3,oneof"` } func (*ChannelPoint_FundingTxidBytes) isChannelPoint_FundingTxid() {} func (*ChannelPoint_FundingTxidStr) isChannelPoint_FundingTxid() {} func (m *ChannelPoint) GetFundingTxid() isChannelPoint_FundingTxid { if m != nil { return m.FundingTxid } return nil } func (m *ChannelPoint) GetFundingTxidBytes() []byte { if x, ok := m.GetFundingTxid().(*ChannelPoint_FundingTxidBytes); ok { return x.FundingTxidBytes } return nil } func (m *ChannelPoint) GetFundingTxidStr() string { if x, ok := m.GetFundingTxid().(*ChannelPoint_FundingTxidStr); ok { return x.FundingTxidStr } return "" } func (m *ChannelPoint) GetOutputIndex() uint32 { if m != nil { return m.OutputIndex } return 0 } // XXX_OneofFuncs is for the internal use of the proto package. func (*ChannelPoint) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _ChannelPoint_OneofMarshaler, _ChannelPoint_OneofUnmarshaler, _ChannelPoint_OneofSizer, []interface{}{ (*ChannelPoint_FundingTxidBytes)(nil), (*ChannelPoint_FundingTxidStr)(nil), } } func _ChannelPoint_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { m := msg.(*ChannelPoint) // funding_txid switch x := m.FundingTxid.(type) { case *ChannelPoint_FundingTxidBytes: b.EncodeVarint(1<<3 | proto.WireBytes) b.EncodeRawBytes(x.FundingTxidBytes) case *ChannelPoint_FundingTxidStr: b.EncodeVarint(2<<3 | proto.WireBytes) b.EncodeStringBytes(x.FundingTxidStr) case nil: default: return fmt.Errorf("ChannelPoint.FundingTxid has unexpected type %T", x) } return nil } func _ChannelPoint_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { m := msg.(*ChannelPoint) switch tag { case 1: // funding_txid.funding_txid_bytes if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } x, err := b.DecodeRawBytes(true) m.FundingTxid = &ChannelPoint_FundingTxidBytes{x} return true, err case 2: // funding_txid.funding_txid_str if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } x, err := b.DecodeStringBytes() m.FundingTxid = &ChannelPoint_FundingTxidStr{x} return true, err default: return false, nil } } func _ChannelPoint_OneofSizer(msg proto.Message) (n int) { m := msg.(*ChannelPoint) // funding_txid switch x := m.FundingTxid.(type) { case *ChannelPoint_FundingTxidBytes: n += 1 // tag and wire n += proto.SizeVarint(uint64(len(x.FundingTxidBytes))) n += len(x.FundingTxidBytes) case *ChannelPoint_FundingTxidStr: n += 1 // tag and wire n += proto.SizeVarint(uint64(len(x.FundingTxidStr))) n += len(x.FundingTxidStr) case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) } return n } type OutPoint struct { // / Raw bytes representing the transaction id. TxidBytes []byte `protobuf:"bytes,1,opt,name=txid_bytes,proto3" json:"txid_bytes,omitempty"` // / Reversed, hex-encoded string representing the transaction id. TxidStr string `protobuf:"bytes,2,opt,name=txid_str,proto3" json:"txid_str,omitempty"` // / The index of the output on the transaction. OutputIndex uint32 `protobuf:"varint,3,opt,name=output_index,proto3" json:"output_index,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *OutPoint) Reset() { *m = OutPoint{} } func (m *OutPoint) String() string { return proto.CompactTextString(m) } func (*OutPoint) ProtoMessage() {} func (*OutPoint) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{17} } func (m *OutPoint) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_OutPoint.Unmarshal(m, b) } func (m *OutPoint) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_OutPoint.Marshal(b, m, deterministic) } func (dst *OutPoint) XXX_Merge(src proto.Message) { xxx_messageInfo_OutPoint.Merge(dst, src) } func (m *OutPoint) XXX_Size() int { return xxx_messageInfo_OutPoint.Size(m) } func (m *OutPoint) XXX_DiscardUnknown() { xxx_messageInfo_OutPoint.DiscardUnknown(m) } var xxx_messageInfo_OutPoint proto.InternalMessageInfo func (m *OutPoint) GetTxidBytes() []byte { if m != nil { return m.TxidBytes } return nil } func (m *OutPoint) GetTxidStr() string { if m != nil { return m.TxidStr } return "" } func (m *OutPoint) GetOutputIndex() uint32 { if m != nil { return m.OutputIndex } return 0 } type LightningAddress struct { // / The identity pubkey of the Lightning node Pubkey string `protobuf:"bytes,1,opt,name=pubkey,proto3" json:"pubkey,omitempty"` // / The network location of the lightning node, e.g. `69.69.69.69:1337` or `localhost:10011` Host string `protobuf:"bytes,2,opt,name=host,proto3" json:"host,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *LightningAddress) Reset() { *m = LightningAddress{} } func (m *LightningAddress) String() string { return proto.CompactTextString(m) } func (*LightningAddress) ProtoMessage() {} func (*LightningAddress) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{18} } func (m *LightningAddress) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_LightningAddress.Unmarshal(m, b) } func (m *LightningAddress) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_LightningAddress.Marshal(b, m, deterministic) } func (dst *LightningAddress) XXX_Merge(src proto.Message) { xxx_messageInfo_LightningAddress.Merge(dst, src) } func (m *LightningAddress) XXX_Size() int { return xxx_messageInfo_LightningAddress.Size(m) } func (m *LightningAddress) XXX_DiscardUnknown() { xxx_messageInfo_LightningAddress.DiscardUnknown(m) } var xxx_messageInfo_LightningAddress proto.InternalMessageInfo func (m *LightningAddress) GetPubkey() string { if m != nil { return m.Pubkey } return "" } func (m *LightningAddress) GetHost() string { if m != nil { return m.Host } return "" } type SendManyRequest struct { // / The map from addresses to amounts AddrToAmount map[string]int64 `protobuf:"bytes,1,rep,name=AddrToAmount,proto3" json:"AddrToAmount,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"varint,2,opt,name=value,proto3"` // / The target number of blocks that this transaction should be confirmed by. TargetConf int32 `protobuf:"varint,3,opt,name=target_conf,json=targetConf,proto3" json:"target_conf,omitempty"` // / A manual fee rate set in sat/byte that should be used when crafting the transaction. SatPerByte int64 `protobuf:"varint,5,opt,name=sat_per_byte,json=satPerByte,proto3" json:"sat_per_byte,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SendManyRequest) Reset() { *m = SendManyRequest{} } func (m *SendManyRequest) String() string { return proto.CompactTextString(m) } func (*SendManyRequest) ProtoMessage() {} func (*SendManyRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{19} } func (m *SendManyRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SendManyRequest.Unmarshal(m, b) } func (m *SendManyRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SendManyRequest.Marshal(b, m, deterministic) } func (dst *SendManyRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_SendManyRequest.Merge(dst, src) } func (m *SendManyRequest) XXX_Size() int { return xxx_messageInfo_SendManyRequest.Size(m) } func (m *SendManyRequest) XXX_DiscardUnknown() { xxx_messageInfo_SendManyRequest.DiscardUnknown(m) } var xxx_messageInfo_SendManyRequest proto.InternalMessageInfo func (m *SendManyRequest) GetAddrToAmount() map[string]int64 { if m != nil { return m.AddrToAmount } return nil } func (m *SendManyRequest) GetTargetConf() int32 { if m != nil { return m.TargetConf } return 0 } func (m *SendManyRequest) GetSatPerByte() int64 { if m != nil { return m.SatPerByte } return 0 } type SendManyResponse struct { // / The id of the transaction Txid string `protobuf:"bytes,1,opt,name=txid,proto3" json:"txid,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SendManyResponse) Reset() { *m = SendManyResponse{} } func (m *SendManyResponse) String() string { return proto.CompactTextString(m) } func (*SendManyResponse) ProtoMessage() {} func (*SendManyResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{20} } func (m *SendManyResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SendManyResponse.Unmarshal(m, b) } func (m *SendManyResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SendManyResponse.Marshal(b, m, deterministic) } func (dst *SendManyResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_SendManyResponse.Merge(dst, src) } func (m *SendManyResponse) XXX_Size() int { return xxx_messageInfo_SendManyResponse.Size(m) } func (m *SendManyResponse) XXX_DiscardUnknown() { xxx_messageInfo_SendManyResponse.DiscardUnknown(m) } var xxx_messageInfo_SendManyResponse proto.InternalMessageInfo func (m *SendManyResponse) GetTxid() string { if m != nil { return m.Txid } return "" } type SendCoinsRequest struct { // / The address to send coins to Addr string `protobuf:"bytes,1,opt,name=addr,proto3" json:"addr,omitempty"` // / The amount in satoshis to send Amount int64 `protobuf:"varint,2,opt,name=amount,proto3" json:"amount,omitempty"` // / The target number of blocks that this transaction should be confirmed by. TargetConf int32 `protobuf:"varint,3,opt,name=target_conf,json=targetConf,proto3" json:"target_conf,omitempty"` // / A manual fee rate set in sat/byte that should be used when crafting the transaction. SatPerByte int64 `protobuf:"varint,5,opt,name=sat_per_byte,json=satPerByte,proto3" json:"sat_per_byte,omitempty"` // * // If set, then the amount field will be ignored, and lnd will attempt to // send all the coins under control of the internal wallet to the specified // address. SendAll bool `protobuf:"varint,6,opt,name=send_all,json=sendAll,proto3" json:"send_all,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SendCoinsRequest) Reset() { *m = SendCoinsRequest{} } func (m *SendCoinsRequest) String() string { return proto.CompactTextString(m) } func (*SendCoinsRequest) ProtoMessage() {} func (*SendCoinsRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{21} } func (m *SendCoinsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SendCoinsRequest.Unmarshal(m, b) } func (m *SendCoinsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SendCoinsRequest.Marshal(b, m, deterministic) } func (dst *SendCoinsRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_SendCoinsRequest.Merge(dst, src) } func (m *SendCoinsRequest) XXX_Size() int { return xxx_messageInfo_SendCoinsRequest.Size(m) } func (m *SendCoinsRequest) XXX_DiscardUnknown() { xxx_messageInfo_SendCoinsRequest.DiscardUnknown(m) } var xxx_messageInfo_SendCoinsRequest proto.InternalMessageInfo func (m *SendCoinsRequest) GetAddr() string { if m != nil { return m.Addr } return "" } func (m *SendCoinsRequest) GetAmount() int64 { if m != nil { return m.Amount } return 0 } func (m *SendCoinsRequest) GetTargetConf() int32 { if m != nil { return m.TargetConf } return 0 } func (m *SendCoinsRequest) GetSatPerByte() int64 { if m != nil { return m.SatPerByte } return 0 } func (m *SendCoinsRequest) GetSendAll() bool { if m != nil { return m.SendAll } return false } type SendCoinsResponse struct { // / The transaction ID of the transaction Txid string `protobuf:"bytes,1,opt,name=txid,proto3" json:"txid,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SendCoinsResponse) Reset() { *m = SendCoinsResponse{} } func (m *SendCoinsResponse) String() string { return proto.CompactTextString(m) } func (*SendCoinsResponse) ProtoMessage() {} func (*SendCoinsResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{22} } func (m *SendCoinsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SendCoinsResponse.Unmarshal(m, b) } func (m *SendCoinsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SendCoinsResponse.Marshal(b, m, deterministic) } func (dst *SendCoinsResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_SendCoinsResponse.Merge(dst, src) } func (m *SendCoinsResponse) XXX_Size() int { return xxx_messageInfo_SendCoinsResponse.Size(m) } func (m *SendCoinsResponse) XXX_DiscardUnknown() { xxx_messageInfo_SendCoinsResponse.DiscardUnknown(m) } var xxx_messageInfo_SendCoinsResponse proto.InternalMessageInfo func (m *SendCoinsResponse) GetTxid() string { if m != nil { return m.Txid } return "" } type ListUnspentRequest struct { // / The minimum number of confirmations to be included. MinConfs int32 `protobuf:"varint,1,opt,name=min_confs,json=minConfs,proto3" json:"min_confs,omitempty"` // / The maximum number of confirmations to be included. MaxConfs int32 `protobuf:"varint,2,opt,name=max_confs,json=maxConfs,proto3" json:"max_confs,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListUnspentRequest) Reset() { *m = ListUnspentRequest{} } func (m *ListUnspentRequest) String() string { return proto.CompactTextString(m) } func (*ListUnspentRequest) ProtoMessage() {} func (*ListUnspentRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{23} } func (m *ListUnspentRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListUnspentRequest.Unmarshal(m, b) } func (m *ListUnspentRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListUnspentRequest.Marshal(b, m, deterministic) } func (dst *ListUnspentRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ListUnspentRequest.Merge(dst, src) } func (m *ListUnspentRequest) XXX_Size() int { return xxx_messageInfo_ListUnspentRequest.Size(m) } func (m *ListUnspentRequest) XXX_DiscardUnknown() { xxx_messageInfo_ListUnspentRequest.DiscardUnknown(m) } var xxx_messageInfo_ListUnspentRequest proto.InternalMessageInfo func (m *ListUnspentRequest) GetMinConfs() int32 { if m != nil { return m.MinConfs } return 0 } func (m *ListUnspentRequest) GetMaxConfs() int32 { if m != nil { return m.MaxConfs } return 0 } type ListUnspentResponse struct { // / A list of utxos Utxos []*Utxo `protobuf:"bytes,1,rep,name=utxos,proto3" json:"utxos,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListUnspentResponse) Reset() { *m = ListUnspentResponse{} } func (m *ListUnspentResponse) String() string { return proto.CompactTextString(m) } func (*ListUnspentResponse) ProtoMessage() {} func (*ListUnspentResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{24} } func (m *ListUnspentResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListUnspentResponse.Unmarshal(m, b) } func (m *ListUnspentResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListUnspentResponse.Marshal(b, m, deterministic) } func (dst *ListUnspentResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ListUnspentResponse.Merge(dst, src) } func (m *ListUnspentResponse) XXX_Size() int { return xxx_messageInfo_ListUnspentResponse.Size(m) } func (m *ListUnspentResponse) XXX_DiscardUnknown() { xxx_messageInfo_ListUnspentResponse.DiscardUnknown(m) } var xxx_messageInfo_ListUnspentResponse proto.InternalMessageInfo func (m *ListUnspentResponse) GetUtxos() []*Utxo { if m != nil { return m.Utxos } return nil } type NewAddressRequest struct { // / The address type Type AddressType `protobuf:"varint,1,opt,name=type,proto3,enum=lnrpc.AddressType" json:"type,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NewAddressRequest) Reset() { *m = NewAddressRequest{} } func (m *NewAddressRequest) String() string { return proto.CompactTextString(m) } func (*NewAddressRequest) ProtoMessage() {} func (*NewAddressRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{25} } func (m *NewAddressRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NewAddressRequest.Unmarshal(m, b) } func (m *NewAddressRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NewAddressRequest.Marshal(b, m, deterministic) } func (dst *NewAddressRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_NewAddressRequest.Merge(dst, src) } func (m *NewAddressRequest) XXX_Size() int { return xxx_messageInfo_NewAddressRequest.Size(m) } func (m *NewAddressRequest) XXX_DiscardUnknown() { xxx_messageInfo_NewAddressRequest.DiscardUnknown(m) } var xxx_messageInfo_NewAddressRequest proto.InternalMessageInfo func (m *NewAddressRequest) GetType() AddressType { if m != nil { return m.Type } return AddressType_WITNESS_PUBKEY_HASH } type NewAddressResponse struct { // / The newly generated wallet address Address string `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NewAddressResponse) Reset() { *m = NewAddressResponse{} } func (m *NewAddressResponse) String() string { return proto.CompactTextString(m) } func (*NewAddressResponse) ProtoMessage() {} func (*NewAddressResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{26} } func (m *NewAddressResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NewAddressResponse.Unmarshal(m, b) } func (m *NewAddressResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NewAddressResponse.Marshal(b, m, deterministic) } func (dst *NewAddressResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_NewAddressResponse.Merge(dst, src) } func (m *NewAddressResponse) XXX_Size() int { return xxx_messageInfo_NewAddressResponse.Size(m) } func (m *NewAddressResponse) XXX_DiscardUnknown() { xxx_messageInfo_NewAddressResponse.DiscardUnknown(m) } var xxx_messageInfo_NewAddressResponse proto.InternalMessageInfo func (m *NewAddressResponse) GetAddress() string { if m != nil { return m.Address } return "" } type SignMessageRequest struct { // / The message to be signed Msg []byte `protobuf:"bytes,1,opt,name=msg,proto3" json:"msg,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SignMessageRequest) Reset() { *m = SignMessageRequest{} } func (m *SignMessageRequest) String() string { return proto.CompactTextString(m) } func (*SignMessageRequest) ProtoMessage() {} func (*SignMessageRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{27} } func (m *SignMessageRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SignMessageRequest.Unmarshal(m, b) } func (m *SignMessageRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SignMessageRequest.Marshal(b, m, deterministic) } func (dst *SignMessageRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_SignMessageRequest.Merge(dst, src) } func (m *SignMessageRequest) XXX_Size() int { return xxx_messageInfo_SignMessageRequest.Size(m) } func (m *SignMessageRequest) XXX_DiscardUnknown() { xxx_messageInfo_SignMessageRequest.DiscardUnknown(m) } var xxx_messageInfo_SignMessageRequest proto.InternalMessageInfo func (m *SignMessageRequest) GetMsg() []byte { if m != nil { return m.Msg } return nil } type SignMessageResponse struct { // / The signature for the given message Signature string `protobuf:"bytes,1,opt,name=signature,proto3" json:"signature,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *SignMessageResponse) Reset() { *m = SignMessageResponse{} } func (m *SignMessageResponse) String() string { return proto.CompactTextString(m) } func (*SignMessageResponse) ProtoMessage() {} func (*SignMessageResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{28} } func (m *SignMessageResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SignMessageResponse.Unmarshal(m, b) } func (m *SignMessageResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_SignMessageResponse.Marshal(b, m, deterministic) } func (dst *SignMessageResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_SignMessageResponse.Merge(dst, src) } func (m *SignMessageResponse) XXX_Size() int { return xxx_messageInfo_SignMessageResponse.Size(m) } func (m *SignMessageResponse) XXX_DiscardUnknown() { xxx_messageInfo_SignMessageResponse.DiscardUnknown(m) } var xxx_messageInfo_SignMessageResponse proto.InternalMessageInfo func (m *SignMessageResponse) GetSignature() string { if m != nil { return m.Signature } return "" } type VerifyMessageRequest struct { // / The message over which the signature is to be verified Msg []byte `protobuf:"bytes,1,opt,name=msg,proto3" json:"msg,omitempty"` // / The signature to be verified over the given message Signature string `protobuf:"bytes,2,opt,name=signature,proto3" json:"signature,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *VerifyMessageRequest) Reset() { *m = VerifyMessageRequest{} } func (m *VerifyMessageRequest) String() string { return proto.CompactTextString(m) } func (*VerifyMessageRequest) ProtoMessage() {} func (*VerifyMessageRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{29} } func (m *VerifyMessageRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VerifyMessageRequest.Unmarshal(m, b) } func (m *VerifyMessageRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_VerifyMessageRequest.Marshal(b, m, deterministic) } func (dst *VerifyMessageRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_VerifyMessageRequest.Merge(dst, src) } func (m *VerifyMessageRequest) XXX_Size() int { return xxx_messageInfo_VerifyMessageRequest.Size(m) } func (m *VerifyMessageRequest) XXX_DiscardUnknown() { xxx_messageInfo_VerifyMessageRequest.DiscardUnknown(m) } var xxx_messageInfo_VerifyMessageRequest proto.InternalMessageInfo func (m *VerifyMessageRequest) GetMsg() []byte { if m != nil { return m.Msg } return nil } func (m *VerifyMessageRequest) GetSignature() string { if m != nil { return m.Signature } return "" } type VerifyMessageResponse struct { // / Whether the signature was valid over the given message Valid bool `protobuf:"varint,1,opt,name=valid,proto3" json:"valid,omitempty"` // / The pubkey recovered from the signature Pubkey string `protobuf:"bytes,2,opt,name=pubkey,proto3" json:"pubkey,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *VerifyMessageResponse) Reset() { *m = VerifyMessageResponse{} } func (m *VerifyMessageResponse) String() string { return proto.CompactTextString(m) } func (*VerifyMessageResponse) ProtoMessage() {} func (*VerifyMessageResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{30} } func (m *VerifyMessageResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VerifyMessageResponse.Unmarshal(m, b) } func (m *VerifyMessageResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_VerifyMessageResponse.Marshal(b, m, deterministic) } func (dst *VerifyMessageResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_VerifyMessageResponse.Merge(dst, src) } func (m *VerifyMessageResponse) XXX_Size() int { return xxx_messageInfo_VerifyMessageResponse.Size(m) } func (m *VerifyMessageResponse) XXX_DiscardUnknown() { xxx_messageInfo_VerifyMessageResponse.DiscardUnknown(m) } var xxx_messageInfo_VerifyMessageResponse proto.InternalMessageInfo func (m *VerifyMessageResponse) GetValid() bool { if m != nil { return m.Valid } return false } func (m *VerifyMessageResponse) GetPubkey() string { if m != nil { return m.Pubkey } return "" } type ConnectPeerRequest struct { // / Lightning address of the peer, in the format `@host` Addr *LightningAddress `protobuf:"bytes,1,opt,name=addr,proto3" json:"addr,omitempty"` // * If set, the daemon will attempt to persistently connect to the target // peer. Otherwise, the call will be synchronous. Perm bool `protobuf:"varint,2,opt,name=perm,proto3" json:"perm,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ConnectPeerRequest) Reset() { *m = ConnectPeerRequest{} } func (m *ConnectPeerRequest) String() string { return proto.CompactTextString(m) } func (*ConnectPeerRequest) ProtoMessage() {} func (*ConnectPeerRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{31} } func (m *ConnectPeerRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ConnectPeerRequest.Unmarshal(m, b) } func (m *ConnectPeerRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ConnectPeerRequest.Marshal(b, m, deterministic) } func (dst *ConnectPeerRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ConnectPeerRequest.Merge(dst, src) } func (m *ConnectPeerRequest) XXX_Size() int { return xxx_messageInfo_ConnectPeerRequest.Size(m) } func (m *ConnectPeerRequest) XXX_DiscardUnknown() { xxx_messageInfo_ConnectPeerRequest.DiscardUnknown(m) } var xxx_messageInfo_ConnectPeerRequest proto.InternalMessageInfo func (m *ConnectPeerRequest) GetAddr() *LightningAddress { if m != nil { return m.Addr } return nil } func (m *ConnectPeerRequest) GetPerm() bool { if m != nil { return m.Perm } return false } type ConnectPeerResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ConnectPeerResponse) Reset() { *m = ConnectPeerResponse{} } func (m *ConnectPeerResponse) String() string { return proto.CompactTextString(m) } func (*ConnectPeerResponse) ProtoMessage() {} func (*ConnectPeerResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{32} } func (m *ConnectPeerResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ConnectPeerResponse.Unmarshal(m, b) } func (m *ConnectPeerResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ConnectPeerResponse.Marshal(b, m, deterministic) } func (dst *ConnectPeerResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ConnectPeerResponse.Merge(dst, src) } func (m *ConnectPeerResponse) XXX_Size() int { return xxx_messageInfo_ConnectPeerResponse.Size(m) } func (m *ConnectPeerResponse) XXX_DiscardUnknown() { xxx_messageInfo_ConnectPeerResponse.DiscardUnknown(m) } var xxx_messageInfo_ConnectPeerResponse proto.InternalMessageInfo type DisconnectPeerRequest struct { // / The pubkey of the node to disconnect from PubKey string `protobuf:"bytes,1,opt,name=pub_key,proto3" json:"pub_key,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *DisconnectPeerRequest) Reset() { *m = DisconnectPeerRequest{} } func (m *DisconnectPeerRequest) String() string { return proto.CompactTextString(m) } func (*DisconnectPeerRequest) ProtoMessage() {} func (*DisconnectPeerRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{33} } func (m *DisconnectPeerRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DisconnectPeerRequest.Unmarshal(m, b) } func (m *DisconnectPeerRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_DisconnectPeerRequest.Marshal(b, m, deterministic) } func (dst *DisconnectPeerRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_DisconnectPeerRequest.Merge(dst, src) } func (m *DisconnectPeerRequest) XXX_Size() int { return xxx_messageInfo_DisconnectPeerRequest.Size(m) } func (m *DisconnectPeerRequest) XXX_DiscardUnknown() { xxx_messageInfo_DisconnectPeerRequest.DiscardUnknown(m) } var xxx_messageInfo_DisconnectPeerRequest proto.InternalMessageInfo func (m *DisconnectPeerRequest) GetPubKey() string { if m != nil { return m.PubKey } return "" } type DisconnectPeerResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *DisconnectPeerResponse) Reset() { *m = DisconnectPeerResponse{} } func (m *DisconnectPeerResponse) String() string { return proto.CompactTextString(m) } func (*DisconnectPeerResponse) ProtoMessage() {} func (*DisconnectPeerResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{34} } func (m *DisconnectPeerResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DisconnectPeerResponse.Unmarshal(m, b) } func (m *DisconnectPeerResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_DisconnectPeerResponse.Marshal(b, m, deterministic) } func (dst *DisconnectPeerResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_DisconnectPeerResponse.Merge(dst, src) } func (m *DisconnectPeerResponse) XXX_Size() int { return xxx_messageInfo_DisconnectPeerResponse.Size(m) } func (m *DisconnectPeerResponse) XXX_DiscardUnknown() { xxx_messageInfo_DisconnectPeerResponse.DiscardUnknown(m) } var xxx_messageInfo_DisconnectPeerResponse proto.InternalMessageInfo type HTLC struct { Incoming bool `protobuf:"varint,1,opt,name=incoming,proto3" json:"incoming,omitempty"` Amount int64 `protobuf:"varint,2,opt,name=amount,proto3" json:"amount,omitempty"` HashLock []byte `protobuf:"bytes,3,opt,name=hash_lock,proto3" json:"hash_lock,omitempty"` ExpirationHeight uint32 `protobuf:"varint,4,opt,name=expiration_height,proto3" json:"expiration_height,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *HTLC) Reset() { *m = HTLC{} } func (m *HTLC) String() string { return proto.CompactTextString(m) } func (*HTLC) ProtoMessage() {} func (*HTLC) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{35} } func (m *HTLC) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_HTLC.Unmarshal(m, b) } func (m *HTLC) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_HTLC.Marshal(b, m, deterministic) } func (dst *HTLC) XXX_Merge(src proto.Message) { xxx_messageInfo_HTLC.Merge(dst, src) } func (m *HTLC) XXX_Size() int { return xxx_messageInfo_HTLC.Size(m) } func (m *HTLC) XXX_DiscardUnknown() { xxx_messageInfo_HTLC.DiscardUnknown(m) } var xxx_messageInfo_HTLC proto.InternalMessageInfo func (m *HTLC) GetIncoming() bool { if m != nil { return m.Incoming } return false } func (m *HTLC) GetAmount() int64 { if m != nil { return m.Amount } return 0 } func (m *HTLC) GetHashLock() []byte { if m != nil { return m.HashLock } return nil } func (m *HTLC) GetExpirationHeight() uint32 { if m != nil { return m.ExpirationHeight } return 0 } type Channel struct { // / Whether this channel is active or not Active bool `protobuf:"varint,1,opt,name=active,proto3" json:"active,omitempty"` // / The identity pubkey of the remote node RemotePubkey string `protobuf:"bytes,2,opt,name=remote_pubkey,proto3" json:"remote_pubkey,omitempty"` // * // The outpoint (txid:index) of the funding transaction. With this value, Bob // will be able to generate a signature for Alice's version of the commitment // transaction. ChannelPoint string `protobuf:"bytes,3,opt,name=channel_point,proto3" json:"channel_point,omitempty"` // * // The unique channel ID for the channel. The first 3 bytes are the block // height, the next 3 the index within the block, and the last 2 bytes are the // output index for the channel. ChanId uint64 `protobuf:"varint,4,opt,name=chan_id,proto3" json:"chan_id,omitempty"` // / The total amount of funds held in this channel Capacity int64 `protobuf:"varint,5,opt,name=capacity,proto3" json:"capacity,omitempty"` // / This node's current balance in this channel LocalBalance int64 `protobuf:"varint,6,opt,name=local_balance,proto3" json:"local_balance,omitempty"` // / The counterparty's current balance in this channel RemoteBalance int64 `protobuf:"varint,7,opt,name=remote_balance,proto3" json:"remote_balance,omitempty"` // * // The amount calculated to be paid in fees for the current set of commitment // transactions. The fee amount is persisted with the channel in order to // allow the fee amount to be removed and recalculated with each channel state // update, including updates that happen after a system restart. CommitFee int64 `protobuf:"varint,8,opt,name=commit_fee,proto3" json:"commit_fee,omitempty"` // / The weight of the commitment transaction CommitWeight int64 `protobuf:"varint,9,opt,name=commit_weight,proto3" json:"commit_weight,omitempty"` // * // The required number of satoshis per kilo-weight that the requester will pay // at all times, for both the funding transaction and commitment transaction. // This value can later be updated once the channel is open. FeePerKw int64 `protobuf:"varint,10,opt,name=fee_per_kw,proto3" json:"fee_per_kw,omitempty"` // / The unsettled balance in this channel UnsettledBalance int64 `protobuf:"varint,11,opt,name=unsettled_balance,proto3" json:"unsettled_balance,omitempty"` // * // The total number of satoshis we've sent within this channel. TotalSatoshisSent int64 `protobuf:"varint,12,opt,name=total_satoshis_sent,proto3" json:"total_satoshis_sent,omitempty"` // * // The total number of satoshis we've received within this channel. TotalSatoshisReceived int64 `protobuf:"varint,13,opt,name=total_satoshis_received,proto3" json:"total_satoshis_received,omitempty"` // * // The total number of updates conducted within this channel. NumUpdates uint64 `protobuf:"varint,14,opt,name=num_updates,proto3" json:"num_updates,omitempty"` // * // The list of active, uncleared HTLCs currently pending within the channel. PendingHtlcs []*HTLC `protobuf:"bytes,15,rep,name=pending_htlcs,proto3" json:"pending_htlcs,omitempty"` // * // The CSV delay expressed in relative blocks. If the channel is force // closed, we'll need to wait for this many blocks before we can regain our // funds. CsvDelay uint32 `protobuf:"varint,16,opt,name=csv_delay,proto3" json:"csv_delay,omitempty"` // / Whether this channel is advertised to the network or not. Private bool `protobuf:"varint,17,opt,name=private,proto3" json:"private,omitempty"` // / True if we were the ones that creted the channel. Initiator bool `protobuf:"varint,18,opt,name=initiator,proto3" json:"initiator,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Channel) Reset() { *m = Channel{} } func (m *Channel) String() string { return proto.CompactTextString(m) } func (*Channel) ProtoMessage() {} func (*Channel) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{36} } func (m *Channel) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Channel.Unmarshal(m, b) } func (m *Channel) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Channel.Marshal(b, m, deterministic) } func (dst *Channel) XXX_Merge(src proto.Message) { xxx_messageInfo_Channel.Merge(dst, src) } func (m *Channel) XXX_Size() int { return xxx_messageInfo_Channel.Size(m) } func (m *Channel) XXX_DiscardUnknown() { xxx_messageInfo_Channel.DiscardUnknown(m) } var xxx_messageInfo_Channel proto.InternalMessageInfo func (m *Channel) GetActive() bool { if m != nil { return m.Active } return false } func (m *Channel) GetRemotePubkey() string { if m != nil { return m.RemotePubkey } return "" } func (m *Channel) GetChannelPoint() string { if m != nil { return m.ChannelPoint } return "" } func (m *Channel) GetChanId() uint64 { if m != nil { return m.ChanId } return 0 } func (m *Channel) GetCapacity() int64 { if m != nil { return m.Capacity } return 0 } func (m *Channel) GetLocalBalance() int64 { if m != nil { return m.LocalBalance } return 0 } func (m *Channel) GetRemoteBalance() int64 { if m != nil { return m.RemoteBalance } return 0 } func (m *Channel) GetCommitFee() int64 { if m != nil { return m.CommitFee } return 0 } func (m *Channel) GetCommitWeight() int64 { if m != nil { return m.CommitWeight } return 0 } func (m *Channel) GetFeePerKw() int64 { if m != nil { return m.FeePerKw } return 0 } func (m *Channel) GetUnsettledBalance() int64 { if m != nil { return m.UnsettledBalance } return 0 } func (m *Channel) GetTotalSatoshisSent() int64 { if m != nil { return m.TotalSatoshisSent } return 0 } func (m *Channel) GetTotalSatoshisReceived() int64 { if m != nil { return m.TotalSatoshisReceived } return 0 } func (m *Channel) GetNumUpdates() uint64 { if m != nil { return m.NumUpdates } return 0 } func (m *Channel) GetPendingHtlcs() []*HTLC { if m != nil { return m.PendingHtlcs } return nil } func (m *Channel) GetCsvDelay() uint32 { if m != nil { return m.CsvDelay } return 0 } func (m *Channel) GetPrivate() bool { if m != nil { return m.Private } return false } func (m *Channel) GetInitiator() bool { if m != nil { return m.Initiator } return false } type ListChannelsRequest struct { ActiveOnly bool `protobuf:"varint,1,opt,name=active_only,json=activeOnly,proto3" json:"active_only,omitempty"` InactiveOnly bool `protobuf:"varint,2,opt,name=inactive_only,json=inactiveOnly,proto3" json:"inactive_only,omitempty"` PublicOnly bool `protobuf:"varint,3,opt,name=public_only,json=publicOnly,proto3" json:"public_only,omitempty"` PrivateOnly bool `protobuf:"varint,4,opt,name=private_only,json=privateOnly,proto3" json:"private_only,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListChannelsRequest) Reset() { *m = ListChannelsRequest{} } func (m *ListChannelsRequest) String() string { return proto.CompactTextString(m) } func (*ListChannelsRequest) ProtoMessage() {} func (*ListChannelsRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{37} } func (m *ListChannelsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListChannelsRequest.Unmarshal(m, b) } func (m *ListChannelsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListChannelsRequest.Marshal(b, m, deterministic) } func (dst *ListChannelsRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ListChannelsRequest.Merge(dst, src) } func (m *ListChannelsRequest) XXX_Size() int { return xxx_messageInfo_ListChannelsRequest.Size(m) } func (m *ListChannelsRequest) XXX_DiscardUnknown() { xxx_messageInfo_ListChannelsRequest.DiscardUnknown(m) } var xxx_messageInfo_ListChannelsRequest proto.InternalMessageInfo func (m *ListChannelsRequest) GetActiveOnly() bool { if m != nil { return m.ActiveOnly } return false } func (m *ListChannelsRequest) GetInactiveOnly() bool { if m != nil { return m.InactiveOnly } return false } func (m *ListChannelsRequest) GetPublicOnly() bool { if m != nil { return m.PublicOnly } return false } func (m *ListChannelsRequest) GetPrivateOnly() bool { if m != nil { return m.PrivateOnly } return false } type ListChannelsResponse struct { // / The list of active channels Channels []*Channel `protobuf:"bytes,11,rep,name=channels,proto3" json:"channels,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListChannelsResponse) Reset() { *m = ListChannelsResponse{} } func (m *ListChannelsResponse) String() string { return proto.CompactTextString(m) } func (*ListChannelsResponse) ProtoMessage() {} func (*ListChannelsResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{38} } func (m *ListChannelsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListChannelsResponse.Unmarshal(m, b) } func (m *ListChannelsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListChannelsResponse.Marshal(b, m, deterministic) } func (dst *ListChannelsResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ListChannelsResponse.Merge(dst, src) } func (m *ListChannelsResponse) XXX_Size() int { return xxx_messageInfo_ListChannelsResponse.Size(m) } func (m *ListChannelsResponse) XXX_DiscardUnknown() { xxx_messageInfo_ListChannelsResponse.DiscardUnknown(m) } var xxx_messageInfo_ListChannelsResponse proto.InternalMessageInfo func (m *ListChannelsResponse) GetChannels() []*Channel { if m != nil { return m.Channels } return nil } type ChannelCloseSummary struct { // / The outpoint (txid:index) of the funding transaction. ChannelPoint string `protobuf:"bytes,1,opt,name=channel_point,proto3" json:"channel_point,omitempty"` // / The unique channel ID for the channel. ChanId uint64 `protobuf:"varint,2,opt,name=chan_id,proto3" json:"chan_id,omitempty"` // / The hash of the genesis block that this channel resides within. ChainHash string `protobuf:"bytes,3,opt,name=chain_hash,proto3" json:"chain_hash,omitempty"` // / The txid of the transaction which ultimately closed this channel. ClosingTxHash string `protobuf:"bytes,4,opt,name=closing_tx_hash,proto3" json:"closing_tx_hash,omitempty"` // / Public key of the remote peer that we formerly had a channel with. RemotePubkey string `protobuf:"bytes,5,opt,name=remote_pubkey,proto3" json:"remote_pubkey,omitempty"` // / Total capacity of the channel. Capacity int64 `protobuf:"varint,6,opt,name=capacity,proto3" json:"capacity,omitempty"` // / Height at which the funding transaction was spent. CloseHeight uint32 `protobuf:"varint,7,opt,name=close_height,proto3" json:"close_height,omitempty"` // / Settled balance at the time of channel closure SettledBalance int64 `protobuf:"varint,8,opt,name=settled_balance,proto3" json:"settled_balance,omitempty"` // / The sum of all the time-locked outputs at the time of channel closure TimeLockedBalance int64 `protobuf:"varint,9,opt,name=time_locked_balance,proto3" json:"time_locked_balance,omitempty"` // / Details on how the channel was closed. CloseType ChannelCloseSummary_ClosureType `protobuf:"varint,10,opt,name=close_type,proto3,enum=lnrpc.ChannelCloseSummary_ClosureType" json:"close_type,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelCloseSummary) Reset() { *m = ChannelCloseSummary{} } func (m *ChannelCloseSummary) String() string { return proto.CompactTextString(m) } func (*ChannelCloseSummary) ProtoMessage() {} func (*ChannelCloseSummary) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{39} } func (m *ChannelCloseSummary) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelCloseSummary.Unmarshal(m, b) } func (m *ChannelCloseSummary) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelCloseSummary.Marshal(b, m, deterministic) } func (dst *ChannelCloseSummary) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelCloseSummary.Merge(dst, src) } func (m *ChannelCloseSummary) XXX_Size() int { return xxx_messageInfo_ChannelCloseSummary.Size(m) } func (m *ChannelCloseSummary) XXX_DiscardUnknown() { xxx_messageInfo_ChannelCloseSummary.DiscardUnknown(m) } var xxx_messageInfo_ChannelCloseSummary proto.InternalMessageInfo func (m *ChannelCloseSummary) GetChannelPoint() string { if m != nil { return m.ChannelPoint } return "" } func (m *ChannelCloseSummary) GetChanId() uint64 { if m != nil { return m.ChanId } return 0 } func (m *ChannelCloseSummary) GetChainHash() string { if m != nil { return m.ChainHash } return "" } func (m *ChannelCloseSummary) GetClosingTxHash() string { if m != nil { return m.ClosingTxHash } return "" } func (m *ChannelCloseSummary) GetRemotePubkey() string { if m != nil { return m.RemotePubkey } return "" } func (m *ChannelCloseSummary) GetCapacity() int64 { if m != nil { return m.Capacity } return 0 } func (m *ChannelCloseSummary) GetCloseHeight() uint32 { if m != nil { return m.CloseHeight } return 0 } func (m *ChannelCloseSummary) GetSettledBalance() int64 { if m != nil { return m.SettledBalance } return 0 } func (m *ChannelCloseSummary) GetTimeLockedBalance() int64 { if m != nil { return m.TimeLockedBalance } return 0 } func (m *ChannelCloseSummary) GetCloseType() ChannelCloseSummary_ClosureType { if m != nil { return m.CloseType } return ChannelCloseSummary_COOPERATIVE_CLOSE } type ClosedChannelsRequest struct { Cooperative bool `protobuf:"varint,1,opt,name=cooperative,proto3" json:"cooperative,omitempty"` LocalForce bool `protobuf:"varint,2,opt,name=local_force,json=localForce,proto3" json:"local_force,omitempty"` RemoteForce bool `protobuf:"varint,3,opt,name=remote_force,json=remoteForce,proto3" json:"remote_force,omitempty"` Breach bool `protobuf:"varint,4,opt,name=breach,proto3" json:"breach,omitempty"` FundingCanceled bool `protobuf:"varint,5,opt,name=funding_canceled,json=fundingCanceled,proto3" json:"funding_canceled,omitempty"` Abandoned bool `protobuf:"varint,6,opt,name=abandoned,proto3" json:"abandoned,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ClosedChannelsRequest) Reset() { *m = ClosedChannelsRequest{} } func (m *ClosedChannelsRequest) String() string { return proto.CompactTextString(m) } func (*ClosedChannelsRequest) ProtoMessage() {} func (*ClosedChannelsRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{40} } func (m *ClosedChannelsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ClosedChannelsRequest.Unmarshal(m, b) } func (m *ClosedChannelsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ClosedChannelsRequest.Marshal(b, m, deterministic) } func (dst *ClosedChannelsRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ClosedChannelsRequest.Merge(dst, src) } func (m *ClosedChannelsRequest) XXX_Size() int { return xxx_messageInfo_ClosedChannelsRequest.Size(m) } func (m *ClosedChannelsRequest) XXX_DiscardUnknown() { xxx_messageInfo_ClosedChannelsRequest.DiscardUnknown(m) } var xxx_messageInfo_ClosedChannelsRequest proto.InternalMessageInfo func (m *ClosedChannelsRequest) GetCooperative() bool { if m != nil { return m.Cooperative } return false } func (m *ClosedChannelsRequest) GetLocalForce() bool { if m != nil { return m.LocalForce } return false } func (m *ClosedChannelsRequest) GetRemoteForce() bool { if m != nil { return m.RemoteForce } return false } func (m *ClosedChannelsRequest) GetBreach() bool { if m != nil { return m.Breach } return false } func (m *ClosedChannelsRequest) GetFundingCanceled() bool { if m != nil { return m.FundingCanceled } return false } func (m *ClosedChannelsRequest) GetAbandoned() bool { if m != nil { return m.Abandoned } return false } type ClosedChannelsResponse struct { Channels []*ChannelCloseSummary `protobuf:"bytes,1,rep,name=channels,proto3" json:"channels,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ClosedChannelsResponse) Reset() { *m = ClosedChannelsResponse{} } func (m *ClosedChannelsResponse) String() string { return proto.CompactTextString(m) } func (*ClosedChannelsResponse) ProtoMessage() {} func (*ClosedChannelsResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{41} } func (m *ClosedChannelsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ClosedChannelsResponse.Unmarshal(m, b) } func (m *ClosedChannelsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ClosedChannelsResponse.Marshal(b, m, deterministic) } func (dst *ClosedChannelsResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ClosedChannelsResponse.Merge(dst, src) } func (m *ClosedChannelsResponse) XXX_Size() int { return xxx_messageInfo_ClosedChannelsResponse.Size(m) } func (m *ClosedChannelsResponse) XXX_DiscardUnknown() { xxx_messageInfo_ClosedChannelsResponse.DiscardUnknown(m) } var xxx_messageInfo_ClosedChannelsResponse proto.InternalMessageInfo func (m *ClosedChannelsResponse) GetChannels() []*ChannelCloseSummary { if m != nil { return m.Channels } return nil } type Peer struct { // / The identity pubkey of the peer PubKey string `protobuf:"bytes,1,opt,name=pub_key,proto3" json:"pub_key,omitempty"` // / Network address of the peer; eg `127.0.0.1:10011` Address string `protobuf:"bytes,3,opt,name=address,proto3" json:"address,omitempty"` // / Bytes of data transmitted to this peer BytesSent uint64 `protobuf:"varint,4,opt,name=bytes_sent,proto3" json:"bytes_sent,omitempty"` // / Bytes of data transmitted from this peer BytesRecv uint64 `protobuf:"varint,5,opt,name=bytes_recv,proto3" json:"bytes_recv,omitempty"` // / Satoshis sent to this peer SatSent int64 `protobuf:"varint,6,opt,name=sat_sent,proto3" json:"sat_sent,omitempty"` // / Satoshis received from this peer SatRecv int64 `protobuf:"varint,7,opt,name=sat_recv,proto3" json:"sat_recv,omitempty"` // / A channel is inbound if the counterparty initiated the channel Inbound bool `protobuf:"varint,8,opt,name=inbound,proto3" json:"inbound,omitempty"` // / Ping time to this peer PingTime int64 `protobuf:"varint,9,opt,name=ping_time,proto3" json:"ping_time,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Peer) Reset() { *m = Peer{} } func (m *Peer) String() string { return proto.CompactTextString(m) } func (*Peer) ProtoMessage() {} func (*Peer) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{42} } func (m *Peer) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Peer.Unmarshal(m, b) } func (m *Peer) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Peer.Marshal(b, m, deterministic) } func (dst *Peer) XXX_Merge(src proto.Message) { xxx_messageInfo_Peer.Merge(dst, src) } func (m *Peer) XXX_Size() int { return xxx_messageInfo_Peer.Size(m) } func (m *Peer) XXX_DiscardUnknown() { xxx_messageInfo_Peer.DiscardUnknown(m) } var xxx_messageInfo_Peer proto.InternalMessageInfo func (m *Peer) GetPubKey() string { if m != nil { return m.PubKey } return "" } func (m *Peer) GetAddress() string { if m != nil { return m.Address } return "" } func (m *Peer) GetBytesSent() uint64 { if m != nil { return m.BytesSent } return 0 } func (m *Peer) GetBytesRecv() uint64 { if m != nil { return m.BytesRecv } return 0 } func (m *Peer) GetSatSent() int64 { if m != nil { return m.SatSent } return 0 } func (m *Peer) GetSatRecv() int64 { if m != nil { return m.SatRecv } return 0 } func (m *Peer) GetInbound() bool { if m != nil { return m.Inbound } return false } func (m *Peer) GetPingTime() int64 { if m != nil { return m.PingTime } return 0 } type ListPeersRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListPeersRequest) Reset() { *m = ListPeersRequest{} } func (m *ListPeersRequest) String() string { return proto.CompactTextString(m) } func (*ListPeersRequest) ProtoMessage() {} func (*ListPeersRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{43} } func (m *ListPeersRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListPeersRequest.Unmarshal(m, b) } func (m *ListPeersRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListPeersRequest.Marshal(b, m, deterministic) } func (dst *ListPeersRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ListPeersRequest.Merge(dst, src) } func (m *ListPeersRequest) XXX_Size() int { return xxx_messageInfo_ListPeersRequest.Size(m) } func (m *ListPeersRequest) XXX_DiscardUnknown() { xxx_messageInfo_ListPeersRequest.DiscardUnknown(m) } var xxx_messageInfo_ListPeersRequest proto.InternalMessageInfo type ListPeersResponse struct { // / The list of currently connected peers Peers []*Peer `protobuf:"bytes,1,rep,name=peers,proto3" json:"peers,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListPeersResponse) Reset() { *m = ListPeersResponse{} } func (m *ListPeersResponse) String() string { return proto.CompactTextString(m) } func (*ListPeersResponse) ProtoMessage() {} func (*ListPeersResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{44} } func (m *ListPeersResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListPeersResponse.Unmarshal(m, b) } func (m *ListPeersResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListPeersResponse.Marshal(b, m, deterministic) } func (dst *ListPeersResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ListPeersResponse.Merge(dst, src) } func (m *ListPeersResponse) XXX_Size() int { return xxx_messageInfo_ListPeersResponse.Size(m) } func (m *ListPeersResponse) XXX_DiscardUnknown() { xxx_messageInfo_ListPeersResponse.DiscardUnknown(m) } var xxx_messageInfo_ListPeersResponse proto.InternalMessageInfo func (m *ListPeersResponse) GetPeers() []*Peer { if m != nil { return m.Peers } return nil } type GetInfoRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *GetInfoRequest) Reset() { *m = GetInfoRequest{} } func (m *GetInfoRequest) String() string { return proto.CompactTextString(m) } func (*GetInfoRequest) ProtoMessage() {} func (*GetInfoRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{45} } func (m *GetInfoRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetInfoRequest.Unmarshal(m, b) } func (m *GetInfoRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_GetInfoRequest.Marshal(b, m, deterministic) } func (dst *GetInfoRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_GetInfoRequest.Merge(dst, src) } func (m *GetInfoRequest) XXX_Size() int { return xxx_messageInfo_GetInfoRequest.Size(m) } func (m *GetInfoRequest) XXX_DiscardUnknown() { xxx_messageInfo_GetInfoRequest.DiscardUnknown(m) } var xxx_messageInfo_GetInfoRequest proto.InternalMessageInfo type GetInfoResponse struct { // / The identity pubkey of the current node. IdentityPubkey string `protobuf:"bytes,1,opt,name=identity_pubkey,proto3" json:"identity_pubkey,omitempty"` // / If applicable, the alias of the current node, e.g. "bob" Alias string `protobuf:"bytes,2,opt,name=alias,proto3" json:"alias,omitempty"` // / Number of pending channels NumPendingChannels uint32 `protobuf:"varint,3,opt,name=num_pending_channels,proto3" json:"num_pending_channels,omitempty"` // / Number of active channels NumActiveChannels uint32 `protobuf:"varint,4,opt,name=num_active_channels,proto3" json:"num_active_channels,omitempty"` // / Number of peers NumPeers uint32 `protobuf:"varint,5,opt,name=num_peers,proto3" json:"num_peers,omitempty"` // / The node's current view of the height of the best block BlockHeight uint32 `protobuf:"varint,6,opt,name=block_height,proto3" json:"block_height,omitempty"` // / The node's current view of the hash of the best block BlockHash string `protobuf:"bytes,8,opt,name=block_hash,proto3" json:"block_hash,omitempty"` // / Whether the wallet's view is synced to the main chain SyncedToChain bool `protobuf:"varint,9,opt,name=synced_to_chain,proto3" json:"synced_to_chain,omitempty"` // * // Whether the current node is connected to testnet. This field is // deprecated and the network field should be used instead Testnet bool `protobuf:"varint,10,opt,name=testnet,proto3" json:"testnet,omitempty"` // Deprecated: Do not use. // / The URIs of the current node. Uris []string `protobuf:"bytes,12,rep,name=uris,proto3" json:"uris,omitempty"` // / Timestamp of the block best known to the wallet BestHeaderTimestamp int64 `protobuf:"varint,13,opt,name=best_header_timestamp,proto3" json:"best_header_timestamp,omitempty"` // / The version of the LND software that the node is running. Version string `protobuf:"bytes,14,opt,name=version,proto3" json:"version,omitempty"` // / Number of inactive channels NumInactiveChannels uint32 `protobuf:"varint,15,opt,name=num_inactive_channels,proto3" json:"num_inactive_channels,omitempty"` // / A list of active chains the node is connected to Chains []*Chain `protobuf:"bytes,16,rep,name=chains,proto3" json:"chains,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *GetInfoResponse) Reset() { *m = GetInfoResponse{} } func (m *GetInfoResponse) String() string { return proto.CompactTextString(m) } func (*GetInfoResponse) ProtoMessage() {} func (*GetInfoResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{46} } func (m *GetInfoResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetInfoResponse.Unmarshal(m, b) } func (m *GetInfoResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_GetInfoResponse.Marshal(b, m, deterministic) } func (dst *GetInfoResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_GetInfoResponse.Merge(dst, src) } func (m *GetInfoResponse) XXX_Size() int { return xxx_messageInfo_GetInfoResponse.Size(m) } func (m *GetInfoResponse) XXX_DiscardUnknown() { xxx_messageInfo_GetInfoResponse.DiscardUnknown(m) } var xxx_messageInfo_GetInfoResponse proto.InternalMessageInfo func (m *GetInfoResponse) GetIdentityPubkey() string { if m != nil { return m.IdentityPubkey } return "" } func (m *GetInfoResponse) GetAlias() string { if m != nil { return m.Alias } return "" } func (m *GetInfoResponse) GetNumPendingChannels() uint32 { if m != nil { return m.NumPendingChannels } return 0 } func (m *GetInfoResponse) GetNumActiveChannels() uint32 { if m != nil { return m.NumActiveChannels } return 0 } func (m *GetInfoResponse) GetNumPeers() uint32 { if m != nil { return m.NumPeers } return 0 } func (m *GetInfoResponse) GetBlockHeight() uint32 { if m != nil { return m.BlockHeight } return 0 } func (m *GetInfoResponse) GetBlockHash() string { if m != nil { return m.BlockHash } return "" } func (m *GetInfoResponse) GetSyncedToChain() bool { if m != nil { return m.SyncedToChain } return false } // Deprecated: Do not use. func (m *GetInfoResponse) GetTestnet() bool { if m != nil { return m.Testnet } return false } func (m *GetInfoResponse) GetUris() []string { if m != nil { return m.Uris } return nil } func (m *GetInfoResponse) GetBestHeaderTimestamp() int64 { if m != nil { return m.BestHeaderTimestamp } return 0 } func (m *GetInfoResponse) GetVersion() string { if m != nil { return m.Version } return "" } func (m *GetInfoResponse) GetNumInactiveChannels() uint32 { if m != nil { return m.NumInactiveChannels } return 0 } func (m *GetInfoResponse) GetChains() []*Chain { if m != nil { return m.Chains } return nil } type Chain struct { // / The blockchain the node is on (eg bitcoin, litecoin) Chain string `protobuf:"bytes,1,opt,name=chain,proto3" json:"chain,omitempty"` // / The network the node is on (eg regtest, testnet, mainnet) Network string `protobuf:"bytes,2,opt,name=network,proto3" json:"network,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Chain) Reset() { *m = Chain{} } func (m *Chain) String() string { return proto.CompactTextString(m) } func (*Chain) ProtoMessage() {} func (*Chain) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{47} } func (m *Chain) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Chain.Unmarshal(m, b) } func (m *Chain) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Chain.Marshal(b, m, deterministic) } func (dst *Chain) XXX_Merge(src proto.Message) { xxx_messageInfo_Chain.Merge(dst, src) } func (m *Chain) XXX_Size() int { return xxx_messageInfo_Chain.Size(m) } func (m *Chain) XXX_DiscardUnknown() { xxx_messageInfo_Chain.DiscardUnknown(m) } var xxx_messageInfo_Chain proto.InternalMessageInfo func (m *Chain) GetChain() string { if m != nil { return m.Chain } return "" } func (m *Chain) GetNetwork() string { if m != nil { return m.Network } return "" } type ConfirmationUpdate struct { BlockSha []byte `protobuf:"bytes,1,opt,name=block_sha,json=blockSha,proto3" json:"block_sha,omitempty"` BlockHeight int32 `protobuf:"varint,2,opt,name=block_height,json=blockHeight,proto3" json:"block_height,omitempty"` NumConfsLeft uint32 `protobuf:"varint,3,opt,name=num_confs_left,json=numConfsLeft,proto3" json:"num_confs_left,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ConfirmationUpdate) Reset() { *m = ConfirmationUpdate{} } func (m *ConfirmationUpdate) String() string { return proto.CompactTextString(m) } func (*ConfirmationUpdate) ProtoMessage() {} func (*ConfirmationUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{48} } func (m *ConfirmationUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ConfirmationUpdate.Unmarshal(m, b) } func (m *ConfirmationUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ConfirmationUpdate.Marshal(b, m, deterministic) } func (dst *ConfirmationUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_ConfirmationUpdate.Merge(dst, src) } func (m *ConfirmationUpdate) XXX_Size() int { return xxx_messageInfo_ConfirmationUpdate.Size(m) } func (m *ConfirmationUpdate) XXX_DiscardUnknown() { xxx_messageInfo_ConfirmationUpdate.DiscardUnknown(m) } var xxx_messageInfo_ConfirmationUpdate proto.InternalMessageInfo func (m *ConfirmationUpdate) GetBlockSha() []byte { if m != nil { return m.BlockSha } return nil } func (m *ConfirmationUpdate) GetBlockHeight() int32 { if m != nil { return m.BlockHeight } return 0 } func (m *ConfirmationUpdate) GetNumConfsLeft() uint32 { if m != nil { return m.NumConfsLeft } return 0 } type ChannelOpenUpdate struct { ChannelPoint *ChannelPoint `protobuf:"bytes,1,opt,name=channel_point,proto3" json:"channel_point,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelOpenUpdate) Reset() { *m = ChannelOpenUpdate{} } func (m *ChannelOpenUpdate) String() string { return proto.CompactTextString(m) } func (*ChannelOpenUpdate) ProtoMessage() {} func (*ChannelOpenUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{49} } func (m *ChannelOpenUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelOpenUpdate.Unmarshal(m, b) } func (m *ChannelOpenUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelOpenUpdate.Marshal(b, m, deterministic) } func (dst *ChannelOpenUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelOpenUpdate.Merge(dst, src) } func (m *ChannelOpenUpdate) XXX_Size() int { return xxx_messageInfo_ChannelOpenUpdate.Size(m) } func (m *ChannelOpenUpdate) XXX_DiscardUnknown() { xxx_messageInfo_ChannelOpenUpdate.DiscardUnknown(m) } var xxx_messageInfo_ChannelOpenUpdate proto.InternalMessageInfo func (m *ChannelOpenUpdate) GetChannelPoint() *ChannelPoint { if m != nil { return m.ChannelPoint } return nil } type ChannelCloseUpdate struct { ClosingTxid []byte `protobuf:"bytes,1,opt,name=closing_txid,proto3" json:"closing_txid,omitempty"` Success bool `protobuf:"varint,2,opt,name=success,proto3" json:"success,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelCloseUpdate) Reset() { *m = ChannelCloseUpdate{} } func (m *ChannelCloseUpdate) String() string { return proto.CompactTextString(m) } func (*ChannelCloseUpdate) ProtoMessage() {} func (*ChannelCloseUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{50} } func (m *ChannelCloseUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelCloseUpdate.Unmarshal(m, b) } func (m *ChannelCloseUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelCloseUpdate.Marshal(b, m, deterministic) } func (dst *ChannelCloseUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelCloseUpdate.Merge(dst, src) } func (m *ChannelCloseUpdate) XXX_Size() int { return xxx_messageInfo_ChannelCloseUpdate.Size(m) } func (m *ChannelCloseUpdate) XXX_DiscardUnknown() { xxx_messageInfo_ChannelCloseUpdate.DiscardUnknown(m) } var xxx_messageInfo_ChannelCloseUpdate proto.InternalMessageInfo func (m *ChannelCloseUpdate) GetClosingTxid() []byte { if m != nil { return m.ClosingTxid } return nil } func (m *ChannelCloseUpdate) GetSuccess() bool { if m != nil { return m.Success } return false } type CloseChannelRequest struct { // * // The outpoint (txid:index) of the funding transaction. With this value, Bob // will be able to generate a signature for Alice's version of the commitment // transaction. ChannelPoint *ChannelPoint `protobuf:"bytes,1,opt,name=channel_point,json=channelPoint,proto3" json:"channel_point,omitempty"` // / If true, then the channel will be closed forcibly. This means the current commitment transaction will be signed and broadcast. Force bool `protobuf:"varint,2,opt,name=force,proto3" json:"force,omitempty"` // / The target number of blocks that the closure transaction should be confirmed by. TargetConf int32 `protobuf:"varint,3,opt,name=target_conf,json=targetConf,proto3" json:"target_conf,omitempty"` // / A manual fee rate set in sat/byte that should be used when crafting the closure transaction. SatPerByte int64 `protobuf:"varint,4,opt,name=sat_per_byte,json=satPerByte,proto3" json:"sat_per_byte,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *CloseChannelRequest) Reset() { *m = CloseChannelRequest{} } func (m *CloseChannelRequest) String() string { return proto.CompactTextString(m) } func (*CloseChannelRequest) ProtoMessage() {} func (*CloseChannelRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{51} } func (m *CloseChannelRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_CloseChannelRequest.Unmarshal(m, b) } func (m *CloseChannelRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_CloseChannelRequest.Marshal(b, m, deterministic) } func (dst *CloseChannelRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_CloseChannelRequest.Merge(dst, src) } func (m *CloseChannelRequest) XXX_Size() int { return xxx_messageInfo_CloseChannelRequest.Size(m) } func (m *CloseChannelRequest) XXX_DiscardUnknown() { xxx_messageInfo_CloseChannelRequest.DiscardUnknown(m) } var xxx_messageInfo_CloseChannelRequest proto.InternalMessageInfo func (m *CloseChannelRequest) GetChannelPoint() *ChannelPoint { if m != nil { return m.ChannelPoint } return nil } func (m *CloseChannelRequest) GetForce() bool { if m != nil { return m.Force } return false } func (m *CloseChannelRequest) GetTargetConf() int32 { if m != nil { return m.TargetConf } return 0 } func (m *CloseChannelRequest) GetSatPerByte() int64 { if m != nil { return m.SatPerByte } return 0 } type CloseStatusUpdate struct { // Types that are valid to be assigned to Update: // *CloseStatusUpdate_ClosePending // *CloseStatusUpdate_ChanClose Update isCloseStatusUpdate_Update `protobuf_oneof:"update"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *CloseStatusUpdate) Reset() { *m = CloseStatusUpdate{} } func (m *CloseStatusUpdate) String() string { return proto.CompactTextString(m) } func (*CloseStatusUpdate) ProtoMessage() {} func (*CloseStatusUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{52} } func (m *CloseStatusUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_CloseStatusUpdate.Unmarshal(m, b) } func (m *CloseStatusUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_CloseStatusUpdate.Marshal(b, m, deterministic) } func (dst *CloseStatusUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_CloseStatusUpdate.Merge(dst, src) } func (m *CloseStatusUpdate) XXX_Size() int { return xxx_messageInfo_CloseStatusUpdate.Size(m) } func (m *CloseStatusUpdate) XXX_DiscardUnknown() { xxx_messageInfo_CloseStatusUpdate.DiscardUnknown(m) } var xxx_messageInfo_CloseStatusUpdate proto.InternalMessageInfo type isCloseStatusUpdate_Update interface { isCloseStatusUpdate_Update() } type CloseStatusUpdate_ClosePending struct { ClosePending *PendingUpdate `protobuf:"bytes,1,opt,name=close_pending,proto3,oneof"` } type CloseStatusUpdate_ChanClose struct { ChanClose *ChannelCloseUpdate `protobuf:"bytes,3,opt,name=chan_close,proto3,oneof"` } func (*CloseStatusUpdate_ClosePending) isCloseStatusUpdate_Update() {} func (*CloseStatusUpdate_ChanClose) isCloseStatusUpdate_Update() {} func (m *CloseStatusUpdate) GetUpdate() isCloseStatusUpdate_Update { if m != nil { return m.Update } return nil } func (m *CloseStatusUpdate) GetClosePending() *PendingUpdate { if x, ok := m.GetUpdate().(*CloseStatusUpdate_ClosePending); ok { return x.ClosePending } return nil } func (m *CloseStatusUpdate) GetChanClose() *ChannelCloseUpdate { if x, ok := m.GetUpdate().(*CloseStatusUpdate_ChanClose); ok { return x.ChanClose } return nil } // XXX_OneofFuncs is for the internal use of the proto package. func (*CloseStatusUpdate) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _CloseStatusUpdate_OneofMarshaler, _CloseStatusUpdate_OneofUnmarshaler, _CloseStatusUpdate_OneofSizer, []interface{}{ (*CloseStatusUpdate_ClosePending)(nil), (*CloseStatusUpdate_ChanClose)(nil), } } func _CloseStatusUpdate_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { m := msg.(*CloseStatusUpdate) // update switch x := m.Update.(type) { case *CloseStatusUpdate_ClosePending: b.EncodeVarint(1<<3 | proto.WireBytes) if err := b.EncodeMessage(x.ClosePending); err != nil { return err } case *CloseStatusUpdate_ChanClose: b.EncodeVarint(3<<3 | proto.WireBytes) if err := b.EncodeMessage(x.ChanClose); err != nil { return err } case nil: default: return fmt.Errorf("CloseStatusUpdate.Update has unexpected type %T", x) } return nil } func _CloseStatusUpdate_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { m := msg.(*CloseStatusUpdate) switch tag { case 1: // update.close_pending if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(PendingUpdate) err := b.DecodeMessage(msg) m.Update = &CloseStatusUpdate_ClosePending{msg} return true, err case 3: // update.chan_close if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(ChannelCloseUpdate) err := b.DecodeMessage(msg) m.Update = &CloseStatusUpdate_ChanClose{msg} return true, err default: return false, nil } } func _CloseStatusUpdate_OneofSizer(msg proto.Message) (n int) { m := msg.(*CloseStatusUpdate) // update switch x := m.Update.(type) { case *CloseStatusUpdate_ClosePending: s := proto.Size(x.ClosePending) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case *CloseStatusUpdate_ChanClose: s := proto.Size(x.ChanClose) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) } return n } type PendingUpdate struct { Txid []byte `protobuf:"bytes,1,opt,name=txid,proto3" json:"txid,omitempty"` OutputIndex uint32 `protobuf:"varint,2,opt,name=output_index,proto3" json:"output_index,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingUpdate) Reset() { *m = PendingUpdate{} } func (m *PendingUpdate) String() string { return proto.CompactTextString(m) } func (*PendingUpdate) ProtoMessage() {} func (*PendingUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{53} } func (m *PendingUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingUpdate.Unmarshal(m, b) } func (m *PendingUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingUpdate.Marshal(b, m, deterministic) } func (dst *PendingUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingUpdate.Merge(dst, src) } func (m *PendingUpdate) XXX_Size() int { return xxx_messageInfo_PendingUpdate.Size(m) } func (m *PendingUpdate) XXX_DiscardUnknown() { xxx_messageInfo_PendingUpdate.DiscardUnknown(m) } var xxx_messageInfo_PendingUpdate proto.InternalMessageInfo func (m *PendingUpdate) GetTxid() []byte { if m != nil { return m.Txid } return nil } func (m *PendingUpdate) GetOutputIndex() uint32 { if m != nil { return m.OutputIndex } return 0 } type OpenChannelRequest struct { // / The pubkey of the node to open a channel with NodePubkey []byte `protobuf:"bytes,2,opt,name=node_pubkey,proto3" json:"node_pubkey,omitempty"` // / The hex encoded pubkey of the node to open a channel with NodePubkeyString string `protobuf:"bytes,3,opt,name=node_pubkey_string,proto3" json:"node_pubkey_string,omitempty"` // / The number of satoshis the wallet should commit to the channel LocalFundingAmount int64 `protobuf:"varint,4,opt,name=local_funding_amount,proto3" json:"local_funding_amount,omitempty"` // / The number of satoshis to push to the remote side as part of the initial commitment state PushSat int64 `protobuf:"varint,5,opt,name=push_sat,proto3" json:"push_sat,omitempty"` // / The target number of blocks that the funding transaction should be confirmed by. TargetConf int32 `protobuf:"varint,6,opt,name=target_conf,json=targetConf,proto3" json:"target_conf,omitempty"` // / A manual fee rate set in sat/byte that should be used when crafting the funding transaction. SatPerByte int64 `protobuf:"varint,7,opt,name=sat_per_byte,json=satPerByte,proto3" json:"sat_per_byte,omitempty"` // / Whether this channel should be private, not announced to the greater network. Private bool `protobuf:"varint,8,opt,name=private,proto3" json:"private,omitempty"` // / The minimum value in millisatoshi we will require for incoming HTLCs on the channel. MinHtlcMsat int64 `protobuf:"varint,9,opt,name=min_htlc_msat,proto3" json:"min_htlc_msat,omitempty"` // / The delay we require on the remote's commitment transaction. If this is not set, it will be scaled automatically with the channel size. RemoteCsvDelay uint32 `protobuf:"varint,10,opt,name=remote_csv_delay,proto3" json:"remote_csv_delay,omitempty"` // / The minimum number of confirmations each one of your outputs used for the funding transaction must satisfy. MinConfs int32 `protobuf:"varint,11,opt,name=min_confs,proto3" json:"min_confs,omitempty"` // / Whether unconfirmed outputs should be used as inputs for the funding transaction. SpendUnconfirmed bool `protobuf:"varint,12,opt,name=spend_unconfirmed,proto3" json:"spend_unconfirmed,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *OpenChannelRequest) Reset() { *m = OpenChannelRequest{} } func (m *OpenChannelRequest) String() string { return proto.CompactTextString(m) } func (*OpenChannelRequest) ProtoMessage() {} func (*OpenChannelRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{54} } func (m *OpenChannelRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_OpenChannelRequest.Unmarshal(m, b) } func (m *OpenChannelRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_OpenChannelRequest.Marshal(b, m, deterministic) } func (dst *OpenChannelRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_OpenChannelRequest.Merge(dst, src) } func (m *OpenChannelRequest) XXX_Size() int { return xxx_messageInfo_OpenChannelRequest.Size(m) } func (m *OpenChannelRequest) XXX_DiscardUnknown() { xxx_messageInfo_OpenChannelRequest.DiscardUnknown(m) } var xxx_messageInfo_OpenChannelRequest proto.InternalMessageInfo func (m *OpenChannelRequest) GetNodePubkey() []byte { if m != nil { return m.NodePubkey } return nil } func (m *OpenChannelRequest) GetNodePubkeyString() string { if m != nil { return m.NodePubkeyString } return "" } func (m *OpenChannelRequest) GetLocalFundingAmount() int64 { if m != nil { return m.LocalFundingAmount } return 0 } func (m *OpenChannelRequest) GetPushSat() int64 { if m != nil { return m.PushSat } return 0 } func (m *OpenChannelRequest) GetTargetConf() int32 { if m != nil { return m.TargetConf } return 0 } func (m *OpenChannelRequest) GetSatPerByte() int64 { if m != nil { return m.SatPerByte } return 0 } func (m *OpenChannelRequest) GetPrivate() bool { if m != nil { return m.Private } return false } func (m *OpenChannelRequest) GetMinHtlcMsat() int64 { if m != nil { return m.MinHtlcMsat } return 0 } func (m *OpenChannelRequest) GetRemoteCsvDelay() uint32 { if m != nil { return m.RemoteCsvDelay } return 0 } func (m *OpenChannelRequest) GetMinConfs() int32 { if m != nil { return m.MinConfs } return 0 } func (m *OpenChannelRequest) GetSpendUnconfirmed() bool { if m != nil { return m.SpendUnconfirmed } return false } type OpenStatusUpdate struct { // Types that are valid to be assigned to Update: // *OpenStatusUpdate_ChanPending // *OpenStatusUpdate_ChanOpen Update isOpenStatusUpdate_Update `protobuf_oneof:"update"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *OpenStatusUpdate) Reset() { *m = OpenStatusUpdate{} } func (m *OpenStatusUpdate) String() string { return proto.CompactTextString(m) } func (*OpenStatusUpdate) ProtoMessage() {} func (*OpenStatusUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{55} } func (m *OpenStatusUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_OpenStatusUpdate.Unmarshal(m, b) } func (m *OpenStatusUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_OpenStatusUpdate.Marshal(b, m, deterministic) } func (dst *OpenStatusUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_OpenStatusUpdate.Merge(dst, src) } func (m *OpenStatusUpdate) XXX_Size() int { return xxx_messageInfo_OpenStatusUpdate.Size(m) } func (m *OpenStatusUpdate) XXX_DiscardUnknown() { xxx_messageInfo_OpenStatusUpdate.DiscardUnknown(m) } var xxx_messageInfo_OpenStatusUpdate proto.InternalMessageInfo type isOpenStatusUpdate_Update interface { isOpenStatusUpdate_Update() } type OpenStatusUpdate_ChanPending struct { ChanPending *PendingUpdate `protobuf:"bytes,1,opt,name=chan_pending,proto3,oneof"` } type OpenStatusUpdate_ChanOpen struct { ChanOpen *ChannelOpenUpdate `protobuf:"bytes,3,opt,name=chan_open,proto3,oneof"` } func (*OpenStatusUpdate_ChanPending) isOpenStatusUpdate_Update() {} func (*OpenStatusUpdate_ChanOpen) isOpenStatusUpdate_Update() {} func (m *OpenStatusUpdate) GetUpdate() isOpenStatusUpdate_Update { if m != nil { return m.Update } return nil } func (m *OpenStatusUpdate) GetChanPending() *PendingUpdate { if x, ok := m.GetUpdate().(*OpenStatusUpdate_ChanPending); ok { return x.ChanPending } return nil } func (m *OpenStatusUpdate) GetChanOpen() *ChannelOpenUpdate { if x, ok := m.GetUpdate().(*OpenStatusUpdate_ChanOpen); ok { return x.ChanOpen } return nil } // XXX_OneofFuncs is for the internal use of the proto package. func (*OpenStatusUpdate) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _OpenStatusUpdate_OneofMarshaler, _OpenStatusUpdate_OneofUnmarshaler, _OpenStatusUpdate_OneofSizer, []interface{}{ (*OpenStatusUpdate_ChanPending)(nil), (*OpenStatusUpdate_ChanOpen)(nil), } } func _OpenStatusUpdate_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { m := msg.(*OpenStatusUpdate) // update switch x := m.Update.(type) { case *OpenStatusUpdate_ChanPending: b.EncodeVarint(1<<3 | proto.WireBytes) if err := b.EncodeMessage(x.ChanPending); err != nil { return err } case *OpenStatusUpdate_ChanOpen: b.EncodeVarint(3<<3 | proto.WireBytes) if err := b.EncodeMessage(x.ChanOpen); err != nil { return err } case nil: default: return fmt.Errorf("OpenStatusUpdate.Update has unexpected type %T", x) } return nil } func _OpenStatusUpdate_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { m := msg.(*OpenStatusUpdate) switch tag { case 1: // update.chan_pending if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(PendingUpdate) err := b.DecodeMessage(msg) m.Update = &OpenStatusUpdate_ChanPending{msg} return true, err case 3: // update.chan_open if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(ChannelOpenUpdate) err := b.DecodeMessage(msg) m.Update = &OpenStatusUpdate_ChanOpen{msg} return true, err default: return false, nil } } func _OpenStatusUpdate_OneofSizer(msg proto.Message) (n int) { m := msg.(*OpenStatusUpdate) // update switch x := m.Update.(type) { case *OpenStatusUpdate_ChanPending: s := proto.Size(x.ChanPending) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case *OpenStatusUpdate_ChanOpen: s := proto.Size(x.ChanOpen) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) } return n } type PendingHTLC struct { // / The direction within the channel that the htlc was sent Incoming bool `protobuf:"varint,1,opt,name=incoming,proto3" json:"incoming,omitempty"` // / The total value of the htlc Amount int64 `protobuf:"varint,2,opt,name=amount,proto3" json:"amount,omitempty"` // / The final output to be swept back to the user's wallet Outpoint string `protobuf:"bytes,3,opt,name=outpoint,proto3" json:"outpoint,omitempty"` // / The next block height at which we can spend the current stage MaturityHeight uint32 `protobuf:"varint,4,opt,name=maturity_height,proto3" json:"maturity_height,omitempty"` // * // The number of blocks remaining until the current stage can be swept. // Negative values indicate how many blocks have passed since becoming // mature. BlocksTilMaturity int32 `protobuf:"varint,5,opt,name=blocks_til_maturity,proto3" json:"blocks_til_maturity,omitempty"` // / Indicates whether the htlc is in its first or second stage of recovery Stage uint32 `protobuf:"varint,6,opt,name=stage,proto3" json:"stage,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingHTLC) Reset() { *m = PendingHTLC{} } func (m *PendingHTLC) String() string { return proto.CompactTextString(m) } func (*PendingHTLC) ProtoMessage() {} func (*PendingHTLC) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{56} } func (m *PendingHTLC) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingHTLC.Unmarshal(m, b) } func (m *PendingHTLC) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingHTLC.Marshal(b, m, deterministic) } func (dst *PendingHTLC) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingHTLC.Merge(dst, src) } func (m *PendingHTLC) XXX_Size() int { return xxx_messageInfo_PendingHTLC.Size(m) } func (m *PendingHTLC) XXX_DiscardUnknown() { xxx_messageInfo_PendingHTLC.DiscardUnknown(m) } var xxx_messageInfo_PendingHTLC proto.InternalMessageInfo func (m *PendingHTLC) GetIncoming() bool { if m != nil { return m.Incoming } return false } func (m *PendingHTLC) GetAmount() int64 { if m != nil { return m.Amount } return 0 } func (m *PendingHTLC) GetOutpoint() string { if m != nil { return m.Outpoint } return "" } func (m *PendingHTLC) GetMaturityHeight() uint32 { if m != nil { return m.MaturityHeight } return 0 } func (m *PendingHTLC) GetBlocksTilMaturity() int32 { if m != nil { return m.BlocksTilMaturity } return 0 } func (m *PendingHTLC) GetStage() uint32 { if m != nil { return m.Stage } return 0 } type PendingChannelsRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingChannelsRequest) Reset() { *m = PendingChannelsRequest{} } func (m *PendingChannelsRequest) String() string { return proto.CompactTextString(m) } func (*PendingChannelsRequest) ProtoMessage() {} func (*PendingChannelsRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{57} } func (m *PendingChannelsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingChannelsRequest.Unmarshal(m, b) } func (m *PendingChannelsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingChannelsRequest.Marshal(b, m, deterministic) } func (dst *PendingChannelsRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingChannelsRequest.Merge(dst, src) } func (m *PendingChannelsRequest) XXX_Size() int { return xxx_messageInfo_PendingChannelsRequest.Size(m) } func (m *PendingChannelsRequest) XXX_DiscardUnknown() { xxx_messageInfo_PendingChannelsRequest.DiscardUnknown(m) } var xxx_messageInfo_PendingChannelsRequest proto.InternalMessageInfo type PendingChannelsResponse struct { // / The balance in satoshis encumbered in pending channels TotalLimboBalance int64 `protobuf:"varint,1,opt,name=total_limbo_balance,proto3" json:"total_limbo_balance,omitempty"` // / Channels pending opening PendingOpenChannels []*PendingChannelsResponse_PendingOpenChannel `protobuf:"bytes,2,rep,name=pending_open_channels,proto3" json:"pending_open_channels,omitempty"` // / Channels pending closing PendingClosingChannels []*PendingChannelsResponse_ClosedChannel `protobuf:"bytes,3,rep,name=pending_closing_channels,proto3" json:"pending_closing_channels,omitempty"` // / Channels pending force closing PendingForceClosingChannels []*PendingChannelsResponse_ForceClosedChannel `protobuf:"bytes,4,rep,name=pending_force_closing_channels,proto3" json:"pending_force_closing_channels,omitempty"` // / Channels waiting for closing tx to confirm WaitingCloseChannels []*PendingChannelsResponse_WaitingCloseChannel `protobuf:"bytes,5,rep,name=waiting_close_channels,proto3" json:"waiting_close_channels,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingChannelsResponse) Reset() { *m = PendingChannelsResponse{} } func (m *PendingChannelsResponse) String() string { return proto.CompactTextString(m) } func (*PendingChannelsResponse) ProtoMessage() {} func (*PendingChannelsResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{58} } func (m *PendingChannelsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingChannelsResponse.Unmarshal(m, b) } func (m *PendingChannelsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingChannelsResponse.Marshal(b, m, deterministic) } func (dst *PendingChannelsResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingChannelsResponse.Merge(dst, src) } func (m *PendingChannelsResponse) XXX_Size() int { return xxx_messageInfo_PendingChannelsResponse.Size(m) } func (m *PendingChannelsResponse) XXX_DiscardUnknown() { xxx_messageInfo_PendingChannelsResponse.DiscardUnknown(m) } var xxx_messageInfo_PendingChannelsResponse proto.InternalMessageInfo func (m *PendingChannelsResponse) GetTotalLimboBalance() int64 { if m != nil { return m.TotalLimboBalance } return 0 } func (m *PendingChannelsResponse) GetPendingOpenChannels() []*PendingChannelsResponse_PendingOpenChannel { if m != nil { return m.PendingOpenChannels } return nil } func (m *PendingChannelsResponse) GetPendingClosingChannels() []*PendingChannelsResponse_ClosedChannel { if m != nil { return m.PendingClosingChannels } return nil } func (m *PendingChannelsResponse) GetPendingForceClosingChannels() []*PendingChannelsResponse_ForceClosedChannel { if m != nil { return m.PendingForceClosingChannels } return nil } func (m *PendingChannelsResponse) GetWaitingCloseChannels() []*PendingChannelsResponse_WaitingCloseChannel { if m != nil { return m.WaitingCloseChannels } return nil } type PendingChannelsResponse_PendingChannel struct { RemoteNodePub string `protobuf:"bytes,1,opt,name=remote_node_pub,proto3" json:"remote_node_pub,omitempty"` ChannelPoint string `protobuf:"bytes,2,opt,name=channel_point,proto3" json:"channel_point,omitempty"` Capacity int64 `protobuf:"varint,3,opt,name=capacity,proto3" json:"capacity,omitempty"` LocalBalance int64 `protobuf:"varint,4,opt,name=local_balance,proto3" json:"local_balance,omitempty"` RemoteBalance int64 `protobuf:"varint,5,opt,name=remote_balance,proto3" json:"remote_balance,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingChannelsResponse_PendingChannel) Reset() { *m = PendingChannelsResponse_PendingChannel{} } func (m *PendingChannelsResponse_PendingChannel) String() string { return proto.CompactTextString(m) } func (*PendingChannelsResponse_PendingChannel) ProtoMessage() {} func (*PendingChannelsResponse_PendingChannel) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{58, 0} } func (m *PendingChannelsResponse_PendingChannel) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingChannelsResponse_PendingChannel.Unmarshal(m, b) } func (m *PendingChannelsResponse_PendingChannel) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingChannelsResponse_PendingChannel.Marshal(b, m, deterministic) } func (dst *PendingChannelsResponse_PendingChannel) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingChannelsResponse_PendingChannel.Merge(dst, src) } func (m *PendingChannelsResponse_PendingChannel) XXX_Size() int { return xxx_messageInfo_PendingChannelsResponse_PendingChannel.Size(m) } func (m *PendingChannelsResponse_PendingChannel) XXX_DiscardUnknown() { xxx_messageInfo_PendingChannelsResponse_PendingChannel.DiscardUnknown(m) } var xxx_messageInfo_PendingChannelsResponse_PendingChannel proto.InternalMessageInfo func (m *PendingChannelsResponse_PendingChannel) GetRemoteNodePub() string { if m != nil { return m.RemoteNodePub } return "" } func (m *PendingChannelsResponse_PendingChannel) GetChannelPoint() string { if m != nil { return m.ChannelPoint } return "" } func (m *PendingChannelsResponse_PendingChannel) GetCapacity() int64 { if m != nil { return m.Capacity } return 0 } func (m *PendingChannelsResponse_PendingChannel) GetLocalBalance() int64 { if m != nil { return m.LocalBalance } return 0 } func (m *PendingChannelsResponse_PendingChannel) GetRemoteBalance() int64 { if m != nil { return m.RemoteBalance } return 0 } type PendingChannelsResponse_PendingOpenChannel struct { // / The pending channel Channel *PendingChannelsResponse_PendingChannel `protobuf:"bytes,1,opt,name=channel,proto3" json:"channel,omitempty"` // / The height at which this channel will be confirmed ConfirmationHeight uint32 `protobuf:"varint,2,opt,name=confirmation_height,proto3" json:"confirmation_height,omitempty"` // * // The amount calculated to be paid in fees for the current set of // commitment transactions. The fee amount is persisted with the channel // in order to allow the fee amount to be removed and recalculated with // each channel state update, including updates that happen after a system // restart. CommitFee int64 `protobuf:"varint,4,opt,name=commit_fee,proto3" json:"commit_fee,omitempty"` // / The weight of the commitment transaction CommitWeight int64 `protobuf:"varint,5,opt,name=commit_weight,proto3" json:"commit_weight,omitempty"` // * // The required number of satoshis per kilo-weight that the requester will // pay at all times, for both the funding transaction and commitment // transaction. This value can later be updated once the channel is open. FeePerKw int64 `protobuf:"varint,6,opt,name=fee_per_kw,proto3" json:"fee_per_kw,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingChannelsResponse_PendingOpenChannel) Reset() { *m = PendingChannelsResponse_PendingOpenChannel{} } func (m *PendingChannelsResponse_PendingOpenChannel) String() string { return proto.CompactTextString(m) } func (*PendingChannelsResponse_PendingOpenChannel) ProtoMessage() {} func (*PendingChannelsResponse_PendingOpenChannel) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{58, 1} } func (m *PendingChannelsResponse_PendingOpenChannel) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingChannelsResponse_PendingOpenChannel.Unmarshal(m, b) } func (m *PendingChannelsResponse_PendingOpenChannel) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingChannelsResponse_PendingOpenChannel.Marshal(b, m, deterministic) } func (dst *PendingChannelsResponse_PendingOpenChannel) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingChannelsResponse_PendingOpenChannel.Merge(dst, src) } func (m *PendingChannelsResponse_PendingOpenChannel) XXX_Size() int { return xxx_messageInfo_PendingChannelsResponse_PendingOpenChannel.Size(m) } func (m *PendingChannelsResponse_PendingOpenChannel) XXX_DiscardUnknown() { xxx_messageInfo_PendingChannelsResponse_PendingOpenChannel.DiscardUnknown(m) } var xxx_messageInfo_PendingChannelsResponse_PendingOpenChannel proto.InternalMessageInfo func (m *PendingChannelsResponse_PendingOpenChannel) GetChannel() *PendingChannelsResponse_PendingChannel { if m != nil { return m.Channel } return nil } func (m *PendingChannelsResponse_PendingOpenChannel) GetConfirmationHeight() uint32 { if m != nil { return m.ConfirmationHeight } return 0 } func (m *PendingChannelsResponse_PendingOpenChannel) GetCommitFee() int64 { if m != nil { return m.CommitFee } return 0 } func (m *PendingChannelsResponse_PendingOpenChannel) GetCommitWeight() int64 { if m != nil { return m.CommitWeight } return 0 } func (m *PendingChannelsResponse_PendingOpenChannel) GetFeePerKw() int64 { if m != nil { return m.FeePerKw } return 0 } type PendingChannelsResponse_WaitingCloseChannel struct { // / The pending channel waiting for closing tx to confirm Channel *PendingChannelsResponse_PendingChannel `protobuf:"bytes,1,opt,name=channel,proto3" json:"channel,omitempty"` // / The balance in satoshis encumbered in this channel LimboBalance int64 `protobuf:"varint,2,opt,name=limbo_balance,proto3" json:"limbo_balance,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingChannelsResponse_WaitingCloseChannel) Reset() { *m = PendingChannelsResponse_WaitingCloseChannel{} } func (m *PendingChannelsResponse_WaitingCloseChannel) String() string { return proto.CompactTextString(m) } func (*PendingChannelsResponse_WaitingCloseChannel) ProtoMessage() {} func (*PendingChannelsResponse_WaitingCloseChannel) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{58, 2} } func (m *PendingChannelsResponse_WaitingCloseChannel) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingChannelsResponse_WaitingCloseChannel.Unmarshal(m, b) } func (m *PendingChannelsResponse_WaitingCloseChannel) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingChannelsResponse_WaitingCloseChannel.Marshal(b, m, deterministic) } func (dst *PendingChannelsResponse_WaitingCloseChannel) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingChannelsResponse_WaitingCloseChannel.Merge(dst, src) } func (m *PendingChannelsResponse_WaitingCloseChannel) XXX_Size() int { return xxx_messageInfo_PendingChannelsResponse_WaitingCloseChannel.Size(m) } func (m *PendingChannelsResponse_WaitingCloseChannel) XXX_DiscardUnknown() { xxx_messageInfo_PendingChannelsResponse_WaitingCloseChannel.DiscardUnknown(m) } var xxx_messageInfo_PendingChannelsResponse_WaitingCloseChannel proto.InternalMessageInfo func (m *PendingChannelsResponse_WaitingCloseChannel) GetChannel() *PendingChannelsResponse_PendingChannel { if m != nil { return m.Channel } return nil } func (m *PendingChannelsResponse_WaitingCloseChannel) GetLimboBalance() int64 { if m != nil { return m.LimboBalance } return 0 } type PendingChannelsResponse_ClosedChannel struct { // / The pending channel to be closed Channel *PendingChannelsResponse_PendingChannel `protobuf:"bytes,1,opt,name=channel,proto3" json:"channel,omitempty"` // / The transaction id of the closing transaction ClosingTxid string `protobuf:"bytes,2,opt,name=closing_txid,proto3" json:"closing_txid,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingChannelsResponse_ClosedChannel) Reset() { *m = PendingChannelsResponse_ClosedChannel{} } func (m *PendingChannelsResponse_ClosedChannel) String() string { return proto.CompactTextString(m) } func (*PendingChannelsResponse_ClosedChannel) ProtoMessage() {} func (*PendingChannelsResponse_ClosedChannel) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{58, 3} } func (m *PendingChannelsResponse_ClosedChannel) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingChannelsResponse_ClosedChannel.Unmarshal(m, b) } func (m *PendingChannelsResponse_ClosedChannel) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingChannelsResponse_ClosedChannel.Marshal(b, m, deterministic) } func (dst *PendingChannelsResponse_ClosedChannel) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingChannelsResponse_ClosedChannel.Merge(dst, src) } func (m *PendingChannelsResponse_ClosedChannel) XXX_Size() int { return xxx_messageInfo_PendingChannelsResponse_ClosedChannel.Size(m) } func (m *PendingChannelsResponse_ClosedChannel) XXX_DiscardUnknown() { xxx_messageInfo_PendingChannelsResponse_ClosedChannel.DiscardUnknown(m) } var xxx_messageInfo_PendingChannelsResponse_ClosedChannel proto.InternalMessageInfo func (m *PendingChannelsResponse_ClosedChannel) GetChannel() *PendingChannelsResponse_PendingChannel { if m != nil { return m.Channel } return nil } func (m *PendingChannelsResponse_ClosedChannel) GetClosingTxid() string { if m != nil { return m.ClosingTxid } return "" } type PendingChannelsResponse_ForceClosedChannel struct { // / The pending channel to be force closed Channel *PendingChannelsResponse_PendingChannel `protobuf:"bytes,1,opt,name=channel,proto3" json:"channel,omitempty"` // / The transaction id of the closing transaction ClosingTxid string `protobuf:"bytes,2,opt,name=closing_txid,proto3" json:"closing_txid,omitempty"` // / The balance in satoshis encumbered in this pending channel LimboBalance int64 `protobuf:"varint,3,opt,name=limbo_balance,proto3" json:"limbo_balance,omitempty"` // / The height at which funds can be sweeped into the wallet MaturityHeight uint32 `protobuf:"varint,4,opt,name=maturity_height,proto3" json:"maturity_height,omitempty"` // // Remaining # of blocks until the commitment output can be swept. // Negative values indicate how many blocks have passed since becoming // mature. BlocksTilMaturity int32 `protobuf:"varint,5,opt,name=blocks_til_maturity,proto3" json:"blocks_til_maturity,omitempty"` // / The total value of funds successfully recovered from this channel RecoveredBalance int64 `protobuf:"varint,6,opt,name=recovered_balance,proto3" json:"recovered_balance,omitempty"` PendingHtlcs []*PendingHTLC `protobuf:"bytes,8,rep,name=pending_htlcs,proto3" json:"pending_htlcs,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PendingChannelsResponse_ForceClosedChannel) Reset() { *m = PendingChannelsResponse_ForceClosedChannel{} } func (m *PendingChannelsResponse_ForceClosedChannel) String() string { return proto.CompactTextString(m) } func (*PendingChannelsResponse_ForceClosedChannel) ProtoMessage() {} func (*PendingChannelsResponse_ForceClosedChannel) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{58, 4} } func (m *PendingChannelsResponse_ForceClosedChannel) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PendingChannelsResponse_ForceClosedChannel.Unmarshal(m, b) } func (m *PendingChannelsResponse_ForceClosedChannel) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PendingChannelsResponse_ForceClosedChannel.Marshal(b, m, deterministic) } func (dst *PendingChannelsResponse_ForceClosedChannel) XXX_Merge(src proto.Message) { xxx_messageInfo_PendingChannelsResponse_ForceClosedChannel.Merge(dst, src) } func (m *PendingChannelsResponse_ForceClosedChannel) XXX_Size() int { return xxx_messageInfo_PendingChannelsResponse_ForceClosedChannel.Size(m) } func (m *PendingChannelsResponse_ForceClosedChannel) XXX_DiscardUnknown() { xxx_messageInfo_PendingChannelsResponse_ForceClosedChannel.DiscardUnknown(m) } var xxx_messageInfo_PendingChannelsResponse_ForceClosedChannel proto.InternalMessageInfo func (m *PendingChannelsResponse_ForceClosedChannel) GetChannel() *PendingChannelsResponse_PendingChannel { if m != nil { return m.Channel } return nil } func (m *PendingChannelsResponse_ForceClosedChannel) GetClosingTxid() string { if m != nil { return m.ClosingTxid } return "" } func (m *PendingChannelsResponse_ForceClosedChannel) GetLimboBalance() int64 { if m != nil { return m.LimboBalance } return 0 } func (m *PendingChannelsResponse_ForceClosedChannel) GetMaturityHeight() uint32 { if m != nil { return m.MaturityHeight } return 0 } func (m *PendingChannelsResponse_ForceClosedChannel) GetBlocksTilMaturity() int32 { if m != nil { return m.BlocksTilMaturity } return 0 } func (m *PendingChannelsResponse_ForceClosedChannel) GetRecoveredBalance() int64 { if m != nil { return m.RecoveredBalance } return 0 } func (m *PendingChannelsResponse_ForceClosedChannel) GetPendingHtlcs() []*PendingHTLC { if m != nil { return m.PendingHtlcs } return nil } type ChannelEventSubscription struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelEventSubscription) Reset() { *m = ChannelEventSubscription{} } func (m *ChannelEventSubscription) String() string { return proto.CompactTextString(m) } func (*ChannelEventSubscription) ProtoMessage() {} func (*ChannelEventSubscription) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{59} } func (m *ChannelEventSubscription) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelEventSubscription.Unmarshal(m, b) } func (m *ChannelEventSubscription) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelEventSubscription.Marshal(b, m, deterministic) } func (dst *ChannelEventSubscription) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelEventSubscription.Merge(dst, src) } func (m *ChannelEventSubscription) XXX_Size() int { return xxx_messageInfo_ChannelEventSubscription.Size(m) } func (m *ChannelEventSubscription) XXX_DiscardUnknown() { xxx_messageInfo_ChannelEventSubscription.DiscardUnknown(m) } var xxx_messageInfo_ChannelEventSubscription proto.InternalMessageInfo type ChannelEventUpdate struct { // Types that are valid to be assigned to Channel: // *ChannelEventUpdate_OpenChannel // *ChannelEventUpdate_ClosedChannel // *ChannelEventUpdate_ActiveChannel // *ChannelEventUpdate_InactiveChannel Channel isChannelEventUpdate_Channel `protobuf_oneof:"channel"` Type ChannelEventUpdate_UpdateType `protobuf:"varint,5,opt,name=type,proto3,enum=lnrpc.ChannelEventUpdate_UpdateType" json:"type,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelEventUpdate) Reset() { *m = ChannelEventUpdate{} } func (m *ChannelEventUpdate) String() string { return proto.CompactTextString(m) } func (*ChannelEventUpdate) ProtoMessage() {} func (*ChannelEventUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{60} } func (m *ChannelEventUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelEventUpdate.Unmarshal(m, b) } func (m *ChannelEventUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelEventUpdate.Marshal(b, m, deterministic) } func (dst *ChannelEventUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelEventUpdate.Merge(dst, src) } func (m *ChannelEventUpdate) XXX_Size() int { return xxx_messageInfo_ChannelEventUpdate.Size(m) } func (m *ChannelEventUpdate) XXX_DiscardUnknown() { xxx_messageInfo_ChannelEventUpdate.DiscardUnknown(m) } var xxx_messageInfo_ChannelEventUpdate proto.InternalMessageInfo type isChannelEventUpdate_Channel interface { isChannelEventUpdate_Channel() } type ChannelEventUpdate_OpenChannel struct { OpenChannel *Channel `protobuf:"bytes,1,opt,name=open_channel,proto3,oneof"` } type ChannelEventUpdate_ClosedChannel struct { ClosedChannel *ChannelCloseSummary `protobuf:"bytes,2,opt,name=closed_channel,proto3,oneof"` } type ChannelEventUpdate_ActiveChannel struct { ActiveChannel *ChannelPoint `protobuf:"bytes,3,opt,name=active_channel,proto3,oneof"` } type ChannelEventUpdate_InactiveChannel struct { InactiveChannel *ChannelPoint `protobuf:"bytes,4,opt,name=inactive_channel,proto3,oneof"` } func (*ChannelEventUpdate_OpenChannel) isChannelEventUpdate_Channel() {} func (*ChannelEventUpdate_ClosedChannel) isChannelEventUpdate_Channel() {} func (*ChannelEventUpdate_ActiveChannel) isChannelEventUpdate_Channel() {} func (*ChannelEventUpdate_InactiveChannel) isChannelEventUpdate_Channel() {} func (m *ChannelEventUpdate) GetChannel() isChannelEventUpdate_Channel { if m != nil { return m.Channel } return nil } func (m *ChannelEventUpdate) GetOpenChannel() *Channel { if x, ok := m.GetChannel().(*ChannelEventUpdate_OpenChannel); ok { return x.OpenChannel } return nil } func (m *ChannelEventUpdate) GetClosedChannel() *ChannelCloseSummary { if x, ok := m.GetChannel().(*ChannelEventUpdate_ClosedChannel); ok { return x.ClosedChannel } return nil } func (m *ChannelEventUpdate) GetActiveChannel() *ChannelPoint { if x, ok := m.GetChannel().(*ChannelEventUpdate_ActiveChannel); ok { return x.ActiveChannel } return nil } func (m *ChannelEventUpdate) GetInactiveChannel() *ChannelPoint { if x, ok := m.GetChannel().(*ChannelEventUpdate_InactiveChannel); ok { return x.InactiveChannel } return nil } func (m *ChannelEventUpdate) GetType() ChannelEventUpdate_UpdateType { if m != nil { return m.Type } return ChannelEventUpdate_OPEN_CHANNEL } // XXX_OneofFuncs is for the internal use of the proto package. func (*ChannelEventUpdate) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _ChannelEventUpdate_OneofMarshaler, _ChannelEventUpdate_OneofUnmarshaler, _ChannelEventUpdate_OneofSizer, []interface{}{ (*ChannelEventUpdate_OpenChannel)(nil), (*ChannelEventUpdate_ClosedChannel)(nil), (*ChannelEventUpdate_ActiveChannel)(nil), (*ChannelEventUpdate_InactiveChannel)(nil), } } func _ChannelEventUpdate_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { m := msg.(*ChannelEventUpdate) // channel switch x := m.Channel.(type) { case *ChannelEventUpdate_OpenChannel: b.EncodeVarint(1<<3 | proto.WireBytes) if err := b.EncodeMessage(x.OpenChannel); err != nil { return err } case *ChannelEventUpdate_ClosedChannel: b.EncodeVarint(2<<3 | proto.WireBytes) if err := b.EncodeMessage(x.ClosedChannel); err != nil { return err } case *ChannelEventUpdate_ActiveChannel: b.EncodeVarint(3<<3 | proto.WireBytes) if err := b.EncodeMessage(x.ActiveChannel); err != nil { return err } case *ChannelEventUpdate_InactiveChannel: b.EncodeVarint(4<<3 | proto.WireBytes) if err := b.EncodeMessage(x.InactiveChannel); err != nil { return err } case nil: default: return fmt.Errorf("ChannelEventUpdate.Channel has unexpected type %T", x) } return nil } func _ChannelEventUpdate_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { m := msg.(*ChannelEventUpdate) switch tag { case 1: // channel.open_channel if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(Channel) err := b.DecodeMessage(msg) m.Channel = &ChannelEventUpdate_OpenChannel{msg} return true, err case 2: // channel.closed_channel if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(ChannelCloseSummary) err := b.DecodeMessage(msg) m.Channel = &ChannelEventUpdate_ClosedChannel{msg} return true, err case 3: // channel.active_channel if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(ChannelPoint) err := b.DecodeMessage(msg) m.Channel = &ChannelEventUpdate_ActiveChannel{msg} return true, err case 4: // channel.inactive_channel if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(ChannelPoint) err := b.DecodeMessage(msg) m.Channel = &ChannelEventUpdate_InactiveChannel{msg} return true, err default: return false, nil } } func _ChannelEventUpdate_OneofSizer(msg proto.Message) (n int) { m := msg.(*ChannelEventUpdate) // channel switch x := m.Channel.(type) { case *ChannelEventUpdate_OpenChannel: s := proto.Size(x.OpenChannel) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case *ChannelEventUpdate_ClosedChannel: s := proto.Size(x.ClosedChannel) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case *ChannelEventUpdate_ActiveChannel: s := proto.Size(x.ActiveChannel) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case *ChannelEventUpdate_InactiveChannel: s := proto.Size(x.InactiveChannel) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) } return n } type WalletBalanceRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *WalletBalanceRequest) Reset() { *m = WalletBalanceRequest{} } func (m *WalletBalanceRequest) String() string { return proto.CompactTextString(m) } func (*WalletBalanceRequest) ProtoMessage() {} func (*WalletBalanceRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{61} } func (m *WalletBalanceRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_WalletBalanceRequest.Unmarshal(m, b) } func (m *WalletBalanceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_WalletBalanceRequest.Marshal(b, m, deterministic) } func (dst *WalletBalanceRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_WalletBalanceRequest.Merge(dst, src) } func (m *WalletBalanceRequest) XXX_Size() int { return xxx_messageInfo_WalletBalanceRequest.Size(m) } func (m *WalletBalanceRequest) XXX_DiscardUnknown() { xxx_messageInfo_WalletBalanceRequest.DiscardUnknown(m) } var xxx_messageInfo_WalletBalanceRequest proto.InternalMessageInfo type WalletBalanceResponse struct { // / The balance of the wallet TotalBalance int64 `protobuf:"varint,1,opt,name=total_balance,proto3" json:"total_balance,omitempty"` // / The confirmed balance of a wallet(with >= 1 confirmations) ConfirmedBalance int64 `protobuf:"varint,2,opt,name=confirmed_balance,proto3" json:"confirmed_balance,omitempty"` // / The unconfirmed balance of a wallet(with 0 confirmations) UnconfirmedBalance int64 `protobuf:"varint,3,opt,name=unconfirmed_balance,proto3" json:"unconfirmed_balance,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *WalletBalanceResponse) Reset() { *m = WalletBalanceResponse{} } func (m *WalletBalanceResponse) String() string { return proto.CompactTextString(m) } func (*WalletBalanceResponse) ProtoMessage() {} func (*WalletBalanceResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{62} } func (m *WalletBalanceResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_WalletBalanceResponse.Unmarshal(m, b) } func (m *WalletBalanceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_WalletBalanceResponse.Marshal(b, m, deterministic) } func (dst *WalletBalanceResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_WalletBalanceResponse.Merge(dst, src) } func (m *WalletBalanceResponse) XXX_Size() int { return xxx_messageInfo_WalletBalanceResponse.Size(m) } func (m *WalletBalanceResponse) XXX_DiscardUnknown() { xxx_messageInfo_WalletBalanceResponse.DiscardUnknown(m) } var xxx_messageInfo_WalletBalanceResponse proto.InternalMessageInfo func (m *WalletBalanceResponse) GetTotalBalance() int64 { if m != nil { return m.TotalBalance } return 0 } func (m *WalletBalanceResponse) GetConfirmedBalance() int64 { if m != nil { return m.ConfirmedBalance } return 0 } func (m *WalletBalanceResponse) GetUnconfirmedBalance() int64 { if m != nil { return m.UnconfirmedBalance } return 0 } type ChannelBalanceRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelBalanceRequest) Reset() { *m = ChannelBalanceRequest{} } func (m *ChannelBalanceRequest) String() string { return proto.CompactTextString(m) } func (*ChannelBalanceRequest) ProtoMessage() {} func (*ChannelBalanceRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{63} } func (m *ChannelBalanceRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelBalanceRequest.Unmarshal(m, b) } func (m *ChannelBalanceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelBalanceRequest.Marshal(b, m, deterministic) } func (dst *ChannelBalanceRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelBalanceRequest.Merge(dst, src) } func (m *ChannelBalanceRequest) XXX_Size() int { return xxx_messageInfo_ChannelBalanceRequest.Size(m) } func (m *ChannelBalanceRequest) XXX_DiscardUnknown() { xxx_messageInfo_ChannelBalanceRequest.DiscardUnknown(m) } var xxx_messageInfo_ChannelBalanceRequest proto.InternalMessageInfo type ChannelBalanceResponse struct { // / Sum of channels balances denominated in satoshis Balance int64 `protobuf:"varint,1,opt,name=balance,proto3" json:"balance,omitempty"` // / Sum of channels pending balances denominated in satoshis PendingOpenBalance int64 `protobuf:"varint,2,opt,name=pending_open_balance,proto3" json:"pending_open_balance,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelBalanceResponse) Reset() { *m = ChannelBalanceResponse{} } func (m *ChannelBalanceResponse) String() string { return proto.CompactTextString(m) } func (*ChannelBalanceResponse) ProtoMessage() {} func (*ChannelBalanceResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{64} } func (m *ChannelBalanceResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelBalanceResponse.Unmarshal(m, b) } func (m *ChannelBalanceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelBalanceResponse.Marshal(b, m, deterministic) } func (dst *ChannelBalanceResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelBalanceResponse.Merge(dst, src) } func (m *ChannelBalanceResponse) XXX_Size() int { return xxx_messageInfo_ChannelBalanceResponse.Size(m) } func (m *ChannelBalanceResponse) XXX_DiscardUnknown() { xxx_messageInfo_ChannelBalanceResponse.DiscardUnknown(m) } var xxx_messageInfo_ChannelBalanceResponse proto.InternalMessageInfo func (m *ChannelBalanceResponse) GetBalance() int64 { if m != nil { return m.Balance } return 0 } func (m *ChannelBalanceResponse) GetPendingOpenBalance() int64 { if m != nil { return m.PendingOpenBalance } return 0 } type QueryRoutesRequest struct { // / The 33-byte hex-encoded public key for the payment destination PubKey string `protobuf:"bytes,1,opt,name=pub_key,json=pubKey,proto3" json:"pub_key,omitempty"` // / The amount to send expressed in satoshis Amt int64 `protobuf:"varint,2,opt,name=amt,proto3" json:"amt,omitempty"` // / The max number of routes to return. NumRoutes int32 `protobuf:"varint,3,opt,name=num_routes,json=numRoutes,proto3" json:"num_routes,omitempty"` // / An optional CLTV delta from the current height that should be used for the timelock of the final hop FinalCltvDelta int32 `protobuf:"varint,4,opt,name=final_cltv_delta,json=finalCltvDelta,proto3" json:"final_cltv_delta,omitempty"` // * // The maximum number of satoshis that will be paid as a fee of the payment. // This value can be represented either as a percentage of the amount being // sent, or as a fixed amount of the maximum fee the user is willing the pay to // send the payment. FeeLimit *FeeLimit `protobuf:"bytes,5,opt,name=fee_limit,json=feeLimit,proto3" json:"fee_limit,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *QueryRoutesRequest) Reset() { *m = QueryRoutesRequest{} } func (m *QueryRoutesRequest) String() string { return proto.CompactTextString(m) } func (*QueryRoutesRequest) ProtoMessage() {} func (*QueryRoutesRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{65} } func (m *QueryRoutesRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_QueryRoutesRequest.Unmarshal(m, b) } func (m *QueryRoutesRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_QueryRoutesRequest.Marshal(b, m, deterministic) } func (dst *QueryRoutesRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_QueryRoutesRequest.Merge(dst, src) } func (m *QueryRoutesRequest) XXX_Size() int { return xxx_messageInfo_QueryRoutesRequest.Size(m) } func (m *QueryRoutesRequest) XXX_DiscardUnknown() { xxx_messageInfo_QueryRoutesRequest.DiscardUnknown(m) } var xxx_messageInfo_QueryRoutesRequest proto.InternalMessageInfo func (m *QueryRoutesRequest) GetPubKey() string { if m != nil { return m.PubKey } return "" } func (m *QueryRoutesRequest) GetAmt() int64 { if m != nil { return m.Amt } return 0 } func (m *QueryRoutesRequest) GetNumRoutes() int32 { if m != nil { return m.NumRoutes } return 0 } func (m *QueryRoutesRequest) GetFinalCltvDelta() int32 { if m != nil { return m.FinalCltvDelta } return 0 } func (m *QueryRoutesRequest) GetFeeLimit() *FeeLimit { if m != nil { return m.FeeLimit } return nil } type QueryRoutesResponse struct { Routes []*Route `protobuf:"bytes,1,rep,name=routes,proto3" json:"routes,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *QueryRoutesResponse) Reset() { *m = QueryRoutesResponse{} } func (m *QueryRoutesResponse) String() string { return proto.CompactTextString(m) } func (*QueryRoutesResponse) ProtoMessage() {} func (*QueryRoutesResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{66} } func (m *QueryRoutesResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_QueryRoutesResponse.Unmarshal(m, b) } func (m *QueryRoutesResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_QueryRoutesResponse.Marshal(b, m, deterministic) } func (dst *QueryRoutesResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_QueryRoutesResponse.Merge(dst, src) } func (m *QueryRoutesResponse) XXX_Size() int { return xxx_messageInfo_QueryRoutesResponse.Size(m) } func (m *QueryRoutesResponse) XXX_DiscardUnknown() { xxx_messageInfo_QueryRoutesResponse.DiscardUnknown(m) } var xxx_messageInfo_QueryRoutesResponse proto.InternalMessageInfo func (m *QueryRoutesResponse) GetRoutes() []*Route { if m != nil { return m.Routes } return nil } type Hop struct { // * // The unique channel ID for the channel. The first 3 bytes are the block // height, the next 3 the index within the block, and the last 2 bytes are the // output index for the channel. ChanId uint64 `protobuf:"varint,1,opt,name=chan_id,proto3" json:"chan_id,omitempty"` ChanCapacity int64 `protobuf:"varint,2,opt,name=chan_capacity,proto3" json:"chan_capacity,omitempty"` AmtToForward int64 `protobuf:"varint,3,opt,name=amt_to_forward,proto3" json:"amt_to_forward,omitempty"` // Deprecated: Do not use. Fee int64 `protobuf:"varint,4,opt,name=fee,proto3" json:"fee,omitempty"` // Deprecated: Do not use. Expiry uint32 `protobuf:"varint,5,opt,name=expiry,proto3" json:"expiry,omitempty"` AmtToForwardMsat int64 `protobuf:"varint,6,opt,name=amt_to_forward_msat,proto3" json:"amt_to_forward_msat,omitempty"` FeeMsat int64 `protobuf:"varint,7,opt,name=fee_msat,proto3" json:"fee_msat,omitempty"` // * // An optional public key of the hop. If the public key is given, the payment // can be executed without relying on a copy of the channel graph. PubKey string `protobuf:"bytes,8,opt,name=pub_key,proto3" json:"pub_key,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Hop) Reset() { *m = Hop{} } func (m *Hop) String() string { return proto.CompactTextString(m) } func (*Hop) ProtoMessage() {} func (*Hop) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{67} } func (m *Hop) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Hop.Unmarshal(m, b) } func (m *Hop) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Hop.Marshal(b, m, deterministic) } func (dst *Hop) XXX_Merge(src proto.Message) { xxx_messageInfo_Hop.Merge(dst, src) } func (m *Hop) XXX_Size() int { return xxx_messageInfo_Hop.Size(m) } func (m *Hop) XXX_DiscardUnknown() { xxx_messageInfo_Hop.DiscardUnknown(m) } var xxx_messageInfo_Hop proto.InternalMessageInfo func (m *Hop) GetChanId() uint64 { if m != nil { return m.ChanId } return 0 } func (m *Hop) GetChanCapacity() int64 { if m != nil { return m.ChanCapacity } return 0 } // Deprecated: Do not use. func (m *Hop) GetAmtToForward() int64 { if m != nil { return m.AmtToForward } return 0 } // Deprecated: Do not use. func (m *Hop) GetFee() int64 { if m != nil { return m.Fee } return 0 } func (m *Hop) GetExpiry() uint32 { if m != nil { return m.Expiry } return 0 } func (m *Hop) GetAmtToForwardMsat() int64 { if m != nil { return m.AmtToForwardMsat } return 0 } func (m *Hop) GetFeeMsat() int64 { if m != nil { return m.FeeMsat } return 0 } func (m *Hop) GetPubKey() string { if m != nil { return m.PubKey } return "" } // * // A path through the channel graph which runs over one or more channels in // succession. This struct carries all the information required to craft the // Sphinx onion packet, and send the payment along the first hop in the path. A // route is only selected as valid if all the channels have sufficient capacity to // carry the initial payment amount after fees are accounted for. type Route struct { // * // The cumulative (final) time lock across the entire route. This is the CLTV // value that should be extended to the first hop in the route. All other hops // will decrement the time-lock as advertised, leaving enough time for all // hops to wait for or present the payment preimage to complete the payment. TotalTimeLock uint32 `protobuf:"varint,1,opt,name=total_time_lock,proto3" json:"total_time_lock,omitempty"` // * // The sum of the fees paid at each hop within the final route. In the case // of a one-hop payment, this value will be zero as we don't need to pay a fee // it ourself. TotalFees int64 `protobuf:"varint,2,opt,name=total_fees,proto3" json:"total_fees,omitempty"` // Deprecated: Do not use. // * // The total amount of funds required to complete a payment over this route. // This value includes the cumulative fees at each hop. As a result, the HTLC // extended to the first-hop in the route will need to have at least this many // satoshis, otherwise the route will fail at an intermediate node due to an // insufficient amount of fees. TotalAmt int64 `protobuf:"varint,3,opt,name=total_amt,proto3" json:"total_amt,omitempty"` // Deprecated: Do not use. // * // Contains details concerning the specific forwarding details at each hop. Hops []*Hop `protobuf:"bytes,4,rep,name=hops,proto3" json:"hops,omitempty"` // * // The total fees in millisatoshis. TotalFeesMsat int64 `protobuf:"varint,5,opt,name=total_fees_msat,proto3" json:"total_fees_msat,omitempty"` // * // The total amount in millisatoshis. TotalAmtMsat int64 `protobuf:"varint,6,opt,name=total_amt_msat,proto3" json:"total_amt_msat,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Route) Reset() { *m = Route{} } func (m *Route) String() string { return proto.CompactTextString(m) } func (*Route) ProtoMessage() {} func (*Route) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{68} } func (m *Route) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Route.Unmarshal(m, b) } func (m *Route) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Route.Marshal(b, m, deterministic) } func (dst *Route) XXX_Merge(src proto.Message) { xxx_messageInfo_Route.Merge(dst, src) } func (m *Route) XXX_Size() int { return xxx_messageInfo_Route.Size(m) } func (m *Route) XXX_DiscardUnknown() { xxx_messageInfo_Route.DiscardUnknown(m) } var xxx_messageInfo_Route proto.InternalMessageInfo func (m *Route) GetTotalTimeLock() uint32 { if m != nil { return m.TotalTimeLock } return 0 } // Deprecated: Do not use. func (m *Route) GetTotalFees() int64 { if m != nil { return m.TotalFees } return 0 } // Deprecated: Do not use. func (m *Route) GetTotalAmt() int64 { if m != nil { return m.TotalAmt } return 0 } func (m *Route) GetHops() []*Hop { if m != nil { return m.Hops } return nil } func (m *Route) GetTotalFeesMsat() int64 { if m != nil { return m.TotalFeesMsat } return 0 } func (m *Route) GetTotalAmtMsat() int64 { if m != nil { return m.TotalAmtMsat } return 0 } type NodeInfoRequest struct { // / The 33-byte hex-encoded compressed public of the target node PubKey string `protobuf:"bytes,1,opt,name=pub_key,json=pubKey,proto3" json:"pub_key,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NodeInfoRequest) Reset() { *m = NodeInfoRequest{} } func (m *NodeInfoRequest) String() string { return proto.CompactTextString(m) } func (*NodeInfoRequest) ProtoMessage() {} func (*NodeInfoRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{69} } func (m *NodeInfoRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeInfoRequest.Unmarshal(m, b) } func (m *NodeInfoRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NodeInfoRequest.Marshal(b, m, deterministic) } func (dst *NodeInfoRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_NodeInfoRequest.Merge(dst, src) } func (m *NodeInfoRequest) XXX_Size() int { return xxx_messageInfo_NodeInfoRequest.Size(m) } func (m *NodeInfoRequest) XXX_DiscardUnknown() { xxx_messageInfo_NodeInfoRequest.DiscardUnknown(m) } var xxx_messageInfo_NodeInfoRequest proto.InternalMessageInfo func (m *NodeInfoRequest) GetPubKey() string { if m != nil { return m.PubKey } return "" } type NodeInfo struct { // * // An individual vertex/node within the channel graph. A node is // connected to other nodes by one or more channel edges emanating from it. As // the graph is directed, a node will also have an incoming edge attached to // it for each outgoing edge. Node *LightningNode `protobuf:"bytes,1,opt,name=node,proto3" json:"node,omitempty"` NumChannels uint32 `protobuf:"varint,2,opt,name=num_channels,proto3" json:"num_channels,omitempty"` TotalCapacity int64 `protobuf:"varint,3,opt,name=total_capacity,proto3" json:"total_capacity,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NodeInfo) Reset() { *m = NodeInfo{} } func (m *NodeInfo) String() string { return proto.CompactTextString(m) } func (*NodeInfo) ProtoMessage() {} func (*NodeInfo) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{70} } func (m *NodeInfo) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeInfo.Unmarshal(m, b) } func (m *NodeInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NodeInfo.Marshal(b, m, deterministic) } func (dst *NodeInfo) XXX_Merge(src proto.Message) { xxx_messageInfo_NodeInfo.Merge(dst, src) } func (m *NodeInfo) XXX_Size() int { return xxx_messageInfo_NodeInfo.Size(m) } func (m *NodeInfo) XXX_DiscardUnknown() { xxx_messageInfo_NodeInfo.DiscardUnknown(m) } var xxx_messageInfo_NodeInfo proto.InternalMessageInfo func (m *NodeInfo) GetNode() *LightningNode { if m != nil { return m.Node } return nil } func (m *NodeInfo) GetNumChannels() uint32 { if m != nil { return m.NumChannels } return 0 } func (m *NodeInfo) GetTotalCapacity() int64 { if m != nil { return m.TotalCapacity } return 0 } // * // An individual vertex/node within the channel graph. A node is // connected to other nodes by one or more channel edges emanating from it. As the // graph is directed, a node will also have an incoming edge attached to it for // each outgoing edge. type LightningNode struct { LastUpdate uint32 `protobuf:"varint,1,opt,name=last_update,proto3" json:"last_update,omitempty"` PubKey string `protobuf:"bytes,2,opt,name=pub_key,proto3" json:"pub_key,omitempty"` Alias string `protobuf:"bytes,3,opt,name=alias,proto3" json:"alias,omitempty"` Addresses []*NodeAddress `protobuf:"bytes,4,rep,name=addresses,proto3" json:"addresses,omitempty"` Color string `protobuf:"bytes,5,opt,name=color,proto3" json:"color,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *LightningNode) Reset() { *m = LightningNode{} } func (m *LightningNode) String() string { return proto.CompactTextString(m) } func (*LightningNode) ProtoMessage() {} func (*LightningNode) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{71} } func (m *LightningNode) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_LightningNode.Unmarshal(m, b) } func (m *LightningNode) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_LightningNode.Marshal(b, m, deterministic) } func (dst *LightningNode) XXX_Merge(src proto.Message) { xxx_messageInfo_LightningNode.Merge(dst, src) } func (m *LightningNode) XXX_Size() int { return xxx_messageInfo_LightningNode.Size(m) } func (m *LightningNode) XXX_DiscardUnknown() { xxx_messageInfo_LightningNode.DiscardUnknown(m) } var xxx_messageInfo_LightningNode proto.InternalMessageInfo func (m *LightningNode) GetLastUpdate() uint32 { if m != nil { return m.LastUpdate } return 0 } func (m *LightningNode) GetPubKey() string { if m != nil { return m.PubKey } return "" } func (m *LightningNode) GetAlias() string { if m != nil { return m.Alias } return "" } func (m *LightningNode) GetAddresses() []*NodeAddress { if m != nil { return m.Addresses } return nil } func (m *LightningNode) GetColor() string { if m != nil { return m.Color } return "" } type NodeAddress struct { Network string `protobuf:"bytes,1,opt,name=network,proto3" json:"network,omitempty"` Addr string `protobuf:"bytes,2,opt,name=addr,proto3" json:"addr,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NodeAddress) Reset() { *m = NodeAddress{} } func (m *NodeAddress) String() string { return proto.CompactTextString(m) } func (*NodeAddress) ProtoMessage() {} func (*NodeAddress) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{72} } func (m *NodeAddress) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeAddress.Unmarshal(m, b) } func (m *NodeAddress) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NodeAddress.Marshal(b, m, deterministic) } func (dst *NodeAddress) XXX_Merge(src proto.Message) { xxx_messageInfo_NodeAddress.Merge(dst, src) } func (m *NodeAddress) XXX_Size() int { return xxx_messageInfo_NodeAddress.Size(m) } func (m *NodeAddress) XXX_DiscardUnknown() { xxx_messageInfo_NodeAddress.DiscardUnknown(m) } var xxx_messageInfo_NodeAddress proto.InternalMessageInfo func (m *NodeAddress) GetNetwork() string { if m != nil { return m.Network } return "" } func (m *NodeAddress) GetAddr() string { if m != nil { return m.Addr } return "" } type RoutingPolicy struct { TimeLockDelta uint32 `protobuf:"varint,1,opt,name=time_lock_delta,proto3" json:"time_lock_delta,omitempty"` MinHtlc int64 `protobuf:"varint,2,opt,name=min_htlc,proto3" json:"min_htlc,omitempty"` FeeBaseMsat int64 `protobuf:"varint,3,opt,name=fee_base_msat,proto3" json:"fee_base_msat,omitempty"` FeeRateMilliMsat int64 `protobuf:"varint,4,opt,name=fee_rate_milli_msat,proto3" json:"fee_rate_milli_msat,omitempty"` Disabled bool `protobuf:"varint,5,opt,name=disabled,proto3" json:"disabled,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *RoutingPolicy) Reset() { *m = RoutingPolicy{} } func (m *RoutingPolicy) String() string { return proto.CompactTextString(m) } func (*RoutingPolicy) ProtoMessage() {} func (*RoutingPolicy) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{73} } func (m *RoutingPolicy) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_RoutingPolicy.Unmarshal(m, b) } func (m *RoutingPolicy) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_RoutingPolicy.Marshal(b, m, deterministic) } func (dst *RoutingPolicy) XXX_Merge(src proto.Message) { xxx_messageInfo_RoutingPolicy.Merge(dst, src) } func (m *RoutingPolicy) XXX_Size() int { return xxx_messageInfo_RoutingPolicy.Size(m) } func (m *RoutingPolicy) XXX_DiscardUnknown() { xxx_messageInfo_RoutingPolicy.DiscardUnknown(m) } var xxx_messageInfo_RoutingPolicy proto.InternalMessageInfo func (m *RoutingPolicy) GetTimeLockDelta() uint32 { if m != nil { return m.TimeLockDelta } return 0 } func (m *RoutingPolicy) GetMinHtlc() int64 { if m != nil { return m.MinHtlc } return 0 } func (m *RoutingPolicy) GetFeeBaseMsat() int64 { if m != nil { return m.FeeBaseMsat } return 0 } func (m *RoutingPolicy) GetFeeRateMilliMsat() int64 { if m != nil { return m.FeeRateMilliMsat } return 0 } func (m *RoutingPolicy) GetDisabled() bool { if m != nil { return m.Disabled } return false } // * // A fully authenticated channel along with all its unique attributes. // Once an authenticated channel announcement has been processed on the network, // then an instance of ChannelEdgeInfo encapsulating the channels attributes is // stored. The other portions relevant to routing policy of a channel are stored // within a ChannelEdgePolicy for each direction of the channel. type ChannelEdge struct { // * // The unique channel ID for the channel. The first 3 bytes are the block // height, the next 3 the index within the block, and the last 2 bytes are the // output index for the channel. ChannelId uint64 `protobuf:"varint,1,opt,name=channel_id,proto3" json:"channel_id,omitempty"` ChanPoint string `protobuf:"bytes,2,opt,name=chan_point,proto3" json:"chan_point,omitempty"` LastUpdate uint32 `protobuf:"varint,3,opt,name=last_update,proto3" json:"last_update,omitempty"` Node1Pub string `protobuf:"bytes,4,opt,name=node1_pub,proto3" json:"node1_pub,omitempty"` Node2Pub string `protobuf:"bytes,5,opt,name=node2_pub,proto3" json:"node2_pub,omitempty"` Capacity int64 `protobuf:"varint,6,opt,name=capacity,proto3" json:"capacity,omitempty"` Node1Policy *RoutingPolicy `protobuf:"bytes,7,opt,name=node1_policy,proto3" json:"node1_policy,omitempty"` Node2Policy *RoutingPolicy `protobuf:"bytes,8,opt,name=node2_policy,proto3" json:"node2_policy,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelEdge) Reset() { *m = ChannelEdge{} } func (m *ChannelEdge) String() string { return proto.CompactTextString(m) } func (*ChannelEdge) ProtoMessage() {} func (*ChannelEdge) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{74} } func (m *ChannelEdge) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelEdge.Unmarshal(m, b) } func (m *ChannelEdge) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelEdge.Marshal(b, m, deterministic) } func (dst *ChannelEdge) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelEdge.Merge(dst, src) } func (m *ChannelEdge) XXX_Size() int { return xxx_messageInfo_ChannelEdge.Size(m) } func (m *ChannelEdge) XXX_DiscardUnknown() { xxx_messageInfo_ChannelEdge.DiscardUnknown(m) } var xxx_messageInfo_ChannelEdge proto.InternalMessageInfo func (m *ChannelEdge) GetChannelId() uint64 { if m != nil { return m.ChannelId } return 0 } func (m *ChannelEdge) GetChanPoint() string { if m != nil { return m.ChanPoint } return "" } func (m *ChannelEdge) GetLastUpdate() uint32 { if m != nil { return m.LastUpdate } return 0 } func (m *ChannelEdge) GetNode1Pub() string { if m != nil { return m.Node1Pub } return "" } func (m *ChannelEdge) GetNode2Pub() string { if m != nil { return m.Node2Pub } return "" } func (m *ChannelEdge) GetCapacity() int64 { if m != nil { return m.Capacity } return 0 } func (m *ChannelEdge) GetNode1Policy() *RoutingPolicy { if m != nil { return m.Node1Policy } return nil } func (m *ChannelEdge) GetNode2Policy() *RoutingPolicy { if m != nil { return m.Node2Policy } return nil } type ChannelGraphRequest struct { // * // Whether unannounced channels are included in the response or not. If set, // unannounced channels are included. Unannounced channels are both private // channels, and public channels that are not yet announced to the network. IncludeUnannounced bool `protobuf:"varint,1,opt,name=include_unannounced,proto3" json:"include_unannounced,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelGraphRequest) Reset() { *m = ChannelGraphRequest{} } func (m *ChannelGraphRequest) String() string { return proto.CompactTextString(m) } func (*ChannelGraphRequest) ProtoMessage() {} func (*ChannelGraphRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{75} } func (m *ChannelGraphRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelGraphRequest.Unmarshal(m, b) } func (m *ChannelGraphRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelGraphRequest.Marshal(b, m, deterministic) } func (dst *ChannelGraphRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelGraphRequest.Merge(dst, src) } func (m *ChannelGraphRequest) XXX_Size() int { return xxx_messageInfo_ChannelGraphRequest.Size(m) } func (m *ChannelGraphRequest) XXX_DiscardUnknown() { xxx_messageInfo_ChannelGraphRequest.DiscardUnknown(m) } var xxx_messageInfo_ChannelGraphRequest proto.InternalMessageInfo func (m *ChannelGraphRequest) GetIncludeUnannounced() bool { if m != nil { return m.IncludeUnannounced } return false } // / Returns a new instance of the directed channel graph. type ChannelGraph struct { // / The list of `LightningNode`s in this channel graph Nodes []*LightningNode `protobuf:"bytes,1,rep,name=nodes,proto3" json:"nodes,omitempty"` // / The list of `ChannelEdge`s in this channel graph Edges []*ChannelEdge `protobuf:"bytes,2,rep,name=edges,proto3" json:"edges,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelGraph) Reset() { *m = ChannelGraph{} } func (m *ChannelGraph) String() string { return proto.CompactTextString(m) } func (*ChannelGraph) ProtoMessage() {} func (*ChannelGraph) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{76} } func (m *ChannelGraph) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelGraph.Unmarshal(m, b) } func (m *ChannelGraph) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelGraph.Marshal(b, m, deterministic) } func (dst *ChannelGraph) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelGraph.Merge(dst, src) } func (m *ChannelGraph) XXX_Size() int { return xxx_messageInfo_ChannelGraph.Size(m) } func (m *ChannelGraph) XXX_DiscardUnknown() { xxx_messageInfo_ChannelGraph.DiscardUnknown(m) } var xxx_messageInfo_ChannelGraph proto.InternalMessageInfo func (m *ChannelGraph) GetNodes() []*LightningNode { if m != nil { return m.Nodes } return nil } func (m *ChannelGraph) GetEdges() []*ChannelEdge { if m != nil { return m.Edges } return nil } type ChanInfoRequest struct { // * // The unique channel ID for the channel. The first 3 bytes are the block // height, the next 3 the index within the block, and the last 2 bytes are the // output index for the channel. ChanId uint64 `protobuf:"varint,1,opt,name=chan_id,json=chanId,proto3" json:"chan_id,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChanInfoRequest) Reset() { *m = ChanInfoRequest{} } func (m *ChanInfoRequest) String() string { return proto.CompactTextString(m) } func (*ChanInfoRequest) ProtoMessage() {} func (*ChanInfoRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{77} } func (m *ChanInfoRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChanInfoRequest.Unmarshal(m, b) } func (m *ChanInfoRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChanInfoRequest.Marshal(b, m, deterministic) } func (dst *ChanInfoRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ChanInfoRequest.Merge(dst, src) } func (m *ChanInfoRequest) XXX_Size() int { return xxx_messageInfo_ChanInfoRequest.Size(m) } func (m *ChanInfoRequest) XXX_DiscardUnknown() { xxx_messageInfo_ChanInfoRequest.DiscardUnknown(m) } var xxx_messageInfo_ChanInfoRequest proto.InternalMessageInfo func (m *ChanInfoRequest) GetChanId() uint64 { if m != nil { return m.ChanId } return 0 } type NetworkInfoRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NetworkInfoRequest) Reset() { *m = NetworkInfoRequest{} } func (m *NetworkInfoRequest) String() string { return proto.CompactTextString(m) } func (*NetworkInfoRequest) ProtoMessage() {} func (*NetworkInfoRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{78} } func (m *NetworkInfoRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NetworkInfoRequest.Unmarshal(m, b) } func (m *NetworkInfoRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NetworkInfoRequest.Marshal(b, m, deterministic) } func (dst *NetworkInfoRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_NetworkInfoRequest.Merge(dst, src) } func (m *NetworkInfoRequest) XXX_Size() int { return xxx_messageInfo_NetworkInfoRequest.Size(m) } func (m *NetworkInfoRequest) XXX_DiscardUnknown() { xxx_messageInfo_NetworkInfoRequest.DiscardUnknown(m) } var xxx_messageInfo_NetworkInfoRequest proto.InternalMessageInfo type NetworkInfo struct { GraphDiameter uint32 `protobuf:"varint,1,opt,name=graph_diameter,proto3" json:"graph_diameter,omitempty"` AvgOutDegree float64 `protobuf:"fixed64,2,opt,name=avg_out_degree,proto3" json:"avg_out_degree,omitempty"` MaxOutDegree uint32 `protobuf:"varint,3,opt,name=max_out_degree,proto3" json:"max_out_degree,omitempty"` NumNodes uint32 `protobuf:"varint,4,opt,name=num_nodes,proto3" json:"num_nodes,omitempty"` NumChannels uint32 `protobuf:"varint,5,opt,name=num_channels,proto3" json:"num_channels,omitempty"` TotalNetworkCapacity int64 `protobuf:"varint,6,opt,name=total_network_capacity,proto3" json:"total_network_capacity,omitempty"` AvgChannelSize float64 `protobuf:"fixed64,7,opt,name=avg_channel_size,proto3" json:"avg_channel_size,omitempty"` MinChannelSize int64 `protobuf:"varint,8,opt,name=min_channel_size,proto3" json:"min_channel_size,omitempty"` MaxChannelSize int64 `protobuf:"varint,9,opt,name=max_channel_size,proto3" json:"max_channel_size,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NetworkInfo) Reset() { *m = NetworkInfo{} } func (m *NetworkInfo) String() string { return proto.CompactTextString(m) } func (*NetworkInfo) ProtoMessage() {} func (*NetworkInfo) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{79} } func (m *NetworkInfo) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NetworkInfo.Unmarshal(m, b) } func (m *NetworkInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NetworkInfo.Marshal(b, m, deterministic) } func (dst *NetworkInfo) XXX_Merge(src proto.Message) { xxx_messageInfo_NetworkInfo.Merge(dst, src) } func (m *NetworkInfo) XXX_Size() int { return xxx_messageInfo_NetworkInfo.Size(m) } func (m *NetworkInfo) XXX_DiscardUnknown() { xxx_messageInfo_NetworkInfo.DiscardUnknown(m) } var xxx_messageInfo_NetworkInfo proto.InternalMessageInfo func (m *NetworkInfo) GetGraphDiameter() uint32 { if m != nil { return m.GraphDiameter } return 0 } func (m *NetworkInfo) GetAvgOutDegree() float64 { if m != nil { return m.AvgOutDegree } return 0 } func (m *NetworkInfo) GetMaxOutDegree() uint32 { if m != nil { return m.MaxOutDegree } return 0 } func (m *NetworkInfo) GetNumNodes() uint32 { if m != nil { return m.NumNodes } return 0 } func (m *NetworkInfo) GetNumChannels() uint32 { if m != nil { return m.NumChannels } return 0 } func (m *NetworkInfo) GetTotalNetworkCapacity() int64 { if m != nil { return m.TotalNetworkCapacity } return 0 } func (m *NetworkInfo) GetAvgChannelSize() float64 { if m != nil { return m.AvgChannelSize } return 0 } func (m *NetworkInfo) GetMinChannelSize() int64 { if m != nil { return m.MinChannelSize } return 0 } func (m *NetworkInfo) GetMaxChannelSize() int64 { if m != nil { return m.MaxChannelSize } return 0 } type StopRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *StopRequest) Reset() { *m = StopRequest{} } func (m *StopRequest) String() string { return proto.CompactTextString(m) } func (*StopRequest) ProtoMessage() {} func (*StopRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{80} } func (m *StopRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_StopRequest.Unmarshal(m, b) } func (m *StopRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_StopRequest.Marshal(b, m, deterministic) } func (dst *StopRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_StopRequest.Merge(dst, src) } func (m *StopRequest) XXX_Size() int { return xxx_messageInfo_StopRequest.Size(m) } func (m *StopRequest) XXX_DiscardUnknown() { xxx_messageInfo_StopRequest.DiscardUnknown(m) } var xxx_messageInfo_StopRequest proto.InternalMessageInfo type StopResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *StopResponse) Reset() { *m = StopResponse{} } func (m *StopResponse) String() string { return proto.CompactTextString(m) } func (*StopResponse) ProtoMessage() {} func (*StopResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{81} } func (m *StopResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_StopResponse.Unmarshal(m, b) } func (m *StopResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_StopResponse.Marshal(b, m, deterministic) } func (dst *StopResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_StopResponse.Merge(dst, src) } func (m *StopResponse) XXX_Size() int { return xxx_messageInfo_StopResponse.Size(m) } func (m *StopResponse) XXX_DiscardUnknown() { xxx_messageInfo_StopResponse.DiscardUnknown(m) } var xxx_messageInfo_StopResponse proto.InternalMessageInfo type GraphTopologySubscription struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *GraphTopologySubscription) Reset() { *m = GraphTopologySubscription{} } func (m *GraphTopologySubscription) String() string { return proto.CompactTextString(m) } func (*GraphTopologySubscription) ProtoMessage() {} func (*GraphTopologySubscription) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{82} } func (m *GraphTopologySubscription) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GraphTopologySubscription.Unmarshal(m, b) } func (m *GraphTopologySubscription) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_GraphTopologySubscription.Marshal(b, m, deterministic) } func (dst *GraphTopologySubscription) XXX_Merge(src proto.Message) { xxx_messageInfo_GraphTopologySubscription.Merge(dst, src) } func (m *GraphTopologySubscription) XXX_Size() int { return xxx_messageInfo_GraphTopologySubscription.Size(m) } func (m *GraphTopologySubscription) XXX_DiscardUnknown() { xxx_messageInfo_GraphTopologySubscription.DiscardUnknown(m) } var xxx_messageInfo_GraphTopologySubscription proto.InternalMessageInfo type GraphTopologyUpdate struct { NodeUpdates []*NodeUpdate `protobuf:"bytes,1,rep,name=node_updates,json=nodeUpdates,proto3" json:"node_updates,omitempty"` ChannelUpdates []*ChannelEdgeUpdate `protobuf:"bytes,2,rep,name=channel_updates,json=channelUpdates,proto3" json:"channel_updates,omitempty"` ClosedChans []*ClosedChannelUpdate `protobuf:"bytes,3,rep,name=closed_chans,json=closedChans,proto3" json:"closed_chans,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *GraphTopologyUpdate) Reset() { *m = GraphTopologyUpdate{} } func (m *GraphTopologyUpdate) String() string { return proto.CompactTextString(m) } func (*GraphTopologyUpdate) ProtoMessage() {} func (*GraphTopologyUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{83} } func (m *GraphTopologyUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GraphTopologyUpdate.Unmarshal(m, b) } func (m *GraphTopologyUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_GraphTopologyUpdate.Marshal(b, m, deterministic) } func (dst *GraphTopologyUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_GraphTopologyUpdate.Merge(dst, src) } func (m *GraphTopologyUpdate) XXX_Size() int { return xxx_messageInfo_GraphTopologyUpdate.Size(m) } func (m *GraphTopologyUpdate) XXX_DiscardUnknown() { xxx_messageInfo_GraphTopologyUpdate.DiscardUnknown(m) } var xxx_messageInfo_GraphTopologyUpdate proto.InternalMessageInfo func (m *GraphTopologyUpdate) GetNodeUpdates() []*NodeUpdate { if m != nil { return m.NodeUpdates } return nil } func (m *GraphTopologyUpdate) GetChannelUpdates() []*ChannelEdgeUpdate { if m != nil { return m.ChannelUpdates } return nil } func (m *GraphTopologyUpdate) GetClosedChans() []*ClosedChannelUpdate { if m != nil { return m.ClosedChans } return nil } type NodeUpdate struct { Addresses []string `protobuf:"bytes,1,rep,name=addresses,proto3" json:"addresses,omitempty"` IdentityKey string `protobuf:"bytes,2,opt,name=identity_key,json=identityKey,proto3" json:"identity_key,omitempty"` GlobalFeatures []byte `protobuf:"bytes,3,opt,name=global_features,json=globalFeatures,proto3" json:"global_features,omitempty"` Alias string `protobuf:"bytes,4,opt,name=alias,proto3" json:"alias,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *NodeUpdate) Reset() { *m = NodeUpdate{} } func (m *NodeUpdate) String() string { return proto.CompactTextString(m) } func (*NodeUpdate) ProtoMessage() {} func (*NodeUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{84} } func (m *NodeUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeUpdate.Unmarshal(m, b) } func (m *NodeUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_NodeUpdate.Marshal(b, m, deterministic) } func (dst *NodeUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_NodeUpdate.Merge(dst, src) } func (m *NodeUpdate) XXX_Size() int { return xxx_messageInfo_NodeUpdate.Size(m) } func (m *NodeUpdate) XXX_DiscardUnknown() { xxx_messageInfo_NodeUpdate.DiscardUnknown(m) } var xxx_messageInfo_NodeUpdate proto.InternalMessageInfo func (m *NodeUpdate) GetAddresses() []string { if m != nil { return m.Addresses } return nil } func (m *NodeUpdate) GetIdentityKey() string { if m != nil { return m.IdentityKey } return "" } func (m *NodeUpdate) GetGlobalFeatures() []byte { if m != nil { return m.GlobalFeatures } return nil } func (m *NodeUpdate) GetAlias() string { if m != nil { return m.Alias } return "" } type ChannelEdgeUpdate struct { // * // The unique channel ID for the channel. The first 3 bytes are the block // height, the next 3 the index within the block, and the last 2 bytes are the // output index for the channel. ChanId uint64 `protobuf:"varint,1,opt,name=chan_id,json=chanId,proto3" json:"chan_id,omitempty"` ChanPoint *ChannelPoint `protobuf:"bytes,2,opt,name=chan_point,json=chanPoint,proto3" json:"chan_point,omitempty"` Capacity int64 `protobuf:"varint,3,opt,name=capacity,proto3" json:"capacity,omitempty"` RoutingPolicy *RoutingPolicy `protobuf:"bytes,4,opt,name=routing_policy,json=routingPolicy,proto3" json:"routing_policy,omitempty"` AdvertisingNode string `protobuf:"bytes,5,opt,name=advertising_node,json=advertisingNode,proto3" json:"advertising_node,omitempty"` ConnectingNode string `protobuf:"bytes,6,opt,name=connecting_node,json=connectingNode,proto3" json:"connecting_node,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelEdgeUpdate) Reset() { *m = ChannelEdgeUpdate{} } func (m *ChannelEdgeUpdate) String() string { return proto.CompactTextString(m) } func (*ChannelEdgeUpdate) ProtoMessage() {} func (*ChannelEdgeUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{85} } func (m *ChannelEdgeUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelEdgeUpdate.Unmarshal(m, b) } func (m *ChannelEdgeUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelEdgeUpdate.Marshal(b, m, deterministic) } func (dst *ChannelEdgeUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelEdgeUpdate.Merge(dst, src) } func (m *ChannelEdgeUpdate) XXX_Size() int { return xxx_messageInfo_ChannelEdgeUpdate.Size(m) } func (m *ChannelEdgeUpdate) XXX_DiscardUnknown() { xxx_messageInfo_ChannelEdgeUpdate.DiscardUnknown(m) } var xxx_messageInfo_ChannelEdgeUpdate proto.InternalMessageInfo func (m *ChannelEdgeUpdate) GetChanId() uint64 { if m != nil { return m.ChanId } return 0 } func (m *ChannelEdgeUpdate) GetChanPoint() *ChannelPoint { if m != nil { return m.ChanPoint } return nil } func (m *ChannelEdgeUpdate) GetCapacity() int64 { if m != nil { return m.Capacity } return 0 } func (m *ChannelEdgeUpdate) GetRoutingPolicy() *RoutingPolicy { if m != nil { return m.RoutingPolicy } return nil } func (m *ChannelEdgeUpdate) GetAdvertisingNode() string { if m != nil { return m.AdvertisingNode } return "" } func (m *ChannelEdgeUpdate) GetConnectingNode() string { if m != nil { return m.ConnectingNode } return "" } type ClosedChannelUpdate struct { // * // The unique channel ID for the channel. The first 3 bytes are the block // height, the next 3 the index within the block, and the last 2 bytes are the // output index for the channel. ChanId uint64 `protobuf:"varint,1,opt,name=chan_id,json=chanId,proto3" json:"chan_id,omitempty"` Capacity int64 `protobuf:"varint,2,opt,name=capacity,proto3" json:"capacity,omitempty"` ClosedHeight uint32 `protobuf:"varint,3,opt,name=closed_height,json=closedHeight,proto3" json:"closed_height,omitempty"` ChanPoint *ChannelPoint `protobuf:"bytes,4,opt,name=chan_point,json=chanPoint,proto3" json:"chan_point,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ClosedChannelUpdate) Reset() { *m = ClosedChannelUpdate{} } func (m *ClosedChannelUpdate) String() string { return proto.CompactTextString(m) } func (*ClosedChannelUpdate) ProtoMessage() {} func (*ClosedChannelUpdate) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{86} } func (m *ClosedChannelUpdate) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ClosedChannelUpdate.Unmarshal(m, b) } func (m *ClosedChannelUpdate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ClosedChannelUpdate.Marshal(b, m, deterministic) } func (dst *ClosedChannelUpdate) XXX_Merge(src proto.Message) { xxx_messageInfo_ClosedChannelUpdate.Merge(dst, src) } func (m *ClosedChannelUpdate) XXX_Size() int { return xxx_messageInfo_ClosedChannelUpdate.Size(m) } func (m *ClosedChannelUpdate) XXX_DiscardUnknown() { xxx_messageInfo_ClosedChannelUpdate.DiscardUnknown(m) } var xxx_messageInfo_ClosedChannelUpdate proto.InternalMessageInfo func (m *ClosedChannelUpdate) GetChanId() uint64 { if m != nil { return m.ChanId } return 0 } func (m *ClosedChannelUpdate) GetCapacity() int64 { if m != nil { return m.Capacity } return 0 } func (m *ClosedChannelUpdate) GetClosedHeight() uint32 { if m != nil { return m.ClosedHeight } return 0 } func (m *ClosedChannelUpdate) GetChanPoint() *ChannelPoint { if m != nil { return m.ChanPoint } return nil } type HopHint struct { // / The public key of the node at the start of the channel. NodeId string `protobuf:"bytes,1,opt,name=node_id,proto3" json:"node_id,omitempty"` // / The unique identifier of the channel. ChanId uint64 `protobuf:"varint,2,opt,name=chan_id,proto3" json:"chan_id,omitempty"` // / The base fee of the channel denominated in millisatoshis. FeeBaseMsat uint32 `protobuf:"varint,3,opt,name=fee_base_msat,proto3" json:"fee_base_msat,omitempty"` // * // The fee rate of the channel for sending one satoshi across it denominated in // millionths of a satoshi. FeeProportionalMillionths uint32 `protobuf:"varint,4,opt,name=fee_proportional_millionths,proto3" json:"fee_proportional_millionths,omitempty"` // / The time-lock delta of the channel. CltvExpiryDelta uint32 `protobuf:"varint,5,opt,name=cltv_expiry_delta,proto3" json:"cltv_expiry_delta,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *HopHint) Reset() { *m = HopHint{} } func (m *HopHint) String() string { return proto.CompactTextString(m) } func (*HopHint) ProtoMessage() {} func (*HopHint) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{87} } func (m *HopHint) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_HopHint.Unmarshal(m, b) } func (m *HopHint) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_HopHint.Marshal(b, m, deterministic) } func (dst *HopHint) XXX_Merge(src proto.Message) { xxx_messageInfo_HopHint.Merge(dst, src) } func (m *HopHint) XXX_Size() int { return xxx_messageInfo_HopHint.Size(m) } func (m *HopHint) XXX_DiscardUnknown() { xxx_messageInfo_HopHint.DiscardUnknown(m) } var xxx_messageInfo_HopHint proto.InternalMessageInfo func (m *HopHint) GetNodeId() string { if m != nil { return m.NodeId } return "" } func (m *HopHint) GetChanId() uint64 { if m != nil { return m.ChanId } return 0 } func (m *HopHint) GetFeeBaseMsat() uint32 { if m != nil { return m.FeeBaseMsat } return 0 } func (m *HopHint) GetFeeProportionalMillionths() uint32 { if m != nil { return m.FeeProportionalMillionths } return 0 } func (m *HopHint) GetCltvExpiryDelta() uint32 { if m != nil { return m.CltvExpiryDelta } return 0 } type RouteHint struct { // * // A list of hop hints that when chained together can assist in reaching a // specific destination. HopHints []*HopHint `protobuf:"bytes,1,rep,name=hop_hints,proto3" json:"hop_hints,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *RouteHint) Reset() { *m = RouteHint{} } func (m *RouteHint) String() string { return proto.CompactTextString(m) } func (*RouteHint) ProtoMessage() {} func (*RouteHint) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{88} } func (m *RouteHint) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_RouteHint.Unmarshal(m, b) } func (m *RouteHint) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_RouteHint.Marshal(b, m, deterministic) } func (dst *RouteHint) XXX_Merge(src proto.Message) { xxx_messageInfo_RouteHint.Merge(dst, src) } func (m *RouteHint) XXX_Size() int { return xxx_messageInfo_RouteHint.Size(m) } func (m *RouteHint) XXX_DiscardUnknown() { xxx_messageInfo_RouteHint.DiscardUnknown(m) } var xxx_messageInfo_RouteHint proto.InternalMessageInfo func (m *RouteHint) GetHopHints() []*HopHint { if m != nil { return m.HopHints } return nil } type Invoice struct { // * // An optional memo to attach along with the invoice. Used for record keeping // purposes for the invoice's creator, and will also be set in the description // field of the encoded payment request if the description_hash field is not // being used. Memo string `protobuf:"bytes,1,opt,name=memo,proto3" json:"memo,omitempty"` // * Deprecated. An optional cryptographic receipt of payment which is not // implemented. Receipt []byte `protobuf:"bytes,2,opt,name=receipt,proto3" json:"receipt,omitempty"` // Deprecated: Do not use. // * // The hex-encoded preimage (32 byte) which will allow settling an incoming // HTLC payable to this preimage RPreimage []byte `protobuf:"bytes,3,opt,name=r_preimage,proto3" json:"r_preimage,omitempty"` // / The hash of the preimage RHash []byte `protobuf:"bytes,4,opt,name=r_hash,proto3" json:"r_hash,omitempty"` // / The value of this invoice in satoshis Value int64 `protobuf:"varint,5,opt,name=value,proto3" json:"value,omitempty"` // / Whether this invoice has been fulfilled Settled bool `protobuf:"varint,6,opt,name=settled,proto3" json:"settled,omitempty"` // Deprecated: Do not use. // / When this invoice was created CreationDate int64 `protobuf:"varint,7,opt,name=creation_date,proto3" json:"creation_date,omitempty"` // / When this invoice was settled SettleDate int64 `protobuf:"varint,8,opt,name=settle_date,proto3" json:"settle_date,omitempty"` // * // A bare-bones invoice for a payment within the Lightning Network. With the // details of the invoice, the sender has all the data necessary to send a // payment to the recipient. PaymentRequest string `protobuf:"bytes,9,opt,name=payment_request,proto3" json:"payment_request,omitempty"` // * // Hash (SHA-256) of a description of the payment. Used if the description of // payment (memo) is too long to naturally fit within the description field // of an encoded payment request. DescriptionHash []byte `protobuf:"bytes,10,opt,name=description_hash,proto3" json:"description_hash,omitempty"` // / Payment request expiry time in seconds. Default is 3600 (1 hour). Expiry int64 `protobuf:"varint,11,opt,name=expiry,proto3" json:"expiry,omitempty"` // / Fallback on-chain address. FallbackAddr string `protobuf:"bytes,12,opt,name=fallback_addr,proto3" json:"fallback_addr,omitempty"` // / Delta to use for the time-lock of the CLTV extended to the final hop. CltvExpiry uint64 `protobuf:"varint,13,opt,name=cltv_expiry,proto3" json:"cltv_expiry,omitempty"` // * // Route hints that can each be individually used to assist in reaching the // invoice's destination. RouteHints []*RouteHint `protobuf:"bytes,14,rep,name=route_hints,proto3" json:"route_hints,omitempty"` // / Whether this invoice should include routing hints for private channels. Private bool `protobuf:"varint,15,opt,name=private,proto3" json:"private,omitempty"` // * // The "add" index of this invoice. Each newly created invoice will increment // this index making it monotonically increasing. Callers to the // SubscribeInvoices call can use this to instantly get notified of all added // invoices with an add_index greater than this one. AddIndex uint64 `protobuf:"varint,16,opt,name=add_index,proto3" json:"add_index,omitempty"` // * // The "settle" index of this invoice. Each newly settled invoice will // increment this index making it monotonically increasing. Callers to the // SubscribeInvoices call can use this to instantly get notified of all // settled invoices with an settle_index greater than this one. SettleIndex uint64 `protobuf:"varint,17,opt,name=settle_index,proto3" json:"settle_index,omitempty"` // / Deprecated, use amt_paid_sat or amt_paid_msat. AmtPaid int64 `protobuf:"varint,18,opt,name=amt_paid,proto3" json:"amt_paid,omitempty"` // Deprecated: Do not use. // * // The amount that was accepted for this invoice, in satoshis. This will ONLY // be set if this invoice has been settled. We provide this field as if the // invoice was created with a zero value, then we need to record what amount // was ultimately accepted. Additionally, it's possible that the sender paid // MORE that was specified in the original invoice. So we'll record that here // as well. AmtPaidSat int64 `protobuf:"varint,19,opt,name=amt_paid_sat,proto3" json:"amt_paid_sat,omitempty"` // * // The amount that was accepted for this invoice, in millisatoshis. This will // ONLY be set if this invoice has been settled. We provide this field as if // the invoice was created with a zero value, then we need to record what // amount was ultimately accepted. Additionally, it's possible that the sender // paid MORE that was specified in the original invoice. So we'll record that // here as well. AmtPaidMsat int64 `protobuf:"varint,20,opt,name=amt_paid_msat,proto3" json:"amt_paid_msat,omitempty"` // * // The state the invoice is in. State Invoice_InvoiceState `protobuf:"varint,21,opt,name=state,proto3,enum=lnrpc.Invoice_InvoiceState" json:"state,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Invoice) Reset() { *m = Invoice{} } func (m *Invoice) String() string { return proto.CompactTextString(m) } func (*Invoice) ProtoMessage() {} func (*Invoice) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{89} } func (m *Invoice) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Invoice.Unmarshal(m, b) } func (m *Invoice) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Invoice.Marshal(b, m, deterministic) } func (dst *Invoice) XXX_Merge(src proto.Message) { xxx_messageInfo_Invoice.Merge(dst, src) } func (m *Invoice) XXX_Size() int { return xxx_messageInfo_Invoice.Size(m) } func (m *Invoice) XXX_DiscardUnknown() { xxx_messageInfo_Invoice.DiscardUnknown(m) } var xxx_messageInfo_Invoice proto.InternalMessageInfo func (m *Invoice) GetMemo() string { if m != nil { return m.Memo } return "" } // Deprecated: Do not use. func (m *Invoice) GetReceipt() []byte { if m != nil { return m.Receipt } return nil } func (m *Invoice) GetRPreimage() []byte { if m != nil { return m.RPreimage } return nil } func (m *Invoice) GetRHash() []byte { if m != nil { return m.RHash } return nil } func (m *Invoice) GetValue() int64 { if m != nil { return m.Value } return 0 } // Deprecated: Do not use. func (m *Invoice) GetSettled() bool { if m != nil { return m.Settled } return false } func (m *Invoice) GetCreationDate() int64 { if m != nil { return m.CreationDate } return 0 } func (m *Invoice) GetSettleDate() int64 { if m != nil { return m.SettleDate } return 0 } func (m *Invoice) GetPaymentRequest() string { if m != nil { return m.PaymentRequest } return "" } func (m *Invoice) GetDescriptionHash() []byte { if m != nil { return m.DescriptionHash } return nil } func (m *Invoice) GetExpiry() int64 { if m != nil { return m.Expiry } return 0 } func (m *Invoice) GetFallbackAddr() string { if m != nil { return m.FallbackAddr } return "" } func (m *Invoice) GetCltvExpiry() uint64 { if m != nil { return m.CltvExpiry } return 0 } func (m *Invoice) GetRouteHints() []*RouteHint { if m != nil { return m.RouteHints } return nil } func (m *Invoice) GetPrivate() bool { if m != nil { return m.Private } return false } func (m *Invoice) GetAddIndex() uint64 { if m != nil { return m.AddIndex } return 0 } func (m *Invoice) GetSettleIndex() uint64 { if m != nil { return m.SettleIndex } return 0 } // Deprecated: Do not use. func (m *Invoice) GetAmtPaid() int64 { if m != nil { return m.AmtPaid } return 0 } func (m *Invoice) GetAmtPaidSat() int64 { if m != nil { return m.AmtPaidSat } return 0 } func (m *Invoice) GetAmtPaidMsat() int64 { if m != nil { return m.AmtPaidMsat } return 0 } func (m *Invoice) GetState() Invoice_InvoiceState { if m != nil { return m.State } return Invoice_OPEN } type AddInvoiceResponse struct { RHash []byte `protobuf:"bytes,1,opt,name=r_hash,proto3" json:"r_hash,omitempty"` // * // A bare-bones invoice for a payment within the Lightning Network. With the // details of the invoice, the sender has all the data necessary to send a // payment to the recipient. PaymentRequest string `protobuf:"bytes,2,opt,name=payment_request,proto3" json:"payment_request,omitempty"` // * // The "add" index of this invoice. Each newly created invoice will increment // this index making it monotonically increasing. Callers to the // SubscribeInvoices call can use this to instantly get notified of all added // invoices with an add_index greater than this one. AddIndex uint64 `protobuf:"varint,16,opt,name=add_index,proto3" json:"add_index,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *AddInvoiceResponse) Reset() { *m = AddInvoiceResponse{} } func (m *AddInvoiceResponse) String() string { return proto.CompactTextString(m) } func (*AddInvoiceResponse) ProtoMessage() {} func (*AddInvoiceResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{90} } func (m *AddInvoiceResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_AddInvoiceResponse.Unmarshal(m, b) } func (m *AddInvoiceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_AddInvoiceResponse.Marshal(b, m, deterministic) } func (dst *AddInvoiceResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_AddInvoiceResponse.Merge(dst, src) } func (m *AddInvoiceResponse) XXX_Size() int { return xxx_messageInfo_AddInvoiceResponse.Size(m) } func (m *AddInvoiceResponse) XXX_DiscardUnknown() { xxx_messageInfo_AddInvoiceResponse.DiscardUnknown(m) } var xxx_messageInfo_AddInvoiceResponse proto.InternalMessageInfo func (m *AddInvoiceResponse) GetRHash() []byte { if m != nil { return m.RHash } return nil } func (m *AddInvoiceResponse) GetPaymentRequest() string { if m != nil { return m.PaymentRequest } return "" } func (m *AddInvoiceResponse) GetAddIndex() uint64 { if m != nil { return m.AddIndex } return 0 } type PaymentHash struct { // * // The hex-encoded payment hash of the invoice to be looked up. The passed // payment hash must be exactly 32 bytes, otherwise an error is returned. RHashStr string `protobuf:"bytes,1,opt,name=r_hash_str,proto3" json:"r_hash_str,omitempty"` // / The payment hash of the invoice to be looked up. RHash []byte `protobuf:"bytes,2,opt,name=r_hash,proto3" json:"r_hash,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PaymentHash) Reset() { *m = PaymentHash{} } func (m *PaymentHash) String() string { return proto.CompactTextString(m) } func (*PaymentHash) ProtoMessage() {} func (*PaymentHash) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{91} } func (m *PaymentHash) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PaymentHash.Unmarshal(m, b) } func (m *PaymentHash) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PaymentHash.Marshal(b, m, deterministic) } func (dst *PaymentHash) XXX_Merge(src proto.Message) { xxx_messageInfo_PaymentHash.Merge(dst, src) } func (m *PaymentHash) XXX_Size() int { return xxx_messageInfo_PaymentHash.Size(m) } func (m *PaymentHash) XXX_DiscardUnknown() { xxx_messageInfo_PaymentHash.DiscardUnknown(m) } var xxx_messageInfo_PaymentHash proto.InternalMessageInfo func (m *PaymentHash) GetRHashStr() string { if m != nil { return m.RHashStr } return "" } func (m *PaymentHash) GetRHash() []byte { if m != nil { return m.RHash } return nil } type ListInvoiceRequest struct { // / If set, only unsettled invoices will be returned in the response. PendingOnly bool `protobuf:"varint,1,opt,name=pending_only,proto3" json:"pending_only,omitempty"` // * // The index of an invoice that will be used as either the start or end of a // query to determine which invoices should be returned in the response. IndexOffset uint64 `protobuf:"varint,4,opt,name=index_offset,proto3" json:"index_offset,omitempty"` // / The max number of invoices to return in the response to this query. NumMaxInvoices uint64 `protobuf:"varint,5,opt,name=num_max_invoices,proto3" json:"num_max_invoices,omitempty"` // * // If set, the invoices returned will result from seeking backwards from the // specified index offset. This can be used to paginate backwards. Reversed bool `protobuf:"varint,6,opt,name=reversed,proto3" json:"reversed,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListInvoiceRequest) Reset() { *m = ListInvoiceRequest{} } func (m *ListInvoiceRequest) String() string { return proto.CompactTextString(m) } func (*ListInvoiceRequest) ProtoMessage() {} func (*ListInvoiceRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{92} } func (m *ListInvoiceRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListInvoiceRequest.Unmarshal(m, b) } func (m *ListInvoiceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListInvoiceRequest.Marshal(b, m, deterministic) } func (dst *ListInvoiceRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ListInvoiceRequest.Merge(dst, src) } func (m *ListInvoiceRequest) XXX_Size() int { return xxx_messageInfo_ListInvoiceRequest.Size(m) } func (m *ListInvoiceRequest) XXX_DiscardUnknown() { xxx_messageInfo_ListInvoiceRequest.DiscardUnknown(m) } var xxx_messageInfo_ListInvoiceRequest proto.InternalMessageInfo func (m *ListInvoiceRequest) GetPendingOnly() bool { if m != nil { return m.PendingOnly } return false } func (m *ListInvoiceRequest) GetIndexOffset() uint64 { if m != nil { return m.IndexOffset } return 0 } func (m *ListInvoiceRequest) GetNumMaxInvoices() uint64 { if m != nil { return m.NumMaxInvoices } return 0 } func (m *ListInvoiceRequest) GetReversed() bool { if m != nil { return m.Reversed } return false } type ListInvoiceResponse struct { // * // A list of invoices from the time slice of the time series specified in the // request. Invoices []*Invoice `protobuf:"bytes,1,rep,name=invoices,proto3" json:"invoices,omitempty"` // * // The index of the last item in the set of returned invoices. This can be used // to seek further, pagination style. LastIndexOffset uint64 `protobuf:"varint,2,opt,name=last_index_offset,proto3" json:"last_index_offset,omitempty"` // * // The index of the last item in the set of returned invoices. This can be used // to seek backwards, pagination style. FirstIndexOffset uint64 `protobuf:"varint,3,opt,name=first_index_offset,proto3" json:"first_index_offset,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListInvoiceResponse) Reset() { *m = ListInvoiceResponse{} } func (m *ListInvoiceResponse) String() string { return proto.CompactTextString(m) } func (*ListInvoiceResponse) ProtoMessage() {} func (*ListInvoiceResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{93} } func (m *ListInvoiceResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListInvoiceResponse.Unmarshal(m, b) } func (m *ListInvoiceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListInvoiceResponse.Marshal(b, m, deterministic) } func (dst *ListInvoiceResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ListInvoiceResponse.Merge(dst, src) } func (m *ListInvoiceResponse) XXX_Size() int { return xxx_messageInfo_ListInvoiceResponse.Size(m) } func (m *ListInvoiceResponse) XXX_DiscardUnknown() { xxx_messageInfo_ListInvoiceResponse.DiscardUnknown(m) } var xxx_messageInfo_ListInvoiceResponse proto.InternalMessageInfo func (m *ListInvoiceResponse) GetInvoices() []*Invoice { if m != nil { return m.Invoices } return nil } func (m *ListInvoiceResponse) GetLastIndexOffset() uint64 { if m != nil { return m.LastIndexOffset } return 0 } func (m *ListInvoiceResponse) GetFirstIndexOffset() uint64 { if m != nil { return m.FirstIndexOffset } return 0 } type InvoiceSubscription struct { // * // If specified (non-zero), then we'll first start by sending out // notifications for all added indexes with an add_index greater than this // value. This allows callers to catch up on any events they missed while they // weren't connected to the streaming RPC. AddIndex uint64 `protobuf:"varint,1,opt,name=add_index,proto3" json:"add_index,omitempty"` // * // If specified (non-zero), then we'll first start by sending out // notifications for all settled indexes with an settle_index greater than // this value. This allows callers to catch up on any events they missed while // they weren't connected to the streaming RPC. SettleIndex uint64 `protobuf:"varint,2,opt,name=settle_index,proto3" json:"settle_index,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *InvoiceSubscription) Reset() { *m = InvoiceSubscription{} } func (m *InvoiceSubscription) String() string { return proto.CompactTextString(m) } func (*InvoiceSubscription) ProtoMessage() {} func (*InvoiceSubscription) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{94} } func (m *InvoiceSubscription) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_InvoiceSubscription.Unmarshal(m, b) } func (m *InvoiceSubscription) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_InvoiceSubscription.Marshal(b, m, deterministic) } func (dst *InvoiceSubscription) XXX_Merge(src proto.Message) { xxx_messageInfo_InvoiceSubscription.Merge(dst, src) } func (m *InvoiceSubscription) XXX_Size() int { return xxx_messageInfo_InvoiceSubscription.Size(m) } func (m *InvoiceSubscription) XXX_DiscardUnknown() { xxx_messageInfo_InvoiceSubscription.DiscardUnknown(m) } var xxx_messageInfo_InvoiceSubscription proto.InternalMessageInfo func (m *InvoiceSubscription) GetAddIndex() uint64 { if m != nil { return m.AddIndex } return 0 } func (m *InvoiceSubscription) GetSettleIndex() uint64 { if m != nil { return m.SettleIndex } return 0 } type Payment struct { // / The payment hash PaymentHash string `protobuf:"bytes,1,opt,name=payment_hash,proto3" json:"payment_hash,omitempty"` // / Deprecated, use value_sat or value_msat. Value int64 `protobuf:"varint,2,opt,name=value,proto3" json:"value,omitempty"` // Deprecated: Do not use. // / The date of this payment CreationDate int64 `protobuf:"varint,3,opt,name=creation_date,proto3" json:"creation_date,omitempty"` // / The path this payment took Path []string `protobuf:"bytes,4,rep,name=path,proto3" json:"path,omitempty"` // / The fee paid for this payment in satoshis Fee int64 `protobuf:"varint,5,opt,name=fee,proto3" json:"fee,omitempty"` // / The payment preimage PaymentPreimage string `protobuf:"bytes,6,opt,name=payment_preimage,proto3" json:"payment_preimage,omitempty"` // / The value of the payment in satoshis ValueSat int64 `protobuf:"varint,7,opt,name=value_sat,proto3" json:"value_sat,omitempty"` // / The value of the payment in milli-satoshis ValueMsat int64 `protobuf:"varint,8,opt,name=value_msat,proto3" json:"value_msat,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *Payment) Reset() { *m = Payment{} } func (m *Payment) String() string { return proto.CompactTextString(m) } func (*Payment) ProtoMessage() {} func (*Payment) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{95} } func (m *Payment) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Payment.Unmarshal(m, b) } func (m *Payment) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_Payment.Marshal(b, m, deterministic) } func (dst *Payment) XXX_Merge(src proto.Message) { xxx_messageInfo_Payment.Merge(dst, src) } func (m *Payment) XXX_Size() int { return xxx_messageInfo_Payment.Size(m) } func (m *Payment) XXX_DiscardUnknown() { xxx_messageInfo_Payment.DiscardUnknown(m) } var xxx_messageInfo_Payment proto.InternalMessageInfo func (m *Payment) GetPaymentHash() string { if m != nil { return m.PaymentHash } return "" } // Deprecated: Do not use. func (m *Payment) GetValue() int64 { if m != nil { return m.Value } return 0 } func (m *Payment) GetCreationDate() int64 { if m != nil { return m.CreationDate } return 0 } func (m *Payment) GetPath() []string { if m != nil { return m.Path } return nil } func (m *Payment) GetFee() int64 { if m != nil { return m.Fee } return 0 } func (m *Payment) GetPaymentPreimage() string { if m != nil { return m.PaymentPreimage } return "" } func (m *Payment) GetValueSat() int64 { if m != nil { return m.ValueSat } return 0 } func (m *Payment) GetValueMsat() int64 { if m != nil { return m.ValueMsat } return 0 } type ListPaymentsRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListPaymentsRequest) Reset() { *m = ListPaymentsRequest{} } func (m *ListPaymentsRequest) String() string { return proto.CompactTextString(m) } func (*ListPaymentsRequest) ProtoMessage() {} func (*ListPaymentsRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{96} } func (m *ListPaymentsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListPaymentsRequest.Unmarshal(m, b) } func (m *ListPaymentsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListPaymentsRequest.Marshal(b, m, deterministic) } func (dst *ListPaymentsRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ListPaymentsRequest.Merge(dst, src) } func (m *ListPaymentsRequest) XXX_Size() int { return xxx_messageInfo_ListPaymentsRequest.Size(m) } func (m *ListPaymentsRequest) XXX_DiscardUnknown() { xxx_messageInfo_ListPaymentsRequest.DiscardUnknown(m) } var xxx_messageInfo_ListPaymentsRequest proto.InternalMessageInfo type ListPaymentsResponse struct { // / The list of payments Payments []*Payment `protobuf:"bytes,1,rep,name=payments,proto3" json:"payments,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ListPaymentsResponse) Reset() { *m = ListPaymentsResponse{} } func (m *ListPaymentsResponse) String() string { return proto.CompactTextString(m) } func (*ListPaymentsResponse) ProtoMessage() {} func (*ListPaymentsResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{97} } func (m *ListPaymentsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListPaymentsResponse.Unmarshal(m, b) } func (m *ListPaymentsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ListPaymentsResponse.Marshal(b, m, deterministic) } func (dst *ListPaymentsResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ListPaymentsResponse.Merge(dst, src) } func (m *ListPaymentsResponse) XXX_Size() int { return xxx_messageInfo_ListPaymentsResponse.Size(m) } func (m *ListPaymentsResponse) XXX_DiscardUnknown() { xxx_messageInfo_ListPaymentsResponse.DiscardUnknown(m) } var xxx_messageInfo_ListPaymentsResponse proto.InternalMessageInfo func (m *ListPaymentsResponse) GetPayments() []*Payment { if m != nil { return m.Payments } return nil } type DeleteAllPaymentsRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *DeleteAllPaymentsRequest) Reset() { *m = DeleteAllPaymentsRequest{} } func (m *DeleteAllPaymentsRequest) String() string { return proto.CompactTextString(m) } func (*DeleteAllPaymentsRequest) ProtoMessage() {} func (*DeleteAllPaymentsRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{98} } func (m *DeleteAllPaymentsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DeleteAllPaymentsRequest.Unmarshal(m, b) } func (m *DeleteAllPaymentsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_DeleteAllPaymentsRequest.Marshal(b, m, deterministic) } func (dst *DeleteAllPaymentsRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_DeleteAllPaymentsRequest.Merge(dst, src) } func (m *DeleteAllPaymentsRequest) XXX_Size() int { return xxx_messageInfo_DeleteAllPaymentsRequest.Size(m) } func (m *DeleteAllPaymentsRequest) XXX_DiscardUnknown() { xxx_messageInfo_DeleteAllPaymentsRequest.DiscardUnknown(m) } var xxx_messageInfo_DeleteAllPaymentsRequest proto.InternalMessageInfo type DeleteAllPaymentsResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *DeleteAllPaymentsResponse) Reset() { *m = DeleteAllPaymentsResponse{} } func (m *DeleteAllPaymentsResponse) String() string { return proto.CompactTextString(m) } func (*DeleteAllPaymentsResponse) ProtoMessage() {} func (*DeleteAllPaymentsResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{99} } func (m *DeleteAllPaymentsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DeleteAllPaymentsResponse.Unmarshal(m, b) } func (m *DeleteAllPaymentsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_DeleteAllPaymentsResponse.Marshal(b, m, deterministic) } func (dst *DeleteAllPaymentsResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_DeleteAllPaymentsResponse.Merge(dst, src) } func (m *DeleteAllPaymentsResponse) XXX_Size() int { return xxx_messageInfo_DeleteAllPaymentsResponse.Size(m) } func (m *DeleteAllPaymentsResponse) XXX_DiscardUnknown() { xxx_messageInfo_DeleteAllPaymentsResponse.DiscardUnknown(m) } var xxx_messageInfo_DeleteAllPaymentsResponse proto.InternalMessageInfo type AbandonChannelRequest struct { ChannelPoint *ChannelPoint `protobuf:"bytes,1,opt,name=channel_point,json=channelPoint,proto3" json:"channel_point,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *AbandonChannelRequest) Reset() { *m = AbandonChannelRequest{} } func (m *AbandonChannelRequest) String() string { return proto.CompactTextString(m) } func (*AbandonChannelRequest) ProtoMessage() {} func (*AbandonChannelRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{100} } func (m *AbandonChannelRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_AbandonChannelRequest.Unmarshal(m, b) } func (m *AbandonChannelRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_AbandonChannelRequest.Marshal(b, m, deterministic) } func (dst *AbandonChannelRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_AbandonChannelRequest.Merge(dst, src) } func (m *AbandonChannelRequest) XXX_Size() int { return xxx_messageInfo_AbandonChannelRequest.Size(m) } func (m *AbandonChannelRequest) XXX_DiscardUnknown() { xxx_messageInfo_AbandonChannelRequest.DiscardUnknown(m) } var xxx_messageInfo_AbandonChannelRequest proto.InternalMessageInfo func (m *AbandonChannelRequest) GetChannelPoint() *ChannelPoint { if m != nil { return m.ChannelPoint } return nil } type AbandonChannelResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *AbandonChannelResponse) Reset() { *m = AbandonChannelResponse{} } func (m *AbandonChannelResponse) String() string { return proto.CompactTextString(m) } func (*AbandonChannelResponse) ProtoMessage() {} func (*AbandonChannelResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{101} } func (m *AbandonChannelResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_AbandonChannelResponse.Unmarshal(m, b) } func (m *AbandonChannelResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_AbandonChannelResponse.Marshal(b, m, deterministic) } func (dst *AbandonChannelResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_AbandonChannelResponse.Merge(dst, src) } func (m *AbandonChannelResponse) XXX_Size() int { return xxx_messageInfo_AbandonChannelResponse.Size(m) } func (m *AbandonChannelResponse) XXX_DiscardUnknown() { xxx_messageInfo_AbandonChannelResponse.DiscardUnknown(m) } var xxx_messageInfo_AbandonChannelResponse proto.InternalMessageInfo type DebugLevelRequest struct { Show bool `protobuf:"varint,1,opt,name=show,proto3" json:"show,omitempty"` LevelSpec string `protobuf:"bytes,2,opt,name=level_spec,json=levelSpec,proto3" json:"level_spec,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *DebugLevelRequest) Reset() { *m = DebugLevelRequest{} } func (m *DebugLevelRequest) String() string { return proto.CompactTextString(m) } func (*DebugLevelRequest) ProtoMessage() {} func (*DebugLevelRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{102} } func (m *DebugLevelRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DebugLevelRequest.Unmarshal(m, b) } func (m *DebugLevelRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_DebugLevelRequest.Marshal(b, m, deterministic) } func (dst *DebugLevelRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_DebugLevelRequest.Merge(dst, src) } func (m *DebugLevelRequest) XXX_Size() int { return xxx_messageInfo_DebugLevelRequest.Size(m) } func (m *DebugLevelRequest) XXX_DiscardUnknown() { xxx_messageInfo_DebugLevelRequest.DiscardUnknown(m) } var xxx_messageInfo_DebugLevelRequest proto.InternalMessageInfo func (m *DebugLevelRequest) GetShow() bool { if m != nil { return m.Show } return false } func (m *DebugLevelRequest) GetLevelSpec() string { if m != nil { return m.LevelSpec } return "" } type DebugLevelResponse struct { SubSystems string `protobuf:"bytes,1,opt,name=sub_systems,proto3" json:"sub_systems,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *DebugLevelResponse) Reset() { *m = DebugLevelResponse{} } func (m *DebugLevelResponse) String() string { return proto.CompactTextString(m) } func (*DebugLevelResponse) ProtoMessage() {} func (*DebugLevelResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{103} } func (m *DebugLevelResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DebugLevelResponse.Unmarshal(m, b) } func (m *DebugLevelResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_DebugLevelResponse.Marshal(b, m, deterministic) } func (dst *DebugLevelResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_DebugLevelResponse.Merge(dst, src) } func (m *DebugLevelResponse) XXX_Size() int { return xxx_messageInfo_DebugLevelResponse.Size(m) } func (m *DebugLevelResponse) XXX_DiscardUnknown() { xxx_messageInfo_DebugLevelResponse.DiscardUnknown(m) } var xxx_messageInfo_DebugLevelResponse proto.InternalMessageInfo func (m *DebugLevelResponse) GetSubSystems() string { if m != nil { return m.SubSystems } return "" } type PayReqString struct { // / The payment request string to be decoded PayReq string `protobuf:"bytes,1,opt,name=pay_req,json=payReq,proto3" json:"pay_req,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PayReqString) Reset() { *m = PayReqString{} } func (m *PayReqString) String() string { return proto.CompactTextString(m) } func (*PayReqString) ProtoMessage() {} func (*PayReqString) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{104} } func (m *PayReqString) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PayReqString.Unmarshal(m, b) } func (m *PayReqString) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PayReqString.Marshal(b, m, deterministic) } func (dst *PayReqString) XXX_Merge(src proto.Message) { xxx_messageInfo_PayReqString.Merge(dst, src) } func (m *PayReqString) XXX_Size() int { return xxx_messageInfo_PayReqString.Size(m) } func (m *PayReqString) XXX_DiscardUnknown() { xxx_messageInfo_PayReqString.DiscardUnknown(m) } var xxx_messageInfo_PayReqString proto.InternalMessageInfo func (m *PayReqString) GetPayReq() string { if m != nil { return m.PayReq } return "" } type PayReq struct { Destination string `protobuf:"bytes,1,opt,name=destination,proto3" json:"destination,omitempty"` PaymentHash string `protobuf:"bytes,2,opt,name=payment_hash,proto3" json:"payment_hash,omitempty"` NumSatoshis int64 `protobuf:"varint,3,opt,name=num_satoshis,proto3" json:"num_satoshis,omitempty"` Timestamp int64 `protobuf:"varint,4,opt,name=timestamp,proto3" json:"timestamp,omitempty"` Expiry int64 `protobuf:"varint,5,opt,name=expiry,proto3" json:"expiry,omitempty"` Description string `protobuf:"bytes,6,opt,name=description,proto3" json:"description,omitempty"` DescriptionHash string `protobuf:"bytes,7,opt,name=description_hash,proto3" json:"description_hash,omitempty"` FallbackAddr string `protobuf:"bytes,8,opt,name=fallback_addr,proto3" json:"fallback_addr,omitempty"` CltvExpiry int64 `protobuf:"varint,9,opt,name=cltv_expiry,proto3" json:"cltv_expiry,omitempty"` RouteHints []*RouteHint `protobuf:"bytes,10,rep,name=route_hints,proto3" json:"route_hints,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PayReq) Reset() { *m = PayReq{} } func (m *PayReq) String() string { return proto.CompactTextString(m) } func (*PayReq) ProtoMessage() {} func (*PayReq) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{105} } func (m *PayReq) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PayReq.Unmarshal(m, b) } func (m *PayReq) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PayReq.Marshal(b, m, deterministic) } func (dst *PayReq) XXX_Merge(src proto.Message) { xxx_messageInfo_PayReq.Merge(dst, src) } func (m *PayReq) XXX_Size() int { return xxx_messageInfo_PayReq.Size(m) } func (m *PayReq) XXX_DiscardUnknown() { xxx_messageInfo_PayReq.DiscardUnknown(m) } var xxx_messageInfo_PayReq proto.InternalMessageInfo func (m *PayReq) GetDestination() string { if m != nil { return m.Destination } return "" } func (m *PayReq) GetPaymentHash() string { if m != nil { return m.PaymentHash } return "" } func (m *PayReq) GetNumSatoshis() int64 { if m != nil { return m.NumSatoshis } return 0 } func (m *PayReq) GetTimestamp() int64 { if m != nil { return m.Timestamp } return 0 } func (m *PayReq) GetExpiry() int64 { if m != nil { return m.Expiry } return 0 } func (m *PayReq) GetDescription() string { if m != nil { return m.Description } return "" } func (m *PayReq) GetDescriptionHash() string { if m != nil { return m.DescriptionHash } return "" } func (m *PayReq) GetFallbackAddr() string { if m != nil { return m.FallbackAddr } return "" } func (m *PayReq) GetCltvExpiry() int64 { if m != nil { return m.CltvExpiry } return 0 } func (m *PayReq) GetRouteHints() []*RouteHint { if m != nil { return m.RouteHints } return nil } type FeeReportRequest struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *FeeReportRequest) Reset() { *m = FeeReportRequest{} } func (m *FeeReportRequest) String() string { return proto.CompactTextString(m) } func (*FeeReportRequest) ProtoMessage() {} func (*FeeReportRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{106} } func (m *FeeReportRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_FeeReportRequest.Unmarshal(m, b) } func (m *FeeReportRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_FeeReportRequest.Marshal(b, m, deterministic) } func (dst *FeeReportRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_FeeReportRequest.Merge(dst, src) } func (m *FeeReportRequest) XXX_Size() int { return xxx_messageInfo_FeeReportRequest.Size(m) } func (m *FeeReportRequest) XXX_DiscardUnknown() { xxx_messageInfo_FeeReportRequest.DiscardUnknown(m) } var xxx_messageInfo_FeeReportRequest proto.InternalMessageInfo type ChannelFeeReport struct { // / The channel that this fee report belongs to. ChanPoint string `protobuf:"bytes,1,opt,name=chan_point,json=channel_point,proto3" json:"chan_point,omitempty"` // / The base fee charged regardless of the number of milli-satoshis sent. BaseFeeMsat int64 `protobuf:"varint,2,opt,name=base_fee_msat,proto3" json:"base_fee_msat,omitempty"` // / The amount charged per milli-satoshis transferred expressed in millionths of a satoshi. FeePerMil int64 `protobuf:"varint,3,opt,name=fee_per_mil,proto3" json:"fee_per_mil,omitempty"` // / The effective fee rate in milli-satoshis. Computed by dividing the fee_per_mil value by 1 million. FeeRate float64 `protobuf:"fixed64,4,opt,name=fee_rate,proto3" json:"fee_rate,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ChannelFeeReport) Reset() { *m = ChannelFeeReport{} } func (m *ChannelFeeReport) String() string { return proto.CompactTextString(m) } func (*ChannelFeeReport) ProtoMessage() {} func (*ChannelFeeReport) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{107} } func (m *ChannelFeeReport) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ChannelFeeReport.Unmarshal(m, b) } func (m *ChannelFeeReport) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ChannelFeeReport.Marshal(b, m, deterministic) } func (dst *ChannelFeeReport) XXX_Merge(src proto.Message) { xxx_messageInfo_ChannelFeeReport.Merge(dst, src) } func (m *ChannelFeeReport) XXX_Size() int { return xxx_messageInfo_ChannelFeeReport.Size(m) } func (m *ChannelFeeReport) XXX_DiscardUnknown() { xxx_messageInfo_ChannelFeeReport.DiscardUnknown(m) } var xxx_messageInfo_ChannelFeeReport proto.InternalMessageInfo func (m *ChannelFeeReport) GetChanPoint() string { if m != nil { return m.ChanPoint } return "" } func (m *ChannelFeeReport) GetBaseFeeMsat() int64 { if m != nil { return m.BaseFeeMsat } return 0 } func (m *ChannelFeeReport) GetFeePerMil() int64 { if m != nil { return m.FeePerMil } return 0 } func (m *ChannelFeeReport) GetFeeRate() float64 { if m != nil { return m.FeeRate } return 0 } type FeeReportResponse struct { // / An array of channel fee reports which describes the current fee schedule for each channel. ChannelFees []*ChannelFeeReport `protobuf:"bytes,1,rep,name=channel_fees,proto3" json:"channel_fees,omitempty"` // / The total amount of fee revenue (in satoshis) the switch has collected over the past 24 hrs. DayFeeSum uint64 `protobuf:"varint,2,opt,name=day_fee_sum,proto3" json:"day_fee_sum,omitempty"` // / The total amount of fee revenue (in satoshis) the switch has collected over the past 1 week. WeekFeeSum uint64 `protobuf:"varint,3,opt,name=week_fee_sum,proto3" json:"week_fee_sum,omitempty"` // / The total amount of fee revenue (in satoshis) the switch has collected over the past 1 month. MonthFeeSum uint64 `protobuf:"varint,4,opt,name=month_fee_sum,proto3" json:"month_fee_sum,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *FeeReportResponse) Reset() { *m = FeeReportResponse{} } func (m *FeeReportResponse) String() string { return proto.CompactTextString(m) } func (*FeeReportResponse) ProtoMessage() {} func (*FeeReportResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{108} } func (m *FeeReportResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_FeeReportResponse.Unmarshal(m, b) } func (m *FeeReportResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_FeeReportResponse.Marshal(b, m, deterministic) } func (dst *FeeReportResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_FeeReportResponse.Merge(dst, src) } func (m *FeeReportResponse) XXX_Size() int { return xxx_messageInfo_FeeReportResponse.Size(m) } func (m *FeeReportResponse) XXX_DiscardUnknown() { xxx_messageInfo_FeeReportResponse.DiscardUnknown(m) } var xxx_messageInfo_FeeReportResponse proto.InternalMessageInfo func (m *FeeReportResponse) GetChannelFees() []*ChannelFeeReport { if m != nil { return m.ChannelFees } return nil } func (m *FeeReportResponse) GetDayFeeSum() uint64 { if m != nil { return m.DayFeeSum } return 0 } func (m *FeeReportResponse) GetWeekFeeSum() uint64 { if m != nil { return m.WeekFeeSum } return 0 } func (m *FeeReportResponse) GetMonthFeeSum() uint64 { if m != nil { return m.MonthFeeSum } return 0 } type PolicyUpdateRequest struct { // Types that are valid to be assigned to Scope: // *PolicyUpdateRequest_Global // *PolicyUpdateRequest_ChanPoint Scope isPolicyUpdateRequest_Scope `protobuf_oneof:"scope"` // / The base fee charged regardless of the number of milli-satoshis sent. BaseFeeMsat int64 `protobuf:"varint,3,opt,name=base_fee_msat,proto3" json:"base_fee_msat,omitempty"` // / The effective fee rate in milli-satoshis. The precision of this value goes up to 6 decimal places, so 1e-6. FeeRate float64 `protobuf:"fixed64,4,opt,name=fee_rate,proto3" json:"fee_rate,omitempty"` // / The required timelock delta for HTLCs forwarded over the channel. TimeLockDelta uint32 `protobuf:"varint,5,opt,name=time_lock_delta,proto3" json:"time_lock_delta,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PolicyUpdateRequest) Reset() { *m = PolicyUpdateRequest{} } func (m *PolicyUpdateRequest) String() string { return proto.CompactTextString(m) } func (*PolicyUpdateRequest) ProtoMessage() {} func (*PolicyUpdateRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{109} } func (m *PolicyUpdateRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PolicyUpdateRequest.Unmarshal(m, b) } func (m *PolicyUpdateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PolicyUpdateRequest.Marshal(b, m, deterministic) } func (dst *PolicyUpdateRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_PolicyUpdateRequest.Merge(dst, src) } func (m *PolicyUpdateRequest) XXX_Size() int { return xxx_messageInfo_PolicyUpdateRequest.Size(m) } func (m *PolicyUpdateRequest) XXX_DiscardUnknown() { xxx_messageInfo_PolicyUpdateRequest.DiscardUnknown(m) } var xxx_messageInfo_PolicyUpdateRequest proto.InternalMessageInfo type isPolicyUpdateRequest_Scope interface { isPolicyUpdateRequest_Scope() } type PolicyUpdateRequest_Global struct { Global bool `protobuf:"varint,1,opt,name=global,proto3,oneof"` } type PolicyUpdateRequest_ChanPoint struct { ChanPoint *ChannelPoint `protobuf:"bytes,2,opt,name=chan_point,proto3,oneof"` } func (*PolicyUpdateRequest_Global) isPolicyUpdateRequest_Scope() {} func (*PolicyUpdateRequest_ChanPoint) isPolicyUpdateRequest_Scope() {} func (m *PolicyUpdateRequest) GetScope() isPolicyUpdateRequest_Scope { if m != nil { return m.Scope } return nil } func (m *PolicyUpdateRequest) GetGlobal() bool { if x, ok := m.GetScope().(*PolicyUpdateRequest_Global); ok { return x.Global } return false } func (m *PolicyUpdateRequest) GetChanPoint() *ChannelPoint { if x, ok := m.GetScope().(*PolicyUpdateRequest_ChanPoint); ok { return x.ChanPoint } return nil } func (m *PolicyUpdateRequest) GetBaseFeeMsat() int64 { if m != nil { return m.BaseFeeMsat } return 0 } func (m *PolicyUpdateRequest) GetFeeRate() float64 { if m != nil { return m.FeeRate } return 0 } func (m *PolicyUpdateRequest) GetTimeLockDelta() uint32 { if m != nil { return m.TimeLockDelta } return 0 } // XXX_OneofFuncs is for the internal use of the proto package. func (*PolicyUpdateRequest) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _PolicyUpdateRequest_OneofMarshaler, _PolicyUpdateRequest_OneofUnmarshaler, _PolicyUpdateRequest_OneofSizer, []interface{}{ (*PolicyUpdateRequest_Global)(nil), (*PolicyUpdateRequest_ChanPoint)(nil), } } func _PolicyUpdateRequest_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { m := msg.(*PolicyUpdateRequest) // scope switch x := m.Scope.(type) { case *PolicyUpdateRequest_Global: t := uint64(0) if x.Global { t = 1 } b.EncodeVarint(1<<3 | proto.WireVarint) b.EncodeVarint(t) case *PolicyUpdateRequest_ChanPoint: b.EncodeVarint(2<<3 | proto.WireBytes) if err := b.EncodeMessage(x.ChanPoint); err != nil { return err } case nil: default: return fmt.Errorf("PolicyUpdateRequest.Scope has unexpected type %T", x) } return nil } func _PolicyUpdateRequest_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { m := msg.(*PolicyUpdateRequest) switch tag { case 1: // scope.global if wire != proto.WireVarint { return true, proto.ErrInternalBadWireType } x, err := b.DecodeVarint() m.Scope = &PolicyUpdateRequest_Global{x != 0} return true, err case 2: // scope.chan_point if wire != proto.WireBytes { return true, proto.ErrInternalBadWireType } msg := new(ChannelPoint) err := b.DecodeMessage(msg) m.Scope = &PolicyUpdateRequest_ChanPoint{msg} return true, err default: return false, nil } } func _PolicyUpdateRequest_OneofSizer(msg proto.Message) (n int) { m := msg.(*PolicyUpdateRequest) // scope switch x := m.Scope.(type) { case *PolicyUpdateRequest_Global: n += 1 // tag and wire n += 1 case *PolicyUpdateRequest_ChanPoint: s := proto.Size(x.ChanPoint) n += 1 // tag and wire n += proto.SizeVarint(uint64(s)) n += s case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) } return n } type PolicyUpdateResponse struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *PolicyUpdateResponse) Reset() { *m = PolicyUpdateResponse{} } func (m *PolicyUpdateResponse) String() string { return proto.CompactTextString(m) } func (*PolicyUpdateResponse) ProtoMessage() {} func (*PolicyUpdateResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{110} } func (m *PolicyUpdateResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PolicyUpdateResponse.Unmarshal(m, b) } func (m *PolicyUpdateResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_PolicyUpdateResponse.Marshal(b, m, deterministic) } func (dst *PolicyUpdateResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_PolicyUpdateResponse.Merge(dst, src) } func (m *PolicyUpdateResponse) XXX_Size() int { return xxx_messageInfo_PolicyUpdateResponse.Size(m) } func (m *PolicyUpdateResponse) XXX_DiscardUnknown() { xxx_messageInfo_PolicyUpdateResponse.DiscardUnknown(m) } var xxx_messageInfo_PolicyUpdateResponse proto.InternalMessageInfo type ForwardingHistoryRequest struct { // / Start time is the starting point of the forwarding history request. All records beyond this point will be included, respecting the end time, and the index offset. StartTime uint64 `protobuf:"varint,1,opt,name=start_time,proto3" json:"start_time,omitempty"` // / End time is the end point of the forwarding history request. The response will carry at most 50k records between the start time and the end time. The index offset can be used to implement pagination. EndTime uint64 `protobuf:"varint,2,opt,name=end_time,proto3" json:"end_time,omitempty"` // / Index offset is the offset in the time series to start at. As each response can only contain 50k records, callers can use this to skip around within a packed time series. IndexOffset uint32 `protobuf:"varint,3,opt,name=index_offset,proto3" json:"index_offset,omitempty"` // / The max number of events to return in the response to this query. NumMaxEvents uint32 `protobuf:"varint,4,opt,name=num_max_events,proto3" json:"num_max_events,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ForwardingHistoryRequest) Reset() { *m = ForwardingHistoryRequest{} } func (m *ForwardingHistoryRequest) String() string { return proto.CompactTextString(m) } func (*ForwardingHistoryRequest) ProtoMessage() {} func (*ForwardingHistoryRequest) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{111} } func (m *ForwardingHistoryRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ForwardingHistoryRequest.Unmarshal(m, b) } func (m *ForwardingHistoryRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ForwardingHistoryRequest.Marshal(b, m, deterministic) } func (dst *ForwardingHistoryRequest) XXX_Merge(src proto.Message) { xxx_messageInfo_ForwardingHistoryRequest.Merge(dst, src) } func (m *ForwardingHistoryRequest) XXX_Size() int { return xxx_messageInfo_ForwardingHistoryRequest.Size(m) } func (m *ForwardingHistoryRequest) XXX_DiscardUnknown() { xxx_messageInfo_ForwardingHistoryRequest.DiscardUnknown(m) } var xxx_messageInfo_ForwardingHistoryRequest proto.InternalMessageInfo func (m *ForwardingHistoryRequest) GetStartTime() uint64 { if m != nil { return m.StartTime } return 0 } func (m *ForwardingHistoryRequest) GetEndTime() uint64 { if m != nil { return m.EndTime } return 0 } func (m *ForwardingHistoryRequest) GetIndexOffset() uint32 { if m != nil { return m.IndexOffset } return 0 } func (m *ForwardingHistoryRequest) GetNumMaxEvents() uint32 { if m != nil { return m.NumMaxEvents } return 0 } type ForwardingEvent struct { // / Timestamp is the time (unix epoch offset) that this circuit was completed. Timestamp uint64 `protobuf:"varint,1,opt,name=timestamp,proto3" json:"timestamp,omitempty"` // / The incoming channel ID that carried the HTLC that created the circuit. ChanIdIn uint64 `protobuf:"varint,2,opt,name=chan_id_in,proto3" json:"chan_id_in,omitempty"` // / The outgoing channel ID that carried the preimage that completed the circuit. ChanIdOut uint64 `protobuf:"varint,4,opt,name=chan_id_out,proto3" json:"chan_id_out,omitempty"` // / The total amount (in satoshis) of the incoming HTLC that created half the circuit. AmtIn uint64 `protobuf:"varint,5,opt,name=amt_in,proto3" json:"amt_in,omitempty"` // / The total amount (in satoshis) of the outgoing HTLC that created the second half of the circuit. AmtOut uint64 `protobuf:"varint,6,opt,name=amt_out,proto3" json:"amt_out,omitempty"` // / The total fee (in satoshis) that this payment circuit carried. Fee uint64 `protobuf:"varint,7,opt,name=fee,proto3" json:"fee,omitempty"` // / The total fee (in milli-satoshis) that this payment circuit carried. FeeMsat uint64 `protobuf:"varint,8,opt,name=fee_msat,proto3" json:"fee_msat,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ForwardingEvent) Reset() { *m = ForwardingEvent{} } func (m *ForwardingEvent) String() string { return proto.CompactTextString(m) } func (*ForwardingEvent) ProtoMessage() {} func (*ForwardingEvent) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{112} } func (m *ForwardingEvent) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ForwardingEvent.Unmarshal(m, b) } func (m *ForwardingEvent) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ForwardingEvent.Marshal(b, m, deterministic) } func (dst *ForwardingEvent) XXX_Merge(src proto.Message) { xxx_messageInfo_ForwardingEvent.Merge(dst, src) } func (m *ForwardingEvent) XXX_Size() int { return xxx_messageInfo_ForwardingEvent.Size(m) } func (m *ForwardingEvent) XXX_DiscardUnknown() { xxx_messageInfo_ForwardingEvent.DiscardUnknown(m) } var xxx_messageInfo_ForwardingEvent proto.InternalMessageInfo func (m *ForwardingEvent) GetTimestamp() uint64 { if m != nil { return m.Timestamp } return 0 } func (m *ForwardingEvent) GetChanIdIn() uint64 { if m != nil { return m.ChanIdIn } return 0 } func (m *ForwardingEvent) GetChanIdOut() uint64 { if m != nil { return m.ChanIdOut } return 0 } func (m *ForwardingEvent) GetAmtIn() uint64 { if m != nil { return m.AmtIn } return 0 } func (m *ForwardingEvent) GetAmtOut() uint64 { if m != nil { return m.AmtOut } return 0 } func (m *ForwardingEvent) GetFee() uint64 { if m != nil { return m.Fee } return 0 } func (m *ForwardingEvent) GetFeeMsat() uint64 { if m != nil { return m.FeeMsat } return 0 } type ForwardingHistoryResponse struct { // / A list of forwarding events from the time slice of the time series specified in the request. ForwardingEvents []*ForwardingEvent `protobuf:"bytes,1,rep,name=forwarding_events,proto3" json:"forwarding_events,omitempty"` // / The index of the last time in the set of returned forwarding events. Can be used to seek further, pagination style. LastOffsetIndex uint32 `protobuf:"varint,2,opt,name=last_offset_index,proto3" json:"last_offset_index,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` } func (m *ForwardingHistoryResponse) Reset() { *m = ForwardingHistoryResponse{} } func (m *ForwardingHistoryResponse) String() string { return proto.CompactTextString(m) } func (*ForwardingHistoryResponse) ProtoMessage() {} func (*ForwardingHistoryResponse) Descriptor() ([]byte, []int) { return fileDescriptor_rpc_2cfe4ee64b0e338d, []int{113} } func (m *ForwardingHistoryResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ForwardingHistoryResponse.Unmarshal(m, b) } func (m *ForwardingHistoryResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { return xxx_messageInfo_ForwardingHistoryResponse.Marshal(b, m, deterministic) } func (dst *ForwardingHistoryResponse) XXX_Merge(src proto.Message) { xxx_messageInfo_ForwardingHistoryResponse.Merge(dst, src) } func (m *ForwardingHistoryResponse) XXX_Size() int { return xxx_messageInfo_ForwardingHistoryResponse.Size(m) } func (m *ForwardingHistoryResponse) XXX_DiscardUnknown() { xxx_messageInfo_ForwardingHistoryResponse.DiscardUnknown(m) } var xxx_messageInfo_ForwardingHistoryResponse proto.InternalMessageInfo func (m *ForwardingHistoryResponse) GetForwardingEvents() []*ForwardingEvent { if m != nil { return m.ForwardingEvents } return nil } func (m *ForwardingHistoryResponse) GetLastOffsetIndex() uint32 { if m != nil { return m.LastOffsetIndex } return 0 } func init() { proto.RegisterType((*GenSeedRequest)(nil), "lnrpc.GenSeedRequest") proto.RegisterType((*GenSeedResponse)(nil), "lnrpc.GenSeedResponse") proto.RegisterType((*InitWalletRequest)(nil), "lnrpc.InitWalletRequest") proto.RegisterType((*InitWalletResponse)(nil), "lnrpc.InitWalletResponse") proto.RegisterType((*UnlockWalletRequest)(nil), "lnrpc.UnlockWalletRequest") proto.RegisterType((*UnlockWalletResponse)(nil), "lnrpc.UnlockWalletResponse") proto.RegisterType((*ChangePasswordRequest)(nil), "lnrpc.ChangePasswordRequest") proto.RegisterType((*ChangePasswordResponse)(nil), "lnrpc.ChangePasswordResponse") proto.RegisterType((*Utxo)(nil), "lnrpc.Utxo") proto.RegisterType((*Transaction)(nil), "lnrpc.Transaction") proto.RegisterType((*GetTransactionsRequest)(nil), "lnrpc.GetTransactionsRequest") proto.RegisterType((*TransactionDetails)(nil), "lnrpc.TransactionDetails") proto.RegisterType((*FeeLimit)(nil), "lnrpc.FeeLimit") proto.RegisterType((*SendRequest)(nil), "lnrpc.SendRequest") proto.RegisterType((*SendResponse)(nil), "lnrpc.SendResponse") proto.RegisterType((*SendToRouteRequest)(nil), "lnrpc.SendToRouteRequest") proto.RegisterType((*ChannelPoint)(nil), "lnrpc.ChannelPoint") proto.RegisterType((*OutPoint)(nil), "lnrpc.OutPoint") proto.RegisterType((*LightningAddress)(nil), "lnrpc.LightningAddress") proto.RegisterType((*SendManyRequest)(nil), "lnrpc.SendManyRequest") proto.RegisterMapType((map[string]int64)(nil), "lnrpc.SendManyRequest.AddrToAmountEntry") proto.RegisterType((*SendManyResponse)(nil), "lnrpc.SendManyResponse") proto.RegisterType((*SendCoinsRequest)(nil), "lnrpc.SendCoinsRequest") proto.RegisterType((*SendCoinsResponse)(nil), "lnrpc.SendCoinsResponse") proto.RegisterType((*ListUnspentRequest)(nil), "lnrpc.ListUnspentRequest") proto.RegisterType((*ListUnspentResponse)(nil), "lnrpc.ListUnspentResponse") proto.RegisterType((*NewAddressRequest)(nil), "lnrpc.NewAddressRequest") proto.RegisterType((*NewAddressResponse)(nil), "lnrpc.NewAddressResponse") proto.RegisterType((*SignMessageRequest)(nil), "lnrpc.SignMessageRequest") proto.RegisterType((*SignMessageResponse)(nil), "lnrpc.SignMessageResponse") proto.RegisterType((*VerifyMessageRequest)(nil), "lnrpc.VerifyMessageRequest") proto.RegisterType((*VerifyMessageResponse)(nil), "lnrpc.VerifyMessageResponse") proto.RegisterType((*ConnectPeerRequest)(nil), "lnrpc.ConnectPeerRequest") proto.RegisterType((*ConnectPeerResponse)(nil), "lnrpc.ConnectPeerResponse") proto.RegisterType((*DisconnectPeerRequest)(nil), "lnrpc.DisconnectPeerRequest") proto.RegisterType((*DisconnectPeerResponse)(nil), "lnrpc.DisconnectPeerResponse") proto.RegisterType((*HTLC)(nil), "lnrpc.HTLC") proto.RegisterType((*Channel)(nil), "lnrpc.Channel") proto.RegisterType((*ListChannelsRequest)(nil), "lnrpc.ListChannelsRequest") proto.RegisterType((*ListChannelsResponse)(nil), "lnrpc.ListChannelsResponse") proto.RegisterType((*ChannelCloseSummary)(nil), "lnrpc.ChannelCloseSummary") proto.RegisterType((*ClosedChannelsRequest)(nil), "lnrpc.ClosedChannelsRequest") proto.RegisterType((*ClosedChannelsResponse)(nil), "lnrpc.ClosedChannelsResponse") proto.RegisterType((*Peer)(nil), "lnrpc.Peer") proto.RegisterType((*ListPeersRequest)(nil), "lnrpc.ListPeersRequest") proto.RegisterType((*ListPeersResponse)(nil), "lnrpc.ListPeersResponse") proto.RegisterType((*GetInfoRequest)(nil), "lnrpc.GetInfoRequest") proto.RegisterType((*GetInfoResponse)(nil), "lnrpc.GetInfoResponse") proto.RegisterType((*Chain)(nil), "lnrpc.Chain") proto.RegisterType((*ConfirmationUpdate)(nil), "lnrpc.ConfirmationUpdate") proto.RegisterType((*ChannelOpenUpdate)(nil), "lnrpc.ChannelOpenUpdate") proto.RegisterType((*ChannelCloseUpdate)(nil), "lnrpc.ChannelCloseUpdate") proto.RegisterType((*CloseChannelRequest)(nil), "lnrpc.CloseChannelRequest") proto.RegisterType((*CloseStatusUpdate)(nil), "lnrpc.CloseStatusUpdate") proto.RegisterType((*PendingUpdate)(nil), "lnrpc.PendingUpdate") proto.RegisterType((*OpenChannelRequest)(nil), "lnrpc.OpenChannelRequest") proto.RegisterType((*OpenStatusUpdate)(nil), "lnrpc.OpenStatusUpdate") proto.RegisterType((*PendingHTLC)(nil), "lnrpc.PendingHTLC") proto.RegisterType((*PendingChannelsRequest)(nil), "lnrpc.PendingChannelsRequest") proto.RegisterType((*PendingChannelsResponse)(nil), "lnrpc.PendingChannelsResponse") proto.RegisterType((*PendingChannelsResponse_PendingChannel)(nil), "lnrpc.PendingChannelsResponse.PendingChannel") proto.RegisterType((*PendingChannelsResponse_PendingOpenChannel)(nil), "lnrpc.PendingChannelsResponse.PendingOpenChannel") proto.RegisterType((*PendingChannelsResponse_WaitingCloseChannel)(nil), "lnrpc.PendingChannelsResponse.WaitingCloseChannel") proto.RegisterType((*PendingChannelsResponse_ClosedChannel)(nil), "lnrpc.PendingChannelsResponse.ClosedChannel") proto.RegisterType((*PendingChannelsResponse_ForceClosedChannel)(nil), "lnrpc.PendingChannelsResponse.ForceClosedChannel") proto.RegisterType((*ChannelEventSubscription)(nil), "lnrpc.ChannelEventSubscription") proto.RegisterType((*ChannelEventUpdate)(nil), "lnrpc.ChannelEventUpdate") proto.RegisterType((*WalletBalanceRequest)(nil), "lnrpc.WalletBalanceRequest") proto.RegisterType((*WalletBalanceResponse)(nil), "lnrpc.WalletBalanceResponse") proto.RegisterType((*ChannelBalanceRequest)(nil), "lnrpc.ChannelBalanceRequest") proto.RegisterType((*ChannelBalanceResponse)(nil), "lnrpc.ChannelBalanceResponse") proto.RegisterType((*QueryRoutesRequest)(nil), "lnrpc.QueryRoutesRequest") proto.RegisterType((*QueryRoutesResponse)(nil), "lnrpc.QueryRoutesResponse") proto.RegisterType((*Hop)(nil), "lnrpc.Hop") proto.RegisterType((*Route)(nil), "lnrpc.Route") proto.RegisterType((*NodeInfoRequest)(nil), "lnrpc.NodeInfoRequest") proto.RegisterType((*NodeInfo)(nil), "lnrpc.NodeInfo") proto.RegisterType((*LightningNode)(nil), "lnrpc.LightningNode") proto.RegisterType((*NodeAddress)(nil), "lnrpc.NodeAddress") proto.RegisterType((*RoutingPolicy)(nil), "lnrpc.RoutingPolicy") proto.RegisterType((*ChannelEdge)(nil), "lnrpc.ChannelEdge") proto.RegisterType((*ChannelGraphRequest)(nil), "lnrpc.ChannelGraphRequest") proto.RegisterType((*ChannelGraph)(nil), "lnrpc.ChannelGraph") proto.RegisterType((*ChanInfoRequest)(nil), "lnrpc.ChanInfoRequest") proto.RegisterType((*NetworkInfoRequest)(nil), "lnrpc.NetworkInfoRequest") proto.RegisterType((*NetworkInfo)(nil), "lnrpc.NetworkInfo") proto.RegisterType((*StopRequest)(nil), "lnrpc.StopRequest") proto.RegisterType((*StopResponse)(nil), "lnrpc.StopResponse") proto.RegisterType((*GraphTopologySubscription)(nil), "lnrpc.GraphTopologySubscription") proto.RegisterType((*GraphTopologyUpdate)(nil), "lnrpc.GraphTopologyUpdate") proto.RegisterType((*NodeUpdate)(nil), "lnrpc.NodeUpdate") proto.RegisterType((*ChannelEdgeUpdate)(nil), "lnrpc.ChannelEdgeUpdate") proto.RegisterType((*ClosedChannelUpdate)(nil), "lnrpc.ClosedChannelUpdate") proto.RegisterType((*HopHint)(nil), "lnrpc.HopHint") proto.RegisterType((*RouteHint)(nil), "lnrpc.RouteHint") proto.RegisterType((*Invoice)(nil), "lnrpc.Invoice") proto.RegisterType((*AddInvoiceResponse)(nil), "lnrpc.AddInvoiceResponse") proto.RegisterType((*PaymentHash)(nil), "lnrpc.PaymentHash") proto.RegisterType((*ListInvoiceRequest)(nil), "lnrpc.ListInvoiceRequest") proto.RegisterType((*ListInvoiceResponse)(nil), "lnrpc.ListInvoiceResponse") proto.RegisterType((*InvoiceSubscription)(nil), "lnrpc.InvoiceSubscription") proto.RegisterType((*Payment)(nil), "lnrpc.Payment") proto.RegisterType((*ListPaymentsRequest)(nil), "lnrpc.ListPaymentsRequest") proto.RegisterType((*ListPaymentsResponse)(nil), "lnrpc.ListPaymentsResponse") proto.RegisterType((*DeleteAllPaymentsRequest)(nil), "lnrpc.DeleteAllPaymentsRequest") proto.RegisterType((*DeleteAllPaymentsResponse)(nil), "lnrpc.DeleteAllPaymentsResponse") proto.RegisterType((*AbandonChannelRequest)(nil), "lnrpc.AbandonChannelRequest") proto.RegisterType((*AbandonChannelResponse)(nil), "lnrpc.AbandonChannelResponse") proto.RegisterType((*DebugLevelRequest)(nil), "lnrpc.DebugLevelRequest") proto.RegisterType((*DebugLevelResponse)(nil), "lnrpc.DebugLevelResponse") proto.RegisterType((*PayReqString)(nil), "lnrpc.PayReqString") proto.RegisterType((*PayReq)(nil), "lnrpc.PayReq") proto.RegisterType((*FeeReportRequest)(nil), "lnrpc.FeeReportRequest") proto.RegisterType((*ChannelFeeReport)(nil), "lnrpc.ChannelFeeReport") proto.RegisterType((*FeeReportResponse)(nil), "lnrpc.FeeReportResponse") proto.RegisterType((*PolicyUpdateRequest)(nil), "lnrpc.PolicyUpdateRequest") proto.RegisterType((*PolicyUpdateResponse)(nil), "lnrpc.PolicyUpdateResponse") proto.RegisterType((*ForwardingHistoryRequest)(nil), "lnrpc.ForwardingHistoryRequest") proto.RegisterType((*ForwardingEvent)(nil), "lnrpc.ForwardingEvent") proto.RegisterType((*ForwardingHistoryResponse)(nil), "lnrpc.ForwardingHistoryResponse") proto.RegisterEnum("lnrpc.AddressType", AddressType_name, AddressType_value) proto.RegisterEnum("lnrpc.ChannelCloseSummary_ClosureType", ChannelCloseSummary_ClosureType_name, ChannelCloseSummary_ClosureType_value) proto.RegisterEnum("lnrpc.ChannelEventUpdate_UpdateType", ChannelEventUpdate_UpdateType_name, ChannelEventUpdate_UpdateType_value) proto.RegisterEnum("lnrpc.Invoice_InvoiceState", Invoice_InvoiceState_name, Invoice_InvoiceState_value) } // Reference imports to suppress errors if they are not otherwise used. var _ context.Context var _ grpc.ClientConn // 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.SupportPackageIsVersion4 // WalletUnlockerClient is the client API for WalletUnlocker service. // // For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. type WalletUnlockerClient interface { // * // GenSeed is the first method that should be used to instantiate a new lnd // instance. This method allows a caller to generate a new aezeed cipher seed // given an optional passphrase. If provided, the passphrase will be necessary // to decrypt the cipherseed to expose the internal wallet seed. // // Once the cipherseed is obtained and verified by the user, the InitWallet // method should be used to commit the newly generated seed, and create the // wallet. GenSeed(ctx context.Context, in *GenSeedRequest, opts ...grpc.CallOption) (*GenSeedResponse, error) // * // InitWallet is used when lnd is starting up for the first time to fully // initialize the daemon and its internal wallet. At the very least a wallet // password must be provided. This will be used to encrypt sensitive material // on disk. // // In the case of a recovery scenario, the user can also specify their aezeed // mnemonic and passphrase. If set, then the daemon will use this prior state // to initialize its internal wallet. // // Alternatively, this can be used along with the GenSeed RPC to obtain a // seed, then present it to the user. Once it has been verified by the user, // the seed can be fed into this RPC in order to commit the new wallet. InitWallet(ctx context.Context, in *InitWalletRequest, opts ...grpc.CallOption) (*InitWalletResponse, error) // * lncli: `unlock` // UnlockWallet is used at startup of lnd to provide a password to unlock // the wallet database. UnlockWallet(ctx context.Context, in *UnlockWalletRequest, opts ...grpc.CallOption) (*UnlockWalletResponse, error) // * lncli: `changepassword` // ChangePassword changes the password of the encrypted wallet. This will // automatically unlock the wallet database if successful. ChangePassword(ctx context.Context, in *ChangePasswordRequest, opts ...grpc.CallOption) (*ChangePasswordResponse, error) } type walletUnlockerClient struct { cc *grpc.ClientConn } func NewWalletUnlockerClient(cc *grpc.ClientConn) WalletUnlockerClient { return &walletUnlockerClient{cc} } func (c *walletUnlockerClient) GenSeed(ctx context.Context, in *GenSeedRequest, opts ...grpc.CallOption) (*GenSeedResponse, error) { out := new(GenSeedResponse) err := c.cc.Invoke(ctx, "/lnrpc.WalletUnlocker/GenSeed", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *walletUnlockerClient) InitWallet(ctx context.Context, in *InitWalletRequest, opts ...grpc.CallOption) (*InitWalletResponse, error) { out := new(InitWalletResponse) err := c.cc.Invoke(ctx, "/lnrpc.WalletUnlocker/InitWallet", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *walletUnlockerClient) UnlockWallet(ctx context.Context, in *UnlockWalletRequest, opts ...grpc.CallOption) (*UnlockWalletResponse, error) { out := new(UnlockWalletResponse) err := c.cc.Invoke(ctx, "/lnrpc.WalletUnlocker/UnlockWallet", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *walletUnlockerClient) ChangePassword(ctx context.Context, in *ChangePasswordRequest, opts ...grpc.CallOption) (*ChangePasswordResponse, error) { out := new(ChangePasswordResponse) err := c.cc.Invoke(ctx, "/lnrpc.WalletUnlocker/ChangePassword", in, out, opts...) if err != nil { return nil, err } return out, nil } // WalletUnlockerServer is the server API for WalletUnlocker service. type WalletUnlockerServer interface { // * // GenSeed is the first method that should be used to instantiate a new lnd // instance. This method allows a caller to generate a new aezeed cipher seed // given an optional passphrase. If provided, the passphrase will be necessary // to decrypt the cipherseed to expose the internal wallet seed. // // Once the cipherseed is obtained and verified by the user, the InitWallet // method should be used to commit the newly generated seed, and create the // wallet. GenSeed(context.Context, *GenSeedRequest) (*GenSeedResponse, error) // * // InitWallet is used when lnd is starting up for the first time to fully // initialize the daemon and its internal wallet. At the very least a wallet // password must be provided. This will be used to encrypt sensitive material // on disk. // // In the case of a recovery scenario, the user can also specify their aezeed // mnemonic and passphrase. If set, then the daemon will use this prior state // to initialize its internal wallet. // // Alternatively, this can be used along with the GenSeed RPC to obtain a // seed, then present it to the user. Once it has been verified by the user, // the seed can be fed into this RPC in order to commit the new wallet. InitWallet(context.Context, *InitWalletRequest) (*InitWalletResponse, error) // * lncli: `unlock` // UnlockWallet is used at startup of lnd to provide a password to unlock // the wallet database. UnlockWallet(context.Context, *UnlockWalletRequest) (*UnlockWalletResponse, error) // * lncli: `changepassword` // ChangePassword changes the password of the encrypted wallet. This will // automatically unlock the wallet database if successful. ChangePassword(context.Context, *ChangePasswordRequest) (*ChangePasswordResponse, error) } func RegisterWalletUnlockerServer(s *grpc.Server, srv WalletUnlockerServer) { s.RegisterService(&_WalletUnlocker_serviceDesc, srv) } func _WalletUnlocker_GenSeed_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(GenSeedRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(WalletUnlockerServer).GenSeed(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.WalletUnlocker/GenSeed", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(WalletUnlockerServer).GenSeed(ctx, req.(*GenSeedRequest)) } return interceptor(ctx, in, info, handler) } func _WalletUnlocker_InitWallet_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(InitWalletRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(WalletUnlockerServer).InitWallet(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.WalletUnlocker/InitWallet", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(WalletUnlockerServer).InitWallet(ctx, req.(*InitWalletRequest)) } return interceptor(ctx, in, info, handler) } func _WalletUnlocker_UnlockWallet_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(UnlockWalletRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(WalletUnlockerServer).UnlockWallet(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.WalletUnlocker/UnlockWallet", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(WalletUnlockerServer).UnlockWallet(ctx, req.(*UnlockWalletRequest)) } return interceptor(ctx, in, info, handler) } func _WalletUnlocker_ChangePassword_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ChangePasswordRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(WalletUnlockerServer).ChangePassword(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.WalletUnlocker/ChangePassword", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(WalletUnlockerServer).ChangePassword(ctx, req.(*ChangePasswordRequest)) } return interceptor(ctx, in, info, handler) } var _WalletUnlocker_serviceDesc = grpc.ServiceDesc{ ServiceName: "lnrpc.WalletUnlocker", HandlerType: (*WalletUnlockerServer)(nil), Methods: []grpc.MethodDesc{ { MethodName: "GenSeed", Handler: _WalletUnlocker_GenSeed_Handler, }, { MethodName: "InitWallet", Handler: _WalletUnlocker_InitWallet_Handler, }, { MethodName: "UnlockWallet", Handler: _WalletUnlocker_UnlockWallet_Handler, }, { MethodName: "ChangePassword", Handler: _WalletUnlocker_ChangePassword_Handler, }, }, Streams: []grpc.StreamDesc{}, Metadata: "rpc.proto", } // LightningClient is the client API for Lightning service. // // For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. type LightningClient interface { // * lncli: `walletbalance` // WalletBalance returns total unspent outputs(confirmed and unconfirmed), all // confirmed unspent outputs and all unconfirmed unspent outputs under control // of the wallet. WalletBalance(ctx context.Context, in *WalletBalanceRequest, opts ...grpc.CallOption) (*WalletBalanceResponse, error) // * lncli: `channelbalance` // ChannelBalance returns the total funds available across all open channels // in satoshis. ChannelBalance(ctx context.Context, in *ChannelBalanceRequest, opts ...grpc.CallOption) (*ChannelBalanceResponse, error) // * lncli: `listchaintxns` // GetTransactions returns a list describing all the known transactions // relevant to the wallet. GetTransactions(ctx context.Context, in *GetTransactionsRequest, opts ...grpc.CallOption) (*TransactionDetails, error) // * lncli: `sendcoins` // SendCoins executes a request to send coins to a particular address. Unlike // SendMany, this RPC call only allows creating a single output at a time. If // neither target_conf, or sat_per_byte are set, then the internal wallet will // consult its fee model to determine a fee for the default confirmation // target. SendCoins(ctx context.Context, in *SendCoinsRequest, opts ...grpc.CallOption) (*SendCoinsResponse, error) // * lncli: `listunspent` // ListUnspent returns a list of all utxos spendable by the wallet with a // number of confirmations between the specified minimum and maximum. ListUnspent(ctx context.Context, in *ListUnspentRequest, opts ...grpc.CallOption) (*ListUnspentResponse, error) // * // SubscribeTransactions creates a uni-directional stream from the server to // the client in which any newly discovered transactions relevant to the // wallet are sent over. SubscribeTransactions(ctx context.Context, in *GetTransactionsRequest, opts ...grpc.CallOption) (Lightning_SubscribeTransactionsClient, error) // * lncli: `sendmany` // SendMany handles a request for a transaction that creates multiple specified // outputs in parallel. If neither target_conf, or sat_per_byte are set, then // the internal wallet will consult its fee model to determine a fee for the // default confirmation target. SendMany(ctx context.Context, in *SendManyRequest, opts ...grpc.CallOption) (*SendManyResponse, error) // * lncli: `newaddress` // NewAddress creates a new address under control of the local wallet. NewAddress(ctx context.Context, in *NewAddressRequest, opts ...grpc.CallOption) (*NewAddressResponse, error) // * lncli: `signmessage` // SignMessage signs a message with this node's private key. The returned // signature string is `zbase32` encoded and pubkey recoverable, meaning that // only the message digest and signature are needed for verification. SignMessage(ctx context.Context, in *SignMessageRequest, opts ...grpc.CallOption) (*SignMessageResponse, error) // * lncli: `verifymessage` // VerifyMessage verifies a signature over a msg. The signature must be // zbase32 encoded and signed by an active node in the resident node's // channel database. In addition to returning the validity of the signature, // VerifyMessage also returns the recovered pubkey from the signature. VerifyMessage(ctx context.Context, in *VerifyMessageRequest, opts ...grpc.CallOption) (*VerifyMessageResponse, error) // * lncli: `connect` // ConnectPeer attempts to establish a connection to a remote peer. This is at // the networking level, and is used for communication between nodes. This is // distinct from establishing a channel with a peer. ConnectPeer(ctx context.Context, in *ConnectPeerRequest, opts ...grpc.CallOption) (*ConnectPeerResponse, error) // * lncli: `disconnect` // DisconnectPeer attempts to disconnect one peer from another identified by a // given pubKey. In the case that we currently have a pending or active channel // with the target peer, then this action will be not be allowed. DisconnectPeer(ctx context.Context, in *DisconnectPeerRequest, opts ...grpc.CallOption) (*DisconnectPeerResponse, error) // * lncli: `listpeers` // ListPeers returns a verbose listing of all currently active peers. ListPeers(ctx context.Context, in *ListPeersRequest, opts ...grpc.CallOption) (*ListPeersResponse, error) // * lncli: `getinfo` // GetInfo returns general information concerning the lightning node including // it's identity pubkey, alias, the chains it is connected to, and information // concerning the number of open+pending channels. GetInfo(ctx context.Context, in *GetInfoRequest, opts ...grpc.CallOption) (*GetInfoResponse, error) // * lncli: `pendingchannels` // PendingChannels returns a list of all the channels that are currently // considered "pending". A channel is pending if it has finished the funding // workflow and is waiting for confirmations for the funding txn, or is in the // process of closure, either initiated cooperatively or non-cooperatively. PendingChannels(ctx context.Context, in *PendingChannelsRequest, opts ...grpc.CallOption) (*PendingChannelsResponse, error) // * lncli: `listchannels` // ListChannels returns a description of all the open channels that this node // is a participant in. ListChannels(ctx context.Context, in *ListChannelsRequest, opts ...grpc.CallOption) (*ListChannelsResponse, error) // * lncli: `subscribechannelevents` // SubscribeChannelEvents creates a uni-directional stream from the server to // the client in which any updates relevant to the state of the channels are // sent over. Events include new active channels, inactive channels, and closed // channels. SubscribeChannelEvents(ctx context.Context, in *ChannelEventSubscription, opts ...grpc.CallOption) (Lightning_SubscribeChannelEventsClient, error) // * lncli: `closedchannels` // ClosedChannels returns a description of all the closed channels that // this node was a participant in. ClosedChannels(ctx context.Context, in *ClosedChannelsRequest, opts ...grpc.CallOption) (*ClosedChannelsResponse, error) // * // OpenChannelSync is a synchronous version of the OpenChannel RPC call. This // call is meant to be consumed by clients to the REST proxy. As with all // other sync calls, all byte slices are intended to be populated as hex // encoded strings. OpenChannelSync(ctx context.Context, in *OpenChannelRequest, opts ...grpc.CallOption) (*ChannelPoint, error) // * lncli: `openchannel` // OpenChannel attempts to open a singly funded channel specified in the // request to a remote peer. Users are able to specify a target number of // blocks that the funding transaction should be confirmed in, or a manual fee // rate to us for the funding transaction. If neither are specified, then a // lax block confirmation target is used. OpenChannel(ctx context.Context, in *OpenChannelRequest, opts ...grpc.CallOption) (Lightning_OpenChannelClient, error) // * lncli: `closechannel` // CloseChannel attempts to close an active channel identified by its channel // outpoint (ChannelPoint). The actions of this method can additionally be // augmented to attempt a force close after a timeout period in the case of an // inactive peer. If a non-force close (cooperative closure) is requested, // then the user can specify either a target number of blocks until the // closure transaction is confirmed, or a manual fee rate. If neither are // specified, then a default lax, block confirmation target is used. CloseChannel(ctx context.Context, in *CloseChannelRequest, opts ...grpc.CallOption) (Lightning_CloseChannelClient, error) // * lncli: `abandonchannel` // AbandonChannel removes all channel state from the database except for a // close summary. This method can be used to get rid of permanently unusable // channels due to bugs fixed in newer versions of lnd. Only available // when in debug builds of lnd. AbandonChannel(ctx context.Context, in *AbandonChannelRequest, opts ...grpc.CallOption) (*AbandonChannelResponse, error) // * lncli: `sendpayment` // SendPayment dispatches a bi-directional streaming RPC for sending payments // through the Lightning Network. A single RPC invocation creates a persistent // bi-directional stream allowing clients to rapidly send payments through the // Lightning Network with a single persistent connection. SendPayment(ctx context.Context, opts ...grpc.CallOption) (Lightning_SendPaymentClient, error) // * // SendPaymentSync is the synchronous non-streaming version of SendPayment. // This RPC is intended to be consumed by clients of the REST proxy. // Additionally, this RPC expects the destination's public key and the payment // hash (if any) to be encoded as hex strings. SendPaymentSync(ctx context.Context, in *SendRequest, opts ...grpc.CallOption) (*SendResponse, error) // * lncli: `sendtoroute` // SendToRoute is a bi-directional streaming RPC for sending payment through // the Lightning Network. This method differs from SendPayment in that it // allows users to specify a full route manually. This can be used for things // like rebalancing, and atomic swaps. SendToRoute(ctx context.Context, opts ...grpc.CallOption) (Lightning_SendToRouteClient, error) // * // SendToRouteSync is a synchronous version of SendToRoute. It Will block // until the payment either fails or succeeds. SendToRouteSync(ctx context.Context, in *SendToRouteRequest, opts ...grpc.CallOption) (*SendResponse, error) // * lncli: `addinvoice` // AddInvoice attempts to add a new invoice to the invoice database. Any // duplicated invoices are rejected, therefore all invoices *must* have a // unique payment preimage. AddInvoice(ctx context.Context, in *Invoice, opts ...grpc.CallOption) (*AddInvoiceResponse, error) // * lncli: `listinvoices` // ListInvoices returns a list of all the invoices currently stored within the // database. Any active debug invoices are ignored. It has full support for // paginated responses, allowing users to query for specific invoices through // their add_index. This can be done by using either the first_index_offset or // last_index_offset fields included in the response as the index_offset of the // next request. By default, the first 100 invoices created will be returned. // Backwards pagination is also supported through the Reversed flag. ListInvoices(ctx context.Context, in *ListInvoiceRequest, opts ...grpc.CallOption) (*ListInvoiceResponse, error) // * lncli: `lookupinvoice` // LookupInvoice attempts to look up an invoice according to its payment hash. // The passed payment hash *must* be exactly 32 bytes, if not, an error is // returned. LookupInvoice(ctx context.Context, in *PaymentHash, opts ...grpc.CallOption) (*Invoice, error) // * // SubscribeInvoices returns a uni-directional stream (server -> client) for // notifying the client of newly added/settled invoices. The caller can // optionally specify the add_index and/or the settle_index. If the add_index // is specified, then we'll first start by sending add invoice events for all // invoices with an add_index greater than the specified value. If the // settle_index is specified, the next, we'll send out all settle events for // invoices with a settle_index greater than the specified value. One or both // of these fields can be set. If no fields are set, then we'll only send out // the latest add/settle events. SubscribeInvoices(ctx context.Context, in *InvoiceSubscription, opts ...grpc.CallOption) (Lightning_SubscribeInvoicesClient, error) // * lncli: `decodepayreq` // DecodePayReq takes an encoded payment request string and attempts to decode // it, returning a full description of the conditions encoded within the // payment request. DecodePayReq(ctx context.Context, in *PayReqString, opts ...grpc.CallOption) (*PayReq, error) // * lncli: `listpayments` // ListPayments returns a list of all outgoing payments. ListPayments(ctx context.Context, in *ListPaymentsRequest, opts ...grpc.CallOption) (*ListPaymentsResponse, error) // * // DeleteAllPayments deletes all outgoing payments from DB. DeleteAllPayments(ctx context.Context, in *DeleteAllPaymentsRequest, opts ...grpc.CallOption) (*DeleteAllPaymentsResponse, error) // * lncli: `describegraph` // DescribeGraph returns a description of the latest graph state from the // point of view of the node. The graph information is partitioned into two // components: all the nodes/vertexes, and all the edges that connect the // vertexes themselves. As this is a directed graph, the edges also contain // the node directional specific routing policy which includes: the time lock // delta, fee information, etc. DescribeGraph(ctx context.Context, in *ChannelGraphRequest, opts ...grpc.CallOption) (*ChannelGraph, error) // * lncli: `getchaninfo` // GetChanInfo returns the latest authenticated network announcement for the // given channel identified by its channel ID: an 8-byte integer which // uniquely identifies the location of transaction's funding output within the // blockchain. GetChanInfo(ctx context.Context, in *ChanInfoRequest, opts ...grpc.CallOption) (*ChannelEdge, error) // * lncli: `getnodeinfo` // GetNodeInfo returns the latest advertised, aggregated, and authenticated // channel information for the specified node identified by its public key. GetNodeInfo(ctx context.Context, in *NodeInfoRequest, opts ...grpc.CallOption) (*NodeInfo, error) // * lncli: `queryroutes` // QueryRoutes attempts to query the daemon's Channel Router for a possible // route to a target destination capable of carrying a specific amount of // satoshis. The retuned route contains the full details required to craft and // send an HTLC, also including the necessary information that should be // present within the Sphinx packet encapsulated within the HTLC. QueryRoutes(ctx context.Context, in *QueryRoutesRequest, opts ...grpc.CallOption) (*QueryRoutesResponse, error) // * lncli: `getnetworkinfo` // GetNetworkInfo returns some basic stats about the known channel graph from // the point of view of the node. GetNetworkInfo(ctx context.Context, in *NetworkInfoRequest, opts ...grpc.CallOption) (*NetworkInfo, error) // * lncli: `stop` // StopDaemon will send a shutdown request to the interrupt handler, triggering // a graceful shutdown of the daemon. StopDaemon(ctx context.Context, in *StopRequest, opts ...grpc.CallOption) (*StopResponse, error) // * // SubscribeChannelGraph launches a streaming RPC that allows the caller to // receive notifications upon any changes to the channel graph topology from // the point of view of the responding node. Events notified include: new // nodes coming online, nodes updating their authenticated attributes, new // channels being advertised, updates in the routing policy for a directional // channel edge, and when channels are closed on-chain. SubscribeChannelGraph(ctx context.Context, in *GraphTopologySubscription, opts ...grpc.CallOption) (Lightning_SubscribeChannelGraphClient, error) // * lncli: `debuglevel` // DebugLevel allows a caller to programmatically set the logging verbosity of // lnd. The logging can be targeted according to a coarse daemon-wide logging // level, or in a granular fashion to specify the logging for a target // sub-system. DebugLevel(ctx context.Context, in *DebugLevelRequest, opts ...grpc.CallOption) (*DebugLevelResponse, error) // * lncli: `feereport` // FeeReport allows the caller to obtain a report detailing the current fee // schedule enforced by the node globally for each channel. FeeReport(ctx context.Context, in *FeeReportRequest, opts ...grpc.CallOption) (*FeeReportResponse, error) // * lncli: `updatechanpolicy` // UpdateChannelPolicy allows the caller to update the fee schedule and // channel policies for all channels globally, or a particular channel. UpdateChannelPolicy(ctx context.Context, in *PolicyUpdateRequest, opts ...grpc.CallOption) (*PolicyUpdateResponse, error) // * lncli: `fwdinghistory` // ForwardingHistory allows the caller to query the htlcswitch for a record of // all HTLC's forwarded within the target time range, and integer offset // within that time range. If no time-range is specified, then the first chunk // of the past 24 hrs of forwarding history are returned. // // A list of forwarding events are returned. The size of each forwarding event // is 40 bytes, and the max message size able to be returned in gRPC is 4 MiB. // As a result each message can only contain 50k entries. Each response has // the index offset of the last entry. The index offset can be provided to the // request to allow the caller to skip a series of records. ForwardingHistory(ctx context.Context, in *ForwardingHistoryRequest, opts ...grpc.CallOption) (*ForwardingHistoryResponse, error) } type lightningClient struct { cc *grpc.ClientConn } func NewLightningClient(cc *grpc.ClientConn) LightningClient { return &lightningClient{cc} } func (c *lightningClient) WalletBalance(ctx context.Context, in *WalletBalanceRequest, opts ...grpc.CallOption) (*WalletBalanceResponse, error) { out := new(WalletBalanceResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/WalletBalance", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ChannelBalance(ctx context.Context, in *ChannelBalanceRequest, opts ...grpc.CallOption) (*ChannelBalanceResponse, error) { out := new(ChannelBalanceResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ChannelBalance", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) GetTransactions(ctx context.Context, in *GetTransactionsRequest, opts ...grpc.CallOption) (*TransactionDetails, error) { out := new(TransactionDetails) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/GetTransactions", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SendCoins(ctx context.Context, in *SendCoinsRequest, opts ...grpc.CallOption) (*SendCoinsResponse, error) { out := new(SendCoinsResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/SendCoins", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ListUnspent(ctx context.Context, in *ListUnspentRequest, opts ...grpc.CallOption) (*ListUnspentResponse, error) { out := new(ListUnspentResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ListUnspent", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SubscribeTransactions(ctx context.Context, in *GetTransactionsRequest, opts ...grpc.CallOption) (Lightning_SubscribeTransactionsClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[0], "/lnrpc.Lightning/SubscribeTransactions", opts...) if err != nil { return nil, err } x := &lightningSubscribeTransactionsClient{stream} if err := x.ClientStream.SendMsg(in); err != nil { return nil, err } if err := x.ClientStream.CloseSend(); err != nil { return nil, err } return x, nil } type Lightning_SubscribeTransactionsClient interface { Recv() (*Transaction, error) grpc.ClientStream } type lightningSubscribeTransactionsClient struct { grpc.ClientStream } func (x *lightningSubscribeTransactionsClient) Recv() (*Transaction, error) { m := new(Transaction) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) SendMany(ctx context.Context, in *SendManyRequest, opts ...grpc.CallOption) (*SendManyResponse, error) { out := new(SendManyResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/SendMany", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) NewAddress(ctx context.Context, in *NewAddressRequest, opts ...grpc.CallOption) (*NewAddressResponse, error) { out := new(NewAddressResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/NewAddress", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SignMessage(ctx context.Context, in *SignMessageRequest, opts ...grpc.CallOption) (*SignMessageResponse, error) { out := new(SignMessageResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/SignMessage", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) VerifyMessage(ctx context.Context, in *VerifyMessageRequest, opts ...grpc.CallOption) (*VerifyMessageResponse, error) { out := new(VerifyMessageResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/VerifyMessage", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ConnectPeer(ctx context.Context, in *ConnectPeerRequest, opts ...grpc.CallOption) (*ConnectPeerResponse, error) { out := new(ConnectPeerResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ConnectPeer", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) DisconnectPeer(ctx context.Context, in *DisconnectPeerRequest, opts ...grpc.CallOption) (*DisconnectPeerResponse, error) { out := new(DisconnectPeerResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/DisconnectPeer", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ListPeers(ctx context.Context, in *ListPeersRequest, opts ...grpc.CallOption) (*ListPeersResponse, error) { out := new(ListPeersResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ListPeers", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) GetInfo(ctx context.Context, in *GetInfoRequest, opts ...grpc.CallOption) (*GetInfoResponse, error) { out := new(GetInfoResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/GetInfo", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) PendingChannels(ctx context.Context, in *PendingChannelsRequest, opts ...grpc.CallOption) (*PendingChannelsResponse, error) { out := new(PendingChannelsResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/PendingChannels", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ListChannels(ctx context.Context, in *ListChannelsRequest, opts ...grpc.CallOption) (*ListChannelsResponse, error) { out := new(ListChannelsResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ListChannels", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SubscribeChannelEvents(ctx context.Context, in *ChannelEventSubscription, opts ...grpc.CallOption) (Lightning_SubscribeChannelEventsClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[1], "/lnrpc.Lightning/SubscribeChannelEvents", opts...) if err != nil { return nil, err } x := &lightningSubscribeChannelEventsClient{stream} if err := x.ClientStream.SendMsg(in); err != nil { return nil, err } if err := x.ClientStream.CloseSend(); err != nil { return nil, err } return x, nil } type Lightning_SubscribeChannelEventsClient interface { Recv() (*ChannelEventUpdate, error) grpc.ClientStream } type lightningSubscribeChannelEventsClient struct { grpc.ClientStream } func (x *lightningSubscribeChannelEventsClient) Recv() (*ChannelEventUpdate, error) { m := new(ChannelEventUpdate) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) ClosedChannels(ctx context.Context, in *ClosedChannelsRequest, opts ...grpc.CallOption) (*ClosedChannelsResponse, error) { out := new(ClosedChannelsResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ClosedChannels", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) OpenChannelSync(ctx context.Context, in *OpenChannelRequest, opts ...grpc.CallOption) (*ChannelPoint, error) { out := new(ChannelPoint) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/OpenChannelSync", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) OpenChannel(ctx context.Context, in *OpenChannelRequest, opts ...grpc.CallOption) (Lightning_OpenChannelClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[2], "/lnrpc.Lightning/OpenChannel", opts...) if err != nil { return nil, err } x := &lightningOpenChannelClient{stream} if err := x.ClientStream.SendMsg(in); err != nil { return nil, err } if err := x.ClientStream.CloseSend(); err != nil { return nil, err } return x, nil } type Lightning_OpenChannelClient interface { Recv() (*OpenStatusUpdate, error) grpc.ClientStream } type lightningOpenChannelClient struct { grpc.ClientStream } func (x *lightningOpenChannelClient) Recv() (*OpenStatusUpdate, error) { m := new(OpenStatusUpdate) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) CloseChannel(ctx context.Context, in *CloseChannelRequest, opts ...grpc.CallOption) (Lightning_CloseChannelClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[3], "/lnrpc.Lightning/CloseChannel", opts...) if err != nil { return nil, err } x := &lightningCloseChannelClient{stream} if err := x.ClientStream.SendMsg(in); err != nil { return nil, err } if err := x.ClientStream.CloseSend(); err != nil { return nil, err } return x, nil } type Lightning_CloseChannelClient interface { Recv() (*CloseStatusUpdate, error) grpc.ClientStream } type lightningCloseChannelClient struct { grpc.ClientStream } func (x *lightningCloseChannelClient) Recv() (*CloseStatusUpdate, error) { m := new(CloseStatusUpdate) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) AbandonChannel(ctx context.Context, in *AbandonChannelRequest, opts ...grpc.CallOption) (*AbandonChannelResponse, error) { out := new(AbandonChannelResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/AbandonChannel", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SendPayment(ctx context.Context, opts ...grpc.CallOption) (Lightning_SendPaymentClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[4], "/lnrpc.Lightning/SendPayment", opts...) if err != nil { return nil, err } x := &lightningSendPaymentClient{stream} return x, nil } type Lightning_SendPaymentClient interface { Send(*SendRequest) error Recv() (*SendResponse, error) grpc.ClientStream } type lightningSendPaymentClient struct { grpc.ClientStream } func (x *lightningSendPaymentClient) Send(m *SendRequest) error { return x.ClientStream.SendMsg(m) } func (x *lightningSendPaymentClient) Recv() (*SendResponse, error) { m := new(SendResponse) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) SendPaymentSync(ctx context.Context, in *SendRequest, opts ...grpc.CallOption) (*SendResponse, error) { out := new(SendResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/SendPaymentSync", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SendToRoute(ctx context.Context, opts ...grpc.CallOption) (Lightning_SendToRouteClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[5], "/lnrpc.Lightning/SendToRoute", opts...) if err != nil { return nil, err } x := &lightningSendToRouteClient{stream} return x, nil } type Lightning_SendToRouteClient interface { Send(*SendToRouteRequest) error Recv() (*SendResponse, error) grpc.ClientStream } type lightningSendToRouteClient struct { grpc.ClientStream } func (x *lightningSendToRouteClient) Send(m *SendToRouteRequest) error { return x.ClientStream.SendMsg(m) } func (x *lightningSendToRouteClient) Recv() (*SendResponse, error) { m := new(SendResponse) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) SendToRouteSync(ctx context.Context, in *SendToRouteRequest, opts ...grpc.CallOption) (*SendResponse, error) { out := new(SendResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/SendToRouteSync", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) AddInvoice(ctx context.Context, in *Invoice, opts ...grpc.CallOption) (*AddInvoiceResponse, error) { out := new(AddInvoiceResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/AddInvoice", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ListInvoices(ctx context.Context, in *ListInvoiceRequest, opts ...grpc.CallOption) (*ListInvoiceResponse, error) { out := new(ListInvoiceResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ListInvoices", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) LookupInvoice(ctx context.Context, in *PaymentHash, opts ...grpc.CallOption) (*Invoice, error) { out := new(Invoice) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/LookupInvoice", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SubscribeInvoices(ctx context.Context, in *InvoiceSubscription, opts ...grpc.CallOption) (Lightning_SubscribeInvoicesClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[6], "/lnrpc.Lightning/SubscribeInvoices", opts...) if err != nil { return nil, err } x := &lightningSubscribeInvoicesClient{stream} if err := x.ClientStream.SendMsg(in); err != nil { return nil, err } if err := x.ClientStream.CloseSend(); err != nil { return nil, err } return x, nil } type Lightning_SubscribeInvoicesClient interface { Recv() (*Invoice, error) grpc.ClientStream } type lightningSubscribeInvoicesClient struct { grpc.ClientStream } func (x *lightningSubscribeInvoicesClient) Recv() (*Invoice, error) { m := new(Invoice) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) DecodePayReq(ctx context.Context, in *PayReqString, opts ...grpc.CallOption) (*PayReq, error) { out := new(PayReq) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/DecodePayReq", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ListPayments(ctx context.Context, in *ListPaymentsRequest, opts ...grpc.CallOption) (*ListPaymentsResponse, error) { out := new(ListPaymentsResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ListPayments", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) DeleteAllPayments(ctx context.Context, in *DeleteAllPaymentsRequest, opts ...grpc.CallOption) (*DeleteAllPaymentsResponse, error) { out := new(DeleteAllPaymentsResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/DeleteAllPayments", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) DescribeGraph(ctx context.Context, in *ChannelGraphRequest, opts ...grpc.CallOption) (*ChannelGraph, error) { out := new(ChannelGraph) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/DescribeGraph", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) GetChanInfo(ctx context.Context, in *ChanInfoRequest, opts ...grpc.CallOption) (*ChannelEdge, error) { out := new(ChannelEdge) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/GetChanInfo", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) GetNodeInfo(ctx context.Context, in *NodeInfoRequest, opts ...grpc.CallOption) (*NodeInfo, error) { out := new(NodeInfo) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/GetNodeInfo", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) QueryRoutes(ctx context.Context, in *QueryRoutesRequest, opts ...grpc.CallOption) (*QueryRoutesResponse, error) { out := new(QueryRoutesResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/QueryRoutes", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) GetNetworkInfo(ctx context.Context, in *NetworkInfoRequest, opts ...grpc.CallOption) (*NetworkInfo, error) { out := new(NetworkInfo) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/GetNetworkInfo", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) StopDaemon(ctx context.Context, in *StopRequest, opts ...grpc.CallOption) (*StopResponse, error) { out := new(StopResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/StopDaemon", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) SubscribeChannelGraph(ctx context.Context, in *GraphTopologySubscription, opts ...grpc.CallOption) (Lightning_SubscribeChannelGraphClient, error) { stream, err := c.cc.NewStream(ctx, &_Lightning_serviceDesc.Streams[7], "/lnrpc.Lightning/SubscribeChannelGraph", opts...) if err != nil { return nil, err } x := &lightningSubscribeChannelGraphClient{stream} if err := x.ClientStream.SendMsg(in); err != nil { return nil, err } if err := x.ClientStream.CloseSend(); err != nil { return nil, err } return x, nil } type Lightning_SubscribeChannelGraphClient interface { Recv() (*GraphTopologyUpdate, error) grpc.ClientStream } type lightningSubscribeChannelGraphClient struct { grpc.ClientStream } func (x *lightningSubscribeChannelGraphClient) Recv() (*GraphTopologyUpdate, error) { m := new(GraphTopologyUpdate) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *lightningClient) DebugLevel(ctx context.Context, in *DebugLevelRequest, opts ...grpc.CallOption) (*DebugLevelResponse, error) { out := new(DebugLevelResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/DebugLevel", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) FeeReport(ctx context.Context, in *FeeReportRequest, opts ...grpc.CallOption) (*FeeReportResponse, error) { out := new(FeeReportResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/FeeReport", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) UpdateChannelPolicy(ctx context.Context, in *PolicyUpdateRequest, opts ...grpc.CallOption) (*PolicyUpdateResponse, error) { out := new(PolicyUpdateResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/UpdateChannelPolicy", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *lightningClient) ForwardingHistory(ctx context.Context, in *ForwardingHistoryRequest, opts ...grpc.CallOption) (*ForwardingHistoryResponse, error) { out := new(ForwardingHistoryResponse) err := c.cc.Invoke(ctx, "/lnrpc.Lightning/ForwardingHistory", in, out, opts...) if err != nil { return nil, err } return out, nil } // LightningServer is the server API for Lightning service. type LightningServer interface { // * lncli: `walletbalance` // WalletBalance returns total unspent outputs(confirmed and unconfirmed), all // confirmed unspent outputs and all unconfirmed unspent outputs under control // of the wallet. WalletBalance(context.Context, *WalletBalanceRequest) (*WalletBalanceResponse, error) // * lncli: `channelbalance` // ChannelBalance returns the total funds available across all open channels // in satoshis. ChannelBalance(context.Context, *ChannelBalanceRequest) (*ChannelBalanceResponse, error) // * lncli: `listchaintxns` // GetTransactions returns a list describing all the known transactions // relevant to the wallet. GetTransactions(context.Context, *GetTransactionsRequest) (*TransactionDetails, error) // * lncli: `sendcoins` // SendCoins executes a request to send coins to a particular address. Unlike // SendMany, this RPC call only allows creating a single output at a time. If // neither target_conf, or sat_per_byte are set, then the internal wallet will // consult its fee model to determine a fee for the default confirmation // target. SendCoins(context.Context, *SendCoinsRequest) (*SendCoinsResponse, error) // * lncli: `listunspent` // ListUnspent returns a list of all utxos spendable by the wallet with a // number of confirmations between the specified minimum and maximum. ListUnspent(context.Context, *ListUnspentRequest) (*ListUnspentResponse, error) // * // SubscribeTransactions creates a uni-directional stream from the server to // the client in which any newly discovered transactions relevant to the // wallet are sent over. SubscribeTransactions(*GetTransactionsRequest, Lightning_SubscribeTransactionsServer) error // * lncli: `sendmany` // SendMany handles a request for a transaction that creates multiple specified // outputs in parallel. If neither target_conf, or sat_per_byte are set, then // the internal wallet will consult its fee model to determine a fee for the // default confirmation target. SendMany(context.Context, *SendManyRequest) (*SendManyResponse, error) // * lncli: `newaddress` // NewAddress creates a new address under control of the local wallet. NewAddress(context.Context, *NewAddressRequest) (*NewAddressResponse, error) // * lncli: `signmessage` // SignMessage signs a message with this node's private key. The returned // signature string is `zbase32` encoded and pubkey recoverable, meaning that // only the message digest and signature are needed for verification. SignMessage(context.Context, *SignMessageRequest) (*SignMessageResponse, error) // * lncli: `verifymessage` // VerifyMessage verifies a signature over a msg. The signature must be // zbase32 encoded and signed by an active node in the resident node's // channel database. In addition to returning the validity of the signature, // VerifyMessage also returns the recovered pubkey from the signature. VerifyMessage(context.Context, *VerifyMessageRequest) (*VerifyMessageResponse, error) // * lncli: `connect` // ConnectPeer attempts to establish a connection to a remote peer. This is at // the networking level, and is used for communication between nodes. This is // distinct from establishing a channel with a peer. ConnectPeer(context.Context, *ConnectPeerRequest) (*ConnectPeerResponse, error) // * lncli: `disconnect` // DisconnectPeer attempts to disconnect one peer from another identified by a // given pubKey. In the case that we currently have a pending or active channel // with the target peer, then this action will be not be allowed. DisconnectPeer(context.Context, *DisconnectPeerRequest) (*DisconnectPeerResponse, error) // * lncli: `listpeers` // ListPeers returns a verbose listing of all currently active peers. ListPeers(context.Context, *ListPeersRequest) (*ListPeersResponse, error) // * lncli: `getinfo` // GetInfo returns general information concerning the lightning node including // it's identity pubkey, alias, the chains it is connected to, and information // concerning the number of open+pending channels. GetInfo(context.Context, *GetInfoRequest) (*GetInfoResponse, error) // * lncli: `pendingchannels` // PendingChannels returns a list of all the channels that are currently // considered "pending". A channel is pending if it has finished the funding // workflow and is waiting for confirmations for the funding txn, or is in the // process of closure, either initiated cooperatively or non-cooperatively. PendingChannels(context.Context, *PendingChannelsRequest) (*PendingChannelsResponse, error) // * lncli: `listchannels` // ListChannels returns a description of all the open channels that this node // is a participant in. ListChannels(context.Context, *ListChannelsRequest) (*ListChannelsResponse, error) // * lncli: `subscribechannelevents` // SubscribeChannelEvents creates a uni-directional stream from the server to // the client in which any updates relevant to the state of the channels are // sent over. Events include new active channels, inactive channels, and closed // channels. SubscribeChannelEvents(*ChannelEventSubscription, Lightning_SubscribeChannelEventsServer) error // * lncli: `closedchannels` // ClosedChannels returns a description of all the closed channels that // this node was a participant in. ClosedChannels(context.Context, *ClosedChannelsRequest) (*ClosedChannelsResponse, error) // * // OpenChannelSync is a synchronous version of the OpenChannel RPC call. This // call is meant to be consumed by clients to the REST proxy. As with all // other sync calls, all byte slices are intended to be populated as hex // encoded strings. OpenChannelSync(context.Context, *OpenChannelRequest) (*ChannelPoint, error) // * lncli: `openchannel` // OpenChannel attempts to open a singly funded channel specified in the // request to a remote peer. Users are able to specify a target number of // blocks that the funding transaction should be confirmed in, or a manual fee // rate to us for the funding transaction. If neither are specified, then a // lax block confirmation target is used. OpenChannel(*OpenChannelRequest, Lightning_OpenChannelServer) error // * lncli: `closechannel` // CloseChannel attempts to close an active channel identified by its channel // outpoint (ChannelPoint). The actions of this method can additionally be // augmented to attempt a force close after a timeout period in the case of an // inactive peer. If a non-force close (cooperative closure) is requested, // then the user can specify either a target number of blocks until the // closure transaction is confirmed, or a manual fee rate. If neither are // specified, then a default lax, block confirmation target is used. CloseChannel(*CloseChannelRequest, Lightning_CloseChannelServer) error // * lncli: `abandonchannel` // AbandonChannel removes all channel state from the database except for a // close summary. This method can be used to get rid of permanently unusable // channels due to bugs fixed in newer versions of lnd. Only available // when in debug builds of lnd. AbandonChannel(context.Context, *AbandonChannelRequest) (*AbandonChannelResponse, error) // * lncli: `sendpayment` // SendPayment dispatches a bi-directional streaming RPC for sending payments // through the Lightning Network. A single RPC invocation creates a persistent // bi-directional stream allowing clients to rapidly send payments through the // Lightning Network with a single persistent connection. SendPayment(Lightning_SendPaymentServer) error // * // SendPaymentSync is the synchronous non-streaming version of SendPayment. // This RPC is intended to be consumed by clients of the REST proxy. // Additionally, this RPC expects the destination's public key and the payment // hash (if any) to be encoded as hex strings. SendPaymentSync(context.Context, *SendRequest) (*SendResponse, error) // * lncli: `sendtoroute` // SendToRoute is a bi-directional streaming RPC for sending payment through // the Lightning Network. This method differs from SendPayment in that it // allows users to specify a full route manually. This can be used for things // like rebalancing, and atomic swaps. SendToRoute(Lightning_SendToRouteServer) error // * // SendToRouteSync is a synchronous version of SendToRoute. It Will block // until the payment either fails or succeeds. SendToRouteSync(context.Context, *SendToRouteRequest) (*SendResponse, error) // * lncli: `addinvoice` // AddInvoice attempts to add a new invoice to the invoice database. Any // duplicated invoices are rejected, therefore all invoices *must* have a // unique payment preimage. AddInvoice(context.Context, *Invoice) (*AddInvoiceResponse, error) // * lncli: `listinvoices` // ListInvoices returns a list of all the invoices currently stored within the // database. Any active debug invoices are ignored. It has full support for // paginated responses, allowing users to query for specific invoices through // their add_index. This can be done by using either the first_index_offset or // last_index_offset fields included in the response as the index_offset of the // next request. By default, the first 100 invoices created will be returned. // Backwards pagination is also supported through the Reversed flag. ListInvoices(context.Context, *ListInvoiceRequest) (*ListInvoiceResponse, error) // * lncli: `lookupinvoice` // LookupInvoice attempts to look up an invoice according to its payment hash. // The passed payment hash *must* be exactly 32 bytes, if not, an error is // returned. LookupInvoice(context.Context, *PaymentHash) (*Invoice, error) // * // SubscribeInvoices returns a uni-directional stream (server -> client) for // notifying the client of newly added/settled invoices. The caller can // optionally specify the add_index and/or the settle_index. If the add_index // is specified, then we'll first start by sending add invoice events for all // invoices with an add_index greater than the specified value. If the // settle_index is specified, the next, we'll send out all settle events for // invoices with a settle_index greater than the specified value. One or both // of these fields can be set. If no fields are set, then we'll only send out // the latest add/settle events. SubscribeInvoices(*InvoiceSubscription, Lightning_SubscribeInvoicesServer) error // * lncli: `decodepayreq` // DecodePayReq takes an encoded payment request string and attempts to decode // it, returning a full description of the conditions encoded within the // payment request. DecodePayReq(context.Context, *PayReqString) (*PayReq, error) // * lncli: `listpayments` // ListPayments returns a list of all outgoing payments. ListPayments(context.Context, *ListPaymentsRequest) (*ListPaymentsResponse, error) // * // DeleteAllPayments deletes all outgoing payments from DB. DeleteAllPayments(context.Context, *DeleteAllPaymentsRequest) (*DeleteAllPaymentsResponse, error) // * lncli: `describegraph` // DescribeGraph returns a description of the latest graph state from the // point of view of the node. The graph information is partitioned into two // components: all the nodes/vertexes, and all the edges that connect the // vertexes themselves. As this is a directed graph, the edges also contain // the node directional specific routing policy which includes: the time lock // delta, fee information, etc. DescribeGraph(context.Context, *ChannelGraphRequest) (*ChannelGraph, error) // * lncli: `getchaninfo` // GetChanInfo returns the latest authenticated network announcement for the // given channel identified by its channel ID: an 8-byte integer which // uniquely identifies the location of transaction's funding output within the // blockchain. GetChanInfo(context.Context, *ChanInfoRequest) (*ChannelEdge, error) // * lncli: `getnodeinfo` // GetNodeInfo returns the latest advertised, aggregated, and authenticated // channel information for the specified node identified by its public key. GetNodeInfo(context.Context, *NodeInfoRequest) (*NodeInfo, error) // * lncli: `queryroutes` // QueryRoutes attempts to query the daemon's Channel Router for a possible // route to a target destination capable of carrying a specific amount of // satoshis. The retuned route contains the full details required to craft and // send an HTLC, also including the necessary information that should be // present within the Sphinx packet encapsulated within the HTLC. QueryRoutes(context.Context, *QueryRoutesRequest) (*QueryRoutesResponse, error) // * lncli: `getnetworkinfo` // GetNetworkInfo returns some basic stats about the known channel graph from // the point of view of the node. GetNetworkInfo(context.Context, *NetworkInfoRequest) (*NetworkInfo, error) // * lncli: `stop` // StopDaemon will send a shutdown request to the interrupt handler, triggering // a graceful shutdown of the daemon. StopDaemon(context.Context, *StopRequest) (*StopResponse, error) // * // SubscribeChannelGraph launches a streaming RPC that allows the caller to // receive notifications upon any changes to the channel graph topology from // the point of view of the responding node. Events notified include: new // nodes coming online, nodes updating their authenticated attributes, new // channels being advertised, updates in the routing policy for a directional // channel edge, and when channels are closed on-chain. SubscribeChannelGraph(*GraphTopologySubscription, Lightning_SubscribeChannelGraphServer) error // * lncli: `debuglevel` // DebugLevel allows a caller to programmatically set the logging verbosity of // lnd. The logging can be targeted according to a coarse daemon-wide logging // level, or in a granular fashion to specify the logging for a target // sub-system. DebugLevel(context.Context, *DebugLevelRequest) (*DebugLevelResponse, error) // * lncli: `feereport` // FeeReport allows the caller to obtain a report detailing the current fee // schedule enforced by the node globally for each channel. FeeReport(context.Context, *FeeReportRequest) (*FeeReportResponse, error) // * lncli: `updatechanpolicy` // UpdateChannelPolicy allows the caller to update the fee schedule and // channel policies for all channels globally, or a particular channel. UpdateChannelPolicy(context.Context, *PolicyUpdateRequest) (*PolicyUpdateResponse, error) // * lncli: `fwdinghistory` // ForwardingHistory allows the caller to query the htlcswitch for a record of // all HTLC's forwarded within the target time range, and integer offset // within that time range. If no time-range is specified, then the first chunk // of the past 24 hrs of forwarding history are returned. // // A list of forwarding events are returned. The size of each forwarding event // is 40 bytes, and the max message size able to be returned in gRPC is 4 MiB. // As a result each message can only contain 50k entries. Each response has // the index offset of the last entry. The index offset can be provided to the // request to allow the caller to skip a series of records. ForwardingHistory(context.Context, *ForwardingHistoryRequest) (*ForwardingHistoryResponse, error) } func RegisterLightningServer(s *grpc.Server, srv LightningServer) { s.RegisterService(&_Lightning_serviceDesc, srv) } func _Lightning_WalletBalance_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(WalletBalanceRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).WalletBalance(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/WalletBalance", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).WalletBalance(ctx, req.(*WalletBalanceRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_ChannelBalance_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ChannelBalanceRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ChannelBalance(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ChannelBalance", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ChannelBalance(ctx, req.(*ChannelBalanceRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_GetTransactions_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(GetTransactionsRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).GetTransactions(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/GetTransactions", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).GetTransactions(ctx, req.(*GetTransactionsRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_SendCoins_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(SendCoinsRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).SendCoins(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/SendCoins", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).SendCoins(ctx, req.(*SendCoinsRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_ListUnspent_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ListUnspentRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ListUnspent(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ListUnspent", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ListUnspent(ctx, req.(*ListUnspentRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_SubscribeTransactions_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(GetTransactionsRequest) if err := stream.RecvMsg(m); err != nil { return err } return srv.(LightningServer).SubscribeTransactions(m, &lightningSubscribeTransactionsServer{stream}) } type Lightning_SubscribeTransactionsServer interface { Send(*Transaction) error grpc.ServerStream } type lightningSubscribeTransactionsServer struct { grpc.ServerStream } func (x *lightningSubscribeTransactionsServer) Send(m *Transaction) error { return x.ServerStream.SendMsg(m) } func _Lightning_SendMany_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(SendManyRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).SendMany(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/SendMany", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).SendMany(ctx, req.(*SendManyRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_NewAddress_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(NewAddressRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).NewAddress(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/NewAddress", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).NewAddress(ctx, req.(*NewAddressRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_SignMessage_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(SignMessageRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).SignMessage(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/SignMessage", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).SignMessage(ctx, req.(*SignMessageRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_VerifyMessage_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(VerifyMessageRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).VerifyMessage(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/VerifyMessage", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).VerifyMessage(ctx, req.(*VerifyMessageRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_ConnectPeer_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ConnectPeerRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ConnectPeer(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ConnectPeer", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ConnectPeer(ctx, req.(*ConnectPeerRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_DisconnectPeer_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(DisconnectPeerRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).DisconnectPeer(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/DisconnectPeer", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).DisconnectPeer(ctx, req.(*DisconnectPeerRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_ListPeers_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ListPeersRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ListPeers(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ListPeers", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ListPeers(ctx, req.(*ListPeersRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_GetInfo_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(GetInfoRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).GetInfo(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/GetInfo", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).GetInfo(ctx, req.(*GetInfoRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_PendingChannels_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(PendingChannelsRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).PendingChannels(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/PendingChannels", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).PendingChannels(ctx, req.(*PendingChannelsRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_ListChannels_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ListChannelsRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ListChannels(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ListChannels", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ListChannels(ctx, req.(*ListChannelsRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_SubscribeChannelEvents_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(ChannelEventSubscription) if err := stream.RecvMsg(m); err != nil { return err } return srv.(LightningServer).SubscribeChannelEvents(m, &lightningSubscribeChannelEventsServer{stream}) } type Lightning_SubscribeChannelEventsServer interface { Send(*ChannelEventUpdate) error grpc.ServerStream } type lightningSubscribeChannelEventsServer struct { grpc.ServerStream } func (x *lightningSubscribeChannelEventsServer) Send(m *ChannelEventUpdate) error { return x.ServerStream.SendMsg(m) } func _Lightning_ClosedChannels_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ClosedChannelsRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ClosedChannels(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ClosedChannels", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ClosedChannels(ctx, req.(*ClosedChannelsRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_OpenChannelSync_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(OpenChannelRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).OpenChannelSync(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/OpenChannelSync", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).OpenChannelSync(ctx, req.(*OpenChannelRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_OpenChannel_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(OpenChannelRequest) if err := stream.RecvMsg(m); err != nil { return err } return srv.(LightningServer).OpenChannel(m, &lightningOpenChannelServer{stream}) } type Lightning_OpenChannelServer interface { Send(*OpenStatusUpdate) error grpc.ServerStream } type lightningOpenChannelServer struct { grpc.ServerStream } func (x *lightningOpenChannelServer) Send(m *OpenStatusUpdate) error { return x.ServerStream.SendMsg(m) } func _Lightning_CloseChannel_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(CloseChannelRequest) if err := stream.RecvMsg(m); err != nil { return err } return srv.(LightningServer).CloseChannel(m, &lightningCloseChannelServer{stream}) } type Lightning_CloseChannelServer interface { Send(*CloseStatusUpdate) error grpc.ServerStream } type lightningCloseChannelServer struct { grpc.ServerStream } func (x *lightningCloseChannelServer) Send(m *CloseStatusUpdate) error { return x.ServerStream.SendMsg(m) } func _Lightning_AbandonChannel_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(AbandonChannelRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).AbandonChannel(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/AbandonChannel", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).AbandonChannel(ctx, req.(*AbandonChannelRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_SendPayment_Handler(srv interface{}, stream grpc.ServerStream) error { return srv.(LightningServer).SendPayment(&lightningSendPaymentServer{stream}) } type Lightning_SendPaymentServer interface { Send(*SendResponse) error Recv() (*SendRequest, error) grpc.ServerStream } type lightningSendPaymentServer struct { grpc.ServerStream } func (x *lightningSendPaymentServer) Send(m *SendResponse) error { return x.ServerStream.SendMsg(m) } func (x *lightningSendPaymentServer) Recv() (*SendRequest, error) { m := new(SendRequest) if err := x.ServerStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func _Lightning_SendPaymentSync_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(SendRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).SendPaymentSync(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/SendPaymentSync", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).SendPaymentSync(ctx, req.(*SendRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_SendToRoute_Handler(srv interface{}, stream grpc.ServerStream) error { return srv.(LightningServer).SendToRoute(&lightningSendToRouteServer{stream}) } type Lightning_SendToRouteServer interface { Send(*SendResponse) error Recv() (*SendToRouteRequest, error) grpc.ServerStream } type lightningSendToRouteServer struct { grpc.ServerStream } func (x *lightningSendToRouteServer) Send(m *SendResponse) error { return x.ServerStream.SendMsg(m) } func (x *lightningSendToRouteServer) Recv() (*SendToRouteRequest, error) { m := new(SendToRouteRequest) if err := x.ServerStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func _Lightning_SendToRouteSync_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(SendToRouteRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).SendToRouteSync(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/SendToRouteSync", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).SendToRouteSync(ctx, req.(*SendToRouteRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_AddInvoice_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(Invoice) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).AddInvoice(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/AddInvoice", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).AddInvoice(ctx, req.(*Invoice)) } return interceptor(ctx, in, info, handler) } func _Lightning_ListInvoices_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ListInvoiceRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ListInvoices(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ListInvoices", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ListInvoices(ctx, req.(*ListInvoiceRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_LookupInvoice_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(PaymentHash) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).LookupInvoice(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/LookupInvoice", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).LookupInvoice(ctx, req.(*PaymentHash)) } return interceptor(ctx, in, info, handler) } func _Lightning_SubscribeInvoices_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(InvoiceSubscription) if err := stream.RecvMsg(m); err != nil { return err } return srv.(LightningServer).SubscribeInvoices(m, &lightningSubscribeInvoicesServer{stream}) } type Lightning_SubscribeInvoicesServer interface { Send(*Invoice) error grpc.ServerStream } type lightningSubscribeInvoicesServer struct { grpc.ServerStream } func (x *lightningSubscribeInvoicesServer) Send(m *Invoice) error { return x.ServerStream.SendMsg(m) } func _Lightning_DecodePayReq_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(PayReqString) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).DecodePayReq(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/DecodePayReq", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).DecodePayReq(ctx, req.(*PayReqString)) } return interceptor(ctx, in, info, handler) } func _Lightning_ListPayments_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ListPaymentsRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ListPayments(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ListPayments", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ListPayments(ctx, req.(*ListPaymentsRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_DeleteAllPayments_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(DeleteAllPaymentsRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).DeleteAllPayments(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/DeleteAllPayments", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).DeleteAllPayments(ctx, req.(*DeleteAllPaymentsRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_DescribeGraph_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ChannelGraphRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).DescribeGraph(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/DescribeGraph", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).DescribeGraph(ctx, req.(*ChannelGraphRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_GetChanInfo_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ChanInfoRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).GetChanInfo(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/GetChanInfo", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).GetChanInfo(ctx, req.(*ChanInfoRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_GetNodeInfo_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(NodeInfoRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).GetNodeInfo(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/GetNodeInfo", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).GetNodeInfo(ctx, req.(*NodeInfoRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_QueryRoutes_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(QueryRoutesRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).QueryRoutes(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/QueryRoutes", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).QueryRoutes(ctx, req.(*QueryRoutesRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_GetNetworkInfo_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(NetworkInfoRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).GetNetworkInfo(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/GetNetworkInfo", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).GetNetworkInfo(ctx, req.(*NetworkInfoRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_StopDaemon_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(StopRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).StopDaemon(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/StopDaemon", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).StopDaemon(ctx, req.(*StopRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_SubscribeChannelGraph_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(GraphTopologySubscription) if err := stream.RecvMsg(m); err != nil { return err } return srv.(LightningServer).SubscribeChannelGraph(m, &lightningSubscribeChannelGraphServer{stream}) } type Lightning_SubscribeChannelGraphServer interface { Send(*GraphTopologyUpdate) error grpc.ServerStream } type lightningSubscribeChannelGraphServer struct { grpc.ServerStream } func (x *lightningSubscribeChannelGraphServer) Send(m *GraphTopologyUpdate) error { return x.ServerStream.SendMsg(m) } func _Lightning_DebugLevel_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(DebugLevelRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).DebugLevel(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/DebugLevel", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).DebugLevel(ctx, req.(*DebugLevelRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_FeeReport_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(FeeReportRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).FeeReport(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/FeeReport", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).FeeReport(ctx, req.(*FeeReportRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_UpdateChannelPolicy_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(PolicyUpdateRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).UpdateChannelPolicy(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/UpdateChannelPolicy", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).UpdateChannelPolicy(ctx, req.(*PolicyUpdateRequest)) } return interceptor(ctx, in, info, handler) } func _Lightning_ForwardingHistory_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(ForwardingHistoryRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(LightningServer).ForwardingHistory(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/lnrpc.Lightning/ForwardingHistory", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(LightningServer).ForwardingHistory(ctx, req.(*ForwardingHistoryRequest)) } return interceptor(ctx, in, info, handler) } var _Lightning_serviceDesc = grpc.ServiceDesc{ ServiceName: "lnrpc.Lightning", HandlerType: (*LightningServer)(nil), Methods: []grpc.MethodDesc{ { MethodName: "WalletBalance", Handler: _Lightning_WalletBalance_Handler, }, { MethodName: "ChannelBalance", Handler: _Lightning_ChannelBalance_Handler, }, { MethodName: "GetTransactions", Handler: _Lightning_GetTransactions_Handler, }, { MethodName: "SendCoins", Handler: _Lightning_SendCoins_Handler, }, { MethodName: "ListUnspent", Handler: _Lightning_ListUnspent_Handler, }, { MethodName: "SendMany", Handler: _Lightning_SendMany_Handler, }, { MethodName: "NewAddress", Handler: _Lightning_NewAddress_Handler, }, { MethodName: "SignMessage", Handler: _Lightning_SignMessage_Handler, }, { MethodName: "VerifyMessage", Handler: _Lightning_VerifyMessage_Handler, }, { MethodName: "ConnectPeer", Handler: _Lightning_ConnectPeer_Handler, }, { MethodName: "DisconnectPeer", Handler: _Lightning_DisconnectPeer_Handler, }, { MethodName: "ListPeers", Handler: _Lightning_ListPeers_Handler, }, { MethodName: "GetInfo", Handler: _Lightning_GetInfo_Handler, }, { MethodName: "PendingChannels", Handler: _Lightning_PendingChannels_Handler, }, { MethodName: "ListChannels", Handler: _Lightning_ListChannels_Handler, }, { MethodName: "ClosedChannels", Handler: _Lightning_ClosedChannels_Handler, }, { MethodName: "OpenChannelSync", Handler: _Lightning_OpenChannelSync_Handler, }, { MethodName: "AbandonChannel", Handler: _Lightning_AbandonChannel_Handler, }, { MethodName: "SendPaymentSync", Handler: _Lightning_SendPaymentSync_Handler, }, { MethodName: "SendToRouteSync", Handler: _Lightning_SendToRouteSync_Handler, }, { MethodName: "AddInvoice", Handler: _Lightning_AddInvoice_Handler, }, { MethodName: "ListInvoices", Handler: _Lightning_ListInvoices_Handler, }, { MethodName: "LookupInvoice", Handler: _Lightning_LookupInvoice_Handler, }, { MethodName: "DecodePayReq", Handler: _Lightning_DecodePayReq_Handler, }, { MethodName: "ListPayments", Handler: _Lightning_ListPayments_Handler, }, { MethodName: "DeleteAllPayments", Handler: _Lightning_DeleteAllPayments_Handler, }, { MethodName: "DescribeGraph", Handler: _Lightning_DescribeGraph_Handler, }, { MethodName: "GetChanInfo", Handler: _Lightning_GetChanInfo_Handler, }, { MethodName: "GetNodeInfo", Handler: _Lightning_GetNodeInfo_Handler, }, { MethodName: "QueryRoutes", Handler: _Lightning_QueryRoutes_Handler, }, { MethodName: "GetNetworkInfo", Handler: _Lightning_GetNetworkInfo_Handler, }, { MethodName: "StopDaemon", Handler: _Lightning_StopDaemon_Handler, }, { MethodName: "DebugLevel", Handler: _Lightning_DebugLevel_Handler, }, { MethodName: "FeeReport", Handler: _Lightning_FeeReport_Handler, }, { MethodName: "UpdateChannelPolicy", Handler: _Lightning_UpdateChannelPolicy_Handler, }, { MethodName: "ForwardingHistory", Handler: _Lightning_ForwardingHistory_Handler, }, }, Streams: []grpc.StreamDesc{ { StreamName: "SubscribeTransactions", Handler: _Lightning_SubscribeTransactions_Handler, ServerStreams: true, }, { StreamName: "SubscribeChannelEvents", Handler: _Lightning_SubscribeChannelEvents_Handler, ServerStreams: true, }, { StreamName: "OpenChannel", Handler: _Lightning_OpenChannel_Handler, ServerStreams: true, }, { StreamName: "CloseChannel", Handler: _Lightning_CloseChannel_Handler, ServerStreams: true, }, { StreamName: "SendPayment", Handler: _Lightning_SendPayment_Handler, ServerStreams: true, ClientStreams: true, }, { StreamName: "SendToRoute", Handler: _Lightning_SendToRoute_Handler, ServerStreams: true, ClientStreams: true, }, { StreamName: "SubscribeInvoices", Handler: _Lightning_SubscribeInvoices_Handler, ServerStreams: true, }, { StreamName: "SubscribeChannelGraph", Handler: _Lightning_SubscribeChannelGraph_Handler, ServerStreams: true, }, }, Metadata: "rpc.proto", } func init() { proto.RegisterFile("rpc.proto", fileDescriptor_rpc_2cfe4ee64b0e338d) } var fileDescriptor_rpc_2cfe4ee64b0e338d = []byte{ // 7002 bytes of a gzipped FileDescriptorProto 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x5c, 0x5f, 0x6c, 0x24, 0xc9, 0x59, 0xdf, 0x9e, 0x3f, 0xf6, 0xcc, 0x37, 0xe3, 0xf1, 0xb8, 0xfc, 0x67, 0x67, 0xe7, 0xf6, 0xf6, 0xf6, 0x3a, 0xcb, 0xad, 0xe3, 0x1c, 0xeb, 0xbd, 0x4d, 0x72, 0x5c, 0xee, 0x48, 0xc0, 0x6b, 0x7b, 0xd7, 0x9b, 0xf8, 0xbc, 0x4e, 0x7b, 0x37, 0x4b, 0x2e, 0x41, 0x93, 0xf6, 0x4c, 0x79, 0xdc, 0xb7, 0x3d, 0xdd, 0x93, 0xee, 0x1e, 0x7b, 0x27, 0xc7, 0x49, 0x08, 0x10, 0x91, 0x10, 0x08, 0x01, 0x2f, 0x04, 0x05, 0x21, 0x05, 0x24, 0xc8, 0x23, 0x0f, 0x89, 0x90, 0x80, 0x37, 0x84, 0x04, 0x12, 0x42, 0x90, 0x47, 0x24, 0x24, 0x04, 0x2f, 0xc0, 0x1b, 0x12, 0x8f, 0x48, 0xa8, 0xbe, 0xfa, 0xd3, 0x55, 0xdd, 0x3d, 0xeb, 0xbd, 0x24, 0xf0, 0x64, 0xd7, 0xaf, 0xbe, 0xae, 0xbf, 0xdf, 0xbf, 0xfa, 0xea, 0xab, 0x81, 0x7a, 0x34, 0xee, 0xdf, 0x1a, 0x47, 0x61, 0x12, 0x92, 0xaa, 0x1f, 0x44, 0xe3, 0x7e, 0xf7, 0xea, 0x30, 0x0c, 0x87, 0x3e, 0xdd, 0x74, 0xc7, 0xde, 0xa6, 0x1b, 0x04, 0x61, 0xe2, 0x26, 0x5e, 0x18, 0xc4, 0x9c, 0xc8, 0xfe, 0x1a, 0xb4, 0xee, 0xd3, 0xe0, 0x88, 0xd2, 0x81, 0x43, 0xbf, 0x3e, 0xa1, 0x71, 0x42, 0x3e, 0x01, 0x4b, 0x2e, 0xfd, 0x06, 0xa5, 0x83, 0xde, 0xd8, 0x8d, 0xe3, 0xf1, 0x69, 0xe4, 0xc6, 0xb4, 0x63, 0x5d, 0xb7, 0xd6, 0x9b, 0x4e, 0x9b, 0x57, 0x1c, 0x2a, 0x9c, 0xbc, 0x0a, 0xcd, 0x98, 0x91, 0xd2, 0x20, 0x89, 0xc2, 0xf1, 0xb4, 0x53, 0x42, 0xba, 0x06, 0xc3, 0x76, 0x39, 0x64, 0xfb, 0xb0, 0xa8, 0x7a, 0x88, 0xc7, 0x61, 0x10, 0x53, 0x72, 0x1b, 0x56, 0xfa, 0xde, 0xf8, 0x94, 0x46, 0x3d, 0xfc, 0x78, 0x14, 0xd0, 0x51, 0x18, 0x78, 0xfd, 0x8e, 0x75, 0xbd, 0xbc, 0x5e, 0x77, 0x08, 0xaf, 0x63, 0x5f, 0xbc, 0x2b, 0x6a, 0xc8, 0x4d, 0x58, 0xa4, 0x01, 0xc7, 0xe9, 0x00, 0xbf, 0x12, 0x5d, 0xb5, 0x52, 0x98, 0x7d, 0x60, 0xff, 0x95, 0x05, 0x4b, 0x0f, 0x02, 0x2f, 0x79, 0xe2, 0xfa, 0x3e, 0x4d, 0xe4, 0x9c, 0x6e, 0xc2, 0xe2, 0x39, 0x02, 0x38, 0xa7, 0xf3, 0x30, 0x1a, 0x88, 0x19, 0xb5, 0x38, 0x7c, 0x28, 0xd0, 0x99, 0x23, 0x2b, 0xcd, 0x1c, 0x59, 0xe1, 0x72, 0x95, 0x67, 0x2c, 0xd7, 0x4d, 0x58, 0x8c, 0x68, 0x3f, 0x3c, 0xa3, 0xd1, 0xb4, 0x77, 0xee, 0x05, 0x83, 0xf0, 0xbc, 0x53, 0xb9, 0x6e, 0xad, 0x57, 0x9d, 0x96, 0x84, 0x9f, 0x20, 0x6a, 0xaf, 0x00, 0xd1, 0x67, 0xc1, 0xd7, 0xcd, 0x1e, 0xc2, 0xf2, 0xe3, 0xc0, 0x0f, 0xfb, 0x4f, 0x7f, 0xc8, 0xd9, 0x15, 0x74, 0x5f, 0x2a, 0xec, 0x7e, 0x0d, 0x56, 0xcc, 0x8e, 0xc4, 0x00, 0x28, 0xac, 0x6e, 0x9f, 0xba, 0xc1, 0x90, 0xca, 0x26, 0xe5, 0x10, 0x3e, 0x0e, 0xed, 0xfe, 0x24, 0x8a, 0x68, 0x90, 0x1b, 0xc3, 0xa2, 0xc0, 0xd5, 0x20, 0x5e, 0x85, 0x66, 0x40, 0xcf, 0x53, 0x32, 0xc1, 0x32, 0x01, 0x3d, 0x97, 0x24, 0x76, 0x07, 0xd6, 0xb2, 0xdd, 0x88, 0x01, 0xfc, 0x8b, 0x05, 0x95, 0xc7, 0xc9, 0xb3, 0x90, 0xdc, 0x82, 0x4a, 0x32, 0x1d, 0x73, 0xc6, 0x6c, 0xdd, 0x21, 0xb7, 0x90, 0xd7, 0x6f, 0x6d, 0x0d, 0x06, 0x11, 0x8d, 0xe3, 0x47, 0xd3, 0x31, 0x75, 0x9a, 0x2e, 0x2f, 0xf4, 0x18, 0x1d, 0xe9, 0xc0, 0xbc, 0x28, 0x63, 0x87, 0x75, 0x47, 0x16, 0xc9, 0x35, 0x00, 0x77, 0x14, 0x4e, 0x82, 0xa4, 0x17, 0xbb, 0x09, 0xee, 0x5c, 0xd9, 0xd1, 0x10, 0x72, 0x15, 0xea, 0xe3, 0xa7, 0xbd, 0xb8, 0x1f, 0x79, 0xe3, 0x04, 0x77, 0xab, 0xee, 0xa4, 0x00, 0xf9, 0x04, 0xd4, 0xc2, 0x49, 0x32, 0x0e, 0xbd, 0x20, 0xe9, 0x54, 0xaf, 0x5b, 0xeb, 0x8d, 0x3b, 0x8b, 0x62, 0x2c, 0x0f, 0x27, 0xc9, 0x21, 0x83, 0x1d, 0x45, 0x40, 0x6e, 0xc0, 0x42, 0x3f, 0x0c, 0x4e, 0xbc, 0x68, 0xc4, 0x65, 0xb0, 0x33, 0x87, 0xbd, 0x99, 0xa0, 0xfd, 0xad, 0x12, 0x34, 0x1e, 0x45, 0x6e, 0x10, 0xbb, 0x7d, 0x06, 0xb0, 0xa1, 0x27, 0xcf, 0x7a, 0xa7, 0x6e, 0x7c, 0x8a, 0xb3, 0xad, 0x3b, 0xb2, 0x48, 0xd6, 0x60, 0x8e, 0x0f, 0x14, 0xe7, 0x54, 0x76, 0x44, 0x89, 0xbc, 0x0e, 0x4b, 0xc1, 0x64, 0xd4, 0x33, 0xfb, 0x2a, 0xe3, 0x4e, 0xe7, 0x2b, 0xd8, 0x02, 0x1c, 0xb3, 0xbd, 0xe6, 0x5d, 0xf0, 0x19, 0x6a, 0x08, 0xb1, 0xa1, 0x29, 0x4a, 0xd4, 0x1b, 0x9e, 0xf2, 0x69, 0x56, 0x1d, 0x03, 0x63, 0x6d, 0x24, 0xde, 0x88, 0xf6, 0xe2, 0xc4, 0x1d, 0x8d, 0xc5, 0xb4, 0x34, 0x04, 0xeb, 0xc3, 0xc4, 0xf5, 0x7b, 0x27, 0x94, 0xc6, 0x9d, 0x79, 0x51, 0xaf, 0x10, 0xf2, 0x1a, 0xb4, 0x06, 0x34, 0x4e, 0x7a, 0x62, 0x53, 0x68, 0xdc, 0xa9, 0xa1, 0xc4, 0x65, 0x50, 0xc6, 0x19, 0xf7, 0x69, 0xa2, 0xad, 0x4e, 0x2c, 0x38, 0xd0, 0xde, 0x07, 0xa2, 0xc1, 0x3b, 0x34, 0x71, 0x3d, 0x3f, 0x26, 0x6f, 0x42, 0x33, 0xd1, 0x88, 0x51, 0xc3, 0x34, 0x14, 0xbb, 0x68, 0x1f, 0x38, 0x06, 0x9d, 0x7d, 0x1f, 0x6a, 0xf7, 0x28, 0xdd, 0xf7, 0x46, 0x5e, 0x42, 0xd6, 0xa0, 0x7a, 0xe2, 0x3d, 0xa3, 0x9c, 0xa1, 0xcb, 0x7b, 0x97, 0x1c, 0x5e, 0x24, 0x5d, 0x98, 0x1f, 0xd3, 0xa8, 0x4f, 0xe5, 0xf2, 0xef, 0x5d, 0x72, 0x24, 0x70, 0x77, 0x1e, 0xaa, 0x3e, 0xfb, 0xd8, 0xfe, 0xc7, 0x12, 0x34, 0x8e, 0x68, 0xa0, 0x04, 0x85, 0x40, 0x85, 0x4d, 0x49, 0x08, 0x07, 0xfe, 0x4f, 0x5e, 0x81, 0x06, 0x4e, 0x33, 0x4e, 0x22, 0x2f, 0x18, 0x0a, 0xfe, 0x04, 0x06, 0x1d, 0x21, 0x42, 0xda, 0x50, 0x76, 0x47, 0x92, 0x37, 0xd9, 0xbf, 0x4c, 0x88, 0xc6, 0xee, 0x74, 0xc4, 0xe4, 0x4d, 0xed, 0x5a, 0xd3, 0x69, 0x08, 0x6c, 0x8f, 0x6d, 0xdb, 0x2d, 0x58, 0xd6, 0x49, 0x64, 0xeb, 0x55, 0x6c, 0x7d, 0x49, 0xa3, 0x14, 0x9d, 0xdc, 0x84, 0x45, 0x49, 0x1f, 0xf1, 0xc1, 0xe2, 0x3e, 0xd6, 0x9d, 0x96, 0x80, 0xe5, 0x14, 0xd6, 0xa1, 0x7d, 0xe2, 0x05, 0xae, 0xdf, 0xeb, 0xfb, 0xc9, 0x59, 0x6f, 0x40, 0xfd, 0xc4, 0xc5, 0x1d, 0xad, 0x3a, 0x2d, 0xc4, 0xb7, 0xfd, 0xe4, 0x6c, 0x87, 0xa1, 0xe4, 0x75, 0xa8, 0x9f, 0x50, 0xda, 0xc3, 0x95, 0xe8, 0xd4, 0x0c, 0xe9, 0x90, 0xab, 0xeb, 0xd4, 0x4e, 0xe4, 0x3a, 0xaf, 0x43, 0x3b, 0x9c, 0x24, 0xc3, 0xd0, 0x0b, 0x86, 0xbd, 0xfe, 0xa9, 0x1b, 0xf4, 0xbc, 0x41, 0xa7, 0x7e, 0xdd, 0x5a, 0xaf, 0x38, 0x2d, 0x89, 0x33, 0xad, 0xf0, 0x60, 0x60, 0xff, 0x99, 0x05, 0x4d, 0xbe, 0xa8, 0xc2, 0xa0, 0xdc, 0x80, 0x05, 0x39, 0x76, 0x1a, 0x45, 0x61, 0x24, 0x04, 0xc5, 0x04, 0xc9, 0x06, 0xb4, 0x25, 0x30, 0x8e, 0xa8, 0x37, 0x72, 0x87, 0x54, 0x68, 0x9f, 0x1c, 0x4e, 0xee, 0xa4, 0x2d, 0x46, 0xe1, 0x24, 0xe1, 0x2a, 0xbd, 0x71, 0xa7, 0x29, 0x86, 0xef, 0x30, 0xcc, 0x31, 0x49, 0x98, 0xa0, 0x14, 0x6c, 0x8a, 0x81, 0xd9, 0xdf, 0xb3, 0x80, 0xb0, 0xa1, 0x3f, 0x0a, 0x79, 0x13, 0x62, 0x4d, 0xb3, 0xfb, 0x69, 0xbd, 0xf0, 0x7e, 0x96, 0x66, 0xed, 0xe7, 0x3a, 0xcc, 0xe1, 0xb0, 0x98, 0xe4, 0x97, 0xb3, 0x43, 0xbf, 0x5b, 0xea, 0x58, 0x8e, 0xa8, 0x27, 0x36, 0x54, 0xf9, 0x1c, 0x2b, 0x05, 0x73, 0xe4, 0x55, 0xf6, 0x77, 0x2c, 0x68, 0xb2, 0xd5, 0x0f, 0xa8, 0x8f, 0x5a, 0x8d, 0xdc, 0x06, 0x72, 0x32, 0x09, 0x06, 0x6c, 0xb3, 0x92, 0x67, 0xde, 0xa0, 0x77, 0x3c, 0x65, 0x5d, 0xe1, 0xb8, 0xf7, 0x2e, 0x39, 0x05, 0x75, 0xe4, 0x75, 0x68, 0x1b, 0x68, 0x9c, 0x44, 0x7c, 0xf4, 0x7b, 0x97, 0x9c, 0x5c, 0x0d, 0x5b, 0x4c, 0xa6, 0x37, 0x27, 0x49, 0xcf, 0x0b, 0x06, 0xf4, 0x19, 0xae, 0xff, 0x82, 0x63, 0x60, 0x77, 0x5b, 0xd0, 0xd4, 0xbf, 0xb3, 0xdf, 0x87, 0x9a, 0xd4, 0xba, 0xa8, 0x71, 0x32, 0xe3, 0x72, 0x34, 0x84, 0x74, 0xa1, 0x66, 0x8e, 0xc2, 0xa9, 0x7d, 0x94, 0xbe, 0xed, 0xcf, 0x41, 0x7b, 0x9f, 0xa9, 0xbe, 0xc0, 0x0b, 0x86, 0xc2, 0xec, 0x30, 0x7d, 0x3c, 0x9e, 0x1c, 0x3f, 0xa5, 0x53, 0xc1, 0x7f, 0xa2, 0xc4, 0x84, 0xfe, 0x34, 0x8c, 0x13, 0xd1, 0x0f, 0xfe, 0x6f, 0xff, 0xab, 0x05, 0x8b, 0x8c, 0x11, 0xde, 0x75, 0x83, 0xa9, 0xe4, 0x82, 0x7d, 0x68, 0xb2, 0xa6, 0x1e, 0x85, 0x5b, 0x5c, 0xab, 0x73, 0x6d, 0xb5, 0x2e, 0xf6, 0x23, 0x43, 0x7d, 0x4b, 0x27, 0x65, 0xce, 0xd6, 0xd4, 0x31, 0xbe, 0x66, 0x6a, 0x25, 0x71, 0xa3, 0x21, 0x4d, 0x50, 0xdf, 0x0b, 0xfd, 0x0f, 0x1c, 0xda, 0x0e, 0x83, 0x13, 0x72, 0x1d, 0x9a, 0xb1, 0x9b, 0xf4, 0xc6, 0x34, 0xc2, 0x35, 0x41, 0xd5, 0x50, 0x76, 0x20, 0x76, 0x93, 0x43, 0x1a, 0xdd, 0x9d, 0x26, 0xb4, 0xfb, 0x33, 0xb0, 0x94, 0xeb, 0x85, 0x69, 0xa3, 0x74, 0x8a, 0xec, 0x5f, 0xb2, 0x02, 0xd5, 0x33, 0xd7, 0x9f, 0x50, 0x61, 0x86, 0x78, 0xe1, 0xed, 0xd2, 0x5b, 0x96, 0xfd, 0x1a, 0xb4, 0xd3, 0x61, 0x0b, 0x61, 0x25, 0x50, 0x61, 0x2b, 0x2d, 0x1a, 0xc0, 0xff, 0xed, 0x6f, 0x5b, 0x9c, 0x70, 0x3b, 0xf4, 0x94, 0x4a, 0x67, 0x84, 0x4c, 0xf3, 0x4b, 0x42, 0xf6, 0xff, 0x4c, 0x93, 0xf7, 0xa3, 0x4f, 0x96, 0x5c, 0x81, 0x5a, 0x4c, 0x83, 0x41, 0xcf, 0xf5, 0x7d, 0xd4, 0x7c, 0x35, 0x67, 0x9e, 0x95, 0xb7, 0x7c, 0xdf, 0xbe, 0x09, 0x4b, 0xda, 0xe8, 0x9e, 0x33, 0x8f, 0x03, 0x20, 0xfb, 0x5e, 0x9c, 0x3c, 0x0e, 0xe2, 0xb1, 0xa6, 0x31, 0x5f, 0x82, 0xfa, 0xc8, 0x0b, 0x70, 0x64, 0x9c, 0x15, 0xab, 0x4e, 0x6d, 0xe4, 0x05, 0x6c, 0x5c, 0x31, 0x56, 0xba, 0xcf, 0x44, 0x65, 0x49, 0x54, 0xba, 0xcf, 0xb0, 0xd2, 0x7e, 0x0b, 0x96, 0x8d, 0xf6, 0x44, 0xd7, 0xaf, 0x42, 0x75, 0x92, 0x3c, 0x0b, 0xa5, 0x3d, 0x6b, 0x08, 0x0e, 0x61, 0x9e, 0x91, 0xc3, 0x6b, 0xec, 0x77, 0x60, 0xe9, 0x80, 0x9e, 0x0b, 0xce, 0x94, 0x03, 0x79, 0xed, 0x42, 0xaf, 0x09, 0xeb, 0xed, 0x5b, 0x40, 0xf4, 0x8f, 0x45, 0xaf, 0x9a, 0x0f, 0x65, 0x19, 0x3e, 0x94, 0xfd, 0x1a, 0x90, 0x23, 0x6f, 0x18, 0xbc, 0x4b, 0xe3, 0xd8, 0x1d, 0x2a, 0xa5, 0xd6, 0x86, 0xf2, 0x28, 0x1e, 0x0a, 0xd9, 0x63, 0xff, 0xda, 0x9f, 0x84, 0x65, 0x83, 0x4e, 0x34, 0x7c, 0x15, 0xea, 0xb1, 0x37, 0x0c, 0xdc, 0x64, 0x12, 0x51, 0xd1, 0x74, 0x0a, 0xd8, 0xf7, 0x60, 0xe5, 0x4b, 0x34, 0xf2, 0x4e, 0xa6, 0x17, 0x35, 0x6f, 0xb6, 0x53, 0xca, 0xb6, 0xb3, 0x0b, 0xab, 0x99, 0x76, 0x44, 0xf7, 0x9c, 0x7d, 0xc5, 0x4e, 0xd6, 0x1c, 0x5e, 0xd0, 0x84, 0xb9, 0xa4, 0x0b, 0xb3, 0xfd, 0x18, 0xc8, 0x76, 0x18, 0x04, 0xb4, 0x9f, 0x1c, 0x52, 0x1a, 0xa5, 0xa7, 0xa6, 0x94, 0x57, 0x1b, 0x77, 0x2e, 0x8b, 0x95, 0xcd, 0x6a, 0x08, 0xc1, 0xc4, 0x04, 0x2a, 0x63, 0x1a, 0x8d, 0xb0, 0xe1, 0x9a, 0x83, 0xff, 0xdb, 0xab, 0xb0, 0x6c, 0x34, 0x2b, 0x1c, 0xde, 0x37, 0x60, 0x75, 0xc7, 0x8b, 0xfb, 0xf9, 0x0e, 0x3b, 0x30, 0x3f, 0x9e, 0x1c, 0xf7, 0x52, 0x49, 0x94, 0x45, 0xe6, 0x23, 0x65, 0x3f, 0x11, 0x8d, 0xfd, 0xaa, 0x05, 0x95, 0xbd, 0x47, 0xfb, 0xdb, 0x4c, 0xf9, 0x79, 0x41, 0x3f, 0x1c, 0x31, 0x03, 0xc2, 0x27, 0xad, 0xca, 0x33, 0x25, 0xec, 0x2a, 0xd4, 0xd1, 0xee, 0x30, 0xb7, 0x4f, 0x1c, 0x70, 0x52, 0x80, 0xb9, 0x9c, 0xf4, 0xd9, 0xd8, 0x8b, 0xd0, 0xa7, 0x94, 0x9e, 0x62, 0x05, 0xf5, 0x66, 0xbe, 0xc2, 0xfe, 0x76, 0x15, 0xe6, 0x85, 0x35, 0xc1, 0xfe, 0xfa, 0x89, 0x77, 0x46, 0xc5, 0x48, 0x44, 0x89, 0xd9, 0xf4, 0x88, 0x8e, 0xc2, 0x84, 0xf6, 0x8c, 0x6d, 0x30, 0x41, 0x74, 0xa9, 0x79, 0x43, 0x3d, 0xee, 0x84, 0x97, 0x39, 0x95, 0x01, 0xb2, 0xc5, 0x92, 0x1e, 0x45, 0x05, 0x3d, 0x0a, 0x59, 0x64, 0x2b, 0xd1, 0x77, 0xc7, 0x6e, 0xdf, 0x4b, 0xa6, 0x42, 0x25, 0xa8, 0x32, 0x6b, 0xdb, 0x0f, 0xfb, 0xae, 0xdf, 0x3b, 0x76, 0x7d, 0x37, 0xe8, 0x53, 0xe9, 0xae, 0x1b, 0x20, 0x73, 0x5d, 0xc5, 0x90, 0x24, 0x19, 0x77, 0x6f, 0x33, 0x28, 0x33, 0x48, 0xfd, 0x70, 0x34, 0xf2, 0x12, 0xe6, 0xf1, 0xa2, 0x37, 0x54, 0x76, 0x34, 0x84, 0x1f, 0x0e, 0xb0, 0x74, 0xce, 0x57, 0xaf, 0x2e, 0x0f, 0x07, 0x1a, 0xc8, 0x5a, 0x61, 0x2e, 0x15, 0x53, 0x63, 0x4f, 0xcf, 0x3b, 0xc0, 0x5b, 0x49, 0x11, 0xb6, 0x0f, 0x93, 0x20, 0xa6, 0x49, 0xe2, 0xd3, 0x81, 0x1a, 0x50, 0x03, 0xc9, 0xf2, 0x15, 0xe4, 0x36, 0x2c, 0x73, 0x27, 0x3c, 0x76, 0x93, 0x30, 0x3e, 0xf5, 0xe2, 0x5e, 0xcc, 0xdc, 0xd9, 0x26, 0xd2, 0x17, 0x55, 0x91, 0xb7, 0xe0, 0x72, 0x06, 0x8e, 0x68, 0x9f, 0x7a, 0x67, 0x74, 0xd0, 0x59, 0xc0, 0xaf, 0x66, 0x55, 0x93, 0xeb, 0xd0, 0x60, 0x67, 0x8f, 0xc9, 0x78, 0xe0, 0x32, 0x8b, 0xdc, 0xc2, 0x7d, 0xd0, 0x21, 0xf2, 0x06, 0x2c, 0x8c, 0x29, 0x37, 0xe7, 0xa7, 0x89, 0xdf, 0x8f, 0x3b, 0x8b, 0x86, 0x76, 0x63, 0x9c, 0xeb, 0x98, 0x14, 0x8c, 0x29, 0xfb, 0x31, 0x3a, 0xa1, 0xee, 0xb4, 0xd3, 0x46, 0x76, 0x4b, 0x01, 0x94, 0x91, 0xc8, 0x3b, 0x73, 0x13, 0xda, 0x59, 0xe2, 0x0a, 0x5d, 0x14, 0xd9, 0x77, 0x5e, 0xe0, 0x25, 0x9e, 0x9b, 0x84, 0x51, 0x87, 0x60, 0x5d, 0x0a, 0xd8, 0x7f, 0x60, 0x71, 0xb5, 0x2b, 0x58, 0x54, 0xa9, 0xcf, 0x57, 0xa0, 0xc1, 0x99, 0xb3, 0x17, 0x06, 0xfe, 0x54, 0xf0, 0x2b, 0x70, 0xe8, 0x61, 0xe0, 0x4f, 0xc9, 0xc7, 0x60, 0xc1, 0x0b, 0x74, 0x12, 0x2e, 0xe1, 0x4d, 0x09, 0x22, 0xd1, 0x2b, 0xd0, 0x18, 0x4f, 0x8e, 0x7d, 0xaf, 0xcf, 0x49, 0xca, 0xbc, 0x15, 0x0e, 0x21, 0x01, 0x73, 0x06, 0xf9, 0x38, 0x39, 0x45, 0x05, 0x29, 0x1a, 0x02, 0x63, 0x24, 0xf6, 0x5d, 0x58, 0x31, 0x07, 0x28, 0x54, 0xd9, 0x06, 0xd4, 0x04, 0xe7, 0xc7, 0x9d, 0x06, 0xae, 0x5e, 0x4b, 0xac, 0x9e, 0x20, 0x75, 0x54, 0xbd, 0xfd, 0xfd, 0x0a, 0x2c, 0x0b, 0x74, 0xdb, 0x0f, 0x63, 0x7a, 0x34, 0x19, 0x8d, 0xdc, 0xa8, 0x40, 0xa4, 0xac, 0x0b, 0x44, 0xaa, 0x64, 0x8a, 0x14, 0x63, 0xf4, 0x53, 0xd7, 0x0b, 0xb8, 0x27, 0xcb, 0xe5, 0x51, 0x43, 0xc8, 0x3a, 0x2c, 0xf6, 0xfd, 0x30, 0xe6, 0x5e, 0x9b, 0x7e, 0xe8, 0xcc, 0xc2, 0x79, 0x15, 0x50, 0x2d, 0x52, 0x01, 0xba, 0x08, 0xcf, 0x65, 0x44, 0xd8, 0x86, 0x26, 0x6b, 0x94, 0x4a, 0x8d, 0x34, 0xcf, 0x3d, 0x39, 0x1d, 0x63, 0xe3, 0xc9, 0x0a, 0x0c, 0x97, 0xce, 0xc5, 0x22, 0x71, 0x61, 0x67, 0x5a, 0xa6, 0xf1, 0x34, 0xea, 0xba, 0x10, 0x97, 0x7c, 0x15, 0xb9, 0x07, 0xc0, 0xfb, 0x42, 0xb3, 0x0b, 0x68, 0x76, 0x5f, 0x33, 0x77, 0x44, 0x5f, 0xfb, 0x5b, 0xac, 0x30, 0x89, 0x28, 0x9a, 0x62, 0xed, 0x4b, 0xfb, 0xd7, 0x2c, 0x68, 0x68, 0x75, 0x64, 0x15, 0x96, 0xb6, 0x1f, 0x3e, 0x3c, 0xdc, 0x75, 0xb6, 0x1e, 0x3d, 0xf8, 0xd2, 0x6e, 0x6f, 0x7b, 0xff, 0xe1, 0xd1, 0x6e, 0xfb, 0x12, 0x83, 0xf7, 0x1f, 0x6e, 0x6f, 0xed, 0xf7, 0xee, 0x3d, 0x74, 0xb6, 0x25, 0x6c, 0x91, 0x35, 0x20, 0xce, 0xee, 0xbb, 0x0f, 0x1f, 0xed, 0x1a, 0x78, 0x89, 0xb4, 0xa1, 0x79, 0xd7, 0xd9, 0xdd, 0xda, 0xde, 0x13, 0x48, 0x99, 0xac, 0x40, 0xfb, 0xde, 0xe3, 0x83, 0x9d, 0x07, 0x07, 0xf7, 0x7b, 0xdb, 0x5b, 0x07, 0xdb, 0xbb, 0xfb, 0xbb, 0x3b, 0xed, 0x0a, 0x59, 0x80, 0xfa, 0xd6, 0xdd, 0xad, 0x83, 0x9d, 0x87, 0x07, 0xbb, 0x3b, 0xed, 0xaa, 0xfd, 0xcf, 0x16, 0xac, 0xe2, 0xa8, 0x07, 0x59, 0x01, 0xb9, 0x0e, 0x8d, 0x7e, 0x18, 0x8e, 0x29, 0xd3, 0xf6, 0x4a, 0xa1, 0xeb, 0x10, 0x63, 0x7e, 0xae, 0x3e, 0x4f, 0xc2, 0xa8, 0x4f, 0x85, 0x7c, 0x00, 0x42, 0xf7, 0x18, 0xc2, 0x98, 0x5f, 0x6c, 0x2f, 0xa7, 0xe0, 0xe2, 0xd1, 0xe0, 0x18, 0x27, 0x59, 0x83, 0xb9, 0xe3, 0x88, 0xba, 0xfd, 0x53, 0x21, 0x19, 0xa2, 0x44, 0x3e, 0x9e, 0x1e, 0x30, 0xfa, 0x6c, 0xf5, 0x7d, 0x3a, 0x40, 0x8e, 0xa9, 0x39, 0x8b, 0x02, 0xdf, 0x16, 0x30, 0x93, 0x7f, 0xf7, 0xd8, 0x0d, 0x06, 0x61, 0x40, 0x07, 0xc2, 0xd9, 0x4b, 0x01, 0xfb, 0x10, 0xd6, 0xb2, 0xf3, 0x13, 0xf2, 0xf5, 0xa6, 0x26, 0x5f, 0xdc, 0xf7, 0xea, 0xce, 0xde, 0x4d, 0x4d, 0xd6, 0xfe, 0xc3, 0x82, 0x0a, 0x33, 0xc5, 0xb3, 0xcd, 0xb6, 0xee, 0x5d, 0x95, 0x73, 0x11, 0x2a, 0x3c, 0xb3, 0x70, 0xe5, 0xcc, 0x0d, 0x98, 0x86, 0xa4, 0xf5, 0x11, 0xed, 0x9f, 0xe1, 0x8c, 0x55, 0x3d, 0x43, 0x98, 0x80, 0x30, 0xd7, 0x17, 0xbf, 0x16, 0x02, 0x22, 0xcb, 0xb2, 0x0e, 0xbf, 0x9c, 0x4f, 0xeb, 0xf0, 0xbb, 0x0e, 0xcc, 0x7b, 0xc1, 0x71, 0x38, 0x09, 0x06, 0x28, 0x10, 0x35, 0x47, 0x16, 0x31, 0x26, 0x86, 0x82, 0xea, 0x8d, 0x24, 0xfb, 0xa7, 0x80, 0x4d, 0xd8, 0xd1, 0x28, 0x46, 0xd7, 0x43, 0x85, 0x67, 0xde, 0x84, 0x25, 0x0d, 0x4b, 0xdd, 0xd8, 0x31, 0x03, 0x32, 0x6e, 0x2c, 0xfa, 0x2c, 0xbc, 0xc6, 0x6e, 0x43, 0xeb, 0x3e, 0x4d, 0x1e, 0x04, 0x27, 0xa1, 0x6c, 0xe9, 0x8f, 0x2b, 0xb0, 0xa8, 0x20, 0xd1, 0xd0, 0x3a, 0x2c, 0x7a, 0x03, 0x1a, 0x24, 0x5e, 0x32, 0xed, 0x19, 0x27, 0xb0, 0x2c, 0xcc, 0x7c, 0x3d, 0xd7, 0xf7, 0x5c, 0x19, 0x05, 0xe4, 0x05, 0x72, 0x07, 0x56, 0x98, 0x21, 0x92, 0xb6, 0x45, 0x6d, 0x31, 0x3f, 0xf8, 0x15, 0xd6, 0x31, 0x65, 0xc0, 0x70, 0xa1, 0xed, 0xd5, 0x27, 0xdc, 0xe7, 0x29, 0xaa, 0x62, 0xab, 0xc6, 0x5b, 0x62, 0x53, 0xae, 0x72, 0x63, 0xa5, 0x80, 0x5c, 0x98, 0x6d, 0x8e, 0xab, 0xaa, 0x6c, 0x98, 0x4d, 0x0b, 0xd5, 0xd5, 0x72, 0xa1, 0x3a, 0xa6, 0xca, 0xa6, 0x41, 0x9f, 0x0e, 0x7a, 0x49, 0xd8, 0x43, 0x95, 0x8b, 0xbb, 0x53, 0x73, 0xb2, 0x30, 0xb9, 0x0a, 0xf3, 0x09, 0x8d, 0x93, 0x80, 0x26, 0xa8, 0x95, 0x6a, 0x18, 0x10, 0x90, 0x10, 0x73, 0x50, 0x27, 0x91, 0x17, 0x77, 0x9a, 0x18, 0x84, 0xc3, 0xff, 0xc9, 0xa7, 0x60, 0xf5, 0x98, 0xc6, 0x49, 0xef, 0x94, 0xba, 0x03, 0x1a, 0xe1, 0x4e, 0xf3, 0x68, 0x1f, 0xb7, 0xfb, 0xc5, 0x95, 0x8c, 0x87, 0xce, 0x68, 0x14, 0x7b, 0x61, 0x80, 0x16, 0xbf, 0xee, 0xc8, 0x22, 0x6b, 0x8f, 0x4d, 0x5e, 0xd9, 0x4b, 0xb5, 0x82, 0x8b, 0x38, 0xf1, 0xe2, 0x4a, 0x72, 0x03, 0xe6, 0x70, 0x02, 0x71, 0xa7, 0x6d, 0x44, 0x35, 0xb6, 0x19, 0xe8, 0x88, 0xba, 0xcf, 0x57, 0x6a, 0x8d, 0x76, 0xd3, 0xfe, 0x29, 0xa8, 0x22, 0xcc, 0x36, 0x9d, 0x2f, 0x06, 0x67, 0x0a, 0x5e, 0x60, 0x43, 0x0b, 0x68, 0x72, 0x1e, 0x46, 0x4f, 0x65, 0x48, 0x58, 0x14, 0xed, 0x6f, 0xa0, 0x8b, 0xaf, 0x42, 0xa4, 0x8f, 0xd1, 0x3f, 0x61, 0x07, 0x35, 0xbe, 0xd4, 0xf1, 0xa9, 0x2b, 0x4e, 0x1d, 0x35, 0x04, 0x8e, 0x4e, 0x5d, 0xa6, 0xb6, 0x8c, 0xdd, 0xe3, 0x07, 0xb9, 0x06, 0x62, 0x7b, 0x7c, 0xf3, 0x6e, 0x40, 0x4b, 0x06, 0x5f, 0xe3, 0x9e, 0x4f, 0x4f, 0x12, 0x19, 0x57, 0x08, 0x26, 0x23, 0x3c, 0xed, 0xed, 0xd3, 0x93, 0xc4, 0x3e, 0x80, 0x25, 0xa1, 0x4a, 0x1e, 0x8e, 0xa9, 0xec, 0xfa, 0x33, 0x45, 0x26, 0xb9, 0x71, 0x67, 0xd9, 0xd4, 0x3d, 0x3c, 0xdc, 0x6c, 0x52, 0xda, 0x0e, 0x10, 0x5d, 0x35, 0x89, 0x06, 0x85, 0x5d, 0x94, 0x91, 0x13, 0x31, 0x1d, 0x03, 0x63, 0xeb, 0x13, 0x4f, 0xfa, 0x7d, 0x19, 0x32, 0x67, 0xc7, 0x61, 0x5e, 0xb4, 0xff, 0xc4, 0x82, 0x65, 0x6c, 0x4d, 0x3a, 0x15, 0x42, 0xfd, 0xbf, 0xf5, 0x11, 0x86, 0xd9, 0xec, 0xeb, 0xd1, 0xa4, 0x15, 0xa8, 0xea, 0x06, 0x81, 0x17, 0x3e, 0xfa, 0xa1, 0xbe, 0x92, 0x3d, 0xd4, 0xdb, 0xbf, 0x6b, 0xc1, 0x12, 0xd7, 0xc9, 0x89, 0x9b, 0x4c, 0x62, 0x31, 0xfd, 0x9f, 0x86, 0x05, 0x6e, 0x5c, 0x85, 0x54, 0x8b, 0x81, 0xae, 0x28, 0x05, 0x84, 0x28, 0x27, 0xde, 0xbb, 0xe4, 0x98, 0xc4, 0xe4, 0x1d, 0x74, 0x70, 0x82, 0x1e, 0xa2, 0x22, 0x30, 0x78, 0xa5, 0xc0, 0x0c, 0xa8, 0xef, 0x35, 0xf2, 0xbb, 0x35, 0x98, 0xe3, 0xfe, 0xae, 0x7d, 0x1f, 0x16, 0x8c, 0x8e, 0x8c, 0x80, 0x42, 0x93, 0x07, 0x14, 0x72, 0xa1, 0xa8, 0x52, 0x41, 0x28, 0xea, 0x4f, 0xcb, 0x40, 0x18, 0xb3, 0x64, 0x76, 0x83, 0x39, 0xdc, 0xe1, 0xc0, 0x38, 0x3e, 0x35, 0x1d, 0x1d, 0x22, 0xb7, 0x80, 0x68, 0x45, 0x19, 0x51, 0xe4, 0xd6, 0xa7, 0xa0, 0x86, 0xa9, 0x49, 0x61, 0xbc, 0x85, 0x99, 0x15, 0x07, 0x45, 0xbe, 0xec, 0x85, 0x75, 0xcc, 0xc0, 0x8c, 0x27, 0xf1, 0x29, 0x5e, 0xae, 0x88, 0x03, 0x96, 0x2c, 0x67, 0xf7, 0x77, 0xee, 0xc2, 0xfd, 0x9d, 0xcf, 0x05, 0x6d, 0x34, 0x17, 0xbf, 0x66, 0xba, 0xf8, 0x37, 0x60, 0x61, 0xc4, 0x5c, 0xce, 0xc4, 0xef, 0xf7, 0x46, 0xac, 0x77, 0x71, 0x9e, 0x32, 0x40, 0xb2, 0x01, 0x6d, 0xe1, 0x6e, 0xa4, 0xe7, 0x08, 0xc0, 0x35, 0xce, 0xe1, 0x4c, 0x7f, 0xa7, 0x61, 0x9c, 0x06, 0x0e, 0x36, 0x05, 0xd8, 0xc9, 0x2b, 0x66, 0x1c, 0xd2, 0x9b, 0x04, 0xe2, 0x7e, 0x85, 0x0e, 0xf0, 0x24, 0x55, 0x73, 0xf2, 0x15, 0xf6, 0x6f, 0x5b, 0xd0, 0x66, 0x7b, 0x66, 0xb0, 0xe5, 0xdb, 0x80, 0x52, 0xf1, 0x82, 0x5c, 0x69, 0xd0, 0x92, 0xb7, 0xa0, 0x8e, 0xe5, 0x70, 0x4c, 0x03, 0xc1, 0x93, 0x1d, 0x93, 0x27, 0x53, 0x7d, 0xb2, 0x77, 0xc9, 0x49, 0x89, 0x35, 0x8e, 0xfc, 0x7b, 0x0b, 0x1a, 0xa2, 0x97, 0x1f, 0x3a, 0x4c, 0xd0, 0xd5, 0x2e, 0xc4, 0x38, 0x27, 0xa5, 0xf7, 0x5f, 0xeb, 0xb0, 0x38, 0x72, 0x93, 0x49, 0xc4, 0xec, 0xb1, 0x11, 0x22, 0xc8, 0xc2, 0xcc, 0xb8, 0xa2, 0xea, 0x8c, 0x7b, 0x89, 0xe7, 0xf7, 0x64, 0xad, 0xb8, 0x7a, 0x2a, 0xaa, 0x62, 0x1a, 0x24, 0x4e, 0xdc, 0x21, 0x15, 0x76, 0x93, 0x17, 0xec, 0x0e, 0xac, 0x89, 0x09, 0x65, 0x5c, 0x55, 0xfb, 0x2f, 0x9b, 0x70, 0x39, 0x57, 0xa5, 0xee, 0xa7, 0xc5, 0xd9, 0xd7, 0xf7, 0x46, 0xc7, 0xa1, 0xf2, 0xf3, 0x2d, 0xfd, 0x58, 0x6c, 0x54, 0x91, 0x21, 0xac, 0x4a, 0x07, 0x81, 0xad, 0x69, 0x6a, 0xcc, 0x4a, 0x68, 0xa5, 0xde, 0x30, 0xb7, 0x30, 0xdb, 0xa1, 0xc4, 0x75, 0x21, 0x2e, 0x6e, 0x8f, 0x9c, 0x42, 0x47, 0x79, 0x22, 0x42, 0x59, 0x6b, 0xde, 0x0a, 0xeb, 0xeb, 0xf5, 0x0b, 0xfa, 0x32, 0x3c, 0x5b, 0x67, 0x66, 0x6b, 0x64, 0x0a, 0xd7, 0x64, 0x1d, 0x6a, 0xe3, 0x7c, 0x7f, 0x95, 0x17, 0x9a, 0x1b, 0xfa, 0xec, 0x66, 0xa7, 0x17, 0x34, 0x4c, 0xde, 0x87, 0xb5, 0x73, 0xd7, 0x4b, 0xe4, 0xb0, 0x34, 0xdf, 0xa0, 0x8a, 0x5d, 0xde, 0xb9, 0xa0, 0xcb, 0x27, 0xfc, 0x63, 0xc3, 0x44, 0xcd, 0x68, 0xb1, 0xfb, 0xb7, 0x16, 0xb4, 0xcc, 0x76, 0x18, 0x9b, 0x0a, 0xd9, 0x97, 0x3a, 0x50, 0x7a, 0x93, 0x19, 0x38, 0x7f, 0x54, 0x2e, 0x15, 0x1d, 0x95, 0xf5, 0x03, 0x6a, 0xf9, 0xa2, 0x18, 0x53, 0xe5, 0xc5, 0x62, 0x4c, 0xd5, 0xa2, 0x18, 0x53, 0xf7, 0xbf, 0x2d, 0x20, 0x79, 0x5e, 0x22, 0xf7, 0xf9, 0x59, 0x3d, 0xa0, 0xbe, 0x50, 0x29, 0x3f, 0xf9, 0x62, 0xfc, 0x28, 0xd7, 0x4e, 0x7e, 0xcd, 0x04, 0x43, 0xbf, 0x3b, 0xd6, 0x9d, 0x9d, 0x05, 0xa7, 0xa8, 0x2a, 0x13, 0xf5, 0xaa, 0x5c, 0x1c, 0xf5, 0xaa, 0x5e, 0x1c, 0xf5, 0x9a, 0xcb, 0x46, 0xbd, 0xba, 0xbf, 0x62, 0xc1, 0x72, 0xc1, 0xa6, 0xff, 0xf8, 0x26, 0xce, 0xb6, 0xc9, 0xd0, 0x05, 0x25, 0xb1, 0x4d, 0x3a, 0xd8, 0xfd, 0x05, 0x58, 0x30, 0x18, 0xfd, 0xc7, 0xd7, 0x7f, 0xd6, 0x5f, 0xe3, 0x7c, 0x66, 0x60, 0xdd, 0xff, 0x2c, 0x01, 0xc9, 0x0b, 0xdb, 0xff, 0xeb, 0x18, 0xf2, 0xeb, 0x54, 0x2e, 0x58, 0xa7, 0xff, 0x53, 0x3b, 0xf0, 0x3a, 0x2c, 0x89, 0x64, 0x16, 0x2d, 0x42, 0xc3, 0x39, 0x26, 0x5f, 0xc1, 0x3c, 0x56, 0x33, 0xe4, 0x58, 0x33, 0x12, 0x04, 0x34, 0x63, 0x98, 0x89, 0x3c, 0xda, 0x5d, 0xe8, 0x88, 0x15, 0xda, 0x3d, 0xa3, 0x41, 0x72, 0x34, 0x39, 0xe6, 0x19, 0x21, 0x5e, 0x18, 0xd8, 0xdf, 0x2b, 0x2b, 0xa7, 0x1b, 0x2b, 0x85, 0x79, 0xff, 0x14, 0x34, 0x75, 0x65, 0x2e, 0xb6, 0x23, 0x13, 0xa0, 0x63, 0x86, 0x5d, 0xa7, 0x22, 0x3b, 0xd0, 0x42, 0x95, 0x35, 0x50, 0xdf, 0x95, 0xf0, 0xbb, 0xe7, 0x04, 0x1e, 0xf6, 0x2e, 0x39, 0x99, 0x6f, 0xc8, 0x67, 0xa1, 0x65, 0x1e, 0xa5, 0x84, 0x8f, 0x50, 0xe4, 0x9b, 0xb3, 0xcf, 0x4d, 0x62, 0xb2, 0x05, 0xed, 0xec, 0x59, 0x4c, 0xdc, 0x16, 0xcf, 0x68, 0x20, 0x47, 0x4e, 0xde, 0x12, 0x77, 0x4f, 0x55, 0x0c, 0x82, 0xdd, 0x30, 0x3f, 0xd3, 0x96, 0xe9, 0x16, 0xff, 0xa3, 0xdd, 0x46, 0x7d, 0x15, 0x20, 0xc5, 0x48, 0x1b, 0x9a, 0x0f, 0x0f, 0x77, 0x0f, 0x7a, 0xdb, 0x7b, 0x5b, 0x07, 0x07, 0xbb, 0xfb, 0xed, 0x4b, 0x84, 0x40, 0x0b, 0xe3, 0x57, 0x3b, 0x0a, 0xb3, 0x18, 0xb6, 0xb5, 0xcd, 0x63, 0x63, 0x02, 0x2b, 0x91, 0x15, 0x68, 0x3f, 0x38, 0xc8, 0xa0, 0xe5, 0xbb, 0x75, 0x25, 0x1f, 0xf6, 0x1a, 0xac, 0xf0, 0x84, 0xa7, 0xbb, 0x9c, 0x3d, 0xa4, 0xaf, 0xf0, 0xfb, 0x16, 0xac, 0x66, 0x2a, 0xd2, 0xc4, 0x03, 0xee, 0x0e, 0x98, 0x3e, 0x82, 0x09, 0x32, 0x9e, 0x54, 0x9e, 0x5f, 0x46, 0x83, 0xe4, 0x2b, 0x18, 0xcf, 0x6b, 0x9e, 0x62, 0x46, 0x92, 0x8a, 0xaa, 0xec, 0xcb, 0x3c, 0x2d, 0x2b, 0xa0, 0x7e, 0x66, 0xe0, 0x27, 0x3c, 0x91, 0x4a, 0xaf, 0x48, 0xef, 0xf2, 0xcc, 0x21, 0xcb, 0x22, 0x73, 0xf2, 0x0d, 0xd7, 0xc3, 0x1c, 0x6f, 0x61, 0x9d, 0xfd, 0x7d, 0x0b, 0xc8, 0x17, 0x27, 0x34, 0x9a, 0x62, 0xce, 0x80, 0x0a, 0x07, 0x5e, 0xce, 0x06, 0xbb, 0xe6, 0xc6, 0x93, 0xe3, 0x2f, 0xd0, 0xa9, 0x4c, 0x68, 0x29, 0xa5, 0x09, 0x2d, 0x2f, 0x03, 0xb0, 0xc3, 0xb1, 0xca, 0x58, 0x40, 0xe7, 0x3a, 0x98, 0x8c, 0x78, 0x83, 0x85, 0x39, 0x27, 0x95, 0x8b, 0x73, 0x4e, 0xaa, 0x17, 0xe4, 0x9c, 0xd8, 0xef, 0xc0, 0xb2, 0x31, 0x6e, 0xb5, 0xad, 0x32, 0x77, 0xc2, 0xca, 0xe7, 0x4e, 0xc8, 0xbc, 0x09, 0xfb, 0x9b, 0x25, 0x28, 0xef, 0x85, 0x63, 0x3d, 0x14, 0x6e, 0x99, 0xa1, 0x70, 0xe1, 0x1f, 0xf4, 0x94, 0xf9, 0x17, 0x66, 0xc3, 0x00, 0xc9, 0x06, 0xb4, 0xdc, 0x51, 0xd2, 0x4b, 0x42, 0xe6, 0x0f, 0x9d, 0xbb, 0xd1, 0x80, 0xef, 0x35, 0x86, 0x64, 0x32, 0x35, 0x64, 0x05, 0xca, 0xca, 0x90, 0x22, 0x01, 0x2b, 0x32, 0x67, 0x1c, 0x2f, 0xd9, 0xa6, 0x22, 0xac, 0x24, 0x4a, 0x8c, 0x95, 0xcc, 0xef, 0xf9, 0x49, 0x88, 0xab, 0xc3, 0xa2, 0x2a, 0xe6, 0xab, 0xb0, 0xe5, 0x43, 0x32, 0x11, 0x0f, 0x94, 0x65, 0x3d, 0x76, 0x59, 0x33, 0xaf, 0x1c, 0xff, 0xdd, 0x82, 0x2a, 0xae, 0x0d, 0x53, 0xed, 0x9c, 0xf7, 0x55, 0x34, 0x1c, 0xd7, 0x64, 0xc1, 0xc9, 0xc2, 0xc4, 0x36, 0x52, 0xc2, 0x4a, 0x6a, 0x42, 0x7a, 0x5a, 0xd8, 0x75, 0xa8, 0xf3, 0x92, 0x4a, 0x7f, 0x42, 0x92, 0x14, 0x24, 0xd7, 0xa0, 0x72, 0x1a, 0x8e, 0xa5, 0x2f, 0x0a, 0xf2, 0xaa, 0x28, 0x1c, 0x3b, 0x88, 0xa7, 0xe3, 0x61, 0xed, 0xf1, 0x69, 0x71, 0x0f, 0x23, 0x0b, 0x33, 0x1f, 0x4b, 0x35, 0xab, 0x2f, 0x53, 0x06, 0xb5, 0x37, 0x60, 0xf1, 0x20, 0x1c, 0x50, 0x2d, 0x24, 0x39, 0x93, 0xcf, 0xed, 0x5f, 0xb4, 0xa0, 0x26, 0x89, 0xc9, 0x3a, 0x54, 0x98, 0xe3, 0x98, 0x39, 0xd5, 0xa9, 0x2b, 0x62, 0x46, 0xe7, 0x20, 0x05, 0xb3, 0xb4, 0x18, 0x29, 0x4a, 0x0f, 0x11, 0x32, 0x4e, 0x94, 0xfa, 0xc8, 0x6a, 0xb8, 0x19, 0xd7, 0x32, 0x83, 0xda, 0xdf, 0xb5, 0x60, 0xc1, 0xe8, 0x83, 0x5c, 0x87, 0x86, 0xef, 0xc6, 0x89, 0xb8, 0x76, 0x13, 0xdb, 0xa3, 0x43, 0xfa, 0x46, 0x97, 0xcc, 0x20, 0xb5, 0x0a, 0x9f, 0x96, 0xf5, 0xf0, 0xe9, 0x6d, 0xa8, 0xa7, 0x89, 0x7b, 0x15, 0xc3, 0x82, 0xb2, 0x1e, 0xe5, 0xe5, 0x77, 0x4a, 0x84, 0x11, 0xb9, 0xd0, 0x0f, 0x23, 0x71, 0xa3, 0xc3, 0x0b, 0xf6, 0x3b, 0xd0, 0xd0, 0xe8, 0xf5, 0x00, 0x9d, 0x65, 0x04, 0xe8, 0x54, 0x66, 0x48, 0x29, 0xcd, 0x0c, 0xb1, 0xff, 0xc6, 0x82, 0x05, 0xc6, 0x83, 0x5e, 0x30, 0x3c, 0x0c, 0x7d, 0xaf, 0x3f, 0xc5, 0xbd, 0x97, 0xec, 0x26, 0x74, 0x86, 0xe4, 0x45, 0x13, 0x66, 0x5c, 0x2f, 0xc3, 0x02, 0x42, 0x44, 0x55, 0x99, 0xc9, 0x30, 0x93, 0x80, 0x63, 0x37, 0x16, 0x62, 0x21, 0x5c, 0x1a, 0x03, 0x64, 0x92, 0xc6, 0x80, 0xc8, 0x4d, 0x68, 0x6f, 0xe4, 0xf9, 0xbe, 0xc7, 0x69, 0xb9, 0xc3, 0x5b, 0x54, 0xc5, 0xfa, 0x1c, 0x78, 0xb1, 0x7b, 0x9c, 0xde, 0x52, 0xa8, 0xb2, 0xfd, 0xe7, 0x25, 0x68, 0x48, 0xcb, 0x38, 0x18, 0x52, 0x71, 0xa5, 0x86, 0x47, 0x0a, 0xa5, 0x64, 0x34, 0x44, 0xd6, 0x1b, 0x87, 0x10, 0x0d, 0xc9, 0x6e, 0x79, 0x39, 0xbf, 0xe5, 0x57, 0xa1, 0xce, 0x58, 0xef, 0x0d, 0x3c, 0xed, 0x88, 0x2c, 0x57, 0x05, 0xc8, 0xda, 0x3b, 0x58, 0x5b, 0x4d, 0x6b, 0x11, 0x78, 0xee, 0x05, 0xdc, 0x5b, 0xd0, 0x14, 0xcd, 0xe0, 0x9e, 0xa0, 0x4e, 0x49, 0x99, 0xdf, 0xd8, 0x2f, 0xc7, 0xa0, 0x94, 0x5f, 0xde, 0x91, 0x5f, 0xd6, 0x2e, 0xfa, 0x52, 0x52, 0xda, 0xf7, 0xd5, 0xbd, 0xe6, 0xfd, 0xc8, 0x1d, 0x9f, 0x4a, 0x29, 0xbd, 0x0d, 0xcb, 0x5e, 0xd0, 0xf7, 0x27, 0x03, 0xda, 0x9b, 0x04, 0x6e, 0x10, 0x84, 0x93, 0xa0, 0x4f, 0x65, 0xd2, 0x47, 0x51, 0x95, 0x3d, 0x50, 0x39, 0x6f, 0xd8, 0x10, 0xd9, 0x80, 0x2a, 0xeb, 0x48, 0x5a, 0x85, 0x62, 0x11, 0xe6, 0x24, 0x64, 0x1d, 0xaa, 0x74, 0x30, 0xa4, 0x32, 0x02, 0x40, 0x32, 0xfe, 0xce, 0x60, 0x48, 0x1d, 0x4e, 0xc0, 0x14, 0x0a, 0xe6, 0x35, 0x9a, 0x0a, 0xc5, 0xb4, 0x28, 0x73, 0x7d, 0x9e, 0xf9, 0xb8, 0x02, 0xe4, 0x80, 0xcb, 0x80, 0x7e, 0x25, 0xf2, 0xcb, 0x65, 0x68, 0x68, 0x30, 0xd3, 0x0d, 0x43, 0x36, 0xe0, 0xde, 0xc0, 0x73, 0x47, 0x34, 0xa1, 0x91, 0xe0, 0xfb, 0x0c, 0xca, 0xe8, 0xdc, 0xb3, 0x61, 0x2f, 0x9c, 0x24, 0xbd, 0x01, 0x1d, 0x46, 0x94, 0x1b, 0x79, 0x66, 0x74, 0x0c, 0x94, 0xd1, 0x8d, 0xdc, 0x67, 0x3a, 0x1d, 0xe7, 0xa0, 0x0c, 0x2a, 0x2f, 0x38, 0xf8, 0x1a, 0x55, 0xd2, 0x0b, 0x0e, 0xbe, 0x22, 0x59, 0xad, 0x56, 0x2d, 0xd0, 0x6a, 0x6f, 0xc2, 0x1a, 0xd7, 0x5f, 0x42, 0xd2, 0x7b, 0x19, 0xc6, 0x9a, 0x51, 0x4b, 0x36, 0xa0, 0xcd, 0xc6, 0x2c, 0x45, 0x22, 0xf6, 0xbe, 0xc1, 0x83, 0x85, 0x96, 0x93, 0xc3, 0x19, 0x2d, 0x46, 0xed, 0x74, 0x5a, 0x7e, 0xe1, 0x9b, 0xc3, 0x91, 0xd6, 0x7d, 0x66, 0xd2, 0xd6, 0x05, 0x6d, 0x06, 0xb7, 0x17, 0xa0, 0x71, 0x94, 0x84, 0x63, 0xb9, 0x29, 0x2d, 0x68, 0xf2, 0xa2, 0x48, 0xbe, 0x79, 0x09, 0xae, 0x20, 0x17, 0x3d, 0x0a, 0xc7, 0xa1, 0x1f, 0x0e, 0xa7, 0xc6, 0x89, 0xe1, 0xef, 0x2c, 0x58, 0x36, 0x6a, 0xd3, 0x23, 0x03, 0x06, 0x1b, 0x64, 0xd6, 0x04, 0x67, 0xbc, 0x25, 0x4d, 0xb9, 0x72, 0x42, 0x1e, 0xd7, 0x7d, 0x2c, 0x12, 0x29, 0xb6, 0x60, 0x51, 0x8e, 0x4c, 0x7e, 0xc8, 0xb9, 0xb0, 0x93, 0xe7, 0x42, 0xf1, 0x7d, 0x4b, 0x7c, 0x20, 0x9b, 0xf8, 0xac, 0xb8, 0x38, 0xe7, 0x27, 0x08, 0x19, 0x5b, 0x52, 0x67, 0x0e, 0xfd, 0x84, 0x29, 0x47, 0xd0, 0x57, 0x60, 0x6c, 0xff, 0xba, 0x05, 0x90, 0x8e, 0x0e, 0xaf, 0x5b, 0x95, 0x81, 0xe0, 0xaf, 0x3c, 0x34, 0x63, 0xf0, 0x2a, 0x34, 0xd5, 0x35, 0x5d, 0x6a, 0x73, 0x1a, 0x12, 0x63, 0x0e, 0xe3, 0x4d, 0x58, 0x1c, 0xfa, 0xe1, 0x31, 0x1a, 0x6c, 0xcc, 0xe6, 0x8a, 0x45, 0x0a, 0x52, 0x8b, 0xc3, 0xf7, 0x04, 0x9a, 0x1a, 0xa8, 0x8a, 0x66, 0xa0, 0xec, 0xdf, 0x28, 0xa9, 0x5b, 0x95, 0x74, 0xce, 0x33, 0xa5, 0x8c, 0xdc, 0xc9, 0xa9, 0xd3, 0x19, 0x97, 0x18, 0x18, 0x45, 0x3d, 0xbc, 0x30, 0xc8, 0xf3, 0x0e, 0xb4, 0x22, 0xae, 0xaf, 0xa4, 0x32, 0xab, 0x3c, 0x47, 0x99, 0x2d, 0x44, 0x86, 0x15, 0xfb, 0x38, 0xb4, 0xdd, 0xc1, 0x19, 0x8d, 0x12, 0x0f, 0x8f, 0xd9, 0xe8, 0x42, 0x70, 0x15, 0xbc, 0xa8, 0xe1, 0x68, 0xd9, 0x6f, 0xc2, 0xa2, 0x48, 0xfb, 0x52, 0x94, 0x22, 0x85, 0x3b, 0x85, 0x19, 0xa1, 0xfd, 0x87, 0xf2, 0x02, 0xc7, 0xdc, 0xc3, 0xd9, 0x2b, 0xa2, 0xcf, 0xae, 0x94, 0x99, 0xdd, 0xc7, 0xc4, 0x65, 0xca, 0x40, 0x9e, 0xe5, 0xcb, 0x5a, 0x92, 0xc5, 0x40, 0x5c, 0x7e, 0x99, 0x4b, 0x5a, 0x79, 0x91, 0x25, 0xb5, 0x7f, 0x60, 0xc1, 0xfc, 0x5e, 0x38, 0xde, 0x13, 0xe9, 0x26, 0x28, 0x08, 0x2a, 0xdf, 0x52, 0x16, 0x9f, 0x93, 0x88, 0x52, 0x68, 0xb9, 0x17, 0xb2, 0x96, 0xfb, 0x67, 0xe1, 0x25, 0x8c, 0x24, 0x45, 0xe1, 0x38, 0x8c, 0x98, 0x30, 0xba, 0x3e, 0x37, 0xd3, 0x61, 0x90, 0x9c, 0x4a, 0x35, 0xf6, 0x3c, 0x12, 0x3c, 0xde, 0xb1, 0x63, 0x09, 0x77, 0xba, 0x85, 0xa7, 0xc1, 0xb5, 0x5b, 0xbe, 0xc2, 0xfe, 0x0c, 0xd4, 0xd1, 0x55, 0xc6, 0x69, 0xbd, 0x0e, 0xf5, 0xd3, 0x70, 0xdc, 0x3b, 0xf5, 0x82, 0x44, 0x0a, 0x77, 0x2b, 0xf5, 0x61, 0xf7, 0x70, 0x41, 0x14, 0x81, 0xfd, 0xcd, 0x39, 0x98, 0x7f, 0x10, 0x9c, 0x85, 0x5e, 0x1f, 0x2f, 0x8b, 0x46, 0x74, 0x14, 0xca, 0xec, 0x53, 0xf6, 0x3f, 0xb9, 0x0a, 0xf3, 0x98, 0x6e, 0x35, 0xe6, 0x4c, 0xdb, 0xe4, 0x97, 0xba, 0x02, 0x62, 0x4e, 0x42, 0x94, 0x26, 0xbe, 0x73, 0xf1, 0xd1, 0x10, 0x76, 0x88, 0x88, 0xf4, 0xc4, 0x75, 0x51, 0x4a, 0xb3, 0x7b, 0xab, 0x5a, 0x76, 0x2f, 0xeb, 0x4b, 0xa4, 0xc7, 0xf0, 0xfc, 0x09, 0xde, 0x97, 0x80, 0xf0, 0xe0, 0x13, 0x51, 0x1e, 0x09, 0x44, 0x97, 0x63, 0x5e, 0x1c, 0x7c, 0x74, 0x90, 0xb9, 0x25, 0xfc, 0x03, 0x4e, 0xc3, 0x95, 0xb0, 0x0e, 0x31, 0x17, 0x2e, 0xfb, 0x28, 0xa1, 0xce, 0x79, 0x3f, 0x03, 0x33, 0x4d, 0x3d, 0xa0, 0x4a, 0xa1, 0xf2, 0x79, 0x00, 0x4f, 0xee, 0xcf, 0xe2, 0xda, 0x71, 0x89, 0x67, 0xc6, 0xc9, 0xe3, 0x12, 0x63, 0x18, 0xd7, 0xf7, 0x8f, 0xdd, 0xfe, 0x53, 0x7c, 0x73, 0x82, 0xd7, 0x37, 0x75, 0xc7, 0x04, 0x31, 0xc9, 0x25, 0xdd, 0x55, 0xbc, 0xfe, 0xae, 0x38, 0x3a, 0x44, 0xee, 0x40, 0x03, 0x8f, 0x88, 0x62, 0x5f, 0x5b, 0xb8, 0xaf, 0x6d, 0xfd, 0x0c, 0x89, 0x3b, 0xab, 0x13, 0xe9, 0x17, 0x59, 0x8b, 0xb9, 0x5c, 0x35, 0x77, 0x30, 0x10, 0xf7, 0x7f, 0x6d, 0xec, 0x2d, 0x05, 0x98, 0x55, 0x15, 0x0b, 0xc6, 0x09, 0x96, 0x90, 0xc0, 0xc0, 0xc8, 0x35, 0xa8, 0xb1, 0xe3, 0xcb, 0xd8, 0xf5, 0x06, 0x98, 0xec, 0xc6, 0x4f, 0x51, 0x0a, 0x63, 0x6d, 0xc8, 0xff, 0xf1, 0x9e, 0x6e, 0x19, 0x57, 0xc5, 0xc0, 0xd8, 0xda, 0xa8, 0x32, 0x0a, 0xd3, 0x0a, 0xdf, 0x51, 0x03, 0x24, 0x6f, 0xe0, 0x2d, 0x4c, 0x42, 0x3b, 0xab, 0x18, 0xe5, 0x79, 0x49, 0xcc, 0x59, 0x30, 0xad, 0xfc, 0x7b, 0xc4, 0x48, 0x1c, 0x4e, 0x69, 0x7f, 0x12, 0x9a, 0x3a, 0x4c, 0x6a, 0x50, 0x79, 0x78, 0xb8, 0x7b, 0xd0, 0xbe, 0x44, 0x1a, 0x30, 0x7f, 0xb4, 0xfb, 0xe8, 0xd1, 0xfe, 0xee, 0x4e, 0xdb, 0x22, 0x4d, 0xa8, 0xa9, 0x8c, 0xa4, 0x92, 0x9d, 0x00, 0xd9, 0x1a, 0x0c, 0xc4, 0x77, 0xea, 0xd8, 0x9e, 0x72, 0xb0, 0x65, 0x70, 0x70, 0x01, 0x17, 0x95, 0x8a, 0xb9, 0xe8, 0xb9, 0x6b, 0x6d, 0xef, 0x42, 0xe3, 0x50, 0x7b, 0x91, 0x81, 0x02, 0x25, 0xdf, 0x62, 0x08, 0x41, 0xd4, 0x10, 0x6d, 0x38, 0x25, 0x7d, 0x38, 0xf6, 0x1f, 0x59, 0x3c, 0x4b, 0x5c, 0x0d, 0x9f, 0xf7, 0x6d, 0x43, 0x53, 0x05, 0x57, 0xd2, 0xf4, 0x42, 0x03, 0x63, 0x34, 0x38, 0x94, 0x5e, 0x78, 0x72, 0x12, 0x53, 0x99, 0x0c, 0x64, 0x60, 0x4c, 0x12, 0x98, 0x4f, 0xc5, 0xfc, 0x13, 0x8f, 0xf7, 0x10, 0x8b, 0xa4, 0xa0, 0x1c, 0xce, 0xf4, 0x7a, 0x44, 0xcf, 0x68, 0x14, 0xab, 0x34, 0x28, 0x55, 0x56, 0x59, 0x90, 0xd9, 0x55, 0xde, 0x80, 0x9a, 0x6a, 0xd7, 0x54, 0x59, 0x92, 0x52, 0xd5, 0x33, 0xd5, 0x88, 0xa7, 0x0c, 0x63, 0xd0, 0x5c, 0x4d, 0xe7, 0x2b, 0xc8, 0x2d, 0x20, 0x27, 0x5e, 0x94, 0x25, 0x2f, 0x23, 0x79, 0x41, 0x8d, 0xfd, 0x04, 0x96, 0x25, 0xeb, 0x68, 0xce, 0x94, 0xb9, 0x89, 0xd6, 0x45, 0x02, 0x53, 0xca, 0x0b, 0x8c, 0xfd, 0x3f, 0x16, 0xcc, 0x8b, 0x9d, 0xce, 0xbd, 0xea, 0xe1, 0xfb, 0x6c, 0x60, 0xa4, 0x63, 0x3c, 0x80, 0x40, 0xe9, 0x12, 0x6a, 0x32, 0xa7, 0x08, 0xcb, 0x45, 0x8a, 0x90, 0x40, 0x65, 0xec, 0x26, 0xa7, 0x78, 0x76, 0xae, 0x3b, 0xf8, 0x3f, 0x69, 0xf3, 0x48, 0x0f, 0x57, 0xba, 0x18, 0xe5, 0x29, 0x7a, 0xbf, 0xc4, 0xed, 0x7b, 0xfe, 0xfd, 0xd2, 0x55, 0xa8, 0xe3, 0x00, 0x7a, 0x69, 0x20, 0x27, 0x05, 0x18, 0xe7, 0xf2, 0x02, 0x4a, 0xb2, 0xc8, 0x45, 0x4e, 0x11, 0x7b, 0x95, 0xef, 0xbc, 0x58, 0x02, 0x75, 0x67, 0x2a, 0xb2, 0x4e, 0x53, 0x38, 0xe5, 0x08, 0x31, 0x80, 0x2c, 0x47, 0x08, 0x52, 0x47, 0xd5, 0xdb, 0x5d, 0xe8, 0xec, 0x50, 0x9f, 0x26, 0x74, 0xcb, 0xf7, 0xb3, 0xed, 0xbf, 0x04, 0x57, 0x0a, 0xea, 0x84, 0xff, 0xfc, 0x45, 0x58, 0xdd, 0xe2, 0x19, 0x7a, 0x3f, 0xae, 0xac, 0x13, 0xbb, 0x03, 0x6b, 0xd9, 0x26, 0x45, 0x67, 0xf7, 0x60, 0x69, 0x87, 0x1e, 0x4f, 0x86, 0xfb, 0xf4, 0x2c, 0xed, 0x88, 0x40, 0x25, 0x3e, 0x0d, 0xcf, 0x85, 0x60, 0xe2, 0xff, 0xe4, 0x65, 0x00, 0x9f, 0xd1, 0xf4, 0xe2, 0x31, 0xed, 0xcb, 0x37, 0x07, 0x88, 0x1c, 0x8d, 0x69, 0xdf, 0x7e, 0x13, 0x88, 0xde, 0x8e, 0x58, 0x2f, 0x66, 0xf7, 0x26, 0xc7, 0xbd, 0x78, 0x1a, 0x27, 0x74, 0x24, 0x1f, 0x53, 0xe8, 0x90, 0x7d, 0x13, 0x9a, 0x87, 0xee, 0xd4, 0xa1, 0x5f, 0x17, 0x8f, 0xb9, 0x2e, 0xc3, 0xfc, 0xd8, 0x9d, 0x32, 0x35, 0xa5, 0x22, 0x4c, 0x58, 0x6d, 0xff, 0x57, 0x09, 0xe6, 0x38, 0x25, 0x6b, 0x75, 0x40, 0xe3, 0xc4, 0x0b, 0x90, 0xb1, 0x64, 0xab, 0x1a, 0x94, 0x63, 0xe5, 0x52, 0x01, 0x2b, 0x8b, 0x53, 0x9a, 0xcc, 0xdf, 0x16, 0xfc, 0x6a, 0x60, 0x8c, 0xb9, 0xd2, 0xf4, 0x2f, 0x1e, 0xe2, 0x48, 0x81, 0x4c, 0x30, 0x32, 0xb5, 0xae, 0x7c, 0x7c, 0x52, 0x4a, 0x05, 0xe7, 0xea, 0x50, 0xa1, 0x0d, 0x9f, 0xe7, 0x0c, 0x9e, 0xb3, 0xe1, 0x39, 0x5b, 0x5d, 0x7b, 0x01, 0x5b, 0xcd, 0x8f, 0x6e, 0xcf, 0xb3, 0xd5, 0xf0, 0x02, 0xb6, 0xda, 0x26, 0xd0, 0xbe, 0x47, 0xa9, 0x43, 0x99, 0x37, 0x28, 0x79, 0xf7, 0x5b, 0x16, 0xb4, 0x05, 0x17, 0xa9, 0x3a, 0xf2, 0xaa, 0xe1, 0xf5, 0x16, 0xe6, 0x51, 0xdf, 0x80, 0x05, 0xf4, 0x45, 0x55, 0xd4, 0x55, 0x84, 0x88, 0x0d, 0x90, 0xcd, 0x43, 0x5e, 0x77, 0x8e, 0x3c, 0x5f, 0x6c, 0x8a, 0x0e, 0xc9, 0xc0, 0x6d, 0xe4, 0x8a, 0x34, 0x28, 0xcb, 0x51, 0x65, 0xfb, 0x2f, 0x2c, 0x58, 0xd2, 0x06, 0x2c, 0xb8, 0xf0, 0x1d, 0x90, 0xd2, 0xc0, 0x43, 0xb0, 0x5c, 0x72, 0x2f, 0x9b, 0x62, 0x93, 0x7e, 0x66, 0x10, 0xe3, 0x66, 0xba, 0x53, 0x1c, 0x60, 0x3c, 0x19, 0x09, 0x25, 0xaa, 0x43, 0x8c, 0x91, 0xce, 0x29, 0x7d, 0xaa, 0x48, 0xb8, 0x1a, 0x37, 0x30, 0xcc, 0xd1, 0x61, 0x3e, 0xb4, 0x22, 0xe2, 0xf6, 0xcc, 0x04, 0xed, 0x7f, 0xb2, 0x60, 0x99, 0x1f, 0x86, 0xc4, 0x51, 0x53, 0x3d, 0x81, 0x99, 0xe3, 0xa7, 0x3f, 0x2e, 0x91, 0x7b, 0x97, 0x1c, 0x51, 0x26, 0x9f, 0x7e, 0xc1, 0x03, 0x9c, 0xca, 0xcd, 0x9a, 0xb1, 0x17, 0xe5, 0xa2, 0xbd, 0x78, 0xce, 0x4a, 0x17, 0x85, 0x1c, 0xab, 0x85, 0x21, 0xc7, 0xbb, 0xf3, 0x50, 0x8d, 0xfb, 0xe1, 0x98, 0xda, 0x6b, 0xb0, 0x62, 0x4e, 0x4e, 0xa8, 0xa0, 0xef, 0x58, 0xd0, 0xb9, 0xc7, 0x43, 0xf3, 0x5e, 0x30, 0xdc, 0xf3, 0xe2, 0x24, 0x8c, 0xd4, 0x4b, 0xc1, 0x6b, 0x00, 0x71, 0xe2, 0x46, 0x09, 0xcf, 0xc0, 0x15, 0x01, 0xc1, 0x14, 0x61, 0x63, 0xa4, 0xc1, 0x80, 0xd7, 0xf2, 0xbd, 0x51, 0xe5, 0x9c, 0x0f, 0x21, 0x8e, 0x6b, 0x86, 0x25, 0x7e, 0x8d, 0xe7, 0x2a, 0x32, 0x5f, 0x81, 0x9e, 0xa1, 0x5e, 0xe7, 0xe7, 0xa0, 0x0c, 0x6a, 0xff, 0x83, 0x05, 0x8b, 0xe9, 0x20, 0xf1, 0x16, 0xcf, 0xd4, 0x0e, 0xc2, 0xfc, 0xa6, 0xda, 0x41, 0x86, 0x2a, 0x3d, 0x66, 0x8f, 0xc5, 0xd8, 0x34, 0x04, 0x25, 0x56, 0x94, 0xc2, 0x89, 0x74, 0x70, 0x74, 0x88, 0x67, 0x1e, 0x31, 0x4f, 0x40, 0x78, 0x35, 0xa2, 0x84, 0x09, 0xd4, 0xa3, 0x04, 0xbf, 0x9a, 0xe3, 0x07, 0x41, 0x51, 0x94, 0xa6, 0x74, 0x1e, 0x51, 0x34, 0xa5, 0xfa, 0x35, 0x47, 0x8d, 0xaf, 0x8f, 0x2c, 0xdb, 0xbf, 0x69, 0xc1, 0x95, 0x82, 0x85, 0x17, 0x52, 0xb3, 0x03, 0x4b, 0x27, 0xaa, 0x52, 0x2e, 0x0e, 0x17, 0x9d, 0x35, 0x79, 0xcf, 0x64, 0x2e, 0x88, 0x93, 0xff, 0x40, 0xf9, 0x45, 0x7c, 0xb9, 0x8d, 0xdc, 0xbe, 0x7c, 0xc5, 0xc6, 0xe7, 0xa0, 0xa1, 0xbd, 0xd1, 0x23, 0x97, 0x61, 0xf9, 0xc9, 0x83, 0x47, 0x07, 0xbb, 0x47, 0x47, 0xbd, 0xc3, 0xc7, 0x77, 0xbf, 0xb0, 0xfb, 0xe5, 0xde, 0xde, 0xd6, 0xd1, 0x5e, 0xfb, 0x12, 0x59, 0x03, 0x72, 0xb0, 0x7b, 0xf4, 0x68, 0x77, 0xc7, 0xc0, 0xad, 0x3b, 0xbf, 0x55, 0x86, 0x16, 0xbf, 0xbf, 0xe4, 0xbf, 0xea, 0x40, 0x23, 0xf2, 0x2e, 0xcc, 0x8b, 0x5f, 0xe5, 0x20, 0xab, 0x62, 0xd8, 0xe6, 0xef, 0x80, 0x74, 0xd7, 0xb2, 0xb0, 0xe0, 0xcb, 0xe5, 0x5f, 0xfa, 0xc1, 0xbf, 0xfd, 0x4e, 0x69, 0x81, 0x34, 0x36, 0xcf, 0xde, 0xd8, 0x1c, 0xd2, 0x20, 0x66, 0x6d, 0x7c, 0x15, 0x20, 0xfd, 0xbd, 0x0a, 0xd2, 0x51, 0xfe, 0x60, 0xe6, 0x87, 0x38, 0xba, 0x57, 0x0a, 0x6a, 0x44, 0xbb, 0x57, 0xb0, 0xdd, 0x65, 0xbb, 0xc5, 0xda, 0xf5, 0x02, 0x2f, 0xe1, 0x3f, 0x5e, 0xf1, 0xb6, 0xb5, 0x41, 0x06, 0xd0, 0xd4, 0x7f, 0x8e, 0x82, 0xc8, 0x30, 0x54, 0xc1, 0x8f, 0x61, 0x74, 0x5f, 0x2a, 0xac, 0x93, 0x31, 0x38, 0xec, 0x63, 0xd5, 0x6e, 0xb3, 0x3e, 0x26, 0x48, 0x91, 0xf6, 0xe2, 0x43, 0xcb, 0xfc, 0xd5, 0x09, 0x72, 0x55, 0x53, 0x19, 0xb9, 0xdf, 0xbc, 0xe8, 0xbe, 0x3c, 0xa3, 0x56, 0xf4, 0xf5, 0x32, 0xf6, 0x75, 0xd9, 0x26, 0xac, 0xaf, 0x3e, 0xd2, 0xc8, 0xdf, 0xbc, 0x78, 0xdb, 0xda, 0xb8, 0xf3, 0xd7, 0xd7, 0xa1, 0xae, 0x02, 0xc7, 0xe4, 0x7d, 0x58, 0x30, 0x2e, 0x98, 0x89, 0x9c, 0x46, 0xd1, 0x7d, 0x74, 0xf7, 0x6a, 0x71, 0xa5, 0xe8, 0xf8, 0x1a, 0x76, 0xdc, 0x21, 0x6b, 0xac, 0x63, 0x71, 0x43, 0xbb, 0x89, 0xa9, 0x12, 0x3c, 0xef, 0xf9, 0x29, 0x9f, 0x67, 0x7a, 0x29, 0x6c, 0xcc, 0x33, 0x77, 0x89, 0x6c, 0xcc, 0x33, 0x7f, 0x93, 0x6c, 0x5f, 0xc5, 0xee, 0xd6, 0xc8, 0x8a, 0xde, 0x9d, 0x0a, 0xe8, 0x52, 0x4c, 0xd6, 0xd7, 0x7f, 0xb0, 0x81, 0xbc, 0xac, 0x18, 0xab, 0xe8, 0x87, 0x1c, 0x14, 0x8b, 0xe4, 0x7f, 0xcd, 0xc1, 0xee, 0x60, 0x57, 0x84, 0xe0, 0xf6, 0xe9, 0xbf, 0xd7, 0x40, 0xbe, 0x02, 0x75, 0xf5, 0x40, 0x97, 0x5c, 0xd6, 0x1e, 0x4c, 0xeb, 0x0f, 0x8a, 0xbb, 0x9d, 0x7c, 0x45, 0x11, 0x63, 0xe8, 0x2d, 0x33, 0xc6, 0x78, 0x02, 0x0d, 0xed, 0x11, 0x2e, 0xb9, 0xa2, 0xc2, 0xfe, 0xd9, 0x87, 0xbe, 0xdd, 0x6e, 0x51, 0x95, 0xe8, 0x62, 0x09, 0xbb, 0x68, 0x90, 0x3a, 0xf2, 0x5e, 0xf2, 0x2c, 0x8c, 0xc9, 0x3e, 0xac, 0x8a, 0x83, 0xcb, 0x31, 0xfd, 0x28, 0x4b, 0x54, 0xf0, 0xfb, 0x15, 0xb7, 0x2d, 0xf2, 0x0e, 0xd4, 0xe4, 0x5b, 0x6b, 0xb2, 0x56, 0xfc, 0x66, 0xbc, 0x7b, 0x39, 0x87, 0x0b, 0xb5, 0xf6, 0x65, 0x80, 0xf4, 0xc5, 0xaf, 0x12, 0xe0, 0xdc, 0x0b, 0x62, 0xb5, 0x3b, 0xf9, 0xe7, 0xc1, 0xf6, 0x1a, 0x4e, 0xb0, 0x4d, 0x50, 0x80, 0x03, 0x7a, 0x2e, 0x9f, 0xaf, 0x7c, 0x0d, 0x1a, 0xda, 0xa3, 0x5f, 0xb5, 0x7c, 0xf9, 0x07, 0xc3, 0x6a, 0xf9, 0x0a, 0xde, 0x08, 0xdb, 0x5d, 0x6c, 0x7d, 0xc5, 0x5e, 0x64, 0xad, 0xc7, 0xde, 0x30, 0x18, 0x71, 0x02, 0xb6, 0x41, 0xa7, 0xb0, 0x60, 0xbc, 0xec, 0x55, 0xd2, 0x53, 0xf4, 0x6e, 0x58, 0x49, 0x4f, 0xe1, 0x63, 0x60, 0xc9, 0xce, 0xf6, 0x12, 0xeb, 0xe7, 0x0c, 0x49, 0xb4, 0x9e, 0xde, 0x83, 0x86, 0xf6, 0x4a, 0x57, 0xcd, 0x25, 0xff, 0x20, 0x58, 0xcd, 0xa5, 0xe8, 0x51, 0xef, 0x0a, 0xf6, 0xd1, 0xb2, 0x91, 0x15, 0xf0, 0xf5, 0x07, 0x6b, 0xfb, 0x7d, 0x68, 0x99, 0xef, 0x76, 0x95, 0x5c, 0x16, 0xbe, 0x00, 0x56, 0x72, 0x39, 0xe3, 0xb1, 0xaf, 0x60, 0xe9, 0x8d, 0x65, 0xd5, 0xc9, 0xe6, 0x07, 0xe2, 0x1a, 0xf7, 0x43, 0xf2, 0x45, 0xa6, 0x7c, 0xc4, 0x73, 0x1c, 0x72, 0x59, 0xe3, 0x5a, 0xfd, 0xd1, 0x8e, 0x92, 0x97, 0xdc, 0xcb, 0x1d, 0x93, 0x99, 0xf9, 0xfb, 0x15, 0xb4, 0x28, 0xf8, 0x2c, 0x47, 0xb3, 0x28, 0xfa, 0xcb, 0x1d, 0xcd, 0xa2, 0x18, 0xaf, 0x77, 0xb2, 0x16, 0x25, 0xf1, 0x58, 0x1b, 0x01, 0x2c, 0x66, 0x12, 0xd4, 0x94, 0x54, 0x14, 0x67, 0xf4, 0x76, 0xaf, 0x3d, 0x3f, 0xaf, 0xcd, 0x54, 0x54, 0x52, 0x41, 0x6d, 0xca, 0xfc, 0xe9, 0x9f, 0x87, 0xa6, 0xfe, 0xa2, 0x92, 0xe8, 0xa2, 0x9c, 0xed, 0xe9, 0xa5, 0xc2, 0x3a, 0x73, 0x73, 0x49, 0x53, 0xef, 0x86, 0x7c, 0x09, 0xd6, 0x94, 0xa8, 0xeb, 0x39, 0x4f, 0x31, 0x79, 0xa5, 0x20, 0x13, 0x4a, 0x0f, 0x67, 0x74, 0xaf, 0xcc, 0x4c, 0x95, 0xba, 0x6d, 0x31, 0xa6, 0x31, 0x9f, 0xaa, 0xa5, 0xca, 0xbc, 0xe8, 0x85, 0x5e, 0xaa, 0xcc, 0x0b, 0xdf, 0xb7, 0x49, 0xa6, 0x21, 0xcb, 0xc6, 0x1a, 0xf1, 0x48, 0x3e, 0x79, 0x0f, 0x16, 0xb5, 0xac, 0xd2, 0xa3, 0x69, 0xd0, 0x57, 0x02, 0x90, 0x7f, 0x7e, 0xd0, 0x2d, 0xf2, 0xb7, 0xed, 0xcb, 0xd8, 0xfe, 0x92, 0x6d, 0x2c, 0x0e, 0x63, 0xfe, 0x6d, 0x68, 0xe8, 0x19, 0xab, 0xcf, 0x69, 0xf7, 0xb2, 0x56, 0xa5, 0x67, 0xcf, 0xdf, 0xb6, 0xc8, 0xef, 0x59, 0xd0, 0x34, 0xf2, 0x3f, 0x8d, 0xfb, 0xaa, 0x4c, 0x3b, 0x1d, 0xbd, 0x4e, 0x6f, 0xc8, 0x76, 0x70, 0x90, 0xfb, 0x1b, 0x9f, 0x37, 0x16, 0xe1, 0x03, 0xe3, 0xdc, 0x76, 0x2b, 0xfb, 0x83, 0x25, 0x1f, 0x66, 0x09, 0xf4, 0x27, 0x1a, 0x1f, 0xde, 0xb6, 0xc8, 0x77, 0x2d, 0x68, 0x99, 0xd1, 0x06, 0xb5, 0x55, 0x85, 0x71, 0x0d, 0xb5, 0x55, 0x33, 0x42, 0x14, 0xef, 0xe1, 0x28, 0x1f, 0x6d, 0x38, 0xc6, 0x28, 0xc5, 0x23, 0xc6, 0x1f, 0x6d, 0xb4, 0xe4, 0x6d, 0xfe, 0xa3, 0x45, 0x32, 0x04, 0x46, 0x34, 0xab, 0x91, 0xdd, 0x5e, 0xfd, 0x77, 0x78, 0xd6, 0xad, 0xdb, 0x16, 0xf9, 0x1a, 0xff, 0x5d, 0x13, 0xf1, 0x2d, 0x72, 0xc9, 0x8b, 0x7e, 0x6f, 0xdf, 0xc0, 0x39, 0x5d, 0xb3, 0xaf, 0x18, 0x73, 0xca, 0xda, 0xe3, 0x2d, 0x3e, 0x3a, 0xf1, 0x13, 0x3a, 0xa9, 0x41, 0xc9, 0xfd, 0xac, 0xce, 0xec, 0x41, 0x8e, 0xf8, 0x20, 0x05, 0xb9, 0xc1, 0xca, 0x2f, 0xd8, 0x8c, 0xbd, 0x81, 0x63, 0xbd, 0x61, 0xbf, 0x32, 0x73, 0xac, 0x9b, 0x18, 0x33, 0x60, 0x23, 0x3e, 0x04, 0x48, 0xc3, 0xd5, 0x24, 0x13, 0x2e, 0x55, 0x02, 0x9e, 0x8f, 0x68, 0x9b, 0xf2, 0x22, 0xa3, 0xaa, 0xac, 0xc5, 0xaf, 0x70, 0x75, 0xf5, 0x40, 0x06, 0x5a, 0x75, 0xa7, 0xc4, 0x8c, 0x2b, 0x1b, 0x4e, 0x49, 0xb6, 0x7d, 0x43, 0x59, 0xa9, 0xa8, 0xed, 0x63, 0x58, 0xd8, 0x0f, 0xc3, 0xa7, 0x93, 0xb1, 0xba, 0x6c, 0x32, 0xc3, 0x79, 0x7b, 0x6e, 0x7c, 0xda, 0xcd, 0xcc, 0xc2, 0xbe, 0x8e, 0x4d, 0x75, 0x49, 0x47, 0x6b, 0x6a, 0xf3, 0x83, 0x34, 0x1c, 0xfe, 0x21, 0x71, 0x61, 0x49, 0xe9, 0x40, 0x35, 0xf0, 0xae, 0xd9, 0x8c, 0xa1, 0xf9, 0xb2, 0x5d, 0x18, 0x9e, 0xad, 0x1c, 0xed, 0x66, 0x2c, 0xdb, 0xbc, 0x6d, 0x91, 0x43, 0x68, 0xee, 0xd0, 0x7e, 0x38, 0xa0, 0x22, 0x26, 0xb6, 0x9c, 0x0e, 0x5c, 0x05, 0xd3, 0xba, 0x0b, 0x06, 0x68, 0xda, 0x85, 0xb1, 0x3b, 0x8d, 0xe8, 0xd7, 0x37, 0x3f, 0x10, 0xd1, 0xb6, 0x0f, 0xa5, 0x5d, 0x90, 0xe1, 0x48, 0xc3, 0x2e, 0x64, 0xe2, 0x97, 0x86, 0x5d, 0xc8, 0xc5, 0x2f, 0x8d, 0xa5, 0x96, 0xe1, 0x50, 0xe2, 0xc3, 0x52, 0x2e, 0xe4, 0xa9, 0x4c, 0xc2, 0xac, 0x40, 0x69, 0xf7, 0xfa, 0x6c, 0x02, 0xb3, 0xb7, 0x0d, 0xb3, 0xb7, 0x23, 0x58, 0xd8, 0xa1, 0x7c, 0xb1, 0x78, 0x46, 0x4b, 0x26, 0x89, 0x58, 0xcf, 0x97, 0xc9, 0x2a, 0x70, 0xac, 0x33, 0x0d, 0x3f, 0xa6, 0x93, 0x90, 0xaf, 0x40, 0xe3, 0x3e, 0x4d, 0x64, 0x0a, 0x8b, 0x72, 0x3d, 0x33, 0x39, 0x2d, 0xdd, 0x82, 0x0c, 0x18, 0x93, 0x67, 0xb0, 0xb5, 0x4d, 0x3a, 0x18, 0x52, 0xae, 0x9c, 0x7a, 0xde, 0xe0, 0x43, 0xf2, 0x73, 0xd8, 0xb8, 0xca, 0xa1, 0x5b, 0xd3, 0x32, 0x1f, 0xf4, 0xc6, 0x17, 0x33, 0x78, 0x51, 0xcb, 0x41, 0x38, 0xa0, 0x9a, 0x0b, 0x14, 0x40, 0x43, 0x4b, 0xfd, 0x54, 0x02, 0x94, 0x4f, 0x63, 0x55, 0x02, 0x54, 0x90, 0x29, 0x6a, 0xaf, 0x63, 0x3f, 0x36, 0xb9, 0x9e, 0xf6, 0xc3, 0xb3, 0x43, 0xd3, 0x9e, 0x36, 0x3f, 0x70, 0x47, 0xc9, 0x87, 0xe4, 0x09, 0xbe, 0x64, 0xd6, 0xd3, 0x74, 0x52, 0x5f, 0x3a, 0x9b, 0xd1, 0xa3, 0x16, 0x4b, 0xab, 0x32, 0xfd, 0x6b, 0xde, 0x15, 0x7a, 0x4a, 0x9f, 0x06, 0x38, 0x4a, 0xc2, 0xf1, 0x8e, 0x4b, 0x47, 0x61, 0x90, 0xea, 0xda, 0x34, 0x15, 0x25, 0xd5, 0x5f, 0x5a, 0x3e, 0x0a, 0x79, 0xa2, 0x1d, 0x3e, 0x8c, 0x2c, 0x27, 0xc9, 0x5c, 0x33, 0xb3, 0x55, 0xd4, 0x82, 0x14, 0x64, 0xac, 0xdc, 0xb6, 0xc8, 0x16, 0x40, 0x1a, 0xf3, 0x56, 0x47, 0x89, 0x5c, 0x38, 0x5d, 0xa9, 0xbd, 0x82, 0x00, 0xf9, 0x21, 0xd4, 0xd3, 0x20, 0xea, 0xe5, 0x34, 0x7d, 0xd7, 0x08, 0xb9, 0x2a, 0x0b, 0x9e, 0x0b, 0x6d, 0xda, 0x6d, 0x5c, 0x2a, 0x20, 0x35, 0xb6, 0x54, 0x18, 0xaf, 0xf4, 0x60, 0x99, 0x0f, 0x50, 0xb9, 0x23, 0x98, 0x5c, 0x21, 0x67, 0x52, 0x10, 0x5e, 0x54, 0xd2, 0x5c, 0x18, 0x9d, 0x33, 0xa2, 0x15, 0x8c, 0x5b, 0x79, 0x62, 0x07, 0x53, 0xcd, 0x23, 0x58, 0xca, 0x85, 0x8f, 0x94, 0x48, 0xcf, 0x8a, 0xe8, 0x29, 0x91, 0x9e, 0x19, 0x79, 0xb2, 0x57, 0xb1, 0xcb, 0x45, 0x1b, 0xf0, 0x04, 0x74, 0xee, 0x25, 0xfd, 0xd3, 0xb7, 0xad, 0x8d, 0xbb, 0x37, 0xdf, 0xfb, 0x89, 0xa1, 0x97, 0x9c, 0x4e, 0x8e, 0x6f, 0xf5, 0xc3, 0xd1, 0xa6, 0x2f, 0x43, 0x0a, 0x22, 0x45, 0x6a, 0xd3, 0x0f, 0x06, 0x9b, 0xd8, 0xf2, 0xf1, 0x1c, 0xfe, 0xe2, 0xeb, 0x27, 0xff, 0x37, 0x00, 0x00, 0xff, 0xff, 0xb1, 0x6a, 0x89, 0xcb, 0x23, 0x56, 0x00, 0x00, }