tx · uMmrNjeJg6ckA2anUDeeAtVt6a5ivW4EBdkFZVHz8Pn

3N8WxMD723WNbLNF6xhbBw2Nmq5mwtYdAwq:  -0.02000000 Waves

2020.11.30 11:48 [1287938] smart account 3N8WxMD723WNbLNF6xhbBw2Nmq5mwtYdAwq > SELF 0.00000000 Waves

{ "type": 13, "id": "uMmrNjeJg6ckA2anUDeeAtVt6a5ivW4EBdkFZVHz8Pn", "fee": 2000000, "feeAssetId": null, "timestamp": 1606726161201, "version": 1, "sender": "3N8WxMD723WNbLNF6xhbBw2Nmq5mwtYdAwq", "senderPublicKey": "9DNsZT846MHG4j3B7Kmm2SqLP9jXQSYQ24HSnvaqrBWB", "proofs": [ "5fAg7W666G1TkZD2fzxWsTL96uYY35CtHT1krToxyxS4UnwEqfagL2VAdrXNGK6xsWU8EQig9jMg7N7TY7DukQ2L", "ZE1e2EL7CvTyJb2g5mFuYbWfJ223VN5sEh7CqfPmpTe5bu8RKEmiwXZnmgDysdRFPP2NmPcfzjLx2hrWBZYc5h2", "5DJtyqmYuhMjX6BmGKYaNKNLpkw5CAU9WMrFjPpCaqnNRn8gdTGspDF52unxQGRFzCxHwtUiXQezBYLHTxxagFKt" ], "script": "base64:AAIEAAAAAAAAAB4IAhIECgIIARIAEgQKAggBEgASBAoCAQgSBAoCAQgAAAAiAQAAAA5nZXROdW1iZXJCeUtleQAAAAEAAAADa2V5CQEAAAALdmFsdWVPckVsc2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAAA2tleQAAAAAAAAAAAAEAAAAOZ2V0U3RyaW5nQnlLZXkAAAABAAAAA2tleQkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkABB0AAAACBQAAAAR0aGlzBQAAAANrZXkCAAAAAAEAAAAMZ2V0Qm9vbEJ5S2V5AAAAAQAAAANrZXkJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQbAAAAAgUAAAAEdGhpcwUAAAADa2V5BwEAAAAYZ2V0TnVtYmVyQnlBZGRyZXNzQW5kS2V5AAAAAgAAAAdhZGRyZXNzAAAAA2tleQkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkABBoAAAACCQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABBQAAAAdhZGRyZXNzBQAAAANrZXkAAAAAAAAAAAABAAAAGGdldFN0cmluZ0J5QWRkcmVzc0FuZEtleQAAAAIAAAAHYWRkcmVzcwAAAANrZXkJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQdAAAAAgUAAAAHYWRkcmVzcwUAAAADa2V5AgAAAAAAAAAAEk5ldXRyaW5vQXNzZXRJZEtleQIAAAARbmV1dHJpbm9fYXNzZXRfaWQAAAAAE05ldXRyaW5vQ29udHJhY3RLZXkCAAAAEW5ldXRyaW5vX2NvbnRyYWN0AAAAAApCYWxhbmNlS2V5AgAAAAtycGRfYmFsYW5jZQAAAAASQ29udHJvbENvbnRyYWN0S2V5AgAAABBjb250cm9sX2NvbnRyYWN0AAAAAA5Oc2J0QXNzZXRJZEtleQIAAAANYm9uZF9hc3NldF9pZAAAAAAJQWRtaW5zS2V5AgAAAAZhZG1pbnMAAAAACFVTRE5UWVBFAgAAAARVU0ROAAAAAAhOU0JUVFlQRQIAAAAETlNCVAEAAAARZ2V0VXNlckJhbGFuY2VLZXkAAAACAAAABW93bmVyAAAAB2Fzc2V0SWQJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgUAAAAKQmFsYW5jZUtleQIAAAABXwUAAAAHYXNzZXRJZAIAAAABXwUAAAAFb3duZXIBAAAAFWdldENvbnRyYWN0QmFsYW5jZUtleQAAAAEAAAAHYXNzZXRJZAkAASwAAAACCQABLAAAAAIFAAAACkJhbGFuY2VLZXkCAAAAAV8FAAAAB2Fzc2V0SWQBAAAAFGdldEV4cGlyZVByb3Bvc2FsS2V5AAAAAQAAAARoYXNoCQABLAAAAAIJAAEsAAAAAgIAAAAPcHJvcG9zYWxfZXhwaXJlAgAAAAFfBQAAAARoYXNoAQAAABNnZXRPd25lclByb3Bvc2FsS2V5AAAAAQAAAARoYXNoCQABLAAAAAIJAAEsAAAAAgIAAAAOcHJvcG9zYWxfb3duZXICAAAAAV8FAAAABGhhc2gBAAAAF2dldEFyZ3VtZW50c1Byb3Bvc2FsS2V5AAAAAQAAAARoYXNoCQABLAAAAAIJAAEsAAAAAgIAAAAScHJvcG9zYWxfYXJndW1lbnRzAgAAAAFfBQAAAARoYXNoAQAAAApnZXRWb3RlS2V5AAAAAgAAAAVvd25lcgAAAARoYXNoCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAICAAAADXByb3Bvc2FsX3ZvdGUCAAAAAV8FAAAABW93bmVyAgAAAAFfBQAAAARoYXNoAQAAABZjb252ZXJ0SnNvbkFycmF5VG9MaXN0AAAAAQAAAAlqc29uQXJyYXkJAAS1AAAAAgUAAAAJanNvbkFycmF5AgAAAAEsAAAAABBuZXV0cmlub0NvbnRyYWN0CQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABCQEAAAAOZ2V0U3RyaW5nQnlLZXkAAAABBQAAABNOZXV0cmlub0NvbnRyYWN0S2V5AAAAAA9jb250cm9sQ29udHJhY3QJAQAAABFAZXh0ck5hdGl2ZSgxMDYyKQAAAAEJAQAAABhnZXRTdHJpbmdCeUFkZHJlc3NBbmRLZXkAAAACBQAAABBuZXV0cmlub0NvbnRyYWN0BQAAABJDb250cm9sQ29udHJhY3RLZXkAAAAAD25ldXRyaW5vQXNzZXRJZAkAAlkAAAABCQEAAAAYZ2V0U3RyaW5nQnlBZGRyZXNzQW5kS2V5AAAAAgUAAAAQbmV1dHJpbm9Db250cmFjdAUAAAASTmV1dHJpbm9Bc3NldElkS2V5AAAAAA5uc2J0QXNzZXRJZFN0cgkBAAAAGGdldFN0cmluZ0J5QWRkcmVzc0FuZEtleQAAAAIFAAAAEG5ldXRyaW5vQ29udHJhY3QFAAAADk5zYnRBc3NldElkS2V5AAAAAAtuc2J0QXNzZXRJZAkAAlkAAAABBQAAAA5uc2J0QXNzZXRJZFN0cgEAAAASZ2V0Q29udHJhY3RCYWxhbmNlAAAAAQAAAAdhc3NldElkCQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABCQEAAAAVZ2V0Q29udHJhY3RCYWxhbmNlS2V5AAAAAQUAAAAHYXNzZXRJZAEAAAAOZ2V0VXNlckJhbGFuY2UAAAACAAAABW93bmVyAAAAB2Fzc2V0SWQJAQAAAA5nZXROdW1iZXJCeUtleQAAAAEJAQAAABFnZXRVc2VyQmFsYW5jZUtleQAAAAIFAAAABW93bmVyBQAAAAdhc3NldElkAQAAABNnZXRSZXdhcmRzQ29uZmlnS2V5AAAAAwAAAAVvd25lcgAAAAVzaGFyZQAAAAhyZWNlaXZlcgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAICAAAADnN0YWtpbmdjb25maWdfBQAAAAVvd25lcgIAAAABXwkAAaQAAAABBQAAAAVzaGFyZQIAAAABXwUAAAAIcmVjZWl2ZXIBAAAAGmdldEN1cnJlbnRSZXdhcmRzQ29uZmlnS2V5AAAAAQAAAAVvd25lcgkAASwAAAACAgAAABZzdGFraW5nY29uZmlnX2N1cnJlbnRfBQAAAAVvd25lcgEAAAAYZ2V0UmV3YXJkc0NvbmZpZ1N0YXJ0S2V5AAAAAgAAAAljb25maWdLZXkAAAAHaXNTdGFydAkAASwAAAACBQAAAAljb25maWdLZXkDBQAAAAdpc1N0YXJ0AgAAAAZfc3RhcnQCAAAABF9lbmQBAAAAG2dldFJld2FyZENvbmZpZ0luaXRpYWxTaGFyZQAAAAEAAAAFb3duZXIJAAEsAAAAAgUAAAAFb3duZXICAAAADV9pbml0aWFsU2hhcmUBAAAAGmdldFZhbGlkU3Rha2luZ0Fzc2V0T3JGYWlsAAAAAgAAAAtzdGFraW5nVHlwZQAAAAdhc3NldElkAwMJAAAAAAAAAgUAAAALc3Rha2luZ1R5cGUFAAAACFVTRE5UWVBFCQEAAAACIT0AAAACBQAAAAdhc3NldElkBQAAAA9uZXV0cmlub0Fzc2V0SWQHCQAAAgAAAAECAAAAEWNhbiB1c2UgVVNETiBvbmx5AwMJAAAAAAAAAgUAAAALc3Rha2luZ1R5cGUFAAAACE5TQlRUWVBFCQEAAAACIT0AAAACBQAAAAdhc3NldElkBQAAAAtuc2J0QXNzZXRJZAcJAAACAAAAAQIAAAARY2FuIHVzZSBOU0JUIG9ubHkDAwkBAAAAAiE9AAAAAgUAAAALc3Rha2luZ1R5cGUFAAAACFVTRE5UWVBFCQEAAAACIT0AAAACBQAAAAtzdGFraW5nVHlwZQUAAAAITlNCVFRZUEUHCQAAAgAAAAEJAAEsAAAAAgIAAAAZdW5zdXBwb3J0ZWQgc3Rha2luZyB0eXBlIAUAAAALc3Rha2luZ1R5cGUFAAAAB2Fzc2V0SWQBAAAAFGludGVybmFsTG9ja05ldXRyaW5vAAAABAAAAAtzdGFraW5nVHlwZQAAAAFpAAAACHJlY2VpdmVyAAAABXNoYXJlBAAAAANwbXQJAQAAAAV2YWx1ZQAAAAEJAAGRAAAAAggFAAAAAWkAAAAIcGF5bWVudHMAAAAAAAAAAAAEAAAAB2Fzc2V0SWQJAQAAABpnZXRWYWxpZFN0YWtpbmdBc3NldE9yRmFpbAAAAAIFAAAAC3N0YWtpbmdUeXBlCQEAAAAFdmFsdWUAAAABCAUAAAADcG10AAAAB2Fzc2V0SWQDCQEAAAABIQAAAAEJAQAAAAlpc0RlZmluZWQAAAABCQAEJgAAAAEFAAAACHJlY2VpdmVyCQAAAgAAAAEJAAEsAAAAAgIAAAAXSW52YWxpZCBhZGRyZXNzIGZvcm1hdCAFAAAACHJlY2VpdmVyAwkAAGYAAAACBQAAAAVzaGFyZQAAAAAAAAAAZAkAAAIAAAABAgAAADBzdGFraW5nIHJld2FyZHMgc2hhcmUgY2Fubm90IGJlIGhpZ2hlciB0aGFuIDEwMCUDCQAAZgAAAAIAAAAAAAAAAAEFAAAABXNoYXJlCQAAAgAAAAECAAAALXN0YWtpbmcgcmV3YXJkcyBzaGFyZSBjYW5ub3QgYmUgbG93ZXIgdGhhbiAxJQQAAAAHYWNjb3VudAkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIEAAAADWFzc2V0SWRTdHJpbmcJAAJYAAAAAQUAAAAHYXNzZXRJZAQAAAANY3VycmVudENvbmZpZwkBAAAADmdldFN0cmluZ0J5S2V5AAAAAQkBAAAAGmdldEN1cnJlbnRSZXdhcmRzQ29uZmlnS2V5AAAAAQUAAAAHYWNjb3VudAQAAAALY29ycmVjdERhdGEDCQEAAAACIT0AAAACBQAAAA1jdXJyZW50Q29uZmlnAgAAAAAEAAAAEWN1cnJlbnRDb25maWdEYXRhCQAEtQAAAAIFAAAADWN1cnJlbnRDb25maWcCAAAAAV8EAAAACWN1cnJTaGFyZQkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAAEWN1cnJlbnRDb25maWdEYXRhAAAAAAAAAAACBAAAAAxjdXJyUmVjZWl2ZXIJAAGRAAAAAgUAAAARY3VycmVudENvbmZpZ0RhdGEAAAAAAAAAAAMEAAAAF25vdE1pZ3JhdGVkSW5pdGlhbFNoYXJlCQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABCQEAAAAbZ2V0UmV3YXJkQ29uZmlnSW5pdGlhbFNoYXJlAAAAAQUAAAAHYWNjb3VudAQAAAASYWN0dWFsSW5pdGlhbFNoYXJlAwkAAAAAAAACBQAAABdub3RNaWdyYXRlZEluaXRpYWxTaGFyZQAAAAAAAAAAAAUAAAAJY3VyclNoYXJlBQAAABdub3RNaWdyYXRlZEluaXRpYWxTaGFyZQQAAAAIbmV3U2hhcmUDAwkAAGYAAAACBQAAABJhY3R1YWxJbml0aWFsU2hhcmUFAAAABXNoYXJlBgkBAAAAAiE9AAAAAgUAAAAMY3VyclJlY2VpdmVyBQAAAAhyZWNlaXZlcgUAAAASYWN0dWFsSW5pdGlhbFNoYXJlBQAAAAVzaGFyZQkABEwAAAACCQABpAAAAAEFAAAAEmFjdHVhbEluaXRpYWxTaGFyZQkABEwAAAACCQABpAAAAAEFAAAACG5ld1NoYXJlCQAETAAAAAIFAAAADGN1cnJSZWNlaXZlcgUAAAADbmlsCQAETAAAAAIJAAGkAAAAAQUAAAAFc2hhcmUJAARMAAAAAgkAAaQAAAABBQAAAAVzaGFyZQkABEwAAAACBQAAAAhyZWNlaXZlcgUAAAADbmlsBAAAABNjb3JyZWN0SW5pdGlhbFNoYXJlCQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAALY29ycmVjdERhdGEAAAAAAAAAAAAEAAAADGNvcnJlY3RTaGFyZQkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAAC2NvcnJlY3REYXRhAAAAAAAAAAABBAAAAA9jb3JyZWN0UmVjZWl2ZXIJAAGRAAAAAgUAAAALY29ycmVjdERhdGEAAAAAAAAAAAIEAAAAEG5ld0N1cnJlbnRDb25maWcJAQAAABNnZXRSZXdhcmRzQ29uZmlnS2V5AAAAAwUAAAAHYWNjb3VudAUAAAAMY29ycmVjdFNoYXJlBQAAAA9jb3JyZWN0UmVjZWl2ZXIEAAAAC2lzTmV3Q29uZmlnCQEAAAABIQAAAAEJAAAAAAAAAgUAAAANY3VycmVudENvbmZpZwUAAAAQbmV3Q3VycmVudENvbmZpZwQAAAADZW5kAwUAAAALaXNOZXdDb25maWcFAAAABmhlaWdodAAAAAAAAAAAAAQAAAAFc3RhcnQDBQAAAAtpc05ld0NvbmZpZwUAAAAGaGVpZ2h0CQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABCQEAAAAYZ2V0UmV3YXJkc0NvbmZpZ1N0YXJ0S2V5AAAAAgUAAAAQbmV3Q3VycmVudENvbmZpZwYJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAQAAABVnZXRDb250cmFjdEJhbGFuY2VLZXkAAAABBQAAAA1hc3NldElkU3RyaW5nCQAAZAAAAAIJAQAAABJnZXRDb250cmFjdEJhbGFuY2UAAAABBQAAAA1hc3NldElkU3RyaW5nCAUAAAADcG10AAAABmFtb3VudAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAEWdldFVzZXJCYWxhbmNlS2V5AAAAAgUAAAAHYWNjb3VudAUAAAANYXNzZXRJZFN0cmluZwkAAGQAAAACCQEAAAAOZ2V0VXNlckJhbGFuY2UAAAACBQAAAAdhY2NvdW50BQAAAA1hc3NldElkU3RyaW5nCAUAAAADcG10AAAABmFtb3VudAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAGGdldFJld2FyZHNDb25maWdTdGFydEtleQAAAAIFAAAADWN1cnJlbnRDb25maWcHBQAAAANlbmQJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAQAAABhnZXRSZXdhcmRzQ29uZmlnU3RhcnRLZXkAAAACBQAAABBuZXdDdXJyZW50Q29uZmlnBgUAAAAFc3RhcnQJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAQAAABtnZXRSZXdhcmRDb25maWdJbml0aWFsU2hhcmUAAAABBQAAAAdhY2NvdW50BQAAABNjb3JyZWN0SW5pdGlhbFNoYXJlCQAETAAAAAIJAQAAAAtTdHJpbmdFbnRyeQAAAAIJAQAAABpnZXRDdXJyZW50UmV3YXJkc0NvbmZpZ0tleQAAAAEFAAAAB2FjY291bnQFAAAAEG5ld0N1cnJlbnRDb25maWcFAAAAA25pbAEAAAAOaW50ZXJuYWxVbmxvY2sAAAAEAAAAC3N0YWtpbmdUeXBlAAAAAWkAAAAMdW5sb2NrQW1vdW50AAAADGFzc2V0SWRQYXJhbQQAAAAHYWNjb3VudAkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIEAAAAB2Fzc2V0SWQJAQAAABpnZXRWYWxpZFN0YWtpbmdBc3NldE9yRmFpbAAAAAIFAAAAC3N0YWtpbmdUeXBlCQACWQAAAAEFAAAADGFzc2V0SWRQYXJhbQQAAAANYXNzZXRJZFN0cmluZwkAAlgAAAABBQAAAAdhc3NldElkBAAAAAdiYWxhbmNlCQAAZQAAAAIJAQAAAA5nZXRVc2VyQmFsYW5jZQAAAAIFAAAAB2FjY291bnQFAAAADWFzc2V0SWRTdHJpbmcFAAAADHVubG9ja0Ftb3VudAMJAABnAAAAAgAAAAAAAAAAAAUAAAAHYmFsYW5jZQkAAAIAAAABAgAAAA5pbnZhbGlkIGFtb3VudAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAFWdldENvbnRyYWN0QmFsYW5jZUtleQAAAAEFAAAADWFzc2V0SWRTdHJpbmcJAABlAAAAAgkBAAAAEmdldENvbnRyYWN0QmFsYW5jZQAAAAEFAAAADWFzc2V0SWRTdHJpbmcFAAAADHVubG9ja0Ftb3VudAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAEWdldFVzZXJCYWxhbmNlS2V5AAAAAgUAAAAHYWNjb3VudAUAAAANYXNzZXRJZFN0cmluZwUAAAAHYmFsYW5jZQkABEwAAAACCQEAAAAOU2NyaXB0VHJhbnNmZXIAAAADCQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABBQAAAAdhY2NvdW50BQAAAAx1bmxvY2tBbW91bnQFAAAAB2Fzc2V0SWQFAAAAA25pbAAAAAYAAAABaQEAAAAObG9ja05ldXRyaW5vU1AAAAACAAAACHJlY2VpdmVyAAAABXNoYXJlCQEAAAAUaW50ZXJuYWxMb2NrTmV1dHJpbm8AAAAEBQAAAAhVU0ROVFlQRQUAAAABaQUAAAAIcmVjZWl2ZXIFAAAABXNoYXJlAAAAAWkBAAAADGxvY2tOZXV0cmlubwAAAAAJAQAAABRpbnRlcm5hbExvY2tOZXV0cmlubwAAAAQFAAAACFVTRE5UWVBFBQAAAAFpCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgAAAAAAAAAAZAAAAAFpAQAAAApsb2NrTnNidFNQAAAAAgAAAAhyZWNlaXZlcgAAAAVzaGFyZQkBAAAAFGludGVybmFsTG9ja05ldXRyaW5vAAAABAUAAAAITlNCVFRZUEUFAAAAAWkFAAAACHJlY2VpdmVyBQAAAAVzaGFyZQAAAAFpAQAAAAhsb2NrTnNidAAAAAAJAQAAABRpbnRlcm5hbExvY2tOZXV0cmlubwAAAAQFAAAACE5TQlRUWVBFBQAAAAFpCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgAAAAAAAAAAZAAAAAFpAQAAAA51bmxvY2tOZXV0cmlubwAAAAIAAAAMdW5sb2NrQW1vdW50AAAADWFzc2V0SWRTdHJpbmcJAQAAAA5pbnRlcm5hbFVubG9jawAAAAQFAAAACFVTRE5UWVBFBQAAAAFpBQAAAAx1bmxvY2tBbW91bnQFAAAADWFzc2V0SWRTdHJpbmcAAAABaQEAAAAKdW5sb2NrTnNidAAAAAIAAAAMdW5sb2NrQW1vdW50AAAADWFzc2V0SWRTdHJpbmcJAQAAAA5pbnRlcm5hbFVubG9jawAAAAQFAAAACE5TQlRUWVBFBQAAAAFpBQAAAAx1bmxvY2tBbW91bnQFAAAADWFzc2V0SWRTdHJpbmcAAAABAAAAAnR4AQAAAAZ2ZXJpZnkAAAAABAAAABBwdWJLZXlBZG1pbnNMaXN0CQAETAAAAAICAAAALEdYeG1aYUNpZ1BnSnNUNmQxY0xyOG5VWEE2NW5HWDhWN0Z1QXp6clk4d1FFCQAETAAAAAICAAAALDN4dW14NGhyUHBlZW9vNzlITEdiWkNnZno5NUwzOVpGZHh4d1dlU1VDMlB1CQAETAAAAAICAAAALEQ0Q3F0SzVmQnNuelJvMzNaTWhyTTduaUxzZURIMnVSb0s2d2VCcTJKUTNBCQAETAAAAAICAAAALDVXUlhGU2p3Y1RiTmZLY0pzOFpxWG1TU1dZc1NWSlV0TXZNcVpqNWhINE5jBQAAAANuaWwEAAAABWNvdW50CQAAZAAAAAIJAABkAAAAAgkAAGQAAAACAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAAJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAEJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAABAAAAAAAAAAABAAAAAAAAAAAAAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAIJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAACAAAAAAAAAAABAAAAAAAAAAAAAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAMJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAADAAAAAAAAAAACAAAAAAAAAAAACQAAZwAAAAIFAAAABWNvdW50AAAAAAAAAAADuKg7Dg==", "chainId": 84, "height": 1287938, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Fh5fKNodeoLXetthR3tF65bzzduz2NdnPVXRyhyLeEyD Next: 643hiLGhHVvypPUjPaZDfnScYcjq2TNnzMZ4kouGtJ9M Diff:
OldNewDifferences
2727 let NsbtAssetIdKey = "bond_asset_id"
2828
2929 let AdminsKey = "admins"
30+
31+let USDNTYPE = "USDN"
32+
33+let NSBTTYPE = "NSBT"
3034
3135 func getUserBalanceKey (owner,assetId) = ((((BalanceKey + "_") + assetId) + "_") + owner)
3236
6569 func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId))
6670
6771
68-func getExpireProposal (hash) = getNumberByKey(getExpireProposalKey(hash))
69-
70-
71-func getOwnerProposal (hash) = getStringByKey(getOwnerProposalKey(hash))
72-
73-
74-func getArgumentsProposal (hash) = getStringByKey(getArgumentsProposalKey(hash))
75-
76-
77-func getVote (owner,hash) = getStringByKey(getVoteKey(owner, hash))
78-
79-
8072 func getRewardsConfigKey (owner,share,receiver) = ((((("stakingconfig_" + owner) + "_") + toString(share)) + "_") + receiver)
8173
8274
9183 func getRewardConfigInitialShare (owner) = (owner + "_initialShare")
9284
9385
94-func internallockNeutrino (i,receiver,share) = {
86+func getValidStakingAssetOrFail (stakingType,assetId) = if (if ((stakingType == USDNTYPE))
87+ then (assetId != neutrinoAssetId)
88+ else false)
89+ then throw("can use USDN only")
90+ else if (if ((stakingType == NSBTTYPE))
91+ then (assetId != nsbtAssetId)
92+ else false)
93+ then throw("can use NSBT only")
94+ else if (if ((stakingType != USDNTYPE))
95+ then (stakingType != NSBTTYPE)
96+ else false)
97+ then throw(("unsupported staking type " + stakingType))
98+ else assetId
99+
100+
101+func internalLockNeutrino (stakingType,i,receiver,share) = {
95102 let pmt = value(i.payments[0])
103+ let assetId = getValidStakingAssetOrFail(stakingType, value(pmt.assetId))
96104 if (!(isDefined(addressFromString(receiver))))
97105 then throw(("Invalid address format " + receiver))
98- else if (if ((pmt.assetId != neutrinoAssetId))
99- then (pmt.assetId != nsbtAssetId)
100- else false)
101- then throw("can use USDN or NSBT only")
102- else if ((share > 100))
103- then throw("staking rewards share cannot be higher than 100%")
104- else if ((1 > share))
105- then throw("staking rewards share cannot be lower than 1%")
106- else {
107- let account = toString(i.caller)
108- let assetIdString = toBase58String(value(pmt.assetId))
109- let currentConfig = getStringByKey(getCurrentRewardsConfigKey(account))
110- let correctData = if ((currentConfig != ""))
111- then {
112- let currentConfigData = split(currentConfig, "_")
113- let currShare = parseIntValue(currentConfigData[2])
114- let currReceiver = currentConfigData[3]
115- let notMigratedInitialShare = getNumberByKey(getRewardConfigInitialShare(account))
116- let actualInitialShare = if ((notMigratedInitialShare == 0))
117- then currShare
118- else notMigratedInitialShare
119- let newShare = if (if ((actualInitialShare > share))
120- then true
121- else (currReceiver != receiver))
122- then actualInitialShare
123- else share
106+ else if ((share > 100))
107+ then throw("staking rewards share cannot be higher than 100%")
108+ else if ((1 > share))
109+ then throw("staking rewards share cannot be lower than 1%")
110+ else {
111+ let account = toString(i.caller)
112+ let assetIdString = toBase58String(assetId)
113+ let currentConfig = getStringByKey(getCurrentRewardsConfigKey(account))
114+ let correctData = if ((currentConfig != ""))
115+ then {
116+ let currentConfigData = split(currentConfig, "_")
117+ let currShare = parseIntValue(currentConfigData[2])
118+ let currReceiver = currentConfigData[3]
119+ let notMigratedInitialShare = getNumberByKey(getRewardConfigInitialShare(account))
120+ let actualInitialShare = if ((notMigratedInitialShare == 0))
121+ then currShare
122+ else notMigratedInitialShare
123+ let newShare = if (if ((actualInitialShare > share))
124+ then true
125+ else (currReceiver != receiver))
126+ then actualInitialShare
127+ else share
124128 [toString(actualInitialShare), toString(newShare), currReceiver]
125- }
126- else [toString(share), toString(share), receiver]
127- let correctInitialShare = parseIntValue(correctData[0])
128- let correctShare = parseIntValue(correctData[1])
129- let correctReceiver = correctData[2]
130- let newCurrentConfig = getRewardsConfigKey(account, correctShare, correctReceiver)
131- let isNewConfig = !((currentConfig == newCurrentConfig))
132- let end = if (isNewConfig)
133- then height
134- else 0
135- let start = if (isNewConfig)
136- then height
137- else getNumberByKey(getRewardsConfigStartKey(newCurrentConfig, true))
129+ }
130+ else [toString(share), toString(share), receiver]
131+ let correctInitialShare = parseIntValue(correctData[0])
132+ let correctShare = parseIntValue(correctData[1])
133+ let correctReceiver = correctData[2]
134+ let newCurrentConfig = getRewardsConfigKey(account, correctShare, correctReceiver)
135+ let isNewConfig = !((currentConfig == newCurrentConfig))
136+ let end = if (isNewConfig)
137+ then height
138+ else 0
139+ let start = if (isNewConfig)
140+ then height
141+ else getNumberByKey(getRewardsConfigStartKey(newCurrentConfig, true))
138142 [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) + pmt.amount)), IntegerEntry(getUserBalanceKey(account, assetIdString), (getUserBalance(account, assetIdString) + pmt.amount)), IntegerEntry(getRewardsConfigStartKey(currentConfig, false), end), IntegerEntry(getRewardsConfigStartKey(newCurrentConfig, true), start), IntegerEntry(getRewardConfigInitialShare(account), correctInitialShare), StringEntry(getCurrentRewardsConfigKey(account), newCurrentConfig)]
139- }
143+ }
144+ }
145+
146+
147+func internalUnlock (stakingType,i,unlockAmount,assetIdParam) = {
148+ let account = toString(i.caller)
149+ let assetId = getValidStakingAssetOrFail(stakingType, fromBase58String(assetIdParam))
150+ let assetIdString = toBase58String(assetId)
151+ let balance = (getUserBalance(account, assetIdString) - unlockAmount)
152+ if ((0 >= balance))
153+ then throw("invalid amount")
154+ else [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, assetId)]
140155 }
141156
142157
143158 @Callable(i)
144-func lockNeutrinoSP (receiver,share) = internallockNeutrino(i, receiver, share)
159+func lockNeutrinoSP (receiver,share) = internalLockNeutrino(USDNTYPE, i, receiver, share)
145160
146161
147162
148163 @Callable(i)
149-func lockNeutrino () = internallockNeutrino(i, toString(i.caller), 100)
164+func lockNeutrino () = internalLockNeutrino(USDNTYPE, i, toString(i.caller), 100)
150165
151166
152167
153168 @Callable(i)
154-func unlockNeutrino (unlockAmount,assetIdString) = {
155- let account = toString(i.caller)
156- let assetId = fromBase58String(assetIdString)
157- let balance = (getUserBalance(account, assetIdString) - unlockAmount)
158- if ((0 > balance))
159- then throw("invalid amount")
160- else if ((assetId != neutrinoAssetId))
161- then throw("can use neutrino")
162- else [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, neutrinoAssetId)]
163- }
169+func lockNsbtSP (receiver,share) = internalLockNeutrino(NSBTTYPE, i, receiver, share)
164170
165171
166172
167173 @Callable(i)
168-func vote (hash,indexArgument) = {
169- let arguments = split(getArgumentsProposal(hash), ",")
170- let argument = arguments[indexArgument]
171- if ((height > getExpireProposal(hash)))
172- then throw("proposal is expired")
173- else [StringEntry(getVoteKey(toString(i.caller), hash), argument)]
174- }
174+func lockNsbt () = internalLockNeutrino(NSBTTYPE, i, toString(i.caller), 100)
175175
176176
177177
178178 @Callable(i)
179-func createProposal (arguments,expairHeight) = {
180- let hash = toBase58String(keccak256(((toBytes(arguments) + toBytes(expairHeight)) + i.callerPublicKey)))
181- if ((getOwnerProposal(hash) != ""))
182- then throw("proposal is exist")
183- else [IntegerEntry(getExpireProposalKey(hash), expairHeight), StringEntry(getOwnerProposalKey(hash), toString(i.caller)), StringEntry(getArgumentsProposalKey(hash), arguments)]
184- }
179+func unlockNeutrino (unlockAmount,assetIdString) = internalUnlock(USDNTYPE, i, unlockAmount, assetIdString)
180+
181+
182+
183+@Callable(i)
184+func unlockNsbt (unlockAmount,assetIdString) = internalUnlock(NSBTTYPE, i, unlockAmount, assetIdString)
185185
186186
187187 @Verifier(tx)
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 4 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func getNumberByKey (key) = valueOrElse(getInteger(this, key), 0)
55
66
77 func getStringByKey (key) = valueOrElse(getString(this, key), "")
88
99
1010 func getBoolByKey (key) = valueOrElse(getBoolean(this, key), false)
1111
1212
1313 func getNumberByAddressAndKey (address,key) = valueOrElse(getInteger(addressFromStringValue(address), key), 0)
1414
1515
1616 func getStringByAddressAndKey (address,key) = valueOrElse(getString(address, key), "")
1717
1818
1919 let NeutrinoAssetIdKey = "neutrino_asset_id"
2020
2121 let NeutrinoContractKey = "neutrino_contract"
2222
2323 let BalanceKey = "rpd_balance"
2424
2525 let ControlContractKey = "control_contract"
2626
2727 let NsbtAssetIdKey = "bond_asset_id"
2828
2929 let AdminsKey = "admins"
30+
31+let USDNTYPE = "USDN"
32+
33+let NSBTTYPE = "NSBT"
3034
3135 func getUserBalanceKey (owner,assetId) = ((((BalanceKey + "_") + assetId) + "_") + owner)
3236
3337
3438 func getContractBalanceKey (assetId) = ((BalanceKey + "_") + assetId)
3539
3640
3741 func getExpireProposalKey (hash) = (("proposal_expire" + "_") + hash)
3842
3943
4044 func getOwnerProposalKey (hash) = (("proposal_owner" + "_") + hash)
4145
4246
4347 func getArgumentsProposalKey (hash) = (("proposal_arguments" + "_") + hash)
4448
4549
4650 func getVoteKey (owner,hash) = (((("proposal_vote" + "_") + owner) + "_") + hash)
4751
4852
4953 func convertJsonArrayToList (jsonArray) = split(jsonArray, ",")
5054
5155
5256 let neutrinoContract = addressFromStringValue(getStringByKey(NeutrinoContractKey))
5357
5458 let controlContract = addressFromStringValue(getStringByAddressAndKey(neutrinoContract, ControlContractKey))
5559
5660 let neutrinoAssetId = fromBase58String(getStringByAddressAndKey(neutrinoContract, NeutrinoAssetIdKey))
5761
5862 let nsbtAssetIdStr = getStringByAddressAndKey(neutrinoContract, NsbtAssetIdKey)
5963
6064 let nsbtAssetId = fromBase58String(nsbtAssetIdStr)
6165
6266 func getContractBalance (assetId) = getNumberByKey(getContractBalanceKey(assetId))
6367
6468
6569 func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId))
6670
6771
68-func getExpireProposal (hash) = getNumberByKey(getExpireProposalKey(hash))
69-
70-
71-func getOwnerProposal (hash) = getStringByKey(getOwnerProposalKey(hash))
72-
73-
74-func getArgumentsProposal (hash) = getStringByKey(getArgumentsProposalKey(hash))
75-
76-
77-func getVote (owner,hash) = getStringByKey(getVoteKey(owner, hash))
78-
79-
8072 func getRewardsConfigKey (owner,share,receiver) = ((((("stakingconfig_" + owner) + "_") + toString(share)) + "_") + receiver)
8173
8274
8375 func getCurrentRewardsConfigKey (owner) = ("stakingconfig_current_" + owner)
8476
8577
8678 func getRewardsConfigStartKey (configKey,isStart) = (configKey + (if (isStart)
8779 then "_start"
8880 else "_end"))
8981
9082
9183 func getRewardConfigInitialShare (owner) = (owner + "_initialShare")
9284
9385
94-func internallockNeutrino (i,receiver,share) = {
86+func getValidStakingAssetOrFail (stakingType,assetId) = if (if ((stakingType == USDNTYPE))
87+ then (assetId != neutrinoAssetId)
88+ else false)
89+ then throw("can use USDN only")
90+ else if (if ((stakingType == NSBTTYPE))
91+ then (assetId != nsbtAssetId)
92+ else false)
93+ then throw("can use NSBT only")
94+ else if (if ((stakingType != USDNTYPE))
95+ then (stakingType != NSBTTYPE)
96+ else false)
97+ then throw(("unsupported staking type " + stakingType))
98+ else assetId
99+
100+
101+func internalLockNeutrino (stakingType,i,receiver,share) = {
95102 let pmt = value(i.payments[0])
103+ let assetId = getValidStakingAssetOrFail(stakingType, value(pmt.assetId))
96104 if (!(isDefined(addressFromString(receiver))))
97105 then throw(("Invalid address format " + receiver))
98- else if (if ((pmt.assetId != neutrinoAssetId))
99- then (pmt.assetId != nsbtAssetId)
100- else false)
101- then throw("can use USDN or NSBT only")
102- else if ((share > 100))
103- then throw("staking rewards share cannot be higher than 100%")
104- else if ((1 > share))
105- then throw("staking rewards share cannot be lower than 1%")
106- else {
107- let account = toString(i.caller)
108- let assetIdString = toBase58String(value(pmt.assetId))
109- let currentConfig = getStringByKey(getCurrentRewardsConfigKey(account))
110- let correctData = if ((currentConfig != ""))
111- then {
112- let currentConfigData = split(currentConfig, "_")
113- let currShare = parseIntValue(currentConfigData[2])
114- let currReceiver = currentConfigData[3]
115- let notMigratedInitialShare = getNumberByKey(getRewardConfigInitialShare(account))
116- let actualInitialShare = if ((notMigratedInitialShare == 0))
117- then currShare
118- else notMigratedInitialShare
119- let newShare = if (if ((actualInitialShare > share))
120- then true
121- else (currReceiver != receiver))
122- then actualInitialShare
123- else share
106+ else if ((share > 100))
107+ then throw("staking rewards share cannot be higher than 100%")
108+ else if ((1 > share))
109+ then throw("staking rewards share cannot be lower than 1%")
110+ else {
111+ let account = toString(i.caller)
112+ let assetIdString = toBase58String(assetId)
113+ let currentConfig = getStringByKey(getCurrentRewardsConfigKey(account))
114+ let correctData = if ((currentConfig != ""))
115+ then {
116+ let currentConfigData = split(currentConfig, "_")
117+ let currShare = parseIntValue(currentConfigData[2])
118+ let currReceiver = currentConfigData[3]
119+ let notMigratedInitialShare = getNumberByKey(getRewardConfigInitialShare(account))
120+ let actualInitialShare = if ((notMigratedInitialShare == 0))
121+ then currShare
122+ else notMigratedInitialShare
123+ let newShare = if (if ((actualInitialShare > share))
124+ then true
125+ else (currReceiver != receiver))
126+ then actualInitialShare
127+ else share
124128 [toString(actualInitialShare), toString(newShare), currReceiver]
125- }
126- else [toString(share), toString(share), receiver]
127- let correctInitialShare = parseIntValue(correctData[0])
128- let correctShare = parseIntValue(correctData[1])
129- let correctReceiver = correctData[2]
130- let newCurrentConfig = getRewardsConfigKey(account, correctShare, correctReceiver)
131- let isNewConfig = !((currentConfig == newCurrentConfig))
132- let end = if (isNewConfig)
133- then height
134- else 0
135- let start = if (isNewConfig)
136- then height
137- else getNumberByKey(getRewardsConfigStartKey(newCurrentConfig, true))
129+ }
130+ else [toString(share), toString(share), receiver]
131+ let correctInitialShare = parseIntValue(correctData[0])
132+ let correctShare = parseIntValue(correctData[1])
133+ let correctReceiver = correctData[2]
134+ let newCurrentConfig = getRewardsConfigKey(account, correctShare, correctReceiver)
135+ let isNewConfig = !((currentConfig == newCurrentConfig))
136+ let end = if (isNewConfig)
137+ then height
138+ else 0
139+ let start = if (isNewConfig)
140+ then height
141+ else getNumberByKey(getRewardsConfigStartKey(newCurrentConfig, true))
138142 [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) + pmt.amount)), IntegerEntry(getUserBalanceKey(account, assetIdString), (getUserBalance(account, assetIdString) + pmt.amount)), IntegerEntry(getRewardsConfigStartKey(currentConfig, false), end), IntegerEntry(getRewardsConfigStartKey(newCurrentConfig, true), start), IntegerEntry(getRewardConfigInitialShare(account), correctInitialShare), StringEntry(getCurrentRewardsConfigKey(account), newCurrentConfig)]
139- }
143+ }
144+ }
145+
146+
147+func internalUnlock (stakingType,i,unlockAmount,assetIdParam) = {
148+ let account = toString(i.caller)
149+ let assetId = getValidStakingAssetOrFail(stakingType, fromBase58String(assetIdParam))
150+ let assetIdString = toBase58String(assetId)
151+ let balance = (getUserBalance(account, assetIdString) - unlockAmount)
152+ if ((0 >= balance))
153+ then throw("invalid amount")
154+ else [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, assetId)]
140155 }
141156
142157
143158 @Callable(i)
144-func lockNeutrinoSP (receiver,share) = internallockNeutrino(i, receiver, share)
159+func lockNeutrinoSP (receiver,share) = internalLockNeutrino(USDNTYPE, i, receiver, share)
145160
146161
147162
148163 @Callable(i)
149-func lockNeutrino () = internallockNeutrino(i, toString(i.caller), 100)
164+func lockNeutrino () = internalLockNeutrino(USDNTYPE, i, toString(i.caller), 100)
150165
151166
152167
153168 @Callable(i)
154-func unlockNeutrino (unlockAmount,assetIdString) = {
155- let account = toString(i.caller)
156- let assetId = fromBase58String(assetIdString)
157- let balance = (getUserBalance(account, assetIdString) - unlockAmount)
158- if ((0 > balance))
159- then throw("invalid amount")
160- else if ((assetId != neutrinoAssetId))
161- then throw("can use neutrino")
162- else [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, neutrinoAssetId)]
163- }
169+func lockNsbtSP (receiver,share) = internalLockNeutrino(NSBTTYPE, i, receiver, share)
164170
165171
166172
167173 @Callable(i)
168-func vote (hash,indexArgument) = {
169- let arguments = split(getArgumentsProposal(hash), ",")
170- let argument = arguments[indexArgument]
171- if ((height > getExpireProposal(hash)))
172- then throw("proposal is expired")
173- else [StringEntry(getVoteKey(toString(i.caller), hash), argument)]
174- }
174+func lockNsbt () = internalLockNeutrino(NSBTTYPE, i, toString(i.caller), 100)
175175
176176
177177
178178 @Callable(i)
179-func createProposal (arguments,expairHeight) = {
180- let hash = toBase58String(keccak256(((toBytes(arguments) + toBytes(expairHeight)) + i.callerPublicKey)))
181- if ((getOwnerProposal(hash) != ""))
182- then throw("proposal is exist")
183- else [IntegerEntry(getExpireProposalKey(hash), expairHeight), StringEntry(getOwnerProposalKey(hash), toString(i.caller)), StringEntry(getArgumentsProposalKey(hash), arguments)]
184- }
179+func unlockNeutrino (unlockAmount,assetIdString) = internalUnlock(USDNTYPE, i, unlockAmount, assetIdString)
180+
181+
182+
183+@Callable(i)
184+func unlockNsbt (unlockAmount,assetIdString) = internalUnlock(NSBTTYPE, i, unlockAmount, assetIdString)
185185
186186
187187 @Verifier(tx)
188188 func verify () = {
189189 let pubKeyAdminsList = ["GXxmZaCigPgJsT6d1cLr8nUXA65nGX8V7FuAzzrY8wQE", "3xumx4hrPpeeoo79HLGbZCgfz95L39ZFdxxwWeSUC2Pu", "D4CqtK5fBsnzRo33ZMhrM7niLseDH2uRoK6weBq2JQ3A", "5WRXFSjwcTbNfKcJs8ZqXmSSWYsSVJUtMvMqZj5hH4Nc"]
190190 let count = ((((if (sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(pubKeyAdminsList[0])))
191191 then 1
192192 else 0) + (if (sigVerify(tx.bodyBytes, tx.proofs[1], fromBase58String(pubKeyAdminsList[1])))
193193 then 1
194194 else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[2], fromBase58String(pubKeyAdminsList[2])))
195195 then 1
196196 else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[3], fromBase58String(pubKeyAdminsList[3])))
197197 then 2
198198 else 0))
199199 (count >= 3)
200200 }
201201

github/deemru/w8io/873ac7e 
62.22 ms