トークンの作成
pragma solidity ^0.8.0;
interface ERC20 {
event Transfer(address _from, address _to, uint256 _value);
event Approval(address _from, address _to, uint256 _value);
// 6 function
function totalSupply() external view returns(uint256);
function balanceOf(address _owner) external view returns(uint256);
function transfer(address _to, uint _value) external returns(bool);
function transferFrom(address _from, address _to, uint256 _value) external returns (bool);
function approve(address _spender, uint256 _value) external returns(bool);
function allowance(address _owner, address _spender) external view returns(uint256);
}
contract StandardToken is ERC20 {
mapping(address => uint256) balances;
mapping(address => mapping(address=>uint256)) allowed;
//allowed[_from][_to] = 50eth;
function totalSupply() override external view returns(uint256) {}
function balanceOf(address _owner) override external view returns(uint256) {
return balances[_owner];
}
function transfer(address _to, uint256 _value) override external returns(bool) {
// owner(_from) -> to(_to) owner have 10eth _value 11 eth
if(balances[msg.sender]>=_value && _value>0){
//true
balances[msg.sender] -= _value;
balances[_to] += _value;
emit Transfer(msg.sender,_to,_value);
return true;
}else{
//false
return false;
}
}
function transferFrom(address _from, address _to, uint256 _value) override external returns (bool) {
if(balances[_from] > _value && _value > 0){
balances[_from] -= _value;
balances[_to] += _value;
emit Transfer(_from,_to,_value);
allowed[_from][_to] -= _value;
return true;
}else{
return false;
}
}
function approve(address _spender, uint256 _value) override external returns(bool) {
allowed[msg.sender][_spender] = _value;
emit Approval(msg.sender, _spender,_value);
return true;
}
function allowance(address _owner, address _spender) external view returns(uint256){
return allowed[_owner][_spender];
}
}
contract IngToken is StandardToken {
string public name; // token name
uint8 public decimals; // 소수점 18 wei의 단위를 넣기 위해
string public symbol; // 단위
string public version; // 1.0.
uint256 public uintsOneEthCanBuy;
uint256 public totalEthInWei;
address public fundWallet;
// 상태변수 선언하고
constructor() payable public{
// 생성자 함수는 최초 한 번만 실행하고 이후는 실행되지 않음
name = "IngToken";
decimals = 18;
symbol = "ING";
uintsOneEthCanBuy = 100;
// 소유자의 이더를 저장하는 공간
fundWallet = msg.sender;
balances[msg.sender] = 1000000000000000000000;
}
// 2가지
// fallback function
// approveAndCall function
/*
// 2가지 익명함수
function(){
}
*/
fallback() external payable {
totalEthInWei = totalEthInWei + msg.value;
uint256 amount = msg.value * uintsOneEthCanBuy;
require(balances[fundWallet] >= amount);
// 코드 실행한 사람주소의 balances
// require()안에 있는 내용이 true이면 코드 계속 진행하고, false이면 코드 종료
// javascript에서 쓰이는 require()와는 다름 . 함수명만 같은 것이다.
balances[fundWallet] -= amount;
balances[msg.sender] += amount;
// 토큰은 거래됨.
emit Transfer(fundWallet, msg.sender, amount);
payable(fundWallet).transfer(msg.value);
}
function approveAndCall(address _spender, uint256 _value, bytes memory _extraData) public returns(bool){
// 내가 다른 사람함수를 쓸때 사용하는 메서드
allowed[msg.sender][_spender] = _value;
emit Approval(msg.sender,_spender,_value);
// "receiveApprpval(address,uint256,address,bytes)"
// msg.sender// _value
// address(this)
//_extraData
// 인자값 5개
// abi.encodeWithSinature(,,,,)
// function
// msg.sender 호출 시킨 사람 주소
// _value 이더수량
// address : 받는 사람 address(this)
// byte :_extraData
// call 이라는 함수가 실행 => object (bool,bytes)
(bool success, bytes memory data) = _spender.call(abi.encodeWithSignature("receiveApprpval(address,uint256,address,bytes)",msg.sender,_value,address(this),_extraData));
require(success,"call failed");
return true;
}
// fallback
// approveAndCall
// 0x957bc22059C07360d7b57725917FDe44021b8237
}
Reference
この問題について(トークンの作成), 我々は、より多くの情報をここで見つけました https://velog.io/@algml/토큰만들기テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol