From dde1cb74067bcbf798d4077ff5860e18abc4a010 Mon Sep 17 00:00:00 2001 From: fiatjaf Date: Wed, 12 Aug 2020 00:29:15 -0300 Subject: [PATCH] improve listpaysext. --- main.go | 2 +- spark-methods.go | 32 +++++++++++++++++--------------- 2 files changed, 18 insertions(+), 16 deletions(-) diff --git a/main.go b/main.go index 9cd6c34..0113ec2 100644 --- a/main.go +++ b/main.go @@ -28,7 +28,7 @@ const DEFAULTPORT = "9737" func main() { p := plugin.Plugin{ Name: "sparko", - Version: "v2.2", + Version: "v2.3", Options: []plugin.Option{ {"sparko-host", "string", "127.0.0.1", "http(s) server listen address"}, {"sparko-port", "string", DEFAULTPORT, "http(s) server port"}, diff --git a/spark-methods.go b/spark-methods.go index 1a3fc2e..c9b93a7 100644 --- a/spark-methods.go +++ b/spark-methods.go @@ -77,26 +77,29 @@ var listpaysExt = plugin.RPCMethod{ return []bool{}, 0, nil } - // more than 50, we filter - if len(pays) > 50 { - pays = pays[:50] + // more than 30, we filter + if len(pays) > 30 { + pays = pays[len(pays)-30:] } + retval := make([]interface{}, len(pays)) // these are not currently available, but be prepared for when they are if pays[0].Get("payment_hash").Exists() && pays[0].Get("created_at").Exists() { - return res.Value(), 0, nil + for i, pay := range pays { + retval[i] = pay.Value() + } + } else { + filled := make(chan interface{}, len(pays)) + for _, pay := range pays { + go fillPay(p, pay, filled) + } + i := 0 + for fpay := range filled { + retval[i] = fpay + i++ + } } - retval := make([]interface{}, len(pays)) - filled := make(chan interface{}, len(pays)) - for _, pay := range pays { - go fillPay(p, pay, filled) - } - i := 0 - for fpay := range filled { - retval[i] = fpay - i++ - } return map[string]interface{}{"pays": retval}, 0, nil }, } @@ -112,7 +115,6 @@ func fillPay(p *plugin.Plugin, pay gjson.Result, filled chan<- interface{}) { hash := sha256.Sum256(preimage) hexhash := hex.EncodeToString(hash[:]) payv["payment_hash"] = hexhash - res, _ := p.Client.CallNamed("listsendpays", "payment_hash", hexhash) payv["created_at"] = res.Get("payments.0.created_at").Int()