Source Code

(use-trait ft-trait 'SP3FBR2AGK5H9QBDH3EEN6DF8EK8JY7RX8QJ5SVTE.sip-010-trait-ft-standard.sip-010-trait)
(use-trait dao-token-trait .arkadiko-dao-token-trait-v1.dao-token-trait)

;; Arkadiko DAO 
;; 
;; Keep contracts used in protocol. 
;; Emergency switch to shut down protocol.


;; Errors
(define-constant ERR-NOT-AUTHORIZED u100401)

;; Contract addresses
(define-map contracts
  { name: (string-ascii 256) }
  {
    address: principal, ;; e.g. 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR
    qualified-name: principal ;; e.g. 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.freddie
  }
)
(define-map contracts-data
  { qualified-name: principal }
  {
    can-mint: bool,
    can-burn: bool
  }
)

;; Variables
(define-data-var emergency-shutdown-activated bool false)
(define-data-var dao-owner principal tx-sender)
(define-data-var payout-address principal (var-get dao-owner)) ;; to which address the foundation is paid
(define-data-var guardian principal (var-get dao-owner)) ;; guardian that can be set

(define-read-only (get-dao-owner)
  (var-get dao-owner)
)

(define-read-only (get-payout-address)
  (var-get payout-address)
)

(define-public (set-dao-owner (address principal))
  (begin
    (asserts! (is-eq tx-sender (var-get dao-owner)) (err ERR-NOT-AUTHORIZED))

    (ok (var-set dao-owner address))
  )
)

(define-public (set-payout-address (address principal))
  (begin
    (asserts! (is-eq tx-sender (var-get dao-owner)) (err ERR-NOT-AUTHORIZED))

    (ok (var-set payout-address address))
  )
)

(define-read-only (get-guardian-address)
  (var-get guardian)
)

(define-public (set-guardian-address (address principal))
  (begin
    (asserts! (is-eq tx-sender (var-get guardian)) (err ERR-NOT-AUTHORIZED))

    (ok (var-set guardian address))
  )
)

(define-public (toggle-emergency-shutdown)
  (begin
    (asserts! (is-eq tx-sender (var-get guardian)) (err ERR-NOT-AUTHORIZED))

    (ok (var-set emergency-shutdown-activated (not (var-get emergency-shutdown-activated))))
  )
)

(define-read-only (get-emergency-shutdown-activated)
  (ok (var-get emergency-shutdown-activated))
)

;; Get contract address
(define-read-only (get-contract-address-by-name (name (string-ascii 256)))
  (get address (map-get? contracts { name: name }))
)

;; Get contract qualified name
(define-read-only (get-qualified-name-by-name (name (string-ascii 256)))
  (get qualified-name (map-get? contracts { name: name }))
)

;; Check if contract can mint
(define-read-only (get-contract-can-mint-by-qualified-name (qualified-name principal))
  (default-to 
    false
    (get can-mint (map-get? contracts-data { qualified-name: qualified-name }))
  )
)

;; Check if contract can burn
(define-read-only (get-contract-can-burn-by-qualified-name (qualified-name principal))
  (default-to 
    false
    (get can-burn (map-get? contracts-data { qualified-name: qualified-name }))
  )
)

;; Governance contract can setup DAO contracts
(define-public (set-contract-address (name (string-ascii 256)) (address principal) (qualified-name principal) (can-mint bool) (can-burn bool))
  (let (
    (current-contract (map-get? contracts { name: name }))
  )
    (begin
      (asserts! (is-eq (unwrap-panic (get-qualified-name-by-name "governance")) contract-caller) (err ERR-NOT-AUTHORIZED))

      (map-set contracts { name: name } { address: address, qualified-name: qualified-name })
      (if (is-some current-contract)
        (map-set contracts-data { qualified-name: (unwrap-panic (get qualified-name current-contract)) } { can-mint: false, can-burn: false })
        false
      )
      (map-set contracts-data { qualified-name: qualified-name } { can-mint: can-mint, can-burn: can-burn })
      (ok true)
    )
  )
)

;; ---------------------------------------------------------
;; Protocol tokens
;; ---------------------------------------------------------

;; Mint protocol tokens
(define-public (mint-token (token <dao-token-trait>) (amount uint) (recipient principal))
  (begin
    (asserts! (is-eq (get-contract-can-mint-by-qualified-name contract-caller) true) (err ERR-NOT-AUTHORIZED))
    (print { type: "token", action: "minted", data: { amount: amount, recipient: recipient } })
    (contract-call? token mint-for-dao amount recipient)
  )
)

;; Burn protocol tokens
(define-public (burn-token (token <dao-token-trait>) (amount uint) (recipient principal))
  (begin
    (asserts! (is-eq (get-contract-can-burn-by-qualified-name contract-caller) true) (err ERR-NOT-AUTHORIZED))
    (print { type: "token", action: "burned", data: { amount: amount, recipient: recipient } })
    (contract-call? token burn-for-dao amount recipient)
  )
)

;; This method is called by the auction engine when more bad debt needs to be burned
;; but the vault collateral is not sufficient
;; As a result, additional DIKO will be minted to cover bad debt
(define-public (request-diko-tokens (collateral-amount uint))
  (begin
    (asserts! (is-eq (unwrap-panic (get-qualified-name-by-name "auction-engine")) contract-caller) (err ERR-NOT-AUTHORIZED))

    (contract-call? .arkadiko-token mint-for-dao collateral-amount (as-contract (unwrap-panic (get-qualified-name-by-name "sip10-reserve"))))
  )
)


;; ---------------------------------------------------------
;; Contract initialisation
;; ---------------------------------------------------------

;; Initialize the contract
(begin
  ;; Add initial contracts
  (map-set contracts
    { name: "freddie" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-freddie-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-freddie-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "auction-engine" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-auction-engine-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-auction-engine-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "oracle" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-oracle-v1-1
    }
  )
  (map-set contracts
    { name: "collateral-types" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-collateral-types-v1-1
    }
  )
  (map-set contracts
    { name: "governance" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-governance-v1-1
    }
  )
  (map-set contracts
    { name: "stake-registry" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-registry-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-registry-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "stake-pool-diko" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-diko-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-diko-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "stake-pool-diko-usda" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-diko-usda-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-diko-usda-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "stake-pool-wstx-usda" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-wstx-usda-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-wstx-usda-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "stake-pool-wstx-diko" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-wstx-diko-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stake-pool-wstx-diko-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "stacker" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stacker-v1-1
    }
  )
  (map-set contracts
    { name: "stacker-2" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stacker-2-v1-1
    }
  )
  (map-set contracts
    { name: "stacker-3" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stacker-3-v1-1
    }
  )
  (map-set contracts
    { name: "stacker-4" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stacker-4-v1-1
    }
  )

  (map-set contracts
    { name: "stacker-payer" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stacker-payer-v1-1
    }
  )

  (map-set contracts
    { name: "stx-reserve" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stx-reserve-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-stx-reserve-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "sip10-reserve" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-sip10-reserve-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-sip10-reserve-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "diko-guardian" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-diko-guardian-v1-1
    }
  )

  (map-set contracts
    { name: "diko-init" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-diko-init
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-diko-init }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "vault-rewards" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-vault-rewards-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-vault-rewards-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "swap" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-swap-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-swap-v1-1 }
    {
      can-mint: true,
      can-burn: true
    }
  )

  (map-set contracts
    { name: "liquidator" }
    {
      address: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR,
      qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-liquidator-v1-1
    }
  )
  (map-set contracts-data
    { qualified-name: 'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-liquidator-v1-1 }
    {
      can-mint: false,
      can-burn: false
    }
  )
)

Functions (16)

FunctionAccessArgs
get-dao-ownerread-only
get-payout-addressread-only
set-dao-ownerpublicaddress: principal
set-payout-addresspublicaddress: principal
get-guardian-addressread-only
set-guardian-addresspublicaddress: principal
toggle-emergency-shutdownpublic
get-emergency-shutdown-activatedread-only
get-contract-address-by-nameread-onlyname: (string-ascii 256
get-qualified-name-by-nameread-onlyname: (string-ascii 256
get-contract-can-mint-by-qualified-nameread-onlyqualified-name: principal
get-contract-can-burn-by-qualified-nameread-onlyqualified-name: principal
set-contract-addresspublicname: (string-ascii 256
mint-tokenpublictoken: <dao-token-trait>, amount: uint, recipient: principal
burn-tokenpublictoken: <dao-token-trait>, amount: uint, recipient: principal
request-diko-tokenspubliccollateral-amount: uint