Latest 25 transactions from a total of 39 transactions

TxHash Age From To Value [TxFee]
0x82a34fb56b71c6587cb07174c437a4bcf05dab4b2d467efbbcac85a60699085984 days 15 hrs ago0x342de40f987eac16ee2f556487b718fb5c019863  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.0190307
0xfc6f8405e294d6c5de5b52b16fee632ad0ac318958bd771d01b7c57389279946102 days 3 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.01903454
0xaa28bfdcf7c82e6ec77b909ee9d24a45547f3b9eeffaaaaf447e29f40e54118f102 days 3 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.00023737
0x2efb072f8ed674062df042762feb9c2dd3f97848364e6f13e63f3c0061e6fa21102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.01903198
0x5ae45d877313fb46af6c5735720d94dd01797c9e0c838451a734ea287de50e31102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.023388
0x25046efec7c23ca7afb0ea865e20d8ed9d7264adb4b2724a9c2c0701664319f8102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.00023737
0x2ef1e6d5a6d9209a81a7b0284dbb8bb14b8c262ad6b44dc089c9c8a647323e84102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.039967158
0x859e082f0a57a8d02996425b2eec7ee30fb6bf087a41424d2efede83cb982149102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.023737
0x2d9be0bfd52ec727c2da4e735a0613243b3b9df0dd04b8522db3a84cab699c9f102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.0941635
0x9c723f6b423aec0a30a6d9c1ed97fb91b9580f5145eeeb9d4b006cdbedb3becd102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.00065493
0xa40dffe19f27f1e836f1b4cc5bc46b44a3ebe861603525ba6c750da6bef879c6102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.00139668
0x9771019d56135857903a8a9411dd1e1c356c68aeea783bd6939a1a7e9a89c3b9102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.000023278
0xfcac69378ac9b80674e4cc8a2d64b679a00b37d758ceef0afe1b92436cf66001102 days 4 hrs ago0xaa7e7b418674c40067aaeb08abb1bf6205431307  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.00188327
0x956d482b46acce38731660c01e84136b5901be9d7767cfa30a6c85a70c5aa95f134 days 16 hrs ago0x49d8621f8862c423abba0dfae4916f838cd264f6  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.0429580305
0x3ac70d8c7214cc1653b31990d4d85ef1a904cafab1c4b6625e9f5f9967ebc8d4134 days 16 hrs ago0x49d8621f8862c423abba0dfae4916f838cd264f6  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.0429535953
0xd0513dc94927030e6846632c6cf3f90af50246f14c5a6c89a59a16539f7e6e93134 days 16 hrs ago0x49d8621f8862c423abba0dfae4916f838cd264f6  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.0429506385
0xaef99480a98a1556276ba282583c78bb4d59436bdc4ca86bb356c2febad918cc136 days 4 hrs ago0x49d8621f8862c423abba0dfae4916f838cd264f6  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.0057627481
0x2aeb8ee0fedc71efd88da81af3b7edb742597946cbc9099b4c2a595cf1692d85231 days 1 min ago0xfdd23835627fbd4aea5524c0cf3784a3a69b7b6a  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.001903326
0x9ce36a2cce863f256b487d441e2484151026665ff5e1f92b9baa28637647c065242 days 3 hrs ago0x6eb26c99d6e8a3b60cb1618d6b7b708c14bab544  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.005711898
0xdfe7b4da83cbc05d9d1f1fbb61d396d67137f7f249577b867cc3a26769948568242 days 3 hrs ago0x6eb26c99d6e8a3b60cb1618d6b7b708c14bab544  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.00380678
0x1683a9f9db7da8c934f98393f615f5cb147d11842b46645eaa1f7e6d29ca2c60251 days 3 hrs ago0xdf9ff5903ac440c76a798fd09cab952c3f3a1ac4  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.001887814
0x1e95303744adc5501af100644c9967351733d52b0e2fddafeaa2d62a9b2a0218251 days 4 hrs ago0xdf9ff5903ac440c76a798fd09cab952c3f3a1ac4  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.000023452
0x2011ff4725475ea4a24c1b05ae2be9c4e35139ca0ca7d3a393bbd12d7da5f7e4251 days 4 hrs ago0xdf9ff5903ac440c76a798fd09cab952c3f3a1ac4  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.001887686
0x967c072832eefcb77858fa3a60ae545f8574c2b4b481b79d9370763de0ebad1a251 days 4 hrs ago0xdf9ff5903ac440c76a798fd09cab952c3f3a1ac4  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.000023452
0xa617e31d729853fe9358462fcbc55330ad2fcd31d448ee8cc410b7653d51ec2a251 days 4 hrs ago0xdf9ff5903ac440c76a798fd09cab952c3f3a1ac4  IN   0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f30 Ether0.000023342
[ Download CSV Export  ] 
 Internal Transactions as a result of Contract Execution
 Latest 25 Internal Txns, Click here To View More View All
ParentTxHash Block Age From To Value
0x82a34fb56b71c6587cb07174c437a4bcf05dab4b2d467efbbcac85a606990859450998784 days 15 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xfc6f8405e294d6c5de5b52b16fee632ad0ac318958bd771d01b7c573892799464393274102 days 3 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x2efb072f8ed674062df042762feb9c2dd3f97848364e6f13e63f3c0061e6fa214393226102 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x2ef1e6d5a6d9209a81a7b0284dbb8bb14b8c262ad6b44dc089c9c8a647323e844393186102 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x2d9be0bfd52ec727c2da4e735a0613243b3b9df0dd04b8522db3a84cab699c9f4393049102 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xfcac69378ac9b80674e4cc8a2d64b679a00b37d758ceef0afe1b92436cf660014392990102 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x956d482b46acce38731660c01e84136b5901be9d7767cfa30a6c85a70c5aa95f4187644134 days 16 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x3ac70d8c7214cc1653b31990d4d85ef1a904cafab1c4b6625e9f5f9967ebc8d44187637134 days 16 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xd0513dc94927030e6846632c6cf3f90af50246f14c5a6c89a59a16539f7e6e934187631134 days 16 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xaef99480a98a1556276ba282583c78bb4d59436bdc4ca86bb356c2febad918cc4178521136 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x2aeb8ee0fedc71efd88da81af3b7edb742597946cbc9099b4c2a595cf1692d853559287231 days 1 min ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x9ce36a2cce863f256b487d441e2484151026665ff5e1f92b9baa28637647c0653486114242 days 3 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xdfe7b4da83cbc05d9d1f1fbb61d396d67137f7f249577b867cc3a267699485683486076242 days 3 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x1683a9f9db7da8c934f98393f615f5cb147d11842b46645eaa1f7e6d29ca2c603426258251 days 3 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x2011ff4725475ea4a24c1b05ae2be9c4e35139ca0ca7d3a393bbd12d7da5f7e43426158251 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xc8bfa3e40427bdc86bca94c7e25c01c09b7edfd54ffd1fb21bedc1a81434cc643426115251 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xbd6258d0b9a457018838ab7594e36bef0c86c7406f2fef02e702e1bf882e4a4a3426099251 days 4 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x8e382a97a40e59d88a3d7e82cf06142e26bc32c930b08ca4f46508e97bce672f3289232272 days 8 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xf04937d5918cbd8096f3ef079377ee6a8b114825464371427fd14ccc5f6385d33289200272 days 8 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x7b03904306b4b13ebab4fa7f98a746c9972048b8b643eea2cb60f1e45f4317533289176272 days 9 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xbfed7e40081188bacc71468fa3c52d36dd117df42081f30b5b16634f081063b33103555300 days 5 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xa9604885eb9fd8a8486feb34522f102dd97d8734f1840f54e68cf3f9fa3af99f2839041340 days 20 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0xb64994a1070f6828f304af6b28d093afe3ba7fb04fd477451248fad73c4ae4ae2839009340 days 20 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x23002f980d668f642ef3bf6e91c876a8153e615b6731d7f29b29b5ab8da247a42775600350 days 14 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
0x7ba563ab6c3751939d2ff12e1777f29384b29f52e21f9e051a189d561e0067f12736779356 days 16 hrs ago0xb62af19795ef9208d368a98bbb0e5b5eb93ed2f3  Contract Creation0 Ether
[ Download CSV Export  ] 
Warning: The Compiled Contract might be susceptible to ExpExponentCleanup (medium/high-severity), EventStructWrongData (very low-severity), NestedArrayFunctionCallDecoder (medium-severity) SolidityCompiler Bugs.

Contract Source Code Verified (Exact Match)
Contract Name: BTTSTokenFactory
Compiler Version: v0.4.19+commit.c4cbbb05
Optimization Enabled: Yes
Runs (Optimiser):  200



  Contract Source Code   Find Similiar Contracts

pragma solidity ^0.4.18;

// ----------------------------------------------------------------------------
// BokkyPooBah's Token Teleportation Service v1.10
//
// https://github.com/bokkypoobah/BokkyPooBahsTokenTeleportationServiceSmartContract
//
// Enjoy. (c) BokkyPooBah / Bok Consulting Pty Ltd 2018. The MIT Licence.
// ----------------------------------------------------------------------------


// ----------------------------------------------------------------------------
// ERC Token Standard #20 Interface
// https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20-token-standard.md
// ----------------------------------------------------------------------------
contract ERC20Interface {
    function totalSupply() public view returns (uint);
    function balanceOf(address tokenOwner) public view returns (uint balance);
    function allowance(address tokenOwner, address spender) public view returns (uint remaining);
    function transfer(address to, uint tokens) public returns (bool success);
    function approve(address spender, uint tokens) public returns (bool success);
    function transferFrom(address from, address to, uint tokens) public returns (bool success);

    event Transfer(address indexed from, address indexed to, uint tokens);
    event Approval(address indexed tokenOwner, address indexed spender, uint tokens);
}


// ----------------------------------------------------------------------------
// Contracts that can have tokens approved, and then a function executed
// ----------------------------------------------------------------------------
contract ApproveAndCallFallBack {
    function receiveApproval(address from, uint256 tokens, address token, bytes data) public;
}


// ----------------------------------------------------------------------------
// BokkyPooBah's Token Teleportation Service Interface v1.10
//
// Enjoy. (c) BokkyPooBah / Bok Consulting Pty Ltd 2018. The MIT Licence.
// ----------------------------------------------------------------------------
contract BTTSTokenInterface is ERC20Interface {
    uint public constant bttsVersion = 110;

    bytes public constant signingPrefix = "\x19Ethereum Signed Message:\n32";
    bytes4 public constant signedTransferSig = "\x75\x32\xea\xac";
    bytes4 public constant signedApproveSig = "\xe9\xaf\xa7\xa1";
    bytes4 public constant signedTransferFromSig = "\x34\x4b\xcc\x7d";
    bytes4 public constant signedApproveAndCallSig = "\xf1\x6f\x9b\x53";

    event OwnershipTransferred(address indexed from, address indexed to);
    event MinterUpdated(address from, address to);
    event Mint(address indexed tokenOwner, uint tokens, bool lockAccount);
    event MintingDisabled();
    event TransfersEnabled();
    event AccountUnlocked(address indexed tokenOwner);

    function approveAndCall(address spender, uint tokens, bytes data) public returns (bool success);

    // ------------------------------------------------------------------------
    // signed{X} functions
    // ------------------------------------------------------------------------
    function signedTransferHash(address tokenOwner, address to, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash);
    function signedTransferCheck(address tokenOwner, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result);
    function signedTransfer(address tokenOwner, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success);

    function signedApproveHash(address tokenOwner, address spender, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash);
    function signedApproveCheck(address tokenOwner, address spender, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result);
    function signedApprove(address tokenOwner, address spender, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success);

    function signedTransferFromHash(address spender, address from, address to, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash);
    function signedTransferFromCheck(address spender, address from, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result);
    function signedTransferFrom(address spender, address from, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success);

    function signedApproveAndCallHash(address tokenOwner, address spender, uint tokens, bytes _data, uint fee, uint nonce) public view returns (bytes32 hash);
    function signedApproveAndCallCheck(address tokenOwner, address spender, uint tokens, bytes _data, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result);
    function signedApproveAndCall(address tokenOwner, address spender, uint tokens, bytes _data, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success);

    function mint(address tokenOwner, uint tokens, bool lockAccount) public returns (bool success);
    function unlockAccount(address tokenOwner) public;
    function disableMinting() public;
    function enableTransfers() public;

    // ------------------------------------------------------------------------
    // signed{X}Check return status
    // ------------------------------------------------------------------------
    enum CheckResult {
        Success,                           // 0 Success
        NotTransferable,                   // 1 Tokens not transferable yet
        AccountLocked,                     // 2 Account locked
        SignerMismatch,                    // 3 Mismatch in signing account
        InvalidNonce,                      // 4 Invalid nonce
        InsufficientApprovedTokens,        // 5 Insufficient approved tokens
        InsufficientApprovedTokensForFees, // 6 Insufficient approved tokens for fees
        InsufficientTokens,                // 7 Insufficient tokens
        InsufficientTokensForFees,         // 8 Insufficient tokens for fees
        OverflowError                      // 9 Overflow error
    }
}


// ----------------------------------------------------------------------------
// BokkyPooBah's Token Teleportation Service Library v1.00
//
// Enjoy. (c) BokkyPooBah / Bok Consulting Pty Ltd 2018. The MIT Licence.
// ----------------------------------------------------------------------------
library BTTSLib {
    struct Data {
        bool initialised;

        // Ownership
        address owner;
        address newOwner;

        // Minting and management
        address minter;
        bool mintable;
        bool transferable;
        mapping(address => bool) accountLocked;

        // Token
        string symbol;
        string name;
        uint8 decimals;
        uint totalSupply;
        mapping(address => uint) balances;
        mapping(address => mapping(address => uint)) allowed;
        mapping(address => uint) nextNonce;
    }


    // ------------------------------------------------------------------------
    // Constants
    // ------------------------------------------------------------------------
    uint public constant bttsVersion = 110;
    bytes public constant signingPrefix = "\x19Ethereum Signed Message:\n32";
    bytes4 public constant signedTransferSig = "\x75\x32\xea\xac";
    bytes4 public constant signedApproveSig = "\xe9\xaf\xa7\xa1";
    bytes4 public constant signedTransferFromSig = "\x34\x4b\xcc\x7d";
    bytes4 public constant signedApproveAndCallSig = "\xf1\x6f\x9b\x53";

    // ------------------------------------------------------------------------
    // Event
    // ------------------------------------------------------------------------
    event OwnershipTransferred(address indexed from, address indexed to);
    event MinterUpdated(address from, address to);
    event Mint(address indexed tokenOwner, uint tokens, bool lockAccount);
    event MintingDisabled();
    event TransfersEnabled();
    event AccountUnlocked(address indexed tokenOwner);
    event Transfer(address indexed from, address indexed to, uint tokens);
    event Approval(address indexed tokenOwner, address indexed spender, uint tokens);


    // ------------------------------------------------------------------------
    // Initialisation
    // ------------------------------------------------------------------------
    function init(Data storage self, address owner, string symbol, string name, uint8 decimals, uint initialSupply, bool mintable, bool transferable) public {
        require(!self.initialised);
        self.initialised = true;
        self.owner = owner;
        self.symbol = symbol;
        self.name = name;
        self.decimals = decimals;
        if (initialSupply > 0) {
            self.balances[owner] = initialSupply;
            self.totalSupply = initialSupply;
            Mint(self.owner, initialSupply, false);
            Transfer(address(0), self.owner, initialSupply);
        }
        self.mintable = mintable;
        self.transferable = transferable;
    }

    // ------------------------------------------------------------------------
    // Safe maths, inspired by OpenZeppelin
    // ------------------------------------------------------------------------
    function safeAdd(uint a, uint b) internal pure returns (uint c) {
        c = a + b;
        require(c >= a);
    }
    function safeSub(uint a, uint b) internal pure returns (uint c) {
        require(b <= a);
        c = a - b;
    }
    function safeMul(uint a, uint b) internal pure returns (uint c) {
        c = a * b;
        require(a == 0 || c / a == b);
    }
    function safeDiv(uint a, uint b) internal pure returns (uint c) {
        require(b > 0);
        c = a / b;
    }

    // ------------------------------------------------------------------------
    // Ownership
    // ------------------------------------------------------------------------
    function transferOwnership(Data storage self, address newOwner) public {
        require(msg.sender == self.owner);
        self.newOwner = newOwner;
    }
    function acceptOwnership(Data storage self) public {
        require(msg.sender == self.newOwner);
        OwnershipTransferred(self.owner, self.newOwner);
        self.owner = self.newOwner;
        self.newOwner = address(0);
    }
    function transferOwnershipImmediately(Data storage self, address newOwner) public {
        require(msg.sender == self.owner);
        OwnershipTransferred(self.owner, newOwner);
        self.owner = newOwner;
        self.newOwner = address(0);
    }

    // ------------------------------------------------------------------------
    // Minting and management
    // ------------------------------------------------------------------------
    function setMinter(Data storage self, address minter) public {
        require(msg.sender == self.owner);
        require(self.mintable);
        MinterUpdated(self.minter, minter);
        self.minter = minter;
    }
    function mint(Data storage self, address tokenOwner, uint tokens, bool lockAccount) public returns (bool success) {
        require(self.mintable);
        require(msg.sender == self.minter || msg.sender == self.owner);
        if (lockAccount) {
            self.accountLocked[tokenOwner] = true;
        }
        self.balances[tokenOwner] = safeAdd(self.balances[tokenOwner], tokens);
        self.totalSupply = safeAdd(self.totalSupply, tokens);
        Mint(tokenOwner, tokens, lockAccount);
        Transfer(address(0), tokenOwner, tokens);
        return true;
    }
    function unlockAccount(Data storage self, address tokenOwner) public {
        require(msg.sender == self.owner);
        require(self.accountLocked[tokenOwner]);
        self.accountLocked[tokenOwner] = false;
        AccountUnlocked(tokenOwner);
    }
    function disableMinting(Data storage self) public {
        require(self.mintable);
        require(msg.sender == self.minter || msg.sender == self.owner);
        self.mintable = false;
        if (self.minter != address(0)) {
            MinterUpdated(self.minter, address(0));
            self.minter = address(0);
        }
        MintingDisabled();
    }
    function enableTransfers(Data storage self) public {
        require(msg.sender == self.owner);
        require(!self.transferable);
        self.transferable = true;
        TransfersEnabled();
    }

    // ------------------------------------------------------------------------
    // Other functions
    // ------------------------------------------------------------------------
    function transferAnyERC20Token(Data storage self, address tokenAddress, uint tokens) public returns (bool success) {
        require(msg.sender == self.owner);
        return ERC20Interface(tokenAddress).transfer(self.owner, tokens);
    }

    // ------------------------------------------------------------------------
    // ecrecover from a signature rather than the signature in parts [v, r, s]
    // The signature format is a compact form {bytes32 r}{bytes32 s}{uint8 v}.
    // Compact means, uint8 is not padded to 32 bytes.
    //
    // An invalid signature results in the address(0) being returned, make
    // sure that the returned result is checked to be non-zero for validity
    //
    // Parts from https://gist.github.com/axic/5b33912c6f61ae6fd96d6c4a47afde6d
    // ------------------------------------------------------------------------
    function ecrecoverFromSig(bytes32 hash, bytes sig) public pure returns (address recoveredAddress) {
        bytes32 r;
        bytes32 s;
        uint8 v;
        if (sig.length != 65) return address(0);
        assembly {
            r := mload(add(sig, 32))
            s := mload(add(sig, 64))
            // Here we are loading the last 32 bytes. We exploit the fact that 'mload' will pad with zeroes if we overread.
            // There is no 'mload8' to do this, but that would be nicer.
            v := byte(0, mload(add(sig, 96)))
        }
        // Albeit non-transactional signatures are not specified by the YP, one would expect it to match the YP range of [27, 28]
        // geth uses [0, 1] and some clients have followed. This might change, see https://github.com/ethereum/go-ethereum/issues/2053
        if (v < 27) {
          v += 27;
        }
        if (v != 27 && v != 28) return address(0);
        return ecrecover(hash, v, r, s);
    }

    // ------------------------------------------------------------------------
    // Get CheckResult message
    // ------------------------------------------------------------------------
    function getCheckResultMessage(Data storage /*self*/, BTTSTokenInterface.CheckResult result) public pure returns (string) {
        if (result == BTTSTokenInterface.CheckResult.Success) {
            return "Success";
        } else if (result == BTTSTokenInterface.CheckResult.NotTransferable) {
            return "Tokens not transferable yet";
        } else if (result == BTTSTokenInterface.CheckResult.AccountLocked) {
            return "Account locked";
        } else if (result == BTTSTokenInterface.CheckResult.SignerMismatch) {
            return "Mismatch in signing account";
        } else if (result == BTTSTokenInterface.CheckResult.InvalidNonce) {
            return "Invalid nonce";
        } else if (result == BTTSTokenInterface.CheckResult.InsufficientApprovedTokens) {
            return "Insufficient approved tokens";
        } else if (result == BTTSTokenInterface.CheckResult.InsufficientApprovedTokensForFees) {
            return "Insufficient approved tokens for fees";
        } else if (result == BTTSTokenInterface.CheckResult.InsufficientTokens) {
            return "Insufficient tokens";
        } else if (result == BTTSTokenInterface.CheckResult.InsufficientTokensForFees) {
            return "Insufficient tokens for fees";
        } else if (result == BTTSTokenInterface.CheckResult.OverflowError) {
            return "Overflow error";
        } else {
            return "Unknown error";
        }
    }

    // ------------------------------------------------------------------------
    // Token functions
    // ------------------------------------------------------------------------
    function transfer(Data storage self, address to, uint tokens) public returns (bool success) {
        // Owner and minter can move tokens before the tokens are transferable
        require(self.transferable || (self.mintable && (msg.sender == self.owner  || msg.sender == self.minter)));
        require(!self.accountLocked[msg.sender]);
        self.balances[msg.sender] = safeSub(self.balances[msg.sender], tokens);
        self.balances[to] = safeAdd(self.balances[to], tokens);
        Transfer(msg.sender, to, tokens);
        return true;
    }
    function approve(Data storage self, address spender, uint tokens) public returns (bool success) {
        require(!self.accountLocked[msg.sender]);
        self.allowed[msg.sender][spender] = tokens;
        Approval(msg.sender, spender, tokens);
        return true;
    }
    function transferFrom(Data storage self, address from, address to, uint tokens) public returns (bool success) {
        require(self.transferable);
        require(!self.accountLocked[from]);
        self.balances[from] = safeSub(self.balances[from], tokens);
        self.allowed[from][msg.sender] = safeSub(self.allowed[from][msg.sender], tokens);
        self.balances[to] = safeAdd(self.balances[to], tokens);
        Transfer(from, to, tokens);
        return true;
    }
    function approveAndCall(Data storage self, address spender, uint tokens, bytes data) public returns (bool success) {
        require(!self.accountLocked[msg.sender]);
        self.allowed[msg.sender][spender] = tokens;
        Approval(msg.sender, spender, tokens);
        ApproveAndCallFallBack(spender).receiveApproval(msg.sender, tokens, address(this), data);
        return true;
    }

    // ------------------------------------------------------------------------
    // Signed function
    // ------------------------------------------------------------------------
    function signedTransferHash(Data storage /*self*/, address tokenOwner, address to, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash) {
        hash = keccak256(signedTransferSig, address(this), tokenOwner, to, tokens, fee, nonce);
    }
    function signedTransferCheck(Data storage self, address tokenOwner, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (BTTSTokenInterface.CheckResult result) {
        if (!self.transferable) return BTTSTokenInterface.CheckResult.NotTransferable;
        bytes32 hash = signedTransferHash(self, tokenOwner, to, tokens, fee, nonce);
        if (tokenOwner == address(0) || tokenOwner != ecrecoverFromSig(keccak256(signingPrefix, hash), sig)) return BTTSTokenInterface.CheckResult.SignerMismatch;
        if (self.accountLocked[tokenOwner]) return BTTSTokenInterface.CheckResult.AccountLocked;
        if (self.nextNonce[tokenOwner] != nonce) return BTTSTokenInterface.CheckResult.InvalidNonce;
        uint total = safeAdd(tokens, fee);
        if (self.balances[tokenOwner] < tokens) return BTTSTokenInterface.CheckResult.InsufficientTokens;
        if (self.balances[tokenOwner] < total) return BTTSTokenInterface.CheckResult.InsufficientTokensForFees;
        if (self.balances[to] + tokens < self.balances[to]) return BTTSTokenInterface.CheckResult.OverflowError;
        if (self.balances[feeAccount] + fee < self.balances[feeAccount]) return BTTSTokenInterface.CheckResult.OverflowError;
        return BTTSTokenInterface.CheckResult.Success;
    }
    function signedTransfer(Data storage self, address tokenOwner, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        require(self.transferable);
        bytes32 hash = signedTransferHash(self, tokenOwner, to, tokens, fee, nonce);
        require(tokenOwner != address(0) && tokenOwner == ecrecoverFromSig(keccak256(signingPrefix, hash), sig));
        require(!self.accountLocked[tokenOwner]);
        require(self.nextNonce[tokenOwner] == nonce);
        self.nextNonce[tokenOwner] = nonce + 1;
        self.balances[tokenOwner] = safeSub(self.balances[tokenOwner], tokens);
        self.balances[to] = safeAdd(self.balances[to], tokens);
        Transfer(tokenOwner, to, tokens);
        self.balances[tokenOwner] = safeSub(self.balances[tokenOwner], fee);
        self.balances[feeAccount] = safeAdd(self.balances[feeAccount], fee);
        Transfer(tokenOwner, feeAccount, fee);
        return true;
    }
    function signedApproveHash(Data storage /*self*/, address tokenOwner, address spender, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash) {
        hash = keccak256(signedApproveSig, address(this), tokenOwner, spender, tokens, fee, nonce);
    }
    function signedApproveCheck(Data storage self, address tokenOwner, address spender, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (BTTSTokenInterface.CheckResult result) {
        if (!self.transferable) return BTTSTokenInterface.CheckResult.NotTransferable;
        bytes32 hash = signedApproveHash(self, tokenOwner, spender, tokens, fee, nonce);
        if (tokenOwner == address(0) || tokenOwner != ecrecoverFromSig(keccak256(signingPrefix, hash), sig)) return BTTSTokenInterface.CheckResult.SignerMismatch;
        if (self.accountLocked[tokenOwner]) return BTTSTokenInterface.CheckResult.AccountLocked;
        if (self.nextNonce[tokenOwner] != nonce) return BTTSTokenInterface.CheckResult.InvalidNonce;
        if (self.balances[tokenOwner] < fee) return BTTSTokenInterface.CheckResult.InsufficientTokensForFees;
        if (self.balances[feeAccount] + fee < self.balances[feeAccount]) return BTTSTokenInterface.CheckResult.OverflowError;
        return BTTSTokenInterface.CheckResult.Success;
    }
    function signedApprove(Data storage self, address tokenOwner, address spender, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        require(self.transferable);
        bytes32 hash = signedApproveHash(self, tokenOwner, spender, tokens, fee, nonce);
        require(tokenOwner != address(0) && tokenOwner == ecrecoverFromSig(keccak256(signingPrefix, hash), sig));
        require(!self.accountLocked[tokenOwner]);
        require(self.nextNonce[tokenOwner] == nonce);
        self.nextNonce[tokenOwner] = nonce + 1;
        self.allowed[tokenOwner][spender] = tokens;
        Approval(tokenOwner, spender, tokens);
        self.balances[tokenOwner] = safeSub(self.balances[tokenOwner], fee);
        self.balances[feeAccount] = safeAdd(self.balances[feeAccount], fee);
        Transfer(tokenOwner, feeAccount, fee);
        return true;
    }
    function signedTransferFromHash(Data storage /*self*/, address spender, address from, address to, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash) {
        hash = keccak256(signedTransferFromSig, address(this), spender, from, to, tokens, fee, nonce);
    }
    function signedTransferFromCheck(Data storage self, address spender, address from, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (BTTSTokenInterface.CheckResult result) {
        if (!self.transferable) return BTTSTokenInterface.CheckResult.NotTransferable;
        bytes32 hash = signedTransferFromHash(self, spender, from, to, tokens, fee, nonce);
        if (spender == address(0) || spender != ecrecoverFromSig(keccak256(signingPrefix, hash), sig)) return BTTSTokenInterface.CheckResult.SignerMismatch;
        if (self.accountLocked[from]) return BTTSTokenInterface.CheckResult.AccountLocked;
        if (self.nextNonce[spender] != nonce) return BTTSTokenInterface.CheckResult.InvalidNonce;
        uint total = safeAdd(tokens, fee);
        if (self.allowed[from][spender] < tokens) return BTTSTokenInterface.CheckResult.InsufficientApprovedTokens;
        if (self.allowed[from][spender] < total) return BTTSTokenInterface.CheckResult.InsufficientApprovedTokensForFees;
        if (self.balances[from] < tokens) return BTTSTokenInterface.CheckResult.InsufficientTokens;
        if (self.balances[from] < total) return BTTSTokenInterface.CheckResult.InsufficientTokensForFees;
        if (self.balances[to] + tokens < self.balances[to]) return BTTSTokenInterface.CheckResult.OverflowError;
        if (self.balances[feeAccount] + fee < self.balances[feeAccount]) return BTTSTokenInterface.CheckResult.OverflowError;
        return BTTSTokenInterface.CheckResult.Success;
    }
    function signedTransferFrom(Data storage self, address spender, address from, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        require(self.transferable);
        bytes32 hash = signedTransferFromHash(self, spender, from, to, tokens, fee, nonce);
        require(spender != address(0) && spender == ecrecoverFromSig(keccak256(signingPrefix, hash), sig));
        require(!self.accountLocked[from]);
        require(self.nextNonce[spender] == nonce);
        self.nextNonce[spender] = nonce + 1;
        self.balances[from] = safeSub(self.balances[from], tokens);
        self.allowed[from][spender] = safeSub(self.allowed[from][spender], tokens);
        self.balances[to] = safeAdd(self.balances[to], tokens);
        Transfer(from, to, tokens);
        self.balances[from] = safeSub(self.balances[from], fee);
        self.allowed[from][spender] = safeSub(self.allowed[from][spender], fee);
        self.balances[feeAccount] = safeAdd(self.balances[feeAccount], fee);
        Transfer(from, feeAccount, fee);
        return true;
    }
    function signedApproveAndCallHash(Data storage /*self*/, address tokenOwner, address spender, uint tokens, bytes data, uint fee, uint nonce) public view returns (bytes32 hash) {
        hash = keccak256(signedApproveAndCallSig, address(this), tokenOwner, spender, tokens, data, fee, nonce);
    }
    function signedApproveAndCallCheck(Data storage self, address tokenOwner, address spender, uint tokens, bytes data, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (BTTSTokenInterface.CheckResult result) {
        if (!self.transferable) return BTTSTokenInterface.CheckResult.NotTransferable;
        bytes32 hash = signedApproveAndCallHash(self, tokenOwner, spender, tokens, data, fee, nonce);
        if (tokenOwner == address(0) || tokenOwner != ecrecoverFromSig(keccak256(signingPrefix, hash), sig)) return BTTSTokenInterface.CheckResult.SignerMismatch;
        if (self.accountLocked[tokenOwner]) return BTTSTokenInterface.CheckResult.AccountLocked;
        if (self.nextNonce[tokenOwner] != nonce) return BTTSTokenInterface.CheckResult.InvalidNonce;
        if (self.balances[tokenOwner] < fee) return BTTSTokenInterface.CheckResult.InsufficientTokensForFees;
        if (self.balances[feeAccount] + fee < self.balances[feeAccount]) return BTTSTokenInterface.CheckResult.OverflowError;
        return BTTSTokenInterface.CheckResult.Success;
    }
    function signedApproveAndCall(Data storage self, address tokenOwner, address spender, uint tokens, bytes data, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        require(self.transferable);
        bytes32 hash = signedApproveAndCallHash(self, tokenOwner, spender, tokens, data, fee, nonce);
        require(tokenOwner != address(0) && tokenOwner == ecrecoverFromSig(keccak256(signingPrefix, hash), sig));
        require(!self.accountLocked[tokenOwner]);
        require(self.nextNonce[tokenOwner] == nonce);
        self.nextNonce[tokenOwner] = nonce + 1;
        self.allowed[tokenOwner][spender] = tokens;
        Approval(tokenOwner, spender, tokens);
        self.balances[tokenOwner] = safeSub(self.balances[tokenOwner], fee);
        self.balances[feeAccount] = safeAdd(self.balances[feeAccount], fee);
        Transfer(tokenOwner, feeAccount, fee);
        ApproveAndCallFallBack(spender).receiveApproval(tokenOwner, tokens, address(this), data);
        return true;
    }
}


// ----------------------------------------------------------------------------
// BokkyPooBah's Token Teleportation Service Token v1.10
//
// Enjoy. (c) BokkyPooBah / Bok Consulting Pty Ltd 2018. The MIT Licence.
// ----------------------------------------------------------------------------
contract BTTSToken is BTTSTokenInterface {
    using BTTSLib for BTTSLib.Data;

    BTTSLib.Data data;

    // ------------------------------------------------------------------------
    // Constructor
    // ------------------------------------------------------------------------
    function BTTSToken(address owner, string symbol, string name, uint8 decimals, uint initialSupply, bool mintable, bool transferable) public {
        data.init(owner, symbol, name, decimals, initialSupply, mintable, transferable);
    }

    // ------------------------------------------------------------------------
    // Ownership
    // ------------------------------------------------------------------------
    function owner() public view returns (address) {
        return data.owner;
    }
    function newOwner() public view returns (address) {
        return data.newOwner;
    }
    function transferOwnership(address _newOwner) public {
        data.transferOwnership(_newOwner);
    }
    function acceptOwnership() public {
        data.acceptOwnership();
    }
    function transferOwnershipImmediately(address _newOwner) public {
        data.transferOwnershipImmediately(_newOwner);
    }

    // ------------------------------------------------------------------------
    // Token
    // ------------------------------------------------------------------------
    function symbol() public view returns (string) {
        return data.symbol;
    }
    function name() public view returns (string) {
        return data.name;
    }
    function decimals() public view returns (uint8) {
        return data.decimals;
    }

    // ------------------------------------------------------------------------
    // Minting and management
    // ------------------------------------------------------------------------
    function minter() public view returns (address) {
        return data.minter;
    }
    function setMinter(address _minter) public {
        data.setMinter(_minter);
    }
    function mint(address tokenOwner, uint tokens, bool lockAccount) public returns (bool success) {
        return data.mint(tokenOwner, tokens, lockAccount);
    }
    function accountLocked(address tokenOwner) public view returns (bool) {
        return data.accountLocked[tokenOwner];
    }
    function unlockAccount(address tokenOwner) public {
        data.unlockAccount(tokenOwner);
    }
    function mintable() public view returns (bool) {
        return data.mintable;
    }
    function transferable() public view returns (bool) {
        return data.transferable;
    }
    function disableMinting() public {
        data.disableMinting();
    }
    function enableTransfers() public {
        data.enableTransfers();
    }
    function nextNonce(address spender) public view returns (uint) {
        return data.nextNonce[spender];
    }

    // ------------------------------------------------------------------------
    // Other functions
    // ------------------------------------------------------------------------
    function transferAnyERC20Token(address tokenAddress, uint tokens) public returns (bool success) {
        return data.transferAnyERC20Token(tokenAddress, tokens);
    }

    // ------------------------------------------------------------------------
    // Don't accept ethers
    // ------------------------------------------------------------------------
    function () public payable {
        revert();
    }

    // ------------------------------------------------------------------------
    // Token functions
    // ------------------------------------------------------------------------
    function totalSupply() public view returns (uint) {
        return data.totalSupply - data.balances[address(0)];
    }
    function balanceOf(address tokenOwner) public view returns (uint balance) {
        return data.balances[tokenOwner];
    }
    function allowance(address tokenOwner, address spender) public view returns (uint remaining) {
        return data.allowed[tokenOwner][spender];
    }
    function transfer(address to, uint tokens) public returns (bool success) {
        return data.transfer(to, tokens);
    }
    function approve(address spender, uint tokens) public returns (bool success) {
        return data.approve(spender, tokens);
    }
    function transferFrom(address from, address to, uint tokens) public returns (bool success) {
        return data.transferFrom(from, to, tokens);
    }
    function approveAndCall(address spender, uint tokens, bytes _data) public returns (bool success) {
        return data.approveAndCall(spender, tokens, _data);
    }

    // ------------------------------------------------------------------------
    // Signed function
    // ------------------------------------------------------------------------
    function signedTransferHash(address tokenOwner, address to, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash) {
        return data.signedTransferHash(tokenOwner, to, tokens, fee, nonce);
    }
    function signedTransferCheck(address tokenOwner, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result) {
        return data.signedTransferCheck(tokenOwner, to, tokens, fee, nonce, sig, feeAccount);
    }
    function signedTransfer(address tokenOwner, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        return data.signedTransfer(tokenOwner, to, tokens, fee, nonce, sig, feeAccount);
    }
    function signedApproveHash(address tokenOwner, address spender, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash) {
        return data.signedApproveHash(tokenOwner, spender, tokens, fee, nonce);
    }
    function signedApproveCheck(address tokenOwner, address spender, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result) {
        return data.signedApproveCheck(tokenOwner, spender, tokens, fee, nonce, sig, feeAccount);
    }
    function signedApprove(address tokenOwner, address spender, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        return data.signedApprove(tokenOwner, spender, tokens, fee, nonce, sig, feeAccount);
    }
    function signedTransferFromHash(address spender, address from, address to, uint tokens, uint fee, uint nonce) public view returns (bytes32 hash) {
        return data.signedTransferFromHash(spender, from, to, tokens, fee, nonce);
    }
    function signedTransferFromCheck(address spender, address from, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result) {
        return data.signedTransferFromCheck(spender, from, to, tokens, fee, nonce, sig, feeAccount);
    }
    function signedTransferFrom(address spender, address from, address to, uint tokens, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        return data.signedTransferFrom(spender, from, to, tokens, fee, nonce, sig, feeAccount);
    }
    function signedApproveAndCallHash(address tokenOwner, address spender, uint tokens, bytes _data, uint fee, uint nonce) public view returns (bytes32 hash) {
        return data.signedApproveAndCallHash(tokenOwner, spender, tokens, _data, fee, nonce);
    }
    function signedApproveAndCallCheck(address tokenOwner, address spender, uint tokens, bytes _data, uint fee, uint nonce, bytes sig, address feeAccount) public view returns (CheckResult result) {
        return data.signedApproveAndCallCheck(tokenOwner, spender, tokens, _data, fee, nonce, sig, feeAccount);
    }
    function signedApproveAndCall(address tokenOwner, address spender, uint tokens, bytes _data, uint fee, uint nonce, bytes sig, address feeAccount) public returns (bool success) {
        return data.signedApproveAndCall(tokenOwner, spender, tokens, _data, fee, nonce, sig, feeAccount);
    }
}

// ----------------------------------------------------------------------------
// Owned contract
// ----------------------------------------------------------------------------
contract Owned {
    address public owner;
    address public newOwner;
    event OwnershipTransferred(address indexed _from, address indexed _to);

    function Owned() public {
        owner = msg.sender;
    }
    modifier onlyOwner {
        require(msg.sender == owner);
        _;
    }
    function transferOwnership(address _newOwner) public onlyOwner {
        newOwner = _newOwner;
    }
    function acceptOwnership() public {
        require(msg.sender == newOwner);
        OwnershipTransferred(owner, newOwner);
        owner = newOwner;
        newOwner = address(0);
    }
    function transferOwnershipImmediately(address _newOwner) public onlyOwner {
        OwnershipTransferred(owner, _newOwner);
        owner = _newOwner;
        newOwner = address(0);
    }
}


// ----------------------------------------------------------------------------
// BokkyPooBah's Token Teleportation Service Token Factory v1.10
//
// Enjoy. (c) BokkyPooBah / Bok Consulting Pty Ltd 2018. The MIT Licence.
// ----------------------------------------------------------------------------
contract BTTSTokenFactory is Owned {

    // ------------------------------------------------------------------------
    // Internal data
    // ------------------------------------------------------------------------
    mapping(address => bool) _verify;
    address[] public deployedTokens;

    // ------------------------------------------------------------------------
    // Event
    // ------------------------------------------------------------------------
    event BTTSTokenListing(address indexed ownerAddress,
        address indexed bttsTokenAddress,
        string symbol, string name, uint8 decimals,
        uint initialSupply, bool mintable, bool transferable);


    // ------------------------------------------------------------------------
    // Anyone can call this method to verify whether the bttsToken contract at
    // the specified address was deployed using this factory
    //
    // Parameters:
    //   tokenContract  the bttsToken contract address
    //
    // Return values:
    //   valid          did this BTTSTokenFactory create the BTTSToken contract?
    //   decimals       number of decimal places for the token contract
    //   initialSupply  the token initial supply
    //   mintable       is the token mintable after deployment?
    //   transferable   are the tokens transferable after deployment?
    // ------------------------------------------------------------------------
    function verify(address tokenContract) public view returns (
        bool    valid,
        address owner,
        uint    decimals,
        bool    mintable,
        bool    transferable
    ) {
        valid = _verify[tokenContract];
        if (valid) {
            BTTSToken t = BTTSToken(tokenContract);
            owner        = t.owner();
            decimals     = t.decimals();
            mintable     = t.mintable();
            transferable = t.transferable();
        }
    }


    // ------------------------------------------------------------------------
    // Any account can call this method to deploy a new BTTSToken contract.
    // The owner of the BTTSToken contract will be the calling account
    //
    // Parameters:
    //   symbol         symbol
    //   name           name
    //   decimals       number of decimal places for the token contract
    //   initialSupply  the token initial supply
    //   mintable       is the token mintable after deployment?
    //   transferable   are the tokens transferable after deployment?
    //
    // For example, deploying a BTTSToken contract with `initialSupply` of
    // 1,000.000000000000000000 tokens:
    //   symbol         "ME"
    //   name           "My Token"
    //   decimals       18
    //   initialSupply  10000000000000000000000 = 1,000.000000000000000000
    //                  tokens
    //   mintable       can tokens be minted after deployment?
    //   transferable   are the tokens transferable after deployment?
    //
    // The BTTSTokenListing() event is logged with the following parameters
    //   owner          the account that execute this transaction
    //   symbol         symbol
    //   name           name
    //   decimals       number of decimal places for the token contract
    //   initialSupply  the token initial supply
    //   mintable       can tokens be minted after deployment?
    //   transferable   are the tokens transferable after deployment?
    // ------------------------------------------------------------------------
    function deployBTTSTokenContract(
        string symbol,
        string name,
        uint8 decimals,
        uint initialSupply,
        bool mintable,
        bool transferable
    ) public returns (address bttsTokenAddress) {
        bttsTokenAddress = new BTTSToken(
            msg.sender,
            symbol,
            name,
            decimals,
            initialSupply,
            mintable,
            transferable);
        // Record that this factory created the trader
        _verify[bttsTokenAddress] = true;
        deployedTokens.push(bttsTokenAddress);
        BTTSTokenListing(msg.sender, bttsTokenAddress, symbol, name, decimals,
            initialSupply, mintable, transferable);
    }


    // ------------------------------------------------------------------------
    // Number of deployed tokens
    // ------------------------------------------------------------------------
    function numberOfDeployedTokens() public view returns (uint) {
        return deployedTokens.length;
    }

    // ------------------------------------------------------------------------
    // Factory owner can transfer out any accidentally sent ERC20 tokens
    //
    // Parameters:
    //   tokenAddress  contract address of the token contract being withdrawn
    //                 from
    //   tokens        number of tokens
    // ------------------------------------------------------------------------
    function transferAnyERC20Token(address tokenAddress, uint tokens) public onlyOwner returns (bool success) {
        return ERC20Interface(tokenAddress).transfer(owner, tokens);
    }

    // ------------------------------------------------------------------------
    // Don't accept ethers
    // ------------------------------------------------------------------------
    function () public payable {
        revert();
    }
}

    Contract ABI  
[{"constant":false,"inputs":[{"name":"symbol","type":"string"},{"name":"name","type":"string"},{"name":"decimals","type":"uint8"},{"name":"initialSupply","type":"uint256"},{"name":"mintable","type":"bool"},{"name":"transferable","type":"bool"}],"name":"deployBTTSTokenContract","outputs":[{"name":"bttsTokenAddress","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"numberOfDeployedTokens","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"tokenContract","type":"address"}],"name":"verify","outputs":[{"name":"valid","type":"bool"},{"name":"owner","type":"address"},{"name":"decimals","type":"uint256"},{"name":"mintable","type":"bool"},{"name":"transferable","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"acceptOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_newOwner","type":"address"}],"name":"transferOwnershipImmediately","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"newOwner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"tokenAddress","type":"address"},{"name":"tokens","type":"uint256"}],"name":"transferAnyERC20Token","outputs":[{"name":"success","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"","type":"uint256"}],"name":"deployedTokens","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"anonymous":false,"inputs":[{"indexed":true,"name":"ownerAddress","type":"address"},{"indexed":true,"name":"bttsTokenAddress","type":"address"},{"indexed":false,"name":"symbol","type":"string"},{"indexed":false,"name":"name","type":"string"},{"indexed":false,"name":"decimals","type":"uint8"},{"indexed":false,"name":"initialSupply","type":"uint256"},{"indexed":false,"name":"mintable","type":"bool"},{"indexed":false,"name":"transferable","type":"bool"}],"name":"BTTSTokenListing","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"_from","type":"address"},{"indexed":true,"name":"_to","type":"address"}],"name":"OwnershipTransferred","type":"event"}]

  Contract Creation Code Switch To Opcodes View
606060405260008054600160a060020a033316600160a060020a0319909116179055612c21806100306000396000f30060606040526004361061008a5763ffffffff60e060020a60003504166308796ea0811461008f5780635cd3b9171461015757806363a9c3d71461017c57806379ba5097146101d85780637e71fb09146101ed5780638da5cb5b1461020c578063d4ee1d901461021f578063dc39d06d14610232578063ec81aadb14610268578063f2fde38b1461027e575b600080fd5b341561009a57600080fd5b61013b60046024813581810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284378201915050505050509190803590602001908201803590602001908080601f0160208091040260200160405190810160405281815292919060208401838380828437509496505050833560ff169360208101359350604081013515159250606001351515905061029d565b604051600160a060020a03909116815260200160405180910390f35b341561016257600080fd5b61016a610576565b60405190815260200160405180910390f35b341561018757600080fd5b61019b600160a060020a036004351661057d565b6040519415158552600160a060020a03909316602085015260408085019290925215156060840152901515608083015260a0909101905180910390f35b34156101e357600080fd5b6101eb61073c565b005b34156101f857600080fd5b6101eb600160a060020a03600435166107ca565b341561021757600080fd5b61013b610857565b341561022a57600080fd5b61013b610866565b341561023d57600080fd5b610254600160a060020a0360043516602435610875565b604051901515815260200160405180910390f35b341561027357600080fd5b61013b600435610918565b341561028957600080fd5b6101eb600160a060020a0360043516610940565b6000338787878787876102ae61098a565b600160a060020a038816815260ff851660608201526080810184905282151560a082015281151560c082015260e060208201818152906040830190830189818151815260200191508051906020019080838360005b8381101561031b578082015183820152602001610303565b50505050905090810190601f1680156103485780820380516001836020036101000a031916815260200191505b50838103825288818151815260200191508051906020019080838360005b8381101561037e578082015183820152602001610366565b50505050905090810190601f1680156103ab5780820380516001836020036101000a031916815260200191505b509950505050505050505050604051809103906000f08015156103cd57600080fd5b600160a060020a0381166000908152600260205260409020805460ff191660019081179091556003805492935091908101610408838261099a565b506000918252602090912001805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a038381169182179092559033167f433b409f8a018a898964fd9c3ce44391119baeb70fcf0dde007576288c61626089898989898960405160ff8516604082015260608101849052821515608082015281151560a082015260c080825281906020820190820189818151815260200191508051906020019080838360005b838110156104c95780820151838201526020016104b1565b50505050905090810190601f1680156104f65780820380516001836020036101000a031916815260200191505b50838103825288818151815260200191508051906020019080838360005b8381101561052c578082015183820152602001610514565b50505050905090810190601f1680156105595780820380516001836020036101000a031916815260200191505b509850505050505050505060405180910390a39695505050505050565b6003545b90565b600160a060020a03811660009081526002602052604081205460ff1690808080808515610732575085600160a060020a038116638da5cb5b6000604051602001526040518163ffffffff1660e060020a028152600401602060405180830381600087803b15156105ec57600080fd5b6102c65a03f115156105fd57600080fd5b5050506040518051955050600160a060020a03811663313ce5676000604051602001526040518163ffffffff1660e060020a028152600401602060405180830381600087803b151561064e57600080fd5b6102c65a03f1151561065f57600080fd5b505050604051805160ff16945050600160a060020a038116634bf365df6000604051602001526040518163ffffffff1660e060020a028152600401602060405180830381600087803b15156106b357600080fd5b6102c65a03f115156106c457600080fd5b5050506040518051935050600160a060020a0381166392ff0d316000604051602001526040518163ffffffff1660e060020a028152600401602060405180830381600087803b151561071557600080fd5b6102c65a03f1151561072657600080fd5b50505060405180519250505b5091939590929450565b60015433600160a060020a0390811691161461075757600080fd5b600154600054600160a060020a0391821691167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3600180546000805473ffffffffffffffffffffffffffffffffffffffff19908116600160a060020a03841617909155169055565b60005433600160a060020a039081169116146107e557600080fd5b600054600160a060020a0380831691167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008054600160a060020a0390921673ffffffffffffffffffffffffffffffffffffffff19928316179055600180549091169055565b600054600160a060020a031681565b600154600160a060020a031681565b6000805433600160a060020a0390811691161461089157600080fd5b60008054600160a060020a038086169263a9059cbb929091169085906040516020015260405160e060020a63ffffffff8516028152600160a060020a0390921660048301526024820152604401602060405180830381600087803b15156108f757600080fd5b6102c65a03f1151561090857600080fd5b5050506040518051949350505050565b600380548290811061092657fe5b600091825260209091200154600160a060020a0316905081565b60005433600160a060020a0390811691161461095b57600080fd5b6001805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0392909216919091179055565b604051612214806109e283390190565b8154818355818115116109be576000838152602090206109be9181019083016109c3565b505050565b61057a91905b808211156109dd57600081556001016109c9565b50905600606060405234156200001057600080fd5b60405162002214380380620022148339810160405280805191906020018051820191906020018051820191906020018051919060200180519190602001805191906020018051915073db53a3db5d9224fce5ab4459ae008bd2a43af74290506335659df96000898989898989896040517c010000000000000000000000000000000000000000000000000000000063ffffffff8b1602815260048101898152600160a060020a038916602483015260ff8616608483015260a4820185905283151560c483015282151560e483015261010060448301908152909160648101906101040189818151815260200191508051906020019080838360005b83811015620001255780820151838201526020016200010b565b50505050905090810190601f168015620001535780820380516001836020036101000a031916815260200191505b50838103825288818151815260200191508051906020019080838360005b838110156200018b57808201518382015260200162000171565b50505050905090810190601f168015620001b95780820380516001836020036101000a031916815260200191505b509a505050505050505050505060006040518083038186803b1515620001de57600080fd5b6102c65a03f41515620001f057600080fd5b5050505050505050505061200a806200020a6000396000f3006060604052600436106102005763ffffffff60e060020a60003504166305a5f830811461020557806306fdde031461028a5780630754617214610314578063095ea7b3146103435780630cd55abf146103795780631296d47d1461039857806318160ddd146103c65780631a2b3adf146103d9578063233907a31461040d57806323b872dd14610455578063313ce5671461047d578063344bcc7d146104a65780634bf365df1461052a578063500b94261461053d5780635b1ea8581461055c57806370a082311461056f5780637532eaac1461058e57806379ba50971461060d5780637c0fbc31146106225780637e5cd5c1146106c55780637e71fb09146106d857806389443aac146106f75780638da5cb5b1461070a578063905295e31461071d57806392ff0d311461073c57806395d89b411461074f578063965b0cc41461076257806396cfd12414610824578063a3fc136a14610852578063a9059cbb14610865578063af35c6c714610887578063c14a932f1461089a578063c7a86e33146108ad578063cae9ca511461092c578063d1a1beb414610991578063d4ee1d90146109b8578063dc39d06d146109cb578063dd62ed3e146109ed578063e2cc7a5114610a12578063e9afa7a114610a25578063f16f9b5314610aa4578063f2fde38b14610b66578063f30d4d3f14610b85578063fca3b5aa14610c09575b600080fd5b341561021057600080fd5b610278600160a060020a036004803582169160248035909116916044359160849060643590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094965050843594602001359350610c2892505050565b60405190815260200160405180910390f35b341561029557600080fd5b61029d610d5e565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156102d95780820151838201526020016102c1565b50505050905090810190601f1680156103065780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561031f57600080fd5b610327610e07565b604051600160a060020a03909116815260200160405180910390f35b341561034e57600080fd5b610365600160a060020a0360043516602435610e16565b604051901515815260200160405180910390f35b341561038457600080fd5b610278600160a060020a0360043516610ea7565b34156103a357600080fd5b610278600160a060020a0360043581169060243516604435606435608435610ec2565b34156103d157600080fd5b610278610f6f565b34156103e457600080fd5b610278600160a060020a036004358116906024358116906044351660643560843560a435610fa1565b341561041857600080fd5b610420611036565b6040517fffffffff00000000000000000000000000000000000000000000000000000000909116815260200160405180910390f35b341561046057600080fd5b610365600160a060020a036004358116906024351660443561105a565b341561048857600080fd5b6104906110f4565b60405160ff909116815260200160405180910390f35b34156104b157600080fd5b61036560048035600160a060020a0390811691602480358316926044351691606435916084359160a4359160e49060c43590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094965050509235600160a060020a031692506110fd915050565b341561053557600080fd5b610365611238565b341561054857600080fd5b610365600160a060020a0360043516611259565b341561056757600080fd5b610420611277565b341561057a57600080fd5b610278600160a060020a036004351661129b565b341561059957600080fd5b610365600160a060020a0360048035821691602480359091169160443591606435916084359160c49060a43590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094965050509235600160a060020a031692506112b6915050565b341561061857600080fd5b6106206113e5565b005b341561062d57600080fd5b6106a1600160a060020a0360048035821691602480359091169160443591606435916084359160c49060a43590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094965050509235600160a060020a0316925061144b915050565b604051808260098111156106b157fe5b60ff16815260200191505060405180910390f35b34156106d057600080fd5b610620611503565b34156106e357600080fd5b610620600160a060020a0360043516611553565b341561070257600080fd5b6102786115c9565b341561071557600080fd5b6103276115ce565b341561072857600080fd5b610620600160a060020a03600435166115e2565b341561074757600080fd5b610365611641565b341561075a57600080fd5b61029d611663565b341561076d57600080fd5b6106a1600160a060020a036004803582169160248035909116916044359160849060643590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094968635966020808201359750919550606081019450604090810135860180830194503592508291601f83018190048102019051908101604052818152929190602084018383808284375094965050509235600160a060020a031692506116d7915050565b341561082f57600080fd5b610278600160a060020a036004358116906024351660443560643560843561184c565b341561085d57600080fd5b6104206118d5565b341561087057600080fd5b610365600160a060020a03600435166024356118f9565b341561089257600080fd5b610620611969565b34156108a557600080fd5b6104206119b9565b34156108b857600080fd5b6106a1600160a060020a0360048035821691602480359091169160443591606435916084359160c49060a43590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094965050509235600160a060020a031692506119dd915050565b341561093757600080fd5b61036560048035600160a060020a03169060248035919060649060443590810190830135806020601f82018190048102016040519081016040528181529291906020840183838082843750949650611a9595505050505050565b341561099c57600080fd5b610365600160a060020a03600435166024356044351515611b7c565b34156109c357600080fd5b610327611bf4565b34156109d657600080fd5b610365600160a060020a0360043516602435611c03565b34156109f857600080fd5b610278600160a060020a0360043581169060243516611c73565b3415610a1d57600080fd5b61029d611c9e565b3415610a3057600080fd5b610365600160a060020a0360048035821691602480359091169160443591606435916084359160c49060a43590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094965050509235600160a060020a03169250611cd5915050565b3415610aaf57600080fd5b610365600160a060020a036004803582169160248035909116916044359160849060643590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094968635966020808201359750919550606081019450604090810135860180830194503592508291601f83018190048102019051908101604052818152929190602084018383808284375094965050509235600160a060020a03169250611d8d915050565b3415610b7157600080fd5b610620600160a060020a0360043516611e4c565b3415610b9057600080fd5b6106a160048035600160a060020a0390811691602480358316926044351691606435916084359160a4359160e49060c43590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284375094965050509235600160a060020a03169250611eab915050565b3415610c1457600080fd5b610620600160a060020a0360043516611f6d565b600073db53a3db5d9224fce5ab4459ae008bd2a43af74263ed3b174b8289898989898986604051602001526040518863ffffffff1660e060020a0281526004018088815260200187600160a060020a0316600160a060020a0316815260200186600160a060020a0316600160a060020a0316815260200185815260200180602001848152602001838152602001828103825285818151815260200191508051906020019080838360005b83811015610cea578082015183820152602001610cd2565b50505050905090810190601f168015610d175780820380516001836020036101000a031916815260200191505b509850505050505050505060206040518083038186803b1515610d3957600080fd5b6102c65a03f41515610d4a57600080fd5b505050604051805198975050505050505050565b610d66611fcc565b60058054600260001961010060018416150201909116046020601f82018190048102016040519081016040528092919081815260200182805460018160011615610100020316600290048015610dfd5780601f10610dd257610100808354040283529160200191610dfd565b820191906000526020600020905b815481529060010190602001808311610de057829003601f168201915b5050505050905090565b600254600160a060020a031690565b600073db53a3db5d9224fce5ab4459ae008bd2a43af74263bed568f7828585826040516020015260405160e060020a63ffffffff86160281526004810193909352600160a060020a039091166024830152604482015260640160206040518083038186803b1515610e8657600080fd5b6102c65a03f41515610e9757600080fd5b5050506040518051949350505050565b600160a060020a03166000908152600a602052604090205490565b600073db53a3db5d9224fce5ab4459ae008bd2a43af742633c0734a3828888888888856040516020015260405160e060020a63ffffffff89160281526004810196909652600160a060020a0394851660248701529290931660448501526064840152608483019190915260a482015260c40160206040518083038186803b1515610f4b57600080fd5b6102c65a03f41515610f5c57600080fd5b5050506040518051979650505050505050565b6000805260086020527f5eff886ea0ce6ca488a3d6e336d6c0f75f46d19b42c06ce5ee98e42c96d256c7546007540390565b600073db53a3db5d9224fce5ab4459ae008bd2a43af742638099f6cb82898989898989866040516020015260405160e060020a63ffffffff8a160281526004810197909752600160a060020a0395861660248801529385166044870152919093166064850152608484019290925260a483019190915260c482015260e40160206040518083038186803b1515610d3957600080fd5b7ff16f9b530000000000000000000000000000000000000000000000000000000081565b600073db53a3db5d9224fce5ab4459ae008bd2a43af7426367b9965482868686836040516020015260405160e060020a63ffffffff87160281526004810194909452600160a060020a03928316602485015291166044830152606482015260840160206040518083038186803b15156110d257600080fd5b6102c65a03f415156110e357600080fd5b505050604051805195945050505050565b60065460ff1690565b600073db53a3db5d9224fce5ab4459ae008bd2a43af742635b08c4d8828b8b8b8b8b8b8b8b886040516020015260405160e060020a63ffffffff8c16028152600481018a8152600160a060020a03808b166024840152898116604484015288811660648401526084830188905260a4830187905260c48301869052831661010483015261012060e4830190815290916101240184818151815260200191508051906020019080838360005b838110156111c05780820151838201526020016111a8565b50505050905090810190601f1680156111ed5780820380516001836020036101000a031916815260200191505b509a505050505050505050505060206040518083038186803b151561121157600080fd5b6102c65a03f4151561122257600080fd5b50505060405180519a9950505050505050505050565b60025474010000000000000000000000000000000000000000900460ff1690565b600160a060020a031660009081526003602052604090205460ff1690565b7f7532eaac0000000000000000000000000000000000000000000000000000000081565b600160a060020a031660009081526008602052604090205490565b600073db53a3db5d9224fce5ab4459ae008bd2a43af7426340c3e55b828a8a8a8a8a8a8a876040516020015260405160e060020a63ffffffff8b1602815260048101898152600160a060020a03808a1660248401528881166044840152606483018890526084830187905260a48301869052831660e483015261010060c4830190815290916101040184818151815260200191508051906020019080838360005b8381101561136f578082015183820152602001611357565b50505050905090810190601f16801561139c5780820380516001836020036101000a031916815260200191505b50995050505050505050505060206040518083038186803b15156113bf57600080fd5b6102c65a03f415156113d057600080fd5b50505060405180519998505050505050505050565b73db53a3db5d9224fce5ab4459ae008bd2a43af74263ea300bda600060405160e060020a63ffffffff8416028152600481019190915260240160006040518083038186803b151561143557600080fd5b6102c65a03f4151561144657600080fd5b505050565b600073db53a3db5d9224fce5ab4459ae008bd2a43af74263f12d346e828a8a8a8a8a8a8a876040516020015260405160e060020a63ffffffff8b1602815260048101898152600160a060020a03808a1660248401528881166044840152606483018890526084830187905260a48301869052831660e483015261010060c4830190815290916101040184818151815260200191508051906020019080838360008381101561136f578082015183820152602001611357565b73db53a3db5d9224fce5ab4459ae008bd2a43af74263f72cb00a600060405160e060020a63ffffffff8416028152600481019190915260240160006040518083038186803b151561143557600080fd5b73db53a3db5d9224fce5ab4459ae008bd2a43af742638fedeca660008360405160e060020a63ffffffff85160281526004810192909252600160a060020a0316602482015260440160006040518083038186803b15156115b257600080fd5b6102c65a03f415156115c357600080fd5b50505050565b606e81565b6000546101009004600160a060020a031690565b73db53a3db5d9224fce5ab4459ae008bd2a43af74263b39d0e0960008360405160e060020a63ffffffff85160281526004810192909252600160a060020a0316602482015260440160006040518083038186803b15156115b257600080fd5b6002547501000000000000000000000000000000000000000000900460ff1690565b61166b611fcc565b60048054600260001961010060018416150201909116046020601f82018190048102016040519081016040528092919081815260200182805460018160011615610100020316600290048015610dfd5780601f10610dd257610100808354040283529160200191610dfd565b600073db53a3db5d9224fce5ab4459ae008bd2a43af74263e0ccb749828b8b8b8b8b8b8b8b886040516020015260405160e060020a63ffffffff8c16028152600481018a8152600160a060020a03808b16602484015289811660448401526064830189905260a4830187905260c48301869052831661010483015261012060848301908152909160e48101906101240188818151815260200191508051906020019080838360005b8381101561179757808201518382015260200161177f565b50505050905090810190601f1680156117c45780820380516001836020036101000a031916815260200191505b50838103825285818151815260200191508051906020019080838360005b838110156117fa5780820151838201526020016117e2565b50505050905090810190601f1680156118275780820380516001836020036101000a031916815260200191505b509b50505050505050505050505060206040518083038186803b151561121157600080fd5b600073db53a3db5d9224fce5ab4459ae008bd2a43af74263836be758828888888888856040516020015260405160e060020a63ffffffff89160281526004810196909652600160a060020a0394851660248701529290931660448501526064840152608483019190915260a482015260c40160206040518083038186803b1515610f4b57600080fd5b7fe9afa7a10000000000000000000000000000000000000000000000000000000081565b600073db53a3db5d9224fce5ab4459ae008bd2a43af7426306ad0e7b828585826040516020015260405160e060020a63ffffffff86160281526004810193909352600160a060020a039091166024830152604482015260640160206040518083038186803b1515610e8657600080fd5b73db53a3db5d9224fce5ab4459ae008bd2a43af74263976f56a5600060405160e060020a63ffffffff8416028152600481019190915260240160006040518083038186803b151561143557600080fd5b7f344bcc7d0000000000000000000000000000000000000000000000000000000081565b600073db53a3db5d9224fce5ab4459ae008bd2a43af74263b457c85f828a8a8a8a8a8a8a876040516020015260405160e060020a63ffffffff8b1602815260048101898152600160a060020a03808a1660248401528881166044840152606483018890526084830187905260a48301869052831660e483015261010060c4830190815290916101040184818151815260200191508051906020019080838360008381101561136f578082015183820152602001611357565b600073db53a3db5d9224fce5ab4459ae008bd2a43af742637f3f30bf8286868683604051602001526040518563ffffffff1660e060020a0281526004018085815260200184600160a060020a0316600160a060020a0316815260200183815260200180602001828103825283818151815260200191508051906020019080838360005b83811015611b30578082015183820152602001611b18565b50505050905090810190601f168015611b5d5780820380516001836020036101000a031916815260200191505b509550505050505060206040518083038186803b15156110d257600080fd5b600073db53a3db5d9224fce5ab4459ae008bd2a43af742639fb6f52682868686836040516020015260405160e060020a63ffffffff87160281526004810194909452600160a060020a03909216602484015260448301521515606482015260840160206040518083038186803b15156110d257600080fd5b600154600160a060020a031690565b600073db53a3db5d9224fce5ab4459ae008bd2a43af742637512eb85828585826040516020015260405160e060020a63ffffffff86160281526004810193909352600160a060020a039091166024830152604482015260640160206040518083038186803b1515610e8657600080fd5b600160a060020a03918216600090815260096020908152604080832093909416825291909152205490565b60408051908101604052601c81527f19457468657265756d205369676e6564204d6573736167653a0a333200000000602082015281565b600073db53a3db5d9224fce5ab4459ae008bd2a43af7426306fc8397828a8a8a8a8a8a8a876040516020015260405160e060020a63ffffffff8b1602815260048101898152600160a060020a03808a1660248401528881166044840152606483018890526084830187905260a48301869052831660e483015261010060c4830190815290916101040184818151815260200191508051906020019080838360008381101561136f578082015183820152602001611357565b600073db53a3db5d9224fce5ab4459ae008bd2a43af74263f134977b828b8b8b8b8b8b8b8b886040516020015260405160e060020a63ffffffff8c16028152600481018a8152600160a060020a03808b16602484015289811660448401526064830189905260a4830187905260c48301869052831661010483015261012060848301908152909160e48101906101240188818151815260200191508051906020019080838360008381101561179757808201518382015260200161177f565b73db53a3db5d9224fce5ab4459ae008bd2a43af7426364850de560008360405160e060020a63ffffffff85160281526004810192909252600160a060020a0316602482015260440160006040518083038186803b15156115b257600080fd5b600073db53a3db5d9224fce5ab4459ae008bd2a43af7426311a44a6b828b8b8b8b8b8b8b8b886040516020015260405160e060020a63ffffffff8c16028152600481018a8152600160a060020a03808b166024840152898116604484015288811660648401526084830188905260a4830187905260c48301869052831661010483015261012060e483019081529091610124018481815181526020019150805190602001908083836000838110156111c05780820151838201526020016111a8565b73db53a3db5d9224fce5ab4459ae008bd2a43af742635250afa160008360405160e060020a63ffffffff85160281526004810192909252600160a060020a0316602482015260440160006040518083038186803b15156115b257600080fd5b602060405190810160405260008152905600a165627a7a72305820758cdb3803388d682a299371175c4075beef718a05bba71aaf4c167b612b1cc10029a165627a7a723058201cbfc172b710f595c0eacba0ee0e239f45a63ad4301848561cf327cd22deac310029

   Library Used
BTTSLib : 0xdb53a3db5d9224fce5ab4459ae008bd2a43af742

   Swarm Source:
bzzr://1cbfc172b710f595c0eacba0ee0e239f45a63ad4301848561cf327cd22deac31

 

View All
Block Age transaction Difficulty GasUsed Reward
View All
Block Age UncleNumber Difficulty GasUsed Reward