// getEligibleInputs returns eligible inputs with addresses between startAddress // and the last used address of lastSeriesID. They're reverse ordered based on // their address. func (p *Pool) getEligibleInputs(store *wtxmgr.Store, startAddress WithdrawalAddress, lastSeriesID uint32, dustThreshold btcutil.Amount, chainHeight int32, minConf int) ([]credit, error) { if p.Series(lastSeriesID) == nil { str := fmt.Sprintf("lastSeriesID (%d) does not exist", lastSeriesID) return nil, newError(ErrSeriesNotExists, str, nil) } unspents, err := store.UnspentOutputs() if err != nil { return nil, newError(ErrInputSelection, "failed to get unspent outputs", err) } addrMap, err := groupCreditsByAddr(unspents, p.manager.ChainParams()) if err != nil { return nil, err } var inputs []credit address := startAddress for { log.Debugf("Looking for eligible inputs at address %v", address.addrIdentifier()) if candidates, ok := addrMap[address.addr.EncodeAddress()]; ok { var eligibles []credit for _, c := range candidates { candidate := newCredit(c, address) if p.isCreditEligible(candidate, minConf, chainHeight, dustThreshold) { eligibles = append(eligibles, candidate) } } inputs = append(inputs, eligibles...) } nAddr, err := nextAddr(p, address.seriesID, address.branch, address.index, lastSeriesID+1) if err != nil { return nil, newError(ErrInputSelection, "failed to get next withdrawal address", err) } else if nAddr == nil { log.Debugf("getEligibleInputs: reached last addr, stopping") break } address = *nAddr } sort.Sort(sort.Reverse(byAddress(inputs))) return inputs, nil }