Source Code

(impl-trait 'SP2KAF9RF86PVX3NEE27DFV1CQX0T4WGR41X3S45C.ft-trait.sip-010-trait)

(define-constant ERR-NOT-AUTHORIZED u401)
(define-constant ERR-INVALID-STAKE u104)
(define-constant ERR-NO-MORE-TOKENS u400)
(define-constant CONTRACT-OWNER tx-sender)

(define-data-var approved-principals (list 1000 principal) (list ))
(define-data-var shutoff-valve bool false)

;; Define TOKEN with a maximum of 1,000,000 tokens / 1T microtokens.
(define-constant TOKEN-CAP u21000000000000)
(define-fungible-token TOKEN TOKEN-CAP)

(define-public (collect (sender principal) (amount uint))
    (let (
        (supply (unwrap-panic (get-total-supply)))
    )
        (asserts! (is-some (index-of (var-get approved-principals) contract-caller)) (err ERR-NOT-AUTHORIZED))
        (asserts! (is-eq (var-get shutoff-valve) false) (err ERR-NOT-AUTHORIZED))
        (begin
            (try! (ft-mint? TOKEN amount sender))
            (ok true)
        )
    )
)

;; Transfers tokens to a recipient
(define-public (transfer (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34))))
  (if (is-eq tx-sender sender)
    (begin
      (try! (ft-transfer? TOKEN amount sender recipient))
      (print memo)
      (ok true)
    )
    (err u4)))

(define-read-only (get-balance (owner principal))
    (ok (ft-get-balance TOKEN owner))
)

(define-read-only (get-name)
    (ok "TOKEN")
)

(define-read-only (get-symbol)
    (ok "SP")
)

(define-read-only (get-decimals)
    (ok u6)
)

(define-read-only (get-total-supply)
    (ok (ft-get-supply TOKEN))
)

(define-read-only (get-token-uri)
  (ok (some u"https://placeholder.com/")))

(define-public (burn (burn-amount uint))
    (begin
        (try! (ft-burn? TOKEN burn-amount tx-sender))
        (ok true)
    )
)

(define-public (admin-airdrop (address principal) (amount uint))
    (let (
        (supply (unwrap-panic (get-total-supply)))
    )   
        (asserts! (is-some (index-of (var-get approved-principals) contract-caller)) (err ERR-NOT-AUTHORIZED))
        (begin
            (try! (ft-mint? TOKEN amount address))
            (ok true)
        )
    )
)

(define-public (principal-add (address principal))
  (if (is-eq tx-sender CONTRACT-OWNER)
    (ok (var-set approved-principals (unwrap-panic (as-max-len? (append (var-get approved-principals) address) u1000))))
    (err ERR-NOT-AUTHORIZED)
  )
)

Functions (11)

FunctionAccessArgs
collectpublicsender: principal, amount: uint
transferpublicamount: uint, sender: principal, recipient: principal, memo: (optional (buff 34
get-balanceread-onlyowner: principal
get-nameread-only
get-symbolread-only
get-decimalsread-only
get-total-supplyread-only
get-token-uriread-only
burnpublicburn-amount: uint
admin-airdroppublicaddress: principal, amount: uint
principal-addpublicaddress: principal