Sponsored Link: Datum ICO unlocks the $120 Bln User Data Economy. Data is the new Oil. Get Free Tokens worth .05 ETH
Contract Overview | CindicatorToken
ETH Balance: 0 Ether
ETH USD Value: $0
No Of Transactions: 6395 txns
Token Tracker 0xd4c435f5b09f855c3317c8524cb1f586e42795fa
  Latest 25 txns from a total Of 6395 transactions View All

TxHash Age From To Value [TxFee]
0x6e046af34e9c28123059f52b387dba152356c68713dda3c655ff08a76d47b25d15 mins ago0x08cf7d4ad7d9472e78be042bedeb2f50027147ce  IN   CindicatorToken0 Ether0.002177742
0x210c42c9bb8760bee47ee217f394b870607ee379768b020effb6d7923c47446719 mins ago0x00d465d2b7092d1e5b8d8be62e9934bf6487c88e  IN   CindicatorToken0 Ether0.00041532
0x844df82361d2dbd5786b089e80cc9b08a0103d4a3c87fe0c10910be01e7fdfef26 mins ago0x501ac3b461e7517d07dcb5492679cc7521aadd42  IN   CindicatorToken0 Ether0.00310914
0x03a07f58e7cf15164fed9c7b4f096016f012088bcbeb68b6b1ae39eff169e97d27 mins ago0x43a6ee06f158988b267e0179a53edb7e0615bf20  IN   CindicatorToken0 Ether0.00040956
0x516ff91b82d9cf7ea34f6b51af0d394709b127e26cb6562dad8d2e6565619b4628 mins ago0x036dc84891e03d92f1da2e31e635a0e1dd1f8292  IN   CindicatorToken0 Ether0.002246948
0x96f29bfbcd4f899f80949e5d7283a58cf22adc235fc2c45761748686147bf2481 hr 16 mins ago0xe5f799e2f18eca1f52c9325898c996d54fd63414  IN   CindicatorToken0 Ether0.002177742
0x8fdf9f8b58d96cf010e9239a5b5336ef186b4acf90c6574a690ead2028626eb31 hr 36 mins ago0x1bb4e46cb53ae7efe7dd41db1f8beee54426b4f1  IN   CindicatorToken0 Ether0.00311106
0xbddafbf5d0541bf5bd75b2fcc33a9774a95c75c8c273e8b91a1f25b9304a4d511 hr 40 mins ago0x51ca9a4707043be59e56c1db14d58dcbd955569e  IN   CindicatorToken0 Ether0.00051003
0x326f38bc5f47e6956f1f6fceb572d6b6dc463547ea6f3f56c3372337619cecc11 hr 43 mins ago0x3097b4e6b308309a7001d111d29889630a0fd1ad  IN   CindicatorToken0 Ether0.002556624
0x9ee5880e91469d9b4fd717e1159b51d38e6b3283025d73d68337fc78ecb3e9f22 hrs 11 mins ago0xcf8372e8bdca2479cae950406d793853579ac1bf  IN   CindicatorToken0 Ether0.00040956
0x533234bfa752006b1bafe0821b5c4f1c8801982da764f7e3230ab5a1d44cdcea2 hrs 27 mins ago0x5286fe7901ba5f80d29d99647e4f03197118c2e0  IN   CindicatorToken0 Ether0.001920156
0x0653278be9956bba2910861617b8e9fc9bdde5e26d7bf3dcba5f56d0274ecef62 hrs 41 mins ago0x28b8ca1960e3645bcba4aad446e48b07ca720cc2  IN   CindicatorToken0 Ether0.00408024
0xfa1462869434ce95bd7fdfb7f63de9cea377469cafbb9c4ba5b713abfd1fbe1d2 hrs 46 mins ago0x5286fe7901ba5f80d29d99647e4f03197118c2e0  IN   CindicatorToken0 Ether0.002175054
0x135e53773e8bc912ad731fe5b44f0df4a60b5f56d106aa275fb5165e240a37982 hrs 48 mins ago0x5286fe7901ba5f80d29d99647e4f03197118c2e0  IN   CindicatorToken0 Ether0.000488376
0x424dc896e98e6fc890fb51c218be8064192ddba1efbea01e39ec014cc7d045a62 hrs 56 mins ago0xda0396c581d426dd0c333d8991c1e979e02f3223  IN   CindicatorToken0 Ether0.000408536
0x4daf58976c2f2b23028796bfa2e383d75f8fba0a9026e562d5a93234d0eb7ff33 hrs 4 mins ago0xdc99d14d80f02c2bf098a3e1dc00b28990fb0ed5  IN   CindicatorToken0 Ether0.000730976
0xc9db23922dc0d08b025cf1d8b7f1911c7de5be2f93277c3bad784425336de3d13 hrs 14 mins ago0xcf8372e8bdca2479cae950406d793853579ac1bf  IN   CindicatorToken0 Ether0.000766005
0x50ec49f2a6c1929aa8b4172e9b7a36b6475ff050ed1de0825f013e512d36efb23 hrs 17 mins ago0xda0396c581d426dd0c333d8991c1e979e02f3223  IN   CindicatorToken0 Ether0.000408536
0xa3f27333e37706b57ebe924719acca846869ca6ac963a835bda5ab8bb6200c6d3 hrs 21 mins ago0x3e7350bfe23f38846fd529af3e8620c783f87aac  IN   CindicatorToken0 Ether0.002177742
0xae01b0d6ffc81753158ab9ce11cb6244b31b89a2ab3de4c7b1181d1b5235ce4f3 hrs 26 mins ago0xdc99d14d80f02c2bf098a3e1dc00b28990fb0ed5  IN   CindicatorToken0 Ether0.000830128
0xc639205798c23bd7d1998bd61b4550c7b948f27e6b8b8b3a98eeb3604ec4415d3 hrs 29 mins ago0x4dc30c8e6f3675a9f9408469ee659b0fe3823655  IN   CindicatorToken0 Ether0.00414808
0xae29e2b2aaa3adf86b979a95563d75ec84a66497448710e05ff2efd916d1d3913 hrs 29 mins ago0x535316f9577f5cfeb6919aa0eb5b1b157c837def  IN   CindicatorToken0 Ether0.000408024
0x1cab5bcf3d39562b5aead7129e283cbee4d3d4b1a9d3b3629459f413de46c0cd3 hrs 36 mins ago0x708b2bacdce0d63aaef94bbf9ca92bef9cf0a463  IN   CindicatorToken0 Ether0.002467044
0x32f3e4d22ca74b2e13ae1a8b75e1c05cceac4fc2f4d74abb805c9f7ac6c8067f3 hrs 38 mins ago0x63e776c2b49b46a2bbc00c31fb5073051b2d6172  IN   CindicatorToken0 Ether0.002176398
0x19c8554967da71b7336802fd65ef28ba0453e19849e295df95d5d02af4f0957e3 hrs 43 mins ago0x030225feaf956e065a3bb9cb44646dec80d184c4  IN   CindicatorToken0 Ether0.00182744
[ Download CSV Export  ] 
 Internal Transactions as a result of Contract Execution
View All
ParentTxHash Block Age From To Value
Contract Source Code Verified
Contract Name: CND
Compiler Version: v0.4.15+commit.bbb8e64f
Optimization Enabled: Yes
Runs (Optimiser):  200



  Contract Source Code   Find Similiar Contracts
pragma solidity ^0.4.15;

contract TokenController {
    /// @notice Called when `_owner` sends ether to the MiniMe Token contract
    /// @param _owner The address that sent the ether to create tokens
    /// @return True if the ether is accepted, false if it throws
    function proxyPayment(address _owner) payable returns(bool);

    /// @notice Notifies the controller about a token transfer allowing the
    ///  controller to react if desired
    /// @param _from The origin of the transfer
    /// @param _to The destination of the transfer
    /// @param _amount The amount of the transfer
    /// @return False if the controller does not authorize the transfer
    function onTransfer(address _from, address _to, uint _amount) returns(bool);

    /// @notice Notifies the controller about an approval allowing the
    ///  controller to react if desired
    /// @param _owner The address that calls `approve()`
    /// @param _spender The spender in the `approve()` call
    /// @param _amount The amount in the `approve()` call
    /// @return False if the controller does not authorize the approval
    function onApprove(address _owner, address _spender, uint _amount)
        returns(bool);
}

contract Controlled {
    /// @notice The address of the controller is the only address that can call
    ///  a function with this modifier
    modifier onlyController { require(msg.sender == controller); _; }

    address public controller;

    function Controlled() { controller = msg.sender;}

    /// @notice Changes the controller of the contract
    /// @param _newController The new controller of the contract
    function changeController(address _newController) onlyController {
        controller = _newController;
    }
}

contract ApproveAndCallFallBack {
    function receiveApproval(address from, uint256 _amount, address _token, bytes _data);
}

contract MiniMeToken is Controlled {

    string public name;                //The Token's name: e.g. DigixDAO Tokens
    uint8 public decimals;             //Number of decimals of the smallest unit
    string public symbol;              //An identifier: e.g. REP
    string public version = 'MMT_0.1'; //An arbitrary versioning scheme


    /// @dev `Checkpoint` is the structure that attaches a block number to a
    ///  given value, the block number attached is the one that last changed the
    ///  value
    struct  Checkpoint {

        // `fromBlock` is the block number that the value was generated from
        uint128 fromBlock;

        // `value` is the amount of tokens at a specific block number
        uint128 value;
    }

    // `parentToken` is the Token address that was cloned to produce this token;
    //  it will be 0x0 for a token that was not cloned
    MiniMeToken public parentToken;

    // `parentSnapShotBlock` is the block number from the Parent Token that was
    //  used to determine the initial distribution of the Clone Token
    uint public parentSnapShotBlock;

    // `creationBlock` is the block number that the Clone Token was created
    uint public creationBlock;

    // `balances` is the map that tracks the balance of each address, in this
    //  contract when the balance changes the block number that the change
    //  occurred is also included in the map
    mapping (address => Checkpoint[]) balances;

    // `allowed` tracks any extra transfer rights as in all ERC20 tokens
    mapping (address => mapping (address => uint256)) allowed;

    // Tracks the history of the `totalSupply` of the token
    Checkpoint[] totalSupplyHistory;

    // Flag that determines if the token is transferable or not.
    bool public transfersEnabled;

    // The factory used to create new clone tokens
    MiniMeTokenFactory public tokenFactory;

////////////////
// Constructor
////////////////

    /// @notice Constructor to create a MiniMeToken
    /// @param _tokenFactory The address of the MiniMeTokenFactory contract that
    ///  will create the Clone token contracts, the token factory needs to be
    ///  deployed first
    /// @param _parentToken Address of the parent token, set to 0x0 if it is a
    ///  new token
    /// @param _parentSnapShotBlock Block of the parent token that will
    ///  determine the initial distribution of the clone token, set to 0 if it
    ///  is a new token
    /// @param _tokenName Name of the new token
    /// @param _decimalUnits Number of decimals of the new token
    /// @param _tokenSymbol Token Symbol for the new token
    /// @param _transfersEnabled If true, tokens will be able to be transferred
    function MiniMeToken(
        address _tokenFactory,
        address _parentToken,
        uint _parentSnapShotBlock,
        string _tokenName,
        uint8 _decimalUnits,
        string _tokenSymbol,
        bool _transfersEnabled
    ) {
        tokenFactory = MiniMeTokenFactory(_tokenFactory);
        name = _tokenName;                                 // Set the name
        decimals = _decimalUnits;                          // Set the decimals
        symbol = _tokenSymbol;                             // Set the symbol
        parentToken = MiniMeToken(_parentToken);
        parentSnapShotBlock = _parentSnapShotBlock;
        transfersEnabled = _transfersEnabled;
        creationBlock = block.number;
    }


///////////////////
// ERC20 Methods
///////////////////

    /// @notice Send `_amount` tokens to `_to` from `msg.sender`
    /// @param _to The address of the recipient
    /// @param _amount The amount of tokens to be transferred
    /// @return Whether the transfer was successful or not
    function transfer(address _to, uint256 _amount) returns (bool success) {
        require(transfersEnabled);
        return doTransfer(msg.sender, _to, _amount);
    }

    /// @notice Send `_amount` tokens to `_to` from `_from` on the condition it
    ///  is approved by `_from`
    /// @param _from The address holding the tokens being transferred
    /// @param _to The address of the recipient
    /// @param _amount The amount of tokens to be transferred
    /// @return True if the transfer was successful
    function transferFrom(address _from, address _to, uint256 _amount
    ) returns (bool success) {

        // The controller of this contract can move tokens around at will,
        //  this is important to recognize! Confirm that you trust the
        //  controller of this contract, which in most situations should be
        //  another open source smart contract or 0x0
        if (msg.sender != controller) {
            require(transfersEnabled);

            // The standard ERC 20 transferFrom functionality
            if (allowed[_from][msg.sender] < _amount) return false;
            allowed[_from][msg.sender] -= _amount;
        }
        return doTransfer(_from, _to, _amount);
    }

    /// @dev This is the actual transfer function in the token contract, it can
    ///  only be called by other functions in this contract.
    /// @param _from The address holding the tokens being transferred
    /// @param _to The address of the recipient
    /// @param _amount The amount of tokens to be transferred
    /// @return True if the transfer was successful
    function doTransfer(address _from, address _to, uint _amount
    ) internal returns(bool) {

           if (_amount == 0) {
               return true;
           }

           require(parentSnapShotBlock < block.number);

           // Do not allow transfer to 0x0 or the token contract itself
           require((_to != 0) && (_to != address(this)));

           // If the amount being transfered is more than the balance of the
           //  account the transfer returns false
           var previousBalanceFrom = balanceOfAt(_from, block.number);
           if (previousBalanceFrom < _amount) {
               return false;
           }

           // Alerts the token controller of the transfer
           if (isContract(controller)) {
               require(TokenController(controller).onTransfer(_from, _to, _amount));
           }

           // First update the balance array with the new value for the address
           //  sending the tokens
           updateValueAtNow(balances[_from], previousBalanceFrom - _amount);

           // Then update the balance array with the new value for the address
           //  receiving the tokens
           var previousBalanceTo = balanceOfAt(_to, block.number);
           require(previousBalanceTo + _amount >= previousBalanceTo); // Check for overflow
           updateValueAtNow(balances[_to], previousBalanceTo + _amount);

           // An event to make the transfer easy to find on the blockchain
           Transfer(_from, _to, _amount);

           return true;
    }

    /// @param _owner The address that's balance is being requested
    /// @return The balance of `_owner` at the current block
    function balanceOf(address _owner) constant returns (uint256 balance) {
        return balanceOfAt(_owner, block.number);
    }

    /// @notice `msg.sender` approves `_spender` to spend `_amount` tokens on
    ///  its behalf. This is a modified version of the ERC20 approve function
    ///  to be a little bit safer
    /// @param _spender The address of the account able to transfer the tokens
    /// @param _amount The amount of tokens to be approved for transfer
    /// @return True if the approval was successful
    function approve(address _spender, uint256 _amount) returns (bool success) {
        require(transfersEnabled);

        // To change the approve amount you first have to reduce the addresses`
        //  allowance to zero by calling `approve(_spender,0)` if it is not
        //  already 0 to mitigate the race condition described here:
        //  https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
        require((_amount == 0) || (allowed[msg.sender][_spender] == 0));

        // Alerts the token controller of the approve function call
        if (isContract(controller)) {
            require(TokenController(controller).onApprove(msg.sender, _spender, _amount));
        }

        allowed[msg.sender][_spender] = _amount;
        Approval(msg.sender, _spender, _amount);
        return true;
    }

    /// @dev This function makes it easy to read the `allowed[]` map
    /// @param _owner The address of the account that owns the token
    /// @param _spender The address of the account able to transfer the tokens
    /// @return Amount of remaining tokens of _owner that _spender is allowed
    ///  to spend
    function allowance(address _owner, address _spender
    ) constant returns (uint256 remaining) {
        return allowed[_owner][_spender];
    }

    /// @notice `msg.sender` approves `_spender` to send `_amount` tokens on
    ///  its behalf, and then a function is triggered in the contract that is
    ///  being approved, `_spender`. This allows users to use their tokens to
    ///  interact with contracts in one function call instead of two
    /// @param _spender The address of the contract able to transfer the tokens
    /// @param _amount The amount of tokens to be approved for transfer
    /// @return True if the function call was successful
    function approveAndCall(address _spender, uint256 _amount, bytes _extraData
    ) returns (bool success) {
        require(approve(_spender, _amount));

        ApproveAndCallFallBack(_spender).receiveApproval(
            msg.sender,
            _amount,
            this,
            _extraData
        );

        return true;
    }

    /// @dev This function makes it easy to get the total number of tokens
    /// @return The total number of tokens
    function totalSupply() constant returns (uint) {
        return totalSupplyAt(block.number);
    }


////////////////
// Query balance and totalSupply in History
////////////////

    /// @dev Queries the balance of `_owner` at a specific `_blockNumber`
    /// @param _owner The address from which the balance will be retrieved
    /// @param _blockNumber The block number when the balance is queried
    /// @return The balance at `_blockNumber`
    function balanceOfAt(address _owner, uint _blockNumber) constant
        returns (uint) {

        // These next few lines are used when the balance of the token is
        //  requested before a check point was ever created for this token, it
        //  requires that the `parentToken.balanceOfAt` be queried at the
        //  genesis block for that token as this contains initial balance of
        //  this token
        if ((balances[_owner].length == 0)
            || (balances[_owner][0].fromBlock > _blockNumber)) {
            if (address(parentToken) != 0) {
                return parentToken.balanceOfAt(_owner, min(_blockNumber, parentSnapShotBlock));
            } else {
                // Has no parent
                return 0;
            }

        // This will return the expected balance during normal situations
        } else {
            return getValueAt(balances[_owner], _blockNumber);
        }
    }

    /// @notice Total amount of tokens at a specific `_blockNumber`.
    /// @param _blockNumber The block number when the totalSupply is queried
    /// @return The total amount of tokens at `_blockNumber`
    function totalSupplyAt(uint _blockNumber) constant returns(uint) {

        // These next few lines are used when the totalSupply of the token is
        //  requested before a check point was ever created for this token, it
        //  requires that the `parentToken.totalSupplyAt` be queried at the
        //  genesis block for this token as that contains totalSupply of this
        //  token at this block number.
        if ((totalSupplyHistory.length == 0)
            || (totalSupplyHistory[0].fromBlock > _blockNumber)) {
            if (address(parentToken) != 0) {
                return parentToken.totalSupplyAt(min(_blockNumber, parentSnapShotBlock));
            } else {
                return 0;
            }

        // This will return the expected totalSupply during normal situations
        } else {
            return getValueAt(totalSupplyHistory, _blockNumber);
        }
    }

////////////////
// Clone Token Method
////////////////

    /// @notice Creates a new clone token with the initial distribution being
    ///  this token at `_snapshotBlock`
    /// @param _cloneTokenName Name of the clone token
    /// @param _cloneDecimalUnits Number of decimals of the smallest unit
    /// @param _cloneTokenSymbol Symbol of the clone token
    /// @param _snapshotBlock Block when the distribution of the parent token is
    ///  copied to set the initial distribution of the new clone token;
    ///  if the block is zero than the actual block, the current block is used
    /// @param _transfersEnabled True if transfers are allowed in the clone
    /// @return The address of the new MiniMeToken Contract
    function createCloneToken(
        string _cloneTokenName,
        uint8 _cloneDecimalUnits,
        string _cloneTokenSymbol,
        uint _snapshotBlock,
        bool _transfersEnabled
        ) returns(address) {
        if (_snapshotBlock == 0) _snapshotBlock = block.number;
        MiniMeToken cloneToken = tokenFactory.createCloneToken(
            this,
            _snapshotBlock,
            _cloneTokenName,
            _cloneDecimalUnits,
            _cloneTokenSymbol,
            _transfersEnabled
            );

        cloneToken.changeController(msg.sender);

        // An event to make the token easy to find on the blockchain
        NewCloneToken(address(cloneToken), _snapshotBlock);
        return address(cloneToken);
    }

////////////////
// Generate and destroy tokens
////////////////

    /// @notice Generates `_amount` tokens that are assigned to `_owner`
    /// @param _owner The address that will be assigned the new tokens
    /// @param _amount The quantity of tokens generated
    /// @return True if the tokens are generated correctly
    function generateTokens(address _owner, uint _amount
    ) onlyController returns (bool) {
        uint curTotalSupply = totalSupply();
        require(curTotalSupply + _amount >= curTotalSupply); // Check for overflow
        uint previousBalanceTo = balanceOf(_owner);
        require(previousBalanceTo + _amount >= previousBalanceTo); // Check for overflow
        updateValueAtNow(totalSupplyHistory, curTotalSupply + _amount);
        updateValueAtNow(balances[_owner], previousBalanceTo + _amount);
        Transfer(0, _owner, _amount);
        return true;
    }


    /// @notice Burns `_amount` tokens from `_owner`
    /// @param _owner The address that will lose the tokens
    /// @param _amount The quantity of tokens to burn
    /// @return True if the tokens are burned correctly
    function destroyTokens(address _owner, uint _amount
    ) onlyController returns (bool) {
        uint curTotalSupply = totalSupply();
        require(curTotalSupply >= _amount);
        uint previousBalanceFrom = balanceOf(_owner);
        require(previousBalanceFrom >= _amount);
        updateValueAtNow(totalSupplyHistory, curTotalSupply - _amount);
        updateValueAtNow(balances[_owner], previousBalanceFrom - _amount);
        Transfer(_owner, 0, _amount);
        return true;
    }

////////////////
// Enable tokens transfers
////////////////


    /// @notice Enables token holders to transfer their tokens freely if true
    /// @param _transfersEnabled True if transfers are allowed in the clone
    function enableTransfers(bool _transfersEnabled) onlyController {
        transfersEnabled = _transfersEnabled;
    }

////////////////
// Internal helper functions to query and set a value in a snapshot array
////////////////

    /// @dev `getValueAt` retrieves the number of tokens at a given block number
    /// @param checkpoints The history of values being queried
    /// @param _block The block number to retrieve the value at
    /// @return The number of tokens being queried
    function getValueAt(Checkpoint[] storage checkpoints, uint _block
    ) constant internal returns (uint) {
        if (checkpoints.length == 0) return 0;

        // Shortcut for the actual value
        if (_block >= checkpoints[checkpoints.length-1].fromBlock)
            return checkpoints[checkpoints.length-1].value;
        if (_block < checkpoints[0].fromBlock) return 0;

        // Binary search of the value in the array
        uint min = 0;
        uint max = checkpoints.length-1;
        while (max > min) {
            uint mid = (max + min + 1)/ 2;
            if (checkpoints[mid].fromBlock<=_block) {
                min = mid;
            } else {
                max = mid-1;
            }
        }
        return checkpoints[min].value;
    }

    /// @dev `updateValueAtNow` used to update the `balances` map and the
    ///  `totalSupplyHistory`
    /// @param checkpoints The history of data being updated
    /// @param _value The new number of tokens
    function updateValueAtNow(Checkpoint[] storage checkpoints, uint _value
    ) internal  {
        if ((checkpoints.length == 0)
        || (checkpoints[checkpoints.length -1].fromBlock < block.number)) {
               Checkpoint storage newCheckPoint = checkpoints[ checkpoints.length++ ];
               newCheckPoint.fromBlock =  uint128(block.number);
               newCheckPoint.value = uint128(_value);
           } else {
               Checkpoint storage oldCheckPoint = checkpoints[checkpoints.length-1];
               oldCheckPoint.value = uint128(_value);
           }
    }

    /// @dev Internal function to determine if an address is a contract
    /// @param _addr The address being queried
    /// @return True if `_addr` is a contract
    function isContract(address _addr) constant internal returns(bool) {
        uint size;
        if (_addr == 0) return false;
        assembly {
            size := extcodesize(_addr)
        }
        return size>0;
    }

    /// @dev Helper function to return a min betwen the two uints
    function min(uint a, uint b) internal returns (uint) {
        return a < b ? a : b;
    }

    /// @notice The fallback function: If the contract's controller has not been
    ///  set to 0, then the `proxyPayment` method is called which relays the
    ///  ether and creates tokens as described in the token controller contract
    function ()  payable {
        require(isContract(controller));
        require(TokenController(controller).proxyPayment.value(msg.value)(msg.sender));
    }

//////////
// Safety Methods
//////////

    /// @notice This method can be used by the controller to extract mistakenly
    ///  sent tokens to this contract.
    /// @param _token The address of the token contract that you want to recover
    ///  set to 0 in case you want to extract ether.
    function claimTokens(address _token) public onlyController {
        if (_token == 0x0) {
            controller.transfer(this.balance);
            return;
        }

        MiniMeToken token = MiniMeToken(_token);
        uint balance = token.balanceOf(this);
        token.transfer(controller, balance);
        ClaimedTokens(_token, controller, balance);
    }

////////////////
// Events
////////////////
    event ClaimedTokens(address indexed _token, address indexed _controller, uint _amount);
    event Transfer(address indexed _from, address indexed _to, uint256 _amount);
    event NewCloneToken(address indexed _cloneToken, uint _snapshotBlock);
    event Approval(
        address indexed _owner,
        address indexed _spender,
        uint256 _amount
        );

}

contract CND is MiniMeToken {
  /**
    * @dev Constructor
  */
  uint256 public constant IS_CND_CONTRACT_MAGIC_NUMBER = 0x1338;
  function CND(address _tokenFactory)
    MiniMeToken(
      _tokenFactory,
      0x0,                      // no parent token
      0,                        // no snapshot block number from parent
      "Cindicator Token",   // Token name
      18,                       // Decimals
      "CND",                    // Symbol
      true                      // Enable transfers
    ) 
    {}

    function() payable {
      require(false);
    }
}

contract MiniMeTokenFactory {

    /// @notice Update the DApp by creating a new token with new functionalities
    ///  the msg.sender becomes the controller of this clone token
    /// @param _parentToken Address of the token being cloned
    /// @param _snapshotBlock Block of the parent token that will
    ///  determine the initial distribution of the clone token
    /// @param _tokenName Name of the new token
    /// @param _decimalUnits Number of decimals of the new token
    /// @param _tokenSymbol Token Symbol for the new token
    /// @param _transfersEnabled If true, tokens will be able to be transferred
    /// @return The address of the new token contract
    function createCloneToken(
        address _parentToken,
        uint _snapshotBlock,
        string _tokenName,
        uint8 _decimalUnits,
        string _tokenSymbol,
        bool _transfersEnabled
    ) returns (MiniMeToken) {
        MiniMeToken newToken = new MiniMeToken(
            this,
            _parentToken,
            _snapshotBlock,
            _tokenName,
            _decimalUnits,
            _tokenSymbol,
            _transfersEnabled
            );

        newToken.changeController(msg.sender);
        return newToken;
    }
}

    Contract ABI  
[{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_amount","type":"uint256"}],"name":"approve","outputs":[{"name":"success","type":"bool"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"creationBlock","outputs":[{"name":"","type":"uint256"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_from","type":"address"},{"name":"_to","type":"address"},{"name":"_amount","type":"uint256"}],"name":"transferFrom","outputs":[{"name":"success","type":"bool"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint8"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_newController","type":"address"}],"name":"changeController","outputs":[],"payable":false,"type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"},{"name":"_blockNumber","type":"uint256"}],"name":"balanceOfAt","outputs":[{"name":"","type":"uint256"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"version","outputs":[{"name":"","type":"string"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_cloneTokenName","type":"string"},{"name":"_cloneDecimalUnits","type":"uint8"},{"name":"_cloneTokenSymbol","type":"string"},{"name":"_snapshotBlock","type":"uint256"},{"name":"_transfersEnabled","type":"bool"}],"name":"createCloneToken","outputs":[{"name":"","type":"address"}],"payable":false,"type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"balance","type":"uint256"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"parentToken","outputs":[{"name":"","type":"address"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_owner","type":"address"},{"name":"_amount","type":"uint256"}],"name":"generateTokens","outputs":[{"name":"","type":"bool"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"type":"function"},{"constant":true,"inputs":[{"name":"_blockNumber","type":"uint256"}],"name":"totalSupplyAt","outputs":[{"name":"","type":"uint256"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_amount","type":"uint256"}],"name":"transfer","outputs":[{"name":"success","type":"bool"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"transfersEnabled","outputs":[{"name":"","type":"bool"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"IS_CND_CONTRACT_MAGIC_NUMBER","outputs":[{"name":"","type":"uint256"}],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"parentSnapShotBlock","outputs":[{"name":"","type":"uint256"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_amount","type":"uint256"},{"name":"_extraData","type":"bytes"}],"name":"approveAndCall","outputs":[{"name":"success","type":"bool"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_owner","type":"address"},{"name":"_amount","type":"uint256"}],"name":"destroyTokens","outputs":[{"name":"","type":"bool"}],"payable":false,"type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"},{"name":"_spender","type":"address"}],"name":"allowance","outputs":[{"name":"remaining","type":"uint256"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_token","type":"address"}],"name":"claimTokens","outputs":[],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"tokenFactory","outputs":[{"name":"","type":"address"}],"payable":false,"type":"function"},{"constant":false,"inputs":[{"name":"_transfersEnabled","type":"bool"}],"name":"enableTransfers","outputs":[],"payable":false,"type":"function"},{"constant":true,"inputs":[],"name":"controller","outputs":[{"name":"","type":"address"}],"payable":false,"type":"function"},{"inputs":[{"name":"_tokenFactory","type":"address"}],"payable":false,"type":"constructor"},{"payable":true,"type":"fallback"},{"anonymous":false,"inputs":[{"indexed":true,"name":"_token","type":"address"},{"indexed":true,"name":"_controller","type":"address"},{"indexed":false,"name":"_amount","type":"uint256"}],"name":"ClaimedTokens","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"_from","type":"address"},{"indexed":true,"name":"_to","type":"address"},{"indexed":false,"name":"_amount","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"_cloneToken","type":"address"},{"indexed":false,"name":"_snapshotBlock","type":"uint256"}],"name":"NewCloneToken","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"_owner","type":"address"},{"indexed":true,"name":"_spender","type":"address"},{"indexed":false,"name":"_amount","type":"uint256"}],"name":"Approval","type":"event"}]

  Contract Creation Code Switch To Opcodes View
606060405260408051908101604052600781527f4d4d545f302e3100000000000000000000000000000000000000000000000000602082015260049080516200004d9291602001906200019f565b5034156200005a57600080fd5b60405160208062001d36833981016040528080519150505b806000806040805190810160405280601081526020017f43696e64696361746f7220546f6b656e00000000000000000000000000000000815250601260408051908101604052600381527f434e440000000000000000000000000000000000000000000000000000000000602082015260015b5b60008054600160a060020a03191633600160a060020a03161790555b600b805461010060a860020a031916610100600160a060020a038a16021790556001848051620001379291602001906200019f565b506002805460ff191660ff851617905560038280516200015c9291602001906200019f565b5060058054600160a060020a031916600160a060020a0388161790556006859055600b805460ff1916821515179055436007555b505050505050505b5062000249565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10620001e257805160ff191683800117855562000212565b8280016001018555821562000212579182015b8281111562000212578251825591602001919060010190620001f5565b5b506200022192915062000225565b5090565b6200024691905b808211156200022157600081556001016200022c565b5090565b90565b611add80620002596000396000f300606060405236156101385763ffffffff60e060020a60003504166306fdde038114610141578063095ea7b3146101cc578063176345141461020257806318160ddd1461022757806323b872dd1461024c578063313ce567146102885780633cebb823146102b15780634ee2cd7e146102d257806354fd4d50146103065780636638c0871461039157806370a082311461045557806380a5400114610486578063827f32c0146104b557806395d89b41146104eb578063981b24d014610576578063a9059cbb1461059e578063bef97c87146105d4578063c16d1377146105fb578063c5bcc4f114610620578063cae9ca5114610645578063d3ce77fe146106be578063dd62ed3e146106f4578063df8de3e71461072b578063e77772fe1461074c578063f41e60c51461077b578063f77c479114610795575b5b600080fd5b5b005b341561014c57600080fd5b6101546107c4565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156101915780820151818401525b602001610178565b50505050905090810190601f1680156101be5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101d757600080fd5b6101ee600160a060020a0360043516602435610862565b604051901515815260200160405180910390f35b341561020d57600080fd5b6102156109cc565b60405190815260200160405180910390f35b341561023257600080fd5b6102156109d2565b60405190815260200160405180910390f35b341561025757600080fd5b6101ee600160a060020a03600435811690602435166044356109e3565b604051901515815260200160405180910390f35b341561029357600080fd5b61029b610a85565b60405160ff909116815260200160405180910390f35b34156102bc57600080fd5b61013e600160a060020a0360043516610a8e565b005b34156102dd57600080fd5b610215600160a060020a0360043516602435610ad6565b60405190815260200160405180910390f35b341561031157600080fd5b610154610c1c565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156101915780820151818401525b602001610178565b50505050905090810190601f1680156101be5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561039c57600080fd5b61043960046024813581810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284378201915050505050509190803560ff1690602001909190803590602001908201803590602001908080601f016020809104026020016040519081016040528181529291906020840183838082843750949650508435946020013515159350610cba92505050565b604051600160a060020a03909116815260200160405180910390f35b341561046057600080fd5b610215600160a060020a0360043516610eea565b60405190815260200160405180910390f35b341561049157600080fd5b610439610efe565b604051600160a060020a03909116815260200160405180910390f35b34156104c057600080fd5b6101ee600160a060020a0360043516602435610f0d565b604051901515815260200160405180910390f35b34156104f657600080fd5b610154610fe0565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156101915780820151818401525b602001610178565b50505050905090810190601f1680156101be5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561058157600080fd5b61021560043561107e565b60405190815260200160405180910390f35b34156105a957600080fd5b6101ee600160a060020a0360043516602435611176565b604051901515815260200160405180910390f35b34156105df57600080fd5b6101ee61119e565b604051901515815260200160405180910390f35b341561060657600080fd5b6102156111a7565b60405190815260200160405180910390f35b341561062b57600080fd5b6102156111ad565b60405190815260200160405180910390f35b341561065057600080fd5b6101ee60048035600160a060020a03169060248035919060649060443590810190830135806020601f820181900481020160405190810160405281815292919060208401838380828437509496506111b395505050505050565b604051901515815260200160405180910390f35b34156106c957600080fd5b6101ee600160a060020a03600435166024356112d1565b604051901515815260200160405180910390f35b34156106ff57600080fd5b610215600160a060020a036004358116906024351661139e565b60405190815260200160405180910390f35b341561073657600080fd5b61013e600160a060020a03600435166113cb565b005b341561075757600080fd5b610439611578565b604051600160a060020a03909116815260200160405180910390f35b341561078657600080fd5b61013e600435151561158c565b005b34156107a057600080fd5b6104396115ba565b604051600160a060020a03909116815260200160405180910390f35b60018054600181600116156101000203166002900480601f01602080910402602001604051908101604052809291908181526020018280546001816001161561010002031660029004801561085a5780601f1061082f5761010080835404028352916020019161085a565b820191906000526020600020905b81548152906001019060200180831161083d57829003601f168201915b505050505081565b600b5460009060ff16151561087657600080fd5b8115806108a65750600160a060020a03338116600090815260096020908152604080832093871683529290522054155b15156108b157600080fd5b6000546108c690600160a060020a03166115c9565b156109615760008054600160a060020a03169063da682aeb903390869086906040516020015260405160e060020a63ffffffff8616028152600160a060020a0393841660048201529190921660248201526044810191909152606401602060405180830381600087803b151561093b57600080fd5b6102c65a03f1151561094c57600080fd5b50505060405180519050151561096157600080fd5b5b600160a060020a03338116600081815260096020908152604080832094881680845294909152908190208590557f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259085905190815260200160405180910390a35060015b92915050565b60075481565b60006109dd4361107e565b90505b90565b6000805433600160a060020a03908116911614610a7057600b5460ff161515610a0b57600080fd5b600160a060020a038085166000908152600960209081526040808320339094168352929052205482901015610a4257506000610a7e565b600160a060020a03808516600090815260096020908152604080832033909416835292905220805483900390555b610a7b8484846115f6565b90505b9392505050565b60025460ff1681565b60005433600160a060020a03908116911614610aa957600080fd5b6000805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0383161790555b5b50565b600160a060020a0382166000908152600860205260408120541580610b365750600160a060020a038316600090815260086020526040812080548492908110610b1b57fe5b906000526020600020900160005b50546001608060020a0316115b15610bec57600554600160a060020a031615610bdf57600554600654600160a060020a0390911690634ee2cd7e908590610b719086906117d5565b60006040516020015260405160e060020a63ffffffff8516028152600160a060020a0390921660048301526024820152604401602060405180830381600087803b1515610bbd57600080fd5b6102c65a03f11515610bce57600080fd5b5050506040518051905090506109c6565b5060006109c6565b6109c6565b600160a060020a0383166000908152600860205260409020610c0e90836117ef565b90506109c6565b5b92915050565b60048054600181600116156101000203166002900480601f01602080910402602001604051908101604052809291908181526020018280546001816001161561010002031660029004801561085a5780601f1061082f5761010080835404028352916020019161085a565b820191906000526020600020905b81548152906001019060200180831161083d57829003601f168201915b505050505081565b600080831515610cc8574393505b600b546101009004600160a060020a0316635b7b72c130868a8a8a8960006040516020015260405160e060020a63ffffffff8916028152600160a060020a038716600482019081526024820187905260ff8516606483015282151560a483015260c0604483019081529091608481019060c40187818151815260200191508051906020019080838360005b83811015610d6c5780820151818401525b602001610d53565b50505050905090810190601f168015610d995780820380516001836020036101000a031916815260200191505b50838103825285818151815260200191508051906020019080838360005b83811015610dd05780820151818401525b602001610db7565b50505050905090810190601f168015610dfd5780820380516001836020036101000a031916815260200191505b5098505050505050505050602060405180830381600087803b1515610e2157600080fd5b6102c65a03f11515610e3257600080fd5b5050506040518051915050600160a060020a038116633cebb8233360405160e060020a63ffffffff8416028152600160a060020a039091166004820152602401600060405180830381600087803b1515610e8b57600080fd5b6102c65a03f11515610e9c57600080fd5b50505080600160a060020a03167f086c875b377f900b07ce03575813022f05dd10ed7640b5282cf6d3c3fc352ade8560405190815260200160405180910390a28091505b5095945050505050565b6000610ef68243610ad6565b90505b919050565b600554600160a060020a031681565b600080548190819033600160a060020a03908116911614610f2d57600080fd5b610f356109d2565b915083820182901015610f4757600080fd5b610f5085610eea565b905083810181901015610f6257600080fd5b610f6f600a858401611963565b600160a060020a0385166000908152600860205260409020610f9390828601611963565b84600160a060020a031660007fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8660405190815260200160405180910390a3600192505b5b505092915050565b60038054600181600116156101000203166002900480601f01602080910402602001604051908101604052809291908181526020018280546001816001161561010002031660029004801561085a5780601f1061082f5761010080835404028352916020019161085a565b820191906000526020600020905b81548152906001019060200180831161083d57829003601f168201915b505050505081565b600a5460009015806110b7575081600a600081548110151561109c57fe5b906000526020600020900160005b50546001608060020a0316115b1561115e57600554600160a060020a03161561115157600554600654600160a060020a039091169063981b24d0906110f09085906117d5565b60006040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b151561112f57600080fd5b6102c65a03f1151561114057600080fd5b505050604051805190509050610ef9565b506000610ef9565b610ef9565b611169600a836117ef565b9050610ef9565b5b919050565b600b5460009060ff16151561118a57600080fd5b6111953384846115f6565b90505b92915050565b600b5460ff1681565b61133881565b60065481565b60006111bf8484610862565b15156111ca57600080fd5b83600160a060020a0316638f4ffcb1338530866040518563ffffffff1660e060020a0281526004018085600160a060020a0316600160a060020a0316815260200184815260200183600160a060020a0316600160a060020a0316815260200180602001828103825283818151815260200191508051906020019080838360005b838110156112635780820151818401525b60200161124a565b50505050905090810190601f1680156112905780820380516001836020036101000a031916815260200191505b5095505050505050600060405180830381600087803b15156112b157600080fd5b6102c65a03f115156112c257600080fd5b505050600190505b9392505050565b600080548190819033600160a060020a039081169116146112f157600080fd5b6112f96109d2565b91508382101561130857600080fd5b61131185610eea565b90508381101561132057600080fd5b61132d600a858403611963565b600160a060020a038516600090815260086020526040902061135190858303611963565b600085600160a060020a03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8660405190815260200160405180910390a3600192505b5b505092915050565b600160a060020a038083166000908152600960209081526040808320938516835292905220545b92915050565b60008054819033600160a060020a039081169116146113e957600080fd5b600160a060020a038316151561143757600054600160a060020a039081169030163180156108fc0290604051600060405180830381858888f19350505050151561143257600080fd5b611572565b82915081600160a060020a03166370a082313060006040516020015260405160e060020a63ffffffff8416028152600160a060020a039091166004820152602401602060405180830381600087803b151561149157600080fd5b6102c65a03f115156114a257600080fd5b505050604051805160008054919350600160a060020a03808616935063a9059cbb92169084906040516020015260405160e060020a63ffffffff8516028152600160a060020a0390921660048301526024820152604401602060405180830381600087803b151561151257600080fd5b6102c65a03f1151561152357600080fd5b50505060405180515050600054600160a060020a039081169084167ff931edb47c50b4b4104c187b5814a9aef5f709e17e2ecf9617e860cacade929c8360405190815260200160405180910390a35b5b505050565b600b546101009004600160a060020a031681565b60005433600160a060020a039081169116146115a757600080fd5b600b805460ff19168215151790555b5b50565b600054600160a060020a031681565b600080600160a060020a03831615156115e557600091506115f0565b823b90506000811191505b50919050565b6000808083151561160a57600192506117cc565b60065443901061161957600080fd5b600160a060020a03851615801590611643575030600160a060020a031685600160a060020a031614155b151561164e57600080fd5b6116588643610ad6565b91508382101561166b57600092506117cc565b60005461168090600160a060020a03166115c9565b1561171b5760008054600160a060020a031690634a393149908890889088906040516020015260405160e060020a63ffffffff8616028152600160a060020a0393841660048201529190921660248201526044810191909152606401602060405180830381600087803b15156116f557600080fd5b6102c65a03f1151561170657600080fd5b50505060405180519050151561171b57600080fd5b5b600160a060020a038616600090815260086020526040902061174090858403611963565b61174a8543610ad6565b90508381018190101561175c57600080fd5b600160a060020a038516600090815260086020526040902061178090828601611963565b84600160a060020a031686600160a060020a03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8660405190815260200160405180910390a3600192505b50509392505050565b60008183106117e45781611195565b825b90505b92915050565b60008060008085805490506000141561180b576000935061195a565b85548690600019810190811061181d57fe5b906000526020600020900160005b50546001608060020a031685106118825785548690600019810190811061184e57fe5b906000526020600020900160005b505470010000000000000000000000000000000090046001608060020a0316935061195a565b85600081548110151561189157fe5b906000526020600020900160005b50546001608060020a03168510156118ba576000935061195a565b8554600093506000190191505b8282111561191c5760026001838501015b0490508486828154811015156118ea57fe5b906000526020600020900160005b50546001608060020a03161161191057809250611917565b6001810391505b6118c7565b858381548110151561192a57fe5b906000526020600020900160005b505470010000000000000000000000000000000090046001608060020a031693505b50505092915050565b8154600090819015806119a05750835443908590600019810190811061198557fe5b906000526020600020900160005b50546001608060020a0316105b15611a1657835484906119b68260018301611a66565b815481106119c057fe5b906000526020600020900160005b5080546001608060020a03858116700100000000000000000000000000000000024382166fffffffffffffffffffffffffffffffff1990931692909217161781559150611a5f565b835484906000198101908110611a2857fe5b906000526020600020900160005b5080546001608060020a0380861670010000000000000000000000000000000002911617815590505b5b50505050565b81548183558181151161157257600083815260209020611572918101908301611a90565b5b505050565b6109e091905b80821115611aaa5760008155600101611a96565b5090565b905600a165627a7a7230582059cb00184ccce912d20c6ce89bc5d7c046591dd620cfaed9f4766dd69351fc74002900000000000000000000000013ba3b63268ec5d4fac9ad1b2dffffd0b3697fd8

    Constructor Arguments (ABI-encoded and is the last bytes of the Contract Creation Code above)
00000000000000000000000013ba3b63268ec5d4fac9ad1b2dffffd0b3697fd8

-----Decoded View---------------
Found 1 constructor arguments :
Arg [0] : 00000000000000000000000013ba3b63268ec5d4fac9ad1b2dffffd0b3697fd8


   Swarm Source:
bzzr://59cb00184ccce912d20c6ce89bc5d7c046591dd620cfaed9f4766dd69351fc74
View All
Block Age txn Difficulty GasUsed Reward
View All
Block Age UncleNumber Difficulty GasUsed Reward
Make sure to use the "downvote" button for any spammy posts, and the "upvote" for interesting conversations.