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

ETH777

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

Баланс

85.8928 ETH.

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

2.222%

Ввод

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

Выводы

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

Условия

В день
-
В час
-

Инвесторов

171

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

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

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

-

Контакты

  • Таймлайн:
  • час
  • день
  • неделя
  • месяц
Пополнения (2284)
Выводы (1901)
Аудит
Код
API
Комменторы
Дата Блок TxHash От кого Кому Сумма
Сегодня 00:32 7246148 0xa02ecfeb6b913fb55836e43902d4f590e29d3b5a90b7b6c1c879323436010b29
Транзакция с ошибкой
0x69bd7f72b98aeecf78ac87823e9ad45ffa85b0c1 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Сегодня 00:08 7246070 0x1ec69f427ff0647848dbd62bc0d67b988ac95bf093b0d7ce445ecf3d6245b5e3
Транзакция с ошибкой
0x6d4ca75fedaa65048bbe49ee008dba255cfada3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 21:53 7245672 0x38b8c5d9a73dd47a2609fe7e5fad7f2b65cf8a4f77a738749e753e8a7607c4e9
Транзакция с ошибкой
0xe7777c01294b8afd56e5bc11fcbd24792657f20e 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 21:19 7245566 0x60b949b8f886ec6be1b01886c7e02b6aba52ffd2a58a6e7405a3750f5cb146f6 0x72fa7aadbea88ab8eaa31ae8b5d9d38633d2e840 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.01 Ether
Вчера 20:34 7245431 0x5752069739d5c4542a8de51045168000cb7ceb8fd854995598a4e0c2ac067032 0xce6296356968306d01bd83d4cff11d317e86147a 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 20:18 7245390 0xeda945672c0ebdab8dc7cbb1971e38d1182cd6e95ab7ca459a2d0d20a6a39214
Транзакция с ошибкой
0xce6296356968306d01bd83d4cff11d317e86147a 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 20:18 7245389 0x3ef8503f6d793a627f7e045afc268f84cf138413ef63d3a2cb63539bc20ab81c
Транзакция с ошибкой
0x61bab21db2fd77cb880c23cf2b6e16df33141337 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 20:17 7245386 0xf5caf97af2de6489920d72e621f81cf89df66a8951c284df8dfe26916d488a77
Транзакция с ошибкой
0xce6296356968306d01bd83d4cff11d317e86147a 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 20:00 7245349 0x7f32797efb7711b20463487daadbd19c04dfd90381744f7b853ba49a276a3969
Транзакция с ошибкой
0x5e86bb7f1f75bab03e01592afc87c4c97f69071b 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 19:56 7245340 0xb5c02cde11fba63496e79b984907594d10a71ea1b351a14a51a6e7337b2064db
Транзакция с ошибкой
0x5e86bb7f1f75bab03e01592afc87c4c97f69071b 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 19:45 7245296 0xa4a661032b50bd6f6a3d9e33625a7a6cf50f84201731698de342c22027c74537
Транзакция с ошибкой
0x5e86bb7f1f75bab03e01592afc87c4c97f69071b 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 19:20 7245225 0x9fa8da19052f9106ad1f134543ae026e379a0c724db01357963ac8edc85bb631 0x173054a462532d859237e9408dc4cbd8853ff7cf 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 18:29 7245064 0x41c856435f28ce956ecef266ca216f6c41486776c32457d306d91a5fdbe3c317 0x017cc341a57891bebab97c9f4941fea8410c3354 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 17:26 7244887 0x6086c8e94dce17f76767efb2c25e3a85b7d29a32b6700250d43e7b360051e699
Транзакция с ошибкой
0x06152e06f4efe49303d716b1ce755739fece8392 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 17:03 7244826 0x194eca686832367ecbd16720c8dc274175ac82e53453ae75d1a3c9819c670848 0x0a760acf7711dfee36fe7cdac433018b9750cef2 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 16:41 7244770 0x3f4d14ad5dc51b18a120ab904f4baa61410bae6a6c5c76cd1e4a0212299793bc 0xde7d023a93f3edd76a385c449839953a3c7c5ac4 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 16:41 7244770 0x7c8ce10ca129e984fa13b3fcd168d5a24229b493e8b547683c2a6b42cb600ef9 0xe3f1d08b17d524b377e698f3ad27d8af178bc4a2 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 16:30 7244737 0xc834e8d65f732f342743967b7ab2a06e56d1fa3b033d73ea908e2e00ed6ec224 0xfb7aca19ba5e01a410f6f864fb6b9e87ceb84548 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.03 Ether
Вчера 16:22 7244718 0x9b3b5bfebaa05146e55b7ba53678b6ac64cf7d69741631664136773441b6a139
Транзакция с ошибкой
0xfb7aca19ba5e01a410f6f864fb6b9e87ceb84548 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.03 Ether
Вчера 16:01 7244656 0xc180fea6692a3118cc8a0367d5973c2d4427dadce68149a47e9022bc52e45040
Транзакция с ошибкой
0x6d4ca75fedaa65048bbe49ee008dba255cfada3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 15:59 7244653 0x25e6b432b25b4b91001e6ccd22c41fb7af136afae5fc1047e8a021404bae3a9f 0xfb7aca19ba5e01a410f6f864fb6b9e87ceb84548 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.6 Ether
Вчера 15:06 7244497 0xfbf344848b9e7cea28b70d266b6c80c7d9822d94af937af1cea48f60b25d75b2
Транзакция с ошибкой
0xfd4c3ad9dc254f0b92bd6f9795961db8257ce15d 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 15:06 7244497 0xc03c7f5aa2b55622ad353270d40759ef51638b9095246358920234c1bca0b272
Транзакция с ошибкой
0x6d4ca75fedaa65048bbe49ee008dba255cfada3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
Вчера 14:34 7244392 0x464731d00cdf06bb3c7990c6b4401b174b9fa947c607ddb438d0a2a8dea59a68 0x39d54d627fdcba16aff90eb9fee264e923dc5b44 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.24 Ether
Вчера 14:30 7244383 0xd1a1597b78442a78deadc06633f440d961f9814399a56462161d3214284529eb
Транзакция с ошибкой
0x46e391f2fcf10d987293202b8a220ee8127c3ab2 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);
  }
}
Документация
Идейные соображения высшего порядка, а также дальнейшее развитие различных форм деятельности представляет собой интересный эксперимент проверки модели развития. Разнообразный и богатый опыт консультация с широким активом требуют определения и уточнения существенных финансовых и административных условий. Задача организации, в особенности же новая модель организационной деятельности требуют от нас анализа системы обучения кадров, соответствует насущным потребностям. Повседневная практика показывает, что дальнейшее развитие различных форм деятельности обеспечивает широкому кругу (специалистов) участие в формировании новых предложений. Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности влечет за собой процесс внедрения и модернизации новых предложений.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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