-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathTRAKLIST-MARKETPLACE-V1.clar
75 lines (61 loc) · 2.58 KB
/
TRAKLIST-MARKETPLACE-V1.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
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
(impl-trait 'SP2PABAF9FTAJYNFZH93XENAJ8FVY99RRM50D2JG9.nft-trait.nft-trait)
(define-non-fungible-token TRX-PROTO uint)
(define-constant ERR-USER-NOT-WHITELISTED u401)
(define-constant ERR-NFT-NOT-WHITELISTED u402)
(define-constant ERR-NOT-AUTHORIZED u403)
(define-constant ERR-MINT-FAILED u100)
(define-constant ERR_STX_TRANSFER u101)
(define-constant CONTRACT-OWNER tx-sender)
(define-constant PRICE u100)
(define-constant ADMIN-ADDRESS 'SP26RS42R5ZH10VWWG4HFYPRJRC3JJ3FKWY4V58CW)
(define-constant WALT3R-ADDRESS 'SP3B08K0WR6H3SYW6HPERXV4TRMGJDWWBMNR51JXN)
(define-map nft-whitelist (string-ascii 10) bool)
(define-map user-whitelist principal bool)
(define-data-var last-id uint u0)
;; private functions
(define-private (mint (new-owner principal))
(let ((next-id (+ u1 (var-get last-id))))
(var-set last-id next-id)
(nft-mint? TRX-PROTO next-id new-owner)
))
;; read only functions
(define-read-only (get-last-token-id)
(ok (var-get last-id)))
(define-read-only (get-token-uri (token-id uint))
(ok (some "https://token.stacks.co/{id}.json")))
(define-read-only (get-owner (token-id uint))
(ok (nft-get-owner? TRX-PROTO token-id)))
;; public functions
(define-public (claim (token-id (string-ascii 10)))
(begin
(unwrap! (map-get? nft-whitelist token-id) (err ERR-NFT-NOT-WHITELISTED))
(unwrap! (map-get? user-whitelist tx-sender) (err ERR-USER-NOT-WHITELISTED))
(unwrap! (stx-transfer? PRICE tx-sender WALT3R-ADDRESS) (err ERR_STX_TRANSFER))
(map-delete user-whitelist tx-sender)
(mint tx-sender)
)
)
(define-public (transfer (token-id uint) (sender principal) (recipient principal))
(begin
(asserts! (is-eq tx-sender sender) (err u403))
(nft-transfer? TRX-PROTO token-id sender recipient)))
(define-public (bernard-whitelist-nft (token-id (string-ascii 10)))
(begin
(asserts! (is-eq tx-sender ADMIN-ADDRESS) (err ERR-NOT-AUTHORIZED))
(map-insert nft-whitelist token-id true)
(ok true)))
(define-public (bernard-blacklist-nft (token-id (string-ascii 10)))
(begin
(asserts! (is-eq tx-sender ADMIN-ADDRESS) (err ERR-NOT-AUTHORIZED))
(map-delete nft-whitelist token-id)
(ok true)))
(define-public (bernard-whitelist-user (user-address principal))
(begin
(asserts! (is-eq tx-sender ADMIN-ADDRESS) (err ERR-NOT-AUTHORIZED))
(map-insert user-whitelist user-address true)
(ok true)))
(define-public (bernard-blacklist-user (user-address principal))
(begin
(asserts! (is-eq tx-sender ADMIN-ADDRESS) (err ERR-NOT-AUTHORIZED))
(map-delete user-whitelist user-address)
(ok true)))