This contract's source code is verified! Compiler
0.8.23+commit.f704f362
File 1 of 9: BunnySwap.sol
pragma solidity 0.8.23;
import { IBunnySwapCallee } from "./interfaces/IBunnySwapCallee.sol" ;
import { IBunnySwapPair } from "./interfaces/IBunnySwapPair.sol" ;
import { ReentrancyGuard } from "lib/solmate/src/utils/ReentrancyGuard.sol" ;
import { ERC20 } from "lib/solmate/src/tokens/ERC20.sol" ;
import { Owned } from "lib/solmate/src/auth/Owned.sol" ;
import { Math } from "./libraries/Math.sol" ;
import { UQ112x112 } from "./libraries/UQ112x112.sol" ;
import { IERC20 } from "./interfaces/IERC20.sol" ;
contract BunnySwap is ERC20 ("BunnySwap" , "POINTS-ETH" , 18 ), Owned (msg .sender ), ReentrancyGuard {
using UQ112x112 for uint224 ;
event Mint (address indexed sender, uint256 amount0, uint256 amount1 ) ;
event Burn (address indexed sender, uint256 amount0, uint256 amount1, address indexed to ) ;
event Swap (address indexed sender, uint256 amount0In, uint256 amount1In, uint256 amount0Out, uint256 amount1Out, address indexed to ) ;
event Sync (uint112 reserve0, uint112 reserve1 ) ;
uint256 public constant MINIMUM_LIQUIDITY = 10 * * 3 ;
bytes4 private constant SELECTOR = bytes4 (keccak256 (bytes ("transfer(address,uint256)" )));
address public token0;
address public token1;
uint112 private reserve0;
uint112 private reserve1;
uint32 private blockTimestampLast;
uint256 public price0CumulativeLast;
uint256 public price1CumulativeLast;
uint256 public kLast;
uint64 public feeTier;
constructor (address _token0, address _token1 ) {
token0 = _token0;
token1 = _token1;
feeTier = 15 ;
}
receive ( ) external payable { }
function getReserves ( ) public view returns (uint112 _reserve0, uint112 _reserve1, uint32 _blockTimestampLast ) {
_reserve0 = reserve0;
_reserve1 = reserve1;
_blockTimestampLast = blockTimestampLast;
}
function _safeTransfer (address token, address to, uint256 value ) internal {
(bool success, bytes memory data) = token.call (abi .encodeWithSelector (SELECTOR, to, value));
require (success & & (data.length = = 0 | | abi .decode (data, (bool ))), "BunnySwap: TRANSFER_FAILED" );
}
function modifyFeeTier (uint64 _feeTier ) external onlyOwner {
feeTier = _feeTier;
}
mapping (address = > bool ) public isAllowedRouter;
function toggleRouterAuthorization (address router, bool status ) external onlyOwner {
isAllowedRouter[router] = status;
}
modifier onlyAuthorizedRouters ( ) {
require (isAllowedRouter[msg .sender ], "BunnySwap: UNAUTHORIZED" );
_ ;
}
function _update (uint256 balance0, uint256 balance1, uint112 _reserve0, uint112 _reserve1 ) internal {
require (balance0 < = type (uint112 ).max & & balance1 < = type (uint112 ).max , "BunnySwap: OVERFLOW" );
uint32 blockTimestamp = uint32 (block .timestamp % 2 * * 32 );
uint32 timeElapsed = blockTimestamp - blockTimestampLast;
if (timeElapsed > 0 & & _reserve0 ! = 0 & & _reserve1 ! = 0 ) {
price0CumulativeLast + = uint256 (UQ112x112.encode(_reserve1).uqdiv(_reserve0)) * timeElapsed;
price1CumulativeLast + = uint256 (UQ112x112.encode(_reserve0).uqdiv(_reserve1)) * timeElapsed;
}
reserve0 = uint112 (balance0);
reserve1 = uint112 (balance1);
blockTimestampLast = blockTimestamp;
emit Sync(reserve0, reserve1);
}
function mint (address to ) external nonReentrant returns (uint256 liquidity ) {
(uint112 _reserve0, uint112 _reserve1,) = getReserves();
uint256 balance0 = IERC20(token0).balanceOf(address (this ));
uint256 balance1 = IERC20(token1).balanceOf(address (this ));
uint256 amount0 = balance0 - (_reserve0);
uint256 amount1 = balance1 - (_reserve1);
uint256 _totalSupply = totalSupply;
if (_totalSupply = = 0 ) {
liquidity = Math.sqrt(amount0 * (amount1)) - (MINIMUM_LIQUIDITY);
_mint(address (0 ), MINIMUM_LIQUIDITY);
} else {
liquidity = Math.min (amount0 * (_totalSupply) / _reserve0, amount1 * (_totalSupply) / _reserve1);
}
require (liquidity > 0 , "BunnySwap: INSUFFICIENT_LIQUIDITY_MINTED" );
_mint(to, liquidity);
_update(balance0, balance1, _reserve0, _reserve1);
emit Mint(msg .sender , amount0, amount1);
}
function burn (address to ) external nonReentrant returns (uint256 amount0, uint256 amount1 ) {
(uint112 _reserve0, uint112 _reserve1,) = getReserves();
address _token0 = token0;
address _token1 = token1;
uint256 balance0 = IERC20(_token0).balanceOf(address (this ));
uint256 balance1 = IERC20(_token1).balanceOf(address (this ));
uint256 liquidity = balanceOf[address (this )];
uint256 _totalSupply = totalSupply;
amount0 = (liquidity * balance0) / _totalSupply;
amount1 = (liquidity * balance1) / _totalSupply;
require (amount0 > 0 & & amount1 > 0 , "BunnySwap: INSUFFICIENT_LIQUIDITY_BURNED" );
_burn(address (this ), liquidity);
_safeTransfer(_token0, to, amount0);
_safeTransfer(_token1, to, amount1);
balance0 = IERC20(_token0).balanceOf(address (this ));
balance1 = IERC20(_token1).balanceOf(address (this ));
_update(balance0, balance1, _reserve0, _reserve1);
emit Burn(msg .sender , amount0, amount1, to);
}
function swap (uint256 amount0Out, uint256 amount1Out, address to, bytes calldata data ) external onlyAuthorizedRouters nonReentrant {
require (amount0Out > 0 | | amount1Out > 0 , "BunnySwap: INSUFFICIENT_OUTPUT_AMOUNT" );
(uint112 _reserve0, uint112 _reserve1,) = getReserves();
require (amount0Out < _reserve0 & & amount1Out < _reserve1, "BunnySwap: INSUFFICIENT_LIQUIDITY" );
uint256 balance0;
uint256 balance1;
{
address _token0 = token0;
address _token1 = token1;
require (to ! = _token0 & & to ! = _token1, "BunnySwap: INVALID_TO" );
if (amount0Out > 0 ) _safeTransfer(_token0, to, amount0Out);
if (amount1Out > 0 ) _safeTransfer(_token1, to, amount1Out);
if (data.length > 0 ) IBunnySwapCallee(to).bunnySwapCall(msg .sender , amount0Out, amount1Out, data);
balance0 = IERC20(_token0).balanceOf(address (this ));
balance1 = IERC20(_token1).balanceOf(address (this ));
}
uint256 amount0In = balance0 > _reserve0 - amount0Out ? balance0 - (_reserve0 - amount0Out) : 0 ;
uint256 amount1In = balance1 > _reserve1 - amount1Out ? balance1 - (_reserve1 - amount1Out) : 0 ;
require (amount0In > 0 | | amount1In > 0 , "BunnySwap: INSUFFICIENT_INPUT_AMOUNT" );
{
uint256 balance0Adjusted = balance0 * (1000 ) - (amount0In * (feeTier));
uint256 balance1Adjusted = balance1 * (1000 ) - (amount1In * (feeTier));
require (balance0Adjusted * (balance1Adjusted) > = uint256 (_reserve0) * (_reserve1) * (1000 * * 2 ), "BunnySwap: K" );
}
_update(balance0, balance1, _reserve0, _reserve1);
emit Swap(msg .sender , amount0In, amount1In, amount0Out, amount1Out, to);
}
function skim (address to ) external nonReentrant {
address _token0 = token0;
address _token1 = token1;
_safeTransfer(_token0, to, IERC20(_token0).balanceOf(address (this )) - (reserve0));
_safeTransfer(_token1, to, IERC20(_token1).balanceOf(address (this )) - (reserve1));
}
function sync ( ) external nonReentrant {
_update(IERC20(token0).balanceOf(address (this )), IERC20(token1).balanceOf(address (this )), reserve0, reserve1);
}
}
File 2 of 9: ERC20.sol
pragma solidity >=0.8.0;
abstract contract ERC20 {
event Transfer (address indexed from , address indexed to, uint256 amount ) ;
event Approval (address indexed owner, address indexed spender, uint256 amount ) ;
string public name;
string public symbol;
uint8 public immutable decimals;
uint256 public totalSupply;
mapping (address = > uint256 ) public balanceOf;
mapping (address = > mapping (address = > uint256 )) public allowance;
uint256 internal immutable INITIAL_CHAIN_ID;
bytes32 internal immutable INITIAL_DOMAIN_SEPARATOR;
mapping (address = > uint256 ) public nonces;
constructor (
string memory _name,
string memory _symbol,
uint8 _decimals
) {
name = _name;
symbol = _symbol;
decimals = _decimals;
INITIAL_CHAIN_ID = block .chainid ;
INITIAL_DOMAIN_SEPARATOR = computeDomainSeparator();
}
function approve (address spender, uint256 amount ) public virtual returns (bool ) {
allowance[msg .sender ][spender] = amount;
emit Approval(msg .sender , spender, amount);
return true ;
}
function transfer (address to, uint256 amount ) public virtual returns (bool ) {
balanceOf[msg .sender ] - = amount;
unchecked {
balanceOf[to] + = amount;
}
emit Transfer(msg .sender , to, amount);
return true ;
}
function transferFrom (
address from ,
address to,
uint256 amount
) public virtual returns (bool ) {
uint256 allowed = allowance[from ][msg .sender ];
if (allowed ! = type (uint256 ).max ) allowance[from ][msg .sender ] = allowed - amount;
balanceOf[from ] - = amount;
unchecked {
balanceOf[to] + = amount;
}
emit Transfer(from , to, amount);
return true ;
}
function permit (
address owner,
address spender,
uint256 value,
uint256 deadline,
uint8 v,
bytes32 r,
bytes32 s
) public virtual {
require (deadline > = block .timestamp , "PERMIT_DEADLINE_EXPIRED" );
unchecked {
address recoveredAddress = ecrecover (
keccak256 (
abi .encodePacked (
"\x19\x01" ,
DOMAIN_SEPARATOR(),
keccak256 (
abi .encode (
keccak256 (
"Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)"
),
owner,
spender,
value,
nonces[owner]+ + ,
deadline
)
)
)
),
v,
r,
s
);
require (recoveredAddress ! = address (0 ) & & recoveredAddress = = owner, "INVALID_SIGNER" );
allowance[recoveredAddress][spender] = value;
}
emit Approval(owner, spender, value);
}
function DOMAIN_SEPARATOR ( ) public view virtual returns (bytes32 ) {
return block .chainid = = INITIAL_CHAIN_ID ? INITIAL_DOMAIN_SEPARATOR : computeDomainSeparator();
}
function computeDomainSeparator ( ) internal view virtual returns (bytes32 ) {
return
keccak256 (
abi .encode (
keccak256 ("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)" ),
keccak256 (bytes (name)),
keccak256 ("1" ),
block .chainid ,
address (this )
)
);
}
function _mint (address to, uint256 amount ) internal virtual {
totalSupply + = amount;
unchecked {
balanceOf[to] + = amount;
}
emit Transfer(address (0 ), to, amount);
}
function _burn (address from , uint256 amount ) internal virtual {
balanceOf[from ] - = amount;
unchecked {
totalSupply - = amount;
}
emit Transfer(from , address (0 ), amount);
}
}
File 3 of 9: IBunnySwapCallee.sol
pragma solidity 0.8.23;
interface IBunnySwapCallee {
function bunnySwapCall (address sender, uint256 amount0, uint256 amount1, bytes calldata data ) external ;
}
File 4 of 9: IBunnySwapPair.sol
pragma solidity 0.8.23;
interface IBunnySwapPair {
event Approval (address indexed owner, address indexed spender, uint256 value ) ;
event Transfer (address indexed from , address indexed to, uint256 value ) ;
function name ( ) external pure returns (string memory ) ;
function symbol ( ) external pure returns (string memory ) ;
function decimals ( ) external pure returns (uint8 ) ;
function totalSupply ( ) external view returns (uint256 ) ;
function balanceOf (address owner ) external view returns (uint256 ) ;
function allowance (address owner, address spender ) external view returns (uint256 ) ;
function feeTier ( ) external view returns (uint64 ) ;
function approve (address spender, uint256 value ) external returns (bool ) ;
function transfer (address to, uint256 value ) external returns (bool ) ;
function transferFrom (address from , address to, uint256 value ) external returns (bool ) ;
function DOMAIN_SEPARATOR ( ) external view returns (bytes32 ) ;
function PERMIT_TYPEHASH ( ) external pure returns (bytes32 ) ;
function nonces (address owner ) external view returns (uint256 ) ;
function permit (address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external ;
event Mint (address indexed sender, uint256 amount0, uint256 amount1 ) ;
event Burn (address indexed sender, uint256 amount0, uint256 amount1, address indexed to ) ;
event Swap (address indexed sender, uint256 amount0In, uint256 amount1In, uint256 amount0Out, uint256 amount1Out, address indexed to ) ;
event Sync (uint112 reserve0, uint112 reserve1 ) ;
function MINIMUM_LIQUIDITY ( ) external pure returns (uint256 ) ;
function factory ( ) external view returns (address ) ;
function token0 ( ) external view returns (address ) ;
function token1 ( ) external view returns (address ) ;
function getReserves ( ) external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast ) ;
function price0CumulativeLast ( ) external view returns (uint256 ) ;
function price1CumulativeLast ( ) external view returns (uint256 ) ;
function kLast ( ) external view returns (uint256 ) ;
function mint (address to ) external returns (uint256 liquidity ) ;
function burn (address to ) external returns (uint256 amount0, uint256 amount1 ) ;
function swap (uint256 amount0Out, uint256 amount1Out, address to, bytes calldata data ) external ;
function skim (address to ) external ;
function sync ( ) external ;
function initialize (address , address ) external ;
}
File 5 of 9: IERC20.sol
pragma solidity 0.8.23;
interface IERC20 {
event Approval (address indexed owner, address indexed spender, uint256 value ) ;
event Transfer (address indexed from , address indexed to, uint256 value ) ;
function name ( ) external view returns (string memory ) ;
function symbol ( ) external view returns (string memory ) ;
function decimals ( ) external view returns (uint8 ) ;
function totalSupply ( ) external view returns (uint256 ) ;
function balanceOf (address owner ) external view returns (uint256 ) ;
function allowance (address owner, address spender ) external view returns (uint256 ) ;
function approve (address spender, uint256 value ) external returns (bool ) ;
function transfer (address to, uint256 value ) external returns (bool ) ;
function transferFrom (address from , address to, uint256 value ) external returns (bool ) ;
}
File 6 of 9: Math.sol
pragma solidity 0.8.23;
library Math {
function min (uint256 x, uint256 y ) internal pure returns (uint256 z ) {
z = x < y ? x : y;
}
function sqrt (uint256 x ) internal pure returns (uint256 z ) {
assembly {
let y := x
z := 181
if iszero (lt (y, 0x10000000000000000000000000000000000 )) {
y := shr (128 , y)
z := shl (64 , z)
}
if iszero (lt (y, 0x1000000000000000000 )) {
y := shr (64 , y)
z := shl (32 , z)
}
if iszero (lt (y, 0x10000000000 )) {
y := shr (32 , y)
z := shl (16 , z)
}
if iszero (lt (y, 0x1000000 )) {
y := shr (16 , y)
z := shl (8 , z)
}
z := shr (18 , mul (z, add (y, 65536 )))
z := shr (1 , add (z, div (x, z)))
z := shr (1 , add (z, div (x, z)))
z := shr (1 , add (z, div (x, z)))
z := shr (1 , add (z, div (x, z)))
z := shr (1 , add (z, div (x, z)))
z := shr (1 , add (z, div (x, z)))
z := shr (1 , add (z, div (x, z)))
z := sub (z, lt (div (x, z), z))
}
}
}
File 7 of 9: Owned.sol
pragma solidity >=0.8.0;
abstract contract Owned {
event OwnershipTransferred (address indexed user, address indexed newOwner ) ;
address public owner;
modifier onlyOwner ( ) virtual {
require (msg .sender = = owner, "UNAUTHORIZED" );
_ ;
}
constructor (address _owner ) {
owner = _owner;
emit OwnershipTransferred(address (0 ), _owner);
}
function transferOwnership (address newOwner ) public virtual onlyOwner {
owner = newOwner;
emit OwnershipTransferred(msg .sender , newOwner);
}
}
File 8 of 9: ReentrancyGuard.sol
pragma solidity >=0.8.0;
abstract contract ReentrancyGuard {
uint256 private locked = 1 ;
modifier nonReentrant ( ) virtual {
require (locked = = 1 , "REENTRANCY" );
locked = 2 ;
_ ;
locked = 1 ;
}
}
File 9 of 9: UQ112x112.sol
pragma solidity 0.8.23;
library UQ112x112 {
uint224 constant Q112 = 2 * * 112 ;
function encode (uint112 y ) internal pure returns (uint224 z ) {
z = uint224 (y) * Q112;
}
function uqdiv (uint224 x, uint112 y ) internal pure returns (uint224 z ) {
z = x / uint224 (y);
}
}
{
"compilationTarget" : {
"src/BunnySwap.sol" : "BunnySwap"
} ,
"evmVersion" : "paris" ,
"libraries" : { } ,
"metadata" : {
"appendCBOR" : false ,
"bytecodeHash" : "none"
} ,
"optimizer" : {
"enabled" : true ,
"runs" : 1000000
} ,
"remappings" : [
":ds-test/=lib/forge-std/lib/ds-test/src/" ,
":forge-std/=lib/forge-std/src/" ,
":murky/=lib/murky/" ,
":openzeppelin-contracts/=lib/murky/lib/openzeppelin-contracts/" ,
":solady/=lib/solady/src/" ,
":solmate/=lib/solmate/src/"
]
} [{"inputs":[{"internalType":"address","name":"_token0","type":"address"},{"internalType":"address","name":"_token1","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount0","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1","type":"uint256"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"Burn","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount0","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1","type":"uint256"}],"name":"Mint","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount0In","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1In","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount0Out","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1Out","type":"uint256"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"Swap","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint112","name":"reserve0","type":"uint112"},{"indexed":false,"internalType":"uint112","name":"reserve1","type":"uint112"}],"name":"Sync","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MINIMUM_LIQUIDITY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"burn","outputs":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeTier","outputs":[{"internalType":"uint64","name":"","type":"uint64"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getReserves","outputs":[{"internalType":"uint112","name":"_reserve0","type":"uint112"},{"internalType":"uint112","name":"_reserve1","type":"uint112"},{"internalType":"uint32","name":"_blockTimestampLast","type":"uint32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isAllowedRouter","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"kLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"mint","outputs":[{"internalType":"uint256","name":"liquidity","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint64","name":"_feeTier","type":"uint64"}],"name":"modifyFeeTier","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"permit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"price0CumulativeLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"price1CumulativeLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"skim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount0Out","type":"uint256"},{"internalType":"uint256","name":"amount1Out","type":"uint256"},{"internalType":"address","name":"to","type":"address"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"swap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sync","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"router","type":"address"},{"internalType":"bool","name":"status","type":"bool"}],"name":"toggleRouterAuthorization","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"token0","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"token1","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]