Closed yuriy77k closed 5 years ago
Auditing time 1 day
@MrCrambo assigned
Auditing time: 2 days.
@danbogd assigned
My report is finished.
Estimated audit time: 1 day
@RideSolo assigned
Twogap Token smart contract security audit report performed by Callisto Security Audit Department
Symbol : TGT
Name : Twogap Token
Total supply: 210,000,000,000
Decimals : 18
Standard : ERC20
In total, 3 issues were reported including:
No critical security issues were found.
If an address receives bounties twice or more the bounties value of the address is not accumulated, meaning that the vesting logic implemented in transfer function will not lock the bounties allowed before the last call to bountyWithdraw
.
function bountyWithdraw(address to, uint256 value) public onlyOwner returns (bool) {
withdraw(to, value);
bounties[to] = value;
return true;
}
function _transfer(address from, address to, uint256 value) internal {
require(to != address(0));
if (block.timestamp < bountyLockTime3Month) {
require(_balances[from].sub(value) >= bounties[from]);
} else if(block.timestamp < bountyLockTime6Month) {
require(_balances[from].sub(value) >= (bounties[from] * 9 / 10));
} else if(block.timestamp < bountyLockTime12Month) {
require(_balances[from].sub(value) >= (bounties[from] * 6 / 10));
}
_balances[from] = _balances[from].sub(value);
_balances[to] = _balances[to].add(value);
emit Transfer(from, to, value);
}
change bounties[to] = value
to bounties[to] = bounties[to].add(value)
decreaseAllowance
throw in case if the value to be subtracted is higher than the amount that is allowed, if the address owner wants to change the value allowed by reducing it and the spender withdraw a part of it before, the function might throw and give more chances for the spender to take the rest of the allowed value.
The value should be set to zero if the value to be subtracted is higher than the allowance.
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;
}
Add the following code to the function _transfer(address from, address to, uint256 value)
function:
require( _to != address(this) );
The audited contract is safe, however issue 3.1 should be fixed.
https://gist.github.com/yuriy77k/ed783fa4761a26d4e917eb5eb6c500ad
https://gist.github.com/yuriy77k/c5aea1e544c1cc2557f391cbe17b154c
https://gist.github.com/yuriy77k/0cfd9435161debfc66bcca612b83f0f5
Audit request
We created the Twogap platform to give Crypto Investors an opportunity to acquire a powerful large-scale, stop-loss product, Cryptobonds. The Twogap core technologies are forming the market by creating super liquidity between the Crypto Exchanges and traditional Securities Exchanges.
https://twogap.com
Source code
https://etherscan.io/address/0xf96aa656ec0e0ac163590db372b430cf3c0d61ca#code
Disclosure policy
contact@twogap.com
Platform
ETH
Number of lines:
186