WEBSITE -
TWITTER -
TELEGRAM - DAPP STORE - DAPP RADAR - DAPP SOTD
EthXEth представляет собой инновационный инвестиционный протокол, основанный на интеллектуальных контрактах Ethereum, которые предоставляют различным анонимным сторонам возможность совершать доверительные транзакции и соглашения без какого-либо центрального органа или внешнего механизма управления.
Контракты делают все транзакции прослеживаемыми, прозрачными и необратимыми.
Как это работает? Наш проект работает на основе специального соглашения Ethereum, поэтому вам не нужно регистрировать свою личную учетную запись на веб-сайте. Все, что вам нужно, - отправить минимум 0,01 ETH на адрес смартфона Ethereum.
Умный контракт запоминает ваш кошелек и сумму депозита. После этого вы сможете отправить запрос на платеж в размере 3,25% от суммы депозита один раз в 5900 блоках, равный 24 часам.
Все средства распределяются и распределяются по схеме: 90% предназначены для платежей, 10% предназначены для продвижения по службе.
Доходность заработка Масштабируемость – ВХОД НА 24 ЧАСА:
* — Договорный баланс << 200 Ether: 3,25 %
* — Договорный баланс >= 200 Ether: 3.50 %
* — Договорный баланс >= 400 Ether: 3.75 %
* — Договорный баланс >= 600 Ether: 4.00 %
* — Договорный баланс >= 800 Ether: 4.25 %
* — Договорный баланс >= 1000 Ether: 4.50 %
Является ли договор безопасным?Интеллектуальный контракт загружается в блок-цепочку Ethereum с активированной функцией «отказ от владения». Это означает, что никто другой не имеет доступа к нему с возможностью влиять на его автономную работу.
Хотя код контракта открыт для всех, кто хочет проверить целостность контракта, его нельзя изменить или стереть. Создатель умного контракта не может иметь никакого влияния на процесс и не имеет возможности взять монеты.
Технология интеллектуального контракта показала человечеству способность строить доверительные отношения без привлечения третьей стороны. Это дает новые, ранее немыслимые возможности в области финансов. Наша автоматизированная модель распространения криптовалюты ETH зарегистрирована в смарт-контракте и загружена в блок-цепочку Ethereum с активированной функцией «отказ от владения», и теперь никто не может повлиять на ее вечный автономный код.
EthXEth Code: https://etherscan.io/address/0x064e2f3511f2399e86953de1acf54322bbdf9d2d#code
pragma solidity 0.4.25;
/**
*
* ETHXETH CRYPTOCURRENCY DISTRIBUTION PROTOCOL
*
* Web - ethxeth.ml
* Twitter - twitter.com/ethxeth0
* Telegram - t.me/ethxeth
*
* - GAIN PER 24 HOURS:
* -- Contract balance << 200 Ether: 3,25 %
* -- Contract balance >= 200 Ether: 3.50 %
* -- Contract balance >= 400 Ether: 3.75 %
* -- Contract balance >= 600 Ether: 4.00 %
* -- Contract balance >= 800 Ether: 4.25 %
* -- Contract balance >= 1000 Ether: 4.50 %
*
* - Life-long payments
* - The revolutionary reliability
* - Minimal contribution 0.01 eth
* - Currency and payment - ETH
* - Contribution allocation schemes:
* -- 90% payments
* -- 10% Marketing + Operating Expenses
*
* ---How to use:
* 1. Send from ETH wallet to the smart contract address
* 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.
* 3. Claim your profit by sending 0 ETH transaction (every day, every week, i don't care unless you're
* spending too much on GAS)
*
* 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.
*
* ---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 - EthXEth. Scroll down to find it.
*
*/
/**
* @title SafeMath
* @dev Math operations with safety checks that throw on error
*/
library SafeMath {
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a * b;
assert(a == 0 || c / a == b);
return c;
}
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;
}
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
assert(b <= a);
return a - b;
}
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
assert(c >= a);
return c;
}
}
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);
}
}
contract EthXEth{
using SafeMath for uint;
using Percent for Percent.percent;
// array containing information about beneficiaries
mapping (address => uint) public balances;
//array containing information about the time of payment
mapping (address => uint) public time;
//The marks of the balance on the contract after which the percentage of payments will change
uint step1 = 200;
uint step2 = 400;
uint step3 = 600;
uint step4 = 800;
uint step5 = 1000;
//the time through which dividends will be paid
uint dividendsTime = 1 days;
event NewInvestor(address indexed investor, uint deposit);
event PayOffDividends(address indexed investor, uint value);
event NewDeposit(address indexed investor, uint value);
uint public allDeposits;
uint public allPercents;
uint public allBeneficiaries;
uint public lastPayment;
uint public constant minInvesment = 10 finney;
address public commissionAddr = 0xead85d8ff7d6bc58e8f0fdf91999c35949375f1a;
Percent.percent private m_adminPercent = Percent.percent(10, 100);
/**
* The modifier checking the positive balance of the beneficiary
*/
modifier isIssetRecepient(){
require(balances[msg.sender] > 0, "Deposit not found");
_;
}
/**
* modifier checking the next payout time
*/
modifier timeCheck(){
require(now >= time[msg.sender].add(dividendsTime), "Too fast payout request. The time of payment has not yet come");
_;
}
function getDepositMultiplier()public view returns(uint){
uint percent = getPercent();
uint rate = balances[msg.sender].mul(percent).div(10000);
uint depositMultiplier = now.sub(time[msg.sender]).div(dividendsTime);
return(rate.mul(depositMultiplier));
}
function receivePayment()isIssetRecepient timeCheck private{
uint depositMultiplier = getDepositMultiplier();
time[msg.sender] = now;
msg.sender.transfer(depositMultiplier);
allPercents+=depositMultiplier;
lastPayment =now;
emit PayOffDividends(msg.sender, depositMultiplier);
}
/**
* @return bool
*/
function authorizationPayment()public view returns(bool){
if (balances[msg.sender] > 0 && now >= (time[msg.sender].add(dividendsTime))){
return (true);
}else{
return(false);
}
}
/**
* @return uint percent
*/
function getPercent() public view returns(uint){
uint contractBalance = address(this).balance;
uint balanceStep1 = step1.mul(1 ether);
uint balanceStep2 = step2.mul(1 ether);
uint balanceStep3 = step3.mul(1 ether);
uint balanceStep4 = step4.mul(1 ether);
uint balanceStep5 = step5.mul(1 ether);
if(contractBalance < balanceStep1){
return(325);
}
if(contractBalance >= balanceStep1 && contractBalance < balanceStep2){
return(350);
}
if(contractBalance >= balanceStep2 && contractBalance < balanceStep3){
return(375);
}
if(contractBalance >= balanceStep3 && contractBalance < balanceStep4){
return(400);
}
if(contractBalance >= balanceStep4 && contractBalance < balanceStep5){
return(425);
}
if(contractBalance >= balanceStep5){
return(450);
}
}
function createDeposit() private{
if(msg.value > 0){
require(msg.value >= minInvesment, "msg.value must be >= minInvesment");
if (balances[msg.sender] == 0){
emit NewInvestor(msg.sender, msg.value);
allBeneficiaries+=1;
}
// commission
commissionAddr.transfer(m_adminPercent.mul(msg.value));
if(getDepositMultiplier() > 0 && now >= time[msg.sender].add(dividendsTime) ){
receivePayment();
}
balances[msg.sender] = balances[msg.sender].add(msg.value);
time[msg.sender] = now;
allDeposits+=msg.value;
emit NewDeposit(msg.sender, msg.value);
}else{
receivePayment();
}
}
/**
* function that is launched when transferring money to a contract
*/
function() external payable{
createDeposit();
}
}