6 namespace org { namespace ldk { namespace structs {
10 * Information about a spendable output to a P2WSH script.
12 * See [`SpendableOutputDescriptor::DelayedPaymentOutput`] for more details on how to spend this.
14 public class DelayedPaymentOutputDescriptor : CommonBase {
15 internal DelayedPaymentOutputDescriptor(object _dummy, long ptr) : base(ptr) { }
16 ~DelayedPaymentOutputDescriptor() {
17 if (ptr != 0) { bindings.DelayedPaymentOutputDescriptor_free(ptr); }
21 * The outpoint which is spendable.
23 public OutPoint get_outpoint() {
24 long ret = bindings.DelayedPaymentOutputDescriptor_get_outpoint(this.ptr);
26 if (ret >= 0 && ret <= 4096) { return null; }
27 org.ldk.structs.OutPoint ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.OutPoint(null, ret); }
28 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(this); };
33 * The outpoint which is spendable.
35 public void set_outpoint(org.ldk.structs.OutPoint val) {
36 bindings.DelayedPaymentOutputDescriptor_set_outpoint(this.ptr, val.ptr);
39 if (this != null) { this.ptrs_to.AddLast(val); };
43 * Per commitment point to derive the delayed payment key by key holder.
45 public byte[] get_per_commitment_point() {
46 long ret = bindings.DelayedPaymentOutputDescriptor_get_per_commitment_point(this.ptr);
48 if (ret >= 0 && ret <= 4096) { return null; }
49 byte[] ret_conv = InternalUtils.decodeUint8Array(ret);
54 * Per commitment point to derive the delayed payment key by key holder.
56 public void set_per_commitment_point(byte[] val) {
57 bindings.DelayedPaymentOutputDescriptor_set_per_commitment_point(this.ptr, InternalUtils.encodeUint8Array(InternalUtils.check_arr_len(val, 33)));
63 * The `nSequence` value which must be set in the spending input to satisfy the `OP_CSV` in
66 public short get_to_self_delay() {
67 short ret = bindings.DelayedPaymentOutputDescriptor_get_to_self_delay(this.ptr);
73 * The `nSequence` value which must be set in the spending input to satisfy the `OP_CSV` in
76 public void set_to_self_delay(short val) {
77 bindings.DelayedPaymentOutputDescriptor_set_to_self_delay(this.ptr, val);
83 * The output which is referenced by the given outpoint.
85 public TxOut get_output() {
86 long ret = bindings.DelayedPaymentOutputDescriptor_get_output(this.ptr);
88 if (ret >= 0 && ret <= 4096) { return null; }
89 TxOut ret_conv = new TxOut(null, ret);
94 * The output which is referenced by the given outpoint.
96 public void set_output(org.ldk.structs.TxOut val) {
97 bindings.DelayedPaymentOutputDescriptor_set_output(this.ptr, val.ptr);
103 * The revocation point specific to the commitment transaction which was broadcast. Used to
104 * derive the witnessScript for this output.
106 public RevocationKey get_revocation_pubkey() {
107 long ret = bindings.DelayedPaymentOutputDescriptor_get_revocation_pubkey(this.ptr);
109 if (ret >= 0 && ret <= 4096) { return null; }
110 org.ldk.structs.RevocationKey ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.RevocationKey(null, ret); }
111 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(this); };
116 * The revocation point specific to the commitment transaction which was broadcast. Used to
117 * derive the witnessScript for this output.
119 public void set_revocation_pubkey(org.ldk.structs.RevocationKey val) {
120 bindings.DelayedPaymentOutputDescriptor_set_revocation_pubkey(this.ptr, val.ptr);
123 if (this != null) { this.ptrs_to.AddLast(val); };
127 * Arbitrary identification information returned by a call to [`ChannelSigner::channel_keys_id`].
128 * This may be useful in re-deriving keys used in the channel to spend the output.
130 public byte[] get_channel_keys_id() {
131 long ret = bindings.DelayedPaymentOutputDescriptor_get_channel_keys_id(this.ptr);
133 if (ret >= 0 && ret <= 4096) { return null; }
134 byte[] ret_conv = InternalUtils.decodeUint8Array(ret);
139 * Arbitrary identification information returned by a call to [`ChannelSigner::channel_keys_id`].
140 * This may be useful in re-deriving keys used in the channel to spend the output.
142 public void set_channel_keys_id(byte[] val) {
143 bindings.DelayedPaymentOutputDescriptor_set_channel_keys_id(this.ptr, InternalUtils.encodeUint8Array(InternalUtils.check_arr_len(val, 32)));
149 * The value of the channel which this output originated from, possibly indirectly.
151 public long get_channel_value_satoshis() {
152 long ret = bindings.DelayedPaymentOutputDescriptor_get_channel_value_satoshis(this.ptr);
158 * The value of the channel which this output originated from, possibly indirectly.
160 public void set_channel_value_satoshis(long val) {
161 bindings.DelayedPaymentOutputDescriptor_set_channel_value_satoshis(this.ptr, val);
167 * The channel public keys and other parameters needed to generate a spending transaction or
168 * to provide to a re-derived signer through [`ChannelSigner::provide_channel_parameters`].
170 * Added as optional, but always `Some` if the descriptor was produced in v0.0.123 or later.
172 * Note that the return value (or a relevant inner pointer) may be NULL or all-0s to represent None
174 public ChannelTransactionParameters get_channel_transaction_parameters() {
175 long ret = bindings.DelayedPaymentOutputDescriptor_get_channel_transaction_parameters(this.ptr);
177 if (ret >= 0 && ret <= 4096) { return null; }
178 org.ldk.structs.ChannelTransactionParameters ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.ChannelTransactionParameters(null, ret); }
179 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(this); };
184 * The channel public keys and other parameters needed to generate a spending transaction or
185 * to provide to a re-derived signer through [`ChannelSigner::provide_channel_parameters`].
187 * Added as optional, but always `Some` if the descriptor was produced in v0.0.123 or later.
189 * Note that val (or a relevant inner pointer) may be NULL or all-0s to represent None
191 public void set_channel_transaction_parameters(org.ldk.structs.ChannelTransactionParameters val) {
192 bindings.DelayedPaymentOutputDescriptor_set_channel_transaction_parameters(this.ptr, val == null ? 0 : val.ptr);
195 if (this != null) { this.ptrs_to.AddLast(val); };
199 * Constructs a new DelayedPaymentOutputDescriptor given each field
201 * Note that channel_transaction_parameters_arg (or a relevant inner pointer) may be NULL or all-0s to represent None
203 public static DelayedPaymentOutputDescriptor of(org.ldk.structs.OutPoint outpoint_arg, byte[] per_commitment_point_arg, short to_self_delay_arg, org.ldk.structs.TxOut output_arg, org.ldk.structs.RevocationKey revocation_pubkey_arg, byte[] channel_keys_id_arg, long channel_value_satoshis_arg, org.ldk.structs.ChannelTransactionParameters channel_transaction_parameters_arg) {
204 long ret = bindings.DelayedPaymentOutputDescriptor_new(outpoint_arg.ptr, InternalUtils.encodeUint8Array(InternalUtils.check_arr_len(per_commitment_point_arg, 33)), to_self_delay_arg, output_arg.ptr, revocation_pubkey_arg.ptr, InternalUtils.encodeUint8Array(InternalUtils.check_arr_len(channel_keys_id_arg, 32)), channel_value_satoshis_arg, channel_transaction_parameters_arg == null ? 0 : channel_transaction_parameters_arg.ptr);
205 GC.KeepAlive(outpoint_arg);
206 GC.KeepAlive(per_commitment_point_arg);
207 GC.KeepAlive(to_self_delay_arg);
208 GC.KeepAlive(output_arg);
209 GC.KeepAlive(revocation_pubkey_arg);
210 GC.KeepAlive(channel_keys_id_arg);
211 GC.KeepAlive(channel_value_satoshis_arg);
212 GC.KeepAlive(channel_transaction_parameters_arg);
213 if (ret >= 0 && ret <= 4096) { return null; }
214 org.ldk.structs.DelayedPaymentOutputDescriptor ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.DelayedPaymentOutputDescriptor(null, ret); }
215 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); };
216 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(outpoint_arg); };
217 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(revocation_pubkey_arg); };
218 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(channel_transaction_parameters_arg); };
222 internal long clone_ptr() {
223 long ret = bindings.DelayedPaymentOutputDescriptor_clone_ptr(this.ptr);
229 * Creates a copy of the DelayedPaymentOutputDescriptor
231 public DelayedPaymentOutputDescriptor clone() {
232 long ret = bindings.DelayedPaymentOutputDescriptor_clone(this.ptr);
234 if (ret >= 0 && ret <= 4096) { return null; }
235 org.ldk.structs.DelayedPaymentOutputDescriptor ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.DelayedPaymentOutputDescriptor(null, ret); }
236 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(this); };
241 * Generates a non-cryptographic 64-bit hash of the DelayedPaymentOutputDescriptor.
244 long ret = bindings.DelayedPaymentOutputDescriptor_hash(this.ptr);
249 public override int GetHashCode() {
250 return (int)this.hash();
253 * Checks if two DelayedPaymentOutputDescriptors contain equal inner contents.
254 * This ignores pointers and is_owned flags and looks at the values in fields.
255 * Two objects with NULL inner values will be considered "equal" here.
257 public bool eq(org.ldk.structs.DelayedPaymentOutputDescriptor b) {
258 bool ret = bindings.DelayedPaymentOutputDescriptor_eq(this.ptr, b.ptr);
261 if (this != null) { this.ptrs_to.AddLast(b); };
265 public override bool Equals(object o) {
266 if (!(o is DelayedPaymentOutputDescriptor)) return false;
267 return this.eq((DelayedPaymentOutputDescriptor)o);
270 * Serialize the DelayedPaymentOutputDescriptor object into a byte array which can be read by DelayedPaymentOutputDescriptor_read
272 public byte[] write() {
273 long ret = bindings.DelayedPaymentOutputDescriptor_write(this.ptr);
275 if (ret >= 0 && ret <= 4096) { return null; }
276 byte[] ret_conv = InternalUtils.decodeUint8Array(ret);
281 * Read a DelayedPaymentOutputDescriptor from a byte array, created by DelayedPaymentOutputDescriptor_write
283 public static Result_DelayedPaymentOutputDescriptorDecodeErrorZ read(byte[] ser) {
284 long ret = bindings.DelayedPaymentOutputDescriptor_read(InternalUtils.encodeUint8Array(ser));
286 if (ret >= 0 && ret <= 4096) { return null; }
287 Result_DelayedPaymentOutputDescriptorDecodeErrorZ ret_hu_conv = Result_DelayedPaymentOutputDescriptorDecodeErrorZ.constr_from_ptr(ret);