tx · 4f29r3Rifad8HW7x6XTxQu9UJTY38KEgaB7s9HGyiYyY

3MptKi7f3jwXjzqhHpvLLzsSpEQdZiwAo5c:  -0.02200000 Waves

2023.05.10 13:07 [2571648] smart account 3MptKi7f3jwXjzqhHpvLLzsSpEQdZiwAo5c > SELF 0.00000000 Waves

{ "type": 13, "id": "4f29r3Rifad8HW7x6XTxQu9UJTY38KEgaB7s9HGyiYyY", "fee": 2200000, "feeAssetId": null, "timestamp": 1683713308316, "version": 2, "chainId": 84, "sender": "3MptKi7f3jwXjzqhHpvLLzsSpEQdZiwAo5c", "senderPublicKey": "44kjsoExo76qSrM51NMhbG8FtdLkcPtyJxEDrwDyT8kz", "proofs": [ "e6uAt3fw7uYa1hmfhsqt3nXUtSWAKFrVU85SgDZYNajp56ywCw4jKhovhBM1UyHApf5aSrvLoVYLJcFirFH6U9d" ], "script": "base64:BgK6IggCEgkKBwEBAQEBCAESABIECgIICBIDCgEIEgQKAggIEgQKAggIIg9nZXRTdHJpbmdPckZhaWwiA2tleSIDU0VQIghCVUZTQ0FMRSIGc2NhbGU4Igh0aHJvd0VyciIDbXNnIghhc1N0cmluZyIDdmFsIgckbWF0Y2gwIgZ2YWxTdHIiHWNvbnZlcnRQcmljZUFzc2V0SW50b0lkb0Fzc2V0IhBwcmljZUFzc2V0QW1vdW50Ig5wcmljZUFzc2V0TVVMVCIFcHJpY2UiCXByaWNlTVVMVCIMaWRvQXNzZXRNVUxUIg9iUHJpY2VBc3NldE1VTFQiDWJJZG9Bc3NldE1VTFQiDmJQcmljZUFzc2V0QlVGIg9iQW1vdW50QXNzZXRCVUYiDklkeENmZ0lkb1N0YXJ0IhFJZHhDZmdJZG9EdXJhdGlvbiIQSWR4Q2ZnQ2xhaW1TdGFydCITSWR4Q2ZnQ2xhaW1EdXJhdGlvbiILSWR4Q2ZnUHJpY2UiD0lkeENmZ1ByaWNlTXVsdCIQSWR4Q2ZnSWRvQXNzZXRJZCISSWR4Q2ZnSWRvQXNzZXRNdWx0IhJJZHhDZmdQcmljZUFzc2V0SWQiFElkeENmZ1ByaWNlQXNzZXRNdWx0IhVJZHhDZmdNaW5JbnZlc3RBbW91bnQiDWZyb21hdENvbmZpZ1MiCGlkb1N0YXJ0IgtpZG9EdXJhdGlvbiIKY2xhaW1TdGFydCINY2xhaW1EdXJhdGlvbiIJcHJpY2VNdWx0IgxpZG9Bc3NldElkNTgiDGlkb0Fzc2V0TXVsdCIOcHJpY2VBc3NldElkNTgiDnByaWNlQXNzZXRNdWx0Ig9taW5JbnZlc3RBbW91bnQiE3RvdGFsSWRvQXNzZXRUb1NlbGwiDGZyb21hdENvbmZpZyIRSWR4SW52VG90YWxBbW91bnQiFUlkeEludlJlbWFpbmluZ0Ftb3VudCIdSWR4SW52Q2xhaW1lZFByaWNlQXNzZXRBbW91bnQiG0lkeEludkNsYWltZWRJZG9Bc3NldEFtb3VudCIXSWR4SW52TGFzdENsYWltZWRIZWlnaHQiD2Zvcm1hdEludmVzdG9yUyILdG90YWxBbW91bnQiD3JlbWFpbmluZ0Ftb3VudCIXY2xhaW1lZFByaWNlQXNzZXRBbW91bnQiFWNsYWltZWRJZG9Bc3NldEFtb3VudCIRbGFzdENsYWltZWRIZWlnaHQiDmZvcm1hdEludmVzdG9yIhNmb3JtYXRIaXN0b3J5UmVjb3JkIg5pZG9Bc3NldEFtb3VudCIJa2V5Q29uZmlnIgtrZXlJbnZlc3RvciILdXNlckFkZHJlc3MiCWtleVRvdGFscyIZa2V5T3BlcmF0aW9uSGlzdG9yeVJlY29yZCIEdHlwZSIGdHhJZDU4IhRrZXlVU0ROQ2xhaW1EaXNhYmxlZCIVa2V5VVNETkNsYWltRW5kSGVpZ2h0Ig9rZXlQZXJpb2RMZW5ndGgiEGtleUN1cnJlbnRQZXJpb2QiFGtleVBlcmlvZFN0YXJ0SGVpZ2h0IglwZXJpb2ROdW0iEmtleVBlcmlvZEVuZEhlaWdodCIfa2V5VXNkdFByaWNlQXNzZXRBbGxvd2FibGVSYXRpbyIXa2V5VG90YWxQZXJpb2RBbGxvd2FuY2UiB2Fzc2V0SWQiFmtleVVzZXJQZXJpb2RBbGxvd2FuY2UiHmtleVBlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbSIda2V5UGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0iG2tleVVzZHRQcmljZUFzc2V0U3RhYmxlUG9vbCIOa2V5VXNkdEFzc2V0SWQiFGtleVByaWNlQXNzZXRCYWxhbmNlIgdhZGRyZXNzIhprZXlJbnZlc3RvclJlbWFpbmluZ0Ftb3VudCIXa2V5VG90YWxSZW1haW5pbmdBbW91bnQiE2tleU1hbmFnZXJQdWJsaWNLZXkiFmtleU1hbmFnZXJWYXVsdEFkZHJlc3MiD3JlYWRDb25maWdBcnJheSIjcmVhZFRvdGFsc0FycmF5T3JEZWZhdWx0QnlDdXN0b21LZXkiCWN1c3RvbUtleSIYcmVhZFRvdGFsc0FycmF5T3JEZWZhdWx0IhpyZWFkSW52ZXN0b3JBcnJheU9yRGVmYXVsdCIXcmVhZEludmVzdG9yQXJyYXlPckZhaWwiHGdldE1hbmFnZXJWYXVsdEFkZHJlc3NPclRoaXMiAXMiFUlkeERpZmZUb3RhbEluY3JlbWVudCIkSWR4RGlmZlJlbWFpbmluZ1ByaWNlQW1vdW50SW5jcmVtZW50IiJJZHhEaWZmQ2xhaW1lZFByaWNlQW1vdW50SW5jcmVtZW50IiVJZHhEaWZmQ2xhaW1lZElkb0Fzc2V0QW1vdW50SW5jcmVtZW50IgtUb3RhbHNFbnRyeSIJb3JpZ0FycmF5Ig1pbmNyZW1lbnREaWZmIhRuZXdMYXN0Q2xhaW1lZEhlaWdodCIRcHJpY2VBc3NldEJhbGFuY2UiDm5ld1RvdGFsQW1vdW50IhJuZXdSZW1haW5pbmdBbW91bnQiCGNmZ0FycmF5IhJwcmljZUFzc2V0RGVjaW1hbHMiI3ByaWNlQXNzZXRCYWxhbmNlUHJpY2VBc3NldERlY2ltYWxzIhpuZXdDbGFpbWVkUHJpY2VBc3NldEFtb3VudCIYbmV3Q2xhaW1lZElkb0Fzc2V0QW1vdW50IgdlbnRyaWVzIgRkaWZmIhduZXdMb2dpY1JlbWFpbmluZ0Ftb3VudCIbSW52ZXN0T3BlcmF0aW9uSGlzdG9yeUVudHJ5IgR0eElkIhpDbGFpbU9wZXJhdGlvbkhpc3RvcnlFbnRyeSINaW50ZXJuYWxDbGFpbSIQY2xhaW1lZEFzc2V0SWQ1OCIIY2xhaW1FbmQiCmlkb0Fzc2V0SWQiDHByaWNlQXNzZXRJZCINdXNlckFkZHJlc3M1OCIPb3JpZ0ludmVzdEFycmF5IhFpbnZlc3RUb3RhbEFtb3VudCIaaW52ZXN0TGFzdENsYWltZWRIZWlnaHRUTVAiF2ludmVzdExhc3RDbGFpbWVkSGVpZ2h0IhRuZXdDbGFpbVBlcmlvZEhlaWdodCIOY2xhaW1pbmdCbG9ja3MiGGNsYWltaW5nUHJpY2VBc3NldEFtb3VudCIWY2xhaW1pbmdJZG9Bc3NldEFtb3VudCIGaXNVU0ROIhNpc1VTRE5DbGFpbURpc2FibGVkIgZjaGVja3MiD2ludGVybmFsQ2xhaW1WMiIJb3V0QW1vdW50Ihl0b3RhbFVzZXJBdmFpbGFibGVUb0NsYWltIh50b3RhbFBlcmlvZFByaWNlQXNzZXRBbGxvd2FuY2UiHXVzZXJQZXJpb2RQcmljZUFzc2V0QWxsb3dhbmNlIgxwZXJpb2RMZW5ndGgiDWN1cnJlbnRQZXJpb2QiG3plcm9QZXJpb2RFbmRIZWlnaElzRGVmaW5lZCINJHQwMTMxMzYxNTAwNiIVbGFzdFBlcmlvZFN0YXJ0SGVpZ2h0IhNsYXN0UGVyaW9kRW5kSGVpZ2h0Ig0kdDAxMzM5NjE0MTAxIhR1cGRhdGVkQ3VycmVudFBlcmlvZCILcGVyaW9kU3RhcnQiF2Jsb2Nrc1RvTGFzdFBlcmlvZFN0YXJ0IglwZXJpb2RFbmQiFXplcm9QZXJpb2RTdGFydEhlaWdodCITemVyb1BlcmlvZEVuZEhlaWdodCINJHQwMTQzNTYxNDczOCIbcGVyaW9kVG90YWxBdmFpbGFibGVUb0NsYWltIhpwZXJpb2RVc2VyQXZhaWxhYmxlVG9DbGFpbSIZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbSIcdXNkdFByaWNlQXNzZXRBbGxvd2FibGVSYXRpbyIbcHV0T25lVGtuVjJQcmljZUFzc2V0QW1vdW50Ig0kdDAxNTc2MTE2MDE0IgFAIgVib251cyIJZmVlQW1vdW50IghscEFtb3VudCILdXNkdEFzc2V0SWQiDSR0MDE2MDc2MTYyOTQiFGdldE9uZVRrblYyRmVlQW1vdW50Igp1c2R0QW1vdW50IhpjdXJyZW50VXNkdFByaWNlQXNzZXRSYXRpbyITZW5kUGVyaW9kQmxvY2tzTGVmdCIWbWFuYWdlclB1YmxpY0tleU9yVW5pdCITbWFuYWdlclZhdWx0QWRkcmVzcyILbXVzdE1hbmFnZXIiAWkiAnBkIgJwayIGaWRvRW5kIgNwbXQiDGlkb0Fzc2V0SW5mbyIOcHJpY2VBc3NldEluZm8iD29yaWdUb3RhbHNBcnJheSIKdG90YWxzRGlmZiIObWluSXZlc3RBbW91bnQiCnBtdEFzc2V0SWQiCXBtdEFtb3VudCIRb3JpZ0ludmVzdG9yQXJyYXkiE25ld1ByaWNlVG90YWxBbW91bnQiFnJlcXVpcmVkSWRvQXNzZXRBbW91bnQiD2NhbGxlckFkZHJlc3M1OCIQY2xhaW1SZXN1bHRUdXBsZSIKb3V0QXNzZXRJZCIaY2xhaW1lZFByaWNlQW1vdW50RnJvbURpZmYiHWNsYWltZWRJZG9Bc3NldEFtb3VudEZyb21EaWZmIg0kdDAyMjEzODIyNTgyIiJ1cGRhdGVkUGVyaW9kVG90YWxBdmFpbGFibGVUb0NsYWltIiF1cGRhdGVkUGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0iDmV2YWx1YXRlUmVzdWx0IhthdmFpbGFibGVQcmljZUFtb3VudFRvQ2xhaW0iEGxhc3RDbGFpbUVudHJpZXMiE2ludmVzdG9yVG90YWxBbW91bnQiF2ludmVzdG9yUmVtYWluaW5nQW1vdW50IhlpbnZlc3RvclByaWNlQXNzZXRCYWxhbmNlIhdpbnZlc3Rvcklkb0Fzc2V0QmFsYW5jZSIZaW52ZXN0b3JMYXN0Q2xhaW1lZEhlaWdodCIObmV3SW52ZXN0QXJyYXkiBnRvdGFscyIRdG90YWxzVG90YWxBbW91bnQiFXRvdGFsc1JlbWFpbmluZ0Ftb3VudCIddG90YWxzQ2xhaW1lZFByaWNlQXNzZXRBbW91bnQiG3RvdGFsc0NsYWltZWRJZG9Bc3NldEFtb3VudCIXdG90YWxzTGFzdENsYWltZWRIZWlnaHQiGG5ld1RvdGFsc1JlbWFpbmluZ0Ftb3VudCINbmV3VG90YWxBcnJheSIXbmV3VG90YWxSZW1haW5pbmdBbW91bnQiGHVwZGF0ZWRQcmljZUFzc2V0QmFsYW5jZSIccHJpY2VBc3NldEJhbGFuY2VJZG9EZWNpbWFscyIUY2hlY2tVbmNsYWltZWRBc3NldHMiCGludmVzdG9yIhxpbnZlc3RvclJlbWFpbmluZ0Ftb3VudENoZWNrIgtuZXdJbnZlc3RvciIJbmV3VG90YWxzIhVhdmFpbGFibGVUb0NsYWltQXJyYXkiGWF2YWlsYWJsZUlkb0Ftb3VudFRvQ2xhaW0iLmF2YWlsYWJsZUlkb0Ftb3VudFRvQ2xhaW1XaXRoUHJpY2VBc3NldEJhbGFuY2UiDSR0MDMzODMzMzQyNDUiFmN1cnJlbnRQZXJpb2RFbmRIZWlnaHQiGnVzZXJUb3RhbFByaWNlQXNzZXRDbGFpbWVkIgxyZXN1bHRTdHJpbmciDHBlcmlvZExlbmdodCITdXNlclBlcmlvZEFsbG93YW5jZSIUdG90YWxQZXJpb2RBbGxvd2FuY2UiAnR4IgZ2ZXJpZnkiD3RhcmdldFB1YmxpY0tleUMBAWEBAWIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBBQFiCQCsAgIJAKwCAgIPbWFuZGF0b3J5IHRoaXMuBQFiAg8gaXMgbm90IGRlZmluZWQAAWMCAl9fAAFkCQC2AgEAgICQu7rWrfANAAFlAIDC1y8BAWYBAWcJAAIBCQC5CQIJAMwIAgIJaWRvLnJpZGU6CQDMCAIFAWcFA25pbAIBIAEBaAEBaQQBagUBaQMJAAECBQFqAgZTdHJpbmcEAWsFAWoFAWsJAAIBAhhmYWlsIHRvIGNhc3QgaW50byBTdHJpbmcBAWwFAW0BbgFvAXABcQQBcgkAtgIBBQFuBAFzCQC2AgEFAXEEAXQJALwCAwkAtgIBBQFtBQFkBQFyBAF1CQC8AgMFAXQJALYCAQUBcAkAtgIBBQFvCQCgAwEJALwCAwUBdQkAtgIBBQFxBQFkAAF2AAEAAXcAAgABeAADAAF5AAQAAXoABQABQQAGAAFCAAcAAUMACAABRAAJAAFFAAoAAUYACwEBRwwBSAFJAUoBSwFvAUwBTQFOAU8BUAFRAVIJALkJAgkAzAgCAhglZCVkJWQlZCVkJWQlcyVkJXMlZCVkJWQJAMwIAgUBSAkAzAgCBQFJCQDMCAIFAUoJAMwIAgUBSwkAzAgCBQFvCQDMCAIFAUwJAMwIAgUBTQkAzAgCBQFOCQDMCAIFAU8JAMwIAgUBUAkAzAgCBQFRCQDMCAIFAVIFA25pbAUBYwEBUwwBSAFJAUoBSwFvAUwBTQFOAU8BUAFRAVIJAQFHDAkApAMBBQFICQCkAwEFAUkJAKQDAQUBSgkApAMBBQFLCQCkAwEFAW8JAKQDAQUBTAUBTQkApAMBBQFOBQFPCQCkAwEFAVAJAKQDAQUBUQkApAMBBQFSAAFUAAEAAVUAAgABVgADAAFXAAQAAVgABQEBWQUBWgJhYQJhYgJhYwJhZAkAuQkCCQDMCAICCiVkJWQlZCVkJWQJAMwIAgUBWgkAzAgCBQJhYQkAzAgCBQJhYgkAzAgCBQJhYwkAzAgCBQJhZAUDbmlsBQFjAQJhZQUBWgJhYQJhYgJhYwJhZAkBAVkFCQCkAwEFAVoJAKQDAQUCYWEJAKQDAQUCYWIJAKQDAQUCYWMJAKQDAQUCYWQBAmFmAgFtAmFnCQC5CQIJAMwIAgIIJWQlZCVkJWQJAMwIAgkApAMBBQZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQCkAwEFAW0JAMwIAgkApAMBBQJhZwUDbmlsBQFjAQJhaAACCiVzX19jb25maWcBAmFpAQJhagkArAICAgQlc19fBQJhagECYWsAAgolc19fdG90YWxzAQJhbAMCYW0CYWoCYW4JALkJAgkAzAgCAhElcyVzJXMlc19faGlzdG9yeQkAzAgCBQJhbQkAzAgCBQJhagkAzAgCBQJhbgUDbmlsBQFjAQJhbwACFSVzX191c2RuQ2xhaW1EaXNhYmxlZAECYXAAAhYlc19fdXNkbkNsYWltRW5kSGVpZ2h0AQJhcQAJALkJAgkAzAgCAgIlcwkAzAgCAgxwZXJpb2RMZW5ndGgFA25pbAUBYwECYXIACQC5CQIJAMwIAgICJXMJAMwIAgINY3VycmVudFBlcmlvZAUDbmlsBQFjAQJhcwECYXQJALkJAgkAzAgCAgQlcyVzCQDMCAICEXBlcmlvZFN0YXJ0SGVpZ2h0CQDMCAIJAKQDAQUCYXQFA25pbAUBYwECYXUBAmF0CQC5CQIJAMwIAgIEJXMlcwkAzAgCAg9wZXJpb2RFbmRIZWlnaHQJAMwIAgkApAMBBQJhdAUDbmlsBQFjAQJhdgAJALkJAgkAzAgCAgIlcwkAzAgCAhx1c2R0UHJpY2VBc3NldEFsbG93YWJsZVJhdGlvBQNuaWwFAWMBAmF3AQJheAkAuQkCCQDMCAICBCVzJXMJAMwIAgIUdG90YWxQZXJpb2RBbGxvd2FuY2UJAMwIAgUCYXgFA25pbAUBYwECYXkBAmF4CQC5CQIJAMwIAgIEJXMlcwkAzAgCAhN1c2VyUGVyaW9kQWxsb3dhbmNlCQDMCAIFAmF4BQNuaWwFAWMBAmF6AgJheAJhdAkAuQkCCQDMCAICBiVzJXMlcwkAzAgCAhtwZXJpb2RUb3RhbEF2YWlsYWJsZVRvQ2xhaW0JAMwIAgUCYXgJAMwIAgkApAMBBQJhdAUDbmlsBQFjAQJhQQMCYXgCYXQCYWoJALkJAgkAzAgCAgglcyVzJXMlcwkAzAgCAhpwZXJpb2RVc2VyQXZhaWxhYmxlVG9DbGFpbQkAzAgCBQJheAkAzAgCCQCkAwEFAmF0CQDMCAIFAmFqBQNuaWwFAWMBAmFCAAkAuQkCCQDMCAICAiVzCQDMCAICGHVzZHRQcmljZUFzc2V0U3RhYmxlUG9vbAUDbmlsBQFjAQJhQwAJALkJAgkAzAgCAgIlcwkAzAgCAgt1c2R0QXNzZXRJZAUDbmlsBQFjAQJhRAECYUUJALkJAgkAzAgCAgQlcyVzCQDMCAICEXByaWNlQXNzZXRCYWxhbmNlCQDMCAIFAmFFBQNuaWwFAWMBAmFGAQJhRQkAuQkCCQDMCAICBCVzJXMJAMwIAgIXaW52ZXN0b3JSZW1haW5pbmdBbW91bnQJAMwIAgUCYUUFA25pbAUBYwECYUcACQC5CQIJAMwIAgICJXMJAMwIAgIUdG90YWxSZW1haW5pbmdBbW91bnQFA25pbAUBYwECYUgAAhQlc19fbWFuYWdlclB1YmxpY0tleQECYUkAAhclc19fbWFuYWdlclZhdWx0QWRkcmVzcwECYUoACQC1CQIJAQFhAQkBAmFoAAUBYwECYUsBAmFMCQC1CQIJAQt2YWx1ZU9yRWxzZQIJAKIIAQUCYUwJAQFZBQIBMAIBMAIBMAIBMAIBMAUBYwECYU0ACQECYUsBCQECYWsAAQJhTgECYWoJAQJhSwEJAQJhaQEFAmFqAQJhTwECYWoJALUJAgkBAWEBCQECYWkBBQJhagUBYwECYVAABAFqCQCiCAEJAQJhSQADCQABAgUBagIGU3RyaW5nBAJhUQUBagkBEUBleHRyTmF0aXZlKDEwNjIpAQUCYVEFBHRoaXMAAmFSAAAAAmFTAAEAAmFUAAIAAmFVAAMBAmFWBQFiAmFXAmFYAmFZAmFaBAFaCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYVcFAVQEAmFhCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYVcFAVUEAmFiCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYVcFAVYEAmFjCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYVcFAVcEAmFkCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYVcFAVgEAmJhCQBkAgUBWgkAkQMCBQJhWAUCYVIEAmJiCQBkAgUCYWEJAJEDAgUCYVgFAmFTBAJiYwkBAmFKAAQBTwkAkQMCBQJiYwUBRAQCYmQICQEFdmFsdWUBCQDsBwEJANkEAQUBTwhkZWNpbWFscwQCYmUJAGsDBQJhWgUBZQkAbAYACgAABQJiZAAAAAAFBERPV04EAmJmCQBlAgkAZAIFAmFiCQCRAwIFAmFYBQJhVAUCYVoEAmJnCQBkAgkAZAIFAmFjCQCRAwIFAmFYBQJhVQUCYmUEAmJoAwkAZgIAAAUCYmIEAmJpCQBlAgkAZQIFAmJhBQJiZgUCYmcEAmJqAwkAZgIAAAUCYmkAAAUCYmkJAQtTdHJpbmdFbnRyeQIFAWIJAQJhZQUFAmJhBQJiagUCYmYFAmJnBQJhWQkBC1N0cmluZ0VudHJ5AgUBYgkBAmFlBQUCYmEFAmJiBQJiZgUCYmcFAmFZBQJiaAECYmsEAmFqAW0CYWcCYmwJAQtTdHJpbmdFbnRyeQIJAQJhbAMCBmludmVzdAUCYWoJANgEAQUCYmwJAQJhZgIFAW0FAmFnAQJibQQCYWoBbQJhZwJibAkBC1N0cmluZ0VudHJ5AgkBAmFsAwIFY2xhaW0FAmFqCQDYBAEFAmJsCQECYWYCBQFtBQJhZwECYm4DAmJvAmFqAmJsBAJiYwkBAmFKAAQBSgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJjBQF4BAFLCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYmMFAXkEAmJwCQBkAgUBSgUBSwQBbwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJjBQF6BAFMCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYmMFAUEEAU0JAJEDAgUCYmMFAUIEAmJxCQDZBAEFAU0EAU4JAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJiYwUBQwQBTwkAkQMCBQJiYwUBRAQCYnIJANkEAQUBTwQBUAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJjBQFFBAJicwkApQgBBQJhagQCYnQJAQJhTwEFAmJzBAJidQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJ0BQFUBAJidgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJ0BQFYBAJidwMJAGcCBQFKBQJidgUBSgUCYnYEAmJ4AwkAZgIFBmhlaWdodAUCYnAFAmJwAwkAZgIFAUoFBmhlaWdodAUBSgUGaGVpZ2h0BAJieQkAZQIFAmJ4BQJidwQCYnoJAGsDBQJidQUCYnkFAUsEAmJBCQEBbAUFAmJ6BQFQBQFvBQFMBQFOBAJiQgkAAAIFAmJvBQFPBAJiQwkBC3ZhbHVlT3JFbHNlAgkAoAgBCQECYW8ABwQCYkQJAMwIAgMJAQEhAQMFAmJCBQJiQwcGCQACAQIWVVNETiBjbGFpbSBpcyBkaXNhYmxlZAUDbmlsAwkAAAIFAmJEBQJiRAMJAAACBQJibwUBTwkAmAoGCQDMCAIAAAkAzAgCCQEBLQEFAmJ6CQDMCAIFAmJ6CQDMCAIAAAUDbmlsBQJiegUCYnIFAmJ0BQJieAkAzAgCBQJiegkAzAgCBQJiQQUDbmlsAwkAAAIFAmJvBQFNCQCYCgYJAMwIAgAACQDMCAIJAQEtAQUCYnoJAMwIAgAACQDMCAIFAmJBBQNuaWwFAmJBBQJicQUCYnQFAmJ4CQDMCAIFAmJ6CQDMCAIFAmJBBQNuaWwJAAIBCQCsAgICFXVuc3VwcG9ydGVkIGFzc2V0SWQ6IAUCYm8JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAmJFBAFPAmJzAmJGAmJHBAJiSAkBBXZhbHVlAQkAnwgBCQECYXcBBQFPBAJiSQkBBXZhbHVlAQkAnwgBCQECYXkBBQFPBAJiSgkBBXZhbHVlAQkAnwgBCQECYXEABAJiSwkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYXIAAAAEAmJMCQEJaXNEZWZpbmVkAQkAnwgBCQECYXUBAAAEAmJNAwkAZgIFAmJLAAAEAmJOCQEFdmFsdWUBCQCfCAEJAQJhcwEFAmJLBAJiTwkBBXZhbHVlAQkAnwgBCQECYXUBBQJiSwQCYlADCQBmAgUGaGVpZ2h0BQJiTwQCYlEJAGQCBQJiSwABBAJiUgMJAGYCBQZoZWlnaHQJAGQCBQJiTwUCYkoEAmJTCQBqAgkAZQIFBmhlaWdodAUCYk8FAmJKAwkAAAIFAmJTAAAJAGQCCQBlAgUGaGVpZ2h0BQJiSgABCQBlAgUGaGVpZ2h0BQJiUwkAZAIFAmJPAAEEAmJUCQBlAgkAZAIFAmJSBQJiSgABCQCVCgMFAmJRBQJiUgUCYlQJAJUKAwUCYksFAmJOBQJiTwQCYlEIBQJiUAJfMQQCYlIIBQJiUAJfMgQCYlQIBQJiUAJfMwkAlQoDBQJiUQUCYlIFAmJUAwUCYkwEAmJVCQEFdmFsdWUBCQCfCAEJAQJhcwEAAAQCYlYJAQV2YWx1ZQEJAJ8IAQkBAmF1AQAABAJiVwMJAGYCBQZoZWlnaHQFAmJWBAJiUQkAZAIFAmJLAAEEAmJSCQBkAgUCYlYAAQQCYlQJAGUCCQBkAgUCYlIFAmJKAAEJAJUKAwUCYlEFAmJSBQJiVAkAlQoDBQJiSwUCYlUFAmJWBAJiUQgFAmJXAl8xBAJiUggFAmJXAl8yBAJiVAgFAmJXAl8zCQCVCgMFAmJRBQJiUgUCYlQJAJUKAwUCYksJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAmFzAQUCYksFBmhlaWdodAkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYXUBBQJiSwkAZQIJAGQCBQZoZWlnaHQFAmJKAAEEAmJRCAUCYk0CXzEEAmJSCAUCYk0CXzIEAmJUCAUCYk0CXzMEAmJYCQELdmFsdWVPckVsc2UCCQCfCAEJAQJhegIFAU8FAmJRBQJiSAQCYlkJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAmFBAwUBTwUCYlEFAmJzBQJiSQQCYVoJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAmFEAQUCYnMAAAQCYloJAJcDAQkAzAgCCQBkAgUCYkYFAmFaCQDMCAIFAmJYCQDMCAIFAmJZBQNuaWwEAmNhCQEFdmFsdWUBCQCfCAEJAQJhdgAEAmNiBQFlBAJjYwoAAmNkCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEJAKIIAQkBAmFCAAIhcHV0T25lVGtuVjJXaXRob3V0VGFrZUZlZVJFQURPTkxZCQDMCAIFAmNiCQDMCAIFAU8FA25pbAUDbmlsAwkAAQIFAmNkAg8oSW50LCBJbnQsIEludCkFAmNkCQACAQkArAICCQADAQUCY2QCJCBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCwgSW50KQMJAAACBQJjYwUCY2MEAmNlCAUCY2MCXzMEAmNmCAUCY2MCXzIEAmNnCAUCY2MCXzEEAmNoCQEFdmFsdWUBCQCiCAEJAQJhQwAEAmNpCgACY2QJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBBXZhbHVlAQkAoggBCQECYUIAAhNnZXRPbmVUa25WMlJFQURPTkxZCQDMCAIFAmNoCQDMCAIFAmNnBQNuaWwFA25pbAMJAAECBQJjZAIKKEludCwgSW50KQUCY2QJAAIBCQCsAgIJAAMBBQJjZAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQMJAAACBQJjaQUCY2kEAmNqCAUCY2kCXzIEAmNrCAUCY2kCXzEEAmNsCQBrAwUCY2IFAWUFAmNrBAJjbQkAZQIFAmJUBQZoZWlnaHQJAJwKCgUCYloFAmJYBQJiWQUCYkcFAmNhBQJjbAUCY20FAmJRBQJiUgUCYlQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAmNuAAQCY28JAQJhUAAEAWoJAJ0IAgUCY28JAQJhSAADCQABAgUBagIGU3RyaW5nBAJhUQUBagkA2QQBBQJhUQMJAAECBQFqAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IBAmNwAQJjcQQCY3IJAAIBAhFQZXJtaXNzaW9uIGRlbmllZAQBagkBAmNuAAMJAAECBQFqAgpCeXRlVmVjdG9yBAJjcwUBagMJAAACCAUCY3EPY2FsbGVyUHVibGljS2V5BQJjcwYFAmNyAwkAAQIFAWoCBFVuaXQDCQAAAggFAmNxBmNhbGxlcgUEdGhpcwYFAmNyCQACAQILTWF0Y2ggZXJyb3IGAmNxAQtjb25zdHJ1Y3RvcgcBSAFJAUoBSwFvAU8BUQQBTAkAaAIJAGgCAGQA6AcA6AcEAmN0CQBkAgUBSAUBSQMJAQlpc0RlZmluZWQBCQCiCAEJAQJhaAAJAAIBAhNhbHJlYWR5IGluaXRpYWxpemVkAwkBAiE9AgIjM1BNRUhMeDFqNnplcmFyWlRZZnNHcURlZVpxUW9NcHhxNVMJAKUIAQgFAmNxBmNhbGxlcgkAAgECDm5vdCBhdXRob3JpemVkAwkBAiE9AgkAkAMBCAUCY3EIcGF5bWVudHMAAQkAAgECImV4YWN0bHkgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQDCQBnAgUCY3QFAUoJAAIBAiZjbGFpbVN0YXJ0IG11c3QgYmUgZ3JlYXRlciB0aGFuIGlkb0VuZAQCY3UJAQV2YWx1ZQEJAJEDAggFAmNxCHBheW1lbnRzAAAEAmJxCQEFdmFsdWUBCAUCY3UHYXNzZXRJZAQCY3YJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJicQIbZmFpbCB0byBsb2FkIGlkbyBhc3NldCBpbmZvBAFNCQDYBAEFAmJxBAFOCQBsBgAKAAAIBQJjdghkZWNpbWFscwAAAAAFBERPV04EAmJyCQDZBAEFAU8EAmN3CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAOwHAQUCYnICHWZhaWwgdG8gbG9hZCBwcmljZSBhc3NldCBpbmZvBAFQCQBsBgAKAAAIBQJjdwhkZWNpbWFscwAAAAAFBERPV04EAmN4CQECYU0ABAJjeQkAzAgCAAAJAMwIAgAACQDMCAIAAAkAzAgCAAAFA25pbAkAzAgCCQELU3RyaW5nRW50cnkCCQECYWgACQEBUwwFAUgFAUkFAUoFAUsFAW8FAUwFAU0FAU4FAU8FAVAFAVEIBQJjdQZhbW91bnQJAMwIAgkBAmFWBQkBAmFrAAUCY3gFAmN5BQFKAAAFA25pbAJjcQEGaW52ZXN0AAQCYmMJAQJhSgAEAUgJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJiYwUBdgQBSQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJjBQF3BAJjdAkAZAIFAUgFAUkEAUoJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJiYwUBeAQBSwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJjBQF5BAFvCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYmMFAXoEAUwJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJiYwUBQQQBTQkAkQMCBQJiYwUBQgQCYnEJANkEAQUBTQQBTgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJjBQFDBAFPCQCRAwIFAmJjBQFEBAJicgkA2QQBBQFPBAFQCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYmMFAUUEAmN6CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYmMFAUYEAmFqCQClCAEIBQJjcQZjYWxsZXIDCQBmAgUBSAUGaGVpZ2h0CQACAQIcaWRvIGhhcyBub3QgYmVlbiBzdGFydGVkIHlldAMJAGYCBQZoZWlnaHQFAmN0CQACAQIaaWRvIGhhcyBiZWVuIGFscmVhZHkgZW5kZWQDCQECIT0CCQCQAwEIBQJjcQhwYXltZW50cwABCQACAQIdZXhhY3RseSAxIHBheW1lbnQgaXMgZXhwZWN0ZWQEAmN1CQEFdmFsdWUBCQCRAwIIBQJjcQhwYXltZW50cwAABAJjQQkBBXZhbHVlAQgFAmN1B2Fzc2V0SWQEAmNCCAUCY3UGYW1vdW50AwkBAiE9AgUCY0EFAmJyCQACAQkArAICCQCsAgICGmludmFsaWQgcGF5bWVudCBhc3NldCBpZDogCQDYBAEFAmNBAgwgaXMgZXhwZWN0ZWQEAmNDCQECYU4BBQJhagQCY3gJAQJhTQAEAmNECQBkAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmN4BQFUBQJjQgQCY0UJAGgCBQJjRABkAwkAZgIFAmNFCQDwBwIFBHRoaXMFAmJxCQACAQI5SURPIGFzc2V0IGhhcyBiZWVuIC0gc29sZCBjb25zaWRlciB0byB1c2Ugc21hbGxlciBwYXltZW50BAJjeQkAzAgCBQJjQgkAzAgCBQJjQgkAzAgCAAAJAMwIAgAABQNuaWwJAMwIAgkBAmFWBQkBAmFpAQUCYWoFAmNDBQJjeQUBSgAACQDMCAIJAQJhVgUJAQJhawAFAmN4BQJjeQUBSgAACQDMCAIJAQJiawQFAmFqBQJjQgAACAUCY3ENdHJhbnNhY3Rpb25JZAUDbmlsAmNxAQVjbGFpbQICYm8CYnMEAmNGCQClCAEIBQJjcQZjYWxsZXIDCQECIT0CBQJicwUCY0YJAAIBAg5ub3QgYXV0aG9yaXplZAQCYmMJAQJhSgAEAU8JAJEDAgUCYmMFAUQEAmNHCQECYm4DBQJibwgFAmNxBmNhbGxlcggFAmNxDXRyYW5zYWN0aW9uSWQEAmN5CAUCY0cCXzEEAmJGCAUCY0cCXzIEAmNICAUCY0cCXzMEAmJ0CAUCY0cCXzQEAmJ4CAUCY0cCXzUEAmNJCQCRAwIFAmN5BQJhVAQCY0oJAJEDAgUCY3kFAmFVBAJhWgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYUQBBQJicwAABAJiZAgJAQV2YWx1ZQEJAOwHAQkA2QQBBQFPCGRlY2ltYWxzBAJiaAMJAAACBQJibwUBTwQCY0sJAQJiRQQFAU8FAmJzBQJiRgkAkQMCBQJjeQUCYVQEAmJaCAUCY0sCXzEEAmJYCAUCY0sCXzIEAmJZCAUCY0sCXzMEAmJHCAUCY0sCXzQEAmNhCAUCY0sCXzUEAmNsCAUCY0sCXzYEAmNtCAUCY0sCXzcEAmJRCAUCY0sCXzgEAmJSCAUCY0sCXzkEAmJUCAUCY0sDXzEwBAJiRAkAzAgCAwkAZgIFAmJZAAAGCQEBZgECOnVuYXZhaWxhYmxlIHRvIGNsYWltIGJlY2F1c2UgdXNlciBwZXJpb2QgYWxsb3dhbmNlIHJlYWNoZWQJAMwIAgMJAGYCBQJiWAAABgkBAWYBAjt1bmF2YWlsYWJsZSB0byBjbGFpbSBiZWNhdXNlIHRvdGFsIHBlcmlvZCBhbGxvd2FuY2UgcmVhY2hlZAkAzAgCAwkAZgIFAmJaAAAGCQEBZgECEG5vdGhpbmcgdG8gY2xhaW0JAMwIAgMJAGYCBQJjYQUCY2wGCQEBZgECT3VuYXZhaWxhYmxlIHRvIGNsYWltIGJlY2F1c2UgdXNkbiBwcmljZSBsb3dlciB0aGFuIHVzZHRQcmljZUFzc2V0QWxsb3dhYmxlUmF0aW8FA25pbAMJAAACBQJiRAUCYkQEAmNMCQBlAgUCYlgFAmJaBAJjTQkAZQIFAmJZBQJiWgQCYmgDCQBmAgUCYVoFAmJaCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQJjcQZjYWxsZXIFAmJaBQJjSAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFEAQUCYnMJAGUCBQJhWgUCYloFA25pbAQCY04JALUJAgkBAWgBCQD8BwQFBHRoaXMCDWNsYWltUkVBRE9OTFkJAMwIAgUBTwkAzAgCBQJicwUDbmlsBQNuaWwFAWMDCQAAAgUCY04FAmNOBAJjTwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNOAAMEAmNQAwkAAAIFAmNPBQJiWgQCY1EJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJidAUBVAQCY1IJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJidAUBVQQCY1MJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJidAUBVgQCY1QJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJidAUBVwQCY1UJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJidAUBWAQCY1YJAMwIAgkApAMBBQJjUQkAzAgCAgEwCQDMCAIJAKQDAQUCY1MJAMwIAgkApAMBBQJjVAkAzAgCCQCkAwEFAmNVBQNuaWwEAmNXCQECYU0ABAJjWAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNXBQFUBAJjWQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNXBQFVBAJjWgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNXBQFWBAJkYQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNXBQFXBAJkYgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNXBQFYBAJkYwkAZQIFAmNZBQJjUgQCZGQJAMwIAgkApAMBBQJjWAkAzAgCCQCkAwEFAmRjCQDMCAIJAKQDAQUCY1oJAMwIAgkApAMBBQJkYQkAzAgCCQCkAwEFAmRiBQNuaWwEAmRlCQBkAgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYUcAAAAFAmNSCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhRgEFAmJzCQCkAwEFAmNSCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhRwAJAKQDAQUCZGUJAMwIAgkBAmFWBQkBAmFpAQUCYnMFAmNWBQJjeQUCYngAAAkAzAgCCQECYVYFCQECYWsABQJkZAUCY3kFAmJ4AAAFA25pbAkAzAgCCQECYVYFCQECYWkBBQJicwUCYnQFAmN5BQJieAAACQDMCAIJAQJhVgUJAQJhawAJAQJhTQAFAmN5BQJieAAABQNuaWwEAmRmCQBlAgkAZAIFAmFaBQJiRgUCYloJAM4IAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUCY3EGY2FsbGVyBQJiWgUCY0gJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJhRAEFAmJzBQJkZgUDbmlsBQJjUAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAlAoCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJhcgAFAmJRCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYXMBBQJiUQUCYlIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJhdQEFAmJRBQJiVAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmF6AgUBTwUCYlEFAmNMCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYUEDBQFPBQJiUQUCYnMFAmNNCQDMCAIJAQJibQQFAmJzBQJiWgUCY0oIBQJjcQ10cmFuc2FjdGlvbklkBQNuaWwFAmJoBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBAJkZwkAawMFAmFaBQFlCQBsBgAKAAAFAmJkAAAAAAUERE9XTgkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQJjcQZjYWxsZXIJAGQCBQJiRgUCZGcFAmNICQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYUQBBQJicwAACQDMCAIJAQJhVgUJAQJhaQEFAmJzBQJidAUCY3kFAmJ4BQJhWgkAzAgCCQECYVYFCQECYWsACQECYU0ABQJjeQUCYngFAmFaCQDMCAIJAQJibQQFAmJzBQJjSQkAZAIFAmNKBQJkZwgFAmNxDXRyYW5zYWN0aW9uSWQFA25pbAUEdW5pdAUCYmgCY3EBEmNsZWFuUmVtYWluZ0Ftb3VudAECYnMEAU8JAJEDAgkBAmFKAAUBRAQCY04JALUJAgkBAWgBCQD8BwQFBHRoaXMCDWNsYWltUkVBRE9OTFkJAMwIAgUBTwkAzAgCBQJicwUDbmlsBQNuaWwFAWMDCQAAAgUCY04FAmNOBAJjTwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNOAAIEAmRoAwkAAAIFAmNPAAAGCQEBZgECGnVzZXIgaGF2ZSB1bmNsYWltZWQgYXNzZXRzAwkAAAIFAmRoBQJkaAQCZGkJALUJAgkBBXZhbHVlAQkAoggBCQECYWkBBQJicwUBYwQCY1EJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkaQUBVAQCY1IJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkaQUBVQQCY1MJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkaQUBVgQCY1QJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkaQUBVwQCY1UJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkaQUBWAQCZGoDCQECIT0CBQJjUgAABgkBAWYBAiRpbnZlc3RvclJlbWFpbmluZ0Ftb3VudCBhbHJlYWR5IHplcm8DCQAAAgUCZGoFAmRqBAJkawkAuQkCCQDMCAICCiVkJWQlZCVkJWQJAMwIAgkApAMBBQJjUQkAzAgCAgEwCQDMCAIJAKQDAQUCY1MJAMwIAgkApAMBBQJjVAkAzAgCCQCkAwEFAmNVBQNuaWwFAWMEAmNXCQC1CQIJAQV2YWx1ZQEJAKIIAQkBAmFrAAUBYwQCY1gJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJjVwUBVAQCY1kJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJjVwUBVQQCY1oJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJjVwUBVgQCZGEJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJjVwUBVwQCZGIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJjVwUBWAQCZGwJALkJAgkAzAgCAgolZCVkJWQlZCVkCQDMCAIJAKQDAQUCY1gJAMwIAgkApAMBCQBlAgUCY1kFAmNSCQDMCAIJAKQDAQUCY1oJAMwIAgkApAMBBQJkYQkAzAgCCQCkAwEFAmRiBQNuaWwFAWMEAmRlCQBkAgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYUcAAAAFAmNSCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhRgEFAmJzCQCkAwEFAmNSCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhRwAJAKQDAQUCZGUJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFpAQUCYnMFAmRrCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhawAFAmRsBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CY3EBDWNsYWltUkVBRE9OTFkCAmJvAmJzBAJjRwkBAmJuAwUCYm8JARFAZXh0ck5hdGl2ZSgxMDYyKQEFAmJzCQDZBAECAAQCY3kIBQJjRwJfMQQCYkYIBQJjRwJfMgQCY0gIBQJjRwJfMwQCYnQIBQJjRwJfNAQCYngIBQJjRwJfNQQCZG0IBQJjRwJfNgQCY08JAJEDAgUCZG0AAAQCZG4JAJEDAgUCZG0AAQkAlAoCBQNuaWwJALkJAgkAzAgCAgYlcyVkJWQJAMwIAgUCYnMJAMwIAgkApAMBBQJjTwkAzAgCCQCkAwEFAmRuBQNuaWwFAWMCY3EBD2NsYWltVjJSRUFET05MWQICYm8CYnMEAmNHCQECYm4DBQJibwkBEUBleHRyTmF0aXZlKDEwNjIpAQUCYnMJANkEAQIABAJjeQgFAmNHAl8xBAJiRggFAmNHAl8yBAJjSAgFAmNHAl8zBAJidAgFAmNHAl80BAJieAgFAmNHAl81BAJkbQgFAmNHAl82BAJjTwkAkQMCBQJkbQAABAJkbgkAkQMCBQJkbQABBAJiYwkBAmFKAAQBTwkAkQMCBQJiYwUBRAQCYVoJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAmFEAQUCYnMAAAQCZGcJAGgCBQJhWgBkBAJkbwkAZAIFAmRuBQJkZwQCZHAJAQJiRQQFAU8FAmJzBQJiRgkAkQMCBQJjeQUCYVQEAmJaCAUCZHACXzEEAmJYCAUCZHACXzIEAmJZCAUCZHACXzMEAmJHCAUCZHACXzQEAmNhCAUCZHACXzUEAmNsCAUCZHACXzYEAmNtCAUCZHACXzcEAmJRCAUCZHACXzgEAmJSCAUCZHACXzkEAmJUCAUCZHADXzEwBAJkcQkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYXUBBQJiUQAABAJkcgkAZQIJAQ1wYXJzZUludFZhbHVlAQkAkQMCCQECYU8BBQJicwUBVgUCYVoEAmRzAwkAZgIFBmhlaWdodAUCZHEEAmR0CQEFdmFsdWUBCQCfCAEJAQJhcQAEAmR1CQEFdmFsdWUBCQCfCAEJAQJheQEFAU8EAmR2CQEFdmFsdWUBCQCfCAEJAQJhdwEFAU8JALkJAgkAzAgCAgwlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQJkbwkAzAgCCQCkAwEFAmR1CQDMCAIJAKQDAQUCZHYJAMwIAgkApAMBBQJjYQkAzAgCCQCkAwEFAmNsCQDMCAIJAKQDAQUCZHQJAMwIAgkApAMBBQJkcgUDbmlsBQFjCQC5CQIJAMwIAgIMJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQUCZG8JAMwIAgkApAMBBQJiWgkAzAgCCQCkAwEFAmJYCQDMCAIJAKQDAQUCY2EJAMwIAgkApAMBBQJjbAkAzAgCCQCkAwEFAmNtCQDMCAIJAKQDAQUCZHIFA25pbAUBYwkAlAoCBQNuaWwFAmRzAQJkdwECZHgABAJkeQQBagkBAmNuAAMJAAECBQFqAgpCeXRlVmVjdG9yBAJjcwUBagUCY3MDCQABAgUBagIEVW5pdAgFAmR3D3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJkdwlib2R5Qnl0ZXMJAJEDAggFAmR3BnByb29mcwAABQJkebRS9H8=", "height": 2571648, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 317zwLpeAhktTyej8CLJHf2vxw9PfSnmW7Wg3QAeACkk Next: 3u4aJct23eHfBtSMFRzP1USEqeyUsiRnDwFa6oQUs9Cv Diff:
OldNewDifferences
158158 func readInvestorArrayOrFail (userAddress) = split(getStringOrFail(keyInvestor(userAddress)), SEP)
159159
160160
161-func getManagerAddressOrFail () = addressFromStringValue(getStringValue(keyManagerVaultAddress()))
161+func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) {
162+ case s: String =>
163+ addressFromStringValue(s)
164+ case _ =>
165+ this
166+}
162167
163168
164169 let IdxDiffTotalIncrement = 0
253258 let periodLength = value(getInteger(keyPeriodLength()))
254259 let currentPeriod = valueOrElse(getInteger(keyCurrentPeriod()), 0)
255260 let zeroPeriodEndHeighIsDefined = isDefined(getInteger(keyPeriodEndHeight(0)))
256- let $t01307714947 = if ((currentPeriod > 0))
261+ let $t01313615006 = if ((currentPeriod > 0))
257262 then {
258263 let lastPeriodStartHeight = value(getInteger(keyPeriodStartHeight(currentPeriod)))
259264 let lastPeriodEndHeight = value(getInteger(keyPeriodEndHeight(currentPeriod)))
260- let $t01333714042 = if ((height > lastPeriodEndHeight))
265+ let $t01339614101 = if ((height > lastPeriodEndHeight))
261266 then {
262267 let updatedCurrentPeriod = (currentPeriod + 1)
263268 let periodStart = if ((height > (lastPeriodEndHeight + periodLength)))
272277 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
273278 }
274279 else $Tuple3(currentPeriod, lastPeriodStartHeight, lastPeriodEndHeight)
275- let updatedCurrentPeriod = $t01333714042._1
276- let periodStart = $t01333714042._2
277- let periodEnd = $t01333714042._3
280+ let updatedCurrentPeriod = $t01339614101._1
281+ let periodStart = $t01339614101._2
282+ let periodEnd = $t01339614101._3
278283 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
279284 }
280285 else if (zeroPeriodEndHeighIsDefined)
281286 then {
282287 let zeroPeriodStartHeight = value(getInteger(keyPeriodStartHeight(0)))
283288 let zeroPeriodEndHeight = value(getInteger(keyPeriodEndHeight(0)))
284- let $t01429714679 = if ((height > zeroPeriodEndHeight))
289+ let $t01435614738 = if ((height > zeroPeriodEndHeight))
285290 then {
286291 let updatedCurrentPeriod = (currentPeriod + 1)
287292 let periodStart = (zeroPeriodEndHeight + 1)
289294 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
290295 }
291296 else $Tuple3(currentPeriod, zeroPeriodStartHeight, zeroPeriodEndHeight)
292- let updatedCurrentPeriod = $t01429714679._1
293- let periodStart = $t01429714679._2
294- let periodEnd = $t01429714679._3
297+ let updatedCurrentPeriod = $t01435614738._1
298+ let periodStart = $t01435614738._2
299+ let periodEnd = $t01435614738._3
295300 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
296301 }
297302 else $Tuple3(currentPeriod, valueOrElse(getInteger(keyPeriodStartHeight(currentPeriod)), height), valueOrElse(getInteger(keyPeriodEndHeight(currentPeriod)), ((height + periodLength) - 1)))
298- let updatedCurrentPeriod = $t01307714947._1
299- let periodStart = $t01307714947._2
300- let periodEnd = $t01307714947._3
303+ let updatedCurrentPeriod = $t01313615006._1
304+ let periodStart = $t01313615006._2
305+ let periodEnd = $t01313615006._3
301306 let periodTotalAvailableToClaim = valueOrElse(getInteger(keyPeriodTotalAvailableToClaim(priceAssetId58, updatedCurrentPeriod)), totalPeriodPriceAssetAllowance)
302307 let periodUserAvailableToClaim = valueOrElse(getInteger(keyPeriodUserAvailableToClaim(priceAssetId58, updatedCurrentPeriod, userAddress58)), userPeriodPriceAssetAllowance)
303308 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
304309 let periodMinAvailableToClaim = min([(outAmount + priceAssetBalance), periodTotalAvailableToClaim, periodUserAvailableToClaim])
305310 let usdtPriceAssetAllowableRatio = value(getInteger(keyUsdtPriceAssetAllowableRatio()))
306311 let putOneTknV2PriceAssetAmount = scale8
307- let $t01570215955 = {
312+ let $t01576116014 = {
308313 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "putOneTknV2WithoutTakeFeeREADONLY", [putOneTknV2PriceAssetAmount, priceAssetId58], nil)
309314 if ($isInstanceOf(@, "(Int, Int, Int)"))
310315 then @
311316 else throw(($getType(@) + " couldn't be cast to (Int, Int, Int)"))
312317 }
313- if (($t01570215955 == $t01570215955))
318+ if (($t01576116014 == $t01576116014))
314319 then {
315- let bonus = $t01570215955._3
316- let feeAmount = $t01570215955._2
317- let lpAmount = $t01570215955._1
320+ let bonus = $t01576116014._3
321+ let feeAmount = $t01576116014._2
322+ let lpAmount = $t01576116014._1
318323 let usdtAssetId = value(getString(keyUsdtAssetId()))
319- let $t01601716235 = {
324+ let $t01607616294 = {
320325 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "getOneTknV2READONLY", [usdtAssetId, lpAmount], nil)
321326 if ($isInstanceOf(@, "(Int, Int)"))
322327 then @
323328 else throw(($getType(@) + " couldn't be cast to (Int, Int)"))
324329 }
325- if (($t01601716235 == $t01601716235))
330+ if (($t01607616294 == $t01607616294))
326331 then {
327- let getOneTknV2FeeAmount = $t01601716235._2
328- let usdtAmount = $t01601716235._1
332+ let getOneTknV2FeeAmount = $t01607616294._2
333+ let usdtAmount = $t01607616294._1
329334 let currentUsdtPriceAssetRatio = fraction(putOneTknV2PriceAssetAmount, scale8, usdtAmount)
330335 let endPeriodBlocksLeft = (periodEnd - height)
331336 $Tuple10(periodMinAvailableToClaim, periodTotalAvailableToClaim, periodUserAvailableToClaim, totalUserAvailableToClaim, usdtPriceAssetAllowableRatio, currentUsdtPriceAssetRatio, endPeriodBlocksLeft, updatedCurrentPeriod, periodStart, periodEnd)
337342
338343
339344 func managerPublicKeyOrUnit () = {
340- let managerVaultAddress = getManagerAddressOrFail()
345+ let managerVaultAddress = getManagerVaultAddressOrThis()
341346 match getString(managerVaultAddress, keyManagerPublicKey()) {
342347 case s: String =>
343348 fromBase58String(s)
462467 let priceAssetDecimals = value(assetInfo(fromBase58String(priceAssetId58))).decimals
463468 let entries = if ((claimedAssetId58 == priceAssetId58))
464469 then {
465- let $t02207422518 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
466- let periodMinAvailableToClaim = $t02207422518._1
467- let periodTotalAvailableToClaim = $t02207422518._2
468- let periodUserAvailableToClaim = $t02207422518._3
469- let totalUserAvailableToClaim = $t02207422518._4
470- let usdtPriceAssetAllowableRatio = $t02207422518._5
471- let currentUsdtPriceAssetRatio = $t02207422518._6
472- let endPeriodBlocksLeft = $t02207422518._7
473- let updatedCurrentPeriod = $t02207422518._8
474- let periodStart = $t02207422518._9
475- let periodEnd = $t02207422518._10
470+ let $t02213822582 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
471+ let periodMinAvailableToClaim = $t02213822582._1
472+ let periodTotalAvailableToClaim = $t02213822582._2
473+ let periodUserAvailableToClaim = $t02213822582._3
474+ let totalUserAvailableToClaim = $t02213822582._4
475+ let usdtPriceAssetAllowableRatio = $t02213822582._5
476+ let currentUsdtPriceAssetRatio = $t02213822582._6
477+ let endPeriodBlocksLeft = $t02213822582._7
478+ let updatedCurrentPeriod = $t02213822582._8
479+ let periodStart = $t02213822582._9
480+ let periodEnd = $t02213822582._10
476481 let checks = [if ((periodUserAvailableToClaim > 0))
477482 then true
478483 else throwErr("unavailable to claim because user period allowance reached"), if ((periodTotalAvailableToClaim > 0))
607612 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
608613 let priceAssetBalanceIdoDecimals = (priceAssetBalance * 100)
609614 let availableIdoAmountToClaimWithPriceAssetBalance = (availableIdoAmountToClaim + priceAssetBalanceIdoDecimals)
610- let $t03376934181 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
611- let periodMinAvailableToClaim = $t03376934181._1
612- let periodTotalAvailableToClaim = $t03376934181._2
613- let periodUserAvailableToClaim = $t03376934181._3
614- let totalUserAvailableToClaim = $t03376934181._4
615- let usdtPriceAssetAllowableRatio = $t03376934181._5
616- let currentUsdtPriceAssetRatio = $t03376934181._6
617- let endPeriodBlocksLeft = $t03376934181._7
618- let updatedCurrentPeriod = $t03376934181._8
619- let periodStart = $t03376934181._9
620- let periodEnd = $t03376934181._10
615+ let $t03383334245 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
616+ let periodMinAvailableToClaim = $t03383334245._1
617+ let periodTotalAvailableToClaim = $t03383334245._2
618+ let periodUserAvailableToClaim = $t03383334245._3
619+ let totalUserAvailableToClaim = $t03383334245._4
620+ let usdtPriceAssetAllowableRatio = $t03383334245._5
621+ let currentUsdtPriceAssetRatio = $t03383334245._6
622+ let endPeriodBlocksLeft = $t03383334245._7
623+ let updatedCurrentPeriod = $t03383334245._8
624+ let periodStart = $t03383334245._9
625+ let periodEnd = $t03383334245._10
621626 let currentPeriodEndHeight = valueOrElse(getInteger(keyPeriodEndHeight(updatedCurrentPeriod)), 0)
622627 let userTotalPriceAssetClaimed = (parseIntValue(readInvestorArrayOrFail(userAddress58)[IdxInvClaimedPriceAssetAmount]) - priceAssetBalance)
623628 let resultString = if ((height > currentPeriodEndHeight))
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func getStringOrFail (key) = valueOrErrorMessage(getString(key), (("mandatory this." + key) + " is not defined"))
55
66
77 let SEP = "__"
88
99 let BUFSCALE = toBigInt(1000000000000000000)
1010
1111 let scale8 = 100000000
1212
1313 func throwErr (msg) = throw(makeString(["ido.ride:", msg], " "))
1414
1515
1616 func asString (val) = match val {
1717 case valStr: String =>
1818 valStr
1919 case _ =>
2020 throw("fail to cast into String")
2121 }
2222
2323
2424 func convertPriceAssetIntoIdoAsset (priceAssetAmount,priceAssetMULT,price,priceMULT,idoAssetMULT) = {
2525 let bPriceAssetMULT = toBigInt(priceAssetMULT)
2626 let bIdoAssetMULT = toBigInt(idoAssetMULT)
2727 let bPriceAssetBUF = fraction(toBigInt(priceAssetAmount), BUFSCALE, bPriceAssetMULT)
2828 let bAmountAssetBUF = fraction(bPriceAssetBUF, toBigInt(priceMULT), toBigInt(price))
2929 toInt(fraction(bAmountAssetBUF, toBigInt(idoAssetMULT), BUFSCALE))
3030 }
3131
3232
3333 let IdxCfgIdoStart = 1
3434
3535 let IdxCfgIdoDuration = 2
3636
3737 let IdxCfgClaimStart = 3
3838
3939 let IdxCfgClaimDuration = 4
4040
4141 let IdxCfgPrice = 5
4242
4343 let IdxCfgPriceMult = 6
4444
4545 let IdxCfgIdoAssetId = 7
4646
4747 let IdxCfgIdoAssetMult = 8
4848
4949 let IdxCfgPriceAssetId = 9
5050
5151 let IdxCfgPriceAssetMult = 10
5252
5353 let IdxCfgMinInvestAmount = 11
5454
5555 func fromatConfigS (idoStart,idoDuration,claimStart,claimDuration,price,priceMult,idoAssetId58,idoAssetMult,priceAssetId58,priceAssetMult,minInvestAmount,totalIdoAssetToSell) = makeString(["%d%d%d%d%d%d%s%d%s%d%d%d", idoStart, idoDuration, claimStart, claimDuration, price, priceMult, idoAssetId58, idoAssetMult, priceAssetId58, priceAssetMult, minInvestAmount, totalIdoAssetToSell], SEP)
5656
5757
5858 func fromatConfig (idoStart,idoDuration,claimStart,claimDuration,price,priceMult,idoAssetId58,idoAssetMult,priceAssetId58,priceAssetMult,minInvestAmount,totalIdoAssetToSell) = fromatConfigS(toString(idoStart), toString(idoDuration), toString(claimStart), toString(claimDuration), toString(price), toString(priceMult), idoAssetId58, toString(idoAssetMult), priceAssetId58, toString(priceAssetMult), toString(minInvestAmount), toString(totalIdoAssetToSell))
5959
6060
6161 let IdxInvTotalAmount = 1
6262
6363 let IdxInvRemainingAmount = 2
6464
6565 let IdxInvClaimedPriceAssetAmount = 3
6666
6767 let IdxInvClaimedIdoAssetAmount = 4
6868
6969 let IdxInvLastClaimedHeight = 5
7070
7171 func formatInvestorS (totalAmount,remainingAmount,claimedPriceAssetAmount,claimedIdoAssetAmount,lastClaimedHeight) = makeString(["%d%d%d%d%d", totalAmount, remainingAmount, claimedPriceAssetAmount, claimedIdoAssetAmount, lastClaimedHeight], SEP)
7272
7373
7474 func formatInvestor (totalAmount,remainingAmount,claimedPriceAssetAmount,claimedIdoAssetAmount,lastClaimedHeight) = formatInvestorS(toString(totalAmount), toString(remainingAmount), toString(claimedPriceAssetAmount), toString(claimedIdoAssetAmount), toString(lastClaimedHeight))
7575
7676
7777 func formatHistoryRecord (priceAssetAmount,idoAssetAmount) = makeString(["%d%d%d%d", toString(height), toString(lastBlock.timestamp), toString(priceAssetAmount), toString(idoAssetAmount)], SEP)
7878
7979
8080 func keyConfig () = "%s__config"
8181
8282
8383 func keyInvestor (userAddress) = ("%s__" + userAddress)
8484
8585
8686 func keyTotals () = "%s__totals"
8787
8888
8989 func keyOperationHistoryRecord (type,userAddress,txId58) = makeString(["%s%s%s%s__history", type, userAddress, txId58], SEP)
9090
9191
9292 func keyUSDNClaimDisabled () = "%s__usdnClaimDisabled"
9393
9494
9595 func keyUSDNClaimEndHeight () = "%s__usdnClaimEndHeight"
9696
9797
9898 func keyPeriodLength () = makeString(["%s", "periodLength"], SEP)
9999
100100
101101 func keyCurrentPeriod () = makeString(["%s", "currentPeriod"], SEP)
102102
103103
104104 func keyPeriodStartHeight (periodNum) = makeString(["%s%s", "periodStartHeight", toString(periodNum)], SEP)
105105
106106
107107 func keyPeriodEndHeight (periodNum) = makeString(["%s%s", "periodEndHeight", toString(periodNum)], SEP)
108108
109109
110110 func keyUsdtPriceAssetAllowableRatio () = makeString(["%s", "usdtPriceAssetAllowableRatio"], SEP)
111111
112112
113113 func keyTotalPeriodAllowance (assetId) = makeString(["%s%s", "totalPeriodAllowance", assetId], SEP)
114114
115115
116116 func keyUserPeriodAllowance (assetId) = makeString(["%s%s", "userPeriodAllowance", assetId], SEP)
117117
118118
119119 func keyPeriodTotalAvailableToClaim (assetId,periodNum) = makeString(["%s%s%s", "periodTotalAvailableToClaim", assetId, toString(periodNum)], SEP)
120120
121121
122122 func keyPeriodUserAvailableToClaim (assetId,periodNum,userAddress) = makeString(["%s%s%s%s", "periodUserAvailableToClaim", assetId, toString(periodNum), userAddress], SEP)
123123
124124
125125 func keyUsdtPriceAssetStablePool () = makeString(["%s", "usdtPriceAssetStablePool"], SEP)
126126
127127
128128 func keyUsdtAssetId () = makeString(["%s", "usdtAssetId"], SEP)
129129
130130
131131 func keyPriceAssetBalance (address) = makeString(["%s%s", "priceAssetBalance", address], SEP)
132132
133133
134134 func keyInvestorRemainingAmount (address) = makeString(["%s%s", "investorRemainingAmount", address], SEP)
135135
136136
137137 func keyTotalRemainingAmount () = makeString(["%s", "totalRemainingAmount"], SEP)
138138
139139
140140 func keyManagerPublicKey () = "%s__managerPublicKey"
141141
142142
143143 func keyManagerVaultAddress () = "%s__managerVaultAddress"
144144
145145
146146 func readConfigArray () = split(getStringOrFail(keyConfig()), SEP)
147147
148148
149149 func readTotalsArrayOrDefaultByCustomKey (customKey) = split(valueOrElse(getString(customKey), formatInvestorS("0", "0", "0", "0", "0")), SEP)
150150
151151
152152 func readTotalsArrayOrDefault () = readTotalsArrayOrDefaultByCustomKey(keyTotals())
153153
154154
155155 func readInvestorArrayOrDefault (userAddress) = readTotalsArrayOrDefaultByCustomKey(keyInvestor(userAddress))
156156
157157
158158 func readInvestorArrayOrFail (userAddress) = split(getStringOrFail(keyInvestor(userAddress)), SEP)
159159
160160
161-func getManagerAddressOrFail () = addressFromStringValue(getStringValue(keyManagerVaultAddress()))
161+func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) {
162+ case s: String =>
163+ addressFromStringValue(s)
164+ case _ =>
165+ this
166+}
162167
163168
164169 let IdxDiffTotalIncrement = 0
165170
166171 let IdxDiffRemainingPriceAmountIncrement = 1
167172
168173 let IdxDiffClaimedPriceAmountIncrement = 2
169174
170175 let IdxDiffClaimedIdoAssetAmountIncrement = 3
171176
172177 func TotalsEntry (key,origArray,incrementDiff,newLastClaimedHeight,priceAssetBalance) = {
173178 let totalAmount = parseIntValue(origArray[IdxInvTotalAmount])
174179 let remainingAmount = parseIntValue(origArray[IdxInvRemainingAmount])
175180 let claimedPriceAssetAmount = parseIntValue(origArray[IdxInvClaimedPriceAssetAmount])
176181 let claimedIdoAssetAmount = parseIntValue(origArray[IdxInvClaimedIdoAssetAmount])
177182 let lastClaimedHeight = parseIntValue(origArray[IdxInvLastClaimedHeight])
178183 let newTotalAmount = (totalAmount + incrementDiff[IdxDiffTotalIncrement])
179184 let newRemainingAmount = (remainingAmount + incrementDiff[IdxDiffRemainingPriceAmountIncrement])
180185 let cfgArray = readConfigArray()
181186 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
182187 let priceAssetDecimals = value(assetInfo(fromBase58String(priceAssetId58))).decimals
183188 let priceAssetBalancePriceAssetDecimals = fraction(priceAssetBalance, scale8, pow(10, 0, priceAssetDecimals, 0, 0, DOWN))
184189 let newClaimedPriceAssetAmount = ((claimedPriceAssetAmount + incrementDiff[IdxDiffClaimedPriceAmountIncrement]) - priceAssetBalance)
185190 let newClaimedIdoAssetAmount = ((claimedIdoAssetAmount + incrementDiff[IdxDiffClaimedIdoAssetAmountIncrement]) + priceAssetBalancePriceAssetDecimals)
186191 let entries = if ((0 > newRemainingAmount))
187192 then {
188193 let diff = ((newTotalAmount - newClaimedPriceAssetAmount) - newClaimedIdoAssetAmount)
189194 let newLogicRemainingAmount = if ((0 > diff))
190195 then 0
191196 else diff
192197 StringEntry(key, formatInvestor(newTotalAmount, newLogicRemainingAmount, newClaimedPriceAssetAmount, newClaimedIdoAssetAmount, newLastClaimedHeight))
193198 }
194199 else StringEntry(key, formatInvestor(newTotalAmount, newRemainingAmount, newClaimedPriceAssetAmount, newClaimedIdoAssetAmount, newLastClaimedHeight))
195200 entries
196201 }
197202
198203
199204 func InvestOperationHistoryEntry (userAddress,priceAssetAmount,idoAssetAmount,txId) = StringEntry(keyOperationHistoryRecord("invest", userAddress, toBase58String(txId)), formatHistoryRecord(priceAssetAmount, idoAssetAmount))
200205
201206
202207 func ClaimOperationHistoryEntry (userAddress,priceAssetAmount,idoAssetAmount,txId) = StringEntry(keyOperationHistoryRecord("claim", userAddress, toBase58String(txId)), formatHistoryRecord(priceAssetAmount, idoAssetAmount))
203208
204209
205210 func internalClaim (claimedAssetId58,userAddress,txId) = {
206211 let cfgArray = readConfigArray()
207212 let claimStart = parseIntValue(cfgArray[IdxCfgClaimStart])
208213 let claimDuration = parseIntValue(cfgArray[IdxCfgClaimDuration])
209214 let claimEnd = (claimStart + claimDuration)
210215 let price = parseIntValue(cfgArray[IdxCfgPrice])
211216 let priceMult = parseIntValue(cfgArray[IdxCfgPriceMult])
212217 let idoAssetId58 = cfgArray[IdxCfgIdoAssetId]
213218 let idoAssetId = fromBase58String(idoAssetId58)
214219 let idoAssetMult = parseIntValue(cfgArray[IdxCfgIdoAssetMult])
215220 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
216221 let priceAssetId = fromBase58String(priceAssetId58)
217222 let priceAssetMult = parseIntValue(cfgArray[IdxCfgPriceAssetMult])
218223 let userAddress58 = toString(userAddress)
219224 let origInvestArray = readInvestorArrayOrFail(userAddress58)
220225 let investTotalAmount = parseIntValue(origInvestArray[IdxInvTotalAmount])
221226 let investLastClaimedHeightTMP = parseIntValue(origInvestArray[IdxInvLastClaimedHeight])
222227 let investLastClaimedHeight = if ((claimStart >= investLastClaimedHeightTMP))
223228 then claimStart
224229 else investLastClaimedHeightTMP
225230 let newClaimPeriodHeight = if ((height > claimEnd))
226231 then claimEnd
227232 else if ((claimStart > height))
228233 then claimStart
229234 else height
230235 let claimingBlocks = (newClaimPeriodHeight - investLastClaimedHeight)
231236 let claimingPriceAssetAmount = fraction(investTotalAmount, claimingBlocks, claimDuration)
232237 let claimingIdoAssetAmount = convertPriceAssetIntoIdoAsset(claimingPriceAssetAmount, priceAssetMult, price, priceMult, idoAssetMult)
233238 let isUSDN = (claimedAssetId58 == priceAssetId58)
234239 let isUSDNClaimDisabled = valueOrElse(getBoolean(keyUSDNClaimDisabled()), false)
235240 let checks = [if (!(if (isUSDN)
236241 then isUSDNClaimDisabled
237242 else false))
238243 then true
239244 else throw("USDN claim is disabled")]
240245 if ((checks == checks))
241246 then if ((claimedAssetId58 == priceAssetId58))
242247 then $Tuple6([0, -(claimingPriceAssetAmount), claimingPriceAssetAmount, 0], claimingPriceAssetAmount, priceAssetId, origInvestArray, newClaimPeriodHeight, [claimingPriceAssetAmount, claimingIdoAssetAmount])
243248 else if ((claimedAssetId58 == idoAssetId58))
244249 then $Tuple6([0, -(claimingPriceAssetAmount), 0, claimingIdoAssetAmount], claimingIdoAssetAmount, idoAssetId, origInvestArray, newClaimPeriodHeight, [claimingPriceAssetAmount, claimingIdoAssetAmount])
245250 else throw(("unsupported assetId: " + claimedAssetId58))
246251 else throw("Strict value is not equal to itself.")
247252 }
248253
249254
250255 func internalClaimV2 (priceAssetId58,userAddress58,outAmount,totalUserAvailableToClaim) = {
251256 let totalPeriodPriceAssetAllowance = value(getInteger(keyTotalPeriodAllowance(priceAssetId58)))
252257 let userPeriodPriceAssetAllowance = value(getInteger(keyUserPeriodAllowance(priceAssetId58)))
253258 let periodLength = value(getInteger(keyPeriodLength()))
254259 let currentPeriod = valueOrElse(getInteger(keyCurrentPeriod()), 0)
255260 let zeroPeriodEndHeighIsDefined = isDefined(getInteger(keyPeriodEndHeight(0)))
256- let $t01307714947 = if ((currentPeriod > 0))
261+ let $t01313615006 = if ((currentPeriod > 0))
257262 then {
258263 let lastPeriodStartHeight = value(getInteger(keyPeriodStartHeight(currentPeriod)))
259264 let lastPeriodEndHeight = value(getInteger(keyPeriodEndHeight(currentPeriod)))
260- let $t01333714042 = if ((height > lastPeriodEndHeight))
265+ let $t01339614101 = if ((height > lastPeriodEndHeight))
261266 then {
262267 let updatedCurrentPeriod = (currentPeriod + 1)
263268 let periodStart = if ((height > (lastPeriodEndHeight + periodLength)))
264269 then {
265270 let blocksToLastPeriodStart = ((height - lastPeriodEndHeight) % periodLength)
266271 if ((blocksToLastPeriodStart == 0))
267272 then ((height - periodLength) + 1)
268273 else (height - blocksToLastPeriodStart)
269274 }
270275 else (lastPeriodEndHeight + 1)
271276 let periodEnd = ((periodStart + periodLength) - 1)
272277 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
273278 }
274279 else $Tuple3(currentPeriod, lastPeriodStartHeight, lastPeriodEndHeight)
275- let updatedCurrentPeriod = $t01333714042._1
276- let periodStart = $t01333714042._2
277- let periodEnd = $t01333714042._3
280+ let updatedCurrentPeriod = $t01339614101._1
281+ let periodStart = $t01339614101._2
282+ let periodEnd = $t01339614101._3
278283 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
279284 }
280285 else if (zeroPeriodEndHeighIsDefined)
281286 then {
282287 let zeroPeriodStartHeight = value(getInteger(keyPeriodStartHeight(0)))
283288 let zeroPeriodEndHeight = value(getInteger(keyPeriodEndHeight(0)))
284- let $t01429714679 = if ((height > zeroPeriodEndHeight))
289+ let $t01435614738 = if ((height > zeroPeriodEndHeight))
285290 then {
286291 let updatedCurrentPeriod = (currentPeriod + 1)
287292 let periodStart = (zeroPeriodEndHeight + 1)
288293 let periodEnd = ((periodStart + periodLength) - 1)
289294 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
290295 }
291296 else $Tuple3(currentPeriod, zeroPeriodStartHeight, zeroPeriodEndHeight)
292- let updatedCurrentPeriod = $t01429714679._1
293- let periodStart = $t01429714679._2
294- let periodEnd = $t01429714679._3
297+ let updatedCurrentPeriod = $t01435614738._1
298+ let periodStart = $t01435614738._2
299+ let periodEnd = $t01435614738._3
295300 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
296301 }
297302 else $Tuple3(currentPeriod, valueOrElse(getInteger(keyPeriodStartHeight(currentPeriod)), height), valueOrElse(getInteger(keyPeriodEndHeight(currentPeriod)), ((height + periodLength) - 1)))
298- let updatedCurrentPeriod = $t01307714947._1
299- let periodStart = $t01307714947._2
300- let periodEnd = $t01307714947._3
303+ let updatedCurrentPeriod = $t01313615006._1
304+ let periodStart = $t01313615006._2
305+ let periodEnd = $t01313615006._3
301306 let periodTotalAvailableToClaim = valueOrElse(getInteger(keyPeriodTotalAvailableToClaim(priceAssetId58, updatedCurrentPeriod)), totalPeriodPriceAssetAllowance)
302307 let periodUserAvailableToClaim = valueOrElse(getInteger(keyPeriodUserAvailableToClaim(priceAssetId58, updatedCurrentPeriod, userAddress58)), userPeriodPriceAssetAllowance)
303308 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
304309 let periodMinAvailableToClaim = min([(outAmount + priceAssetBalance), periodTotalAvailableToClaim, periodUserAvailableToClaim])
305310 let usdtPriceAssetAllowableRatio = value(getInteger(keyUsdtPriceAssetAllowableRatio()))
306311 let putOneTknV2PriceAssetAmount = scale8
307- let $t01570215955 = {
312+ let $t01576116014 = {
308313 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "putOneTknV2WithoutTakeFeeREADONLY", [putOneTknV2PriceAssetAmount, priceAssetId58], nil)
309314 if ($isInstanceOf(@, "(Int, Int, Int)"))
310315 then @
311316 else throw(($getType(@) + " couldn't be cast to (Int, Int, Int)"))
312317 }
313- if (($t01570215955 == $t01570215955))
318+ if (($t01576116014 == $t01576116014))
314319 then {
315- let bonus = $t01570215955._3
316- let feeAmount = $t01570215955._2
317- let lpAmount = $t01570215955._1
320+ let bonus = $t01576116014._3
321+ let feeAmount = $t01576116014._2
322+ let lpAmount = $t01576116014._1
318323 let usdtAssetId = value(getString(keyUsdtAssetId()))
319- let $t01601716235 = {
324+ let $t01607616294 = {
320325 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "getOneTknV2READONLY", [usdtAssetId, lpAmount], nil)
321326 if ($isInstanceOf(@, "(Int, Int)"))
322327 then @
323328 else throw(($getType(@) + " couldn't be cast to (Int, Int)"))
324329 }
325- if (($t01601716235 == $t01601716235))
330+ if (($t01607616294 == $t01607616294))
326331 then {
327- let getOneTknV2FeeAmount = $t01601716235._2
328- let usdtAmount = $t01601716235._1
332+ let getOneTknV2FeeAmount = $t01607616294._2
333+ let usdtAmount = $t01607616294._1
329334 let currentUsdtPriceAssetRatio = fraction(putOneTknV2PriceAssetAmount, scale8, usdtAmount)
330335 let endPeriodBlocksLeft = (periodEnd - height)
331336 $Tuple10(periodMinAvailableToClaim, periodTotalAvailableToClaim, periodUserAvailableToClaim, totalUserAvailableToClaim, usdtPriceAssetAllowableRatio, currentUsdtPriceAssetRatio, endPeriodBlocksLeft, updatedCurrentPeriod, periodStart, periodEnd)
332337 }
333338 else throw("Strict value is not equal to itself.")
334339 }
335340 else throw("Strict value is not equal to itself.")
336341 }
337342
338343
339344 func managerPublicKeyOrUnit () = {
340- let managerVaultAddress = getManagerAddressOrFail()
345+ let managerVaultAddress = getManagerVaultAddressOrThis()
341346 match getString(managerVaultAddress, keyManagerPublicKey()) {
342347 case s: String =>
343348 fromBase58String(s)
344349 case _: Unit =>
345350 unit
346351 case _ =>
347352 throw("Match error")
348353 }
349354 }
350355
351356
352357 func mustManager (i) = {
353358 let pd = throw("Permission denied")
354359 match managerPublicKeyOrUnit() {
355360 case pk: ByteVector =>
356361 if ((i.callerPublicKey == pk))
357362 then true
358363 else pd
359364 case _: Unit =>
360365 if ((i.caller == this))
361366 then true
362367 else pd
363368 case _ =>
364369 throw("Match error")
365370 }
366371 }
367372
368373
369374 @Callable(i)
370375 func constructor (idoStart,idoDuration,claimStart,claimDuration,price,priceAssetId58,minInvestAmount) = {
371376 let priceMult = ((100 * 1000) * 1000)
372377 let idoEnd = (idoStart + idoDuration)
373378 if (isDefined(getString(keyConfig())))
374379 then throw("already initialized")
375380 else if (("3PMEHLx1j6zerarZTYfsGqDeeZqQoMpxq5S" != toString(i.caller)))
376381 then throw("not authorized")
377382 else if ((size(i.payments) != 1))
378383 then throw("exactly 1 payment must be attached")
379384 else if ((idoEnd >= claimStart))
380385 then throw("claimStart must be greater than idoEnd")
381386 else {
382387 let pmt = value(i.payments[0])
383388 let idoAssetId = value(pmt.assetId)
384389 let idoAssetInfo = valueOrErrorMessage(assetInfo(idoAssetId), "fail to load ido asset info")
385390 let idoAssetId58 = toBase58String(idoAssetId)
386391 let idoAssetMult = pow(10, 0, idoAssetInfo.decimals, 0, 0, DOWN)
387392 let priceAssetId = fromBase58String(priceAssetId58)
388393 let priceAssetInfo = valueOrErrorMessage(assetInfo(priceAssetId), "fail to load price asset info")
389394 let priceAssetMult = pow(10, 0, priceAssetInfo.decimals, 0, 0, DOWN)
390395 let origTotalsArray = readTotalsArrayOrDefault()
391396 let totalsDiff = [0, 0, 0, 0]
392397 [StringEntry(keyConfig(), fromatConfig(idoStart, idoDuration, claimStart, claimDuration, price, priceMult, idoAssetId58, idoAssetMult, priceAssetId58, priceAssetMult, minInvestAmount, pmt.amount)), TotalsEntry(keyTotals(), origTotalsArray, totalsDiff, claimStart, 0)]
393398 }
394399 }
395400
396401
397402
398403 @Callable(i)
399404 func invest () = {
400405 let cfgArray = readConfigArray()
401406 let idoStart = parseIntValue(cfgArray[IdxCfgIdoStart])
402407 let idoDuration = parseIntValue(cfgArray[IdxCfgIdoDuration])
403408 let idoEnd = (idoStart + idoDuration)
404409 let claimStart = parseIntValue(cfgArray[IdxCfgClaimStart])
405410 let claimDuration = parseIntValue(cfgArray[IdxCfgClaimDuration])
406411 let price = parseIntValue(cfgArray[IdxCfgPrice])
407412 let priceMult = parseIntValue(cfgArray[IdxCfgPriceMult])
408413 let idoAssetId58 = cfgArray[IdxCfgIdoAssetId]
409414 let idoAssetId = fromBase58String(idoAssetId58)
410415 let idoAssetMult = parseIntValue(cfgArray[IdxCfgIdoAssetMult])
411416 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
412417 let priceAssetId = fromBase58String(priceAssetId58)
413418 let priceAssetMult = parseIntValue(cfgArray[IdxCfgPriceAssetMult])
414419 let minIvestAmount = parseIntValue(cfgArray[IdxCfgMinInvestAmount])
415420 let userAddress = toString(i.caller)
416421 if ((idoStart > height))
417422 then throw("ido has not been started yet")
418423 else if ((height > idoEnd))
419424 then throw("ido has been already ended")
420425 else if ((size(i.payments) != 1))
421426 then throw("exactly 1 payment is expected")
422427 else {
423428 let pmt = value(i.payments[0])
424429 let pmtAssetId = value(pmt.assetId)
425430 let pmtAmount = pmt.amount
426431 if ((pmtAssetId != priceAssetId))
427432 then throw((("invalid payment asset id: " + toBase58String(pmtAssetId)) + " is expected"))
428433 else {
429434 let origInvestorArray = readInvestorArrayOrDefault(userAddress)
430435 let origTotalsArray = readTotalsArrayOrDefault()
431436 let newPriceTotalAmount = (parseIntValue(origTotalsArray[IdxInvTotalAmount]) + pmtAmount)
432437 let requiredIdoAssetAmount = (newPriceTotalAmount * 100)
433438 if ((requiredIdoAssetAmount > assetBalance(this, idoAssetId)))
434439 then throw("IDO asset has been - sold consider to use smaller payment")
435440 else {
436441 let totalsDiff = [pmtAmount, pmtAmount, 0, 0]
437442 [TotalsEntry(keyInvestor(userAddress), origInvestorArray, totalsDiff, claimStart, 0), TotalsEntry(keyTotals(), origTotalsArray, totalsDiff, claimStart, 0), InvestOperationHistoryEntry(userAddress, pmtAmount, 0, i.transactionId)]
438443 }
439444 }
440445 }
441446 }
442447
443448
444449
445450 @Callable(i)
446451 func claim (claimedAssetId58,userAddress58) = {
447452 let callerAddress58 = toString(i.caller)
448453 if ((userAddress58 != callerAddress58))
449454 then throw("not authorized")
450455 else {
451456 let cfgArray = readConfigArray()
452457 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
453458 let claimResultTuple = internalClaim(claimedAssetId58, i.caller, i.transactionId)
454459 let totalsDiff = claimResultTuple._1
455460 let outAmount = claimResultTuple._2
456461 let outAssetId = claimResultTuple._3
457462 let origInvestArray = claimResultTuple._4
458463 let newClaimPeriodHeight = claimResultTuple._5
459464 let claimedPriceAmountFromDiff = totalsDiff[IdxDiffClaimedPriceAmountIncrement]
460465 let claimedIdoAssetAmountFromDiff = totalsDiff[IdxDiffClaimedIdoAssetAmountIncrement]
461466 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
462467 let priceAssetDecimals = value(assetInfo(fromBase58String(priceAssetId58))).decimals
463468 let entries = if ((claimedAssetId58 == priceAssetId58))
464469 then {
465- let $t02207422518 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
466- let periodMinAvailableToClaim = $t02207422518._1
467- let periodTotalAvailableToClaim = $t02207422518._2
468- let periodUserAvailableToClaim = $t02207422518._3
469- let totalUserAvailableToClaim = $t02207422518._4
470- let usdtPriceAssetAllowableRatio = $t02207422518._5
471- let currentUsdtPriceAssetRatio = $t02207422518._6
472- let endPeriodBlocksLeft = $t02207422518._7
473- let updatedCurrentPeriod = $t02207422518._8
474- let periodStart = $t02207422518._9
475- let periodEnd = $t02207422518._10
470+ let $t02213822582 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
471+ let periodMinAvailableToClaim = $t02213822582._1
472+ let periodTotalAvailableToClaim = $t02213822582._2
473+ let periodUserAvailableToClaim = $t02213822582._3
474+ let totalUserAvailableToClaim = $t02213822582._4
475+ let usdtPriceAssetAllowableRatio = $t02213822582._5
476+ let currentUsdtPriceAssetRatio = $t02213822582._6
477+ let endPeriodBlocksLeft = $t02213822582._7
478+ let updatedCurrentPeriod = $t02213822582._8
479+ let periodStart = $t02213822582._9
480+ let periodEnd = $t02213822582._10
476481 let checks = [if ((periodUserAvailableToClaim > 0))
477482 then true
478483 else throwErr("unavailable to claim because user period allowance reached"), if ((periodTotalAvailableToClaim > 0))
479484 then true
480485 else throwErr("unavailable to claim because total period allowance reached"), if ((periodMinAvailableToClaim > 0))
481486 then true
482487 else throwErr("nothing to claim"), if ((usdtPriceAssetAllowableRatio > currentUsdtPriceAssetRatio))
483488 then true
484489 else throwErr("unavailable to claim because usdn price lower than usdtPriceAssetAllowableRatio")]
485490 if ((checks == checks))
486491 then {
487492 let updatedPeriodTotalAvailableToClaim = (periodTotalAvailableToClaim - periodMinAvailableToClaim)
488493 let updatedPeriodUserAvailableToClaim = (periodUserAvailableToClaim - periodMinAvailableToClaim)
489494 let entries = if ((priceAssetBalance > periodMinAvailableToClaim))
490495 then [ScriptTransfer(i.caller, periodMinAvailableToClaim, outAssetId), IntegerEntry(keyPriceAssetBalance(userAddress58), (priceAssetBalance - periodMinAvailableToClaim))]
491496 else {
492497 let evaluateResult = split(asString(invoke(this, "claimREADONLY", [priceAssetId58, userAddress58], nil)), SEP)
493498 if ((evaluateResult == evaluateResult))
494499 then {
495500 let availablePriceAmountToClaim = parseIntValue(evaluateResult[3])
496501 let lastClaimEntries = if ((availablePriceAmountToClaim == periodMinAvailableToClaim))
497502 then {
498503 let investorTotalAmount = parseIntValue(origInvestArray[IdxInvTotalAmount])
499504 let investorRemainingAmount = parseIntValue(origInvestArray[IdxInvRemainingAmount])
500505 let investorPriceAssetBalance = parseIntValue(origInvestArray[IdxInvClaimedPriceAssetAmount])
501506 let investorIdoAssetBalance = parseIntValue(origInvestArray[IdxInvClaimedIdoAssetAmount])
502507 let investorLastClaimedHeight = parseIntValue(origInvestArray[IdxInvLastClaimedHeight])
503508 let newInvestArray = [toString(investorTotalAmount), "0", toString(investorPriceAssetBalance), toString(investorIdoAssetBalance), toString(investorLastClaimedHeight)]
504509 let totals = readTotalsArrayOrDefault()
505510 let totalsTotalAmount = parseIntValue(totals[IdxInvTotalAmount])
506511 let totalsRemainingAmount = parseIntValue(totals[IdxInvRemainingAmount])
507512 let totalsClaimedPriceAssetAmount = parseIntValue(totals[IdxInvClaimedPriceAssetAmount])
508513 let totalsClaimedIdoAssetAmount = parseIntValue(totals[IdxInvClaimedIdoAssetAmount])
509514 let totalsLastClaimedHeight = parseIntValue(totals[IdxInvLastClaimedHeight])
510515 let newTotalsRemainingAmount = (totalsRemainingAmount - investorRemainingAmount)
511516 let newTotalArray = [toString(totalsTotalAmount), toString(newTotalsRemainingAmount), toString(totalsClaimedPriceAssetAmount), toString(totalsClaimedIdoAssetAmount), toString(totalsLastClaimedHeight)]
512517 let newTotalRemainingAmount = (valueOrElse(getInteger(keyTotalRemainingAmount()), 0) + investorRemainingAmount)
513518 [StringEntry(keyInvestorRemainingAmount(userAddress58), toString(investorRemainingAmount)), StringEntry(keyTotalRemainingAmount(), toString(newTotalRemainingAmount)), TotalsEntry(keyInvestor(userAddress58), newInvestArray, totalsDiff, newClaimPeriodHeight, 0), TotalsEntry(keyTotals(), newTotalArray, totalsDiff, newClaimPeriodHeight, 0)]
514519 }
515520 else [TotalsEntry(keyInvestor(userAddress58), origInvestArray, totalsDiff, newClaimPeriodHeight, 0), TotalsEntry(keyTotals(), readTotalsArrayOrDefault(), totalsDiff, newClaimPeriodHeight, 0)]
516521 let updatedPriceAssetBalance = ((priceAssetBalance + outAmount) - periodMinAvailableToClaim)
517522 ([ScriptTransfer(i.caller, periodMinAvailableToClaim, outAssetId), IntegerEntry(keyPriceAssetBalance(userAddress58), updatedPriceAssetBalance)] ++ lastClaimEntries)
518523 }
519524 else throw("Strict value is not equal to itself.")
520525 }
521526 $Tuple2(([IntegerEntry(keyCurrentPeriod(), updatedCurrentPeriod), IntegerEntry(keyPeriodStartHeight(updatedCurrentPeriod), periodStart), IntegerEntry(keyPeriodEndHeight(updatedCurrentPeriod), periodEnd), IntegerEntry(keyPeriodTotalAvailableToClaim(priceAssetId58, updatedCurrentPeriod), updatedPeriodTotalAvailableToClaim), IntegerEntry(keyPeriodUserAvailableToClaim(priceAssetId58, updatedCurrentPeriod, userAddress58), updatedPeriodUserAvailableToClaim), ClaimOperationHistoryEntry(userAddress58, periodMinAvailableToClaim, claimedIdoAssetAmountFromDiff, i.transactionId)] ++ entries), unit)
522527 }
523528 else throw("Strict value is not equal to itself.")
524529 }
525530 else {
526531 let priceAssetBalanceIdoDecimals = fraction(priceAssetBalance, scale8, pow(10, 0, priceAssetDecimals, 0, 0, DOWN))
527532 $Tuple2([ScriptTransfer(i.caller, (outAmount + priceAssetBalanceIdoDecimals), outAssetId), IntegerEntry(keyPriceAssetBalance(userAddress58), 0), TotalsEntry(keyInvestor(userAddress58), origInvestArray, totalsDiff, newClaimPeriodHeight, priceAssetBalance), TotalsEntry(keyTotals(), readTotalsArrayOrDefault(), totalsDiff, newClaimPeriodHeight, priceAssetBalance), ClaimOperationHistoryEntry(userAddress58, claimedPriceAmountFromDiff, (claimedIdoAssetAmountFromDiff + priceAssetBalanceIdoDecimals), i.transactionId)], unit)
528533 }
529534 entries
530535 }
531536 }
532537
533538
534539
535540 @Callable(i)
536541 func cleanRemaingAmount (userAddress58) = {
537542 let priceAssetId58 = readConfigArray()[IdxCfgPriceAssetId]
538543 let evaluateResult = split(asString(invoke(this, "claimREADONLY", [priceAssetId58, userAddress58], nil)), SEP)
539544 if ((evaluateResult == evaluateResult))
540545 then {
541546 let availablePriceAmountToClaim = parseIntValue(evaluateResult[2])
542547 let checkUnclaimedAssets = if ((availablePriceAmountToClaim == 0))
543548 then true
544549 else throwErr("user have unclaimed assets")
545550 if ((checkUnclaimedAssets == checkUnclaimedAssets))
546551 then {
547552 let investor = split(value(getString(keyInvestor(userAddress58))), SEP)
548553 let investorTotalAmount = parseIntValue(investor[IdxInvTotalAmount])
549554 let investorRemainingAmount = parseIntValue(investor[IdxInvRemainingAmount])
550555 let investorPriceAssetBalance = parseIntValue(investor[IdxInvClaimedPriceAssetAmount])
551556 let investorIdoAssetBalance = parseIntValue(investor[IdxInvClaimedIdoAssetAmount])
552557 let investorLastClaimedHeight = parseIntValue(investor[IdxInvLastClaimedHeight])
553558 let investorRemainingAmountCheck = if ((investorRemainingAmount != 0))
554559 then true
555560 else throwErr("investorRemainingAmount already zero")
556561 if ((investorRemainingAmountCheck == investorRemainingAmountCheck))
557562 then {
558563 let newInvestor = makeString(["%d%d%d%d%d", toString(investorTotalAmount), "0", toString(investorPriceAssetBalance), toString(investorIdoAssetBalance), toString(investorLastClaimedHeight)], SEP)
559564 let totals = split(value(getString(keyTotals())), SEP)
560565 let totalsTotalAmount = parseIntValue(totals[IdxInvTotalAmount])
561566 let totalsRemainingAmount = parseIntValue(totals[IdxInvRemainingAmount])
562567 let totalsClaimedPriceAssetAmount = parseIntValue(totals[IdxInvClaimedPriceAssetAmount])
563568 let totalsClaimedIdoAssetAmount = parseIntValue(totals[IdxInvClaimedIdoAssetAmount])
564569 let totalsLastClaimedHeight = parseIntValue(totals[IdxInvLastClaimedHeight])
565570 let newTotals = makeString(["%d%d%d%d%d", toString(totalsTotalAmount), toString((totalsRemainingAmount - investorRemainingAmount)), toString(totalsClaimedPriceAssetAmount), toString(totalsClaimedIdoAssetAmount), toString(totalsLastClaimedHeight)], SEP)
566571 let newTotalRemainingAmount = (valueOrElse(getInteger(keyTotalRemainingAmount()), 0) + investorRemainingAmount)
567572 [StringEntry(keyInvestorRemainingAmount(userAddress58), toString(investorRemainingAmount)), StringEntry(keyTotalRemainingAmount(), toString(newTotalRemainingAmount)), StringEntry(keyInvestor(userAddress58), newInvestor), StringEntry(keyTotals(), newTotals)]
568573 }
569574 else throw("Strict value is not equal to itself.")
570575 }
571576 else throw("Strict value is not equal to itself.")
572577 }
573578 else throw("Strict value is not equal to itself.")
574579 }
575580
576581
577582
578583 @Callable(i)
579584 func claimREADONLY (claimedAssetId58,userAddress58) = {
580585 let claimResultTuple = internalClaim(claimedAssetId58, addressFromStringValue(userAddress58), fromBase58String(""))
581586 let totalsDiff = claimResultTuple._1
582587 let outAmount = claimResultTuple._2
583588 let outAssetId = claimResultTuple._3
584589 let origInvestArray = claimResultTuple._4
585590 let newClaimPeriodHeight = claimResultTuple._5
586591 let availableToClaimArray = claimResultTuple._6
587592 let availablePriceAmountToClaim = availableToClaimArray[0]
588593 let availableIdoAmountToClaim = availableToClaimArray[1]
589594 $Tuple2(nil, makeString(["%s%d%d", userAddress58, toString(availablePriceAmountToClaim), toString(availableIdoAmountToClaim)], SEP))
590595 }
591596
592597
593598
594599 @Callable(i)
595600 func claimV2READONLY (claimedAssetId58,userAddress58) = {
596601 let claimResultTuple = internalClaim(claimedAssetId58, addressFromStringValue(userAddress58), fromBase58String(""))
597602 let totalsDiff = claimResultTuple._1
598603 let outAmount = claimResultTuple._2
599604 let outAssetId = claimResultTuple._3
600605 let origInvestArray = claimResultTuple._4
601606 let newClaimPeriodHeight = claimResultTuple._5
602607 let availableToClaimArray = claimResultTuple._6
603608 let availablePriceAmountToClaim = availableToClaimArray[0]
604609 let availableIdoAmountToClaim = availableToClaimArray[1]
605610 let cfgArray = readConfigArray()
606611 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
607612 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
608613 let priceAssetBalanceIdoDecimals = (priceAssetBalance * 100)
609614 let availableIdoAmountToClaimWithPriceAssetBalance = (availableIdoAmountToClaim + priceAssetBalanceIdoDecimals)
610- let $t03376934181 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
611- let periodMinAvailableToClaim = $t03376934181._1
612- let periodTotalAvailableToClaim = $t03376934181._2
613- let periodUserAvailableToClaim = $t03376934181._3
614- let totalUserAvailableToClaim = $t03376934181._4
615- let usdtPriceAssetAllowableRatio = $t03376934181._5
616- let currentUsdtPriceAssetRatio = $t03376934181._6
617- let endPeriodBlocksLeft = $t03376934181._7
618- let updatedCurrentPeriod = $t03376934181._8
619- let periodStart = $t03376934181._9
620- let periodEnd = $t03376934181._10
615+ let $t03383334245 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
616+ let periodMinAvailableToClaim = $t03383334245._1
617+ let periodTotalAvailableToClaim = $t03383334245._2
618+ let periodUserAvailableToClaim = $t03383334245._3
619+ let totalUserAvailableToClaim = $t03383334245._4
620+ let usdtPriceAssetAllowableRatio = $t03383334245._5
621+ let currentUsdtPriceAssetRatio = $t03383334245._6
622+ let endPeriodBlocksLeft = $t03383334245._7
623+ let updatedCurrentPeriod = $t03383334245._8
624+ let periodStart = $t03383334245._9
625+ let periodEnd = $t03383334245._10
621626 let currentPeriodEndHeight = valueOrElse(getInteger(keyPeriodEndHeight(updatedCurrentPeriod)), 0)
622627 let userTotalPriceAssetClaimed = (parseIntValue(readInvestorArrayOrFail(userAddress58)[IdxInvClaimedPriceAssetAmount]) - priceAssetBalance)
623628 let resultString = if ((height > currentPeriodEndHeight))
624629 then {
625630 let periodLenght = value(getInteger(keyPeriodLength()))
626631 let userPeriodAllowance = value(getInteger(keyUserPeriodAllowance(priceAssetId58)))
627632 let totalPeriodAllowance = value(getInteger(keyTotalPeriodAllowance(priceAssetId58)))
628633 makeString(["%d%d%d%d%d%d", toString(availableIdoAmountToClaimWithPriceAssetBalance), toString(userPeriodAllowance), toString(totalPeriodAllowance), toString(usdtPriceAssetAllowableRatio), toString(currentUsdtPriceAssetRatio), toString(periodLenght), toString(userTotalPriceAssetClaimed)], SEP)
629634 }
630635 else makeString(["%d%d%d%d%d%d", toString(availableIdoAmountToClaimWithPriceAssetBalance), toString(periodMinAvailableToClaim), toString(periodTotalAvailableToClaim), toString(usdtPriceAssetAllowableRatio), toString(currentUsdtPriceAssetRatio), toString(endPeriodBlocksLeft), toString(userTotalPriceAssetClaimed)], SEP)
631636 $Tuple2(nil, resultString)
632637 }
633638
634639
635640 @Verifier(tx)
636641 func verify () = {
637642 let targetPublicKey = match managerPublicKeyOrUnit() {
638643 case pk: ByteVector =>
639644 pk
640645 case _: Unit =>
641646 tx.senderPublicKey
642647 case _ =>
643648 throw("Match error")
644649 }
645650 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
646651 }
647652

github/deemru/w8io/3ef1775 
131.46 ms