]> git.bitcoin.ninja Git - ldk-java/blobdiff - ts/structs/NetworkUpdate.ts
Update auto-generated bindings to 0.0.101
[ldk-java] / ts / structs / NetworkUpdate.ts
diff --git a/ts/structs/NetworkUpdate.ts b/ts/structs/NetworkUpdate.ts
new file mode 100644 (file)
index 0000000..b7b9e92
--- /dev/null
@@ -0,0 +1,88 @@
+
+import CommonBase from './CommonBase';
+import * as bindings from '../bindings' // TODO: figure out location
+
+export default class NetworkUpdate extends CommonBase {
+       protected constructor(_dummy: object, ptr: number) { super(ptr); }
+       protected finalize() {
+               super.finalize();
+               if (this.ptr != 0) { bindings.NetworkUpdate_free(this.ptr); }
+       }
+       static constr_from_ptr(ptr: number): NetworkUpdate {
+               const raw_val: bindings.LDKNetworkUpdate = bindings.LDKNetworkUpdate_ref_from_ptr(ptr);
+               if (raw_val instanceof bindings.LDKNetworkUpdate.ChannelUpdateMessage) {
+                       return new ChannelUpdateMessage(this.ptr, raw_val);
+               }
+               if (raw_val instanceof bindings.LDKNetworkUpdate.ChannelClosed) {
+                       return new ChannelClosed(this.ptr, raw_val);
+               }
+               if (raw_val instanceof bindings.LDKNetworkUpdate.NodeFailure) {
+                       return new NodeFailure(this.ptr, raw_val);
+               }
+               throw new Error('oops, this should be unreachable'); // Unreachable without extending the (internal) bindings interface
+       }
+
+}
+export class ChannelUpdateMessage extends NetworkUpdate {
+       public msg: ChannelUpdate;
+       private constructor(ptr: number, obj: bindings.LDKNetworkUpdate.ChannelUpdateMessage) {
+               super(null, ptr);
+               const msg: number = obj.msg;
+               const msg_hu_conv: ChannelUpdate = new ChannelUpdate(null, msg);
+                       msg_hu_conv.ptrs_to.add(this);
+               this.msg = msg_hu_conv;
+       }
+}
+export class ChannelClosed extends NetworkUpdate {
+       public short_channel_id: number;
+       public is_permanent: boolean;
+       private constructor(ptr: number, obj: bindings.LDKNetworkUpdate.ChannelClosed) {
+               super(null, ptr);
+               this.short_channel_id = obj.short_channel_id;
+               this.is_permanent = obj.is_permanent;
+       }
+}
+export class NodeFailure extends NetworkUpdate {
+       public node_id: Uint8Array;
+       public is_permanent: boolean;
+       private constructor(ptr: number, obj: bindings.LDKNetworkUpdate.NodeFailure) {
+               super(null, ptr);
+               this.node_id = obj.node_id;
+               this.is_permanent = obj.is_permanent;
+       }
+}
+       public NetworkUpdate clone() {
+               number ret = bindings.NetworkUpdate_clone(this.ptr);
+               NetworkUpdate ret_hu_conv = NetworkUpdate.constr_from_ptr(ret);
+               ret_hu_conv.ptrs_to.add(this);
+               return ret_hu_conv;
+       }
+
+       public static NetworkUpdate constructor_channel_update_message(ChannelUpdate msg) {
+               number ret = bindings.NetworkUpdate_channel_update_message(msg == null ? 0 : msg.ptr & ~1);
+               NetworkUpdate ret_hu_conv = NetworkUpdate.constr_from_ptr(ret);
+               ret_hu_conv.ptrs_to.add(ret_hu_conv);
+               ret_hu_conv.ptrs_to.add(msg);
+               return ret_hu_conv;
+       }
+
+       public static NetworkUpdate constructor_channel_closed(number short_channel_id, boolean is_permanent) {
+               number ret = bindings.NetworkUpdate_channel_closed(short_channel_id, is_permanent);
+               NetworkUpdate ret_hu_conv = NetworkUpdate.constr_from_ptr(ret);
+               ret_hu_conv.ptrs_to.add(ret_hu_conv);
+               return ret_hu_conv;
+       }
+
+       public static NetworkUpdate constructor_node_failure(Uint8Array node_id, boolean is_permanent) {
+               number ret = bindings.NetworkUpdate_node_failure(node_id, is_permanent);
+               NetworkUpdate ret_hu_conv = NetworkUpdate.constr_from_ptr(ret);
+               ret_hu_conv.ptrs_to.add(ret_hu_conv);
+               return ret_hu_conv;
+       }
+
+       public Uint8Array write() {
+               Uint8Array ret = bindings.NetworkUpdate_write(this.ptr);
+               return ret;
+       }
+
+}