Created
October 9, 2019 12:46
-
-
Save athlona64/23762c1fd4d4786198012c79fe5c7aa6 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.5.11+commit.c082d0b4.js&optimize=false&gist=
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.7.0; | |
| contract A { | |
| function checkTime() public view returns (uint); | |
| } | |
| contract B { | |
| function callContractA(address _contractA) view public returns (uint){ | |
| return A(_contractA).checkTime(); | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.6.0; | |
| contract Ballot { | |
| struct Voter { | |
| uint weight; | |
| bool voted; | |
| uint8 vote; | |
| address delegate; | |
| } | |
| struct Proposal { | |
| uint voteCount; | |
| } | |
| address chairperson; | |
| mapping(address => Voter) voters; | |
| Proposal[] proposals; | |
| /// Create a new ballot with $(_numProposals) different proposals. | |
| constructor(uint8 _numProposals) public { | |
| chairperson = msg.sender; | |
| voters[chairperson].weight = 1; | |
| proposals.length = _numProposals; | |
| } | |
| /// Give $(toVoter) the right to vote on this ballot. | |
| /// May only be called by $(chairperson). | |
| function giveRightToVote(address toVoter) public { | |
| if (msg.sender != chairperson || voters[toVoter].voted) return; | |
| voters[toVoter].weight = 1; | |
| } | |
| /// Delegate your vote to the voter $(to). | |
| function delegate(address to) public { | |
| Voter storage sender = voters[msg.sender]; // assigns reference | |
| if (sender.voted) return; | |
| while (voters[to].delegate != address(0) && voters[to].delegate != msg.sender) | |
| to = voters[to].delegate; | |
| if (to == msg.sender) return; | |
| sender.voted = true; | |
| sender.delegate = to; | |
| Voter storage delegateTo = voters[to]; | |
| if (delegateTo.voted) | |
| proposals[delegateTo.vote].voteCount += sender.weight; | |
| else | |
| delegateTo.weight += sender.weight; | |
| } | |
| /// Give a single vote to proposal $(toProposal). | |
| function vote(uint8 toProposal) public { | |
| Voter storage sender = voters[msg.sender]; | |
| if (sender.voted || toProposal >= proposals.length) return; | |
| sender.voted = true; | |
| sender.vote = toProposal; | |
| proposals[toProposal].voteCount += sender.weight; | |
| } | |
| function winningProposal() public view returns (uint8 _winningProposal) { | |
| uint256 winningVoteCount = 0; | |
| for (uint8 prop = 0; prop < proposals.length; prop++) | |
| if (proposals[prop].voteCount > winningVoteCount) { | |
| winningVoteCount = proposals[prop].voteCount; | |
| _winningProposal = prop; | |
| } | |
| } | |
| } |
This file contains hidden or 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
| import "remix_tests.sol"; // this import is automatically injected by Remix. | |
| import "./ballot.sol"; | |
| contract test3 { | |
| Ballot ballotToTest; | |
| function beforeAll () public { | |
| ballotToTest = new Ballot(2); | |
| } | |
| function checkWinningProposal () public { | |
| ballotToTest.vote(1); | |
| Assert.equal(ballotToTest.winningProposal(), uint(1), "1 should be the winning proposal"); | |
| } | |
| function checkWinninProposalWithReturnValue () public view returns (bool) { | |
| return ballotToTest.winningProposal() == 1; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.6.0; | |
| contract loan { | |
| } |
This file contains hidden or 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
| /** | |
| *Submitted for verification at Etherscan.io on 2017-07-05 | |
| */ | |
| pragma solidity ^0.4.11; | |
| /** | |
| * Math operations with safety checks | |
| */ | |
| library 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); // Solidity automatically throws when dividing by 0 | |
| uint c = a / b; | |
| // assert(a == b * c + a % b); // There is no case in which this doesn't hold | |
| 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 max64(uint64 a, uint64 b) internal pure returns (uint64) { | |
| return a >= b ? a : b; | |
| } | |
| function min64(uint64 a, uint64 b) internal pure returns (uint64) { | |
| return a < b ? a : b; | |
| } | |
| function max256(uint256 a, uint256 b) internal pure returns (uint256) { | |
| return a >= b ? a : b; | |
| } | |
| function min256(uint256 a, uint256 b) internal pure returns (uint256) { | |
| return a < b ? a : b; | |
| } | |
| function assert(bool assertion) internal { | |
| if (!assertion) { | |
| revert(); | |
| } | |
| } | |
| } | |
| /** | |
| * @title ERC20Basic | |
| * @dev Simpler version of ERC20 interface | |
| * @dev see https://github.com/ethereum/EIPs/issues/20 | |
| */ | |
| contract ERC20Basic { | |
| uint public totalSupply; | |
| function balanceOf(address who) view returns (uint); | |
| function transfer(address to, uint value); | |
| event Transfer(address indexed from, address indexed to, uint value); | |
| } | |
| /** | |
| * @title Basic token | |
| * @dev Basic version of StandardToken, with no allowances. | |
| */ | |
| contract BasicToken is ERC20Basic { | |
| using SafeMath for uint; | |
| mapping(address => uint) balances; | |
| /** | |
| * @dev Fix for the ERC20 short address attack. | |
| */ | |
| modifier onlyPayloadSize(uint size) { | |
| if(msg.data.length < size + 4) { | |
| throw; | |
| } | |
| _; | |
| } | |
| /** | |
| * @dev transfer token for a specified address | |
| * @param _to The address to transfer to. | |
| * @param _value The amount to be transferred. | |
| */ | |
| function transfer(address _to, uint _value) onlyPayloadSize(2 * 32) { | |
| balances[msg.sender] = balances[msg.sender].sub(_value); | |
| balances[_to] = balances[_to].add(_value); | |
| Transfer(msg.sender, _to, _value); | |
| } | |
| /** | |
| * @dev Gets the balance of the specified address. | |
| * @param _owner The address to query the the balance of. | |
| * @return An uint representing the amount owned by the passed address. | |
| */ | |
| function balanceOf(address _owner) view returns (uint balance) { | |
| return balances[_owner]; | |
| } | |
| } | |
| /** | |
| * @title ERC20 interface | |
| * @dev see https://github.com/ethereum/EIPs/issues/20 | |
| */ | |
| contract ERC20 is ERC20Basic { | |
| function allowance(address owner, address spender) view returns (uint); | |
| function transferFrom(address from, address to, uint value); | |
| function approve(address spender, uint value); | |
| event Approval(address indexed owner, address indexed spender, uint value); | |
| } | |
| /** | |
| * @title Standard ERC20 token | |
| * | |
| * @dev Implemantation of the basic standart token. | |
| * @dev https://github.com/ethereum/EIPs/issues/20 | |
| * @dev Based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol | |
| */ | |
| contract StandardToken is BasicToken, ERC20 { | |
| mapping (address => mapping (address => uint)) allowed; | |
| /** | |
| * @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 uint the amout of tokens to be transfered | |
| */ | |
| function transferFrom(address _from, address _to, uint _value) onlyPayloadSize(3 * 32) { | |
| var _allowance = allowed[_from][msg.sender]; | |
| // Check is not needed because sub(_allowance, _value) will already throw if this condition is not met | |
| // if (_value > _allowance) throw; | |
| balances[_to] = balances[_to].add(_value); | |
| balances[_from] = balances[_from].sub(_value); | |
| allowed[_from][msg.sender] = _allowance.sub(_value); | |
| Transfer(_from, _to, _value); | |
| } | |
| /** | |
| * @dev Aprove the passed address to spend the specified amount of tokens on beahlf of msg.sender. | |
| * @param _spender The address which will spend the funds. | |
| * @param _value The amount of tokens to be spent. | |
| */ | |
| function approve(address _spender, uint _value) { | |
| // 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); | |
| } | |
| /** | |
| * @dev Function to check the amount of tokens than an owner allowed to a spender. | |
| * @param _owner address The address which owns the funds. | |
| * @param _spender address The address which will spend the funds. | |
| * @return A uint specifing the amount of tokens still avaible for the spender. | |
| */ | |
| function allowance(address _owner, address _spender) view returns (uint remaining) { | |
| return allowed[_owner][_spender]; | |
| } | |
| } | |
| /** | |
| * @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; | |
| /** | |
| * @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() { | |
| if (msg.sender != owner) { | |
| throw; | |
| } | |
| _; | |
| } | |
| /** | |
| * @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 { | |
| if (newOwner != address(0)) { | |
| owner = newOwner; | |
| } | |
| } | |
| } | |
| /** | |
| * @title Mintable token | |
| * @dev Simple ERC20 Token example, with mintable token creation | |
| * @dev Issue: * https://github.com/OpenZeppelin/zeppelin-solidity/issues/120 | |
| * Based on code by TokenMarketNet: https://github.com/TokenMarketNet/ico/blob/master/contracts/MintableToken.sol | |
| */ | |
| contract MintableToken is StandardToken, Ownable { | |
| event Mint(address indexed to, uint value); | |
| event MintFinished(); | |
| bool public mintingFinished = false; | |
| uint public totalSupply = 0; | |
| modifier canMint() { | |
| if(mintingFinished) throw; | |
| _; | |
| } | |
| /** | |
| * @dev Function to mint tokens | |
| * @param _to The address that will recieve the minted tokens. | |
| * @param _amount The amount of tokens to mint. | |
| * @return A boolean that indicates if the operation was successful. | |
| */ | |
| function mint(address _to, uint _amount) onlyOwner canMint returns (bool) { | |
| totalSupply = totalSupply.add(_amount); | |
| balances[_to] = balances[_to].add(_amount); | |
| Mint(_to, _amount); | |
| return true; | |
| } | |
| /** | |
| * @dev Function to stop minting new tokens. | |
| * @return True if the operation was successful. | |
| */ | |
| function finishMinting() onlyOwner returns (bool) { | |
| mintingFinished = true; | |
| MintFinished(); | |
| return true; | |
| } | |
| } | |
| /** | |
| * @title Pausable | |
| * @dev Base contract which allows children to implement an emergency stop mechanism. | |
| */ | |
| contract Pausable is Ownable { | |
| event Pause(); | |
| event Unpause(); | |
| bool public paused = false; | |
| /** | |
| * @dev modifier to allow actions only when the contract IS paused | |
| */ | |
| modifier whenNotPaused() { | |
| if (paused) throw; | |
| _; | |
| } | |
| /** | |
| * @dev modifier to allow actions only when the contract IS NOT paused | |
| */ | |
| modifier whenPaused { | |
| if (!paused) throw; | |
| _; | |
| } | |
| /** | |
| * @dev called by the owner to pause, triggers stopped state | |
| */ | |
| function pause() onlyOwner whenNotPaused returns (bool) { | |
| paused = true; | |
| Pause(); | |
| return true; | |
| } | |
| /** | |
| * @dev called by the owner to unpause, returns to normal state | |
| */ | |
| function unpause() onlyOwner whenPaused returns (bool) { | |
| paused = false; | |
| Unpause(); | |
| return true; | |
| } | |
| } | |
| /** | |
| * Pausable token | |
| * | |
| * Simple ERC20 Token example, with pausable token creation | |
| **/ | |
| contract PausableToken is StandardToken, Pausable { | |
| function transfer(address _to, uint _value) whenNotPaused { | |
| super.transfer(_to, _value); | |
| } | |
| function transferFrom(address _from, address _to, uint _value) whenNotPaused { | |
| super.transferFrom(_from, _to, _value); | |
| } | |
| } | |
| /** | |
| * @title TokenTimelock | |
| * @dev TokenTimelock is a token holder contract that will allow a | |
| * beneficiary to extract the tokens after a time has passed | |
| */ | |
| contract TokenTimelock { | |
| // ERC20 basic token contract being held | |
| ERC20Basic token; | |
| // beneficiary of tokens after they are released | |
| address beneficiary; | |
| // timestamp where token release is enabled | |
| uint releaseTime; | |
| function TokenTimelock(ERC20Basic _token, address _beneficiary, uint _releaseTime) { | |
| require(_releaseTime > now); | |
| token = _token; | |
| beneficiary = _beneficiary; | |
| releaseTime = _releaseTime; | |
| } | |
| /** | |
| * @dev beneficiary claims tokens held by time lock | |
| */ | |
| function claim() { | |
| require(msg.sender == beneficiary); | |
| require(now >= releaseTime); | |
| uint amount = token.balanceOf(this); | |
| require(amount > 0); | |
| token.transfer(beneficiary, amount); | |
| } | |
| } | |
| /** | |
| * @title OMGToken | |
| * @dev Omise Go Token contract | |
| */ | |
| contract OMGToken is PausableToken, MintableToken { | |
| using SafeMath for uint256; | |
| string public name = "OMGToken"; | |
| string public symbol = "OMG"; | |
| uint public decimals = 18; | |
| /** | |
| * @dev mint timelocked tokens | |
| */ | |
| function mintTimelocked(address _to, uint256 _amount, uint256 _releaseTime) | |
| onlyOwner canMint returns (TokenTimelock) { | |
| TokenTimelock timelock = new TokenTimelock(this, _to, _releaseTime); | |
| mint(timelock, _amount); | |
| return timelock; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.7.0; | |
| contract A { | |
| uint a = 10; | |
| event SetA(uint a); | |
| function setA(uint _a) public { | |
| a = _a; | |
| emit SetA(_a); | |
| } | |
| function getA() public view returns (uint) { | |
| return a; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.6.0; | |
| contract EasySmartcontract { | |
| uint256 public number_smart; | |
| constructor(uint256 number) public { | |
| number_smart = number; | |
| } | |
| function changeNumber(uint256 value) public returns (bool){ | |
| number_smart = value; | |
| return true; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.6.0; | |
| contract TokenBegin { | |
| uint public totalSupply; | |
| mapping(address => uint) public balances; | |
| event Transfer(address indexed _from, address indexed _to, uint256 _value); | |
| constructor(uint _value) public { | |
| totalSupply = _value; | |
| balances[msg.sender] = totalSupply; | |
| } | |
| function transfer(address to, uint _value) public returns (bool) { | |
| require(balances[msg.sender] >= _value); | |
| balances[to] += _value; | |
| balances[msg.sender] -= _value; | |
| emit Transfer(msg.sender, to, _value); | |
| return true; | |
| } | |
| function balanceOf(address owner) view public returns (uint){ | |
| return balances[owner]; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.6.0; | |
| contract Owned { | |
| address public owner; | |
| address public newOwner; | |
| event OwnershipTransferred(address indexed _from, address indexed _to); | |
| constructor() public { | |
| owner = msg.sender; | |
| } | |
| modifier onlyOwner { | |
| require(msg.sender == owner); | |
| _; | |
| } | |
| function transferOwnership(address _newOwner) public onlyOwner { | |
| newOwner = _newOwner; | |
| } | |
| function acceptOwnership() public { | |
| require(msg.sender == newOwner); | |
| emit OwnershipTransferred(owner, newOwner); | |
| owner = newOwner; | |
| newOwner = address(0); | |
| } | |
| } | |
| contract TokenBegin is Owned{ | |
| uint public totalSupply; | |
| mapping(address => uint) public balances; | |
| mapping(address => mapping (address => uint256)) allowed; | |
| event Transfer(address indexed _from, address indexed _to, uint256 _value); | |
| event Approval(address indexed _owner, address indexed _spender, uint256 _value); | |
| string public constant name = "ManZer"; | |
| string public constant symbol = "MAN"; | |
| uint8 public constant decimals = 18; // 18 is the most common number of decimal places | |
| constructor(uint _value) public { | |
| totalSupply = _value; | |
| balances[msg.sender] = totalSupply; | |
| } | |
| function transfer(address to, uint _value) public returns (bool) { | |
| require(balances[msg.sender] >= _value); | |
| balances[to] += _value; | |
| balances[msg.sender] -= _value; | |
| emit Transfer(msg.sender, to, _value); | |
| return true; | |
| } | |
| function balanceOf(address owner) view public returns (uint){ | |
| return balances[owner]; | |
| } | |
| function transferFrom(address _from, address _to, uint256 _value) public returns (bool success){ | |
| balances[_from] -= _value; | |
| allowed[_from][msg.sender] += _value; | |
| balances[_to] += _value; | |
| emit Transfer(msg.sender, _to, _value); | |
| return true; | |
| } | |
| function approve(address _spender, uint256 _value) public returns (bool success){ | |
| allowed[msg.sender][_spender] = _value; | |
| emit Approval(msg.sender, _spender, _value); | |
| return true; | |
| } | |
| function allowance(address _owner, address _spender) public view returns (uint256 remaining){ | |
| return allowed[_owner][_spender]; | |
| } | |
| function mintSupply(uint _value) public onlyOwner returns(bool) { | |
| totalSupply += _value; | |
| balances[msg.sender] += _value; | |
| return true; | |
| } | |
| function burnSupply(uint _value) public onlyOwner returns(bool) { | |
| require(balances[msg.sender] >= _value, 'Something bad happened') ; | |
| totalSupply -= _value; | |
| balances[msg.sender] -= _value; | |
| return true; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.6.0; | |
| contract loan { | |
| mapping(address => bool) public borrow; | |
| mapping(address => uint) public balances; | |
| mapping(address => Borrower) public borrower_contract; | |
| event BorrowCall(address borrower, uint _value, uint installment, uint interest, address no); | |
| struct Borrower { | |
| address borrow; | |
| uint amount; | |
| uint interest; | |
| address no; | |
| uint installments; | |
| } | |
| function deposit() payable public { | |
| balances[msg.sender] = msg.value; | |
| } | |
| function Installment() internal returns(bool){ | |
| Borrower storage borow = borrower_contract[msg.sender]; | |
| if(borow.installments == 1){ | |
| require(borow.amount == msg.value); | |
| borrow[msg.sender] = false; | |
| } | |
| borow.installments -= 1; | |
| borow.amount -= msg.value; | |
| return true; | |
| } | |
| function borrowStart(uint _value, uint _installments, uint _interest) public returns(bool){ | |
| require(!borrow[msg.sender]); | |
| require(address(this).balance >= _value, 'this contract not enough balance'); | |
| Borrower storage borow = borrower_contract[msg.sender]; | |
| borow.amount = _value; | |
| borow.interest = _interest; | |
| borow.installments = _installments; | |
| borow.borrow = msg.sender; | |
| borow.no = tx.origin; | |
| msg.sender.transfer(_value); | |
| emit BorrowCall(msg.sender, _value, _installments, _interest, tx.origin); | |
| borrow[msg.sender] = true; | |
| return true; | |
| } | |
| function () payable external { | |
| if(borrow[msg.sender]){ | |
| Installment(); | |
| }else{ | |
| deposit(); | |
| } | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.7.0; | |
| contract kloan { | |
| mapping(address => bool) public Lender; | |
| mapping(address => bool) public Borrower; | |
| mapping(address => uint) public balances; | |
| mapping(address => loan) public contractK; | |
| struct loan{ | |
| address lender; | |
| address borrower; | |
| uint amount; | |
| uint installments; | |
| uint expire; | |
| uint interest; | |
| uint total; | |
| uint pay; | |
| address tx; | |
| } | |
| function () external payable { | |
| if(Borrower[msg.sender]){ | |
| Installment(); | |
| }else{ | |
| deposit(); | |
| } | |
| } | |
| function deposit() internal { | |
| Lender[msg.sender] = true; | |
| balances[msg.sender] += msg.value; | |
| } | |
| function okloan(uint _amount, address _lender, uint _installments) public returns (bool){ | |
| require(!Lender[msg.sender]); | |
| require(balances[_lender] >= _amount); | |
| uint _interest = 5; | |
| loan storage x = contractK[msg.sender]; | |
| x.lender = _lender; | |
| x.borrower = msg.sender; | |
| x.amount = _amount; | |
| x.installments = _installments; | |
| x.expire = now + 7 days; | |
| x.interest = _interest; | |
| x.total = ((_interest/100)*_amount) + _amount; | |
| x.pay = x.total/_installments; | |
| x.tx = tx.origin; | |
| msg.sender.transfer(_amount); | |
| Borrower[msg.sender] = true; | |
| return true; | |
| } | |
| function Installment() internal{ | |
| loan storage x = contractK[msg.sender]; | |
| require(x.pay == msg.value); | |
| require(now < x.expire, 'sorry this contract expire !'); | |
| if(x.installments == 1) { | |
| require(x.amount >= msg.value); | |
| Borrower[msg.sender] = false; | |
| } | |
| x.installments -= 1; | |
| x.amount -= msg.value; | |
| convertAddress(x.lender).transfer(msg.value); | |
| } | |
| function convertAddress(address _lender) internal pure returns (address payable) { | |
| return address(uint160(_lender)); | |
| } | |
| } |
This file contains hidden or 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
| /* | |
| Lottery Contract | |
| */ | |
| pragma solidity >=0.4.22 <0.6.0; | |
| import "github.com/oraclize/ethereum-api/oraclizeAPI.sol"; | |
| contract Lottery is usingOraclize { | |
| string public betNumber; | |
| string public result; | |
| address payable public house; | |
| address payable public better; | |
| uint256 public balances; | |
| enum State { Created, Betted, Paidout, Inactive } | |
| State public state; | |
| event newOraclizeQuery(string description); | |
| event Aborted(); | |
| event Betted(); | |
| event Released(); | |
| constructor() public payable { | |
| house = msg.sender; | |
| state = State.Created; | |
| } | |
| modifier condition(bool _condition) { | |
| require(_condition); | |
| _; | |
| } | |
| modifier onlyBetter() { | |
| require(msg.sender == better); | |
| _; | |
| } | |
| modifier onlyHouse() { | |
| require(msg.sender == house); | |
| _; | |
| } | |
| modifier inState(State _state) { | |
| require(state == _state); | |
| _; | |
| } | |
| //source: https://ethereum.stackexchange.com/questions/30912/how-to-compare-strings-in-solidity | |
| function compareStrings (string memory a, string memory b) pure public returns (bool){ | |
| return keccak256(abi.encode(a)) == keccak256(abi.encode(b)); | |
| } | |
| function bet(string memory _betNumber) | |
| public | |
| inState(State.Created) | |
| payable | |
| { | |
| emit Betted(); | |
| better = msg.sender; | |
| betNumber = _betNumber; | |
| state = State.Betted; | |
| } | |
| function abort() | |
| public | |
| onlyHouse | |
| inState(State.Created) | |
| { | |
| emit Aborted(); | |
| state = State.Inactive; | |
| house.transfer(address(this).balance); | |
| } | |
| function release() | |
| payable | |
| public | |
| onlyHouse | |
| inState(State.Betted) | |
| { | |
| if (oraclize_getPrice("URL") > address(this).balance) { | |
| emit newOraclizeQuery("Oraclize query was NOT sent, please add some ETH to cover for the query fee"); | |
| } else { | |
| emit newOraclizeQuery("Oraclize query was sent, standing by for the answer.."); | |
| oraclize_query("URL", "json(https://jacksonng.org/codetest/random.php).random"); | |
| } | |
| } | |
| function __callback(bytes32 myid, string memory res) public { | |
| if (msg.sender != oraclize_cbAddress()) revert(); | |
| result = res; | |
| if (compareStrings(result,betNumber)) { | |
| better.transfer(address(this).balance); | |
| } | |
| else { | |
| house.transfer(address(this).balance); | |
| } | |
| emit Released(); | |
| state = State.Paidout; | |
| } | |
| function () payable external { | |
| balances += msg.value; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity ^0.4.11; | |
| /** | |
| * Math operations with safety checks | |
| */ | |
| library 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); // Solidity automatically throws when dividing by 0 | |
| uint c = a / b; | |
| // assert(a == b * c + a % b); // There is no case in which this doesn't hold | |
| 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 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; | |
| } | |
| function assert(bool assertion) internal { | |
| if (!assertion) { | |
| throw; | |
| } | |
| } | |
| } | |
| /** | |
| * @title ERC20Basic | |
| * @dev Simpler version of ERC20 interface | |
| * @dev see https://github.com/ethereum/EIPs/issues/20 | |
| */ | |
| contract ERC20Basic { | |
| uint public totalSupply; | |
| function balanceOf(address who) constant returns (uint); | |
| function transfer(address to, uint value); | |
| event Transfer(address indexed from, address indexed to, uint value); | |
| } | |
| /** | |
| * @title Basic token | |
| * @dev Basic version of StandardToken, with no allowances. | |
| */ | |
| contract BasicToken is ERC20Basic { | |
| using SafeMath for uint; | |
| mapping(address => uint) balances; | |
| /** | |
| * @dev Fix for the ERC20 short address attack. | |
| */ | |
| modifier onlyPayloadSize(uint size) { | |
| if(msg.data.length < size + 4) { | |
| throw; | |
| } | |
| _; | |
| } | |
| /** | |
| * @dev transfer token for a specified address | |
| * @param _to The address to transfer to. | |
| * @param _value The amount to be transferred. | |
| */ | |
| function transfer(address _to, uint _value) onlyPayloadSize(2 * 32) { | |
| balances[msg.sender] = balances[msg.sender].sub(_value); | |
| balances[_to] = balances[_to].add(_value); | |
| Transfer(msg.sender, _to, _value); | |
| } | |
| /** | |
| * @dev Gets the balance of the specified address. | |
| * @param _owner The address to query the the balance of. | |
| * @return An uint representing the amount owned by the passed address. | |
| */ | |
| function balanceOf(address _owner) constant returns (uint balance) { | |
| return balances[_owner]; | |
| } | |
| } | |
| /** | |
| * @title ERC20 interface | |
| * @dev see https://github.com/ethereum/EIPs/issues/20 | |
| */ | |
| contract ERC20 is ERC20Basic { | |
| function allowance(address owner, address spender) constant returns (uint); | |
| function transferFrom(address from, address to, uint value); | |
| function approve(address spender, uint value); | |
| event Approval(address indexed owner, address indexed spender, uint value); | |
| } | |
| /** | |
| * @title Standard ERC20 token | |
| * | |
| * @dev Implemantation of the basic standart token. | |
| * @dev https://github.com/ethereum/EIPs/issues/20 | |
| * @dev Based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol | |
| */ | |
| contract StandardToken is BasicToken, ERC20 { | |
| mapping (address => mapping (address => uint)) allowed; | |
| /** | |
| * @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 uint the amout of tokens to be transfered | |
| */ | |
| function transferFrom(address _from, address _to, uint _value) onlyPayloadSize(3 * 32) { | |
| var _allowance = allowed[_from][msg.sender]; | |
| // Check is not needed because sub(_allowance, _value) will already throw if this condition is not met | |
| // if (_value > _allowance) throw; | |
| balances[_to] = balances[_to].add(_value); | |
| balances[_from] = balances[_from].sub(_value); | |
| allowed[_from][msg.sender] = _allowance.sub(_value); | |
| Transfer(_from, _to, _value); | |
| } | |
| /** | |
| * @dev Aprove the passed address to spend the specified amount of tokens on beahlf of msg.sender. | |
| * @param _spender The address which will spend the funds. | |
| * @param _value The amount of tokens to be spent. | |
| */ | |
| function approve(address _spender, uint _value) { | |
| // 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); | |
| } | |
| /** | |
| * @dev Function to check the amount of tokens than an owner allowed to a spender. | |
| * @param _owner address The address which owns the funds. | |
| * @param _spender address The address which will spend the funds. | |
| * @return A uint specifing the amount of tokens still avaible for the spender. | |
| */ | |
| function allowance(address _owner, address _spender) constant returns (uint remaining) { | |
| return allowed[_owner][_spender]; | |
| } | |
| } | |
| /** | |
| * @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; | |
| /** | |
| * @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() { | |
| if (msg.sender != owner) { | |
| throw; | |
| } | |
| _; | |
| } | |
| /** | |
| * @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 { | |
| if (newOwner != address(0)) { | |
| owner = newOwner; | |
| } | |
| } | |
| } | |
| /** | |
| * @title Mintable token | |
| * @dev Simple ERC20 Token example, with mintable token creation | |
| * @dev Issue: * https://github.com/OpenZeppelin/zeppelin-solidity/issues/120 | |
| * Based on code by TokenMarketNet: https://github.com/TokenMarketNet/ico/blob/master/contracts/MintableToken.sol | |
| */ | |
| contract MintableToken is StandardToken, Ownable { | |
| event Mint(address indexed to, uint value); | |
| event MintFinished(); | |
| bool public mintingFinished = false; | |
| uint public totalSupply = 0; | |
| modifier canMint() { | |
| if(mintingFinished) throw; | |
| _; | |
| } | |
| /** | |
| * @dev Function to mint tokens | |
| * @param _to The address that will recieve the minted tokens. | |
| * @param _amount The amount of tokens to mint. | |
| * @return A boolean that indicates if the operation was successful. | |
| */ | |
| function mint(address _to, uint _amount) onlyOwner canMint returns (bool) { | |
| totalSupply = totalSupply.add(_amount); | |
| balances[_to] = balances[_to].add(_amount); | |
| Mint(_to, _amount); | |
| return true; | |
| } | |
| /** | |
| * @dev Function to stop minting new tokens. | |
| * @return True if the operation was successful. | |
| */ | |
| function finishMinting() onlyOwner returns (bool) { | |
| mintingFinished = true; | |
| MintFinished(); | |
| return true; | |
| } | |
| } | |
| /** | |
| * @title Pausable | |
| * @dev Base contract which allows children to implement an emergency stop mechanism. | |
| */ | |
| contract Pausable is Ownable { | |
| event Pause(); | |
| event Unpause(); | |
| bool public paused = false; | |
| /** | |
| * @dev modifier to allow actions only when the contract IS paused | |
| */ | |
| modifier whenNotPaused() { | |
| if (paused) throw; | |
| _; | |
| } | |
| /** | |
| * @dev modifier to allow actions only when the contract IS NOT paused | |
| */ | |
| modifier whenPaused { | |
| if (!paused) throw; | |
| _; | |
| } | |
| /** | |
| * @dev called by the owner to pause, triggers stopped state | |
| */ | |
| function pause() onlyOwner whenNotPaused returns (bool) { | |
| paused = true; | |
| Pause(); | |
| return true; | |
| } | |
| /** | |
| * @dev called by the owner to unpause, returns to normal state | |
| */ | |
| function unpause() onlyOwner whenPaused returns (bool) { | |
| paused = false; | |
| Unpause(); | |
| return true; | |
| } | |
| } | |
| /** | |
| * Pausable token | |
| * | |
| * Simple ERC20 Token example, with pausable token creation | |
| **/ | |
| contract PausableToken is StandardToken, Pausable { | |
| function transfer(address _to, uint _value) whenNotPaused { | |
| super.transfer(_to, _value); | |
| } | |
| function transferFrom(address _from, address _to, uint _value) whenNotPaused { | |
| super.transferFrom(_from, _to, _value); | |
| } | |
| } | |
| /** | |
| * @title TokenTimelock | |
| * @dev TokenTimelock is a token holder contract that will allow a | |
| * beneficiary to extract the tokens after a time has passed | |
| */ | |
| contract TokenTimelock { | |
| // ERC20 basic token contract being held | |
| ERC20Basic token; | |
| // beneficiary of tokens after they are released | |
| address beneficiary; | |
| // timestamp where token release is enabled | |
| uint releaseTime; | |
| function TokenTimelock(ERC20Basic _token, address _beneficiary, uint _releaseTime) { | |
| require(_releaseTime > now); | |
| token = _token; | |
| beneficiary = _beneficiary; | |
| releaseTime = _releaseTime; | |
| } | |
| /** | |
| * @dev beneficiary claims tokens held by time lock | |
| */ | |
| function claim() { | |
| require(msg.sender == beneficiary); | |
| require(now >= releaseTime); | |
| uint amount = token.balanceOf(this); | |
| require(amount > 0); | |
| token.transfer(beneficiary, amount); | |
| } | |
| } | |
| /** | |
| * @title OMGToken | |
| * @dev Omise Go Token contract | |
| */ | |
| contract ManToken is PausableToken, MintableToken { | |
| using SafeMath for uint256; | |
| string public name = "ManToken"; | |
| string public symbol = "MAN"; | |
| uint public decimals = 18; | |
| /** | |
| * @dev mint timelocked tokens | |
| */ | |
| function mintTimelocked(address _to, uint256 _amount, uint256 _releaseTibame) | |
| onlyOwner canMint returns (TokenTimelock) { | |
| TokenTimelock timelock = new TokenTimelock(this, _to, _releaseTime); | |
| mint(timelock, _amount); | |
| return timelock; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.0 <0.7.0; | |
| contract x { | |
| function d() public{ | |
| uint k = now; //1528328328; | |
| } | |
| } |
This file contains hidden or 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
| pragma solidity >=0.4.22 <0.7.0; | |
| contract A { | |
| function checkTime() public view returns (uint) { | |
| return now; | |
| } | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment