tx · 5NcwC6LQDrx48AUrS9zWCsQH332zWc3P4H3Q1QVJvgJ

3PKpsc1TNquw4HAF62pWK8ka1DBz9vyEBkt:  -0.03400000 Waves

2023.05.10 14:40 [3637204] smart account 3PKpsc1TNquw4HAF62pWK8ka1DBz9vyEBkt > SELF 0.00000000 Waves

{ "type": 13, "id": "5NcwC6LQDrx48AUrS9zWCsQH332zWc3P4H3Q1QVJvgJ", "fee": 3400000, "feeAssetId": null, "timestamp": 1683718882677, "version": 2, "chainId": 87, "sender": "3PKpsc1TNquw4HAF62pWK8ka1DBz9vyEBkt", "senderPublicKey": "8ZLAVkwG8sZ97hmBdGRkQpYTp5En9xgEYX4PeupqxpFw", "proofs": [ "3xk4mEuKzqU8h24nUcVgDQeJZvJNfMR6tSgVGEMT9DnBb9BJGvtCrwMapfSkfQPjuYBAsUBGrN2NkLXWn384vkAK" ], "script": "base64:BgImCAISCQoHAQEBAQEIARIAEgQKAggIEgMKAQgSBAoCCAgSBAoCCAhDAQ9nZXRTdHJpbmdPckZhaWwBA2tleQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEFA2tleQkArAICCQCsAgICD21hbmRhdG9yeSB0aGlzLgUDa2V5Ag8gaXMgbm90IGRlZmluZWQAA1NFUAICX18ACEJVRlNDQUxFCQC2AgEAgICQu7rWrfANAAZzY2FsZTgAgMLXLwEIdGhyb3dFcnIBA21zZwkAAgEJALkJAgkAzAgCAglpZG8ucmlkZToJAMwIAgUDbXNnBQNuaWwCASABCGFzU3RyaW5nAQN2YWwEByRtYXRjaDAFA3ZhbAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEBnZhbFN0cgUHJG1hdGNoMAUGdmFsU3RyCQACAQIYZmFpbCB0byBjYXN0IGludG8gU3RyaW5nAR1jb252ZXJ0UHJpY2VBc3NldEludG9JZG9Bc3NldAUQcHJpY2VBc3NldEFtb3VudA5wcmljZUFzc2V0TVVMVAVwcmljZQlwcmljZU1VTFQMaWRvQXNzZXRNVUxUBA9iUHJpY2VBc3NldE1VTFQJALYCAQUOcHJpY2VBc3NldE1VTFQEDWJJZG9Bc3NldE1VTFQJALYCAQUMaWRvQXNzZXRNVUxUBA5iUHJpY2VBc3NldEJVRgkAvAIDCQC2AgEFEHByaWNlQXNzZXRBbW91bnQFCEJVRlNDQUxFBQ9iUHJpY2VBc3NldE1VTFQED2JBbW91bnRBc3NldEJVRgkAvAIDBQ5iUHJpY2VBc3NldEJVRgkAtgIBBQlwcmljZU1VTFQJALYCAQUFcHJpY2UJAKADAQkAvAIDBQ9iQW1vdW50QXNzZXRCVUYJALYCAQUMaWRvQXNzZXRNVUxUBQhCVUZTQ0FMRQAOSWR4Q2ZnSWRvU3RhcnQAAQARSWR4Q2ZnSWRvRHVyYXRpb24AAgAQSWR4Q2ZnQ2xhaW1TdGFydAADABNJZHhDZmdDbGFpbUR1cmF0aW9uAAQAC0lkeENmZ1ByaWNlAAUAD0lkeENmZ1ByaWNlTXVsdAAGABBJZHhDZmdJZG9Bc3NldElkAAcAEklkeENmZ0lkb0Fzc2V0TXVsdAAIABJJZHhDZmdQcmljZUFzc2V0SWQACQAUSWR4Q2ZnUHJpY2VBc3NldE11bHQACgAVSWR4Q2ZnTWluSW52ZXN0QW1vdW50AAsBDWZyb21hdENvbmZpZ1MMCGlkb1N0YXJ0C2lkb0R1cmF0aW9uCmNsYWltU3RhcnQNY2xhaW1EdXJhdGlvbgVwcmljZQlwcmljZU11bHQMaWRvQXNzZXRJZDU4DGlkb0Fzc2V0TXVsdA5wcmljZUFzc2V0SWQ1OA5wcmljZUFzc2V0TXVsdA9taW5JbnZlc3RBbW91bnQTdG90YWxJZG9Bc3NldFRvU2VsbAkAuQkCCQDMCAICGCVkJWQlZCVkJWQlZCVzJWQlcyVkJWQlZAkAzAgCBQhpZG9TdGFydAkAzAgCBQtpZG9EdXJhdGlvbgkAzAgCBQpjbGFpbVN0YXJ0CQDMCAIFDWNsYWltRHVyYXRpb24JAMwIAgUFcHJpY2UJAMwIAgUJcHJpY2VNdWx0CQDMCAIFDGlkb0Fzc2V0SWQ1OAkAzAgCBQxpZG9Bc3NldE11bHQJAMwIAgUOcHJpY2VBc3NldElkNTgJAMwIAgUOcHJpY2VBc3NldE11bHQJAMwIAgUPbWluSW52ZXN0QW1vdW50CQDMCAIFE3RvdGFsSWRvQXNzZXRUb1NlbGwFA25pbAUDU0VQAQxmcm9tYXRDb25maWcMCGlkb1N0YXJ0C2lkb0R1cmF0aW9uCmNsYWltU3RhcnQNY2xhaW1EdXJhdGlvbgVwcmljZQlwcmljZU11bHQMaWRvQXNzZXRJZDU4DGlkb0Fzc2V0TXVsdA5wcmljZUFzc2V0SWQ1OA5wcmljZUFzc2V0TXVsdA9taW5JbnZlc3RBbW91bnQTdG90YWxJZG9Bc3NldFRvU2VsbAkBDWZyb21hdENvbmZpZ1MMCQCkAwEFCGlkb1N0YXJ0CQCkAwEFC2lkb0R1cmF0aW9uCQCkAwEFCmNsYWltU3RhcnQJAKQDAQUNY2xhaW1EdXJhdGlvbgkApAMBBQVwcmljZQkApAMBBQlwcmljZU11bHQFDGlkb0Fzc2V0SWQ1OAkApAMBBQxpZG9Bc3NldE11bHQFDnByaWNlQXNzZXRJZDU4CQCkAwEFDnByaWNlQXNzZXRNdWx0CQCkAwEFD21pbkludmVzdEFtb3VudAkApAMBBRN0b3RhbElkb0Fzc2V0VG9TZWxsABFJZHhJbnZUb3RhbEFtb3VudAABABVJZHhJbnZSZW1haW5pbmdBbW91bnQAAgAdSWR4SW52Q2xhaW1lZFByaWNlQXNzZXRBbW91bnQAAwAbSWR4SW52Q2xhaW1lZElkb0Fzc2V0QW1vdW50AAQAF0lkeEludkxhc3RDbGFpbWVkSGVpZ2h0AAUBD2Zvcm1hdEludmVzdG9yUwULdG90YWxBbW91bnQPcmVtYWluaW5nQW1vdW50F2NsYWltZWRQcmljZUFzc2V0QW1vdW50FWNsYWltZWRJZG9Bc3NldEFtb3VudBFsYXN0Q2xhaW1lZEhlaWdodAkAuQkCCQDMCAICCiVkJWQlZCVkJWQJAMwIAgULdG90YWxBbW91bnQJAMwIAgUPcmVtYWluaW5nQW1vdW50CQDMCAIFF2NsYWltZWRQcmljZUFzc2V0QW1vdW50CQDMCAIFFWNsYWltZWRJZG9Bc3NldEFtb3VudAkAzAgCBRFsYXN0Q2xhaW1lZEhlaWdodAUDbmlsBQNTRVABDmZvcm1hdEludmVzdG9yBQt0b3RhbEFtb3VudA9yZW1haW5pbmdBbW91bnQXY2xhaW1lZFByaWNlQXNzZXRBbW91bnQVY2xhaW1lZElkb0Fzc2V0QW1vdW50EWxhc3RDbGFpbWVkSGVpZ2h0CQEPZm9ybWF0SW52ZXN0b3JTBQkApAMBBQt0b3RhbEFtb3VudAkApAMBBQ9yZW1haW5pbmdBbW91bnQJAKQDAQUXY2xhaW1lZFByaWNlQXNzZXRBbW91bnQJAKQDAQUVY2xhaW1lZElkb0Fzc2V0QW1vdW50CQCkAwEFEWxhc3RDbGFpbWVkSGVpZ2h0ARNmb3JtYXRIaXN0b3J5UmVjb3JkAhBwcmljZUFzc2V0QW1vdW50Dmlkb0Fzc2V0QW1vdW50CQC5CQIJAMwIAgIIJWQlZCVkJWQJAMwIAgkApAMBBQZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQCkAwEFEHByaWNlQXNzZXRBbW91bnQJAMwIAgkApAMBBQ5pZG9Bc3NldEFtb3VudAUDbmlsBQNTRVABCWtleUNvbmZpZwACCiVzX19jb25maWcBC2tleUludmVzdG9yAQt1c2VyQWRkcmVzcwkArAICAgQlc19fBQt1c2VyQWRkcmVzcwEJa2V5VG90YWxzAAIKJXNfX3RvdGFscwEZa2V5T3BlcmF0aW9uSGlzdG9yeVJlY29yZAMEdHlwZQt1c2VyQWRkcmVzcwZ0eElkNTgJALkJAgkAzAgCAhElcyVzJXMlc19faGlzdG9yeQkAzAgCBQR0eXBlCQDMCAIFC3VzZXJBZGRyZXNzCQDMCAIFBnR4SWQ1OAUDbmlsBQNTRVABFGtleVVTRE5DbGFpbURpc2FibGVkAAIVJXNfX3VzZG5DbGFpbURpc2FibGVkARVrZXlVU0ROQ2xhaW1FbmRIZWlnaHQAAhYlc19fdXNkbkNsYWltRW5kSGVpZ2h0AQ9rZXlQZXJpb2RMZW5ndGgACQC5CQIJAMwIAgICJXMJAMwIAgIMcGVyaW9kTGVuZ3RoBQNuaWwFA1NFUAEQa2V5Q3VycmVudFBlcmlvZAAJALkJAgkAzAgCAgIlcwkAzAgCAg1jdXJyZW50UGVyaW9kBQNuaWwFA1NFUAEUa2V5UGVyaW9kU3RhcnRIZWlnaHQBCXBlcmlvZE51bQkAuQkCCQDMCAICBCVzJXMJAMwIAgIRcGVyaW9kU3RhcnRIZWlnaHQJAMwIAgkApAMBBQlwZXJpb2ROdW0FA25pbAUDU0VQARJrZXlQZXJpb2RFbmRIZWlnaHQBCXBlcmlvZE51bQkAuQkCCQDMCAICBCVzJXMJAMwIAgIPcGVyaW9kRW5kSGVpZ2h0CQDMCAIJAKQDAQUJcGVyaW9kTnVtBQNuaWwFA1NFUAEfa2V5VXNkdFByaWNlQXNzZXRBbGxvd2FibGVSYXRpbwAJALkJAgkAzAgCAgIlcwkAzAgCAhx1c2R0UHJpY2VBc3NldEFsbG93YWJsZVJhdGlvBQNuaWwFA1NFUAEXa2V5VG90YWxQZXJpb2RBbGxvd2FuY2UBB2Fzc2V0SWQJALkJAgkAzAgCAgQlcyVzCQDMCAICFHRvdGFsUGVyaW9kQWxsb3dhbmNlCQDMCAIFB2Fzc2V0SWQFA25pbAUDU0VQARZrZXlVc2VyUGVyaW9kQWxsb3dhbmNlAQdhc3NldElkCQC5CQIJAMwIAgIEJXMlcwkAzAgCAhN1c2VyUGVyaW9kQWxsb3dhbmNlCQDMCAIFB2Fzc2V0SWQFA25pbAUDU0VQAR5rZXlQZXJpb2RUb3RhbEF2YWlsYWJsZVRvQ2xhaW0CB2Fzc2V0SWQJcGVyaW9kTnVtCQC5CQIJAMwIAgIGJXMlcyVzCQDMCAICG3BlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbQkAzAgCBQdhc3NldElkCQDMCAIJAKQDAQUJcGVyaW9kTnVtBQNuaWwFA1NFUAEda2V5UGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0DB2Fzc2V0SWQJcGVyaW9kTnVtC3VzZXJBZGRyZXNzCQC5CQIJAMwIAgIIJXMlcyVzJXMJAMwIAgIacGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0JAMwIAgUHYXNzZXRJZAkAzAgCCQCkAwEFCXBlcmlvZE51bQkAzAgCBQt1c2VyQWRkcmVzcwUDbmlsBQNTRVABG2tleVVzZHRQcmljZUFzc2V0U3RhYmxlUG9vbAAJALkJAgkAzAgCAgIlcwkAzAgCAhh1c2R0UHJpY2VBc3NldFN0YWJsZVBvb2wFA25pbAUDU0VQAQ5rZXlVc2R0QXNzZXRJZAAJALkJAgkAzAgCAgIlcwkAzAgCAgt1c2R0QXNzZXRJZAUDbmlsBQNTRVABFGtleVByaWNlQXNzZXRCYWxhbmNlAQdhZGRyZXNzCQC5CQIJAMwIAgIEJXMlcwkAzAgCAhFwcmljZUFzc2V0QmFsYW5jZQkAzAgCBQdhZGRyZXNzBQNuaWwFA1NFUAEaa2V5SW52ZXN0b3JSZW1haW5pbmdBbW91bnQBB2FkZHJlc3MJALkJAgkAzAgCAgQlcyVzCQDMCAICF2ludmVzdG9yUmVtYWluaW5nQW1vdW50CQDMCAIFB2FkZHJlc3MFA25pbAUDU0VQARdrZXlUb3RhbFJlbWFpbmluZ0Ftb3VudAAJALkJAgkAzAgCAgIlcwkAzAgCAhR0b3RhbFJlbWFpbmluZ0Ftb3VudAUDbmlsBQNTRVABE2tleU1hbmFnZXJQdWJsaWNLZXkAAhQlc19fbWFuYWdlclB1YmxpY0tleQEWa2V5TWFuYWdlclZhdWx0QWRkcmVzcwACFyVzX19tYW5hZ2VyVmF1bHRBZGRyZXNzAQ9yZWFkQ29uZmlnQXJyYXkACQC1CQIJAQ9nZXRTdHJpbmdPckZhaWwBCQEJa2V5Q29uZmlnAAUDU0VQASNyZWFkVG90YWxzQXJyYXlPckRlZmF1bHRCeUN1c3RvbUtleQEJY3VzdG9tS2V5CQC1CQIJAQt2YWx1ZU9yRWxzZQIJAKIIAQUJY3VzdG9tS2V5CQEPZm9ybWF0SW52ZXN0b3JTBQIBMAIBMAIBMAIBMAIBMAUDU0VQARhyZWFkVG90YWxzQXJyYXlPckRlZmF1bHQACQEjcmVhZFRvdGFsc0FycmF5T3JEZWZhdWx0QnlDdXN0b21LZXkBCQEJa2V5VG90YWxzAAEacmVhZEludmVzdG9yQXJyYXlPckRlZmF1bHQBC3VzZXJBZGRyZXNzCQEjcmVhZFRvdGFsc0FycmF5T3JEZWZhdWx0QnlDdXN0b21LZXkBCQELa2V5SW52ZXN0b3IBBQt1c2VyQWRkcmVzcwEXcmVhZEludmVzdG9yQXJyYXlPckZhaWwBC3VzZXJBZGRyZXNzCQC1CQIJAQ9nZXRTdHJpbmdPckZhaWwBCQELa2V5SW52ZXN0b3IBBQt1c2VyQWRkcmVzcwUDU0VQARxnZXRNYW5hZ2VyVmF1bHRBZGRyZXNzT3JUaGlzAAQHJG1hdGNoMAkAoggBCQEWa2V5TWFuYWdlclZhdWx0QWRkcmVzcwADCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwCQERQGV4dHJOYXRpdmUoMTA2MikBBQFzBQR0aGlzABVJZHhEaWZmVG90YWxJbmNyZW1lbnQAAAAkSWR4RGlmZlJlbWFpbmluZ1ByaWNlQW1vdW50SW5jcmVtZW50AAEAIklkeERpZmZDbGFpbWVkUHJpY2VBbW91bnRJbmNyZW1lbnQAAgAlSWR4RGlmZkNsYWltZWRJZG9Bc3NldEFtb3VudEluY3JlbWVudAADAQtUb3RhbHNFbnRyeQUDa2V5CW9yaWdBcnJheQ1pbmNyZW1lbnREaWZmFG5ld0xhc3RDbGFpbWVkSGVpZ2h0EXByaWNlQXNzZXRCYWxhbmNlBAt0b3RhbEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCW9yaWdBcnJheQURSWR4SW52VG90YWxBbW91bnQED3JlbWFpbmluZ0Ftb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCW9yaWdBcnJheQUVSWR4SW52UmVtYWluaW5nQW1vdW50BBdjbGFpbWVkUHJpY2VBc3NldEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCW9yaWdBcnJheQUdSWR4SW52Q2xhaW1lZFByaWNlQXNzZXRBbW91bnQEFWNsYWltZWRJZG9Bc3NldEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCW9yaWdBcnJheQUbSWR4SW52Q2xhaW1lZElkb0Fzc2V0QW1vdW50BBFsYXN0Q2xhaW1lZEhlaWdodAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCW9yaWdBcnJheQUXSWR4SW52TGFzdENsYWltZWRIZWlnaHQEDm5ld1RvdGFsQW1vdW50CQBkAgULdG90YWxBbW91bnQJAJEDAgUNaW5jcmVtZW50RGlmZgUVSWR4RGlmZlRvdGFsSW5jcmVtZW50BBJuZXdSZW1haW5pbmdBbW91bnQJAGQCBQ9yZW1haW5pbmdBbW91bnQJAJEDAgUNaW5jcmVtZW50RGlmZgUkSWR4RGlmZlJlbWFpbmluZ1ByaWNlQW1vdW50SW5jcmVtZW50BAhjZmdBcnJheQkBD3JlYWRDb25maWdBcnJheQAEDnByaWNlQXNzZXRJZDU4CQCRAwIFCGNmZ0FycmF5BRJJZHhDZmdQcmljZUFzc2V0SWQEEnByaWNlQXNzZXREZWNpbWFscwgJAQV2YWx1ZQEJAOwHAQkA2QQBBQ5wcmljZUFzc2V0SWQ1OAhkZWNpbWFscwQjcHJpY2VBc3NldEJhbGFuY2VQcmljZUFzc2V0RGVjaW1hbHMJAGsDBRFwcmljZUFzc2V0QmFsYW5jZQUGc2NhbGU4CQBsBgAKAAAFEnByaWNlQXNzZXREZWNpbWFscwAAAAAFBERPV04EGm5ld0NsYWltZWRQcmljZUFzc2V0QW1vdW50CQBlAgkAZAIFF2NsYWltZWRQcmljZUFzc2V0QW1vdW50CQCRAwIFDWluY3JlbWVudERpZmYFIklkeERpZmZDbGFpbWVkUHJpY2VBbW91bnRJbmNyZW1lbnQFEXByaWNlQXNzZXRCYWxhbmNlBBhuZXdDbGFpbWVkSWRvQXNzZXRBbW91bnQJAGQCCQBkAgUVY2xhaW1lZElkb0Fzc2V0QW1vdW50CQCRAwIFDWluY3JlbWVudERpZmYFJUlkeERpZmZDbGFpbWVkSWRvQXNzZXRBbW91bnRJbmNyZW1lbnQFI3ByaWNlQXNzZXRCYWxhbmNlUHJpY2VBc3NldERlY2ltYWxzBAdlbnRyaWVzAwkAZgIAAAUSbmV3UmVtYWluaW5nQW1vdW50BARkaWZmCQBlAgkAZQIFDm5ld1RvdGFsQW1vdW50BRpuZXdDbGFpbWVkUHJpY2VBc3NldEFtb3VudAUYbmV3Q2xhaW1lZElkb0Fzc2V0QW1vdW50BBduZXdMb2dpY1JlbWFpbmluZ0Ftb3VudAMJAGYCAAAFBGRpZmYAAAUEZGlmZgkBC1N0cmluZ0VudHJ5AgUDa2V5CQEOZm9ybWF0SW52ZXN0b3IFBQ5uZXdUb3RhbEFtb3VudAUXbmV3TG9naWNSZW1haW5pbmdBbW91bnQFGm5ld0NsYWltZWRQcmljZUFzc2V0QW1vdW50BRhuZXdDbGFpbWVkSWRvQXNzZXRBbW91bnQFFG5ld0xhc3RDbGFpbWVkSGVpZ2h0CQELU3RyaW5nRW50cnkCBQNrZXkJAQ5mb3JtYXRJbnZlc3RvcgUFDm5ld1RvdGFsQW1vdW50BRJuZXdSZW1haW5pbmdBbW91bnQFGm5ld0NsYWltZWRQcmljZUFzc2V0QW1vdW50BRhuZXdDbGFpbWVkSWRvQXNzZXRBbW91bnQFFG5ld0xhc3RDbGFpbWVkSGVpZ2h0BQdlbnRyaWVzARtJbnZlc3RPcGVyYXRpb25IaXN0b3J5RW50cnkEC3VzZXJBZGRyZXNzEHByaWNlQXNzZXRBbW91bnQOaWRvQXNzZXRBbW91bnQEdHhJZAkBC1N0cmluZ0VudHJ5AgkBGWtleU9wZXJhdGlvbkhpc3RvcnlSZWNvcmQDAgZpbnZlc3QFC3VzZXJBZGRyZXNzCQDYBAEFBHR4SWQJARNmb3JtYXRIaXN0b3J5UmVjb3JkAgUQcHJpY2VBc3NldEFtb3VudAUOaWRvQXNzZXRBbW91bnQBGkNsYWltT3BlcmF0aW9uSGlzdG9yeUVudHJ5BAt1c2VyQWRkcmVzcxBwcmljZUFzc2V0QW1vdW50Dmlkb0Fzc2V0QW1vdW50BHR4SWQJAQtTdHJpbmdFbnRyeQIJARlrZXlPcGVyYXRpb25IaXN0b3J5UmVjb3JkAwIFY2xhaW0FC3VzZXJBZGRyZXNzCQDYBAEFBHR4SWQJARNmb3JtYXRIaXN0b3J5UmVjb3JkAgUQcHJpY2VBc3NldEFtb3VudAUOaWRvQXNzZXRBbW91bnQBDWludGVybmFsQ2xhaW0DEGNsYWltZWRBc3NldElkNTgLdXNlckFkZHJlc3MEdHhJZAQIY2ZnQXJyYXkJAQ9yZWFkQ29uZmlnQXJyYXkABApjbGFpbVN0YXJ0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIY2ZnQXJyYXkFEElkeENmZ0NsYWltU3RhcnQEDWNsYWltRHVyYXRpb24JAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhjZmdBcnJheQUTSWR4Q2ZnQ2xhaW1EdXJhdGlvbgQIY2xhaW1FbmQJAGQCBQpjbGFpbVN0YXJ0BQ1jbGFpbUR1cmF0aW9uBAVwcmljZQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGNmZ0FycmF5BQtJZHhDZmdQcmljZQQJcHJpY2VNdWx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIY2ZnQXJyYXkFD0lkeENmZ1ByaWNlTXVsdAQMaWRvQXNzZXRJZDU4CQCRAwIFCGNmZ0FycmF5BRBJZHhDZmdJZG9Bc3NldElkBAppZG9Bc3NldElkCQDZBAEFDGlkb0Fzc2V0SWQ1OAQMaWRvQXNzZXRNdWx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIY2ZnQXJyYXkFEklkeENmZ0lkb0Fzc2V0TXVsdAQOcHJpY2VBc3NldElkNTgJAJEDAgUIY2ZnQXJyYXkFEklkeENmZ1ByaWNlQXNzZXRJZAQMcHJpY2VBc3NldElkCQDZBAEFDnByaWNlQXNzZXRJZDU4BA5wcmljZUFzc2V0TXVsdAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGNmZ0FycmF5BRRJZHhDZmdQcmljZUFzc2V0TXVsdAQNdXNlckFkZHJlc3M1OAkApQgBBQt1c2VyQWRkcmVzcwQPb3JpZ0ludmVzdEFycmF5CQEXcmVhZEludmVzdG9yQXJyYXlPckZhaWwBBQ11c2VyQWRkcmVzczU4BBFpbnZlc3RUb3RhbEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFD29yaWdJbnZlc3RBcnJheQURSWR4SW52VG90YWxBbW91bnQEGmludmVzdExhc3RDbGFpbWVkSGVpZ2h0VE1QCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUPb3JpZ0ludmVzdEFycmF5BRdJZHhJbnZMYXN0Q2xhaW1lZEhlaWdodAQXaW52ZXN0TGFzdENsYWltZWRIZWlnaHQDCQBnAgUKY2xhaW1TdGFydAUaaW52ZXN0TGFzdENsYWltZWRIZWlnaHRUTVAFCmNsYWltU3RhcnQFGmludmVzdExhc3RDbGFpbWVkSGVpZ2h0VE1QBBRuZXdDbGFpbVBlcmlvZEhlaWdodAMJAGYCBQZoZWlnaHQFCGNsYWltRW5kBQhjbGFpbUVuZAMJAGYCBQpjbGFpbVN0YXJ0BQZoZWlnaHQFCmNsYWltU3RhcnQFBmhlaWdodAQOY2xhaW1pbmdCbG9ja3MJAGUCBRRuZXdDbGFpbVBlcmlvZEhlaWdodAUXaW52ZXN0TGFzdENsYWltZWRIZWlnaHQEGGNsYWltaW5nUHJpY2VBc3NldEFtb3VudAkAawMFEWludmVzdFRvdGFsQW1vdW50BQ5jbGFpbWluZ0Jsb2NrcwUNY2xhaW1EdXJhdGlvbgQWY2xhaW1pbmdJZG9Bc3NldEFtb3VudAkBHWNvbnZlcnRQcmljZUFzc2V0SW50b0lkb0Fzc2V0BQUYY2xhaW1pbmdQcmljZUFzc2V0QW1vdW50BQ5wcmljZUFzc2V0TXVsdAUFcHJpY2UFCXByaWNlTXVsdAUMaWRvQXNzZXRNdWx0BAZpc1VTRE4JAAACBRBjbGFpbWVkQXNzZXRJZDU4BQ5wcmljZUFzc2V0SWQ1OAQTaXNVU0ROQ2xhaW1EaXNhYmxlZAkBC3ZhbHVlT3JFbHNlAgkAoAgBCQEUa2V5VVNETkNsYWltRGlzYWJsZWQABwQGY2hlY2tzCQDMCAIDCQEBIQEDBQZpc1VTRE4FE2lzVVNETkNsYWltRGlzYWJsZWQHBgkAAgECFlVTRE4gY2xhaW0gaXMgZGlzYWJsZWQFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwMJAAACBRBjbGFpbWVkQXNzZXRJZDU4BQ5wcmljZUFzc2V0SWQ1OAkAmAoGCQDMCAIAAAkAzAgCCQEBLQEFGGNsYWltaW5nUHJpY2VBc3NldEFtb3VudAkAzAgCBRhjbGFpbWluZ1ByaWNlQXNzZXRBbW91bnQJAMwIAgAABQNuaWwFGGNsYWltaW5nUHJpY2VBc3NldEFtb3VudAUMcHJpY2VBc3NldElkBQ9vcmlnSW52ZXN0QXJyYXkFFG5ld0NsYWltUGVyaW9kSGVpZ2h0CQDMCAIFGGNsYWltaW5nUHJpY2VBc3NldEFtb3VudAkAzAgCBRZjbGFpbWluZ0lkb0Fzc2V0QW1vdW50BQNuaWwDCQAAAgUQY2xhaW1lZEFzc2V0SWQ1OAUMaWRvQXNzZXRJZDU4CQCYCgYJAMwIAgAACQDMCAIJAQEtAQUYY2xhaW1pbmdQcmljZUFzc2V0QW1vdW50CQDMCAIAAAkAzAgCBRZjbGFpbWluZ0lkb0Fzc2V0QW1vdW50BQNuaWwFFmNsYWltaW5nSWRvQXNzZXRBbW91bnQFCmlkb0Fzc2V0SWQFD29yaWdJbnZlc3RBcnJheQUUbmV3Q2xhaW1QZXJpb2RIZWlnaHQJAMwIAgUYY2xhaW1pbmdQcmljZUFzc2V0QW1vdW50CQDMCAIFFmNsYWltaW5nSWRvQXNzZXRBbW91bnQFA25pbAkAAgEJAKwCAgIVdW5zdXBwb3J0ZWQgYXNzZXRJZDogBRBjbGFpbWVkQXNzZXRJZDU4CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ9pbnRlcm5hbENsYWltVjIEDnByaWNlQXNzZXRJZDU4DXVzZXJBZGRyZXNzNTgJb3V0QW1vdW50GXRvdGFsVXNlckF2YWlsYWJsZVRvQ2xhaW0EHnRvdGFsUGVyaW9kUHJpY2VBc3NldEFsbG93YW5jZQkBBXZhbHVlAQkAnwgBCQEXa2V5VG90YWxQZXJpb2RBbGxvd2FuY2UBBQ5wcmljZUFzc2V0SWQ1OAQddXNlclBlcmlvZFByaWNlQXNzZXRBbGxvd2FuY2UJAQV2YWx1ZQEJAJ8IAQkBFmtleVVzZXJQZXJpb2RBbGxvd2FuY2UBBQ5wcmljZUFzc2V0SWQ1OAQMcGVyaW9kTGVuZ3RoCQEFdmFsdWUBCQCfCAEJAQ9rZXlQZXJpb2RMZW5ndGgABA1jdXJyZW50UGVyaW9kCQELdmFsdWVPckVsc2UCCQCfCAEJARBrZXlDdXJyZW50UGVyaW9kAAAABBt6ZXJvUGVyaW9kRW5kSGVpZ2hJc0RlZmluZWQJAQlpc0RlZmluZWQBCQCfCAEJARJrZXlQZXJpb2RFbmRIZWlnaHQBAAAEDSR0MDEzMTM2MTUwMDYDCQBmAgUNY3VycmVudFBlcmlvZAAABBVsYXN0UGVyaW9kU3RhcnRIZWlnaHQJAQV2YWx1ZQEJAJ8IAQkBFGtleVBlcmlvZFN0YXJ0SGVpZ2h0AQUNY3VycmVudFBlcmlvZAQTbGFzdFBlcmlvZEVuZEhlaWdodAkBBXZhbHVlAQkAnwgBCQESa2V5UGVyaW9kRW5kSGVpZ2h0AQUNY3VycmVudFBlcmlvZAQNJHQwMTMzOTYxNDEwMQMJAGYCBQZoZWlnaHQFE2xhc3RQZXJpb2RFbmRIZWlnaHQEFHVwZGF0ZWRDdXJyZW50UGVyaW9kCQBkAgUNY3VycmVudFBlcmlvZAABBAtwZXJpb2RTdGFydAMJAGYCBQZoZWlnaHQJAGQCBRNsYXN0UGVyaW9kRW5kSGVpZ2h0BQxwZXJpb2RMZW5ndGgEF2Jsb2Nrc1RvTGFzdFBlcmlvZFN0YXJ0CQBqAgkAZQIFBmhlaWdodAUTbGFzdFBlcmlvZEVuZEhlaWdodAUMcGVyaW9kTGVuZ3RoAwkAAAIFF2Jsb2Nrc1RvTGFzdFBlcmlvZFN0YXJ0AAAJAGQCCQBlAgUGaGVpZ2h0BQxwZXJpb2RMZW5ndGgAAQkAZQIFBmhlaWdodAUXYmxvY2tzVG9MYXN0UGVyaW9kU3RhcnQJAGQCBRNsYXN0UGVyaW9kRW5kSGVpZ2h0AAEECXBlcmlvZEVuZAkAZQIJAGQCBQtwZXJpb2RTdGFydAUMcGVyaW9kTGVuZ3RoAAEJAJUKAwUUdXBkYXRlZEN1cnJlbnRQZXJpb2QFC3BlcmlvZFN0YXJ0BQlwZXJpb2RFbmQJAJUKAwUNY3VycmVudFBlcmlvZAUVbGFzdFBlcmlvZFN0YXJ0SGVpZ2h0BRNsYXN0UGVyaW9kRW5kSGVpZ2h0BBR1cGRhdGVkQ3VycmVudFBlcmlvZAgFDSR0MDEzMzk2MTQxMDECXzEEC3BlcmlvZFN0YXJ0CAUNJHQwMTMzOTYxNDEwMQJfMgQJcGVyaW9kRW5kCAUNJHQwMTMzOTYxNDEwMQJfMwkAlQoDBRR1cGRhdGVkQ3VycmVudFBlcmlvZAULcGVyaW9kU3RhcnQFCXBlcmlvZEVuZAMFG3plcm9QZXJpb2RFbmRIZWlnaElzRGVmaW5lZAQVemVyb1BlcmlvZFN0YXJ0SGVpZ2h0CQEFdmFsdWUBCQCfCAEJARRrZXlQZXJpb2RTdGFydEhlaWdodAEAAAQTemVyb1BlcmlvZEVuZEhlaWdodAkBBXZhbHVlAQkAnwgBCQESa2V5UGVyaW9kRW5kSGVpZ2h0AQAABA0kdDAxNDM1NjE0NzM4AwkAZgIFBmhlaWdodAUTemVyb1BlcmlvZEVuZEhlaWdodAQUdXBkYXRlZEN1cnJlbnRQZXJpb2QJAGQCBQ1jdXJyZW50UGVyaW9kAAEEC3BlcmlvZFN0YXJ0CQBkAgUTemVyb1BlcmlvZEVuZEhlaWdodAABBAlwZXJpb2RFbmQJAGUCCQBkAgULcGVyaW9kU3RhcnQFDHBlcmlvZExlbmd0aAABCQCVCgMFFHVwZGF0ZWRDdXJyZW50UGVyaW9kBQtwZXJpb2RTdGFydAUJcGVyaW9kRW5kCQCVCgMFDWN1cnJlbnRQZXJpb2QFFXplcm9QZXJpb2RTdGFydEhlaWdodAUTemVyb1BlcmlvZEVuZEhlaWdodAQUdXBkYXRlZEN1cnJlbnRQZXJpb2QIBQ0kdDAxNDM1NjE0NzM4Al8xBAtwZXJpb2RTdGFydAgFDSR0MDE0MzU2MTQ3MzgCXzIECXBlcmlvZEVuZAgFDSR0MDE0MzU2MTQ3MzgCXzMJAJUKAwUUdXBkYXRlZEN1cnJlbnRQZXJpb2QFC3BlcmlvZFN0YXJ0BQlwZXJpb2RFbmQJAJUKAwUNY3VycmVudFBlcmlvZAkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEUa2V5UGVyaW9kU3RhcnRIZWlnaHQBBQ1jdXJyZW50UGVyaW9kBQZoZWlnaHQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBEmtleVBlcmlvZEVuZEhlaWdodAEFDWN1cnJlbnRQZXJpb2QJAGUCCQBkAgUGaGVpZ2h0BQxwZXJpb2RMZW5ndGgAAQQUdXBkYXRlZEN1cnJlbnRQZXJpb2QIBQ0kdDAxMzEzNjE1MDA2Al8xBAtwZXJpb2RTdGFydAgFDSR0MDEzMTM2MTUwMDYCXzIECXBlcmlvZEVuZAgFDSR0MDEzMTM2MTUwMDYCXzMEG3BlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbQkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEea2V5UGVyaW9kVG90YWxBdmFpbGFibGVUb0NsYWltAgUOcHJpY2VBc3NldElkNTgFFHVwZGF0ZWRDdXJyZW50UGVyaW9kBR50b3RhbFBlcmlvZFByaWNlQXNzZXRBbGxvd2FuY2UEGnBlcmlvZFVzZXJBdmFpbGFibGVUb0NsYWltCQELdmFsdWVPckVsc2UCCQCfCAEJAR1rZXlQZXJpb2RVc2VyQXZhaWxhYmxlVG9DbGFpbQMFDnByaWNlQXNzZXRJZDU4BRR1cGRhdGVkQ3VycmVudFBlcmlvZAUNdXNlckFkZHJlc3M1OAUddXNlclBlcmlvZFByaWNlQXNzZXRBbGxvd2FuY2UEEXByaWNlQXNzZXRCYWxhbmNlCQELdmFsdWVPckVsc2UCCQCfCAEJARRrZXlQcmljZUFzc2V0QmFsYW5jZQEFDXVzZXJBZGRyZXNzNTgAAAQZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbQkAlwMBCQDMCAIJAGQCBQlvdXRBbW91bnQFEXByaWNlQXNzZXRCYWxhbmNlCQDMCAIFG3BlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbQkAzAgCBRpwZXJpb2RVc2VyQXZhaWxhYmxlVG9DbGFpbQUDbmlsBBx1c2R0UHJpY2VBc3NldEFsbG93YWJsZVJhdGlvCQEFdmFsdWUBCQCfCAEJAR9rZXlVc2R0UHJpY2VBc3NldEFsbG93YWJsZVJhdGlvAAQbcHV0T25lVGtuVjJQcmljZUFzc2V0QW1vdW50BQZzY2FsZTgEDSR0MDE1NzYxMTYwMTQKAAFACQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEJAKIIAQkBG2tleVVzZHRQcmljZUFzc2V0U3RhYmxlUG9vbAACIXB1dE9uZVRrblYyV2l0aG91dFRha2VGZWVSRUFET05MWQkAzAgCBRtwdXRPbmVUa25WMlByaWNlQXNzZXRBbW91bnQJAMwIAgUOcHJpY2VBc3NldElkNTgFA25pbAUDbmlsAwkAAQIFAUACDyhJbnQsIEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACJCBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCwgSW50KQMJAAACBQ0kdDAxNTc2MTE2MDE0BQ0kdDAxNTc2MTE2MDE0BAVib251cwgFDSR0MDE1NzYxMTYwMTQCXzMECWZlZUFtb3VudAgFDSR0MDE1NzYxMTYwMTQCXzIECGxwQW1vdW50CAUNJHQwMTU3NjExNjAxNAJfMQQLdXNkdEFzc2V0SWQJAQV2YWx1ZQEJAKIIAQkBDmtleVVzZHRBc3NldElkAAQNJHQwMTYwNzYxNjI5NAoAAUAJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBBXZhbHVlAQkAoggBCQEba2V5VXNkdFByaWNlQXNzZXRTdGFibGVQb29sAAITZ2V0T25lVGtuVjJSRUFET05MWQkAzAgCBQt1c2R0QXNzZXRJZAkAzAgCBQhscEFtb3VudAUDbmlsBQNuaWwDCQABAgUBQAIKKEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACHyBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCkDCQAAAgUNJHQwMTYwNzYxNjI5NAUNJHQwMTYwNzYxNjI5NAQUZ2V0T25lVGtuVjJGZWVBbW91bnQIBQ0kdDAxNjA3NjE2Mjk0Al8yBAp1c2R0QW1vdW50CAUNJHQwMTYwNzYxNjI5NAJfMQQaY3VycmVudFVzZHRQcmljZUFzc2V0UmF0aW8JAGsDBRtwdXRPbmVUa25WMlByaWNlQXNzZXRBbW91bnQFBnNjYWxlOAUKdXNkdEFtb3VudAQTZW5kUGVyaW9kQmxvY2tzTGVmdAkAZQIFCXBlcmlvZEVuZAUGaGVpZ2h0CQCcCgoFGXBlcmlvZE1pbkF2YWlsYWJsZVRvQ2xhaW0FG3BlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbQUacGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0FGXRvdGFsVXNlckF2YWlsYWJsZVRvQ2xhaW0FHHVzZHRQcmljZUFzc2V0QWxsb3dhYmxlUmF0aW8FGmN1cnJlbnRVc2R0UHJpY2VBc3NldFJhdGlvBRNlbmRQZXJpb2RCbG9ja3NMZWZ0BRR1cGRhdGVkQ3VycmVudFBlcmlvZAULcGVyaW9kU3RhcnQFCXBlcmlvZEVuZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAAEE21hbmFnZXJWYXVsdEFkZHJlc3MJARxnZXRNYW5hZ2VyVmF1bHRBZGRyZXNzT3JUaGlzAAQHJG1hdGNoMAkAnQgCBRNtYW5hZ2VyVmF1bHRBZGRyZXNzCQETa2V5TWFuYWdlclB1YmxpY0tleQADCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwCQDZBAEFAXMDCQABAgUHJG1hdGNoMAIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAQttdXN0TWFuYWdlcgEBaQQCcGQJAAIBAhFQZXJtaXNzaW9uIGRlbmllZAQHJG1hdGNoMAkBFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQAAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAnBrBQckbWF0Y2gwAwkAAAIIBQFpD2NhbGxlclB1YmxpY0tleQUCcGsGBQJwZAMJAAECBQckbWF0Y2gwAgRVbml0AwkAAAIIBQFpBmNhbGxlcgUEdGhpcwYFAnBkCQACAQILTWF0Y2ggZXJyb3IGAWkBC2NvbnN0cnVjdG9yBwhpZG9TdGFydAtpZG9EdXJhdGlvbgpjbGFpbVN0YXJ0DWNsYWltRHVyYXRpb24FcHJpY2UOcHJpY2VBc3NldElkNTgPbWluSW52ZXN0QW1vdW50BAlwcmljZU11bHQJAGgCCQBoAgBkAOgHAOgHBAZpZG9FbmQJAGQCBQhpZG9TdGFydAULaWRvRHVyYXRpb24DCQEJaXNEZWZpbmVkAQkAoggBCQEJa2V5Q29uZmlnAAkAAgECE2FscmVhZHkgaW5pdGlhbGl6ZWQDCQECIT0CAiMzUE1FSEx4MWo2emVyYXJaVFlmc0dxRGVlWnFRb01weHE1UwkApQgBCAUBaQZjYWxsZXIJAAIBAg5ub3QgYXV0aG9yaXplZAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECImV4YWN0bHkgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQDCQBnAgUGaWRvRW5kBQpjbGFpbVN0YXJ0CQACAQImY2xhaW1TdGFydCBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBpZG9FbmQEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABAppZG9Bc3NldElkCQEFdmFsdWUBCAUDcG10B2Fzc2V0SWQEDGlkb0Fzc2V0SW5mbwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFCmlkb0Fzc2V0SWQCG2ZhaWwgdG8gbG9hZCBpZG8gYXNzZXQgaW5mbwQMaWRvQXNzZXRJZDU4CQDYBAEFCmlkb0Fzc2V0SWQEDGlkb0Fzc2V0TXVsdAkAbAYACgAACAUMaWRvQXNzZXRJbmZvCGRlY2ltYWxzAAAAAAUERE9XTgQMcHJpY2VBc3NldElkCQDZBAEFDnByaWNlQXNzZXRJZDU4BA5wcmljZUFzc2V0SW5mbwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFDHByaWNlQXNzZXRJZAIdZmFpbCB0byBsb2FkIHByaWNlIGFzc2V0IGluZm8EDnByaWNlQXNzZXRNdWx0CQBsBgAKAAAIBQ5wcmljZUFzc2V0SW5mbwhkZWNpbWFscwAAAAAFBERPV04ED29yaWdUb3RhbHNBcnJheQkBGHJlYWRUb3RhbHNBcnJheU9yRGVmYXVsdAAECnRvdGFsc0RpZmYJAMwIAgAACQDMCAIAAAkAzAgCAAAJAMwIAgAABQNuaWwJAMwIAgkBC1N0cmluZ0VudHJ5AgkBCWtleUNvbmZpZwAJAQxmcm9tYXRDb25maWcMBQhpZG9TdGFydAULaWRvRHVyYXRpb24FCmNsYWltU3RhcnQFDWNsYWltRHVyYXRpb24FBXByaWNlBQlwcmljZU11bHQFDGlkb0Fzc2V0SWQ1OAUMaWRvQXNzZXRNdWx0BQ5wcmljZUFzc2V0SWQ1OAUOcHJpY2VBc3NldE11bHQFD21pbkludmVzdEFtb3VudAgFA3BtdAZhbW91bnQJAMwIAgkBC1RvdGFsc0VudHJ5BQkBCWtleVRvdGFscwAFD29yaWdUb3RhbHNBcnJheQUKdG90YWxzRGlmZgUKY2xhaW1TdGFydAAABQNuaWwBaQEGaW52ZXN0AAQIY2ZnQXJyYXkJAQ9yZWFkQ29uZmlnQXJyYXkABAhpZG9TdGFydAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGNmZ0FycmF5BQ5JZHhDZmdJZG9TdGFydAQLaWRvRHVyYXRpb24JAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhjZmdBcnJheQURSWR4Q2ZnSWRvRHVyYXRpb24EBmlkb0VuZAkAZAIFCGlkb1N0YXJ0BQtpZG9EdXJhdGlvbgQKY2xhaW1TdGFydAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGNmZ0FycmF5BRBJZHhDZmdDbGFpbVN0YXJ0BA1jbGFpbUR1cmF0aW9uCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIY2ZnQXJyYXkFE0lkeENmZ0NsYWltRHVyYXRpb24EBXByaWNlCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIY2ZnQXJyYXkFC0lkeENmZ1ByaWNlBAlwcmljZU11bHQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhjZmdBcnJheQUPSWR4Q2ZnUHJpY2VNdWx0BAxpZG9Bc3NldElkNTgJAJEDAgUIY2ZnQXJyYXkFEElkeENmZ0lkb0Fzc2V0SWQECmlkb0Fzc2V0SWQJANkEAQUMaWRvQXNzZXRJZDU4BAxpZG9Bc3NldE11bHQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhjZmdBcnJheQUSSWR4Q2ZnSWRvQXNzZXRNdWx0BA5wcmljZUFzc2V0SWQ1OAkAkQMCBQhjZmdBcnJheQUSSWR4Q2ZnUHJpY2VBc3NldElkBAxwcmljZUFzc2V0SWQJANkEAQUOcHJpY2VBc3NldElkNTgEDnByaWNlQXNzZXRNdWx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIY2ZnQXJyYXkFFElkeENmZ1ByaWNlQXNzZXRNdWx0BA5taW5JdmVzdEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGNmZ0FycmF5BRVJZHhDZmdNaW5JbnZlc3RBbW91bnQEC3VzZXJBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgMJAGYCBQhpZG9TdGFydAUGaGVpZ2h0CQACAQIcaWRvIGhhcyBub3QgYmVlbiBzdGFydGVkIHlldAMJAGYCBQZoZWlnaHQFBmlkb0VuZAkAAgECGmlkbyBoYXMgYmVlbiBhbHJlYWR5IGVuZGVkAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIdZXhhY3RseSAxIHBheW1lbnQgaXMgZXhwZWN0ZWQEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABApwbXRBc3NldElkCQEFdmFsdWUBCAUDcG10B2Fzc2V0SWQECXBtdEFtb3VudAgFA3BtdAZhbW91bnQDCQECIT0CBQpwbXRBc3NldElkBQxwcmljZUFzc2V0SWQJAAIBCQCsAgIJAKwCAgIaaW52YWxpZCBwYXltZW50IGFzc2V0IGlkOiAJANgEAQUKcG10QXNzZXRJZAIMIGlzIGV4cGVjdGVkBBFvcmlnSW52ZXN0b3JBcnJheQkBGnJlYWRJbnZlc3RvckFycmF5T3JEZWZhdWx0AQULdXNlckFkZHJlc3MED29yaWdUb3RhbHNBcnJheQkBGHJlYWRUb3RhbHNBcnJheU9yRGVmYXVsdAAEE25ld1ByaWNlVG90YWxBbW91bnQJAGQCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUPb3JpZ1RvdGFsc0FycmF5BRFJZHhJbnZUb3RhbEFtb3VudAUJcG10QW1vdW50BBZyZXF1aXJlZElkb0Fzc2V0QW1vdW50CQBoAgUTbmV3UHJpY2VUb3RhbEFtb3VudABkAwkAZgIFFnJlcXVpcmVkSWRvQXNzZXRBbW91bnQJAPAHAgUEdGhpcwUKaWRvQXNzZXRJZAkAAgECOUlETyBhc3NldCBoYXMgYmVlbiAtIHNvbGQgY29uc2lkZXIgdG8gdXNlIHNtYWxsZXIgcGF5bWVudAQKdG90YWxzRGlmZgkAzAgCBQlwbXRBbW91bnQJAMwIAgUJcG10QW1vdW50CQDMCAIAAAkAzAgCAAAFA25pbAkAzAgCCQELVG90YWxzRW50cnkFCQELa2V5SW52ZXN0b3IBBQt1c2VyQWRkcmVzcwURb3JpZ0ludmVzdG9yQXJyYXkFCnRvdGFsc0RpZmYFCmNsYWltU3RhcnQAAAkAzAgCCQELVG90YWxzRW50cnkFCQEJa2V5VG90YWxzAAUPb3JpZ1RvdGFsc0FycmF5BQp0b3RhbHNEaWZmBQpjbGFpbVN0YXJ0AAAJAMwIAgkBG0ludmVzdE9wZXJhdGlvbkhpc3RvcnlFbnRyeQQFC3VzZXJBZGRyZXNzBQlwbXRBbW91bnQAAAgFAWkNdHJhbnNhY3Rpb25JZAUDbmlsAWkBBWNsYWltAhBjbGFpbWVkQXNzZXRJZDU4DXVzZXJBZGRyZXNzNTgED2NhbGxlckFkZHJlc3M1OAkApQgBCAUBaQZjYWxsZXIDCQECIT0CBQ11c2VyQWRkcmVzczU4BQ9jYWxsZXJBZGRyZXNzNTgJAAIBAg5ub3QgYXV0aG9yaXplZAQIY2ZnQXJyYXkJAQ9yZWFkQ29uZmlnQXJyYXkABA5wcmljZUFzc2V0SWQ1OAkAkQMCBQhjZmdBcnJheQUSSWR4Q2ZnUHJpY2VBc3NldElkBBBjbGFpbVJlc3VsdFR1cGxlCQENaW50ZXJuYWxDbGFpbQMFEGNsYWltZWRBc3NldElkNTgIBQFpBmNhbGxlcggFAWkNdHJhbnNhY3Rpb25JZAQKdG90YWxzRGlmZggFEGNsYWltUmVzdWx0VHVwbGUCXzEECW91dEFtb3VudAgFEGNsYWltUmVzdWx0VHVwbGUCXzIECm91dEFzc2V0SWQIBRBjbGFpbVJlc3VsdFR1cGxlAl8zBA9vcmlnSW52ZXN0QXJyYXkIBRBjbGFpbVJlc3VsdFR1cGxlAl80BBRuZXdDbGFpbVBlcmlvZEhlaWdodAgFEGNsYWltUmVzdWx0VHVwbGUCXzUEGmNsYWltZWRQcmljZUFtb3VudEZyb21EaWZmCQCRAwIFCnRvdGFsc0RpZmYFIklkeERpZmZDbGFpbWVkUHJpY2VBbW91bnRJbmNyZW1lbnQEHWNsYWltZWRJZG9Bc3NldEFtb3VudEZyb21EaWZmCQCRAwIFCnRvdGFsc0RpZmYFJUlkeERpZmZDbGFpbWVkSWRvQXNzZXRBbW91bnRJbmNyZW1lbnQEEXByaWNlQXNzZXRCYWxhbmNlCQELdmFsdWVPckVsc2UCCQCfCAEJARRrZXlQcmljZUFzc2V0QmFsYW5jZQEFDXVzZXJBZGRyZXNzNTgAAAQScHJpY2VBc3NldERlY2ltYWxzCAkBBXZhbHVlAQkA7AcBCQDZBAEFDnByaWNlQXNzZXRJZDU4CGRlY2ltYWxzBAdlbnRyaWVzAwkAAAIFEGNsYWltZWRBc3NldElkNTgFDnByaWNlQXNzZXRJZDU4BA0kdDAyMjEzODIyNTgyCQEPaW50ZXJuYWxDbGFpbVYyBAUOcHJpY2VBc3NldElkNTgFDXVzZXJBZGRyZXNzNTgFCW91dEFtb3VudAkAkQMCBQp0b3RhbHNEaWZmBSJJZHhEaWZmQ2xhaW1lZFByaWNlQW1vdW50SW5jcmVtZW50BBlwZXJpb2RNaW5BdmFpbGFibGVUb0NsYWltCAUNJHQwMjIxMzgyMjU4MgJfMQQbcGVyaW9kVG90YWxBdmFpbGFibGVUb0NsYWltCAUNJHQwMjIxMzgyMjU4MgJfMgQacGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0IBQ0kdDAyMjEzODIyNTgyAl8zBBl0b3RhbFVzZXJBdmFpbGFibGVUb0NsYWltCAUNJHQwMjIxMzgyMjU4MgJfNAQcdXNkdFByaWNlQXNzZXRBbGxvd2FibGVSYXRpbwgFDSR0MDIyMTM4MjI1ODICXzUEGmN1cnJlbnRVc2R0UHJpY2VBc3NldFJhdGlvCAUNJHQwMjIxMzgyMjU4MgJfNgQTZW5kUGVyaW9kQmxvY2tzTGVmdAgFDSR0MDIyMTM4MjI1ODICXzcEFHVwZGF0ZWRDdXJyZW50UGVyaW9kCAUNJHQwMjIxMzgyMjU4MgJfOAQLcGVyaW9kU3RhcnQIBQ0kdDAyMjEzODIyNTgyAl85BAlwZXJpb2RFbmQIBQ0kdDAyMjEzODIyNTgyA18xMAQGY2hlY2tzCQDMCAIDCQBmAgUacGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0AAAYJAQh0aHJvd0VycgECOnVuYXZhaWxhYmxlIHRvIGNsYWltIGJlY2F1c2UgdXNlciBwZXJpb2QgYWxsb3dhbmNlIHJlYWNoZWQJAMwIAgMJAGYCBRtwZXJpb2RUb3RhbEF2YWlsYWJsZVRvQ2xhaW0AAAYJAQh0aHJvd0VycgECO3VuYXZhaWxhYmxlIHRvIGNsYWltIGJlY2F1c2UgdG90YWwgcGVyaW9kIGFsbG93YW5jZSByZWFjaGVkCQDMCAIDCQBmAgUZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbQAABgkBCHRocm93RXJyAQIQbm90aGluZyB0byBjbGFpbQkAzAgCAwkAZgIFHHVzZHRQcmljZUFzc2V0QWxsb3dhYmxlUmF0aW8FGmN1cnJlbnRVc2R0UHJpY2VBc3NldFJhdGlvBgkBCHRocm93RXJyAQJPdW5hdmFpbGFibGUgdG8gY2xhaW0gYmVjYXVzZSB1c2RuIHByaWNlIGxvd2VyIHRoYW4gdXNkdFByaWNlQXNzZXRBbGxvd2FibGVSYXRpbwUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBCJ1cGRhdGVkUGVyaW9kVG90YWxBdmFpbGFibGVUb0NsYWltCQBlAgUbcGVyaW9kVG90YWxBdmFpbGFibGVUb0NsYWltBRlwZXJpb2RNaW5BdmFpbGFibGVUb0NsYWltBCF1cGRhdGVkUGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0JAGUCBRpwZXJpb2RVc2VyQXZhaWxhYmxlVG9DbGFpbQUZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbQQHZW50cmllcwMJAGYCBRFwcmljZUFzc2V0QmFsYW5jZQUZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFGXBlcmlvZE1pbkF2YWlsYWJsZVRvQ2xhaW0FCm91dEFzc2V0SWQJAMwIAgkBDEludGVnZXJFbnRyeQIJARRrZXlQcmljZUFzc2V0QmFsYW5jZQEFDXVzZXJBZGRyZXNzNTgJAGUCBRFwcmljZUFzc2V0QmFsYW5jZQUZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbQUDbmlsBA5ldmFsdWF0ZVJlc3VsdAkAtQkCCQEIYXNTdHJpbmcBCQD8BwQFBHRoaXMCDWNsYWltUkVBRE9OTFkJAMwIAgUOcHJpY2VBc3NldElkNTgJAMwIAgUNdXNlckFkZHJlc3M1OAUDbmlsBQNuaWwFA1NFUAMJAAACBQ5ldmFsdWF0ZVJlc3VsdAUOZXZhbHVhdGVSZXN1bHQEG2F2YWlsYWJsZVByaWNlQW1vdW50VG9DbGFpbQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDmV2YWx1YXRlUmVzdWx0AAMEEGxhc3RDbGFpbUVudHJpZXMDCQAAAgUbYXZhaWxhYmxlUHJpY2VBbW91bnRUb0NsYWltBRlwZXJpb2RNaW5BdmFpbGFibGVUb0NsYWltBBNpbnZlc3RvclRvdGFsQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUPb3JpZ0ludmVzdEFycmF5BRFJZHhJbnZUb3RhbEFtb3VudAQXaW52ZXN0b3JSZW1haW5pbmdBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ9vcmlnSW52ZXN0QXJyYXkFFUlkeEludlJlbWFpbmluZ0Ftb3VudAQZaW52ZXN0b3JQcmljZUFzc2V0QmFsYW5jZQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFD29yaWdJbnZlc3RBcnJheQUdSWR4SW52Q2xhaW1lZFByaWNlQXNzZXRBbW91bnQEF2ludmVzdG9ySWRvQXNzZXRCYWxhbmNlCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUPb3JpZ0ludmVzdEFycmF5BRtJZHhJbnZDbGFpbWVkSWRvQXNzZXRBbW91bnQEGWludmVzdG9yTGFzdENsYWltZWRIZWlnaHQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ9vcmlnSW52ZXN0QXJyYXkFF0lkeEludkxhc3RDbGFpbWVkSGVpZ2h0BA5uZXdJbnZlc3RBcnJheQkAzAgCCQCkAwEFE2ludmVzdG9yVG90YWxBbW91bnQJAMwIAgIBMAkAzAgCCQCkAwEFGWludmVzdG9yUHJpY2VBc3NldEJhbGFuY2UJAMwIAgkApAMBBRdpbnZlc3Rvcklkb0Fzc2V0QmFsYW5jZQkAzAgCCQCkAwEFGWludmVzdG9yTGFzdENsYWltZWRIZWlnaHQFA25pbAQGdG90YWxzCQEYcmVhZFRvdGFsc0FycmF5T3JEZWZhdWx0AAQRdG90YWxzVG90YWxBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZ0b3RhbHMFEUlkeEludlRvdGFsQW1vdW50BBV0b3RhbHNSZW1haW5pbmdBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZ0b3RhbHMFFUlkeEludlJlbWFpbmluZ0Ftb3VudAQddG90YWxzQ2xhaW1lZFByaWNlQXNzZXRBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZ0b3RhbHMFHUlkeEludkNsYWltZWRQcmljZUFzc2V0QW1vdW50BBt0b3RhbHNDbGFpbWVkSWRvQXNzZXRBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZ0b3RhbHMFG0lkeEludkNsYWltZWRJZG9Bc3NldEFtb3VudAQXdG90YWxzTGFzdENsYWltZWRIZWlnaHQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZ0b3RhbHMFF0lkeEludkxhc3RDbGFpbWVkSGVpZ2h0BBhuZXdUb3RhbHNSZW1haW5pbmdBbW91bnQJAGUCBRV0b3RhbHNSZW1haW5pbmdBbW91bnQFF2ludmVzdG9yUmVtYWluaW5nQW1vdW50BA1uZXdUb3RhbEFycmF5CQDMCAIJAKQDAQURdG90YWxzVG90YWxBbW91bnQJAMwIAgkApAMBBRhuZXdUb3RhbHNSZW1haW5pbmdBbW91bnQJAMwIAgkApAMBBR10b3RhbHNDbGFpbWVkUHJpY2VBc3NldEFtb3VudAkAzAgCCQCkAwEFG3RvdGFsc0NsYWltZWRJZG9Bc3NldEFtb3VudAkAzAgCCQCkAwEFF3RvdGFsc0xhc3RDbGFpbWVkSGVpZ2h0BQNuaWwEF25ld1RvdGFsUmVtYWluaW5nQW1vdW50CQBkAgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEXa2V5VG90YWxSZW1haW5pbmdBbW91bnQAAAAFF2ludmVzdG9yUmVtYWluaW5nQW1vdW50CQDMCAIJAQtTdHJpbmdFbnRyeQIJARprZXlJbnZlc3RvclJlbWFpbmluZ0Ftb3VudAEFDXVzZXJBZGRyZXNzNTgJAKQDAQUXaW52ZXN0b3JSZW1haW5pbmdBbW91bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBF2tleVRvdGFsUmVtYWluaW5nQW1vdW50AAkApAMBBRduZXdUb3RhbFJlbWFpbmluZ0Ftb3VudAkAzAgCCQELVG90YWxzRW50cnkFCQELa2V5SW52ZXN0b3IBBQ11c2VyQWRkcmVzczU4BQ5uZXdJbnZlc3RBcnJheQUKdG90YWxzRGlmZgUUbmV3Q2xhaW1QZXJpb2RIZWlnaHQAAAkAzAgCCQELVG90YWxzRW50cnkFCQEJa2V5VG90YWxzAAUNbmV3VG90YWxBcnJheQUKdG90YWxzRGlmZgUUbmV3Q2xhaW1QZXJpb2RIZWlnaHQAAAUDbmlsCQDMCAIJAQtUb3RhbHNFbnRyeQUJAQtrZXlJbnZlc3RvcgEFDXVzZXJBZGRyZXNzNTgFD29yaWdJbnZlc3RBcnJheQUKdG90YWxzRGlmZgUUbmV3Q2xhaW1QZXJpb2RIZWlnaHQAAAkAzAgCCQELVG90YWxzRW50cnkFCQEJa2V5VG90YWxzAAkBGHJlYWRUb3RhbHNBcnJheU9yRGVmYXVsdAAFCnRvdGFsc0RpZmYFFG5ld0NsYWltUGVyaW9kSGVpZ2h0AAAFA25pbAQYdXBkYXRlZFByaWNlQXNzZXRCYWxhbmNlCQBlAgkAZAIFEXByaWNlQXNzZXRCYWxhbmNlBQlvdXRBbW91bnQFGXBlcmlvZE1pbkF2YWlsYWJsZVRvQ2xhaW0JAM4IAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFGXBlcmlvZE1pbkF2YWlsYWJsZVRvQ2xhaW0FCm91dEFzc2V0SWQJAMwIAgkBDEludGVnZXJFbnRyeQIJARRrZXlQcmljZUFzc2V0QmFsYW5jZQEFDXVzZXJBZGRyZXNzNTgFGHVwZGF0ZWRQcmljZUFzc2V0QmFsYW5jZQUDbmlsBRBsYXN0Q2xhaW1FbnRyaWVzCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQCUCgIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBEGtleUN1cnJlbnRQZXJpb2QABRR1cGRhdGVkQ3VycmVudFBlcmlvZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFGtleVBlcmlvZFN0YXJ0SGVpZ2h0AQUUdXBkYXRlZEN1cnJlbnRQZXJpb2QFC3BlcmlvZFN0YXJ0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQESa2V5UGVyaW9kRW5kSGVpZ2h0AQUUdXBkYXRlZEN1cnJlbnRQZXJpb2QFCXBlcmlvZEVuZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBHmtleVBlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbQIFDnByaWNlQXNzZXRJZDU4BRR1cGRhdGVkQ3VycmVudFBlcmlvZAUidXBkYXRlZFBlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBHWtleVBlcmlvZFVzZXJBdmFpbGFibGVUb0NsYWltAwUOcHJpY2VBc3NldElkNTgFFHVwZGF0ZWRDdXJyZW50UGVyaW9kBQ11c2VyQWRkcmVzczU4BSF1cGRhdGVkUGVyaW9kVXNlckF2YWlsYWJsZVRvQ2xhaW0JAMwIAgkBGkNsYWltT3BlcmF0aW9uSGlzdG9yeUVudHJ5BAUNdXNlckFkZHJlc3M1OAUZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbQUdY2xhaW1lZElkb0Fzc2V0QW1vdW50RnJvbURpZmYIBQFpDXRyYW5zYWN0aW9uSWQFA25pbAUHZW50cmllcwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQccHJpY2VBc3NldEJhbGFuY2VJZG9EZWNpbWFscwkAawMFEXByaWNlQXNzZXRCYWxhbmNlBQZzY2FsZTgJAGwGAAoAAAUScHJpY2VBc3NldERlY2ltYWxzAAAAAAUERE9XTgkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgkAZAIFCW91dEFtb3VudAUccHJpY2VBc3NldEJhbGFuY2VJZG9EZWNpbWFscwUKb3V0QXNzZXRJZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFGtleVByaWNlQXNzZXRCYWxhbmNlAQUNdXNlckFkZHJlc3M1OAAACQDMCAIJAQtUb3RhbHNFbnRyeQUJAQtrZXlJbnZlc3RvcgEFDXVzZXJBZGRyZXNzNTgFD29yaWdJbnZlc3RBcnJheQUKdG90YWxzRGlmZgUUbmV3Q2xhaW1QZXJpb2RIZWlnaHQFEXByaWNlQXNzZXRCYWxhbmNlCQDMCAIJAQtUb3RhbHNFbnRyeQUJAQlrZXlUb3RhbHMACQEYcmVhZFRvdGFsc0FycmF5T3JEZWZhdWx0AAUKdG90YWxzRGlmZgUUbmV3Q2xhaW1QZXJpb2RIZWlnaHQFEXByaWNlQXNzZXRCYWxhbmNlCQDMCAIJARpDbGFpbU9wZXJhdGlvbkhpc3RvcnlFbnRyeQQFDXVzZXJBZGRyZXNzNTgFGmNsYWltZWRQcmljZUFtb3VudEZyb21EaWZmCQBkAgUdY2xhaW1lZElkb0Fzc2V0QW1vdW50RnJvbURpZmYFHHByaWNlQXNzZXRCYWxhbmNlSWRvRGVjaW1hbHMIBQFpDXRyYW5zYWN0aW9uSWQFA25pbAUEdW5pdAUHZW50cmllcwFpARJjbGVhblJlbWFpbmdBbW91bnQBDXVzZXJBZGRyZXNzNTgEDnByaWNlQXNzZXRJZDU4CQCRAwIJAQ9yZWFkQ29uZmlnQXJyYXkABRJJZHhDZmdQcmljZUFzc2V0SWQEDmV2YWx1YXRlUmVzdWx0CQC1CQIJAQhhc1N0cmluZwEJAPwHBAUEdGhpcwINY2xhaW1SRUFET05MWQkAzAgCBQ5wcmljZUFzc2V0SWQ1OAkAzAgCBQ11c2VyQWRkcmVzczU4BQNuaWwFA25pbAUDU0VQAwkAAAIFDmV2YWx1YXRlUmVzdWx0BQ5ldmFsdWF0ZVJlc3VsdAQbYXZhaWxhYmxlUHJpY2VBbW91bnRUb0NsYWltCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUOZXZhbHVhdGVSZXN1bHQAAgQUY2hlY2tVbmNsYWltZWRBc3NldHMDCQAAAgUbYXZhaWxhYmxlUHJpY2VBbW91bnRUb0NsYWltAAAGCQEIdGhyb3dFcnIBAhp1c2VyIGhhdmUgdW5jbGFpbWVkIGFzc2V0cwMJAAACBRRjaGVja1VuY2xhaW1lZEFzc2V0cwUUY2hlY2tVbmNsYWltZWRBc3NldHMECGludmVzdG9yCQC1CQIJAQV2YWx1ZQEJAKIIAQkBC2tleUludmVzdG9yAQUNdXNlckFkZHJlc3M1OAUDU0VQBBNpbnZlc3RvclRvdGFsQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIaW52ZXN0b3IFEUlkeEludlRvdGFsQW1vdW50BBdpbnZlc3RvclJlbWFpbmluZ0Ftb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGludmVzdG9yBRVJZHhJbnZSZW1haW5pbmdBbW91bnQEGWludmVzdG9yUHJpY2VBc3NldEJhbGFuY2UJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhpbnZlc3RvcgUdSWR4SW52Q2xhaW1lZFByaWNlQXNzZXRBbW91bnQEF2ludmVzdG9ySWRvQXNzZXRCYWxhbmNlCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIaW52ZXN0b3IFG0lkeEludkNsYWltZWRJZG9Bc3NldEFtb3VudAQZaW52ZXN0b3JMYXN0Q2xhaW1lZEhlaWdodAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGludmVzdG9yBRdJZHhJbnZMYXN0Q2xhaW1lZEhlaWdodAQcaW52ZXN0b3JSZW1haW5pbmdBbW91bnRDaGVjawMJAQIhPQIFF2ludmVzdG9yUmVtYWluaW5nQW1vdW50AAAGCQEIdGhyb3dFcnIBAiRpbnZlc3RvclJlbWFpbmluZ0Ftb3VudCBhbHJlYWR5IHplcm8DCQAAAgUcaW52ZXN0b3JSZW1haW5pbmdBbW91bnRDaGVjawUcaW52ZXN0b3JSZW1haW5pbmdBbW91bnRDaGVjawQLbmV3SW52ZXN0b3IJALkJAgkAzAgCAgolZCVkJWQlZCVkCQDMCAIJAKQDAQUTaW52ZXN0b3JUb3RhbEFtb3VudAkAzAgCAgEwCQDMCAIJAKQDAQUZaW52ZXN0b3JQcmljZUFzc2V0QmFsYW5jZQkAzAgCCQCkAwEFF2ludmVzdG9ySWRvQXNzZXRCYWxhbmNlCQDMCAIJAKQDAQUZaW52ZXN0b3JMYXN0Q2xhaW1lZEhlaWdodAUDbmlsBQNTRVAEBnRvdGFscwkAtQkCCQEFdmFsdWUBCQCiCAEJAQlrZXlUb3RhbHMABQNTRVAEEXRvdGFsc1RvdGFsQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGdG90YWxzBRFJZHhJbnZUb3RhbEFtb3VudAQVdG90YWxzUmVtYWluaW5nQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGdG90YWxzBRVJZHhJbnZSZW1haW5pbmdBbW91bnQEHXRvdGFsc0NsYWltZWRQcmljZUFzc2V0QW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGdG90YWxzBR1JZHhJbnZDbGFpbWVkUHJpY2VBc3NldEFtb3VudAQbdG90YWxzQ2xhaW1lZElkb0Fzc2V0QW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGdG90YWxzBRtJZHhJbnZDbGFpbWVkSWRvQXNzZXRBbW91bnQEF3RvdGFsc0xhc3RDbGFpbWVkSGVpZ2h0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGdG90YWxzBRdJZHhJbnZMYXN0Q2xhaW1lZEhlaWdodAQJbmV3VG90YWxzCQC5CQIJAMwIAgIKJWQlZCVkJWQlZAkAzAgCCQCkAwEFEXRvdGFsc1RvdGFsQW1vdW50CQDMCAIJAKQDAQkAZQIFFXRvdGFsc1JlbWFpbmluZ0Ftb3VudAUXaW52ZXN0b3JSZW1haW5pbmdBbW91bnQJAMwIAgkApAMBBR10b3RhbHNDbGFpbWVkUHJpY2VBc3NldEFtb3VudAkAzAgCCQCkAwEFG3RvdGFsc0NsYWltZWRJZG9Bc3NldEFtb3VudAkAzAgCCQCkAwEFF3RvdGFsc0xhc3RDbGFpbWVkSGVpZ2h0BQNuaWwFA1NFUAQXbmV3VG90YWxSZW1haW5pbmdBbW91bnQJAGQCCQELdmFsdWVPckVsc2UCCQCfCAEJARdrZXlUb3RhbFJlbWFpbmluZ0Ftb3VudAAAAAUXaW52ZXN0b3JSZW1haW5pbmdBbW91bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBGmtleUludmVzdG9yUmVtYWluaW5nQW1vdW50AQUNdXNlckFkZHJlc3M1OAkApAMBBRdpbnZlc3RvclJlbWFpbmluZ0Ftb3VudAkAzAgCCQELU3RyaW5nRW50cnkCCQEXa2V5VG90YWxSZW1haW5pbmdBbW91bnQACQCkAwEFF25ld1RvdGFsUmVtYWluaW5nQW1vdW50CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQtrZXlJbnZlc3RvcgEFDXVzZXJBZGRyZXNzNTgFC25ld0ludmVzdG9yCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQlrZXlUb3RhbHMABQluZXdUb3RhbHMFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ1jbGFpbVJFQURPTkxZAhBjbGFpbWVkQXNzZXRJZDU4DXVzZXJBZGRyZXNzNTgEEGNsYWltUmVzdWx0VHVwbGUJAQ1pbnRlcm5hbENsYWltAwUQY2xhaW1lZEFzc2V0SWQ1OAkBEUBleHRyTmF0aXZlKDEwNjIpAQUNdXNlckFkZHJlc3M1OAkA2QQBAgAECnRvdGFsc0RpZmYIBRBjbGFpbVJlc3VsdFR1cGxlAl8xBAlvdXRBbW91bnQIBRBjbGFpbVJlc3VsdFR1cGxlAl8yBApvdXRBc3NldElkCAUQY2xhaW1SZXN1bHRUdXBsZQJfMwQPb3JpZ0ludmVzdEFycmF5CAUQY2xhaW1SZXN1bHRUdXBsZQJfNAQUbmV3Q2xhaW1QZXJpb2RIZWlnaHQIBRBjbGFpbVJlc3VsdFR1cGxlAl81BBVhdmFpbGFibGVUb0NsYWltQXJyYXkIBRBjbGFpbVJlc3VsdFR1cGxlAl82BBthdmFpbGFibGVQcmljZUFtb3VudFRvQ2xhaW0JAJEDAgUVYXZhaWxhYmxlVG9DbGFpbUFycmF5AAAEGWF2YWlsYWJsZUlkb0Ftb3VudFRvQ2xhaW0JAJEDAgUVYXZhaWxhYmxlVG9DbGFpbUFycmF5AAEJAJQKAgUDbmlsCQC5CQIJAMwIAgIGJXMlZCVkCQDMCAIFDXVzZXJBZGRyZXNzNTgJAMwIAgkApAMBBRthdmFpbGFibGVQcmljZUFtb3VudFRvQ2xhaW0JAMwIAgkApAMBBRlhdmFpbGFibGVJZG9BbW91bnRUb0NsYWltBQNuaWwFA1NFUAFpAQ9jbGFpbVYyUkVBRE9OTFkCEGNsYWltZWRBc3NldElkNTgNdXNlckFkZHJlc3M1OAQQY2xhaW1SZXN1bHRUdXBsZQkBDWludGVybmFsQ2xhaW0DBRBjbGFpbWVkQXNzZXRJZDU4CQERQGV4dHJOYXRpdmUoMTA2MikBBQ11c2VyQWRkcmVzczU4CQDZBAECAAQKdG90YWxzRGlmZggFEGNsYWltUmVzdWx0VHVwbGUCXzEECW91dEFtb3VudAgFEGNsYWltUmVzdWx0VHVwbGUCXzIECm91dEFzc2V0SWQIBRBjbGFpbVJlc3VsdFR1cGxlAl8zBA9vcmlnSW52ZXN0QXJyYXkIBRBjbGFpbVJlc3VsdFR1cGxlAl80BBRuZXdDbGFpbVBlcmlvZEhlaWdodAgFEGNsYWltUmVzdWx0VHVwbGUCXzUEFWF2YWlsYWJsZVRvQ2xhaW1BcnJheQgFEGNsYWltUmVzdWx0VHVwbGUCXzYEG2F2YWlsYWJsZVByaWNlQW1vdW50VG9DbGFpbQkAkQMCBRVhdmFpbGFibGVUb0NsYWltQXJyYXkAAAQZYXZhaWxhYmxlSWRvQW1vdW50VG9DbGFpbQkAkQMCBRVhdmFpbGFibGVUb0NsYWltQXJyYXkAAQQIY2ZnQXJyYXkJAQ9yZWFkQ29uZmlnQXJyYXkABA5wcmljZUFzc2V0SWQ1OAkAkQMCBQhjZmdBcnJheQUSSWR4Q2ZnUHJpY2VBc3NldElkBBFwcmljZUFzc2V0QmFsYW5jZQkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEUa2V5UHJpY2VBc3NldEJhbGFuY2UBBQ11c2VyQWRkcmVzczU4AAAEHHByaWNlQXNzZXRCYWxhbmNlSWRvRGVjaW1hbHMJAGgCBRFwcmljZUFzc2V0QmFsYW5jZQBkBC5hdmFpbGFibGVJZG9BbW91bnRUb0NsYWltV2l0aFByaWNlQXNzZXRCYWxhbmNlCQBkAgUZYXZhaWxhYmxlSWRvQW1vdW50VG9DbGFpbQUccHJpY2VBc3NldEJhbGFuY2VJZG9EZWNpbWFscwQNJHQwMzM4MzMzNDI0NQkBD2ludGVybmFsQ2xhaW1WMgQFDnByaWNlQXNzZXRJZDU4BQ11c2VyQWRkcmVzczU4BQlvdXRBbW91bnQJAJEDAgUKdG90YWxzRGlmZgUiSWR4RGlmZkNsYWltZWRQcmljZUFtb3VudEluY3JlbWVudAQZcGVyaW9kTWluQXZhaWxhYmxlVG9DbGFpbQgFDSR0MDMzODMzMzQyNDUCXzEEG3BlcmlvZFRvdGFsQXZhaWxhYmxlVG9DbGFpbQgFDSR0MDMzODMzMzQyNDUCXzIEGnBlcmlvZFVzZXJBdmFpbGFibGVUb0NsYWltCAUNJHQwMzM4MzMzNDI0NQJfMwQZdG90YWxVc2VyQXZhaWxhYmxlVG9DbGFpbQgFDSR0MDMzODMzMzQyNDUCXzQEHHVzZHRQcmljZUFzc2V0QWxsb3dhYmxlUmF0aW8IBQ0kdDAzMzgzMzM0MjQ1Al81BBpjdXJyZW50VXNkdFByaWNlQXNzZXRSYXRpbwgFDSR0MDMzODMzMzQyNDUCXzYEE2VuZFBlcmlvZEJsb2Nrc0xlZnQIBQ0kdDAzMzgzMzM0MjQ1Al83BBR1cGRhdGVkQ3VycmVudFBlcmlvZAgFDSR0MDMzODMzMzQyNDUCXzgEC3BlcmlvZFN0YXJ0CAUNJHQwMzM4MzMzNDI0NQJfOQQJcGVyaW9kRW5kCAUNJHQwMzM4MzMzNDI0NQNfMTAEFmN1cnJlbnRQZXJpb2RFbmRIZWlnaHQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBEmtleVBlcmlvZEVuZEhlaWdodAEFFHVwZGF0ZWRDdXJyZW50UGVyaW9kAAAEGnVzZXJUb3RhbFByaWNlQXNzZXRDbGFpbWVkCQBlAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIJARdyZWFkSW52ZXN0b3JBcnJheU9yRmFpbAEFDXVzZXJBZGRyZXNzNTgFHUlkeEludkNsYWltZWRQcmljZUFzc2V0QW1vdW50BRFwcmljZUFzc2V0QmFsYW5jZQQMcmVzdWx0U3RyaW5nAwkAZgIFBmhlaWdodAUWY3VycmVudFBlcmlvZEVuZEhlaWdodAQMcGVyaW9kTGVuZ2h0CQEFdmFsdWUBCQCfCAEJAQ9rZXlQZXJpb2RMZW5ndGgABBN1c2VyUGVyaW9kQWxsb3dhbmNlCQEFdmFsdWUBCQCfCAEJARZrZXlVc2VyUGVyaW9kQWxsb3dhbmNlAQUOcHJpY2VBc3NldElkNTgEFHRvdGFsUGVyaW9kQWxsb3dhbmNlCQEFdmFsdWUBCQCfCAEJARdrZXlUb3RhbFBlcmlvZEFsbG93YW5jZQEFDnByaWNlQXNzZXRJZDU4CQC5CQIJAMwIAgIMJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQUuYXZhaWxhYmxlSWRvQW1vdW50VG9DbGFpbVdpdGhQcmljZUFzc2V0QmFsYW5jZQkAzAgCCQCkAwEFE3VzZXJQZXJpb2RBbGxvd2FuY2UJAMwIAgkApAMBBRR0b3RhbFBlcmlvZEFsbG93YW5jZQkAzAgCCQCkAwEFHHVzZHRQcmljZUFzc2V0QWxsb3dhYmxlUmF0aW8JAMwIAgkApAMBBRpjdXJyZW50VXNkdFByaWNlQXNzZXRSYXRpbwkAzAgCCQCkAwEFDHBlcmlvZExlbmdodAkAzAgCCQCkAwEFGnVzZXJUb3RhbFByaWNlQXNzZXRDbGFpbWVkBQNuaWwFA1NFUAkAuQkCCQDMCAICDCVkJWQlZCVkJWQlZAkAzAgCCQCkAwEFLmF2YWlsYWJsZUlkb0Ftb3VudFRvQ2xhaW1XaXRoUHJpY2VBc3NldEJhbGFuY2UJAMwIAgkApAMBBRlwZXJpb2RNaW5BdmFpbGFibGVUb0NsYWltCQDMCAIJAKQDAQUbcGVyaW9kVG90YWxBdmFpbGFibGVUb0NsYWltCQDMCAIJAKQDAQUcdXNkdFByaWNlQXNzZXRBbGxvd2FibGVSYXRpbwkAzAgCCQCkAwEFGmN1cnJlbnRVc2R0UHJpY2VBc3NldFJhdGlvCQDMCAIJAKQDAQUTZW5kUGVyaW9kQmxvY2tzTGVmdAkAzAgCCQCkAwEFGnVzZXJUb3RhbFByaWNlQXNzZXRDbGFpbWVkBQNuaWwFA1NFUAkAlAoCBQNuaWwFDHJlc3VsdFN0cmluZwECdHgBBnZlcmlmeQAED3RhcmdldFB1YmxpY0tleQQHJG1hdGNoMAkBFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQAAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAnBrBQckbWF0Y2gwBQJwawMJAAECBQckbWF0Y2gwAgRVbml0CAUCdHgPc2VuZGVyUHVibGljS2V5CQACAQILTWF0Y2ggZXJyb3IJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFD3RhcmdldFB1YmxpY0tleU/2roA=", "height": 3637204, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: J6YGvoLyetNcouWxfyCCLrJy5mDjE9EnDLH7rWSRcLjU Next: 4mZvTvca21oAuYfHbZkLXxKojPbmLdc1yt3irigtfuSV Diff:
OldNewDifferences
140140 func keyManagerPublicKey () = "%s__managerPublicKey"
141141
142142
143-func keyPendingManagerPublicKey () = "%s__pendingManagerPublicKey"
143+func keyManagerVaultAddress () = "%s__managerVaultAddress"
144144
145145
146146 func readConfigArray () = split(getStringOrFail(keyConfig()), SEP)
156156
157157
158158 func readInvestorArrayOrFail (userAddress) = split(getStringOrFail(keyInvestor(userAddress)), SEP)
159+
160+
161+func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) {
162+ case s: String =>
163+ addressFromStringValue(s)
164+ case _ =>
165+ this
166+}
159167
160168
161169 let IdxDiffTotalIncrement = 0
250258 let periodLength = value(getInteger(keyPeriodLength()))
251259 let currentPeriod = valueOrElse(getInteger(keyCurrentPeriod()), 0)
252260 let zeroPeriodEndHeighIsDefined = isDefined(getInteger(keyPeriodEndHeight(0)))
253- let $t01298714857 = if ((currentPeriod > 0))
261+ let $t01313615006 = if ((currentPeriod > 0))
254262 then {
255263 let lastPeriodStartHeight = value(getInteger(keyPeriodStartHeight(currentPeriod)))
256264 let lastPeriodEndHeight = value(getInteger(keyPeriodEndHeight(currentPeriod)))
257- let $t01324713952 = if ((height > lastPeriodEndHeight))
265+ let $t01339614101 = if ((height > lastPeriodEndHeight))
258266 then {
259267 let updatedCurrentPeriod = (currentPeriod + 1)
260268 let periodStart = if ((height > (lastPeriodEndHeight + periodLength)))
269277 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
270278 }
271279 else $Tuple3(currentPeriod, lastPeriodStartHeight, lastPeriodEndHeight)
272- let updatedCurrentPeriod = $t01324713952._1
273- let periodStart = $t01324713952._2
274- let periodEnd = $t01324713952._3
280+ let updatedCurrentPeriod = $t01339614101._1
281+ let periodStart = $t01339614101._2
282+ let periodEnd = $t01339614101._3
275283 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
276284 }
277285 else if (zeroPeriodEndHeighIsDefined)
278286 then {
279287 let zeroPeriodStartHeight = value(getInteger(keyPeriodStartHeight(0)))
280288 let zeroPeriodEndHeight = value(getInteger(keyPeriodEndHeight(0)))
281- let $t01420714589 = if ((height > zeroPeriodEndHeight))
289+ let $t01435614738 = if ((height > zeroPeriodEndHeight))
282290 then {
283291 let updatedCurrentPeriod = (currentPeriod + 1)
284292 let periodStart = (zeroPeriodEndHeight + 1)
286294 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
287295 }
288296 else $Tuple3(currentPeriod, zeroPeriodStartHeight, zeroPeriodEndHeight)
289- let updatedCurrentPeriod = $t01420714589._1
290- let periodStart = $t01420714589._2
291- let periodEnd = $t01420714589._3
297+ let updatedCurrentPeriod = $t01435614738._1
298+ let periodStart = $t01435614738._2
299+ let periodEnd = $t01435614738._3
292300 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
293301 }
294302 else $Tuple3(currentPeriod, valueOrElse(getInteger(keyPeriodStartHeight(currentPeriod)), height), valueOrElse(getInteger(keyPeriodEndHeight(currentPeriod)), ((height + periodLength) - 1)))
295- let updatedCurrentPeriod = $t01298714857._1
296- let periodStart = $t01298714857._2
297- let periodEnd = $t01298714857._3
303+ let updatedCurrentPeriod = $t01313615006._1
304+ let periodStart = $t01313615006._2
305+ let periodEnd = $t01313615006._3
298306 let periodTotalAvailableToClaim = valueOrElse(getInteger(keyPeriodTotalAvailableToClaim(priceAssetId58, updatedCurrentPeriod)), totalPeriodPriceAssetAllowance)
299307 let periodUserAvailableToClaim = valueOrElse(getInteger(keyPeriodUserAvailableToClaim(priceAssetId58, updatedCurrentPeriod, userAddress58)), userPeriodPriceAssetAllowance)
300308 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
301309 let periodMinAvailableToClaim = min([(outAmount + priceAssetBalance), periodTotalAvailableToClaim, periodUserAvailableToClaim])
302310 let usdtPriceAssetAllowableRatio = value(getInteger(keyUsdtPriceAssetAllowableRatio()))
303311 let putOneTknV2PriceAssetAmount = scale8
304- let $t01561215865 = {
312+ let $t01576116014 = {
305313 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "putOneTknV2WithoutTakeFeeREADONLY", [putOneTknV2PriceAssetAmount, priceAssetId58], nil)
306314 if ($isInstanceOf(@, "(Int, Int, Int)"))
307315 then @
308316 else throw(($getType(@) + " couldn't be cast to (Int, Int, Int)"))
309317 }
310- if (($t01561215865 == $t01561215865))
318+ if (($t01576116014 == $t01576116014))
311319 then {
312- let bonus = $t01561215865._3
313- let feeAmount = $t01561215865._2
314- let lpAmount = $t01561215865._1
320+ let bonus = $t01576116014._3
321+ let feeAmount = $t01576116014._2
322+ let lpAmount = $t01576116014._1
315323 let usdtAssetId = value(getString(keyUsdtAssetId()))
316- let $t01592716145 = {
324+ let $t01607616294 = {
317325 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "getOneTknV2READONLY", [usdtAssetId, lpAmount], nil)
318326 if ($isInstanceOf(@, "(Int, Int)"))
319327 then @
320328 else throw(($getType(@) + " couldn't be cast to (Int, Int)"))
321329 }
322- if (($t01592716145 == $t01592716145))
330+ if (($t01607616294 == $t01607616294))
323331 then {
324- let getOneTknV2FeeAmount = $t01592716145._2
325- let usdtAmount = $t01592716145._1
332+ let getOneTknV2FeeAmount = $t01607616294._2
333+ let usdtAmount = $t01607616294._1
326334 let currentUsdtPriceAssetRatio = fraction(putOneTknV2PriceAssetAmount, scale8, usdtAmount)
327335 let endPeriodBlocksLeft = (periodEnd - height)
328336 $Tuple10(periodMinAvailableToClaim, periodTotalAvailableToClaim, periodUserAvailableToClaim, totalUserAvailableToClaim, usdtPriceAssetAllowableRatio, currentUsdtPriceAssetRatio, endPeriodBlocksLeft, updatedCurrentPeriod, periodStart, periodEnd)
333341 }
334342
335343
336-func managerPublicKeyOrUnit () = match getString(keyManagerPublicKey()) {
337- case s: String =>
338- fromBase58String(s)
339- case _: Unit =>
340- unit
341- case _ =>
342- throw("Match error")
343-}
344-
345-
346-func pendingManagerPublicKeyOrUnit () = match getString(keyPendingManagerPublicKey()) {
347- case s: String =>
348- fromBase58String(s)
349- case _: Unit =>
350- unit
351- case _ =>
352- throw("Match error")
353-}
344+func managerPublicKeyOrUnit () = {
345+ let managerVaultAddress = getManagerVaultAddressOrThis()
346+ match getString(managerVaultAddress, keyManagerPublicKey()) {
347+ case s: String =>
348+ fromBase58String(s)
349+ case _: Unit =>
350+ unit
351+ case _ =>
352+ throw("Match error")
353+ }
354+ }
354355
355356
356357 func mustManager (i) = {
466467 let priceAssetDecimals = value(assetInfo(fromBase58String(priceAssetId58))).decimals
467468 let entries = if ((claimedAssetId58 == priceAssetId58))
468469 then {
469- let $t02205422498 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
470- let periodMinAvailableToClaim = $t02205422498._1
471- let periodTotalAvailableToClaim = $t02205422498._2
472- let periodUserAvailableToClaim = $t02205422498._3
473- let totalUserAvailableToClaim = $t02205422498._4
474- let usdtPriceAssetAllowableRatio = $t02205422498._5
475- let currentUsdtPriceAssetRatio = $t02205422498._6
476- let endPeriodBlocksLeft = $t02205422498._7
477- let updatedCurrentPeriod = $t02205422498._8
478- let periodStart = $t02205422498._9
479- let periodEnd = $t02205422498._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
480481 let checks = [if ((periodUserAvailableToClaim > 0))
481482 then true
482483 else throwErr("unavailable to claim because user period allowance reached"), if ((periodTotalAvailableToClaim > 0))
611612 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
612613 let priceAssetBalanceIdoDecimals = (priceAssetBalance * 100)
613614 let availableIdoAmountToClaimWithPriceAssetBalance = (availableIdoAmountToClaim + priceAssetBalanceIdoDecimals)
614- let $t03374934161 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
615- let periodMinAvailableToClaim = $t03374934161._1
616- let periodTotalAvailableToClaim = $t03374934161._2
617- let periodUserAvailableToClaim = $t03374934161._3
618- let totalUserAvailableToClaim = $t03374934161._4
619- let usdtPriceAssetAllowableRatio = $t03374934161._5
620- let currentUsdtPriceAssetRatio = $t03374934161._6
621- let endPeriodBlocksLeft = $t03374934161._7
622- let updatedCurrentPeriod = $t03374934161._8
623- let periodStart = $t03374934161._9
624- let periodEnd = $t03374934161._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
625626 let currentPeriodEndHeight = valueOrElse(getInteger(keyPeriodEndHeight(updatedCurrentPeriod)), 0)
626627 let userTotalPriceAssetClaimed = (parseIntValue(readInvestorArrayOrFail(userAddress58)[IdxInvClaimedPriceAssetAmount]) - priceAssetBalance)
627628 let resultString = if ((height > currentPeriodEndHeight))
633634 }
634635 else makeString(["%d%d%d%d%d%d", toString(availableIdoAmountToClaimWithPriceAssetBalance), toString(periodMinAvailableToClaim), toString(periodTotalAvailableToClaim), toString(usdtPriceAssetAllowableRatio), toString(currentUsdtPriceAssetRatio), toString(endPeriodBlocksLeft), toString(userTotalPriceAssetClaimed)], SEP)
635636 $Tuple2(nil, resultString)
636- }
637-
638-
639-
640-@Callable(i)
641-func setManager (pendingManagerPublicKey) = {
642- let checkCaller = mustManager(i)
643- if ((checkCaller == checkCaller))
644- then {
645- let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
646- if ((checkManagerPublicKey == checkManagerPublicKey))
647- then [StringEntry(keyPendingManagerPublicKey(), pendingManagerPublicKey)]
648- else throw("Strict value is not equal to itself.")
649- }
650- else throw("Strict value is not equal to itself.")
651- }
652-
653-
654-
655-@Callable(i)
656-func confirmManager () = {
657- let pm = pendingManagerPublicKeyOrUnit()
658- let hasPM = if (isDefined(pm))
659- then true
660- else throw("No pending manager")
661- if ((hasPM == hasPM))
662- then {
663- let checkPM = if ((i.callerPublicKey == value(pm)))
664- then true
665- else throw("You are not pending manager")
666- if ((checkPM == checkPM))
667- then [StringEntry(keyManagerPublicKey(), toBase58String(value(pm))), DeleteEntry(keyPendingManagerPublicKey())]
668- else throw("Strict value is not equal to itself.")
669- }
670- else throw("Strict value is not equal to itself.")
671637 }
672638
673639
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
143-func keyPendingManagerPublicKey () = "%s__pendingManagerPublicKey"
143+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)
159+
160+
161+func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) {
162+ case s: String =>
163+ addressFromStringValue(s)
164+ case _ =>
165+ this
166+}
159167
160168
161169 let IdxDiffTotalIncrement = 0
162170
163171 let IdxDiffRemainingPriceAmountIncrement = 1
164172
165173 let IdxDiffClaimedPriceAmountIncrement = 2
166174
167175 let IdxDiffClaimedIdoAssetAmountIncrement = 3
168176
169177 func TotalsEntry (key,origArray,incrementDiff,newLastClaimedHeight,priceAssetBalance) = {
170178 let totalAmount = parseIntValue(origArray[IdxInvTotalAmount])
171179 let remainingAmount = parseIntValue(origArray[IdxInvRemainingAmount])
172180 let claimedPriceAssetAmount = parseIntValue(origArray[IdxInvClaimedPriceAssetAmount])
173181 let claimedIdoAssetAmount = parseIntValue(origArray[IdxInvClaimedIdoAssetAmount])
174182 let lastClaimedHeight = parseIntValue(origArray[IdxInvLastClaimedHeight])
175183 let newTotalAmount = (totalAmount + incrementDiff[IdxDiffTotalIncrement])
176184 let newRemainingAmount = (remainingAmount + incrementDiff[IdxDiffRemainingPriceAmountIncrement])
177185 let cfgArray = readConfigArray()
178186 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
179187 let priceAssetDecimals = value(assetInfo(fromBase58String(priceAssetId58))).decimals
180188 let priceAssetBalancePriceAssetDecimals = fraction(priceAssetBalance, scale8, pow(10, 0, priceAssetDecimals, 0, 0, DOWN))
181189 let newClaimedPriceAssetAmount = ((claimedPriceAssetAmount + incrementDiff[IdxDiffClaimedPriceAmountIncrement]) - priceAssetBalance)
182190 let newClaimedIdoAssetAmount = ((claimedIdoAssetAmount + incrementDiff[IdxDiffClaimedIdoAssetAmountIncrement]) + priceAssetBalancePriceAssetDecimals)
183191 let entries = if ((0 > newRemainingAmount))
184192 then {
185193 let diff = ((newTotalAmount - newClaimedPriceAssetAmount) - newClaimedIdoAssetAmount)
186194 let newLogicRemainingAmount = if ((0 > diff))
187195 then 0
188196 else diff
189197 StringEntry(key, formatInvestor(newTotalAmount, newLogicRemainingAmount, newClaimedPriceAssetAmount, newClaimedIdoAssetAmount, newLastClaimedHeight))
190198 }
191199 else StringEntry(key, formatInvestor(newTotalAmount, newRemainingAmount, newClaimedPriceAssetAmount, newClaimedIdoAssetAmount, newLastClaimedHeight))
192200 entries
193201 }
194202
195203
196204 func InvestOperationHistoryEntry (userAddress,priceAssetAmount,idoAssetAmount,txId) = StringEntry(keyOperationHistoryRecord("invest", userAddress, toBase58String(txId)), formatHistoryRecord(priceAssetAmount, idoAssetAmount))
197205
198206
199207 func ClaimOperationHistoryEntry (userAddress,priceAssetAmount,idoAssetAmount,txId) = StringEntry(keyOperationHistoryRecord("claim", userAddress, toBase58String(txId)), formatHistoryRecord(priceAssetAmount, idoAssetAmount))
200208
201209
202210 func internalClaim (claimedAssetId58,userAddress,txId) = {
203211 let cfgArray = readConfigArray()
204212 let claimStart = parseIntValue(cfgArray[IdxCfgClaimStart])
205213 let claimDuration = parseIntValue(cfgArray[IdxCfgClaimDuration])
206214 let claimEnd = (claimStart + claimDuration)
207215 let price = parseIntValue(cfgArray[IdxCfgPrice])
208216 let priceMult = parseIntValue(cfgArray[IdxCfgPriceMult])
209217 let idoAssetId58 = cfgArray[IdxCfgIdoAssetId]
210218 let idoAssetId = fromBase58String(idoAssetId58)
211219 let idoAssetMult = parseIntValue(cfgArray[IdxCfgIdoAssetMult])
212220 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
213221 let priceAssetId = fromBase58String(priceAssetId58)
214222 let priceAssetMult = parseIntValue(cfgArray[IdxCfgPriceAssetMult])
215223 let userAddress58 = toString(userAddress)
216224 let origInvestArray = readInvestorArrayOrFail(userAddress58)
217225 let investTotalAmount = parseIntValue(origInvestArray[IdxInvTotalAmount])
218226 let investLastClaimedHeightTMP = parseIntValue(origInvestArray[IdxInvLastClaimedHeight])
219227 let investLastClaimedHeight = if ((claimStart >= investLastClaimedHeightTMP))
220228 then claimStart
221229 else investLastClaimedHeightTMP
222230 let newClaimPeriodHeight = if ((height > claimEnd))
223231 then claimEnd
224232 else if ((claimStart > height))
225233 then claimStart
226234 else height
227235 let claimingBlocks = (newClaimPeriodHeight - investLastClaimedHeight)
228236 let claimingPriceAssetAmount = fraction(investTotalAmount, claimingBlocks, claimDuration)
229237 let claimingIdoAssetAmount = convertPriceAssetIntoIdoAsset(claimingPriceAssetAmount, priceAssetMult, price, priceMult, idoAssetMult)
230238 let isUSDN = (claimedAssetId58 == priceAssetId58)
231239 let isUSDNClaimDisabled = valueOrElse(getBoolean(keyUSDNClaimDisabled()), false)
232240 let checks = [if (!(if (isUSDN)
233241 then isUSDNClaimDisabled
234242 else false))
235243 then true
236244 else throw("USDN claim is disabled")]
237245 if ((checks == checks))
238246 then if ((claimedAssetId58 == priceAssetId58))
239247 then $Tuple6([0, -(claimingPriceAssetAmount), claimingPriceAssetAmount, 0], claimingPriceAssetAmount, priceAssetId, origInvestArray, newClaimPeriodHeight, [claimingPriceAssetAmount, claimingIdoAssetAmount])
240248 else if ((claimedAssetId58 == idoAssetId58))
241249 then $Tuple6([0, -(claimingPriceAssetAmount), 0, claimingIdoAssetAmount], claimingIdoAssetAmount, idoAssetId, origInvestArray, newClaimPeriodHeight, [claimingPriceAssetAmount, claimingIdoAssetAmount])
242250 else throw(("unsupported assetId: " + claimedAssetId58))
243251 else throw("Strict value is not equal to itself.")
244252 }
245253
246254
247255 func internalClaimV2 (priceAssetId58,userAddress58,outAmount,totalUserAvailableToClaim) = {
248256 let totalPeriodPriceAssetAllowance = value(getInteger(keyTotalPeriodAllowance(priceAssetId58)))
249257 let userPeriodPriceAssetAllowance = value(getInteger(keyUserPeriodAllowance(priceAssetId58)))
250258 let periodLength = value(getInteger(keyPeriodLength()))
251259 let currentPeriod = valueOrElse(getInteger(keyCurrentPeriod()), 0)
252260 let zeroPeriodEndHeighIsDefined = isDefined(getInteger(keyPeriodEndHeight(0)))
253- let $t01298714857 = if ((currentPeriod > 0))
261+ let $t01313615006 = if ((currentPeriod > 0))
254262 then {
255263 let lastPeriodStartHeight = value(getInteger(keyPeriodStartHeight(currentPeriod)))
256264 let lastPeriodEndHeight = value(getInteger(keyPeriodEndHeight(currentPeriod)))
257- let $t01324713952 = if ((height > lastPeriodEndHeight))
265+ let $t01339614101 = if ((height > lastPeriodEndHeight))
258266 then {
259267 let updatedCurrentPeriod = (currentPeriod + 1)
260268 let periodStart = if ((height > (lastPeriodEndHeight + periodLength)))
261269 then {
262270 let blocksToLastPeriodStart = ((height - lastPeriodEndHeight) % periodLength)
263271 if ((blocksToLastPeriodStart == 0))
264272 then ((height - periodLength) + 1)
265273 else (height - blocksToLastPeriodStart)
266274 }
267275 else (lastPeriodEndHeight + 1)
268276 let periodEnd = ((periodStart + periodLength) - 1)
269277 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
270278 }
271279 else $Tuple3(currentPeriod, lastPeriodStartHeight, lastPeriodEndHeight)
272- let updatedCurrentPeriod = $t01324713952._1
273- let periodStart = $t01324713952._2
274- let periodEnd = $t01324713952._3
280+ let updatedCurrentPeriod = $t01339614101._1
281+ let periodStart = $t01339614101._2
282+ let periodEnd = $t01339614101._3
275283 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
276284 }
277285 else if (zeroPeriodEndHeighIsDefined)
278286 then {
279287 let zeroPeriodStartHeight = value(getInteger(keyPeriodStartHeight(0)))
280288 let zeroPeriodEndHeight = value(getInteger(keyPeriodEndHeight(0)))
281- let $t01420714589 = if ((height > zeroPeriodEndHeight))
289+ let $t01435614738 = if ((height > zeroPeriodEndHeight))
282290 then {
283291 let updatedCurrentPeriod = (currentPeriod + 1)
284292 let periodStart = (zeroPeriodEndHeight + 1)
285293 let periodEnd = ((periodStart + periodLength) - 1)
286294 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
287295 }
288296 else $Tuple3(currentPeriod, zeroPeriodStartHeight, zeroPeriodEndHeight)
289- let updatedCurrentPeriod = $t01420714589._1
290- let periodStart = $t01420714589._2
291- let periodEnd = $t01420714589._3
297+ let updatedCurrentPeriod = $t01435614738._1
298+ let periodStart = $t01435614738._2
299+ let periodEnd = $t01435614738._3
292300 $Tuple3(updatedCurrentPeriod, periodStart, periodEnd)
293301 }
294302 else $Tuple3(currentPeriod, valueOrElse(getInteger(keyPeriodStartHeight(currentPeriod)), height), valueOrElse(getInteger(keyPeriodEndHeight(currentPeriod)), ((height + periodLength) - 1)))
295- let updatedCurrentPeriod = $t01298714857._1
296- let periodStart = $t01298714857._2
297- let periodEnd = $t01298714857._3
303+ let updatedCurrentPeriod = $t01313615006._1
304+ let periodStart = $t01313615006._2
305+ let periodEnd = $t01313615006._3
298306 let periodTotalAvailableToClaim = valueOrElse(getInteger(keyPeriodTotalAvailableToClaim(priceAssetId58, updatedCurrentPeriod)), totalPeriodPriceAssetAllowance)
299307 let periodUserAvailableToClaim = valueOrElse(getInteger(keyPeriodUserAvailableToClaim(priceAssetId58, updatedCurrentPeriod, userAddress58)), userPeriodPriceAssetAllowance)
300308 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
301309 let periodMinAvailableToClaim = min([(outAmount + priceAssetBalance), periodTotalAvailableToClaim, periodUserAvailableToClaim])
302310 let usdtPriceAssetAllowableRatio = value(getInteger(keyUsdtPriceAssetAllowableRatio()))
303311 let putOneTknV2PriceAssetAmount = scale8
304- let $t01561215865 = {
312+ let $t01576116014 = {
305313 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "putOneTknV2WithoutTakeFeeREADONLY", [putOneTknV2PriceAssetAmount, priceAssetId58], nil)
306314 if ($isInstanceOf(@, "(Int, Int, Int)"))
307315 then @
308316 else throw(($getType(@) + " couldn't be cast to (Int, Int, Int)"))
309317 }
310- if (($t01561215865 == $t01561215865))
318+ if (($t01576116014 == $t01576116014))
311319 then {
312- let bonus = $t01561215865._3
313- let feeAmount = $t01561215865._2
314- let lpAmount = $t01561215865._1
320+ let bonus = $t01576116014._3
321+ let feeAmount = $t01576116014._2
322+ let lpAmount = $t01576116014._1
315323 let usdtAssetId = value(getString(keyUsdtAssetId()))
316- let $t01592716145 = {
324+ let $t01607616294 = {
317325 let @ = invoke(addressFromStringValue(value(getString(keyUsdtPriceAssetStablePool()))), "getOneTknV2READONLY", [usdtAssetId, lpAmount], nil)
318326 if ($isInstanceOf(@, "(Int, Int)"))
319327 then @
320328 else throw(($getType(@) + " couldn't be cast to (Int, Int)"))
321329 }
322- if (($t01592716145 == $t01592716145))
330+ if (($t01607616294 == $t01607616294))
323331 then {
324- let getOneTknV2FeeAmount = $t01592716145._2
325- let usdtAmount = $t01592716145._1
332+ let getOneTknV2FeeAmount = $t01607616294._2
333+ let usdtAmount = $t01607616294._1
326334 let currentUsdtPriceAssetRatio = fraction(putOneTknV2PriceAssetAmount, scale8, usdtAmount)
327335 let endPeriodBlocksLeft = (periodEnd - height)
328336 $Tuple10(periodMinAvailableToClaim, periodTotalAvailableToClaim, periodUserAvailableToClaim, totalUserAvailableToClaim, usdtPriceAssetAllowableRatio, currentUsdtPriceAssetRatio, endPeriodBlocksLeft, updatedCurrentPeriod, periodStart, periodEnd)
329337 }
330338 else throw("Strict value is not equal to itself.")
331339 }
332340 else throw("Strict value is not equal to itself.")
333341 }
334342
335343
336-func managerPublicKeyOrUnit () = match getString(keyManagerPublicKey()) {
337- case s: String =>
338- fromBase58String(s)
339- case _: Unit =>
340- unit
341- case _ =>
342- throw("Match error")
343-}
344-
345-
346-func pendingManagerPublicKeyOrUnit () = match getString(keyPendingManagerPublicKey()) {
347- case s: String =>
348- fromBase58String(s)
349- case _: Unit =>
350- unit
351- case _ =>
352- throw("Match error")
353-}
344+func managerPublicKeyOrUnit () = {
345+ let managerVaultAddress = getManagerVaultAddressOrThis()
346+ match getString(managerVaultAddress, keyManagerPublicKey()) {
347+ case s: String =>
348+ fromBase58String(s)
349+ case _: Unit =>
350+ unit
351+ case _ =>
352+ throw("Match error")
353+ }
354+ }
354355
355356
356357 func mustManager (i) = {
357358 let pd = throw("Permission denied")
358359 match managerPublicKeyOrUnit() {
359360 case pk: ByteVector =>
360361 if ((i.callerPublicKey == pk))
361362 then true
362363 else pd
363364 case _: Unit =>
364365 if ((i.caller == this))
365366 then true
366367 else pd
367368 case _ =>
368369 throw("Match error")
369370 }
370371 }
371372
372373
373374 @Callable(i)
374375 func constructor (idoStart,idoDuration,claimStart,claimDuration,price,priceAssetId58,minInvestAmount) = {
375376 let priceMult = ((100 * 1000) * 1000)
376377 let idoEnd = (idoStart + idoDuration)
377378 if (isDefined(getString(keyConfig())))
378379 then throw("already initialized")
379380 else if (("3PMEHLx1j6zerarZTYfsGqDeeZqQoMpxq5S" != toString(i.caller)))
380381 then throw("not authorized")
381382 else if ((size(i.payments) != 1))
382383 then throw("exactly 1 payment must be attached")
383384 else if ((idoEnd >= claimStart))
384385 then throw("claimStart must be greater than idoEnd")
385386 else {
386387 let pmt = value(i.payments[0])
387388 let idoAssetId = value(pmt.assetId)
388389 let idoAssetInfo = valueOrErrorMessage(assetInfo(idoAssetId), "fail to load ido asset info")
389390 let idoAssetId58 = toBase58String(idoAssetId)
390391 let idoAssetMult = pow(10, 0, idoAssetInfo.decimals, 0, 0, DOWN)
391392 let priceAssetId = fromBase58String(priceAssetId58)
392393 let priceAssetInfo = valueOrErrorMessage(assetInfo(priceAssetId), "fail to load price asset info")
393394 let priceAssetMult = pow(10, 0, priceAssetInfo.decimals, 0, 0, DOWN)
394395 let origTotalsArray = readTotalsArrayOrDefault()
395396 let totalsDiff = [0, 0, 0, 0]
396397 [StringEntry(keyConfig(), fromatConfig(idoStart, idoDuration, claimStart, claimDuration, price, priceMult, idoAssetId58, idoAssetMult, priceAssetId58, priceAssetMult, minInvestAmount, pmt.amount)), TotalsEntry(keyTotals(), origTotalsArray, totalsDiff, claimStart, 0)]
397398 }
398399 }
399400
400401
401402
402403 @Callable(i)
403404 func invest () = {
404405 let cfgArray = readConfigArray()
405406 let idoStart = parseIntValue(cfgArray[IdxCfgIdoStart])
406407 let idoDuration = parseIntValue(cfgArray[IdxCfgIdoDuration])
407408 let idoEnd = (idoStart + idoDuration)
408409 let claimStart = parseIntValue(cfgArray[IdxCfgClaimStart])
409410 let claimDuration = parseIntValue(cfgArray[IdxCfgClaimDuration])
410411 let price = parseIntValue(cfgArray[IdxCfgPrice])
411412 let priceMult = parseIntValue(cfgArray[IdxCfgPriceMult])
412413 let idoAssetId58 = cfgArray[IdxCfgIdoAssetId]
413414 let idoAssetId = fromBase58String(idoAssetId58)
414415 let idoAssetMult = parseIntValue(cfgArray[IdxCfgIdoAssetMult])
415416 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
416417 let priceAssetId = fromBase58String(priceAssetId58)
417418 let priceAssetMult = parseIntValue(cfgArray[IdxCfgPriceAssetMult])
418419 let minIvestAmount = parseIntValue(cfgArray[IdxCfgMinInvestAmount])
419420 let userAddress = toString(i.caller)
420421 if ((idoStart > height))
421422 then throw("ido has not been started yet")
422423 else if ((height > idoEnd))
423424 then throw("ido has been already ended")
424425 else if ((size(i.payments) != 1))
425426 then throw("exactly 1 payment is expected")
426427 else {
427428 let pmt = value(i.payments[0])
428429 let pmtAssetId = value(pmt.assetId)
429430 let pmtAmount = pmt.amount
430431 if ((pmtAssetId != priceAssetId))
431432 then throw((("invalid payment asset id: " + toBase58String(pmtAssetId)) + " is expected"))
432433 else {
433434 let origInvestorArray = readInvestorArrayOrDefault(userAddress)
434435 let origTotalsArray = readTotalsArrayOrDefault()
435436 let newPriceTotalAmount = (parseIntValue(origTotalsArray[IdxInvTotalAmount]) + pmtAmount)
436437 let requiredIdoAssetAmount = (newPriceTotalAmount * 100)
437438 if ((requiredIdoAssetAmount > assetBalance(this, idoAssetId)))
438439 then throw("IDO asset has been - sold consider to use smaller payment")
439440 else {
440441 let totalsDiff = [pmtAmount, pmtAmount, 0, 0]
441442 [TotalsEntry(keyInvestor(userAddress), origInvestorArray, totalsDiff, claimStart, 0), TotalsEntry(keyTotals(), origTotalsArray, totalsDiff, claimStart, 0), InvestOperationHistoryEntry(userAddress, pmtAmount, 0, i.transactionId)]
442443 }
443444 }
444445 }
445446 }
446447
447448
448449
449450 @Callable(i)
450451 func claim (claimedAssetId58,userAddress58) = {
451452 let callerAddress58 = toString(i.caller)
452453 if ((userAddress58 != callerAddress58))
453454 then throw("not authorized")
454455 else {
455456 let cfgArray = readConfigArray()
456457 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
457458 let claimResultTuple = internalClaim(claimedAssetId58, i.caller, i.transactionId)
458459 let totalsDiff = claimResultTuple._1
459460 let outAmount = claimResultTuple._2
460461 let outAssetId = claimResultTuple._3
461462 let origInvestArray = claimResultTuple._4
462463 let newClaimPeriodHeight = claimResultTuple._5
463464 let claimedPriceAmountFromDiff = totalsDiff[IdxDiffClaimedPriceAmountIncrement]
464465 let claimedIdoAssetAmountFromDiff = totalsDiff[IdxDiffClaimedIdoAssetAmountIncrement]
465466 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
466467 let priceAssetDecimals = value(assetInfo(fromBase58String(priceAssetId58))).decimals
467468 let entries = if ((claimedAssetId58 == priceAssetId58))
468469 then {
469- let $t02205422498 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
470- let periodMinAvailableToClaim = $t02205422498._1
471- let periodTotalAvailableToClaim = $t02205422498._2
472- let periodUserAvailableToClaim = $t02205422498._3
473- let totalUserAvailableToClaim = $t02205422498._4
474- let usdtPriceAssetAllowableRatio = $t02205422498._5
475- let currentUsdtPriceAssetRatio = $t02205422498._6
476- let endPeriodBlocksLeft = $t02205422498._7
477- let updatedCurrentPeriod = $t02205422498._8
478- let periodStart = $t02205422498._9
479- let periodEnd = $t02205422498._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
480481 let checks = [if ((periodUserAvailableToClaim > 0))
481482 then true
482483 else throwErr("unavailable to claim because user period allowance reached"), if ((periodTotalAvailableToClaim > 0))
483484 then true
484485 else throwErr("unavailable to claim because total period allowance reached"), if ((periodMinAvailableToClaim > 0))
485486 then true
486487 else throwErr("nothing to claim"), if ((usdtPriceAssetAllowableRatio > currentUsdtPriceAssetRatio))
487488 then true
488489 else throwErr("unavailable to claim because usdn price lower than usdtPriceAssetAllowableRatio")]
489490 if ((checks == checks))
490491 then {
491492 let updatedPeriodTotalAvailableToClaim = (periodTotalAvailableToClaim - periodMinAvailableToClaim)
492493 let updatedPeriodUserAvailableToClaim = (periodUserAvailableToClaim - periodMinAvailableToClaim)
493494 let entries = if ((priceAssetBalance > periodMinAvailableToClaim))
494495 then [ScriptTransfer(i.caller, periodMinAvailableToClaim, outAssetId), IntegerEntry(keyPriceAssetBalance(userAddress58), (priceAssetBalance - periodMinAvailableToClaim))]
495496 else {
496497 let evaluateResult = split(asString(invoke(this, "claimREADONLY", [priceAssetId58, userAddress58], nil)), SEP)
497498 if ((evaluateResult == evaluateResult))
498499 then {
499500 let availablePriceAmountToClaim = parseIntValue(evaluateResult[3])
500501 let lastClaimEntries = if ((availablePriceAmountToClaim == periodMinAvailableToClaim))
501502 then {
502503 let investorTotalAmount = parseIntValue(origInvestArray[IdxInvTotalAmount])
503504 let investorRemainingAmount = parseIntValue(origInvestArray[IdxInvRemainingAmount])
504505 let investorPriceAssetBalance = parseIntValue(origInvestArray[IdxInvClaimedPriceAssetAmount])
505506 let investorIdoAssetBalance = parseIntValue(origInvestArray[IdxInvClaimedIdoAssetAmount])
506507 let investorLastClaimedHeight = parseIntValue(origInvestArray[IdxInvLastClaimedHeight])
507508 let newInvestArray = [toString(investorTotalAmount), "0", toString(investorPriceAssetBalance), toString(investorIdoAssetBalance), toString(investorLastClaimedHeight)]
508509 let totals = readTotalsArrayOrDefault()
509510 let totalsTotalAmount = parseIntValue(totals[IdxInvTotalAmount])
510511 let totalsRemainingAmount = parseIntValue(totals[IdxInvRemainingAmount])
511512 let totalsClaimedPriceAssetAmount = parseIntValue(totals[IdxInvClaimedPriceAssetAmount])
512513 let totalsClaimedIdoAssetAmount = parseIntValue(totals[IdxInvClaimedIdoAssetAmount])
513514 let totalsLastClaimedHeight = parseIntValue(totals[IdxInvLastClaimedHeight])
514515 let newTotalsRemainingAmount = (totalsRemainingAmount - investorRemainingAmount)
515516 let newTotalArray = [toString(totalsTotalAmount), toString(newTotalsRemainingAmount), toString(totalsClaimedPriceAssetAmount), toString(totalsClaimedIdoAssetAmount), toString(totalsLastClaimedHeight)]
516517 let newTotalRemainingAmount = (valueOrElse(getInteger(keyTotalRemainingAmount()), 0) + investorRemainingAmount)
517518 [StringEntry(keyInvestorRemainingAmount(userAddress58), toString(investorRemainingAmount)), StringEntry(keyTotalRemainingAmount(), toString(newTotalRemainingAmount)), TotalsEntry(keyInvestor(userAddress58), newInvestArray, totalsDiff, newClaimPeriodHeight, 0), TotalsEntry(keyTotals(), newTotalArray, totalsDiff, newClaimPeriodHeight, 0)]
518519 }
519520 else [TotalsEntry(keyInvestor(userAddress58), origInvestArray, totalsDiff, newClaimPeriodHeight, 0), TotalsEntry(keyTotals(), readTotalsArrayOrDefault(), totalsDiff, newClaimPeriodHeight, 0)]
520521 let updatedPriceAssetBalance = ((priceAssetBalance + outAmount) - periodMinAvailableToClaim)
521522 ([ScriptTransfer(i.caller, periodMinAvailableToClaim, outAssetId), IntegerEntry(keyPriceAssetBalance(userAddress58), updatedPriceAssetBalance)] ++ lastClaimEntries)
522523 }
523524 else throw("Strict value is not equal to itself.")
524525 }
525526 $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)
526527 }
527528 else throw("Strict value is not equal to itself.")
528529 }
529530 else {
530531 let priceAssetBalanceIdoDecimals = fraction(priceAssetBalance, scale8, pow(10, 0, priceAssetDecimals, 0, 0, DOWN))
531532 $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)
532533 }
533534 entries
534535 }
535536 }
536537
537538
538539
539540 @Callable(i)
540541 func cleanRemaingAmount (userAddress58) = {
541542 let priceAssetId58 = readConfigArray()[IdxCfgPriceAssetId]
542543 let evaluateResult = split(asString(invoke(this, "claimREADONLY", [priceAssetId58, userAddress58], nil)), SEP)
543544 if ((evaluateResult == evaluateResult))
544545 then {
545546 let availablePriceAmountToClaim = parseIntValue(evaluateResult[2])
546547 let checkUnclaimedAssets = if ((availablePriceAmountToClaim == 0))
547548 then true
548549 else throwErr("user have unclaimed assets")
549550 if ((checkUnclaimedAssets == checkUnclaimedAssets))
550551 then {
551552 let investor = split(value(getString(keyInvestor(userAddress58))), SEP)
552553 let investorTotalAmount = parseIntValue(investor[IdxInvTotalAmount])
553554 let investorRemainingAmount = parseIntValue(investor[IdxInvRemainingAmount])
554555 let investorPriceAssetBalance = parseIntValue(investor[IdxInvClaimedPriceAssetAmount])
555556 let investorIdoAssetBalance = parseIntValue(investor[IdxInvClaimedIdoAssetAmount])
556557 let investorLastClaimedHeight = parseIntValue(investor[IdxInvLastClaimedHeight])
557558 let investorRemainingAmountCheck = if ((investorRemainingAmount != 0))
558559 then true
559560 else throwErr("investorRemainingAmount already zero")
560561 if ((investorRemainingAmountCheck == investorRemainingAmountCheck))
561562 then {
562563 let newInvestor = makeString(["%d%d%d%d%d", toString(investorTotalAmount), "0", toString(investorPriceAssetBalance), toString(investorIdoAssetBalance), toString(investorLastClaimedHeight)], SEP)
563564 let totals = split(value(getString(keyTotals())), SEP)
564565 let totalsTotalAmount = parseIntValue(totals[IdxInvTotalAmount])
565566 let totalsRemainingAmount = parseIntValue(totals[IdxInvRemainingAmount])
566567 let totalsClaimedPriceAssetAmount = parseIntValue(totals[IdxInvClaimedPriceAssetAmount])
567568 let totalsClaimedIdoAssetAmount = parseIntValue(totals[IdxInvClaimedIdoAssetAmount])
568569 let totalsLastClaimedHeight = parseIntValue(totals[IdxInvLastClaimedHeight])
569570 let newTotals = makeString(["%d%d%d%d%d", toString(totalsTotalAmount), toString((totalsRemainingAmount - investorRemainingAmount)), toString(totalsClaimedPriceAssetAmount), toString(totalsClaimedIdoAssetAmount), toString(totalsLastClaimedHeight)], SEP)
570571 let newTotalRemainingAmount = (valueOrElse(getInteger(keyTotalRemainingAmount()), 0) + investorRemainingAmount)
571572 [StringEntry(keyInvestorRemainingAmount(userAddress58), toString(investorRemainingAmount)), StringEntry(keyTotalRemainingAmount(), toString(newTotalRemainingAmount)), StringEntry(keyInvestor(userAddress58), newInvestor), StringEntry(keyTotals(), newTotals)]
572573 }
573574 else throw("Strict value is not equal to itself.")
574575 }
575576 else throw("Strict value is not equal to itself.")
576577 }
577578 else throw("Strict value is not equal to itself.")
578579 }
579580
580581
581582
582583 @Callable(i)
583584 func claimREADONLY (claimedAssetId58,userAddress58) = {
584585 let claimResultTuple = internalClaim(claimedAssetId58, addressFromStringValue(userAddress58), fromBase58String(""))
585586 let totalsDiff = claimResultTuple._1
586587 let outAmount = claimResultTuple._2
587588 let outAssetId = claimResultTuple._3
588589 let origInvestArray = claimResultTuple._4
589590 let newClaimPeriodHeight = claimResultTuple._5
590591 let availableToClaimArray = claimResultTuple._6
591592 let availablePriceAmountToClaim = availableToClaimArray[0]
592593 let availableIdoAmountToClaim = availableToClaimArray[1]
593594 $Tuple2(nil, makeString(["%s%d%d", userAddress58, toString(availablePriceAmountToClaim), toString(availableIdoAmountToClaim)], SEP))
594595 }
595596
596597
597598
598599 @Callable(i)
599600 func claimV2READONLY (claimedAssetId58,userAddress58) = {
600601 let claimResultTuple = internalClaim(claimedAssetId58, addressFromStringValue(userAddress58), fromBase58String(""))
601602 let totalsDiff = claimResultTuple._1
602603 let outAmount = claimResultTuple._2
603604 let outAssetId = claimResultTuple._3
604605 let origInvestArray = claimResultTuple._4
605606 let newClaimPeriodHeight = claimResultTuple._5
606607 let availableToClaimArray = claimResultTuple._6
607608 let availablePriceAmountToClaim = availableToClaimArray[0]
608609 let availableIdoAmountToClaim = availableToClaimArray[1]
609610 let cfgArray = readConfigArray()
610611 let priceAssetId58 = cfgArray[IdxCfgPriceAssetId]
611612 let priceAssetBalance = valueOrElse(getInteger(keyPriceAssetBalance(userAddress58)), 0)
612613 let priceAssetBalanceIdoDecimals = (priceAssetBalance * 100)
613614 let availableIdoAmountToClaimWithPriceAssetBalance = (availableIdoAmountToClaim + priceAssetBalanceIdoDecimals)
614- let $t03374934161 = internalClaimV2(priceAssetId58, userAddress58, outAmount, totalsDiff[IdxDiffClaimedPriceAmountIncrement])
615- let periodMinAvailableToClaim = $t03374934161._1
616- let periodTotalAvailableToClaim = $t03374934161._2
617- let periodUserAvailableToClaim = $t03374934161._3
618- let totalUserAvailableToClaim = $t03374934161._4
619- let usdtPriceAssetAllowableRatio = $t03374934161._5
620- let currentUsdtPriceAssetRatio = $t03374934161._6
621- let endPeriodBlocksLeft = $t03374934161._7
622- let updatedCurrentPeriod = $t03374934161._8
623- let periodStart = $t03374934161._9
624- let periodEnd = $t03374934161._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
625626 let currentPeriodEndHeight = valueOrElse(getInteger(keyPeriodEndHeight(updatedCurrentPeriod)), 0)
626627 let userTotalPriceAssetClaimed = (parseIntValue(readInvestorArrayOrFail(userAddress58)[IdxInvClaimedPriceAssetAmount]) - priceAssetBalance)
627628 let resultString = if ((height > currentPeriodEndHeight))
628629 then {
629630 let periodLenght = value(getInteger(keyPeriodLength()))
630631 let userPeriodAllowance = value(getInteger(keyUserPeriodAllowance(priceAssetId58)))
631632 let totalPeriodAllowance = value(getInteger(keyTotalPeriodAllowance(priceAssetId58)))
632633 makeString(["%d%d%d%d%d%d", toString(availableIdoAmountToClaimWithPriceAssetBalance), toString(userPeriodAllowance), toString(totalPeriodAllowance), toString(usdtPriceAssetAllowableRatio), toString(currentUsdtPriceAssetRatio), toString(periodLenght), toString(userTotalPriceAssetClaimed)], SEP)
633634 }
634635 else makeString(["%d%d%d%d%d%d", toString(availableIdoAmountToClaimWithPriceAssetBalance), toString(periodMinAvailableToClaim), toString(periodTotalAvailableToClaim), toString(usdtPriceAssetAllowableRatio), toString(currentUsdtPriceAssetRatio), toString(endPeriodBlocksLeft), toString(userTotalPriceAssetClaimed)], SEP)
635636 $Tuple2(nil, resultString)
636- }
637-
638-
639-
640-@Callable(i)
641-func setManager (pendingManagerPublicKey) = {
642- let checkCaller = mustManager(i)
643- if ((checkCaller == checkCaller))
644- then {
645- let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
646- if ((checkManagerPublicKey == checkManagerPublicKey))
647- then [StringEntry(keyPendingManagerPublicKey(), pendingManagerPublicKey)]
648- else throw("Strict value is not equal to itself.")
649- }
650- else throw("Strict value is not equal to itself.")
651- }
652-
653-
654-
655-@Callable(i)
656-func confirmManager () = {
657- let pm = pendingManagerPublicKeyOrUnit()
658- let hasPM = if (isDefined(pm))
659- then true
660- else throw("No pending manager")
661- if ((hasPM == hasPM))
662- then {
663- let checkPM = if ((i.callerPublicKey == value(pm)))
664- then true
665- else throw("You are not pending manager")
666- if ((checkPM == checkPM))
667- then [StringEntry(keyManagerPublicKey(), toBase58String(value(pm))), DeleteEntry(keyPendingManagerPublicKey())]
668- else throw("Strict value is not equal to itself.")
669- }
670- else throw("Strict value is not equal to itself.")
671637 }
672638
673639
674640 @Verifier(tx)
675641 func verify () = {
676642 let targetPublicKey = match managerPublicKeyOrUnit() {
677643 case pk: ByteVector =>
678644 pk
679645 case _: Unit =>
680646 tx.senderPublicKey
681647 case _ =>
682648 throw("Match error")
683649 }
684650 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
685651 }
686652

github/deemru/w8io/6500d08 
116.88 ms