tx · Creg6rvoHACzGUhn5W9rarf6NDGJSJmTC2hZnwEoCKyT

3N28mjf56ZDzhGpFQVgFTuA6U6snixN1F4F:  -0.03000000 Waves

2024.10.07 20:29 [3316722] smart account 3N28mjf56ZDzhGpFQVgFTuA6U6snixN1F4F > SELF 0.00000000 Waves

{ "type": 13, "id": "Creg6rvoHACzGUhn5W9rarf6NDGJSJmTC2hZnwEoCKyT", "fee": 3000000, "feeAssetId": null, "timestamp": 1728322179981, "version": 2, "chainId": 84, "sender": "3N28mjf56ZDzhGpFQVgFTuA6U6snixN1F4F", "senderPublicKey": "7BHuSdyDnrkksxAzJUPKg1XQ4gFK21M7zrbLh6Evj6zf", "proofs": [ "526JBJnoDysmGDNE9DsaBHer9ahgw6cMvpihw4iQkpUuPPbRasNdXVJSfTu9G9oB35qatCTeBgA6dDJ5kpi23wYq" ], "script": "base64:BgJDCAISBQoDCAgBEgASBgoECAgICBIDCgEIEgMKAQQSABIDCgEBEgASAwoBBBIECgIIARIFCgMEAQgSABIHCgUIAQEICD0ACXN0YXJ0VHNNcwCgy9Cb5jEBF2NhbGN1bGF0ZURheXNTaW5jZVN0YXJ0AAQEZGlmZgkAZQIIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQlzdGFydFRzTXMECmRheXNQYXNzZWQJAGkCBQRkaWZmCQBoAgCAowUA6AcFCmRheXNQYXNzZWQBCmFzSW50VHVwbGUBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgooSW50LCBJbnQpBANpbnQFByRtYXRjaDAFA2ludAkAAgECH1dyb25nIHR5cGUsIGV4cGVjdGVkOiBUdXBsZSBJbnQBFHN0YXRpY0tleV9lZ2dBc3NldElkAAIRc3RhdGljX2VnZ0Fzc2V0SWQBFnN0YXRpY0tleV9zcGljZUFzc2V0SWQAAhNzdGF0aWNfc3BpY2VBc3NldElkARVzdGF0aWNLZXlfcGV0ZUFzc2V0SWQAAhJzdGF0aWNfcGV0ZUFzc2V0SWQBHnN0YXRpY0tleV9tdXRhbnRGYXJtaW5nQWRkcmVzcwACG3N0YXRpY19tdXRhbnRGYXJtaW5nQWRkcmVzcwEec3RhdGljS2V5X2ZlbGluZUZhcm1pbmdBZGRyZXNzAAIbc3RhdGljX2ZlbGluZVN0YWtpbmdBZGRyZXNzARBnZXRPcmFjbGVBZGRyZXNzAAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzAg1zdGF0aWNfb3JhY2xlAhFvcmFjbGUgbm90IGZvdW5kIQIWY291bGQgbm90IHBhcnNlIG9yYWNsZQEOZ2V0RmVlc0FjY291bnQACQERQGV4dHJOYXRpdmUoMTA2MikBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBEGdldE9yYWNsZUFkZHJlc3MAAhRzdGF0aWNfZmVlQWdncmVnYXRvcgIfc3RhdGljX2ZlZUFnZ3JlZ2F0b3Igbm90IGZvdW5kIQEOZ2V0Tm9kZUFjY291bnQACQERQGV4dHJOYXRpdmUoMTA2MikBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBEGdldE9yYWNsZUFkZHJlc3MAAhJzdGF0aWNfbm9kZUFkZHJlc3MCF25vZGVfYWRkcmVzcyBub3QgZm91bmQhARdnZXRNdXRhbnRGYXJtaW5nQWNjb3VudAAJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCCQEQZ2V0T3JhY2xlQWRkcmVzcwAJAR5zdGF0aWNLZXlfbXV0YW50RmFybWluZ0FkZHJlc3MACQCsAgIJAR5zdGF0aWNLZXlfbXV0YW50RmFybWluZ0FkZHJlc3MAAgsgbm90IGZvdW5kIQEXZ2V0RmVsaW5lRmFybWluZ0FjY291bnQACQERQGV4dHJOYXRpdmUoMTA2MikBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBEGdldE9yYWNsZUFkZHJlc3MACQEec3RhdGljS2V5X2ZlbGluZUZhcm1pbmdBZGRyZXNzAAkArAICCQEec3RhdGljS2V5X2ZlbGluZUZhcm1pbmdBZGRyZXNzAAILIG5vdCBmb3VuZCEBD2dldFNwaWNlQXNzZXRJZAAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCCQEQZ2V0T3JhY2xlQWRkcmVzcwAJARZzdGF0aWNLZXlfc3BpY2VBc3NldElkAAkArAICCQEWc3RhdGljS2V5X3NwaWNlQXNzZXRJZAACCyBub3QgZm91bmQhAQ1nZXRFZ2dBc3NldElkAAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJARBnZXRPcmFjbGVBZGRyZXNzAAkBFHN0YXRpY0tleV9lZ2dBc3NldElkAAkArAICCQEUc3RhdGljS2V5X2VnZ0Fzc2V0SWQAAgsgbm90IGZvdW5kIQEOZ2V0UGV0ZUFzc2V0SWQACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBEGdldE9yYWNsZUFkZHJlc3MACQEVc3RhdGljS2V5X3BldGVBc3NldElkAAkArAICCQEVc3RhdGljS2V5X3BldGVBc3NldElkAAILIG5vdCBmb3VuZCEBDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABDHRyeUdldEJpbmFyeQEDa2V5BAckbWF0Y2gwCQCcCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFiBQckbWF0Y2gwBQFiAQABDHRyeUdldFN0cmluZwEDa2V5BAckbWF0Y2gwCQCdCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWIFByRtYXRjaDAFAWICAAEOZ2V0QXNzZXRTdHJpbmcBB2Fzc2V0SWQEByRtYXRjaDAFB2Fzc2V0SWQDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQBYgUHJG1hdGNoMAkA2AQBBQFiAgVXQVZFUwENZ2V0QXNzZXRCeXRlcwEKYXNzZXRJZFN0cgMJAAACBQphc3NldElkU3RyAgVXQVZFUwUEdW5pdAkA2QQBBQphc3NldElkU3RyARNhZGRBc3NldEJ5dGVzVG9MaXN0AgVhY2N1bQRpdGVtCQDOCAIFBWFjY3VtCQDMCAIJAQ1nZXRBc3NldEJ5dGVzAQUEaXRlbQUDbmlsARRhZGRBc3NldFdlaWdodFRvTGlzdAIFYWNjdW0EaXRlbQkAzggCBQVhY2N1bQkAzAgCCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdzdGF0aWNfCQEOZ2V0QXNzZXRTdHJpbmcBBQRpdGVtAgdfd2VpZ2h0BQNuaWwBFmFkZEFzc2V0RGVjaW1hbHNUb0xpc3QCBWFjY3VtBGl0ZW0JAM4IAgUFYWNjdW0JAMwIAgkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHc3RhdGljXwkBDmdldEFzc2V0U3RyaW5nAQUEaXRlbQIJX2RlY2ltYWxzBQNuaWwBE2FkZEFzc2V0U2NhbGVUb0xpc3QCBWFjY3VtBGl0ZW0JAM4IAgUFYWNjdW0JAMwIAgkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHc3RhdGljXwkBDmdldEFzc2V0U3RyaW5nAQUEaXRlbQIGX3NjYWxlBQNuaWwBDGFkZEludFRvTGlzdAIFYWNjdW0EaXRlbQkAzggCBQVhY2N1bQkAzAgCCQENcGFyc2VJbnRWYWx1ZQEFBGl0ZW0FA25pbAEXcmV2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ZXNzAAkArAICAglhbW1fYnVybl8JAKUIAQUEdGhpcwMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAF4BQckbWF0Y2gwBQF4BwcBCmlzU2h1dGRvd24ABAhzaHV0ZG93bgMJAQIhPQIJAQx0cnlHZXRTdHJpbmcBAg1zdGF0aWNfb3JhY2xlAgAEByRtYXRjaDAJAJsIAgkBEGdldE9yYWNsZUFkZHJlc3MAAgxhbW1fc2h1dGRvd24DCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBeAUHJG1hdGNoMAUBeAcHBAlzaHV0ZG93bjIEByRtYXRjaDAJAJsIAgUEdGhpcwILaXNfc2h1dGRvd24DCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBeAUHJG1hdGNoMAUBeAcDBQhzaHV0ZG93bgYFCXNodXRkb3duMgEJY2FuVXBkYXRlAAMJAQIhPQIJAQx0cnlHZXRTdHJpbmcBAg1zdGF0aWNfb3JhY2xlAgAEByRtYXRjaDAJAJsIAgkBEGdldE9yYWNsZUFkZHJlc3MAAgZhbW1fdHgDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBeAUHJG1hdGNoMAUBeAYGARZnZXRDdXJyZW50VG9rZW5CYWxhbmNlAQl0b2tlblR5cGUEB3Rva2VuSWQJAQ5nZXRBc3NldFN0cmluZwEJAJEDAgUIYXNzZXRJZHMFCXRva2VuVHlwZQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwUHdG9rZW5JZAIIX2JhbGFuY2UBEGNhbGN1bGF0ZVBJc3N1ZWQCBmFtb3VudAd0b2tlbklkBAdQc3VwcGx5CQENdHJ5R2V0SW50ZWdlcgECF2dsb2JhbF9wb29sVG9rZW5fYW1vdW50BAdCYWxhbmNlCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBBQd0b2tlbklkAghfYmFsYW5jZQkAbgQFBmFtb3VudAUHUHN1cHBseQUHQmFsYW5jZQUERE9XTgENZ2V0TWluUElzc3VlZAEIcGF5bWVudHMKAQdoYW5kbGVyAgVhY2N1bQdjdXJyZW50BAdQSXNzdWVkCQEQY2FsY3VsYXRlUElzc3VlZAIIBQdjdXJyZW50BmFtb3VudAgFB2N1cnJlbnQHYXNzZXRJZAMJAAACBQdQSXNzdWVkAAAJAAIBAiRvbmUgb2YgdGhlIHRva2VucyBhbW91bnRzIGlzIHRvbyBsb3cDAwkAAAIFBWFjY3VtAAAGCQBmAgUFYWNjdW0FB1BJc3N1ZWQFB1BJc3N1ZWQFBWFjY3VtBAltaW5QSXNzZWQKAAIkbAUIcGF5bWVudHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjRfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBB2hhbmRsZXICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjRfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY0XzICCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoFCW1pblBJc3NlZAETY2hlY2tUb2tlbnNWYWxpZGl0eQEIcGF5bWVudHMKAQhoYW5kbGVyMQIFYWNjdW0HcGF5bWVudAkAzggCBQVhY2N1bQkAzAgCCAUHcGF5bWVudAdhc3NldElkBQNuaWwEA2lkcwoAAiRsBQhwYXltZW50cwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmNF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEIaGFuZGxlcjECBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjRfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY0XzICCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoDCQAAAgUDaWRzBQNpZHMKAQhoYW5kbGVyMgIFYWNjdW0HYXNzZXRJZAMJAQIhPQIJAM8IAgUDaWRzBQdhc3NldElkBQR1bml0CQBkAgUFYWNjdW0AAQkAAgEJAKwCAgIUYXNzZXQgbm90IGF0dGFjaGVkOiAJAQ5nZXRBc3NldFN0cmluZwEFB2Fzc2V0SWQEBmNoZWNrcwoAAiRsBQhhc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAAAAoBBSRmNV8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEIaGFuZGxlcjICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjVfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY1XzICCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoDCQAAAgUGY2hlY2tzBQZjaGVja3MGCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQxzdGFrZVVuc3Rha2UDBXN0YWtlBmFtb3VudAdhc3NldElkAwMJAAACBQdhc3NldElkAgVXQVZFUwkAZgIFBmFtb3VudAAABwQNbGVhc2luZ0Ftb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzAg5sZWFzaW5nX2Ftb3VudAAABA5uZXdMZWFzZUFtb3VudAMFBXN0YWtlCQBkAgUNbGVhc2luZ0Ftb3VudAUGYW1vdW50CQBlAgUNbGVhc2luZ0Ftb3VudAUGYW1vdW50BAhuZXdMZWFzZQkAxAgCCQEOZ2V0Tm9kZUFjY291bnQABQ5uZXdMZWFzZUFtb3VudAQKbmV3TGVhc2VJZAkAuQgBBQhuZXdMZWFzZQQEZGF0YQkAzAgCBQhuZXdMZWFzZQkAzAgCCQELU3RyaW5nRW50cnkCAg1sYXN0X3N0YWtlX2lkCQDYBAEFCm5ld0xlYXNlSWQJAMwIAgkBDEludGVnZXJFbnRyeQICDmxlYXNpbmdfYW1vdW50BQ5uZXdMZWFzZUFtb3VudAUDbmlsAwkBAiE9AgUHc3Rha2VJZAIACQDOCAIJAMwIAgkBC0xlYXNlQ2FuY2VsAQkA2QQBBQdzdGFrZUlkBQNuaWwFBGRhdGEFBGRhdGEFA25pbAETaGFuZGxlUG9vbFRva2Vuc0FkZAQHUElzc3VlZAhwYXltZW50cwt1c2VyQWRkcmVzcwpuZWVkQ2hhbmdlCgEVZ2V0VG9rZW5QYXltZW50QW1vdW50AQd0b2tlbklkCgEHaGFuZGxlcgIFYWNjdW0HcGF5bWVudAMJAAACCAUHcGF5bWVudAdhc3NldElkBQd0b2tlbklkCAUHcGF5bWVudAZhbW91bnQFBWFjY3VtCgACJGwFCHBheW1lbnRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQdoYW5kbGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKCgERaGFuZGxlVG9rZW5DaGFuZ2UCBWFjY3VtB3Rva2VuSWQEAkJrCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBBQd0b2tlbklkAghfYmFsYW5jZQQHUFN1cHBseQkBDXRyeUdldEludGVnZXIBAhdnbG9iYWxfcG9vbFRva2VuX2Ftb3VudAQNdG9rZW5EZWNpbWFscwkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHc3RhdGljXwkBDmdldEFzc2V0U3RyaW5nAQUHdG9rZW5JZAIGX3NjYWxlBAZEa1RlbXAJAG4ECQBlAgkAbgQJAGQCBQdQU3VwcGx5BQdQSXNzdWVkBQ10b2tlbkRlY2ltYWxzBQdQU3VwcGx5BQdDRUlMSU5HBQ10b2tlbkRlY2ltYWxzBQJCawUNdG9rZW5EZWNpbWFscwUHQ0VJTElORwQNcGF5bWVudEFtb3VudAkBFWdldFRva2VuUGF5bWVudEFtb3VudAEFB3Rva2VuSWQEAkRrCQCXAwEJAMwIAgUGRGtUZW1wCQDMCAIFDXBheW1lbnRBbW91bnQFA25pbAQIdG9SZXR1cm4JAGUCAwkBAiE9AgUNcGF5bWVudEFtb3VudAAABQ1wYXltZW50QW1vdW50AAAFAkRrBAF0AwMFCm5lZWRDaGFuZ2UJAGYCBQh0b1JldHVybgAABwkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQt1c2VyQWRkcmVzcwUIdG9SZXR1cm4FB3Rva2VuSWQFA25pbAUDbmlsBBBzdGFrZVVuc3Rha2VEYXRhAwkAAAIJAQ5nZXRBc3NldFN0cmluZwEFB3Rva2VuSWQCBVdBVkVTCQEMc3Rha2VVbnN0YWtlAwYFAkRrAgVXQVZFUwUDbmlsCQDOCAIJAM4IAgkAzggCBQVhY2N1bQUBdAUQc3Rha2VVbnN0YWtlRGF0YQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFB3Rva2VuSWQCCF9iYWxhbmNlCQBkAgUCQmsFAkRrBQNuaWwKAAIkbAUIYXNzZXRJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjRfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBEWhhbmRsZVRva2VuQ2hhbmdlAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKARZoYW5kbGVQb29sVG9rZW5zUmVkZWVtAglQUmVkZWVtZWQLdXNlckFkZHJlc3MKARFoYW5kbGVUb2tlblJlZGVlbQIFYWNjdW0HdG9rZW5JZAQCQmsJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFB3Rva2VuSWQCCF9iYWxhbmNlBAdQU3VwcGx5CQENdHJ5R2V0SW50ZWdlcgECF2dsb2JhbF9wb29sVG9rZW5fYW1vdW50BA10b2tlbkRlY2ltYWxzCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdzdGF0aWNfCQEOZ2V0QXNzZXRTdHJpbmcBBQd0b2tlbklkAgZfc2NhbGUEBmFtb3VudAkAoAMBCQC9AgQJALgCAgkAtgIBBQZTY2FsZTgJAL0CBAkAtgIBCQBlAgUHUFN1cHBseQUJUFJlZGVlbWVkCQC2AgEFBlNjYWxlOAkAtgIBBQdQU3VwcGx5BQdDRUlMSU5HCQC2AgEFAkJrCQC2AgEFBlNjYWxlOAUERE9XTgQQc3Rha2VVbnN0YWtlRGF0YQMJAAACCQEOZ2V0QXNzZXRTdHJpbmcBBQd0b2tlbklkAgVXQVZFUwkBDHN0YWtlVW5zdGFrZQMHBQZhbW91bnQCBVdBVkVTBQNuaWwJAM4IAgkAzggCBQVhY2N1bQUQc3Rha2VVbnN0YWtlRGF0YQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFB3Rva2VuSWQCCF9iYWxhbmNlCQBlAgUCQmsFBmFtb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQt1c2VyQWRkcmVzcwUGYW1vdW50BQd0b2tlbklkBQNuaWwKAAIkbAUIYXNzZXRJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjRfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBEWhhbmRsZVRva2VuUmVkZWVtAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKARJjYWxjdWxhdGVPdXRBbW91bnQFCEFtb3VudEluB2Fzc2V0SW4IYXNzZXRPdXQJQmFsYW5jZUluCkJhbGFuY2VPdXQEB0luZGV4SW4JAQV2YWx1ZQEJAM8IAgUIYXNzZXRJZHMFB2Fzc2V0SW4ECEluZGV4T3V0CQEFdmFsdWUBCQDPCAIFCGFzc2V0SWRzBQhhc3NldE91dAMJAAACBQdJbmRleEluBQhJbmRleE91dAkAAgECEXdyb25nIHRva2VucyBwYWlyCQBuBAUKQmFsYW5jZU91dAkAZQIJAGgCBQZTY2FsZTgFBlNjYWxlOAkAoAMBCQB2BgkAvQIECQC2AgEFCUJhbGFuY2VJbgkAtgIBCQBoAgUGU2NhbGU4BQZTY2FsZTgJALYCAQkAZAIFCUJhbGFuY2VJbgUIQW1vdW50SW4FBkhBTEZVUAAQCQC2AgEJAGsDCQCRAwIFDUFzc2V0c1dlaWdodHMFB0luZGV4SW4AkE4JAJEDAgUNQXNzZXRzV2VpZ2h0cwUISW5kZXhPdXQABAAQBQdDRUlMSU5HCQBoAgUGU2NhbGU4BQZTY2FsZTgFBERPV04BEWNhbGN1bGF0ZU1pblRvR2V0AwZhc3NldDEGYXNzZXQyDGFtb3VudFRvU3dhcAQJa0JhbGFuY2VBCQCsAgIJAKwCAgIHZ2xvYmFsXwUGYXNzZXQxAghfYmFsYW5jZQQPQV9hc3NldF9iYWxhbmNlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQlrQmFsYW5jZUEECWtCYWxhbmNlQgkArAICCQCsAgICB2dsb2JhbF8FBmFzc2V0MgIIX2JhbGFuY2UED0JfYXNzZXRfYmFsYW5jZQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwUJa0JhbGFuY2VCBAV0b0dldAkBEmNhbGN1bGF0ZU91dEFtb3VudAUFDGFtb3VudFRvU3dhcAkBDWdldEFzc2V0Qnl0ZXMBBQZhc3NldDEJAQ1nZXRBc3NldEJ5dGVzAQUGYXNzZXQyBQ9BX2Fzc2V0X2JhbGFuY2UFD0JfYXNzZXRfYmFsYW5jZQQJZmVlQW1vdW50CQBrAwUFdG9HZXQFA0ZlZQUIRmVlU2NhbGUDCQAAAgUJZmVlQW1vdW50BQlmZWVBbW91bnQEDmNsZWFuQW1vdW50T3V0CQBlAgUFdG9HZXQFCWZlZUFtb3VudAMJAAACBQ5jbGVhbkFtb3VudE91dAUOY2xlYW5BbW91bnRPdXQFDmNsZWFuQW1vdW50T3V0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ9nZXRUb2tlbkJhbGFuY2UBB2Fzc2V0SWQEByRtYXRjaDAFB2Fzc2V0SWQDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQBdAUHJG1hdGNoMAkA8AcCBQR0aGlzBQF0CAkA7wcBBQR0aGlzB3JlZ3VsYXIBHWNhbGN1bGF0ZUN1cnJlbnRBc3NldEludGVyZXN0BAdhc3NldElkCmFzc2V0SWRTdHIIYUJhbGFuY2UWdG9rZW5FYXJuaW5nc0xhc3RDaGVjawQLdG90YWxTdGFrZWQJAQ10cnlHZXRJbnRlZ2VyAQISZ2xvYmFsX2luZGV4U3Rha2VkBBV0b2tlbkJhbGFuY2VMYXN0Q2hlY2sFFnRva2VuRWFybmluZ3NMYXN0Q2hlY2sEE2N1cnJlbnRCYWxhbmNlRGVsdGEJAGUCCQEPZ2V0VG9rZW5CYWxhbmNlAQUHYXNzZXRJZAUIYUJhbGFuY2UEFGN1cnJlbnRUb2tlbkVhcm5pbmdzAwkAZgIFE2N1cnJlbnRCYWxhbmNlRGVsdGEFFXRva2VuQmFsYW5jZUxhc3RDaGVjawUTY3VycmVudEJhbGFuY2VEZWx0YQUVdG9rZW5CYWxhbmNlTGFzdENoZWNrBAtuZXdFYXJuaW5ncwkAZQIFFGN1cnJlbnRUb2tlbkVhcm5pbmdzBRV0b2tlbkJhbGFuY2VMYXN0Q2hlY2sEC25ld0ludGVyZXN0AwkAAAIFC3RvdGFsU3Rha2VkAAAAAAkAawMFC25ld0Vhcm5pbmdzBQZTY2FsZTgFC3RvdGFsU3Rha2VkBBFsYXN0Q2hlY2tJbnRlcmVzdAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIRZ2xvYmFsX2xhc3RDaGVja18FCmFzc2V0SWRTdHICCV9pbnRlcmVzdAkAZAIFEWxhc3RDaGVja0ludGVyZXN0BQtuZXdJbnRlcmVzdAELY2xhaW1SZXN1bHQBB2FkZHJlc3MECmFkZHJlc3NTdHIJAKUIAQUHYWRkcmVzcwQLc2hhcmVBbW91bnQJAQ10cnlHZXRJbnRlZ2VyAQkArAICBQphZGRyZXNzU3RyAgxfaW5kZXhTdGFrZWQKAQdoYW5kbGVyAgVhY2N1bQdhc3NldElkBAphc3NldElkU3RyCQEOZ2V0QXNzZXRTdHJpbmcBBQdhc3NldElkBAhhQmFsYW5jZQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwkBDmdldEFzc2V0U3RyaW5nAQUHYXNzZXRJZAIIX2JhbGFuY2UEFnRva2VuRWFybmluZ3NMYXN0Q2hlY2sJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICEWdsb2JhbF9sYXN0Q2hlY2tfBQphc3NldElkU3RyAglfZWFybmluZ3MEFGN1cnJlbnRUb2tlbkludGVyZXN0CQEdY2FsY3VsYXRlQ3VycmVudEFzc2V0SW50ZXJlc3QEBQdhc3NldElkBQphc3NldElkU3RyBQhhQmFsYW5jZQUWdG9rZW5FYXJuaW5nc0xhc3RDaGVjawQUY3VycmVudFRva2VuRWFybmluZ3MJAJYDAQkAzAgCBRZ0b2tlbkVhcm5pbmdzTGFzdENoZWNrCQDMCAIJAGUCCQEPZ2V0VG9rZW5CYWxhbmNlAQUHYXNzZXRJZAUIYUJhbGFuY2UFA25pbAQMcmV3YXJkQW1vdW50CQBrAwULc2hhcmVBbW91bnQJAGUCBRRjdXJyZW50VG9rZW5JbnRlcmVzdAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgkArAICBQphZGRyZXNzU3RyAgtfbGFzdENoZWNrXwUKYXNzZXRJZFN0cgIJX2ludGVyZXN0BQZTY2FsZTgECHRyYW5zZmVyAwkAAAIFDHJld2FyZEFtb3VudAAABQNuaWwJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUHYWRkcmVzcwUMcmV3YXJkQW1vdW50BQdhc3NldElkBQNuaWwEB2NsYWltZWQJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgIJAKwCAgUKYWRkcmVzc1N0cgILX2xhc3RDaGVja18FCmFzc2V0SWRTdHICCF9jbGFpbWVkCQDOCAIJAM4IAgUFYWNjdW0FCHRyYW5zZmVyCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIRZ2xvYmFsX2xhc3RDaGVja18FCmFzc2V0SWRTdHICCV9lYXJuaW5ncwkAZQIFFGN1cnJlbnRUb2tlbkVhcm5pbmdzBQxyZXdhcmRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAhFnbG9iYWxfbGFzdENoZWNrXwUKYXNzZXRJZFN0cgIJX2ludGVyZXN0BRRjdXJyZW50VG9rZW5JbnRlcmVzdAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgUKYWRkcmVzc1N0cgILX2xhc3RDaGVja18FCmFzc2V0SWRTdHICCV9pbnRlcmVzdAUUY3VycmVudFRva2VuSW50ZXJlc3QJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIFCmFkZHJlc3NTdHICC19sYXN0Q2hlY2tfBQphc3NldElkU3RyAghfY2xhaW1lZAkAZAIFB2NsYWltZWQFDHJld2FyZEFtb3VudAUDbmlsBAVhY2N1bQoAAiRsBQxlYXJuZWRBc3NldHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjRfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBB2hhbmRsZXICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjRfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY0XzICCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoJAM4IAgUFYWNjdW0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUKYWRkcmVzc1N0cgIKX2xhc3RDbGFpbQgFCWxhc3RCbG9jawl0aW1lc3RhbXAFA25pbAEQaW5kZXhTdGFrZVJlc3VsdAIKYWRkcmVzc1N0cgZhbW91bnQEAmxpCQELY2xhaW1SZXN1bHQBCQERQGV4dHJOYXRpdmUoMTA2MikBBQphZGRyZXNzU3RyCQDOCAIFAmxpCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCmFkZHJlc3NTdHICDF9pbmRleFN0YWtlZAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICBQphZGRyZXNzU3RyAgxfaW5kZXhTdGFrZWQFBmFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgISZ2xvYmFsX2luZGV4U3Rha2VkCQBkAgkBDXRyeUdldEludGVnZXIBAhJnbG9iYWxfaW5kZXhTdGFrZWQFBmFtb3VudAUDbmlsAQNzdW0CBWFjY3VtAW4JAGQCBQVhY2N1bQkBDXBhcnNlSW50VmFsdWUBBQFuARtzZXRPcmFjbGVBZGRyZXNzQW5kSW5pdGlhdGUBB2FkZHJlc3MJAMwIAgkBC1N0cmluZ0VudHJ5AgINc3RhdGljX29yYWNsZQUHYWRkcmVzcwUDbmlsAQlpc1Rlc3RFbnYABAd0ZXN0ZW52BAckbWF0Y2gwCQCbCAIFBHRoaXMCB1RFU1RFTlYDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBeAUHJG1hdGNoMAUBeAcFB3Rlc3RlbnYNAWkBDHJlYWRPbmx5RnVuYwMGYXNzZXQxBmFzc2V0MgxhbW91bnRUb1N3YXAECWFtb3VudE91dAkBEWNhbGN1bGF0ZU1pblRvR2V0AwUGYXNzZXQxBQZhc3NldDIFDGFtb3VudFRvU3dhcAkAzAgCCQEMSW50ZWdlckVudHJ5AgIFREVCVUcFCWFtb3VudE91dAUDbmlsAWkBCnRvcFVwRnVuZHMAAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIYV3JvbmcgcGF5bWVudHMgYXR0YWNoZWQhBAdwYXltZW50CQCRAwIIBQFpCHBheW1lbnRzAAAEBWFzc2V0CAUHcGF5bWVudAdhc3NldElkAwkAAAIJAM8IAgUIYXNzZXRJZHMFBWFzc2V0BQR1bml0CQACAQIVTm90IHN1cHBvcnRlZCBhc3NldElkBAZhbW91bnQIBQdwYXltZW50BmFtb3VudAQIYUJhbGFuY2UJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFBWFzc2V0AghfYmFsYW5jZQQDZGF5CQEXY2FsY3VsYXRlRGF5c1NpbmNlU3RhcnQABAdyZXZlbmV1CQENdHJ5R2V0SW50ZWdlcgEJARdyZXZlbmV1Rm9yRGF5QnlBc3NldE91dAIFA2RheQkBDmdldEFzc2V0U3RyaW5nAQUFYXNzZXQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBBQVhc3NldAIIX2JhbGFuY2UJAGQCBQhhQmFsYW5jZQUGYW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCAg5kYXlzX3NpbmNlX2FweQUDZGF5CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEXcmV2ZW5ldUZvckRheUJ5QXNzZXRPdXQCBQNkYXkJAQ5nZXRBc3NldFN0cmluZwEFBWFzc2V0CQBkAgUHcmV2ZW5ldQUGYW1vdW50BQNuaWwBaQEHcHJlSW5pdAQLYXNzZXRJZHNTdHIPYXNzZXRXZWlnaHRzU3RyDmJhc2VUb2tlbklkU3RyCnBvb2xEb21haW4DCQECIT0CBQR0aGlzCAUBaQZjYWxsZXIJAAIBAgphZG1pbiBvbmx5AwkAZgIJALECAQUKcG9vbERvbWFpbgANCQACAQIVdG9vIGxhcmdlIHBvb2wgZG9tYWluBA1hc3NldElkc1N0ckxpCQC1CQIFC2Fzc2V0SWRzU3RyAgEsBAphc3NldElkc0xpCgACJGwFDWFzc2V0SWRzU3RyTGkKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjRfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBE2FkZEFzc2V0Qnl0ZXNUb0xpc3QCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjRfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY0XzICCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoEEWFzc2V0V2VpZ2h0c1N0ckxpCQC1CQIFD2Fzc2V0V2VpZ2h0c1N0cgIBLAQPYXNzZXRXZWlnaHRzU3VtCgACJGwFEWFzc2V0V2VpZ2h0c1N0ckxpCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGY1XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQNzdW0CBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjVfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY1XzICCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoKARNhZGRUb2tlbkRhdGFFbnRyaWVzAgVhY2N1bQhhc3NldE51bQMJAGcCBQhhc3NldE51bQkAkAMBBQphc3NldElkc0xpBQVhY2N1bQQNYXNzZXREZWNpbWFscwQHJG1hdGNoMAkAkQMCBQphc3NldElkc0xpBQhhc3NldE51bQMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAF4BQckbWF0Y2gwCAkBBXZhbHVlAQkA7AcBCQCRAwIFCmFzc2V0SWRzTGkFCGFzc2V0TnVtCGRlY2ltYWxzAAgJAM4IAgUFYWNjdW0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdzdGF0aWNfCQCRAwIFDWFzc2V0SWRzU3RyTGkFCGFzc2V0TnVtAgZfc2NhbGUJAGwGAAoAAAUNYXNzZXREZWNpbWFscwAAAAAFBERPV04JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdzdGF0aWNfCQCRAwIFDWFzc2V0SWRzU3RyTGkFCGFzc2V0TnVtAglfZGVjaW1hbHMFDWFzc2V0RGVjaW1hbHMJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdzdGF0aWNfCQCRAwIFDWFzc2V0SWRzU3RyTGkFCGFzc2V0TnVtAgdfd2VpZ2h0CQEFdmFsdWUBCQC2CQEJAJEDAgURYXNzZXRXZWlnaHRzU3RyTGkFCGFzc2V0TnVtBQNuaWwDCQECIT0CBQ9h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b2xUb2tlblNjYWxlCgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQdoYW5kbGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAwkAZgIJAQ10cnlHZXRJbnRlZ2VyAQIQZ2xvYmFsX3dhc0luaXRlZAAACQACAQITcG9vbCBhbHJlYWR5IGluaXRlZAQRaW5pdGlhbFBvb2xUb2tlbnMJARljYWxjdWxhdGVQb29sVG9rZW5zQW1vdW50AQgFAWkIcGF5bWVudHMDCQAAAgURaW5pdGlhbFBvb2xUb2tlbnMAAAkAAgECMnlvdSBuZWVkIGEgYmlnZ2VyIHRva2VucyBhbW91bnQgdG8gbGF1bmNoIHRoZSBwb29sBA5wb29sVG9rZW5Jc3N1ZQkAwwgHCQCsAgICA1dEIAkBDHRyeUdldFN0cmluZwECEXN0YXRpY19wb29sRG9tYWluAg1XRCBwb29sIHRva2VuBRFpbml0aWFsUG9vbFRva2VucwURUG9vbFRva2VuRGVjaW1hbHMGBQR1bml0AAAEC3Bvb2xUb2tlbklkCQC4CAEFDnBvb2xUb2tlbklzc3VlCQDOCAIJAM4IAgkBC3ByZXBhcmVMaXN0AAkAzAgCBQ5wb29sVG9rZW5Jc3N1ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQFEWluaXRpYWxQb29sVG9rZW5zCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhBnbG9iYWxfd2FzSW5pdGVkAAEJAMwIAgkBC0JpbmFyeUVudHJ5AgITZ2xvYmFsX3Bvb2xUb2tlbl9pZAULcG9vbFRva2VuSWQJAMwIAgkBC1N0cmluZ0VudHJ5AgIWc3RhdGljX3Bvb2xUb2tlbl9pZFN0cgkBDmdldEFzc2V0U3RyaW5nAQULcG9vbFRva2VuSWQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBRFpbml0aWFsUG9vbFRva2VucwULcG9vbFRva2VuSWQFA25pbAkBG3NldE9yYWNsZUFkZHJlc3NBbmRJbml0aWF0ZQEFBm9yYWNsZQFpAQ1nZW5lcmF0ZUluZGV4AQpuZWVkQ2hhbmdlAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwUBVAkAAgEJAKwCAgI7eW91IG5lZWQgdG8gYXR0YWNoIGFsbCBwb29sIHRva2Vucy4gYW1vdW50IG9mIHBvb2wgdG9rZW5zOiAJAKQDAQUBVAMJAQEhAQkBE2NoZWNrVG9rZW5zVmFsaWRpdHkBCAUBaQhwYXltZW50cwkAAgECFXdyb25nIGFzc2V0cyBhdHRhY2hlZAQHUElzc3VlZAkBDWdldE1pblBJc3N1ZWQBCAUBaQhwYXltZW50cwQHcmVpc3N1ZQkBB1JlaXNzdWUDCQERQGV4dHJOYXRpdmUoMTA1NykBAhNnbG9iYWxfcG9vbFRva2VuX2lkBQdQSXNzdWVkBgQGcmVzdWx0CQETaGFuZGxlUG9vbFRva2Vuc0FkZAQFB1BJc3N1ZWQIBQFpCHBheW1lbnRzCAUBaQxvcmlnaW5DYWxsZXIFCm5lZWRDaGFuZ2UJAJQKAgkAzggCBQZyZXN1bHQJAMwIAgUHcmVpc3N1ZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFB1BJc3N1ZWQJAQx0cnlHZXRCaW5hcnkBAhNnbG9iYWxfcG9vbFRva2VuX2lkCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhdnbG9iYWxfcG9vbFRva2VuX2Ftb3VudAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQFB1BJc3N1ZWQFA25pbAUHUElzc3VlZAFpAQpzdGFrZUluZGV4AAQKYWRkcmVzc1N0cgkApQgBCAUBaQxvcmlnaW5DYWxsZXIEA3BtdAkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AgkBBXZhbHVlAQgFA3BtdAdhc3NldElkCQEMdHJ5R2V0QmluYXJ5AQITZ2xvYmFsX3Bvb2xUb2tlbl9pZAkAAgECFHdyb25nIGFzc2V0IGF0dGFjaGVkCQEQaW5kZXhTdGFrZVJlc3VsdAIFCmFkZHJlc3NTdHIIBQNwbXQGYW1vdW50AWkBDHVuc3Rha2VJbmRleAELc2hhcmVBbW91bnQECmFkZHJlc3NTdHIJAKUIAQgFAWkMb3JpZ2luQ2FsbGVyBA5zaGFyZUF2YWlsYWJsZQkBDXRyeUdldEludGVnZXIBCQCsAgIFCmFkZHJlc3NTdHICDF9pbmRleFN0YWtlZAMJAGYCBQtzaGFyZUFtb3VudAUOc2hhcmVBdmFpbGFibGUJAAIBAiV5b3UgZG9uJ3QgaGF2ZSBpbmRleCB0b2tlbnMgYXZhaWxhYmxlCQDOCAIJAQtjbGFpbVJlc3VsdAEIBQFpDG9yaWdpbkNhbGxlcgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQphZGRyZXNzU3RyAgxfaW5kZXhTdGFrZWQJAGUCBQ5zaGFyZUF2YWlsYWJsZQULc2hhcmVBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQICEmdsb2JhbF9pbmRleFN0YWtlZAkAZQIJAQ10cnlHZXRJbnRlZ2VyAQISZ2xvYmFsX2luZGV4U3Rha2VkBQtzaGFyZUFtb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFC3NoYXJlQW1vdW50CQERQGV4dHJOYXRpdmUoMTA1NykBAhNnbG9iYWxfcG9vbFRva2VuX2lkBQNuaWwBaQERY2xhaW1JbmRleFJld2FyZHMACQELY2xhaW1SZXN1bHQBCAUBaQZjYWxsZXIBaQELcmVkZWVtSW5kZXgBDHNlbmRUb09yaWdpbgQDcG10CQCRAwIIBQFpCHBheW1lbnRzAAADCQECIT0CCAUDcG10B2Fzc2V0SWQJAQx0cnlHZXRCaW5hcnkBAhNnbG9iYWxfcG9vbFRva2VuX2lkCQACAQIecGxlYXNlIGF0dGFjaCBwb29sIHNoYXJlIHRva2VuBAlQUmVkZWVtZWQIBQNwbXQGYW1vdW50BAZyZXN1bHQJARZoYW5kbGVQb29sVG9rZW5zUmVkZWVtAgUJUFJlZGVlbWVkAwUMc2VuZFRvT3JpZ2luCAUBaQxvcmlnaW5DYWxsZXIIBQFpBmNhbGxlcgkAzggCBQZyZXN1bHQJAMwIAgkBBEJ1cm4CCQEMdHJ5R2V0QmluYXJ5AQITZ2xvYmFsX3Bvb2xUb2tlbl9pZAUJUFJlZGVlbWVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhdnbG9iYWxfcG9vbFRva2VuX2Ftb3VudAkAZQIJAQ10cnlHZXRJbnRlZ2VyAQIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQFCVBSZWRlZW1lZAUDbmlsAWkBBHN3YXACCGFzc2V0T3V0B21pbmltdW0DCQEKaXNTaHV0ZG93bgAJAAIBAhpQb29sIGlzIGN1cnJlbnRseSBzaHV0ZG93bgQDcG10CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAECEFtb3VudEluCQEFdmFsdWUBCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQHQXNzZXRJbggFA3BtdAdhc3NldElkBAppbnZva2VTd2FwCQEKYXNJbnRUdXBsZQEJAP0HBAUEdGhpcwIMc3dhcEludGVybmFsCQDMCAIFCGFzc2V0T3V0CQDMCAIFB21pbmltdW0JAMwIAgUIQW1vdW50SW4JAMwIAgkBDmdldEFzc2V0U3RyaW5nAQUHQXNzZXRJbgkAzAgCCQClCAEIBQFpBmNhbGxlcgUDbmlsBQNuaWwDCQAAAgUKaW52b2tlU3dhcAUKaW52b2tlU3dhcAQOY2xlYW5BbW91bnRPdXQIBQppbnZva2VTd2FwAl8xAwkAAAIFDmNsZWFuQW1vdW50T3V0BQ5jbGVhbkFtb3VudE91dAQJZmVlQW1vdW50CAUKaW52b2tlU3dhcAJfMgMJAAACBQlmZWVBbW91bnQFCWZlZUFtb3VudAQOZmVlc01hbmFnZW1lbnQDAwkBCGJ1cm5GZWVzAAkBAiE9AgUIYXNzZXRPdXQCBVdBVkVTBwkAzAgCCQEEQnVybgIJAQV2YWx1ZQEJAQ1nZXRBc3NldEJ5dGVzAQUIYXNzZXRPdXQJAGsDBQlmZWVBbW91bnQAAgAECQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIHZ2xvYmFsXwUIYXNzZXRPdXQCB19idXJuZWQJAGQCCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfBQhhc3NldE91dAIHX2J1cm5lZAkAawMFCWZlZUFtb3VudAACAAQFA25pbAMJAAACBQhhc3NldE91dAkBDmdldFBldGVBc3NldElkAAQGdG9wdXAyCQD8BwQJARdnZXRGZWxpbmVGYXJtaW5nQWNjb3VudAACC3RvcFVwUmV3YXJkBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQkBDmdldFBldGVBc3NldElkAAkAawMFCWZlZUFtb3VudAABAAQFA25pbAMJAAACBQZ0b3B1cDIFBnRvcHVwMgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQEOZ2V0RmVlc0FjY291bnQACQBrAwUJZmVlQW1vdW50AAEABAkBDWdldEFzc2V0Qnl0ZXMBBQhhc3NldE91dAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJAQ5nZXRGZWVzQWNjb3VudAAJAGsDBQlmZWVBbW91bnQAAgAECQENZ2V0QXNzZXRCeXRlcwEFCGFzc2V0T3V0BQNuaWwDCQAAAgUOZmVlc01hbmFnZW1lbnQFDmZlZXNNYW5hZ2VtZW50CQCUCgIFDmZlZXNNYW5hZ2VtZW50BQ5jbGVhbkFtb3VudE91dAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQhpbnRlcm5hbAMFc3Rha2UGYW1vdW50B2Fzc2V0SWQDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgtOb3QgYWxsb3dlZAkBDHN0YWtlVW5zdGFrZQMFBXN0YWtlBQZhbW91bnQFB2Fzc2V0SWQBaQEIc3Rha2VBbGwACQEMc3Rha2VVbnN0YWtlAwYJAGUCCQENdHJ5R2V0SW50ZWdlcgECFGdsb2JhbF9XQVZFU19iYWxhbmNlCQENdHJ5R2V0SW50ZWdlcgECDmxlYXNpbmdfYW1vdW50AgVXQVZFUwFpAQxzd2FwSW50ZXJuYWwFCGFzc2V0T3V0B21pbmltdW0IQW1vdW50SW4HQXNzZXRJbgZjYWxsZXIDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhtZb3UgY2FudCBjYWxsIHRoaXMgZGlyZWN0bHkECEFzc2V0T3V0CQENZ2V0QXNzZXRCeXRlcwEFCGFzc2V0T3V0BANkYXkJARdjYWxjdWxhdGVEYXlzU2luY2VTdGFydAAEB3JldmVuZXUJAQ10cnlHZXRJbnRlZ2VyAQkBF3JldmVuZXVGb3JEYXlCeUFzc2V0T3V0AgUDZGF5BQhhc3NldE91dAQOQXNzZXRJbkJhbGFuY2UJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8FB0Fzc2V0SW4CCF9iYWxhbmNlAwkAAAIFDkFzc2V0SW5CYWxhbmNlBQ5Bc3NldEluQmFsYW5jZQQPQXNzZXRPdXRCYWxhbmNlCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfBQhhc3NldE91dAIIX2JhbGFuY2UDCQAAAgUPQXNzZXRPdXRCYWxhbmNlBQ9Bc3NldE91dEJhbGFuY2UECUFtb3VudE91dAkBEmNhbGN1bGF0ZU91dEFtb3VudAUFCEFtb3VudEluCQENZ2V0QXNzZXRCeXRlcwEFB0Fzc2V0SW4FCEFzc2V0T3V0BQ5Bc3NldEluQmFsYW5jZQUPQXNzZXRPdXRCYWxhbmNlAwkAAAIFCUFtb3VudE91dAUJQW1vdW50T3V0BAlmZWVBbW91bnQJAGsDBQlBbW91bnRPdXQFA0ZlZQUIRmVlU2NhbGUDCQAAAgUJZmVlQW1vdW50BQlmZWVBbW91bnQEDmNsZWFuQW1vdW50T3V0CQBlAgUJQW1vdW50T3V0BQlmZWVBbW91bnQDCQAAAgUOY2xlYW5BbW91bnRPdXQFDmNsZWFuQW1vdW50T3V0AwkAZgIFB21pbmltdW0FDmNsZWFuQW1vdW50T3V0CQACAQkArAICAithbW91bnQgdG8gcmVjaWV2ZSBpcyBsb3dlciB0aGFuIGdpdmVuIG9uZTogCQCkAwEFDmNsZWFuQW1vdW50T3V0AwkAZgIAAAkAZQIFD0Fzc2V0T3V0QmFsYW5jZQUJQW1vdW50T3V0CQACAQIbY29udHJhY3QgaXMgb3V0IG9mIHJlc2VydmVzAwkAAAIFCEFzc2V0T3V0CQENZ2V0QXNzZXRCeXRlcwEFB0Fzc2V0SW4JAAIBAhh0aGlzIHN3YXAgaXMgbm90IGFsbG93ZWQECXZvbHVtZUtleQkBEHZvbHVtZUZvckRheUJ5SW4CBQNkYXkFB0Fzc2V0SW4EBnZvbHVtZQkBDXRyeUdldEludGVnZXIBBQl2b2x1bWVLZXkEDG5ld0JhbGFuY2VJbgkAZAIFDkFzc2V0SW5CYWxhbmNlBQhBbW91bnRJbgMJAAACBQxuZXdCYWxhbmNlSW4FDG5ld0JhbGFuY2VJbgQFc3Rha2UJAP0HBAUEdGhpcwIIaW50ZXJuYWwJAMwIAgYJAMwIAgUIQW1vdW50SW4JAMwIAgUHQXNzZXRJbgUDbmlsBQNuaWwDCQAAAgUFc3Rha2UFBXN0YWtlBA1uZXdCYWxhbmNlT3V0CQBlAgUPQXNzZXRPdXRCYWxhbmNlBQlBbW91bnRPdXQDCQAAAgUNbmV3QmFsYW5jZU91dAUNbmV3QmFsYW5jZU91dAQHdW5zdGFrZQkA/QcEBQR0aGlzAghpbnRlcm5hbAkAzAgCBwkAzAgCCQBkAgUOY2xlYW5BbW91bnRPdXQJAGsDBQlmZWVBbW91bnQAAwAECQDMCAIFCGFzc2V0T3V0BQNuaWwFA25pbAMJAAACBQd1bnN0YWtlBQd1bnN0YWtlCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdnbG9iYWxfBQhhc3NldE91dAIIX2JhbGFuY2UJAGQCBQ1uZXdCYWxhbmNlT3V0CQBrAwUJZmVlQW1vdW50AAEABAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQERQGV4dHJOYXRpdmUoMTA2MikBBQZjYWxsZXIFDmNsZWFuQW1vdW50T3V0BQhBc3NldE91dAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICB2dsb2JhbF8FB0Fzc2V0SW4CCF9iYWxhbmNlBQxuZXdCYWxhbmNlSW4JAMwIAgkBDEludGVnZXJFbnRyeQICDmRheXNfc2luY2VfYXB5BQNkYXkJAMwIAgkBDEludGVnZXJFbnRyeQIJARdyZXZlbmV1Rm9yRGF5QnlBc3NldE91dAIFA2RheQUIYXNzZXRPdXQJAGQCBQdyZXZlbmV1BQlmZWVBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFCXZvbHVtZUtleQkAZAIFBnZvbHVtZQUIQW1vdW50SW4FA25pbAkAlAoCBQ5jbGVhbkFtb3VudE91dAUJZmVlQW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAMJAQlpc1Rlc3RFbnYACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BAlmaXJzdFVzZXIBIFEc5P1m/xJp0vFaFJ87suL0O3/By2gnojRebDjXV91tBApzZWNvbmRVc2VyASBccg5LrvEhT2bmGUX6aqKx7bE2KVlfGczMsOFNQYhqfQQJdGhpcmRVc2VyASCgr5HlLXlDYWEyEq2OufoYWVGdLVNJNsPQo/eoYBk7TgQPZmlyc3RVc2VyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUJZmlyc3RVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwABBQlmaXJzdFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFCWZpcnN0VXNlcgABAAAEEHNlY29uZFVzZXJTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQpzZWNvbmRVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwABBQpzZWNvbmRVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwACBQpzZWNvbmRVc2VyAAEAAAQPdGhpcmRVc2VyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUJdGhpcmRVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwABBQl0aGlyZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFCXRoaXJkVXNlcgABAAAED3NpZ25hdHVyZXNDb3VudAkAZAIJAGQCBQ9maXJzdFVzZXJTaWduZWQFEHNlY29uZFVzZXJTaWduZWQFD3RoaXJkVXNlclNpZ25lZAQHJG1hdGNoMAUCdHgJAGcCBQ9zaWduYXR1cmVzQ291bnQAAnHcupc=", "height": 3316722, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: 4ThP26WYewaxaQvhM2gDz4FoN2eou7CpX5YBFJeMPGX4 Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 6 #-}
2+{-# SCRIPT_TYPE ACCOUNT #-}
3+{-# CONTENT_TYPE DAPP #-}
4+let a = 1711065540000
5+
6+func b () = {
7+ let c = (lastBlock.timestamp - a)
8+ let d = (c / (86400 * 1000))
9+ d
10+ }
11+
12+
13+func e (f) = {
14+ let g = f
15+ if ($isInstanceOf(g, "(Int, Int)"))
16+ then {
17+ let h = g
18+ h
19+ }
20+ else throw("Wrong type, expected: Tuple Int")
21+ }
22+
23+
24+func i () = "static_eggAssetId"
25+
26+
27+func j () = "static_spiceAssetId"
28+
29+
30+func k () = "static_peteAssetId"
31+
32+
33+func l () = "static_mutantFarmingAddress"
34+
35+
36+func m () = "static_felineStakingAddress"
37+
38+
39+func n () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "static_oracle"), "oracle not found!")), "could not parse oracle")
40+
41+
42+func o () = addressFromStringValue(valueOrErrorMessage(getString(n(), "static_feeAggregator"), "static_feeAggregator not found!"))
43+
44+
45+func p () = addressFromStringValue(valueOrErrorMessage(getString(n(), "static_nodeAddress"), "node_address not found!"))
46+
47+
48+func q () = addressFromStringValue(valueOrErrorMessage(getString(n(), l()), (l() + " not found!")))
49+
50+
51+func r () = addressFromStringValue(valueOrErrorMessage(getString(n(), m()), (m() + " not found!")))
52+
53+
54+func s () = valueOrErrorMessage(getString(n(), j()), (j() + " not found!"))
55+
56+
57+func t () = valueOrErrorMessage(getString(n(), i()), (i() + " not found!"))
58+
59+
60+func u () = valueOrErrorMessage(getString(n(), k()), (k() + " not found!"))
61+
62+
63+func v (w) = {
64+ let g = getInteger(this, w)
65+ if ($isInstanceOf(g, "Int"))
66+ then {
67+ let x = g
68+ x
69+ }
70+ else 0
71+ }
72+
73+
74+func y (w) = {
75+ let g = getBinary(this, w)
76+ if ($isInstanceOf(g, "ByteVector"))
77+ then {
78+ let x = g
79+ x
80+ }
81+ else base58''
82+ }
83+
84+
85+func z (w) = {
86+ let g = getString(this, w)
87+ if ($isInstanceOf(g, "String"))
88+ then {
89+ let x = g
90+ x
91+ }
92+ else ""
93+ }
94+
95+
96+func A (B) = {
97+ let g = B
98+ if ($isInstanceOf(g, "ByteVector"))
99+ then {
100+ let x = g
101+ toBase58String(x)
102+ }
103+ else "WAVES"
104+ }
105+
106+
107+func C (D) = if ((D == "WAVES"))
108+ then unit
109+ else fromBase58String(D)
110+
111+
112+func E (F,G) = (F ++ [C(G)])
113+
114+
115+func H (F,G) = (F ++ [v((("static_" + A(G)) + "_weight"))])
116+
117+
118+func I (F,G) = (F ++ [v((("static_" + A(G)) + "_decimals"))])
119+
120+
121+func J (F,G) = (F ++ [v((("static_" + A(G)) + "_scale"))])
122+
123+
124+func K (F,G) = (F ++ [parseIntValue(G)])
125+
126+
127+func L (M,B) = ((("reveneu_day_" + B) + "_") + toString(M))
128+
129+
130+func N (M,B) = ((("volume_day_" + B) + "_") + toString(M))
131+
132+
133+let O = v("static_tokensAmount")
134+
135+let P = {
136+ let Q = split(z("static_tokenIds"), ",")
137+ let R = size(Q)
138+ let S = nil
139+ func T (U,V) = if ((V >= R))
140+ then U
141+ else E(U, Q[V])
142+
143+ func W (U,V) = if ((V >= R))
144+ then U
145+ else throw("List size exceeds 10")
146+
147+ W(T(T(T(T(T(T(T(T(T(T(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
148+ }
149+
150+let X = {
151+ let Q = P
152+ let R = size(Q)
153+ let S = nil
154+ func Y (U,V) = if ((V >= R))
155+ then U
156+ else H(U, Q[V])
157+
158+ func Z (U,V) = if ((V >= R))
159+ then U
160+ else throw("List size exceeds 10")
161+
162+ Z(Y(Y(Y(Y(Y(Y(Y(Y(Y(Y(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
163+ }
164+
165+let aa = {
166+ let Q = P
167+ let R = size(Q)
168+ let S = nil
169+ func ab (U,V) = if ((V >= R))
170+ then U
171+ else I(U, Q[V])
172+
173+ func ac (U,V) = if ((V >= R))
174+ then U
175+ else throw("List size exceeds 10")
176+
177+ ac(ab(ab(ab(ab(ab(ab(ab(ab(ab(ab(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
178+ }
179+
180+let ad = {
181+ let Q = P
182+ let R = size(Q)
183+ let S = nil
184+ func ae (U,V) = if ((V >= R))
185+ then U
186+ else J(U, Q[V])
187+
188+ func af (U,V) = if ((V >= R))
189+ then U
190+ else throw("List size exceeds 10")
191+
192+ af(ae(ae(ae(ae(ae(ae(ae(ae(ae(ae(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
193+ }
194+
195+let ag = z("last_stake_id")
196+
197+let ah = v("static_fee")
198+
199+let ai = 2
200+
201+let aj = 10000
202+
203+let ak = 100000000
204+
205+let al = 10000
206+
207+let am = 8
208+
209+let an = pow(10, 0, am, 0, 0, HALFUP)
210+
211+let ao = P
212+
213+func ap () = if ((z("static_oracle") != ""))
214+ then {
215+ let g = getBoolean(n(), ("amm_burn_" + toString(this)))
216+ if ($isInstanceOf(g, "Boolean"))
217+ then {
218+ let aq = g
219+ aq
220+ }
221+ else false
222+ }
223+ else false
224+
225+
226+func ar () = {
227+ let as = if ((z("static_oracle") != ""))
228+ then {
229+ let g = getBoolean(n(), "amm_shutdown")
230+ if ($isInstanceOf(g, "Boolean"))
231+ then {
232+ let aq = g
233+ aq
234+ }
235+ else false
236+ }
237+ else false
238+ let at = {
239+ let g = getBoolean(this, "is_shutdown")
240+ if ($isInstanceOf(g, "Boolean"))
241+ then {
242+ let aq = g
243+ aq
244+ }
245+ else false
246+ }
247+ if (as)
248+ then true
249+ else at
250+ }
251+
252+
253+func au () = if ((z("static_oracle") != ""))
254+ then {
255+ let g = getBoolean(n(), "amm_tx")
256+ if ($isInstanceOf(g, "Boolean"))
257+ then {
258+ let aq = g
259+ aq
260+ }
261+ else true
262+ }
263+ else true
264+
265+
266+func av (aw) = {
267+ let ax = A(P[aw])
268+ v((("global_" + ax) + "_balance"))
269+ }
270+
271+
272+func ay (az,ax) = {
273+ let aA = v("global_poolToken_amount")
274+ let aB = v((("global_" + A(ax)) + "_balance"))
275+ fraction(az, aA, aB, DOWN)
276+ }
277+
278+
279+func aC (aD) = {
280+ func aE (F,aF) = {
281+ let aG = ay(aF.amount, aF.assetId)
282+ if ((aG == 0))
283+ then throw("one of the tokens amounts is too low")
284+ else if (if ((F == 0))
285+ then true
286+ else (F > aG))
287+ then aG
288+ else F
289+ }
290+
291+ let aH = {
292+ let Q = aD
293+ let R = size(Q)
294+ let S = 0
295+ func aI (U,V) = if ((V >= R))
296+ then U
297+ else aE(U, Q[V])
298+
299+ func aJ (U,V) = if ((V >= R))
300+ then U
301+ else throw("List size exceeds 10")
302+
303+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
304+ }
305+ aH
306+ }
307+
308+
309+func aK (aD) = {
310+ func aL (F,aM) = (F ++ [aM.assetId])
311+
312+ let aN = {
313+ let Q = aD
314+ let R = size(Q)
315+ let S = nil
316+ func aI (U,V) = if ((V >= R))
317+ then U
318+ else aL(U, Q[V])
319+
320+ func aJ (U,V) = if ((V >= R))
321+ then U
322+ else throw("List size exceeds 10")
323+
324+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
325+ }
326+ if ((aN == aN))
327+ then {
328+ func aO (F,B) = if ((indexOf(aN, B) != unit))
329+ then (F + 1)
330+ else throw(("asset not attached: " + A(B)))
331+
332+ let aP = {
333+ let Q = P
334+ let R = size(Q)
335+ let S = 0
336+ func aQ (U,V) = if ((V >= R))
337+ then U
338+ else aO(U, Q[V])
339+
340+ func aR (U,V) = if ((V >= R))
341+ then U
342+ else throw("List size exceeds 10")
343+
344+ aR(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
345+ }
346+ if ((aP == aP))
347+ then true
348+ else throw("Strict value is not equal to itself.")
349+ }
350+ else throw("Strict value is not equal to itself.")
351+ }
352+
353+
354+func aS (aT,az,B) = if (if ((B == "WAVES"))
355+ then (az > 0)
356+ else false)
357+ then {
358+ let aU = valueOrElse(getInteger(this, "leasing_amount"), 0)
359+ let aV = if (aT)
360+ then (aU + az)
361+ else (aU - az)
362+ let aW = Lease(p(), aV)
363+ let aX = calculateLeaseId(aW)
364+ let aY = [aW, StringEntry("last_stake_id", toBase58String(aX)), IntegerEntry("leasing_amount", aV)]
365+ if ((ag != ""))
366+ then ([LeaseCancel(fromBase58String(ag))] ++ aY)
367+ else aY
368+ }
369+ else nil
370+
371+
372+func aZ (aG,aD,ba,bb) = {
373+ func bc (ax) = {
374+ func aE (F,aM) = if ((aM.assetId == ax))
375+ then aM.amount
376+ else F
377+
378+ let Q = aD
379+ let R = size(Q)
380+ let S = 0
381+ func aI (U,V) = if ((V >= R))
382+ then U
383+ else aE(U, Q[V])
384+
385+ func aJ (U,V) = if ((V >= R))
386+ then U
387+ else throw("List size exceeds 10")
388+
389+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
390+ }
391+
392+ func bd (F,ax) = {
393+ let be = v((("global_" + A(ax)) + "_balance"))
394+ let bf = v("global_poolToken_amount")
395+ let bg = v((("static_" + A(ax)) + "_scale"))
396+ let bh = fraction((fraction((bf + aG), bg, bf, CEILING) - bg), be, bg, CEILING)
397+ let bi = bc(ax)
398+ let bj = min([bh, bi])
399+ let bk = ((if ((bi != 0))
400+ then bi
401+ else 0) - bj)
402+ let bl = if (if (bb)
403+ then (bk > 0)
404+ else false)
405+ then [ScriptTransfer(ba, bk, ax)]
406+ else nil
407+ let bm = if ((A(ax) == "WAVES"))
408+ then aS(true, bj, "WAVES")
409+ else nil
410+ (((F ++ bl) ++ bm) ++ [IntegerEntry((("global_" + A(ax)) + "_balance"), (be + bj))])
411+ }
412+
413+ let Q = P
414+ let R = size(Q)
415+ let S = nil
416+ func aI (U,V) = if ((V >= R))
417+ then U
418+ else bd(U, Q[V])
419+
420+ func aJ (U,V) = if ((V >= R))
421+ then U
422+ else throw("List size exceeds 10")
423+
424+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
425+ }
426+
427+
428+func bn (bo,ba) = {
429+ func bp (F,ax) = {
430+ let be = v((("global_" + A(ax)) + "_balance"))
431+ let bf = v("global_poolToken_amount")
432+ let bg = v((("static_" + A(ax)) + "_scale"))
433+ let az = toInt(fraction((toBigInt(ak) - fraction(toBigInt((bf - bo)), toBigInt(ak), toBigInt(bf), CEILING)), toBigInt(be), toBigInt(ak), DOWN))
434+ let bm = if ((A(ax) == "WAVES"))
435+ then aS(false, az, "WAVES")
436+ else nil
437+ ((F ++ bm) ++ [IntegerEntry((("global_" + A(ax)) + "_balance"), (be - az)), ScriptTransfer(ba, az, ax)])
438+ }
439+
440+ let Q = P
441+ let R = size(Q)
442+ let S = nil
443+ func aI (U,V) = if ((V >= R))
444+ then U
445+ else bp(U, Q[V])
446+
447+ func aJ (U,V) = if ((V >= R))
448+ then U
449+ else throw("List size exceeds 10")
450+
451+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
452+ }
453+
454+
455+func bq (br,bs,bt,bu,bv) = {
456+ let bw = value(indexOf(P, bs))
457+ let bx = value(indexOf(P, bt))
458+ if ((bw == bx))
459+ then throw("wrong tokens pair")
460+ else fraction(bv, ((ak * ak) - toInt(pow(fraction(toBigInt(bu), toBigInt((ak * ak)), toBigInt((bu + br)), HALFUP), 16, toBigInt(fraction(X[bw], 10000, X[bx])), 4, 16, CEILING))), (ak * ak), DOWN)
461+ }
462+
463+
464+func by (bz,bA,bB) = {
465+ let bC = (("global_" + bz) + "_balance")
466+ let bD = getIntegerValue(this, bC)
467+ let bE = (("global_" + bA) + "_balance")
468+ let bF = getIntegerValue(this, bE)
469+ let bG = bq(bB, C(bz), C(bA), bD, bF)
470+ let bH = fraction(bG, ah, al)
471+ if ((bH == bH))
472+ then {
473+ let bI = (bG - bH)
474+ if ((bI == bI))
475+ then bI
476+ else throw("Strict value is not equal to itself.")
477+ }
478+ else throw("Strict value is not equal to itself.")
479+ }
480+
481+
482+func bJ (B) = {
483+ let g = B
484+ if ($isInstanceOf(g, "ByteVector"))
485+ then {
486+ let bl = g
487+ assetBalance(this, bl)
488+ }
489+ else wavesBalance(this).regular
490+ }
491+
492+
493+func bK (B,D,bL,bM) = {
494+ let bN = v("global_indexStaked")
495+ let bO = bM
496+ let bP = (bJ(B) - bL)
497+ let bQ = if ((bP > bO))
498+ then bP
499+ else bO
500+ let bR = (bQ - bO)
501+ let bS = if ((bN == 0))
502+ then 0
503+ else fraction(bR, ak, bN)
504+ let bT = v((("global_lastCheck_" + D) + "_interest"))
505+ (bT + bS)
506+ }
507+
508+
509+func bU (bV) = {
510+ let bW = toString(bV)
511+ let bX = v((bW + "_indexStaked"))
512+ func aE (F,B) = {
513+ let D = A(B)
514+ let bL = v((("global_" + A(B)) + "_balance"))
515+ let bM = v((("global_lastCheck_" + D) + "_earnings"))
516+ let bY = bK(B, D, bL, bM)
517+ let bQ = max([bM, (bJ(B) - bL)])
518+ let bZ = fraction(bX, (bY - v((((bW + "_lastCheck_") + D) + "_interest"))), ak)
519+ let ca = if ((bZ == 0))
520+ then nil
521+ else [ScriptTransfer(bV, bZ, B)]
522+ let cb = v((((bW + "_lastCheck_") + D) + "_claimed"))
523+ ((F ++ ca) ++ [IntegerEntry((("global_lastCheck_" + D) + "_earnings"), (bQ - bZ)), IntegerEntry((("global_lastCheck_" + D) + "_interest"), bY), IntegerEntry((((bW + "_lastCheck_") + D) + "_interest"), bY), IntegerEntry((((bW + "_lastCheck_") + D) + "_claimed"), (cb + bZ))])
524+ }
525+
526+ let F = {
527+ let Q = ao
528+ let R = size(Q)
529+ let S = nil
530+ func aI (U,V) = if ((V >= R))
531+ then U
532+ else aE(U, Q[V])
533+
534+ func aJ (U,V) = if ((V >= R))
535+ then U
536+ else throw("List size exceeds 10")
537+
538+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
539+ }
540+ (F ++ [IntegerEntry((bW + "_lastClaim"), lastBlock.timestamp)])
541+ }
542+
543+
544+func cc (bW,az) = {
545+ let cd = bU(addressFromStringValue(bW))
546+ (cd ++ [IntegerEntry((bW + "_indexStaked"), (v((bW + "_indexStaked")) + az)), IntegerEntry("global_indexStaked", (v("global_indexStaked") + az))])
547+ }
548+
549+
550+func ce (F,cf) = (F + parseIntValue(cf))
551+
552+
553+func cg (bV) = [StringEntry("static_oracle", bV)]
554+
555+
556+func ch () = {
557+ let ci = {
558+ let g = getBoolean(this, "TESTENV")
559+ if ($isInstanceOf(g, "Boolean"))
560+ then {
561+ let aq = g
562+ aq
563+ }
564+ else false
565+ }
566+ ci
567+ }
568+
569+
570+@Callable(cj)
571+func readOnlyFunc (bz,bA,bB) = {
572+ let ck = by(bz, bA, bB)
573+[IntegerEntry("DEBUG", ck)]
574+ }
575+
576+
577+
578+@Callable(cj)
579+func topUpFunds () = if ((size(cj.payments) != 1))
580+ then throw("Wrong payments attached!")
581+ else {
582+ let aM = cj.payments[0]
583+ let cl = aM.assetId
584+ if ((indexOf(P, cl) == unit))
585+ then throw("Not supported assetId")
586+ else {
587+ let az = aM.amount
588+ let bL = v((("global_" + A(cl)) + "_balance"))
589+ let M = b()
590+ let cm = v(L(M, A(cl)))
591+[IntegerEntry((("global_" + A(cl)) + "_balance"), (bL + az)), IntegerEntry("days_since_apy", M), IntegerEntry(L(M, A(cl)), (cm + az))]
592+ }
593+ }
594+
595+
596+
597+@Callable(cj)
598+func preInit (cn,co,cp,cq) = if ((this != cj.caller))
599+ then throw("admin only")
600+ else if ((size(cq) > 13))
601+ then throw("too large pool domain")
602+ else {
603+ let cr = split(cn, ",")
604+ let cs = {
605+ let Q = cr
606+ let R = size(Q)
607+ let S = nil
608+ func aI (U,V) = if ((V >= R))
609+ then U
610+ else E(U, Q[V])
611+
612+ func aJ (U,V) = if ((V >= R))
613+ then U
614+ else throw("List size exceeds 10")
615+
616+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
617+ }
618+ let ct = split(co, ",")
619+ let cu = {
620+ let Q = ct
621+ let R = size(Q)
622+ let S = 0
623+ func aQ (U,V) = if ((V >= R))
624+ then U
625+ else ce(U, Q[V])
626+
627+ func aR (U,V) = if ((V >= R))
628+ then U
629+ else throw("List size exceeds 10")
630+
631+ aR(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(aQ(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
632+ }
633+ func cv (F,cw) = if ((cw >= size(cs)))
634+ then F
635+ else {
636+ let cx = {
637+ let g = cs[cw]
638+ if ($isInstanceOf(g, "ByteVector"))
639+ then {
640+ let aq = g
641+ value(assetInfo(cs[cw])).decimals
642+ }
643+ else 8
644+ }
645+ (F ++ [IntegerEntry((("static_" + cr[cw]) + "_scale"), pow(10, 0, cx, 0, 0, DOWN)), IntegerEntry((("static_" + cr[cw]) + "_decimals"), cx), IntegerEntry((("static_" + cr[cw]) + "_weight"), value(parseInt(ct[cw])))])
646+ }
647+
648+ if ((cu != 100))
649+ then throw("sum of token weights must be equal to 100")
650+ else ({
651+ let Q = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
652+ let R = size(Q)
653+ let S = nil
654+ func cy (U,V) = if ((V >= R))
655+ then U
656+ else cv(U, Q[V])
657+
658+ func cz (U,V) = if ((V >= R))
659+ then U
660+ else throw("List size exceeds 10")
661+
662+ cz(cy(cy(cy(cy(cy(cy(cy(cy(cy(cy(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
663+ } ++ [StringEntry("static_tokenIds", cn), StringEntry("static_tokenWeights", co), IntegerEntry("static_tokensAmount", size(cs)), StringEntry("static_poolDomain", cq), StringEntry("static_baseTokenId", cp), IntegerEntry("static_fee", 100)])
664+ }
665+
666+
667+
668+@Callable(cj)
669+func init (cA) = {
670+ func cB () = {
671+ func aE (F,cf) = (F ++ [IntegerEntry((("global_" + A(cf.assetId)) + "_balance"), cf.amount)])
672+
673+ let Q = cj.payments
674+ let R = size(Q)
675+ let S = nil
676+ func aI (U,V) = if ((V >= R))
677+ then U
678+ else aE(U, Q[V])
679+
680+ func aJ (U,V) = if ((V >= R))
681+ then U
682+ else throw("List size exceeds 10")
683+
684+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
685+ }
686+
687+ func cC (aD) = {
688+ func aE (F,cD) = {
689+ let B = cD.assetId
690+ func aO (F,cf) = if ((cf == B))
691+ then value(indexOf(P, cf))
692+ else F
693+
694+ let cE = {
695+ let Q = P
696+ let R = size(Q)
697+ let S = 1
698+ func aI (U,V) = if ((V >= R))
699+ then U
700+ else aO(U, Q[V])
701+
702+ func aJ (U,V) = if ((V >= R))
703+ then U
704+ else throw("List size exceeds 10")
705+
706+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
707+ }
708+ fraction(F, pow(cD.amount, aa[cE], X[cE], ai, 8, FLOOR), ak)
709+ }
710+
711+ let Q = aD
712+ let R = size(Q)
713+ let S = an
714+ func aI (U,V) = if ((V >= R))
715+ then U
716+ else aE(U, Q[V])
717+
718+ func aJ (U,V) = if ((V >= R))
719+ then U
720+ else throw("List size exceeds 10")
721+
722+ aJ(aI(aI(aI(aI(aI(aI(aI(aI(aI(aI(S, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
723+ }
724+
725+ if ((v("global_wasInited") > 0))
726+ then throw("pool already inited")
727+ else {
728+ let cF = cC(cj.payments)
729+ if ((cF == 0))
730+ then throw("you need a bigger tokens amount to launch the pool")
731+ else {
732+ let cG = Issue(("WD " + z("static_poolDomain")), "WD pool token", cF, am, true, unit, 0)
733+ let cH = calculateAssetId(cG)
734+ ((cB() ++ [cG, IntegerEntry("global_poolToken_amount", cF), IntegerEntry("global_wasInited", 1), BinaryEntry("global_poolToken_id", cH), StringEntry("static_poolToken_idStr", A(cH)), ScriptTransfer(cj.caller, cF, cH)]) ++ cg(cA))
735+ }
736+ }
737+ }
738+
739+
740+
741+@Callable(cj)
742+func generateIndex (bb) = if ((size(cj.payments) != O))
743+ then throw(("you need to attach all pool tokens. amount of pool tokens: " + toString(O)))
744+ else if (!(aK(cj.payments)))
745+ then throw("wrong assets attached")
746+ else {
747+ let aG = aC(cj.payments)
748+ let cI = Reissue(getBinaryValue("global_poolToken_id"), aG, true)
749+ let cJ = aZ(aG, cj.payments, cj.originCaller, bb)
750+ $Tuple2((cJ ++ [cI, ScriptTransfer(cj.caller, aG, y("global_poolToken_id")), IntegerEntry("global_poolToken_amount", (v("global_poolToken_amount") + aG))]), aG)
751+ }
752+
753+
754+
755+@Callable(cj)
756+func stakeIndex () = {
757+ let bW = toString(cj.originCaller)
758+ let cD = cj.payments[0]
759+ if ((value(cD.assetId) != y("global_poolToken_id")))
760+ then throw("wrong asset attached")
761+ else cc(bW, cD.amount)
762+ }
763+
764+
765+
766+@Callable(cj)
767+func unstakeIndex (bX) = {
768+ let bW = toString(cj.originCaller)
769+ let cK = v((bW + "_indexStaked"))
770+ if ((bX > cK))
771+ then throw("you don't have index tokens available")
772+ else (bU(cj.originCaller) ++ [IntegerEntry((bW + "_indexStaked"), (cK - bX)), IntegerEntry("global_indexStaked", (v("global_indexStaked") - bX)), ScriptTransfer(cj.caller, bX, getBinaryValue("global_poolToken_id"))])
773+ }
774+
775+
776+
777+@Callable(cj)
778+func claimIndexRewards () = bU(cj.caller)
779+
780+
781+
782+@Callable(cj)
783+func redeemIndex (cL) = {
784+ let cD = cj.payments[0]
785+ if ((cD.assetId != y("global_poolToken_id")))
786+ then throw("please attach pool share token")
787+ else {
788+ let bo = cD.amount
789+ let cJ = bn(bo, if (cL)
790+ then cj.originCaller
791+ else cj.caller)
792+ (cJ ++ [Burn(y("global_poolToken_id"), bo), IntegerEntry("global_poolToken_amount", (v("global_poolToken_amount") - bo))])
793+ }
794+ }
795+
796+
797+
798+@Callable(cj)
799+func swap (bt,cM) = if (ar())
800+ then throw("Pool is currently shutdown")
801+ else {
802+ let cD = value(cj.payments[0])
803+ let br = value(cj.payments[0].amount)
804+ let cN = cD.assetId
805+ let cO = e(reentrantInvoke(this, "swapInternal", [bt, cM, br, A(cN), toString(cj.caller)], nil))
806+ if ((cO == cO))
807+ then {
808+ let bI = cO._1
809+ if ((bI == bI))
810+ then {
811+ let bH = cO._2
812+ if ((bH == bH))
813+ then {
814+ let cP = if (if (ap())
815+ then (bt != "WAVES")
816+ else false)
817+ then [Burn(value(C(bt)), fraction(bH, 2, 4)), IntegerEntry((("global_" + bt) + "_burned"), (v((("global_" + bt) + "_burned")) + fraction(bH, 2, 4)))]
818+ else if ((bt == u()))
819+ then {
820+ let cQ = invoke(r(), "topUpReward", nil, [AttachedPayment(fromBase58String(u()), fraction(bH, 1, 4))])
821+ if ((cQ == cQ))
822+ then [ScriptTransfer(o(), fraction(bH, 1, 4), C(bt))]
823+ else throw("Strict value is not equal to itself.")
824+ }
825+ else [ScriptTransfer(o(), fraction(bH, 2, 4), C(bt))]
826+ if ((cP == cP))
827+ then $Tuple2(cP, bI)
828+ else throw("Strict value is not equal to itself.")
829+ }
830+ else throw("Strict value is not equal to itself.")
831+ }
832+ else throw("Strict value is not equal to itself.")
833+ }
834+ else throw("Strict value is not equal to itself.")
835+ }
836+
837+
838+
839+@Callable(cj)
840+func internal (aT,az,B) = if ((cj.caller != this))
841+ then throw("Not allowed")
842+ else aS(aT, az, B)
843+
844+
845+
846+@Callable(cj)
847+func stakeAll () = aS(true, (v("global_WAVES_balance") - v("leasing_amount")), "WAVES")
848+
849+
850+
851+@Callable(cj)
852+func swapInternal (bt,cM,br,cN,cR) = if ((cj.caller != this))
853+ then throw("You cant call this directly")
854+ else {
855+ let cS = C(bt)
856+ let M = b()
857+ let cm = v(L(M, bt))
858+ let cT = v((("global_" + cN) + "_balance"))
859+ if ((cT == cT))
860+ then {
861+ let cU = v((("global_" + bt) + "_balance"))
862+ if ((cU == cU))
863+ then {
864+ let cV = bq(br, C(cN), cS, cT, cU)
865+ if ((cV == cV))
866+ then {
867+ let bH = fraction(cV, ah, al)
868+ if ((bH == bH))
869+ then {
870+ let bI = (cV - bH)
871+ if ((bI == bI))
872+ then if ((cM > bI))
873+ then throw(("amount to recieve is lower than given one: " + toString(bI)))
874+ else if ((0 > (cU - cV)))
875+ then throw("contract is out of reserves")
876+ else if ((cS == C(cN)))
877+ then throw("this swap is not allowed")
878+ else {
879+ let cW = N(M, cN)
880+ let cX = v(cW)
881+ let cY = (cT + br)
882+ if ((cY == cY))
883+ then {
884+ let aT = reentrantInvoke(this, "internal", [true, br, cN], nil)
885+ if ((aT == aT))
886+ then {
887+ let cZ = (cU - cV)
888+ if ((cZ == cZ))
889+ then {
890+ let da = reentrantInvoke(this, "internal", [false, (bI + fraction(bH, 3, 4)), bt], nil)
891+ if ((da == da))
892+ then $Tuple2([IntegerEntry((("global_" + bt) + "_balance"), (cZ + fraction(bH, 1, 4))), ScriptTransfer(addressFromStringValue(cR), bI, cS), IntegerEntry((("global_" + cN) + "_balance"), cY), IntegerEntry("days_since_apy", M), IntegerEntry(L(M, bt), (cm + bH)), IntegerEntry(cW, (cX + br))], $Tuple2(bI, bH))
893+ else throw("Strict value is not equal to itself.")
894+ }
895+ else throw("Strict value is not equal to itself.")
896+ }
897+ else throw("Strict value is not equal to itself.")
898+ }
899+ else throw("Strict value is not equal to itself.")
900+ }
901+ else throw("Strict value is not equal to itself.")
902+ }
903+ else throw("Strict value is not equal to itself.")
904+ }
905+ else throw("Strict value is not equal to itself.")
906+ }
907+ else throw("Strict value is not equal to itself.")
908+ }
909+ else throw("Strict value is not equal to itself.")
910+ }
911+
912+
913+@Verifier(db)
914+func dc () = if (ch())
915+ then sigVerify(db.bodyBytes, db.proofs[0], db.senderPublicKey)
916+ else {
917+ let dd = base58'6TdaXEfhnjYquvPf3yV7MFxt2CbgFmaqsvGwkKfXtKi4'
918+ let de = base58'7DsP2WaMLocbHuUxux7pbXRjTrrZ1TFQPsi5QumS3gr8'
919+ let df = base58'BpFWP3p3JgYrrP45xfrKzeMcWMEXoinj4FVPPkUiA8D3'
920+ let dg = if (sigVerify(db.bodyBytes, db.proofs[0], dd))
921+ then 1
922+ else if (sigVerify(db.bodyBytes, db.proofs[1], dd))
923+ then 1
924+ else if (sigVerify(db.bodyBytes, db.proofs[2], dd))
925+ then 1
926+ else 0
927+ let dh = if (sigVerify(db.bodyBytes, db.proofs[0], de))
928+ then 1
929+ else if (sigVerify(db.bodyBytes, db.proofs[1], de))
930+ then 1
931+ else if (sigVerify(db.bodyBytes, db.proofs[2], de))
932+ then 1
933+ else 0
934+ let di = if (sigVerify(db.bodyBytes, db.proofs[0], df))
935+ then 1
936+ else if (sigVerify(db.bodyBytes, db.proofs[1], df))
937+ then 1
938+ else if (sigVerify(db.bodyBytes, db.proofs[2], df))
939+ then 1
940+ else 0
941+ let dj = ((dg + dh) + di)
942+ let g = db
943+ (dj >= 2)
944+ }
945+

github/deemru/w8io/c3f4982 
37.92 ms