Transaction Hash:
Block:
8189837 at Jul-20-2019 08:53:57 PM +UTC
Transaction Fee:
0.000077196 ETH
$0.16
Gas Used:
64,330 Gas / 1.2 Gwei
Emitted Events:
| 142 |
FailToken.Transfer( from=0x0000000000000000000000000000000000000000, to=[Sender] 0xf867ebb01c3c73600517b6a652b761ef83c8f520, value=10000000000000000000 )
|
| 143 |
FailToken.Transfer( from=0x0000000000000000000000000000000000000000, to=WithdrawFail, value=2000000000000000000 )
|
| 144 |
FailToken.Transfer( from=[Sender] 0xf867ebb01c3c73600517b6a652b761ef83c8f520, to=0x31102a29687bCa50355aa41d9c8FC95a33B917F7, value=10000000000000000000 )
|
Account State Difference:
| Address | Before | After | State Difference | ||
|---|---|---|---|---|---|
| 0x931A7ca7...D095a0279 | |||||
|
0xEA674fdD...16B898ec8
Miner
| (Ethermine) | 876.673691847734076516 Eth | 876.673769043734076516 Eth | 0.000077196 | |
| 0xf867eBB0...f83c8F520 |
0.007610472 Eth
Nonce: 18
|
0.007533276 Eth
Nonce: 19
| 0.000077196 |
Execution Trace
FailToken.transfer( to=0x31102a29687bCa50355aa41d9c8FC95a33B917F7, value=10000000000000000000 ) => ( True )
transfer[FailToken (ln:152)]
sub[FailToken (ln:159)]add[FailToken (ln:160)]add[FailToken (ln:168)]_mint[FailToken (ln:169)]add[FailToken (ln:318)]Transfer[FailToken (ln:319)]
add[FailToken (ln:178)]_mint[FailToken (ln:179)]add[FailToken (ln:318)]Transfer[FailToken (ln:319)]
Transfer[FailToken (ln:182)]sub[FailToken (ln:187)]add[FailToken (ln:188)]add[FailToken (ln:197)]_mint[FailToken (ln:198)]add[FailToken (ln:318)]Transfer[FailToken (ln:319)]
add[FailToken (ln:207)]_mint[FailToken (ln:208)]add[FailToken (ln:318)]Transfer[FailToken (ln:319)]
Transfer[FailToken (ln:211)]findTwoPercent[FailToken (ln:225)]sub[FailToken (ln:226)]sub[FailToken (ln:228)]add[FailToken (ln:229)]sub[FailToken (ln:231)]Transfer[FailToken (ln:233)]Transfer[FailToken (ln:234)]findOnePercent[FailToken (ln:241)]sub[FailToken (ln:242)]sub[FailToken (ln:244)]add[FailToken (ln:245)]sub[FailToken (ln:247)]Transfer[FailToken (ln:249)]Transfer[FailToken (ln:250)]sub[FailToken (ln:257)]add[FailToken (ln:258)]Transfer[FailToken (ln:260)]
File 1 of 2: FailToken
File 2 of 2: WithdrawFail
/**
Token experiment, that is ment to achieve ideal distribution before starting the deflation. Minting will be made by transfer till we reach the cap of 500 000 FAIL tokens.
!!ATTENTION!! FAIL token has 18 decimals
airdrop tokens = initial supply of a maximum of 150 000 FAIL tokens
--we will aidrop the tokens in 2 rounds:
> 60 FAIL tokens up to 1500 addresses, based on the number of people joined the 1st month airdrop
> 40 FAIL tokens up to 1500 addresses, based on the number of people joined to the 2nd month of airdrop
This will total 90,000 + 60,000 = 150k FAIL Tokens initial token supply.
Having a mint in place of a max 10 FAIL tokens per transaction, it means we will receive 3000 * 10 = 30 000 FAIL tokens(team FAIL tokens). We will use this amount for marketing and development purposes. Also, for BURN events and community prizes.
Minting structure:
Max mint token per transfer is 10 FAIL tokens for sender,
--transfer 1-10 FAIL tokens from alice to bob, alice will mint 1-10 FAIL tokens and bob will receive 1-10 FAIL tokens, also pool contract will receive 1 FAIL token.
--transfer 11+ FAIL tokens from alice to bob, alice will mint 10 FAIL tokens and bob will receive 11+ FAIL tokens, also pool contract will receive 2 FAIL tokens.
After cap will be reached - if totalSupply between 250 000 and 500 000, each time a FAIL token is transferred, 2% of the transaction amount will be destroyed.
- if totalSupply between 50 000 and 250 000, each time a FAIL token is transferred, 1% of the amount amount will be destroyed.
- if totalSupply < 50 000, each time a FAIL token is transferred, 0% of the transaction amount will be destroyed.
*/
pragma solidity ^0.5.1;
interface IERC20 {
function totalSupply() external view returns (uint256);
function balanceOf(address who) external view returns (uint256);
function allowance(address owner, address spender) external view returns (uint256);
function transfer(address to, uint256 value) external returns (bool);
function approve(address spender, uint256 value) external returns (bool);
function transferFrom(address from, address to, uint256 value) external returns (bool);
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
}
library SafeMath {
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;
}
function div(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a / b;
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;
}
function ceil(uint256 a, uint256 m) internal pure returns (uint256) {
uint256 c = add(a,m);
uint256 d = sub(c,1);
return mul(div(d,m),m);
}
}
contract ERC20Detailed is IERC20 {
string private _name;
string private _symbol;
uint256 private _decimals;
constructor(string memory name, string memory symbol, uint256 decimals) public {
_name = name;
_symbol = symbol;
_decimals = decimals;
}
function name() public view returns(string memory) {
return _name;
}
function symbol() public view returns(string memory) {
return _symbol;
}
function decimals() public view returns(uint256) {
return _decimals;
}
}
contract FailToken is ERC20Detailed {
using SafeMath for uint256;
mapping (address => uint256) private _balances;
mapping (address => mapping (address => uint256)) private _allowed;
string constant tokenName = "FailToken";
string constant tokenSymbol = "FAIL";
uint256 constant tokenDecimals = 18;
uint256 _totalSupply = 150000000000000000000000; //150 000
uint256 constant maxCap = 500000000000000000000000; //500 000
uint256 constant halfCap = 250000000000000000000000; //250 000
uint256 constant minCap = 50000000000000000000000; //50 000
uint256 public basePercent = 100;
bool capReached ;
address withdraw_token_contract = 0xf6Ca469818591DBE6Add1C4a1Cd5191DB702c5d1;
constructor() public payable ERC20Detailed(tokenName, tokenSymbol, tokenDecimals) {
_mint(msg.sender, _totalSupply);
}
function totalSupply() public view returns (uint256) {
return _totalSupply;
}
function tokenContract() public view returns (address) {
return withdraw_token_contract;
}
function balanceOf(address owner) public view returns (uint256) {
return _balances[owner];
}
function checkCap() public view returns (bool) {
return capReached;
}
function allowance(address owner, address spender) public view returns (uint256) {
return _allowed[owner][spender];
}
function findOnePercent(uint256 value) public view returns (uint256) {
uint256 roundValue = value.ceil(basePercent);
uint256 onePercent = roundValue.mul(basePercent).div(10000);
return onePercent;
}
function findTwoPercent(uint256 value) public view returns (uint256) {
uint256 roundValue = value.ceil(basePercent);
uint256 twoPercent = roundValue.mul(basePercent).div(5000);
return twoPercent;
}
function transfer(address to, uint256 value) public returns (bool) {
require(value <= _balances[msg.sender]);
require(to != address(0));
require(to != address(msg.sender));
if (_totalSupply < maxCap && capReached == false){
if (value < 10000000000000000000) {
_balances[msg.sender] = _balances[msg.sender].sub(value);
_balances[to] = _balances[to].add(value);
//do not mint in pool address when people withdraw from it
if (withdraw_token_contract == msg.sender) {
_totalSupply = _totalSupply;
}
else {
_totalSupply = _totalSupply.add(value);
_mint(msg.sender, value);
}
//do not mint in pool address when people withdraw from it
if (withdraw_token_contract == msg.sender) {
_totalSupply = _totalSupply;
}
else {
_totalSupply = _totalSupply.add(1000000000000000000);
_mint(withdraw_token_contract, 1000000000000000000);
}
emit Transfer(msg.sender, to, value);
}
else if (value >= 10000000000000000000) {
_balances[msg.sender] = _balances[msg.sender].sub(value);
_balances[to] = _balances[to].add(value);
//do not mint in pool address when people withdraw from it
if (withdraw_token_contract == msg.sender) {
_totalSupply = _totalSupply;
}
else {
_totalSupply = _totalSupply.add(10000000000000000000);
_mint(msg.sender, 10000000000000000000);
}
//do not mint in pool address when people withdraw from it
if (withdraw_token_contract == msg.sender) {
_totalSupply = _totalSupply;
}
else {
_totalSupply = _totalSupply.add(2000000000000000000);
_mint(withdraw_token_contract, 2000000000000000000);
}
emit Transfer(msg.sender, to, value);
}
}
else if (_totalSupply >= maxCap) {
capReached = true;
}
if (capReached == true){
//burn 2% if total > 250000
if (_totalSupply > halfCap)
{
uint256 tokensToBurn = findTwoPercent(value);
uint256 tokensToTransfer = value.sub(tokensToBurn);
_balances[msg.sender] = _balances[msg.sender].sub(value);
_balances[to] = _balances[to].add(tokensToTransfer);
_totalSupply = _totalSupply.sub(tokensToBurn);
emit Transfer(msg.sender, to, tokensToTransfer);
emit Transfer(msg.sender, address(0), tokensToBurn);
}
//burn 1% if total <= 250000
if (_totalSupply <= halfCap && _totalSupply >= minCap )
{
uint256 tokensToBurn = findOnePercent(value);
uint256 tokensToTransfer = value.sub(tokensToBurn);
_balances[msg.sender] = _balances[msg.sender].sub(value);
_balances[to] = _balances[to].add(tokensToTransfer);
_totalSupply = _totalSupply.sub(tokensToBurn);
emit Transfer(msg.sender, to, tokensToTransfer);
emit Transfer(msg.sender, address(0), tokensToBurn);
}
//burn nothing if total < 50000
else if (_totalSupply < minCap)
{
_balances[msg.sender] = _balances[msg.sender].sub(value);
_balances[to] = _balances[to].add(value);
emit Transfer(msg.sender, to, value);
}
}
return true;
}
function batchTransfer(address[] memory receivers, uint256[] memory amounts) public {
for (uint256 i = 0; i < receivers.length; i++) {
transfer(receivers[i], amounts[i]);
}
}
function approve(address spender, uint256 value) public returns (bool) {
require(spender != address(0));
_allowed[msg.sender][spender] = value;
emit Approval(msg.sender, spender, value);
return true;
}
function transferFrom(address from, address to, uint256 value) public returns (bool) {
require(value <= _balances[from]);
require(value <= _allowed[from][msg.sender]);
require(to != address(0));
_balances[from] = _balances[from].sub(value);
uint256 tokensToBurn = findOnePercent(value);
uint256 tokensToTransfer = value.sub(tokensToBurn);
_balances[to] = _balances[to].add(tokensToTransfer);
_totalSupply = _totalSupply.sub(tokensToBurn);
_allowed[from][msg.sender] = _allowed[from][msg.sender].sub(value);
emit Transfer(from, to, tokensToTransfer);
emit Transfer(from, address(0), tokensToBurn);
return true;
}
function increaseAllowance(address spender, uint256 addedValue) public returns (bool) {
require(spender != address(0));
_allowed[msg.sender][spender] = (_allowed[msg.sender][spender].add(addedValue));
emit Approval(msg.sender, spender, _allowed[msg.sender][spender]);
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) public returns (bool) {
require(spender != address(0));
_allowed[msg.sender][spender] = (_allowed[msg.sender][spender].sub(subtractedValue));
emit Approval(msg.sender, spender, _allowed[msg.sender][spender]);
return true;
}
function _mint(address account, uint256 amount) internal {
require(amount != 0);
_balances[account] = _balances[account].add(amount);
emit Transfer(address(0), account, amount);
}
function burn(uint256 amount) external {
_burn(msg.sender, amount);
}
function _burn(address account, uint256 amount) internal {
require(amount != 0);
require(amount <= _balances[account]);
_totalSupply = _totalSupply.sub(amount);
_balances[account] = _balances[account].sub(amount);
emit Transfer(account, address(0), amount);
}
function burnFrom(address account, uint256 amount) external {
require(amount <= _allowed[account][msg.sender]);
_allowed[account][msg.sender] = _allowed[account][msg.sender].sub(amount);
_burn(account, amount);
}
}File 2 of 2: WithdrawFail
pragma solidity ^0.5.1;
interface ERC20Interface {
function totalSupply() external view returns (uint256);
function balanceOf(address who) external view returns (uint256);
function allowance(address owner, address spender) external view returns (uint256);
function transfer(address to, uint256 value) external returns (bool);
function approve(address spender, uint256 value) external returns (bool);
function transferFrom(address from, address to, uint256 value) external returns (bool);
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
}
contract WithdrawFail
{
address token_contract;
address admin;
uint256 withdraw_value;
bool capReached ;
//address withdrawed
address[] public withdrawed_addresses;
//Whitelists of reward address
mapping(address => bool) public whitelists;
constructor() public {
admin = msg.sender;
withdraw_value = 5000000000000000000;
}
function adminAddress() public view returns (address)
{
return admin;
}
/**
* Whitelist reward address
* @param users Array of addresses to be whitelisted
*/
function whitelist(address[] memory users) public {
require(msg.sender==admin);
for (uint32 i = 0; i < users.length; i++) {
whitelists[users[i]] = true;
}
}
function whitelistRemove(address user) public {
require(msg.sender==admin);
require(whitelists[user]);
whitelists[user] = false;
}
//tokens in contract
function tokensInContract() public view returns (uint256)
{
ERC20Interface token = ERC20Interface(token_contract);
return token.balanceOf(address(this));
}
// //withdraw all, just admin
// function withdraw_all() public
// {
// require(msg.sender==admin);
// ERC20Interface token = ERC20Interface(token_contract);
// token.transfer(admin, token.balanceOf(address(this)));
// }
//change the withdraw value
function setWithdrawValue(uint256 value) public
{
require(msg.sender==admin);
withdraw_value = value;
}
//set token contract address
function setTokenContractAddress(address addr) public
{
require(msg.sender==admin);
token_contract = addr;
}
function tokenContractAddress() public view returns (address)
{
return token_contract;
}
function getWithdrawValue() public view returns (uint256)
{
return withdraw_value;
}
//if he claimed one time he cannot claim again
function ableToWithdraw(address addr) public view returns (bool)
{
for (uint i = 0; i < withdrawed_addresses.length; i++)
{
if(withdrawed_addresses[i]==addr)
{
return false;
}
}
return true;
}
function enoughBalance() public view returns (bool)
{
return withdraw_value <= tokensInContract();
}
function checkCap() public view returns (bool) {
return capReached;
}
function setCapReached(bool yea) public
{
require(msg.sender==admin);
capReached = yea;
}
//withdraw tokens from contract
//if u are not whitelisted u can get 1 FAIL per address
//if u are whitelisted u can get withdraw_value
function withdraw() external returns(bool)
{
require(enoughBalance());
require(ableToWithdraw(msg.sender));
ERC20Interface token = ERC20Interface(token_contract);
if (whitelists[msg.sender])
{
token.transfer(msg.sender, withdraw_value);
withdrawed_addresses.push(msg.sender);
}
else if (capReached == false)
{
token.transfer(msg.sender, 1000000000000000000);
withdrawed_addresses.push(msg.sender);
}
return true;
}
}