Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xCcbA0b2bc4BAbe4cbFb6bD2f1Edc2A9e86b7845f
Balance 0 ETH
Nonce 1
Code Size 5538 bytes
Last Active
Indexed Transactions 12 (24,179,49024,315,744)
Gas Used (indexed) 730,812
External Etherscan · Sourcify

Contract Bytecode

5538 bytes
0x608060405234801561001057600080fd5b50600436106102485760003560e01c806379ba50971161013b578063cea3e530116100b8578063ef08fc6e1161007c578063ef08fc6e14610363578063f2fde38b14610507578063f65036621461051a578063f77e180e1461052d578063f79875461461053757600080fd5b8063cea3e53014610479578063d390a1e4146104a0578063d4ee1d90146104a8578063dc39d06d146104bb578063dd62ed3e146104ce57600080fd5b80639fb68299116100ff5780639fb6829914610425578063a0712d6814610438578063a9059cbb1461044b578063aa3308bd1461045e578063c2d98c6e1461047157600080fd5b806379ba5097146103a95780638da5cb5b146103b35780638f759183146103de578063902d55a5146103f157806395d89b411461040357600080fd5b8063313ce567116101c95780634ef376281161018d5780634ef376281461035b57806357dd62fb146103635780635dbdda691461036e5780636de9f32b1461037757806370a082311461038057600080fd5b8063313ce5671461032b57806332e997081461033257806336bcf7d61461033a578063490203a71461034a5780634a1da80e1461035257600080fd5b806317da485f1161021057806317da485f146102db5780631801fbe5146102e357806318160ddd146102f657806323b872dd146102fe5780632e0f26251461031157600080fd5b8063031052f31461024d578063068a24951461026b57806306fdde031461028e578063095ea7b3146102bf5780630d97a2fb146102d2575b600080fd5b610258600160ea1b81565b6040519081526020015b60405180910390f35b61027e610279366004611190565b61053f565b6040519015158152602001610262565b60408051808201909152600c81526b2bb4b73a32b9102a37b5b2b760a11b60208201525b604051610262919061134c565b61027e6102cd366004611133565b6105a0565b61025860035481565b610258610645565b61027e6102f13660046112a0565b61065f565b600654610258565b61027e61030c3660046110f7565b610734565b610319601281565b60405160ff9091168152602001610262565b6012610319565b600554610258565b6102586805b12aefafa804000081565b610258610874565b61025860025481565b600454610258565b6102586305a39a8081565b61025861025881565b61025860065481565b61025861038e3660046110a9565b6001600160a01b031660009081526007602052604090205490565b6103b1610886565b005b6000546103c6906001600160a01b031681565b6040516001600160a01b039091168152602001610262565b6102586103ec366004611287565b610901565b6102586a1b63e87c1f629e3f80000081565b6040805180820190915260068152652ba4a72a22a960d11b60208201526102b2565b6102586104333660046112a0565b610912565b61027e610446366004611287565b610948565b61027e610459366004611133565b610b14565b61025861046c366004611287565b610bec565b610258600481565b6102587f0000000000000000000000000000000000000000000000000000000061349d3681565b610258604881565b6001546103c6906001600160a01b031681565b61027e6104c9366004611133565b610c5b565b6102586104dc3660046110c4565b6001600160a01b03918216600090815260086020908152604080832093909416825291909152205490565b6103b16105153660046110a9565b610cf9565b61027e61052836600461115d565b610d58565b6102586201000081565b610258610da4565b3360009081526008602090815260408083206001600160a01b0388168452909152812054841461058a5760405162461bcd60e51b815260040161058190611388565b60405180910390fd5b610595858484610db6565b90505b949350505050565b60006001600160a01b038316158015906105c357506001600160a01b0383163014155b6105df5760405162461bcd60e51b81526004016105819061135f565b3360008181526008602090815260408083206001600160a01b03881680855290835292819020869055518581529192917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a35060015b92915050565b6005546000906000199061065990826113fd565b91505090565b6004546040805160208101929092526bffffffffffffffffffffffff193360601b169082015260548101839052600090819060740160405160208183030381529060405280519060200120905082811461072b5760405162461bcd60e51b815260206004820152604160248201527f4368616c6c656e67652064696765737420646f6573206e6f74206d617463682060448201527f657870656374656420646967657374206f6e20746f6b656e20636f6e747261636064820152601d60fa1b608482015260a401610581565b61059884610948565b60006001600160a01b0383161580159061075757506001600160a01b0383163014155b6107735760405162461bcd60e51b81526004016105819061135f565b6001600160a01b038416600090815260076020526040902054610797908390611529565b6001600160a01b03851660009081526007602090815260408083209390935560088152828220338352905220546107cf908390611529565b6001600160a01b03808616600090815260086020908152604080832033845282528083209490945591861681526007909152205461080e9083906113e5565b6001600160a01b0380851660008181526007602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906108629086815260200190565b60405180910390a35060019392505050565b6000610881600254610ebe565b905090565b6001546001600160a01b0316331461089d57600080fd5b600154600080546040516001600160a01b0393841693909116917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a360018054600080546001600160a01b03199081166001600160a01b03841617909155169055565b600061063f60025460035484610ee7565b6000806109328460055461092691906113fd565b60025460035486610f27565b90508061093e84610ebe565b610598919061150a565b6002546000908161095882610ebe565b9050806109a75760405162461bcd60e51b815260206004820152601760248201527f526577617264206861732072656163686564207a65726f0000000000000000006044820152606401610581565b600454604080516020808201939093523360601b6bffffffffffffffffffffffff1916818301526054808201889052825180830390910181526074909101909152805191012060055480821115610a4c5760405162461bcd60e51b815260206004820152602360248201527f446967657374206973206c6172676572207468616e206d696e696e672074617260448201526219d95d60ea1b6064820152608401610581565b6003546000610a66610a5e85856113fd565b878442610f27565b90506000610a74828761150a565b90506000610a8182610f48565b9050610a8d8385610f8b565b610a9985898542610f9c565b6005556000610aa78261103b565b600481905542600281905590915033907fcf6fbb9dcea7d07263ab4f5c3a92f53af33dffc421d9d121e1c74b307e68189d908590610ae490611054565b604080519283526020830191909152810184905260600160405180910390a25060019a9950505050505050505050565b60006001600160a01b03831615801590610b3757506001600160a01b0383163014155b610b535760405162461bcd60e51b81526004016105819061135f565b33600090815260076020526040902054610b6e908390611529565b33600090815260076020526040808220929092556001600160a01b03851681522054610b9b9083906113e5565b6001600160a01b0384166000818152600760205260409081902092909255905133907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906106339086815260200190565b600080610c197f0000000000000000000000000000000000000000000000000000000061349d3684611529565b90506305a39a80811015610c305750600092915050565b6305a39a80610c3f8183611529565b610c4991906113fd565b610c549060016113e5565b9392505050565b600080546001600160a01b03163314610c7357600080fd5b60005460405163a9059cbb60e01b81526001600160a01b039182166004820152602481018490529084169063a9059cbb90604401602060405180830381600087803b158015610cc157600080fd5b505af1158015610cd5573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c549190611265565b6000546001600160a01b03163314610d1057600080fd5b6001600160a01b038116610d365760405162461bcd60e51b81526004016105819061135f565b600180546001600160a01b0319166001600160a01b0392909216919091179055565b3360009081526008602090815260408083206001600160a01b03871684529091528120548314610d9a5760405162461bcd60e51b815260040161058190611388565b61059884836105a0565b6000600354610258610881919061150a565b60006001600160a01b03841615801590610dd957506001600160a01b0384163014155b610df55760405162461bcd60e51b81526004016105819061135f565b3360008181526008602090815260408083206001600160a01b03891680855290835292819020879055518681529192917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3604051638f4ffcb160e01b81526001600160a01b03851690638f4ffcb190610e8290339087903090889060040161130f565b600060405180830381600087803b158015610e9c57600080fd5b505af1158015610eb0573d6000803e3d6000fd5b506001979650505050505050565b6000610ec982610bec565b610ed4906002611462565b61063f906805b12aefafa80400006113fd565b60008281610258610ef88786611529565b610f0291906113fd565b905081811115610f10578091505b6048821115610f1e57604891505b50949350505050565b600080610f35858585610ee7565b9050808610156105955785915050610598565b33600090815260076020526040812080548391908390610f699084906113e5565b9091555050600654600090610f7f9084906113e5565b60068190559392505050565b808214610f985760038290555b5050565b600080610fa98584611529565b9050610fb76102588561150a565b610fc290603d61150a565b610fcd82605861150a565b1015610ff1576064610fe087606361150a565b610fea91906113fd565b955061100b565b6063610ffe87606461150a565b61100891906113fd565b95505b6201000086101561101d576201000095505b600160ea1b86111561103157600160ea1b95505b5093949350505050565b600060048261104b600143611529565b40181892915050565b60006102586110837f0000000000000000000000000000000000000000000000000000000061349d3684611529565b61063f91906113fd565b80356001600160a01b03811681146110a457600080fd5b919050565b6000602082840312156110bb57600080fd5b610c548261108d565b600080604083850312156110d757600080fd5b6110e08361108d565b91506110ee6020840161108d565b90509250929050565b60008060006060848603121561110c57600080fd5b6111158461108d565b92506111236020850161108d565b9150604084013590509250925092565b6000806040838503121561114657600080fd5b61114f8361108d565b946020939093013593505050565b60008060006060848603121561117257600080fd5b61117b8461108d565b95602085013595506040909401359392505050565b600080600080608085870312156111a657600080fd5b6111af8561108d565b93506020850135925060408501359150606085013567ffffffffffffffff808211156111da57600080fd5b818701915087601f8301126111ee57600080fd5b81358181111561120057611200611556565b604051601f8201601f19908116603f0116810190838211818310171561122857611228611556565b816040528281528a602084870101111561124157600080fd5b82602086016020830137600060208483010152809550505050505092959194509250565b60006020828403121561127757600080fd5b81518015158114610c5457600080fd5b60006020828403121561129957600080fd5b5035919050565b600080604083850312156112b357600080fd5b50508035926020909101359150565b6000815180845260005b818110156112e8576020818501810151868301820152016112cc565b818111156112fa576000602083870101525b50601f01601f19169290920160200192915050565b6001600160a01b0385811682526020820185905283166040820152608060608201819052600090611342908301846112c2565b9695505050505050565b602081526000610c5460208301846112c2565b6020808252600f908201526e496e76616c6964206164647265737360881b604082015260600190565b60208082526038908201527f43757272656e74207370656e64657220616c6c6f77616e636520646f6573206e60408201527f6f74206d61746368207370656369666965642076616c75650000000000000000606082015260800190565b600082198211156113f8576113f8611540565b500190565b60008261141a57634e487b7160e01b600052601260045260246000fd5b500490565b600181815b8085111561145a57816000190482111561144057611440611540565b8085161561144d57918102915b93841c9390800290611424565b509250929050565b6000610c5483836000826114785750600161063f565b816114855750600061063f565b816001811461149b57600281146114a5576114c1565b600191505061063f565b60ff8411156114b6576114b6611540565b50506001821b61063f565b5060208310610133831016604e8410600b84101617156114e4575081810a61063f565b6114ee838361141f565b806000190482111561150257611502611540565b029392505050565b600081600019048311821515161561152457611524611540565b500290565b60008282101561153b5761153b611540565b500390565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052604160045260246000fdfea2646970667358221220675ac9516343bf5e254dc38eb10f6377b12932588d9091dacac9e60d7d6bc65a64736f6c63430008050033

Verified Source Code Partial Match

Compiler: v0.8.5+commit.a4f2e591 EVM: berlin Optimization: Yes (200 runs)
ERC20.sol 34 lines
    //SPDX-License-Identifier: MIT
    pragma solidity 0.8.5;


    // ----------------------------------------------------------------------------

    // ERC Token Standard #20 Interface

    // https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20-token-standard.md

    // ----------------------------------------------------------------------------

    abstract contract ERC20Interface {

        function totalSupply() public view virtual returns (uint);

        function balanceOf(address tokenOwner) public view virtual returns (uint balance);

        function allowance(address tokenOwner, address spender) public view virtual returns (uint remaining);

        function transfer(address to, uint tokens) public virtual returns (bool success);

        function approve(address spender, uint tokens) public virtual returns (bool success);

        function transferFrom(address from, address to, uint tokens) public virtual returns (bool success);


        event Transfer(address indexed from, address indexed to, uint tokens);

        event Approval(address indexed tokenOwner, address indexed spender, uint tokens);

    }


Owned.sol 59 lines
    //SPDX-License-Identifier: MIT
    pragma solidity 0.8.5;



    // ----------------------------------------------------------------------------

    // Owned contract

    // ----------------------------------------------------------------------------

    abstract contract Owned {

        address public owner;

        address public newOwner;


        event OwnershipTransferred(address indexed _from, address indexed _to);


        constructor() {

            owner = msg.sender;

        }


        modifier onlyOwner {

            require(msg.sender == owner);

            _;

        }


        function transferOwnership(address _newOwner) public onlyOwner {

            require(_newOwner != address(0), "Invalid address");

            newOwner = _newOwner;

        }

        function acceptOwnership() external {

            require(msg.sender == newOwner);

            emit OwnershipTransferred(owner, newOwner);

            owner = newOwner;

            newOwner = address(0);

        }

    }

ERC918.sol 31 lines
    //SPDX-License-Identifier: MIT
    pragma solidity 0.8.5;


    // ----------------------------------------------------------------------------

    // ERC Token Standard #918 Interface

    // https://eips.ethereum.org/EIPS/eip-918

    // ----------------------------------------------------------------------------

    interface ERC918  {

        function mint(uint256 nonce) external returns (bool success);

        function getAdjustmentInterval() external view returns (uint);

        function getChallengeNumber() external view returns (bytes32);

        function getMiningDifficulty() external view returns (uint);

        function getMiningTarget() external view returns (uint);

        function getMiningReward() external view returns (uint);
       
        function decimals() external view returns (uint8);


        event Mint(address indexed from, uint rewardAmount, uint epochCount, bytes32 newChallengeNumber);
    }
WinterToken.sol 498 lines
//SPDX-License-Identifier: MIT
pragma solidity 0.8.5;


import "./ERC20.sol";
import "./ERC918.sol";
import "./Owned.sol";
import "./ApproveAndCallFallBack.sol";


// ----------------------------------------------------------------------------

// 'Winter Token' contract

// ERC20 & ERC918 Mineable Token using Proof Of Work

// Symbol      : WINTER

// Name        : Winter Token

// Total supply: 33,112,800.00

// Decimals    : 18

// Initial mining reward: 105

// Fraction of total supply released before first halving: 1/2

// ----------------------------------------------------------------------------





contract WinterToken is ERC20Interface, ERC918, Owned {

    string private constant SYMBOL = "WINTER";

    string private constant NAME = "Winter Token";

    uint256 public constant TOKEN_IDENTIFIER = 4;

    uint8 public constant DECIMALS = 18;

    uint256 public constant TOTAL_SUPPLY = 33112800 * 10**18;

    uint256 public constant INITIAL_REWARD = 105 * 10**18;

    uint256 public constant MAX_REWARDS_AVAILABLE = 72; // no more than 72 rewards per mint

    uint256 public constant REWARD_INTERVAL = 600; // rewards every ten minutes on average

    uint256 public constant DURATION_OF_FIRST_ERA = (365 * 24 * 60 * 60 * 3); // 36 months

    uint256 public constant DURATION_OF_ERA = 3 * 365 * 24 * 60 * 60; // three years

    uint256 public constant MINIMUM_TARGET = 2**16;

    uint256 public constant MAXIMUM_TARGET = 2**234;

    uint256 public immutable contractCreationTime;

    uint256 public lastRewardBlockTime;

    uint256 public maxNumberOfRewardsPerMint;

    bytes32 private challengeNumber;
        
    uint256 private miningTarget;

    uint256 public tokensMinted;

    mapping(address => uint256) internal balances;

    mapping(address => mapping(address => uint256)) internal allowed;


    constructor() {

        miningTarget = MAXIMUM_TARGET / 2**19;

        contractCreationTime = block.timestamp;
        lastRewardBlockTime = block.timestamp;

        maxNumberOfRewardsPerMint = 1;

        challengeNumber = _getNewChallengeNumber(0);

    }

    function name() public pure returns (string memory) {
        return NAME;
    }

    function symbol() public pure returns (string memory) {
        return SYMBOL;
    }

    function mint(uint256 nonce) override public returns (bool success) {

        uint256 _lastRewardBlockTime = lastRewardBlockTime;
        
        uint256 singleRewardAmount = _getMiningReward(_lastRewardBlockTime);

        // no more minting when reward reaches zero
        if (singleRewardAmount == 0) revert("Reward has reached zero");

        // the PoW must contain work that includes the challenge number and the msg.sender's address
        bytes32 digest =  keccak256(abi.encodePacked(challengeNumber, msg.sender, nonce));

        uint256 _miningTarget = miningTarget;
        // the digest must be smaller than the target
        if (uint256(digest) > _miningTarget) revert("Digest is larger than mining target");

        uint256 _previousMaxNumberOfRewards = maxNumberOfRewardsPerMint;
        uint256 numberOfRewardsToGive = _numberOfRewardsToGive(_miningTarget / uint256(digest), 
                                                               _lastRewardBlockTime,
                                                               _previousMaxNumberOfRewards,
                                                               block.timestamp);
        uint256 totalRewardAmount = singleRewardAmount * numberOfRewardsToGive;

        uint256 _tokensMinted = _giveRewards(totalRewardAmount);
        
        _setNextMaxNumberOfRewards(numberOfRewardsToGive, _previousMaxNumberOfRewards);

        miningTarget = _adjustDifficulty(_miningTarget, _lastRewardBlockTime,
                                         numberOfRewardsToGive, block.timestamp);

        bytes32 newChallengeNumber = _getNewChallengeNumber(_tokensMinted);
        challengeNumber = newChallengeNumber;

        lastRewardBlockTime = block.timestamp;

        emit Mint(msg.sender, totalRewardAmount, _scheduledNumberOfRewards(block.timestamp), 
                  newChallengeNumber);

        return true;
    }

    function _numberOfRewardsAvailable(uint256 _lastRewardBlockTime, 
                                       uint256 _previousMaxNumberOfRewards, 
                                       uint256 currentTime) internal pure returns (uint256) {

        uint256 numberAvailable = _previousMaxNumberOfRewards;
        uint256 intervalsSinceLastReward = (currentTime - _lastRewardBlockTime) / REWARD_INTERVAL;
        
        if (intervalsSinceLastReward > numberAvailable)
            numberAvailable = intervalsSinceLastReward;

        if (numberAvailable > MAX_REWARDS_AVAILABLE)
            numberAvailable = MAX_REWARDS_AVAILABLE;

        return numberAvailable;
    }

    function _numberOfRewardsToGive(uint256 numberEarned, uint256 _lastRewardBlockTime, 
                                    uint256 _previousMaxNumberOfRewards,
                                    uint256 currentTime) internal pure returns (uint256) {

        uint256 numberAvailable = _numberOfRewardsAvailable(_lastRewardBlockTime,
                                                         _previousMaxNumberOfRewards,
                                                         currentTime);
        if (numberEarned < numberAvailable)
            return numberEarned;

        return numberAvailable;
    }

    function _giveRewards(uint256 totalReward) internal returns (uint256) {

        balances[msg.sender] += totalReward;
        uint256 _tokensMinted = tokensMinted + totalReward;
        tokensMinted = _tokensMinted;
        return _tokensMinted;
    }

    function _setNextMaxNumberOfRewards(uint256 numberOfRewardsGivenNow, 
                                        uint256 _previousMaxNumberOfRewards) internal {

        // the value of the rewards given to this miner presumably exceed the gas costs
        // for processing the transaction. the next miner can submit a proof of enough work
        // to claim up to the same number of rewards immediately, or, if gas costs have increased,
        // wait until the maximum number of rewards claimable has increased enough to overcome
        // the costs.

        if (numberOfRewardsGivenNow != _previousMaxNumberOfRewards)
            maxNumberOfRewardsPerMint = numberOfRewardsGivenNow;
    }

    // backwards compatible mint function
    function mint(uint256 _nonce, bytes32 _challengeDigest) external returns (bool) {

        bytes32 digest = keccak256(abi.encodePacked(challengeNumber, msg.sender, _nonce));
        require(digest == _challengeDigest, "Challenge digest does not match expected digest on token contract");
        
        return mint(_nonce);
    }

    function _getNewChallengeNumber(uint256 _tokensMinted) internal view returns (bytes32) {
        
        // make the latest ethereum block hash a part of the next challenge

        // xor with a number unique to this token to avoid merged mining
        
        // xor with the number of tokens minted to ensure that the challenge changes
        // even if there are multiple mints in the same ethereum block
        
        return bytes32(uint256(blockhash(block.number - 1)) ^ _tokensMinted ^ TOKEN_IDENTIFIER);
    }


    function _scheduledNumberOfRewards(uint256 currentTime) internal view returns (uint256) {
        return (currentTime - contractCreationTime) / REWARD_INTERVAL;
    }

    function _adjustDifficulty(uint256 _miningTarget, 
                               uint256 _lastRewardBlockTime, 
                               uint256 rewardsGivenNow,
                               uint256 currentTime) internal pure returns (uint256){

        uint256 timeSinceLastReward = currentTime - _lastRewardBlockTime;

        // we target a median interval of 10 minutes multiplied by log(2) ~ 61/88 
        // this gives a mean interval of 10 minutes per reward

        if (timeSinceLastReward * 88 < rewardsGivenNow * REWARD_INTERVAL * 61)
            _miningTarget = (_miningTarget * 99) / 100;   // slow down
        else
            _miningTarget = (_miningTarget * 100) / 99;   // speed up

        if (_miningTarget < MINIMUM_TARGET)
            _miningTarget = MINIMUM_TARGET;
        
        if (_miningTarget > MAXIMUM_TARGET) 
            _miningTarget = MAXIMUM_TARGET;

        return _miningTarget;
    }


    function rewardEra(uint256 _time) public view returns (uint256) {

        uint256 timeSinceContractCreation = _time - contractCreationTime;

        if (timeSinceContractCreation < DURATION_OF_FIRST_ERA)
            return 0;
        else
            return 1 + (timeSinceContractCreation - DURATION_OF_FIRST_ERA) / DURATION_OF_ERA;
    }

    function getAdjustmentInterval() public view override returns (uint256) {
        return REWARD_INTERVAL * maxNumberOfRewardsPerMint;
    }

    function getChallengeNumber() public view override returns (bytes32) {
        return challengeNumber;
    }

    function getMiningDifficulty() public view override returns (uint256) {
        // 64 f's:         1234567890123456789012345678901234567890123456789012345678901234
        uint256 maxInt = 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff;
        return maxInt / miningTarget;
    }

    function getMiningTarget() public view override returns (uint256) {
       return miningTarget;
   }

    function getMiningReward() public view override returns (uint256) {

        // use the timestamp of the ethereum block that gave the last reward
        // because ethereum miners can manipulate the value of block.timestamp
        return _getMiningReward(lastRewardBlockTime);
    }

    function _getMiningReward(uint256 _time) internal view returns (uint256) {
        return INITIAL_REWARD / 2**rewardEra(_time);
    }

    function getNumberOfRewardsAvailable(uint256 currentTime) external view returns (uint256) {
        return _numberOfRewardsAvailable(lastRewardBlockTime, 
                                         maxNumberOfRewardsPerMint, 
                                         currentTime);
    }

    function getRewardAmountForAchievingTarget(uint256 targetAchieved, uint256 currentTime) external view returns (uint256) {
        uint256 numberOfRewardsToGive = _numberOfRewardsToGive(miningTarget / targetAchieved, 
                                                               lastRewardBlockTime, 
                                                               maxNumberOfRewardsPerMint, 
                                                               currentTime);
        return _getMiningReward(currentTime) * numberOfRewardsToGive;
    }

    function decimals() public pure override returns (uint8) {
        return DECIMALS;
    }

    function totalSupply() public view override returns (uint256) {

        return tokensMinted;
    }


    // ------------------------------------------------------------------------

    // Get the token balance for account `tokenOwner`

    // ------------------------------------------------------------------------

    function balanceOf(address tokenOwner) public view override returns (uint256 balance) {

        return balances[tokenOwner];

    }



    // ------------------------------------------------------------------------

    // Transfer the balance from token owner's account to `to` account

    // - Owner's account must have sufficient balance to transfer

    // - 0 value transfers are allowed

    // ------------------------------------------------------------------------

    function transfer(address to, uint256 tokens) public override returns (bool success) {
        
        require(to != address(0) && to != address(this), "Invalid address");
        
        balances[msg.sender] = balances[msg.sender] - tokens;

        balances[to] = balances[to] + tokens;

        emit Transfer(msg.sender, to, tokens);

        return true;

    }



    // ------------------------------------------------------------------------

    // Token owner can approve for `spender` to transferFrom(...) `tokens`

    // from the token owner's account

    //

    // Warning: This function is vulnerable to double-spend attacks and is

    // included for backwards compatibility. Use safeApprove instead.

    // ------------------------------------------------------------------------

    function approve(address spender, uint256 tokens) public override returns (bool success) {
        
        require(spender != address(0) && spender != address(this), "Invalid address");

        allowed[msg.sender][spender] = tokens;

        emit Approval(msg.sender, spender, tokens);

        return true;

    }



    // ------------------------------------------------------------------------

    // Allow token owner to cancel the approval if the approved amount changes from its last

    // known value before this transaction is processed. This allows the owner to avoid 

    // unintentionally re-approving funds that have already been spent.

    // ------------------------------------------------------------------------

    function safeApprove(address spender, uint256 previousAllowance, uint256 newAllowance) external returns (bool success) {

        require(allowed[msg.sender][spender] == previousAllowance,
                "Current spender allowance does not match specified value");

        return approve(spender, newAllowance);
    }



    // ------------------------------------------------------------------------

    // Transfer `tokens` from the `from` account to the `to` account

    //

    // The calling account must already have sufficient tokens approve(...)-d

    // for spending from the `from` account and

    // - From account must have sufficient balance to transfer

    // - Spender must have sufficient allowance to transfer

    // - 0 value transfers are allowed

    // ------------------------------------------------------------------------

    function transferFrom(address from, address to, uint256 tokens) public override returns (bool success) {
        
        require(to != address(0) && to != address(this), "Invalid address");

        balances[from] = balances[from] - tokens;

        allowed[from][msg.sender] = allowed[from][msg.sender] - tokens;

        balances[to] = balances[to] + tokens;

        emit Transfer(from, to, tokens);

        return true;

    }



    // ------------------------------------------------------------------------

    // Returns the amount of tokens approved by the owner that can be

    // transferred to the spender's account

    // ------------------------------------------------------------------------

    function allowance(address tokenOwner, address spender) public view override returns (uint256 remaining){

        return allowed[tokenOwner][spender];

    }


    // ------------------------------------------------------------------------

    // Token owner can approve for `spender` to transferFrom(...) `tokens`

    // from the token owner's account. The `spender` contract function

    // `receiveApproval(...)` is then executed. This is vulnerable to double-spend attacks

    // when called directly, so it is declared internal and called by safeApproveAndCall

    // ------------------------------------------------------------------------

    function approveAndCall(address spender, uint256 tokens, bytes memory data) internal returns (bool success) {
        
        require(spender != address(0) && spender != address(this), "Invalid address");

        allowed[msg.sender][spender] = tokens;

        emit Approval(msg.sender, spender, tokens);

        ApproveAndCallFallBack(spender).receiveApproval(msg.sender, tokens, address(this), data);

        return true;

    }


    // ------------------------------------------------------------------------

    // Allow safe approvals with calls to receiving contract

    // ------------------------------------------------------------------------

    function safeApproveAndCall(address spender, uint256 previousAllowance, 
                                uint256 newAllowance, bytes memory data) external returns (bool success) {

        require(allowed[msg.sender][spender] == previousAllowance,
                "Current spender allowance does not match specified value");

        return approveAndCall(spender, newAllowance, data);
    }


    // ------------------------------------------------------------------------

    // Owner can transfer out any accidentally sent ERC20 tokens

    // ------------------------------------------------------------------------

    function transferAnyERC20Token(address tokenAddress, uint256 tokens) external onlyOwner returns (bool success) {

        return ERC20Interface(tokenAddress).transfer(owner, tokens);

    }

}
ApproveAndCallFallBack.sol 19 lines
    //SPDX-License-Identifier: MIT
    pragma solidity 0.8.5;



    // ----------------------------------------------------------------------------

    // Contract function to receive approval and execute function in one call

    // Borrowed from MiniMeToken

    // ----------------------------------------------------------------------------

    abstract contract ApproveAndCallFallBack {

        function receiveApproval(address from, uint256 tokens, address token, bytes memory data) public virtual ;

    }

Read Contract

DECIMALS 0x2e0f2625 → uint8
DURATION_OF_ERA 0x57dd62fb → uint256
DURATION_OF_FIRST_ERA 0xef08fc6e → uint256
INITIAL_REWARD 0x36bcf7d6 → uint256
MAXIMUM_TARGET 0x031052f3 → uint256
MAX_REWARDS_AVAILABLE 0xd390a1e4 → uint256
MINIMUM_TARGET 0xf77e180e → uint256
REWARD_INTERVAL 0x5dbdda69 → uint256
TOKEN_IDENTIFIER 0xc2d98c6e → uint256
TOTAL_SUPPLY 0x902d55a5 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
contractCreationTime 0xcea3e530 → uint256
decimals 0x313ce567 → uint8
getAdjustmentInterval 0xf7987546 → uint256
getChallengeNumber 0x4ef37628 → bytes32
getMiningDifficulty 0x17da485f → uint256
getMiningReward 0x490203a7 → uint256
getMiningTarget 0x32e99708 → uint256
getNumberOfRewardsAvailable 0x8f759183 → uint256
getRewardAmountForAchievingTarget 0x9fb68299 → uint256
lastRewardBlockTime 0x4a1da80e → uint256
maxNumberOfRewardsPerMint 0x0d97a2fb → uint256
name 0x06fdde03 → string
newOwner 0xd4ee1d90 → address
owner 0x8da5cb5b → address
rewardEra 0xaa3308bd → uint256
symbol 0x95d89b41 → string
tokensMinted 0x6de9f32b → uint256
totalSupply 0x18160ddd → uint256

Write Contract 10 functions

These functions modify contract state and require a wallet transaction to execute.

acceptOwnership 0x79ba5097
No parameters
approve 0x095ea7b3
address spender
uint256 tokens
returns: bool
mint 0x1801fbe5
uint256 _nonce
bytes32 _challengeDigest
returns: bool
mint 0xa0712d68
uint256 nonce
returns: bool
safeApprove 0xf6503662
address spender
uint256 previousAllowance
uint256 newAllowance
returns: bool
safeApproveAndCall 0x068a2495
address spender
uint256 previousAllowance
uint256 newAllowance
bytes data
returns: bool
transfer 0xa9059cbb
address to
uint256 tokens
returns: bool
transferAnyERC20Token 0xdc39d06d
address tokenAddress
uint256 tokens
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 tokens
returns: bool
transferOwnership 0xf2fde38b
address _newOwner

Top Interactions

Recent Transactions

CSV View All 12 Transactions →
|
Hash Method Block Age From/To Value Txn Fee Type
0xad2f31e9...70e373 0x068a2495 24,315,744 IN 0x72187bc0...1098 0 ETH 0.000006766096 ETH Legacy
0xade5aab5...63c7b5 0x068a2495 24,308,473 IN 0x72187bc0...1098 0 ETH 0.000003025573 ETH Legacy
0xb414f4c0...e2e01b approve 24,308,205 IN 0xF9f29343...f434 0 ETH 0.000002612304 ETH EIP-1559
0x24b13250...103e15 0x068a2495 24,286,985 IN 0x72187bc0...1098 0 ETH 0.000003171121 ETH Legacy
0x80ac279f...5ea15f 0x068a2495 24,251,120 IN 0x72187bc0...1098 0 ETH 0.000002899980 ETH Legacy
0x4d98ba4c...ddd4dd 0x068a2495 24,243,948 IN 0x72187bc0...1098 0 ETH 0.000003870149 ETH Legacy
0xa6f89d94...4f5503 approve 24,214,175 IN 0x43480914...cfE6 0 ETH 0.000001651752 ETH EIP-1559
0x4706fbaa...e53656 approve 24,212,744 IN 0x9F642617...05F2 0 ETH 0.000004943027 ETH EIP-1559
0x047d8195...5b60ef 0x068a2495 24,208,115 IN 0x72187bc0...1098 0 ETH 0.000002718702 ETH Legacy
0x954002be...009d1b 0x068a2495 24,179,490 IN 0x72187bc0...1098 0 ETH 0.000003033550 ETH Legacy