/
BABYTHOR.clar
43 lines (32 loc) · 1.39 KB
/
BABYTHOR.clar
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
(impl-trait 'SP20X3DC5R091J8B6YPQT638J8NR1W83KN6TN5BJY.ft-trait.ft-trait)
(define-constant MAX_SUPPLY (* u1000000000 (pow u10 u6)))
(define-fungible-token BABYTHOR MAX_SUPPLY)
(define-constant err-check-owner (err u1))
(define-constant err-transfer (err u4))
(define-data-var owner principal tx-sender)
(define-private (check-owner)
(ok (asserts! (is-eq tx-sender (var-get owner)) err-check-owner)))
(define-public (set-owner (new-owner principal))
(begin
(try! (check-owner))
(ok (var-set owner new-owner)) ))
(define-public
(transfer
(amt uint)
(from principal)
(to principal)
(memo (optional (buff 34))))
(begin
(asserts! (is-eq tx-sender from) err-transfer)
(ft-transfer? BABYTHOR amt from to)))
(define-public (mint (amt uint) (to principal))
(begin
(try! (check-owner))
(ft-mint? BABYTHOR amt to) ))
(define-read-only (get-name) (ok "BABYTHOR"))
(define-read-only (get-symbol) (ok "BABYTHOR"))
(define-read-only (get-decimals) (ok u6))
(define-read-only (get-balance (of principal)) (ok (ft-get-balance BABYTHOR of)))
(define-read-only (get-total-supply) (ok (ft-get-supply BABYTHOR)))
(define-read-only (get-max-supply) (ok MAX_SUPPLY))
(define-read-only (get-token-uri) (ok (some u"https://babythor.com")))