Skip to content

Instantly share code, notes, and snippets.

@akirill0v
Forked from anonymous/AbstractToken.sol
Created June 21, 2017 05:02
Show Gist options
  • Save akirill0v/2c3cee1fc30fe5d15ae87234ee75b478 to your computer and use it in GitHub Desktop.
Save akirill0v/2c3cee1fc30fe5d15ae87234ee75b478 to your computer and use it in GitHub Desktop.
Created using browser-solidity: Realtime Ethereum Contract Compiler and Runtime. Load this file by pasting this gists URL or ID at https://ethereum.github.io/browser-solidity/#version=soljson-v0.4.11+commit.68ef5810.js&optimize=undefined&gist=
pragma solidity ^0.4.6;
/// Implements ERC 20 Token standard: https://github.com/ethereum/EIPs/issues/20
/// @title Abstract token contract - Functions to be implemented by token contracts.
contract AbstractToken {
// This is not an abstract function, because solc won't recognize generated getter functions for public variables as functions
function totalSupply() constant returns (uint256 supply) {}
function balanceOf(address owner) constant returns (uint256 balance);
function transfer(address to, uint256 value) returns (bool success);
function transferFrom(address from, address to, uint256 value) returns (bool success);
function approve(address spender, uint256 value) returns (bool success);
function allowance(address owner, address spender) constant returns (uint256 remaining);
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
event Issuance(address indexed to, uint256 value);
}
pragma solidity ^0.4.8;
import "./SafeMath.sol";
import "./HumaniqToken.sol";
contract Emission is SafeMath{
enum State{
NotRegistered,
Registered,
SentTransaction,
ReceivedTransaction,
DidBoth
}
modifier emissionFinished() {
// emission is going until k_max is achieved (according whitepaper)
if (amountRegistrations > maxRegistered) {
throw;
}
_;
}
HumaniqToken public humaniqToken;
mapping(address => State) statuses;
// uint64 type was choosen as number of people on Earth is less than 2*10^19
mapping(address => uint64) numberRegistration;
//TODO coeffs should dynamically change by community (WTF?)
mapping(uint8 => uint) coeffs;
uint64 amountRegistrations = 0;
uint maxRegistered = 1000; // need to be calculated from ICO + Pre ICO tokens, as sum/125
function Emission(){
humaniqToken = new HumaniqToken(msg.sender);
coeffs[3] = 1;
coeffs[2] = 1;
coeffs[5] = 1;
}
/// returns True if tokens are successfully sent
function fixRegistration()
emissionFinished
returns (bool){
uint amount = emissionAmount(numberRegistration[msg.sender]);
if(statuses[msg.sender] == State.NotRegistered && humaniqToken.issueTokens(msg.sender, amount)){
//TODO think about numeration: start number with 1 or 0
amountRegistrations++;
numberRegistration[msg.sender] = amountRegistrations;
statuses[msg.sender] = State.Registered;
return true;
}
return false;
}
function emissionAmount(uint registrationNumber) returns (uint){
return sub(860, mul(registrationNumber, div(720, maxRegistered)));
}
function getBonusForReceivedTx()
emissionFinished{
if(statuses[msg.sender] != State.ReceivedTransaction && statuses[msg.sender] != State.NotRegistered
&& statuses[msg.sender] != State.DidBoth){
// TODO make "round" instead of "floor"
uint bonus = div(mul(4, mul(numberRegistration[msg.sender], coeffs[2])), 100);
humaniqToken.issueTokens(msg.sender, min(bonus, 15 * getExchangeRate()));
if(statuses[msg.sender] == State.SentTransaction)
statuses[msg.sender] = State.DidBoth;
else
statuses[msg.sender] = State.ReceivedTransaction;
}
}
function getBonusForSentTx()
emissionFinished{
if(statuses[msg.sender] != State.SentTransaction && statuses[msg.sender] != State.NotRegistered
&& statuses[msg.sender] != State.DidBoth){
// TODO make "round" instead of "floor"
// TODO we have 3 bonuses for sent transcation for 1, 2, 3 months
uint bonus = div(mul(5, mul(numberRegistration[msg.sender], coeffs[5])), 100);
humaniqToken.issueTokens(msg.sender, min(bonus, 15 * getExchangeRate()));
if(statuses[msg.sender] == State.ReceivedTransaction)
statuses[msg.sender] = State.DidBoth;
else
statuses[msg.sender] = State.SentTransaction;
}
}
function min(uint a, uint b) returns (uint){
if(a > b)
return b;
return a;
}
/// TODO add checking for "current rate < average rate for the last week."
function getExchangeRate() returns (uint){
return 1;
}
}
pragma solidity ^0.4.6;
import "./StandardToken.sol";
import "./SafeMath.sol";
/// @title Token contract - Implements Standard Token Interface with HumaniQ features.
/// @author Evgeny Yurtaev - <[email protected]>
/// @author Alexey Bashlykov - <[email protected]>
contract HumaniqToken is StandardToken, SafeMath {
/*
* External contracts
*/
address public minter;
/*
* Token meta data
*/
string constant public name = "Humaniq";
string constant public symbol = "HMQ";
uint8 constant public decimals = 8;
// Address of the founder of Humaniq.
address public founder = 0xc890b1f532e674977dfdb791cafaee898dfa9671;
// Multisig address of the founders
address public multisig = 0xa2c9a7578e2172f32a36c5c0e49d64776f9e7883;
// Address where all tokens created during ICO stage initially allocated
address constant public allocationAddressICO = 0x1111111111111111111111111111111111111111;
// Address where all tokens created during preICO stage initially allocated
address constant public allocationAddressPreICO = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF;
// 31 820 314 tokens were minted during preICO
uint constant public preICOSupply = mul(31820314, 100000000);
// 131 038 286 tokens were minted during ICO
uint constant public ICOSupply = mul(131038286, 100000000);
// Max number of tokens that can be minted
uint public maxTotalSupply;
/*
* Modifiers
*/
modifier onlyFounder() {
// Only founder is allowed to do this action.
if (msg.sender != founder) {
throw;
}
_;
}
modifier onlyMinter() {
// Only minter is allowed to proceed.
if (msg.sender != minter) {
throw;
}
_;
}
/*
* Contract functions
*/
/// @dev Crowdfunding contract issues new tokens for address. Returns success.
/// @param _for Address of receiver.
/// @param tokenCount Number of tokens to issue.
function issueTokens(address _for, uint tokenCount)
external
payable
onlyMinter
returns (bool)
{
if (tokenCount == 0) {
return false;
}
if (add(totalSupply, tokenCount) > maxTotalSupply) {
throw;
}
totalSupply = add(totalSupply, tokenCount);
balances[_for] = add(balances[_for], tokenCount);
Issuance(_for, tokenCount);
return true;
}
/// @dev Function to change address that is allowed to do emission.
/// @param newAddress Address of new emission contract.
function changeMinter(address newAddress)
public
onlyFounder
returns (bool)
{
// Forbid previous emission contract to distribute tokens minted during ICO stage
delete allowed[allocationAddressICO][minter];
minter = newAddress;
// Allow emission contract to distribute tokens minted during ICO stage
allowed[allocationAddressICO][minter] = balanceOf(allocationAddressICO);
}
/// @dev Function to change founder address.
/// @param newAddress Address of new founder.
function changeFounder(address newAddress)
public
onlyFounder
returns (bool)
{
founder = newAddress;
}
/// @dev Function to change multisig address.
/// @param newAddress Address of new multisig.
function changeMultisig(address newAddress)
public
onlyFounder
returns (bool)
{
multisig = newAddress;
}
/// @dev Contract constructor function sets initial token balances.
function HumaniqToken(address founderAddress)
{
// Set founder address
founder = founderAddress;
// Allocate all created tokens during ICO stage to allocationAddressICO.
balances[allocationAddressICO] = ICOSupply;
// Allocate all created tokens during preICO stage to allocationAddressPreICO.
balances[allocationAddressPreICO] = preICOSupply;
// Allow founder to distribute tokens minted during preICO stage
allowed[allocationAddressPreICO][founder] = preICOSupply;
// Give 14 percent of all tokens to founders.
balances[multisig] = div(mul(ICOSupply, 14), 86);
// Set correct totalSupply and limit maximum total supply.
totalSupply = add(ICOSupply, balances[multisig]);
totalSupply = add(totalSupply, preICOSupply);
maxTotalSupply = mul(totalSupply, 5);
}
}
pragma solidity ^0.4.6;
/**
* Math operations with safety checks
*/
contract SafeMath {
function mul(uint a, uint b) internal returns (uint) {
uint c = a * b;
assert(a == 0 || c / a == b);
return c;
}
function div(uint a, uint b) internal returns (uint) {
assert(b > 0);
uint c = a / b;
assert(a == b * c + a % b);
return c;
}
function sub(uint a, uint b) internal returns (uint) {
assert(b <= a);
return a - b;
}
function add(uint a, uint b) internal returns (uint) {
uint c = a + b;
assert(c >= a);
return c;
}
function assert(bool assertion) internal {
if (!assertion) {
throw;
}
}
}
pragma solidity ^0.4.2;
import "./AbstractToken.sol";
contract StandardToken is AbstractToken {
/*
* Data structures
*/
mapping (address => uint256) balances;
mapping (address => mapping (address => uint256)) allowed;
uint256 public totalSupply;
/*
* Read and write storage functions
*/
/// @dev Transfers sender's tokens to a given address. Returns success.
/// @param _to Address of token receiver.
/// @param _value Number of tokens to transfer.
function transfer(address _to, uint256 _value) returns (bool success) {
if (balances[msg.sender] >= _value && balances[_to] + _value > balances[_to]) {
balances[msg.sender] -= _value;
balances[_to] += _value;
Transfer(msg.sender, _to, _value);
return true;
}
else {
return false;
}
}
/// @dev Allows allowed third party to transfer tokens from one address to another. Returns success.
/// @param _from Address from where tokens are withdrawn.
/// @param _to Address to where tokens are sent.
/// @param _value Number of tokens to transfer.
function transferFrom(address _from, address _to, uint256 _value) returns (bool success) {
if (balances[_from] >= _value && allowed[_from][msg.sender] >= _value && balances[_to] + _value > balances[_to]) {
balances[_to] += _value;
balances[_from] -= _value;
allowed[_from][msg.sender] -= _value;
Transfer(_from, _to, _value);
return true;
}
else {
return false;
}
}
/// @dev Returns number of tokens owned by given address.
/// @param _owner Address of token owner.
function balanceOf(address _owner) constant returns (uint256 balance) {
return balances[_owner];
}
/// @dev Sets approved amount of tokens for spender. Returns success.
/// @param _spender Address of allowed account.
/// @param _value Number of approved tokens.
function approve(address _spender, uint256 _value) returns (bool success) {
allowed[msg.sender][_spender] = _value;
Approval(msg.sender, _spender, _value);
return true;
}
/*
* Read storage functions
*/
/// @dev Returns number of allowed tokens for given address.
/// @param _owner Address of token owner.
/// @param _spender Address of token spender.
function allowance(address _owner, address _spender) constant returns (uint256 remaining) {
return allowed[_owner][_spender];
}
}
pragma solidity ^0.4.8;
contract Test{
enum State{
NotRegistered,
Registered,
SentTransaction,
ReceivedTransaction,
DidBoth
}
State state = State.NotRegistered;
function getState() returns (State){
return state;
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment