This repository has been archived by the owner on Aug 8, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 33
/
DTKERC20.cairo
121 lines (105 loc) · 3.3 KB
/
DTKERC20.cairo
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
%lang starknet
from starkware.cairo.common.cairo_builtins import HashBuiltin
from starkware.cairo.common.uint256 import Uint256
from starkware.starknet.common.syscalls import get_caller_address
from openzeppelin.token.erc20.library import ERC20
@constructor
func constructor{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(
name: felt, symbol: felt, initial_supply: Uint256, recipient: felt
) {
ERC20.initializer(name, symbol, 18);
ERC20._mint(recipient, initial_supply);
return ();
}
//
// Getters
//
@view
func name{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}() -> (name: felt) {
let (name) = ERC20.name();
return (name,);
}
@view
func symbol{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}() -> (symbol: felt) {
let (symbol) = ERC20.symbol();
return (symbol,);
}
@view
func totalSupply{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}() -> (
totalSupply: Uint256
) {
let (totalSupply: Uint256) = ERC20.total_supply();
return (totalSupply,);
}
@view
func decimals{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}() -> (
decimals: felt
) {
let (decimals) = ERC20.decimals();
return (decimals,);
}
@view
func balanceOf{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(account: felt) -> (
balance: Uint256
) {
let (balance: Uint256) = ERC20.balance_of(account);
return (balance,);
}
@view
func allowance{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(
owner: felt, spender: felt
) -> (remaining: Uint256) {
let (remaining: Uint256) = ERC20.allowance(owner, spender);
return (remaining,);
}
//
// Externals
//
@external
func faucet{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}() -> (success: felt) {
let amount: Uint256 = Uint256(100 * 1000000000000000000, 0);
let (caller) = get_caller_address();
ERC20._mint(caller, amount);
// Cairo equivalent to 'return (true)'
return (1,);
}
@external
func transfer{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(
recipient: felt, amount: Uint256
) -> (success: felt) {
ERC20.transfer(recipient, amount);
// Cairo equivalent to 'return (true)'
return (1,);
}
@external
func transferFrom{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(
sender: felt, recipient: felt, amount: Uint256
) -> (success: felt) {
ERC20.transfer_from(sender, recipient, amount);
// Cairo equivalent to 'return (true)'
return (1,);
}
@external
func approve{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(
spender: felt, amount: Uint256
) -> (success: felt) {
ERC20.approve(spender, amount);
// Cairo equivalent to 'return (true)'
return (1,);
}
@external
func increaseAllowance{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(
spender: felt, added_value: Uint256
) -> (success: felt) {
ERC20.increase_allowance(spender, added_value);
// Cairo equivalent to 'return (true)'
return (1,);
}
@external
func decreaseAllowance{syscall_ptr: felt*, pedersen_ptr: HashBuiltin*, range_check_ptr}(
spender: felt, subtracted_value: Uint256
) -> (success: felt) {
ERC20.decrease_allowance(spender, subtracted_value);
// Cairo equivalent to 'return (true)'
return (1,);
}