1 //! This module contains standard C-mapped types for types not in the original crate.
3 /// Auto-generated C-mapped types for templated containers
6 use bitcoin::Transaction as BitcoinTransaction;
7 use bitcoin::hashes::Hash;
8 use bitcoin::secp256k1::key::PublicKey as SecpPublicKey;
9 use bitcoin::secp256k1::key::SecretKey as SecpSecretKey;
10 use bitcoin::secp256k1::Signature as SecpSignature;
11 use bitcoin::secp256k1::Error as SecpError;
12 use bitcoin::secp256k1::recovery::RecoveryId;
13 use bitcoin::secp256k1::recovery::RecoverableSignature as SecpRecoverableSignature;
16 use std::convert::TryInto; // Bindings need at least rustc 1.34
18 /// Integer in the range `0..32`
19 #[derive(PartialEq, Eq, Copy, Clone)]
20 #[allow(non_camel_case_types)]
24 impl From<bech32::u5> for u5 {
25 fn from(o: bech32::u5) -> Self { Self(o.to_u8()) }
27 impl Into<bech32::u5> for u5 {
28 fn into(self) -> bech32::u5 { bech32::u5::try_from_u8(self.0).expect("u5 objects must be in the range 0..32") }
33 /// Represents a valid secp256k1 public key serialized in "compressed form" as a 33 byte array.
34 pub struct PublicKey {
35 /// The bytes of the public key
36 pub compressed_form: [u8; 33],
39 pub(crate) fn from_rust(pk: &SecpPublicKey) -> Self {
41 compressed_form: pk.serialize(),
44 pub(crate) fn into_rust(&self) -> SecpPublicKey {
45 SecpPublicKey::from_slice(&self.compressed_form).unwrap()
47 pub(crate) fn is_null(&self) -> bool { self.compressed_form[..] == [0; 33][..] }
48 pub(crate) fn null() -> Self { Self { compressed_form: [0; 33] } }
52 /// Represents a valid secp256k1 secret key serialized as a 32 byte array.
53 pub struct SecretKey {
54 /// The bytes of the secret key
58 // from_rust isn't implemented for a ref since we just return byte array refs directly
59 pub(crate) fn from_rust(sk: SecpSecretKey) -> Self {
60 let mut bytes = [0; 32];
61 bytes.copy_from_slice(&sk[..]);
64 pub(crate) fn into_rust(&self) -> SecpSecretKey {
65 SecpSecretKey::from_slice(&self.bytes).unwrap()
71 /// Represents a secp256k1 signature serialized as two 32-byte numbers
72 pub struct Signature {
73 /// The bytes of the signature in "compact" form
74 pub compact_form: [u8; 64],
77 pub(crate) fn from_rust(pk: &SecpSignature) -> Self {
79 compact_form: pk.serialize_compact(),
82 pub(crate) fn into_rust(&self) -> SecpSignature {
83 SecpSignature::from_compact(&self.compact_form).unwrap()
85 // The following are used for Option<Signature> which we support, but don't use anymore
86 #[allow(unused)] pub(crate) fn is_null(&self) -> bool { self.compact_form[..] == [0; 64][..] }
87 #[allow(unused)] pub(crate) fn null() -> Self { Self { compact_form: [0; 64] } }
92 /// Represents a secp256k1 signature serialized as two 32-byte numbers as well as a tag which
93 /// allows recovering the exact public key which created the signature given the message.
94 pub struct RecoverableSignature {
95 /// The bytes of the signature in "compact" form plus a "Recovery ID" which allows for
97 pub serialized_form: [u8; 68],
99 impl RecoverableSignature {
100 pub(crate) fn from_rust(pk: &SecpRecoverableSignature) -> Self {
101 let (id, compact_form) = pk.serialize_compact();
102 let mut serialized_form = [0; 68];
103 serialized_form[0..64].copy_from_slice(&compact_form[..]);
104 serialized_form[64..].copy_from_slice(&id.to_i32().to_le_bytes());
105 Self { serialized_form }
107 pub(crate) fn into_rust(&self) -> SecpRecoverableSignature {
109 id.copy_from_slice(&self.serialized_form[64..]);
110 SecpRecoverableSignature::from_compact(&self.serialized_form[0..64],
111 RecoveryId::from_i32(i32::from_le_bytes(id)).expect("Invalid Recovery ID"))
117 /// Represents an error returned from libsecp256k1 during validation of some secp256k1 data
118 pub enum Secp256k1Error {
119 /// Signature failed verification
121 /// Badly sized message ("messages" are actually fixed-sized digests; see the MESSAGE_SIZE constant)
131 /// Invalid tweak for add_assign or mul_assign
133 /// tweak_add_check failed on an xonly public key
135 /// Didn't pass enough memory to context creation with preallocated memory
138 impl Secp256k1Error {
139 pub(crate) fn from_rust(err: SecpError) -> Self {
141 SecpError::IncorrectSignature => Secp256k1Error::IncorrectSignature,
142 SecpError::InvalidMessage => Secp256k1Error::InvalidMessage,
143 SecpError::InvalidPublicKey => Secp256k1Error::InvalidPublicKey,
144 SecpError::InvalidSignature => Secp256k1Error::InvalidSignature,
145 SecpError::InvalidSecretKey => Secp256k1Error::InvalidSecretKey,
146 SecpError::InvalidRecoveryId => Secp256k1Error::InvalidRecoveryId,
147 SecpError::InvalidTweak => Secp256k1Error::InvalidTweak,
148 SecpError::TweakCheckFailed => Secp256k1Error::TweakCheckFailed,
149 SecpError::NotEnoughMemory => Secp256k1Error::NotEnoughMemory,
155 #[allow(missing_docs)] // If there's no docs upstream, that's good enough for us
156 /// Represents an IO Error. Note that some information is lost in the conversion from Rust.
178 pub(crate) fn from_rust(err: std::io::Error) -> Self {
180 std::io::ErrorKind::NotFound => IOError::NotFound,
181 std::io::ErrorKind::PermissionDenied => IOError::PermissionDenied,
182 std::io::ErrorKind::ConnectionRefused => IOError::ConnectionRefused,
183 std::io::ErrorKind::ConnectionReset => IOError::ConnectionReset,
184 std::io::ErrorKind::ConnectionAborted => IOError::ConnectionAborted,
185 std::io::ErrorKind::NotConnected => IOError::NotConnected,
186 std::io::ErrorKind::AddrInUse => IOError::AddrInUse,
187 std::io::ErrorKind::AddrNotAvailable => IOError::AddrNotAvailable,
188 std::io::ErrorKind::BrokenPipe => IOError::BrokenPipe,
189 std::io::ErrorKind::AlreadyExists => IOError::AlreadyExists,
190 std::io::ErrorKind::WouldBlock => IOError::WouldBlock,
191 std::io::ErrorKind::InvalidInput => IOError::InvalidInput,
192 std::io::ErrorKind::InvalidData => IOError::InvalidData,
193 std::io::ErrorKind::TimedOut => IOError::TimedOut,
194 std::io::ErrorKind::WriteZero => IOError::WriteZero,
195 std::io::ErrorKind::Interrupted => IOError::Interrupted,
196 std::io::ErrorKind::Other => IOError::Other,
197 std::io::ErrorKind::UnexpectedEof => IOError::UnexpectedEof,
201 pub(crate) fn to_rust(&self) -> std::io::Error {
202 std::io::Error::new(match self {
203 IOError::NotFound => std::io::ErrorKind::NotFound,
204 IOError::PermissionDenied => std::io::ErrorKind::PermissionDenied,
205 IOError::ConnectionRefused => std::io::ErrorKind::ConnectionRefused,
206 IOError::ConnectionReset => std::io::ErrorKind::ConnectionReset,
207 IOError::ConnectionAborted => std::io::ErrorKind::ConnectionAborted,
208 IOError::NotConnected => std::io::ErrorKind::NotConnected,
209 IOError::AddrInUse => std::io::ErrorKind::AddrInUse,
210 IOError::AddrNotAvailable => std::io::ErrorKind::AddrNotAvailable,
211 IOError::BrokenPipe => std::io::ErrorKind::BrokenPipe,
212 IOError::AlreadyExists => std::io::ErrorKind::AlreadyExists,
213 IOError::WouldBlock => std::io::ErrorKind::WouldBlock,
214 IOError::InvalidInput => std::io::ErrorKind::InvalidInput,
215 IOError::InvalidData => std::io::ErrorKind::InvalidData,
216 IOError::TimedOut => std::io::ErrorKind::TimedOut,
217 IOError::WriteZero => std::io::ErrorKind::WriteZero,
218 IOError::Interrupted => std::io::ErrorKind::Interrupted,
219 IOError::Other => std::io::ErrorKind::Other,
220 IOError::UnexpectedEof => std::io::ErrorKind::UnexpectedEof,
226 /// A serialized transaction, in (pointer, length) form.
228 /// This type optionally owns its own memory, and thus the semantics around access change based on
229 /// the `data_is_owned` flag. If `data_is_owned` is set, you must call `Transaction_free` to free
230 /// the underlying buffer before the object goes out of scope. If `data_is_owned` is not set, any
231 /// access to the buffer after the scope in which the object was provided to you is invalid. eg,
232 /// access after you return from the call in which a `!data_is_owned` `Transaction` is provided to
233 /// you would be invalid.
235 /// Note that, while it may change in the future, because transactions on the Rust side are stored
236 /// in a deserialized form, all `Transaction`s generated on the Rust side will have `data_is_owned`
237 /// set. Similarly, while it may change in the future, all `Transaction`s you pass to Rust may have
238 /// `data_is_owned` either set or unset at your discretion.
239 pub struct Transaction {
240 /// The serialized transaction data.
242 /// This is non-const for your convenience, an object passed to Rust is never written to.
244 /// The length of the serialized transaction
246 /// Whether the data pointed to by `data` should be freed or not.
247 pub data_is_owned: bool,
250 pub(crate) fn into_bitcoin(&self) -> BitcoinTransaction {
251 if self.datalen == 0 { panic!("0-length buffer can never represent a valid Transaction"); }
252 ::bitcoin::consensus::encode::deserialize(unsafe { std::slice::from_raw_parts(self.data, self.datalen) }).unwrap()
254 pub(crate) fn from_bitcoin(btc: &BitcoinTransaction) -> Self {
255 let vec = ::bitcoin::consensus::encode::serialize(btc);
256 let datalen = vec.len();
257 let data = Box::into_raw(vec.into_boxed_slice());
259 data: unsafe { (*data).as_mut_ptr() },
265 impl Drop for Transaction {
267 if self.data_is_owned && self.datalen != 0 {
268 let _ = derived::CVec_u8Z { data: self.data as *mut u8, datalen: self.datalen };
273 /// Frees the data buffer, if data_is_owned is set and datalen > 0.
274 pub extern "C" fn Transaction_free(_res: Transaction) { }
276 pub(crate) fn bitcoin_to_C_outpoint(outpoint: ::bitcoin::blockdata::transaction::OutPoint) -> crate::lightning::chain::transaction::OutPoint {
277 crate::lightning::chain::transaction::OutPoint_new(ThirtyTwoBytes { data: outpoint.txid.into_inner() }, outpoint.vout.try_into().unwrap())
282 /// A transaction output including a scriptPubKey and value.
283 /// This type *does* own its own memory, so must be free'd appropriately.
285 /// The script_pubkey in this output
286 pub script_pubkey: derived::CVec_u8Z,
287 /// The value, in satoshis, of this output
292 pub(crate) fn into_rust(mut self) -> ::bitcoin::blockdata::transaction::TxOut {
293 ::bitcoin::blockdata::transaction::TxOut {
294 script_pubkey: self.script_pubkey.into_rust().into(),
298 pub(crate) fn from_rust(txout: ::bitcoin::blockdata::transaction::TxOut) -> Self {
300 script_pubkey: derived::CVec_u8Z::from(txout.script_pubkey.into_bytes()),
306 /// Frees the data pointed to by script_pubkey.
307 pub extern "C" fn TxOut_free(_res: TxOut) { }
309 /// Creates a new TxOut which has the same data as `orig` but with a new script buffer.
310 pub extern "C" fn TxOut_clone(orig: &TxOut) -> TxOut { orig.clone() }
313 /// A "slice" referencing some byte array. This is simply a length-tagged pointer which does not
314 /// own the memory pointed to by data.
316 /// A pointer to the byte buffer
318 /// The number of bytes pointed to by `data`.
322 pub(crate) fn from_slice(s: &[u8]) -> Self {
328 pub(crate) fn to_slice(&self) -> &[u8] {
329 if self.datalen == 0 { return &[]; }
330 unsafe { std::slice::from_raw_parts(self.data, self.datalen) }
335 #[derive(Copy, Clone)]
336 /// Arbitrary 32 bytes, which could represent one of a few different things. You probably want to
337 /// look up the corresponding function in rust-lightning's docs.
338 pub struct ThirtyTwoBytes {
339 /// The thirty-two bytes
342 impl ThirtyTwoBytes {
343 pub(crate) fn null() -> Self {
344 Self { data: [0; 32] }
349 /// A 3-byte byte array.
350 pub struct ThreeBytes { /** The three bytes */ pub data: [u8; 3], }
353 /// A 4-byte byte array.
354 pub struct FourBytes { /** The four bytes */ pub data: [u8; 4], }
357 /// A 10-byte byte array.
358 pub struct TenBytes { /** The ten bytes */ pub data: [u8; 10], }
361 /// A 16-byte byte array.
362 pub struct SixteenBytes { /** The sixteen bytes */ pub data: [u8; 16], }
365 /// A 20-byte byte array.
366 pub struct TwentyBytes { /** The twenty bytes */ pub data: [u8; 20], }
368 pub(crate) struct VecWriter(pub Vec<u8>);
369 impl lightning::util::ser::Writer for VecWriter {
370 fn write_all(&mut self, buf: &[u8]) -> Result<(), ::std::io::Error> {
371 self.0.extend_from_slice(buf);
374 fn size_hint(&mut self, size: usize) {
375 self.0.reserve_exact(size);
378 pub(crate) fn serialize_obj<I: lightning::util::ser::Writeable>(i: &I) -> derived::CVec_u8Z {
379 let mut out = VecWriter(Vec::new());
380 i.write(&mut out).unwrap();
381 derived::CVec_u8Z::from(out.0)
383 pub(crate) fn deserialize_obj<I: lightning::util::ser::Readable>(s: u8slice) -> Result<I, lightning::ln::msgs::DecodeError> {
384 I::read(&mut s.to_slice())
386 pub(crate) fn deserialize_obj_arg<A, I: lightning::util::ser::ReadableArgs<A>>(s: u8slice, args: A) -> Result<I, lightning::ln::msgs::DecodeError> {
387 I::read(&mut s.to_slice(), args)
392 /// A Rust str object, ie a reference to a UTF8-valid string.
393 /// This is *not* null-terminated so cannot be used directly as a C string!
395 /// A pointer to the string's bytes, in UTF8 encoding
396 pub chars: *const u8,
397 /// The number of bytes (not characters!) pointed to by `chars`
399 /// Whether the data pointed to by `chars` should be freed or not.
400 pub chars_is_owned: bool,
402 impl Into<Str> for &'static str {
403 fn into(self) -> Str {
404 Str { chars: self.as_ptr(), len: self.len(), chars_is_owned: false }
408 pub(crate) fn into_str(&self) -> &'static str {
409 if self.len == 0 { return ""; }
410 std::str::from_utf8(unsafe { std::slice::from_raw_parts(self.chars, self.len) }).unwrap()
412 pub(crate) fn into_string(mut self) -> String {
413 let bytes = if self.len == 0 {
415 } else if self.chars_is_owned {
417 Box::from_raw(std::slice::from_raw_parts_mut(unsafe { self.chars as *mut u8 }, self.len))
419 self.chars_is_owned = false;
422 let mut ret = Vec::with_capacity(self.len);
423 ret.extend_from_slice(unsafe { std::slice::from_raw_parts(self.chars, self.len) });
426 String::from_utf8(bytes).unwrap()
429 impl Into<Str> for String {
430 fn into(self) -> Str {
431 let s = Box::leak(self.into_boxed_str());
432 Str { chars: s.as_ptr(), len: s.len(), chars_is_owned: true }
438 if self.chars_is_owned && self.len != 0 {
439 let _ = derived::CVec_u8Z { data: self.chars as *mut u8, datalen: self.len };
444 /// Frees the data buffer, if chars_is_owned is set and len > 0.
445 pub extern "C" fn Str_free(_res: Str) { }
447 // Note that the C++ headers memset(0) all the Templ types to avoid deallocation!
448 // Thus, they must gracefully handle being completely null in _free.
450 // TODO: Integer/bool primitives should avoid the pointer indirection for underlying types
451 // everywhere in the containers.
454 pub(crate) union CResultPtr<O, E> {
455 pub(crate) result: *mut O,
456 pub(crate) err: *mut E,
459 pub(crate) struct CResultTempl<O, E> {
460 pub(crate) contents: CResultPtr<O, E>,
461 pub(crate) result_ok: bool,
463 impl<O, E> CResultTempl<O, E> {
464 pub(crate) extern "C" fn ok(o: O) -> Self {
466 contents: CResultPtr {
467 result: Box::into_raw(Box::new(o)),
472 pub(crate) extern "C" fn err(e: E) -> Self {
474 contents: CResultPtr {
475 err: Box::into_raw(Box::new(e)),
481 impl<O, E> Drop for CResultTempl<O, E> {
484 if unsafe { !self.contents.result.is_null() } {
485 unsafe { Box::from_raw(self.contents.result) };
487 } else if unsafe { !self.contents.err.is_null() } {
488 unsafe { Box::from_raw(self.contents.err) };
493 /// Utility to make it easy to set a pointer to null and get its original value in line.
494 pub(crate) trait TakePointer<T> {
495 fn take_ptr(&mut self) -> T;
497 impl<T> TakePointer<*const T> for *const T {
498 fn take_ptr(&mut self) -> *const T {
500 *self = std::ptr::null();
504 impl<T> TakePointer<*mut T> for *mut T {
505 fn take_ptr(&mut self) -> *mut T {
507 *self = std::ptr::null_mut();