2023.04.06 15:50 [3588357] smart account 3P9vKqQKjUdmpXAfiWau8krREYAY1Xr69pE > SELF 0.00000000 Waves

{ "type": 13, "id": "73hjnEhyV2ymvnqzgk9ZRiyehmwq1qR7KKTUjUBwbvLE", "fee": 1900000, "feeAssetId": null, "timestamp": 1680787540403, "version": 1, "sender": "3P9vKqQKjUdmpXAfiWau8krREYAY1Xr69pE", "senderPublicKey": "7AUMX54ukYMYvPmma7yoFf5NjZhs4Bu5nz3Ez9EV8sur", "proofs": [ "54KnumZ4Ho3UiiHTEFMYDAQmpM2Jf4CRNMqLEQmsr19MP2SHb1nZSe1qJtcHLHaHxVo2ocVbjYyD5bZeDdSfJjVb" ], "script": "base64:BgIrCAISBwoFAQgIAQESBQoDCAgIEgASAwoBCBIDCgEIEgYKBAgIAQESAwoBCEIAA1NFUAICX18ABU1VTFQ2AMCEPQAFTVVMVDgAgMLXLwAKV0FWRVNJRFNUUgIFV0FWRVMAB1dBVkVTSUQJANkEAQUKV0FWRVNJRFNUUgEMZ2V0SW50T3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQR0aGlzBQNrZXkJAKwCAgkArAICAg9NYW5kYXRvcnkgdGhpcy4FA2tleQIPIGlzIG5vdCBkZWZpbmVkAQxnZXRTdHJPckVsc2UDB2FkZHJlc3MDa2V5CmRlZmF1bHRWYWwJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUHYWRkcmVzcwUDa2V5BQpkZWZhdWx0VmFsAQ9nZXRTdHJpbmdPckZhaWwCB2FkZHJlc3MDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUHYWRkcmVzcwUDa2V5CQCsAgIJAKwCAgIPTWFuZGF0b3J5IHRoaXMuBQNrZXkCDyBpcyBub3QgZGVmaW5lZAEQZ2V0QWRkcmVzc09yRmFpbAEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMFA2tleQkArAICCQCsAgICFUZhaWwgdG8gY29udmVydCB0aGlzLgUDa2V5AhMgdmFsdWUgaW50byBBZGRyZXNzAQlhc0FueUxpc3QBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACCUxpc3RbQW55XQQKdmFsQW55TGlzdAUHJG1hdGNoMAUKdmFsQW55TGlzdAkAAgECG2ZhaWwgdG8gY2FzdCBpbnRvIExpc3RbQW55XQEFYXNJbnQBAXYEByRtYXRjaDAFAXYDCQABAgUHJG1hdGNoMAIDSW50BAFpBQckbWF0Y2gwBQFpCQACAQIVZmFpbCB0byBjYXN0IGludG8gSW50AQthc0J5dGVWZWNvdAEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFpBQckbWF0Y2gwBQFpCQACAQIcZmFpbCB0byBjYXN0IGludG8gQnl0ZVZlY3RvcgEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQphZGRyZXNzU3RyBAdhZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUKYWRkcmVzc1N0cgkArAICAh1mYWlsIHRvIGNvbnZlcnQgaW50byBhZGRyZXNzIAUKYWRkcmVzc1N0cgMJAGYCAAAICQDvBwEFB2FkZHJlc3MJYXZhaWxhYmxlCQEFdGhyb3cABQphZGRyZXNzU3RyAQ9rZXlOb2RlUmVnaXN0cnkBB2FkZHJlc3MJAKwCAgIEJXNfXwUHYWRkcmVzcwEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBB2FkZHJlc3MJAKwCAgIOJXMlc19fdG90YWxzX18FB2FkZHJlc3MBE2tleUFwcHJvdmVkTm9kZUxpc3QAAhQlc19fYXBwcm92ZWROb2RlTGlzdAEQa2V5RGVwb3NpdEFtb3VudAACGCVzJXNfX2NmZ19fZGVwb3NpdEFtb3VudAEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAIaJXMlc19fY2ZnX19uZXV0cmlub0FkZHJlc3MBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAIiJXMlc19fY2ZnX19tYWluTmV1dHJpbm9Ob2RlQWRkcmVzcwERa2V5UHJvdG9jb2xQYXJ0WDYAAhklcyVzX19jZmdfX3Byb3RvY29sUGFydFg2ARNrZXlCZW5pZmljYXJ5UGFydFg2AAIbJXMlc19fY2ZnX19iZW5pZmljYXJ5UGFydFg2ARZrZXlNaW5EaXN0cmlidXRlQW1vdW50AAIeJXMlc19fY2ZnX19taW5EaXN0cmlidXRlQW1vdW50ARxrZXlTd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzAAIkJXMlc19fY2ZnX19zd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzARBrZXlXeFN3YXBBZGRyZXNzAAIYJXMlc19fY2ZnX193eFN3YXBBZGRyZXNzARFrZXlTYXZpbmdzQWRkcmVzcwACGSVzJXNfX2NmZ19fc2F2aW5nc0FkZHJlc3MBFWtleUJlbmVmaWNpYXJ5QWRkcmVzcwACHSVzJXNfX2NmZ19fYmVuZWZpY2lhcnlBZGRyZXNzABlJZHhDb250cm9sQ2ZnTmV1dHJpbm9EYXBwAAEAGElkeENvbnRyb2xDZmdBdWN0aW9uRGFwcAACABRJZHhDb250cm9sQ2ZnUnBkRGFwcAADABVJZHhDb250cm9sQ2ZnTWF0aERhcHAABAAcSWR4Q29udHJvbENmZ0xpcXVpZGF0aW9uRGFwcAAFABVJZHhDb250cm9sQ2ZnUmVzdERhcHAABgAdSWR4Q29udHJvbENmZ05vZGVSZWdpc3RyeURhcHAABwAcSWR4Q29udHJvbENmZ05zYnRTdGFraW5nRGFwcAAIABlJZHhDb250cm9sQ2ZnTWVkaWF0b3JEYXBwAAkAHElkeENvbnRyb2xDZmdTdXJmU3Rha2luZ0RhcHAACgAgSWR4Q29udHJvbENmZ0duc2J0Q29udHJvbGxlckRhcHAACwAXSWR4Q29udHJvbENmZ1Jlc3RWMkRhcHAADAAbSWR4Q29udHJvbENmZ0dvdmVybmFuY2VEYXBwAA0BEWtleUNvbnRyb2xBZGRyZXNzAAIcJXMlc19fY29uZmlnX19jb250cm9sQWRkcmVzcwENa2V5Q29udHJvbENmZwACESVzX19jb250cm9sQ29uZmlnAQ5rZXlVc2RuQXNzZXRJZAACEW5ldXRyaW5vX2Fzc2V0X2lkARRyZWFkQ29udHJvbENmZ09yRmFpbAEHY29udHJvbAkAvAkCCQEPZ2V0U3RyaW5nT3JGYWlsAgUHY29udHJvbAkBDWtleUNvbnRyb2xDZmcABQNTRVABGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIKY29udHJvbENmZwNpZHgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFCmNvbnRyb2xDZmcFA2lkeAkArAICAi1Db250cm9sIGNmZyBkb2Vzbid0IGNvbnRhaW4gYWRkcmVzcyBhdCBpbmRleCAJAKQDAQUDaWR4AA9jb250cm9sQ29udHJhY3QJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkBEWtleUNvbnRyb2xBZGRyZXNzAAIjM1A1QmZkNThQUGZOdkJNMkh5OFFmYmNEcU1lTnR6ZzdLZlAACmNvbnRyb2xDZmcJARRyZWFkQ29udHJvbENmZ09yRmFpbAEFD2NvbnRyb2xDb250cmFjdAAQbmV1dHJpbm9Db250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFCmNvbnRyb2xDZmcFGUlkeENvbnRyb2xDZmdOZXV0cmlub0RhcHAADnVzZG5Bc3NldElkU3RyCQEMZ2V0U3RyT3JFbHNlAwUQbmV1dHJpbm9Db250cmFjdAkBDmtleVVzZG5Bc3NldElkAAIsREcyeEZrUGREd0tVb0JrekdBaFF0THBTR3pmWExpQ1lQRXplS0gyQWQyNHAAC3VzZG5Bc3NldElkCQDZBAEFDnVzZG5Bc3NldElkU3RyAAxuUmVnSWR4VHhBZGQAAQAQblJlZ0lkeEhlaWdodEFkZAACAA5uUmVnSWR4VGltZUFkZAADAA5uUmVnSWR4RGVwb0FtdAAEABJuUmVnSWR4RGVwb0FtdExlZnQABQANblJlZ0lkeFN0YXR1cwAGABluUmVnSWR4U3RhdHVzQ2hhbmdlSGVpZ2h0AAcAF25SZWdJZHhTdGF0dXNDaGFuZ2VUaW1lAAgBEGZvcm1hdERlcG9zaXRBZGQEB3R4SWRTdHINZGVwb3NpdEFtb3VudBZyZW1haW5pbmdEZXBvc2l0QW1vdW50BnN0YXR1cwkAuQkCCQDMCAICECVzJWQlZCVkJWQlcyVkJWQJAMwIAgUHdHhJZFN0cgkAzAgCCQCkAwEIBQlsYXN0QmxvY2sGaGVpZ2h0CQDMCAIJAKQDAQgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkApAMBBQ1kZXBvc2l0QW1vdW50CQDMCAIJAKQDAQUWcmVtYWluaW5nRGVwb3NpdEFtb3VudAkAzAgCBQZzdGF0dXMJAMwIAgIBMAkAzAgCAgEwBQNuaWwFA1NFUAEZZm9ybWF0RGVwb3NpdENoYW5nZVN0YXR1cwIFb3JpZ1MJbmV3U3RhdHVzBARvcmlnCQC1CQIFBW9yaWdTBQNTRVAJALkJAgkAzAgCAhAlcyVkJWQlZCVkJXMlZCVkCQDMCAIJAJEDAgUEb3JpZwUMblJlZ0lkeFR4QWRkCQDMCAIJAJEDAgUEb3JpZwUQblJlZ0lkeEhlaWdodEFkZAkAzAgCCQCRAwIFBG9yaWcFDm5SZWdJZHhUaW1lQWRkCQDMCAIJAJEDAgUEb3JpZwUOblJlZ0lkeERlcG9BbXQJAMwIAgkAkQMCBQRvcmlnBRJuUmVnSWR4RGVwb0FtdExlZnQJAMwIAgUJbmV3U3RhdHVzCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUDbmlsBQNTRVABEGtleVJld2FyZEhpc3RvcnkCC25vZGVBZGRyZXNzBHR4SWQJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIHaGlzdG9yeQkAzAgCCQClCAEFC25vZGVBZGRyZXNzCQDMCAIJANgEAQUEdHhJZAUDbmlsBQNTRVABEWRhdGFSZXdhcmRIaXN0b3J5BRB3YXZlc0Ftb3VudFRvdGFsDmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICDiVkJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQCkAwEFEHdhdmVzQW1vdW50VG90YWwJAMwIAgkApAMBBQ5iZW5lZmljaWFyeUFtdAkAzAgCCQCkAwEFC3Byb3RvY29sQW10CQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MQkAzAgCCQCkAwEFEHByb3RvY29sQW10UGFydDIFA25pbAUDU0VQARJSZXdhcmRIaXN0b3J5RW50cnkHC25vZGVBZGRyZXNzBHR4SWQIbWluZWRBbXQOYmVuZWZpY2lhcnlBbXQLcHJvdG9jb2xBbXQMcHJvdG9jb2xBbXQxDHByb3RvY29sQW10MgkBC1N0cmluZ0VudHJ5AgkBEGtleVJld2FyZEhpc3RvcnkCBQtub2RlQWRkcmVzcwUEdHhJZAkBEWRhdGFSZXdhcmRIaXN0b3J5BQUIbWluZWRBbXQFDmJlbmVmaWNpYXJ5QW10BQtwcm90b2NvbEFtdAUMcHJvdG9jb2xBbXQxBQxwcm90b2NvbEFtdDIBEGRhdGFSZXdhcmRUb3RhbHMFCG1pbmVkQW10DmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICCiVkJWQlZCVkJWQJAMwIAgkApAMBBQhtaW5lZEFtdAkAzAgCCQCkAwEFDmJlbmVmaWNpYXJ5QW10CQDMCAIJAKQDAQULcHJvdG9jb2xBbXQJAMwIAgkApAMBBRBwcm90b2NvbEFtdFBhcnQxCQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MgUDbmlsBQNTRVABEVJld2FyZFRvdGFsc0VudHJ5BgVtaW5lcghtaW5lZEFtdA5iZW5lZmljaWFyeUFtdAtwcm90b2NvbEFtdBBwcm90b2NvbEFtdFBhcnQxEHByb3RvY29sQW10UGFydDIEFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBCQClCAEFBW1pbmVyBBBub2RlUmV3YXJkc0FycmF5CQC1CQIJAQxnZXRTdHJPckVsc2UDBQR0aGlzBRRub2RlUmV3YXJkc1RvdGFsc0tFWQkBEGRhdGFSZXdhcmRUb3RhbHMFAAAAAAAAAAAAAAUDU0VQBAtuZXdNaW5lZEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAEFCG1pbmVkQW10BBFuZXdCZW5lZmljaWFyeUFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAIFDmJlbmVmaWNpYXJ5QW10BA5uZXdQcm90b2NvbEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAMFC3Byb3RvY29sQW10BBNuZXdQcm90b2NvbEFtdFBhcnQxCQBkAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFEG5vZGVSZXdhcmRzQXJyYXkABAUQcHJvdG9jb2xBbXRQYXJ0MQQTbmV3UHJvdG9jb2xBbXRQYXJ0MgkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAUFEHByb3RvY29sQW10UGFydDIJAQtTdHJpbmdFbnRyeQIFFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEQZGF0YVJld2FyZFRvdGFscwUFC25ld01pbmVkQW10BRFuZXdCZW5lZmljaWFyeUFtdAUObmV3UHJvdG9jb2xBbXQFE25ld1Byb3RvY29sQW10UGFydDEFE25ld1Byb3RvY29sQW10UGFydDIBFHJlc29sdmVCZW5lZmljaWFyaWVzAgxtaW5lckFkZHJlc3MUYmVuZWZpY2lhcnlGcm9tUGFyYW0EGWJlbmVmaWNpYXJ5RnJvbU1pbmVyU3RhdGUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQ9nZXRTdHJpbmdPckZhaWwCBQxtaW5lckFkZHJlc3MJARVrZXlCZW5lZmljaWFyeUFkZHJlc3MAAwkAAAIJAPEHAQUMbWluZXJBZGRyZXNzBQR1bml0BRRiZW5lZmljaWFyeUZyb21QYXJhbQUZYmVuZWZpY2lhcnlGcm9tTWluZXJTdGF0ZQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCCG5vZGVBZGRyDmV4cGVjdGVkU3RhdHVzBAtub2RlRGF0YU9wdAkAoggBCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUIbm9kZUFkZHIDCQEBIQEJAQlpc0RlZmluZWQBBQtub2RlRGF0YU9wdAkAAgEJAKwCAgINVW5rbm93biBOb2RlIAUIbm9kZUFkZHIEC25vZGVEYXRhU3RyCQEFdmFsdWUBBQtub2RlRGF0YU9wdAQIbm9kZURhdGEJALUJAgULbm9kZURhdGFTdHIFA1NFUAQKbm9kZVN0YXR1cwMJAGcCCQCQAwEFCG5vZGVEYXRhAAkJAJEDAgUIbm9kZURhdGEFDW5SZWdJZHhTdGF0dXMCB1BFTkRJTkcDCQECIT0CBQpub2RlU3RhdHVzBQ5leHBlY3RlZFN0YXR1cwkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgVOb2RlIAUIbm9kZUFkZHICEiBzdGF0dXMgc2hvdWxkIGJlIAUOZXhwZWN0ZWRTdGF0dXMCDywgYnV0IGFjdHVhbGx5IAUKbm9kZVN0YXR1cwULbm9kZURhdGFTdHIHAWkBDWNvbnN0cnVjdG9yVjEFDWRlcG9zaXRBbW91bnQSbmV1dHJpbm9BZGRyZXNzU3RyFG1hc3Rlck5vZGVBZGRyZXNzU3RyDnByb3RvY29sUGFydFg2EGJlbmlmaWNhcnlQYXJ0WDYDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhJwZXJtaXNzaW9ucyBkZW5pZWQDCQBmAgAABQ1kZXBvc2l0QW1vdW50CQACAQIcZGVwb3NpdEFtb3VudCBsZXNzIHRoZW4gemVybwMJAGYCAAAFDnByb3RvY29sUGFydFg2CQACAQIdcHJvdG9jb2xQYXJ0WDYgbGVzcyB0aGVuIHplcm8DCQBmAgAABRBiZW5pZmljYXJ5UGFydFg2CQACAQIfYmVuaWZpY2FyeVBhcnRYNiBsZXNzIHRoZW4gemVybwMJAQIhPQIJAGQCBQ5wcm90b2NvbFBhcnRYNgUQYmVuaWZpY2FyeVBhcnRYNgUFTVVMVDYJAAIBAhNwYXJ0cyBzdW0gbXVzdCBiZSAxCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEQa2V5RGVwb3NpdEFtb3VudAAFDWRlcG9zaXRBbW91bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBFWtleU5ldXRyaW5vQWRkcmVzc1N0cgAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRJuZXV0cmlub0FkZHJlc3NTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAkBFXZhbGlkYXRlQWRkcmVzc09yRmFpbAEFFG1hc3Rlck5vZGVBZGRyZXNzU3RyCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQERa2V5UHJvdG9jb2xQYXJ0WDYABQ5wcm90b2NvbFBhcnRYNgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBE2tleUJlbmlmaWNhcnlQYXJ0WDYABRBiZW5pZmljYXJ5UGFydFg2BQNuaWwBaQENY29uc3RydWN0b3JWMgMQc3dvcGZpQWRkcmVzc1N0chFjb250cm9sQWRkcmVzc1N0chFzYXZpbmdzQWRkcmVzc1N0cgMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECEnBlcm1pc3Npb25zIGRlbmllZAkAzAgCCQELU3RyaW5nRW50cnkCCQEca2V5U3dvcGZpVXNkdFVzZG5Qb29sQWRkcmVzcwAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRBzd29wZmlBZGRyZXNzU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQIJARFrZXlDb250cm9sQWRkcmVzcwAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRFjb250cm9sQWRkcmVzc1N0cgkAzAgCCQELU3RyaW5nRW50cnkCCQERa2V5U2F2aW5nc0FkZHJlc3MACQEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQURc2F2aW5nc0FkZHJlc3NTdHIFA25pbAFpARFzdW1iaXRBcHBsaWNhdGlvbgADCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAiBleGFjdCAxIHBheW1lbnQgbXVzdCBiZSBhdHRhY2hlZAMJAQIhPQIIBQFpBmNhbGxlcggFAWkMb3JpZ2luQ2FsbGVyCQACAQIiZGFwcCB0byBkYXBwIGNhbGxzIGFyZSBub3QgYWxsb3dlZAQDcG10CQCRAwIIBQFpCHBheW1lbnRzAAAEB2RlcG9zaXQIBQNwbXQGYW1vdW50BApwbXRBc3NldElkCQELdmFsdWVPckVsc2UCCAUDcG10B2Fzc2V0SWQFB1dBVkVTSUQEFWV4cGVjdGVkRGVwb3NpdEFtb3VudAkBDGdldEludE9yRmFpbAEJARBrZXlEZXBvc2l0QW1vdW50AAQEdHhJZAkA2AQBCAUBaQ10cmFuc2FjdGlvbklkBAtub2RlQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIED25vZGVSZWdpc3RyeUtFWQkBD2tleU5vZGVSZWdpc3RyeQEFC25vZGVBZGRyZXNzAwkBAiE9AgUKcG10QXNzZXRJZAUHV0FWRVNJRAkAAgECIm9ubHkgV2F2ZXMgY2FuIGJlIHVzZWQgZm9yIGRlcG9zaXQDCQECIT0CBQdkZXBvc2l0BRVleHBlY3RlZERlcG9zaXRBbW91bnQJAAIBCQCsAgIJAKwCAgIIZXhhY3RseSAJAKQDAQUVZXhwZWN0ZWREZXBvc2l0QW1vdW50AhYgV2F2ZWxldHMgYXJlIGV4cGVjdGVkAwkBAiE9AgkBDGdldFN0ck9yRWxzZQMFBHRoaXMFD25vZGVSZWdpc3RyeUtFWQIAAgAJAAIBAhx5b3VyIG5vZGUgYWxyZWFkeSByZWdpc3RlcmVkCQDMCAIJAQtTdHJpbmdFbnRyeQIFD25vZGVSZWdpc3RyeUtFWQkBEGZvcm1hdERlcG9zaXRBZGQEBQR0eElkBQdkZXBvc2l0BQdkZXBvc2l0AgdQRU5ESU5HBQNuaWwBaQEVZGlzdHJpYnV0ZU1pbmVyUmV3YXJkARViZW5lZmljaWFyeUFkZHJlc3NTdHIEE21pbkRpc3RyaWJ1dGVBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBFmtleU1pbkRpc3RyaWJ1dGVBbW91bnQACQBoAgAYBQVNVUxUOAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECIGV4YWN0IDEgcGF5bWVudCBtdXN0IGJlIGF0dGFjaGVkAwkBAiE9AggFAWkGY2FsbGVyCAUBaQxvcmlnaW5DYWxsZXIJAAIBAiJkYXBwIHRvIGRhcHAgY2FsbHMgYXJlIG5vdCBhbGxvd2VkBANwbXQJAJEDAggFAWkIcGF5bWVudHMAAAQKcG10QXNzZXRJZAkBC3ZhbHVlT3JFbHNlAggFA3BtdAdhc3NldElkBQdXQVZFU0lEBAZmZWVBbXQIBQFpA2ZlZQQKZmVlQXNzZXRJZAkBC3ZhbHVlT3JFbHNlAggFAWkKZmVlQXNzZXRJZAUHV0FWRVNJRAQKY2FsbFJld2FyZAkAaAIFBmZlZUFtdAADBAhtaW5lZEFtdAkAZQIIBQNwbXQGYW1vdW50BQpjYWxsUmV3YXJkAwkBAiE9AggFA3BtdAZhbW91bnQFE21pbkRpc3RyaWJ1dGVBbW91bnQJAAIBCQCsAgIJAKwCAgIfYXR0YWNoZWQgcGF5bWVudCBtdXN0IGJlIGV4YWN0IAkApAMBBRNtaW5EaXN0cmlidXRlQW1vdW50AgkgV2F2ZWxldHMDCQECIT0CBQpwbXRBc3NldElkBQdXQVZFU0lECQACAQIhb25seSBXYXZlcyBjYW4gYmUgdXNlZCBpbiBwYXltZW50AwkBAiE9AgUKZmVlQXNzZXRJZAUHV0FWRVNJRAkAAgECHm9ubHkgV2F2ZXMgY2FuIGJlIHVzZWQgaW4gZmVlcwMJAQIhPQIFBmZlZUFtdAkAaQIJAGgCAAUFBU1VTFQ4AOgHCQACAQIgZmVlIGFtb3VudCBjb3VsZG4ndCBleGNlZWQgMC4wMDUED25ldXRyaW5vQWRkcmVzcwkBEGdldEFkZHJlc3NPckZhaWwBCQEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAQRbWFzdGVyTm9kZUFkZHJlc3MJARBnZXRBZGRyZXNzT3JGYWlsAQkBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAQMbWluZXJBZGRyZXNzCAUBaQZjYWxsZXIEFGJlbmVmaWNpYXJ5RnJvbVBhcmFtCQERQGV4dHJOYXRpdmUoMTA2MikBBRViZW5lZmljaWFyeUFkZHJlc3NTdHIEEmJlbmVmaWNpYXJ5QWRkcmVzcwkBFHJlc29sdmVCZW5lZmljaWFyaWVzAgUMbWluZXJBZGRyZXNzBRRiZW5lZmljaWFyeUZyb21QYXJhbQQQdHhSZXdhcmRSZWNlaXZlcgUUYmVuZWZpY2lhcnlGcm9tUGFyYW0EDHByb3RvY29sUGFydAkBDGdldEludE9yRmFpbAEJARFrZXlQcm90b2NvbFBhcnRYNgAED2JlbmVmaWNpYXJ5UGFydAkBDGdldEludE9yRmFpbAEJARNrZXlCZW5pZmljYXJ5UGFydFg2AAQOYmVuZWZpY2lhcnlBbXQJAGsDBQhtaW5lZEFtdAUPYmVuZWZpY2lhcnlQYXJ0BQVNVUxUNgQLcHJvdG9jb2xBbXQJAGUCBQhtaW5lZEFtdAUOYmVuZWZpY2lhcnlBbXQECmJ1eUJhY2tBbXQJAGgCAHgFBU1VTFQ4BA5zYXZpbmdzQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBDGdldFN0ck9yRWxzZQMFBHRoaXMJARFrZXlTYXZpbmdzQWRkcmVzcwACIzNQQzdEQmltYXV5S3l0eDh0WGhLbzV1MkVDYjZGc25kWUtIBApzYXZpbmdzQW10CQEFYXNJbnQBCQD8BwQFDnNhdmluZ3NBZGRyZXNzAgh3aXRoZHJhdwkAzAgCBQpidXlCYWNrQW10BQNuaWwFA25pbAQMd3hBc3NldElkU3RyAixBdHF2NTlFWXpqRkd1aXRLVm5NUms2SDhGdWtqb1Yza3RQb3JiRXlzMjVvbgQNd3hTd2FwQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBDGdldFN0ck9yRWxzZQMFBHRoaXMJARBrZXlXeFN3YXBBZGRyZXNzAAIjM1A2OHpOaXVmc3UxdmlacHUxYVkzY2RhaFJSS2N2VjVOOTMECnN3YXBSZXN1bHQJAPwHBAUNd3hTd2FwQWRkcmVzcwIEc3dhcAkAzAgCAAEJAMwIAgUMd3hBc3NldElkU3RyCQDMCAIJAKUIAQUQbmV1dHJpbm9Db250cmFjdAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQR1bml0BQpidXlCYWNrQW10BQNuaWwDCQAAAgUKc3dhcFJlc3VsdAUKc3dhcFJlc3VsdAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRJiZW5lZmljaWFyeUFkZHJlc3MFDmJlbmVmaWNpYXJ5QW10BQR1bml0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFEG5ldXRyaW5vQ29udHJhY3QFC3Byb3RvY29sQW10BQR1bml0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFEHR4UmV3YXJkUmVjZWl2ZXIFCmNhbGxSZXdhcmQFBHVuaXQJAMwIAgkBElJld2FyZEhpc3RvcnlFbnRyeQcFDG1pbmVyQWRkcmVzcwgFAWkNdHJhbnNhY3Rpb25JZAUIbWluZWRBbXQFDmJlbmVmaWNpYXJ5QW10BQtwcm90b2NvbEFtdAULcHJvdG9jb2xBbXQAAAkAzAgCCQERUmV3YXJkVG90YWxzRW50cnkGBQxtaW5lckFkZHJlc3MFCG1pbmVkQW10BQ5iZW5lZmljaWFyeUFtdAULcHJvdG9jb2xBbXQFC3Byb3RvY29sQW10AAAFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARp2YWxpZGF0ZUFuZEFwcHJvdmVMZWFzaW5ncwEGbkxpc3RTBAVuSWR4cwkAzAgCAAAJAMwIAgABCQDMCAIAAgkAzAgCAAMJAMwIAgAECQDMCAIABQkAzAgCAAYJAMwIAgAHBQNuaWwEBW5MaXN0CQC1CQIFBm5MaXN0UwUDU0VQBA1leHBlY3RlZENvdW50CQCQAwEFBW5JZHhzBA9uZXV0cmlub0FkZHJlc3MJARBnZXRBZGRyZXNzT3JGYWlsAQkBFWtleU5ldXRyaW5vQWRkcmVzc1N0cgADCQECIT0CCAUBaQZjYWxsZXIFD25ldXRyaW5vQWRkcmVzcwkAAgECKXZhbGlkYXRlQW5kQXBwcm92ZUxlYXNpbmdzIG5vdCBhdXRob3JpemVkAwkBAiE9AgkAagIJAJADAQUFbkxpc3QAAgAACQACAQIkT25seSBldmVuIG51bWJlciBvZiBub2RlcyBpcyBhbGxvd2VkAwkBAiE9AgkAkAMBBQVuTGlzdAUNZXhwZWN0ZWRDb3VudAkAAgEJAKwCAgkArAICAgVPbmx5IAkApAMBBQ1leHBlY3RlZENvdW50AiIgb2Ygbm9kZXMnIGFkZHJlc3NlcyBjYW4gYmUgcGFzc2VkCgEXZm9yRWFjaE5vZGVDaGFuZ2VTdGF0dXMCA2FjYwFpBAhub2RlQWRkcgkAkQMCBQVuTGlzdAUBaQQLbm9kZURhdGFTdHIJAR1yZWFkTm9kZURhdGFBbmRWYWxpZGF0ZVN0YXR1cwIFCG5vZGVBZGRyAgdQRU5ESU5HCQDNCAIFA2FjYwkBC1N0cmluZ0VudHJ5AgkBD2tleU5vZGVSZWdpc3RyeQEFCG5vZGVBZGRyCQEZZm9ybWF0RGVwb3NpdENoYW5nZVN0YXR1cwIFC25vZGVEYXRhU3RyAghBUFBST1ZFRAQRYXBwcm92ZWROb2Rlc0RhdGEKAAIkbAUFbklkeHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBF2ZvckVhY2hOb2RlQ2hhbmdlU3RhdHVzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA4CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAkAlAoCBRFhcHByb3ZlZE5vZGVzRGF0YQUDbmlsAWkBE3JlcGxhY2VBcHByb3ZlZE5vZGUEDm9sZE5vZGVBZGRyU3RyDm5ld05vZGVBZGRyU3RyCGdyb3VwTnVtDXBlbmFsdHlBbW91bnQDCQECIT0CCAUBaQZjYWxsZXIFEG5ldXRyaW5vQ29udHJhY3QJAAIBAhJwZXJtaXNzaW9ucyBkZW5pZWQECm9sZERhdGFTdHIJAR1yZWFkTm9kZURhdGFBbmRWYWxpZGF0ZVN0YXR1cwIFDm9sZE5vZGVBZGRyU3RyAghBUFBST1ZFRAQKbmV3RGF0YVN0cgkBHXJlYWROb2RlRGF0YUFuZFZhbGlkYXRlU3RhdHVzAgUObmV3Tm9kZUFkZHJTdHICB1BFTkRJTkcEEWFwcHJvdmVkTm9kZUxpc3RTCQEPZ2V0U3RyaW5nT3JGYWlsAgUEdGhpcwkBE2tleUFwcHJvdmVkTm9kZUxpc3QAAwkBASEBCQEIY29udGFpbnMCBRFhcHByb3ZlZE5vZGVMaXN0UwUOb2xkTm9kZUFkZHJTdHIJAAIBCQCsAgICImFwcHJvdmVkTm9kZUxpc3QgZG9lcyBub3QgY29udGFpbiAFDm9sZE5vZGVBZGRyU3RyBBB1cGRhdGVkTm9kZUxpc3RTCQC6CQIJALwJAgURYXBwcm92ZWROb2RlTGlzdFMFDm9sZE5vZGVBZGRyU3RyBQ5uZXdOb2RlQWRkclN0cgQLb2xkTm9kZUFkZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDm9sZE5vZGVBZGRyU3RyBBJiZW5lZmljaWFyeUFkZHJlc3MJARRyZXNvbHZlQmVuZWZpY2lhcmllcwIFC29sZE5vZGVBZGRyBQtvbGROb2RlQWRkcgQKZGVwb0Ftb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIJALUJAgUKb2xkRGF0YVN0cgUDU0VQBQ5uUmVnSWR4RGVwb0FtdAQHYWN0aW9ucwkAzAgCCQELU3RyaW5nRW50cnkCCQETa2V5QXBwcm92ZWROb2RlTGlzdAAFEHVwZGF0ZWROb2RlTGlzdFMJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBD2tleU5vZGVSZWdpc3RyeQEFDm9sZE5vZGVBZGRyU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ9rZXlOb2RlUmVnaXN0cnkBBQ5uZXdOb2RlQWRkclN0cgkBGWZvcm1hdERlcG9zaXRDaGFuZ2VTdGF0dXMCBQpuZXdEYXRhU3RyAghBUFBST1ZFRAUDbmlsCQCUCgIDCQBmAgUKZGVwb0Ftb3VudAUNcGVuYWx0eUFtb3VudAkAzQgCBQdhY3Rpb25zCQEOU2NyaXB0VHJhbnNmZXIDBRJiZW5lZmljaWFyeUFkZHJlc3MJAGUCBQpkZXBvQW1vdW50BQ1wZW5hbHR5QW1vdW50BQR1bml0BQdhY3Rpb25zBQR1bml0AWkBDXJldHVybkRlcG9zaXQBDm5vZGVBZGRyZXNzU3RyAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwAACQACAQITTm8gcGF5bWVudHMgYWxsb3dlZAQNY2FsbGVyQWRkcmVzcwgFAWkGY2FsbGVyBA9ub2RlUmVnaXN0cnlLRVkJAQ9rZXlOb2RlUmVnaXN0cnkBBQ5ub2RlQWRkcmVzc1N0cgQLbm9kZURhdGFPcHQJAJ0IAgUEdGhpcwUPbm9kZVJlZ2lzdHJ5S0VZAwkBASEBCQEJaXNEZWZpbmVkAQULbm9kZURhdGFPcHQJAAIBCQCsAgICKUFkZHJlc3MgaXMgbm90IGFwcGxpZWQgYXMgbmV1dHJpbm8gbm9kZTogBQ5ub2RlQWRkcmVzc1N0cgQQYXBwcm92ZWROb2RlTGlzdAkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMJARNrZXlBcHByb3ZlZE5vZGVMaXN0AAMJAQhjb250YWlucwIFEGFwcHJvdmVkTm9kZUxpc3QFDm5vZGVBZGRyZXNzU3RyCQACAQJMSW1wb3NzaWJsZSB0byByZXR1cm4gZGVwb3NpdCBmcm9tIGFwcHJvdmVkIE5vZGUsIHBsZWFzZSBjb250YWN0IHN1cHBvcnQgdGVhbQQIbm9kZURhdGEJALUJAgkBBXZhbHVlAQULbm9kZURhdGFPcHQFA1NFUAQGc3RhdHVzAwkAZwIJAJADAQUIbm9kZURhdGEACQkAkQMCBQhub2RlRGF0YQUNblJlZ0lkeFN0YXR1cwIHUEVORElORwMJAQIhPQIFBnN0YXR1cwIHUEVORElORwkAAgECIkFwcGxpY2F0aW9uIHN0YXR1cyBpcyBub3QgUEVORElORyEECmRlcG9BbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhub2RlRGF0YQUOblJlZ0lkeERlcG9BbXQEC25vZGVBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBBQ5ub2RlQWRkcmVzc1N0cgQSYmVuZWZpY2lhcnlBZGRyZXNzCQEUcmVzb2x2ZUJlbmVmaWNpYXJpZXMCBQtub2RlQWRkcmVzcwULbm9kZUFkZHJlc3MDCQEBIQEDAwkAAAIFDWNhbGxlckFkZHJlc3MFBHRoaXMGAwkBAiE9AgUSYmVuZWZpY2lhcnlBZGRyZXNzBQtub2RlQWRkcmVzcwkAAAIFDWNhbGxlckFkZHJlc3MFEmJlbmVmaWNpYXJ5QWRkcmVzcwcGAwkAAAIFEmJlbmVmaWNpYXJ5QWRkcmVzcwULbm9kZUFkZHJlc3MJAAACBQ1jYWxsZXJBZGRyZXNzBQtub2RlQWRkcmVzcwcJAAIBAiByZXR1cm5EZXBvc2l0IHBlcm1pc3Npb25zIGRlbmllZAkAzAgCCQELRGVsZXRlRW50cnkBBQ9ub2RlUmVnaXN0cnlLRVkJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUSYmVuZWZpY2lhcnlBZGRyZXNzBQpkZXBvQW1vdW50BQR1bml0BQNuaWwAkMiGug==", "chainId": 87, "height": 3588357, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: FZxsn7ucPK356GPvvijWgkXFbuGx4Nn3Un5c29ahxgwj Next: tyeGHVqBvsGEjbhFt1uvbbGpEBde22TJF4rmBrHLxWp Diff:
OldNewDifferences
8383
8484
8585 func keySwopfiUsdtUsdnPoolAddress () = "%s%s__cfg__swopfiUsdtUsdnPoolAddress"
86+
87+
88+func keyWxSwapAddress () = "%s%s__cfg__wxSwapAddress"
8689
8790
8891 func keySavingsAddress () = "%s%s__cfg__savingsAddress"
295298 let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
296299 let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
297300 let protocolAmt = (minedAmt - beneficiaryAmt)
298-[ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(neutrinoContract, protocolAmt, unit), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0)]
301+ let buyBackAmt = (120 * MULT8)
302+ let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
303+ let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [buyBackAmt], nil))
304+ let wxAssetIdStr = "Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on"
305+ let wxSwapAddress = addressFromStringValue(getStrOrElse(this, keyWxSwapAddress(), "3P68zNiufsu1viZpu1aY3cdahRRKcvV5N93"))
306+ let swapResult = invoke(wxSwapAddress, "swap", [1, wxAssetIdStr, toString(neutrinoContract)], [AttachedPayment(unit, buyBackAmt)])
307+ if ((swapResult == swapResult))
308+ then [ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(neutrinoContract, protocolAmt, unit), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0)]
309+ else throw("Strict value is not equal to itself.")
299310 }
300311 }
301312 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let SEP = "__"
55
66 let MULT6 = 1000000
77
88 let MULT8 = 100000000
99
1010 let WAVESIDSTR = "WAVES"
1111
1212 let WAVESID = fromBase58String(WAVESIDSTR)
1313
1414 func getIntOrFail (key) = valueOrErrorMessage(getInteger(this, key), (("Mandatory this." + key) + " is not defined"))
1515
1616
1717 func getStrOrElse (address,key,defaultVal) = valueOrElse(getString(address, key), defaultVal)
1818
1919
2020 func getStringOrFail (address,key) = valueOrErrorMessage(getString(address, key), (("Mandatory this." + key) + " is not defined"))
2121
2222
2323 func getAddressOrFail (key) = valueOrErrorMessage(addressFromString(getStringOrFail(this, key)), (("Fail to convert this." + key) + " value into Address"))
2424
2525
2626 func asAnyList (val) = match val {
2727 case valAnyList: List[Any] =>
2828 valAnyList
2929 case _ =>
3030 throw("fail to cast into List[Any]")
3131 }
3232
3333
3434 func asInt (v) = match v {
3535 case i: Int =>
3636 i
3737 case _ =>
3838 throw("fail to cast into Int")
3939 }
4040
4141
4242 func asByteVecot (v) = match v {
4343 case i: ByteVector =>
4444 i
4545 case _ =>
4646 throw("fail to cast into ByteVector")
4747 }
4848
4949
5050 func validateAddressOrFail (addressStr) = {
5151 let address = valueOrErrorMessage(addressFromString(addressStr), ("fail to convert into address " + addressStr))
5252 if ((0 > wavesBalance(address).available))
5353 then throw()
5454 else addressStr
5555 }
5656
5757
5858 func keyNodeRegistry (address) = ("%s__" + address)
5959
6060
6161 func keyNodeRewardsTotals (address) = ("%s%s__totals__" + address)
6262
6363
6464 func keyApprovedNodeList () = "%s__approvedNodeList"
6565
6666
6767 func keyDepositAmount () = "%s%s__cfg__depositAmount"
6868
6969
7070 func keyNeutrinoAddressStr () = "%s%s__cfg__neutrinoAddress"
7171
7272
7373 func keyMasterNodeAddressStr () = "%s%s__cfg__mainNeutrinoNodeAddress"
7474
7575
7676 func keyProtocolPartX6 () = "%s%s__cfg__protocolPartX6"
7777
7878
7979 func keyBenificaryPartX6 () = "%s%s__cfg__benificaryPartX6"
8080
8181
8282 func keyMinDistributeAmount () = "%s%s__cfg__minDistributeAmount"
8383
8484
8585 func keySwopfiUsdtUsdnPoolAddress () = "%s%s__cfg__swopfiUsdtUsdnPoolAddress"
86+
87+
88+func keyWxSwapAddress () = "%s%s__cfg__wxSwapAddress"
8689
8790
8891 func keySavingsAddress () = "%s%s__cfg__savingsAddress"
8992
9093
9194 func keyBeneficiaryAddress () = "%s%s__cfg__beneficiaryAddress"
9295
9396
9497 let IdxControlCfgNeutrinoDapp = 1
9598
9699 let IdxControlCfgAuctionDapp = 2
97100
98101 let IdxControlCfgRpdDapp = 3
99102
100103 let IdxControlCfgMathDapp = 4
101104
102105 let IdxControlCfgLiquidationDapp = 5
103106
104107 let IdxControlCfgRestDapp = 6
105108
106109 let IdxControlCfgNodeRegistryDapp = 7
107110
108111 let IdxControlCfgNsbtStakingDapp = 8
109112
110113 let IdxControlCfgMediatorDapp = 9
111114
112115 let IdxControlCfgSurfStakingDapp = 10
113116
114117 let IdxControlCfgGnsbtControllerDapp = 11
115118
116119 let IdxControlCfgRestV2Dapp = 12
117120
118121 let IdxControlCfgGovernanceDapp = 13
119122
120123 func keyControlAddress () = "%s%s__config__controlAddress"
121124
122125
123126 func keyControlCfg () = "%s__controlConfig"
124127
125128
126129 func keyUsdnAssetId () = "neutrino_asset_id"
127130
128131
129132 func readControlCfgOrFail (control) = split_4C(getStringOrFail(control, keyControlCfg()), SEP)
130133
131134
132135 func getContractAddressOrFail (controlCfg,idx) = valueOrErrorMessage(addressFromString(controlCfg[idx]), ("Control cfg doesn't contain address at index " + toString(idx)))
133136
134137
135138 let controlContract = addressFromStringValue(valueOrElse(getString(this, keyControlAddress()), "3P5Bfd58PPfNvBM2Hy8QfbcDqMeNtzg7KfP"))
136139
137140 let controlCfg = readControlCfgOrFail(controlContract)
138141
139142 let neutrinoContract = getContractAddressOrFail(controlCfg, IdxControlCfgNeutrinoDapp)
140143
141144 let usdnAssetIdStr = getStrOrElse(neutrinoContract, keyUsdnAssetId(), "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p")
142145
143146 let usdnAssetId = fromBase58String(usdnAssetIdStr)
144147
145148 let nRegIdxTxAdd = 1
146149
147150 let nRegIdxHeightAdd = 2
148151
149152 let nRegIdxTimeAdd = 3
150153
151154 let nRegIdxDepoAmt = 4
152155
153156 let nRegIdxDepoAmtLeft = 5
154157
155158 let nRegIdxStatus = 6
156159
157160 let nRegIdxStatusChangeHeight = 7
158161
159162 let nRegIdxStatusChangeTime = 8
160163
161164 func formatDepositAdd (txIdStr,depositAmount,remainingDepositAmount,status) = makeString(["%s%d%d%d%d%s%d%d", txIdStr, toString(lastBlock.height), toString(lastBlock.timestamp), toString(depositAmount), toString(remainingDepositAmount), status, "0", "0"], SEP)
162165
163166
164167 func formatDepositChangeStatus (origS,newStatus) = {
165168 let orig = split(origS, SEP)
166169 makeString(["%s%d%d%d%d%s%d%d", orig[nRegIdxTxAdd], orig[nRegIdxHeightAdd], orig[nRegIdxTimeAdd], orig[nRegIdxDepoAmt], orig[nRegIdxDepoAmtLeft], newStatus, toString(lastBlock.height), toString(lastBlock.timestamp)], SEP)
167170 }
168171
169172
170173 func keyRewardHistory (nodeAddress,txId) = makeString(["%s%s%s", "history", toString(nodeAddress), toBase58String(txId)], SEP)
171174
172175
173176 func dataRewardHistory (wavesAmountTotal,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = makeString(["%d%d%d%d%d%d%d", toString(lastBlock.height), toString(lastBlock.timestamp), toString(wavesAmountTotal), toString(beneficiaryAmt), toString(protocolAmt), toString(protocolAmtPart1), toString(protocolAmtPart2)], SEP)
174177
175178
176179 func RewardHistoryEntry (nodeAddress,txId,minedAmt,beneficiaryAmt,protocolAmt,protocolAmt1,protocolAmt2) = StringEntry(keyRewardHistory(nodeAddress, txId), dataRewardHistory(minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2))
177180
178181
179182 func dataRewardTotals (minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = makeString(["%d%d%d%d%d", toString(minedAmt), toString(beneficiaryAmt), toString(protocolAmt), toString(protocolAmtPart1), toString(protocolAmtPart2)], SEP)
180183
181184
182185 func RewardTotalsEntry (miner,minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = {
183186 let nodeRewardsTotalsKEY = keyNodeRewardsTotals(toString(miner))
184187 let nodeRewardsArray = split(getStrOrElse(this, nodeRewardsTotalsKEY, dataRewardTotals(0, 0, 0, 0, 0)), SEP)
185188 let newMinedAmt = (parseIntValue(nodeRewardsArray[1]) + minedAmt)
186189 let newBeneficiaryAmt = (parseIntValue(nodeRewardsArray[2]) + beneficiaryAmt)
187190 let newProtocolAmt = (parseIntValue(nodeRewardsArray[3]) + protocolAmt)
188191 let newProtocolAmtPart1 = (parseIntValue(nodeRewardsArray[4]) + protocolAmtPart1)
189192 let newProtocolAmtPart2 = (parseIntValue(nodeRewardsArray[5]) + protocolAmtPart2)
190193 StringEntry(nodeRewardsTotalsKEY, dataRewardTotals(newMinedAmt, newBeneficiaryAmt, newProtocolAmt, newProtocolAmtPart1, newProtocolAmtPart2))
191194 }
192195
193196
194197 func resolveBeneficiaries (minerAddress,beneficiaryFromParam) = {
195198 let beneficiaryFromMinerState = addressFromStringValue(getStringOrFail(minerAddress, keyBeneficiaryAddress()))
196199 if ((scriptHash(minerAddress) == unit))
197200 then beneficiaryFromParam
198201 else beneficiaryFromMinerState
199202 }
200203
201204
202205 func readNodeDataAndValidateStatus (nodeAddr,expectedStatus) = {
203206 let nodeDataOpt = getString(keyNodeRegistry(nodeAddr))
204207 if (!(isDefined(nodeDataOpt)))
205208 then throw(("Unknown Node " + nodeAddr))
206209 else {
207210 let nodeDataStr = value(nodeDataOpt)
208211 let nodeData = split(nodeDataStr, SEP)
209212 let nodeStatus = if ((size(nodeData) >= 9))
210213 then nodeData[nRegIdxStatus]
211214 else "PENDING"
212215 if ((nodeStatus != expectedStatus))
213216 then throw(((((("Node " + nodeAddr) + " status should be ") + expectedStatus) + ", but actually ") + nodeStatus))
214217 else nodeDataStr
215218 }
216219 }
217220
218221
219222 @Callable(i)
220223 func constructorV1 (depositAmount,neutrinoAddressStr,masterNodeAddressStr,protocolPartX6,benificaryPartX6) = if ((i.caller != this))
221224 then throw("permissions denied")
222225 else if ((0 > depositAmount))
223226 then throw("depositAmount less then zero")
224227 else if ((0 > protocolPartX6))
225228 then throw("protocolPartX6 less then zero")
226229 else if ((0 > benificaryPartX6))
227230 then throw("benificaryPartX6 less then zero")
228231 else if (((protocolPartX6 + benificaryPartX6) != MULT6))
229232 then throw("parts sum must be 1")
230233 else [IntegerEntry(keyDepositAmount(), depositAmount), StringEntry(keyNeutrinoAddressStr(), validateAddressOrFail(neutrinoAddressStr)), StringEntry(keyMasterNodeAddressStr(), validateAddressOrFail(masterNodeAddressStr)), IntegerEntry(keyProtocolPartX6(), protocolPartX6), IntegerEntry(keyBenificaryPartX6(), benificaryPartX6)]
231234
232235
233236
234237 @Callable(i)
235238 func constructorV2 (swopfiAddressStr,controlAddressStr,savingsAddressStr) = if ((i.caller != this))
236239 then throw("permissions denied")
237240 else [StringEntry(keySwopfiUsdtUsdnPoolAddress(), validateAddressOrFail(swopfiAddressStr)), StringEntry(keyControlAddress(), validateAddressOrFail(controlAddressStr)), StringEntry(keySavingsAddress(), validateAddressOrFail(savingsAddressStr))]
238241
239242
240243
241244 @Callable(i)
242245 func sumbitApplication () = if ((size(i.payments) != 1))
243246 then throw("exact 1 payment must be attached")
244247 else if ((i.caller != i.originCaller))
245248 then throw("dapp to dapp calls are not allowed")
246249 else {
247250 let pmt = i.payments[0]
248251 let deposit = pmt.amount
249252 let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
250253 let expectedDepositAmount = getIntOrFail(keyDepositAmount())
251254 let txId = toBase58String(i.transactionId)
252255 let nodeAddress = toString(i.caller)
253256 let nodeRegistryKEY = keyNodeRegistry(nodeAddress)
254257 if ((pmtAssetId != WAVESID))
255258 then throw("only Waves can be used for deposit")
256259 else if ((deposit != expectedDepositAmount))
257260 then throw((("exactly " + toString(expectedDepositAmount)) + " Wavelets are expected"))
258261 else if ((getStrOrElse(this, nodeRegistryKEY, "") != ""))
259262 then throw("your node already registered")
260263 else [StringEntry(nodeRegistryKEY, formatDepositAdd(txId, deposit, deposit, "PENDING"))]
261264 }
262265
263266
264267
265268 @Callable(i)
266269 func distributeMinerReward (beneficiaryAddressStr) = {
267270 let minDistributeAmount = valueOrElse(getInteger(this, keyMinDistributeAmount()), (24 * MULT8))
268271 if ((size(i.payments) != 1))
269272 then throw("exact 1 payment must be attached")
270273 else if ((i.caller != i.originCaller))
271274 then throw("dapp to dapp calls are not allowed")
272275 else {
273276 let pmt = i.payments[0]
274277 let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
275278 let feeAmt = i.fee
276279 let feeAssetId = valueOrElse(i.feeAssetId, WAVESID)
277280 let callReward = (feeAmt * 3)
278281 let minedAmt = (pmt.amount - callReward)
279282 if ((pmt.amount != minDistributeAmount))
280283 then throw((("attached payment must be exact " + toString(minDistributeAmount)) + " Wavelets"))
281284 else if ((pmtAssetId != WAVESID))
282285 then throw("only Waves can be used in payment")
283286 else if ((feeAssetId != WAVESID))
284287 then throw("only Waves can be used in fees")
285288 else if ((feeAmt != ((5 * MULT8) / 1000)))
286289 then throw("fee amount couldn't exceed 0.005")
287290 else {
288291 let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
289292 let masterNodeAddress = getAddressOrFail(keyMasterNodeAddressStr())
290293 let minerAddress = i.caller
291294 let beneficiaryFromParam = addressFromStringValue(beneficiaryAddressStr)
292295 let beneficiaryAddress = resolveBeneficiaries(minerAddress, beneficiaryFromParam)
293296 let txRewardReceiver = beneficiaryFromParam
294297 let protocolPart = getIntOrFail(keyProtocolPartX6())
295298 let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
296299 let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
297300 let protocolAmt = (minedAmt - beneficiaryAmt)
298-[ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(neutrinoContract, protocolAmt, unit), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0)]
301+ let buyBackAmt = (120 * MULT8)
302+ let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
303+ let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [buyBackAmt], nil))
304+ let wxAssetIdStr = "Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on"
305+ let wxSwapAddress = addressFromStringValue(getStrOrElse(this, keyWxSwapAddress(), "3P68zNiufsu1viZpu1aY3cdahRRKcvV5N93"))
306+ let swapResult = invoke(wxSwapAddress, "swap", [1, wxAssetIdStr, toString(neutrinoContract)], [AttachedPayment(unit, buyBackAmt)])
307+ if ((swapResult == swapResult))
308+ then [ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(neutrinoContract, protocolAmt, unit), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt, 0)]
309+ else throw("Strict value is not equal to itself.")
299310 }
300311 }
301312 }
302313
303314
304315
305316 @Callable(i)
306317 func validateAndApproveLeasings (nListS) = {
307318 let nIdxs = [0, 1, 2, 3, 4, 5, 6, 7]
308319 let nList = split(nListS, SEP)
309320 let expectedCount = size(nIdxs)
310321 let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
311322 if ((i.caller != neutrinoAddress))
312323 then throw("validateAndApproveLeasings not authorized")
313324 else if (((size(nList) % 2) != 0))
314325 then throw("Only even number of nodes is allowed")
315326 else if ((size(nList) != expectedCount))
316327 then throw((("Only " + toString(expectedCount)) + " of nodes' addresses can be passed"))
317328 else {
318329 func forEachNodeChangeStatus (acc,i) = {
319330 let nodeAddr = nList[i]
320331 let nodeDataStr = readNodeDataAndValidateStatus(nodeAddr, "PENDING")
321332 (acc :+ StringEntry(keyNodeRegistry(nodeAddr), formatDepositChangeStatus(nodeDataStr, "APPROVED")))
322333 }
323334
324335 let approvedNodesData = {
325336 let $l = nIdxs
326337 let $s = size($l)
327338 let $acc0 = nil
328339 func $f0_1 ($a,$i) = if (($i >= $s))
329340 then $a
330341 else forEachNodeChangeStatus($a, $l[$i])
331342
332343 func $f0_2 ($a,$i) = if (($i >= $s))
333344 then $a
334345 else throw("List size exceeds 8")
335346
336347 $f0_2($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)
337348 }
338349 $Tuple2(approvedNodesData, nil)
339350 }
340351 }
341352
342353
343354
344355 @Callable(i)
345356 func replaceApprovedNode (oldNodeAddrStr,newNodeAddrStr,groupNum,penaltyAmount) = if ((i.caller != neutrinoContract))
346357 then throw("permissions denied")
347358 else {
348359 let oldDataStr = readNodeDataAndValidateStatus(oldNodeAddrStr, "APPROVED")
349360 let newDataStr = readNodeDataAndValidateStatus(newNodeAddrStr, "PENDING")
350361 let approvedNodeListS = getStringOrFail(this, keyApprovedNodeList())
351362 if (!(contains(approvedNodeListS, oldNodeAddrStr)))
352363 then throw(("approvedNodeList does not contain " + oldNodeAddrStr))
353364 else {
354365 let updatedNodeListS = makeString_2C(split_4C(approvedNodeListS, oldNodeAddrStr), newNodeAddrStr)
355366 let oldNodeAddr = addressFromStringValue(oldNodeAddrStr)
356367 let beneficiaryAddress = resolveBeneficiaries(oldNodeAddr, oldNodeAddr)
357368 let depoAmount = parseIntValue(split(oldDataStr, SEP)[nRegIdxDepoAmt])
358369 let actions = [StringEntry(keyApprovedNodeList(), updatedNodeListS), DeleteEntry(keyNodeRegistry(oldNodeAddrStr)), StringEntry(keyNodeRegistry(newNodeAddrStr), formatDepositChangeStatus(newDataStr, "APPROVED"))]
359370 $Tuple2(if ((depoAmount > penaltyAmount))
360371 then (actions :+ ScriptTransfer(beneficiaryAddress, (depoAmount - penaltyAmount), unit))
361372 else actions, unit)
362373 }
363374 }
364375
365376
366377
367378 @Callable(i)
368379 func returnDeposit (nodeAddressStr) = if ((size(i.payments) != 0))
369380 then throw("No payments allowed")
370381 else {
371382 let callerAddress = i.caller
372383 let nodeRegistryKEY = keyNodeRegistry(nodeAddressStr)
373384 let nodeDataOpt = getString(this, nodeRegistryKEY)
374385 if (!(isDefined(nodeDataOpt)))
375386 then throw(("Address is not applied as neutrino node: " + nodeAddressStr))
376387 else {
377388 let approvedNodeList = getStringOrFail(this, keyApprovedNodeList())
378389 if (contains(approvedNodeList, nodeAddressStr))
379390 then throw("Impossible to return deposit from approved Node, please contact support team")
380391 else {
381392 let nodeData = split(value(nodeDataOpt), SEP)
382393 let status = if ((size(nodeData) >= 9))
383394 then nodeData[nRegIdxStatus]
384395 else "PENDING"
385396 if ((status != "PENDING"))
386397 then throw("Application status is not PENDING!")
387398 else {
388399 let depoAmount = parseIntValue(nodeData[nRegIdxDepoAmt])
389400 let nodeAddress = addressFromStringValue(nodeAddressStr)
390401 let beneficiaryAddress = resolveBeneficiaries(nodeAddress, nodeAddress)
391402 if (!(if (if ((callerAddress == this))
392403 then true
393404 else if ((beneficiaryAddress != nodeAddress))
394405 then (callerAddress == beneficiaryAddress)
395406 else false)
396407 then true
397408 else if ((beneficiaryAddress == nodeAddress))
398409 then (callerAddress == nodeAddress)
399410 else false))
400411 then throw("returnDeposit permissions denied")
401412 else [DeleteEntry(nodeRegistryKEY), ScriptTransfer(beneficiaryAddress, depoAmount, unit)]
402413 }
403414 }
404415 }
405416 }
406417
407418

github/deemru/w8io/786bc32 
60.54 ms