/
contract-88653690418.clar
49 lines (36 loc) · 1.43 KB
/
contract-88653690418.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
44
45
46
47
48
49
(impl-trait 'SP3FBR2AGK5H9QBDH3EEN6DF8EK8JY7RX8QJ5SVTE.sip-010-trait-ft-standard.sip-010-trait)
(define-constant contract-owner tx-sender)
(define-constant err-owner-only (err u100))
(define-constant err-not-token-owner (err u101))
;; No maximum supply!
(define-fungible-token paul)
(define-data-var token-name (string-ascii 32) "Paul Boss de Boss")
(define-data-var token-symbol (string-ascii 10) "paul")
(define-public (set-name (new-name (string-ascii 32)))
(begin
(ok (var-set token-name new-name))))
(define-public (set-symbol (new-symbol (string-ascii 10)))
(begin
(ok (var-set token-symbol new-symbol))))
(define-read-only (get-name)
(ok (var-get token-name)))
(define-read-only (get-symbol)
(ok (var-get token-symbol)))
(define-read-only (get-decimals)
(ok u0))
(define-read-only (get-balance (who principal))
(ok (ft-get-balance paul who)))
(define-read-only (get-total-supply)
(ok (ft-get-supply paul)))
(define-read-only (get-token-uri)
(ok none))
(define-public (transfer (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34))))
(begin
(asserts! (is-eq tx-sender sender) err-not-token-owner)
(try! (ft-transfer? paul amount sender recipient))
(match memo to-print (print to-print) 0x)
(ok true)))
(define-public (mint (amount uint) (recipient principal))
(begin
(asserts! (is-eq tx-sender contract-owner) err-owner-only)
(ft-mint? paul amount recipient)))