ETH Price: $1,850.93 (+1.56%)
Gas: 20 Gwei
 

Overview

ETH Balance

0.008 ETH

Eth Value

$14.81 (@ $1,850.93/ETH)

Token Holdings

Multi Chain

Multichain Addresses

0 address found via
Transaction Hash
Method
Block
From
To
Value
Perform Swap Col...155592942022-09-18 8:38:35263 days 13 hrs ago1663490315IN
Totle: Primary
0.0001 ETH0.000083142
Perform Swap Col...103616952020-06-29 16:09:211074 days 5 hrs ago1593446961IN
Totle: Primary
8.8 ETH0.0134864550
Perform Swap Col...103616732020-06-29 16:04:251074 days 5 hrs ago1593446665IN
Totle: Primary
0.15 ETH0.0084340850.40000153
Perform Swap Col...103616352020-06-29 15:54:011074 days 5 hrs ago1593446041IN
Totle: Primary
0.047 ETH0.0102649448.00000145
Perform Swap Col...103614622020-06-29 15:11:431074 days 6 hrs ago1593443503IN
Totle: Primary
0.15 ETH0.0013933640
Perform Swap Col...103614352020-06-29 15:07:131074 days 6 hrs ago1593443233IN
Totle: Primary
0.4 ETH0.0091144846
Perform Swap Col...103613862020-06-29 14:55:261074 days 6 hrs ago1593442526IN
Totle: Primary
0.245 ETH0.0089801844
Perform Swap Col...103611962020-06-29 14:10:171074 days 7 hrs ago1593439817IN
Totle: Primary
0.1 ETH0.0062938641
Perform Swap Col...103610172020-06-29 13:29:171074 days 8 hrs ago1593437357IN
Totle: Primary
0.4 ETH0.0069349335
Perform Swap Col...103608352020-06-29 12:48:511074 days 9 hrs ago1593434931IN
Totle: Primary
0 ETH0.0206409330
Perform Swap Col...103604662020-06-29 11:27:411074 days 10 hrs ago1593430061IN
Totle: Primary
0 ETH0.0369483639
Perform Swap Col...103604272020-06-29 11:18:501074 days 10 hrs ago1593429530IN
Totle: Primary
2 ETH0.0101353939
Perform Swap Col...103599552020-06-29 9:33:561074 days 12 hrs ago1593423236IN
Totle: Primary
0.25 ETH0.0129138
Perform Swap Col...103595112020-06-29 7:49:411074 days 14 hrs ago1593416981IN
Totle: Primary
0.9 ETH0.0071845728
Perform Swap Col...103592472020-06-29 6:53:271074 days 14 hrs ago1593413607IN
Totle: Primary
0.0855 ETH0.0026744635.69665272
Perform Swap Col...103592202020-06-29 6:46:231074 days 15 hrs ago1593413183IN
Totle: Primary
0.085 ETH0.0072163637
Perform Swap Col...103592102020-06-29 6:44:511074 days 15 hrs ago1593413091IN
Totle: Primary
0.085 ETH0.0148177435
Perform Swap Col...103591982020-06-29 6:42:561074 days 15 hrs ago1593412976IN
Totle: Primary
0.085 ETH0.004095333
Perform Swap Col...103590612020-06-29 6:11:051074 days 15 hrs ago1593411065IN
Totle: Primary
16.5 ETH0.0192580137
Perform Swap Col...103589052020-06-29 5:37:121074 days 16 hrs ago1593409032IN
Totle: Primary
0.06731567 ETH0.0192212236.70000076
Perform Swap Col...103588982020-06-29 5:35:301074 days 16 hrs ago1593408930IN
Totle: Primary
0.89 ETH0.0094413535
Perform Swap Col...103587082020-06-29 4:56:071074 days 16 hrs ago1593406567IN
Totle: Primary
0 ETH0.0255128134
Perform Swap Col...103586792020-06-29 4:50:241074 days 17 hrs ago1593406224IN
Totle: Primary
0 ETH0.0254467535
Perform Swap Col...103584022020-06-29 3:39:581074 days 18 hrs ago1593401998IN
Totle: Primary
0 ETH0.0226378324
Perform Swap Col...103583062020-06-29 3:19:591074 days 18 hrs ago1593400799IN
Totle: Primary
0.1 ETH0.0116850532
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Advanced Filter
Parent Txn Hash Block From To Value
105244442020-07-24 20:42:031049 days 1 hr ago1595623323
Totle: Primary
0.004 ETH
104666042020-07-15 21:51:221058 days ago1594849882
Totle: Primary
0.004 ETH
103760472020-07-01 21:45:291072 days 6 mins ago1593639929
Totle: Primary
1 wei
103760472020-07-01 21:45:291072 days 6 mins ago1593639929
Totle: Primary
1 wei
103760472020-07-01 21:45:291072 days 6 mins ago1593639929
Totle: Primary
0.17534247 ETH
103760472020-07-01 21:45:291072 days 6 mins ago1593639929
Totle: Primary
0.17534247 ETH
103616952020-06-29 16:09:211074 days 5 hrs ago1593446961
Totle: Primary
6.468 ETH
103616952020-06-29 16:09:211074 days 5 hrs ago1593446961
Totle: Primary
6.468 ETH
103616952020-06-29 16:09:211074 days 5 hrs ago1593446961
Totle: Primary
8.8 ETH
103616732020-06-29 16:04:251074 days 5 hrs ago1593446665
Totle: Primary
0.1485 ETH
103616732020-06-29 16:04:251074 days 5 hrs ago1593446665
Totle: Primary
0.0015 ETH
103616352020-06-29 15:54:011074 days 5 hrs ago1593446041
Totle: Primary
0.047 ETH
103614352020-06-29 15:07:131074 days 6 hrs ago1593443233
Totle: Primary
0.396 ETH
103614352020-06-29 15:07:131074 days 6 hrs ago1593443233
Totle: Primary
0.004 ETH
103613862020-06-29 14:55:261074 days 6 hrs ago1593442526
Totle: Primary
0.245 ETH
103611962020-06-29 14:10:171074 days 7 hrs ago1593439817
Totle: Primary
0.1 ETH
103610172020-06-29 13:29:171074 days 8 hrs ago1593437357
Totle: Primary
0.396 ETH
103610172020-06-29 13:29:171074 days 8 hrs ago1593437357
Totle: Primary
0.004 ETH
103609942020-06-29 13:24:311074 days 8 hrs ago1593437071
Totle: Primary
158 wei
103609942020-06-29 13:24:311074 days 8 hrs ago1593437071
Totle: Primary
158 wei
103609942020-06-29 13:24:311074 days 8 hrs ago1593437071
Totle: Primary
0.70430761 ETH
103609942020-06-29 13:24:311074 days 8 hrs ago1593437071
Totle: Primary
0.70430761 ETH
103608352020-06-29 12:48:511074 days 9 hrs ago1593434931
Totle: Primary
5 wei
103608352020-06-29 12:48:511074 days 9 hrs ago1593434931
Totle: Primary
5 wei
103608352020-06-29 12:48:511074 days 9 hrs ago1593434931
Totle: Primary
2.88488187 ETH
View All Internal Transactions
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
TotlePrimary

Compiler Version
v0.5.7+commit.6da8b019

Optimization Enabled:
Yes with 999 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2020-03-02
*/

pragma solidity 0.5.7;
pragma experimental ABIEncoderV2;

/*
 * @title Ownable
 * @dev The Ownable contract has an owner address, and provides basic authorization control
 * functions, this simplifies the implementation of "user permissions".
 */
contract Ownable {
  address payable public owner;


  event OwnershipRenounced(address indexed previousOwner);
  event OwnershipTransferred(
    address indexed previousOwner,
    address indexed newOwner
  );


  /**
   * @dev The Ownable constructor sets the original `owner` of the contract to the sender
   * account.
   */
  constructor() public {
    owner = msg.sender;
  }

  /**
   * @dev Throws if called by any account other than the owner.
   */
  modifier onlyOwner() {
    require(msg.sender == owner);
    _;
  }

  /**
   * @dev Allows the current owner to relinquish control of the contract.
   * @notice Renouncing to ownership will leave the contract without an owner.
   * It will not be possible to call the functions with the `onlyOwner`
   * modifier anymore.
   */
  function renounceOwnership() public onlyOwner {
    emit OwnershipRenounced(owner);
    owner = address(0);
  }

  /**
   * @dev Allows the current owner to transfer control of the contract to a newOwner.
   * @param _newOwner The address to transfer ownership to.
   */
  function transferOwnership(address payable _newOwner) public onlyOwner {
    _transferOwnership(_newOwner);
  }

  /**
   * @dev Transfers control of the contract to a newOwner.
   * @param _newOwner The address to transfer ownership to.
   */
  function _transferOwnership(address payable _newOwner) internal {
    require(_newOwner != address(0));
    emit OwnershipTransferred(owner, _newOwner);
    owner = _newOwner;
  }
}

library ERC20SafeTransfer {
    function safeTransfer(address _tokenAddress, address _to, uint256 _value) internal returns (bool success) {
        (success,) = _tokenAddress.call(abi.encodeWithSignature("transfer(address,uint256)", _to, _value));
        require(success, "Transfer failed");

        return fetchReturnData();
    }

    function safeTransferFrom(address _tokenAddress, address _from, address _to, uint256 _value) internal returns (bool success) {
        (success,) = _tokenAddress.call(abi.encodeWithSignature("transferFrom(address,address,uint256)", _from, _to, _value));
        require(success, "Transfer From failed");

        return fetchReturnData();
    }

    function safeApprove(address _tokenAddress, address _spender, uint256 _value) internal returns (bool success) {
        (success,) = _tokenAddress.call(abi.encodeWithSignature("approve(address,uint256)", _spender, _value));
        require(success,  "Approve failed");

        return fetchReturnData();
    }

    function fetchReturnData() internal pure returns (bool success){
        assembly {
            switch returndatasize()
            case 0 {
                success := 1
            }
            case 32 {
                returndatacopy(0, 0, 32)
                success := mload(0)
            }
            default {
                revert(0, 0)
            }
        }
    }

}

/// @title A contract which allows its owner to withdraw any ether which is contained inside
contract Withdrawable is Ownable {

    /// @notice Withdraw ether contained in this contract and send it back to owner
    /// @dev onlyOwner modifier only allows the contract owner to run the code
    /// @param _token The address of the token that the user wants to withdraw
    /// @param _amount The amount of tokens that the caller wants to withdraw
    /// @return bool value indicating whether the transfer was successful
    function withdrawToken(address _token, uint256 _amount) external onlyOwner returns (bool) {
        return ERC20SafeTransfer.safeTransfer(_token, owner, _amount);
    }

    /// @notice Withdraw ether contained in this contract and send it back to owner
    /// @dev onlyOwner modifier only allows the contract owner to run the code
    /// @param _amount The amount of ether that the caller wants to withdraw
    function withdrawETH(uint256 _amount) external onlyOwner {
        owner.transfer(_amount);
    }
}

/**
 * @title Pausable
 * @dev Base contract which allows children to implement an emergency stop mechanism.
 */
contract Pausable is Ownable {
  event Paused();
  event Unpaused();

  bool private _paused = false;

  /**
   * @return true if the contract is paused, false otherwise.
   */
  function paused() public view returns (bool) {
    return _paused;
  }

  /**
   * @dev Modifier to make a function callable only when the contract is not paused.
   */
  modifier whenNotPaused() {
    require(!_paused, "Contract is paused.");
    _;
  }

  /**
   * @dev Modifier to make a function callable only when the contract is paused.
   */
  modifier whenPaused() {
    require(_paused, "Contract not paused.");
    _;
  }

  /**
   * @dev called by the owner to pause, triggers stopped state
   */
  function pause() public onlyOwner whenNotPaused {
    _paused = true;
    emit Paused();
  }

  /**
   * @dev called by the owner to unpause, returns to normal state
   */
  function unpause() public onlyOwner whenPaused {
    _paused = false;
    emit Unpaused();
  }
}

/**
 * @title ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/20
 */
contract ERC20 {
  function totalSupply() public view returns (uint256);

  function balanceOf(address _who) public view returns (uint256);

  function allowance(address _owner, address _spender)
    public view returns (uint256);

  function transfer(address _to, uint256 _value) public returns (bool);

  function approve(address _spender, uint256 _value)
    public returns (bool);

  function transferFrom(address _from, address _to, uint256 _value)
    public returns (bool);

  function decimals() public view returns (uint256);

  event Transfer(
    address indexed from,
    address indexed to,
    uint256 value
  );

  event Approval(
    address indexed owner,
    address indexed spender,
    uint256 value
  );
}

/*

  Copyright 2018 ZeroEx Intl.

  Licensed under the Apache License, Version 2.0 (the "License");
  you may not use this file except in compliance with the License.
  You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

  Unless required by applicable law or agreed to in writing, software
  distributed under the License is distributed on an "AS IS" BASIS,
  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  See the License for the specific language governing permissions and
  limitations under the License.

*/

/// @title TokenTransferProxy - Transfers tokens on behalf of contracts that have been approved via decentralized governance.
/// @author Amir Bandeali - <[email protected]>, Will Warren - <[email protected]>
contract TokenTransferProxy is Ownable {

    /// @dev Only authorized addresses can invoke functions with this modifier.
    modifier onlyAuthorized {
        require(authorized[msg.sender]);
        _;
    }

    modifier targetAuthorized(address target) {
        require(authorized[target]);
        _;
    }

    modifier targetNotAuthorized(address target) {
        require(!authorized[target]);
        _;
    }

    mapping (address => bool) public authorized;
    address[] public authorities;

    event LogAuthorizedAddressAdded(address indexed target, address indexed caller);
    event LogAuthorizedAddressRemoved(address indexed target, address indexed caller);

    /*
     * Public functions
     */

    /// @dev Authorizes an address.
    /// @param target Address to authorize.
    function addAuthorizedAddress(address target)
        public
        onlyOwner
        targetNotAuthorized(target)
    {
        authorized[target] = true;
        authorities.push(target);
        emit LogAuthorizedAddressAdded(target, msg.sender);
    }

    /// @dev Removes authorizion of an address.
    /// @param target Address to remove authorization from.
    function removeAuthorizedAddress(address target)
        public
        onlyOwner
        targetAuthorized(target)
    {
        delete authorized[target];
        for (uint i = 0; i < authorities.length; i++) {
            if (authorities[i] == target) {
                authorities[i] = authorities[authorities.length - 1];
                authorities.length -= 1;
                break;
            }
        }
        emit LogAuthorizedAddressRemoved(target, msg.sender);
    }

    /// @dev Calls into ERC20 Token contract, invoking transferFrom.
    /// @param token Address of token to transfer.
    /// @param from Address to transfer token from.
    /// @param to Address to transfer token to.
    /// @param value Amount of token to transfer.
    /// @return Success of transfer.
    function transferFrom(
        address token,
        address from,
        address to,
        uint value)
        public
        onlyAuthorized
        returns (bool)
    {
        require(ERC20SafeTransfer.safeTransferFrom(token, from, to, value));
        return true;
    }

    /*
     * Public view functions
     */

    /// @dev Gets all authorized addresses.
    /// @return Array of authorized addresses.
    function getAuthorizedAddresses()
        public
        view
        returns (address[] memory)
    {
        return authorities;
    }
}

/*
    Modified Util contract as used by Kyber Network
*/

library Utils {

    uint256 constant internal PRECISION = (10**18);
    uint256 constant internal MAX_QTY   = (10**28); // 10B tokens
    uint256 constant internal MAX_RATE  = (PRECISION * 10**6); // up to 1M tokens per ETH
    uint256 constant internal MAX_DECIMALS = 18;
    uint256 constant internal ETH_DECIMALS = 18;
    uint256 constant internal MAX_UINT = 2**256-1;
    address constant internal ETH_ADDRESS = address(0x0);

    // Currently constants can't be accessed from other contracts, so providing functions to do that here
    function precision() internal pure returns (uint256) { return PRECISION; }
    function max_qty() internal pure returns (uint256) { return MAX_QTY; }
    function max_rate() internal pure returns (uint256) { return MAX_RATE; }
    function max_decimals() internal pure returns (uint256) { return MAX_DECIMALS; }
    function eth_decimals() internal pure returns (uint256) { return ETH_DECIMALS; }
    function max_uint() internal pure returns (uint256) { return MAX_UINT; }
    function eth_address() internal pure returns (address) { return ETH_ADDRESS; }

    /// @notice Retrieve the number of decimals used for a given ERC20 token
    /// @dev As decimals are an optional feature in ERC20, this contract uses `call` to
    /// ensure that an exception doesn't cause transaction failure
    /// @param token the token for which we should retrieve the decimals
    /// @return decimals the number of decimals in the given token
    function getDecimals(address token)
        internal
        returns (uint256 decimals)
    {
        bytes4 functionSig = bytes4(keccak256("decimals()"));

        /// @dev Using assembly due to issues with current solidity `address.call()`
        /// implementation: https://github.com/ethereum/solidity/issues/2884
        assembly {
            // Pointer to next free memory slot
            let ptr := mload(0x40)
            // Store functionSig variable at ptr
            mstore(ptr,functionSig)
            let functionSigLength := 0x04
            let wordLength := 0x20

            let success := call(
                                gas, // Amount of gas
                                token, // Address to call
                                0, // ether to send
                                ptr, // ptr to input data
                                functionSigLength, // size of data
                                ptr, // where to store output data (overwrite input)
                                wordLength // size of output data (32 bytes)
                               )

            switch success
            case 0 {
                decimals := 0 // If the token doesn't implement `decimals()`, return 0 as default
            }
            case 1 {
                decimals := mload(ptr) // Set decimals to return data from call
            }
            mstore(0x40,add(ptr,0x04)) // Reset the free memory pointer to the next known free location
        }
    }

    /// @dev Checks that a given address has its token allowance and balance set above the given amount
    /// @param tokenOwner the address which should have custody of the token
    /// @param tokenAddress the address of the token to check
    /// @param tokenAmount the amount of the token which should be set
    /// @param addressToAllow the address which should be allowed to transfer the token
    /// @return bool true if the allowance and balance is set, false if not
    function tokenAllowanceAndBalanceSet(
        address tokenOwner,
        address tokenAddress,
        uint256 tokenAmount,
        address addressToAllow
    )
        internal
        view
        returns (bool)
    {
        return (
            ERC20(tokenAddress).allowance(tokenOwner, addressToAllow) >= tokenAmount &&
            ERC20(tokenAddress).balanceOf(tokenOwner) >= tokenAmount
        );
    }

    function calcDstQty(uint srcQty, uint srcDecimals, uint dstDecimals, uint rate) internal pure returns (uint) {
        if (dstDecimals >= srcDecimals) {
            require((dstDecimals - srcDecimals) <= MAX_DECIMALS);
            return (srcQty * rate * (10**(dstDecimals - srcDecimals))) / PRECISION;
        } else {
            require((srcDecimals - dstDecimals) <= MAX_DECIMALS);
            return (srcQty * rate) / (PRECISION * (10**(srcDecimals - dstDecimals)));
        }
    }

    function calcSrcQty(uint dstQty, uint srcDecimals, uint dstDecimals, uint rate) internal pure returns (uint) {

        //source quantity is rounded up. to avoid dest quantity being too low.
        uint numerator;
        uint denominator;
        if (srcDecimals >= dstDecimals) {
            require((srcDecimals - dstDecimals) <= MAX_DECIMALS);
            numerator = (PRECISION * dstQty * (10**(srcDecimals - dstDecimals)));
            denominator = rate;
        } else {
            require((dstDecimals - srcDecimals) <= MAX_DECIMALS);
            numerator = (PRECISION * dstQty);
            denominator = (rate * (10**(dstDecimals - srcDecimals)));
        }
        return (numerator + denominator - 1) / denominator; //avoid rounding down errors
    }

    function calcDestAmount(ERC20 src, ERC20 dest, uint srcAmount, uint rate) internal returns (uint) {
        return calcDstQty(srcAmount, getDecimals(address(src)), getDecimals(address(dest)), rate);
    }

    function calcSrcAmount(ERC20 src, ERC20 dest, uint destAmount, uint rate) internal returns (uint) {
        return calcSrcQty(destAmount, getDecimals(address(src)), getDecimals(address(dest)), rate);
    }

    function calcRateFromQty(uint srcAmount, uint destAmount, uint srcDecimals, uint dstDecimals)
        internal pure returns (uint)
    {
        require(srcAmount <= MAX_QTY);
        require(destAmount <= MAX_QTY);

        if (dstDecimals >= srcDecimals) {
            require((dstDecimals - srcDecimals) <= MAX_DECIMALS);
            return (destAmount * PRECISION / ((10 ** (dstDecimals - srcDecimals)) * srcAmount));
        } else {
            require((srcDecimals - dstDecimals) <= MAX_DECIMALS);
            return (destAmount * PRECISION * (10 ** (srcDecimals - dstDecimals)) / srcAmount);
        }
    }

    /// @notice Bringing this in from the Math library as we've run out of space in TotlePrimary (see EIP-170)
    function min(uint256 a, uint256 b) internal pure returns (uint256) {
        return a < b ? a : b;
    }
}

/**
 * @title SafeMath
 * @dev Math operations with safety checks that revert on error
 */
library SafeMath {

  /**
  * @dev Multiplies two numbers, reverts on overflow.
  */
  function mul(uint256 _a, uint256 _b) internal pure returns (uint256) {
    // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
    // benefit is lost if 'b' is also tested.
    // See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522
    if (_a == 0) {
      return 0;
    }

    uint256 c = _a * _b;
    require(c / _a == _b);

    return c;
  }

  /**
  * @dev Integer division of two numbers truncating the quotient, reverts on division by zero.
  */
  function div(uint256 _a, uint256 _b) internal pure returns (uint256) {
    require(_b > 0); // Solidity only automatically asserts when dividing by 0
    uint256 c = _a / _b;
    // assert(_a == _b * c + _a % _b); // There is no case in which this doesn't hold

    return c;
  }

  /**
  * @dev Subtracts two numbers, reverts on overflow (i.e. if subtrahend is greater than minuend).
  */
  function sub(uint256 _a, uint256 _b) internal pure returns (uint256) {
    require(_b <= _a);
    uint256 c = _a - _b;

    return c;
  }

  /**
  * @dev Adds two numbers, reverts on overflow.
  */
  function add(uint256 _a, uint256 _b) internal pure returns (uint256) {
    uint256 c = _a + _b;
    require(c >= _a);

    return c;
  }

  /**
  * @dev Divides two numbers and returns the remainder (unsigned integer modulo),
  * reverts when dividing by zero.
  */
  function mod(uint256 a, uint256 b) internal pure returns (uint256) {
    require(b != 0);
    return a % b;
  }
}

/**
 * @title Math
 * @dev Assorted math operations
 */

library Math {
  function max(uint256 a, uint256 b) internal pure returns (uint256) {
    return a >= b ? a : b;
  }

  function min(uint256 a, uint256 b) internal pure returns (uint256) {
    return a < b ? a : b;
  }

  function average(uint256 a, uint256 b) internal pure returns (uint256) {
    // (a + b) / 2 can overflow, so we distribute
    return (a / 2) + (b / 2) + ((a % 2 + b % 2) / 2);
  }
}


contract PartnerRegistry is Ownable, Pausable {

    address target;
    mapping(address => bool) partnerContracts;
    address payable public companyBeneficiary;
    uint256 public basePercentage;
    PartnerRegistry public previousRegistry;

    event PartnerRegistered(address indexed creator, address indexed beneficiary, address partnerContract);

    constructor(PartnerRegistry _previousRegistry, address _target, address payable _companyBeneficiary, uint256 _basePercentage) public {
        previousRegistry = _previousRegistry;
        target = _target;
        companyBeneficiary = _companyBeneficiary;
        basePercentage = _basePercentage;
    }

    function registerPartner(address payable partnerBeneficiary, uint256 partnerPercentage) whenNotPaused external {
        Partner newPartner = Partner(createClone());
        newPartner.init(this,address(0x0000000000000000000000000000000000000000), 0, partnerBeneficiary, partnerPercentage);
        partnerContracts[address(newPartner)] = true;
        emit PartnerRegistered(address(msg.sender), partnerBeneficiary, address(newPartner));
    }

    function overrideRegisterPartner(
        address payable _companyBeneficiary,
        uint256 _companyPercentage,
        address payable partnerBeneficiary,
        uint256 partnerPercentage
    ) external onlyOwner {
        Partner newPartner = Partner(createClone());
        newPartner.init(PartnerRegistry(0x0000000000000000000000000000000000000000), _companyBeneficiary, _companyPercentage, partnerBeneficiary, partnerPercentage);
        partnerContracts[address(newPartner)] = true;
        emit PartnerRegistered(address(msg.sender), partnerBeneficiary, address(newPartner));
    }

    function deletePartner(address _partnerAddress) external onlyOwner {
        partnerContracts[_partnerAddress] = false;
    }

    function createClone() internal returns (address payable result) {
        bytes20 targetBytes = bytes20(target);
        assembly {
            let clone := mload(0x40)
            mstore(clone, 0x3d602d80600a3d3981f3363d3d373d3d3d363d73000000000000000000000000)
            mstore(add(clone, 0x14), targetBytes)
            mstore(add(clone, 0x28), 0x5af43d82803e903d91602b57fd5bf30000000000000000000000000000000000)
            result := create(0, clone, 0x37)
        }
    }

    function isValidPartner(address partnerContract) external view returns(bool) {
        return partnerContracts[partnerContract] || previousRegistry.isValidPartner(partnerContract);
    }

    function updateCompanyInfo(address payable newCompanyBeneficiary, uint256 newBasePercentage) external onlyOwner {
        companyBeneficiary = newCompanyBeneficiary;
        basePercentage = newBasePercentage;
    }
}


contract Partner {

    address payable public partnerBeneficiary;
    uint256 public partnerPercentage; //This is out of 1 ETH, e.g. 0.5 ETH is 50% of the fee

    uint256 public overrideCompanyPercentage;
    address payable public overrideCompanyBeneficiary;

    PartnerRegistry public registry;

    event LogPayout(
        address[] tokens,
        uint256[] amount
    );

    function init(
        PartnerRegistry _registry,
        address payable _overrideCompanyBeneficiary,
        uint256 _overrideCompanyPercentage,
        address payable _partnerBeneficiary,
        uint256 _partnerPercentage
    ) public {
        require(registry == PartnerRegistry(0x0000000000000000000000000000000000000000) &&
          overrideCompanyBeneficiary == address(0x0) && partnerBeneficiary == address(0x0)
        );
        overrideCompanyBeneficiary = _overrideCompanyBeneficiary;
        overrideCompanyPercentage = _overrideCompanyPercentage;
        partnerBeneficiary = _partnerBeneficiary;
        partnerPercentage = _partnerPercentage;
        overrideCompanyPercentage = _overrideCompanyPercentage;
        registry = _registry;
    }

    function payout(
        address[] memory tokens,
        uint256[] memory amounts
    ) public {
        uint totalFeePercentage = getTotalFeePercentage();
        address payable companyBeneficiary = companyBeneficiary();
        // Payout both the partner and the company at the same time
        for(uint256 index = 0; index<tokens.length; index++){
            uint256 partnerAmount = SafeMath.div(SafeMath.mul(amounts[index], partnerPercentage), getTotalFeePercentage());
            uint256 companyAmount = amounts[index] - partnerAmount;
            if(tokens[index] == Utils.eth_address()){
                partnerBeneficiary.transfer(partnerAmount);
                companyBeneficiary.transfer(companyAmount);
            } else {
                ERC20SafeTransfer.safeTransfer(tokens[index], partnerBeneficiary, partnerAmount);
                ERC20SafeTransfer.safeTransfer(tokens[index], companyBeneficiary, companyAmount);
            }
        }
	emit LogPayout(tokens,amounts);
    }

    function getTotalFeePercentage() public view returns (uint256){
        return partnerPercentage + companyPercentage();
    }

    function companyPercentage() public view returns (uint256){
        if(registry != PartnerRegistry(0x0000000000000000000000000000000000000000)){
            return Math.max(registry.basePercentage(), partnerPercentage);
        } else {
            return overrideCompanyPercentage;
        }
    }

    function companyBeneficiary() public view returns (address payable) {
        if(registry != PartnerRegistry(0x0000000000000000000000000000000000000000)){
            return registry.companyBeneficiary();
        } else {
            return overrideCompanyBeneficiary;
        }    
    }

    function() external payable {

    }
}

library TokenBalanceLibrary {
    struct TokenBalance {
        address tokenAddress;
        uint256 balance;
    }

    function findToken(TokenBalance[20] memory balances, address token)
        internal
        pure
        returns (uint256)
    {
        for (uint256 index = 0; index < balances.length; index++) {
            if (balances[index].tokenAddress == token) {
                return index;
            } else if (
                index != 0 && balances[index].tokenAddress == address(0x0)
            ) {
                balances[index] = TokenBalance(token, 0);
                return index;
            }
        }
    }

    function addBalance(
        TokenBalance[20] memory balances,
        address tokenAddress,
        uint256 amountToAdd
    ) internal pure {
        uint256 tokenIndex = findToken(balances, tokenAddress);
        addBalance(balances, tokenIndex, amountToAdd);
    }

    function addBalance(
        TokenBalance[20] memory balances,
        uint256 balanceIndex,
        uint256 amountToAdd
    ) internal pure {
        balances[balanceIndex].balance += amountToAdd;
    }

    function removeBalance(
        TokenBalance[20] memory balances,
        address tokenAddress,
        uint256 amountToRemove
    ) internal pure {
        uint256 tokenIndex = findToken(balances, tokenAddress);
        removeBalance(balances, tokenIndex, amountToRemove);
    }

    function removeBalance(
        TokenBalance[20] memory balances,
        uint256 balanceIndex,
        uint256 amountToRemove
    ) internal pure {
        balances[balanceIndex].balance -= amountToRemove;
    }
}

/// @title Interface for all exchange handler contracts
contract ExchangeHandler is Withdrawable, Pausable {

    /*
    *   State Variables
    */

    /* Logger public logger; */
    /*
    *   Modifiers
    */

    function performOrder(
        bytes memory genericPayload,
        uint256 availableToSpend,
        uint256 targetAmount,
        bool targetAmountIsSource
    )
        public
        payable
        returns (uint256 amountSpentOnOrder, uint256 amountReceivedFromOrder);

}

interface IGST2 {
    function freeUpTo(uint256) external returns (uint256);
}

/// @title The primary contract for Totle
contract TotlePrimary is Withdrawable, Pausable {
    /*
    *   State Variables
    */

    IGST2 public constant GAS_TOKEN = IGST2(
        0x0000000000b3F879cb30FE243b4Dfee438691c04
    );
    TokenTransferProxy public tokenTransferProxy;
    mapping(address => bool) public signers;
    uint256 public MIN_REFUND_GAS_PRICE = 3000000000;
    /*
    *   Types
    */

    // Structs
    struct Order {
        address payable exchangeHandler;
        bytes encodedPayload;
    }

    struct Trade {
        address sourceToken;
        address destinationToken;
        uint256 amount;
        bool isSourceAmount; //true if amount is sourceToken, false if it's destinationToken
        Order[] orders;
    }

    struct Swap {
        Trade[] trades;
        uint256 minimumExchangeRate;
        uint256 minimumDestinationAmount;
        uint256 sourceAmount;
        uint256 tradeToTakeFeeFrom;
        bool takeFeeFromSource; //Takes the fee before the trade if true, takes it after if false
        address payable redirectAddress;
        bool required;
    }

    struct SwapCollection {
        Swap[] swaps;
        address payable partnerContract;
        uint256 expirationBlock;
        bytes32 id;
        uint256 maxGasPrice;
        uint8 v;
        bytes32 r;
        bytes32 s;
    }

    struct FeeVariables {
        uint256 feePercentage;
        Partner partner;
        uint256 totalFee;
    }

    struct AmountsSpentReceived {
        uint256 spent;
        uint256 received;
    }
    /*
    *   Events
    */

    event LogSwapCollection(
        bytes32 indexed id,
        address indexed partnerContract,
        address indexed user
    );

    event LogSwap(
        bytes32 indexed id,
        address sourceAsset,
        address destinationAsset,
        uint256 sourceAmount,
        uint256 destinationAmount,
        address feeAsset,
        uint256 feeAmount
    );

    /// @notice Constructor
    /// @param _tokenTransferProxy address of the TokenTransferProxy
    /// @param _signer the suggester's address that signs the payloads. More can be added with add/removeSigner functions
    constructor(address _tokenTransferProxy, address _signer) public {
        tokenTransferProxy = TokenTransferProxy(_tokenTransferProxy);
        signers[_signer] = true;
    }

    /*
    *   Public functions
    */

    modifier notExpired(SwapCollection memory swaps) {
        require(swaps.expirationBlock > block.number, "Expired");
        _;
    }

    modifier validSignature(SwapCollection memory swaps) {
        bytes32 hash = keccak256(
            abi.encode(
                swaps.swaps,
                swaps.partnerContract,
                swaps.expirationBlock,
                swaps.id,
                swaps.maxGasPrice,
                msg.sender
            )
        );
        require(
            signers[ecrecover(
                keccak256(
                    abi.encodePacked("\x19Ethereum Signed Message:\n32", hash)
                ),
                swaps.v,
                swaps.r,
                swaps.s
            )],
            "Invalid signature"
        );
        _;
    }

    modifier notAboveMaxGas(SwapCollection memory swaps) {
        require(tx.gasprice <= swaps.maxGasPrice, "Gas price too high");
        _;
    }

    /// @notice Performs the requested set of swaps
    /// @param swaps The struct that defines the collection of swaps to perform
    function performSwapCollection(SwapCollection memory swaps)
        public
        payable
        whenNotPaused
        notExpired(swaps)
        validSignature(swaps)
        notAboveMaxGas(swaps)
    {
        uint256 startingGas = 0;
        if (tx.gasprice >= MIN_REFUND_GAS_PRICE) {
            startingGas = gasleft();
        }
        TokenBalanceLibrary.TokenBalance[20] memory balances;
        balances[0] = TokenBalanceLibrary.TokenBalance(
            address(Utils.eth_address()),
            msg.value
        );
        for (
            uint256 swapIndex = 0;
            swapIndex < swaps.swaps.length;
            swapIndex++
        ) {
            performSwap(
                swaps.id,
                swaps.swaps[swapIndex],
                balances,
                swaps.partnerContract
            );
        }
        emit LogSwapCollection(swaps.id, swaps.partnerContract, msg.sender);
        transferAllTokensToUser(balances);
        if (startingGas > 0) {
            refundGas(startingGas);
        }
    }

    function refundGas(uint256 startingGas) internal {
        uint256 gasRemaining = gasleft();
        uint256 gasSpent = startingGas - gasRemaining;
        uint256 tokensToFree = Math.min(
            (gasSpent + 14154) / 41130,
            (gasRemaining - 27710) / (1148 + 5722 + 150)
        );
        GAS_TOKEN.freeUpTo(tokensToFree);
    }

    function addSigner(address newSigner) public onlyOwner {
        signers[newSigner] = true;
    }

    function removeSigner(address signer) public onlyOwner {
        signers[signer] = false;
    }

    function updateMinRefundGasPrice(uint256 newMinRefundGasPrice)
        external
        onlyOwner
    {
        MIN_REFUND_GAS_PRICE = newMinRefundGasPrice;
    }
    /*
    *   Internal functions
    */

    function performSwap(
        bytes32 swapCollectionId,
        Swap memory swap,
        TokenBalanceLibrary.TokenBalance[20] memory balances,
        address payable partnerContract
    ) internal {
        if (
            !transferFromSenderDifference(
                balances,
                swap.trades[0].sourceToken,
                swap.sourceAmount
            )
        ) {
            if (swap.required) {
                revert("Failed to get tokens for swap");
            } else {
                return;
            }
        }
        uint256 amountSpentFirstTrade = 0;
        uint256 amountReceived = 0;
        uint256 feeAmount = 0;
        for (
            uint256 tradeIndex = 0;
            tradeIndex < swap.trades.length;
            tradeIndex++
        ) {
            if (
                tradeIndex == swap.tradeToTakeFeeFrom && swap.takeFeeFromSource
            ) {
                feeAmount = takeFee(
                    balances,
                    swap.trades[tradeIndex].sourceToken,
                    partnerContract,
                    tradeIndex == 0 ? swap.sourceAmount : amountReceived
                );
            }
            uint256 tempSpent;
            (tempSpent, amountReceived) = performTrade(
                swap.trades[tradeIndex],
                balances,
                Utils.min(
                    tradeIndex == 0 ? swap.sourceAmount : amountReceived,
                    balances[TokenBalanceLibrary.findToken(
                        balances,
                        swap.trades[tradeIndex].sourceToken
                    )]
                        .balance
                )
            );
            if (
                !swap.trades[tradeIndex].isSourceAmount &&
                amountReceived < swap.trades[tradeIndex].amount
            ) {
                if (swap.required) {
                    revert("Not enough destination amount");
                }
                return;
            }
            if (tradeIndex == 0) {
                amountSpentFirstTrade = tempSpent;
                if (feeAmount != 0) {
                    amountSpentFirstTrade += feeAmount;
                }
            }
            if (
                tradeIndex == swap.tradeToTakeFeeFrom && !swap.takeFeeFromSource
            ) {
                feeAmount = takeFee(
                    balances,
                    swap.trades[tradeIndex].destinationToken,
                    partnerContract,
                    amountReceived
                );
                amountReceived -= feeAmount;
            }
        }
        emit LogSwap(
            swapCollectionId,
            swap.trades[0].sourceToken,
            swap.trades[swap.trades.length - 1].destinationToken,
            amountSpentFirstTrade,
            amountReceived,
            swap.takeFeeFromSource
                ? swap.trades[swap.tradeToTakeFeeFrom].sourceToken
                : swap.trades[swap.tradeToTakeFeeFrom].destinationToken,
            feeAmount
        );

        if (amountReceived < swap.minimumDestinationAmount) {
            revert("Got less than minimumDestinationAmount");
        } else if (
            minimumRateFailed(
                swap.trades[0].sourceToken,
                swap.trades[swap.trades.length - 1].destinationToken,
                swap.sourceAmount,
                amountReceived,
                swap.minimumExchangeRate
            )
        ) {
            revert("Minimum exchange rate not met");
        }
        if (
            swap.redirectAddress != msg.sender &&
            swap.redirectAddress != address(0x0)
        ) {
            uint256 destinationTokenIndex = TokenBalanceLibrary.findToken(
                balances,
                swap.trades[swap.trades.length - 1].destinationToken
            );
            uint256 amountToSend = Math.min(
                amountReceived,
                balances[destinationTokenIndex].balance
            );
            transferTokens(
                balances,
                destinationTokenIndex,
                swap.redirectAddress,
                amountToSend
            );
            TokenBalanceLibrary.removeBalance(
                balances,
                swap.trades[swap.trades.length - 1].destinationToken,
                amountToSend
            );
        }
    }

    function performTrade(
        Trade memory trade,
        TokenBalanceLibrary.TokenBalance[20] memory balances,
        uint256 availableToSpend
    ) internal returns (uint256 totalSpent, uint256 totalReceived) {
        uint256 tempSpent = 0;
        uint256 tempReceived = 0;
        for (
            uint256 orderIndex = 0;
            orderIndex < trade.orders.length;
            orderIndex++
        ) {
            if ((availableToSpend - totalSpent) * 10000 < availableToSpend) {
                break;
            } else if (!trade.isSourceAmount && tempReceived == trade.amount) {
                break;
            } else if (trade.isSourceAmount && tempSpent == trade.amount) {
                break;
            }
            (tempSpent, tempReceived) = performOrder(
                trade.orders[orderIndex],
                availableToSpend - totalSpent,
                trade.isSourceAmount
                    ? availableToSpend - totalSpent
                    : trade.amount - totalReceived,
                trade.isSourceAmount,
                trade.sourceToken,
                balances
            );
            totalSpent += tempSpent;
            totalReceived += tempReceived;
        }
        TokenBalanceLibrary.addBalance(
            balances,
            trade.destinationToken,
            totalReceived
        );
        TokenBalanceLibrary.removeBalance(
            balances,
            trade.sourceToken,
            totalSpent
        );
    }

    function performOrder(
        Order memory order,
        uint256 availableToSpend,
        uint256 targetAmount,
        bool isSourceAmount,
        address tokenToSpend,
        TokenBalanceLibrary.TokenBalance[20] memory balances
    ) internal returns (uint256 spent, uint256 received) {
        if (tokenToSpend == Utils.eth_address()) {
            (spent, received) = ExchangeHandler(order.exchangeHandler)
                .performOrder
                .value(availableToSpend)(
                order.encodedPayload,
                availableToSpend,
                targetAmount,
                isSourceAmount
            );

        } else {
            transferTokens(
                balances,
                TokenBalanceLibrary.findToken(balances, tokenToSpend),
                order.exchangeHandler,
                availableToSpend
            );
            (spent, received) = ExchangeHandler(order.exchangeHandler)
                .performOrder(
                order.encodedPayload,
                availableToSpend,
                targetAmount,
                isSourceAmount
            );
        }
    }

    function minimumRateFailed(
        address sourceToken,
        address destinationToken,
        uint256 sourceAmount,
        uint256 destinationAmount,
        uint256 minimumExchangeRate
    ) internal returns (bool failed) {
        uint256 sourceDecimals = sourceToken == Utils.eth_address()
            ? 18
            : Utils.getDecimals(sourceToken);
        uint256 destinationDecimals = destinationToken == Utils.eth_address()
            ? 18
            : Utils.getDecimals(destinationToken);
        uint256 rateGot = Utils.calcRateFromQty(
            sourceAmount,
            destinationAmount,
            sourceDecimals,
            destinationDecimals
        );
        return rateGot < minimumExchangeRate;
    }

    function takeFee(
        TokenBalanceLibrary.TokenBalance[20] memory balances,
        address token,
        address payable partnerContract,
        uint256 amountTraded
    ) internal returns (uint256 feeAmount) {
        Partner partner = Partner(partnerContract);
        uint256 feePercentage = partner.getTotalFeePercentage();
        feeAmount = calculateFee(amountTraded, feePercentage);
        transferTokens(
            balances,
            TokenBalanceLibrary.findToken(balances, token),
            partnerContract,
            feeAmount
        );
        TokenBalanceLibrary.removeBalance(
            balances,
            TokenBalanceLibrary.findToken(balances, token),
            feeAmount
        );
        return feeAmount;
    }

    function transferFromSenderDifference(
        TokenBalanceLibrary.TokenBalance[20] memory balances,
        address token,
        uint256 sourceAmount
    ) internal returns (bool) {
        if (token == Utils.eth_address()) {
            if (sourceAmount > balances[0].balance) {
                return false;
            }
            return true;
        }

        uint256 tokenIndex = TokenBalanceLibrary.findToken(balances, token);
        if (sourceAmount > balances[tokenIndex].balance) {
            bool success;
            (success, ) = address(tokenTransferProxy).call(
                abi.encodeWithSignature(
                    "transferFrom(address,address,address,uint256)",
                    token,
                    msg.sender,
                    address(this),
                    sourceAmount - balances[tokenIndex].balance
                )
            );
            if (success) {
                balances[tokenIndex].balance = sourceAmount;
                return true;
            }
            return false;
        }
        return true;
    }

    function transferAllTokensToUser(
        TokenBalanceLibrary.TokenBalance[20] memory balances
    ) internal {
        for (
            uint256 balanceIndex = 0;
            balanceIndex < balances.length;
            balanceIndex++
        ) {
            if (
                balanceIndex != 0 &&
                balances[balanceIndex].tokenAddress == address(0x0)
            ) {
                return;
            }
            transferTokens(
                balances,
                balanceIndex,
                msg.sender,
                balances[balanceIndex].balance
            );
        }
    }

    function transferTokens(
        TokenBalanceLibrary.TokenBalance[20] memory balances,
        uint256 tokenIndex,
        address payable destination,
        uint256 tokenAmount
    ) internal {
        if (tokenAmount > 0) {
            if (balances[tokenIndex].tokenAddress == Utils.eth_address()) {
                destination.transfer(tokenAmount);
            } else {
                require(
                    ERC20SafeTransfer.safeTransfer(
                        balances[tokenIndex].tokenAddress,
                        destination,
                        tokenAmount
                    ),
                    "Transfer failed"
                );
            }
        }
    }

    // @notice Calculates the fee amount given a fee percentage and amount
    // @param amount the amount to calculate the fee based on
    // @param fee the percentage, out of 1 eth (e.g. 0.01 ETH would be 1%)
    function calculateFee(uint256 amount, uint256 fee)
        internal
        pure
        returns (uint256)
    {
        return SafeMath.div(SafeMath.mul(amount, fee), 1 ether);
    }

    /*
    *   Payable fallback function
    */

    /// @notice payable fallback to allow handler or exchange contracts to return ether
    /// @dev only accounts containing code (ie. contracts) can send ether to contract
    function() external payable whenNotPaused {
        // Check in here that the sender is a contract! (to stop accidents)
        uint256 size;
        address sender = msg.sender;
        assembly {
            size := extcodesize(sender)
        }
        if (size == 0) {
            revert("EOA cannot send ether to primary fallback");
        }
    }
}

Contract Security Audit

Contract ABI

[{"constant":false,"inputs":[{"name":"signer","type":"address"}],"name":"removeSigner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"tokenTransferProxy","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"unpause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"components":[{"components":[{"components":[{"name":"sourceToken","type":"address"},{"name":"destinationToken","type":"address"},{"name":"amount","type":"uint256"},{"name":"isSourceAmount","type":"bool"},{"components":[{"name":"exchangeHandler","type":"address"},{"name":"encodedPayload","type":"bytes"}],"name":"orders","type":"tuple[]"}],"name":"trades","type":"tuple[]"},{"name":"minimumExchangeRate","type":"uint256"},{"name":"minimumDestinationAmount","type":"uint256"},{"name":"sourceAmount","type":"uint256"},{"name":"tradeToTakeFeeFrom","type":"uint256"},{"name":"takeFeeFromSource","type":"bool"},{"name":"redirectAddress","type":"address"},{"name":"required","type":"bool"}],"name":"swaps","type":"tuple[]"},{"name":"partnerContract","type":"address"},{"name":"expirationBlock","type":"uint256"},{"name":"id","type":"bytes32"},{"name":"maxGasPrice","type":"uint256"},{"name":"v","type":"uint8"},{"name":"r","type":"bytes32"},{"name":"s","type":"bytes32"}],"name":"swaps","type":"tuple"}],"name":"performSwapCollection","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"","type":"address"}],"name":"signers","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"MIN_REFUND_GAS_PRICE","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"GAS_TOKEN","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_token","type":"address"},{"name":"_amount","type":"uint256"}],"name":"withdrawToken","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"newMinRefundGasPrice","type":"uint256"}],"name":"updateMinRefundGasPrice","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"newSigner","type":"address"}],"name":"addSigner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_amount","type":"uint256"}],"name":"withdrawETH","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[{"name":"_tokenTransferProxy","type":"address"},{"name":"_signer","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"anonymous":false,"inputs":[{"indexed":true,"name":"id","type":"bytes32"},{"indexed":true,"name":"partnerContract","type":"address"},{"indexed":true,"name":"user","type":"address"}],"name":"LogSwapCollection","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"id","type":"bytes32"},{"indexed":false,"name":"sourceAsset","type":"address"},{"indexed":false,"name":"destinationAsset","type":"address"},{"indexed":false,"name":"sourceAmount","type":"uint256"},{"indexed":false,"name":"destinationAmount","type":"uint256"},{"indexed":false,"name":"feeAsset","type":"address"},{"indexed":false,"name":"feeAmount","type":"uint256"}],"name":"LogSwap","type":"event"},{"anonymous":false,"inputs":[],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[],"name":"Unpaused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"}],"name":"OwnershipRenounced","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"},{"indexed":true,"name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"}]

608060405260008054600160a01b60ff021916905563b2d05e006003553480156200002957600080fd5b506040516040806200291583398101806040526200004b9190810190620000aa565b60008054336001600160a01b0319918216178255600180549091166001600160a01b0394851617815591909216825260026020526040909120805460ff1916909117905562000108565b6000620000a38251620000e9565b9392505050565b60008060408385031215620000be57600080fd5b6000620000cc858562000095565b9250506020620000df8582860162000095565b9150509250929050565b6000620000f682620000fc565b92915050565b6001600160a01b031690565b6127fd80620001186000396000f3fe6080604052600436106100f35760003560e01c80638456cb591161008a578063c571c67e11610059578063c571c67e146102ab578063eb12d61e146102cb578063f14210a6146102eb578063f2fde38b1461030b576100f3565b80638456cb591461023f5780638af8d4c3146102545780638da5cb5b146102695780639e281a981461028b576100f3565b80635f10dffc116100c65780635f10dffc146101d5578063715018a6146101e8578063736c0d5b146101fd5780637822b9ae1461021d576100f3565b80630e316ab7146101515780630eefdbad146101735780633f4ba83a1461019e5780635c975abb146101b3575b600054600160a01b900460ff161561012957604051600160e51b62461bcd0281526004016101209061268b565b60405180910390fd5b33803b908161014d57604051600160e51b62461bcd0281526004016101209061262b565b5050005b34801561015d57600080fd5b5061017161016c366004611cf2565b61032b565b005b34801561017f57600080fd5b50610188610363565b60405161019591906125fd565b60405180910390f35b3480156101aa57600080fd5b50610171610372565b3480156101bf57600080fd5b506101c86103fc565b604051610195919061258d565b6101716101e3366004611d4a565b61040c565b3480156101f457600080fd5b50610171610674565b34801561020957600080fd5b506101c8610218366004611cf2565b6106e0565b34801561022957600080fd5b506102326106f5565b60405161019591906126bb565b34801561024b57600080fd5b506101716106fb565b34801561026057600080fd5b5061018861078c565b34801561027557600080fd5b5061027e61079f565b6040516101959190612481565b34801561029757600080fd5b506101c86102a6366004611d10565b6107ae565b3480156102b757600080fd5b506101716102c6366004611d7f565b6107e7565b3480156102d757600080fd5b506101716102e6366004611cf2565b610803565b3480156102f757600080fd5b50610171610306366004611d7f565b61083e565b34801561031757600080fd5b50610171610326366004611cf2565b610892565b6000546001600160a01b0316331461034257600080fd5b6001600160a01b03166000908152600260205260409020805460ff19169055565b6001546001600160a01b031681565b6000546001600160a01b0316331461038957600080fd5b600054600160a01b900460ff166103b557604051600160e51b62461bcd0281526004016101209061260b565b6000805474ff0000000000000000000000000000000000000000191681556040517fa45f47fdea8a1efdd9029a5691c7f759c32b7c698632b563573e155625d169339190a1565b600054600160a01b900460ff1690565b600054600160a01b900460ff161561043957604051600160e51b62461bcd0281526004016101209061268b565b804381604001511161046057604051600160e51b62461bcd028152600401610120906126ab565b816000816000015182602001518360400151846060015185608001513360405160200161049296959493929190612539565b604051602081830303815290604052805190602001209050600260006001836040516020016104c19190612456565b604051602081830303815290604052805190602001208560a001518660c001518760e0015160405160008152602001604052604051610503949392919061259b565b6020604051602081039080840390855afa158015610525573d6000803e3d6000fd5b505060408051601f1901516001600160a01b03168352602083019390935250016000205460ff1661056b57604051600160e51b62461bcd0281526004016101209061263b565b8380608001513a111561059357604051600160e51b62461bcd0281526004016101209061264b565b6003546000903a106105a3575a90505b6105ab61185e565b60405180604001604052806105be6108b5565b6001600160a01b0316815234602090910152815260005b8751518110156106125761060a8860600151896000015183815181106105f757fe5b6020026020010151848b602001516108ba565b6001016105d5565b506020870151606088015160405133926001600160a01b031691907fc3dcfccc2c1c6fe2a908d1825ba2e62b5b2d61a6b9c500791f75cdc538bdeb9d90600090a461065c81610cdf565b811561066b5761066b82610d47565b50505050505050565b6000546001600160a01b0316331461068b57600080fd5b600080546040516001600160a01b03909116917ff8df31144d9c2f0f6b59d69b8b98abd5459d07f2742c4df920b25aae33c6482091a26000805473ffffffffffffffffffffffffffffffffffffffff19169055565b60026020526000908152604090205460ff1681565b60035481565b6000546001600160a01b0316331461071257600080fd5b600054600160a01b900460ff161561073f57604051600160e51b62461bcd0281526004016101209061268b565b6000805474ff00000000000000000000000000000000000000001916600160a01b1781556040517f9e87fac88ff661f02d44f95383c817fece4bce600a3dab7a54406878b965e7529190a1565b6eb3f879cb30fe243b4dfee438691c0481565b6000546001600160a01b031681565b600080546001600160a01b031633146107c657600080fd5b6000546107de9084906001600160a01b031684610e13565b90505b92915050565b6000546001600160a01b031633146107fe57600080fd5b600355565b6000546001600160a01b0316331461081a57600080fd5b6001600160a01b03166000908152600260205260409020805460ff19166001179055565b6000546001600160a01b0316331461085557600080fd5b600080546040516001600160a01b039091169183156108fc02918491818181858888f1935050505015801561088e573d6000803e3d6000fd5b5050565b6000546001600160a01b031633146108a957600080fd5b6108b281610f0f565b50565b600090565b6108e58284600001516000815181106108cf57fe5b6020026020010151600001518560600151610f8a565b610913578260e001511561090e57604051600160e51b62461bcd0281526004016101209061266b565b610cd9565b60008080805b865151811015610acf5786608001518114801561093757508660a001515b1561097957610976868860000151838151811061095057fe5b602002602001015160000151878460001461096b5786610971565b8a606001515b61111b565b91505b60006109f18860000151838151811061098e57fe5b6020026020010151886109ec856000146109a857876109ae565b8b606001515b8b6109d48d8f600001518a815181106109c357fe5b6020026020010151600001516111d6565b601481106109de57fe5b602002015160200151611289565b61129f565b8951805191965091925083908110610a0557fe5b602002602001015160600151158015610a3657508751805183908110610a2757fe5b60200260200101516040015184105b15610a6a578760e0015115610a6057604051600160e51b62461bcd0281526004016101209061269b565b5050505050610cd9565b81610a7d579350838215610a7d57938201935b876080015182148015610a9257508760a00151155b15610ac657610abe8789600001518481518110610aab57fe5b602002602001015160200151888761111b565b925082840393505b50600101610919565b50867f7c396f87ca37e7dab636d7ffad74fe2ef4729fda118a0a2c105bf74f4890437f8760000151600081518110610b0357fe5b602090810291909101015151885180516000198101908110610b2157fe5b60200260200101516020015186868b60a00151610b5a578b5160808d015181518110610b4957fe5b602002602001015160200151610b78565b8b5160808d015181518110610b6b57fe5b6020026020010151600001515b87604051610b8b969594939291906124c4565b60405180910390a28560400151821015610bba57604051600160e51b62461bcd0281526004016101209061267b565b610c088660000151600081518110610bce57fe5b602090810291909101015151875180516000198101908110610bec57fe5b6020026020010151602001518860600151858a60200151611385565b15610c2857604051600160e51b62461bcd0281526004016101209061265b565b60c08601516001600160a01b03163314801590610c51575060c08601516001600160a01b031615155b1561066b5785518051600091610c83918891906000198101908110610c7257fe5b6020026020010151602001516111d6565b90506000610c97848884601481106109de57fe5b9050610ca987838a60c001518461140f565b87518051610cd39189916000198101908110610cc157fe5b602002602001015160200151836114be565b50505050505b50505050565b60005b601481101561088e578015801590610d1457506000828260148110610d0357fe5b6020020151516001600160a01b0316145b15610d1f57506108b2565b610d3f828233858560148110610d3157fe5b60200201516020015161140f565b600101610ce2565b60005a90508082036000610d6c61a0aa61374a840104611b6c616c3d19860104611289565b6040517f6366b9360000000000000000000000000000000000000000000000000000000081529091506eb3f879cb30fe243b4dfee438691c0490636366b93690610dba9084906004016126bb565b602060405180830381600087803b158015610dd457600080fd5b505af1158015610de8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250610e0c9190810190611d9d565b5050505050565b6000836001600160a01b03168383604051602401610e3292919061251e565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167fa9059cbb0000000000000000000000000000000000000000000000000000000017905251610e95919061244a565b6000604051808303816000865af19150503d8060008114610ed2576040519150601f19603f3d011682016040523d82523d6000602084013e610ed7565b606091505b50508091505080610efd57604051600160e51b62461bcd0281526004016101209061261b565b610f056114d7565b90505b9392505050565b6001600160a01b038116610f2257600080fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a36000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6000610f946108b5565b6001600160a01b0316836001600160a01b03161415610fca57835160200151821115610fc257506000610f08565b506001610f08565b6000610fd685856111d6565b9050848160148110610fe457fe5b602002015160200151831115611110576001546000906001600160a01b031685333089866014811061101257fe5b6020020151602001518803604051602401611030949392919061248f565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f15dacbea0000000000000000000000000000000000000000000000000000000017905251611093919061244a565b6000604051808303816000865af19150503d80600081146110d0576040519150601f19603f3d011682016040523d82523d6000602084013e6110d5565b606091505b5090915050801561110557838683601481106110ed57fe5b60200201516020018181525050600192505050610f08565b600092505050610f08565b506001949350505050565b6000808390506000816001600160a01b031663064367bb6040518163ffffffff1660e01b815260040160206040518083038186803b15801561115c57600080fd5b505afa158015611170573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052506111949190810190611d9d565b90506111a08482611506565b92506111b7876111b089896111d6565b878661140f565b6111cb876111c589896111d6565b85611523565b50505b949350505050565b6000805b601481101561128257826001600160a01b03168482601481106111f957fe5b6020020151516001600160a01b031614156112155790506107e1565b801580159061123e5750600084826014811061122d57fe5b6020020151516001600160a01b0316145b1561127a576040518060400160405280846001600160a01b03168152602001600081525084826014811061126e57fe5b602002015290506107e1565b6001016111da565b5092915050565b600081831061129857816107de565b5090919050565b6000808080805b87608001515181101561135c57858587036127100210156112c65761135c565b87606001511580156112db5750876040015182145b156112e55761135c565b876060015180156112f95750876040015183145b156113035761135c565b6113478860800151828151811061131657fe5b60200260200101518688038a6060015161133657868b604001510361133a565b8789035b60608c01518c518c611548565b958101959485019490935091506001016112a6565b5061136c868860200151856116e4565b61137b868860000151866114be565b5050935093915050565b6000806113906108b5565b6001600160a01b0316876001600160a01b0316146113b6576113b1876116fd565b6113b9565b60125b905060006113c56108b5565b6001600160a01b0316876001600160a01b0316146113eb576113e6876116fd565b6113ee565b60125b905060006113fe87878585611759565b851193505050505b95945050505050565b8015610cd95761141d6108b5565b6001600160a01b031684846014811061143257fe5b6020020151516001600160a01b03161415611483576040516001600160a01b0383169082156108fc029083906000818181858888f1935050505015801561147d573d6000803e3d6000fd5b50610cd9565b61149f84846014811061149257fe5b6020020151518383610e13565b610cd957604051600160e51b62461bcd0281526004016101209061261b565b60006114ca84846111d6565b9050610cd9848284611523565b60003d80156114ed57602081146114f657600080fd5b60019150611502565b60206000803e60005191505b5090565b60006107de61151584846117f0565b670de0b6b3a7640000611817565b8083836014811061153057fe5b60200201516020018181510391508181525050505050565b6000806115536108b5565b6001600160a01b0316846001600160a01b0316141561161b57875160208901516040517f0345c2a60000000000000000000000000000000000000000000000000000000081526001600160a01b0390921691630345c2a6918a916115c0919083908c908c906004016125c3565b60408051808303818588803b1580156115d857600080fd5b505af11580156115ec573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052506116119190810190611dbb565b90925090506116d9565b6116318361162985876111d6565b8a518a61140f565b875160208901516040517f0345c2a60000000000000000000000000000000000000000000000000000000081526001600160a01b0390921691630345c2a691611682918b908b908b906004016125c3565b6040805180830381600087803b15801561169b57600080fd5b505af11580156116af573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052506116d39190810190611dbb565b90925090505b965096945050505050565b60006116f084846111d6565b9050610cd9848284611839565b60008060405161170c90612476565b6040519081900381208082529150600460208083838160008a5af180801561173b576001811461174457611749565b60009650611749565b845196505b5050505060040160405250919050565b60006b204fce5e3e2502611000000085111561177457600080fd5b6b204fce5e3e2502611000000084111561178d57600080fd5b8282106117c657601283830311156117a457600080fd5b84838303600a0a02670de0b6b3a76400008502816117be57fe5b0490506111ce565b601282840311156117d657600080fd5b84828403600a0a670de0b6b3a7640000860202816117be57fe5b6000826117ff575060006107e1565b8282028284828161180c57fe5b04146107de57600080fd5b600080821161182557600080fd5b600082848161183057fe5b04949350505050565b8083836014811061184657fe5b60200201516020018181510191508181525050505050565b6040518061050001604052806014905b61187661188c565b81526020019060019003908161186e5790505090565b604080518082019091526000808252602082015290565b60006107de8235612751565b600082601f8301126118c057600080fd5b81356118d36118ce826126f0565b6126c9565b81815260209384019390925082018360005b8381101561191157813586016118fb8882611a3c565b84525060209283019291909101906001016118e5565b5050505092915050565b600082601f83011261192c57600080fd5b813561193a6118ce826126f0565b81815260209384019390925082018360005b8381101561191157813586016119628882611b73565b845250602092830192919091019060010161194c565b600082601f83011261198957600080fd5b81356119976118ce826126f0565b81815260209384019390925082018360005b8381101561191157813586016119bf8882611c3f565b84525060209283019291909101906001016119a9565b60006107de823561275c565b60006107de8235612761565b600082601f8301126119fe57600080fd5b8135611a0c6118ce82612711565b91508082526020830160208301858383011115611a2857600080fd5b611a33838284612781565b50505092915050565b600060408284031215611a4e57600080fd5b611a5860406126c9565b90506000611a6684846118a3565b825250602082013567ffffffffffffffff811115611a8357600080fd5b611a8f848285016119ed565b60208301525092915050565b60006101008284031215611aae57600080fd5b611ab96101006126c9565b9050813567ffffffffffffffff811115611ad257600080fd5b611ade8482850161191b565b8252506020611aef848483016118a3565b6020830152506040611b03848285016119e1565b6040830152506060611b17848285016119e1565b6060830152506080611b2b848285016119e1565b60808301525060a0611b3f84828501611ce6565b60a08301525060c0611b53848285016119e1565b60c08301525060e0611b67848285016119e1565b60e08301525092915050565b60006101008284031215611b8657600080fd5b611b916101006126c9565b9050813567ffffffffffffffff811115611baa57600080fd5b611bb684828501611978565b8252506020611bc7848483016119e1565b6020830152506040611bdb848285016119e1565b6040830152506060611bef848285016119e1565b6060830152506080611c03848285016119e1565b60808301525060a0611c17848285016119d5565b60a08301525060c0611c2b848285016118a3565b60c08301525060e0611b67848285016119d5565b600060a08284031215611c5157600080fd5b611c5b60a06126c9565b90506000611c6984846118a3565b8252506020611c7a848483016118a3565b6020830152506040611c8e848285016119e1565b6040830152506060611ca2848285016119d5565b606083015250608082013567ffffffffffffffff811115611cc257600080fd5b611cce848285016118af565b60808301525092915050565b60006107de8251612761565b60006107de8235612770565b600060208284031215611d0457600080fd5b60006111ce84846118a3565b60008060408385031215611d2357600080fd5b6000611d2f85856118a3565b9250506020611d40858286016119e1565b9150509250929050565b600060208284031215611d5c57600080fd5b813567ffffffffffffffff811115611d7357600080fd5b6111ce84828501611a9b565b600060208284031215611d9157600080fd5b60006111ce84846119e1565b600060208284031215611daf57600080fd5b60006111ce8484611cda565b60008060408385031215611dce57600080fd5b6000611dda8585611cda565b9250506020611d4085828601611cda565b60006107de8383612308565b60006107de8383612334565b60006107de83836123dc565b611e1881612751565b82525050565b6000611e298261273f565b611e338185612743565b935083602082028501611e4585612739565b60005b84811015611e7c578383038852611e60838351611deb565b9250611e6b82612739565b602098909801979150600101611e48565b50909695505050505050565b6000611e938261273f565b611e9d8185612743565b935083602082028501611eaf85612739565b60005b84811015611e7c578383038852611eca838351611df7565b9250611ed582612739565b602098909801979150600101611eb2565b6000611ef18261273f565b611efb8185612743565b935083602082028501611f0d85612739565b60005b84811015611e7c578383038852611f28838351611e03565b9250611f3382612739565b602098909801979150600101611f10565b611e188161275c565b611e1881612761565b611e18611f6282612761565b612761565b6000611f728261273f565b611f7c818561274c565b9350611f8c81856020860161278d565b9290920192915050565b6000611fa18261273f565b611fab8185612743565b9350611fbb81856020860161278d565b611fc4816127b9565b9093019392505050565b611e1881612776565b6000611fe4601483612743565b7f436f6e7472616374206e6f74207061757365642e000000000000000000000000815260200192915050565b600061201d601c8361274c565b7f19457468657265756d205369676e6564204d6573736167653a0a3332000000008152601c0192915050565b6000612056600f83612743565b7f5472616e73666572206661696c65640000000000000000000000000000000000815260200192915050565b600061208f600a8361274c565b7f646563696d616c732829000000000000000000000000000000000000000000008152600a0192915050565b60006120c8602983612743565b7f454f412063616e6e6f742073656e6420657468657220746f207072696d61727981527f2066616c6c6261636b0000000000000000000000000000000000000000000000602082015260400192915050565b6000612127601183612743565b7f496e76616c6964207369676e6174757265000000000000000000000000000000815260200192915050565b6000612160601283612743565b7f47617320707269636520746f6f20686967680000000000000000000000000000815260200192915050565b6000612199601d83612743565b7f4d696e696d756d2065786368616e67652072617465206e6f74206d6574000000815260200192915050565b60006121d2601d83612743565b7f4661696c656420746f2067657420746f6b656e7320666f722073776170000000815260200192915050565b600061220b602683612743565b7f476f74206c657373207468616e206d696e696d756d44657374696e6174696f6e81527f416d6f756e740000000000000000000000000000000000000000000000000000602082015260400192915050565b600061226a601383612743565b7f436f6e7472616374206973207061757365642e00000000000000000000000000815260200192915050565b60006122a3601d83612743565b7f4e6f7420656e6f7567682064657374696e6174696f6e20616d6f756e74000000815260200192915050565b60006122dc600783612743565b7f4578706972656400000000000000000000000000000000000000000000000000815260200192915050565b8051600090604084019061231c8582611e0f565b50602083015184820360208601526114068282611f96565b80516101008084526000919084019061234d8282611ee6565b91505060208301516123626020860182611f4d565b5060408301516123756040860182611f4d565b5060608301516123886060860182611f4d565b50608083015161239b6080860182611f4d565b5060a08301516123ae60a0860182611f44565b5060c08301516123c160c0860182611e0f565b5060e08301516123d460e0860182611f44565b509392505050565b805160009060a08401906123f08582611e0f565b5060208301516124036020860182611e0f565b5060408301516124166040860182611f4d565b5060608301516124296060860182611f44565b50608083015184820360808601526114068282611e1e565b611e1881612770565b6000610f088284611f67565b600061246182612010565b915061246d8284611f56565b50602001919050565b60006107e182612082565b602081016107e18284611e0f565b6080810161249d8287611e0f565b6124aa6020830186611e0f565b6124b76040830185611e0f565b6114066060830184611f4d565b60c081016124d28289611e0f565b6124df6020830188611e0f565b6124ec6040830187611f4d565b6124f96060830186611f4d565b6125066080830185611e0f565b61251360a0830184611f4d565b979650505050505050565b6040810161252c8285611e0f565b610f086020830184611f4d565b60c0808252810161254a8189611e88565b90506125596020830188611e0f565b6125666040830187611f4d565b6125736060830186611f4d565b6125806080830185611f4d565b61251360a0830184611e0f565b602081016107e18284611f44565b608081016125a98287611f4d565b6125b66020830186612441565b6124b76040830185611f4d565b608080825281016125d48187611f96565b90506125e36020830186611f4d565b6125f06040830185611f4d565b6114066060830184611f44565b602081016107e18284611fce565b602080825281016107e181611fd7565b602080825281016107e181612049565b602080825281016107e1816120bb565b602080825281016107e18161211a565b602080825281016107e181612153565b602080825281016107e18161218c565b602080825281016107e1816121c5565b602080825281016107e1816121fe565b602080825281016107e18161225d565b602080825281016107e181612296565b602080825281016107e1816122cf565b602081016107e18284611f4d565b60405181810167ffffffffffffffff811182821017156126e857600080fd5b604052919050565b600067ffffffffffffffff82111561270757600080fd5b5060209081020190565b600067ffffffffffffffff82111561272857600080fd5b506020601f91909101601f19160190565b60200190565b5190565b90815260200190565b919050565b60006107e182612764565b151590565b90565b6001600160a01b031690565b60ff1690565b60006107e182612751565b82818337506000910152565b60005b838110156127a8578181015183820152602001612790565b83811115610cd95750506000910152565b601f01601f19169056fea265627a7a7230582095d6985e82d5bc9264e0e5404d1cf09645ab81a9cefd5ede925f5f51e7747b4f6c6578706572696d656e74616cf5003700000000000000000000000074758acfce059f503a7e6b0fc2c8737600f9f2c4000000000000000000000000c2d7cf95645d33006175b78989035c7c9061d3f9

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

00000000000000000000000074758acfce059f503a7e6b0fc2c8737600f9f2c4000000000000000000000000c2d7cf95645d33006175b78989035c7c9061d3f9

-----Decoded View---------------
Arg [0] : _tokenTransferProxy (address): 0x74758AcFcE059f503a7E6B0fC2c8737600f9F2c4
Arg [1] : _signer (address): 0xC2D7CF95645D33006175B78989035C7c9061d3F9

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 00000000000000000000000074758acfce059f503a7e6b0fc2c8737600f9f2c4
Arg [1] : 000000000000000000000000c2d7cf95645d33006175b78989035c7c9061d3f9


Deployed ByteCode Sourcemap

26644:17656:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4818:7;;-1:-1:-1;;;4818:7:0;;;;4817:8;4809:40;;;;-1:-1:-1;;;;;4809:40:0;;;;;;;;;;;;;;;;;44104:10;44157:19;;;44201:9;44197:93;;44227:51;;-1:-1:-1;;;;;44227:51:0;;;;;;;;44197:93;4856:1;;26644:17656;31756:97;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;31756:97:0;;;;;;;;:::i;:::-;;26848:44;;8:9:-1;5:2;;;30:1;27;20:12;5:2;26848:44:0;;;:::i;:::-;;;;;;;;;;;;;;;;5314:97;;8:9:-1;5:2;;;30:1;27;20:12;5:2;5314:97:0;;;:::i;4599:72::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;4599:72:0;;;:::i;:::-;;;;;;;;30207:1074;;;;;;;;;:::i;1080:114::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;1080:114:0;;;:::i;26899:39::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;26899:39:0;;;;;;;;:::i;26945:48::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;26945:48:0;;;:::i;:::-;;;;;;;;5132:95;;8:9:-1;5:2;;;30:1;27;20:12;5:2;5132:95:0;;;:::i;26742:99::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;26742:99:0;;;:::i;277:28::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;277:28:0;;;:::i;:::-;;;;;;;;3767:170;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;3767:170:0;;;;;;;;:::i;31861:167::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;31861:167:0;;;;;;;;:::i;31649:99::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;31649:99:0;;;;;;;;:::i;4188:::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;4188:99:0;;;;;;;;:::i;1362:113::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;1362:113:0;;;;;;;;:::i;31756:97::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;-1:-1:-1;;;;;31822:15:0;31840:5;31822:15;;;:7;:15;;;;;:23;;-1:-1:-1;;31822:23:0;;;31756:97::o;26848:44::-;;;-1:-1:-1;;;;;26848:44:0;;:::o;5314:97::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;5002:7;;-1:-1:-1;;;5002:7:0;;;;4994:40;;;;-1:-1:-1;;;;;4994:40:0;;;;;;;;;5378:5;5368:15;;-1:-1:-1;;5368:15:0;;;5395:10;;;;5378:5;5395:10;5314:97::o;4599:72::-;4638:4;4658:7;-1:-1:-1;;;4658:7:0;;;;;4599:72::o;30207:1074::-;4818:7;;-1:-1:-1;;;4818:7:0;;;;4817:8;4809:40;;;;-1:-1:-1;;;;;4809:40:0;;;;;;;;;30343:5;29180:12;29156:5;:21;;;:36;29148:56;;;;-1:-1:-1;;;;;29148:56:0;;;;;;;;;30374:5;29296:12;29364:5;:11;;;29394:5;:21;;;29434:5;:21;;;29474:5;:8;;;29501:5;:17;;;29537:10;29335:227;;;;;;;;;;;;;;;;;49:4:-1;39:7;30;26:21;22:32;13:7;6:49;29335:227:0;;;29311:262;;;;;;29296:277;;29606:7;:239;29614:230;29727:4;29674:58;;;;;;;;;;;;49:4:-1;39:7;30;26:21;22:32;13:7;6:49;29674:58:0;;;29642:109;;;;;;29770:5;:7;;;29796:5;:7;;;29822:5;:7;;;29614:230;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;29614:230:0;;;-1:-1:-1;;29614:230:0;;-1:-1:-1;;;;;29606:239:0;;;29614:230;29606:239;;;;;;-1:-1:-1;29606:239:0;-1:-1:-1;29606:239:0;;;;29584:306;;;;-1:-1:-1;;;;;29584:306:0;;;;;;;;;30405:5;30005;:17;;;29990:11;:32;;29982:63;;;;-1:-1:-1;;;;;29982:63:0;;;;;;;;;30481:20;;30428:19;;30466:11;:35;30462:91;;30532:9;30518:23;;30462:91;30563:52;;:::i;:::-;30640:110;;;;;;;;30695:19;:17;:19::i;:::-;-1:-1:-1;;;;;30640:110:0;;;30730:9;30640:110;;;;;30626:124;;-1:-1:-1;30761:311:0;30828:11;;:18;30816:30;;30761:311;;;30899:161;30929:5;:8;;;30956:5;:11;;;30968:9;30956:22;;;;;;;;;;;;;;30997:8;31024:5;:21;;;30899:11;:161::i;:::-;30861:11;;30761:311;;;-1:-1:-1;31115:21:0;;;;31105:8;;;;31087:62;;31138:10;;-1:-1:-1;;;;;31087:62:0;;31105:8;31087:62;;;;;31160:33;31184:8;31160:23;:33::i;:::-;31208:15;;31204:70;;31240:22;31250:11;31240:9;:22::i;:::-;30056:1;;29901;29215;;4856;30207:1074;:::o;1080:114::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;1157:5;;;1138:25;;-1:-1:-1;;;;;1157:5:0;;;;1138:25;;;1186:1;1170:18;;-1:-1:-1;;1170:18:0;;;1080:114::o;26899:39::-;;;;;;;;;;;;;;;:::o;26945:48::-;;;;:::o;5132:95::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;4818:7;;-1:-1:-1;;;4818:7:0;;;;4817:8;4809:40;;;;-1:-1:-1;;;;;4809:40:0;;;;;;;;;5187:7;:14;;-1:-1:-1;;5187:14:0;-1:-1:-1;;;5187:14:0;;;5213:8;;;;5187:7;5213:8;5132:95::o;26742:99::-;26792:42;26742:99;:::o;277:28::-;;;-1:-1:-1;;;;;277:28:0;;:::o;3767:170::-;3851:4;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;3914:5;;3875:54;;3906:6;;-1:-1:-1;;;;;3914:5:0;3921:7;3875:30;:54::i;:::-;3868:61;;801:1;3767:170;;;;:::o;31861:167::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;31977:20;:43;31861:167::o;31649:99::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;-1:-1:-1;;;;;31715:18:0;;;;;:7;:18;;;;;:25;;-1:-1:-1;;31715:25:0;31736:4;31715:25;;;31649:99::o;4188:::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;4256:5;;;:23;;-1:-1:-1;;;;;4256:5:0;;;;:23;;;;;4271:7;;4256:23;:5;:23;4271:7;4256:5;:23;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;4256:23:0;4188:99;:::o;1362:113::-;788:5;;-1:-1:-1;;;;;788:5:0;774:10;:19;766:28;;;;;;1440:29;1459:9;1440:18;:29::i;:::-;1362:113;:::o;10799:78::-;10845:7;10799:78;:::o;32080:4467::-;32314:151;32361:8;32388:4;:11;;;32400:1;32388:14;;;;;;;;;;;;;;:26;;;32433:4;:17;;;32314:28;:151::i;:::-;32295:348;;32496:4;:13;;;32492:140;;;32530:39;;-1:-1:-1;;;;;32530:39:0;;;;;;;;32492:140;32610:7;;32492:140;32653:29;;;;32766:1980;32835:11;;:18;32822:31;;32766:1980;;;32943:4;:23;;;32929:10;:37;:63;;;;;32970:4;:22;;;32929:63;32907:376;;;33039:228;33069:8;33100:4;:11;;;33112:10;33100:23;;;;;;;;;;;;;;:35;;;33158:15;33196:10;33210:1;33196:15;:52;;33234:14;33196:52;;;33214:4;:17;;;33196:52;33039:7;:228::i;:::-;33027:240;;32907:376;33297:17;33359:434;33390:4;:11;;;33402:10;33390:23;;;;;;;;;;;;;;33432:8;33459:319;33491:10;33505:1;33491:15;:52;;33529:14;33491:52;;;33509:4;:17;;;33491:52;33566:8;33575:149;33631:8;33666:4;:11;;;33678:10;33666:23;;;;;;;;;;;;;;:35;;;33575:29;:149::i;:::-;33566:159;;;;;;;;;;;:193;;;33459:9;:319::i;:::-;33359:12;:434::i;:::-;33831:11;;:23;;33329:464;;-1:-1:-1;33329:464:0;;-1:-1:-1;33843:10:0;;33831:23;;;;;;;;;;;;:38;;;33830:39;:107;;;;-1:-1:-1;33907:11:0;;:23;;33919:10;;33907:23;;;;;;;;;;;;:30;;;33890:14;:47;33830:107;33808:305;;;33976:4;:13;;;33972:101;;;34014:39;;-1:-1:-1;;;;;34014:39:0;;;;;;;;33972:101;34091:7;;;;;;;33808:305;34131:15;34127:204;;34191:9;-1:-1:-1;34191:9:0;34223:14;;34219:97;;34262:34;;;;34219:97;34381:4;:23;;;34367:10;:37;:64;;;;;34409:4;:22;;;34408:23;34367:64;34345:390;;;34478:195;34508:8;34539:4;:11;;;34551:10;34539:23;;;;;;;;;;;;;;:40;;;34602:15;34640:14;34478:7;:195::i;:::-;34466:207;;34710:9;34692:27;;;;34345:390;-1:-1:-1;32868:12:0;;32766:1980;;;;34783:16;34761:424;34814:4;:11;;;34826:1;34814:14;;;;;;;;;;;;;;;;;;:26;34855:11;;34867:18;;-1:-1:-1;;34867:22:0;;;34855:35;;;;;;;;;;;;:52;;;34922:21;34958:14;34987:4;:22;;;:163;;35097:11;;35109:23;;;;35097:36;;;;;;;;;;;;;;:53;;;34987:163;;;35029:11;;35041:23;;;;35029:36;;;;;;;;;;;;;;:48;;;34987:163;35165:9;34761:424;;;;;;;;;;;;;;;;;;;;35219:4;:29;;;35202:14;:46;35198:489;;;35265:48;;-1:-1:-1;;;;;35265:48:0;;;;;;;;35198:489;35349:260;35385:4;:11;;;35397:1;35385:14;;;;;;;;;;;;;;;;;;:26;35430:11;;35442:18;;-1:-1:-1;;35442:22:0;;;35430:35;;;;;;;;;;;;:52;;;35501:4;:17;;;35537:14;35570:4;:24;;;35349:17;:260::i;:::-;35331:356;;;35636:39;;-1:-1:-1;;;;;35636:39:0;;;;;;;;35331:356;35715:20;;;;-1:-1:-1;;;;;35715:34:0;35739:10;35715:34;;;;:87;;-1:-1:-1;35766:20:0;;;;-1:-1:-1;;;;;35766:36:0;;;35715:87;35697:843;;;35936:11;;35948:18;;35829:29;;35861:142;;35909:8;;35936:11;-1:-1:-1;;35948:22:0;;;35936:35;;;;;;;;;;;;:52;;;35861:29;:142::i;:::-;35829:174;;36018:20;36041:114;36068:14;36101:8;36110:21;36101:31;;;;;;36041:114;36018:137;;36170:166;36203:8;36230:21;36270:4;:20;;;36309:12;36170:14;:166::i;:::-;36430:11;;36442:18;;36351:177;;36403:8;;-1:-1:-1;;36442:22:0;;;36430:35;;;;;;;;;;;;:52;;;36501:12;36351:33;:177::i;:::-;35697:843;;32080:4467;;;;;;;;:::o;41930:633::-;42072:20;42053:503;42126:15;42111:12;:30;42053:503;;;42219:17;;;;;:89;;-1:-1:-1;42304:3:0;42257:8;42266:12;42257:22;;;;;;;;;;;:35;-1:-1:-1;;;;;42257:51:0;;42219:89;42197:168;;;42343:7;;;42197:168;42379:165;42412:8;42439:12;42470:10;42499:8;42508:12;42499:22;;;;;;;;;;;:30;;;42379:14;:165::i;:::-;42156:14;;42053:503;;31289:352;31349:20;31372:9;31349:32;-1:-1:-1;31411:26:0;;;31392:16;31471:119;31515:5;31506;31495:16;;31494:26;31561:17;-1:-1:-1;;31536:20:0;;31535:44;31471:8;:119::i;:::-;31601:32;;;;;31448:142;;-1:-1:-1;26792:42:0;;31601:18;;:32;;31448:142;;31601:32;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;31601:32:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;31601:32:0;;;;;;;101:4:-1;97:9;90:4;84;80:15;76:31;69:5;65:43;126:6;120:4;113:20;0:138;31601:32:0;;;;;;;;;;31289:352;;;;:::o;1839:306::-;1931:12;1969:13;-1:-1:-1;;;;;1969:18:0;2041:3;2046:6;1988:65;;;;;;;;;;;;;;-1:-1:-1;;26:21;;;22:32;6:49;;1988:65:0;;;49:4:-1;25:18;;61:17;;1988:65:0;182:15:-1;1988:65:0;179:29:-1;160:49;;1969:85:0;;;1988:65;1969:85;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;;1956:98:0;;;;;2073:7;2065:35;;;;-1:-1:-1;;;;;2065:35:0;;;;;;;;;2120:17;:15;:17::i;:::-;2113:24;;1839:306;;;;;;:::o;1616:183::-;-1:-1:-1;;;;;1695:23:0;;1687:32;;;;;;1752:5;;;1731:38;;-1:-1:-1;;;;;1731:38:0;;;;1752:5;;;1731:38;;;1776:5;:17;;-1:-1:-1;;1776:17:0;-1:-1:-1;;;;;1776:17:0;;;;;;;;;;1616:183::o;40812:1110::-;40993:4;41023:19;:17;:19::i;:::-;-1:-1:-1;;;;;41014:28:0;:5;-1:-1:-1;;;;;41014:28:0;;41010:173;;;41078:11;;;:19;;41063:34;;41059:87;;;-1:-1:-1;41125:5:0;41118:12;;41059:87;-1:-1:-1;41167:4:0;41160:11;;41010:173;41195:18;41216:46;41246:8;41256:5;41216:29;:46::i;:::-;41195:67;;41292:8;41301:10;41292:20;;;;;;;;;;;:28;;;41277:12;:43;41273:620;;;41386:18;;41337:12;;-1:-1:-1;;;;;41386:18:0;41545:5;41573:10;41614:4;41657:8;41666:10;41657:20;;;;;;;;;;;:28;;;41642:12;:43;41429:275;;;;;;;;;;;;;;;;-1:-1:-1;;26:21;;;22:32;6:49;;41429:275:0;;;49:4:-1;25:18;;61:17;;41429:275:0;182:15:-1;41429:275:0;179:29:-1;160:49;;41378:341:0;;;41429:275;41378:341;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;-1:-1;41364:355:0;;-1:-1:-1;;41734:121:0;;;;41797:12;41766:8;41775:10;41766:20;;;;;;;;;;;:28;;:43;;;;;41835:4;41828:11;;;;;;41734:121;41876:5;41869:12;;;;;;41273:620;-1:-1:-1;41910:4:0;;40812:1110;-1:-1:-1;;;;40812:1110:0:o;40028:776::-;40230:17;40260:15;40286;40260:42;;40313:21;40337:7;-1:-1:-1;;;;;40337:29:0;;:31;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;40337:31:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;40337:31:0;;;;;;;101:4:-1;97:9;90:4;84;80:15;76:31;69:5;65:43;126:6;120:4;113:20;0:138;40337:31:0;;;;;;;;;40313:55;;40391:41;40404:12;40418:13;40391:12;:41::i;:::-;40379:53;;40443:163;40472:8;40495:46;40525:8;40535:5;40495:29;:46::i;:::-;40556:15;40586:9;40443:14;:163::i;:::-;40617:152;40665:8;40688:46;40718:8;40728:5;40688:29;:46::i;:::-;40749:9;40617:33;:152::i;:::-;-1:-1:-1;;40028:776:0;;;;;;;:::o;24439:532::-;24557:7;;24582:382;24614:15;24606:5;:23;24582:382;;;24691:5;-1:-1:-1;;;;;24659:37:0;:8;24668:5;24659:15;;;;;;;;;;;:28;-1:-1:-1;;;;;24659:37:0;;24655:298;;;24724:5;-1:-1:-1;24717:12:0;;24655:298;24773:10;;;;;:58;;-1:-1:-1;24827:3:0;24787:8;24796:5;24787:15;;;;;;;;;;;:28;-1:-1:-1;;;;;24787:44:0;;24773:58;24751:202;;;24884:22;;;;;;;;24897:5;-1:-1:-1;;;;;24884:22:0;;;;;24904:1;24884:22;;;24866:8;24875:5;24866:15;;;;;;;;;;:40;24932:5;-1:-1:-1;24925:12:0;;24751:202;24631:7;;24582:382;;;;24439:532;;;;:::o;16187:106::-;16245:7;16276:1;16272;:5;:13;;16284:1;16272:13;;;-1:-1:-1;16280:1:0;;16187:106;-1:-1:-1;16187:106:0:o;36555:1529::-;36729:18;;;;;36850:952;36919:5;:12;;;:19;36906:10;:32;36850:952;;;37038:16;37016:10;36997:16;:29;37030:5;36996:39;:58;36992:310;;;37075:5;;36992:310;37107:5;:20;;;37106:21;:53;;;;;37147:5;:12;;;37131;:28;37106:53;37102:200;;;37180:5;;37102:200;37211:5;:20;;;:49;;;;;37248:5;:12;;;37235:9;:25;37211:49;37207:95;;;37281:5;;37207:95;37344:364;37375:5;:12;;;37388:10;37375:24;;;;;;;;;;;;;;37437:10;37418:16;:29;37466:5;:20;;;:125;;37578:13;37563:5;:12;;;:28;37466:125;;;37529:10;37510:16;:29;37466:125;37610:20;;;;37649:17;;37685:8;37344:12;:364::i;:::-;37723:23;;;;37761:29;;;;37316:392;;-1:-1:-1;37316:392:0;-1:-1:-1;36953:12:0;;36850:952;;;;37812:129;37857:8;37880:5;:22;;;37917:13;37812:30;:129::i;:::-;37952:124;38000:8;38023:5;:17;;;38055:10;37952:33;:124::i;:::-;36555:1529;;;;;;;;:::o;39264:756::-;39486:11;39510:22;39550:19;:17;:19::i;:::-;-1:-1:-1;;;;;39535:34:0;:11;-1:-1:-1;;;;;39535:34:0;;:98;;39603:30;39621:11;39603:17;:30::i;:::-;39535:98;;;39585:2;39535:98;39510:123;;39644:27;39694:19;:17;:19::i;:::-;-1:-1:-1;;;;;39674:39:0;:16;-1:-1:-1;;;;;39674:39:0;;:108;;39747:35;39765:16;39747:17;:35::i;:::-;39674:108;;;39729:2;39674:108;39644:138;;39793:15;39811:154;39847:12;39874:17;39906:14;39935:19;39811:21;:154::i;:::-;39983:29;-1:-1:-1;39983:29:0;-1:-1:-1;;;;39264:756:0;;;;;;;;:::o;42571:714::-;42786:15;;42782:496;;42859:19;:17;:19::i;:::-;-1:-1:-1;;;;;42822:56:0;:8;42831:10;42822:20;;;;;;;;;;;:33;-1:-1:-1;;;;;42822:56:0;;42818:449;;;42899:33;;-1:-1:-1;;;;;42899:20:0;;;:33;;;;;42920:11;;42899:33;;;;42920:11;42899:20;:33;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;42899:33:0;42818:449;;;43003:189;43060:8;43069:10;43060:20;;;;;;;;;;;:33;43120:11;43158;43003:30;:189::i;:::-;42973:278;;;;-1:-1:-1;;;;;42973:278:0;;;;;;;;25478:286;25640:18;25661:33;25671:8;25681:12;25661:9;:33::i;:::-;25640:54;;25705:51;25719:8;25729:10;25741:14;25705:13;:51::i;2832:391::-;2882:12;2937:16;2967:53;;;;3039:2;3034:103;;;;3188:1;3185;3178:12;2967:53;3004:1;2993:12;;2967:53;;3034:103;3082:2;3079:1;3076;3061:24;3120:1;3114:8;3103:19;;2930:275;;2915:301;:::o;43508:189::-;43609:7;43641:48;43654:25;43667:6;43675:3;43654:12;:25::i;:::-;43681:7;43641:12;:48::i;25772:218::-;25968:14;25934:8;25943:12;25934:22;;;;;;;;;;;:30;;:48;;;;;;;;;;;25772:218;;;:::o;38092:1164::-;38358:13;38373:16;38422:19;:17;:19::i;:::-;-1:-1:-1;;;;;38406:35:0;:12;-1:-1:-1;;;;;38406:35:0;;38402:847;;;38494:21;;38608:20;;;;38478:264;;;;;-1:-1:-1;;;;;38478:69:0;;;;;;38572:16;;38478:264;;38608:20;38572:16;;38682:12;;38713:14;;38478:264;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;38478:264:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;38478:264:0;;;;;;;;101:4:-1;97:9;90:4;84;80:15;76:31;69:5;65:43;126:6;120:4;113:20;0:138;38478:264:0;;;;;;;;;38458:284;;-1:-1:-1;38458:284:0;-1:-1:-1;38402:847:0;;;38777:203;38810:8;38837:53;38867:8;38877:12;38837:29;:53::i;:::-;38909:21;;38949:16;38777:14;:203::i;:::-;39031:21;;39103:20;;;;39015:222;;;;;-1:-1:-1;;;;;39015:69:0;;;;;;:222;;39142:16;;39177:12;;39208:14;;39015:222;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;39015:222:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;39015:222:0;;;;;;;101:4:-1;97:9;90:4;84;80:15;76:31;69:5;65:43;126:6;120:4;113:20;0:138;39015:222:0;;;;;;;;;38995:242;;-1:-1:-1;38995:242:0;-1:-1:-1;38402:847:0;38092:1164;;;;;;;;;:::o;24979:274::-;25135:18;25156:33;25166:8;25176:12;25156:9;:33::i;:::-;25135:54;;25200:45;25211:8;25221:10;25233:11;25200:10;:45::i;11262:1531::-;11334:16;11368:18;11396:23;;;;;;;;;;;;;;;11756;;;11396;-1:-1:-1;11818:4:0;11854;;11396:23;11818:4;11396:23;12042:1;11983:5;11928:3;11889:497;12409:7;12430:122;;;;12571:1;12566:104;;;;12402:268;;12430:122;12468:1;12456:13;;12430:122;;12566:104;12610:3;12604:10;12592:22;;12402:268;-1:-1:-1;;;;12704:4:0;12696:13;12691:4;12684:26;-1:-1:-1;11606:1180:0;;-1:-1:-1;11606:1180:0:o;15439:628::-;15565:4;9876:6;15595:9;:20;;15587:29;;;;;;9876:6;15635:10;:21;;15627:30;;;;;;15689:11;15674;:26;15670:390;;10036:2;15740:11;15726;:25;15725:43;;15717:52;;;;;;15856:9;15840:11;15826;:25;15819:2;:33;15818:47;9823:6;15792:10;:22;:74;;;;;;15784:83;;;;15670:390;10036:2;15923:11;15909;:25;15908:43;;15900:52;;;;;;16038:9;16022:11;16008;:25;16001:2;:33;9823:6;15975:10;:22;:60;:72;;;;16487:400;16547:7;16775;16771:38;;-1:-1:-1;16800:1:0;16793:8;;16771:38;16829:7;;;16834:2;16829;:7;:2;16851:6;;;;;:12;16843:21;;;;;17002:285;17062:7;17091:1;17086:2;:6;17078:15;;;;;;17158:9;17175:2;17170;:7;;;;;;;17002:285;-1:-1:-1;;;;17002:285:0:o;25261:209::-;25451:11;25417:8;25426:12;25417:22;;;;;;;;;;;:30;;:45;;;;;;;;;;;25261:209;;;:::o;26644:17656::-;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;:::o;:::-;;;;;;;;;;-1:-1:-1;26644:17656:0;;;;;;;;:::o;5:118:-1:-;;72:46;110:6;97:20;72:46;;307:727;;439:3;432:4;424:6;420:17;416:27;406:2;;457:1;454;447:12;406:2;494:6;481:20;516:95;531:79;603:6;531:79;;;516:95;;;639:21;;;683:4;671:17;;;;507:104;;-1:-1;696:14;;671:17;791:1;776:252;801:6;798:1;795:13;776:252;;;884:3;871:17;863:6;859:30;908:56;960:3;948:10;908:56;;;896:69;;-1:-1;988:4;979:14;;;;1007;;;;;823:1;816:9;776:252;;;780:14;399:635;;;;;;;;1077:724;;1208:3;1201:4;1193:6;1189:17;1185:27;1175:2;;1226:1;1223;1216:12;1175:2;1263:6;1250:20;1285:94;1300:78;1371:6;1300:78;;1285:94;1407:21;;;1451:4;1439:17;;;;1276:103;;-1:-1;1464:14;;1439:17;1559:1;1544:251;1569:6;1566:1;1563:13;1544:251;;;1652:3;1639:17;1631:6;1627:30;1676:55;1727:3;1715:10;1676:55;;;1664:68;;-1:-1;1755:4;1746:14;;;;1774;;;;;1591:1;1584:9;1544:251;;1845:727;;1977:3;1970:4;1962:6;1958:17;1954:27;1944:2;;1995:1;1992;1985:12;1944:2;2032:6;2019:20;2054:95;2069:79;2141:6;2069:79;;2054:95;2177:21;;;2221:4;2209:17;;;;2045:104;;-1:-1;2234:14;;2209:17;2329:1;2314:252;2339:6;2336:1;2333:13;2314:252;;;2422:3;2409:17;2401:6;2397:30;2446:56;2498:3;2486:10;2446:56;;;2434:69;;-1:-1;2526:4;2517:14;;;;2545;;;;;2361:1;2354:9;2314:252;;2580:112;;2644:43;2679:6;2666:20;2644:43;;2699:118;;2766:46;2804:6;2791:20;2766:46;;2825:432;;2922:3;2915:4;2907:6;2903:17;2899:27;2889:2;;2940:1;2937;2930:12;2889:2;2977:6;2964:20;2999:60;3014:44;3051:6;3014:44;;2999:60;2990:69;;3079:6;3072:5;3065:21;3115:4;3107:6;3103:17;3148:4;3141:5;3137:16;3183:3;3174:6;3169:3;3165:16;3162:25;3159:2;;;3200:1;3197;3190:12;3159:2;3210:41;3244:6;3239:3;3234;3210:41;;;2882:375;;;;;;;;3297:580;;3405:4;3393:9;3388:3;3384:19;3380:30;3377:2;;;3423:1;3420;3413:12;3377:2;3441:20;3456:4;3441:20;;;3432:29;-1:-1;3522:1;3553:57;3606:3;3586:9;3553:57;;;3529:82;;-1:-1;3710:2;3695:18;;3682:32;3734:18;3723:30;;3720:2;;;3766:1;3763;3756:12;3720:2;3801:54;3851:3;3842:6;3831:9;3827:22;3801:54;;;3794:4;3787:5;3783:16;3776:80;3632:235;3371:506;;;;;3925:1493;;4046:5;4034:9;4029:3;4025:19;4021:31;4018:2;;;4065:1;4062;4055:12;4018:2;4083:21;4098:5;4083:21;;;4074:30;-1:-1;4155:31;;4206:18;4195:30;;4192:2;;;4238:1;4235;4228:12;4192:2;4272:88;4356:3;4347:6;4336:9;4332:22;4272:88;;;4248:113;;-1:-1;4433:2;4466:57;4519:3;4495:22;;;4466:57;;;4459:4;4452:5;4448:16;4441:83;4382:153;4596:2;4629:49;4674:3;4665:6;4654:9;4650:22;4629:49;;;4622:4;4615:5;4611:16;4604:75;4545:145;4738:2;4771:49;4816:3;4807:6;4796:9;4792:22;4771:49;;;4764:4;4757:5;4753:16;4746:75;4700:132;4889:3;4923:49;4968:3;4959:6;4948:9;4944:22;4923:49;;;4916:4;4909:5;4905:16;4898:75;4842:142;5031:3;5065:47;5108:3;5099:6;5088:9;5084:22;5065:47;;;5058:4;5051:5;5047:16;5040:73;4994:130;5171:3;5205:49;5250:3;5241:6;5230:9;5226:22;5205:49;;;5198:4;5191:5;5187:16;5180:75;5134:132;5313:3;5347:49;5392:3;5383:6;5372:9;5368:22;5347:49;;;5340:4;5333:5;5329:16;5322:75;5276:132;4012:1406;;;;;5456:1544;;5563:5;5551:9;5546:3;5542:19;5538:31;5535:2;;;5582:1;5579;5572:12;5535:2;5600:21;5615:5;5600:21;;;5591:30;-1:-1;5673:31;;5724:18;5713:30;;5710:2;;;5756:1;5753;5746:12;5710:2;5790:89;5875:3;5866:6;5855:9;5851:22;5790:89;;;5766:114;;-1:-1;5956:2;5989:49;6034:3;6010:22;;;5989:49;;;5982:4;5975:5;5971:16;5964:75;5901:149;6120:2;6153:49;6198:3;6189:6;6178:9;6174:22;6153:49;;;6146:4;6139:5;6135:16;6128:75;6060:154;6272:2;6305:49;6350:3;6341:6;6330:9;6326:22;6305:49;;;6298:4;6291:5;6287:16;6280:75;6224:142;6430:3;6464:49;6509:3;6500:6;6489:9;6485:22;6464:49;;;6457:4;6450:5;6446:16;6439:75;6376:149;6588:3;6622:46;6664:3;6655:6;6644:9;6640:22;6622:46;;;6615:4;6608:5;6604:16;6597:72;6535:145;6741:3;6775:57;6828:3;6819:6;6808:9;6804:22;6775:57;;;6768:4;6761:5;6757:16;6750:83;6690:154;6898:3;6932:46;6974:3;6965:6;6954:9;6950:22;6932:46;;7039:1049;;7147:4;7135:9;7130:3;7126:19;7122:30;7119:2;;;7165:1;7162;7155:12;7119:2;7183:20;7198:4;7183:20;;;7174:29;-1:-1;7260:1;7291:49;7336:3;7316:9;7291:49;;;7267:74;;-1:-1;7414:2;7447:49;7492:3;7468:22;;;7447:49;;;7440:4;7433:5;7429:16;7422:75;7362:146;7560:2;7593:49;7638:3;7629:6;7618:9;7614:22;7593:49;;;7586:4;7579:5;7575:16;7568:75;7518:136;7714:2;7747:46;7789:3;7780:6;7769:9;7765:22;7747:46;;;7740:4;7733:5;7729:16;7722:72;7664:141;7885:3;7874:9;7870:19;7857:33;7910:18;7902:6;7899:30;7896:2;;;7942:1;7939;7932:12;7896:2;7977:89;8062:3;8053:6;8042:9;8038:22;7977:89;;;7970:4;7963:5;7959:16;7952:115;7815:263;7113:975;;;;;8220:122;;8298:39;8329:6;8323:13;8298:39;;8349:114;;8414:44;8450:6;8437:20;8414:44;;8470:241;;8574:2;8562:9;8553:7;8549:23;8545:32;8542:2;;;8590:1;8587;8580:12;8542:2;8625:1;8642:53;8687:7;8667:9;8642:53;;8982:366;;;9103:2;9091:9;9082:7;9078:23;9074:32;9071:2;;;9119:1;9116;9109:12;9071:2;9154:1;9171:53;9216:7;9196:9;9171:53;;;9161:63;;9133:97;9261:2;9279:53;9324:7;9315:6;9304:9;9300:22;9279:53;;;9269:63;;9240:98;9065:283;;;;;;9355:391;;9491:2;9479:9;9470:7;9466:23;9462:32;9459:2;;;9507:1;9504;9497:12;9459:2;9542:31;;9593:18;9582:30;;9579:2;;;9625:1;9622;9615:12;9579:2;9645:85;9722:7;9713:6;9702:9;9698:22;9645:85;;9753:241;;9857:2;9845:9;9836:7;9832:23;9828:32;9825:2;;;9873:1;9870;9863:12;9825:2;9908:1;9925:53;9970:7;9950:9;9925:53;;10001:263;;10116:2;10104:9;10095:7;10091:23;10087:32;10084:2;;;10132:1;10129;10122:12;10084:2;10167:1;10184:64;10240:7;10220:9;10184:64;;10271:399;;;10403:2;10391:9;10382:7;10378:23;10374:32;10371:2;;;10419:1;10416;10409:12;10371:2;10454:1;10471:64;10527:7;10507:9;10471:64;;;10461:74;;10433:108;10572:2;10590:64;10646:7;10637:6;10626:9;10622:22;10590:64;;10678:233;;10817:88;10901:3;10893:6;10817:88;;10920:229;;11057:86;11139:3;11131:6;11057:86;;11158:233;;11297:88;11381:3;11373:6;11297:88;;11399:134;11488:39;11521:5;11488:39;;;11483:3;11476:52;11470:63;;;12002:895;;12171:69;12234:5;12171:69;;;12253:95;12341:6;12336:3;12253:95;;;12246:102;;12371:3;12413:4;12405:6;12401:17;12396:3;12392:27;12439:71;12504:5;12439:71;;;12531:1;12516:342;12541:6;12538:1;12535:13;12516:342;;;12603:9;12597:4;12593:20;12588:3;12581:33;12629:102;12726:4;12717:6;12711:13;12629:102;;;12621:110;;12748:75;12816:6;12748:75;;;12846:4;12837:14;;;;;12738:85;-1:-1;12563:1;12556:9;12516:342;;;-1:-1;12871:4;;12150:747;-1:-1;;;;;;12150:747;12970:907;;13147:68;13209:5;13147:68;;;13228:104;13325:6;13320:3;13228:104;;;13221:111;;13355:3;13397:4;13389:6;13385:17;13380:3;13376:27;13423:70;13487:5;13423:70;;;13514:1;13499:339;13524:6;13521:1;13518:13;13499:339;;;13586:9;13580:4;13576:20;13571:3;13564:33;13612:100;13707:4;13698:6;13692:13;13612:100;;;13604:108;;13729:74;13796:6;13729:74;;;13826:4;13817:14;;;;;13719:84;-1:-1;13546:1;13539:9;13499:339;;13952:895;;14121:69;14184:5;14121:69;;;14203:95;14291:6;14286:3;14203:95;;;14196:102;;14321:3;14363:4;14355:6;14351:17;14346:3;14342:27;14389:71;14454:5;14389:71;;;14481:1;14466:342;14491:6;14488:1;14485:13;14466:342;;;14553:9;14547:4;14543:20;14538:3;14531:33;14579:102;14676:4;14667:6;14661:13;14579:102;;;14571:110;;14698:75;14766:6;14698:75;;;14796:4;14787:14;;;;;14688:85;-1:-1;14513:1;14506:9;14466:342;;14855:101;14922:28;14944:5;14922:28;;15081:120;15164:31;15189:5;15164:31;;15208:159;15309:52;15329:31;15354:5;15329:31;;;15309:52;;15374:356;;15502:38;15534:5;15502:38;;;15552:88;15633:6;15628:3;15552:88;;;15545:95;;15645:52;15690:6;15685:3;15678:4;15671:5;15667:16;15645:52;;;15709:16;;;;;15482:248;-1:-1;;15482:248;15737:315;;15833:34;15861:5;15833:34;;;15879:60;15932:6;15927:3;15879:60;;;15872:67;;15944:52;15989:6;15984:3;15977:4;15970:5;15966:16;15944:52;;;16017:29;16039:6;16017:29;;;16008:39;;;;15813:239;-1:-1;;;15813:239;16401:154;16498:51;16543:5;16498:51;;16748:364;;16908:67;16972:2;16967:3;16908:67;;;17008:66;16988:87;;17103:2;17094:12;;16894:218;-1:-1;;16894:218;17121:400;;17299:85;17381:2;17376:3;17299:85;;;17417:66;17397:87;;17512:2;17503:12;;17285:236;-1:-1;;17285:236;17530:364;;17690:67;17754:2;17749:3;17690:67;;;17790:66;17770:87;;17885:2;17876:12;;17676:218;-1:-1;;17676:218;17903:400;;18081:85;18163:2;18158:3;18081:85;;;18199:66;18179:87;;18294:2;18285:12;;18067:236;-1:-1;;18067:236;18312:465;;18472:67;18536:2;18531:3;18472:67;;;18572:66;18552:87;;18673:66;18668:2;18659:12;;18652:88;18768:2;18759:12;;18458:319;-1:-1;;18458:319;18786:364;;18946:67;19010:2;19005:3;18946:67;;;19046:66;19026:87;;19141:2;19132:12;;18932:218;-1:-1;;18932:218;19159:364;;19319:67;19383:2;19378:3;19319:67;;;19419:66;19399:87;;19514:2;19505:12;;19305:218;-1:-1;;19305:218;19532:364;;19692:67;19756:2;19751:3;19692:67;;;19792:66;19772:87;;19887:2;19878:12;;19678:218;-1:-1;;19678:218;19905:364;;20065:67;20129:2;20124:3;20065:67;;;20165:66;20145:87;;20260:2;20251:12;;20051:218;-1:-1;;20051:218;20278:465;;20438:67;20502:2;20497:3;20438:67;;;20538:66;20518:87;;20639:66;20634:2;20625:12;;20618:88;20734:2;20725:12;;20424:319;-1:-1;;20424:319;20752:364;;20912:67;20976:2;20971:3;20912:67;;;21012:66;20992:87;;21107:2;21098:12;;20898:218;-1:-1;;20898:218;21125:364;;21285:67;21349:2;21344:3;21285:67;;;21385:66;21365:87;;21480:2;21471:12;;21271:218;-1:-1;;21271:218;21498:363;;21658:66;21722:1;21717:3;21658:66;;;21757;21737:87;;21852:2;21843:12;;21644:217;-1:-1;;21644:217;21930:578;22139:22;;21930:578;;22063:4;22054:14;;;22167:77;22058:3;22139:22;22167:77;;;22083:167;22332:4;22325:5;22321:16;22315:23;22384:3;22378:4;22374:14;22367:4;22362:3;22358:14;22351:38;22404:66;22465:4;22452:11;22404:66;;22574:1613;22773:22;;22705:5;22808:37;;;22574:1613;;22696:15;;;;22860:136;22696:15;22773:22;22860:136;;;22852:144;;22726:282;23095:4;23088:5;23084:16;23078:23;23107:62;23163:4;23158:3;23154:14;23141:11;23107:62;;;23018:157;23267:4;23260:5;23256:16;23250:23;23279:62;23335:4;23330:3;23326:14;23313:11;23279:62;;;23185:162;23427:4;23420:5;23416:16;23410:23;23439:62;23495:4;23490:3;23486:14;23473:11;23439:62;;;23357:150;23593:4;23586:5;23582:16;23576:23;23605:62;23661:4;23656:3;23652:14;23639:11;23605:62;;;23517:156;23758:4;23751:5;23747:16;23741:23;23770:56;23820:4;23815:3;23811:14;23798:11;23770:56;;;23683:149;23915:4;23908:5;23904:16;23898:23;23927:78;23999:4;23994:3;23990:14;23977:11;23927:78;;;23842:169;24087:4;24080:5;24076:16;24070:23;24099:56;24149:4;24144:3;24140:14;24127:11;24099:56;;;-1:-1;24178:4;22678:1509;-1:-1;;;22678:1509;24255:1094;24460:22;;24255:1094;;24388:4;24379:14;;;24488:61;24383:3;24460:22;24488:61;;;24408:147;24639:4;24632:5;24628:16;24622:23;24651:62;24707:4;24702:3;24698:14;24685:11;24651:62;;;24565:154;24793:4;24786:5;24782:16;24776:23;24805:62;24861:4;24856:3;24852:14;24839:11;24805:62;;;24729:144;24955:4;24948:5;24944:16;24938:23;24967:56;25017:4;25012:3;25008:14;24995:11;24967:56;;;24883:146;25103:4;25096:5;25092:16;25086:23;25155:3;25149:4;25145:14;25138:4;25133:3;25129:14;25122:38;25175:136;25306:4;25293:11;25175:136;;25600:114;25679:29;25702:5;25679:29;;25721:262;;25865:93;25954:3;25945:6;25865:93;;25990:511;;26217:148;26361:3;26217:148;;;26210:155;;26376:75;26447:3;26438:6;26376:75;;;-1:-1;26473:2;26464:12;;26198:303;-1:-1;26198:303;26508:372;;26707:148;26851:3;26707:148;;26887:245;27021:2;27006:18;;27035:87;27010:9;27095:6;27035:87;;27139:611;27373:3;27358:19;;27388:71;27362:9;27432:6;27388:71;;;27470:88;27554:2;27543:9;27539:18;27530:6;27470:88;;;27569;27653:2;27642:9;27638:18;27629:6;27569:88;;;27668:72;27736:2;27725:9;27721:18;27712:6;27668:72;;27757:771;28015:3;28000:19;;28030:71;28004:9;28074:6;28030:71;;;28112:72;28180:2;28169:9;28165:18;28156:6;28112:72;;;28195;28263:2;28252:9;28248:18;28239:6;28195:72;;;28278;28346:2;28335:9;28331:18;28322:6;28278:72;;;28361:73;28429:3;28418:9;28414:19;28405:6;28361:73;;;28445;28513:3;28502:9;28498:19;28489:6;28445:73;;;27986:542;;;;;;;;;;28535:324;28681:2;28666:18;;28695:71;28670:9;28739:6;28695:71;;;28777:72;28845:2;28834:9;28830:18;28821:6;28777:72;;28866:1047;29238:3;29253:47;;;29223:19;;29314:140;29223:19;29440:6;29314:140;;;29306:148;;29465:88;29549:2;29538:9;29534:18;29525:6;29465:88;;;29564:72;29632:2;29621:9;29617:18;29608:6;29564:72;;;29647;29715:2;29704:9;29700:18;29691:6;29647:72;;;29730:73;29798:3;29787:9;29783:19;29774:6;29730:73;;;29814:89;29898:3;29887:9;29883:19;29874:6;29814:89;;29920:201;30032:2;30017:18;;30046:65;30021:9;30084:6;30046:65;;30128:539;30326:3;30311:19;;30341:71;30315:9;30385:6;30341:71;;;30423:68;30487:2;30476:9;30472:18;30463:6;30423:68;;;30502:72;30570:2;30559:9;30555:18;30546:6;30502:72;;30674:611;30884:3;30899:47;;;30869:19;;30960:72;30869:19;31018:6;30960:72;;;30952:80;;31043:72;31111:2;31100:9;31096:18;31087:6;31043:72;;;31126;31194:2;31183:9;31179:18;31170:6;31126:72;;;31209:66;31271:2;31260:9;31256:18;31247:6;31209:66;;31292:241;31424:2;31409:18;;31438:85;31413:9;31496:6;31438:85;;31812:407;32003:2;32017:47;;;31988:18;;32078:131;31988:18;32078:131;;32226:407;32417:2;32431:47;;;32402:18;;32492:131;32402:18;32492:131;;32640:407;32831:2;32845:47;;;32816:18;;32906:131;32816:18;32906:131;;33054:407;33245:2;33259:47;;;33230:18;;33320:131;33230:18;33320:131;;33468:407;33659:2;33673:47;;;33644:18;;33734:131;33644:18;33734:131;;33882:407;34073:2;34087:47;;;34058:18;;34148:131;34058:18;34148:131;;34296:407;34487:2;34501:47;;;34472:18;;34562:131;34472:18;34562:131;;34710:407;34901:2;34915:47;;;34886:18;;34976:131;34886:18;34976:131;;35124:407;35315:2;35329:47;;;35300:18;;35390:131;35300:18;35390:131;;35538:407;35729:2;35743:47;;;35714:18;;35804:131;35714:18;35804:131;;35952:407;36143:2;36157:47;;;36128:18;;36218:131;36128:18;36218:131;;36366:213;36484:2;36469:18;;36498:71;36473:9;36542:6;36498:71;;36586:256;36648:2;36642:9;36674:17;;;36749:18;36734:34;;36770:22;;;36731:62;36728:2;;;36806:1;36803;36796:12;36728:2;36822;36815:22;36626:216;;-1:-1;36626:216;36849:273;;37023:18;37015:6;37012:30;37009:2;;;37055:1;37052;37045:12;37009:2;-1:-1;37084:4;37072:17;;;37102:15;;36946:176;37688:254;;37827:18;37819:6;37816:30;37813:2;;;37859:1;37856;37849:12;37813:2;-1:-1;37932:4;37903;37880:17;;;;-1:-1;;37876:33;37922:15;;37750:192;37951:136;38075:4;38063:17;;38044:43;38389:122;38494:12;;38478:33;39405:187;39532:19;;;39581:4;39572:14;;39525:67;40334:144;40469:3;40447:31;-1:-1;40447:31;40812:105;;40881:31;40906:5;40881:31;;41044:92;41117:13;41110:21;;41093:43;41143:79;41212:5;41195:27;41229:128;-1:-1;;;;;41298:54;;41281:76;41450:88;41528:4;41517:16;;41500:38;42278:149;;42371:51;42416:5;42371:51;;42899:145;42980:6;42975:3;42970;42957:30;-1:-1;43036:1;43018:16;;43011:27;42950:94;43053:268;43118:1;43125:101;43139:6;43136:1;43133:13;43125:101;;;43206:11;;;43200:18;43187:11;;;43180:39;43161:2;43154:10;43125:101;;;43241:6;43238:1;43235:13;43232:2;;;-1:-1;;43306:1;43288:16;;43281:27;43102:219;43410:97;43498:2;43478:14;-1:-1;;43474:28;;43458:49

Swarm Source

bzzr://95d6985e82d5bc9264e0e5404d1cf09645ab81a9cefd5ede925f5f51e7747b4f

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading

OVERVIEW

The primary exchange address for Totle.

Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.

Validator Index Block Amount
View All Withdrawals

Txn Hash Block Value Eth2 PubKey Valid
View All Deposits
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.