tx · FM25eVbuBZQz3brG1BevUBxPuyccxJ5TBfFWmWpjHWhc 3N5qejBhCedYyTbK7Qgqxn2T6kubSeHt7pu: -0.14000000 Waves 2021.10.28 14:05 [1766063] smart account 3N5qejBhCedYyTbK7Qgqxn2T6kubSeHt7pu > SELF 0.00000000 Waves
{ "type": 13, "id": "FM25eVbuBZQz3brG1BevUBxPuyccxJ5TBfFWmWpjHWhc", "fee": 14000000, "feeAssetId": null, "timestamp": 1635419123693, "version": 2, "chainId": 84, "sender": "3N5qejBhCedYyTbK7Qgqxn2T6kubSeHt7pu", "senderPublicKey": "Ese6jz6mtrhgwJWdXbAxHNHg2qzae5D2xXWuVF7tLfs8", "proofs": [ "5NiaUsLmUN1Xb4WTP1mN8y7MFdFGDZ6cc8E5W1d3s3kC8ny3mkb1EXjaZ9DqpafegjMVU4MuYFkMBGGFdAPYEkRL", "5ZJ9EfQ6ua1K94WuWx1DK5QEfQJtGJFL76Pu8tAMQnK9DFZVF6c9XK3igttCY2B2SS7z1KtzHV8zhA4zg3NJTLoh" ], "script": "base64:AAIFAAAAAAAAABEIAhIAEgMKAQESABIAEgASAAAAABMAAAAADGFkbWluUHViS2V5MQEAAAAgziDrH6xfwdIN/6jc9LbpeFKW8n6DL11Crgzyd6TZbxsAAAAADGFkbWluUHViS2V5MgEAAAAgziDrH6xfwdIN/6jc9LbpeFKW8n6DL11Crgzyd6TZbxsAAAAADGFkbWluUHViS2V5MwEAAAAgziDrH6xfwdIN/6jc9LbpeFKW8n6DL11Crgzyd6TZbxsAAAAAFGFkbWluUHViS2V5U3RhcnRTdG9wAQAAACDOIOsfrF/B0g3/qNz0tul4UpbyfoMvXUKuDPJ3pNlvGwAAAAAJa2V5QWN0aXZlAgAAAAZhY3RpdmUAAAAACGtleUNhdXNlAgAAAA5zaHV0ZG93bl9jYXVzZQAAAAARa2V5VXNlckVOTk9Mb2NrZWQCAAAADF9FTk5PX2Ftb3VudAAAAAASa2V5VG90YWxFTk5PTG9ja2VkAgAAABF0b3RhbF9FTk5PX2Ftb3VudAAAAAAYa2V5VXNlckVOTk9DbGFpbWVkQW1vdW50AgAAABRfRU5OT19jbGFpbWVkX2Ftb3VudAAAAAAca2V5VXNlckVOTk9MYXN0Q2xhaW1lZEFtb3VudAIAAAAZX0VOTk9fbGFzdF9jbGFpbWVkX2Ftb3VudAAAAAAUa2V5VXNlckVOTk9Mb2NrZWRUYWcCAAAABnNoYXJlXwAAAAAIaXNBY3RpdmUJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQbAAAAAgUAAAAEdGhpcwUAAAAJa2V5QWN0aXZlBgAAAAAJc2hhcmVEYXRhAQAAACBbQ+QzUMC1aF2T3qieo6NeRn/NixQZhgbin5TRqlXoWQAAAAAERU5OTwEAAAAgFbvcV9OA6rL+53m/DeV6nxGYIu+IXr9brrnP32tIN3ABAAAAB3N1c3BlbmQAAAABAAAABWNhdXNlCQAETAAAAAIJAQAAAAxCb29sZWFuRW50cnkAAAACBQAAAAlrZXlBY3RpdmUHCQAETAAAAAIJAQAAAAtTdHJpbmdFbnRyeQAAAAIFAAAACGtleUNhdXNlBQAAAAVjYXVzZQUAAAADbmlsAQAAABFnZXRVc2VyRU5OT0xvY2tlZAAAAAEAAAAEdXNlcgkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIJAAQlAAAAAQUAAAAEdXNlcgUAAAARa2V5VXNlckVOTk9Mb2NrZWQAAAAAAAAAAAABAAAAEmdldFRvdGFsRU5OT0xvY2tlZAAAAAAJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwUAAAASa2V5VG90YWxFTk5PTG9ja2VkAAAAAAAAAAAAAQAAAA5nZXRDYWxsZXJTaGFyZQAAAAEAAAAGY2FsbGVyBAAAAAtjYWxsZXJTaGFyZQkABBoAAAACCQEAAAAUYWRkcmVzc0Zyb21QdWJsaWNLZXkAAAABBQAAAAlzaGFyZURhdGEJAAEsAAAAAgUAAAAUa2V5VXNlckVOTk9Mb2NrZWRUYWcJAAQlAAAAAQUAAAAGY2FsbGVyBAAAABFjYWxsZXJTaGFyZUFtb3VudAQAAAAHJG1hdGNoMAUAAAALY2FsbGVyU2hhcmUDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAAFc2hhcmUFAAAAByRtYXRjaDAFAAAABXNoYXJlAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAARVbml0BAAAAAVzaGFyZQUAAAAHJG1hdGNoMAkAAAIAAAABAgAAADJPbmx5IGdvdmVybmFuY2UgcXVhbGlmaWVycyBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uLgkAAAIAAAABAgAAAAtNYXRjaCBlcnJvcgUAAAARY2FsbGVyU2hhcmVBbW91bnQBAAAAEGdldENsYWltZWRBbW91bnQAAAABAAAABmNhbGxlcgQAAAAPY2FsbGVyV2l0aGRyYXduCQAEGgAAAAIFAAAABHRoaXMJAAEsAAAAAgkABCUAAAABBQAAAAZjYWxsZXIFAAAAGGtleVVzZXJFTk5PQ2xhaW1lZEFtb3VudAQAAAAVY2FsbGVyV2l0aGRyYXduQW1vdW50BAAAAAckbWF0Y2gwBQAAAA9jYWxsZXJXaXRoZHJhd24DCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAAFc2hhcmUFAAAAByRtYXRjaDAFAAAABXNoYXJlAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAARVbml0BAAAAAVzaGFyZQUAAAAHJG1hdGNoMAAAAAAAAAAAAAkAAAIAAAABAgAAAAtNYXRjaCBlcnJvcgUAAAAVY2FsbGVyV2l0aGRyYXduQW1vdW50AAAABgAAAAFpAQAAAAhsb2NrRU5OTwAAAAADCQEAAAABIQAAAAEFAAAACGlzQWN0aXZlCQAAAgAAAAECAAAAH0RBcHAgaXMgaW5hY3RpdmUgYXQgdGhpcyBtb21lbnQEAAAACyR0MDE4OTYxOTcxCQAFFAAAAAIICQABkQAAAAIIBQAAAAFpAAAACHBheW1lbnRzAAAAAAAAAAAAAAAABmFtb3VudAgJAAGRAAAAAggFAAAAAWkAAAAIcGF5bWVudHMAAAAAAAAAAAAAAAAHYXNzZXRJZAQAAAAJcG10QW1vdW50CAUAAAALJHQwMTg5NjE5NzEAAAACXzEEAAAACnBtdEFzc2V0SWQIBQAAAAskdDAxODk2MTk3MQAAAAJfMgMJAQAAAAIhPQAAAAIFAAAACnBtdEFzc2V0SWQFAAAABEVOTk8JAAACAAAAAQIAAAA0SW5jb3JyZWN0IHBheW1lbnQgYXNzZXRJZCBvbmx5IEVubm8gQ2FzaCBpcyBhbGxvd2VkLgQAAAAOdXNlckVOTk9Mb2NrZWQJAQAAABFnZXRVc2VyRU5OT0xvY2tlZAAAAAEIBQAAAAFpAAAADG9yaWdpbkNhbGxlcgQAAAARdXNlckVOTk9Mb2NrZWROZXcJAABkAAAAAgUAAAAOdXNlckVOTk9Mb2NrZWQFAAAACXBtdEFtb3VudAQAAAAPdG90YWxFTk5PTG9ja2VkCQEAAAASZ2V0VG90YWxFTk5PTG9ja2VkAAAAAAQAAAASdG90YWxFTk5PTG9ja2VkTmV3CQAAZAAAAAIFAAAAD3RvdGFsRU5OT0xvY2tlZAUAAAAJcG10QW1vdW50CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAIJAAQlAAAAAQgFAAAAAWkAAAAMb3JpZ2luQ2FsbGVyBQAAABFrZXlVc2VyRU5OT0xvY2tlZAUAAAARdXNlckVOTk9Mb2NrZWROZXcJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIFAAAAEmtleVRvdGFsRU5OT0xvY2tlZAUAAAASdG90YWxFTk5PTG9ja2VkTmV3BQAAAANuaWwAAAABaQEAAAAMd2l0aGRyYXdFTk5PAAAAAQAAAA53aXRoZHJhd0Ftb3VudAMJAQAAAAEhAAAAAQUAAAAIaXNBY3RpdmUJAAACAAAAAQIAAAAfREFwcCBpcyBpbmFjdGl2ZSBhdCB0aGlzIG1vbWVudAMJAABnAAAAAgAAAAAAAAAAAAUAAAAOd2l0aGRyYXdBbW91bnQJAAACAAAAAQIAAAATd2l0aGRyYXdBbW91bnQgPD0gMAQAAAAPdG90YWxFTk5PTG9ja2VkCQEAAAASZ2V0VG90YWxFTk5PTG9ja2VkAAAAAAQAAAAOdXNlckVOTk9Mb2NrZWQJAQAAABFnZXRVc2VyRU5OT0xvY2tlZAAAAAEIBQAAAAFpAAAABmNhbGxlcgMJAABmAAAAAgUAAAAOd2l0aGRyYXdBbW91bnQFAAAAD3RvdGFsRU5OT0xvY2tlZAkAAAIAAAABAgAAADF3aXRoZHJhd0Ftb3VudCBpcyBtb3JlIHRoYW4gYXZhaWxhYmxlIHRvIHdpdGhkcmF3AwkAAGYAAAACBQAAAA53aXRoZHJhd0Ftb3VudAUAAAAOdXNlckVOTk9Mb2NrZWQJAAACAAAAAQIAAAA0WW91IGFyZSB0cnlpbmcgdG8gdW5zdGFrZSBtb3JlIHRoYW4geW91IGhhdmUgc3Rha2VkLgQAAAASdG90YWxFTk5PTG9ja2VkTmV3CQAAZQAAAAIFAAAAD3RvdGFsRU5OT0xvY2tlZAUAAAAOd2l0aGRyYXdBbW91bnQEAAAAEXVzZXJFTk5PYW1vdW50TmV3CQAAZQAAAAIFAAAADnVzZXJFTk5PTG9ja2VkBQAAAA53aXRoZHJhd0Ftb3VudAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkAASwAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAARa2V5VXNlckVOTk9Mb2NrZWQFAAAAEXVzZXJFTk5PYW1vdW50TmV3CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACBQAAABJrZXlUb3RhbEVOTk9Mb2NrZWQFAAAAEnRvdGFsRU5OT0xvY2tlZE5ldwkABEwAAAACCQEAAAAOU2NyaXB0VHJhbnNmZXIAAAADCAUAAAABaQAAAAZjYWxsZXIFAAAADndpdGhkcmF3QW1vdW50BQAAAARFTk5PBQAAAANuaWwAAAABaQEAAAAUY2xhaW1BbmRXaXRoZHJhd0VOTk8AAAAAAwkBAAAAASEAAAABBQAAAAhpc0FjdGl2ZQkAAAIAAAABAgAAAB9EQXBwIGlzIGluYWN0aXZlIGF0IHRoaXMgbW9tZW50BAAAAAl1c2VyU2hhcmUJAQAAAA5nZXRDYWxsZXJTaGFyZQAAAAEIBQAAAAFpAAAABmNhbGxlcgQAAAARdXNlckNsYWltZWRBbW91bnQJAQAAABBnZXRDbGFpbWVkQW1vdW50AAAAAQgFAAAAAWkAAAAGY2FsbGVyBAAAAAtjbGFpbUFtb3VudAkAAGUAAAACBQAAAAl1c2VyU2hhcmUFAAAAEXVzZXJDbGFpbWVkQW1vdW50BAAAAA90b3RhbEVOTk9Mb2NrZWQJAQAAABJnZXRUb3RhbEVOTk9Mb2NrZWQAAAAAAwkAAGYAAAACBQAAAAtjbGFpbUFtb3VudAUAAAAPdG90YWxFTk5PTG9ja2VkCQAAAgAAAAECAAAALmNsYWltQW1vdW50IGlzIG1vcmUgdGhhbiBhdmFpbGFibGUgdG8gd2l0aGRyYXcDCQAAZwAAAAIAAAAAAAAAAAAFAAAAC2NsYWltQW1vdW50CQAAAgAAAAECAAAAIkNsYWltIGFtb3VudCBtdXN0IGJlIGJpZ2dlciB0aGFuIDAEAAAAFHVzZXJDbGFpbWVkQW1vdW50TmV3CQAAZAAAAAIFAAAAEXVzZXJDbGFpbWVkQW1vdW50BQAAAAtjbGFpbUFtb3VudAkABEwAAAACCQEAAAAOU2NyaXB0VHJhbnNmZXIAAAADCAUAAAABaQAAAAZjYWxsZXIFAAAAC2NsYWltQW1vdW50BQAAAARFTk5PCQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAIJAAQlAAAAAQgFAAAAAWkAAAAGY2FsbGVyBQAAABhrZXlVc2VyRU5OT0NsYWltZWRBbW91bnQFAAAAFHVzZXJDbGFpbWVkQW1vdW50TmV3CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAIJAAQlAAAAAQgFAAAAAWkAAAAGY2FsbGVyBQAAABxrZXlVc2VyRU5OT0xhc3RDbGFpbWVkQW1vdW50BQAAAAtjbGFpbUFtb3VudAUAAAADbmlsAAAAAWkBAAAAEWNsYWltQW5kU3Rha2VFTk5PAAAAAAMJAQAAAAEhAAAAAQUAAAAIaXNBY3RpdmUJAAACAAAAAQIAAAAfREFwcCBpcyBpbmFjdGl2ZSBhdCB0aGlzIG1vbWVudAQAAAAJdXNlclNoYXJlCQEAAAAOZ2V0Q2FsbGVyU2hhcmUAAAABCAUAAAABaQAAAAZjYWxsZXIEAAAAEXVzZXJDbGFpbWVkQW1vdW50CQEAAAAQZ2V0Q2xhaW1lZEFtb3VudAAAAAEIBQAAAAFpAAAABmNhbGxlcgQAAAALY2xhaW1BbW91bnQJAABlAAAAAgUAAAAJdXNlclNoYXJlBQAAABF1c2VyQ2xhaW1lZEFtb3VudAMJAABnAAAAAgAAAAAAAAAAAAUAAAALY2xhaW1BbW91bnQJAAACAAAAAQIAAAAiQ2xhaW0gYW1vdW50IG11c3QgYmUgYmlnZ2VyIHRoYW4gMAQAAAAUdXNlckNsYWltZWRBbW91bnROZXcJAABkAAAAAgUAAAARdXNlckNsYWltZWRBbW91bnQFAAAAC2NsYWltQW1vdW50BAAAAA51c2VyRU5OT0xvY2tlZAkBAAAAEWdldFVzZXJFTk5PTG9ja2VkAAAAAQgFAAAAAWkAAAAGY2FsbGVyBAAAABF1c2VyRU5OT0xvY2tlZE5ldwkAAGQAAAACBQAAAA51c2VyRU5OT0xvY2tlZAUAAAALY2xhaW1BbW91bnQEAAAAD3RvdGFsRU5OT0xvY2tlZAkBAAAAEmdldFRvdGFsRU5OT0xvY2tlZAAAAAAEAAAAEnRvdGFsRU5OT0xvY2tlZE5ldwkAAGQAAAACBQAAAA90b3RhbEVOTk9Mb2NrZWQFAAAAC2NsYWltQW1vdW50CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAIJAAQlAAAAAQgFAAAAAWkAAAAGY2FsbGVyBQAAABFrZXlVc2VyRU5OT0xvY2tlZAUAAAARdXNlckVOTk9Mb2NrZWROZXcJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIFAAAAEmtleVRvdGFsRU5OT0xvY2tlZAUAAAASdG90YWxFTk5PTG9ja2VkTmV3BQAAAANuaWwAAAABaQEAAAAIc2h1dGRvd24AAAAAAwkBAAAAASEAAAABBQAAAAhpc0FjdGl2ZQkAAAIAAAABCQABLAAAAAICAAAAIkRBcHAgaXMgYWxyZWFkeSBzdXNwZW5kZWQuIENhdXNlOiAJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQdAAAAAgUAAAAEdGhpcwUAAAAIa2V5Q2F1c2UCAAAAGnRoZSBjYXVzZSB3YXNuJ3Qgc3BlY2lmaWVkAwkBAAAAASEAAAABCQEAAAAPY29udGFpbnNFbGVtZW50AAAAAgkABEwAAAACBQAAAAxhZG1pblB1YktleTEJAARMAAAAAgUAAAAMYWRtaW5QdWJLZXkyCQAETAAAAAIFAAAADGFkbWluUHViS2V5MwkABEwAAAACBQAAABRhZG1pblB1YktleVN0YXJ0U3RvcAUAAAADbmlsCAUAAAABaQAAAA9jYWxsZXJQdWJsaWNLZXkJAAACAAAAAQIAAAAhT25seSBhZG1pbiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uCQEAAAAHc3VzcGVuZAAAAAECAAAAD1BhdXNlZCBieSBhZG1pbgAAAAFpAQAAAAhhY3RpdmF0ZQAAAAADBQAAAAhpc0FjdGl2ZQkAAAIAAAABAgAAABZEQXBwIGlzIGFscmVhZHkgYWN0aXZlAwkBAAAAASEAAAABCQEAAAAPY29udGFpbnNFbGVtZW50AAAAAgkABEwAAAACBQAAAAxhZG1pblB1YktleTEJAARMAAAAAgUAAAAMYWRtaW5QdWJLZXkyCQAETAAAAAIFAAAADGFkbWluUHViS2V5MwkABEwAAAACBQAAABRhZG1pblB1YktleVN0YXJ0U3RvcAUAAAADbmlsCAUAAAABaQAAAA9jYWxsZXJQdWJsaWNLZXkJAAACAAAAAQIAAAAhT25seSBhZG1pbiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uCQAETAAAAAIJAQAAAAxCb29sZWFuRW50cnkAAAACBQAAAAlrZXlBY3RpdmUGCQAETAAAAAIJAQAAAAtEZWxldGVFbnRyeQAAAAEFAAAACGtleUNhdXNlBQAAAANuaWwAAAABAAAAAnR4AQAAAAZ2ZXJpZnkAAAAABAAAABJhZG1pblB1YktleTFTaWduZWQDCQAB9AAAAAMIBQAAAAJ0eAAAAAlib2R5Qnl0ZXMJAAGRAAAAAggFAAAAAnR4AAAABnByb29mcwAAAAAAAAAAAAUAAAAMYWRtaW5QdWJLZXkxAAAAAAAAAAABAAAAAAAAAAAABAAAABJhZG1pblB1YktleTJTaWduZWQDCQAB9AAAAAMIBQAAAAJ0eAAAAAlib2R5Qnl0ZXMJAAGRAAAAAggFAAAAAnR4AAAABnByb29mcwAAAAAAAAAAAQUAAAAMYWRtaW5QdWJLZXkyAAAAAAAAAAABAAAAAAAAAAAABAAAABJhZG1pblB1YktleTNTaWduZWQDCQAB9AAAAAMIBQAAAAJ0eAAAAAlib2R5Qnl0ZXMJAAGRAAAAAggFAAAAAnR4AAAABnByb29mcwAAAAAAAAAAAgUAAAAMYWRtaW5QdWJLZXkzAAAAAAAAAAABAAAAAAAAAAAACQAAZwAAAAIJAABkAAAAAgkAAGQAAAACBQAAABJhZG1pblB1YktleTFTaWduZWQFAAAAEmFkbWluUHViS2V5MlNpZ25lZAUAAAASYWRtaW5QdWJLZXkzU2lnbmVkAAAAAAAAAAAClA6Tmw==", "height": 1766063, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GbznBGgfwacLpZXqqXWdoGfd3AAYrbt9pXZi4BiPhecs Next: 6f1RKAwJURygkYjSvWC9j7N7Akp3qMXEDwoiT7PVw3GK Diff:
Old | New | Differences | |
---|---|---|---|
94 | 94 | else { | |
95 | 95 | let totalENNOLocked = getTotalENNOLocked() | |
96 | 96 | let userENNOLocked = getUserENNOLocked(i.caller) | |
97 | - | if ((withdrawAmount > userENNOLocked)) | |
98 | - | then throw("You are trying to unstake more than you have staked.") | |
99 | - | else { | |
100 | - | let totalENNOLockedNew = (totalENNOLocked - withdrawAmount) | |
101 | - | let userENNOamountNew = (userENNOLocked - withdrawAmount) | |
97 | + | if ((withdrawAmount > totalENNOLocked)) | |
98 | + | then throw("withdrawAmount is more than available to withdraw") | |
99 | + | else if ((withdrawAmount > userENNOLocked)) | |
100 | + | then throw("You are trying to unstake more than you have staked.") | |
101 | + | else { | |
102 | + | let totalENNOLockedNew = (totalENNOLocked - withdrawAmount) | |
103 | + | let userENNOamountNew = (userENNOLocked - withdrawAmount) | |
102 | 104 | [IntegerEntry((toString(i.caller) + keyUserENNOLocked), userENNOamountNew), IntegerEntry(keyTotalENNOLocked, totalENNOLockedNew), ScriptTransfer(i.caller, withdrawAmount, ENNO)] | |
103 | - | } | |
105 | + | } | |
104 | 106 | } | |
105 | 107 | ||
106 | 108 | ||
112 | 114 | let userShare = getCallerShare(i.caller) | |
113 | 115 | let userClaimedAmount = getClaimedAmount(i.caller) | |
114 | 116 | let claimAmount = (userShare - userClaimedAmount) | |
115 | - | if ((0 >= claimAmount)) | |
116 | - | then throw("Claim amount must be bigger than 0") | |
117 | - | else { | |
118 | - | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
117 | + | let totalENNOLocked = getTotalENNOLocked() | |
118 | + | if ((claimAmount > totalENNOLocked)) | |
119 | + | then throw("claimAmount is more than available to withdraw") | |
120 | + | else if ((0 >= claimAmount)) | |
121 | + | then throw("Claim amount must be bigger than 0") | |
122 | + | else { | |
123 | + | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
119 | 124 | [ScriptTransfer(i.caller, claimAmount, ENNO), IntegerEntry((toString(i.caller) + keyUserENNOClaimedAmount), userClaimedAmountNew), IntegerEntry((toString(i.caller) + keyUserENNOLastClaimedAmount), claimAmount)] | |
120 | - | } | |
125 | + | } | |
121 | 126 | } | |
122 | 127 | ||
123 | 128 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let adminPubKey1 = base58'Ese6jz6mtrhgwJWdXbAxHNHg2qzae5D2xXWuVF7tLfs8' | |
5 | 5 | ||
6 | 6 | let adminPubKey2 = base58'Ese6jz6mtrhgwJWdXbAxHNHg2qzae5D2xXWuVF7tLfs8' | |
7 | 7 | ||
8 | 8 | let adminPubKey3 = base58'Ese6jz6mtrhgwJWdXbAxHNHg2qzae5D2xXWuVF7tLfs8' | |
9 | 9 | ||
10 | 10 | let adminPubKeyStartStop = base58'Ese6jz6mtrhgwJWdXbAxHNHg2qzae5D2xXWuVF7tLfs8' | |
11 | 11 | ||
12 | 12 | let keyActive = "active" | |
13 | 13 | ||
14 | 14 | let keyCause = "shutdown_cause" | |
15 | 15 | ||
16 | 16 | let keyUserENNOLocked = "_ENNO_amount" | |
17 | 17 | ||
18 | 18 | let keyTotalENNOLocked = "total_ENNO_amount" | |
19 | 19 | ||
20 | 20 | let keyUserENNOClaimedAmount = "_ENNO_claimed_amount" | |
21 | 21 | ||
22 | 22 | let keyUserENNOLastClaimedAmount = "_ENNO_last_claimed_amount" | |
23 | 23 | ||
24 | 24 | let keyUserENNOLockedTag = "share_" | |
25 | 25 | ||
26 | 26 | let isActive = valueOrElse(getBoolean(this, keyActive), true) | |
27 | 27 | ||
28 | 28 | let shareData = base58'79G9MRTWPsir5gThDeuicpBuQxx8UFNqVaDUYcRfWtPA' | |
29 | 29 | ||
30 | 30 | let ENNO = base58'2Tqhz5PWbkijnzYpdLxLDFfVDw5ALQWm2rmxQ79ooMRZ' | |
31 | 31 | ||
32 | 32 | func suspend (cause) = [BooleanEntry(keyActive, false), StringEntry(keyCause, cause)] | |
33 | 33 | ||
34 | 34 | ||
35 | 35 | func getUserENNOLocked (user) = valueOrElse(getInteger(this, (toString(user) + keyUserENNOLocked)), 0) | |
36 | 36 | ||
37 | 37 | ||
38 | 38 | func getTotalENNOLocked () = valueOrElse(getInteger(this, keyTotalENNOLocked), 0) | |
39 | 39 | ||
40 | 40 | ||
41 | 41 | func getCallerShare (caller) = { | |
42 | 42 | let callerShare = getInteger(addressFromPublicKey(shareData), (keyUserENNOLockedTag + toString(caller))) | |
43 | 43 | let callerShareAmount = match callerShare { | |
44 | 44 | case share: Int => | |
45 | 45 | share | |
46 | 46 | case share: Unit => | |
47 | 47 | throw("Only governance qualifiers can call this function.") | |
48 | 48 | case _ => | |
49 | 49 | throw("Match error") | |
50 | 50 | } | |
51 | 51 | callerShareAmount | |
52 | 52 | } | |
53 | 53 | ||
54 | 54 | ||
55 | 55 | func getClaimedAmount (caller) = { | |
56 | 56 | let callerWithdrawn = getInteger(this, (toString(caller) + keyUserENNOClaimedAmount)) | |
57 | 57 | let callerWithdrawnAmount = match callerWithdrawn { | |
58 | 58 | case share: Int => | |
59 | 59 | share | |
60 | 60 | case share: Unit => | |
61 | 61 | 0 | |
62 | 62 | case _ => | |
63 | 63 | throw("Match error") | |
64 | 64 | } | |
65 | 65 | callerWithdrawnAmount | |
66 | 66 | } | |
67 | 67 | ||
68 | 68 | ||
69 | 69 | @Callable(i) | |
70 | 70 | func lockENNO () = if (!(isActive)) | |
71 | 71 | then throw("DApp is inactive at this moment") | |
72 | 72 | else { | |
73 | 73 | let $t018961971 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
74 | 74 | let pmtAmount = $t018961971._1 | |
75 | 75 | let pmtAssetId = $t018961971._2 | |
76 | 76 | if ((pmtAssetId != ENNO)) | |
77 | 77 | then throw("Incorrect payment assetId only Enno Cash is allowed.") | |
78 | 78 | else { | |
79 | 79 | let userENNOLocked = getUserENNOLocked(i.originCaller) | |
80 | 80 | let userENNOLockedNew = (userENNOLocked + pmtAmount) | |
81 | 81 | let totalENNOLocked = getTotalENNOLocked() | |
82 | 82 | let totalENNOLockedNew = (totalENNOLocked + pmtAmount) | |
83 | 83 | [IntegerEntry((toString(i.originCaller) + keyUserENNOLocked), userENNOLockedNew), IntegerEntry(keyTotalENNOLocked, totalENNOLockedNew)] | |
84 | 84 | } | |
85 | 85 | } | |
86 | 86 | ||
87 | 87 | ||
88 | 88 | ||
89 | 89 | @Callable(i) | |
90 | 90 | func withdrawENNO (withdrawAmount) = if (!(isActive)) | |
91 | 91 | then throw("DApp is inactive at this moment") | |
92 | 92 | else if ((0 >= withdrawAmount)) | |
93 | 93 | then throw("withdrawAmount <= 0") | |
94 | 94 | else { | |
95 | 95 | let totalENNOLocked = getTotalENNOLocked() | |
96 | 96 | let userENNOLocked = getUserENNOLocked(i.caller) | |
97 | - | if ((withdrawAmount > userENNOLocked)) | |
98 | - | then throw("You are trying to unstake more than you have staked.") | |
99 | - | else { | |
100 | - | let totalENNOLockedNew = (totalENNOLocked - withdrawAmount) | |
101 | - | let userENNOamountNew = (userENNOLocked - withdrawAmount) | |
97 | + | if ((withdrawAmount > totalENNOLocked)) | |
98 | + | then throw("withdrawAmount is more than available to withdraw") | |
99 | + | else if ((withdrawAmount > userENNOLocked)) | |
100 | + | then throw("You are trying to unstake more than you have staked.") | |
101 | + | else { | |
102 | + | let totalENNOLockedNew = (totalENNOLocked - withdrawAmount) | |
103 | + | let userENNOamountNew = (userENNOLocked - withdrawAmount) | |
102 | 104 | [IntegerEntry((toString(i.caller) + keyUserENNOLocked), userENNOamountNew), IntegerEntry(keyTotalENNOLocked, totalENNOLockedNew), ScriptTransfer(i.caller, withdrawAmount, ENNO)] | |
103 | - | } | |
105 | + | } | |
104 | 106 | } | |
105 | 107 | ||
106 | 108 | ||
107 | 109 | ||
108 | 110 | @Callable(i) | |
109 | 111 | func claimAndWithdrawENNO () = if (!(isActive)) | |
110 | 112 | then throw("DApp is inactive at this moment") | |
111 | 113 | else { | |
112 | 114 | let userShare = getCallerShare(i.caller) | |
113 | 115 | let userClaimedAmount = getClaimedAmount(i.caller) | |
114 | 116 | let claimAmount = (userShare - userClaimedAmount) | |
115 | - | if ((0 >= claimAmount)) | |
116 | - | then throw("Claim amount must be bigger than 0") | |
117 | - | else { | |
118 | - | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
117 | + | let totalENNOLocked = getTotalENNOLocked() | |
118 | + | if ((claimAmount > totalENNOLocked)) | |
119 | + | then throw("claimAmount is more than available to withdraw") | |
120 | + | else if ((0 >= claimAmount)) | |
121 | + | then throw("Claim amount must be bigger than 0") | |
122 | + | else { | |
123 | + | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
119 | 124 | [ScriptTransfer(i.caller, claimAmount, ENNO), IntegerEntry((toString(i.caller) + keyUserENNOClaimedAmount), userClaimedAmountNew), IntegerEntry((toString(i.caller) + keyUserENNOLastClaimedAmount), claimAmount)] | |
120 | - | } | |
125 | + | } | |
121 | 126 | } | |
122 | 127 | ||
123 | 128 | ||
124 | 129 | ||
125 | 130 | @Callable(i) | |
126 | 131 | func claimAndStakeENNO () = if (!(isActive)) | |
127 | 132 | then throw("DApp is inactive at this moment") | |
128 | 133 | else { | |
129 | 134 | let userShare = getCallerShare(i.caller) | |
130 | 135 | let userClaimedAmount = getClaimedAmount(i.caller) | |
131 | 136 | let claimAmount = (userShare - userClaimedAmount) | |
132 | 137 | if ((0 >= claimAmount)) | |
133 | 138 | then throw("Claim amount must be bigger than 0") | |
134 | 139 | else { | |
135 | 140 | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
136 | 141 | let userENNOLocked = getUserENNOLocked(i.caller) | |
137 | 142 | let userENNOLockedNew = (userENNOLocked + claimAmount) | |
138 | 143 | let totalENNOLocked = getTotalENNOLocked() | |
139 | 144 | let totalENNOLockedNew = (totalENNOLocked + claimAmount) | |
140 | 145 | [IntegerEntry((toString(i.caller) + keyUserENNOLocked), userENNOLockedNew), IntegerEntry(keyTotalENNOLocked, totalENNOLockedNew)] | |
141 | 146 | } | |
142 | 147 | } | |
143 | 148 | ||
144 | 149 | ||
145 | 150 | ||
146 | 151 | @Callable(i) | |
147 | 152 | func shutdown () = if (!(isActive)) | |
148 | 153 | then throw(("DApp is already suspended. Cause: " + valueOrElse(getString(this, keyCause), "the cause wasn't specified"))) | |
149 | 154 | else if (!(containsElement([adminPubKey1, adminPubKey2, adminPubKey3, adminPubKeyStartStop], i.callerPublicKey))) | |
150 | 155 | then throw("Only admin can call this function") | |
151 | 156 | else suspend("Paused by admin") | |
152 | 157 | ||
153 | 158 | ||
154 | 159 | ||
155 | 160 | @Callable(i) | |
156 | 161 | func activate () = if (isActive) | |
157 | 162 | then throw("DApp is already active") | |
158 | 163 | else if (!(containsElement([adminPubKey1, adminPubKey2, adminPubKey3, adminPubKeyStartStop], i.callerPublicKey))) | |
159 | 164 | then throw("Only admin can call this function") | |
160 | 165 | else [BooleanEntry(keyActive, true), DeleteEntry(keyCause)] | |
161 | 166 | ||
162 | 167 | ||
163 | 168 | @Verifier(tx) | |
164 | 169 | func verify () = { | |
165 | 170 | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1)) | |
166 | 171 | then 1 | |
167 | 172 | else 0 | |
168 | 173 | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2)) | |
169 | 174 | then 1 | |
170 | 175 | else 0 | |
171 | 176 | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3)) | |
172 | 177 | then 1 | |
173 | 178 | else 0 | |
174 | 179 | (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2) | |
175 | 180 | } | |
176 | 181 |
github/deemru/w8io/169f3d6 41.10 ms ◑![]()