tx · 8hfsfid4pXftqSPYu5BQEVLbDw6K8ngs73DUefavdaNf 3MsxHxruYWoddB4HRiPBYAWtMXMtCF1V9XT: -0.01400000 Waves 2021.09.13 18:16 [1701442] smart account 3MsxHxruYWoddB4HRiPBYAWtMXMtCF1V9XT > SELF 0.00000000 Waves
{ "type": 13, "id": "8hfsfid4pXftqSPYu5BQEVLbDw6K8ngs73DUefavdaNf", "fee": 1400000, "feeAssetId": null, "timestamp": 1631546195717, "version": 2, "chainId": 84, "sender": "3MsxHxruYWoddB4HRiPBYAWtMXMtCF1V9XT", "senderPublicKey": "3ijdmxaYrpDFsKVbQH2kvB7i6JzHj9bep9bGWiQPra2D", "proofs": [ "2DCvQszS7Fv1SM8tHZb5iLQ6gE6bEm3vG5vHn1bEvCuS5Td6pDjEAWsZnpYYak4mrZx5sfSCqwXFJhSh4B38PFZu", "2j6QJQwoWeSg13vnrH4CHY6VmGL3M7KGR3Epx7A9G8ZXTKwZdNntA2dGP2jDVGuohVhjqttPpocHRwu2N5FzeD4D" ], "script": "base64:AAIFAAAAAAAAAB8IAhIDCgEIEgUKAwgYARIFCgMICAESBAoCCAESABIAAAAAXAAAAAAMYWRtaW5QdWJLZXkxAQAAACDip4xAO4bNF+a0S4fb5aGDrK4qoew3Ll5lBRPytezvBAAAAAAMYWRtaW5QdWJLZXkyAQAAACDqOKy5AbWIPHKjnig9gdQaImURE43fjoONfP1X8ZsRWQAAAAAMYWRtaW5QdWJLZXkzAQAAACCnNJaCsKPJx10yYgF/O0UnTzPqvzbEAc8Qt3RwqifMbgAAAAAUa2V5U2hhcmVUb2tlbnNMb2NrZWQCAAAAGl90b3RhbF9zaGFyZV90b2tlbnNfbG9ja2VkAAAAAAtrU2hhcmVMaW1pdAIAAAAcc2hhcmVfbGltaXRfb25fZmlyc3RfaGFydmVzdAAAAAAJa2V5QWN0aXZlAgAAAAZhY3RpdmUAAAAACGtleUNhdXNlAgAAAA5zaHV0ZG93bl9jYXVzZQAAAAAca2V5UmV3YXJkUG9vbEZyYWN0aW9uQ3VycmVudAIAAAAdX2N1cnJlbnRfcG9vbF9mcmFjdGlvbl9yZXdhcmQAAAAAHWtleVJld2FyZFBvb2xGcmFjdGlvblByZXZpb3VzAgAAAB5fcHJldmlvdXNfcG9vbF9mcmFjdGlvbl9yZXdhcmQAAAAAFWtleUhlaWdodFBvb2xGcmFjdGlvbgIAAAAaX3Bvb2xfcmV3YXJkX3VwZGF0ZV9oZWlnaHQAAAAAHWtleVRvdGFsUmV3YXJkUGVyQmxvY2tDdXJyZW50AgAAAB50b3RhbF9yZXdhcmRfcGVyX2Jsb2NrX2N1cnJlbnQAAAAAHmtleVRvdGFsUmV3YXJkUGVyQmxvY2tQcmV2aW91cwIAAAAfdG90YWxfcmV3YXJkX3Blcl9ibG9ja19wcmV2aW91cwAAAAAVa2V5UmV3YXJkVXBkYXRlSGVpZ2h0AgAAABRyZXdhcmRfdXBkYXRlX2hlaWdodAAAAAAPa2V5TGFzdEludGVyZXN0AgAAAA5fbGFzdF9pbnRlcmVzdAAAAAAVa2V5TGFzdEludGVyZXN0SGVpZ2h0AgAAABVfbGFzdF9pbnRlcmVzdF9oZWlnaHQAAAAAGGtleVVzZXJTaGFyZVRva2Vuc0xvY2tlZAIAAAAUX3NoYXJlX3Rva2Vuc19sb2NrZWQAAAAAE2tleVVzZXJMYXN0SW50ZXJlc3QCAAAADl9sYXN0X2ludGVyZXN0AAAAAAlrZXlTV09QaWQCAAAAB1NXT1BfaWQAAAAAGGtleVVzZXJTV09QQ2xhaW1lZEFtb3VudAIAAAAUX1NXT1BfY2xhaW1lZF9hbW91bnQAAAAAHGtleVVzZXJTV09QTGFzdENsYWltZWRBbW91bnQCAAAAGV9TV09QX2xhc3RfY2xhaW1lZF9hbW91bnQAAAAAEGtleUF2YWlsYWJsZVNXT1ACAAAAD19hdmFpbGFibGVfU1dPUAAAAAAVa2V5RmFybWluZ1N0YXJ0SGVpZ2h0AgAAABRmYXJtaW5nX3N0YXJ0X2hlaWdodAAAAAAGa2V5QVBZAgAAAANhcHkAAAAAFmtQcmV2aW91c1RvdGFsVm90ZVNXT1ACAAAAGHByZXZpb3VzX3RvdGFsX3ZvdGVfU1dPUAAAAAATa2V5U3dvcFllYXJFbWlzc2lvbgIAAAASc3dvcF95ZWFyX2VtaXNzaW9uAAAAAA9rZXlCYWxhbmNlY3BtbUECAAAAD0FfYXNzZXRfYmFsYW5jZQAAAAAPa2V5QmFsYW5jZWNwbW1CAgAAAA9CX2Fzc2V0X2JhbGFuY2UAAAAAIWtIYXJ2ZXN0UG9vbEFjdGl2ZVZvdGVTdHJ1Y1ZvdGluZwIAAAAeX2hhcnZlc3RfcG9vbF9hY3RpdmVWb3RlX3N0cnVjAAAAACVrSGFydmVzdFVzZXJQb29sQWN0aXZlVm90ZVN0cnVjVm90aW5nAgAAACNfaGFydmVzdF91c2VyX3Bvb2xfYWN0aXZlVm90ZV9zdHJ1YwAAAAAZa2V5TGltaXRTaGFyZUZpcnN0SGFydmVzdAIAAAAcc2hhcmVfbGltaXRfb25fZmlyc3RfaGFydmVzdAAAAAALa2V5QXNzZXRJZEECAAAACkFfYXNzZXRfaWQAAAAAC2tleUFzc2V0SWRCAgAAAApCX2Fzc2V0X2lkAAAAABVrZXlGaXJzdEhhcnZlc3RIZWlnaHQCAAAAFGZpcnN0X2hhcnZlc3RfaGVpZ2h0AAAAABNrZXlmaXJzdEhhcnZlc3RDcG1tAgAAAA1maXJzdF9oYXJ2ZXN0AAAAAA5rZXlUZW1wUHJldlN1bQIAAAATc3VtX3Jld2FyZF9wcmV2aW91cwAAAAANa2V5VGVtcEN1clN1bQIAAAASc3VtX3Jld2FyZF9jdXJyZW50AAAAABFnb3Zlcm5hbmNlQWRkcmVzcwkBAAAAB0FkZHJlc3MAAAABAQAAABoBVKr6ad6B9BNShco/LjqIUbMZ6pgcWfINLQAAAAAGd2FsbGV0CQEAAAAHQWRkcmVzcwAAAAEBAAAAGgFU3z1Ll4lYWd4V4ORRC1bdPXpfvbV/hSGJAAAAAA12b3RpbmdBZGRyZXNzCQEAAAAHQWRkcmVzcwAAAAEBAAAAGgFUGjZ+31einSdpXP6/9ybU5/uhw2g+IMp/AAAAABxhZG1pbkluY3JlYXNlSW50ZXJlc3RBZGRyZXNzCQEAAAAHQWRkcmVzcwAAAAEBAAAAGgFU3z1Ll4lYWd4V4ORRC1bdPXpfvbV/hSGJAAAAAA5vbmVXZWVrSW5CbG9jawAAAAAAAAAnegAAAAAOdG90YWxWb3RlU2hhcmUAAAAAAlQL5AAAAAAAC3NjYWxlVmFsdWUxAAAAAAAAAAAKAAAAAAtzY2FsZVZhbHVlMwAAAAAAAAAD6AAAAAALc2NhbGVWYWx1ZTUAAAAAAAABhqAAAAAAC3NjYWxlVmFsdWU2AAAAAAAAD0JAAAAAAAtzY2FsZVZhbHVlOAAAAAAABfXhAAAAAAAMc2NhbGVWYWx1ZTExAAAAABdIdugAAQAAAAtzdHJBc3NldElkQQAAAAEAAAAEcG9vbAkBAAAAEUBleHRyTmF0aXZlKDEwNTMpAAAAAgUAAAAEcG9vbAUAAAALa2V5QXNzZXRJZEEBAAAAC3N0ckFzc2V0SWRCAAAAAQAAAARwb29sCQEAAAARQGV4dHJOYXRpdmUoMTA1MykAAAACBQAAAARwb29sBQAAAAtrZXlBc3NldElkQgEAAAAIYXNzZXRJZEEAAAABAAAABHBvb2wDCQAAAAAAAAIJAQAAAAtzdHJBc3NldElkQQAAAAEFAAAABHBvb2wCAAAABVdBVkVTBQAAAAR1bml0CQACWQAAAAEJAQAAAAtzdHJBc3NldElkQQAAAAEFAAAABHBvb2wBAAAACGFzc2V0SWRCAAAAAQAAAARwb29sAwkAAAAAAAACCQEAAAALc3RyQXNzZXRJZEIAAAABBQAAAARwb29sAgAAAAVXQVZFUwUAAAAEdW5pdAkAAlkAAAABCQEAAAALc3RyQXNzZXRJZEIAAAABBQAAAARwb29sAAAAAAtrQmFzZVBlcmlvZAIAAAALYmFzZV9wZXJpb2QAAAAADWtQZXJpb2RMZW5ndGgCAAAADXBlcmlvZF9sZW5ndGgAAAAADGtTdGFydEhlaWdodAIAAAAMc3RhcnRfaGVpZ2h0AAAAABNrRmlyc3RIYXJ2ZXN0SGVpZ2h0AgAAABRmaXJzdF9oYXJ2ZXN0X2hlaWdodAAAAAAWa0R1cmF0aW9uRnVsbFZvdGVQb3dlcgIAAAAYZHVyYXRpb25fZnVsbF92b3RlX3Bvd2VyAAAAAA1rTWluVm90ZVBvd2VyAgAAAA5taW5fdm90ZV9wb3dlcgAAAAAKYmFzZVBlcmlvZAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAADXZvdGluZ0FkZHJlc3MFAAAAC2tCYXNlUGVyaW9kAgAAABFFbXB0eSBrQmFzZVBlcmlvZAAAAAALc3RhcnRIZWlnaHQJAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkABBoAAAACBQAAAA12b3RpbmdBZGRyZXNzBQAAAAxrU3RhcnRIZWlnaHQCAAAAEkVtcHR5IGtTdGFydEhlaWdodAAAAAAMcGVyaW9kTGVuZ3RoCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQaAAAAAgUAAAANdm90aW5nQWRkcmVzcwUAAAANa1BlcmlvZExlbmd0aAIAAAATRW1wdHkga1BlcmlvZExlbmd0aAAAAAAVZHVyYXRpb25GdWxsVm90ZVBvd2VyCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQaAAAAAgUAAAANdm90aW5nQWRkcmVzcwUAAAAWa0R1cmF0aW9uRnVsbFZvdGVQb3dlcgIAAAAcRW1wdHkga0R1cmF0aW9uRnVsbFZvdGVQb3dlcgAAAAAMbWluVm90ZVBvd2VyCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQaAAAAAgUAAAANdm90aW5nQWRkcmVzcwUAAAANa01pblZvdGVQb3dlcgIAAAATRW1wdHkga01pblZvdGVQb3dlcgAAAAAIaXNBY3RpdmUJAQAAABFAZXh0ck5hdGl2ZSgxMDUxKQAAAAIFAAAABHRoaXMFAAAACWtleUFjdGl2ZQAAAAAKY3VyclBlcmlvZAkAAGQAAAACBQAAAApiYXNlUGVyaW9kCQAAaQAAAAIJAABlAAAAAgUAAAAGaGVpZ2h0BQAAAAtzdGFydEhlaWdodAUAAAAMcGVyaW9kTGVuZ3RoAQAAAA1nZXRMaW1pdFRva2VuAAAAAQAAAARwb29sCQEAAAALdmFsdWVPckVsc2UAAAACCQEAAAARQGV4dHJOYXRpdmUoMTA1MCkAAAACBQAAAARwb29sBQAAABlrZXlMaW1pdFNoYXJlRmlyc3RIYXJ2ZXN0AAAAAAAAAAAAAAAAAANBUFkJAQAAABFAZXh0ck5hdGl2ZSgxMDUwKQAAAAIFAAAABHRoaXMFAAAABmtleUFQWQAAAAAQU3dvcFllYXJFbWlzc2lvbgkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgUAAAAEdGhpcwUAAAATa2V5U3dvcFllYXJFbWlzc2lvbgEAAAAKYXNzZXROYW1lQQAAAAEAAAAEcG9vbAQAAAAHJG1hdGNoMAkBAAAACGFzc2V0SWRBAAAAAQUAAAAEcG9vbAMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAKQnl0ZVZlY3RvcgQAAAACaWQFAAAAByRtYXRjaDAICQEAAAAFdmFsdWUAAAABCQAD7AAAAAEFAAAAAmlkAAAABG5hbWUDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAABFVuaXQEAAAABXdhdmVzBQAAAAckbWF0Y2gwAgAAAAVXQVZFUwkAAAIAAAABAgAAAAtNYXRjaCBlcnJvcgEAAAAKYXNzZXROYW1lQgAAAAEAAAAEcG9vbAQAAAAHJG1hdGNoMAkBAAAACGFzc2V0SWRCAAAAAQUAAAAEcG9vbAMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAKQnl0ZVZlY3RvcgQAAAACaWQFAAAAByRtYXRjaDAICQEAAAAFdmFsdWUAAAABCQAD7AAAAAEFAAAAAmlkAAAABG5hbWUDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAABFVuaXQEAAAABXdhdmVzBQAAAAckbWF0Y2gwAgAAAAVXQVZFUwkAAAIAAAABAgAAAAtNYXRjaCBlcnJvcgAAAAAEU1dPUAkAAlkAAAABCQEAAAARQGV4dHJOYXRpdmUoMTA1MykAAAACBQAAAAR0aGlzBQAAAAlrZXlTV09QaWQBAAAADmlzRmlyc3RIYXJ2ZXN0AAAAAQAAAARwb29sCQEAAAALdmFsdWVPckVsc2UAAAACCQAEGwAAAAIFAAAABHBvb2wFAAAAE2tleWZpcnN0SGFydmVzdENwbW0HAQAAABVnZXRIZWlnaHRGaXJzdEhhcnZlc3QAAAABAAAABHBvb2wJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEcG9vbAUAAAAVa2V5Rmlyc3RIYXJ2ZXN0SGVpZ2h0AAAAAAAAAAAAAQAAAAtnZXRCYWxhbmNlQQAAAAEAAAAEcG9vbAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAABHBvb2wFAAAAD2tleUJhbGFuY2VjcG1tQQkAASwAAAACAgAAABRObyBkYXRhIG9uIHRoZSBrZXk6IAUAAAAPa2V5QmFsYW5jZWNwbW1BAQAAAAtnZXRCYWxhbmNlQgAAAAEAAAAEcG9vbAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAABHBvb2wFAAAAD2tleUJhbGFuY2VjcG1tQgkAASwAAAACAgAAABRObyBkYXRhIG9uIHRoZSBrZXk6IAUAAAAPa2V5QmFsYW5jZWNwbW1CAQAAABJnZXRTaGFyZUxpbWl0VG9rZW4AAAABAAAABHBvb2wJAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkABBoAAAACBQAAAARwb29sBQAAAAtrU2hhcmVMaW1pdAkAASwAAAACAgAAABRObyBkYXRhIG9uIHRoZSBrZXk6IAUAAAALa1NoYXJlTGltaXQBAAAAGGdldFRvdGFsU2hhcmVUb2tlbkxvY2tlZAAAAAEAAAAEcG9vbAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAABHRoaXMJAAEsAAAAAgUAAAAEcG9vbAUAAAAUa2V5U2hhcmVUb2tlbnNMb2NrZWQJAAEsAAAAAgkAASwAAAACAgAAABRObyBkYXRhIG9uIHRoZSBrZXk6IAUAAAAEcG9vbAUAAAAUa2V5U2hhcmVUb2tlbnNMb2NrZWQBAAAAD2dldFNoYXJlQXNzZXRJZAAAAAEAAAAEcG9vbAkAAlkAAAABCQEAAAARQGV4dHJOYXRpdmUoMTA1MykAAAACCQEAAAAFdmFsdWUAAAABCQAEJgAAAAEFAAAABHBvb2wCAAAADnNoYXJlX2Fzc2V0X2lkAQAAAA5hY2NvdW50QmFsYW5jZQAAAAEAAAAHYXNzZXRJZAQAAAAHJG1hdGNoMAUAAAAHYXNzZXRJZAMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAKQnl0ZVZlY3RvcgQAAAACaWQFAAAAByRtYXRjaDAJAAPwAAAAAgUAAAAEdGhpcwUAAAACaWQDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAABFVuaXQEAAAABXdhdmVzBQAAAAckbWF0Y2gwCAkAA+8AAAABBQAAAAR0aGlzAAAACWF2YWlsYWJsZQkAAAIAAAABAgAAAAtNYXRjaCBlcnJvcgEAAAAMZ2V0QXNzZXRJbmZvAAAAAQAAAAdhc3NldElkBAAAAAckbWF0Y2gwBQAAAAdhc3NldElkAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAApCeXRlVmVjdG9yBAAAAAJpZAUAAAAHJG1hdGNoMAQAAAAIc3RyaW5nSWQJAAJYAAAAAQUAAAACaWQEAAAABGluZm8JAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkAA+wAAAABBQAAAAJpZAkAASwAAAACCQABLAAAAAICAAAABkFzc2V0IAUAAAAIc3RyaW5nSWQCAAAADiBkb2Vzbid0IGV4aXN0CQAFFQAAAAMFAAAACHN0cmluZ0lkCAUAAAAEaW5mbwAAAARuYW1lCAUAAAAEaW5mbwAAAAhkZWNpbWFscwMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAEVW5pdAQAAAAFd2F2ZXMFAAAAByRtYXRjaDAJAAUVAAAAAwIAAAAFV0FWRVMCAAAABVdBVkVTAAAAAAAAAAAICQAAAgAAAAECAAAAC01hdGNoIGVycm9yAQAAAA5jYWxjU2NhbGVWYWx1ZQAAAAIAAAAIYXNzZXRJZDEAAAAIYXNzZXRJZDIEAAAAEGFzc2V0SWQxRGVjaW1hbHMICQEAAAAFdmFsdWUAAAABCQAD7AAAAAEFAAAACGFzc2V0SWQxAAAACGRlY2ltYWxzBAAAABBhc3NldElkMkRlY2ltYWxzCAkBAAAABXZhbHVlAAAAAQkAA+wAAAABBQAAAAhhc3NldElkMgAAAAhkZWNpbWFscwQAAAALc2NhbGVEaWdpdHMJAABkAAAAAgkAAGUAAAACBQAAABBhc3NldElkMkRlY2ltYWxzBQAAABBhc3NldElkMURlY2ltYWxzAAAAAAAAAAAICQAAbAAAAAYAAAAAAAAAAAoAAAAAAAAAAAAFAAAAC3NjYWxlRGlnaXRzAAAAAAAAAAAAAAAAAAAAAAAABQAAAAVGTE9PUgEAAAARdXNlckF2YWlsYWJsZVNXT1AAAAACAAAABHBvb2wAAAAEdXNlcgkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAARwb29sAgAAAAFfBQAAAAR1c2VyBQAAABBrZXlBdmFpbGFibGVTV09QAAAAAAAAAAAAAQAAAApyZXdhcmRJbmZvAAAAAQAAAARwb29sBAAAABp0b3RhbFJld2FyZFBlckJsb2NrQ3VycmVudAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAAEWdvdmVybmFuY2VBZGRyZXNzBQAAAB1rZXlUb3RhbFJld2FyZFBlckJsb2NrQ3VycmVudAkAASwAAAACCQABLAAAAAIJAAEsAAAAAgIAAAAUTm8gZGF0YSBvbiB0aGUga2V5OiAFAAAAHWtleVRvdGFsUmV3YXJkUGVyQmxvY2tDdXJyZW50AgAAAAwgYXQgYWRkcmVzcyAJAAQlAAAAAQUAAAARZ292ZXJuYW5jZUFkZHJlc3MEAAAAG3RvdGFsUmV3YXJkUGVyQmxvY2tQcmV2aW91cwkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAAEWdvdmVybmFuY2VBZGRyZXNzBQAAAB5rZXlUb3RhbFJld2FyZFBlckJsb2NrUHJldmlvdXMJAAEsAAAAAgkAASwAAAACCQABLAAAAAICAAAAFE5vIGRhdGEgb24gdGhlIGtleTogBQAAAB5rZXlUb3RhbFJld2FyZFBlckJsb2NrUHJldmlvdXMCAAAADCBhdCBhZGRyZXNzIAkABCUAAAABBQAAABFnb3Zlcm5hbmNlQWRkcmVzcwQAAAAZcmV3YXJkUG9vbEZyYWN0aW9uQ3VycmVudAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAAEWdvdmVybmFuY2VBZGRyZXNzCQABLAAAAAIFAAAABHBvb2wFAAAAHGtleVJld2FyZFBvb2xGcmFjdGlvbkN1cnJlbnQJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgIAAAAUTm8gZGF0YSBvbiB0aGUga2V5OiAFAAAABHBvb2wFAAAAHGtleVJld2FyZFBvb2xGcmFjdGlvbkN1cnJlbnQCAAAADCBhdCBhZGRyZXNzIAkABCUAAAABBQAAABFnb3Zlcm5hbmNlQWRkcmVzcwQAAAAScmV3YXJkVXBkYXRlSGVpZ2h0CQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQaAAAAAgUAAAARZ292ZXJuYW5jZUFkZHJlc3MFAAAAFWtleVJld2FyZFVwZGF0ZUhlaWdodAkAASwAAAACCQABLAAAAAIJAAEsAAAAAgIAAAAUTm8gZGF0YSBvbiB0aGUga2V5OiAFAAAAFWtleVJld2FyZFVwZGF0ZUhlaWdodAIAAAAMIGF0IGFkZHJlc3MgCQAEJQAAAAEFAAAAEWdvdmVybmFuY2VBZGRyZXNzBAAAABZwb29sUmV3YXJkVXBkYXRlSGVpZ2h0CQEAAAALdmFsdWVPckVsc2UAAAACCQAEGgAAAAIFAAAAEWdvdmVybmFuY2VBZGRyZXNzCQABLAAAAAIFAAAABHBvb2wFAAAAFWtleUhlaWdodFBvb2xGcmFjdGlvbgAAAAAAAAAAAAQAAAAacmV3YXJkUG9vbEZyYWN0aW9uUHJldmlvdXMJAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkABBoAAAACBQAAABFnb3Zlcm5hbmNlQWRkcmVzcwkAASwAAAACBQAAAARwb29sBQAAAB1rZXlSZXdhcmRQb29sRnJhY3Rpb25QcmV2aW91cwkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACAgAAABRObyBkYXRhIG9uIHRoZSBrZXk6IAUAAAAEcG9vbAUAAAAda2V5UmV3YXJkUG9vbEZyYWN0aW9uUHJldmlvdXMCAAAADCBhdCBhZGRyZXNzIAkABCUAAAABBQAAABFnb3Zlcm5hbmNlQWRkcmVzcwQAAAARcmV3YXJkUG9vbEN1cnJlbnQJAABrAAAAAwUAAAAadG90YWxSZXdhcmRQZXJCbG9ja0N1cnJlbnQFAAAAGXJld2FyZFBvb2xGcmFjdGlvbkN1cnJlbnQFAAAADnRvdGFsVm90ZVNoYXJlBAAAABJyZXdhcmRQb29sUHJldmlvdXMJAABrAAAAAwUAAAAbdG90YWxSZXdhcmRQZXJCbG9ja1ByZXZpb3VzBQAAABpyZXdhcmRQb29sRnJhY3Rpb25QcmV2aW91cwUAAAAOdG90YWxWb3RlU2hhcmUDAwkAAGYAAAACBQAAABFyZXdhcmRQb29sQ3VycmVudAUAAAAadG90YWxSZXdhcmRQZXJCbG9ja0N1cnJlbnQGCQAAZgAAAAIFAAAAEnJld2FyZFBvb2xQcmV2aW91cwUAAAAbdG90YWxSZXdhcmRQZXJCbG9ja1ByZXZpb3VzCQAAAgAAAAECAAAAYnJld2FyZFBvb2xDdXJyZW50ID4gdG90YWxSZXdhcmRQZXJCbG9ja0N1cnJlbnQgb3IgcmV3YXJkUG9vbFByZXZpb3VzID4gdG90YWxSZXdhcmRQZXJCbG9ja1ByZXZpb3VzCQAFFgAAAAQFAAAAEXJld2FyZFBvb2xDdXJyZW50BQAAABJyZXdhcmRVcGRhdGVIZWlnaHQFAAAAEnJld2FyZFBvb2xQcmV2aW91cwUAAAAWcG9vbFJld2FyZFVwZGF0ZUhlaWdodAEAAAATZ2V0TGFzdEludGVyZXN0SW5mbwAAAAEAAAAEcG9vbAQAAAAMbGFzdEludGVyZXN0CQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAARwb29sBQAAAA9rZXlMYXN0SW50ZXJlc3QJAAEsAAAAAgkAASwAAAACAgAAABRObyBkYXRhIG9uIHRoZSBrZXk6IAUAAAAEcG9vbAUAAAAPa2V5TGFzdEludGVyZXN0BAAAABJsYXN0SW50ZXJlc3RIZWlnaHQJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAARwb29sBQAAABVrZXlMYXN0SW50ZXJlc3RIZWlnaHQFAAAABmhlaWdodAkABRQAAAACBQAAABJsYXN0SW50ZXJlc3RIZWlnaHQFAAAADGxhc3RJbnRlcmVzdAEAAAATZ2V0VXNlckludGVyZXN0SW5mbwAAAAIAAAAEcG9vbAAAAAt1c2VyQWRkclN0cgQAAAAQdXNlckxhc3RJbnRlcmVzdAkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAARwb29sAgAAAAFfBQAAAAt1c2VyQWRkclN0cgUAAAATa2V5VXNlckxhc3RJbnRlcmVzdAQAAAAJdXNlclNoYXJlCQAEGgAAAAIFAAAABHRoaXMJAAEsAAAAAgkAASwAAAACCQABLAAAAAIFAAAABHBvb2wCAAAAAV8FAAAAC3VzZXJBZGRyU3RyBQAAABhrZXlVc2VyU2hhcmVUb2tlbnNMb2NrZWQEAAAADGxhc3RJbnRlcmVzdAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAABHRoaXMJAAEsAAAAAgUAAAAEcG9vbAUAAAAPa2V5TGFzdEludGVyZXN0CQABLAAAAAIJAAEsAAAAAgIAAAAUTm8gZGF0YSBvbiB0aGUga2V5OiAFAAAABHBvb2wFAAAAD2tleUxhc3RJbnRlcmVzdAQAAAAVdXNlckxhc3RJbnRlcmVzdFZhbHVlBAAAAAckbWF0Y2gwBQAAABB1c2VyTGFzdEludGVyZXN0AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAEHVzZXJMYXN0SW50ZXJlc3QFAAAAByRtYXRjaDAFAAAAEHVzZXJMYXN0SW50ZXJlc3QFAAAADGxhc3RJbnRlcmVzdAQAAAAVdXNlclNoYXJlVG9rZW5zQW1vdW50BAAAAAckbWF0Y2gwBQAAAAl1c2VyU2hhcmUDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAAJdXNlclNoYXJlBQAAAAckbWF0Y2gwBQAAAAl1c2VyU2hhcmUAAAAAAAAAAAAJAAUUAAAAAgUAAAAVdXNlckxhc3RJbnRlcmVzdFZhbHVlBQAAABV1c2VyU2hhcmVUb2tlbnNBbW91bnQBAAAADGNhbGNJbnRlcmVzdAAAAAkAAAASbGFzdEludGVyZXN0SGVpZ2h0AAAAEnJld2FyZFVwZGF0ZUhlaWdodAAAABZwb29sUmV3YXJkVXBkYXRlSGVpZ2h0AAAADGxhc3RJbnRlcmVzdAAAABVjdXJyZW50UmV3YXJkUGVyQmxvY2sAAAAQc2hhcmVUb2tlbkxvY2tlZAAAABZwcmV2aW91c1Jld2FyZFBlckJsb2NrAAAACnNjYWxlVmFsdWUAAAABaAMJAAAAAAAAAgUAAAAQc2hhcmVUb2tlbkxvY2tlZAAAAAAAAAAAAAAAAAAAAAAAAAMJAQAAAAIhPQAAAAIFAAAAFnBvb2xSZXdhcmRVcGRhdGVIZWlnaHQAAAAAAAAAAAADAwkAAGYAAAACBQAAABJyZXdhcmRVcGRhdGVIZWlnaHQFAAAAAWgJAAAAAAAAAgUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0BQAAABZwb29sUmV3YXJkVXBkYXRlSGVpZ2h0BwQAAAAGcmV3YXJkCQAAaAAAAAIFAAAAFnByZXZpb3VzUmV3YXJkUGVyQmxvY2sJAABlAAAAAgUAAAABaAUAAAASbGFzdEludGVyZXN0SGVpZ2h0CQAAZAAAAAIFAAAADGxhc3RJbnRlcmVzdAkAAGsAAAADBQAAAAZyZXdhcmQFAAAACnNjYWxlVmFsdWUFAAAAEHNoYXJlVG9rZW5Mb2NrZWQDAwkAAGYAAAACBQAAAAFoBQAAABJyZXdhcmRVcGRhdGVIZWlnaHQJAQAAAAIhPQAAAAIFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAUAAAAWcG9vbFJld2FyZFVwZGF0ZUhlaWdodAcEAAAABnJld2FyZAkAAGgAAAACBQAAABZwcmV2aW91c1Jld2FyZFBlckJsb2NrCQAAZQAAAAIFAAAAAWgFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAkAAGQAAAACBQAAAAxsYXN0SW50ZXJlc3QJAABrAAAAAwUAAAAGcmV3YXJkBQAAAApzY2FsZVZhbHVlBQAAABBzaGFyZVRva2VuTG9ja2VkAwMDCQAAZgAAAAIFAAAAAWgFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAkAAAAAAAACBQAAABJyZXdhcmRVcGRhdGVIZWlnaHQFAAAAFnBvb2xSZXdhcmRVcGRhdGVIZWlnaHQHCQAAZgAAAAIFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0BwQAAAAGcmV3YXJkCQAAaAAAAAIFAAAAFWN1cnJlbnRSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAAAFoBQAAABJsYXN0SW50ZXJlc3RIZWlnaHQJAABkAAAAAgUAAAAMbGFzdEludGVyZXN0CQAAawAAAAMFAAAABnJld2FyZAUAAAAKc2NhbGVWYWx1ZQUAAAAQc2hhcmVUb2tlbkxvY2tlZAQAAAAqcmV3YXJkQWZ0ZXJMYXN0SW50ZXJlc3RCZWZvcmVSZWF3YXJkVXBkYXRlCQAAaAAAAAIFAAAAFnByZXZpb3VzUmV3YXJkUGVyQmxvY2sJAABlAAAAAgUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0BQAAABJsYXN0SW50ZXJlc3RIZWlnaHQEAAAAE2ludGVyZXN0QWZ0ZXJVcGRhdGUJAABkAAAAAgUAAAAMbGFzdEludGVyZXN0CQAAawAAAAMFAAAAKnJld2FyZEFmdGVyTGFzdEludGVyZXN0QmVmb3JlUmVhd2FyZFVwZGF0ZQUAAAAKc2NhbGVWYWx1ZQUAAAAQc2hhcmVUb2tlbkxvY2tlZAQAAAAGcmV3YXJkCQAAaAAAAAIFAAAAFWN1cnJlbnRSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAAAFoBQAAABJyZXdhcmRVcGRhdGVIZWlnaHQJAABkAAAAAgUAAAATaW50ZXJlc3RBZnRlclVwZGF0ZQkAAGsAAAADBQAAAAZyZXdhcmQFAAAACnNjYWxlVmFsdWUFAAAAEHNoYXJlVG9rZW5Mb2NrZWQDCQAAZgAAAAIFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAUAAAABaAQAAAAGcmV3YXJkCQAAaAAAAAIFAAAAFnByZXZpb3VzUmV3YXJkUGVyQmxvY2sJAABlAAAAAgUAAAABaAUAAAASbGFzdEludGVyZXN0SGVpZ2h0CQAAZAAAAAIFAAAADGxhc3RJbnRlcmVzdAkAAGsAAAADBQAAAAZyZXdhcmQFAAAACnNjYWxlVmFsdWUFAAAAEHNoYXJlVG9rZW5Mb2NrZWQDCQAAZgAAAAIFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0BAAAAAZyZXdhcmQJAABoAAAAAgUAAAAVY3VycmVudFJld2FyZFBlckJsb2NrCQAAZQAAAAIFAAAAAWgFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAkAAGQAAAACBQAAAAxsYXN0SW50ZXJlc3QJAABrAAAAAwUAAAAGcmV3YXJkBQAAAApzY2FsZVZhbHVlBQAAABBzaGFyZVRva2VuTG9ja2VkBAAAACpyZXdhcmRBZnRlckxhc3RJbnRlcmVzdEJlZm9yZVJlYXdhcmRVcGRhdGUJAABoAAAAAgUAAAAWcHJldmlvdXNSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAABJyZXdhcmRVcGRhdGVIZWlnaHQFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAQAAAATaW50ZXJlc3RBZnRlclVwZGF0ZQkAAGQAAAACBQAAAAxsYXN0SW50ZXJlc3QJAABrAAAAAwUAAAAqcmV3YXJkQWZ0ZXJMYXN0SW50ZXJlc3RCZWZvcmVSZWF3YXJkVXBkYXRlBQAAAApzY2FsZVZhbHVlBQAAABBzaGFyZVRva2VuTG9ja2VkBAAAAAZyZXdhcmQJAABoAAAAAgUAAAAVY3VycmVudFJld2FyZFBlckJsb2NrCQAAZQAAAAIFAAAAAWgFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAkAAGQAAAACBQAAABNpbnRlcmVzdEFmdGVyVXBkYXRlCQAAawAAAAMFAAAABnJld2FyZAUAAAAKc2NhbGVWYWx1ZQUAAAAQc2hhcmVUb2tlbkxvY2tlZAEAAAAJY2xhaW1DYWxjAAAAAwAAAARwb29sAAAAC3VzZXJBZGRyU3RyAAAAAWgEAAAADHNoYXJlQXNzZXRJZAkBAAAAD2dldFNoYXJlQXNzZXRJZAAAAAEFAAAABHBvb2wEAAAACnNjYWxlVmFsdWUJAQAAAA5jYWxjU2NhbGVWYWx1ZQAAAAIFAAAABFNXT1AFAAAADHNoYXJlQXNzZXRJZAQAAAAQc2hhcmVUb2tlbkxvY2tlZAkBAAAAGGdldFRvdGFsU2hhcmVUb2tlbkxvY2tlZAAAAAEFAAAABHBvb2wEAAAADSR0MDEzMDI3MTMwOTIJAQAAABNnZXRMYXN0SW50ZXJlc3RJbmZvAAAAAQUAAAAEcG9vbAQAAAASbGFzdEludGVyZXN0SGVpZ2h0CAUAAAANJHQwMTMwMjcxMzA5MgAAAAJfMQQAAAAMbGFzdEludGVyZXN0CAUAAAANJHQwMTMwMjcxMzA5MgAAAAJfMgQAAAANJHQwMTMwOTcxMzIwOQkBAAAACnJld2FyZEluZm8AAAABBQAAAARwb29sBAAAABVjdXJyZW50UmV3YXJkUGVyQmxvY2sIBQAAAA0kdDAxMzA5NzEzMjA5AAAAAl8xBAAAABJyZXdhcmRVcGRhdGVIZWlnaHQIBQAAAA0kdDAxMzA5NzEzMjA5AAAAAl8yBAAAABZwcmV2aW91c1Jld2FyZFBlckJsb2NrCAUAAAANJHQwMTMwOTcxMzIwOQAAAAJfMwQAAAAWcG9vbFJld2FyZFVwZGF0ZUhlaWdodAgFAAAADSR0MDEzMDk3MTMyMDkAAAACXzQEAAAADSR0MDEzMjE0MTMyOTgJAQAAABNnZXRVc2VySW50ZXJlc3RJbmZvAAAAAgUAAAAEcG9vbAUAAAALdXNlckFkZHJTdHIEAAAAEHVzZXJMYXN0SW50ZXJlc3QIBQAAAA0kdDAxMzIxNDEzMjk4AAAAAl8xBAAAABV1c2VyU2hhcmVUb2tlbnNBbW91bnQIBQAAAA0kdDAxMzIxNDEzMjk4AAAAAl8yBAAAAA9jdXJyZW50SW50ZXJlc3QJAQAAAAxjYWxjSW50ZXJlc3QAAAAJBQAAABJsYXN0SW50ZXJlc3RIZWlnaHQFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAUAAAAWcG9vbFJld2FyZFVwZGF0ZUhlaWdodAUAAAAMbGFzdEludGVyZXN0BQAAABVjdXJyZW50UmV3YXJkUGVyQmxvY2sFAAAAEHNoYXJlVG9rZW5Mb2NrZWQFAAAAFnByZXZpb3VzUmV3YXJkUGVyQmxvY2sFAAAACnNjYWxlVmFsdWUFAAAAAWgEAAAAC2NsYWltQW1vdW50CQAAawAAAAMFAAAAFXVzZXJTaGFyZVRva2Vuc0Ftb3VudAkAAGUAAAACBQAAAA9jdXJyZW50SW50ZXJlc3QFAAAAEHVzZXJMYXN0SW50ZXJlc3QFAAAACnNjYWxlVmFsdWUEAAAAD3VzZXJOZXdJbnRlcmVzdAUAAAAPY3VycmVudEludGVyZXN0CQAFFgAAAAQFAAAAD3VzZXJOZXdJbnRlcmVzdAUAAAAPY3VycmVudEludGVyZXN0BQAAAAtjbGFpbUFtb3VudAUAAAAVdXNlclNoYXJlVG9rZW5zQW1vdW50AQAAABVjbGFpbUNhbGNGb3JNaWdyYXRpb24AAAADAAAABHBvb2wAAAALdXNlckFkZHJTdHIAAAABaAQAAAAMc2hhcmVBc3NldElkCQEAAAAPZ2V0U2hhcmVBc3NldElkAAAAAQUAAAAEcG9vbAQAAAAKc2NhbGVWYWx1ZQkBAAAADmNhbGNTY2FsZVZhbHVlAAAAAgUAAAAEU1dPUAUAAAAMc2hhcmVBc3NldElkBAAAABBzaGFyZVRva2VuTG9ja2VkCQEAAAAYZ2V0VG90YWxTaGFyZVRva2VuTG9ja2VkAAAAAQUAAAAEcG9vbAQAAAANJHQwMTQwMjExNDA4NgkBAAAAE2dldExhc3RJbnRlcmVzdEluZm8AAAABBQAAAARwb29sBAAAABJsYXN0SW50ZXJlc3RIZWlnaHQIBQAAAA0kdDAxNDAyMTE0MDg2AAAAAl8xBAAAAAxsYXN0SW50ZXJlc3QIBQAAAA0kdDAxNDAyMTE0MDg2AAAAAl8yBAAAAA0kdDAxNDA5MTE0MjAzCQEAAAAKcmV3YXJkSW5mbwAAAAEFAAAABHBvb2wEAAAAFWN1cnJlbnRSZXdhcmRQZXJCbG9jawgFAAAADSR0MDE0MDkxMTQyMDMAAAACXzEEAAAAEnJld2FyZFVwZGF0ZUhlaWdodAgFAAAADSR0MDE0MDkxMTQyMDMAAAACXzIEAAAAFnByZXZpb3VzUmV3YXJkUGVyQmxvY2sIBQAAAA0kdDAxNDA5MTE0MjAzAAAAAl8zBAAAABZwb29sUmV3YXJkVXBkYXRlSGVpZ2h0CAUAAAANJHQwMTQwOTExNDIwMwAAAAJfNAQAAAANJHQwMTQyMDgxNDI5MgkBAAAAE2dldFVzZXJJbnRlcmVzdEluZm8AAAACBQAAAARwb29sBQAAAAt1c2VyQWRkclN0cgQAAAAQdXNlckxhc3RJbnRlcmVzdAgFAAAADSR0MDE0MjA4MTQyOTIAAAACXzEEAAAAFXVzZXJTaGFyZVRva2Vuc0Ftb3VudAgFAAAADSR0MDE0MjA4MTQyOTIAAAACXzIEAAAAD2N1cnJlbnRJbnRlcmVzdAkBAAAADGNhbGNJbnRlcmVzdAAAAAkFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0BQAAABZwb29sUmV3YXJkVXBkYXRlSGVpZ2h0BQAAAAxsYXN0SW50ZXJlc3QFAAAAFWN1cnJlbnRSZXdhcmRQZXJCbG9jawUAAAAQc2hhcmVUb2tlbkxvY2tlZAUAAAAWcHJldmlvdXNSZXdhcmRQZXJCbG9jawUAAAAKc2NhbGVWYWx1ZQUAAAABaAQAAAALY2xhaW1BbW91bnQJAABrAAAAAwUAAAAVdXNlclNoYXJlVG9rZW5zQW1vdW50CQAAZQAAAAIFAAAAD2N1cnJlbnRJbnRlcmVzdAUAAAAQdXNlckxhc3RJbnRlcmVzdAUAAAAKc2NhbGVWYWx1ZQQAAAAPdXNlck5ld0ludGVyZXN0BQAAAA9jdXJyZW50SW50ZXJlc3QJAAUWAAAABAUAAAAPdXNlck5ld0ludGVyZXN0BQAAAA9jdXJyZW50SW50ZXJlc3QFAAAAC2NsYWltQW1vdW50BQAAABV1c2VyU2hhcmVUb2tlbnNBbW91bnQBAAAAF2NhbGN1bGF0ZVByb3RvY29sUmV3YXJkAAAAAQAAAARwb29sBAAAAA0kdDAxNDc5NjE0ODYxCQEAAAATZ2V0TGFzdEludGVyZXN0SW5mbwAAAAEFAAAABHBvb2wEAAAAEmxhc3RJbnRlcmVzdEhlaWdodAgFAAAADSR0MDE0Nzk2MTQ4NjEAAAACXzEEAAAADGxhc3RJbnRlcmVzdAgFAAAADSR0MDE0Nzk2MTQ4NjEAAAACXzIEAAAADSR0MDE0ODY2MTQ5NzcJAQAAAApyZXdhcmRJbmZvAAAAAQUAAAAEcG9vbAQAAAAVY3VycmVudFJld2FyZFBlckJsb2NrCAUAAAANJHQwMTQ4NjYxNDk3NwAAAAJfMQQAAAAScmV3YXJkVXBkYXRlSGVpZ2h0CAUAAAANJHQwMTQ4NjYxNDk3NwAAAAJfMgQAAAAWcHJldmlvdXNSZXdhcmRQZXJCbG9jawgFAAAADSR0MDE0ODY2MTQ5NzcAAAACXzMEAAAAFnBvb2xSZXdhcmRVcGRhdGVIZWlnaHQIBQAAAA0kdDAxNDg2NjE0OTc3AAAAAl80BAAAABBzaGFyZVRva2VuTG9ja2VkCQEAAAAYZ2V0VG90YWxTaGFyZVRva2VuTG9ja2VkAAAAAQUAAAAEcG9vbAMDCQAAAAAAAAIFAAAAEHNoYXJlVG9rZW5Mb2NrZWQAAAAAAAAAAAAJAAAAAAAAAgUAAAAWcG9vbFJld2FyZFVwZGF0ZUhlaWdodAAAAAAAAAAAAAcDCQAAZgAAAAIFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAUAAAAGaGVpZ2h0BAAAAAZyZXdhcmQJAABoAAAAAgUAAAAWcHJldmlvdXNSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAAAZoZWlnaHQFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAUAAAAGcmV3YXJkAwkAAGYAAAACBQAAABJsYXN0SW50ZXJlc3RIZWlnaHQFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAQAAAAGcmV3YXJkCQAAaAAAAAIFAAAAFWN1cnJlbnRSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAAAZoZWlnaHQFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAUAAAAGcmV3YXJkBAAAACpyZXdhcmRBZnRlckxhc3RJbnRlcmVzdEJlZm9yZVJlYXdhcmRVcGRhdGUJAABoAAAAAgUAAAAWcHJldmlvdXNSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAABJyZXdhcmRVcGRhdGVIZWlnaHQFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAQAAAAGcmV3YXJkCQAAaAAAAAIFAAAAFWN1cnJlbnRSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAAAZoZWlnaHQFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAkAAGQAAAACBQAAAAZyZXdhcmQFAAAAKnJld2FyZEFmdGVyTGFzdEludGVyZXN0QmVmb3JlUmVhd2FyZFVwZGF0ZQMDCQAAAAAAAAIFAAAAEHNoYXJlVG9rZW5Mb2NrZWQAAAAAAAAAAAAJAQAAAAIhPQAAAAIFAAAAFnBvb2xSZXdhcmRVcGRhdGVIZWlnaHQAAAAAAAAAAAAHAwMJAABmAAAAAgUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0BQAAAAZoZWlnaHQJAAAAAAAAAgUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0BQAAABZwb29sUmV3YXJkVXBkYXRlSGVpZ2h0BwQAAAAGcmV3YXJkCQAAaAAAAAIFAAAAFnByZXZpb3VzUmV3YXJkUGVyQmxvY2sJAABlAAAAAgUAAAAGaGVpZ2h0BQAAABJsYXN0SW50ZXJlc3RIZWlnaHQFAAAABnJld2FyZAMDCQAAZgAAAAIFAAAABmhlaWdodAUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0CQEAAAACIT0AAAACBQAAABJyZXdhcmRVcGRhdGVIZWlnaHQFAAAAFnBvb2xSZXdhcmRVcGRhdGVIZWlnaHQHBAAAAAZyZXdhcmQJAABoAAAAAgUAAAAWcHJldmlvdXNSZXdhcmRQZXJCbG9jawkAAGUAAAACBQAAAAZoZWlnaHQFAAAAEmxhc3RJbnRlcmVzdEhlaWdodAUAAAAGcmV3YXJkAwMDCQAAZgAAAAIFAAAABmhlaWdodAUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0CQAAAAAAAAIFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAUAAAAWcG9vbFJld2FyZFVwZGF0ZUhlaWdodAcJAABmAAAAAgUAAAASbGFzdEludGVyZXN0SGVpZ2h0BQAAABJyZXdhcmRVcGRhdGVIZWlnaHQHBAAAAAZyZXdhcmQJAABoAAAAAgUAAAAVY3VycmVudFJld2FyZFBlckJsb2NrCQAAZQAAAAIFAAAABmhlaWdodAUAAAASbGFzdEludGVyZXN0SGVpZ2h0BQAAAAZyZXdhcmQEAAAAKnJld2FyZEFmdGVyTGFzdEludGVyZXN0QmVmb3JlUmVhd2FyZFVwZGF0ZQkAAGgAAAACBQAAABZwcmV2aW91c1Jld2FyZFBlckJsb2NrCQAAZQAAAAIFAAAAEnJld2FyZFVwZGF0ZUhlaWdodAUAAAASbGFzdEludGVyZXN0SGVpZ2h0BAAAAAZyZXdhcmQJAABoAAAAAgUAAAAVY3VycmVudFJld2FyZFBlckJsb2NrCQAAZQAAAAIFAAAABmhlaWdodAUAAAAScmV3YXJkVXBkYXRlSGVpZ2h0CQAAZAAAAAIFAAAABnJld2FyZAUAAAAqcmV3YXJkQWZ0ZXJMYXN0SW50ZXJlc3RCZWZvcmVSZWF3YXJkVXBkYXRlAAAAAAAAAAAAAQAAABZjaGVja1BtdEFzc2V0SWRDb3JyZWN0AAAAAgAAAARwb29sAAAACnBtdEFzc2V0SWQEAAAAEHBvb2xTaGFyZUFzc2V0SWQJAAJZAAAAAQkBAAAAEUBleHRyTmF0aXZlKDEwNTMpAAAAAgkBAAAABXZhbHVlAAAAAQkABCYAAAABBQAAAARwb29sAgAAAA5zaGFyZV9hc3NldF9pZAMJAAAAAAAAAgUAAAAKcG10QXNzZXRJZAUAAAAQcG9vbFNoYXJlQXNzZXRJZAYHAQAAABhnZXRVc2VyU1dPUENsYWltZWRBbW91bnQAAAACAAAABHBvb2wAAAAEdXNlcgkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAARwb29sAgAAAAFfBQAAAAR1c2VyBQAAABhrZXlVc2VyU1dPUENsYWltZWRBbW91bnQAAAAAAAAAAAABAAAAB3N1c3BlbmQAAAABAAAABWNhdXNlCQAETAAAAAIJAQAAAAxCb29sZWFuRW50cnkAAAACBQAAAAlrZXlBY3RpdmUHCQAETAAAAAIJAQAAAAtTdHJpbmdFbnRyeQAAAAIFAAAACGtleUNhdXNlBQAAAAVjYXVzZQUAAAADbmlsAAAABgAAAAFpAQAAAARpbml0AAAAAQAAAAdlYXJseUxQAwkBAAAACWlzRGVmaW5lZAAAAAEJAAQdAAAAAgUAAAAEdGhpcwUAAAAJa2V5U1dPUGlkCQAAAgAAAAECAAAAGFNXT1AgYWxyZWFkeSBpbml0aWFsaXplZAQAAAAKaW5pdEFtb3VudAAAAFrzEHpAAAQAAAAJU1dPUGlzc3VlCQAEQgAAAAUCAAAABFNXT1ACAAAAE1NXT1AgcHJvdG9jb2wgdG9rZW4FAAAACmluaXRBbW91bnQAAAAAAAAAAAgGBAAAAAZTV09QaWQJAAQ4AAAAAQUAAAAJU1dPUGlzc3VlCQAETAAAAAIJAQAAAAxCb29sZWFuRW50cnkAAAACBQAAAAlrZXlBY3RpdmUGCQAETAAAAAIJAARCAAAABQIAAAAEU1dPUAIAAAATU1dPUCBwcm90b2NvbCB0b2tlbgUAAAAKaW5pdEFtb3VudAAAAAAAAAAACAYJAARMAAAAAgkBAAAAC1N0cmluZ0VudHJ5AAAAAgUAAAAJa2V5U1dPUGlkCQACWAAAAAEFAAAABlNXT1BpZAUAAAADbmlsAAAAAWkBAAAABGVnZzAAAAADAAAABHBvb2wAAAAFdXNlcnMAAAAPbWlncmF0aW9uSGVpZ2h0AwMJAQAAAAIhPQAAAAIFAAAABHBvb2wCAAAAIzNNeDZ3QkZ6UEpHMmhVV05MeTJtZWk4WkhidG1SWjZKSlRHCQEAAAACIT0AAAACBQAAAARwb29sAgAAACMzTXJ3ZThCTUZYTFZkR2NCaGRmM1Q5WU5VbnJVRU1Ia0RBOAcJAQAAAAV0aHJvdwAAAAAKAQAAAAp1cGRhdGVVc2VyAAAAAgAAAAVhY2N1bQAAAAF1BAAAAAFyCQAD/AAAAAQFAAAABHRoaXMCAAAABGVnZzEJAARMAAAAAgUAAAAEcG9vbAkABEwAAAACBQAAAAF1CQAETAAAAAIFAAAAD21pZ3JhdGlvbkhlaWdodAUAAAADbmlsBQAAAANuaWwDCQAAAAAAAAIFAAAAAXIFAAAAAXIJAARNAAAAAgUAAAAFYWNjdW0JAQAAAAxCb29sZWFuRW50cnkAAAACCQABLAAAAAIFAAAAAXUCAAAACl9taWdyYXRpb24GCQAAAgAAAAECAAAAJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQAAAAPJGxpc3QxODIwMDE4MjMxBQAAAAV1c2VycwQAAAAPJHNpemUxODIwMDE4MjMxCQABkAAAAAEFAAAADyRsaXN0MTgyMDAxODIzMQQAAAAPJGFjYzAxODIwMDE4MjMxBQAAAANuaWwDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAAAUAAAAPJGFjYzAxODIwMDE4MjMxBAAAAA8kYWNjMTE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAPJGFjYzAxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAAAMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAABBQAAAA8kYWNjMTE4MjAwMTgyMzEEAAAADyRhY2MyMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAAA8kYWNjMTE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAABAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAAAIFAAAADyRhY2MyMTgyMDAxODIzMQQAAAAPJGFjYzMxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAADyRhY2MyMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAAIDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAAwUAAAAPJGFjYzMxODIwMDE4MjMxBAAAAA8kYWNjNDE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAPJGFjYzMxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAAwMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAEBQAAAA8kYWNjNDE4MjAwMTgyMzEEAAAADyRhY2M1MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAAA8kYWNjNDE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAEAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAAAUFAAAADyRhY2M1MTgyMDAxODIzMQQAAAAPJGFjYzYxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAADyRhY2M1MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAAUDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAABgUAAAAPJGFjYzYxODIwMDE4MjMxBAAAAA8kYWNjNzE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAPJGFjYzYxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAABgMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAHBQAAAA8kYWNjNzE4MjAwMTgyMzEEAAAADyRhY2M4MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAAA8kYWNjNzE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAHAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAAAgFAAAADyRhY2M4MTgyMDAxODIzMQQAAAAPJGFjYzkxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAADyRhY2M4MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAAgDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAACQUAAAAPJGFjYzkxODIwMDE4MjMxBAAAABAkYWNjMTAxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAADyRhY2M5MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAAkDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAACgUAAAAQJGFjYzEwMTgyMDAxODIzMQQAAAAQJGFjYzExMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMTAxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAACgMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAALBQAAABAkYWNjMTExODIwMDE4MjMxBAAAABAkYWNjMTIxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MxMTE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAALAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAAAwFAAAAECRhY2MxMjE4MjAwMTgyMzEEAAAAECRhY2MxMzE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzEyMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAAwDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAADQUAAAAQJGFjYzEzMTgyMDAxODIzMQQAAAAQJGFjYzE0MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMTMxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAADQMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAOBQAAABAkYWNjMTQxODIwMDE4MjMxBAAAABAkYWNjMTUxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MxNDE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAOAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAAA8FAAAAECRhY2MxNTE4MjAwMTgyMzEEAAAAECRhY2MxNjE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzE1MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAA8DCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAEAUAAAAQJGFjYzE2MTgyMDAxODIzMQQAAAAQJGFjYzE3MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMTYxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAEAMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAARBQAAABAkYWNjMTcxODIwMDE4MjMxBAAAABAkYWNjMTgxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MxNzE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAARAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAABIFAAAAECRhY2MxODE4MjAwMTgyMzEEAAAAECRhY2MxOTE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzE4MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAABIDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAEwUAAAAQJGFjYzE5MTgyMDAxODIzMQQAAAAQJGFjYzIwMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMTkxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAEwMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAUBQAAABAkYWNjMjAxODIwMDE4MjMxBAAAABAkYWNjMjExODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MyMDE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAUAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAABUFAAAAECRhY2MyMTE4MjAwMTgyMzEEAAAAECRhY2MyMjE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzIxMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAABUDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAFgUAAAAQJGFjYzIyMTgyMDAxODIzMQQAAAAQJGFjYzIzMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMjIxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAFgMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAXBQAAABAkYWNjMjMxODIwMDE4MjMxBAAAABAkYWNjMjQxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MyMzE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAXAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAABgFAAAAECRhY2MyNDE4MjAwMTgyMzEEAAAAECRhY2MyNTE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzI0MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAABgDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAGQUAAAAQJGFjYzI1MTgyMDAxODIzMQQAAAAQJGFjYzI2MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMjUxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAGQMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAaBQAAABAkYWNjMjYxODIwMDE4MjMxBAAAABAkYWNjMjcxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MyNjE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAaAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAABsFAAAAECRhY2MyNzE4MjAwMTgyMzEEAAAAECRhY2MyODE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzI3MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAABsDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAHAUAAAAQJGFjYzI4MTgyMDAxODIzMQQAAAAQJGFjYzI5MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMjgxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAHAMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAdBQAAABAkYWNjMjkxODIwMDE4MjMxBAAAABAkYWNjMzAxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MyOTE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAdAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAAB4FAAAAECRhY2MzMDE4MjAwMTgyMzEEAAAAECRhY2MzMTE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzMwMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAB4DCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAHwUAAAAQJGFjYzMxMTgyMDAxODIzMQQAAAAQJGFjYzMyMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMzExODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAHwMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAgBQAAABAkYWNjMzIxODIwMDE4MjMxBAAAABAkYWNjMzMxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MzMjE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAgAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAACEFAAAAECRhY2MzMzE4MjAwMTgyMzEEAAAAECRhY2MzNDE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzMzMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAACEDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAIgUAAAAQJGFjYzM0MTgyMDAxODIzMQQAAAAQJGFjYzM1MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMzQxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAIgMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAjBQAAABAkYWNjMzUxODIwMDE4MjMxBAAAABAkYWNjMzYxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MzNTE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAjAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAACQFAAAAECRhY2MzNjE4MjAwMTgyMzEEAAAAECRhY2MzNzE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzM2MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAACQDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAJQUAAAAQJGFjYzM3MTgyMDAxODIzMQQAAAAQJGFjYzM4MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjMzcxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAJQMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAmBQAAABAkYWNjMzgxODIwMDE4MjMxBAAAABAkYWNjMzkxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2MzODE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAmAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAACcFAAAAECRhY2MzOTE4MjAwMTgyMzEEAAAAECRhY2M0MDE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzM5MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAACcDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAKAUAAAAQJGFjYzQwMTgyMDAxODIzMQQAAAAQJGFjYzQxMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjNDAxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAKAMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAApBQAAABAkYWNjNDExODIwMDE4MjMxBAAAABAkYWNjNDIxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2M0MTE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAApAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAACoFAAAAECRhY2M0MjE4MjAwMTgyMzEEAAAAECRhY2M0MzE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzQyMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAACoDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAKwUAAAAQJGFjYzQzMTgyMDAxODIzMQQAAAAQJGFjYzQ0MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjNDMxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAKwMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAsBQAAABAkYWNjNDQxODIwMDE4MjMxBAAAABAkYWNjNDUxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2M0NDE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAsAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAAC0FAAAAECRhY2M0NTE4MjAwMTgyMzEEAAAAECRhY2M0NjE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzQ1MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAAC0DCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAALgUAAAAQJGFjYzQ2MTgyMDAxODIzMQQAAAAQJGFjYzQ3MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjNDYxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAALgMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAvBQAAABAkYWNjNDcxODIwMDE4MjMxBAAAABAkYWNjNDgxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2M0NzE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAvAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAADAFAAAAECRhY2M0ODE4MjAwMTgyMzEEAAAAECRhY2M0OTE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzQ4MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAADADCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAMQUAAAAQJGFjYzQ5MTgyMDAxODIzMQQAAAAQJGFjYzUwMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjNDkxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAMQMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAAyBQAAABAkYWNjNTAxODIwMDE4MjMxBAAAABAkYWNjNTExODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2M1MDE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAAyAwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAADMFAAAAECRhY2M1MTE4MjAwMTgyMzEEAAAAECRhY2M1MjE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzUxMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAADMDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAANAUAAAAQJGFjYzUyMTgyMDAxODIzMQQAAAAQJGFjYzUzMTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjNTIxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAANAMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAA1BQAAABAkYWNjNTMxODIwMDE4MjMxBAAAABAkYWNjNTQxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2M1MzE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAA1AwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAADYFAAAAECRhY2M1NDE4MjAwMTgyMzEEAAAAECRhY2M1NTE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzU0MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAADYDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAANwUAAAAQJGFjYzU1MTgyMDAxODIzMQQAAAAQJGFjYzU2MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjNTUxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAANwMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAA4BQAAABAkYWNjNTYxODIwMDE4MjMxBAAAABAkYWNjNTcxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2M1NjE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAA4AwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAADkFAAAAECRhY2M1NzE4MjAwMTgyMzEEAAAAECRhY2M1ODE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzU3MTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAADkDCQAAAAAAAAIFAAAADyRzaXplMTgyMDAxODIzMQAAAAAAAAAAOgUAAAAQJGFjYzU4MTgyMDAxODIzMQQAAAAQJGFjYzU5MTgyMDAxODIzMQkBAAAACnVwZGF0ZVVzZXIAAAACBQAAABAkYWNjNTgxODIwMDE4MjMxCQABkQAAAAIFAAAADyRsaXN0MTgyMDAxODIzMQAAAAAAAAAAOgMJAAAAAAAAAgUAAAAPJHNpemUxODIwMDE4MjMxAAAAAAAAAAA7BQAAABAkYWNjNTkxODIwMDE4MjMxBAAAABAkYWNjNjAxODIwMDE4MjMxCQEAAAAKdXBkYXRlVXNlcgAAAAIFAAAAECRhY2M1OTE4MjAwMTgyMzEJAAGRAAAAAgUAAAAPJGxpc3QxODIwMDE4MjMxAAAAAAAAAAA7AwkAAAAAAAACBQAAAA8kc2l6ZTE4MjAwMTgyMzEAAAAAAAAAADwFAAAAECRhY2M2MDE4MjAwMTgyMzEEAAAAECRhY2M2MTE4MjAwMTgyMzEJAQAAAAp1cGRhdGVVc2VyAAAAAgUAAAAQJGFjYzYwMTgyMDAxODIzMQkAAZEAAAACBQAAAA8kbGlzdDE4MjAwMTgyMzEAAAAAAAAAADwJAAACAAAAAQIAAAATTGlzdCBzaXplIGV4Y2VlZCA2MAAAAAFpAQAAAARlZ2cxAAAAAwAAAARwb29sAAAAAXUAAAAPbWlncmF0aW9uSGVpZ2h0BAAAABRzaGFyZVRva2VuTXVsdGlwbHllcgAAAAAAAAAD6AQAAAANJHQwMTgzNDgxODQ2MAkBAAAACWNsYWltQ2FsYwAAAAMFAAAABHBvb2wFAAAAAXUFAAAAD21pZ3JhdGlvbkhlaWdodAQAAAAPdXNlck5ld0ludGVyZXN0CAUAAAANJHQwMTgzNDgxODQ2MAAAAAJfMQQAAAAPY3VycmVudEludGVyZXN0CAUAAAANJHQwMTgzNDgxODQ2MAAAAAJfMgQAAAALY2xhaW1BbW91bnQIBQAAAA0kdDAxODM0ODE4NDYwAAAAAl8zBAAAABV1c2VyU2hhcmVUb2tlbnNBbW91bnQIBQAAAA0kdDAxODM0ODE4NDYwAAAAAl80BAAAABFhdmFpbGFibGVGdW5kc05ldwkAAGQAAAACCQEAAAARdXNlckF2YWlsYWJsZVNXT1AAAAACBQAAAARwb29sBQAAAAF1BQAAAAtjbGFpbUFtb3VudAQAAAARdXNlckNsYWltZWRBbW91bnQJAQAAABhnZXRVc2VyU1dPUENsYWltZWRBbW91bnQAAAACBQAAAARwb29sBQAAAAF1BAAAABR1c2VyQ2xhaW1lZEFtb3VudE5ldwkAAGQAAAACBQAAABF1c2VyQ2xhaW1lZEFtb3VudAUAAAALY2xhaW1BbW91bnQEAAAAGHVzZXJTaGFyZVRva2Vuc0Ftb3VudE5ldwkAAGgAAAACBQAAABV1c2VyU2hhcmVUb2tlbnNBbW91bnQFAAAAFHNoYXJlVG9rZW5NdWx0aXBseWVyBAAAAB50b3RhbEFtb3VudE5ld1NoYXJlVG9rZW5Mb2NrZWQJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACCQABLAAAAAIFAAAABHBvb2wCAAAAAV8CAAAAInRvdGFsX2Ftb3VudF9uZXdfc2hhcmV0b2tlbl9sb2NrZWQAAAAAAAAAAAAJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIFAAAABHBvb2wCAAAAAV8FAAAAAXUFAAAAE2tleVVzZXJMYXN0SW50ZXJlc3QAAAAAAAAAAAAJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIFAAAABHBvb2wCAAAAAV8FAAAAAXUFAAAAGGtleVVzZXJTaGFyZVRva2Vuc0xvY2tlZAUAAAAYdXNlclNoYXJlVG9rZW5zQW1vdW50TmV3CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAARwb29sAgAAAAFfBQAAAAF1BQAAABBrZXlBdmFpbGFibGVTV09QBQAAABFhdmFpbGFibGVGdW5kc05ldwkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgUAAAAEcG9vbAIAAAABXwkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIFAAAAGGtleVVzZXJTV09QQ2xhaW1lZEFtb3VudAUAAAAUdXNlckNsYWltZWRBbW91bnROZXcJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIFAAAABHBvb2wCAAAAAV8JAAQlAAAAAQgFAAAAAWkAAAAGY2FsbGVyBQAAABxrZXlVc2VyU1dPUExhc3RDbGFpbWVkQW1vdW50BQAAAAtjbGFpbUFtb3VudAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkAASwAAAACCQABLAAAAAIFAAAABHBvb2wCAAAAAV8CAAAAInRvdGFsX2Ftb3VudF9uZXdfc2hhcmV0b2tlbl9sb2NrZWQJAABkAAAAAgUAAAAedG90YWxBbW91bnROZXdTaGFyZVRva2VuTG9ja2VkBQAAABh1c2VyU2hhcmVUb2tlbnNBbW91bnROZXcFAAAAA25pbAAAAAFpAQAAABx1cGRhdGVUb3RhbFNoYXJlVG9rZW5zTG9ja2VkAAAAAgAAAARwb29sAAAAD21pZ3JhdGlvbkhlaWdodAQAAAAUc2hhcmVUb2tlbk11bHRpcGx5ZXIAAAAAAAAAA+gEAAAAInRvdGFsQW1vdW50U2hhcmVUb2tlbnNMb2NrZWRCZWZvcmUJAABoAAAAAgkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAARwb29sBQAAABRrZXlTaGFyZVRva2Vuc0xvY2tlZAAAAAAAAAAD6AQAAAAfdG90YWxBbW91bnRTaGFyZVRva2Vuc0xvY2tlZE5ldwkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgUAAAAEdGhpcwkAASwAAAACCQABLAAAAAIFAAAABHBvb2wCAAAAAV8CAAAAInRvdGFsX2Ftb3VudF9uZXdfc2hhcmV0b2tlbl9sb2NrZWQDCQEAAAACIT0AAAACBQAAACJ0b3RhbEFtb3VudFNoYXJlVG9rZW5zTG9ja2VkQmVmb3JlBQAAAB90b3RhbEFtb3VudFNoYXJlVG9rZW5zTG9ja2VkTmV3CQAAAgAAAAECAAAAMk5ldyB0b3RhbCBhbW91bnQgc2hhcmUgdG9ja2VucyAhPSBvbGQgdG90YWwgYW1vdW50CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAIFAAAABHBvb2wFAAAAD2tleUxhc3RJbnRlcmVzdAAAAAAAAAAAAAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkAASwAAAACBQAAAARwb29sBQAAABVrZXlMYXN0SW50ZXJlc3RIZWlnaHQFAAAAD21pZ3JhdGlvbkhlaWdodAUAAAADbmlsAAAAAWkBAAAACHNodXRkb3duAAAAAAMJAQAAAAEhAAAAAQUAAAAIaXNBY3RpdmUJAAACAAAAAQkAASwAAAACAgAAACJEQXBwIGlzIGFscmVhZHkgc3VzcGVuZGVkLiBDYXVzZTogCQEAAAALdmFsdWVPckVsc2UAAAACCQAEHQAAAAIFAAAABHRoaXMFAAAACGtleUNhdXNlAgAAABp0aGUgY2F1c2Ugd2Fzbid0IHNwZWNpZmllZAMJAQAAAAEhAAAAAQkBAAAAD2NvbnRhaW5zRWxlbWVudAAAAAIJAARMAAAAAgUAAAAMYWRtaW5QdWJLZXkxCQAETAAAAAIFAAAADGFkbWluUHViS2V5MgkABEwAAAACBQAAAAxhZG1pblB1YktleTMFAAAAA25pbAgFAAAAAWkAAAAPY2FsbGVyUHVibGljS2V5CQAAAgAAAAECAAAAIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgkBAAAAB3N1c3BlbmQAAAABAgAAAA9QYXVzZWQgYnkgYWRtaW4AAAABaQEAAAAIYWN0aXZhdGUAAAAAAwUAAAAIaXNBY3RpdmUJAAACAAAAAQIAAAAWREFwcCBpcyBhbHJlYWR5IGFjdGl2ZQMJAQAAAAEhAAAAAQkBAAAAD2NvbnRhaW5zRWxlbWVudAAAAAIJAARMAAAAAgUAAAAMYWRtaW5QdWJLZXkxCQAETAAAAAIFAAAADGFkbWluUHViS2V5MgkABEwAAAACBQAAAAxhZG1pblB1YktleTMFAAAAA25pbAgFAAAAAWkAAAAPY2FsbGVyUHVibGljS2V5CQAAAgAAAAECAAAAIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgkABEwAAAACCQEAAAAMQm9vbGVhbkVudHJ5AAAAAgUAAAAJa2V5QWN0aXZlBgkABEwAAAACCQEAAAALRGVsZXRlRW50cnkAAAABBQAAAAhrZXlDYXVzZQUAAAADbmlsAAAAAQAAAAJ0eAEAAAAGdmVyaWZ5AAAAAAQAAAAHJG1hdGNoMAUAAAACdHgEAAAAEmFkbWluUHViS2V5MVNpZ25lZAMJAAH0AAAAAwgFAAAAAnR4AAAACWJvZHlCeXRlcwkAAZEAAAACCAUAAAACdHgAAAAGcHJvb2ZzAAAAAAAAAAAABQAAAAxhZG1pblB1YktleTEAAAAAAAAAAAEAAAAAAAAAAAAEAAAAEmFkbWluUHViS2V5MlNpZ25lZAMJAAH0AAAAAwgFAAAAAnR4AAAACWJvZHlCeXRlcwkAAZEAAAACCAUAAAACdHgAAAAGcHJvb2ZzAAAAAAAAAAABBQAAAAxhZG1pblB1YktleTIAAAAAAAAAAAEAAAAAAAAAAAAEAAAAEmFkbWluUHViS2V5M1NpZ25lZAMJAAH0AAAAAwgFAAAAAnR4AAAACWJvZHlCeXRlcwkAAZEAAAACCAUAAAACdHgAAAAGcHJvb2ZzAAAAAAAAAAACBQAAAAxhZG1pblB1YktleTMAAAAAAAAAAAEAAAAAAAAAAAAJAABnAAAAAgkAAGQAAAACCQAAZAAAAAIFAAAAEmFkbWluUHViS2V5MVNpZ25lZAUAAAASYWRtaW5QdWJLZXkyU2lnbmVkBQAAABJhZG1pblB1YktleTNTaWduZWQAAAAAAAAAAAISSvlF", "height": 1701442, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: HJLBrT6fYGERdCCnkcQ42NfMeD25rk2CANR2vH4X87Wy Next: J6ABghUW2KsfFVDNWucZuGU3nNDeDt7jYLWNL2G4fYQD Diff:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let adminPubKey1 = base58'GFmKZ2naZFRoCvNbwKAQVGmLb1uBeWGDgFabdGBuZiuy' | |
5 | + | ||
6 | + | let adminPubKey2 = base58'GmJXRyhRA79g8yUGgKBAVdnFfQFDMjQG98b1MmLDh5kk' | |
7 | + | ||
8 | + | let adminPubKey3 = base58'CFhbV6h41hVjbGHudGtS3fYUv7QAKRxFQzKNtx4B5PqP' | |
9 | + | ||
4 | 10 | let keyShareTokensLocked = "_total_share_tokens_locked" | |
5 | 11 | ||
6 | 12 | let kShareLimit = "share_limit_on_first_harvest" | |
90 | 96 | let scaleValue8 = 100000000 | |
91 | 97 | ||
92 | 98 | let scaleValue11 = 100000000000 | |
93 | - | ||
94 | - | let keyAdminPubKey1 = "admin_pub_1" | |
95 | - | ||
96 | - | let keyAdminPubKey2 = "admin_pub_2" | |
97 | - | ||
98 | - | let keyAdminPubKey3 = "admin_pub_3" | |
99 | - | ||
100 | - | let oracle = Address(base58'3NBBWfzZtZtszaXbitTKnrB2xXwv26Bn7H9') | |
101 | - | ||
102 | - | func getAdminPub (keyAdminPub) = match getString(oracle, keyAdminPub) { | |
103 | - | case string: String => | |
104 | - | fromBase58String(string) | |
105 | - | case nothing => | |
106 | - | throw("Admin public key is empty") | |
107 | - | } | |
108 | - | ||
109 | - | ||
110 | - | let adminPubKey1 = getAdminPub(keyAdminPubKey1) | |
111 | - | ||
112 | - | let adminPubKey2 = getAdminPub(keyAdminPubKey2) | |
113 | - | ||
114 | - | let adminPubKey3 = getAdminPub(keyAdminPubKey3) | |
115 | 99 | ||
116 | 100 | func strAssetIdA (pool) = getStringValue(pool, keyAssetIdA) | |
117 | 101 | ||
231 | 215 | let assetId1Decimals = value(assetInfo(assetId1)).decimals | |
232 | 216 | let assetId2Decimals = value(assetInfo(assetId2)).decimals | |
233 | 217 | let scaleDigits = ((assetId2Decimals - assetId1Decimals) + 8) | |
234 | - | pow(10, 0, scaleDigits, 0, 0, | |
218 | + | pow(10, 0, scaleDigits, 0, 0, FLOOR) | |
235 | 219 | } | |
236 | 220 | ||
237 | 221 | ||
238 | - | func userAvailableSWOP (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + | |
222 | + | func userAvailableSWOP (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + user) + keyAvailableSWOP)), 0) | |
239 | 223 | ||
240 | 224 | ||
241 | 225 | func rewardInfo (pool) = { | |
262 | 246 | } | |
263 | 247 | ||
264 | 248 | ||
265 | - | func getUserInterestInfo (pool, | |
266 | - | let userLastInterest = getInteger(this, (((pool + "_") + | |
267 | - | let userShare = getInteger(this, (((pool + "_") + | |
249 | + | func getUserInterestInfo (pool,userAddrStr) = { | |
250 | + | let userLastInterest = getInteger(this, (((pool + "_") + userAddrStr) + keyUserLastInterest)) | |
251 | + | let userShare = getInteger(this, (((pool + "_") + userAddrStr) + keyUserShareTokensLocked)) | |
268 | 252 | let lastInterest = valueOrErrorMessage(getInteger(this, (pool + keyLastInterest)), (("No data on the key: " + pool) + keyLastInterest)) | |
269 | 253 | let userLastInterestValue = match userLastInterest { | |
270 | 254 | case userLastInterest: Int => | |
282 | 266 | } | |
283 | 267 | ||
284 | 268 | ||
285 | - | func calcInterest (lastInterestHeight,rewardUpdateHeight,poolRewardUpdateHeight,lastInterest,currentRewardPerBlock,shareTokenLocked,previousRewardPerBlock, | |
269 | + | func calcInterest (lastInterestHeight,rewardUpdateHeight,poolRewardUpdateHeight,lastInterest,currentRewardPerBlock,shareTokenLocked,previousRewardPerBlock,scaleValue,h) = if ((shareTokenLocked == 0)) | |
286 | 270 | then 0 | |
287 | 271 | else if ((poolRewardUpdateHeight != 0)) | |
288 | - | then if (if ((rewardUpdateHeight > | |
272 | + | then if (if ((rewardUpdateHeight > h)) | |
289 | 273 | then (rewardUpdateHeight == poolRewardUpdateHeight) | |
290 | 274 | else false) | |
291 | 275 | then { | |
292 | - | let reward = (previousRewardPerBlock * ( | |
276 | + | let reward = (previousRewardPerBlock * (h - lastInterestHeight)) | |
293 | 277 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
294 | 278 | } | |
295 | - | else if (if (( | |
279 | + | else if (if ((h > rewardUpdateHeight)) | |
296 | 280 | then (rewardUpdateHeight != poolRewardUpdateHeight) | |
297 | 281 | else false) | |
298 | 282 | then { | |
299 | - | let reward = (previousRewardPerBlock * ( | |
283 | + | let reward = (previousRewardPerBlock * (h - lastInterestHeight)) | |
300 | 284 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
301 | 285 | } | |
302 | - | else if (if (if (( | |
286 | + | else if (if (if ((h > rewardUpdateHeight)) | |
303 | 287 | then (rewardUpdateHeight == poolRewardUpdateHeight) | |
304 | 288 | else false) | |
305 | 289 | then (lastInterestHeight > rewardUpdateHeight) | |
306 | 290 | else false) | |
307 | 291 | then { | |
308 | - | let reward = (currentRewardPerBlock * ( | |
292 | + | let reward = (currentRewardPerBlock * (h - lastInterestHeight)) | |
309 | 293 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
310 | 294 | } | |
311 | 295 | else { | |
312 | 296 | let rewardAfterLastInterestBeforeReawardUpdate = (previousRewardPerBlock * (rewardUpdateHeight - lastInterestHeight)) | |
313 | 297 | let interestAfterUpdate = (lastInterest + fraction(rewardAfterLastInterestBeforeReawardUpdate, scaleValue, shareTokenLocked)) | |
314 | - | let reward = (currentRewardPerBlock * ( | |
298 | + | let reward = (currentRewardPerBlock * (h - rewardUpdateHeight)) | |
315 | 299 | (interestAfterUpdate + fraction(reward, scaleValue, shareTokenLocked)) | |
316 | 300 | } | |
317 | - | else if ((rewardUpdateHeight > | |
301 | + | else if ((rewardUpdateHeight > h)) | |
318 | 302 | then { | |
319 | - | let reward = (previousRewardPerBlock * ( | |
303 | + | let reward = (previousRewardPerBlock * (h - lastInterestHeight)) | |
320 | 304 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
321 | 305 | } | |
322 | 306 | else if ((lastInterestHeight > rewardUpdateHeight)) | |
323 | 307 | then { | |
324 | - | let reward = (currentRewardPerBlock * ( | |
308 | + | let reward = (currentRewardPerBlock * (h - lastInterestHeight)) | |
325 | 309 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
326 | 310 | } | |
327 | 311 | else { | |
328 | 312 | let rewardAfterLastInterestBeforeReawardUpdate = (previousRewardPerBlock * (rewardUpdateHeight - lastInterestHeight)) | |
329 | 313 | let interestAfterUpdate = (lastInterest + fraction(rewardAfterLastInterestBeforeReawardUpdate, scaleValue, shareTokenLocked)) | |
330 | - | let reward = (currentRewardPerBlock * ( | |
314 | + | let reward = (currentRewardPerBlock * (h - rewardUpdateHeight)) | |
331 | 315 | (interestAfterUpdate + fraction(reward, scaleValue, shareTokenLocked)) | |
332 | 316 | } | |
333 | 317 | ||
334 | 318 | ||
335 | - | func claimCalc (pool, | |
319 | + | func claimCalc (pool,userAddrStr,h) = { | |
336 | 320 | let shareAssetId = getShareAssetId(pool) | |
337 | 321 | let scaleValue = calcScaleValue(SWOP, shareAssetId) | |
338 | 322 | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
339 | - | let $t01344513510 = getLastInterestInfo(pool) | |
340 | - | let lastInterestHeight = $t01344513510._1 | |
341 | - | let lastInterest = $t01344513510._2 | |
342 | - | let $t01351513627 = rewardInfo(pool) | |
343 | - | let currentRewardPerBlock = $t01351513627._1 | |
344 | - | let rewardUpdateHeight = $t01351513627._2 | |
345 | - | let previousRewardPerBlock = $t01351513627._3 | |
346 | - | let poolRewardUpdateHeight = $t01351513627._4 | |
347 | - | let $t01363213711 = getUserInterestInfo(pool, caller) | |
348 | - | let userLastInterest = $t01363213711._1 | |
349 | - | let userShareTokensAmount = $t01363213711._2 | |
350 | - | let currentInterest = calcInterest(lastInterestHeight, rewardUpdateHeight, poolRewardUpdateHeight, lastInterest, currentRewardPerBlock, shareTokenLocked, previousRewardPerBlock, shareAssetId, scaleValue, pmtAmount) | |
323 | + | let $t01302713092 = getLastInterestInfo(pool) | |
324 | + | let lastInterestHeight = $t01302713092._1 | |
325 | + | let lastInterest = $t01302713092._2 | |
326 | + | let $t01309713209 = rewardInfo(pool) | |
327 | + | let currentRewardPerBlock = $t01309713209._1 | |
328 | + | let rewardUpdateHeight = $t01309713209._2 | |
329 | + | let previousRewardPerBlock = $t01309713209._3 | |
330 | + | let poolRewardUpdateHeight = $t01309713209._4 | |
331 | + | let $t01321413298 = getUserInterestInfo(pool, userAddrStr) | |
332 | + | let userLastInterest = $t01321413298._1 | |
333 | + | let userShareTokensAmount = $t01321413298._2 | |
334 | + | let currentInterest = calcInterest(lastInterestHeight, rewardUpdateHeight, poolRewardUpdateHeight, lastInterest, currentRewardPerBlock, shareTokenLocked, previousRewardPerBlock, scaleValue, h) | |
335 | + | let claimAmount = fraction(userShareTokensAmount, (currentInterest - userLastInterest), scaleValue) | |
336 | + | let userNewInterest = currentInterest | |
337 | + | $Tuple4(userNewInterest, currentInterest, claimAmount, userShareTokensAmount) | |
338 | + | } | |
339 | + | ||
340 | + | ||
341 | + | func claimCalcForMigration (pool,userAddrStr,h) = { | |
342 | + | let shareAssetId = getShareAssetId(pool) | |
343 | + | let scaleValue = calcScaleValue(SWOP, shareAssetId) | |
344 | + | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
345 | + | let $t01402114086 = getLastInterestInfo(pool) | |
346 | + | let lastInterestHeight = $t01402114086._1 | |
347 | + | let lastInterest = $t01402114086._2 | |
348 | + | let $t01409114203 = rewardInfo(pool) | |
349 | + | let currentRewardPerBlock = $t01409114203._1 | |
350 | + | let rewardUpdateHeight = $t01409114203._2 | |
351 | + | let previousRewardPerBlock = $t01409114203._3 | |
352 | + | let poolRewardUpdateHeight = $t01409114203._4 | |
353 | + | let $t01420814292 = getUserInterestInfo(pool, userAddrStr) | |
354 | + | let userLastInterest = $t01420814292._1 | |
355 | + | let userShareTokensAmount = $t01420814292._2 | |
356 | + | let currentInterest = calcInterest(lastInterestHeight, rewardUpdateHeight, poolRewardUpdateHeight, lastInterest, currentRewardPerBlock, shareTokenLocked, previousRewardPerBlock, scaleValue, h) | |
351 | 357 | let claimAmount = fraction(userShareTokensAmount, (currentInterest - userLastInterest), scaleValue) | |
352 | 358 | let userNewInterest = currentInterest | |
353 | 359 | $Tuple4(userNewInterest, currentInterest, claimAmount, userShareTokensAmount) | |
355 | 361 | ||
356 | 362 | ||
357 | 363 | func calculateProtocolReward (pool) = { | |
358 | - | let $ | |
359 | - | let lastInterestHeight = $ | |
360 | - | let lastInterest = $ | |
361 | - | let $ | |
362 | - | let currentRewardPerBlock = $ | |
363 | - | let rewardUpdateHeight = $ | |
364 | - | let previousRewardPerBlock = $ | |
365 | - | let poolRewardUpdateHeight = $ | |
364 | + | let $t01479614861 = getLastInterestInfo(pool) | |
365 | + | let lastInterestHeight = $t01479614861._1 | |
366 | + | let lastInterest = $t01479614861._2 | |
367 | + | let $t01486614977 = rewardInfo(pool) | |
368 | + | let currentRewardPerBlock = $t01486614977._1 | |
369 | + | let rewardUpdateHeight = $t01486614977._2 | |
370 | + | let previousRewardPerBlock = $t01486614977._3 | |
371 | + | let poolRewardUpdateHeight = $t01486614977._4 | |
366 | 372 | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
367 | 373 | if (if ((shareTokenLocked == 0)) | |
368 | 374 | then (poolRewardUpdateHeight == 0) | |
425 | 431 | } | |
426 | 432 | ||
427 | 433 | ||
428 | - | func getUserSWOPClaimedAmount (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + | |
434 | + | func getUserSWOPClaimedAmount (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + user) + keyUserSWOPClaimedAmount)), 0) | |
429 | 435 | ||
430 | 436 | ||
431 | 437 | func suspend (cause) = [BooleanEntry(keyActive, false), StringEntry(keyCause, cause)] | |
444 | 450 | ||
445 | 451 | ||
446 | 452 | @Callable(i) | |
447 | - | func initPoolShareFarming (pool) = if ((i.caller != this)) | |
448 | - | then throw("Only the DApp itself can call this function") | |
453 | + | func egg0 (pool,users,migrationHeight) = if (if ((pool != "3Mx6wBFzPJG2hUWNLy2mei8ZHbtmRZ6JJTG")) | |
454 | + | then (pool != "3Mrwe8BMFXLVdGcBhdf3T9YNUnrUEMHkDA8") | |
455 | + | else false) | |
456 | + | then throw() | |
449 | 457 | else { | |
450 | - | let $t01739417497 = rewardInfo(pool) | |
451 | - | let currentReward = $t01739417497._1 | |
452 | - | let rewardUpdateHeight = $t01739417497._2 | |
453 | - | let previousRewardPerBlock = $t01739417497._3 | |
454 | - | let poolRewardUpdateHeight = $t01739417497._4 | |
455 | - | [IntegerEntry((pool + keyShareTokensLocked), 0), IntegerEntry((pool + keyLastInterest), 0), IntegerEntry((pool + keyLastInterestHeight), height)] | |
458 | + | func updateUser (accum,u) = { | |
459 | + | let r = invoke(this, "egg1", [pool, u, migrationHeight], nil) | |
460 | + | if ((r == r)) | |
461 | + | then (accum :+ BooleanEntry((u + "_migration"), true)) | |
462 | + | else throw("Strict value is not equal to itself.") | |
463 | + | } | |
464 | + | ||
465 | + | let $list1820018231 = users | |
466 | + | let $size1820018231 = size($list1820018231) | |
467 | + | let $acc01820018231 = nil | |
468 | + | if (($size1820018231 == 0)) | |
469 | + | then $acc01820018231 | |
470 | + | else { | |
471 | + | let $acc11820018231 = updateUser($acc01820018231, $list1820018231[0]) | |
472 | + | if (($size1820018231 == 1)) | |
473 | + | then $acc11820018231 | |
474 | + | else { | |
475 | + | let $acc21820018231 = updateUser($acc11820018231, $list1820018231[1]) | |
476 | + | if (($size1820018231 == 2)) | |
477 | + | then $acc21820018231 | |
478 | + | else { | |
479 | + | let $acc31820018231 = updateUser($acc21820018231, $list1820018231[2]) | |
480 | + | if (($size1820018231 == 3)) | |
481 | + | then $acc31820018231 | |
482 | + | else { | |
483 | + | let $acc41820018231 = updateUser($acc31820018231, $list1820018231[3]) | |
484 | + | if (($size1820018231 == 4)) | |
485 | + | then $acc41820018231 | |
486 | + | else { | |
487 | + | let $acc51820018231 = updateUser($acc41820018231, $list1820018231[4]) | |
488 | + | if (($size1820018231 == 5)) | |
489 | + | then $acc51820018231 | |
490 | + | else { | |
491 | + | let $acc61820018231 = updateUser($acc51820018231, $list1820018231[5]) | |
492 | + | if (($size1820018231 == 6)) | |
493 | + | then $acc61820018231 | |
494 | + | else { | |
495 | + | let $acc71820018231 = updateUser($acc61820018231, $list1820018231[6]) | |
496 | + | if (($size1820018231 == 7)) | |
497 | + | then $acc71820018231 | |
498 | + | else { | |
499 | + | let $acc81820018231 = updateUser($acc71820018231, $list1820018231[7]) | |
500 | + | if (($size1820018231 == 8)) | |
501 | + | then $acc81820018231 | |
502 | + | else { | |
503 | + | let $acc91820018231 = updateUser($acc81820018231, $list1820018231[8]) | |
504 | + | if (($size1820018231 == 9)) | |
505 | + | then $acc91820018231 | |
506 | + | else { | |
507 | + | let $acc101820018231 = updateUser($acc91820018231, $list1820018231[9]) | |
508 | + | if (($size1820018231 == 10)) | |
509 | + | then $acc101820018231 | |
510 | + | else { | |
511 | + | let $acc111820018231 = updateUser($acc101820018231, $list1820018231[10]) | |
512 | + | if (($size1820018231 == 11)) | |
513 | + | then $acc111820018231 | |
514 | + | else { | |
515 | + | let $acc121820018231 = updateUser($acc111820018231, $list1820018231[11]) | |
516 | + | if (($size1820018231 == 12)) | |
517 | + | then $acc121820018231 | |
518 | + | else { | |
519 | + | let $acc131820018231 = updateUser($acc121820018231, $list1820018231[12]) | |
520 | + | if (($size1820018231 == 13)) | |
521 | + | then $acc131820018231 | |
522 | + | else { | |
523 | + | let $acc141820018231 = updateUser($acc131820018231, $list1820018231[13]) | |
524 | + | if (($size1820018231 == 14)) | |
525 | + | then $acc141820018231 | |
526 | + | else { | |
527 | + | let $acc151820018231 = updateUser($acc141820018231, $list1820018231[14]) | |
528 | + | if (($size1820018231 == 15)) | |
529 | + | then $acc151820018231 | |
530 | + | else { | |
531 | + | let $acc161820018231 = updateUser($acc151820018231, $list1820018231[15]) | |
532 | + | if (($size1820018231 == 16)) | |
533 | + | then $acc161820018231 | |
534 | + | else { | |
535 | + | let $acc171820018231 = updateUser($acc161820018231, $list1820018231[16]) | |
536 | + | if (($size1820018231 == 17)) | |
537 | + | then $acc171820018231 | |
538 | + | else { | |
539 | + | let $acc181820018231 = updateUser($acc171820018231, $list1820018231[17]) | |
540 | + | if (($size1820018231 == 18)) | |
541 | + | then $acc181820018231 | |
542 | + | else { | |
543 | + | let $acc191820018231 = updateUser($acc181820018231, $list1820018231[18]) | |
544 | + | if (($size1820018231 == 19)) | |
545 | + | then $acc191820018231 | |
546 | + | else { | |
547 | + | let $acc201820018231 = updateUser($acc191820018231, $list1820018231[19]) | |
548 | + | if (($size1820018231 == 20)) | |
549 | + | then $acc201820018231 | |
550 | + | else { | |
551 | + | let $acc211820018231 = updateUser($acc201820018231, $list1820018231[20]) | |
552 | + | if (($size1820018231 == 21)) | |
553 | + | then $acc211820018231 | |
554 | + | else { | |
555 | + | let $acc221820018231 = updateUser($acc211820018231, $list1820018231[21]) | |
556 | + | if (($size1820018231 == 22)) | |
557 | + | then $acc221820018231 | |
558 | + | else { | |
559 | + | let $acc231820018231 = updateUser($acc221820018231, $list1820018231[22]) | |
560 | + | if (($size1820018231 == 23)) | |
561 | + | then $acc231820018231 | |
562 | + | else { | |
563 | + | let $acc241820018231 = updateUser($acc231820018231, $list1820018231[23]) | |
564 | + | if (($size1820018231 == 24)) | |
565 | + | then $acc241820018231 | |
566 | + | else { | |
567 | + | let $acc251820018231 = updateUser($acc241820018231, $list1820018231[24]) | |
568 | + | if (($size1820018231 == 25)) | |
569 | + | then $acc251820018231 | |
570 | + | else { | |
571 | + | let $acc261820018231 = updateUser($acc251820018231, $list1820018231[25]) | |
572 | + | if (($size1820018231 == 26)) | |
573 | + | then $acc261820018231 | |
574 | + | else { | |
575 | + | let $acc271820018231 = updateUser($acc261820018231, $list1820018231[26]) | |
576 | + | if (($size1820018231 == 27)) | |
577 | + | then $acc271820018231 | |
578 | + | else { | |
579 | + | let $acc281820018231 = updateUser($acc271820018231, $list1820018231[27]) | |
580 | + | if (($size1820018231 == 28)) | |
581 | + | then $acc281820018231 | |
582 | + | else { | |
583 | + | let $acc291820018231 = updateUser($acc281820018231, $list1820018231[28]) | |
584 | + | if (($size1820018231 == 29)) | |
585 | + | then $acc291820018231 | |
586 | + | else { | |
587 | + | let $acc301820018231 = updateUser($acc291820018231, $list1820018231[29]) | |
588 | + | if (($size1820018231 == 30)) | |
589 | + | then $acc301820018231 | |
590 | + | else { | |
591 | + | let $acc311820018231 = updateUser($acc301820018231, $list1820018231[30]) | |
592 | + | if (($size1820018231 == 31)) | |
593 | + | then $acc311820018231 | |
594 | + | else { | |
595 | + | let $acc321820018231 = updateUser($acc311820018231, $list1820018231[31]) | |
596 | + | if (($size1820018231 == 32)) | |
597 | + | then $acc321820018231 | |
598 | + | else { | |
599 | + | let $acc331820018231 = updateUser($acc321820018231, $list1820018231[32]) | |
600 | + | if (($size1820018231 == 33)) | |
601 | + | then $acc331820018231 | |
602 | + | else { | |
603 | + | let $acc341820018231 = updateUser($acc331820018231, $list1820018231[33]) | |
604 | + | if (($size1820018231 == 34)) | |
605 | + | then $acc341820018231 | |
606 | + | else { | |
607 | + | let $acc351820018231 = updateUser($acc341820018231, $list1820018231[34]) | |
608 | + | if (($size1820018231 == 35)) | |
609 | + | then $acc351820018231 | |
610 | + | else { | |
611 | + | let $acc361820018231 = updateUser($acc351820018231, $list1820018231[35]) | |
612 | + | if (($size1820018231 == 36)) | |
613 | + | then $acc361820018231 | |
614 | + | else { | |
615 | + | let $acc371820018231 = updateUser($acc361820018231, $list1820018231[36]) | |
616 | + | if (($size1820018231 == 37)) | |
617 | + | then $acc371820018231 | |
618 | + | else { | |
619 | + | let $acc381820018231 = updateUser($acc371820018231, $list1820018231[37]) | |
620 | + | if (($size1820018231 == 38)) | |
621 | + | then $acc381820018231 | |
622 | + | else { | |
623 | + | let $acc391820018231 = updateUser($acc381820018231, $list1820018231[38]) | |
624 | + | if (($size1820018231 == 39)) | |
625 | + | then $acc391820018231 | |
626 | + | else { | |
627 | + | let $acc401820018231 = updateUser($acc391820018231, $list1820018231[39]) | |
628 | + | if (($size1820018231 == 40)) | |
629 | + | then $acc401820018231 | |
630 | + | else { | |
631 | + | let $acc411820018231 = updateUser($acc401820018231, $list1820018231[40]) | |
632 | + | if (($size1820018231 == 41)) | |
633 | + | then $acc411820018231 | |
634 | + | else { | |
635 | + | let $acc421820018231 = updateUser($acc411820018231, $list1820018231[41]) | |
636 | + | if (($size1820018231 == 42)) | |
637 | + | then $acc421820018231 | |
638 | + | else { | |
639 | + | let $acc431820018231 = updateUser($acc421820018231, $list1820018231[42]) | |
640 | + | if (($size1820018231 == 43)) | |
641 | + | then $acc431820018231 | |
642 | + | else { | |
643 | + | let $acc441820018231 = updateUser($acc431820018231, $list1820018231[43]) | |
644 | + | if (($size1820018231 == 44)) | |
645 | + | then $acc441820018231 | |
646 | + | else { | |
647 | + | let $acc451820018231 = updateUser($acc441820018231, $list1820018231[44]) | |
648 | + | if (($size1820018231 == 45)) | |
649 | + | then $acc451820018231 | |
650 | + | else { | |
651 | + | let $acc461820018231 = updateUser($acc451820018231, $list1820018231[45]) | |
652 | + | if (($size1820018231 == 46)) | |
653 | + | then $acc461820018231 | |
654 | + | else { | |
655 | + | let $acc471820018231 = updateUser($acc461820018231, $list1820018231[46]) | |
656 | + | if (($size1820018231 == 47)) | |
657 | + | then $acc471820018231 | |
658 | + | else { | |
659 | + | let $acc481820018231 = updateUser($acc471820018231, $list1820018231[47]) | |
660 | + | if (($size1820018231 == 48)) | |
661 | + | then $acc481820018231 | |
662 | + | else { | |
663 | + | let $acc491820018231 = updateUser($acc481820018231, $list1820018231[48]) | |
664 | + | if (($size1820018231 == 49)) | |
665 | + | then $acc491820018231 | |
666 | + | else { | |
667 | + | let $acc501820018231 = updateUser($acc491820018231, $list1820018231[49]) | |
668 | + | if (($size1820018231 == 50)) | |
669 | + | then $acc501820018231 | |
670 | + | else { | |
671 | + | let $acc511820018231 = updateUser($acc501820018231, $list1820018231[50]) | |
672 | + | if (($size1820018231 == 51)) | |
673 | + | then $acc511820018231 | |
674 | + | else { | |
675 | + | let $acc521820018231 = updateUser($acc511820018231, $list1820018231[51]) | |
676 | + | if (($size1820018231 == 52)) | |
677 | + | then $acc521820018231 | |
678 | + | else { | |
679 | + | let $acc531820018231 = updateUser($acc521820018231, $list1820018231[52]) | |
680 | + | if (($size1820018231 == 53)) | |
681 | + | then $acc531820018231 | |
682 | + | else { | |
683 | + | let $acc541820018231 = updateUser($acc531820018231, $list1820018231[53]) | |
684 | + | if (($size1820018231 == 54)) | |
685 | + | then $acc541820018231 | |
686 | + | else { | |
687 | + | let $acc551820018231 = updateUser($acc541820018231, $list1820018231[54]) | |
688 | + | if (($size1820018231 == 55)) | |
689 | + | then $acc551820018231 | |
690 | + | else { | |
691 | + | let $acc561820018231 = updateUser($acc551820018231, $list1820018231[55]) | |
692 | + | if (($size1820018231 == 56)) | |
693 | + | then $acc561820018231 | |
694 | + | else { | |
695 | + | let $acc571820018231 = updateUser($acc561820018231, $list1820018231[56]) | |
696 | + | if (($size1820018231 == 57)) | |
697 | + | then $acc571820018231 | |
698 | + | else { | |
699 | + | let $acc581820018231 = updateUser($acc571820018231, $list1820018231[57]) | |
700 | + | if (($size1820018231 == 58)) | |
701 | + | then $acc581820018231 | |
702 | + | else { | |
703 | + | let $acc591820018231 = updateUser($acc581820018231, $list1820018231[58]) | |
704 | + | if (($size1820018231 == 59)) | |
705 | + | then $acc591820018231 | |
706 | + | else { | |
707 | + | let $acc601820018231 = updateUser($acc591820018231, $list1820018231[59]) | |
708 | + | if (($size1820018231 == 60)) | |
709 | + | then $acc601820018231 | |
710 | + | else { | |
711 | + | let $acc611820018231 = updateUser($acc601820018231, $list1820018231[60]) | |
712 | + | throw("List size exceed 60") | |
713 | + | } | |
714 | + | } | |
715 | + | } | |
716 | + | } | |
717 | + | } | |
718 | + | } | |
719 | + | } | |
720 | + | } | |
721 | + | } | |
722 | + | } | |
723 | + | } | |
724 | + | } | |
725 | + | } | |
726 | + | } | |
727 | + | } | |
728 | + | } | |
729 | + | } | |
730 | + | } | |
731 | + | } | |
732 | + | } | |
733 | + | } | |
734 | + | } | |
735 | + | } | |
736 | + | } | |
737 | + | } | |
738 | + | } | |
739 | + | } | |
740 | + | } | |
741 | + | } | |
742 | + | } | |
743 | + | } | |
744 | + | } | |
745 | + | } | |
746 | + | } | |
747 | + | } | |
748 | + | } | |
749 | + | } | |
750 | + | } | |
751 | + | } | |
752 | + | } | |
753 | + | } | |
754 | + | } | |
755 | + | } | |
756 | + | } | |
757 | + | } | |
758 | + | } | |
759 | + | } | |
760 | + | } | |
761 | + | } | |
762 | + | } | |
763 | + | } | |
764 | + | } | |
765 | + | } | |
766 | + | } | |
767 | + | } | |
768 | + | } | |
769 | + | } | |
770 | + | } | |
771 | + | } | |
772 | + | } | |
773 | + | } | |
456 | 774 | } | |
457 | 775 | ||
458 | 776 | ||
459 | 777 | ||
460 | 778 | @Callable(i) | |
461 | - | func updatePoolInterest (pool) = if ((i.caller != wallet)) | |
462 | - | then throw("Only the Admin itself can call this function") | |
463 | - | else if (!(isActive)) | |
464 | - | then throw("DApp is inactive at this moment") | |
465 | - | else { | |
466 | - | let $t01790618026 = claimCalc(pool, adminIncreaseInterestAddress, 0) | |
467 | - | let userNewInterest = $t01790618026._1 | |
468 | - | let currentInterest = $t01790618026._2 | |
469 | - | let claimAmount = $t01790618026._3 | |
470 | - | let userShareTokensAmount = $t01790618026._4 | |
471 | - | let $t01803118134 = rewardInfo(pool) | |
472 | - | let currentReward = $t01803118134._1 | |
473 | - | let rewardUpdateHeight = $t01803118134._2 | |
474 | - | let previousRewardPerBlock = $t01803118134._3 | |
475 | - | let poolRewardUpdateHeight = $t01803118134._4 | |
476 | - | [IntegerEntry((pool + keyLastInterest), userNewInterest), IntegerEntry((pool + keyLastInterestHeight), height)] | |
477 | - | } | |
478 | - | ||
479 | - | ||
480 | - | ||
481 | - | @Callable(i) | |
482 | - | func lockShareTokens (pool) = { | |
483 | - | let $t01832618401 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
484 | - | let pmtAmount = $t01832618401._1 | |
485 | - | let pmtAssetId = $t01832618401._2 | |
486 | - | let $t01840618479 = getAssetInfo(pmtAssetId) | |
487 | - | let pmtStrAssetId = $t01840618479._1 | |
488 | - | let pmtAssetName = $t01840618479._2 | |
489 | - | let pmtDecimals = $t01840618479._3 | |
490 | - | let $t01848418592 = claimCalc(pool, i.caller, pmtAmount) | |
491 | - | let userNewInterest = $t01848418592._1 | |
492 | - | let currentInterest = $t01848418592._2 | |
493 | - | let claimAmount = $t01848418592._3 | |
494 | - | let userShareTokensAmount = $t01848418592._4 | |
495 | - | let userShareAmountNew = (userShareTokensAmount + pmtAmount) | |
496 | - | let availableFundsNew = (userAvailableSWOP(pool, i.caller) + claimAmount) | |
497 | - | let totalShareAmount = getTotalShareTokenLocked(pool) | |
498 | - | let totalShareAmountNew = (totalShareAmount + pmtAmount) | |
499 | - | let userClaimedAmount = getUserSWOPClaimedAmount(pool, i.caller) | |
779 | + | func egg1 (pool,u,migrationHeight) = { | |
780 | + | let shareTokenMultiplyer = 1000 | |
781 | + | let $t01834818460 = claimCalc(pool, u, migrationHeight) | |
782 | + | let userNewInterest = $t01834818460._1 | |
783 | + | let currentInterest = $t01834818460._2 | |
784 | + | let claimAmount = $t01834818460._3 | |
785 | + | let userShareTokensAmount = $t01834818460._4 | |
786 | + | let availableFundsNew = (userAvailableSWOP(pool, u) + claimAmount) | |
787 | + | let userClaimedAmount = getUserSWOPClaimedAmount(pool, u) | |
500 | 788 | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
501 | - | let baseEntry = [IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserLastInterest), userNewInterest), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserShareTokensLocked), userShareAmountNew), IntegerEntry((pool + keyShareTokensLocked), totalShareAmountNew), IntegerEntry((pool + keyLastInterest), currentInterest), IntegerEntry((pool + keyLastInterestHeight), height), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), IntegerEntry((((pool + "_") + toString(i.caller)) + keyAvailableSWOP), availableFundsNew)] | |
502 | - | if ((0 >= pmtAmount)) | |
503 | - | then throw("You can't lock token") | |
504 | - | else if (!(isActive)) | |
505 | - | then throw("DApp is inactive at this moment") | |
506 | - | else if (!(checkPmtAssetIdCorrect(pool, pmtAssetId))) | |
507 | - | then throw("Incorrect pmtAssetId") | |
508 | - | else if (if (isFirstHarvest(Address(fromBase58String(pool)))) | |
509 | - | then (getHeightFirstHarvest(Address(fromBase58String(pool))) > height) | |
510 | - | else false) | |
511 | - | then { | |
512 | - | let harvestPeriod = ((((getHeightFirstHarvest(Address(fromBase58String(pool))) - startHeight) + 1) / periodLength) - 1) | |
513 | - | let amountOfVoting = split(getStringValue(votingAddress, (((toString(i.caller) + "_") + pool) + "_user_pool_struc")), "_") | |
514 | - | let amountPoolStract = split(getStringValue(votingAddress, (pool + "_pool_struc")), "_") | |
515 | - | let amountActiveVoteUserPoolStract = split(valueOrElse(getString(votingAddress, (((toString(i.caller) + "_") + pool) + kHarvestUserPoolActiveVoteStrucVoting)), ""), "_") | |
516 | - | let amountPoolActiveVoteStract = split(valueOrElse(getString(votingAddress, (pool + kHarvestPoolActiveVoteStrucVoting)), ""), "_") | |
517 | - | let userShareTokenLocked = userShareTokensAmount | |
518 | - | let userPoolActiveVote = if ((toString(currPeriod) == amountOfVoting[2])) | |
519 | - | then valueOrElse(parseInt(amountActiveVoteUserPoolStract[0]), 0) | |
520 | - | else valueOrElse(parseInt(amountOfVoting[1]), 0) | |
521 | - | let poolActiveVote = if ((toString(currPeriod) == amountPoolStract[2])) | |
522 | - | then valueOrElse(parseInt(amountPoolActiveVoteStract[0]), 0) | |
523 | - | else valueOrElse(parseInt(amountPoolStract[1]), 0) | |
524 | - | let accBalance = accountBalance(pmtAssetId) | |
525 | - | let weirdBehaviour = fraction(99, (accBalance + pmtAmount), 100) | |
526 | - | let protocolReward = calculateProtocolReward(pool) | |
527 | - | if ((userPoolActiveVote != 0)) | |
528 | - | then { | |
529 | - | let limitShareToken = getShareLimitToken(addressFromStringValue(pool)) | |
530 | - | let shareToken = (fraction(limitShareToken, userPoolActiveVote, poolActiveVote) - userShareTokenLocked) | |
531 | - | if (if ((size(amountActiveVoteUserPoolStract) > 1)) | |
532 | - | then (valueOrElse(parseInt(amountActiveVoteUserPoolStract[1]), 0) >= harvestPeriod) | |
533 | - | else false) | |
534 | - | then throw("You can't share token") | |
535 | - | else if ((pmtAmount > limitShareToken)) | |
536 | - | then throw(("You can't share token more than " + toString(limitShareToken))) | |
537 | - | else if ((shareToken > 0)) | |
538 | - | then if ((weirdBehaviour > totalShareAmountNew)) | |
539 | - | then throw("Balance of share-token is greater than totalAmount") | |
540 | - | else if (if ((totalShareAmount == 0)) | |
541 | - | then (shareToken >= pmtAmount) | |
542 | - | else false) | |
543 | - | then (baseEntry ++ [ScriptTransfer(wallet, protocolReward, SWOP)]) | |
544 | - | else if ((shareToken >= pmtAmount)) | |
545 | - | then baseEntry | |
546 | - | else throw(("Your maximum share token is " + toString(shareToken))) | |
547 | - | else throw("You can't share token") | |
548 | - | } | |
549 | - | else throw("Your amount of token less than 0") | |
550 | - | } | |
551 | - | else baseEntry | |
789 | + | let userShareTokensAmountNew = (userShareTokensAmount * shareTokenMultiplyer) | |
790 | + | let totalAmountNewShareTokenLocked = valueOrElse(getInteger(this, ((pool + "_") + "total_amount_new_sharetoken_locked")), 0) | |
791 | + | [IntegerEntry((((pool + "_") + u) + keyUserLastInterest), 0), IntegerEntry((((pool + "_") + u) + keyUserShareTokensLocked), userShareTokensAmountNew), IntegerEntry((((pool + "_") + u) + keyAvailableSWOP), availableFundsNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), IntegerEntry(((pool + "_") + "total_amount_new_sharetoken_locked"), (totalAmountNewShareTokenLocked + userShareTokensAmountNew))] | |
552 | 792 | } | |
553 | 793 | ||
554 | 794 | ||
555 | 795 | ||
556 | 796 | @Callable(i) | |
557 | - | func withdrawShareTokens (pool,shareTokensWithdrawAmount) = { | |
558 | - | let shareTokensId = fromBase58String(getStringValue(value(addressFromString(pool)), "share_asset_id")) | |
559 | - | let $t02316123261 = claimCalc(pool, i.caller, 1) | |
560 | - | let userNewInterest = $t02316123261._1 | |
561 | - | let currentInterest = $t02316123261._2 | |
562 | - | let claimAmount = $t02316123261._3 | |
563 | - | let userShareTokensAmount = $t02316123261._4 | |
564 | - | let userShareAmountNew = (userShareTokensAmount - shareTokensWithdrawAmount) | |
565 | - | let availableFundsNew = (userAvailableSWOP(pool, i.caller) + claimAmount) | |
566 | - | let totalShareAmount = getTotalShareTokenLocked(pool) | |
567 | - | let totalShareAmountNew = (totalShareAmount - shareTokensWithdrawAmount) | |
568 | - | let userClaimedAmount = getUserSWOPClaimedAmount(pool, i.caller) | |
569 | - | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
570 | - | if ((shareTokensWithdrawAmount > userShareTokensAmount)) | |
571 | - | then throw("Withdraw amount more then user locked amount") | |
572 | - | else if (!(isActive)) | |
573 | - | then throw("DApp is inactive at this moment") | |
574 | - | else if ((shareTokensWithdrawAmount > userShareTokensAmount)) | |
575 | - | then throw("Withdraw amount more then user locked amount") | |
576 | - | else if ((fraction(99, (accountBalance(shareTokensId) - shareTokensWithdrawAmount), 100) > totalShareAmountNew)) | |
577 | - | then throw("Balance of share-token is greater than totalAmount") | |
578 | - | else [IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserLastInterest), userNewInterest), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserShareTokensLocked), userShareAmountNew), IntegerEntry((pool + keyLastInterest), currentInterest), IntegerEntry((pool + keyLastInterestHeight), height), IntegerEntry((pool + keyShareTokensLocked), totalShareAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyAvailableSWOP), availableFundsNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), ScriptTransfer(i.caller, shareTokensWithdrawAmount, shareTokensId)] | |
579 | - | } | |
580 | - | ||
581 | - | ||
582 | - | ||
583 | - | @Callable(i) | |
584 | - | func claim (pool) = { | |
585 | - | let shareTokensId = fromBase58String(getStringValue(value(addressFromString(pool)), "share_asset_id")) | |
586 | - | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
587 | - | let $t02526725332 = getLastInterestInfo(pool) | |
588 | - | let lastInterestHeight = $t02526725332._1 | |
589 | - | let lastInterest = $t02526725332._2 | |
590 | - | let $t02533725449 = rewardInfo(pool) | |
591 | - | let currentRewardPerBlock = $t02533725449._1 | |
592 | - | let rewardUpdateHeight = $t02533725449._2 | |
593 | - | let previousRewardPerBlock = $t02533725449._3 | |
594 | - | let poolRewardUpdateHeight = $t02533725449._4 | |
595 | - | let $t02545425554 = claimCalc(pool, i.caller, 1) | |
596 | - | let userNewInterest = $t02545425554._1 | |
597 | - | let currentInterest = $t02545425554._2 | |
598 | - | let claimAmount = $t02545425554._3 | |
599 | - | let userShareTokensAmount = $t02545425554._4 | |
600 | - | let availableFund = (userAvailableSWOP(pool, i.caller) + claimAmount) | |
601 | - | let userClaimedAmount = getUserSWOPClaimedAmount(pool, i.caller) | |
602 | - | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
603 | - | if ((availableFund == 0)) | |
604 | - | then throw("You have 0 available SWOP") | |
605 | - | else if (!(isActive)) | |
606 | - | then throw("DApp is inactive at this moment") | |
607 | - | else if ((availableFund == 0)) | |
608 | - | then throw("You have 0 available SWOP") | |
609 | - | else if ((fraction(99, accountBalance(shareTokensId), 100) > shareTokenLocked)) | |
610 | - | then throw("Balance of share-token is greater than totalAmount") | |
611 | - | else [IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserLastInterest), userNewInterest), IntegerEntry((pool + keyLastInterest), currentInterest), IntegerEntry((pool + keyLastInterestHeight), height), IntegerEntry((((pool + "_") + toString(i.caller)) + keyAvailableSWOP), 0), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), ScriptTransfer(i.caller, availableFund, SWOP)] | |
797 | + | func updateTotalShareTokensLocked (pool,migrationHeight) = { | |
798 | + | let shareTokenMultiplyer = 1000 | |
799 | + | let totalAmountShareTokensLockedBefore = (getIntegerValue(this, (pool + keyShareTokensLocked)) * 1000) | |
800 | + | let totalAmountShareTokensLockedNew = getIntegerValue(this, ((pool + "_") + "total_amount_new_sharetoken_locked")) | |
801 | + | if ((totalAmountShareTokensLockedBefore != totalAmountShareTokensLockedNew)) | |
802 | + | then throw("New total amount share tockens != old total amount") | |
803 | + | else [IntegerEntry((pool + keyLastInterest), 0), IntegerEntry((pool + keyLastInterestHeight), migrationHeight)] | |
612 | 804 | } | |
613 | 805 | ||
614 | 806 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let adminPubKey1 = base58'GFmKZ2naZFRoCvNbwKAQVGmLb1uBeWGDgFabdGBuZiuy' | |
5 | + | ||
6 | + | let adminPubKey2 = base58'GmJXRyhRA79g8yUGgKBAVdnFfQFDMjQG98b1MmLDh5kk' | |
7 | + | ||
8 | + | let adminPubKey3 = base58'CFhbV6h41hVjbGHudGtS3fYUv7QAKRxFQzKNtx4B5PqP' | |
9 | + | ||
4 | 10 | let keyShareTokensLocked = "_total_share_tokens_locked" | |
5 | 11 | ||
6 | 12 | let kShareLimit = "share_limit_on_first_harvest" | |
7 | 13 | ||
8 | 14 | let keyActive = "active" | |
9 | 15 | ||
10 | 16 | let keyCause = "shutdown_cause" | |
11 | 17 | ||
12 | 18 | let keyRewardPoolFractionCurrent = "_current_pool_fraction_reward" | |
13 | 19 | ||
14 | 20 | let keyRewardPoolFractionPrevious = "_previous_pool_fraction_reward" | |
15 | 21 | ||
16 | 22 | let keyHeightPoolFraction = "_pool_reward_update_height" | |
17 | 23 | ||
18 | 24 | let keyTotalRewardPerBlockCurrent = "total_reward_per_block_current" | |
19 | 25 | ||
20 | 26 | let keyTotalRewardPerBlockPrevious = "total_reward_per_block_previous" | |
21 | 27 | ||
22 | 28 | let keyRewardUpdateHeight = "reward_update_height" | |
23 | 29 | ||
24 | 30 | let keyLastInterest = "_last_interest" | |
25 | 31 | ||
26 | 32 | let keyLastInterestHeight = "_last_interest_height" | |
27 | 33 | ||
28 | 34 | let keyUserShareTokensLocked = "_share_tokens_locked" | |
29 | 35 | ||
30 | 36 | let keyUserLastInterest = "_last_interest" | |
31 | 37 | ||
32 | 38 | let keySWOPid = "SWOP_id" | |
33 | 39 | ||
34 | 40 | let keyUserSWOPClaimedAmount = "_SWOP_claimed_amount" | |
35 | 41 | ||
36 | 42 | let keyUserSWOPLastClaimedAmount = "_SWOP_last_claimed_amount" | |
37 | 43 | ||
38 | 44 | let keyAvailableSWOP = "_available_SWOP" | |
39 | 45 | ||
40 | 46 | let keyFarmingStartHeight = "farming_start_height" | |
41 | 47 | ||
42 | 48 | let keyAPY = "apy" | |
43 | 49 | ||
44 | 50 | let kPreviousTotalVoteSWOP = "previous_total_vote_SWOP" | |
45 | 51 | ||
46 | 52 | let keySwopYearEmission = "swop_year_emission" | |
47 | 53 | ||
48 | 54 | let keyBalancecpmmA = "A_asset_balance" | |
49 | 55 | ||
50 | 56 | let keyBalancecpmmB = "B_asset_balance" | |
51 | 57 | ||
52 | 58 | let kHarvestPoolActiveVoteStrucVoting = "_harvest_pool_activeVote_struc" | |
53 | 59 | ||
54 | 60 | let kHarvestUserPoolActiveVoteStrucVoting = "_harvest_user_pool_activeVote_struc" | |
55 | 61 | ||
56 | 62 | let keyLimitShareFirstHarvest = "share_limit_on_first_harvest" | |
57 | 63 | ||
58 | 64 | let keyAssetIdA = "A_asset_id" | |
59 | 65 | ||
60 | 66 | let keyAssetIdB = "B_asset_id" | |
61 | 67 | ||
62 | 68 | let keyFirstHarvestHeight = "first_harvest_height" | |
63 | 69 | ||
64 | 70 | let keyfirstHarvestCpmm = "first_harvest" | |
65 | 71 | ||
66 | 72 | let keyTempPrevSum = "sum_reward_previous" | |
67 | 73 | ||
68 | 74 | let keyTempCurSum = "sum_reward_current" | |
69 | 75 | ||
70 | 76 | let governanceAddress = Address(base58'3N5W8da2iiijVieA6qLGo7KzCJj8B19smWU') | |
71 | 77 | ||
72 | 78 | let wallet = Address(base58'3NAGTtZz6WpupSN89NZD5rMZwwziZEg4Kx4') | |
73 | 79 | ||
74 | 80 | let votingAddress = Address(base58'3MrJgdL1GniipErHy44YF9idzLaUL2iX5DQ') | |
75 | 81 | ||
76 | 82 | let adminIncreaseInterestAddress = Address(base58'3NAGTtZz6WpupSN89NZD5rMZwwziZEg4Kx4') | |
77 | 83 | ||
78 | 84 | let oneWeekInBlock = 10106 | |
79 | 85 | ||
80 | 86 | let totalVoteShare = 10000000000 | |
81 | 87 | ||
82 | 88 | let scaleValue1 = 10 | |
83 | 89 | ||
84 | 90 | let scaleValue3 = 1000 | |
85 | 91 | ||
86 | 92 | let scaleValue5 = 100000 | |
87 | 93 | ||
88 | 94 | let scaleValue6 = 1000000 | |
89 | 95 | ||
90 | 96 | let scaleValue8 = 100000000 | |
91 | 97 | ||
92 | 98 | let scaleValue11 = 100000000000 | |
93 | - | ||
94 | - | let keyAdminPubKey1 = "admin_pub_1" | |
95 | - | ||
96 | - | let keyAdminPubKey2 = "admin_pub_2" | |
97 | - | ||
98 | - | let keyAdminPubKey3 = "admin_pub_3" | |
99 | - | ||
100 | - | let oracle = Address(base58'3NBBWfzZtZtszaXbitTKnrB2xXwv26Bn7H9') | |
101 | - | ||
102 | - | func getAdminPub (keyAdminPub) = match getString(oracle, keyAdminPub) { | |
103 | - | case string: String => | |
104 | - | fromBase58String(string) | |
105 | - | case nothing => | |
106 | - | throw("Admin public key is empty") | |
107 | - | } | |
108 | - | ||
109 | - | ||
110 | - | let adminPubKey1 = getAdminPub(keyAdminPubKey1) | |
111 | - | ||
112 | - | let adminPubKey2 = getAdminPub(keyAdminPubKey2) | |
113 | - | ||
114 | - | let adminPubKey3 = getAdminPub(keyAdminPubKey3) | |
115 | 99 | ||
116 | 100 | func strAssetIdA (pool) = getStringValue(pool, keyAssetIdA) | |
117 | 101 | ||
118 | 102 | ||
119 | 103 | func strAssetIdB (pool) = getStringValue(pool, keyAssetIdB) | |
120 | 104 | ||
121 | 105 | ||
122 | 106 | func assetIdA (pool) = if ((strAssetIdA(pool) == "WAVES")) | |
123 | 107 | then unit | |
124 | 108 | else fromBase58String(strAssetIdA(pool)) | |
125 | 109 | ||
126 | 110 | ||
127 | 111 | func assetIdB (pool) = if ((strAssetIdB(pool) == "WAVES")) | |
128 | 112 | then unit | |
129 | 113 | else fromBase58String(strAssetIdB(pool)) | |
130 | 114 | ||
131 | 115 | ||
132 | 116 | let kBasePeriod = "base_period" | |
133 | 117 | ||
134 | 118 | let kPeriodLength = "period_length" | |
135 | 119 | ||
136 | 120 | let kStartHeight = "start_height" | |
137 | 121 | ||
138 | 122 | let kFirstHarvestHeight = "first_harvest_height" | |
139 | 123 | ||
140 | 124 | let kDurationFullVotePower = "duration_full_vote_power" | |
141 | 125 | ||
142 | 126 | let kMinVotePower = "min_vote_power" | |
143 | 127 | ||
144 | 128 | let basePeriod = valueOrErrorMessage(getInteger(votingAddress, kBasePeriod), "Empty kBasePeriod") | |
145 | 129 | ||
146 | 130 | let startHeight = valueOrErrorMessage(getInteger(votingAddress, kStartHeight), "Empty kStartHeight") | |
147 | 131 | ||
148 | 132 | let periodLength = valueOrErrorMessage(getInteger(votingAddress, kPeriodLength), "Empty kPeriodLength") | |
149 | 133 | ||
150 | 134 | let durationFullVotePower = valueOrErrorMessage(getInteger(votingAddress, kDurationFullVotePower), "Empty kDurationFullVotePower") | |
151 | 135 | ||
152 | 136 | let minVotePower = valueOrErrorMessage(getInteger(votingAddress, kMinVotePower), "Empty kMinVotePower") | |
153 | 137 | ||
154 | 138 | let isActive = getBooleanValue(this, keyActive) | |
155 | 139 | ||
156 | 140 | let currPeriod = (basePeriod + ((height - startHeight) / periodLength)) | |
157 | 141 | ||
158 | 142 | func getLimitToken (pool) = valueOrElse(getIntegerValue(pool, keyLimitShareFirstHarvest), 0) | |
159 | 143 | ||
160 | 144 | ||
161 | 145 | let APY = getIntegerValue(this, keyAPY) | |
162 | 146 | ||
163 | 147 | let SwopYearEmission = getIntegerValue(this, keySwopYearEmission) | |
164 | 148 | ||
165 | 149 | func assetNameA (pool) = match assetIdA(pool) { | |
166 | 150 | case id: ByteVector => | |
167 | 151 | value(assetInfo(id)).name | |
168 | 152 | case waves: Unit => | |
169 | 153 | "WAVES" | |
170 | 154 | case _ => | |
171 | 155 | throw("Match error") | |
172 | 156 | } | |
173 | 157 | ||
174 | 158 | ||
175 | 159 | func assetNameB (pool) = match assetIdB(pool) { | |
176 | 160 | case id: ByteVector => | |
177 | 161 | value(assetInfo(id)).name | |
178 | 162 | case waves: Unit => | |
179 | 163 | "WAVES" | |
180 | 164 | case _ => | |
181 | 165 | throw("Match error") | |
182 | 166 | } | |
183 | 167 | ||
184 | 168 | ||
185 | 169 | let SWOP = fromBase58String(getStringValue(this, keySWOPid)) | |
186 | 170 | ||
187 | 171 | func isFirstHarvest (pool) = valueOrElse(getBoolean(pool, keyfirstHarvestCpmm), false) | |
188 | 172 | ||
189 | 173 | ||
190 | 174 | func getHeightFirstHarvest (pool) = valueOrElse(getInteger(pool, keyFirstHarvestHeight), 0) | |
191 | 175 | ||
192 | 176 | ||
193 | 177 | func getBalanceA (pool) = valueOrErrorMessage(getInteger(pool, keyBalancecpmmA), ("No data on the key: " + keyBalancecpmmA)) | |
194 | 178 | ||
195 | 179 | ||
196 | 180 | func getBalanceB (pool) = valueOrErrorMessage(getInteger(pool, keyBalancecpmmB), ("No data on the key: " + keyBalancecpmmB)) | |
197 | 181 | ||
198 | 182 | ||
199 | 183 | func getShareLimitToken (pool) = valueOrErrorMessage(getInteger(pool, kShareLimit), ("No data on the key: " + kShareLimit)) | |
200 | 184 | ||
201 | 185 | ||
202 | 186 | func getTotalShareTokenLocked (pool) = valueOrErrorMessage(getInteger(this, (pool + keyShareTokensLocked)), (("No data on the key: " + pool) + keyShareTokensLocked)) | |
203 | 187 | ||
204 | 188 | ||
205 | 189 | func getShareAssetId (pool) = fromBase58String(getStringValue(value(addressFromString(pool)), "share_asset_id")) | |
206 | 190 | ||
207 | 191 | ||
208 | 192 | func accountBalance (assetId) = match assetId { | |
209 | 193 | case id: ByteVector => | |
210 | 194 | assetBalance(this, id) | |
211 | 195 | case waves: Unit => | |
212 | 196 | wavesBalance(this).available | |
213 | 197 | case _ => | |
214 | 198 | throw("Match error") | |
215 | 199 | } | |
216 | 200 | ||
217 | 201 | ||
218 | 202 | func getAssetInfo (assetId) = match assetId { | |
219 | 203 | case id: ByteVector => | |
220 | 204 | let stringId = toBase58String(id) | |
221 | 205 | let info = valueOrErrorMessage(assetInfo(id), (("Asset " + stringId) + " doesn't exist")) | |
222 | 206 | $Tuple3(stringId, info.name, info.decimals) | |
223 | 207 | case waves: Unit => | |
224 | 208 | $Tuple3("WAVES", "WAVES", 8) | |
225 | 209 | case _ => | |
226 | 210 | throw("Match error") | |
227 | 211 | } | |
228 | 212 | ||
229 | 213 | ||
230 | 214 | func calcScaleValue (assetId1,assetId2) = { | |
231 | 215 | let assetId1Decimals = value(assetInfo(assetId1)).decimals | |
232 | 216 | let assetId2Decimals = value(assetInfo(assetId2)).decimals | |
233 | 217 | let scaleDigits = ((assetId2Decimals - assetId1Decimals) + 8) | |
234 | - | pow(10, 0, scaleDigits, 0, 0, | |
218 | + | pow(10, 0, scaleDigits, 0, 0, FLOOR) | |
235 | 219 | } | |
236 | 220 | ||
237 | 221 | ||
238 | - | func userAvailableSWOP (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + | |
222 | + | func userAvailableSWOP (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + user) + keyAvailableSWOP)), 0) | |
239 | 223 | ||
240 | 224 | ||
241 | 225 | func rewardInfo (pool) = { | |
242 | 226 | let totalRewardPerBlockCurrent = valueOrErrorMessage(getInteger(governanceAddress, keyTotalRewardPerBlockCurrent), ((("No data on the key: " + keyTotalRewardPerBlockCurrent) + " at address ") + toString(governanceAddress))) | |
243 | 227 | let totalRewardPerBlockPrevious = valueOrErrorMessage(getInteger(governanceAddress, keyTotalRewardPerBlockPrevious), ((("No data on the key: " + keyTotalRewardPerBlockPrevious) + " at address ") + toString(governanceAddress))) | |
244 | 228 | let rewardPoolFractionCurrent = valueOrErrorMessage(getInteger(governanceAddress, (pool + keyRewardPoolFractionCurrent)), (((("No data on the key: " + pool) + keyRewardPoolFractionCurrent) + " at address ") + toString(governanceAddress))) | |
245 | 229 | let rewardUpdateHeight = valueOrErrorMessage(getInteger(governanceAddress, keyRewardUpdateHeight), ((("No data on the key: " + keyRewardUpdateHeight) + " at address ") + toString(governanceAddress))) | |
246 | 230 | let poolRewardUpdateHeight = valueOrElse(getInteger(governanceAddress, (pool + keyHeightPoolFraction)), 0) | |
247 | 231 | let rewardPoolFractionPrevious = valueOrErrorMessage(getInteger(governanceAddress, (pool + keyRewardPoolFractionPrevious)), (((("No data on the key: " + pool) + keyRewardPoolFractionPrevious) + " at address ") + toString(governanceAddress))) | |
248 | 232 | let rewardPoolCurrent = fraction(totalRewardPerBlockCurrent, rewardPoolFractionCurrent, totalVoteShare) | |
249 | 233 | let rewardPoolPrevious = fraction(totalRewardPerBlockPrevious, rewardPoolFractionPrevious, totalVoteShare) | |
250 | 234 | if (if ((rewardPoolCurrent > totalRewardPerBlockCurrent)) | |
251 | 235 | then true | |
252 | 236 | else (rewardPoolPrevious > totalRewardPerBlockPrevious)) | |
253 | 237 | then throw("rewardPoolCurrent > totalRewardPerBlockCurrent or rewardPoolPrevious > totalRewardPerBlockPrevious") | |
254 | 238 | else $Tuple4(rewardPoolCurrent, rewardUpdateHeight, rewardPoolPrevious, poolRewardUpdateHeight) | |
255 | 239 | } | |
256 | 240 | ||
257 | 241 | ||
258 | 242 | func getLastInterestInfo (pool) = { | |
259 | 243 | let lastInterest = valueOrErrorMessage(getInteger(this, (pool + keyLastInterest)), (("No data on the key: " + pool) + keyLastInterest)) | |
260 | 244 | let lastInterestHeight = valueOrElse(getInteger(this, (pool + keyLastInterestHeight)), height) | |
261 | 245 | $Tuple2(lastInterestHeight, lastInterest) | |
262 | 246 | } | |
263 | 247 | ||
264 | 248 | ||
265 | - | func getUserInterestInfo (pool, | |
266 | - | let userLastInterest = getInteger(this, (((pool + "_") + | |
267 | - | let userShare = getInteger(this, (((pool + "_") + | |
249 | + | func getUserInterestInfo (pool,userAddrStr) = { | |
250 | + | let userLastInterest = getInteger(this, (((pool + "_") + userAddrStr) + keyUserLastInterest)) | |
251 | + | let userShare = getInteger(this, (((pool + "_") + userAddrStr) + keyUserShareTokensLocked)) | |
268 | 252 | let lastInterest = valueOrErrorMessage(getInteger(this, (pool + keyLastInterest)), (("No data on the key: " + pool) + keyLastInterest)) | |
269 | 253 | let userLastInterestValue = match userLastInterest { | |
270 | 254 | case userLastInterest: Int => | |
271 | 255 | userLastInterest | |
272 | 256 | case _ => | |
273 | 257 | lastInterest | |
274 | 258 | } | |
275 | 259 | let userShareTokensAmount = match userShare { | |
276 | 260 | case userShare: Int => | |
277 | 261 | userShare | |
278 | 262 | case _ => | |
279 | 263 | 0 | |
280 | 264 | } | |
281 | 265 | $Tuple2(userLastInterestValue, userShareTokensAmount) | |
282 | 266 | } | |
283 | 267 | ||
284 | 268 | ||
285 | - | func calcInterest (lastInterestHeight,rewardUpdateHeight,poolRewardUpdateHeight,lastInterest,currentRewardPerBlock,shareTokenLocked,previousRewardPerBlock, | |
269 | + | func calcInterest (lastInterestHeight,rewardUpdateHeight,poolRewardUpdateHeight,lastInterest,currentRewardPerBlock,shareTokenLocked,previousRewardPerBlock,scaleValue,h) = if ((shareTokenLocked == 0)) | |
286 | 270 | then 0 | |
287 | 271 | else if ((poolRewardUpdateHeight != 0)) | |
288 | - | then if (if ((rewardUpdateHeight > | |
272 | + | then if (if ((rewardUpdateHeight > h)) | |
289 | 273 | then (rewardUpdateHeight == poolRewardUpdateHeight) | |
290 | 274 | else false) | |
291 | 275 | then { | |
292 | - | let reward = (previousRewardPerBlock * ( | |
276 | + | let reward = (previousRewardPerBlock * (h - lastInterestHeight)) | |
293 | 277 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
294 | 278 | } | |
295 | - | else if (if (( | |
279 | + | else if (if ((h > rewardUpdateHeight)) | |
296 | 280 | then (rewardUpdateHeight != poolRewardUpdateHeight) | |
297 | 281 | else false) | |
298 | 282 | then { | |
299 | - | let reward = (previousRewardPerBlock * ( | |
283 | + | let reward = (previousRewardPerBlock * (h - lastInterestHeight)) | |
300 | 284 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
301 | 285 | } | |
302 | - | else if (if (if (( | |
286 | + | else if (if (if ((h > rewardUpdateHeight)) | |
303 | 287 | then (rewardUpdateHeight == poolRewardUpdateHeight) | |
304 | 288 | else false) | |
305 | 289 | then (lastInterestHeight > rewardUpdateHeight) | |
306 | 290 | else false) | |
307 | 291 | then { | |
308 | - | let reward = (currentRewardPerBlock * ( | |
292 | + | let reward = (currentRewardPerBlock * (h - lastInterestHeight)) | |
309 | 293 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
310 | 294 | } | |
311 | 295 | else { | |
312 | 296 | let rewardAfterLastInterestBeforeReawardUpdate = (previousRewardPerBlock * (rewardUpdateHeight - lastInterestHeight)) | |
313 | 297 | let interestAfterUpdate = (lastInterest + fraction(rewardAfterLastInterestBeforeReawardUpdate, scaleValue, shareTokenLocked)) | |
314 | - | let reward = (currentRewardPerBlock * ( | |
298 | + | let reward = (currentRewardPerBlock * (h - rewardUpdateHeight)) | |
315 | 299 | (interestAfterUpdate + fraction(reward, scaleValue, shareTokenLocked)) | |
316 | 300 | } | |
317 | - | else if ((rewardUpdateHeight > | |
301 | + | else if ((rewardUpdateHeight > h)) | |
318 | 302 | then { | |
319 | - | let reward = (previousRewardPerBlock * ( | |
303 | + | let reward = (previousRewardPerBlock * (h - lastInterestHeight)) | |
320 | 304 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
321 | 305 | } | |
322 | 306 | else if ((lastInterestHeight > rewardUpdateHeight)) | |
323 | 307 | then { | |
324 | - | let reward = (currentRewardPerBlock * ( | |
308 | + | let reward = (currentRewardPerBlock * (h - lastInterestHeight)) | |
325 | 309 | (lastInterest + fraction(reward, scaleValue, shareTokenLocked)) | |
326 | 310 | } | |
327 | 311 | else { | |
328 | 312 | let rewardAfterLastInterestBeforeReawardUpdate = (previousRewardPerBlock * (rewardUpdateHeight - lastInterestHeight)) | |
329 | 313 | let interestAfterUpdate = (lastInterest + fraction(rewardAfterLastInterestBeforeReawardUpdate, scaleValue, shareTokenLocked)) | |
330 | - | let reward = (currentRewardPerBlock * ( | |
314 | + | let reward = (currentRewardPerBlock * (h - rewardUpdateHeight)) | |
331 | 315 | (interestAfterUpdate + fraction(reward, scaleValue, shareTokenLocked)) | |
332 | 316 | } | |
333 | 317 | ||
334 | 318 | ||
335 | - | func claimCalc (pool, | |
319 | + | func claimCalc (pool,userAddrStr,h) = { | |
336 | 320 | let shareAssetId = getShareAssetId(pool) | |
337 | 321 | let scaleValue = calcScaleValue(SWOP, shareAssetId) | |
338 | 322 | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
339 | - | let $t01344513510 = getLastInterestInfo(pool) | |
340 | - | let lastInterestHeight = $t01344513510._1 | |
341 | - | let lastInterest = $t01344513510._2 | |
342 | - | let $t01351513627 = rewardInfo(pool) | |
343 | - | let currentRewardPerBlock = $t01351513627._1 | |
344 | - | let rewardUpdateHeight = $t01351513627._2 | |
345 | - | let previousRewardPerBlock = $t01351513627._3 | |
346 | - | let poolRewardUpdateHeight = $t01351513627._4 | |
347 | - | let $t01363213711 = getUserInterestInfo(pool, caller) | |
348 | - | let userLastInterest = $t01363213711._1 | |
349 | - | let userShareTokensAmount = $t01363213711._2 | |
350 | - | let currentInterest = calcInterest(lastInterestHeight, rewardUpdateHeight, poolRewardUpdateHeight, lastInterest, currentRewardPerBlock, shareTokenLocked, previousRewardPerBlock, shareAssetId, scaleValue, pmtAmount) | |
323 | + | let $t01302713092 = getLastInterestInfo(pool) | |
324 | + | let lastInterestHeight = $t01302713092._1 | |
325 | + | let lastInterest = $t01302713092._2 | |
326 | + | let $t01309713209 = rewardInfo(pool) | |
327 | + | let currentRewardPerBlock = $t01309713209._1 | |
328 | + | let rewardUpdateHeight = $t01309713209._2 | |
329 | + | let previousRewardPerBlock = $t01309713209._3 | |
330 | + | let poolRewardUpdateHeight = $t01309713209._4 | |
331 | + | let $t01321413298 = getUserInterestInfo(pool, userAddrStr) | |
332 | + | let userLastInterest = $t01321413298._1 | |
333 | + | let userShareTokensAmount = $t01321413298._2 | |
334 | + | let currentInterest = calcInterest(lastInterestHeight, rewardUpdateHeight, poolRewardUpdateHeight, lastInterest, currentRewardPerBlock, shareTokenLocked, previousRewardPerBlock, scaleValue, h) | |
335 | + | let claimAmount = fraction(userShareTokensAmount, (currentInterest - userLastInterest), scaleValue) | |
336 | + | let userNewInterest = currentInterest | |
337 | + | $Tuple4(userNewInterest, currentInterest, claimAmount, userShareTokensAmount) | |
338 | + | } | |
339 | + | ||
340 | + | ||
341 | + | func claimCalcForMigration (pool,userAddrStr,h) = { | |
342 | + | let shareAssetId = getShareAssetId(pool) | |
343 | + | let scaleValue = calcScaleValue(SWOP, shareAssetId) | |
344 | + | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
345 | + | let $t01402114086 = getLastInterestInfo(pool) | |
346 | + | let lastInterestHeight = $t01402114086._1 | |
347 | + | let lastInterest = $t01402114086._2 | |
348 | + | let $t01409114203 = rewardInfo(pool) | |
349 | + | let currentRewardPerBlock = $t01409114203._1 | |
350 | + | let rewardUpdateHeight = $t01409114203._2 | |
351 | + | let previousRewardPerBlock = $t01409114203._3 | |
352 | + | let poolRewardUpdateHeight = $t01409114203._4 | |
353 | + | let $t01420814292 = getUserInterestInfo(pool, userAddrStr) | |
354 | + | let userLastInterest = $t01420814292._1 | |
355 | + | let userShareTokensAmount = $t01420814292._2 | |
356 | + | let currentInterest = calcInterest(lastInterestHeight, rewardUpdateHeight, poolRewardUpdateHeight, lastInterest, currentRewardPerBlock, shareTokenLocked, previousRewardPerBlock, scaleValue, h) | |
351 | 357 | let claimAmount = fraction(userShareTokensAmount, (currentInterest - userLastInterest), scaleValue) | |
352 | 358 | let userNewInterest = currentInterest | |
353 | 359 | $Tuple4(userNewInterest, currentInterest, claimAmount, userShareTokensAmount) | |
354 | 360 | } | |
355 | 361 | ||
356 | 362 | ||
357 | 363 | func calculateProtocolReward (pool) = { | |
358 | - | let $ | |
359 | - | let lastInterestHeight = $ | |
360 | - | let lastInterest = $ | |
361 | - | let $ | |
362 | - | let currentRewardPerBlock = $ | |
363 | - | let rewardUpdateHeight = $ | |
364 | - | let previousRewardPerBlock = $ | |
365 | - | let poolRewardUpdateHeight = $ | |
364 | + | let $t01479614861 = getLastInterestInfo(pool) | |
365 | + | let lastInterestHeight = $t01479614861._1 | |
366 | + | let lastInterest = $t01479614861._2 | |
367 | + | let $t01486614977 = rewardInfo(pool) | |
368 | + | let currentRewardPerBlock = $t01486614977._1 | |
369 | + | let rewardUpdateHeight = $t01486614977._2 | |
370 | + | let previousRewardPerBlock = $t01486614977._3 | |
371 | + | let poolRewardUpdateHeight = $t01486614977._4 | |
366 | 372 | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
367 | 373 | if (if ((shareTokenLocked == 0)) | |
368 | 374 | then (poolRewardUpdateHeight == 0) | |
369 | 375 | else false) | |
370 | 376 | then if ((rewardUpdateHeight > height)) | |
371 | 377 | then { | |
372 | 378 | let reward = (previousRewardPerBlock * (height - lastInterestHeight)) | |
373 | 379 | reward | |
374 | 380 | } | |
375 | 381 | else if ((lastInterestHeight > rewardUpdateHeight)) | |
376 | 382 | then { | |
377 | 383 | let reward = (currentRewardPerBlock * (height - lastInterestHeight)) | |
378 | 384 | reward | |
379 | 385 | } | |
380 | 386 | else { | |
381 | 387 | let rewardAfterLastInterestBeforeReawardUpdate = (previousRewardPerBlock * (rewardUpdateHeight - lastInterestHeight)) | |
382 | 388 | let reward = (currentRewardPerBlock * (height - rewardUpdateHeight)) | |
383 | 389 | (reward + rewardAfterLastInterestBeforeReawardUpdate) | |
384 | 390 | } | |
385 | 391 | else if (if ((shareTokenLocked == 0)) | |
386 | 392 | then (poolRewardUpdateHeight != 0) | |
387 | 393 | else false) | |
388 | 394 | then if (if ((rewardUpdateHeight > height)) | |
389 | 395 | then (rewardUpdateHeight == poolRewardUpdateHeight) | |
390 | 396 | else false) | |
391 | 397 | then { | |
392 | 398 | let reward = (previousRewardPerBlock * (height - lastInterestHeight)) | |
393 | 399 | reward | |
394 | 400 | } | |
395 | 401 | else if (if ((height > rewardUpdateHeight)) | |
396 | 402 | then (rewardUpdateHeight != poolRewardUpdateHeight) | |
397 | 403 | else false) | |
398 | 404 | then { | |
399 | 405 | let reward = (previousRewardPerBlock * (height - lastInterestHeight)) | |
400 | 406 | reward | |
401 | 407 | } | |
402 | 408 | else if (if (if ((height > rewardUpdateHeight)) | |
403 | 409 | then (rewardUpdateHeight == poolRewardUpdateHeight) | |
404 | 410 | else false) | |
405 | 411 | then (lastInterestHeight > rewardUpdateHeight) | |
406 | 412 | else false) | |
407 | 413 | then { | |
408 | 414 | let reward = (currentRewardPerBlock * (height - lastInterestHeight)) | |
409 | 415 | reward | |
410 | 416 | } | |
411 | 417 | else { | |
412 | 418 | let rewardAfterLastInterestBeforeReawardUpdate = (previousRewardPerBlock * (rewardUpdateHeight - lastInterestHeight)) | |
413 | 419 | let reward = (currentRewardPerBlock * (height - rewardUpdateHeight)) | |
414 | 420 | (reward + rewardAfterLastInterestBeforeReawardUpdate) | |
415 | 421 | } | |
416 | 422 | else 0 | |
417 | 423 | } | |
418 | 424 | ||
419 | 425 | ||
420 | 426 | func checkPmtAssetIdCorrect (pool,pmtAssetId) = { | |
421 | 427 | let poolShareAssetId = fromBase58String(getStringValue(value(addressFromString(pool)), "share_asset_id")) | |
422 | 428 | if ((pmtAssetId == poolShareAssetId)) | |
423 | 429 | then true | |
424 | 430 | else false | |
425 | 431 | } | |
426 | 432 | ||
427 | 433 | ||
428 | - | func getUserSWOPClaimedAmount (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + | |
434 | + | func getUserSWOPClaimedAmount (pool,user) = valueOrElse(getInteger(this, (((pool + "_") + user) + keyUserSWOPClaimedAmount)), 0) | |
429 | 435 | ||
430 | 436 | ||
431 | 437 | func suspend (cause) = [BooleanEntry(keyActive, false), StringEntry(keyCause, cause)] | |
432 | 438 | ||
433 | 439 | ||
434 | 440 | @Callable(i) | |
435 | 441 | func init (earlyLP) = if (isDefined(getString(this, keySWOPid))) | |
436 | 442 | then throw("SWOP already initialized") | |
437 | 443 | else { | |
438 | 444 | let initAmount = 100000000000000 | |
439 | 445 | let SWOPissue = Issue("SWOP", "SWOP protocol token", initAmount, 8, true) | |
440 | 446 | let SWOPid = calculateAssetId(SWOPissue) | |
441 | 447 | [BooleanEntry(keyActive, true), Issue("SWOP", "SWOP protocol token", initAmount, 8, true), StringEntry(keySWOPid, toBase58String(SWOPid))] | |
442 | 448 | } | |
443 | 449 | ||
444 | 450 | ||
445 | 451 | ||
446 | 452 | @Callable(i) | |
447 | - | func initPoolShareFarming (pool) = if ((i.caller != this)) | |
448 | - | then throw("Only the DApp itself can call this function") | |
453 | + | func egg0 (pool,users,migrationHeight) = if (if ((pool != "3Mx6wBFzPJG2hUWNLy2mei8ZHbtmRZ6JJTG")) | |
454 | + | then (pool != "3Mrwe8BMFXLVdGcBhdf3T9YNUnrUEMHkDA8") | |
455 | + | else false) | |
456 | + | then throw() | |
449 | 457 | else { | |
450 | - | let $t01739417497 = rewardInfo(pool) | |
451 | - | let currentReward = $t01739417497._1 | |
452 | - | let rewardUpdateHeight = $t01739417497._2 | |
453 | - | let previousRewardPerBlock = $t01739417497._3 | |
454 | - | let poolRewardUpdateHeight = $t01739417497._4 | |
455 | - | [IntegerEntry((pool + keyShareTokensLocked), 0), IntegerEntry((pool + keyLastInterest), 0), IntegerEntry((pool + keyLastInterestHeight), height)] | |
458 | + | func updateUser (accum,u) = { | |
459 | + | let r = invoke(this, "egg1", [pool, u, migrationHeight], nil) | |
460 | + | if ((r == r)) | |
461 | + | then (accum :+ BooleanEntry((u + "_migration"), true)) | |
462 | + | else throw("Strict value is not equal to itself.") | |
463 | + | } | |
464 | + | ||
465 | + | let $list1820018231 = users | |
466 | + | let $size1820018231 = size($list1820018231) | |
467 | + | let $acc01820018231 = nil | |
468 | + | if (($size1820018231 == 0)) | |
469 | + | then $acc01820018231 | |
470 | + | else { | |
471 | + | let $acc11820018231 = updateUser($acc01820018231, $list1820018231[0]) | |
472 | + | if (($size1820018231 == 1)) | |
473 | + | then $acc11820018231 | |
474 | + | else { | |
475 | + | let $acc21820018231 = updateUser($acc11820018231, $list1820018231[1]) | |
476 | + | if (($size1820018231 == 2)) | |
477 | + | then $acc21820018231 | |
478 | + | else { | |
479 | + | let $acc31820018231 = updateUser($acc21820018231, $list1820018231[2]) | |
480 | + | if (($size1820018231 == 3)) | |
481 | + | then $acc31820018231 | |
482 | + | else { | |
483 | + | let $acc41820018231 = updateUser($acc31820018231, $list1820018231[3]) | |
484 | + | if (($size1820018231 == 4)) | |
485 | + | then $acc41820018231 | |
486 | + | else { | |
487 | + | let $acc51820018231 = updateUser($acc41820018231, $list1820018231[4]) | |
488 | + | if (($size1820018231 == 5)) | |
489 | + | then $acc51820018231 | |
490 | + | else { | |
491 | + | let $acc61820018231 = updateUser($acc51820018231, $list1820018231[5]) | |
492 | + | if (($size1820018231 == 6)) | |
493 | + | then $acc61820018231 | |
494 | + | else { | |
495 | + | let $acc71820018231 = updateUser($acc61820018231, $list1820018231[6]) | |
496 | + | if (($size1820018231 == 7)) | |
497 | + | then $acc71820018231 | |
498 | + | else { | |
499 | + | let $acc81820018231 = updateUser($acc71820018231, $list1820018231[7]) | |
500 | + | if (($size1820018231 == 8)) | |
501 | + | then $acc81820018231 | |
502 | + | else { | |
503 | + | let $acc91820018231 = updateUser($acc81820018231, $list1820018231[8]) | |
504 | + | if (($size1820018231 == 9)) | |
505 | + | then $acc91820018231 | |
506 | + | else { | |
507 | + | let $acc101820018231 = updateUser($acc91820018231, $list1820018231[9]) | |
508 | + | if (($size1820018231 == 10)) | |
509 | + | then $acc101820018231 | |
510 | + | else { | |
511 | + | let $acc111820018231 = updateUser($acc101820018231, $list1820018231[10]) | |
512 | + | if (($size1820018231 == 11)) | |
513 | + | then $acc111820018231 | |
514 | + | else { | |
515 | + | let $acc121820018231 = updateUser($acc111820018231, $list1820018231[11]) | |
516 | + | if (($size1820018231 == 12)) | |
517 | + | then $acc121820018231 | |
518 | + | else { | |
519 | + | let $acc131820018231 = updateUser($acc121820018231, $list1820018231[12]) | |
520 | + | if (($size1820018231 == 13)) | |
521 | + | then $acc131820018231 | |
522 | + | else { | |
523 | + | let $acc141820018231 = updateUser($acc131820018231, $list1820018231[13]) | |
524 | + | if (($size1820018231 == 14)) | |
525 | + | then $acc141820018231 | |
526 | + | else { | |
527 | + | let $acc151820018231 = updateUser($acc141820018231, $list1820018231[14]) | |
528 | + | if (($size1820018231 == 15)) | |
529 | + | then $acc151820018231 | |
530 | + | else { | |
531 | + | let $acc161820018231 = updateUser($acc151820018231, $list1820018231[15]) | |
532 | + | if (($size1820018231 == 16)) | |
533 | + | then $acc161820018231 | |
534 | + | else { | |
535 | + | let $acc171820018231 = updateUser($acc161820018231, $list1820018231[16]) | |
536 | + | if (($size1820018231 == 17)) | |
537 | + | then $acc171820018231 | |
538 | + | else { | |
539 | + | let $acc181820018231 = updateUser($acc171820018231, $list1820018231[17]) | |
540 | + | if (($size1820018231 == 18)) | |
541 | + | then $acc181820018231 | |
542 | + | else { | |
543 | + | let $acc191820018231 = updateUser($acc181820018231, $list1820018231[18]) | |
544 | + | if (($size1820018231 == 19)) | |
545 | + | then $acc191820018231 | |
546 | + | else { | |
547 | + | let $acc201820018231 = updateUser($acc191820018231, $list1820018231[19]) | |
548 | + | if (($size1820018231 == 20)) | |
549 | + | then $acc201820018231 | |
550 | + | else { | |
551 | + | let $acc211820018231 = updateUser($acc201820018231, $list1820018231[20]) | |
552 | + | if (($size1820018231 == 21)) | |
553 | + | then $acc211820018231 | |
554 | + | else { | |
555 | + | let $acc221820018231 = updateUser($acc211820018231, $list1820018231[21]) | |
556 | + | if (($size1820018231 == 22)) | |
557 | + | then $acc221820018231 | |
558 | + | else { | |
559 | + | let $acc231820018231 = updateUser($acc221820018231, $list1820018231[22]) | |
560 | + | if (($size1820018231 == 23)) | |
561 | + | then $acc231820018231 | |
562 | + | else { | |
563 | + | let $acc241820018231 = updateUser($acc231820018231, $list1820018231[23]) | |
564 | + | if (($size1820018231 == 24)) | |
565 | + | then $acc241820018231 | |
566 | + | else { | |
567 | + | let $acc251820018231 = updateUser($acc241820018231, $list1820018231[24]) | |
568 | + | if (($size1820018231 == 25)) | |
569 | + | then $acc251820018231 | |
570 | + | else { | |
571 | + | let $acc261820018231 = updateUser($acc251820018231, $list1820018231[25]) | |
572 | + | if (($size1820018231 == 26)) | |
573 | + | then $acc261820018231 | |
574 | + | else { | |
575 | + | let $acc271820018231 = updateUser($acc261820018231, $list1820018231[26]) | |
576 | + | if (($size1820018231 == 27)) | |
577 | + | then $acc271820018231 | |
578 | + | else { | |
579 | + | let $acc281820018231 = updateUser($acc271820018231, $list1820018231[27]) | |
580 | + | if (($size1820018231 == 28)) | |
581 | + | then $acc281820018231 | |
582 | + | else { | |
583 | + | let $acc291820018231 = updateUser($acc281820018231, $list1820018231[28]) | |
584 | + | if (($size1820018231 == 29)) | |
585 | + | then $acc291820018231 | |
586 | + | else { | |
587 | + | let $acc301820018231 = updateUser($acc291820018231, $list1820018231[29]) | |
588 | + | if (($size1820018231 == 30)) | |
589 | + | then $acc301820018231 | |
590 | + | else { | |
591 | + | let $acc311820018231 = updateUser($acc301820018231, $list1820018231[30]) | |
592 | + | if (($size1820018231 == 31)) | |
593 | + | then $acc311820018231 | |
594 | + | else { | |
595 | + | let $acc321820018231 = updateUser($acc311820018231, $list1820018231[31]) | |
596 | + | if (($size1820018231 == 32)) | |
597 | + | then $acc321820018231 | |
598 | + | else { | |
599 | + | let $acc331820018231 = updateUser($acc321820018231, $list1820018231[32]) | |
600 | + | if (($size1820018231 == 33)) | |
601 | + | then $acc331820018231 | |
602 | + | else { | |
603 | + | let $acc341820018231 = updateUser($acc331820018231, $list1820018231[33]) | |
604 | + | if (($size1820018231 == 34)) | |
605 | + | then $acc341820018231 | |
606 | + | else { | |
607 | + | let $acc351820018231 = updateUser($acc341820018231, $list1820018231[34]) | |
608 | + | if (($size1820018231 == 35)) | |
609 | + | then $acc351820018231 | |
610 | + | else { | |
611 | + | let $acc361820018231 = updateUser($acc351820018231, $list1820018231[35]) | |
612 | + | if (($size1820018231 == 36)) | |
613 | + | then $acc361820018231 | |
614 | + | else { | |
615 | + | let $acc371820018231 = updateUser($acc361820018231, $list1820018231[36]) | |
616 | + | if (($size1820018231 == 37)) | |
617 | + | then $acc371820018231 | |
618 | + | else { | |
619 | + | let $acc381820018231 = updateUser($acc371820018231, $list1820018231[37]) | |
620 | + | if (($size1820018231 == 38)) | |
621 | + | then $acc381820018231 | |
622 | + | else { | |
623 | + | let $acc391820018231 = updateUser($acc381820018231, $list1820018231[38]) | |
624 | + | if (($size1820018231 == 39)) | |
625 | + | then $acc391820018231 | |
626 | + | else { | |
627 | + | let $acc401820018231 = updateUser($acc391820018231, $list1820018231[39]) | |
628 | + | if (($size1820018231 == 40)) | |
629 | + | then $acc401820018231 | |
630 | + | else { | |
631 | + | let $acc411820018231 = updateUser($acc401820018231, $list1820018231[40]) | |
632 | + | if (($size1820018231 == 41)) | |
633 | + | then $acc411820018231 | |
634 | + | else { | |
635 | + | let $acc421820018231 = updateUser($acc411820018231, $list1820018231[41]) | |
636 | + | if (($size1820018231 == 42)) | |
637 | + | then $acc421820018231 | |
638 | + | else { | |
639 | + | let $acc431820018231 = updateUser($acc421820018231, $list1820018231[42]) | |
640 | + | if (($size1820018231 == 43)) | |
641 | + | then $acc431820018231 | |
642 | + | else { | |
643 | + | let $acc441820018231 = updateUser($acc431820018231, $list1820018231[43]) | |
644 | + | if (($size1820018231 == 44)) | |
645 | + | then $acc441820018231 | |
646 | + | else { | |
647 | + | let $acc451820018231 = updateUser($acc441820018231, $list1820018231[44]) | |
648 | + | if (($size1820018231 == 45)) | |
649 | + | then $acc451820018231 | |
650 | + | else { | |
651 | + | let $acc461820018231 = updateUser($acc451820018231, $list1820018231[45]) | |
652 | + | if (($size1820018231 == 46)) | |
653 | + | then $acc461820018231 | |
654 | + | else { | |
655 | + | let $acc471820018231 = updateUser($acc461820018231, $list1820018231[46]) | |
656 | + | if (($size1820018231 == 47)) | |
657 | + | then $acc471820018231 | |
658 | + | else { | |
659 | + | let $acc481820018231 = updateUser($acc471820018231, $list1820018231[47]) | |
660 | + | if (($size1820018231 == 48)) | |
661 | + | then $acc481820018231 | |
662 | + | else { | |
663 | + | let $acc491820018231 = updateUser($acc481820018231, $list1820018231[48]) | |
664 | + | if (($size1820018231 == 49)) | |
665 | + | then $acc491820018231 | |
666 | + | else { | |
667 | + | let $acc501820018231 = updateUser($acc491820018231, $list1820018231[49]) | |
668 | + | if (($size1820018231 == 50)) | |
669 | + | then $acc501820018231 | |
670 | + | else { | |
671 | + | let $acc511820018231 = updateUser($acc501820018231, $list1820018231[50]) | |
672 | + | if (($size1820018231 == 51)) | |
673 | + | then $acc511820018231 | |
674 | + | else { | |
675 | + | let $acc521820018231 = updateUser($acc511820018231, $list1820018231[51]) | |
676 | + | if (($size1820018231 == 52)) | |
677 | + | then $acc521820018231 | |
678 | + | else { | |
679 | + | let $acc531820018231 = updateUser($acc521820018231, $list1820018231[52]) | |
680 | + | if (($size1820018231 == 53)) | |
681 | + | then $acc531820018231 | |
682 | + | else { | |
683 | + | let $acc541820018231 = updateUser($acc531820018231, $list1820018231[53]) | |
684 | + | if (($size1820018231 == 54)) | |
685 | + | then $acc541820018231 | |
686 | + | else { | |
687 | + | let $acc551820018231 = updateUser($acc541820018231, $list1820018231[54]) | |
688 | + | if (($size1820018231 == 55)) | |
689 | + | then $acc551820018231 | |
690 | + | else { | |
691 | + | let $acc561820018231 = updateUser($acc551820018231, $list1820018231[55]) | |
692 | + | if (($size1820018231 == 56)) | |
693 | + | then $acc561820018231 | |
694 | + | else { | |
695 | + | let $acc571820018231 = updateUser($acc561820018231, $list1820018231[56]) | |
696 | + | if (($size1820018231 == 57)) | |
697 | + | then $acc571820018231 | |
698 | + | else { | |
699 | + | let $acc581820018231 = updateUser($acc571820018231, $list1820018231[57]) | |
700 | + | if (($size1820018231 == 58)) | |
701 | + | then $acc581820018231 | |
702 | + | else { | |
703 | + | let $acc591820018231 = updateUser($acc581820018231, $list1820018231[58]) | |
704 | + | if (($size1820018231 == 59)) | |
705 | + | then $acc591820018231 | |
706 | + | else { | |
707 | + | let $acc601820018231 = updateUser($acc591820018231, $list1820018231[59]) | |
708 | + | if (($size1820018231 == 60)) | |
709 | + | then $acc601820018231 | |
710 | + | else { | |
711 | + | let $acc611820018231 = updateUser($acc601820018231, $list1820018231[60]) | |
712 | + | throw("List size exceed 60") | |
713 | + | } | |
714 | + | } | |
715 | + | } | |
716 | + | } | |
717 | + | } | |
718 | + | } | |
719 | + | } | |
720 | + | } | |
721 | + | } | |
722 | + | } | |
723 | + | } | |
724 | + | } | |
725 | + | } | |
726 | + | } | |
727 | + | } | |
728 | + | } | |
729 | + | } | |
730 | + | } | |
731 | + | } | |
732 | + | } | |
733 | + | } | |
734 | + | } | |
735 | + | } | |
736 | + | } | |
737 | + | } | |
738 | + | } | |
739 | + | } | |
740 | + | } | |
741 | + | } | |
742 | + | } | |
743 | + | } | |
744 | + | } | |
745 | + | } | |
746 | + | } | |
747 | + | } | |
748 | + | } | |
749 | + | } | |
750 | + | } | |
751 | + | } | |
752 | + | } | |
753 | + | } | |
754 | + | } | |
755 | + | } | |
756 | + | } | |
757 | + | } | |
758 | + | } | |
759 | + | } | |
760 | + | } | |
761 | + | } | |
762 | + | } | |
763 | + | } | |
764 | + | } | |
765 | + | } | |
766 | + | } | |
767 | + | } | |
768 | + | } | |
769 | + | } | |
770 | + | } | |
771 | + | } | |
772 | + | } | |
773 | + | } | |
456 | 774 | } | |
457 | 775 | ||
458 | 776 | ||
459 | 777 | ||
460 | 778 | @Callable(i) | |
461 | - | func updatePoolInterest (pool) = if ((i.caller != wallet)) | |
462 | - | then throw("Only the Admin itself can call this function") | |
463 | - | else if (!(isActive)) | |
464 | - | then throw("DApp is inactive at this moment") | |
465 | - | else { | |
466 | - | let $t01790618026 = claimCalc(pool, adminIncreaseInterestAddress, 0) | |
467 | - | let userNewInterest = $t01790618026._1 | |
468 | - | let currentInterest = $t01790618026._2 | |
469 | - | let claimAmount = $t01790618026._3 | |
470 | - | let userShareTokensAmount = $t01790618026._4 | |
471 | - | let $t01803118134 = rewardInfo(pool) | |
472 | - | let currentReward = $t01803118134._1 | |
473 | - | let rewardUpdateHeight = $t01803118134._2 | |
474 | - | let previousRewardPerBlock = $t01803118134._3 | |
475 | - | let poolRewardUpdateHeight = $t01803118134._4 | |
476 | - | [IntegerEntry((pool + keyLastInterest), userNewInterest), IntegerEntry((pool + keyLastInterestHeight), height)] | |
477 | - | } | |
478 | - | ||
479 | - | ||
480 | - | ||
481 | - | @Callable(i) | |
482 | - | func lockShareTokens (pool) = { | |
483 | - | let $t01832618401 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
484 | - | let pmtAmount = $t01832618401._1 | |
485 | - | let pmtAssetId = $t01832618401._2 | |
486 | - | let $t01840618479 = getAssetInfo(pmtAssetId) | |
487 | - | let pmtStrAssetId = $t01840618479._1 | |
488 | - | let pmtAssetName = $t01840618479._2 | |
489 | - | let pmtDecimals = $t01840618479._3 | |
490 | - | let $t01848418592 = claimCalc(pool, i.caller, pmtAmount) | |
491 | - | let userNewInterest = $t01848418592._1 | |
492 | - | let currentInterest = $t01848418592._2 | |
493 | - | let claimAmount = $t01848418592._3 | |
494 | - | let userShareTokensAmount = $t01848418592._4 | |
495 | - | let userShareAmountNew = (userShareTokensAmount + pmtAmount) | |
496 | - | let availableFundsNew = (userAvailableSWOP(pool, i.caller) + claimAmount) | |
497 | - | let totalShareAmount = getTotalShareTokenLocked(pool) | |
498 | - | let totalShareAmountNew = (totalShareAmount + pmtAmount) | |
499 | - | let userClaimedAmount = getUserSWOPClaimedAmount(pool, i.caller) | |
779 | + | func egg1 (pool,u,migrationHeight) = { | |
780 | + | let shareTokenMultiplyer = 1000 | |
781 | + | let $t01834818460 = claimCalc(pool, u, migrationHeight) | |
782 | + | let userNewInterest = $t01834818460._1 | |
783 | + | let currentInterest = $t01834818460._2 | |
784 | + | let claimAmount = $t01834818460._3 | |
785 | + | let userShareTokensAmount = $t01834818460._4 | |
786 | + | let availableFundsNew = (userAvailableSWOP(pool, u) + claimAmount) | |
787 | + | let userClaimedAmount = getUserSWOPClaimedAmount(pool, u) | |
500 | 788 | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
501 | - | let baseEntry = [IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserLastInterest), userNewInterest), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserShareTokensLocked), userShareAmountNew), IntegerEntry((pool + keyShareTokensLocked), totalShareAmountNew), IntegerEntry((pool + keyLastInterest), currentInterest), IntegerEntry((pool + keyLastInterestHeight), height), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), IntegerEntry((((pool + "_") + toString(i.caller)) + keyAvailableSWOP), availableFundsNew)] | |
502 | - | if ((0 >= pmtAmount)) | |
503 | - | then throw("You can't lock token") | |
504 | - | else if (!(isActive)) | |
505 | - | then throw("DApp is inactive at this moment") | |
506 | - | else if (!(checkPmtAssetIdCorrect(pool, pmtAssetId))) | |
507 | - | then throw("Incorrect pmtAssetId") | |
508 | - | else if (if (isFirstHarvest(Address(fromBase58String(pool)))) | |
509 | - | then (getHeightFirstHarvest(Address(fromBase58String(pool))) > height) | |
510 | - | else false) | |
511 | - | then { | |
512 | - | let harvestPeriod = ((((getHeightFirstHarvest(Address(fromBase58String(pool))) - startHeight) + 1) / periodLength) - 1) | |
513 | - | let amountOfVoting = split(getStringValue(votingAddress, (((toString(i.caller) + "_") + pool) + "_user_pool_struc")), "_") | |
514 | - | let amountPoolStract = split(getStringValue(votingAddress, (pool + "_pool_struc")), "_") | |
515 | - | let amountActiveVoteUserPoolStract = split(valueOrElse(getString(votingAddress, (((toString(i.caller) + "_") + pool) + kHarvestUserPoolActiveVoteStrucVoting)), ""), "_") | |
516 | - | let amountPoolActiveVoteStract = split(valueOrElse(getString(votingAddress, (pool + kHarvestPoolActiveVoteStrucVoting)), ""), "_") | |
517 | - | let userShareTokenLocked = userShareTokensAmount | |
518 | - | let userPoolActiveVote = if ((toString(currPeriod) == amountOfVoting[2])) | |
519 | - | then valueOrElse(parseInt(amountActiveVoteUserPoolStract[0]), 0) | |
520 | - | else valueOrElse(parseInt(amountOfVoting[1]), 0) | |
521 | - | let poolActiveVote = if ((toString(currPeriod) == amountPoolStract[2])) | |
522 | - | then valueOrElse(parseInt(amountPoolActiveVoteStract[0]), 0) | |
523 | - | else valueOrElse(parseInt(amountPoolStract[1]), 0) | |
524 | - | let accBalance = accountBalance(pmtAssetId) | |
525 | - | let weirdBehaviour = fraction(99, (accBalance + pmtAmount), 100) | |
526 | - | let protocolReward = calculateProtocolReward(pool) | |
527 | - | if ((userPoolActiveVote != 0)) | |
528 | - | then { | |
529 | - | let limitShareToken = getShareLimitToken(addressFromStringValue(pool)) | |
530 | - | let shareToken = (fraction(limitShareToken, userPoolActiveVote, poolActiveVote) - userShareTokenLocked) | |
531 | - | if (if ((size(amountActiveVoteUserPoolStract) > 1)) | |
532 | - | then (valueOrElse(parseInt(amountActiveVoteUserPoolStract[1]), 0) >= harvestPeriod) | |
533 | - | else false) | |
534 | - | then throw("You can't share token") | |
535 | - | else if ((pmtAmount > limitShareToken)) | |
536 | - | then throw(("You can't share token more than " + toString(limitShareToken))) | |
537 | - | else if ((shareToken > 0)) | |
538 | - | then if ((weirdBehaviour > totalShareAmountNew)) | |
539 | - | then throw("Balance of share-token is greater than totalAmount") | |
540 | - | else if (if ((totalShareAmount == 0)) | |
541 | - | then (shareToken >= pmtAmount) | |
542 | - | else false) | |
543 | - | then (baseEntry ++ [ScriptTransfer(wallet, protocolReward, SWOP)]) | |
544 | - | else if ((shareToken >= pmtAmount)) | |
545 | - | then baseEntry | |
546 | - | else throw(("Your maximum share token is " + toString(shareToken))) | |
547 | - | else throw("You can't share token") | |
548 | - | } | |
549 | - | else throw("Your amount of token less than 0") | |
550 | - | } | |
551 | - | else baseEntry | |
789 | + | let userShareTokensAmountNew = (userShareTokensAmount * shareTokenMultiplyer) | |
790 | + | let totalAmountNewShareTokenLocked = valueOrElse(getInteger(this, ((pool + "_") + "total_amount_new_sharetoken_locked")), 0) | |
791 | + | [IntegerEntry((((pool + "_") + u) + keyUserLastInterest), 0), IntegerEntry((((pool + "_") + u) + keyUserShareTokensLocked), userShareTokensAmountNew), IntegerEntry((((pool + "_") + u) + keyAvailableSWOP), availableFundsNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), IntegerEntry(((pool + "_") + "total_amount_new_sharetoken_locked"), (totalAmountNewShareTokenLocked + userShareTokensAmountNew))] | |
552 | 792 | } | |
553 | 793 | ||
554 | 794 | ||
555 | 795 | ||
556 | 796 | @Callable(i) | |
557 | - | func withdrawShareTokens (pool,shareTokensWithdrawAmount) = { | |
558 | - | let shareTokensId = fromBase58String(getStringValue(value(addressFromString(pool)), "share_asset_id")) | |
559 | - | let $t02316123261 = claimCalc(pool, i.caller, 1) | |
560 | - | let userNewInterest = $t02316123261._1 | |
561 | - | let currentInterest = $t02316123261._2 | |
562 | - | let claimAmount = $t02316123261._3 | |
563 | - | let userShareTokensAmount = $t02316123261._4 | |
564 | - | let userShareAmountNew = (userShareTokensAmount - shareTokensWithdrawAmount) | |
565 | - | let availableFundsNew = (userAvailableSWOP(pool, i.caller) + claimAmount) | |
566 | - | let totalShareAmount = getTotalShareTokenLocked(pool) | |
567 | - | let totalShareAmountNew = (totalShareAmount - shareTokensWithdrawAmount) | |
568 | - | let userClaimedAmount = getUserSWOPClaimedAmount(pool, i.caller) | |
569 | - | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
570 | - | if ((shareTokensWithdrawAmount > userShareTokensAmount)) | |
571 | - | then throw("Withdraw amount more then user locked amount") | |
572 | - | else if (!(isActive)) | |
573 | - | then throw("DApp is inactive at this moment") | |
574 | - | else if ((shareTokensWithdrawAmount > userShareTokensAmount)) | |
575 | - | then throw("Withdraw amount more then user locked amount") | |
576 | - | else if ((fraction(99, (accountBalance(shareTokensId) - shareTokensWithdrawAmount), 100) > totalShareAmountNew)) | |
577 | - | then throw("Balance of share-token is greater than totalAmount") | |
578 | - | else [IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserLastInterest), userNewInterest), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserShareTokensLocked), userShareAmountNew), IntegerEntry((pool + keyLastInterest), currentInterest), IntegerEntry((pool + keyLastInterestHeight), height), IntegerEntry((pool + keyShareTokensLocked), totalShareAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyAvailableSWOP), availableFundsNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), ScriptTransfer(i.caller, shareTokensWithdrawAmount, shareTokensId)] | |
579 | - | } | |
580 | - | ||
581 | - | ||
582 | - | ||
583 | - | @Callable(i) | |
584 | - | func claim (pool) = { | |
585 | - | let shareTokensId = fromBase58String(getStringValue(value(addressFromString(pool)), "share_asset_id")) | |
586 | - | let shareTokenLocked = getTotalShareTokenLocked(pool) | |
587 | - | let $t02526725332 = getLastInterestInfo(pool) | |
588 | - | let lastInterestHeight = $t02526725332._1 | |
589 | - | let lastInterest = $t02526725332._2 | |
590 | - | let $t02533725449 = rewardInfo(pool) | |
591 | - | let currentRewardPerBlock = $t02533725449._1 | |
592 | - | let rewardUpdateHeight = $t02533725449._2 | |
593 | - | let previousRewardPerBlock = $t02533725449._3 | |
594 | - | let poolRewardUpdateHeight = $t02533725449._4 | |
595 | - | let $t02545425554 = claimCalc(pool, i.caller, 1) | |
596 | - | let userNewInterest = $t02545425554._1 | |
597 | - | let currentInterest = $t02545425554._2 | |
598 | - | let claimAmount = $t02545425554._3 | |
599 | - | let userShareTokensAmount = $t02545425554._4 | |
600 | - | let availableFund = (userAvailableSWOP(pool, i.caller) + claimAmount) | |
601 | - | let userClaimedAmount = getUserSWOPClaimedAmount(pool, i.caller) | |
602 | - | let userClaimedAmountNew = (userClaimedAmount + claimAmount) | |
603 | - | if ((availableFund == 0)) | |
604 | - | then throw("You have 0 available SWOP") | |
605 | - | else if (!(isActive)) | |
606 | - | then throw("DApp is inactive at this moment") | |
607 | - | else if ((availableFund == 0)) | |
608 | - | then throw("You have 0 available SWOP") | |
609 | - | else if ((fraction(99, accountBalance(shareTokensId), 100) > shareTokenLocked)) | |
610 | - | then throw("Balance of share-token is greater than totalAmount") | |
611 | - | else [IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserLastInterest), userNewInterest), IntegerEntry((pool + keyLastInterest), currentInterest), IntegerEntry((pool + keyLastInterestHeight), height), IntegerEntry((((pool + "_") + toString(i.caller)) + keyAvailableSWOP), 0), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPClaimedAmount), userClaimedAmountNew), IntegerEntry((((pool + "_") + toString(i.caller)) + keyUserSWOPLastClaimedAmount), claimAmount), ScriptTransfer(i.caller, availableFund, SWOP)] | |
797 | + | func updateTotalShareTokensLocked (pool,migrationHeight) = { | |
798 | + | let shareTokenMultiplyer = 1000 | |
799 | + | let totalAmountShareTokensLockedBefore = (getIntegerValue(this, (pool + keyShareTokensLocked)) * 1000) | |
800 | + | let totalAmountShareTokensLockedNew = getIntegerValue(this, ((pool + "_") + "total_amount_new_sharetoken_locked")) | |
801 | + | if ((totalAmountShareTokensLockedBefore != totalAmountShareTokensLockedNew)) | |
802 | + | then throw("New total amount share tockens != old total amount") | |
803 | + | else [IntegerEntry((pool + keyLastInterest), 0), IntegerEntry((pool + keyLastInterestHeight), migrationHeight)] | |
612 | 804 | } | |
613 | 805 | ||
614 | 806 | ||
615 | 807 | ||
616 | 808 | @Callable(i) | |
617 | 809 | func shutdown () = if (!(isActive)) | |
618 | 810 | then throw(("DApp is already suspended. Cause: " + valueOrElse(getString(this, keyCause), "the cause wasn't specified"))) | |
619 | 811 | else if (!(containsElement([adminPubKey1, adminPubKey2, adminPubKey3], i.callerPublicKey))) | |
620 | 812 | then throw("Only admin can call this function") | |
621 | 813 | else suspend("Paused by admin") | |
622 | 814 | ||
623 | 815 | ||
624 | 816 | ||
625 | 817 | @Callable(i) | |
626 | 818 | func activate () = if (isActive) | |
627 | 819 | then throw("DApp is already active") | |
628 | 820 | else if (!(containsElement([adminPubKey1, adminPubKey2, adminPubKey3], i.callerPublicKey))) | |
629 | 821 | then throw("Only admin can call this function") | |
630 | 822 | else [BooleanEntry(keyActive, true), DeleteEntry(keyCause)] | |
631 | 823 | ||
632 | 824 | ||
633 | 825 | @Verifier(tx) | |
634 | 826 | func verify () = match tx { | |
635 | 827 | case _ => | |
636 | 828 | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1)) | |
637 | 829 | then 1 | |
638 | 830 | else 0 | |
639 | 831 | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2)) | |
640 | 832 | then 1 | |
641 | 833 | else 0 | |
642 | 834 | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3)) | |
643 | 835 | then 1 | |
644 | 836 | else 0 | |
645 | 837 | (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2) | |
646 | 838 | } | |
647 | 839 |
github/deemru/w8io/169f3d6 109.72 ms ◑![]()