;; ---------------------------------------------------------
;; MEMEGOATSTX Fungible Token Contract
;; ---------------------------------------------------------
(impl-trait 'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.trait-sip-010.sip-010-trait)
(define-fungible-token memegoatstx)
(define-data-var token-uri (string-utf8 256) u"ipfs://ipfs/bafybeiha6ubrgfvmbd77j6jbmtkpxqhbosvalam2ud3zgnu4vydfw4d5be")
(define-data-var contract-owner principal tx-sender)
(define-constant contract-creator tx-sender)
(define-constant max-supply u5000000000000000) ;; max supply of 5 billion
(define-map approved-contracts principal bool)
;; errors
(define-constant ERR-NOT-AUTHORIZED (err u1000))
(define-constant ERR-MAX-SUPPLY (err u8000))
;; contract management
(define-read-only (get-contract-owner)
(ok (var-get contract-owner))
)
(define-public (set-contract-owner (owner principal))
(begin
(asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
(ok (var-set contract-owner owner))
)
)
;; @desc check-is-approved
;; @restricted Contract-Owner
;; @params sender
;; @returns (response bool)
(define-private (check-is-approved (sender principal))
(ok (asserts! (or (default-to false (map-get? approved-contracts sender)) (is-eq sender (var-get contract-owner))) ERR-NOT-AUTHORIZED))
)
(define-public (add-approved-contract (new-approved-contract principal))
(begin
(asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
(map-set approved-contracts new-approved-contract true)
(ok true)
)
)
(define-public (set-approved-contract (owner principal) (approved bool))
(begin
(asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
(ok (map-set approved-contracts owner approved))
)
)
;; ---------------------------------------------------------
;; SIP-10 Functions
;; ---------------------------------------------------------
;; @desc get-total-supply
;; @returns (response uint)
(define-read-only (get-total-supply)
(ok (ft-get-supply memegoatstx))
)
;; @desc get-name
;; @returns (response string-utf8)
(define-read-only (get-name)
(ok "memegoatstx")
)
;; @desc get-symbol
;; @returns (response string-utf8)
(define-read-only (get-symbol)
(ok "GOATSTX")
)
;; @desc get-decimals
;; @returns (response uint)
(define-read-only (get-decimals)
(ok u6)
)
;; @desc get-balance
;; @params account
;; @returns (response uint)
(define-read-only (get-balance (account principal))
(ok (ft-get-balance memegoatstx account))
)
;; @desc set-token-uri
;; @restricted Contract-Owner
;; @params value
;; @returns (response bool)
(define-public (set-token-uri (value (string-utf8 256)))
(begin
(asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
(ok (var-set token-uri value))
)
)
;; @desc get-token-uri
;; @params token-id
;; @returns (response none)
(define-read-only (get-token-uri)
(ok (some (var-get token-uri)))
)
;; @desc transfer
;; @restricted sender
;; @params token-id
;; @params amount
;; @params sender
;; @params recipient
;; @returns (response boolean)
(define-public (transfer (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34))))
(begin
(asserts! (is-eq sender tx-sender) ERR-NOT-AUTHORIZED)
(match (ft-transfer? memegoatstx amount sender recipient)
response (begin
(print memo)
(ok response)
)
error (err error)
)
)
)
;; @desc mint
;; @restricted ContractOwner/Approved Contract
;; @params token-id
;; @params amount
;; @params recipient
;; @returns (response boolean)
(define-public (mint (amount uint) (recipient principal))
(begin
(try! (check-is-approved tx-sender))
(asserts! (< (ft-get-supply memegoatstx) max-supply) ERR-MAX-SUPPLY)
(ft-mint? memegoatstx amount recipient)
)
)
;; @desc burn
;; @params token-id
;; @params amount
;; @params sender
;; @returns (response boolean)
(define-public (burn (amount uint) (sender principal))
(begin
(asserts! (is-eq sender tx-sender) ERR-NOT-AUTHORIZED)
(ft-burn? memegoatstx amount sender)
)
)
(define-constant ONE_8 u100000000)
;; @desc pow-decimals
;; @returns uint
(define-private (pow-decimals)
(pow u10 (unwrap-panic (get-decimals)))
)
;; @desc fixed-to-decimals
;; @params amount
;; @returns uint
(define-read-only (fixed-to-decimals (amount uint))
(/ (* amount (pow-decimals)) ONE_8)
)
;; @desc decimals-to-fixed
;; @params amount
;; @returns uint
(define-private (decimals-to-fixed (amount uint))
(/ (* amount ONE_8) (pow-decimals))
)
;; @desc get-total-supply-fixed
;; @params token-id
;; @returns (response uint)
(define-read-only (get-total-supply-fixed)
(ok (decimals-to-fixed (ft-get-supply memegoatstx)))
)
;; @desc get-balance-fixed
;; @params token-id
;; @params who
;; @returns (response uint)
(define-read-only (get-balance-fixed (account principal))
(ok (decimals-to-fixed (ft-get-balance memegoatstx account)))
)
;; @desc transfer-fixed
;; @params token-id
;; @params amount
;; @params sender
;; @params recipient
;; @returns (response boolean)
(define-public (transfer-fixed (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34))))
(transfer (fixed-to-decimals amount) sender recipient memo)
)
;; @desc mint-fixed
;; @params token-id
;; @params amount
;; @params recipient
;; @returns (response boolean)
(define-public (mint-fixed (amount uint) (recipient principal))
(mint (fixed-to-decimals amount) recipient)
)
;; @desc burn-fixed
;; @params token-id
;; @params amount
;; @params sender
;; @returns (response boolean)
(define-public (burn-fixed (amount uint) (sender principal))
(burn (fixed-to-decimals amount) sender)
)
;; ---------------------------------------------------------
;; Mint Supply 5B
;; ---------------------------------------------------------
(begin
(try! (ft-mint? memegoatstx max-supply contract-creator))
)