编译器
0.8.19+commit.7dd6d404
文件 1 的 10:Address.sol
pragma solidity ^0.8.0;
library Address {
function isContract(address account) internal view returns (bool) {
uint256 size;
assembly {
size := extcodesize(account)
}
return size > 0;
}
function sendValue(address payable recipient, uint256 amount) internal {
require(address(this).balance >= amount, "Address: insufficient balance");
(bool success, ) = recipient.call{value: amount}("");
require(success, "Address: unable to send value, recipient may have reverted");
}
function functionCall(address target, bytes memory data) internal returns (bytes memory) {
return functionCall(target, data, "Address: low-level call failed");
}
function functionCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
return functionCallWithValue(target, data, 0, errorMessage);
}
function functionCallWithValue(
address target,
bytes memory data,
uint256 value
) internal returns (bytes memory) {
return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
}
function functionCallWithValue(
address target,
bytes memory data,
uint256 value,
string memory errorMessage
) internal returns (bytes memory) {
require(address(this).balance >= value, "Address: insufficient balance for call");
require(isContract(target), "Address: call to non-contract");
(bool success, bytes memory returndata) = target.call{value: value}(data);
return verifyCallResult(success, returndata, errorMessage);
}
function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
return functionStaticCall(target, data, "Address: low-level static call failed");
}
function functionStaticCall(
address target,
bytes memory data,
string memory errorMessage
) internal view returns (bytes memory) {
require(isContract(target), "Address: static call to non-contract");
(bool success, bytes memory returndata) = target.staticcall(data);
return verifyCallResult(success, returndata, errorMessage);
}
function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
return functionDelegateCall(target, data, "Address: low-level delegate call failed");
}
function functionDelegateCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
require(isContract(target), "Address: delegate call to non-contract");
(bool success, bytes memory returndata) = target.delegatecall(data);
return verifyCallResult(success, returndata, errorMessage);
}
function verifyCallResult(
bool success,
bytes memory returndata,
string memory errorMessage
) internal pure returns (bytes memory) {
if (success) {
return returndata;
} else {
if (returndata.length > 0) {
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
}
文件 2 的 10:Context.sol
pragma solidity ^0.8.0;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
文件 3 的 10:IBurnableToken.sol
pragma solidity ^0.8.0;
import "./IERC20.sol";
interface IBurnableToken is IERC20 {
function mint(address target, uint256 amount) external returns (bool);
function burn(uint256 amount) external returns (bool);
function mintable() external returns (bool);
}
文件 4 的 10:IERC20.sol
pragma solidity ^0.8.0;
interface IERC20 {
function totalSupply() external view returns (uint256);
function decimals() external view returns (uint8);
function symbol() external view returns (string memory);
function name() external view returns (string memory);
function getOwner() external view returns (address);
function balanceOf(address account) external view returns (uint256);
function transfer(address recipient, uint256 amount)
external
returns (bool);
function allowance(address _owner, address spender)
external
view
returns (uint256);
function approve(address spender, uint256 amount) external returns (bool);
function transferFrom(
address sender,
address recipient,
uint256 amount
) external returns (bool);
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(
address indexed owner,
address indexed spender,
uint256 value
);
}
文件 5 的 10:ISwapContract.sol
pragma solidity ^0.8.0;
pragma experimental ABIEncoderV2;
import "./IBurnableToken.sol";
interface ISwapContract {
function BTCT_ADDR() external returns (address);
function lpToken() external returns (IBurnableToken);
function singleTransferERC20(
address _destToken,
address _to,
uint256 _amount,
uint256 _totalSwapped,
uint256 _rewardsAmount,
bytes32[] memory _redeemedFloatTxIds
) external returns (bool);
function multiTransferERC20TightlyPacked(
address _destToken,
bytes32[] memory _addressesAndAmounts,
uint256 _totalSwapped,
uint256 _rewardsAmount,
bytes32[] memory _redeemedFloatTxIds
) external returns (bool);
function collectSwapFeesForBTC(
uint256 _incomingAmount,
uint256 _minerFee,
uint256 _rewardsAmount,
address[] memory _spenders,
uint256[] memory _swapAmounts
) external returns (bool);
function recordIncomingFloat(
address _token,
bytes32 _addressesAndAmountOfFloat,
bytes32 _txid
) external returns (bool);
function recordOutcomingFloat(
address _token,
bytes32 _addressesAndAmountOfLPtoken,
uint256 _minerFee,
bytes32 _txid
) external returns (bool);
function recordUTXOSweepMinerFee(
uint256 _minerFee,
bytes32 _txid
) external returns (bool);
function churn(
address _newOwner,
address[] memory _nodes,
bool[] memory _isRemoved,
uint8 _churnedInCount,
uint8 _tssThreshold
) external returns (bool);
function updateParams(
address _sbBTCPool,
address _buybackAddress,
uint256 _withdrawalFeeBPS,
uint256 _nodeRewardsRatio,
uint256 _buybackRewardsRatio
) external returns (bool);
function isTxUsed(bytes32 _txid) external view returns (bool);
function getCurrentPriceLP() external view returns (uint256);
function getFloatReserve(
address _tokenA,
address _tokenB
) external returns (uint256 reserveA, uint256 reserveB);
function getActiveNodes() external view returns (address[] memory);
function isNodeStake(address _user) external returns (bool);
}
文件 6 的 10:ISwapRewards.sol
pragma solidity ^0.8.0;
interface ISwapRewards {
function setSWINGBYPrice(uint256 _pricePerBTC) external;
function pullRewards(address _dest, address _receiver, uint256 _swapped) external returns (bool);
function pullRewardsMulti(address _dest, address[] memory _receiver, uint256[] memory _swapped) external returns (bool);
}
文件 7 的 10:Ownable.sol
pragma solidity ^0.8.0;
import "../utils/Context.sol";
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor() {
_transferOwnership(_msgSender());
}
modifier onlyOwner() {
_checkOwner();
_;
}
function owner() public view virtual returns (address) {
return _owner;
}
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
文件 8 的 10:SafeERC20.sol
pragma solidity ^0.8.0;
import "../IERC20.sol";
import "./Address.sol";
library SafeERC20 {
using Address for address;
function safeTransfer(
IERC20 token,
address to,
uint256 value
) internal {
_callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
}
function safeTransferFrom(
IERC20 token,
address from,
address to,
uint256 value
) internal {
_callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
}
function safeApprove(
IERC20 token,
address spender,
uint256 value
) internal {
require(
(value == 0) || (token.allowance(address(this), spender) == 0),
"SafeERC20: approve from non-zero to non-zero allowance"
);
_callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
}
function safeIncreaseAllowance(
IERC20 token,
address spender,
uint256 value
) internal {
uint256 newAllowance = token.allowance(address(this), spender) + value;
_callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
}
function _callOptionalReturn(IERC20 token, bytes memory data) private {
bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed");
if (returndata.length > 0) {
require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
}
}
}
文件 9 的 10:SafeMath.sol
pragma solidity ^0.8.0;
library SafeMath {
function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
uint256 c = a + b;
if (c < a) return (false, 0);
return (true, c);
}
}
function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (b > a) return (false, 0);
return (true, a - b);
}
}
function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (a == 0) return (true, 0);
uint256 c = a * b;
if (c / a != b) return (false, 0);
return (true, c);
}
}
function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (b == 0) return (false, 0);
return (true, a / b);
}
}
function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (b == 0) return (false, 0);
return (true, a % b);
}
}
function add(uint256 a, uint256 b) internal pure returns (uint256) {
return a + b;
}
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
return a - b;
}
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
return a * b;
}
function div(uint256 a, uint256 b) internal pure returns (uint256) {
return a / b;
}
function mod(uint256 a, uint256 b) internal pure returns (uint256) {
return a % b;
}
function sub(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
unchecked {
require(b <= a, errorMessage);
return a - b;
}
}
function div(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
unchecked {
require(b > 0, errorMessage);
return a / b;
}
}
function mod(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
unchecked {
require(b > 0, errorMessage);
return a % b;
}
}
}
文件 10 的 10:SwapContract.sol
pragma solidity ^0.8.0;
pragma experimental ABIEncoderV2;
import "./interfaces/ISwapContract.sol";
import "./interfaces/ISwapRewards.sol";
import "@openzeppelin/contracts/access/Ownable.sol";
import "./interfaces/lib/SafeERC20.sol";
import "@openzeppelin/contracts/utils/math/SafeMath.sol";
contract SwapContract is ISwapContract, Ownable {
using SafeMath for uint256;
using SafeERC20 for IERC20;
IBurnableToken public immutable lpToken;
ISwapRewards public immutable sw;
mapping(address => bool) public whitelist;
address public immutable BTCT_ADDR;
uint256 private immutable convertScale;
uint256 private immutable lpDivisor;
address public buybackAddress;
address public sbBTCPool;
uint256 public withdrawalFeeBPS;
uint256 public nodeRewardsRatio;
uint256 public buybackRewardsRatio;
mapping(address => uint256) private floatAmountOf;
mapping(bytes32 => bool) private used;
mapping(address => uint8) private nodes;
address[] private nodeAddrs;
uint8 public activeNodeCount;
uint8 public churnedInCount;
uint8 public tssThreshold;
event Swap(address from, address to, uint256 amount);
event RewardsCollection(
address feesToken,
uint256 rewards,
uint256 rewardsLPTTotal,
uint256 currentPriceLP
);
event IssueLPTokensForFloat(
address to,
uint256 amountOfFloat,
uint256 amountOfLP,
uint256 currentPriceLP,
uint256 depositFees,
bytes32 txid
);
event BurnLPTokensForFloat(
address token,
uint256 amountOfLP,
uint256 amountOfFloat,
uint256 currentPriceLP,
uint256 withdrawal,
bytes32 txid
);
modifier priceCheck() {
uint256 beforePrice = getCurrentPriceLP();
_;
require(getCurrentPriceLP() >= beforePrice, "Invalid LPT price");
}
constructor(
address _lpToken,
address _btct,
address _sbBTCPool,
address _swapRewards,
address _buybackAddress,
uint256 _initBTCFloat,
uint256 _initWBTCFloat
) {
sbBTCPool = _sbBTCPool;
sw = ISwapRewards(_swapRewards);
lpToken = IBurnableToken(_lpToken);
lpDivisor = 10 ** IERC20(_lpToken).decimals();
BTCT_ADDR = _btct;
convertScale = 10 ** (IERC20(_btct).decimals() - 8);
whitelist[_btct] = true;
whitelist[_lpToken] = true;
whitelist[address(0)] = true;
floatAmountOf[address(0)] = _initBTCFloat;
floatAmountOf[BTCT_ADDR] = _initWBTCFloat;
buybackAddress = _buybackAddress;
withdrawalFeeBPS = 20;
nodeRewardsRatio = 66;
buybackRewardsRatio = 25;
}
function singleTransferERC20(
address _destToken,
address _to,
uint256 _amount,
uint256 _totalSwapped,
uint256 _rewardsAmount,
bytes32[] memory _redeemedFloatTxIds
) external override onlyOwner returns (bool) {
require(whitelist[_destToken], "14");
require(
_destToken != address(0),
"15"
);
address _feesToken = address(0);
if (_totalSwapped > 0) {
sw.pullRewards(_destToken, _to, _totalSwapped);
_swap(address(0), BTCT_ADDR, _totalSwapped);
} else {
_feesToken = (_destToken == address(lpToken))
? address(lpToken)
: BTCT_ADDR;
}
_rewardsCollection(_feesToken, _rewardsAmount);
_addUsedTxs(_redeemedFloatTxIds);
_safeTransfer(_destToken, _to, _amount);
return true;
}
function multiTransferERC20TightlyPacked(
address _destToken,
bytes32[] memory _addressesAndAmounts,
uint256 _totalSwapped,
uint256 _rewardsAmount,
bytes32[] memory _redeemedFloatTxIds
) external override onlyOwner returns (bool) {
require(whitelist[_destToken], "_destToken is not whitelisted");
require(
_destToken != address(0),
"_destToken should not be address(0)"
);
address _feesToken = address(0);
if (_totalSwapped > 0) {
_swap(address(0), BTCT_ADDR, _totalSwapped);
} else {
_feesToken = (_destToken == address(lpToken))
? address(lpToken)
: BTCT_ADDR;
}
_rewardsCollection(_feesToken, _rewardsAmount);
_addUsedTxs(_redeemedFloatTxIds);
for (uint256 i = 0; i < _addressesAndAmounts.length; i++) {
_safeTransfer(
_destToken,
address(uint160(uint256(_addressesAndAmounts[i]))),
uint256(uint96(bytes12(_addressesAndAmounts[i])))
);
}
return true;
}
function collectSwapFeesForBTC(
uint256 _incomingAmount,
uint256 _minerFee,
uint256 _rewardsAmount,
address[] memory _spenders,
uint256[] memory _swapAmounts
) external override onlyOwner returns (bool) {
address _feesToken = BTCT_ADDR;
if (_incomingAmount > 0) {
uint256 swapAmount = _incomingAmount.sub(_rewardsAmount);
sw.pullRewardsMulti(address(0), _spenders, _swapAmounts);
_swap(BTCT_ADDR, address(0), swapAmount);
} else if (_incomingAmount == 0) {
_feesToken = address(0);
}
_rewardsCollection(_feesToken, _rewardsAmount);
return true;
}
function recordIncomingFloat(
address _token,
bytes32 _addressesAndAmountOfFloat,
bytes32 _txid
) external override onlyOwner priceCheck returns (bool) {
require(whitelist[_token], "16");
require(
_issueLPTokensForFloat(_token, _addressesAndAmountOfFloat, _txid)
);
return true;
}
function recordOutcomingFloat(
address _token,
bytes32 _addressesAndAmountOfLPtoken,
uint256 _minerFee,
bytes32 _txid
) external override onlyOwner priceCheck returns (bool) {
require(whitelist[_token], "16");
require(
_burnLPTokensForFloat(
_token,
_addressesAndAmountOfLPtoken,
_minerFee,
_txid
)
);
return true;
}
fallback() external {
revert();
}
function recordUTXOSweepMinerFee(
uint256 _minerFee,
bytes32 _txid
) public override onlyOwner returns (bool) {
require(!isTxUsed(_txid), "The txid is already used");
floatAmountOf[address(0)] = floatAmountOf[address(0)].sub(
_minerFee,
"12"
);
_addUsedTx(_txid);
return true;
}
function churn(
address _newOwner,
address[] memory _nodes,
bool[] memory _isRemoved,
uint8 _churnedInCount,
uint8 _tssThreshold
) external override onlyOwner returns (bool) {
require(
_tssThreshold >= tssThreshold && _tssThreshold <= 2 ** 8 - 1,
"01"
);
require(
_churnedInCount >= _tssThreshold + uint8(1),
"02"
);
require(
_nodes.length == _isRemoved.length,
"05"
);
transferOwnership(_newOwner);
for (uint256 i = 0; i < _nodes.length; i++) {
if (!_isRemoved[i]) {
if (nodes[_nodes[i]] == uint8(0)) {
nodeAddrs.push(_nodes[i]);
}
if (nodes[_nodes[i]] != uint8(1)) {
activeNodeCount++;
}
nodes[_nodes[i]] = uint8(1);
} else {
activeNodeCount--;
nodes[_nodes[i]] = uint8(2);
}
}
require(activeNodeCount <= 100, "Stored node size should be <= 100");
churnedInCount = _churnedInCount;
tssThreshold = _tssThreshold;
return true;
}
function updateParams(
address _sbBTCPool,
address _buybackAddress,
uint256 _withdrawalFeeBPS,
uint256 _nodeRewardsRatio,
uint256 _buybackRewardsRatio
) external override onlyOwner returns (bool) {
sbBTCPool = _sbBTCPool;
buybackAddress = _buybackAddress;
withdrawalFeeBPS = _withdrawalFeeBPS;
nodeRewardsRatio = _nodeRewardsRatio;
buybackRewardsRatio = _buybackRewardsRatio;
return true;
}
function isTxUsed(bytes32 _txid) public view override returns (bool) {
return used[_txid];
}
function getCurrentPriceLP()
public
view
override
returns (uint256 nowPrice)
{
(uint256 reserveA, uint256 reserveB) = getFloatReserve(
address(0),
BTCT_ADDR
);
uint256 totalLPs = lpToken.totalSupply();
nowPrice = totalLPs == 0
? lpDivisor
: (reserveA.add(reserveB)).mul(lpDivisor).div(totalLPs);
return nowPrice;
}
function getFloatReserve(
address _tokenA,
address _tokenB
) public view override returns (uint256 reserveA, uint256 reserveB) {
(reserveA, reserveB) = (floatAmountOf[_tokenA], floatAmountOf[_tokenB]);
}
function getActiveNodes() public view override returns (address[] memory) {
uint256 count = 0;
address[] memory _nodes = new address[](activeNodeCount);
for (uint256 i = 0; i < nodeAddrs.length; i++) {
if (nodes[nodeAddrs[i]] == uint8(1)) {
_nodes[count] = nodeAddrs[i];
count++;
}
}
return _nodes;
}
function isNodeStake(address _user) public view override returns (bool) {
if (nodes[_user] == uint8(1)) {
return true;
}
return false;
}
function _issueLPTokensForFloat(
address _token,
bytes32 _transaction,
bytes32 _txid
) internal returns (bool) {
require(!isTxUsed(_txid), "06");
require(_transaction != 0x0, "07");
(address to, uint256 amountOfFloat) = _splitToValues(_transaction);
uint256 nowPrice = getCurrentPriceLP();
uint256 amountOfLP = amountOfFloat.mul(lpDivisor).div(nowPrice);
lpToken.mint(to, amountOfLP);
_addFloat(_token, amountOfFloat);
_addUsedTx(_txid);
emit IssueLPTokensForFloat(
to,
amountOfFloat,
amountOfLP,
nowPrice,
0,
_txid
);
return true;
}
function _burnLPTokensForFloat(
address _token,
bytes32 _transaction,
uint256 _minerFee,
bytes32 _txid
) internal returns (bool) {
require(!isTxUsed(_txid), "06");
require(_transaction != 0x0, "07");
(address to, uint256 amountOfLP) = _splitToValues(_transaction);
uint256 nowPrice = getCurrentPriceLP();
uint256 amountOfFloat = amountOfLP.mul(nowPrice).div(lpDivisor);
uint256 withdrawalFees = amountOfFloat.mul(withdrawalFeeBPS).div(10000);
require(
amountOfFloat.sub(withdrawalFees) >= _minerFee,
"09"
);
uint256 withdrawal = amountOfFloat.sub(withdrawalFees).sub(_minerFee);
(uint256 reserveA, uint256 reserveB) = getFloatReserve(
address(0),
BTCT_ADDR
);
if (_token == address(0)) {
require(
reserveA >= amountOfFloat.sub(withdrawalFees),
"08"
);
} else if (_token == BTCT_ADDR) {
require(
reserveB >= amountOfFloat.sub(withdrawalFees),
"12"
);
}
_rewardsCollection(_token, withdrawalFees);
_removeFloat(_token, amountOfFloat);
_addUsedTx(_txid);
if (_token == BTCT_ADDR) {
_safeTransfer(_token, to, withdrawal);
}
require(lpToken.burn(amountOfLP));
emit BurnLPTokensForFloat(
to,
amountOfLP,
amountOfFloat,
nowPrice,
withdrawal,
_txid
);
return true;
}
function _addFloat(address _token, uint256 _amount) internal {
floatAmountOf[_token] = floatAmountOf[_token].add(_amount);
}
function _removeFloat(address _token, uint256 _amount) internal {
floatAmountOf[_token] = floatAmountOf[_token].sub(
_amount,
"10"
);
}
function _swap(
address _sourceToken,
address _destToken,
uint256 _swapAmount
) internal {
floatAmountOf[_destToken] = floatAmountOf[_destToken].sub(
_swapAmount,
"11"
);
floatAmountOf[_sourceToken] = floatAmountOf[_sourceToken].add(
_swapAmount
);
emit Swap(_sourceToken, _destToken, _swapAmount);
}
function _safeTransfer(
address _token,
address _to,
uint256 _amount
) internal {
if (_token == BTCT_ADDR) {
_amount = _amount.mul(convertScale);
}
IERC20(_token).safeTransfer(_to, _amount);
}
function _rewardsCollection(
address _feesToken,
uint256 _rewardsAmount
) internal {
if (_rewardsAmount == 0) return;
uint256 nowPrice = getCurrentPriceLP();
floatAmountOf[_feesToken] = floatAmountOf[_feesToken].add(
_rewardsAmount
);
uint256 feesTotal = _rewardsAmount.mul(nodeRewardsRatio).div(100);
uint256 feesLPTTotal = feesTotal.mul(lpDivisor).div(nowPrice);
uint256 feesBuyback = feesLPTTotal.mul(buybackRewardsRatio).div(100);
lpToken.mint(sbBTCPool, feesLPTTotal.sub(feesBuyback));
lpToken.mint(buybackAddress, feesBuyback);
emit RewardsCollection(
_feesToken,
_rewardsAmount,
feesLPTTotal,
nowPrice
);
}
function _addUsedTx(bytes32 _txid) internal {
used[_txid] = true;
}
function _addUsedTxs(bytes32[] memory _txids) internal {
for (uint256 i = 0; i < _txids.length; i++) {
used[_txids[i]] = true;
}
}
function _splitToValues(
bytes32 _data
) internal pure returns (address, uint256) {
return (
address(uint160(uint256(_data))),
uint256(uint96(bytes12(_data)))
);
}
}
{
"compilationTarget": {
"contracts/SwapContract.sol": "SwapContract"
},
"evmVersion": "paris",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 1000
},
"remappings": []
}
[{"inputs":[{"internalType":"address","name":"_lpToken","type":"address"},{"internalType":"address","name":"_btct","type":"address"},{"internalType":"address","name":"_sbBTCPool","type":"address"},{"internalType":"address","name":"_swapRewards","type":"address"},{"internalType":"address","name":"_buybackAddress","type":"address"},{"internalType":"uint256","name":"_initBTCFloat","type":"uint256"},{"internalType":"uint256","name":"_initWBTCFloat","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"uint256","name":"amountOfLP","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amountOfFloat","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"currentPriceLP","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"withdrawal","type":"uint256"},{"indexed":false,"internalType":"bytes32","name":"txid","type":"bytes32"}],"name":"BurnLPTokensForFloat","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amountOfFloat","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amountOfLP","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"currentPriceLP","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"depositFees","type":"uint256"},{"indexed":false,"internalType":"bytes32","name":"txid","type":"bytes32"}],"name":"IssueLPTokensForFloat","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"feesToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"rewards","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"rewardsLPTTotal","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"currentPriceLP","type":"uint256"}],"name":"RewardsCollection","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Swap","type":"event"},{"stateMutability":"nonpayable","type":"fallback"},{"inputs":[],"name":"BTCT_ADDR","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"activeNodeCount","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackRewardsRatio","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_newOwner","type":"address"},{"internalType":"address[]","name":"_nodes","type":"address[]"},{"internalType":"bool[]","name":"_isRemoved","type":"bool[]"},{"internalType":"uint8","name":"_churnedInCount","type":"uint8"},{"internalType":"uint8","name":"_tssThreshold","type":"uint8"}],"name":"churn","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"churnedInCount","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_incomingAmount","type":"uint256"},{"internalType":"uint256","name":"_minerFee","type":"uint256"},{"internalType":"uint256","name":"_rewardsAmount","type":"uint256"},{"internalType":"address[]","name":"_spenders","type":"address[]"},{"internalType":"uint256[]","name":"_swapAmounts","type":"uint256[]"}],"name":"collectSwapFeesForBTC","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getActiveNodes","outputs":[{"internalType":"address[]","name":"","type":"address[]"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getCurrentPriceLP","outputs":[{"internalType":"uint256","name":"nowPrice","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenA","type":"address"},{"internalType":"address","name":"_tokenB","type":"address"}],"name":"getFloatReserve","outputs":[{"internalType":"uint256","name":"reserveA","type":"uint256"},{"internalType":"uint256","name":"reserveB","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_user","type":"address"}],"name":"isNodeStake","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"_txid","type":"bytes32"}],"name":"isTxUsed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lpToken","outputs":[{"internalType":"contract IBurnableToken","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_destToken","type":"address"},{"internalType":"bytes32[]","name":"_addressesAndAmounts","type":"bytes32[]"},{"internalType":"uint256","name":"_totalSwapped","type":"uint256"},{"internalType":"uint256","name":"_rewardsAmount","type":"uint256"},{"internalType":"bytes32[]","name":"_redeemedFloatTxIds","type":"bytes32[]"}],"name":"multiTransferERC20TightlyPacked","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"nodeRewardsRatio","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":"_token","type":"address"},{"internalType":"bytes32","name":"_addressesAndAmountOfFloat","type":"bytes32"},{"internalType":"bytes32","name":"_txid","type":"bytes32"}],"name":"recordIncomingFloat","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"bytes32","name":"_addressesAndAmountOfLPtoken","type":"bytes32"},{"internalType":"uint256","name":"_minerFee","type":"uint256"},{"internalType":"bytes32","name":"_txid","type":"bytes32"}],"name":"recordOutcomingFloat","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_minerFee","type":"uint256"},{"internalType":"bytes32","name":"_txid","type":"bytes32"}],"name":"recordUTXOSweepMinerFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sbBTCPool","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_destToken","type":"address"},{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint256","name":"_totalSwapped","type":"uint256"},{"internalType":"uint256","name":"_rewardsAmount","type":"uint256"},{"internalType":"bytes32[]","name":"_redeemedFloatTxIds","type":"bytes32[]"}],"name":"singleTransferERC20","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sw","outputs":[{"internalType":"contract ISwapRewards","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"tssThreshold","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_sbBTCPool","type":"address"},{"internalType":"address","name":"_buybackAddress","type":"address"},{"internalType":"uint256","name":"_withdrawalFeeBPS","type":"uint256"},{"internalType":"uint256","name":"_nodeRewardsRatio","type":"uint256"},{"internalType":"uint256","name":"_buybackRewardsRatio","type":"uint256"}],"name":"updateParams","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whitelist","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawalFeeBPS","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}]