harb/onchain/test/mocks/MockOptimizer.sol

94 lines
3.4 KiB
Solidity
Raw Normal View History

// SPDX-License-Identifier: GPL-3.0-or-later
pragma solidity ^0.8.19;
import {Kraiken} from "../../src/Kraiken.sol";
import {Stake} from "../../src/Stake.sol";
import {UUPSUpgradeable} from "@openzeppelin/proxy/utils/UUPSUpgradeable.sol";
import {Initializable} from "@openzeppelin/proxy/utils/Initializable.sol";
contract MockOptimizer is Initializable, UUPSUpgradeable {
Kraiken private kraiken;
2025-07-08 10:33:10 +02:00
Stake private stake;
// Configurable parameters for sentiment analysis (V1 fallback values)
uint256 private _capitalInefficiency = 5 * 10 ** 17; // 50%
uint256 private _anchorShare = 5 * 10 ** 17; // 50%
uint24 private _anchorWidth = 50; // 50 (V1 used 5 * 10, but that's the same as 50)
uint256 private _discoveryDepth = 5 * 10 ** 17; // 50%
/**
* @dev The caller account is not authorized to perform an operation.
*/
error UnauthorizedAccount(address account);
function initialize(address _kraiken, address _stake) public initializer {
2025-07-08 10:33:10 +02:00
_changeAdmin(msg.sender);
kraiken = Kraiken(_kraiken);
2025-07-08 10:33:10 +02:00
stake = Stake(_stake);
}
/**
* @dev Throws if called by any account other than the admin.
*/
2025-07-08 10:33:10 +02:00
modifier onlyAdmin() {
_checkAdmin();
_;
}
/**
* @dev Throws if the sender is not the admin.
*/
function _checkAdmin() internal view virtual {
if (_getAdmin() != msg.sender) {
revert UnauthorizedAccount(msg.sender);
}
}
2025-07-08 10:33:10 +02:00
function _authorizeUpgrade(address newImplementation) internal override onlyAdmin {}
/// @notice Set liquidity parameters for sentiment analysis testing
/// @param capitalInefficiency Capital inefficiency parameter (0-1e18)
/// @param anchorShare Anchor share parameter (0-1e18)
/// @param anchorWidth Anchor width parameter
/// @param discoveryDepth Discovery depth parameter (0-1e18)
function setLiquidityParams(
uint256 capitalInefficiency,
uint256 anchorShare,
uint24 anchorWidth,
uint256 discoveryDepth
) external {
_capitalInefficiency = capitalInefficiency;
_anchorShare = anchorShare;
_anchorWidth = anchorWidth;
_discoveryDepth = discoveryDepth;
}
2024-11-13 16:37:23 +01:00
function calculateSentiment(uint256, uint256) public pure returns (uint256 sentimentValue) {
return 0;
}
/// @notice Computes the staker sentiment based on the proportion of the authorized stake that is currently staked.
/// @return sentiment A number between 0 and 200 indicating the market sentiment.
2024-11-13 16:37:23 +01:00
function getSentiment() external view returns (uint256 sentiment) {
uint256 percentageStaked = stake.getPercentageStaked();
2025-07-08 10:33:10 +02:00
uint256 averageTaxRate = stake.getAverageTaxRate();
sentiment = calculateSentiment(averageTaxRate, percentageStaked);
}
/// @notice Returns configurable liquidity parameters for testing
/// @return capitalInefficiency Configurable capital inefficiency
/// @return anchorShare Configurable anchor share
/// @return anchorWidth Configurable anchor width
/// @return discoveryDepth Configurable discovery depth
2025-07-06 10:08:59 +02:00
function getLiquidityParams()
external
view
2025-07-08 10:33:10 +02:00
returns (uint256 capitalInefficiency, uint256 anchorShare, uint24 anchorWidth, uint256 discoveryDepth)
2025-07-06 10:08:59 +02:00
{
capitalInefficiency = _capitalInefficiency;
anchorShare = _anchorShare;
anchorWidth = _anchorWidth;
discoveryDepth = _discoveryDepth;
2025-07-06 10:08:59 +02:00
}
}