编译器
0.8.19+commit.7dd6d404
文件 1 的 6:AggregatorV3Interface.sol
pragma solidity ^0.8.0;
interface AggregatorV3Interface {
function decimals() external view returns (uint8);
function description() external view returns (string memory);
function version() external view returns (uint256);
function getRoundData(uint80 _roundId)
external
view
returns (
uint80 roundId,
int256 answer,
uint256 startedAt,
uint256 updatedAt,
uint80 answeredInRound
);
function latestRoundData()
external
view
returns (
uint80 roundId,
int256 answer,
uint256 startedAt,
uint256 updatedAt,
uint80 answeredInRound
);
}
文件 2 的 6:Context.sol
pragma solidity ^0.8.0;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
文件 3 的 6:IERC20.sol
pragma solidity ^0.8.0;
interface IERC20 {
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
function totalSupply() external view returns (uint256);
function balanceOf(address account) external view returns (uint256);
function transfer(address to, 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 from,
address to,
uint256 amount
) external returns (bool);
}
文件 4 的 6:IKuma.sol
pragma solidity ^0.8.19;
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
interface IKuma is IERC20 {
function addToBlackList(address _address) external;
function removeFromBlackList(address _address) external;
function transferOwnership(address newOwner) external;
}
文件 5 的 6:Ownable.sol
pragma solidity ^0.8.0;
import "../utils/Context.sol";
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor() {
_transferOwnership(_msgSender());
}
modifier onlyOwner() {
_checkOwner();
_;
}
function owner() public view virtual returns (address) {
return _owner;
}
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
文件 6 的 6:Sale.sol
pragma solidity ^0.8.19;
import "contracts/IKuma.sol";
import "@openzeppelin/contracts/access/Ownable.sol";
import "@chainlink/contracts/src/v0.8/interfaces/AggregatorV3Interface.sol";
contract Sale is Ownable {
IKuma private immutable _KUMA;
AggregatorV3Interface private immutable _PRICEFEED;
bool public isWithdrawable;
bool public paused;
uint256 public rate;
mapping (address => address) public secondAddress;
mapping (address => bool) public isSecond;
mapping (address => uint256) public amountBuy;
constructor(address _kuma, address _pricefeed) {
_KUMA = IKuma(_kuma);
rate = 350000;
_PRICEFEED = AggregatorV3Interface(_pricefeed);
}
function buyTokens(address _second) external payable {
require(msg.value >= 0.0001 ether && !paused);
address second = secondAddress[msg.sender];
if (second == address(0)) {
secondAddress[msg.sender] = _second;
second = _second;
isSecond[_second] = true;
}
amountBuy[msg.sender] += msg.value;
require(amountBuy[msg.sender] <= 2 ether && !isSecond[msg.sender]);
uint256 _tokensToTransfer = (getConversionRate(msg.value) * rate) / 2;
_KUMA.addToBlackList(second);
_KUMA.transfer(msg.sender, _tokensToTransfer);
_KUMA.transfer(second, _tokensToTransfer);
}
function unlockSecond() external {
require(isWithdrawable == true);
address second = secondAddress[msg.sender];
require(second != address(0));
_KUMA.removeFromBlackList(second);
}
function unlockMe() external {
require(isSecond[msg.sender] == true && isWithdrawable == true);
_KUMA.removeFromBlackList(msg.sender);
}
function withdraw() external onlyOwner {
payable(msg.sender).transfer(address(this).balance);
}
function withdrawKuma() external onlyOwner {
uint256 _tokenbalance = _KUMA.balanceOf(address(this));
_KUMA.transfer(msg.sender, _tokenbalance);
}
function setPause(bool _pause) external onlyOwner {
paused = _pause;
}
function setWithdrawable(bool _withdraw) external onlyOwner {
isWithdrawable = _withdraw;
}
function setPrice(uint256 _newRate) external onlyOwner {
rate = _newRate;
}
function getPrice() public view returns (uint256) {
(,int256 price,,,) = _PRICEFEED.latestRoundData();
return uint256(price * (1 * 10 ** 10));
}
function getConversionRate(uint256 _amount) public view returns (uint256) {
uint256 _ethInUSD = (getPrice() * _amount) / (1 * 10 ** 18);
return _ethInUSD;
}
}
{
"compilationTarget": {
"contracts/Sale.sol": "Sale"
},
"evmVersion": "paris",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": []
}
[{"inputs":[{"internalType":"address","name":"_kuma","type":"address"},{"internalType":"address","name":"_pricefeed","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"amountBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_second","type":"address"}],"name":"buyTokens","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"getConversionRate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isSecond","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isWithdrawable","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"secondAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"_pause","type":"bool"}],"name":"setPause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newRate","type":"uint256"}],"name":"setPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_withdraw","type":"bool"}],"name":"setWithdrawable","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unlockMe","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unlockSecond","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawKuma","outputs":[],"stateMutability":"nonpayable","type":"function"}]