-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
e6e79d5
commit 708fd20
Showing
2 changed files
with
170 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
The current Substrate RPC API & pallets used by the daemon, unfortunately, don't have any strict standart, which all nodes & chains follow, and the common implementations of RPC API & pallets lack of some essential features. This creates restrictions & assumptions for which nodes & chains the daemon can be used with. Of course, our first priority is and will be a support of the Polkadot relaychain & the Polkadot Asset Hub parachain with a support of USDT & USDC assets on that parachain but in the future, we'll try to lift the following limitations and support a broader range of nodes & chains along with the evolution of the Substrate ecosystem & its standarts. | ||
|
||
### Transfers | ||
|
||
All extrinsics sent by the daemon are transfer transactions. Despite they themselves are quite unsophisticated, the whole process of the approximate fee calculation to subtract it from the transfer amount and then, in case of a fail because a real fee was higher than the daemon estimated, the resending of the same transaction after another never accurate calculation does sound like a really hard path. | ||
|
||
We tried to use the [`transfer_allow_death`] call in the Balances pallet for all transfers because we thought that a transfer fee would never be greater than the existential deposit but that isn't true for all chains (e.g. it's true for Polkadot, but not for Kusama), and unlikely will be a standart, so we stuck with the [`transfer_all`] call for transfers to both the beneficiary & overpayers accounts. | ||
|
||
The Assets pallet doesn't have a call similar to Balances's [`transfer_all`], so the daemon uses [`transfer`] assuming that a fee for that call wouldn't be higher than asset's [`min_balance`]. For now, that's true for USDT & USDC on Polkadot Asset Hub, but **if one these or another asset won't meet this criteria, the daemon won't be able to work with them**. We plan to propose and hopefully include some kind of `transfer_all` call in Assets pallet to subsequently eliminate this restriction. | ||
|
||
[`transfer_all`]: https://docs.rs/pallet-balances/30.0.0/pallet_balances/pallet/struct.Pallet.html#method.transfer_all | ||
[`transfer_allow_death`]: https://docs.rs/pallet-balances/30.0.0/pallet_balances/pallet/struct.Pallet.html#method.transfer_allow_death | ||
[`transfer`]: https://docs.rs/pallet-assets/31.0.0/pallet_assets/pallet/struct.Pallet.html#method.transfer | ||
[`min_balance`]: https://docs.rs/pallet-assets/31.0.0/src/pallet_assets/types.rs.html#66 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,156 @@ | ||
## 1 | ||
|
||
**All slots are encoded with `parity-scale-codec = "3"`.** | ||
|
||
### Tables | ||
|
||
* `root` | ||
```rs | ||
type Key = String; | ||
type Value = Vec<u8>; | ||
``` | ||
|
||
Public keys of all active accounts. | ||
* `keys` | ||
```rs | ||
/// A public key. | ||
type Key = [u8; 32]; | ||
/// An accounts amount (never equals 0). | ||
type Value = U256; | ||
``` | ||
|
||
* `chains` | ||
```rs | ||
/// A chain hash. | ||
type Key = [u8; 32]; | ||
/// A last scanned block. | ||
type Value = Compact<u64>; | ||
``` | ||
|
||
* `invoices` | ||
```rs | ||
/// An invoice name. | ||
type Key = Vec<u8>; | ||
type Value = Invoice; | ||
``` | ||
|
||
* `accounts[chain_hash]` | ||
```rs | ||
/// An asset ID & an account ID. | ||
type Key = (u128, [u8; 32]); | ||
/// An invoice name. | ||
type Value = Vec<u8>; | ||
``` | ||
|
||
* `transactions[chain_hash]` | ||
```rs | ||
/// A death block. | ||
type Key = Compact<u64>; | ||
/// Pending transactions. | ||
/// An account ID, a transaction nonce, a transaction. | ||
type Values = ([u8; 32], u32, ???); | ||
``` | ||
|
||
* `hit_list` | ||
```rs | ||
/// A creation timestamp. | ||
type Key = u64; | ||
/// A chain hash, an asset ID, and an account ID. | ||
type Value = ([u8; 32], u128, [u8; 32]); | ||
``` | ||
|
||
* `archive` | ||
```rs | ||
??? | ||
``` | ||
|
||
### `root` keyed untyped slots | ||
|
||
* `db_version` | ||
```rs | ||
Compact<u64> | ||
``` | ||
|
||
* `daemon_info` | ||
```rs | ||
struct DaemonInfo { | ||
/// A chain name, genesis hash, database hash, and type. | ||
chains: Vec<(String, String, [u8; 32], ChainType)>, | ||
/// The current public key. | ||
current_key: [u8; 32], | ||
} | ||
``` | ||
|
||
### Typed slots | ||
|
||
```rs | ||
struct Invoice { | ||
/// A public key & a derivation hash. | ||
derivation: ([u8; 32], [u8; 32]), | ||
status: InvoiceStatus, | ||
/// A creation timestamp. | ||
timestamp: u64 | ||
} | ||
|
||
enum InvoiceStatus { | ||
Unpaid(u128), | ||
Paid, | ||
} | ||
|
||
??? ChainType { | ||
??? | ||
} | ||
``` | ||
|
||
## 0 | ||
|
||
**All slots are encoded with `parity-scale-codec = "3"`.** | ||
|
||
### Tables | ||
|
||
* `root` | ||
```rs | ||
type Key = String; | ||
type Value = Vec<u8>; | ||
``` | ||
|
||
* `invoices` | ||
```rs | ||
type Key = [u8; 32]; | ||
type Value = Invoice; | ||
``` | ||
|
||
### `root` keyed untyped slots | ||
|
||
* `db_version` | ||
```rs | ||
Compact<u64> | ||
``` | ||
|
||
* `daemon_info` | ||
```rs | ||
struct DaemonInfo { | ||
rpc: String, | ||
key: [u8; 32], | ||
} | ||
``` | ||
|
||
* `last_block` | ||
```rs | ||
Compact<u32> | ||
``` | ||
|
||
### Typed slots | ||
|
||
```rs | ||
struct Invoice { | ||
recipient: [u8; 32], | ||
order: [u8; 32], | ||
status: InvoiceStatus, | ||
} | ||
|
||
enum InvoiceStatus { | ||
Unpaid(u128), | ||
Paid(u128), | ||
} | ||
``` |