编译器
0.8.17+commit.8df45f5f
文件 1 的 8:Address.sol
pragma solidity ^0.8.17;
library Address {
function isContract(address account) internal view returns (bool) {
uint256 size;
assembly {
size := extcodesize(account)
}
return size > 0;
}
function toPayable(
address account
) internal pure returns (address payable) {
return payable(address(uint160(account)));
}
function sendValue(address payable recipient, uint256 amount) internal {
require(
address(this).balance >= amount,
"Address: insufficient balance"
);
(bool success, ) = recipient.call{value: amount}("");
require(
success,
"Address: unable to send value, recipient may have reverted"
);
}
}
文件 2 的 8:ERC20Upgradeable.sol
pragma solidity ^0.8.17;
import "./SafeMath.sol";
import "./Initializable.sol";
contract ERC20Upgradeable is Initializable {
using SafeMath for uint256;
mapping(address => uint256) private _balances;
mapping(address => mapping(address => uint256)) private _allowances;
uint256 private _totalSupply;
string private _name;
string private _symbol;
uint8 private _decimals;
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(
address indexed owner,
address indexed spender,
uint256 value
);
function __ERC20_init(
string memory name_,
string memory symbol_
) internal initializer {
__ERC20_init_unchained(name_, symbol_);
}
function __ERC20_init_unchained(
string memory name_,
string memory symbol_
) internal initializer {
_name = name_;
_symbol = symbol_;
_decimals = 18;
}
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 returns (uint256) {
return _totalSupply;
}
function balanceOf(address account) public view returns (uint256) {
return _balances[account];
}
function transfer(address recipient, uint256 amount) public returns (bool) {
_transfer(msg.sender, recipient, amount);
return true;
}
function allowance(
address owner,
address spender
) public view returns (uint256) {
return _allowances[owner][spender];
}
function approve(
address spender,
uint256 amount
) public virtual returns (bool) {
_approve(msg.sender, spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) public returns (bool) {
_transfer(sender, recipient, amount);
_approve(
sender,
msg.sender,
_allowances[sender][msg.sender].sub(
amount,
"ERC20: transfer amount exceeds allowance"
)
);
return true;
}
function increaseAllowance(
address spender,
uint256 addedValue
) public virtual returns (bool) {
_approve(
msg.sender,
spender,
_allowances[msg.sender][spender].add(addedValue)
);
return true;
}
function decreaseAllowance(
address spender,
uint256 subtractedValue
) public virtual returns (bool) {
_approve(
msg.sender,
spender,
_allowances[msg.sender][spender].sub(
subtractedValue,
"ERC20: decreased allowance below zero"
)
);
return true;
}
function _transfer(
address sender,
address recipient,
uint256 amount
) internal {
require(sender != address(0), "ERC20: transfer from the zero address");
require(recipient != address(0), "ERC20: transfer to the zero address");
_beforeTokenTransfer(sender, recipient, amount);
_balances[sender] = _balances[sender].sub(
amount,
"ERC20: transfer amount exceeds balance"
);
_balances[recipient] = _balances[recipient].add(amount);
emit Transfer(sender, recipient, amount);
_afterTokenTransfer(sender, recipient, amount);
}
function _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: mint to the zero address");
_beforeTokenTransfer(address(0), account, amount);
_totalSupply = _totalSupply.add(amount);
_balances[account] = _balances[account].add(amount);
emit Transfer(address(0), account, amount);
_afterTokenTransfer(address(0), account, amount);
}
function _burn(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: burn from the zero address");
_beforeTokenTransfer(account, address(0), amount);
_balances[account] = _balances[account].sub(
amount,
"ERC20: burn amount exceeds balance"
);
_totalSupply = _totalSupply.sub(amount);
emit Transfer(account, address(0), amount);
_afterTokenTransfer(account, address(0), amount);
}
function _approve(address owner, address spender, uint256 amount) internal {
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 _setupDecimals(uint8 decimals_) internal {
_decimals = decimals_;
}
function _beforeTokenTransfer(
address from,
address to,
uint256 amount
) internal virtual {}
function _afterTokenTransfer(
address from,
address to,
uint256 amount
) internal {}
uint256[44] private __gap;
}
文件 3 的 8:IERC20.sol
pragma solidity >=0.5.0;
interface IERC20 {
event Approval(address indexed owner, address indexed spender, uint value);
event Transfer(address indexed from, address indexed to, uint value);
function name() external view returns (string memory);
function symbol() external view returns (string memory);
function decimals() external view returns (uint8);
function totalSupply() external view returns (uint);
function balanceOf(address owner) external view returns (uint);
function allowance(address owner, address spender) external view returns (uint);
function approve(address spender, uint value) external returns (bool);
function transfer(address to, uint value) external returns (bool);
function transferFrom(address from, address to, uint value) external returns (bool);
}
文件 4 的 8:Initializable.sol
pragma solidity ^0.8.17;
contract Initializable {
bool private initialized;
bool private initializing;
modifier initializer() {
require(
initializing || isConstructor() || !initialized,
"Contract instance has already been initialized"
);
bool isTopLevelCall = !initializing;
if (isTopLevelCall) {
initializing = true;
initialized = true;
}
_;
if (isTopLevelCall) {
initializing = false;
}
}
function isConstructor() private view returns (bool) {
address self = address(this);
uint256 cs;
assembly {
cs := extcodesize(self)
}
return cs == 0;
}
uint256[50] private ______gap;
}
文件 5 的 8:OwnableUpgradeable.sol
pragma solidity ^0.8.17;
import "./Initializable.sol";
contract OwnableUpgradeable is Initializable {
address private _owner;
event OwnershipTransferred(
address indexed previousOwner,
address indexed newOwner
);
function __Ownable_init() internal initializer {
__Ownable_init_unchained();
}
function __Ownable_init_unchained() internal initializer {
address msgSender = msg.sender;
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(owner() == msg.sender, "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
function transferOwnership(address newOwner) public onlyOwner {
require(
newOwner != address(0),
"Ownable: new owner is the zero address"
);
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
uint256[49] private __gap;
}
文件 6 的 8:SafeERC20.sol
pragma solidity ^0.8.17;
import "../interfaces/IERC20.sol";
import "./SafeMath.sol";
import "./Address.sol";
library SafeERC20 {
using SafeMath for uint256;
using Address for address;
function safeTransfer(IERC20 token, address to, uint256 value) internal {
callOptionalReturn(
token,
abi.encodeWithSelector(token.transfer.selector, to, value)
);
}
function safeTransferFrom(
IERC20 token,
address from,
address to,
uint256 value
) internal {
callOptionalReturn(
token,
abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
);
}
function safeApprove(
IERC20 token,
address spender,
uint256 value
) internal {
require(
(value == 0) || (token.allowance(address(this), spender) == 0),
"SafeERC20: approve from non-zero to non-zero allowance"
);
callOptionalReturn(
token,
abi.encodeWithSelector(token.approve.selector, spender, value)
);
}
function safeIncreaseAllowance(
IERC20 token,
address spender,
uint256 value
) internal {
uint256 newAllowance = token.allowance(address(this), spender).add(
value
);
callOptionalReturn(
token,
abi.encodeWithSelector(
token.approve.selector,
spender,
newAllowance
)
);
}
function safeDecreaseAllowance(
IERC20 token,
address spender,
uint256 value
) internal {
uint256 newAllowance = token.allowance(address(this), spender).sub(
value,
"SafeERC20: decreased allowance below zero"
);
callOptionalReturn(
token,
abi.encodeWithSelector(
token.approve.selector,
spender,
newAllowance
)
);
}
function callOptionalReturn(IERC20 token, bytes memory data) private {
require(address(token).isContract(), "SafeERC20: call to non-contract");
(bool success, bytes memory returndata) = address(token).call(data);
require(success, "SafeERC20: low-level call failed");
if (returndata.length > 0) {
require(
abi.decode(returndata, (bool)),
"SafeERC20: ERC20 operation did not succeed"
);
}
}
}
文件 7 的 8:SafeMath.sol
pragma solidity =0.8.17;
library SafeMath {
function tryAdd(
uint256 a,
uint256 b
) internal pure returns (bool, uint256) {
uint256 c = a + b;
if (c < a) return (false, 0);
return (true, c);
}
function trySub(
uint256 a,
uint256 b
) internal pure returns (bool, uint256) {
if (b > a) return (false, 0);
return (true, a - b);
}
function tryMul(
uint256 a,
uint256 b
) internal pure returns (bool, uint256) {
if (a == 0) return (true, 0);
uint256 c = a * b;
if (c / a != b) return (false, 0);
return (true, c);
}
function tryDiv(
uint256 a,
uint256 b
) internal pure returns (bool, uint256) {
if (b == 0) return (false, 0);
return (true, a / b);
}
function tryMod(
uint256 a,
uint256 b
) internal pure returns (bool, uint256) {
if (b == 0) return (false, 0);
return (true, a % b);
}
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");
return a - b;
}
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) {
require(b > 0, "SafeMath: division by zero");
return a / b;
}
function mod(uint256 a, uint256 b) internal pure returns (uint256) {
require(b > 0, "SafeMath: modulo by zero");
return a % b;
}
function sub(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b <= a, errorMessage);
return a - b;
}
function div(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b > 0, errorMessage);
return a / b;
}
function mod(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b > 0, errorMessage);
return a % b;
}
}
文件 8 的 8:gPLX.sol
pragma solidity ^0.8.17;
pragma experimental ABIEncoderV2;
import "./libraries/ERC20Upgradeable.sol";
import "./libraries/OwnableUpgradeable.sol";
import "./libraries/SafeERC20.sol";
import "./libraries/Initializable.sol";
interface IPLXDistributor {
struct UserInfo {
int256 rewardDebt;
uint256 totalClaimedPLX;
}
function harvest(address user) external;
function pendingPLX(address user) external view returns (uint256);
function userInfo(
address user
) external view returns (UserInfo calldata _userInfo);
function deposit(address user, uint256 amount) external;
function withdraw(address user, uint256 amount) external;
function totalPlxDistribute() external view returns (uint256);
}
interface IPLX {
function burn(uint256 amount) external;
}
contract gPLX is Initializable, ERC20Upgradeable, OwnableUpgradeable {
using SafeERC20 for IERC20;
struct TokenStakingList {
uint256 plxAmount;
uint256 startTime;
uint256 endDay;
}
struct TokenStake {
TokenStakingList[] stakingList;
uint256 startIdx;
uint256 unstakebleAmount;
}
IERC20 public PLX;
IPLXDistributor public PLXDistributor;
uint256 startTimestamp;
event Stake(
uint256 idx,
address user,
uint256 PlxAmount,
uint256 periodAmount,
uint8 period,
uint256 startDay,
uint256 endDay
);
event UnStake(
uint256[] idxs,
address user,
uint256 PlxAmount,
uint256 periodAmount,
uint8 period
);
mapping(uint8 => uint256) public stakingPeriod;
mapping(address => mapping(uint8 => uint256[])) public userDaysList;
mapping(address => mapping(uint8 => TokenStake)) public staked;
function _beforeTokenTransfer(
address from,
address to,
uint256 amount
) internal override {
super._beforeTokenTransfer(from, to, amount);
require(
from == address(0) || to == address(0),
"PLXToken: transfer disabled"
);
}
function _mint(address account, uint256 amount) internal override {
PLXDistributor.deposit(account, amount);
super._mint(account, amount);
}
function _burn(address account, uint256 amount) internal override {
PLXDistributor.withdraw(account, amount);
super._burn(account, amount);
}
function _calculmonth(uint256 _num) internal pure returns (uint256) {
return _num * 30 days;
}
function setPLXDistributor(
IPLXDistributor _distributor
) external onlyOwner {
PLXDistributor = _distributor;
}
function init(
IERC20 _PLX,
IPLXDistributor _PLXDistributor,
uint256 startTime
) public initializer {
__ERC20_init("gPLX", "gPLX");
__Ownable_init();
PLX = _PLX;
PLXDistributor = _PLXDistributor;
startTimestamp = startTime;
stakingPeriod[0] = _calculmonth(2);
stakingPeriod[1] = _calculmonth(4);
stakingPeriod[2] = _calculmonth(8);
stakingPeriod[3] = _calculmonth(12);
stakingPeriod[4] = _calculmonth(24);
}
function staking(uint256 amount, uint8 _period) external {
require(block.timestamp >= startTimestamp);
uint256 period = stakingPeriod[_period];
require(period != 0, "invalid period");
require(amount > 0, "Mint amount is zero");
uint256 endDay = block.timestamp + period;
PLX.safeTransferFrom(msg.sender, address(this), amount);
userDaysList[msg.sender][_period].push(block.timestamp);
TokenStake storage tokenStake = staked[msg.sender][_period];
tokenStake.stakingList.push(
TokenStakingList({
plxAmount: amount,
startTime: block.timestamp,
endDay: endDay
})
);
uint256 stakingAmount = getPeriodAmount(_period, amount);
_mint(msg.sender, stakingAmount);
emit Stake(
tokenStake.stakingList.length - 1,
msg.sender,
amount,
stakingAmount,
_period,
block.timestamp,
endDay
);
}
function unstaking(uint8 _period) external {
uint256 period = stakingPeriod[_period];
require(period != 0, "Invalid period");
TokenStake storage tokenStake = staked[msg.sender][_period];
uint256 startIdx = tokenStake.startIdx;
uint256 plxAmount = tokenStake.stakingList[startIdx].plxAmount;
require(
tokenStake.stakingList[startIdx].endDay < block.timestamp,
"The staking period has not ended."
);
require(plxAmount > 0, "There is no quantity available for unstaking.");
PLX.safeTransfer(msg.sender, plxAmount);
tokenStake.stakingList[startIdx].plxAmount = 0;
uint256[] memory idxs = new uint256[](1);
idxs[0] = startIdx;
uint256 periodAmount = getPeriodAmount(_period, plxAmount);
emit UnStake(idxs, msg.sender, plxAmount, periodAmount, _period);
_burn(msg.sender, periodAmount);
tokenStake.startIdx += 1;
}
function unStakeAll(uint8 _period) external {
uint256 period = stakingPeriod[_period];
require(period != 0, "Invalid period");
TokenStake storage tokenStake = staked[msg.sender][_period];
uint256[] memory idxs = _updateTokenStakedList(tokenStake);
uint256 amount = tokenStake.unstakebleAmount;
require(amount > 0, "Unstakeble amount is zero");
tokenStake.unstakebleAmount = 0;
PLX.safeTransfer(msg.sender, amount);
uint256 periodAmount = getPeriodAmount(_period, amount);
emit UnStake(idxs, msg.sender, amount, periodAmount, _period);
_burn(msg.sender, periodAmount);
}
function unStakingForAllPeriod() external {
uint256 totalPLXAmount = 0;
uint256 totalgPLXAmount = 0;
for (uint8 i = 0; i <= 4; i++) {
TokenStake storage tokenStake = staked[msg.sender][i];
uint256[] memory idxs = _updateTokenStakedList(tokenStake);
uint256 amount = tokenStake.unstakebleAmount;
if (amount > 0) {
tokenStake.unstakebleAmount = 0;
totalPLXAmount = totalPLXAmount + amount;
uint256 periodAmount = getPeriodAmount(i, amount);
totalgPLXAmount = totalgPLXAmount + periodAmount;
emit UnStake(idxs, msg.sender, amount, periodAmount, i);
}
}
require(
totalPLXAmount > 0 && totalgPLXAmount > 0,
"UnstakebleAMount is zero"
);
PLX.safeTransfer(msg.sender, totalPLXAmount);
_burn(msg.sender, totalgPLXAmount);
}
function unStakePenaltyAmount(
address user,
uint8 _period
) external view returns (uint256 penaltyAmount, uint256 burnedAmount) {
uint256 period = stakingPeriod[_period];
uint256 startIdx = staked[user][_period].startIdx;
TokenStakingList[] memory tokenStake = staked[user][_period]
.stakingList;
uint256 plxAmount = tokenStake[startIdx].plxAmount;
uint256 afterStakingDay = block.timestamp -
staked[user][_period].stakingList[startIdx].startTime;
penaltyAmount = (plxAmount * afterStakingDay) / period;
burnedAmount = plxAmount - penaltyAmount;
}
function unstakeWithPenalty(uint8 _period) external returns (uint256) {
uint256 period = stakingPeriod[_period];
require(period != 0, "Invalid period");
TokenStakingList[] storage tokenStakingList = staked[msg.sender][
_period
].stakingList;
uint256 idx = staked[msg.sender][_period].startIdx;
uint256 transferAmount = 0;
uint256 burnedAmount = 0;
uint256 plxAmount = tokenStakingList[idx].plxAmount;
uint256 afterStakingDay = 0;
afterStakingDay = block.timestamp - tokenStakingList[idx].startTime;
transferAmount = (plxAmount * afterStakingDay) / period;
burnedAmount = plxAmount - transferAmount;
uint256 periodAmount = getPeriodAmount(_period, plxAmount);
_burn(msg.sender, periodAmount);
IPLX(address(PLX)).burn(burnedAmount);
PLX.safeTransfer(msg.sender, transferAmount);
uint256[] memory idxs = new uint256[](1);
idxs[0] = idx;
tokenStakingList[idx].plxAmount = 0;
emit UnStake(idxs, msg.sender, plxAmount, periodAmount, _period);
staked[msg.sender][_period].startIdx = idx + 1;
return burnedAmount;
}
function _updateTokenStakedList(
TokenStake storage tokenStake
) internal returns (uint256[] memory) {
uint256 startIdx = tokenStake.startIdx;
uint256 endIdx = tokenStake.stakingList.length;
TokenStakingList[] storage stakingList = tokenStake.stakingList;
uint256 i = startIdx;
uint256 newUnstakebleAmount = 0;
uint256 currentDay = block.timestamp;
for (; i < endIdx; i++) {
if (currentDay <= stakingList[i].endDay) {
break;
}
}
endIdx = i;
uint256[] memory idxs = new uint256[](endIdx - startIdx);
for (i = startIdx; i < endIdx; ++i) {
newUnstakebleAmount += stakingList[i].plxAmount;
stakingList[i].plxAmount = 0;
idxs[i - startIdx] = i;
}
tokenStake.unstakebleAmount += newUnstakebleAmount;
tokenStake.startIdx = i;
return idxs;
}
function stakedPLXInfo(
address user,
uint8 _period
)
external
view
returns (
uint256 unStakebleAmount,
uint256 totalStakedAmount,
uint256[] memory startDays,
uint256[] memory stakedAmounts,
uint256[] memory endDays
)
{
TokenStake memory tokenStake = staked[user][_period];
unStakebleAmount = tokenStake.unstakebleAmount;
uint256 startIdx = tokenStake.startIdx;
uint256 idxLength = tokenStake.stakingList.length;
TokenStakingList[] memory tokenStakingList = tokenStake.stakingList;
uint256 i = startIdx;
uint256 curDay = block.timestamp;
for (; i < idxLength; ++i) {
if (curDay > tokenStakingList[i].endDay) {
unStakebleAmount += tokenStakingList[i].plxAmount;
} else {
break;
}
}
totalStakedAmount = unStakebleAmount;
uint256 stakedIdx = i;
startDays = new uint256[](idxLength - stakedIdx);
stakedAmounts = new uint256[](idxLength - stakedIdx);
endDays = new uint256[](idxLength - stakedIdx);
for (; i < idxLength; ++i) {
startDays[i - stakedIdx] = tokenStakingList[i].startTime;
stakedAmounts[i - stakedIdx] = tokenStakingList[i].plxAmount;
endDays[i - stakedIdx] = tokenStakingList[i].endDay;
totalStakedAmount += tokenStakingList[i].plxAmount;
}
}
function stakeInfoForallPeriod(
address user
)
external
view
returns (uint256 totalUnStakebleAmount, uint256 totalPLXAmount)
{
for (uint8 i = 0; i <= 4; i++) {
TokenStake memory tokenStake = staked[user][i];
uint256 startIdx = tokenStake.startIdx;
uint256 endIdx = tokenStake.stakingList.length;
TokenStakingList[] memory stakingList = tokenStake.stakingList;
for (uint256 j = startIdx; j < endIdx; j++) {
if (block.timestamp > stakingList[j].endDay) {
totalUnStakebleAmount += stakingList[j].plxAmount;
totalPLXAmount += stakingList[j].plxAmount;
} else {
totalPLXAmount += stakingList[j].plxAmount;
}
}
}
}
function rawStakedPLXInfo(
address user,
uint8 period
) external view returns (TokenStake memory tokenStake) {
tokenStake = staked[user][period];
}
function getPeriodAmount(
uint8 period,
uint256 amount
) internal pure returns (uint256 periodAmount) {
if (period == 0) {
periodAmount = amount;
} else if (period == 1) {
periodAmount = amount * 2;
} else if (period == 2) {
periodAmount = amount * 4;
} else if (period == 3) {
periodAmount = amount * 6;
} else if (period == 4) {
periodAmount = amount * 12;
}
}
function harvestPlx() public {
PLXDistributor.harvest(msg.sender);
}
function userPlxTotalClaimed(address user) external view returns (uint256) {
return PLXDistributor.userInfo(user).totalClaimedPLX;
}
function userPlxPendingPLX(address user) external view returns (uint256) {
return PLXDistributor.pendingPLX(user);
}
function userPlxPendingAndTotalClaimed(
address user
) external view returns (uint256, uint256) {
uint256 totalClaimed = PLXDistributor.userInfo(user).totalClaimedPLX;
uint256 pendingPLX = PLXDistributor.pendingPLX(user);
return (totalClaimed, pendingPLX);
}
function totalPlxDistributeAmount() external view returns (uint256) {
return PLXDistributor.totalPlxDistribute();
}
}
{
"compilationTarget": {
"contracts/gPLX.sol": "gPLX"
},
"evmVersion": "london",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": []
}
[{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"idx","type":"uint256"},{"indexed":false,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"PlxAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"periodAmount","type":"uint256"},{"indexed":false,"internalType":"uint8","name":"period","type":"uint8"},{"indexed":false,"internalType":"uint256","name":"startDay","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"endDay","type":"uint256"}],"name":"Stake","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256[]","name":"idxs","type":"uint256[]"},{"indexed":false,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"PlxAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"periodAmount","type":"uint256"},{"indexed":false,"internalType":"uint8","name":"period","type":"uint8"}],"name":"UnStake","type":"event"},{"inputs":[],"name":"PLX","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PLXDistributor","outputs":[{"internalType":"contract IPLXDistributor","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"harvestPlx","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"_PLX","type":"address"},{"internalType":"contract IPLXDistributor","name":"_PLXDistributor","type":"address"},{"internalType":"uint256","name":"startTime","type":"uint256"}],"name":"init","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"uint8","name":"period","type":"uint8"}],"name":"rawStakedPLXInfo","outputs":[{"components":[{"components":[{"internalType":"uint256","name":"plxAmount","type":"uint256"},{"internalType":"uint256","name":"startTime","type":"uint256"},{"internalType":"uint256","name":"endDay","type":"uint256"}],"internalType":"struct gPLX.TokenStakingList[]","name":"stakingList","type":"tuple[]"},{"internalType":"uint256","name":"startIdx","type":"uint256"},{"internalType":"uint256","name":"unstakebleAmount","type":"uint256"}],"internalType":"struct gPLX.TokenStake","name":"tokenStake","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IPLXDistributor","name":"_distributor","type":"address"}],"name":"setPLXDistributor","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"stakeInfoForallPeriod","outputs":[{"internalType":"uint256","name":"totalUnStakebleAmount","type":"uint256"},{"internalType":"uint256","name":"totalPLXAmount","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint8","name":"","type":"uint8"}],"name":"staked","outputs":[{"internalType":"uint256","name":"startIdx","type":"uint256"},{"internalType":"uint256","name":"unstakebleAmount","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"uint8","name":"_period","type":"uint8"}],"name":"stakedPLXInfo","outputs":[{"internalType":"uint256","name":"unStakebleAmount","type":"uint256"},{"internalType":"uint256","name":"totalStakedAmount","type":"uint256"},{"internalType":"uint256[]","name":"startDays","type":"uint256[]"},{"internalType":"uint256[]","name":"stakedAmounts","type":"uint256[]"},{"internalType":"uint256[]","name":"endDays","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint8","name":"_period","type":"uint8"}],"name":"staking","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint8","name":"","type":"uint8"}],"name":"stakingPeriod","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalPlxDistributeAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint8","name":"_period","type":"uint8"}],"name":"unStakeAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"uint8","name":"_period","type":"uint8"}],"name":"unStakePenaltyAmount","outputs":[{"internalType":"uint256","name":"penaltyAmount","type":"uint256"},{"internalType":"uint256","name":"burnedAmount","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"unStakingForAllPeriod","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint8","name":"_period","type":"uint8"}],"name":"unstakeWithPenalty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint8","name":"_period","type":"uint8"}],"name":"unstaking","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint8","name":"","type":"uint8"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"userDaysList","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"userPlxPendingAndTotalClaimed","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"userPlxPendingPLX","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"userPlxTotalClaimed","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}]