tx · GsTfzVaPPc7f16tY2WR4j3kQK6rPs3FxFn7kxrUea4sE 3N6q7sCGSSLBUXDdjBdYGTJbZGZfhhh8cNg: -0.01400000 Waves 2021.10.15 17:33 [1747510] smart account 3N6q7sCGSSLBUXDdjBdYGTJbZGZfhhh8cNg > SELF 0.00000000 Waves
{ "type": 13, "id": "GsTfzVaPPc7f16tY2WR4j3kQK6rPs3FxFn7kxrUea4sE", "fee": 1400000, "feeAssetId": null, "timestamp": 1634308388154, "version": 2, "chainId": 84, "sender": "3N6q7sCGSSLBUXDdjBdYGTJbZGZfhhh8cNg", "senderPublicKey": "6RxCbWeRD4VWkRJtcAR8HBRkrBbEzZWucSBL6YrSFQrE", "proofs": [ "zjyx8Fg5o9G7oRFwgNjxexPJKEfN7JXEDdBxi59TkWF2pC4eNYSiwEHNgUnitBQ93bpd7iKtd52BSys5cN91TeP" ], "script": "base64:AAIFAAAAAAAAAB4IAhIECgIIARIAEgQKAggBEgASBAoCAQgSBAoCAQgAAAAiAQAAAA5nZXROdW1iZXJCeUtleQAAAAEAAAADa2V5CQEAAAALdmFsdWVPckVsc2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAAA2tleQAAAAAAAAAAAAEAAAAOZ2V0U3RyaW5nQnlLZXkAAAABAAAAA2tleQkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkABB0AAAACBQAAAAR0aGlzBQAAAANrZXkCAAAAAAEAAAAMZ2V0Qm9vbEJ5S2V5AAAAAQAAAANrZXkJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQbAAAAAgUAAAAEdGhpcwUAAAADa2V5BwEAAAAYZ2V0TnVtYmVyQnlBZGRyZXNzQW5kS2V5AAAAAgAAAAdhZGRyZXNzAAAAA2tleQkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkABBoAAAACCQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABBQAAAAdhZGRyZXNzBQAAAANrZXkAAAAAAAAAAAABAAAAGGdldFN0cmluZ0J5QWRkcmVzc0FuZEtleQAAAAIAAAAHYWRkcmVzcwAAAANrZXkJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQdAAAAAgUAAAAHYWRkcmVzcwUAAAADa2V5AgAAAAAAAAAAEk5ldXRyaW5vQXNzZXRJZEtleQIAAAARbmV1dHJpbm9fYXNzZXRfaWQAAAAAE05ldXRyaW5vQ29udHJhY3RLZXkCAAAAEW5ldXRyaW5vX2NvbnRyYWN0AAAAAApCYWxhbmNlS2V5AgAAAAtycGRfYmFsYW5jZQAAAAASQ29udHJvbENvbnRyYWN0S2V5AgAAABBjb250cm9sX2NvbnRyYWN0AAAAAA5Oc2J0QXNzZXRJZEtleQIAAAANYm9uZF9hc3NldF9pZAAAAAAJQWRtaW5zS2V5AgAAAAZhZG1pbnMAAAAACFVTRE5UWVBFAgAAAARVU0ROAAAAAAhOU0JUVFlQRQIAAAAETlNCVAEAAAARZ2V0VXNlckJhbGFuY2VLZXkAAAACAAAABW93bmVyAAAAB2Fzc2V0SWQJAAS5AAAAAgkABEwAAAACBQAAAApCYWxhbmNlS2V5CQAETAAAAAIFAAAAB2Fzc2V0SWQJAARMAAAAAgUAAAAFb3duZXIFAAAAA25pbAIAAAABXwEAAAAVZ2V0Q29udHJhY3RCYWxhbmNlS2V5AAAAAQAAAAdhc3NldElkCQABLAAAAAIJAAEsAAAAAgUAAAAKQmFsYW5jZUtleQIAAAABXwUAAAAHYXNzZXRJZAEAAAAUZ2V0RXhwaXJlUHJvcG9zYWxLZXkAAAABAAAABGhhc2gJAAEsAAAAAgkAASwAAAACAgAAAA9wcm9wb3NhbF9leHBpcmUCAAAAAV8FAAAABGhhc2gBAAAAE2dldE93bmVyUHJvcG9zYWxLZXkAAAABAAAABGhhc2gJAAEsAAAAAgkAASwAAAACAgAAAA5wcm9wb3NhbF9vd25lcgIAAAABXwUAAAAEaGFzaAEAAAAXZ2V0QXJndW1lbnRzUHJvcG9zYWxLZXkAAAABAAAABGhhc2gJAAEsAAAAAgkAASwAAAACAgAAABJwcm9wb3NhbF9hcmd1bWVudHMCAAAAAV8FAAAABGhhc2gBAAAACmdldFZvdGVLZXkAAAACAAAABW93bmVyAAAABGhhc2gJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgIAAAANcHJvcG9zYWxfdm90ZQIAAAABXwUAAAAFb3duZXICAAAAAV8FAAAABGhhc2gBAAAAFmNvbnZlcnRKc29uQXJyYXlUb0xpc3QAAAABAAAACWpzb25BcnJheQkABLUAAAACBQAAAAlqc29uQXJyYXkCAAAAASwAAAAAEG5ldXRyaW5vQ29udHJhY3QJAQAAABFAZXh0ck5hdGl2ZSgxMDYyKQAAAAEJAQAAAA5nZXRTdHJpbmdCeUtleQAAAAEFAAAAE05ldXRyaW5vQ29udHJhY3RLZXkAAAAAD2NvbnRyb2xDb250cmFjdAkBAAAAEUBleHRyTmF0aXZlKDEwNjIpAAAAAQkBAAAAGGdldFN0cmluZ0J5QWRkcmVzc0FuZEtleQAAAAIFAAAAEG5ldXRyaW5vQ29udHJhY3QFAAAAEkNvbnRyb2xDb250cmFjdEtleQAAAAAPbmV1dHJpbm9Bc3NldElkCQACWQAAAAEJAQAAABhnZXRTdHJpbmdCeUFkZHJlc3NBbmRLZXkAAAACBQAAABBuZXV0cmlub0NvbnRyYWN0BQAAABJOZXV0cmlub0Fzc2V0SWRLZXkAAAAADm5zYnRBc3NldElkU3RyCQEAAAAYZ2V0U3RyaW5nQnlBZGRyZXNzQW5kS2V5AAAAAgUAAAAQbmV1dHJpbm9Db250cmFjdAUAAAAOTnNidEFzc2V0SWRLZXkAAAAAC25zYnRBc3NldElkCQACWQAAAAEFAAAADm5zYnRBc3NldElkU3RyAQAAABJnZXRDb250cmFjdEJhbGFuY2UAAAABAAAAB2Fzc2V0SWQJAQAAAA5nZXROdW1iZXJCeUtleQAAAAEJAQAAABVnZXRDb250cmFjdEJhbGFuY2VLZXkAAAABBQAAAAdhc3NldElkAQAAAA5nZXRVc2VyQmFsYW5jZQAAAAIAAAAFb3duZXIAAAAHYXNzZXRJZAkBAAAADmdldE51bWJlckJ5S2V5AAAAAQkBAAAAEWdldFVzZXJCYWxhbmNlS2V5AAAAAgUAAAAFb3duZXIFAAAAB2Fzc2V0SWQBAAAAE2dldFJld2FyZHNDb25maWdLZXkAAAADAAAABW93bmVyAAAABXNoYXJlAAAACHJlY2VpdmVyCQAEuQAAAAIJAARMAAAAAgIAAAANc3Rha2luZ2NvbmZpZwkABEwAAAACBQAAAAVvd25lcgkABEwAAAACCQABpAAAAAEFAAAABXNoYXJlCQAETAAAAAIFAAAACHJlY2VpdmVyBQAAAANuaWwCAAAAAV8BAAAAGmdldEN1cnJlbnRSZXdhcmRzQ29uZmlnS2V5AAAAAQAAAAVvd25lcgkAASwAAAACAgAAABZzdGFraW5nY29uZmlnX2N1cnJlbnRfBQAAAAVvd25lcgEAAAAYZ2V0UmV3YXJkc0NvbmZpZ1N0YXJ0S2V5AAAAAgAAAAljb25maWdLZXkAAAAHaXNTdGFydAkAASwAAAACBQAAAAljb25maWdLZXkDBQAAAAdpc1N0YXJ0AgAAAAZfc3RhcnQCAAAABF9lbmQBAAAAG2dldFJld2FyZENvbmZpZ0luaXRpYWxTaGFyZQAAAAEAAAAFb3duZXIJAAEsAAAAAgUAAAAFb3duZXICAAAADV9pbml0aWFsU2hhcmUBAAAAGmdldFZhbGlkU3Rha2luZ0Fzc2V0T3JGYWlsAAAAAgAAAAtzdGFraW5nVHlwZQAAAAdhc3NldElkAwMJAAAAAAAAAgUAAAALc3Rha2luZ1R5cGUFAAAACFVTRE5UWVBFCQEAAAACIT0AAAACBQAAAAdhc3NldElkBQAAAA9uZXV0cmlub0Fzc2V0SWQHCQAAAgAAAAECAAAAEWNhbiB1c2UgVVNETiBvbmx5AwMJAAAAAAAAAgUAAAALc3Rha2luZ1R5cGUFAAAACE5TQlRUWVBFCQEAAAACIT0AAAACBQAAAAdhc3NldElkBQAAAAtuc2J0QXNzZXRJZAcJAAACAAAAAQIAAAARY2FuIHVzZSBOU0JUIG9ubHkDAwkBAAAAAiE9AAAAAgUAAAALc3Rha2luZ1R5cGUFAAAACFVTRE5UWVBFCQEAAAACIT0AAAACBQAAAAtzdGFraW5nVHlwZQUAAAAITlNCVFRZUEUHCQAAAgAAAAEJAAEsAAAAAgIAAAAZdW5zdXBwb3J0ZWQgc3Rha2luZyB0eXBlIAUAAAALc3Rha2luZ1R5cGUFAAAAB2Fzc2V0SWQBAAAAFGludGVybmFsTG9ja05ldXRyaW5vAAAABAAAAAtzdGFraW5nVHlwZQAAAAFpAAAACHJlY2VpdmVyAAAABXNoYXJlBAAAAANwbXQJAQAAAAV2YWx1ZQAAAAEJAAGRAAAAAggFAAAAAWkAAAAIcGF5bWVudHMAAAAAAAAAAAAEAAAAB2Fzc2V0SWQJAQAAABpnZXRWYWxpZFN0YWtpbmdBc3NldE9yRmFpbAAAAAIFAAAAC3N0YWtpbmdUeXBlCQEAAAAFdmFsdWUAAAABCAUAAAADcG10AAAAB2Fzc2V0SWQDCQEAAAABIQAAAAEJAQAAAAlpc0RlZmluZWQAAAABCQAEJgAAAAEFAAAACHJlY2VpdmVyCQAAAgAAAAEJAAEsAAAAAgIAAAAXSW52YWxpZCBhZGRyZXNzIGZvcm1hdCAFAAAACHJlY2VpdmVyAwkAAGYAAAACBQAAAAVzaGFyZQAAAAAAAAAAZAkAAAIAAAABAgAAADBzdGFraW5nIHJld2FyZHMgc2hhcmUgY2Fubm90IGJlIGhpZ2hlciB0aGFuIDEwMCUDCQAAZgAAAAIAAAAAAAAAAAEFAAAABXNoYXJlCQAAAgAAAAECAAAALXN0YWtpbmcgcmV3YXJkcyBzaGFyZSBjYW5ub3QgYmUgbG93ZXIgdGhhbiAxJQQAAAAHYWNjb3VudAkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIEAAAADWFzc2V0SWRTdHJpbmcJAAJYAAAAAQUAAAAHYXNzZXRJZAQAAAANY3VycmVudENvbmZpZwkBAAAADmdldFN0cmluZ0J5S2V5AAAAAQkBAAAAGmdldEN1cnJlbnRSZXdhcmRzQ29uZmlnS2V5AAAAAQUAAAAHYWNjb3VudAQAAAALY29ycmVjdERhdGEDCQEAAAACIT0AAAACBQAAAA1jdXJyZW50Q29uZmlnAgAAAAAEAAAAEWN1cnJlbnRDb25maWdEYXRhCQAEtQAAAAIFAAAADWN1cnJlbnRDb25maWcCAAAAAV8EAAAACWN1cnJTaGFyZQkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAAEWN1cnJlbnRDb25maWdEYXRhAAAAAAAAAAACBAAAAAxjdXJyUmVjZWl2ZXIJAAGRAAAAAgUAAAARY3VycmVudENvbmZpZ0RhdGEAAAAAAAAAAAMEAAAAF25vdE1pZ3JhdGVkSW5pdGlhbFNoYXJlCQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABCQEAAAAbZ2V0UmV3YXJkQ29uZmlnSW5pdGlhbFNoYXJlAAAAAQUAAAAHYWNjb3VudAQAAAASYWN0dWFsSW5pdGlhbFNoYXJlAwkAAAAAAAACBQAAABdub3RNaWdyYXRlZEluaXRpYWxTaGFyZQAAAAAAAAAAAAUAAAAJY3VyclNoYXJlBQAAABdub3RNaWdyYXRlZEluaXRpYWxTaGFyZQQAAAAIbmV3U2hhcmUDAwkAAGYAAAACBQAAABJhY3R1YWxJbml0aWFsU2hhcmUFAAAABXNoYXJlBgkBAAAAAiE9AAAAAgUAAAAMY3VyclJlY2VpdmVyBQAAAAhyZWNlaXZlcgUAAAASYWN0dWFsSW5pdGlhbFNoYXJlBQAAAAVzaGFyZQkABEwAAAACCQABpAAAAAEFAAAAEmFjdHVhbEluaXRpYWxTaGFyZQkABEwAAAACCQABpAAAAAEFAAAACG5ld1NoYXJlCQAETAAAAAIFAAAADGN1cnJSZWNlaXZlcgUAAAADbmlsCQAETAAAAAIJAAGkAAAAAQUAAAAFc2hhcmUJAARMAAAAAgkAAaQAAAABBQAAAAVzaGFyZQkABEwAAAACBQAAAAhyZWNlaXZlcgUAAAADbmlsBAAAABNjb3JyZWN0SW5pdGlhbFNoYXJlCQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAALY29ycmVjdERhdGEAAAAAAAAAAAAEAAAADGNvcnJlY3RTaGFyZQkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAAC2NvcnJlY3REYXRhAAAAAAAAAAABBAAAAA9jb3JyZWN0UmVjZWl2ZXIJAAGRAAAAAgUAAAALY29ycmVjdERhdGEAAAAAAAAAAAIEAAAAEG5ld0N1cnJlbnRDb25maWcJAQAAABNnZXRSZXdhcmRzQ29uZmlnS2V5AAAAAwUAAAAHYWNjb3VudAUAAAAMY29ycmVjdFNoYXJlBQAAAA9jb3JyZWN0UmVjZWl2ZXIEAAAAC2lzTmV3Q29uZmlnCQEAAAABIQAAAAEJAAAAAAAAAgUAAAANY3VycmVudENvbmZpZwUAAAAQbmV3Q3VycmVudENvbmZpZwQAAAADZW5kAwUAAAALaXNOZXdDb25maWcFAAAABmhlaWdodAAAAAAAAAAAAAQAAAAFc3RhcnQDBQAAAAtpc05ld0NvbmZpZwUAAAAGaGVpZ2h0CQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABCQEAAAAYZ2V0UmV3YXJkc0NvbmZpZ1N0YXJ0S2V5AAAAAgUAAAAQbmV3Q3VycmVudENvbmZpZwYJAAUUAAAAAgkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAFWdldENvbnRyYWN0QmFsYW5jZUtleQAAAAEFAAAADWFzc2V0SWRTdHJpbmcJAABkAAAAAgkBAAAAEmdldENvbnRyYWN0QmFsYW5jZQAAAAEFAAAADWFzc2V0SWRTdHJpbmcIBQAAAANwbXQAAAAGYW1vdW50CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQEAAAARZ2V0VXNlckJhbGFuY2VLZXkAAAACBQAAAAdhY2NvdW50BQAAAA1hc3NldElkU3RyaW5nCQAAZAAAAAIJAQAAAA5nZXRVc2VyQmFsYW5jZQAAAAIFAAAAB2FjY291bnQFAAAADWFzc2V0SWRTdHJpbmcIBQAAAANwbXQAAAAGYW1vdW50CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQEAAAAYZ2V0UmV3YXJkc0NvbmZpZ1N0YXJ0S2V5AAAAAgUAAAANY3VycmVudENvbmZpZwcFAAAAA2VuZAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAGGdldFJld2FyZHNDb25maWdTdGFydEtleQAAAAIFAAAAEG5ld0N1cnJlbnRDb25maWcGBQAAAAVzdGFydAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAG2dldFJld2FyZENvbmZpZ0luaXRpYWxTaGFyZQAAAAEFAAAAB2FjY291bnQFAAAAE2NvcnJlY3RJbml0aWFsU2hhcmUJAARMAAAAAgkBAAAAC1N0cmluZ0VudHJ5AAAAAgkBAAAAGmdldEN1cnJlbnRSZXdhcmRzQ29uZmlnS2V5AAAAAQUAAAAHYWNjb3VudAUAAAAQbmV3Q3VycmVudENvbmZpZwUAAAADbmlsBQAAAAR1bml0AQAAAA5pbnRlcm5hbFVubG9jawAAAAQAAAALc3Rha2luZ1R5cGUAAAABaQAAAAx1bmxvY2tBbW91bnQAAAAMYXNzZXRJZFBhcmFtBAAAAAdhY2NvdW50CQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgQAAAAHYXNzZXRJZAkBAAAAGmdldFZhbGlkU3Rha2luZ0Fzc2V0T3JGYWlsAAAAAgUAAAALc3Rha2luZ1R5cGUJAAJZAAAAAQUAAAAMYXNzZXRJZFBhcmFtBAAAAA1hc3NldElkU3RyaW5nCQACWAAAAAEFAAAAB2Fzc2V0SWQEAAAAB2JhbGFuY2UJAABlAAAAAgkBAAAADmdldFVzZXJCYWxhbmNlAAAAAgUAAAAHYWNjb3VudAUAAAANYXNzZXRJZFN0cmluZwUAAAAMdW5sb2NrQW1vdW50AwkAAGYAAAACAAAAAAAAAAAABQAAAAdiYWxhbmNlCQAAAgAAAAECAAAADmludmFsaWQgYW1vdW50CQAFFAAAAAIJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAQAAABVnZXRDb250cmFjdEJhbGFuY2VLZXkAAAABBQAAAA1hc3NldElkU3RyaW5nCQAAZQAAAAIJAQAAABJnZXRDb250cmFjdEJhbGFuY2UAAAABBQAAAA1hc3NldElkU3RyaW5nBQAAAAx1bmxvY2tBbW91bnQJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAQAAABFnZXRVc2VyQmFsYW5jZUtleQAAAAIFAAAAB2FjY291bnQFAAAADWFzc2V0SWRTdHJpbmcFAAAAB2JhbGFuY2UJAARMAAAAAgkBAAAADlNjcmlwdFRyYW5zZmVyAAAAAwkBAAAAEUBleHRyTmF0aXZlKDEwNjIpAAAAAQUAAAAHYWNjb3VudAUAAAAMdW5sb2NrQW1vdW50BQAAAAdhc3NldElkBQAAAANuaWwFAAAABHVuaXQAAAAGAAAAAWkBAAAADmxvY2tOZXV0cmlub1NQAAAAAgAAAAhyZWNlaXZlcgAAAAVzaGFyZQkBAAAAFGludGVybmFsTG9ja05ldXRyaW5vAAAABAUAAAAIVVNETlRZUEUFAAAAAWkFAAAACHJlY2VpdmVyBQAAAAVzaGFyZQAAAAFpAQAAAAxsb2NrTmV1dHJpbm8AAAAACQEAAAAUaW50ZXJuYWxMb2NrTmV1dHJpbm8AAAAEBQAAAAhVU0ROVFlQRQUAAAABaQkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIAAAAAAAAAAGQAAAABaQEAAAAKbG9ja05zYnRTUAAAAAIAAAAIcmVjZWl2ZXIAAAAFc2hhcmUJAQAAABRpbnRlcm5hbExvY2tOZXV0cmlubwAAAAQFAAAACE5TQlRUWVBFBQAAAAFpBQAAAAhyZWNlaXZlcgUAAAAFc2hhcmUAAAABaQEAAAAIbG9ja05zYnQAAAAACQEAAAAUaW50ZXJuYWxMb2NrTmV1dHJpbm8AAAAEBQAAAAhOU0JUVFlQRQUAAAABaQkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIAAAAAAAAAAGQAAAABaQEAAAAOdW5sb2NrTmV1dHJpbm8AAAACAAAADHVubG9ja0Ftb3VudAAAAA1hc3NldElkU3RyaW5nCQEAAAAOaW50ZXJuYWxVbmxvY2sAAAAEBQAAAAhVU0ROVFlQRQUAAAABaQUAAAAMdW5sb2NrQW1vdW50BQAAAA1hc3NldElkU3RyaW5nAAAAAWkBAAAACnVubG9ja05zYnQAAAACAAAADHVubG9ja0Ftb3VudAAAAA1hc3NldElkU3RyaW5nCQEAAAAOaW50ZXJuYWxVbmxvY2sAAAAEBQAAAAhOU0JUVFlQRQUAAAABaQUAAAAMdW5sb2NrQW1vdW50BQAAAA1hc3NldElkU3RyaW5nAAAAAQAAAAJ0eAEAAAAGdmVyaWZ5AAAAAAQAAAAQcHViS2V5QWRtaW5zTGlzdAkABEwAAAACAgAAACxHRm1LWjJuYVpGUm9Ddk5id0tBUVZHbUxiMXVCZVdHRGdGYWJkR0J1Wml1eQkABEwAAAACAgAAACxHbUpYUnloUkE3OWc4eVVHZ0tCQVZkbkZmUUZETWpRRzk4YjFNbUxEaDVrawkABEwAAAACAgAAACxDRmhiVjZoNDFoVmpiR0h1ZEd0UzNmWVV2N1FBS1J4RlF6S050eDRCNVBxUAkABEwAAAACAgAAACtLbjdOcHphRzEyZExaZ2NIZjJpcFVmdFU2aGJKeWdtcmhGcVFZRTRCN1pLBQAAAANuaWwEAAAABWNvdW50CQAAZAAAAAIJAABkAAAAAgkAAGQAAAACAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAAJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAEJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAABAAAAAAAAAAABAAAAAAAAAAAAAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAIJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAACAAAAAAAAAAABAAAAAAAAAAAAAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAMJAAJZAAAAAQkAAZEAAAACBQAAABBwdWJLZXlBZG1pbnNMaXN0AAAAAAAAAAADAAAAAAAAAAACAAAAAAAAAAAACQAAZwAAAAIFAAAABWNvdW50AAAAAAAAAAADioSHjQ==", "height": 1747510, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: BtqRat7zqcEVN4TbxMheQkMMncrG3sdEy3LnM8vnanzL Next: none Diff:
Old | New | Differences | |
---|---|---|---|
1 | - | {-# STDLIB_VERSION | |
1 | + | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | ||
4 | + | func getNumberByKey (key) = valueOrElse(getInteger(this, key), 0) | |
5 | 5 | ||
6 | - | let nsbtAssetId = base58'36mg8NZTaFRDygiVwb8uBnLR51hetJruUCZcxhaVcHj9' | |
7 | 6 | ||
8 | - | let NeutrinoContractKey = base58'3N6q7sCGSSLBUXDdjBdYGTJbZGZfhhh8cNg' | |
7 | + | func getStringByKey (key) = valueOrElse(getString(this, key), "") | |
8 | + | ||
9 | + | ||
10 | + | func getBoolByKey (key) = valueOrElse(getBoolean(this, key), false) | |
11 | + | ||
12 | + | ||
13 | + | func getNumberByAddressAndKey (address,key) = valueOrElse(getInteger(addressFromStringValue(address), key), 0) | |
14 | + | ||
15 | + | ||
16 | + | func getStringByAddressAndKey (address,key) = valueOrElse(getString(address, key), "") | |
17 | + | ||
18 | + | ||
19 | + | let NeutrinoAssetIdKey = "neutrino_asset_id" | |
20 | + | ||
21 | + | let NeutrinoContractKey = "neutrino_contract" | |
22 | + | ||
23 | + | let BalanceKey = "rpd_balance" | |
24 | + | ||
25 | + | let ControlContractKey = "control_contract" | |
26 | + | ||
27 | + | let NsbtAssetIdKey = "bond_asset_id" | |
28 | + | ||
29 | + | let AdminsKey = "admins" | |
9 | 30 | ||
10 | 31 | let USDNTYPE = "USDN" | |
11 | 32 | ||
12 | 33 | let NSBTTYPE = "NSBT" | |
13 | 34 | ||
14 | - | let BalanceKey = "rpd_balance" | |
15 | - | ||
16 | 35 | func getUserBalanceKey (owner,assetId) = makeString([BalanceKey, assetId, owner], "_") | |
17 | 36 | ||
18 | 37 | ||
19 | - | func | |
38 | + | func getContractBalanceKey (assetId) = ((BalanceKey + "_") + assetId) | |
20 | 39 | ||
21 | 40 | ||
22 | - | func | |
41 | + | func getExpireProposalKey (hash) = (("proposal_expire" + "_") + hash) | |
23 | 42 | ||
24 | 43 | ||
25 | - | func getRewardConfigInitialShare (owner) = (owner + "_initialShare") | |
44 | + | func getOwnerProposalKey (hash) = (("proposal_owner" + "_") + hash) | |
45 | + | ||
46 | + | ||
47 | + | func getArgumentsProposalKey (hash) = (("proposal_arguments" + "_") + hash) | |
48 | + | ||
49 | + | ||
50 | + | func getVoteKey (owner,hash) = (((("proposal_vote" + "_") + owner) + "_") + hash) | |
51 | + | ||
52 | + | ||
53 | + | func convertJsonArrayToList (jsonArray) = split(jsonArray, ",") | |
54 | + | ||
55 | + | ||
56 | + | let neutrinoContract = addressFromStringValue(getStringByKey(NeutrinoContractKey)) | |
57 | + | ||
58 | + | let controlContract = addressFromStringValue(getStringByAddressAndKey(neutrinoContract, ControlContractKey)) | |
59 | + | ||
60 | + | let neutrinoAssetId = fromBase58String(getStringByAddressAndKey(neutrinoContract, NeutrinoAssetIdKey)) | |
61 | + | ||
62 | + | let nsbtAssetIdStr = getStringByAddressAndKey(neutrinoContract, NsbtAssetIdKey) | |
63 | + | ||
64 | + | let nsbtAssetId = fromBase58String(nsbtAssetIdStr) | |
65 | + | ||
66 | + | func getContractBalance (assetId) = getNumberByKey(getContractBalanceKey(assetId)) | |
67 | + | ||
68 | + | ||
69 | + | func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId)) | |
26 | 70 | ||
27 | 71 | ||
28 | 72 | func getRewardsConfigKey (owner,share,receiver) = makeString(["stakingconfig", owner, toString(share), receiver], "_") | |
29 | 73 | ||
30 | 74 | ||
31 | - | func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId)) | |
75 | + | func getCurrentRewardsConfigKey (owner) = ("stakingconfig_current_" + owner) | |
76 | + | ||
77 | + | ||
78 | + | func getRewardsConfigStartKey (configKey,isStart) = (configKey + (if (isStart) | |
79 | + | then "_start" | |
80 | + | else "_end")) | |
81 | + | ||
82 | + | ||
83 | + | func getRewardConfigInitialShare (owner) = (owner + "_initialShare") | |
32 | 84 | ||
33 | 85 | ||
34 | 86 | func getValidStakingAssetOrFail (stakingType,assetId) = if (if ((stakingType == USDNTYPE)) | |
44 | 96 | else false) | |
45 | 97 | then throw(("unsupported staking type " + stakingType)) | |
46 | 98 | else assetId | |
47 | - | ||
48 | - | ||
49 | - | func getCurrentRewardsConfigKey (owner) = ("stakingconfig_current_" + owner) | |
50 | - | ||
51 | - | ||
52 | - | func getRewardsConfigStartKey (configKey,isStart) = (configKey + (if (isStart) | |
53 | - | then "_start" | |
54 | - | else "_end")) | |
55 | - | ||
56 | - | ||
57 | - | func getContractBalanceKey (assetId) = ((BalanceKey + "_") + assetId) | |
58 | - | ||
59 | - | ||
60 | - | func getContractBalance (assetId) = getNumberByKey(getContractBalanceKey(assetId)) | |
61 | - | ||
62 | - | ||
63 | - | func internalUnlock (stakingType,i,unlockAmount,assetIdParam) = { | |
64 | - | let account = toString(i.caller) | |
65 | - | let assetId = getValidStakingAssetOrFail(stakingType, fromBase58String(assetIdParam)) | |
66 | - | let assetIdString = toBase58String(assetId) | |
67 | - | let balance = (getUserBalance(account, assetIdString) - unlockAmount) | |
68 | - | if ((0 > balance)) | |
69 | - | then throw("invalid amount") | |
70 | - | else [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, assetId)] | |
71 | - | } | |
72 | 99 | ||
73 | 100 | ||
74 | 101 | func internalLockNeutrino (stakingType,i,receiver,share) = { | |
112 | 139 | let start = if (isNewConfig) | |
113 | 140 | then height | |
114 | 141 | else getNumberByKey(getRewardsConfigStartKey(newCurrentConfig, true)) | |
115 | - | [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)] | |
142 | + | $Tuple2([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)], unit) | |
116 | 143 | } | |
117 | 144 | } | |
118 | 145 | ||
119 | 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 $Tuple2([IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, assetId)], unit) | |
155 | + | } | |
156 | + | ||
157 | + | ||
158 | + | @Callable(i) | |
159 | + | func lockNeutrinoSP (receiver,share) = internalLockNeutrino(USDNTYPE, i, receiver, share) | |
160 | + | ||
161 | + | ||
162 | + | ||
120 | 163 | @Callable(i) | |
121 | 164 | func lockNeutrino () = internalLockNeutrino(USDNTYPE, i, toString(i.caller), 100) | |
165 | + | ||
166 | + | ||
167 | + | ||
168 | + | @Callable(i) | |
169 | + | func lockNsbtSP (receiver,share) = internalLockNeutrino(NSBTTYPE, i, receiver, share) | |
122 | 170 | ||
123 | 171 | ||
124 | 172 | ||
137 | 185 | ||
138 | 186 | ||
139 | 187 | @Verifier(tx) | |
140 | - | func verify () = match tx { | |
141 | - | case _ => | |
142 | - | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
143 | - | } | |
188 | + | func verify () = { | |
189 | + | let pubKeyAdminsList = ["GFmKZ2naZFRoCvNbwKAQVGmLb1uBeWGDgFabdGBuZiuy", "GmJXRyhRA79g8yUGgKBAVdnFfQFDMjQG98b1MmLDh5kk", "CFhbV6h41hVjbGHudGtS3fYUv7QAKRxFQzKNtx4B5PqP", "Kn7NpzaG12dLZgcHf2ipUftU6hbJygmrhFqQYE4B7ZK"] | |
190 | + | let count = ((((if (sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(pubKeyAdminsList[0]))) | |
191 | + | then 1 | |
192 | + | else 0) + (if (sigVerify(tx.bodyBytes, tx.proofs[1], fromBase58String(pubKeyAdminsList[1]))) | |
193 | + | then 1 | |
194 | + | else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[2], fromBase58String(pubKeyAdminsList[2]))) | |
195 | + | then 1 | |
196 | + | else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[3], fromBase58String(pubKeyAdminsList[3]))) | |
197 | + | then 2 | |
198 | + | else 0)) | |
199 | + | (count >= 3) | |
200 | + | } | |
144 | 201 |
Old | New | Differences | |
---|---|---|---|
1 | - | {-# STDLIB_VERSION | |
1 | + | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | ||
4 | + | func getNumberByKey (key) = valueOrElse(getInteger(this, key), 0) | |
5 | 5 | ||
6 | - | let nsbtAssetId = base58'36mg8NZTaFRDygiVwb8uBnLR51hetJruUCZcxhaVcHj9' | |
7 | 6 | ||
8 | - | let NeutrinoContractKey = base58'3N6q7sCGSSLBUXDdjBdYGTJbZGZfhhh8cNg' | |
7 | + | func getStringByKey (key) = valueOrElse(getString(this, key), "") | |
8 | + | ||
9 | + | ||
10 | + | func getBoolByKey (key) = valueOrElse(getBoolean(this, key), false) | |
11 | + | ||
12 | + | ||
13 | + | func getNumberByAddressAndKey (address,key) = valueOrElse(getInteger(addressFromStringValue(address), key), 0) | |
14 | + | ||
15 | + | ||
16 | + | func getStringByAddressAndKey (address,key) = valueOrElse(getString(address, key), "") | |
17 | + | ||
18 | + | ||
19 | + | let NeutrinoAssetIdKey = "neutrino_asset_id" | |
20 | + | ||
21 | + | let NeutrinoContractKey = "neutrino_contract" | |
22 | + | ||
23 | + | let BalanceKey = "rpd_balance" | |
24 | + | ||
25 | + | let ControlContractKey = "control_contract" | |
26 | + | ||
27 | + | let NsbtAssetIdKey = "bond_asset_id" | |
28 | + | ||
29 | + | let AdminsKey = "admins" | |
9 | 30 | ||
10 | 31 | let USDNTYPE = "USDN" | |
11 | 32 | ||
12 | 33 | let NSBTTYPE = "NSBT" | |
13 | 34 | ||
14 | - | let BalanceKey = "rpd_balance" | |
15 | - | ||
16 | 35 | func getUserBalanceKey (owner,assetId) = makeString([BalanceKey, assetId, owner], "_") | |
17 | 36 | ||
18 | 37 | ||
19 | - | func | |
38 | + | func getContractBalanceKey (assetId) = ((BalanceKey + "_") + assetId) | |
20 | 39 | ||
21 | 40 | ||
22 | - | func | |
41 | + | func getExpireProposalKey (hash) = (("proposal_expire" + "_") + hash) | |
23 | 42 | ||
24 | 43 | ||
25 | - | func getRewardConfigInitialShare (owner) = (owner + "_initialShare") | |
44 | + | func getOwnerProposalKey (hash) = (("proposal_owner" + "_") + hash) | |
45 | + | ||
46 | + | ||
47 | + | func getArgumentsProposalKey (hash) = (("proposal_arguments" + "_") + hash) | |
48 | + | ||
49 | + | ||
50 | + | func getVoteKey (owner,hash) = (((("proposal_vote" + "_") + owner) + "_") + hash) | |
51 | + | ||
52 | + | ||
53 | + | func convertJsonArrayToList (jsonArray) = split(jsonArray, ",") | |
54 | + | ||
55 | + | ||
56 | + | let neutrinoContract = addressFromStringValue(getStringByKey(NeutrinoContractKey)) | |
57 | + | ||
58 | + | let controlContract = addressFromStringValue(getStringByAddressAndKey(neutrinoContract, ControlContractKey)) | |
59 | + | ||
60 | + | let neutrinoAssetId = fromBase58String(getStringByAddressAndKey(neutrinoContract, NeutrinoAssetIdKey)) | |
61 | + | ||
62 | + | let nsbtAssetIdStr = getStringByAddressAndKey(neutrinoContract, NsbtAssetIdKey) | |
63 | + | ||
64 | + | let nsbtAssetId = fromBase58String(nsbtAssetIdStr) | |
65 | + | ||
66 | + | func getContractBalance (assetId) = getNumberByKey(getContractBalanceKey(assetId)) | |
67 | + | ||
68 | + | ||
69 | + | func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId)) | |
26 | 70 | ||
27 | 71 | ||
28 | 72 | func getRewardsConfigKey (owner,share,receiver) = makeString(["stakingconfig", owner, toString(share), receiver], "_") | |
29 | 73 | ||
30 | 74 | ||
31 | - | func getUserBalance (owner,assetId) = getNumberByKey(getUserBalanceKey(owner, assetId)) | |
75 | + | func getCurrentRewardsConfigKey (owner) = ("stakingconfig_current_" + owner) | |
76 | + | ||
77 | + | ||
78 | + | func getRewardsConfigStartKey (configKey,isStart) = (configKey + (if (isStart) | |
79 | + | then "_start" | |
80 | + | else "_end")) | |
81 | + | ||
82 | + | ||
83 | + | func getRewardConfigInitialShare (owner) = (owner + "_initialShare") | |
32 | 84 | ||
33 | 85 | ||
34 | 86 | func getValidStakingAssetOrFail (stakingType,assetId) = if (if ((stakingType == USDNTYPE)) | |
35 | 87 | then (assetId != neutrinoAssetId) | |
36 | 88 | else false) | |
37 | 89 | then throw("can use USDN only") | |
38 | 90 | else if (if ((stakingType == NSBTTYPE)) | |
39 | 91 | then (assetId != nsbtAssetId) | |
40 | 92 | else false) | |
41 | 93 | then throw("can use NSBT only") | |
42 | 94 | else if (if ((stakingType != USDNTYPE)) | |
43 | 95 | then (stakingType != NSBTTYPE) | |
44 | 96 | else false) | |
45 | 97 | then throw(("unsupported staking type " + stakingType)) | |
46 | 98 | else assetId | |
47 | - | ||
48 | - | ||
49 | - | func getCurrentRewardsConfigKey (owner) = ("stakingconfig_current_" + owner) | |
50 | - | ||
51 | - | ||
52 | - | func getRewardsConfigStartKey (configKey,isStart) = (configKey + (if (isStart) | |
53 | - | then "_start" | |
54 | - | else "_end")) | |
55 | - | ||
56 | - | ||
57 | - | func getContractBalanceKey (assetId) = ((BalanceKey + "_") + assetId) | |
58 | - | ||
59 | - | ||
60 | - | func getContractBalance (assetId) = getNumberByKey(getContractBalanceKey(assetId)) | |
61 | - | ||
62 | - | ||
63 | - | func internalUnlock (stakingType,i,unlockAmount,assetIdParam) = { | |
64 | - | let account = toString(i.caller) | |
65 | - | let assetId = getValidStakingAssetOrFail(stakingType, fromBase58String(assetIdParam)) | |
66 | - | let assetIdString = toBase58String(assetId) | |
67 | - | let balance = (getUserBalance(account, assetIdString) - unlockAmount) | |
68 | - | if ((0 > balance)) | |
69 | - | then throw("invalid amount") | |
70 | - | else [IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, assetId)] | |
71 | - | } | |
72 | 99 | ||
73 | 100 | ||
74 | 101 | func internalLockNeutrino (stakingType,i,receiver,share) = { | |
75 | 102 | let pmt = value(i.payments[0]) | |
76 | 103 | let assetId = getValidStakingAssetOrFail(stakingType, value(pmt.assetId)) | |
77 | 104 | if (!(isDefined(addressFromString(receiver)))) | |
78 | 105 | then throw(("Invalid address format " + receiver)) | |
79 | 106 | else if ((share > 100)) | |
80 | 107 | then throw("staking rewards share cannot be higher than 100%") | |
81 | 108 | else if ((1 > share)) | |
82 | 109 | then throw("staking rewards share cannot be lower than 1%") | |
83 | 110 | else { | |
84 | 111 | let account = toString(i.caller) | |
85 | 112 | let assetIdString = toBase58String(assetId) | |
86 | 113 | let currentConfig = getStringByKey(getCurrentRewardsConfigKey(account)) | |
87 | 114 | let correctData = if ((currentConfig != "")) | |
88 | 115 | then { | |
89 | 116 | let currentConfigData = split(currentConfig, "_") | |
90 | 117 | let currShare = parseIntValue(currentConfigData[2]) | |
91 | 118 | let currReceiver = currentConfigData[3] | |
92 | 119 | let notMigratedInitialShare = getNumberByKey(getRewardConfigInitialShare(account)) | |
93 | 120 | let actualInitialShare = if ((notMigratedInitialShare == 0)) | |
94 | 121 | then currShare | |
95 | 122 | else notMigratedInitialShare | |
96 | 123 | let newShare = if (if ((actualInitialShare > share)) | |
97 | 124 | then true | |
98 | 125 | else (currReceiver != receiver)) | |
99 | 126 | then actualInitialShare | |
100 | 127 | else share | |
101 | 128 | [toString(actualInitialShare), toString(newShare), currReceiver] | |
102 | 129 | } | |
103 | 130 | else [toString(share), toString(share), receiver] | |
104 | 131 | let correctInitialShare = parseIntValue(correctData[0]) | |
105 | 132 | let correctShare = parseIntValue(correctData[1]) | |
106 | 133 | let correctReceiver = correctData[2] | |
107 | 134 | let newCurrentConfig = getRewardsConfigKey(account, correctShare, correctReceiver) | |
108 | 135 | let isNewConfig = !((currentConfig == newCurrentConfig)) | |
109 | 136 | let end = if (isNewConfig) | |
110 | 137 | then height | |
111 | 138 | else 0 | |
112 | 139 | let start = if (isNewConfig) | |
113 | 140 | then height | |
114 | 141 | else getNumberByKey(getRewardsConfigStartKey(newCurrentConfig, true)) | |
115 | - | [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)] | |
142 | + | $Tuple2([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)], unit) | |
116 | 143 | } | |
117 | 144 | } | |
118 | 145 | ||
119 | 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 $Tuple2([IntegerEntry(getContractBalanceKey(assetIdString), (getContractBalance(assetIdString) - unlockAmount)), IntegerEntry(getUserBalanceKey(account, assetIdString), balance), ScriptTransfer(addressFromStringValue(account), unlockAmount, assetId)], unit) | |
155 | + | } | |
156 | + | ||
157 | + | ||
158 | + | @Callable(i) | |
159 | + | func lockNeutrinoSP (receiver,share) = internalLockNeutrino(USDNTYPE, i, receiver, share) | |
160 | + | ||
161 | + | ||
162 | + | ||
120 | 163 | @Callable(i) | |
121 | 164 | func lockNeutrino () = internalLockNeutrino(USDNTYPE, i, toString(i.caller), 100) | |
165 | + | ||
166 | + | ||
167 | + | ||
168 | + | @Callable(i) | |
169 | + | func lockNsbtSP (receiver,share) = internalLockNeutrino(NSBTTYPE, i, receiver, share) | |
122 | 170 | ||
123 | 171 | ||
124 | 172 | ||
125 | 173 | @Callable(i) | |
126 | 174 | func lockNsbt () = internalLockNeutrino(NSBTTYPE, i, toString(i.caller), 100) | |
127 | 175 | ||
128 | 176 | ||
129 | 177 | ||
130 | 178 | @Callable(i) | |
131 | 179 | func unlockNeutrino (unlockAmount,assetIdString) = internalUnlock(USDNTYPE, i, unlockAmount, assetIdString) | |
132 | 180 | ||
133 | 181 | ||
134 | 182 | ||
135 | 183 | @Callable(i) | |
136 | 184 | func unlockNsbt (unlockAmount,assetIdString) = internalUnlock(NSBTTYPE, i, unlockAmount, assetIdString) | |
137 | 185 | ||
138 | 186 | ||
139 | 187 | @Verifier(tx) | |
140 | - | func verify () = match tx { | |
141 | - | case _ => | |
142 | - | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
143 | - | } | |
188 | + | func verify () = { | |
189 | + | let pubKeyAdminsList = ["GFmKZ2naZFRoCvNbwKAQVGmLb1uBeWGDgFabdGBuZiuy", "GmJXRyhRA79g8yUGgKBAVdnFfQFDMjQG98b1MmLDh5kk", "CFhbV6h41hVjbGHudGtS3fYUv7QAKRxFQzKNtx4B5PqP", "Kn7NpzaG12dLZgcHf2ipUftU6hbJygmrhFqQYE4B7ZK"] | |
190 | + | let count = ((((if (sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(pubKeyAdminsList[0]))) | |
191 | + | then 1 | |
192 | + | else 0) + (if (sigVerify(tx.bodyBytes, tx.proofs[1], fromBase58String(pubKeyAdminsList[1]))) | |
193 | + | then 1 | |
194 | + | else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[2], fromBase58String(pubKeyAdminsList[2]))) | |
195 | + | then 1 | |
196 | + | else 0)) + (if (sigVerify(tx.bodyBytes, tx.proofs[3], fromBase58String(pubKeyAdminsList[3]))) | |
197 | + | then 2 | |
198 | + | else 0)) | |
199 | + | (count >= 3) | |
200 | + | } | |
144 | 201 |
github/deemru/w8io/026f985 35.53 ms ◑