文件 1 的 19:Address.sol
pragma solidity ^0.8.1;
library Address {
function isContract(address account) internal view returns (bool) {
return account.code.length > 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 functionCallWithValue(target, data, 0, "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");
(bool success, bytes memory returndata) = target.call{value: value}(data);
return verifyCallResultFromTarget(target, 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) {
(bool success, bytes memory returndata) = target.staticcall(data);
return verifyCallResultFromTarget(target, 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) {
(bool success, bytes memory returndata) = target.delegatecall(data);
return verifyCallResultFromTarget(target, success, returndata, errorMessage);
}
function verifyCallResultFromTarget(
address target,
bool success,
bytes memory returndata,
string memory errorMessage
) internal view returns (bytes memory) {
if (success) {
if (returndata.length == 0) {
require(isContract(target), "Address: call to non-contract");
}
return returndata;
} else {
_revert(returndata, errorMessage);
}
}
function verifyCallResult(
bool success,
bytes memory returndata,
string memory errorMessage
) internal pure returns (bytes memory) {
if (success) {
return returndata;
} else {
_revert(returndata, errorMessage);
}
}
function _revert(bytes memory returndata, string memory errorMessage) private pure {
if (returndata.length > 0) {
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
文件 2 的 19: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 的 19:IERC1155.sol
pragma solidity ^0.8.0;
import "../../utils/introspection/IERC165.sol";
interface IERC1155 is IERC165 {
event TransferSingle(address indexed operator, address indexed from, address indexed to, uint256 id, uint256 value);
event TransferBatch(
address indexed operator,
address indexed from,
address indexed to,
uint256[] ids,
uint256[] values
);
event ApprovalForAll(address indexed account, address indexed operator, bool approved);
event URI(string value, uint256 indexed id);
function balanceOf(address account, uint256 id) external view returns (uint256);
function balanceOfBatch(
address[] calldata accounts,
uint256[] calldata ids
) external view returns (uint256[] memory);
function setApprovalForAll(address operator, bool approved) external;
function isApprovedForAll(address account, address operator) external view returns (bool);
function safeTransferFrom(address from, address to, uint256 id, uint256 amount, bytes calldata data) external;
function safeBatchTransferFrom(
address from,
address to,
uint256[] calldata ids,
uint256[] calldata amounts,
bytes calldata data
) external;
}
文件 4 的 19:IERC165.sol
pragma solidity ^0.8.0;
interface IERC165 {
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
文件 5 的 19:IERC20.sol
pragma solidity ^0.8.0;
interface IERC20 {
function totalSupply() external view returns (uint256);
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);
}
文件 6 的 19:IERC20Permit.sol
pragma solidity ^0.8.0;
interface IERC20Permit {
function permit(
address owner,
address spender,
uint256 value,
uint256 deadline,
uint8 v,
bytes32 r,
bytes32 s
) external;
function nonces(address owner) external view returns (uint256);
function DOMAIN_SEPARATOR() external view returns (bytes32);
}
文件 7 的 19:IERC721.sol
pragma solidity ^0.8.0;
import "../../utils/introspection/IERC165.sol";
interface IERC721 is IERC165 {
event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);
event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);
event ApprovalForAll(address indexed owner, address indexed operator, bool approved);
function balanceOf(address owner) external view returns (uint256 balance);
function ownerOf(uint256 tokenId) external view returns (address owner);
function safeTransferFrom(
address from,
address to,
uint256 tokenId
) external;
function transferFrom(
address from,
address to,
uint256 tokenId
) external;
function approve(address to, uint256 tokenId) external;
function getApproved(uint256 tokenId) external view returns (address operator);
function setApprovalForAll(address operator, bool _approved) external;
function isApprovedForAll(address owner, address operator) external view returns (bool);
function safeTransferFrom(
address from,
address to,
uint256 tokenId,
bytes calldata data
) external;
}
文件 8 的 19:IKSZapRouterPosition.sol
pragma solidity 0.8.9;
interface IKSZapRouterPosition {
event ClientData(bytes _clientData);
event ZapExecuted(
uint8 indexed _dexType,
bytes indexed _srcInfo,
address _validator,
address _executor,
bytes _zapInfo,
bytes _extraData,
bytes _initialData,
bytes _zapResults
);
event ExecutorWhitelisted(address indexed _executor, bool indexed _grantOrRevoke);
event ValidatorWhitelisted(address indexed _validator, bool indexed _grantOrRevoke);
event ERC20Collected(address indexed _token, uint256 indexed _amount);
event ERC721Collected(address indexed _token, uint256 indexed _id);
event ERC1155Collected(address indexed _token, uint256 indexed _id, uint256 indexed _amount);
struct ZapDescription {
uint16 zapFlags;
bytes srcInfo;
bytes zapInfo;
bytes extraData;
}
struct ZapExecutionData {
address validator;
address executor;
uint32 deadline;
bytes executorData;
bytes clientData;
}
struct DelegatecallData {
address helper;
bytes4 funcSelector;
}
struct ERC20SrcInfo {
address[] tokens;
uint256[] amounts;
}
struct ERC721SrcInfo {
address[] tokens;
uint256[] ids;
}
struct ERC1155SrcInfo {
address[] tokens;
uint256[] ids;
uint256[] amounts;
bytes[] datas;
}
function zap(
ZapDescription calldata _desc,
ZapExecutionData calldata _exe
) external payable returns (bytes memory zapResults);
function whitelistExecutors(address[] calldata _executors, bool _grantOrRevoke) external;
function whitelistValidators(address[] calldata _validators, bool _grantOrRevoke) external;
}
文件 9 的 19:IZapDexEnum.sol
pragma solidity >= 0.8.0;
interface IZapDexEnum {
enum DexType {
UniswapV2,
UniswapV3
}
enum SrcType {
ERC20Token,
ERC721Token,
ERC1155Token
}
}
文件 10 的 19:IZapExecutorPosition.sol
pragma solidity 0.8.9;
interface IZapExecutorPosition {
function executeZap(
bytes calldata _executorData
) external payable returns (bytes memory zapResults);
}
文件 11 的 19:IZapValidator.sol
pragma solidity 0.8.9;
import {IZapDexEnum} from 'contracts/interfaces/zap/common/IZapDexEnum.sol';
interface IZapValidator is IZapDexEnum {
function prepareValidationData(
uint8 _dexType,
bytes calldata _zapInfo
) external view returns (bytes memory validationData);
function validateData(
uint8 _dexType,
bytes calldata _extraData,
bytes calldata _initialData,
bytes calldata _zapResults
) external view returns (bool isValid);
}
文件 12 的 19:KSRescue.sol
pragma solidity ^0.8.0;
import {KyberSwapRole} from '@src/KyberSwapRole.sol';
import {IERC20} from '@openzeppelin/contracts/token/ERC20/IERC20.sol';
import {SafeERC20} from '@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol';
abstract contract KSRescue is KyberSwapRole {
using SafeERC20 for IERC20;
address private constant ETH_ADDRESS = address(0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE);
function rescueFunds(address token, uint256 amount, address recipient) external onlyOwner {
require(recipient != address(0), 'KSRescue: invalid recipient');
if (amount == 0) amount = _getAvailableAmount(token);
if (amount > 0) {
if (_isETH(token)) {
(bool success,) = recipient.call{value: amount}('');
require(success, 'KSRescue: ETH_TRANSFER_FAILED');
} else {
IERC20(token).safeTransfer(recipient, amount);
}
}
}
function _getAvailableAmount(address token) internal view virtual returns (uint256 amount) {
if (_isETH(token)) {
amount = address(this).balance;
} else {
amount = IERC20(token).balanceOf(address(this));
}
if (amount > 0) --amount;
}
function _isETH(address token) internal pure returns (bool) {
return (token == ETH_ADDRESS);
}
}
文件 13 的 19:KSRescueV2.sol
pragma solidity ^0.8.0;
import {KSRescue} from '@src/KSRescue.sol';
import {IERC721} from '@openzeppelin/contracts/token/ERC721/IERC721.sol';
import {IERC1155} from '@openzeppelin/contracts/token/ERC1155/IERC1155.sol';
abstract contract KSRescueV2 is KSRescue {
function rescueBatchERC721(
address token,
uint256[] calldata _ids,
address recipient
) external onlyOwner {
require(recipient != address(0), 'KSRescue: invalid recipient');
for (uint256 i = 0; i < _ids.length; i++) {
IERC721(token).transferFrom(address(this), recipient, _ids[i]);
}
}
function rescueBatchERC1155(
address token,
uint256[] calldata ids,
uint256[] memory amounts,
bytes calldata data,
address recipient
) external onlyOwner {
require(recipient != address(0), 'KSRescue: invalid recipient');
require(ids.length == amounts.length, 'KSRescue: invalid array length');
for (uint256 i = 0; i < ids.length; ++i) {
if (amounts[i] == 0) amounts[i] = IERC1155(token).balanceOf(address(this), ids[i]);
}
IERC1155(token).safeBatchTransferFrom(address(this), recipient, ids, amounts, data);
}
}
文件 14 的 19:KSZapRouterPosition.sol
pragma solidity 0.8.9;
import {IKSZapRouterPosition} from 'contracts/interfaces/IKSZapRouterPosition.sol';
import {IZapValidator} from 'contracts/interfaces/zap/validators/IZapValidator.sol';
import {IZapExecutorPosition} from 'contracts/interfaces/zap/executors/IZapExecutorPosition.sol';
import {IZapDexEnum} from 'contracts/interfaces/zap/common/IZapDexEnum.sol';
import {KSRescueV2} from 'ks-growth-utils-sc/contracts/KSRescueV2.sol';
import {ReentrancyGuard} from 'openzeppelin/contracts/security/ReentrancyGuard.sol';
import {IERC20} from 'openzeppelin/contracts/token/ERC20/IERC20.sol';
import {SafeERC20} from 'openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol';
import {IERC721} from 'openzeppelin/contracts/token/ERC721/IERC721.sol';
import {IERC1155} from 'openzeppelin/contracts/token/ERC1155/IERC1155.sol';
contract KSZapRouterPosition is IKSZapRouterPosition, IZapDexEnum, KSRescueV2, ReentrancyGuard {
using SafeERC20 for IERC20;
address private constant ETH_ADDRESS = address(0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE);
mapping(address => bool) public whitelistedExecutor;
mapping(address => bool) public whitelistedValidator;
modifier checkDeadline(uint32 _deadline) {
require(block.timestamp <= _deadline, 'ZapRouter: expired');
_;
}
constructor() {}
function whitelistExecutors(
address[] calldata _executors,
bool _grantOrRevoke
) external onlyOwner {
for (uint256 i = 0; i < _executors.length; i++) {
whitelistedExecutor[_executors[i]] = _grantOrRevoke;
emit ExecutorWhitelisted(_executors[i], _grantOrRevoke);
}
}
function whitelistValidators(
address[] calldata _validators,
bool _grantOrRevoke
) external onlyOwner {
for (uint256 i = 0; i < _validators.length; i++) {
whitelistedValidator[_validators[i]] = _grantOrRevoke;
emit ValidatorWhitelisted(_validators[i], _grantOrRevoke);
}
}
function zap(
ZapDescription calldata _desc,
ZapExecutionData calldata _exe
)
external
payable
override
whenNotPaused
nonReentrant
checkDeadline(_exe.deadline)
returns (bytes memory zapResults)
{
uint8 dexType = uint8(_desc.zapFlags >> 8);
uint8 srcType = uint8(_desc.zapFlags);
require(whitelistedExecutor[_exe.executor], 'ZapRouter: non whitelisted executor');
if (srcType == uint8(SrcType.ERC20Token)) {
_handleCollectERC20Tokens(_desc.srcInfo, _exe.executor);
} else if (srcType == uint8(SrcType.ERC721Token)) {
_handleCollectERC721Tokens(_desc.srcInfo, _exe.executor);
} else if (srcType == uint8(SrcType.ERC1155Token)) {
_handleCollectERC1155Tokens(_desc.srcInfo, _exe.executor);
}
bytes memory initialData;
if (_exe.validator != address(0)) {
require(whitelistedValidator[_exe.validator], 'ZapRouter: non whitelisted validator');
initialData = IZapValidator(_exe.validator).prepareValidationData(dexType, _desc.zapInfo);
}
zapResults = IZapExecutorPosition(_exe.executor).executeZap{value: msg.value}(_exe.executorData);
if (_exe.validator != address(0)) {
bool isValid = IZapValidator(_exe.validator).validateData(
dexType, _desc.extraData, initialData, zapResults
);
require(isValid, 'ZapRouter: validation failed');
}
emit ZapExecuted(
dexType,
_desc.srcInfo,
_exe.validator,
_exe.executor,
_desc.zapInfo,
_desc.extraData,
initialData,
zapResults
);
emit ClientData(_exe.clientData);
}
function _handleCollectERC20Tokens(bytes memory _srcInfo, address _executor) internal {
ERC20SrcInfo memory src = abi.decode(_srcInfo, (ERC20SrcInfo));
require(
src.tokens.length == src.amounts.length && src.tokens.length > 0, 'ZapRouter: invalid data'
);
uint256 msgValue = msg.value;
address msgSender = msg.sender;
for (uint256 i = 0; i < src.tokens.length;) {
if (src.tokens[i] == ETH_ADDRESS) {
require(msgValue > 0 && msgValue == src.amounts[i], 'ZapRouter: invalid msg value');
msgValue = 0;
} else {
IERC20(src.tokens[i]).safeTransferFrom(msgSender, _executor, src.amounts[i]);
}
emit ERC20Collected(src.tokens[i], src.amounts[i]);
unchecked {
++i;
}
}
require(msgValue == 0, 'ZapRouter: invalid msg value');
}
function _handleCollectERC721Tokens(bytes memory _srcInfo, address _executor) internal {
require(msg.value == 0, 'ZapRouter: invalid msg value');
ERC721SrcInfo memory src = abi.decode(_srcInfo, (ERC721SrcInfo));
require(src.tokens.length == src.ids.length && src.tokens.length > 0, 'ZapRouter: invalid data');
for (uint256 i = 0; i < src.tokens.length;) {
IERC721(src.tokens[i]).safeTransferFrom(msg.sender, _executor, src.ids[i]);
emit ERC721Collected(src.tokens[i], src.ids[i]);
unchecked {
++i;
}
}
}
function _handleCollectERC1155Tokens(bytes memory _srcInfo, address _executor) internal {
require(msg.value == 0, 'ZapRouter: invalid msg value');
ERC1155SrcInfo memory src = abi.decode(_srcInfo, (ERC1155SrcInfo));
require(src.tokens.length > 0 && src.tokens.length == src.ids.length, 'ZapRouter: invalid data');
require(src.tokens.length == src.amounts.length, 'ZapRouter: invalid data');
require(src.tokens.length == src.datas.length, 'ZapRouter: invalid data');
for (uint256 i = 0; i < src.tokens.length;) {
IERC1155(src.tokens[i]).safeTransferFrom(
msg.sender, _executor, src.ids[i], src.amounts[i], src.datas[i]
);
emit ERC1155Collected(src.tokens[i], src.ids[i], src.amounts[i]);
unchecked {
++i;
}
}
}
}
文件 15 的 19:KyberSwapRole.sol
pragma solidity ^0.8.0;
import {Ownable} from '@openzeppelin/contracts/access/Ownable.sol';
import {Pausable} from '@openzeppelin/contracts/security/Pausable.sol';
abstract contract KyberSwapRole is Ownable, Pausable {
mapping(address => bool) public operators;
mapping(address => bool) public guardians;
event UpdateOperator(address user, bool grantOrRevoke);
event UpdateGuardian(address user, bool grantOrRevoke);
modifier onlyOperator() {
require(operators[msg.sender], 'KyberSwapRole: not operator');
_;
}
modifier onlyGuardian() {
require(guardians[msg.sender], 'KyberSwapRole: not guardian');
_;
}
function updateOperator(address user, bool grantOrRevoke) external onlyOwner {
operators[user] = grantOrRevoke;
emit UpdateOperator(user, grantOrRevoke);
}
function updateGuardian(address user, bool grantOrRevoke) external onlyOwner {
guardians[user] = grantOrRevoke;
emit UpdateGuardian(user, grantOrRevoke);
}
function enableLogic() external onlyOwner {
_unpause();
}
function disableLogic() external onlyGuardian {
_pause();
}
}
文件 16 的 19: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() {
_setOwner(_msgSender());
}
function owner() public view virtual returns (address) {
return _owner;
}
modifier onlyOwner() {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
_setOwner(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_setOwner(newOwner);
}
function _setOwner(address newOwner) private {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
文件 17 的 19:Pausable.sol
pragma solidity ^0.8.0;
import "../utils/Context.sol";
abstract contract Pausable is Context {
event Paused(address account);
event Unpaused(address account);
bool private _paused;
constructor() {
_paused = false;
}
function paused() public view virtual returns (bool) {
return _paused;
}
modifier whenNotPaused() {
require(!paused(), "Pausable: paused");
_;
}
modifier whenPaused() {
require(paused(), "Pausable: not paused");
_;
}
function _pause() internal virtual whenNotPaused {
_paused = true;
emit Paused(_msgSender());
}
function _unpause() internal virtual whenPaused {
_paused = false;
emit Unpaused(_msgSender());
}
}
文件 18 的 19:ReentrancyGuard.sol
pragma solidity ^0.8.0;
abstract contract ReentrancyGuard {
uint256 private constant _NOT_ENTERED = 1;
uint256 private constant _ENTERED = 2;
uint256 private _status;
constructor() {
_status = _NOT_ENTERED;
}
modifier nonReentrant() {
_nonReentrantBefore();
_;
_nonReentrantAfter();
}
function _nonReentrantBefore() private {
require(_status != _ENTERED, "ReentrancyGuard: reentrant call");
_status = _ENTERED;
}
function _nonReentrantAfter() private {
_status = _NOT_ENTERED;
}
function _reentrancyGuardEntered() internal view returns (bool) {
return _status == _ENTERED;
}
}
文件 19 的 19:SafeERC20.sol
pragma solidity ^0.8.0;
import "../IERC20.sol";
import "../../../utils/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 safeDecreaseAllowance(
IERC20 token,
address spender,
uint256 value
) internal {
unchecked {
uint256 oldAllowance = token.allowance(address(this), spender);
require(oldAllowance >= value, "SafeERC20: decreased allowance below zero");
uint256 newAllowance = oldAllowance - 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");
}
}
}
{
"compilationTarget": {
"contracts/KSZapRouterPosition.sol": "KSZapRouterPosition"
},
"evmVersion": "london",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": [
":@openzeppelin/=lib/ks-growth-utils-sc/lib/openzeppelin-contracts/",
":@src/=lib/ks-growth-utils-sc/contracts/",
":ds-test/=lib/forge-std/lib/ds-test/src/",
":erc4626-tests/=lib/openzeppelin-contracts/lib/erc4626-tests/",
":forge-std/=lib/forge-std/src/",
":ks-growth-utils-sc/=lib/ks-growth-utils-sc/",
":openzeppelin-contracts/=lib/openzeppelin-contracts/",
":openzeppelin/=lib/openzeppelin-contracts/"
]
}
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bytes","name":"_clientData","type":"bytes"}],"name":"ClientData","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_token","type":"address"},{"indexed":true,"internalType":"uint256","name":"_id","type":"uint256"},{"indexed":true,"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"ERC1155Collected","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_token","type":"address"},{"indexed":true,"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"ERC20Collected","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_token","type":"address"},{"indexed":true,"internalType":"uint256","name":"_id","type":"uint256"}],"name":"ERC721Collected","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_executor","type":"address"},{"indexed":true,"internalType":"bool","name":"_grantOrRevoke","type":"bool"}],"name":"ExecutorWhitelisted","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":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"bool","name":"grantOrRevoke","type":"bool"}],"name":"UpdateGuardian","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"bool","name":"grantOrRevoke","type":"bool"}],"name":"UpdateOperator","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_validator","type":"address"},{"indexed":true,"internalType":"bool","name":"_grantOrRevoke","type":"bool"}],"name":"ValidatorWhitelisted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint8","name":"_dexType","type":"uint8"},{"indexed":true,"internalType":"bytes","name":"_srcInfo","type":"bytes"},{"indexed":false,"internalType":"address","name":"_validator","type":"address"},{"indexed":false,"internalType":"address","name":"_executor","type":"address"},{"indexed":false,"internalType":"bytes","name":"_zapInfo","type":"bytes"},{"indexed":false,"internalType":"bytes","name":"_extraData","type":"bytes"},{"indexed":false,"internalType":"bytes","name":"_initialData","type":"bytes"},{"indexed":false,"internalType":"bytes","name":"_zapResults","type":"bytes"}],"name":"ZapExecuted","type":"event"},{"inputs":[],"name":"disableLogic","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableLogic","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"guardians","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"operators","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256[]","name":"ids","type":"uint256[]"},{"internalType":"uint256[]","name":"amounts","type":"uint256[]"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"address","name":"recipient","type":"address"}],"name":"rescueBatchERC1155","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256[]","name":"_ids","type":"uint256[]"},{"internalType":"address","name":"recipient","type":"address"}],"name":"rescueBatchERC721","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"}],"name":"rescueFunds","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"bool","name":"grantOrRevoke","type":"bool"}],"name":"updateGuardian","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"bool","name":"grantOrRevoke","type":"bool"}],"name":"updateOperator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_executors","type":"address[]"},{"internalType":"bool","name":"_grantOrRevoke","type":"bool"}],"name":"whitelistExecutors","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_validators","type":"address[]"},{"internalType":"bool","name":"_grantOrRevoke","type":"bool"}],"name":"whitelistValidators","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whitelistedExecutor","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whitelistedValidator","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"uint16","name":"zapFlags","type":"uint16"},{"internalType":"bytes","name":"srcInfo","type":"bytes"},{"internalType":"bytes","name":"zapInfo","type":"bytes"},{"internalType":"bytes","name":"extraData","type":"bytes"}],"internalType":"struct IKSZapRouterPosition.ZapDescription","name":"_desc","type":"tuple"},{"components":[{"internalType":"address","name":"validator","type":"address"},{"internalType":"address","name":"executor","type":"address"},{"internalType":"uint32","name":"deadline","type":"uint32"},{"internalType":"bytes","name":"executorData","type":"bytes"},{"internalType":"bytes","name":"clientData","type":"bytes"}],"internalType":"struct IKSZapRouterPosition.ZapExecutionData","name":"_exe","type":"tuple"}],"name":"zap","outputs":[{"internalType":"bytes","name":"zapResults","type":"bytes"}],"stateMutability":"payable","type":"function"}]