import org.ldk.enums.*;
import org.ldk.util.*;
import java.util.Arrays;
+import javax.annotation.Nullable;
+
+/**
+ * An event to be processed by the ChannelManager.
+ */
@SuppressWarnings("unchecked") // We correctly assign various generic arrays
public class MonitorEvent extends CommonBase {
private MonitorEvent(Object _dummy, long ptr) { super(ptr); }
if (raw_val.getClass() == bindings.LDKMonitorEvent.HTLCEvent.class) {
return new HTLCEvent(ptr, (bindings.LDKMonitorEvent.HTLCEvent)raw_val);
}
- if (raw_val.getClass() == bindings.LDKMonitorEvent.CommitmentTxBroadcasted.class) {
- return new CommitmentTxBroadcasted(ptr, (bindings.LDKMonitorEvent.CommitmentTxBroadcasted)raw_val);
+ if (raw_val.getClass() == bindings.LDKMonitorEvent.CommitmentTxConfirmed.class) {
+ return new CommitmentTxConfirmed(ptr, (bindings.LDKMonitorEvent.CommitmentTxConfirmed)raw_val);
}
assert false; return null; // Unreachable without extending the (internal) bindings interface
}
public final static class HTLCEvent extends MonitorEvent {
+ public final HTLCUpdate htlc_event;
private HTLCEvent(long ptr, bindings.LDKMonitorEvent.HTLCEvent obj) {
super(null, ptr);
+ long htlc_event = obj.htlc_event;
+ HTLCUpdate htlc_event_hu_conv = new HTLCUpdate(null, htlc_event);
+ htlc_event_hu_conv.ptrs_to.add(this);
+ this.htlc_event = htlc_event_hu_conv;
}
}
- public final static class CommitmentTxBroadcasted extends MonitorEvent {
- private CommitmentTxBroadcasted(long ptr, bindings.LDKMonitorEvent.CommitmentTxBroadcasted obj) {
+ public final static class CommitmentTxConfirmed extends MonitorEvent {
+ public final OutPoint commitment_tx_confirmed;
+ private CommitmentTxConfirmed(long ptr, bindings.LDKMonitorEvent.CommitmentTxConfirmed obj) {
super(null, ptr);
+ long commitment_tx_confirmed = obj.commitment_tx_confirmed;
+ OutPoint commitment_tx_confirmed_hu_conv = new OutPoint(null, commitment_tx_confirmed);
+ commitment_tx_confirmed_hu_conv.ptrs_to.add(this);
+ this.commitment_tx_confirmed = commitment_tx_confirmed_hu_conv;
}
}
+ /**
+ * Creates a copy of the MonitorEvent
+ */
+ public MonitorEvent clone() {
+ long ret = bindings.MonitorEvent_clone(this.ptr);
+ if (ret < 1024) { return null; }
+ MonitorEvent ret_hu_conv = MonitorEvent.constr_from_ptr(ret);
+ ret_hu_conv.ptrs_to.add(this);
+ return ret_hu_conv;
+ }
+
+ /**
+ * Utility method to constructs a new HTLCEvent-variant MonitorEvent
+ */
+ public static MonitorEvent htlcevent(HTLCUpdate a) {
+ long ret = bindings.MonitorEvent_htlcevent(a == null ? 0 : a.ptr & ~1);
+ if (ret < 1024) { return null; }
+ MonitorEvent ret_hu_conv = MonitorEvent.constr_from_ptr(ret);
+ ret_hu_conv.ptrs_to.add(ret_hu_conv);
+ ret_hu_conv.ptrs_to.add(a);
+ return ret_hu_conv;
+ }
+
+ /**
+ * Utility method to constructs a new CommitmentTxConfirmed-variant MonitorEvent
+ */
+ public static MonitorEvent commitment_tx_confirmed(OutPoint a) {
+ long ret = bindings.MonitorEvent_commitment_tx_confirmed(a == null ? 0 : a.ptr & ~1);
+ if (ret < 1024) { return null; }
+ MonitorEvent ret_hu_conv = MonitorEvent.constr_from_ptr(ret);
+ ret_hu_conv.ptrs_to.add(ret_hu_conv);
+ ret_hu_conv.ptrs_to.add(a);
+ return ret_hu_conv;
+ }
+
}