tx · 8pXcuY2GYuSRsU9gNUNXJDLtWZxPdPXS4n26cmhdGMJe

3PJ6iR5X1PT2rZcNmbqByKuh7k8mtj5wVGw:  -0.01300000 Waves

2023.01.25 13:25 [3485882] smart account 3PJ6iR5X1PT2rZcNmbqByKuh7k8mtj5wVGw > SELF 0.00000000 Waves

{ "type": 13, "id": "8pXcuY2GYuSRsU9gNUNXJDLtWZxPdPXS4n26cmhdGMJe", "fee": 1300000, "feeAssetId": null, "timestamp": 1674642338396, "version": 1, "sender": "3PJ6iR5X1PT2rZcNmbqByKuh7k8mtj5wVGw", "senderPublicKey": "6pk8htkepkqL8WkHrnvRr2tu1r3NC7hfLTJEtiQDbiKF", "proofs": [ "3bhgoXo75bERa8W1fHhRL2xESsA1QJ8NoA9AsdwYcP9MnTtouTeiCVdEVzG1kE1FHPrE4SKkRfxbbk3a24qJNLKk" ], "script": "base64:BgIjCAISAwoBCBIGCgQICAgBEgYKBAgICAESBAoCCAgSBAoCCAgjAAtmYWN0b3JzQmFzZQDoBwEDZkNpAwV2YWx1ZQludW1lcmF0b3ILZGVub21pbmF0b3IEBGNhbmQJAGsDBQV2YWx1ZQUJbnVtZXJhdG9yBQtkZW5vbWluYXRvcgQBRACz5pOoCwQFZXhhY3QJAAACCQBqAgkAaAIJAGoCBQRjYW5kBQFECQBqAgULZGVub21pbmF0b3IFAUQFAUQJAGoCCQBoAgkAagIFBXZhbHVlBQFECQBqAgUJbnVtZXJhdG9yBQFEBQFEAwUFZXhhY3QFBGNhbmQJAGQCBQRjYW5kAAEBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQEFYXNJbnQBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgNJbnQEA2ludAUHJG1hdGNoMAUDaW50CQACAQIEbTI6MQEGYXNJbnQzAQV2YWx1ZQQHJG1hdGNoMAUFdmFsdWUDCQABAgUHJG1hdGNoMAIPKEludCwgSW50LCBJbnQpBAF4BQckbWF0Y2gwBQF4BAF0BQckbWF0Y2gwCQACAQIBMgERYXNVc2VyQmFsYW5jZURhdGEBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAiIoSW50LCBJbnQsIEludCwgSW50LCBJbnQsIEJvb2xlYW4pBAF4BQckbWF0Y2gwBQF4BAF0BQckbWF0Y2gwCQACAQIBMwALY29uZmlnU3RvcmUCBmNvbmZpZwANcmVzZXJ2ZXNTdG9yZQIIcmVzZXJ2ZXMABWFUSWRTAghhVG9rZW5JZAAEYUlkUwIHYXNzZXRJZAANY29uZmlnQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwULY29uZmlnU3RvcmUAC3Jlc2VydmVzU3RyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwIQcHJpbWFyeV9yZXNlcnZlcwIWbm8gcmVzZXJ2ZXMgcmVnaXN0ZXJlZAAIcmVzZXJ2ZXMJALwJAgULcmVzZXJ2ZXNTdHICAXwAA21WRAQHJG1hdGNoMAkAnQgCBQ1jb25maWdBZGRyZXNzAhF2aXJlc19kaXN0cmlidXRvcgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWQFByRtYXRjaDAJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAWQFBHVuaXQBEGFzc2V0SWRPZlJlc2VydmUBA3JzcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFA3JzcgUEYUlkUwIVbm8gYXNzZXRJZCBpbiByZXNlcnZlARBjb2xsYXRlcmFsRmFjdG9yAQNyc3IJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIJARBhc3NldElkT2ZSZXNlcnZlAQUDcnNyAhFfQ29sbGF0ZXJhbEZhY3RvcgIEbm8gMQEUbGlxdWlkYXRpb25UaHJlc2hvbGQBA3JzcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MJAKwCAgkBEGFzc2V0SWRPZlJlc2VydmUBBQNyc3ICFV9MaXF1aWRhdGlvblRocmVzaG9sZAIEbm8gMgESbGlxdWlkYXRpb25QZW5hbHR5AQdhc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwkArAICBQdhc3NldElkAhNfTGlxdWlkYXRpb25QZW5hbHR5AgRubyAzABZhY2NvdW50SGVhbHRoVGhyZXNob2xkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIYYWNjb3VudF9oZWFsdGhfdGhyZXNob2xkAgRubyA0ABRhY2NvdW50SGVhbHRoT3ZlcmxhcAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCFmFjY291bnRfaGVhbHRoX292ZXJsYXACBG5vIDUAD2NvbGxhcHNlUGVuYWx0eQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCEGNvbGxhcHNlX3BlbmFsdHkCBG5vIDYAC2xpcXVpZGF0b3JzCQELdmFsdWVPckVsc2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCC2xpcXVpZGF0b3JzAgABA3ZsUgEBcgMJAQhjb250YWlucwIFC3Jlc2VydmVzU3RyBQFyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUBcgINbWFpbjogYmFkIHJzcgkAAgEJAKwCAgIMdW5rbm93biByc3I6BQFyAQt1c2VyQmFsYW5jZQIDcnNyBHVzZXIJARFhc1VzZXJCYWxhbmNlRGF0YQEJAPwHBAUDcnNyAgt1c2VyQmFsYW5jZQkAzAgCBQR1c2VyBQNuaWwFA25pbAAObWF5YmVQcm90ZWN0ZWQEByRtYXRjaDAJAJ0IAgUNY29uZmlnQWRkcmVzcwIRcHJvdGVjdGVkX3Jlc2VydmUDCQABAgUHJG1hdGNoMAIGU3RyaW5nBANwZHMFByRtYXRjaDAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQNwZHMCDWJhZCBwcm90ZWN0ZWQFBHVuaXQBCXVzZXJQb3dlcgEEdXNlcgQQcHJvdGVjdGVkRGVwb3NpdAQHJG1hdGNoMAUObWF5YmVQcm90ZWN0ZWQDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQCcGEFByRtYXRjaDAJAQVhc0ludAEJAPwHBAUCcGECC2JvcnJvd1Bvd2VyCQDMCAIFBHVzZXIFA25pbAUDbmlsAAAKAQRmb2xkAgZ0b3RhbHMBcgQLJHQwMjkzODI5ODQFBnRvdGFscwQGdG90YWxECAULJHQwMjkzODI5ODQCXzEEBnRvdGFsQggFCyR0MDI5MzgyOTg0Al8yBA9udW1iZXJPZkJvcnJvd3MIBQskdDAyOTM4Mjk4NAJfMwQDcnNyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUBcgIPcnNyIGJhZCBhZGRyZXNzBAJjZgkBEGNvbGxhdGVyYWxGYWN0b3IBBQNyc3IEAmx0CQEUbGlxdWlkYXRpb25UaHJlc2hvbGQBBQNyc3IECyR0MDMxMzgzMjIyCQELdXNlckJhbGFuY2UCBQNyc3IFBHVzZXIEBXRva2VuCAULJHQwMzEzODMyMjICXzEEBWFzc2V0CAULJHQwMzEzODMyMjICXzIECmRlcG9zaXRVc2QIBQskdDAzMTM4MzIyMgJfMwQEZGVidAgFCyR0MDMxMzgzMjIyAl80BAdkZWJ0VXNkCAULJHQwMzEzODMyMjICXzUEDGFzQ29sbGF0ZXJhbAgFCyR0MDMxMzgzMjIyAl82BAx0b3RhbEJvcnJvd3MJAGQCBQ9udW1iZXJPZkJvcnJvd3MDCQBmAgUEZGVidAAAAAEAAAQTZWZmZWN0aXZlRGVwb3NpdFVzZAMFDGFzQ29sbGF0ZXJhbAUKZGVwb3NpdFVzZAAABApvdmVybGFwVXNkCQCXAwEJAMwIAgUHZGVidFVzZAkAzAgCBRNlZmZlY3RpdmVEZXBvc2l0VXNkBQNuaWwEDW92ZXJsYXBDaGFyZ2UJAQNmQ2kDBQpvdmVybGFwVXNkBRRhY2NvdW50SGVhbHRoT3ZlcmxhcAULZmFjdG9yc0Jhc2UDCQBmAgUHZGVidFVzZAUTZWZmZWN0aXZlRGVwb3NpdFVzZAkAlQoDBQZ0b3RhbEQJAGQCCQBkAgUGdG90YWxCCQBrAwkAZQIFB2RlYnRVc2QFE2VmZmVjdGl2ZURlcG9zaXRVc2QFC2ZhY3RvcnNCYXNlBQJsdAUNb3ZlcmxhcENoYXJnZQUMdG90YWxCb3Jyb3dzCQCVCgMJAGQCBQZ0b3RhbEQJAGsDCQBlAgUTZWZmZWN0aXZlRGVwb3NpdFVzZAUHZGVidFVzZAUCY2YFC2ZhY3RvcnNCYXNlCQBkAgUGdG90YWxCBQ1vdmVybGFwQ2hhcmdlBQx0b3RhbEJvcnJvd3MEAXIKAAIkbAUIcmVzZXJ2ZXMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCVCgMFEHByb3RlY3RlZERlcG9zaXQAAAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQRmb2xkAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAyMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQDAwkAZgIFEHByb3RlY3RlZERlcG9zaXQAAAkAZgIIBQFyAl8zAAQHCQACAQIeY2FuJ3QgaGF2ZSBtb3JlIHRoYW4gNCBib3Jyb3dzBQFyAQ1nZXRVc2VySGVhbHRoAQdhY2NvdW50BAskdDAzOTc3NDAyOAkBBmFzSW50MwEJAQl1c2VyUG93ZXIBBQdhY2NvdW50BAJicAgFCyR0MDM5Nzc0MDI4Al8xBANicHUIBQskdDAzOTc3NDAyOAJfMgQGaWdub3JlCAULJHQwMzk3NzQwMjgCXzMJAKwCAgkArAICCQCsAgICA2JwOgkApAMBBQJicAIGLCBicHU6CQCkAwEFA2JwdQENdmFsaWRhdGVBZnRlcgIEdXNlcgJvcAQLJHQwNDEzOTQxNzAJAQl1c2VyUG93ZXIBBQR1c2VyBAJicAgFCyR0MDQxMzk0MTcwAl8xBANicHUIBQskdDA0MTM5NDE3MAJfMgQJYWNjSGVhbHRoCQBpAgkAaAIJAGUCBQJicAUDYnB1BQtmYWN0b3JzQmFzZQUCYnADAwkAAAIFAmJwAAAJAAACBQNicHUAAAcFA25pbAMDCQAAAgUCYnAAAAkAZgIFA2JwdQAABwkAAgEJAKwCAgkArAICBQJvcAIsOiBicmVhY2hpbmcgbGlxdWlkYXRpb24gdGhyZXNob2xkKGJwPTAsIGJwdT0JAKQDAQUDYnB1AwkAZgIFFmFjY291bnRIZWFsdGhUaHJlc2hvbGQFCWFjY0hlYWx0aAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUCb3ACJTogYnJlYWNoaW5nIGxpcXVpZGF0aW9uIHRocmVzaG9sZChicD0JAKQDAQUCYnACBiwgYnB1PQkApAMBBQNicHUCCSwgaGVhbHRoPQkApAMBBQlhY2NIZWFsdGgCASkFA25pbAEMdXBkYXRlU3RyZWFtBQNyc3IGYWN0aW9uBHVzZXIKdXNlckNoYW5nZQxzdHJlYW1DaGFuZ2UEByRtYXRjaDAFA21WRAMJAAECBQckbWF0Y2gwAgdBZGRyZXNzBAFhBQckbWF0Y2gwCQD8BwQFAWECCG9uQWN0aW9uCQDMCAIFA3JzcgkAzAgCBQZhY3Rpb24JAMwIAgUEdXNlcgkAzAgCBQp1c2VyQ2hhbmdlCQDMCAIFDHN0cmVhbUNoYW5nZQUDbmlsBQNuaWwFBHVuaXQBCm1vdmVTdHJlYW0FA3JzcgZhY3Rpb24EZnJvbQZzdHJpbmcDYW10BAckbWF0Y2gwBQNtVkQDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQBYQUHJG1hdGNoMAkA/AcEBQFhAgRtb3ZlCQDMCAIFA3JzcgkAzAgCBQZhY3Rpb24JAMwIAgUEZnJvbQkAzAgCBQZzdHJpbmcJAMwIAgUDYW10BQNuaWwFA25pbAUEdW5pdAELc3luY1Jld2FyZHMBA3JzcgQHJG1hdGNoMAUDbVZEAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEAWEFByRtYXRjaDAJAPwHBAUBYQIKc3luY0hlaWdodAkAzAgCBQNyc3IFA25pbAUDbmlsBQR1bml0AQtwdXJlQXNzZXRJZAEHYXNzZXRJZAQBaQkAkQMCCQC1CQIFB2Fzc2V0SWQCAV8AAAMJAAACBQFpAgVXQVZFUwUEdW5pdAkA2QQBBQFpAQ5tb3ZlQ29sbGF0ZXJhbAQEYWRkcghhc3NldFN0cgNyc3IKcmVzZXJ2ZVN0cgQQcHJvdGVjdGVkUmVzZXJ2ZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBQ5tYXliZVByb3RlY3RlZAIQbm8gcHJvdGVjdGVkIHJzcgQDYW10CQEFYXNJbnQBCQD8BwQFEHByb3RlY3RlZFJlc2VydmUCDndpdGhkcmF3VG9NYWluCQDMCAIFBGFkZHIJAMwIAgUIYXNzZXRTdHIFA25pbAUDbmlsAwkAAAIFA2FtdAUDYW10BAdhc3NldElkAwkAAAIFCGFzc2V0U3RyAgVXQVZFUwUEdW5pdAkA2QQBBQhhc3NldFN0cgQDZGVwCQD8BwQFA3JzcgIKZGVwb3NpdEZvcgkAzAgCBQRhZGRyCQDMCAIGBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQtwdXJlQXNzZXRJZAEFCGFzc2V0U3RyBQNhbXQFA25pbAMJAAACBQNkZXAFA2RlcAQEcHJvcAkBDHVwZGF0ZVN0cmVhbQUFCnJlc2VydmVTdHICB2RlcG9zaXQFBGFkZHIFA2FtdAUDYW10AwkAAAIFBHByb3AFBHByb3AFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BFHRyYW5zZmVyRGVidEludGVybmFsBgpsaXF1aWRhdG9yDWJvcnJvd1Jlc2VydmURY29sbGF0ZXJhbFJlc2VydmUIYm9ycm93ZXITbGlxdWlkYXRlRGVidEFtb3VudA1mcm9tUHJvdGVjdGVkBANzaDEJAQtzeW5jUmV3YXJkcwEFDWJvcnJvd1Jlc2VydmUDCQAAAgUDc2gxBQNzaDEEA3NoMgkBC3N5bmNSZXdhcmRzAQURY29sbGF0ZXJhbFJlc2VydmUDCQAAAgUDc2gyBQNzaDIDCQBnAgAABRNsaXF1aWRhdGVEZWJ0QW1vdW50CQACAQITbm9uLXBvc2l0aXZlIGFtb3VudAMJAAACBRFjb2xsYXRlcmFsUmVzZXJ2ZQUNYm9ycm93UmVzZXJ2ZQkAAgECB2NyID0gYnIDCQAAAgUKbGlxdWlkYXRvcgUIYm9ycm93ZXIJAAIBAgRzZWxmBAskdDA2NDUwNjQ4NQkBCXVzZXJQb3dlcgEFCGJvcnJvd2VyBAJicAgFCyR0MDY0NTA2NDg1Al8xBANicHUIBQskdDA2NDUwNjQ4NQJfMgMJAGYCBQJicAUDYnB1CQACAQkArAICAhEgaGVhbHRoeSB1c2VyOiB1PQUIYm9ycm93ZXIEAmJyCQEDdmxSAQUNYm9ycm93UmVzZXJ2ZQQCY3IJAQN2bFIBBRFjb2xsYXRlcmFsUmVzZXJ2ZQQLYm9ycm93QXNzZXQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQJicgUEYUlkUwIQbm8gYXNzZXRJZCBpbiBicgQPY29sbGF0ZXJhbEFzc2V0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUCY3IFBGFJZFMCEG5vIGFzc2V0SWQgaW4gY3IEDGlzQ29sbGF0ZXJhbAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQJjcgkArAICBQhib3Jyb3dlcgIQX3VzZUFzQ29sbGF0ZXJhbAcDCQAAAgUMaXNDb2xsYXRlcmFsBQxpc0NvbGxhdGVyYWwDAwkBASEBBQ1mcm9tUHJvdGVjdGVkCQEBIQEFDGlzQ29sbGF0ZXJhbAcJAAIBAh5kZXBvc2l0IG5vdCB1c2VkIGFzIGNvbGxhdGVyYWwECyR0MDY5NTU3MDQ1CQELdXNlckJhbGFuY2UCBQJicgUIYm9ycm93ZXIDCQAAAgULJHQwNjk1NTcwNDUFCyR0MDY5NTU3MDQ1BAt1c2VyRGVidFVzZAgFCyR0MDY5NTU3MDQ1Al81BAh1c2VyRGVidAgFCyR0MDY5NTU3MDQ1Al80BAx1c2VyQXNzZXRVc2QIBQskdDA2OTU1NzA0NQJfMwQJdXNlckFzc2V0CAULJHQwNjk1NTcwNDUCXzIEBmlnbm9yZQgFCyR0MDY5NTU3MDQ1Al8xAwkAZwIFCXVzZXJBc3NldAUIdXNlckRlYnQJAAIBAg5wb3NpdGl2ZSBzYWxkbwMJAGcCAAAFE2xpcXVpZGF0ZURlYnRBbW91bnQJAAIBAgU8PSAwPgQGZmFjdG9yCQELdmFsdWVPckVsc2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MJAKwCAgUPY29sbGF0ZXJhbEFzc2V0AhpfTGlxdWlkYXRpb25GcmFjdGlvbkZhY3RvcgACAwkAZgIJAGgCBRNsaXF1aWRhdGVEZWJ0QW1vdW50BQZmYWN0b3IJAGUCBQh1c2VyRGVidAUJdXNlckFzc2V0CQACAQkArAICCQCsAgIJAKwCAgIibW9yZSB0aGFuIDEvZmFjdG9yIG9mIHNhbGRvOiBkZWJ0PQkApAMBBQh1c2VyRGVidAIYLCBsaXF1aWRhdGVEZWJ0QW1vdW50ID0gCQCkAwEFE2xpcXVpZGF0ZURlYnRBbW91bnQEDWNvbGxhdGVyYWxVc2QJAGsDBRNsaXF1aWRhdGVEZWJ0QW1vdW50BQt1c2VyRGVidFVzZAUIdXNlckRlYnQEDXBlbmFsdGl6ZWRVc2QJAGsDBQ1jb2xsYXRlcmFsVXNkCQBkAgULZmFjdG9yc0Jhc2UJARJsaXF1aWRhdGlvblBlbmFsdHkBBQtib3Jyb3dBc3NldAULZmFjdG9yc0Jhc2UEAm1jAwUNZnJvbVByb3RlY3RlZAkBDm1vdmVDb2xsYXRlcmFsBAUIYm9ycm93ZXIFD2NvbGxhdGVyYWxBc3NldAUCY3IFEWNvbGxhdGVyYWxSZXNlcnZlBQR1bml0AwkAAAIFAm1jBQJtYwQVdHJhbnNmZXJyZWRDb2xsYXRlcmFsCQEFYXNJbnQBCQD8BwQFAmNyAhJ0cmFuc2ZlckFUb2tlbnNGb3IJAMwIAgUIYm9ycm93ZXIJAMwIAgUKbGlxdWlkYXRvcgkAzAgCBQ1wZW5hbHRpemVkVXNkBQNuaWwFA25pbAMJAAACBRV0cmFuc2ZlcnJlZENvbGxhdGVyYWwFFXRyYW5zZmVycmVkQ29sbGF0ZXJhbAQEcFJ3MQkBCm1vdmVTdHJlYW0FBRFjb2xsYXRlcmFsUmVzZXJ2ZQIHZGVwb3NpdAUIYm9ycm93ZXIFCmxpcXVpZGF0b3IFFXRyYW5zZmVycmVkQ29sbGF0ZXJhbAMJAAACBQRwUncxBQRwUncxBA90cmFuc2ZlcnJlZERlYnQJAQVhc0ludAEJAPwHBAUCYnICD3RyYW5zZmVyRGVidEZvcgkAzAgCBQhib3Jyb3dlcgkAzAgCBQpsaXF1aWRhdG9yCQDMCAIFE2xpcXVpZGF0ZURlYnRBbW91bnQFA25pbAUDbmlsAwkAAAIFD3RyYW5zZmVycmVkRGVidAUPdHJhbnNmZXJyZWREZWJ0BARwUncyCQEKbW92ZVN0cmVhbQUFDWJvcnJvd1Jlc2VydmUCBmJvcnJvdwUIYm9ycm93ZXIFCmxpcXVpZGF0b3IFD3RyYW5zZmVycmVkRGVidAMJAAACBQRwUncyBQRwUncyBBVsaXF1aWRhdG9ySGVhbHRoQ2hlY2sDCQEIY29udGFpbnMCBQtsaXF1aWRhdG9ycwUKbGlxdWlkYXRvcgUDbmlsCQENdmFsaWRhdGVBZnRlcgIFCmxpcXVpZGF0b3ICEXRyYW5zZmVycmluZyBkZWJ0AwkAAAIFFWxpcXVpZGF0b3JIZWFsdGhDaGVjawUVbGlxdWlkYXRvckhlYWx0aENoZWNrCQCUCgIFFWxpcXVpZGF0b3JIZWFsdGhDaGVjawUVdHJhbnNmZXJyZWRDb2xsYXRlcmFsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARVmb3JjZUNvbGxhcHNlSW50ZXJuYWwECmxpcXVpZGF0b3IDcnNyCGJvcnJvd2VyDWZyb21Qcm90ZWN0ZWQEDnJlc2VydmVBZGRyZXNzCQEDdmxSAQUDcnNyAwkAAAIFDnJlc2VydmVBZGRyZXNzBQ5yZXNlcnZlQWRkcmVzcwQCc2gJAQtzeW5jUmV3YXJkcwEFA3JzcgMJAAACBQJzaAUCc2gDCQAAAgUKbGlxdWlkYXRvcgUIYm9ycm93ZXIJAAIBAiRjYW4ndCBjb2xsYXBzZSBzZWxmIGluIHRoaXMgZnVuY3Rpb24ECyR0MDg2OTM4NzI4CQEJdXNlclBvd2VyAQUIYm9ycm93ZXIEAmJwCAULJHQwODY5Mzg3MjgCXzEEA2JwdQgFCyR0MDg2OTM4NzI4Al8yAwkAZgIFAmJwBQNicHUJAAIBCQCsAgICImNhbid0IGZvcmNlIGNvbGxhcHNlIGhlYWx0aHkgdXNlciAFCGJvcnJvd2VyBAVhc3NldAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDnJlc2VydmVBZGRyZXNzBQRhSWRTCQCsAgICGG5vIGFzc2V0SWQgZmllbGQgaW4gcnNyIAUDcnNyBAJtYwMFDWZyb21Qcm90ZWN0ZWQJAQ5tb3ZlQ29sbGF0ZXJhbAQFCGJvcnJvd2VyBQVhc3NldAUOcmVzZXJ2ZUFkZHJlc3MFA3JzcgUEdW5pdAMJAAACBQJtYwUCbWMECyR0MDkwMzA5MTM4CQELdXNlckJhbGFuY2UCBQ5yZXNlcnZlQWRkcmVzcwUIYm9ycm93ZXIDCQAAAgULJHQwOTAzMDkxMzgFCyR0MDkwMzA5MTM4BAt1c2VyRGVidFVzZAgFCyR0MDkwMzA5MTM4Al81BAh1c2VyRGVidAgFCyR0MDkwMzA5MTM4Al80BAx1c2VyQXNzZXRVc2QIBQskdDA5MDMwOTEzOAJfMwQPYm9ycm93ZXJEZXBvc2l0CAULJHQwOTAzMDkxMzgCXzIEBmlnbm9yZQgFCyR0MDkwMzA5MTM4Al8xBA1wZW5hbHRpemVkVXNkCQBrAwkAlwMBCQDMCAIFDHVzZXJBc3NldFVzZAkAzAgCBQt1c2VyRGVidFVzZAUDbmlsBQ9jb2xsYXBzZVBlbmFsdHkFC2ZhY3RvcnNCYXNlBBF0cmFuc2ZlcnJlZEFzc2V0cwkBBWFzSW50AQkA/AcEBQ5yZXNlcnZlQWRkcmVzcwISdHJhbnNmZXJBVG9rZW5zRm9yCQDMCAIFCGJvcnJvd2VyCQDMCAIFCmxpcXVpZGF0b3IJAMwIAgUNcGVuYWx0aXplZFVzZAUDbmlsBQNuaWwDCQAAAgURdHJhbnNmZXJyZWRBc3NldHMFEXRyYW5zZmVycmVkQXNzZXRzBARwUncxCQEKbW92ZVN0cmVhbQUFA3JzcgIHZGVwb3NpdAUIYm9ycm93ZXIFCmxpcXVpZGF0b3IFEXRyYW5zZmVycmVkQXNzZXRzAwkAAAIFBHBSdzEFBHBSdzEECWNvbGxhcHNlZAkBBWFzSW50AQkA/AcEBQ5yZXNlcnZlQWRkcmVzcwILY29sbGFwc2VGb3IJAMwIAgUIYm9ycm93ZXIFA25pbAUDbmlsAwkAAAIFCWNvbGxhcHNlZAUJY29sbGFwc2VkBARwUncyCQEMdXBkYXRlU3RyZWFtBQUDcnNyAgZib3Jyb3cFCGJvcnJvd2VyCQEBLQEFCWNvbGxhcHNlZAkBAS0BBQljb2xsYXBzZWQDCQAAAgUEcFJ3MgUEcFJ3MgQEcFJ3MwkBDHVwZGF0ZVN0cmVhbQUFA3JzcgIHZGVwb3NpdAUIYm9ycm93ZXIJAQEtAQUJY29sbGFwc2VkCQEBLQEFCWNvbGxhcHNlZAMJAAACBQRwUnczBQRwUnczBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4FAWkBCmluaXRpYWxpemUBAmNhCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgULY29uZmlnU3RvcmUFAmNhBQNuaWwBaQEMdHJhbnNmZXJEZWJ0BAJicgJjcgFiAmxhCQEUdHJhbnNmZXJEZWJ0SW50ZXJuYWwGCQClCAEIBQFpBmNhbGxlcgUCYnIFAmNyBQFiBQJsYQcBaQENdHJhbnNmZXJEZWJ0MgQCYnICY3IBYgJsYQkBFHRyYW5zZmVyRGVidEludGVybmFsBgkApQgBCAUBaQZjYWxsZXIFAmJyBQJjcgUBYgUCbGEGAWkBDWZvcmNlQ29sbGFwc2UCAXIBYgkBFWZvcmNlQ29sbGFwc2VJbnRlcm5hbAQJAKUIAQgFAWkGY2FsbGVyBQFyBQFiBwFpAQ5mb3JjZUNvbGxhcHNlMgIBcgFiCQEVZm9yY2VDb2xsYXBzZUludGVybmFsBAkApQgBCAUBaQZjYWxsZXIFAXIFAWIGAQJ0eAEGdmVyaWZ5AAQSbWF5YmVPcmFjbGVBZGRyZXNzBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCDm9yYWNsZV9hZGRyZXNzAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkApggBBQFzBQR1bml0BAZIRUlHSFQFBmhlaWdodAQEQkFTRQDoBwQLcXVvcnVtUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzAhVwcm9wb3NhbF9xdW9ydW1fcmF0aW8CInByb3Bvc2FsUXVvcnVtUmF0aW8gaXMgbm90IGRlZmluZWQEC3Bhc3NlZFJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcGFzc2VkX3JhdGlvAiVwcm9wb3NhbFRocmVzaG9sZFJhdGlvIGlzIG5vdCBkZWZpbmVkBA5nVmlyZXNDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhJkaXZpZGVuZHNfY29udHJhY3QCFW5vIGRpdmlkZW5kc19jb250cmFjdAIaaW52YWxpZCBkaXZpZGVuZHNfY29udHJhY3QEDnZvdGluZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD3ZvdGluZ19jb250cmFjdAISbm8gdm90aW5nX2NvbnRyYWN0AhdpbnZhbGlkIHZvdGluZ19jb250cmFjdAQCaWQJANgEAQgFAnR4AmlkBAh2b3Rlc1llcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAg1wcm9wb3NhbF95ZXNfBQJpZAAABAd2b3Rlc05vCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDHByb3Bvc2FsX25vXwUCaWQAAAQOcHJvcG9zYWxIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhBwcm9wb3NhbF9oZWlnaHRfBQJpZAIXcHJvcG9zYWwgbm90IHJlZ2lzdGVyZWQECmFwcGx5U3RhcnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIUcHJvcG9zYWxfYXBwbHlzdGFydF8FAmlkAAAECGFwcGx5RW5kCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEnByb3Bvc2FsX2FwcGx5ZW5kXwUCaWQAAAQLdG90YWxHVmlyZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfZ3ZpcmVzXwUCaWQAAAQHZW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzAh1vcF9nb3Zlcm5hbmNlX2FwcGx5X3R4X3BhdXNlZAcEB3ZvdGVZZXMFCHZvdGVzWWVzBAZ2b3RlTm8FB3ZvdGVzTm8ECnRvdGFsVm90ZXMJAGQCBQd2b3RlWWVzBQZ2b3RlTm8ECWhhc1F1b3J1bQkAZwIJAGkCCQBoAgUKdG90YWxWb3RlcwUEQkFTRQULdG90YWxHVmlyZXMFC3F1b3J1bVJhdGlvBAloYXNQYXNzZWQJAGcCCQBpAgkAaAIFB3ZvdGVZZXMFBEJBU0UFCnRvdGFsVm90ZXMFC3Bhc3NlZFJhdGlvBAh0b29FYXJseQkAZwIFCmFwcGx5U3RhcnQFBkhFSUdIVAQHdG9vTGF0ZQkAZwIFBkhFSUdIVAUIYXBwbHlFbmQECXRpbWVEZWJ1ZwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhFwcm9wb3NhbEhlaWdodCA9IAkApAMBBQ5wcm9wb3NhbEhlaWdodAIPLCBhcHBseVN0YXJ0ID0gCQCkAwEFCmFwcGx5U3RhcnQCDSwgYXBwbHlFbmQgPSAJAKQDAQUIYXBwbHlFbmQCCywgSEVJR0hUID0gCQCkAwEFBkhFSUdIVAQIYnlWb3RpbmcDCQEBIQEFB2VuYWJsZWQJAAIBAit0eCBhcHBsaWNhdGlvbiB0aHJvdyBnb3Zlcm5hbmNlIG5vdCBlbmFibGVkAwUIdG9vRWFybHkJAAIBCQCsAgICLnByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGVhcmx5OiAFCXRpbWVEZWJ1ZwMFB3Rvb0xhdGUJAAIBCQCsAgICLHByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGxhdGU6BQl0aW1lRGVidWcDCQEBIQEFCWhhc1F1b3J1bQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICC25vIHF1b3J1bTogAgx0b3RhbFZvdGVzOiAJAKQDAQUKdG90YWxWb3RlcwIPLCB0b3RhbEdWaXJlczogCQCkAwEFC3RvdGFsR1ZpcmVzAg8sIHF1b3J1bVJhdGlvOiAJAKQDAQULcXVvcnVtUmF0aW8DCQEBIQEFCWhhc1Bhc3NlZAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICF25vIHRocmVzaG9sZCBhY2hpZXZlZDogAgl2b3RlWWVzOiAJAKQDAQUHdm90ZVllcwIKLCB2b3RlTm86IAkApAMBBQZ2b3RlTm8CDywgcGFzc2VkUmF0aW86IAkApAMBBQtwYXNzZWRSYXRpbwYDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgUIYnlWb3RpbmeUMAjV", "chainId": 87, "height": 3485882, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: E7Li1cyWJz9563habY8cE5sB73nenFPp7JXsgpNczc9L Next: 6WJEpXwRfMohXb2qKQdw6sTokVU2pbYjYzLYiWx1vTBV Diff:
OldNewDifferences
456456 func forceCollapse2 (L,bJ) = bz(toString(aO.caller), L, bJ, true)
457457
458458
459+@Verifier(bL)
460+func bM () = {
461+ let bN = {
462+ let l = getString(v, "oracle_address")
463+ if ($isInstanceOf(l, "String"))
464+ then {
465+ let bO = l
466+ addressFromString(bO)
467+ }
468+ else unit
469+ }
470+ let bP = height
471+ let bQ = 1000
472+ let bR = valueOrErrorMessage(getInteger(v, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
473+ let bS = valueOrErrorMessage(getInteger(v, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
474+ let bT = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(v, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
475+ let bU = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(v, "voting_contract"), "no voting_contract")), "invalid voting_contract")
476+ let bV = toBase58String(bL.id)
477+ let bW = valueOrElse(getInteger(bU, ("proposal_yes_" + bV)), 0)
478+ let bX = valueOrElse(getInteger(bU, ("proposal_no_" + bV)), 0)
479+ let bY = valueOrErrorMessage(getInteger(bU, ("proposal_height_" + bV)), "proposal not registered")
480+ let bZ = valueOrElse(getInteger(bU, ("proposal_applystart_" + bV)), 0)
481+ let ca = valueOrElse(getInteger(bU, ("proposal_applyend_" + bV)), 0)
482+ let cb = valueOrElse(getInteger(bU, ("proposal_gvires_" + bV)), 0)
483+ let cc = valueOrElse(getBoolean(v, "op_governance_apply_tx_paused"), false)
484+ let cd = bW
485+ let ce = bX
486+ let cf = (cd + ce)
487+ let cg = (((cf * bQ) / cb) >= bR)
488+ let ch = (((cd * bQ) / cf) >= bS)
489+ let ci = (bZ >= bP)
490+ let cj = (bP >= ca)
491+ let ck = ((((((("proposalHeight = " + toString(bY)) + ", applyStart = ") + toString(bZ)) + ", applyEnd = ") + toString(ca)) + ", HEIGHT = ") + toString(bP))
492+ let cl = if (!(cc))
493+ then throw("tx application throw governance not enabled")
494+ else if (ci)
495+ then throw(("proposal can't be executed as it's too early: " + ck))
496+ else if (cj)
497+ then throw(("proposal can't be executed as it's too late:" + ck))
498+ else if (!(cg))
499+ then throw((((((("no quorum: " + "totalVotes: ") + toString(cf)) + ", totalGVires: ") + toString(cb)) + ", quorumRatio: ") + toString(bR)))
500+ else if (!(ch))
501+ then throw((((((("no threshold achieved: " + "voteYes: ") + toString(cd)) + ", voteNo: ") + toString(ce)) + ", passedRatio: ") + toString(bS)))
502+ else true
503+ if (sigVerify(bL.bodyBytes, bL.proofs[0], bL.senderPublicKey))
504+ then true
505+ else cl
506+ }
507+
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = 1000
55
66 func b (c,d,e) = {
77 let f = fraction(c, d, e)
88 let g = 3037000499
99 let h = ((((f % g) * (e % g)) % g) == (((c % g) * (d % g)) % g))
1010 if (h)
1111 then f
1212 else (f + 1)
1313 }
1414
1515
1616 func i (j,c) = if (!(isDefined(getString(this, j))))
1717 then StringEntry(j, c)
1818 else throw(("already initialized: " + j))
1919
2020
2121 func k (c) = {
2222 let l = c
2323 if ($isInstanceOf(l, "Int"))
2424 then {
2525 let m = l
2626 m
2727 }
2828 else throw("m2:1")
2929 }
3030
3131
3232 func n (c) = {
3333 let l = c
3434 if ($isInstanceOf(l, "(Int, Int, Int)"))
3535 then {
3636 let o = l
3737 o
3838 }
3939 else {
4040 let p = l
4141 throw("2")
4242 }
4343 }
4444
4545
4646 func q (c) = {
4747 let l = c
4848 if ($isInstanceOf(l, "(Int, Int, Int, Int, Int, Boolean)"))
4949 then {
5050 let o = l
5151 o
5252 }
5353 else {
5454 let p = l
5555 throw("3")
5656 }
5757 }
5858
5959
6060 let r = "config"
6161
6262 let s = "reserves"
6363
6464 let t = "aTokenId"
6565
6666 let u = "assetId"
6767
6868 let v = addressFromStringValue(getStringValue(this, r))
6969
7070 let w = valueOrErrorMessage(getString(v, "primary_reserves"), "no reserves registered")
7171
7272 let x = split_4C(w, "|")
7373
7474 let y = {
7575 let l = getString(v, "vires_distributor")
7676 if ($isInstanceOf(l, "String"))
7777 then {
7878 let z = l
7979 addressFromStringValue(z)
8080 }
8181 else unit
8282 }
8383
8484 func A (B) = valueOrErrorMessage(getString(B, u), "no assetId in reserve")
8585
8686
8787 func C (B) = valueOrErrorMessage(getInteger(v, (A(B) + "_CollateralFactor")), "no 1")
8888
8989
9090 func D (B) = valueOrErrorMessage(getInteger(v, (A(B) + "_LiquidationThreshold")), "no 2")
9191
9292
9393 func E (F) = valueOrErrorMessage(getInteger(v, (F + "_LiquidationPenalty")), "no 3")
9494
9595
9696 let G = valueOrErrorMessage(getInteger(v, "account_health_threshold"), "no 4")
9797
9898 let H = valueOrErrorMessage(getInteger(v, "account_health_overlap"), "no 5")
9999
100100 let I = valueOrErrorMessage(getInteger(v, "collapse_penalty"), "no 6")
101101
102102 let J = valueOrElse(getString(v, "liquidators"), "")
103103
104104 func K (L) = if (contains(w, L))
105105 then valueOrErrorMessage(addressFromString(L), "main: bad rsr")
106106 else throw(("unknown rsr:" + L))
107107
108108
109109 func M (B,N) = q(invoke(B, "userBalance", [N], nil))
110110
111111
112112 let O = {
113113 let l = getString(v, "protected_reserve")
114114 if ($isInstanceOf(l, "String"))
115115 then {
116116 let P = l
117117 valueOrErrorMessage(addressFromString(P), "bad protected")
118118 }
119119 else unit
120120 }
121121
122122 func Q (N) = {
123123 let R = {
124124 let l = O
125125 if ($isInstanceOf(l, "Address"))
126126 then {
127127 let S = l
128128 k(invoke(S, "borrowPower", [N], nil))
129129 }
130130 else 0
131131 }
132132 func T (U,L) = {
133133 let V = U
134134 let W = V._1
135135 let X = V._2
136136 let Y = V._3
137137 let B = valueOrErrorMessage(addressFromString(L), "rsr bad address")
138138 let Z = C(B)
139139 let aa = D(B)
140140 let ab = M(B, N)
141141 let ac = ab._1
142142 let ad = ab._2
143143 let ae = ab._3
144144 let af = ab._4
145145 let ag = ab._5
146146 let ah = ab._6
147147 let ai = (Y + (if ((af > 0))
148148 then 1
149149 else 0))
150150 let aj = if (ah)
151151 then ae
152152 else 0
153153 let ak = min([ag, aj])
154154 let al = b(ak, H, a)
155155 if ((ag > aj))
156156 then $Tuple3(W, ((X + fraction((ag - aj), a, aa)) + al), ai)
157157 else $Tuple3((W + fraction((aj - ag), Z, a)), (X + al), ai)
158158 }
159159
160160 let L = {
161161 let am = x
162162 let an = size(am)
163163 let ao = $Tuple3(R, 0, 0)
164164 func ap (aq,ar) = if ((ar >= an))
165165 then aq
166166 else T(aq, am[ar])
167167
168168 func as (aq,ar) = if ((ar >= an))
169169 then aq
170170 else throw("List size exceeds 20")
171171
172172 as(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ap(ao, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
173173 }
174174 if (if ((R > 0))
175175 then (L._3 > 4)
176176 else false)
177177 then throw("can't have more than 4 borrows")
178178 else L
179179 }
180180
181181
182182 func at (au) = {
183183 let av = n(Q(au))
184184 let aw = av._1
185185 let ax = av._2
186186 let ay = av._3
187187 ((("bp:" + toString(aw)) + ", bpu:") + toString(ax))
188188 }
189189
190190
191191 func az (N,aA) = {
192192 let aB = Q(N)
193193 let aw = aB._1
194194 let ax = aB._2
195195 let aC = (((aw - ax) * a) / aw)
196196 if (if ((aw == 0))
197197 then (ax == 0)
198198 else false)
199199 then nil
200200 else if (if ((aw == 0))
201201 then (ax > 0)
202202 else false)
203203 then throw(((aA + ": breaching liquidation threshold(bp=0, bpu=") + toString(ax)))
204204 else if ((G > aC))
205205 then throw((((((((aA + ": breaching liquidation threshold(bp=") + toString(aw)) + ", bpu=") + toString(ax)) + ", health=") + toString(aC)) + ")"))
206206 else nil
207207 }
208208
209209
210210 func aD (B,aE,N,aF,aG) = {
211211 let l = y
212212 if ($isInstanceOf(l, "Address"))
213213 then {
214214 let aH = l
215215 invoke(aH, "onAction", [B, aE, N, aF, aG], nil)
216216 }
217217 else unit
218218 }
219219
220220
221221 func aI (B,aE,aJ,aK,aL) = {
222222 let l = y
223223 if ($isInstanceOf(l, "Address"))
224224 then {
225225 let aH = l
226226 invoke(aH, "move", [B, aE, aJ, aK, aL], nil)
227227 }
228228 else unit
229229 }
230230
231231
232232 func aM (B) = {
233233 let l = y
234234 if ($isInstanceOf(l, "Address"))
235235 then {
236236 let aH = l
237237 invoke(aH, "syncHeight", [B], nil)
238238 }
239239 else unit
240240 }
241241
242242
243243 func aN (F) = {
244244 let aO = split(F, "_")[0]
245245 if ((aO == "WAVES"))
246246 then unit
247247 else fromBase58String(aO)
248248 }
249249
250250
251251 func aP (aQ,aR,B,aS) = {
252252 let aT = valueOrErrorMessage(O, "no protected rsr")
253253 let aL = k(invoke(aT, "withdrawToMain", [aQ, aR], nil))
254254 if ((aL == aL))
255255 then {
256256 let F = if ((aR == "WAVES"))
257257 then unit
258258 else fromBase58String(aR)
259259 let aU = invoke(B, "depositFor", [aQ, true], [AttachedPayment(aN(aR), aL)])
260260 if ((aU == aU))
261261 then {
262262 let aV = aD(aS, "deposit", aQ, aL, aL)
263263 if ((aV == aV))
264264 then unit
265265 else throw("Strict value is not equal to itself.")
266266 }
267267 else throw("Strict value is not equal to itself.")
268268 }
269269 else throw("Strict value is not equal to itself.")
270270 }
271271
272272
273273 func aW (aX,aY,aZ,ba,bb,bc) = {
274274 let bd = aM(aY)
275275 if ((bd == bd))
276276 then {
277277 let be = aM(aZ)
278278 if ((be == be))
279279 then if ((0 >= bb))
280280 then throw("non-positive amount")
281281 else if ((aZ == aY))
282282 then throw("cr = br")
283283 else if ((aX == ba))
284284 then throw("self")
285285 else {
286286 let bf = Q(ba)
287287 let aw = bf._1
288288 let ax = bf._2
289289 if ((aw > ax))
290290 then throw((" healthy user: u=" + ba))
291291 else {
292292 let bg = K(aY)
293293 let bh = K(aZ)
294294 let bi = valueOrErrorMessage(getString(bg, u), "no assetId in br")
295295 let bj = valueOrErrorMessage(getString(bh, u), "no assetId in cr")
296296 let bk = valueOrElse(getBoolean(bh, (ba + "_useAsCollateral")), false)
297297 if ((bk == bk))
298298 then if (if (!(bc))
299299 then !(bk)
300300 else false)
301301 then throw("deposit not used as collateral")
302302 else {
303303 let bl = M(bg, ba)
304304 if ((bl == bl))
305305 then {
306306 let bm = bl._5
307307 let bn = bl._4
308308 let bo = bl._3
309309 let bp = bl._2
310310 let ay = bl._1
311311 if ((bp >= bn))
312312 then throw("positive saldo")
313313 else if ((0 >= bb))
314314 then throw("<= 0>")
315315 else {
316316 let bq = valueOrElse(getInteger(v, (bj + "_LiquidationFractionFactor")), 2)
317317 if (((bb * bq) > (bn - bp)))
318318 then throw(((("more than 1/factor of saldo: debt=" + toString(bn)) + ", liquidateDebtAmount = ") + toString(bb)))
319319 else {
320320 let br = fraction(bb, bm, bn)
321321 let bs = fraction(br, (a + E(bi)), a)
322322 let bt = if (bc)
323323 then aP(ba, bj, bh, aZ)
324324 else unit
325325 if ((bt == bt))
326326 then {
327327 let bu = k(invoke(bh, "transferATokensFor", [ba, aX, bs], nil))
328328 if ((bu == bu))
329329 then {
330330 let bv = aI(aZ, "deposit", ba, aX, bu)
331331 if ((bv == bv))
332332 then {
333333 let bw = k(invoke(bg, "transferDebtFor", [ba, aX, bb], nil))
334334 if ((bw == bw))
335335 then {
336336 let bx = aI(aY, "borrow", ba, aX, bw)
337337 if ((bx == bx))
338338 then {
339339 let by = if (contains(J, aX))
340340 then nil
341341 else az(aX, "transferring debt")
342342 if ((by == by))
343343 then $Tuple2(by, bu)
344344 else throw("Strict value is not equal to itself.")
345345 }
346346 else throw("Strict value is not equal to itself.")
347347 }
348348 else throw("Strict value is not equal to itself.")
349349 }
350350 else throw("Strict value is not equal to itself.")
351351 }
352352 else throw("Strict value is not equal to itself.")
353353 }
354354 else throw("Strict value is not equal to itself.")
355355 }
356356 }
357357 }
358358 else throw("Strict value is not equal to itself.")
359359 }
360360 else throw("Strict value is not equal to itself.")
361361 }
362362 }
363363 else throw("Strict value is not equal to itself.")
364364 }
365365 else throw("Strict value is not equal to itself.")
366366 }
367367
368368
369369 func bz (aX,B,ba,bc) = {
370370 let bA = K(B)
371371 if ((bA == bA))
372372 then {
373373 let bB = aM(B)
374374 if ((bB == bB))
375375 then if ((aX == ba))
376376 then throw("can't collapse self in this function")
377377 else {
378378 let bC = Q(ba)
379379 let aw = bC._1
380380 let ax = bC._2
381381 if ((aw > ax))
382382 then throw(("can't force collapse healthy user " + ba))
383383 else {
384384 let ad = valueOrErrorMessage(getString(bA, u), ("no assetId field in rsr " + B))
385385 let bt = if (bc)
386386 then aP(ba, ad, bA, B)
387387 else unit
388388 if ((bt == bt))
389389 then {
390390 let bD = M(bA, ba)
391391 if ((bD == bD))
392392 then {
393393 let bm = bD._5
394394 let bn = bD._4
395395 let bo = bD._3
396396 let bE = bD._2
397397 let ay = bD._1
398398 let bs = fraction(min([bo, bm]), I, a)
399399 let bF = k(invoke(bA, "transferATokensFor", [ba, aX, bs], nil))
400400 if ((bF == bF))
401401 then {
402402 let bv = aI(B, "deposit", ba, aX, bF)
403403 if ((bv == bv))
404404 then {
405405 let bG = k(invoke(bA, "collapseFor", [ba], nil))
406406 if ((bG == bG))
407407 then {
408408 let bx = aD(B, "borrow", ba, -(bG), -(bG))
409409 if ((bx == bx))
410410 then {
411411 let bH = aD(B, "deposit", ba, -(bG), -(bG))
412412 if ((bH == bH))
413413 then nil
414414 else throw("Strict value is not equal to itself.")
415415 }
416416 else throw("Strict value is not equal to itself.")
417417 }
418418 else throw("Strict value is not equal to itself.")
419419 }
420420 else throw("Strict value is not equal to itself.")
421421 }
422422 else throw("Strict value is not equal to itself.")
423423 }
424424 else throw("Strict value is not equal to itself.")
425425 }
426426 else throw("Strict value is not equal to itself.")
427427 }
428428 }
429429 else throw("Strict value is not equal to itself.")
430430 }
431431 else throw("Strict value is not equal to itself.")
432432 }
433433
434434
435435 @Callable(aO)
436436 func initialize (bI) = [i(r, bI)]
437437
438438
439439
440440 @Callable(aO)
441441 func transferDebt (bg,bh,bJ,bK) = aW(toString(aO.caller), bg, bh, bJ, bK, false)
442442
443443
444444
445445 @Callable(aO)
446446 func transferDebt2 (bg,bh,bJ,bK) = aW(toString(aO.caller), bg, bh, bJ, bK, true)
447447
448448
449449
450450 @Callable(aO)
451451 func forceCollapse (L,bJ) = bz(toString(aO.caller), L, bJ, false)
452452
453453
454454
455455 @Callable(aO)
456456 func forceCollapse2 (L,bJ) = bz(toString(aO.caller), L, bJ, true)
457457
458458
459+@Verifier(bL)
460+func bM () = {
461+ let bN = {
462+ let l = getString(v, "oracle_address")
463+ if ($isInstanceOf(l, "String"))
464+ then {
465+ let bO = l
466+ addressFromString(bO)
467+ }
468+ else unit
469+ }
470+ let bP = height
471+ let bQ = 1000
472+ let bR = valueOrErrorMessage(getInteger(v, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
473+ let bS = valueOrErrorMessage(getInteger(v, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
474+ let bT = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(v, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
475+ let bU = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(v, "voting_contract"), "no voting_contract")), "invalid voting_contract")
476+ let bV = toBase58String(bL.id)
477+ let bW = valueOrElse(getInteger(bU, ("proposal_yes_" + bV)), 0)
478+ let bX = valueOrElse(getInteger(bU, ("proposal_no_" + bV)), 0)
479+ let bY = valueOrErrorMessage(getInteger(bU, ("proposal_height_" + bV)), "proposal not registered")
480+ let bZ = valueOrElse(getInteger(bU, ("proposal_applystart_" + bV)), 0)
481+ let ca = valueOrElse(getInteger(bU, ("proposal_applyend_" + bV)), 0)
482+ let cb = valueOrElse(getInteger(bU, ("proposal_gvires_" + bV)), 0)
483+ let cc = valueOrElse(getBoolean(v, "op_governance_apply_tx_paused"), false)
484+ let cd = bW
485+ let ce = bX
486+ let cf = (cd + ce)
487+ let cg = (((cf * bQ) / cb) >= bR)
488+ let ch = (((cd * bQ) / cf) >= bS)
489+ let ci = (bZ >= bP)
490+ let cj = (bP >= ca)
491+ let ck = ((((((("proposalHeight = " + toString(bY)) + ", applyStart = ") + toString(bZ)) + ", applyEnd = ") + toString(ca)) + ", HEIGHT = ") + toString(bP))
492+ let cl = if (!(cc))
493+ then throw("tx application throw governance not enabled")
494+ else if (ci)
495+ then throw(("proposal can't be executed as it's too early: " + ck))
496+ else if (cj)
497+ then throw(("proposal can't be executed as it's too late:" + ck))
498+ else if (!(cg))
499+ then throw((((((("no quorum: " + "totalVotes: ") + toString(cf)) + ", totalGVires: ") + toString(cb)) + ", quorumRatio: ") + toString(bR)))
500+ else if (!(ch))
501+ then throw((((((("no threshold achieved: " + "voteYes: ") + toString(cd)) + ", voteNo: ") + toString(ce)) + ", passedRatio: ") + toString(bS)))
502+ else true
503+ if (sigVerify(bL.bodyBytes, bL.proofs[0], bL.senderPublicKey))
504+ then true
505+ else cl
506+ }
507+

github/deemru/w8io/3ef1775 
56.03 ms