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