tx · 7VZfmoJ2WTcT6gHPVvmWzhxoULJJfjb1oprvZhjLWAQY 3PKwLVb8jYk58oYbfXxs2dUjD3YEKeqGWrX: -0.01400000 Waves 2021.12.14 21:34 [2899279] smart account 3PKwLVb8jYk58oYbfXxs2dUjD3YEKeqGWrX > SELF 0.00000000 Waves
{ "type": 13, "id": "7VZfmoJ2WTcT6gHPVvmWzhxoULJJfjb1oprvZhjLWAQY", "fee": 1400000, "feeAssetId": null, "timestamp": 1639506901287, "version": 2, "chainId": 87, "sender": "3PKwLVb8jYk58oYbfXxs2dUjD3YEKeqGWrX", "senderPublicKey": "27DK15MykfnsVojpifD1gbr8kRr8rpY5mw6EH4zL8R25", "proofs": [ "4cDgf7jcJoCY3XixZ8cRGJhqCDHU2nBgBF51SVHxxpRBGgKSJ3JaorXFWFdS82xFuQeoyXrbx7ueCo92VjRMSdrv" ], "script": "base64:AAIFAAAAAAAABqUIAhIECgIICBIGCgQICAEBEgMKAQgSABoaCgFBEhVnZXRDdXJyZW50TGV2ZWxCaWdJbnQaDwoBQhIKa0R1Y2tMZXZlbBoGCgFDEgFzGgwKAUQSByRtYXRjaDEaEgoBRRINZ2V0Q3VycmVudExhcBoYCgFGEhNnZXRMYXN0RmVkVGltZXN0YW1wGhUKAUcSEGxhc3RGZWRUaW1lc3RhbXAaHgoBSBIZY2FsY3VsYXRlTmV3RHVja2xpbmdMZXZlbBoSCgFJEg1wYXltZW50QW1vdW50Gg4KAUoSCWN1cnJlbnRUcxocCgFLEhdsYXN0RmVkVGltZXN0YW1wQ2hlY2tlZBoMCgFMEgdmZWREaWZmGgwKAU0SB3BlbmFsdHkaCwoBThIGZ3Jvd3RoGhEKAU8SDGN1cnJlbnRMZXZlbBoNCgFQEghuZXdMZXZlbBoLCgFREgZyZXN1bHQaFAoBUhIPZ2V0QmFja2VuZFByb29mGhIKAVMSDW1heEZlZWRBbW91bnQaDgoBVBIJdXNlck5vbmNlGgYKAVUSAWkaDAoBVhIHdHhJZFN0choKCgFXEgVhc3NldBoMCgFYEgdhc3NldElkGhUKAVkSEGJhY2tlbmRTaWduYXR1cmUaEgoBWhINYWRkcmVzc1N0cmluZxoVCgFhEhBpbmN1YmF0b3JBZGRyZXNzGgsKAmFBEgUkYWNjMBoLCgJhQhIFJGYwXzEaCAoCYUMSAiRhGggKAmFEEgIkaRoLCgJhRRIFJGYwXzIaCgoCYUYSBHR4SWQaGgoCYUcSFGxhc3RJc3N1ZWREdWNrbGluZ1RzGhEKAmFIEgtmaXZlTWluSW5NcxoJCgJhSRIDcG10GgoKAmFKEgRjYWxsGhQKAmFLEg5rRHVja2xpbmdHcm93bhoICgJhTBICdHgaDAoCYU0SBnZlcmlmeRoSCgJhYRIMYmFja2VuZFByb29mGhMKAmFiEg1rQWRkcmVzc05vbmNlGhIKAmFjEgxjdXJyZW50Tm9uY2UaFAoCYWQSDnJlYWxEdWNrbGluZ0lkGhUKAmFlEg9kdWNrbGluZ0Fzc2V0SWQaCAoCYWYSAmlkGgcKAmFnEgF2GhUKAmFoEg9kdWNrbGluZ0lkQ2hlY2saFgoCYWkSEGR1Y2tsaW5nSWRTdHJpbmcaGAoCYWoSEmtEdWNrbGluZ0xhc3RGZWRUcxoPCgJhaxIJbGFzdEZlZFRzGhQKAmFsEg5jdXJyZW50UGF5bWVudBoPCgJhbRIJa05ld0xldmVsGhAKAmFuEgprVG90YWxGZWVkGg8KAmFvEgl0b3RhbEZlZWQaEgoCYXASDGtGZWVkVHhTdGF0cxoaCgJhcRIUa0FkZHJlc3NGZWRUaW1lc3RhbXAaHgoCYXISGGtEdWNrbGluZ0ZlZExhcFRpbWVzdGFtcBoWCgJhcxIQY2FsY3VsYXRlUmVzdWx0cxoRCgJhdBILZHVja2xpbmdJZHMaFQoCYXUSD2R1Y2tsaW5nSWRzTGlzdBoOCgJhdhIIaGFuZGxlSWQaCQoCYXcSA2FjYxoTCgJheBINc3RhcnRpbmdMZXZlbBoICgJheRICJGwaCAoCYXoSAiRzGhIKAWISDWJhY2tlbmRQdWJLZXkaEwoBYxIOU1RBUlRUSU1FU1RBTVAaDgoBZBIJTEFQTEVOR1RIGg8KAWUSCkVHR0FTU0VUSUQaEgoBZhINRFVDS0xJTkdQUklDRRobCgFnEhZwZXJjZW50R3Jvd3RoUHJlY2lzaW9uGhoKAWgSFWV4aXN0aW5nRHVja1ByZWNpc2lvbhobCgFpEhZLR2xvYmFsSXNzdWVkVGltZXN0YW1wGgwKAWoSB01TSU5EQVkaEQoBaxIMa2V5VG90YWxGZWVkGg8KAWwSCmR1Y2tsaW5nSWQaHwoBbRIaa2V5RHVja2xpbmdGZWRMYXBUaW1lc3RhbXAaCAoBbhIDbGFwGhsKAW8SFmtleUFkZHJlc3NGZWRUaW1lc3RhbXAaDAoBcBIHYWRkcmVzcxoUCgFxEg9rZXlBZGRyZXNzTm9uY2UaIAoBchIba2V5RHVja2xpbmdGZWRMYXN0VGltZXN0YW1wGhUKAXMSEGtleUR1Y2tsaW5nTGV2ZWwaFQoBdBIQa2V5RHVja2xpbmdHcm93bhoSCgF1Eg10cnlHZXRJbnRlZ2VyGggKAXYSA2tleRoICgF3EgN2YWwaDAoBeBIHJG1hdGNoMBoGCgF5EgFiGgwKAXoSB2dldEJvb2wAAAAYAAAAAAFhAQAAABoBVzG/mmi5MDJ8KLMUgT61fi6VglLk6UbbgAAAAAABYgEAAAAgoDCy4rCf80EEjcXf21TkTT+MhYwNT/IrVrGQdfl53jUAAAAA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", "height": 2899279, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6u5GXvZphMoap8Xa9ts3ceiQ889CFN6sDkmbsM2icWSD Next: Mt7bJpX2aD7rFcPYaJfxSjgwvSobPnqfmricEE7UL2p Diff:
Old | New | Differences | |
---|---|---|---|
232 | 232 | if ((pmt.issuer != this)) | |
233 | 233 | then throw("Can use only ducklings from this dApp") | |
234 | 234 | else { | |
235 | - | let call = invoke(Address(incubatorAddress), " | |
235 | + | let call = invoke(Address(incubatorAddress), "startDuckHatching", nil, nil) | |
236 | 236 | if ((call == call)) | |
237 | 237 | then { | |
238 | 238 | let kDucklingGrown = keyDucklingGrown(toBase58String(pmt.id)) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let incubatorAddress = base58'3P6TwNU39Ykkbeqhn5TE4a2736xsA1vXemM' | |
5 | 5 | ||
6 | 6 | let backendPubKey = base58'BnKJTqkWD69SotKhJXdKu76NRtkdQJEpThqGGeFwF9EL' | |
7 | 7 | ||
8 | 8 | let STARTTIMESTAMP = 1632474000000 | |
9 | 9 | ||
10 | 10 | let LAPLENGTH = 21600000 | |
11 | 11 | ||
12 | 12 | let EGGASSETID = base58'3v7zGkeHS6KrsvmTRzEzvCxm5cdzkCtM7z5cM6efcjCB' | |
13 | 13 | ||
14 | 14 | let DUCKLINGPRICE = 80000000 | |
15 | 15 | ||
16 | 16 | let percentGrowthPrecision = 10000000000000000 | |
17 | 17 | ||
18 | 18 | let existingDuckPrecision = 100000000000000 | |
19 | 19 | ||
20 | 20 | let KGlobalIssuedTimestamp = "global_issued_timestamp" | |
21 | 21 | ||
22 | 22 | let MSINDAY = 86400000 | |
23 | 23 | ||
24 | 24 | func keyTotalFeed (ducklingId) = (("duckling_" + ducklingId) + "_feed") | |
25 | 25 | ||
26 | 26 | ||
27 | 27 | func keyDucklingFedLapTimestamp (ducklingId,lap) = (((("duckling_" + ducklingId) + "_lap_") + toString(lap)) + "_fedTs") | |
28 | 28 | ||
29 | 29 | ||
30 | 30 | func keyAddressFedTimestamp (address,lap) = (((("address_" + address) + "_lap_") + toString(lap)) + "_fedTs") | |
31 | 31 | ||
32 | 32 | ||
33 | 33 | func keyAddressNonce (address) = (("address_" + address) + "_nonce") | |
34 | 34 | ||
35 | 35 | ||
36 | 36 | func keyDucklingFedLastTimestamp (ducklingId) = (("duckling_" + ducklingId) + "_fedLastTs") | |
37 | 37 | ||
38 | 38 | ||
39 | 39 | func keyDucklingLevel (ducklingId) = (("duckling_" + ducklingId) + "_level") | |
40 | 40 | ||
41 | 41 | ||
42 | 42 | func keyDucklingGrown (ducklingId) = (("duckling_" + ducklingId) + "_grown") | |
43 | 43 | ||
44 | 44 | ||
45 | 45 | func tryGetInteger (key) = { | |
46 | 46 | let val = match getInteger(this, key) { | |
47 | 47 | case b: Int => | |
48 | 48 | b | |
49 | 49 | case _ => | |
50 | 50 | 0 | |
51 | 51 | } | |
52 | 52 | val | |
53 | 53 | } | |
54 | 54 | ||
55 | 55 | ||
56 | 56 | func getBool (key) = match getBoolean(this, key) { | |
57 | 57 | case b: Boolean => | |
58 | 58 | b | |
59 | 59 | case _ => | |
60 | 60 | false | |
61 | 61 | } | |
62 | 62 | ||
63 | 63 | ||
64 | 64 | func getCurrentLevelBigInt (ducklingId) = { | |
65 | 65 | let kDuckLevel = keyDucklingLevel(ducklingId) | |
66 | 66 | match getString(kDuckLevel) { | |
67 | 67 | case s: String => | |
68 | 68 | parseBigIntValue(s) | |
69 | 69 | case _ => | |
70 | 70 | match getBoolean((("duckling_" + ducklingId) + "_issuedByFeedCall")) { | |
71 | 71 | case b: Boolean => | |
72 | 72 | toBigInt(0) | |
73 | 73 | case _ => | |
74 | 74 | toBigInt((20 * existingDuckPrecision)) | |
75 | 75 | } | |
76 | 76 | } | |
77 | 77 | } | |
78 | 78 | ||
79 | 79 | ||
80 | 80 | func getCurrentLap () = (((lastBlock.timestamp - STARTTIMESTAMP) / LAPLENGTH) + 1) | |
81 | 81 | ||
82 | 82 | ||
83 | 83 | func getLastFedTimestamp (ducklingId) = { | |
84 | 84 | let lastFedTimestamp = tryGetInteger(keyDucklingFedLastTimestamp(ducklingId)) | |
85 | 85 | if ((lastFedTimestamp > 0)) | |
86 | 86 | then lastFedTimestamp | |
87 | 87 | else lastBlock.timestamp | |
88 | 88 | } | |
89 | 89 | ||
90 | 90 | ||
91 | 91 | func calculateNewDucklingLevel (ducklingId,paymentAmount) = { | |
92 | 92 | let currentTs = lastBlock.timestamp | |
93 | 93 | let lastFedTimestampChecked = getLastFedTimestamp(ducklingId) | |
94 | 94 | let fedDiff = (currentTs - lastFedTimestampChecked) | |
95 | 95 | let penalty = if (if ((fedDiff == 0)) | |
96 | 96 | then true | |
97 | 97 | else ((MSINDAY * 2) >= fedDiff)) | |
98 | 98 | then toBigInt(0) | |
99 | 99 | else (toBigInt((fedDiff / MSINDAY)) * toBigInt((existingDuckPrecision / 10))) | |
100 | 100 | let growth = fraction(toBigInt(paymentAmount), toBigInt(percentGrowthPrecision), toBigInt(DUCKLINGPRICE)) | |
101 | 101 | let currentLevel = getCurrentLevelBigInt(ducklingId) | |
102 | 102 | let newLevel = ((currentLevel - penalty) + growth) | |
103 | 103 | let result = if ((toBigInt(0) > newLevel)) | |
104 | 104 | then toString(growth) | |
105 | 105 | else toString(newLevel) | |
106 | 106 | $Tuple2(result, [("currentLevel=" + toString(currentLevel)), ("newLevel=" + toString(newLevel)), ("growth=" + toString(growth)), ("penalty=" + toString(penalty)), ("lastFedTs=" + toString(lastFedTimestampChecked)), ("fedDiff=" + toString(fedDiff))]) | |
107 | 107 | } | |
108 | 108 | ||
109 | 109 | ||
110 | 110 | func getBackendProof (maxFeedAmount,userNonce,address) = makeString([toString(maxFeedAmount), toString(userNonce), address], ";") | |
111 | 111 | ||
112 | 112 | ||
113 | 113 | @Callable(i) | |
114 | 114 | func issueFreeDuckling (address,txIdStr) = { | |
115 | 115 | let asset = Issue("BABY-11111111-GZ", "", 1, 0, false, unit, height) | |
116 | 116 | let assetId = calculateAssetId(asset) | |
117 | 117 | $Tuple2([StringEntry((((address + "_") + txIdStr) + "_di"), toBase58String(assetId)), IntegerEntry("stats_amount", (tryGetInteger("stats_amount") + 1)), BooleanEntry((("duckling_" + toBase58String(assetId)) + "_issuedByFeedCall"), (i.caller == this)), asset, ScriptTransfer(value(addressFromString(address)), 1, assetId)], toBase58String(assetId)) | |
118 | 118 | } | |
119 | 119 | ||
120 | 120 | ||
121 | 121 | ||
122 | 122 | @Callable(i) | |
123 | 123 | func feedDuckling (ducklingId,backendSignature,maxFeedAmount,userNonce) = { | |
124 | 124 | let addressString = toString(i.caller) | |
125 | 125 | let backendProof = getBackendProof(maxFeedAmount, userNonce, addressString) | |
126 | 126 | let kAddressNonce = keyAddressNonce(addressString) | |
127 | 127 | let currentNonce = tryGetInteger(kAddressNonce) | |
128 | 128 | let realDucklingId = if (!(sigVerify_8Kb(toBytes(backendProof), fromBase58String(backendSignature), backendPubKey))) | |
129 | 129 | then throw("Invalid proof from backend") | |
130 | 130 | else if (if ((size(i.payments) != 1)) | |
131 | 131 | then true | |
132 | 132 | else (value(i.payments[0]).assetId != EGGASSETID)) | |
133 | 133 | then throw("Bad payment attached (asset[s] or amount)") | |
134 | 134 | else if (getBool(keyDucklingGrown(ducklingId))) | |
135 | 135 | then throw("Duckling is already grown") | |
136 | 136 | else if ((userNonce != (currentNonce + 1))) | |
137 | 137 | then throw(((("User Nonce should be " + toString(currentNonce)) + " + 1, while received ") + toString(userNonce))) | |
138 | 138 | else if ((ducklingId == "")) | |
139 | 139 | then { | |
140 | 140 | let ducklingAssetId = invoke(this, "issueFreeDuckling", [toString(i.originCaller), toBase58String(i.transactionId)], nil) | |
141 | 141 | if ((ducklingAssetId == ducklingAssetId)) | |
142 | 142 | then { | |
143 | 143 | let id = match ducklingAssetId { | |
144 | 144 | case v: String => | |
145 | 145 | v | |
146 | 146 | case _ => | |
147 | 147 | throw("Can't generate NFT") | |
148 | 148 | } | |
149 | 149 | id | |
150 | 150 | } | |
151 | 151 | else throw("Strict value is not equal to itself.") | |
152 | 152 | } | |
153 | 153 | else { | |
154 | 154 | let ducklingIdCheck = value(assetInfo(fromBase58String(ducklingId))) | |
155 | 155 | if ((assetBalance(i.caller, ducklingIdCheck.id) != 1)) | |
156 | 156 | then throw("You're not the owner of the duckling") | |
157 | 157 | else if ((ducklingIdCheck.issuer != this)) | |
158 | 158 | then throw("Cant find duckling with such id") | |
159 | 159 | else { | |
160 | 160 | let ducklingIdString = toBase58String(ducklingIdCheck.id) | |
161 | 161 | ducklingIdString | |
162 | 162 | } | |
163 | 163 | } | |
164 | 164 | let kDucklingLastFedTs = keyDucklingFedLastTimestamp(ducklingId) | |
165 | 165 | let lastFedTs = getLastFedTimestamp(realDucklingId) | |
166 | 166 | let currentPayment = value(i.payments[0]).amount | |
167 | 167 | let kNewLevel = keyDucklingLevel(realDucklingId) | |
168 | 168 | let kTotalFeed = keyTotalFeed(realDucklingId) | |
169 | 169 | let totalFeed = tryGetInteger(kTotalFeed) | |
170 | 170 | let kFeedTxStats = ((("duckling_" + realDucklingId) + "_stat_") + toString(lastBlock.timestamp)) | |
171 | 171 | let kAddressFedTimestamp = keyAddressFedTimestamp(addressString, getCurrentLap()) | |
172 | 172 | let kDucklingFedLapTimestamp = keyDucklingFedLapTimestamp(realDucklingId, getCurrentLap()) | |
173 | 173 | if ((currentPayment > maxFeedAmount)) | |
174 | 174 | then throw(("Cannot feed duckling for such amount, max feed amount is: " + toString(maxFeedAmount))) | |
175 | 175 | else { | |
176 | 176 | let calculateResults = calculateNewDucklingLevel(realDucklingId, currentPayment) | |
177 | 177 | [IntegerEntry(kAddressNonce, (currentNonce + 1)), IntegerEntry(kDucklingLastFedTs, lastBlock.timestamp), IntegerEntry(kTotalFeed, (totalFeed + currentPayment)), IntegerEntry(kFeedTxStats, currentPayment), IntegerEntry(kAddressFedTimestamp, currentPayment), IntegerEntry(kDucklingFedLapTimestamp, currentPayment), StringEntry(kNewLevel, calculateResults._1), StringEntry((kFeedTxStats + "_debug"), makeString(calculateResults._2, ";"))] | |
178 | 178 | } | |
179 | 179 | } | |
180 | 180 | ||
181 | 181 | ||
182 | 182 | ||
183 | 183 | @Callable(i) | |
184 | 184 | func fixLevels (ducklingIds) = if ((i.callerPublicKey != base58'GDxBbsDRmeY39quNrDsTXKJzFWbQVtjxHseF4ikxZ7n9')) | |
185 | 185 | then throw("") | |
186 | 186 | else { | |
187 | 187 | let ducklingIdsList = value(split(ducklingIds, ",")) | |
188 | 188 | func handleId (acc,id) = { | |
189 | 189 | let kTotalFeed = keyTotalFeed(id) | |
190 | 190 | let totalFeed = tryGetInteger(kTotalFeed) | |
191 | 191 | let kNewLevel = keyDucklingLevel(id) | |
192 | 192 | let startingLevel = match getBoolean((("duckling_" + id) + "_issuedByFeedCall")) { | |
193 | 193 | case b: Boolean => | |
194 | 194 | toBigInt(0) | |
195 | 195 | case _ => | |
196 | 196 | toBigInt((20 * existingDuckPrecision)) | |
197 | 197 | } | |
198 | 198 | let growth = fraction(toBigInt(totalFeed), toBigInt(percentGrowthPrecision), toBigInt(DUCKLINGPRICE)) | |
199 | 199 | (acc ++ [StringEntry(kNewLevel, toString((startingLevel + growth)))]) | |
200 | 200 | } | |
201 | 201 | ||
202 | 202 | let $l = ducklingIdsList | |
203 | 203 | let $s = size($l) | |
204 | 204 | let $acc0 = nil | |
205 | 205 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
206 | 206 | then $a | |
207 | 207 | else handleId($a, $l[$i]) | |
208 | 208 | ||
209 | 209 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
210 | 210 | then $a | |
211 | 211 | else throw("List size exceeds 20") | |
212 | 212 | ||
213 | 213 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($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), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
214 | 214 | } | |
215 | 215 | ||
216 | 216 | ||
217 | 217 | ||
218 | 218 | @Callable(i) | |
219 | 219 | func turnDucklingIntoDuck () = { | |
220 | 220 | let address = toString(i.caller) | |
221 | 221 | let txId = toBase58String(i.transactionId) | |
222 | 222 | let lastIssuedDucklingTs = tryGetInteger(KGlobalIssuedTimestamp) | |
223 | 223 | let fiveMinInMs = ((5 * 60) * 1000) | |
224 | 224 | if (if ((lastIssuedDucklingTs > 0)) | |
225 | 225 | then (fiveMinInMs > (lastBlock.timestamp - lastIssuedDucklingTs)) | |
226 | 226 | else false) | |
227 | 227 | then throw(("Can issue ducklings only once per 5 minutes, please wait for " + toString((fiveMinInMs - (lastBlock.timestamp - lastIssuedDucklingTs))))) | |
228 | 228 | else if ((size(i.payments) != 1)) | |
229 | 229 | then throw("Bad payment attached (asset[s] or amount)") | |
230 | 230 | else { | |
231 | 231 | let pmt = value(assetInfo(value(value(i.payments[0]).assetId))) | |
232 | 232 | if ((pmt.issuer != this)) | |
233 | 233 | then throw("Can use only ducklings from this dApp") | |
234 | 234 | else { | |
235 | - | let call = invoke(Address(incubatorAddress), " | |
235 | + | let call = invoke(Address(incubatorAddress), "startDuckHatching", nil, nil) | |
236 | 236 | if ((call == call)) | |
237 | 237 | then { | |
238 | 238 | let kDucklingGrown = keyDucklingGrown(toBase58String(pmt.id)) | |
239 | 239 | [BooleanEntry(kDucklingGrown, true), IntegerEntry(KGlobalIssuedTimestamp, lastBlock.timestamp)] | |
240 | 240 | } | |
241 | 241 | else throw("Strict value is not equal to itself.") | |
242 | 242 | } | |
243 | 243 | } | |
244 | 244 | } | |
245 | 245 | ||
246 | 246 | ||
247 | 247 | @Verifier(tx) | |
248 | 248 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
249 | 249 |
github/deemru/w8io/6500d08 56.75 ms ◑