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:
Old | New | Differences | |
---|---|---|---|
27 | 27 | let NsbtAssetIdKey = "bond_asset_id" | |
28 | 28 | ||
29 | 29 | let AdminsKey = "admins" | |
30 | + | ||
31 | + | let USDNTYPE = "USDN" | |
32 | + | ||
33 | + | let NSBTTYPE = "NSBT" | |
30 | 34 | ||
31 | 35 | func getUserBalanceKey (owner,assetId) = ((((BalanceKey + "_") + assetId) + "_") + owner) | |
32 | 36 | ||
65 | 69 | func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId)) | |
66 | 70 | ||
67 | 71 | ||
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 | - | ||
80 | 72 | func getRewardsConfigKey (owner,share,receiver) = ((((("stakingconfig_" + owner) + "_") + toString(share)) + "_") + receiver) | |
81 | 73 | ||
82 | 74 | ||
91 | 83 | func getRewardConfigInitialShare (owner) = (owner + "_initialShare") | |
92 | 84 | ||
93 | 85 | ||
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) = { | |
95 | 102 | let pmt = value(i.payments[0]) | |
103 | + | let assetId = getValidStakingAssetOrFail(stakingType, value(pmt.assetId)) | |
96 | 104 | if (!(isDefined(addressFromString(receiver)))) | |
97 | 105 | 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 | |
124 | 128 | [toString(actualInitialShare), toString(newShare), currReceiver] | |
125 | - | ||
126 | - | ||
127 | - | ||
128 | - | ||
129 | - | ||
130 | - | ||
131 | - | ||
132 | - | ||
133 | - | ||
134 | - | ||
135 | - | ||
136 | - | ||
137 | - | ||
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)) | |
138 | 142 | [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)] | |
140 | 155 | } | |
141 | 156 | ||
142 | 157 | ||
143 | 158 | @Callable(i) | |
144 | - | func lockNeutrinoSP (receiver,share) = | |
159 | + | func lockNeutrinoSP (receiver,share) = internalLockNeutrino(USDNTYPE, i, receiver, share) | |
145 | 160 | ||
146 | 161 | ||
147 | 162 | ||
148 | 163 | @Callable(i) | |
149 | - | func lockNeutrino () = | |
164 | + | func lockNeutrino () = internalLockNeutrino(USDNTYPE, i, toString(i.caller), 100) | |
150 | 165 | ||
151 | 166 | ||
152 | 167 | ||
153 | 168 | @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) | |
164 | 170 | ||
165 | 171 | ||
166 | 172 | ||
167 | 173 | @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) | |
175 | 175 | ||
176 | 176 | ||
177 | 177 | ||
178 | 178 | @Callable(i) | |
179 | - | func | |
180 | - | ||
181 | - | ||
182 | - | ||
183 | - | ||
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) | |
185 | 185 | ||
186 | 186 | ||
187 | 187 | @Verifier(tx) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 4 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | func getNumberByKey (key) = valueOrElse(getInteger(this, key), 0) | |
5 | 5 | ||
6 | 6 | ||
7 | 7 | func getStringByKey (key) = valueOrElse(getString(this, key), "") | |
8 | 8 | ||
9 | 9 | ||
10 | 10 | func getBoolByKey (key) = valueOrElse(getBoolean(this, key), false) | |
11 | 11 | ||
12 | 12 | ||
13 | 13 | func getNumberByAddressAndKey (address,key) = valueOrElse(getInteger(addressFromStringValue(address), key), 0) | |
14 | 14 | ||
15 | 15 | ||
16 | 16 | func getStringByAddressAndKey (address,key) = valueOrElse(getString(address, key), "") | |
17 | 17 | ||
18 | 18 | ||
19 | 19 | let NeutrinoAssetIdKey = "neutrino_asset_id" | |
20 | 20 | ||
21 | 21 | let NeutrinoContractKey = "neutrino_contract" | |
22 | 22 | ||
23 | 23 | let BalanceKey = "rpd_balance" | |
24 | 24 | ||
25 | 25 | let ControlContractKey = "control_contract" | |
26 | 26 | ||
27 | 27 | let NsbtAssetIdKey = "bond_asset_id" | |
28 | 28 | ||
29 | 29 | let AdminsKey = "admins" | |
30 | + | ||
31 | + | let USDNTYPE = "USDN" | |
32 | + | ||
33 | + | let NSBTTYPE = "NSBT" | |
30 | 34 | ||
31 | 35 | func getUserBalanceKey (owner,assetId) = ((((BalanceKey + "_") + assetId) + "_") + owner) | |
32 | 36 | ||
33 | 37 | ||
34 | 38 | func getContractBalanceKey (assetId) = ((BalanceKey + "_") + assetId) | |
35 | 39 | ||
36 | 40 | ||
37 | 41 | func getExpireProposalKey (hash) = (("proposal_expire" + "_") + hash) | |
38 | 42 | ||
39 | 43 | ||
40 | 44 | func getOwnerProposalKey (hash) = (("proposal_owner" + "_") + hash) | |
41 | 45 | ||
42 | 46 | ||
43 | 47 | func getArgumentsProposalKey (hash) = (("proposal_arguments" + "_") + hash) | |
44 | 48 | ||
45 | 49 | ||
46 | 50 | func getVoteKey (owner,hash) = (((("proposal_vote" + "_") + owner) + "_") + hash) | |
47 | 51 | ||
48 | 52 | ||
49 | 53 | func convertJsonArrayToList (jsonArray) = split(jsonArray, ",") | |
50 | 54 | ||
51 | 55 | ||
52 | 56 | let neutrinoContract = addressFromStringValue(getStringByKey(NeutrinoContractKey)) | |
53 | 57 | ||
54 | 58 | let controlContract = addressFromStringValue(getStringByAddressAndKey(neutrinoContract, ControlContractKey)) | |
55 | 59 | ||
56 | 60 | let neutrinoAssetId = fromBase58String(getStringByAddressAndKey(neutrinoContract, NeutrinoAssetIdKey)) | |
57 | 61 | ||
58 | 62 | let nsbtAssetIdStr = getStringByAddressAndKey(neutrinoContract, NsbtAssetIdKey) | |
59 | 63 | ||
60 | 64 | let nsbtAssetId = fromBase58String(nsbtAssetIdStr) | |
61 | 65 | ||
62 | 66 | func getContractBalance (assetId) = getNumberByKey(getContractBalanceKey(assetId)) | |
63 | 67 | ||
64 | 68 | ||
65 | 69 | func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId)) | |
66 | 70 | ||
67 | 71 | ||
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 | - | ||
80 | 72 | func getRewardsConfigKey (owner,share,receiver) = ((((("stakingconfig_" + owner) + "_") + toString(share)) + "_") + receiver) | |
81 | 73 | ||
82 | 74 | ||
83 | 75 | func getCurrentRewardsConfigKey (owner) = ("stakingconfig_current_" + owner) | |
84 | 76 | ||
85 | 77 | ||
86 | 78 | func getRewardsConfigStartKey (configKey,isStart) = (configKey + (if (isStart) | |
87 | 79 | then "_start" | |
88 | 80 | else "_end")) | |
89 | 81 | ||
90 | 82 | ||
91 | 83 | func getRewardConfigInitialShare (owner) = (owner + "_initialShare") | |
92 | 84 | ||
93 | 85 | ||
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) = { | |
95 | 102 | let pmt = value(i.payments[0]) | |
103 | + | let assetId = getValidStakingAssetOrFail(stakingType, value(pmt.assetId)) | |
96 | 104 | if (!(isDefined(addressFromString(receiver)))) | |
97 | 105 | 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 | |
124 | 128 | [toString(actualInitialShare), toString(newShare), currReceiver] | |
125 | - | ||
126 | - | ||
127 | - | ||
128 | - | ||
129 | - | ||
130 | - | ||
131 | - | ||
132 | - | ||
133 | - | ||
134 | - | ||
135 | - | ||
136 | - | ||
137 | - | ||
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)) | |
138 | 142 | [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)] | |
140 | 155 | } | |
141 | 156 | ||
142 | 157 | ||
143 | 158 | @Callable(i) | |
144 | - | func lockNeutrinoSP (receiver,share) = | |
159 | + | func lockNeutrinoSP (receiver,share) = internalLockNeutrino(USDNTYPE, i, receiver, share) | |
145 | 160 | ||
146 | 161 | ||
147 | 162 | ||
148 | 163 | @Callable(i) | |
149 | - | func lockNeutrino () = | |
164 | + | func lockNeutrino () = internalLockNeutrino(USDNTYPE, i, toString(i.caller), 100) | |
150 | 165 | ||
151 | 166 | ||
152 | 167 | ||
153 | 168 | @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) | |
164 | 170 | ||
165 | 171 | ||
166 | 172 | ||
167 | 173 | @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) | |
175 | 175 | ||
176 | 176 | ||
177 | 177 | ||
178 | 178 | @Callable(i) | |
179 | - | func | |
180 | - | ||
181 | - | ||
182 | - | ||
183 | - | ||
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) | |
185 | 185 | ||
186 | 186 | ||
187 | 187 | @Verifier(tx) | |
188 | 188 | func verify () = { | |
189 | 189 | let pubKeyAdminsList = ["GXxmZaCigPgJsT6d1cLr8nUXA65nGX8V7FuAzzrY8wQE", "3xumx4hrPpeeoo79HLGbZCgfz95L39ZFdxxwWeSUC2Pu", "D4CqtK5fBsnzRo33ZMhrM7niLseDH2uRoK6weBq2JQ3A", "5WRXFSjwcTbNfKcJs8ZqXmSSWYsSVJUtMvMqZj5hH4Nc"] | |
190 | 190 | let count = ((((if (sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(pubKeyAdminsList[0]))) | |
191 | 191 | then 1 | |
192 | 192 | else 0) + (if (sigVerify(tx.bodyBytes, tx.proofs[1], fromBase58String(pubKeyAdminsList[1]))) | |
193 | 193 | then 1 | |
194 | 194 | else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[2], fromBase58String(pubKeyAdminsList[2]))) | |
195 | 195 | then 1 | |
196 | 196 | else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[3], fromBase58String(pubKeyAdminsList[3]))) | |
197 | 197 | then 2 | |
198 | 198 | else 0)) | |
199 | 199 | (count >= 3) | |
200 | 200 | } | |
201 | 201 |
github/deemru/w8io/873ac7e 62.22 ms ◑