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

SnailThrone

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

Баланс

13.3287 ETH.

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

0%

Ввод

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

Выводы

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

Условия

В день
-
В час
-

Инвесторов

55

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

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

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

-

Контакты

  • Таймлайн:
  • час
  • день
  • неделя
  • месяц
Пополнения (1702)
Выводы (137)
Аудит
Код
API
Комменторы
Дата Блок TxHash От кого Кому Сумма
Сегодня 09:43 7247797 0x3e475ebe880c1cc6c5549d63b9f093f1bc9e13049d9d38c2aa622d7f8a47c528 0xa7e67f2ef812c3c6427aa62a6af77580181f4b3c 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Сегодня 09:42 7247794 0x8fd910426f79dce9f039e63c6ff1011075739d08cbd60bcfd3006dfeb46ecfac 0xa7e67f2ef812c3c6427aa62a6af77580181f4b3c 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Сегодня 09:41 7247792 0x789274713a9391671ce26125676913699a987829f410675fed24309731b1d0d2 0xa7e67f2ef812c3c6427aa62a6af77580181f4b3c 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Сегодня 05:27 7247018 0x4f6d20033d0f4f2268f59161b40ac6f75fc2ced717b08073659167a973747e97 0x1c180f637927384465a3c43e03d2dce18a892fda 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Сегодня 05:21 7247001 0x927dd0625cf6bfa6cf31dbed981024dea36ce640c11ec5e548473fcd1b52d062 0x1c180f637927384465a3c43e03d2dce18a892fda 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Сегодня 05:17 7246993 0x5e3c4a0f63336b05bf2df097d9bf25ef8a88d17d34a6d78746b5fbfc933bcf9e 0x1c180f637927384465a3c43e03d2dce18a892fda 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Сегодня 05:14 7246982 0xb2fdeb176191acfcc7e5e167805423210c8aef8e4a52d772d287daf6f61c7d41 0x1c180f637927384465a3c43e03d2dce18a892fda 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Сегодня 05:08 7246968 0xec044a2e03a49550f7e907a33ece27cfaed19a376d0b97db107efc5edc5ba08d 0xa4e7918fb5f4a8c12f9513b193be1d764d5757dc 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Вчера 15:36 7244583 0x9478fcb982d738e4db721e348db11a3df214b20c8d959bbe758d8c12b6db90c0 0x3c46b2005b1207da0c0d27fd5f4391b894ce6e42 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Вчера 14:01 7244295 0xd16c07fa6a29d8cc9243c7b4eb57129a3efc8f8b05b4ef20c6fdb6e1f623688b 0x8949db9fbb4716ce5a2803085c7732c14fe03a37 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
Вчера 03:21 7242438 0xdcb892b47cdfaa1e3ef2c43f0be8b4e0c420bd0a5f90ef697b913b7630a402b0 0xa4e7918fb5f4a8c12f9513b193be1d764d5757dc 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
19 фев. 23:49 7241802 0x38207cbe1480b9c5f6a568fdef51391b13945b0777c35b3cdd2f5f817249f8bb 0xabf3e252006d805cce3c7219a929b83465f2a46e 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
19 фев. 22:21 7241541 0x9f801fe8bc8cc70e9e977b81d05cc35efd6311c62a95828da9f9e94634d380ee 0x78feff3e50afff2316be5cae1b49cc00c0570353 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
19 фев. 18:30 7240867 0x981c5e8d573a10f6af9e96fa6400ff7f277c4a7f69262d2850ee0ea3e4d1d475 0xfbf13497056f33300ad82511c6a1349dd3d2ae26 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
18 фев. 15:44 7236123 0x74890de0b8812f48ec847f365516fbd588c4a731a538405fd1516cce724463d0 0x3c46b2005b1207da0c0d27fd5f4391b894ce6e42 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 20:45 7232822 0xb7005863983f72ac5e2cfe35aaab6820e528aa312e80959acb25d936b7226c5b 0xa7e67f2ef812c3c6427aa62a6af77580181f4b3c 0x261d650a521103428c6827a11fc0cbce96d74dbc 0.020741 Ether
17 фев. 20:07 7232695 0xde291fa60e4dddc1b154995505cb953f7e9532bc6d13676750866afbe8c14b9f 0xabf3e252006d805cce3c7219a929b83465f2a46e 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 09:42 7230846 0x7c5e4b7ebd115316d4741d1d3bd12ec78417fe10e622974bc2cc4a36d84c973b 0x5a777dd5052aabd0d48833081b5f57ff80989fde 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 08:20 7230643 0x0416793ec9a12797ef63e4bf994a39fc58f88e216b59860a65ce7a096104bc96 0x5a777dd5052aabd0d48833081b5f57ff80989fde 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 05:08 7230072 0x8588a52bde017da9a48ab83001f4aa38adeb60db8673a08917ef4b74f5b490fd 0x78feff3e50afff2316be5cae1b49cc00c0570353 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 00:35 7229284 0x7d9995f75e81650a2671c885c00954d3cca66e190489d1530a82e8536e3d8630 0x8949db9fbb4716ce5a2803085c7732c14fe03a37 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 00:33 7229281 0xc3b66766189431705d80cb3003af7b57f55c0a74a93b049673fc719df421fe33 0x8949db9fbb4716ce5a2803085c7732c14fe03a37 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 00:30 7229273 0x150f883f7535481d62b23274e2d1033383f42afb2958874cc16e8382f1b62cb0 0x3c46b2005b1207da0c0d27fd5f4391b894ce6e42 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
17 фев. 00:27 7229268 0x185bfd2ae9974de2e1ca843b8d0b2ef5182e16d6a07fcd5d19918a707edc9066 0x3c46b2005b1207da0c0d27fd5f4391b894ce6e42 0x261d650a521103428c6827a11fc0cbce96d74dbc 0 Ether
16 фев. 18:56 7228285 0x5f70d67013d688bd75b914f3a5f5dee318696245c17579248e6e8f647e2f23c0 0xa7e67f2ef812c3c6427aa62a6af77580181f4b3c 0x261d650a521103428c6827a11fc0cbce96d74dbc 0.014811 Ether
Дата Блок parentTxHash От кого Кому Сумма
20 дек. 2018 г. 09:16 6919240 0xce3062edce5d102a0a977fe587f2fc0d01f907e9ba29612e1c5aadb64cbc9b00 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x1c180f637927384465a3c43e03d2dce18a892fda 0.005807571330522756 Ether
19 дек. 2018 г. 22:51 6916698 0xfe476e738f1a3f38f67c07ac1c2ff472714fbd7827c1896a55d7a9182a3ae189 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xb74d5f0a81ce99ac1857133e489bc2b4954935ff 0.1446857965066023 Ether
18 дек. 2018 г. 22:32 6910746 0x6127c722adffbe908ceda821435d9529df44b0eea1e0f007090d2ccbc085dbec 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xabf3e252006d805cce3c7219a929b83465f2a46e 1.92725488523838 Ether
18 дек. 2018 г. 04:53 6906463 0x68e0b6d7ad3647e0fe3d60748a620edfd841bd0cfb98f02453caddb754e02c95 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x778f7434956b899303708fa3c5fad85bf9d93e06 0.4829246010084437 Ether
18 дек. 2018 г. 02:13 6905812 0x380a06e8ad03b89f299133d239243649cd6ec75a8875f72ba1f2b31126578527 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xc1176c5d853432ba6d7dfaa0e8d5d2286d143c58 0.6214166273792057 Ether
17 дек. 2018 г. 16:10 6903320 0x9684c689b7d995dd35c6dda1631e25fddbc349f00fc2a984b23d3ec548575373 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xcf75afcc01ea555d54269320cc9baff325ba3736 0.2553303151158518 Ether
17 дек. 2018 г. 16:09 6903313 0xdfd6854dec32ecf41bb567d7bc76a8a6077ed0b8785bf5d5a063de4f1309c474 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x0e9a79ecec42e41b9fe201d4401fb077c1dcf4c7 0.11113088321706754 Ether
17 дек. 2018 г. 16:07 6903307 0xd6b66a9a1d6758719412e5c140e60efafc21bee77f70af1fa3b8fc39c031b57e 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x7091d5758bcc57e3d69d9c4e0a126ce5ef17a012 0.5920628702549567 Ether
17 дек. 2018 г. 16:00 6903280 0x40ce11bb91ac120fcabc222a66f92953ca8d9fbced1b0e9fc0aba54143437e28 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x8d3ef8f58da859514a3627f0c677d4a2f66a2055 0.11980795211160616 Ether
17 дек. 2018 г. 16:00 6903278 0xc470688b0c789871b37929795618fef5ffb7b89ecfa5dae855d659188cd9512c 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x218f04bce746c068ece0b0b88f9e9dfd9dda6fdb 0.10540717322419778 Ether
17 дек. 2018 г. 15:57 6903266 0x8a58b21ee26b06cb54b0ba2ef18ad1748f4c265e012a64749fd25f5c1447b04b 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xf71b240920ef53e0ccb5f8000ca42eb714108c74 0.10622088649084115 Ether
17 дек. 2018 г. 15:57 6903262 0xc8fa04ce3c3dc909e905e5ea1aff7b27d6b2eddbeb38eecad2d299f5d5dd9889 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xb5f5655e8be6039173fef87191e53c86f799f7ca 0.16110413502879806 Ether
17 дек. 2018 г. 15:15 6903087 0xd390fb3d8c77a3b493362ac2f10cd6090973892c14b353e3b9b40461756b52d7 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x867e29a4dd0d5ca0e23eeacd2146df164804c63f 0.06656457866258897 Ether
17 дек. 2018 г. 15:08 6903062 0xe7ec0e2d4d84507674ab098b1bf1a677bc633b27ce05b632b25c9d3f6538cb50 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xaa5dd1ac6e16e5f34c88bb7b3d67938d22ebe9a9 0.1998114836222852 Ether
17 дек. 2018 г. 15:07 6903059 0xef7be5bf8374b5a5375939cb9ea5b4220270bee7a3b21f6c9bb92fb528341ea8 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x23b2bcae8dec395afd931f49ea8387937e515ca1 2.481447018777978 Ether
17 дек. 2018 г. 15:07 6903059 0xdbf2cbdb2c78bacfd98b865a52c5d7bfdd6a070871134d717b23d877e3174095 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x885b09500cbc1c9cbcd0626459385f471ef72d47 0.05118409899889405 Ether
17 дек. 2018 г. 14:52 6902979 0xce43f74d5ee13ddf5782a71884d35857a0e6ef27057b9322216356765b560a94 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xe84fd91cbba2fcddc22d96965158ae676dd61d28 2.420733515242946 Ether
17 дек. 2018 г. 08:32 6901473 0xd608f336f640891ffa7b9cd6d778bff946739d4b70f402e5e2af5351707288a2 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xc1176c5d853432ba6d7dfaa0e8d5d2286d143c58 0.34110297059147177 Ether
16 дек. 2018 г. 23:54 6899328 0x6bf81e4bae3a11c835b8b2fe24beecfdbe6eacc8389b140a7db6694b3db01a17 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x8949db9fbb4716ce5a2803085c7732c14fe03a37 0.02994542878385718 Ether
16 дек. 2018 г. 22:03 6898872 0x293155e208ad031ebb115bb45b19c21d679f2d15c53d19772713d48c068436c5 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x23b2bcae8dec395afd931f49ea8387937e515ca1 0.14014331087043047 Ether
16 дек. 2018 г. 22:02 6898868 0x8a0f14453afb7aed73eecc654b6d2725271bc3db858b9eed7c301940ecf484f9 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xe84fd91cbba2fcddc22d96965158ae676dd61d28 0.1312210269365446 Ether
16 дек. 2018 г. 03:55 6894302 0xff67659e2eb27c95ed4975afd150e42f0e2981ee1ccc868dd31e8ec07b39cf78 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xb38094d492af4fffff760707f36869713bfb2250 0.4177873716510131 Ether
16 дек. 2018 г. 01:06 6893606 0x03c1b93922306427c4be70b64ab4b2f10ef66d52bbc5fd9a2ef20d1aca5de00a 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xb38094d492af4fffff760707f36869713bfb2250 0.020812348731081363 Ether
15 дек. 2018 г. 23:39 6893218 0x7d77beaf90427154514c785fa5b5b4ba4677e5f694afa15b26147cb2ce05e95d 0x261d650a521103428c6827a11fc0cbce96d74dbc 0x778f7434956b899303708fa3c5fad85bf9d93e06 0.15315183304190325 Ether
15 дек. 2018 г. 20:35 6892432 0x1dc248555546fd0fedf4c84f087ddb2e02137f5c3f92e4d2d1497341e50a522e 0x261d650a521103428c6827a11fc0cbce96d74dbc 0xc1176c5d853432ba6d7dfaa0e8d5d2286d143c58 0.22338177825133468 Ether
Средняя оценка аудиторов -
Contract Source Code </>
pragma solidity ^0.4.24;

/* SNAILTHRONE

// SnailFarm + Pyramid + Fomo

// Buy and sell snails, pyramid tokens, directly from the contract
// Snail holders receive proportional dividends from buys and hatches
// Token price correlates with snail max supply

// Snails produce eggs, at a rate of 8% per day
// Up to a maximum equal to the amount of snails the player owns
// Players can hatch these eggs to turn them into more tokens
// Hatching comes at half the cost of buying tokens
// Players can also sacrifice their eggs to the FrogKing for an ETH reward

// On buy, incoming ETH is distributed as such:
// 50% saved for the SnailPot (token price on sale)
// 20% in divs
// 20% go to the FrogPot
// 2% is given to the current Pharaoh
// 2% goes to the SnailGod pot
// 6% goes to the referral. lacking ref, it goes to the SnailGod pot

// On hatch, incoming ETH is distributed as follows:
// 40% in divs
// 40% go to the FrogPot
// 4% is given to the current Pharaoh
// 16% goes to the SnailGod pot

// SNAILPOT 
// Snails can be sold to the SnailPot for ether 
// Price per snail is 50% of the current buy price 
// No more than 10% of the SnailPot can be drained in one sale 

// FROGPOT
// Feeding eggs to the frogking grants a reward 
// Ether earned = frogpot * eggs fed / total snails

// SNAILGOD
// The ultimate reward of the game, on a 24 hours timer
// Sacrifice a minimum of 40 snails to become the Pharaoh
// While the Pharaoh sits on the throne, he receives 2% ETH of every buy
// A successful sacrifice will bump the timer back up by 8 minutes
// and set the minimum snail requirement to 40 + this sacrifice
// This number lowers back down to 40 over time
// Once the timer hits 0, whoever holds the Pharaoh title ascends to godhood
// The SnailGod can instantly claim 50% of the SnailGod pot
// Timer resets at 24 hours, minimum sacrifice resets at 40 snails 
// and the previous Pharaoh takes the throne until a contender sacrifices enough snails

// REFERRALS
// Unlocked by owning at least 300 snails
// Every buy through a referral link gives 6% to the referred address
// Addresses aren't bound to their referral link
// Referrals don't profit from hatching eggs

*/

contract SnailThrone {
    using SafeMath for uint;
    
    /* Events */
    
    event WithdrewEarnings (address indexed player, uint ethreward);
    event ClaimedDivs (address indexed player, uint ethreward);
    event BoughtSnail (address indexed player, uint ethspent, uint snail);
    event SoldSnail (address indexed player, uint ethreward, uint snail);
    event HatchedSnail (address indexed player, uint ethspent, uint snail);
    event FedFrogking (address indexed player, uint ethreward, uint egg);
    event Ascended (address indexed player, uint ethreward, uint indexed round);
    event BecamePharaoh (address indexed player, uint indexed round);
    event NewDivs (uint ethreward);
    
    /* Constants */
    
    uint256 public GOD_TIMER_START      = 86400; //seconds, or 24 hours
	uint256 public PHARAOH_REQ_START    = 40; //number of snails to become pharaoh
    uint256 public GOD_TIMER_INTERVAL   = 12; //seconds to remove one snail from req
	uint256 public GOD_TIMER_BOOST		= 480; //seconds added to timer with new pharaoh
    uint256 public TIME_TO_HATCH_1SNAIL = 1080000; //8% daily
    uint256 public TOKEN_PRICE_FLOOR    = 0.00002 ether; //4 zeroes
    uint256 public TOKEN_PRICE_MULT     = 0.00000000001 ether; //10 zeroes
    uint256 public TOKEN_MAX_BUY        = 4 ether; //max allowed eth in one buy transaction
    uint256 public SNAIL_REQ_REF        = 300; //number of snails for ref link to be active
	
    /* Variables */
    
    //Becomes true one time to start the game
    bool public gameStarted             = false;
    
    //Used to ensure a proper game start
    address public gameOwner;
    
    //SnailGod round, amount, timer
    uint256 public godRound             = 0;
    uint256 public godPot               = 0;
    uint256 public godTimer             = 0;
    
    //Current Pharaoh
    address public pharaoh;
    
    //Last time throne was claimed or pharaohReq was computed
    uint256 public lastClaim;
    
    //Snails required to become the Pharaoh
    uint256 public pharaohReq           = PHARAOH_REQ_START;
    
    //Total number of snail tokens
    uint256 public maxSnail             = 0;
    
    //Egg sell fund
    uint256 public frogPot              = 0;
    
    //Token sell fund
    uint256 public snailPot             = 0;
    
    //Current divs per snail
    uint256 public divsPerSnail         = 0;
    	
    /* Mappings */
    
    mapping (address => uint256) public hatcherySnail;
    mapping (address => uint256) public lastHatch;
    mapping (address => uint256) public playerEarnings;
    mapping (address => uint256) public claimedDivs;
	
    /* Functions */
    
    // ACTIONS
    
    // Constructor
    // Sets msg.sender as gameOwner to start the game properly
    
    constructor() public {
        gameOwner = msg.sender;
    }

    // StartGame
    // Initialize godTimer
    // Set pharaoh and lastPharaoh as gameOwner
    // Buy tokens for value of message
    
    function StartGame() public payable {
        require(gameStarted == false);
        require(msg.sender == gameOwner);
        
        godTimer = now + GOD_TIMER_START;
        godRound = 1;
        gameStarted = true;
        pharaoh = gameOwner;
        lastClaim = now;
        BuySnail(msg.sender);
    }
    
    // WithdrawEarnings
    // Sends all player ETH earnings to his wallet
    
    function WithdrawEarnings() public {
        require(playerEarnings[msg.sender] > 0);
        
        uint256 _amount = playerEarnings[msg.sender];
        playerEarnings[msg.sender] = 0;
        msg.sender.transfer(_amount);
        
        emit WithdrewEarnings(msg.sender, _amount);
    }
    
    // ClaimDivs
    // Sends player dividends to his playerEarnings
    // Adjusts claimable dividends
    
    function ClaimDivs() public {
        
        uint256 _playerDivs = ComputeMyDivs();
        
        if(_playerDivs > 0) {
            //Add new divs to claimed divs
            claimedDivs[msg.sender] = claimedDivs[msg.sender].add(_playerDivs);
            
            //Send divs to playerEarnings
            playerEarnings[msg.sender] = playerEarnings[msg.sender].add(_playerDivs);
            
            emit ClaimedDivs(msg.sender, _playerDivs);
        }
    }
    
    // BuySnail 
    
    function BuySnail(address _ref) public payable {
        require(gameStarted == true, "game hasn't started yet");
        require(tx.origin == msg.sender, "contracts not allowed");
        require(msg.value <= TOKEN_MAX_BUY, "maximum buy = 4 ETH");
        
        //Calculate price and resulting snails
        uint256 _snailsBought = ComputeBuy(msg.value);
        
        //Adjust player claimed divs
        claimedDivs[msg.sender] = claimedDivs[msg.sender].add(_snailsBought.mul(divsPerSnail));
        
        //Change maxSnail before new div calculation
        maxSnail = maxSnail.add(_snailsBought);
        
        //Divide incoming ETH
        PotSplit(msg.value, _ref, true);
        
        //Set last hatch to current timestamp
        lastHatch[msg.sender] = now;
        
        //Add player snails
        hatcherySnail[msg.sender] = hatcherySnail[msg.sender].add(_snailsBought);
        
        emit BoughtSnail(msg.sender, msg.value, _snailsBought);
    }
    
    // SellSnail
    
    function SellSnail(uint256 _tokensSold) public {
        require(gameStarted == true, "game hasn't started yet");
        require(hatcherySnail[msg.sender] >= _tokensSold, "not enough snails to sell");
        
        //Call ClaimDivs so ETH isn't blackholed
        ClaimDivs();

        //Check token price, sell price is half of current buy price
        uint256 _tokenSellPrice = ComputeTokenPrice();
        _tokenSellPrice = _tokenSellPrice.div(2);
        
        //Check maximum ETH that can be obtained = 10% of SnailPot
        uint256 _maxEth = snailPot.div(10);
        
        //Check maximum amount of tokens that can be sold
        uint256 _maxTokens = _maxEth.div(_tokenSellPrice);
        
        //Check if player tried to sell too many tokens
        if(_tokensSold > _maxTokens) {
            _tokensSold = _maxTokens;
        }
        
        //Calculate sell reward, tokens * price per token
        uint256 _sellReward = _tokensSold.mul(_tokenSellPrice);
        
        //Remove reserve ETH 
        snailPot = snailPot.sub(_sellReward);
        
        //Remove tokens
        hatcherySnail[msg.sender] = hatcherySnail[msg.sender].sub(_tokensSold);
        maxSnail = maxSnail.sub(_tokensSold);
        
        //Adjust player claimed divs
        claimedDivs[msg.sender] = claimedDivs[msg.sender].sub(divsPerSnail.mul(_tokensSold));
        
        //Give ETH to player 
        playerEarnings[msg.sender] = playerEarnings[msg.sender].add(_sellReward);
        
        emit SoldSnail(msg.sender, _sellReward, _tokensSold);
    }
    
    // HatchEgg
    // Turns player eggs into snails
    // Costs half the ETH of a normal buy
    
    function HatchEgg() public payable {
        require(gameStarted == true, "game hasn't started yet");
        require(msg.value > 0, "need ETH to hatch eggs");
        
        //Check how many eggs the ether sent can pay for
        uint256 _tokenPrice = ComputeTokenPrice().div(2);
        uint256 _maxHatch = msg.value.div(_tokenPrice);
        
        //Check number of eggs to hatch
        uint256 _newSnail = ComputeMyEggs(msg.sender);
        
        //Multiply by token price
        uint256 _snailPrice = _tokenPrice.mul(_newSnail);
        
        //Refund any extra ether
        uint256 _ethUsed = msg.value;
                
        if (msg.value > _snailPrice) {
            uint256 _refund = msg.value.sub(_snailPrice);
            playerEarnings[msg.sender] = playerEarnings[msg.sender].add(_refund);
            _ethUsed = _snailPrice;
        }
        
        //Adjust new snail amount if not enough ether 
        if (msg.value < _snailPrice) {
            _newSnail = _maxHatch;
        }
        
        //Adjust player divs
        claimedDivs[msg.sender] = claimedDivs[msg.sender].add(_newSnail.mul(divsPerSnail));
        
        //Change maxSnail before div calculation
        maxSnail = maxSnail.add(_newSnail);
        
        //Divide incoming ETH 
        PotSplit(_ethUsed, msg.sender, false);
        
        //Add new snails
        lastHatch[msg.sender] = now;
        hatcherySnail[msg.sender] = hatcherySnail[msg.sender].add(_newSnail);
        
        emit HatchedSnail(msg.sender, _ethUsed, _newSnail);
    }
    
    // PotSplit
    // Called on buy and hatch
    
    function PotSplit(uint256 _msgValue, address _ref, bool _buy) private {
        
        //On token buy, 50% of the ether goes to snailpot
        //On hatch, no ether goes to the snailpot
        uint256 _eth = _msgValue;
        
        if (_buy == true) {
            _eth = _msgValue.div(2);
            snailPot = snailPot.add(_eth);
        }
        
        //20% distributed as divs (40% on hatch)
        divsPerSnail = divsPerSnail.add(_eth.mul(2).div(5).div(maxSnail));
        
        //20% to FrogPot (40% on hatch)
        frogPot = frogPot.add(_eth.mul(2).div(5));
        
        //2% to Pharaoh (4% on hatch)
        playerEarnings[pharaoh] = playerEarnings[pharaoh].add(_eth.mul(2).div(50));
        
        //2% to SnailGod pot (4% on hatch)
        godPot = godPot.add(_eth.mul(2).div(50));
        
        //Check for referrals (300 snails required)
        //Give 6% to referrer if there is one
        //Else give 6% to SnailGod pot
        //Always give 12% to SnailGod pot on hatch
        if (_ref != msg.sender && hatcherySnail[_ref] >= SNAIL_REQ_REF) {
            playerEarnings[_ref] = playerEarnings[_ref].add(_eth.mul(6).div(50));
        } else {
            godPot = godPot.add(_eth.mul(6).div(50));
        }
    }
    
    // FeedEgg
    // Sacrifices the player's eggs to the FrogPot
    // Gives ETH in return
    
    function FeedEgg() public {
        require(gameStarted == true, "game hasn't started yet");
        
        //Check number of eggs to hatch
        uint256 _eggsUsed = ComputeMyEggs(msg.sender);
        
        //Remove eggs
        lastHatch[msg.sender] = now;
        
        //Calculate ETH earned
        uint256 _reward = _eggsUsed.mul(frogPot).div(maxSnail);
        frogPot = frogPot.sub(_reward);
        playerEarnings[msg.sender] = playerEarnings[msg.sender].add(_reward);
        
        emit FedFrogking(msg.sender, _reward, _eggsUsed);
    }
    
    // AscendGod
    // Distributes SnailGod pot to winner, restarts timer 
    
    function AscendGod() public {
		require(gameStarted == true, "game hasn't started yet");
        require(now >= godTimer, "pharaoh hasn't ascended yet");
        
        //Reset timer and start new round 
        godTimer = now + GOD_TIMER_START;
        pharaohReq = PHARAOH_REQ_START;
        godRound = godRound.add(1);
        
        //Calculate and give reward
        uint256 _godReward = godPot.div(2);
        godPot = godPot.sub(_godReward);
        playerEarnings[pharaoh] = playerEarnings[pharaoh].add(_godReward);
        
        emit Ascended(pharaoh, _godReward, godRound);
        
        //msg.sender becomes pharaoh 
        pharaoh = msg.sender;
    }

    // BecomePharaoh
    // Sacrifices snails to become the Pharaoh
    
    function BecomePharaoh(uint256 _snails) public {
        require(gameStarted == true, "game hasn't started yet");
        require(hatcherySnail[msg.sender] >= _snails, "not enough snails in hatchery");
        
        //Run end round function if round is over
        if(now >= godTimer) {
            AscendGod();
        }
        
        //Call ClaimDivs so ETH isn't blackholed
        ClaimDivs();
        
        //Check number of snails to remove from pharaohReq
        uint256 _snailsToRemove = ComputePharaohReq();
        
        //Save claim time to lower number of snails later
        lastClaim = now;
        
        //Adjust pharaohReq
        if(pharaohReq < _snailsToRemove){
            pharaohReq = PHARAOH_REQ_START;
        } else {
            pharaohReq = pharaohReq.sub(_snailsToRemove);
            if(pharaohReq < PHARAOH_REQ_START){
                pharaohReq = PHARAOH_REQ_START;
            }
        }
        
        //Make sure player fits requirement
        if(_snails >= pharaohReq) {
            
        //Remove snails
            maxSnail = maxSnail.sub(_snails);
            hatcherySnail[msg.sender] = hatcherySnail[msg.sender].sub(_snails);
            
        //Adjust msg.sender claimed dividends
            claimedDivs[msg.sender] = claimedDivs[msg.sender].sub(_snails.mul(divsPerSnail));
        
        //Add 8 minutes to timer
            godTimer = godTimer.add(GOD_TIMER_BOOST);
            
        //pharaohReq becomes the amount of snails sacrificed + 40
            pharaohReq = _snails.add(PHARAOH_REQ_START);

        //msg.sender becomes new Pharaoh
            pharaoh = msg.sender;
            
            emit BecamePharaoh(msg.sender, godRound);
        }
    }
    
    // fallback function
    // Distributes sent ETH as dividends
    
    function() public payable {
        divsPerSnail = divsPerSnail.add(msg.value.div(maxSnail));
        
        emit NewDivs(msg.value);
    }
    
    // VIEW
    
    // ComputePharaohReq
    // Returns number of snails to remove from pharaohReq
    // Snail requirement lowers by 1 every 12 seconds

    function ComputePharaohReq() public view returns(uint256) {
        uint256 _timeLeft = now.sub(lastClaim);
        uint256 _req = _timeLeft.div(GOD_TIMER_INTERVAL);
        return _req;
    }

    // ComputeTokenPrice
    // Returns ETH required to buy one snail
    // 1 snail = (T_P_FLOOR + (T_P_MULT * total amount of snails)) eth
    
    function ComputeTokenPrice() public view returns(uint256) {
        return TOKEN_PRICE_FLOOR.add(TOKEN_PRICE_MULT.mul(maxSnail));
    }
    
    // ComputeBuy
    // Returns snails bought for a given amount of ETH 
    
    function ComputeBuy(uint256 _ether) public view returns(uint256) {
        uint256 _tokenPrice = ComputeTokenPrice();
        return _ether.div(_tokenPrice);
    }
    
    // ComputeMyEggs
    // Returns eggs produced since last hatch or sacrifice
	// Egg amount can never be above current snail count
    
    function ComputeMyEggs(address adr) public view returns(uint256) {
        uint256 _eggs = now.sub(lastHatch[adr]);
        _eggs = _eggs.mul(hatcherySnail[adr]).div(TIME_TO_HATCH_1SNAIL);
        if (_eggs > hatcherySnail[adr]) {
            _eggs = hatcherySnail[adr];
        }
        return _eggs;
    }
    
    // ComputeMyDivs
    // Returns unclaimed divs for the player
    
    function ComputeMyDivs() public view returns(uint256) {
        //Calculate share of player
        uint256 _playerShare = divsPerSnail.mul(hatcherySnail[msg.sender]);
		
        //Subtract already claimed divs
    	_playerShare = _playerShare.sub(claimedDivs[msg.sender]);
        return _playerShare;
    }
    
    // GetMySnails
    // Returns player snails
    
    function GetMySnails() public view returns(uint256) {
        return hatcherySnail[msg.sender];
    }
    
    // GetMyEarnings
    // Returns player earnings
    
    function GetMyEarnings() public view returns(uint256) {
        return playerEarnings[msg.sender];
    }
    
    // GetContractBalance
    // Returns ETH in contract
    
    function GetContractBalance() public view returns (uint256) {
        return address(this).balance;
    }
    
}

library SafeMath {

  /**
  * @dev Multiplies two numbers, throws on overflow.
  */
  function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    if (a == 0) {
      return 0;
    }
    uint256 c = a * b;
    assert(c / a == b);
    return c;
  }

  /**
  * @dev Integer division of two numbers, truncating the quotient.
  */
  function div(uint256 a, uint256 b) internal pure returns (uint256) {
    // assert(b > 0); // Solidity automatically throws 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 Substracts two numbers, throws on overflow (i.e. if subtrahend is greater than minuend).
  */
  function sub(uint256 a, uint256 b) internal pure returns (uint256) {
    assert(b <= a);
    return a - b;
  }

  /**
  * @dev Adds two numbers, throws on overflow.
  */
  function add(uint256 a, uint256 b) internal pure returns (uint256) {
    uint256 c = a + b;
    assert(c >= a);
    return c;
  }
}
Документация
Идейные соображения высшего порядка, а также дальнейшее развитие различных форм деятельности представляет собой интересный эксперимент проверки модели развития. Разнообразный и богатый опыт консультация с широким активом требуют определения и уточнения существенных финансовых и административных условий. Задача организации, в особенности же новая модель организационной деятельности требуют от нас анализа системы обучения кадров, соответствует насущным потребностям. Повседневная практика показывает, что дальнейшее развитие различных форм деятельности обеспечивает широкому кругу (специалистов) участие в формировании новых предложений. Разнообразный и богатый опыт дальнейшее развитие различных форм деятельности влечет за собой процесс внедрения и модернизации новых предложений.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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