;; Storage
(define-map private-presale-count principal uint)
(define-map public-sale-count principal uint)
;; Define Constants
(define-constant CONTRACT-OWNER tx-sender)
(define-constant ERR-NOT-AUTHORIZED (err u401))
(define-constant ERR-SALE-NOT-ACTIVE (err u500))
(define-constant ERR-NO-MINTPASS-REMAINING (err u501))
;; Define Variables
(define-data-var private-mintpass-sale-active bool false)
(define-data-var sale-active bool false)
(define-data-var sale-stage uint u0)
(define-data-var private-mintpasses (list 1000 principal) (list ))
(define-data-var admin principal 'SP2KAF9RF86PVX3NEE27DFV1CQX0T4WGR41X3S45C)
(define-read-only (get-private-presale-balance (account principal))
(default-to u0
(map-get? private-presale-count account)))
(define-read-only (get-public-balance (account principal))
(default-to u0
(map-get? public-sale-count account)))
(define-read-only (get-private-list)
(var-get private-mintpasses)
)
;; Claim a new NFT
(define-public (claim)
(if (var-get sale-active)
(public-mint tx-sender)
(if (var-get private-mintpass-sale-active)
(private-mintpass-mint tx-sender)
(not-live)
)
)
)
(define-public (claim-two)
(begin
(try! (claim))
(try! (claim))
(ok true)))
(define-public (claim-three)
(begin
(try! (claim))
(try! (claim))
(try! (claim))
(ok true)))
(define-public (claim-four)
(begin
(try! (claim))
(try! (claim))
(try! (claim))
(try! (claim))
(ok true)))
(define-public (claim-five)
(begin
(try! (claim))
(try! (claim))
(try! (claim))
(try! (claim))
(try! (claim))
(ok true)))
(define-public (claim-six)
(begin
(try! (claim))
(try! (claim))
(try! (claim))
(try! (claim))
(try! (claim))
(try! (claim))
(ok true)))
;; Internal - Mint NFT using Mintpass mechanism
(define-private (private-mintpass-mint (new-owner principal))
(let ((mint-count (get-private-presale-balance new-owner)))
(asserts! (var-get private-mintpass-sale-active) ERR-SALE-NOT-ACTIVE)
(asserts! (> mint-count u0) ERR-NO-MINTPASS-REMAINING)
(map-set private-presale-count
new-owner
(- mint-count u1))
(contract-call? .gadget-november mint new-owner)
)
)
;; Internal - Mint public sale NFT
(define-private (public-mint (new-owner principal))
(let ((mint-count (get-public-balance new-owner)))
(asserts! (var-get sale-active) ERR-SALE-NOT-ACTIVE)
(contract-call? .gadget-november mint new-owner)
)
)
(define-private (not-live)
(begin
(asserts! (var-get sale-active) ERR-SALE-NOT-ACTIVE)
(asserts! (var-get private-mintpass-sale-active) ERR-SALE-NOT-ACTIVE)
(ok false)
)
)
;; Set public sale flag
(define-public (flip-private-sale)
(begin
(asserts! (is-eq tx-sender CONTRACT-OWNER) ERR-NOT-AUTHORIZED)
;; Disable the Public sale
(var-set sale-active false)
(var-set private-mintpass-sale-active (not (var-get private-mintpass-sale-active)))
(ok (var-get private-mintpass-sale-active))))
;; Set public sale flag
(define-public (flip-sale)
(begin
(asserts! (is-eq tx-sender CONTRACT-OWNER) ERR-NOT-AUTHORIZED)
(var-set private-mintpass-sale-active false)
(var-set sale-active (not (var-get sale-active)))
(ok (var-get sale-active))))
(define-read-only (get-sale-status)
(list (var-get private-mintpass-sale-active) (var-get sale-active))
)
(as-contract (contract-call? .gadget-november set-mint-address))
;; update pre-sale counts
(define-public (set-private-wl (address principal) (limit uint))
(begin
(asserts! (is-eq tx-sender CONTRACT-OWNER) ERR-NOT-AUTHORIZED)
(map-set private-presale-count address limit)
(ok true)
)
)
(define-public (bulk-add-partner (addresses (list 1000 principal)) (limits (list 1000 uint)))
(begin
(asserts! (is-eq tx-sender CONTRACT-OWNER) ERR-NOT-AUTHORIZED)
(print (map set-private-wl addresses limits))
(ok true)
)
)