amm-vault-v2-01.clar 5.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. (use-trait ft-trait .trait-sip-010.sip-010-trait)
  2. (use-trait sft-trait .trait-semi-fungible.semi-fungible-trait)
  3. (use-trait flash-loan-trait .trait-flash-loan-user.flash-loan-user-trait)
  4. (define-constant ONE_8 u100000000) ;; 8 decimal places
  5. (define-constant ERR-NOT-AUTHORIZED (err u1000))
  6. (define-constant ERR-PAUSED (err u1001))
  7. (define-constant ERR-INVALID-BALANCE (err u1002))
  8. (define-constant ERR-INVALID-TOKEN (err u2026))
  9. (define-constant ERR-AMOUNT-EXCEED-RESERVE (err u2024))
  10. (define-map approved-tokens principal bool)
  11. (define-map approved-flash-loan-users principal bool)
  12. (define-map reserve principal uint)
  13. (define-data-var flash-loan-fee-rate uint u0)
  14. (define-data-var flash-loan-enabled bool false)
  15. (define-data-var paused bool false)
  16. (define-read-only (is-dao-or-extension)
  17. (ok (asserts! (or (is-eq tx-sender .executor-dao) (contract-call? .executor-dao is-extension contract-caller)) ERR-NOT-AUTHORIZED)))
  18. (define-read-only (get-flash-loan-enabled)
  19. (var-get flash-loan-enabled))
  20. (define-read-only (is-paused)
  21. (var-get paused))
  22. (define-read-only (get-flash-loan-fee-rate)
  23. (var-get flash-loan-fee-rate))
  24. (define-read-only (get-reserve (token-trait principal))
  25. (default-to u0 (map-get? reserve token-trait)))
  26. (define-public (set-flash-loan-enabled (enabled bool))
  27. (begin
  28. (try! (is-dao-or-extension))
  29. (ok (var-set flash-loan-enabled enabled))))
  30. (define-public (pause (new-paused bool))
  31. (begin
  32. (try! (is-dao-or-extension))
  33. (ok (var-set paused new-paused))))
  34. (define-public (set-approved-flash-loan-user (flash-loan-user-trait principal) (approved bool))
  35. (begin
  36. (try! (is-dao-or-extension))
  37. (ok (map-set approved-flash-loan-users flash-loan-user-trait approved))))
  38. (define-public (set-approved-token (token-trait principal) (approved bool))
  39. (begin
  40. (try! (is-dao-or-extension))
  41. (ok (map-set approved-tokens token-trait approved))))
  42. (define-public (set-flash-loan-fee-rate (fee uint))
  43. (begin
  44. (try! (is-dao-or-extension))
  45. (ok (var-set flash-loan-fee-rate fee))))
  46. (define-public (transfer-ft (token-trait <ft-trait>) (amount uint) (recipient principal))
  47. (begin
  48. (asserts! (not (is-paused)) ERR-PAUSED)
  49. (asserts! (and (is-ok (is-dao-or-extension)) (is-ok (check-is-approved-token (contract-of token-trait)))) ERR-NOT-AUTHORIZED)
  50. (as-contract (contract-call? token-trait transfer-fixed amount tx-sender recipient none))))
  51. (define-public (transfer-ft-two (token-x-trait <ft-trait>) (dx uint) (token-y-trait <ft-trait>) (dy uint) (recipient principal))
  52. (begin
  53. (try! (transfer-ft token-x-trait dx recipient))
  54. (transfer-ft token-y-trait dy recipient)))
  55. (define-public (transfer-sft (token-trait <sft-trait>) (token-id uint) (amount uint) (recipient principal))
  56. (begin
  57. (asserts! (not (is-paused)) ERR-PAUSED)
  58. (asserts! (and (is-ok (is-dao-or-extension)) (is-ok (check-is-approved-token (contract-of token-trait)))) ERR-NOT-AUTHORIZED)
  59. (as-contract (contract-call? token-trait transfer-fixed token-id amount tx-sender recipient))))
  60. (define-public (flash-loan (flash-loan-user-trait <flash-loan-trait>) (token-trait <ft-trait>) (amount uint) (memo (optional (buff 16))))
  61. (let (
  62. (pre-bal (unwrap-panic (contract-call? token-trait get-balance-fixed (as-contract tx-sender))))
  63. (fee-with-principal (+ ONE_8 (var-get flash-loan-fee-rate)))
  64. (amount-with-fee (mul-up amount fee-with-principal))
  65. (recipient tx-sender))
  66. (asserts! (not (is-paused)) ERR-PAUSED)
  67. (asserts! (and (is-ok (check-is-approved-flash-loan-user (contract-of flash-loan-user-trait))) (is-ok (check-is-approved-token (contract-of token-trait)))) ERR-NOT-AUTHORIZED)
  68. ;; make sure current balance > loan amount
  69. (asserts! (> pre-bal amount) ERR-INVALID-BALANCE)
  70. ;; transfer loan to flash-loan-user
  71. (as-contract (try! (contract-call? token-trait transfer-fixed amount tx-sender recipient none)))
  72. ;; flash-loan-user executes with loan received
  73. (try! (contract-call? flash-loan-user-trait execute token-trait amount memo))
  74. ;; return the loan + fee
  75. (try! (contract-call? token-trait transfer-fixed amount-with-fee recipient (as-contract tx-sender) none))
  76. (ok amount-with-fee)))
  77. (define-public (add-to-reserve (token-trait principal) (amount uint))
  78. (begin
  79. (asserts! (not (is-paused)) ERR-PAUSED)
  80. (try! (is-dao-or-extension))
  81. (ok (map-set reserve token-trait (+ amount (get-reserve token-trait))))))
  82. (define-public (remove-from-reserve (token-trait principal) (amount uint))
  83. (begin
  84. (asserts! (not (is-paused)) ERR-PAUSED)
  85. (try! (is-dao-or-extension))
  86. (asserts! (<= amount (get-reserve token-trait)) ERR-AMOUNT-EXCEED-RESERVE)
  87. (ok (map-set reserve token-trait (- (get-reserve token-trait) amount)))))
  88. (define-private (check-is-approved-flash-loan-user (flash-loan-user-trait principal))
  89. (ok (asserts! (default-to false (map-get? approved-flash-loan-users flash-loan-user-trait)) ERR-NOT-AUTHORIZED)))
  90. (define-private (check-is-approved-token (flash-loan-token principal))
  91. (ok (asserts! (default-to false (map-get? approved-tokens flash-loan-token)) ERR-NOT-AUTHORIZED)))
  92. (define-private (mul-down (a uint) (b uint))
  93. (/ (* a b) ONE_8))
  94. (define-private (mul-up (a uint) (b uint))
  95. (let (
  96. (product (* a b)))
  97. (if (is-eq product u0) u0 (+ u1 (/ (- product u1) ONE_8)))))