(use-trait sft-trait .trait-semi-fungible.semi-fungible-trait)
(use-trait ft-trait .trait-sip-010.sip-010-trait)
(define-constant ERR-NOT-AUTHORIZED (err u1000))
(define-constant ONE_8 u100000000)
(define-fungible-token vault-welsh-pool)
(define-data-var contract-owner principal tx-sender)
(define-data-var token-name (string-ascii 32) "vault-welsh-pool")
(define-data-var token-symbol (string-ascii 10) "vWelshLP")
(define-data-var token-uri (optional (string-utf8 256)) (some u"https://cdn.alexlab.co/metadata/vault-welsh-pool.json"))
(define-data-var token-decimals uint u8)
(define-data-var token-id uint u3) ;; mainnet
(define-public (set-token-id (new-id uint))
(begin
(try! (check-is-owner))
(ok (var-set token-id new-id))))
(define-public (set-contract-owner (owner principal))
(begin
(try! (check-is-owner))
(ok (var-set contract-owner owner))))
(define-public (set-name (new-name (string-ascii 32)))
(begin
(try! (check-is-owner))
(ok (var-set token-name new-name))))
(define-public (set-symbol (new-symbol (string-ascii 10)))
(begin
(try! (check-is-owner))
(ok (var-set token-symbol new-symbol))
)
)
(define-public (set-decimals (new-decimals uint))
(begin
(try! (check-is-owner))
(ok (var-set token-decimals new-decimals))))
(define-public (set-token-uri (new-uri (optional (string-utf8 256))))
(begin
(try! (check-is-owner))
(ok (var-set token-uri new-uri))))
(define-public (transfer (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34))))
(transfer-fixed (decimals-to-fixed amount) sender recipient memo))
(define-public (mint (amount uint) (recipient principal))
(mint-fixed (decimals-to-fixed amount) recipient))
(define-public (burn (amount uint) (sender principal))
(burn-fixed (decimals-to-fixed amount) sender))
(define-public (transfer-fixed (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34))))
(begin
(asserts! (is-eq sender tx-sender) ERR-NOT-AUTHORIZED)
(try! (ft-transfer? vault-welsh-pool (fixed-to-decimals amount) sender recipient))
(match memo to-print (print to-print) 0x)
(ok true)))
(define-public (mint-fixed (amount uint) (recipient principal))
(begin
(asserts! (is-eq recipient tx-sender) ERR-NOT-AUTHORIZED)
(try! (contract-call? .token-amm-swap-pool transfer-fixed (var-get token-id) amount recipient (as-contract tx-sender)))
(ft-mint? vault-welsh-pool (fixed-to-decimals amount) recipient)))
(define-public (burn-fixed (amount uint) (sender principal))
(begin
(asserts! (is-eq sender tx-sender) ERR-NOT-AUTHORIZED)
(try! (ft-burn? vault-welsh-pool (fixed-to-decimals amount) sender))
(as-contract (contract-call? .token-amm-swap-pool transfer-fixed (var-get token-id) amount tx-sender sender))))
(define-read-only (get-token-id)
(var-get token-id))
(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 (var-get token-decimals)))
(define-read-only (get-balance (who principal))
(ok (ft-get-balance vault-welsh-pool who)))
(define-read-only (get-total-supply)
(ok (ft-get-supply vault-welsh-pool)))
(define-read-only (get-total-supply-fixed)
(ok (decimals-to-fixed (unwrap-panic (get-total-supply)))))
(define-read-only (get-balance-fixed (account principal))
(ok (decimals-to-fixed (unwrap-panic (get-balance account)))))
(define-read-only (get-token-uri)
(ok (var-get token-uri)))
(define-read-only (get-contract-owner)
(ok (var-get contract-owner)))
(define-private (check-is-owner)
(ok (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)))
(define-private (pow-decimals)
(pow u10 (unwrap-panic (get-decimals))))
(define-private (decimals-to-fixed (amount uint))
(/ (* amount ONE_8) (pow-decimals)))
(define-private (fixed-to-decimals (amount uint))
(/ (* amount (pow-decimals)) ONE_8))
(define-private (mul-down (a uint) (b uint))
(/ (* a b) ONE_8))
(define-private (div-down (a uint) (b uint))
(if (is-eq a u0)
u0
(/ (* a ONE_8) b)))