tx · UjJCzcnHprUqHuKsr9t26qme7EGxkVFTk6RhRg3UjwU 3N6HSS7Toat1RhyEsyqVGgVSRzH19W1FTbP: -0.03400000 Waves 2023.08.23 09:43 [2722925] smart account 3N6HSS7Toat1RhyEsyqVGgVSRzH19W1FTbP > SELF 0.00000000 Waves
{ "type": 13, "id": "UjJCzcnHprUqHuKsr9t26qme7EGxkVFTk6RhRg3UjwU", "fee": 3400000, "feeAssetId": null, "timestamp": 1692773059004, "version": 1, "sender": "3N6HSS7Toat1RhyEsyqVGgVSRzH19W1FTbP", "senderPublicKey": "AoKo4segKHU4DeJnxXQYJj2u7J6XJeux6r8KLW52cd2Q", "proofs": [ "4BaZxHn9tJHbF84X6r6JYEbd19yGM2shQDCzKHTqMQJxRJNaSTwAnA9TBKtNi4hgGQn3Vb3cPSDA3iYkzKyGAC8L" ], "script": "base64:BwJHCAISABIDCgECEgcKBQIBAQEBEgYKBAEBAQESAwoBAhIDCgECEgQKAgICEgQKAgIIEgQKAgIYEgQKAgIIEgQKAgIYEgMKAQJAAANTRVACAl9fAA1DT05UUkFDVF9OQU1FAg9jYWxjdWxhdG9yLnJpZGUABlNDQUxFOACAwtcvAAdQRU5ESU5HAgdQRU5ESU5HAAVXQVZFUwIFV0FWRVMAHGJsb2Nrc1Byb2Nlc3NpbmdCYXRjaFNpemVNYXgACgEHd3JhcEVycgEBcwkArAICCQCsAgIFDUNPTlRSQUNUX05BTUUCAjogBQFzAQh0aHJvd0VycgEBcwkAAgEJAQd3cmFwRXJyAQUBcwEPYXNzZXRJZFRvU3RyaW5nAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAWIFByRtYXRjaDAJANgEAQUBYgMJAAECBQckbWF0Y2gwAgRVbml0BQVXQVZFUwkAAgECC01hdGNoIGVycm9yAQ9zdHJpbmdUb0Fzc2V0SWQBAXMDCQAAAgUBcwUFV0FWRVMFBHVuaXQJANkEAQUBcwEDYWJzAQFuAwkAZgIAAAUBbgkBAS0BBQFuBQFuARFrZXlGYWN0b3J5QWRkcmVzcwAJALkJAgkAzAgCAgIlcwkAzAgCAgdmYWN0b3J5BQNuaWwFA1NFUAETa2V5TWFuYWdlclB1YmxpY0tleQAJALkJAgkAzAgCAgIlcwkAzAgCAhBtYW5hZ2VyUHVibGljS2V5BQNuaWwFA1NFUAEMa2V5THBBc3NldElkAAkAuQkCCQDMCAICAiVzCQDMCAICCWxwQXNzZXRJZAUDbmlsBQNTRVABF2tleVByb3h5VHJlYXN1cnlBZGRyZXNzAAkAuQkCCQDMCAICAiVzCQDMCAICDXByb3h5VHJlYXN1cnkFA25pbAUDU0VQARZrZXlNYWluVHJlYXN1cnlBZGRyZXNzAAkAuQkCCQDMCAICAiVzCQDMCAICDG1haW5UcmVhc3VyeQUDbmlsBQNTRVABGmtleUJ1c2luZXNzVHJlYXN1cnlBZGRyZXNzAAkAuQkCCQDMCAICAiVzCQDMCAICEGJ1c2luZXNzVHJlYXN1cnkFA25pbAUDU0VQARdrZXlCdXNpbmVzc1RyZWFzdXJ5UGFydAAJALkJAgkAzAgCAgIlcwkAzAgCAhRidXNpbmVzc1RyZWFzdXJ5UGFydAUDbmlsBQNTRVABF2tleVBvd2VyQ29udHJhY3RBZGRyZXNzAAkAuQkCCQDMCAICAiVzCQDMCAICDXBvd2VyQ29udHJhY3QFA25pbAUDU0VQARJrZXlQb3dlclNoYXJlUmF0aW8ACQC5CQIJAMwIAgICJXMJAMwIAgIPcG93ZXJTaGFyZVJhdGlvBQNuaWwFA1NFUAEPa2V5UG93ZXJBc3NldElkAAkAuQkCCQDMCAICAiVzCQDMCAICDHBvd2VyQXNzZXRJZAUDbmlsBQNTRVABC2tleUludmVzdGVkAQdhc3NldElkCQC5CQIJAMwIAgIEJXMlcwkAzAgCAghpbnZlc3RlZAkAzAgCCQEPYXNzZXRJZFRvU3RyaW5nAQUHYXNzZXRJZAUDbmlsBQNTRVABCmtleURvbmF0ZWQBB2Fzc2V0SWQJALkJAgkAzAgCAgQlcyVzCQDMCAICB2RvbmF0ZWQJAMwIAgkBD2Fzc2V0SWRUb1N0cmluZwEFB2Fzc2V0SWQFA25pbAUDU0VQAQxrZXlBdmFpbGFibGUBC3VzZXJBZGRyZXNzCQC5CQIJAMwIAgIEJXMlcwkAzAgCAglhdmFpbGFibGUJAMwIAgkApQgBBQt1c2VyQWRkcmVzcwUDbmlsBQNTRVABCmtleUNsYWltZWQBC3VzZXJBZGRyZXNzCQC5CQIJAMwIAgIEJXMlcwkAzAgCAgdjbGFpbWVkCQDMCAIJAKUIAQULdXNlckFkZHJlc3MFA25pbAUDU0VQARBrZXlDdXJyZW50UGVyaW9kAAkAuQkCCQDMCAICAiVzCQDMCAICDWN1cnJlbnRQZXJpb2QFA25pbAUDU0VQARFrZXlQcmljZUZvclBlcmlvZAEGcGVyaW9kCQC5CQIJAMwIAgIEJXMlZAkAzAgCAgVwcmljZQkAzAgCCQCkAwEFBnBlcmlvZAUDbmlsBQNTRVABDmtleVN0YXJ0SGVpZ2h0AQZwZXJpb2QJALkJAgkAzAgCAgQlcyVkCQDMCAICC3N0YXJ0SGVpZ2h0CQDMCAIJAKQDAQUGcGVyaW9kBQNuaWwFA1NFUAEUa2V5UG93ZXJNYW5hZ2VyQm9udXMBBnBlcmlvZAkAuQkCCQDMCAICBCVzJWQJAMwIAgIRcG93ZXJNYW5hZ2VyQm9udXMJAMwIAgkApAMBBQZwZXJpb2QFA25pbAUDU0VQARNrZXlDbGFpbVdhdmVzQW1vdW50AQZwZXJpb2QJALkJAgkAzAgCAgQlcyVkCQDMCAICEGNsYWltV2F2ZXNBbW91bnQJAMwIAgkApAMBBQZwZXJpb2QFA25pbAUDU0VQAQ9rZXlQZXJpb2RMZW5ndGgAAhAlc19fcGVyaW9kTGVuZ3RoARVrZXlJbnZlc3RQZXJpb2RMZW5ndGgAAhYlc19faW52ZXN0UGVyaW9kTGVuZ3RoARhrZXlCbG9ja1Byb2Nlc3NpbmdSZXdhcmQAAhklc19fYmxvY2tQcm9jZXNzaW5nUmV3YXJkARVrZXlOZXh0QmxvY2tUb1Byb2Nlc3MAAhYlc19fbmV4dEJsb2NrVG9Qcm9jZXNzARFrZXlCbG9ja1Byb2Nlc3NlZAEGaGVpZ2h0CQC5CQIJAMwIAgIEJXMlZAkAzAgCAg5ibG9ja1Byb2Nlc3NlZAkAzAgCCQCkAwEFBmhlaWdodAUDbmlsBQNTRVABDWtleVdpdGhkcmF3YWwAAg4lc19fd2l0aGRyYXdhbAEUa2V5V2l0aGRyYXdhbFJlcXVlc3QCC3VzZXJBZGRyZXNzBHR4SWQJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIKd2l0aGRyYXdhbAkAzAgCCQClCAEFC3VzZXJBZGRyZXNzCQDMCAIJANgEAQUEdHhJZAUDbmlsBQNTRVABFnZhbHVlV2l0aGRyYXdhbFJlcXVlc3QEBnN0YXR1cw1scEFzc2V0QW1vdW50DHRhcmdldFBlcmlvZAljbGFpbVR4SWQEDGNsYWltVHhJZFN0cgQHJG1hdGNoMAUJY2xhaW1UeElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAWIFByRtYXRjaDAJANgEAQUBYgMJAAECBQckbWF0Y2gwAgRVbml0AgRTT09OCQACAQILTWF0Y2ggZXJyb3IJALkJAgkAzAgCAgglcyVkJWQlcwkAzAgCBQZzdGF0dXMJAMwIAgkApAMBBQ1scEFzc2V0QW1vdW50CQDMCAIJAKQDAQUMdGFyZ2V0UGVyaW9kCQDMCAIFDGNsYWltVHhJZFN0cgUDbmlsBQNTRVABFGtleVdpdGhkcmF3YWxIaXN0b3J5Agt1c2VyQWRkcmVzcwR0eElkCQC5CQIJAMwIAgIGJXMlcyVzCQDMCAICEXdpdGhkcmF3YWxIaXN0b3J5CQDMCAIJAKUIAQULdXNlckFkZHJlc3MJAMwIAgkA2AQBBQR0eElkBQNuaWwFA1NFUAEba2V5UGVyaW9kV2l0aGRyYXdhbEFzc2V0SWRzAQZwZXJpb2QJALkJAgkAzAgCAgQlcyVkCQDMCAICDHBlcmlvZFJld2FyZAkAzAgCCQCkAwEFBnBlcmlvZAUDbmlsBQNTRVABGmtleVBlcmlvZFdpdGhkcmF3YWxBbW91bnRzAQZwZXJpb2QJALkJAgkAzAgCAgQlcyVkCQDMCAICEnBlcmlvZFJld2FyZEFtb3VudAkAzAgCCQCkAwEFBnBlcmlvZAUDbmlsBQNTRVABIXBhcnNlV2l0aGRyYXdhbFJlcXVlc3RWYWx1ZU9yRmFpbAEBcwQFcGFydHMJALUJAgUBcwUDU0VQAwkAAAIJAJADAQUFcGFydHMABQQGc3RhdHVzCQCRAwIFBXBhcnRzAAEEDWxwQXNzZXRBbW91bnQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAtgkBCQCRAwIFBXBhcnRzAAIJAQd3cmFwRXJyAQIVaW52YWxpZCBscEFzc2V0QW1vdW50BAx0YXJnZXRQZXJpb2QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAtgkBCQCRAwIFBXBhcnRzAAMJAQd3cmFwRXJyAQIUaW52YWxpZCB0YXJnZXRQZXJpb2QECWNsYWltVHhJZAkAkQMCBQVwYXJ0cwAECQCWCgQFBnN0YXR1cwUNbHBBc3NldEFtb3VudAUMdGFyZ2V0UGVyaW9kBQljbGFpbVR4SWQJAQh0aHJvd0VycgECIGludmFsaWQgd2l0aGRyYXdhbCByZXF1ZXN0IHZhbHVlABRmYWN0b3J5QWRkcmVzc09wdGlvbgQHJG1hdGNoMAkAnQgCBQR0aGlzCQERa2V5RmFjdG9yeUFkZHJlc3MAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkApggBBQFzAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgAUZmFjdG9yeUFkZHJlc3NPckZhaWwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgUUZmFjdG9yeUFkZHJlc3NPcHRpb24JAQd3cmFwRXJyAQIXaW52YWxpZCBmYWN0b3J5IGFkZHJlc3MAD2xwQXNzZXRJZE9wdGlvbgQHJG1hdGNoMAUUZmFjdG9yeUFkZHJlc3NPcHRpb24DCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQBYQUHJG1hdGNoMAQHJG1hdGNoMQkAnQgCBQFhCQEMa2V5THBBc3NldElkAAMJAAECBQckbWF0Y2gxAgZTdHJpbmcEAXMFByRtYXRjaDEJANkEAQUBcwMJAAECBQckbWF0Y2gxAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IDCQABAgUHJG1hdGNoMAIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAA9scEFzc2V0SWRPckZhaWwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgUPbHBBc3NldElkT3B0aW9uCQEHd3JhcEVycgECEWludmFsaWQgbHBBc3NldElkABpwcm94eVRyZWFzdXJ5QWRkcmVzc09wdGlvbgQHJG1hdGNoMAUUZmFjdG9yeUFkZHJlc3NPcHRpb24DCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQBYQUHJG1hdGNoMAQHJG1hdGNoMQkAnQgCBQFhCQEXa2V5UHJveHlUcmVhc3VyeUFkZHJlc3MAAwkAAQIFByRtYXRjaDECBlN0cmluZwQBcwUHJG1hdGNoMQkApggBBQFzAwkAAQIFByRtYXRjaDECBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgMJAAECBQckbWF0Y2gwAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IAGnByb3h5VHJlYXN1cnlBZGRyZXNzT3JGYWlsCQETdmFsdWVPckVycm9yTWVzc2FnZQIFGnByb3h5VHJlYXN1cnlBZGRyZXNzT3B0aW9uCQEHd3JhcEVycgECHmludmFsaWQgcHJveHkgdHJlYXN1cnkgYWRkcmVzcwAZbWFpblRyZWFzdXJ5QWRkcmVzc09wdGlvbgQHJG1hdGNoMAUUZmFjdG9yeUFkZHJlc3NPcHRpb24DCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQBYQUHJG1hdGNoMAQHJG1hdGNoMQkAnQgCBQFhCQEWa2V5TWFpblRyZWFzdXJ5QWRkcmVzcwADCQABAgUHJG1hdGNoMQIGU3RyaW5nBAFzBQckbWF0Y2gxCQCmCAEFAXMDCQABAgUHJG1hdGNoMQIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgAdYnVzaW5lc3NUcmVhc3VyeUFkZHJlc3NPcHRpb24EByRtYXRjaDAFFGZhY3RvcnlBZGRyZXNzT3B0aW9uAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEAWEFByRtYXRjaDAEByRtYXRjaDEJAJ0IAgUBYQkBGmtleUJ1c2luZXNzVHJlYXN1cnlBZGRyZXNzAAMJAAECBQckbWF0Y2gxAgZTdHJpbmcEAXMFByRtYXRjaDEJAKYIAQUBcwMJAAECBQckbWF0Y2gxAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IDCQABAgUHJG1hdGNoMAIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yABltYWluVHJlYXN1cnlBZGRyZXNzT3JGYWlsCQETdmFsdWVPckVycm9yTWVzc2FnZQIFGW1haW5UcmVhc3VyeUFkZHJlc3NPcHRpb24JAQd3cmFwRXJyAQIdaW52YWxpZCBtYWluIHRyZWFzdXJ5IGFkZHJlc3MAHWJ1c2luZXNzVHJlYXN1cnlBZGRyZXNzT3JGYWlsCQETdmFsdWVPckVycm9yTWVzc2FnZQIFHWJ1c2luZXNzVHJlYXN1cnlBZGRyZXNzT3B0aW9uCQEHd3JhcEVycgECIWludmFsaWQgYnVzaW5lc3MgdHJlYXN1cnkgYWRkcmVzcwAacG93ZXJDb250cmFjdEFkZHJlc3NPcHRpb24EByRtYXRjaDAFFGZhY3RvcnlBZGRyZXNzT3B0aW9uAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEAWEFByRtYXRjaDAEByRtYXRjaDEJAJ0IAgUBYQkBF2tleVBvd2VyQ29udHJhY3RBZGRyZXNzAAMJAAECBQckbWF0Y2gxAgZTdHJpbmcEAXMFByRtYXRjaDEJAKYIAQUBcwMJAAECBQckbWF0Y2gxAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IDCQABAgUHJG1hdGNoMAIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yABpwb3dlckNvbnRyYWN0QWRkcmVzc09yRmFpbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBRpwb3dlckNvbnRyYWN0QWRkcmVzc09wdGlvbgkBB3dyYXBFcnIBAh5pbnZhbGlkIHBvd2VyIGNvbnRyYWN0IGFkZHJlc3MAGHBvd2VyQXNzZXRJZFN0cmluZ09yRmFpbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEPa2V5UG93ZXJBc3NldElkAAkBB3dyYXBFcnIBAhhwb3dlciBhc3NldCBpZCBub3QgZm91bmQBGWdldE1hbmFnZXJQdWJsaWNLZXlPclVuaXQABAckbWF0Y2gwBRRmYWN0b3J5QWRkcmVzc09wdGlvbgMJAAECBQckbWF0Y2gwAgdBZGRyZXNzBAJmYQUHJG1hdGNoMAQHJG1hdGNoMQkAnQgCBQJmYQkBE2tleU1hbmFnZXJQdWJsaWNLZXkAAwkAAQIFByRtYXRjaDECBlN0cmluZwQDcHViBQckbWF0Y2gxCQDZBAEFA3B1YgUEdW5pdAUEdW5pdAELb25seUFkZHJlc3MCAWkHYWRkcmVzcwMJAAACCAUBaQZjYWxsZXIFB2FkZHJlc3MGCQEIdGhyb3dFcnIBAhFwZXJtaXNzaW9uIGRlbmllZAELb25seUZhY3RvcnkBAWkJAQtvbmx5QWRkcmVzcwIFAWkFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAQ9yZXdhcmRGb3JPcHRpb24CB3Jld2FyZHMGdGFyZ2V0BAFzCQCQAwEFB3Jld2FyZHMECyR0MDY2Njk2Njk0CQCRAwIFB3Jld2FyZHMAAAQCYTAIBQskdDA2NjY5NjY5NAJfMQQCcjAIBQskdDA2NjY5NjY5NAJfMgQLJHQwNjY5NzY3MjIJAJEDAgUHcmV3YXJkcwABBAJhMQgFCyR0MDY2OTc2NzIyAl8xBAJyMQgFCyR0MDY2OTc2NzIyAl8yBAskdDA2NzI1Njc1MAkAkQMCBQdyZXdhcmRzAAIEAmEyCAULJHQwNjcyNTY3NTACXzEEAnIyCAULJHQwNjcyNTY3NTACXzIDAwkAZgIFAXMAAAkAAAIFAmEwBQZ0YXJnZXQHBQJyMAMDCQBmAgUBcwABCQAAAgUCYTEFBnRhcmdldAcFAnIxAwMJAGYCBQFzAAIJAAACBQJhMgUGdGFyZ2V0BwUCcjIFBHVuaXQBDmNhbGN1bGF0ZVByaWNlAQ1scFBhcnRJbldhdmVzBBNscEFzc2V0QW1vdW50VG9CdXJuCQELdmFsdWVPckVsc2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQENa2V5V2l0aGRyYXdhbAAAAAQPbHBBc3NldFF1YW50aXR5CAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFD2xwQXNzZXRJZE9yRmFpbAkBB3dyYXBFcnIBAhRpbnZhbGlkIGxwQXNzZXQgaW5mbwhxdWFudGl0eQQIbmV3UHJpY2UJAGsDBQ1scFBhcnRJbldhdmVzBQZTQ0FMRTgJAGUCBQ9scEFzc2V0UXVhbnRpdHkFE2xwQXNzZXRBbW91bnRUb0J1cm4EE2NoZWNrSWZQcmljZU5vdFplcm8DCQECIT0CBQhuZXdQcmljZQAABgkBCHRocm93RXJyAQIUTFAgcHJpY2UgY2Fubm90IGJlIDADCQAAAgUTY2hlY2tJZlByaWNlTm90WmVybwUTY2hlY2tJZlByaWNlTm90WmVybwQUbHBBc3NldEZpbmFsUXVhbnRpdHkJAGUCBQ9scEFzc2V0UXVhbnRpdHkFE2xwQXNzZXRBbW91bnRUb0J1cm4JAJUKAwUIbmV3UHJpY2UFE2xwQXNzZXRBbW91bnRUb0J1cm4FFGxwQXNzZXRGaW5hbFF1YW50aXR5CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARdjbGFpbUNvbGxhdGVyYWxJTlRFUk5BTAIQdXNlckFkZHJlc3NCeXRlcwR0eElkBAt1c2VyQWRkcmVzcwkBB0FkZHJlc3MBBRB1c2VyQWRkcmVzc0J5dGVzBBNjdXJyZW50UGVyaW9kT3JGYWlsCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJARBrZXlDdXJyZW50UGVyaW9kAAkBB3dyYXBFcnIBAg5pbnZhbGlkIHBlcmlvZAQXd2l0aGRyYXdhbFJlcXVlc3RPcHRpb24JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBFGtleVdpdGhkcmF3YWxSZXF1ZXN0AgULdXNlckFkZHJlc3MFBHR4SWQJAQd3cmFwRXJyAQIaaW52YWxpZCB3aXRoZHJhd2FsIHJlcXVlc3QECyR0MDc5MTc4MDMwCQEhcGFyc2VXaXRoZHJhd2FsUmVxdWVzdFZhbHVlT3JGYWlsAQUXd2l0aGRyYXdhbFJlcXVlc3RPcHRpb24EBnN0YXR1cwgFCyR0MDc5MTc4MDMwAl8xBA1scEFzc2V0QW1vdW50CAULJHQwNzkxNzgwMzACXzIEDHRhcmdldFBlcmlvZAgFCyR0MDc5MTc4MDMwAl8zBAljbGFpbVR4SWQIBQskdDA3OTE3ODAzMAJfNAMJAGYCBQx0YXJnZXRQZXJpb2QFE2N1cnJlbnRQZXJpb2RPckZhaWwJAQh0aHJvd0VycgECIWludmFsaWQgd2l0aGRyYXdhbCByZXF1ZXN0IHBlcmlvZAQLcHJpY2VPckZhaWwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBEWtleVByaWNlRm9yUGVyaW9kAQUMdGFyZ2V0UGVyaW9kCQEHd3JhcEVycgECDWludmFsaWQgcHJpY2UEC3dhdmVzQW1vdW50AwkAZgIFC3ByaWNlT3JGYWlsAAAJAGsDBQ1scEFzc2V0QW1vdW50BQtwcmljZU9yRmFpbAUGU0NBTEU4AAAEDGFzc2V0c1N0cmluZwkBEUBleHRyTmF0aXZlKDEwNTMpAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJARtrZXlQZXJpb2RXaXRoZHJhd2FsQXNzZXRJZHMBBRNjdXJyZW50UGVyaW9kT3JGYWlsBA1hbW91bnRzU3RyaW5nCQERQGV4dHJOYXRpdmUoMTA1MykCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBGmtleVBlcmlvZFdpdGhkcmF3YWxBbW91bnRzAQUTY3VycmVudFBlcmlvZE9yRmFpbAkAmAoGBQt1c2VyQWRkcmVzcwUNbHBBc3NldEFtb3VudAUMdGFyZ2V0UGVyaW9kBQt3YXZlc0Ftb3VudAUMYXNzZXRzU3RyaW5nBQ1hbW91bnRzU3RyaW5nASVjbGFpbUNvbGxhdGVyYWxSRUFET05MWVN0cmluZ1Jlc3BvbnNlAhB1c2VyQWRkcmVzc0J5dGVzBHR4SWQECyR0MDg4MTc4OTgzCQEXY2xhaW1Db2xsYXRlcmFsSU5URVJOQUwCBRB1c2VyQWRkcmVzc0J5dGVzBQR0eElkBAt1c2VyQWRkcmVzcwgFCyR0MDg4MTc4OTgzAl8xBA1scEFzc2V0QW1vdW50CAULJHQwODgxNzg5ODMCXzIEDHRhcmdldFBlcmlvZAgFCyR0MDg4MTc4OTgzAl8zBAt3YXZlc0Ftb3VudAgFCyR0MDg4MTc4OTgzAl80BAxhc3NldHNTdHJpbmcIBQskdDA4ODE3ODk4MwJfNQQNYW1vdW50c1N0cmluZwgFCyR0MDg4MTc4OTgzAl82BAZhc3NldHMJALkJAgkA0QgCCQC9CQIFDGFzc2V0c1N0cmluZwUDU0VQAAACAToEB2Ftb3VudHMJALkJAgkA0QgCCQC9CQIFDWFtb3VudHNTdHJpbmcFA1NFUAAAAgE6CQC5CQIJAMwIAgIGJWQlcyVzCQDMCAIJAKQDAQULd2F2ZXNBbW91bnQJAMwIAgUGYXNzZXRzCQDMCAIFB2Ftb3VudHMFA25pbAUDU0VQAQ5nZXRSZXdhcmRTcGxpdAEVZ2VuZXJhdG9yUmV3YXJkQW1vdW50BA9wb3dlclNoYXJlUmF0aW8JAJYDAQkAzAgCAAAJAMwIAgkAlwMBCQDMCAIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJARJrZXlQb3dlclNoYXJlUmF0aW8AAAAJAMwIAgUGU0NBTEU4BQNuaWwFA25pbAQRYnVzaW5lc3NQYXJ0UmF0aW8JAJYDAQkAzAgCAAAJAMwIAgkAlwMBCQDMCAIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJARdrZXlCdXNpbmVzc1RyZWFzdXJ5UGFydAAAAAkAzAgCBQZTQ0FMRTgFA25pbAUDbmlsBBFhbW91bnRUb1Bvd2VyUGFydAkAawMFFWdlbmVyYXRvclJld2FyZEFtb3VudAUPcG93ZXJTaGFyZVJhdGlvBQZTQ0FMRTgEGmJ1c2luZXNzVHJlYXN1cnlBbW91bnRQYXJ0CQBrAwUVZ2VuZXJhdG9yUmV3YXJkQW1vdW50BRFidXNpbmVzc1BhcnRSYXRpbwUGU0NBTEU4BA9yZXdhcmRSZW1haW5kZXIJAGUCCQBlAgUVZ2VuZXJhdG9yUmV3YXJkQW1vdW50BRFhbW91bnRUb1Bvd2VyUGFydAUaYnVzaW5lc3NUcmVhc3VyeUFtb3VudFBhcnQDCQBmAgUPcmV3YXJkUmVtYWluZGVyAAAJAJUKAwURYW1vdW50VG9Qb3dlclBhcnQFGmJ1c2luZXNzVHJlYXN1cnlBbW91bnRQYXJ0BQ9yZXdhcmRSZW1haW5kZXIJAQh0aHJvd0VycgECKmFtb3VudCB0byBtYWluIHRyZWFzdXJ5IGNhbm5vdCBiZSBuZWdhdGl2ZQEYY2FsY1Jld2FyZFNwbGl0Rm9yQW1vdW50AQZhbW91bnQEDSR0MDEwMDgyMTAxNzUJAQ5nZXRSZXdhcmRTcGxpdAEFBmFtb3VudAQRYW1vdW50VG9Qb3dlclBhcnQIBQ0kdDAxMDA4MjEwMTc1Al8xBBpidXNpbmVzc1RyZWFzdXJ5QW1vdW50UGFydAgFDSR0MDEwMDgyMTAxNzUCXzIED3Jld2FyZFJlbWFpbmRlcggFDSR0MDEwMDgyMTAxNzUCXzMEFWJsb2NrUHJvY2Vzc2luZ1Jld2FyZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEYa2V5QmxvY2tQcm9jZXNzaW5nUmV3YXJkAAkBB3dyYXBFcnIBAh9pbnZhbGlkIGJsb2NrIHByb2Nlc3NpbmcgcmV3YXJkBCBibG9ja1Byb2Nlc3NpbmdSZXdhcmRCeUdlbmVyYXRvcgkAaQIFFWJsb2NrUHJvY2Vzc2luZ1Jld2FyZAUcYmxvY2tzUHJvY2Vzc2luZ0JhdGNoU2l6ZU1heAQKdG9McEFtb3VudAkAZQIFD3Jld2FyZFJlbWFpbmRlcgUVYmxvY2tQcm9jZXNzaW5nUmV3YXJkCQCXCgUFEWFtb3VudFRvUG93ZXJQYXJ0BRpidXNpbmVzc1RyZWFzdXJ5QW1vdW50UGFydAUVYmxvY2tQcm9jZXNzaW5nUmV3YXJkBQp0b0xwQW1vdW50BQZhbW91bnQMAWkBE3Jld2FyZFNwbGl0UkVBRE9OTFkABBF0YXJnZXRCbG9ja0hlaWdodAkAZQIFBmhlaWdodAABBA90YXJnZXRCbG9ja0luZm8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7QcBBRF0YXJnZXRCbG9ja0hlaWdodAkBB3dyYXBFcnIBAhJpbnZhbGlkIGJsb2NrIGluZm8EFHRyZWFzdXJ5UmV3YXJkT3JGYWlsCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAQ9yZXdhcmRGb3JPcHRpb24CCAUPdGFyZ2V0QmxvY2tJbmZvB3Jld2FyZHMFGnByb3h5VHJlYXN1cnlBZGRyZXNzT3JGYWlsCQEHd3JhcEVycgEJAKwCAgIjaW52YWxpZCB0cmVhc3VyeSByZXdhcmQgZm9yIGhlaWdodCAJAKQDAQURdGFyZ2V0QmxvY2tIZWlnaHQJAJQKAgUDbmlsCQEYY2FsY1Jld2FyZFNwbGl0Rm9yQW1vdW50AQUUdHJlYXN1cnlSZXdhcmRPckZhaWwBaQEHY2xhaW1MUAEQdXNlckFkZHJlc3NCeXRlcwQLY2hlY2tDYWxsZXIJAQtvbmx5RmFjdG9yeQEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyBAt1c2VyQWRkcmVzcwkBB0FkZHJlc3MBBRB1c2VyQWRkcmVzc0J5dGVzBAlhdmFpbGFibGUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJAQxrZXlBdmFpbGFibGUBBQt1c2VyQWRkcmVzcwAABAdjbGFpbWVkCQELdmFsdWVPckVsc2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEKa2V5Q2xhaW1lZAEFC3VzZXJBZGRyZXNzAAAEDmZhY3RvcnlBY3Rpb25zAwkAZgIFCWF2YWlsYWJsZQAACQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCDXRyYW5zZmVyQXNzZXQJAMwIAgUQdXNlckFkZHJlc3NCeXRlcwkAzAgCBQlhdmFpbGFibGUJAMwIAgUPbHBBc3NldElkT3JGYWlsBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgxpbnRlZ2VyRW50cnkJAMwIAgkBDGtleUF2YWlsYWJsZQEFC3VzZXJBZGRyZXNzCQDMCAIAAAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIMaW50ZWdlckVudHJ5CQDMCAIJAQprZXlDbGFpbWVkAQULdXNlckFkZHJlc3MJAMwIAgkAZAIFB2NsYWltZWQFCWF2YWlsYWJsZQUDbmlsBQNuaWwFA25pbAkBCHRocm93RXJyAQIQbm90aGluZyB0byBjbGFpbQkAlAoCBQNuaWwFDmZhY3RvcnlBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCGZpbmFsaXplBRB1c2VyQWRkcmVzc0J5dGVzE2RvbmF0aW9uUGFydEluV2F2ZXMNbHBQYXJ0SW5XYXZlcxBjbGFpbVBhcnRJbldhdmVzFXBvd2VyU3Rha2VQYXJ0SW5XYXZlcwQLY2hlY2tDYWxsZXIJAQtvbmx5RmFjdG9yeQEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyBBNjdXJyZW50UGVyaW9kT3JGYWlsCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJARBrZXlDdXJyZW50UGVyaW9kAAkBB3dyYXBFcnIBAg5pbnZhbGlkIHBlcmlvZAQMcGVyaW9kTGVuZ3RoCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJAQ9rZXlQZXJpb2RMZW5ndGgACQEHd3JhcEVycgECFWludmFsaWQgcGVyaW9kIGxlbmd0aAQSY3VycmVudFN0YXJ0SGVpZ2h0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJAQ5rZXlTdGFydEhlaWdodAEFE2N1cnJlbnRQZXJpb2RPckZhaWwJAQd3cmFwRXJyAQIUaW52YWxpZCBzdGFydCBoZWlnaHQEEmN1cnJlbnRQcmljZU9yRmFpbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQERa2V5UHJpY2VGb3JQZXJpb2QBBRNjdXJyZW50UGVyaW9kT3JGYWlsCQEHd3JhcEVycgECDWludmFsaWQgcHJpY2UEEm5leHRCbG9ja1RvUHJvY2VzcwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEVa2V5TmV4dEJsb2NrVG9Qcm9jZXNzAAkBB3dyYXBFcnIBAh1pbnZhbGlkIG5leHQgYmxvY2sgdG8gcHJvY2VzcwQPcGVyaW9kRW5kSGVpZ2h0CQBlAgkAZAIFEmN1cnJlbnRTdGFydEhlaWdodAUMcGVyaW9kTGVuZ3RoAAEEBmNoZWNrcwkAzAgCAwkAAAIIBQFpDG9yaWdpbkNhbGxlcgUZbWFpblRyZWFzdXJ5QWRkcmVzc09yRmFpbAYJAQh0aHJvd0VycgECEXBlcm1pc3Npb24gZGVuaWVkCQDMCAIDCQBmAgUSbmV4dEJsb2NrVG9Qcm9jZXNzBQ9wZXJpb2RFbmRIZWlnaHQGCQEIdGhyb3dFcnIBAhJ1bnByb2Nlc3NlZCBibG9ja3MJAMwIAgMJAGcCBRNkb25hdGlvblBhcnRJbldhdmVzAAAGCQEIdGhyb3dFcnIBAhVpbnZhbGlkIGRvbmF0aW9uIHBhcnQJAMwIAgMJAGcCBQ1scFBhcnRJbldhdmVzAAAGCQEIdGhyb3dFcnIBAg9pbnZhbGlkIGxwIHBhcnQJAMwIAgMJAGcCBRBjbGFpbVBhcnRJbldhdmVzAAAGCQEIdGhyb3dFcnIBAhJpbnZhbGlkIGNsYWltIHBhcnQJAMwIAgMJAGcCBRVwb3dlclN0YWtlUGFydEluV2F2ZXMAAAYJAQh0aHJvd0VycgECFmludmFsaWQgUFdSIHN0YWtlIHBhcnQFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQNJHQwMTM1MTMxMzYxOAkBDmNhbGN1bGF0ZVByaWNlAQUNbHBQYXJ0SW5XYXZlcwQIbmV3UHJpY2UIBQ0kdDAxMzUxMzEzNjE4Al8xBBNscEFzc2V0QW1vdW50VG9CdXJuCAUNJHQwMTM1MTMxMzYxOAJfMgQUbHBBc3NldEZpbmFsUXVhbnRpdHkIBQ0kdDAxMzUxMzEzNjE4Al8zBAluZXdQZXJpb2QJAGQCBRNjdXJyZW50UGVyaW9kT3JGYWlsAAEKAQxhZGROZXdBY3Rpb24CB2FjdGlvbnMHcGF5bWVudAQNJHQwMTM3NjYxMzgyOAUHYWN0aW9ucwQPc2NyaXB0VHJhbnNmZXJzCAUNJHQwMTM3NjYxMzgyOAJfMQQOYXNzZXRJZHNTdHJpbmcIBQ0kdDAxMzc2NjEzODI4Al8yBA1hbW91bnRzU3RyaW5nCAUNJHQwMTM3NjYxMzgyOAJfMwQNcGF5bWVudEFtb3VudAgFB3BheW1lbnQGYW1vdW50BA5wYXltZW50QXNzZXRJZAgFB3BheW1lbnQHYXNzZXRJZAQRbmV3QXNzZXRJZHNTdHJpbmcJAKwCAgICJXMJALkJAgkAzAgCBQ5hc3NldElkc1N0cmluZwkAzAgCCQEPYXNzZXRJZFRvU3RyaW5nAQUOcGF5bWVudEFzc2V0SWQFA25pbAUDU0VQBBBuZXdBbW91bnRzU3RyaW5nCQCsAgICAiVkCQC5CQIJAMwIAgUNYW1vdW50c1N0cmluZwkAzAgCCQCkAwEFDXBheW1lbnRBbW91bnQFA25pbAUDU0VQBBFuZXdTY3JpcHRUcmFuc2ZlcgkBDlNjcmlwdFRyYW5zZmVyAwUUZmFjdG9yeUFkZHJlc3NPckZhaWwFDXBheW1lbnRBbW91bnQFDnBheW1lbnRBc3NldElkCQCVCgMJAM0IAgUPc2NyaXB0VHJhbnNmZXJzBRFuZXdTY3JpcHRUcmFuc2ZlcgURbmV3QXNzZXRJZHNTdHJpbmcFEG5ld0Ftb3VudHNTdHJpbmcEDSR0MDE0Mjg4MTQzNzkKAAIkbAgFAWkIcGF5bWVudHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCVCgMFA25pbAIAAgAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDGFkZE5ld0FjdGlvbgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgQPc2NyaXB0VHJhbnNmZXJzCAUNJHQwMTQyODgxNDM3OQJfMQQIQXNzZXRJZHMIBQ0kdDAxNDI4ODE0Mzc5Al8yBAdBbW91bnRzCAUNJHQwMTQyODgxNDM3OQJfMwQOZmFjdG9yeUFjdGlvbnMJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIMaW50ZWdlckVudHJ5CQDMCAIJARRrZXlQb3dlck1hbmFnZXJCb251cwEFE2N1cnJlbnRQZXJpb2RPckZhaWwJAMwIAgUVcG93ZXJTdGFrZVBhcnRJbldhdmVzBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgxpbnRlZ2VyRW50cnkJAMwIAgkBE2tleUNsYWltV2F2ZXNBbW91bnQBBRNjdXJyZW50UGVyaW9kT3JGYWlsCQDMCAIFEGNsYWltUGFydEluV2F2ZXMFA25pbAUDbmlsCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCDGludGVnZXJFbnRyeQkAzAgCCQEQa2V5Q3VycmVudFBlcmlvZAAJAMwIAgUJbmV3UGVyaW9kBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgxpbnRlZ2VyRW50cnkJAMwIAgkBEWtleVByaWNlRm9yUGVyaW9kAQUJbmV3UGVyaW9kCQDMCAIFCG5ld1ByaWNlBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgxpbnRlZ2VyRW50cnkJAMwIAgkBDmtleVN0YXJ0SGVpZ2h0AQUJbmV3UGVyaW9kCQDMCAIJAGQCBQ9wZXJpb2RFbmRIZWlnaHQAAQUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIEYnVybgkAzAgCBRNscEFzc2V0QW1vdW50VG9CdXJuBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgxpbnRlZ2VyRW50cnkJAMwIAgkBDWtleVdpdGhkcmF3YWwACQDMCAIAAAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIMaW50ZWdlckVudHJ5CQDMCAIJAQtrZXlJbnZlc3RlZAEFBHVuaXQJAMwIAgUNbHBQYXJ0SW5XYXZlcwUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIMaW50ZWdlckVudHJ5CQDMCAIJAQprZXlEb25hdGVkAQUEdW5pdAkAzAgCBRNkb25hdGlvblBhcnRJbldhdmVzBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgtzdHJpbmdFbnRyeQkAzAgCCQEba2V5UGVyaW9kV2l0aGRyYXdhbEFzc2V0SWRzAQUJbmV3UGVyaW9kCQDMCAIFCEFzc2V0SWRzBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgtzdHJpbmdFbnRyeQkAzAgCCQEaa2V5UGVyaW9kV2l0aGRyYXdhbEFtb3VudHMBBQluZXdQZXJpb2QJAMwIAgUHQW1vdW50cwUDbmlsBQNuaWwFA25pbAkAlAoCBQ9zY3JpcHRUcmFuc2ZlcnMFDmZhY3RvcnlBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBEGZpbmFsaXplUkVBRE9OTFkEE2RvbmF0aW9uUGFydEluV2F2ZXMNbHBQYXJ0SW5XYXZlcxBjbGFpbVBhcnRJbldhdmVzFXBvd2VyU3Rha2VQYXJ0SW5XYXZlcwQTY3VycmVudFBlcmlvZE9yRmFpbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEQa2V5Q3VycmVudFBlcmlvZAAJAQd3cmFwRXJyAQIOaW52YWxpZCBwZXJpb2QEDHBlcmlvZExlbmd0aAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEPa2V5UGVyaW9kTGVuZ3RoAAkBB3dyYXBFcnIBAhVpbnZhbGlkIHBlcmlvZCBsZW5ndGgEEmN1cnJlbnRTdGFydEhlaWdodAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEOa2V5U3RhcnRIZWlnaHQBBRNjdXJyZW50UGVyaW9kT3JGYWlsCQEHd3JhcEVycgECFGludmFsaWQgc3RhcnQgaGVpZ2h0BBJjdXJyZW50UHJpY2VPckZhaWwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBEWtleVByaWNlRm9yUGVyaW9kAQUTY3VycmVudFBlcmlvZE9yRmFpbAkBB3dyYXBFcnIBAg1pbnZhbGlkIHByaWNlBBJuZXh0QmxvY2tUb1Byb2Nlc3MJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBFWtleU5leHRCbG9ja1RvUHJvY2VzcwAJAQd3cmFwRXJyAQIdaW52YWxpZCBuZXh0IGJsb2NrIHRvIHByb2Nlc3MED3BlcmlvZEVuZEhlaWdodAkAZQIJAGQCBRJjdXJyZW50U3RhcnRIZWlnaHQFDHBlcmlvZExlbmd0aAABBAZjaGVja3MJAMwIAgMJAGYCBRJuZXh0QmxvY2tUb1Byb2Nlc3MFD3BlcmlvZEVuZEhlaWdodAYJAQh0aHJvd0VycgECEnVucHJvY2Vzc2VkIGJsb2NrcwkAzAgCAwkAZwIFE2RvbmF0aW9uUGFydEluV2F2ZXMAAAYJAQh0aHJvd0VycgECFWludmFsaWQgZG9uYXRpb24gcGFydAkAzAgCAwkAZwIFDWxwUGFydEluV2F2ZXMAAAYJAQh0aHJvd0VycgECD2ludmFsaWQgbHAgcGFydAkAzAgCAwkAZwIFEGNsYWltUGFydEluV2F2ZXMAAAYJAQh0aHJvd0VycgECEmludmFsaWQgY2xhaW0gcGFydAkAzAgCAwkAZwIFFXBvd2VyU3Rha2VQYXJ0SW5XYXZlcwAABgkBCHRocm93RXJyAQIWaW52YWxpZCBQV1Igc3Rha2UgcGFydAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBA0kdDAxNzI1ODE3MzYzCQEOY2FsY3VsYXRlUHJpY2UBBQ1scFBhcnRJbldhdmVzBAhuZXdQcmljZQgFDSR0MDE3MjU4MTczNjMCXzEEE2xwQXNzZXRBbW91bnRUb0J1cm4IBQ0kdDAxNzI1ODE3MzYzAl8yBBRscEFzc2V0RmluYWxRdWFudGl0eQgFDSR0MDE3MjU4MTczNjMCXzMJAJQKAgUDbmlsCQCYCgYFEGNsYWltUGFydEluV2F2ZXMFDWxwUGFydEluV2F2ZXMFE2RvbmF0aW9uUGFydEluV2F2ZXMFCG5ld1ByaWNlBRNscEFzc2V0QW1vdW50VG9CdXJuBRRscEFzc2V0RmluYWxRdWFudGl0eQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQZpbnZlc3QBEHVzZXJBZGRyZXNzQnl0ZXMEC2NoZWNrQ2FsbGVyCQELb25seUZhY3RvcnkBBQFpAwkAAAIFC2NoZWNrQ2FsbGVyBQtjaGVja0NhbGxlcgQLdXNlckFkZHJlc3MJAQdBZGRyZXNzAQUQdXNlckFkZHJlc3NCeXRlcwQTY3VycmVudFBlcmlvZE9yRmFpbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEQa2V5Q3VycmVudFBlcmlvZAAJAQd3cmFwRXJyAQIOaW52YWxpZCBwZXJpb2QEEmN1cnJlbnRTdGFydEhlaWdodAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEOa2V5U3RhcnRIZWlnaHQBBRNjdXJyZW50UGVyaW9kT3JGYWlsCQEHd3JhcEVycgECFGludmFsaWQgc3RhcnQgaGVpZ2h0BBJpbnZlc3RQZXJpb2RMZW5ndGgJARFAZXh0ck5hdGl2ZSgxMDUwKQIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEVa2V5SW52ZXN0UGVyaW9kTGVuZ3RoAAQLaGVpZ2h0Q2hlY2sDCQBmAgkAZAIFEmN1cnJlbnRTdGFydEhlaWdodAUSaW52ZXN0UGVyaW9kTGVuZ3RoBQZoZWlnaHQGCQEIdGhyb3dFcnIBAiF0b28gbGF0ZSB0byBpbnZlc3QgaW4gdGhpcyBwZXJpb2QDCQAAAgULaGVpZ2h0Q2hlY2sFC2hlaWdodENoZWNrBBJjdXJyZW50UHJpY2VPckZhaWwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBEWtleVByaWNlRm9yUGVyaW9kAQUTY3VycmVudFBlcmlvZE9yRmFpbAkBB3dyYXBFcnIBAg1pbnZhbGlkIHByaWNlBAdwYXltZW50AwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQkAkQMCCAUBaQhwYXltZW50cwAACQEIdGhyb3dFcnIBAhBpbnZhbGlkIHBheW1lbnRzBA0kdDAxODQ3MjE4NjQ5AwMJAAACCAUHcGF5bWVudAdhc3NldElkBQR1bml0CQBmAggFB3BheW1lbnQGYW1vdW50AAAHCQCUCgIIBQdwYXltZW50BmFtb3VudAgFB3BheW1lbnQHYXNzZXRJZAkBCHRocm93RXJyAQIWaW52YWxpZCBwYXltZW50IGFtb3VudAQNcGF5bWVudEFtb3VudAgFDSR0MDE4NDcyMTg2NDkCXzEEDnBheW1lbnRBc3NldElkCAUNJHQwMTg0NzIxODY0OQJfMgQMdHJlYXN1cnlQYXJ0CQELdmFsdWVPckVsc2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEXa2V5QnVzaW5lc3NUcmVhc3VyeVBhcnQAAAAEG3BheW1lbnRzV2l0aG91dFRyZWFzdXJ5UGFydAkAawMFDXBheW1lbnRBbW91bnQJAGUCBQZTQ0FMRTgFDHRyZWFzdXJ5UGFydAUGU0NBTEU4BA1scEFzc2V0QW1vdW50AwkAZgIFEmN1cnJlbnRQcmljZU9yRmFpbAAACQBrAwUbcGF5bWVudHNXaXRob3V0VHJlYXN1cnlQYXJ0BQZTQ0FMRTgFEmN1cnJlbnRQcmljZU9yRmFpbAAABAhpbnZlc3RlZAkBC3ZhbHVlT3JFbHNlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBC2tleUludmVzdGVkAQUEdW5pdAAABAdhY3Rpb25zCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFGW1haW5UcmVhc3VyeUFkZHJlc3NPckZhaWwFG3BheW1lbnRzV2l0aG91dFRyZWFzdXJ5UGFydAUOcGF5bWVudEFzc2V0SWQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUdYnVzaW5lc3NUcmVhc3VyeUFkZHJlc3NPckZhaWwFDHRyZWFzdXJ5UGFydAUOcGF5bWVudEFzc2V0SWQFA25pbAQOZmFjdG9yeUFjdGlvbnMJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIMaW50ZWdlckVudHJ5CQDMCAIJAQtrZXlJbnZlc3RlZAEFBHVuaXQJAMwIAgkAZAIFCGludmVzdGVkBRtwYXltZW50c1dpdGhvdXRUcmVhc3VyeVBhcnQFA25pbAUDbmlsCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCB3JlaXNzdWUJAMwIAgUNbHBBc3NldEFtb3VudAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAINdHJhbnNmZXJBc3NldAkAzAgCBRB1c2VyQWRkcmVzc0J5dGVzCQDMCAIFDWxwQXNzZXRBbW91bnQJAMwIAgUPbHBBc3NldElkT3JGYWlsBQNuaWwFA25pbAUDbmlsCQCUCgIFB2FjdGlvbnMFDmZhY3RvcnlBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCHdpdGhkcmF3ARB1c2VyQWRkcmVzc0J5dGVzBAtjaGVja0NhbGxlcgkBC29ubHlGYWN0b3J5AQUBaQMJAAACBQtjaGVja0NhbGxlcgULY2hlY2tDYWxsZXIEC3VzZXJBZGRyZXNzCQEHQWRkcmVzcwEFEHVzZXJBZGRyZXNzQnl0ZXMEE2N1cnJlbnRQZXJpb2RPckZhaWwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBEGtleUN1cnJlbnRQZXJpb2QACQEHd3JhcEVycgECDmludmFsaWQgcGVyaW9kBAxwZXJpb2RMZW5ndGgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBD2tleVBlcmlvZExlbmd0aAAJAQd3cmFwRXJyAQIVaW52YWxpZCBwZXJpb2QgbGVuZ3RoBBJjdXJyZW50U3RhcnRIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBDmtleVN0YXJ0SGVpZ2h0AQUTY3VycmVudFBlcmlvZE9yRmFpbAkBB3dyYXBFcnIBAhRpbnZhbGlkIHN0YXJ0IGhlaWdodAQLaGVpZ2h0Q2hlY2sDCQBmAgkAZAIFEmN1cnJlbnRTdGFydEhlaWdodAUMcGVyaW9kTGVuZ3RoBQZoZWlnaHQGCQEIdGhyb3dFcnIBAiN0b28gbGF0ZSB0byB3aXRoZHJhdyBpbiB0aGlzIHBlcmlvZAMJAAACBQtoZWlnaHRDaGVjawULaGVpZ2h0Q2hlY2sEB3BheW1lbnQDCQAAAgkAkAMBCAUBaQhwYXltZW50cwABCQCRAwIIBQFpCHBheW1lbnRzAAAJAQh0aHJvd0VycgEJAQd3cmFwRXJyAQIQaW52YWxpZCBwYXltZW50cwQOcGF5bWVudEFzc2V0SWQDCQAAAggFB3BheW1lbnQHYXNzZXRJZAUPbHBBc3NldElkT3JGYWlsBQ9scEFzc2V0SWRPckZhaWwJAQh0aHJvd0VycgECFWludmFsaWQgcGF5bWVudCBhc3NldAQNcGF5bWVudEFtb3VudAMJAGYCCAUHcGF5bWVudAZhbW91bnQAAAgFB3BheW1lbnQGYW1vdW50CQEIdGhyb3dFcnIBAhZpbnZhbGlkIHBheW1lbnQgYW1vdW50BAp3aXRoZHJhd2FsCQELdmFsdWVPckVsc2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQENa2V5V2l0aGRyYXdhbAAAAAQHYWN0aW9ucwkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRRmYWN0b3J5QWRkcmVzc09yRmFpbAUNcGF5bWVudEFtb3VudAUOcGF5bWVudEFzc2V0SWQFA25pbAQOZmFjdG9yeUFjdGlvbnMJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIMaW50ZWdlckVudHJ5CQDMCAIJAQ1rZXlXaXRoZHJhd2FsAAkAzAgCCQBkAgUKd2l0aGRyYXdhbAUNcGF5bWVudEFtb3VudAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAILc3RyaW5nRW50cnkJAMwIAgkBFGtleVdpdGhkcmF3YWxSZXF1ZXN0AgULdXNlckFkZHJlc3MIBQFpDXRyYW5zYWN0aW9uSWQJAMwIAgkBFnZhbHVlV2l0aGRyYXdhbFJlcXVlc3QEBQdQRU5ESU5HBQ1wYXltZW50QW1vdW50CQBkAgUTY3VycmVudFBlcmlvZE9yRmFpbAABBQR1bml0BQNuaWwFA25pbAUDbmlsAwkAAAIFDmZhY3RvcnlBY3Rpb25zBQ5mYWN0b3J5QWN0aW9ucwkAlAoCBQdhY3Rpb25zBQ5mYWN0b3J5QWN0aW9ucwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ5jYW5jZWxXaXRoZHJhdwIQdXNlckFkZHJlc3NCeXRlcwR0eElkBAtjaGVja0NhbGxlcgkBC29ubHlGYWN0b3J5AQUBaQMJAAACBQtjaGVja0NhbGxlcgULY2hlY2tDYWxsZXIJAQh0aHJvd0VycgECHGNhbmNlbFdpdGhkcmF3IGlzIGRlcHJlY2F0ZWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEPY2xhaW1Db2xsYXRlcmFsAhB1c2VyQWRkcmVzc0J5dGVzBHR4SWQEC2NoZWNrQ2FsbGVyCQELb25seUZhY3RvcnkBBQFpAwkAAAIFC2NoZWNrQ2FsbGVyBQtjaGVja0NhbGxlcgQNJHQwMjE2MTYyMTgwMQkBF2NsYWltQ29sbGF0ZXJhbElOVEVSTkFMAgUQdXNlckFkZHJlc3NCeXRlcwkA2QQBBQR0eElkBAt1c2VyQWRkcmVzcwgFDSR0MDIxNjE2MjE4MDECXzEEDWxwQXNzZXRBbW91bnQIBQ0kdDAyMTYxNjIxODAxAl8yBAx0YXJnZXRQZXJpb2QIBQ0kdDAyMTYxNjIxODAxAl8zBAt3YXZlc0Ftb3VudAgFDSR0MDIxNjE2MjE4MDECXzQEDGFzc2V0c1N0cmluZwgFDSR0MDIxNjE2MjE4MDECXzUEDWFtb3VudHNTdHJpbmcIBQ0kdDAyMTYxNjIxODAxAl82BAphc3NldHNMaXN0CQDRCAIJAL0JAgUMYXNzZXRzU3RyaW5nBQNTRVAAAAQLYW1vdW50c0xpc3QJANEIAgkAvQkCBQ1hbW91bnRzU3RyaW5nBQNTRVAAAAQOZmFjdG9yeUFjdGlvbnMJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAILZGVsZXRlRW50cnkJAMwIAgkBFGtleVdpdGhkcmF3YWxSZXF1ZXN0AgULdXNlckFkZHJlc3MJANkEAQUEdHhJZAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIMaW50ZWdlckVudHJ5CQDMCAIJARRrZXlXaXRoZHJhd2FsSGlzdG9yeQIFC3VzZXJBZGRyZXNzCQDZBAEFBHR4SWQJAMwIAgUNbHBBc3NldEFtb3VudAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIOdHJhbnNmZXJBc3NldHMJAMwIAgUQdXNlckFkZHJlc3NCeXRlcwkAzAgCBQphc3NldHNMaXN0CQDMCAIFC2Ftb3VudHNMaXN0BQNuaWwFA25pbAUDbmlsCQCUCgIFA25pbAUOZmFjdG9yeUFjdGlvbnMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQETY2xhaW1Db2xsYXRlcmFsQnVsawIQdXNlckFkZHJlc3NCeXRlcwV0eElkcwQLY2hlY2tDYWxsZXIJAQtvbmx5RmFjdG9yeQEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyCgEMYWRkTmV3QWN0aW9uAgVzdGF0ZQR0eElkBA0kdDAyMjU1OTIyNzU4CQEXY2xhaW1Db2xsYXRlcmFsSU5URVJOQUwCBRB1c2VyQWRkcmVzc0J5dGVzCQDZBAEFBHR4SWQEC3VzZXJBZGRyZXNzCAUNJHQwMjI1NTkyMjc1OAJfMQQNbHBBc3NldEFtb3VudAgFDSR0MDIyNTU5MjI3NTgCXzIEDHRhcmdldFBlcmlvZAgFDSR0MDIyNTU5MjI3NTgCXzMEC3dhdmVzQW1vdW50CAUNJHQwMjI1NTkyMjc1OAJfNAQMYXNzZXRzU3RyaW5nCAUNJHQwMjI1NTkyMjc1OAJfNQQNYW1vdW50c1N0cmluZwgFDSR0MDIyNTU5MjI3NTgCXzYECmFzc2V0c0xpc3QJANEIAgkAvQkCBQxhc3NldHNTdHJpbmcFA1NFUAAABAthbW91bnRzTGlzdAkA0QgCCQC9CQIFDWFtb3VudHNTdHJpbmcFA1NFUAAABApuZXdBY3Rpb25zCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCC2RlbGV0ZUVudHJ5CQDMCAIJARRrZXlXaXRoZHJhd2FsUmVxdWVzdAIFC3VzZXJBZGRyZXNzCQDZBAEFBHR4SWQFA25pbAUDbmlsCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCDGludGVnZXJFbnRyeQkAzAgCCQEUa2V5V2l0aGRyYXdhbEhpc3RvcnkCBQt1c2VyQWRkcmVzcwkA2QQBBQR0eElkCQDMCAIFDWxwQXNzZXRBbW91bnQFA25pbAUDbmlsCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCDnRyYW5zZmVyQXNzZXRzCQDMCAIFEHVzZXJBZGRyZXNzQnl0ZXMJAMwIAgUKYXNzZXRzTGlzdAkAzAgCBQthbW91bnRzTGlzdAUDbmlsBQNuaWwFA25pbAkAzggCBQVzdGF0ZQUKbmV3QWN0aW9ucwQRYWxsRmFjdG9yeUFjdGlvbnMKAAIkbAUFdHhJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDGFkZE5ld0FjdGlvbgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgkAlAoCBQNuaWwFEWFsbEZhY3RvcnlBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBF2NsYWltQ29sbGF0ZXJhbFJFQURPTkxZAhB1c2VyQWRkcmVzc0J5dGVzBHR4SWQECHJlc3BvbnNlCQElY2xhaW1Db2xsYXRlcmFsUkVBRE9OTFlTdHJpbmdSZXNwb25zZQIFEHVzZXJBZGRyZXNzQnl0ZXMJANkEAQUEdHhJZAkAlAoCBQNuaWwFCHJlc3BvbnNlAWkBG2NsYWltQ29sbGF0ZXJhbEJ1bGtSRUFET05MWQIQdXNlckFkZHJlc3NCeXRlcwV0eElkcwoBC3Byb2Nlc3NUeElkAgVzdGF0ZQR0eElkBAhyZXNwb25zZQkBJWNsYWltQ29sbGF0ZXJhbFJFQURPTkxZU3RyaW5nUmVzcG9uc2UCBRB1c2VyQWRkcmVzc0J5dGVzCQDZBAEFBHR4SWQJAM0IAgUFc3RhdGUFCHJlc3BvbnNlBAxhbGxSZXNwb25zZXMKAAIkbAUFdHhJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBC3Byb2Nlc3NUeElkAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKCQCUCgIFA25pbAUMYWxsUmVzcG9uc2VzAWkBDXByb2Nlc3NCbG9ja3MBEHVzZXJBZGRyZXNzQnl0ZXMEC2NoZWNrQ2FsbGVyCQELb25seUZhY3RvcnkBBQFpAwkAAAIFC2NoZWNrQ2FsbGVyBQtjaGVja0NhbGxlcgQLdXNlckFkZHJlc3MJAQdBZGRyZXNzAQUQdXNlckFkZHJlc3NCeXRlcwQTY3VycmVudFBlcmlvZE9yRmFpbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEQa2V5Q3VycmVudFBlcmlvZAAJAQd3cmFwRXJyAQIOaW52YWxpZCBwZXJpb2QEDHBlcmlvZExlbmd0aAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEPa2V5UGVyaW9kTGVuZ3RoAAkBB3dyYXBFcnIBAhVpbnZhbGlkIHBlcmlvZCBsZW5ndGgEEmN1cnJlbnRTdGFydEhlaWdodAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEOa2V5U3RhcnRIZWlnaHQBBRNjdXJyZW50UGVyaW9kT3JGYWlsCQEHd3JhcEVycgECFGludmFsaWQgc3RhcnQgaGVpZ2h0BBJjdXJyZW50UHJpY2VPckZhaWwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBEWtleVByaWNlRm9yUGVyaW9kAQUTY3VycmVudFBlcmlvZE9yRmFpbAkBB3dyYXBFcnIBAg1pbnZhbGlkIHByaWNlBBJuZXh0QmxvY2tUb1Byb2Nlc3MJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBRRmYWN0b3J5QWRkcmVzc09yRmFpbAkBFWtleU5leHRCbG9ja1RvUHJvY2VzcwAJAQd3cmFwRXJyAQIdaW52YWxpZCBuZXh0IGJsb2NrIHRvIHByb2Nlc3MED3BlcmlvZEVuZEhlaWdodAkAZQIJAGQCBRJjdXJyZW50U3RhcnRIZWlnaHQFDHBlcmlvZExlbmd0aAABBBlibG9ja3NQcm9jZXNzaW5nQmF0Y2hTaXplAwMDCQBnAgUGaGVpZ2h0BRJuZXh0QmxvY2tUb1Byb2Nlc3MDCQBnAgUSbmV4dEJsb2NrVG9Qcm9jZXNzBRJjdXJyZW50U3RhcnRIZWlnaHQGCQAAAgUTY3VycmVudFBlcmlvZE9yRmFpbAAABwkAZwIFD3BlcmlvZEVuZEhlaWdodAUSbmV4dEJsb2NrVG9Qcm9jZXNzBwkAlwMBCQDMCAIJAGQCCQBlAgUPcGVyaW9kRW5kSGVpZ2h0BRJuZXh0QmxvY2tUb1Byb2Nlc3MAAQkAzAgCBRxibG9ja3NQcm9jZXNzaW5nQmF0Y2hTaXplTWF4BQNuaWwJAQh0aHJvd0VycgEJAQd3cmFwRXJyAQIUaW52YWxpZCB0YXJnZXQgYmxvY2sEFWJsb2NrUHJvY2Vzc2luZ1Jld2FyZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFFGZhY3RvcnlBZGRyZXNzT3JGYWlsCQEYa2V5QmxvY2tQcm9jZXNzaW5nUmV3YXJkAAkBB3dyYXBFcnIBAh9pbnZhbGlkIGJsb2NrIHByb2Nlc3NpbmcgcmV3YXJkBCBibG9ja1Byb2Nlc3NpbmdSZXdhcmRCeUdlbmVyYXRvcgkAaQIFFWJsb2NrUHJvY2Vzc2luZ1Jld2FyZAUZYmxvY2tzUHJvY2Vzc2luZ0JhdGNoU2l6ZQQpYmxvY2tQcm9jZXNzaW5nUmV3YXJkQnlHZW5lcmF0b3JSZW1haW5kZXIJAGUCBRVibG9ja1Byb2Nlc3NpbmdSZXdhcmQJAGgCBSBibG9ja1Byb2Nlc3NpbmdSZXdhcmRCeUdlbmVyYXRvcgUZYmxvY2tzUHJvY2Vzc2luZ0JhdGNoU2l6ZQoBA21hcAIDYWNjA2luYwMJAGcCBQNpbmMFGWJsb2Nrc1Byb2Nlc3NpbmdCYXRjaFNpemUFA2FjYwQRdGFyZ2V0QmxvY2tIZWlnaHQJAGQCBRJuZXh0QmxvY2tUb1Byb2Nlc3MFA2luYwQPdGFyZ2V0QmxvY2tJbmZvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAO0HAQURdGFyZ2V0QmxvY2tIZWlnaHQJAQd3cmFwRXJyAQISaW52YWxpZCBibG9jayBpbmZvBBR0cmVhc3VyeVJld2FyZE9yRmFpbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQEPcmV3YXJkRm9yT3B0aW9uAggFD3RhcmdldEJsb2NrSW5mbwdyZXdhcmRzBRpwcm94eVRyZWFzdXJ5QWRkcmVzc09yRmFpbAkBB3dyYXBFcnIBCQCsAgICI2ludmFsaWQgdHJlYXN1cnkgcmV3YXJkIGZvciBoZWlnaHQgCQCkAwEFEXRhcmdldEJsb2NrSGVpZ2h0BAlnZW5lcmF0b3IIBQ90YXJnZXRCbG9ja0luZm8JZ2VuZXJhdG9yBAlhdmFpbGFibGUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJAQxrZXlBdmFpbGFibGUBBQlnZW5lcmF0b3IAAAQMY2FsbGVyUmV3YXJkAwkAAAIFA2luYwkAZQIFGWJsb2Nrc1Byb2Nlc3NpbmdCYXRjaFNpemUAAQkAZAIFIGJsb2NrUHJvY2Vzc2luZ1Jld2FyZEJ5R2VuZXJhdG9yBSlibG9ja1Byb2Nlc3NpbmdSZXdhcmRCeUdlbmVyYXRvclJlbWFpbmRlcgUgYmxvY2tQcm9jZXNzaW5nUmV3YXJkQnlHZW5lcmF0b3IEDSR0MDI2NjU4MjY3NjYJAQ5nZXRSZXdhcmRTcGxpdAEFFHRyZWFzdXJ5UmV3YXJkT3JGYWlsBBJzaGFyZUFtb3VudFRvUG93ZXIIBQ0kdDAyNjY1ODI2NzY2Al8xBBpidXNpbmVzc1RyZWFzdXJ5QW1vdW50UGFydAgFDSR0MDI2NjU4MjY3NjYCXzIED3Jld2FyZFJlbWFpbmRlcggFDSR0MDI2NjU4MjY3NjYCXzMEDWxwQXNzZXRBbW91bnQDCQBmAgUSY3VycmVudFByaWNlT3JGYWlsAAAJAGsDCQBlAgUPcmV3YXJkUmVtYWluZGVyBQxjYWxsZXJSZXdhcmQFBlNDQUxFOAUSY3VycmVudFByaWNlT3JGYWlsAAAEFGZhY3RvcnlBY3Rpb25zU2luZ2xlCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCC3N0cmluZ0VudHJ5CQDMCAIJARFrZXlCbG9ja1Byb2Nlc3NlZAEFEXRhcmdldEJsb2NrSGVpZ2h0CQDMCAIJALkJAgkAzAgCCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQJAMwIAgkApAMBBRNjdXJyZW50UGVyaW9kT3JGYWlsCQDMCAIJAKUIAQUJZ2VuZXJhdG9yCQDMCAIJANgEAQUQdXNlckFkZHJlc3NCeXRlcwkAzAgCCQCkAwEFFHRyZWFzdXJ5UmV3YXJkT3JGYWlsCQDMCAIJAKQDAQUMY2FsbGVyUmV3YXJkCQDMCAIJAKQDAQUNbHBBc3NldEFtb3VudAkAzAgCCQCkAwEFEnNoYXJlQW1vdW50VG9Qb3dlcgUDbmlsBQNTRVAFA25pbAUDbmlsCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCDGludGVnZXJFbnRyeQkAzAgCCQEMa2V5QXZhaWxhYmxlAQUJZ2VuZXJhdG9yCQDMCAIJAGQCBQlhdmFpbGFibGUFDWxwQXNzZXRBbW91bnQFA25pbAUDbmlsBQNuaWwDCQAAAgUUZmFjdG9yeUFjdGlvbnNTaW5nbGUFFGZhY3RvcnlBY3Rpb25zU2luZ2xlBA0kdDAyNzYxNDI3Njg5BQNhY2MECmxwQXNzZXRBY2MIBQ0kdDAyNzYxNDI3Njg5Al8xBAlyZXdhcmRBY2MIBQ0kdDAyNzYxNDI3Njg5Al8yBBNidXNpbmVzc1RyZWFzdXJ5QWNjCAUNJHQwMjc2MTQyNzY4OQJfMwQTcG93ZXJTaGFyZURhdGFUdXBsZQgFDSR0MDI3NjE0Mjc2ODkCXzQEDSR0MDI3Njk2Mjc3NjIFE3Bvd2VyU2hhcmVEYXRhVHVwbGUEDXBvd2VyU2hhcmVBY2MIBQ0kdDAyNzY5NjI3NzYyAl8xBBdnZW5lcmF0b3JQb3dlclNoYXJlTGlzdAgFDSR0MDI3Njk2Mjc3NjICXzIEGm5ld0dlbmVyYXRvclBvd2VyU2hhcmVMaXN0CQDNCAIFF2dlbmVyYXRvclBvd2VyU2hhcmVMaXN0CQCUCgIJAKUIAQUJZ2VuZXJhdG9yBRJzaGFyZUFtb3VudFRvUG93ZXIJAJYKBAkAZAIFCmxwQXNzZXRBY2MFDWxwQXNzZXRBbW91bnQJAGQCBQlyZXdhcmRBY2MFFHRyZWFzdXJ5UmV3YXJkT3JGYWlsCQBkAgUTYnVzaW5lc3NUcmVhc3VyeUFjYwUaYnVzaW5lc3NUcmVhc3VyeUFtb3VudFBhcnQJAJQKAgkAZAIFDXBvd2VyU2hhcmVBY2MFEnNoYXJlQW1vdW50VG9Qb3dlcgUabmV3R2VuZXJhdG9yUG93ZXJTaGFyZUxpc3QJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EBGxpc3QJAMwIAgAACQDMCAIAAQkAzAgCAAIJAMwIAgADCQDMCAIABAkAzAgCAAUJAMwIAgAGCQDMCAIABwkAzAgCAAgJAMwIAgAJCQDMCAIACgkAzAgCAAsJAMwIAgAMCQDMCAIADQkAzAgCAA4JAMwIAgAPCQDMCAIAEAkAzAgCABEJAMwIAgASCQDMCAIAEwUDbmlsBA0kdDAyODIxMDI4MzcyCgACJGwFBGxpc3QKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCWCgQAAAAAAAAJAJQKAgAABQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBA21hcAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMjAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUAwkAAAIFDSR0MDI4MjEwMjgzNzIFDSR0MDI4MjEwMjgzNzIEE3Bvd2VyU2hhcmVEYXRhVHVwbGUIBQ0kdDAyODIxMDI4MzcyAl80BB5yZXdhcmRUb0J1c2luZXNzVHJlYXN1cnlBbW91bnQIBQ0kdDAyODIxMDI4MzcyAl8zBBFyZXdhcmRBbW91bnRUb3RhbAgFDSR0MDI4MjEwMjgzNzICXzIEEmxwQXNzZXRBbW91bnRUb3RhbAgFDSR0MDI4MjEwMjgzNzICXzEEDSR0MDI4Mzc2Mjg0NDUFE3Bvd2VyU2hhcmVEYXRhVHVwbGUEEmFtb3VudFRvUG93ZXJUb3RhbAgFDSR0MDI4Mzc2Mjg0NDUCXzEEFXBvd2VyU2hhcmVBbW91bnRzTGlzdAgFDSR0MDI4Mzc2Mjg0NDUCXzIEGnJld2FyZFRvTWFpblRyZWFzdXJ5QW1vdW50CQBlAgkAZQIJAGUCBRFyZXdhcmRBbW91bnRUb3RhbAUecmV3YXJkVG9CdXNpbmVzc1RyZWFzdXJ5QW1vdW50BRVibG9ja1Byb2Nlc3NpbmdSZXdhcmQFEmFtb3VudFRvUG93ZXJUb3RhbAQIaW52ZXN0ZWQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUUZmFjdG9yeUFkZHJlc3NPckZhaWwJAQtrZXlJbnZlc3RlZAEFBHVuaXQAAAQRcG93ZXJTaGFyZUFjdGlvbnMDCQBmAgUSYW1vdW50VG9Qb3dlclRvdGFsAAAEDnRyYW5zZmVyQWN0aW9uCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCGXRyYW5zZmVyRnJvbVByb3h5VHJlYXN1cnkJAMwIAggFFGZhY3RvcnlBZGRyZXNzT3JGYWlsBWJ5dGVzCQDMCAIFEmFtb3VudFRvUG93ZXJUb3RhbAUDbmlsBQNuaWwFA25pbAMJAAACBQ50cmFuc2ZlckFjdGlvbgUOdHJhbnNmZXJBY3Rpb24EEHRvdGFsUG93ZXJBbW91bnQJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCBHN3YXAJAMwIAgUYcG93ZXJBc3NldElkU3RyaW5nT3JGYWlsCQDMCAIFBVdBVkVTCQDMCAIFEmFtb3VudFRvUG93ZXJUb3RhbAUDbmlsBQNuaWwDCQAAAgUQdG90YWxQb3dlckFtb3VudAUQdG90YWxQb3dlckFtb3VudAQTdG90YWxQb3dlckFtb3VudEludAQHJG1hdGNoMAUQdG90YWxQb3dlckFtb3VudAMJAAECBQckbWF0Y2gwAgNJbnQEB3BBbW91bnQFByRtYXRjaDAFB3BBbW91bnQAAAoBEHN0YWtlUG93ZXJJbnZva2UCA2FjYwRuZXh0BA0kdDAyOTMxOTI5MzU0BQRuZXh0BAlnZW5lcmF0b3IIBQ0kdDAyOTMxOTI5MzU0Al8xBAtzaGFyZUFtb3VudAgFDSR0MDI5MzE5MjkzNTQCXzIDCQBmAgUSYW1vdW50VG9Qb3dlclRvdGFsAAAEC3Bvd2VyQW1vdW50CQBrAwULc2hhcmVBbW91bnQFE3RvdGFsUG93ZXJBbW91bnRJbnQFEmFtb3VudFRvUG93ZXJUb3RhbAQDaW52CQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgpwb3dlclN0YWtlCQDMCAIJANkEAQUJZ2VuZXJhdG9yCQDMCAIJANkEAQUYcG93ZXJBc3NldElkU3RyaW5nT3JGYWlsCQDMCAIFC3Bvd2VyQW1vdW50BQNuaWwFA25pbAMJAAACBQNpbnYFA2ludgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBQNuaWwEEnBvd2VyU3Rha2VzQWN0aW9ucwoAAiRsBRVwb3dlclNoYXJlQW1vdW50c0xpc3QKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjFfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBEHN0YWtlUG93ZXJJbnZva2UCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjFfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYxXzICCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAMJAAACBRJwb3dlclN0YWtlc0FjdGlvbnMFEnBvd2VyU3Rha2VzQWN0aW9ucwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBQNuaWwDCQAAAgURcG93ZXJTaGFyZUFjdGlvbnMFEXBvd2VyU2hhcmVBY3Rpb25zBAdhY3Rpb25zCQDMCAIJAPwHBAUUZmFjdG9yeUFkZHJlc3NPckZhaWwCB3JlaXNzdWUJAMwIAgUSbHBBc3NldEFtb3VudFRvdGFsBQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgxpbnRlZ2VyRW50cnkJAMwIAgkBFWtleU5leHRCbG9ja1RvUHJvY2VzcwAJAMwIAgkAZAIFEm5leHRCbG9ja1RvUHJvY2VzcwUZYmxvY2tzUHJvY2Vzc2luZ0JhdGNoU2l6ZQUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIZdHJhbnNmZXJGcm9tUHJveHlUcmVhc3VyeQkAzAgCCAUZbWFpblRyZWFzdXJ5QWRkcmVzc09yRmFpbAVieXRlcwkAzAgCBRpyZXdhcmRUb01haW5UcmVhc3VyeUFtb3VudAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIZdHJhbnNmZXJGcm9tUHJveHlUcmVhc3VyeQkAzAgCBRB1c2VyQWRkcmVzc0J5dGVzCQDMCAIFFWJsb2NrUHJvY2Vzc2luZ1Jld2FyZAUDbmlsBQNuaWwJAMwIAgkA/AcEBRRmYWN0b3J5QWRkcmVzc09yRmFpbAIZdHJhbnNmZXJGcm9tUHJveHlUcmVhc3VyeQkAzAgCCAUdYnVzaW5lc3NUcmVhc3VyeUFkZHJlc3NPckZhaWwFYnl0ZXMJAMwIAgUecmV3YXJkVG9CdXNpbmVzc1RyZWFzdXJ5QW1vdW50BQNuaWwFA25pbAkAzAgCCQD8BwQFFGZhY3RvcnlBZGRyZXNzT3JGYWlsAgxpbnRlZ2VyRW50cnkJAMwIAgkBC2tleUludmVzdGVkAQUEdW5pdAkAzAgCCQBkAgUIaW52ZXN0ZWQFGnJld2FyZFRvTWFpblRyZWFzdXJ5QW1vdW50BQNuaWwFA25pbAUDbmlsAwkAAAIFB2FjdGlvbnMFB2FjdGlvbnMJAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQJcHVibGljS2V5BAckbWF0Y2gwCQEZZ2V0TWFuYWdlclB1YmxpY0tleU9yVW5pdAADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQDcHViBQckbWF0Y2gwBQNwdWIIBQJ0eA9zZW5kZXJQdWJsaWNLZXkJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCXB1YmxpY0tleW96YJ0=", "chainId": 84, "height": 2722925, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: CphUDDL8wy6DDW4P13GA5Up16NHqiMwP9TkSLAjEchGk Next: 3g5NWKChUxZLhL17CbHBmZMnV1BRvXJFmTcYPsH2vsiT Diff:
Old | New | Differences | |
---|---|---|---|
10 | 10 | let PENDING = "PENDING" | |
11 | 11 | ||
12 | 12 | let WAVES = "WAVES" | |
13 | + | ||
14 | + | let blocksProcessingBatchSizeMax = 10 | |
13 | 15 | ||
14 | 16 | func wrapErr (s) = ((CONTRACT_NAME + ": ") + s) | |
15 | 17 | ||
277 | 279 | ||
278 | 280 | func rewardForOption (rewards,target) = { | |
279 | 281 | let s = size(rewards) | |
280 | - | let $ | |
281 | - | let a0 = $ | |
282 | - | let r0 = $ | |
283 | - | let $ | |
284 | - | let a1 = $ | |
285 | - | let r1 = $ | |
286 | - | let $ | |
287 | - | let a2 = $ | |
288 | - | let r2 = $ | |
282 | + | let $t066696694 = rewards[0] | |
283 | + | let a0 = $t066696694._1 | |
284 | + | let r0 = $t066696694._2 | |
285 | + | let $t066976722 = rewards[1] | |
286 | + | let a1 = $t066976722._1 | |
287 | + | let r1 = $t066976722._2 | |
288 | + | let $t067256750 = rewards[2] | |
289 | + | let a2 = $t067256750._1 | |
290 | + | let r2 = $t067256750._2 | |
289 | 291 | if (if ((s > 0)) | |
290 | 292 | then (a0 == target) | |
291 | 293 | else false) | |
322 | 324 | let userAddress = Address(userAddressBytes) | |
323 | 325 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
324 | 326 | let withdrawalRequestOption = valueOrErrorMessage(getString(factoryAddressOrFail, keyWithdrawalRequest(userAddress, txId)), wrapErr("invalid withdrawal request")) | |
325 | - | let $ | |
326 | - | let status = $ | |
327 | - | let lpAssetAmount = $ | |
328 | - | let targetPeriod = $ | |
329 | - | let claimTxId = $ | |
327 | + | let $t079178030 = parseWithdrawalRequestValueOrFail(withdrawalRequestOption) | |
328 | + | let status = $t079178030._1 | |
329 | + | let lpAssetAmount = $t079178030._2 | |
330 | + | let targetPeriod = $t079178030._3 | |
331 | + | let claimTxId = $t079178030._4 | |
330 | 332 | if ((targetPeriod > currentPeriodOrFail)) | |
331 | 333 | then throwErr("invalid withdrawal request period") | |
332 | 334 | else { | |
342 | 344 | ||
343 | 345 | ||
344 | 346 | func claimCollateralREADONLYStringResponse (userAddressBytes,txId) = { | |
345 | - | let $ | |
346 | - | let userAddress = $ | |
347 | - | let lpAssetAmount = $ | |
348 | - | let targetPeriod = $ | |
349 | - | let wavesAmount = $ | |
350 | - | let assetsString = $ | |
351 | - | let amountsString = $ | |
347 | + | let $t088178983 = claimCollateralINTERNAL(userAddressBytes, txId) | |
348 | + | let userAddress = $t088178983._1 | |
349 | + | let lpAssetAmount = $t088178983._2 | |
350 | + | let targetPeriod = $t088178983._3 | |
351 | + | let wavesAmount = $t088178983._4 | |
352 | + | let assetsString = $t088178983._5 | |
353 | + | let amountsString = $t088178983._6 | |
352 | 354 | let assets = makeString(removeByIndex(split_51C(assetsString, SEP), 0), ":") | |
353 | 355 | let amounts = makeString(removeByIndex(split_51C(amountsString, SEP), 0), ":") | |
354 | 356 | makeString(["%d%s%s", toString(wavesAmount), assets, amounts], SEP) | |
368 | 370 | ||
369 | 371 | ||
370 | 372 | func calcRewardSplitForAmount (amount) = { | |
371 | - | let blocksProcessingBatchSizeMax = 20 | |
372 | - | let $t01008410177 = getRewardSplit(amount) | |
373 | - | let amountToPowerPart = $t01008410177._1 | |
374 | - | let businessTreasuryAmountPart = $t01008410177._2 | |
375 | - | let rewardRemainder = $t01008410177._3 | |
373 | + | let $t01008210175 = getRewardSplit(amount) | |
374 | + | let amountToPowerPart = $t01008210175._1 | |
375 | + | let businessTreasuryAmountPart = $t01008210175._2 | |
376 | + | let rewardRemainder = $t01008210175._3 | |
376 | 377 | let blockProcessingReward = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyBlockProcessingReward()), wrapErr("invalid block processing reward")) | |
377 | 378 | let blockProcessingRewardByGenerator = (blockProcessingReward / blocksProcessingBatchSizeMax) | |
378 | 379 | let toLpAmount = (rewardRemainder - blockProcessingReward) | |
434 | 435 | else throwErr("invalid PWR stake part")] | |
435 | 436 | if ((checks == checks)) | |
436 | 437 | then { | |
437 | - | let $ | |
438 | - | let newPrice = $ | |
439 | - | let lpAssetAmountToBurn = $ | |
440 | - | let lpAssetFinalQuantity = $ | |
438 | + | let $t01351313618 = calculatePrice(lpPartInWaves) | |
439 | + | let newPrice = $t01351313618._1 | |
440 | + | let lpAssetAmountToBurn = $t01351313618._2 | |
441 | + | let lpAssetFinalQuantity = $t01351313618._3 | |
441 | 442 | let newPeriod = (currentPeriodOrFail + 1) | |
442 | 443 | func addNewAction (actions,payment) = { | |
443 | - | let $ | |
444 | - | let scriptTransfers = $ | |
445 | - | let assetIdsString = $ | |
446 | - | let amountsString = $ | |
444 | + | let $t01376613828 = actions | |
445 | + | let scriptTransfers = $t01376613828._1 | |
446 | + | let assetIdsString = $t01376613828._2 | |
447 | + | let amountsString = $t01376613828._3 | |
447 | 448 | let paymentAmount = payment.amount | |
448 | 449 | let paymentAssetId = payment.assetId | |
449 | 450 | let newAssetIdsString = ("%s" + makeString([assetIdsString, assetIdToString(paymentAssetId)], SEP)) | |
452 | 453 | $Tuple3((scriptTransfers :+ newScriptTransfer), newAssetIdsString, newAmountsString) | |
453 | 454 | } | |
454 | 455 | ||
455 | - | let $ | |
456 | + | let $t01428814379 = { | |
456 | 457 | let $l = i.payments | |
457 | 458 | let $s = size($l) | |
458 | 459 | let $acc0 = $Tuple3(nil, "", "") | |
466 | 467 | ||
467 | 468 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
468 | 469 | } | |
469 | - | let scriptTransfers = $ | |
470 | - | let AssetIds = $ | |
471 | - | let Amounts = $ | |
470 | + | let scriptTransfers = $t01428814379._1 | |
471 | + | let AssetIds = $t01428814379._2 | |
472 | + | let Amounts = $t01428814379._3 | |
472 | 473 | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyPowerManagerBonus(currentPeriodOrFail), powerStakePartInWaves], nil), invoke(factoryAddressOrFail, "integerEntry", [keyClaimWavesAmount(currentPeriodOrFail), claimPartInWaves], nil), invoke(factoryAddressOrFail, "integerEntry", [keyCurrentPeriod(), newPeriod], nil), invoke(factoryAddressOrFail, "integerEntry", [keyPriceForPeriod(newPeriod), newPrice], nil), invoke(factoryAddressOrFail, "integerEntry", [keyStartHeight(newPeriod), (periodEndHeight + 1)], nil), invoke(factoryAddressOrFail, "burn", [lpAssetAmountToBurn], nil), invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), 0], nil), invoke(factoryAddressOrFail, "integerEntry", [keyInvested(unit), lpPartInWaves], nil), invoke(factoryAddressOrFail, "integerEntry", [keyDonated(unit), donationPartInWaves], nil), invoke(factoryAddressOrFail, "stringEntry", [keyPeriodWithdrawalAssetIds(newPeriod), AssetIds], nil), invoke(factoryAddressOrFail, "stringEntry", [keyPeriodWithdrawalAmounts(newPeriod), Amounts], nil)] | |
473 | 474 | $Tuple2(scriptTransfers, factoryActions) | |
474 | 475 | } | |
500 | 501 | else throwErr("invalid PWR stake part")] | |
501 | 502 | if ((checks == checks)) | |
502 | 503 | then { | |
503 | - | let $ | |
504 | - | let newPrice = $ | |
505 | - | let lpAssetAmountToBurn = $ | |
506 | - | let lpAssetFinalQuantity = $ | |
504 | + | let $t01725817363 = calculatePrice(lpPartInWaves) | |
505 | + | let newPrice = $t01725817363._1 | |
506 | + | let lpAssetAmountToBurn = $t01725817363._2 | |
507 | + | let lpAssetFinalQuantity = $t01725817363._3 | |
507 | 508 | $Tuple2(nil, $Tuple6(claimPartInWaves, lpPartInWaves, donationPartInWaves, newPrice, lpAssetAmountToBurn, lpAssetFinalQuantity)) | |
508 | 509 | } | |
509 | 510 | else throw("Strict value is not equal to itself.") | |
529 | 530 | let payment = if ((size(i.payments) == 1)) | |
530 | 531 | then i.payments[0] | |
531 | 532 | else throwErr("invalid payments") | |
532 | - | let $ | |
533 | + | let $t01847218649 = if (if ((payment.assetId == unit)) | |
533 | 534 | then (payment.amount > 0) | |
534 | 535 | else false) | |
535 | 536 | then $Tuple2(payment.amount, payment.assetId) | |
536 | 537 | else throwErr("invalid payment amount") | |
537 | - | let paymentAmount = $ | |
538 | - | let paymentAssetId = $ | |
538 | + | let paymentAmount = $t01847218649._1 | |
539 | + | let paymentAssetId = $t01847218649._2 | |
539 | 540 | let treasuryPart = valueOrElse(getInteger(factoryAddressOrFail, keyBusinessTreasuryPart()), 0) | |
540 | 541 | let paymentsWithoutTreasuryPart = fraction(paymentAmount, (SCALE8 - treasuryPart), SCALE8) | |
541 | 542 | let lpAssetAmount = if ((currentPriceOrFail > 0)) | |
560 | 561 | then { | |
561 | 562 | let userAddress = Address(userAddressBytes) | |
562 | 563 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
563 | - | let payment = if ((size(i.payments) == 1)) | |
564 | - | then i.payments[0] | |
565 | - | else throwErr(wrapErr("invalid payments")) | |
566 | - | let paymentAssetId = if ((payment.assetId == lpAssetIdOrFail)) | |
567 | - | then lpAssetIdOrFail | |
568 | - | else throwErr("invalid payment asset") | |
569 | - | let paymentAmount = if ((payment.amount > 0)) | |
570 | - | then payment.amount | |
571 | - | else throwErr("invalid payment amount") | |
572 | - | let withdrawal = valueOrElse(getInteger(factoryAddressOrFail, keyWithdrawal()), 0) | |
573 | - | let actions = [ScriptTransfer(factoryAddressOrFail, paymentAmount, paymentAssetId)] | |
574 | - | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), (withdrawal + paymentAmount)], nil), invoke(factoryAddressOrFail, "stringEntry", [keyWithdrawalRequest(userAddress, i.transactionId), valueWithdrawalRequest(PENDING, paymentAmount, (currentPeriodOrFail + 1), unit)], nil)] | |
575 | - | if ((factoryActions == factoryActions)) | |
576 | - | then $Tuple2(actions, factoryActions) | |
564 | + | let periodLength = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPeriodLength()), wrapErr("invalid period length")) | |
565 | + | let currentStartHeight = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyStartHeight(currentPeriodOrFail)), wrapErr("invalid start height")) | |
566 | + | let heightCheck = if (((currentStartHeight + periodLength) > height)) | |
567 | + | then true | |
568 | + | else throwErr("too late to withdraw in this period") | |
569 | + | if ((heightCheck == heightCheck)) | |
570 | + | then { | |
571 | + | let payment = if ((size(i.payments) == 1)) | |
572 | + | then i.payments[0] | |
573 | + | else throwErr(wrapErr("invalid payments")) | |
574 | + | let paymentAssetId = if ((payment.assetId == lpAssetIdOrFail)) | |
575 | + | then lpAssetIdOrFail | |
576 | + | else throwErr("invalid payment asset") | |
577 | + | let paymentAmount = if ((payment.amount > 0)) | |
578 | + | then payment.amount | |
579 | + | else throwErr("invalid payment amount") | |
580 | + | let withdrawal = valueOrElse(getInteger(factoryAddressOrFail, keyWithdrawal()), 0) | |
581 | + | let actions = [ScriptTransfer(factoryAddressOrFail, paymentAmount, paymentAssetId)] | |
582 | + | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), (withdrawal + paymentAmount)], nil), invoke(factoryAddressOrFail, "stringEntry", [keyWithdrawalRequest(userAddress, i.transactionId), valueWithdrawalRequest(PENDING, paymentAmount, (currentPeriodOrFail + 1), unit)], nil)] | |
583 | + | if ((factoryActions == factoryActions)) | |
584 | + | then $Tuple2(actions, factoryActions) | |
585 | + | else throw("Strict value is not equal to itself.") | |
586 | + | } | |
577 | 587 | else throw("Strict value is not equal to itself.") | |
578 | 588 | } | |
579 | 589 | else throw("Strict value is not equal to itself.") | |
585 | 595 | func cancelWithdraw (userAddressBytes,txId) = { | |
586 | 596 | let checkCaller = onlyFactory(i) | |
587 | 597 | if ((checkCaller == checkCaller)) | |
588 | - | then { | |
589 | - | let userAddress = Address(userAddressBytes) | |
590 | - | let withdrawalRequestOption = valueOrErrorMessage(getString(factoryAddressOrFail, keyWithdrawalRequest(userAddress, txId)), wrapErr("invalid withdrawal request")) | |
591 | - | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
592 | - | let $t02138521498 = parseWithdrawalRequestValueOrFail(withdrawalRequestOption) | |
593 | - | let status = $t02138521498._1 | |
594 | - | let lpAssetAmount = $t02138521498._2 | |
595 | - | let targetPeriod = $t02138521498._3 | |
596 | - | let claimTxId = $t02138521498._4 | |
597 | - | let checks = [if ((status == PENDING)) | |
598 | - | then true | |
599 | - | else throwErr("invalid withdrawal request status"), if ((targetPeriod > currentPeriodOrFail)) | |
600 | - | then true | |
601 | - | else throwErr("invalid withdrawal request period")] | |
602 | - | if ((checks == checks)) | |
603 | - | then { | |
604 | - | let withdrawal = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyWithdrawal()), wrapErr("invalid total withdrawal amount")) | |
605 | - | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), if ((withdrawal >= lpAssetAmount)) | |
606 | - | then (withdrawal - lpAssetAmount) | |
607 | - | else throwErr("invalid withdrawal amount")], nil), invoke(factoryAddressOrFail, "deleteEntry", [keyWithdrawalRequest(userAddress, txId)], nil), invoke(factoryAddressOrFail, "transferAsset", [userAddressBytes, lpAssetAmount, lpAssetIdOrFail], nil)] | |
608 | - | if ((factoryActions == factoryActions)) | |
609 | - | then $Tuple2(nil, factoryActions) | |
610 | - | else throw("Strict value is not equal to itself.") | |
611 | - | } | |
612 | - | else throw("Strict value is not equal to itself.") | |
613 | - | } | |
598 | + | then throwErr("cancelWithdraw is deprecated") | |
614 | 599 | else throw("Strict value is not equal to itself.") | |
615 | 600 | } | |
616 | 601 | ||
621 | 606 | let checkCaller = onlyFactory(i) | |
622 | 607 | if ((checkCaller == checkCaller)) | |
623 | 608 | then { | |
624 | - | let $ | |
625 | - | let userAddress = $ | |
626 | - | let lpAssetAmount = $ | |
627 | - | let targetPeriod = $ | |
628 | - | let wavesAmount = $ | |
629 | - | let assetsString = $ | |
630 | - | let amountsString = $ | |
609 | + | let $t02161621801 = claimCollateralINTERNAL(userAddressBytes, fromBase58String(txId)) | |
610 | + | let userAddress = $t02161621801._1 | |
611 | + | let lpAssetAmount = $t02161621801._2 | |
612 | + | let targetPeriod = $t02161621801._3 | |
613 | + | let wavesAmount = $t02161621801._4 | |
614 | + | let assetsString = $t02161621801._5 | |
615 | + | let amountsString = $t02161621801._6 | |
631 | 616 | let assetsList = removeByIndex(split_51C(assetsString, SEP), 0) | |
632 | 617 | let amountsList = removeByIndex(split_51C(amountsString, SEP), 0) | |
633 | 618 | let factoryActions = [invoke(factoryAddressOrFail, "deleteEntry", [keyWithdrawalRequest(userAddress, fromBase58String(txId))], nil), invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawalHistory(userAddress, fromBase58String(txId)), lpAssetAmount], nil), invoke(factoryAddressOrFail, "transferAssets", [userAddressBytes, assetsList, amountsList], nil)] | |
644 | 629 | if ((checkCaller == checkCaller)) | |
645 | 630 | then { | |
646 | 631 | func addNewAction (state,txId) = { | |
647 | - | let $ | |
648 | - | let userAddress = $ | |
649 | - | let lpAssetAmount = $ | |
650 | - | let targetPeriod = $ | |
651 | - | let wavesAmount = $ | |
652 | - | let assetsString = $ | |
653 | - | let amountsString = $ | |
632 | + | let $t02255922758 = claimCollateralINTERNAL(userAddressBytes, fromBase58String(txId)) | |
633 | + | let userAddress = $t02255922758._1 | |
634 | + | let lpAssetAmount = $t02255922758._2 | |
635 | + | let targetPeriod = $t02255922758._3 | |
636 | + | let wavesAmount = $t02255922758._4 | |
637 | + | let assetsString = $t02255922758._5 | |
638 | + | let amountsString = $t02255922758._6 | |
654 | 639 | let assetsList = removeByIndex(split_51C(assetsString, SEP), 0) | |
655 | 640 | let amountsList = removeByIndex(split_51C(amountsString, SEP), 0) | |
656 | 641 | let newActions = [invoke(factoryAddressOrFail, "deleteEntry", [keyWithdrawalRequest(userAddress, fromBase58String(txId))], nil), invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawalHistory(userAddress, fromBase58String(txId)), lpAssetAmount], nil), invoke(factoryAddressOrFail, "transferAssets", [userAddressBytes, assetsList, amountsList], nil)] | |
724 | 709 | let currentPriceOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPriceForPeriod(currentPeriodOrFail)), wrapErr("invalid price")) | |
725 | 710 | let nextBlockToProcess = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyNextBlockToProcess()), wrapErr("invalid next block to process")) | |
726 | 711 | let periodEndHeight = ((currentStartHeight + periodLength) - 1) | |
727 | - | let blocksProcessingBatchSizeMax = 20 | |
728 | 712 | let blocksProcessingBatchSize = if (if (if ((height >= nextBlockToProcess)) | |
729 | 713 | then if ((nextBlockToProcess >= currentStartHeight)) | |
730 | 714 | then true | |
748 | 732 | let callerReward = if ((inc == (blocksProcessingBatchSize - 1))) | |
749 | 733 | then (blockProcessingRewardByGenerator + blockProcessingRewardByGeneratorRemainder) | |
750 | 734 | else blockProcessingRewardByGenerator | |
751 | - | let $ | |
752 | - | let shareAmountToPower = $ | |
753 | - | let businessTreasuryAmountPart = $ | |
754 | - | let rewardRemainder = $ | |
735 | + | let $t02665826766 = getRewardSplit(treasuryRewardOrFail) | |
736 | + | let shareAmountToPower = $t02665826766._1 | |
737 | + | let businessTreasuryAmountPart = $t02665826766._2 | |
738 | + | let rewardRemainder = $t02665826766._3 | |
755 | 739 | let lpAssetAmount = if ((currentPriceOrFail > 0)) | |
756 | 740 | then fraction((rewardRemainder - callerReward), SCALE8, currentPriceOrFail) | |
757 | 741 | else 0 | |
758 | 742 | let factoryActionsSingle = [invoke(factoryAddressOrFail, "stringEntry", [keyBlockProcessed(targetBlockHeight), makeString([toBase58String(i.transactionId), toString(currentPeriodOrFail), toString(generator), toBase58String(userAddressBytes), toString(treasuryRewardOrFail), toString(callerReward), toString(lpAssetAmount), toString(shareAmountToPower)], SEP)], nil), invoke(factoryAddressOrFail, "integerEntry", [keyAvailable(generator), (available + lpAssetAmount)], nil)] | |
759 | 743 | if ((factoryActionsSingle == factoryActionsSingle)) | |
760 | 744 | then { | |
761 | - | let $ | |
762 | - | let lpAssetAcc = $ | |
763 | - | let rewardAcc = $ | |
764 | - | let businessTreasuryAcc = $ | |
765 | - | let powerShareDataTuple = $ | |
766 | - | let $ | |
767 | - | let powerShareAcc = $ | |
768 | - | let generatorPowerShareList = $ | |
745 | + | let $t02761427689 = acc | |
746 | + | let lpAssetAcc = $t02761427689._1 | |
747 | + | let rewardAcc = $t02761427689._2 | |
748 | + | let businessTreasuryAcc = $t02761427689._3 | |
749 | + | let powerShareDataTuple = $t02761427689._4 | |
750 | + | let $t02769627762 = powerShareDataTuple | |
751 | + | let powerShareAcc = $t02769627762._1 | |
752 | + | let generatorPowerShareList = $t02769627762._2 | |
769 | 753 | let newGeneratorPowerShareList = (generatorPowerShareList :+ $Tuple2(toString(generator), shareAmountToPower)) | |
770 | 754 | $Tuple4((lpAssetAcc + lpAssetAmount), (rewardAcc + treasuryRewardOrFail), (businessTreasuryAcc + businessTreasuryAmountPart), $Tuple2((powerShareAcc + shareAmountToPower), newGeneratorPowerShareList)) | |
771 | 755 | } | |
773 | 757 | } | |
774 | 758 | ||
775 | 759 | let list = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19] | |
776 | - | let $ | |
760 | + | let $t02821028372 = { | |
777 | 761 | let $l = list | |
778 | 762 | let $s = size($l) | |
779 | 763 | let $acc0 = $Tuple4(0, 0, 0, $Tuple2(0, nil)) | |
787 | 771 | ||
788 | 772 | $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) | |
789 | 773 | } | |
790 | - | if (($ | |
774 | + | if (($t02821028372 == $t02821028372)) | |
791 | 775 | then { | |
792 | - | let powerShareDataTuple = $ | |
793 | - | let rewardToBusinessTreasuryAmount = $ | |
794 | - | let rewardAmountTotal = $ | |
795 | - | let lpAssetAmountTotal = $ | |
796 | - | let $ | |
797 | - | let amountToPowerTotal = $ | |
798 | - | let powerShareAmountsList = $ | |
776 | + | let powerShareDataTuple = $t02821028372._4 | |
777 | + | let rewardToBusinessTreasuryAmount = $t02821028372._3 | |
778 | + | let rewardAmountTotal = $t02821028372._2 | |
779 | + | let lpAssetAmountTotal = $t02821028372._1 | |
780 | + | let $t02837628445 = powerShareDataTuple | |
781 | + | let amountToPowerTotal = $t02837628445._1 | |
782 | + | let powerShareAmountsList = $t02837628445._2 | |
799 | 783 | let rewardToMainTreasuryAmount = (((rewardAmountTotal - rewardToBusinessTreasuryAmount) - blockProcessingReward) - amountToPowerTotal) | |
800 | 784 | let invested = valueOrElse(getInteger(factoryAddressOrFail, keyInvested(unit)), 0) | |
801 | 785 | let powerShareActions = if ((amountToPowerTotal > 0)) | |
813 | 797 | 0 | |
814 | 798 | } | |
815 | 799 | func stakePowerInvoke (acc,next) = { | |
816 | - | let $ | |
817 | - | let generator = $ | |
818 | - | let shareAmount = $ | |
800 | + | let $t02931929354 = next | |
801 | + | let generator = $t02931929354._1 | |
802 | + | let shareAmount = $t02931929354._2 | |
819 | 803 | if ((amountToPowerTotal > 0)) | |
820 | 804 | then { | |
821 | 805 | let powerAmount = fraction(shareAmount, totalPowerAmountInt, amountToPowerTotal) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 7 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let SEP = "__" | |
5 | 5 | ||
6 | 6 | let CONTRACT_NAME = "calculator.ride" | |
7 | 7 | ||
8 | 8 | let SCALE8 = 100000000 | |
9 | 9 | ||
10 | 10 | let PENDING = "PENDING" | |
11 | 11 | ||
12 | 12 | let WAVES = "WAVES" | |
13 | + | ||
14 | + | let blocksProcessingBatchSizeMax = 10 | |
13 | 15 | ||
14 | 16 | func wrapErr (s) = ((CONTRACT_NAME + ": ") + s) | |
15 | 17 | ||
16 | 18 | ||
17 | 19 | func throwErr (s) = throw(wrapErr(s)) | |
18 | 20 | ||
19 | 21 | ||
20 | 22 | func assetIdToString (assetId) = match assetId { | |
21 | 23 | case b: ByteVector => | |
22 | 24 | toBase58String(b) | |
23 | 25 | case _: Unit => | |
24 | 26 | WAVES | |
25 | 27 | case _ => | |
26 | 28 | throw("Match error") | |
27 | 29 | } | |
28 | 30 | ||
29 | 31 | ||
30 | 32 | func stringToAssetId (s) = if ((s == WAVES)) | |
31 | 33 | then unit | |
32 | 34 | else fromBase58String(s) | |
33 | 35 | ||
34 | 36 | ||
35 | 37 | func abs (n) = if ((0 > n)) | |
36 | 38 | then -(n) | |
37 | 39 | else n | |
38 | 40 | ||
39 | 41 | ||
40 | 42 | func keyFactoryAddress () = makeString(["%s", "factory"], SEP) | |
41 | 43 | ||
42 | 44 | ||
43 | 45 | func keyManagerPublicKey () = makeString(["%s", "managerPublicKey"], SEP) | |
44 | 46 | ||
45 | 47 | ||
46 | 48 | func keyLpAssetId () = makeString(["%s", "lpAssetId"], SEP) | |
47 | 49 | ||
48 | 50 | ||
49 | 51 | func keyProxyTreasuryAddress () = makeString(["%s", "proxyTreasury"], SEP) | |
50 | 52 | ||
51 | 53 | ||
52 | 54 | func keyMainTreasuryAddress () = makeString(["%s", "mainTreasury"], SEP) | |
53 | 55 | ||
54 | 56 | ||
55 | 57 | func keyBusinessTreasuryAddress () = makeString(["%s", "businessTreasury"], SEP) | |
56 | 58 | ||
57 | 59 | ||
58 | 60 | func keyBusinessTreasuryPart () = makeString(["%s", "businessTreasuryPart"], SEP) | |
59 | 61 | ||
60 | 62 | ||
61 | 63 | func keyPowerContractAddress () = makeString(["%s", "powerContract"], SEP) | |
62 | 64 | ||
63 | 65 | ||
64 | 66 | func keyPowerShareRatio () = makeString(["%s", "powerShareRatio"], SEP) | |
65 | 67 | ||
66 | 68 | ||
67 | 69 | func keyPowerAssetId () = makeString(["%s", "powerAssetId"], SEP) | |
68 | 70 | ||
69 | 71 | ||
70 | 72 | func keyInvested (assetId) = makeString(["%s%s", "invested", assetIdToString(assetId)], SEP) | |
71 | 73 | ||
72 | 74 | ||
73 | 75 | func keyDonated (assetId) = makeString(["%s%s", "donated", assetIdToString(assetId)], SEP) | |
74 | 76 | ||
75 | 77 | ||
76 | 78 | func keyAvailable (userAddress) = makeString(["%s%s", "available", toString(userAddress)], SEP) | |
77 | 79 | ||
78 | 80 | ||
79 | 81 | func keyClaimed (userAddress) = makeString(["%s%s", "claimed", toString(userAddress)], SEP) | |
80 | 82 | ||
81 | 83 | ||
82 | 84 | func keyCurrentPeriod () = makeString(["%s", "currentPeriod"], SEP) | |
83 | 85 | ||
84 | 86 | ||
85 | 87 | func keyPriceForPeriod (period) = makeString(["%s%d", "price", toString(period)], SEP) | |
86 | 88 | ||
87 | 89 | ||
88 | 90 | func keyStartHeight (period) = makeString(["%s%d", "startHeight", toString(period)], SEP) | |
89 | 91 | ||
90 | 92 | ||
91 | 93 | func keyPowerManagerBonus (period) = makeString(["%s%d", "powerManagerBonus", toString(period)], SEP) | |
92 | 94 | ||
93 | 95 | ||
94 | 96 | func keyClaimWavesAmount (period) = makeString(["%s%d", "claimWavesAmount", toString(period)], SEP) | |
95 | 97 | ||
96 | 98 | ||
97 | 99 | func keyPeriodLength () = "%s__periodLength" | |
98 | 100 | ||
99 | 101 | ||
100 | 102 | func keyInvestPeriodLength () = "%s__investPeriodLength" | |
101 | 103 | ||
102 | 104 | ||
103 | 105 | func keyBlockProcessingReward () = "%s__blockProcessingReward" | |
104 | 106 | ||
105 | 107 | ||
106 | 108 | func keyNextBlockToProcess () = "%s__nextBlockToProcess" | |
107 | 109 | ||
108 | 110 | ||
109 | 111 | func keyBlockProcessed (height) = makeString(["%s%d", "blockProcessed", toString(height)], SEP) | |
110 | 112 | ||
111 | 113 | ||
112 | 114 | func keyWithdrawal () = "%s__withdrawal" | |
113 | 115 | ||
114 | 116 | ||
115 | 117 | func keyWithdrawalRequest (userAddress,txId) = makeString(["%s%s%s", "withdrawal", toString(userAddress), toBase58String(txId)], SEP) | |
116 | 118 | ||
117 | 119 | ||
118 | 120 | func valueWithdrawalRequest (status,lpAssetAmount,targetPeriod,claimTxId) = { | |
119 | 121 | let claimTxIdStr = match claimTxId { | |
120 | 122 | case b: ByteVector => | |
121 | 123 | toBase58String(b) | |
122 | 124 | case _: Unit => | |
123 | 125 | "SOON" | |
124 | 126 | case _ => | |
125 | 127 | throw("Match error") | |
126 | 128 | } | |
127 | 129 | makeString(["%s%d%d%s", status, toString(lpAssetAmount), toString(targetPeriod), claimTxIdStr], SEP) | |
128 | 130 | } | |
129 | 131 | ||
130 | 132 | ||
131 | 133 | func keyWithdrawalHistory (userAddress,txId) = makeString(["%s%s%s", "withdrawalHistory", toString(userAddress), toBase58String(txId)], SEP) | |
132 | 134 | ||
133 | 135 | ||
134 | 136 | func keyPeriodWithdrawalAssetIds (period) = makeString(["%s%d", "periodReward", toString(period)], SEP) | |
135 | 137 | ||
136 | 138 | ||
137 | 139 | func keyPeriodWithdrawalAmounts (period) = makeString(["%s%d", "periodRewardAmount", toString(period)], SEP) | |
138 | 140 | ||
139 | 141 | ||
140 | 142 | func parseWithdrawalRequestValueOrFail (s) = { | |
141 | 143 | let parts = split(s, SEP) | |
142 | 144 | if ((size(parts) == 5)) | |
143 | 145 | then { | |
144 | 146 | let status = parts[1] | |
145 | 147 | let lpAssetAmount = valueOrErrorMessage(parseInt(parts[2]), wrapErr("invalid lpAssetAmount")) | |
146 | 148 | let targetPeriod = valueOrErrorMessage(parseInt(parts[3]), wrapErr("invalid targetPeriod")) | |
147 | 149 | let claimTxId = parts[4] | |
148 | 150 | $Tuple4(status, lpAssetAmount, targetPeriod, claimTxId) | |
149 | 151 | } | |
150 | 152 | else throwErr("invalid withdrawal request value") | |
151 | 153 | } | |
152 | 154 | ||
153 | 155 | ||
154 | 156 | let factoryAddressOption = match getString(this, keyFactoryAddress()) { | |
155 | 157 | case s: String => | |
156 | 158 | addressFromString(s) | |
157 | 159 | case _: Unit => | |
158 | 160 | unit | |
159 | 161 | case _ => | |
160 | 162 | throw("Match error") | |
161 | 163 | } | |
162 | 164 | ||
163 | 165 | let factoryAddressOrFail = valueOrErrorMessage(factoryAddressOption, wrapErr("invalid factory address")) | |
164 | 166 | ||
165 | 167 | let lpAssetIdOption = match factoryAddressOption { | |
166 | 168 | case a: Address => | |
167 | 169 | match getString(a, keyLpAssetId()) { | |
168 | 170 | case s: String => | |
169 | 171 | fromBase58String(s) | |
170 | 172 | case _: Unit => | |
171 | 173 | unit | |
172 | 174 | case _ => | |
173 | 175 | throw("Match error") | |
174 | 176 | } | |
175 | 177 | case _: Unit => | |
176 | 178 | unit | |
177 | 179 | case _ => | |
178 | 180 | throw("Match error") | |
179 | 181 | } | |
180 | 182 | ||
181 | 183 | let lpAssetIdOrFail = valueOrErrorMessage(lpAssetIdOption, wrapErr("invalid lpAssetId")) | |
182 | 184 | ||
183 | 185 | let proxyTreasuryAddressOption = match factoryAddressOption { | |
184 | 186 | case a: Address => | |
185 | 187 | match getString(a, keyProxyTreasuryAddress()) { | |
186 | 188 | case s: String => | |
187 | 189 | addressFromString(s) | |
188 | 190 | case _: Unit => | |
189 | 191 | unit | |
190 | 192 | case _ => | |
191 | 193 | throw("Match error") | |
192 | 194 | } | |
193 | 195 | case _: Unit => | |
194 | 196 | unit | |
195 | 197 | case _ => | |
196 | 198 | throw("Match error") | |
197 | 199 | } | |
198 | 200 | ||
199 | 201 | let proxyTreasuryAddressOrFail = valueOrErrorMessage(proxyTreasuryAddressOption, wrapErr("invalid proxy treasury address")) | |
200 | 202 | ||
201 | 203 | let mainTreasuryAddressOption = match factoryAddressOption { | |
202 | 204 | case a: Address => | |
203 | 205 | match getString(a, keyMainTreasuryAddress()) { | |
204 | 206 | case s: String => | |
205 | 207 | addressFromString(s) | |
206 | 208 | case _: Unit => | |
207 | 209 | unit | |
208 | 210 | case _ => | |
209 | 211 | throw("Match error") | |
210 | 212 | } | |
211 | 213 | case _: Unit => | |
212 | 214 | unit | |
213 | 215 | case _ => | |
214 | 216 | throw("Match error") | |
215 | 217 | } | |
216 | 218 | ||
217 | 219 | let businessTreasuryAddressOption = match factoryAddressOption { | |
218 | 220 | case a: Address => | |
219 | 221 | match getString(a, keyBusinessTreasuryAddress()) { | |
220 | 222 | case s: String => | |
221 | 223 | addressFromString(s) | |
222 | 224 | case _: Unit => | |
223 | 225 | unit | |
224 | 226 | case _ => | |
225 | 227 | throw("Match error") | |
226 | 228 | } | |
227 | 229 | case _: Unit => | |
228 | 230 | unit | |
229 | 231 | case _ => | |
230 | 232 | throw("Match error") | |
231 | 233 | } | |
232 | 234 | ||
233 | 235 | let mainTreasuryAddressOrFail = valueOrErrorMessage(mainTreasuryAddressOption, wrapErr("invalid main treasury address")) | |
234 | 236 | ||
235 | 237 | let businessTreasuryAddressOrFail = valueOrErrorMessage(businessTreasuryAddressOption, wrapErr("invalid business treasury address")) | |
236 | 238 | ||
237 | 239 | let powerContractAddressOption = match factoryAddressOption { | |
238 | 240 | case a: Address => | |
239 | 241 | match getString(a, keyPowerContractAddress()) { | |
240 | 242 | case s: String => | |
241 | 243 | addressFromString(s) | |
242 | 244 | case _: Unit => | |
243 | 245 | unit | |
244 | 246 | case _ => | |
245 | 247 | throw("Match error") | |
246 | 248 | } | |
247 | 249 | case _: Unit => | |
248 | 250 | unit | |
249 | 251 | case _ => | |
250 | 252 | throw("Match error") | |
251 | 253 | } | |
252 | 254 | ||
253 | 255 | let powerContractAddressOrFail = valueOrErrorMessage(powerContractAddressOption, wrapErr("invalid power contract address")) | |
254 | 256 | ||
255 | 257 | let powerAssetIdStringOrFail = valueOrErrorMessage(getString(factoryAddressOrFail, keyPowerAssetId()), wrapErr("power asset id not found")) | |
256 | 258 | ||
257 | 259 | func getManagerPublicKeyOrUnit () = match factoryAddressOption { | |
258 | 260 | case fa: Address => | |
259 | 261 | match getString(fa, keyManagerPublicKey()) { | |
260 | 262 | case pub: String => | |
261 | 263 | fromBase58String(pub) | |
262 | 264 | case _ => | |
263 | 265 | unit | |
264 | 266 | } | |
265 | 267 | case _ => | |
266 | 268 | unit | |
267 | 269 | } | |
268 | 270 | ||
269 | 271 | ||
270 | 272 | func onlyAddress (i,address) = if ((i.caller == address)) | |
271 | 273 | then true | |
272 | 274 | else throwErr("permission denied") | |
273 | 275 | ||
274 | 276 | ||
275 | 277 | func onlyFactory (i) = onlyAddress(i, factoryAddressOrFail) | |
276 | 278 | ||
277 | 279 | ||
278 | 280 | func rewardForOption (rewards,target) = { | |
279 | 281 | let s = size(rewards) | |
280 | - | let $ | |
281 | - | let a0 = $ | |
282 | - | let r0 = $ | |
283 | - | let $ | |
284 | - | let a1 = $ | |
285 | - | let r1 = $ | |
286 | - | let $ | |
287 | - | let a2 = $ | |
288 | - | let r2 = $ | |
282 | + | let $t066696694 = rewards[0] | |
283 | + | let a0 = $t066696694._1 | |
284 | + | let r0 = $t066696694._2 | |
285 | + | let $t066976722 = rewards[1] | |
286 | + | let a1 = $t066976722._1 | |
287 | + | let r1 = $t066976722._2 | |
288 | + | let $t067256750 = rewards[2] | |
289 | + | let a2 = $t067256750._1 | |
290 | + | let r2 = $t067256750._2 | |
289 | 291 | if (if ((s > 0)) | |
290 | 292 | then (a0 == target) | |
291 | 293 | else false) | |
292 | 294 | then r0 | |
293 | 295 | else if (if ((s > 1)) | |
294 | 296 | then (a1 == target) | |
295 | 297 | else false) | |
296 | 298 | then r1 | |
297 | 299 | else if (if ((s > 2)) | |
298 | 300 | then (a2 == target) | |
299 | 301 | else false) | |
300 | 302 | then r2 | |
301 | 303 | else unit | |
302 | 304 | } | |
303 | 305 | ||
304 | 306 | ||
305 | 307 | func calculatePrice (lpPartInWaves) = { | |
306 | 308 | let lpAssetAmountToBurn = valueOrElse(getInteger(factoryAddressOrFail, keyWithdrawal()), 0) | |
307 | 309 | let lpAssetQuantity = valueOrErrorMessage(assetInfo(lpAssetIdOrFail), wrapErr("invalid lpAsset info")).quantity | |
308 | 310 | let newPrice = fraction(lpPartInWaves, SCALE8, (lpAssetQuantity - lpAssetAmountToBurn)) | |
309 | 311 | let checkIfPriceNotZero = if ((newPrice != 0)) | |
310 | 312 | then true | |
311 | 313 | else throwErr("LP price cannot be 0") | |
312 | 314 | if ((checkIfPriceNotZero == checkIfPriceNotZero)) | |
313 | 315 | then { | |
314 | 316 | let lpAssetFinalQuantity = (lpAssetQuantity - lpAssetAmountToBurn) | |
315 | 317 | $Tuple3(newPrice, lpAssetAmountToBurn, lpAssetFinalQuantity) | |
316 | 318 | } | |
317 | 319 | else throw("Strict value is not equal to itself.") | |
318 | 320 | } | |
319 | 321 | ||
320 | 322 | ||
321 | 323 | func claimCollateralINTERNAL (userAddressBytes,txId) = { | |
322 | 324 | let userAddress = Address(userAddressBytes) | |
323 | 325 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
324 | 326 | let withdrawalRequestOption = valueOrErrorMessage(getString(factoryAddressOrFail, keyWithdrawalRequest(userAddress, txId)), wrapErr("invalid withdrawal request")) | |
325 | - | let $ | |
326 | - | let status = $ | |
327 | - | let lpAssetAmount = $ | |
328 | - | let targetPeriod = $ | |
329 | - | let claimTxId = $ | |
327 | + | let $t079178030 = parseWithdrawalRequestValueOrFail(withdrawalRequestOption) | |
328 | + | let status = $t079178030._1 | |
329 | + | let lpAssetAmount = $t079178030._2 | |
330 | + | let targetPeriod = $t079178030._3 | |
331 | + | let claimTxId = $t079178030._4 | |
330 | 332 | if ((targetPeriod > currentPeriodOrFail)) | |
331 | 333 | then throwErr("invalid withdrawal request period") | |
332 | 334 | else { | |
333 | 335 | let priceOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPriceForPeriod(targetPeriod)), wrapErr("invalid price")) | |
334 | 336 | let wavesAmount = if ((priceOrFail > 0)) | |
335 | 337 | then fraction(lpAssetAmount, priceOrFail, SCALE8) | |
336 | 338 | else 0 | |
337 | 339 | let assetsString = getStringValue(factoryAddressOrFail, keyPeriodWithdrawalAssetIds(currentPeriodOrFail)) | |
338 | 340 | let amountsString = getStringValue(factoryAddressOrFail, keyPeriodWithdrawalAmounts(currentPeriodOrFail)) | |
339 | 341 | $Tuple6(userAddress, lpAssetAmount, targetPeriod, wavesAmount, assetsString, amountsString) | |
340 | 342 | } | |
341 | 343 | } | |
342 | 344 | ||
343 | 345 | ||
344 | 346 | func claimCollateralREADONLYStringResponse (userAddressBytes,txId) = { | |
345 | - | let $ | |
346 | - | let userAddress = $ | |
347 | - | let lpAssetAmount = $ | |
348 | - | let targetPeriod = $ | |
349 | - | let wavesAmount = $ | |
350 | - | let assetsString = $ | |
351 | - | let amountsString = $ | |
347 | + | let $t088178983 = claimCollateralINTERNAL(userAddressBytes, txId) | |
348 | + | let userAddress = $t088178983._1 | |
349 | + | let lpAssetAmount = $t088178983._2 | |
350 | + | let targetPeriod = $t088178983._3 | |
351 | + | let wavesAmount = $t088178983._4 | |
352 | + | let assetsString = $t088178983._5 | |
353 | + | let amountsString = $t088178983._6 | |
352 | 354 | let assets = makeString(removeByIndex(split_51C(assetsString, SEP), 0), ":") | |
353 | 355 | let amounts = makeString(removeByIndex(split_51C(amountsString, SEP), 0), ":") | |
354 | 356 | makeString(["%d%s%s", toString(wavesAmount), assets, amounts], SEP) | |
355 | 357 | } | |
356 | 358 | ||
357 | 359 | ||
358 | 360 | func getRewardSplit (generatorRewardAmount) = { | |
359 | 361 | let powerShareRatio = max([0, min([valueOrElse(getInteger(factoryAddressOrFail, keyPowerShareRatio()), 0), SCALE8])]) | |
360 | 362 | let businessPartRatio = max([0, min([valueOrElse(getInteger(factoryAddressOrFail, keyBusinessTreasuryPart()), 0), SCALE8])]) | |
361 | 363 | let amountToPowerPart = fraction(generatorRewardAmount, powerShareRatio, SCALE8) | |
362 | 364 | let businessTreasuryAmountPart = fraction(generatorRewardAmount, businessPartRatio, SCALE8) | |
363 | 365 | let rewardRemainder = ((generatorRewardAmount - amountToPowerPart) - businessTreasuryAmountPart) | |
364 | 366 | if ((rewardRemainder > 0)) | |
365 | 367 | then $Tuple3(amountToPowerPart, businessTreasuryAmountPart, rewardRemainder) | |
366 | 368 | else throwErr("amount to main treasury cannot be negative") | |
367 | 369 | } | |
368 | 370 | ||
369 | 371 | ||
370 | 372 | func calcRewardSplitForAmount (amount) = { | |
371 | - | let blocksProcessingBatchSizeMax = 20 | |
372 | - | let $t01008410177 = getRewardSplit(amount) | |
373 | - | let amountToPowerPart = $t01008410177._1 | |
374 | - | let businessTreasuryAmountPart = $t01008410177._2 | |
375 | - | let rewardRemainder = $t01008410177._3 | |
373 | + | let $t01008210175 = getRewardSplit(amount) | |
374 | + | let amountToPowerPart = $t01008210175._1 | |
375 | + | let businessTreasuryAmountPart = $t01008210175._2 | |
376 | + | let rewardRemainder = $t01008210175._3 | |
376 | 377 | let blockProcessingReward = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyBlockProcessingReward()), wrapErr("invalid block processing reward")) | |
377 | 378 | let blockProcessingRewardByGenerator = (blockProcessingReward / blocksProcessingBatchSizeMax) | |
378 | 379 | let toLpAmount = (rewardRemainder - blockProcessingReward) | |
379 | 380 | $Tuple5(amountToPowerPart, businessTreasuryAmountPart, blockProcessingReward, toLpAmount, amount) | |
380 | 381 | } | |
381 | 382 | ||
382 | 383 | ||
383 | 384 | @Callable(i) | |
384 | 385 | func rewardSplitREADONLY () = { | |
385 | 386 | let targetBlockHeight = (height - 1) | |
386 | 387 | let targetBlockInfo = valueOrErrorMessage(blockInfoByHeight(targetBlockHeight), wrapErr("invalid block info")) | |
387 | 388 | let treasuryRewardOrFail = valueOrErrorMessage(rewardForOption(targetBlockInfo.rewards, proxyTreasuryAddressOrFail), wrapErr(("invalid treasury reward for height " + toString(targetBlockHeight)))) | |
388 | 389 | $Tuple2(nil, calcRewardSplitForAmount(treasuryRewardOrFail)) | |
389 | 390 | } | |
390 | 391 | ||
391 | 392 | ||
392 | 393 | ||
393 | 394 | @Callable(i) | |
394 | 395 | func claimLP (userAddressBytes) = { | |
395 | 396 | let checkCaller = onlyFactory(i) | |
396 | 397 | if ((checkCaller == checkCaller)) | |
397 | 398 | then { | |
398 | 399 | let userAddress = Address(userAddressBytes) | |
399 | 400 | let available = valueOrElse(getInteger(factoryAddressOrFail, keyAvailable(userAddress)), 0) | |
400 | 401 | let claimed = valueOrElse(getInteger(factoryAddressOrFail, keyClaimed(userAddress)), 0) | |
401 | 402 | let factoryActions = if ((available > 0)) | |
402 | 403 | then [invoke(factoryAddressOrFail, "transferAsset", [userAddressBytes, available, lpAssetIdOrFail], nil), invoke(factoryAddressOrFail, "integerEntry", [keyAvailable(userAddress), 0], nil), invoke(factoryAddressOrFail, "integerEntry", [keyClaimed(userAddress), (claimed + available)], nil)] | |
403 | 404 | else throwErr("nothing to claim") | |
404 | 405 | $Tuple2(nil, factoryActions) | |
405 | 406 | } | |
406 | 407 | else throw("Strict value is not equal to itself.") | |
407 | 408 | } | |
408 | 409 | ||
409 | 410 | ||
410 | 411 | ||
411 | 412 | @Callable(i) | |
412 | 413 | func finalize (userAddressBytes,donationPartInWaves,lpPartInWaves,claimPartInWaves,powerStakePartInWaves) = { | |
413 | 414 | let checkCaller = onlyFactory(i) | |
414 | 415 | if ((checkCaller == checkCaller)) | |
415 | 416 | then { | |
416 | 417 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
417 | 418 | let periodLength = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPeriodLength()), wrapErr("invalid period length")) | |
418 | 419 | let currentStartHeight = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyStartHeight(currentPeriodOrFail)), wrapErr("invalid start height")) | |
419 | 420 | let currentPriceOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPriceForPeriod(currentPeriodOrFail)), wrapErr("invalid price")) | |
420 | 421 | let nextBlockToProcess = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyNextBlockToProcess()), wrapErr("invalid next block to process")) | |
421 | 422 | let periodEndHeight = ((currentStartHeight + periodLength) - 1) | |
422 | 423 | let checks = [if ((i.originCaller == mainTreasuryAddressOrFail)) | |
423 | 424 | then true | |
424 | 425 | else throwErr("permission denied"), if ((nextBlockToProcess > periodEndHeight)) | |
425 | 426 | then true | |
426 | 427 | else throwErr("unprocessed blocks"), if ((donationPartInWaves >= 0)) | |
427 | 428 | then true | |
428 | 429 | else throwErr("invalid donation part"), if ((lpPartInWaves >= 0)) | |
429 | 430 | then true | |
430 | 431 | else throwErr("invalid lp part"), if ((claimPartInWaves >= 0)) | |
431 | 432 | then true | |
432 | 433 | else throwErr("invalid claim part"), if ((powerStakePartInWaves >= 0)) | |
433 | 434 | then true | |
434 | 435 | else throwErr("invalid PWR stake part")] | |
435 | 436 | if ((checks == checks)) | |
436 | 437 | then { | |
437 | - | let $ | |
438 | - | let newPrice = $ | |
439 | - | let lpAssetAmountToBurn = $ | |
440 | - | let lpAssetFinalQuantity = $ | |
438 | + | let $t01351313618 = calculatePrice(lpPartInWaves) | |
439 | + | let newPrice = $t01351313618._1 | |
440 | + | let lpAssetAmountToBurn = $t01351313618._2 | |
441 | + | let lpAssetFinalQuantity = $t01351313618._3 | |
441 | 442 | let newPeriod = (currentPeriodOrFail + 1) | |
442 | 443 | func addNewAction (actions,payment) = { | |
443 | - | let $ | |
444 | - | let scriptTransfers = $ | |
445 | - | let assetIdsString = $ | |
446 | - | let amountsString = $ | |
444 | + | let $t01376613828 = actions | |
445 | + | let scriptTransfers = $t01376613828._1 | |
446 | + | let assetIdsString = $t01376613828._2 | |
447 | + | let amountsString = $t01376613828._3 | |
447 | 448 | let paymentAmount = payment.amount | |
448 | 449 | let paymentAssetId = payment.assetId | |
449 | 450 | let newAssetIdsString = ("%s" + makeString([assetIdsString, assetIdToString(paymentAssetId)], SEP)) | |
450 | 451 | let newAmountsString = ("%d" + makeString([amountsString, toString(paymentAmount)], SEP)) | |
451 | 452 | let newScriptTransfer = ScriptTransfer(factoryAddressOrFail, paymentAmount, paymentAssetId) | |
452 | 453 | $Tuple3((scriptTransfers :+ newScriptTransfer), newAssetIdsString, newAmountsString) | |
453 | 454 | } | |
454 | 455 | ||
455 | - | let $ | |
456 | + | let $t01428814379 = { | |
456 | 457 | let $l = i.payments | |
457 | 458 | let $s = size($l) | |
458 | 459 | let $acc0 = $Tuple3(nil, "", "") | |
459 | 460 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
460 | 461 | then $a | |
461 | 462 | else addNewAction($a, $l[$i]) | |
462 | 463 | ||
463 | 464 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
464 | 465 | then $a | |
465 | 466 | else throw("List size exceeds 10") | |
466 | 467 | ||
467 | 468 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
468 | 469 | } | |
469 | - | let scriptTransfers = $ | |
470 | - | let AssetIds = $ | |
471 | - | let Amounts = $ | |
470 | + | let scriptTransfers = $t01428814379._1 | |
471 | + | let AssetIds = $t01428814379._2 | |
472 | + | let Amounts = $t01428814379._3 | |
472 | 473 | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyPowerManagerBonus(currentPeriodOrFail), powerStakePartInWaves], nil), invoke(factoryAddressOrFail, "integerEntry", [keyClaimWavesAmount(currentPeriodOrFail), claimPartInWaves], nil), invoke(factoryAddressOrFail, "integerEntry", [keyCurrentPeriod(), newPeriod], nil), invoke(factoryAddressOrFail, "integerEntry", [keyPriceForPeriod(newPeriod), newPrice], nil), invoke(factoryAddressOrFail, "integerEntry", [keyStartHeight(newPeriod), (periodEndHeight + 1)], nil), invoke(factoryAddressOrFail, "burn", [lpAssetAmountToBurn], nil), invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), 0], nil), invoke(factoryAddressOrFail, "integerEntry", [keyInvested(unit), lpPartInWaves], nil), invoke(factoryAddressOrFail, "integerEntry", [keyDonated(unit), donationPartInWaves], nil), invoke(factoryAddressOrFail, "stringEntry", [keyPeriodWithdrawalAssetIds(newPeriod), AssetIds], nil), invoke(factoryAddressOrFail, "stringEntry", [keyPeriodWithdrawalAmounts(newPeriod), Amounts], nil)] | |
473 | 474 | $Tuple2(scriptTransfers, factoryActions) | |
474 | 475 | } | |
475 | 476 | else throw("Strict value is not equal to itself.") | |
476 | 477 | } | |
477 | 478 | else throw("Strict value is not equal to itself.") | |
478 | 479 | } | |
479 | 480 | ||
480 | 481 | ||
481 | 482 | ||
482 | 483 | @Callable(i) | |
483 | 484 | func finalizeREADONLY (donationPartInWaves,lpPartInWaves,claimPartInWaves,powerStakePartInWaves) = { | |
484 | 485 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
485 | 486 | let periodLength = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPeriodLength()), wrapErr("invalid period length")) | |
486 | 487 | let currentStartHeight = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyStartHeight(currentPeriodOrFail)), wrapErr("invalid start height")) | |
487 | 488 | let currentPriceOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPriceForPeriod(currentPeriodOrFail)), wrapErr("invalid price")) | |
488 | 489 | let nextBlockToProcess = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyNextBlockToProcess()), wrapErr("invalid next block to process")) | |
489 | 490 | let periodEndHeight = ((currentStartHeight + periodLength) - 1) | |
490 | 491 | let checks = [if ((nextBlockToProcess > periodEndHeight)) | |
491 | 492 | then true | |
492 | 493 | else throwErr("unprocessed blocks"), if ((donationPartInWaves >= 0)) | |
493 | 494 | then true | |
494 | 495 | else throwErr("invalid donation part"), if ((lpPartInWaves >= 0)) | |
495 | 496 | then true | |
496 | 497 | else throwErr("invalid lp part"), if ((claimPartInWaves >= 0)) | |
497 | 498 | then true | |
498 | 499 | else throwErr("invalid claim part"), if ((powerStakePartInWaves >= 0)) | |
499 | 500 | then true | |
500 | 501 | else throwErr("invalid PWR stake part")] | |
501 | 502 | if ((checks == checks)) | |
502 | 503 | then { | |
503 | - | let $ | |
504 | - | let newPrice = $ | |
505 | - | let lpAssetAmountToBurn = $ | |
506 | - | let lpAssetFinalQuantity = $ | |
504 | + | let $t01725817363 = calculatePrice(lpPartInWaves) | |
505 | + | let newPrice = $t01725817363._1 | |
506 | + | let lpAssetAmountToBurn = $t01725817363._2 | |
507 | + | let lpAssetFinalQuantity = $t01725817363._3 | |
507 | 508 | $Tuple2(nil, $Tuple6(claimPartInWaves, lpPartInWaves, donationPartInWaves, newPrice, lpAssetAmountToBurn, lpAssetFinalQuantity)) | |
508 | 509 | } | |
509 | 510 | else throw("Strict value is not equal to itself.") | |
510 | 511 | } | |
511 | 512 | ||
512 | 513 | ||
513 | 514 | ||
514 | 515 | @Callable(i) | |
515 | 516 | func invest (userAddressBytes) = { | |
516 | 517 | let checkCaller = onlyFactory(i) | |
517 | 518 | if ((checkCaller == checkCaller)) | |
518 | 519 | then { | |
519 | 520 | let userAddress = Address(userAddressBytes) | |
520 | 521 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
521 | 522 | let currentStartHeight = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyStartHeight(currentPeriodOrFail)), wrapErr("invalid start height")) | |
522 | 523 | let investPeriodLength = getIntegerValue(factoryAddressOrFail, keyInvestPeriodLength()) | |
523 | 524 | let heightCheck = if (((currentStartHeight + investPeriodLength) > height)) | |
524 | 525 | then true | |
525 | 526 | else throwErr("too late to invest in this period") | |
526 | 527 | if ((heightCheck == heightCheck)) | |
527 | 528 | then { | |
528 | 529 | let currentPriceOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPriceForPeriod(currentPeriodOrFail)), wrapErr("invalid price")) | |
529 | 530 | let payment = if ((size(i.payments) == 1)) | |
530 | 531 | then i.payments[0] | |
531 | 532 | else throwErr("invalid payments") | |
532 | - | let $ | |
533 | + | let $t01847218649 = if (if ((payment.assetId == unit)) | |
533 | 534 | then (payment.amount > 0) | |
534 | 535 | else false) | |
535 | 536 | then $Tuple2(payment.amount, payment.assetId) | |
536 | 537 | else throwErr("invalid payment amount") | |
537 | - | let paymentAmount = $ | |
538 | - | let paymentAssetId = $ | |
538 | + | let paymentAmount = $t01847218649._1 | |
539 | + | let paymentAssetId = $t01847218649._2 | |
539 | 540 | let treasuryPart = valueOrElse(getInteger(factoryAddressOrFail, keyBusinessTreasuryPart()), 0) | |
540 | 541 | let paymentsWithoutTreasuryPart = fraction(paymentAmount, (SCALE8 - treasuryPart), SCALE8) | |
541 | 542 | let lpAssetAmount = if ((currentPriceOrFail > 0)) | |
542 | 543 | then fraction(paymentsWithoutTreasuryPart, SCALE8, currentPriceOrFail) | |
543 | 544 | else 0 | |
544 | 545 | let invested = valueOrElse(getInteger(factoryAddressOrFail, keyInvested(unit)), 0) | |
545 | 546 | let actions = [ScriptTransfer(mainTreasuryAddressOrFail, paymentsWithoutTreasuryPart, paymentAssetId), ScriptTransfer(businessTreasuryAddressOrFail, treasuryPart, paymentAssetId)] | |
546 | 547 | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyInvested(unit), (invested + paymentsWithoutTreasuryPart)], nil), invoke(factoryAddressOrFail, "reissue", [lpAssetAmount], nil), invoke(factoryAddressOrFail, "transferAsset", [userAddressBytes, lpAssetAmount, lpAssetIdOrFail], nil)] | |
547 | 548 | $Tuple2(actions, factoryActions) | |
548 | 549 | } | |
549 | 550 | else throw("Strict value is not equal to itself.") | |
550 | 551 | } | |
551 | 552 | else throw("Strict value is not equal to itself.") | |
552 | 553 | } | |
553 | 554 | ||
554 | 555 | ||
555 | 556 | ||
556 | 557 | @Callable(i) | |
557 | 558 | func withdraw (userAddressBytes) = { | |
558 | 559 | let checkCaller = onlyFactory(i) | |
559 | 560 | if ((checkCaller == checkCaller)) | |
560 | 561 | then { | |
561 | 562 | let userAddress = Address(userAddressBytes) | |
562 | 563 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
563 | - | let payment = if ((size(i.payments) == 1)) | |
564 | - | then i.payments[0] | |
565 | - | else throwErr(wrapErr("invalid payments")) | |
566 | - | let paymentAssetId = if ((payment.assetId == lpAssetIdOrFail)) | |
567 | - | then lpAssetIdOrFail | |
568 | - | else throwErr("invalid payment asset") | |
569 | - | let paymentAmount = if ((payment.amount > 0)) | |
570 | - | then payment.amount | |
571 | - | else throwErr("invalid payment amount") | |
572 | - | let withdrawal = valueOrElse(getInteger(factoryAddressOrFail, keyWithdrawal()), 0) | |
573 | - | let actions = [ScriptTransfer(factoryAddressOrFail, paymentAmount, paymentAssetId)] | |
574 | - | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), (withdrawal + paymentAmount)], nil), invoke(factoryAddressOrFail, "stringEntry", [keyWithdrawalRequest(userAddress, i.transactionId), valueWithdrawalRequest(PENDING, paymentAmount, (currentPeriodOrFail + 1), unit)], nil)] | |
575 | - | if ((factoryActions == factoryActions)) | |
576 | - | then $Tuple2(actions, factoryActions) | |
564 | + | let periodLength = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPeriodLength()), wrapErr("invalid period length")) | |
565 | + | let currentStartHeight = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyStartHeight(currentPeriodOrFail)), wrapErr("invalid start height")) | |
566 | + | let heightCheck = if (((currentStartHeight + periodLength) > height)) | |
567 | + | then true | |
568 | + | else throwErr("too late to withdraw in this period") | |
569 | + | if ((heightCheck == heightCheck)) | |
570 | + | then { | |
571 | + | let payment = if ((size(i.payments) == 1)) | |
572 | + | then i.payments[0] | |
573 | + | else throwErr(wrapErr("invalid payments")) | |
574 | + | let paymentAssetId = if ((payment.assetId == lpAssetIdOrFail)) | |
575 | + | then lpAssetIdOrFail | |
576 | + | else throwErr("invalid payment asset") | |
577 | + | let paymentAmount = if ((payment.amount > 0)) | |
578 | + | then payment.amount | |
579 | + | else throwErr("invalid payment amount") | |
580 | + | let withdrawal = valueOrElse(getInteger(factoryAddressOrFail, keyWithdrawal()), 0) | |
581 | + | let actions = [ScriptTransfer(factoryAddressOrFail, paymentAmount, paymentAssetId)] | |
582 | + | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), (withdrawal + paymentAmount)], nil), invoke(factoryAddressOrFail, "stringEntry", [keyWithdrawalRequest(userAddress, i.transactionId), valueWithdrawalRequest(PENDING, paymentAmount, (currentPeriodOrFail + 1), unit)], nil)] | |
583 | + | if ((factoryActions == factoryActions)) | |
584 | + | then $Tuple2(actions, factoryActions) | |
585 | + | else throw("Strict value is not equal to itself.") | |
586 | + | } | |
577 | 587 | else throw("Strict value is not equal to itself.") | |
578 | 588 | } | |
579 | 589 | else throw("Strict value is not equal to itself.") | |
580 | 590 | } | |
581 | 591 | ||
582 | 592 | ||
583 | 593 | ||
584 | 594 | @Callable(i) | |
585 | 595 | func cancelWithdraw (userAddressBytes,txId) = { | |
586 | 596 | let checkCaller = onlyFactory(i) | |
587 | 597 | if ((checkCaller == checkCaller)) | |
588 | - | then { | |
589 | - | let userAddress = Address(userAddressBytes) | |
590 | - | let withdrawalRequestOption = valueOrErrorMessage(getString(factoryAddressOrFail, keyWithdrawalRequest(userAddress, txId)), wrapErr("invalid withdrawal request")) | |
591 | - | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
592 | - | let $t02138521498 = parseWithdrawalRequestValueOrFail(withdrawalRequestOption) | |
593 | - | let status = $t02138521498._1 | |
594 | - | let lpAssetAmount = $t02138521498._2 | |
595 | - | let targetPeriod = $t02138521498._3 | |
596 | - | let claimTxId = $t02138521498._4 | |
597 | - | let checks = [if ((status == PENDING)) | |
598 | - | then true | |
599 | - | else throwErr("invalid withdrawal request status"), if ((targetPeriod > currentPeriodOrFail)) | |
600 | - | then true | |
601 | - | else throwErr("invalid withdrawal request period")] | |
602 | - | if ((checks == checks)) | |
603 | - | then { | |
604 | - | let withdrawal = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyWithdrawal()), wrapErr("invalid total withdrawal amount")) | |
605 | - | let factoryActions = [invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawal(), if ((withdrawal >= lpAssetAmount)) | |
606 | - | then (withdrawal - lpAssetAmount) | |
607 | - | else throwErr("invalid withdrawal amount")], nil), invoke(factoryAddressOrFail, "deleteEntry", [keyWithdrawalRequest(userAddress, txId)], nil), invoke(factoryAddressOrFail, "transferAsset", [userAddressBytes, lpAssetAmount, lpAssetIdOrFail], nil)] | |
608 | - | if ((factoryActions == factoryActions)) | |
609 | - | then $Tuple2(nil, factoryActions) | |
610 | - | else throw("Strict value is not equal to itself.") | |
611 | - | } | |
612 | - | else throw("Strict value is not equal to itself.") | |
613 | - | } | |
598 | + | then throwErr("cancelWithdraw is deprecated") | |
614 | 599 | else throw("Strict value is not equal to itself.") | |
615 | 600 | } | |
616 | 601 | ||
617 | 602 | ||
618 | 603 | ||
619 | 604 | @Callable(i) | |
620 | 605 | func claimCollateral (userAddressBytes,txId) = { | |
621 | 606 | let checkCaller = onlyFactory(i) | |
622 | 607 | if ((checkCaller == checkCaller)) | |
623 | 608 | then { | |
624 | - | let $ | |
625 | - | let userAddress = $ | |
626 | - | let lpAssetAmount = $ | |
627 | - | let targetPeriod = $ | |
628 | - | let wavesAmount = $ | |
629 | - | let assetsString = $ | |
630 | - | let amountsString = $ | |
609 | + | let $t02161621801 = claimCollateralINTERNAL(userAddressBytes, fromBase58String(txId)) | |
610 | + | let userAddress = $t02161621801._1 | |
611 | + | let lpAssetAmount = $t02161621801._2 | |
612 | + | let targetPeriod = $t02161621801._3 | |
613 | + | let wavesAmount = $t02161621801._4 | |
614 | + | let assetsString = $t02161621801._5 | |
615 | + | let amountsString = $t02161621801._6 | |
631 | 616 | let assetsList = removeByIndex(split_51C(assetsString, SEP), 0) | |
632 | 617 | let amountsList = removeByIndex(split_51C(amountsString, SEP), 0) | |
633 | 618 | let factoryActions = [invoke(factoryAddressOrFail, "deleteEntry", [keyWithdrawalRequest(userAddress, fromBase58String(txId))], nil), invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawalHistory(userAddress, fromBase58String(txId)), lpAssetAmount], nil), invoke(factoryAddressOrFail, "transferAssets", [userAddressBytes, assetsList, amountsList], nil)] | |
634 | 619 | $Tuple2(nil, factoryActions) | |
635 | 620 | } | |
636 | 621 | else throw("Strict value is not equal to itself.") | |
637 | 622 | } | |
638 | 623 | ||
639 | 624 | ||
640 | 625 | ||
641 | 626 | @Callable(i) | |
642 | 627 | func claimCollateralBulk (userAddressBytes,txIds) = { | |
643 | 628 | let checkCaller = onlyFactory(i) | |
644 | 629 | if ((checkCaller == checkCaller)) | |
645 | 630 | then { | |
646 | 631 | func addNewAction (state,txId) = { | |
647 | - | let $ | |
648 | - | let userAddress = $ | |
649 | - | let lpAssetAmount = $ | |
650 | - | let targetPeriod = $ | |
651 | - | let wavesAmount = $ | |
652 | - | let assetsString = $ | |
653 | - | let amountsString = $ | |
632 | + | let $t02255922758 = claimCollateralINTERNAL(userAddressBytes, fromBase58String(txId)) | |
633 | + | let userAddress = $t02255922758._1 | |
634 | + | let lpAssetAmount = $t02255922758._2 | |
635 | + | let targetPeriod = $t02255922758._3 | |
636 | + | let wavesAmount = $t02255922758._4 | |
637 | + | let assetsString = $t02255922758._5 | |
638 | + | let amountsString = $t02255922758._6 | |
654 | 639 | let assetsList = removeByIndex(split_51C(assetsString, SEP), 0) | |
655 | 640 | let amountsList = removeByIndex(split_51C(amountsString, SEP), 0) | |
656 | 641 | let newActions = [invoke(factoryAddressOrFail, "deleteEntry", [keyWithdrawalRequest(userAddress, fromBase58String(txId))], nil), invoke(factoryAddressOrFail, "integerEntry", [keyWithdrawalHistory(userAddress, fromBase58String(txId)), lpAssetAmount], nil), invoke(factoryAddressOrFail, "transferAssets", [userAddressBytes, assetsList, amountsList], nil)] | |
657 | 642 | (state ++ newActions) | |
658 | 643 | } | |
659 | 644 | ||
660 | 645 | let allFactoryActions = { | |
661 | 646 | let $l = txIds | |
662 | 647 | let $s = size($l) | |
663 | 648 | let $acc0 = nil | |
664 | 649 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
665 | 650 | then $a | |
666 | 651 | else addNewAction($a, $l[$i]) | |
667 | 652 | ||
668 | 653 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
669 | 654 | then $a | |
670 | 655 | else throw("List size exceeds 10") | |
671 | 656 | ||
672 | 657 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
673 | 658 | } | |
674 | 659 | $Tuple2(nil, allFactoryActions) | |
675 | 660 | } | |
676 | 661 | else throw("Strict value is not equal to itself.") | |
677 | 662 | } | |
678 | 663 | ||
679 | 664 | ||
680 | 665 | ||
681 | 666 | @Callable(i) | |
682 | 667 | func claimCollateralREADONLY (userAddressBytes,txId) = { | |
683 | 668 | let response = claimCollateralREADONLYStringResponse(userAddressBytes, fromBase58String(txId)) | |
684 | 669 | $Tuple2(nil, response) | |
685 | 670 | } | |
686 | 671 | ||
687 | 672 | ||
688 | 673 | ||
689 | 674 | @Callable(i) | |
690 | 675 | func claimCollateralBulkREADONLY (userAddressBytes,txIds) = { | |
691 | 676 | func processTxId (state,txId) = { | |
692 | 677 | let response = claimCollateralREADONLYStringResponse(userAddressBytes, fromBase58String(txId)) | |
693 | 678 | (state :+ response) | |
694 | 679 | } | |
695 | 680 | ||
696 | 681 | let allResponses = { | |
697 | 682 | let $l = txIds | |
698 | 683 | let $s = size($l) | |
699 | 684 | let $acc0 = nil | |
700 | 685 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
701 | 686 | then $a | |
702 | 687 | else processTxId($a, $l[$i]) | |
703 | 688 | ||
704 | 689 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
705 | 690 | then $a | |
706 | 691 | else throw("List size exceeds 10") | |
707 | 692 | ||
708 | 693 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
709 | 694 | } | |
710 | 695 | $Tuple2(nil, allResponses) | |
711 | 696 | } | |
712 | 697 | ||
713 | 698 | ||
714 | 699 | ||
715 | 700 | @Callable(i) | |
716 | 701 | func processBlocks (userAddressBytes) = { | |
717 | 702 | let checkCaller = onlyFactory(i) | |
718 | 703 | if ((checkCaller == checkCaller)) | |
719 | 704 | then { | |
720 | 705 | let userAddress = Address(userAddressBytes) | |
721 | 706 | let currentPeriodOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyCurrentPeriod()), wrapErr("invalid period")) | |
722 | 707 | let periodLength = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPeriodLength()), wrapErr("invalid period length")) | |
723 | 708 | let currentStartHeight = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyStartHeight(currentPeriodOrFail)), wrapErr("invalid start height")) | |
724 | 709 | let currentPriceOrFail = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyPriceForPeriod(currentPeriodOrFail)), wrapErr("invalid price")) | |
725 | 710 | let nextBlockToProcess = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyNextBlockToProcess()), wrapErr("invalid next block to process")) | |
726 | 711 | let periodEndHeight = ((currentStartHeight + periodLength) - 1) | |
727 | - | let blocksProcessingBatchSizeMax = 20 | |
728 | 712 | let blocksProcessingBatchSize = if (if (if ((height >= nextBlockToProcess)) | |
729 | 713 | then if ((nextBlockToProcess >= currentStartHeight)) | |
730 | 714 | then true | |
731 | 715 | else (currentPeriodOrFail == 0) | |
732 | 716 | else false) | |
733 | 717 | then (periodEndHeight >= nextBlockToProcess) | |
734 | 718 | else false) | |
735 | 719 | then min([((periodEndHeight - nextBlockToProcess) + 1), blocksProcessingBatchSizeMax]) | |
736 | 720 | else throwErr(wrapErr("invalid target block")) | |
737 | 721 | let blockProcessingReward = valueOrErrorMessage(getInteger(factoryAddressOrFail, keyBlockProcessingReward()), wrapErr("invalid block processing reward")) | |
738 | 722 | let blockProcessingRewardByGenerator = (blockProcessingReward / blocksProcessingBatchSize) | |
739 | 723 | let blockProcessingRewardByGeneratorRemainder = (blockProcessingReward - (blockProcessingRewardByGenerator * blocksProcessingBatchSize)) | |
740 | 724 | func map (acc,inc) = if ((inc >= blocksProcessingBatchSize)) | |
741 | 725 | then acc | |
742 | 726 | else { | |
743 | 727 | let targetBlockHeight = (nextBlockToProcess + inc) | |
744 | 728 | let targetBlockInfo = valueOrErrorMessage(blockInfoByHeight(targetBlockHeight), wrapErr("invalid block info")) | |
745 | 729 | let treasuryRewardOrFail = valueOrErrorMessage(rewardForOption(targetBlockInfo.rewards, proxyTreasuryAddressOrFail), wrapErr(("invalid treasury reward for height " + toString(targetBlockHeight)))) | |
746 | 730 | let generator = targetBlockInfo.generator | |
747 | 731 | let available = valueOrElse(getInteger(factoryAddressOrFail, keyAvailable(generator)), 0) | |
748 | 732 | let callerReward = if ((inc == (blocksProcessingBatchSize - 1))) | |
749 | 733 | then (blockProcessingRewardByGenerator + blockProcessingRewardByGeneratorRemainder) | |
750 | 734 | else blockProcessingRewardByGenerator | |
751 | - | let $ | |
752 | - | let shareAmountToPower = $ | |
753 | - | let businessTreasuryAmountPart = $ | |
754 | - | let rewardRemainder = $ | |
735 | + | let $t02665826766 = getRewardSplit(treasuryRewardOrFail) | |
736 | + | let shareAmountToPower = $t02665826766._1 | |
737 | + | let businessTreasuryAmountPart = $t02665826766._2 | |
738 | + | let rewardRemainder = $t02665826766._3 | |
755 | 739 | let lpAssetAmount = if ((currentPriceOrFail > 0)) | |
756 | 740 | then fraction((rewardRemainder - callerReward), SCALE8, currentPriceOrFail) | |
757 | 741 | else 0 | |
758 | 742 | let factoryActionsSingle = [invoke(factoryAddressOrFail, "stringEntry", [keyBlockProcessed(targetBlockHeight), makeString([toBase58String(i.transactionId), toString(currentPeriodOrFail), toString(generator), toBase58String(userAddressBytes), toString(treasuryRewardOrFail), toString(callerReward), toString(lpAssetAmount), toString(shareAmountToPower)], SEP)], nil), invoke(factoryAddressOrFail, "integerEntry", [keyAvailable(generator), (available + lpAssetAmount)], nil)] | |
759 | 743 | if ((factoryActionsSingle == factoryActionsSingle)) | |
760 | 744 | then { | |
761 | - | let $ | |
762 | - | let lpAssetAcc = $ | |
763 | - | let rewardAcc = $ | |
764 | - | let businessTreasuryAcc = $ | |
765 | - | let powerShareDataTuple = $ | |
766 | - | let $ | |
767 | - | let powerShareAcc = $ | |
768 | - | let generatorPowerShareList = $ | |
745 | + | let $t02761427689 = acc | |
746 | + | let lpAssetAcc = $t02761427689._1 | |
747 | + | let rewardAcc = $t02761427689._2 | |
748 | + | let businessTreasuryAcc = $t02761427689._3 | |
749 | + | let powerShareDataTuple = $t02761427689._4 | |
750 | + | let $t02769627762 = powerShareDataTuple | |
751 | + | let powerShareAcc = $t02769627762._1 | |
752 | + | let generatorPowerShareList = $t02769627762._2 | |
769 | 753 | let newGeneratorPowerShareList = (generatorPowerShareList :+ $Tuple2(toString(generator), shareAmountToPower)) | |
770 | 754 | $Tuple4((lpAssetAcc + lpAssetAmount), (rewardAcc + treasuryRewardOrFail), (businessTreasuryAcc + businessTreasuryAmountPart), $Tuple2((powerShareAcc + shareAmountToPower), newGeneratorPowerShareList)) | |
771 | 755 | } | |
772 | 756 | else throw("Strict value is not equal to itself.") | |
773 | 757 | } | |
774 | 758 | ||
775 | 759 | let list = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19] | |
776 | - | let $ | |
760 | + | let $t02821028372 = { | |
777 | 761 | let $l = list | |
778 | 762 | let $s = size($l) | |
779 | 763 | let $acc0 = $Tuple4(0, 0, 0, $Tuple2(0, nil)) | |
780 | 764 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
781 | 765 | then $a | |
782 | 766 | else map($a, $l[$i]) | |
783 | 767 | ||
784 | 768 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
785 | 769 | then $a | |
786 | 770 | else throw("List size exceeds 20") | |
787 | 771 | ||
788 | 772 | $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) | |
789 | 773 | } | |
790 | - | if (($ | |
774 | + | if (($t02821028372 == $t02821028372)) | |
791 | 775 | then { | |
792 | - | let powerShareDataTuple = $ | |
793 | - | let rewardToBusinessTreasuryAmount = $ | |
794 | - | let rewardAmountTotal = $ | |
795 | - | let lpAssetAmountTotal = $ | |
796 | - | let $ | |
797 | - | let amountToPowerTotal = $ | |
798 | - | let powerShareAmountsList = $ | |
776 | + | let powerShareDataTuple = $t02821028372._4 | |
777 | + | let rewardToBusinessTreasuryAmount = $t02821028372._3 | |
778 | + | let rewardAmountTotal = $t02821028372._2 | |
779 | + | let lpAssetAmountTotal = $t02821028372._1 | |
780 | + | let $t02837628445 = powerShareDataTuple | |
781 | + | let amountToPowerTotal = $t02837628445._1 | |
782 | + | let powerShareAmountsList = $t02837628445._2 | |
799 | 783 | let rewardToMainTreasuryAmount = (((rewardAmountTotal - rewardToBusinessTreasuryAmount) - blockProcessingReward) - amountToPowerTotal) | |
800 | 784 | let invested = valueOrElse(getInteger(factoryAddressOrFail, keyInvested(unit)), 0) | |
801 | 785 | let powerShareActions = if ((amountToPowerTotal > 0)) | |
802 | 786 | then { | |
803 | 787 | let transferAction = [invoke(factoryAddressOrFail, "transferFromProxyTreasury", [factoryAddressOrFail.bytes, amountToPowerTotal], nil)] | |
804 | 788 | if ((transferAction == transferAction)) | |
805 | 789 | then { | |
806 | 790 | let totalPowerAmount = invoke(factoryAddressOrFail, "swap", [powerAssetIdStringOrFail, WAVES, amountToPowerTotal], nil) | |
807 | 791 | if ((totalPowerAmount == totalPowerAmount)) | |
808 | 792 | then { | |
809 | 793 | let totalPowerAmountInt = match totalPowerAmount { | |
810 | 794 | case pAmount: Int => | |
811 | 795 | pAmount | |
812 | 796 | case _ => | |
813 | 797 | 0 | |
814 | 798 | } | |
815 | 799 | func stakePowerInvoke (acc,next) = { | |
816 | - | let $ | |
817 | - | let generator = $ | |
818 | - | let shareAmount = $ | |
800 | + | let $t02931929354 = next | |
801 | + | let generator = $t02931929354._1 | |
802 | + | let shareAmount = $t02931929354._2 | |
819 | 803 | if ((amountToPowerTotal > 0)) | |
820 | 804 | then { | |
821 | 805 | let powerAmount = fraction(shareAmount, totalPowerAmountInt, amountToPowerTotal) | |
822 | 806 | let inv = invoke(factoryAddressOrFail, "powerStake", [fromBase58String(generator), fromBase58String(powerAssetIdStringOrFail), powerAmount], nil) | |
823 | 807 | if ((inv == inv)) | |
824 | 808 | then nil | |
825 | 809 | else throw("Strict value is not equal to itself.") | |
826 | 810 | } | |
827 | 811 | else nil | |
828 | 812 | } | |
829 | 813 | ||
830 | 814 | let powerStakesActions = { | |
831 | 815 | let $l = powerShareAmountsList | |
832 | 816 | let $s = size($l) | |
833 | 817 | let $acc0 = 0 | |
834 | 818 | func $f1_1 ($a,$i) = if (($i >= $s)) | |
835 | 819 | then $a | |
836 | 820 | else stakePowerInvoke($a, $l[$i]) | |
837 | 821 | ||
838 | 822 | func $f1_2 ($a,$i) = if (($i >= $s)) | |
839 | 823 | then $a | |
840 | 824 | else throw("List size exceeds 20") | |
841 | 825 | ||
842 | 826 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
843 | 827 | } | |
844 | 828 | if ((powerStakesActions == powerStakesActions)) | |
845 | 829 | then nil | |
846 | 830 | else throw("Strict value is not equal to itself.") | |
847 | 831 | } | |
848 | 832 | else throw("Strict value is not equal to itself.") | |
849 | 833 | } | |
850 | 834 | else throw("Strict value is not equal to itself.") | |
851 | 835 | } | |
852 | 836 | else nil | |
853 | 837 | if ((powerShareActions == powerShareActions)) | |
854 | 838 | then { | |
855 | 839 | let actions = [invoke(factoryAddressOrFail, "reissue", [lpAssetAmountTotal], nil), invoke(factoryAddressOrFail, "integerEntry", [keyNextBlockToProcess(), (nextBlockToProcess + blocksProcessingBatchSize)], nil), invoke(factoryAddressOrFail, "transferFromProxyTreasury", [mainTreasuryAddressOrFail.bytes, rewardToMainTreasuryAmount], nil), invoke(factoryAddressOrFail, "transferFromProxyTreasury", [userAddressBytes, blockProcessingReward], nil), invoke(factoryAddressOrFail, "transferFromProxyTreasury", [businessTreasuryAddressOrFail.bytes, rewardToBusinessTreasuryAmount], nil), invoke(factoryAddressOrFail, "integerEntry", [keyInvested(unit), (invested + rewardToMainTreasuryAmount)], nil)] | |
856 | 840 | if ((actions == actions)) | |
857 | 841 | then $Tuple2(nil, unit) | |
858 | 842 | else throw("Strict value is not equal to itself.") | |
859 | 843 | } | |
860 | 844 | else throw("Strict value is not equal to itself.") | |
861 | 845 | } | |
862 | 846 | else throw("Strict value is not equal to itself.") | |
863 | 847 | } | |
864 | 848 | else throw("Strict value is not equal to itself.") | |
865 | 849 | } | |
866 | 850 | ||
867 | 851 | ||
868 | 852 | @Verifier(tx) | |
869 | 853 | func verify () = { | |
870 | 854 | let publicKey = match getManagerPublicKeyOrUnit() { | |
871 | 855 | case pub: ByteVector => | |
872 | 856 | pub | |
873 | 857 | case _ => | |
874 | 858 | tx.senderPublicKey | |
875 | 859 | } | |
876 | 860 | sigVerify(tx.bodyBytes, tx.proofs[0], publicKey) | |
877 | 861 | } | |
878 | 862 |
github/deemru/w8io/169f3d6 111.83 ms ◑![]()