/
auto-alex-v2.clar
31 lines (30 loc) · 1.17 KB
/
auto-alex-v2.clar
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
(define-constant A tx-sender)
(define-public (add-to-position (a0 uint))
(let ((sender tx-sender))
(asserts! (is-eq tx-sender A) (err u0))
(try! (stx-transfer? a0 sender (as-contract tx-sender)))
(as-contract
(let (
(b0 (try! (contract-call?
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.amm-swap-pool-v1-1 swap-x-for-y
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.token-wstx
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.token-waeusdc
u100000000 (* a0 u100) none)))
(a1 (/ (get dy b0) u100))
(a2 (unwrap-panic (contract-call?
'SPQC38PW542EQJ5M11CR25P7BS1CA6QT4TBXGB3M.stableswap-aeusdc-susdt-v-1-2 swap-x-for-y
'SP3Y2ZSH8P7D50B0VBTSX11S7XSG24M1VB9YFQA4K.token-aeusdc
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.token-susdt
'SPQC38PW542EQJ5M11CR25P7BS1CA6QT4TBXGB3M.aeusdc-susdt-lp-token-v-1-2
a1 u0)))
(b2 (try! (contract-call?
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.amm-swap-pool-v1-1 swap-y-for-x
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.token-wstx
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.token-susdt
u100000000 a2 none)))
(a3 (/ (get dx b2) u100))
)
(asserts! (> a3 a0) (err a3))
(try! (stx-transfer? a3 tx-sender sender))
(ok (list a0 a1 a2 a3))
))))