tx · 2i1jQW5DFctdbaq769vF1dYZg7FgqGJV8e7yRmmpk2Zb 3PChRF3AsJG9YX78ED7wkXLwgCz6LuJBT1Z: -0.01000000 Waves 2024.02.01 14:06 [4022851] smart account 3PChRF3AsJG9YX78ED7wkXLwgCz6LuJBT1Z > SELF 0.00000000 Waves
{ "type": 13, "id": "2i1jQW5DFctdbaq769vF1dYZg7FgqGJV8e7yRmmpk2Zb", "fee": 1000000, "feeAssetId": null, "timestamp": 1706785599413, "version": 2, "chainId": 87, "sender": "3PChRF3AsJG9YX78ED7wkXLwgCz6LuJBT1Z", "senderPublicKey": "Zqe5SqPv6kYySiE63WTvm2zCtWbEqfp7H1DwyaK8H5n", "proofs": [ "5me4AZRWYjYY2gkrHx2foiPYcNvGbtK4vAD6wcTsr1dPypSGmBSfWGJ1qEnPi3uYJuxk9w6ZeuussANuvY4Tn6Vx" ], "script": "base64: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a2V5UG9vbEFkZHJlc3MAAAAAAQAAABVnZXRQb29sRmFjdG9yeUFkZHJlc3MAAAAACQEAAAALdmFsdWVPckVsc2UAAAACCQAEIgAAAAEJAQAAABVrZXlQb29sRmFjdG9yeUFkZHJlc3MAAAAABQAAAA9ERUZBVUxUX0ZBQ1RPUlkBAAAABHBvb2wAAAAACQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABCQEAAAAOZ2V0UG9vbEFkZHJlc3MAAAAAAQAAAAdmYWN0b3J5AAAAAAkBAAAAEUBleHRyTmF0aXZlKDEwNjIpAAAAAQkBAAAAFWdldFBvb2xGYWN0b3J5QWRkcmVzcwAAAAABAAAABm9yYWNsZQAAAAAJAQAAABFAZXh0ck5hdGl2ZSgxMDYyKQAAAAEJAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkABCIAAAABCQEAAAAQa2V5T3JhY2xlQWRkcmVzcwAAAAACAAAAEU9yYWNsZSBpcyBub3Qgc2V0AQAAAClrZXlNYXBwaW5nUG9vbENvbnRyYWN0QWRkcmVzc1RvUG9vbEFzc2V0cwAAAAEAAAATcG9vbENvbnRyYWN0QWRkcmVzcwkBAAAABGpvaW4AAAABCQAETAAAAAICAAAABiVzJXMlcwkABEwAAAACBQAAABNwb29sQ29udHJhY3RBZGRyZXNzCQAETAAAAAICAAAACG1hcHBpbmdzCQAETAAAAAICAAAAF3Bvb2xDb250cmFjdDJQb29sQXNzZXRzBQAAAANuaWwBAAAADWtleVBvb2xDb25maWcAAAACAAAAE2Ftb3VudEFzc2V0SW50ZXJuYWwAAAAScHJpY2VBc3NldEludGVybmFsCQEAAAAEam9pbgAAAAEJAARMAAAAAgIAAAAGJWQlZCVzCQAETAAAAAIFAAAAE2Ftb3VudEFzc2V0SW50ZXJuYWwJAARMAAAAAgUAAAAScHJpY2VBc3NldEludGVybmFsCQAETAAAAAICAAAABmNvbmZpZwUAAAADbmlsAQAAAA1nZXRQb29sQ29uZmlnAAAAAAQAAAALcG9vbEFkZHJlc3MJAQAAAA5nZXRQb29sQWRkcmVzcwAAAAAEAAAACnBvb2xBc3NldHMJAAS1AAAAAgkBAAAAEUBleHRyTmF0aXZlKDEwNTMpAAAAAgkBAAAAB2ZhY3RvcnkAAAAACQEAAAApa2V5TWFwcGluZ1Bvb2xDb250cmFjdEFkZHJlc3NUb1Bvb2xBc3NldHMAAAABBQAAAAtwb29sQWRkcmVzcwUAAAADU0VQBAAAABNhbW91bnRBc3NldEludGVybmFsCQABkQAAAAIFAAAACnBvb2xBc3NldHMAAAAAAAAAAAEEAAAAEnByaWNlQXNzZXRJbnRlcm5hbAkAAZEAAAACBQAAAApwb29sQXNzZXRzAAAAAAAAAAACCQAEtQAAAAIJAQAAABFAZXh0ck5hdGl2ZSgxMDUzKQAAAAIJAQAAAAdmYWN0b3J5AAAAAAkBAAAADWtleVBvb2xDb25maWcAAAACBQAAABNhbW91bnRBc3NldEludGVybmFsBQAAABJwcmljZUFzc2V0SW50ZXJuYWwFAAAAA1NFUAEAAAAQY2hlY2tIZWlnaHREZWx0YQAAAAEAAAALcHJpY2VIZWlnaHQEAAAADm1heEhlaWdodERlbHRhBQAAABVNQVhfUkFURV9IRUlHSFRfREVMVEEEAAAAC2N1cnJlbnREaWZmCQAAZQAAAAIIBQAAAAlsYXN0QmxvY2sAAAAGaGVpZ2h0BQAAAAtwcmljZUhlaWdodAMJAABnAAAAAgUAAAAObWF4SGVpZ2h0RGVsdGEFAAAAC2N1cnJlbnREaWZmBQAAAAR1bml0CQAAAgAAAAECAAAAEkxhcmdlIHByaWNlIGRlbHRhLgEAAAATZ2V0QW10QXNzZXRVc2RQcmljZQAAAAAEAAAABnRpY2tlcgkBAAAAEUBleHRyTmF0aXZlKDEwNTgpAAAAAQkBAAAACWtleVRpY2tlcgAAAAAEAAAAC3ByaWNlSGVpZ2h0CQEAAAARQGV4dHJOYXRpdmUoMTA1MCkAAAACCQEAAAAGb3JhY2xlAAAAAAkBAAAAGmtleU9yYWNsZVRpY2tlclByaWNlSGVpZ2h0AAAAAQUAAAAGdGlja2VyBAAAAAtjaGVja0hlaWdodAkBAAAAEGNoZWNrSGVpZ2h0RGVsdGEAAAABBQAAAAtwcmljZUhlaWdodAMJAAAAAAAAAgUAAAALY2hlY2tIZWlnaHQFAAAAC2NoZWNrSGVpZ2h0BAAAAAVwcmljZQkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgkBAAAABm9y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", "height": 4022851, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: BCHCeG5kUqPm1GRRg8KEDiUWDod8EgCanB1Xc3BrtfQs Next: HvUr2B356u5yF9UmXMi8LaSzcVFtt1MxGzpDjgGqb1px Diff:
Old | New | Differences | |
---|---|---|---|
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let DEFAULT_FACTORY = "3PCuHsTU58WKhCqotbcSwABvdPzqqVAbbTv" | |
5 | 5 | ||
6 | - | let DECIMAL_18 = | |
6 | + | let DECIMAL_18 = 1000000000000000000 | |
7 | 7 | ||
8 | 8 | let SEP = "__" | |
9 | 9 | ||
28 | 28 | case _ => | |
29 | 29 | throw("Match error") | |
30 | 30 | } | |
31 | + | ||
32 | + | ||
33 | + | func asInt (val) = match val { | |
34 | + | case valInt: Int => | |
35 | + | valInt | |
36 | + | case _ => | |
37 | + | throw("fail to cast into Int") | |
38 | + | } | |
39 | + | ||
40 | + | ||
41 | + | func asString (val) = match val { | |
42 | + | case valStr: String => | |
43 | + | valStr | |
44 | + | case _ => | |
45 | + | throw("fail to cast into String") | |
46 | + | } | |
47 | + | ||
48 | + | ||
49 | + | func toIntScale8 (val) = toInt((val / toBigInt(10000000000))) | |
31 | 50 | ||
32 | 51 | ||
33 | 52 | let IdxPoolAddress = 1 | |
91 | 110 | func keyPoolConfig (amountAssetInternal,priceAssetInternal) = join(["%d%d%s", amountAssetInternal, priceAssetInternal, "config"]) | |
92 | 111 | ||
93 | 112 | ||
94 | - | func asInt (val) = match val { | |
95 | - | case valInt: Int => | |
96 | - | valInt | |
97 | - | case _ => | |
98 | - | throw("fail to cast into Int") | |
99 | - | } | |
100 | - | ||
101 | - | ||
102 | - | func asString (val) = match val { | |
103 | - | case valStr: String => | |
104 | - | valStr | |
105 | - | case _ => | |
106 | - | throw("fail to cast into String") | |
107 | - | } | |
108 | - | ||
109 | - | ||
110 | 113 | func getPoolConfig () = { | |
111 | 114 | let poolAddress = getPoolAddress() | |
112 | 115 | let poolAssets = split(getStringValue(factory(), keyMappingPoolContractAddressToPoolAssets(poolAddress)), SEP) | |
147 | 150 | let accAmtAssetBalance = asInt(invoke(pool(), "getAccBalanceWrapperREADONLY", [amtAssetId], nil)) | |
148 | 151 | let accPriceAssetBalance = asInt(invoke(pool(), "getAccBalanceWrapperREADONLY", [priceAssetId], nil)) | |
149 | 152 | let accPriceAssetPrice = if ((poolLpBalance == 0)) | |
150 | - | then | |
151 | - | else parseBigIntValue({ | |
153 | + | then 0 | |
154 | + | else toIntScale8(parseBigIntValue({ | |
152 | 155 | let @ = ({ | |
153 | 156 | let @ = invoke(pool(), "calcPricesWrapperREADONLY", [accAmtAssetBalance, accPriceAssetBalance, poolLpBalance], nil) | |
154 | 157 | if ($isInstanceOf(@, "List[Any]")) | |
158 | 161 | if ($isInstanceOf(@, "String")) | |
159 | 162 | then @ | |
160 | 163 | else throw("Couldn't cast Any to String") | |
161 | - | }) | |
162 | - | let accAmtAssetEq = ( | |
164 | + | })) | |
165 | + | let accAmtAssetEq = (accAmtAssetBalance + fraction(accPriceAssetBalance, DECIMAL_18, accPriceAssetPrice)) | |
163 | 166 | let accAmtAssetPrice = getAmtAssetUsdPrice() | |
164 | - | let LPPrice = fraction(accAmtAssetEq, | |
165 | - | $Tuple2(nil, [ | |
167 | + | let LPPrice = fraction(accAmtAssetEq, accAmtAssetPrice, poolLpBalance) | |
168 | + | $Tuple2(nil, [poolLpBalance, accAmtAssetBalance, accPriceAssetBalance, accAmtAssetEq, accAmtAssetPrice, LPPrice]) | |
166 | 169 | } | |
167 | 170 | ||
168 | 171 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let DEFAULT_FACTORY = "3PCuHsTU58WKhCqotbcSwABvdPzqqVAbbTv" | |
5 | 5 | ||
6 | - | let DECIMAL_18 = | |
6 | + | let DECIMAL_18 = 1000000000000000000 | |
7 | 7 | ||
8 | 8 | let SEP = "__" | |
9 | 9 | ||
10 | 10 | let EMPTY = "" | |
11 | 11 | ||
12 | 12 | let PRECISION = 1000000000000 | |
13 | 13 | ||
14 | 14 | let DECIMALS = 100000000 | |
15 | 15 | ||
16 | 16 | let MAX_RATE_HEIGHT_DELTA = 5 | |
17 | 17 | ||
18 | 18 | let ORACLE_DECIMALS = 1000000 | |
19 | 19 | ||
20 | 20 | func join (ar) = makeString(ar, SEP) | |
21 | 21 | ||
22 | 22 | ||
23 | 23 | func checkAddress (_address) = match addressFromString(_address) { | |
24 | 24 | case address: Address => | |
25 | 25 | true | |
26 | 26 | case _: Unit => | |
27 | 27 | throw("Invalid address") | |
28 | 28 | case _ => | |
29 | 29 | throw("Match error") | |
30 | 30 | } | |
31 | + | ||
32 | + | ||
33 | + | func asInt (val) = match val { | |
34 | + | case valInt: Int => | |
35 | + | valInt | |
36 | + | case _ => | |
37 | + | throw("fail to cast into Int") | |
38 | + | } | |
39 | + | ||
40 | + | ||
41 | + | func asString (val) = match val { | |
42 | + | case valStr: String => | |
43 | + | valStr | |
44 | + | case _ => | |
45 | + | throw("fail to cast into String") | |
46 | + | } | |
47 | + | ||
48 | + | ||
49 | + | func toIntScale8 (val) = toInt((val / toBigInt(10000000000))) | |
31 | 50 | ||
32 | 51 | ||
33 | 52 | let IdxPoolAddress = 1 | |
34 | 53 | ||
35 | 54 | let IdxPoolStatus = 2 | |
36 | 55 | ||
37 | 56 | let IdxPoolLPAssetId = 3 | |
38 | 57 | ||
39 | 58 | let IdxAmtAssetId = 4 | |
40 | 59 | ||
41 | 60 | let IdxPriceAssetId = 5 | |
42 | 61 | ||
43 | 62 | let IdxAmtAssetDcm = 6 | |
44 | 63 | ||
45 | 64 | let IdxPriceAssetDcm = 7 | |
46 | 65 | ||
47 | 66 | let IdxIAmtAssetId = 8 | |
48 | 67 | ||
49 | 68 | let IdxIPriceAssetId = 9 | |
50 | 69 | ||
51 | 70 | let IdxLPAssetDcm = 10 | |
52 | 71 | ||
53 | 72 | let IdxPoolType = 11 | |
54 | 73 | ||
55 | 74 | func keyPoolAddress () = join(["%s", "poolAddress"]) | |
56 | 75 | ||
57 | 76 | ||
58 | 77 | func keyPoolFactoryAddress () = join(["%s", "poolFactoryAddress"]) | |
59 | 78 | ||
60 | 79 | ||
61 | 80 | func keyTicker () = join(["%s", "ticker"]) | |
62 | 81 | ||
63 | 82 | ||
64 | 83 | func keyOracleTickerPriceHeight (ticker) = join(["%s%s", "lastHeight", ticker]) | |
65 | 84 | ||
66 | 85 | ||
67 | 86 | func keyOracleAddress () = join(["%s", "oracleAddress"]) | |
68 | 87 | ||
69 | 88 | ||
70 | 89 | func keyOracleTickerPrice (ticker) = join(["%s%s", "price", ticker]) | |
71 | 90 | ||
72 | 91 | ||
73 | 92 | func getPoolAddress () = getStringValue(keyPoolAddress()) | |
74 | 93 | ||
75 | 94 | ||
76 | 95 | func getPoolFactoryAddress () = valueOrElse(getString(keyPoolFactoryAddress()), DEFAULT_FACTORY) | |
77 | 96 | ||
78 | 97 | ||
79 | 98 | func pool () = addressFromStringValue(getPoolAddress()) | |
80 | 99 | ||
81 | 100 | ||
82 | 101 | func factory () = addressFromStringValue(getPoolFactoryAddress()) | |
83 | 102 | ||
84 | 103 | ||
85 | 104 | func oracle () = addressFromStringValue(valueOrErrorMessage(getString(keyOracleAddress()), "Oracle is not set")) | |
86 | 105 | ||
87 | 106 | ||
88 | 107 | func keyMappingPoolContractAddressToPoolAssets (poolContractAddress) = join(["%s%s%s", poolContractAddress, "mappings", "poolContract2PoolAssets"]) | |
89 | 108 | ||
90 | 109 | ||
91 | 110 | func keyPoolConfig (amountAssetInternal,priceAssetInternal) = join(["%d%d%s", amountAssetInternal, priceAssetInternal, "config"]) | |
92 | 111 | ||
93 | 112 | ||
94 | - | func asInt (val) = match val { | |
95 | - | case valInt: Int => | |
96 | - | valInt | |
97 | - | case _ => | |
98 | - | throw("fail to cast into Int") | |
99 | - | } | |
100 | - | ||
101 | - | ||
102 | - | func asString (val) = match val { | |
103 | - | case valStr: String => | |
104 | - | valStr | |
105 | - | case _ => | |
106 | - | throw("fail to cast into String") | |
107 | - | } | |
108 | - | ||
109 | - | ||
110 | 113 | func getPoolConfig () = { | |
111 | 114 | let poolAddress = getPoolAddress() | |
112 | 115 | let poolAssets = split(getStringValue(factory(), keyMappingPoolContractAddressToPoolAssets(poolAddress)), SEP) | |
113 | 116 | let amountAssetInternal = poolAssets[1] | |
114 | 117 | let priceAssetInternal = poolAssets[2] | |
115 | 118 | split(getStringValue(factory(), keyPoolConfig(amountAssetInternal, priceAssetInternal)), SEP) | |
116 | 119 | } | |
117 | 120 | ||
118 | 121 | ||
119 | 122 | func checkHeightDelta (priceHeight) = { | |
120 | 123 | let maxHeightDelta = MAX_RATE_HEIGHT_DELTA | |
121 | 124 | let currentDiff = (lastBlock.height - priceHeight) | |
122 | 125 | if ((maxHeightDelta >= currentDiff)) | |
123 | 126 | then unit | |
124 | 127 | else throw("Large price delta.") | |
125 | 128 | } | |
126 | 129 | ||
127 | 130 | ||
128 | 131 | func getAmtAssetUsdPrice () = { | |
129 | 132 | let ticker = getStringValue(keyTicker()) | |
130 | 133 | let priceHeight = getIntegerValue(oracle(), keyOracleTickerPriceHeight(ticker)) | |
131 | 134 | let checkHeight = checkHeightDelta(priceHeight) | |
132 | 135 | if ((checkHeight == checkHeight)) | |
133 | 136 | then { | |
134 | 137 | let price = getIntegerValue(oracle(), keyOracleTickerPrice(ticker)) | |
135 | 138 | fraction(price, PRECISION, ORACLE_DECIMALS) | |
136 | 139 | } | |
137 | 140 | else throw("Strict value is not equal to itself.") | |
138 | 141 | } | |
139 | 142 | ||
140 | 143 | ||
141 | 144 | func getAssetUsdPrice () = { | |
142 | 145 | let cfg = getPoolConfig() | |
143 | 146 | let lpAssetId = fromBase58String(cfg[IdxPoolLPAssetId]) | |
144 | 147 | let amtAssetId = cfg[IdxAmtAssetId] | |
145 | 148 | let priceAssetId = cfg[IdxPriceAssetId] | |
146 | 149 | let poolLpBalance = value(assetInfo(lpAssetId)).quantity | |
147 | 150 | let accAmtAssetBalance = asInt(invoke(pool(), "getAccBalanceWrapperREADONLY", [amtAssetId], nil)) | |
148 | 151 | let accPriceAssetBalance = asInt(invoke(pool(), "getAccBalanceWrapperREADONLY", [priceAssetId], nil)) | |
149 | 152 | let accPriceAssetPrice = if ((poolLpBalance == 0)) | |
150 | - | then | |
151 | - | else parseBigIntValue({ | |
153 | + | then 0 | |
154 | + | else toIntScale8(parseBigIntValue({ | |
152 | 155 | let @ = ({ | |
153 | 156 | let @ = invoke(pool(), "calcPricesWrapperREADONLY", [accAmtAssetBalance, accPriceAssetBalance, poolLpBalance], nil) | |
154 | 157 | if ($isInstanceOf(@, "List[Any]")) | |
155 | 158 | then @ | |
156 | 159 | else throw("Couldn't cast Any to List[Any]") | |
157 | 160 | })[0] | |
158 | 161 | if ($isInstanceOf(@, "String")) | |
159 | 162 | then @ | |
160 | 163 | else throw("Couldn't cast Any to String") | |
161 | - | }) | |
162 | - | let accAmtAssetEq = ( | |
164 | + | })) | |
165 | + | let accAmtAssetEq = (accAmtAssetBalance + fraction(accPriceAssetBalance, DECIMAL_18, accPriceAssetPrice)) | |
163 | 166 | let accAmtAssetPrice = getAmtAssetUsdPrice() | |
164 | - | let LPPrice = fraction(accAmtAssetEq, | |
165 | - | $Tuple2(nil, [ | |
167 | + | let LPPrice = fraction(accAmtAssetEq, accAmtAssetPrice, poolLpBalance) | |
168 | + | $Tuple2(nil, [poolLpBalance, accAmtAssetBalance, accPriceAssetBalance, accAmtAssetEq, accAmtAssetPrice, LPPrice]) | |
166 | 169 | } | |
167 | 170 | ||
168 | 171 | ||
169 | 172 | @Callable(i) | |
170 | 173 | func initialize (_oracleAddress,_poolAddress,_ticker) = { | |
171 | 174 | let doChecks = [checkAddress(_oracleAddress), checkAddress(_poolAddress)] | |
172 | 175 | if ((doChecks == doChecks)) | |
173 | 176 | then [StringEntry(keyOracleAddress(), _oracleAddress), StringEntry(keyPoolAddress(), _poolAddress), StringEntry(keyTicker(), _ticker)] | |
174 | 177 | else throw("Strict value is not equal to itself.") | |
175 | 178 | } | |
176 | 179 | ||
177 | 180 | ||
178 | 181 | ||
179 | 182 | @Callable(i) | |
180 | 183 | func getCurrentUsdPrice () = $Tuple2(nil, getAssetUsdPrice()) | |
181 | 184 | ||
182 | 185 | ||
183 | 186 | @Verifier(tx) | |
184 | 187 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
185 | 188 |
github/deemru/w8io/6500d08 32.92 ms ◑