-
Notifications
You must be signed in to change notification settings - Fork 710
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
xcm-executor: take transport fee from transferred assets if necessary #4834
base: master
Are you sure you want to change the base?
xcm-executor: take transport fee from transferred assets if necessary #4834
Conversation
we shouldn't touch xcm-executor without open discussions (i.e. RFC process) |
I agree we can go through RFC process for this (I assumed it is ok even without RFC since it enables new scenarios without breaking any existing ones).
I don't agree, the proposed change is only used in scenarios not possible before (nobody is doing this yet) - when they'll try to do it, there are only two options (in current XCM) or three with XCMv5:
From a practical point of view, option 2 will enable needed scenarios in the Community while still being able to control fee UX from the higher levels (UI). |
The issue of adding new features without RFC is that we can't easily change/remove it in future without a breaking change. So we need to get it right. We have observed such case in past and I want to make sure we don't repeat the same mistake. I get we want to get features out and don't want to wait forever (everything it is taking too long and we need to address it somehow). However, I need to point it out with the option 2, there is a non zero chance people will lose funds in corner cases. e.g. if the fee payment mechanism is powered by a swap action and there could be someone doing market manipulation to take nearly all the transferred amount as fee and steal funds. This is a security risk and much worse than just have people funds stuck in limbo, which can be rescued via governance action. Such risk maybe tolerable (e.g. the hop/dest chain are not using swap for fee payment) but I need to make sure all the concerns are discussed and addressed. |
@xlc @seadanda @franciscoaguirre Using existing XCMv3 and XCMv4, we currently do not support DOT (or KSM for Kusama) transfers from a Parachain to the Relay Chain while using AH as reserve. We need this PR to make it possible. See #6637 XCMv5 supports it nicely. I want your input considering the XCMv5 timeline (released in SDK this year, integrated in Relay and Sys Chains Q1 2025), and the Minimal Relay migration. We have three options:
Note: option 2 is practically impossible, bound to fail in practice, so either 1 or 3. WDYT? |
Upgrade to XCM v5 requires upgrade to latest polkadot-sdk, which could be a lot of work for some teams that are many versions behind. So I can feel there will be a lot of push-back from teams about option 1. |
0bc841c
to
3a6650f
Compare
This can be paid either: - from `origin` local account if `jit_withdraw = true`, - taken from Holding register otherwise. This currently works for following hops/scenarios: 1. On destination no transport fee needed (only sending costs, not receiving), 2. Local/originating chain: just set JIT=true and fee will be paid from signed account, 3. Intermediary hops - only if intermediary is acting as reserve between two untrusted chains (aka only for `DepositReserveAsset` instruction) - this was fixed in paritytech#3142 But now we're seeing more complex asset transfers that are mixing reserve transfers with teleports depending on the involved chains. E.g. transferring DOT between Relay and parachain, but through AH (using AH instead of the Relay chain as parachain's DOT reserve). In the `Parachain --1--> AssetHub --2--> Relay` scenario, DOT has to be reserve-withdrawn in leg `1`, then teleported in leg `2`. On the intermediary hop (AssetHub), `InitiateTeleport` fails to send onward message because of missing transport fees. We also can't rely on `jit_withdraw` because the original origin is lost on the way, and even if it weren't we can't rely on the user having funded accounts on each hop along the way. - Charge the transport fee in the executor from the transferred assets (if available), - Only charge from transferred assets if JIT_WITHDRAW was not set, - Only charge from transferred assets if Holding doesn't already contain enough (other) assets to pay for the transport fee. Added regression tests in emulated transfers. Fixes paritytech#4832 Signed-off-by: Adrian Catangiu <[email protected]>
3a6650f
to
2ea6aba
Compare
Description
Sending XCM messages to other chains requires paying a "transport fee". This can be paid either:
origin
local account ifjit_withdraw = true
,This currently works for following hops/scenarios:
DepositReserveAsset
instruction) - this was fixed in xcm-executor: DepositReserveAsset charges delivery fees from inner assets #3142But now we're seeing more complex asset transfers that are mixing reserve transfers with teleports depending on the involved chains.
Example
E.g. transferring DOT between Relay and parachain, but through AH (using AH instead of the Relay chain as parachain's DOT reserve).
In the
Parachain --1--> AssetHub --2--> Relay
scenario, DOT has to be reserve-withdrawn in leg1
, then teleported in leg2
.On the intermediary hop (AssetHub),
InitiateTeleport
fails to send onward message because of missing transport fees. We also can't rely onjit_withdraw
because the original origin is lost on the way, and even if it weren't we can't rely on the user having funded accounts on each hop along the way.Solution/Changes
Testing
Added regression tests in emulated transfers.
Fixes #4832
Fixes #6637