tx · HnfzuHnfntP9fksk1np26Xf77C5yezs1bQAwNPQRmCwW 3PA7Ltf9QeX5H95FoGqgsPnyRNsa1Q7a8A8: -0.01000000 Waves 2022.02.11 18:40 [2984223] smart account 3PA7Ltf9QeX5H95FoGqgsPnyRNsa1Q7a8A8 > SELF 0.00000000 Waves
{ "type": 13, "id": "HnfzuHnfntP9fksk1np26Xf77C5yezs1bQAwNPQRmCwW", "fee": 1000000, "feeAssetId": null, "timestamp": 1644594060552, "version": 2, "chainId": 87, "sender": "3PA7Ltf9QeX5H95FoGqgsPnyRNsa1Q7a8A8", "senderPublicKey": "8znHEexmcGCGdFwoyxjvgTj4YUke8B5whsVWAtXrohML", "proofs": [ "5Dg5NcWomRKcnesYsiSaT6gYdDPnYyyS56AKqTJ2pBtpPbTKepKoAhxPyyReirDcj8uEyrauJWoRg1QgX6soYnVh" ], "script": "base64:AAIFAAAAAAAAABUIAhIDCgEIEgMKARgSAwoBBBIAEgAAAAARAAAAAApzaGlueXdnZ2lkAQAAACCGKLEZX4aTB7txPBRrEZbfW42EKb/sqd2HQ6Im8j0hDgAAAAAMYWRtaW5BZGRyZXNzCQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABAgAAACMzUDlvdFM1cFBCN0JDa3BWR29wdkVDZGFSQVdONGc4VjdTQgAAAAATbWF4VG9rZW5zcGVyQWRkcmVzcwAAAAkYTnKgAAAAAAAQbWluVG9rZW5zUmVzZXJ2ZQAAAAAAO5rKAAAAAAAEdXNkTgEAAAAgtiYpwwT1zlORpA5LdSQvZIxRsfrfr1QpvUjSHSqyqtEAAAAAA0VnZwEAAAAgo59/TyNyUdEs4iGSYohNDAvz6iJugdWv/AuTF85tsckAAAAACGFzc2V0SWRzCQAETAAAAAIFAAAABHVuaXQJAARMAAAAAgUAAAAEdXNkTgkABEwAAAACBQAAAANFZ2cFAAAAA25pbAAAAAANQXNzZXRzV2VpZ2h0cwkABEwAAAACAAAAAAAAAAAUCQAETAAAAAIAAAAAAAAAAA8JAARMAAAAAgAAAAAAAAAACgUAAAADbmlsAAAAAAhEZWNpbWFscwkABEwAAAACAAAAAAAAAAAICQAETAAAAAIAAAAAAAAAAAYJAARMAAAAAgAAAAAAAAAACAUAAAADbmlsAQAAAA10cnlHZXRJbnRlZ2VyAAAAAQAAAANrZXkEAAAAByRtYXRjaDAJAAQaAAAAAgUAAAAEdGhpcwUAAAADa2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAAWIFAAAAByRtYXRjaDAFAAAAAWIAAAAAAAAAAAABAAAADXRyeUdldEJvb2xlYW4AAAABAAAAA2tleQQAAAAHJG1hdGNoMAkABBsAAAACBQAAAAR0aGlzBQAAAANrZXkDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAB0Jvb2xlYW4EAAAAAWIFAAAAByRtYXRjaDAFAAAAAWIHAQAAAA5nZXRBc3NldFN0cmluZwAAAAEAAAAHYXNzZXRJZAQAAAAHJG1hdGNoMAUAAAAHYXNzZXRJZAMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAKQnl0ZVZlY3RvcgQAAAABYgUAAAAHJG1hdGNoMAkAAlgAAAABBQAAAAFiAgAAAAVXQVZFUwEAAAASY2FsY3VsYXRlVXNkblZhbHVlAAAAAgAAAAdhc3NldElkAAAABmFtb3VudAQAAAAKdXNkbldlaWdodAkAAZEAAAACBQAAAA1Bc3NldHNXZWlnaHRzCQEAAAAFdmFsdWUAAAABCQAETwAAAAIFAAAACGFzc2V0SWRzBQAAAAR1c2ROBAAAAAthc3NldFdlaWdodAkAAZEAAAACBQAAAA1Bc3NldHNXZWlnaHRzCQEAAAAFdmFsdWUAAAABCQAETwAAAAIFAAAACGFzc2V0SWRzBQAAAAdhc3NldElkBAAAAA1wdXp6bGVhZGRyZXNzCQEAAAAUYWRkcmVzc0Zyb21QdWJsaWNLZXkAAAABAQAAABoBV4LO3M3ldfCapQxtvNBliIgYnL69lTD/swQAAAALdXNkbkJhbGFuY2UJAQAAABFAZXh0ck5hdGl2ZSgxMDUwKQAAAAIFAAAADXB1enpsZWFkZHJlc3MJAAEsAAAAAgkAASwAAAACAgAAAAdnbG9iYWxfCQEAAAAOZ2V0QXNzZXRTdHJpbmcAAAABBQAAAAR1c2ROAgAAAAhfYmFsYW5jZQQAAAAIYUJhbGFuY2UJAQAAABFAZXh0ck5hdGl2ZSgxMDUwKQAAAAIFAAAADXB1enpsZWFkZHJlc3MJAAEsAAAAAgkAASwAAAACAgAAAAdnbG9iYWxfCQEAAAAOZ2V0QXNzZXRTdHJpbmcAAAABBQAAAAdhc3NldElkAgAAAAhfYmFsYW5jZQkAAGsAAAADBQAAAAZhbW91bnQJAABpAAAAAgUAAAALdXNkbkJhbGFuY2UFAAAACnVzZG5XZWlnaHQJAABpAAAAAgUAAAAIYUJhbGFuY2UFAAAAC2Fzc2V0V2VpZ2h0AQAAAA1pc0dhbWVTdGFydGVkAAAAAAkBAAAADXRyeUdldEJvb2xlYW4AAAABAgAAAAxHYW1lX1N0YXJ0ZWQBAAAADWlzV2hpdGVMaXN0ZWQAAAABAAAACmFkZHJlc3NTdHIJAQAAAA10cnlHZXRCb29sZWFuAAAAAQkAASwAAAACBQAAAAphZGRyZXNzU3RyAgAAAAxfd2hpdGVMaXN0ZWQBAAAAEWNhbGNUb2tlbnRvUmVkZWVtAAAAAgAAAARhbW50AAAA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", "height": 2984223, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: ETM2cHQhS1iN6izVZu3EsV3LKMXzWVHybWNdcCmT84j2 Next: Ed6bwYAm1roYvR8h29MBuFSrBZsuBiRrtxUt1WFJiLFm Diff:
Old | New | Differences | |
---|---|---|---|
46 | 46 | func calculateUsdnValue (assetId,amount) = { | |
47 | 47 | let usdnWeight = AssetsWeights[value(indexOf(assetIds, usdN))] | |
48 | 48 | let assetWeight = AssetsWeights[value(indexOf(assetIds, assetId))] | |
49 | - | let usdnBalance = getIntegerValue(addressFromPublicKey(base58'3PDrYPF6izza2sXWffzTPF7e2Fcir2CMpki'), (("global_" + getAssetString(usdN)) + "_balance")) | |
50 | - | let aBalance = getIntegerValue(addressFromPublicKey(base58'3PDrYPF6izza2sXWffzTPF7e2Fcir2CMpki'), (("global_" + getAssetString(assetId)) + "_balance")) | |
49 | + | let puzzleaddress = addressFromPublicKey(base58'3PDrYPF6izza2sXWffzTPF7e2Fcir2CMpki') | |
50 | + | let usdnBalance = getIntegerValue(puzzleaddress, (("global_" + getAssetString(usdN)) + "_balance")) | |
51 | + | let aBalance = getIntegerValue(puzzleaddress, (("global_" + getAssetString(assetId)) + "_balance")) | |
51 | 52 | fraction(amount, (usdnBalance / usdnWeight), (aBalance / assetWeight)) | |
52 | 53 | } | |
53 | 54 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let shinywggid = base58'A2hcw6RV23Fc8Y8FNfV35Sq5QeS9Tgp6n8hbrESiRvXX' | |
5 | 5 | ||
6 | 6 | let adminAddress = addressFromStringValue("3P9otS5pPB7BCkpVGopvECdaRAWN4g8V7SB") | |
7 | 7 | ||
8 | 8 | let maxTokensperAddress = 10000000000000 | |
9 | 9 | ||
10 | 10 | let minTokensReserve = 1000000000 | |
11 | 11 | ||
12 | 12 | let usdN = base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p' | |
13 | 13 | ||
14 | 14 | let Egg = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS' | |
15 | 15 | ||
16 | 16 | let assetIds = [unit, usdN, Egg] | |
17 | 17 | ||
18 | 18 | let AssetsWeights = [20, 15, 10] | |
19 | 19 | ||
20 | 20 | let Decimals = [8, 6, 8] | |
21 | 21 | ||
22 | 22 | func tryGetInteger (key) = match getInteger(this, key) { | |
23 | 23 | case b: Int => | |
24 | 24 | b | |
25 | 25 | case _ => | |
26 | 26 | 0 | |
27 | 27 | } | |
28 | 28 | ||
29 | 29 | ||
30 | 30 | func tryGetBoolean (key) = match getBoolean(this, key) { | |
31 | 31 | case b: Boolean => | |
32 | 32 | b | |
33 | 33 | case _ => | |
34 | 34 | false | |
35 | 35 | } | |
36 | 36 | ||
37 | 37 | ||
38 | 38 | func getAssetString (assetId) = match assetId { | |
39 | 39 | case b: ByteVector => | |
40 | 40 | toBase58String(b) | |
41 | 41 | case _ => | |
42 | 42 | "WAVES" | |
43 | 43 | } | |
44 | 44 | ||
45 | 45 | ||
46 | 46 | func calculateUsdnValue (assetId,amount) = { | |
47 | 47 | let usdnWeight = AssetsWeights[value(indexOf(assetIds, usdN))] | |
48 | 48 | let assetWeight = AssetsWeights[value(indexOf(assetIds, assetId))] | |
49 | - | let usdnBalance = getIntegerValue(addressFromPublicKey(base58'3PDrYPF6izza2sXWffzTPF7e2Fcir2CMpki'), (("global_" + getAssetString(usdN)) + "_balance")) | |
50 | - | let aBalance = getIntegerValue(addressFromPublicKey(base58'3PDrYPF6izza2sXWffzTPF7e2Fcir2CMpki'), (("global_" + getAssetString(assetId)) + "_balance")) | |
49 | + | let puzzleaddress = addressFromPublicKey(base58'3PDrYPF6izza2sXWffzTPF7e2Fcir2CMpki') | |
50 | + | let usdnBalance = getIntegerValue(puzzleaddress, (("global_" + getAssetString(usdN)) + "_balance")) | |
51 | + | let aBalance = getIntegerValue(puzzleaddress, (("global_" + getAssetString(assetId)) + "_balance")) | |
51 | 52 | fraction(amount, (usdnBalance / usdnWeight), (aBalance / assetWeight)) | |
52 | 53 | } | |
53 | 54 | ||
54 | 55 | ||
55 | 56 | func isGameStarted () = tryGetBoolean("Game_Started") | |
56 | 57 | ||
57 | 58 | ||
58 | 59 | func isWhiteListed (addressStr) = tryGetBoolean((addressStr + "_whiteListed")) | |
59 | 60 | ||
60 | 61 | ||
61 | 62 | func calcTokentoRedeem (amnt,addressStr) = { | |
62 | 63 | let startHeight = tryGetInteger("Start_Height") | |
63 | 64 | let redeemed = tryGetInteger((addressStr + "_Redeemed")) | |
64 | 65 | if ((startHeight == 0)) | |
65 | 66 | then throw("Redeem time not started") | |
66 | 67 | else { | |
67 | 68 | let blocknum = (1440 * 180) | |
68 | 69 | if ((lastBlock.height > (startHeight + blocknum))) | |
69 | 70 | then (amnt - redeemed) | |
70 | 71 | else { | |
71 | 72 | let perblock = fraction(amnt, 1, blocknum) | |
72 | 73 | (((lastBlock.height - startHeight) * perblock) - redeemed) | |
73 | 74 | } | |
74 | 75 | } | |
75 | 76 | } | |
76 | 77 | ||
77 | 78 | ||
78 | 79 | func addStringEntry (accum,nextValue) = (accum :+ BooleanEntry((nextValue + "_whiteListed"), true)) | |
79 | 80 | ||
80 | 81 | ||
81 | 82 | @Callable(i) | |
82 | 83 | func addToWhiteList (addressStr) = if ((i.caller != this)) | |
83 | 84 | then throw("you are not authorized to perform this operation") | |
84 | 85 | else [BooleanEntry((addressStr + "_whiteListed"), true)] | |
85 | 86 | ||
86 | 87 | ||
87 | 88 | ||
88 | 89 | @Callable(i) | |
89 | 90 | func addToMultipleWhiteList (addresses) = if ((i.caller != this)) | |
90 | 91 | then throw("you are not authorized to perform this operation") | |
91 | 92 | else { | |
92 | 93 | let lsize = size(addresses) | |
93 | 94 | if ((lsize > 10)) | |
94 | 95 | then throw("you can insert max 10 addresses per time") | |
95 | 96 | else ({ | |
96 | 97 | let $l = addresses | |
97 | 98 | let $s = size($l) | |
98 | 99 | let $acc0 = nil | |
99 | 100 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
100 | 101 | then $a | |
101 | 102 | else addStringEntry($a, $l[$i]) | |
102 | 103 | ||
103 | 104 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
104 | 105 | then $a | |
105 | 106 | else throw("List size exceeds 10") | |
106 | 107 | ||
107 | 108 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
108 | 109 | } :+ BooleanEntry("whitelistWritten", true)) | |
109 | 110 | } | |
110 | 111 | ||
111 | 112 | ||
112 | 113 | ||
113 | 114 | @Callable(i) | |
114 | 115 | func setStartGame (start) = if ((i.caller != this)) | |
115 | 116 | then throw("you are not authorized to perform this operation") | |
116 | 117 | else [BooleanEntry("Game_Started", start), IntegerEntry("Start_Height", lastBlock.height)] | |
117 | 118 | ||
118 | 119 | ||
119 | 120 | ||
120 | 121 | @Callable(i) | |
121 | 122 | func reserveTokens () = if (isGameStarted()) | |
122 | 123 | then throw("The pre-sale time has finished!") | |
123 | 124 | else { | |
124 | 125 | let addressStr = toString(i.caller) | |
125 | 126 | let wl = isWhiteListed(addressStr) | |
126 | 127 | if (!(wl)) | |
127 | 128 | then throw("you are not whitelisted!") | |
128 | 129 | else { | |
129 | 130 | let pmt = i.payments[0] | |
130 | 131 | if ((pmt == pmt)) | |
131 | 132 | then { | |
132 | 133 | let amountIn = value(i.payments[0].amount) | |
133 | 134 | if ((amountIn == amountIn)) | |
134 | 135 | then { | |
135 | 136 | let assetIn = pmt.assetId | |
136 | 137 | if ((assetIn == assetIn)) | |
137 | 138 | then if (!(containsElement(assetIds, assetIn))) | |
138 | 139 | then throw("ONLY USDN, WAVES and EGGS ALLOWED") | |
139 | 140 | else { | |
140 | 141 | let index = indexOf(assetIds, assetIn) | |
141 | 142 | let dec = Decimals[value(index)] | |
142 | 143 | let diff = (8 - dec) | |
143 | 144 | let conv = pow(10, 0, diff, 0, 0, FLOOR) | |
144 | 145 | let mult = calculateUsdnValue(pmt.assetId, pow(10, 0, dec, 0, 0, FLOOR)) | |
145 | 146 | let reservedAmount = (amountIn * conv) | |
146 | 147 | if ((reservedAmount == reservedAmount)) | |
147 | 148 | then { | |
148 | 149 | let convertedAmount = fraction(reservedAmount, mult, 1000000) | |
149 | 150 | if ((convertedAmount == convertedAmount)) | |
150 | 151 | then { | |
151 | 152 | let alreadyReserved = tryGetInteger((addressStr + "_Reserved")) | |
152 | 153 | if ((alreadyReserved == alreadyReserved)) | |
153 | 154 | then { | |
154 | 155 | let globalreserved = tryGetInteger("global_reserved") | |
155 | 156 | let remainingTokens = (assetBalance(this, shinywggid) - globalreserved) | |
156 | 157 | if ((minTokensReserve > convertedAmount)) | |
157 | 158 | then throw((("The minimum amount is " + toString(fraction(minTokensReserve, 1, 100000000))) + " $HEG")) | |
158 | 159 | else if ((0 >= remainingTokens)) | |
159 | 160 | then throw("Presale is out of stock!") | |
160 | 161 | else if ((convertedAmount > remainingTokens)) | |
161 | 162 | then throw((("You can reserve only" + toString(fraction(remainingTokens, 1, 100000000))) + " $HEG")) | |
162 | 163 | else { | |
163 | 164 | let reservable = (maxTokensperAddress - alreadyReserved) | |
164 | 165 | if ((convertedAmount > reservable)) | |
165 | 166 | then throw((("You can reserve max " + toString(fraction(reservable, 1, 100000000))) + " $HEG")) | |
166 | 167 | else { | |
167 | 168 | let remainingTokens2 = (remainingTokens - convertedAmount) | |
168 | 169 | [IntegerEntry("global_reserved", (globalreserved - convertedAmount)), IntegerEntry((addressStr + "_Reserved"), (convertedAmount + alreadyReserved)), ScriptTransfer(adminAddress, amountIn, pmt.assetId)] | |
169 | 170 | } | |
170 | 171 | } | |
171 | 172 | } | |
172 | 173 | else throw("Strict value is not equal to itself.") | |
173 | 174 | } | |
174 | 175 | else throw("Strict value is not equal to itself.") | |
175 | 176 | } | |
176 | 177 | else throw("Strict value is not equal to itself.") | |
177 | 178 | } | |
178 | 179 | else throw("Strict value is not equal to itself.") | |
179 | 180 | } | |
180 | 181 | else throw("Strict value is not equal to itself.") | |
181 | 182 | } | |
182 | 183 | else throw("Strict value is not equal to itself.") | |
183 | 184 | } | |
184 | 185 | } | |
185 | 186 | ||
186 | 187 | ||
187 | 188 | ||
188 | 189 | @Callable(i) | |
189 | 190 | func redeem () = if (!(isGameStarted())) | |
190 | 191 | then throw("Cannot redeem anything before the game starts!") | |
191 | 192 | else { | |
192 | 193 | let addressStr = toString(i.caller) | |
193 | 194 | let reservedAmount = tryGetInteger((addressStr + "_Reserved")) | |
194 | 195 | let redeemed = tryGetInteger((addressStr + "_Redeemed")) | |
195 | 196 | if ((reservedAmount == 0)) | |
196 | 197 | then throw("Nothing to redeem") | |
197 | 198 | else { | |
198 | 199 | let toRedeem = calcTokentoRedeem(reservedAmount, addressStr) | |
199 | 200 | let remaining = (reservedAmount - redeemed) | |
200 | 201 | if ((toRedeem == 0)) | |
201 | 202 | then throw("No SHEG to redeem, you may have redeemed all your SHEG or you have to wait at least another block") | |
202 | 203 | else if ((remaining >= toRedeem)) | |
203 | 204 | then [IntegerEntry((addressStr + "_Redeemed"), (redeemed + toRedeem)), ScriptTransfer(i.caller, toRedeem, shinywggid)] | |
204 | 205 | else throw((("you can redeem max " + toString(fraction(remaining, 1, 100000000))) + " SHEG")) | |
205 | 206 | } | |
206 | 207 | } | |
207 | 208 | ||
208 | 209 |
github/deemru/w8io/3ef1775 48.78 ms ◑