ICO: BONUS + 20% TOKENS

RU:COIN LOYALTY

Russian Currencies RUCOIN
Crypto-currency secured by the obligations of RUCOIN LOYALTY

current period: ICO

1 ETH = 750 Rucoin | 1 BTC = 7500 Rucoin | +20% Bonus

$ 788.103

$ 4.500.000

PRE ICO collected

$ 788103

24

Bitcoin received

196

Ethereum received

Completion ICO with a bonus of 20% through

! Depending on the network traffic, digits may be delayed

About the project

RUCOIN cryptocurrency and the One Global Loyalty Network are aiming to be a bridge between virtual currencies of the digital world and world-known brands’ bonuses/discounts of the real world.

 

Features of RUCOIN.

 

    • Stable Crypto-Currency with a quarterly increase in liabilities.
    • Now consumers don’t have to combine different rewards and loyalty points, they can just use RUCOIN in the Global Loyalty Network, receiving goods and services that are necessary for them.
  • As of January 14, 2018 10:02 there are 1 082 632 offers from 87 stores.
  • Loyalty network offers:
  • 1. Consumers: a purse with the account RUCOIN, which shows the phi-equivalent of RUCOIN, the ability to translate tokens to other users. Built Exchange Exchange Rucoin, Bitcoin, Ethereum. The list of goods available for purchase for RUCOIN under the loyalty program.
  • Safe transactions using crypto currency Rucoin, Bitcoin, Ethereum. In a secure transaction, RUCOIN LOYALTY acts as a guarantor of execution of the transaction by the parties to the participants.
  • 2. For retailers: the opportunity of exponential development of the partner loyalty network. This will reduce their balance obligations by means of use/repayment by consumers.
  • Manufacturers and brands willing to acquire new customers can also become members of RUCOIN LOYALTY.
  • 3. Owners (of applications/websites): a convenient and meaningful way to reward users for their involvement without the need of creating and managing the rewards system.
  • It will be a means of exchange and use in the system. Being a cryptocurrency, the RUCOIN token will provide unlimited, safe and secure transactions between partner brands around the world. In addition,
    RUCOIN will also act as an exit point for site owners who try to attract users.
    This model will lead to the consumer base growth in the ecosystem, which will result in transactions increase.
  • The key components of the proposed solution will be RUCOIN, namely
    the Complex of Interaction between the Clients and the RUCOIN LOYALTY Network.

 

  • ATTENTION! Official Rucoin is NOT traded on stock exchanges!
  • Listing on the exchanges in March 2018
  • advantages
    RuCoin cryptocurrency open source code.
  • advantages
    Payments are published in a public block chain which ensures confidentiality.
  • advantages
    RuCoin has a fixed total stock of 500 million units.
  • advantages
    BFT delegated nodes validators + DPoS delegated proof of stake.
  • advantages
    The speed of transaction less than
    1 second.
  • advantages
    Secure transactions with the Rucoin, Bitcoin, Ethereum.
  • advantages
    Throughput of over 100,000 operations per second.
  • advantages
    Cashback wallet of rewards, bonuses, discounts.
    Built Exchange Exchange Rucoin, Bitcoin, Ethereum.
    Goods and services of the catalog BRC.
  • advantages
    0.01% of max commission for transactions.
  • advantages
    Automation reduces transaction costs.
  • advantages
    Quick and secure identification.
  • advantages
    Stable and predictable token.
Rucoin using
loyalty rule - a product or service in RUCOIN is cheaper by at least 5%
  • title

    Buy goods and services

  • title

    Receive bonuses in RUCOIN and cashback from 5%

  • title

    Buy goods and services in RUCOIN at a discount

a trading platform with bonuses RUCOIN already more
1 105 428 offers from 79 stores
rl
Any types of loyalty programs
  • Constant minimum discount of 5% MasterCard RUCOIN
  • Get RUCOIN from one brand and use it everywhere
  • Use your bonuses to pay for everything you want
  • Exchange of bonuses for other digital assets
  • Send and receive RUCOIN with RUCOIN LOYALTY
android ios
We are working with
title
title
title
title
title
Road Map
  • February 12, 2014
    Foundtion of RuCoin Community. Building the vision and ideology of the platform.
  • December, 2014
    Market and its needs analysis. Development of the first RUCOIN platform prototype.
  • October, 2016
    Development and testing the Alpha version platform. BRC site development.
  • November, 2017
    Start of Pre-ICO RUCOIN. Issue of Biotech products.
  • March, 2018
    Internal currency exchange.
  • February, 2018
    RUCOIN platform launching.
  • January, 2018
    ICO RUCOIN.
  • December, 2017
    Legal structure RUCOIN CHECK platform prototype. BRCICO site.
  • April, 2018
    Rucoin Loyalty, See Life, Smart Reputation and Movie Worker launching, Rucoin Check.
  • May, 2018
    Application for iOS. Improving the web version.
  • July, 2018
    Android app.
  • August, 2018
    Development of additional functionality. Integration with third-party services.
  • September, 2018
    Localization of the platform into additional languages.
Token sales
  • PRE-ICO RUCOIN

    Start: 22.11.2017 (12:00 AM MSK Time, UTC+3)

    Finish: 27.12.2017 (11:59 PM MSK Time, UTC+3)

    Accepted currencies: Bitcoin (ВТС), Ethereum (ETH)

    Minimum transaction amount in Bitcoins 0.0025

    Minimum transaction amount in Ethereum 0.04

    Minimum: 10 tokens; Maximum: 50 000 tokens;

    1 RUCOIN = $1.2 Bonus:

    30% – 22.11.2017

    25% – 29.11.2017

    Limited number – 4.500.000 tokens

  • ICO RUCOIN

    Start: 15.01.2018 (12:00 AM MSK Time, UTC+)

    Finish: 15.04.2018 (12:00 PM MSK Time, UTC+3)

    Accepted currencies: Bitcoin (ВТС), Ethereum (ETH)

    Minimum transaction amount in Bitcoins 0.0025

    Minimum transaction amount in Ethereum 0.04

    Minimum: 10 tokens; Maximum: 50 000 tokens;

    1 RUCOIN = $2 Bonus:

    20% – 15.01.2018 – 40.500.000 tokens

     

    Limited number – 40.500.000 tokens

Smart contract rucoin
// Created using ICO Wizard https://github.com/oraclesorg/ico-wizard by Oracles Network 
pragma solidity ^0.4.11;


/**
 * @title ERC20Basic
 * @dev Simpler version of ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/179
 */
contract ERC20Basic {
  uint256 public totalSupply;
  function balanceOf(address who) public constant returns (uint256);
  function transfer(address to, uint256 value) public returns (bool);
  event Transfer(address indexed from, address indexed to, uint256 value);
}



/**
 * @title Ownable
 * @dev The Ownable contract has an owner address, and provides basic authorization control
 * functions, this simplifies the implementation of "user permissions".
 */
contract Ownable {
  address public owner;


  event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);


  /**
   * @dev The Ownable constructor sets the original `owner` of the contract to the sender
   * account.
   */
  function Ownable() {
    owner = msg.sender;
  }


  /**
   * @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) onlyOwner public {
    require(newOwner != address(0));
    OwnershipTransferred(owner, newOwner);
    owner = newOwner;
  }

}
// Temporarily have SafeMath here until all contracts have been migrated to SafeMathLib version from OpenZeppelin




/**
 * Math operations with safety checks
 */
contract SafeMath {
  function safeMul(uint a, uint b) internal returns (uint) {
    uint c = a * b;
    assert(a == 0 || c / a == b);
    return c;
  }

  function safeDiv(uint a, uint b) internal returns (uint) {
    assert(b > 0);
    uint c = a / b;
    assert(a == b * c + a % b);
    return c;
  }

  function safeSub(uint a, uint b) internal returns (uint) {
    assert(b <= a);
    return a - b;
  }

  function safeAdd(uint a, uint b) internal returns (uint) {
    uint c = a + b;
    assert(c>=a && c>=b);
    return c;
  }

  function max64(uint64 a, uint64 b) internal constant returns (uint64) {
    return a >= b ? a : b;
  }

  function min64(uint64 a, uint64 b) internal constant returns (uint64) {
    return a < b ? a : b;
  }

  function max256(uint256 a, uint256 b) internal constant returns (uint256) {
    return a >= b ? a : b;
  }

  function min256(uint256 a, uint256 b) internal constant returns (uint256) {
    return a < b ? a : b;
  }

}
/**
 * This smart contract code is Copyright 2017 TokenMarket Ltd. For more information see https://tokenmarket.net
 *
 * Licensed under the Apache License, version 2.0: https://github.com/TokenMarketNet/ico/blob/master/LICENSE.txt
 */



/**
 * This smart contract code is Copyright 2017 TokenMarket Ltd. For more information see https://tokenmarket.net
 *
 * Licensed under the Apache License, version 2.0: https://github.com/TokenMarketNet/ico/blob/master/LICENSE.txt
 */










/**
 * @title ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/20
 */
contract ERC20 is ERC20Basic {
  function allowance(address owner, address spender) public constant returns (uint256);
  function transferFrom(address from, address to, uint256 value) public returns (bool);
  function approve(address spender, uint256 value) public returns (bool);
  event Approval(address indexed owner, address indexed spender, uint256 value);
}




/**
 * Standard ERC20 token with Short Hand Attack and approve() race condition mitigation.
 *
 * Based on code by FirstBlood:
 * https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
 */
contract StandardToken is ERC20, SafeMath {

  /* Token supply got increased and a new owner received these tokens */
  event Minted(address receiver, uint amount);

  /* Actual balances of token holders */
  mapping(address => uint) balances;

  /* approve() allowances */
  mapping (address => mapping (address => uint)) allowed;

  /* Interface declaration */
  function isToken() public constant returns (bool weAre) {
    return true;
  }

  function transfer(address _to, uint _value) returns (bool success) {
    balances[msg.sender] = safeSub(balances[msg.sender], _value);
    balances[_to] = safeAdd(balances[_to], _value);
    Transfer(msg.sender, _to, _value);
    return true;
  }

  function transferFrom(address _from, address _to, uint _value) returns (bool success) {
    uint _allowance = allowed[_from][msg.sender];

    balances[_to] = safeAdd(balances[_to], _value);
    balances[_from] = safeSub(balances[_from], _value);
    allowed[_from][msg.sender] = safeSub(_allowance, _value);
    Transfer(_from, _to, _value);
    return true;
  }

  function balanceOf(address _owner) constant returns (uint balance) {
    return balances[_owner];
  }

  function approve(address _spender, uint _value) returns (bool success) {

    // To change the approve amount you first have to reduce the addresses`
    //  allowance to zero by calling `approve(_spender, 0)` if it is not
    //  already 0 to mitigate the race condition described here:
    //  https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
    if ((_value != 0) && (allowed[msg.sender][_spender] != 0)) throw;

    allowed[msg.sender][_spender] = _value;
    Approval(msg.sender, _spender, _value);
    return true;
  }

  function allowance(address _owner, address _spender) constant returns (uint remaining) {
    return allowed[_owner][_spender];
  }

}

/**
 * This smart contract code is Copyright 2017 TokenMarket Ltd. For more information see https://tokenmarket.net
 *
 * Licensed under the Apache License, version 2.0: https://github.com/TokenMarketNet/ico/blob/master/LICENSE.txt
 */





/**
 * This smart contract code is Copyright 2017 TokenMarket Ltd. For more information see https://tokenmarket.net
 *
 * Licensed under the Apache License, version 2.0: https://github.com/TokenMarketNet/ico/blob/master/LICENSE.txt
 */



/**
 * Upgrade agent interface inspired by Lunyr.
 *
 * Upgrade agent transfers tokens to a new contract.
 * Upgrade agent itself can be the token contract, or just a middle man contract doing the heavy lifting.
 */
contract UpgradeAgent {

  uint public originalSupply;

  /** Interface marker */
  function isUpgradeAgent() public constant returns (bool) {
    return true;
  }

  function upgradeFrom(address _from, uint256 _value) public;

}


/**
 * A token upgrade mechanism where users can opt-in amount of tokens to the next smart contract revision.
 *
 * First envisioned by Golem and Lunyr projects.
 */
contract UpgradeableToken is StandardToken {

  /** Contract / person who can set the upgrade path. This can be the same as team multisig wallet, as what it is with its default value. */
  address public upgradeMaster;

  /** The next contract where the tokens will be migrated. */
  UpgradeAgent public upgradeAgent;

  /** How many tokens we have upgraded by now. */
  uint256 public totalUpgraded;

  /**
   * Upgrade states.
   *
   * - NotAllowed: The child contract has not reached a condition where the upgrade can bgun
   * - WaitingForAgent: Token allows upgrade, but we don't have a new agent yet
   * - ReadyToUpgrade: The agent is set, but not a single token has been upgraded yet
   * - Upgrading: Upgrade agent is set and the balance holders can upgrade their tokens
   *
   */
  enum UpgradeState {Unknown, NotAllowed, WaitingForAgent, ReadyToUpgrade, Upgrading}

  /**
   * Somebody has upgraded some of his tokens.
   */
  event Upgrade(address indexed _from, address indexed _to, uint256 _value);

  /**
   * New upgrade agent available.
   */
  event UpgradeAgentSet(address agent);

  /**
   * Do not allow construction without upgrade master set.
   */
  function UpgradeableToken(address _upgradeMaster) {
    upgradeMaster = _upgradeMaster;
  }

  /**
   * Allow the token holder to upgrade some of their tokens to a new contract.
   */
  function upgrade(uint256 value) public {

      UpgradeState state = getUpgradeState();
      if(!(state == UpgradeState.ReadyToUpgrade || state == UpgradeState.Upgrading)) {
        // Called in a bad state
        throw;
      }

      // Validate input value.
      if (value == 0) throw;

      balances[msg.sender] = safeSub(balances[msg.sender], value);

      // Take tokens out from circulation
      totalSupply = safeSub(totalSupply, value);
      totalUpgraded = safeAdd(totalUpgraded, value);

      // Upgrade agent reissues the tokens
      upgradeAgent.upgradeFrom(msg.sender, value);
      Upgrade(msg.sender, upgradeAgent, value);
  }

  /**
   * Set an upgrade agent that handles
   */
  function setUpgradeAgent(address agent) external {

      if(!canUpgrade()) {
        // The token is not yet in a state that we could think upgrading
        throw;
      }

      if (agent == 0x0) throw;
      // Only a master can designate the next agent
      if (msg.sender != upgradeMaster) throw;
      // Upgrade has already begun for an agent
      if (getUpgradeState() == UpgradeState.Upgrading) throw;

      upgradeAgent = UpgradeAgent(agent);

      // Bad interface
      if(!upgradeAgent.isUpgradeAgent()) throw;
      // Make sure that token supplies match in source and target
      if (upgradeAgent.originalSupply() != totalSupply) throw;

      UpgradeAgentSet(upgradeAgent);
  }

  /**
   * Get the state of the token upgrade.
   */
  function getUpgradeState() public constant returns(UpgradeState) {
    if(!canUpgrade()) return UpgradeState.NotAllowed;
    else if(address(upgradeAgent) == 0x00) return UpgradeState.WaitingForAgent;
    else if(totalUpgraded == 0) return UpgradeState.ReadyToUpgrade;
    else return UpgradeState.Upgrading;
  }

  /**
   * Change the upgrade master.
   *
   * This allows us to set a new owner for the upgrade mechanism.
   */
  function setUpgradeMaster(address master) public {
      if (master == 0x0) throw;
      if (msg.sender != upgradeMaster) throw;
      upgradeMaster = master;
  }

  /**
   * Child contract can enable to provide the condition when the upgrade can begun.
   */
  function canUpgrade() public constant returns(bool) {
     return true;
  }

}

/**
 * This smart contract code is Copyright 2017 TokenMarket Ltd. For more information see https://tokenmarket.net
 *
 * Licensed under the Apache License, version 2.0: https://github.com/TokenMarketNet/ico/blob/master/LICENSE.txt
 */







/**
 * Define interface for releasing the token transfer after a successful crowdsale.
 */
contract ReleasableToken is ERC20, Ownable {

  /* The finalizer contract that allows unlift the transfer limits on this token */
  address public releaseAgent;

  /** A crowdsale contract can release us to the wild if ICO success. If false we are are in transfer lock up period.*/
  bool public released = false;

  /** Map of agents that are allowed to transfer tokens regardless of the lock down period. These are crowdsale contracts and possible the team multisig itself. */
  mapping (address => bool) public transferAgents;

  /**
   * Limit token transfer until the crowdsale is over.
   *
   */
  modifier canTransfer(address _sender) {

    if(!released) {
        if(!transferAgents[_sender]) {
            throw;
        }
    }

    _;
  }

  /**
   * Set the contract that can call release and make the token transferable.
   *
   * Design choice. Allow reset the release agent to fix fat finger mistakes.
   */
  function setReleaseAgent(address addr) onlyOwner inReleaseState(false) public {

    // We don't do interface check here as we might want to a normal wallet address to act as a release agent
    releaseAgent = addr;
  }

  /**
   * Owner can allow a particular address (a crowdsale contract) to transfer tokens despite the lock up period.
   */
  function setTransferAgent(address addr, bool state) onlyOwner inReleaseState(false) public {
    transferAgents[addr] = state;
  }

  /**
   * One way function to release the tokens to the wild.
   *
   * Can be called only from the release agent that is the final ICO contract. It is only called if the crowdsale has been success (first milestone reached).
   */
  function releaseTokenTransfer() public onlyReleaseAgent {
    released = true;
  }

  /** The function can be called only before or after the tokens have been releasesd */
  modifier inReleaseState(bool releaseState) {
    if(releaseState != released) {
        throw;
    }
    _;
  }

  /** The function can be called only by a whitelisted release agent. */
  modifier onlyReleaseAgent() {
    if(msg.sender != releaseAgent) {
        throw;
    }
    _;
  }

  function transfer(address _to, uint _value) canTransfer(msg.sender) returns (bool success) {
    // Call StandardToken.transfer()
   return super.transfer(_to, _value);
  }

  function transferFrom(address _from, address _to, uint _value) canTransfer(_from) returns (bool success) {
    // Call StandardToken.transferForm()
    return super.transferFrom(_from, _to, _value);
  }

}

/**
 * This smart contract code is Copyright 2017 TokenMarket Ltd. For more information see https://tokenmarket.net
 *
 * Licensed under the Apache License, version 2.0: https://github.com/TokenMarketNet/ico/blob/master/LICENSE.txt
 */




/**
 * This smart contract code is Copyright 2017 TokenMarket Ltd. For more information see https://tokenmarket.net
 *
 * Licensed under the Apache License, version 2.0: https://github.com/TokenMarketNet/ico/blob/master/LICENSE.txt
 */



/**
 * Safe unsigned safe math.
 *
 * https://blog.aragon.one/library-driven-development-in-solidity-2bebcaf88736#.750gwtwli
 *
 * Originally from https://raw.githubusercontent.com/AragonOne/zeppelin-solidity/master/contracts/SafeMathLib.sol
 *
 * Maintained here until merged to mainline zeppelin-solidity.
 *
 */
library SafeMathLibExt {

  function times(uint a, uint b) returns (uint) {
    uint c = a * b;
    assert(a == 0 || c / a == b);
    return c;
  }

  function divides(uint a, uint b) returns (uint) {
    assert(b > 0);
    uint c = a / b;
    assert(a == b * c + a % b);
    return c;
  }

  function minus(uint a, uint b) returns (uint) {
    assert(b <= a);
    return a - b;
  }

  function plus(uint a, uint b) returns (uint) {
    uint c = a + b;
    assert(c>=a);
    return c;
  }

}




/**
 * A token that can increase its supply by another contract.
 *
 * This allows uncapped crowdsale by dynamically increasing the supply when money pours in.
 * Only mint agents, contracts whitelisted by owner, can mint new tokens.
 *
 */
contract MintableTokenExt is StandardToken, Ownable {

  using SafeMathLibExt for uint;

  bool public mintingFinished = false;

  /** List of agents that are allowed to create new tokens */
  mapping (address => bool) public mintAgents;

  event MintingAgentChanged(address addr, bool state  );

  /** inPercentageUnit is percents of tokens multiplied to 10 up to percents decimals.
  * For example, for reserved tokens in percents 2.54%
  * inPercentageUnit = 254
  * inPercentageDecimals = 2
  */
  struct ReservedTokensData {
    uint inTokens;
    uint inPercentageUnit;
    uint inPercentageDecimals;
  }

  mapping (address => ReservedTokensData) public reservedTokensList;
  address[] public reservedTokensDestinations;
  uint public reservedTokensDestinationsLen = 0;

  function setReservedTokensList(address addr, uint inTokens, uint inPercentageUnit, uint inPercentageDecimals) onlyOwner {
    reservedTokensDestinations.push(addr);
    reservedTokensDestinationsLen++;
    reservedTokensList[addr] = ReservedTokensData({inTokens:inTokens, inPercentageUnit:inPercentageUnit, inPercentageDecimals: inPercentageDecimals});
  }

  function getReservedTokensListValInTokens(address addr) constant returns (uint inTokens) {
    return reservedTokensList[addr].inTokens;
  }

  function getReservedTokensListValInPercentageUnit(address addr) constant returns (uint inPercentageUnit) {
    return reservedTokensList[addr].inPercentageUnit;
  }

  function getReservedTokensListValInPercentageDecimals(address addr) constant returns (uint inPercentageDecimals) {
    return reservedTokensList[addr].inPercentageDecimals;
  }

  function setReservedTokensListMultiple(address[] addrs, uint[] inTokens, uint[] inPercentageUnit, uint[] inPercentageDecimals) onlyOwner {
    for (uint iterator = 0; iterator < addrs.length; iterator++) {
      setReservedTokensList(addrs[iterator], inTokens[iterator], inPercentageUnit[iterator], inPercentageDecimals[iterator]);
    }
  }

  /**
   * Create new tokens and allocate them to an address..
   *
   * Only callably by a crowdsale contract (mint agent).
   */
  function mint(address receiver, uint amount) onlyMintAgent canMint public {
    totalSupply = totalSupply.plus(amount);
    balances[receiver] = balances[receiver].plus(amount);

    // This will make the mint transaction apper in EtherScan.io
    // We can remove this after there is a standardized minting event
    Transfer(0, receiver, amount);
  }

  /**
   * Owner can allow a crowdsale contract to mint new tokens.
   */
  function setMintAgent(address addr, bool state) onlyOwner canMint public {
    mintAgents[addr] = state;
    MintingAgentChanged(addr, state);
  }

  modifier onlyMintAgent() {
    // Only crowdsale contracts are allowed to mint new tokens
    if(!mintAgents[msg.sender]) {
        throw;
    }
    _;
  }

  /** Make sure we are not done yet. */
  modifier canMint() {
    if(mintingFinished) throw;
    _;
  }
}



/**
 * A crowdsaled token.
 *
 * An ERC-20 token designed specifically for crowdsales with investor protection and further development path.
 *
 * - The token transfer() is disabled until the crowdsale is over
 * - The token contract gives an opt-in upgrade path to a new contract
 * - The same token can be part of several crowdsales through approve() mechanism
 * - The token can be capped (supply set in the constructor) or uncapped (crowdsale contract can mint new tokens)
 *
 */
contract CrowdsaleTokenExt is ReleasableToken, MintableTokenExt, UpgradeableToken {

  /** Name and symbol were updated. */
  event UpdatedTokenInformation(string newName, string newSymbol);

  string public name;

  string public symbol;

  uint public decimals;

  /* Minimum ammount of tokens every buyer can buy. */
  uint public minCap;

  /**
   * Construct the token.
   *
   * This token must be created through a team multisig wallet, so that it is owned by that wallet.
   *
   * @param _name Token name
   * @param _symbol Token symbol - should be all caps
   * @param _initialSupply How many tokens we start with
   * @param _decimals Number of decimal places
   * @param _mintable Are new tokens created over the crowdsale or do we distribute only the initial supply? Note that when the token becomes transferable the minting always ends.
   */
  function CrowdsaleTokenExt(string _name, string _symbol, uint _initialSupply, uint _decimals, bool _mintable, uint _globalMinCap)
    UpgradeableToken(msg.sender) {

    // Create any address, can be transferred
    // to team multisig via changeOwner(),
    // also remember to call setUpgradeMaster()
    owner = msg.sender;

    name = _name;
    symbol = _symbol;

    totalSupply = _initialSupply;

    decimals = _decimals;

    minCap = _globalMinCap;

    // Create initially all balance on the team multisig
    balances[owner] = totalSupply;

    if(totalSupply > 0) {
      Minted(owner, totalSupply);
    }

    // No more new supply allowed after the token creation
    if(!_mintable) {
      mintingFinished = true;
      if(totalSupply == 0) {
        throw; // Cannot create a token without supply and no minting
      }
    }
  }

  /**
   * When token is released to be transferable, enforce no new tokens can be created.
   */
  function releaseTokenTransfer() public onlyReleaseAgent {
    mintingFinished = true;
    super.releaseTokenTransfer();
  }

  /**
   * Allow upgrade agent functionality kick in only if the crowdsale was success.
   */
  function canUpgrade() public constant returns(bool) {
    return released && super.canUpgrade();
  }

  /**
   * Owner can update token information here.
   *
   * It is often useful to conceal the actual token association, until
   * the token operations, like central issuance or reissuance have been completed.
   *
   * This function allows the token owner to rename the token after the operations
   * have been completed and then point the audience to use the token contract.
   */
  function setTokenInformation(string _name, string _symbol) onlyOwner {
    name = _name;
    symbol = _symbol;

    UpdatedTokenInformation(name, symbol);
  }

}
grah
graf
Documentation
  • WHITE PAPER

    Choose language:

    EN RU
  • ROADMAP

    Choose language:

    EN RU
  • TOKEN SALE POLICY

    Choose language:

    EN RU
MEDIA PUBLICATIONS
  • RUCOIN Aims to be the First Decentralized E-commerce Platform
    RUCOIN Aims to be the First Decentralized E-commerce Platform
    Shortly speaking, RUCOIN is a smart marketplace platform with smart contracts, a unique rating system of vendors based on blockchain technology, and transactions...
    06/11/2017
  • The Russian company entered the PRE ICO with the project RUCOIN LOYALTY
    The Russian company entered the PRE ICO with the project RUCOIN LOYALTY
    The RUCOIN Token and the Unified Global Loyalty Network together seek to become a bridge between the digital world of virtual currencies and real-world bonuses / discounts of well-known brands around the world. Features of RUCOIN.
    26/11/2017
  • GLOBAL (Adoption and conversion in real time)
    GLOBAL (Adoption and conversion in real time)
    At first glance, GLOBAL makes possible local transactions of fiat money between the parties, which is convenient for business.
    24/11/2017
  • How to conduct ICO in Russia
    How to conduct ICO in Russia
    Consumers do not need to now, combine different reward points, bonus points, and simply use RUCOIN in the Global Loyalty Network, now getting goods and services that are of real value to them.
    24/11/2017
  • RUCOIN Crypto currency provided with fiat money
    RUCOIN Crypto currency provided with fiat money
    Crypto currency provided with phi-monies ($ / ¥ / € / ₽ / ₹ / ...) bonus programs of brands, applications and websites
    25/11/2017
  • Business requests that only the domestic cryptocurrency to be spread in Russia
    Business requests that only the domestic cryptocurrency to be spread in Russia
    The business community asks the Federation Council and the Duma to legislate to allow only domestic cryptocurrency in Russia, noting that anonymous operations using foreign currencies can pursue obscure objectives and provide a source of financing
    16/10/2017
  • Russian businessmen are asked to legitimize the domestic cryptocurrency
    Russian businessmen are asked to legitimize the domestic cryptocurrency
    In conditions of global rivalry on the part of competitors in the geopolitical arena, the issuance and circulation of foreign cryptocurrency ...
    16/10/2017
  • A penny to cryptoruble
    A penny to cryptoruble
    July 2017 should be followed by an event that is unlikely to be public, but which must be crucial in answering the question of what is really happening in Russia with cryptocurrencies and with the attitude of the Bank of Russia towards them.
    27/06/2017
  • Cryptoruble and cryptotaxes: get the bear inside the den?
    Cryptoruble and cryptotaxes: get the bear inside the den?
    The early release of the "cryptoruble" was spoken at the top. And then they were hastened to add a tax on these very virtual rubles. Income. I got a cryptoruble.
    17/10/2017
  • The AVANTI association calls for only the domestic cryptocurrency
    The AVANTI association calls for only the domestic cryptocurrency
    The representatives of Association of Business Patriots "Avanti" go to the Russian Federation to send letters to the Speakers of Federation Council and the Duma ...
    16/10/2017
  • Creating a national cryptocurrency in Russia will be difficult ... But it is still possible!
    Creating a national cryptocurrency in Russia will be difficult ... But it is still possible!
    Today, the "Open Innovations" forum opened in Moscow. One of the topics of this meeting is the digital economy and cryptocurrency. The Forum graduate its work in two days.
    17/10/2017
  • In Russia, the collection of folk funds for the creation of its RUCOIN cryptocurrency began.
    In Russia, the collection of folk funds for the creation of its RUCOIN cryptocurrency began.
    On one of the Russian crowd founding platforms, Boomstarter, they began collecting funds to implement the Russian RUCOIN cryptocurrency project. Development and support is carried out by the Research institute of "Innovation Technologies"
    18/08/2017
  • Cryptocurrency in Russia: what is the risk and why do we need the entrepreneurs of Russian Rucoin
    Cryptocurrency in Russia: what is the risk and why do we need the entrepreneurs of Russian Rucoin
    Cryptocurrency in Russia: what are the risks and why do the entrepreneurs need their Russian RUcoin. Cryptocurrency in Russia and in the world is gaining momentum and more fans. Today, people don't have to pay...
    16/10/2017
  • Allow in Russia only the cryptocurrency to be spread
    Allow in Russia only the cryptocurrency to be spread
    In conditions of the global opposition of competitors on the geopolitical scene, issuing and handling foreign cryptocurrency on the territory of the Russian Federation
    16/10/2017
  • Business requests that only the domestic cryptocurrency to be spread in Russia
    Business requests that only the domestic cryptocurrency to be spread in Russia
    The business community asks the Federation Council and the Duma to legislate to allow only domestic cryptocurrency in Russia, noting that anonymous operations using foreign currencies can pursue obscure objectives and provide a source of financing
    16/10/2017
  • The business community requests the Federation Council and the Duma to legislate to allow only the domestic cryptocurrency to be spread in Russia
    The business community requests the Federation Council and the Duma to legislate to allow only the domestic cryptocurrency to be spread in Russia
    The business community requests the Federation Council and the Duma to legislate to allow only domestic cryptocurrency in Russia, noting that anonymous operations using foreign currencies may have unclear objectives ...
    16/10/2017
  • The spreading in the Russian Federation only of the domestic cryptocurrency
    The spreading in the Russian Federation only of the domestic cryptocurrency
    The representatives of the Business Patriots Association "Avanti" sent letters to the Speakers of the Federation Council and the Duma, Valentina Matviyenko and Vyacheslav Volodin, requesting legislate to allow only domestic cryptocurrency in Russia
    16/10/2017
  • Russian government to introduce and legislate the trafficking of Russian cryptocurrency
    Russian government to introduce and legislate the trafficking of Russian cryptocurrency
    Information from the Business Patriots Association in the Duma and the Federation Council notes that the state cryptocurrency is a modern necessity, because a virtual financial market
    16/10/2017
  • Ru:Coin Loyalty-Russian Currencies Rucoin-Crypto-currency secured by the obligations of Rucoin Loyalty
    Ru:Coin Loyalty-Russian Currencies Rucoin-Crypto-currency secured by the obligations of Rucoin Loyalty
    RUCOIN cryptocurrency and the One Global Loyalty Network are aiming to be a bridge between virtual currencies of the digital world and world-known brands’ bonuses/discounts of the real world.
    05/01/2018
  • Blockchain to Connect Virtual Assets and the Real World
    Blockchain to Connect Virtual Assets and the Real World
    From this article you will learn how Rucoin builds a bridge between virtual currencies of the digital world and bonuses and discounts of the real world
    15/01/2018
  • Russia's Leading Bank Opens Blockchain Lab Amid Cryptocurrency Fever
    Russia's Leading Bank Opens Blockchain Lab Amid Cryptocurrency Fever
    Blockchain technology is a distributed and transparent computing system that uses cryptography to store information in a continuously growing list of records, called blocks.
    11/01/2018
Team
  • L. V. Luchko
    L. V. LuchkoFounder and CEO

    The leader and founder of the Scientific Innovation department, co-founder of RUCOIN.

  • A. A. Luchko
    A. A. LuchkoProject manager

    Co-founder of RUCOIN. Consultant for implementing business processes and through analytics.

  • E. A. Veredin
    E. A. VeredinMedia and public relations

    Strategic marketing, responsible for branding, content and public relations.

  • A. Kh. Serechenko
    A. Kh. SerechenkoFinancial director

    Marketing businessman and PR manager. Consultant in the area of legal expertise in financial technology.

  • S. O. Goroh
    S. O. GorohFront-end developer

    Hero style and the code that creates the user interface.

  • I. U. Purysheva
    I. U. PuryshevaManager of the Bounty campaign

    Create and administer a Bounty campaign. Advising and promoting the RuCoin crypto currency project.

Tell us about our ICO. Get 2%

Get 2% of purchased tokens now!
The remuneration program until February 15, 2018

STAY IN TOUCHsupport@ru-coin.com

Subscribe to our e-mail newsletter to be the first to know about all news

Social networks
  • fb
  • tw
  • tl
  • in
  • yt
  • vk
  • btc
  • ruc
  • wechat
x
x
Thank you for subscribing

We will contact You....

x
Sign Up
x
Log in
x
Personal information
x
Buy Ethereum

In order to comply with the KYC procedure, this wallet address is not subject to disclosure.
Minimum transaction of 0,04 ETH.

ethereum
0x8d7B3a122b8379faD019eD35E3899951148d9027
Buy Bitcoin

In order to comply with the KYC procedure, this wallet address is not subject to disclosure.
Minimum transaction of 0.0025 BTC.

bitcoin
1Jg4imJH5pioWkDbfTq2Z3c7jENmmVoJ7x