From f2ff7cae6516baa3a44989dfd6b6216f5e71bdd5 Mon Sep 17 00:00:00 2001 From: fiftyeightandeight Date: Tue, 30 Apr 2024 17:18:42 +0800 Subject: [PATCH] token-ssl-memegoatstx-E0G14 (#800) * token-ssl-parker-QW155 * token-ssl-memegoatstx-E0G14 * conflict fixed --- clarity/Clarinet.toml | 8 + .../token-ssl-memegoatstx-E0G14.clar | 213 ++++++++++++++++++ 2 files changed, 221 insertions(+) create mode 100644 clarity/contracts/wrapped-token/token-ssl-memegoatstx-E0G14.clar diff --git a/clarity/Clarinet.toml b/clarity/Clarinet.toml index 553147dd..b90f1a56 100644 --- a/clarity/Clarinet.toml +++ b/clarity/Clarinet.toml @@ -78,6 +78,8 @@ contract_id = "SP351ZJK9F5AWZJEEZGZ7NZKSRKA65EWFRR48V9KS.ALL" # contract_id = "SP3R4MHK99JAAM0N3T0CBZRZVSVQFG1N75DQ08JSD.nakamoto" [[project.requirements]] contract_id = "SPTJG5KG69N7GEDB2WKMN898Q934ZB2J2NTQW155.Parker-Muneebs-Cat" +[[project.requirements]] +contract_id = "SP2F4QC563WN0A0949WPH5W1YXVC4M1R46QKE0G14.memegoatstx" [repl] costs_version = 2 @@ -1678,4 +1680,10 @@ epoch = 2.4 path = "contracts/wrapped-token/token-ssl-parker-QW155.clar" depends_on = [ "trait-ownable", "trait-sip-010" ] clarity_version = 2 +epoch = 2.4 + +[contracts.token-ssl-memegoatstx-E0G14] +path = "contracts/wrapped-token/token-ssl-memegoatstx-E0G14.clar" +depends_on = [ "trait-ownable", "trait-sip-010" ] +clarity_version = 2 epoch = 2.4 \ No newline at end of file diff --git a/clarity/contracts/wrapped-token/token-ssl-memegoatstx-E0G14.clar b/clarity/contracts/wrapped-token/token-ssl-memegoatstx-E0G14.clar new file mode 100644 index 00000000..474b7fec --- /dev/null +++ b/clarity/contracts/wrapped-token/token-ssl-memegoatstx-E0G14.clar @@ -0,0 +1,213 @@ +(impl-trait .trait-ownable.ownable-trait) +(impl-trait .trait-sip-010.sip-010-trait) + +(define-fungible-token memegoatstx-E0G14) + +(define-data-var token-name (string-ascii 32) "memegoatstx-E0G14 (SSL)") +(define-data-var token-symbol (string-ascii 10) "goatstx") +(define-data-var token-uri (optional (string-utf8 256)) (some u"https://cdn.alexlab.co/metadata/token-ssl-memegoatstx-E0G14.json")) + +(define-data-var token-decimals uint u8) + +(define-data-var contract-owner principal tx-sender) + +;; errors +(define-constant ERR-NOT-AUTHORIZED (err u1000)) +(define-constant ERR-MINT-FAILED (err u6002)) +(define-constant ERR-BURN-FAILED (err u6003)) +(define-constant ERR-TRANSFER-FAILED (err u3000)) +(define-constant ERR-NOT-SUPPORTED (err u6004)) + +(define-read-only (get-contract-owner) + (ok (var-get contract-owner)) +) + +(define-public (set-contract-owner (owner principal)) + (begin + (try! (check-is-owner)) + (ok (var-set contract-owner owner)) + ) +) + +(define-private (check-is-owner) + (ok (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)) +) + +(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)) + ) +) + +;; --------------------------------------------------------- +;; SIP-10 Functions +;; --------------------------------------------------------- + +;; @desc get-total-supply +;; @returns (response uint) +(define-read-only (get-total-supply) + ;; least authority Issue D + ERR-NOT-SUPPORTED +) + +;; @desc get-name +;; @returns (response string-utf8) +(define-read-only (get-name) + (ok (var-get token-name)) +) + +;; @desc get-symbol +;; @returns (response string-utf8) +(define-read-only (get-symbol) + (ok (var-get token-symbol)) +) + +;; @desc get-decimals +;; @returns (response uint) +(define-read-only (get-decimals) + (ok (var-get token-decimals)) +) + +(define-private (get-base-decimals) + (contract-call? 'SP2F4QC563WN0A0949WPH5W1YXVC4M1R46QKE0G14.memegoatstx get-decimals)) + +;; @desc get-balance +;; @params account +;; @returns (response uint) +(define-read-only (get-balance (account principal)) + (ok (/ (* (unwrap-panic (contract-call? 'SP2F4QC563WN0A0949WPH5W1YXVC4M1R46QKE0G14.memegoatstx get-balance account)) (pow-decimals)) (pow u10 (unwrap-panic (get-base-decimals))))) +) + +;; @desc get-token-uri +;; @returns (response some string-utf-8) +(define-read-only (get-token-uri) + (ok (var-get token-uri)) +) + +;; @desc transfer +;; @restricted sender; tx-sender should be sender +;; @params amount +;; @params sender +;; @params recipient +;; @params memo; expiry +;; @returns (response bool uint)/ error +(define-public (transfer (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34)))) + (begin + (asserts! (is-eq sender tx-sender) ERR-NOT-AUTHORIZED) + (contract-call? 'SP2F4QC563WN0A0949WPH5W1YXVC4M1R46QKE0G14.memegoatstx transfer (/ (* amount (pow u10 (unwrap-panic (get-base-decimals)))) (pow-decimals)) sender recipient memo) + ) +) + +(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) + ;; least authority Issue D + ERR-NOT-SUPPORTED +) + +;; @desc get-balance-fixed +;; @params token-id +;; @params who +;; @returns (response uint) +(define-read-only (get-balance-fixed (account principal)) + (ok (decimals-to-fixed (unwrap-panic (get-balance account)))) +) + +;; @desc transfer-fixed +;; @params token-id +;; @params amount +;; @params sender +;; @params recipient +;; @returns (response bool) +(define-public (transfer-fixed (amount uint) (sender principal) (recipient principal) (memo (optional (buff 34)))) + (transfer (fixed-to-decimals amount) sender recipient memo) +) + +(define-public (mint (amount uint) (recipient principal)) + ERR-MINT-FAILED +) + +(define-public (burn (amount uint) (sender principal)) + ERR-BURN-FAILED +) + +(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 bool) +(define-public (burn-fixed (amount uint) (sender principal)) + (burn (fixed-to-decimals amount) sender) +) + +;; @desc check-err +;; @params result +;; @params prior +;; @returns (response bool uint) +(define-private (check-err (result (response bool uint)) (prior (response bool uint))) + (match prior + ok-value result + err-value (err err-value) + ) +) + +(define-private (transfer-from-tuple (recipient { to: principal, amount: uint })) + (ok (unwrap! (transfer-fixed (get amount recipient) tx-sender (get to recipient) none) ERR-TRANSFER-FAILED)) +) + +(define-public (send-many (recipients (list 200 { to: principal, amount: uint}))) + (fold check-err (map transfer-from-tuple recipients) (ok true)) +) + +;; contract initialisation +(contract-call? .alex-vault-v1-1 set-approved-token .token-ssl-memegoatstx-E0G14 true) +(set-contract-owner .executor-dao)