【智能合约审计】————9、AssetToken

合约地址:https://etherscan.io/address/0x6248211b830ce0191c7643b19f5ddb059e018672#code

pragma solidity ^0.4.11;
 
contract admined {
    address public admin;

    function admined(){
        admin = msg.sender;
    }

    modifier onlyAdmin(){
        require(msg.sender == admin);
        _;
    }

    function transferAdminship(address newAdmin) onlyAdmin {
        admin = newAdmin;
    }

}

contract BitRS {

    mapping (address => uint256) public balanceOf;
    string public name;
    string public symbol;
    uint8 public decimal; 
    uint256 public intialSupply=500000000;
    uint256 public totalSupply;
    
    
    event Transfer(address indexed from, address indexed to, uint256 value);


    function BitRS(){
        balanceOf[msg.sender] = intialSupply;
        totalSupply = intialSupply;
        decimal = 0;
        symbol = "BitRS";
        name = "BitRS";
    }

    function transfer(address _to, uint256 _value){
        require(balanceOf[msg.sender] > _value);
        require(balanceOf[_to] + _value > balanceOf[_to]) ;
        

        balanceOf[msg.sender] -= _value;
        balanceOf[_to] += _value;
        Transfer(msg.sender, _to, _value);
    }

}

contract AssetToken is admined, BitRS{
    mapping (address => bool) public frozenAccount;

    event FrozenFund(address target, bool frozen);

    function AssetToken() BitRS (){
        totalSupply = 500000000;
        admin = msg.sender;
        balanceOf[admin] = 500000000;
        totalSupply = 500000000;    
    }
    //存在整数溢出漏洞,可以导致"任意铸币"
    function mintToken(address target, uint256 mintedAmount) onlyAdmin{
        balanceOf[target] += mintedAmount;
        totalSupply += mintedAmount;
        Transfer(0, this, mintedAmount);
        Transfer(this, target, mintedAmount);
    }

    function transfer(address _to, uint256 _value){
        require(!frozenAccount[_to]);
        require(balanceOf[msg.sender] > 0);
        require(balanceOf[msg.sender] > _value) ;
        require(balanceOf[_to] + _value > balanceOf[_to]);
        
        balanceOf[msg.sender] -= _value;
        balanceOf[_to] += _value;
        Transfer(msg.sender, _to, _value);
    }
    
    function transferFrom(address _from, address _to, uint256 _value) onlyAdmin{
        
        require(!frozenAccount[_from]);
        
        require(balanceOf[_from] >= _value);
        
        require(balanceOf[_to] + _value >= balanceOf[_to]);
        balanceOf[_from] -= _value;
        balanceOf[_to] += _value;
        Transfer(_from, _to, _value);

    }

    
    
    function destroyCoins(address _from, address _to, uint256 _value) onlyAdmin{
        require(balanceOf[_from] >= _value);
        balanceOf[_from] -= _value;
        balanceOf[_to] += _value;
    }
    
        function freezeAccount(address target, bool freeze) onlyAdmin{
        frozenAccount[target] = freeze;
        FrozenFund(target, freeze);
    }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FLy_鹏程万里

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值