tx · 5BNM5fTHxYPRFxfsmENaeTnrzR8Dkbdq34KCEXptS5ov 3N3b5wban4PEUuND6PxSbTvoekc66fss78g: -0.14000000 Waves 2021.10.28 21:17 [1766498] smart account 3N3b5wban4PEUuND6PxSbTvoekc66fss78g > SELF 0.00000000 Waves
{ "type": 13, "id": "5BNM5fTHxYPRFxfsmENaeTnrzR8Dkbdq34KCEXptS5ov", "fee": 14000000, "feeAssetId": null, "timestamp": 1635445057716, "version": 2, "chainId": 84, "sender": "3N3b5wban4PEUuND6PxSbTvoekc66fss78g", "senderPublicKey": "DkMBTSHqT9hKVK1joeyL9DWKdzMAiCYZtYVkMPUx4Zwq", "proofs": [ "62iokSF6ep7x7kPeUPuENWsmaqppQrty6yPsgHJt28MRi211iX1ghQVjoBTJKRcRtZoCB7CuBCTnRwf7GJ3SzUMz" ], "script": "base64:AAIFAAAAAAAAAAQIAhIAAAAADQAAAAARa2V5QWN0aXZhdGVIZWlnaHQCAAAAD2FjdGl2YXRlX2hlaWdodAAAAAAPa2V5RmluaXNoSGVpZ2h0AgAAAA1maW5pc2hfaGVpZ2h0AAAAAA5hY3RpdmF0ZUhlaWdodAkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgUAAAAEdGhpcwUAAAARa2V5QWN0aXZhdGVIZWlnaHQAAAAADGZpbmlzaEhlaWdodAkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgUAAAAEdGhpcwUAAAAPa2V5RmluaXNoSGVpZ2h0AAAAAA50b3RhbFNoYXJlRU5OTwAAAFrzEHpAAAAAAAAERU5OTwEAAAAgFbvcV9OA6rL+53m/DeV6nxGYIu+IXr9brrnP32tIN3AAAAAAGGtleVVzZXJFTk5PQ2xhaW1lZEFtb3VudAIAAAAUX0VOTk9fY2xhaW1lZF9hbW91bnQAAAAAHGtleVVzZXJFTk5PTGFzdENsYWltZWRBbW91bnQCAAAAGV9FTk5PX2xhc3RfY2xhaW1lZF9hbW91bnQAAAAADGFkbWluUHViS2V5MQEAAAAgvWcJKwwP99rCF9lbusP3PzHjegHHk+TyHcmUZzmz6DQAAAAADGFkbWluUHViS2V5MgEAAAAgvWcJKwwP99rCF9lbusP3PzHjegHHk+TyHcmUZzmz6DQAAAAADGFkbWluUHViS2V5MwEAAAAgvWcJKwwP99rCF9lbusP3PzHjegHHk+TyHcmUZzmz6DQBAAAADmdldENhbGxlclNoYXJlAAAAAQAAAAZjYWxsZXIEAAAAC2NhbGxlclNoYXJlCQAEGgAAAAIFAAAABHRoaXMJAAEsAAAAAgIAAAAGc2hhcmVfCQAEJQAAAAEFAAAABmNhbGxlcgQAAAARY2FsbGVyU2hhcmVBbW91bnQEAAAAByRtYXRjaDAFAAAAC2NhbGxlclNoYXJlAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAABXNoYXJlBQAAAAckbWF0Y2gwBQAAAAVzaGFyZQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAEVW5pdAQAAAAFc2hhcmUFAAAAByRtYXRjaDAJAAACAAAAAQIAAAA1T25seSBlYXJseSBsaXF1aWRpdHkgcHJvdmlkZXJzIGNhbiBjYWxsIHRoaXMgZnVuY3Rpb24JAAACAAAAAQIAAAALTWF0Y2ggZXJyb3IFAAAAEWNhbGxlclNoYXJlQW1vdW50AQAAABBnZXRDbGFpbWVkQW1vdW50AAAAAQAAAAZjYWxsZXIEAAAAD2NhbGxlcldpdGhkcmF3bgkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIJAAQlAAAAAQUAAAAGY2FsbGVyBQAAABhrZXlVc2VyRU5OT0NsYWltZWRBbW91bnQEAAAAFWNhbGxlcldpdGhkcmF3bkFtb3VudAQAAAAHJG1hdGNoMAUAAAAPY2FsbGVyV2l0aGRyYXduAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAABXNoYXJlBQAAAAckbWF0Y2gwBQAAAAVzaGFyZQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAEVW5pdAQAAAAFc2hhcmUFAAAAByRtYXRjaDAAAAAAAAAAAAAJAAACAAAAAQIAAAALTWF0Y2ggZXJyb3IFAAAAFWNhbGxlcldpdGhkcmF3bkFtb3VudAAAAAEAAAABaQEAAAAJY2xhaW1FTk5PAAAAAAQAAAANYmxvY2tEdXJhdGlvbgkAAGUAAAACBQAAAAxmaW5pc2hIZWlnaHQFAAAADmFjdGl2YXRlSGVpZ2h0BAAAAA9jdXJyZW50RHVyYXRpb24DCQAAZgAAAAIFAAAADGZpbmlzaEhlaWdodAUAAAAGaGVpZ2h0BQAAAAZoZWlnaHQFAAAADGZpbmlzaEhlaWdodAQAAAAJdXNlclNoYXJlCQEAAAAOZ2V0Q2FsbGVyU2hhcmUAAAABCAUAAAABaQAAAAZjYWxsZXIDCQAAZgAAAAIFAAAADmFjdGl2YXRlSGVpZ2h0BQAAAAZoZWlnaHQJAAACAAAAAQIAAAArRWFybHkgQmlyZCBwZXJpb2QgaGFzIG5vdCBiZWVuIHN0YXJ0ZWQgeWV0LgQAAAARdXNlckNsYWltZWRBbW91bnQJAQAAABBnZXRDbGFpbWVkQW1vdW50AAAAAQgFAAAAAWkAAAAGY2FsbGVyBAAAAAtjbGFpbUFtb3VudAkAAGUAAAACCQAAawAAAAMJAABlAAAAAgUAAAAPY3VycmVudER1cmF0aW9uBQAAAA5hY3RpdmF0ZUhlaWdodAUAAAAJdXNlclNoYXJlBQAAAA1ibG9ja0R1cmF0aW9uBQAAABF1c2VyQ2xhaW1lZEFtb3VudAQAAAAUdXNlckNsYWltZWRBbW91bnROZXcJAABkAAAAAgUAAAARdXNlckNsYWltZWRBbW91bnQFAAAAC2NsYWltQW1vdW50CQAETAAAAAIJAQAAAA5TY3JpcHRUcmFuc2ZlcgAAAAMIBQAAAAFpAAAABmNhbGxlcgUAAAALY2xhaW1BbW91bnQFAAAABEVOTk8JAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIFAAAAGGtleVVzZXJFTk5PQ2xhaW1lZEFtb3VudAUAAAAUdXNlckNsYWltZWRBbW91bnROZXcJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIFAAAAHGtleVVzZXJFTk5PTGFzdENsYWltZWRBbW91bnQFAAAAC2NsYWltQW1vdW50BQAAAANuaWwAAAABAAAAAnR4AQAAAAZ2ZXJpZnkAAAAABAAAAAckbWF0Y2gwBQAAAAJ0eAMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAPRGF0YVRyYW5zYWN0aW9uBAAAAAFkBQAAAAckbWF0Y2gwCQAB9AAAAAMIBQAAAAJ0eAAAAAlib2R5Qnl0ZXMJAAGRAAAAAggFAAAAAnR4AAAABnByb29mcwAAAAAAAAAAAAgFAAAAAnR4AAAAD3NlbmRlclB1YmxpY0tleQQAAAASYWRtaW5QdWJLZXkxU2lnbmVkAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAAFAAAADGFkbWluUHViS2V5MQAAAAAAAAAAAQAAAAAAAAAAAAQAAAASYWRtaW5QdWJLZXkyU2lnbmVkAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAEFAAAADGFkbWluUHViS2V5MgAAAAAAAAAAAQAAAAAAAAAAAAQAAAASYWRtaW5QdWJLZXkzU2lnbmVkAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAIFAAAADGFkbWluUHViS2V5MwAAAAAAAAAAAQAAAAAAAAAAAAkAAGcAAAACCQAAZAAAAAIJAABkAAAAAgUAAAASYWRtaW5QdWJLZXkxU2lnbmVkBQAAABJhZG1pblB1YktleTJTaWduZWQFAAAAEmFkbWluUHViS2V5M1NpZ25lZAAAAAAAAAAAApGRgDc=", "height": 1766498, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 4aD1JDKnZugmCBZ3QiSsXiQvQG7QNE6dxadJBQYpDsFe Next: FtQ99f4gaWUZqeKktSpjHSF9kmna88E29bujTT3eAuVC Full:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let keyActivateHeight = "activate_height" | |
5 | + | ||
6 | + | let keyFinishHeight = "finish_height" | |
7 | + | ||
8 | + | let activateHeight = getIntegerValue(this, keyActivateHeight) | |
9 | + | ||
10 | + | let finishHeight = getIntegerValue(this, keyFinishHeight) | |
11 | + | ||
12 | + | let totalShareENNO = 100000000000000 | |
13 | + | ||
14 | + | let ENNO = base58'2Tqhz5PWbkijnzYpdLxLDFfVDw5ALQWm2rmxQ79ooMRZ' | |
15 | + | ||
16 | + | let keyUserENNOClaimedAmount = "_ENNO_claimed_amount" | |
17 | + | ||
18 | + | let keyUserENNOLastClaimedAmount = "_ENNO_last_claimed_amount" | |
19 | + | ||
20 | + | let adminPubKey1 = base58'DkMBTSHqT9hKVK1joeyL9DWKdzMAiCYZtYVkMPUx4Zwq' | |
21 | + | ||
22 | + | let adminPubKey2 = base58'DkMBTSHqT9hKVK1joeyL9DWKdzMAiCYZtYVkMPUx4Zwq' | |
23 | + | ||
24 | + | let adminPubKey3 = base58'DkMBTSHqT9hKVK1joeyL9DWKdzMAiCYZtYVkMPUx4Zwq' | |
25 | + | ||
26 | + | func getCallerShare (caller) = { | |
27 | + | let callerShare = getInteger(this, ("share_" + toString(caller))) | |
28 | + | let callerShareAmount = match callerShare { | |
29 | + | case share: Int => | |
30 | + | share | |
31 | + | case share: Unit => | |
32 | + | throw("Only early liquidity providers can call this function") | |
33 | + | case _ => | |
34 | + | throw("Match error") | |
35 | + | } | |
36 | + | callerShareAmount | |
37 | + | } | |
4 | 38 | ||
5 | 39 | ||
40 | + | func getClaimedAmount (caller) = { | |
41 | + | let callerWithdrawn = getInteger(this, (toString(caller) + keyUserENNOClaimedAmount)) | |
42 | + | let callerWithdrawnAmount = match callerWithdrawn { | |
43 | + | case share: Int => | |
44 | + | share | |
45 | + | case share: Unit => | |
46 | + | 0 | |
47 | + | case _ => | |
48 | + | throw("Match error") | |
49 | + | } | |
50 | + | callerWithdrawnAmount | |
51 | + | } | |
52 | + | ||
53 | + | ||
54 | + | @Callable(i) | |
55 | + | func claimENNO () = { | |
56 | + | let blockDuration = (finishHeight - activateHeight) | |
57 | + | let currentDuration = if ((finishHeight > height)) | |
58 | + | then height | |
59 | + | else finishHeight | |
60 | + | let userShare = getCallerShare(i.caller) | |
61 | + | if ((activateHeight > height)) | |
62 | + | then throw("Early Bird period has not been started yet.") | |
63 | + | else { | |
64 | + | let userClaimedAmount = getClaimedAmount(i.caller) | |
65 | + | let claimAmount = (fraction((currentDuration - activateHeight), userShare, blockDuration) - userClaimedAmount) | |
66 | + | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
67 | + | [ScriptTransfer(i.caller, claimAmount, ENNO), IntegerEntry((toString(i.caller) + keyUserENNOClaimedAmount), userClaimedAmountNew), IntegerEntry((toString(i.caller) + keyUserENNOLastClaimedAmount), claimAmount)] | |
68 | + | } | |
69 | + | } | |
70 | + | ||
71 | + | ||
72 | + | @Verifier(tx) | |
73 | + | func verify () = match tx { | |
74 | + | case d: DataTransaction => | |
75 | + | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
76 | + | case _ => | |
77 | + | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1)) | |
78 | + | then 1 | |
79 | + | else 0 | |
80 | + | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2)) | |
81 | + | then 1 | |
82 | + | else 0 | |
83 | + | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3)) | |
84 | + | then 1 | |
85 | + | else 0 | |
86 | + | (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2) | |
87 | + | } | |
6 | 88 |
github/deemru/w8io/169f3d6 38.35 ms ◑