X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=ts%2Fstructs%2FScore.ts;h=6c73fe5c53f99835d2d721d8be04d434f1796231;hb=1854b5cebef22ace9e9e4dd191f609818df9ce08;hp=9a86ae0efbf59bde4a51a39bb1154c8fd32535a5;hpb=5fd405f7a48aaeca779c45c88ec6b3d3d3dbf0e4;p=ldk-java diff --git a/ts/structs/Score.ts b/ts/structs/Score.ts index 9a86ae0e..6c73fe5c 100644 --- a/ts/structs/Score.ts +++ b/ts/structs/Score.ts @@ -32,10 +32,12 @@ import * as bindings from '../bindings' // TODO: figure out location const impl_holder: LDKScoreHolder = new LDKScoreHolder(); let structImplementation = { // todo: in-line interface filling - channel_penalty_msat (short_channel_id: number, source: number, target: number): number { + channel_penalty_msat (short_channel_id: number, send_amt_msat: number, channel_capacity_msat: number, source: number, target: number): number { + Option_u64Z channel_capacity_msat_hu_conv = Option_u64Z.constr_from_ptr(channel_capacity_msat); + channel_capacity_msat_hu_conv.ptrs_to.add(this); const source_hu_conv: NodeId = new NodeId(null, source); const target_hu_conv: NodeId = new NodeId(null, target); - number ret = arg.channel_penalty_msat(short_channel_id, source_hu_conv, target_hu_conv); + number ret = arg.channel_penalty_msat(short_channel_id, send_amt_msat, channel_capacity_msat_hu_conv, source_hu_conv, target_hu_conv); return ret; }, @@ -50,6 +52,17 @@ import * as bindings from '../bindings' // TODO: figure out location arg.payment_path_failed(path_conv_10_arr, short_channel_id); }, + payment_path_successful (path: number[]): void { + RouteHop[] path_conv_10_arr = new RouteHop[path.length]; + for (int k = 0; k < path.length; k++) { + number path_conv_10 = path[k]; + const path_conv_10_hu_conv: RouteHop = new RouteHop(null, path_conv_10); + path_conv_10_hu_conv.ptrs_to.add(this); + path_conv_10_arr[k] = path_conv_10_hu_conv; + } + arg.payment_path_successful(path_conv_10_arr); + }, + write (): Uint8Array { Uint8Array ret = arg.write(); return ret; @@ -62,8 +75,9 @@ import * as bindings from '../bindings' // TODO: figure out location } export interface ScoreInterface { - channel_penalty_msat(short_channel_id: number, source: NodeId, target: NodeId): number; + channel_penalty_msat(short_channel_id: number, send_amt_msat: number, channel_capacity_msat: Option_u64Z, source: NodeId, target: NodeId): number; payment_path_failed(path: RouteHop[], short_channel_id: number): void; + payment_path_successful(path: RouteHop[]): void; write(): Uint8Array; } @@ -71,8 +85,8 @@ import * as bindings from '../bindings' // TODO: figure out location class LDKScoreHolder { held: Score; } - public number channel_penalty_msat(number short_channel_id, NodeId source, NodeId target) { - number ret = bindings.Score_channel_penalty_msat(this.ptr, short_channel_id, source == null ? 0 : source.ptr & ~1, target == null ? 0 : target.ptr & ~1); + public number channel_penalty_msat(number short_channel_id, number send_amt_msat, Option_u64Z channel_capacity_msat, NodeId source, NodeId target) { + number ret = bindings.Score_channel_penalty_msat(this.ptr, short_channel_id, send_amt_msat, channel_capacity_msat.ptr, source == null ? 0 : source.ptr & ~1, target == null ? 0 : target.ptr & ~1); this.ptrs_to.add(source); this.ptrs_to.add(target); return ret; @@ -82,6 +96,10 @@ import * as bindings from '../bindings' // TODO: figure out location bindings.Score_payment_path_failed(this.ptr, path != null ? Arrays.stream(path).map(path_conv_10 -> path_conv_10 == null ? 0 : path_conv_10.ptr & ~1).toArray(number[]::new) : null, short_channel_id); } + public void payment_path_successful(RouteHop[] path) { + bindings.Score_payment_path_successful(this.ptr, path != null ? Arrays.stream(path).map(path_conv_10 -> path_conv_10 == null ? 0 : path_conv_10.ptr & ~1).toArray(number[]::new) : null); + } + public Uint8Array write() { Uint8Array ret = bindings.Score_write(this.ptr); return ret;