Address Contract Partially Verified
Address
0xfe65601137c67537789Ce33fa0D49Df10F974F5E
Balance
0 ETH
Nonce
1
Code Size
5510 bytes
Creator
0x55193ecE...8aDF at tx 0xceb27c48...36079a
Indexed Transactions
0
Contract Bytecode
5510 bytes
0x608060405234801561001057600080fd5b50600436106101425760003560e01c80638da5cb5b116100b8578063d1c469161161007c578063d1c4691614610296578063d8fb9337146102a9578063dd62ed3e146102df578063de6baccb14610318578063e20bc67b1461032b578063f2fde38b1461033e57600080fd5b80638da5cb5b1461022557806395d89b4114610240578063a457c2d714610248578063a9059cbb1461025b578063b2520a7c1461026e57600080fd5b8063313ce5671161010a578063313ce567146101c057806339509351146101cf57806342966c68146101e257806370a08231146101f7578063715018a61461020a5780637eee288d1461021257600080fd5b80630635e3b41461014757806306fdde031461016d578063095ea7b31461018257806318160ddd146101a557806323b872dd146101ad575b600080fd5b61015a6101553660046112ad565b610351565b6040519081526020015b60405180910390f35b6101756103f9565b60405161016491906112cf565b61019561019036600461131d565b61048b565b6040519015158152602001610164565b60025461015a565b6101956101bb366004611347565b6104a2565b60405160128152602001610164565b6101956101dd36600461131d565b61054a565b6101f56101f0366004611383565b610586565b005b61015a6102053660046112ad565b610593565b6101f56105b1565b61019561022036600461131d565b610625565b6005546040516001600160a01b039091168152602001610164565b6101756106cd565b61019561025636600461131d565b6106dc565b61019561026936600461131d565b61075d565b61028161027c36600461131d565b6107e8565b60408051928352602083019190915201610164565b6101956102a43660046112ad565b61084f565b6102816102b73660046112ad565b6001600160a01b03166000908152600760209081526040808320546006909252909120549091565b61015a6102ed36600461139c565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6101956103263660046113cf565b610928565b6101956103393660046112ad565b610989565b6101f561034c3660046112ad565b610a10565b6001600160a01b038116600090815260208181526040808320546007835281842054600690935290832054909183918184101561038d57600080fd5b80156103da5760005b818110156103d8576000806103ab89846107e8565b915091504282116103c3576103c08187611418565b95505b505080806103d09061142b565b915050610396565b505b826103e58386611444565b6103ef9190611418565b9695505050505050565b60606003805461040890611457565b80601f016020809104026020016040519081016040528092919081815260200182805461043490611457565b80156104815780601f1061045657610100808354040283529160200191610481565b820191906000526020600020905b81548152906001019060200180831161046457829003601f168201915b5050505050905090565b6000610498338484610aec565b5060015b92915050565b6001600160a01b0383166000908152600660205260408120548490839080156104d0576104ce83610989565b505b6001600160a01b0383166000908152600760205260409020546104f4908390611418565b6001600160a01b03841660009081526020819052604090205410156105345760405162461bcd60e51b815260040161052b90611491565b60405180910390fd5b61053f878787610bfa565b979650505050505050565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610498918590610581908690611418565b610aec565b6105903382610c92565b50565b6001600160a01b03811660009081526020819052604081205461049c565b6005546001600160a01b031633146105db5760405162461bcd60e51b815260040161052b906114d6565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546000906001600160a01b031633146106525760405162461bcd60e51b815260040161052b906114d6565b6001600160a01b03831660009081526006602052604090205482106106b95760405162461bcd60e51b815260206004820152601d60248201527f5468657265206973206e6f206c6f636b20696e666f726d6174696f6e2e000000604482015260640161052b565b6106c38383610dc3565b5060019392505050565b60606004805461040890611457565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156107505760405162461bcd60e51b815260206004820152601e60248201527f44656372656173656420616c6c6f77616e63652062656c6f77207a65726f0000604482015260640161052b565b6106c33385858403610aec565b33600081815260066020526040812054909190839080156107835761078183610989565b505b6001600160a01b0383166000908152600760205260409020546107a7908390611418565b6001600160a01b03841660009081526020819052604090205410156107de5760405162461bcd60e51b815260040161052b90611491565b6103ef8686610f7e565b6001600160a01b0382166000908152600660205260408120805482918291859081106108165761081661150d565b60009182526020918290206040805180820190915260029092020180548083526001909101549190920181905290969095509350505050565b6005546000906001600160a01b0316331461087c5760405162461bcd60e51b815260040161052b906114d6565b6001600160a01b0382166000908152600660205260409020546108e15760405162461bcd60e51b815260206004820152601d60248201527f5468657265206973206e6f206c6f636b20696e666f726d6174696f6e2e000000604482015260640161052b565b6001600160a01b0382166000908152600660205260409020545b80156104985761091583610910600184611444565b610dc3565b508061092081611523565b9150506108fb565b6005546000906001600160a01b031633146109555760405162461bcd60e51b815260040161052b906114d6565b6001600160a01b03841661096857600080fd5b610973338585610f87565b61097e84848461112d565b506001949350505050565b6000805b6001600160a01b038316600090815260066020526040902054811015610498576001600160a01b03831660009081526006602052604090208054429190839081106109da576109da61150d565b90600052602060002090600202016000015410156109fe576109fc8382610dc3565b505b80610a088161142b565b91505061098d565b6005546001600160a01b03163314610a3a5760405162461bcd60e51b815260040161052b906114d6565b6001600160a01b038116610a905760405162461bcd60e51b815260206004820152601d60248201527f4e6577206f776e657220697320746865207a65726f2061646472657373000000604482015260640161052b565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610b425760405162461bcd60e51b815260206004820152601d60248201527f417070726f76652066726f6d20746865207a65726f2061646472657373000000604482015260640161052b565b6001600160a01b038216610b985760405162461bcd60e51b815260206004820152601b60248201527f417070726f766520746f20746865207a65726f20616464726573730000000000604482015260640161052b565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6000610c07848484610f87565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610c855760405162461bcd60e51b815260206004820152602160248201527f5472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636044820152606560f81b606482015260840161052b565b61097e8533858403610aec565b6001600160a01b038216610ce85760405162461bcd60e51b815260206004820152601a60248201527f4275726e2066726f6d20746865207a65726f2061646472657373000000000000604482015260640161052b565b6001600160a01b03821660009081526020819052604090205481811015610d515760405162461bcd60e51b815260206004820152601b60248201527f4275726e20616d6f756e7420657863656564732062616c616e63650000000000604482015260640161052b565b6001600160a01b0383166000908152602081905260408120838303905560028054849290610d80908490611444565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90602001610bed565b6001600160a01b0382166000908152600660205260408120805482919084908110610df057610df061150d565b90600052602060002090600202019050806001015460076000866001600160a01b03166001600160a01b0316815260200190815260200160002054610e359190611444565b6001600160a01b03851660008181526007602052604090819020929092556001830154915190917f6381d9813cabeb57471b5a7e05078e64845ccdb563146a6911d536f24ce960f191610e8a91815260200190565b60405180910390a26001600160a01b03841660009081526006602052604090208054610eb890600190611444565b81548110610ec857610ec861150d565b906000526020600020906002020160066000866001600160a01b03166001600160a01b031681526020019081526020016000208481548110610f0c57610f0c61150d565b60009182526020808320845460029093020191825560019384015493909101929092556001600160a01b0386168152600690915260409020805480610f5357610f5361153a565b6000828152602081206002600019909301928302018181556001908101919091559155949350505050565b60006104983384845b6001600160a01b038316610fdd5760405162461bcd60e51b815260206004820152601e60248201527f5472616e736665722066726f6d20746865207a65726f20616464726573730000604482015260640161052b565b6001600160a01b0382166110335760405162461bcd60e51b815260206004820152601c60248201527f5472616e7366657220746f20746865207a65726f206164647265737300000000604482015260640161052b565b6001600160a01b0383166000908152602081905260409020548181101561109c5760405162461bcd60e51b815260206004820152601f60248201527f5472616e7366657220616d6f756e7420657863656564732062616c616e636500604482015260640161052b565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906110d3908490611418565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161111f91815260200190565b60405180910390a350505050565b6001600160a01b0383166000908152600760205260408120546111509084611418565b6001600160a01b03851660009081526020819052604090205410156111cb5760405162461bcd60e51b815260206004820152602b60248201527f4c6f636b656420746f74616c2073686f756c6420626520736d616c6c6572207460448201526a68616e2062616c616e636560a81b606482015260840161052b565b6001600160a01b0384166000908152600760205260409020546111ef908490611418565b6001600160a01b0385166000818152600760209081526040808320949094556006815283822084518086018652878152808301898152825460018181018555938652939094209051600290930201918255915191015590517f49eaf4942f1237055eb4cfa5f31c9dfe50d5b4ade01e021f7de8be2fbbde557b9061127f9086908690918252602082015260400190565b60405180910390a25060019392505050565b80356001600160a01b03811681146112a857600080fd5b919050565b6000602082840312156112bf57600080fd5b6112c882611291565b9392505050565b600060208083528351808285015260005b818110156112fc578581018301518582016040015282016112e0565b506000604082860101526040601f19601f8301168501019250505092915050565b6000806040838503121561133057600080fd5b61133983611291565b946020939093013593505050565b60008060006060848603121561135c57600080fd5b61136584611291565b925061137360208501611291565b9150604084013590509250925092565b60006020828403121561139557600080fd5b5035919050565b600080604083850312156113af57600080fd5b6113b883611291565b91506113c660208401611291565b90509250929050565b6000806000606084860312156113e457600080fd5b6113ed84611291565b95602085013595506040909401359392505050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561049c5761049c611402565b60006001820161143d5761143d611402565b5060010190565b8181038181111561049c5761049c611402565b600181811c9082168061146b57607f821691505b60208210810361148b57634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526025908201527f43616e6e6f742073656e64206d6f7265207468616e20756e6c6f636b656420616040820152641b5bdd5b9d60da1b606082015260800190565b60208082526017908201527f43616c6c6572206973206e6f7420746865206f776e6572000000000000000000604082015260600190565b634e487b7160e01b600052603260045260246000fd5b60008161153257611532611402565b506000190190565b634e487b7160e01b600052603160045260246000fdfea26469706673582212207af7dfcecd567ee2bf54b740beffe85e0f9e73095318073e4d644ea8ed4319cc64736f6c63430008130033
Verified Source Code Partial Match
Compiler: v0.8.19+commit.7dd6d404
EVM: paris
Optimization: Yes (200 runs)
ParagonPay.sol 344 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.8.19;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
this;
return msg.data;
}
}
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor() {
address msgSender = _msgSender();
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
function owner() public view virtual returns (address) {
return _owner;
}
modifier onlyOwner() {
require(owner() == _msgSender(), "Caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "New owner is the zero address");
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
}
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);
}
interface IERC20Metadata is IERC20 {
function name() external view returns (string memory);
function symbol() external view returns (string memory);
function decimals() external view returns (uint8);
}
contract ERC20 is Context, IERC20, IERC20Metadata {
mapping(address => uint256) internal _balances;
mapping(address => mapping(address => uint256)) private _allowances;
uint256 private _totalSupply;
string private _name;
string private _symbol;
constructor(string memory name_, string memory symbol_) {
_name = name_;
_symbol = symbol_;
}
function name() public view virtual override returns (string memory) {
return _name;
}
function symbol() public view virtual override returns (string memory) {
return _symbol;
}
function decimals() public view virtual override returns (uint8) {
return 18;
}
function totalSupply() public view virtual override returns (uint256) {
return _totalSupply;
}
function balanceOf(address account) public view virtual override returns (uint256) {
return _balances[account];
}
function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(address owner, address spender) public view virtual override returns (uint256) {
return _allowances[owner][spender];
}
function approve(address spender, uint256 amount) public virtual override returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) public virtual override returns (bool) {
_transfer(sender, recipient, amount);
uint256 currentAllowance = _allowances[sender][_msgSender()];
require(currentAllowance >= amount, "Transfer amount exceeds allowance");
unchecked {
_approve(sender, _msgSender(), currentAllowance - amount);
}
return true;
}
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
uint256 currentAllowance = _allowances[_msgSender()][spender];
require(currentAllowance >= subtractedValue, "Decreased allowance below zero");
unchecked {
_approve(_msgSender(), spender, currentAllowance - subtractedValue);
}
return true;
}
function _transfer(
address sender,
address recipient,
uint256 amount
) internal virtual {
require(sender != address(0), "Transfer from the zero address");
require(recipient != address(0), "Transfer to the zero address");
_beforeTokenTransfer(sender, recipient, amount);
uint256 senderBalance = _balances[sender];
require(senderBalance >= amount, "Transfer amount exceeds balance");
unchecked {
_balances[sender] = senderBalance - amount;
}
_balances[recipient] += amount;
emit Transfer(sender, recipient, amount);
}
function _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "Mint to the zero address");
_beforeTokenTransfer(address(0), account, amount);
_totalSupply += amount;
_balances[account] += amount;
emit Transfer(address(0), account, amount);
}
function _burn(address account, uint256 amount) internal virtual {
require(account != address(0), "Burn from the zero address");
_beforeTokenTransfer(account, address(0), amount);
uint256 accountBalance = _balances[account];
require(accountBalance >= amount, "Burn amount exceeds balance");
unchecked {
_balances[account] = accountBalance - amount;
}
_totalSupply -= amount;
emit Transfer(account, address(0), amount);
}
function _approve(
address owner,
address spender,
uint256 amount
) internal virtual {
require(owner != address(0), "Approve from the zero address");
require(spender != address(0), "Approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
function _beforeTokenTransfer(
address from,
address to,
uint256 amount
) internal virtual {}
}
abstract contract ERC20Burnable is Context, ERC20, Ownable {
function burn(uint256 amount) public virtual {
_burn(_msgSender(), amount);
}
}
abstract contract ERC20Lockable is ERC20, Ownable {
struct LockInfo {
uint256 _releaseTime;
uint256 _amount;
}
mapping(address => LockInfo[]) internal _locks;
mapping(address => uint256) internal _totalLocked;
event Lock(address indexed from, uint256 amount, uint256 releaseTime);
event Unlock(address indexed from, uint256 amount);
modifier checkLock(address from, uint256 amount) {
uint256 length = _locks[from].length;
if (length > 0) {
autoUnlock(from);
}
require(_balances[from] >= _totalLocked[from] + amount, "Cannot send more than unlocked amount");
_;
}
function _lock(address from, uint256 amount, uint256 releaseTime) internal returns (bool success)
{
require(
_balances[from] >= amount + _totalLocked[from],
"Locked total should be smaller than balance"
);
_totalLocked[from] = _totalLocked[from] + amount;
_locks[from].push(LockInfo(releaseTime, amount));
emit Lock(from, amount, releaseTime);
success = true;
}
function _unlock(address from, uint256 index) internal returns (bool success) {
LockInfo storage info = _locks[from][index];
_totalLocked[from] = _totalLocked[from] - info._amount;
emit Unlock(from, info._amount);
_locks[from][index] = _locks[from][_locks[from].length - 1];
_locks[from].pop();
success = true;
}
function autoUnlock(address from) public returns (bool success) {
for (uint256 i = 0; i < _locks[from].length; i++) {
if (_locks[from][i]._releaseTime < block.timestamp) {
_unlock(from, i);
}
}
success = true;
}
function unlock(address from, uint256 idx) public onlyOwner returns (bool success) {
require(_locks[from].length > idx, "There is no lock information.");
_unlock(from, idx);
success = true;
}
function releaseLock(address from) external onlyOwner returns (bool success){
require(_locks[from].length > 0, "There is no lock information.");
for (uint256 i = _locks[from].length; i > 0; i--) {
_unlock(from, i - 1);
}
success = true;
}
function transferWithLock(address recipient, uint256 amount, uint256 releaseTime) external onlyOwner returns (bool success)
{
require(recipient != address(0));
_transfer(msg.sender, recipient, amount);
_lock(recipient, amount, releaseTime);
success = true;
}
function lockInfo(address locked, uint256 index) public view returns (uint256 releaseTime, uint256 amount)
{
LockInfo memory info = _locks[locked][index];
releaseTime = info._releaseTime;
amount = info._amount;
}
function totalLocked(address locked) public view returns (uint256 amount, uint256 length){
amount = _totalLocked[locked];
length = _locks[locked].length;
}
}
contract ParagonPay is ERC20, ERC20Burnable, ERC20Lockable {
constructor() ERC20("Paragon Pay", "PARAGON") {
_mint(msg.sender, 500000000 * (10 ** decimals()));
}
function transfer(address to, uint256 amount) public checkLock(msg.sender, amount) override returns (bool) {
return super.transfer(to, amount);
}
function transferFrom(address from, address to, uint256 amount) public checkLock(from, amount) override returns (bool) {
return super.transferFrom(from, to, amount);
}
function balanceOf(address holder) public view override returns (uint256 balance) {
balance = super.balanceOf(holder);
}
function balanceOfavaliable(address holder) public view returns (uint256 balance) {
uint256 totalBalance = super.balanceOf(holder);
uint256 avaliableBalance = 0;
(uint256 lockedBalance, uint256 lockedLength) = totalLocked(holder);
require(totalBalance >= lockedBalance);
if (lockedLength > 0) {
for (uint i = 0; i < lockedLength; i++) {
(uint256 releaseTime, uint256 amount) = lockInfo(holder, i);
if (releaseTime <= block.timestamp) {
avaliableBalance += amount;
}
}
}
balance = totalBalance - lockedBalance + avaliableBalance;
}
function _beforeTokenTransfer(
address from,
address to,
uint256 amount
)
internal override {
super._beforeTokenTransfer(from, to, amount);
}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
balanceOfavaliable 0x0635e3b4 → uint256
decimals 0x313ce567 → uint8
lockInfo 0xb2520a7c → uint256, uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalLocked 0xd8fb9337 → uint256, uint256
totalSupply 0x18160ddd → uint256
Write Contract 12 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
autoUnlock 0xe20bc67b
address from
returns: bool
burn 0x42966c68
uint256 amount
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
releaseLock 0xd1c46916
address from
returns: bool
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
transferWithLock 0xde6baccb
address recipient
uint256 amount
uint256 releaseTime
returns: bool
unlock 0x7eee288d
address from
uint256 idx
returns: bool
Recent Transactions
No transactions found for this address