tx · CzXTL45gVBcARtUBk9qduHA7wPgmR2QX9cYPDtgvacJe

3P975LUuqc7uBPiSxp3nemf2FZh62zfirSh:  -0.02300000 Waves

2023.01.24 08:57 [3484158] smart account 3P975LUuqc7uBPiSxp3nemf2FZh62zfirSh > SELF 0.00000000 Waves

{ "type": 13, "id": "CzXTL45gVBcARtUBk9qduHA7wPgmR2QX9cYPDtgvacJe", "fee": 2300000, "feeAssetId": null, "timestamp": 1674539876554, "version": 2, "chainId": 87, "sender": "3P975LUuqc7uBPiSxp3nemf2FZh62zfirSh", "senderPublicKey": "6Dx2LuCqezyDYjt3zMEL6WRrs5oaor6aK3L6QouPMP1b", "proofs": [ "3tFLcSwUM8ADMzEz8WRvrVZBPk1fPkqqVVxyBZvWkVBWjRB86GrdSm6HjePBM3LAcVCKfnj9cpBoTX87UptRFWAT" ], "script": "base64:BgInCAISAwoBBBIECgIIBBIDCgEIEgMKAQgSBAoCCAgSBAoCCAgSABIAEAAPY3JlYXRpb25BZGRyZXNzCQEHQWRkcmVzcwEBGgFXk93E0hfnIAr99yESTvDwdmcmgwN41FxMABRzaWduQXJ0SXNzdWVyQWRkcmVzcwkBB0FkZHJlc3MBARoBV3tk1VvWnhe5qtPmj/wDXMjEFvibuoYp4gALVVNEVEFzc2V0SWQBIB6UBxNSdqEllf3IYaiCXxB/3zpPKbv8mkY/Wv02T5+RAA50b3RhbFN0YWtlZEtleQIMdG90YWxfc3Rha2VkAA10b3RhbFBvd2VyS2V5Agt0b3RhbF9wb3dlcgASdG90YWxTcGVudFBvd2VyS2V5AhB0b3RhbF9zcGVudFBvd2VyABF2b3RlUG93ZXJMaW1pdEtleQIQVk9URV9QT1dFUl9MSU1JVAAWY3VycmVudFJld29yZHNSb3VuZEtleQIVY3VycmVudF9yZXdvcmRzX3JvdW5kABhmaW5hbFZvdGluZ0NhbmRpZGF0ZXNLZXkCGGZpbmFsX3ZvaXRpbmdfY2FuZGlkYXRlcwAVYWxsU3Rha2VkQWRkcmVzc2VzS2V5AhRhbGxfc3Rha2VkX2FkZHJlc3NlcwAXUHV6emxlRHJhZ29uc1NpZ25BcnRJZHMJAMwIAgIsOWlQTHNZb3o4Zk55VXA5cWNnZUFGUHBNaktHY2I0bU5VUmhBWjdkZnpYZWoJAMwIAgIsMks4NDdHZEFjcWFISFluMWRTUzFGM05Zcml1cXVKS0t6TW9CRVMxY240TWIJAMwIAgIsN0QxZUNWZU1iakhMcGpZdXFLWjk2TG9XUHdENzFxdXd1V3BaeGN1S25rSjcJAMwIAgIrempFNWR3VHYzQXVrUWo2eE15ZGRqY3FBODJiS3ZTTkxlYUtMaG5GWUtHZgkAzAgCAiw0VDhRU3JMTHFVcEhwaThTZWNTUVQxcDV0R28xQ0Fza1RHZ1lnVW1YQllFYgkAzAgCAixBakhrdnhKcGd4eDhVQU1tejZndnhqdEJhbkdCSGVFVWFZeHlnZHNUUmNWNgkAzAgCAiw0anJ1Rk0xZ3ZydE1IWGlLZHoyRUt0MTJmSEdqSDVNVDhZY1prRjZLVkdQNwkAzAgCAitaWjFjTThOM1VDM3VBZG9DWEp3VHdrbXBlVFNGanBOQjRHVmE1VXdZVkdTCQDMCAICLDZVQXZvakpwRnhVakFvUkZiM25oeENSVWRHekZDdnhDS25pTHRKcXhWazc3CQDMCAICLDJOU3ZwNUpYOFlUTlhXS1hwRTlraVpBMjJnZzRETTJZYzdtY2I5VTZQa3hCBQNuaWwBCGNoZWNrTkZUAQVhc3NldAQOaXNQdXp6bGVEcmFnb24EByRtYXRjaDAJAM8IAgUXUHV6emxlRHJhZ29uc1NpZ25BcnRJZHMJANgEAQgFBWFzc2V0AmlkAwkAAQIFByRtYXRjaDACA0ludAQBeAUHJG1hdGNoMAkAZwIFAXgAAAcDAwMDAwUOaXNQdXp6bGVEcmFnb24GCQAAAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUPY3JlYXRpb25BZGRyZXNzCQCsAgIJAKwCAgIEbmZ0XwkA2AQBCAUFYXNzZXQCaWQCB19pc3N1ZXIJAKUIAQUEdGhpcwkAAAIIBQVhc3NldAZpc3N1ZXIDBQ5pc1B1enpsZURyYWdvbgUUc2lnbkFydElzc3VlckFkZHJlc3MFD2NyZWF0aW9uQWRkcmVzcwcJAAACCAUFYXNzZXQIZGVjaW1hbHMAAAcJAAACCAUFYXNzZXQKcmVpc3N1YWJsZQcHCQAAAggFBWFzc2V0CHF1YW50aXR5AAEHAQtnZXRQb3dlck5GVAEFYXNzZXQEDmlzUHV6emxlRHJhZ29uBAckbWF0Y2gwCQDPCAIFF1B1enpsZURyYWdvbnNTaWduQXJ0SWRzCQDYBAEIBQVhc3NldAJpZAMJAAECBQckbWF0Y2gwAgNJbnQEAXgFByRtYXRjaDAJAGcCBQF4AAAHAwUOaXNQdXp6bGVEcmFnb24AKAQGcGFyYW1zCQERQGV4dHJOYXRpdmUoMTA1MykCBQ9jcmVhdGlvbkFkZHJlc3MJAKwCAgkArAICAgRuZnRfCQDYBAEIBQVhc3NldAJpZAIHX3BhcmFtcwMJAAACBQZwYXJhbXMCBGdvbGQAZAAoAQ5pc1ZvdGluZ0Nsb3NlZAEGdm90ZUlkBBB2b3RlQ29uZmlybWVkS2V5CQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIKX2NvbmZpcm1lZAQPdm90ZVJlamVjdGVkS2V5CQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIJX3JlamVjdGVkBAtpc0NvbmZpcm1lZAkBC3ZhbHVlT3JFbHNlAgkAoAgBBRB2b3RlQ29uZmlybWVkS2V5BwQKaXNSZWplY3RlZAkBC3ZhbHVlT3JFbHNlAgkAoAgBBQ92b3RlUmVqZWN0ZWRLZXkHAwULaXNDb25maXJtZWQGBQppc1JlamVjdGVkARVhZGRTdHJpbmdUb1N0YXRlQXJyYXkCB2RhdGFLZXkEaXRlbQQHYWxsRGF0YQkBC3ZhbHVlT3JFbHNlAgkAoggBBQdkYXRhS2V5AgADCQEBIQEJAQlpc0RlZmluZWQBCQCzCQIFB2FsbERhdGEFBGl0ZW0DCQAAAgkAsQIBBQdhbGxEYXRhAAAJAMwIAgkBC1N0cmluZ0VudHJ5AgUHZGF0YUtleQUEaXRlbQUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIFB2RhdGFLZXkJALsJAgkAzQgCCQC9CQIFB2FsbERhdGECASwFBGl0ZW0CASwFA25pbAUDbmlsARhyZW1vdmVJdGVtRnJvbVN0YXRlQXJyYXkCB2RhdGFLZXkEaXRlbQQHYWxsRGF0YQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEFB2RhdGFLZXkJAKwCAgkArAICAg9EYXRhIGZvciBrZXk6ICcFB2RhdGFLZXkCCycgbm90IGZvdW5kAwkBCWlzRGVmaW5lZAEJALMJAgUHYWxsRGF0YQUEaXRlbQQIZGF0YUxpc3QJAL0JAgUHYWxsRGF0YQIBLAQJaXRlbUluZGV4CQEFdmFsdWUBCQDPCAIFCGRhdGFMaXN0BQRpdGVtCQDMCAIJAQtTdHJpbmdFbnRyeQIFB2RhdGFLZXkJALsJAgkA0QgCBQhkYXRhTGlzdAUJaXRlbUluZGV4AgEsBQNuaWwFA25pbAgBaQEFc3Rha2UBBWRlYnVnBAphZGRyZXNzU3RyCQClCAEIBQFpBmNhbGxlcgQBcAMJAGYCCQCQAwEIBQFpCHBheW1lbnRzAAAJAJEDAggFAWkIcGF5bWVudHMAAAkAAgECFlBheW1lbnRzIGxpc3QgaXMgZW1wdHkEBWFzc2V0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAOwHAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAUBcAdhc3NldElkAg9JbnZhbGlkIHBheW1lbnQCEEludmFsaWQgYXNzZXQgSWQDBQVkZWJ1ZwkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAg5wYXltZW50cyBzaXplIAkApAMBCQCQAwEIBQFpCHBheW1lbnRzAgkgYXNzZXRJZCAJANgEAQkBBXZhbHVlAQgFAXAHYXNzZXRJZAIIIGFtb3VudCAJAKQDAQgFAXAGYW1vdW50AwMJAGYCCAUBcAZhbW91bnQAAAkBCGNoZWNrTkZUAQUFYXNzZXQHBAt0b3RhbFN0YWtlZAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQ50b3RhbFN0YWtlZEtleQAABAp0b3RhbFBvd2VyCQELdmFsdWVPckVsc2UCCQCfCAEFDXRvdGFsUG93ZXJLZXkAAAQPYWRkcmVzc1Bvd2VyS2V5CQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICBl9wb3dlcgQVYWRkcmVzc1RvdGFsU3Rha2VkS2V5CQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICDF90b3RhbFN0YWtlZAQUYWRkcmVzc1N0YWtlZE5mdHNLZXkJAKwCAgkArAICAghhZGRyZXNzXwUKYWRkcmVzc1N0cgILX3N0YWtlZE5mdHMEDGFkZHJlc3NQb3dlcgkBC3ZhbHVlT3JFbHNlAgkAnwgBBQ9hZGRyZXNzUG93ZXJLZXkAAAQSYWRkcmVzc1RvdGFsU3Rha2VkCQELdmFsdWVPckVsc2UCCQCfCAEFFWFkZHJlc3NUb3RhbFN0YWtlZEtleQAABBFhZGRyZXNzU3Rha2VkTmZ0cwkBC3ZhbHVlT3JFbHNlAgkAoggBBRRhZGRyZXNzU3Rha2VkTmZ0c0tleQIAAwkAZgIJAGQCBRJhZGRyZXNzVG90YWxTdGFrZWQAAQAFCQACAQIZWW91IGNhbiBzdGFrZSBvbmx5IDUgTkZUcwQIbmZ0UG93ZXIJAQtnZXRQb3dlck5GVAEFBWFzc2V0BAhuZnRJZFN0cgkA2AQBCAUFYXNzZXQCaWQEFmFkZHJlc3NTdGFrZWROZnRzU3RhdGUDCQAAAgkAsQIBBRFhZGRyZXNzU3Rha2VkTmZ0cwAACQDMCAIJAQtTdHJpbmdFbnRyeQIFFGFkZHJlc3NTdGFrZWROZnRzS2V5BQhuZnRJZFN0cgUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIFFGFkZHJlc3NTdGFrZWROZnRzS2V5CQC5CQIJAM0IAgkAtQkCBRFhZGRyZXNzU3Rha2VkTmZ0cwIBLAUIbmZ0SWRTdHICASwFA25pbAkAzggCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFDnRvdGFsU3Rha2VkS2V5CQBkAgULdG90YWxTdGFrZWQAAQkAzAgCCQEMSW50ZWdlckVudHJ5AgUNdG90YWxQb3dlcktleQkAZAIFCnRvdGFsUG93ZXIFCG5mdFBvd2VyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgRuZnRfBQhuZnRJZFN0cgIGX293bmVyBQphZGRyZXNzU3RyCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIEbmZ0XwUIbmZ0SWRTdHICBl9wb3dlcgUIbmZ0UG93ZXIJAMwIAgkBDEludGVnZXJFbnRyeQIFD2FkZHJlc3NQb3dlcktleQkAZAIFDGFkZHJlc3NQb3dlcgUIbmZ0UG93ZXIJAMwIAgkBDEludGVnZXJFbnRyeQIFFWFkZHJlc3NUb3RhbFN0YWtlZEtleQkAZAIFEmFkZHJlc3NUb3RhbFN0YWtlZAABBQNuaWwJARVhZGRTdHJpbmdUb1N0YXRlQXJyYXkCBRVhbGxTdGFrZWRBZGRyZXNzZXNLZXkFCmFkZHJlc3NTdHIFFmFkZHJlc3NTdGFrZWROZnRzU3RhdGUJAAIBAiJJbnZhbGlkIHBheW1lbnQgYXNzZXQgSWQgb3IgYW1vdW50AWkBB3Vuc3Rha2UCCG5mdElkU3RyBWRlYnVnBAphZGRyZXNzU3RyCQClCAEIBQFpBmNhbGxlcgQFYXNzZXQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBCQDZBAEFCG5mdElkU3RyAg5JbnZhbGlkIG5mdCBJZAQMb3duZXJBZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKIIAQkArAICCQCsAgICBG5mdF8FCG5mdElkU3RyAgZfb3duZXICEk93bmVyIGRhdGEgaW52YWxpZAMJAQIhPQIFDG93bmVyQWRkcmVzcwUKYWRkcmVzc1N0cgkAAgECFVlvdSBhcmUgbm90IHRoZSBvd25lcgMJAQhjaGVja05GVAEFBWFzc2V0BAt0b3RhbFN0YWtlZAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQ50b3RhbFN0YWtlZEtleQAABAp0b3RhbFBvd2VyCQELdmFsdWVPckVsc2UCCQCfCAEFDXRvdGFsUG93ZXJLZXkAAAQPYWRkcmVzc1Bvd2VyS2V5CQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICBl9wb3dlcgQVYWRkcmVzc1RvdGFsU3Rha2VkS2V5CQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICDF90b3RhbFN0YWtlZAQUYWRkcmVzc1N0YWtlZE5mdHNLZXkJAKwCAgkArAICAghhZGRyZXNzXwUKYWRkcmVzc1N0cgILX3N0YWtlZE5mdHMEDGFkZHJlc3NQb3dlcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFD2FkZHJlc3NQb3dlcktleQIdQWRkcmVzcyBwb3dlciB2YWx1ZSBub3QgZm91bmQEEmFkZHJlc3NUb3RhbFN0YWtlZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFFWFkZHJlc3NUb3RhbFN0YWtlZEtleQIkQWRkcmVzcyB0b3RhbCBzdGFrZWQgdmFsdWUgbm90IGZvdW5kBBFhZGRyZXNzU3Rha2VkTmZ0cwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEFFGFkZHJlc3NTdGFrZWROZnRzS2V5AiNBZGRyZXNzIHN0YWtlZCBOZnRzIHZhbHVlIG5vdCBmb3VuZAQNbmZ0QXNzZXRJZFN0cgkA2AQBCAUFYXNzZXQCaWQECG5mdFBvd2VyCQERQGV4dHJOYXRpdmUoMTA1NSkBCQCsAgIJAKwCAgIEbmZ0XwUNbmZ0QXNzZXRJZFN0cgIGX3Bvd2VyBBN1cGRhdGVkQWRkcmVzc1Bvd2VyCQBlAgUMYWRkcmVzc1Bvd2VyBQhuZnRQb3dlcgQTcmVtb3ZlU3Rha2VkQWRkcmVzcwMJAAACBRN1cGRhdGVkQWRkcmVzc1Bvd2VyAAAJARhyZW1vdmVJdGVtRnJvbVN0YXRlQXJyYXkCBRVhbGxTdGFrZWRBZGRyZXNzZXNLZXkFCmFkZHJlc3NTdHIFA25pbAQVYWRkcmVzc1N0YWtlZE5mdHNMaXN0CQC1CQIFEWFkZHJlc3NTdGFrZWROZnRzAgEsBBVhZGRyZXNzU3Rha2VkTmZ0SW5kZXgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAzwgCBRVhZGRyZXNzU3Rha2VkTmZ0c0xpc3QFCG5mdElkU3RyAiVORlQgbm90IGZvdW5lZCBpbiBhZGRyZXNzIHN0YWtlZCBsaXN0CQDOCAIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyAAEIBQVhc3NldAJpZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUOdG90YWxTdGFrZWRLZXkJAGUCBQt0b3RhbFN0YWtlZAABCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ10b3RhbFBvd2VyS2V5CQBlAgUKdG90YWxQb3dlcgUIbmZ0UG93ZXIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgICBG5mdF8FDW5mdEFzc2V0SWRTdHICBl9vd25lcgkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgIEbmZ0XwUNbmZ0QXNzZXRJZFN0cgIGX3Bvd2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9hZGRyZXNzUG93ZXJLZXkFE3VwZGF0ZWRBZGRyZXNzUG93ZXIJAMwIAgkBDEludGVnZXJFbnRyeQIFFWFkZHJlc3NUb3RhbFN0YWtlZEtleQkAZQIFEmFkZHJlc3NUb3RhbFN0YWtlZAABCQDMCAIJAQtTdHJpbmdFbnRyeQIFFGFkZHJlc3NTdGFrZWROZnRzS2V5CQC5CQIJANEIAgUVYWRkcmVzc1N0YWtlZE5mdHNMaXN0BRVhZGRyZXNzU3Rha2VkTmZ0SW5kZXgCASwFA25pbAUTcmVtb3ZlU3Rha2VkQWRkcmVzcwkAAgECDkludmFsaWQgbmZ0IElkAWkBCnNlbmRUb1ZvdGUBDGNvbGxlY3Rpb25JZAQGaXNzdWVyCQCRAwIJALUJAgUMY29sbGVjdGlvbklkAgFfAAAEB2lzRXhpc3QEByRtYXRjaDAJAKIIAQkArAICCQCsAgICC2NvbGxlY3Rpb25fBQxjb2xsZWN0aW9uSWQCB192b3RlSWQDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAF0BQckbWF0Y2gwBgcDCQAAAgkAsQIBBQZpc3N1ZXIAAAkAAgECG0NvbGxlY3Rpb24gaXNzdWVyIG5vdCBmb3VuZAMFB2lzRXhpc3QJAAIBAjBDb2xsZWN0aW9uIGhhcyBhbHJlYWR5IGJlZW4gc3VibWl0dGVkIGZvciB2b3RpbmcDCQECIT0CBQZpc3N1ZXIJAKUIAQgFAWkGY2FsbGVyCQACAQImT25seSB0aGUgaXNzdWVyIGNhbiBzdWJtaXQgdG8gdGhlIHZvdGUEBnZvdGVJZAkA2AQBCQDUFgEJAJsDAQUMY29sbGVjdGlvbklkBAp0b3RhbFZvdGVzCQELdmFsdWVPckVsc2UCCQCfCAECC3RvdGFsX3ZvdGVzAAAEC3F1b3J1bUxpbWl0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQURdm90ZVBvd2VyTGltaXRLZXkCGlZvdGUgcG93ZXIgbGltaXQgbm90IGZvdW5kCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgtjb2xsZWN0aW9uXwUMY29sbGVjdGlvbklkAgdfdm90ZUlkBQZ2b3RlSWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCDV9jb2xsZWN0aW9uSWQFDGNvbGxlY3Rpb25JZAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIGX293bmVyCQClCAEIBQFpBmNhbGxlcgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCCl9jcmVhdGVkQXQFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCB19xdW9ydW0FC3F1b3J1bUxpbWl0CQDMCAIJAQxJbnRlZ2VyRW50cnkCAgt0b3RhbF92b3RlcwkAZAIFCnRvdGFsVm90ZXMAAQUDbmlsAWkBDnJlbW92ZUZyb21Wb3RlAQZ2b3RlSWQEDGNvbGxlY3Rpb25JZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEJAKwCAgkArAICAgV2b3RlXwUGdm90ZUlkAg1fY29sbGVjdGlvbklkAhdDb2xsZWN0aW9uIElkIG5vdCBmb3VuZAQFb3duZXIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBCQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIGX293bmVyAg9Pd25lciBub3QgZm91bmQDCQECIT0CBQVvd25lcgkApQgBCAUBaQZjYWxsZXIJAAIBAhVZb3UgYXJlIG5vdCB0aGUgb3duZXIDCQEOaXNWb3RpbmdDbG9zZWQBBQZ2b3RlSWQJAAIBAhBWb3RpbmcgaXMgY2xvc2VkBAp0b3RhbFZvdGVzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQILdG90YWxfdm90ZXMCG3RvdGFsIHZvdGVzIHZhbHVlIG5vdCBmb3VuZAkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgILY29sbGVjdGlvbl8FDGNvbGxlY3Rpb25JZAIHX3ZvdGVJZAkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAINX2NvbGxlY3Rpb25JZAkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIGX293bmVyCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICAgV2b3RlXwUGdm90ZUlkAgpfY3JlYXRlZEF0CQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICAgV2b3RlXwUGdm90ZUlkAgdfcXVvcnVtCQDMCAIJAQxJbnRlZ2VyRW50cnkCAgt0b3RhbF92b3RlcwkAZQIFCnRvdGFsVm90ZXMAAQUDbmlsAWkBCXZvdGVCeU5GVAIGdm90ZUlkBmFzc2V0cwQKYWRkcmVzc1N0cgkApQgBCAUBaQZjYWxsZXIEDGNvbGxlY3Rpb25JZAkBC3ZhbHVlT3JFbHNlAgkAoggBCQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAINX2NvbGxlY3Rpb25JZAIAAwkBDmlzVm90aW5nQ2xvc2VkAQUGdm90ZUlkCQACAQIQVm90aW5nIGlzIGNsb3NlZAMJAAACCQCxAgEFDGNvbGxlY3Rpb25JZAAACQACAQIUQ29sbGVjdGlvbiBub3QgZm91bmQDCQAAAgkAsQIBBQZhc3NldHMAAAkAAgECFEFzc2V0cyBsaXN0IGlzIGVtcHR5BA52b3RlVXBQb3dlcktleQkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCCF91cFBvd2VyBBB2b3RlRG93blBvd2VyS2V5CQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIKX2Rvd25Qb3dlcgQRdm90ZVRvdGFsUG93ZXJLZXkJAKwCAgkArAICAgV2b3RlXwUGdm90ZUlkAgtfdG90YWxQb3dlcgQPdm90ZVVzZWROZnRzS2V5CQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIJX3VzZWROZnRzBBJ2b3RlclNwZW50UG93ZXJLZXkJAKwCAgkArAICAgZ2b3Rlcl8FCmFkZHJlc3NTdHICC19zcGVudFBvd2VyBBR2b3RlclZvdGVVc2VkTmZ0c0tleQkArAICCQCsAgIJAKwCAgkArAICAgZ2b3Rlcl8FCmFkZHJlc3NTdHICBl92b3RlXwUGdm90ZUlkAglfdXNlZE5mdHMEFnZvdGVyVm90ZVNwZW50UG93ZXJLZXkJAKwCAgkArAICCQCsAgIJAKwCAgIGdm90ZXJfBQphZGRyZXNzU3RyAgZfdm90ZV8FBnZvdGVJZAILX3NwZW50UG93ZXIED2FkZHJlc3NQb3dlcktleQkArAICCQCsAgICCGFkZHJlc3NfBQphZGRyZXNzU3RyAgZfcG93ZXIEFGFkZHJlc3NTdGFrZWROZnRzS2V5CQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICC19zdGFrZWROZnRzBAt1cFBvd2VyRGFwcAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQ52b3RlVXBQb3dlcktleQAABA1kb3duUG93ZXJEYXBwCQELdmFsdWVPckVsc2UCCQCfCAEFEHZvdGVEb3duUG93ZXJLZXkAAAQOdG90YWxWb3RlUG93ZXIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQURdm90ZVRvdGFsUG93ZXJLZXkAAAQMdm90ZVVzZWROZnRzCQELdmFsdWVPckVsc2UCCQCiCAEFD3ZvdGVVc2VkTmZ0c0tleQIABA92b3RlclNwZW50UG93ZXIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUSdm90ZXJTcGVudFBvd2VyS2V5AAAEEXZvdGVyVm90ZVVzZWROZnRzCQELdmFsdWVPckVsc2UCCQCiCAEFFHZvdGVyVm90ZVVzZWROZnRzS2V5AgAED3RvdGFsU3BlbnRQb3dlcgkBC3ZhbHVlT3JFbHNlAgkAnwgBBRJ0b3RhbFNwZW50UG93ZXJLZXkAAAQTdm90ZXJWb3RlU3BlbnRQb3dlcgkBC3ZhbHVlT3JFbHNlAgkAnwgBBRZ2b3RlclZvdGVTcGVudFBvd2VyS2V5AAAEDGFkZHJlc3NQb3dlcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFD2FkZHJlc3NQb3dlcktleQIUWW91IGRvbid0IGhhdmUgcG93ZXIEEWFkZHJlc3NTdGFrZWROZnRzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKIIAQUUYWRkcmVzc1N0YWtlZE5mdHNLZXkCGllvdSBkb24ndCBoYXZlIHN0YWtlZCBORlRzBBlhZGRlcnNzTGFzdFJld2FyZFJvdW5kS2V5CQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICEV9sYXN0UmV3YXJkc1JvdW5kBBNjdXJyZW50UmV3b3Jkc1JvdW5kCQELdmFsdWVPckVsc2UCCQCfCAEFFmN1cnJlbnRSZXdvcmRzUm91bmRLZXkAAAQWYWRkZXJzc0xhc3RSZXdhcmRSb3VuZAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRlhZGRlcnNzTGFzdFJld2FyZFJvdW5kS2V5AAAECmFzc2V0c0xpc3QJALUJAgUGYXNzZXRzAgF8BBB2b3RlVXNlZE5mdHNMaXN0AwkAAAIJALECAQUMdm90ZVVzZWROZnRzAAAFA25pbAkAvQkCBQx2b3RlVXNlZE5mdHMCASwEFXZvdGVyVm90ZVVzZWROZnRzTGlzdAMJAAACCQCxAgEFEXZvdGVyVm90ZVVzZWROZnRzAAAFA25pbAkAvQkCBRF2b3RlclZvdGVVc2VkTmZ0cwIBLAoBDXByb2Nlc3NBc3NldHMCBWFjY3VtBG5leHQEBXBhcnRzCQC1CQIFBG5leHQCAV8EBW5mdElkCQCRAwIFBXBhcnRzAAAEBHR5cGUJAJEDAgUFcGFydHMAAQQFcG93ZXIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnwgBCQCsAgIJAKwCAgIEbmZ0XwUFbmZ0SWQCBl9wb3dlcgITTkZUIHBvd2VyIG5vdCBmb3VuZAQQc3Rha2VkT3duZXJJbmRleAkBC3ZhbHVlT3JFbHNlAgkAswkCBRFhZGRyZXNzU3Rha2VkTmZ0cwUFbmZ0SWQA////////////AQMJAAACBQVwb3dlcgAACQACAQIXUG93ZXIgbXVzdCBiZSBtb3JlIHplcm8DCQAAAgUQc3Rha2VkT3duZXJJbmRleAD///////////8BCQACAQIcQXNzZXQgZG9lcyBub3QgYmVsb25nIHRvIHlvdQQKYXNzZXRJbmRleAkBC3ZhbHVlT3JFbHNlAgkAzwgCBRB2b3RlVXNlZE5mdHNMaXN0BQVuZnRJZAD///////////8BAwkAAAIFCmFzc2V0SW5kZXgA////////////AQMDCQECIT0CBQR0eXBlAgJ1cAkBAiE9AgUEdHlwZQIEZG93bgcJAAIBAgxJbnZhbGlkIHR5cGUJAJYKBAkAZAIIBQVhY2N1bQJfMQMJAAACBQR0eXBlAgJ1cAUFcG93ZXIAAAkAZAIIBQVhY2N1bQJfMgMJAAACBQR0eXBlAgRkb3duBQVwb3dlcgAACQDNCAIIBQVhY2N1bQJfMwUFbmZ0SWQJAM0IAggFBWFjY3VtAl80CQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIGdm90ZXJfBQphZGRyZXNzU3RyAgZfdm90ZV8FBnZvdGVJZAIJX2Fzc2V0SWRfBQVuZnRJZAkArAICCQCsAgIJAKwCAgkArAICBQR0eXBlAgE6CQCkAwEFBXBvd2VyAgE6CQCkAwEFBmhlaWdodAUFYWNjdW0EEnByb2Nlc3NSZXN1bHRUdXBsZQoAAiRsBQphc3NldHNMaXN0CgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlgoEAAAAAAUDbmlsBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDXByb2Nlc3NBc3NldHMCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDUJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFBAd1cFBvd2VyCAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl8xBAlkb3duUG93ZXIIBRJwcm9jZXNzUmVzdWx0VHVwbGUCXzIECnBvd2VyVmFsdWUJAGQCBQd1cFBvd2VyBQlkb3duUG93ZXIDCQBmAgUKcG93ZXJWYWx1ZQUMYWRkcmVzc1Bvd2VyCQACAQIiUG93ZXIgZXhjZWVkcyBwb3dlciBvZiB0aGUgYWNjb3VudAMJAAACBQpwb3dlclZhbHVlAAAJAAIBAhhOb3QgZW5vdWdoIHBvd2VyIHRvIHZvdGUDCQAAAgkAkAMBCAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl8zAAAJAAIBAhtVc2VkIGxpc3QgbXVzdCBub3QgYmUgZW1wdHkDCQAAAgkAkAMBCAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl80AAAJAAIBAiRTdGF0ZSBlbnRyaWVzIGxpc3QgbXVzdCBub3QgYmUgZW1wdHkEC3F1b3J1bUxpbWl0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQURdm90ZVBvd2VyTGltaXRLZXkCGlZvdGUgcG93ZXIgbGltaXQgbm90IGZvdW5kBBR1cGRhdGVDYW5kaXRhdGVzTGlzdAMJAGYCCQBkAgUOdG90YWxWb3RlUG93ZXIFCnBvd2VyVmFsdWUFC3F1b3J1bUxpbWl0CQEVYWRkU3RyaW5nVG9TdGF0ZUFycmF5AgUYZmluYWxWb3RpbmdDYW5kaWRhdGVzS2V5BQZ2b3RlSWQFA25pbAQYYWRkcmVzc1Jld29yZHNSb3VuZFN0YXRlAwMJAAACBRZhZGRlcnNzTGFzdFJld2FyZFJvdW5kAAAJAGYCBRNjdXJyZW50UmV3b3Jkc1JvdW5kBRZhZGRlcnNzTGFzdFJld2FyZFJvdW5kBwkAzAgCCQEMSW50ZWdlckVudHJ5AgUZYWRkZXJzc0xhc3RSZXdhcmRSb3VuZEtleQUTY3VycmVudFJld29yZHNSb3VuZAUDbmlsBQNuaWwJAM4IAgkAzggCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFEnZvdGVyU3BlbnRQb3dlcktleQkAZAIFD3ZvdGVyU3BlbnRQb3dlcgUKcG93ZXJWYWx1ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgUSdG90YWxTcGVudFBvd2VyS2V5CQBkAgUPdG90YWxTcGVudFBvd2VyBQpwb3dlclZhbHVlCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ52b3RlVXBQb3dlcktleQkAZAIFC3VwUG93ZXJEYXBwBQd1cFBvd2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRB2b3RlRG93blBvd2VyS2V5CQBkAgUNZG93blBvd2VyRGFwcAUJZG93blBvd2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRF2b3RlVG90YWxQb3dlcktleQkAZAIFDnRvdGFsVm90ZVBvd2VyBQpwb3dlclZhbHVlCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRZ2b3RlclZvdGVTcGVudFBvd2VyS2V5CQBkAgUTdm90ZXJWb3RlU3BlbnRQb3dlcgUKcG93ZXJWYWx1ZQkAzAgCCQELU3RyaW5nRW50cnkCBRR2b3RlclZvdGVVc2VkTmZ0c0tleQkAuwkCCQDOCAIFFXZvdGVyVm90ZVVzZWROZnRzTGlzdAgFEnByb2Nlc3NSZXN1bHRUdXBsZQJfMwIBLAkAzAgCCQELU3RyaW5nRW50cnkCBQ92b3RlVXNlZE5mdHNLZXkJALsJAgkAzggCBRB2b3RlVXNlZE5mdHNMaXN0CAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl8zAgEsBQNuaWwIBRJwcm9jZXNzUmVzdWx0VHVwbGUCXzQFFHVwZGF0ZUNhbmRpdGF0ZXNMaXN0BRhhZGRyZXNzUmV3b3Jkc1JvdW5kU3RhdGUBaQELdW52b3RlQnlORlQCBnZvdGVJZAZhc3NldHMECmFkZHJlc3NTdHIJAKUIAQgFAWkGY2FsbGVyBAxjb2xsZWN0aW9uSWQJAQt2YWx1ZU9yRWxzZQIJAKIIAQkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCDV9jb2xsZWN0aW9uSWQCAAMJAQ5pc1ZvdGluZ0Nsb3NlZAEFBnZvdGVJZAkAAgECEFZvdGluZyBpcyBjbG9zZWQDCQAAAgkAsQIBBQxjb2xsZWN0aW9uSWQAAAkAAgECFENvbGxlY3Rpb24gbm90IGZvdW5kBA52b3RlVXBQb3dlcktleQkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCCF91cFBvd2VyBBB2b3RlRG93blBvd2VyS2V5CQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIKX2Rvd25Qb3dlcgQRdm90ZVRvdGFsUG93ZXJLZXkJAKwCAgkArAICAgV2b3RlXwUGdm90ZUlkAgtfdG90YWxQb3dlcgQPdm90ZVVzZWROZnRzS2V5CQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAIJX3VzZWROZnRzBBJ2b3RlclNwZW50UG93ZXJLZXkJAKwCAgkArAICAgZ2b3Rlcl8FCmFkZHJlc3NTdHICC19zcGVudFBvd2VyBBR2b3RlclZvdGVVc2VkTmZ0c0tleQkArAICCQCsAgIJAKwCAgkArAICAgZ2b3Rlcl8FCmFkZHJlc3NTdHICBl92b3RlXwUGdm90ZUlkAglfdXNlZE5mdHMEFnZvdGVyVm90ZVNwZW50UG93ZXJLZXkJAKwCAgkArAICCQCsAgIJAKwCAgIGdm90ZXJfBQphZGRyZXNzU3RyAgZfdm90ZV8FBnZvdGVJZAILX3NwZW50UG93ZXIED2FkZHJlc3NQb3dlcktleQkArAICCQCsAgICCGFkZHJlc3NfBQphZGRyZXNzU3RyAgZfcG93ZXIEFGFkZHJlc3NTdGFrZWROZnRzS2V5CQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICC19zdGFrZWROZnRzBAt1cFBvd2VyRGFwcAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFDnZvdGVVcFBvd2VyS2V5AhdVcCB2b3RlIHBvd2VyIG5vdCBmb3VuZAQNZG93blBvd2VyRGFwcAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFEHZvdGVEb3duUG93ZXJLZXkCGURvd24gdm90ZSBwb3dlciBub3QgZm91bmQEDnRvdGFsVm90ZVBvd2VyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQURdm90ZVRvdGFsUG93ZXJLZXkCGlRvdGFsIHZvdGUgcG93ZXIgbm90IGZvdW5kBAx2b3RlVXNlZE5mdHMJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBBQ92b3RlVXNlZE5mdHNLZXkCGVZvdGUgdXNlZCBwb3dlciBub3QgZm91bmQED3ZvdGVyU3BlbnRQb3dlcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFEnZvdGVyU3BlbnRQb3dlcktleQIbVm90ZXIgc3BlbnQgcG93ZXIgbm90IGZvdW5kBA12b3RlclVzZWROZnRzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQUUdm90ZXJWb3RlVXNlZE5mdHNLZXkCHlZvdGVyIHZvdGUgdXNlZCBuZnRzIG5vdCBmb3VuZAQRdm90ZXJWb3RlVXNlZE5mdHMJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBBRR2b3RlclZvdGVVc2VkTmZ0c0tleQIjVm90ZXIgdm90ZSB1c2VkIG5mdHMgbGlzdCBub3QgZm91bmQED3RvdGFsU3BlbnRQb3dlcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFEnRvdGFsU3BlbnRQb3dlcktleQIbVG90YWwgc3BlbnQgcG93ZXIgbm90IGZvdW5kBBN2b3RlclZvdGVTcGVudFBvd2VyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQUWdm90ZXJWb3RlU3BlbnRQb3dlcktleQIiQWRkcmVzcyB2b3RlIHNwZW50IHBvd2VyIG5vdCBmb3VuZAQMYWRkcmVzc1Bvd2VyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQUPYWRkcmVzc1Bvd2VyS2V5AhRZb3UgZG9uJ3QgaGF2ZSBwb3dlcgQRYWRkcmVzc1N0YWtlZE5mdHMJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBBRRhZGRyZXNzU3Rha2VkTmZ0c0tleQIaWW91IGRvbid0IGhhdmUgc3Rha2VkIE5GVHMECmFzc2V0c0xpc3QDCQBmAgkAsQIBBQZhc3NldHMAAAkAtQkCBQZhc3NldHMCAXwDCQAAAgkAsQIBBRF2b3RlclZvdGVVc2VkTmZ0cwAABQNuaWwJALUJAgURdm90ZXJWb3RlVXNlZE5mdHMCASwKAQ1wcm9jZXNzQXNzZXRzAgVhY2N1bQRuZXh0BAlhc3NldFZvdGUJAQt2YWx1ZU9yRWxzZQIJAKIIAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgICBnZvdGVyXwUKYWRkcmVzc1N0cgIGX3ZvdGVfBQZ2b3RlSWQCCV9hc3NldElkXwUEbmV4dAIABAVwYXJ0cwkAtQkCBQlhc3NldFZvdGUCAToEBHR5cGUJAJEDAgUFcGFydHMAAAQFcG93ZXIJAQt2YWx1ZU9yRWxzZQIJALYJAQkAkQMCBQVwYXJ0cwABAAAEEHN0YWtlZE93bmVySW5kZXgJAQt2YWx1ZU9yRWxzZQIJALMJAgURYWRkcmVzc1N0YWtlZE5mdHMFBG5leHQA////////////AQQSdm90ZXJWb3RlVXNlZEluZGV4CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAM8IAggFBWFjY3VtAl80BQRuZXh0Ah9Wb3RlciB2b3RlIHVzZWQgaW5kZXggbm90IGZvdW5kAwkAAAIJALECAQUJYXNzZXRWb3RlAAAFBWFjY3VtAwkAAAIFBXBvd2VyAAAJAAIBAhdQb3dlciBtdXN0IGJlIG1vcmUgemVybwMDCQBmAgAABRJ2b3RlclZvdGVVc2VkSW5kZXgJAAACBRBzdGFrZWRPd25lckluZGV4AP///////////wEHCQACAQIcQXNzZXQgZG9lcyBub3QgYmVsb25nIHRvIHlvdQQOYXNzZXRVc2VkSW5kZXgJAQt2YWx1ZU9yRWxzZQIJAM8IAggFBWFjY3VtAl8zBQRuZXh0AP///////////wEDCQBnAgUOYXNzZXRVc2VkSW5kZXgAAAMDCQECIT0CBQR0eXBlAgJ1cAkBAiE9AgUEdHlwZQIEZG93bgcJAAIBAgxJbnZhbGlkIHR5cGUJAJcKBQkAZAIIBQVhY2N1bQJfMQMJAAACBQR0eXBlAgJ1cAUFcG93ZXIAAAkAZAIIBQVhY2N1bQJfMgMJAAACBQR0eXBlAgRkb3duBQVwb3dlcgAACQDRCAIIBQVhY2N1bQJfMwUOYXNzZXRVc2VkSW5kZXgJANEIAggFBWFjY3VtAl80BRJ2b3RlclZvdGVVc2VkSW5kZXgJAM0IAggFBWFjY3VtAl81CQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIGdm90ZXJfBQphZGRyZXNzU3RyAgZfdm90ZV8FBnZvdGVJZAIJX2Fzc2V0SWRfBQRuZXh0BQVhY2N1bQQScHJvY2Vzc1Jlc3VsdFR1cGxlCgACJGwFCmFzc2V0c0xpc3QKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCXCgUAAAAACQC9CQIFDHZvdGVVc2VkTmZ0cwIBLAkAvQkCBRF2b3RlclZvdGVVc2VkTmZ0cwIBLAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQ1wcm9jZXNzQXNzZXRzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA1CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQQHdXBQb3dlcggFEnByb2Nlc3NSZXN1bHRUdXBsZQJfMQQJZG93blBvd2VyCAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl8yBApwb3dlclZhbHVlCQBkAgUHdXBQb3dlcgUJZG93blBvd2VyAwkAZgIFCnBvd2VyVmFsdWUFD3ZvdGVyU3BlbnRQb3dlcgkAAgECJVBvd2VyIHZhbHVlIGV4Y2VlZHMgdm90ZXIgc3BlbnQgcG93ZXIDCQAAAgUKcG93ZXJWYWx1ZQAACQACAQIaTm90IGVub3VnaCBwb3dlciB0byB1bnZvdGUDCQAAAgkAkAMBCAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl81AAAJAAIBAiRTdGF0ZSBlbnRyaWVzIGxpc3QgbXVzdCBub3QgYmUgZW1wdHkEC3F1b3J1bUxpbWl0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQURdm90ZVBvd2VyTGltaXRLZXkCGlZvdGUgcG93ZXIgbGltaXQgbm90IGZvdW5kBBR1cGRhdGVDYW5kaXRhdGVzTGlzdAMJAGYCBQtxdW9ydW1MaW1pdAkAZQIFDnRvdGFsVm90ZVBvd2VyBQpwb3dlclZhbHVlCQEYcmVtb3ZlSXRlbUZyb21TdGF0ZUFycmF5AgUYZmluYWxWb3RpbmdDYW5kaWRhdGVzS2V5BQZ2b3RlSWQFA25pbAkAzggCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFEnZvdGVyU3BlbnRQb3dlcktleQkAZQIFD3ZvdGVyU3BlbnRQb3dlcgUKcG93ZXJWYWx1ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgUSdG90YWxTcGVudFBvd2VyS2V5CQBlAgUPdG90YWxTcGVudFBvd2VyBQpwb3dlclZhbHVlCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ52b3RlVXBQb3dlcktleQkAZQIFC3VwUG93ZXJEYXBwBQd1cFBvd2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRB2b3RlRG93blBvd2VyS2V5CQBlAgUNZG93blBvd2VyRGFwcAUJZG93blBvd2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRF2b3RlVG90YWxQb3dlcktleQkAZQIFDnRvdGFsVm90ZVBvd2VyBQpwb3dlclZhbHVlCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRZ2b3RlclZvdGVTcGVudFBvd2VyS2V5CQBlAgUTdm90ZXJWb3RlU3BlbnRQb3dlcgUKcG93ZXJWYWx1ZQkAzAgCCQELU3RyaW5nRW50cnkCBRR2b3RlclZvdGVVc2VkTmZ0c0tleQkAuwkCCAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl80AgEsCQDMCAIJAQtTdHJpbmdFbnRyeQIFD3ZvdGVVc2VkTmZ0c0tleQkAuwkCCAUScHJvY2Vzc1Jlc3VsdFR1cGxlAl8zAgEsBQNuaWwIBRJwcm9jZXNzUmVzdWx0VHVwbGUCXzUFFHVwZGF0ZUNhbmRpdGF0ZXNMaXN0AWkBDWZpbGxUcmVhc3VhcnkAAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAAkAAgECCk5vIHBheW1lbnQDCQAAAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQAAAkAAgECFlBheW1lbnQgbXVzdCBiZSBtb3JlIDADCQECIT0CCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFC1VTRFRBc3NldElkCQACAQIXUGF5bWVudCBtdXN0IGJlIGluIFVTRFQEBmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQEB2Fzc2V0SWQJAQV2YWx1ZQEICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAQVZmluYWxWb3RpbmdDYW5kaWRhdGVzCQELdmFsdWVPckVsc2UCCQCiCAEFGGZpbmFsVm90aW5nQ2FuZGlkYXRlc0tleQIAAwkAAAIJALECAQUVZmluYWxWb3RpbmdDYW5kaWRhdGVzAAAJAAIBAhhDYW5kaXRhdGVzIGxpc3QgaXMgZW1wdHkEGWZpbmFsVm90aW5nQ2FuZGlkYXRlc0xpc3QJALUJAgUVZmluYWxWb3RpbmdDYW5kaWRhdGVzAgEsCgELcHJvY2Vzc1ZvdGUCBWFjY3VtBG5leHQEBnZvdGVJZAUEbmV4dAQOdm90ZVVwUG93ZXJLZXkJAKwCAgkArAICAgV2b3RlXwUGdm90ZUlkAghfdXBQb3dlcgQQdm90ZURvd25Qb3dlcktleQkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCCl9kb3duUG93ZXIEEXZvdGVUb3RhbFBvd2VyS2V5CQCsAgIJAKwCAgIFdm90ZV8FBnZvdGVJZAILX3RvdGFsUG93ZXIEC3ZvdGVVcFBvd2VyCQELdmFsdWVPckVsc2UCCQCfCAEFDnZvdGVVcFBvd2VyS2V5AAAEDXZvdGVEb3duUG93ZXIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUQdm90ZURvd25Qb3dlcktleQAABA52b3RlVG90YWxQb3dlcgkBC3ZhbHVlT3JFbHNlAgkAnwgBBRF2b3RlVG90YWxQb3dlcktleQAABAtxdW9ydW1MaW1pdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFEXZvdGVQb3dlckxpbWl0S2V5AhpWb3RlIHBvd2VyIGxpbWl0IG5vdCBmb3VuZAMJAAACBQ52b3RlVG90YWxQb3dlcgAACQACAQITSW52YWxpZCB0b3RhbCBwb3dlcgMJAGYCBQtxdW9ydW1MaW1pdAUOdm90ZVRvdGFsUG93ZXIJAAIBAhVQb3dlciBsZXNzIHRoYW4gbGltaXQDCQAAAgkAZAIFC3ZvdGVVcFBvd2VyBQ12b3RlRG93blBvd2VyAAAJAAIBAhZJbnZhbGlkIHVwLCBkb3duIHBvd2VyAwkBDmlzVm90aW5nQ2xvc2VkAQUGdm90ZUlkCQCWCgQIBQVhY2N1bQJfMQgFBWFjY3VtAl8yCAUFYWNjdW0CXzMJARhyZW1vdmVJdGVtRnJvbVN0YXRlQXJyYXkCBRhmaW5hbFZvdGluZ0NhbmRpZGF0ZXNLZXkFBnZvdGVJZAQJdXBQZXJjZW50CQBrAwULdm90ZVVwUG93ZXIAZAUOdm90ZVRvdGFsUG93ZXIEDmZpbmFsVm90ZVN0YXRlAwkAZgIFCXVwUGVyY2VudAAyCQEMQm9vbGVhbkVudHJ5AgkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCCl9jb25maXJtZWQGCQEMQm9vbGVhbkVudHJ5AgkArAICCQCsAgICBXZvdGVfBQZ2b3RlSWQCCV9yZWplY3RlZAYJAJYKBAkAZAIIBQVhY2N1bQJfMQUOdm90ZVRvdGFsUG93ZXIJAM0IAggFBWFjY3VtAl8yBQZ2b3RlSWQJAM0IAggFBWFjY3VtAl8zBQ5maW5hbFZvdGVTdGF0ZQkBGHJlbW92ZUl0ZW1Gcm9tU3RhdGVBcnJheQIFGGZpbmFsVm90aW5nQ2FuZGlkYXRlc0tleQUGdm90ZUlkBAtyZXN1bHRUdXBsZQoAAiRsBRlmaW5hbFZvdGluZ0NhbmRpZGF0ZXNMaXN0CgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlgoEAAAFA25pbAUDbmlsBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBC3Byb2Nlc3NWb3RlAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBBBhbGxFbmRWb3Rlc1Bvd2VyCAULcmVzdWx0VHVwbGUCXzEEDmZpbmFsVm90ZXNMaXN0CAULcmVzdWx0VHVwbGUCXzIED2ZpbmFsVm90ZXNTdGF0ZQgFC3Jlc3VsdFR1cGxlAl8zBBp1cGRhdGVkTGlzdEZpbmFsQ2FuZGl0YXRlcwgFC3Jlc3VsdFR1cGxlAl80AwkAAAIFEGFsbEVuZFZvdGVzUG93ZXIAAAkAAgECIU5vIHBvd2VyIGFmdGVyIHByb2Nlc3MgY2FuZGl0YXRlcwQTY3VycmVudFJld29yZHNSb3VuZAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRZjdXJyZW50UmV3b3Jkc1JvdW5kS2V5AAAEDGNvc3RQZXJQb3dlcgkAawMFBmFtb3VudAABBRBhbGxFbmRWb3Rlc1Bvd2VyBBh0cmVhc3VhcnlBc3NldElkVG90YWxLZXkJAKwCAgkArAICAgp0cmVhc3VhcnlfCQDYBAEFB2Fzc2V0SWQCBl90b3RhbAQcdHJlYXN1YXJ5QXNzZXRJZEF2YWlsYWJsZUtleQkArAICCQCsAgICCnRyZWFzdWFyeV8JANgEAQUHYXNzZXRJZAIKX2F2YWlsYWJsZQQVdHJlYXN1YXJ5QXNzZXRJZFRvdGFsCQELdmFsdWVPckVsc2UCCQCfCAEFGHRyZWFzdWFyeUFzc2V0SWRUb3RhbEtleQAABBl0cmVhc3VhcnlBc3NldElkQXZhaWxhYmxlCQELdmFsdWVPckVsc2UCCQCfCAEFHHRyZWFzdWFyeUFzc2V0SWRBdmFpbGFibGVLZXkAAAkAzggCCQDOCAIJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICB3Jld2FyZF8JAKQDAQUTY3VycmVudFJld29yZHNSb3VuZAIJX3ZvdGVzSWRzCQC5CQIFDmZpbmFsVm90ZXNMaXN0AgEsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICAgdyZXdhcmRfCQCkAwEFE2N1cnJlbnRSZXdvcmRzUm91bmQCCF9hc3NldElkCQDYBAEFB2Fzc2V0SWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdyZXdhcmRfCQCkAwEFE2N1cnJlbnRSZXdvcmRzUm91bmQCDV9jb3N0UGVyUG93ZXIFDGNvc3RQZXJQb3dlcgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICB3Jld2FyZF8JAKQDAQUTY3VycmVudFJld29yZHNSb3VuZAIKX3BhaWRQb3dlcgUQYWxsRW5kVm90ZXNQb3dlcgkAzAgCCQEMSW50ZWdlckVudHJ5AgUYdHJlYXN1YXJ5QXNzZXRJZFRvdGFsS2V5CQBkAgUVdHJlYXN1YXJ5QXNzZXRJZFRvdGFsBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFHHRyZWFzdWFyeUFzc2V0SWRBdmFpbGFibGVLZXkJAGQCBRl0cmVhc3VhcnlBc3NldElkQXZhaWxhYmxlBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFFmN1cnJlbnRSZXdvcmRzUm91bmRLZXkJAGQCBRNjdXJyZW50UmV3b3Jkc1JvdW5kAAEFA25pbAUPZmluYWxWb3Rlc1N0YXRlBRp1cGRhdGVkTGlzdEZpbmFsQ2FuZGl0YXRlcwFpAQxjbGFpbVJld2FyZHMABAphZGRyZXNzU3RyCQClCAEIBQFpBmNhbGxlcgQZYWRkZXJzc0xhc3RSZXdhcmRSb3VuZEtleQkArAICCQCsAgICCGFkZHJlc3NfBQphZGRyZXNzU3RyAhFfbGFzdFJld2FyZHNSb3VuZAQTY3VycmVudFJld29yZHNSb3VuZAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRZjdXJyZW50UmV3b3Jkc1JvdW5kS2V5AAAEFmFkZGVyc3NMYXN0UmV3YXJkUm91bmQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUZYWRkZXJzc0xhc3RSZXdhcmRSb3VuZEtleQAAAwkAAAIFE2N1cnJlbnRSZXdvcmRzUm91bmQFFmFkZGVyc3NMYXN0UmV3YXJkUm91bmQJAAIBAhpUaGVyZSB3ZXJlIG5vIG5ldyBwYXltZW50cwoBEGNhbGNSZXdhcmRzUm91bmQCBWFjY3VtBG5leHQDCQBnAggFBWFjY3VtAl8xBRNjdXJyZW50UmV3b3Jkc1JvdW5kBQVhY2N1bQQIdm90ZXNJZHMJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBCQCsAgIJAKwCAgIHcmV3YXJkXwkApAMBCAUFYWNjdW0CXzECCV92b3Rlc0lkcwIaUmV3YXJkIHZvdGVzIGlkcyBub3QgZm91bmQEB2Fzc2V0SWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBCQCsAgIJAKwCAgIHcmV3YXJkXwkApAMBCAUFYWNjdW0CXzECCF9hc3NldElkAhhSZXdhcmQgYXNzZXRJZCBub3QgZm91bmQECWNvc3RQb3dlcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEJAKwCAgkArAICAgdyZXdhcmRfCQCkAwEIBQVhY2N1bQJfMQINX2Nvc3RQZXJQb3dlcgIbUmV3YXJkIGNvc3QgcG93ZXIgbm90IGZvdW5kBBp0cmVhc3VhcnlBc3NldElkQ2xhaW1lZEtleQkArAICCQCsAgICCnRyZWFzdWFyeV8FB2Fzc2V0SWQCCF9jbGFpbWVkBBx0cmVhc3VhcnlBc3NldElkQXZhaWxhYmxlS2V5CQCsAgIJAKwCAgIKdHJlYXN1YXJ5XwUHYXNzZXRJZAIKX2F2YWlsYWJsZQQXdHJlYXN1YXJ5QXNzZXRJZENsYWltZWQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUadHJlYXN1YXJ5QXNzZXRJZENsYWltZWRLZXkAAAQZdHJlYXN1YXJ5QXNzZXRJZEF2YWlsYWJsZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFHHRyZWFzdWFyeUFzc2V0SWRBdmFpbGFibGVLZXkCG1RyZWFzdWFyeSBhc3NldElkIG5vdCBmb3VuZAQYYWRkcmVzc0Fzc2V0SWRDbGFpbWVkS2V5CQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgxyZXdhcmRSb3VuZF8JAKQDAQgFBWFjY3VtAl8xAglfYWRkcmVzc18FCmFkZHJlc3NTdHICCV9hc3NldElkXwUHYXNzZXRJZAIIX2NsYWltZWQEFWFkZHJlc3NBc3NldElkQ2xhaW1lZAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRhhZGRyZXNzQXNzZXRJZENsYWltZWRLZXkAAAMJAGcCAAAFGXRyZWFzdWFyeUFzc2V0SWRBdmFpbGFibGUJAAIBAhtUcmVhc3VhcnkgYXNzZXQgSWQgaXMgZW1wdHkDCQAAAgkAsQIBBQh2b3Rlc0lkcwAACQACAQIXVm90ZSBpZHMgbGlzdCBhcmUgZW1wdHkDCQAAAgkAsQIBBQdhc3NldElkAAAJAAIBAhFBc3NldCBpZCBpcyBlbXB0eQMDCQAAAgUJY29zdFBvd2VyAAAGCQBmAgAABQljb3N0UG93ZXIJAAIBAhJJbnZhbGlkIGNvc3QgcG93ZXIKARVjYWxjQWRkcmVzc1NwZW50UG93ZXICBWFjY3VtBG5leHQEBnZvdGVJZAUEbmV4dAQRYWRkcmVzc1NwZW50UG93ZXIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkArAICCQCsAgIJAKwCAgkArAICAgZ2b3Rlcl8FCmFkZHJlc3NTdHICBl92b3RlXwUGdm90ZUlkAgtfc3BlbnRQb3dlcgAACQBkAgUFYWNjdW0FEWFkZHJlc3NTcGVudFBvd2VyBApzcGVudFBvd2VyCgACJGwJALUJAgUIdm90ZXNJZHMCASwKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBFWNhbGNBZGRyZXNzU3BlbnRQb3dlcgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgMDCQBnAgAABQpzcGVudFBvd2VyBgkAZgIFFWFkZHJlc3NBc3NldElkQ2xhaW1lZAAACQCUCgIJAGQCCAUFYWNjdW0CXzEFBG5leHQIBQVhY2N1bQJfMgkAlAoCCQBkAggFBWFjY3VtAl8xBQRuZXh0CQDOCAIIBQVhY2N1bQJfMgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIJAGgCBQpzcGVudFBvd2VyBQljb3N0UG93ZXIJANkEAQUHYXNzZXRJZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUYYWRkcmVzc0Fzc2V0SWRDbGFpbWVkS2V5CQBoAgUKc3BlbnRQb3dlcgUJY29zdFBvd2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRp0cmVhc3VhcnlBc3NldElkQ2xhaW1lZEtleQkAZAIFF3RyZWFzdWFyeUFzc2V0SWRDbGFpbWVkCQBoAgUKc3BlbnRQb3dlcgUJY29zdFBvd2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRx0cmVhc3VhcnlBc3NldElkQXZhaWxhYmxlS2V5CQBlAgUZdHJlYXN1YXJ5QXNzZXRJZEF2YWlsYWJsZQkAaAIFCnNwZW50UG93ZXIFCWNvc3RQb3dlcgUDbmlsBAFyCgACJGwJAMwIAgABCQDMCAIAAQkAzAgCAAEJAMwIAgABCQDMCAIAAQUDbmlsCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlAoCBRZhZGRlcnNzTGFzdFJld2FyZFJvdW5kBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBEGNhbGNSZXdhcmRzUm91bmQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDUJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFGWFkZGVyc3NMYXN0UmV3YXJkUm91bmRLZXkIBQFyAl8xBQNuaWwIBQFyAl8yAQJ0eAEGdmVyaWZ5AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tlea0p9WQ=", "height": 3484158, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 5Vh1TtD7STTgQD7SWojWL9jQxshJdRXxpeVYaD7JPQgL Next: FENYsxAVwJ56k92UAkapZf6KEuNYeyE7FnYXxXcB4WuM Diff:
OldNewDifferences
3636 if (if (if (if (if (n)
3737 then true
3838 else (getStringValue(a, (("nft_" + toBase58String(m.id)) + "_issuer")) == toString(this)))
39- then (m.issuer == a)
39+ then (m.issuer == (if (n)
40+ then b
41+ else a))
4042 else false)
4143 then (m.decimals == 0)
4244 else false)
106108 let H = toString(F.caller)
107109 let I = if ((size(F.payments) > 0))
108110 then F.payments[0]
109- else throw("No payments")
111+ else throw("Payments list is empty")
110112 let m = valueOrErrorMessage(assetInfo(valueOrErrorMessage(I.assetId, "Invalid payment")), "Invalid asset Id")
111113 if (G)
112114 then throw(((((("payments size " + toString(size(F.payments))) + " assetId ") + toBase58String(value(I.assetId))) + " amount ") + toString(I.amount)))
133135 (([IntegerEntry(d, (J + 1)), IntegerEntry(e, (K + R)), StringEntry((("nft_" + S) + "_owner"), H), IntegerEntry((("nft_" + S) + "_power"), R), IntegerEntry(L, (O + R)), IntegerEntry(M, (P + 1))] ++ y(j, H)) ++ T)
134136 }
135137 }
136- else throw("No payments")
138+ else throw("Invalid payment asset Id or amount")
137139 }
138140
139141
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = Address(base58'3PFQjjDMiZKQZdu5JqTHD7HwgSXyp9Rw9By')
55
66 let b = Address(base58'3PDBLdsUrcsiPxNbt8g2gQVoefKgzt3kJzV')
77
88 let c = base58'34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ'
99
1010 let d = "total_staked"
1111
1212 let e = "total_power"
1313
1414 let f = "total_spentPower"
1515
1616 let g = "VOTE_POWER_LIMIT"
1717
1818 let h = "current_rewords_round"
1919
2020 let i = "final_voiting_candidates"
2121
2222 let j = "all_staked_addresses"
2323
2424 let k = ["9iPLsYoz8fNyUp9qcgeAFPpMjKGcb4mNURhAZ7dfzXej", "2K847GdAcqaHHYn1dSS1F3NYriuquJKKzMoBES1cn4Mb", "7D1eCVeMbjHLpjYuqKZ96LoWPwD71quwuWpZxcuKnkJ7", "zjE5dwTv3AukQj6xMyddjcqA82bKvSNLeaKLhnFYKGf", "4T8QSrLLqUpHpi8SecSQT1p5tGo1CAskTGgYgUmXBYEb", "AjHkvxJpgxx8UAMmz6gvxjtBanGBHeEUaYxygdsTRcV6", "4jruFM1gvrtMHXiKdz2EKt12fHGjH5MT8YcZkF6KVGP7", "ZZ1cM8N3UC3uAdoCXJwTwkmpeTSFjpNB4GVa5UwYVGS", "6UAvojJpFxUjAoRFb3nhxCRUdGzFCvxCKniLtJqxVk77", "2NSvp5JX8YTNXWKXpE9kiZA22gg4DM2Yc7mcb9U6PkxB"]
2525
2626 func l (m) = {
2727 let n = {
2828 let o = indexOf(k, toBase58String(m.id))
2929 if ($isInstanceOf(o, "Int"))
3030 then {
3131 let p = o
3232 (p >= 0)
3333 }
3434 else false
3535 }
3636 if (if (if (if (if (n)
3737 then true
3838 else (getStringValue(a, (("nft_" + toBase58String(m.id)) + "_issuer")) == toString(this)))
39- then (m.issuer == a)
39+ then (m.issuer == (if (n)
40+ then b
41+ else a))
4042 else false)
4143 then (m.decimals == 0)
4244 else false)
4345 then (m.reissuable == false)
4446 else false)
4547 then (m.quantity == 1)
4648 else false
4749 }
4850
4951
5052 func q (m) = {
5153 let n = {
5254 let o = indexOf(k, toBase58String(m.id))
5355 if ($isInstanceOf(o, "Int"))
5456 then {
5557 let p = o
5658 (p >= 0)
5759 }
5860 else false
5961 }
6062 if (n)
6163 then 40
6264 else {
6365 let r = getStringValue(a, (("nft_" + toBase58String(m.id)) + "_params"))
6466 if ((r == "gold"))
6567 then 100
6668 else 40
6769 }
6870 }
6971
7072
7173 func s (t) = {
7274 let u = (("vote_" + t) + "_confirmed")
7375 let v = (("vote_" + t) + "_rejected")
7476 let w = valueOrElse(getBoolean(u), false)
7577 let x = valueOrElse(getBoolean(v), false)
7678 if (w)
7779 then true
7880 else x
7981 }
8082
8183
8284 func y (z,A) = {
8385 let B = valueOrElse(getString(z), "")
8486 if (!(isDefined(indexOf(B, A))))
8587 then if ((size(B) == 0))
8688 then [StringEntry(z, A)]
8789 else [StringEntry(z, makeString_11C((split_51C(B, ",") :+ A), ","))]
8890 else nil
8991 }
9092
9193
9294 func C (z,A) = {
9395 let B = valueOrErrorMessage(getString(z), (("Data for key: '" + z) + "' not found"))
9496 if (isDefined(indexOf(B, A)))
9597 then {
9698 let D = split_51C(B, ",")
9799 let E = value(indexOf(D, A))
98100 [StringEntry(z, makeString_11C(removeByIndex(D, E), ","))]
99101 }
100102 else nil
101103 }
102104
103105
104106 @Callable(F)
105107 func stake (G) = {
106108 let H = toString(F.caller)
107109 let I = if ((size(F.payments) > 0))
108110 then F.payments[0]
109- else throw("No payments")
111+ else throw("Payments list is empty")
110112 let m = valueOrErrorMessage(assetInfo(valueOrErrorMessage(I.assetId, "Invalid payment")), "Invalid asset Id")
111113 if (G)
112114 then throw(((((("payments size " + toString(size(F.payments))) + " assetId ") + toBase58String(value(I.assetId))) + " amount ") + toString(I.amount)))
113115 else if (if ((I.amount > 0))
114116 then l(m)
115117 else false)
116118 then {
117119 let J = valueOrElse(getInteger(d), 0)
118120 let K = valueOrElse(getInteger(e), 0)
119121 let L = (("address_" + H) + "_power")
120122 let M = (("address_" + H) + "_totalStaked")
121123 let N = (("address_" + H) + "_stakedNfts")
122124 let O = valueOrElse(getInteger(L), 0)
123125 let P = valueOrElse(getInteger(M), 0)
124126 let Q = valueOrElse(getString(N), "")
125127 if (((P + 1) > 5))
126128 then throw("You can stake only 5 NFTs")
127129 else {
128130 let R = q(m)
129131 let S = toBase58String(m.id)
130132 let T = if ((size(Q) == 0))
131133 then [StringEntry(N, S)]
132134 else [StringEntry(N, makeString((split(Q, ",") :+ S), ","))]
133135 (([IntegerEntry(d, (J + 1)), IntegerEntry(e, (K + R)), StringEntry((("nft_" + S) + "_owner"), H), IntegerEntry((("nft_" + S) + "_power"), R), IntegerEntry(L, (O + R)), IntegerEntry(M, (P + 1))] ++ y(j, H)) ++ T)
134136 }
135137 }
136- else throw("No payments")
138+ else throw("Invalid payment asset Id or amount")
137139 }
138140
139141
140142
141143 @Callable(F)
142144 func unstake (S,G) = {
143145 let H = toString(F.caller)
144146 let m = valueOrErrorMessage(assetInfo(fromBase58String(S)), "Invalid nft Id")
145147 let U = valueOrErrorMessage(getString((("nft_" + S) + "_owner")), "Owner data invalid")
146148 if ((U != H))
147149 then throw("You are not the owner")
148150 else if (l(m))
149151 then {
150152 let J = valueOrElse(getInteger(d), 0)
151153 let K = valueOrElse(getInteger(e), 0)
152154 let L = (("address_" + H) + "_power")
153155 let M = (("address_" + H) + "_totalStaked")
154156 let N = (("address_" + H) + "_stakedNfts")
155157 let O = valueOrErrorMessage(getInteger(L), "Address power value not found")
156158 let P = valueOrErrorMessage(getInteger(M), "Address total staked value not found")
157159 let Q = valueOrErrorMessage(getString(N), "Address staked Nfts value not found")
158160 let V = toBase58String(m.id)
159161 let R = getIntegerValue((("nft_" + V) + "_power"))
160162 let W = (O - R)
161163 let X = if ((W == 0))
162164 then C(j, H)
163165 else nil
164166 let Y = split(Q, ",")
165167 let Z = valueOrErrorMessage(indexOf(Y, S), "NFT not founed in address staked list")
166168 ([ScriptTransfer(F.caller, 1, m.id), IntegerEntry(d, (J - 1)), IntegerEntry(e, (K - R)), DeleteEntry((("nft_" + V) + "_owner")), DeleteEntry((("nft_" + V) + "_power")), IntegerEntry(L, W), IntegerEntry(M, (P - 1)), StringEntry(N, makeString(removeByIndex(Y, Z), ","))] ++ X)
167169 }
168170 else throw("Invalid nft Id")
169171 }
170172
171173
172174
173175 @Callable(F)
174176 func sendToVote (aa) = {
175177 let ab = split(aa, "_")[0]
176178 let ac = {
177179 let o = getString((("collection_" + aa) + "_voteId"))
178180 if ($isInstanceOf(o, "String"))
179181 then {
180182 let ad = o
181183 true
182184 }
183185 else false
184186 }
185187 if ((size(ab) == 0))
186188 then throw("Collection issuer not found")
187189 else if (ac)
188190 then throw("Collection has already been submitted for voting")
189191 else if ((ab != toString(F.caller)))
190192 then throw("Only the issuer can submit to the vote")
191193 else {
192194 let t = toBase58String(sha256_16Kb(toBytes(aa)))
193195 let ae = valueOrElse(getInteger("total_votes"), 0)
194196 let af = valueOrErrorMessage(getInteger(g), "Vote power limit not found")
195197 [StringEntry((("collection_" + aa) + "_voteId"), t), StringEntry((("vote_" + t) + "_collectionId"), aa), StringEntry((("vote_" + t) + "_owner"), toString(F.caller)), IntegerEntry((("vote_" + t) + "_createdAt"), height), IntegerEntry((("vote_" + t) + "_quorum"), af), IntegerEntry("total_votes", (ae + 1))]
196198 }
197199 }
198200
199201
200202
201203 @Callable(F)
202204 func removeFromVote (t) = {
203205 let aa = valueOrErrorMessage(getString((("vote_" + t) + "_collectionId")), "Collection Id not found")
204206 let ag = valueOrErrorMessage(getString((("vote_" + t) + "_owner")), "Owner not found")
205207 if ((ag != toString(F.caller)))
206208 then throw("You are not the owner")
207209 else if (s(t))
208210 then throw("Voting is closed")
209211 else {
210212 let ae = valueOrErrorMessage(getInteger("total_votes"), "total votes value not found")
211213 [DeleteEntry((("collection_" + aa) + "_voteId")), DeleteEntry((("vote_" + t) + "_collectionId")), DeleteEntry((("vote_" + t) + "_owner")), DeleteEntry((("vote_" + t) + "_createdAt")), DeleteEntry((("vote_" + t) + "_quorum")), IntegerEntry("total_votes", (ae - 1))]
212214 }
213215 }
214216
215217
216218
217219 @Callable(F)
218220 func voteByNFT (t,ah) = {
219221 let H = toString(F.caller)
220222 let aa = valueOrElse(getString((("vote_" + t) + "_collectionId")), "")
221223 if (s(t))
222224 then throw("Voting is closed")
223225 else if ((size(aa) == 0))
224226 then throw("Collection not found")
225227 else if ((size(ah) == 0))
226228 then throw("Assets list is empty")
227229 else {
228230 let ai = (("vote_" + t) + "_upPower")
229231 let aj = (("vote_" + t) + "_downPower")
230232 let ak = (("vote_" + t) + "_totalPower")
231233 let al = (("vote_" + t) + "_usedNfts")
232234 let am = (("voter_" + H) + "_spentPower")
233235 let an = (((("voter_" + H) + "_vote_") + t) + "_usedNfts")
234236 let ao = (((("voter_" + H) + "_vote_") + t) + "_spentPower")
235237 let L = (("address_" + H) + "_power")
236238 let N = (("address_" + H) + "_stakedNfts")
237239 let ap = valueOrElse(getInteger(ai), 0)
238240 let aq = valueOrElse(getInteger(aj), 0)
239241 let ar = valueOrElse(getInteger(ak), 0)
240242 let as = valueOrElse(getString(al), "")
241243 let at = valueOrElse(getInteger(am), 0)
242244 let au = valueOrElse(getString(an), "")
243245 let av = valueOrElse(getInteger(f), 0)
244246 let aw = valueOrElse(getInteger(ao), 0)
245247 let O = valueOrErrorMessage(getInteger(L), "You don't have power")
246248 let Q = valueOrErrorMessage(getString(N), "You don't have staked NFTs")
247249 let ax = (("address_" + H) + "_lastRewardsRound")
248250 let ay = valueOrElse(getInteger(h), 0)
249251 let az = valueOrElse(getInteger(ax), 0)
250252 let aA = split(ah, "|")
251253 let aB = if ((size(as) == 0))
252254 then nil
253255 else split_51C(as, ",")
254256 let aC = if ((size(au) == 0))
255257 then nil
256258 else split_51C(au, ",")
257259 func aD (aE,aF) = {
258260 let aG = split(aF, "_")
259261 let aH = aG[0]
260262 let aI = aG[1]
261263 let aJ = valueOrErrorMessage(getInteger((("nft_" + aH) + "_power")), "NFT power not found")
262264 let aK = valueOrElse(indexOf(Q, aH), -1)
263265 if ((aJ == 0))
264266 then throw("Power must be more zero")
265267 else if ((aK == -1))
266268 then throw("Asset does not belong to you")
267269 else {
268270 let aL = valueOrElse(indexOf(aB, aH), -1)
269271 if ((aL == -1))
270272 then if (if ((aI != "up"))
271273 then (aI != "down")
272274 else false)
273275 then throw("Invalid type")
274276 else $Tuple4((aE._1 + (if ((aI == "up"))
275277 then aJ
276278 else 0)), (aE._2 + (if ((aI == "down"))
277279 then aJ
278280 else 0)), (aE._3 :+ aH), (aE._4 :+ StringEntry(((((("voter_" + H) + "_vote_") + t) + "_assetId_") + aH), ((((aI + ":") + toString(aJ)) + ":") + toString(height)))))
279281 else aE
280282 }
281283 }
282284
283285 let aM = {
284286 let aN = aA
285287 let aO = size(aN)
286288 let aP = $Tuple4(0, 0, nil, nil)
287289 func aQ (aR,aS) = if ((aS >= aO))
288290 then aR
289291 else aD(aR, aN[aS])
290292
291293 func aT (aR,aS) = if ((aS >= aO))
292294 then aR
293295 else throw("List size exceeds 5")
294296
295297 aT(aQ(aQ(aQ(aQ(aQ(aP, 0), 1), 2), 3), 4), 5)
296298 }
297299 let aU = aM._1
298300 let aV = aM._2
299301 let aW = (aU + aV)
300302 if ((aW > O))
301303 then throw("Power exceeds power of the account")
302304 else if ((aW == 0))
303305 then throw("Not enough power to vote")
304306 else if ((size(aM._3) == 0))
305307 then throw("Used list must not be empty")
306308 else if ((size(aM._4) == 0))
307309 then throw("State entries list must not be empty")
308310 else {
309311 let af = valueOrErrorMessage(getInteger(g), "Vote power limit not found")
310312 let aX = if (((ar + aW) > af))
311313 then y(i, t)
312314 else nil
313315 let aY = if (if ((az == 0))
314316 then (ay > az)
315317 else false)
316318 then [IntegerEntry(ax, ay)]
317319 else nil
318320 ((([IntegerEntry(am, (at + aW)), IntegerEntry(f, (av + aW)), IntegerEntry(ai, (ap + aU)), IntegerEntry(aj, (aq + aV)), IntegerEntry(ak, (ar + aW)), IntegerEntry(ao, (aw + aW)), StringEntry(an, makeString_11C((aC ++ aM._3), ",")), StringEntry(al, makeString_11C((aB ++ aM._3), ","))] ++ aM._4) ++ aX) ++ aY)
319321 }
320322 }
321323 }
322324
323325
324326
325327 @Callable(F)
326328 func unvoteByNFT (t,ah) = {
327329 let H = toString(F.caller)
328330 let aa = valueOrElse(getString((("vote_" + t) + "_collectionId")), "")
329331 if (s(t))
330332 then throw("Voting is closed")
331333 else if ((size(aa) == 0))
332334 then throw("Collection not found")
333335 else {
334336 let ai = (("vote_" + t) + "_upPower")
335337 let aj = (("vote_" + t) + "_downPower")
336338 let ak = (("vote_" + t) + "_totalPower")
337339 let al = (("vote_" + t) + "_usedNfts")
338340 let am = (("voter_" + H) + "_spentPower")
339341 let an = (((("voter_" + H) + "_vote_") + t) + "_usedNfts")
340342 let ao = (((("voter_" + H) + "_vote_") + t) + "_spentPower")
341343 let L = (("address_" + H) + "_power")
342344 let N = (("address_" + H) + "_stakedNfts")
343345 let ap = valueOrErrorMessage(getInteger(ai), "Up vote power not found")
344346 let aq = valueOrErrorMessage(getInteger(aj), "Down vote power not found")
345347 let ar = valueOrErrorMessage(getInteger(ak), "Total vote power not found")
346348 let as = valueOrErrorMessage(getString(al), "Vote used power not found")
347349 let at = valueOrErrorMessage(getInteger(am), "Voter spent power not found")
348350 let aZ = valueOrErrorMessage(getInteger(an), "Voter vote used nfts not found")
349351 let au = valueOrErrorMessage(getString(an), "Voter vote used nfts list not found")
350352 let av = valueOrErrorMessage(getInteger(f), "Total spent power not found")
351353 let aw = valueOrErrorMessage(getInteger(ao), "Address vote spent power not found")
352354 let O = valueOrErrorMessage(getInteger(L), "You don't have power")
353355 let Q = valueOrErrorMessage(getString(N), "You don't have staked NFTs")
354356 let aA = if ((size(ah) > 0))
355357 then split(ah, "|")
356358 else if ((size(au) == 0))
357359 then nil
358360 else split(au, ",")
359361 func aD (aE,aF) = {
360362 let ba = valueOrElse(getString(((((("voter_" + H) + "_vote_") + t) + "_assetId_") + aF)), "")
361363 let aG = split(ba, ":")
362364 let aI = aG[0]
363365 let aJ = valueOrElse(parseInt(aG[1]), 0)
364366 let aK = valueOrElse(indexOf(Q, aF), -1)
365367 let bb = valueOrErrorMessage(indexOf(aE._4, aF), "Voter vote used index not found")
366368 if ((size(ba) == 0))
367369 then aE
368370 else if ((aJ == 0))
369371 then throw("Power must be more zero")
370372 else if (if ((0 > bb))
371373 then (aK == -1)
372374 else false)
373375 then throw("Asset does not belong to you")
374376 else {
375377 let bc = valueOrElse(indexOf(aE._3, aF), -1)
376378 if ((bc >= 0))
377379 then if (if ((aI != "up"))
378380 then (aI != "down")
379381 else false)
380382 then throw("Invalid type")
381383 else $Tuple5((aE._1 + (if ((aI == "up"))
382384 then aJ
383385 else 0)), (aE._2 + (if ((aI == "down"))
384386 then aJ
385387 else 0)), removeByIndex(aE._3, bc), removeByIndex(aE._4, bb), (aE._5 :+ DeleteEntry(((((("voter_" + H) + "_vote_") + t) + "_assetId_") + aF))))
386388 else aE
387389 }
388390 }
389391
390392 let aM = {
391393 let aN = aA
392394 let aO = size(aN)
393395 let aP = $Tuple5(0, 0, split_51C(as, ","), split_51C(au, ","), nil)
394396 func aQ (aR,aS) = if ((aS >= aO))
395397 then aR
396398 else aD(aR, aN[aS])
397399
398400 func aT (aR,aS) = if ((aS >= aO))
399401 then aR
400402 else throw("List size exceeds 5")
401403
402404 aT(aQ(aQ(aQ(aQ(aQ(aP, 0), 1), 2), 3), 4), 5)
403405 }
404406 let aU = aM._1
405407 let aV = aM._2
406408 let aW = (aU + aV)
407409 if ((aW > at))
408410 then throw("Power value exceeds voter spent power")
409411 else if ((aW == 0))
410412 then throw("Not enough power to unvote")
411413 else if ((size(aM._5) == 0))
412414 then throw("State entries list must not be empty")
413415 else {
414416 let af = valueOrErrorMessage(getInteger(g), "Vote power limit not found")
415417 let aX = if ((af > (ar - aW)))
416418 then C(i, t)
417419 else nil
418420 (([IntegerEntry(am, (at - aW)), IntegerEntry(f, (av - aW)), IntegerEntry(ai, (ap - aU)), IntegerEntry(aj, (aq - aV)), IntegerEntry(ak, (ar - aW)), IntegerEntry(ao, (aw - aW)), StringEntry(an, makeString_11C(aM._4, ",")), StringEntry(al, makeString_11C(aM._3, ","))] ++ aM._5) ++ aX)
419421 }
420422 }
421423 }
422424
423425
424426
425427 @Callable(F)
426428 func fillTreasuary () = if ((size(F.payments) == 0))
427429 then throw("No payment")
428430 else if ((F.payments[0].amount == 0))
429431 then throw("Payment must be more 0")
430432 else if ((F.payments[0].assetId != c))
431433 then throw("Payment must be in USDT")
432434 else {
433435 let bd = F.payments[0].amount
434436 let be = value(F.payments[0].assetId)
435437 let bf = valueOrElse(getString(i), "")
436438 if ((size(bf) == 0))
437439 then throw("Canditates list is empty")
438440 else {
439441 let bg = split(bf, ",")
440442 func bh (aE,aF) = {
441443 let t = aF
442444 let ai = (("vote_" + t) + "_upPower")
443445 let aj = (("vote_" + t) + "_downPower")
444446 let ak = (("vote_" + t) + "_totalPower")
445447 let bi = valueOrElse(getInteger(ai), 0)
446448 let bj = valueOrElse(getInteger(aj), 0)
447449 let bk = valueOrElse(getInteger(ak), 0)
448450 let af = valueOrErrorMessage(getInteger(g), "Vote power limit not found")
449451 if ((bk == 0))
450452 then throw("Invalid total power")
451453 else if ((af > bk))
452454 then throw("Power less than limit")
453455 else if (((bi + bj) == 0))
454456 then throw("Invalid up, down power")
455457 else if (s(t))
456458 then $Tuple4(aE._1, aE._2, aE._3, C(i, t))
457459 else {
458460 let bl = fraction(bi, 100, bk)
459461 let bm = if ((bl > 50))
460462 then BooleanEntry((("vote_" + t) + "_confirmed"), true)
461463 else BooleanEntry((("vote_" + t) + "_rejected"), true)
462464 $Tuple4((aE._1 + bk), (aE._2 :+ t), (aE._3 :+ bm), C(i, t))
463465 }
464466 }
465467
466468 let bn = {
467469 let aN = bg
468470 let aO = size(aN)
469471 let aP = $Tuple4(0, nil, nil, nil)
470472 func aQ (aR,aS) = if ((aS >= aO))
471473 then aR
472474 else bh(aR, aN[aS])
473475
474476 func aT (aR,aS) = if ((aS >= aO))
475477 then aR
476478 else throw("List size exceeds 10")
477479
478480 aT(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aP, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
479481 }
480482 let bo = bn._1
481483 let bp = bn._2
482484 let bq = bn._3
483485 let br = bn._4
484486 if ((bo == 0))
485487 then throw("No power after process canditates")
486488 else {
487489 let ay = valueOrElse(getInteger(h), 0)
488490 let bs = fraction(bd, 1, bo)
489491 let bt = (("treasuary_" + toBase58String(be)) + "_total")
490492 let bu = (("treasuary_" + toBase58String(be)) + "_available")
491493 let bv = valueOrElse(getInteger(bt), 0)
492494 let bw = valueOrElse(getInteger(bu), 0)
493495 (([StringEntry((("reward_" + toString(ay)) + "_votesIds"), makeString(bp, ",")), StringEntry((("reward_" + toString(ay)) + "_assetId"), toBase58String(be)), IntegerEntry((("reward_" + toString(ay)) + "_costPerPower"), bs), IntegerEntry((("reward_" + toString(ay)) + "_paidPower"), bo), IntegerEntry(bt, (bv + bd)), IntegerEntry(bu, (bw + bd)), IntegerEntry(h, (ay + 1))] ++ bq) ++ br)
494496 }
495497 }
496498 }
497499
498500
499501
500502 @Callable(F)
501503 func claimRewards () = {
502504 let H = toString(F.caller)
503505 let ax = (("address_" + H) + "_lastRewardsRound")
504506 let ay = valueOrElse(getInteger(h), 0)
505507 let az = valueOrElse(getInteger(ax), 0)
506508 if ((ay == az))
507509 then throw("There were no new payments")
508510 else {
509511 func bx (aE,aF) = if ((aE._1 >= ay))
510512 then aE
511513 else {
512514 let by = valueOrErrorMessage(getString((("reward_" + toString(aE._1)) + "_votesIds")), "Reward votes ids not found")
513515 let be = valueOrErrorMessage(getString((("reward_" + toString(aE._1)) + "_assetId")), "Reward assetId not found")
514516 let bz = valueOrErrorMessage(getInteger((("reward_" + toString(aE._1)) + "_costPerPower")), "Reward cost power not found")
515517 let bA = (("treasuary_" + be) + "_claimed")
516518 let bu = (("treasuary_" + be) + "_available")
517519 let bB = valueOrElse(getInteger(bA), 0)
518520 let bw = valueOrErrorMessage(getInteger(bu), "Treasuary assetId not found")
519521 let bC = (((((("rewardRound_" + toString(aE._1)) + "_address_") + H) + "_assetId_") + be) + "_claimed")
520522 let bD = valueOrElse(getInteger(bC), 0)
521523 if ((0 >= bw))
522524 then throw("Treasuary asset Id is empty")
523525 else if ((size(by) == 0))
524526 then throw("Vote ids list are empty")
525527 else if ((size(be) == 0))
526528 then throw("Asset id is empty")
527529 else if (if ((bz == 0))
528530 then true
529531 else (0 > bz))
530532 then throw("Invalid cost power")
531533 else {
532534 func bE (aE,aF) = {
533535 let t = aF
534536 let bF = valueOrElse(getInteger((((("voter_" + H) + "_vote_") + t) + "_spentPower")), 0)
535537 (aE + bF)
536538 }
537539
538540 let bG = {
539541 let aN = split(by, ",")
540542 let aO = size(aN)
541543 let aP = 0
542544 func aQ (aR,aS) = if ((aS >= aO))
543545 then aR
544546 else bE(aR, aN[aS])
545547
546548 func aT (aR,aS) = if ((aS >= aO))
547549 then aR
548550 else throw("List size exceeds 10")
549551
550552 aT(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aP, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
551553 }
552554 if (if ((0 >= bG))
553555 then true
554556 else (bD > 0))
555557 then $Tuple2((aE._1 + aF), aE._2)
556558 else $Tuple2((aE._1 + aF), (aE._2 ++ [ScriptTransfer(F.caller, (bG * bz), fromBase58String(be)), IntegerEntry(bC, (bG * bz)), IntegerEntry(bA, (bB + (bG * bz))), IntegerEntry(bu, (bw - (bG * bz)))]))
557559 }
558560 }
559561
560562 let bH = {
561563 let aN = [1, 1, 1, 1, 1]
562564 let aO = size(aN)
563565 let aP = $Tuple2(az, nil)
564566 func aQ (aR,aS) = if ((aS >= aO))
565567 then aR
566568 else bx(aR, aN[aS])
567569
568570 func aT (aR,aS) = if ((aS >= aO))
569571 then aR
570572 else throw("List size exceeds 5")
571573
572574 aT(aQ(aQ(aQ(aQ(aQ(aP, 0), 1), 2), 3), 4), 5)
573575 }
574576 ([IntegerEntry(ax, bH._1)] ++ bH._2)
575577 }
576578 }
577579
578580
579581 @Verifier(bI)
580582 func bJ () = sigVerify(bI.bodyBytes, bI.proofs[0], bI.senderPublicKey)
581583

github/deemru/w8io/0e76f2f 
215.65 ms