Source Code

(define-data-var executed bool false)
(define-constant deployer tx-sender)

(define-constant stx-address .wstx)
(define-constant ststx-address 'SP4SZE494VC2YC5JYG7AYFQ44F5Q4PYV7DVMDPBG.ststx-token)
(define-constant ststxbtc-address 'SP4SZE494VC2YC5JYG7AYFQ44F5Q4PYV7DVMDPBG.ststxbtc-token)
(define-constant sbtc-address 'SM3VDXK3WZZSA84XXFKAFAF15NNZX32CTSG82JFQ4.sbtc-token)

(define-constant stx-oracle .stx-btc-oracle-v1-2)
(define-constant ststx-oracle .stx-btc-oracle-v1-2)
(define-constant ststxbtc-oracle .stx-btc-oracle-v1-2)
(define-constant sbtc-oracle .stx-btc-oracle-v1-2)

(define-public (run-update)
  (let (
    (reserve-data-1 (unwrap-panic (contract-call? .pool-reserve-data get-reserve-state-read stx-address)))
    (reserve-data-2 (unwrap-panic (contract-call? .pool-reserve-data get-reserve-state-read ststx-address)))
    (reserve-data-3 (unwrap-panic (contract-call? .pool-reserve-data get-reserve-state-read ststxbtc-address)))
    (reserve-data-4 (unwrap-panic (contract-call? .pool-reserve-data get-reserve-state-read sbtc-address)))
  )
    (asserts! (not (var-get executed)) (err u10))
    (asserts! (is-eq deployer tx-sender) (err u11))

    (print reserve-data-1)
    (print reserve-data-2)
    (print reserve-data-3)
    (print reserve-data-4)

    (try!
      (contract-call? .pool-borrow-v2-2 set-reserve stx-address
        (merge reserve-data-1 { oracle: stx-oracle })
      )
    )
    (try!
      (contract-call? .pool-borrow-v2-2 set-reserve ststx-address
        (merge reserve-data-2 { oracle: ststx-oracle })
      )
    )
    (try!
      (contract-call? .pool-borrow-v2-2 set-reserve ststxbtc-address
        (merge reserve-data-3 { oracle: ststxbtc-oracle })
      )
    )
    (try!
      (contract-call? .pool-borrow-v2-2 set-reserve sbtc-address
        (merge reserve-data-4 { oracle: sbtc-oracle })
      )
    )

    (var-set executed true)
    (ok true)
  )
)


(define-public (disable)
  (begin
    (asserts! (is-eq deployer tx-sender) (err u11))
    (ok (var-set executed true))
  )
)

(define-read-only (can-execute)
  (begin
    (asserts! (not (var-get executed)) (err u10))
    (ok (not (var-get executed)))
  )
)

Functions (3)

FunctionAccessArgs
run-updatepublic
disablepublic
can-executeread-only