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

333 v.2

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

Баланс

0 ETH.

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

0%

Ввод

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

Выводы

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

Условия

В день
-
В час
-

Инвесторов

2265

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

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

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

-

Контакты

  • Таймлайн:
  • час
  • день
  • неделя
  • месяц
Пополнения (35496)
Выводы (35769)
Аудит
Код
API
Комменторы
Дата Блок TxHash От кого Кому Сумма
Сегодня 00:38 7246161 0x2648a5c01432533a3fe166192dfee694ea604da3770df7146eac5de2fe0c76b0
Транзакция с ошибкой
0x477f7f4bc76ae35eefb7895af37de846400680dd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
10 фев. 15:02 7202462 0x1dd6f00f88c01be9eedb0ee6f9086d9f6eb872b81fa442caba1d936b2d2809fb
Транзакция с ошибкой
0x7a9029dbcc4456242bb0880e10f31845d52ef8bd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
9 фев. 11:03 7196928 0xe3815db028ab7cc82f309ea0b0c6041c4f4ff0a44cc3ef7666a3ba5696016625
Транзакция с ошибкой
0x18f0f095a5dac83655ceb70d36f43073c5fc6fb4 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
29 янв. 12:12 7143255 0x0864961128d1772542bb531c243faab1c36dbf8f98d8ca8348805c3d994821be
Транзакция с ошибкой
0x97f62ab92f99e82f55a449aa0cb3d4e1835cc20a 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
28 янв. 23:49 7140767 0x7f3996da0e11b91b7f9dcef21c392508390b0f131ae6c871aa70939a3b38834a
Транзакция с ошибкой
0xee934c2cd888e6b216081bf95ac93813ef28f724 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
26 янв. 06:06 7127094 0x9b5affa21cd6ee3ef14ff55f156def67b91b243ce591fcc0d541c0000a24fe55
Транзакция с ошибкой
0x916e374b7348e2e6b9e7cdd7d2f5079f72950c31 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
25 янв. 06:45 7122147 0x92d8484812f941128d5ace8711646dae3b2d14c10c011dd92ad95cffd9569df6
Транзакция с ошибкой
0x5724ac2d8d62d28ba60fb458a3e8f0f0d1c76bbd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
15 янв. 19:58 7071424 0xbbee2e5c49da6f6fdae94833b49179d87dae10ddfabc4a0c5ae4b00a0298e054
Транзакция с ошибкой
0x3021158afd040101bbb49b9a73b058ba9a3196cd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
13 янв. 13:58 7058811 0xfb845047982f7f19bacdce6638b17f1885a55ce470e24320b80680fef9e95031
Транзакция с ошибкой
0x3021158afd040101bbb49b9a73b058ba9a3196cd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
12 янв. 17:30 7054044 0x2242e72d4464a15bdf0774ae109b06a657558d2f50399093c89739ddefbd2c9c
Транзакция с ошибкой
0x7a9029dbcc4456242bb0880e10f31845d52ef8bd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
11 янв. 18:34 7048703 0x4104ce413283fe1be99c9c2479aba6194b5128f47c595f85fe3600267f512c73
Транзакция с ошибкой
0x4085fbf6c8236180410ecfc34f8ca77db4034b3d 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
10 янв. 20:39 7043588 0x389b5a6d2140225cb97a367af0881d120fa5c64ae25ba9ebe11075c5846c8146
Транзакция с ошибкой
0xb1d7f3d36bba17d027af362d5e93cd3fd29ffdf2 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
10 янв. 16:38 7042671 0xbd7d67ec6d30a18bb172fa03eaec2f29cdad330440c3c3228e8efbd414b2df72
Транзакция с ошибкой
0x4085fbf6c8236180410ecfc34f8ca77db4034b3d 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
8 янв. 18:16 7031914 0x9251d7b1d2fbafad6a2750fd5fe2eaa1a1eec65b52a1faf7ad32b4edad043f5c
Транзакция с ошибкой
0x3021158afd040101bbb49b9a73b058ba9a3196cd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
8 янв. 18:11 7031894 0x23b4dbaa8de5127209d29407887f8e500d9ecb2b18b7104609b0edb56f615545
Транзакция с ошибкой
0x3021158afd040101bbb49b9a73b058ba9a3196cd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
5 янв. 13:06 7013890 0xc577c3450ccba08f709e9e81421cc3e3d570d018047daf097d4d7dccb1d952cb
Транзакция с ошибкой
0xef4b0f95ec4792a5a28030463ff2208e0dbe2910 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
4 янв. 23:29 7010718 0x8151382b46f2cd4e696533027954beddc517574f42d2bc0278a36894d45cb00d
Транзакция с ошибкой
0xaae291def326cae5737c33183f274a81191185b5 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0.01 Ether
4 янв. 12:33 7008220 0x7be8d813cea0abfa8e227f8d3ec96c7a65c6b5ee17ae5c89062987cb303d59d9
Транзакция с ошибкой
0x65bdd9813be74425622b5c41e4cf5ea580fbb82f 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
4 янв. 04:18 7006325 0x640eef6d3497fb84d52baae19a898bafdc71dc67b031f3cd21471d186b64e570
Транзакция с ошибкой
0x258d756213c3b5d99c090118dc3ae17dc913f8dc 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
4 янв. 00:18 7005387 0x481e6536326c52d01d9f0c1a5c6227fb59b42e01791ed92b6ed93427ec4cdf80
Транзакция с ошибкой
0xbc40918765a651985bef84f2d7c571a290ce25a4 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
3 янв. 23:56 7005303 0x2aff121bcfe6f1e5b05ab7927c414247f5091d0f6e557eb0ef108724351ff5dc
Транзакция с ошибкой
0x637705f86574ab7e323e17cb3472ef51fc55b86e 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
3 янв. 23:33 7005221 0x316beaa5c1f72e3fe126a4c80ce0df2326746dc606626a42a15b9022dfe44132
Транзакция с ошибкой
0x17dc2801de0959ddb53c576dd6d015efea3fb728 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
3 янв. 23:30 7005210 0xf6ee07d0971eeed9c4e1eafbf14fd0bf0004753b99a31f99b8e80831445afb54
Транзакция с ошибкой
0x32e26036dfac4c95feff9df273c39dcf3b35db93 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
3 янв. 22:47 7005058 0xa1763908dace13a924ca35c3bb2e335a0895dae9c5c2cdd5b7a18b8e6bdecee1
Транзакция с ошибкой
0x2fa4f0913f2c98953a877f5ab1264238e2261afe 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
3 янв. 22:01 7004868 0xf2f1f9ec4b84d92097e8d260edd987db3c64ecd3f9897f08d528f5e57e8471c5
Транзакция с ошибкой
0x698bda760f46118f841f2e95d8e2e91c8424a6f2 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
Дата Блок parentTxHash От кого Кому Сумма
4 янв. 23:29 7010718 0x8151382b46f2cd4e696533027954beddc517574f42d2bc0278a36894d45cb00d
Транзакция с ошибкой
0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xf4d27660abb9d9f3bbc0388cb721d4712e53999d 0.00075 Ether
4 янв. 23:29 7010718 0x8151382b46f2cd4e696533027954beddc517574f42d2bc0278a36894d45cb00d
Транзакция с ошибкой
0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xd3b9ca15996766d9856f3895cd67d186187113dd 0.0005 Ether
2 янв. 04:45 6994925 0x4214bc61bb9a2b480b473b9a20a9622562eade827822ab72546375796cce12fd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0 Ether
2 янв. 04:45 6994925 0x4214bc61bb9a2b480b473b9a20a9622562eade827822ab72546375796cce12fd 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x8cdb7313ef7a83a01081b5e64275d69e2a4f9d6b 0.011120702735730506 Ether
2 янв. 04:26 6994845 0x2f9a075e2662b1ff4ad701b656eb7771472f06a153e0ff254d4eb0da0b637641 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x48f4ec26820d80a2e0b620a1fe9c9293b328d46a 0.0023656875 Ether
2 янв. 03:16 6994566 0xe4415769c3965b4dec209f27de6c89589aceff074d7c0ca917e29e2f087b9863 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xa18fb8bf2db2829d000bd0910c3b341c0003745f 0.00074552595 Ether
2 янв. 02:18 6994326 0x94d90650ee4cec9dc83ec0b29274843e22db9ffea376e353eec4b9d3483644fa 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x477f7f4bc76ae35eefb7895af37de846400680dd 0.00185 Ether
2 янв. 01:09 6994041 0x9e9ad656e6b0ee819f7c8b94f166b656b5242be2e9506cdb2e0aa788dd9e7cbc 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xa18fb8bf2db2829d000bd0910c3b341c0003745f 0.000372762975 Ether
2 янв. 00:57 6994000 0x43f1b4640e1428c65644cede5c93eeb9d07e9858aaf19373eb58fc8fe7be7eca 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x7233358d60f76d6d91d89738af465b73bf379e13 0.00005177595 Ether
2 янв. 00:05 6993781 0x501f8ca510ffca009d4a1f1cf5df18e1dc805c88b6e3eb719550a8395dfceb3d 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xa18fb8bf2db2829d000bd0910c3b341c0003745f 0.0004348901375 Ether
1 янв. 23:30 6993627 0x0fe8b79b6d210834b2335b6ff111b3b5d6f1b4020fa27d7e4b241194156cd827 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xb37e16a835acd6f480016f5a0e45f97a72d55b0a 0.003693351701608697 Ether
1 янв. 23:14 6993564 0x2725a144954442b4dc1c440c7924617a5ca09399f372925e2698997bdf34b9d6 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xb63ec73faf02a2d07d842b96cb13873dc8ff0f3c 0.001205312623623785 Ether
1 янв. 22:48 6993450 0xa090547e15cb0f7472f7380f1e1feecc6cb4d68b1bb6d723c99231c8a5fff71b 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x7233358d60f76d6d91d89738af465b73bf379e13 0.001803528925 Ether
1 янв. 22:46 6993444 0x3a88ae8ad756218e4acc1217b9e48650dc04197c2e6a9b9910e6f972756dde3f 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xa18fb8bf2db2829d000bd0910c3b341c0003745f 0.016277316575 Ether
1 янв. 22:34 6993395 0x5bf9c2d0e23acfa5468c4d9ec93ae2401db9281a2683fb7f68970ae4ad66b4c2 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xb8169e5444841c4c125d8f2714604bc241638247 0.003894006760600805 Ether
1 янв. 22:01 6993244 0x6fb6c4b9067a639be0362750273e9ec360feb4111187496472910db56b728855 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x477f7f4bc76ae35eefb7895af37de846400680dd 0.001776 Ether
1 янв. 21:33 6993120 0xdcd3908500a58817a1df4bbee83099d67db87e3dd2cb717a02b0f6839927d9c3 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xeb5bf0e93cadb3fc480306f8e76335c99a9a50ef 0.010927731044936781 Ether
1 янв. 17:52 6992210 0xae2757e88337a390d2690df4eccc208b5be63a79f2a352fe04c54b684215ee92 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x477f7f4bc76ae35eefb7895af37de846400680dd 0.022718 Ether
1 янв. 15:27 6991588 0xa08e2382a0c27cfbf0a983aaa582ce0bec9e31b55db442db29dc1107d25f32a4 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xb63ec73faf02a2d07d842b96cb13873dc8ff0f3c 0.011083635647670901 Ether
1 янв. 13:36 6991147 0xb8d650cb0c1a85ccea2629296d3817d897128dfdf23c9597ad08d079f221cae0 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xeb5bf0e93cadb3fc480306f8e76335c99a9a50ef 0.014182799866832843 Ether
1 янв. 09:41 6990275 0x181d8e565e51a7aa816c81163f1637d878d5a81fa7122ab005661bf4903809c8 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xb8169e5444841c4c125d8f2714604bc241638247 0.00515829466988678 Ether
1 янв. 03:18 6988698 0x6959e8cdb96b258153f3c0a59251f6bc6f82d7aaa73584d2653aa5a7b7e01b33 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xeb5bf0e93cadb3fc480306f8e76335c99a9a50ef 0.015810334277780873 Ether
1 янв. 02:50 6988573 0x14c354baeab25cb170245155ad5c56dbf495936e5af99399a915604845d33052 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x0944807ade36dc625868fe149153312a5c1d0f2e 0.000372762975 Ether
31 дек. 2018 г. 23:19 6987669 0x19d1f37e99a8d8a5d1ffeb5936049cbc87342e6088c789b6736540d3b9bb97c7 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0x3021158afd040101bbb49b9a73b058ba9a3196cd 0.009485875 Ether
31 дек. 2018 г. 22:02 6987329 0xd93ea397ead6b1bfe3a95bec41d6ac49962f85f699337533a597399cf19e48a3 0x215ce36e90b1b64e6fa2e358305177f8fe5daf25 0xb37e16a835acd6f480016f5a0e45f97a72d55b0a 0.031952351892206826 Ether
Средняя оценка аудиторов -
Contract Source Code </>
pragma solidity 0.4.25;


/**
*
* ETH CRYPTOCURRENCY DISTRIBUTION PROJECT v 2.0
* Web              - https://333eth.io
* GitHub           - https://github.com/Revolution333/
* Twitter          - https://twitter.com/333eth_io
* Youtube          - https://www.youtube.com/c/333eth
* Discord          - https://discord.gg/P87buwT
* Telegram_channel - https://t.me/Ethereum333
* EN  Telegram_chat: https://t.me/Ethereum333_chat_en
* RU  Telegram_chat: https://t.me/Ethereum333_chat_ru
* KOR Telegram_chat: https://t.me/Ethereum333_chat_kor
* CN  Telegram_chat: https://t.me/Ethereum333_chat_cn
* Email:             mailto:support(at sign)333eth.io
* 
* 
*  - GAIN 3,33% - 1% PER 24 HOURS (interest is charges in equal parts every 10 min)
*  - Life-long payments
*  - The revolutionary reliability
*  - Minimal contribution 0.01 eth
*  - Currency and payment - ETH
*  - Contribution allocation schemes:
*    -- 87,5% payments
*    --  7,5% marketing
*    --  5,0% technical support
*
*   ---About the Project
*  Blockchain-enabled smart contracts have opened a new era of trustless relationships without 
*  intermediaries. This technology opens incredible financial possibilities. Our automated investment 
*  distribution model is written into a smart contract, uploaded to the Ethereum blockchain and can be 
*  freely accessed online. In order to insure our investors' complete security, full control over the 
*  project has been transferred from the organizers to the smart contract: nobody can influence the 
*  system's permanent autonomous functioning.
* 
* ---How to use:
*  1. Send from ETH wallet to the smart contract address 0x311f71389e3DE68f7B2097Ad02c6aD7B2dDE4C71
*     any amount from 0.01 ETH.
*  2. Verify your transaction in the history of your application or etherscan.io, specifying the address 
*     of your wallet.
*  3a. Claim your profit by sending 0 ether transaction (every 10 min, every day, every week, i don't care unless you're 
*      spending too much on GAS)
*  OR
*  3b. For reinvest, you need to deposit the amount that you want to reinvest and the 
*      accrued interest automatically summed to your new contribution.
*  
* RECOMMENDED GAS LIMIT: 200000
* RECOMMENDED GAS PRICE: https://ethgasstation.info/
* You can check the payments on the etherscan.io site, in the "Internal Txns" tab of your wallet.
*
* ---Refferral system:
*     from 0 to 10.000 ethers in the fund - remuneration to each contributor is 3.33%, 
*     from 10.000 to 100.000 ethers in the fund - remuneration will be 2%, 
*     from 100.000 ethers in the fund - each contributor will get 1%.
*
* ---It is not allowed to transfer from exchanges, only from your personal ETH wallet, for which you 
* have private keys.
* 
* Contracts reviewed and approved by pros!
* 
* Main contract - Revolution2. Scroll down to find it.
*/ 


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 {
  // Solidity automatically throws when dividing by 0
  struct percent {
    uint num;
    uint den;
  }
  
  // storage
  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);
  }

  // memory 
  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) {
    // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
    // benefit is lost if 'b' is also tested.
    // See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522
    if (_a == 0) {
      return 0;
    }

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

    return c;
  }

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

    return c;
  }

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

    return c;
  }

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

    return c;
  }

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


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) {
    // check if investorAddr has access
    if (!pe.hasAccess[investorAddr]) {
      return 0;
    }

    // get investor max investment = investment from revolution 1
    (uint maxInvestment, ) = pe.rev1Storage.investorShortInfo(investorAddr);
    if (maxInvestment == 0) {
      return 0;
    }
    maxInvestment = Math.min(maxInvestment, pe.investorMaxInvestment);

    // get current investment from revolution 2
    (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;
  }
}


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; // +1 for skip zero day
  }
}








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; //       0.01 eth
  uint public constant maxBalance = 333e5 ether; // 33 300 000 eth
  address public advertisingAddress;
  address public adminsAddress;
  uint public investmentsNumber;
  uint public waveStartup;

  // percents 
  Percent.percent private m_1_percent = Percent.percent(1, 100);           //   1/100  *100% = 1%
  Percent.percent private m_2_percent = Percent.percent(2, 100);           //   2/100  *100% = 2%
  Percent.percent private m_3_33_percent = Percent.percent(333, 10000);    // 333/10000*100% = 3.33%
  Percent.percent private m_adminsPercent = Percent.percent(5, 100);       //   5/100  *100% = 5%
  Percent.percent private m_advertisingPercent = Percent.percent(75, 1000);// 75/1000  *100% = 7.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 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 percent1() public view returns(uint numerator, uint denominator) {
    (numerator, denominator) = (m_1_percent.num, m_1_percent.den);
  }

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

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

  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 refBonusPercentAtNow() public view returns(uint numerator, uint denominator) {
    Percent.percent memory p = refBonusPercent();
    (numerator, denominator) = (p.num, p.den);
  }

  function getMyDividends() public notFromContract balanceChanged {
    // calculate dividends
    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 refBonus = refBonusPercent().mmul(investment);
      assert(m_investors.addInvestment(referrerAddr, refBonus)); // add referrer bonus
      investment += refBonus;                                    // add referral bonus
      emit LogNewReferral(msg.sender, referrerAddr, now, refBonus);
    }

    // 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
    // if daily percent is X, then 10min percent = X / (24h / 10 min) = X / 144

    // and we must to get numbers of 10 min interval after investor got payment:
    // (now - investor.paymentTime) / 10min 

    // finaly calculate dividends = ((now - investor.paymentTime) / 10min) * (X * investor.investment)  / 144) 

    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;

    // (3) 3.33% if balance < 1 000 ETH
    // (2) 2% if 1 000 ETH <= balance <= 33 333 ETH
    // (1) 1% if 33 333 ETH < balance

    if (balance < 1000 ether) { 
      p = m_3_33_percent.toMemory(); // (3)
    } else if ( 1000 ether <= balance && balance <= 33333 ether) {
      p = m_2_percent.toMemory();    // (2)
    } else {
      p = m_1_percent.toMemory();    // (1)
    }
  }

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

    // (1) 1% if 100 000 ETH < balance
    // (2) 2% if 10 000 ETH <= balance <= 100 000 ETH
    // (3) 3.33% if balance < 10 000 ETH   
    
    if (balance < 10000 ether) { 
      p = m_3_33_percent.toMemory(); // (3)
    } else if ( 10000 ether <= balance && balance <= 100000 ether) {
      p = m_2_percent.toMemory();    // (2)
    } else {
      p = m_1_percent.toMemory();    // (1)
    }          
  }

  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);
  }
}
Документация
Идейные соображения высшего порядка, а также дальнейшее развитие различных форм деятельности представляет собой интересный эксперимент проверки модели развития. Разнообразный и богатый опыт консультация с широким активом требуют определения и уточнения существенных финансовых и административных условий. Задача организации, в особенности же новая модель организационной деятельности требуют от нас анализа системы обучения кадров, соответствует насущным потребностям. Повседневная практика показывает, что дальнейшее развитие различных форм деятельности обеспечивает широкому кругу (специалистов) участие в формировании новых предложений. Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности влечет за собой процесс внедрения и модернизации новых предложений.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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