Created
December 22, 2020 16:57
-
-
Save bet02024/1eae558eb4e8e80048dd57de2dba9086 to your computer and use it in GitHub Desktop.
Created using remix-ide: Realtime Ethereum Contract Compiler and Runtime. Load this file by pasting this gists URL or ID at https://remix.ethereum.org/#version=soljson-v0.6.2+commit.bacdbe57.js&optimize=false&runs=200&gist=
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// SPDX-License-Identifier: MIT | |
pragma solidity ^0.6.0; | |
import "./Ownable.sol"; | |
/** | |
* @title Blacklistable Token | |
* @dev Allows accounts to be blacklisted by a "blacklister" role | |
*/ | |
contract Blacklistable is Ownable { | |
address public blacklister; | |
mapping(address => bool) internal blacklisted; | |
event Blacklisted(address indexed _account); | |
event UnBlacklisted(address indexed _account); | |
event BlacklisterChanged(address indexed newBlacklister); | |
/** | |
* @dev Throws if called by any account other than the blacklister | |
*/ | |
modifier onlyBlacklister() { | |
require(msg.sender == blacklister); | |
_; | |
} | |
/** | |
* @dev Throws if argument account is blacklisted | |
* @param _account The address to check | |
*/ | |
modifier notBlacklisted(address _account) { | |
require(blacklisted[_account] == false); | |
_; | |
} | |
/** | |
* @dev Checks if account is blacklisted | |
* @param _account The address to check | |
*/ | |
function isBlacklisted(address _account) public view returns (bool) { | |
return blacklisted[_account]; | |
} | |
/** | |
* @dev Adds account to blacklist | |
* @param _account The address to blacklist | |
*/ | |
function blacklist(address _account) public onlyBlacklister { | |
blacklisted[_account] = true; | |
emit Blacklisted(_account); | |
} | |
/** | |
* @dev Removes account from blacklist | |
* @param _account The address to remove from the blacklist | |
*/ | |
function unBlacklist(address _account) public onlyBlacklister { | |
blacklisted[_account] = false; | |
emit UnBlacklisted(_account); | |
} | |
function updateBlacklister(address _newBlacklister) public onlyOwner { | |
require(_newBlacklister != address(0)); | |
blacklister = _newBlacklister; | |
emit BlacklisterChanged(blacklister); | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// SPDX-License-Identifier: MIT | |
pragma solidity ^0.6.0; | |
import 'https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/ERC20.sol'; | |
import "./Ownable.sol"; | |
import './Blacklistable.sol'; | |
import "./Pausable.sol"; | |
/** | |
* @title CarbonToken | |
* @dev ERC20 Token backed by C02 bonds | |
*/ | |
contract CarbonToken is Ownable, ERC20, Pausable, Blacklistable { | |
using SafeMath for uint256; | |
string public currency; | |
address public masterMinter; | |
bool internal initialized; | |
mapping(address => uint256) internal balances; | |
mapping(address => mapping(address => uint256)) internal allowed; | |
uint256 internal totalSupply_ = 0; | |
mapping(address => bool) internal minters; | |
mapping(address => uint256) internal minterAllowed; | |
event Mint(address indexed minter, address indexed to, uint256 amount); | |
event Burn(address indexed burner, uint256 amount); | |
event MinterConfigured(address indexed minter, uint256 minterAllowedAmount); | |
event MinterRemoved(address indexed oldMinter); | |
event MasterMinterChanged(address indexed newMasterMinter); | |
constructor (string memory _name, string memory _symbol) public ERC20(_name, _symbol){ | |
_setupDecimals(3); | |
} | |
function initialize( | |
string memory _currency, | |
uint8 _decimals, | |
address _masterMinter, | |
address _pauser, | |
address _blacklister, | |
address _owner | |
) public { | |
require(!initialized); | |
require(_masterMinter != address(0)); | |
require(_pauser != address(0)); | |
require(_blacklister != address(0)); | |
require(_blacklister != address(0)); | |
require(_owner != address(0)); | |
_setupDecimals(_decimals); | |
currency = _currency; | |
masterMinter = _masterMinter; | |
pauser = _pauser; | |
blacklister = _blacklister; | |
setOwner(_owner); | |
initialized = true; | |
} | |
/** | |
* @dev Throws if called by any account other than a minter | |
*/ | |
modifier onlyMinters() { | |
require(minters[msg.sender] == true); | |
_; | |
} | |
/** | |
* @dev Function to mint tokens | |
* @param _to The address that will receive the minted tokens. | |
* @param _amount The amount of tokens to mint. Must be less than or equal to the minterAllowance of the caller. | |
* @return A boolean that indicates if the operation was successful. | |
*/ | |
function mint(address _to, uint256 _amount) whenNotPaused onlyMinters notBlacklisted(msg.sender) notBlacklisted(_to) public returns (bool) { | |
require(_to != address(0)); | |
require(_amount > 0); | |
uint256 mintingAllowedAmount = minterAllowed[msg.sender]; | |
require(_amount <= mintingAllowedAmount); | |
totalSupply_ = totalSupply_.add(_amount); | |
balances[_to] = balances[_to].add(_amount); | |
minterAllowed[msg.sender] = mintingAllowedAmount.sub(_amount); | |
emit Mint(msg.sender, _to, _amount); | |
emit Transfer(address(0x0), _to, _amount); | |
return true; | |
} | |
/** | |
* @dev Throws if called by any account other than the masterMinter | |
*/ | |
modifier onlyMasterMinter() { | |
require(msg.sender == masterMinter); | |
_; | |
} | |
/** | |
* @dev Get minter allowance for an account | |
* @param minter The address of the minter | |
*/ | |
function minterAllowance(address minter) public view returns (uint256) { | |
return minterAllowed[minter]; | |
} | |
/** | |
* @dev Checks if account is a minter | |
* @param account The address to check | |
*/ | |
function isMinter(address account) public view returns (bool) { | |
return minters[account]; | |
} | |
/** | |
* @dev Get allowed amount for an account | |
* @param owner address The account owner | |
* @param spender address The account spender | |
*/ | |
function allowance(address owner, address spender) public override view returns (uint256) { | |
return allowed[owner][spender]; | |
} | |
/** | |
* @dev Get totalSupply of token | |
*/ | |
function totalSupply() public override view returns (uint256) { | |
return totalSupply_; | |
} | |
/** | |
* @dev Get token balance of an account | |
* @param account address The account | |
*/ | |
function balanceOf(address account) public view override returns (uint256) { | |
return balances[account]; | |
} | |
/** | |
* @dev Adds blacklisted check to approve | |
* @return True if the operation was successful. | |
*/ | |
function approve(address _spender, uint256 _value) whenNotPaused notBlacklisted(msg.sender) notBlacklisted(_spender) public override returns (bool) { | |
allowed[msg.sender][_spender] = _value; | |
emit Approval(msg.sender, _spender, _value); | |
return true; | |
} | |
/** | |
* @dev Transfer tokens from one address to another. | |
* @param _from address The address which you want to send tokens from | |
* @param _to address The address which you want to transfer to | |
* @param _value uint256 the amount of tokens to be transferred | |
* @return bool success | |
*/ | |
function transferFrom(address _from, address _to, uint256 _value) whenNotPaused notBlacklisted(_to) notBlacklisted(msg.sender) notBlacklisted(_from) public override returns (bool) { | |
require(_to != address(0)); | |
require(_value <= balances[_from]); | |
require(_value <= allowed[_from][msg.sender]); | |
balances[_from] = balances[_from].sub(_value); | |
balances[_to] = balances[_to].add(_value); | |
allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value); | |
emit Transfer(_from, _to, _value); | |
return true; | |
} | |
/** | |
* @dev transfer token for a specified address | |
* @param _to The address to transfer to. | |
* @param _value The amount to be transferred. | |
* @return bool success | |
*/ | |
function transfer(address _to, uint256 _value) whenNotPaused notBlacklisted(msg.sender) notBlacklisted(_to) public override returns (bool) { | |
require(_to != address(0)); | |
require(_value <= balances[msg.sender]); | |
balances[msg.sender] = balances[msg.sender].sub(_value); | |
balances[_to] = balances[_to].add(_value); | |
emit Transfer(msg.sender, _to, _value); | |
return true; | |
} | |
/** | |
* @dev Function to add/update a new minter | |
* @param minter The address of the minter | |
* @param minterAllowedAmount The minting amount allowed for the minter | |
* @return True if the operation was successful. | |
*/ | |
function configureMinter(address minter, uint256 minterAllowedAmount) whenNotPaused onlyMasterMinter public returns (bool) { | |
minters[minter] = true; | |
minterAllowed[minter] = minterAllowedAmount; | |
emit MinterConfigured(minter, minterAllowedAmount); | |
return true; | |
} | |
/** | |
* @dev Function to remove a minter | |
* @param minter The address of the minter to remove | |
* @return True if the operation was successful. | |
*/ | |
function removeMinter(address minter) onlyMasterMinter public returns (bool) { | |
minters[minter] = false; | |
minterAllowed[minter] = 0; | |
emit MinterRemoved(minter); | |
return true; | |
} | |
/** | |
* @dev allows a minter to burn some of its own tokens | |
* Validates that caller is a minter and that sender is not blacklisted | |
* amount is less than or equal to the minter's account balance | |
* @param _amount uint256 the amount of tokens to be burned | |
*/ | |
function burn(uint256 _amount) whenNotPaused onlyMinters notBlacklisted(msg.sender) public { | |
uint256 balance = balances[msg.sender]; | |
require(_amount > 0); | |
require(balance >= _amount); | |
totalSupply_ = totalSupply_.sub(_amount); | |
balances[msg.sender] = balance.sub(_amount); | |
emit Burn(msg.sender, _amount); | |
emit Transfer(msg.sender, address(0), _amount); | |
} | |
function updateMasterMinter(address _newMasterMinter) onlyOwner public { | |
require(_newMasterMinter != address(0)); | |
masterMinter = _newMasterMinter; | |
emit MasterMinterChanged(masterMinter); | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// SPDX-License-Identifier: MIT | |
pragma solidity ^0.6.0; | |
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/release-v3.2.0/contracts/token/ERC721/ERC721.sol"; | |
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/release-v3.2.0/contracts/token/ERC721/ERC721Burnable.sol"; | |
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/release-v3.2.0/contracts/token/ERC721/ERC721Pausable.sol"; | |
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/release-v3.2.0/contracts/token/ERC721/ERC721Holder.sol"; | |
import './Ownable.sol'; | |
contract M2Coin is ERC721, ERC721Burnable, ERC721Holder, Ownable { | |
//mapping (uint256 => string) private _tokenJson; | |
//mapping(address => bool) internal minters; | |
//mapping(address => uint256) internal minterAllowed; | |
//event Mint(address indexed minter, address indexed to, uint256 amount); | |
//event Burn(address indexed burner, uint256 amount); | |
constructor (string memory name, string memory symbol, address _owner) public ERC721(name, symbol){ | |
setOwner(_owner); | |
} | |
mapping(address => bool) internal minters; | |
mapping (uint256 => uint256) internal lands; | |
modifier onlyMinters() { | |
require(minters[msg.sender] == true); | |
_; | |
} | |
function landIdFromToken(uint256 tokenId) public view returns (uint256 ) { | |
require(_exists(tokenId), "ERC721Metadata: URI query for nonexistent token"); | |
return lands[tokenId]; | |
} | |
function isMinter(address account) public view returns (bool) { | |
return minters[account]; | |
} | |
function configureMinter(address minter) public onlyOwner returns (bool) { | |
minters[minter] = true; | |
return true; | |
} | |
function removeMinter(address minter) public onlyOwner returns (bool) { | |
minters[minter] = false; | |
return true; | |
} | |
function mintTokensWithTokenURI(address to, uint256 totalTokens, uint256 landId, string memory tokenURI) public onlyMinters returns (bool) { | |
uint256 currentTokens = totalSupply(); | |
for (uint256 tokenId = currentTokens + 1; tokenId <= currentTokens + totalTokens + 1; tokenId++) { | |
_safeMint(to, tokenId, ""); | |
_setTokenURI(tokenId, tokenURI); | |
lands[tokenId] = landId; | |
} | |
return true; | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// SPDX-License-Identifier: MIT | |
pragma solidity ^0.6.0; | |
/** | |
* @title Ownable | |
* @dev The Ownable contract from https://github.com/zeppelinos/labs/blob/master/upgradeability_ownership/contracts/ownership/Ownable.sol | |
* branch: master commit: 3887ab77b8adafba4a26ace002f3a684c1a3388b modified to: | |
* 1) Add emit prefix to OwnershipTransferred event (7/13/18) | |
* 2) Replace constructor with constructor syntax (7/13/18) | |
* 3) consolidate OwnableStorage into this contract | |
*/ | |
contract Ownable { | |
// Owner of the contract | |
address private _owner; | |
/** | |
* @dev Event to show ownership has been transferred | |
* @param previousOwner representing the address of the previous owner | |
* @param newOwner representing the address of the new owner | |
*/ | |
event OwnershipTransferred(address previousOwner, address newOwner); | |
/** | |
* @dev The constructor sets the original owner of the contract to the sender account. | |
*/ | |
constructor() public { | |
setOwner(msg.sender); | |
} | |
/** | |
* @dev Tells the address of the owner | |
* @return the address of the owner | |
*/ | |
function owner() public view returns (address) { | |
return _owner; | |
} | |
/** | |
* @dev Sets a new owner address | |
*/ | |
function setOwner(address newOwner) internal { | |
_owner = newOwner; | |
} | |
/** | |
* @dev Throws if called by any account other than the owner. | |
*/ | |
modifier onlyOwner() { | |
require(msg.sender == owner()); | |
_; | |
} | |
/** | |
* @dev Allows the current owner to transfer control of the contract to a newOwner. | |
* @param newOwner The address to transfer ownership to. | |
*/ | |
function transferOwnership(address newOwner) public onlyOwner { | |
require(newOwner != address(0)); | |
emit OwnershipTransferred(owner(), newOwner); | |
setOwner(newOwner); | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// SPDX-License-Identifier: MIT | |
pragma solidity ^0.6.0; | |
import "./Ownable.sol"; | |
/** | |
* @title Pausable | |
* @dev Base contract which allows children to implement an emergency stop mechanism. | |
* Based on openzeppelin tag v1.10.0 commit: feb665136c0dae9912e08397c1a21c4af3651ef3 | |
* Modifications: | |
* 1) Added pauser role, switched pause/unpause to be onlyPauser (6/14/2018) | |
* 2) Removed whenNotPause/whenPaused from pause/unpause (6/14/2018) | |
* 3) Removed whenPaused (6/14/2018) | |
* 4) Switches ownable library to use zeppelinos (7/12/18) | |
* 5) Remove constructor (7/13/18) | |
*/ | |
contract Pausable is Ownable { | |
event Pause(); | |
event Unpause(); | |
event PauserChanged(address indexed newAddress); | |
address public pauser; | |
bool public paused = false; | |
/** | |
* @dev Modifier to make a function callable only when the contract is not paused. | |
*/ | |
modifier whenNotPaused() { | |
require(!paused); | |
_; | |
} | |
/** | |
* @dev throws if called by any account other than the pauser | |
*/ | |
modifier onlyPauser() { | |
require(msg.sender == pauser); | |
_; | |
} | |
/** | |
* @dev called by the owner to pause, triggers stopped state | |
*/ | |
function pause() onlyPauser public { | |
paused = true; | |
emit Pause(); | |
} | |
/** | |
* @dev called by the owner to unpause, returns to normal state | |
*/ | |
function unpause() onlyPauser public { | |
paused = false; | |
emit Unpause(); | |
} | |
/** | |
* @dev update the pauser role | |
*/ | |
function updatePauser(address _newPauser) onlyOwner public { | |
require(_newPauser != address(0)); | |
pauser = _newPauser; | |
emit PauserChanged(pauser); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment