2022.07.05 18:59 [3192173] smart account 3PAZv9tgK1PX7dKR7b4kchq5qdpUS3G5sYT > SELF 0.00000000 Waves
{ "type": 13, "id": "Hcs5oNEScBSToHQcibFzsRD2AtkhfRK5wzWGmpFWMrww", "fee": 2300000, "feeAssetId": null, "timestamp": 1657036631087, "version": 1, "sender": "3PAZv9tgK1PX7dKR7b4kchq5qdpUS3G5sYT", "senderPublicKey": "2cFG5wZimjVSeCT8ZCRybx7Mzo5tJF879aw2b31uLRmR", "proofs": [ "3cDwpekDwTJo47QdVEY85gJ9RVsyFEpJTVtQ1dEJ9mzb73ib7PorMYgLQsV1ftuJHuPNQQALh1NEXiu9ctXfgfAs" ], "script": "base64:BgKBAQgCEgMKAQgSBAoCCAQSBQoDCAQIEgMKAQgSBAoCCAESABIAEgASBAoCCAESBAoCCAESAwoBCBIECgIIARIDCgEIEgQKAggBEgQKAggBEgQKAggBEgQKAgEEEgUKAwgBBBIECgIEBBIDCgEIEgQKAgEEEgASBAoCCAQSABIECgIIATgAC2ZhY3RvcnNCYXNlAOgHAQNmQ2kDBXZhbHVlCW51bWVyYXRvcgtkZW5vbWluYXRvcgQEY2FuZAkAawMFBXZhbHVlBQludW1lcmF0b3IFC2Rlbm9taW5hdG9yBAFEALPmk6gLBAVleGFjdAkAAAIJAGoCCQBoAgkAagIFBGNhbmQFAUQJAGoCBQtkZW5vbWluYXRvcgUBRAUBRAkAagIJAGgCCQBqAgUFdmFsdWUFAUQJAGoCBQludW1lcmF0b3IFAUQFAUQDBQVleGFjdAUEY2FuZAkAZAIFBGNhbmQAAQEMYXNzZXRTdHJUb0lkAQdhc3NldElkAwkAAAIFB2Fzc2V0SWQCBVdBVkVTBQR1bml0CQDZBAEFB2Fzc2V0SWQBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQEFYXNJbnQBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgNJbnQEA2ludAUHJG1hdGNoMAUDaW50CQACAQIDbToxAQZhc0ludDMBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAg8oSW50LCBJbnQsIEludCkEAXgFByRtYXRjaDAFAXgEAXQFByRtYXRjaDAJAAIBAgEyARFhc1VzZXJCYWxhbmNlRGF0YQEFdmFsdWUEByRtYXRjaDAFBXZhbHVlAwkAAQIFByRtYXRjaDACIihJbnQsIEludCwgSW50LCBJbnQsIEludCwgQm9vbGVhbikEAXgFByRtYXRjaDAFAXgEAXQFByRtYXRjaDAJAAIBAgEzAAtjb25maWdTdG9yZQIGY29uZmlnAA1yZXNlcnZlc1N0b3JlAghyZXNlcnZlcwAFYVRJZFMCCGFUb2tlbklkAARhSWRTAgdhc3NldElkAA1jb25maWdBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQtjb25maWdTdG9yZQAGbG9ja2VyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCCWxwX2xvY2tlcgIebm8gbHBfbG9ja2VyIGFkZHJlc3MgaW4gY29uZmlnAh9iYWQgbHBfbG9ja2VyIGFkZHJlc3MgaW4gY29uZmlnAAtyZXNlcnZlc1N0cgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCEHByaW1hcnlfcmVzZXJ2ZXMCFm5vIHJlc2VydmVzIHJlZ2lzdGVyZWQACHJlc2VydmVzCQC8CQIFC3Jlc2VydmVzU3RyAgF8AANlYlIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAgplYl9yZXdhcmRzAg1ubyBlYl9yZXdhcmRzAAt2aXJlc01pbnRlcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAgx2aXJlc19taW50ZXICFG1haW46IG5vIHZpcmVzTWludGVyAgpiYWQgbWludGVyAAdtYXliZXZTCQCdCAIFDWNvbmZpZ0FkZHJlc3MCDHZpcmVzX3N0YWtlcgACdlMJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgUHbWF5YmV2UwIPbm8gdmlyZXNfc3Rha2VyAAJkQwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhJkaXZpZGVuZHNfY29udHJhY3QCFW5vIGRpdmlkZW5kc19jb250cmFjdAIHYmFkIGRpdgADbVZEBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCEXZpcmVzX2Rpc3RyaWJ1dG9yAwkAAQIFByRtYXRjaDACBlN0cmluZwQBZAUHJG1hdGNoMAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBZAUEdW5pdAACVkQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgUDbVZEAghubyBkaXN0cgAHbGltaXRlcgQHJG1hdGNoMAkAnQgCBQ1jb25maWdBZGRyZXNzAgdsaW1pdGVyAwkAAQIFByRtYXRjaDACBlN0cmluZwQBZAUHJG1hdGNoMAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBZAUEdW5pdAARbWF5YmVWaXJlc0Fzc2V0SWQJAJ0IAgULdmlyZXNNaW50ZXIFBGFJZFMADHZpcmVzQXNzZXRJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgURbWF5YmVWaXJlc0Fzc2V0SWQCC25vIHZpcmVzIGlkAhBpbnZhbGlkIHZpcmVzIGlkAQx2aXJlc1BheW1lbnQBAWkDCQAAAgkAkAMBCAUBaQhwYXltZW50cwAAAAADCQECIT0CCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFDHZpcmVzQXNzZXRJZAkAAgECCW5vdCB2aXJlcwgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQBEGFzc2V0SWRPZlJlc2VydmUBA3JzcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFA3JzcgUEYUlkUwIRbm8gYXNzZXRJZCBpbiByc3IBEGNvbGxhdGVyYWxGYWN0b3IBA3JzcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MJAKwCAgkBEGFzc2V0SWRPZlJlc2VydmUBBQNyc3ICEV9Db2xsYXRlcmFsRmFjdG9yAgRubyAxARRsaXF1aWRhdGlvblRocmVzaG9sZAEDcnNyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwkArAICCQEQYXNzZXRJZE9mUmVzZXJ2ZQEFA3JzcgIVX0xpcXVpZGF0aW9uVGhyZXNob2xkAgRubyAyABZhY2NvdW50SGVhbHRoVGhyZXNob2xkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIYYWNjb3VudF9oZWFsdGhfdGhyZXNob2xkAgRubyA0ABRhY2NvdW50SGVhbHRoT3ZlcmxhcAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCFmFjY291bnRfaGVhbHRoX292ZXJsYXACBG5vIDUAC2xpcXVpZGF0b3JzCQELdmFsdWVPckVsc2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCC2xpcXVpZGF0b3JzAgABCXJlc2VydmVCeQIFc3RvcmUFdmFsdWUKAQRmb2xkAgFhAXIEByRtYXRjaDAFAWEDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQFZm91bmQFByRtYXRjaDAFBWZvdW5kBANyc3IJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQFyAg9yc3IgYmFkIGFkZHJlc3MDCQAAAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFA3JzcgUFc3RvcmUJAKwCAgILcnNyIGhhcyBubyAFBXN0b3JlBQV2YWx1ZQUDcnNyBQR1bml0BAckbWF0Y2gwCgACJGwFCHJlc2VydmVzCgACJHMJAJADAQUCJGwKAAUkYWNjMAUEdW5pdAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEEZm9sZAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMjAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEBWZvdW5kBQckbWF0Y2gwBQVmb3VuZAkAAgEJAKwCAgIIdW5rbm93biAFBXN0b3JlAQN2bFIBAXIDCQEIY29udGFpbnMCBQtyZXNlcnZlc1N0cgUBcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEFAXICDW1haW46IGJhZCByc3IJAAIBCQCsAgICDHVua25vd24gcnNyOgUBcgELdXNlckJhbGFuY2UCA3JzcgR1c2VyCQERYXNVc2VyQmFsYW5jZURhdGEBCQD8BwQFA3JzcgILdXNlckJhbGFuY2UJAMwIAgUEdXNlcgUDbmlsBQNuaWwADm1heWJlUHJvdGVjdGVkBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCEXByb3RlY3RlZF9yZXNlcnZlAwkAAQIFByRtYXRjaDACBlN0cmluZwQDcGRzBQckbWF0Y2gwCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUDcGRzAg1iYWQgcHJvdGVjdGVkBQR1bml0ABBwcm90ZWN0ZWRSZXNlcnZlCQETdmFsdWVPckVycm9yTWVzc2FnZQIFDm1heWJlUHJvdGVjdGVkAhBubyBwcm90ZWN0ZWQgcnNyABxwcm9oaWJpdGVkQ29sbGF0ZXJhbFJlc2VydmVzBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCHHByb2hpYml0ZWRDb2xsYXRlcmFsUmVzZXJ2ZXMDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwCQC1CQIFAXMCAXwFA25pbAEdZW5zdXJlTm9Qcm9oaWJpdGVkQ29sbGF0ZXJhbHMBBHVzZXIKAQhmb2xkRnVuYwIBYRFwcm9oaWJpdGVkUmVzZXJ2ZQQDYXRiCQELdmFsdWVPckVsc2UCCQCaCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFEXByb2hpYml0ZWRSZXNlcnZlCQCsAgIFBHVzZXICDl9hVG9rZW5CYWxhbmNlAAADCQBmAgUDYXRiAAAJAAIBCQCsAgIJAKwCAgkArAICCQCsAgICJm9wZXJhdGlvbiBkZW5pZWQ6IHVzZXIgaGFzIGRlcG9zaXQgaW4gBRFwcm9oaWJpdGVkUmVzZXJ2ZQICOiAJAKQDAQUDYXRiAgsobHAgdG9rZW5zKQYKAAIkbAUccHJvaGliaXRlZENvbGxhdGVyYWxSZXNlcnZlcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAGCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQhmb2xkRnVuYwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTUJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8BEmVuc3VyZU5vUHJvaGliaXRlZAMEdXNlcgNicHUHcmVzZXJ2ZQMDCQAAAgUDYnB1AAAGCQEJaXNEZWZpbmVkAQkAzwgCBRxwcm9oaWJpdGVkQ29sbGF0ZXJhbFJlc2VydmVzBQdyZXNlcnZlBgkBHWVuc3VyZU5vUHJvaGliaXRlZENvbGxhdGVyYWxzAQUEdXNlcgERZW5zdXJlTm9Qcm90ZWN0ZWQBBHVzZXIEA2hhcwQHJG1hdGNoMAUObWF5YmVQcm90ZWN0ZWQDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQCcGEFByRtYXRjaDAJAQt2YWx1ZU9yRWxzZQIJAJsIAgUCcGEJAKwCAgIVcHJvdGVjdGVkX2NvbGxhdGVyYWxfBQR1c2VyBwcDBQNoYXMJAAIBAgpkaXNhbGxvd2VkBQR1bml0AQtlbnN1cmVMaW1pdAQGYWN0aW9uA3JzcgR1c2VyBmFtb3VudAQHJG1hdGNoMAUHbGltaXRlcgMJAAECBQckbWF0Y2gwAgdBZGRyZXNzBAFsBQckbWF0Y2gwCQEFYXNJbnQBCQD8BwQFAWwCDXZhbGlkYXRlTGltaXQJAMwIAgUGYWN0aW9uCQDMCAIJAKUIAQUDcnNyCQDMCAIFBHVzZXIJAMwIAgUGYW1vdW50BQNuaWwFA25pbAYBCXVzZXJQb3dlcgEEdXNlcgQQcHJvdGVjdGVkRGVwb3NpdAQHJG1hdGNoMAUObWF5YmVQcm90ZWN0ZWQDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQCcGEFByRtYXRjaDAJAQVhc0ludAEJAPwHBAUCcGECC2JvcnJvd1Bvd2VyCQDMCAIFBHVzZXIFA25pbAUDbmlsAAAKAQRmb2xkAgZ0b3RhbHMBcgQLJHQwODc5NTg4NDEFBnRvdGFscwQGdG90YWxECAULJHQwODc5NTg4NDECXzEEBnRvdGFsQggFCyR0MDg3OTU4ODQxAl8yBA9udW1iZXJPZkJvcnJvd3MIBQskdDA4Nzk1ODg0MQJfMwQDcnNyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUBcgIPcnNyIGJhZCBhZGRyZXNzBAJjZgkBEGNvbGxhdGVyYWxGYWN0b3IBBQNyc3IEAmx0CQEUbGlxdWlkYXRpb25UaHJlc2hvbGQBBQNyc3IECyR0MDg5OTU5MDc5CQELdXNlckJhbGFuY2UCBQNyc3IFBHVzZXIEBXRva2VuCAULJHQwODk5NTkwNzkCXzEEBWFzc2V0CAULJHQwODk5NTkwNzkCXzIECmRlcG9zaXRVc2QIBQskdDA4OTk1OTA3OQJfMwQEZGVidAgFCyR0MDg5OTU5MDc5Al80BAdkZWJ0VXNkCAULJHQwODk5NTkwNzkCXzUEDGFzQ29sbGF0ZXJhbAgFCyR0MDg5OTU5MDc5Al82BAx0b3RhbEJvcnJvd3MJAGQCBQ9udW1iZXJPZkJvcnJvd3MDCQBmAgUEZGVidAAAAAEAAAQTZWZmZWN0aXZlRGVwb3NpdFVzZAMFDGFzQ29sbGF0ZXJhbAUKZGVwb3NpdFVzZAAABApvdmVybGFwVXNkCQCXAwEJAMwIAgUHZGVidFVzZAkAzAgCBRNlZmZlY3RpdmVEZXBvc2l0VXNkBQNuaWwEDW92ZXJsYXBDaGFyZ2UJAQNmQ2kDBQpvdmVybGFwVXNkBRRhY2NvdW50SGVhbHRoT3ZlcmxhcAULZmFjdG9yc0Jhc2UDCQBmAgUHZGVidFVzZAUTZWZmZWN0aXZlRGVwb3NpdFVzZAkAlQoDBQZ0b3RhbEQJAGQCCQBkAgUGdG90YWxCCQBrAwkAZQIFB2RlYnRVc2QFE2VmZmVjdGl2ZURlcG9zaXRVc2QFC2ZhY3RvcnNCYXNlBQJsdAUNb3ZlcmxhcENoYXJnZQUMdG90YWxCb3Jyb3dzCQCVCgMJAGQCBQZ0b3RhbEQJAGsDCQBlAgUTZWZmZWN0aXZlRGVwb3NpdFVzZAUHZGVidFVzZAUCY2YFC2ZhY3RvcnNCYXNlCQBkAgUGdG90YWxCBQ1vdmVybGFwQ2hhcmdlBQx0b3RhbEJvcnJvd3MEAXIKAAIkbAUIcmVzZXJ2ZXMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCVCgMFEHByb3RlY3RlZERlcG9zaXQAAAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQRmb2xkAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAyMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQDAwkAZgIFEHByb3RlY3RlZERlcG9zaXQAAAkAZgIIBQFyAl8zAAIHCQACAQIeY2FuJ3QgaGF2ZSBtb3JlIHRoYW4gMiBib3Jyb3dzBQFyAQ1nZXRVc2VySGVhbHRoAQdhY2NvdW50BAskdDA5ODM0OTg4NQkBBmFzSW50MwEJAQl1c2VyUG93ZXIBBQdhY2NvdW50BAJicAgFCyR0MDk4MzQ5ODg1Al8xBANicHUIBQskdDA5ODM0OTg4NQJfMgQGaWdub3JlCAULJHQwOTgzNDk4ODUCXzMJAKwCAgkArAICCQCsAgICA2JwOgkApAMBBQJicAIGLCBicHU6CQCkAwEFA2JwdQENdmFsaWRhdGVBZnRlcgIEdXNlcgJvcAQMJHQwOTk5NzEwMDI4CQEJdXNlclBvd2VyAQUEdXNlcgQCYnAIBQwkdDA5OTk3MTAwMjgCXzEEA2JwdQgFDCR0MDk5OTcxMDAyOAJfMgQJYWNjSGVhbHRoCQBpAgkAaAIJAGUCBQJicAUDYnB1BQtmYWN0b3JzQmFzZQUCYnADAwkAAAIFAmJwAAAJAAACBQNicHUAAAcAAAMDCQAAAgUCYnAAAAkAZgIFA2JwdQAABwkAAgEJAKwCAgkArAICBQJvcAIsOiBicmVhY2hpbmcgbGlxdWlkYXRpb24gdGhyZXNob2xkKGJwPTAsIGJwdT0JAKQDAQUDYnB1AwkAZgIFFmFjY291bnRIZWFsdGhUaHJlc2hvbGQFCWFjY0hlYWx0aAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUCb3ACJTogYnJlYWNoaW5nIGxpcXVpZGF0aW9uIHRocmVzaG9sZChicD0JAKQDAQUCYnACBiwgYnB1PQkApAMBBQNicHUCCSwgaGVhbHRoPQkApAMBBQlhY2NIZWFsdGgCASkFA2JwdQECdVMFA3JzcgZhY3Rpb24EdXNlcgp1c2VyQ2hhbmdlDHN0cmVhbUNoYW5nZQQHJG1hdGNoMAUDbVZEAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEAWEFByRtYXRjaDAJAPwHBAUBYQIIb25BY3Rpb24JAMwIAgUDcnNyCQDMCAIFBmFjdGlvbgkAzAgCBQR1c2VyCQDMCAIFCnVzZXJDaGFuZ2UJAMwIAgUMc3RyZWFtQ2hhbmdlBQNuaWwFA25pbAUEdW5pdAEKbW92ZVN0cmVhbQUDcnNyBmFjdGlvbgRmcm9tBnN0cmluZwNhbXQEByRtYXRjaDAFA21WRAMJAAECBQckbWF0Y2gwAgdBZGRyZXNzBAFhBQckbWF0Y2gwCQD8BwQFAWECBG1vdmUJAMwIAgUDcnNyCQDMCAIFBmFjdGlvbgkAzAgCBQRmcm9tCQDMCAIFBnN0cmluZwkAzAgCBQNhbXQFA25pbAUDbmlsBQR1bml0AQJzUgEDcnNyBAckbWF0Y2gwBQNtVkQDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQBYQUHJG1hdGNoMAkA/AcEBQFhAgpzeW5jSGVpZ2h0CQDMCAIFA3JzcgUDbmlsBQNuaWwFBHVuaXQBDGxvY2tPclBheW91dAMJcmVjaXBpZW50A2FtdARsb2NrAwkBASEBBQRsb2NrCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFCXJlY2lwaWVudAUDYW10BQx2aXJlc0Fzc2V0SWQFA25pbAQGZG9Mb2NrCQD8BwQFAmRDAgdsb2NrRm9yCQDMCAIJAKUIAQUJcmVjaXBpZW50CQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQx2aXJlc0Fzc2V0SWQFA2FtdAUDbmlsAwkAAAIFBmRvTG9jawUGZG9Mb2NrBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BCWRvRGVwb3NpdAMBaQNyc3IFYXNDb2wEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAZjaGVja3MJARFlbnN1cmVOb1Byb3RlY3RlZAEFBHVzZXIDCQAAAgUGY2hlY2tzBQZjaGVja3MEAnNoCQECc1IBBQNyc3IDCQAAAgUCc2gFAnNoBAZhY3Rpb24JAPwHBAkBA3ZsUgEFA3JzcgIKZGVwb3NpdEZvcgkAzAgCBQR1c2VyCQDMCAIFBWFzQ29sBQNuaWwIBQFpCHBheW1lbnRzAwkAAAIFBmFjdGlvbgUGYWN0aW9uBANhbXQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BANwUncJAQJ1UwUFA3JzcgIHZGVwb3NpdAUEdXNlcgUDYW10BQNhbXQDCQAAAgUDcFJ3BQNwUncEAnZhAwkBASEBBQVhc0NvbAkBDXZhbGlkYXRlQWZ0ZXICBQR1c2VyAgpkZXBvc2l0aW5nAAADCQAAAgUCdmEFAnZhBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4ADnJld2FyZFJlc2VydmVzCQC8CQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhNyZXdhcmRhYmxlX3Jlc2VydmVzAglubyBzdHJpbmcCAXwBFmNsYWltQWxsUmV3YXJkc0ZvclVzZXIBBHVzZXIECWNsYWltZWRFYgkBBWFzSW50AQkA/AcEBQNlYlICEGNsYWltRWJSZXdhcmRGb3IJAMwIAgUEdXNlcgkAzAgCAP///////////wEFA25pbAUDbmlsAwkAAAIFCWNsYWltZWRFYgUJY2xhaW1lZEViCgEEZm9sZAIDYWNjA3JzcgQHY2xhaW1lZAkBBWFzSW50AQkA/AcEBQJWRAIOY2xhaW1SZXdhcmRGb3IJAMwIAgUDcnNyCQDMCAIFBHVzZXIJAMwIAgD///////////8BBQNuaWwFA25pbAMJAAACBQdjbGFpbWVkBQdjbGFpbWVkCQBkAgUDYWNjBQdjbGFpbWVkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBAxjbGFpbWVkVG90YWwKAAIkbAUOcmV3YXJkUmVzZXJ2ZXMKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBBGZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAkAZAIFDGNsYWltZWRUb3RhbAUJY2xhaW1lZEViCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARhjbGFpbUFsbExwUmV3YXJkc0ZvclVzZXIBBHVzZXIKAQRmb2xkAgNhY2MDcnNyBAhhVG9rZW5JZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFA3JzcgUFYVRJZFMCFm5vIGFUb2tlbklkIGluIHJlc2VydmUEB2NsYWltZWQJAQVhc0ludAEJAPwHBAUGbG9ja2VyAhBjbGFpbUxwUmV3YXJkRm9yCQDMCAIFBHVzZXIJAMwIAgUIYVRva2VuSWQJAMwIAgD///////////8BBQNuaWwFA25pbAMJAAACBQdjbGFpbWVkBQdjbGFpbWVkCQBkAgUDYWNjBQdjbGFpbWVkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBAxjbGFpbWVkVG90YWwKAAIkbAUOcmV3YXJkUmVzZXJ2ZXMKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBBGZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAUMY2xhaW1lZFRvdGFsAQ5tb3ZlQ29sbGF0ZXJhbAQEYWRkcghhc3NldFN0cgNyc3IKcmVzZXJ2ZVN0cgQDYW10CQEFYXNJbnQBCQD8BwQFEHByb3RlY3RlZFJlc2VydmUCDndpdGhkcmF3VG9NYWluCQDMCAIFBGFkZHIJAMwIAgUIYXNzZXRTdHIFA25pbAUDbmlsAwkAAAIFA2FtdAUDYW10BAdhc3NldElkAwkAAAIFCGFzc2V0U3RyAgVXQVZFUwUEdW5pdAkA2QQBBQhhc3NldFN0cgQDZGVwCQD8BwQFA3JzcgIKZGVwb3NpdEZvcgkAzAgCBQRhZGRyCQDMCAIGBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFB2Fzc2V0SWQFA2FtdAUDbmlsAwkAAAIFA2RlcAUDZGVwBARwcm9wCQECdVMFBQpyZXNlcnZlU3RyAgdkZXBvc2l0BQRhZGRyBQNhbXQFA2FtdAMJAAACBQRwcm9wBQRwcm9wBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQRzcGZyAAkA/AcEBQJkQwIXc2hhcmVQcm9maXRGcm9tUmVzZXJ2ZXMFA25pbAUDbmlsAQp3ZEludGVybmFsBAR1c2VyA3JzcgNhbXQCb3AEAnNoCQECc1IBCQClCAEFA3JzcgMJAAACBQJzaAUCc2gED3dpdGhkcmF3bkFtb3VudAkBBWFzSW50AQkA/AcEBQNyc3IFAm9wCQDMCAIFBHVzZXIJAMwIAgUDYW10BQNuaWwFA25pbAMJAAACBQ93aXRoZHJhd25BbW91bnQFD3dpdGhkcmF3bkFtb3VudAQDcFJ3CQECdVMFCQClCAEFA3JzcgIHZGVwb3NpdAUEdXNlcgkBAS0BBQ93aXRoZHJhd25BbW91bnQJAQEtAQUPd2l0aGRyYXduQW1vdW50AwkAAAIFA3BSdwUDcFJ3BAFlCQELZW5zdXJlTGltaXQEAgh3aXRoZHJhdwUDcnNyBQR1c2VyBQ93aXRoZHJhd25BbW91bnQDCQAAAgUBZQUBZQUPd2l0aGRyYXduQW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuGQFpAQppbml0aWFsaXplAQJjYQkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwIFC2NvbmZpZ1N0b3JlBQJjYQUDbmlsAWkBB2RlcG9zaXQCA3JzcgVhc0NvbAkBCWRvRGVwb3NpdAMFAWkFA3JzcgUFYXNDb2wBaQEKZGVwb3NpdFJlZgMDcnNyBWFzQ29sA3JlZgkBCWRvRGVwb3NpdAMFAWkFA3JzcgUFYXNDb2wBaQEFcmVwYXkBA3JzcgQEdXNlcgkApQgBCAUBaQZjYWxsZXIEAnNoCQECc1IBBQNyc3IDCQAAAgUCc2gFAnNoBAZyZXBhaWQJAQVhc0ludAEJAPwHBAkBA3ZsUgEFA3JzcgIIcmVwYXlGb3IJAMwIAgUEdXNlcgUDbmlsCAUBaQhwYXltZW50cwMJAAACBQZyZXBhaWQFBnJlcGFpZAQDcFJ3CQECdVMFBQNyc3ICBmJvcnJvdwUEdXNlcgkBAS0BBQZyZXBhaWQJAQEtAQUGcmVwYWlkAwkAAAIFA3BSdwUDcFJ3BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKbWludEF0b2tlbgIIYVRva2VuSWQDYW10BAR1c2VyCQClCAEIBQFpBmNhbGxlcgQBdAkBCXJlc2VydmVCeQIFBWFUSWRTBQhhVG9rZW5JZAQCc2gJAQJzUgEJAKUIAQUBdAMJAAACBQJzaAUCc2gEBmFjdHVhbAkBBWFzSW50AQkA/AcEBQF0Ag1taW50QXRva2VuRm9yCQDMCAIFBHVzZXIJAMwIAgUDYW10BQNuaWwFA25pbAMJAAACBQZhY3R1YWwFBmFjdHVhbAQDcFJ3CQECdVMFCQClCAEFAXQCB2RlcG9zaXQFBHVzZXIJAQEtAQUGYWN0dWFsAAADCQAAAgUDcFJ3BQNwUncEA2JwdQkBBWFzSW50AQkBDXZhbGlkYXRlQWZ0ZXICBQR1c2VyAgdtaW50aW5nAwkAAAIFA2JwdQUDYnB1BAJwYwkBEmVuc3VyZU5vUHJvaGliaXRlZAMFBHVzZXIFA2JwdQkApQgBBQF0AwkAAAIFAnBjBQJwYwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBE3JlcGxlbmlzaFdpdGhBdG9rZW4ABAR1c2VyCQClCAEIBQFpBmNhbGxlcgQGY2hlY2tzCQERZW5zdXJlTm9Qcm90ZWN0ZWQBBQR1c2VyAwkAAAIFBmNoZWNrcwUGY2hlY2tzBAhhVG9rZW5JZAkA2AQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAIOYmFkIGFzc2V0SWQodykEA3JzcgkBCXJlc2VydmVCeQIFBWFUSWRTBQhhVG9rZW5JZAQCc2gJAQJzUgEJAKUIAQUDcnNyAwkAAAIFAnNoBQJzaAQDYW10CQEFYXNJbnQBCQD8BwQFA3JzcgIWcmVwbGVuaXNoV2l0aEF0b2tlbkZvcgkAzAgCBQR1c2VyBQNuaWwIBQFpCHBheW1lbnRzAwkAAAIFA2FtdAUDYW10BANwUncJAQJ1UwUJAKUIAQUDcnNyAgdkZXBvc2l0BQR1c2VyBQNhbXQAAAMJAAACBQNwUncFA3BSdwQBZQkBC2Vuc3VyZUxpbWl0BAIGaW1wb3J0BQNyc3IFBHVzZXIFA2FtdAMJAAACBQFlBQFlBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEPcmVwYXlXaXRoQXRva2VuAAQEdXNlcgkApQgBCAUBaQZjYWxsZXIECGFUb2tlbklkCQDYBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkAh5iYWQgYXNzZXRJZDogd2F2ZXMgbm90IGFsbG93ZWQEAXQJAQlyZXNlcnZlQnkCBQVhVElkUwUIYVRva2VuSWQEAnNoCQECc1IBCQClCAEFAXQDCQAAAgUCc2gFAnNoBANhbXQJAQVhc0ludAEJAPwHBAUBdAIecmVwbGVuaXNoRm9yUmVwYXlXaXRoQXRva2VuRm9yCQDMCAIFBHVzZXIFA25pbAgFAWkIcGF5bWVudHMDCQAAAgUDYW10BQNhbXQEAWMJAQVhc0ludAEJAPwHBAUBdAIRY29sbGFwc2VGb3JBbW91bnQJAMwIAgUEdXNlcgkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFAWMFAWMDCQBmAgUDYW10BQFjCQACAQIRcmVwYXlpbmcgdG9vIG11Y2gEA3BSdwkBAnVTBQkApQgBBQF0AgZib3Jyb3cFBHVzZXIJAQEtAQUBYwkBAS0BBQFjAwkAAAIFA3BSdwUDcFJ3BARwUncyCQECdVMFCQClCAEFAXQCB2RlcG9zaXQFBHVzZXIJAGUCBQNhbXQFAWMJAQEtAQUBYwMJAAACBQRwUncyBQRwUncyBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQENcmVkZWVtQXRva2VucwAEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAhhVG9rZW5JZAkA2AQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAISYmFkIGFzc2V0SWQ6IFdBVkVTBANyc3IJAQlyZXNlcnZlQnkCBQVhVElkUwUIYVRva2VuSWQEAnNoCQECc1IBCQClCAEFA3JzcgMJAAACBQJzaAUCc2gEA2FtdAkBBWFzSW50AQkA/AcEBQNyc3ICEHJlZGVlbUF0b2tlbnNGb3IJAMwIAgUEdXNlcgUDbmlsCAUBaQhwYXltZW50cwMJAAACBQNhbXQFA2FtdAQDcFJ3CQECdVMFCQClCAEFA3JzcgIHZGVwb3NpdAUEdXNlcgAACQEBLQEFA2FtdAMJAAACBQNwUncFA3BSdwQBZQkBC2Vuc3VyZUxpbWl0BAIGcmVkZWVtBQNyc3IFBHVzZXIFA2FtdAMJAAACBQFlBQFlBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEId2l0aGRyYXcCB2Fzc2V0SWQDYW10BAR1c2VyCQClCAEIBQFpBmNhbGxlcgQBcgkBCXJlc2VydmVCeQIFBGFJZFMFB2Fzc2V0SWQEBnJlc3VsdAkBBWFzSW50AQkBCndkSW50ZXJuYWwEBQR1c2VyBQFyBQNhbXQCC3dpdGhkcmF3Rm9yAwkAAAIFBnJlc3VsdAUGcmVzdWx0BANicHUJAQVhc0ludAEJAQ12YWxpZGF0ZUFmdGVyAgUEdXNlcgILd2l0aGRyYXdpbmcDCQAAAgUDYnB1BQNicHUEAnBjCQESZW5zdXJlTm9Qcm9oaWJpdGVkAwUEdXNlcgUDYnB1CQClCAEFAXIDCQAAAgUCcGMFAnBjCQCUCgIFA25pbAUGcmVzdWx0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCXdpdGhkcmF3MgIDcnNyA2FtdAQEdXNlcgkApQgBCAUBaQZjYWxsZXIEAnNoCQECc1IBBQNyc3IDCQAAAgUCc2gFAnNoBAdyc3JBZGRyCQEDdmxSAQUDcnNyBAZhY3R1YWwJAQVhc0ludAEJAPwHBAUHcnNyQWRkcgILd2l0aGRyYXdGb3IJAMwIAgUEdXNlcgkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFBmFjdHVhbAUGYWN0dWFsBANwUncJAQJ1UwUFA3JzcgIHZGVwb3NpdAUEdXNlcgkBAS0BBQZhY3R1YWwJAQEtAQUGYWN0dWFsAwkAAAIFA3BSdwUDcFJ3BANicHUDCQEIY29udGFpbnMCBQtsaXF1aWRhdG9ycwUEdXNlcgAABAFlCQELZW5zdXJlTGltaXQEAgh3aXRoZHJhdwUHcnNyQWRkcgUEdXNlcgUGYWN0dWFsAwkAAAIFAWUFAWUJAQVhc0ludAEJAQ12YWxpZGF0ZUFmdGVyAgUEdXNlcgIMd2l0aGRyYXdpbmcyCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBAJwYwkBEmVuc3VyZU5vUHJvaGliaXRlZAMFBHVzZXIFA2JwdQUDcnNyAwkAAAIFAnBjBQJwYwkAlAoCBQNuaWwFBmFjdHVhbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARFwcm90ZWN0Q29sbGF0ZXJhbAEDcnNyBAR1c2VyCQClCAEIBQFpBmNhbGxlcgQBcgkBA3ZsUgEFA3JzcgQDYW10CQEFYXNJbnQBCQEKd2RJbnRlcm5hbAQFBHVzZXIFAXIA////////////AQIOd2l0aGRyYXdUb01haW4DCQAAAgUDYW10BQNhbXQEB2Fzc2V0SWQJAQxhc3NldFN0clRvSWQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQFyBQRhSWRTBAFwCQD8BwQFEHByb3RlY3RlZFJlc2VydmUCCXN1cHBseUZvcgkAzAgCBQR1c2VyBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFB2Fzc2V0SWQFA2FtdAUDbmlsAwkAAAIFAXAFAXAEAnBjCQESZW5zdXJlTm9Qcm9oaWJpdGVkAwUEdXNlcggJAQl1c2VyUG93ZXIBBQR1c2VyAl8yBQNyc3IDCQAAAgUCcGMFAnBjCQCUCgIFA25pbAUDYW10CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBG3dpdGhkcmF3UHJvdGVjdGVkQ29sbGF0ZXJhbAIHYXNzZXRJZANhbXQEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAFhCQEFYXNJbnQBCQD8BwQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgUQcHJvdGVjdGVkUmVzZXJ2ZQITbm8gcHJvdGVjdGVkUmVzZXJ2ZQILd2l0aGRyYXdGb3IJAMwIAgUEdXNlcgkAzAgCBQdhc3NldElkCQDMCAIFA2FtdAUDbmlsBQNuaWwDCQAAAgUBYQUBYQQCdmEJAQ12YWxpZGF0ZUFmdGVyAgUEdXNlcgIVd2l0aGRyYXdpbmcgcHJvdGVjdGVkAwkAAAIFAnZhBQJ2YQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBE25vcm1hbGl6ZUNvbGxhdGVyYWwBA3JzcgQEYWRkcgkApQgBCAUBaQZjYWxsZXIEAnJBCQEDdmxSAQUDcnNyAwkAAAIFAnJBBQJyQQQCc2gJAQJzUgEFA3JzcgMJAAACBQJzaAUCc2gECmFzc2V0SWRTdHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQJyQQUEYUlkUwkArAICAhNubyBhc3NldElkIGluIHJzdjogBQNyc3IEAm1jCQEObW92ZUNvbGxhdGVyYWwEBQRhZGRyBQphc3NldElkU3RyBQJyQQUDcnNyAwkAAAIFAm1jBQJtYwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBmJvcnJvdwIHYXNzZXRJZANhbXQEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBANyc3IJAQlyZXNlcnZlQnkCBQRhSWRTBQdhc3NldElkBAJzaAkBAnNSAQkApQgBBQNyc3IDCQAAAgUCc2gFAnNoBAFhCQD8BwQFA3JzcgIJYm9ycm93Rm9yCQDMCAIFBHVzZXIJAMwIAgUDYW10BQNuaWwFA25pbAMJAAACBQFhBQFhBANwUncJAQJ1UwUJAKUIAQUDcnNyAgZib3Jyb3cFBHVzZXIFA2FtdAUDYW10AwkAAAIFA3BSdwUDcFJ3BAFlCQELZW5zdXJlTGltaXQEAgZib3Jyb3cFA3JzcgUEdXNlcgUDYW10AwkAAAIFAWUFAWUEA2JwdQkBBWFzSW50AQkBDXZhbGlkYXRlQWZ0ZXICBQR1c2VyAglib3Jyb3dpbmcDCQAAAgUDYnB1BQNicHUEAnBjCQEdZW5zdXJlTm9Qcm9oaWJpdGVkQ29sbGF0ZXJhbHMBBQR1c2VyAwkAAAIFAnBjBQJwYwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB2JvcnJvdzICA3JzcgNhbXQEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAFyCQEDdmxSAQUDcnNyBAJzaAkBAnNSAQUDcnNyAwkAAAIFAnNoBQJzaAQBYQkA/AcEBQFyAglib3Jyb3dGb3IJAMwIAgUEdXNlcgkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFAWEFAWEEA3BSdwkBAnVTBQUDcnNyAgZib3Jyb3cFBHVzZXIFA2FtdAUDYW10AwkAAAIFA3BSdwUDcFJ3BAFlCQELZW5zdXJlTGltaXQEAgZib3Jyb3cFAXIFBHVzZXIFA2FtdAMJAAACBQFlBQFlBANicHUJAQVhc0ludAEJAQ12YWxpZGF0ZUFmdGVyAgUEdXNlcgIJYm9ycm93aW5nAwkAAAIFA2JwdQUDYnB1BAJwYwkBHWVuc3VyZU5vUHJvaGliaXRlZENvbGxhdGVyYWxzAQUEdXNlcgMJAAACBQJwYwUCcGMFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQhjb2xsYXBzZQIDcnNyA2FtdAQEdXNlcgkApQgBCAUBaQZjYWxsZXIEAnNoCQECc1IBBQNyc3IDCQAAAgUCc2gFAnNoBAFjCQEFYXNJbnQBCQD8BwQJAQN2bFIBBQNyc3ICEWNvbGxhcHNlRm9yQW1vdW50CQDMCAIFBHVzZXIJAMwIAgUDYW10BQNuaWwFA25pbAMJAAACBQFjBQFjBANwUncJAQJ1UwUFA3JzcgIGYm9ycm93BQR1c2VyCQEBLQEFAWMJAQEtAQUBYwMJAAACBQNwUncFA3BSdwQEcFJ3MgkBAnVTBQUDcnNyAgdkZXBvc2l0BQR1c2VyCQEBLQEFAWMJAQEtAQUBYwMJAAACBQRwUncyBQRwUncyBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEOY2xhaW1FYlJld2FyZDICA2FtdARsb2NrBAR1c2VyCQClCAEIBQFpBmNhbGxlcgQBYwkBBWFzSW50AQkA/AcEBQNlYlICEGNsYWltRWJSZXdhcmRGb3IJAMwIAgUEdXNlcgkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFAWMFAWMJAQxsb2NrT3JQYXlvdXQDCAUBaQZjYWxsZXIFAWMFBGxvY2sJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEMY2xhaW1SZXdhcmQyAwNyc3IDYW10BGxvY2sEAXYJAQN2bFIBBQNyc3IDCQAAAgUBdgUBdgQEdXNlcgkApQgBCAUBaQZjYWxsZXIEAWMJAQVhc0ludAEJAPwHBAUCVkQCDmNsYWltUmV3YXJkRm9yCQDMCAIFA3JzcgkAzAgCBQR1c2VyCQDMCAIFA2FtdAUDbmlsBQNuaWwDCQAAAgUBYwUBYwkBDGxvY2tPclBheW91dAMIBQFpBmNhbGxlcgUBYwUEbG9jawkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpASFjbGFpbUFsbFJld2FyZHNBbmRBbGxFYkF2YWlsYWJsZTICBGxvY2sNdW5zdGFrZUxlZ2FjeQQEdXNlcgkApQgBCAUBaQZjYWxsZXIEAmNyCQEWY2xhaW1BbGxSZXdhcmRzRm9yVXNlcgEFBHVzZXIDCQAAAgUCY3IFAmNyBARjckxwCQEYY2xhaW1BbGxMcFJld2FyZHNGb3JVc2VyAQUEdXNlcgMJAAACBQRjckxwBQRjckxwBAJsQQMFDXVuc3Rha2VMZWdhY3kJAQVhc0ludAEJAPwHBAUCdlMCE3Vuc3Rha2VBbGxWaXJlc0Zyb20JAMwIAgUEdXNlcgUDbmlsBQNuaWwAAAMJAAACBQJsQQUCbEEJAQxsb2NrT3JQYXlvdXQDCAUBaQZjYWxsZXIJAGQCCQBkAgUCY3IFBGNyTHAFAmxBBQRsb2NrCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFmRpc2FibGVVc2VBc0NvbGxhdGVyYWwBA3JzcgQEdXNlcgkApQgBCAUBaQZjYWxsZXIEAWQJAPwHBAkBA3ZsUgEFA3JzcgIZZGlzYWJsZVVzZUFzQ29sbGF0ZXJhbEZvcgkAzAgCBQR1c2VyBQNuaWwFA25pbAMJAAACBQFkBQFkBAJ2YQkBDXZhbGlkYXRlQWZ0ZXICBQR1c2VyAhpjaGFuZ2luZyBjb2xsYXRlcmFsIHN0YXR1cwMJAAACBQJ2YQUCdmEFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQlsb2NrVmlyZXMCBmZhY3RvcgdtaWdyYXRlBAR1c2VyCQClCAEIBQFpBmNhbGxlcgQBYQkBBHNwZnIAAwkAAAIFAWEFAWEEDW1pZ3JhdGVBbW91bnQDBQdtaWdyYXRlCQEFYXNJbnQBCQD8BwQFAnZTAhN1bnN0YWtlQWxsVmlyZXNGcm9tCQDMCAIFBHVzZXIFA25pbAUDbmlsAAAEBXRvdGFsCQBkAgUNbWlncmF0ZUFtb3VudAkBDHZpcmVzUGF5bWVudAEFAWkEAWwJAPwHBAUCZEMCB2xvY2tGb3IJAMwIAgUEdXNlcgkAzAgCBQZmYWN0b3IFA25pbAMJAAACBQV0b3RhbAAABQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFDHZpcmVzQXNzZXRJZAUFdG90YWwFA25pbAMJAAACBQFsBQFsBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEYd2l0aGRyYXdBbGxQb3NzaWJsZVZpcmVzAAQEdXNlcgkApQgBCAUBaQZjYWxsZXIEAWEJAQRzcGZyAAMJAAACBQFhBQFhBBFzdGFrZXJWaXJlc0Ftb3VudAkBBWFzSW50AQkA/AcEBQJ2UwITdW5zdGFrZUFsbFZpcmVzRnJvbQkAzAgCBQR1c2VyBQNuaWwFA25pbAMJAAACBRFzdGFrZXJWaXJlc0Ftb3VudAURc3Rha2VyVmlyZXNBbW91bnQEAXUJAPwHBAUCZEMCE3dpdGhkcmF3VW5sb2NrZWRGb3IJAMwIAgUEdXNlcgUDbmlsBQNuaWwDCQAAAgUBdQUBdQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFEXN0YWtlclZpcmVzQW1vdW50BQx2aXJlc0Fzc2V0SWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARdjbGFpbVByb3RvY29sUHJvZml0RnJvbQIEZnJvbQZyZWxvY2sEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAFhCQEEc3BmcgADCQAAAgUBYQUBYQQBdQkA/AcEBQJkQwILY2xhaW1Qcm9maXQJAMwIAgUEZnJvbQkAzAgCBQR1c2VyCQDMCAIFBnJlbG9jawUDbmlsBQNuaWwDCQAAAgUBdQUBdQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFXdpdGhkcmF3VW5sb2NrZWRWaXJlcwAEAWEJAQRzcGZyAAMJAAACBQFhBQFhBAF1CQD8BwQFAmRDAhN3aXRoZHJhd1VubG9ja2VkRm9yCQDMCAIJAKUIAQgFAWkGY2FsbGVyBQNuaWwFA25pbAMJAAACBQF1BQF1BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKbG9ja1N1cHBseQIHcmVzZXJ2ZQZwZXJpb2QEA3JzcgkBA3ZsUgEFB3Jlc2VydmUEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAZjaGVja3MJARFlbnN1cmVOb1Byb3RlY3RlZAEFBHVzZXIDCQAAAgUGY2hlY2tzBQZjaGVja3MECGFUb2tlbklkCQEFdmFsdWUBCQEMYXNzZXRTdHJUb0lkAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFA3JzcgIIYVRva2VuSWQCFm5vIGFUb2tlbklkIGluIHJlc2VydmUECW1pZ3JhdGlvbgMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAAFBHVuaXQDCQAAAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQhhVG9rZW5JZAUEdW5pdAMJAAACCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQJAQxhc3NldFN0clRvSWQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUDcnNyAgdhc3NldElkAhVubyBhc3NldElkIGluIHJlc2VydmUEAnNoCQECc1IBBQdyZXNlcnZlAwkAAAIFAnNoBQJzaAQGYWN0aW9uCQD8BwQFA3JzcgIKZGVwb3NpdEZvcgkAzAgCBQR1c2VyCQDMCAIGBQNuaWwIBQFpCHBheW1lbnRzAwkAAAIFBmFjdGlvbgUGYWN0aW9uBANhbXQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BANwUncJAQJ1UwUFB3Jlc2VydmUCB2RlcG9zaXQFBHVzZXIFA2FtdAUDYW10AwkAAAIFA3BSdwUDcFJ3BQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQISYmFkIGFzc2V0IGF0dGFjaGVkAwkAAAIFCW1pZ3JhdGlvbgUJbWlncmF0aW9uBARtaW50BAJzaAkBAnNSAQUHcmVzZXJ2ZQMJAAACBQJzaAUCc2gEBmFjdHVhbAkBBWFzSW50AQkA/AcEBQNyc3ICD21pbnRBdG9rZW5Gb3JUbwkAzAgCBQR1c2VyCQDMCAIA////////////AQkAzAgCCQClCAEFBHRoaXMFA25pbAUDbmlsAwkAAAIFBmFjdHVhbAUGYWN0dWFsBANwUncJAQJ1UwUJAKUIAQUDcnNyAgdkZXBvc2l0BQR1c2VyCQEBLQEFBmFjdHVhbAAAAwkAAAIFA3BSdwUDcFJ3BAJ2YQkBDXZhbGlkYXRlQWZ0ZXICBQR1c2VyAgxsb2NrLW1pbnRpbmcDCQAAAgUCdmEFAnZhBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQAAAgUEbWludAUEbWludAQHYmFsYW5jZQkA8AcCBQR0aGlzBQhhVG9rZW5JZAQBcgkA/AcEBQZsb2NrZXICBmxvY2tMUAkAzAgCBQR1c2VyCQDMCAIFBnBlcmlvZAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQhhVG9rZW5JZAUHYmFsYW5jZQUDbmlsAwkAAAIFAXIFAXIJAJQKAgUDbmlsBQdiYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAHfL0ls=", "chainId": 87, "height": 3192173, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: BqiakJKL8mHw7XyCPpd8FQwPShrfEKHY1qgDUNRF3KZC Next: FZniNb4zdWo1D1PGgUXqTsHnkPeXJG7fehrtyDx9UHac Diff:
Old | New | Differences | |
---|---|---|---|
1 | - | {-# STDLIB_VERSION | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let factorsBase = 1000 | |
27 | 27 | case int: Int => | |
28 | 28 | int | |
29 | 29 | case _ => | |
30 | - | throw("1") | |
30 | + | throw("m:1") | |
31 | 31 | } | |
32 | 32 | ||
33 | 33 | ||
61 | 61 | ||
62 | 62 | let reservesStr = valueOrErrorMessage(getString(configAddress, "primary_reserves"), "no reserves registered") | |
63 | 63 | ||
64 | - | let reserves = split(reservesStr, "|") | |
64 | + | let reserves = split_4C(reservesStr, "|") | |
65 | 65 | ||
66 | 66 | let ebR = addressFromStringValue(valueOrErrorMessage(getString(configAddress, "eb_rewards"), "no eb_rewards")) | |
67 | 67 | ||
135 | 135 | ||
136 | 136 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
137 | 137 | then $a | |
138 | - | else throw("List size exceeds | |
138 | + | else throw("List size exceeds 20") | |
139 | 139 | ||
140 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) { | |
140 | + | $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($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), 16), 17), 18), 19), 20) { | |
141 | 141 | case found: Address => | |
142 | 142 | found | |
143 | 143 | case _ => | |
162 | 162 | } | |
163 | 163 | ||
164 | 164 | let protectedReserve = valueOrErrorMessage(maybeProtected, "no protected rsr") | |
165 | + | ||
166 | + | let prohibitedCollateralReserves = match getString(configAddress, "prohibitedCollateralReserves") { | |
167 | + | case s: String => | |
168 | + | split(s, "|") | |
169 | + | case _ => | |
170 | + | nil | |
171 | + | } | |
172 | + | ||
173 | + | func ensureNoProhibitedCollaterals (user) = { | |
174 | + | func foldFunc (a,prohibitedReserve) = { | |
175 | + | let atb = valueOrElse(getInteger(addressFromStringValue(prohibitedReserve), (user + "_aTokenBalance")), 0) | |
176 | + | if ((atb > 0)) | |
177 | + | then throw((((("operation denied: user has deposit in " + prohibitedReserve) + ": ") + toString(atb)) + "(lp tokens)")) | |
178 | + | else true | |
179 | + | } | |
180 | + | ||
181 | + | let $l = prohibitedCollateralReserves | |
182 | + | let $s = size($l) | |
183 | + | let $acc0 = true | |
184 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
185 | + | then $a | |
186 | + | else foldFunc($a, $l[$i]) | |
187 | + | ||
188 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
189 | + | then $a | |
190 | + | else throw("List size exceeds 15") | |
191 | + | ||
192 | + | $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) | |
193 | + | } | |
194 | + | ||
195 | + | ||
196 | + | func ensureNoProhibited (user,bpu,reserve) = if (if ((bpu == 0)) | |
197 | + | then true | |
198 | + | else isDefined(indexOf(prohibitedCollateralReserves, reserve))) | |
199 | + | then true | |
200 | + | else ensureNoProhibitedCollaterals(user) | |
201 | + | ||
165 | 202 | ||
166 | 203 | func ensureNoProtected (user) = { | |
167 | 204 | let has = match maybeProtected { | |
192 | 229 | 0 | |
193 | 230 | } | |
194 | 231 | func fold (totals,r) = { | |
195 | - | let $ | |
196 | - | let totalD = $ | |
197 | - | let totalB = $ | |
198 | - | let numberOfBorrows = $ | |
232 | + | let $t087958841 = totals | |
233 | + | let totalD = $t087958841._1 | |
234 | + | let totalB = $t087958841._2 | |
235 | + | let numberOfBorrows = $t087958841._3 | |
199 | 236 | let rsr = valueOrErrorMessage(addressFromString(r), "rsr bad address") | |
200 | 237 | let cf = collateralFactor(rsr) | |
201 | 238 | let lt = liquidationThreshold(rsr) | |
202 | - | let $ | |
203 | - | let token = $ | |
204 | - | let asset = $ | |
205 | - | let depositUsd = $ | |
206 | - | let debt = $ | |
207 | - | let debtUsd = $ | |
208 | - | let asCollateral = $ | |
239 | + | let $t089959079 = userBalance(rsr, user) | |
240 | + | let token = $t089959079._1 | |
241 | + | let asset = $t089959079._2 | |
242 | + | let depositUsd = $t089959079._3 | |
243 | + | let debt = $t089959079._4 | |
244 | + | let debtUsd = $t089959079._5 | |
245 | + | let asCollateral = $t089959079._6 | |
209 | 246 | let totalBorrows = (numberOfBorrows + (if ((debt > 0)) | |
210 | 247 | then 1 | |
211 | 248 | else 0)) | |
229 | 266 | ||
230 | 267 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
231 | 268 | then $a | |
232 | - | else throw("List size exceeds | |
269 | + | else throw("List size exceeds 20") | |
233 | 270 | ||
234 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) | |
271 | + | $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($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), 16), 17), 18), 19), 20) | |
235 | 272 | } | |
236 | 273 | if (if ((protectedDeposit > 0)) | |
237 | 274 | then (r._3 > 2) | |
242 | 279 | ||
243 | 280 | ||
244 | 281 | func getUserHealth (account) = { | |
245 | - | let $ | |
246 | - | let bp = $ | |
247 | - | let bpu = $ | |
248 | - | let ignore = $ | |
282 | + | let $t098349885 = asInt3(userPower(account)) | |
283 | + | let bp = $t098349885._1 | |
284 | + | let bpu = $t098349885._2 | |
285 | + | let ignore = $t098349885._3 | |
249 | 286 | ((("bp:" + toString(bp)) + ", bpu:") + toString(bpu)) | |
250 | 287 | } | |
251 | 288 | ||
252 | 289 | ||
253 | 290 | func validateAfter (user,op) = { | |
254 | - | let $ | |
255 | - | let bp = $ | |
256 | - | let bpu = $ | |
291 | + | let $t0999710028 = userPower(user) | |
292 | + | let bp = $t0999710028._1 | |
293 | + | let bpu = $t0999710028._2 | |
257 | 294 | let accHealth = (((bp - bpu) * factorsBase) / bp) | |
258 | 295 | if (if ((bp == 0)) | |
259 | 296 | then (bpu == 0) | |
260 | 297 | else false) | |
261 | - | then | |
298 | + | then 0 | |
262 | 299 | else if (if ((bp == 0)) | |
263 | 300 | then (bpu > 0) | |
264 | 301 | else false) | |
265 | 302 | then throw(((op + ": breaching liquidation threshold(bp=0, bpu=") + toString(bpu))) | |
266 | 303 | else if ((accountHealthThreshold > accHealth)) | |
267 | 304 | then throw((((((((op + ": breaching liquidation threshold(bp=") + toString(bp)) + ", bpu=") + toString(bpu)) + ", health=") + toString(accHealth)) + ")")) | |
268 | - | else | |
305 | + | else bpu | |
269 | 306 | } | |
270 | 307 | ||
271 | 308 | ||
317 | 354 | let amt = i.payments[0].amount | |
318 | 355 | let pRw = uS(rsr, "deposit", user, amt, amt) | |
319 | 356 | if ((pRw == pRw)) | |
320 | - | then if (!(asCol)) | |
321 | - | then validateAfter(user, "depositing") | |
322 | - | else nil | |
357 | + | then { | |
358 | + | let va = if (!(asCol)) | |
359 | + | then validateAfter(user, "depositing") | |
360 | + | else 0 | |
361 | + | if ((va == va)) | |
362 | + | then nil | |
363 | + | else throw("Strict value is not equal to itself.") | |
364 | + | } | |
323 | 365 | else throw("Strict value is not equal to itself.") | |
324 | 366 | } | |
325 | 367 | else throw("Strict value is not equal to itself.") | |
330 | 372 | } | |
331 | 373 | ||
332 | 374 | ||
375 | + | let rewardReserves = split_4C(valueOrErrorMessage(getString(configAddress, "rewardable_reserves"), "no string"), "|") | |
376 | + | ||
333 | 377 | func claimAllRewardsForUser (user) = { | |
334 | 378 | let claimedEb = asInt(invoke(ebR, "claimEbRewardFor", [user, -1], nil)) | |
335 | 379 | if ((claimedEb == claimedEb)) | |
336 | 380 | then { | |
337 | - | let rewardReserves = split(valueOrErrorMessage(getString(configAddress, "rewardable_reserves"), "no string"), "|") | |
338 | 381 | func fold (acc,rsr) = { | |
339 | 382 | let claimed = asInt(invoke(VD, "claimRewardFor", [rsr, user, -1], nil)) | |
340 | 383 | if ((claimed == claimed)) | |
352 | 395 | ||
353 | 396 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
354 | 397 | then $a | |
355 | - | else throw("List size exceeds | |
398 | + | else throw("List size exceeds 20") | |
356 | 399 | ||
357 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) | |
400 | + | $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($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), 16), 17), 18), 19), 20) | |
358 | 401 | } | |
359 | 402 | (claimedTotal + claimedEb) | |
360 | 403 | } | |
363 | 406 | ||
364 | 407 | ||
365 | 408 | func claimAllLpRewardsForUser (user) = { | |
366 | - | let rewardReserves = split(valueOrErrorMessage(getString(configAddress, "rewardable_reserves"), "no string"), "|") | |
367 | 409 | func fold (acc,rsr) = { | |
368 | 410 | let aTokenId = valueOrErrorMessage(getString(addressFromStringValue(rsr), aTIdS), "no aTokenId in reserve") | |
369 | 411 | let claimed = asInt(invoke(locker, "claimLpRewardFor", [user, aTokenId, -1], nil)) | |
382 | 424 | ||
383 | 425 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
384 | 426 | then $a | |
385 | - | else throw("List size exceeds | |
427 | + | else throw("List size exceeds 20") | |
386 | 428 | ||
387 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) | |
429 | + | $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($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), 16), 17), 18), 19), 20) | |
388 | 430 | } | |
389 | 431 | claimedTotal | |
390 | 432 | } | |
485 | 527 | then { | |
486 | 528 | let pRw = uS(toString(t), "deposit", user, -(actual), 0) | |
487 | 529 | if ((pRw == pRw)) | |
488 | - | then validateAfter(user, "minting") | |
530 | + | then { | |
531 | + | let bpu = asInt(validateAfter(user, "minting")) | |
532 | + | if ((bpu == bpu)) | |
533 | + | then { | |
534 | + | let pc = ensureNoProhibited(user, bpu, toString(t)) | |
535 | + | if ((pc == pc)) | |
536 | + | then nil | |
537 | + | else throw("Strict value is not equal to itself.") | |
538 | + | } | |
539 | + | else throw("Strict value is not equal to itself.") | |
540 | + | } | |
489 | 541 | else throw("Strict value is not equal to itself.") | |
490 | 542 | } | |
491 | 543 | else throw("Strict value is not equal to itself.") | |
594 | 646 | @Callable(i) | |
595 | 647 | func withdraw (assetId,amt) = { | |
596 | 648 | let user = toString(i.caller) | |
597 | - | let result = asInt(wdInternal(user, reserveBy(aIdS, assetId), amt, "withdrawFor")) | |
649 | + | let r = reserveBy(aIdS, assetId) | |
650 | + | let result = asInt(wdInternal(user, r, amt, "withdrawFor")) | |
598 | 651 | if ((result == result)) | |
599 | - | then $Tuple2(validateAfter(user, "withdrawing"), result) | |
652 | + | then { | |
653 | + | let bpu = asInt(validateAfter(user, "withdrawing")) | |
654 | + | if ((bpu == bpu)) | |
655 | + | then { | |
656 | + | let pc = ensureNoProhibited(user, bpu, toString(r)) | |
657 | + | if ((pc == pc)) | |
658 | + | then $Tuple2(nil, result) | |
659 | + | else throw("Strict value is not equal to itself.") | |
660 | + | } | |
661 | + | else throw("Strict value is not equal to itself.") | |
662 | + | } | |
600 | 663 | else throw("Strict value is not equal to itself.") | |
601 | 664 | } | |
602 | 665 | ||
615 | 678 | let pRw = uS(rsr, "deposit", user, -(actual), -(actual)) | |
616 | 679 | if ((pRw == pRw)) | |
617 | 680 | then { | |
618 | - | let e = ensureLimit("withdraw", rsrAddr, user, actual) | |
619 | - | if ((e == e)) | |
620 | - | then if (contains(liquidators, user)) | |
621 | - | then nil | |
622 | - | else validateAfter(user, "withdrawing2") | |
681 | + | let bpu = if (contains(liquidators, user)) | |
682 | + | then 0 | |
683 | + | else { | |
684 | + | let e = ensureLimit("withdraw", rsrAddr, user, actual) | |
685 | + | if ((e == e)) | |
686 | + | then asInt(validateAfter(user, "withdrawing2")) | |
687 | + | else throw("Strict value is not equal to itself.") | |
688 | + | } | |
689 | + | let pc = ensureNoProhibited(user, bpu, rsr) | |
690 | + | if ((pc == pc)) | |
691 | + | then $Tuple2(nil, actual) | |
623 | 692 | else throw("Strict value is not equal to itself.") | |
624 | 693 | } | |
625 | 694 | else throw("Strict value is not equal to itself.") | |
641 | 710 | let assetId = assetStrToId(getStringValue(r, aIdS)) | |
642 | 711 | let p = invoke(protectedReserve, "supplyFor", [user], [AttachedPayment(assetId, amt)]) | |
643 | 712 | if ((p == p)) | |
644 | - | then $Tuple2(nil, amt) | |
713 | + | then { | |
714 | + | let pc = ensureNoProhibited(user, userPower(user)._2, rsr) | |
715 | + | if ((pc == pc)) | |
716 | + | then $Tuple2(nil, amt) | |
717 | + | else throw("Strict value is not equal to itself.") | |
718 | + | } | |
645 | 719 | else throw("Strict value is not equal to itself.") | |
646 | 720 | } | |
647 | 721 | else throw("Strict value is not equal to itself.") | |
654 | 728 | let user = toString(i.caller) | |
655 | 729 | let a = asInt(invoke(valueOrErrorMessage(protectedReserve, "no protectedReserve"), "withdrawFor", [user, assetId, amt], nil)) | |
656 | 730 | if ((a == a)) | |
657 | - | then validateAfter(user, "withdrawing protected") | |
731 | + | then { | |
732 | + | let va = validateAfter(user, "withdrawing protected") | |
733 | + | if ((va == va)) | |
734 | + | then nil | |
735 | + | else throw("Strict value is not equal to itself.") | |
736 | + | } | |
658 | 737 | else throw("Strict value is not equal to itself.") | |
659 | 738 | } | |
660 | 739 | ||
697 | 776 | then { | |
698 | 777 | let e = ensureLimit("borrow", rsr, user, amt) | |
699 | 778 | if ((e == e)) | |
700 | - | then validateAfter(user, "borrowing") | |
779 | + | then { | |
780 | + | let bpu = asInt(validateAfter(user, "borrowing")) | |
781 | + | if ((bpu == bpu)) | |
782 | + | then { | |
783 | + | let pc = ensureNoProhibitedCollaterals(user) | |
784 | + | if ((pc == pc)) | |
785 | + | then nil | |
786 | + | else throw("Strict value is not equal to itself.") | |
787 | + | } | |
788 | + | else throw("Strict value is not equal to itself.") | |
789 | + | } | |
701 | 790 | else throw("Strict value is not equal to itself.") | |
702 | 791 | } | |
703 | 792 | else throw("Strict value is not equal to itself.") | |
724 | 813 | then { | |
725 | 814 | let e = ensureLimit("borrow", r, user, amt) | |
726 | 815 | if ((e == e)) | |
727 | - | then validateAfter(user, "borrowing") | |
816 | + | then { | |
817 | + | let bpu = asInt(validateAfter(user, "borrowing")) | |
818 | + | if ((bpu == bpu)) | |
819 | + | then { | |
820 | + | let pc = ensureNoProhibitedCollaterals(user) | |
821 | + | if ((pc == pc)) | |
822 | + | then nil | |
823 | + | else throw("Strict value is not equal to itself.") | |
824 | + | } | |
825 | + | else throw("Strict value is not equal to itself.") | |
826 | + | } | |
728 | 827 | else throw("Strict value is not equal to itself.") | |
729 | 828 | } | |
730 | 829 | else throw("Strict value is not equal to itself.") | |
817 | 916 | let user = toString(i.caller) | |
818 | 917 | let d = invoke(vlR(rsr), "disableUseAsCollateralFor", [user], nil) | |
819 | 918 | if ((d == d)) | |
820 | - | then validateAfter(user, "changing collateral status") | |
919 | + | then { | |
920 | + | let va = validateAfter(user, "changing collateral status") | |
921 | + | if ((va == va)) | |
922 | + | then nil | |
923 | + | else throw("Strict value is not equal to itself.") | |
924 | + | } | |
821 | 925 | else throw("Strict value is not equal to itself.") | |
822 | 926 | } | |
823 | 927 | ||
939 | 1043 | then { | |
940 | 1044 | let pRw = uS(toString(rsr), "deposit", user, -(actual), 0) | |
941 | 1045 | if ((pRw == pRw)) | |
942 | - | then validateAfter(user, "lock-minting") | |
1046 | + | then { | |
1047 | + | let va = validateAfter(user, "lock-minting") | |
1048 | + | if ((va == va)) | |
1049 | + | then nil | |
1050 | + | else throw("Strict value is not equal to itself.") | |
1051 | + | } | |
943 | 1052 | else throw("Strict value is not equal to itself.") | |
944 | 1053 | } | |
945 | 1054 | else throw("Strict value is not equal to itself.") |
Old | New | Differences | |
---|---|---|---|
1 | - | {-# STDLIB_VERSION | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let factorsBase = 1000 | |
5 | 5 | ||
6 | 6 | func fCi (value,numerator,denominator) = { | |
7 | 7 | let cand = fraction(value, numerator, denominator) | |
8 | 8 | let D = 3037000499 | |
9 | 9 | let exact = ((((cand % D) * (denominator % D)) % D) == (((value % D) * (numerator % D)) % D)) | |
10 | 10 | if (exact) | |
11 | 11 | then cand | |
12 | 12 | else (cand + 1) | |
13 | 13 | } | |
14 | 14 | ||
15 | 15 | ||
16 | 16 | func assetStrToId (assetId) = if ((assetId == "WAVES")) | |
17 | 17 | then unit | |
18 | 18 | else fromBase58String(assetId) | |
19 | 19 | ||
20 | 20 | ||
21 | 21 | func writeConstString (key,value) = if (!(isDefined(getString(this, key)))) | |
22 | 22 | then StringEntry(key, value) | |
23 | 23 | else throw(("already initialized: " + key)) | |
24 | 24 | ||
25 | 25 | ||
26 | 26 | func asInt (value) = match value { | |
27 | 27 | case int: Int => | |
28 | 28 | int | |
29 | 29 | case _ => | |
30 | - | throw("1") | |
30 | + | throw("m:1") | |
31 | 31 | } | |
32 | 32 | ||
33 | 33 | ||
34 | 34 | func asInt3 (value) = match value { | |
35 | 35 | case x: (Int, Int, Int) => | |
36 | 36 | x | |
37 | 37 | case t => | |
38 | 38 | throw("2") | |
39 | 39 | } | |
40 | 40 | ||
41 | 41 | ||
42 | 42 | func asUserBalanceData (value) = match value { | |
43 | 43 | case x: (Int, Int, Int, Int, Int, Boolean) => | |
44 | 44 | x | |
45 | 45 | case t => | |
46 | 46 | throw("3") | |
47 | 47 | } | |
48 | 48 | ||
49 | 49 | ||
50 | 50 | let configStore = "config" | |
51 | 51 | ||
52 | 52 | let reservesStore = "reserves" | |
53 | 53 | ||
54 | 54 | let aTIdS = "aTokenId" | |
55 | 55 | ||
56 | 56 | let aIdS = "assetId" | |
57 | 57 | ||
58 | 58 | let configAddress = addressFromStringValue(getStringValue(this, configStore)) | |
59 | 59 | ||
60 | 60 | let locker = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "lp_locker"), "no lp_locker address in config")), "bad lp_locker address in config") | |
61 | 61 | ||
62 | 62 | let reservesStr = valueOrErrorMessage(getString(configAddress, "primary_reserves"), "no reserves registered") | |
63 | 63 | ||
64 | - | let reserves = split(reservesStr, "|") | |
64 | + | let reserves = split_4C(reservesStr, "|") | |
65 | 65 | ||
66 | 66 | let ebR = addressFromStringValue(valueOrErrorMessage(getString(configAddress, "eb_rewards"), "no eb_rewards")) | |
67 | 67 | ||
68 | 68 | let viresMinter = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "vires_minter"), "main: no viresMinter")), "bad minter") | |
69 | 69 | ||
70 | 70 | let maybevS = getString(configAddress, "vires_staker") | |
71 | 71 | ||
72 | 72 | let vS = addressFromStringValue(valueOrErrorMessage(maybevS, "no vires_staker")) | |
73 | 73 | ||
74 | 74 | let dC = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "bad div") | |
75 | 75 | ||
76 | 76 | let mVD = match getString(configAddress, "vires_distributor") { | |
77 | 77 | case d: String => | |
78 | 78 | addressFromStringValue(d) | |
79 | 79 | case _ => | |
80 | 80 | unit | |
81 | 81 | } | |
82 | 82 | ||
83 | 83 | let VD = valueOrErrorMessage(mVD, "no distr") | |
84 | 84 | ||
85 | 85 | let limiter = match getString(configAddress, "limiter") { | |
86 | 86 | case d: String => | |
87 | 87 | addressFromStringValue(d) | |
88 | 88 | case _ => | |
89 | 89 | unit | |
90 | 90 | } | |
91 | 91 | ||
92 | 92 | let maybeViresAssetId = getString(viresMinter, aIdS) | |
93 | 93 | ||
94 | 94 | let viresAssetId = valueOrErrorMessage(fromBase58String(valueOrErrorMessage(maybeViresAssetId, "no vires id")), "invalid vires id") | |
95 | 95 | ||
96 | 96 | func viresPayment (i) = if ((size(i.payments) == 0)) | |
97 | 97 | then 0 | |
98 | 98 | else if ((i.payments[0].assetId != viresAssetId)) | |
99 | 99 | then throw("not vires") | |
100 | 100 | else i.payments[0].amount | |
101 | 101 | ||
102 | 102 | ||
103 | 103 | func assetIdOfReserve (rsr) = valueOrErrorMessage(getString(rsr, aIdS), "no assetId in rsr") | |
104 | 104 | ||
105 | 105 | ||
106 | 106 | func collateralFactor (rsr) = valueOrErrorMessage(getInteger(configAddress, (assetIdOfReserve(rsr) + "_CollateralFactor")), "no 1") | |
107 | 107 | ||
108 | 108 | ||
109 | 109 | func liquidationThreshold (rsr) = valueOrErrorMessage(getInteger(configAddress, (assetIdOfReserve(rsr) + "_LiquidationThreshold")), "no 2") | |
110 | 110 | ||
111 | 111 | ||
112 | 112 | let accountHealthThreshold = valueOrErrorMessage(getInteger(configAddress, "account_health_threshold"), "no 4") | |
113 | 113 | ||
114 | 114 | let accountHealthOverlap = valueOrErrorMessage(getInteger(configAddress, "account_health_overlap"), "no 5") | |
115 | 115 | ||
116 | 116 | let liquidators = valueOrElse(getString(configAddress, "liquidators"), "") | |
117 | 117 | ||
118 | 118 | func reserveBy (store,value) = { | |
119 | 119 | func fold (a,r) = match a { | |
120 | 120 | case found: Address => | |
121 | 121 | found | |
122 | 122 | case _ => | |
123 | 123 | let rsr = valueOrErrorMessage(addressFromString(r), "rsr bad address") | |
124 | 124 | if ((valueOrErrorMessage(getString(rsr, store), ("rsr has no " + store)) == value)) | |
125 | 125 | then rsr | |
126 | 126 | else unit | |
127 | 127 | } | |
128 | 128 | ||
129 | 129 | match let $l = reserves | |
130 | 130 | let $s = size($l) | |
131 | 131 | let $acc0 = unit | |
132 | 132 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
133 | 133 | then $a | |
134 | 134 | else fold($a, $l[$i]) | |
135 | 135 | ||
136 | 136 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
137 | 137 | then $a | |
138 | - | else throw("List size exceeds | |
138 | + | else throw("List size exceeds 20") | |
139 | 139 | ||
140 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) { | |
140 | + | $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($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), 16), 17), 18), 19), 20) { | |
141 | 141 | case found: Address => | |
142 | 142 | found | |
143 | 143 | case _ => | |
144 | 144 | throw(("unknown " + store)) | |
145 | 145 | } | |
146 | 146 | } | |
147 | 147 | ||
148 | 148 | ||
149 | 149 | func vlR (r) = if (contains(reservesStr, r)) | |
150 | 150 | then valueOrErrorMessage(addressFromString(r), "main: bad rsr") | |
151 | 151 | else throw(("unknown rsr:" + r)) | |
152 | 152 | ||
153 | 153 | ||
154 | 154 | func userBalance (rsr,user) = asUserBalanceData(invoke(rsr, "userBalance", [user], nil)) | |
155 | 155 | ||
156 | 156 | ||
157 | 157 | let maybeProtected = match getString(configAddress, "protected_reserve") { | |
158 | 158 | case pds: String => | |
159 | 159 | valueOrErrorMessage(addressFromString(pds), "bad protected") | |
160 | 160 | case _ => | |
161 | 161 | unit | |
162 | 162 | } | |
163 | 163 | ||
164 | 164 | let protectedReserve = valueOrErrorMessage(maybeProtected, "no protected rsr") | |
165 | + | ||
166 | + | let prohibitedCollateralReserves = match getString(configAddress, "prohibitedCollateralReserves") { | |
167 | + | case s: String => | |
168 | + | split(s, "|") | |
169 | + | case _ => | |
170 | + | nil | |
171 | + | } | |
172 | + | ||
173 | + | func ensureNoProhibitedCollaterals (user) = { | |
174 | + | func foldFunc (a,prohibitedReserve) = { | |
175 | + | let atb = valueOrElse(getInteger(addressFromStringValue(prohibitedReserve), (user + "_aTokenBalance")), 0) | |
176 | + | if ((atb > 0)) | |
177 | + | then throw((((("operation denied: user has deposit in " + prohibitedReserve) + ": ") + toString(atb)) + "(lp tokens)")) | |
178 | + | else true | |
179 | + | } | |
180 | + | ||
181 | + | let $l = prohibitedCollateralReserves | |
182 | + | let $s = size($l) | |
183 | + | let $acc0 = true | |
184 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
185 | + | then $a | |
186 | + | else foldFunc($a, $l[$i]) | |
187 | + | ||
188 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
189 | + | then $a | |
190 | + | else throw("List size exceeds 15") | |
191 | + | ||
192 | + | $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) | |
193 | + | } | |
194 | + | ||
195 | + | ||
196 | + | func ensureNoProhibited (user,bpu,reserve) = if (if ((bpu == 0)) | |
197 | + | then true | |
198 | + | else isDefined(indexOf(prohibitedCollateralReserves, reserve))) | |
199 | + | then true | |
200 | + | else ensureNoProhibitedCollaterals(user) | |
201 | + | ||
165 | 202 | ||
166 | 203 | func ensureNoProtected (user) = { | |
167 | 204 | let has = match maybeProtected { | |
168 | 205 | case pa: Address => | |
169 | 206 | valueOrElse(getBoolean(pa, ("protected_collateral_" + user)), false) | |
170 | 207 | case _ => | |
171 | 208 | false | |
172 | 209 | } | |
173 | 210 | if (has) | |
174 | 211 | then throw("disallowed") | |
175 | 212 | else unit | |
176 | 213 | } | |
177 | 214 | ||
178 | 215 | ||
179 | 216 | func ensureLimit (action,rsr,user,amount) = match limiter { | |
180 | 217 | case l: Address => | |
181 | 218 | asInt(invoke(l, "validateLimit", [action, toString(rsr), user, amount], nil)) | |
182 | 219 | case _ => | |
183 | 220 | true | |
184 | 221 | } | |
185 | 222 | ||
186 | 223 | ||
187 | 224 | func userPower (user) = { | |
188 | 225 | let protectedDeposit = match maybeProtected { | |
189 | 226 | case pa: Address => | |
190 | 227 | asInt(invoke(pa, "borrowPower", [user], nil)) | |
191 | 228 | case _ => | |
192 | 229 | 0 | |
193 | 230 | } | |
194 | 231 | func fold (totals,r) = { | |
195 | - | let $ | |
196 | - | let totalD = $ | |
197 | - | let totalB = $ | |
198 | - | let numberOfBorrows = $ | |
232 | + | let $t087958841 = totals | |
233 | + | let totalD = $t087958841._1 | |
234 | + | let totalB = $t087958841._2 | |
235 | + | let numberOfBorrows = $t087958841._3 | |
199 | 236 | let rsr = valueOrErrorMessage(addressFromString(r), "rsr bad address") | |
200 | 237 | let cf = collateralFactor(rsr) | |
201 | 238 | let lt = liquidationThreshold(rsr) | |
202 | - | let $ | |
203 | - | let token = $ | |
204 | - | let asset = $ | |
205 | - | let depositUsd = $ | |
206 | - | let debt = $ | |
207 | - | let debtUsd = $ | |
208 | - | let asCollateral = $ | |
239 | + | let $t089959079 = userBalance(rsr, user) | |
240 | + | let token = $t089959079._1 | |
241 | + | let asset = $t089959079._2 | |
242 | + | let depositUsd = $t089959079._3 | |
243 | + | let debt = $t089959079._4 | |
244 | + | let debtUsd = $t089959079._5 | |
245 | + | let asCollateral = $t089959079._6 | |
209 | 246 | let totalBorrows = (numberOfBorrows + (if ((debt > 0)) | |
210 | 247 | then 1 | |
211 | 248 | else 0)) | |
212 | 249 | let effectiveDepositUsd = if (asCollateral) | |
213 | 250 | then depositUsd | |
214 | 251 | else 0 | |
215 | 252 | let overlapUsd = min([debtUsd, effectiveDepositUsd]) | |
216 | 253 | let overlapCharge = fCi(overlapUsd, accountHealthOverlap, factorsBase) | |
217 | 254 | if ((debtUsd > effectiveDepositUsd)) | |
218 | 255 | then $Tuple3(totalD, ((totalB + fraction((debtUsd - effectiveDepositUsd), factorsBase, lt)) + overlapCharge), totalBorrows) | |
219 | 256 | else $Tuple3((totalD + fraction((effectiveDepositUsd - debtUsd), cf, factorsBase)), (totalB + overlapCharge), totalBorrows) | |
220 | 257 | } | |
221 | 258 | ||
222 | 259 | let r = { | |
223 | 260 | let $l = reserves | |
224 | 261 | let $s = size($l) | |
225 | 262 | let $acc0 = $Tuple3(protectedDeposit, 0, 0) | |
226 | 263 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
227 | 264 | then $a | |
228 | 265 | else fold($a, $l[$i]) | |
229 | 266 | ||
230 | 267 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
231 | 268 | then $a | |
232 | - | else throw("List size exceeds | |
269 | + | else throw("List size exceeds 20") | |
233 | 270 | ||
234 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) | |
271 | + | $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($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), 16), 17), 18), 19), 20) | |
235 | 272 | } | |
236 | 273 | if (if ((protectedDeposit > 0)) | |
237 | 274 | then (r._3 > 2) | |
238 | 275 | else false) | |
239 | 276 | then throw("can't have more than 2 borrows") | |
240 | 277 | else r | |
241 | 278 | } | |
242 | 279 | ||
243 | 280 | ||
244 | 281 | func getUserHealth (account) = { | |
245 | - | let $ | |
246 | - | let bp = $ | |
247 | - | let bpu = $ | |
248 | - | let ignore = $ | |
282 | + | let $t098349885 = asInt3(userPower(account)) | |
283 | + | let bp = $t098349885._1 | |
284 | + | let bpu = $t098349885._2 | |
285 | + | let ignore = $t098349885._3 | |
249 | 286 | ((("bp:" + toString(bp)) + ", bpu:") + toString(bpu)) | |
250 | 287 | } | |
251 | 288 | ||
252 | 289 | ||
253 | 290 | func validateAfter (user,op) = { | |
254 | - | let $ | |
255 | - | let bp = $ | |
256 | - | let bpu = $ | |
291 | + | let $t0999710028 = userPower(user) | |
292 | + | let bp = $t0999710028._1 | |
293 | + | let bpu = $t0999710028._2 | |
257 | 294 | let accHealth = (((bp - bpu) * factorsBase) / bp) | |
258 | 295 | if (if ((bp == 0)) | |
259 | 296 | then (bpu == 0) | |
260 | 297 | else false) | |
261 | - | then | |
298 | + | then 0 | |
262 | 299 | else if (if ((bp == 0)) | |
263 | 300 | then (bpu > 0) | |
264 | 301 | else false) | |
265 | 302 | then throw(((op + ": breaching liquidation threshold(bp=0, bpu=") + toString(bpu))) | |
266 | 303 | else if ((accountHealthThreshold > accHealth)) | |
267 | 304 | then throw((((((((op + ": breaching liquidation threshold(bp=") + toString(bp)) + ", bpu=") + toString(bpu)) + ", health=") + toString(accHealth)) + ")")) | |
268 | - | else | |
305 | + | else bpu | |
269 | 306 | } | |
270 | 307 | ||
271 | 308 | ||
272 | 309 | func uS (rsr,action,user,userChange,streamChange) = match mVD { | |
273 | 310 | case a: Address => | |
274 | 311 | invoke(a, "onAction", [rsr, action, user, userChange, streamChange], nil) | |
275 | 312 | case _ => | |
276 | 313 | unit | |
277 | 314 | } | |
278 | 315 | ||
279 | 316 | ||
280 | 317 | func moveStream (rsr,action,from,string,amt) = match mVD { | |
281 | 318 | case a: Address => | |
282 | 319 | invoke(a, "move", [rsr, action, from, string, amt], nil) | |
283 | 320 | case _ => | |
284 | 321 | unit | |
285 | 322 | } | |
286 | 323 | ||
287 | 324 | ||
288 | 325 | func sR (rsr) = match mVD { | |
289 | 326 | case a: Address => | |
290 | 327 | invoke(a, "syncHeight", [rsr], nil) | |
291 | 328 | case _ => | |
292 | 329 | unit | |
293 | 330 | } | |
294 | 331 | ||
295 | 332 | ||
296 | 333 | func lockOrPayout (recipient,amt,lock) = if (!(lock)) | |
297 | 334 | then [ScriptTransfer(recipient, amt, viresAssetId)] | |
298 | 335 | else { | |
299 | 336 | let doLock = invoke(dC, "lockFor", [toString(recipient), 1], [AttachedPayment(viresAssetId, amt)]) | |
300 | 337 | if ((doLock == doLock)) | |
301 | 338 | then nil | |
302 | 339 | else throw("Strict value is not equal to itself.") | |
303 | 340 | } | |
304 | 341 | ||
305 | 342 | ||
306 | 343 | func doDeposit (i,rsr,asCol) = { | |
307 | 344 | let user = toString(i.caller) | |
308 | 345 | let checks = ensureNoProtected(user) | |
309 | 346 | if ((checks == checks)) | |
310 | 347 | then { | |
311 | 348 | let sh = sR(rsr) | |
312 | 349 | if ((sh == sh)) | |
313 | 350 | then { | |
314 | 351 | let action = invoke(vlR(rsr), "depositFor", [user, asCol], i.payments) | |
315 | 352 | if ((action == action)) | |
316 | 353 | then { | |
317 | 354 | let amt = i.payments[0].amount | |
318 | 355 | let pRw = uS(rsr, "deposit", user, amt, amt) | |
319 | 356 | if ((pRw == pRw)) | |
320 | - | then if (!(asCol)) | |
321 | - | then validateAfter(user, "depositing") | |
322 | - | else nil | |
357 | + | then { | |
358 | + | let va = if (!(asCol)) | |
359 | + | then validateAfter(user, "depositing") | |
360 | + | else 0 | |
361 | + | if ((va == va)) | |
362 | + | then nil | |
363 | + | else throw("Strict value is not equal to itself.") | |
364 | + | } | |
323 | 365 | else throw("Strict value is not equal to itself.") | |
324 | 366 | } | |
325 | 367 | else throw("Strict value is not equal to itself.") | |
326 | 368 | } | |
327 | 369 | else throw("Strict value is not equal to itself.") | |
328 | 370 | } | |
329 | 371 | else throw("Strict value is not equal to itself.") | |
330 | 372 | } | |
331 | 373 | ||
332 | 374 | ||
375 | + | let rewardReserves = split_4C(valueOrErrorMessage(getString(configAddress, "rewardable_reserves"), "no string"), "|") | |
376 | + | ||
333 | 377 | func claimAllRewardsForUser (user) = { | |
334 | 378 | let claimedEb = asInt(invoke(ebR, "claimEbRewardFor", [user, -1], nil)) | |
335 | 379 | if ((claimedEb == claimedEb)) | |
336 | 380 | then { | |
337 | - | let rewardReserves = split(valueOrErrorMessage(getString(configAddress, "rewardable_reserves"), "no string"), "|") | |
338 | 381 | func fold (acc,rsr) = { | |
339 | 382 | let claimed = asInt(invoke(VD, "claimRewardFor", [rsr, user, -1], nil)) | |
340 | 383 | if ((claimed == claimed)) | |
341 | 384 | then (acc + claimed) | |
342 | 385 | else throw("Strict value is not equal to itself.") | |
343 | 386 | } | |
344 | 387 | ||
345 | 388 | let claimedTotal = { | |
346 | 389 | let $l = rewardReserves | |
347 | 390 | let $s = size($l) | |
348 | 391 | let $acc0 = 0 | |
349 | 392 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
350 | 393 | then $a | |
351 | 394 | else fold($a, $l[$i]) | |
352 | 395 | ||
353 | 396 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
354 | 397 | then $a | |
355 | - | else throw("List size exceeds | |
398 | + | else throw("List size exceeds 20") | |
356 | 399 | ||
357 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) | |
400 | + | $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($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), 16), 17), 18), 19), 20) | |
358 | 401 | } | |
359 | 402 | (claimedTotal + claimedEb) | |
360 | 403 | } | |
361 | 404 | else throw("Strict value is not equal to itself.") | |
362 | 405 | } | |
363 | 406 | ||
364 | 407 | ||
365 | 408 | func claimAllLpRewardsForUser (user) = { | |
366 | - | let rewardReserves = split(valueOrErrorMessage(getString(configAddress, "rewardable_reserves"), "no string"), "|") | |
367 | 409 | func fold (acc,rsr) = { | |
368 | 410 | let aTokenId = valueOrErrorMessage(getString(addressFromStringValue(rsr), aTIdS), "no aTokenId in reserve") | |
369 | 411 | let claimed = asInt(invoke(locker, "claimLpRewardFor", [user, aTokenId, -1], nil)) | |
370 | 412 | if ((claimed == claimed)) | |
371 | 413 | then (acc + claimed) | |
372 | 414 | else throw("Strict value is not equal to itself.") | |
373 | 415 | } | |
374 | 416 | ||
375 | 417 | let claimedTotal = { | |
376 | 418 | let $l = rewardReserves | |
377 | 419 | let $s = size($l) | |
378 | 420 | let $acc0 = 0 | |
379 | 421 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
380 | 422 | then $a | |
381 | 423 | else fold($a, $l[$i]) | |
382 | 424 | ||
383 | 425 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
384 | 426 | then $a | |
385 | - | else throw("List size exceeds | |
427 | + | else throw("List size exceeds 20") | |
386 | 428 | ||
387 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7) | |
429 | + | $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($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), 16), 17), 18), 19), 20) | |
388 | 430 | } | |
389 | 431 | claimedTotal | |
390 | 432 | } | |
391 | 433 | ||
392 | 434 | ||
393 | 435 | func moveCollateral (addr,assetStr,rsr,reserveStr) = { | |
394 | 436 | let amt = asInt(invoke(protectedReserve, "withdrawToMain", [addr, assetStr], nil)) | |
395 | 437 | if ((amt == amt)) | |
396 | 438 | then { | |
397 | 439 | let assetId = if ((assetStr == "WAVES")) | |
398 | 440 | then unit | |
399 | 441 | else fromBase58String(assetStr) | |
400 | 442 | let dep = invoke(rsr, "depositFor", [addr, true], [AttachedPayment(assetId, amt)]) | |
401 | 443 | if ((dep == dep)) | |
402 | 444 | then { | |
403 | 445 | let prop = uS(reserveStr, "deposit", addr, amt, amt) | |
404 | 446 | if ((prop == prop)) | |
405 | 447 | then unit | |
406 | 448 | else throw("Strict value is not equal to itself.") | |
407 | 449 | } | |
408 | 450 | else throw("Strict value is not equal to itself.") | |
409 | 451 | } | |
410 | 452 | else throw("Strict value is not equal to itself.") | |
411 | 453 | } | |
412 | 454 | ||
413 | 455 | ||
414 | 456 | func spfr () = invoke(dC, "shareProfitFromReserves", nil, nil) | |
415 | 457 | ||
416 | 458 | ||
417 | 459 | func wdInternal (user,rsr,amt,op) = { | |
418 | 460 | let sh = sR(toString(rsr)) | |
419 | 461 | if ((sh == sh)) | |
420 | 462 | then { | |
421 | 463 | let withdrawnAmount = asInt(invoke(rsr, op, [user, amt], nil)) | |
422 | 464 | if ((withdrawnAmount == withdrawnAmount)) | |
423 | 465 | then { | |
424 | 466 | let pRw = uS(toString(rsr), "deposit", user, -(withdrawnAmount), -(withdrawnAmount)) | |
425 | 467 | if ((pRw == pRw)) | |
426 | 468 | then { | |
427 | 469 | let e = ensureLimit("withdraw", rsr, user, withdrawnAmount) | |
428 | 470 | if ((e == e)) | |
429 | 471 | then withdrawnAmount | |
430 | 472 | else throw("Strict value is not equal to itself.") | |
431 | 473 | } | |
432 | 474 | else throw("Strict value is not equal to itself.") | |
433 | 475 | } | |
434 | 476 | else throw("Strict value is not equal to itself.") | |
435 | 477 | } | |
436 | 478 | else throw("Strict value is not equal to itself.") | |
437 | 479 | } | |
438 | 480 | ||
439 | 481 | ||
440 | 482 | @Callable(i) | |
441 | 483 | func initialize (ca) = [writeConstString(configStore, ca)] | |
442 | 484 | ||
443 | 485 | ||
444 | 486 | ||
445 | 487 | @Callable(i) | |
446 | 488 | func deposit (rsr,asCol) = doDeposit(i, rsr, asCol) | |
447 | 489 | ||
448 | 490 | ||
449 | 491 | ||
450 | 492 | @Callable(i) | |
451 | 493 | func depositRef (rsr,asCol,ref) = doDeposit(i, rsr, asCol) | |
452 | 494 | ||
453 | 495 | ||
454 | 496 | ||
455 | 497 | @Callable(i) | |
456 | 498 | func repay (rsr) = { | |
457 | 499 | let user = toString(i.caller) | |
458 | 500 | let sh = sR(rsr) | |
459 | 501 | if ((sh == sh)) | |
460 | 502 | then { | |
461 | 503 | let repaid = asInt(invoke(vlR(rsr), "repayFor", [user], i.payments)) | |
462 | 504 | if ((repaid == repaid)) | |
463 | 505 | then { | |
464 | 506 | let pRw = uS(rsr, "borrow", user, -(repaid), -(repaid)) | |
465 | 507 | if ((pRw == pRw)) | |
466 | 508 | then nil | |
467 | 509 | else throw("Strict value is not equal to itself.") | |
468 | 510 | } | |
469 | 511 | else throw("Strict value is not equal to itself.") | |
470 | 512 | } | |
471 | 513 | else throw("Strict value is not equal to itself.") | |
472 | 514 | } | |
473 | 515 | ||
474 | 516 | ||
475 | 517 | ||
476 | 518 | @Callable(i) | |
477 | 519 | func mintAtoken (aTokenId,amt) = { | |
478 | 520 | let user = toString(i.caller) | |
479 | 521 | let t = reserveBy(aTIdS, aTokenId) | |
480 | 522 | let sh = sR(toString(t)) | |
481 | 523 | if ((sh == sh)) | |
482 | 524 | then { | |
483 | 525 | let actual = asInt(invoke(t, "mintAtokenFor", [user, amt], nil)) | |
484 | 526 | if ((actual == actual)) | |
485 | 527 | then { | |
486 | 528 | let pRw = uS(toString(t), "deposit", user, -(actual), 0) | |
487 | 529 | if ((pRw == pRw)) | |
488 | - | then validateAfter(user, "minting") | |
530 | + | then { | |
531 | + | let bpu = asInt(validateAfter(user, "minting")) | |
532 | + | if ((bpu == bpu)) | |
533 | + | then { | |
534 | + | let pc = ensureNoProhibited(user, bpu, toString(t)) | |
535 | + | if ((pc == pc)) | |
536 | + | then nil | |
537 | + | else throw("Strict value is not equal to itself.") | |
538 | + | } | |
539 | + | else throw("Strict value is not equal to itself.") | |
540 | + | } | |
489 | 541 | else throw("Strict value is not equal to itself.") | |
490 | 542 | } | |
491 | 543 | else throw("Strict value is not equal to itself.") | |
492 | 544 | } | |
493 | 545 | else throw("Strict value is not equal to itself.") | |
494 | 546 | } | |
495 | 547 | ||
496 | 548 | ||
497 | 549 | ||
498 | 550 | @Callable(i) | |
499 | 551 | func replenishWithAtoken () = { | |
500 | 552 | let user = toString(i.caller) | |
501 | 553 | let checks = ensureNoProtected(user) | |
502 | 554 | if ((checks == checks)) | |
503 | 555 | then { | |
504 | 556 | let aTokenId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "bad assetId(w)")) | |
505 | 557 | let rsr = reserveBy(aTIdS, aTokenId) | |
506 | 558 | let sh = sR(toString(rsr)) | |
507 | 559 | if ((sh == sh)) | |
508 | 560 | then { | |
509 | 561 | let amt = asInt(invoke(rsr, "replenishWithAtokenFor", [user], i.payments)) | |
510 | 562 | if ((amt == amt)) | |
511 | 563 | then { | |
512 | 564 | let pRw = uS(toString(rsr), "deposit", user, amt, 0) | |
513 | 565 | if ((pRw == pRw)) | |
514 | 566 | then { | |
515 | 567 | let e = ensureLimit("import", rsr, user, amt) | |
516 | 568 | if ((e == e)) | |
517 | 569 | then nil | |
518 | 570 | else throw("Strict value is not equal to itself.") | |
519 | 571 | } | |
520 | 572 | else throw("Strict value is not equal to itself.") | |
521 | 573 | } | |
522 | 574 | else throw("Strict value is not equal to itself.") | |
523 | 575 | } | |
524 | 576 | else throw("Strict value is not equal to itself.") | |
525 | 577 | } | |
526 | 578 | else throw("Strict value is not equal to itself.") | |
527 | 579 | } | |
528 | 580 | ||
529 | 581 | ||
530 | 582 | ||
531 | 583 | @Callable(i) | |
532 | 584 | func repayWithAtoken () = { | |
533 | 585 | let user = toString(i.caller) | |
534 | 586 | let aTokenId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "bad assetId: waves not allowed")) | |
535 | 587 | let t = reserveBy(aTIdS, aTokenId) | |
536 | 588 | let sh = sR(toString(t)) | |
537 | 589 | if ((sh == sh)) | |
538 | 590 | then { | |
539 | 591 | let amt = asInt(invoke(t, "replenishForRepayWithAtokenFor", [user], i.payments)) | |
540 | 592 | if ((amt == amt)) | |
541 | 593 | then { | |
542 | 594 | let c = asInt(invoke(t, "collapseForAmount", [user, amt], nil)) | |
543 | 595 | if ((c == c)) | |
544 | 596 | then if ((amt > c)) | |
545 | 597 | then throw("repaying too much") | |
546 | 598 | else { | |
547 | 599 | let pRw = uS(toString(t), "borrow", user, -(c), -(c)) | |
548 | 600 | if ((pRw == pRw)) | |
549 | 601 | then { | |
550 | 602 | let pRw2 = uS(toString(t), "deposit", user, (amt - c), -(c)) | |
551 | 603 | if ((pRw2 == pRw2)) | |
552 | 604 | then nil | |
553 | 605 | else throw("Strict value is not equal to itself.") | |
554 | 606 | } | |
555 | 607 | else throw("Strict value is not equal to itself.") | |
556 | 608 | } | |
557 | 609 | else throw("Strict value is not equal to itself.") | |
558 | 610 | } | |
559 | 611 | else throw("Strict value is not equal to itself.") | |
560 | 612 | } | |
561 | 613 | else throw("Strict value is not equal to itself.") | |
562 | 614 | } | |
563 | 615 | ||
564 | 616 | ||
565 | 617 | ||
566 | 618 | @Callable(i) | |
567 | 619 | func redeemAtokens () = { | |
568 | 620 | let user = toString(i.caller) | |
569 | 621 | let aTokenId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "bad assetId: WAVES")) | |
570 | 622 | let rsr = reserveBy(aTIdS, aTokenId) | |
571 | 623 | let sh = sR(toString(rsr)) | |
572 | 624 | if ((sh == sh)) | |
573 | 625 | then { | |
574 | 626 | let amt = asInt(invoke(rsr, "redeemAtokensFor", [user], i.payments)) | |
575 | 627 | if ((amt == amt)) | |
576 | 628 | then { | |
577 | 629 | let pRw = uS(toString(rsr), "deposit", user, 0, -(amt)) | |
578 | 630 | if ((pRw == pRw)) | |
579 | 631 | then { | |
580 | 632 | let e = ensureLimit("redeem", rsr, user, amt) | |
581 | 633 | if ((e == e)) | |
582 | 634 | then nil | |
583 | 635 | else throw("Strict value is not equal to itself.") | |
584 | 636 | } | |
585 | 637 | else throw("Strict value is not equal to itself.") | |
586 | 638 | } | |
587 | 639 | else throw("Strict value is not equal to itself.") | |
588 | 640 | } | |
589 | 641 | else throw("Strict value is not equal to itself.") | |
590 | 642 | } | |
591 | 643 | ||
592 | 644 | ||
593 | 645 | ||
594 | 646 | @Callable(i) | |
595 | 647 | func withdraw (assetId,amt) = { | |
596 | 648 | let user = toString(i.caller) | |
597 | - | let result = asInt(wdInternal(user, reserveBy(aIdS, assetId), amt, "withdrawFor")) | |
649 | + | let r = reserveBy(aIdS, assetId) | |
650 | + | let result = asInt(wdInternal(user, r, amt, "withdrawFor")) | |
598 | 651 | if ((result == result)) | |
599 | - | then $Tuple2(validateAfter(user, "withdrawing"), result) | |
652 | + | then { | |
653 | + | let bpu = asInt(validateAfter(user, "withdrawing")) | |
654 | + | if ((bpu == bpu)) | |
655 | + | then { | |
656 | + | let pc = ensureNoProhibited(user, bpu, toString(r)) | |
657 | + | if ((pc == pc)) | |
658 | + | then $Tuple2(nil, result) | |
659 | + | else throw("Strict value is not equal to itself.") | |
660 | + | } | |
661 | + | else throw("Strict value is not equal to itself.") | |
662 | + | } | |
600 | 663 | else throw("Strict value is not equal to itself.") | |
601 | 664 | } | |
602 | 665 | ||
603 | 666 | ||
604 | 667 | ||
605 | 668 | @Callable(i) | |
606 | 669 | func withdraw2 (rsr,amt) = { | |
607 | 670 | let user = toString(i.caller) | |
608 | 671 | let sh = sR(rsr) | |
609 | 672 | if ((sh == sh)) | |
610 | 673 | then { | |
611 | 674 | let rsrAddr = vlR(rsr) | |
612 | 675 | let actual = asInt(invoke(rsrAddr, "withdrawFor", [user, amt], nil)) | |
613 | 676 | if ((actual == actual)) | |
614 | 677 | then { | |
615 | 678 | let pRw = uS(rsr, "deposit", user, -(actual), -(actual)) | |
616 | 679 | if ((pRw == pRw)) | |
617 | 680 | then { | |
618 | - | let e = ensureLimit("withdraw", rsrAddr, user, actual) | |
619 | - | if ((e == e)) | |
620 | - | then if (contains(liquidators, user)) | |
621 | - | then nil | |
622 | - | else validateAfter(user, "withdrawing2") | |
681 | + | let bpu = if (contains(liquidators, user)) | |
682 | + | then 0 | |
683 | + | else { | |
684 | + | let e = ensureLimit("withdraw", rsrAddr, user, actual) | |
685 | + | if ((e == e)) | |
686 | + | then asInt(validateAfter(user, "withdrawing2")) | |
687 | + | else throw("Strict value is not equal to itself.") | |
688 | + | } | |
689 | + | let pc = ensureNoProhibited(user, bpu, rsr) | |
690 | + | if ((pc == pc)) | |
691 | + | then $Tuple2(nil, actual) | |
623 | 692 | else throw("Strict value is not equal to itself.") | |
624 | 693 | } | |
625 | 694 | else throw("Strict value is not equal to itself.") | |
626 | 695 | } | |
627 | 696 | else throw("Strict value is not equal to itself.") | |
628 | 697 | } | |
629 | 698 | else throw("Strict value is not equal to itself.") | |
630 | 699 | } | |
631 | 700 | ||
632 | 701 | ||
633 | 702 | ||
634 | 703 | @Callable(i) | |
635 | 704 | func protectCollateral (rsr) = { | |
636 | 705 | let user = toString(i.caller) | |
637 | 706 | let r = vlR(rsr) | |
638 | 707 | let amt = asInt(wdInternal(user, r, -1, "withdrawToMain")) | |
639 | 708 | if ((amt == amt)) | |
640 | 709 | then { | |
641 | 710 | let assetId = assetStrToId(getStringValue(r, aIdS)) | |
642 | 711 | let p = invoke(protectedReserve, "supplyFor", [user], [AttachedPayment(assetId, amt)]) | |
643 | 712 | if ((p == p)) | |
644 | - | then $Tuple2(nil, amt) | |
713 | + | then { | |
714 | + | let pc = ensureNoProhibited(user, userPower(user)._2, rsr) | |
715 | + | if ((pc == pc)) | |
716 | + | then $Tuple2(nil, amt) | |
717 | + | else throw("Strict value is not equal to itself.") | |
718 | + | } | |
645 | 719 | else throw("Strict value is not equal to itself.") | |
646 | 720 | } | |
647 | 721 | else throw("Strict value is not equal to itself.") | |
648 | 722 | } | |
649 | 723 | ||
650 | 724 | ||
651 | 725 | ||
652 | 726 | @Callable(i) | |
653 | 727 | func withdrawProtectedCollateral (assetId,amt) = { | |
654 | 728 | let user = toString(i.caller) | |
655 | 729 | let a = asInt(invoke(valueOrErrorMessage(protectedReserve, "no protectedReserve"), "withdrawFor", [user, assetId, amt], nil)) | |
656 | 730 | if ((a == a)) | |
657 | - | then validateAfter(user, "withdrawing protected") | |
731 | + | then { | |
732 | + | let va = validateAfter(user, "withdrawing protected") | |
733 | + | if ((va == va)) | |
734 | + | then nil | |
735 | + | else throw("Strict value is not equal to itself.") | |
736 | + | } | |
658 | 737 | else throw("Strict value is not equal to itself.") | |
659 | 738 | } | |
660 | 739 | ||
661 | 740 | ||
662 | 741 | ||
663 | 742 | @Callable(i) | |
664 | 743 | func normalizeCollateral (rsr) = { | |
665 | 744 | let addr = toString(i.caller) | |
666 | 745 | let rA = vlR(rsr) | |
667 | 746 | if ((rA == rA)) | |
668 | 747 | then { | |
669 | 748 | let sh = sR(rsr) | |
670 | 749 | if ((sh == sh)) | |
671 | 750 | then { | |
672 | 751 | let assetIdStr = valueOrErrorMessage(getString(rA, aIdS), ("no assetId in rsv: " + rsr)) | |
673 | 752 | let mc = moveCollateral(addr, assetIdStr, rA, rsr) | |
674 | 753 | if ((mc == mc)) | |
675 | 754 | then nil | |
676 | 755 | else throw("Strict value is not equal to itself.") | |
677 | 756 | } | |
678 | 757 | else throw("Strict value is not equal to itself.") | |
679 | 758 | } | |
680 | 759 | else throw("Strict value is not equal to itself.") | |
681 | 760 | } | |
682 | 761 | ||
683 | 762 | ||
684 | 763 | ||
685 | 764 | @Callable(i) | |
686 | 765 | func borrow (assetId,amt) = { | |
687 | 766 | let user = toString(i.caller) | |
688 | 767 | let rsr = reserveBy(aIdS, assetId) | |
689 | 768 | let sh = sR(toString(rsr)) | |
690 | 769 | if ((sh == sh)) | |
691 | 770 | then { | |
692 | 771 | let a = invoke(rsr, "borrowFor", [user, amt], nil) | |
693 | 772 | if ((a == a)) | |
694 | 773 | then { | |
695 | 774 | let pRw = uS(toString(rsr), "borrow", user, amt, amt) | |
696 | 775 | if ((pRw == pRw)) | |
697 | 776 | then { | |
698 | 777 | let e = ensureLimit("borrow", rsr, user, amt) | |
699 | 778 | if ((e == e)) | |
700 | - | then validateAfter(user, "borrowing") | |
779 | + | then { | |
780 | + | let bpu = asInt(validateAfter(user, "borrowing")) | |
781 | + | if ((bpu == bpu)) | |
782 | + | then { | |
783 | + | let pc = ensureNoProhibitedCollaterals(user) | |
784 | + | if ((pc == pc)) | |
785 | + | then nil | |
786 | + | else throw("Strict value is not equal to itself.") | |
787 | + | } | |
788 | + | else throw("Strict value is not equal to itself.") | |
789 | + | } | |
701 | 790 | else throw("Strict value is not equal to itself.") | |
702 | 791 | } | |
703 | 792 | else throw("Strict value is not equal to itself.") | |
704 | 793 | } | |
705 | 794 | else throw("Strict value is not equal to itself.") | |
706 | 795 | } | |
707 | 796 | else throw("Strict value is not equal to itself.") | |
708 | 797 | } | |
709 | 798 | ||
710 | 799 | ||
711 | 800 | ||
712 | 801 | @Callable(i) | |
713 | 802 | func borrow2 (rsr,amt) = { | |
714 | 803 | let user = toString(i.caller) | |
715 | 804 | let r = vlR(rsr) | |
716 | 805 | let sh = sR(rsr) | |
717 | 806 | if ((sh == sh)) | |
718 | 807 | then { | |
719 | 808 | let a = invoke(r, "borrowFor", [user, amt], nil) | |
720 | 809 | if ((a == a)) | |
721 | 810 | then { | |
722 | 811 | let pRw = uS(rsr, "borrow", user, amt, amt) | |
723 | 812 | if ((pRw == pRw)) | |
724 | 813 | then { | |
725 | 814 | let e = ensureLimit("borrow", r, user, amt) | |
726 | 815 | if ((e == e)) | |
727 | - | then validateAfter(user, "borrowing") | |
816 | + | then { | |
817 | + | let bpu = asInt(validateAfter(user, "borrowing")) | |
818 | + | if ((bpu == bpu)) | |
819 | + | then { | |
820 | + | let pc = ensureNoProhibitedCollaterals(user) | |
821 | + | if ((pc == pc)) | |
822 | + | then nil | |
823 | + | else throw("Strict value is not equal to itself.") | |
824 | + | } | |
825 | + | else throw("Strict value is not equal to itself.") | |
826 | + | } | |
728 | 827 | else throw("Strict value is not equal to itself.") | |
729 | 828 | } | |
730 | 829 | else throw("Strict value is not equal to itself.") | |
731 | 830 | } | |
732 | 831 | else throw("Strict value is not equal to itself.") | |
733 | 832 | } | |
734 | 833 | else throw("Strict value is not equal to itself.") | |
735 | 834 | } | |
736 | 835 | ||
737 | 836 | ||
738 | 837 | ||
739 | 838 | @Callable(i) | |
740 | 839 | func collapse (rsr,amt) = { | |
741 | 840 | let user = toString(i.caller) | |
742 | 841 | let sh = sR(rsr) | |
743 | 842 | if ((sh == sh)) | |
744 | 843 | then { | |
745 | 844 | let c = asInt(invoke(vlR(rsr), "collapseForAmount", [user, amt], nil)) | |
746 | 845 | if ((c == c)) | |
747 | 846 | then { | |
748 | 847 | let pRw = uS(rsr, "borrow", user, -(c), -(c)) | |
749 | 848 | if ((pRw == pRw)) | |
750 | 849 | then { | |
751 | 850 | let pRw2 = uS(rsr, "deposit", user, -(c), -(c)) | |
752 | 851 | if ((pRw2 == pRw2)) | |
753 | 852 | then nil | |
754 | 853 | else throw("Strict value is not equal to itself.") | |
755 | 854 | } | |
756 | 855 | else throw("Strict value is not equal to itself.") | |
757 | 856 | } | |
758 | 857 | else throw("Strict value is not equal to itself.") | |
759 | 858 | } | |
760 | 859 | else throw("Strict value is not equal to itself.") | |
761 | 860 | } | |
762 | 861 | ||
763 | 862 | ||
764 | 863 | ||
765 | 864 | @Callable(i) | |
766 | 865 | func claimEbReward2 (amt,lock) = { | |
767 | 866 | let user = toString(i.caller) | |
768 | 867 | let c = asInt(invoke(ebR, "claimEbRewardFor", [user, amt], nil)) | |
769 | 868 | if ((c == c)) | |
770 | 869 | then lockOrPayout(i.caller, c, lock) | |
771 | 870 | else throw("Strict value is not equal to itself.") | |
772 | 871 | } | |
773 | 872 | ||
774 | 873 | ||
775 | 874 | ||
776 | 875 | @Callable(i) | |
777 | 876 | func claimReward2 (rsr,amt,lock) = { | |
778 | 877 | let v = vlR(rsr) | |
779 | 878 | if ((v == v)) | |
780 | 879 | then { | |
781 | 880 | let user = toString(i.caller) | |
782 | 881 | let c = asInt(invoke(VD, "claimRewardFor", [rsr, user, amt], nil)) | |
783 | 882 | if ((c == c)) | |
784 | 883 | then lockOrPayout(i.caller, c, lock) | |
785 | 884 | else throw("Strict value is not equal to itself.") | |
786 | 885 | } | |
787 | 886 | else throw("Strict value is not equal to itself.") | |
788 | 887 | } | |
789 | 888 | ||
790 | 889 | ||
791 | 890 | ||
792 | 891 | @Callable(i) | |
793 | 892 | func claimAllRewardsAndAllEbAvailable2 (lock,unstakeLegacy) = { | |
794 | 893 | let user = toString(i.caller) | |
795 | 894 | let cr = claimAllRewardsForUser(user) | |
796 | 895 | if ((cr == cr)) | |
797 | 896 | then { | |
798 | 897 | let crLp = claimAllLpRewardsForUser(user) | |
799 | 898 | if ((crLp == crLp)) | |
800 | 899 | then { | |
801 | 900 | let lA = if (unstakeLegacy) | |
802 | 901 | then asInt(invoke(vS, "unstakeAllViresFrom", [user], nil)) | |
803 | 902 | else 0 | |
804 | 903 | if ((lA == lA)) | |
805 | 904 | then lockOrPayout(i.caller, ((cr + crLp) + lA), lock) | |
806 | 905 | else throw("Strict value is not equal to itself.") | |
807 | 906 | } | |
808 | 907 | else throw("Strict value is not equal to itself.") | |
809 | 908 | } | |
810 | 909 | else throw("Strict value is not equal to itself.") | |
811 | 910 | } | |
812 | 911 | ||
813 | 912 | ||
814 | 913 | ||
815 | 914 | @Callable(i) | |
816 | 915 | func disableUseAsCollateral (rsr) = { | |
817 | 916 | let user = toString(i.caller) | |
818 | 917 | let d = invoke(vlR(rsr), "disableUseAsCollateralFor", [user], nil) | |
819 | 918 | if ((d == d)) | |
820 | - | then validateAfter(user, "changing collateral status") | |
919 | + | then { | |
920 | + | let va = validateAfter(user, "changing collateral status") | |
921 | + | if ((va == va)) | |
922 | + | then nil | |
923 | + | else throw("Strict value is not equal to itself.") | |
924 | + | } | |
821 | 925 | else throw("Strict value is not equal to itself.") | |
822 | 926 | } | |
823 | 927 | ||
824 | 928 | ||
825 | 929 | ||
826 | 930 | @Callable(i) | |
827 | 931 | func lockVires (factor,migrate) = { | |
828 | 932 | let user = toString(i.caller) | |
829 | 933 | let a = spfr() | |
830 | 934 | if ((a == a)) | |
831 | 935 | then { | |
832 | 936 | let migrateAmount = if (migrate) | |
833 | 937 | then asInt(invoke(vS, "unstakeAllViresFrom", [user], nil)) | |
834 | 938 | else 0 | |
835 | 939 | let total = (migrateAmount + viresPayment(i)) | |
836 | 940 | let l = invoke(dC, "lockFor", [user, factor], if ((total == 0)) | |
837 | 941 | then nil | |
838 | 942 | else [AttachedPayment(viresAssetId, total)]) | |
839 | 943 | if ((l == l)) | |
840 | 944 | then nil | |
841 | 945 | else throw("Strict value is not equal to itself.") | |
842 | 946 | } | |
843 | 947 | else throw("Strict value is not equal to itself.") | |
844 | 948 | } | |
845 | 949 | ||
846 | 950 | ||
847 | 951 | ||
848 | 952 | @Callable(i) | |
849 | 953 | func withdrawAllPossibleVires () = { | |
850 | 954 | let user = toString(i.caller) | |
851 | 955 | let a = spfr() | |
852 | 956 | if ((a == a)) | |
853 | 957 | then { | |
854 | 958 | let stakerViresAmount = asInt(invoke(vS, "unstakeAllViresFrom", [user], nil)) | |
855 | 959 | if ((stakerViresAmount == stakerViresAmount)) | |
856 | 960 | then { | |
857 | 961 | let u = invoke(dC, "withdrawUnlockedFor", [user], nil) | |
858 | 962 | if ((u == u)) | |
859 | 963 | then [ScriptTransfer(i.caller, stakerViresAmount, viresAssetId)] | |
860 | 964 | else throw("Strict value is not equal to itself.") | |
861 | 965 | } | |
862 | 966 | else throw("Strict value is not equal to itself.") | |
863 | 967 | } | |
864 | 968 | else throw("Strict value is not equal to itself.") | |
865 | 969 | } | |
866 | 970 | ||
867 | 971 | ||
868 | 972 | ||
869 | 973 | @Callable(i) | |
870 | 974 | func claimProtocolProfitFrom (from,relock) = { | |
871 | 975 | let user = toString(i.caller) | |
872 | 976 | let a = spfr() | |
873 | 977 | if ((a == a)) | |
874 | 978 | then { | |
875 | 979 | let u = invoke(dC, "claimProfit", [from, user, relock], nil) | |
876 | 980 | if ((u == u)) | |
877 | 981 | then nil | |
878 | 982 | else throw("Strict value is not equal to itself.") | |
879 | 983 | } | |
880 | 984 | else throw("Strict value is not equal to itself.") | |
881 | 985 | } | |
882 | 986 | ||
883 | 987 | ||
884 | 988 | ||
885 | 989 | @Callable(i) | |
886 | 990 | func withdrawUnlockedVires () = { | |
887 | 991 | let a = spfr() | |
888 | 992 | if ((a == a)) | |
889 | 993 | then { | |
890 | 994 | let u = invoke(dC, "withdrawUnlockedFor", [toString(i.caller)], nil) | |
891 | 995 | if ((u == u)) | |
892 | 996 | then nil | |
893 | 997 | else throw("Strict value is not equal to itself.") | |
894 | 998 | } | |
895 | 999 | else throw("Strict value is not equal to itself.") | |
896 | 1000 | } | |
897 | 1001 | ||
898 | 1002 | ||
899 | 1003 | ||
900 | 1004 | @Callable(i) | |
901 | 1005 | func lockSupply (reserve,period) = { | |
902 | 1006 | let rsr = vlR(reserve) | |
903 | 1007 | let user = toString(i.caller) | |
904 | 1008 | let checks = ensureNoProtected(user) | |
905 | 1009 | if ((checks == checks)) | |
906 | 1010 | then { | |
907 | 1011 | let aTokenId = value(assetStrToId(valueOrErrorMessage(getString(rsr, "aTokenId"), "no aTokenId in reserve"))) | |
908 | 1012 | let migration = if ((size(i.payments) == 0)) | |
909 | 1013 | then unit | |
910 | 1014 | else if ((i.payments[0].assetId == aTokenId)) | |
911 | 1015 | then unit | |
912 | 1016 | else if ((i.payments[0].assetId == assetStrToId(valueOrErrorMessage(getString(rsr, "assetId"), "no assetId in reserve")))) | |
913 | 1017 | then { | |
914 | 1018 | let sh = sR(reserve) | |
915 | 1019 | if ((sh == sh)) | |
916 | 1020 | then { | |
917 | 1021 | let action = invoke(rsr, "depositFor", [user, true], i.payments) | |
918 | 1022 | if ((action == action)) | |
919 | 1023 | then { | |
920 | 1024 | let amt = i.payments[0].amount | |
921 | 1025 | let pRw = uS(reserve, "deposit", user, amt, amt) | |
922 | 1026 | if ((pRw == pRw)) | |
923 | 1027 | then unit | |
924 | 1028 | else throw("Strict value is not equal to itself.") | |
925 | 1029 | } | |
926 | 1030 | else throw("Strict value is not equal to itself.") | |
927 | 1031 | } | |
928 | 1032 | else throw("Strict value is not equal to itself.") | |
929 | 1033 | } | |
930 | 1034 | else throw("bad asset attached") | |
931 | 1035 | if ((migration == migration)) | |
932 | 1036 | then { | |
933 | 1037 | let mint = { | |
934 | 1038 | let sh = sR(reserve) | |
935 | 1039 | if ((sh == sh)) | |
936 | 1040 | then { | |
937 | 1041 | let actual = asInt(invoke(rsr, "mintAtokenForTo", [user, -1, toString(this)], nil)) | |
938 | 1042 | if ((actual == actual)) | |
939 | 1043 | then { | |
940 | 1044 | let pRw = uS(toString(rsr), "deposit", user, -(actual), 0) | |
941 | 1045 | if ((pRw == pRw)) | |
942 | - | then validateAfter(user, "lock-minting") | |
1046 | + | then { | |
1047 | + | let va = validateAfter(user, "lock-minting") | |
1048 | + | if ((va == va)) | |
1049 | + | then nil | |
1050 | + | else throw("Strict value is not equal to itself.") | |
1051 | + | } | |
943 | 1052 | else throw("Strict value is not equal to itself.") | |
944 | 1053 | } | |
945 | 1054 | else throw("Strict value is not equal to itself.") | |
946 | 1055 | } | |
947 | 1056 | else throw("Strict value is not equal to itself.") | |
948 | 1057 | } | |
949 | 1058 | if ((mint == mint)) | |
950 | 1059 | then { | |
951 | 1060 | let balance = assetBalance(this, aTokenId) | |
952 | 1061 | let r = invoke(locker, "lockLP", [user, period], [AttachedPayment(aTokenId, balance)]) | |
953 | 1062 | if ((r == r)) | |
954 | 1063 | then $Tuple2(nil, balance) | |
955 | 1064 | else throw("Strict value is not equal to itself.") | |
956 | 1065 | } | |
957 | 1066 | else throw("Strict value is not equal to itself.") | |
958 | 1067 | } | |
959 | 1068 | else throw("Strict value is not equal to itself.") | |
960 | 1069 | } | |
961 | 1070 | else throw("Strict value is not equal to itself.") | |
962 | 1071 | } | |
963 | 1072 | ||
964 | 1073 |
github/deemru/w8io/786bc32 215.87 ms ◑