HedgerPool
Inherits: Initializable, ReentrancyGuardUpgradeable, AccessControlUpgradeable, PausableUpgradeable, SecureUpgradeable
Author: Quantillon Labs - Nicolas Bellengé - @chewbaccoin
Optimized EUR/USD hedging pool for managing currency risk and providing yield
Optimized version with reduced contract size through library extraction and code consolidation
Note: security-contact: team@quantillon.money
State Variables
GOVERNANCE_ROLE
bytes32 public constant GOVERNANCE_ROLE = keccak256("GOVERNANCE_ROLE")
LIQUIDATOR_ROLE
bytes32 public constant LIQUIDATOR_ROLE = keccak256("LIQUIDATOR_ROLE")
EMERGENCY_ROLE
bytes32 public constant EMERGENCY_ROLE = keccak256("EMERGENCY_ROLE")
HEDGER_ROLE
bytes32 public constant HEDGER_ROLE = keccak256("HEDGER_ROLE")
usdc
IERC20 public usdc
oracle
IChainlinkOracle public oracle
yieldShift
IYieldShift public yieldShift
vault
IQuantillonVault public vault
treasury
address public treasury
TIME_PROVIDER
TimeProvider public immutable TIME_PROVIDER
coreParams
CoreParams public coreParams
totalMargin
uint256 public totalMargin
totalExposure
uint256 public totalExposure
activeHedgers
uint256 public activeHedgers
nextPositionId
uint256 public nextPositionId
isWhitelistedHedger
mapping(address => bool) public isWhitelistedHedger
hedgerWhitelistEnabled
bool public hedgerWhitelistEnabled
positions
mapping(uint256 => HedgePosition) public positions
hedgers
mapping(address => HedgerInfo) public hedgers
activePositionCount
mapping(address => uint256) public activePositionCount
hedgerHasPosition
mapping(address => mapping(uint256 => bool)) public hedgerHasPosition
positionIndex
mapping(address => mapping(uint256 => uint256)) public positionIndex
liquidationCommitments
mapping(bytes32 => bool) public liquidationCommitments
liquidationCommitmentTimes
mapping(bytes32 => uint256) public liquidationCommitmentTimes
lastLiquidationAttempt
mapping(address => uint256) public lastLiquidationAttempt
hasPendingLiquidation
mapping(address => mapping(uint256 => bool)) public hasPendingLiquidation
hedgerLastRewardBlock
mapping(address => uint256) public hedgerLastRewardBlock
MAX_POSITIONS_PER_HEDGER
uint256 public constant MAX_POSITIONS_PER_HEDGER = 50
MAX_UINT96_VALUE
uint96 public constant MAX_UINT96_VALUE = type(uint96).max
MAX_POSITION_SIZE
uint256 public constant MAX_POSITION_SIZE = MAX_UINT96_VALUE
MAX_MARGIN
uint256 public constant MAX_MARGIN = MAX_UINT96_VALUE
MAX_ENTRY_PRICE
uint256 public constant MAX_ENTRY_PRICE = MAX_UINT96_VALUE
MAX_LEVERAGE
uint256 public constant MAX_LEVERAGE = type(uint16).max
MAX_MARGIN_RATIO
uint256 public constant MAX_MARGIN_RATIO = 5000
MAX_UINT128_VALUE
uint128 public constant MAX_UINT128_VALUE = type(uint128).max
MAX_TOTAL_MARGIN
uint256 public constant MAX_TOTAL_MARGIN = MAX_UINT128_VALUE
MAX_TOTAL_EXPOSURE
uint256 public constant MAX_TOTAL_EXPOSURE = MAX_UINT128_VALUE
MAX_PENDING_REWARDS
uint256 public constant MAX_PENDING_REWARDS = MAX_UINT128_VALUE
LIQUIDATION_COOLDOWN
uint256 public constant LIQUIDATION_COOLDOWN = 300
MAX_REWARD_PERIOD
uint256 public constant MAX_REWARD_PERIOD = 365 days
Functions
flashLoanProtection
modifier flashLoanProtection() ;
secureNonReentrant
modifier secureNonReentrant() ;
constructor
Initializes the HedgerPool contract with a time provider
Constructor that sets up the time provider and disables initializers for upgrade safety
Notes:
- 
security: Validates that the time provider is not zero address 
- 
validation: Ensures TIME_PROVIDER is a valid contract address 
- 
state-changes: Sets TIME_PROVIDER and disables initializers 
- 
events: None 
- 
errors: Throws ZeroAddress if _TIME_PROVIDER is address(0) 
- 
reentrancy: Not applicable - constructor 
- 
access: Public constructor 
- 
oracle: Not applicable 
constructor(TimeProvider _TIME_PROVIDER) ;
Parameters
| Name | Type | Description | 
|---|---|---|
| _TIME_PROVIDER | TimeProvider | The time provider contract for timestamp management | 
initialize
Initializes the HedgerPool with contracts and parameters
This function configures:
- Access roles and permissions
- References to external contracts
- Default protocol parameters
- Security (pause, reentrancy, upgrades)
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Initializes all contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by initializer modifier 
- 
access: Restricted to initializer modifier 
- 
oracle: No oracle dependencies 
function initialize(
    address admin,
    address _usdc,
    address _oracle,
    address _yieldShift,
    address _timelock,
    address _treasury,
    address _vault
) public initializer;
Parameters
| Name | Type | Description | 
|---|---|---|
| admin | address | Address with administrator privileges | 
| _usdc | address | Address of the USDC token contract | 
| _oracle | address | Address of the Oracle contract | 
| _yieldShift | address | Address of the YieldShift contract | 
| _timelock | address | Address of the timelock contract | 
| _treasury | address | Address of the treasury contract | 
| _vault | address | Address of the QuantillonVault contract | 
enterHedgePosition
Opens a new hedge position for a hedger
Position opening process:
- Validates hedger whitelist status
- Fetches current EUR/USD price from oracle
- Calculates position size and validates parameters
- Transfers USDC to vault for unified liquidity
- Creates position record and updates hedger stats
Security features:
- Flash loan protection via secureNonReentrant
- Whitelist validation if enabled
- Parameter validation (leverage, amounts)
- Oracle price validation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates amount > 0, leverage within limits, hedger whitelist 
- 
state-changes: Creates new position, updates hedger stats, transfers USDC to vault 
- 
events: Emits HedgePositionOpened with position details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by secureNonReentrant modifier and proper CEI pattern 
- 
access: Restricted to whitelisted hedgers (if whitelist enabled) 
- 
oracle: Requires fresh oracle price data 
function enterHedgePosition(uint256 usdcAmount, uint256 leverage)
    external
    secureNonReentrant
    returns (uint256 positionId);
Parameters
| Name | Type | Description | 
|---|---|---|
| usdcAmount | uint256 | Amount of USDC to deposit as margin (6 decimals) | 
| leverage | uint256 | Leverage multiplier for the position (1-20x) | 
Returns
| Name | Type | Description | 
|---|---|---|
| positionId | uint256 | Unique identifier for the new position | 
exitHedgePosition
Closes an existing hedge position
Position closing process:
- Validates position ownership and active status
- Checks protocol collateralization safety
- Calculates current PnL based on price change
- Determines net payout to hedger
- Updates hedger stats and removes position
- Withdraws USDC from vault for hedger payout
Security features:
- Position ownership validation
- Protocol collateralization safety check
- Pause protection
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates position ownership, active status, and protocol safety 
- 
state-changes: Closes position, updates hedger stats, withdraws USDC from vault 
- 
events: Emits HedgePositionClosed with position details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by whenNotPaused modifier 
- 
access: Restricted to position owner 
- 
oracle: Requires fresh oracle price data 
function exitHedgePosition(uint256 positionId) external whenNotPaused returns (int256 pnl);
Parameters
| Name | Type | Description | 
|---|---|---|
| positionId | uint256 | Unique identifier of the position to close | 
Returns
| Name | Type | Description | 
|---|---|---|
| pnl | int256 | Profit or loss from the position (positive = profit, negative = loss) | 
addMargin
Adds additional margin to an existing hedge position
Margin addition process:
- Validates position ownership and active status
- Validates amount is positive
- Checks liquidation cooldown and pending liquidation status
- Transfers USDC from hedger to vault
- Updates position margin and hedger stats
Security features:
- Flash loan protection
- Position ownership validation
- Liquidation cooldown validation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates position ownership, active status, positive amount, liquidation cooldown 
- 
state-changes: Updates position margin, hedger stats, transfers USDC to vault 
- 
events: Emits MarginAdded with position details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by flashLoanProtection modifier 
- 
access: Restricted to position owner 
- 
oracle: No oracle dependencies 
function addMargin(uint256 positionId, uint256 amount) external flashLoanProtection;
Parameters
| Name | Type | Description | 
|---|---|---|
| positionId | uint256 | Unique identifier of the position | 
| amount | uint256 | Amount of USDC to add as margin (6 decimals) | 
removeMargin
Removes margin from an existing hedge position
Margin removal process:
- Validates position ownership and active status
- Validates amount is positive
- Validates margin operation maintains minimum margin ratio
- Updates position margin and hedger stats
- Withdraws USDC from vault to hedger
Security features:
- Flash loan protection
- Position ownership validation
- Minimum margin ratio validation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates position ownership, active status, positive amount, minimum margin ratio 
- 
state-changes: Updates position margin, hedger stats, withdraws USDC from vault 
- 
events: Emits MarginUpdated with position details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by flashLoanProtection modifier 
- 
access: Restricted to position owner 
- 
oracle: No oracle dependencies 
function removeMargin(uint256 positionId, uint256 amount) external flashLoanProtection;
Parameters
| Name | Type | Description | 
|---|---|---|
| positionId | uint256 | Unique identifier of the position | 
| amount | uint256 | Amount of USDC to remove from margin (6 decimals) | 
commitLiquidation
Commits to liquidating a hedger position with a salt for MEV protection
Creates a liquidation commitment that must be executed within a time window
Notes:
- 
security: Requires LIQUIDATOR_ROLE, validates addresses and position ID 
- 
validation: Ensures hedger is valid address, positionId > 0, commitment doesn't exist 
- 
state-changes: Sets liquidation commitment, timing, and pending liquidation flags 
- 
events: None (commitment phase) 
- 
errors: Throws InvalidRole, InvalidAddress, InvalidPosition, or CommitmentExists 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to LIQUIDATOR_ROLE 
- 
oracle: Not applicable 
function commitLiquidation(address hedger, uint256 positionId, bytes32 salt) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger whose position will be liquidated | 
| positionId | uint256 | ID of the position to liquidate | 
| salt | bytes32 | Random salt for commitment uniqueness and MEV protection | 
liquidateHedger
Liquidates an undercollateralized hedge position
Liquidation process:
- Validates liquidator role and commitment
- Validates position ownership and active status
- Calculates liquidation reward and remaining margin
- Updates hedger stats and removes position
- Withdraws USDC from vault for liquidator reward and remaining margin
Security features:
- Role-based access control (LIQUIDATOR_ROLE)
- Commitment validation to prevent front-running
- Reentrancy protection
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates liquidator role, commitment, position ownership, active status 
- 
state-changes: Liquidates position, updates hedger stats, withdraws USDC from vault 
- 
events: Emits HedgerLiquidated with liquidation details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to LIQUIDATOR_ROLE 
- 
oracle: Requires fresh oracle price data 
function liquidateHedger(address hedger, uint256 positionId, bytes32 salt)
    external
    nonReentrant
    returns (uint256 liquidationReward);
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger to liquidate | 
| positionId | uint256 | Unique identifier of the position to liquidate | 
| salt | bytes32 | Random salt for commitment validation | 
Returns
| Name | Type | Description | 
|---|---|---|
| liquidationReward | uint256 | Amount of USDC reward for the liquidator | 
claimHedgingRewards
Claims hedging rewards for a hedger
Reward claiming process:
- Calculates interest differential based on exposure and rates
- Calculates yield shift rewards from YieldShift contract
- Updates hedger's last reward block
- Transfers total rewards to hedger
Security features:
- Reentrancy protection
- Reward calculation validation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates hedger has active positions and rewards available 
- 
state-changes: Updates hedger reward tracking, transfers rewards 
- 
events: Emits HedgingRewardsClaimed with reward details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to hedgers with active positions 
- 
oracle: No oracle dependencies 
function claimHedgingRewards()
    external
    nonReentrant
    returns (uint256 interestDifferential, uint256 yieldShiftRewards, uint256 totalRewards);
Returns
| Name | Type | Description | 
|---|---|---|
| interestDifferential | uint256 | Interest differential rewards earned | 
| yieldShiftRewards | uint256 | Yield shift rewards earned | 
| totalRewards | uint256 | Total rewards claimed | 
getHedgerPosition
Retrieves detailed information about a specific hedger position
Returns position data including current oracle price for real-time calculations
Notes:
- 
security: Validates that the caller owns the position 
- 
validation: Ensures position exists and hedger matches 
- 
state-changes: None (view function with oracle call) 
- 
events: None 
- 
errors: Throws InvalidHedger if position doesn't belong to hedger 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Public (anyone can query position data) 
- 
oracle: Calls _getValidOraclePrice() for current price 
function getHedgerPosition(address hedger, uint256 positionId)
    external
    view
    returns (
        uint256 positionSize,
        uint256 margin,
        uint256 entryPrice,
        uint256 currentPrice,
        uint256 leverage,
        uint256 lastUpdateTime
    );
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger who owns the position | 
| positionId | uint256 | ID of the position to retrieve | 
Returns
| Name | Type | Description | 
|---|---|---|
| positionSize | uint256 | Current size of the position in USDC | 
| margin | uint256 | Current margin amount for the position | 
| entryPrice | uint256 | Price at which the position was opened | 
| currentPrice | uint256 | Current EUR/USD price from oracle | 
| leverage | uint256 | Leverage multiplier for the position | 
| lastUpdateTime | uint256 | Timestamp of last position update | 
getHedgerMarginRatio
Calculates the current margin ratio for a hedger position
Returns margin ratio as basis points (10000 = 100%)
Notes:
- 
security: Validates that the caller owns the position 
- 
validation: Ensures position exists and hedger matches 
- 
state-changes: None (view function) 
- 
events: None 
- 
errors: Throws InvalidHedger if position doesn't belong to hedger 
- 
reentrancy: Not applicable - view function 
- 
access: Public (anyone can query margin ratio) 
- 
oracle: Not applicable 
function getHedgerMarginRatio(address hedger, uint256 positionId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger who owns the position | 
| positionId | uint256 | ID of the position to check | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | Current margin ratio in basis points (margin/positionSize * 10000) | 
isHedgerLiquidatable
Checks if a hedger position is eligible for liquidation
Uses current oracle price to determine if position is undercollateralized
Notes:
- 
security: Validates that the caller owns the position 
- 
validation: Ensures position exists, is active, and hedger matches 
- 
state-changes: None (view function with oracle call) 
- 
events: None 
- 
errors: Throws InvalidHedger if position doesn't belong to hedger 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Public (anyone can check liquidation status) 
- 
oracle: Calls _getValidOraclePrice() for current price comparison 
function isHedgerLiquidatable(address hedger, uint256 positionId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger who owns the position | 
| positionId | uint256 | ID of the position to check | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | True if position can be liquidated, false otherwise | 
getTotalHedgeExposure
Returns the total hedge exposure across all active positions
Provides aggregate exposure for risk management and monitoring
Notes:
- 
security: No security validations required for view function 
- 
validation: None required for view function 
- 
state-changes: None (view function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - view function 
- 
access: Public (anyone can query total exposure) 
- 
oracle: Not applicable 
function getTotalHedgeExposure() external view returns (uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | Total exposure amount in USDC across all active hedge positions | 
updateHedgingParameters
Updates core hedging parameters for the protocol
Allows governance to adjust risk parameters for hedge positions
Notes:
- 
security: Requires GOVERNANCE_ROLE, validates parameter ranges 
- 
validation: Ensures minMarginRatio >= 500, liquidationThreshold < minMarginRatio, maxLeverage <= 20, liquidationPenalty <= 1000 
- 
state-changes: Updates coreParams struct with new values 
- 
events: None 
- 
errors: Throws InvalidRole, ConfigValueTooLow, ConfigInvalid, or ConfigValueTooHigh 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: Not applicable 
function updateHedgingParameters(
    uint256 newMinMarginRatio,
    uint256 newLiquidationThreshold,
    uint256 newMaxLeverage,
    uint256 newLiquidationPenalty
) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newMinMarginRatio | uint256 | New minimum margin ratio in basis points (minimum 500 = 5%) | 
| newLiquidationThreshold | uint256 | New liquidation threshold in basis points (must be < minMarginRatio) | 
| newMaxLeverage | uint256 | New maximum leverage multiplier (maximum 20x) | 
| newLiquidationPenalty | uint256 | New liquidation penalty in basis points (maximum 1000 = 10%) | 
updateInterestRates
Updates interest rates for EUR and USD positions
Allows governance to adjust interest rates for yield calculations
Notes:
- 
security: Requires GOVERNANCE_ROLE, validates rate limits 
- 
validation: Ensures both rates are <= 2000 basis points (20%) 
- 
state-changes: Updates coreParams with new interest rates 
- 
events: None 
- 
errors: Throws InvalidRole or ConfigValueTooHigh 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: Not applicable 
function updateInterestRates(uint256 newEurRate, uint256 newUsdRate) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newEurRate | uint256 | New EUR interest rate in basis points (maximum 2000 = 20%) | 
| newUsdRate | uint256 | New USD interest rate in basis points (maximum 2000 = 20%) | 
setHedgingFees
Sets the fee structure for hedge positions
Allows governance to adjust fees for position entry, exit, and margin operations
Notes:
- 
security: Requires GOVERNANCE_ROLE, validates fee limits 
- 
validation: Ensures entryFee <= 100, exitFee <= 100, marginFee <= 50 
- 
state-changes: Updates coreParams with new fee values 
- 
events: None 
- 
errors: Throws InvalidRole or InvalidFee 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: Not applicable 
function setHedgingFees(uint256 _entryFee, uint256 _exitFee, uint256 _marginFee) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| _entryFee | uint256 | New entry fee in basis points (maximum 100 = 1%) | 
| _exitFee | uint256 | New exit fee in basis points (maximum 100 = 1%) | 
| _marginFee | uint256 | New margin fee in basis points (maximum 50 = 0.5%) | 
emergencyClosePosition
Emergency closure of a hedge position by governance
Emergency closure process:
- Validates emergency role and position ownership
- Validates position is active
- Updates hedger stats and removes position
- Withdraws USDC from vault for hedger's margin
Security features:
- Role-based access control (EMERGENCY_ROLE)
- Position ownership validation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates emergency role, position ownership, active status 
- 
state-changes: Closes position, updates hedger stats, withdraws USDC from vault 
- 
events: Emits EmergencyPositionClosed with position details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Not protected - emergency function 
- 
access: Restricted to EMERGENCY_ROLE 
- 
oracle: No oracle dependencies 
function emergencyClosePosition(address hedger, uint256 positionId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger whose position to close | 
| positionId | uint256 | Unique identifier of the position to close | 
pause
Pauses all contract operations in case of emergency
Emergency function to halt all user interactions
Notes:
- 
security: Requires EMERGENCY_ROLE 
- 
validation: None required 
- 
state-changes: Sets contract to paused state 
- 
events: Emits Paused event 
- 
errors: Throws InvalidRole if caller lacks EMERGENCY_ROLE 
- 
reentrancy: Not applicable 
- 
access: Restricted to EMERGENCY_ROLE 
- 
oracle: Not applicable 
function pause() external;
unpause
Unpauses contract operations after emergency
Resumes normal contract functionality
Notes:
- 
security: Requires EMERGENCY_ROLE 
- 
validation: None required 
- 
state-changes: Sets contract to unpaused state 
- 
events: Emits Unpaused event 
- 
errors: Throws InvalidRole if caller lacks EMERGENCY_ROLE 
- 
reentrancy: Not applicable 
- 
access: Restricted to EMERGENCY_ROLE 
- 
oracle: Not applicable 
function unpause() external;
hasPendingLiquidationCommitment
Checks if a position has a pending liquidation commitment
Returns true if a liquidation commitment exists for the position
Notes:
- 
security: No security validations required for view function 
- 
validation: None required for view function 
- 
state-changes: None (view function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - view function 
- 
access: Public (anyone can query commitment status) 
- 
oracle: Not applicable 
function hasPendingLiquidationCommitment(address hedger, uint256 positionId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger who owns the position | 
| positionId | uint256 | ID of the position to check | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | True if liquidation commitment exists, false otherwise | 
getHedgingConfig
Returns the current hedging configuration parameters
Provides access to all core hedging parameters for external contracts
Notes:
- 
security: No security validations required for view function 
- 
validation: None required for view function 
- 
state-changes: None (view function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - view function 
- 
access: Public (anyone can query configuration) 
- 
oracle: Not applicable 
function getHedgingConfig()
    external
    view
    returns (
        uint256 minMarginRatio_,
        uint256 liquidationThreshold_,
        uint256 maxLeverage_,
        uint256 liquidationPenalty_,
        uint256 entryFee_,
        uint256 exitFee_
    );
Returns
| Name | Type | Description | 
|---|---|---|
| minMarginRatio_ | uint256 | Current minimum margin ratio in basis points | 
| liquidationThreshold_ | uint256 | Current liquidation threshold in basis points | 
| maxLeverage_ | uint256 | Current maximum leverage multiplier | 
| liquidationPenalty_ | uint256 | Current liquidation penalty in basis points | 
| entryFee_ | uint256 | Current entry fee in basis points | 
| exitFee_ | uint256 | Current exit fee in basis points | 
marginFee
Returns the current margin fee rate
Provides the margin fee for margin operations
Notes:
- 
security: No security validations required for view function 
- 
validation: None required for view function 
- 
state-changes: None (view function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - view function 
- 
access: Public (anyone can query margin fee) 
- 
oracle: Not applicable 
function marginFee() external view returns (uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | Current margin fee in basis points | 
getMaxValues
Returns the maximum allowed values for various parameters
Provides hard limits for position sizes, margins, and other constraints
Notes:
- 
security: No security validations required for pure function 
- 
validation: None required for pure function 
- 
state-changes: None (pure function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - pure function 
- 
access: Public (anyone can query max values) 
- 
oracle: Not applicable 
function getMaxValues()
    external
    pure
    returns (
        uint256 maxPositionSize,
        uint256 maxMargin,
        uint256 maxEntryPrice,
        uint256 maxLeverageValue,
        uint256 maxTotalMargin,
        uint256 maxTotalExposure,
        uint256 maxPendingRewards
    );
Returns
| Name | Type | Description | 
|---|---|---|
| maxPositionSize | uint256 | Maximum position size in USDC | 
| maxMargin | uint256 | Maximum margin per position in USDC | 
| maxEntryPrice | uint256 | Maximum entry price for positions | 
| maxLeverageValue | uint256 | Maximum leverage multiplier | 
| maxTotalMargin | uint256 | Maximum total margin across all positions | 
| maxTotalExposure | uint256 | Maximum total exposure across all positions | 
| maxPendingRewards | uint256 | Maximum pending rewards amount | 
isHedgingActive
Checks if hedging operations are currently active
Returns true if contract is not paused, false if paused
Notes:
- 
security: No security validations required for view function 
- 
validation: None required for view function 
- 
state-changes: None (view function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - view function 
- 
access: Public (anyone can query hedging status) 
- 
oracle: Not applicable 
function isHedgingActive() external view returns (bool);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | True if hedging is active, false if paused | 
clearExpiredLiquidationCommitment
Clears expired liquidation commitments after cooldown period
Allows liquidators to clean up expired commitments
Notes:
- 
security: Requires LIQUIDATOR_ROLE, checks cooldown period 
- 
validation: Ensures cooldown period has passed 
- 
state-changes: Clears pending liquidation flag if expired 
- 
events: None 
- 
errors: Throws InvalidRole if caller lacks LIQUIDATOR_ROLE 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to LIQUIDATOR_ROLE 
- 
oracle: Not applicable 
function clearExpiredLiquidationCommitment(address hedger, uint256 positionId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger whose commitment to clear | 
| positionId | uint256 | ID of the position whose commitment to clear | 
cancelLiquidationCommitment
Cancels a liquidation commitment before execution
Allows liquidators to cancel their own commitments
Notes:
- 
security: Requires LIQUIDATOR_ROLE, validates commitment exists 
- 
validation: Ensures commitment exists and belongs to caller 
- 
state-changes: Deletes commitment data and clears pending liquidation flag 
- 
events: None 
- 
errors: Throws InvalidRole or CommitmentNotFound 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to LIQUIDATOR_ROLE 
- 
oracle: Not applicable 
function cancelLiquidationCommitment(address hedger, uint256 positionId, bytes32 salt) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger whose position was committed for liquidation | 
| positionId | uint256 | ID of the position whose commitment to cancel | 
| salt | bytes32 | Salt used in the original commitment | 
recoverToken
Recovers accidentally sent tokens to the treasury
Emergency function to recover tokens sent to the contract
Notes:
- 
security: Requires DEFAULT_ADMIN_ROLE 
- 
validation: None required 
- 
state-changes: Transfers tokens from contract to treasury 
- 
events: None 
- 
errors: Throws InvalidRole if caller lacks DEFAULT_ADMIN_ROLE 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to DEFAULT_ADMIN_ROLE 
- 
oracle: Not applicable 
function recoverToken(address token, uint256 amount) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| token | address | Address of the token to recover | 
| amount | uint256 | Amount of tokens to recover | 
recoverETH
Recovers accidentally sent ETH to the treasury
Emergency function to recover ETH sent to the contract
Notes:
- 
security: Requires DEFAULT_ADMIN_ROLE 
- 
validation: None required 
- 
state-changes: Transfers ETH from contract to treasury 
- 
events: Emits ETHRecovered event 
- 
errors: Throws InvalidRole if caller lacks DEFAULT_ADMIN_ROLE 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to DEFAULT_ADMIN_ROLE 
- 
oracle: Not applicable 
function recoverETH() external;
updateTreasury
Updates the treasury address for fee collection
Allows governance to change the treasury address
Notes:
- 
security: Requires GOVERNANCE_ROLE, validates address 
- 
validation: Ensures treasury is not zero address and passes validation 
- 
state-changes: Updates treasury address 
- 
events: Emits TreasuryUpdated event 
- 
errors: Throws InvalidRole, InvalidAddress, or zero address error 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: Not applicable 
function updateTreasury(address _treasury) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| _treasury | address | New treasury address for fee collection | 
updateVault
Updates the vault address for USDC management
Allows governance to change the vault contract address
Notes:
- 
security: Requires GOVERNANCE_ROLE, validates address 
- 
validation: Ensures vault is not zero address 
- 
state-changes: Updates vault address 
- 
events: Emits VaultUpdated event 
- 
errors: Throws InvalidRole or InvalidAddress 
- 
reentrancy: Protected by nonReentrant modifier 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: Not applicable 
function updateVault(address _vault) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| _vault | address | New vault address for USDC operations | 
updateOracle
Updates the oracle address
Governance-only setter to allow phased wiring after minimal initialization
function updateOracle(address _oracle) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| _oracle | address | New oracle address | 
updateYieldShift
Updates the YieldShift address
Governance-only setter to allow phased wiring after minimal initialization
function updateYieldShift(address _yieldShift) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| _yieldShift | address | New YieldShift address | 
whitelistHedger
Whitelists a hedger address for position opening
Whitelisting process:
- Validates governance role and hedger address
- Checks hedger is not already whitelisted
- Adds hedger to whitelist and grants HEDGER_ROLE
Security features:
- Role-based access control (GOVERNANCE_ROLE)
- Address validation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates governance role, hedger address, not already whitelisted 
- 
state-changes: Adds hedger to whitelist, grants HEDGER_ROLE 
- 
events: Emits HedgerWhitelisted with hedger and caller details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Not protected - governance function 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: No oracle dependencies 
function whitelistHedger(address hedger) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger to whitelist | 
removeHedger
Removes a hedger from the whitelist
Removal process:
- Validates governance role and hedger address
- Checks hedger is currently whitelisted
- Removes hedger from whitelist and revokes HEDGER_ROLE
Security features:
- Role-based access control (GOVERNANCE_ROLE)
- Address validation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates governance role, hedger address, currently whitelisted 
- 
state-changes: Removes hedger from whitelist, revokes HEDGER_ROLE 
- 
events: Emits HedgerRemoved with hedger and caller details 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Not protected - governance function 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: No oracle dependencies 
function removeHedger(address hedger) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger to remove from whitelist | 
toggleHedgerWhitelistMode
Toggles the hedger whitelist mode on/off
Whitelist mode toggle:
- Validates governance role
- Updates hedgerWhitelistEnabled state
- Emits event for transparency
When enabled: Only whitelisted hedgers can open positions
When disabled: Any address can open positions
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates governance role 
- 
state-changes: Updates hedgerWhitelistEnabled state 
- 
events: Emits HedgerWhitelistModeToggled with new state and caller 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Not protected - governance function 
- 
access: Restricted to GOVERNANCE_ROLE 
- 
oracle: No oracle dependencies 
function toggleHedgerWhitelistMode(bool enabled) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| enabled | bool | Whether to enable or disable the whitelist mode | 
_getValidOraclePrice
Gets a valid EUR/USD price from the oracle
Internal function to fetch and validate oracle price
Notes:
- 
security: Validates oracle price is valid 
- 
validation: Validates oracle price is valid 
- 
state-changes: No state changes 
- 
events: No events emitted 
- 
errors: Throws InvalidOraclePrice if price is invalid 
- 
reentrancy: Not protected - internal function 
- 
access: Internal function - no access restrictions 
- 
oracle: Requires fresh oracle price data 
function _getValidOraclePrice() internal view returns (uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | price Valid EUR/USD price from oracle | 
_validateRole
Validates that the caller has the required role
Internal function to check role-based access control
Notes:
- 
security: Validates caller has the specified role 
- 
validation: Checks role against AccessControlLibrary 
- 
state-changes: None (view function) 
- 
events: None 
- 
errors: Throws InvalidRole if caller lacks required role 
- 
reentrancy: Not applicable - view function 
- 
access: Internal function 
- 
oracle: Not applicable 
function _validateRole(bytes32 role) internal view;
Parameters
| Name | Type | Description | 
|---|---|---|
| role | bytes32 | The role to validate against | 
_removePositionFromArrays
Removes a position from the hedger's position arrays
Internal function to maintain position tracking arrays
Notes:
- 
security: Validates position exists before removal 
- 
validation: Ensures position exists in hedger's array 
- 
state-changes: Removes position from arrays and updates indices 
- 
events: None 
- 
errors: Throws PositionNotFound if position doesn't exist 
- 
reentrancy: Not applicable - internal function 
- 
access: Internal function 
- 
oracle: Not applicable 
function _removePositionFromArrays(address hedger, uint256 positionId) internal;
Parameters
| Name | Type | Description | 
|---|---|---|
| hedger | address | Address of the hedger whose position to remove | 
| positionId | uint256 | ID of the position to remove | 
_packPositionOpenData
Packs position open data into a single bytes32 for gas efficiency
Encodes position size, margin, leverage, and entry price into a compact format
Notes:
- 
security: No security validations required for pure function 
- 
validation: None required for pure function 
- 
state-changes: None (pure function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - pure function 
- 
access: Internal function 
- 
oracle: Uses provided entryPrice parameter 
function _packPositionOpenData(uint256 positionSize, uint256 margin, uint256 leverage, uint256 entryPrice)
    internal
    pure
    returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| positionSize | uint256 | Size of the position in USDC | 
| margin | uint256 | Margin amount for the position | 
| leverage | uint256 | Leverage multiplier for the position | 
| entryPrice | uint256 | Price at which the position was opened | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | Packed data as bytes32 | 
_packPositionCloseData
Packs position close data into a single bytes32 for gas efficiency
Encodes exit price, PnL, and timestamp into a compact format
Notes:
- 
security: No security validations required for pure function 
- 
validation: None required for pure function 
- 
state-changes: None (pure function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - pure function 
- 
access: Internal function 
- 
oracle: Not applicable 
function _packPositionCloseData(uint256 exitPrice, int256 pnl, uint256 timestamp) internal pure returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| exitPrice | uint256 | Price at which the position was closed | 
| pnl | int256 | Profit or loss from the position (can be negative) | 
| timestamp | uint256 | Timestamp when the position was closed | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | Packed data as bytes32 | 
_packMarginData
Packs margin data into a single bytes32 for gas efficiency
Encodes margin amount, new margin ratio, and operation type
Notes:
- 
security: No security validations required for pure function 
- 
validation: None required for pure function 
- 
state-changes: None (pure function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - pure function 
- 
access: Internal function 
- 
oracle: Not applicable 
function _packMarginData(uint256 marginAmount, uint256 newMarginRatio, bool isAdded)
    internal
    pure
    returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| marginAmount | uint256 | Amount of margin added or removed | 
| newMarginRatio | uint256 | New margin ratio after the operation | 
| isAdded | bool | True if margin was added, false if removed | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | Packed data as bytes32 | 
_packLiquidationData
Packs liquidation data into a single bytes32 for gas efficiency
Encodes liquidation reward and remaining margin
Notes:
- 
security: No security validations required for pure function 
- 
validation: None required for pure function 
- 
state-changes: None (pure function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - pure function 
- 
access: Internal function 
- 
oracle: Not applicable 
function _packLiquidationData(uint256 liquidationReward, uint256 remainingMargin) internal pure returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| liquidationReward | uint256 | Reward paid to the liquidator | 
| remainingMargin | uint256 | Margin remaining after liquidation | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | Packed data as bytes32 | 
_packRewardData
Packs reward data into a single bytes32 for gas efficiency
Encodes interest differential, yield shift rewards, and total rewards
Notes:
- 
security: No security validations required for pure function 
- 
validation: None required for pure function 
- 
state-changes: None (pure function) 
- 
events: None 
- 
errors: None 
- 
reentrancy: Not applicable - pure function 
- 
access: Internal function 
- 
oracle: Not applicable 
function _packRewardData(uint256 interestDifferential, uint256 yieldShiftRewards, uint256 totalRewards)
    internal
    pure
    returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| interestDifferential | uint256 | Interest rate differential between EUR and USD | 
| yieldShiftRewards | uint256 | Rewards from yield shifting operations | 
| totalRewards | uint256 | Total rewards accumulated | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | Packed data as bytes32 | 
_validatePositionClosureSafety
Validates that closing a position won't cause protocol undercollateralization
Checks if closing the position would make the protocol undercollateralized for QEURO minting
Notes:
- 
security: Validates protocol collateralization status 
- 
validation: Checks vault collateralization ratio 
- 
state-changes: No state changes - validation only 
- 
events: No events emitted 
- 
errors: Throws PositionClosureRestricted if closure would cause undercollateralization 
- 
reentrancy: Not protected - internal function only 
- 
access: Internal function - no access restrictions 
- 
oracle: No oracle dependencies 
function _validatePositionClosureSafety(
    uint256,
    /* positionId */
    uint256 positionMargin
)
    internal
    view;
Parameters
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | |
| positionMargin | uint256 | The margin amount of the position being closed | 
Events
HedgePositionOpened
event HedgePositionOpened(address indexed hedger, uint256 indexed positionId, bytes32 packedData);
HedgePositionClosed
event HedgePositionClosed(address indexed hedger, uint256 indexed positionId, bytes32 packedData);
MarginUpdated
event MarginUpdated(address indexed hedger, uint256 indexed positionId, bytes32 packedData);
HedgerLiquidated
event HedgerLiquidated(
    address indexed hedger, uint256 indexed positionId, address indexed liquidator, bytes32 packedData
);
HedgingRewardsClaimed
event HedgingRewardsClaimed(address indexed hedger, bytes32 packedData);
HedgerWhitelisted
event HedgerWhitelisted(address indexed hedger, address indexed caller);
HedgerRemoved
event HedgerRemoved(address indexed hedger, address indexed caller);
HedgerWhitelistModeToggled
event HedgerWhitelistModeToggled(bool enabled, address indexed caller);
ETHRecovered
event ETHRecovered(address indexed to, uint256 indexed amount);
TreasuryUpdated
event TreasuryUpdated(address indexed treasury);
VaultUpdated
event VaultUpdated(address indexed vault);
Structs
CoreParams
struct CoreParams {
    uint64 minMarginRatio;
    uint64 liquidationThreshold;
    uint16 maxLeverage;
    uint16 liquidationPenalty;
    uint16 entryFee;
    uint16 exitFee;
    uint16 marginFee;
    uint16 eurInterestRate;
    uint16 usdInterestRate;
    uint8 reserved;
}
HedgePosition
struct HedgePosition {
    address hedger;
    uint96 positionSize;
    uint96 margin;
    uint96 entryPrice;
    uint32 entryTime;
    uint32 lastUpdateTime;
    int128 unrealizedPnL;
    uint16 leverage;
    bool isActive;
}
HedgerInfo
struct HedgerInfo {
    uint256[] positionIds;
    uint128 totalMargin;
    uint128 totalExposure;
    uint128 pendingRewards;
    uint64 lastRewardClaim;
    bool isActive;
}
