文件 1 的 1:TokenSwapPhase2.sol
pragma solidity ^0.5.0;
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) {
require(b <= a, "SafeMath: subtraction overflow");
uint256 c = a - b;
return c;
}
}
contract Token {
function totalSupply() public view returns (uint256 supply);
function balanceOf(address _owner) public view returns (uint256 balance);
function transfer(address _to, uint256 _value)
public
returns (bool success);
function transferFrom(
address _from,
address _to,
uint256 _value
) public returns (bool success);
function approve(address _spender, uint256 _value)
public
returns (bool success);
function allowance(address _owner, address _spender)
public
view
returns (uint256 remaining);
function burn(uint256 amount) public;
event Transfer(address indexed _from, address indexed _to, uint256 _value);
event Approval(
address indexed _owner,
address indexed _spender,
uint256 _value
);
}
contract TokenSwapPhase2 {
using SafeMath for uint256;
constructor() public {
owner = msg.sender;
isEnd = false;
}
address constant KAI_ADDRESS = 0xD9Ec3ff1f8be459Bb9369b4E79e9Ebcf7141C093;
address private owner;
address[] public depositors;
bool public isEnd;
mapping (address => uint256) public amount;
modifier onlyOwner() {
require(msg.sender == owner);
_;
}
function depositKAI(address _toAddress, uint256 _amount) public {
require(isEnd == false, "The campaign is ended");
require(Token(KAI_ADDRESS).transferFrom(msg.sender, address(this), _amount));
if (amount[_toAddress] == 0) {
depositors.push(_toAddress);
}
amount[_toAddress] += _amount;
}
function burnKAI() public onlyOwner {
Token(KAI_ADDRESS).burn(getBalanceKAIContract());
}
function getBalanceKAIContract() public view returns (uint256) {
return Token(KAI_ADDRESS).balanceOf(address(this));
}
function setIsEnd() public onlyOwner {
isEnd = true;
}
function getNumberDepositors() public view returns (uint256) {
return depositors.length;
}
function emergencyWithdrawalKAI(uint256 _amount) public onlyOwner {
Token(KAI_ADDRESS).transfer(msg.sender, _amount);
}
}
{
"compilationTarget": {
"TokenSwapPhase2.sol": "TokenSwapPhase2"
},
"evmVersion": "byzantium",
"libraries": {},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": []
}