Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xfe65601137c67537789Ce33fa0D49Df10F974F5E
Balance 0 ETH
Nonce 1
Code Size 5510 bytes
Indexed Transactions 0
External Etherscan · Sourcify

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