6 namespace org { namespace ldk { namespace structs {
10 * Information about a spendable output to our \"payment key\".
12 * See [`SpendableOutputDescriptor::StaticPaymentOutput`] for more details on how to spend this.
14 public class StaticPaymentOutputDescriptor : CommonBase {
15 internal StaticPaymentOutputDescriptor(object _dummy, long ptr) : base(ptr) { }
16 ~StaticPaymentOutputDescriptor() {
17 if (ptr != 0) { bindings.StaticPaymentOutputDescriptor_free(ptr); }
21 * The outpoint which is spendable.
23 public OutPoint get_outpoint() {
24 long ret = bindings.StaticPaymentOutputDescriptor_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.StaticPaymentOutputDescriptor_set_outpoint(this.ptr, val == null ? 0 : val.ptr);
39 if (this != null) { this.ptrs_to.AddLast(val); };
43 * The output which is referenced by the given outpoint.
45 * Returns a copy of the field.
47 public TxOut get_output() {
48 long ret = bindings.StaticPaymentOutputDescriptor_get_output(this.ptr);
50 if (ret >= 0 && ret <= 4096) { return null; }
51 TxOut ret_conv = new TxOut(null, ret);
56 * The output which is referenced by the given outpoint.
58 public void set_output(org.ldk.structs.TxOut val) {
59 bindings.StaticPaymentOutputDescriptor_set_output(this.ptr, val.ptr);
65 * Arbitrary identification information returned by a call to [`BaseSign::channel_keys_id`].
66 * This may be useful in re-deriving keys used in the channel to spend the output.
68 public byte[] get_channel_keys_id() {
69 byte[] ret = bindings.StaticPaymentOutputDescriptor_get_channel_keys_id(this.ptr);
75 * Arbitrary identification information returned by a call to [`BaseSign::channel_keys_id`].
76 * This may be useful in re-deriving keys used in the channel to spend the output.
78 public void set_channel_keys_id(byte[] val) {
79 bindings.StaticPaymentOutputDescriptor_set_channel_keys_id(this.ptr, InternalUtils.check_arr_len(val, 32));
85 * The value of the channel which this transactions spends.
87 public long get_channel_value_satoshis() {
88 long ret = bindings.StaticPaymentOutputDescriptor_get_channel_value_satoshis(this.ptr);
94 * The value of the channel which this transactions spends.
96 public void set_channel_value_satoshis(long val) {
97 bindings.StaticPaymentOutputDescriptor_set_channel_value_satoshis(this.ptr, val);
103 * Constructs a new StaticPaymentOutputDescriptor given each field
105 public static StaticPaymentOutputDescriptor of(org.ldk.structs.OutPoint outpoint_arg, org.ldk.structs.TxOut output_arg, byte[] channel_keys_id_arg, long channel_value_satoshis_arg) {
106 long ret = bindings.StaticPaymentOutputDescriptor_new(outpoint_arg == null ? 0 : outpoint_arg.ptr, output_arg.ptr, InternalUtils.check_arr_len(channel_keys_id_arg, 32), channel_value_satoshis_arg);
107 GC.KeepAlive(outpoint_arg);
108 GC.KeepAlive(output_arg);
109 GC.KeepAlive(channel_keys_id_arg);
110 GC.KeepAlive(channel_value_satoshis_arg);
111 if (ret >= 0 && ret <= 4096) { return null; }
112 org.ldk.structs.StaticPaymentOutputDescriptor ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.StaticPaymentOutputDescriptor(null, ret); }
113 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(ret_hu_conv); };
114 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(outpoint_arg); };
118 internal long clone_ptr() {
119 long ret = bindings.StaticPaymentOutputDescriptor_clone_ptr(this.ptr);
125 * Creates a copy of the StaticPaymentOutputDescriptor
127 public StaticPaymentOutputDescriptor clone() {
128 long ret = bindings.StaticPaymentOutputDescriptor_clone(this.ptr);
130 if (ret >= 0 && ret <= 4096) { return null; }
131 org.ldk.structs.StaticPaymentOutputDescriptor ret_hu_conv = null; if (ret < 0 || ret > 4096) { ret_hu_conv = new org.ldk.structs.StaticPaymentOutputDescriptor(null, ret); }
132 if (ret_hu_conv != null) { ret_hu_conv.ptrs_to.AddLast(this); };
137 * Checks if two StaticPaymentOutputDescriptors contain equal inner contents.
138 * This ignores pointers and is_owned flags and looks at the values in fields.
139 * Two objects with NULL inner values will be considered "equal" here.
141 public bool eq(org.ldk.structs.StaticPaymentOutputDescriptor b) {
142 bool ret = bindings.StaticPaymentOutputDescriptor_eq(this.ptr, b == null ? 0 : b.ptr);
145 if (this != null) { this.ptrs_to.AddLast(b); };
149 public override bool Equals(object o) {
150 if (!(o is StaticPaymentOutputDescriptor)) return false;
151 return this.eq((StaticPaymentOutputDescriptor)o);
154 * Serialize the StaticPaymentOutputDescriptor object into a byte array which can be read by StaticPaymentOutputDescriptor_read
156 public byte[] write() {
157 byte[] ret = bindings.StaticPaymentOutputDescriptor_write(this.ptr);
163 * Read a StaticPaymentOutputDescriptor from a byte array, created by StaticPaymentOutputDescriptor_write
165 public static Result_StaticPaymentOutputDescriptorDecodeErrorZ read(byte[] ser) {
166 long ret = bindings.StaticPaymentOutputDescriptor_read(ser);
168 if (ret >= 0 && ret <= 4096) { return null; }
169 Result_StaticPaymentOutputDescriptorDecodeErrorZ ret_hu_conv = Result_StaticPaymentOutputDescriptorDecodeErrorZ.constr_from_ptr(ret);