This document provides comprehensive technical details for the registry contract within ALEX's Automated Market Maker (AMM) Trading Pool system. The contract primarily functions as a persistence module for all pool-related information needed by the main contract amm-pool-v2-01.clar.
To achieve this, the contract allows for the creation and updating of pools. Pool creation involves persisting an entry in a datamap, using token-x
, token-y
, and factor
as the key and containing all relevant pool information.
Additionally, the contract includes configuration getters and setters that support position and swap operations. It is also responsible for managing a list of blocklisted operators.
-
pools-data-map
(datamap key: { token-x: principal, token-y: principal, factor: uint } value: { pool-id: uint, total-supply: uint, balance-x: uint, balance-y: uint, pool-owner: principal, fee-rate-x: uint, fee-rate-y: uint, fee-rebate: uint, oracle-enabled: bool, oracle-average: uint, oracle-resilient: uint, start-block: uint, end-block: uint, threshold-x: uint, threshold-y: uint, max-in-ratio: uint, max-out-ratio: uint } ) A datamap structure that persists complete pool information. The map key consists of the unique pool identifier{token-x, token-y, factor}
, and the map value contains detailed pool attributes. -
pools-id-map
(datamap key: uint value: { token-x: principal, token-y: principal, factor: uint }) A datamap structure that facilitates the retrieval of pool details using the pool ID as the key. The stored values includetoken-x
andtoken-y
principals, andfactor
. -
blocklist
(datamap key: principal value: bool) A datamap structure that stores a persisted list of blocklisted addresses for operating within the Alex Trading Pool.
-
pool-nonce
(uint) A persisted variable used to generate a new pool ID incrementally. The stored value represents the last pool ID that was created. -
switch-threshold
(uint) An internal variable used to set a fixed threshold for calculations. It is initialized withu80000000
and can be retrieved and modified usingget-switch-threshold
andset-switch-threshold
functions. The value ofswitch-threshold
must be less than or equal to the constantONE_8
. This value is crucial for the mathematical formulas used within theamm-pool-v2-01.clar
contract. -
max-ratio-limit
(uint) This variable sets the upper limit for the ratio in a token pool. These ratios are evaluated during each pool swap operation to determine the maximum amount that can be deposited or exchanged in the pool. It is initialized with the value of the constantONE_8
.
This symbolic constant is employed to define and restrict decimal precision to 8 decimal places.
ONE_8
It is declared asu100000000
.
executor-dao
This call is used to verify whether a certain contract caller is designated as an extension.
create-pool
This function establishes a liquidity pool for a specified token pair (token-x/token-y). It begins by verifying that thetx-sender
is an ALEX admin operator (see the functionis-dao-or-extension
), as it is intended to be used by the mainamm-pool-v2-01.clar
contract in the current model. The primary validation performed by this function ensures that the pool does not already exist; if it does, an error is thrown. This validation considers the factor and both token combinations (token-x/token/y or token-y/token-x) as unique identifiers. When a pool is created, an entry is added to thepools-data-map
structure, using this unique identifier as the key to keep track of all pool information, including balances, fees, thresholds, and more. Additionally, the function generates an ID for the newly created pool (seepool-nonce
). All remaining values in the datamap are initialized to zero (u0
), except fororacle-enabled
, which is set tofalse
. Additionally,start-block
andend-block
are initialized with the maximum uint value to ensure the pool remains in a non-operational status until properly initialized. For a complete list of fields, refer to thepools-data-map
.
Input:
(token-x-trait <ft-trait>)
(token-y-trait <ft-trait>)
(factor uint)
(pool-owner principal)
update-pool
This function updates a liquidity pool identified by the unique combination oftoken-x
,token-y
, andfactor
. It is a governed function that restricts thetx-sender
to be an ALEX admin operator (see the functionis-dao-or-extension
). Similar to the aforementionedcreate-pool
function,update-pool
is designed to be used by the mainamm-pool-v2-01.clar
contract. However, in this case, it is used indirectly in position and swap operations.
Input:
(token-x principal)
(token-y principal)
(factor uint)
(pool-data {
pool-id: uint,
total-supply: uint,
balance-x: uint,
balance-y: uint,
pool-owner: principal,
fee-rate-x: uint,
fee-rate-y: uint,
fee-rebate: uint,
oracle-enabled: bool,
oracle-average: uint,
oracle-resilient: uint,
start-block: uint,
end-block: uint,
threshold-x: uint,
threshold-y: uint,
max-in-ratio: uint,
max-out-ratio: uint }
)
-
is-dao-or-extension
This standard protocol function checks whether a caller (tx-sender
) is the DAO executor or an authorized extension, delegating the extensions check to theexecutor-dao
contract.
Input: None. -
is-blocklisted-or-default
A read-only feature that verifies if a given address is blacklisted using theblocklist
map.
Input:
(sender principal)
set-blocklist-many
A public function, governed by theis-dao-or-extension
mechanism, that allows setting or updating the blocklisted status for a list of addresses (up to 1000 addresses).
Input:
(list 1000 {
sender: principal,
blocked: bool
})
set-fee-rebate
set-pool-owner
set-max-ratio-limit
set-switch-threshold
The following groups of functions support pool usage and configuration features consumed by the main amm-pool-v2-01.clar
contract.
set-start-block
set-end-block
set-fee-rate-x
set-fee-rate-y
set-max-in-ratio
set-max-out-ratio
set-oracle-average
set-oracle-enabled
set-threshold-x
set-threshold-y
get-pool-details-by-id
get-pool-details
get-pool-exists
get-max-ratio-limit
get-switch-threshold
set-blocklist
This is a private function designed to complement the aforementioned governance functionset-blocklist-many
.
Input:
(sender principal)
(blocked bool)
ERR-EXCEEDS-MAX-SLIPPAGE
ERR-INVALID-LIQUIDITY
ERR-INVALID-POOL
ERR-MAX-IN-RATIO
ERR-MAX-OUT-RATIO
ERR-NO-LIQUIDITY
ERR-NOT-AUTHORIZED
ERR-ORACLE-AVERAGE-BIGGER-THAN-ONE
ERR-ORACLE-NOT-ENABLED
ERR-PAUSED
ERR-PERCENT-GREATER-THAN-ONE
ERR-POOL-ALREADY-EXISTS
ERR-SWITCH-THRESHOLD-BIGGER-THAN-ONE