/
one-tx-register-v1.clar
34 lines (33 loc) · 1.22 KB
/
one-tx-register-v1.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
32
33
34
(define-constant A tx-sender)
(define-public (register (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?
'SP1Z92MPDQEWZXW36VX71Q25HKF5K2EPCJ304F275.stackswap-swap-v5k swap-x-for-y
'SP1Z92MPDQEWZXW36VX71Q25HKF5K2EPCJ304F275.wstx-token-v4a
'SP2C2YFP12AJZB4MABJBAJ55XECVS7E4PMMZ89YZR.arkadiko-token
'SP1Z92MPDQEWZXW36VX71Q25HKF5K2EPCJ304F275.liquidity-token-v5kt9nmle8c
a0 u0)))
(a1 (unwrap-panic (element-at b0 u1)))
(b1 (try! (contract-call?
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.amm-swap-pool swap-y-for-x
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.age000-governance-token
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.token-wdiko
u100000000 (* a1 u100) none)))
(a2 (get dx b1))
(b2 (try! (contract-call?
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.amm-swap-pool-v1-1 swap-y-for-x
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.token-wstx
'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.age000-governance-token
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))
)
)
))