Merge pull request #33 from TheBlueMatt/main
[ldk-java] / src / main / java / org / ldk / structs / CounterpartyChannelTransactionParameters.java
1 package org.ldk.structs;
2
3 import org.ldk.impl.bindings;
4 import org.ldk.enums.*;
5 import org.ldk.util.*;
6 import java.util.Arrays;
7 import javax.annotation.Nullable;
8
9
10 /**
11  * Late-bound per-channel counterparty data used to build transactions.
12  */
13 @SuppressWarnings("unchecked") // We correctly assign various generic arrays
14 public class CounterpartyChannelTransactionParameters extends CommonBase {
15         CounterpartyChannelTransactionParameters(Object _dummy, long ptr) { super(ptr); }
16         @Override @SuppressWarnings("deprecation")
17         protected void finalize() throws Throwable {
18                 super.finalize();
19                 if (ptr != 0) { bindings.CounterpartyChannelTransactionParameters_free(ptr); }
20         }
21
22         /**
23          * Counter-party public keys
24          */
25         public ChannelPublicKeys get_pubkeys() {
26                 long ret = bindings.CounterpartyChannelTransactionParameters_get_pubkeys(this.ptr);
27                 if (ret < 1024) { return null; }
28                 ChannelPublicKeys ret_hu_conv = new ChannelPublicKeys(null, ret);
29                 ret_hu_conv.ptrs_to.add(this);
30                 return ret_hu_conv;
31         }
32
33         /**
34          * Counter-party public keys
35          */
36         public void set_pubkeys(ChannelPublicKeys val) {
37                 bindings.CounterpartyChannelTransactionParameters_set_pubkeys(this.ptr, val == null ? 0 : val.ptr & ~1);
38                 this.ptrs_to.add(val);
39         }
40
41         /**
42          * The contest delay selected by the counterparty, which applies to holder-broadcast transactions
43          */
44         public short get_selected_contest_delay() {
45                 short ret = bindings.CounterpartyChannelTransactionParameters_get_selected_contest_delay(this.ptr);
46                 return ret;
47         }
48
49         /**
50          * The contest delay selected by the counterparty, which applies to holder-broadcast transactions
51          */
52         public void set_selected_contest_delay(short val) {
53                 bindings.CounterpartyChannelTransactionParameters_set_selected_contest_delay(this.ptr, val);
54         }
55
56         /**
57          * Constructs a new CounterpartyChannelTransactionParameters given each field
58          */
59         public static CounterpartyChannelTransactionParameters of(ChannelPublicKeys pubkeys_arg, short selected_contest_delay_arg) {
60                 long ret = bindings.CounterpartyChannelTransactionParameters_new(pubkeys_arg == null ? 0 : pubkeys_arg.ptr & ~1, selected_contest_delay_arg);
61                 if (ret < 1024) { return null; }
62                 CounterpartyChannelTransactionParameters ret_hu_conv = new CounterpartyChannelTransactionParameters(null, ret);
63                 ret_hu_conv.ptrs_to.add(ret_hu_conv);
64                 ret_hu_conv.ptrs_to.add(pubkeys_arg);
65                 return ret_hu_conv;
66         }
67
68         /**
69          * Creates a copy of the CounterpartyChannelTransactionParameters
70          */
71         public CounterpartyChannelTransactionParameters clone() {
72                 long ret = bindings.CounterpartyChannelTransactionParameters_clone(this.ptr);
73                 if (ret < 1024) { return null; }
74                 CounterpartyChannelTransactionParameters ret_hu_conv = new CounterpartyChannelTransactionParameters(null, ret);
75                 ret_hu_conv.ptrs_to.add(this);
76                 return ret_hu_conv;
77         }
78
79         /**
80          * Serialize the CounterpartyChannelTransactionParameters object into a byte array which can be read by CounterpartyChannelTransactionParameters_read
81          */
82         public byte[] write() {
83                 byte[] ret = bindings.CounterpartyChannelTransactionParameters_write(this.ptr);
84                 return ret;
85         }
86
87         /**
88          * Read a CounterpartyChannelTransactionParameters from a byte array, created by CounterpartyChannelTransactionParameters_write
89          */
90         public static Result_CounterpartyChannelTransactionParametersDecodeErrorZ read(byte[] ser) {
91                 long ret = bindings.CounterpartyChannelTransactionParameters_read(ser);
92                 if (ret < 1024) { return null; }
93                 Result_CounterpartyChannelTransactionParametersDecodeErrorZ ret_hu_conv = Result_CounterpartyChannelTransactionParametersDecodeErrorZ.constr_from_ptr(ret);
94                 return ret_hu_conv;
95         }
96
97 }