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

Adjust the default GraphQL complexity for queries that can potentially use indexation #2496

Open
rafal-ch opened this issue Dec 12, 2024 · 2 comments
Assignees

Comments

@rafal-ch
Copy link
Contributor

Basically, this issue is about resolving the following TODO in the code.

pub const DEFAULT_QUERY_COSTS: Costs = Costs {
    // TODO: The cost of the `balance` and `balances` query should depend on the
    //  `OffChainDatabase::balances_enabled` value. If additional indexation is enabled,
    //  the cost should be cheaper.
    balance_query: 40001,
    coins_to_spend: 40001,

If the "balances" or "coins to spend" indexation is available in the particular instance of the client, these costs should be lower.

Please note that the default cost is no longer "const", as it depends on the flag in offchain DB metadata (indexation_availability flag).

@anubhavitis
Copy link

@rafal-ch
I am interested to work on this issue. Can you help me with it please.

Based on what I understand, OffChainDatabase::balances_enabled value should determine the default cost of balance_query. But how do we calculate that in first place?

@rafal-ch
Copy link
Contributor Author

Hi @anubhavitis
Thanks for offering to lend a hand but we're going to have to put a pin in this for now and think a bit about the best way forward.

rafal-ch added a commit that referenced this issue Jan 13, 2025
Closes #2391

This PR includes all changes from the [Part 1
PR](#2455), making it
deprecated.

## Description
Changes in this PR:

#### The new `CoinsToSpend` index
* This is the database that stores all coins to spend sorted by the
amounts (i.e. largest-by-value coins first)
* The key consists of several parts
* _Retryable flag_ - to distinguish between retryable messages and other
coins
  * _Address_ (owner)
  * _AssetID_
* _Amount_ - as "big-endian" bytes to leverage the RocksDB key sorting
capabilities
* _Foreign Key_ - this are bytes of the key from either the `Messages`
or `Coins` on-chain databases
    * for messages this is a 32-bytes `Nonce`
    * for coins this is a 34-bytes `UtxoId`
* The value is an instance of `IndexedCoinType` enum, so we know which
on-chain database to query when returning the actual coins
* This index is updated when executor events are processed
* When querying for "coins to spend" the following algorithm is applied:
* First, we get as many "big" coins as required to satisfy _double the
amount_ from the query (respecting `max` and `excluded` params)
* If we have enough coins, but there are still some "slots" in the query
left (because we selected less coins than `max`) we fill the remaining
slots with a **random** number of "dust" coins
* If it happens that the value of selected "dust coins" is able to cover
the value of some of the already selected "big coins", we remove the
latter from the response
* If at any step we encounter a problem (reading from database, integer
conversions, etc.) we bail with an appropriate error

#### Changes to `CoinsQueryError` type
* The `MaxCoinsReached` variant has been removed because in the new
algorithm we never query for more coins than the specified `max`, hence,
without additional effort, we are not able to tell whether the query
could be satisfied if user provided bigger `max`
* The `InsufficientCoins` has been renamed to
`InsufficientCoinsForTheMax` and it now contains the additional `max`
field

#### Off-chain database metadata
* The metadata for off-chain database now contain the additional
`IndexationKind` - `CoinsToSpend`

#### Refactoring
* The `indexation.rs` module was split into separate files, each per
indexation type + errors + some utils.

#### Other
* Integration tests have to be updated to not expect the exact number of
coins to spend in the response (currently, due to randomness, we're not
deterministic in this regard)
* The number of excluded ids in the `coinsToSpend` GraphQL query is now
limited to the maximum number of inputs allowed in transaction.

### Before requesting review
- [X] I have reviewed the code myself
- [X] I have created follow-up issues caused by this PR and linked them
here

### Follow-up issues
* #2498
* #2448
* #2428
* #2499
* #2496

---------

Co-authored-by: Green Baneling <XgreenX9999@gmail.com>
@rafal-ch rafal-ch self-assigned this Jan 13, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants