首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Crowdsale不停工

Crowdsale不停工
EN

Ethereum用户
提问于 2017-09-21 15:56:06
回答 1查看 82关注 0票数 1

我正试着创造一个象征性的促销活动。这样做的目的是为了重新启动众包销售,每次我们增加资金来扩大收藏时,代金券都可以燃烧,可以从收藏中购买物品。销售应该有资金上限和时间上限。

但是,当时间到了,或者达到了供资目标时,我可以继续向合同发送资金,并创建新的令牌,就好像我编码的条件无关紧要一样。

这是我的密码:

代码语言:javascript
复制
pragma solidity ^0.4.11;

import './IERC20.sol';
import './SafeMath.sol';

contract TestToken4 is IERC20 {

    using SafeMath for uint256;

    uint public _totalSupply = 0;
    uint public fundingGoal;
    uint public deadline;
    uint public amountRaised = 0;

    string public constant symbol = "TST4";
    string public constant name = "TestToken4";
    uint8 public constant decimals = 18;

    bool isEnabled;
    bool GoalReached = false;
    bool TokenSaleEnded = false;

    // 1 ether = 2000 tst3
    uint256 public RATE = 2000;

    address public owner;

    mapping(address => uint256) balances;
    mapping(address => mapping(address => uint256)) allowed;


    modifier isOwner() {
        require(msg.sender == owner);
        _;
    }

    function toggle() isOwner {
        isEnabled = !isEnabled;
    }

    function () payable {
        createTokens();
    }

    function TestToken4() {
        owner = msg.sender;
    }

    function createTokens() payable {
        require(
            msg.value > 0
            && isEnabled
            && !GoalReached
            && !TokenSaleEnded);

        uint256 tokens = msg.value.mul(RATE);
        balances[msg.sender] = balances[msg.sender].add(tokens);
        _totalSupply = _totalSupply.add(tokens);
        amountRaised = amountRaised.add(msg.value); 

        owner.transfer(msg.value);
    }

    function setCrowdsale (
        uint fundingGoalInEthers,
        uint durationInMinutes,
        uint tokensPerEth
        ) isOwner {
            fundingGoal = fundingGoalInEthers.mul(1 ether);
            deadline = now + durationInMinutes * 1 minutes;
            RATE = tokensPerEth;
        }

    function checkGoalReached() {
        if (amountRaised >= fundingGoal) {
            GoalReached = true;
        }
        if (now >= deadline) {
            TokenSaleEnded = true;
        }
        else {
            GoalReached = false;
            TokenSaleEnded = false;
        }
    }

    function totalSupply () constant returns (uint256 totalSupply) {
        return _totalSupply;
    }

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

    function transfer(address _to, uint256 _value) returns (bool success) {
        require(
            balances[msg.sender] >= _value
            && _value > 0
        );
        balances[msg.sender] = balances[msg.sender].sub(_value);
        balances[_to] = balances[_to].add(_value);
        Transfer(msg.sender, _to, _value);
        return true;
    }

    function transferFrom(address _from, address _to, uint256 _value) returns (bool success) {
        require(
            allowed[_from][msg.sender] >= _value
            && balances[_from] >= _value
            && _value > 0
        );
        balances[_from] = balances[_from].sub(_value);
        balances[_to] = balances[_to].add(_value);
        allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
        Transfer(_from, _to, _value);
        return true;
    }

    function approve(address _spender, uint256 _value) returns (bool success) {
        allowed[msg.sender][_spender] = _value;
        Approval(msg.sender, _spender, _value);
        return true;
    }

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

    function burn(uint256 _value) isOwner returns (bool success) {
        require(
            balances[msg.sender] >= _value
            && _value > 0
        );
        balances[msg.sender] = balances[msg.sender].sub(_value);
        _totalSupply = _totalSupply.sub(_value);
        Burn (msg.sender, _value);
        return true;
    } 

    event Transfer(address indexed _from, address indexed _to, uint256 _value);
    event Approval(address indexed _owner, address indexed _spender, uint256 _value);
    event Burn(address indexed from, uint256 value);
}
EN

回答 1

Ethereum用户

发布于 2017-09-21 19:47:39

因为我不能评论我在堆叠溢出事件上的低声誉.

我觉得问题就在代码的这一部分。

代码语言:javascript
复制
function checkGoalReached() {
    if (amountRaised >= fundingGoal) {
        GoalReached = true;
    }
    if (now >= deadline) {
        TokenSaleEnded = true;
    }
    else {
        GoalReached = false;
        TokenSaleEnded = false;
    }
}
票数 1
EN
页面原文内容由Ethereum提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://ethereum.stackexchange.com/questions/26851

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档