Реклама вашего контракта Кабинет инвестора
Меню
Появились вопросы или есть предложения?
Напишите нам в Telegram t.me/smartradar
ETH777

ETH777

Etherscan
0xdDFc21DF6f2556528b21574695c7b33f22e60A70
Следить за контрактом

Баланс

85.8928 ETH.

Динамика пополнений
от общего пополнения за день

2.086%

Ввод

За последний час
0 ETH.
Всего
457.05 ETH.

Выводы

За последний час
0 ETH.
Всего
371.157 ETH.

Условия

В день
-
В час
-

Инвесторов

171

Повторные пополнения

За последний час
0 ETH.
Всего
256.927 ETH.

Средняя оценка аудиторов

-

Контакты

  • Таймлайн:
  • час
  • день
  • неделя
  • месяц
Пополнения (2284)
Выводы (1901)
Аудит
Код
API
Комменторы
Дата Блок TxHash От кого Кому Сумма
Вчера 14:27 7244376 0xf162c7ba41739469c63563b70e07f48c52f820a84aae1a48210792d30b6a602d
Транзакция с ошибкой
0x46e391f2fcf10d987293202b8a220ee8127c3ab2 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 14:04 7244305 0x33c39deaca9e3946d49bf378a32749bf4a7fef66b9e6bdfe949f129f925a658b
Транзакция с ошибкой
0xd7921adbd135d989cf99d0b24d67cb71f3fd86a6 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 13:00 7244122 0x43971a890344ae858dc3a9c8d3b990a6781a380b9b9a787720cbe1606138c581 0xfb7aca19ba5e01a410f6f864fb6b9e87ceb84548 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 12:17 7244000 0x8bb4a030e0536bdda9c850cbb9a6739ef26f7a37debed17614c943dc5c22e9b0 0xa27650e067c690474995ac4d1c7b0c454aeb16b7 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 06:54 7243077 0x9b657e70573f4ce14917af97283c05cff64945d6bd3136f6ff2e537e939d5a8c
Транзакция с ошибкой
0x8865aae7d89ad9e3695ddbefbddd8b482ab7435d 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 06:45 7243039 0xc40871e855b784db2cecf7d2fba7dbf170c2198e2d1d03b6631405ec7aba40c4 0x4701639792de046c61cfc43b44b9d3f349125cce 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.011 Ether
Вчера 06:32 7242998 0x9fda3ea6b0bbf6e8573a45c9bcd33b1031606b86111371e0996ef94ed53dd15a
Транзакция с ошибкой
0x60aef4e0bee8ac34f04c6a454122c68ccf65f4fa 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 05:43 7242871 0x8587a1ff1f22dda7dfa4186a78b9bec94661bcaa47b97a3e041a7c6efa56725d
Транзакция с ошибкой
0x4a9fa4a4b9b92723b24e14b5c6921afb2c413609 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 05:30 7242826 0xe51b51fcb9eea6237e3e742f43134559eca0e91bed44782a53927a751e4bfc8e 0x06152e06f4efe49303d716b1ce755739fece8392 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 03:33 7242468 0xf6ab26a459b5c8248ce95c85e97d916a9bd3d9a9f2318dec4e8d9d54fbfd986e 0xcbf097b2224fe9bef04ab4ed369f8e26cbadfe3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.03873 Ether
Вчера 03:08 7242389 0x479205e11f53e3e064084ac3f7edb4e4cbb7dfeea2cdb22817b2b152542837d3 0xcbf097b2224fe9bef04ab4ed369f8e26cbadfe3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 01:57 7242179 0xc6c784e798e620e08d0bb34df08759bdf75788e1774f3dcc0caa76d1750a0785 0x62eb3e90696d302f80c48d859943f0e244823436 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 00:43 7241954 0x1dd539bc5e1cdc035db0a1bc0a561f064201b30ce482469da54428134f8d7e9b
Транзакция с ошибкой
0x6d4ca75fedaa65048bbe49ee008dba255cfada3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 00:39 7241937 0x2cc282b947c0a3c21dcece28e59c44c62ce7ad2ea82c337fae7647b04cf1b6af 0x06da272a981b634dea1ab8c66c71c81c6aa1692a 0xddfc21df6f2556528b21574695c7b33f22e60a70 16.1 Ether
Вчера 00:03 7241838 0xbe91cf3c1b4b1023b4bc0eeccccc91cadd687f6c8613465dd5d181f0901926e9
Транзакция с ошибкой
0x60aef4e0bee8ac34f04c6a454122c68ccf65f4fa 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 23:20 7241700 0x9192856acc89980a61aa6c0457f7ed5bb7ebfdcb7d4d4b9f6e307086f1125ed3 0x4701639792de046c61cfc43b44b9d3f349125cce 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 23:14 7241678 0xc2132d2c7dc7c7e9ec0a26acdf4ef23a6304cf292455dbe164d4c260e684242f 0x6e37cf9ecec9d1e264e921308ec52cafe18ca49c 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 23:03 7241651 0xcce164e0c0d134c3e9e54980aef5954d4f8131e93513b71011ee9baec7e7c548 0x1478b6390fe3e89c95c17bc694502e466a87ccfc 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 21:18 7241352 0xa77dc8e26f6ac87bafc700f08359b837107d6e5454413f4448bd69e805eaf410
Транзакция с ошибкой
0xff172a72bbdcec54210516fbb8a21bfe109a9f75 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.019 Ether
19 фев. 20:45 7241263 0xfc4d5f76a219156f5e3526e0733d3828da5dd1a6c43ec103a67fe15cdfd7de06
Транзакция с ошибкой
0xff172a72bbdcec54210516fbb8a21bfe109a9f75 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.019 Ether
19 фев. 20:23 7241204 0xc0aad5561277a02004cbf47b000de8b7982da3be4fd3f4f01a7c248894043936 0xce6296356968306d01bd83d4cff11d317e86147a 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.21 Ether
19 фев. 19:53 7241114 0x292bd6073b3d48a73ae65026fcbd5104b6af5b71871d322e40e4b7d207ac0e12 0x39d54d627fdcba16aff90eb9fee264e923dc5b44 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 19:41 7241079 0x5571bd023bd9b22c452f7cf9d1a112e5d0d78393fbb579b13e619559a2b896ab 0xbe8c9c5c2946de72449500669a990cc75ed4c8b2 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 19:25 7241037 0x0abac6491e38e1e74124aad2b44fc3e4ac180da3e79af538f11576647a07d5e7
Транзакция с ошибкой
0xa55d0edebbfb43d150f2cb51fbdd572d32e6329a 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 18:46 7240920 0xddbb395fd24322ff53328358a09cc4ed17380d92052f4d9dff0dd27b42134a61 0x173054a462532d859237e9408dc4cbd8853ff7cf 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Дата Блок parentTxHash От кого Кому Сумма
Сегодня 17:54 7249229 0x30012e7812d8d4a0001a3236d7bf40d9d8748269e95a9389b4051389ae74c7d1 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x0a760acf7711dfee36fe7cdac433018b9750cef2 0.12987919560185185 Ether
Сегодня 15:58 7248897 0xa1618f16c75c9ea5879418f96041ec834af5361bb43f4cfe0118b6d235658a64 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xead697fcd7312b5cdff51be90f2c363d98cdc9b9 0.027400063157406472 Ether
Сегодня 09:10 7247708 0x15cb9923dde90ce1743e6facb05894da6f2807d570f6ebc8fe5a9e261bc95fdc
Транзакция с ошибкой
0xddfc21df6f2556528b21574695c7b33f22e60a70 0xcfece32a154c1eb0827dbddb9d42123fd5714e56 0.00095 Ether
Сегодня 09:10 7247708 0x15cb9923dde90ce1743e6facb05894da6f2807d570f6ebc8fe5a9e261bc95fdc
Транзакция с ошибкой
0xddfc21df6f2556528b21574695c7b33f22e60a70 0xd141612964af8078b468715ba3ef1e79a1ae060a 0.00055 Ether
Сегодня 08:35 7247577 0xc1583f14bfc541e46ef8ac3d7873c0b2b33389a9490f93f42d81fd9ed4bd5361 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x1478b6390fe3e89c95c17bc694502e466a87ccfc 0.002442708333333333 Ether
Сегодня 06:27 7247197 0x60c3a851f2bb55268fe4cfbe01cfdb043122013c84055f52324047f30fdcccba 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xfa87ee06d31cef5c369474e0e10004e79e973f8c 0.017263888888888888 Ether
Сегодня 05:31 7247033 0xa14e4876a4919bca600e08615559b657844153243a69f09d84e451e9c8bab3c5 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x06152e06f4efe49303d716b1ce755739fece8392 0.002552021608339893 Ether
Сегодня 03:46 7246728 0x619598b8ba9704e47bb1cd6f81d5a17f246c9e20a4650c1e95296985eb4ea8c1 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xcfece32a154c1eb0827dbddb9d42123fd5714e56 0.00386555 Ether
Сегодня 03:46 7246728 0x619598b8ba9704e47bb1cd6f81d5a17f246c9e20a4650c1e95296985eb4ea8c1 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xd141612964af8078b468715ba3ef1e79a1ae060a 0.00223795 Ether
Сегодня 03:38 7246700 0x5222cca7c343afd4fdb6d1550d8c81188bf404b6f24cb93f8a80d8e811219203 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xcbf097b2224fe9bef04ab4ed369f8e26cbadfe3f 0.04069801762750474 Ether
Сегодня 02:07 7246447 0x842ddfac1786a7e98f90379fa13f268887410aa7d93ac6ba7b72d9bcfd3230c5 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x06da272a981b634dea1ab8c66c71c81c6aa1692a 0.8922083333333334 Ether
Сегодня 01:46 7246391 0x16fbdb34eed50ea263b85d86194b3c23111827f143c04771a6573b7a27b596b1 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x3f9afd6a8289ba697fd07154db5cfa4aa4be1a76 1.4395776204427084 Ether
Вчера 21:19 7245566 0x60b949b8f886ec6be1b01886c7e02b6aba52ffd2a58a6e7405a3750f5cb146f6 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xcfece32a154c1eb0827dbddb9d42123fd5714e56 0.00095 Ether
Вчера 21:19 7245566 0x60b949b8f886ec6be1b01886c7e02b6aba52ffd2a58a6e7405a3750f5cb146f6 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xd141612964af8078b468715ba3ef1e79a1ae060a 0.00055 Ether
Вчера 20:34 7245431 0x5752069739d5c4542a8de51045168000cb7ceb8fd854995598a4e0c2ac067032 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xce6296356968306d01bd83d4cff11d317e86147a 0.01267631172839506 Ether
Вчера 19:20 7245225 0x9fa8da19052f9106ad1f134543ae026e379a0c724db01357963ac8edc85bb631 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x173054a462532d859237e9408dc4cbd8853ff7cf 0.002883486782644347 Ether
Вчера 18:29 7245064 0x41c856435f28ce956ecef266ca216f6c41486776c32457d306d91a5fdbe3c317 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x017cc341a57891bebab97c9f4941fea8410c3354 0.030849283854166666 Ether
Вчера 17:03 7244826 0x194eca686832367ecbd16720c8dc274175ac82e53453ae75d1a3c9819c670848 0xddfc21df6f2556528b21574695c7b33f22e60a70 0x0a760acf7711dfee36fe7cdac433018b9750cef2 0.24842664930555555 Ether
Вчера 16:41 7244770 0x3f4d14ad5dc51b18a120ab904f4baa61410bae6a6c5c76cd1e4a0212299793bc 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xde7d023a93f3edd76a385c449839953a3c7c5ac4 1.37078125 Ether
Вчера 16:41 7244770 0x7c8ce10ca129e984fa13b3fcd168d5a24229b493e8b547683c2a6b42cb600ef9 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xe3f1d08b17d524b377e698f3ad27d8af178bc4a2 3.398922222222222 Ether
Вчера 16:30 7244737 0xc834e8d65f732f342743967b7ab2a06e56d1fa3b033d73ea908e2e00ed6ec224 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xcfece32a154c1eb0827dbddb9d42123fd5714e56 0.00285 Ether
Вчера 16:30 7244737 0xc834e8d65f732f342743967b7ab2a06e56d1fa3b033d73ea908e2e00ed6ec224 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xd141612964af8078b468715ba3ef1e79a1ae060a 0.00165 Ether
Вчера 16:22 7244718 0x9b3b5bfebaa05146e55b7ba53678b6ac64cf7d69741631664136773441b6a139
Транзакция с ошибкой
0xddfc21df6f2556528b21574695c7b33f22e60a70 0xcfece32a154c1eb0827dbddb9d42123fd5714e56 0.00285 Ether
Вчера 16:22 7244718 0x9b3b5bfebaa05146e55b7ba53678b6ac64cf7d69741631664136773441b6a139
Транзакция с ошибкой
0xddfc21df6f2556528b21574695c7b33f22e60a70 0xd141612964af8078b468715ba3ef1e79a1ae060a 0.00165 Ether
Вчера 15:59 7244653 0x25e6b432b25b4b91001e6ccd22c41fb7af136afae5fc1047e8a021404bae3a9f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0xcfece32a154c1eb0827dbddb9d42123fd5714e56 0.057 Ether
Средняя оценка аудиторов -
Contract Source Code </>
pragma solidity 0.4.25;

/**
* Инновационный проект по распределению криптовалюты ETH с ежедневными выплатами до 12% в день!
* An innovative Blockchain Ethereum project with open source up to 12% per day! 
* ежедневные выплаты, навечно. инновационная надежность. до 12% в день, до 360% в месяц. 
* валюта вклада и выплаты — ETH, минимальный взнос — 0,01 ETH
* Daily payments forever. The innovative reliability. up to 12% per day, up to 360% per month. 
* Currency and payment — ETH. Minimal contribution 0.01 eth
* https://www.eth777.io/
*/ 


library Math {
  function min(uint a, uint b) internal pure returns(uint) {
    if (a > b) {
      return b;
    }
    return a;
  }
}


library Zero {
  function requireNotZero(address addr) internal pure {
    require(addr != address(0), "require not zero address");
  }

  function requireNotZero(uint val) internal pure {
    require(val != 0, "require not zero value");
  }

  function notZero(address addr) internal pure returns(bool) {
    return !(addr == address(0));
  }

  function isZero(address addr) internal pure returns(bool) {
    return addr == address(0);
  }

  function isZero(uint a) internal pure returns(bool) {
    return a == 0;
  }

  function notZero(uint a) internal pure returns(bool) {
    return a != 0;
  }
}


library Percent {
  struct percent {
    uint num;
    uint den;
  }
  
  function mul(percent storage p, uint a) internal view returns (uint) {
    if (a == 0) {
      return 0;
    }
    return a*p.num/p.den;
  }

  function div(percent storage p, uint a) internal view returns (uint) {
    return a/p.num*p.den;
  }

  function sub(percent storage p, uint a) internal view returns (uint) {
    uint b = mul(p, a);
    if (b >= a) {
      return 0;
    }
    return a - b;
  }

  function add(percent storage p, uint a) internal view returns (uint) {
    return a + mul(p, a);
  }

  function toMemory(percent storage p) internal view returns (Percent.percent memory) {
    return Percent.percent(p.num, p.den);
  }

  function mmul(percent memory p, uint a) internal pure returns (uint) {
    if (a == 0) {
      return 0;
    }
    return a*p.num/p.den;
  }

  function mdiv(percent memory p, uint a) internal pure returns (uint) {
    return a/p.num*p.den;
  }

  function msub(percent memory p, uint a) internal pure returns (uint) {
    uint b = mmul(p, a);
    if (b >= a) {
      return 0;
    }
    return a - b;
  }

  function madd(percent memory p, uint a) internal pure returns (uint) {
    return a + mmul(p, a);
  }
}


library Address {
  function toAddress(bytes source) internal pure returns(address addr) {
    assembly { addr := mload(add(source,0x14)) }
    return addr;
  }

  function isNotContract(address addr) internal view returns(bool) {
    uint length;
    assembly { length := extcodesize(addr) }
    return length == 0;
  }
}


/**
 * @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) {
    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;
  }
}


contract Accessibility {
  address private owner;
  modifier onlyOwner() {
    require(msg.sender == owner, "access denied");
    _;
  }

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

  function disown() internal {
    delete owner;
  }
}


contract Rev1Storage {
  function investorShortInfo(address addr) public view returns(uint value, uint refBonus); 
}


contract Rev2Storage {
  function investorInfo(address addr) public view returns(uint investment, uint paymentTime); 
}


library PrivateEntrance {
  using PrivateEntrance for privateEntrance;
  using Math for uint;
  struct privateEntrance {
    Rev1Storage rev1Storage;
    Rev2Storage rev2Storage;
    uint investorMaxInvestment;
    uint endTimestamp;
    mapping(address=>bool) hasAccess;
  }

  function isActive(privateEntrance storage pe) internal view returns(bool) {
    return pe.endTimestamp > now;
  }

  function maxInvestmentFor(privateEntrance storage pe, address investorAddr) internal view returns(uint) {
    if (!pe.hasAccess[investorAddr]) {
      return 0;
    }

    (uint maxInvestment, ) = pe.rev1Storage.investorShortInfo(investorAddr);
    if (maxInvestment == 0) {
      return 0;
    }
    maxInvestment = Math.min(maxInvestment, pe.investorMaxInvestment);

    (uint currInvestment, ) = pe.rev2Storage.investorInfo(investorAddr);
    
    if (currInvestment >= maxInvestment) {
      return 0;
    }

    return maxInvestment-currInvestment;
  }

  function provideAccessFor(privateEntrance storage pe, address[] addrs) internal {
    for (uint16 i; i < addrs.length; i++) {
      pe.hasAccess[addrs[i]] = true;
    }
  }
}


contract InvestorsStorage is Accessibility {
  struct Investor {
    uint investment;
    uint paymentTime;
  }
  uint public size;

  mapping (address => Investor) private investors;

  function isInvestor(address addr) public view returns (bool) {
    return investors[addr].investment > 0;
  }

  function investorInfo(address addr) public view returns(uint investment, uint paymentTime) {
    investment = investors[addr].investment;
    paymentTime = investors[addr].paymentTime;
  }

  function newInvestor(address addr, uint investment, uint paymentTime) public onlyOwner returns (bool) {
    Investor storage inv = investors[addr];
    if (inv.investment != 0 || investment == 0) {
      return false;
    }
    inv.investment = investment;
    inv.paymentTime = paymentTime;
    size++;
    return true;
  }

  function addInvestment(address addr, uint investment) public onlyOwner returns (bool) {
    if (investors[addr].investment == 0) {
      return false;
    }
    investors[addr].investment += investment;
    return true;
  }

  function setPaymentTime(address addr, uint paymentTime) public onlyOwner returns (bool) {
    if (investors[addr].investment == 0) {
      return false;
    }
    investors[addr].paymentTime = paymentTime;
    return true;
  }

  function disqalify(address addr) public onlyOwner returns (bool) {
    if (isInvestor(addr)) {
      investors[addr].investment = 0;
    }
  }
}


library RapidGrowthProtection {
  using RapidGrowthProtection for rapidGrowthProtection;
  
  struct rapidGrowthProtection {
    uint startTimestamp;
    uint maxDailyTotalInvestment;
    uint8 activityDays;
    mapping(uint8 => uint) dailyTotalInvestment;
  }

  function maxInvestmentAtNow(rapidGrowthProtection storage rgp) internal view returns(uint) {
    uint day = rgp.currDay();
    if (day == 0 || day > rgp.activityDays) {
      return 0;
    }
    if (rgp.dailyTotalInvestment[uint8(day)] >= rgp.maxDailyTotalInvestment) {
      return 0;
    }
    return rgp.maxDailyTotalInvestment - rgp.dailyTotalInvestment[uint8(day)];
  }

  function isActive(rapidGrowthProtection storage rgp) internal view returns(bool) {
    uint day = rgp.currDay();
    return day != 0 && day <= rgp.activityDays;
  }

  function saveInvestment(rapidGrowthProtection storage rgp, uint investment) internal returns(bool) {
    uint day = rgp.currDay();
    if (day == 0 || day > rgp.activityDays) {
      return false;
    }
    if (rgp.dailyTotalInvestment[uint8(day)] + investment > rgp.maxDailyTotalInvestment) {
      return false;
    }
    rgp.dailyTotalInvestment[uint8(day)] += investment;
    return true;
  }

  function startAt(rapidGrowthProtection storage rgp, uint timestamp) internal { 
    rgp.startTimestamp = timestamp;

    // restart
    for (uint8 i = 1; i <= rgp.activityDays; i++) {
      if (rgp.dailyTotalInvestment[i] != 0) {
        delete rgp.dailyTotalInvestment[i];
      }
    }
  }

  function currDay(rapidGrowthProtection storage rgp) internal view returns(uint day) {
    if (rgp.startTimestamp > now) {
      return 0;
    }
    day = (now - rgp.startTimestamp) / 24 hours + 1; 
  }
}

contract Revolution2 is Accessibility {
  using RapidGrowthProtection for RapidGrowthProtection.rapidGrowthProtection;
  using PrivateEntrance for PrivateEntrance.privateEntrance;
  using Percent for Percent.percent;
  using SafeMath for uint;
  using Math for uint;

  // easy read for investors
  using Address for *;
  using Zero for *; 
  
  RapidGrowthProtection.rapidGrowthProtection private m_rgp;
  PrivateEntrance.privateEntrance private m_privEnter;
  mapping(address => bool) private m_referrals;
  InvestorsStorage private m_investors;

  // automatically generates getters
  uint public constant minInvesment = 10 finney; 
  uint public constant maxBalance = 333e5 ether; 
  address public advertisingAddress;
  address public adminsAddress;
  uint public investmentsNumber;
  uint public waveStartup;

  // percents 
  Percent.percent private m_5_percent = Percent.percent(5,100);            // 5/100 *100% = 5%
  Percent.percent private m_6_percent = Percent.percent(6,100);            // 6/100 *100% = 6%
  Percent.percent private m_7_percent = Percent.percent(7,100);            // 7/100 *100% = 7%
  Percent.percent private m_8_percent = Percent.percent(8,100);            // 8/100 *100% = 8%
  Percent.percent private m_9_percent = Percent.percent(9,100);            // 9/100 *100% = 9%
  Percent.percent private m_10_percent = Percent.percent(10,100);          // 10/100 *100% = 10%
  Percent.percent private m_11_percent = Percent.percent(11,100);            // 11/100 *100% = 11%
  Percent.percent private m_12_percent = Percent.percent(12,100);            // 12/100 *100% = 12%
  Percent.percent private m_referal_percent = Percent.percent(5,100);        // 5/100 *100% = 5%
  Percent.percent private m_referrer_percent = Percent.percent(7,100);       // 7/100 *100% = 7%
  Percent.percent private m_referrer_percentMax = Percent.percent(10,100);   // 10/100 *100% = 10%
  Percent.percent private m_adminsPercent = Percent.percent(55, 1000);       //   55/100  *100% = 5.5%
  Percent.percent private m_advertisingPercent = Percent.percent(95, 1000);// 95/1000  *100% = 9.5%

  // more events for easy read from blockchain
  event LogPEInit(uint when, address rev1Storage, address rev2Storage, uint investorMaxInvestment, uint endTimestamp);
  event LogSendExcessOfEther(address indexed addr, uint when, uint value, uint investment, uint excess);
  event LogNewReferral(address indexed addr, address indexed referrerAddr, uint when, uint refBonus);
  event LogRGPInit(uint when, uint startTimestamp, uint maxDailyTotalInvestment, uint activityDays);
  event LogRGPInvestment(address indexed addr, uint when, uint investment, uint indexed day);
  event LogNewInvesment(address indexed addr, uint when, uint investment, uint value);
  event LogAutomaticReinvest(address indexed addr, uint when, uint investment);
  event LogPayDividends(address indexed addr, uint when, uint dividends);
  event LogNewInvestor(address indexed addr, uint when);
  event LogBalanceChanged(uint when, uint balance);
  event LogNextWave(uint when);
  event LogDisown(uint when);


  modifier balanceChanged {
    _;
    emit LogBalanceChanged(now, address(this).balance);
  }

  modifier notFromContract() {
    require(msg.sender.isNotContract(), "only externally accounts");
    _;
  }

  constructor() public {
    adminsAddress = msg.sender;
    advertisingAddress = msg.sender;
    nextWave();
  }

  function() public payable {
    // investor get him dividends
    if (msg.value.isZero()) {
      getMyDividends();
      return;
    }

    // sender do invest
    doInvest(msg.data.toAddress());
  }

  function disqualifyAddress(address addr) public onlyOwner {
    m_investors.disqalify(addr);
  }

  function doDisown() public onlyOwner {
    disown();
    emit LogDisown(now);
  }

  function init(address rev1StorageAddr, uint timestamp) public onlyOwner {
    // init Rapid Growth Protection
    m_rgp.startTimestamp = timestamp + 1;
    m_rgp.maxDailyTotalInvestment = 500 ether;
    m_rgp.activityDays = 21;
    emit LogRGPInit(
      now, 
      m_rgp.startTimestamp,
      m_rgp.maxDailyTotalInvestment,
      m_rgp.activityDays
    );


    // init Private Entrance
    m_privEnter.rev1Storage = Rev1Storage(rev1StorageAddr);
    m_privEnter.rev2Storage = Rev2Storage(address(m_investors));
    m_privEnter.investorMaxInvestment = 50 ether;
    m_privEnter.endTimestamp = timestamp;
    emit LogPEInit(
      now, 
      address(m_privEnter.rev1Storage), 
      address(m_privEnter.rev2Storage), 
      m_privEnter.investorMaxInvestment, 
      m_privEnter.endTimestamp
    );
  }

  function setAdvertisingAddress(address addr) public onlyOwner {
    addr.requireNotZero();
    advertisingAddress = addr;
  }

  function setAdminsAddress(address addr) public onlyOwner {
    addr.requireNotZero();
    adminsAddress = addr;
  }

  function privateEntranceProvideAccessFor(address[] addrs) public onlyOwner {
    m_privEnter.provideAccessFor(addrs);
  }

  function rapidGrowthProtectionmMaxInvestmentAtNow() public view returns(uint investment) {
    investment = m_rgp.maxInvestmentAtNow();
  }

  function investorsNumber() public view returns(uint) {
    return m_investors.size();
  }

  function balanceETH() public view returns(uint) {
    return address(this).balance;
  }

  function advertisingPercent() public view returns(uint numerator, uint denominator) {
    (numerator, denominator) = (m_advertisingPercent.num, m_advertisingPercent.den);
  }

  function adminsPercent() public view returns(uint numerator, uint denominator) {
    (numerator, denominator) = (m_adminsPercent.num, m_adminsPercent.den);
  }

  function investorInfo(address investorAddr) public view returns(uint investment, uint paymentTime, bool isReferral) {
    (investment, paymentTime) = m_investors.investorInfo(investorAddr);
    isReferral = m_referrals[investorAddr];
  }

  function investorDividendsAtNow(address investorAddr) public view returns(uint dividends) {
    dividends = calcDividends(investorAddr);
  }

  function dailyPercentAtNow() public view returns(uint numerator, uint denominator) {
    Percent.percent memory p = dailyPercent();
    (numerator, denominator) = (p.num, p.den);
  }

  function getMyDividends() public notFromContract balanceChanged {
    // calculate dividends
    
    //check if 1 day passed after last payment
    require(now.sub(getMemInvestor(msg.sender).paymentTime) > 24 hours);

    uint dividends = calcDividends(msg.sender);
    require (dividends.notZero(), "cannot to pay zero dividends");

    // update investor payment timestamp
    assert(m_investors.setPaymentTime(msg.sender, now));

    // check enough eth - goto next wave if needed
    if (address(this).balance <= dividends) {
      nextWave();
      dividends = address(this).balance;
    } 

    // transfer dividends to investor
    msg.sender.transfer(dividends);
    emit LogPayDividends(msg.sender, now, dividends);
  }

  function doInvest(address referrerAddr) public payable notFromContract balanceChanged {
    uint investment = msg.value;
    uint receivedEther = msg.value;
    require(investment >= minInvesment, "investment must be >= minInvesment");
    require(address(this).balance <= maxBalance, "the contract eth balance limit");

    if (m_rgp.isActive()) { 
      // use Rapid Growth Protection if needed
      uint rpgMaxInvest = m_rgp.maxInvestmentAtNow();
      rpgMaxInvest.requireNotZero();
      investment = Math.min(investment, rpgMaxInvest);
      assert(m_rgp.saveInvestment(investment));
      emit LogRGPInvestment(msg.sender, now, investment, m_rgp.currDay());
      
    } else if (m_privEnter.isActive()) {
      // use Private Entrance if needed
      uint peMaxInvest = m_privEnter.maxInvestmentFor(msg.sender);
      peMaxInvest.requireNotZero();
      investment = Math.min(investment, peMaxInvest);
    }

    // send excess of ether if needed
    if (receivedEther > investment) {
      uint excess = receivedEther - investment;
      msg.sender.transfer(excess);
      receivedEther = investment;
      emit LogSendExcessOfEther(msg.sender, now, msg.value, investment, excess);
    }

    // commission
    advertisingAddress.send(m_advertisingPercent.mul(receivedEther));
    adminsAddress.send(m_adminsPercent.mul(receivedEther));

    bool senderIsInvestor = m_investors.isInvestor(msg.sender);

    // ref system works only once and only on first invest
    if (referrerAddr.notZero() && !senderIsInvestor && !m_referrals[msg.sender] &&
      referrerAddr != msg.sender && m_investors.isInvestor(referrerAddr)) {
      
      m_referrals[msg.sender] = true;
      // add referral bonus to investor`s and referral`s investments
      uint referrerBonus = m_referrer_percent.mmul(investment);
      if (investment > 10 ether) {
        referrerBonus = m_referrer_percentMax.mmul(investment);
      }
      
      uint referalBonus = m_referal_percent.mmul(investment);
      assert(m_investors.addInvestment(referrerAddr, referrerBonus)); // add referrer bonus
      investment += referalBonus;                                    // add referral bonus
      emit LogNewReferral(msg.sender, referrerAddr, now, referalBonus);
    }

    // automatic reinvest - prevent burning dividends
    uint dividends = calcDividends(msg.sender);
    if (senderIsInvestor && dividends.notZero()) {
      investment += dividends;
      emit LogAutomaticReinvest(msg.sender, now, dividends);
    }

    if (senderIsInvestor) {
      // update existing investor
      assert(m_investors.addInvestment(msg.sender, investment));
      assert(m_investors.setPaymentTime(msg.sender, now));
    } else {
      // create new investor
      assert(m_investors.newInvestor(msg.sender, investment, now));
      emit LogNewInvestor(msg.sender, now);
    }

    investmentsNumber++;
    emit LogNewInvesment(msg.sender, now, investment, receivedEther);
  }

  function getMemInvestor(address investorAddr) internal view returns(InvestorsStorage.Investor memory) {
    (uint investment, uint paymentTime) = m_investors.investorInfo(investorAddr);
    return InvestorsStorage.Investor(investment, paymentTime);
  }

  function calcDividends(address investorAddr) internal view returns(uint dividends) {
    InvestorsStorage.Investor memory investor = getMemInvestor(investorAddr);

    // safe gas if dividends will be 0
    if (investor.investment.isZero() || now.sub(investor.paymentTime) < 10 minutes) {
      return 0;
    }
    
    // for prevent burning daily dividends if 24h did not pass - calculate it per 10 min interval
    Percent.percent memory p = dailyPercent();
    dividends = (now.sub(investor.paymentTime) / 10 minutes) * p.mmul(investor.investment) / 144;
  }

  function dailyPercent() internal view returns(Percent.percent memory p) {
    uint balance = address(this).balance;

    if (balance < 500 ether) { 
      p = m_5_percent.toMemory(); 
    } else if ( 500 ether <= balance && balance <= 1500 ether) {
      p = m_6_percent.toMemory();    
    } else if ( 1500 ether <= balance && balance <= 5000 ether) {
      p = m_7_percent.toMemory();   
    } else if ( 5000 ether <= balance && balance <= 10000 ether) {
      p = m_8_percent.toMemory();  
    } else if ( 10000 ether <= balance && balance <= 20000 ether) {
      p = m_9_percent.toMemory();    
    } else if ( 20000 ether <= balance && balance <= 30000 ether) {
      p = m_10_percent.toMemory();  
    } else if ( 30000 ether <= balance && balance <= 50000 ether) {
      p = m_11_percent.toMemory();   
    } else {
      p = m_12_percent.toMemory();    
    } 
  }

  function nextWave() private {
    m_investors = new InvestorsStorage();
    investmentsNumber = 0;
    waveStartup = now;
    m_rgp.startAt(now);
    emit LogRGPInit(now , m_rgp.startTimestamp, m_rgp.maxDailyTotalInvestment, m_rgp.activityDays);
    emit LogNextWave(now);
  }
}
Документация
Идейные соображения высшего порядка, а также дальнейшее развитие различных форм деятельности представляет собой интересный эксперимент проверки модели развития. Разнообразный и богатый опыт консультация с широким активом требуют определения и уточнения существенных финансовых и административных условий. Задача организации, в особенности же новая модель организационной деятельности требуют от нас анализа системы обучения кадров, соответствует насущным потребностям. Повседневная практика показывает, что дальнейшее развитие различных форм деятельности обеспечивает широкому кругу (специалистов) участие в формировании новых предложений. Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности влечет за собой процесс внедрения и модернизации новых предложений.

Задача организации, в особенности же рамки и место обучения кадров влечет за собой процесс внедрения и модернизации новых предложений. Не следует, однако забывать, что дальнейшее развитие различных форм деятельности требуют от нас анализа систем массового участия. Значимость этих проблем настолько очевидна, что новая модель организационной деятельности влечет за собой процесс внедрения и модернизации модели развития. Повседневная практика показывает, что постоянное информационно-пропагандистское обеспечение нашей деятельности в значительной степени обуславливает создание существенных финансовых и административных условий.

Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности требуют определения и уточнения соответствующий условий активизации. Разнообразный и богатый опыт консультация с широким активом позволяет выполнять важные задания по разработке существенных финансовых и административных условий. С другой стороны консультация с широким активом позволяет оценить значение системы обучения кадров, соответствует насущным потребностям. Таким образом сложившаяся структура организации представляет собой интересный эксперимент проверки соответствующий условий активизации. Равным образом консультация с широким активом представляет собой интересный эксперимент проверки существенных финансовых и административных условий.

Товарищи! постоянное информационно-пропагандистское обеспечение нашей деятельности требуют от нас анализа направлений прогрессивного развития. С другой стороны начало повседневной работы по формированию позиции позволяет оценить значение новых предложений.

Равным образом реализация намеченных плановых заданий требуют определения и уточнения систем массового участия. Разнообразный и богатый опыт постоянное информационно-пропагандистское обеспечение нашей деятельности требуют от нас анализа направлений прогрессивного развития. Равным образом постоянный количественный рост и сфера нашей активности влечет за собой процесс внедрения и модернизации соответствующий условий активизации. Повседневная практика показывает, что дальнейшее развитие различных форм деятельности влечет за собой процесс внедрения и модернизации модели развития.

Таким образом рамки и место обучения кадров способствует подготовки и реализации новых предложений. Равным образом укрепление и развитие структуры в значительной степени обуславливает создание существенных финансовых и административных условий. Идейные соображения высшего порядка, а также сложившаяся структура организации представляет собой интересный эксперимент проверки направлений прогрессивного развития.

Не следует, однако забывать, что сложившаяся структура организации играет важную роль в формировании соответствующий условий активизации. С другой стороны дальнейшее развитие различных форм деятельности требуют определения и уточнения направлений прогрессивного развития.

Повседневная практика показывает, что начало повседневной работы по формированию позиции представляет собой интересный эксперимент проверки систем массового участия. Идейные соображения высшего порядка, а также постоянный количественный рост и сфера нашей активности в значительной степени обуславливает создание систем массового участия.

Таким образом укрепление и развитие структуры представляет собой интересный эксперимент проверки существенных финансовых и административных условий. Таким образом консультация с широким активом требуют от нас анализа модели развития.

Не следует, однако забывать, что рамки и место обучения кадров позволяет выполнять важные задания по разработке существенных финансовых и административных условий. С другой стороны постоянное информационно-пропагандистское обеспечение нашей деятельности позволяет выполнять важные задания по разработке соответствующий условий активизации. Товарищи! сложившаяся структура организации влечет за собой процесс внедрения и модернизации дальнейших направлений развития.
Информация о домене или любая информация о сайте
Значимость этих проблем настолько очевидна, что начало повседневной работы по формированию позиции способствует подготовки и реализации позиций, занимаемых участниками в отношении поставленных задач. Товарищи! новая модель организационной деятельности позволяет оценить значение направлений прогрессивного развития. Равным образом дальнейшее развитие различных форм деятельности влечет за собой процесс внедрения и модернизации направлений прогрессивного развития. Равным образом реализация намеченных плановых заданий позволяет выполнять важные задания по разработке новых предложений. Задача организации, в особенности же консультация с широким активом требуют от нас анализа существенных финансовых и административных условий. Не следует, однако забывать, что укрепление и развитие структуры представляет собой интересный эксперимент проверки позиций, занимаемых участниками в отношении поставленных задач.

Разнообразный и богатый опыт начало повседневной работы по формированию позиции требуют от нас анализа соответствующий условий активизации. Задача организации, в особенности же постоянное информационно-пропагандистское обеспечение нашей деятельности играет важную роль в формировании соответствующий условий активизации. Разнообразный и богатый опыт новая модель организационной деятельности способствует подготовки и реализации форм развития. Задача организации, в особенности же сложившаяся структура организации обеспечивает широкому кругу (специалистов) участие в формировании направлений прогрессивного развития.

Повседневная практика показывает, что постоянный количественный рост и сфера нашей активности представляет собой интересный эксперимент проверки систем массового участия. Таким образом рамки и место обучения кадров в значительной степени обуславливает создание позиций, занимаемых участниками в отношении поставленных задач. Товарищи! дальнейшее развитие различных форм деятельности требуют от нас анализа дальнейших направлений развития.

Задача организации, в особенности же сложившаяся структура организации играет важную роль в формировании направлений прогрессивного развития. Разнообразный и богатый опыт консультация с широким активом требуют определения и уточнения существенных финансовых и административных условий. Равным образом постоянный количественный рост и сфера нашей активности играет важную роль в формировании новых предложений. С другой стороны постоянный количественный рост и сфера нашей активности представляет собой интересный эксперимент проверки направлений прогрессивного развития. Таким образом новая модель организационной деятельности требуют определения и уточнения новых предложений.

Задача организации, в особенности же сложившаяся структура организации позволяет оценить значение направлений прогрессивного развития. Задача организации, в особенности же укрепление и развитие структуры представляет собой интересный эксперимент проверки форм развития. Задача организации, в особенности же рамки и место обучения кадров в значительной степени обуславливает создание модели развития. Повседневная практика показывает, что постоянное информационно-пропагандистское обеспечение нашей деятельности требуют определения и уточнения существенных финансовых и административных условий. Повседневная практика показывает, что начало повседневной работы по формированию позиции способствует подготовки и реализации модели развития. Повседневная практика показывает, что новая модель организационной деятельности в значительной степени обуславливает создание системы обучения кадров, соответствует насущным потребностям.

Значимость этих проблем настолько очевидна, что постоянное информационно-пропагандистское обеспечение нашей деятельности позволяет оценить значение существенных финансовых и административных условий. Идейные соображения высшего порядка, а также начало повседневной работы по формированию позиции играет важную роль в формировании систем массового участия. Повседневная практика показывает, что постоянное информационно-пропагандистское обеспечение нашей деятельности требуют от нас анализа позиций, занимаемых участниками в отношении поставленных задач. Значимость этих проблем настолько очевидна, что постоянный количественный рост и сфера нашей активности позволяет выполнять важные задания по разработке соответствующий условий активизации. Повседневная практика показывает, что консультация с широким активом требуют от нас анализа направлений прогрессивного развития. Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности позволяет выполнять важные задания по разработке дальнейших направлений развития.

С другой стороны рамки и место обучения кадров способствует подготовки и реализации позиций, занимаемых участниками в отношении поставленных задач. Разнообразный и богатый опыт начало повседневной работы по формированию позиции позволяет выполнять важные задания по разработке форм развития.

Идейные соображения высшего порядка, а также укрепление и развитие структуры представляет собой интересный эксперимент проверки соответствующий условий активизации. Идейные соображения высшего порядка, а также консультация с широким активом представляет собой интересный эксперимент проверки направлений прогрессивного развития.

Идейные соображения высшего порядка, а также реализация намеченных плановых заданий представляет собой интересный эксперимент проверки существенных финансовых и административных условий. Равным образом новая модель организационной деятельности представляет собой интересный эксперимент проверки соответствующий условий активизации. Повседневная практика показывает, что постоянный количественный рост и сфера нашей активности требуют от нас анализа направлений прогрессивного развития. Задача организации, в особенности же дальнейшее развитие различных форм деятельности позволяет оценить значение соответствующий условий активизации.

Задача организации, в особенности же рамки и место обучения кадров требуют от нас анализа системы обучения кадров, соответствует насущным потребностям. Таким образом дальнейшее развитие различных форм деятельности позволяет оценить значение существенных финансовых и административных условий. Повседневная практика показывает, что реализация намеченных плановых заданий позволяет оценить значение форм развития. Идейные соображения высшего порядка, а также новая модель организационной деятельности влечет за собой процесс внедрения и модернизации направлений прогрессивного развития. Равным образом консультация с широким активом в значительной степени обуславливает создание дальнейших направлений развития. Товарищи! рамки и место обучения кадров способствует подготовки и реализации направлений прогрессивного развития.

Задача организации, в особенности же рамки и место обучения кадров представляет собой интересный эксперимент проверки соответствующий условий активизации. Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности способствует подготовки и реализации систем массового участия. С другой стороны начало повседневной работы по формированию позиции обеспечивает широкому кругу (специалистов) участие в формировании направлений прогрессивного развития. Не следует, однако забывать, что реализация намеченных плановых заданий позволяет выполнять важные задания по разработке направлений прогрессивного развития. Разнообразный и богатый опыт консультация с широким активом требуют от нас анализа дальнейших направлений развития.

Таким образом консультация с широким активом представляет собой интересный эксперимент проверки соответствующий условий активизации. Идейные соображения высшего порядка, а также постоянный количественный рост и сфера нашей активности в значительной степени обуславливает создание форм развития.

Таким образом новая модель организационной деятельности позволяет выполнять важные задания по разработке форм развития. Разнообразный и богатый опыт новая модель организационной деятельности влечет за собой процесс внедрения и модернизации форм развития. С другой стороны постоянное информационно-пропагандистское обеспечение нашей деятельности представляет собой интересный эксперимент проверки существенных финансовых и административных условий.

Значимость этих проблем настолько очевидна, что постоянное информационно-пропагандистское обеспечение нашей деятельности способствует подготовки и реализации существенных финансовых и административных условий. Не следует, однако забывать, что постоянное информационно-пропагандистское обеспечение нашей деятельности способствует подготовки и реализации направлений прогрессивного развития. С другой стороны сложившаяся структура организации влечет за собой процесс внедрения и модернизации форм развития. Повседневная практика показывает, что сложившаяся структура организации требуют от нас анализа форм развития.

Товарищи! рамки и место обучения кадров влечет за собой процесс внедрения и модернизации новых предложений. Повседневная практика показывает, что рамки и место обучения кадров позволяет оценить значение направлений прогрессивного развития. Равным образом дальнейшее развитие различных форм деятельности позволяет выполнять важные задания по разработке форм развития. Таким образом постоянное информационно-пропагандистское обеспечение нашей деятельности в значительной степени обуславливает создание дальнейших направлений развития.