Address Contract Partially Verified
Address
0x017E71e96f2Ae777C679740d2D8Dc15Ed4231981
Balance
0 ETH
Nonce
1
Code Size
4845 bytes
Creator
0x2D407dDb...d45C at tx 0xbb19b1e1...c742d8
Indexed Transactions
0 (1 on-chain, 0.8% indexed)
Contract Bytecode
4845 bytes
0x608060405234801561001057600080fd5b506004361061018e5760003560e01c806370a08231116100de578063b6b55f2511610097578063dd62ed3e11610071578063dd62ed3e14610313578063de5f626814610326578063f39c38a01461032e578063f44637ba146103365761018e565b8063b6b55f25146102e5578063d505accf146102f8578063d82d41ac1461030b5761018e565b806370a082311461027e5780637ecebe001461029157806395d89b41146102a45780639dc29fac146102ac578063a9059cbb146102bf578063ab033ea9146102d25761018e565b806320606b701161014b57806330adf81f1161012557806330adf81f14610239578063313ce5671461024157806340c10f19146102565780635aa6e675146102695761018e565b806320606b7014610216578063238efcbc1461021e57806323b872dd146102265761018e565b8063028468581461019357806303d41e0e146101a857806306fdde03146101d1578063095ea7b3146101e65780631778e29c146101f957806318160ddd1461020e575b600080fd5b6101a66101a1366004610dd4565b610349565b005b6101bb6101b6366004610dd4565b61039d565b6040516101c89190610fbb565b60405180910390f35b6101d96103b2565b6040516101c89190611021565b6101bb6101f4366004610ed3565b6103d9565b610201610443565b6040516101c89190610fc6565b610201610467565b61020161046d565b6101a6610491565b6101bb610234366004610e27565b6104df565b6102016105ab565b6102496105cf565b6040516101c891906111fe565b6101a6610264366004610ed3565b6105d4565b610271610611565b6040516101c89190610f83565b61020161028c366004610dd4565b610620565b61020161029f366004610dd4565b61063f565b6101d9610651565b6101a66102ba366004610ed3565b610671565b6101bb6102cd366004610ed3565b6106aa565b6101a66102e0366004610dd4565b6106c0565b6101a66102f3366004610f1c565b61070c565b6101a6610306366004610e62565b610718565b61027161091e565b610201610321366004610df5565b610936565b6101a6610961565b6102716109f3565b6101a6610344366004610dd4565b610a02565b6001546001600160a01b0316331461037c5760405162461bcd60e51b815260040161037390611054565b60405180910390fd5b6001600160a01b03166000908152600360205260409020805460ff19169055565b60036020526000908152604090205460ff1681565b6040518060400160405280600b81526020016a577261707065642059464960a81b81525081565b3360008181526004602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92590610432908690610fc6565b60405180910390a350600192915050565b7f402ea8e0c0709618717df35c9b3fdde654338cbe0e1d04a6c689327bc894f59e81565b60005481565b7f797cfab58fcb15f590eb8e4252d5c228ff88f94f907e119e80c4393a946e8f3581565b6002546001600160a01b031633146104bb5760405162461bcd60e51b8152600401610373906110d7565b600254600180546001600160a01b0319166001600160a01b03909216919091179055565b6001600160a01b03831660008181526004602090815260408083203380855292528220549192909190821480159061051957506000198114155b1561059457600061052a8583611243565b6001600160a01b03808916600081815260046020908152604080832094891680845294909152908190208490555192935090917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259061058a908590610fc6565b60405180910390a3505b61059f868686610a50565b50600195945050505050565b7f5fae9ec55a1e547936e0e74d606b44cd5f912f9adcd0bba561fea62d570259e981565b601281565b3360009081526003602052604090205460ff166106035760405162461bcd60e51b8152600401610373906111a6565b61060d8282610afc565b5050565b6001546001600160a01b031681565b6001600160a01b0381166000908152600560205260409020545b919050565b60066020526000908152604090205481565b604051806040016040528060048152602001637759464960e01b81525081565b3360009081526003602052604090205460ff166106a05760405162461bcd60e51b8152600401610373906111a6565b61060d8282610b89565b60006106b7338484610a50565b50600192915050565b6001546001600160a01b031633146106ea5760405162461bcd60e51b815260040161037390611054565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b61071581610c0a565b50565b6001600160a01b038716600090815260066020526040812080547f5fae9ec55a1e547936e0e74d606b44cd5f912f9adcd0bba561fea62d570259e9918a918a918a91908661076583611286565b919050558960405160200161077f96959493929190610fcf565b60405160208183030381529060405280519060200120905060007f402ea8e0c0709618717df35c9b3fdde654338cbe0e1d04a6c689327bc894f59e826040516020016107cc929190610f68565b6040516020818303038152906040528051906020012090506000600182878787604051600081526020016040526040516108099493929190611003565b6020604051602081039080840390855afa15801561082b573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811661085e5760405162461bcd60e51b815260040161037390611131565b896001600160a01b0316816001600160a01b03161461088f5760405162461bcd60e51b815260040161037390611103565b864211156108af5760405162461bcd60e51b8152600401610373906110ae565b6001600160a01b03808b166000818152600460209081526040808320948e1680845294909152908190208b9055517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259061090a908c90610fc6565b60405180910390a350505050505050505050565b730bc529c00c6401aef6d220be8c6ea1667f6ad93e81565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b6040516370a0823160e01b81526109f190730bc529c00c6401aef6d220be8c6ea1667f6ad93e906370a082319061099c903390600401610f83565b60206040518083038186803b1580156109b457600080fd5b505afa1580156109c8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109ec9190610f34565b610c0a565b565b6002546001600160a01b031681565b6001546001600160a01b03163314610a2c5760405162461bcd60e51b815260040161037390611054565b6001600160a01b03166000908152600360205260409020805460ff19166001179055565b6001600160a01b03831660009081526005602052604081208054839290610a78908490611243565b90915550506001600160a01b03821660009081526005602052604081208054839290610aa590849061120c565b92505081905550816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610aef9190610fc6565b60405180910390a3505050565b80600080828254610b0d919061120c565b90915550506001600160a01b03821660009081526005602052604081208054839290610b3a90849061120c565b90915550506040516001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610b7d908590610fc6565b60405180910390a35050565b80600080828254610b9a9190611243565b90915550506001600160a01b03821660009081526005602052604081208054839290610bc7908490611243565b90915550506040516000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610b7d908590610fc6565b610c2a730bc529c00c6401aef6d220be8c6ea1667f6ad93e333084610c3f565b61071533610c3a836103e8611224565b610afc565b610c97846323b872dd60e01b858585604051602401610c6093929190610f97565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b031990931692909217909152610c9d565b50505050565b610caf826001600160a01b0316610d81565b610ccb5760405162461bcd60e51b8152600401610373906111c7565b600080836001600160a01b031683604051610ce69190610f4c565b6000604051808303816000865af19150503d8060008114610d23576040519150601f19603f3d011682016040523d82523d6000602084013e610d28565b606091505b509150915081610d4a5760405162461bcd60e51b815260040161037390611079565b805115610c975780806020019051810190610d659190610efc565b610c975760405162461bcd60e51b81526004016103739061115c565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a4708115801590610db55750808214155b949350505050565b80356001600160a01b038116811461063a57600080fd5b600060208284031215610de5578081fd5b610dee82610dbd565b9392505050565b60008060408385031215610e07578081fd5b610e1083610dbd565b9150610e1e60208401610dbd565b90509250929050565b600080600060608486031215610e3b578081fd5b610e4484610dbd565b9250610e5260208501610dbd565b9150604084013590509250925092565b600080600080600080600060e0888a031215610e7c578283fd5b610e8588610dbd565b9650610e9360208901610dbd565b95506040880135945060608801359350608088013560ff81168114610eb6578384fd5b9699959850939692959460a0840135945060c09093013592915050565b60008060408385031215610ee5578182fd5b610eee83610dbd565b946020939093013593505050565b600060208284031215610f0d578081fd5b81518015158114610dee578182fd5b600060208284031215610f2d578081fd5b5035919050565b600060208284031215610f45578081fd5b5051919050565b60008251610f5e81846020870161125a565b9190910192915050565b61190160f01b81526002810192909252602282015260420190565b6001600160a01b0391909116815260200190565b6001600160a01b039384168152919092166020820152604081019190915260600190565b901515815260200190565b90815260200190565b9586526001600160a01b0394851660208701529290931660408501526060840152608083019190915260a082015260c00190565b93845260ff9290921660208401526040830152606082015260800190565b600060208252825180602084015261104081604085016020870161125a565b601f01601f19169190910160400192915050565b6020808252600b908201526a21676f7665726e616e636560a81b604082015260600190565b6020808252818101527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564604082015260600190565b6020808252600f908201526e1c195c9b5a5d0e88195e1c1a5c9959608a1b604082015260600190565b6020808252601290820152712170656e64696e67476f7665726e616e636560701b604082015260600190565b6020808252601490820152731c195c9b5a5d0e881d5b985d5d1a1bdc9a5e995960621b604082015260600190565b6020808252601190820152707065726d69743a207369676e617475726560781b604082015260600190565b6020808252602a908201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6040820152691bdd081cdd58d8d9595960b21b606082015260800190565b60208082526007908201526610b13ab93732b960c91b604082015260600190565b6020808252601f908201527f5361666545524332303a2063616c6c20746f206e6f6e2d636f6e747261637400604082015260600190565b60ff91909116815260200190565b6000821982111561121f5761121f6112a1565b500190565b600081600019048311821515161561123e5761123e6112a1565b500290565b600082821015611255576112556112a1565b500390565b60005b8381101561127557818101518382015260200161125d565b83811115610c975750506000910152565b600060001982141561129a5761129a6112a1565b5060010190565b634e487b7160e01b600052601160045260246000fdfea26469706673582212207c847a66516d273288a0a6849f69743af950f8e29d2f84dcf75f79b6a715eb3864736f6c63430008000033
Verified Source Code Partial Match
Compiler: v0.8.0+commit.c7dfd78e
EVM: istanbul
Optimization: Yes (200 runs)
WrappedYFI.sol 268 lines
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
interface IERC20 {
function totalSupply() external view returns (uint256);
function decimals() 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);
}
library Address {
function isContract(address account) internal view returns (bool) {
bytes32 codehash;
bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
// solhint-disable-next-line no-inline-assembly
assembly { codehash := extcodehash(account) }
return (codehash != 0x0 && codehash != accountHash);
}
}
library SafeERC20 {
using Address for address;
function safeTransfer(IERC20 token, address to, uint value) internal {
callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
}
function safeTransferFrom(IERC20 token, address from, address to, uint value) internal {
callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
}
function safeApprove(IERC20 token, address spender, uint 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 callOptionalReturn(IERC20 token, bytes memory data) private {
require(address(token).isContract(), "SafeERC20: call to non-contract");
// solhint-disable-next-line avoid-low-level-calls
(bool success, bytes memory returndata) = address(token).call(data);
require(success, "SafeERC20: low-level call failed");
if (returndata.length > 0) { // Return data is optional
// solhint-disable-next-line max-line-length
require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
}
}
}
contract WrappedYFI {
using SafeERC20 for IERC20;
/// @notice EIP-20 token name for this token
string public constant name = "Wrapped YFI";
/// @notice EIP-20 token symbol for this token
string public constant symbol = "wYFI";
/// @notice EIP-20 token decimals for this token
uint8 public constant decimals = 18;
/// @notice Total number of tokens in circulation
uint public totalSupply = 0;
IERC20 public constant YFI = IERC20(0x0bc529c00C6401aEF6D220BE8C6Ea1667F6Ad93e);
address public governance;
address public pendingGovernance;
mapping(address => bool) public burners;
mapping(address => mapping (address => uint)) internal allowances;
mapping(address => uint) internal balances;
/// @notice The EIP-712 typehash for the contract's domain
bytes32 public constant DOMAIN_TYPEHASH = keccak256("EIP712Domain(string name,uint chainId,address verifyingContract)");
bytes32 public immutable DOMAINSEPARATOR;
/// @notice The EIP-712 typehash for the permit struct used by the contract
bytes32 public constant PERMIT_TYPEHASH = keccak256("Permit(address owner,address spender,uint value,uint nonce,uint deadline)");
/// @notice A record of states for signing / validating signatures
mapping (address => uint) public nonces;
function mint(address account, uint amount) public {
require(burners[msg.sender], "!burner");
_mint(account, amount);
}
function burn(address account, uint amount) public {
require(burners[msg.sender], "!burner");
_burn(account, amount);
}
function setGovernance(address _governance) public {
require(msg.sender == governance, "!governance");
pendingGovernance = _governance;
}
function acceptGovernance() public {
require(msg.sender == pendingGovernance, "!pendingGovernance");
governance = pendingGovernance;
}
function addBurner(address _burner) public {
require(msg.sender == governance, "!governance");
burners[_burner] = true;
}
function removeBurner(address _burner) public {
require(msg.sender == governance, "!governance");
burners[_burner] = false;
}
function safe32(uint n, string memory errorMessage) internal pure returns (uint32) {
require(n < 2**32, errorMessage);
return uint32(n);
}
/// @notice The standard EIP-20 transfer event
event Transfer(address indexed from, address indexed to, uint amount);
/// @notice The standard EIP-20 approval event
event Approval(address indexed owner, address indexed spender, uint amount);
constructor () {
DOMAINSEPARATOR = keccak256(abi.encode(DOMAIN_TYPEHASH, keccak256(bytes(name)), _getChainId(), address(this)));
governance = msg.sender;
}
function _mint(address dst, uint amount) internal {
// mint the amount
totalSupply += amount;
// transfer the amount to the recipient
balances[dst] += amount;
emit Transfer(address(0), dst, amount);
}
function _burn(address dst, uint amount) internal {
// burn the amount
totalSupply -= amount;
// transfer the amount from the recipient
balances[dst] -= amount;
emit Transfer(dst, address(0), amount);
}
function depositAll() external {
_deposit(YFI.balanceOf(msg.sender));
}
function deposit(uint amount) external {
_deposit(amount);
}
function _deposit(uint amount) internal {
YFI.safeTransferFrom(msg.sender, address(this), amount);
_mint(msg.sender, amount * 1e3);
}
/**
* @notice Get the number of tokens `spender` is approved to spend on behalf of `account`
* @param account The address of the account holding the funds
* @param spender The address of the account spending the funds
* @return The number of tokens approved
*/
function allowance(address account, address spender) external view returns (uint) {
return allowances[account][spender];
}
/**
* @notice Approve `spender` to transfer up to `amount` from `src`
* @dev This will overwrite the approval amount for `spender`
* and is subject to issues noted [here](https://eips.ethereum.org/EIPS/eip-20#approve)
* @param spender The address of the account which may transfer tokens
* @param amount The number of tokens that are approved (2^256-1 means infinite)
* @return Whether or not the approval succeeded
*/
function approve(address spender, uint amount) external returns (bool) {
allowances[msg.sender][spender] = amount;
emit Approval(msg.sender, spender, amount);
return true;
}
/**
* @notice Triggers an approval from owner to spends
* @param owner The address to approve from
* @param spender The address to be approved
* @param amount The number of tokens that are approved (2^256-1 means infinite)
* @param deadline The time at which to expire the signature
* @param v The recovery byte of the signature
* @param r Half of the ECDSA signature pair
* @param s Half of the ECDSA signature pair
*/
function permit(address owner, address spender, uint amount, uint deadline, uint8 v, bytes32 r, bytes32 s) external {
bytes32 structHash = keccak256(abi.encode(PERMIT_TYPEHASH, owner, spender, amount, nonces[owner]++, deadline));
bytes32 digest = keccak256(abi.encodePacked("\x19\x01", DOMAINSEPARATOR, structHash));
address signatory = ecrecover(digest, v, r, s);
require(signatory != address(0), "permit: signature");
require(signatory == owner, "permit: unauthorized");
require(block.timestamp <= deadline, "permit: expired");
allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
/**
* @notice Get the number of tokens held by the `account`
* @param account The address of the account to get the balance of
* @return The number of tokens held
*/
function balanceOf(address account) external view returns (uint) {
return balances[account];
}
/**
* @notice Transfer `amount` tokens from `msg.sender` to `dst`
* @param dst The address of the destination account
* @param amount The number of tokens to transfer
* @return Whether or not the transfer succeeded
*/
function transfer(address dst, uint amount) external returns (bool) {
_transferTokens(msg.sender, dst, amount);
return true;
}
/**
* @notice Transfer `amount` tokens from `src` to `dst`
* @param src The address of the source account
* @param dst The address of the destination account
* @param amount The number of tokens to transfer
* @return Whether or not the transfer succeeded
*/
function transferFrom(address src, address dst, uint amount) external returns (bool) {
address spender = msg.sender;
uint spenderAllowance = allowances[src][spender];
if (spender != src && spenderAllowance != type(uint).max) {
uint newAllowance = spenderAllowance - amount;
allowances[src][spender] = newAllowance;
emit Approval(src, spender, newAllowance);
}
_transferTokens(src, dst, amount);
return true;
}
function _transferTokens(address src, address dst, uint amount) internal {
balances[src] -= amount;
balances[dst] += amount;
emit Transfer(src, dst, amount);
}
function _getChainId() internal view returns (uint) {
uint chainId;
assembly { chainId := chainid() }
return chainId;
}
}
Read Contract
DOMAINSEPARATOR 0x1778e29c → bytes32
DOMAIN_TYPEHASH 0x20606b70 → bytes32
PERMIT_TYPEHASH 0x30adf81f → bytes32
YFI 0xd82d41ac → address
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
burners 0x03d41e0e → bool
decimals 0x313ce567 → uint8
governance 0x5aa6e675 → address
name 0x06fdde03 → string
nonces 0x7ecebe00 → uint256
pendingGovernance 0xf39c38a0 → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 12 functions
These functions modify contract state and require a wallet transaction to execute.
acceptGovernance 0x238efcbc
No parameters
addBurner 0xf44637ba
address _burner
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
burn 0x9dc29fac
address account
uint256 amount
deposit 0xb6b55f25
uint256 amount
depositAll 0xde5f6268
No parameters
mint 0x40c10f19
address account
uint256 amount
permit 0xd505accf
address owner
address spender
uint256 amount
uint256 deadline
uint8 v
bytes32 r
bytes32 s
removeBurner 0x02846858
address _burner
setGovernance 0xab033ea9
address _governance
transfer 0xa9059cbb
address dst
uint256 amount
returns: bool
transferFrom 0x23b872dd
address src
address dst
uint256 amount
returns: bool
Recent Transactions
This address has 1 on-chain transactions, but only 0.8% of the chain is indexed. Transactions will appear as indexing progresses. View on Etherscan →