22e31affe2
* sdk/rust: organize workspace * sdk/rust: add serde_wormhole to deps * sdk/rust: serde_wormhole -> wormhole-raw-serde * sdk/rust: add supported-chains; serde_wormhole -> wormhole-vaas-serde * cosmwasm: fix deps * sdk/rust: fix fmt * sdk/rust: jk * sdk/rust: add desc * sdk/rust: rm Cargo.lock * .github: fix workflow --------- Co-authored-by: A5 Pickle <a5-pickle@users.noreply.github.com> |
||
---|---|---|
.. | ||
examples | ||
schema | ||
src | ||
tests | ||
Cargo.toml | ||
README.md |
README.md
Native Token Transfer - Global Accountant
This contract is intended to serve the same purpose as the Global Accountant, but for Native Token Transfer protocols instead of the Token Bridge.
This is made possible by the following modifications:
- Keep a list of Standard Relayer emitters.
- These registrations are approved by Wormhole Governance akin to the Token Bridge, so this is a 1-1 replacement.
- Extract the message sender and payload from either a Core Bridge message or a Standard Relayer payload.
- NTTs can either emit messages via their transceiver directly or via Standard Relayers.
- This should be done in the accountant contract (as opposed to pre-processed by the guardian) in order to support backfilling signed VAAs.
- Keep a map of registered NTT transceivers and their locking hub.
- This contract must be able to permissionlessly determine what constitutes a valid transfer between two NTT transceivers. In order to determine that, the contract needs to have a record of both the sending and receiving transceivers' registrations.
- An NTT transceiver emits a VAA when...
- it is initialized, which includes if it's associated manager is in
locking
orburning
mode. - a new transceiver is registered with it.
- it is initialized, which includes if it's associated manager is in
- These VAAs can then be relayed to the NTT Global Accountant, verified, parsed, and stored into a map.
- These maps are a one-way lookup of...
- Transceiver hubs
[chainA, emitter address] -> [chainB, foreign transceiver emitter address]
- Transceiver peers
[chainA, emitter address, chainB] -> [foreign transceiver emitter address]
- Transceiver hubs
- Update the logic for handling an observation or NTT transfer VAA. Instead of checking the token bridge emitter:
- If the core message was from a known Standard Relayer emitter, use the sender as the emitter, otherwise use the core message emitter.
- If the emitter (sender) does not have a key in the maps, return.
- If the emitter's foreign transceiver (known receiver) does not match the target recipient, return.
- If the foreign transceiver (receiver) does not have a registration for the emitter (sender) - i.e. they are not cross-registered, return.
- Use
<chain, locking_hub_chain, locking_hub_transceiver_address>
in place of<chain, token_chain, token_address>
for theAccount::key
to track each network of transceivers separately. This requires a 1:1 transceiver:token mapping.
The guardians will have a new allow list of NTTs and will be expected to submit observations for the allow-listed NTTs to the NTT global accountant contract on Wormhole Gateway.
Caveats
- The NTT Global Accountant can only account for NTTs which have exactly one Manager in
lock
mode. In an allburn
mode network, the tokens have a potentially unlimited supply on every chain or other legitimate methods of minting which cannot be known to the accountant. In a multiplelock
setup, the existing accountant logic, which is single-source chain per "token", would no longer directly apply. It is possible for these cases to be covered in the future, but may require further NTT protocol and significant accountant logic changes. - The NTT Global Accountant expects each transceiver to be associated with exactly 1 token.
- In order to avoid backfilling (the process of relaying VAAs emitted prior to the enforcement of Global Accountant on a network of NTTs), these initial steps should be completed, in order, before making any transfers.
- Initialize the NTT transceivers.
- Add the NTT transceivers' emitters to the Guardian's allow list.
- Cross-register the NTT transceivers on-chain, emitting the VAAs.
- Submit the locking mode initialization VAA to the NTT accountant contract.
- Submit the burn transceivers' locking hub registration VAA to the NTT accountant contract.
- Submit the remaining registration VAAs to the NTT accountant.