Address Contract Partially Verified
Address
0x96546AFE4a21515A3a30CD3fd64A70eB478DC174
Balance
0 ETH
Nonce
1
Code Size
7881 bytes
Creator
0x073a8C4c...02F8 at tx 0x24a5d458...d140fd
Indexed Transactions
0
Contract Bytecode
7881 bytes
0x608060405234801561001057600080fd5b50600436106101cf5760003560e01c80636e9960c311610104578063a9059cbb116100a2578063ccfa214f11610071578063ccfa214f146103ce578063d6e242b8146103db578063dd62ed3e146103e3578063f851a440146103f657600080fd5b8063a9059cbb1461038d578063aea0cf49146103a0578063b38fe957146103b3578063b5c22877146103bb57600080fd5b806393310ffe116100de57806393310ffe1461034c578063936af9111461035f57806395d89b4114610372578063a457c2d71461037a57600080fd5b80636e9960c3146102ff57806370a082311461031057806379cc67901461033957600080fd5b806334f6ebf51161017157806342966c681161014b57806342966c68146102c35780635b8a194a146102d65780635f6529a3146102de57806361086b00146102f657600080fd5b806334f6ebf51461026d578063395093511461029d57806340c10f19146102b057600080fd5b806323b872dd116101ad57806323b872dd146102275780632baa3c9e1461023a5780632ecaf6751461024f578063313ce5671461025857600080fd5b806306fdde03146101d4578063095ea7b3146101f257806318160ddd14610215575b600080fd5b6101dc610409565b6040516101e99190611ab5565b60405180910390f35b610205610200366004611b3d565b61049b565b60405190151581526020016101e9565b6002545b6040519081526020016101e9565b610205610235366004611b67565b61055b565b61024d610248366004611ba3565b6106db565b005b61021960095481565b60055460405160ff90911681526020016101e9565b600b546102859061010090046001600160a01b031681565b6040516001600160a01b0390911681526020016101e9565b6102056102ab366004611b3d565b61080f565b61024d6102be366004611b3d565b6108ef565b61024d6102d1366004611bc5565b6109f7565b61024d610a9a565b6005546102859061010090046001600160a01b031681565b610219600a5481565b6008546001600160a01b0316610285565b61021961031e366004611ba3565b6001600160a01b031660009081526020819052604090205490565b61024d610347366004611b3d565b610bb0565b61024d61035a366004611b3d565b610ce6565b61024d61036d366004611bde565b610db6565b6101dc610f1c565b610205610388366004611b3d565b610f2b565b61020561039b366004611b3d565b61108a565b61024d6103ae366004611ba3565b61113f565b61024d61123c565b61024d6103c9366004611c82565b6113a0565b600b546102059060ff1681565b61024d6114f4565b6102196103f1366004611d51565b611645565b600854610285906001600160a01b031681565b60606003805461041890611d84565b80601f016020809104026020016040519081016040528092919081815260200182805461044490611d84565b80156104915780601f1061046657610100808354040283529160200191610491565b820191906000526020600020905b81548152906001019060200180831161047457829003601f168201915b5050505050905090565b600b546000908390839060ff161561054557600b5461010090046001600160a01b03166347abf3be336040517fffffffff0000000000000000000000000000000000000000000000000000000060e084901b1681526001600160a01b039182166004820152908516602482015260448101849052606401600060405180830381600087803b15801561052c57600080fd5b505af1158015610540573d6000803e3d6000fd5b505050505b610550338686611672565b506001949350505050565b600b5460009084908490849060ff161561060f57600b5461010090046001600160a01b031663379f5c69336040517fffffffff0000000000000000000000000000000000000000000000000000000060e084901b1681526001600160a01b0391821660048201528187166024820152908516604482015260648101849052608401600060405180830381600087803b1580156105f657600080fd5b505af115801561060a573d6000803e3d6000fd5b505050505b6001600160a01b0387166000908152600160209081526040808320338452909152902054858110156106ae5760405162461bcd60e51b815260206004820152602960248201527f4c45524332303a207472616e7366657220616d6f756e7420657863656564732060448201527f616c6c6f77616e6365000000000000000000000000000000000000000000000060648201526084015b60405180910390fd5b6106b98888886116d4565b6106cd88336106c88985611e06565b611672565b506001979650505050505050565b60055461010090046001600160a01b0316336001600160a01b0316146107435760405162461bcd60e51b815260206004820152601e60248201527f4c45524332303a204d757374206265207265636f766572792061646d696e000060448201526064016106a5565b6008546001600160a01b03908116908216036107a15760405162461bcd60e51b815260206004820152601f60248201527f4c45524332303a2043616e6e6f74207365742073616d6520616464726573730060448201526064016106a5565b6040516001600160a01b038216907f71614071b88dee5e0b2ae578a9dd7b2ebbe9ae832ba419dc0242cd065a290b6c90600090a2600880547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b0392909216919091179055565b600b546000908390839060ff16156108b957600b5461010090046001600160a01b031663cf5961bb336040517fffffffff0000000000000000000000000000000000000000000000000000000060e084901b1681526001600160a01b039182166004820152908516602482015260448101849052606401600060405180830381600087803b1580156108a057600080fd5b505af11580156108b4573d6000803e3d6000fd5b505050505b3360008181526001602090815260408083206001600160a01b038a168452909152902054610550919087906106c8908890611e19565b600b548290829060ff161561098457600b546040517f0628a2c00000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301526024820184905261010090920490911690630628a2c090604401600060405180830381600087803b15801561096b57600080fd5b505af115801561097f573d6000803e3d6000fd5b505050505b6008546001600160a01b0316336001600160a01b0316146109e75760405162461bcd60e51b815260206004820152601560248201527f4c45524332303a204d7573742062652061646d696e000000000000000000000060448201526064016106a5565b6109f18484611879565b50505050565b33600b54829060ff1615610a8b57600b546040517f4a1fefbd0000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301526024820184905261010090920490911690634a1fefbd90604401600060405180830381600087803b158015610a7257600080fd5b505af1158015610a86573d6000803e3d6000fd5b505050505b610a953384611938565b505050565b60055461010090046001600160a01b0316336001600160a01b031614610b025760405162461bcd60e51b815260206004820152601e60248201527f4c45524332303a204d757374206265207265636f766572792061646d696e000060448201526064016106a5565b600b5460ff1615610b555760405162461bcd60e51b815260206004820152601b60248201527f4c45524332303a204c6f73736c65737320616c7265616479206f6e000000000060448201526064016106a5565b6000600a819055600b80547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff001660011790556040517f1ba3b66404043da8297d0b876fa6464f2cb127edfc6626308046d4503028322b9190a1565b600b548290829060ff1615610c4557600b546040517f4a1fefbd0000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301526024820184905261010090920490911690634a1fefbd90604401600060405180830381600087803b158015610c2c57600080fd5b505af1158015610c40573d6000803e3d6000fd5b505050505b6000610c518533611645565b905083811015610cc85760405162461bcd60e51b8152602060048201526024808201527f45524332303a206275726e20616d6f756e74206578636565647320616c6c6f7760448201527f616e63650000000000000000000000000000000000000000000000000000000060648201526084016106a5565b610cd58533868403611672565b610cdf8585611938565b5050505050565b60055461010090046001600160a01b0316336001600160a01b031614610d4e5760405162461bcd60e51b815260206004820152601e60248201527f4c45524332303a204d757374206265207265636f766572792061646d696e000060448201526064016106a5565b600680547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b03841690811790915560078290556040517f6c591da8da2f6e69746d7d9ae61c27ee29fbe303798141b4942ae2aef54274b190600090a25050565b600b5461010090046001600160a01b0316336001600160a01b031614610e1e5760405162461bcd60e51b815260206004820152601e60248201527f4c45524332303a204f6e6c79206c6f73736c65737320636f6e7472616374000060448201526064016106a5565b806000805b82811015610ee1576000858583818110610e3f57610e3f611e2c565b9050602002016020810190610e549190611ba3565b6001600160a01b03811660009081526020819052604081208054919055909150610e7e8185611e19565b600b546040518381529195506001600160a01b03610100909104811691908416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a350508080610ed990611e5b565b915050610e23565b50600b5461010090046001600160a01b031660009081526020819052604081208054839290610f11908490611e19565b909155505050505050565b60606004805461041890611d84565b600b546000908390839060ff1615610fd557600b5461010090046001600160a01b031663568c75a9336040517fffffffff0000000000000000000000000000000000000000000000000000000060e084901b1681526001600160a01b039182166004820152908516602482015260448101849052606401600060405180830381600087803b158015610fbc57600080fd5b505af1158015610fd0573d6000803e3d6000fd5b505050505b3360009081526001602090815260408083206001600160a01b03891684529091529020548481101561106f5760405162461bcd60e51b815260206004820152602660248201527f4c45524332303a2064656372656173656420616c6c6f77616e63652062656c6f60448201527f77207a65726f000000000000000000000000000000000000000000000000000060648201526084016106a5565b61107e33876106c88885611e06565b50600195945050505050565b600b546000908390839060ff161561113457600b5461010090046001600160a01b0316631ffb811f336040517fffffffff0000000000000000000000000000000000000000000000000000000060e084901b1681526001600160a01b039182166004820152908516602482015260448101849052606401600060405180830381600087803b15801561111b57600080fd5b505af115801561112f573d6000803e3d6000fd5b505050505b6105503386866116d4565b60055461010090046001600160a01b0316336001600160a01b0316146111a75760405162461bcd60e51b815260206004820152601e60248201527f4c45524332303a204d757374206265207265636f766572792061646d696e000060448201526064016106a5565b6001600160a01b0381166111fd5760405162461bcd60e51b815260206004820152601d60248201527f4c45524332303a2043616e6e6f7420736574206164647265737328302900000060448201526064016106a5565b600b80546001600160a01b03909216610100027fffffffffffffffffffffff0000000000000000000000000000000000000000ff909216919091179055565b60055461010090046001600160a01b0316336001600160a01b0316146112a45760405162461bcd60e51b815260206004820152601e60248201527f4c45524332303a204d757374206265207265636f766572792061646d696e000060448201526064016106a5565b600a546000036112f65760405162461bcd60e51b815260206004820152601c60248201527f4c45524332303a205475726e4f6666206e6f742070726f706f7365640000000060448201526064016106a5565b42600a5411156113485760405162461bcd60e51b815260206004820152601d60248201527f4c45524332303a2054696d65206c6f636b20696e2070726f677265737300000060448201526064016106a5565b600b80547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff001690556000600a8190556040517f3eb72350c9c7928d31e9ab450bfff2c159434aa4b82658a7d8eae7f109cb4e7b9190a1565b6006546001600160a01b0316336001600160a01b0316146114035760405162461bcd60e51b815260206004820152601960248201527f4c45524332303a204d7573742062652063616e6469746174650000000000000060448201526064016106a5565b600754815160208301201461145a5760405162461bcd60e51b815260206004820152601360248201527f4c45524332303a20496e76616c6964206b65790000000000000000000000000060448201526064016106a5565b6006546040516001600160a01b03909116907fb94bba6936ec7f75ee931dadf6e1a4d66b43d09b6fa0178fb13df9b77fb5841f90600090a25060068054600580547fffffffffffffffffffffff0000000000000000000000000000000000000000ff166101006001600160a01b038416021790557fffffffffffffffffffffffff0000000000000000000000000000000000000000169055565b60055461010090046001600160a01b0316336001600160a01b03161461155c5760405162461bcd60e51b815260206004820152601e60248201527f4c45524332303a204d757374206265207265636f766572792061646d696e000060448201526064016106a5565b600a54156115ac5760405162461bcd60e51b815260206004820181905260248201527f4c45524332303a205475726e4f666620616c72656164792070726f706f73656460448201526064016106a5565b600b5460ff166115fe5760405162461bcd60e51b815260206004820152601c60248201527f4c45524332303a204c6f73736c65737320616c7265616479206f66660000000060448201526064016106a5565b60095461160b9042611e19565b600a8190556040519081527f6ca688e6e3ddd707280140b2bf0106afe883689b6c74e68cbd517576dd9c245a9060200160405180910390a1565b6001600160a01b038083166000908152600160209081526040808320938516835292905220545b92915050565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166117505760405162461bcd60e51b815260206004820152602660248201527f4c45524332303a207472616e736665722066726f6d20746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016106a5565b6001600160a01b038316600090815260208190526040902054818110156117df5760405162461bcd60e51b815260206004820152602760248201527f4c45524332303a207472616e7366657220616d6f756e7420657863656564732060448201527f62616c616e63650000000000000000000000000000000000000000000000000060648201526084016106a5565b6117e98282611e06565b6001600160a01b03808616600090815260208190526040808220939093559085168152908120805484929061181f908490611e19565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161186b91815260200190565b60405180910390a350505050565b6001600160a01b0382166118cf5760405162461bcd60e51b815260206004820181905260248201527f4c45524332303a206d696e7420746f20746865207a65726f206164647265737360448201526064016106a5565b80600260008282546118e19190611e19565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6001600160a01b0382166119b45760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f2061646472657360448201527f730000000000000000000000000000000000000000000000000000000000000060648201526084016106a5565b6001600160a01b03821660009081526020819052604090205481811015611a435760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e60448201527f636500000000000000000000000000000000000000000000000000000000000060648201526084016106a5565b6001600160a01b0383166000908152602081905260408120838303905560028054849290611a72908490611e06565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020016116c7565b600060208083528351808285015260005b81811015611ae257858101830151858201604001528201611ac6565b5060006040828601015260407fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0601f8301168501019250505092915050565b80356001600160a01b0381168114611b3857600080fd5b919050565b60008060408385031215611b5057600080fd5b611b5983611b21565b946020939093013593505050565b600080600060608486031215611b7c57600080fd5b611b8584611b21565b9250611b9360208501611b21565b9150604084013590509250925092565b600060208284031215611bb557600080fd5b611bbe82611b21565b9392505050565b600060208284031215611bd757600080fd5b5035919050565b60008060208385031215611bf157600080fd5b823567ffffffffffffffff80821115611c0957600080fd5b818501915085601f830112611c1d57600080fd5b813581811115611c2c57600080fd5b8660208260051b8501011115611c4157600080fd5b60209290920196919550909350505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b600060208284031215611c9457600080fd5b813567ffffffffffffffff80821115611cac57600080fd5b818401915084601f830112611cc057600080fd5b813581811115611cd257611cd2611c53565b604051601f82017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0908116603f01168101908382118183101715611d1857611d18611c53565b81604052828152876020848701011115611d3157600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060408385031215611d6457600080fd5b611d6d83611b21565b9150611d7b60208401611b21565b90509250929050565b600181811c90821680611d9857607f821691505b602082108103611dd1577f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b8181038181111561166c5761166c611dd7565b8082018082111561166c5761166c611dd7565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b60007fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203611e8c57611e8c611dd7565b506001019056fea2646970667358221220eb23d28c07e6fd7d068d45610f56f4f4f931bc77839a4a39c998a65a9c152e7864736f6c63430008130033
Verified Source Code Partial Match
Compiler: v0.8.19+commit.7dd6d404
EVM: paris
Optimization: Yes (10000 runs)
LERC20MintableBurnable.sol 394 lines
/**
*Submitted for verification at Etherscan.io on 2023-05-11
*/
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
/**
* @dev Provides information about the current execution context, including the
* sender of the transaction and its data. While these are generally available
* via msg.sender and msg.data, they should not be accessed in such a direct
* manner, since when dealing with meta-transactions the account sending and
* paying for execution may not be the actual sender (as far as an application
* is concerned).
*
* This contract is only required for intermediate, library-like contracts.
*/
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
interface ILERC20 {
function name() external view returns (string memory);
function admin() external view returns (address);
function getAdmin() external view returns (address);
function symbol() external view returns (string memory);
function decimals() external view returns (uint8);
function totalSupply() external view returns (uint256);
function balanceOf(address _account) external view returns (uint256);
function transfer(address _recipient, 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 _sender, address _recipient, uint256 _amount) external returns (bool);
function increaseAllowance(address _spender, uint256 _addedValue) external returns (bool);
function decreaseAllowance(address _spender, uint256 _subtractedValue) external returns (bool);
function transferOutBlacklistedFunds(address[] calldata _from) external;
function setLosslessAdmin(address _newAdmin) external;
function transferRecoveryAdminOwnership(address _candidate, bytes32 _keyHash) external;
function acceptRecoveryAdminOwnership(bytes memory _key) external;
function proposeLosslessTurnOff() external;
function executeLosslessTurnOff() external;
function executeLosslessTurnOn() external;
event Transfer(address indexed _from, address indexed _to, uint256 _value);
event Approval(address indexed _owner, address indexed _spender, uint256 _value);
event NewAdmin(address indexed _newAdmin);
event NewRecoveryAdminProposal(address indexed _candidate);
event NewRecoveryAdmin(address indexed _newAdmin);
event LosslessTurnOffProposal(uint256 _turnOffDate);
event LosslessOff();
event LosslessOn();
}
interface ILssController {
// function getLockedAmount(ILERC20 _token, address _account) returns (uint256);
// function getAvailableAmount(ILERC20 _token, address _account) external view returns (uint256 amount);
function whitelist(address _adr) external view returns (bool);
function blacklist(address _adr) external view returns (bool);
function admin() external view returns (address);
function recoveryAdmin() external view returns (address);
function setAdmin(address _newAdmin) external;
function setRecoveryAdmin(address _newRecoveryAdmin) external;
function setWhitelist(address[] calldata _addrList, bool _value) external;
function setBlacklist(address[] calldata _addrList, bool _value) external;
function beforeTransfer(address _sender, address _recipient, uint256 _amount) external;
function beforeTransferFrom(address _msgSender, address _sender, address _recipient, uint256 _amount) external;
function beforeApprove(address _sender, address _spender, uint256 _amount) external;
function beforeIncreaseAllowance(address _msgSender, address _spender, uint256 _addedValue) external;
function beforeDecreaseAllowance(address _msgSender, address _spender, uint256 _subtractedValue) external;
function beforeMint(address _to, uint256 _amount) external;
function beforeBurn(address _account, uint256 _amount) external;
function afterTransfer(address _sender, address _recipient, uint256 _amount) external;
event AdminChange(address indexed _newAdmin);
event RecoveryAdminChange(address indexed _newAdmin);
event PauseAdminChange(address indexed _newAdmin);
}
contract LERC20 is Context, ILERC20 {
mapping (address => uint256) private _balances;
mapping (address => mapping (address => uint256)) private _allowances;
uint256 private _totalSupply;
string private _name;
string private _symbol;
uint8 private _decimals;
address public recoveryAdmin;
address private recoveryAdminCandidate;
bytes32 private recoveryAdminKeyHash;
address override public admin;
uint256 public timelockPeriod;
uint256 public losslessTurnOffTimestamp;
bool public isLosslessOn = false;
ILssController public lossless;
constructor(uint256 totalSupply_, string memory name_, string memory symbol_, uint8 decimals_, address admin_, address recoveryAdmin_, uint256 timelockPeriod_, address lossless_) {
_mint(_msgSender(), totalSupply_);
_name = name_;
_symbol = symbol_;
_decimals = decimals_;
admin = admin_;
recoveryAdmin = recoveryAdmin_;
recoveryAdminCandidate = address(0);
recoveryAdminKeyHash = "";
timelockPeriod = timelockPeriod_;
losslessTurnOffTimestamp = 0;
lossless = ILssController(lossless_);
}
// --- LOSSLESS modifiers ---
modifier lssAprove(address spender, uint256 amount) {
if (isLosslessOn) {
lossless.beforeApprove(_msgSender(), spender, amount);
}
_;
}
modifier lssTransfer(address recipient, uint256 amount) {
if (isLosslessOn) {
lossless.beforeTransfer(_msgSender(), recipient, amount);
}
_;
}
modifier lssTransferFrom(address sender, address recipient, uint256 amount) {
if (isLosslessOn) {
lossless.beforeTransferFrom(_msgSender(),sender, recipient, amount);
}
_;
}
modifier lssIncreaseAllowance(address spender, uint256 addedValue) {
if (isLosslessOn) {
lossless.beforeIncreaseAllowance(_msgSender(), spender, addedValue);
}
_;
}
modifier lssDecreaseAllowance(address spender, uint256 subtractedValue) {
if (isLosslessOn) {
lossless.beforeDecreaseAllowance(_msgSender(), spender, subtractedValue);
}
_;
}
modifier onlyRecoveryAdmin() {
require(_msgSender() == recoveryAdmin, "LERC20: Must be recovery admin");
_;
}
// --- LOSSLESS management ---
function transferOutBlacklistedFunds(address[] calldata from) override external {
require(_msgSender() == address(lossless), "LERC20: Only lossless contract");
uint256 fromLength = from.length;
uint256 totalAmount = 0;
for (uint256 i = 0; i < fromLength; i++) {
address fromAddress = from[i];
uint256 fromBalance = _balances[fromAddress];
_balances[fromAddress] = 0;
totalAmount += fromBalance;
emit Transfer(fromAddress, address(lossless), fromBalance);
}
_balances[address(lossless)] += totalAmount;
}
function setLosslessAdmin(address newAdmin) override external onlyRecoveryAdmin {
require(newAdmin != admin, "LERC20: Cannot set same address");
emit NewAdmin(newAdmin);
admin = newAdmin;
}
function transferRecoveryAdminOwnership(address candidate, bytes32 keyHash) override external onlyRecoveryAdmin {
recoveryAdminCandidate = candidate;
recoveryAdminKeyHash = keyHash;
emit NewRecoveryAdminProposal(candidate);
}
function acceptRecoveryAdminOwnership(bytes memory key) override external {
require(_msgSender() == recoveryAdminCandidate, "LERC20: Must be canditate");
require(keccak256(key) == recoveryAdminKeyHash, "LERC20: Invalid key");
emit NewRecoveryAdmin(recoveryAdminCandidate);
recoveryAdmin = recoveryAdminCandidate;
recoveryAdminCandidate = address(0);
}
function proposeLosslessTurnOff() override external onlyRecoveryAdmin {
require(losslessTurnOffTimestamp == 0, "LERC20: TurnOff already proposed");
require(isLosslessOn, "LERC20: Lossless already off");
losslessTurnOffTimestamp = block.timestamp + timelockPeriod;
emit LosslessTurnOffProposal(losslessTurnOffTimestamp);
}
function executeLosslessTurnOff() override external onlyRecoveryAdmin {
require(losslessTurnOffTimestamp != 0, "LERC20: TurnOff not proposed");
require(losslessTurnOffTimestamp <= block.timestamp, "LERC20: Time lock in progress");
isLosslessOn = false;
losslessTurnOffTimestamp = 0;
emit LosslessOff();
}
function executeLosslessTurnOn() override external onlyRecoveryAdmin {
require(!isLosslessOn, "LERC20: Lossless already on");
losslessTurnOffTimestamp = 0;
isLosslessOn = true;
emit LosslessOn();
}
function getAdmin() override public view virtual returns (address) {
return admin;
}
// --- ERC20 methods ---
function name() override public view virtual returns (string memory) {
return _name;
}
function symbol() override public view virtual returns (string memory) {
return _symbol;
}
function decimals() override public view virtual returns (uint8) {
return _decimals;
}
function totalSupply() public view virtual override returns (uint256) {
return _totalSupply;
}
function balanceOf(address account) public view virtual override returns (uint256) {
return _balances[account];
}
function transfer(address recipient, uint256 amount) public virtual override lssTransfer(recipient, amount) returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(address owner, address spender) public view virtual override returns (uint256) {
return _allowances[owner][spender];
}
function approve(address spender, uint256 amount) public virtual override lssAprove(spender, amount) returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(address sender, address recipient, uint256 amount) public virtual override lssTransferFrom(sender, recipient, amount) returns (bool) {
uint256 currentAllowance = _allowances[sender][_msgSender()];
require(currentAllowance >= amount, "LERC20: transfer amount exceeds allowance");
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), currentAllowance - amount);
return true;
}
function increaseAllowance(address spender, uint256 addedValue) override public virtual lssIncreaseAllowance(spender, addedValue) returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) override public virtual lssDecreaseAllowance(spender, subtractedValue) returns (bool) {
uint256 currentAllowance = _allowances[_msgSender()][spender];
require(currentAllowance >= subtractedValue, "LERC20: decreased allowance below zero");
_approve(_msgSender(), spender, currentAllowance - subtractedValue);
return true;
}
function _transfer(address sender, address recipient, uint256 amount) internal virtual {
require(sender != address(0), "LERC20: transfer from the zero address");
uint256 senderBalance = _balances[sender];
require(senderBalance >= amount, "LERC20: transfer amount exceeds balance");
_balances[sender] = senderBalance - amount;
_balances[recipient] += amount;
emit Transfer(sender, recipient, amount);
}
function _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "LERC20: mint to the zero address");
_totalSupply += amount;
// Cannot overflow because the sum of all user
// balances can't exceed the max uint256 value.
unchecked {
_balances[account] += amount;
}
emit Transfer(address(0), account, amount);
}
function _burn(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: burn from the zero address");
uint256 accountBalance = _balances[account];
require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
unchecked {
_balances[account] = accountBalance - amount;
}
_totalSupply -= amount;
emit Transfer(account, address(0), amount);
}
function _approve(address owner, address spender, uint256 amount) internal virtual {
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
}
contract LERC20MintableBurnable is Context, LERC20 {
constructor(
uint256 totalSupply_,
string memory name_,
string memory symbol_,
uint8 decimals_,
address admin_,
address recoveryAdmin_,
uint256 timelockPeriod_,
address lossless_
) LERC20(
totalSupply_,
name_,
symbol_,
decimals_,
admin_,
recoveryAdmin_,
timelockPeriod_,
lossless_
) {}
modifier lssBurn(address account, uint256 amount) {
if (isLosslessOn) {
lossless.beforeBurn(account, amount);
}
_;
}
modifier lssMint(address account, uint256 amount) {
if (isLosslessOn) {
lossless.beforeMint(account, amount);
}
_;
}
function burn(uint256 amount) public virtual lssBurn(_msgSender(), amount) {
_burn(_msgSender(), amount);
}
function burnFrom(address account, uint256 amount) public virtual lssBurn(account, amount) {
uint256 currentAllowance = allowance(account, _msgSender());
require(currentAllowance >= amount, "ERC20: burn amount exceeds allowance");
unchecked {
_approve(account, _msgSender(), currentAllowance - amount);
}
_burn(account, amount);
}
function mint(address to, uint256 amount) public virtual lssMint(to, amount) {
require(_msgSender() == admin, "LERC20: Must be admin");
_mint(to, amount);
}
/// @notice This function sets a new lossless controller
/// @dev Only can be called by the Recovery admin
/// @param _newLossless Address corresponding to the new Lossless Controller
function setLossless(address _newLossless) external onlyRecoveryAdmin {
require(_newLossless != address(0), "LERC20: Cannot set address(0)");
lossless = ILssController(_newLossless);
}
}
Read Contract
admin 0xf851a440 → address
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getAdmin 0x6e9960c3 → address
isLosslessOn 0xccfa214f → bool
lossless 0x34f6ebf5 → address
losslessTurnOffTimestamp 0x61086b00 → uint256
name 0x06fdde03 → string
recoveryAdmin 0x5f6529a3 → address
symbol 0x95d89b41 → string
timelockPeriod 0x2ecaf675 → uint256
totalSupply 0x18160ddd → uint256
Write Contract 16 functions
These functions modify contract state and require a wallet transaction to execute.
acceptRecoveryAdminOwnership 0xb5c22877
bytes key
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
burn 0x42966c68
uint256 amount
burnFrom 0x79cc6790
address account
uint256 amount
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
executeLosslessTurnOff 0xb38fe957
No parameters
executeLosslessTurnOn 0x5b8a194a
No parameters
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
mint 0x40c10f19
address to
uint256 amount
proposeLosslessTurnOff 0xd6e242b8
No parameters
setLossless 0xaea0cf49
address _newLossless
setLosslessAdmin 0x2baa3c9e
address newAdmin
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOutBlacklistedFunds 0x936af911
address[] from
transferRecoveryAdminOwnership 0x93310ffe
address candidate
bytes32 keyHash
Recent Transactions
No transactions found for this address