1 // This file is Copyright its original authors, visible in version control
2 // history and in the source files from which this was generated.
4 // This file is licensed under the license available in the LICENSE or LICENSE.md
5 // file in the root of this repository or, if no such file exists, the same
6 // license as that which applies to the original source files from which this
7 // source was automatically generated.
9 //! Wire messages, traits representing wire message handlers, and a few error types live here.
11 //! For a normal node you probably don't need to use anything here, however, if you wish to split a
12 //! node into an internet-facing route/message socket handling daemon and a separate daemon (or
13 //! server entirely) which handles only channel-related messages you may wish to implement
14 //! ChannelMessageHandler yourself and use it to re-serialize messages and pass them across
17 //! Note that if you go with such an architecture (instead of passing raw socket events to a
18 //! non-internet-facing system) you trust the frontend internet-facing system to not lie about the
19 //! source node_id of the message, however this does allow you to significantly reduce bandwidth
20 //! between the systems as routing messages can represent a significant chunk of bandwidth usage
21 //! (especially for non-channel-publicly-announcing nodes). As an alternate design which avoids
22 //! this issue, if you have sufficient bidirectional bandwidth between your systems, you may send
23 //! raw socket events into your non-internet-facing system and then send routing events back to
24 //! track the network on the less-secure system.
26 use alloc::str::FromStr;
27 use core::ffi::c_void;
28 use core::convert::Infallible;
29 use bitcoin::hashes::Hash;
30 use crate::c_types::*;
31 #[cfg(feature="no-std")]
32 use alloc::{vec::Vec, boxed::Box};
35 use lightning::ln::msgs::DecodeError as nativeDecodeErrorImport;
36 pub(crate) type nativeDecodeError = nativeDecodeErrorImport;
38 /// An error in decoding a message or struct.
41 pub struct DecodeError {
42 /// A pointer to the opaque Rust object.
44 /// Nearly everywhere, inner must be non-null, however in places where
45 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
46 pub inner: *mut nativeDecodeError,
47 /// Indicates that this is the only struct which contains the same pointer.
49 /// Rust functions which take ownership of an object provided via an argument require
50 /// this to be true and invalidate the object pointed to by inner.
54 impl Drop for DecodeError {
56 if self.is_owned && !<*mut nativeDecodeError>::is_null(self.inner) {
57 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
61 /// Frees any resources used by the DecodeError, if is_owned is set and inner is non-NULL.
63 pub extern "C" fn DecodeError_free(this_obj: DecodeError) { }
65 /// Used only if an object of this type is returned as a trait impl by a method
66 pub(crate) extern "C" fn DecodeError_free_void(this_ptr: *mut c_void) {
67 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeDecodeError); }
71 pub(crate) fn get_native_ref(&self) -> &'static nativeDecodeError {
72 unsafe { &*ObjOps::untweak_ptr(self.inner) }
74 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeDecodeError {
75 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
77 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
78 pub(crate) fn take_inner(mut self) -> *mut nativeDecodeError {
79 assert!(self.is_owned);
80 let ret = ObjOps::untweak_ptr(self.inner);
81 self.inner = core::ptr::null_mut();
85 impl Clone for DecodeError {
86 fn clone(&self) -> Self {
88 inner: if <*mut nativeDecodeError>::is_null(self.inner) { core::ptr::null_mut() } else {
89 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
95 /// Used only if an object of this type is returned as a trait impl by a method
96 pub(crate) extern "C" fn DecodeError_clone_void(this_ptr: *const c_void) -> *mut c_void {
97 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeDecodeError)).clone() })) as *mut c_void
100 /// Creates a copy of the DecodeError
101 pub extern "C" fn DecodeError_clone(orig: &DecodeError) -> DecodeError {
105 use lightning::ln::msgs::Init as nativeInitImport;
106 pub(crate) type nativeInit = nativeInitImport;
108 /// An init message to be sent or received from a peer
112 /// A pointer to the opaque Rust object.
114 /// Nearly everywhere, inner must be non-null, however in places where
115 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
116 pub inner: *mut nativeInit,
117 /// Indicates that this is the only struct which contains the same pointer.
119 /// Rust functions which take ownership of an object provided via an argument require
120 /// this to be true and invalidate the object pointed to by inner.
126 if self.is_owned && !<*mut nativeInit>::is_null(self.inner) {
127 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
131 /// Frees any resources used by the Init, if is_owned is set and inner is non-NULL.
133 pub extern "C" fn Init_free(this_obj: Init) { }
135 /// Used only if an object of this type is returned as a trait impl by a method
136 pub(crate) extern "C" fn Init_free_void(this_ptr: *mut c_void) {
137 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeInit); }
141 pub(crate) fn get_native_ref(&self) -> &'static nativeInit {
142 unsafe { &*ObjOps::untweak_ptr(self.inner) }
144 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeInit {
145 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
147 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
148 pub(crate) fn take_inner(mut self) -> *mut nativeInit {
149 assert!(self.is_owned);
150 let ret = ObjOps::untweak_ptr(self.inner);
151 self.inner = core::ptr::null_mut();
155 /// The relevant features which the sender supports
157 pub extern "C" fn Init_get_features(this_ptr: &Init) -> crate::lightning::ln::features::InitFeatures {
158 let mut inner_val = &mut this_ptr.get_native_mut_ref().features;
159 crate::lightning::ln::features::InitFeatures { inner: unsafe { ObjOps::nonnull_ptr_to_inner((inner_val as *const lightning::ln::features::InitFeatures<>) as *mut _) }, is_owned: false }
161 /// The relevant features which the sender supports
163 pub extern "C" fn Init_set_features(this_ptr: &mut Init, mut val: crate::lightning::ln::features::InitFeatures) {
164 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.features = *unsafe { Box::from_raw(val.take_inner()) };
166 /// The receipient's network address. This adds the option to report a remote IP address
167 /// back to a connecting peer using the init message. A node can decide to use that information
168 /// to discover a potential update to its public IPv4 address (NAT) and use
169 /// that for a node_announcement update message containing the new address.
171 pub extern "C" fn Init_get_remote_network_address(this_ptr: &Init) -> crate::c_types::derived::COption_NetAddressZ {
172 let mut inner_val = &mut this_ptr.get_native_mut_ref().remote_network_address;
173 let mut local_inner_val = if inner_val.is_none() { crate::c_types::derived::COption_NetAddressZ::None } else { crate::c_types::derived::COption_NetAddressZ::Some(/* WARNING: CLONING CONVERSION HERE! &Option<Enum> is otherwise un-expressable. */ { crate::lightning::ln::msgs::NetAddress::native_into(inner_val.clone().unwrap()) }) };
176 /// The receipient's network address. This adds the option to report a remote IP address
177 /// back to a connecting peer using the init message. A node can decide to use that information
178 /// to discover a potential update to its public IPv4 address (NAT) and use
179 /// that for a node_announcement update message containing the new address.
181 pub extern "C" fn Init_set_remote_network_address(this_ptr: &mut Init, mut val: crate::c_types::derived::COption_NetAddressZ) {
182 let mut local_val = { /* val*/ let val_opt = val; { } if val_opt.is_none() { None } else { Some({ val_opt.take().into_native() }) } };
183 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.remote_network_address = local_val;
185 /// Constructs a new Init given each field
188 pub extern "C" fn Init_new(mut features_arg: crate::lightning::ln::features::InitFeatures, mut remote_network_address_arg: crate::c_types::derived::COption_NetAddressZ) -> Init {
189 let mut local_remote_network_address_arg = { /* remote_network_address_arg*/ let remote_network_address_arg_opt = remote_network_address_arg; { } if remote_network_address_arg_opt.is_none() { None } else { Some({ remote_network_address_arg_opt.take().into_native() }) } };
190 Init { inner: ObjOps::heap_alloc(nativeInit {
191 features: *unsafe { Box::from_raw(features_arg.take_inner()) },
192 remote_network_address: local_remote_network_address_arg,
195 impl Clone for Init {
196 fn clone(&self) -> Self {
198 inner: if <*mut nativeInit>::is_null(self.inner) { core::ptr::null_mut() } else {
199 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
205 /// Used only if an object of this type is returned as a trait impl by a method
206 pub(crate) extern "C" fn Init_clone_void(this_ptr: *const c_void) -> *mut c_void {
207 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeInit)).clone() })) as *mut c_void
210 /// Creates a copy of the Init
211 pub extern "C" fn Init_clone(orig: &Init) -> Init {
215 use lightning::ln::msgs::ErrorMessage as nativeErrorMessageImport;
216 pub(crate) type nativeErrorMessage = nativeErrorMessageImport;
218 /// An error message to be sent or received from a peer
221 pub struct ErrorMessage {
222 /// A pointer to the opaque Rust object.
224 /// Nearly everywhere, inner must be non-null, however in places where
225 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
226 pub inner: *mut nativeErrorMessage,
227 /// Indicates that this is the only struct which contains the same pointer.
229 /// Rust functions which take ownership of an object provided via an argument require
230 /// this to be true and invalidate the object pointed to by inner.
234 impl Drop for ErrorMessage {
236 if self.is_owned && !<*mut nativeErrorMessage>::is_null(self.inner) {
237 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
241 /// Frees any resources used by the ErrorMessage, if is_owned is set and inner is non-NULL.
243 pub extern "C" fn ErrorMessage_free(this_obj: ErrorMessage) { }
245 /// Used only if an object of this type is returned as a trait impl by a method
246 pub(crate) extern "C" fn ErrorMessage_free_void(this_ptr: *mut c_void) {
247 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeErrorMessage); }
251 pub(crate) fn get_native_ref(&self) -> &'static nativeErrorMessage {
252 unsafe { &*ObjOps::untweak_ptr(self.inner) }
254 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeErrorMessage {
255 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
257 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
258 pub(crate) fn take_inner(mut self) -> *mut nativeErrorMessage {
259 assert!(self.is_owned);
260 let ret = ObjOps::untweak_ptr(self.inner);
261 self.inner = core::ptr::null_mut();
265 /// The channel ID involved in the error.
267 /// All-0s indicates a general error unrelated to a specific channel, after which all channels
268 /// with the sending peer should be closed.
270 pub extern "C" fn ErrorMessage_get_channel_id(this_ptr: &ErrorMessage) -> *const [u8; 32] {
271 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
274 /// The channel ID involved in the error.
276 /// All-0s indicates a general error unrelated to a specific channel, after which all channels
277 /// with the sending peer should be closed.
279 pub extern "C" fn ErrorMessage_set_channel_id(this_ptr: &mut ErrorMessage, mut val: crate::c_types::ThirtyTwoBytes) {
280 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
282 /// A possibly human-readable error description.
283 /// The string should be sanitized before it is used (e.g. emitted to logs or printed to
284 /// stdout). Otherwise, a well crafted error message may trigger a security vulnerability in
285 /// the terminal emulator or the logging subsystem.
287 pub extern "C" fn ErrorMessage_get_data(this_ptr: &ErrorMessage) -> crate::c_types::Str {
288 let mut inner_val = &mut this_ptr.get_native_mut_ref().data;
289 inner_val.as_str().into()
291 /// A possibly human-readable error description.
292 /// The string should be sanitized before it is used (e.g. emitted to logs or printed to
293 /// stdout). Otherwise, a well crafted error message may trigger a security vulnerability in
294 /// the terminal emulator or the logging subsystem.
296 pub extern "C" fn ErrorMessage_set_data(this_ptr: &mut ErrorMessage, mut val: crate::c_types::Str) {
297 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.data = val.into_string();
299 /// Constructs a new ErrorMessage given each field
302 pub extern "C" fn ErrorMessage_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut data_arg: crate::c_types::Str) -> ErrorMessage {
303 ErrorMessage { inner: ObjOps::heap_alloc(nativeErrorMessage {
304 channel_id: channel_id_arg.data,
305 data: data_arg.into_string(),
308 impl Clone for ErrorMessage {
309 fn clone(&self) -> Self {
311 inner: if <*mut nativeErrorMessage>::is_null(self.inner) { core::ptr::null_mut() } else {
312 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
318 /// Used only if an object of this type is returned as a trait impl by a method
319 pub(crate) extern "C" fn ErrorMessage_clone_void(this_ptr: *const c_void) -> *mut c_void {
320 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeErrorMessage)).clone() })) as *mut c_void
323 /// Creates a copy of the ErrorMessage
324 pub extern "C" fn ErrorMessage_clone(orig: &ErrorMessage) -> ErrorMessage {
328 use lightning::ln::msgs::WarningMessage as nativeWarningMessageImport;
329 pub(crate) type nativeWarningMessage = nativeWarningMessageImport;
331 /// A warning message to be sent or received from a peer
334 pub struct WarningMessage {
335 /// A pointer to the opaque Rust object.
337 /// Nearly everywhere, inner must be non-null, however in places where
338 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
339 pub inner: *mut nativeWarningMessage,
340 /// Indicates that this is the only struct which contains the same pointer.
342 /// Rust functions which take ownership of an object provided via an argument require
343 /// this to be true and invalidate the object pointed to by inner.
347 impl Drop for WarningMessage {
349 if self.is_owned && !<*mut nativeWarningMessage>::is_null(self.inner) {
350 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
354 /// Frees any resources used by the WarningMessage, if is_owned is set and inner is non-NULL.
356 pub extern "C" fn WarningMessage_free(this_obj: WarningMessage) { }
358 /// Used only if an object of this type is returned as a trait impl by a method
359 pub(crate) extern "C" fn WarningMessage_free_void(this_ptr: *mut c_void) {
360 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeWarningMessage); }
363 impl WarningMessage {
364 pub(crate) fn get_native_ref(&self) -> &'static nativeWarningMessage {
365 unsafe { &*ObjOps::untweak_ptr(self.inner) }
367 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeWarningMessage {
368 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
370 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
371 pub(crate) fn take_inner(mut self) -> *mut nativeWarningMessage {
372 assert!(self.is_owned);
373 let ret = ObjOps::untweak_ptr(self.inner);
374 self.inner = core::ptr::null_mut();
378 /// The channel ID involved in the warning.
380 /// All-0s indicates a warning unrelated to a specific channel.
382 pub extern "C" fn WarningMessage_get_channel_id(this_ptr: &WarningMessage) -> *const [u8; 32] {
383 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
386 /// The channel ID involved in the warning.
388 /// All-0s indicates a warning unrelated to a specific channel.
390 pub extern "C" fn WarningMessage_set_channel_id(this_ptr: &mut WarningMessage, mut val: crate::c_types::ThirtyTwoBytes) {
391 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
393 /// A possibly human-readable warning description.
394 /// The string should be sanitized before it is used (e.g. emitted to logs or printed to
395 /// stdout). Otherwise, a well crafted error message may trigger a security vulnerability in
396 /// the terminal emulator or the logging subsystem.
398 pub extern "C" fn WarningMessage_get_data(this_ptr: &WarningMessage) -> crate::c_types::Str {
399 let mut inner_val = &mut this_ptr.get_native_mut_ref().data;
400 inner_val.as_str().into()
402 /// A possibly human-readable warning description.
403 /// The string should be sanitized before it is used (e.g. emitted to logs or printed to
404 /// stdout). Otherwise, a well crafted error message may trigger a security vulnerability in
405 /// the terminal emulator or the logging subsystem.
407 pub extern "C" fn WarningMessage_set_data(this_ptr: &mut WarningMessage, mut val: crate::c_types::Str) {
408 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.data = val.into_string();
410 /// Constructs a new WarningMessage given each field
413 pub extern "C" fn WarningMessage_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut data_arg: crate::c_types::Str) -> WarningMessage {
414 WarningMessage { inner: ObjOps::heap_alloc(nativeWarningMessage {
415 channel_id: channel_id_arg.data,
416 data: data_arg.into_string(),
419 impl Clone for WarningMessage {
420 fn clone(&self) -> Self {
422 inner: if <*mut nativeWarningMessage>::is_null(self.inner) { core::ptr::null_mut() } else {
423 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
429 /// Used only if an object of this type is returned as a trait impl by a method
430 pub(crate) extern "C" fn WarningMessage_clone_void(this_ptr: *const c_void) -> *mut c_void {
431 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeWarningMessage)).clone() })) as *mut c_void
434 /// Creates a copy of the WarningMessage
435 pub extern "C" fn WarningMessage_clone(orig: &WarningMessage) -> WarningMessage {
439 use lightning::ln::msgs::Ping as nativePingImport;
440 pub(crate) type nativePing = nativePingImport;
442 /// A ping message to be sent or received from a peer
446 /// A pointer to the opaque Rust object.
448 /// Nearly everywhere, inner must be non-null, however in places where
449 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
450 pub inner: *mut nativePing,
451 /// Indicates that this is the only struct which contains the same pointer.
453 /// Rust functions which take ownership of an object provided via an argument require
454 /// this to be true and invalidate the object pointed to by inner.
460 if self.is_owned && !<*mut nativePing>::is_null(self.inner) {
461 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
465 /// Frees any resources used by the Ping, if is_owned is set and inner is non-NULL.
467 pub extern "C" fn Ping_free(this_obj: Ping) { }
469 /// Used only if an object of this type is returned as a trait impl by a method
470 pub(crate) extern "C" fn Ping_free_void(this_ptr: *mut c_void) {
471 unsafe { let _ = Box::from_raw(this_ptr as *mut nativePing); }
475 pub(crate) fn get_native_ref(&self) -> &'static nativePing {
476 unsafe { &*ObjOps::untweak_ptr(self.inner) }
478 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativePing {
479 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
481 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
482 pub(crate) fn take_inner(mut self) -> *mut nativePing {
483 assert!(self.is_owned);
484 let ret = ObjOps::untweak_ptr(self.inner);
485 self.inner = core::ptr::null_mut();
489 /// The desired response length
491 pub extern "C" fn Ping_get_ponglen(this_ptr: &Ping) -> u16 {
492 let mut inner_val = &mut this_ptr.get_native_mut_ref().ponglen;
495 /// The desired response length
497 pub extern "C" fn Ping_set_ponglen(this_ptr: &mut Ping, mut val: u16) {
498 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.ponglen = val;
500 /// The ping packet size.
501 /// This field is not sent on the wire. byteslen zeros are sent.
503 pub extern "C" fn Ping_get_byteslen(this_ptr: &Ping) -> u16 {
504 let mut inner_val = &mut this_ptr.get_native_mut_ref().byteslen;
507 /// The ping packet size.
508 /// This field is not sent on the wire. byteslen zeros are sent.
510 pub extern "C" fn Ping_set_byteslen(this_ptr: &mut Ping, mut val: u16) {
511 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.byteslen = val;
513 /// Constructs a new Ping given each field
516 pub extern "C" fn Ping_new(mut ponglen_arg: u16, mut byteslen_arg: u16) -> Ping {
517 Ping { inner: ObjOps::heap_alloc(nativePing {
518 ponglen: ponglen_arg,
519 byteslen: byteslen_arg,
522 impl Clone for Ping {
523 fn clone(&self) -> Self {
525 inner: if <*mut nativePing>::is_null(self.inner) { core::ptr::null_mut() } else {
526 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
532 /// Used only if an object of this type is returned as a trait impl by a method
533 pub(crate) extern "C" fn Ping_clone_void(this_ptr: *const c_void) -> *mut c_void {
534 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativePing)).clone() })) as *mut c_void
537 /// Creates a copy of the Ping
538 pub extern "C" fn Ping_clone(orig: &Ping) -> Ping {
542 use lightning::ln::msgs::Pong as nativePongImport;
543 pub(crate) type nativePong = nativePongImport;
545 /// A pong message to be sent or received from a peer
549 /// A pointer to the opaque Rust object.
551 /// Nearly everywhere, inner must be non-null, however in places where
552 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
553 pub inner: *mut nativePong,
554 /// Indicates that this is the only struct which contains the same pointer.
556 /// Rust functions which take ownership of an object provided via an argument require
557 /// this to be true and invalidate the object pointed to by inner.
563 if self.is_owned && !<*mut nativePong>::is_null(self.inner) {
564 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
568 /// Frees any resources used by the Pong, if is_owned is set and inner is non-NULL.
570 pub extern "C" fn Pong_free(this_obj: Pong) { }
572 /// Used only if an object of this type is returned as a trait impl by a method
573 pub(crate) extern "C" fn Pong_free_void(this_ptr: *mut c_void) {
574 unsafe { let _ = Box::from_raw(this_ptr as *mut nativePong); }
578 pub(crate) fn get_native_ref(&self) -> &'static nativePong {
579 unsafe { &*ObjOps::untweak_ptr(self.inner) }
581 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativePong {
582 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
584 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
585 pub(crate) fn take_inner(mut self) -> *mut nativePong {
586 assert!(self.is_owned);
587 let ret = ObjOps::untweak_ptr(self.inner);
588 self.inner = core::ptr::null_mut();
592 /// The pong packet size.
593 /// This field is not sent on the wire. byteslen zeros are sent.
595 pub extern "C" fn Pong_get_byteslen(this_ptr: &Pong) -> u16 {
596 let mut inner_val = &mut this_ptr.get_native_mut_ref().byteslen;
599 /// The pong packet size.
600 /// This field is not sent on the wire. byteslen zeros are sent.
602 pub extern "C" fn Pong_set_byteslen(this_ptr: &mut Pong, mut val: u16) {
603 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.byteslen = val;
605 /// Constructs a new Pong given each field
608 pub extern "C" fn Pong_new(mut byteslen_arg: u16) -> Pong {
609 Pong { inner: ObjOps::heap_alloc(nativePong {
610 byteslen: byteslen_arg,
613 impl Clone for Pong {
614 fn clone(&self) -> Self {
616 inner: if <*mut nativePong>::is_null(self.inner) { core::ptr::null_mut() } else {
617 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
623 /// Used only if an object of this type is returned as a trait impl by a method
624 pub(crate) extern "C" fn Pong_clone_void(this_ptr: *const c_void) -> *mut c_void {
625 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativePong)).clone() })) as *mut c_void
628 /// Creates a copy of the Pong
629 pub extern "C" fn Pong_clone(orig: &Pong) -> Pong {
633 use lightning::ln::msgs::OpenChannel as nativeOpenChannelImport;
634 pub(crate) type nativeOpenChannel = nativeOpenChannelImport;
636 /// An open_channel message to be sent or received from a peer
639 pub struct OpenChannel {
640 /// A pointer to the opaque Rust object.
642 /// Nearly everywhere, inner must be non-null, however in places where
643 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
644 pub inner: *mut nativeOpenChannel,
645 /// Indicates that this is the only struct which contains the same pointer.
647 /// Rust functions which take ownership of an object provided via an argument require
648 /// this to be true and invalidate the object pointed to by inner.
652 impl Drop for OpenChannel {
654 if self.is_owned && !<*mut nativeOpenChannel>::is_null(self.inner) {
655 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
659 /// Frees any resources used by the OpenChannel, if is_owned is set and inner is non-NULL.
661 pub extern "C" fn OpenChannel_free(this_obj: OpenChannel) { }
663 /// Used only if an object of this type is returned as a trait impl by a method
664 pub(crate) extern "C" fn OpenChannel_free_void(this_ptr: *mut c_void) {
665 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeOpenChannel); }
669 pub(crate) fn get_native_ref(&self) -> &'static nativeOpenChannel {
670 unsafe { &*ObjOps::untweak_ptr(self.inner) }
672 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeOpenChannel {
673 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
675 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
676 pub(crate) fn take_inner(mut self) -> *mut nativeOpenChannel {
677 assert!(self.is_owned);
678 let ret = ObjOps::untweak_ptr(self.inner);
679 self.inner = core::ptr::null_mut();
683 /// The genesis hash of the blockchain where the channel is to be opened
685 pub extern "C" fn OpenChannel_get_chain_hash(this_ptr: &OpenChannel) -> *const [u8; 32] {
686 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
689 /// The genesis hash of the blockchain where the channel is to be opened
691 pub extern "C" fn OpenChannel_set_chain_hash(this_ptr: &mut OpenChannel, mut val: crate::c_types::ThirtyTwoBytes) {
692 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
694 /// A temporary channel ID, until the funding outpoint is announced
696 pub extern "C" fn OpenChannel_get_temporary_channel_id(this_ptr: &OpenChannel) -> *const [u8; 32] {
697 let mut inner_val = &mut this_ptr.get_native_mut_ref().temporary_channel_id;
700 /// A temporary channel ID, until the funding outpoint is announced
702 pub extern "C" fn OpenChannel_set_temporary_channel_id(this_ptr: &mut OpenChannel, mut val: crate::c_types::ThirtyTwoBytes) {
703 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.temporary_channel_id = val.data;
705 /// The channel value
707 pub extern "C" fn OpenChannel_get_funding_satoshis(this_ptr: &OpenChannel) -> u64 {
708 let mut inner_val = &mut this_ptr.get_native_mut_ref().funding_satoshis;
711 /// The channel value
713 pub extern "C" fn OpenChannel_set_funding_satoshis(this_ptr: &mut OpenChannel, mut val: u64) {
714 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.funding_satoshis = val;
716 /// The amount to push to the counterparty as part of the open, in milli-satoshi
718 pub extern "C" fn OpenChannel_get_push_msat(this_ptr: &OpenChannel) -> u64 {
719 let mut inner_val = &mut this_ptr.get_native_mut_ref().push_msat;
722 /// The amount to push to the counterparty as part of the open, in milli-satoshi
724 pub extern "C" fn OpenChannel_set_push_msat(this_ptr: &mut OpenChannel, mut val: u64) {
725 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.push_msat = val;
727 /// The threshold below which outputs on transactions broadcast by sender will be omitted
729 pub extern "C" fn OpenChannel_get_dust_limit_satoshis(this_ptr: &OpenChannel) -> u64 {
730 let mut inner_val = &mut this_ptr.get_native_mut_ref().dust_limit_satoshis;
733 /// The threshold below which outputs on transactions broadcast by sender will be omitted
735 pub extern "C" fn OpenChannel_set_dust_limit_satoshis(this_ptr: &mut OpenChannel, mut val: u64) {
736 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.dust_limit_satoshis = val;
738 /// The maximum inbound HTLC value in flight towards sender, in milli-satoshi
740 pub extern "C" fn OpenChannel_get_max_htlc_value_in_flight_msat(this_ptr: &OpenChannel) -> u64 {
741 let mut inner_val = &mut this_ptr.get_native_mut_ref().max_htlc_value_in_flight_msat;
744 /// The maximum inbound HTLC value in flight towards sender, in milli-satoshi
746 pub extern "C" fn OpenChannel_set_max_htlc_value_in_flight_msat(this_ptr: &mut OpenChannel, mut val: u64) {
747 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.max_htlc_value_in_flight_msat = val;
749 /// The minimum value unencumbered by HTLCs for the counterparty to keep in the channel
751 pub extern "C" fn OpenChannel_get_channel_reserve_satoshis(this_ptr: &OpenChannel) -> u64 {
752 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_reserve_satoshis;
755 /// The minimum value unencumbered by HTLCs for the counterparty to keep in the channel
757 pub extern "C" fn OpenChannel_set_channel_reserve_satoshis(this_ptr: &mut OpenChannel, mut val: u64) {
758 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_reserve_satoshis = val;
760 /// The minimum HTLC size incoming to sender, in milli-satoshi
762 pub extern "C" fn OpenChannel_get_htlc_minimum_msat(this_ptr: &OpenChannel) -> u64 {
763 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_minimum_msat;
766 /// The minimum HTLC size incoming to sender, in milli-satoshi
768 pub extern "C" fn OpenChannel_set_htlc_minimum_msat(this_ptr: &mut OpenChannel, mut val: u64) {
769 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_minimum_msat = val;
771 /// The feerate per 1000-weight of sender generated transactions, until updated by update_fee
773 pub extern "C" fn OpenChannel_get_feerate_per_kw(this_ptr: &OpenChannel) -> u32 {
774 let mut inner_val = &mut this_ptr.get_native_mut_ref().feerate_per_kw;
777 /// The feerate per 1000-weight of sender generated transactions, until updated by update_fee
779 pub extern "C" fn OpenChannel_set_feerate_per_kw(this_ptr: &mut OpenChannel, mut val: u32) {
780 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.feerate_per_kw = val;
782 /// The number of blocks which the counterparty will have to wait to claim on-chain funds if they broadcast a commitment transaction
784 pub extern "C" fn OpenChannel_get_to_self_delay(this_ptr: &OpenChannel) -> u16 {
785 let mut inner_val = &mut this_ptr.get_native_mut_ref().to_self_delay;
788 /// The number of blocks which the counterparty will have to wait to claim on-chain funds if they broadcast a commitment transaction
790 pub extern "C" fn OpenChannel_set_to_self_delay(this_ptr: &mut OpenChannel, mut val: u16) {
791 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.to_self_delay = val;
793 /// The maximum number of inbound HTLCs towards sender
795 pub extern "C" fn OpenChannel_get_max_accepted_htlcs(this_ptr: &OpenChannel) -> u16 {
796 let mut inner_val = &mut this_ptr.get_native_mut_ref().max_accepted_htlcs;
799 /// The maximum number of inbound HTLCs towards sender
801 pub extern "C" fn OpenChannel_set_max_accepted_htlcs(this_ptr: &mut OpenChannel, mut val: u16) {
802 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.max_accepted_htlcs = val;
804 /// The sender's key controlling the funding transaction
806 pub extern "C" fn OpenChannel_get_funding_pubkey(this_ptr: &OpenChannel) -> crate::c_types::PublicKey {
807 let mut inner_val = &mut this_ptr.get_native_mut_ref().funding_pubkey;
808 crate::c_types::PublicKey::from_rust(&inner_val)
810 /// The sender's key controlling the funding transaction
812 pub extern "C" fn OpenChannel_set_funding_pubkey(this_ptr: &mut OpenChannel, mut val: crate::c_types::PublicKey) {
813 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.funding_pubkey = val.into_rust();
815 /// Used to derive a revocation key for transactions broadcast by counterparty
817 pub extern "C" fn OpenChannel_get_revocation_basepoint(this_ptr: &OpenChannel) -> crate::c_types::PublicKey {
818 let mut inner_val = &mut this_ptr.get_native_mut_ref().revocation_basepoint;
819 crate::c_types::PublicKey::from_rust(&inner_val)
821 /// Used to derive a revocation key for transactions broadcast by counterparty
823 pub extern "C" fn OpenChannel_set_revocation_basepoint(this_ptr: &mut OpenChannel, mut val: crate::c_types::PublicKey) {
824 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.revocation_basepoint = val.into_rust();
826 /// A payment key to sender for transactions broadcast by counterparty
828 pub extern "C" fn OpenChannel_get_payment_point(this_ptr: &OpenChannel) -> crate::c_types::PublicKey {
829 let mut inner_val = &mut this_ptr.get_native_mut_ref().payment_point;
830 crate::c_types::PublicKey::from_rust(&inner_val)
832 /// A payment key to sender for transactions broadcast by counterparty
834 pub extern "C" fn OpenChannel_set_payment_point(this_ptr: &mut OpenChannel, mut val: crate::c_types::PublicKey) {
835 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.payment_point = val.into_rust();
837 /// Used to derive a payment key to sender for transactions broadcast by sender
839 pub extern "C" fn OpenChannel_get_delayed_payment_basepoint(this_ptr: &OpenChannel) -> crate::c_types::PublicKey {
840 let mut inner_val = &mut this_ptr.get_native_mut_ref().delayed_payment_basepoint;
841 crate::c_types::PublicKey::from_rust(&inner_val)
843 /// Used to derive a payment key to sender for transactions broadcast by sender
845 pub extern "C" fn OpenChannel_set_delayed_payment_basepoint(this_ptr: &mut OpenChannel, mut val: crate::c_types::PublicKey) {
846 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.delayed_payment_basepoint = val.into_rust();
848 /// Used to derive an HTLC payment key to sender
850 pub extern "C" fn OpenChannel_get_htlc_basepoint(this_ptr: &OpenChannel) -> crate::c_types::PublicKey {
851 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_basepoint;
852 crate::c_types::PublicKey::from_rust(&inner_val)
854 /// Used to derive an HTLC payment key to sender
856 pub extern "C" fn OpenChannel_set_htlc_basepoint(this_ptr: &mut OpenChannel, mut val: crate::c_types::PublicKey) {
857 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_basepoint = val.into_rust();
859 /// The first to-be-broadcast-by-sender transaction's per commitment point
861 pub extern "C" fn OpenChannel_get_first_per_commitment_point(this_ptr: &OpenChannel) -> crate::c_types::PublicKey {
862 let mut inner_val = &mut this_ptr.get_native_mut_ref().first_per_commitment_point;
863 crate::c_types::PublicKey::from_rust(&inner_val)
865 /// The first to-be-broadcast-by-sender transaction's per commitment point
867 pub extern "C" fn OpenChannel_set_first_per_commitment_point(this_ptr: &mut OpenChannel, mut val: crate::c_types::PublicKey) {
868 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.first_per_commitment_point = val.into_rust();
872 pub extern "C" fn OpenChannel_get_channel_flags(this_ptr: &OpenChannel) -> u8 {
873 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_flags;
878 pub extern "C" fn OpenChannel_set_channel_flags(this_ptr: &mut OpenChannel, mut val: u8) {
879 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_flags = val;
881 /// The channel type that this channel will represent. If none is set, we derive the channel
882 /// type from the intersection of our feature bits with our counterparty's feature bits from
883 /// the Init message.
885 /// Note that the return value (or a relevant inner pointer) may be NULL or all-0s to represent None
887 pub extern "C" fn OpenChannel_get_channel_type(this_ptr: &OpenChannel) -> crate::lightning::ln::features::ChannelTypeFeatures {
888 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_type;
889 let mut local_inner_val = crate::lightning::ln::features::ChannelTypeFeatures { inner: unsafe { (if inner_val.is_none() { core::ptr::null() } else { ObjOps::nonnull_ptr_to_inner( { (inner_val.as_ref().unwrap()) }) } as *const lightning::ln::features::ChannelTypeFeatures<>) as *mut _ }, is_owned: false };
892 /// The channel type that this channel will represent. If none is set, we derive the channel
893 /// type from the intersection of our feature bits with our counterparty's feature bits from
894 /// the Init message.
896 /// Note that val (or a relevant inner pointer) may be NULL or all-0s to represent None
898 pub extern "C" fn OpenChannel_set_channel_type(this_ptr: &mut OpenChannel, mut val: crate::lightning::ln::features::ChannelTypeFeatures) {
899 let mut local_val = if val.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(val.take_inner()) } }) };
900 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_type = local_val;
902 impl Clone for OpenChannel {
903 fn clone(&self) -> Self {
905 inner: if <*mut nativeOpenChannel>::is_null(self.inner) { core::ptr::null_mut() } else {
906 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
912 /// Used only if an object of this type is returned as a trait impl by a method
913 pub(crate) extern "C" fn OpenChannel_clone_void(this_ptr: *const c_void) -> *mut c_void {
914 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeOpenChannel)).clone() })) as *mut c_void
917 /// Creates a copy of the OpenChannel
918 pub extern "C" fn OpenChannel_clone(orig: &OpenChannel) -> OpenChannel {
922 use lightning::ln::msgs::AcceptChannel as nativeAcceptChannelImport;
923 pub(crate) type nativeAcceptChannel = nativeAcceptChannelImport;
925 /// An accept_channel message to be sent or received from a peer
928 pub struct AcceptChannel {
929 /// A pointer to the opaque Rust object.
931 /// Nearly everywhere, inner must be non-null, however in places where
932 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
933 pub inner: *mut nativeAcceptChannel,
934 /// Indicates that this is the only struct which contains the same pointer.
936 /// Rust functions which take ownership of an object provided via an argument require
937 /// this to be true and invalidate the object pointed to by inner.
941 impl Drop for AcceptChannel {
943 if self.is_owned && !<*mut nativeAcceptChannel>::is_null(self.inner) {
944 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
948 /// Frees any resources used by the AcceptChannel, if is_owned is set and inner is non-NULL.
950 pub extern "C" fn AcceptChannel_free(this_obj: AcceptChannel) { }
952 /// Used only if an object of this type is returned as a trait impl by a method
953 pub(crate) extern "C" fn AcceptChannel_free_void(this_ptr: *mut c_void) {
954 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeAcceptChannel); }
958 pub(crate) fn get_native_ref(&self) -> &'static nativeAcceptChannel {
959 unsafe { &*ObjOps::untweak_ptr(self.inner) }
961 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeAcceptChannel {
962 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
964 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
965 pub(crate) fn take_inner(mut self) -> *mut nativeAcceptChannel {
966 assert!(self.is_owned);
967 let ret = ObjOps::untweak_ptr(self.inner);
968 self.inner = core::ptr::null_mut();
972 /// A temporary channel ID, until the funding outpoint is announced
974 pub extern "C" fn AcceptChannel_get_temporary_channel_id(this_ptr: &AcceptChannel) -> *const [u8; 32] {
975 let mut inner_val = &mut this_ptr.get_native_mut_ref().temporary_channel_id;
978 /// A temporary channel ID, until the funding outpoint is announced
980 pub extern "C" fn AcceptChannel_set_temporary_channel_id(this_ptr: &mut AcceptChannel, mut val: crate::c_types::ThirtyTwoBytes) {
981 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.temporary_channel_id = val.data;
983 /// The threshold below which outputs on transactions broadcast by sender will be omitted
985 pub extern "C" fn AcceptChannel_get_dust_limit_satoshis(this_ptr: &AcceptChannel) -> u64 {
986 let mut inner_val = &mut this_ptr.get_native_mut_ref().dust_limit_satoshis;
989 /// The threshold below which outputs on transactions broadcast by sender will be omitted
991 pub extern "C" fn AcceptChannel_set_dust_limit_satoshis(this_ptr: &mut AcceptChannel, mut val: u64) {
992 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.dust_limit_satoshis = val;
994 /// The maximum inbound HTLC value in flight towards sender, in milli-satoshi
996 pub extern "C" fn AcceptChannel_get_max_htlc_value_in_flight_msat(this_ptr: &AcceptChannel) -> u64 {
997 let mut inner_val = &mut this_ptr.get_native_mut_ref().max_htlc_value_in_flight_msat;
1000 /// The maximum inbound HTLC value in flight towards sender, in milli-satoshi
1002 pub extern "C" fn AcceptChannel_set_max_htlc_value_in_flight_msat(this_ptr: &mut AcceptChannel, mut val: u64) {
1003 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.max_htlc_value_in_flight_msat = val;
1005 /// The minimum value unencumbered by HTLCs for the counterparty to keep in the channel
1007 pub extern "C" fn AcceptChannel_get_channel_reserve_satoshis(this_ptr: &AcceptChannel) -> u64 {
1008 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_reserve_satoshis;
1011 /// The minimum value unencumbered by HTLCs for the counterparty to keep in the channel
1013 pub extern "C" fn AcceptChannel_set_channel_reserve_satoshis(this_ptr: &mut AcceptChannel, mut val: u64) {
1014 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_reserve_satoshis = val;
1016 /// The minimum HTLC size incoming to sender, in milli-satoshi
1018 pub extern "C" fn AcceptChannel_get_htlc_minimum_msat(this_ptr: &AcceptChannel) -> u64 {
1019 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_minimum_msat;
1022 /// The minimum HTLC size incoming to sender, in milli-satoshi
1024 pub extern "C" fn AcceptChannel_set_htlc_minimum_msat(this_ptr: &mut AcceptChannel, mut val: u64) {
1025 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_minimum_msat = val;
1027 /// Minimum depth of the funding transaction before the channel is considered open
1029 pub extern "C" fn AcceptChannel_get_minimum_depth(this_ptr: &AcceptChannel) -> u32 {
1030 let mut inner_val = &mut this_ptr.get_native_mut_ref().minimum_depth;
1033 /// Minimum depth of the funding transaction before the channel is considered open
1035 pub extern "C" fn AcceptChannel_set_minimum_depth(this_ptr: &mut AcceptChannel, mut val: u32) {
1036 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.minimum_depth = val;
1038 /// The number of blocks which the counterparty will have to wait to claim on-chain funds if they broadcast a commitment transaction
1040 pub extern "C" fn AcceptChannel_get_to_self_delay(this_ptr: &AcceptChannel) -> u16 {
1041 let mut inner_val = &mut this_ptr.get_native_mut_ref().to_self_delay;
1044 /// The number of blocks which the counterparty will have to wait to claim on-chain funds if they broadcast a commitment transaction
1046 pub extern "C" fn AcceptChannel_set_to_self_delay(this_ptr: &mut AcceptChannel, mut val: u16) {
1047 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.to_self_delay = val;
1049 /// The maximum number of inbound HTLCs towards sender
1051 pub extern "C" fn AcceptChannel_get_max_accepted_htlcs(this_ptr: &AcceptChannel) -> u16 {
1052 let mut inner_val = &mut this_ptr.get_native_mut_ref().max_accepted_htlcs;
1055 /// The maximum number of inbound HTLCs towards sender
1057 pub extern "C" fn AcceptChannel_set_max_accepted_htlcs(this_ptr: &mut AcceptChannel, mut val: u16) {
1058 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.max_accepted_htlcs = val;
1060 /// The sender's key controlling the funding transaction
1062 pub extern "C" fn AcceptChannel_get_funding_pubkey(this_ptr: &AcceptChannel) -> crate::c_types::PublicKey {
1063 let mut inner_val = &mut this_ptr.get_native_mut_ref().funding_pubkey;
1064 crate::c_types::PublicKey::from_rust(&inner_val)
1066 /// The sender's key controlling the funding transaction
1068 pub extern "C" fn AcceptChannel_set_funding_pubkey(this_ptr: &mut AcceptChannel, mut val: crate::c_types::PublicKey) {
1069 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.funding_pubkey = val.into_rust();
1071 /// Used to derive a revocation key for transactions broadcast by counterparty
1073 pub extern "C" fn AcceptChannel_get_revocation_basepoint(this_ptr: &AcceptChannel) -> crate::c_types::PublicKey {
1074 let mut inner_val = &mut this_ptr.get_native_mut_ref().revocation_basepoint;
1075 crate::c_types::PublicKey::from_rust(&inner_val)
1077 /// Used to derive a revocation key for transactions broadcast by counterparty
1079 pub extern "C" fn AcceptChannel_set_revocation_basepoint(this_ptr: &mut AcceptChannel, mut val: crate::c_types::PublicKey) {
1080 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.revocation_basepoint = val.into_rust();
1082 /// A payment key to sender for transactions broadcast by counterparty
1084 pub extern "C" fn AcceptChannel_get_payment_point(this_ptr: &AcceptChannel) -> crate::c_types::PublicKey {
1085 let mut inner_val = &mut this_ptr.get_native_mut_ref().payment_point;
1086 crate::c_types::PublicKey::from_rust(&inner_val)
1088 /// A payment key to sender for transactions broadcast by counterparty
1090 pub extern "C" fn AcceptChannel_set_payment_point(this_ptr: &mut AcceptChannel, mut val: crate::c_types::PublicKey) {
1091 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.payment_point = val.into_rust();
1093 /// Used to derive a payment key to sender for transactions broadcast by sender
1095 pub extern "C" fn AcceptChannel_get_delayed_payment_basepoint(this_ptr: &AcceptChannel) -> crate::c_types::PublicKey {
1096 let mut inner_val = &mut this_ptr.get_native_mut_ref().delayed_payment_basepoint;
1097 crate::c_types::PublicKey::from_rust(&inner_val)
1099 /// Used to derive a payment key to sender for transactions broadcast by sender
1101 pub extern "C" fn AcceptChannel_set_delayed_payment_basepoint(this_ptr: &mut AcceptChannel, mut val: crate::c_types::PublicKey) {
1102 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.delayed_payment_basepoint = val.into_rust();
1104 /// Used to derive an HTLC payment key to sender for transactions broadcast by counterparty
1106 pub extern "C" fn AcceptChannel_get_htlc_basepoint(this_ptr: &AcceptChannel) -> crate::c_types::PublicKey {
1107 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_basepoint;
1108 crate::c_types::PublicKey::from_rust(&inner_val)
1110 /// Used to derive an HTLC payment key to sender for transactions broadcast by counterparty
1112 pub extern "C" fn AcceptChannel_set_htlc_basepoint(this_ptr: &mut AcceptChannel, mut val: crate::c_types::PublicKey) {
1113 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_basepoint = val.into_rust();
1115 /// The first to-be-broadcast-by-sender transaction's per commitment point
1117 pub extern "C" fn AcceptChannel_get_first_per_commitment_point(this_ptr: &AcceptChannel) -> crate::c_types::PublicKey {
1118 let mut inner_val = &mut this_ptr.get_native_mut_ref().first_per_commitment_point;
1119 crate::c_types::PublicKey::from_rust(&inner_val)
1121 /// The first to-be-broadcast-by-sender transaction's per commitment point
1123 pub extern "C" fn AcceptChannel_set_first_per_commitment_point(this_ptr: &mut AcceptChannel, mut val: crate::c_types::PublicKey) {
1124 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.first_per_commitment_point = val.into_rust();
1126 /// The channel type that this channel will represent. If none is set, we derive the channel
1127 /// type from the intersection of our feature bits with our counterparty's feature bits from
1128 /// the Init message.
1130 /// This is required to match the equivalent field in [`OpenChannel::channel_type`].
1132 /// Note that the return value (or a relevant inner pointer) may be NULL or all-0s to represent None
1134 pub extern "C" fn AcceptChannel_get_channel_type(this_ptr: &AcceptChannel) -> crate::lightning::ln::features::ChannelTypeFeatures {
1135 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_type;
1136 let mut local_inner_val = crate::lightning::ln::features::ChannelTypeFeatures { inner: unsafe { (if inner_val.is_none() { core::ptr::null() } else { ObjOps::nonnull_ptr_to_inner( { (inner_val.as_ref().unwrap()) }) } as *const lightning::ln::features::ChannelTypeFeatures<>) as *mut _ }, is_owned: false };
1139 /// The channel type that this channel will represent. If none is set, we derive the channel
1140 /// type from the intersection of our feature bits with our counterparty's feature bits from
1141 /// the Init message.
1143 /// This is required to match the equivalent field in [`OpenChannel::channel_type`].
1145 /// Note that val (or a relevant inner pointer) may be NULL or all-0s to represent None
1147 pub extern "C" fn AcceptChannel_set_channel_type(this_ptr: &mut AcceptChannel, mut val: crate::lightning::ln::features::ChannelTypeFeatures) {
1148 let mut local_val = if val.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(val.take_inner()) } }) };
1149 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_type = local_val;
1151 impl Clone for AcceptChannel {
1152 fn clone(&self) -> Self {
1154 inner: if <*mut nativeAcceptChannel>::is_null(self.inner) { core::ptr::null_mut() } else {
1155 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1161 /// Used only if an object of this type is returned as a trait impl by a method
1162 pub(crate) extern "C" fn AcceptChannel_clone_void(this_ptr: *const c_void) -> *mut c_void {
1163 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeAcceptChannel)).clone() })) as *mut c_void
1166 /// Creates a copy of the AcceptChannel
1167 pub extern "C" fn AcceptChannel_clone(orig: &AcceptChannel) -> AcceptChannel {
1171 use lightning::ln::msgs::FundingCreated as nativeFundingCreatedImport;
1172 pub(crate) type nativeFundingCreated = nativeFundingCreatedImport;
1174 /// A funding_created message to be sent or received from a peer
1177 pub struct FundingCreated {
1178 /// A pointer to the opaque Rust object.
1180 /// Nearly everywhere, inner must be non-null, however in places where
1181 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1182 pub inner: *mut nativeFundingCreated,
1183 /// Indicates that this is the only struct which contains the same pointer.
1185 /// Rust functions which take ownership of an object provided via an argument require
1186 /// this to be true and invalidate the object pointed to by inner.
1190 impl Drop for FundingCreated {
1191 fn drop(&mut self) {
1192 if self.is_owned && !<*mut nativeFundingCreated>::is_null(self.inner) {
1193 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
1197 /// Frees any resources used by the FundingCreated, if is_owned is set and inner is non-NULL.
1199 pub extern "C" fn FundingCreated_free(this_obj: FundingCreated) { }
1201 /// Used only if an object of this type is returned as a trait impl by a method
1202 pub(crate) extern "C" fn FundingCreated_free_void(this_ptr: *mut c_void) {
1203 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeFundingCreated); }
1206 impl FundingCreated {
1207 pub(crate) fn get_native_ref(&self) -> &'static nativeFundingCreated {
1208 unsafe { &*ObjOps::untweak_ptr(self.inner) }
1210 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeFundingCreated {
1211 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
1213 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
1214 pub(crate) fn take_inner(mut self) -> *mut nativeFundingCreated {
1215 assert!(self.is_owned);
1216 let ret = ObjOps::untweak_ptr(self.inner);
1217 self.inner = core::ptr::null_mut();
1221 /// A temporary channel ID, until the funding is established
1223 pub extern "C" fn FundingCreated_get_temporary_channel_id(this_ptr: &FundingCreated) -> *const [u8; 32] {
1224 let mut inner_val = &mut this_ptr.get_native_mut_ref().temporary_channel_id;
1227 /// A temporary channel ID, until the funding is established
1229 pub extern "C" fn FundingCreated_set_temporary_channel_id(this_ptr: &mut FundingCreated, mut val: crate::c_types::ThirtyTwoBytes) {
1230 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.temporary_channel_id = val.data;
1232 /// The funding transaction ID
1234 pub extern "C" fn FundingCreated_get_funding_txid(this_ptr: &FundingCreated) -> *const [u8; 32] {
1235 let mut inner_val = &mut this_ptr.get_native_mut_ref().funding_txid;
1236 inner_val.as_inner()
1238 /// The funding transaction ID
1240 pub extern "C" fn FundingCreated_set_funding_txid(this_ptr: &mut FundingCreated, mut val: crate::c_types::ThirtyTwoBytes) {
1241 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.funding_txid = ::bitcoin::hash_types::Txid::from_slice(&val.data[..]).unwrap();
1243 /// The specific output index funding this channel
1245 pub extern "C" fn FundingCreated_get_funding_output_index(this_ptr: &FundingCreated) -> u16 {
1246 let mut inner_val = &mut this_ptr.get_native_mut_ref().funding_output_index;
1249 /// The specific output index funding this channel
1251 pub extern "C" fn FundingCreated_set_funding_output_index(this_ptr: &mut FundingCreated, mut val: u16) {
1252 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.funding_output_index = val;
1254 /// The signature of the channel initiator (funder) on the initial commitment transaction
1256 pub extern "C" fn FundingCreated_get_signature(this_ptr: &FundingCreated) -> crate::c_types::Signature {
1257 let mut inner_val = &mut this_ptr.get_native_mut_ref().signature;
1258 crate::c_types::Signature::from_rust(&inner_val)
1260 /// The signature of the channel initiator (funder) on the initial commitment transaction
1262 pub extern "C" fn FundingCreated_set_signature(this_ptr: &mut FundingCreated, mut val: crate::c_types::Signature) {
1263 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.signature = val.into_rust();
1265 /// Constructs a new FundingCreated given each field
1268 pub extern "C" fn FundingCreated_new(mut temporary_channel_id_arg: crate::c_types::ThirtyTwoBytes, mut funding_txid_arg: crate::c_types::ThirtyTwoBytes, mut funding_output_index_arg: u16, mut signature_arg: crate::c_types::Signature) -> FundingCreated {
1269 FundingCreated { inner: ObjOps::heap_alloc(nativeFundingCreated {
1270 temporary_channel_id: temporary_channel_id_arg.data,
1271 funding_txid: ::bitcoin::hash_types::Txid::from_slice(&funding_txid_arg.data[..]).unwrap(),
1272 funding_output_index: funding_output_index_arg,
1273 signature: signature_arg.into_rust(),
1274 }), is_owned: true }
1276 impl Clone for FundingCreated {
1277 fn clone(&self) -> Self {
1279 inner: if <*mut nativeFundingCreated>::is_null(self.inner) { core::ptr::null_mut() } else {
1280 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1286 /// Used only if an object of this type is returned as a trait impl by a method
1287 pub(crate) extern "C" fn FundingCreated_clone_void(this_ptr: *const c_void) -> *mut c_void {
1288 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeFundingCreated)).clone() })) as *mut c_void
1291 /// Creates a copy of the FundingCreated
1292 pub extern "C" fn FundingCreated_clone(orig: &FundingCreated) -> FundingCreated {
1296 use lightning::ln::msgs::FundingSigned as nativeFundingSignedImport;
1297 pub(crate) type nativeFundingSigned = nativeFundingSignedImport;
1299 /// A funding_signed message to be sent or received from a peer
1302 pub struct FundingSigned {
1303 /// A pointer to the opaque Rust object.
1305 /// Nearly everywhere, inner must be non-null, however in places where
1306 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1307 pub inner: *mut nativeFundingSigned,
1308 /// Indicates that this is the only struct which contains the same pointer.
1310 /// Rust functions which take ownership of an object provided via an argument require
1311 /// this to be true and invalidate the object pointed to by inner.
1315 impl Drop for FundingSigned {
1316 fn drop(&mut self) {
1317 if self.is_owned && !<*mut nativeFundingSigned>::is_null(self.inner) {
1318 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
1322 /// Frees any resources used by the FundingSigned, if is_owned is set and inner is non-NULL.
1324 pub extern "C" fn FundingSigned_free(this_obj: FundingSigned) { }
1326 /// Used only if an object of this type is returned as a trait impl by a method
1327 pub(crate) extern "C" fn FundingSigned_free_void(this_ptr: *mut c_void) {
1328 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeFundingSigned); }
1331 impl FundingSigned {
1332 pub(crate) fn get_native_ref(&self) -> &'static nativeFundingSigned {
1333 unsafe { &*ObjOps::untweak_ptr(self.inner) }
1335 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeFundingSigned {
1336 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
1338 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
1339 pub(crate) fn take_inner(mut self) -> *mut nativeFundingSigned {
1340 assert!(self.is_owned);
1341 let ret = ObjOps::untweak_ptr(self.inner);
1342 self.inner = core::ptr::null_mut();
1348 pub extern "C" fn FundingSigned_get_channel_id(this_ptr: &FundingSigned) -> *const [u8; 32] {
1349 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
1354 pub extern "C" fn FundingSigned_set_channel_id(this_ptr: &mut FundingSigned, mut val: crate::c_types::ThirtyTwoBytes) {
1355 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
1357 /// The signature of the channel acceptor (fundee) on the initial commitment transaction
1359 pub extern "C" fn FundingSigned_get_signature(this_ptr: &FundingSigned) -> crate::c_types::Signature {
1360 let mut inner_val = &mut this_ptr.get_native_mut_ref().signature;
1361 crate::c_types::Signature::from_rust(&inner_val)
1363 /// The signature of the channel acceptor (fundee) on the initial commitment transaction
1365 pub extern "C" fn FundingSigned_set_signature(this_ptr: &mut FundingSigned, mut val: crate::c_types::Signature) {
1366 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.signature = val.into_rust();
1368 /// Constructs a new FundingSigned given each field
1371 pub extern "C" fn FundingSigned_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut signature_arg: crate::c_types::Signature) -> FundingSigned {
1372 FundingSigned { inner: ObjOps::heap_alloc(nativeFundingSigned {
1373 channel_id: channel_id_arg.data,
1374 signature: signature_arg.into_rust(),
1375 }), is_owned: true }
1377 impl Clone for FundingSigned {
1378 fn clone(&self) -> Self {
1380 inner: if <*mut nativeFundingSigned>::is_null(self.inner) { core::ptr::null_mut() } else {
1381 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1387 /// Used only if an object of this type is returned as a trait impl by a method
1388 pub(crate) extern "C" fn FundingSigned_clone_void(this_ptr: *const c_void) -> *mut c_void {
1389 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeFundingSigned)).clone() })) as *mut c_void
1392 /// Creates a copy of the FundingSigned
1393 pub extern "C" fn FundingSigned_clone(orig: &FundingSigned) -> FundingSigned {
1397 use lightning::ln::msgs::ChannelReady as nativeChannelReadyImport;
1398 pub(crate) type nativeChannelReady = nativeChannelReadyImport;
1400 /// A channel_ready message to be sent or received from a peer
1403 pub struct ChannelReady {
1404 /// A pointer to the opaque Rust object.
1406 /// Nearly everywhere, inner must be non-null, however in places where
1407 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1408 pub inner: *mut nativeChannelReady,
1409 /// Indicates that this is the only struct which contains the same pointer.
1411 /// Rust functions which take ownership of an object provided via an argument require
1412 /// this to be true and invalidate the object pointed to by inner.
1416 impl Drop for ChannelReady {
1417 fn drop(&mut self) {
1418 if self.is_owned && !<*mut nativeChannelReady>::is_null(self.inner) {
1419 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
1423 /// Frees any resources used by the ChannelReady, if is_owned is set and inner is non-NULL.
1425 pub extern "C" fn ChannelReady_free(this_obj: ChannelReady) { }
1427 /// Used only if an object of this type is returned as a trait impl by a method
1428 pub(crate) extern "C" fn ChannelReady_free_void(this_ptr: *mut c_void) {
1429 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeChannelReady); }
1433 pub(crate) fn get_native_ref(&self) -> &'static nativeChannelReady {
1434 unsafe { &*ObjOps::untweak_ptr(self.inner) }
1436 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeChannelReady {
1437 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
1439 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
1440 pub(crate) fn take_inner(mut self) -> *mut nativeChannelReady {
1441 assert!(self.is_owned);
1442 let ret = ObjOps::untweak_ptr(self.inner);
1443 self.inner = core::ptr::null_mut();
1449 pub extern "C" fn ChannelReady_get_channel_id(this_ptr: &ChannelReady) -> *const [u8; 32] {
1450 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
1455 pub extern "C" fn ChannelReady_set_channel_id(this_ptr: &mut ChannelReady, mut val: crate::c_types::ThirtyTwoBytes) {
1456 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
1458 /// The per-commitment point of the second commitment transaction
1460 pub extern "C" fn ChannelReady_get_next_per_commitment_point(this_ptr: &ChannelReady) -> crate::c_types::PublicKey {
1461 let mut inner_val = &mut this_ptr.get_native_mut_ref().next_per_commitment_point;
1462 crate::c_types::PublicKey::from_rust(&inner_val)
1464 /// The per-commitment point of the second commitment transaction
1466 pub extern "C" fn ChannelReady_set_next_per_commitment_point(this_ptr: &mut ChannelReady, mut val: crate::c_types::PublicKey) {
1467 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.next_per_commitment_point = val.into_rust();
1469 /// If set, provides a short_channel_id alias for this channel. The sender will accept payments
1470 /// to be forwarded over this SCID and forward them to this messages' recipient.
1472 pub extern "C" fn ChannelReady_get_short_channel_id_alias(this_ptr: &ChannelReady) -> crate::c_types::derived::COption_u64Z {
1473 let mut inner_val = &mut this_ptr.get_native_mut_ref().short_channel_id_alias;
1474 let mut local_inner_val = if inner_val.is_none() { crate::c_types::derived::COption_u64Z::None } else { crate::c_types::derived::COption_u64Z::Some( { inner_val.unwrap() }) };
1477 /// If set, provides a short_channel_id alias for this channel. The sender will accept payments
1478 /// to be forwarded over this SCID and forward them to this messages' recipient.
1480 pub extern "C" fn ChannelReady_set_short_channel_id_alias(this_ptr: &mut ChannelReady, mut val: crate::c_types::derived::COption_u64Z) {
1481 let mut local_val = if val.is_some() { Some( { val.take() }) } else { None };
1482 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.short_channel_id_alias = local_val;
1484 /// Constructs a new ChannelReady given each field
1487 pub extern "C" fn ChannelReady_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut next_per_commitment_point_arg: crate::c_types::PublicKey, mut short_channel_id_alias_arg: crate::c_types::derived::COption_u64Z) -> ChannelReady {
1488 let mut local_short_channel_id_alias_arg = if short_channel_id_alias_arg.is_some() { Some( { short_channel_id_alias_arg.take() }) } else { None };
1489 ChannelReady { inner: ObjOps::heap_alloc(nativeChannelReady {
1490 channel_id: channel_id_arg.data,
1491 next_per_commitment_point: next_per_commitment_point_arg.into_rust(),
1492 short_channel_id_alias: local_short_channel_id_alias_arg,
1493 }), is_owned: true }
1495 impl Clone for ChannelReady {
1496 fn clone(&self) -> Self {
1498 inner: if <*mut nativeChannelReady>::is_null(self.inner) { core::ptr::null_mut() } else {
1499 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1505 /// Used only if an object of this type is returned as a trait impl by a method
1506 pub(crate) extern "C" fn ChannelReady_clone_void(this_ptr: *const c_void) -> *mut c_void {
1507 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeChannelReady)).clone() })) as *mut c_void
1510 /// Creates a copy of the ChannelReady
1511 pub extern "C" fn ChannelReady_clone(orig: &ChannelReady) -> ChannelReady {
1515 use lightning::ln::msgs::Shutdown as nativeShutdownImport;
1516 pub(crate) type nativeShutdown = nativeShutdownImport;
1518 /// A shutdown message to be sent or received from a peer
1521 pub struct Shutdown {
1522 /// A pointer to the opaque Rust object.
1524 /// Nearly everywhere, inner must be non-null, however in places where
1525 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1526 pub inner: *mut nativeShutdown,
1527 /// Indicates that this is the only struct which contains the same pointer.
1529 /// Rust functions which take ownership of an object provided via an argument require
1530 /// this to be true and invalidate the object pointed to by inner.
1534 impl Drop for Shutdown {
1535 fn drop(&mut self) {
1536 if self.is_owned && !<*mut nativeShutdown>::is_null(self.inner) {
1537 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
1541 /// Frees any resources used by the Shutdown, if is_owned is set and inner is non-NULL.
1543 pub extern "C" fn Shutdown_free(this_obj: Shutdown) { }
1545 /// Used only if an object of this type is returned as a trait impl by a method
1546 pub(crate) extern "C" fn Shutdown_free_void(this_ptr: *mut c_void) {
1547 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeShutdown); }
1551 pub(crate) fn get_native_ref(&self) -> &'static nativeShutdown {
1552 unsafe { &*ObjOps::untweak_ptr(self.inner) }
1554 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeShutdown {
1555 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
1557 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
1558 pub(crate) fn take_inner(mut self) -> *mut nativeShutdown {
1559 assert!(self.is_owned);
1560 let ret = ObjOps::untweak_ptr(self.inner);
1561 self.inner = core::ptr::null_mut();
1567 pub extern "C" fn Shutdown_get_channel_id(this_ptr: &Shutdown) -> *const [u8; 32] {
1568 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
1573 pub extern "C" fn Shutdown_set_channel_id(this_ptr: &mut Shutdown, mut val: crate::c_types::ThirtyTwoBytes) {
1574 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
1576 /// The destination of this peer's funds on closing.
1577 /// Must be in one of these forms: p2pkh, p2sh, p2wpkh, p2wsh.
1579 pub extern "C" fn Shutdown_get_scriptpubkey(this_ptr: &Shutdown) -> crate::c_types::u8slice {
1580 let mut inner_val = &mut this_ptr.get_native_mut_ref().scriptpubkey;
1581 crate::c_types::u8slice::from_slice(&inner_val[..])
1583 /// The destination of this peer's funds on closing.
1584 /// Must be in one of these forms: p2pkh, p2sh, p2wpkh, p2wsh.
1586 pub extern "C" fn Shutdown_set_scriptpubkey(this_ptr: &mut Shutdown, mut val: crate::c_types::derived::CVec_u8Z) {
1587 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.scriptpubkey = ::bitcoin::blockdata::script::Script::from(val.into_rust());
1589 /// Constructs a new Shutdown given each field
1592 pub extern "C" fn Shutdown_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut scriptpubkey_arg: crate::c_types::derived::CVec_u8Z) -> Shutdown {
1593 Shutdown { inner: ObjOps::heap_alloc(nativeShutdown {
1594 channel_id: channel_id_arg.data,
1595 scriptpubkey: ::bitcoin::blockdata::script::Script::from(scriptpubkey_arg.into_rust()),
1596 }), is_owned: true }
1598 impl Clone for Shutdown {
1599 fn clone(&self) -> Self {
1601 inner: if <*mut nativeShutdown>::is_null(self.inner) { core::ptr::null_mut() } else {
1602 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1608 /// Used only if an object of this type is returned as a trait impl by a method
1609 pub(crate) extern "C" fn Shutdown_clone_void(this_ptr: *const c_void) -> *mut c_void {
1610 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeShutdown)).clone() })) as *mut c_void
1613 /// Creates a copy of the Shutdown
1614 pub extern "C" fn Shutdown_clone(orig: &Shutdown) -> Shutdown {
1618 use lightning::ln::msgs::ClosingSignedFeeRange as nativeClosingSignedFeeRangeImport;
1619 pub(crate) type nativeClosingSignedFeeRange = nativeClosingSignedFeeRangeImport;
1621 /// The minimum and maximum fees which the sender is willing to place on the closing transaction.
1622 /// This is provided in [`ClosingSigned`] by both sides to indicate the fee range they are willing
1626 pub struct ClosingSignedFeeRange {
1627 /// A pointer to the opaque Rust object.
1629 /// Nearly everywhere, inner must be non-null, however in places where
1630 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1631 pub inner: *mut nativeClosingSignedFeeRange,
1632 /// Indicates that this is the only struct which contains the same pointer.
1634 /// Rust functions which take ownership of an object provided via an argument require
1635 /// this to be true and invalidate the object pointed to by inner.
1639 impl Drop for ClosingSignedFeeRange {
1640 fn drop(&mut self) {
1641 if self.is_owned && !<*mut nativeClosingSignedFeeRange>::is_null(self.inner) {
1642 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
1646 /// Frees any resources used by the ClosingSignedFeeRange, if is_owned is set and inner is non-NULL.
1648 pub extern "C" fn ClosingSignedFeeRange_free(this_obj: ClosingSignedFeeRange) { }
1650 /// Used only if an object of this type is returned as a trait impl by a method
1651 pub(crate) extern "C" fn ClosingSignedFeeRange_free_void(this_ptr: *mut c_void) {
1652 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeClosingSignedFeeRange); }
1655 impl ClosingSignedFeeRange {
1656 pub(crate) fn get_native_ref(&self) -> &'static nativeClosingSignedFeeRange {
1657 unsafe { &*ObjOps::untweak_ptr(self.inner) }
1659 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeClosingSignedFeeRange {
1660 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
1662 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
1663 pub(crate) fn take_inner(mut self) -> *mut nativeClosingSignedFeeRange {
1664 assert!(self.is_owned);
1665 let ret = ObjOps::untweak_ptr(self.inner);
1666 self.inner = core::ptr::null_mut();
1670 /// The minimum absolute fee, in satoshis, which the sender is willing to place on the closing
1673 pub extern "C" fn ClosingSignedFeeRange_get_min_fee_satoshis(this_ptr: &ClosingSignedFeeRange) -> u64 {
1674 let mut inner_val = &mut this_ptr.get_native_mut_ref().min_fee_satoshis;
1677 /// The minimum absolute fee, in satoshis, which the sender is willing to place on the closing
1680 pub extern "C" fn ClosingSignedFeeRange_set_min_fee_satoshis(this_ptr: &mut ClosingSignedFeeRange, mut val: u64) {
1681 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.min_fee_satoshis = val;
1683 /// The maximum absolute fee, in satoshis, which the sender is willing to place on the closing
1686 pub extern "C" fn ClosingSignedFeeRange_get_max_fee_satoshis(this_ptr: &ClosingSignedFeeRange) -> u64 {
1687 let mut inner_val = &mut this_ptr.get_native_mut_ref().max_fee_satoshis;
1690 /// The maximum absolute fee, in satoshis, which the sender is willing to place on the closing
1693 pub extern "C" fn ClosingSignedFeeRange_set_max_fee_satoshis(this_ptr: &mut ClosingSignedFeeRange, mut val: u64) {
1694 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.max_fee_satoshis = val;
1696 /// Constructs a new ClosingSignedFeeRange given each field
1699 pub extern "C" fn ClosingSignedFeeRange_new(mut min_fee_satoshis_arg: u64, mut max_fee_satoshis_arg: u64) -> ClosingSignedFeeRange {
1700 ClosingSignedFeeRange { inner: ObjOps::heap_alloc(nativeClosingSignedFeeRange {
1701 min_fee_satoshis: min_fee_satoshis_arg,
1702 max_fee_satoshis: max_fee_satoshis_arg,
1703 }), is_owned: true }
1705 impl Clone for ClosingSignedFeeRange {
1706 fn clone(&self) -> Self {
1708 inner: if <*mut nativeClosingSignedFeeRange>::is_null(self.inner) { core::ptr::null_mut() } else {
1709 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1715 /// Used only if an object of this type is returned as a trait impl by a method
1716 pub(crate) extern "C" fn ClosingSignedFeeRange_clone_void(this_ptr: *const c_void) -> *mut c_void {
1717 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeClosingSignedFeeRange)).clone() })) as *mut c_void
1720 /// Creates a copy of the ClosingSignedFeeRange
1721 pub extern "C" fn ClosingSignedFeeRange_clone(orig: &ClosingSignedFeeRange) -> ClosingSignedFeeRange {
1725 use lightning::ln::msgs::ClosingSigned as nativeClosingSignedImport;
1726 pub(crate) type nativeClosingSigned = nativeClosingSignedImport;
1728 /// A closing_signed message to be sent or received from a peer
1731 pub struct ClosingSigned {
1732 /// A pointer to the opaque Rust object.
1734 /// Nearly everywhere, inner must be non-null, however in places where
1735 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1736 pub inner: *mut nativeClosingSigned,
1737 /// Indicates that this is the only struct which contains the same pointer.
1739 /// Rust functions which take ownership of an object provided via an argument require
1740 /// this to be true and invalidate the object pointed to by inner.
1744 impl Drop for ClosingSigned {
1745 fn drop(&mut self) {
1746 if self.is_owned && !<*mut nativeClosingSigned>::is_null(self.inner) {
1747 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
1751 /// Frees any resources used by the ClosingSigned, if is_owned is set and inner is non-NULL.
1753 pub extern "C" fn ClosingSigned_free(this_obj: ClosingSigned) { }
1755 /// Used only if an object of this type is returned as a trait impl by a method
1756 pub(crate) extern "C" fn ClosingSigned_free_void(this_ptr: *mut c_void) {
1757 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeClosingSigned); }
1760 impl ClosingSigned {
1761 pub(crate) fn get_native_ref(&self) -> &'static nativeClosingSigned {
1762 unsafe { &*ObjOps::untweak_ptr(self.inner) }
1764 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeClosingSigned {
1765 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
1767 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
1768 pub(crate) fn take_inner(mut self) -> *mut nativeClosingSigned {
1769 assert!(self.is_owned);
1770 let ret = ObjOps::untweak_ptr(self.inner);
1771 self.inner = core::ptr::null_mut();
1777 pub extern "C" fn ClosingSigned_get_channel_id(this_ptr: &ClosingSigned) -> *const [u8; 32] {
1778 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
1783 pub extern "C" fn ClosingSigned_set_channel_id(this_ptr: &mut ClosingSigned, mut val: crate::c_types::ThirtyTwoBytes) {
1784 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
1786 /// The proposed total fee for the closing transaction
1788 pub extern "C" fn ClosingSigned_get_fee_satoshis(this_ptr: &ClosingSigned) -> u64 {
1789 let mut inner_val = &mut this_ptr.get_native_mut_ref().fee_satoshis;
1792 /// The proposed total fee for the closing transaction
1794 pub extern "C" fn ClosingSigned_set_fee_satoshis(this_ptr: &mut ClosingSigned, mut val: u64) {
1795 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.fee_satoshis = val;
1797 /// A signature on the closing transaction
1799 pub extern "C" fn ClosingSigned_get_signature(this_ptr: &ClosingSigned) -> crate::c_types::Signature {
1800 let mut inner_val = &mut this_ptr.get_native_mut_ref().signature;
1801 crate::c_types::Signature::from_rust(&inner_val)
1803 /// A signature on the closing transaction
1805 pub extern "C" fn ClosingSigned_set_signature(this_ptr: &mut ClosingSigned, mut val: crate::c_types::Signature) {
1806 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.signature = val.into_rust();
1808 /// The minimum and maximum fees which the sender is willing to accept, provided only by new
1811 /// Note that the return value (or a relevant inner pointer) may be NULL or all-0s to represent None
1813 pub extern "C" fn ClosingSigned_get_fee_range(this_ptr: &ClosingSigned) -> crate::lightning::ln::msgs::ClosingSignedFeeRange {
1814 let mut inner_val = &mut this_ptr.get_native_mut_ref().fee_range;
1815 let mut local_inner_val = crate::lightning::ln::msgs::ClosingSignedFeeRange { inner: unsafe { (if inner_val.is_none() { core::ptr::null() } else { ObjOps::nonnull_ptr_to_inner( { (inner_val.as_ref().unwrap()) }) } as *const lightning::ln::msgs::ClosingSignedFeeRange<>) as *mut _ }, is_owned: false };
1818 /// The minimum and maximum fees which the sender is willing to accept, provided only by new
1821 /// Note that val (or a relevant inner pointer) may be NULL or all-0s to represent None
1823 pub extern "C" fn ClosingSigned_set_fee_range(this_ptr: &mut ClosingSigned, mut val: crate::lightning::ln::msgs::ClosingSignedFeeRange) {
1824 let mut local_val = if val.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(val.take_inner()) } }) };
1825 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.fee_range = local_val;
1827 /// Constructs a new ClosingSigned given each field
1830 pub extern "C" fn ClosingSigned_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut fee_satoshis_arg: u64, mut signature_arg: crate::c_types::Signature, mut fee_range_arg: crate::lightning::ln::msgs::ClosingSignedFeeRange) -> ClosingSigned {
1831 let mut local_fee_range_arg = if fee_range_arg.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(fee_range_arg.take_inner()) } }) };
1832 ClosingSigned { inner: ObjOps::heap_alloc(nativeClosingSigned {
1833 channel_id: channel_id_arg.data,
1834 fee_satoshis: fee_satoshis_arg,
1835 signature: signature_arg.into_rust(),
1836 fee_range: local_fee_range_arg,
1837 }), is_owned: true }
1839 impl Clone for ClosingSigned {
1840 fn clone(&self) -> Self {
1842 inner: if <*mut nativeClosingSigned>::is_null(self.inner) { core::ptr::null_mut() } else {
1843 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1849 /// Used only if an object of this type is returned as a trait impl by a method
1850 pub(crate) extern "C" fn ClosingSigned_clone_void(this_ptr: *const c_void) -> *mut c_void {
1851 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeClosingSigned)).clone() })) as *mut c_void
1854 /// Creates a copy of the ClosingSigned
1855 pub extern "C" fn ClosingSigned_clone(orig: &ClosingSigned) -> ClosingSigned {
1859 use lightning::ln::msgs::UpdateAddHTLC as nativeUpdateAddHTLCImport;
1860 pub(crate) type nativeUpdateAddHTLC = nativeUpdateAddHTLCImport;
1862 /// An update_add_htlc message to be sent or received from a peer
1865 pub struct UpdateAddHTLC {
1866 /// A pointer to the opaque Rust object.
1868 /// Nearly everywhere, inner must be non-null, however in places where
1869 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1870 pub inner: *mut nativeUpdateAddHTLC,
1871 /// Indicates that this is the only struct which contains the same pointer.
1873 /// Rust functions which take ownership of an object provided via an argument require
1874 /// this to be true and invalidate the object pointed to by inner.
1878 impl Drop for UpdateAddHTLC {
1879 fn drop(&mut self) {
1880 if self.is_owned && !<*mut nativeUpdateAddHTLC>::is_null(self.inner) {
1881 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
1885 /// Frees any resources used by the UpdateAddHTLC, if is_owned is set and inner is non-NULL.
1887 pub extern "C" fn UpdateAddHTLC_free(this_obj: UpdateAddHTLC) { }
1889 /// Used only if an object of this type is returned as a trait impl by a method
1890 pub(crate) extern "C" fn UpdateAddHTLC_free_void(this_ptr: *mut c_void) {
1891 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUpdateAddHTLC); }
1894 impl UpdateAddHTLC {
1895 pub(crate) fn get_native_ref(&self) -> &'static nativeUpdateAddHTLC {
1896 unsafe { &*ObjOps::untweak_ptr(self.inner) }
1898 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUpdateAddHTLC {
1899 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
1901 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
1902 pub(crate) fn take_inner(mut self) -> *mut nativeUpdateAddHTLC {
1903 assert!(self.is_owned);
1904 let ret = ObjOps::untweak_ptr(self.inner);
1905 self.inner = core::ptr::null_mut();
1911 pub extern "C" fn UpdateAddHTLC_get_channel_id(this_ptr: &UpdateAddHTLC) -> *const [u8; 32] {
1912 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
1917 pub extern "C" fn UpdateAddHTLC_set_channel_id(this_ptr: &mut UpdateAddHTLC, mut val: crate::c_types::ThirtyTwoBytes) {
1918 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
1922 pub extern "C" fn UpdateAddHTLC_get_htlc_id(this_ptr: &UpdateAddHTLC) -> u64 {
1923 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_id;
1928 pub extern "C" fn UpdateAddHTLC_set_htlc_id(this_ptr: &mut UpdateAddHTLC, mut val: u64) {
1929 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_id = val;
1931 /// The HTLC value in milli-satoshi
1933 pub extern "C" fn UpdateAddHTLC_get_amount_msat(this_ptr: &UpdateAddHTLC) -> u64 {
1934 let mut inner_val = &mut this_ptr.get_native_mut_ref().amount_msat;
1937 /// The HTLC value in milli-satoshi
1939 pub extern "C" fn UpdateAddHTLC_set_amount_msat(this_ptr: &mut UpdateAddHTLC, mut val: u64) {
1940 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.amount_msat = val;
1942 /// The payment hash, the pre-image of which controls HTLC redemption
1944 pub extern "C" fn UpdateAddHTLC_get_payment_hash(this_ptr: &UpdateAddHTLC) -> *const [u8; 32] {
1945 let mut inner_val = &mut this_ptr.get_native_mut_ref().payment_hash;
1948 /// The payment hash, the pre-image of which controls HTLC redemption
1950 pub extern "C" fn UpdateAddHTLC_set_payment_hash(this_ptr: &mut UpdateAddHTLC, mut val: crate::c_types::ThirtyTwoBytes) {
1951 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.payment_hash = ::lightning::ln::PaymentHash(val.data);
1953 /// The expiry height of the HTLC
1955 pub extern "C" fn UpdateAddHTLC_get_cltv_expiry(this_ptr: &UpdateAddHTLC) -> u32 {
1956 let mut inner_val = &mut this_ptr.get_native_mut_ref().cltv_expiry;
1959 /// The expiry height of the HTLC
1961 pub extern "C" fn UpdateAddHTLC_set_cltv_expiry(this_ptr: &mut UpdateAddHTLC, mut val: u32) {
1962 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.cltv_expiry = val;
1964 impl Clone for UpdateAddHTLC {
1965 fn clone(&self) -> Self {
1967 inner: if <*mut nativeUpdateAddHTLC>::is_null(self.inner) { core::ptr::null_mut() } else {
1968 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
1974 /// Used only if an object of this type is returned as a trait impl by a method
1975 pub(crate) extern "C" fn UpdateAddHTLC_clone_void(this_ptr: *const c_void) -> *mut c_void {
1976 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUpdateAddHTLC)).clone() })) as *mut c_void
1979 /// Creates a copy of the UpdateAddHTLC
1980 pub extern "C" fn UpdateAddHTLC_clone(orig: &UpdateAddHTLC) -> UpdateAddHTLC {
1984 use lightning::ln::msgs::UpdateFulfillHTLC as nativeUpdateFulfillHTLCImport;
1985 pub(crate) type nativeUpdateFulfillHTLC = nativeUpdateFulfillHTLCImport;
1987 /// An update_fulfill_htlc message to be sent or received from a peer
1990 pub struct UpdateFulfillHTLC {
1991 /// A pointer to the opaque Rust object.
1993 /// Nearly everywhere, inner must be non-null, however in places where
1994 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
1995 pub inner: *mut nativeUpdateFulfillHTLC,
1996 /// Indicates that this is the only struct which contains the same pointer.
1998 /// Rust functions which take ownership of an object provided via an argument require
1999 /// this to be true and invalidate the object pointed to by inner.
2003 impl Drop for UpdateFulfillHTLC {
2004 fn drop(&mut self) {
2005 if self.is_owned && !<*mut nativeUpdateFulfillHTLC>::is_null(self.inner) {
2006 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2010 /// Frees any resources used by the UpdateFulfillHTLC, if is_owned is set and inner is non-NULL.
2012 pub extern "C" fn UpdateFulfillHTLC_free(this_obj: UpdateFulfillHTLC) { }
2014 /// Used only if an object of this type is returned as a trait impl by a method
2015 pub(crate) extern "C" fn UpdateFulfillHTLC_free_void(this_ptr: *mut c_void) {
2016 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUpdateFulfillHTLC); }
2019 impl UpdateFulfillHTLC {
2020 pub(crate) fn get_native_ref(&self) -> &'static nativeUpdateFulfillHTLC {
2021 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2023 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUpdateFulfillHTLC {
2024 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2026 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2027 pub(crate) fn take_inner(mut self) -> *mut nativeUpdateFulfillHTLC {
2028 assert!(self.is_owned);
2029 let ret = ObjOps::untweak_ptr(self.inner);
2030 self.inner = core::ptr::null_mut();
2036 pub extern "C" fn UpdateFulfillHTLC_get_channel_id(this_ptr: &UpdateFulfillHTLC) -> *const [u8; 32] {
2037 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2042 pub extern "C" fn UpdateFulfillHTLC_set_channel_id(this_ptr: &mut UpdateFulfillHTLC, mut val: crate::c_types::ThirtyTwoBytes) {
2043 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2047 pub extern "C" fn UpdateFulfillHTLC_get_htlc_id(this_ptr: &UpdateFulfillHTLC) -> u64 {
2048 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_id;
2053 pub extern "C" fn UpdateFulfillHTLC_set_htlc_id(this_ptr: &mut UpdateFulfillHTLC, mut val: u64) {
2054 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_id = val;
2056 /// The pre-image of the payment hash, allowing HTLC redemption
2058 pub extern "C" fn UpdateFulfillHTLC_get_payment_preimage(this_ptr: &UpdateFulfillHTLC) -> *const [u8; 32] {
2059 let mut inner_val = &mut this_ptr.get_native_mut_ref().payment_preimage;
2062 /// The pre-image of the payment hash, allowing HTLC redemption
2064 pub extern "C" fn UpdateFulfillHTLC_set_payment_preimage(this_ptr: &mut UpdateFulfillHTLC, mut val: crate::c_types::ThirtyTwoBytes) {
2065 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.payment_preimage = ::lightning::ln::PaymentPreimage(val.data);
2067 /// Constructs a new UpdateFulfillHTLC given each field
2070 pub extern "C" fn UpdateFulfillHTLC_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut htlc_id_arg: u64, mut payment_preimage_arg: crate::c_types::ThirtyTwoBytes) -> UpdateFulfillHTLC {
2071 UpdateFulfillHTLC { inner: ObjOps::heap_alloc(nativeUpdateFulfillHTLC {
2072 channel_id: channel_id_arg.data,
2073 htlc_id: htlc_id_arg,
2074 payment_preimage: ::lightning::ln::PaymentPreimage(payment_preimage_arg.data),
2075 }), is_owned: true }
2077 impl Clone for UpdateFulfillHTLC {
2078 fn clone(&self) -> Self {
2080 inner: if <*mut nativeUpdateFulfillHTLC>::is_null(self.inner) { core::ptr::null_mut() } else {
2081 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2087 /// Used only if an object of this type is returned as a trait impl by a method
2088 pub(crate) extern "C" fn UpdateFulfillHTLC_clone_void(this_ptr: *const c_void) -> *mut c_void {
2089 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUpdateFulfillHTLC)).clone() })) as *mut c_void
2092 /// Creates a copy of the UpdateFulfillHTLC
2093 pub extern "C" fn UpdateFulfillHTLC_clone(orig: &UpdateFulfillHTLC) -> UpdateFulfillHTLC {
2097 use lightning::ln::msgs::UpdateFailHTLC as nativeUpdateFailHTLCImport;
2098 pub(crate) type nativeUpdateFailHTLC = nativeUpdateFailHTLCImport;
2100 /// An update_fail_htlc message to be sent or received from a peer
2103 pub struct UpdateFailHTLC {
2104 /// A pointer to the opaque Rust object.
2106 /// Nearly everywhere, inner must be non-null, however in places where
2107 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2108 pub inner: *mut nativeUpdateFailHTLC,
2109 /// Indicates that this is the only struct which contains the same pointer.
2111 /// Rust functions which take ownership of an object provided via an argument require
2112 /// this to be true and invalidate the object pointed to by inner.
2116 impl Drop for UpdateFailHTLC {
2117 fn drop(&mut self) {
2118 if self.is_owned && !<*mut nativeUpdateFailHTLC>::is_null(self.inner) {
2119 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2123 /// Frees any resources used by the UpdateFailHTLC, if is_owned is set and inner is non-NULL.
2125 pub extern "C" fn UpdateFailHTLC_free(this_obj: UpdateFailHTLC) { }
2127 /// Used only if an object of this type is returned as a trait impl by a method
2128 pub(crate) extern "C" fn UpdateFailHTLC_free_void(this_ptr: *mut c_void) {
2129 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUpdateFailHTLC); }
2132 impl UpdateFailHTLC {
2133 pub(crate) fn get_native_ref(&self) -> &'static nativeUpdateFailHTLC {
2134 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2136 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUpdateFailHTLC {
2137 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2139 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2140 pub(crate) fn take_inner(mut self) -> *mut nativeUpdateFailHTLC {
2141 assert!(self.is_owned);
2142 let ret = ObjOps::untweak_ptr(self.inner);
2143 self.inner = core::ptr::null_mut();
2149 pub extern "C" fn UpdateFailHTLC_get_channel_id(this_ptr: &UpdateFailHTLC) -> *const [u8; 32] {
2150 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2155 pub extern "C" fn UpdateFailHTLC_set_channel_id(this_ptr: &mut UpdateFailHTLC, mut val: crate::c_types::ThirtyTwoBytes) {
2156 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2160 pub extern "C" fn UpdateFailHTLC_get_htlc_id(this_ptr: &UpdateFailHTLC) -> u64 {
2161 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_id;
2166 pub extern "C" fn UpdateFailHTLC_set_htlc_id(this_ptr: &mut UpdateFailHTLC, mut val: u64) {
2167 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_id = val;
2169 impl Clone for UpdateFailHTLC {
2170 fn clone(&self) -> Self {
2172 inner: if <*mut nativeUpdateFailHTLC>::is_null(self.inner) { core::ptr::null_mut() } else {
2173 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2179 /// Used only if an object of this type is returned as a trait impl by a method
2180 pub(crate) extern "C" fn UpdateFailHTLC_clone_void(this_ptr: *const c_void) -> *mut c_void {
2181 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUpdateFailHTLC)).clone() })) as *mut c_void
2184 /// Creates a copy of the UpdateFailHTLC
2185 pub extern "C" fn UpdateFailHTLC_clone(orig: &UpdateFailHTLC) -> UpdateFailHTLC {
2189 use lightning::ln::msgs::UpdateFailMalformedHTLC as nativeUpdateFailMalformedHTLCImport;
2190 pub(crate) type nativeUpdateFailMalformedHTLC = nativeUpdateFailMalformedHTLCImport;
2192 /// An update_fail_malformed_htlc message to be sent or received from a peer
2195 pub struct UpdateFailMalformedHTLC {
2196 /// A pointer to the opaque Rust object.
2198 /// Nearly everywhere, inner must be non-null, however in places where
2199 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2200 pub inner: *mut nativeUpdateFailMalformedHTLC,
2201 /// Indicates that this is the only struct which contains the same pointer.
2203 /// Rust functions which take ownership of an object provided via an argument require
2204 /// this to be true and invalidate the object pointed to by inner.
2208 impl Drop for UpdateFailMalformedHTLC {
2209 fn drop(&mut self) {
2210 if self.is_owned && !<*mut nativeUpdateFailMalformedHTLC>::is_null(self.inner) {
2211 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2215 /// Frees any resources used by the UpdateFailMalformedHTLC, if is_owned is set and inner is non-NULL.
2217 pub extern "C" fn UpdateFailMalformedHTLC_free(this_obj: UpdateFailMalformedHTLC) { }
2219 /// Used only if an object of this type is returned as a trait impl by a method
2220 pub(crate) extern "C" fn UpdateFailMalformedHTLC_free_void(this_ptr: *mut c_void) {
2221 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUpdateFailMalformedHTLC); }
2224 impl UpdateFailMalformedHTLC {
2225 pub(crate) fn get_native_ref(&self) -> &'static nativeUpdateFailMalformedHTLC {
2226 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2228 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUpdateFailMalformedHTLC {
2229 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2231 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2232 pub(crate) fn take_inner(mut self) -> *mut nativeUpdateFailMalformedHTLC {
2233 assert!(self.is_owned);
2234 let ret = ObjOps::untweak_ptr(self.inner);
2235 self.inner = core::ptr::null_mut();
2241 pub extern "C" fn UpdateFailMalformedHTLC_get_channel_id(this_ptr: &UpdateFailMalformedHTLC) -> *const [u8; 32] {
2242 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2247 pub extern "C" fn UpdateFailMalformedHTLC_set_channel_id(this_ptr: &mut UpdateFailMalformedHTLC, mut val: crate::c_types::ThirtyTwoBytes) {
2248 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2252 pub extern "C" fn UpdateFailMalformedHTLC_get_htlc_id(this_ptr: &UpdateFailMalformedHTLC) -> u64 {
2253 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_id;
2258 pub extern "C" fn UpdateFailMalformedHTLC_set_htlc_id(this_ptr: &mut UpdateFailMalformedHTLC, mut val: u64) {
2259 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_id = val;
2261 /// The failure code
2263 pub extern "C" fn UpdateFailMalformedHTLC_get_failure_code(this_ptr: &UpdateFailMalformedHTLC) -> u16 {
2264 let mut inner_val = &mut this_ptr.get_native_mut_ref().failure_code;
2267 /// The failure code
2269 pub extern "C" fn UpdateFailMalformedHTLC_set_failure_code(this_ptr: &mut UpdateFailMalformedHTLC, mut val: u16) {
2270 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.failure_code = val;
2272 impl Clone for UpdateFailMalformedHTLC {
2273 fn clone(&self) -> Self {
2275 inner: if <*mut nativeUpdateFailMalformedHTLC>::is_null(self.inner) { core::ptr::null_mut() } else {
2276 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2282 /// Used only if an object of this type is returned as a trait impl by a method
2283 pub(crate) extern "C" fn UpdateFailMalformedHTLC_clone_void(this_ptr: *const c_void) -> *mut c_void {
2284 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUpdateFailMalformedHTLC)).clone() })) as *mut c_void
2287 /// Creates a copy of the UpdateFailMalformedHTLC
2288 pub extern "C" fn UpdateFailMalformedHTLC_clone(orig: &UpdateFailMalformedHTLC) -> UpdateFailMalformedHTLC {
2292 use lightning::ln::msgs::CommitmentSigned as nativeCommitmentSignedImport;
2293 pub(crate) type nativeCommitmentSigned = nativeCommitmentSignedImport;
2295 /// A commitment_signed message to be sent or received from a peer
2298 pub struct CommitmentSigned {
2299 /// A pointer to the opaque Rust object.
2301 /// Nearly everywhere, inner must be non-null, however in places where
2302 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2303 pub inner: *mut nativeCommitmentSigned,
2304 /// Indicates that this is the only struct which contains the same pointer.
2306 /// Rust functions which take ownership of an object provided via an argument require
2307 /// this to be true and invalidate the object pointed to by inner.
2311 impl Drop for CommitmentSigned {
2312 fn drop(&mut self) {
2313 if self.is_owned && !<*mut nativeCommitmentSigned>::is_null(self.inner) {
2314 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2318 /// Frees any resources used by the CommitmentSigned, if is_owned is set and inner is non-NULL.
2320 pub extern "C" fn CommitmentSigned_free(this_obj: CommitmentSigned) { }
2322 /// Used only if an object of this type is returned as a trait impl by a method
2323 pub(crate) extern "C" fn CommitmentSigned_free_void(this_ptr: *mut c_void) {
2324 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeCommitmentSigned); }
2327 impl CommitmentSigned {
2328 pub(crate) fn get_native_ref(&self) -> &'static nativeCommitmentSigned {
2329 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2331 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeCommitmentSigned {
2332 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2334 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2335 pub(crate) fn take_inner(mut self) -> *mut nativeCommitmentSigned {
2336 assert!(self.is_owned);
2337 let ret = ObjOps::untweak_ptr(self.inner);
2338 self.inner = core::ptr::null_mut();
2344 pub extern "C" fn CommitmentSigned_get_channel_id(this_ptr: &CommitmentSigned) -> *const [u8; 32] {
2345 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2350 pub extern "C" fn CommitmentSigned_set_channel_id(this_ptr: &mut CommitmentSigned, mut val: crate::c_types::ThirtyTwoBytes) {
2351 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2353 /// A signature on the commitment transaction
2355 pub extern "C" fn CommitmentSigned_get_signature(this_ptr: &CommitmentSigned) -> crate::c_types::Signature {
2356 let mut inner_val = &mut this_ptr.get_native_mut_ref().signature;
2357 crate::c_types::Signature::from_rust(&inner_val)
2359 /// A signature on the commitment transaction
2361 pub extern "C" fn CommitmentSigned_set_signature(this_ptr: &mut CommitmentSigned, mut val: crate::c_types::Signature) {
2362 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.signature = val.into_rust();
2364 /// Signatures on the HTLC transactions
2366 pub extern "C" fn CommitmentSigned_set_htlc_signatures(this_ptr: &mut CommitmentSigned, mut val: crate::c_types::derived::CVec_SignatureZ) {
2367 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { item.into_rust() }); };
2368 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_signatures = local_val;
2370 /// Constructs a new CommitmentSigned given each field
2373 pub extern "C" fn CommitmentSigned_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut signature_arg: crate::c_types::Signature, mut htlc_signatures_arg: crate::c_types::derived::CVec_SignatureZ) -> CommitmentSigned {
2374 let mut local_htlc_signatures_arg = Vec::new(); for mut item in htlc_signatures_arg.into_rust().drain(..) { local_htlc_signatures_arg.push( { item.into_rust() }); };
2375 CommitmentSigned { inner: ObjOps::heap_alloc(nativeCommitmentSigned {
2376 channel_id: channel_id_arg.data,
2377 signature: signature_arg.into_rust(),
2378 htlc_signatures: local_htlc_signatures_arg,
2379 }), is_owned: true }
2381 impl Clone for CommitmentSigned {
2382 fn clone(&self) -> Self {
2384 inner: if <*mut nativeCommitmentSigned>::is_null(self.inner) { core::ptr::null_mut() } else {
2385 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2391 /// Used only if an object of this type is returned as a trait impl by a method
2392 pub(crate) extern "C" fn CommitmentSigned_clone_void(this_ptr: *const c_void) -> *mut c_void {
2393 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeCommitmentSigned)).clone() })) as *mut c_void
2396 /// Creates a copy of the CommitmentSigned
2397 pub extern "C" fn CommitmentSigned_clone(orig: &CommitmentSigned) -> CommitmentSigned {
2401 use lightning::ln::msgs::RevokeAndACK as nativeRevokeAndACKImport;
2402 pub(crate) type nativeRevokeAndACK = nativeRevokeAndACKImport;
2404 /// A revoke_and_ack message to be sent or received from a peer
2407 pub struct RevokeAndACK {
2408 /// A pointer to the opaque Rust object.
2410 /// Nearly everywhere, inner must be non-null, however in places where
2411 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2412 pub inner: *mut nativeRevokeAndACK,
2413 /// Indicates that this is the only struct which contains the same pointer.
2415 /// Rust functions which take ownership of an object provided via an argument require
2416 /// this to be true and invalidate the object pointed to by inner.
2420 impl Drop for RevokeAndACK {
2421 fn drop(&mut self) {
2422 if self.is_owned && !<*mut nativeRevokeAndACK>::is_null(self.inner) {
2423 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2427 /// Frees any resources used by the RevokeAndACK, if is_owned is set and inner is non-NULL.
2429 pub extern "C" fn RevokeAndACK_free(this_obj: RevokeAndACK) { }
2431 /// Used only if an object of this type is returned as a trait impl by a method
2432 pub(crate) extern "C" fn RevokeAndACK_free_void(this_ptr: *mut c_void) {
2433 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeRevokeAndACK); }
2437 pub(crate) fn get_native_ref(&self) -> &'static nativeRevokeAndACK {
2438 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2440 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeRevokeAndACK {
2441 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2443 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2444 pub(crate) fn take_inner(mut self) -> *mut nativeRevokeAndACK {
2445 assert!(self.is_owned);
2446 let ret = ObjOps::untweak_ptr(self.inner);
2447 self.inner = core::ptr::null_mut();
2453 pub extern "C" fn RevokeAndACK_get_channel_id(this_ptr: &RevokeAndACK) -> *const [u8; 32] {
2454 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2459 pub extern "C" fn RevokeAndACK_set_channel_id(this_ptr: &mut RevokeAndACK, mut val: crate::c_types::ThirtyTwoBytes) {
2460 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2462 /// The secret corresponding to the per-commitment point
2464 pub extern "C" fn RevokeAndACK_get_per_commitment_secret(this_ptr: &RevokeAndACK) -> *const [u8; 32] {
2465 let mut inner_val = &mut this_ptr.get_native_mut_ref().per_commitment_secret;
2468 /// The secret corresponding to the per-commitment point
2470 pub extern "C" fn RevokeAndACK_set_per_commitment_secret(this_ptr: &mut RevokeAndACK, mut val: crate::c_types::ThirtyTwoBytes) {
2471 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.per_commitment_secret = val.data;
2473 /// The next sender-broadcast commitment transaction's per-commitment point
2475 pub extern "C" fn RevokeAndACK_get_next_per_commitment_point(this_ptr: &RevokeAndACK) -> crate::c_types::PublicKey {
2476 let mut inner_val = &mut this_ptr.get_native_mut_ref().next_per_commitment_point;
2477 crate::c_types::PublicKey::from_rust(&inner_val)
2479 /// The next sender-broadcast commitment transaction's per-commitment point
2481 pub extern "C" fn RevokeAndACK_set_next_per_commitment_point(this_ptr: &mut RevokeAndACK, mut val: crate::c_types::PublicKey) {
2482 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.next_per_commitment_point = val.into_rust();
2484 /// Constructs a new RevokeAndACK given each field
2487 pub extern "C" fn RevokeAndACK_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut per_commitment_secret_arg: crate::c_types::ThirtyTwoBytes, mut next_per_commitment_point_arg: crate::c_types::PublicKey) -> RevokeAndACK {
2488 RevokeAndACK { inner: ObjOps::heap_alloc(nativeRevokeAndACK {
2489 channel_id: channel_id_arg.data,
2490 per_commitment_secret: per_commitment_secret_arg.data,
2491 next_per_commitment_point: next_per_commitment_point_arg.into_rust(),
2492 }), is_owned: true }
2494 impl Clone for RevokeAndACK {
2495 fn clone(&self) -> Self {
2497 inner: if <*mut nativeRevokeAndACK>::is_null(self.inner) { core::ptr::null_mut() } else {
2498 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2504 /// Used only if an object of this type is returned as a trait impl by a method
2505 pub(crate) extern "C" fn RevokeAndACK_clone_void(this_ptr: *const c_void) -> *mut c_void {
2506 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeRevokeAndACK)).clone() })) as *mut c_void
2509 /// Creates a copy of the RevokeAndACK
2510 pub extern "C" fn RevokeAndACK_clone(orig: &RevokeAndACK) -> RevokeAndACK {
2514 use lightning::ln::msgs::UpdateFee as nativeUpdateFeeImport;
2515 pub(crate) type nativeUpdateFee = nativeUpdateFeeImport;
2517 /// An update_fee message to be sent or received from a peer
2520 pub struct UpdateFee {
2521 /// A pointer to the opaque Rust object.
2523 /// Nearly everywhere, inner must be non-null, however in places where
2524 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2525 pub inner: *mut nativeUpdateFee,
2526 /// Indicates that this is the only struct which contains the same pointer.
2528 /// Rust functions which take ownership of an object provided via an argument require
2529 /// this to be true and invalidate the object pointed to by inner.
2533 impl Drop for UpdateFee {
2534 fn drop(&mut self) {
2535 if self.is_owned && !<*mut nativeUpdateFee>::is_null(self.inner) {
2536 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2540 /// Frees any resources used by the UpdateFee, if is_owned is set and inner is non-NULL.
2542 pub extern "C" fn UpdateFee_free(this_obj: UpdateFee) { }
2544 /// Used only if an object of this type is returned as a trait impl by a method
2545 pub(crate) extern "C" fn UpdateFee_free_void(this_ptr: *mut c_void) {
2546 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUpdateFee); }
2550 pub(crate) fn get_native_ref(&self) -> &'static nativeUpdateFee {
2551 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2553 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUpdateFee {
2554 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2556 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2557 pub(crate) fn take_inner(mut self) -> *mut nativeUpdateFee {
2558 assert!(self.is_owned);
2559 let ret = ObjOps::untweak_ptr(self.inner);
2560 self.inner = core::ptr::null_mut();
2566 pub extern "C" fn UpdateFee_get_channel_id(this_ptr: &UpdateFee) -> *const [u8; 32] {
2567 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2572 pub extern "C" fn UpdateFee_set_channel_id(this_ptr: &mut UpdateFee, mut val: crate::c_types::ThirtyTwoBytes) {
2573 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2575 /// Fee rate per 1000-weight of the transaction
2577 pub extern "C" fn UpdateFee_get_feerate_per_kw(this_ptr: &UpdateFee) -> u32 {
2578 let mut inner_val = &mut this_ptr.get_native_mut_ref().feerate_per_kw;
2581 /// Fee rate per 1000-weight of the transaction
2583 pub extern "C" fn UpdateFee_set_feerate_per_kw(this_ptr: &mut UpdateFee, mut val: u32) {
2584 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.feerate_per_kw = val;
2586 /// Constructs a new UpdateFee given each field
2589 pub extern "C" fn UpdateFee_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut feerate_per_kw_arg: u32) -> UpdateFee {
2590 UpdateFee { inner: ObjOps::heap_alloc(nativeUpdateFee {
2591 channel_id: channel_id_arg.data,
2592 feerate_per_kw: feerate_per_kw_arg,
2593 }), is_owned: true }
2595 impl Clone for UpdateFee {
2596 fn clone(&self) -> Self {
2598 inner: if <*mut nativeUpdateFee>::is_null(self.inner) { core::ptr::null_mut() } else {
2599 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2605 /// Used only if an object of this type is returned as a trait impl by a method
2606 pub(crate) extern "C" fn UpdateFee_clone_void(this_ptr: *const c_void) -> *mut c_void {
2607 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUpdateFee)).clone() })) as *mut c_void
2610 /// Creates a copy of the UpdateFee
2611 pub extern "C" fn UpdateFee_clone(orig: &UpdateFee) -> UpdateFee {
2615 use lightning::ln::msgs::DataLossProtect as nativeDataLossProtectImport;
2616 pub(crate) type nativeDataLossProtect = nativeDataLossProtectImport;
2618 /// Proof that the sender knows the per-commitment secret of the previous commitment transaction.
2619 /// This is used to convince the recipient that the channel is at a certain commitment
2620 /// number even if they lost that data due to a local failure. Of course, the peer may lie
2621 /// and even later commitments may have been revoked.
2624 pub struct DataLossProtect {
2625 /// A pointer to the opaque Rust object.
2627 /// Nearly everywhere, inner must be non-null, however in places where
2628 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2629 pub inner: *mut nativeDataLossProtect,
2630 /// Indicates that this is the only struct which contains the same pointer.
2632 /// Rust functions which take ownership of an object provided via an argument require
2633 /// this to be true and invalidate the object pointed to by inner.
2637 impl Drop for DataLossProtect {
2638 fn drop(&mut self) {
2639 if self.is_owned && !<*mut nativeDataLossProtect>::is_null(self.inner) {
2640 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2644 /// Frees any resources used by the DataLossProtect, if is_owned is set and inner is non-NULL.
2646 pub extern "C" fn DataLossProtect_free(this_obj: DataLossProtect) { }
2648 /// Used only if an object of this type is returned as a trait impl by a method
2649 pub(crate) extern "C" fn DataLossProtect_free_void(this_ptr: *mut c_void) {
2650 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeDataLossProtect); }
2653 impl DataLossProtect {
2654 pub(crate) fn get_native_ref(&self) -> &'static nativeDataLossProtect {
2655 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2657 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeDataLossProtect {
2658 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2660 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2661 pub(crate) fn take_inner(mut self) -> *mut nativeDataLossProtect {
2662 assert!(self.is_owned);
2663 let ret = ObjOps::untweak_ptr(self.inner);
2664 self.inner = core::ptr::null_mut();
2668 /// Proof that the sender knows the per-commitment secret of a specific commitment transaction
2669 /// belonging to the recipient
2671 pub extern "C" fn DataLossProtect_get_your_last_per_commitment_secret(this_ptr: &DataLossProtect) -> *const [u8; 32] {
2672 let mut inner_val = &mut this_ptr.get_native_mut_ref().your_last_per_commitment_secret;
2675 /// Proof that the sender knows the per-commitment secret of a specific commitment transaction
2676 /// belonging to the recipient
2678 pub extern "C" fn DataLossProtect_set_your_last_per_commitment_secret(this_ptr: &mut DataLossProtect, mut val: crate::c_types::ThirtyTwoBytes) {
2679 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.your_last_per_commitment_secret = val.data;
2681 /// The sender's per-commitment point for their current commitment transaction
2683 pub extern "C" fn DataLossProtect_get_my_current_per_commitment_point(this_ptr: &DataLossProtect) -> crate::c_types::PublicKey {
2684 let mut inner_val = &mut this_ptr.get_native_mut_ref().my_current_per_commitment_point;
2685 crate::c_types::PublicKey::from_rust(&inner_val)
2687 /// The sender's per-commitment point for their current commitment transaction
2689 pub extern "C" fn DataLossProtect_set_my_current_per_commitment_point(this_ptr: &mut DataLossProtect, mut val: crate::c_types::PublicKey) {
2690 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.my_current_per_commitment_point = val.into_rust();
2692 /// Constructs a new DataLossProtect given each field
2695 pub extern "C" fn DataLossProtect_new(mut your_last_per_commitment_secret_arg: crate::c_types::ThirtyTwoBytes, mut my_current_per_commitment_point_arg: crate::c_types::PublicKey) -> DataLossProtect {
2696 DataLossProtect { inner: ObjOps::heap_alloc(nativeDataLossProtect {
2697 your_last_per_commitment_secret: your_last_per_commitment_secret_arg.data,
2698 my_current_per_commitment_point: my_current_per_commitment_point_arg.into_rust(),
2699 }), is_owned: true }
2701 impl Clone for DataLossProtect {
2702 fn clone(&self) -> Self {
2704 inner: if <*mut nativeDataLossProtect>::is_null(self.inner) { core::ptr::null_mut() } else {
2705 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2711 /// Used only if an object of this type is returned as a trait impl by a method
2712 pub(crate) extern "C" fn DataLossProtect_clone_void(this_ptr: *const c_void) -> *mut c_void {
2713 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeDataLossProtect)).clone() })) as *mut c_void
2716 /// Creates a copy of the DataLossProtect
2717 pub extern "C" fn DataLossProtect_clone(orig: &DataLossProtect) -> DataLossProtect {
2721 use lightning::ln::msgs::ChannelReestablish as nativeChannelReestablishImport;
2722 pub(crate) type nativeChannelReestablish = nativeChannelReestablishImport;
2724 /// A channel_reestablish message to be sent or received from a peer
2727 pub struct ChannelReestablish {
2728 /// A pointer to the opaque Rust object.
2730 /// Nearly everywhere, inner must be non-null, however in places where
2731 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2732 pub inner: *mut nativeChannelReestablish,
2733 /// Indicates that this is the only struct which contains the same pointer.
2735 /// Rust functions which take ownership of an object provided via an argument require
2736 /// this to be true and invalidate the object pointed to by inner.
2740 impl Drop for ChannelReestablish {
2741 fn drop(&mut self) {
2742 if self.is_owned && !<*mut nativeChannelReestablish>::is_null(self.inner) {
2743 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2747 /// Frees any resources used by the ChannelReestablish, if is_owned is set and inner is non-NULL.
2749 pub extern "C" fn ChannelReestablish_free(this_obj: ChannelReestablish) { }
2751 /// Used only if an object of this type is returned as a trait impl by a method
2752 pub(crate) extern "C" fn ChannelReestablish_free_void(this_ptr: *mut c_void) {
2753 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeChannelReestablish); }
2756 impl ChannelReestablish {
2757 pub(crate) fn get_native_ref(&self) -> &'static nativeChannelReestablish {
2758 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2760 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeChannelReestablish {
2761 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2763 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2764 pub(crate) fn take_inner(mut self) -> *mut nativeChannelReestablish {
2765 assert!(self.is_owned);
2766 let ret = ObjOps::untweak_ptr(self.inner);
2767 self.inner = core::ptr::null_mut();
2773 pub extern "C" fn ChannelReestablish_get_channel_id(this_ptr: &ChannelReestablish) -> *const [u8; 32] {
2774 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2779 pub extern "C" fn ChannelReestablish_set_channel_id(this_ptr: &mut ChannelReestablish, mut val: crate::c_types::ThirtyTwoBytes) {
2780 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2782 /// The next commitment number for the sender
2784 pub extern "C" fn ChannelReestablish_get_next_local_commitment_number(this_ptr: &ChannelReestablish) -> u64 {
2785 let mut inner_val = &mut this_ptr.get_native_mut_ref().next_local_commitment_number;
2788 /// The next commitment number for the sender
2790 pub extern "C" fn ChannelReestablish_set_next_local_commitment_number(this_ptr: &mut ChannelReestablish, mut val: u64) {
2791 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.next_local_commitment_number = val;
2793 /// The next commitment number for the recipient
2795 pub extern "C" fn ChannelReestablish_get_next_remote_commitment_number(this_ptr: &ChannelReestablish) -> u64 {
2796 let mut inner_val = &mut this_ptr.get_native_mut_ref().next_remote_commitment_number;
2799 /// The next commitment number for the recipient
2801 pub extern "C" fn ChannelReestablish_set_next_remote_commitment_number(this_ptr: &mut ChannelReestablish, mut val: u64) {
2802 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.next_remote_commitment_number = val;
2804 impl Clone for ChannelReestablish {
2805 fn clone(&self) -> Self {
2807 inner: if <*mut nativeChannelReestablish>::is_null(self.inner) { core::ptr::null_mut() } else {
2808 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2814 /// Used only if an object of this type is returned as a trait impl by a method
2815 pub(crate) extern "C" fn ChannelReestablish_clone_void(this_ptr: *const c_void) -> *mut c_void {
2816 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeChannelReestablish)).clone() })) as *mut c_void
2819 /// Creates a copy of the ChannelReestablish
2820 pub extern "C" fn ChannelReestablish_clone(orig: &ChannelReestablish) -> ChannelReestablish {
2824 use lightning::ln::msgs::AnnouncementSignatures as nativeAnnouncementSignaturesImport;
2825 pub(crate) type nativeAnnouncementSignatures = nativeAnnouncementSignaturesImport;
2827 /// An announcement_signatures message to be sent or received from a peer
2830 pub struct AnnouncementSignatures {
2831 /// A pointer to the opaque Rust object.
2833 /// Nearly everywhere, inner must be non-null, however in places where
2834 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
2835 pub inner: *mut nativeAnnouncementSignatures,
2836 /// Indicates that this is the only struct which contains the same pointer.
2838 /// Rust functions which take ownership of an object provided via an argument require
2839 /// this to be true and invalidate the object pointed to by inner.
2843 impl Drop for AnnouncementSignatures {
2844 fn drop(&mut self) {
2845 if self.is_owned && !<*mut nativeAnnouncementSignatures>::is_null(self.inner) {
2846 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
2850 /// Frees any resources used by the AnnouncementSignatures, if is_owned is set and inner is non-NULL.
2852 pub extern "C" fn AnnouncementSignatures_free(this_obj: AnnouncementSignatures) { }
2854 /// Used only if an object of this type is returned as a trait impl by a method
2855 pub(crate) extern "C" fn AnnouncementSignatures_free_void(this_ptr: *mut c_void) {
2856 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeAnnouncementSignatures); }
2859 impl AnnouncementSignatures {
2860 pub(crate) fn get_native_ref(&self) -> &'static nativeAnnouncementSignatures {
2861 unsafe { &*ObjOps::untweak_ptr(self.inner) }
2863 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeAnnouncementSignatures {
2864 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
2866 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
2867 pub(crate) fn take_inner(mut self) -> *mut nativeAnnouncementSignatures {
2868 assert!(self.is_owned);
2869 let ret = ObjOps::untweak_ptr(self.inner);
2870 self.inner = core::ptr::null_mut();
2876 pub extern "C" fn AnnouncementSignatures_get_channel_id(this_ptr: &AnnouncementSignatures) -> *const [u8; 32] {
2877 let mut inner_val = &mut this_ptr.get_native_mut_ref().channel_id;
2882 pub extern "C" fn AnnouncementSignatures_set_channel_id(this_ptr: &mut AnnouncementSignatures, mut val: crate::c_types::ThirtyTwoBytes) {
2883 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.channel_id = val.data;
2885 /// The short channel ID
2887 pub extern "C" fn AnnouncementSignatures_get_short_channel_id(this_ptr: &AnnouncementSignatures) -> u64 {
2888 let mut inner_val = &mut this_ptr.get_native_mut_ref().short_channel_id;
2891 /// The short channel ID
2893 pub extern "C" fn AnnouncementSignatures_set_short_channel_id(this_ptr: &mut AnnouncementSignatures, mut val: u64) {
2894 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.short_channel_id = val;
2896 /// A signature by the node key
2898 pub extern "C" fn AnnouncementSignatures_get_node_signature(this_ptr: &AnnouncementSignatures) -> crate::c_types::Signature {
2899 let mut inner_val = &mut this_ptr.get_native_mut_ref().node_signature;
2900 crate::c_types::Signature::from_rust(&inner_val)
2902 /// A signature by the node key
2904 pub extern "C" fn AnnouncementSignatures_set_node_signature(this_ptr: &mut AnnouncementSignatures, mut val: crate::c_types::Signature) {
2905 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.node_signature = val.into_rust();
2907 /// A signature by the funding key
2909 pub extern "C" fn AnnouncementSignatures_get_bitcoin_signature(this_ptr: &AnnouncementSignatures) -> crate::c_types::Signature {
2910 let mut inner_val = &mut this_ptr.get_native_mut_ref().bitcoin_signature;
2911 crate::c_types::Signature::from_rust(&inner_val)
2913 /// A signature by the funding key
2915 pub extern "C" fn AnnouncementSignatures_set_bitcoin_signature(this_ptr: &mut AnnouncementSignatures, mut val: crate::c_types::Signature) {
2916 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.bitcoin_signature = val.into_rust();
2918 /// Constructs a new AnnouncementSignatures given each field
2921 pub extern "C" fn AnnouncementSignatures_new(mut channel_id_arg: crate::c_types::ThirtyTwoBytes, mut short_channel_id_arg: u64, mut node_signature_arg: crate::c_types::Signature, mut bitcoin_signature_arg: crate::c_types::Signature) -> AnnouncementSignatures {
2922 AnnouncementSignatures { inner: ObjOps::heap_alloc(nativeAnnouncementSignatures {
2923 channel_id: channel_id_arg.data,
2924 short_channel_id: short_channel_id_arg,
2925 node_signature: node_signature_arg.into_rust(),
2926 bitcoin_signature: bitcoin_signature_arg.into_rust(),
2927 }), is_owned: true }
2929 impl Clone for AnnouncementSignatures {
2930 fn clone(&self) -> Self {
2932 inner: if <*mut nativeAnnouncementSignatures>::is_null(self.inner) { core::ptr::null_mut() } else {
2933 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
2939 /// Used only if an object of this type is returned as a trait impl by a method
2940 pub(crate) extern "C" fn AnnouncementSignatures_clone_void(this_ptr: *const c_void) -> *mut c_void {
2941 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeAnnouncementSignatures)).clone() })) as *mut c_void
2944 /// Creates a copy of the AnnouncementSignatures
2945 pub extern "C" fn AnnouncementSignatures_clone(orig: &AnnouncementSignatures) -> AnnouncementSignatures {
2948 /// An address which can be used to connect to a remote peer
2952 pub enum NetAddress {
2953 /// An IPv4 address/port on which the peer is listening.
2955 /// The 4-byte IPv4 address
2956 addr: crate::c_types::FourBytes,
2957 /// The port on which the node is listening
2960 /// An IPv6 address/port on which the peer is listening.
2962 /// The 16-byte IPv6 address
2963 addr: crate::c_types::SixteenBytes,
2964 /// The port on which the node is listening
2967 /// An old-style Tor onion address/port on which the peer is listening.
2969 /// This field is deprecated and the Tor network generally no longer supports V2 Onion
2970 /// addresses. Thus, the details are not parsed here.
2972 crate::c_types::TwelveBytes),
2973 /// A new-style Tor onion address/port on which the peer is listening.
2974 /// To create the human-readable \"hostname\", concatenate ed25519_pubkey, checksum, and version,
2975 /// wrap as base32 and append \".onion\".
2977 /// The ed25519 long-term public key of the peer
2978 ed25519_pubkey: crate::c_types::ThirtyTwoBytes,
2979 /// The checksum of the pubkey and version, as included in the onion address
2981 /// The version byte, as defined by the Tor Onion v3 spec.
2983 /// The port on which the node is listening
2986 /// A hostname/port on which the peer is listening.
2988 /// The hostname on which the node is listening.
2989 hostname: crate::lightning::util::ser::Hostname,
2990 /// The port on which the node is listening.
2994 use lightning::ln::msgs::NetAddress as NetAddressImport;
2995 pub(crate) type nativeNetAddress = NetAddressImport;
2999 pub(crate) fn to_native(&self) -> nativeNetAddress {
3001 NetAddress::IPv4 {ref addr, ref port, } => {
3002 let mut addr_nonref = (*addr).clone();
3003 let mut port_nonref = (*port).clone();
3004 nativeNetAddress::IPv4 {
3005 addr: addr_nonref.data,
3009 NetAddress::IPv6 {ref addr, ref port, } => {
3010 let mut addr_nonref = (*addr).clone();
3011 let mut port_nonref = (*port).clone();
3012 nativeNetAddress::IPv6 {
3013 addr: addr_nonref.data,
3017 NetAddress::OnionV2 (ref a, ) => {
3018 let mut a_nonref = (*a).clone();
3019 nativeNetAddress::OnionV2 (
3023 NetAddress::OnionV3 {ref ed25519_pubkey, ref checksum, ref version, ref port, } => {
3024 let mut ed25519_pubkey_nonref = (*ed25519_pubkey).clone();
3025 let mut checksum_nonref = (*checksum).clone();
3026 let mut version_nonref = (*version).clone();
3027 let mut port_nonref = (*port).clone();
3028 nativeNetAddress::OnionV3 {
3029 ed25519_pubkey: ed25519_pubkey_nonref.data,
3030 checksum: checksum_nonref,
3031 version: version_nonref,
3035 NetAddress::Hostname {ref hostname, ref port, } => {
3036 let mut hostname_nonref = (*hostname).clone();
3037 let mut port_nonref = (*port).clone();
3038 nativeNetAddress::Hostname {
3039 hostname: *unsafe { Box::from_raw(hostname_nonref.take_inner()) },
3046 pub(crate) fn into_native(self) -> nativeNetAddress {
3048 NetAddress::IPv4 {mut addr, mut port, } => {
3049 nativeNetAddress::IPv4 {
3054 NetAddress::IPv6 {mut addr, mut port, } => {
3055 nativeNetAddress::IPv6 {
3060 NetAddress::OnionV2 (mut a, ) => {
3061 nativeNetAddress::OnionV2 (
3065 NetAddress::OnionV3 {mut ed25519_pubkey, mut checksum, mut version, mut port, } => {
3066 nativeNetAddress::OnionV3 {
3067 ed25519_pubkey: ed25519_pubkey.data,
3073 NetAddress::Hostname {mut hostname, mut port, } => {
3074 nativeNetAddress::Hostname {
3075 hostname: *unsafe { Box::from_raw(hostname.take_inner()) },
3082 pub(crate) fn from_native(native: &nativeNetAddress) -> Self {
3084 nativeNetAddress::IPv4 {ref addr, ref port, } => {
3085 let mut addr_nonref = (*addr).clone();
3086 let mut port_nonref = (*port).clone();
3088 addr: crate::c_types::FourBytes { data: addr_nonref },
3092 nativeNetAddress::IPv6 {ref addr, ref port, } => {
3093 let mut addr_nonref = (*addr).clone();
3094 let mut port_nonref = (*port).clone();
3096 addr: crate::c_types::SixteenBytes { data: addr_nonref },
3100 nativeNetAddress::OnionV2 (ref a, ) => {
3101 let mut a_nonref = (*a).clone();
3102 NetAddress::OnionV2 (
3103 crate::c_types::TwelveBytes { data: a_nonref },
3106 nativeNetAddress::OnionV3 {ref ed25519_pubkey, ref checksum, ref version, ref port, } => {
3107 let mut ed25519_pubkey_nonref = (*ed25519_pubkey).clone();
3108 let mut checksum_nonref = (*checksum).clone();
3109 let mut version_nonref = (*version).clone();
3110 let mut port_nonref = (*port).clone();
3111 NetAddress::OnionV3 {
3112 ed25519_pubkey: crate::c_types::ThirtyTwoBytes { data: ed25519_pubkey_nonref },
3113 checksum: checksum_nonref,
3114 version: version_nonref,
3118 nativeNetAddress::Hostname {ref hostname, ref port, } => {
3119 let mut hostname_nonref = (*hostname).clone();
3120 let mut port_nonref = (*port).clone();
3121 NetAddress::Hostname {
3122 hostname: crate::lightning::util::ser::Hostname { inner: ObjOps::heap_alloc(hostname_nonref), is_owned: true },
3129 pub(crate) fn native_into(native: nativeNetAddress) -> Self {
3131 nativeNetAddress::IPv4 {mut addr, mut port, } => {
3133 addr: crate::c_types::FourBytes { data: addr },
3137 nativeNetAddress::IPv6 {mut addr, mut port, } => {
3139 addr: crate::c_types::SixteenBytes { data: addr },
3143 nativeNetAddress::OnionV2 (mut a, ) => {
3144 NetAddress::OnionV2 (
3145 crate::c_types::TwelveBytes { data: a },
3148 nativeNetAddress::OnionV3 {mut ed25519_pubkey, mut checksum, mut version, mut port, } => {
3149 NetAddress::OnionV3 {
3150 ed25519_pubkey: crate::c_types::ThirtyTwoBytes { data: ed25519_pubkey },
3156 nativeNetAddress::Hostname {mut hostname, mut port, } => {
3157 NetAddress::Hostname {
3158 hostname: crate::lightning::util::ser::Hostname { inner: ObjOps::heap_alloc(hostname), is_owned: true },
3165 /// Frees any resources used by the NetAddress
3167 pub extern "C" fn NetAddress_free(this_ptr: NetAddress) { }
3168 /// Creates a copy of the NetAddress
3170 pub extern "C" fn NetAddress_clone(orig: &NetAddress) -> NetAddress {
3174 /// Utility method to constructs a new IPv4-variant NetAddress
3175 pub extern "C" fn NetAddress_ipv4(addr: crate::c_types::FourBytes, port: u16) -> NetAddress {
3182 /// Utility method to constructs a new IPv6-variant NetAddress
3183 pub extern "C" fn NetAddress_ipv6(addr: crate::c_types::SixteenBytes, port: u16) -> NetAddress {
3190 /// Utility method to constructs a new OnionV2-variant NetAddress
3191 pub extern "C" fn NetAddress_onion_v2(a: crate::c_types::TwelveBytes) -> NetAddress {
3192 NetAddress::OnionV2(a, )
3195 /// Utility method to constructs a new OnionV3-variant NetAddress
3196 pub extern "C" fn NetAddress_onion_v3(ed25519_pubkey: crate::c_types::ThirtyTwoBytes, checksum: u16, version: u8, port: u16) -> NetAddress {
3197 NetAddress::OnionV3 {
3205 /// Utility method to constructs a new Hostname-variant NetAddress
3206 pub extern "C" fn NetAddress_hostname(hostname: crate::lightning::util::ser::Hostname, port: u16) -> NetAddress {
3207 NetAddress::Hostname {
3213 /// Serialize the NetAddress object into a byte array which can be read by NetAddress_read
3214 pub extern "C" fn NetAddress_write(obj: &crate::lightning::ln::msgs::NetAddress) -> crate::c_types::derived::CVec_u8Z {
3215 crate::c_types::serialize_obj(&unsafe { &*obj }.to_native())
3218 /// Read a NetAddress from a byte array, created by NetAddress_write
3219 pub extern "C" fn NetAddress_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_NetAddressDecodeErrorZ {
3220 let res: Result<lightning::ln::msgs::NetAddress, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
3221 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::NetAddress::native_into(o) }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
3225 use lightning::ln::msgs::UnsignedNodeAnnouncement as nativeUnsignedNodeAnnouncementImport;
3226 pub(crate) type nativeUnsignedNodeAnnouncement = nativeUnsignedNodeAnnouncementImport;
3228 /// The unsigned part of a node_announcement
3231 pub struct UnsignedNodeAnnouncement {
3232 /// A pointer to the opaque Rust object.
3234 /// Nearly everywhere, inner must be non-null, however in places where
3235 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
3236 pub inner: *mut nativeUnsignedNodeAnnouncement,
3237 /// Indicates that this is the only struct which contains the same pointer.
3239 /// Rust functions which take ownership of an object provided via an argument require
3240 /// this to be true and invalidate the object pointed to by inner.
3244 impl Drop for UnsignedNodeAnnouncement {
3245 fn drop(&mut self) {
3246 if self.is_owned && !<*mut nativeUnsignedNodeAnnouncement>::is_null(self.inner) {
3247 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
3251 /// Frees any resources used by the UnsignedNodeAnnouncement, if is_owned is set and inner is non-NULL.
3253 pub extern "C" fn UnsignedNodeAnnouncement_free(this_obj: UnsignedNodeAnnouncement) { }
3255 /// Used only if an object of this type is returned as a trait impl by a method
3256 pub(crate) extern "C" fn UnsignedNodeAnnouncement_free_void(this_ptr: *mut c_void) {
3257 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUnsignedNodeAnnouncement); }
3260 impl UnsignedNodeAnnouncement {
3261 pub(crate) fn get_native_ref(&self) -> &'static nativeUnsignedNodeAnnouncement {
3262 unsafe { &*ObjOps::untweak_ptr(self.inner) }
3264 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUnsignedNodeAnnouncement {
3265 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
3267 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
3268 pub(crate) fn take_inner(mut self) -> *mut nativeUnsignedNodeAnnouncement {
3269 assert!(self.is_owned);
3270 let ret = ObjOps::untweak_ptr(self.inner);
3271 self.inner = core::ptr::null_mut();
3275 /// The advertised features
3277 pub extern "C" fn UnsignedNodeAnnouncement_get_features(this_ptr: &UnsignedNodeAnnouncement) -> crate::lightning::ln::features::NodeFeatures {
3278 let mut inner_val = &mut this_ptr.get_native_mut_ref().features;
3279 crate::lightning::ln::features::NodeFeatures { inner: unsafe { ObjOps::nonnull_ptr_to_inner((inner_val as *const lightning::ln::features::NodeFeatures<>) as *mut _) }, is_owned: false }
3281 /// The advertised features
3283 pub extern "C" fn UnsignedNodeAnnouncement_set_features(this_ptr: &mut UnsignedNodeAnnouncement, mut val: crate::lightning::ln::features::NodeFeatures) {
3284 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.features = *unsafe { Box::from_raw(val.take_inner()) };
3286 /// A strictly monotonic announcement counter, with gaps allowed
3288 pub extern "C" fn UnsignedNodeAnnouncement_get_timestamp(this_ptr: &UnsignedNodeAnnouncement) -> u32 {
3289 let mut inner_val = &mut this_ptr.get_native_mut_ref().timestamp;
3292 /// A strictly monotonic announcement counter, with gaps allowed
3294 pub extern "C" fn UnsignedNodeAnnouncement_set_timestamp(this_ptr: &mut UnsignedNodeAnnouncement, mut val: u32) {
3295 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.timestamp = val;
3297 /// The node_id this announcement originated from (don't rebroadcast the node_announcement back
3300 pub extern "C" fn UnsignedNodeAnnouncement_get_node_id(this_ptr: &UnsignedNodeAnnouncement) -> crate::c_types::PublicKey {
3301 let mut inner_val = &mut this_ptr.get_native_mut_ref().node_id;
3302 crate::c_types::PublicKey::from_rust(&inner_val)
3304 /// The node_id this announcement originated from (don't rebroadcast the node_announcement back
3307 pub extern "C" fn UnsignedNodeAnnouncement_set_node_id(this_ptr: &mut UnsignedNodeAnnouncement, mut val: crate::c_types::PublicKey) {
3308 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.node_id = val.into_rust();
3310 /// An RGB color for UI purposes
3312 pub extern "C" fn UnsignedNodeAnnouncement_get_rgb(this_ptr: &UnsignedNodeAnnouncement) -> *const [u8; 3] {
3313 let mut inner_val = &mut this_ptr.get_native_mut_ref().rgb;
3316 /// An RGB color for UI purposes
3318 pub extern "C" fn UnsignedNodeAnnouncement_set_rgb(this_ptr: &mut UnsignedNodeAnnouncement, mut val: crate::c_types::ThreeBytes) {
3319 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.rgb = val.data;
3321 /// An alias, for UI purposes. This should be sanitized before use. There is no guarantee
3324 pub extern "C" fn UnsignedNodeAnnouncement_get_alias(this_ptr: &UnsignedNodeAnnouncement) -> *const [u8; 32] {
3325 let mut inner_val = &mut this_ptr.get_native_mut_ref().alias;
3328 /// An alias, for UI purposes. This should be sanitized before use. There is no guarantee
3331 pub extern "C" fn UnsignedNodeAnnouncement_set_alias(this_ptr: &mut UnsignedNodeAnnouncement, mut val: crate::c_types::ThirtyTwoBytes) {
3332 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.alias = val.data;
3334 /// List of addresses on which this node is reachable
3336 pub extern "C" fn UnsignedNodeAnnouncement_set_addresses(this_ptr: &mut UnsignedNodeAnnouncement, mut val: crate::c_types::derived::CVec_NetAddressZ) {
3337 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { item.into_native() }); };
3338 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.addresses = local_val;
3340 impl Clone for UnsignedNodeAnnouncement {
3341 fn clone(&self) -> Self {
3343 inner: if <*mut nativeUnsignedNodeAnnouncement>::is_null(self.inner) { core::ptr::null_mut() } else {
3344 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
3350 /// Used only if an object of this type is returned as a trait impl by a method
3351 pub(crate) extern "C" fn UnsignedNodeAnnouncement_clone_void(this_ptr: *const c_void) -> *mut c_void {
3352 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUnsignedNodeAnnouncement)).clone() })) as *mut c_void
3355 /// Creates a copy of the UnsignedNodeAnnouncement
3356 pub extern "C" fn UnsignedNodeAnnouncement_clone(orig: &UnsignedNodeAnnouncement) -> UnsignedNodeAnnouncement {
3360 use lightning::ln::msgs::NodeAnnouncement as nativeNodeAnnouncementImport;
3361 pub(crate) type nativeNodeAnnouncement = nativeNodeAnnouncementImport;
3363 /// A node_announcement message to be sent or received from a peer
3366 pub struct NodeAnnouncement {
3367 /// A pointer to the opaque Rust object.
3369 /// Nearly everywhere, inner must be non-null, however in places where
3370 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
3371 pub inner: *mut nativeNodeAnnouncement,
3372 /// Indicates that this is the only struct which contains the same pointer.
3374 /// Rust functions which take ownership of an object provided via an argument require
3375 /// this to be true and invalidate the object pointed to by inner.
3379 impl Drop for NodeAnnouncement {
3380 fn drop(&mut self) {
3381 if self.is_owned && !<*mut nativeNodeAnnouncement>::is_null(self.inner) {
3382 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
3386 /// Frees any resources used by the NodeAnnouncement, if is_owned is set and inner is non-NULL.
3388 pub extern "C" fn NodeAnnouncement_free(this_obj: NodeAnnouncement) { }
3390 /// Used only if an object of this type is returned as a trait impl by a method
3391 pub(crate) extern "C" fn NodeAnnouncement_free_void(this_ptr: *mut c_void) {
3392 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeNodeAnnouncement); }
3395 impl NodeAnnouncement {
3396 pub(crate) fn get_native_ref(&self) -> &'static nativeNodeAnnouncement {
3397 unsafe { &*ObjOps::untweak_ptr(self.inner) }
3399 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeNodeAnnouncement {
3400 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
3402 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
3403 pub(crate) fn take_inner(mut self) -> *mut nativeNodeAnnouncement {
3404 assert!(self.is_owned);
3405 let ret = ObjOps::untweak_ptr(self.inner);
3406 self.inner = core::ptr::null_mut();
3410 /// The signature by the node key
3412 pub extern "C" fn NodeAnnouncement_get_signature(this_ptr: &NodeAnnouncement) -> crate::c_types::Signature {
3413 let mut inner_val = &mut this_ptr.get_native_mut_ref().signature;
3414 crate::c_types::Signature::from_rust(&inner_val)
3416 /// The signature by the node key
3418 pub extern "C" fn NodeAnnouncement_set_signature(this_ptr: &mut NodeAnnouncement, mut val: crate::c_types::Signature) {
3419 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.signature = val.into_rust();
3421 /// The actual content of the announcement
3423 pub extern "C" fn NodeAnnouncement_get_contents(this_ptr: &NodeAnnouncement) -> crate::lightning::ln::msgs::UnsignedNodeAnnouncement {
3424 let mut inner_val = &mut this_ptr.get_native_mut_ref().contents;
3425 crate::lightning::ln::msgs::UnsignedNodeAnnouncement { inner: unsafe { ObjOps::nonnull_ptr_to_inner((inner_val as *const lightning::ln::msgs::UnsignedNodeAnnouncement<>) as *mut _) }, is_owned: false }
3427 /// The actual content of the announcement
3429 pub extern "C" fn NodeAnnouncement_set_contents(this_ptr: &mut NodeAnnouncement, mut val: crate::lightning::ln::msgs::UnsignedNodeAnnouncement) {
3430 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.contents = *unsafe { Box::from_raw(val.take_inner()) };
3432 /// Constructs a new NodeAnnouncement given each field
3435 pub extern "C" fn NodeAnnouncement_new(mut signature_arg: crate::c_types::Signature, mut contents_arg: crate::lightning::ln::msgs::UnsignedNodeAnnouncement) -> NodeAnnouncement {
3436 NodeAnnouncement { inner: ObjOps::heap_alloc(nativeNodeAnnouncement {
3437 signature: signature_arg.into_rust(),
3438 contents: *unsafe { Box::from_raw(contents_arg.take_inner()) },
3439 }), is_owned: true }
3441 impl Clone for NodeAnnouncement {
3442 fn clone(&self) -> Self {
3444 inner: if <*mut nativeNodeAnnouncement>::is_null(self.inner) { core::ptr::null_mut() } else {
3445 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
3451 /// Used only if an object of this type is returned as a trait impl by a method
3452 pub(crate) extern "C" fn NodeAnnouncement_clone_void(this_ptr: *const c_void) -> *mut c_void {
3453 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeNodeAnnouncement)).clone() })) as *mut c_void
3456 /// Creates a copy of the NodeAnnouncement
3457 pub extern "C" fn NodeAnnouncement_clone(orig: &NodeAnnouncement) -> NodeAnnouncement {
3461 use lightning::ln::msgs::UnsignedChannelAnnouncement as nativeUnsignedChannelAnnouncementImport;
3462 pub(crate) type nativeUnsignedChannelAnnouncement = nativeUnsignedChannelAnnouncementImport;
3464 /// The unsigned part of a channel_announcement
3467 pub struct UnsignedChannelAnnouncement {
3468 /// A pointer to the opaque Rust object.
3470 /// Nearly everywhere, inner must be non-null, however in places where
3471 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
3472 pub inner: *mut nativeUnsignedChannelAnnouncement,
3473 /// Indicates that this is the only struct which contains the same pointer.
3475 /// Rust functions which take ownership of an object provided via an argument require
3476 /// this to be true and invalidate the object pointed to by inner.
3480 impl Drop for UnsignedChannelAnnouncement {
3481 fn drop(&mut self) {
3482 if self.is_owned && !<*mut nativeUnsignedChannelAnnouncement>::is_null(self.inner) {
3483 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
3487 /// Frees any resources used by the UnsignedChannelAnnouncement, if is_owned is set and inner is non-NULL.
3489 pub extern "C" fn UnsignedChannelAnnouncement_free(this_obj: UnsignedChannelAnnouncement) { }
3491 /// Used only if an object of this type is returned as a trait impl by a method
3492 pub(crate) extern "C" fn UnsignedChannelAnnouncement_free_void(this_ptr: *mut c_void) {
3493 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUnsignedChannelAnnouncement); }
3496 impl UnsignedChannelAnnouncement {
3497 pub(crate) fn get_native_ref(&self) -> &'static nativeUnsignedChannelAnnouncement {
3498 unsafe { &*ObjOps::untweak_ptr(self.inner) }
3500 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUnsignedChannelAnnouncement {
3501 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
3503 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
3504 pub(crate) fn take_inner(mut self) -> *mut nativeUnsignedChannelAnnouncement {
3505 assert!(self.is_owned);
3506 let ret = ObjOps::untweak_ptr(self.inner);
3507 self.inner = core::ptr::null_mut();
3511 /// The advertised channel features
3513 pub extern "C" fn UnsignedChannelAnnouncement_get_features(this_ptr: &UnsignedChannelAnnouncement) -> crate::lightning::ln::features::ChannelFeatures {
3514 let mut inner_val = &mut this_ptr.get_native_mut_ref().features;
3515 crate::lightning::ln::features::ChannelFeatures { inner: unsafe { ObjOps::nonnull_ptr_to_inner((inner_val as *const lightning::ln::features::ChannelFeatures<>) as *mut _) }, is_owned: false }
3517 /// The advertised channel features
3519 pub extern "C" fn UnsignedChannelAnnouncement_set_features(this_ptr: &mut UnsignedChannelAnnouncement, mut val: crate::lightning::ln::features::ChannelFeatures) {
3520 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.features = *unsafe { Box::from_raw(val.take_inner()) };
3522 /// The genesis hash of the blockchain where the channel is to be opened
3524 pub extern "C" fn UnsignedChannelAnnouncement_get_chain_hash(this_ptr: &UnsignedChannelAnnouncement) -> *const [u8; 32] {
3525 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
3526 inner_val.as_inner()
3528 /// The genesis hash of the blockchain where the channel is to be opened
3530 pub extern "C" fn UnsignedChannelAnnouncement_set_chain_hash(this_ptr: &mut UnsignedChannelAnnouncement, mut val: crate::c_types::ThirtyTwoBytes) {
3531 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
3533 /// The short channel ID
3535 pub extern "C" fn UnsignedChannelAnnouncement_get_short_channel_id(this_ptr: &UnsignedChannelAnnouncement) -> u64 {
3536 let mut inner_val = &mut this_ptr.get_native_mut_ref().short_channel_id;
3539 /// The short channel ID
3541 pub extern "C" fn UnsignedChannelAnnouncement_set_short_channel_id(this_ptr: &mut UnsignedChannelAnnouncement, mut val: u64) {
3542 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.short_channel_id = val;
3544 /// One of the two node_ids which are endpoints of this channel
3546 pub extern "C" fn UnsignedChannelAnnouncement_get_node_id_1(this_ptr: &UnsignedChannelAnnouncement) -> crate::c_types::PublicKey {
3547 let mut inner_val = &mut this_ptr.get_native_mut_ref().node_id_1;
3548 crate::c_types::PublicKey::from_rust(&inner_val)
3550 /// One of the two node_ids which are endpoints of this channel
3552 pub extern "C" fn UnsignedChannelAnnouncement_set_node_id_1(this_ptr: &mut UnsignedChannelAnnouncement, mut val: crate::c_types::PublicKey) {
3553 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.node_id_1 = val.into_rust();
3555 /// The other of the two node_ids which are endpoints of this channel
3557 pub extern "C" fn UnsignedChannelAnnouncement_get_node_id_2(this_ptr: &UnsignedChannelAnnouncement) -> crate::c_types::PublicKey {
3558 let mut inner_val = &mut this_ptr.get_native_mut_ref().node_id_2;
3559 crate::c_types::PublicKey::from_rust(&inner_val)
3561 /// The other of the two node_ids which are endpoints of this channel
3563 pub extern "C" fn UnsignedChannelAnnouncement_set_node_id_2(this_ptr: &mut UnsignedChannelAnnouncement, mut val: crate::c_types::PublicKey) {
3564 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.node_id_2 = val.into_rust();
3566 /// The funding key for the first node
3568 pub extern "C" fn UnsignedChannelAnnouncement_get_bitcoin_key_1(this_ptr: &UnsignedChannelAnnouncement) -> crate::c_types::PublicKey {
3569 let mut inner_val = &mut this_ptr.get_native_mut_ref().bitcoin_key_1;
3570 crate::c_types::PublicKey::from_rust(&inner_val)
3572 /// The funding key for the first node
3574 pub extern "C" fn UnsignedChannelAnnouncement_set_bitcoin_key_1(this_ptr: &mut UnsignedChannelAnnouncement, mut val: crate::c_types::PublicKey) {
3575 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.bitcoin_key_1 = val.into_rust();
3577 /// The funding key for the second node
3579 pub extern "C" fn UnsignedChannelAnnouncement_get_bitcoin_key_2(this_ptr: &UnsignedChannelAnnouncement) -> crate::c_types::PublicKey {
3580 let mut inner_val = &mut this_ptr.get_native_mut_ref().bitcoin_key_2;
3581 crate::c_types::PublicKey::from_rust(&inner_val)
3583 /// The funding key for the second node
3585 pub extern "C" fn UnsignedChannelAnnouncement_set_bitcoin_key_2(this_ptr: &mut UnsignedChannelAnnouncement, mut val: crate::c_types::PublicKey) {
3586 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.bitcoin_key_2 = val.into_rust();
3588 impl Clone for UnsignedChannelAnnouncement {
3589 fn clone(&self) -> Self {
3591 inner: if <*mut nativeUnsignedChannelAnnouncement>::is_null(self.inner) { core::ptr::null_mut() } else {
3592 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
3598 /// Used only if an object of this type is returned as a trait impl by a method
3599 pub(crate) extern "C" fn UnsignedChannelAnnouncement_clone_void(this_ptr: *const c_void) -> *mut c_void {
3600 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUnsignedChannelAnnouncement)).clone() })) as *mut c_void
3603 /// Creates a copy of the UnsignedChannelAnnouncement
3604 pub extern "C" fn UnsignedChannelAnnouncement_clone(orig: &UnsignedChannelAnnouncement) -> UnsignedChannelAnnouncement {
3608 use lightning::ln::msgs::ChannelAnnouncement as nativeChannelAnnouncementImport;
3609 pub(crate) type nativeChannelAnnouncement = nativeChannelAnnouncementImport;
3611 /// A channel_announcement message to be sent or received from a peer
3614 pub struct ChannelAnnouncement {
3615 /// A pointer to the opaque Rust object.
3617 /// Nearly everywhere, inner must be non-null, however in places where
3618 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
3619 pub inner: *mut nativeChannelAnnouncement,
3620 /// Indicates that this is the only struct which contains the same pointer.
3622 /// Rust functions which take ownership of an object provided via an argument require
3623 /// this to be true and invalidate the object pointed to by inner.
3627 impl Drop for ChannelAnnouncement {
3628 fn drop(&mut self) {
3629 if self.is_owned && !<*mut nativeChannelAnnouncement>::is_null(self.inner) {
3630 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
3634 /// Frees any resources used by the ChannelAnnouncement, if is_owned is set and inner is non-NULL.
3636 pub extern "C" fn ChannelAnnouncement_free(this_obj: ChannelAnnouncement) { }
3638 /// Used only if an object of this type is returned as a trait impl by a method
3639 pub(crate) extern "C" fn ChannelAnnouncement_free_void(this_ptr: *mut c_void) {
3640 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeChannelAnnouncement); }
3643 impl ChannelAnnouncement {
3644 pub(crate) fn get_native_ref(&self) -> &'static nativeChannelAnnouncement {
3645 unsafe { &*ObjOps::untweak_ptr(self.inner) }
3647 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeChannelAnnouncement {
3648 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
3650 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
3651 pub(crate) fn take_inner(mut self) -> *mut nativeChannelAnnouncement {
3652 assert!(self.is_owned);
3653 let ret = ObjOps::untweak_ptr(self.inner);
3654 self.inner = core::ptr::null_mut();
3658 /// Authentication of the announcement by the first public node
3660 pub extern "C" fn ChannelAnnouncement_get_node_signature_1(this_ptr: &ChannelAnnouncement) -> crate::c_types::Signature {
3661 let mut inner_val = &mut this_ptr.get_native_mut_ref().node_signature_1;
3662 crate::c_types::Signature::from_rust(&inner_val)
3664 /// Authentication of the announcement by the first public node
3666 pub extern "C" fn ChannelAnnouncement_set_node_signature_1(this_ptr: &mut ChannelAnnouncement, mut val: crate::c_types::Signature) {
3667 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.node_signature_1 = val.into_rust();
3669 /// Authentication of the announcement by the second public node
3671 pub extern "C" fn ChannelAnnouncement_get_node_signature_2(this_ptr: &ChannelAnnouncement) -> crate::c_types::Signature {
3672 let mut inner_val = &mut this_ptr.get_native_mut_ref().node_signature_2;
3673 crate::c_types::Signature::from_rust(&inner_val)
3675 /// Authentication of the announcement by the second public node
3677 pub extern "C" fn ChannelAnnouncement_set_node_signature_2(this_ptr: &mut ChannelAnnouncement, mut val: crate::c_types::Signature) {
3678 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.node_signature_2 = val.into_rust();
3680 /// Proof of funding UTXO ownership by the first public node
3682 pub extern "C" fn ChannelAnnouncement_get_bitcoin_signature_1(this_ptr: &ChannelAnnouncement) -> crate::c_types::Signature {
3683 let mut inner_val = &mut this_ptr.get_native_mut_ref().bitcoin_signature_1;
3684 crate::c_types::Signature::from_rust(&inner_val)
3686 /// Proof of funding UTXO ownership by the first public node
3688 pub extern "C" fn ChannelAnnouncement_set_bitcoin_signature_1(this_ptr: &mut ChannelAnnouncement, mut val: crate::c_types::Signature) {
3689 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.bitcoin_signature_1 = val.into_rust();
3691 /// Proof of funding UTXO ownership by the second public node
3693 pub extern "C" fn ChannelAnnouncement_get_bitcoin_signature_2(this_ptr: &ChannelAnnouncement) -> crate::c_types::Signature {
3694 let mut inner_val = &mut this_ptr.get_native_mut_ref().bitcoin_signature_2;
3695 crate::c_types::Signature::from_rust(&inner_val)
3697 /// Proof of funding UTXO ownership by the second public node
3699 pub extern "C" fn ChannelAnnouncement_set_bitcoin_signature_2(this_ptr: &mut ChannelAnnouncement, mut val: crate::c_types::Signature) {
3700 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.bitcoin_signature_2 = val.into_rust();
3702 /// The actual announcement
3704 pub extern "C" fn ChannelAnnouncement_get_contents(this_ptr: &ChannelAnnouncement) -> crate::lightning::ln::msgs::UnsignedChannelAnnouncement {
3705 let mut inner_val = &mut this_ptr.get_native_mut_ref().contents;
3706 crate::lightning::ln::msgs::UnsignedChannelAnnouncement { inner: unsafe { ObjOps::nonnull_ptr_to_inner((inner_val as *const lightning::ln::msgs::UnsignedChannelAnnouncement<>) as *mut _) }, is_owned: false }
3708 /// The actual announcement
3710 pub extern "C" fn ChannelAnnouncement_set_contents(this_ptr: &mut ChannelAnnouncement, mut val: crate::lightning::ln::msgs::UnsignedChannelAnnouncement) {
3711 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.contents = *unsafe { Box::from_raw(val.take_inner()) };
3713 /// Constructs a new ChannelAnnouncement given each field
3716 pub extern "C" fn ChannelAnnouncement_new(mut node_signature_1_arg: crate::c_types::Signature, mut node_signature_2_arg: crate::c_types::Signature, mut bitcoin_signature_1_arg: crate::c_types::Signature, mut bitcoin_signature_2_arg: crate::c_types::Signature, mut contents_arg: crate::lightning::ln::msgs::UnsignedChannelAnnouncement) -> ChannelAnnouncement {
3717 ChannelAnnouncement { inner: ObjOps::heap_alloc(nativeChannelAnnouncement {
3718 node_signature_1: node_signature_1_arg.into_rust(),
3719 node_signature_2: node_signature_2_arg.into_rust(),
3720 bitcoin_signature_1: bitcoin_signature_1_arg.into_rust(),
3721 bitcoin_signature_2: bitcoin_signature_2_arg.into_rust(),
3722 contents: *unsafe { Box::from_raw(contents_arg.take_inner()) },
3723 }), is_owned: true }
3725 impl Clone for ChannelAnnouncement {
3726 fn clone(&self) -> Self {
3728 inner: if <*mut nativeChannelAnnouncement>::is_null(self.inner) { core::ptr::null_mut() } else {
3729 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
3735 /// Used only if an object of this type is returned as a trait impl by a method
3736 pub(crate) extern "C" fn ChannelAnnouncement_clone_void(this_ptr: *const c_void) -> *mut c_void {
3737 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeChannelAnnouncement)).clone() })) as *mut c_void
3740 /// Creates a copy of the ChannelAnnouncement
3741 pub extern "C" fn ChannelAnnouncement_clone(orig: &ChannelAnnouncement) -> ChannelAnnouncement {
3745 use lightning::ln::msgs::UnsignedChannelUpdate as nativeUnsignedChannelUpdateImport;
3746 pub(crate) type nativeUnsignedChannelUpdate = nativeUnsignedChannelUpdateImport;
3748 /// The unsigned part of a channel_update
3751 pub struct UnsignedChannelUpdate {
3752 /// A pointer to the opaque Rust object.
3754 /// Nearly everywhere, inner must be non-null, however in places where
3755 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
3756 pub inner: *mut nativeUnsignedChannelUpdate,
3757 /// Indicates that this is the only struct which contains the same pointer.
3759 /// Rust functions which take ownership of an object provided via an argument require
3760 /// this to be true and invalidate the object pointed to by inner.
3764 impl Drop for UnsignedChannelUpdate {
3765 fn drop(&mut self) {
3766 if self.is_owned && !<*mut nativeUnsignedChannelUpdate>::is_null(self.inner) {
3767 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
3771 /// Frees any resources used by the UnsignedChannelUpdate, if is_owned is set and inner is non-NULL.
3773 pub extern "C" fn UnsignedChannelUpdate_free(this_obj: UnsignedChannelUpdate) { }
3775 /// Used only if an object of this type is returned as a trait impl by a method
3776 pub(crate) extern "C" fn UnsignedChannelUpdate_free_void(this_ptr: *mut c_void) {
3777 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeUnsignedChannelUpdate); }
3780 impl UnsignedChannelUpdate {
3781 pub(crate) fn get_native_ref(&self) -> &'static nativeUnsignedChannelUpdate {
3782 unsafe { &*ObjOps::untweak_ptr(self.inner) }
3784 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeUnsignedChannelUpdate {
3785 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
3787 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
3788 pub(crate) fn take_inner(mut self) -> *mut nativeUnsignedChannelUpdate {
3789 assert!(self.is_owned);
3790 let ret = ObjOps::untweak_ptr(self.inner);
3791 self.inner = core::ptr::null_mut();
3795 /// The genesis hash of the blockchain where the channel is to be opened
3797 pub extern "C" fn UnsignedChannelUpdate_get_chain_hash(this_ptr: &UnsignedChannelUpdate) -> *const [u8; 32] {
3798 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
3799 inner_val.as_inner()
3801 /// The genesis hash of the blockchain where the channel is to be opened
3803 pub extern "C" fn UnsignedChannelUpdate_set_chain_hash(this_ptr: &mut UnsignedChannelUpdate, mut val: crate::c_types::ThirtyTwoBytes) {
3804 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
3806 /// The short channel ID
3808 pub extern "C" fn UnsignedChannelUpdate_get_short_channel_id(this_ptr: &UnsignedChannelUpdate) -> u64 {
3809 let mut inner_val = &mut this_ptr.get_native_mut_ref().short_channel_id;
3812 /// The short channel ID
3814 pub extern "C" fn UnsignedChannelUpdate_set_short_channel_id(this_ptr: &mut UnsignedChannelUpdate, mut val: u64) {
3815 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.short_channel_id = val;
3817 /// A strictly monotonic announcement counter, with gaps allowed, specific to this channel
3819 pub extern "C" fn UnsignedChannelUpdate_get_timestamp(this_ptr: &UnsignedChannelUpdate) -> u32 {
3820 let mut inner_val = &mut this_ptr.get_native_mut_ref().timestamp;
3823 /// A strictly monotonic announcement counter, with gaps allowed, specific to this channel
3825 pub extern "C" fn UnsignedChannelUpdate_set_timestamp(this_ptr: &mut UnsignedChannelUpdate, mut val: u32) {
3826 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.timestamp = val;
3830 pub extern "C" fn UnsignedChannelUpdate_get_flags(this_ptr: &UnsignedChannelUpdate) -> u8 {
3831 let mut inner_val = &mut this_ptr.get_native_mut_ref().flags;
3836 pub extern "C" fn UnsignedChannelUpdate_set_flags(this_ptr: &mut UnsignedChannelUpdate, mut val: u8) {
3837 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.flags = val;
3839 /// The number of blocks such that if:
3840 /// `incoming_htlc.cltv_expiry < outgoing_htlc.cltv_expiry + cltv_expiry_delta`
3841 /// then we need to fail the HTLC backwards. When forwarding an HTLC, cltv_expiry_delta determines
3842 /// the outgoing HTLC's minimum cltv_expiry value -- so, if an incoming HTLC comes in with a
3843 /// cltv_expiry of 100000, and the node we're forwarding to has a cltv_expiry_delta value of 10,
3844 /// then we'll check that the outgoing HTLC's cltv_expiry value is at least 100010 before
3845 /// forwarding. Note that the HTLC sender is the one who originally sets this value when
3846 /// constructing the route.
3848 pub extern "C" fn UnsignedChannelUpdate_get_cltv_expiry_delta(this_ptr: &UnsignedChannelUpdate) -> u16 {
3849 let mut inner_val = &mut this_ptr.get_native_mut_ref().cltv_expiry_delta;
3852 /// The number of blocks such that if:
3853 /// `incoming_htlc.cltv_expiry < outgoing_htlc.cltv_expiry + cltv_expiry_delta`
3854 /// then we need to fail the HTLC backwards. When forwarding an HTLC, cltv_expiry_delta determines
3855 /// the outgoing HTLC's minimum cltv_expiry value -- so, if an incoming HTLC comes in with a
3856 /// cltv_expiry of 100000, and the node we're forwarding to has a cltv_expiry_delta value of 10,
3857 /// then we'll check that the outgoing HTLC's cltv_expiry value is at least 100010 before
3858 /// forwarding. Note that the HTLC sender is the one who originally sets this value when
3859 /// constructing the route.
3861 pub extern "C" fn UnsignedChannelUpdate_set_cltv_expiry_delta(this_ptr: &mut UnsignedChannelUpdate, mut val: u16) {
3862 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.cltv_expiry_delta = val;
3864 /// The minimum HTLC size incoming to sender, in milli-satoshi
3866 pub extern "C" fn UnsignedChannelUpdate_get_htlc_minimum_msat(this_ptr: &UnsignedChannelUpdate) -> u64 {
3867 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_minimum_msat;
3870 /// The minimum HTLC size incoming to sender, in milli-satoshi
3872 pub extern "C" fn UnsignedChannelUpdate_set_htlc_minimum_msat(this_ptr: &mut UnsignedChannelUpdate, mut val: u64) {
3873 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_minimum_msat = val;
3875 /// The maximum HTLC value incoming to sender, in milli-satoshi. Used to be optional.
3877 pub extern "C" fn UnsignedChannelUpdate_get_htlc_maximum_msat(this_ptr: &UnsignedChannelUpdate) -> u64 {
3878 let mut inner_val = &mut this_ptr.get_native_mut_ref().htlc_maximum_msat;
3881 /// The maximum HTLC value incoming to sender, in milli-satoshi. Used to be optional.
3883 pub extern "C" fn UnsignedChannelUpdate_set_htlc_maximum_msat(this_ptr: &mut UnsignedChannelUpdate, mut val: u64) {
3884 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.htlc_maximum_msat = val;
3886 /// The base HTLC fee charged by sender, in milli-satoshi
3888 pub extern "C" fn UnsignedChannelUpdate_get_fee_base_msat(this_ptr: &UnsignedChannelUpdate) -> u32 {
3889 let mut inner_val = &mut this_ptr.get_native_mut_ref().fee_base_msat;
3892 /// The base HTLC fee charged by sender, in milli-satoshi
3894 pub extern "C" fn UnsignedChannelUpdate_set_fee_base_msat(this_ptr: &mut UnsignedChannelUpdate, mut val: u32) {
3895 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.fee_base_msat = val;
3897 /// The amount to fee multiplier, in micro-satoshi
3899 pub extern "C" fn UnsignedChannelUpdate_get_fee_proportional_millionths(this_ptr: &UnsignedChannelUpdate) -> u32 {
3900 let mut inner_val = &mut this_ptr.get_native_mut_ref().fee_proportional_millionths;
3903 /// The amount to fee multiplier, in micro-satoshi
3905 pub extern "C" fn UnsignedChannelUpdate_set_fee_proportional_millionths(this_ptr: &mut UnsignedChannelUpdate, mut val: u32) {
3906 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.fee_proportional_millionths = val;
3908 /// Excess data which was signed as a part of the message which we do not (yet) understand how
3909 /// to decode. This is stored to ensure forward-compatibility as new fields are added to the
3910 /// lightning gossip
3912 pub extern "C" fn UnsignedChannelUpdate_set_excess_data(this_ptr: &mut UnsignedChannelUpdate, mut val: crate::c_types::derived::CVec_u8Z) {
3913 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { item }); };
3914 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.excess_data = local_val;
3916 /// Constructs a new UnsignedChannelUpdate given each field
3919 pub extern "C" fn UnsignedChannelUpdate_new(mut chain_hash_arg: crate::c_types::ThirtyTwoBytes, mut short_channel_id_arg: u64, mut timestamp_arg: u32, mut flags_arg: u8, mut cltv_expiry_delta_arg: u16, mut htlc_minimum_msat_arg: u64, mut htlc_maximum_msat_arg: u64, mut fee_base_msat_arg: u32, mut fee_proportional_millionths_arg: u32, mut excess_data_arg: crate::c_types::derived::CVec_u8Z) -> UnsignedChannelUpdate {
3920 let mut local_excess_data_arg = Vec::new(); for mut item in excess_data_arg.into_rust().drain(..) { local_excess_data_arg.push( { item }); };
3921 UnsignedChannelUpdate { inner: ObjOps::heap_alloc(nativeUnsignedChannelUpdate {
3922 chain_hash: ::bitcoin::hash_types::BlockHash::from_slice(&chain_hash_arg.data[..]).unwrap(),
3923 short_channel_id: short_channel_id_arg,
3924 timestamp: timestamp_arg,
3926 cltv_expiry_delta: cltv_expiry_delta_arg,
3927 htlc_minimum_msat: htlc_minimum_msat_arg,
3928 htlc_maximum_msat: htlc_maximum_msat_arg,
3929 fee_base_msat: fee_base_msat_arg,
3930 fee_proportional_millionths: fee_proportional_millionths_arg,
3931 excess_data: local_excess_data_arg,
3932 }), is_owned: true }
3934 impl Clone for UnsignedChannelUpdate {
3935 fn clone(&self) -> Self {
3937 inner: if <*mut nativeUnsignedChannelUpdate>::is_null(self.inner) { core::ptr::null_mut() } else {
3938 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
3944 /// Used only if an object of this type is returned as a trait impl by a method
3945 pub(crate) extern "C" fn UnsignedChannelUpdate_clone_void(this_ptr: *const c_void) -> *mut c_void {
3946 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeUnsignedChannelUpdate)).clone() })) as *mut c_void
3949 /// Creates a copy of the UnsignedChannelUpdate
3950 pub extern "C" fn UnsignedChannelUpdate_clone(orig: &UnsignedChannelUpdate) -> UnsignedChannelUpdate {
3954 use lightning::ln::msgs::ChannelUpdate as nativeChannelUpdateImport;
3955 pub(crate) type nativeChannelUpdate = nativeChannelUpdateImport;
3957 /// A channel_update message to be sent or received from a peer
3960 pub struct ChannelUpdate {
3961 /// A pointer to the opaque Rust object.
3963 /// Nearly everywhere, inner must be non-null, however in places where
3964 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
3965 pub inner: *mut nativeChannelUpdate,
3966 /// Indicates that this is the only struct which contains the same pointer.
3968 /// Rust functions which take ownership of an object provided via an argument require
3969 /// this to be true and invalidate the object pointed to by inner.
3973 impl Drop for ChannelUpdate {
3974 fn drop(&mut self) {
3975 if self.is_owned && !<*mut nativeChannelUpdate>::is_null(self.inner) {
3976 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
3980 /// Frees any resources used by the ChannelUpdate, if is_owned is set and inner is non-NULL.
3982 pub extern "C" fn ChannelUpdate_free(this_obj: ChannelUpdate) { }
3984 /// Used only if an object of this type is returned as a trait impl by a method
3985 pub(crate) extern "C" fn ChannelUpdate_free_void(this_ptr: *mut c_void) {
3986 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeChannelUpdate); }
3989 impl ChannelUpdate {
3990 pub(crate) fn get_native_ref(&self) -> &'static nativeChannelUpdate {
3991 unsafe { &*ObjOps::untweak_ptr(self.inner) }
3993 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeChannelUpdate {
3994 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
3996 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
3997 pub(crate) fn take_inner(mut self) -> *mut nativeChannelUpdate {
3998 assert!(self.is_owned);
3999 let ret = ObjOps::untweak_ptr(self.inner);
4000 self.inner = core::ptr::null_mut();
4004 /// A signature of the channel update
4006 pub extern "C" fn ChannelUpdate_get_signature(this_ptr: &ChannelUpdate) -> crate::c_types::Signature {
4007 let mut inner_val = &mut this_ptr.get_native_mut_ref().signature;
4008 crate::c_types::Signature::from_rust(&inner_val)
4010 /// A signature of the channel update
4012 pub extern "C" fn ChannelUpdate_set_signature(this_ptr: &mut ChannelUpdate, mut val: crate::c_types::Signature) {
4013 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.signature = val.into_rust();
4015 /// The actual channel update
4017 pub extern "C" fn ChannelUpdate_get_contents(this_ptr: &ChannelUpdate) -> crate::lightning::ln::msgs::UnsignedChannelUpdate {
4018 let mut inner_val = &mut this_ptr.get_native_mut_ref().contents;
4019 crate::lightning::ln::msgs::UnsignedChannelUpdate { inner: unsafe { ObjOps::nonnull_ptr_to_inner((inner_val as *const lightning::ln::msgs::UnsignedChannelUpdate<>) as *mut _) }, is_owned: false }
4021 /// The actual channel update
4023 pub extern "C" fn ChannelUpdate_set_contents(this_ptr: &mut ChannelUpdate, mut val: crate::lightning::ln::msgs::UnsignedChannelUpdate) {
4024 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.contents = *unsafe { Box::from_raw(val.take_inner()) };
4026 /// Constructs a new ChannelUpdate given each field
4029 pub extern "C" fn ChannelUpdate_new(mut signature_arg: crate::c_types::Signature, mut contents_arg: crate::lightning::ln::msgs::UnsignedChannelUpdate) -> ChannelUpdate {
4030 ChannelUpdate { inner: ObjOps::heap_alloc(nativeChannelUpdate {
4031 signature: signature_arg.into_rust(),
4032 contents: *unsafe { Box::from_raw(contents_arg.take_inner()) },
4033 }), is_owned: true }
4035 impl Clone for ChannelUpdate {
4036 fn clone(&self) -> Self {
4038 inner: if <*mut nativeChannelUpdate>::is_null(self.inner) { core::ptr::null_mut() } else {
4039 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
4045 /// Used only if an object of this type is returned as a trait impl by a method
4046 pub(crate) extern "C" fn ChannelUpdate_clone_void(this_ptr: *const c_void) -> *mut c_void {
4047 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeChannelUpdate)).clone() })) as *mut c_void
4050 /// Creates a copy of the ChannelUpdate
4051 pub extern "C" fn ChannelUpdate_clone(orig: &ChannelUpdate) -> ChannelUpdate {
4055 use lightning::ln::msgs::QueryChannelRange as nativeQueryChannelRangeImport;
4056 pub(crate) type nativeQueryChannelRange = nativeQueryChannelRangeImport;
4058 /// A query_channel_range message is used to query a peer for channel
4059 /// UTXOs in a range of blocks. The recipient of a query makes a best
4060 /// effort to reply to the query using one or more reply_channel_range
4064 pub struct QueryChannelRange {
4065 /// A pointer to the opaque Rust object.
4067 /// Nearly everywhere, inner must be non-null, however in places where
4068 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
4069 pub inner: *mut nativeQueryChannelRange,
4070 /// Indicates that this is the only struct which contains the same pointer.
4072 /// Rust functions which take ownership of an object provided via an argument require
4073 /// this to be true and invalidate the object pointed to by inner.
4077 impl Drop for QueryChannelRange {
4078 fn drop(&mut self) {
4079 if self.is_owned && !<*mut nativeQueryChannelRange>::is_null(self.inner) {
4080 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
4084 /// Frees any resources used by the QueryChannelRange, if is_owned is set and inner is non-NULL.
4086 pub extern "C" fn QueryChannelRange_free(this_obj: QueryChannelRange) { }
4088 /// Used only if an object of this type is returned as a trait impl by a method
4089 pub(crate) extern "C" fn QueryChannelRange_free_void(this_ptr: *mut c_void) {
4090 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeQueryChannelRange); }
4093 impl QueryChannelRange {
4094 pub(crate) fn get_native_ref(&self) -> &'static nativeQueryChannelRange {
4095 unsafe { &*ObjOps::untweak_ptr(self.inner) }
4097 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeQueryChannelRange {
4098 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
4100 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
4101 pub(crate) fn take_inner(mut self) -> *mut nativeQueryChannelRange {
4102 assert!(self.is_owned);
4103 let ret = ObjOps::untweak_ptr(self.inner);
4104 self.inner = core::ptr::null_mut();
4108 /// The genesis hash of the blockchain being queried
4110 pub extern "C" fn QueryChannelRange_get_chain_hash(this_ptr: &QueryChannelRange) -> *const [u8; 32] {
4111 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
4112 inner_val.as_inner()
4114 /// The genesis hash of the blockchain being queried
4116 pub extern "C" fn QueryChannelRange_set_chain_hash(this_ptr: &mut QueryChannelRange, mut val: crate::c_types::ThirtyTwoBytes) {
4117 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
4119 /// The height of the first block for the channel UTXOs being queried
4121 pub extern "C" fn QueryChannelRange_get_first_blocknum(this_ptr: &QueryChannelRange) -> u32 {
4122 let mut inner_val = &mut this_ptr.get_native_mut_ref().first_blocknum;
4125 /// The height of the first block for the channel UTXOs being queried
4127 pub extern "C" fn QueryChannelRange_set_first_blocknum(this_ptr: &mut QueryChannelRange, mut val: u32) {
4128 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.first_blocknum = val;
4130 /// The number of blocks to include in the query results
4132 pub extern "C" fn QueryChannelRange_get_number_of_blocks(this_ptr: &QueryChannelRange) -> u32 {
4133 let mut inner_val = &mut this_ptr.get_native_mut_ref().number_of_blocks;
4136 /// The number of blocks to include in the query results
4138 pub extern "C" fn QueryChannelRange_set_number_of_blocks(this_ptr: &mut QueryChannelRange, mut val: u32) {
4139 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.number_of_blocks = val;
4141 /// Constructs a new QueryChannelRange given each field
4144 pub extern "C" fn QueryChannelRange_new(mut chain_hash_arg: crate::c_types::ThirtyTwoBytes, mut first_blocknum_arg: u32, mut number_of_blocks_arg: u32) -> QueryChannelRange {
4145 QueryChannelRange { inner: ObjOps::heap_alloc(nativeQueryChannelRange {
4146 chain_hash: ::bitcoin::hash_types::BlockHash::from_slice(&chain_hash_arg.data[..]).unwrap(),
4147 first_blocknum: first_blocknum_arg,
4148 number_of_blocks: number_of_blocks_arg,
4149 }), is_owned: true }
4151 impl Clone for QueryChannelRange {
4152 fn clone(&self) -> Self {
4154 inner: if <*mut nativeQueryChannelRange>::is_null(self.inner) { core::ptr::null_mut() } else {
4155 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
4161 /// Used only if an object of this type is returned as a trait impl by a method
4162 pub(crate) extern "C" fn QueryChannelRange_clone_void(this_ptr: *const c_void) -> *mut c_void {
4163 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeQueryChannelRange)).clone() })) as *mut c_void
4166 /// Creates a copy of the QueryChannelRange
4167 pub extern "C" fn QueryChannelRange_clone(orig: &QueryChannelRange) -> QueryChannelRange {
4171 use lightning::ln::msgs::ReplyChannelRange as nativeReplyChannelRangeImport;
4172 pub(crate) type nativeReplyChannelRange = nativeReplyChannelRangeImport;
4174 /// A reply_channel_range message is a reply to a query_channel_range
4175 /// message. Multiple reply_channel_range messages can be sent in reply
4176 /// to a single query_channel_range message. The query recipient makes a
4177 /// best effort to respond based on their local network view which may
4178 /// not be a perfect view of the network. The short_channel_ids in the
4179 /// reply are encoded. We only support encoding_type=0 uncompressed
4180 /// serialization and do not support encoding_type=1 zlib serialization.
4183 pub struct ReplyChannelRange {
4184 /// A pointer to the opaque Rust object.
4186 /// Nearly everywhere, inner must be non-null, however in places where
4187 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
4188 pub inner: *mut nativeReplyChannelRange,
4189 /// Indicates that this is the only struct which contains the same pointer.
4191 /// Rust functions which take ownership of an object provided via an argument require
4192 /// this to be true and invalidate the object pointed to by inner.
4196 impl Drop for ReplyChannelRange {
4197 fn drop(&mut self) {
4198 if self.is_owned && !<*mut nativeReplyChannelRange>::is_null(self.inner) {
4199 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
4203 /// Frees any resources used by the ReplyChannelRange, if is_owned is set and inner is non-NULL.
4205 pub extern "C" fn ReplyChannelRange_free(this_obj: ReplyChannelRange) { }
4207 /// Used only if an object of this type is returned as a trait impl by a method
4208 pub(crate) extern "C" fn ReplyChannelRange_free_void(this_ptr: *mut c_void) {
4209 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeReplyChannelRange); }
4212 impl ReplyChannelRange {
4213 pub(crate) fn get_native_ref(&self) -> &'static nativeReplyChannelRange {
4214 unsafe { &*ObjOps::untweak_ptr(self.inner) }
4216 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeReplyChannelRange {
4217 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
4219 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
4220 pub(crate) fn take_inner(mut self) -> *mut nativeReplyChannelRange {
4221 assert!(self.is_owned);
4222 let ret = ObjOps::untweak_ptr(self.inner);
4223 self.inner = core::ptr::null_mut();
4227 /// The genesis hash of the blockchain being queried
4229 pub extern "C" fn ReplyChannelRange_get_chain_hash(this_ptr: &ReplyChannelRange) -> *const [u8; 32] {
4230 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
4231 inner_val.as_inner()
4233 /// The genesis hash of the blockchain being queried
4235 pub extern "C" fn ReplyChannelRange_set_chain_hash(this_ptr: &mut ReplyChannelRange, mut val: crate::c_types::ThirtyTwoBytes) {
4236 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
4238 /// The height of the first block in the range of the reply
4240 pub extern "C" fn ReplyChannelRange_get_first_blocknum(this_ptr: &ReplyChannelRange) -> u32 {
4241 let mut inner_val = &mut this_ptr.get_native_mut_ref().first_blocknum;
4244 /// The height of the first block in the range of the reply
4246 pub extern "C" fn ReplyChannelRange_set_first_blocknum(this_ptr: &mut ReplyChannelRange, mut val: u32) {
4247 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.first_blocknum = val;
4249 /// The number of blocks included in the range of the reply
4251 pub extern "C" fn ReplyChannelRange_get_number_of_blocks(this_ptr: &ReplyChannelRange) -> u32 {
4252 let mut inner_val = &mut this_ptr.get_native_mut_ref().number_of_blocks;
4255 /// The number of blocks included in the range of the reply
4257 pub extern "C" fn ReplyChannelRange_set_number_of_blocks(this_ptr: &mut ReplyChannelRange, mut val: u32) {
4258 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.number_of_blocks = val;
4260 /// True when this is the final reply for a query
4262 pub extern "C" fn ReplyChannelRange_get_sync_complete(this_ptr: &ReplyChannelRange) -> bool {
4263 let mut inner_val = &mut this_ptr.get_native_mut_ref().sync_complete;
4266 /// True when this is the final reply for a query
4268 pub extern "C" fn ReplyChannelRange_set_sync_complete(this_ptr: &mut ReplyChannelRange, mut val: bool) {
4269 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.sync_complete = val;
4271 /// The short_channel_ids in the channel range
4273 pub extern "C" fn ReplyChannelRange_set_short_channel_ids(this_ptr: &mut ReplyChannelRange, mut val: crate::c_types::derived::CVec_u64Z) {
4274 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { item }); };
4275 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.short_channel_ids = local_val;
4277 /// Constructs a new ReplyChannelRange given each field
4280 pub extern "C" fn ReplyChannelRange_new(mut chain_hash_arg: crate::c_types::ThirtyTwoBytes, mut first_blocknum_arg: u32, mut number_of_blocks_arg: u32, mut sync_complete_arg: bool, mut short_channel_ids_arg: crate::c_types::derived::CVec_u64Z) -> ReplyChannelRange {
4281 let mut local_short_channel_ids_arg = Vec::new(); for mut item in short_channel_ids_arg.into_rust().drain(..) { local_short_channel_ids_arg.push( { item }); };
4282 ReplyChannelRange { inner: ObjOps::heap_alloc(nativeReplyChannelRange {
4283 chain_hash: ::bitcoin::hash_types::BlockHash::from_slice(&chain_hash_arg.data[..]).unwrap(),
4284 first_blocknum: first_blocknum_arg,
4285 number_of_blocks: number_of_blocks_arg,
4286 sync_complete: sync_complete_arg,
4287 short_channel_ids: local_short_channel_ids_arg,
4288 }), is_owned: true }
4290 impl Clone for ReplyChannelRange {
4291 fn clone(&self) -> Self {
4293 inner: if <*mut nativeReplyChannelRange>::is_null(self.inner) { core::ptr::null_mut() } else {
4294 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
4300 /// Used only if an object of this type is returned as a trait impl by a method
4301 pub(crate) extern "C" fn ReplyChannelRange_clone_void(this_ptr: *const c_void) -> *mut c_void {
4302 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeReplyChannelRange)).clone() })) as *mut c_void
4305 /// Creates a copy of the ReplyChannelRange
4306 pub extern "C" fn ReplyChannelRange_clone(orig: &ReplyChannelRange) -> ReplyChannelRange {
4310 use lightning::ln::msgs::QueryShortChannelIds as nativeQueryShortChannelIdsImport;
4311 pub(crate) type nativeQueryShortChannelIds = nativeQueryShortChannelIdsImport;
4313 /// A query_short_channel_ids message is used to query a peer for
4314 /// routing gossip messages related to one or more short_channel_ids.
4315 /// The query recipient will reply with the latest, if available,
4316 /// channel_announcement, channel_update and node_announcement messages
4317 /// it maintains for the requested short_channel_ids followed by a
4318 /// reply_short_channel_ids_end message. The short_channel_ids sent in
4319 /// this query are encoded. We only support encoding_type=0 uncompressed
4320 /// serialization and do not support encoding_type=1 zlib serialization.
4323 pub struct QueryShortChannelIds {
4324 /// A pointer to the opaque Rust object.
4326 /// Nearly everywhere, inner must be non-null, however in places where
4327 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
4328 pub inner: *mut nativeQueryShortChannelIds,
4329 /// Indicates that this is the only struct which contains the same pointer.
4331 /// Rust functions which take ownership of an object provided via an argument require
4332 /// this to be true and invalidate the object pointed to by inner.
4336 impl Drop for QueryShortChannelIds {
4337 fn drop(&mut self) {
4338 if self.is_owned && !<*mut nativeQueryShortChannelIds>::is_null(self.inner) {
4339 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
4343 /// Frees any resources used by the QueryShortChannelIds, if is_owned is set and inner is non-NULL.
4345 pub extern "C" fn QueryShortChannelIds_free(this_obj: QueryShortChannelIds) { }
4347 /// Used only if an object of this type is returned as a trait impl by a method
4348 pub(crate) extern "C" fn QueryShortChannelIds_free_void(this_ptr: *mut c_void) {
4349 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeQueryShortChannelIds); }
4352 impl QueryShortChannelIds {
4353 pub(crate) fn get_native_ref(&self) -> &'static nativeQueryShortChannelIds {
4354 unsafe { &*ObjOps::untweak_ptr(self.inner) }
4356 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeQueryShortChannelIds {
4357 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
4359 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
4360 pub(crate) fn take_inner(mut self) -> *mut nativeQueryShortChannelIds {
4361 assert!(self.is_owned);
4362 let ret = ObjOps::untweak_ptr(self.inner);
4363 self.inner = core::ptr::null_mut();
4367 /// The genesis hash of the blockchain being queried
4369 pub extern "C" fn QueryShortChannelIds_get_chain_hash(this_ptr: &QueryShortChannelIds) -> *const [u8; 32] {
4370 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
4371 inner_val.as_inner()
4373 /// The genesis hash of the blockchain being queried
4375 pub extern "C" fn QueryShortChannelIds_set_chain_hash(this_ptr: &mut QueryShortChannelIds, mut val: crate::c_types::ThirtyTwoBytes) {
4376 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
4378 /// The short_channel_ids that are being queried
4380 pub extern "C" fn QueryShortChannelIds_set_short_channel_ids(this_ptr: &mut QueryShortChannelIds, mut val: crate::c_types::derived::CVec_u64Z) {
4381 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { item }); };
4382 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.short_channel_ids = local_val;
4384 /// Constructs a new QueryShortChannelIds given each field
4387 pub extern "C" fn QueryShortChannelIds_new(mut chain_hash_arg: crate::c_types::ThirtyTwoBytes, mut short_channel_ids_arg: crate::c_types::derived::CVec_u64Z) -> QueryShortChannelIds {
4388 let mut local_short_channel_ids_arg = Vec::new(); for mut item in short_channel_ids_arg.into_rust().drain(..) { local_short_channel_ids_arg.push( { item }); };
4389 QueryShortChannelIds { inner: ObjOps::heap_alloc(nativeQueryShortChannelIds {
4390 chain_hash: ::bitcoin::hash_types::BlockHash::from_slice(&chain_hash_arg.data[..]).unwrap(),
4391 short_channel_ids: local_short_channel_ids_arg,
4392 }), is_owned: true }
4394 impl Clone for QueryShortChannelIds {
4395 fn clone(&self) -> Self {
4397 inner: if <*mut nativeQueryShortChannelIds>::is_null(self.inner) { core::ptr::null_mut() } else {
4398 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
4404 /// Used only if an object of this type is returned as a trait impl by a method
4405 pub(crate) extern "C" fn QueryShortChannelIds_clone_void(this_ptr: *const c_void) -> *mut c_void {
4406 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeQueryShortChannelIds)).clone() })) as *mut c_void
4409 /// Creates a copy of the QueryShortChannelIds
4410 pub extern "C" fn QueryShortChannelIds_clone(orig: &QueryShortChannelIds) -> QueryShortChannelIds {
4414 use lightning::ln::msgs::ReplyShortChannelIdsEnd as nativeReplyShortChannelIdsEndImport;
4415 pub(crate) type nativeReplyShortChannelIdsEnd = nativeReplyShortChannelIdsEndImport;
4417 /// A reply_short_channel_ids_end message is sent as a reply to a
4418 /// query_short_channel_ids message. The query recipient makes a best
4419 /// effort to respond based on their local network view which may not be
4420 /// a perfect view of the network.
4423 pub struct ReplyShortChannelIdsEnd {
4424 /// A pointer to the opaque Rust object.
4426 /// Nearly everywhere, inner must be non-null, however in places where
4427 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
4428 pub inner: *mut nativeReplyShortChannelIdsEnd,
4429 /// Indicates that this is the only struct which contains the same pointer.
4431 /// Rust functions which take ownership of an object provided via an argument require
4432 /// this to be true and invalidate the object pointed to by inner.
4436 impl Drop for ReplyShortChannelIdsEnd {
4437 fn drop(&mut self) {
4438 if self.is_owned && !<*mut nativeReplyShortChannelIdsEnd>::is_null(self.inner) {
4439 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
4443 /// Frees any resources used by the ReplyShortChannelIdsEnd, if is_owned is set and inner is non-NULL.
4445 pub extern "C" fn ReplyShortChannelIdsEnd_free(this_obj: ReplyShortChannelIdsEnd) { }
4447 /// Used only if an object of this type is returned as a trait impl by a method
4448 pub(crate) extern "C" fn ReplyShortChannelIdsEnd_free_void(this_ptr: *mut c_void) {
4449 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeReplyShortChannelIdsEnd); }
4452 impl ReplyShortChannelIdsEnd {
4453 pub(crate) fn get_native_ref(&self) -> &'static nativeReplyShortChannelIdsEnd {
4454 unsafe { &*ObjOps::untweak_ptr(self.inner) }
4456 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeReplyShortChannelIdsEnd {
4457 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
4459 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
4460 pub(crate) fn take_inner(mut self) -> *mut nativeReplyShortChannelIdsEnd {
4461 assert!(self.is_owned);
4462 let ret = ObjOps::untweak_ptr(self.inner);
4463 self.inner = core::ptr::null_mut();
4467 /// The genesis hash of the blockchain that was queried
4469 pub extern "C" fn ReplyShortChannelIdsEnd_get_chain_hash(this_ptr: &ReplyShortChannelIdsEnd) -> *const [u8; 32] {
4470 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
4471 inner_val.as_inner()
4473 /// The genesis hash of the blockchain that was queried
4475 pub extern "C" fn ReplyShortChannelIdsEnd_set_chain_hash(this_ptr: &mut ReplyShortChannelIdsEnd, mut val: crate::c_types::ThirtyTwoBytes) {
4476 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
4478 /// Indicates if the query recipient maintains up-to-date channel
4479 /// information for the chain_hash
4481 pub extern "C" fn ReplyShortChannelIdsEnd_get_full_information(this_ptr: &ReplyShortChannelIdsEnd) -> bool {
4482 let mut inner_val = &mut this_ptr.get_native_mut_ref().full_information;
4485 /// Indicates if the query recipient maintains up-to-date channel
4486 /// information for the chain_hash
4488 pub extern "C" fn ReplyShortChannelIdsEnd_set_full_information(this_ptr: &mut ReplyShortChannelIdsEnd, mut val: bool) {
4489 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.full_information = val;
4491 /// Constructs a new ReplyShortChannelIdsEnd given each field
4494 pub extern "C" fn ReplyShortChannelIdsEnd_new(mut chain_hash_arg: crate::c_types::ThirtyTwoBytes, mut full_information_arg: bool) -> ReplyShortChannelIdsEnd {
4495 ReplyShortChannelIdsEnd { inner: ObjOps::heap_alloc(nativeReplyShortChannelIdsEnd {
4496 chain_hash: ::bitcoin::hash_types::BlockHash::from_slice(&chain_hash_arg.data[..]).unwrap(),
4497 full_information: full_information_arg,
4498 }), is_owned: true }
4500 impl Clone for ReplyShortChannelIdsEnd {
4501 fn clone(&self) -> Self {
4503 inner: if <*mut nativeReplyShortChannelIdsEnd>::is_null(self.inner) { core::ptr::null_mut() } else {
4504 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
4510 /// Used only if an object of this type is returned as a trait impl by a method
4511 pub(crate) extern "C" fn ReplyShortChannelIdsEnd_clone_void(this_ptr: *const c_void) -> *mut c_void {
4512 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeReplyShortChannelIdsEnd)).clone() })) as *mut c_void
4515 /// Creates a copy of the ReplyShortChannelIdsEnd
4516 pub extern "C" fn ReplyShortChannelIdsEnd_clone(orig: &ReplyShortChannelIdsEnd) -> ReplyShortChannelIdsEnd {
4520 use lightning::ln::msgs::GossipTimestampFilter as nativeGossipTimestampFilterImport;
4521 pub(crate) type nativeGossipTimestampFilter = nativeGossipTimestampFilterImport;
4523 /// A gossip_timestamp_filter message is used by a node to request
4524 /// gossip relay for messages in the requested time range when the
4525 /// gossip_queries feature has been negotiated.
4528 pub struct GossipTimestampFilter {
4529 /// A pointer to the opaque Rust object.
4531 /// Nearly everywhere, inner must be non-null, however in places where
4532 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
4533 pub inner: *mut nativeGossipTimestampFilter,
4534 /// Indicates that this is the only struct which contains the same pointer.
4536 /// Rust functions which take ownership of an object provided via an argument require
4537 /// this to be true and invalidate the object pointed to by inner.
4541 impl Drop for GossipTimestampFilter {
4542 fn drop(&mut self) {
4543 if self.is_owned && !<*mut nativeGossipTimestampFilter>::is_null(self.inner) {
4544 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
4548 /// Frees any resources used by the GossipTimestampFilter, if is_owned is set and inner is non-NULL.
4550 pub extern "C" fn GossipTimestampFilter_free(this_obj: GossipTimestampFilter) { }
4552 /// Used only if an object of this type is returned as a trait impl by a method
4553 pub(crate) extern "C" fn GossipTimestampFilter_free_void(this_ptr: *mut c_void) {
4554 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeGossipTimestampFilter); }
4557 impl GossipTimestampFilter {
4558 pub(crate) fn get_native_ref(&self) -> &'static nativeGossipTimestampFilter {
4559 unsafe { &*ObjOps::untweak_ptr(self.inner) }
4561 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeGossipTimestampFilter {
4562 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
4564 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
4565 pub(crate) fn take_inner(mut self) -> *mut nativeGossipTimestampFilter {
4566 assert!(self.is_owned);
4567 let ret = ObjOps::untweak_ptr(self.inner);
4568 self.inner = core::ptr::null_mut();
4572 /// The genesis hash of the blockchain for channel and node information
4574 pub extern "C" fn GossipTimestampFilter_get_chain_hash(this_ptr: &GossipTimestampFilter) -> *const [u8; 32] {
4575 let mut inner_val = &mut this_ptr.get_native_mut_ref().chain_hash;
4576 inner_val.as_inner()
4578 /// The genesis hash of the blockchain for channel and node information
4580 pub extern "C" fn GossipTimestampFilter_set_chain_hash(this_ptr: &mut GossipTimestampFilter, mut val: crate::c_types::ThirtyTwoBytes) {
4581 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.chain_hash = ::bitcoin::hash_types::BlockHash::from_slice(&val.data[..]).unwrap();
4583 /// The starting unix timestamp
4585 pub extern "C" fn GossipTimestampFilter_get_first_timestamp(this_ptr: &GossipTimestampFilter) -> u32 {
4586 let mut inner_val = &mut this_ptr.get_native_mut_ref().first_timestamp;
4589 /// The starting unix timestamp
4591 pub extern "C" fn GossipTimestampFilter_set_first_timestamp(this_ptr: &mut GossipTimestampFilter, mut val: u32) {
4592 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.first_timestamp = val;
4594 /// The range of information in seconds
4596 pub extern "C" fn GossipTimestampFilter_get_timestamp_range(this_ptr: &GossipTimestampFilter) -> u32 {
4597 let mut inner_val = &mut this_ptr.get_native_mut_ref().timestamp_range;
4600 /// The range of information in seconds
4602 pub extern "C" fn GossipTimestampFilter_set_timestamp_range(this_ptr: &mut GossipTimestampFilter, mut val: u32) {
4603 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.timestamp_range = val;
4605 /// Constructs a new GossipTimestampFilter given each field
4608 pub extern "C" fn GossipTimestampFilter_new(mut chain_hash_arg: crate::c_types::ThirtyTwoBytes, mut first_timestamp_arg: u32, mut timestamp_range_arg: u32) -> GossipTimestampFilter {
4609 GossipTimestampFilter { inner: ObjOps::heap_alloc(nativeGossipTimestampFilter {
4610 chain_hash: ::bitcoin::hash_types::BlockHash::from_slice(&chain_hash_arg.data[..]).unwrap(),
4611 first_timestamp: first_timestamp_arg,
4612 timestamp_range: timestamp_range_arg,
4613 }), is_owned: true }
4615 impl Clone for GossipTimestampFilter {
4616 fn clone(&self) -> Self {
4618 inner: if <*mut nativeGossipTimestampFilter>::is_null(self.inner) { core::ptr::null_mut() } else {
4619 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
4625 /// Used only if an object of this type is returned as a trait impl by a method
4626 pub(crate) extern "C" fn GossipTimestampFilter_clone_void(this_ptr: *const c_void) -> *mut c_void {
4627 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeGossipTimestampFilter)).clone() })) as *mut c_void
4630 /// Creates a copy of the GossipTimestampFilter
4631 pub extern "C" fn GossipTimestampFilter_clone(orig: &GossipTimestampFilter) -> GossipTimestampFilter {
4634 /// Used to put an error message in a LightningError
4638 pub enum ErrorAction {
4639 /// The peer took some action which made us think they were useless. Disconnect them.
4641 /// An error message which we should make an effort to send before we disconnect.
4643 /// Note that this (or a relevant inner pointer) may be NULL or all-0s to represent None
4644 msg: crate::lightning::ln::msgs::ErrorMessage,
4646 /// The peer did something harmless that we weren't able to process, just log and ignore
4648 /// The peer did something harmless that we weren't able to meaningfully process.
4649 /// If the error is logged, log it at the given level.
4651 crate::lightning::util::logger::Level),
4652 /// The peer provided us with a gossip message which we'd already seen. In most cases this
4653 /// should be ignored, but it may result in the message being forwarded if it is a duplicate of
4654 /// our own channel announcements.
4655 IgnoreDuplicateGossip,
4656 /// The peer did something incorrect. Tell them.
4658 /// The message to send.
4659 msg: crate::lightning::ln::msgs::ErrorMessage,
4661 /// The peer did something incorrect. Tell them without closing any channels.
4662 SendWarningMessage {
4663 /// The message to send.
4664 msg: crate::lightning::ln::msgs::WarningMessage,
4665 /// The peer may have done something harmless that we weren't able to meaningfully process,
4666 /// though we should still tell them about it.
4667 /// If this event is logged, log it at the given level.
4668 log_level: crate::lightning::util::logger::Level,
4671 use lightning::ln::msgs::ErrorAction as ErrorActionImport;
4672 pub(crate) type nativeErrorAction = ErrorActionImport;
4676 pub(crate) fn to_native(&self) -> nativeErrorAction {
4678 ErrorAction::DisconnectPeer {ref msg, } => {
4679 let mut msg_nonref = (*msg).clone();
4680 let mut local_msg_nonref = if msg_nonref.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(msg_nonref.take_inner()) } }) };
4681 nativeErrorAction::DisconnectPeer {
4682 msg: local_msg_nonref,
4685 ErrorAction::IgnoreError => nativeErrorAction::IgnoreError,
4686 ErrorAction::IgnoreAndLog (ref a, ) => {
4687 let mut a_nonref = (*a).clone();
4688 nativeErrorAction::IgnoreAndLog (
4689 a_nonref.into_native(),
4692 ErrorAction::IgnoreDuplicateGossip => nativeErrorAction::IgnoreDuplicateGossip,
4693 ErrorAction::SendErrorMessage {ref msg, } => {
4694 let mut msg_nonref = (*msg).clone();
4695 nativeErrorAction::SendErrorMessage {
4696 msg: *unsafe { Box::from_raw(msg_nonref.take_inner()) },
4699 ErrorAction::SendWarningMessage {ref msg, ref log_level, } => {
4700 let mut msg_nonref = (*msg).clone();
4701 let mut log_level_nonref = (*log_level).clone();
4702 nativeErrorAction::SendWarningMessage {
4703 msg: *unsafe { Box::from_raw(msg_nonref.take_inner()) },
4704 log_level: log_level_nonref.into_native(),
4710 pub(crate) fn into_native(self) -> nativeErrorAction {
4712 ErrorAction::DisconnectPeer {mut msg, } => {
4713 let mut local_msg = if msg.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(msg.take_inner()) } }) };
4714 nativeErrorAction::DisconnectPeer {
4718 ErrorAction::IgnoreError => nativeErrorAction::IgnoreError,
4719 ErrorAction::IgnoreAndLog (mut a, ) => {
4720 nativeErrorAction::IgnoreAndLog (
4724 ErrorAction::IgnoreDuplicateGossip => nativeErrorAction::IgnoreDuplicateGossip,
4725 ErrorAction::SendErrorMessage {mut msg, } => {
4726 nativeErrorAction::SendErrorMessage {
4727 msg: *unsafe { Box::from_raw(msg.take_inner()) },
4730 ErrorAction::SendWarningMessage {mut msg, mut log_level, } => {
4731 nativeErrorAction::SendWarningMessage {
4732 msg: *unsafe { Box::from_raw(msg.take_inner()) },
4733 log_level: log_level.into_native(),
4739 pub(crate) fn from_native(native: &nativeErrorAction) -> Self {
4741 nativeErrorAction::DisconnectPeer {ref msg, } => {
4742 let mut msg_nonref = (*msg).clone();
4743 let mut local_msg_nonref = crate::lightning::ln::msgs::ErrorMessage { inner: if msg_nonref.is_none() { core::ptr::null_mut() } else { { ObjOps::heap_alloc((msg_nonref.unwrap())) } }, is_owned: true };
4744 ErrorAction::DisconnectPeer {
4745 msg: local_msg_nonref,
4748 nativeErrorAction::IgnoreError => ErrorAction::IgnoreError,
4749 nativeErrorAction::IgnoreAndLog (ref a, ) => {
4750 let mut a_nonref = (*a).clone();
4751 ErrorAction::IgnoreAndLog (
4752 crate::lightning::util::logger::Level::native_into(a_nonref),
4755 nativeErrorAction::IgnoreDuplicateGossip => ErrorAction::IgnoreDuplicateGossip,
4756 nativeErrorAction::SendErrorMessage {ref msg, } => {
4757 let mut msg_nonref = (*msg).clone();
4758 ErrorAction::SendErrorMessage {
4759 msg: crate::lightning::ln::msgs::ErrorMessage { inner: ObjOps::heap_alloc(msg_nonref), is_owned: true },
4762 nativeErrorAction::SendWarningMessage {ref msg, ref log_level, } => {
4763 let mut msg_nonref = (*msg).clone();
4764 let mut log_level_nonref = (*log_level).clone();
4765 ErrorAction::SendWarningMessage {
4766 msg: crate::lightning::ln::msgs::WarningMessage { inner: ObjOps::heap_alloc(msg_nonref), is_owned: true },
4767 log_level: crate::lightning::util::logger::Level::native_into(log_level_nonref),
4773 pub(crate) fn native_into(native: nativeErrorAction) -> Self {
4775 nativeErrorAction::DisconnectPeer {mut msg, } => {
4776 let mut local_msg = crate::lightning::ln::msgs::ErrorMessage { inner: if msg.is_none() { core::ptr::null_mut() } else { { ObjOps::heap_alloc((msg.unwrap())) } }, is_owned: true };
4777 ErrorAction::DisconnectPeer {
4781 nativeErrorAction::IgnoreError => ErrorAction::IgnoreError,
4782 nativeErrorAction::IgnoreAndLog (mut a, ) => {
4783 ErrorAction::IgnoreAndLog (
4784 crate::lightning::util::logger::Level::native_into(a),
4787 nativeErrorAction::IgnoreDuplicateGossip => ErrorAction::IgnoreDuplicateGossip,
4788 nativeErrorAction::SendErrorMessage {mut msg, } => {
4789 ErrorAction::SendErrorMessage {
4790 msg: crate::lightning::ln::msgs::ErrorMessage { inner: ObjOps::heap_alloc(msg), is_owned: true },
4793 nativeErrorAction::SendWarningMessage {mut msg, mut log_level, } => {
4794 ErrorAction::SendWarningMessage {
4795 msg: crate::lightning::ln::msgs::WarningMessage { inner: ObjOps::heap_alloc(msg), is_owned: true },
4796 log_level: crate::lightning::util::logger::Level::native_into(log_level),
4802 /// Frees any resources used by the ErrorAction
4804 pub extern "C" fn ErrorAction_free(this_ptr: ErrorAction) { }
4805 /// Creates a copy of the ErrorAction
4807 pub extern "C" fn ErrorAction_clone(orig: &ErrorAction) -> ErrorAction {
4811 /// Utility method to constructs a new DisconnectPeer-variant ErrorAction
4812 pub extern "C" fn ErrorAction_disconnect_peer(msg: crate::lightning::ln::msgs::ErrorMessage) -> ErrorAction {
4813 ErrorAction::DisconnectPeer {
4818 /// Utility method to constructs a new IgnoreError-variant ErrorAction
4819 pub extern "C" fn ErrorAction_ignore_error() -> ErrorAction {
4820 ErrorAction::IgnoreError}
4822 /// Utility method to constructs a new IgnoreAndLog-variant ErrorAction
4823 pub extern "C" fn ErrorAction_ignore_and_log(a: crate::lightning::util::logger::Level) -> ErrorAction {
4824 ErrorAction::IgnoreAndLog(a, )
4827 /// Utility method to constructs a new IgnoreDuplicateGossip-variant ErrorAction
4828 pub extern "C" fn ErrorAction_ignore_duplicate_gossip() -> ErrorAction {
4829 ErrorAction::IgnoreDuplicateGossip}
4831 /// Utility method to constructs a new SendErrorMessage-variant ErrorAction
4832 pub extern "C" fn ErrorAction_send_error_message(msg: crate::lightning::ln::msgs::ErrorMessage) -> ErrorAction {
4833 ErrorAction::SendErrorMessage {
4838 /// Utility method to constructs a new SendWarningMessage-variant ErrorAction
4839 pub extern "C" fn ErrorAction_send_warning_message(msg: crate::lightning::ln::msgs::WarningMessage, log_level: crate::lightning::util::logger::Level) -> ErrorAction {
4840 ErrorAction::SendWarningMessage {
4846 use lightning::ln::msgs::LightningError as nativeLightningErrorImport;
4847 pub(crate) type nativeLightningError = nativeLightningErrorImport;
4849 /// An Err type for failure to process messages.
4852 pub struct LightningError {
4853 /// A pointer to the opaque Rust object.
4855 /// Nearly everywhere, inner must be non-null, however in places where
4856 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
4857 pub inner: *mut nativeLightningError,
4858 /// Indicates that this is the only struct which contains the same pointer.
4860 /// Rust functions which take ownership of an object provided via an argument require
4861 /// this to be true and invalidate the object pointed to by inner.
4865 impl Drop for LightningError {
4866 fn drop(&mut self) {
4867 if self.is_owned && !<*mut nativeLightningError>::is_null(self.inner) {
4868 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
4872 /// Frees any resources used by the LightningError, if is_owned is set and inner is non-NULL.
4874 pub extern "C" fn LightningError_free(this_obj: LightningError) { }
4876 /// Used only if an object of this type is returned as a trait impl by a method
4877 pub(crate) extern "C" fn LightningError_free_void(this_ptr: *mut c_void) {
4878 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeLightningError); }
4881 impl LightningError {
4882 pub(crate) fn get_native_ref(&self) -> &'static nativeLightningError {
4883 unsafe { &*ObjOps::untweak_ptr(self.inner) }
4885 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeLightningError {
4886 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
4888 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
4889 pub(crate) fn take_inner(mut self) -> *mut nativeLightningError {
4890 assert!(self.is_owned);
4891 let ret = ObjOps::untweak_ptr(self.inner);
4892 self.inner = core::ptr::null_mut();
4896 /// A human-readable message describing the error
4898 pub extern "C" fn LightningError_get_err(this_ptr: &LightningError) -> crate::c_types::Str {
4899 let mut inner_val = &mut this_ptr.get_native_mut_ref().err;
4900 inner_val.as_str().into()
4902 /// A human-readable message describing the error
4904 pub extern "C" fn LightningError_set_err(this_ptr: &mut LightningError, mut val: crate::c_types::Str) {
4905 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.err = val.into_string();
4907 /// The action which should be taken against the offending peer.
4909 pub extern "C" fn LightningError_get_action(this_ptr: &LightningError) -> crate::lightning::ln::msgs::ErrorAction {
4910 let mut inner_val = &mut this_ptr.get_native_mut_ref().action;
4911 crate::lightning::ln::msgs::ErrorAction::from_native(inner_val)
4913 /// The action which should be taken against the offending peer.
4915 pub extern "C" fn LightningError_set_action(this_ptr: &mut LightningError, mut val: crate::lightning::ln::msgs::ErrorAction) {
4916 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.action = val.into_native();
4918 /// Constructs a new LightningError given each field
4921 pub extern "C" fn LightningError_new(mut err_arg: crate::c_types::Str, mut action_arg: crate::lightning::ln::msgs::ErrorAction) -> LightningError {
4922 LightningError { inner: ObjOps::heap_alloc(nativeLightningError {
4923 err: err_arg.into_string(),
4924 action: action_arg.into_native(),
4925 }), is_owned: true }
4927 impl Clone for LightningError {
4928 fn clone(&self) -> Self {
4930 inner: if <*mut nativeLightningError>::is_null(self.inner) { core::ptr::null_mut() } else {
4931 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
4937 /// Used only if an object of this type is returned as a trait impl by a method
4938 pub(crate) extern "C" fn LightningError_clone_void(this_ptr: *const c_void) -> *mut c_void {
4939 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeLightningError)).clone() })) as *mut c_void
4942 /// Creates a copy of the LightningError
4943 pub extern "C" fn LightningError_clone(orig: &LightningError) -> LightningError {
4947 use lightning::ln::msgs::CommitmentUpdate as nativeCommitmentUpdateImport;
4948 pub(crate) type nativeCommitmentUpdate = nativeCommitmentUpdateImport;
4950 /// Struct used to return values from revoke_and_ack messages, containing a bunch of commitment
4951 /// transaction updates if they were pending.
4954 pub struct CommitmentUpdate {
4955 /// A pointer to the opaque Rust object.
4957 /// Nearly everywhere, inner must be non-null, however in places where
4958 /// the Rust equivalent takes an Option, it may be set to null to indicate None.
4959 pub inner: *mut nativeCommitmentUpdate,
4960 /// Indicates that this is the only struct which contains the same pointer.
4962 /// Rust functions which take ownership of an object provided via an argument require
4963 /// this to be true and invalidate the object pointed to by inner.
4967 impl Drop for CommitmentUpdate {
4968 fn drop(&mut self) {
4969 if self.is_owned && !<*mut nativeCommitmentUpdate>::is_null(self.inner) {
4970 let _ = unsafe { Box::from_raw(ObjOps::untweak_ptr(self.inner)) };
4974 /// Frees any resources used by the CommitmentUpdate, if is_owned is set and inner is non-NULL.
4976 pub extern "C" fn CommitmentUpdate_free(this_obj: CommitmentUpdate) { }
4978 /// Used only if an object of this type is returned as a trait impl by a method
4979 pub(crate) extern "C" fn CommitmentUpdate_free_void(this_ptr: *mut c_void) {
4980 unsafe { let _ = Box::from_raw(this_ptr as *mut nativeCommitmentUpdate); }
4983 impl CommitmentUpdate {
4984 pub(crate) fn get_native_ref(&self) -> &'static nativeCommitmentUpdate {
4985 unsafe { &*ObjOps::untweak_ptr(self.inner) }
4987 pub(crate) fn get_native_mut_ref(&self) -> &'static mut nativeCommitmentUpdate {
4988 unsafe { &mut *ObjOps::untweak_ptr(self.inner) }
4990 /// When moving out of the pointer, we have to ensure we aren't a reference, this makes that easy
4991 pub(crate) fn take_inner(mut self) -> *mut nativeCommitmentUpdate {
4992 assert!(self.is_owned);
4993 let ret = ObjOps::untweak_ptr(self.inner);
4994 self.inner = core::ptr::null_mut();
4998 /// update_add_htlc messages which should be sent
5000 pub extern "C" fn CommitmentUpdate_get_update_add_htlcs(this_ptr: &CommitmentUpdate) -> crate::c_types::derived::CVec_UpdateAddHTLCZ {
5001 let mut inner_val = &mut this_ptr.get_native_mut_ref().update_add_htlcs;
5002 let mut local_inner_val = Vec::new(); for item in inner_val.iter() { local_inner_val.push( { crate::lightning::ln::msgs::UpdateAddHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((item as *const lightning::ln::msgs::UpdateAddHTLC<>) as *mut _) }, is_owned: false } }); };
5003 local_inner_val.into()
5005 /// update_add_htlc messages which should be sent
5007 pub extern "C" fn CommitmentUpdate_set_update_add_htlcs(this_ptr: &mut CommitmentUpdate, mut val: crate::c_types::derived::CVec_UpdateAddHTLCZ) {
5008 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5009 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.update_add_htlcs = local_val;
5011 /// update_fulfill_htlc messages which should be sent
5013 pub extern "C" fn CommitmentUpdate_get_update_fulfill_htlcs(this_ptr: &CommitmentUpdate) -> crate::c_types::derived::CVec_UpdateFulfillHTLCZ {
5014 let mut inner_val = &mut this_ptr.get_native_mut_ref().update_fulfill_htlcs;
5015 let mut local_inner_val = Vec::new(); for item in inner_val.iter() { local_inner_val.push( { crate::lightning::ln::msgs::UpdateFulfillHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((item as *const lightning::ln::msgs::UpdateFulfillHTLC<>) as *mut _) }, is_owned: false } }); };
5016 local_inner_val.into()
5018 /// update_fulfill_htlc messages which should be sent
5020 pub extern "C" fn CommitmentUpdate_set_update_fulfill_htlcs(this_ptr: &mut CommitmentUpdate, mut val: crate::c_types::derived::CVec_UpdateFulfillHTLCZ) {
5021 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5022 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.update_fulfill_htlcs = local_val;
5024 /// update_fail_htlc messages which should be sent
5026 pub extern "C" fn CommitmentUpdate_get_update_fail_htlcs(this_ptr: &CommitmentUpdate) -> crate::c_types::derived::CVec_UpdateFailHTLCZ {
5027 let mut inner_val = &mut this_ptr.get_native_mut_ref().update_fail_htlcs;
5028 let mut local_inner_val = Vec::new(); for item in inner_val.iter() { local_inner_val.push( { crate::lightning::ln::msgs::UpdateFailHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((item as *const lightning::ln::msgs::UpdateFailHTLC<>) as *mut _) }, is_owned: false } }); };
5029 local_inner_val.into()
5031 /// update_fail_htlc messages which should be sent
5033 pub extern "C" fn CommitmentUpdate_set_update_fail_htlcs(this_ptr: &mut CommitmentUpdate, mut val: crate::c_types::derived::CVec_UpdateFailHTLCZ) {
5034 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5035 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.update_fail_htlcs = local_val;
5037 /// update_fail_malformed_htlc messages which should be sent
5039 pub extern "C" fn CommitmentUpdate_get_update_fail_malformed_htlcs(this_ptr: &CommitmentUpdate) -> crate::c_types::derived::CVec_UpdateFailMalformedHTLCZ {
5040 let mut inner_val = &mut this_ptr.get_native_mut_ref().update_fail_malformed_htlcs;
5041 let mut local_inner_val = Vec::new(); for item in inner_val.iter() { local_inner_val.push( { crate::lightning::ln::msgs::UpdateFailMalformedHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((item as *const lightning::ln::msgs::UpdateFailMalformedHTLC<>) as *mut _) }, is_owned: false } }); };
5042 local_inner_val.into()
5044 /// update_fail_malformed_htlc messages which should be sent
5046 pub extern "C" fn CommitmentUpdate_set_update_fail_malformed_htlcs(this_ptr: &mut CommitmentUpdate, mut val: crate::c_types::derived::CVec_UpdateFailMalformedHTLCZ) {
5047 let mut local_val = Vec::new(); for mut item in val.into_rust().drain(..) { local_val.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5048 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.update_fail_malformed_htlcs = local_val;
5050 /// An update_fee message which should be sent
5052 /// Note that the return value (or a relevant inner pointer) may be NULL or all-0s to represent None
5054 pub extern "C" fn CommitmentUpdate_get_update_fee(this_ptr: &CommitmentUpdate) -> crate::lightning::ln::msgs::UpdateFee {
5055 let mut inner_val = &mut this_ptr.get_native_mut_ref().update_fee;
5056 let mut local_inner_val = crate::lightning::ln::msgs::UpdateFee { inner: unsafe { (if inner_val.is_none() { core::ptr::null() } else { ObjOps::nonnull_ptr_to_inner( { (inner_val.as_ref().unwrap()) }) } as *const lightning::ln::msgs::UpdateFee<>) as *mut _ }, is_owned: false };
5059 /// An update_fee message which should be sent
5061 /// Note that val (or a relevant inner pointer) may be NULL or all-0s to represent None
5063 pub extern "C" fn CommitmentUpdate_set_update_fee(this_ptr: &mut CommitmentUpdate, mut val: crate::lightning::ln::msgs::UpdateFee) {
5064 let mut local_val = if val.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(val.take_inner()) } }) };
5065 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.update_fee = local_val;
5067 /// Finally, the commitment_signed message which should be sent
5069 pub extern "C" fn CommitmentUpdate_get_commitment_signed(this_ptr: &CommitmentUpdate) -> crate::lightning::ln::msgs::CommitmentSigned {
5070 let mut inner_val = &mut this_ptr.get_native_mut_ref().commitment_signed;
5071 crate::lightning::ln::msgs::CommitmentSigned { inner: unsafe { ObjOps::nonnull_ptr_to_inner((inner_val as *const lightning::ln::msgs::CommitmentSigned<>) as *mut _) }, is_owned: false }
5073 /// Finally, the commitment_signed message which should be sent
5075 pub extern "C" fn CommitmentUpdate_set_commitment_signed(this_ptr: &mut CommitmentUpdate, mut val: crate::lightning::ln::msgs::CommitmentSigned) {
5076 unsafe { &mut *ObjOps::untweak_ptr(this_ptr.inner) }.commitment_signed = *unsafe { Box::from_raw(val.take_inner()) };
5078 /// Constructs a new CommitmentUpdate given each field
5081 pub extern "C" fn CommitmentUpdate_new(mut update_add_htlcs_arg: crate::c_types::derived::CVec_UpdateAddHTLCZ, mut update_fulfill_htlcs_arg: crate::c_types::derived::CVec_UpdateFulfillHTLCZ, mut update_fail_htlcs_arg: crate::c_types::derived::CVec_UpdateFailHTLCZ, mut update_fail_malformed_htlcs_arg: crate::c_types::derived::CVec_UpdateFailMalformedHTLCZ, mut update_fee_arg: crate::lightning::ln::msgs::UpdateFee, mut commitment_signed_arg: crate::lightning::ln::msgs::CommitmentSigned) -> CommitmentUpdate {
5082 let mut local_update_add_htlcs_arg = Vec::new(); for mut item in update_add_htlcs_arg.into_rust().drain(..) { local_update_add_htlcs_arg.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5083 let mut local_update_fulfill_htlcs_arg = Vec::new(); for mut item in update_fulfill_htlcs_arg.into_rust().drain(..) { local_update_fulfill_htlcs_arg.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5084 let mut local_update_fail_htlcs_arg = Vec::new(); for mut item in update_fail_htlcs_arg.into_rust().drain(..) { local_update_fail_htlcs_arg.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5085 let mut local_update_fail_malformed_htlcs_arg = Vec::new(); for mut item in update_fail_malformed_htlcs_arg.into_rust().drain(..) { local_update_fail_malformed_htlcs_arg.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5086 let mut local_update_fee_arg = if update_fee_arg.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(update_fee_arg.take_inner()) } }) };
5087 CommitmentUpdate { inner: ObjOps::heap_alloc(nativeCommitmentUpdate {
5088 update_add_htlcs: local_update_add_htlcs_arg,
5089 update_fulfill_htlcs: local_update_fulfill_htlcs_arg,
5090 update_fail_htlcs: local_update_fail_htlcs_arg,
5091 update_fail_malformed_htlcs: local_update_fail_malformed_htlcs_arg,
5092 update_fee: local_update_fee_arg,
5093 commitment_signed: *unsafe { Box::from_raw(commitment_signed_arg.take_inner()) },
5094 }), is_owned: true }
5096 impl Clone for CommitmentUpdate {
5097 fn clone(&self) -> Self {
5099 inner: if <*mut nativeCommitmentUpdate>::is_null(self.inner) { core::ptr::null_mut() } else {
5100 ObjOps::heap_alloc(unsafe { &*ObjOps::untweak_ptr(self.inner) }.clone()) },
5106 /// Used only if an object of this type is returned as a trait impl by a method
5107 pub(crate) extern "C" fn CommitmentUpdate_clone_void(this_ptr: *const c_void) -> *mut c_void {
5108 Box::into_raw(Box::new(unsafe { (*(this_ptr as *mut nativeCommitmentUpdate)).clone() })) as *mut c_void
5111 /// Creates a copy of the CommitmentUpdate
5112 pub extern "C" fn CommitmentUpdate_clone(orig: &CommitmentUpdate) -> CommitmentUpdate {
5115 /// A trait to describe an object which can receive channel messages.
5117 /// Messages MAY be called in parallel when they originate from different their_node_ids, however
5118 /// they MUST NOT be called in parallel when the two calls have the same their_node_id.
5120 pub struct ChannelMessageHandler {
5121 /// An opaque pointer which is passed to your function implementations as an argument.
5122 /// This has no meaning in the LDK, and can be NULL or any other value.
5123 pub this_arg: *mut c_void,
5124 /// Handle an incoming open_channel message from the given peer.
5125 pub handle_open_channel: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, their_features: crate::lightning::ln::features::InitFeatures, msg: &crate::lightning::ln::msgs::OpenChannel),
5126 /// Handle an incoming accept_channel message from the given peer.
5127 pub handle_accept_channel: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, their_features: crate::lightning::ln::features::InitFeatures, msg: &crate::lightning::ln::msgs::AcceptChannel),
5128 /// Handle an incoming funding_created message from the given peer.
5129 pub handle_funding_created: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::FundingCreated),
5130 /// Handle an incoming funding_signed message from the given peer.
5131 pub handle_funding_signed: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::FundingSigned),
5132 /// Handle an incoming channel_ready message from the given peer.
5133 pub handle_channel_ready: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::ChannelReady),
5134 /// Handle an incoming shutdown message from the given peer.
5135 pub handle_shutdown: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, their_features: &crate::lightning::ln::features::InitFeatures, msg: &crate::lightning::ln::msgs::Shutdown),
5136 /// Handle an incoming closing_signed message from the given peer.
5137 pub handle_closing_signed: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::ClosingSigned),
5138 /// Handle an incoming update_add_htlc message from the given peer.
5139 pub handle_update_add_htlc: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::UpdateAddHTLC),
5140 /// Handle an incoming update_fulfill_htlc message from the given peer.
5141 pub handle_update_fulfill_htlc: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::UpdateFulfillHTLC),
5142 /// Handle an incoming update_fail_htlc message from the given peer.
5143 pub handle_update_fail_htlc: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::UpdateFailHTLC),
5144 /// Handle an incoming update_fail_malformed_htlc message from the given peer.
5145 pub handle_update_fail_malformed_htlc: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::UpdateFailMalformedHTLC),
5146 /// Handle an incoming commitment_signed message from the given peer.
5147 pub handle_commitment_signed: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::CommitmentSigned),
5148 /// Handle an incoming revoke_and_ack message from the given peer.
5149 pub handle_revoke_and_ack: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::RevokeAndACK),
5150 /// Handle an incoming update_fee message from the given peer.
5151 pub handle_update_fee: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::UpdateFee),
5152 /// Handle an incoming announcement_signatures message from the given peer.
5153 pub handle_announcement_signatures: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::AnnouncementSignatures),
5154 /// Indicates a connection to the peer failed/an existing connection was lost. If no connection
5155 /// is believed to be possible in the future (eg they're sending us messages we don't
5156 /// understand or indicate they require unknown feature bits), no_connection_possible is set
5157 /// and any outstanding channels should be failed.
5158 pub peer_disconnected: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, no_connection_possible: bool),
5159 /// Handle a peer reconnecting, possibly generating channel_reestablish message(s).
5160 pub peer_connected: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::Init),
5161 /// Handle an incoming channel_reestablish message from the given peer.
5162 pub handle_channel_reestablish: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::ChannelReestablish),
5163 /// Handle an incoming channel update from the given peer.
5164 pub handle_channel_update: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::ChannelUpdate),
5165 /// Handle an incoming error message from the given peer.
5166 pub handle_error: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: &crate::lightning::ln::msgs::ErrorMessage),
5167 /// Implementation of MessageSendEventsProvider for this object.
5168 pub MessageSendEventsProvider: crate::lightning::util::events::MessageSendEventsProvider,
5169 /// Frees any resources associated with this object given its this_arg pointer.
5170 /// Does not need to free the outer struct containing function pointers and may be NULL is no resources need to be freed.
5171 pub free: Option<extern "C" fn(this_arg: *mut c_void)>,
5173 unsafe impl Send for ChannelMessageHandler {}
5174 unsafe impl Sync for ChannelMessageHandler {}
5176 pub(crate) extern "C" fn ChannelMessageHandler_clone_fields(orig: &ChannelMessageHandler) -> ChannelMessageHandler {
5177 ChannelMessageHandler {
5178 this_arg: orig.this_arg,
5179 handle_open_channel: Clone::clone(&orig.handle_open_channel),
5180 handle_accept_channel: Clone::clone(&orig.handle_accept_channel),
5181 handle_funding_created: Clone::clone(&orig.handle_funding_created),
5182 handle_funding_signed: Clone::clone(&orig.handle_funding_signed),
5183 handle_channel_ready: Clone::clone(&orig.handle_channel_ready),
5184 handle_shutdown: Clone::clone(&orig.handle_shutdown),
5185 handle_closing_signed: Clone::clone(&orig.handle_closing_signed),
5186 handle_update_add_htlc: Clone::clone(&orig.handle_update_add_htlc),
5187 handle_update_fulfill_htlc: Clone::clone(&orig.handle_update_fulfill_htlc),
5188 handle_update_fail_htlc: Clone::clone(&orig.handle_update_fail_htlc),
5189 handle_update_fail_malformed_htlc: Clone::clone(&orig.handle_update_fail_malformed_htlc),
5190 handle_commitment_signed: Clone::clone(&orig.handle_commitment_signed),
5191 handle_revoke_and_ack: Clone::clone(&orig.handle_revoke_and_ack),
5192 handle_update_fee: Clone::clone(&orig.handle_update_fee),
5193 handle_announcement_signatures: Clone::clone(&orig.handle_announcement_signatures),
5194 peer_disconnected: Clone::clone(&orig.peer_disconnected),
5195 peer_connected: Clone::clone(&orig.peer_connected),
5196 handle_channel_reestablish: Clone::clone(&orig.handle_channel_reestablish),
5197 handle_channel_update: Clone::clone(&orig.handle_channel_update),
5198 handle_error: Clone::clone(&orig.handle_error),
5199 MessageSendEventsProvider: crate::lightning::util::events::MessageSendEventsProvider_clone_fields(&orig.MessageSendEventsProvider),
5200 free: Clone::clone(&orig.free),
5203 impl lightning::util::events::MessageSendEventsProvider for ChannelMessageHandler {
5204 fn get_and_clear_pending_msg_events(&self) -> Vec<lightning::util::events::MessageSendEvent> {
5205 let mut ret = (self.MessageSendEventsProvider.get_and_clear_pending_msg_events)(self.MessageSendEventsProvider.this_arg);
5206 let mut local_ret = Vec::new(); for mut item in ret.into_rust().drain(..) { local_ret.push( { item.into_native() }); };
5211 use lightning::ln::msgs::ChannelMessageHandler as rustChannelMessageHandler;
5212 impl rustChannelMessageHandler for ChannelMessageHandler {
5213 fn handle_open_channel(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut their_features: lightning::ln::features::InitFeatures, mut msg: &lightning::ln::msgs::OpenChannel) {
5214 (self.handle_open_channel)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), crate::lightning::ln::features::InitFeatures { inner: ObjOps::heap_alloc(their_features), is_owned: true }, &crate::lightning::ln::msgs::OpenChannel { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::OpenChannel<>) as *mut _) }, is_owned: false })
5216 fn handle_accept_channel(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut their_features: lightning::ln::features::InitFeatures, mut msg: &lightning::ln::msgs::AcceptChannel) {
5217 (self.handle_accept_channel)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), crate::lightning::ln::features::InitFeatures { inner: ObjOps::heap_alloc(their_features), is_owned: true }, &crate::lightning::ln::msgs::AcceptChannel { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::AcceptChannel<>) as *mut _) }, is_owned: false })
5219 fn handle_funding_created(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::FundingCreated) {
5220 (self.handle_funding_created)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::FundingCreated { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::FundingCreated<>) as *mut _) }, is_owned: false })
5222 fn handle_funding_signed(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::FundingSigned) {
5223 (self.handle_funding_signed)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::FundingSigned { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::FundingSigned<>) as *mut _) }, is_owned: false })
5225 fn handle_channel_ready(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::ChannelReady) {
5226 (self.handle_channel_ready)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::ChannelReady { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::ChannelReady<>) as *mut _) }, is_owned: false })
5228 fn handle_shutdown(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut their_features: &lightning::ln::features::InitFeatures, mut msg: &lightning::ln::msgs::Shutdown) {
5229 (self.handle_shutdown)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::features::InitFeatures { inner: unsafe { ObjOps::nonnull_ptr_to_inner((their_features as *const lightning::ln::features::InitFeatures<>) as *mut _) }, is_owned: false }, &crate::lightning::ln::msgs::Shutdown { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::Shutdown<>) as *mut _) }, is_owned: false })
5231 fn handle_closing_signed(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::ClosingSigned) {
5232 (self.handle_closing_signed)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::ClosingSigned { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::ClosingSigned<>) as *mut _) }, is_owned: false })
5234 fn handle_update_add_htlc(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::UpdateAddHTLC) {
5235 (self.handle_update_add_htlc)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::UpdateAddHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::UpdateAddHTLC<>) as *mut _) }, is_owned: false })
5237 fn handle_update_fulfill_htlc(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::UpdateFulfillHTLC) {
5238 (self.handle_update_fulfill_htlc)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::UpdateFulfillHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::UpdateFulfillHTLC<>) as *mut _) }, is_owned: false })
5240 fn handle_update_fail_htlc(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::UpdateFailHTLC) {
5241 (self.handle_update_fail_htlc)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::UpdateFailHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::UpdateFailHTLC<>) as *mut _) }, is_owned: false })
5243 fn handle_update_fail_malformed_htlc(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::UpdateFailMalformedHTLC) {
5244 (self.handle_update_fail_malformed_htlc)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::UpdateFailMalformedHTLC { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::UpdateFailMalformedHTLC<>) as *mut _) }, is_owned: false })
5246 fn handle_commitment_signed(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::CommitmentSigned) {
5247 (self.handle_commitment_signed)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::CommitmentSigned { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::CommitmentSigned<>) as *mut _) }, is_owned: false })
5249 fn handle_revoke_and_ack(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::RevokeAndACK) {
5250 (self.handle_revoke_and_ack)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::RevokeAndACK { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::RevokeAndACK<>) as *mut _) }, is_owned: false })
5252 fn handle_update_fee(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::UpdateFee) {
5253 (self.handle_update_fee)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::UpdateFee { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::UpdateFee<>) as *mut _) }, is_owned: false })
5255 fn handle_announcement_signatures(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::AnnouncementSignatures) {
5256 (self.handle_announcement_signatures)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::AnnouncementSignatures { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::AnnouncementSignatures<>) as *mut _) }, is_owned: false })
5258 fn peer_disconnected(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut no_connection_possible: bool) {
5259 (self.peer_disconnected)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), no_connection_possible)
5261 fn peer_connected(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::Init) {
5262 (self.peer_connected)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::Init { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::Init<>) as *mut _) }, is_owned: false })
5264 fn handle_channel_reestablish(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::ChannelReestablish) {
5265 (self.handle_channel_reestablish)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::ChannelReestablish { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::ChannelReestablish<>) as *mut _) }, is_owned: false })
5267 fn handle_channel_update(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::ChannelUpdate) {
5268 (self.handle_channel_update)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::ChannelUpdate { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::ChannelUpdate<>) as *mut _) }, is_owned: false })
5270 fn handle_error(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: &lightning::ln::msgs::ErrorMessage) {
5271 (self.handle_error)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::ErrorMessage { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::ErrorMessage<>) as *mut _) }, is_owned: false })
5275 // We're essentially a pointer already, or at least a set of pointers, so allow us to be used
5276 // directly as a Deref trait in higher-level structs:
5277 impl core::ops::Deref for ChannelMessageHandler {
5279 fn deref(&self) -> &Self {
5283 /// Calls the free function if one is set
5285 pub extern "C" fn ChannelMessageHandler_free(this_ptr: ChannelMessageHandler) { }
5286 impl Drop for ChannelMessageHandler {
5287 fn drop(&mut self) {
5288 if let Some(f) = self.free {
5293 /// A trait to describe an object which can receive routing messages.
5295 /// # Implementor DoS Warnings
5297 /// For `gossip_queries` messages there are potential DoS vectors when handling
5298 /// inbound queries. Implementors using an on-disk network graph should be aware of
5299 /// repeated disk I/O for queries accessing different parts of the network graph.
5301 pub struct RoutingMessageHandler {
5302 /// An opaque pointer which is passed to your function implementations as an argument.
5303 /// This has no meaning in the LDK, and can be NULL or any other value.
5304 pub this_arg: *mut c_void,
5305 /// Handle an incoming node_announcement message, returning true if it should be forwarded on,
5306 /// false or returning an Err otherwise.
5308 pub handle_node_announcement: extern "C" fn (this_arg: *const c_void, msg: &crate::lightning::ln::msgs::NodeAnnouncement) -> crate::c_types::derived::CResult_boolLightningErrorZ,
5309 /// Handle a channel_announcement message, returning true if it should be forwarded on, false
5310 /// or returning an Err otherwise.
5312 pub handle_channel_announcement: extern "C" fn (this_arg: *const c_void, msg: &crate::lightning::ln::msgs::ChannelAnnouncement) -> crate::c_types::derived::CResult_boolLightningErrorZ,
5313 /// Handle an incoming channel_update message, returning true if it should be forwarded on,
5314 /// false or returning an Err otherwise.
5316 pub handle_channel_update: extern "C" fn (this_arg: *const c_void, msg: &crate::lightning::ln::msgs::ChannelUpdate) -> crate::c_types::derived::CResult_boolLightningErrorZ,
5317 /// Gets a subset of the channel announcements and updates required to dump our routing table
5318 /// to a remote node, starting at the short_channel_id indicated by starting_point and
5319 /// including the batch_amount entries immediately higher in numerical value than starting_point.
5321 pub get_next_channel_announcements: extern "C" fn (this_arg: *const c_void, starting_point: u64, batch_amount: u8) -> crate::c_types::derived::CVec_C3Tuple_ChannelAnnouncementChannelUpdateChannelUpdateZZ,
5322 /// Gets a subset of the node announcements required to dump our routing table to a remote node,
5323 /// starting at the node *after* the provided publickey and including batch_amount entries
5324 /// immediately higher (as defined by <PublicKey as Ord>::cmp) than starting_point.
5325 /// If None is provided for starting_point, we start at the first node.
5327 /// Note that starting_point (or a relevant inner pointer) may be NULL or all-0s to represent None
5329 pub get_next_node_announcements: extern "C" fn (this_arg: *const c_void, starting_point: crate::c_types::PublicKey, batch_amount: u8) -> crate::c_types::derived::CVec_NodeAnnouncementZ,
5330 /// Called when a connection is established with a peer. This can be used to
5331 /// perform routing table synchronization using a strategy defined by the
5333 pub peer_connected: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, init: &crate::lightning::ln::msgs::Init),
5334 /// Handles the reply of a query we initiated to learn about channels
5335 /// for a given range of blocks. We can expect to receive one or more
5336 /// replies to a single query.
5338 pub handle_reply_channel_range: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: crate::lightning::ln::msgs::ReplyChannelRange) -> crate::c_types::derived::CResult_NoneLightningErrorZ,
5339 /// Handles the reply of a query we initiated asking for routing gossip
5340 /// messages for a list of channels. We should receive this message when
5341 /// a node has completed its best effort to send us the pertaining routing
5342 /// gossip messages.
5344 pub handle_reply_short_channel_ids_end: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: crate::lightning::ln::msgs::ReplyShortChannelIdsEnd) -> crate::c_types::derived::CResult_NoneLightningErrorZ,
5345 /// Handles when a peer asks us to send a list of short_channel_ids
5346 /// for the requested range of blocks.
5348 pub handle_query_channel_range: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: crate::lightning::ln::msgs::QueryChannelRange) -> crate::c_types::derived::CResult_NoneLightningErrorZ,
5349 /// Handles when a peer asks us to send routing gossip messages for a
5350 /// list of short_channel_ids.
5352 pub handle_query_short_channel_ids: extern "C" fn (this_arg: *const c_void, their_node_id: crate::c_types::PublicKey, msg: crate::lightning::ln::msgs::QueryShortChannelIds) -> crate::c_types::derived::CResult_NoneLightningErrorZ,
5353 /// Implementation of MessageSendEventsProvider for this object.
5354 pub MessageSendEventsProvider: crate::lightning::util::events::MessageSendEventsProvider,
5355 /// Frees any resources associated with this object given its this_arg pointer.
5356 /// Does not need to free the outer struct containing function pointers and may be NULL is no resources need to be freed.
5357 pub free: Option<extern "C" fn(this_arg: *mut c_void)>,
5359 unsafe impl Send for RoutingMessageHandler {}
5360 unsafe impl Sync for RoutingMessageHandler {}
5362 pub(crate) extern "C" fn RoutingMessageHandler_clone_fields(orig: &RoutingMessageHandler) -> RoutingMessageHandler {
5363 RoutingMessageHandler {
5364 this_arg: orig.this_arg,
5365 handle_node_announcement: Clone::clone(&orig.handle_node_announcement),
5366 handle_channel_announcement: Clone::clone(&orig.handle_channel_announcement),
5367 handle_channel_update: Clone::clone(&orig.handle_channel_update),
5368 get_next_channel_announcements: Clone::clone(&orig.get_next_channel_announcements),
5369 get_next_node_announcements: Clone::clone(&orig.get_next_node_announcements),
5370 peer_connected: Clone::clone(&orig.peer_connected),
5371 handle_reply_channel_range: Clone::clone(&orig.handle_reply_channel_range),
5372 handle_reply_short_channel_ids_end: Clone::clone(&orig.handle_reply_short_channel_ids_end),
5373 handle_query_channel_range: Clone::clone(&orig.handle_query_channel_range),
5374 handle_query_short_channel_ids: Clone::clone(&orig.handle_query_short_channel_ids),
5375 MessageSendEventsProvider: crate::lightning::util::events::MessageSendEventsProvider_clone_fields(&orig.MessageSendEventsProvider),
5376 free: Clone::clone(&orig.free),
5379 impl lightning::util::events::MessageSendEventsProvider for RoutingMessageHandler {
5380 fn get_and_clear_pending_msg_events(&self) -> Vec<lightning::util::events::MessageSendEvent> {
5381 let mut ret = (self.MessageSendEventsProvider.get_and_clear_pending_msg_events)(self.MessageSendEventsProvider.this_arg);
5382 let mut local_ret = Vec::new(); for mut item in ret.into_rust().drain(..) { local_ret.push( { item.into_native() }); };
5387 use lightning::ln::msgs::RoutingMessageHandler as rustRoutingMessageHandler;
5388 impl rustRoutingMessageHandler for RoutingMessageHandler {
5389 fn handle_node_announcement(&self, mut msg: &lightning::ln::msgs::NodeAnnouncement) -> Result<bool, lightning::ln::msgs::LightningError> {
5390 let mut ret = (self.handle_node_announcement)(self.this_arg, &crate::lightning::ln::msgs::NodeAnnouncement { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::NodeAnnouncement<>) as *mut _) }, is_owned: false });
5391 let mut local_ret = match ret.result_ok { true => Ok( { (*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.result)) }) }), false => Err( { *unsafe { Box::from_raw((*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.err)) }).take_inner()) } })};
5394 fn handle_channel_announcement(&self, mut msg: &lightning::ln::msgs::ChannelAnnouncement) -> Result<bool, lightning::ln::msgs::LightningError> {
5395 let mut ret = (self.handle_channel_announcement)(self.this_arg, &crate::lightning::ln::msgs::ChannelAnnouncement { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::ChannelAnnouncement<>) as *mut _) }, is_owned: false });
5396 let mut local_ret = match ret.result_ok { true => Ok( { (*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.result)) }) }), false => Err( { *unsafe { Box::from_raw((*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.err)) }).take_inner()) } })};
5399 fn handle_channel_update(&self, mut msg: &lightning::ln::msgs::ChannelUpdate) -> Result<bool, lightning::ln::msgs::LightningError> {
5400 let mut ret = (self.handle_channel_update)(self.this_arg, &crate::lightning::ln::msgs::ChannelUpdate { inner: unsafe { ObjOps::nonnull_ptr_to_inner((msg as *const lightning::ln::msgs::ChannelUpdate<>) as *mut _) }, is_owned: false });
5401 let mut local_ret = match ret.result_ok { true => Ok( { (*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.result)) }) }), false => Err( { *unsafe { Box::from_raw((*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.err)) }).take_inner()) } })};
5404 fn get_next_channel_announcements(&self, mut starting_point: u64, mut batch_amount: u8) -> Vec<(lightning::ln::msgs::ChannelAnnouncement, Option<lightning::ln::msgs::ChannelUpdate>, Option<lightning::ln::msgs::ChannelUpdate>)> {
5405 let mut ret = (self.get_next_channel_announcements)(self.this_arg, starting_point, batch_amount);
5406 let mut local_ret = Vec::new(); for mut item in ret.into_rust().drain(..) { local_ret.push( { let (mut orig_ret_0_0, mut orig_ret_0_1, mut orig_ret_0_2) = item.to_rust(); let mut local_orig_ret_0_1 = if orig_ret_0_1.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(orig_ret_0_1.take_inner()) } }) }; let mut local_orig_ret_0_2 = if orig_ret_0_2.inner.is_null() { None } else { Some( { *unsafe { Box::from_raw(orig_ret_0_2.take_inner()) } }) }; let mut local_ret_0 = (*unsafe { Box::from_raw(orig_ret_0_0.take_inner()) }, local_orig_ret_0_1, local_orig_ret_0_2); local_ret_0 }); };
5409 fn get_next_node_announcements(&self, mut starting_point: Option<&bitcoin::secp256k1::PublicKey>, mut batch_amount: u8) -> Vec<lightning::ln::msgs::NodeAnnouncement> {
5410 let mut local_starting_point = if starting_point.is_none() { crate::c_types::PublicKey::null() } else { { crate::c_types::PublicKey::from_rust(&(starting_point.unwrap())) } };
5411 let mut ret = (self.get_next_node_announcements)(self.this_arg, local_starting_point, batch_amount);
5412 let mut local_ret = Vec::new(); for mut item in ret.into_rust().drain(..) { local_ret.push( { *unsafe { Box::from_raw(item.take_inner()) } }); };
5415 fn peer_connected(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut init: &lightning::ln::msgs::Init) {
5416 (self.peer_connected)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), &crate::lightning::ln::msgs::Init { inner: unsafe { ObjOps::nonnull_ptr_to_inner((init as *const lightning::ln::msgs::Init<>) as *mut _) }, is_owned: false })
5418 fn handle_reply_channel_range(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: lightning::ln::msgs::ReplyChannelRange) -> Result<(), lightning::ln::msgs::LightningError> {
5419 let mut ret = (self.handle_reply_channel_range)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), crate::lightning::ln::msgs::ReplyChannelRange { inner: ObjOps::heap_alloc(msg), is_owned: true });
5420 let mut local_ret = match ret.result_ok { true => Ok( { () /*(*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.result)) })*/ }), false => Err( { *unsafe { Box::from_raw((*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.err)) }).take_inner()) } })};
5423 fn handle_reply_short_channel_ids_end(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: lightning::ln::msgs::ReplyShortChannelIdsEnd) -> Result<(), lightning::ln::msgs::LightningError> {
5424 let mut ret = (self.handle_reply_short_channel_ids_end)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), crate::lightning::ln::msgs::ReplyShortChannelIdsEnd { inner: ObjOps::heap_alloc(msg), is_owned: true });
5425 let mut local_ret = match ret.result_ok { true => Ok( { () /*(*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.result)) })*/ }), false => Err( { *unsafe { Box::from_raw((*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.err)) }).take_inner()) } })};
5428 fn handle_query_channel_range(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: lightning::ln::msgs::QueryChannelRange) -> Result<(), lightning::ln::msgs::LightningError> {
5429 let mut ret = (self.handle_query_channel_range)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), crate::lightning::ln::msgs::QueryChannelRange { inner: ObjOps::heap_alloc(msg), is_owned: true });
5430 let mut local_ret = match ret.result_ok { true => Ok( { () /*(*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.result)) })*/ }), false => Err( { *unsafe { Box::from_raw((*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.err)) }).take_inner()) } })};
5433 fn handle_query_short_channel_ids(&self, mut their_node_id: &bitcoin::secp256k1::PublicKey, mut msg: lightning::ln::msgs::QueryShortChannelIds) -> Result<(), lightning::ln::msgs::LightningError> {
5434 let mut ret = (self.handle_query_short_channel_ids)(self.this_arg, crate::c_types::PublicKey::from_rust(&their_node_id), crate::lightning::ln::msgs::QueryShortChannelIds { inner: ObjOps::heap_alloc(msg), is_owned: true });
5435 let mut local_ret = match ret.result_ok { true => Ok( { () /*(*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.result)) })*/ }), false => Err( { *unsafe { Box::from_raw((*unsafe { Box::from_raw(<*mut _>::take_ptr(&mut ret.contents.err)) }).take_inner()) } })};
5440 // We're essentially a pointer already, or at least a set of pointers, so allow us to be used
5441 // directly as a Deref trait in higher-level structs:
5442 impl core::ops::Deref for RoutingMessageHandler {
5444 fn deref(&self) -> &Self {
5448 /// Calls the free function if one is set
5450 pub extern "C" fn RoutingMessageHandler_free(this_ptr: RoutingMessageHandler) { }
5451 impl Drop for RoutingMessageHandler {
5452 fn drop(&mut self) {
5453 if let Some(f) = self.free {
5458 mod fuzzy_internal_msgs {
5460 use alloc::str::FromStr;
5461 use core::ffi::c_void;
5462 use core::convert::Infallible;
5463 use bitcoin::hashes::Hash;
5464 use crate::c_types::*;
5465 #[cfg(feature="no-std")]
5466 use alloc::{vec::Vec, boxed::Box};
5470 /// Serialize the AcceptChannel object into a byte array which can be read by AcceptChannel_read
5471 pub extern "C" fn AcceptChannel_write(obj: &crate::lightning::ln::msgs::AcceptChannel) -> crate::c_types::derived::CVec_u8Z {
5472 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5475 pub(crate) extern "C" fn AcceptChannel_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5476 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeAcceptChannel) })
5479 /// Read a AcceptChannel from a byte array, created by AcceptChannel_write
5480 pub extern "C" fn AcceptChannel_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_AcceptChannelDecodeErrorZ {
5481 let res: Result<lightning::ln::msgs::AcceptChannel, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5482 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::AcceptChannel { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5486 /// Serialize the AnnouncementSignatures object into a byte array which can be read by AnnouncementSignatures_read
5487 pub extern "C" fn AnnouncementSignatures_write(obj: &crate::lightning::ln::msgs::AnnouncementSignatures) -> crate::c_types::derived::CVec_u8Z {
5488 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5491 pub(crate) extern "C" fn AnnouncementSignatures_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5492 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeAnnouncementSignatures) })
5495 /// Read a AnnouncementSignatures from a byte array, created by AnnouncementSignatures_write
5496 pub extern "C" fn AnnouncementSignatures_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_AnnouncementSignaturesDecodeErrorZ {
5497 let res: Result<lightning::ln::msgs::AnnouncementSignatures, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5498 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::AnnouncementSignatures { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5502 /// Serialize the ChannelReestablish object into a byte array which can be read by ChannelReestablish_read
5503 pub extern "C" fn ChannelReestablish_write(obj: &crate::lightning::ln::msgs::ChannelReestablish) -> crate::c_types::derived::CVec_u8Z {
5504 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5507 pub(crate) extern "C" fn ChannelReestablish_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5508 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeChannelReestablish) })
5511 /// Read a ChannelReestablish from a byte array, created by ChannelReestablish_write
5512 pub extern "C" fn ChannelReestablish_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ChannelReestablishDecodeErrorZ {
5513 let res: Result<lightning::ln::msgs::ChannelReestablish, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5514 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ChannelReestablish { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5518 /// Serialize the ClosingSigned object into a byte array which can be read by ClosingSigned_read
5519 pub extern "C" fn ClosingSigned_write(obj: &crate::lightning::ln::msgs::ClosingSigned) -> crate::c_types::derived::CVec_u8Z {
5520 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5523 pub(crate) extern "C" fn ClosingSigned_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5524 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeClosingSigned) })
5527 /// Read a ClosingSigned from a byte array, created by ClosingSigned_write
5528 pub extern "C" fn ClosingSigned_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ClosingSignedDecodeErrorZ {
5529 let res: Result<lightning::ln::msgs::ClosingSigned, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5530 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ClosingSigned { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5534 /// Serialize the ClosingSignedFeeRange object into a byte array which can be read by ClosingSignedFeeRange_read
5535 pub extern "C" fn ClosingSignedFeeRange_write(obj: &crate::lightning::ln::msgs::ClosingSignedFeeRange) -> crate::c_types::derived::CVec_u8Z {
5536 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5539 pub(crate) extern "C" fn ClosingSignedFeeRange_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5540 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeClosingSignedFeeRange) })
5543 /// Read a ClosingSignedFeeRange from a byte array, created by ClosingSignedFeeRange_write
5544 pub extern "C" fn ClosingSignedFeeRange_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ClosingSignedFeeRangeDecodeErrorZ {
5545 let res: Result<lightning::ln::msgs::ClosingSignedFeeRange, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5546 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ClosingSignedFeeRange { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5550 /// Serialize the CommitmentSigned object into a byte array which can be read by CommitmentSigned_read
5551 pub extern "C" fn CommitmentSigned_write(obj: &crate::lightning::ln::msgs::CommitmentSigned) -> crate::c_types::derived::CVec_u8Z {
5552 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5555 pub(crate) extern "C" fn CommitmentSigned_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5556 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeCommitmentSigned) })
5559 /// Read a CommitmentSigned from a byte array, created by CommitmentSigned_write
5560 pub extern "C" fn CommitmentSigned_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_CommitmentSignedDecodeErrorZ {
5561 let res: Result<lightning::ln::msgs::CommitmentSigned, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5562 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::CommitmentSigned { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5566 /// Serialize the FundingCreated object into a byte array which can be read by FundingCreated_read
5567 pub extern "C" fn FundingCreated_write(obj: &crate::lightning::ln::msgs::FundingCreated) -> crate::c_types::derived::CVec_u8Z {
5568 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5571 pub(crate) extern "C" fn FundingCreated_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5572 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeFundingCreated) })
5575 /// Read a FundingCreated from a byte array, created by FundingCreated_write
5576 pub extern "C" fn FundingCreated_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_FundingCreatedDecodeErrorZ {
5577 let res: Result<lightning::ln::msgs::FundingCreated, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5578 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::FundingCreated { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5582 /// Serialize the FundingSigned object into a byte array which can be read by FundingSigned_read
5583 pub extern "C" fn FundingSigned_write(obj: &crate::lightning::ln::msgs::FundingSigned) -> crate::c_types::derived::CVec_u8Z {
5584 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5587 pub(crate) extern "C" fn FundingSigned_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5588 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeFundingSigned) })
5591 /// Read a FundingSigned from a byte array, created by FundingSigned_write
5592 pub extern "C" fn FundingSigned_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_FundingSignedDecodeErrorZ {
5593 let res: Result<lightning::ln::msgs::FundingSigned, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5594 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::FundingSigned { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5598 /// Serialize the ChannelReady object into a byte array which can be read by ChannelReady_read
5599 pub extern "C" fn ChannelReady_write(obj: &crate::lightning::ln::msgs::ChannelReady) -> crate::c_types::derived::CVec_u8Z {
5600 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5603 pub(crate) extern "C" fn ChannelReady_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5604 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeChannelReady) })
5607 /// Read a ChannelReady from a byte array, created by ChannelReady_write
5608 pub extern "C" fn ChannelReady_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ChannelReadyDecodeErrorZ {
5609 let res: Result<lightning::ln::msgs::ChannelReady, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5610 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ChannelReady { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5614 /// Serialize the Init object into a byte array which can be read by Init_read
5615 pub extern "C" fn Init_write(obj: &crate::lightning::ln::msgs::Init) -> crate::c_types::derived::CVec_u8Z {
5616 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5619 pub(crate) extern "C" fn Init_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5620 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeInit) })
5623 /// Read a Init from a byte array, created by Init_write
5624 pub extern "C" fn Init_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_InitDecodeErrorZ {
5625 let res: Result<lightning::ln::msgs::Init, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5626 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::Init { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5630 /// Serialize the OpenChannel object into a byte array which can be read by OpenChannel_read
5631 pub extern "C" fn OpenChannel_write(obj: &crate::lightning::ln::msgs::OpenChannel) -> crate::c_types::derived::CVec_u8Z {
5632 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5635 pub(crate) extern "C" fn OpenChannel_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5636 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeOpenChannel) })
5639 /// Read a OpenChannel from a byte array, created by OpenChannel_write
5640 pub extern "C" fn OpenChannel_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_OpenChannelDecodeErrorZ {
5641 let res: Result<lightning::ln::msgs::OpenChannel, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5642 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::OpenChannel { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5646 /// Serialize the RevokeAndACK object into a byte array which can be read by RevokeAndACK_read
5647 pub extern "C" fn RevokeAndACK_write(obj: &crate::lightning::ln::msgs::RevokeAndACK) -> crate::c_types::derived::CVec_u8Z {
5648 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5651 pub(crate) extern "C" fn RevokeAndACK_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5652 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeRevokeAndACK) })
5655 /// Read a RevokeAndACK from a byte array, created by RevokeAndACK_write
5656 pub extern "C" fn RevokeAndACK_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_RevokeAndACKDecodeErrorZ {
5657 let res: Result<lightning::ln::msgs::RevokeAndACK, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5658 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::RevokeAndACK { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5662 /// Serialize the Shutdown object into a byte array which can be read by Shutdown_read
5663 pub extern "C" fn Shutdown_write(obj: &crate::lightning::ln::msgs::Shutdown) -> crate::c_types::derived::CVec_u8Z {
5664 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5667 pub(crate) extern "C" fn Shutdown_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5668 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeShutdown) })
5671 /// Read a Shutdown from a byte array, created by Shutdown_write
5672 pub extern "C" fn Shutdown_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ShutdownDecodeErrorZ {
5673 let res: Result<lightning::ln::msgs::Shutdown, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5674 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::Shutdown { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5678 /// Serialize the UpdateFailHTLC object into a byte array which can be read by UpdateFailHTLC_read
5679 pub extern "C" fn UpdateFailHTLC_write(obj: &crate::lightning::ln::msgs::UpdateFailHTLC) -> crate::c_types::derived::CVec_u8Z {
5680 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5683 pub(crate) extern "C" fn UpdateFailHTLC_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5684 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUpdateFailHTLC) })
5687 /// Read a UpdateFailHTLC from a byte array, created by UpdateFailHTLC_write
5688 pub extern "C" fn UpdateFailHTLC_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UpdateFailHTLCDecodeErrorZ {
5689 let res: Result<lightning::ln::msgs::UpdateFailHTLC, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5690 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UpdateFailHTLC { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5694 /// Serialize the UpdateFailMalformedHTLC object into a byte array which can be read by UpdateFailMalformedHTLC_read
5695 pub extern "C" fn UpdateFailMalformedHTLC_write(obj: &crate::lightning::ln::msgs::UpdateFailMalformedHTLC) -> crate::c_types::derived::CVec_u8Z {
5696 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5699 pub(crate) extern "C" fn UpdateFailMalformedHTLC_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5700 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUpdateFailMalformedHTLC) })
5703 /// Read a UpdateFailMalformedHTLC from a byte array, created by UpdateFailMalformedHTLC_write
5704 pub extern "C" fn UpdateFailMalformedHTLC_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UpdateFailMalformedHTLCDecodeErrorZ {
5705 let res: Result<lightning::ln::msgs::UpdateFailMalformedHTLC, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5706 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UpdateFailMalformedHTLC { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5710 /// Serialize the UpdateFee object into a byte array which can be read by UpdateFee_read
5711 pub extern "C" fn UpdateFee_write(obj: &crate::lightning::ln::msgs::UpdateFee) -> crate::c_types::derived::CVec_u8Z {
5712 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5715 pub(crate) extern "C" fn UpdateFee_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5716 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUpdateFee) })
5719 /// Read a UpdateFee from a byte array, created by UpdateFee_write
5720 pub extern "C" fn UpdateFee_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UpdateFeeDecodeErrorZ {
5721 let res: Result<lightning::ln::msgs::UpdateFee, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5722 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UpdateFee { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5726 /// Serialize the UpdateFulfillHTLC object into a byte array which can be read by UpdateFulfillHTLC_read
5727 pub extern "C" fn UpdateFulfillHTLC_write(obj: &crate::lightning::ln::msgs::UpdateFulfillHTLC) -> crate::c_types::derived::CVec_u8Z {
5728 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5731 pub(crate) extern "C" fn UpdateFulfillHTLC_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5732 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUpdateFulfillHTLC) })
5735 /// Read a UpdateFulfillHTLC from a byte array, created by UpdateFulfillHTLC_write
5736 pub extern "C" fn UpdateFulfillHTLC_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UpdateFulfillHTLCDecodeErrorZ {
5737 let res: Result<lightning::ln::msgs::UpdateFulfillHTLC, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5738 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UpdateFulfillHTLC { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5742 /// Serialize the UpdateAddHTLC object into a byte array which can be read by UpdateAddHTLC_read
5743 pub extern "C" fn UpdateAddHTLC_write(obj: &crate::lightning::ln::msgs::UpdateAddHTLC) -> crate::c_types::derived::CVec_u8Z {
5744 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5747 pub(crate) extern "C" fn UpdateAddHTLC_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5748 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUpdateAddHTLC) })
5751 /// Read a UpdateAddHTLC from a byte array, created by UpdateAddHTLC_write
5752 pub extern "C" fn UpdateAddHTLC_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UpdateAddHTLCDecodeErrorZ {
5753 let res: Result<lightning::ln::msgs::UpdateAddHTLC, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5754 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UpdateAddHTLC { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5758 /// Serialize the Ping object into a byte array which can be read by Ping_read
5759 pub extern "C" fn Ping_write(obj: &crate::lightning::ln::msgs::Ping) -> crate::c_types::derived::CVec_u8Z {
5760 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5763 pub(crate) extern "C" fn Ping_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5764 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativePing) })
5767 /// Read a Ping from a byte array, created by Ping_write
5768 pub extern "C" fn Ping_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_PingDecodeErrorZ {
5769 let res: Result<lightning::ln::msgs::Ping, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5770 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::Ping { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5774 /// Serialize the Pong object into a byte array which can be read by Pong_read
5775 pub extern "C" fn Pong_write(obj: &crate::lightning::ln::msgs::Pong) -> crate::c_types::derived::CVec_u8Z {
5776 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5779 pub(crate) extern "C" fn Pong_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5780 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativePong) })
5783 /// Read a Pong from a byte array, created by Pong_write
5784 pub extern "C" fn Pong_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_PongDecodeErrorZ {
5785 let res: Result<lightning::ln::msgs::Pong, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5786 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::Pong { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5790 /// Serialize the UnsignedChannelAnnouncement object into a byte array which can be read by UnsignedChannelAnnouncement_read
5791 pub extern "C" fn UnsignedChannelAnnouncement_write(obj: &crate::lightning::ln::msgs::UnsignedChannelAnnouncement) -> crate::c_types::derived::CVec_u8Z {
5792 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5795 pub(crate) extern "C" fn UnsignedChannelAnnouncement_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5796 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUnsignedChannelAnnouncement) })
5799 /// Read a UnsignedChannelAnnouncement from a byte array, created by UnsignedChannelAnnouncement_write
5800 pub extern "C" fn UnsignedChannelAnnouncement_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UnsignedChannelAnnouncementDecodeErrorZ {
5801 let res: Result<lightning::ln::msgs::UnsignedChannelAnnouncement, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5802 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UnsignedChannelAnnouncement { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5806 /// Serialize the ChannelAnnouncement object into a byte array which can be read by ChannelAnnouncement_read
5807 pub extern "C" fn ChannelAnnouncement_write(obj: &crate::lightning::ln::msgs::ChannelAnnouncement) -> crate::c_types::derived::CVec_u8Z {
5808 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5811 pub(crate) extern "C" fn ChannelAnnouncement_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5812 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeChannelAnnouncement) })
5815 /// Read a ChannelAnnouncement from a byte array, created by ChannelAnnouncement_write
5816 pub extern "C" fn ChannelAnnouncement_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ChannelAnnouncementDecodeErrorZ {
5817 let res: Result<lightning::ln::msgs::ChannelAnnouncement, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5818 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ChannelAnnouncement { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5822 /// Serialize the UnsignedChannelUpdate object into a byte array which can be read by UnsignedChannelUpdate_read
5823 pub extern "C" fn UnsignedChannelUpdate_write(obj: &crate::lightning::ln::msgs::UnsignedChannelUpdate) -> crate::c_types::derived::CVec_u8Z {
5824 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5827 pub(crate) extern "C" fn UnsignedChannelUpdate_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5828 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUnsignedChannelUpdate) })
5831 /// Read a UnsignedChannelUpdate from a byte array, created by UnsignedChannelUpdate_write
5832 pub extern "C" fn UnsignedChannelUpdate_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UnsignedChannelUpdateDecodeErrorZ {
5833 let res: Result<lightning::ln::msgs::UnsignedChannelUpdate, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5834 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UnsignedChannelUpdate { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5838 /// Serialize the ChannelUpdate object into a byte array which can be read by ChannelUpdate_read
5839 pub extern "C" fn ChannelUpdate_write(obj: &crate::lightning::ln::msgs::ChannelUpdate) -> crate::c_types::derived::CVec_u8Z {
5840 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5843 pub(crate) extern "C" fn ChannelUpdate_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5844 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeChannelUpdate) })
5847 /// Read a ChannelUpdate from a byte array, created by ChannelUpdate_write
5848 pub extern "C" fn ChannelUpdate_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ChannelUpdateDecodeErrorZ {
5849 let res: Result<lightning::ln::msgs::ChannelUpdate, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5850 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ChannelUpdate { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5854 /// Serialize the ErrorMessage object into a byte array which can be read by ErrorMessage_read
5855 pub extern "C" fn ErrorMessage_write(obj: &crate::lightning::ln::msgs::ErrorMessage) -> crate::c_types::derived::CVec_u8Z {
5856 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5859 pub(crate) extern "C" fn ErrorMessage_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5860 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeErrorMessage) })
5863 /// Read a ErrorMessage from a byte array, created by ErrorMessage_write
5864 pub extern "C" fn ErrorMessage_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ErrorMessageDecodeErrorZ {
5865 let res: Result<lightning::ln::msgs::ErrorMessage, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5866 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ErrorMessage { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5870 /// Serialize the WarningMessage object into a byte array which can be read by WarningMessage_read
5871 pub extern "C" fn WarningMessage_write(obj: &crate::lightning::ln::msgs::WarningMessage) -> crate::c_types::derived::CVec_u8Z {
5872 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5875 pub(crate) extern "C" fn WarningMessage_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5876 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeWarningMessage) })
5879 /// Read a WarningMessage from a byte array, created by WarningMessage_write
5880 pub extern "C" fn WarningMessage_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_WarningMessageDecodeErrorZ {
5881 let res: Result<lightning::ln::msgs::WarningMessage, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5882 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::WarningMessage { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5886 /// Serialize the UnsignedNodeAnnouncement object into a byte array which can be read by UnsignedNodeAnnouncement_read
5887 pub extern "C" fn UnsignedNodeAnnouncement_write(obj: &crate::lightning::ln::msgs::UnsignedNodeAnnouncement) -> crate::c_types::derived::CVec_u8Z {
5888 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5891 pub(crate) extern "C" fn UnsignedNodeAnnouncement_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5892 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeUnsignedNodeAnnouncement) })
5895 /// Read a UnsignedNodeAnnouncement from a byte array, created by UnsignedNodeAnnouncement_write
5896 pub extern "C" fn UnsignedNodeAnnouncement_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_UnsignedNodeAnnouncementDecodeErrorZ {
5897 let res: Result<lightning::ln::msgs::UnsignedNodeAnnouncement, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5898 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::UnsignedNodeAnnouncement { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5902 /// Serialize the NodeAnnouncement object into a byte array which can be read by NodeAnnouncement_read
5903 pub extern "C" fn NodeAnnouncement_write(obj: &crate::lightning::ln::msgs::NodeAnnouncement) -> crate::c_types::derived::CVec_u8Z {
5904 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5907 pub(crate) extern "C" fn NodeAnnouncement_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5908 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeNodeAnnouncement) })
5911 /// Read a NodeAnnouncement from a byte array, created by NodeAnnouncement_write
5912 pub extern "C" fn NodeAnnouncement_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_NodeAnnouncementDecodeErrorZ {
5913 let res: Result<lightning::ln::msgs::NodeAnnouncement, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5914 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::NodeAnnouncement { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5918 /// Read a QueryShortChannelIds from a byte array, created by QueryShortChannelIds_write
5919 pub extern "C" fn QueryShortChannelIds_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_QueryShortChannelIdsDecodeErrorZ {
5920 let res: Result<lightning::ln::msgs::QueryShortChannelIds, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5921 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::QueryShortChannelIds { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5925 /// Serialize the QueryShortChannelIds object into a byte array which can be read by QueryShortChannelIds_read
5926 pub extern "C" fn QueryShortChannelIds_write(obj: &crate::lightning::ln::msgs::QueryShortChannelIds) -> crate::c_types::derived::CVec_u8Z {
5927 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5930 pub(crate) extern "C" fn QueryShortChannelIds_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5931 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeQueryShortChannelIds) })
5934 /// Serialize the ReplyShortChannelIdsEnd object into a byte array which can be read by ReplyShortChannelIdsEnd_read
5935 pub extern "C" fn ReplyShortChannelIdsEnd_write(obj: &crate::lightning::ln::msgs::ReplyShortChannelIdsEnd) -> crate::c_types::derived::CVec_u8Z {
5936 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5939 pub(crate) extern "C" fn ReplyShortChannelIdsEnd_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5940 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeReplyShortChannelIdsEnd) })
5943 /// Read a ReplyShortChannelIdsEnd from a byte array, created by ReplyShortChannelIdsEnd_write
5944 pub extern "C" fn ReplyShortChannelIdsEnd_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ReplyShortChannelIdsEndDecodeErrorZ {
5945 let res: Result<lightning::ln::msgs::ReplyShortChannelIdsEnd, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5946 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ReplyShortChannelIdsEnd { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5949 ///\n\t * Calculates the overflow safe ending block height for the query.\n\t * Overflow returns `0xffffffff`, otherwise returns `first_blocknum + number_of_blocks`\n\t
5952 pub extern "C" fn QueryChannelRange_end_blocknum(this_arg: &crate::lightning::ln::msgs::QueryChannelRange) -> u32 {
5953 let mut ret = unsafe { &*ObjOps::untweak_ptr(this_arg.inner) }.end_blocknum();
5958 /// Serialize the QueryChannelRange object into a byte array which can be read by QueryChannelRange_read
5959 pub extern "C" fn QueryChannelRange_write(obj: &crate::lightning::ln::msgs::QueryChannelRange) -> crate::c_types::derived::CVec_u8Z {
5960 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5963 pub(crate) extern "C" fn QueryChannelRange_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5964 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeQueryChannelRange) })
5967 /// Read a QueryChannelRange from a byte array, created by QueryChannelRange_write
5968 pub extern "C" fn QueryChannelRange_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_QueryChannelRangeDecodeErrorZ {
5969 let res: Result<lightning::ln::msgs::QueryChannelRange, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5970 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::QueryChannelRange { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5974 /// Read a ReplyChannelRange from a byte array, created by ReplyChannelRange_write
5975 pub extern "C" fn ReplyChannelRange_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_ReplyChannelRangeDecodeErrorZ {
5976 let res: Result<lightning::ln::msgs::ReplyChannelRange, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
5977 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::ReplyChannelRange { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };
5981 /// Serialize the ReplyChannelRange object into a byte array which can be read by ReplyChannelRange_read
5982 pub extern "C" fn ReplyChannelRange_write(obj: &crate::lightning::ln::msgs::ReplyChannelRange) -> crate::c_types::derived::CVec_u8Z {
5983 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5986 pub(crate) extern "C" fn ReplyChannelRange_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5987 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeReplyChannelRange) })
5990 /// Serialize the GossipTimestampFilter object into a byte array which can be read by GossipTimestampFilter_read
5991 pub extern "C" fn GossipTimestampFilter_write(obj: &crate::lightning::ln::msgs::GossipTimestampFilter) -> crate::c_types::derived::CVec_u8Z {
5992 crate::c_types::serialize_obj(unsafe { &*obj }.get_native_ref())
5995 pub(crate) extern "C" fn GossipTimestampFilter_write_void(obj: *const c_void) -> crate::c_types::derived::CVec_u8Z {
5996 crate::c_types::serialize_obj(unsafe { &*(obj as *const nativeGossipTimestampFilter) })
5999 /// Read a GossipTimestampFilter from a byte array, created by GossipTimestampFilter_write
6000 pub extern "C" fn GossipTimestampFilter_read(ser: crate::c_types::u8slice) -> crate::c_types::derived::CResult_GossipTimestampFilterDecodeErrorZ {
6001 let res: Result<lightning::ln::msgs::GossipTimestampFilter, lightning::ln::msgs::DecodeError> = crate::c_types::deserialize_obj(ser);
6002 let mut local_res = match res { Ok(mut o) => crate::c_types::CResultTempl::ok( { crate::lightning::ln::msgs::GossipTimestampFilter { inner: ObjOps::heap_alloc(o), is_owned: true } }).into(), Err(mut e) => crate::c_types::CResultTempl::err( { crate::lightning::ln::msgs::DecodeError { inner: ObjOps::heap_alloc(e), is_owned: true } }).into() };