/* Generated by the protocol buffer compiler. DO NOT EDIT! */ /* Generated from: lightning.proto */ #ifndef PROTOBUF_C_lightning_2eproto__INCLUDED #define PROTOBUF_C_lightning_2eproto__INCLUDED #include PROTOBUF_C__BEGIN_DECLS #if PROTOBUF_C_VERSION_NUMBER < 1000000 # error This file was generated by a newer version of protoc-c which is incompatible with your libprotobuf-c headers. Please update your headers. #elif 1001001 < PROTOBUF_C_MIN_COMPILER_VERSION # error This file was generated by an older version of protoc-c which is incompatible with your libprotobuf-c headers. Please regenerate this file with a newer version of protoc-c. #endif typedef struct _Sha256Hash Sha256Hash; typedef struct _Signature Signature; typedef struct _Locktime Locktime; typedef struct _BitcoinPubkey BitcoinPubkey; typedef struct _Funding Funding; typedef struct _Authenticate Authenticate; typedef struct _OpenChannel OpenChannel; typedef struct _OpenAnchor OpenAnchor; typedef struct _OpenCommitSig OpenCommitSig; typedef struct _OpenComplete OpenComplete; typedef struct _UpdateAddHtlc UpdateAddHtlc; typedef struct _UpdateDeclineHtlc UpdateDeclineHtlc; typedef struct _UpdateFulfillHtlc UpdateFulfillHtlc; typedef struct _UpdateFailHtlc UpdateFailHtlc; typedef struct _UpdateAccept UpdateAccept; typedef struct _UpdateSignature UpdateSignature; typedef struct _UpdateComplete UpdateComplete; typedef struct _CloseClearing CloseClearing; typedef struct _CloseSignature CloseSignature; typedef struct _Error Error; typedef struct _Pkt Pkt; /* --- enums --- */ typedef enum _OpenChannel__AnchorOffer { /* * I will create the anchor */ OPEN_CHANNEL__ANCHOR_OFFER__WILL_CREATE_ANCHOR = 1, /* * I won't create the anchor */ OPEN_CHANNEL__ANCHOR_OFFER__WONT_CREATE_ANCHOR = 2 PROTOBUF_C__FORCE_ENUM_TO_BE_INT_SIZE(OPEN_CHANNEL__ANCHOR_OFFER) } OpenChannel__AnchorOffer; /* --- messages --- */ /* * Protobufs don't have fixed-length fields, so these are a hack. */ struct _Sha256Hash { ProtobufCMessage base; uint64_t a; uint64_t b; uint64_t c; uint64_t d; }; #define SHA256_HASH__INIT \ { PROTOBUF_C_MESSAGE_INIT (&sha256_hash__descriptor) \ , 0, 0, 0, 0 } struct _Signature { ProtobufCMessage base; uint64_t r1; uint64_t r2; uint64_t r3; uint64_t r4; uint64_t s1; uint64_t s2; uint64_t s3; uint64_t s4; }; #define SIGNATURE__INIT \ { PROTOBUF_C_MESSAGE_INIT (&signature__descriptor) \ , 0, 0, 0, 0, 0, 0, 0, 0 } typedef enum { LOCKTIME__LOCKTIME__NOT_SET = 0, LOCKTIME__LOCKTIME_SECONDS = 1, LOCKTIME__LOCKTIME_BLOCKS = 2, } Locktime__LocktimeCase; struct _Locktime { ProtobufCMessage base; Locktime__LocktimeCase locktime_case; union { uint32_t seconds; uint32_t blocks; }; }; #define LOCKTIME__INIT \ { PROTOBUF_C_MESSAGE_INIT (&locktime__descriptor) \ , LOCKTIME__LOCKTIME__NOT_SET, {} } /* * Pubkey for commitment transaction input. */ struct _BitcoinPubkey { ProtobufCMessage base; /* * Either 65 or 33 bytes. */ ProtobufCBinaryData key; }; #define BITCOIN_PUBKEY__INIT \ { PROTOBUF_C_MESSAGE_INIT (&bitcoin_pubkey__descriptor) \ , {0,NULL} } /* * How much a node charges (or pays!) for sending. */ struct _Funding { ProtobufCMessage base; /* * Base amount (in satoshi). */ protobuf_c_boolean has_fixed; int64_t fixed; /* * This is charge per millionth of a satoshi. */ protobuf_c_boolean has_per_micro_satoshi; int32_t per_micro_satoshi; }; #define FUNDING__INIT \ { PROTOBUF_C_MESSAGE_INIT (&funding__descriptor) \ , 0,0ll, 0,0 } /* * Set channel params. */ struct _Authenticate { ProtobufCMessage base; /* * Which node this is. */ BitcoinPubkey *node_id; /* * Signature of your session key. * */ Signature *session_sig; }; #define AUTHENTICATE__INIT \ { PROTOBUF_C_MESSAGE_INIT (&authenticate__descriptor) \ , NULL, NULL } /* * Set channel params. */ struct _OpenChannel { ProtobufCMessage base; /* * Relative locktime for outputs going to us. */ Locktime *delay; /* * Hash for revoking first commitment transaction. */ Sha256Hash *revocation_hash; /* * Hash for revoking second commitment transaction. */ Sha256Hash *next_revocation_hash; /* * Pubkey for anchor to pay into commitment tx. */ BitcoinPubkey *commit_key; /* * How to pay money to us from commit_tx. */ BitcoinPubkey *final_key; OpenChannel__AnchorOffer anch; /* * How far must anchor be buried before we consider channel live? */ protobuf_c_boolean has_min_depth; uint32_t min_depth; /* * How much fee would I like on commitment tx? */ uint64_t commitment_fee; }; #define OPEN_CHANNEL__INIT \ { PROTOBUF_C_MESSAGE_INIT (&open_channel__descriptor) \ , NULL, NULL, NULL, NULL, NULL, 0, 0,0u, 0 } /* * Whoever is supplying anchor sends this. */ struct _OpenAnchor { ProtobufCMessage base; /* * Transaction ID of anchor. */ Sha256Hash *txid; /* * Which output is going to the 2 of 2. */ uint32_t output_index; /* * Amount of anchor output. */ uint64_t amount; /* * Signature for your initial commitment tx. */ Signature *commit_sig; }; #define OPEN_ANCHOR__INIT \ { PROTOBUF_C_MESSAGE_INIT (&open_anchor__descriptor) \ , NULL, 0, 0, NULL } /* * Reply: signature for your initial commitment tx */ struct _OpenCommitSig { ProtobufCMessage base; Signature *sig; }; #define OPEN_COMMIT_SIG__INIT \ { PROTOBUF_C_MESSAGE_INIT (&open_commit_sig__descriptor) \ , NULL } /* * Indicates we've seen anchor reach min-depth. */ struct _OpenComplete { ProtobufCMessage base; /* * Block it went into. */ /* * FIXME: add a merkle proof plus block headers here? */ Sha256Hash *blockid; }; #define OPEN_COMPLETE__INIT \ { PROTOBUF_C_MESSAGE_INIT (&open_complete__descriptor) \ , NULL } /* * Start a new commitment tx to add an HTLC me -> you. */ struct _UpdateAddHtlc { ProtobufCMessage base; /* * Hash for which I will supply preimage to revoke this commitment tx. */ Sha256Hash *revocation_hash; /* * Amount for htlc (millisatoshi) */ uint32_t amount_msat; /* * Hash for HTLC R value. */ Sha256Hash *r_hash; /* * Time at which HTLC expires (absolute) */ /* * FIXME: Routing information. */ Locktime *expiry; }; #define UPDATE_ADD_HTLC__INIT \ { PROTOBUF_C_MESSAGE_INIT (&update_add_htlc__descriptor) \ , NULL, 0, NULL, NULL } typedef enum { UPDATE_DECLINE_HTLC__REASON__NOT_SET = 0, UPDATE_DECLINE_HTLC__REASON_INSUFFICIENT_FUNDS = 1, UPDATE_DECLINE_HTLC__REASON_CANNOT_ROUTE = 2, } UpdateDeclineHtlc__ReasonCase; /* * We can't do this HTLC, sorry (instead of update_accept) */ struct _UpdateDeclineHtlc { ProtobufCMessage base; UpdateDeclineHtlc__ReasonCase reason_case; union { Funding *insufficient_funds; protobuf_c_boolean cannot_route; }; }; #define UPDATE_DECLINE_HTLC__INIT \ { PROTOBUF_C_MESSAGE_INIT (&update_decline_htlc__descriptor) \ , UPDATE_DECLINE_HTLC__REASON__NOT_SET, {} } /* * Complete your HTLC: I have the R value, pay me! */ struct _UpdateFulfillHtlc { ProtobufCMessage base; /* * Hash for which I will supply preimage to revoke this commitment tx. */ Sha256Hash *revocation_hash; /* * HTLC R value. */ Sha256Hash *r; }; #define UPDATE_FULFILL_HTLC__INIT \ { PROTOBUF_C_MESSAGE_INIT (&update_fulfill_htlc__descriptor) \ , NULL, NULL } /* * Remove your HTLC: routing has failed upstream, we didn't like it, or timeout. */ struct _UpdateFailHtlc { ProtobufCMessage base; /* * Hash for which I will supply preimage to revoke this commitment tx. */ Sha256Hash *revocation_hash; /* * Hash for HTLC R value. */ Sha256Hash *r_hash; }; #define UPDATE_FAIL_HTLC__INIT \ { PROTOBUF_C_MESSAGE_INIT (&update_fail_htlc__descriptor) \ , NULL, NULL } /* * OK, I accept that update; here's your signature. */ struct _UpdateAccept { ProtobufCMessage base; /* * Signature for your new commitment tx. */ Signature *sig; /* * Hash for which I will supply preimage to revoke this new commit tx. */ Sha256Hash *revocation_hash; }; #define UPDATE_ACCEPT__INIT \ { PROTOBUF_C_MESSAGE_INIT (&update_accept__descriptor) \ , NULL, NULL } /* * Thanks for accepting, here's my last bit. */ struct _UpdateSignature { ProtobufCMessage base; /* * Signature for your new commitment tx. */ Signature *sig; /* * Hash preimage which revokes old commitment tx. */ Sha256Hash *revocation_preimage; }; #define UPDATE_SIGNATURE__INIT \ { PROTOBUF_C_MESSAGE_INIT (&update_signature__descriptor) \ , NULL, NULL } /* * Complete the update. */ struct _UpdateComplete { ProtobufCMessage base; /* * Hash preimage which revokes old commitment tx. */ Sha256Hash *revocation_preimage; }; #define UPDATE_COMPLETE__INIT \ { PROTOBUF_C_MESSAGE_INIT (&update_complete__descriptor) \ , NULL } /* * Start clearing out the channel HTLCs so we can close it */ struct _CloseClearing { ProtobufCMessage base; }; #define CLOSE_CLEARING__INIT \ { PROTOBUF_C_MESSAGE_INIT (&close_clearing__descriptor) \ } struct _CloseSignature { ProtobufCMessage base; /* * Fee in satoshis. */ uint64_t close_fee; /* * Signature on the close transaction. */ Signature *sig; }; #define CLOSE_SIGNATURE__INIT \ { PROTOBUF_C_MESSAGE_INIT (&close_signature__descriptor) \ , 0, NULL } /* * This means we're going to hang up; it's to help diagnose only! */ struct _Error { ProtobufCMessage base; char *problem; }; #define ERROR__INIT \ { PROTOBUF_C_MESSAGE_INIT (&error__descriptor) \ , NULL } typedef enum { PKT__PKT__NOT_SET = 0, PKT__PKT_AUTH = 50, PKT__PKT_OPEN = 20, PKT__PKT_OPEN_ANCHOR = 21, PKT__PKT_OPEN_COMMIT_SIG = 22, PKT__PKT_OPEN_COMPLETE = 23, PKT__PKT_UPDATE_ADD_HTLC = 2, PKT__PKT_UPDATE_ACCEPT = 3, PKT__PKT_UPDATE_SIGNATURE = 4, PKT__PKT_UPDATE_COMPLETE = 5, PKT__PKT_UPDATE_DECLINE_HTLC = 6, PKT__PKT_UPDATE_FULFILL_HTLC = 7, PKT__PKT_UPDATE_FAIL_HTLC = 9, PKT__PKT_CLOSE_CLEARING = 30, PKT__PKT_CLOSE_SIGNATURE = 31, PKT__PKT_ERROR = 40, } Pkt__PktCase; /* * This is the union which defines all of them */ struct _Pkt { ProtobufCMessage base; Pkt__PktCase pkt_case; union { /* * Start of connection */ Authenticate *auth; /* * Opening */ OpenChannel *open; OpenAnchor *open_anchor; OpenCommitSig *open_commit_sig; OpenComplete *open_complete; /* * Updating (most common) */ UpdateAddHtlc *update_add_htlc; UpdateAccept *update_accept; UpdateSignature *update_signature; UpdateComplete *update_complete; UpdateDeclineHtlc *update_decline_htlc; UpdateFulfillHtlc *update_fulfill_htlc; UpdateFailHtlc *update_fail_htlc; /* * Closing */ CloseClearing *close_clearing; CloseSignature *close_signature; /* * Unexpected issue. */ Error *error; }; }; #define PKT__INIT \ { PROTOBUF_C_MESSAGE_INIT (&pkt__descriptor) \ , PKT__PKT__NOT_SET, {} } /* Sha256Hash methods */ void sha256_hash__init (Sha256Hash *message); size_t sha256_hash__get_packed_size (const Sha256Hash *message); size_t sha256_hash__pack (const Sha256Hash *message, uint8_t *out); size_t sha256_hash__pack_to_buffer (const Sha256Hash *message, ProtobufCBuffer *buffer); Sha256Hash * sha256_hash__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void sha256_hash__free_unpacked (Sha256Hash *message, ProtobufCAllocator *allocator); /* Signature methods */ void signature__init (Signature *message); size_t signature__get_packed_size (const Signature *message); size_t signature__pack (const Signature *message, uint8_t *out); size_t signature__pack_to_buffer (const Signature *message, ProtobufCBuffer *buffer); Signature * signature__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void signature__free_unpacked (Signature *message, ProtobufCAllocator *allocator); /* Locktime methods */ void locktime__init (Locktime *message); size_t locktime__get_packed_size (const Locktime *message); size_t locktime__pack (const Locktime *message, uint8_t *out); size_t locktime__pack_to_buffer (const Locktime *message, ProtobufCBuffer *buffer); Locktime * locktime__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void locktime__free_unpacked (Locktime *message, ProtobufCAllocator *allocator); /* BitcoinPubkey methods */ void bitcoin_pubkey__init (BitcoinPubkey *message); size_t bitcoin_pubkey__get_packed_size (const BitcoinPubkey *message); size_t bitcoin_pubkey__pack (const BitcoinPubkey *message, uint8_t *out); size_t bitcoin_pubkey__pack_to_buffer (const BitcoinPubkey *message, ProtobufCBuffer *buffer); BitcoinPubkey * bitcoin_pubkey__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void bitcoin_pubkey__free_unpacked (BitcoinPubkey *message, ProtobufCAllocator *allocator); /* Funding methods */ void funding__init (Funding *message); size_t funding__get_packed_size (const Funding *message); size_t funding__pack (const Funding *message, uint8_t *out); size_t funding__pack_to_buffer (const Funding *message, ProtobufCBuffer *buffer); Funding * funding__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void funding__free_unpacked (Funding *message, ProtobufCAllocator *allocator); /* Authenticate methods */ void authenticate__init (Authenticate *message); size_t authenticate__get_packed_size (const Authenticate *message); size_t authenticate__pack (const Authenticate *message, uint8_t *out); size_t authenticate__pack_to_buffer (const Authenticate *message, ProtobufCBuffer *buffer); Authenticate * authenticate__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void authenticate__free_unpacked (Authenticate *message, ProtobufCAllocator *allocator); /* OpenChannel methods */ void open_channel__init (OpenChannel *message); size_t open_channel__get_packed_size (const OpenChannel *message); size_t open_channel__pack (const OpenChannel *message, uint8_t *out); size_t open_channel__pack_to_buffer (const OpenChannel *message, ProtobufCBuffer *buffer); OpenChannel * open_channel__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void open_channel__free_unpacked (OpenChannel *message, ProtobufCAllocator *allocator); /* OpenAnchor methods */ void open_anchor__init (OpenAnchor *message); size_t open_anchor__get_packed_size (const OpenAnchor *message); size_t open_anchor__pack (const OpenAnchor *message, uint8_t *out); size_t open_anchor__pack_to_buffer (const OpenAnchor *message, ProtobufCBuffer *buffer); OpenAnchor * open_anchor__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void open_anchor__free_unpacked (OpenAnchor *message, ProtobufCAllocator *allocator); /* OpenCommitSig methods */ void open_commit_sig__init (OpenCommitSig *message); size_t open_commit_sig__get_packed_size (const OpenCommitSig *message); size_t open_commit_sig__pack (const OpenCommitSig *message, uint8_t *out); size_t open_commit_sig__pack_to_buffer (const OpenCommitSig *message, ProtobufCBuffer *buffer); OpenCommitSig * open_commit_sig__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void open_commit_sig__free_unpacked (OpenCommitSig *message, ProtobufCAllocator *allocator); /* OpenComplete methods */ void open_complete__init (OpenComplete *message); size_t open_complete__get_packed_size (const OpenComplete *message); size_t open_complete__pack (const OpenComplete *message, uint8_t *out); size_t open_complete__pack_to_buffer (const OpenComplete *message, ProtobufCBuffer *buffer); OpenComplete * open_complete__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void open_complete__free_unpacked (OpenComplete *message, ProtobufCAllocator *allocator); /* UpdateAddHtlc methods */ void update_add_htlc__init (UpdateAddHtlc *message); size_t update_add_htlc__get_packed_size (const UpdateAddHtlc *message); size_t update_add_htlc__pack (const UpdateAddHtlc *message, uint8_t *out); size_t update_add_htlc__pack_to_buffer (const UpdateAddHtlc *message, ProtobufCBuffer *buffer); UpdateAddHtlc * update_add_htlc__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void update_add_htlc__free_unpacked (UpdateAddHtlc *message, ProtobufCAllocator *allocator); /* UpdateDeclineHtlc methods */ void update_decline_htlc__init (UpdateDeclineHtlc *message); size_t update_decline_htlc__get_packed_size (const UpdateDeclineHtlc *message); size_t update_decline_htlc__pack (const UpdateDeclineHtlc *message, uint8_t *out); size_t update_decline_htlc__pack_to_buffer (const UpdateDeclineHtlc *message, ProtobufCBuffer *buffer); UpdateDeclineHtlc * update_decline_htlc__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void update_decline_htlc__free_unpacked (UpdateDeclineHtlc *message, ProtobufCAllocator *allocator); /* UpdateFulfillHtlc methods */ void update_fulfill_htlc__init (UpdateFulfillHtlc *message); size_t update_fulfill_htlc__get_packed_size (const UpdateFulfillHtlc *message); size_t update_fulfill_htlc__pack (const UpdateFulfillHtlc *message, uint8_t *out); size_t update_fulfill_htlc__pack_to_buffer (const UpdateFulfillHtlc *message, ProtobufCBuffer *buffer); UpdateFulfillHtlc * update_fulfill_htlc__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void update_fulfill_htlc__free_unpacked (UpdateFulfillHtlc *message, ProtobufCAllocator *allocator); /* UpdateFailHtlc methods */ void update_fail_htlc__init (UpdateFailHtlc *message); size_t update_fail_htlc__get_packed_size (const UpdateFailHtlc *message); size_t update_fail_htlc__pack (const UpdateFailHtlc *message, uint8_t *out); size_t update_fail_htlc__pack_to_buffer (const UpdateFailHtlc *message, ProtobufCBuffer *buffer); UpdateFailHtlc * update_fail_htlc__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void update_fail_htlc__free_unpacked (UpdateFailHtlc *message, ProtobufCAllocator *allocator); /* UpdateAccept methods */ void update_accept__init (UpdateAccept *message); size_t update_accept__get_packed_size (const UpdateAccept *message); size_t update_accept__pack (const UpdateAccept *message, uint8_t *out); size_t update_accept__pack_to_buffer (const UpdateAccept *message, ProtobufCBuffer *buffer); UpdateAccept * update_accept__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void update_accept__free_unpacked (UpdateAccept *message, ProtobufCAllocator *allocator); /* UpdateSignature methods */ void update_signature__init (UpdateSignature *message); size_t update_signature__get_packed_size (const UpdateSignature *message); size_t update_signature__pack (const UpdateSignature *message, uint8_t *out); size_t update_signature__pack_to_buffer (const UpdateSignature *message, ProtobufCBuffer *buffer); UpdateSignature * update_signature__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void update_signature__free_unpacked (UpdateSignature *message, ProtobufCAllocator *allocator); /* UpdateComplete methods */ void update_complete__init (UpdateComplete *message); size_t update_complete__get_packed_size (const UpdateComplete *message); size_t update_complete__pack (const UpdateComplete *message, uint8_t *out); size_t update_complete__pack_to_buffer (const UpdateComplete *message, ProtobufCBuffer *buffer); UpdateComplete * update_complete__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void update_complete__free_unpacked (UpdateComplete *message, ProtobufCAllocator *allocator); /* CloseClearing methods */ void close_clearing__init (CloseClearing *message); size_t close_clearing__get_packed_size (const CloseClearing *message); size_t close_clearing__pack (const CloseClearing *message, uint8_t *out); size_t close_clearing__pack_to_buffer (const CloseClearing *message, ProtobufCBuffer *buffer); CloseClearing * close_clearing__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void close_clearing__free_unpacked (CloseClearing *message, ProtobufCAllocator *allocator); /* CloseSignature methods */ void close_signature__init (CloseSignature *message); size_t close_signature__get_packed_size (const CloseSignature *message); size_t close_signature__pack (const CloseSignature *message, uint8_t *out); size_t close_signature__pack_to_buffer (const CloseSignature *message, ProtobufCBuffer *buffer); CloseSignature * close_signature__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void close_signature__free_unpacked (CloseSignature *message, ProtobufCAllocator *allocator); /* Error methods */ void error__init (Error *message); size_t error__get_packed_size (const Error *message); size_t error__pack (const Error *message, uint8_t *out); size_t error__pack_to_buffer (const Error *message, ProtobufCBuffer *buffer); Error * error__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void error__free_unpacked (Error *message, ProtobufCAllocator *allocator); /* Pkt methods */ void pkt__init (Pkt *message); size_t pkt__get_packed_size (const Pkt *message); size_t pkt__pack (const Pkt *message, uint8_t *out); size_t pkt__pack_to_buffer (const Pkt *message, ProtobufCBuffer *buffer); Pkt * pkt__unpack (ProtobufCAllocator *allocator, size_t len, const uint8_t *data); void pkt__free_unpacked (Pkt *message, ProtobufCAllocator *allocator); /* --- per-message closures --- */ typedef void (*Sha256Hash_Closure) (const Sha256Hash *message, void *closure_data); typedef void (*Signature_Closure) (const Signature *message, void *closure_data); typedef void (*Locktime_Closure) (const Locktime *message, void *closure_data); typedef void (*BitcoinPubkey_Closure) (const BitcoinPubkey *message, void *closure_data); typedef void (*Funding_Closure) (const Funding *message, void *closure_data); typedef void (*Authenticate_Closure) (const Authenticate *message, void *closure_data); typedef void (*OpenChannel_Closure) (const OpenChannel *message, void *closure_data); typedef void (*OpenAnchor_Closure) (const OpenAnchor *message, void *closure_data); typedef void (*OpenCommitSig_Closure) (const OpenCommitSig *message, void *closure_data); typedef void (*OpenComplete_Closure) (const OpenComplete *message, void *closure_data); typedef void (*UpdateAddHtlc_Closure) (const UpdateAddHtlc *message, void *closure_data); typedef void (*UpdateDeclineHtlc_Closure) (const UpdateDeclineHtlc *message, void *closure_data); typedef void (*UpdateFulfillHtlc_Closure) (const UpdateFulfillHtlc *message, void *closure_data); typedef void (*UpdateFailHtlc_Closure) (const UpdateFailHtlc *message, void *closure_data); typedef void (*UpdateAccept_Closure) (const UpdateAccept *message, void *closure_data); typedef void (*UpdateSignature_Closure) (const UpdateSignature *message, void *closure_data); typedef void (*UpdateComplete_Closure) (const UpdateComplete *message, void *closure_data); typedef void (*CloseClearing_Closure) (const CloseClearing *message, void *closure_data); typedef void (*CloseSignature_Closure) (const CloseSignature *message, void *closure_data); typedef void (*Error_Closure) (const Error *message, void *closure_data); typedef void (*Pkt_Closure) (const Pkt *message, void *closure_data); /* --- services --- */ /* --- descriptors --- */ extern const ProtobufCMessageDescriptor sha256_hash__descriptor; extern const ProtobufCMessageDescriptor signature__descriptor; extern const ProtobufCMessageDescriptor locktime__descriptor; extern const ProtobufCMessageDescriptor bitcoin_pubkey__descriptor; extern const ProtobufCMessageDescriptor funding__descriptor; extern const ProtobufCMessageDescriptor authenticate__descriptor; extern const ProtobufCMessageDescriptor open_channel__descriptor; extern const ProtobufCEnumDescriptor open_channel__anchor_offer__descriptor; extern const ProtobufCMessageDescriptor open_anchor__descriptor; extern const ProtobufCMessageDescriptor open_commit_sig__descriptor; extern const ProtobufCMessageDescriptor open_complete__descriptor; extern const ProtobufCMessageDescriptor update_add_htlc__descriptor; extern const ProtobufCMessageDescriptor update_decline_htlc__descriptor; extern const ProtobufCMessageDescriptor update_fulfill_htlc__descriptor; extern const ProtobufCMessageDescriptor update_fail_htlc__descriptor; extern const ProtobufCMessageDescriptor update_accept__descriptor; extern const ProtobufCMessageDescriptor update_signature__descriptor; extern const ProtobufCMessageDescriptor update_complete__descriptor; extern const ProtobufCMessageDescriptor close_clearing__descriptor; extern const ProtobufCMessageDescriptor close_signature__descriptor; extern const ProtobufCMessageDescriptor error__descriptor; extern const ProtobufCMessageDescriptor pkt__descriptor; PROTOBUF_C__END_DECLS #endif /* PROTOBUF_C_lightning_2eproto__INCLUDED */