TL;DR
The proposal aims to recover 317.001366 USDT lost in a failed XCM transfer. Bifrost Kusama part of transfer was successful with USDT burnt on Bifrost Kusama. However, AssetHub dropped message execution since it hasn't passed one of the xcm barriers. The proposal suggests performing recovery by issuing USDT tokens on Bifrost Kusama to the user account that has originated the abovementioned xcm transfer.
Two months ago user tried to transfer 317.001366 USDT from the Bifrost Kusama chain to AssetHub (Kusama) chain. They were successfully burnt on the Bifrost Kusama side. By burning we mean that total issuance of USDT decreases whenTokens::Wihtdrawn
event is issued.
On the AssetHub side, however, the message hasn't passed a barrier. In particular, it failed due toAllowTopLevelPaidExecutionFrom
barrier which rejected the message due to zero proof_size
in WeightLimit.Limited
argument. Previously it was not a problem since proof_size
was not accounted for when checking weights. However, after a certain runtime upgrade, it started being accounted which caused the barrier to reject the message.
Given the above, this proposal aims to recover USDT on the Bifrost Kusama side.
Tokens not arriving at a user account on AssetHub doesn't necessarily mean they haven't been recorded by AssetHub. In particular, when message execution fails in XCMVM, tokens get recorded into AssetTrap
.
However, in discussed case, message execution hasn't even started - barriers checks are performed before executing message & even before initializing XCMVM. Moreover, when assets are trapped, runtime emits AssetsTrapped
event, which is not present in our case.
Given that, we can conclude, that tokens haven't been recorded by AssetHub in any way, thus creating an imbalance between AssetHub reserves and Bifrost Kusama derivatives of USDT.
We can only issue USDT on Bifrost if we are sure it won't end up with more USDT on Bifrost than there are on AssetHub.
AssetHub currently (at the time of writing) holds 26,837.133 USDT on Bifrost Kusama sovereign account.
On the other hand, Bifrost Kusama have 26,512.064781 USDT
This means AssetHub has 325.068219 USDT more in reserves than Bifrost Kusama has derivatives.
Bifrost Kusama doesn't have issue
or mint
calls for tokens
that might be called with privileged origin. Given that, the proposed recovery solution is to perform two calls wrapped in batch_all
:
tokens.setBalance
for some inaccessible account(e.g. with 0x00..00 public key)tokens.forceTransfer
from abovementioned account to the user's account (fa4zqK6a2sSd59UFJLuCz4D1fFTHEpnjqNFuUvtZR2JMfz1
)The first step is needed since we cannot safely call update_balance
since it would require accounting for existing user balance which might change while the referendum passes on-chain. Thus, we update the balance of some inaccessible accounts instead.
The Nova team performed a strong analysis on this specific bug that happened and was fixed at the time with a runtime upgrade.
So it should not happen anymore (until maybe other versions of XCM we don't know).
-> The proposed solution is the safest one in 2 steps
I fully agree nothing is user's fault here and he has to see his USDT back.
i am the user who lost the fund, although i am frustrated how long the process is, but i know how democracy work and this process takes time, Web3 is so small and our community is not large. But if we gradually improve over times when things happen, we are on the way to the bright future that will be happenned inevitably. Best wishes to the teams, i really appreciated what Nova and Bifrost's team have done for the our entire ecosystem.
I think there is no problem, we can consider promoting the proposal as soon as possible. Given that bifrost currently has sufficient USDT reserves in the statemine to deal with this part of USDT that needs to be issued, I don’t think there will be too much controversy in the whole process . But for the processing method, I think it is feasible to use currencies.updateBalance
directly. This method will increase or decrease the set number of tokens at the specified address, and will not be affected by the original number of tokens in the address.
Edited
I agree with the proposal, it will set a precedent for the technical forces to recover user's fund when incident occurred thus will prove the highest security of XCM transfers