sweep: leave exclusive group unchanged on parameter update
Exclusive group is a static property that doesn't need to be updated. Requiring the exclusive group to be passed into UpdateParams creates a burden for the caller to make sure they supply the existing group. This change will be beneficial for users that bump anchor sweeps that have exclusive groups set.
This commit is contained in:
parent
1c93e9e03d
commit
29e1489179
@ -486,7 +486,7 @@ func (w *WalletKit) BumpFee(ctx context.Context,
|
|||||||
// bump its fee, which will result in a replacement transaction (RBF)
|
// bump its fee, which will result in a replacement transaction (RBF)
|
||||||
// being broadcast. If it is not aware of the input however,
|
// being broadcast. If it is not aware of the input however,
|
||||||
// lnwallet.ErrNotMine is returned.
|
// lnwallet.ErrNotMine is returned.
|
||||||
params := sweep.Params{
|
params := sweep.ParamsUpdate{
|
||||||
Fee: feePreference,
|
Fee: feePreference,
|
||||||
Force: in.Force,
|
Force: in.Force,
|
||||||
}
|
}
|
||||||
|
@ -82,6 +82,18 @@ type Params struct {
|
|||||||
ExclusiveGroup *uint64
|
ExclusiveGroup *uint64
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ParamsUpdate contains a new set of parameters to update a pending sweep with.
|
||||||
|
type ParamsUpdate struct {
|
||||||
|
// Fee is the fee preference of the client who requested the input to be
|
||||||
|
// swept. If a confirmation target is specified, then we'll map it into
|
||||||
|
// a fee rate whenever we attempt to cluster inputs for a sweep.
|
||||||
|
Fee FeePreference
|
||||||
|
|
||||||
|
// Force indicates whether the input should be swept regardless of
|
||||||
|
// whether it is economical to do so.
|
||||||
|
Force bool
|
||||||
|
}
|
||||||
|
|
||||||
// String returns a human readable interpretation of the sweep parameters.
|
// String returns a human readable interpretation of the sweep parameters.
|
||||||
func (p Params) String() string {
|
func (p Params) String() string {
|
||||||
return fmt.Sprintf("fee=%v, force=%v, exclusive_group=%v",
|
return fmt.Sprintf("fee=%v, force=%v, exclusive_group=%v",
|
||||||
@ -174,7 +186,7 @@ type PendingInput struct {
|
|||||||
// intent to update the sweep parameters of a given input.
|
// intent to update the sweep parameters of a given input.
|
||||||
type updateReq struct {
|
type updateReq struct {
|
||||||
input wire.OutPoint
|
input wire.OutPoint
|
||||||
params Params
|
params ParamsUpdate
|
||||||
responseChan chan *updateResp
|
responseChan chan *updateResp
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1119,7 +1131,7 @@ func (s *UtxoSweeper) handlePendingSweepsReq(
|
|||||||
// is actually successful. The responsibility of doing so should be handled by
|
// is actually successful. The responsibility of doing so should be handled by
|
||||||
// the caller.
|
// the caller.
|
||||||
func (s *UtxoSweeper) UpdateParams(input wire.OutPoint,
|
func (s *UtxoSweeper) UpdateParams(input wire.OutPoint,
|
||||||
params Params) (chan Result, error) {
|
params ParamsUpdate) (chan Result, error) {
|
||||||
|
|
||||||
// Ensure the client provided a sane fee preference.
|
// Ensure the client provided a sane fee preference.
|
||||||
if _, err := s.feeRateForPreference(params.Fee); err != nil {
|
if _, err := s.feeRateForPreference(params.Fee); err != nil {
|
||||||
@ -1169,10 +1181,16 @@ func (s *UtxoSweeper) handleUpdateReq(req *updateReq, bestHeight int32) (
|
|||||||
return nil, lnwallet.ErrNotMine
|
return nil, lnwallet.ErrNotMine
|
||||||
}
|
}
|
||||||
|
|
||||||
log.Debugf("Updating sweep parameters for %v from %v to %v", req.input,
|
// Create the updated parameters struct. Leave the exclusive group
|
||||||
pendingInput.params, req.params)
|
// unchanged.
|
||||||
|
newParams := pendingInput.params
|
||||||
|
newParams.Fee = req.params.Fee
|
||||||
|
newParams.Force = req.params.Force
|
||||||
|
|
||||||
pendingInput.params = req.params
|
log.Debugf("Updating sweep parameters for %v from %v to %v", req.input,
|
||||||
|
pendingInput.params, newParams)
|
||||||
|
|
||||||
|
pendingInput.params = newParams
|
||||||
|
|
||||||
// We'll reset the input's publish height to the current so that a new
|
// We'll reset the input's publish height to the current so that a new
|
||||||
// transaction can be created that replaces the transaction currently
|
// transaction can be created that replaces the transaction currently
|
||||||
|
@ -1179,7 +1179,7 @@ func TestBumpFeeRBF(t *testing.T) {
|
|||||||
// We'll first try to bump the fee of an output currently unknown to the
|
// We'll first try to bump the fee of an output currently unknown to the
|
||||||
// UtxoSweeper. Doing so should result in a lnwallet.ErrNotMine error.
|
// UtxoSweeper. Doing so should result in a lnwallet.ErrNotMine error.
|
||||||
_, err := ctx.sweeper.UpdateParams(
|
_, err := ctx.sweeper.UpdateParams(
|
||||||
wire.OutPoint{}, Params{Fee: lowFeePref},
|
wire.OutPoint{}, ParamsUpdate{Fee: lowFeePref},
|
||||||
)
|
)
|
||||||
if err != lnwallet.ErrNotMine {
|
if err != lnwallet.ErrNotMine {
|
||||||
t.Fatalf("expected error lnwallet.ErrNotMine, got \"%v\"", err)
|
t.Fatalf("expected error lnwallet.ErrNotMine, got \"%v\"", err)
|
||||||
@ -1208,13 +1208,13 @@ func TestBumpFeeRBF(t *testing.T) {
|
|||||||
ctx.estimator.blocksToFee[highFeePref.ConfTarget] = highFeeRate
|
ctx.estimator.blocksToFee[highFeePref.ConfTarget] = highFeeRate
|
||||||
|
|
||||||
// We should expect to see an error if a fee preference isn't provided.
|
// We should expect to see an error if a fee preference isn't provided.
|
||||||
_, err = ctx.sweeper.UpdateParams(*input.OutPoint(), Params{})
|
_, err = ctx.sweeper.UpdateParams(*input.OutPoint(), ParamsUpdate{})
|
||||||
if err != ErrNoFeePreference {
|
if err != ErrNoFeePreference {
|
||||||
t.Fatalf("expected ErrNoFeePreference, got %v", err)
|
t.Fatalf("expected ErrNoFeePreference, got %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
bumpResult, err := ctx.sweeper.UpdateParams(
|
bumpResult, err := ctx.sweeper.UpdateParams(
|
||||||
*input.OutPoint(), Params{Fee: highFeePref},
|
*input.OutPoint(), ParamsUpdate{Fee: highFeePref},
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unable to bump input's fee: %v", err)
|
t.Fatalf("unable to bump input's fee: %v", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user