tx · FabvQhQiL89SSAQDjnsG6zntzunGFgrGWNg7cAJuVjy7

3PBhJMugz8Gxvn3mNs7a3sbJY6fbsAQMKfg:  -0.03800000 Waves

2022.11.25 10:56 [3397801] smart account 3PBhJMugz8Gxvn3mNs7a3sbJY6fbsAQMKfg > SELF 0.00000000 Waves

{ "type": 13, "id": "FabvQhQiL89SSAQDjnsG6zntzunGFgrGWNg7cAJuVjy7", "fee": 3800000, "feeAssetId": null, "timestamp": 1669362808095, "version": 2, "chainId": 87, "sender": "3PBhJMugz8Gxvn3mNs7a3sbJY6fbsAQMKfg", "senderPublicKey": "6HroEdc5WXn2cvBrujAQhcu9HR4zC2iUoXZVvmSrxyyb", "proofs": [ "", "1EPsEkEfqazDbfQUnSGjCWVpJ77VUSU9PRxT9uzyq3dakRdkR5y5MCAq4XpRNB8ePE7HKvNnLCM8UteFS3vgomq", "4esxtzEJym5fydRD1iiSHa4wpts8PD2fWyTzh32wVtEXxYguhoikskBFpPJkqSAYCGsDFs5dyqM7YchYj54UaP6S" ], "script": "base64:BgJmCAISBAoCEQESBQoDCAEBEgUKAwEEARIECgIRCBIDCgEBEgYKBAgIAQgSBAoCCAESAwoBERIECgIRARIFCgMBCAgSBAoCCAESBQoDCAEBEgASABIECgIRBBIECgIBARIAEgASABIAXAAJUFJFQ0lTSU9OAMCEPQAFTUFYX0EAwIQ9AAxNQVhfQV9DSEFOR0UACgAIREVDSU1BTFMABgANTUlOX1JBTVBfVElNRQkAaQIAgKMFADwAB3ZlcnNpb24CBTMuMC4wAAhrVmVyc2lvbgIHdmVyc2lvbgAHa0Fzc2V0cwIJYXNzZXRfaWRzAA1rQXNzZXRCYWxhbmNlAghfYmFsYW5jZQAHa0FjdGl2ZQIGYWN0aXZlAAtrQWN0aXZlR2xvYgIUYWN0aXZlX2FsbF9jb250cmFjdHMABmtDYXVzZQIOc2h1dGRvd25fY2F1c2UADWtTaGFyZUFzc2V0SWQCDnNoYXJlX2Fzc2V0X2lkABFrU2hhcmVBc3NldFN1cHBseQISc2hhcmVfYXNzZXRfc3VwcGx5AARrRmVlAgpjb21taXNzaW9uABJrREFwcFRocmVzaG9sZENvZWYCEWRBcHBUaHJlc2hvbGRDb2VmAAxrVVNETkFkZHJlc3MCGHN0YWtpbmdfdXNkbm5zYnRfYWRkcmVzcwAKa0Rpc2NvdW50cwIJZGlzY291bnRzAA9rRGlzY291bnRWYWx1ZXMCD2Rpc2NvdW50X3ZhbHVlcwAOa1VzZXJTd29wSW5Hb3YCDF9TV09QX2Ftb3VudAAPa1VzZXJHU3dvcEluR292Ag1fR1N3b3BfYW1vdW50AA1rQWRtaW5QdWJLZXkxAgthZG1pbl9wdWJfMQANa0FkbWluUHViS2V5MgILYWRtaW5fcHViXzIADWtBZG1pblB1YktleTMCC2FkbWluX3B1Yl8zABJrQWRtaW5JbnZva2VQdWJLZXkCEGFkbWluX2ludm9rZV9wdWIAEGtNb25leUJveEFkZHJlc3MCEW1vbmV5X2JveF9hZGRyZXNzAAtrR292QWRkcmVzcwISZ292ZXJuYW5jZV9hZGRyZXNzAA5rVm90aW5nQWRkcmVzcwIOdm90aW5nX2FkZHJlc3MAD2tGYXJtaW5nQWRkcmVzcwIPZmFybWluZ19hZGRyZXNzABFrTFBGYXJtaW5nQWRkcmVzcwIKbHBfZmFybWluZwAGb3JhY2xlCQEHQWRkcmVzcwEBGgFXiv8IaJo1ukDNYXTyEjfepjfw+jjO6B44ARNnZXRCYXNlNThGcm9tT3JhY2xlAQNrZXkEByRtYXRjaDAJAJ0IAgUGb3JhY2xlBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAZzdHJpbmcFByRtYXRjaDAJANkEAQUGc3RyaW5nBAdub3RoaW5nBQckbWF0Y2gwCQACAQkArAICBQNrZXkCCGlzIGVtcHR5AAxhZG1pblB1YktleTEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUNa0FkbWluUHViS2V5MQAMYWRtaW5QdWJLZXkyCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDWtBZG1pblB1YktleTIADGFkbWluUHViS2V5MwkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQ1rQWRtaW5QdWJLZXkzABFhZG1pblB1YktleUludm9rZQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBRJrQWRtaW5JbnZva2VQdWJLZXkAD21vbmV5Qm94QWRkcmVzcwkBB0FkZHJlc3MBCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFEGtNb25leUJveEFkZHJlc3MACmdvdkFkZHJlc3MJAQdBZGRyZXNzAQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQtrR292QWRkcmVzcwASc3Rha2luZ1VTRE5BZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUMa1VTRE5BZGRyZXNzAA12b3RpbmdBZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUOa1ZvdGluZ0FkZHJlc3MADmZhcm1pbmdBZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUPa0Zhcm1pbmdBZGRyZXNzABBscEZhcm1pbmdBZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQURa0xQRmFybWluZ0FkZHJlc3MABFVTRE4BILYmKcME9c5TkaQOS3UkL2SMUbH6369UKb1I0h0qsqrRAA1zdGFraW5nQXNzZXRzCQDMCAIJANgEAQUEVVNETgUDbmlsAAZhY3RpdmUJARFAZXh0ck5hdGl2ZSgxMDUxKQIFBHRoaXMFB2tBY3RpdmUACmFjdGl2ZUdsb2IJAQt2YWx1ZU9yRWxzZQIJAJsIAgUGb3JhY2xlBQtrQWN0aXZlR2xvYgYADHNoYXJlQXNzZXRJZAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQ1rU2hhcmVBc3NldElkAAtzaGFyZVN1cHBseQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwURa1NoYXJlQXNzZXRTdXBwbHkACWZlZVNjYWxlNgDAhD0AA2ZlZQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwUEa0ZlZQANZmVlR292ZXJuYW5jZQkAawMAKAUJZmVlU2NhbGU2AGQACWluaXRpYWxfQQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwIJaW5pdGlhbF9BAAhmdXR1cmVfQQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwIIZnV0dXJlX0EADmluaXRpYWxfQV90aW1lCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMCDmluaXRpYWxfQV90aW1lAAAADWZ1dHVyZV9BX3RpbWUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwINZnV0dXJlX0FfdGltZQAAAAhhc3NldElkcwkAtQkCCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQdrQXNzZXRzAgEsAAZuQ29pbnMJAJADAQUIYXNzZXRJZHMBB3N1c3BlbmQBBWNhdXNlCQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBwkAzAgCCQELU3RyaW5nRW50cnkCBQZrQ2F1c2UFBWNhdXNlBQNuaWwBDXRocm93SXNBY3RpdmUACQACAQIWREFwcCBpcyBhbHJlYWR5IGFjdGl2ZQEIaXNBY3RpdmUAAwMFBmFjdGl2ZQUKYWN0aXZlR2xvYgcFBHVuaXQJAAIBAh9EQXBwIGlzIGluYWN0aXZlIGF0IHRoaXMgbW9tZW50AQtpc0FkbWluQ2FsbAEBaQMJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFDGFkbWluUHViS2V5MQkAzAgCBQxhZG1pblB1YktleTIJAMwIAgUMYWRtaW5QdWJLZXkzBQNuaWwIBQFpD2NhbGxlclB1YmxpY0tleQUEdW5pdAkAAgECIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgEKaXNTZWxmQ2FsbAEBaQMJAAACBQR0aGlzCAUBaQZjYWxsZXIFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAARiaWcyCQC2AgEAAgAGaXRlcjEwCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQUDbmlsAAZpdGVyMTUJAMwIAgAACQDMCAIAAQkAzAgCAAIJAMwIAgADCQDMCAIABAkAzAgCAAUJAMwIAgAGCQDMCAIABwkAzAgCAAgJAMwIAgAJCQDMCAIACgkAzAgCAAsJAMwIAgAMCQDMCAIADQkAzAgCAA4FA25pbAAGaXRlcjE2CQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQkAzAgCAAoJAMwIAgALCQDMCAIADAkAzAgCAA0JAMwIAgAOCQDMCAIADwUDbmlsAA5ibG9ja1RpbWVzdGFtcAUGaGVpZ2h0AQZhc3NlcnQBAWEDBQFhBwYBFGNhbGN1bGF0ZUZlZURpc2NvdW50AQh1c2VyQWRkcgQEdXNlcgQHJG1hdGNoMAUIdXNlckFkZHIDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQBdQUHJG1hdGNoMAkApQgBBQF1AwkAAQIFByRtYXRjaDACBlN0cmluZwQBdQUHJG1hdGNoMAUBdQkAAgECGFVua25vdyB0eXBlIG9mIHVzZXIgQWRkcgQKc3dvcEFtb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQpnb3ZBZGRyZXNzCQCsAgIFBHVzZXIFD2tVc2VyR1N3b3BJbkdvdgAABAtnU3dvcEFtb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQpnb3ZBZGRyZXNzCQCsAgIFBHVzZXIFD2tVc2VyR1N3b3BJbkdvdgUKc3dvcEFtb3VudAQOZGlzY291bnRWYWx1ZXMJALUJAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUGb3JhY2xlBQ9rRGlzY291bnRWYWx1ZXMCASwECWRpc2NvdW50cwkAtQkCCQERQGV4dHJOYXRpdmUoMTA1MykCBQZvcmFjbGUFCmtEaXNjb3VudHMCASwDAwkAZwIFC2dTd29wQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUOZGlzY291bnRWYWx1ZXMAAAkAZgIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ5kaXNjb3VudFZhbHVlcwABBQtnU3dvcEFtb3VudAcJAGUCBQlmZWVTY2FsZTYJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQlkaXNjb3VudHMAAAMDCQBnAgULZ1N3b3BBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ5kaXNjb3VudFZhbHVlcwABCQBmAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDmRpc2NvdW50VmFsdWVzAAIFC2dTd29wQW1vdW50BwkAZQIFCWZlZVNjYWxlNgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCWRpc2NvdW50cwABAwMJAGcCBQtnU3dvcEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDmRpc2NvdW50VmFsdWVzAAIJAGYCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUOZGlzY291bnRWYWx1ZXMAAwULZ1N3b3BBbW91bnQHCQBlAgUJZmVlU2NhbGU2CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUJZGlzY291bnRzAAIDAwkAZwIFC2dTd29wQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUOZGlzY291bnRWYWx1ZXMAAwkAZgIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ5kaXNjb3VudFZhbHVlcwAEBQtnU3dvcEFtb3VudAcJAGUCBQlmZWVTY2FsZTYJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQlkaXNjb3VudHMAAwMJAGcCBQtnU3dvcEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDmRpc2NvdW50VmFsdWVzAAQJAGUCBQlmZWVTY2FsZTYJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQlkaXNjb3VudHMABAUJZmVlU2NhbGU2AQJfQQAEAnQxBQ1mdXR1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BSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBAp4cF9yZWR1Y2VkCAUNJHQwMTAyMDMxMDI2NwJfMQQFaW5kZXgIBQ0kdDAxMDIwMzEwMjY3Al8yBAx4cF9yZWR1Y2VkX2kJAJEDAgUKeHBfcmVkdWNlZAUBaQQCZHkJAGUCCQBlAgUMeHBfcmVkdWNlZF9pCQEHZ2V0X3lfRAQFA2FtcAUBaQUKeHBfcmVkdWNlZAUCRDEAAQkAlAoCBQJkeQkAZQIFBGR5XzAFAmR5AQ1nZXRTdHJBc3NldElkAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwCQDYBAEFAmlkAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwAgVXQVZFUwkAAgECC01hdGNoIGVycm9yARhjYWxjU3Rha2luZ0Z1bmNBbmRBZGRyZXMCBXN0YWtlB2Fzc2V0SWQDBQVzdGFrZQkAlAoCAgxsb2NrTmV1dHJpbm8FEnN0YWtpbmdVU0ROQWRkcmVzcwkAlAoCAg51bmxvY2tOZXV0cmlubwUSc3Rha2luZ1VTRE5BZGRyZXNzARFjYWxjU3Rha2luZ1BhcmFtcwMFc3Rha2UGYW1vdW50B2Fzc2V0SWQDBQVzdGFrZQQNJHQwMTA4MzExMDg5NwkBGGNhbGNTdGFraW5nRnVuY0FuZEFkZHJlcwIFBXN0YWtlBQdhc3NldElkBARjYWxsCAUNJHQwMTA4MzExMDg5NwJfMQQLc3Rha2luZ0FkZHIIBQ0kdDAxMDgzMTEwODk3Al8yCQCWCgQFBGNhbGwFC3N0YWtpbmdBZGRyBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFB2Fzc2V0SWQFBmFtb3VudAUDbmlsBA0kdDAxMDk4MzExMDQ5CQEYY2FsY1N0YWtpbmdGdW5jQW5kQWRkcmVzAgUFc3Rha2UFB2Fzc2V0SWQEBGNhbGwIBQ0kdDAxMDk4MzExMDQ5Al8xBAtzdGFraW5nQWRkcggFDSR0MDEwOTgzMTEwNDkCXzIJAJYKBAUEY2FsbAULc3Rha2luZ0FkZHIJAMwIAgUGYW1vdW50CQDMCAIJANgEAQUHYXNzZXRJZAUDbmlsBQNuaWwBBXN0YWtlAgZhbW91bnQNYXNzZXRJZFN0cmluZwMJAQ9jb250YWluc0VsZW1lbnQCBQ1zdGFraW5nQXNzZXRzBQ1hc3NldElkU3RyaW5nBA0kdDAxMTIzNjExMzM4CQERY2FsY1N0YWtpbmdQYXJhbXMDBgUGYW1vdW50CQDZBAEFDWFzc2V0SWRTdHJpbmcEBGNhbGwIBQ0kdDAxMTIzNjExMzM4Al8xBARhZGRyCAUNJHQwMTEyMzYxMTMzOAJfMgQGcGFyYW1zCAUNJHQwMTEyMzYxMTMzOAJfMwQIcGF5bWVudHMIBQ0kdDAxMTIzNjExMzM4Al80CQD8BwQFBGFkZHIFBGNhbGwFBnBhcmFtcwUIcGF5bWVudHMAAAEHdW5zdGFrZQIGYW1vdW50DWFzc2V0SWRTdHJpbmcDCQEPY29udGFpbnNFbGVtZW50AgUNc3Rha2luZ0Fzc2V0cwUNYXNzZXRJZFN0cmluZwQNJHQwMTE1MjMxMTYyNgkBEWNhbGNTdGFraW5nUGFyYW1zAwcFBmFtb3VudAkA2QQBBQ1hc3NldElkU3RyaW5nBARjYWxsCAUNJHQwMTE1MjMxMTYyNgJfMQQEYWRkcggFDSR0MDExNTIzMTE2MjYCXzIEBnBhcmFtcwgFDSR0MDExNTIzMTE2MjYCXzMECHBheW1lbnRzCAUNJHQwMTE1MjMxMTYyNgJfNAkA/AcEBQRhZGRyBQRjYWxsBQZwYXJhbXMFCHBheW1lbnRzAAABDHN0YWtlZEFtb3VudAEHYXNzZXRJZAQWc3Rha2VkQW1vdW50Q2FsY3VsYXRlZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBANhSWQFByRtYXRjaDADCQAAAgUDYUlkBQRVU0ROCQCaCAIFEnN0YWtpbmdVU0ROQWRkcmVzcwkArAICCQCsAgIJAKwCAgIMcnBkX2JhbGFuY2VfCQDYBAEFA2FJZAIBXwkApQgBBQR0aGlzAAADCQABAgUHJG1hdGNoMAIEVW5pdAAACQACAQILTWF0Y2ggZXJyb3IEByRtYXRjaDAFFnN0YWtlZEFtb3VudENhbGN1bGF0ZWQDCQABAgUHJG1hdGNoMAIDSW50BAFpBQckbWF0Y2gwBQFpAAABD2NoZWNrU3VzcGljaW91cwAEEGNvbnRyYWN0QmFsYW5jZXMJAQNfeHAACgEMY2hlY2tCYWxhbmNlAgNhY2MHYXNzZXRJZAQNJHQwMTIyMzcxMjI2MgUDYWNjBApzdXNwaWNpb3VzCAUNJHQwMTIyMzcxMjI2MgJfMQQBaQgFDSR0MDEyMjM3MTIyNjICXzIDBQpzdXNwaWNpb3VzCQCUCgIFCnN1c3BpY2lvdXMFAWkECGFCYWxhbmNlCQBkAgkA8AcCBQR0aGlzCQDZBAEFB2Fzc2V0SWQJAQxzdGFrZWRBbW91bnQBCQDZBAEFB2Fzc2V0SWQDCQBmAgkAkQMCBRBjb250cmFjdEJhbGFuY2VzBQFpBQhhQmFsYW5jZQkAlAoCBgUBaQkAlAoCBwkAZAIFAWkAAQoAAiRsBQhhc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgcAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEMY2hlY2tCYWxhbmNlAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKARFzdXNwZW5kU3VzcGljaW91cwEBaQkBB3N1c3BlbmQBCQCsAgICHVN1c3BpY2lvdXMgc3RhdGUgd2l0aCBhc3NldDogCQCRAwIFCGFzc2V0SWRzBQFpAQ5yZXR1cm5QYXltZW50cwIGY2FsbGVyCHBheW1lbnRzCgENcGFyc2VQYXltZW50cwIDYWNjB3BheW1lbnQJAM0IAgUDYWNjCQEOU2NyaXB0VHJhbnNmZXIDBQZjYWxsZXIIBQdwYXltZW50BmFtb3VudAgFB3BheW1lbnQHYXNzZXRJZAoAAiRsBQhwYXltZW50cwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQENcGFyc2VQYXltZW50cwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgESY2hlY2tEQXBwVGhyZXNob2xkAQtuZXdCYWxhbmNlcwQRZEFwcFRocmVzaG9sZENvZWYJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQR0aGlzBRJrREFwcFRocmVzaG9sZENvZWYCGE5vIGRBcHBUaHJlc2hvbGRDb2VmIGtleQQOdGhyZXNob2xkU2NhbGUAkE4ECm1heEJhbGFuY2UJAJYDAQULbmV3QmFsYW5jZXMECm1pbkJhbGFuY2UJAJcDAQULbmV3QmFsYW5jZXMEBXJhdGlvCQBrAwUKbWF4QmFsYW5jZQUOdGhyZXNob2xkU2NhbGUFCm1pbkJhbGFuY2UDCQBmAgUFcmF0aW8JAGgCBRFkQXBwVGhyZXNob2xkQ29lZgUOdGhyZXNob2xkU2NhbGUJAAIBAjhOZXcgYmFsYW5jZSBpbiBhc3NldHMgb2YgdGhlIERBcHAgaXMgbGVzcyB0aGFuIHRocmVzaG9sZAcBCmNoZWNrQ29pbnMBCGFzc2V0SWRzBAVjb2lucwkAtQkCBQhhc3NldElkcwIBLAMJAGYCCQCQAwEFBWNvaW5zAAoJAAIBAiBUbyBtYW55IGNvaW5zLCBtYXggY29pbnMgc2l6ZSAxMAoBCWNoZWNrQ29pbgIFZXJyb3IHYXNzZXRJZAQFYXNzZXQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA2QQBBQdhc3NldElkCQCsAgICEmZyb21CYXNlNThTdHJpbmc6IAUHYXNzZXRJZAQIZGVjaW1hbHMICQETdmFsdWVPckVycm9yTWVzc2FnZQIJAOwHAQUFYXNzZXQJAKwCAgILYXNzZXRJbmZvOiAFB2Fzc2V0SWQIZGVjaW1hbHMDCQECIT0CBQhkZWNpbWFscwUIREVDSU1BTFMJAAIBAg53cm9uZyBkZWNpbWFscwcKAAIkbAUFY29pbnMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBwoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEJY2hlY2tDb2luAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAQxjYWxjV2l0aGRyYXcDA21zZwptaW5BbW91bnRzDHVubG9ja0Ftb3VudAQKc3VzcGljaW91cwkBD2NoZWNrU3VzcGljaW91cwADCAUKc3VzcGljaW91cwJfMQkAzggCCQERc3VzcGVuZFN1c3BpY2lvdXMBCAUKc3VzcGljaW91cwJfMgkBDnJldHVyblBheW1lbnRzAggFA21zZwZjYWxsZXIIBQNtc2cIcGF5bWVudHMECXBtdEFtb3VudAMJAGYCCQCQAwEIBQNtc2cIcGF5bWVudHMAAAMJAQIhPQIJAJADAQgFA21zZwhwYXltZW50cwABCQACAQITc2l6ZShwYXltZW50cykgIT0gMQQKcG10QXNzZXRJZAgJAJEDAggFA21zZwhwYXltZW50cwAAB2Fzc2V0SWQDCQECIT0CBQxzaGFyZUFzc2V0SWQFCnBtdEFzc2V0SWQJAAIBAhV1bmtub3duIHBheW1lbnQgdG9rZW4ICQCRAwIIBQNtc2cIcGF5bWVudHMAAAZhbW91bnQAAAQOd2l0aGRyYXdBbW91bnQJAGQCBQlwbXRBbW91bnQFDHVubG9ja0Ftb3VudAoBEWNhbGNTY3JpcHRBY3Rpb25zAgNhY2MHYmFsYW5jZQQNJHQwMTQ2NzgxNDcwNgUDYWNjBA1zY3JpcHRBY3Rpb25zCAUNJHQwMTQ2NzgxNDcwNgJfMQQBaQgFDSR0MDE0Njc4MTQ3MDYCXzIEB3dBbW91bnQJAGsDBQdiYWxhbmNlBQ53aXRoZHJhd0Ftb3VudAULc2hhcmVTdXBwbHkDCQEGYXNzZXJ0AQkAZwIFB3dBbW91bnQJAJEDAgUKbWluQW1vdW50cwUBaQkAAgECMFdpdGhkcmF3YWwgcmVzdWx0ZWQgaW4gZmV3ZXIgY29pbnMgdGhhbiBleHBlY3RlZAQCdXMJAQd1bnN0YWtlAgUHd0Ftb3VudAkAkQMCBQhhc3NldElkcwUBaQMJAAACBQJ1cwUCdXMJAJQKAgkAzggCBQ1zY3JpcHRBY3Rpb25zCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAJEDAgUIYXNzZXRJZHMFAWkFDWtBc3NldEJhbGFuY2UJAGUCBQdiYWxhbmNlBQd3QW1vdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQNtc2cGY2FsbGVyBQd3QW1vdW50CQDZBAEJAJEDAgUIYXNzZXRJZHMFAWkFA25pbAkAZAIFAWkAAQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQNJHQwMTUxOTUxNTI2MwoAAiRsCQEDX3hwAAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgUDbmlsAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBEWNhbGNTY3JpcHRBY3Rpb25zAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBA1zY3JpcHRBY3Rpb25zCAUNJHQwMTUxOTUxNTI2MwJfMQQBaQgFDSR0MDE1MTk1MTUyNjMCXzIJAM4IAgUNc2NyaXB0QWN0aW9ucwkAzAgCCQEEQnVybgIFDHNoYXJlQXNzZXRJZAUOd2l0aGRyYXdBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFEWtTaGFyZUFzc2V0U3VwcGx5CQBlAgULc2hhcmVTdXBwbHkFDndpdGhkcmF3QW1vdW50BQNuaWwBGmNhbGNXaXRoZHJhd09uZUNvaW5FbnRyaWVzBANtc2cIdG9rZW5PdXQJbWluQW1vdW50DHVubG9ja0Ftb3VudAQKc3VzcGljaW91cwkBD2NoZWNrU3VzcGljaW91cwADCAUKc3VzcGljaW91cwJfMQkAzggCCQERc3VzcGVuZFN1c3BpY2lvdXMBCAUKc3VzcGljaW91cwJfMgkBDnJldHVyblBheW1lbnRzAggFA21zZwxvcmlnaW5DYWxsZXIIBQNtc2cIcGF5bWVudHMECXBtdEFtb3VudAMJAGYCCQCQAwEIBQNtc2cIcGF5bWVudHMAAAQKcG10QXNzZXRJZAgJAJEDAggFA21zZwhwYXltZW50cwAAB2Fzc2V0SWQDCQECIT0CBQxzaGFyZUFzc2V0SWQFCnBtdEFzc2V0SWQJAAIBAhV1bmtub3duIHBheW1lbnQgdG9rZW4ICQCRAwIIBQNtc2cIcGF5bWVudHMAAAZhbW91bnQAAAQIb3V0SW5kZXgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAzwgCBQhhc3NldElkcwUIdG9rZW5PdXQCEXVua25vd24gdG9rZW4gb3V0BAt0b2tlbk91dEI1OAkA2QQBBQh0b2tlbk91dAQOd2l0aGRyYXdBbW91bnQJAGQCBQlwbXRBbW91bnQFDHVubG9ja0Ftb3VudAQCeHAJAQNfeHAABA0kdDAxNjEyNTE2MjEyCQEUX2NhbGNXaXRoZHJhd09uZUNvaW4EBQJ4cAUOd2l0aGRyYXdBbW91bnQFCG91dEluZGV4CAUDbXNnDG9yaWdpbkNhbGxlcgQCZHkIBQ0kdDAxNjEyNTE2MjEyAl8xBAZkeV9mZWUIBQ0kdDAxNjEyNTE2MjEyAl8yAwkBBmFzc2VydAEJAGcCBQJkeQUJbWluQW1vdW50CQACAQIYTm90IGVub3VnaCBjb2lucyByZW1vdmVkBA5nb3Zlcm5hbmNlRmVlcwkAawMFBmR5X2ZlZQUNZmVlR292ZXJuYW5jZQUJZmVlU2NhbGU2BApkeV9hbmRfZmVlCQBkAgUCZHkFBmR5X2ZlZQoBD21ha2VOZXdCYWxhbmNlcwIDYWNjDHRva2VuQmFsYW5jZQQNJHQwMTY0NzAxNjQ5NgUDYWNjBAtuZXdCYWxhbmNlcwgFDSR0MDE2NDcwMTY0OTYCXzEEAWkIBQ0kdDAxNjQ3MDE2NDk2Al8yAwkAAAIFAWkFCG91dEluZGV4CQCUCgIJAM0IAgULbmV3QmFsYW5jZXMJAGUCBQx0b2tlbkJhbGFuY2UFCmR5X2FuZF9mZWUJAGQCBQFpAAEJAJQKAgkAzQgCBQtuZXdCYWxhbmNlcwUMdG9rZW5CYWxhbmNlCQBkAgUBaQABBA0kdDAxNjY2MzE2NzI0CgACJGwFAnhwCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlAoCBQNuaWwAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEPbWFrZU5ld0JhbGFuY2VzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBAtuZXdCYWxhbmNlcwgFDSR0MDE2NjYzMTY3MjQCXzEEAXYIBQ0kdDAxNjY2MzE2NzI0Al8yAwkBEmNoZWNrREFwcFRocmVzaG9sZAEFC25ld0JhbGFuY2VzCQEFdGhyb3cABAJ1cwkBB3Vuc3Rha2UCBQpkeV9hbmRfZmVlBQh0b2tlbk91dAMJAAACBQJ1cwUCdXMEBmxwRmVlcwkAZQIFBmR5X2ZlZQUOZ292ZXJuYW5jZUZlZXMEB2FpcmRyb3ADCQBmAgUGbHBGZWVzAAAJAPwHBAUQbHBGYXJtaW5nQWRkcmVzcwIHYWlyRHJvcAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQt0b2tlbk91dEI1OAUGbHBGZWVzBQNuaWwAAAMJAAACBQdhaXJkcm9wBQdhaXJkcm9wCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQNtc2cMb3JpZ2luQ2FsbGVyBQJkeQULdG9rZW5PdXRCNTgJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkAkQMCBQhhc3NldElkcwUIb3V0SW5kZXgFDWtBc3NldEJhbGFuY2UJAGUCCQCRAwIFAnhwBQhvdXRJbmRleAUKZHlfYW5kX2ZlZQkAzAgCCQEEQnVybgIFDHNoYXJlQXNzZXRJZAUOd2l0aGRyYXdBbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUPbW9uZXlCb3hBZGRyZXNzBQ5nb3Zlcm5hbmNlRmVlcwULdG9rZW5PdXRCNTgJAMwIAgkBDEludGVnZXJFbnRyeQIFEWtTaGFyZUFzc2V0U3VwcGx5CQBlAgULc2hhcmVTdXBwbHkFDndpdGhkcmF3QW1vdW50BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4UA21zZwEBRAICeHADYW1wBAFECQEOZ2V0X0RfaW50ZXJuYWwCBQJ4cAUDYW1wCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQICAUQFAUQFA25pbAUBRANtc2cBBGluaXQDCGFzc2V0SWRzAl9BEl9kQXBwVGhyZXNob2xkQ29lZgMJAQEhAQkAnggBBQR0aGlzCQACAQITQWxyZWFkeSBpbml0aWFsaXplZAMJAGcCAAAFAl9BCQACAQIUQW1wIG11c3QgYmUgbXVzdCA+IDADCQBnAgAABRJfZEFwcFRocmVzaG9sZENvZWYJAAIBAh9kQXBwIFRocmVzaG9sZCBDb2VmIG11c3QgYmUgPiAwBAlzaGFyZU5hbWUCC3NfTXVsdGlfVVNEBBBzaGFyZURlc2NyaXB0aW9uCQCsAgICQlNoYXJlVG9rZW4gb2YgU3dvcEZpIHByb3RvY29sIGZvciBNdWx0aVN0YWJsZSBVU0QgcG9vbCBhdCBhZGRyZXNzIAkApQgBBQR0aGlzBAppc3N1ZVRva2VuCQDCCAUFCXNoYXJlTmFtZQUQc2hhcmVEZXNjcmlwdGlvbgAAAAYGBAd0b2tlbklkCQC4CAEFCmlzc3VlVG9rZW4DCQEKY2hlY2tDb2lucwEFCGFzc2V0SWRzCQEFdGhyb3cACQDMCAIJAQtTdHJpbmdFbnRyeQIFCGtWZXJzaW9uBQd2ZXJzaW9uCQDMCAIJAQtTdHJpbmdFbnRyeQIFB2tBc3NldHMFCGFzc2V0SWRzCQDMCAIJAQxJbnRlZ2VyRW50cnkCAglpbml0aWFsX0EFAl9BCQDMCAIJAQxJbnRlZ2VyRW50cnkCAghmdXR1cmVfQQUCX0EJAMwIAgkBDEludGVnZXJFbnRyeQIFBGtGZWUJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBm9yYWNsZQINYmFzZV9mZWVfZmxhdAkAzAgCCQELU3RyaW5nRW50cnkCBQ1rU2hhcmVBc3NldElkCQDYBAEFB3Rva2VuSWQJAMwIAgkBDEludGVnZXJFbnRyeQIFEWtTaGFyZUFzc2V0U3VwcGx5AAAJAMwIAgkBDEludGVnZXJFbnRyeQIFEmtEQXBwVGhyZXNob2xkQ29lZgUSX2RBcHBUaHJlc2hvbGRDb2VmCQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBgkAzAgCBQppc3N1ZVRva2VuBQNuaWwDbXNnAQxhZGRMaXF1aWRpdHkDDW1pbk1pbnRBbW91bnQMc3Rha2VGYXJtaW5nCGxvY2tUeXBlCQELdmFsdWVPckVsc2UCCQEIaXNBY3RpdmUABANhbXAJAQJfQQAEAnhwCQEDX3hwAAQCRDADCQAAAgULc2hhcmVTdXBwbHkAAAAACQEHZ2V0RE1lbQIFAnhwBQNhbXAEDSR0MDE4ODY0MTkxMTgDAwkAZgIFCGxvY2tUeXBlAAAJAAACCAkAkQMCCAUDbXNnCHBheW1lbnRzCQBlAgkAkAMBCAUDbXNnCHBheW1lbnRzAAEHYXNzZXRJZAUEdW5pdAcJAJQKAgkA0QgCCAUDbXNnCHBheW1lbnRzCQBlAgkAkAMBCAUDbXNnCHBheW1lbnRzAAEJAMwIAgkAkQMCCAUDbXNnCHBheW1lbnRzCQBlAgkAkAMBCAUDbXNnCHBheW1lbnRzAAEFA25pbAkAlAoCCAUDbXNnCHBheW1lbnRzBQNuaWwECHBheW1lbnRzCAUNJHQwMTg4NjQxOTExOAJfMQQHbG9ja0ZlZQgFDSR0MDE4ODY0MTkxMTgCXzIEDHBheW1lbnRzU2l6ZQkAkAMBBQhwYXltZW50cwoBDXZhbGlkUGF5bWVudHMBAW4DCQBmAgUMcGF5bWVudHNTaXplBQZuQ29pbnMJAAIBCQCsAgICEHBheW1lbnRzIHNpemUgPiAJAKQDAQUGbkNvaW5zAwkAZgIAAQUMcGF5bWVudHNTaXplCQACAQIRcGF5bWVudHMgc2l6ZSA8IDEDAwkAAAIFC3NoYXJlU3VwcGx5AAAJAQIhPQIFBm5Db2lucwUMcGF5bWVudHNTaXplBwkAAgECImluaXRpYWwgZGVwb3NpdCByZXF1aXJlcyBhbGwgY29pbnMKAQxwYXltYW50VmFsaWQCA2FjYwdwYXltZW50AwkBD2NvbnRhaW5zRWxlbWVudAIFCGFzc2V0SWRzCQENZ2V0U3RyQXNzZXRJZAEIBQdwYXltZW50B2Fzc2V0SWQGCQACAQIYSW52YWxpZCBhc3NldCBpbiBwYXltZW50CgACJGwFCHBheW1lbnRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAcKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDHBheW1hbnRWYWxpZAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgMJAQEhAQkBDXZhbGlkUGF5bWVudHMBBQxwYXltZW50c1NpemUJAQV0aHJvdwAECnN1c3BpY2lvdXMJAQ9jaGVja1N1c3BpY2lvdXMAAwgFCnN1c3BpY2lvdXMCXzEJAM4IAgkBEXN1c3BlbmRTdXNwaWNpb3VzAQgFCnN1c3BpY2lvdXMCXzIJAQ5yZXR1cm5QYXltZW50cwIIBQNtc2cGY2FsbGVyBQhwYXltZW50cwoBDXBhcnNlUGF5bWVudHMCA2FjYwdhc3NldElkBA0kdDAxOTk4ODIwMDE0BQNhY2MEC25ld0JhbGFuY2VzCAUNJHQwMTk5ODgyMDAxNAJfMQQBaQgFDSR0MDE5OTg4MjAwMTQCXzIKAQxwYXJzZVBheW1lbnQCCm5ld0JhbGFuY2UHcGF5bWVudAMJAAACCQENZ2V0U3RyQXNzZXRJZAEIBQdwYXltZW50B2Fzc2V0SWQFB2Fzc2V0SWQJAGQCBQpuZXdCYWxhbmNlCAUHcGF5bWVudAZhbW91bnQFCm5ld0JhbGFuY2UECW5ld0JhbGFjZQoAAiRsBQhwYXltZW50cwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJEDAgUCeHAFAWkKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDHBhcnNlUGF5bWVudAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgkAlAoCCQDNCAIFC25ld0JhbGFuY2VzBQluZXdCYWxhY2UJAGQCBQFpAAEEDSR0MDIwMzY0MjA0MzEKAAIkbAUIYXNzZXRJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFA25pbAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQ1wYXJzZVBheW1lbnRzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBAtuZXdCYWxhbmNlcwgFDSR0MDIwMzY0MjA0MzECXzEEAWsIBQ0kdDAyMDM2NDIwNDMxAl8yAwkBEmNoZWNrREFwcFRocmVzaG9sZAEFC25ld0JhbGFuY2VzCQEFdGhyb3cABAJEMQkBB2dldERNZW0CBQtuZXdCYWxhbmNlcwUDYW1wAwkBBmFzc2VydAEJAGYCBQJEMQUCRDAJAAIBAgdEMSA+IEQwBAtmZWVEaXNjb3VudAkBFGNhbGN1bGF0ZUZlZURpc2NvdW50AQgFA21zZwZjYWxsZXIKARFjYWxjU2NyaXB0QWN0aW9ucwIDYWNjCm5ld0JhbGFuY2UEDSR0MDIwNzUxMjA3OTIFA2FjYwQLaW52QmFsYW5jZXMIBQ0kdDAyMDc1MTIwNzkyAl8xBA1zY3JpcHRBY3Rpb25zCAUNJHQwMjA3NTEyMDc5MgJfMgQBaQgFDSR0MDIwNzUxMjA3OTICXzMDCQBmAgULc2hhcmVTdXBwbHkAAAQEX2ZlZQkAaQIJAGgCCQBuBAUDZmVlBQtmZWVEaXNjb3VudAUJZmVlU2NhbGU2BQdDRUlMSU5HBQZuQ29pbnMJAGgCAAQJAGUCBQZuQ29pbnMAAQQEZmVlcwQMaWRlYWxCYWxhbmNlCQBrAwUCRDEJAJEDAgUCeHAFAWkFAkQwBApkaWZmZXJlbmNlAwkAZgIFDGlkZWFsQmFsYW5jZQUKbmV3QmFsYW5jZQkAZQIFDGlkZWFsQmFsYW5jZQUKbmV3QmFsYW5jZQkAZQIFCm5ld0JhbGFuY2UFDGlkZWFsQmFsYW5jZQkAawMFBF9mZWUFCmRpZmZlcmVuY2UFCWZlZVNjYWxlNgQOZ292ZXJuYW5jZUZlZXMJAGsDBQRmZWVzBQ1mZWVHb3Zlcm5hbmNlBQlmZWVTY2FsZTYEDGZpbmFsQmFsYW5jZQkAZQIFCm5ld0JhbGFuY2UFBGZlZXMEEGludmFyaWFudEJhbGFuY2UJAGUCBQpuZXdCYWxhbmNlBQRmZWVzBANwbXQJAGUCBQpuZXdCYWxhbmNlCQCRAwIFAnhwBQFpBAZscEZlZXMJAGUCBQRmZWVzBQ5nb3Zlcm5hbmNlRmVlcwQDaW52AwkAZgIFA3BtdAAACQEFc3Rha2UCCQBlAgUDcG10BQRmZWVzCQCRAwIFCGFzc2V0SWRzBQFpCQEHdW5zdGFrZQIFBGZlZXMJAJEDAgUIYXNzZXRJZHMFAWkDCQAAAgUDaW52BQNpbnYEB2FpcmRyb3ADCQBmAgUGbHBGZWVzAAAJAPwHBAUQbHBGYXJtaW5nQWRkcmVzcwIHYWlyRHJvcAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEJAJEDAgUIYXNzZXRJZHMFAWkFBmxwRmVlcwUDbmlsAAADCQAAAgUHYWlyZHJvcAUHYWlyZHJvcAkAlQoDCQDNCAIFC2ludkJhbGFuY2VzBRBpbnZhcmlhbnRCYWxhbmNlCQDOCAIFDXNjcmlwdEFjdGlvbnMJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUPbW9uZXlCb3hBZGRyZXNzBQ5nb3Zlcm5hbmNlRmVlcwkA2QQBCQCRAwIFCGFzc2V0SWRzBQFpCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAJEDAgUIYXNzZXRJZHMFAWkFDWtBc3NldEJhbGFuY2UFDGZpbmFsQmFsYW5jZQUDbmlsCQBkAgUBaQABCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBANpbnYJAQVzdGFrZQIFCm5ld0JhbGFuY2UJAJEDAgUIYXNzZXRJZHMFAWkDCQAAAgUDaW52BQNpbnYJAJUKAwkAzQgCBQtpbnZCYWxhbmNlcwUKbmV3QmFsYW5jZQkAzQgCBQ1zY3JpcHRBY3Rpb25zCQEMSW50ZWdlckVudHJ5AgkArAICCQCRAwIFCGFzc2V0SWRzBQFpBQ1rQXNzZXRCYWxhbmNlBQpuZXdCYWxhbmNlCQBkAgUBaQABCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBA0kdDAyMjQ5NzIyNTg1CgACJGwFC25ld0JhbGFuY2VzCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlQoDBQNuaWwFA25pbAAACgEFJGYxXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARFjYWxjU2NyaXB0QWN0aW9ucwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMV8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjFfMgIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIJAQUkZjFfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgQLaW52QmFsYW5jZXMIBQ0kdDAyMjQ5NzIyNTg1Al8xBA1zY3JpcHRBY3Rpb25zCAUNJHQwMjI0OTcyMjU4NQJfMgQCRDIJAQdnZXRETWVtAgULaW52QmFsYW5jZXMFA2FtcAQLbWludF9hbW91bnQDCQAAAgULc2hhcmVTdXBwbHkAAAUCRDEJAGsDBQtzaGFyZVN1cHBseQkAZQIFAkQyBQJEMAUCRDADCQEGYXNzZXJ0AQkAZwIFC21pbnRfYW1vdW50BQ1taW5NaW50QW1vdW50CQACAQIUU2xpcHBhZ2Ugc2NyZXdlZCB5b3UDBQxzdGFrZUZhcm1pbmcEAnJlCQD8BwQFBHRoaXMCDHJlaXNzdWVTaGFyZQkAzAgCBQttaW50X2Ftb3VudAUDbmlsBQNuaWwDCQAAAgUCcmUFAnJlBAFzCQD8BwQFDmZhcm1pbmdBZGRyZXNzAhdsb2NrU2hhcmVUb2tlbnNGcm9tUG9vbAkAzAgCCAgFA21zZwZjYWxsZXIFYnl0ZXMJAMwIAgkApQgBBQR0aGlzCQDMCAIFCGxvY2tUeXBlBQNuaWwJAM4IAgkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUMc2hhcmVBc3NldElkBQttaW50X2Ftb3VudAUDbmlsBQdsb2NrRmVlAwkAAAIFAXMFAXMJAM0IAgUNc2NyaXB0QWN0aW9ucwkBDEludGVnZXJFbnRyeQIFEWtTaGFyZUFzc2V0U3VwcGx5CQBkAgULc2hhcmVTdXBwbHkFC21pbnRfYW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQDOCAIFDXNjcmlwdEFjdGlvbnMJAMwIAgkBB1JlaXNzdWUDBQxzaGFyZUFzc2V0SWQFC21pbnRfYW1vdW50BgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUDbXNnBmNhbGxlcgULbWludF9hbW91bnQFDHNoYXJlQXNzZXRJZAkAzAgCCQEMSW50ZWdlckVudHJ5AgURa1NoYXJlQXNzZXRTdXBwbHkJAGQCBQtzaGFyZVN1cHBseQULbWludF9hbW91bnQFA25pbANtc2cBDmNhbGNNaW50QW1vdW50AgtuZXdCYWxhbmNlcwR1c2VyBANhbXAJAQJfQQAEAnhwCQEDX3hwAAQCRDEJAQdnZXRETWVtAgULbmV3QmFsYW5jZXMFA2FtcAMJAAACBQtzaGFyZVN1cHBseQAACQCUCgIFA25pbAUCRDEEAkQwCQEHZ2V0RE1lbQIFAnhwBQNhbXAEC2ZlZURpc2NvdW50CQEUY2FsY3VsYXRlRmVlRGlzY291bnQBBQR1c2VyCgEPY2FsY0ludkJhbGFuY2VzAgNhY2MKbmV3QmFsYW5jZQQNJHQwMjM4NjEyMzg4NwUDYWNjBAtpbnZCYWxhbmNlcwgFDSR0MDIzODYxMjM4ODcCXzEEAWkIBQ0kdDAyMzg2MTIzODg3Al8yBARfZmVlCQBpAgkAaAIJAG4EBQNmZWUFC2ZlZURpc2NvdW50BQlmZWVTY2FsZTYFB0NFSUxJTkcFBm5Db2lucwkAaAIABAkAZQIFBm5Db2lucwABBARmZWVzBAxpZGVhbEJhbGFuY2UJAGsDBQJEMQkAkQMCBQJ4cAUBaQUCRDAECmRpZmZlcmVuY2UDCQBmAgUMaWRlYWxCYWxhbmNlBQpuZXdCYWxhbmNlCQBlAgUMaWRlYWxCYWxhbmNlBQpuZXdCYWxhbmNlCQBlAgUKbmV3QmFsYW5jZQUMaWRlYWxCYWxhbmNlCQBrAwUEX2ZlZQUKZGlmZmVyZW5jZQUJZmVlU2NhbGU2BBBpbnZhcmlhbnRCYWxhbmNlCQBlAgUKbmV3QmFsYW5jZQUEZmVlcwkAlAoCCQDNCAIFC2ludkJhbGFuY2VzBRBpbnZhcmlhbnRCYWxhbmNlCQBkAgUBaQABBA0kdDAyNDQ4OTI0NTU5CgACJGwFC25ld0JhbGFuY2VzCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlAoCBQNuaWwAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEPY2FsY0ludkJhbGFuY2VzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBAtpbnZCYWxhbmNlcwgFDSR0MDI0NDg5MjQ1NTkCXzEEAWsIBQ0kdDAyNDQ4OTI0NTU5Al8yBAJEMgkBB2dldERNZW0CBQtpbnZCYWxhbmNlcwUDYW1wBAptaW50QW1vdW50CQBrAwULc2hhcmVTdXBwbHkJAGUCBQJEMgUCRDAFAkQwCQCUCgIFA25pbAUKbWludEFtb3VudANtc2cBDHJlaXNzdWVTaGFyZQEGYW1vdW50CQELdmFsdWVPckVsc2UCCQEKaXNTZWxmQ2FsbAEFA21zZwkAzAgCCQEHUmVpc3N1ZQMFDHNoYXJlQXNzZXRJZAUGYW1vdW50BgUDbmlsA21zZwEFZ2V0RHkECWFzc2V0RnJvbQdhc3NldFRvAmR4C3VzZXJBZGRyZXNzBAJ4cAkBA194cAAECWZyb21JbmRleAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDPCAIFCGFzc2V0SWRzBQlhc3NldEZyb20CEHVua25vd24gdG9rZW4gaW4EB3RvSW5kZXgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAzwgCBQhhc3NldElkcwUHYXNzZXRUbwIRdW5rbm93biB0b2tlbiBvdXQEAXgJAGQCCQCRAwIFAnhwBQlmcm9tSW5kZXgFAmR4BAF5CQEEZ2V0WQQFCWZyb21JbmRleAUHdG9JbmRleAUBeAUCeHAEAmR5CQBlAgkAZQIJAJEDAgUCeHAFB3RvSW5kZXgFAXkAAQQLZmVlRGlzY291bnQJARRjYWxjdWxhdGVGZWVEaXNjb3VudAEJAQdBZGRyZXNzAQkA2QQBBQt1c2VyQWRkcmVzcwQEX2ZlZQkAawMJAG4EBQNmZWUFC2ZlZURpc2NvdW50BQlmZWVTY2FsZTYFB0NFSUxJTkcFAmR5BQlmZWVTY2FsZTYJAJQKAgUDbmlsCQCUCgIJAGUCBQJkeQUEX2ZlZQUEX2ZlZQNtc2cBCGV4Y2hhbmdlAgh0b2tlbk91dAZtaW5fZHkJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQADCQECIT0CCQCQAwEIBQNtc2cIcGF5bWVudHMAAQkAAgECE3NpemUocGF5bWVudHMpICE9IDEECnN1c3BpY2lvdXMJAQ9jaGVja1N1c3BpY2lvdXMAAwgFCnN1c3BpY2lvdXMCXzEJAM4IAgkBEXN1c3BlbmRTdXNwaWNpb3VzAQgFCnN1c3BpY2lvdXMCXzIJAQ5yZXR1cm5QYXltZW50cwIIBQNtc2cGY2FsbGVyCAUDbXNnCHBheW1lbnRzBAdwYXltZW50CQCRAwIIBQNtc2cIcGF5bWVudHMAAAQHdG9rZW5JbgkBDWdldFN0ckFzc2V0SWQBCAUHcGF5bWVudAdhc3NldElkBAt0b2tlbk91dEI1OAkA2QQBBQh0b2tlbk91dAQCZHgIBQdwYXltZW50BmFtb3VudAQJZnJvbUluZGV4CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAM8IAgUIYXNzZXRJZHMFB3Rva2VuSW4CEHVua25vd24gdG9rZW4gaW4EB3RvSW5kZXgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAzwgCBQhhc3NldElkcwUIdG9rZW5PdXQCEXVua25vd24gdG9rZW4gb3V0BAJ4cAkBA194cAAEAXgJAGQCCQCRAwIFAnhwBQlmcm9tSW5kZXgFAmR4BAF5CQEEZ2V0WQQFCWZyb21JbmRleAUHdG9JbmRleAUBeAUCeHAEA19keQkAZQIJAGUCCQCRAwIFAnhwBQd0b0luZGV4BQF5AAEEC2ZlZURpc2NvdW50CQEUY2FsY3VsYXRlRmVlRGlzY291bnQBCAUDbXNnDG9yaWdpbkNhbGxlcgQEX2ZlZQkAawMFA19keQkAbgQFA2ZlZQULZmVlRGlzY291bnQFCWZlZVNjYWxlNgUHQ0VJTElORwUJZmVlU2NhbGU2BAJkeQkAZQIFA19keQUEX2ZlZQQOZ292ZXJuYW5jZUZlZXMJAGsDBQRfZmVlBQ1mZWVHb3Zlcm5hbmNlBQlmZWVTY2FsZTYDCQEGYXNzZXJ0AQkAZwIFAmR5BQZtaW5fZHkJAAIBAi5FeGNoYW5nZSByZXN1bHRlZCBpbiBmZXdlciBjb2lucyB0aGFuIGV4cGVjdGVkCgEPbWFrZU5ld0JhbGFuY2VzAgNhY2MMdG9rZW5CYWxhbmNlBA0kdDAyNjYwMDI2NjI2BQNhY2MEC25ld0JhbGFuY2VzCAUNJHQwMjY2MDAyNjYyNgJfMQQBaQgFDSR0MDI2NjAwMjY2MjYCXzIDCQAAAgUBaQUJZnJvbUluZGV4CQCUCgIJAM0IAgULbmV3QmFsYW5jZXMJAGQCBQx0b2tlbkJhbGFuY2UFAmR4CQBkAgUBaQABAwkAAAIFAWkFB3RvSW5kZXgJAJQKAgkAzQgCBQtuZXdCYWxhbmNlcwkAZQIFDHRva2VuQmFsYW5jZQUDX2R5CQBkAgUBaQABCQCUCgIJAM0IAgULbmV3QmFsYW5jZXMFDHRva2VuQmFsYW5jZQkAZAIFAWkAAQQNJHQwMjY4NzcyNjkzOAoAAiRsBQJ4cAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgUDbmlsAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBD21ha2VOZXdCYWxhbmNlcwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgQLbmV3QmFsYW5jZXMIBQ0kdDAyNjg3NzI2OTM4Al8xBAFpCAUNJHQwMjY4NzcyNjkzOAJfMgMJARJjaGVja0RBcHBUaHJlc2hvbGQBBQtuZXdCYWxhbmNlcwkBBXRocm93AAQBcwkBBXN0YWtlAggFB3BheW1lbnQGYW1vdW50CQENZ2V0U3RyQXNzZXRJZAEIBQdwYXltZW50B2Fzc2V0SWQDCQAAAgUBcwUBcwQCdXMJAQd1bnN0YWtlAgUDX2R5BQh0b2tlbk91dAMJAAACBQJ1cwUCdXMEBmxwRmVlcwkAZQIFBF9mZWUFDmdvdmVybmFuY2VGZWVzBAdhaXJkcm9wAwkAZgIFBmxwRmVlcwAACQD8BwQFEGxwRmFybWluZ0FkZHJlc3MCB2FpckRyb3AFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgULdG9rZW5PdXRCNTgFBmxwRmVlcwUDbmlsAAADCQAAAgUHYWlyZHJvcAUHYWlyZHJvcAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFB3Rva2VuSW4FDWtBc3NldEJhbGFuY2UFAXgJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIdG9rZW5PdXQFDWtBc3NldEJhbGFuY2UJAGUCCQCRAwIFAnhwBQd0b0luZGV4BQNfZHkJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFA21zZwZjYWxsZXIFAmR5BQt0b2tlbk91dEI1OAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQ9tb25leUJveEFkZHJlc3MFDmdvdmVybmFuY2VGZWVzBQt0b2tlbk91dEI1OAUDbmlsCQDMCAIFAmR5CQDMCAIFC3Rva2VuT3V0QjU4BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DbXNnAQh3aXRoZHJhdwEKbWluQW1vdW50cwkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAkBDGNhbGNXaXRoZHJhdwMFA21zZwUKbWluQW1vdW50cwAAA21zZwESd2l0aGRyYXdXaXRoVW5sb2NrAgptaW5BbW91bnRzDHVubG9ja0Ftb3VudAkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAMJAGcCAAAFDHVubG9ja0Ftb3VudAkAAgECHlVubG9jayBhbW91bnQgbXVzdCBiZSBwb3NpdGl2ZQQGdW5sb2NrCQD8BwQFDmZhcm1pbmdBZGRyZXNzAht3aXRoZHJhd1NoYXJlVG9rZW5zRnJvbVBvb2wJAMwIAggIBQNtc2cGY2FsbGVyBWJ5dGVzCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQx1bmxvY2tBbW91bnQFA25pbAUDbmlsAwkAAAIFBnVubG9jawUGdW5sb2NrCQEMY2FsY1dpdGhkcmF3AwUDbXNnBQptaW5BbW91bnRzBQx1bmxvY2tBbW91bnQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DbXNnARNjYWxjV2l0aGRyYXdPbmVDb2luAwt0b2tlbkFtb3VudAh0b2tlbk91dAR1c2VyAwkAZwIAAAULdG9rZW5BbW91bnQJAAIBAhdBbW91bnQgbXVzdCBiZSBwb3NpdGl2ZQQBaQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDPCAIFCGFzc2V0SWRzBQh0b2tlbk91dAIRdW5rbm93biB0b2tlbiBvdXQJAJQKAgUDbmlsCAkBFF9jYWxjV2l0aGRyYXdPbmVDb2luBAkBA194cAAFC3Rva2VuQW1vdW50BQFpCQEHQWRkcmVzcwEJANkEAQUEdXNlcgJfMQNtc2cBD3dpdGhkcmF3T25lQ29pbgIIdG9rZW5PdXQJbWluQW1vdW50CQELdmFsdWVPckVsc2UCCQEIaXNBY3RpdmUAAwkBAiE9AgkAkAMBCAUDbXNnCHBheW1lbnRzAAEJAAIBAhNzaXplKHBheW1lbnRzKSAhPSAxCQEaY2FsY1dpdGhkcmF3T25lQ29pbkVudHJpZXMEBQNtc2cFCHRva2VuT3V0BQltaW5BbW91bnQAAANtc2cBGXdpdGhkcmF3T25lQ29pbldpdGhVbmxvY2sDCHRva2VuT3V0CW1pbkFtb3VudAx1bmxvY2tBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQADCQBmAgAABQx1bmxvY2tBbW91bnQJAAIBAh5VbmxvY2sgYW1vdW50IG11c3QgYmUgcG9zaXRpdmUEBnVubG9jawkA/AcEBQ5mYXJtaW5nQWRkcmVzcwIbd2l0aGRyYXdTaGFyZVRva2Vuc0Zyb21Qb29sCQDMCAIICAUDbXNnBmNhbGxlcgVieXRlcwkAzAgCCQClCAEFBHRoaXMJAMwIAgUMdW5sb2NrQW1vdW50BQNuaWwFA25pbAMJAAACBQZ1bmxvY2sFBnVubG9jawkBGmNhbGNXaXRoZHJhd09uZUNvaW5FbnRyaWVzBAUDbXNnBQh0b2tlbk91dAUJbWluQW1vdW50BQx1bmxvY2tBbW91bnQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DbXNnAQFBAAkAlAoCBQNuaWwJAQJfQQADbXNnAQ9nZXRWaXJ0dWFsUHJpY2UABAFECQEFZ2V0X0QCCQEDX3hwAAkBAl9BAAkAlAoCBQNuaWwJAGsDBQFEBQlQUkVDSVNJT04FC3NoYXJlU3VwcGx5A21zZwEPY2FsY1Rva2VuQW1vdW50AgdhbW91bnRzB2RlcG9zaXQEA2FtcAkBAl9BAAQIYmFsYW5jZXMJAQNfeHAABAJEMAkBB2dldERNZW0CBQhiYWxhbmNlcwUDYW1wCgEPY2FsY05ld0JhbGFuY2VzAgNhY2MHYmFsYW5jZQQNJHQwMjk1MTUyOTU0MQUDYWNjBAtuZXdCYWxhbmNlcwgFDSR0MDI5NTE1Mjk1NDECXzEEAWkIBQ0kdDAyOTUxNTI5NTQxAl8yBApuZXdCYWxhbmNlCQBkAgUHYmFsYW5jZQMFB2RlcG9zaXQJAJEDAgUHYW1vdW50cwUBaQkBAS0BCQCRAwIFB2Ftb3VudHMFAWkJAJQKAgkAzQgCBQtuZXdCYWxhbmNlcwUKbmV3QmFsYW5jZQkAZAIFAWkAAQQLbmV3QmFsYW5jZXMICgACJGwFCGJhbGFuY2VzCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlAoCBQNuaWwAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEPY2FsY05ld0JhbGFuY2VzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAl8xBAJEMQkBB2dldERNZW0CBQtuZXdCYWxhbmNlcwUDYW1wBARkaWZmAwUHZGVwb3NpdAkAZQIFAkQxBQJEMAkAZQIFAkQwBQJEMQkAlAoCBQNuaWwJAGsDBQRkaWZmBQtzaGFyZVN1cHBseQUCRDADbXNnAQVyYW1wQQIIX2Z1dHVyZUELX2Z1dHVyZVRpbWUJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFA21zZwMJAQZhc3NlcnQBCQBnAgUOYmxvY2tUaW1lc3RhbXAJAGQCBQ5pbml0aWFsX0FfdGltZQUNTUlOX1JBTVBfVElNRQkAAgECCXRvbyBvZnRlbgMJAQZhc3NlcnQBCQBnAgULX2Z1dHVyZVRpbWUJAGQCBQ5ibG9ja1RpbWVzdGFtcAUNTUlOX1JBTVBfVElNRQkAAgECEWluc3VmZmljaWVudCB0aW1lBApfaW5pdGlhbF9BCQECX0EAAwkBBmFzc2VydAEDCQBmAgUIX2Z1dHVyZUEAAAkAZgIFBU1BWF9BBQhfZnV0dXJlQQcJAAIBAhFvdXQgb2YgYmFzZSByYW5nZQMJAQZhc3NlcnQBAwMJAGcCBQhfZnV0dXJlQQUKX2luaXRpYWxfQQkAZwIJAGgCBQpfaW5pdGlhbF9BBQxNQVhfQV9DSEFOR0UFCF9mdXR1cmVBBwYDCQBmAgUKX2luaXRpYWxfQQUIX2Z1dHVyZUEJAGcCCQBoAgUIX2Z1dHVyZUEFDE1BWF9BX0NIQU5HRQUKX2luaXRpYWxfQQcJAAIBAgxvdXQgb2YgcmFuZ2UJAMwIAgkBDEludGVnZXJFbnRyeQICCWluaXRpYWxfQQUKX2luaXRpYWxfQQkAzAgCCQEMSW50ZWdlckVudHJ5AgIIZnV0dXJlX0EFCF9mdXR1cmVBCQDMCAIJAQxJbnRlZ2VyRW50cnkCAg5pbml0aWFsX0FfdGltZQUOYmxvY2tUaW1lc3RhbXAJAMwIAgkBDEludGVnZXJFbnRyeQICDWZ1dHVyZV9BX3RpbWUFC19mdXR1cmVUaW1lBQNuaWwDbXNnAQlzdG9wUmFtcEEACQELdmFsdWVPckVsc2UCCQEIaXNBY3RpdmUACQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQNtc2cECGN1cnJlbnRBCQECX0EACQDMCAIJAQxJbnRlZ2VyRW50cnkCAglpbml0aWFsX0EFCGN1cnJlbnRBCQDMCAIJAQxJbnRlZ2VyRW50cnkCAghmdXR1cmVfQQUIY3VycmVudEEJAMwIAgkBDEludGVnZXJFbnRyeQICDmluaXRpYWxfQV90aW1lBQ5ibG9ja1RpbWVzdGFtcAkAzAgCCQEMSW50ZWdlckVudHJ5AgINZnV0dXJlX0FfdGltZQUOYmxvY2tUaW1lc3RhbXAFA25pbANtc2cBCHNodXRkb3duAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUDbXNnAwkBASEBBQZhY3RpdmUJAAIBCQCsAgICIkRBcHAgaXMgYWxyZWFkeSBzdXNwZW5kZWQuIENhdXNlOiAJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUGa0NhdXNlAhp0aGUgY2F1c2Ugd2Fzbid0IHNwZWNpZmllZAkBB3N1c3BlbmQBAg9QYXVzZWQgYnkgYWRtaW4DbXNnAQhhY3RpdmF0ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFA21zZwMFBmFjdGl2ZQkBDXRocm93SXNBY3RpdmUACQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBgkAzAgCCQELRGVsZXRlRW50cnkBBQZrQ2F1c2UFA25pbANtc2cBGXRha2VJbnRvQWNjb3VudEV4dHJhRnVuZHMACQELdmFsdWVPckVsc2UCCQEIaXNBY3RpdmUAAwkBAiE9AggFA21zZwZjYWxsZXIFD21vbmV5Qm94QWRkcmVzcwkAAgECJk9ubHkgdGhlIHdhbGxldCBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uBAhiYWxhbmNlcwkBA194cAAKAQ50YWtlRXh0cmFGdW5kcwIDYWNjB2Fzc2V0SWQEDSR0MDMxODgzMzE5MDEFA2FjYwQDc3VtCAUNJHQwMzE4ODMzMTkwMQJfMQQBaQgFDSR0MDMxODgzMzE5MDECXzIECHRva2VuQjU4CQDZBAEFB2Fzc2V0SWQECHJCYWxhbmNlCQBkAgkA8AcCBQR0aGlzBQh0b2tlbkI1OAkBDHN0YWtlZEFtb3VudAEFCHRva2VuQjU4BAxlbnJvbGxBbW91bnQJAGUCBQhyQmFsYW5jZQkAkQMCBQhiYWxhbmNlcwUBaQMJAGYCAAAFDGVucm9sbEFtb3VudAkBB3N1c3BlbmQBCQCsAgICIEVucm9sbCBhbW91bnQgbmVnYXRpdmUgZm9yIGFzc2V0BQdhc3NldElkBAdhaXJkcm9wAwkAZgIFDGVucm9sbEFtb3VudAAACQD8BwQFEGxwRmFybWluZ0FkZHJlc3MCB2FpckRyb3AFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUIdG9rZW5CNTgFDGVucm9sbEFtb3VudAUDbmlsAAADCQAAAgUHYWlyZHJvcAUHYWlyZHJvcAkAlAoCCQBkAgUDc3VtBQxlbnJvbGxBbW91bnQJAGQCBQFpAAEJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EAWsKAAIkbAUIYXNzZXRJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIAAAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQ50YWtlRXh0cmFGdW5kcwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgMJAAACCAUBawJfMQAACQACAQIQTm8gbW9uZXkgdG8gdGFrZQUDbmlsAQJ0eAEGdmVyaWZ5AAQTbXVsdGlTaWduZWRCeUFkbWlucwQSYWRtaW5QdWJLZXkxU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMYWRtaW5QdWJLZXkxAAEAAAQSYWRtaW5QdWJLZXkyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAQUMYWRtaW5QdWJLZXkyAAEAAAQSYWRtaW5QdWJLZXkzU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUMYWRtaW5QdWJLZXkzAAEAAAkAZwIJAGQCCQBkAgUSYWRtaW5QdWJLZXkxU2lnbmVkBRJhZG1pblB1YktleTJTaWduZWQFEmFkbWluUHViS2V5M1NpZ25lZAACBAckbWF0Y2gwBQJ0eAMJAAECBQckbWF0Y2gwAhdJbnZva2VTY3JpcHRUcmFuc2FjdGlvbgQDaW52BQckbWF0Y2gwBBNjYWxsVGFrZUludG9BY2NvdW50AwkAAAIIBQNpbnYEZEFwcAUEdGhpcwkAAAIIBQNpbnYIZnVuY3Rpb24CGXRha2VJbnRvQWNjb3VudEV4dHJhRnVuZHMHBA1zaWduZWRCeUFkbWluAwMDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQxhZG1pblB1YktleTEGCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQxhZG1pblB1YktleTIGCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQxhZG1pblB1YktleTMGCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABRFhZG1pblB1YktleUludm9rZQMDBRNjYWxsVGFrZUludG9BY2NvdW50BQ1zaWduZWRCeUFkbWluBwYFE211bHRpU2lnbmVkQnlBZG1pbnMFE211bHRpU2lnbmVkQnlBZG1pbnNSDw5U", "height": 3397801, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 9xiQZW1NPnEwFDsKu2UAYnnWteiAvFKULkH3GD2HFhHV Next: 6RRMHMcr7Qw7jKvS4cMjRSGf6owMYLpDbyWUcL9MkbGa Diff:
OldNewDifferences
2121
2222 let kActive = "active"
2323
24+let kActiveGlob = "active_all_contracts"
25+
2426 let kCause = "shutdown_cause"
2527
2628 let kShareAssetId = "share_asset_id"
3840 let kDiscountValues = "discount_values"
3941
4042 let kUserSwopInGov = "_SWOP_amount"
43+
44+let kUserGSwopInGov = "_GSwop_amount"
4145
4246 let kAdminPubKey1 = "admin_pub_1"
4347
9397
9498 let active = getBooleanValue(this, kActive)
9599
100+let activeGlob = valueOrElse(getBoolean(oracle, kActiveGlob), true)
101+
96102 let shareAssetId = fromBase58String(getStringValue(this, kShareAssetId))
97103
98104 let shareSupply = getIntegerValue(this, kShareAssetSupply)
121127 func throwIsActive () = throw("DApp is already active")
122128
123129
124-func isActive () = if (active)
130+func isActive () = if (if (active)
131+ then activeGlob
132+ else false)
125133 then unit
126134 else throw("DApp is inactive at this moment")
127135
137145
138146
139147 let big2 = toBigInt(2)
148+
149+let iter10 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
150+
151+let iter15 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
152+
153+let iter16 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
140154
141155 let blockTimestamp = height
142156
154168 case _ =>
155169 throw("Unknow type of user Addr")
156170 }
157- let swopAmount = valueOrElse(getInteger(govAddress, (user + kUserSwopInGov)), 0)
171+ let swopAmount = valueOrElse(getInteger(govAddress, (user + kUserGSwopInGov)), 0)
172+ let gSwopAmount = valueOrElse(getInteger(govAddress, (user + kUserGSwopInGov)), swopAmount)
158173 let discountValues = split(getStringValue(oracle, kDiscountValues), ",")
159174 let discounts = split(getStringValue(oracle, kDiscounts), ",")
160- if (if ((swopAmount >= parseIntValue(discountValues[0])))
161- then (parseIntValue(discountValues[1]) > swopAmount)
175+ if (if ((gSwopAmount >= parseIntValue(discountValues[0])))
176+ then (parseIntValue(discountValues[1]) > gSwopAmount)
162177 else false)
163178 then (feeScale6 - parseIntValue(discounts[0]))
164- else if (if ((swopAmount >= parseIntValue(discountValues[1])))
165- then (parseIntValue(discountValues[2]) > swopAmount)
179+ else if (if ((gSwopAmount >= parseIntValue(discountValues[1])))
180+ then (parseIntValue(discountValues[2]) > gSwopAmount)
166181 else false)
167182 then (feeScale6 - parseIntValue(discounts[1]))
168- else if (if ((swopAmount >= parseIntValue(discountValues[2])))
169- then (parseIntValue(discountValues[3]) > swopAmount)
183+ else if (if ((gSwopAmount >= parseIntValue(discountValues[2])))
184+ then (parseIntValue(discountValues[3]) > gSwopAmount)
170185 else false)
171186 then (feeScale6 - parseIntValue(discounts[2]))
172- else if (if ((swopAmount >= parseIntValue(discountValues[3])))
173- then (parseIntValue(discountValues[4]) > swopAmount)
187+ else if (if ((gSwopAmount >= parseIntValue(discountValues[3])))
188+ then (parseIntValue(discountValues[4]) > gSwopAmount)
174189 else false)
175190 then (feeScale6 - parseIntValue(discounts[3]))
176- else if ((swopAmount >= parseIntValue(discountValues[4])))
191+ else if ((gSwopAmount >= parseIntValue(discountValues[4])))
177192 then (feeScale6 - parseIntValue(discounts[4]))
178193 else feeScale6
179194 }
206221
207222 func $f0_2 ($a,$i) = if (($i >= $s))
208223 then $a
209- else throw("List size exceeds 15")
224+ else throw("List size exceeds 10")
210225
211- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
226+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
212227 }
213228
214229
222237 let @ = invoke(this, "D", [xp, amp], nil)
223238 if ($isInstanceOf(@, "Int"))
224239 then @
225- else throw(($getType(invoke(this, "D", [xp, amp], nil)) + " couldn't be cast to Int"))
240+ else throw(($getType(@) + " couldn't be cast to Int"))
226241 }
227242
228243
237252
238253 func $f0_2 ($a,$i) = if (($i >= $s))
239254 then $a
240- else throw("List size exceeds 15")
255+ else throw("List size exceeds 10")
241256
242- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
257+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
243258 }
244259 if ((S == 0))
245260 then 0
256271 else D_P
257272
258273 let D_P = {
259- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
274+ let $l = iter10
260275 let $s = size($l)
261276 let $acc0 = Dprev
262277 func $f1_1 ($a,$i) = if (($i >= $s))
265280
266281 func $f1_2 ($a,$i) = if (($i >= $s))
267282 then $a
268- else throw("List size exceeds 15")
283+ else throw("List size exceeds 10")
269284
270- $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
285+ $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
271286 }
272287 let D = fraction((AnnS + (toBigInt(nCoins) * D_P)), Dprev, ((Ann1 * Dprev) + (toBigInt((nCoins + 1)) * D_P)))
273288 if ((D > Dprev))
279294 else $Tuple2(D, false)
280295 }
281296
282- let $t061916303 = {
283- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
297+ let $t065826648 = {
298+ let $l = iter15
284299 let $s = size($l)
285300 let $acc0 = $Tuple2(toBigInt(S), false)
286301 func $f1_1 ($a,$i) = if (($i >= $s))
293308
294309 $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
295310 }
296- let D = $t061916303._1
297- let finished = $t061916303._2
311+ let D = $t065826648._1
312+ let finished = $t065826648._2
298313 if ((finished == false))
299314 then throw(("get_D() not finished with " + toString(D)))
300315 else toInt(D)
320335 let D = get_D(xp_, amp)
321336 let Ann = (amp * nCoins)
322337 func S_c (acc,i) = {
323- let $t068746891 = acc
324- let S_ = $t068746891._1
325- let c = $t068746891._2
338+ let $t072197236 = acc
339+ let S_ = $t072197236._1
340+ let c = $t072197236._2
326341 let x_ = if ((in == i))
327342 then x
328343 else xp_[i]
333348 else $Tuple2(S_, c)
334349 }
335350
336- let $t070997200 = {
337- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
351+ let $t074447499 = {
352+ let $l = iter10
338353 let $s = size($l)
339354 let $acc0 = $Tuple2(0, toBigInt(D))
340355 func $f0_1 ($a,$i) = if (($i >= $s))
343358
344359 func $f0_2 ($a,$i) = if (($i >= $s))
345360 then $a
346- else throw("List size exceeds 15")
361+ else throw("List size exceeds 10")
347362
348- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
363+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
349364 }
350- let S_ = $t070997200._1
351- let c_ = $t070997200._2
365+ let S_ = $t074447499._1
366+ let c_ = $t074447499._2
352367 let c = fraction(c_, toBigInt(D), toBigInt((Ann * nCoins)))
353368 let bD = toBigInt(((S_ + (D / Ann)) - D))
354369 func y_proc (acc,_i) = if ((acc._2 == true))
365380 else $Tuple2(y, false)
366381 }
367382
368- let $t076827799 = {
369- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
383+ let $t079818048 = {
384+ let $l = iter16
370385 let $s = size($l)
371386 let $acc0 = $Tuple2(toBigInt(D), false)
372387 func $f1_1 ($a,$i) = if (($i >= $s))
379394
380395 $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16)
381396 }
382- let y = $t076827799._1
383- let finished = $t076827799._2
397+ let y = $t079818048._1
398+ let finished = $t079818048._2
384399 if ((finished == false))
385400 then throw(("getY() not finished with " + toString(y)))
386401 else toInt(y)
394409 else {
395410 let Ann = (A_ * nCoins)
396411 func S_c (acc,i) = {
397- let $t081788195 = acc
398- let S_ = $t081788195._1
399- let c = $t081788195._2
412+ let $t084278444 = acc
413+ let S_ = $t084278444._1
414+ let c = $t084278444._2
400415 let x_ = if (if ((in != i))
401416 then (nCoins > i)
402417 else false)
409424 else $Tuple2(S_, c)
410425 }
411426
412- let $t084158516 = {
413- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
427+ let $t086648719 = {
428+ let $l = iter10
414429 let $s = size($l)
415430 let $acc0 = $Tuple2(0, toBigInt(D))
416431 func $f0_1 ($a,$i) = if (($i >= $s))
419434
420435 func $f0_2 ($a,$i) = if (($i >= $s))
421436 then $a
422- else throw("List size exceeds 15")
437+ else throw("List size exceeds 10")
423438
424- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
439+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
425440 }
426- let S_ = $t084158516._1
427- let c_ = $t084158516._2
441+ let S_ = $t086648719._1
442+ let c_ = $t086648719._2
428443 let c = fraction(c_, toBigInt(D), toBigInt((Ann * nCoins)))
429444 let bD = toBigInt(((S_ + (D / Ann)) - D))
430445 func y_D_proc (acc,i) = if ((acc._2 == true))
441456 else $Tuple2(y, false)
442457 }
443458
444- let $t089999118 = {
445- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
459+ let $t092029271 = {
460+ let $l = iter16
446461 let $s = size($l)
447462 let $acc0 = $Tuple2(toBigInt(D), false)
448463 func $f1_1 ($a,$i) = if (($i >= $s))
455470
456471 $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16)
457472 }
458- let y = $t089999118._1
459- let finished = $t089999118._2
473+ let y = $t092029271._1
474+ let finished = $t092029271._2
460475 if ((finished == false))
461476 then throw(("get_y_D() not finished with " + toString(y)))
462477 else toInt(y)
473488 let new_y = get_y_D(amp, i, xp, D1)
474489 let dy_0 = (xp[i] - new_y)
475490 func xp_reduced_proc (acc,xp_j) = {
476- let $t097599788 = acc
477- let xp_reduced = $t097599788._1
478- let index = $t097599788._2
491+ let $t099129941 = acc
492+ let xp_reduced = $t099129941._1
493+ let index = $t099129941._2
479494 let dx_expected = if ((index == i))
480495 then (fraction(xp_j, D1, D0) - new_y)
481496 else (xp_j - fraction(xp_j, D1, D0))
482497 $Tuple2((xp_reduced :+ (xp_j - fraction(_fee, dx_expected, feeScale6))), (index + 1))
483498 }
484499
485- let $t01005010114 = {
500+ let $t01020310267 = {
486501 let $l = xp
487502 let $s = size($l)
488503 let $acc0 = $Tuple2(nil, 0)
492507
493508 func $f0_2 ($a,$i) = if (($i >= $s))
494509 then $a
495- else throw("List size exceeds 15")
510+ else throw("List size exceeds 10")
496511
497- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
512+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
498513 }
499- let xp_reduced = $t01005010114._1
500- let index = $t01005010114._2
514+ let xp_reduced = $t01020310267._1
515+ let index = $t01020310267._2
501516 let xp_reduced_i = xp_reduced[i]
502517 let dy = ((xp_reduced_i - get_y_D(amp, i, xp_reduced, D1)) - 1)
503518 $Tuple2(dy, (dy_0 - dy))
521536
522537 func calcStakingParams (stake,amount,assetId) = if (stake)
523538 then {
524- let $t01067810744 = calcStakingFuncAndAddres(stake, assetId)
525- let call = $t01067810744._1
526- let stakingAddr = $t01067810744._2
539+ let $t01083110897 = calcStakingFuncAndAddres(stake, assetId)
540+ let call = $t01083110897._1
541+ let stakingAddr = $t01083110897._2
527542 $Tuple4(call, stakingAddr, nil, [AttachedPayment(assetId, amount)])
528543 }
529544 else {
530- let $t01083010896 = calcStakingFuncAndAddres(stake, assetId)
531- let call = $t01083010896._1
532- let stakingAddr = $t01083010896._2
545+ let $t01098311049 = calcStakingFuncAndAddres(stake, assetId)
546+ let call = $t01098311049._1
547+ let stakingAddr = $t01098311049._2
533548 $Tuple4(call, stakingAddr, [amount, toBase58String(assetId)], nil)
534549 }
535550
536551
537552 func stake (amount,assetIdString) = if (containsElement(stakingAssets, assetIdString))
538553 then {
539- let $t01108311185 = calcStakingParams(true, amount, fromBase58String(assetIdString))
540- let call = $t01108311185._1
541- let addr = $t01108311185._2
542- let params = $t01108311185._3
543- let payments = $t01108311185._4
554+ let $t01123611338 = calcStakingParams(true, amount, fromBase58String(assetIdString))
555+ let call = $t01123611338._1
556+ let addr = $t01123611338._2
557+ let params = $t01123611338._3
558+ let payments = $t01123611338._4
544559 invoke(addr, call, params, payments)
545560 }
546561 else 0
548563
549564 func unstake (amount,assetIdString) = if (containsElement(stakingAssets, assetIdString))
550565 then {
551- let $t01137011473 = calcStakingParams(false, amount, fromBase58String(assetIdString))
552- let call = $t01137011473._1
553- let addr = $t01137011473._2
554- let params = $t01137011473._3
555- let payments = $t01137011473._4
566+ let $t01152311626 = calcStakingParams(false, amount, fromBase58String(assetIdString))
567+ let call = $t01152311626._1
568+ let addr = $t01152311626._2
569+ let params = $t01152311626._3
570+ let payments = $t01152311626._4
556571 invoke(addr, call, params, payments)
557572 }
558573 else 0
581596 func checkSuspicious () = {
582597 let contractBalances = _xp()
583598 func checkBalance (acc,assetId) = {
584- let $t01208412109 = acc
585- let suspicious = $t01208412109._1
586- let i = $t01208412109._2
599+ let $t01223712262 = acc
600+ let suspicious = $t01223712262._1
601+ let i = $t01223712262._2
587602 if (suspicious)
588603 then $Tuple2(suspicious, i)
589604 else {
603618
604619 func $f0_2 ($a,$i) = if (($i >= $s))
605620 then $a
606- else throw("List size exceeds 15")
621+ else throw("List size exceeds 10")
607622
608- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
623+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
609624 }
610625
611626
624639
625640 func $f0_2 ($a,$i) = if (($i >= $s))
626641 then $a
627- else throw("List size exceeds 15")
642+ else throw("List size exceeds 10")
628643
629- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
644+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
630645 }
631646
632647
644659
645660 func checkCoins (assetIds) = {
646661 let coins = split(assetIds, ",")
647- func checkCoin (error,assetId) = {
648- let asset = valueOrErrorMessage(fromBase58String(assetId), ("fromBase58String: " + assetId))
649- let decimals = valueOrErrorMessage(assetInfo(asset), ("assetInfo: " + assetId)).decimals
650- if ((decimals != DECIMALS))
651- then throw("wrong decimals")
652- else false
653- }
662+ if ((size(coins) > 10))
663+ then throw("To many coins, max coins size 10")
664+ else {
665+ func checkCoin (error,assetId) = {
666+ let asset = valueOrErrorMessage(fromBase58String(assetId), ("fromBase58String: " + assetId))
667+ let decimals = valueOrErrorMessage(assetInfo(asset), ("assetInfo: " + assetId)).decimals
668+ if ((decimals != DECIMALS))
669+ then throw("wrong decimals")
670+ else false
671+ }
654672
655- let $l = coins
656- let $s = size($l)
657- let $acc0 = false
658- func $f0_1 ($a,$i) = if (($i >= $s))
659- then $a
660- else checkCoin($a, $l[$i])
673+ let $l = coins
674+ let $s = size($l)
675+ let $acc0 = false
676+ func $f0_1 ($a,$i) = if (($i >= $s))
677+ then $a
678+ else checkCoin($a, $l[$i])
661679
662- func $f0_2 ($a,$i) = if (($i >= $s))
663- then $a
664- else throw("List size exceeds 15")
680+ func $f0_2 ($a,$i) = if (($i >= $s))
681+ then $a
682+ else throw("List size exceeds 10")
665683
666- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
684+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
685+ }
686+ }
687+
688+
689+func calcWithdraw (msg,minAmounts,unlockAmount) = {
690+ let suspicious = checkSuspicious()
691+ if (suspicious._1)
692+ then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, msg.payments))
693+ else {
694+ let pmtAmount = if ((size(msg.payments) > 0))
695+ then if ((size(msg.payments) != 1))
696+ then throw("size(payments) != 1")
697+ else {
698+ let pmtAssetId = msg.payments[0].assetId
699+ if ((shareAssetId != pmtAssetId))
700+ then throw("unknown payment token")
701+ else msg.payments[0].amount
702+ }
703+ else 0
704+ let withdrawAmount = (pmtAmount + unlockAmount)
705+ func calcScriptActions (acc,balance) = {
706+ let $t01467814706 = acc
707+ let scriptActions = $t01467814706._1
708+ let i = $t01467814706._2
709+ let wAmount = fraction(balance, withdrawAmount, shareSupply)
710+ if (assert((wAmount >= minAmounts[i])))
711+ then throw("Withdrawal resulted in fewer coins than expected")
712+ else {
713+ let us = unstake(wAmount, assetIds[i])
714+ if ((us == us))
715+ then $Tuple2((scriptActions ++ [IntegerEntry((assetIds[i] + kAssetBalance), (balance - wAmount)), ScriptTransfer(msg.caller, wAmount, fromBase58String(assetIds[i]))]), (i + 1))
716+ else throw("Strict value is not equal to itself.")
717+ }
718+ }
719+
720+ let $t01519515263 = {
721+ let $l = _xp()
722+ let $s = size($l)
723+ let $acc0 = $Tuple2(nil, 0)
724+ func $f0_1 ($a,$i) = if (($i >= $s))
725+ then $a
726+ else calcScriptActions($a, $l[$i])
727+
728+ func $f0_2 ($a,$i) = if (($i >= $s))
729+ then $a
730+ else throw("List size exceeds 10")
731+
732+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
733+ }
734+ let scriptActions = $t01519515263._1
735+ let i = $t01519515263._2
736+ (scriptActions ++ [Burn(shareAssetId, withdrawAmount), IntegerEntry(kShareAssetSupply, (shareSupply - withdrawAmount))])
737+ }
738+ }
739+
740+
741+func calcWithdrawOneCoinEntries (msg,tokenOut,minAmount,unlockAmount) = {
742+ let suspicious = checkSuspicious()
743+ if (suspicious._1)
744+ then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.originCaller, msg.payments))
745+ else {
746+ let pmtAmount = if ((size(msg.payments) > 0))
747+ then {
748+ let pmtAssetId = msg.payments[0].assetId
749+ if ((shareAssetId != pmtAssetId))
750+ then throw("unknown payment token")
751+ else msg.payments[0].amount
752+ }
753+ else 0
754+ let outIndex = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
755+ let tokenOutB58 = fromBase58String(tokenOut)
756+ let withdrawAmount = (pmtAmount + unlockAmount)
757+ let xp = _xp()
758+ let $t01612516212 = _calcWithdrawOneCoin(xp, withdrawAmount, outIndex, msg.originCaller)
759+ let dy = $t01612516212._1
760+ let dy_fee = $t01612516212._2
761+ if (assert((dy >= minAmount)))
762+ then throw("Not enough coins removed")
763+ else {
764+ let governanceFees = fraction(dy_fee, feeGovernance, feeScale6)
765+ let dy_and_fee = (dy + dy_fee)
766+ func makeNewBalances (acc,tokenBalance) = {
767+ let $t01647016496 = acc
768+ let newBalances = $t01647016496._1
769+ let i = $t01647016496._2
770+ if ((i == outIndex))
771+ then $Tuple2((newBalances :+ (tokenBalance - dy_and_fee)), (i + 1))
772+ else $Tuple2((newBalances :+ tokenBalance), (i + 1))
773+ }
774+
775+ let $t01666316724 = {
776+ let $l = xp
777+ let $s = size($l)
778+ let $acc0 = $Tuple2(nil, 0)
779+ func $f0_1 ($a,$i) = if (($i >= $s))
780+ then $a
781+ else makeNewBalances($a, $l[$i])
782+
783+ func $f0_2 ($a,$i) = if (($i >= $s))
784+ then $a
785+ else throw("List size exceeds 10")
786+
787+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
788+ }
789+ let newBalances = $t01666316724._1
790+ let v = $t01666316724._2
791+ if (checkDAppThreshold(newBalances))
792+ then throw()
793+ else {
794+ let us = unstake(dy_and_fee, tokenOut)
795+ if ((us == us))
796+ then {
797+ let lpFees = (dy_fee - governanceFees)
798+ let airdrop = if ((lpFees > 0))
799+ then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(tokenOutB58, lpFees)])
800+ else 0
801+ if ((airdrop == airdrop))
802+ then [ScriptTransfer(msg.originCaller, dy, tokenOutB58), IntegerEntry((assetIds[outIndex] + kAssetBalance), (xp[outIndex] - dy_and_fee)), Burn(shareAssetId, withdrawAmount), ScriptTransfer(moneyBoxAddress, governanceFees, tokenOutB58), IntegerEntry(kShareAssetSupply, (shareSupply - withdrawAmount))]
803+ else throw("Strict value is not equal to itself.")
804+ }
805+ else throw("Strict value is not equal to itself.")
806+ }
807+ }
808+ }
667809 }
668810
669811
683825 else if ((0 >= _dAppThresholdCoef))
684826 then throw("dApp Threshold Coef must be > 0")
685827 else {
686- let shareName = "multiUSDC"
687- let shareDescription = ("ShareToken of SwopFi protocol for multi-stable USDC pool at address " + toString(this))
828+ let shareName = "s_Multi_USD"
829+ let shareDescription = ("ShareToken of SwopFi protocol for MultiStable USD pool at address " + toString(this))
688830 let issueToken = Issue(shareName, shareDescription, 0, 6, true)
689831 let tokenId = calculateAssetId(issueToken)
690832 if (checkCoins(assetIds))
695837
696838
697839 @Callable(msg)
698-func addLiquidity (minMintAmount,stakeFarming) = valueOrElse(isActive(), {
840+func addLiquidity (minMintAmount,stakeFarming,lockType) = valueOrElse(isActive(), {
699841 let amp = _A()
700842 let xp = _xp()
701843 let D0 = if ((shareSupply == 0))
702844 then 0
703845 else getDMem(xp, amp)
704- let payments = msg.payments
846+ let $t01886419118 = if (if ((lockType > 0))
847+ then (msg.payments[(size(msg.payments) - 1)].assetId == unit)
848+ else false)
849+ then $Tuple2(removeByIndex(msg.payments, (size(msg.payments) - 1)), [msg.payments[(size(msg.payments) - 1)]])
850+ else $Tuple2(msg.payments, nil)
851+ let payments = $t01886419118._1
852+ let lockFee = $t01886419118._2
705853 let paymentsSize = size(payments)
706854 func validPayments (n) = if ((paymentsSize > nCoins))
707855 then throw(("payments size > " + toString(nCoins)))
725873
726874 func $f0_2 ($a,$i) = if (($i >= $s))
727875 then $a
728- else throw("List size exceeds 15")
876+ else throw("List size exceeds 10")
729877
730- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
878+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
731879 }
732880
733881 if (!(validPayments(paymentsSize)))
738886 then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, payments))
739887 else {
740888 func parsePayments (acc,assetId) = {
741- let $t01612516154 = acc
742- let newBalances = $t01612516154._1
743- let i = $t01612516154._2
744- let j = $t01612516154._3
745- if (if ((paymentsSize > j))
746- then (getStrAssetId(payments[j].assetId) == assetId)
747- else false)
748- then $Tuple3((newBalances :+ (xp[i] + payments[j].amount)), (i + 1), (j + 1))
749- else $Tuple3((newBalances :+ xp[i]), (i + 1), j)
889+ let $t01998820014 = acc
890+ let newBalances = $t01998820014._1
891+ let i = $t01998820014._2
892+ func parsePayment (newBalance,payment) = if ((getStrAssetId(payment.assetId) == assetId))
893+ then (newBalance + payment.amount)
894+ else newBalance
895+
896+ let newBalace = {
897+ let $l = payments
898+ let $s = size($l)
899+ let $acc0 = xp[i]
900+ func $f0_1 ($a,$i) = if (($i >= $s))
901+ then $a
902+ else parsePayment($a, $l[$i])
903+
904+ func $f0_2 ($a,$i) = if (($i >= $s))
905+ then $a
906+ else throw("List size exceeds 10")
907+
908+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
909+ }
910+ $Tuple2((newBalances :+ newBalace), (i + 1))
750911 }
751912
752- let $t01637416460 = {
913+ let $t02036420431 = {
753914 let $l = assetIds
754915 let $s = size($l)
755- let $acc0 = $Tuple3(nil, 0, 0)
916+ let $acc0 = $Tuple2(nil, 0)
756917 func $f0_1 ($a,$i) = if (($i >= $s))
757918 then $a
758919 else parsePayments($a, $l[$i])
759920
760921 func $f0_2 ($a,$i) = if (($i >= $s))
761922 then $a
762- else throw("List size exceeds 15")
923+ else throw("List size exceeds 10")
763924
764- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
925+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
765926 }
766- let newBalances = $t01637416460._1
767- let k = $t01637416460._2
768- let parsedPayments = $t01637416460._3
769- if ((paymentsSize > parsedPayments))
770- then throw("Incorect payments order")
771- else if (checkDAppThreshold(newBalances))
772- then throw()
773- else {
774- let D1 = getDMem(newBalances, amp)
775- if (assert((D1 > D0)))
776- then throw("D1 > D0")
777- else {
778- let feeDiscount = calculateFeeDiscount(msg.caller)
779- func calcScriptActions (acc,newBalance) = {
780- let $t01686116902 = acc
781- let invBalances = $t01686116902._1
782- let scriptActions = $t01686116902._2
783- let i = $t01686116902._3
784- if ((shareSupply > 0))
785- then {
786- let _fee = ((fraction(fee, feeDiscount, feeScale6, CEILING) * nCoins) / (4 * (nCoins - 1)))
787- let fees = {
788- let idealBalance = fraction(D1, xp[i], D0)
789- let difference = if ((idealBalance > newBalance))
790- then (idealBalance - newBalance)
791- else (newBalance - idealBalance)
792- fraction(_fee, difference, feeScale6)
927+ let newBalances = $t02036420431._1
928+ let k = $t02036420431._2
929+ if (checkDAppThreshold(newBalances))
930+ then throw()
931+ else {
932+ let D1 = getDMem(newBalances, amp)
933+ if (assert((D1 > D0)))
934+ then throw("D1 > D0")
935+ else {
936+ let feeDiscount = calculateFeeDiscount(msg.caller)
937+ func calcScriptActions (acc,newBalance) = {
938+ let $t02075120792 = acc
939+ let invBalances = $t02075120792._1
940+ let scriptActions = $t02075120792._2
941+ let i = $t02075120792._3
942+ if ((shareSupply > 0))
943+ then {
944+ let _fee = ((fraction(fee, feeDiscount, feeScale6, CEILING) * nCoins) / (4 * (nCoins - 1)))
945+ let fees = {
946+ let idealBalance = fraction(D1, xp[i], D0)
947+ let difference = if ((idealBalance > newBalance))
948+ then (idealBalance - newBalance)
949+ else (newBalance - idealBalance)
950+ fraction(_fee, difference, feeScale6)
951+ }
952+ let governanceFees = fraction(fees, feeGovernance, feeScale6)
953+ let finalBalance = (newBalance - fees)
954+ let invariantBalance = (newBalance - fees)
955+ let pmt = (newBalance - xp[i])
956+ let lpFees = (fees - governanceFees)
957+ let inv = if ((pmt > 0))
958+ then stake((pmt - fees), assetIds[i])
959+ else unstake(fees, assetIds[i])
960+ if ((inv == inv))
961+ then {
962+ let airdrop = if ((lpFees > 0))
963+ then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(fromBase58String(assetIds[i]), lpFees)])
964+ else 0
965+ if ((airdrop == airdrop))
966+ then $Tuple3((invBalances :+ invariantBalance), (scriptActions ++ [ScriptTransfer(moneyBoxAddress, governanceFees, fromBase58String(assetIds[i])), IntegerEntry((assetIds[i] + kAssetBalance), finalBalance)]), (i + 1))
967+ else throw("Strict value is not equal to itself.")
793968 }
794- let governanceFees = fraction(fees, feeGovernance, feeScale6)
795- let finalBalance = (newBalance - fees)
796- let invariantBalance = (newBalance - fees)
797- let pmt = (newBalance - xp[i])
798- let lpFees = (fees - governanceFees)
799- let inv = if ((pmt > 0))
800- then stake((pmt - fees), assetIds[i])
801- else unstake(fees, assetIds[i])
802- if ((inv == inv))
803- then {
804- let airdrop = if ((lpFees > 0))
805- then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(fromBase58String(assetIds[i]), lpFees)])
806- else 0
807- if ((airdrop == airdrop))
808- then $Tuple3((invBalances :+ invariantBalance), (scriptActions ++ [ScriptTransfer(moneyBoxAddress, governanceFees, fromBase58String(assetIds[i])), IntegerEntry((assetIds[i] + kAssetBalance), finalBalance)]), (i + 1))
809- else throw("Strict value is not equal to itself.")
810- }
811- else throw("Strict value is not equal to itself.")
812- }
813- else {
814- let inv = stake(newBalance, assetIds[i])
815- if ((inv == inv))
816- then $Tuple3((invBalances :+ newBalance), (scriptActions :+ IntegerEntry((assetIds[i] + kAssetBalance), newBalance)), (i + 1))
817- else throw("Strict value is not equal to itself.")
818- }
819- }
969+ else throw("Strict value is not equal to itself.")
970+ }
971+ else {
972+ let inv = stake(newBalance, assetIds[i])
973+ if ((inv == inv))
974+ then $Tuple3((invBalances :+ newBalance), (scriptActions :+ IntegerEntry((assetIds[i] + kAssetBalance), newBalance)), (i + 1))
975+ else throw("Strict value is not equal to itself.")
976+ }
977+ }
820978
821- let $t01860718695 = {
822- let $l = newBalances
823- let $s = size($l)
824- let $acc0 = $Tuple3(nil, nil, 0)
825- func $f1_1 ($a,$i) = if (($i >= $s))
826- then $a
827- else calcScriptActions($a, $l[$i])
979+ let $t02249722585 = {
980+ let $l = newBalances
981+ let $s = size($l)
982+ let $acc0 = $Tuple3(nil, nil, 0)
983+ func $f1_1 ($a,$i) = if (($i >= $s))
984+ then $a
985+ else calcScriptActions($a, $l[$i])
828986
829- func $f1_2 ($a,$i) = if (($i >= $s))
830- then $a
831- else throw("List size exceeds 15")
987+ func $f1_2 ($a,$i) = if (($i >= $s))
988+ then $a
989+ else throw("List size exceeds 10")
832990
833- $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
834- }
835- let invBalances = $t01860718695._1
836- let scriptActions = $t01860718695._2
837- let D2 = getDMem(invBalances, amp)
838- let mint_amount = if ((shareSupply == 0))
839- then D1
840- else fraction(shareSupply, (D2 - D0), D0)
841- if (assert((mint_amount >= minMintAmount)))
842- then throw("Slippage screwed you")
843- else if (stakeFarming)
844- then {
845- let re = invoke(this, "reissueShare", [mint_amount], nil)
846- if ((re == re))
847- then {
848- let s = invoke(farmingAddress, "lockShareTokens", [toString(this)], [AttachedPayment(shareAssetId, mint_amount)])
849- if ((s == s))
850- then (scriptActions :+ IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount)))
851- else throw("Strict value is not equal to itself.")
852- }
853- else throw("Strict value is not equal to itself.")
854- }
855- else (scriptActions ++ [Reissue(shareAssetId, mint_amount, true), ScriptTransfer(msg.caller, mint_amount, shareAssetId), IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount))])
991+ $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
856992 }
857- }
993+ let invBalances = $t02249722585._1
994+ let scriptActions = $t02249722585._2
995+ let D2 = getDMem(invBalances, amp)
996+ let mint_amount = if ((shareSupply == 0))
997+ then D1
998+ else fraction(shareSupply, (D2 - D0), D0)
999+ if (assert((mint_amount >= minMintAmount)))
1000+ then throw("Slippage screwed you")
1001+ else if (stakeFarming)
1002+ then {
1003+ let re = invoke(this, "reissueShare", [mint_amount], nil)
1004+ if ((re == re))
1005+ then {
1006+ let s = invoke(farmingAddress, "lockShareTokensFromPool", [msg.caller.bytes, toString(this), lockType], ([AttachedPayment(shareAssetId, mint_amount)] ++ lockFee))
1007+ if ((s == s))
1008+ then (scriptActions :+ IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount)))
1009+ else throw("Strict value is not equal to itself.")
1010+ }
1011+ else throw("Strict value is not equal to itself.")
1012+ }
1013+ else (scriptActions ++ [Reissue(shareAssetId, mint_amount, true), ScriptTransfer(msg.caller, mint_amount, shareAssetId), IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount))])
1014+ }
1015+ }
8581016 }
8591017 }
8601018 })
8721030 let D0 = getDMem(xp, amp)
8731031 let feeDiscount = calculateFeeDiscount(user)
8741032 func calcInvBalances (acc,newBalance) = {
875- let $t01988419910 = acc
876- let invBalances = $t01988419910._1
877- let i = $t01988419910._2
1033+ let $t02386123887 = acc
1034+ let invBalances = $t02386123887._1
1035+ let i = $t02386123887._2
8781036 let _fee = ((fraction(fee, feeDiscount, feeScale6, CEILING) * nCoins) / (4 * (nCoins - 1)))
8791037 let fees = {
8801038 let idealBalance = fraction(D1, xp[i], D0)
8871045 $Tuple2((invBalances :+ invariantBalance), (i + 1))
8881046 }
8891047
890- let $t02051220582 = {
1048+ let $t02448924559 = {
8911049 let $l = newBalances
8921050 let $s = size($l)
8931051 let $acc0 = $Tuple2(nil, 0)
8971055
8981056 func $f0_2 ($a,$i) = if (($i >= $s))
8991057 then $a
900- else throw("List size exceeds 15")
1058+ else throw("List size exceeds 10")
9011059
902- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1060+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
9031061 }
904- let invBalances = $t02051220582._1
905- let k = $t02051220582._2
1062+ let invBalances = $t02448924559._1
1063+ let k = $t02448924559._2
9061064 let D2 = getDMem(invBalances, amp)
9071065 let mintAmount = fraction(shareSupply, (D2 - D0), D0)
9081066 $Tuple2(nil, mintAmount)
9571115 then throw("Exchange resulted in fewer coins than expected")
9581116 else {
9591117 func makeNewBalances (acc,tokenBalance) = {
960- let $t02262322649 = acc
961- let newBalances = $t02262322649._1
962- let i = $t02262322649._2
1118+ let $t02660026626 = acc
1119+ let newBalances = $t02660026626._1
1120+ let i = $t02660026626._2
9631121 if ((i == fromIndex))
9641122 then $Tuple2((newBalances :+ (tokenBalance + dx)), (i + 1))
9651123 else if ((i == toIndex))
9671125 else $Tuple2((newBalances :+ tokenBalance), (i + 1))
9681126 }
9691127
970- let $t02290022961 = {
1128+ let $t02687726938 = {
9711129 let $l = xp
9721130 let $s = size($l)
9731131 let $acc0 = $Tuple2(nil, 0)
9771135
9781136 func $f0_2 ($a,$i) = if (($i >= $s))
9791137 then $a
980- else throw("List size exceeds 15")
1138+ else throw("List size exceeds 10")
9811139
982- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1140+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
9831141 }
984- let newBalances = $t02290022961._1
985- let i = $t02290022961._2
1142+ let newBalances = $t02687726938._1
1143+ let i = $t02687726938._2
9861144 if (checkDAppThreshold(newBalances))
9871145 then throw()
9881146 else {
10111169
10121170
10131171 @Callable(msg)
1014-func withdraw (minAmounts) = valueOrElse(isActive(), if ((size(msg.payments) != 1))
1015- then throw("size(payments) != 1")
1016- else {
1017- let pmtAmount = msg.payments[0].amount
1018- let pmtAssetId = msg.payments[0].assetId
1019- if ((shareAssetId != pmtAssetId))
1020- then throw("unknown payment token")
1021- else {
1022- let suspicious = checkSuspicious()
1023- if (suspicious._1)
1024- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.originCaller, msg.payments))
1025- else {
1026- func calcScriptActions (acc,balance) = {
1027- let $t02425224280 = acc
1028- let scriptActions = $t02425224280._1
1029- let i = $t02425224280._2
1030- let wAmount = fraction(balance, pmtAmount, shareSupply)
1031- if (assert((wAmount >= minAmounts[i])))
1032- then throw("Withdrawal resulted in fewer coins than expected")
1033- else {
1034- let us = unstake(wAmount, assetIds[i])
1035- if ((us == us))
1036- then $Tuple2((scriptActions ++ [IntegerEntry((assetIds[i] + kAssetBalance), (balance - wAmount)), ScriptTransfer(msg.originCaller, wAmount, fromBase58String(assetIds[i]))]), (i + 1))
1037- else throw("Strict value is not equal to itself.")
1038- }
1039- }
1040-
1041- let $t02477024838 = {
1042- let $l = _xp()
1043- let $s = size($l)
1044- let $acc0 = $Tuple2(nil, 0)
1045- func $f0_1 ($a,$i) = if (($i >= $s))
1046- then $a
1047- else calcScriptActions($a, $l[$i])
1048-
1049- func $f0_2 ($a,$i) = if (($i >= $s))
1050- then $a
1051- else throw("List size exceeds 15")
1052-
1053- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1054- }
1055- let scriptActions = $t02477024838._1
1056- let i = $t02477024838._2
1057- (scriptActions ++ [Burn(shareAssetId, pmtAmount), IntegerEntry(kShareAssetSupply, (shareSupply - pmtAmount))])
1058- }
1059- }
1060- })
1172+func withdraw (minAmounts) = valueOrElse(isActive(), calcWithdraw(msg, minAmounts, 0))
10611173
10621174
10631175
10651177 func withdrawWithUnlock (minAmounts,unlockAmount) = valueOrElse(isActive(), if ((0 >= unlockAmount))
10661178 then throw("Unlock amount must be positive")
10671179 else {
1068- let suspicious = checkSuspicious()
1069- if (suspicious._1)
1070- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, msg.payments))
1071- else {
1072- let pmtAmount = if ((size(msg.payments) > 0))
1073- then if ((size(msg.payments) != 1))
1074- then throw("size(payments) != 1")
1075- else {
1076- let pmtAssetId = msg.payments[0].assetId
1077- if ((shareAssetId != pmtAssetId))
1078- then throw("unknown payment token")
1079- else msg.payments[0].amount
1080- }
1081- else 0
1082- let unlock = invoke(farmingAddress, "withdrawShareTokens", [toString(this), unlockAmount], nil)
1083- if ((unlock == unlock))
1084- then {
1085- let withdrawAmount = (pmtAmount + unlockAmount)
1086- let inv = invoke(this, "withdraw", [minAmounts], [AttachedPayment(shareAssetId, withdrawAmount)])
1087- if ((inv == inv))
1088- then nil
1089- else throw("Strict value is not equal to itself.")
1090- }
1091- else throw("Strict value is not equal to itself.")
1092- }
1180+ let unlock = invoke(farmingAddress, "withdrawShareTokensFromPool", [msg.caller.bytes, toString(this), unlockAmount], nil)
1181+ if ((unlock == unlock))
1182+ then calcWithdraw(msg, minAmounts, unlockAmount)
1183+ else throw("Strict value is not equal to itself.")
10931184 })
10941185
10951186
10961187
10971188 @Callable(msg)
1098-func calcWithdrawOneCoin (tokenAmount,tokenOut,user) = {
1099- let i = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
1100- $Tuple2(nil, _calcWithdrawOneCoin(_xp(), tokenAmount, i, Address(fromBase58String(user)))._1)
1101- }
1189+func calcWithdrawOneCoin (tokenAmount,tokenOut,user) = if ((0 >= tokenAmount))
1190+ then throw("Amount must be positive")
1191+ else {
1192+ let i = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
1193+ $Tuple2(nil, _calcWithdrawOneCoin(_xp(), tokenAmount, i, Address(fromBase58String(user)))._1)
1194+ }
11021195
11031196
11041197
11051198 @Callable(msg)
11061199 func withdrawOneCoin (tokenOut,minAmount) = valueOrElse(isActive(), if ((size(msg.payments) != 1))
11071200 then throw("size(payments) != 1")
1108- else {
1109- let suspicious = checkSuspicious()
1110- if (suspicious._1)
1111- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.originCaller, msg.payments))
1112- else {
1113- let pmtAmount = msg.payments[0].amount
1114- let pmtAssetId = msg.payments[0].assetId
1115- if ((pmtAssetId != shareAssetId))
1116- then throw("unknown token")
1117- else {
1118- let outIndex = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
1119- let tokenOutB58 = fromBase58String(tokenOut)
1120- let xp = _xp()
1121- let $t02680226884 = _calcWithdrawOneCoin(xp, pmtAmount, outIndex, msg.originCaller)
1122- let dy = $t02680226884._1
1123- let dy_fee = $t02680226884._2
1124- if (assert((dy >= minAmount)))
1125- then throw("Not enough coins removed")
1126- else {
1127- let governanceFees = fraction(dy_fee, feeGovernance, feeScale6)
1128- let dy_and_fee = (dy + dy_fee)
1129- func makeNewBalances (acc,tokenBalance) = {
1130- let $t02714227168 = acc
1131- let newBalances = $t02714227168._1
1132- let i = $t02714227168._2
1133- if ((i == outIndex))
1134- then $Tuple2((newBalances :+ (tokenBalance - dy_and_fee)), (i + 1))
1135- else $Tuple2((newBalances :+ tokenBalance), (i + 1))
1136- }
1137-
1138- let $t02733527396 = {
1139- let $l = xp
1140- let $s = size($l)
1141- let $acc0 = $Tuple2(nil, 0)
1142- func $f0_1 ($a,$i) = if (($i >= $s))
1143- then $a
1144- else makeNewBalances($a, $l[$i])
1145-
1146- func $f0_2 ($a,$i) = if (($i >= $s))
1147- then $a
1148- else throw("List size exceeds 15")
1149-
1150- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1151- }
1152- let newBalances = $t02733527396._1
1153- let v = $t02733527396._2
1154- if (checkDAppThreshold(newBalances))
1155- then throw()
1156- else {
1157- let us = unstake(dy_and_fee, tokenOut)
1158- if ((us == us))
1159- then {
1160- let lpFees = (dy_fee - governanceFees)
1161- let airdrop = if ((lpFees > 0))
1162- then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(tokenOutB58, lpFees)])
1163- else 0
1164- if ((airdrop == airdrop))
1165- then [ScriptTransfer(msg.originCaller, dy, tokenOutB58), IntegerEntry((assetIds[outIndex] + kAssetBalance), (xp[outIndex] - dy_and_fee)), Burn(shareAssetId, pmtAmount), ScriptTransfer(moneyBoxAddress, governanceFees, tokenOutB58), IntegerEntry(kShareAssetSupply, (shareSupply - pmtAmount))]
1166- else throw("Strict value is not equal to itself.")
1167- }
1168- else throw("Strict value is not equal to itself.")
1169- }
1170- }
1171- }
1172- }
1173- })
1201+ else calcWithdrawOneCoinEntries(msg, tokenOut, minAmount, 0))
11741202
11751203
11761204
11771205 @Callable(msg)
1178-func withdrawOneCoinWithUnlock (tokenOut,minAmount,unlockAmount) = valueOrElse(isActive(), if ((0 >= unlockAmount))
1206+func withdrawOneCoinWithUnlock (tokenOut,minAmount,unlockAmount) = valueOrElse(isActive(), if ((0 > unlockAmount))
11791207 then throw("Unlock amount must be positive")
11801208 else {
1181- let suspicious = checkSuspicious()
1182- if (suspicious._1)
1183- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, msg.payments))
1184- else {
1185- let pmtAmount = if ((size(msg.payments) > 0))
1186- then if ((size(msg.payments) != 1))
1187- then throw("size(payments) != 1")
1188- else {
1189- let pmtAssetId = msg.payments[0].assetId
1190- if ((shareAssetId != pmtAssetId))
1191- then throw("unknown payment token")
1192- else msg.payments[0].amount
1193- }
1194- else 0
1195- let unlock = invoke(farmingAddress, "withdrawShareTokens", [toString(this), unlockAmount], nil)
1196- if ((unlock == unlock))
1197- then {
1198- let withdrawAmount = (pmtAmount + unlockAmount)
1199- let inv = invoke(this, "withdrawOneCoin", [tokenOut, minAmount], [AttachedPayment(shareAssetId, withdrawAmount)])
1200- if ((inv == inv))
1201- then nil
1202- else throw("Strict value is not equal to itself.")
1203- }
1204- else throw("Strict value is not equal to itself.")
1205- }
1209+ let unlock = invoke(farmingAddress, "withdrawShareTokensFromPool", [msg.caller.bytes, toString(this), unlockAmount], nil)
1210+ if ((unlock == unlock))
1211+ then calcWithdrawOneCoinEntries(msg, tokenOut, minAmount, unlockAmount)
1212+ else throw("Strict value is not equal to itself.")
12061213 })
12071214
12081215
12261233 let balances = _xp()
12271234 let D0 = getDMem(balances, amp)
12281235 func calcNewBalances (acc,balance) = {
1229- let $t02941329439 = acc
1230- let newBalances = $t02941329439._1
1231- let i = $t02941329439._2
1236+ let $t02951529541 = acc
1237+ let newBalances = $t02951529541._1
1238+ let i = $t02951529541._2
12321239 let newBalance = (balance + (if (deposit)
12331240 then amounts[i]
12341241 else -(amounts[i])))
12441251
12451252 func $f0_2 ($a,$i) = if (($i >= $s))
12461253 then $a
1247- else throw("List size exceeds 15")
1254+ else throw("List size exceeds 10")
12481255
1249- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15))._1
1256+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10))._1
12501257 let D1 = getDMem(newBalances, amp)
12511258 let diff = if (deposit)
12521259 then (D1 - D0)
13081315 else {
13091316 let balances = _xp()
13101317 func takeExtraFunds (acc,assetId) = {
1311- let $t03178131799 = acc
1312- let sum = $t03178131799._1
1313- let i = $t03178131799._2
1318+ let $t03188331901 = acc
1319+ let sum = $t03188331901._1
1320+ let i = $t03188331901._2
13141321 let tokenB58 = fromBase58String(assetId)
13151322 let rBalance = (assetBalance(this, tokenB58) + stakedAmount(tokenB58))
13161323 let enrollAmount = (rBalance - balances[i])
13361343
13371344 func $f0_2 ($a,$i) = if (($i >= $s))
13381345 then $a
1339- else throw("List size exceeds 15")
1346+ else throw("List size exceeds 10")
13401347
1341- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1348+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
13421349 }
13431350 if ((k._1 == 0))
13441351 then throw("No money to take")
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let PRECISION = 1000000
55
66 let MAX_A = 1000000
77
88 let MAX_A_CHANGE = 10
99
1010 let DECIMALS = 6
1111
1212 let MIN_RAMP_TIME = (86400 / 60)
1313
1414 let version = "3.0.0"
1515
1616 let kVersion = "version"
1717
1818 let kAssets = "asset_ids"
1919
2020 let kAssetBalance = "_balance"
2121
2222 let kActive = "active"
2323
24+let kActiveGlob = "active_all_contracts"
25+
2426 let kCause = "shutdown_cause"
2527
2628 let kShareAssetId = "share_asset_id"
2729
2830 let kShareAssetSupply = "share_asset_supply"
2931
3032 let kFee = "commission"
3133
3234 let kDAppThresholdCoef = "dAppThresholdCoef"
3335
3436 let kUSDNAddress = "staking_usdnnsbt_address"
3537
3638 let kDiscounts = "discounts"
3739
3840 let kDiscountValues = "discount_values"
3941
4042 let kUserSwopInGov = "_SWOP_amount"
43+
44+let kUserGSwopInGov = "_GSwop_amount"
4145
4246 let kAdminPubKey1 = "admin_pub_1"
4347
4448 let kAdminPubKey2 = "admin_pub_2"
4549
4650 let kAdminPubKey3 = "admin_pub_3"
4751
4852 let kAdminInvokePubKey = "admin_invoke_pub"
4953
5054 let kMoneyBoxAddress = "money_box_address"
5155
5256 let kGovAddress = "governance_address"
5357
5458 let kVotingAddress = "voting_address"
5559
5660 let kFarmingAddress = "farming_address"
5761
5862 let kLPFarmingAddress = "lp_farming"
5963
6064 let oracle = Address(base58'3PEbqViERCoKnmcSULh6n2aiMvUdSQdCsom')
6165
6266 func getBase58FromOracle (key) = match getString(oracle, key) {
6367 case string: String =>
6468 fromBase58String(string)
6569 case nothing =>
6670 throw((key + "is empty"))
6771 }
6872
6973
7074 let adminPubKey1 = getBase58FromOracle(kAdminPubKey1)
7175
7276 let adminPubKey2 = getBase58FromOracle(kAdminPubKey2)
7377
7478 let adminPubKey3 = getBase58FromOracle(kAdminPubKey3)
7579
7680 let adminPubKeyInvoke = getBase58FromOracle(kAdminInvokePubKey)
7781
7882 let moneyBoxAddress = Address(getBase58FromOracle(kMoneyBoxAddress))
7983
8084 let govAddress = Address(getBase58FromOracle(kGovAddress))
8185
8286 let stakingUSDNAddress = Address(getBase58FromOracle(kUSDNAddress))
8387
8488 let votingAddress = Address(getBase58FromOracle(kVotingAddress))
8589
8690 let farmingAddress = Address(getBase58FromOracle(kFarmingAddress))
8791
8892 let lpFarmingAddress = Address(getBase58FromOracle(kLPFarmingAddress))
8993
9094 let USDN = base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p'
9195
9296 let stakingAssets = [toBase58String(USDN)]
9397
9498 let active = getBooleanValue(this, kActive)
9599
100+let activeGlob = valueOrElse(getBoolean(oracle, kActiveGlob), true)
101+
96102 let shareAssetId = fromBase58String(getStringValue(this, kShareAssetId))
97103
98104 let shareSupply = getIntegerValue(this, kShareAssetSupply)
99105
100106 let feeScale6 = 1000000
101107
102108 let fee = getIntegerValue(this, kFee)
103109
104110 let feeGovernance = fraction(40, feeScale6, 100)
105111
106112 let initial_A = getIntegerValue(this, "initial_A")
107113
108114 let future_A = getIntegerValue(this, "future_A")
109115
110116 let initial_A_time = valueOrElse(getInteger(this, "initial_A_time"), 0)
111117
112118 let future_A_time = valueOrElse(getInteger(this, "future_A_time"), 0)
113119
114120 let assetIds = split(getStringValue(this, kAssets), ",")
115121
116122 let nCoins = size(assetIds)
117123
118124 func suspend (cause) = [BooleanEntry(kActive, false), StringEntry(kCause, cause)]
119125
120126
121127 func throwIsActive () = throw("DApp is already active")
122128
123129
124-func isActive () = if (active)
130+func isActive () = if (if (active)
131+ then activeGlob
132+ else false)
125133 then unit
126134 else throw("DApp is inactive at this moment")
127135
128136
129137 func isAdminCall (i) = if (containsElement([adminPubKey1, adminPubKey2, adminPubKey3], i.callerPublicKey))
130138 then unit
131139 else throw("Only admin can call this function")
132140
133141
134142 func isSelfCall (i) = if ((this == i.caller))
135143 then unit
136144 else throw("Only contract itself can call this function")
137145
138146
139147 let big2 = toBigInt(2)
148+
149+let iter10 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
150+
151+let iter15 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
152+
153+let iter16 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
140154
141155 let blockTimestamp = height
142156
143157 func assert (a) = if (a)
144158 then false
145159 else true
146160
147161
148162 func calculateFeeDiscount (userAddr) = {
149163 let user = match userAddr {
150164 case u: Address =>
151165 toString(u)
152166 case u: String =>
153167 u
154168 case _ =>
155169 throw("Unknow type of user Addr")
156170 }
157- let swopAmount = valueOrElse(getInteger(govAddress, (user + kUserSwopInGov)), 0)
171+ let swopAmount = valueOrElse(getInteger(govAddress, (user + kUserGSwopInGov)), 0)
172+ let gSwopAmount = valueOrElse(getInteger(govAddress, (user + kUserGSwopInGov)), swopAmount)
158173 let discountValues = split(getStringValue(oracle, kDiscountValues), ",")
159174 let discounts = split(getStringValue(oracle, kDiscounts), ",")
160- if (if ((swopAmount >= parseIntValue(discountValues[0])))
161- then (parseIntValue(discountValues[1]) > swopAmount)
175+ if (if ((gSwopAmount >= parseIntValue(discountValues[0])))
176+ then (parseIntValue(discountValues[1]) > gSwopAmount)
162177 else false)
163178 then (feeScale6 - parseIntValue(discounts[0]))
164- else if (if ((swopAmount >= parseIntValue(discountValues[1])))
165- then (parseIntValue(discountValues[2]) > swopAmount)
179+ else if (if ((gSwopAmount >= parseIntValue(discountValues[1])))
180+ then (parseIntValue(discountValues[2]) > gSwopAmount)
166181 else false)
167182 then (feeScale6 - parseIntValue(discounts[1]))
168- else if (if ((swopAmount >= parseIntValue(discountValues[2])))
169- then (parseIntValue(discountValues[3]) > swopAmount)
183+ else if (if ((gSwopAmount >= parseIntValue(discountValues[2])))
184+ then (parseIntValue(discountValues[3]) > gSwopAmount)
170185 else false)
171186 then (feeScale6 - parseIntValue(discounts[2]))
172- else if (if ((swopAmount >= parseIntValue(discountValues[3])))
173- then (parseIntValue(discountValues[4]) > swopAmount)
187+ else if (if ((gSwopAmount >= parseIntValue(discountValues[3])))
188+ then (parseIntValue(discountValues[4]) > gSwopAmount)
174189 else false)
175190 then (feeScale6 - parseIntValue(discounts[3]))
176- else if ((swopAmount >= parseIntValue(discountValues[4])))
191+ else if ((gSwopAmount >= parseIntValue(discountValues[4])))
177192 then (feeScale6 - parseIntValue(discounts[4]))
178193 else feeScale6
179194 }
180195
181196
182197 func _A () = {
183198 let t1 = future_A_time
184199 let A1 = future_A
185200 if ((t1 > blockTimestamp))
186201 then {
187202 let A0 = initial_A
188203 let t0 = initial_A_time
189204 if ((A1 > A0))
190205 then (A0 + (((A1 - A0) * (blockTimestamp - t0)) / (t1 - t0)))
191206 else (A0 - (((A0 - A1) * (blockTimestamp - t0)) / (t1 - t0)))
192207 }
193208 else A1
194209 }
195210
196211
197212 func _xp () = {
198213 func assetBalances (acc,assetId) = (acc :+ valueOrElse(getInteger(this, (assetId + kAssetBalance)), 0))
199214
200215 let $l = assetIds
201216 let $s = size($l)
202217 let $acc0 = nil
203218 func $f0_1 ($a,$i) = if (($i >= $s))
204219 then $a
205220 else assetBalances($a, $l[$i])
206221
207222 func $f0_2 ($a,$i) = if (($i >= $s))
208223 then $a
209- else throw("List size exceeds 15")
224+ else throw("List size exceeds 10")
210225
211- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
226+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
212227 }
213228
214229
215230 func _xp_mem (xp) = xp
216231
217232
218233 func sumList (acc,element) = (acc + element)
219234
220235
221236 func get_D (xp,amp) = {
222237 let @ = invoke(this, "D", [xp, amp], nil)
223238 if ($isInstanceOf(@, "Int"))
224239 then @
225- else throw(($getType(invoke(this, "D", [xp, amp], nil)) + " couldn't be cast to Int"))
240+ else throw(($getType(@) + " couldn't be cast to Int"))
226241 }
227242
228243
229244 func get_D_internal (xp,amp) = {
230245 let S = {
231246 let $l = xp
232247 let $s = size($l)
233248 let $acc0 = 0
234249 func $f0_1 ($a,$i) = if (($i >= $s))
235250 then $a
236251 else sumList($a, $l[$i])
237252
238253 func $f0_2 ($a,$i) = if (($i >= $s))
239254 then $a
240- else throw("List size exceeds 15")
255+ else throw("List size exceeds 10")
241256
242- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
257+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
243258 }
244259 if ((S == 0))
245260 then 0
246261 else {
247262 let Ann = (amp * nCoins)
248263 let AnnS = (toBigInt(Ann) * toBigInt(S))
249264 let Ann1 = toBigInt((Ann - 1))
250265 func Dproc (acc,i) = if ((acc._2 == true))
251266 then acc
252267 else {
253268 let Dprev = acc._1
254269 func D_PProc (D_P,i) = if ((nCoins > i))
255270 then ((D_P * Dprev) / (toBigInt(xp[i]) * toBigInt(nCoins)))
256271 else D_P
257272
258273 let D_P = {
259- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
274+ let $l = iter10
260275 let $s = size($l)
261276 let $acc0 = Dprev
262277 func $f1_1 ($a,$i) = if (($i >= $s))
263278 then $a
264279 else D_PProc($a, $l[$i])
265280
266281 func $f1_2 ($a,$i) = if (($i >= $s))
267282 then $a
268- else throw("List size exceeds 15")
283+ else throw("List size exceeds 10")
269284
270- $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
285+ $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
271286 }
272287 let D = fraction((AnnS + (toBigInt(nCoins) * D_P)), Dprev, ((Ann1 * Dprev) + (toBigInt((nCoins + 1)) * D_P)))
273288 if ((D > Dprev))
274289 then if ((1 >= toInt((D - Dprev))))
275290 then $Tuple2(D, true)
276291 else $Tuple2(D, false)
277292 else if ((1 >= toInt((Dprev - D))))
278293 then $Tuple2(D, true)
279294 else $Tuple2(D, false)
280295 }
281296
282- let $t061916303 = {
283- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
297+ let $t065826648 = {
298+ let $l = iter15
284299 let $s = size($l)
285300 let $acc0 = $Tuple2(toBigInt(S), false)
286301 func $f1_1 ($a,$i) = if (($i >= $s))
287302 then $a
288303 else Dproc($a, $l[$i])
289304
290305 func $f1_2 ($a,$i) = if (($i >= $s))
291306 then $a
292307 else throw("List size exceeds 15")
293308
294309 $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
295310 }
296- let D = $t061916303._1
297- let finished = $t061916303._2
311+ let D = $t065826648._1
312+ let finished = $t065826648._2
298313 if ((finished == false))
299314 then throw(("get_D() not finished with " + toString(D)))
300315 else toInt(D)
301316 }
302317 }
303318
304319
305320 func getDMem (xp,amp) = get_D(_xp_mem(xp), amp)
306321
307322
308323 func getY (in,out,x,xp_) = if (assert((in != out)))
309324 then throw("same coin")
310325 else if (assert(if ((out >= 0))
311326 then (in >= 0)
312327 else false))
313328 then throw("below zero")
314329 else if (assert(if ((nCoins > out))
315330 then (nCoins > in)
316331 else false))
317332 then throw("above N_COINS")
318333 else {
319334 let amp = _A()
320335 let D = get_D(xp_, amp)
321336 let Ann = (amp * nCoins)
322337 func S_c (acc,i) = {
323- let $t068746891 = acc
324- let S_ = $t068746891._1
325- let c = $t068746891._2
338+ let $t072197236 = acc
339+ let S_ = $t072197236._1
340+ let c = $t072197236._2
326341 let x_ = if ((in == i))
327342 then x
328343 else xp_[i]
329344 if (if ((i != out))
330345 then (nCoins > i)
331346 else false)
332347 then $Tuple2((S_ + x_), fraction(c, toBigInt(D), toBigInt((x_ * nCoins))))
333348 else $Tuple2(S_, c)
334349 }
335350
336- let $t070997200 = {
337- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
351+ let $t074447499 = {
352+ let $l = iter10
338353 let $s = size($l)
339354 let $acc0 = $Tuple2(0, toBigInt(D))
340355 func $f0_1 ($a,$i) = if (($i >= $s))
341356 then $a
342357 else S_c($a, $l[$i])
343358
344359 func $f0_2 ($a,$i) = if (($i >= $s))
345360 then $a
346- else throw("List size exceeds 15")
361+ else throw("List size exceeds 10")
347362
348- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
363+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
349364 }
350- let S_ = $t070997200._1
351- let c_ = $t070997200._2
365+ let S_ = $t074447499._1
366+ let c_ = $t074447499._2
352367 let c = fraction(c_, toBigInt(D), toBigInt((Ann * nCoins)))
353368 let bD = toBigInt(((S_ + (D / Ann)) - D))
354369 func y_proc (acc,_i) = if ((acc._2 == true))
355370 then acc
356371 else {
357372 let y_prev = acc._1
358373 let y = (((y_prev * y_prev) + c) / ((big2 * y_prev) + bD))
359374 if ((y > y_prev))
360375 then if ((1 >= toInt((y - y_prev))))
361376 then $Tuple2(y, true)
362377 else $Tuple2(y, false)
363378 else if ((1 >= toInt((y_prev - y))))
364379 then $Tuple2(y, true)
365380 else $Tuple2(y, false)
366381 }
367382
368- let $t076827799 = {
369- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
383+ let $t079818048 = {
384+ let $l = iter16
370385 let $s = size($l)
371386 let $acc0 = $Tuple2(toBigInt(D), false)
372387 func $f1_1 ($a,$i) = if (($i >= $s))
373388 then $a
374389 else y_proc($a, $l[$i])
375390
376391 func $f1_2 ($a,$i) = if (($i >= $s))
377392 then $a
378393 else throw("List size exceeds 16")
379394
380395 $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16)
381396 }
382- let y = $t076827799._1
383- let finished = $t076827799._2
397+ let y = $t079818048._1
398+ let finished = $t079818048._2
384399 if ((finished == false))
385400 then throw(("getY() not finished with " + toString(y)))
386401 else toInt(y)
387402 }
388403
389404
390405 func get_y_D (A_,in,xp,D) = if (assert((in >= 0)))
391406 then throw("i below zero")
392407 else if (assert((nCoins > in)))
393408 then throw("i above N_COINS")
394409 else {
395410 let Ann = (A_ * nCoins)
396411 func S_c (acc,i) = {
397- let $t081788195 = acc
398- let S_ = $t081788195._1
399- let c = $t081788195._2
412+ let $t084278444 = acc
413+ let S_ = $t084278444._1
414+ let c = $t084278444._2
400415 let x_ = if (if ((in != i))
401416 then (nCoins > i)
402417 else false)
403418 then xp[i]
404419 else 0
405420 if (if ((nCoins > i))
406421 then (in != i)
407422 else false)
408423 then $Tuple2((S_ + x_), fraction(c, toBigInt(D), toBigInt((x_ * nCoins))))
409424 else $Tuple2(S_, c)
410425 }
411426
412- let $t084158516 = {
413- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
427+ let $t086648719 = {
428+ let $l = iter10
414429 let $s = size($l)
415430 let $acc0 = $Tuple2(0, toBigInt(D))
416431 func $f0_1 ($a,$i) = if (($i >= $s))
417432 then $a
418433 else S_c($a, $l[$i])
419434
420435 func $f0_2 ($a,$i) = if (($i >= $s))
421436 then $a
422- else throw("List size exceeds 15")
437+ else throw("List size exceeds 10")
423438
424- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
439+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
425440 }
426- let S_ = $t084158516._1
427- let c_ = $t084158516._2
441+ let S_ = $t086648719._1
442+ let c_ = $t086648719._2
428443 let c = fraction(c_, toBigInt(D), toBigInt((Ann * nCoins)))
429444 let bD = toBigInt(((S_ + (D / Ann)) - D))
430445 func y_D_proc (acc,i) = if ((acc._2 == true))
431446 then acc
432447 else {
433448 let y_prev = acc._1
434449 let y = (((y_prev * y_prev) + c) / ((big2 * y_prev) + bD))
435450 if ((y > y_prev))
436451 then if ((1 >= toInt((y - y_prev))))
437452 then $Tuple2(y, true)
438453 else $Tuple2(y, false)
439454 else if ((1 >= toInt((y_prev - y))))
440455 then $Tuple2(y, true)
441456 else $Tuple2(y, false)
442457 }
443458
444- let $t089999118 = {
445- let $l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
459+ let $t092029271 = {
460+ let $l = iter16
446461 let $s = size($l)
447462 let $acc0 = $Tuple2(toBigInt(D), false)
448463 func $f1_1 ($a,$i) = if (($i >= $s))
449464 then $a
450465 else y_D_proc($a, $l[$i])
451466
452467 func $f1_2 ($a,$i) = if (($i >= $s))
453468 then $a
454469 else throw("List size exceeds 16")
455470
456471 $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16)
457472 }
458- let y = $t089999118._1
459- let finished = $t089999118._2
473+ let y = $t092029271._1
474+ let finished = $t092029271._2
460475 if ((finished == false))
461476 then throw(("get_y_D() not finished with " + toString(y)))
462477 else toInt(y)
463478 }
464479
465480
466481 func _calcWithdrawOneCoin (xp,_token_amount,i,caller) = {
467482 let feeDiscount = calculateFeeDiscount(caller)
468483 let amp = _A()
469484 let _fee = ((fraction(fee, feeDiscount, feeScale6, CEILING) * nCoins) / (4 * (nCoins - 1)))
470485 let total_supply = shareSupply
471486 let D0 = get_D(xp, amp)
472487 let D1 = (D0 - fraction(_token_amount, D0, total_supply))
473488 let new_y = get_y_D(amp, i, xp, D1)
474489 let dy_0 = (xp[i] - new_y)
475490 func xp_reduced_proc (acc,xp_j) = {
476- let $t097599788 = acc
477- let xp_reduced = $t097599788._1
478- let index = $t097599788._2
491+ let $t099129941 = acc
492+ let xp_reduced = $t099129941._1
493+ let index = $t099129941._2
479494 let dx_expected = if ((index == i))
480495 then (fraction(xp_j, D1, D0) - new_y)
481496 else (xp_j - fraction(xp_j, D1, D0))
482497 $Tuple2((xp_reduced :+ (xp_j - fraction(_fee, dx_expected, feeScale6))), (index + 1))
483498 }
484499
485- let $t01005010114 = {
500+ let $t01020310267 = {
486501 let $l = xp
487502 let $s = size($l)
488503 let $acc0 = $Tuple2(nil, 0)
489504 func $f0_1 ($a,$i) = if (($i >= $s))
490505 then $a
491506 else xp_reduced_proc($a, $l[$i])
492507
493508 func $f0_2 ($a,$i) = if (($i >= $s))
494509 then $a
495- else throw("List size exceeds 15")
510+ else throw("List size exceeds 10")
496511
497- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
512+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
498513 }
499- let xp_reduced = $t01005010114._1
500- let index = $t01005010114._2
514+ let xp_reduced = $t01020310267._1
515+ let index = $t01020310267._2
501516 let xp_reduced_i = xp_reduced[i]
502517 let dy = ((xp_reduced_i - get_y_D(amp, i, xp_reduced, D1)) - 1)
503518 $Tuple2(dy, (dy_0 - dy))
504519 }
505520
506521
507522 func getStrAssetId (assetId) = match assetId {
508523 case id: ByteVector =>
509524 toBase58String(id)
510525 case waves: Unit =>
511526 "WAVES"
512527 case _ =>
513528 throw("Match error")
514529 }
515530
516531
517532 func calcStakingFuncAndAddres (stake,assetId) = if (stake)
518533 then $Tuple2("lockNeutrino", stakingUSDNAddress)
519534 else $Tuple2("unlockNeutrino", stakingUSDNAddress)
520535
521536
522537 func calcStakingParams (stake,amount,assetId) = if (stake)
523538 then {
524- let $t01067810744 = calcStakingFuncAndAddres(stake, assetId)
525- let call = $t01067810744._1
526- let stakingAddr = $t01067810744._2
539+ let $t01083110897 = calcStakingFuncAndAddres(stake, assetId)
540+ let call = $t01083110897._1
541+ let stakingAddr = $t01083110897._2
527542 $Tuple4(call, stakingAddr, nil, [AttachedPayment(assetId, amount)])
528543 }
529544 else {
530- let $t01083010896 = calcStakingFuncAndAddres(stake, assetId)
531- let call = $t01083010896._1
532- let stakingAddr = $t01083010896._2
545+ let $t01098311049 = calcStakingFuncAndAddres(stake, assetId)
546+ let call = $t01098311049._1
547+ let stakingAddr = $t01098311049._2
533548 $Tuple4(call, stakingAddr, [amount, toBase58String(assetId)], nil)
534549 }
535550
536551
537552 func stake (amount,assetIdString) = if (containsElement(stakingAssets, assetIdString))
538553 then {
539- let $t01108311185 = calcStakingParams(true, amount, fromBase58String(assetIdString))
540- let call = $t01108311185._1
541- let addr = $t01108311185._2
542- let params = $t01108311185._3
543- let payments = $t01108311185._4
554+ let $t01123611338 = calcStakingParams(true, amount, fromBase58String(assetIdString))
555+ let call = $t01123611338._1
556+ let addr = $t01123611338._2
557+ let params = $t01123611338._3
558+ let payments = $t01123611338._4
544559 invoke(addr, call, params, payments)
545560 }
546561 else 0
547562
548563
549564 func unstake (amount,assetIdString) = if (containsElement(stakingAssets, assetIdString))
550565 then {
551- let $t01137011473 = calcStakingParams(false, amount, fromBase58String(assetIdString))
552- let call = $t01137011473._1
553- let addr = $t01137011473._2
554- let params = $t01137011473._3
555- let payments = $t01137011473._4
566+ let $t01152311626 = calcStakingParams(false, amount, fromBase58String(assetIdString))
567+ let call = $t01152311626._1
568+ let addr = $t01152311626._2
569+ let params = $t01152311626._3
570+ let payments = $t01152311626._4
556571 invoke(addr, call, params, payments)
557572 }
558573 else 0
559574
560575
561576 func stakedAmount (assetId) = {
562577 let stakedAmountCalculated = match assetId {
563578 case aId: ByteVector =>
564579 if ((aId == USDN))
565580 then getInteger(stakingUSDNAddress, ((("rpd_balance_" + toBase58String(aId)) + "_") + toString(this)))
566581 else 0
567582 case _: Unit =>
568583 0
569584 case _ =>
570585 throw("Match error")
571586 }
572587 match stakedAmountCalculated {
573588 case i: Int =>
574589 i
575590 case _ =>
576591 0
577592 }
578593 }
579594
580595
581596 func checkSuspicious () = {
582597 let contractBalances = _xp()
583598 func checkBalance (acc,assetId) = {
584- let $t01208412109 = acc
585- let suspicious = $t01208412109._1
586- let i = $t01208412109._2
599+ let $t01223712262 = acc
600+ let suspicious = $t01223712262._1
601+ let i = $t01223712262._2
587602 if (suspicious)
588603 then $Tuple2(suspicious, i)
589604 else {
590605 let aBalance = (assetBalance(this, fromBase58String(assetId)) + stakedAmount(fromBase58String(assetId)))
591606 if ((contractBalances[i] > aBalance))
592607 then $Tuple2(true, i)
593608 else $Tuple2(false, (i + 1))
594609 }
595610 }
596611
597612 let $l = assetIds
598613 let $s = size($l)
599614 let $acc0 = $Tuple2(false, 0)
600615 func $f0_1 ($a,$i) = if (($i >= $s))
601616 then $a
602617 else checkBalance($a, $l[$i])
603618
604619 func $f0_2 ($a,$i) = if (($i >= $s))
605620 then $a
606- else throw("List size exceeds 15")
621+ else throw("List size exceeds 10")
607622
608- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
623+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
609624 }
610625
611626
612627 func suspendSuspicious (i) = suspend(("Suspicious state with asset: " + assetIds[i]))
613628
614629
615630 func returnPayments (caller,payments) = {
616631 func parsePayments (acc,payment) = (acc :+ ScriptTransfer(caller, payment.amount, payment.assetId))
617632
618633 let $l = payments
619634 let $s = size($l)
620635 let $acc0 = nil
621636 func $f0_1 ($a,$i) = if (($i >= $s))
622637 then $a
623638 else parsePayments($a, $l[$i])
624639
625640 func $f0_2 ($a,$i) = if (($i >= $s))
626641 then $a
627- else throw("List size exceeds 15")
642+ else throw("List size exceeds 10")
628643
629- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
644+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
630645 }
631646
632647
633648 func checkDAppThreshold (newBalances) = {
634649 let dAppThresholdCoef = valueOrErrorMessage(getInteger(this, kDAppThresholdCoef), "No dAppThresholdCoef key")
635650 let thresholdScale = 10000
636651 let maxBalance = max(newBalances)
637652 let minBalance = min(newBalances)
638653 let ratio = fraction(maxBalance, thresholdScale, minBalance)
639654 if ((ratio > (dAppThresholdCoef * thresholdScale)))
640655 then throw("New balance in assets of the DApp is less than threshold")
641656 else false
642657 }
643658
644659
645660 func checkCoins (assetIds) = {
646661 let coins = split(assetIds, ",")
647- func checkCoin (error,assetId) = {
648- let asset = valueOrErrorMessage(fromBase58String(assetId), ("fromBase58String: " + assetId))
649- let decimals = valueOrErrorMessage(assetInfo(asset), ("assetInfo: " + assetId)).decimals
650- if ((decimals != DECIMALS))
651- then throw("wrong decimals")
652- else false
653- }
662+ if ((size(coins) > 10))
663+ then throw("To many coins, max coins size 10")
664+ else {
665+ func checkCoin (error,assetId) = {
666+ let asset = valueOrErrorMessage(fromBase58String(assetId), ("fromBase58String: " + assetId))
667+ let decimals = valueOrErrorMessage(assetInfo(asset), ("assetInfo: " + assetId)).decimals
668+ if ((decimals != DECIMALS))
669+ then throw("wrong decimals")
670+ else false
671+ }
654672
655- let $l = coins
656- let $s = size($l)
657- let $acc0 = false
658- func $f0_1 ($a,$i) = if (($i >= $s))
659- then $a
660- else checkCoin($a, $l[$i])
673+ let $l = coins
674+ let $s = size($l)
675+ let $acc0 = false
676+ func $f0_1 ($a,$i) = if (($i >= $s))
677+ then $a
678+ else checkCoin($a, $l[$i])
661679
662- func $f0_2 ($a,$i) = if (($i >= $s))
663- then $a
664- else throw("List size exceeds 15")
680+ func $f0_2 ($a,$i) = if (($i >= $s))
681+ then $a
682+ else throw("List size exceeds 10")
665683
666- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
684+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
685+ }
686+ }
687+
688+
689+func calcWithdraw (msg,minAmounts,unlockAmount) = {
690+ let suspicious = checkSuspicious()
691+ if (suspicious._1)
692+ then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, msg.payments))
693+ else {
694+ let pmtAmount = if ((size(msg.payments) > 0))
695+ then if ((size(msg.payments) != 1))
696+ then throw("size(payments) != 1")
697+ else {
698+ let pmtAssetId = msg.payments[0].assetId
699+ if ((shareAssetId != pmtAssetId))
700+ then throw("unknown payment token")
701+ else msg.payments[0].amount
702+ }
703+ else 0
704+ let withdrawAmount = (pmtAmount + unlockAmount)
705+ func calcScriptActions (acc,balance) = {
706+ let $t01467814706 = acc
707+ let scriptActions = $t01467814706._1
708+ let i = $t01467814706._2
709+ let wAmount = fraction(balance, withdrawAmount, shareSupply)
710+ if (assert((wAmount >= minAmounts[i])))
711+ then throw("Withdrawal resulted in fewer coins than expected")
712+ else {
713+ let us = unstake(wAmount, assetIds[i])
714+ if ((us == us))
715+ then $Tuple2((scriptActions ++ [IntegerEntry((assetIds[i] + kAssetBalance), (balance - wAmount)), ScriptTransfer(msg.caller, wAmount, fromBase58String(assetIds[i]))]), (i + 1))
716+ else throw("Strict value is not equal to itself.")
717+ }
718+ }
719+
720+ let $t01519515263 = {
721+ let $l = _xp()
722+ let $s = size($l)
723+ let $acc0 = $Tuple2(nil, 0)
724+ func $f0_1 ($a,$i) = if (($i >= $s))
725+ then $a
726+ else calcScriptActions($a, $l[$i])
727+
728+ func $f0_2 ($a,$i) = if (($i >= $s))
729+ then $a
730+ else throw("List size exceeds 10")
731+
732+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
733+ }
734+ let scriptActions = $t01519515263._1
735+ let i = $t01519515263._2
736+ (scriptActions ++ [Burn(shareAssetId, withdrawAmount), IntegerEntry(kShareAssetSupply, (shareSupply - withdrawAmount))])
737+ }
738+ }
739+
740+
741+func calcWithdrawOneCoinEntries (msg,tokenOut,minAmount,unlockAmount) = {
742+ let suspicious = checkSuspicious()
743+ if (suspicious._1)
744+ then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.originCaller, msg.payments))
745+ else {
746+ let pmtAmount = if ((size(msg.payments) > 0))
747+ then {
748+ let pmtAssetId = msg.payments[0].assetId
749+ if ((shareAssetId != pmtAssetId))
750+ then throw("unknown payment token")
751+ else msg.payments[0].amount
752+ }
753+ else 0
754+ let outIndex = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
755+ let tokenOutB58 = fromBase58String(tokenOut)
756+ let withdrawAmount = (pmtAmount + unlockAmount)
757+ let xp = _xp()
758+ let $t01612516212 = _calcWithdrawOneCoin(xp, withdrawAmount, outIndex, msg.originCaller)
759+ let dy = $t01612516212._1
760+ let dy_fee = $t01612516212._2
761+ if (assert((dy >= minAmount)))
762+ then throw("Not enough coins removed")
763+ else {
764+ let governanceFees = fraction(dy_fee, feeGovernance, feeScale6)
765+ let dy_and_fee = (dy + dy_fee)
766+ func makeNewBalances (acc,tokenBalance) = {
767+ let $t01647016496 = acc
768+ let newBalances = $t01647016496._1
769+ let i = $t01647016496._2
770+ if ((i == outIndex))
771+ then $Tuple2((newBalances :+ (tokenBalance - dy_and_fee)), (i + 1))
772+ else $Tuple2((newBalances :+ tokenBalance), (i + 1))
773+ }
774+
775+ let $t01666316724 = {
776+ let $l = xp
777+ let $s = size($l)
778+ let $acc0 = $Tuple2(nil, 0)
779+ func $f0_1 ($a,$i) = if (($i >= $s))
780+ then $a
781+ else makeNewBalances($a, $l[$i])
782+
783+ func $f0_2 ($a,$i) = if (($i >= $s))
784+ then $a
785+ else throw("List size exceeds 10")
786+
787+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
788+ }
789+ let newBalances = $t01666316724._1
790+ let v = $t01666316724._2
791+ if (checkDAppThreshold(newBalances))
792+ then throw()
793+ else {
794+ let us = unstake(dy_and_fee, tokenOut)
795+ if ((us == us))
796+ then {
797+ let lpFees = (dy_fee - governanceFees)
798+ let airdrop = if ((lpFees > 0))
799+ then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(tokenOutB58, lpFees)])
800+ else 0
801+ if ((airdrop == airdrop))
802+ then [ScriptTransfer(msg.originCaller, dy, tokenOutB58), IntegerEntry((assetIds[outIndex] + kAssetBalance), (xp[outIndex] - dy_and_fee)), Burn(shareAssetId, withdrawAmount), ScriptTransfer(moneyBoxAddress, governanceFees, tokenOutB58), IntegerEntry(kShareAssetSupply, (shareSupply - withdrawAmount))]
803+ else throw("Strict value is not equal to itself.")
804+ }
805+ else throw("Strict value is not equal to itself.")
806+ }
807+ }
808+ }
667809 }
668810
669811
670812 @Callable(msg)
671813 func D (xp,amp) = {
672814 let D = get_D_internal(xp, amp)
673815 $Tuple2([IntegerEntry("D", D)], D)
674816 }
675817
676818
677819
678820 @Callable(msg)
679821 func init (assetIds,_A,_dAppThresholdCoef) = if (!(isDataStorageUntouched(this)))
680822 then throw("Already initialized")
681823 else if ((0 >= _A))
682824 then throw("Amp must be must > 0")
683825 else if ((0 >= _dAppThresholdCoef))
684826 then throw("dApp Threshold Coef must be > 0")
685827 else {
686- let shareName = "multiUSDC"
687- let shareDescription = ("ShareToken of SwopFi protocol for multi-stable USDC pool at address " + toString(this))
828+ let shareName = "s_Multi_USD"
829+ let shareDescription = ("ShareToken of SwopFi protocol for MultiStable USD pool at address " + toString(this))
688830 let issueToken = Issue(shareName, shareDescription, 0, 6, true)
689831 let tokenId = calculateAssetId(issueToken)
690832 if (checkCoins(assetIds))
691833 then throw()
692834 else [StringEntry(kVersion, version), StringEntry(kAssets, assetIds), IntegerEntry("initial_A", _A), IntegerEntry("future_A", _A), IntegerEntry(kFee, getIntegerValue(oracle, "base_fee_flat")), StringEntry(kShareAssetId, toBase58String(tokenId)), IntegerEntry(kShareAssetSupply, 0), IntegerEntry(kDAppThresholdCoef, _dAppThresholdCoef), BooleanEntry(kActive, true), issueToken]
693835 }
694836
695837
696838
697839 @Callable(msg)
698-func addLiquidity (minMintAmount,stakeFarming) = valueOrElse(isActive(), {
840+func addLiquidity (minMintAmount,stakeFarming,lockType) = valueOrElse(isActive(), {
699841 let amp = _A()
700842 let xp = _xp()
701843 let D0 = if ((shareSupply == 0))
702844 then 0
703845 else getDMem(xp, amp)
704- let payments = msg.payments
846+ let $t01886419118 = if (if ((lockType > 0))
847+ then (msg.payments[(size(msg.payments) - 1)].assetId == unit)
848+ else false)
849+ then $Tuple2(removeByIndex(msg.payments, (size(msg.payments) - 1)), [msg.payments[(size(msg.payments) - 1)]])
850+ else $Tuple2(msg.payments, nil)
851+ let payments = $t01886419118._1
852+ let lockFee = $t01886419118._2
705853 let paymentsSize = size(payments)
706854 func validPayments (n) = if ((paymentsSize > nCoins))
707855 then throw(("payments size > " + toString(nCoins)))
708856 else if ((1 > paymentsSize))
709857 then throw("payments size < 1")
710858 else if (if ((shareSupply == 0))
711859 then (nCoins != paymentsSize)
712860 else false)
713861 then throw("initial deposit requires all coins")
714862 else {
715863 func paymantValid (acc,payment) = if (containsElement(assetIds, getStrAssetId(payment.assetId)))
716864 then true
717865 else throw("Invalid asset in payment")
718866
719867 let $l = payments
720868 let $s = size($l)
721869 let $acc0 = false
722870 func $f0_1 ($a,$i) = if (($i >= $s))
723871 then $a
724872 else paymantValid($a, $l[$i])
725873
726874 func $f0_2 ($a,$i) = if (($i >= $s))
727875 then $a
728- else throw("List size exceeds 15")
876+ else throw("List size exceeds 10")
729877
730- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
878+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
731879 }
732880
733881 if (!(validPayments(paymentsSize)))
734882 then throw()
735883 else {
736884 let suspicious = checkSuspicious()
737885 if (suspicious._1)
738886 then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, payments))
739887 else {
740888 func parsePayments (acc,assetId) = {
741- let $t01612516154 = acc
742- let newBalances = $t01612516154._1
743- let i = $t01612516154._2
744- let j = $t01612516154._3
745- if (if ((paymentsSize > j))
746- then (getStrAssetId(payments[j].assetId) == assetId)
747- else false)
748- then $Tuple3((newBalances :+ (xp[i] + payments[j].amount)), (i + 1), (j + 1))
749- else $Tuple3((newBalances :+ xp[i]), (i + 1), j)
889+ let $t01998820014 = acc
890+ let newBalances = $t01998820014._1
891+ let i = $t01998820014._2
892+ func parsePayment (newBalance,payment) = if ((getStrAssetId(payment.assetId) == assetId))
893+ then (newBalance + payment.amount)
894+ else newBalance
895+
896+ let newBalace = {
897+ let $l = payments
898+ let $s = size($l)
899+ let $acc0 = xp[i]
900+ func $f0_1 ($a,$i) = if (($i >= $s))
901+ then $a
902+ else parsePayment($a, $l[$i])
903+
904+ func $f0_2 ($a,$i) = if (($i >= $s))
905+ then $a
906+ else throw("List size exceeds 10")
907+
908+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
909+ }
910+ $Tuple2((newBalances :+ newBalace), (i + 1))
750911 }
751912
752- let $t01637416460 = {
913+ let $t02036420431 = {
753914 let $l = assetIds
754915 let $s = size($l)
755- let $acc0 = $Tuple3(nil, 0, 0)
916+ let $acc0 = $Tuple2(nil, 0)
756917 func $f0_1 ($a,$i) = if (($i >= $s))
757918 then $a
758919 else parsePayments($a, $l[$i])
759920
760921 func $f0_2 ($a,$i) = if (($i >= $s))
761922 then $a
762- else throw("List size exceeds 15")
923+ else throw("List size exceeds 10")
763924
764- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
925+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
765926 }
766- let newBalances = $t01637416460._1
767- let k = $t01637416460._2
768- let parsedPayments = $t01637416460._3
769- if ((paymentsSize > parsedPayments))
770- then throw("Incorect payments order")
771- else if (checkDAppThreshold(newBalances))
772- then throw()
773- else {
774- let D1 = getDMem(newBalances, amp)
775- if (assert((D1 > D0)))
776- then throw("D1 > D0")
777- else {
778- let feeDiscount = calculateFeeDiscount(msg.caller)
779- func calcScriptActions (acc,newBalance) = {
780- let $t01686116902 = acc
781- let invBalances = $t01686116902._1
782- let scriptActions = $t01686116902._2
783- let i = $t01686116902._3
784- if ((shareSupply > 0))
785- then {
786- let _fee = ((fraction(fee, feeDiscount, feeScale6, CEILING) * nCoins) / (4 * (nCoins - 1)))
787- let fees = {
788- let idealBalance = fraction(D1, xp[i], D0)
789- let difference = if ((idealBalance > newBalance))
790- then (idealBalance - newBalance)
791- else (newBalance - idealBalance)
792- fraction(_fee, difference, feeScale6)
927+ let newBalances = $t02036420431._1
928+ let k = $t02036420431._2
929+ if (checkDAppThreshold(newBalances))
930+ then throw()
931+ else {
932+ let D1 = getDMem(newBalances, amp)
933+ if (assert((D1 > D0)))
934+ then throw("D1 > D0")
935+ else {
936+ let feeDiscount = calculateFeeDiscount(msg.caller)
937+ func calcScriptActions (acc,newBalance) = {
938+ let $t02075120792 = acc
939+ let invBalances = $t02075120792._1
940+ let scriptActions = $t02075120792._2
941+ let i = $t02075120792._3
942+ if ((shareSupply > 0))
943+ then {
944+ let _fee = ((fraction(fee, feeDiscount, feeScale6, CEILING) * nCoins) / (4 * (nCoins - 1)))
945+ let fees = {
946+ let idealBalance = fraction(D1, xp[i], D0)
947+ let difference = if ((idealBalance > newBalance))
948+ then (idealBalance - newBalance)
949+ else (newBalance - idealBalance)
950+ fraction(_fee, difference, feeScale6)
951+ }
952+ let governanceFees = fraction(fees, feeGovernance, feeScale6)
953+ let finalBalance = (newBalance - fees)
954+ let invariantBalance = (newBalance - fees)
955+ let pmt = (newBalance - xp[i])
956+ let lpFees = (fees - governanceFees)
957+ let inv = if ((pmt > 0))
958+ then stake((pmt - fees), assetIds[i])
959+ else unstake(fees, assetIds[i])
960+ if ((inv == inv))
961+ then {
962+ let airdrop = if ((lpFees > 0))
963+ then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(fromBase58String(assetIds[i]), lpFees)])
964+ else 0
965+ if ((airdrop == airdrop))
966+ then $Tuple3((invBalances :+ invariantBalance), (scriptActions ++ [ScriptTransfer(moneyBoxAddress, governanceFees, fromBase58String(assetIds[i])), IntegerEntry((assetIds[i] + kAssetBalance), finalBalance)]), (i + 1))
967+ else throw("Strict value is not equal to itself.")
793968 }
794- let governanceFees = fraction(fees, feeGovernance, feeScale6)
795- let finalBalance = (newBalance - fees)
796- let invariantBalance = (newBalance - fees)
797- let pmt = (newBalance - xp[i])
798- let lpFees = (fees - governanceFees)
799- let inv = if ((pmt > 0))
800- then stake((pmt - fees), assetIds[i])
801- else unstake(fees, assetIds[i])
802- if ((inv == inv))
803- then {
804- let airdrop = if ((lpFees > 0))
805- then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(fromBase58String(assetIds[i]), lpFees)])
806- else 0
807- if ((airdrop == airdrop))
808- then $Tuple3((invBalances :+ invariantBalance), (scriptActions ++ [ScriptTransfer(moneyBoxAddress, governanceFees, fromBase58String(assetIds[i])), IntegerEntry((assetIds[i] + kAssetBalance), finalBalance)]), (i + 1))
809- else throw("Strict value is not equal to itself.")
810- }
811- else throw("Strict value is not equal to itself.")
812- }
813- else {
814- let inv = stake(newBalance, assetIds[i])
815- if ((inv == inv))
816- then $Tuple3((invBalances :+ newBalance), (scriptActions :+ IntegerEntry((assetIds[i] + kAssetBalance), newBalance)), (i + 1))
817- else throw("Strict value is not equal to itself.")
818- }
819- }
969+ else throw("Strict value is not equal to itself.")
970+ }
971+ else {
972+ let inv = stake(newBalance, assetIds[i])
973+ if ((inv == inv))
974+ then $Tuple3((invBalances :+ newBalance), (scriptActions :+ IntegerEntry((assetIds[i] + kAssetBalance), newBalance)), (i + 1))
975+ else throw("Strict value is not equal to itself.")
976+ }
977+ }
820978
821- let $t01860718695 = {
822- let $l = newBalances
823- let $s = size($l)
824- let $acc0 = $Tuple3(nil, nil, 0)
825- func $f1_1 ($a,$i) = if (($i >= $s))
826- then $a
827- else calcScriptActions($a, $l[$i])
979+ let $t02249722585 = {
980+ let $l = newBalances
981+ let $s = size($l)
982+ let $acc0 = $Tuple3(nil, nil, 0)
983+ func $f1_1 ($a,$i) = if (($i >= $s))
984+ then $a
985+ else calcScriptActions($a, $l[$i])
828986
829- func $f1_2 ($a,$i) = if (($i >= $s))
830- then $a
831- else throw("List size exceeds 15")
987+ func $f1_2 ($a,$i) = if (($i >= $s))
988+ then $a
989+ else throw("List size exceeds 10")
832990
833- $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
834- }
835- let invBalances = $t01860718695._1
836- let scriptActions = $t01860718695._2
837- let D2 = getDMem(invBalances, amp)
838- let mint_amount = if ((shareSupply == 0))
839- then D1
840- else fraction(shareSupply, (D2 - D0), D0)
841- if (assert((mint_amount >= minMintAmount)))
842- then throw("Slippage screwed you")
843- else if (stakeFarming)
844- then {
845- let re = invoke(this, "reissueShare", [mint_amount], nil)
846- if ((re == re))
847- then {
848- let s = invoke(farmingAddress, "lockShareTokens", [toString(this)], [AttachedPayment(shareAssetId, mint_amount)])
849- if ((s == s))
850- then (scriptActions :+ IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount)))
851- else throw("Strict value is not equal to itself.")
852- }
853- else throw("Strict value is not equal to itself.")
854- }
855- else (scriptActions ++ [Reissue(shareAssetId, mint_amount, true), ScriptTransfer(msg.caller, mint_amount, shareAssetId), IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount))])
991+ $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
856992 }
857- }
993+ let invBalances = $t02249722585._1
994+ let scriptActions = $t02249722585._2
995+ let D2 = getDMem(invBalances, amp)
996+ let mint_amount = if ((shareSupply == 0))
997+ then D1
998+ else fraction(shareSupply, (D2 - D0), D0)
999+ if (assert((mint_amount >= minMintAmount)))
1000+ then throw("Slippage screwed you")
1001+ else if (stakeFarming)
1002+ then {
1003+ let re = invoke(this, "reissueShare", [mint_amount], nil)
1004+ if ((re == re))
1005+ then {
1006+ let s = invoke(farmingAddress, "lockShareTokensFromPool", [msg.caller.bytes, toString(this), lockType], ([AttachedPayment(shareAssetId, mint_amount)] ++ lockFee))
1007+ if ((s == s))
1008+ then (scriptActions :+ IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount)))
1009+ else throw("Strict value is not equal to itself.")
1010+ }
1011+ else throw("Strict value is not equal to itself.")
1012+ }
1013+ else (scriptActions ++ [Reissue(shareAssetId, mint_amount, true), ScriptTransfer(msg.caller, mint_amount, shareAssetId), IntegerEntry(kShareAssetSupply, (shareSupply + mint_amount))])
1014+ }
1015+ }
8581016 }
8591017 }
8601018 })
8611019
8621020
8631021
8641022 @Callable(msg)
8651023 func calcMintAmount (newBalances,user) = {
8661024 let amp = _A()
8671025 let xp = _xp()
8681026 let D1 = getDMem(newBalances, amp)
8691027 if ((shareSupply == 0))
8701028 then $Tuple2(nil, D1)
8711029 else {
8721030 let D0 = getDMem(xp, amp)
8731031 let feeDiscount = calculateFeeDiscount(user)
8741032 func calcInvBalances (acc,newBalance) = {
875- let $t01988419910 = acc
876- let invBalances = $t01988419910._1
877- let i = $t01988419910._2
1033+ let $t02386123887 = acc
1034+ let invBalances = $t02386123887._1
1035+ let i = $t02386123887._2
8781036 let _fee = ((fraction(fee, feeDiscount, feeScale6, CEILING) * nCoins) / (4 * (nCoins - 1)))
8791037 let fees = {
8801038 let idealBalance = fraction(D1, xp[i], D0)
8811039 let difference = if ((idealBalance > newBalance))
8821040 then (idealBalance - newBalance)
8831041 else (newBalance - idealBalance)
8841042 fraction(_fee, difference, feeScale6)
8851043 }
8861044 let invariantBalance = (newBalance - fees)
8871045 $Tuple2((invBalances :+ invariantBalance), (i + 1))
8881046 }
8891047
890- let $t02051220582 = {
1048+ let $t02448924559 = {
8911049 let $l = newBalances
8921050 let $s = size($l)
8931051 let $acc0 = $Tuple2(nil, 0)
8941052 func $f0_1 ($a,$i) = if (($i >= $s))
8951053 then $a
8961054 else calcInvBalances($a, $l[$i])
8971055
8981056 func $f0_2 ($a,$i) = if (($i >= $s))
8991057 then $a
900- else throw("List size exceeds 15")
1058+ else throw("List size exceeds 10")
9011059
902- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1060+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
9031061 }
904- let invBalances = $t02051220582._1
905- let k = $t02051220582._2
1062+ let invBalances = $t02448924559._1
1063+ let k = $t02448924559._2
9061064 let D2 = getDMem(invBalances, amp)
9071065 let mintAmount = fraction(shareSupply, (D2 - D0), D0)
9081066 $Tuple2(nil, mintAmount)
9091067 }
9101068 }
9111069
9121070
9131071
9141072 @Callable(msg)
9151073 func reissueShare (amount) = valueOrElse(isSelfCall(msg), [Reissue(shareAssetId, amount, true)])
9161074
9171075
9181076
9191077 @Callable(msg)
9201078 func getDy (assetFrom,assetTo,dx,userAddress) = {
9211079 let xp = _xp()
9221080 let fromIndex = valueOrErrorMessage(indexOf(assetIds, assetFrom), "unknown token in")
9231081 let toIndex = valueOrErrorMessage(indexOf(assetIds, assetTo), "unknown token out")
9241082 let x = (xp[fromIndex] + dx)
9251083 let y = getY(fromIndex, toIndex, x, xp)
9261084 let dy = ((xp[toIndex] - y) - 1)
9271085 let feeDiscount = calculateFeeDiscount(Address(fromBase58String(userAddress)))
9281086 let _fee = fraction(fraction(fee, feeDiscount, feeScale6, CEILING), dy, feeScale6)
9291087 $Tuple2(nil, $Tuple2((dy - _fee), _fee))
9301088 }
9311089
9321090
9331091
9341092 @Callable(msg)
9351093 func exchange (tokenOut,min_dy) = valueOrElse(isActive(), if ((size(msg.payments) != 1))
9361094 then throw("size(payments) != 1")
9371095 else {
9381096 let suspicious = checkSuspicious()
9391097 if (suspicious._1)
9401098 then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, msg.payments))
9411099 else {
9421100 let payment = msg.payments[0]
9431101 let tokenIn = getStrAssetId(payment.assetId)
9441102 let tokenOutB58 = fromBase58String(tokenOut)
9451103 let dx = payment.amount
9461104 let fromIndex = valueOrErrorMessage(indexOf(assetIds, tokenIn), "unknown token in")
9471105 let toIndex = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
9481106 let xp = _xp()
9491107 let x = (xp[fromIndex] + dx)
9501108 let y = getY(fromIndex, toIndex, x, xp)
9511109 let _dy = ((xp[toIndex] - y) - 1)
9521110 let feeDiscount = calculateFeeDiscount(msg.originCaller)
9531111 let _fee = fraction(_dy, fraction(fee, feeDiscount, feeScale6, CEILING), feeScale6)
9541112 let dy = (_dy - _fee)
9551113 let governanceFees = fraction(_fee, feeGovernance, feeScale6)
9561114 if (assert((dy >= min_dy)))
9571115 then throw("Exchange resulted in fewer coins than expected")
9581116 else {
9591117 func makeNewBalances (acc,tokenBalance) = {
960- let $t02262322649 = acc
961- let newBalances = $t02262322649._1
962- let i = $t02262322649._2
1118+ let $t02660026626 = acc
1119+ let newBalances = $t02660026626._1
1120+ let i = $t02660026626._2
9631121 if ((i == fromIndex))
9641122 then $Tuple2((newBalances :+ (tokenBalance + dx)), (i + 1))
9651123 else if ((i == toIndex))
9661124 then $Tuple2((newBalances :+ (tokenBalance - _dy)), (i + 1))
9671125 else $Tuple2((newBalances :+ tokenBalance), (i + 1))
9681126 }
9691127
970- let $t02290022961 = {
1128+ let $t02687726938 = {
9711129 let $l = xp
9721130 let $s = size($l)
9731131 let $acc0 = $Tuple2(nil, 0)
9741132 func $f0_1 ($a,$i) = if (($i >= $s))
9751133 then $a
9761134 else makeNewBalances($a, $l[$i])
9771135
9781136 func $f0_2 ($a,$i) = if (($i >= $s))
9791137 then $a
980- else throw("List size exceeds 15")
1138+ else throw("List size exceeds 10")
9811139
982- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1140+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
9831141 }
984- let newBalances = $t02290022961._1
985- let i = $t02290022961._2
1142+ let newBalances = $t02687726938._1
1143+ let i = $t02687726938._2
9861144 if (checkDAppThreshold(newBalances))
9871145 then throw()
9881146 else {
9891147 let s = stake(payment.amount, getStrAssetId(payment.assetId))
9901148 if ((s == s))
9911149 then {
9921150 let us = unstake(_dy, tokenOut)
9931151 if ((us == us))
9941152 then {
9951153 let lpFees = (_fee - governanceFees)
9961154 let airdrop = if ((lpFees > 0))
9971155 then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(tokenOutB58, lpFees)])
9981156 else 0
9991157 if ((airdrop == airdrop))
10001158 then $Tuple2([IntegerEntry((tokenIn + kAssetBalance), x), IntegerEntry((tokenOut + kAssetBalance), (xp[toIndex] - _dy)), ScriptTransfer(msg.caller, dy, tokenOutB58), ScriptTransfer(moneyBoxAddress, governanceFees, tokenOutB58)], [dy, tokenOutB58])
10011159 else throw("Strict value is not equal to itself.")
10021160 }
10031161 else throw("Strict value is not equal to itself.")
10041162 }
10051163 else throw("Strict value is not equal to itself.")
10061164 }
10071165 }
10081166 }
10091167 })
10101168
10111169
10121170
10131171 @Callable(msg)
1014-func withdraw (minAmounts) = valueOrElse(isActive(), if ((size(msg.payments) != 1))
1015- then throw("size(payments) != 1")
1016- else {
1017- let pmtAmount = msg.payments[0].amount
1018- let pmtAssetId = msg.payments[0].assetId
1019- if ((shareAssetId != pmtAssetId))
1020- then throw("unknown payment token")
1021- else {
1022- let suspicious = checkSuspicious()
1023- if (suspicious._1)
1024- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.originCaller, msg.payments))
1025- else {
1026- func calcScriptActions (acc,balance) = {
1027- let $t02425224280 = acc
1028- let scriptActions = $t02425224280._1
1029- let i = $t02425224280._2
1030- let wAmount = fraction(balance, pmtAmount, shareSupply)
1031- if (assert((wAmount >= minAmounts[i])))
1032- then throw("Withdrawal resulted in fewer coins than expected")
1033- else {
1034- let us = unstake(wAmount, assetIds[i])
1035- if ((us == us))
1036- then $Tuple2((scriptActions ++ [IntegerEntry((assetIds[i] + kAssetBalance), (balance - wAmount)), ScriptTransfer(msg.originCaller, wAmount, fromBase58String(assetIds[i]))]), (i + 1))
1037- else throw("Strict value is not equal to itself.")
1038- }
1039- }
1040-
1041- let $t02477024838 = {
1042- let $l = _xp()
1043- let $s = size($l)
1044- let $acc0 = $Tuple2(nil, 0)
1045- func $f0_1 ($a,$i) = if (($i >= $s))
1046- then $a
1047- else calcScriptActions($a, $l[$i])
1048-
1049- func $f0_2 ($a,$i) = if (($i >= $s))
1050- then $a
1051- else throw("List size exceeds 15")
1052-
1053- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1054- }
1055- let scriptActions = $t02477024838._1
1056- let i = $t02477024838._2
1057- (scriptActions ++ [Burn(shareAssetId, pmtAmount), IntegerEntry(kShareAssetSupply, (shareSupply - pmtAmount))])
1058- }
1059- }
1060- })
1172+func withdraw (minAmounts) = valueOrElse(isActive(), calcWithdraw(msg, minAmounts, 0))
10611173
10621174
10631175
10641176 @Callable(msg)
10651177 func withdrawWithUnlock (minAmounts,unlockAmount) = valueOrElse(isActive(), if ((0 >= unlockAmount))
10661178 then throw("Unlock amount must be positive")
10671179 else {
1068- let suspicious = checkSuspicious()
1069- if (suspicious._1)
1070- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, msg.payments))
1071- else {
1072- let pmtAmount = if ((size(msg.payments) > 0))
1073- then if ((size(msg.payments) != 1))
1074- then throw("size(payments) != 1")
1075- else {
1076- let pmtAssetId = msg.payments[0].assetId
1077- if ((shareAssetId != pmtAssetId))
1078- then throw("unknown payment token")
1079- else msg.payments[0].amount
1080- }
1081- else 0
1082- let unlock = invoke(farmingAddress, "withdrawShareTokens", [toString(this), unlockAmount], nil)
1083- if ((unlock == unlock))
1084- then {
1085- let withdrawAmount = (pmtAmount + unlockAmount)
1086- let inv = invoke(this, "withdraw", [minAmounts], [AttachedPayment(shareAssetId, withdrawAmount)])
1087- if ((inv == inv))
1088- then nil
1089- else throw("Strict value is not equal to itself.")
1090- }
1091- else throw("Strict value is not equal to itself.")
1092- }
1180+ let unlock = invoke(farmingAddress, "withdrawShareTokensFromPool", [msg.caller.bytes, toString(this), unlockAmount], nil)
1181+ if ((unlock == unlock))
1182+ then calcWithdraw(msg, minAmounts, unlockAmount)
1183+ else throw("Strict value is not equal to itself.")
10931184 })
10941185
10951186
10961187
10971188 @Callable(msg)
1098-func calcWithdrawOneCoin (tokenAmount,tokenOut,user) = {
1099- let i = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
1100- $Tuple2(nil, _calcWithdrawOneCoin(_xp(), tokenAmount, i, Address(fromBase58String(user)))._1)
1101- }
1189+func calcWithdrawOneCoin (tokenAmount,tokenOut,user) = if ((0 >= tokenAmount))
1190+ then throw("Amount must be positive")
1191+ else {
1192+ let i = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
1193+ $Tuple2(nil, _calcWithdrawOneCoin(_xp(), tokenAmount, i, Address(fromBase58String(user)))._1)
1194+ }
11021195
11031196
11041197
11051198 @Callable(msg)
11061199 func withdrawOneCoin (tokenOut,minAmount) = valueOrElse(isActive(), if ((size(msg.payments) != 1))
11071200 then throw("size(payments) != 1")
1108- else {
1109- let suspicious = checkSuspicious()
1110- if (suspicious._1)
1111- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.originCaller, msg.payments))
1112- else {
1113- let pmtAmount = msg.payments[0].amount
1114- let pmtAssetId = msg.payments[0].assetId
1115- if ((pmtAssetId != shareAssetId))
1116- then throw("unknown token")
1117- else {
1118- let outIndex = valueOrErrorMessage(indexOf(assetIds, tokenOut), "unknown token out")
1119- let tokenOutB58 = fromBase58String(tokenOut)
1120- let xp = _xp()
1121- let $t02680226884 = _calcWithdrawOneCoin(xp, pmtAmount, outIndex, msg.originCaller)
1122- let dy = $t02680226884._1
1123- let dy_fee = $t02680226884._2
1124- if (assert((dy >= minAmount)))
1125- then throw("Not enough coins removed")
1126- else {
1127- let governanceFees = fraction(dy_fee, feeGovernance, feeScale6)
1128- let dy_and_fee = (dy + dy_fee)
1129- func makeNewBalances (acc,tokenBalance) = {
1130- let $t02714227168 = acc
1131- let newBalances = $t02714227168._1
1132- let i = $t02714227168._2
1133- if ((i == outIndex))
1134- then $Tuple2((newBalances :+ (tokenBalance - dy_and_fee)), (i + 1))
1135- else $Tuple2((newBalances :+ tokenBalance), (i + 1))
1136- }
1137-
1138- let $t02733527396 = {
1139- let $l = xp
1140- let $s = size($l)
1141- let $acc0 = $Tuple2(nil, 0)
1142- func $f0_1 ($a,$i) = if (($i >= $s))
1143- then $a
1144- else makeNewBalances($a, $l[$i])
1145-
1146- func $f0_2 ($a,$i) = if (($i >= $s))
1147- then $a
1148- else throw("List size exceeds 15")
1149-
1150- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1151- }
1152- let newBalances = $t02733527396._1
1153- let v = $t02733527396._2
1154- if (checkDAppThreshold(newBalances))
1155- then throw()
1156- else {
1157- let us = unstake(dy_and_fee, tokenOut)
1158- if ((us == us))
1159- then {
1160- let lpFees = (dy_fee - governanceFees)
1161- let airdrop = if ((lpFees > 0))
1162- then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(tokenOutB58, lpFees)])
1163- else 0
1164- if ((airdrop == airdrop))
1165- then [ScriptTransfer(msg.originCaller, dy, tokenOutB58), IntegerEntry((assetIds[outIndex] + kAssetBalance), (xp[outIndex] - dy_and_fee)), Burn(shareAssetId, pmtAmount), ScriptTransfer(moneyBoxAddress, governanceFees, tokenOutB58), IntegerEntry(kShareAssetSupply, (shareSupply - pmtAmount))]
1166- else throw("Strict value is not equal to itself.")
1167- }
1168- else throw("Strict value is not equal to itself.")
1169- }
1170- }
1171- }
1172- }
1173- })
1201+ else calcWithdrawOneCoinEntries(msg, tokenOut, minAmount, 0))
11741202
11751203
11761204
11771205 @Callable(msg)
1178-func withdrawOneCoinWithUnlock (tokenOut,minAmount,unlockAmount) = valueOrElse(isActive(), if ((0 >= unlockAmount))
1206+func withdrawOneCoinWithUnlock (tokenOut,minAmount,unlockAmount) = valueOrElse(isActive(), if ((0 > unlockAmount))
11791207 then throw("Unlock amount must be positive")
11801208 else {
1181- let suspicious = checkSuspicious()
1182- if (suspicious._1)
1183- then (suspendSuspicious(suspicious._2) ++ returnPayments(msg.caller, msg.payments))
1184- else {
1185- let pmtAmount = if ((size(msg.payments) > 0))
1186- then if ((size(msg.payments) != 1))
1187- then throw("size(payments) != 1")
1188- else {
1189- let pmtAssetId = msg.payments[0].assetId
1190- if ((shareAssetId != pmtAssetId))
1191- then throw("unknown payment token")
1192- else msg.payments[0].amount
1193- }
1194- else 0
1195- let unlock = invoke(farmingAddress, "withdrawShareTokens", [toString(this), unlockAmount], nil)
1196- if ((unlock == unlock))
1197- then {
1198- let withdrawAmount = (pmtAmount + unlockAmount)
1199- let inv = invoke(this, "withdrawOneCoin", [tokenOut, minAmount], [AttachedPayment(shareAssetId, withdrawAmount)])
1200- if ((inv == inv))
1201- then nil
1202- else throw("Strict value is not equal to itself.")
1203- }
1204- else throw("Strict value is not equal to itself.")
1205- }
1209+ let unlock = invoke(farmingAddress, "withdrawShareTokensFromPool", [msg.caller.bytes, toString(this), unlockAmount], nil)
1210+ if ((unlock == unlock))
1211+ then calcWithdrawOneCoinEntries(msg, tokenOut, minAmount, unlockAmount)
1212+ else throw("Strict value is not equal to itself.")
12061213 })
12071214
12081215
12091216
12101217 @Callable(msg)
12111218 func A () = $Tuple2(nil, _A())
12121219
12131220
12141221
12151222 @Callable(msg)
12161223 func getVirtualPrice () = {
12171224 let D = get_D(_xp(), _A())
12181225 $Tuple2(nil, fraction(D, PRECISION, shareSupply))
12191226 }
12201227
12211228
12221229
12231230 @Callable(msg)
12241231 func calcTokenAmount (amounts,deposit) = {
12251232 let amp = _A()
12261233 let balances = _xp()
12271234 let D0 = getDMem(balances, amp)
12281235 func calcNewBalances (acc,balance) = {
1229- let $t02941329439 = acc
1230- let newBalances = $t02941329439._1
1231- let i = $t02941329439._2
1236+ let $t02951529541 = acc
1237+ let newBalances = $t02951529541._1
1238+ let i = $t02951529541._2
12321239 let newBalance = (balance + (if (deposit)
12331240 then amounts[i]
12341241 else -(amounts[i])))
12351242 $Tuple2((newBalances :+ newBalance), (i + 1))
12361243 }
12371244
12381245 let newBalances = ( let $l = balances
12391246 let $s = size($l)
12401247 let $acc0 = $Tuple2(nil, 0)
12411248 func $f0_1 ($a,$i) = if (($i >= $s))
12421249 then $a
12431250 else calcNewBalances($a, $l[$i])
12441251
12451252 func $f0_2 ($a,$i) = if (($i >= $s))
12461253 then $a
1247- else throw("List size exceeds 15")
1254+ else throw("List size exceeds 10")
12481255
1249- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15))._1
1256+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10))._1
12501257 let D1 = getDMem(newBalances, amp)
12511258 let diff = if (deposit)
12521259 then (D1 - D0)
12531260 else (D0 - D1)
12541261 $Tuple2(nil, fraction(diff, shareSupply, D0))
12551262 }
12561263
12571264
12581265
12591266 @Callable(msg)
12601267 func rampA (_futureA,_futureTime) = valueOrElse(isActive(), valueOrElse(isAdminCall(msg), if (assert((blockTimestamp >= (initial_A_time + MIN_RAMP_TIME))))
12611268 then throw("too often")
12621269 else if (assert((_futureTime >= (blockTimestamp + MIN_RAMP_TIME))))
12631270 then throw("insufficient time")
12641271 else {
12651272 let _initial_A = _A()
12661273 if (assert(if ((_futureA > 0))
12671274 then (MAX_A > _futureA)
12681275 else false))
12691276 then throw("out of base range")
12701277 else if (assert(if (if ((_futureA >= _initial_A))
12711278 then ((_initial_A * MAX_A_CHANGE) >= _futureA)
12721279 else false)
12731280 then true
12741281 else if ((_initial_A > _futureA))
12751282 then ((_futureA * MAX_A_CHANGE) >= _initial_A)
12761283 else false))
12771284 then throw("out of range")
12781285 else [IntegerEntry("initial_A", _initial_A), IntegerEntry("future_A", _futureA), IntegerEntry("initial_A_time", blockTimestamp), IntegerEntry("future_A_time", _futureTime)]
12791286 }))
12801287
12811288
12821289
12831290 @Callable(msg)
12841291 func stopRampA () = valueOrElse(isActive(), valueOrElse(isAdminCall(msg), {
12851292 let currentA = _A()
12861293 [IntegerEntry("initial_A", currentA), IntegerEntry("future_A", currentA), IntegerEntry("initial_A_time", blockTimestamp), IntegerEntry("future_A_time", blockTimestamp)]
12871294 }))
12881295
12891296
12901297
12911298 @Callable(msg)
12921299 func shutdown () = valueOrElse(isAdminCall(msg), if (!(active))
12931300 then throw(("DApp is already suspended. Cause: " + valueOrElse(getString(this, kCause), "the cause wasn't specified")))
12941301 else suspend("Paused by admin"))
12951302
12961303
12971304
12981305 @Callable(msg)
12991306 func activate () = valueOrElse(isAdminCall(msg), if (active)
13001307 then throwIsActive()
13011308 else [BooleanEntry(kActive, true), DeleteEntry(kCause)])
13021309
13031310
13041311
13051312 @Callable(msg)
13061313 func takeIntoAccountExtraFunds () = valueOrElse(isActive(), if ((msg.caller != moneyBoxAddress))
13071314 then throw("Only the wallet can call this function")
13081315 else {
13091316 let balances = _xp()
13101317 func takeExtraFunds (acc,assetId) = {
1311- let $t03178131799 = acc
1312- let sum = $t03178131799._1
1313- let i = $t03178131799._2
1318+ let $t03188331901 = acc
1319+ let sum = $t03188331901._1
1320+ let i = $t03188331901._2
13141321 let tokenB58 = fromBase58String(assetId)
13151322 let rBalance = (assetBalance(this, tokenB58) + stakedAmount(tokenB58))
13161323 let enrollAmount = (rBalance - balances[i])
13171324 if ((0 > enrollAmount))
13181325 then suspend(("Enroll amount negative for asset" + assetId))
13191326 else {
13201327 let airdrop = if ((enrollAmount > 0))
13211328 then invoke(lpFarmingAddress, "airDrop", nil, [AttachedPayment(tokenB58, enrollAmount)])
13221329 else 0
13231330 if ((airdrop == airdrop))
13241331 then $Tuple2((sum + enrollAmount), (i + 1))
13251332 else throw("Strict value is not equal to itself.")
13261333 }
13271334 }
13281335
13291336 let k = {
13301337 let $l = assetIds
13311338 let $s = size($l)
13321339 let $acc0 = $Tuple2(0, 0)
13331340 func $f0_1 ($a,$i) = if (($i >= $s))
13341341 then $a
13351342 else takeExtraFunds($a, $l[$i])
13361343
13371344 func $f0_2 ($a,$i) = if (($i >= $s))
13381345 then $a
1339- else throw("List size exceeds 15")
1346+ else throw("List size exceeds 10")
13401347
1341- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
1348+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
13421349 }
13431350 if ((k._1 == 0))
13441351 then throw("No money to take")
13451352 else nil
13461353 })
13471354
13481355
13491356 @Verifier(tx)
13501357 func verify () = {
13511358 let multiSignedByAdmins = {
13521359 let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1))
13531360 then 1
13541361 else 0
13551362 let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2))
13561363 then 1
13571364 else 0
13581365 let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3))
13591366 then 1
13601367 else 0
13611368 (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2)
13621369 }
13631370 match tx {
13641371 case inv: InvokeScriptTransaction =>
13651372 let callTakeIntoAccount = if ((inv.dApp == this))
13661373 then (inv.function == "takeIntoAccountExtraFunds")
13671374 else false
13681375 let signedByAdmin = if (if (if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1))
13691376 then true
13701377 else sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey2))
13711378 then true
13721379 else sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey3))
13731380 then true
13741381 else sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKeyInvoke)
13751382 if (if (callTakeIntoAccount)
13761383 then signedByAdmin
13771384 else false)
13781385 then true
13791386 else multiSignedByAdmins
13801387 case _ =>
13811388 multiSignedByAdmins
13821389 }
13831390 }
13841391

github/deemru/w8io/6500d08 
244.73 ms