Contract 0x01e9b35785ef3f7ef2677c371442976bd550f320 1

Txn Hash Method
Block
From
To
Value [Txn Fee]
0x88710918410d79f4ea7bc00874d16894a172693c5e0155059d01361581b67e30Set Gov580466242023-03-21 10:07:1471 days 8 hrs agoMummy Finance: Deployer IN  0x01e9b35785ef3f7ef2677c371442976bd550f3200 FTM0.0403155
0x484f58bc9bd0c7f06fddfb3d19883790da7eeb8fe73bbc2364309fc47eda60bdSet Is Price Fee...580465602023-03-21 10:05:2871 days 8 hrs agoMummy Finance: Deployer IN  0x01e9b35785ef3f7ef2677c371442976bd550f3200 FTM0.0364185
0xaf24b9cd627bec00007e0d59ed1ce34e009e1c65a6787c4d334bc2bbb488b38dSet Is Price Fee...577617472023-03-17 8:50:5275 days 10 hrs agoMummy Finance: Deployer IN  0x01e9b35785ef3f7ef2677c371442976bd550f3200 FTM0.0692685
0xc9e6912baedd8e127a99cd7c1036bcae195512ceb729943a2f2b7a9735cd8007Set Gov520540822022-12-09 8:32:53173 days 10 hrs agoMummy Finance: Deployer IN  0x01e9b35785ef3f7ef2677c371442976bd550f3200 FTM0.00134385
0x7e231bd4a92ee2b89a14db42f4d6b1ad0d7b084fad07c10bb1e77c06a2b588e9Set Is Price Fee...517133232022-12-01 11:07:26181 days 7 hrs agoMummy Finance: Deployer IN  0x01e9b35785ef3f7ef2677c371442976bd550f3200 FTM0.00230955
0x9be707d772609e68ce00a190df875f46200f923a3c1283cec73dcd608106d6bd0x60806040517100712022-12-01 10:00:01181 days 9 hrs agoMummy Finance: Deployer IN  Create: FastPriceEvents0 FTM0.01278105
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0x9be707d772609e68ce00a190df875f46200f923a3c1283cec73dcd608106d6bd517100712022-12-01 10:00:01181 days 9 hrs ago Mummy Finance: Deployer  Contract Creation0 FTM
[ Download CSV Export 
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
FastPriceEvents

Compiler Version
v0.6.12+commit.27d51765

Optimization Enabled:
Yes with 8 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at FtmScan.com on 2022-12-02
*/

pragma solidity 0.6.12;



/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}


interface IFastPriceEvents {
    function emitPriceEvent(address _token, uint256 _price) external;
}


contract Governable {
    address public gov;

    constructor() public {
        gov = msg.sender;
    }

    modifier onlyGov() {
        require(msg.sender == gov, "Governable: forbidden");
        _;
    }

    function setGov(address _gov) external onlyGov {
        gov = _gov;
    }
}


contract FastPriceEvents is IFastPriceEvents, Governable {

    mapping (address => bool) public isPriceFeed;
    event PriceUpdate(address token, uint256 price, address priceFeed);

    function setIsPriceFeed(address _priceFeed, bool _isPriceFeed) external onlyGov {
      isPriceFeed[_priceFeed] = _isPriceFeed;
    }

    function emitPriceEvent(address _token, uint256 _price) external override {
      require(isPriceFeed[msg.sender], "FastPriceEvents: invalid sender");
      emit PriceUpdate(_token, _price, msg.sender);
    }
}

Contract Security Audit

Contract ABI

[{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"uint256","name":"price","type":"uint256"},{"indexed":false,"internalType":"address","name":"priceFeed","type":"address"}],"name":"PriceUpdate","type":"event"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"uint256","name":"_price","type":"uint256"}],"name":"emitPriceEvent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"gov","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isPriceFeed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_gov","type":"address"}],"name":"setGov","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_priceFeed","type":"address"},{"internalType":"bool","name":"_isPriceFeed","type":"bool"}],"name":"setIsPriceFeed","outputs":[],"stateMutability":"nonpayable","type":"function"}]

608060405234801561001057600080fd5b50600080546001600160a01b03191633179055610341806100326000396000f3fe608060405234801561001057600080fd5b50600436106100575760003560e01c806312d43a511461005c57806357a94beb1461008057806369d4c924146100ba578063cfad57a2146100ea578063e0409c7114610110575b600080fd5b61006461013c565b604080516001600160a01b039092168252519081900360200190f35b6100a66004803603602081101561009657600080fd5b50356001600160a01b031661014b565b604080519115158252519081900360200190f35b6100e8600480360360408110156100d057600080fd5b506001600160a01b0381351690602001351515610160565b005b6100e86004803603602081101561010057600080fd5b50356001600160a01b03166101e2565b6100e86004803603604081101561012657600080fd5b506001600160a01b03813516906020013561025b565b6000546001600160a01b031681565b60016020526000908152604090205460ff1681565b6000546001600160a01b031633146101b7576040805162461bcd60e51b815260206004820152601560248201527423b7bb32b93730b136329d103337b93134b23232b760591b604482015290519081900360640190fd5b6001600160a01b03919091166000908152600160205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314610239576040805162461bcd60e51b815260206004820152601560248201527423b7bb32b93730b136329d103337b93134b23232b760591b604482015290519081900360640190fd5b600080546001600160a01b0319166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff166102bf576040805162461bcd60e51b815260206004820152601f60248201527f4661737450726963654576656e74733a20696e76616c69642073656e64657200604482015290519081900360640190fd5b604080516001600160a01b038416815260208101839052338183015290517fc37a77b91cc3fc2d0e4b43fd2f347ec67adda10e39215de4742836cc3e42c97a9181900360600190a1505056fea264697066735822122095f92e20c2c417514452348d06e85d6c3cf46ffec9c289eee10f9de44bf6479164736f6c634300060c0033

Deployed ByteCode Sourcemap

5753:549:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5468:18;;;:::i;:::-;;;;-1:-1:-1;;;;;5468:18:0;;;;;;;;;;;;;;5819:44;;;;;;;;;;;;;;;;-1:-1:-1;5819:44:0;-1:-1:-1;;;;;5819:44:0;;:::i;:::-;;;;;;;;;;;;;;;;;;5945:135;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;5945:135:0;;;;;;;;;;:::i;:::-;;5668:76;;;;;;;;;;;;;;;;-1:-1:-1;5668:76:0;-1:-1:-1;;;;;5668:76:0;;:::i;6088:211::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;6088:211:0;;;;;;;;:::i;5468:18::-;;;-1:-1:-1;;;;;5468:18:0;;:::o;5819:44::-;;;;;;;;;;;;;;;:::o;5945:135::-;5611:3;;-1:-1:-1;;;;;5611:3:0;5597:10;:17;5589:51;;;;;-1:-1:-1;;;5589:51:0;;;;;;;;;;;;-1:-1:-1;;;5589:51:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;6034:23:0;;;::::1;;::::0;;;:11:::1;:23;::::0;;;;:38;;-1:-1:-1;;6034:38:0::1;::::0;::::1;;::::0;;;::::1;::::0;;5945:135::o;5668:76::-;5611:3;;-1:-1:-1;;;;;5611:3:0;5597:10;:17;5589:51;;;;;-1:-1:-1;;;5589:51:0;;;;;;;;;;;;-1:-1:-1;;;5589:51:0;;;;;;;;;;;;;;;5726:3:::1;:10:::0;;-1:-1:-1;;;;;;5726:10:0::1;-1:-1:-1::0;;;;;5726:10:0;;;::::1;::::0;;;::::1;::::0;;5668:76::o;6088:211::-;6191:10;6179:23;;;;:11;:23;;;;;;;;6171:67;;;;;-1:-1:-1;;;6171:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;6252:39;;;-1:-1:-1;;;;;6252:39:0;;;;;;;;;;6280:10;6252:39;;;;;;;;;;;;;;;6088:211;;:::o

Swarm Source

ipfs://95f92e20c2c417514452348d06e85d6c3cf46ffec9c289eee10f9de44bf64791
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Validator ID :
0 FTM

Amount Staked
0

Amount Delegated
0

Staking Total
0

Staking Start Epoch
0

Staking Start Time
0

Proof of Importance
0

Origination Score
0

Validation Score
0

Active
0

Online
0

Downtime
0 s
Address Amount claimed Rewards Created On Epoch Created On
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.