Archived
1
0
Fork 0

fix(payments): Improve paged response (#8)

Signed-off-by: Julien Riou <julien@riou.xyz>
This commit is contained in:
Julien Riou 2022-04-08 13:41:44 +02:00
parent 6445f3f292
commit d01fefbfbf
No known key found for this signature in database
GPG key ID: FF42D23B580C89F7

View file

@ -87,6 +87,7 @@ func (f *FlexpoolClient) MinerBalance(coin string, address string) (float64, err
type PaymentsResponse struct {
Error string `json:"error"`
Result struct {
TotalPages int `json:"totalPages"`
Data []struct {
Hash string `json:"hash"`
Value float64 `json:"value"`
@ -98,7 +99,9 @@ type PaymentsResponse struct {
// MinerPayments returns an ordered list of payments
func (f *FlexpoolClient) MinerPayments(coin string, address string, limit int) (payments []*Payment, err error) {
page := 0
for {
totalPages := 0
for page <= MaxIterations && len(payments) < limit {
body, err := f.request(fmt.Sprintf("%s/miner/payments/?coin=%s&address=%s&page=%d", FlexpoolAPIURL, coin, address, page))
if err != nil {
return nil, err
@ -107,6 +110,10 @@ func (f *FlexpoolClient) MinerPayments(coin string, address string, limit int) (
var response PaymentsResponse
json.Unmarshal(body, &response)
if totalPages == 0 {
totalPages = response.Result.TotalPages
}
for _, result := range response.Result.Data {
payment := NewPayment(
result.Hash,
@ -115,18 +122,24 @@ func (f *FlexpoolClient) MinerPayments(coin string, address string, limit int) (
)
payments = append(payments, payment)
if len(payments) >= limit {
// sort by timestamp
break
}
}
page++
if page >= totalPages {
break
}
}
if page > MaxIterations {
return nil, fmt.Errorf("Max iterations of %d reached", MaxIterations)
}
// Sort by timestamp
sort.Slice(payments, func(p1, p2 int) bool {
return payments[p1].Timestamp > payments[p2].Timestamp
})
return payments, nil
}
}
page = page + 1
if page > MaxIterations {
return nil, fmt.Errorf("Max iterations of %d reached", MaxIterations)
}
}
}
// LastMinerPayment return the last payment of a miner