Реклама вашего контракта Кабинет инвестора
Меню
Появились вопросы или есть предложения?
Напишите нам в 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 От кого Кому Сумма
19 фев. 04:49 7238377 0xb758e76f4dcd9797fff3ef9ca39f66b2cfedaf3f7f0aa894f7afa57c9357c24c 0x06152e06f4efe49303d716b1ce755739fece8392 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 04:44 7238359 0x036a326d72d1d6f1f35d4de89d6391e7c222a2b51969238abfb8c08a547fea3e
Транзакция с ошибкой
0x4a9fa4a4b9b92723b24e14b5c6921afb2c413609 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 04:17 7238288 0xd7954b602240658a7db960c118c61d6cd22ef6325bcad4911360515452f05a0c
Транзакция с ошибкой
0x06152e06f4efe49303d716b1ce755739fece8392 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 03:36 7238179 0xb8999e2ff359f727f6148f6a1384f5d705fc9684bd17c9ed3c7fe428c8ee483e
Транзакция с ошибкой
0x06152e06f4efe49303d716b1ce755739fece8392 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 03:29 7238155 0xf7870a2b9bceff5769e3fed53df164d597b2689ac59709ca3da59b3be4b9c21a
Транзакция с ошибкой
0x06152e06f4efe49303d716b1ce755739fece8392 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 03:06 7238087 0xc470122ec8b96903b9f99d02b0a52d271b8430646b15a37d887bf6ab562a5106 0xcbf097b2224fe9bef04ab4ed369f8e26cbadfe3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.03687 Ether
19 фев. 02:49 7238044 0xaf94311326a34f159da2b45bbab735394977fd5d9a4b9c847523596e56fdf499 0xcbf097b2224fe9bef04ab4ed369f8e26cbadfe3f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 00:32 7237651 0x43dd536d754f5198cac9bd3c78113d2a58e67c841e84f288eddad2815106e4c8
Транзакция с ошибкой
0xfd4c3ad9dc254f0b92bd6f9795961db8257ce15d 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
19 фев. 00:15 7237596 0xa34afae1ad7e952250b44f0568d2a4a24cce09e27fbe4361db40015e28b925f7
Транзакция с ошибкой
0x542bc99656a8473227adb42562c514c460790a01 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 23:42 7237499 0xba5c6fdc8b78cd26b69a89fd891037c99f76fdfb09c5cbc6194190c7cc001c42
Транзакция с ошибкой
0xe7777c01294b8afd56e5bc11fcbd24792657f20e 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 23:40 7237484 0xff492afa215f659ea1f120e2241cc9b533a77c95693e3c53b21f418f56dddca5
Транзакция с ошибкой
0xfd4c3ad9dc254f0b92bd6f9795961db8257ce15d 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 23:38 7237481 0xfb80b38a3ed00d2267d9c07d56878e3e856dafb3ecedabe72247d9c1b512ced2
Транзакция с ошибкой
0xfd4c3ad9dc254f0b92bd6f9795961db8257ce15d 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 23:08 7237386 0xece1c74c2c569d9da962d10057ac5d0188f9ebeea190b92209e4c7e0c29adb8d 0x6e37cf9ecec9d1e264e921308ec52cafe18ca49c 0xddfc21df6f2556528b21574695c7b33f22e60a70 0.25 Ether
18 фев. 22:59 7237363 0x16bc915ebf4ffb267d0c138cfafaddfac8d5799718808bcc62dc00ab687c3a2a 0xce6296356968306d01bd83d4cff11d317e86147a 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 22:40 7237312 0xa3e30a47d2cb4ea68b89d1d7c13054106b3f7e9510d391ea404c7ef5df23f315 0xd7921adbd135d989cf99d0b24d67cb71f3fd86a6 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 21:54 7237174 0xdf634c80b211bc8e5aebadd3b87345e5d6fc76c051b441203ea3bb0bd6a7d247
Транзакция с ошибкой
0xa55d0edebbfb43d150f2cb51fbdd572d32e6329a 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 20:04 7236861 0x9475c006636663b09d274984123bc6e3c13232581be9e77a9545a124d26fe0ff 0x8e6b5bf2377f9ace277fbacd712bba952fc003a3 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 20:00 7236851 0x73561ccf66acdb36fc63182eecd43ec555114952f9d8bc01c745132740f98c9c 0x8e6b5bf2377f9ace277fbacd712bba952fc003a3 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 19:58 7236840 0x54a24ec069e314b5b092c9930c30a150686c98bb97d5f03524678ee835ef4abd 0x8e6b5bf2377f9ace277fbacd712bba952fc003a3 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 19:48 7236809 0x17f2c2c8a89d568cf641eed072db50b3aea923cf76f6b5e0e624ceef5ad3a8fc
Транзакция с ошибкой
0x8527267bd483338feaa85634304c31ffedb9631f 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 19:48 7236808 0x009dd50a123b37ff4bad7444467ee7cc7571759eb662ed883075993fd7a01edb 0x8e6b5bf2377f9ace277fbacd712bba952fc003a3 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 19:45 7236801 0x05ec4f119437cbab4a07e41d2f7c484feb7a0729a556b840b363b222978e18c5 0x8e6b5bf2377f9ace277fbacd712bba952fc003a3 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 19:43 7236797 0x6dbe6a1741f21a693cdf1f4ebc5736c26542c44136d83f20c999f1a101b821f2 0x8e6b5bf2377f9ace277fbacd712bba952fc003a3 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 19:42 7236792 0xc01356d45bd528d62a83d58d0be5b8c8fce20925827713e74b51cdc154bc441a
Транзакция с ошибкой
0x4701639792de046c61cfc43b44b9d3f349125cce 0xddfc21df6f2556528b21574695c7b33f22e60a70 0 Ether
18 фев. 19:41 7236788 0xe10ffc51307c17fbc8fb2bb04cd063d6a90b141a67a026a56cb151eb706282aa 0x8e6b5bf2377f9ace277fbacd712bba952fc003a3 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);
  }
}
Документация
Идейные соображения высшего порядка, а также дальнейшее развитие различных форм деятельности представляет собой интересный эксперимент проверки модели развития. Разнообразный и богатый опыт консультация с широким активом требуют определения и уточнения существенных финансовых и административных условий. Задача организации, в особенности же новая модель организационной деятельности требуют от нас анализа системы обучения кадров, соответствует насущным потребностям. Повседневная практика показывает, что дальнейшее развитие различных форм деятельности обеспечивает широкому кругу (специалистов) участие в формировании новых предложений. Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности влечет за собой процесс внедрения и модернизации новых предложений.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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