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