Transaction Hash:
Block:
13841320 at Dec-20-2021 09:49:52 AM +UTC
Transaction Fee:
0.005158788080531269 ETH
$9.51
Gas Used:
112,823 Gas / 45.724613603 Gwei
Emitted Events:
250 |
Polkazeck.Transfer( from=[Sender] 0x68b22215ff74e3606bd5e6c1de8c2d68180c85f7, to=0x0000000000000000000000000000000000000000, value=2784200000000000000000 )
|
251 |
Polkazeck.Transfer( from=[Sender] 0x68b22215ff74e3606bd5e6c1de8c2d68180c85f7, to=0xd11616e66b128c0b756b91cC13466deFaae67D07, value=136425800000000000000000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x1aD91ee0...dA6B45836
Miner
| (Hiveon Pool) | 8,582.355128800054651541 Eth | 8,582.355303675704651541 Eth | 0.00017487565 | |
0x68b22215...8180c85F7 | (BitMart 2) |
0.176175161875198018 Eth
Nonce: 633578
|
0.171016373794666749 Eth
Nonce: 633579
| 0.005158788080531269 | |
0xeDB7b784...4Ce82Ba32 |
Execution Trace
Polkazeck.transfer( recipient=0xd11616e66b128c0b756b91cC13466deFaae67D07, amount=139210000000000000000000 ) => ( True )
transfer[Polkazeck (ln:227)]
_transfer[Polkazeck (ln:228)]
_transferFromExcluded[Polkazeck (ln:326)]
_getValues[Polkazeck (ln:358)]
_getRate[Polkazeck (ln:385)]
_getCurrentSupply[Polkazeck (ln:406)]
div[Polkazeck (ln:407)]
sub[Polkazeck (ln:359)]
sub[Polkazeck (ln:360)]
add[Polkazeck (ln:361)]
_burn[Polkazeck (ln:362)]
sub[Polkazeck (ln:423)]
Transfer[Polkazeck (ln:424)]
_reflectFee[Polkazeck (ln:363)]
Transfer[Polkazeck (ln:364)]
_transferToExcluded[Polkazeck (ln:328)]
_getValues[Polkazeck (ln:348)]
_getRate[Polkazeck (ln:385)]
_getCurrentSupply[Polkazeck (ln:406)]
div[Polkazeck (ln:407)]
sub[Polkazeck (ln:349)]
add[Polkazeck (ln:350)]
add[Polkazeck (ln:351)]
_burn[Polkazeck (ln:352)]
sub[Polkazeck (ln:423)]
Transfer[Polkazeck (ln:424)]
_reflectFee[Polkazeck (ln:353)]
Transfer[Polkazeck (ln:354)]
_transferStandard[Polkazeck (ln:330)]
_getValues[Polkazeck (ln:339)]
_getRate[Polkazeck (ln:385)]
_getCurrentSupply[Polkazeck (ln:406)]
div[Polkazeck (ln:407)]
sub[Polkazeck (ln:340)]
add[Polkazeck (ln:341)]
_burn[Polkazeck (ln:342)]
sub[Polkazeck (ln:423)]
Transfer[Polkazeck (ln:424)]
_reflectFee[Polkazeck (ln:343)]
Transfer[Polkazeck (ln:344)]
_transferBothExcluded[Polkazeck (ln:332)]
_getValues[Polkazeck (ln:368)]
_getRate[Polkazeck (ln:385)]
_getCurrentSupply[Polkazeck (ln:406)]
div[Polkazeck (ln:407)]
sub[Polkazeck (ln:369)]
sub[Polkazeck (ln:370)]
add[Polkazeck (ln:371)]
add[Polkazeck (ln:372)]
_burn[Polkazeck (ln:373)]
sub[Polkazeck (ln:423)]
Transfer[Polkazeck (ln:424)]
_reflectFee[Polkazeck (ln:374)]
Transfer[Polkazeck (ln:375)]
_transferStandard[Polkazeck (ln:334)]
_getValues[Polkazeck (ln:339)]
_getRate[Polkazeck (ln:385)]
_getCurrentSupply[Polkazeck (ln:406)]
div[Polkazeck (ln:407)]
sub[Polkazeck (ln:340)]
add[Polkazeck (ln:341)]
_burn[Polkazeck (ln:342)]
sub[Polkazeck (ln:423)]
Transfer[Polkazeck (ln:424)]
_reflectFee[Polkazeck (ln:343)]
Transfer[Polkazeck (ln:344)]
_msgSender[Polkazeck (ln:228)]
// SPDX-License-Identifier: MIT pragma solidity ^0.6.2; abstract contract Context { function _msgSender() internal view virtual returns (address payable) { return msg.sender; } function _msgData() internal view virtual returns (bytes memory) { this; return msg.data; } } interface IERC20 { function totalSupply() external view returns (uint256); function balanceOf(address account) external view returns (uint256); function transfer(address recipient, uint256 amount) external returns (bool); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 amount) external returns (bool); function transferFrom(address sender, address recipient, uint256 amount) 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 add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); uint256 c = a / b; return c; } function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, "SafeMath: modulo by zero"); } function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } library Address { function isContract(address account) internal view returns (bool) { bytes32 codehash; bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470; // solhint-disable-next-line no-inline-assembly assembly { codehash := extcodehash(account) } return (codehash != accountHash && codehash != 0x0); } function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); // solhint-disable-next-line avoid-low-level-calls, avoid-call-value (bool success, ) = recipient.call{ value: amount }(""); require(success, "Address: unable to send value, recipient may have reverted"); } function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { return _functionCallWithValue(target, data, 0, errorMessage); } function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); return _functionCallWithValue(target, data, value, errorMessage); } function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) { require(isContract(target), "Address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: weiValue }(data); if (success) { return returndata; } else { if (returndata.length > 0) { // solhint-disable-next-line no-inline-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } } contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); constructor () internal { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } function owner() public view returns (address) { return _owner; } modifier onlyOwner() { require(_owner == _msgSender(), "Ownable: caller is not the owner"); _; } function renounceOwnership() public virtual onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } contract Polkazeck is Context, IERC20, Ownable { using SafeMath for uint256; using Address for address; mapping (address => uint256) private _rOwned; mapping (address => uint256) private _tOwned; mapping (address => mapping (address => uint256)) private _allowances; mapping (address => bool) private _isExcluded; address[] private _excluded; uint256 private constant MAX = ~uint256(0); uint256 private _tTotal = 162 * 10**6 * 10**18; uint256 private _rTotal = (MAX - (MAX % _tTotal)); uint256 private _tFeeTotal; uint256 public _taxFee = 30; uint256 public _burnFee = 25; string private _name = "Polkazeck"; string private _symbol = "ZCK"; uint8 private _decimals = 18; address public beneficiary = address(0xd3F9c90041Aa7B3306f5bE5a2Ab6441620190722); uint256 private tMarketing = _tTotal.mul(20).div(100); uint256 private marketingClaimCount; uint256 private tTeam = _tTotal.mul(10).div(100); uint256 private teamClaimCount; uint256 private claimInterval = 7884000; uint8 private claimPercent = 25; uint256 private marketingClaimNext; uint256 private teamClaimNext; uint256 private tReserve = _tTotal.mul(5).div(100); uint256 private reserveClaimAt; uint256 private tEcosystem = _tTotal.mul(175).div(1000); uint256 private ecosystemClaimAt; constructor () public { uint256 time = block.timestamp; marketingClaimNext = time.add(claimInterval); teamClaimNext = time.add(63070000); reserveClaimAt = time.add(31540000); ecosystemClaimAt = time.add(31540000); uint256 tLockedTotal = tMarketing.add(tTeam).add(tReserve).add(tEcosystem); uint256 rLockedTotal = reflectionFromToken(tLockedTotal, false); _rOwned[beneficiary] = _rTotal.sub(rLockedTotal); _rOwned[address(this)] = rLockedTotal; emit Transfer(address(0), beneficiary, _tTotal.sub(tLockedTotal)); emit Transfer(address(0), address(this), tLockedTotal); } function name() public view returns (string memory) { return _name; } function symbol() public view returns (string memory) { return _symbol; } function decimals() public view returns (uint8) { return _decimals; } function totalSupply() public view override returns (uint256) { return _tTotal; } function balanceOf(address account) public view override returns (uint256) { if (_isExcluded[account]) return _tOwned[account]; return tokenFromReflection(_rOwned[account]); } function transfer(address recipient, uint256 amount) public override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } function allowance(address owner, address spender) public view override returns (uint256) { return _allowances[owner][spender]; } function approve(address spender, uint256 amount) public override returns (bool) { _approve(_msgSender(), spender, amount); return true; } function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) { _transfer(sender, recipient, amount); _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance")); return true; } function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue)); return true; } function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero")); return true; } function isExcluded(address account) public view returns (bool) { return _isExcluded[account]; } function totalFees() public view returns (uint256) { return _tFeeTotal; } function reflect(uint256 tAmount) public { address sender = _msgSender(); require(!_isExcluded[sender], "Excluded addresses cannot call this function"); (uint256 rAmount,,,,,) = _getValues(tAmount); _rOwned[sender] = _rOwned[sender].sub(rAmount); _rTotal = _rTotal.sub(rAmount); _tFeeTotal = _tFeeTotal.add(tAmount); } function reflectionFromToken(uint256 tAmount, bool deductTransferFee) public view returns(uint256) { require(tAmount <= _tTotal, "Amount must be less than supply"); if (!deductTransferFee) { (uint256 rAmount,,,,,) = _getValues(tAmount); return rAmount; } else { (,uint256 rTransferAmount,,,,) = _getValues(tAmount); return rTransferAmount; } } function tokenFromReflection(uint256 rAmount) public view returns(uint256) { require(rAmount <= _rTotal, "Amount must be less than total reflections"); uint256 currentRate = _getRate(); return rAmount.div(currentRate); } function excludeAccount(address account) external onlyOwner() { require(!_isExcluded[account], "Account is already excluded"); if(_rOwned[account] > 0) { _tOwned[account] = tokenFromReflection(_rOwned[account]); } _isExcluded[account] = true; _excluded.push(account); } function includeAccount(address account) external onlyOwner() { require(_isExcluded[account], "Account is already excluded"); for (uint256 i = 0; i < _excluded.length; i++) { if (_excluded[i] == account) { _excluded[i] = _excluded[_excluded.length - 1]; _tOwned[account] = 0; _isExcluded[account] = false; _excluded.pop(); break; } } } function _approve(address owner, address spender, uint256 amount) private { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } function _transfer(address sender, address recipient, uint256 amount) private { require(sender != address(0), "ERC20: transfer from the zero address"); require(recipient != address(0), "ERC20: transfer to the zero address"); require(amount > 0, "Transfer amount must be greater than zero"); if (_isExcluded[sender] && !_isExcluded[recipient]) { _transferFromExcluded(sender, recipient, amount); } else if (!_isExcluded[sender] && _isExcluded[recipient]) { _transferToExcluded(sender, recipient, amount); } else if (!_isExcluded[sender] && !_isExcluded[recipient]) { _transferStandard(sender, recipient, amount); } else if (_isExcluded[sender] && _isExcluded[recipient]) { _transferBothExcluded(sender, recipient, amount); } else { _transferStandard(sender, recipient, amount); } } function _transferStandard(address sender, address recipient, uint256 tAmount) private { (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn) = _getValues(tAmount); _rOwned[sender] = _rOwned[sender].sub(rAmount); _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount); _burn(sender, tBurn); _reflectFee(rFee, tFee); emit Transfer(sender, recipient, tTransferAmount); } function _transferToExcluded(address sender, address recipient, uint256 tAmount) private { (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn) = _getValues(tAmount); _rOwned[sender] = _rOwned[sender].sub(rAmount); _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount); _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount); _burn(sender, tBurn); _reflectFee(rFee, tFee); emit Transfer(sender, recipient, tTransferAmount); } function _transferFromExcluded(address sender, address recipient, uint256 tAmount) private { (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn) = _getValues(tAmount); _tOwned[sender] = _tOwned[sender].sub(tAmount); _rOwned[sender] = _rOwned[sender].sub(rAmount); _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount); _burn(sender, tBurn); _reflectFee(rFee, tFee); emit Transfer(sender, recipient, tTransferAmount); } function _transferBothExcluded(address sender, address recipient, uint256 tAmount) private { (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn) = _getValues(tAmount); _tOwned[sender] = _tOwned[sender].sub(tAmount); _rOwned[sender] = _rOwned[sender].sub(rAmount); _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount); _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount); _burn(sender, tBurn); _reflectFee(rFee, tFee); emit Transfer(sender, recipient, tTransferAmount); } function _reflectFee(uint256 rFee, uint256 tFee) private { _rTotal = _rTotal.sub(rFee); _tFeeTotal = _tFeeTotal.add(tFee); } function _getValues(uint256 tAmount) private view returns (uint256, uint256, uint256, uint256, uint256, uint256) { (uint256 tTransferAmount, uint256 tFee, uint256 tBurn) = _getTValues(tAmount); uint256 currentRate = _getRate(); (uint256 rAmount, uint256 rTransferAmount, uint256 rFee) = _getRValues(tAmount, tFee, currentRate, tBurn); return (rAmount, rTransferAmount, rFee, tTransferAmount, tFee, tBurn); } function _getTValues(uint256 tAmount) private view returns (uint256, uint256, uint256) { uint256 tFee = tAmount.mul(_taxFee).div(1000); uint256 tBurn = tAmount.mul(_burnFee).div(1000); uint256 tTransferAmount = tAmount.sub(tFee).sub(tBurn); return (tTransferAmount, tFee, tBurn); } function _getRValues(uint256 tAmount, uint256 tFee, uint256 currentRate, uint256 tBurn) private pure returns (uint256, uint256, uint256) { uint256 rAmount = tAmount.mul(currentRate); uint256 rFee = tFee.mul(currentRate); uint256 rBurn = tBurn.mul(currentRate); uint256 rTransferAmount = rAmount.sub(rFee).sub(rBurn); return (rAmount, rTransferAmount, rFee); } function _getRate() private view returns(uint256) { (uint256 rSupply, uint256 tSupply) = _getCurrentSupply(); return rSupply.div(tSupply); } function _getCurrentSupply() private view returns(uint256, uint256) { uint256 rSupply = _rTotal; uint256 tSupply = _tTotal; for (uint256 i = 0; i < _excluded.length; i++) { if (_rOwned[_excluded[i]] > rSupply || _tOwned[_excluded[i]] > tSupply) return (_rTotal, _tTotal); rSupply = rSupply.sub(_rOwned[_excluded[i]]); tSupply = tSupply.sub(_tOwned[_excluded[i]]); } if (rSupply < _rTotal.div(_tTotal)) return (_rTotal, _tTotal); return (rSupply, tSupply); } function _burn(address sender, uint256 tBurn) private { _tTotal = _tTotal.sub(tBurn); emit Transfer(sender, address(0), tBurn); } function setTaxFeePercent(uint256 taxFee) external onlyOwner() { _taxFee = taxFee.mul(10); } function setBurnFeePercent(uint256 burnFee) external onlyOwner() { _burnFee = burnFee.mul(10); } function releaseMarketing() public { require(block.timestamp >= marketingClaimNext, "Too early"); require(marketingClaimCount < 4, "Claim completed"); marketingClaimNext = marketingClaimNext.add(claimInterval); marketingClaimCount = marketingClaimCount.add(1); uint256 tAmount = tMarketing.mul(claimPercent).div(100); uint256 rAmount = reflectionFromToken(tAmount, false); _releaseLocked(address(this), beneficiary, rAmount, tAmount); } function releaseTeam() public { require(block.timestamp >= teamClaimNext, "Too early"); require(teamClaimCount < 4, "Claim completed"); teamClaimNext = teamClaimNext.add(claimInterval); teamClaimCount = teamClaimCount.add(1); uint256 tAmount = tTeam.mul(claimPercent).div(100); uint256 rAmount = reflectionFromToken(tAmount, false); _releaseLocked(address(this), beneficiary, rAmount, tAmount); } function releaseReserve() public { require(tReserve > 0, "Already claimed"); require(block.timestamp >= reserveClaimAt, "Too early"); _releaseLocked(address(this), beneficiary, reflectionFromToken(tReserve, false), tReserve); tReserve = 0; } function releaseEcosystem() public { require(tEcosystem > 0, "Already claimed"); require(block.timestamp >= ecosystemClaimAt, "Too early"); _releaseLocked(address(this), beneficiary, reflectionFromToken(tEcosystem, false), tEcosystem); tEcosystem = 0; } function _releaseLocked(address sender, address recipient, uint256 rAmount, uint256 tAmount) private { _rOwned[sender] = _rOwned[sender].sub(rAmount); _rOwned[recipient] = _rOwned[recipient].add(rAmount); emit Transfer(sender, recipient, tAmount); } }