tx · 9oVmtXc14ZJfo7dwmYj9qdGnC9i5y8C4MnhTyxbdTW7p

3MpMuGN8rW9EpPwzETAQz88Pe9TQhSwiriq:  -0.01400000 Waves

2023.07.21 15:10 [2675596] smart account 3MpMuGN8rW9EpPwzETAQz88Pe9TQhSwiriq > SELF 0.00000000 Waves

{ "type": 13, "id": "9oVmtXc14ZJfo7dwmYj9qdGnC9i5y8C4MnhTyxbdTW7p", "fee": 1400000, "feeAssetId": null, "timestamp": 1689941454364, "version": 2, "chainId": 84, "sender": "3MpMuGN8rW9EpPwzETAQz88Pe9TQhSwiriq", "senderPublicKey": "57SkjQUEwC1ayCqLbXLuzBqifK6B6SR6rfxtGsbAo3zW", "proofs": [ "HbAeaF2dsEEPT4s9j5LcA4h39RPhVycQb3SqXZP4NTdFuyFkRgKRanqNjFQjxp9ja5y9dsBtu8GzwqssSma88KQ" ], "script": "base64:BgIfCAISAwoBARIAEgMKAQgSAwoBARIDCgEIEgASAwoBCC0ADGNvbnRyYWN0RmlsZQIQbXB0X3N0YWtpbmcucmlkZQADU0VQAgJfXwAGc2NhbGU4AIDC1y8AEkFERFJFU1NfQllURVNfU0laRQAaAA1CTE9DS1NfSU5fREFZAAoBCHRocm93RXJyAQNtc2cJAAIBCQCsAgIJAKwCAgUMY29udHJhY3RGaWxlAgI6IAUDbXNnAAprZXlBc3NldElkCQC5CQIJAMwIAgICJXMJAMwIAgIHYXNzZXRJZAUDbmlsBQNTRVAAE2tleUVtaXNzaW9uUGVyQmxvY2sJALkJAgkAzAgCAgIlcwkAzAgCAhBlbWlzc2lvblBlckJsb2NrBQNuaWwFA1NFUAANa2V5U3RhcnRCbG9jawkAuQkCCQDMCAICAiVzCQDMCAICCnN0YXJ0QmxvY2sFA25pbAUDU0VQABBrZXlUb3RhbExwQW1vdW50CQC5CQIJAMwIAgICJXMJAMwIAgINdG90YWxMcEFtb3VudAUDbmlsBQNTRVAAE2tleVRvdGFsQXNzZXRBbW91bnQJALkJAgkAzAgCAgIlcwkAzAgCAhB0b3RhbEFzc2V0QW1vdW50BQNuaWwFA1NFUAEPa2V5VXNlckxwQW1vdW50AQt1c2VyQWRkcmVzcwkAuQkCCQDMCAICBCVzJXMJAMwIAgIMdXNlckxwQW1vdW50CQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwFA1NFUAEaa2V5VXNlclRvdGFsQXNzZXRXaXRoZHJhd24BC3VzZXJBZGRyZXNzCQC5CQIJAMwIAgIEJXMlcwkAzAgCAhN0b3RhbEFzc2V0V2l0aGRyYXduCQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwFA1NFUAEXa2V5VXNlclRvdGFsQXNzZXRTdGFrZWQBC3VzZXJBZGRyZXNzCQC5CQIJAMwIAgIEJXMlcwkAzAgCAhB0b3RhbEFzc2V0U3Rha2VkCQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwFA1NFUAANdG90YWxMcEFtb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBRBrZXlUb3RhbExwQW1vdW50AAAAEHRvdGFsQXNzZXRBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUTa2V5VG90YWxBc3NldEFtb3VudAAAAA1hc3NldElkU3RyaW5nCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFCmtleUFzc2V0SWQCBVdBVkVTAAxhc3NldElkQnl0ZXMDCQAAAgUNYXNzZXRJZFN0cmluZwIFV0FWRVMFBHVuaXQJANkEAQUNYXNzZXRJZFN0cmluZwAOZW1pc3Npb25QZXJEYXkJAGgCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFE2tleUVtaXNzaW9uUGVyQmxvY2sAAAUNQkxPQ0tTX0lOX0RBWQAMaGVpZ2h0SW5EYXlzCQBrAwUGaGVpZ2h0AAEFDUJMT0NLU19JTl9EQVkAD0FETUlOX0xJU1RfU0laRQAFAAZRVU9SVU0AAwARVFhJRF9CWVRFU19MRU5HVEgAIAEYa2V5QWxsb3dlZFR4SWRWb3RlUHJlZml4AQR0eElkCQC5CQIJAMwIAgIGJXMlcyVzCQDMCAICCWFsbG93VHhJZAkAzAgCBQR0eElkBQNuaWwFA1NFUAEQa2V5RnVsbEFkbWluVm90ZQIGcHJlZml4DGFkbWluQWRkcmVzcwkAuQkCCQDMCAIFBnByZWZpeAkAzAgCBQxhZG1pbkFkZHJlc3MFA25pbAUDU0VQARNrZXlBZG1pbkFkZHJlc3NMaXN0AAkAuQkCCQDMCAICAiVzCQDMCAICEGFkbWluQWRkcmVzc0xpc3QFA25pbAUDU0VQAQ5rZXlBbGxvd2VkVHhJZAAJALkJAgkAzAgCAgIlcwkAzAgCAgR0eElkBQNuaWwFA1NFUAEMZ2V0QWRtaW5Wb3RlAgZwcmVmaXgFYWRtaW4EB3ZvdGVLZXkJARBrZXlGdWxsQWRtaW5Wb3RlAgUGcHJlZml4BQVhZG1pbgkBC3ZhbHVlT3JFbHNlAgkAnwgBBQd2b3RlS2V5AAABDWdldEFkbWluc0xpc3QABAckbWF0Y2gwCQCdCAIFBHRoaXMJARNrZXlBZG1pbkFkZHJlc3NMaXN0AAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAJALUJAgUBcwUDU0VQBQNuaWwBDWlzSW5BZG1pbkxpc3QBB2FkZHJlc3MJAQ9jb250YWluc0VsZW1lbnQCCQENZ2V0QWRtaW5zTGlzdAAFB2FkZHJlc3MBEmdlblZvdGVzS2V5c0hlbHBlcgIBYQxhZG1pbkFkZHJlc3MECyR0MDI0MDgyNDMyBQFhBAZyZXN1bHQIBQskdDAyNDA4MjQzMgJfMQQGcHJlZml4CAULJHQwMjQwODI0MzICXzIJAJQKAgkAzQgCBQZyZXN1bHQJARBrZXlGdWxsQWRtaW5Wb3RlAgUGcHJlZml4BQxhZG1pbkFkZHJlc3MFBnByZWZpeAEMZ2VuVm90ZXNLZXlzAQlrZXlQcmVmaXgECWFkbWluTGlzdAkBE2tleUFkbWluQWRkcmVzc0xpc3QABAskdDAyNTc5MjY2MwoAAiRsCQENZ2V0QWRtaW5zTGlzdAAKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFA25pbAUJa2V5UHJlZml4CgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARJnZW5Wb3Rlc0tleXNIZWxwZXICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDUJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFBAZyZXN1bHQIBQskdDAyNTc5MjY2MwJfMQQGcHJlZml4CAULJHQwMjU3OTI2NjMCXzIFBnJlc3VsdAEQY291bnRWb3Rlc0hlbHBlcgIGcmVzdWx0B3ZvdGVLZXkJAGQCBQZyZXN1bHQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUHdm90ZUtleQAAAQpjb3VudFZvdGVzAQZwcmVmaXgEBXZvdGVzCQEMZ2VuVm90ZXNLZXlzAQUGcHJlZml4CgACJGwFBXZvdGVzCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARBjb3VudFZvdGVzSGVscGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA1CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQEQY2xlYXJWb3Rlc0hlbHBlcgIGcmVzdWx0A2tleQkAzQgCBQZyZXN1bHQJAQtEZWxldGVFbnRyeQEFA2tleQETZ2V0Q2xlYXJWb3RlRW50cmllcwEGcHJlZml4BAV2b3RlcwkBDGdlblZvdGVzS2V5cwEFBnByZWZpeAoAAiRsBQV2b3RlcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEQY2xlYXJWb3Rlc0hlbHBlcgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgNQkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUBDHZvdGVJTlRFUk5BTAQTY2FsbGVyQWRkcmVzc1N0cmluZwlrZXlQcmVmaXgIbWluVm90ZXMKdm90ZVJlc3VsdAQHdm90ZUtleQkBEGtleUZ1bGxBZG1pblZvdGUCBQlrZXlQcmVmaXgFE2NhbGxlckFkZHJlc3NTdHJpbmcEEGFkbWluQ3VycmVudFZvdGUJAQxnZXRBZG1pblZvdGUCBQlrZXlQcmVmaXgFE2NhbGxlckFkZHJlc3NTdHJpbmcEA2VycgMJAQEhAQkBDWlzSW5BZG1pbkxpc3QBBRNjYWxsZXJBZGRyZXNzU3RyaW5nCQEIdGhyb3dFcnIBCQCsAgIJAKwCAgIJQWRkcmVzczogBRNjYWxsZXJBZGRyZXNzU3RyaW5nAhIgbm90IGluIEFkbWluIGxpc3QDCQAAAgUQYWRtaW5DdXJyZW50Vm90ZQABCQEIdGhyb3dFcnIBCQCsAgIFB3ZvdGVLZXkCEiB5b3UgYWxyZWFkeSB2b3RlZAUEdW5pdAMJAAACBQNlcnIFA2VycgQFdm90ZXMJAQpjb3VudFZvdGVzAQUJa2V5UHJlZml4AwkAZwIJAGQCBQV2b3RlcwABBQhtaW5Wb3RlcwQQY2xlYXJWb3RlRW50cmllcwkBE2dldENsZWFyVm90ZUVudHJpZXMBBQlrZXlQcmVmaXgJAM4IAgUQY2xlYXJWb3RlRW50cmllcwUKdm90ZVJlc3VsdAkAzAgCCQEMSW50ZWdlckVudHJ5AgUHdm90ZUtleQABBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BD2NhbGNUb3RhbFByb2ZpdAAECnN0YXJ0QmxvY2sJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUNa2V5U3RhcnRCbG9jawAABAhzdGFydERheQkAawMFCnN0YXJ0QmxvY2sAAQUNQkxPQ0tTX0lOX0RBWQQLZWxhcHNlZERheXMJAGUCBQxoZWlnaHRJbkRheXMFCHN0YXJ0RGF5CQCWAwEJAMwIAgAACQDMCAIJAGgCBQ5lbWlzc2lvblBlckRheQULZWxhcHNlZERheXMFA25pbAEJZGVidWdEYXlzAAQKc3RhcnRCbG9jawkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQ1rZXlTdGFydEJsb2NrAAAECHN0YXJ0RGF5CQBrAwUKc3RhcnRCbG9jawABBQ1CTE9DS1NfSU5fREFZBAtlbGFwc2VkRGF5cwkAZQIFDGhlaWdodEluRGF5cwUIc3RhcnREYXkJAJUKAwUIc3RhcnREYXkFDGhlaWdodEluRGF5cwULZWxhcHNlZERheXMBK2dldFRvdGFsQXNzZXRBbW91bnRXaXRoUHJvZml0T3JNYXhBdmFpbGFibGUABBp0b3RhbEFzc2V0QW1vdW50V2l0aFByb2ZpdAkAZAIFEHRvdGFsQXNzZXRBbW91bnQJAQ9jYWxjVG90YWxQcm9maXQABAt0b3RhbEFtb3VudAQHJG1hdGNoMAUMYXNzZXRJZEJ5dGVzAwkAAQIFByRtYXRjaDACBFVuaXQEAXUFByRtYXRjaDAJAJcDAQkAzAgCBRp0b3RhbEFzc2V0QW1vdW50V2l0aFByb2ZpdAkAzAgCCAkA7wcBBQR0aGlzCWF2YWlsYWJsZQUDbmlsAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAWIFByRtYXRjaDAJAJcDAQkAzAgCBRp0b3RhbEFzc2V0QW1vdW50V2l0aFByb2ZpdAkAzAgCCQDwBwIFBHRoaXMFAWIFA25pbAkAAgECC01hdGNoIGVycm9yAwkAAAIFDXRvdGFsTHBBbW91bnQAAAAABQt0b3RhbEFtb3VudAEPZ2V0Q3VycmVudFByaWNlAAMJAQIhPQIFDXRvdGFsTHBBbW91bnQAAAkAawMJAStnZXRUb3RhbEFzc2V0QW1vdW50V2l0aFByb2ZpdE9yTWF4QXZhaWxhYmxlAAUGc2NhbGU4BQ10b3RhbExwQW1vdW50CQBoAgABBQZzY2FsZTgBD2dldFVzZXJMcEFtb3VudAELdXNlckFkZHJlc3MJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBD2tleVVzZXJMcEFtb3VudAEFC3VzZXJBZGRyZXNzAAABIGdldFVzZXJBdmFpbGFibGVBc3NldHNUb1dpdGhkcmF3AQt1c2VyQWRkcmVzcwQMdXNlckxwQW1vdW50CQEPZ2V0VXNlckxwQW1vdW50AQULdXNlckFkZHJlc3MEHHVzZXJBdmFpbGFibGVBc3NldFRvV2l0aGRyYXcJAGsDBQx1c2VyTHBBbW91bnQJAQ9nZXRDdXJyZW50UHJpY2UABQZzY2FsZTgDCQBmAgkBD2dldEN1cnJlbnRQcmljZQAJAGgCBRx1c2VyQXZhaWxhYmxlQXNzZXRUb1dpdGhkcmF3BQZzY2FsZTgAAAUcdXNlckF2YWlsYWJsZUFzc2V0VG9XaXRoZHJhdwEPZ2V0U3Rha2VBY3Rpb25zAgFpC3VzZXJBZGRyZXNzBAZjaGVja3MJAMwIAgMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEGCQEIdGhyb3dFcnIBAhhzaG91bGQgaW5jbHVkZSAxIHBheW1lbnQJAMwIAgMJAAACCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFDGFzc2V0SWRCeXRlcwYJAQh0aHJvd0VycgEJAKwCAgIVcGF5bWVudCBzaG91bGQgYmUgaW4gBQ1hc3NldElkU3RyaW5nCQDMCAIDCQBmAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQAAAYCJ3BheW1lbnQgYW1vdW50IHNob3VsZCBiZSBncmVhdGVyIHRoYW4gMAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBA1wYXltZW50QW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQPcGF5bWVudExwQW1vdW50CQBrAwUNcGF5bWVudEFtb3VudAUGc2NhbGU4CQEPZ2V0Q3VycmVudFByaWNlAAQMdXNlckxwQW1vdW50CQEPZ2V0VXNlckxwQW1vdW50AQULdXNlckFkZHJlc3MEFXVzZXJUb3RhbFN0YWtlZEFtb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEXa2V5VXNlclRvdGFsQXNzZXRTdGFrZWQBBQt1c2VyQWRkcmVzcwAABBBuZXdUb3RhbExwQW1vdW50CQBkAgUNdG90YWxMcEFtb3VudAUPcGF5bWVudExwQW1vdW50BBNuZXdUb3RhbEFzc2V0QW1vdW50CQBkAgUQdG90YWxBc3NldEFtb3VudAUNcGF5bWVudEFtb3VudAQPbmV3VXNlckxwQW1vdW50CQBkAgUMdXNlckxwQW1vdW50BQ9wYXltZW50THBBbW91bnQEGG5ld1VzZXJUb3RhbFN0YWtlZEFtb3VudAkAZAIFFXVzZXJUb3RhbFN0YWtlZEFtb3VudAUNcGF5bWVudEFtb3VudAQXdXBkYXRlU3RhcnRIZWlnaHRBY3Rpb24DCQAAAgUNdG90YWxMcEFtb3VudAAACQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ1rZXlTdGFydEJsb2NrBQZoZWlnaHQFA25pbAUDbmlsCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFEGtleVRvdGFsTHBBbW91bnQFEG5ld1RvdGFsTHBBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFE2tleVRvdGFsQXNzZXRBbW91bnQFE25ld1RvdGFsQXNzZXRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ9rZXlVc2VyTHBBbW91bnQBBQt1c2VyQWRkcmVzcwUPbmV3VXNlckxwQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEXa2V5VXNlclRvdGFsQXNzZXRTdGFrZWQBBQt1c2VyQWRkcmVzcwUYbmV3VXNlclRvdGFsU3Rha2VkQW1vdW50BQNuaWwFF3VwZGF0ZVN0YXJ0SGVpZ2h0QWN0aW9uCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARJnZXRXaXRoZHJhd0FjdGlvbnMCAWkVbHBBc3NldFdpdGhkcmF3QW1vdW50BAt1c2VyQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEDHVzZXJMcEFtb3VudAkBD2dldFVzZXJMcEFtb3VudAEFC3VzZXJBZGRyZXNzBAVjaGVjawkAzAgCAwkAZgIFFWxwQXNzZXRXaXRoZHJhd0Ftb3VudAAABgkBCHRocm93RXJyAQIcYW1vdW50IHNob3VsZCBiZSBtb3JlIHRoYW4gMAkAzAgCAwkAZwIFDHVzZXJMcEFtb3VudAUVbHBBc3NldFdpdGhkcmF3QW1vdW50BgkBCHRocm93RXJyAQkArAICCQCsAgICJWNhbm5vdCB3aXRoZHJhdyBtb3JlIHRoYW4gYXZhaWxhYmxlICgJAKQDAQUMdXNlckxwQW1vdW50AgEpBQNuaWwDCQAAAgUFY2hlY2sFBWNoZWNrBA9uZXdVc2VyTHBBbW91bnQJAGUCBQx1c2VyTHBBbW91bnQFFWxwQXNzZXRXaXRoZHJhd0Ftb3VudAQTd2l0aGRyYXdBc3NldEFtb3VudAkAawMFFWxwQXNzZXRXaXRoZHJhd0Ftb3VudAkBD2dldEN1cnJlbnRQcmljZQAFBnNjYWxlOAQQbmV3VG90YWxMcEFtb3VudAkAZQIFDXRvdGFsTHBBbW91bnQFFWxwQXNzZXRXaXRoZHJhd0Ftb3VudAQTbmV3VG90YWxBc3NldEFtb3VudAkAawMFEG5ld1RvdGFsTHBBbW91bnQJAQ9nZXRDdXJyZW50UHJpY2UABQZzY2FsZTgEF3VzZXJUb3RhbEFzc2V0V2l0aGRyYXduCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJARprZXlVc2VyVG90YWxBc3NldFdpdGhkcmF3bgEFC3VzZXJBZGRyZXNzAAAEGm5ld1VzZXJUb3RhbEFzc2V0V2l0aGRyYXduCQBkAgUXdXNlclRvdGFsQXNzZXRXaXRoZHJhd24FE3dpdGhkcmF3QXNzZXRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFEGtleVRvdGFsTHBBbW91bnQFEG5ld1RvdGFsTHBBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFE2tleVRvdGFsQXNzZXRBbW91bnQFE25ld1RvdGFsQXNzZXRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ9rZXlVc2VyTHBBbW91bnQBBQt1c2VyQWRkcmVzcwUPbmV3VXNlckxwQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEaa2V5VXNlclRvdGFsQXNzZXRXaXRoZHJhd24BBQt1c2VyQWRkcmVzcwUabmV3VXNlclRvdGFsQXNzZXRXaXRoZHJhd24JAMwIAgkBDEludGVnZXJFbnRyeQIFDWtleVN0YXJ0QmxvY2sFBmhlaWdodAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFE3dpdGhkcmF3QXNzZXRBbW91bnQFDGFzc2V0SWRCeXRlcwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBwFpARNzZXRFbWlzc2lvblBlckJsb2NrARBlbWlzc2lvblBlckJsb2NrBAVjaGVjawkAzAgCAwkAAAIIBQFpBmNhbGxlcgUEdGhpcwYJAQh0aHJvd0VycgECEXBlcm1pc3Npb24gZGVuaWVkBQNuaWwDCQAAAgUFY2hlY2sFBWNoZWNrCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNrZXlUb3RhbEFzc2V0QW1vdW50CQErZ2V0VG90YWxBc3NldEFtb3VudFdpdGhQcm9maXRPck1heEF2YWlsYWJsZQAJAMwIAgkBDEludGVnZXJFbnRyeQIFDWtleVN0YXJ0QmxvY2sFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgUTa2V5RW1pc3Npb25QZXJCbG9jawkAlgMBCQDMCAIAAAkAzAgCBRBlbWlzc2lvblBlckJsb2NrBQNuaWwFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQVzdGFrZQAJAQ9nZXRTdGFrZUFjdGlvbnMCBQFpCQClCAEIBQFpBmNhbGxlcgFpAQhzdGFrZUZvcgELdXNlckFkZHJlc3MEBWNoZWNrCQDMCAIDCQAAAgkAyAEBCQDZBAEFC3VzZXJBZGRyZXNzBRJBRERSRVNTX0JZVEVTX1NJWkUGCQEIdGhyb3dFcnIBAhRhZGRyZXNzIGlzIG5vdCB2YWxpZAUDbmlsAwkAAAIFBWNoZWNrBQVjaGVjawkBD2dldFN0YWtlQWN0aW9ucwIFAWkFC3VzZXJBZGRyZXNzCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCHdpdGhkcmF3ARN3aXRoZHJhd0Fzc2V0QW1vdW50BAt1c2VyQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEDHVzZXJMcEFtb3VudAkBD2dldFVzZXJMcEFtb3VudAEFC3VzZXJBZGRyZXNzBBJscEFtb3VudFRvV2l0aGRyYXcJAGsDBRN3aXRoZHJhd0Fzc2V0QW1vdW50BQZzY2FsZTgJAQ9nZXRDdXJyZW50UHJpY2UABBx1c2VyQXZhaWxhYmxlQXNzZXRUb1dpdGhkcmF3CQEgZ2V0VXNlckF2YWlsYWJsZUFzc2V0c1RvV2l0aGRyYXcBBQt1c2VyQWRkcmVzcwQFY2hlY2sJAMwIAgMJAGYCBRN3aXRoZHJhd0Fzc2V0QW1vdW50AAAGCQEIdGhyb3dFcnIBAiV3aXRoZHJhdyBhbW91bnQgc2hvdWxkIGJlIG1vcmUgdGhhbiAwCQDMCAIDCQBnAgUcdXNlckF2YWlsYWJsZUFzc2V0VG9XaXRoZHJhdwUTd2l0aGRyYXdBc3NldEFtb3VudAYJAQh0aHJvd0VycgEJAKwCAgkArAICAiVjYW5ub3Qgd2l0aGRyYXcgbW9yZSB0aGFuIGF2YWlsYWJsZSAoCQCkAwEFHHVzZXJBdmFpbGFibGVBc3NldFRvV2l0aGRyYXcCASkFA25pbAMJAAACBQVjaGVjawUFY2hlY2sJARJnZXRXaXRoZHJhd0FjdGlvbnMCBQFpBRJscEFtb3VudFRvV2l0aGRyYXcJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEVZ2V0VXNlckFzc2V0c1JFQURPTkxZAQt1c2VyQWRkcmVzcwQMdXNlckxwQW1vdW50CQEPZ2V0VXNlckxwQW1vdW50AQULdXNlckFkZHJlc3MEHHVzZXJBdmFpbGFibGVBc3NldFRvV2l0aGRyYXcJASBnZXRVc2VyQXZhaWxhYmxlQXNzZXRzVG9XaXRoZHJhdwEFC3VzZXJBZGRyZXNzBBV1c2VyVG90YWxTdGFrZWRBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBF2tleVVzZXJUb3RhbEFzc2V0U3Rha2VkAQULdXNlckFkZHJlc3MAAAQXdXNlclRvdGFsQXNzZXRXaXRoZHJhd24JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBGmtleVVzZXJUb3RhbEFzc2V0V2l0aGRyYXduAQULdXNlckFkZHJlc3MAAAkAlAoCBQNuaWwJAJcKBQUMdXNlckxwQW1vdW50BRx1c2VyQXZhaWxhYmxlQXNzZXRUb1dpdGhkcmF3CQEPZ2V0Q3VycmVudFByaWNlAAUVdXNlclRvdGFsU3Rha2VkQW1vdW50BRd1c2VyVG90YWxBc3NldFdpdGhkcmF3bgFpARZnZXRUb3RhbEFzc2V0c1JFQURPTkxZAAkAlAoCBQNuaWwJAJUKAwUNdG90YWxMcEFtb3VudAkBK2dldFRvdGFsQXNzZXRBbW91bnRXaXRoUHJvZml0T3JNYXhBdmFpbGFibGUACQEPZ2V0Q3VycmVudFByaWNlAAFpAQt2b3RlRm9yVHhJZAEEdHhJZAQTY2FsbGVyQWRkcmVzc1N0cmluZwkA2AQBCAgFAWkGY2FsbGVyBWJ5dGVzBAlrZXlQcmVmaXgJARhrZXlBbGxvd2VkVHhJZFZvdGVQcmVmaXgBBQR0eElkBAZyZXN1bHQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDmtleUFsbG93ZWRUeElkAAUEdHhJZAUDbmlsBBFhbGxvd2VkVHhJZE9wdGlvbgkAnQgCBQR0aGlzCQEOa2V5QWxsb3dlZFR4SWQABANlcnIJAMwIAgMJAAACCQDIAQEJANkEAQUEdHhJZAURVFhJRF9CWVRFU19MRU5HVEgGCQEIdGhyb3dFcnIBCQCsAgIFBHR4SWQCEiBpcyBub3QgdmFsaWQgdHhJZAkAzAgCAwMJAAACBRFhbGxvd2VkVHhJZE9wdGlvbgUEdW5pdAYJAQIhPQIJAQV2YWx1ZQEFEWFsbG93ZWRUeElkT3B0aW9uBQR0eElkBgkBCHRocm93RXJyAQkArAICBQR0eElkAhMgaXMgYWxyZWFkeSBhbGxvd2VkBQNuaWwDCQAAAgUDZXJyBQNlcnIJAQx2b3RlSU5URVJOQUwEBRNjYWxsZXJBZGRyZXNzU3RyaW5nBQlrZXlQcmVmaXgFBlFVT1JVTQUGcmVzdWx0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQIYnlBZG1pbnMJAAACCAUCdHgCaWQJANkEAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzCQEOa2V5QWxsb3dlZFR4SWQAAgAEB2J5T3duZXIDCQBnAgkAkAMBCQENZ2V0QWRtaW5zTGlzdAAFBlFVT1JVTQcJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkDBQhieUFkbWlucwYFB2J5T3duZXKc3oLw", "height": 2675596, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: J3tJi6bV1jGFPYQ4Z4eqyjZ4ZoQvHHE8P5BJQ9dQf2bS Next: 3vNLwKZ7ywkKpGbgqP6yX4tKUizLA3DeWCqEWiiqAirE Diff:
OldNewDifferences
182182 }
183183
184184
185+func debugDays () = {
186+ let startBlock = valueOrElse(getInteger(this, keyStartBlock), 0)
187+ let startDay = fraction(startBlock, 1, BLOCKS_IN_DAY)
188+ let elapsedDays = (heightInDays - startDay)
189+ $Tuple3(startDay, heightInDays, elapsedDays)
190+ }
191+
192+
185193 func getTotalAssetAmountWithProfitOrMaxAvailable () = {
186194 let totalAssetAmountWithProfit = (totalAssetAmount + calcTotalProfit())
187195 let totalAmount = match assetIdBytes {
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let contractFile = "mpt_staking.ride"
55
66 let SEP = "__"
77
88 let scale8 = 100000000
99
1010 let ADDRESS_BYTES_SIZE = 26
1111
1212 let BLOCKS_IN_DAY = 10
1313
1414 func throwErr (msg) = throw(((contractFile + ": ") + msg))
1515
1616
1717 let keyAssetId = makeString(["%s", "assetId"], SEP)
1818
1919 let keyEmissionPerBlock = makeString(["%s", "emissionPerBlock"], SEP)
2020
2121 let keyStartBlock = makeString(["%s", "startBlock"], SEP)
2222
2323 let keyTotalLpAmount = makeString(["%s", "totalLpAmount"], SEP)
2424
2525 let keyTotalAssetAmount = makeString(["%s", "totalAssetAmount"], SEP)
2626
2727 func keyUserLpAmount (userAddress) = makeString(["%s%s", "userLpAmount", userAddress], SEP)
2828
2929
3030 func keyUserTotalAssetWithdrawn (userAddress) = makeString(["%s%s", "totalAssetWithdrawn", userAddress], SEP)
3131
3232
3333 func keyUserTotalAssetStaked (userAddress) = makeString(["%s%s", "totalAssetStaked", userAddress], SEP)
3434
3535
3636 let totalLpAmount = valueOrElse(getInteger(this, keyTotalLpAmount), 0)
3737
3838 let totalAssetAmount = valueOrElse(getInteger(this, keyTotalAssetAmount), 0)
3939
4040 let assetIdString = valueOrElse(getString(this, keyAssetId), "WAVES")
4141
4242 let assetIdBytes = if ((assetIdString == "WAVES"))
4343 then unit
4444 else fromBase58String(assetIdString)
4545
4646 let emissionPerDay = (valueOrElse(getInteger(this, keyEmissionPerBlock), 0) * BLOCKS_IN_DAY)
4747
4848 let heightInDays = fraction(height, 1, BLOCKS_IN_DAY)
4949
5050 let ADMIN_LIST_SIZE = 5
5151
5252 let QUORUM = 3
5353
5454 let TXID_BYTES_LENGTH = 32
5555
5656 func keyAllowedTxIdVotePrefix (txId) = makeString(["%s%s%s", "allowTxId", txId], SEP)
5757
5858
5959 func keyFullAdminVote (prefix,adminAddress) = makeString([prefix, adminAddress], SEP)
6060
6161
6262 func keyAdminAddressList () = makeString(["%s", "adminAddressList"], SEP)
6363
6464
6565 func keyAllowedTxId () = makeString(["%s", "txId"], SEP)
6666
6767
6868 func getAdminVote (prefix,admin) = {
6969 let voteKey = keyFullAdminVote(prefix, admin)
7070 valueOrElse(getInteger(voteKey), 0)
7171 }
7272
7373
7474 func getAdminsList () = match getString(this, keyAdminAddressList()) {
7575 case s: String =>
7676 split(s, SEP)
7777 case _ =>
7878 nil
7979 }
8080
8181
8282 func isInAdminList (address) = containsElement(getAdminsList(), address)
8383
8484
8585 func genVotesKeysHelper (a,adminAddress) = {
8686 let $t024082432 = a
8787 let result = $t024082432._1
8888 let prefix = $t024082432._2
8989 $Tuple2((result :+ keyFullAdminVote(prefix, adminAddress)), prefix)
9090 }
9191
9292
9393 func genVotesKeys (keyPrefix) = {
9494 let adminList = keyAdminAddressList()
9595 let $t025792663 = {
9696 let $l = getAdminsList()
9797 let $s = size($l)
9898 let $acc0 = $Tuple2(nil, keyPrefix)
9999 func $f0_1 ($a,$i) = if (($i >= $s))
100100 then $a
101101 else genVotesKeysHelper($a, $l[$i])
102102
103103 func $f0_2 ($a,$i) = if (($i >= $s))
104104 then $a
105105 else throw("List size exceeds 5")
106106
107107 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5)
108108 }
109109 let result = $t025792663._1
110110 let prefix = $t025792663._2
111111 result
112112 }
113113
114114
115115 func countVotesHelper (result,voteKey) = (result + valueOrElse(getInteger(voteKey), 0))
116116
117117
118118 func countVotes (prefix) = {
119119 let votes = genVotesKeys(prefix)
120120 let $l = votes
121121 let $s = size($l)
122122 let $acc0 = 0
123123 func $f0_1 ($a,$i) = if (($i >= $s))
124124 then $a
125125 else countVotesHelper($a, $l[$i])
126126
127127 func $f0_2 ($a,$i) = if (($i >= $s))
128128 then $a
129129 else throw("List size exceeds 5")
130130
131131 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5)
132132 }
133133
134134
135135 func clearVotesHelper (result,key) = (result :+ DeleteEntry(key))
136136
137137
138138 func getClearVoteEntries (prefix) = {
139139 let votes = genVotesKeys(prefix)
140140 let $l = votes
141141 let $s = size($l)
142142 let $acc0 = nil
143143 func $f0_1 ($a,$i) = if (($i >= $s))
144144 then $a
145145 else clearVotesHelper($a, $l[$i])
146146
147147 func $f0_2 ($a,$i) = if (($i >= $s))
148148 then $a
149149 else throw("List size exceeds 5")
150150
151151 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5)
152152 }
153153
154154
155155 func voteINTERNAL (callerAddressString,keyPrefix,minVotes,voteResult) = {
156156 let voteKey = keyFullAdminVote(keyPrefix, callerAddressString)
157157 let adminCurrentVote = getAdminVote(keyPrefix, callerAddressString)
158158 let err = if (!(isInAdminList(callerAddressString)))
159159 then throwErr((("Address: " + callerAddressString) + " not in Admin list"))
160160 else if ((adminCurrentVote == 1))
161161 then throwErr((voteKey + " you already voted"))
162162 else unit
163163 if ((err == err))
164164 then {
165165 let votes = countVotes(keyPrefix)
166166 if (((votes + 1) >= minVotes))
167167 then {
168168 let clearVoteEntries = getClearVoteEntries(keyPrefix)
169169 (clearVoteEntries ++ voteResult)
170170 }
171171 else [IntegerEntry(voteKey, 1)]
172172 }
173173 else throw("Strict value is not equal to itself.")
174174 }
175175
176176
177177 func calcTotalProfit () = {
178178 let startBlock = valueOrElse(getInteger(this, keyStartBlock), 0)
179179 let startDay = fraction(startBlock, 1, BLOCKS_IN_DAY)
180180 let elapsedDays = (heightInDays - startDay)
181181 max([0, (emissionPerDay * elapsedDays)])
182182 }
183183
184184
185+func debugDays () = {
186+ let startBlock = valueOrElse(getInteger(this, keyStartBlock), 0)
187+ let startDay = fraction(startBlock, 1, BLOCKS_IN_DAY)
188+ let elapsedDays = (heightInDays - startDay)
189+ $Tuple3(startDay, heightInDays, elapsedDays)
190+ }
191+
192+
185193 func getTotalAssetAmountWithProfitOrMaxAvailable () = {
186194 let totalAssetAmountWithProfit = (totalAssetAmount + calcTotalProfit())
187195 let totalAmount = match assetIdBytes {
188196 case u: Unit =>
189197 min([totalAssetAmountWithProfit, wavesBalance(this).available])
190198 case b: ByteVector =>
191199 min([totalAssetAmountWithProfit, assetBalance(this, b)])
192200 case _ =>
193201 throw("Match error")
194202 }
195203 if ((totalLpAmount == 0))
196204 then 0
197205 else totalAmount
198206 }
199207
200208
201209 func getCurrentPrice () = if ((totalLpAmount != 0))
202210 then fraction(getTotalAssetAmountWithProfitOrMaxAvailable(), scale8, totalLpAmount)
203211 else (1 * scale8)
204212
205213
206214 func getUserLpAmount (userAddress) = valueOrElse(getInteger(this, keyUserLpAmount(userAddress)), 0)
207215
208216
209217 func getUserAvailableAssetsToWithdraw (userAddress) = {
210218 let userLpAmount = getUserLpAmount(userAddress)
211219 let userAvailableAssetToWithdraw = fraction(userLpAmount, getCurrentPrice(), scale8)
212220 if ((getCurrentPrice() > (userAvailableAssetToWithdraw * scale8)))
213221 then 0
214222 else userAvailableAssetToWithdraw
215223 }
216224
217225
218226 func getStakeActions (i,userAddress) = {
219227 let checks = [if ((size(i.payments) == 1))
220228 then true
221229 else throwErr("should include 1 payment"), if ((i.payments[0].assetId == assetIdBytes))
222230 then true
223231 else throwErr(("payment should be in " + assetIdString)), if ((i.payments[0].amount > 0))
224232 then true
225233 else "payment amount should be greater than 0"]
226234 if ((checks == checks))
227235 then {
228236 let paymentAmount = i.payments[0].amount
229237 let paymentLpAmount = fraction(paymentAmount, scale8, getCurrentPrice())
230238 let userLpAmount = getUserLpAmount(userAddress)
231239 let userTotalStakedAmount = valueOrElse(getInteger(this, keyUserTotalAssetStaked(userAddress)), 0)
232240 let newTotalLpAmount = (totalLpAmount + paymentLpAmount)
233241 let newTotalAssetAmount = (totalAssetAmount + paymentAmount)
234242 let newUserLpAmount = (userLpAmount + paymentLpAmount)
235243 let newUserTotalStakedAmount = (userTotalStakedAmount + paymentAmount)
236244 let updateStartHeightAction = if ((totalLpAmount == 0))
237245 then [IntegerEntry(keyStartBlock, height)]
238246 else nil
239247 ([IntegerEntry(keyTotalLpAmount, newTotalLpAmount), IntegerEntry(keyTotalAssetAmount, newTotalAssetAmount), IntegerEntry(keyUserLpAmount(userAddress), newUserLpAmount), IntegerEntry(keyUserTotalAssetStaked(userAddress), newUserTotalStakedAmount)] ++ updateStartHeightAction)
240248 }
241249 else throw("Strict value is not equal to itself.")
242250 }
243251
244252
245253 func getWithdrawActions (i,lpAssetWithdrawAmount) = {
246254 let userAddress = toString(i.caller)
247255 let userLpAmount = getUserLpAmount(userAddress)
248256 let check = [if ((lpAssetWithdrawAmount > 0))
249257 then true
250258 else throwErr("amount should be more than 0"), if ((userLpAmount >= lpAssetWithdrawAmount))
251259 then true
252260 else throwErr((("cannot withdraw more than available (" + toString(userLpAmount)) + ")"))]
253261 if ((check == check))
254262 then {
255263 let newUserLpAmount = (userLpAmount - lpAssetWithdrawAmount)
256264 let withdrawAssetAmount = fraction(lpAssetWithdrawAmount, getCurrentPrice(), scale8)
257265 let newTotalLpAmount = (totalLpAmount - lpAssetWithdrawAmount)
258266 let newTotalAssetAmount = fraction(newTotalLpAmount, getCurrentPrice(), scale8)
259267 let userTotalAssetWithdrawn = valueOrElse(getInteger(this, keyUserTotalAssetWithdrawn(userAddress)), 0)
260268 let newUserTotalAssetWithdrawn = (userTotalAssetWithdrawn + withdrawAssetAmount)
261269 [IntegerEntry(keyTotalLpAmount, newTotalLpAmount), IntegerEntry(keyTotalAssetAmount, newTotalAssetAmount), IntegerEntry(keyUserLpAmount(userAddress), newUserLpAmount), IntegerEntry(keyUserTotalAssetWithdrawn(userAddress), newUserTotalAssetWithdrawn), IntegerEntry(keyStartBlock, height), ScriptTransfer(i.caller, withdrawAssetAmount, assetIdBytes)]
262270 }
263271 else throw("Strict value is not equal to itself.")
264272 }
265273
266274
267275 @Callable(i)
268276 func setEmissionPerBlock (emissionPerBlock) = {
269277 let check = [if ((i.caller == this))
270278 then true
271279 else throwErr("permission denied")]
272280 if ((check == check))
273281 then [IntegerEntry(keyTotalAssetAmount, getTotalAssetAmountWithProfitOrMaxAvailable()), IntegerEntry(keyStartBlock, height), IntegerEntry(keyEmissionPerBlock, max([0, emissionPerBlock]))]
274282 else throw("Strict value is not equal to itself.")
275283 }
276284
277285
278286
279287 @Callable(i)
280288 func stake () = getStakeActions(i, toString(i.caller))
281289
282290
283291
284292 @Callable(i)
285293 func stakeFor (userAddress) = {
286294 let check = [if ((size(fromBase58String(userAddress)) == ADDRESS_BYTES_SIZE))
287295 then true
288296 else throwErr("address is not valid")]
289297 if ((check == check))
290298 then getStakeActions(i, userAddress)
291299 else throw("Strict value is not equal to itself.")
292300 }
293301
294302
295303
296304 @Callable(i)
297305 func withdraw (withdrawAssetAmount) = {
298306 let userAddress = toString(i.caller)
299307 let userLpAmount = getUserLpAmount(userAddress)
300308 let lpAmountToWithdraw = fraction(withdrawAssetAmount, scale8, getCurrentPrice())
301309 let userAvailableAssetToWithdraw = getUserAvailableAssetsToWithdraw(userAddress)
302310 let check = [if ((withdrawAssetAmount > 0))
303311 then true
304312 else throwErr("withdraw amount should be more than 0"), if ((userAvailableAssetToWithdraw >= withdrawAssetAmount))
305313 then true
306314 else throwErr((("cannot withdraw more than available (" + toString(userAvailableAssetToWithdraw)) + ")"))]
307315 if ((check == check))
308316 then getWithdrawActions(i, lpAmountToWithdraw)
309317 else throw("Strict value is not equal to itself.")
310318 }
311319
312320
313321
314322 @Callable(i)
315323 func getUserAssetsREADONLY (userAddress) = {
316324 let userLpAmount = getUserLpAmount(userAddress)
317325 let userAvailableAssetToWithdraw = getUserAvailableAssetsToWithdraw(userAddress)
318326 let userTotalStakedAmount = valueOrElse(getInteger(this, keyUserTotalAssetStaked(userAddress)), 0)
319327 let userTotalAssetWithdrawn = valueOrElse(getInteger(this, keyUserTotalAssetWithdrawn(userAddress)), 0)
320328 $Tuple2(nil, $Tuple5(userLpAmount, userAvailableAssetToWithdraw, getCurrentPrice(), userTotalStakedAmount, userTotalAssetWithdrawn))
321329 }
322330
323331
324332
325333 @Callable(i)
326334 func getTotalAssetsREADONLY () = $Tuple2(nil, $Tuple3(totalLpAmount, getTotalAssetAmountWithProfitOrMaxAvailable(), getCurrentPrice()))
327335
328336
329337
330338 @Callable(i)
331339 func voteForTxId (txId) = {
332340 let callerAddressString = toBase58String(i.caller.bytes)
333341 let keyPrefix = keyAllowedTxIdVotePrefix(txId)
334342 let result = [StringEntry(keyAllowedTxId(), txId)]
335343 let allowedTxIdOption = getString(this, keyAllowedTxId())
336344 let err = [if ((size(fromBase58String(txId)) == TXID_BYTES_LENGTH))
337345 then true
338346 else throwErr((txId + " is not valid txId")), if (if ((allowedTxIdOption == unit))
339347 then true
340348 else (value(allowedTxIdOption) != txId))
341349 then true
342350 else throwErr((txId + " is already allowed"))]
343351 if ((err == err))
344352 then voteINTERNAL(callerAddressString, keyPrefix, QUORUM, result)
345353 else throw("Strict value is not equal to itself.")
346354 }
347355
348356
349357 @Verifier(tx)
350358 func verify () = {
351359 let byAdmins = (tx.id == fromBase58String(valueOrElse(getString(this, keyAllowedTxId()), "")))
352360 let byOwner = if ((size(getAdminsList()) >= QUORUM))
353361 then false
354362 else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
355363 if (byAdmins)
356364 then true
357365 else byOwner
358366 }
359367

github/deemru/w8io/3ef1775 
72.14 ms