Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Nomination pools cannot chill if depositor bond is less than MinNominatorBond #2350

Closed
rossbulat opened this issue Nov 15, 2023 · 8 comments · Fixed by #3453
Closed

Nomination pools cannot chill if depositor bond is less than MinNominatorBond #2350

rossbulat opened this issue Nov 15, 2023 · 8 comments · Fixed by #3453
Labels
C1-mentor A task where a mentor is available. Please indicate in the issue who the mentor could be.

Comments

@rossbulat
Copy link

rossbulat commented Nov 15, 2023

Nomination pools currently have an issue whereby member funds cannot be unbonded if the depositor bonded amount is less than MinNominatorBond.

E.g. Pool 72 (this is a real scenario at the time of writing)

MinNominatorBond: 250 DOT
---
Pool Depositor Bonded: 240 DOT 
Pool Member 1 Bonded: 200 DOT

Now Pool Member 1 cannot unbond the full amount (only up to 190 DOT, to maintain at least 10 DOT for the pool stash to meet MinNominatorBond), and gets the InsufficientBond error on an attempt.

The solution for direct nominators is to chill before unbonding, but nomination pools do not currently support a call to permissionlessly chill if the depositor's bond is below MinNominatorBond.

For added context, StakingInterface::chill checks the threshold of the total bonded funds of the nominator, which equates to the total balance of a nomination pool's stash account.

It looks like we need a direct call into Staking::chill from the nomination pool pallet via a permissionless call, that validates the depositor's bond is less than MinNominatorBond prior to it calling chill in the staking pallet. If a pool was able to chill under this condition, members would then be able to unbond, as the pool would no longer be nominating.

@Ank4n Ank4n added the C1-mentor A task where a mentor is available. Please indicate in the issue who the mentor could be. label Nov 17, 2023
@muddlebee
Copy link
Contributor

I would like take a stab on this. I have never contributed before, so mught take time to figure out stuff 👀

@valentunn
Copy link

Another user is facing the same issue and cannot unstake all of the staked tokens:
https://polkadot.subscan.io/nomination_pool/31

@bkchr
Copy link
Member

bkchr commented Feb 19, 2024

Cc @kianenigma @Ank4n

@Ank4n
Copy link
Contributor

Ank4n commented Feb 19, 2024

I would like take a stab on this. I have never contributed before, so mught take time to figure out stuff 👀

How is it going? Have you made progress?

@Ank4n
Copy link
Contributor

Ank4n commented Feb 19, 2024

Another user is facing the same issue and cannot unstake all of the staked tokens: https://polkadot.subscan.io/nomination_pool/31

If it is possible to get in touch with pool creator, the best way currently is for them to top up their stake up to minimum bond.

The more long term solution is, as Ross described, having a permissionless extrinsic exposed by Pool that allows chilling of pool if the creator stake is lower than MinimumNominatorBond. This though has the side effect that whenever this number increases further in future, creators would need to top it up else someone can chill the pool. Given the expectation is the pool operators are actively managing the pool, this should be acceptable.

@dastansam
Copy link
Contributor

hey @Ank4n @kianenigma

I would like to work on this

@Ank4n
Copy link
Contributor

Ank4n commented Feb 21, 2024

hey @Ank4n @kianenigma

I would like to work on this

Since there is no PR yet from @muddlebee , feel free to start working on it.

@muddlebee
Copy link
Contributor

go ahead. didn't get time to pick this up.

github-merge-queue bot pushed a commit that referenced this issue Mar 7, 2024
Currently, pool member funds cannot be unbonded if the depositor's stake
is less than `MinNominatorBond`. This usually happens after
`T::MinNominatorBond` is increased.

To fix this, the above mentioned condition is added as a case for
permissionless dispatch of `chill`. After pool is chilled, pool members
can unbond their funds since pool won't be nominating anymore.

Consequently, same check is added to `nominate` call, i.e pool can not
start nominating if it's depositor does not have `MinNominatorBond`

cc @Ank4n @kianenigma 

closes #2350

Polkadot address: 16FqwPZ8GRC5U5D4Fu7W33nA55ZXzXGWHwmbnE1eT6pxuqcT

---------

Co-authored-by: Ankan <10196091+Ank4n@users.noreply.github.com>
Co-authored-by: Gonçalo Pestana <g6pestana@gmail.com>
Co-authored-by: command-bot <>
@github-project-automation github-project-automation bot moved this from 📕 Backlog to ✅ Done in (Nominated) Proof of Stake Mar 7, 2024
bgallois pushed a commit to duniter/duniter-polkadot-sdk that referenced this issue Mar 25, 2024
…ch#3453)

Currently, pool member funds cannot be unbonded if the depositor's stake
is less than `MinNominatorBond`. This usually happens after
`T::MinNominatorBond` is increased.

To fix this, the above mentioned condition is added as a case for
permissionless dispatch of `chill`. After pool is chilled, pool members
can unbond their funds since pool won't be nominating anymore.

Consequently, same check is added to `nominate` call, i.e pool can not
start nominating if it's depositor does not have `MinNominatorBond`

cc @Ank4n @kianenigma 

closes paritytech#2350

Polkadot address: 16FqwPZ8GRC5U5D4Fu7W33nA55ZXzXGWHwmbnE1eT6pxuqcT

---------

Co-authored-by: Ankan <10196091+Ank4n@users.noreply.github.com>
Co-authored-by: Gonçalo Pestana <g6pestana@gmail.com>
Co-authored-by: command-bot <>
bkchr pushed a commit that referenced this issue Apr 10, 2024
* impl backpressure in the XcmBlobHaulerAdapter

* LocalXcmQueueManager + more adapters

* OnMessageDelviered callback

* forbid mesage delivery transactions when the channel between target bridge hub and target asset hub is suspended

* pallet-xcm-bridge-hub-router

* removed commented code

* improvements and tests for palle-xcm-bridge-router

* use LocalXcmChannel in XcmBlobMessageDispatch

* new tests for logic changes in messages pallet

* tests for LocalXcmQueueSuspender

* tests for LocalXcmQueueMessageProcessor

* tests for new logic in the XcmBlobHaulerAdapter

* fix other tests in the bridge-runtime-common

* extension_reject_call_when_dispatcher_is_inactive

* benchmarks for pallet-xcm-bridge-hub-router

* get rid of redundant storage value

* add new pallet to verify-pallets-build.sh

* fixing spellcheck, clippy and rustdoc

* trigger CI

* Revert "trigger CI"

This reverts commit 48f1ba032334e3c6d8470436483736988aa060ac.

* change log target for xcm bridge router pallet

* Update modules/xcm-bridge-hub-router/src/lib.rs

Co-authored-by: Branislav Kontur <bkontur@gmail.com>

* use saturated_len where possible

* fmt

* (Suggestion) Ability to externalize configuration for `ExporterFor` (#2313)

* Ability to externalize configuration for `ExporterFor`
(Replaced `BridgedNetworkId/SiblingBridgeHubLocation` with `Bridges: ExporterFor`)

* Fix millau

* Compile fix

* Return back `BridgedNetworkId` but as optional filter

* Replaced `BaseFee` with fees from inner `Bridges: ExporterFor`

* typo

* Clippy

* Rename LocalXcmChannel to XcmChannelStatusProvider (#2319)

* Rename LocalXcmChannel to XcmChannelStatusProvider

* fmt

* added/fixed some docs

* Dynamic fees v1: report congestion status to sending chain (#2318)

* report congestion status: changes at the sending chain

* OnMessagesDelivered is back

* report congestion status: changes at the bridge hub

* moer logging

* fix? benchmarks

* spelling

* tests for XcmBlobHaulerAdapter and LocalXcmQueueManager

* tests for messages pallet

* fix typo

* rustdoc

* Update modules/messages/src/lib.rs

* apply review suggestions

* ".git/.scripts/commands/fmt/fmt.sh"

* Added `XcmBridgeHubRouterCall::report_bridge_status` encodings for AHK/P (#2350)

* Added `XcmBridgeHubRouterCall::report_bridge_status` encodings for AHK/P

* Spellcheck

* Added const for `XcmBridgeHubRouterTransactCallMaxWeight`

* Cargo.lock

* Introduced base delivery fee constants

* Congestion messages as Optional to turn on/off `supports_congestion_detection`

* Spellcheck

* Ability to externalize dest for benchmarks

* Ability to externalize dest for benchmarks

---------

Co-authored-by: Branislav Kontur <bkontur@gmail.com>
Co-authored-by: command-bot <>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
C1-mentor A task where a mentor is available. Please indicate in the issue who the mentor could be.
Projects
Status: Done
Development

Successfully merging a pull request may close this issue.

6 participants