2022.11.26 21:18 [3399892] smart account 3P9vKqQKjUdmpXAfiWau8krREYAY1Xr69pE > SELF 0.00000000 Waves

{ "type": 13, "id": "3ocZJgmuwaSFZvRUzDfVJGvfTAmTJnCi5NjrNKq5Maoe", "fee": 1900000, "feeAssetId": null, "timestamp": 1669490256681, "version": 1, "sender": "3P9vKqQKjUdmpXAfiWau8krREYAY1Xr69pE", "senderPublicKey": "7AUMX54ukYMYvPmma7yoFf5NjZhs4Bu5nz3Ez9EV8sur", "proofs": [ "2LVrDKfGbrBSzNYJicY5tQWvPY37vWYRhhp2u7CBPDx9m5vwV6um3sk9Z6Cen6f8FzR8j3E9NBwBvA5YCDGgFbWm" ], "script": "base64:BgIrCAISBwoFAQgIAQESBQoDCAgIEgASAwoBCBIDCgEIEgYKBAgIAQESAwoBCEEAA1NFUAICX18ABU1VTFQ2AMCEPQAFTVVMVDgAgMLXLwAKV0FWRVNJRFNUUgIFV0FWRVMAB1dBVkVTSUQJANkEAQUKV0FWRVNJRFNUUgEMZ2V0SW50T3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQR0aGlzBQNrZXkJAKwCAgkArAICAg9NYW5kYXRvcnkgdGhpcy4FA2tleQIPIGlzIG5vdCBkZWZpbmVkAQxnZXRTdHJPckVsc2UDB2FkZHJlc3MDa2V5CmRlZmF1bHRWYWwJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUHYWRkcmVzcwUDa2V5BQpkZWZhdWx0VmFsAQ9nZXRTdHJpbmdPckZhaWwCB2FkZHJlc3MDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUHYWRkcmVzcwUDa2V5CQCsAgIJAKwCAgIPTWFuZGF0b3J5IHRoaXMuBQNrZXkCDyBpcyBub3QgZGVmaW5lZAEQZ2V0QWRkcmVzc09yRmFpbAEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMFA2tleQkArAICCQCsAgICFUZhaWwgdG8gY29udmVydCB0aGlzLgUDa2V5AhMgdmFsdWUgaW50byBBZGRyZXNzAQlhc0FueUxpc3QBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACCUxpc3RbQW55XQQKdmFsQW55TGlzdAUHJG1hdGNoMAUKdmFsQW55TGlzdAkAAgECG2ZhaWwgdG8gY2FzdCBpbnRvIExpc3RbQW55XQEFYXNJbnQBAXYEByRtYXRjaDAFAXYDCQABAgUHJG1hdGNoMAIDSW50BAFpBQckbWF0Y2gwBQFpCQACAQIVZmFpbCB0byBjYXN0IGludG8gSW50AQthc0J5dGVWZWNvdAEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFpBQckbWF0Y2gwBQFpCQACAQIcZmFpbCB0byBjYXN0IGludG8gQnl0ZVZlY3RvcgEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQphZGRyZXNzU3RyBAdhZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUKYWRkcmVzc1N0cgkArAICAh1mYWlsIHRvIGNvbnZlcnQgaW50byBhZGRyZXNzIAUKYWRkcmVzc1N0cgMJAGYCAAAICQDvBwEFB2FkZHJlc3MJYXZhaWxhYmxlCQEFdGhyb3cABQphZGRyZXNzU3RyAQ9rZXlOb2RlUmVnaXN0cnkBB2FkZHJlc3MJAKwCAgIEJXNfXwUHYWRkcmVzcwEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBB2FkZHJlc3MJAKwCAgIOJXMlc19fdG90YWxzX18FB2FkZHJlc3MBE2tleUFwcHJvdmVkTm9kZUxpc3QAAhQlc19fYXBwcm92ZWROb2RlTGlzdAEQa2V5RGVwb3NpdEFtb3VudAACGCVzJXNfX2NmZ19fZGVwb3NpdEFtb3VudAEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAIaJXMlc19fY2ZnX19uZXV0cmlub0FkZHJlc3MBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAIiJXMlc19fY2ZnX19tYWluTmV1dHJpbm9Ob2RlQWRkcmVzcwERa2V5UHJvdG9jb2xQYXJ0WDYAAhklcyVzX19jZmdfX3Byb3RvY29sUGFydFg2ARNrZXlCZW5pZmljYXJ5UGFydFg2AAIbJXMlc19fY2ZnX19iZW5pZmljYXJ5UGFydFg2ARZrZXlNaW5EaXN0cmlidXRlQW1vdW50AAIeJXMlc19fY2ZnX19taW5EaXN0cmlidXRlQW1vdW50ARxrZXlTd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzAAIkJXMlc19fY2ZnX19zd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzARFrZXlTYXZpbmdzQWRkcmVzcwACGSVzJXNfX2NmZ19fc2F2aW5nc0FkZHJlc3MBFWtleUJlbmVmaWNpYXJ5QWRkcmVzcwACHSVzJXNfX2NmZ19fYmVuZWZpY2lhcnlBZGRyZXNzABlJZHhDb250cm9sQ2ZnTmV1dHJpbm9EYXBwAAEAGElkeENvbnRyb2xDZmdBdWN0aW9uRGFwcAACABRJZHhDb250cm9sQ2ZnUnBkRGFwcAADABVJZHhDb250cm9sQ2ZnTWF0aERhcHAABAAcSWR4Q29udHJvbENmZ0xpcXVpZGF0aW9uRGFwcAAFABVJZHhDb250cm9sQ2ZnUmVzdERhcHAABgAdSWR4Q29udHJvbENmZ05vZGVSZWdpc3RyeURhcHAABwAcSWR4Q29udHJvbENmZ05zYnRTdGFraW5nRGFwcAAIABlJZHhDb250cm9sQ2ZnTWVkaWF0b3JEYXBwAAkAHElkeENvbnRyb2xDZmdTdXJmU3Rha2luZ0RhcHAACgAgSWR4Q29udHJvbENmZ0duc2J0Q29udHJvbGxlckRhcHAACwAXSWR4Q29udHJvbENmZ1Jlc3RWMkRhcHAADAAbSWR4Q29udHJvbENmZ0dvdmVybmFuY2VEYXBwAA0BEWtleUNvbnRyb2xBZGRyZXNzAAIcJXMlc19fY29uZmlnX19jb250cm9sQWRkcmVzcwENa2V5Q29udHJvbENmZwACESVzX19jb250cm9sQ29uZmlnAQ5rZXlVc2RuQXNzZXRJZAACEW5ldXRyaW5vX2Fzc2V0X2lkARRyZWFkQ29udHJvbENmZ09yRmFpbAEHY29udHJvbAkAvAkCCQEPZ2V0U3RyaW5nT3JGYWlsAgUHY29udHJvbAkBDWtleUNvbnRyb2xDZmcABQNTRVABGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIKY29udHJvbENmZwNpZHgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFCmNvbnRyb2xDZmcFA2lkeAkArAICAi1Db250cm9sIGNmZyBkb2Vzbid0IGNvbnRhaW4gYWRkcmVzcyBhdCBpbmRleCAJAKQDAQUDaWR4AA9jb250cm9sQ29udHJhY3QJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkBEWtleUNvbnRyb2xBZGRyZXNzAAIjM1A1QmZkNThQUGZOdkJNMkh5OFFmYmNEcU1lTnR6ZzdLZlAACmNvbnRyb2xDZmcJARRyZWFkQ29udHJvbENmZ09yRmFpbAEFD2NvbnRyb2xDb250cmFjdAAQbmV1dHJpbm9Db250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFCmNvbnRyb2xDZmcFGUlkeENvbnRyb2xDZmdOZXV0cmlub0RhcHAADnVzZG5Bc3NldElkU3RyCQEMZ2V0U3RyT3JFbHNlAwUQbmV1dHJpbm9Db250cmFjdAkBDmtleVVzZG5Bc3NldElkAAIsREcyeEZrUGREd0tVb0JrekdBaFF0THBTR3pmWExpQ1lQRXplS0gyQWQyNHAAC3VzZG5Bc3NldElkCQDZBAEFDnVzZG5Bc3NldElkU3RyAAxuUmVnSWR4VHhBZGQAAQAQblJlZ0lkeEhlaWdodEFkZAACAA5uUmVnSWR4VGltZUFkZAADAA5uUmVnSWR4RGVwb0FtdAAEABJuUmVnSWR4RGVwb0FtdExlZnQABQANblJlZ0lkeFN0YXR1cwAGABluUmVnSWR4U3RhdHVzQ2hhbmdlSGVpZ2h0AAcAF25SZWdJZHhTdGF0dXNDaGFuZ2VUaW1lAAgBEGZvcm1hdERlcG9zaXRBZGQEB3R4SWRTdHINZGVwb3NpdEFtb3VudBZyZW1haW5pbmdEZXBvc2l0QW1vdW50BnN0YXR1cwkAuQkCCQDMCAICECVzJWQlZCVkJWQlcyVkJWQJAMwIAgUHdHhJZFN0cgkAzAgCCQCkAwEIBQlsYXN0QmxvY2sGaGVpZ2h0CQDMCAIJAKQDAQgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkApAMBBQ1kZXBvc2l0QW1vdW50CQDMCAIJAKQDAQUWcmVtYWluaW5nRGVwb3NpdEFtb3VudAkAzAgCBQZzdGF0dXMJAMwIAgIBMAkAzAgCAgEwBQNuaWwFA1NFUAEZZm9ybWF0RGVwb3NpdENoYW5nZVN0YXR1cwIFb3JpZ1MJbmV3U3RhdHVzBARvcmlnCQC1CQIFBW9yaWdTBQNTRVAJALkJAgkAzAgCAhAlcyVkJWQlZCVkJXMlZCVkCQDMCAIJAJEDAgUEb3JpZwUMblJlZ0lkeFR4QWRkCQDMCAIJAJEDAgUEb3JpZwUQblJlZ0lkeEhlaWdodEFkZAkAzAgCCQCRAwIFBG9yaWcFDm5SZWdJZHhUaW1lQWRkCQDMCAIJAJEDAgUEb3JpZwUOblJlZ0lkeERlcG9BbXQJAMwIAgkAkQMCBQRvcmlnBRJuUmVnSWR4RGVwb0FtdExlZnQJAMwIAgUJbmV3U3RhdHVzCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUDbmlsBQNTRVABEGtleVJld2FyZEhpc3RvcnkCC25vZGVBZGRyZXNzBHR4SWQJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIHaGlzdG9yeQkAzAgCCQClCAEFC25vZGVBZGRyZXNzCQDMCAIJANgEAQUEdHhJZAUDbmlsBQNTRVABEWRhdGFSZXdhcmRIaXN0b3J5BRB3YXZlc0Ftb3VudFRvdGFsDmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICDiVkJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQCkAwEFEHdhdmVzQW1vdW50VG90YWwJAMwIAgkApAMBBQ5iZW5lZmljaWFyeUFtdAkAzAgCCQCkAwEFC3Byb3RvY29sQW10CQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MQkAzAgCCQCkAwEFEHByb3RvY29sQW10UGFydDIFA25pbAUDU0VQARJSZXdhcmRIaXN0b3J5RW50cnkHC25vZGVBZGRyZXNzBHR4SWQIbWluZWRBbXQOYmVuZWZpY2lhcnlBbXQLcHJvdG9jb2xBbXQMcHJvdG9jb2xBbXQxDHByb3RvY29sQW10MgkBC1N0cmluZ0VudHJ5AgkBEGtleVJld2FyZEhpc3RvcnkCBQtub2RlQWRkcmVzcwUEdHhJZAkBEWRhdGFSZXdhcmRIaXN0b3J5BQUIbWluZWRBbXQFDmJlbmVmaWNpYXJ5QW10BQtwcm90b2NvbEFtdAUMcHJvdG9jb2xBbXQxBQxwcm90b2NvbEFtdDIBEGRhdGFSZXdhcmRUb3RhbHMFCG1pbmVkQW10DmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICCiVkJWQlZCVkJWQJAMwIAgkApAMBBQhtaW5lZEFtdAkAzAgCCQCkAwEFDmJlbmVmaWNpYXJ5QW10CQDMCAIJAKQDAQULcHJvdG9jb2xBbXQJAMwIAgkApAMBBRBwcm90b2NvbEFtdFBhcnQxCQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MgUDbmlsBQNTRVABEVJld2FyZFRvdGFsc0VudHJ5BgVtaW5lcghtaW5lZEFtdA5iZW5lZmljaWFyeUFtdAtwcm90b2NvbEFtdBBwcm90b2NvbEFtdFBhcnQxEHByb3RvY29sQW10UGFydDIEFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBCQClCAEFBW1pbmVyBBBub2RlUmV3YXJkc0FycmF5CQC1CQIJAQxnZXRTdHJPckVsc2UDBQR0aGlzBRRub2RlUmV3YXJkc1RvdGFsc0tFWQkBEGRhdGFSZXdhcmRUb3RhbHMFAAAAAAAAAAAAAAUDU0VQBAtuZXdNaW5lZEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAEFCG1pbmVkQW10BBFuZXdCZW5lZmljaWFyeUFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAIFDmJlbmVmaWNpYXJ5QW10BA5uZXdQcm90b2NvbEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAMFC3Byb3RvY29sQW10BBNuZXdQcm90b2NvbEFtdFBhcnQxCQBkAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFEG5vZGVSZXdhcmRzQXJyYXkABAUQcHJvdG9jb2xBbXRQYXJ0MQQTbmV3UHJvdG9jb2xBbXRQYXJ0MgkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAUFEHByb3RvY29sQW10UGFydDIJAQtTdHJpbmdFbnRyeQIFFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEQZGF0YVJld2FyZFRvdGFscwUFC25ld01pbmVkQW10BRFuZXdCZW5lZmljaWFyeUFtdAUObmV3UHJvdG9jb2xBbXQFE25ld1Byb3RvY29sQW10UGFydDEFE25ld1Byb3RvY29sQW10UGFydDIBFHJlc29sdmVCZW5lZmljaWFyaWVzAgxtaW5lckFkZHJlc3MUYmVuZWZpY2lhcnlGcm9tUGFyYW0ED21pbmVyU2NyaXB0SGFzaAkA8QcBBQxtaW5lckFkZHJlc3MEGWJlbmVmaWNpYXJ5RnJvbU1pbmVyU3RhdGUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQ9nZXRTdHJpbmdPckZhaWwCBQxtaW5lckFkZHJlc3MJARVrZXlCZW5lZmljaWFyeUFkZHJlc3MAAwkAAAIFD21pbmVyU2NyaXB0SGFzaAUEdW5pdAUUYmVuZWZpY2lhcnlGcm9tUGFyYW0FGWJlbmVmaWNpYXJ5RnJvbU1pbmVyU3RhdGUBHXJlYWROb2RlRGF0YUFuZFZhbGlkYXRlU3RhdHVzAghub2RlQWRkcg5leHBlY3RlZFN0YXR1cwQLbm9kZURhdGFPcHQJAKIIAQkBD2tleU5vZGVSZWdpc3RyeQEFCG5vZGVBZGRyAwkBASEBCQEJaXNEZWZpbmVkAQULbm9kZURhdGFPcHQJAAIBCQCsAgICDVVua25vd24gTm9kZSAFCG5vZGVBZGRyBAtub2RlRGF0YVN0cgkBBXZhbHVlAQULbm9kZURhdGFPcHQECG5vZGVEYXRhCQC1CQIFC25vZGVEYXRhU3RyBQNTRVAECm5vZGVTdGF0dXMDCQBnAgkAkAMBBQhub2RlRGF0YQAJCQCRAwIFCG5vZGVEYXRhBQ1uUmVnSWR4U3RhdHVzAgdQRU5ESU5HAwkBAiE9AgUKbm9kZVN0YXR1cwUOZXhwZWN0ZWRTdGF0dXMJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIFTm9kZSAFCG5vZGVBZGRyAhIgc3RhdHVzIHNob3VsZCBiZSAFDmV4cGVjdGVkU3RhdHVzAg8sIGJ1dCBhY3R1YWxseSAFCm5vZGVTdGF0dXMFC25vZGVEYXRhU3RyBwFpAQtjb25zdHJ1Y3RvcgUNZGVwb3NpdEFtb3VudBJuZXV0cmlub0FkZHJlc3NTdHIUbWFzdGVyTm9kZUFkZHJlc3NTdHIOcHJvdG9jb2xQYXJ0WDYQYmVuaWZpY2FyeVBhcnRYNgMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECEnBlcm1pc3Npb25zIGRlbmllZAMJAGYCAAAFDWRlcG9zaXRBbW91bnQJAAIBAhxkZXBvc2l0QW1vdW50IGxlc3MgdGhlbiB6ZXJvAwkAZgIAAAUOcHJvdG9jb2xQYXJ0WDYJAAIBAh1wcm90b2NvbFBhcnRYNiBsZXNzIHRoZW4gemVybwMJAGYCAAAFEGJlbmlmaWNhcnlQYXJ0WDYJAAIBAh9iZW5pZmljYXJ5UGFydFg2IGxlc3MgdGhlbiB6ZXJvAwkBAiE9AgkAZAIFDnByb3RvY29sUGFydFg2BRBiZW5pZmljYXJ5UGFydFg2BQVNVUxUNgkAAgECE3BhcnRzIHN1bSBtdXN0IGJlIDEJAMwIAgkBDEludGVnZXJFbnRyeQIJARBrZXlEZXBvc2l0QW1vdW50AAUNZGVwb3NpdEFtb3VudAkAzAgCCQELU3RyaW5nRW50cnkCCQEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAkBFXZhbGlkYXRlQWRkcmVzc09yRmFpbAEFEm5ldXRyaW5vQWRkcmVzc1N0cgkAzAgCCQELU3RyaW5nRW50cnkCCQEXa2V5TWFzdGVyTm9kZUFkZHJlc3NTdHIACQEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQUUbWFzdGVyTm9kZUFkZHJlc3NTdHIJAMwIAgkBDEludGVnZXJFbnRyeQIJARFrZXlQcm90b2NvbFBhcnRYNgAFDnByb3RvY29sUGFydFg2CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQETa2V5QmVuaWZpY2FyeVBhcnRYNgAFEGJlbmlmaWNhcnlQYXJ0WDYFA25pbAFpAQ1jb25zdHJ1Y3RvclYyAxBzd29wZmlBZGRyZXNzU3RyEWNvbnRyb2xBZGRyZXNzU3RyEXNhdmluZ3NBZGRyZXNzU3RyAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIScGVybWlzc2lvbnMgZGVuaWVkCQDMCAIJAQtTdHJpbmdFbnRyeQIJARxrZXlTd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzAAkBFXZhbGlkYXRlQWRkcmVzc09yRmFpbAEFEHN3b3BmaUFkZHJlc3NTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEWtleUNvbnRyb2xBZGRyZXNzAAkBFXZhbGlkYXRlQWRkcmVzc09yRmFpbAEFEWNvbnRyb2xBZGRyZXNzU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQIJARFrZXlTYXZpbmdzQWRkcmVzcwAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRFzYXZpbmdzQWRkcmVzc1N0cgUDbmlsAWkBEXN1bWJpdEFwcGxpY2F0aW9uAAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECIGV4YWN0IDEgcGF5bWVudCBtdXN0IGJlIGF0dGFjaGVkAwkBAiE9AggFAWkGY2FsbGVyCAUBaQxvcmlnaW5DYWxsZXIJAAIBAiJkYXBwIHRvIGRhcHAgY2FsbHMgYXJlIG5vdCBhbGxvd2VkBANwbXQJAJEDAggFAWkIcGF5bWVudHMAAAQHZGVwb3NpdAgFA3BtdAZhbW91bnQECnBtdEFzc2V0SWQJAQt2YWx1ZU9yRWxzZQIIBQNwbXQHYXNzZXRJZAUHV0FWRVNJRAQVZXhwZWN0ZWREZXBvc2l0QW1vdW50CQEMZ2V0SW50T3JGYWlsAQkBEGtleURlcG9zaXRBbW91bnQABAR0eElkCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQEC25vZGVBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgQPbm9kZVJlZ2lzdHJ5S0VZCQEPa2V5Tm9kZVJlZ2lzdHJ5AQULbm9kZUFkZHJlc3MDCQECIT0CBQpwbXRBc3NldElkBQdXQVZFU0lECQACAQIib25seSBXYXZlcyBjYW4gYmUgdXNlZCBmb3IgZGVwb3NpdAMJAQIhPQIFB2RlcG9zaXQFFWV4cGVjdGVkRGVwb3NpdEFtb3VudAkAAgEJAKwCAgkArAICAghleGFjdGx5IAkApAMBBRVleHBlY3RlZERlcG9zaXRBbW91bnQCFiBXYXZlbGV0cyBhcmUgZXhwZWN0ZWQDCQECIT0CCQEMZ2V0U3RyT3JFbHNlAwUEdGhpcwUPbm9kZVJlZ2lzdHJ5S0VZAgACAAkAAgECHHlvdXIgbm9kZSBhbHJlYWR5IHJlZ2lzdGVyZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUPbm9kZVJlZ2lzdHJ5S0VZCQEQZm9ybWF0RGVwb3NpdEFkZAQFBHR4SWQFB2RlcG9zaXQFB2RlcG9zaXQCB1BFTkRJTkcFA25pbAFpARVkaXN0cmlidXRlTWluZXJSZXdhcmQBFWJlbmVmaWNpYXJ5QWRkcmVzc1N0cgQTbWluRGlzdHJpYnV0ZUFtb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEWa2V5TWluRGlzdHJpYnV0ZUFtb3VudAAJAGgCABgFBU1VTFQ4AwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIgZXhhY3QgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQDCQECIT0CCAUBaQZjYWxsZXIIBQFpDG9yaWdpbkNhbGxlcgkAAgECImRhcHAgdG8gZGFwcCBjYWxscyBhcmUgbm90IGFsbG93ZWQEA3BtdAkAkQMCCAUBaQhwYXltZW50cwAABApwbXRBc3NldElkCQELdmFsdWVPckVsc2UCCAUDcG10B2Fzc2V0SWQFB1dBVkVTSUQEBmZlZUFtdAgFAWkDZmVlBApmZWVBc3NldElkCQELdmFsdWVPckVsc2UCCAUBaQpmZWVBc3NldElkBQdXQVZFU0lEBApjYWxsUmV3YXJkCQBoAgUGZmVlQW10AAMECG1pbmVkQW10CQBlAggFA3BtdAZhbW91bnQFCmNhbGxSZXdhcmQDCQECIT0CCAUDcG10BmFtb3VudAUTbWluRGlzdHJpYnV0ZUFtb3VudAkAAgEJAKwCAgkArAICAh9hdHRhY2hlZCBwYXltZW50IG11c3QgYmUgZXhhY3QgCQCkAwEFE21pbkRpc3RyaWJ1dGVBbW91bnQCCSBXYXZlbGV0cwMJAQIhPQIFCnBtdEFzc2V0SWQFB1dBVkVTSUQJAAIBAiFvbmx5IFdhdmVzIGNhbiBiZSB1c2VkIGluIHBheW1lbnQDCQECIT0CBQpmZWVBc3NldElkBQdXQVZFU0lECQACAQIeb25seSBXYXZlcyBjYW4gYmUgdXNlZCBpbiBmZWVzAwkBAiE9AgUGZmVlQW10CQBpAgkAaAIABQUFTVVMVDgA6AcJAAIBAiBmZWUgYW1vdW50IGNvdWxkbid0IGV4Y2VlZCAwLjAwNQQPbmV1dHJpbm9BZGRyZXNzCQEQZ2V0QWRkcmVzc09yRmFpbAEJARVrZXlOZXV0cmlub0FkZHJlc3NTdHIABBFtYXN0ZXJOb2RlQWRkcmVzcwkBEGdldEFkZHJlc3NPckZhaWwBCQEXa2V5TWFzdGVyTm9kZUFkZHJlc3NTdHIABAxtaW5lckFkZHJlc3MIBQFpBmNhbGxlcgQUYmVuZWZpY2lhcnlGcm9tUGFyYW0JARFAZXh0ck5hdGl2ZSgxMDYyKQEFFWJlbmVmaWNpYXJ5QWRkcmVzc1N0cgQSYmVuZWZpY2lhcnlBZGRyZXNzCQEUcmVzb2x2ZUJlbmVmaWNpYXJpZXMCBQxtaW5lckFkZHJlc3MFFGJlbmVmaWNpYXJ5RnJvbVBhcmFtBBB0eFJld2FyZFJlY2VpdmVyBRRiZW5lZmljaWFyeUZyb21QYXJhbQQMcHJvdG9jb2xQYXJ0CQEMZ2V0SW50T3JGYWlsAQkBEWtleVByb3RvY29sUGFydFg2AAQPYmVuZWZpY2lhcnlQYXJ0CQEMZ2V0SW50T3JGYWlsAQkBE2tleUJlbmlmaWNhcnlQYXJ0WDYABA5iZW5lZmljaWFyeUFtdAkAawMFCG1pbmVkQW10BQ9iZW5lZmljaWFyeVBhcnQFBU1VTFQ2BAtwcm90b2NvbEFtdAkAZQIFCG1pbmVkQW10BQ5iZW5lZmljaWFyeUFtdAQMcHJvdG9jb2xBbXQxAAAEDHByb3RvY29sQW10MgkAZQIFC3Byb3RvY29sQW10BQxwcm90b2NvbEFtdDEEDnNhdmluZ3NBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBCQEMZ2V0U3RyT3JFbHNlAwUEdGhpcwkBEWtleVNhdmluZ3NBZGRyZXNzAAIjM1BDN0RCaW1hdXlLeXR4OHRYaEtvNXUyRUNiNkZzbmRZS0gECnNhdmluZ3NBbXQJAQVhc0ludAEJAPwHBAUOc2F2aW5nc0FkZHJlc3MCCHdpdGhkcmF3CQDMCAIFDHByb3RvY29sQW10MgUDbmlsBQNuaWwEDXN3b3BmaUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQxnZXRTdHJPckVsc2UDBQR0aGlzCQEca2V5U3dvcGZpVXNkdFVzZG5Qb29sQWRkcmVzcwACIzNQSGFOZ29tQmtydkVMMlFudUphclFWSmE3MXdqdzlxaXFHBAxzd29wZmlSZXN1bHQJAQlhc0FueUxpc3QBCQD8BwQFDXN3b3BmaUFkZHJlc3MCCGV4Y2hhbmdlCQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQR1bml0CQBkAgUMcHJvdG9jb2xBbXQyBQpzYXZpbmdzQW10BQNuaWwED3JlY2VpdmVkVXNkbkFtdAkBBWFzSW50AQkAkQMCBQxzd29wZmlSZXN1bHQAAAQPcmVjZWl2ZWRBc3NldElkCQELYXNCeXRlVmVjb3QBCQCRAwIFDHN3b3BmaVJlc3VsdAABAwkBAiE9AgULdXNkbkFzc2V0SWQFD3JlY2VpdmVkQXNzZXRJZAkAAgECMGludmFsaWQgYXNzZXQgaWQgcmVjZWl2ZWQgZHVyaW5nIHN3b3BmaSBleGNoYW5nZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRJiZW5lZmljaWFyeUFkZHJlc3MFDmJlbmVmaWNpYXJ5QW10BQR1bml0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFEW1hc3Rlck5vZGVBZGRyZXNzBQ9yZWNlaXZlZFVzZG5BbXQFC3VzZG5Bc3NldElkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFEHR4UmV3YXJkUmVjZWl2ZXIFCmNhbGxSZXdhcmQFBHVuaXQJAMwIAgkBElJld2FyZEhpc3RvcnlFbnRyeQcFDG1pbmVyQWRkcmVzcwgFAWkNdHJhbnNhY3Rpb25JZAUIbWluZWRBbXQFDmJlbmVmaWNpYXJ5QW10BQtwcm90b2NvbEFtdAUMcHJvdG9jb2xBbXQxBQxwcm90b2NvbEFtdDIJAMwIAgkBEVJld2FyZFRvdGFsc0VudHJ5BgUMbWluZXJBZGRyZXNzBQhtaW5lZEFtdAUOYmVuZWZpY2lhcnlBbXQFC3Byb3RvY29sQW10BQxwcm90b2NvbEFtdDEFDHByb3RvY29sQW10MgUDbmlsAWkBGnZhbGlkYXRlQW5kQXBwcm92ZUxlYXNpbmdzAQZuTGlzdFMEBW5JZHhzCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcFA25pbAQFbkxpc3QJALUJAgUGbkxpc3RTBQNTRVAEDWV4cGVjdGVkQ291bnQJAJADAQUFbklkeHMED25ldXRyaW5vQWRkcmVzcwkBEGdldEFkZHJlc3NPckZhaWwBCQEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAMJAQIhPQIIBQFpBmNhbGxlcgUPbmV1dHJpbm9BZGRyZXNzCQACAQIpdmFsaWRhdGVBbmRBcHByb3ZlTGVhc2luZ3Mgbm90IGF1dGhvcml6ZWQDCQECIT0CCQBqAgkAkAMBBQVuTGlzdAACAAAJAAIBAiRPbmx5IGV2ZW4gbnVtYmVyIG9mIG5vZGVzIGlzIGFsbG93ZWQDCQECIT0CCQCQAwEFBW5MaXN0BQ1leHBlY3RlZENvdW50CQACAQkArAICCQCsAgICBU9ubHkgCQCkAwEFDWV4cGVjdGVkQ291bnQCIiBvZiBub2RlcycgYWRkcmVzc2VzIGNhbiBiZSBwYXNzZWQKARdmb3JFYWNoTm9kZUNoYW5nZVN0YXR1cwIDYWNjAWkECG5vZGVBZGRyCQCRAwIFBW5MaXN0BQFpBAtub2RlRGF0YVN0cgkBHXJlYWROb2RlRGF0YUFuZFZhbGlkYXRlU3RhdHVzAgUIbm9kZUFkZHICB1BFTkRJTkcJAM0IAgUDYWNjCQELU3RyaW5nRW50cnkCCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUIbm9kZUFkZHIJARlmb3JtYXREZXBvc2l0Q2hhbmdlU3RhdHVzAgULbm9kZURhdGFTdHICCEFQUFJPVkVEBBFhcHByb3ZlZE5vZGVzRGF0YQoAAiRsBQVuSWR4cwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEXZm9yRWFjaE5vZGVDaGFuZ2VTdGF0dXMCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDgJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAICQCUCgIFEWFwcHJvdmVkTm9kZXNEYXRhBQNuaWwBaQETcmVwbGFjZUFwcHJvdmVkTm9kZQQOb2xkTm9kZUFkZHJTdHIObmV3Tm9kZUFkZHJTdHIIZ3JvdXBOdW0NcGVuYWx0eUFtb3VudAMJAQIhPQIIBQFpBmNhbGxlcgUQbmV1dHJpbm9Db250cmFjdAkAAgECEnBlcm1pc3Npb25zIGRlbmllZAQKb2xkRGF0YVN0cgkBHXJlYWROb2RlRGF0YUFuZFZhbGlkYXRlU3RhdHVzAgUOb2xkTm9kZUFkZHJTdHICCEFQUFJPVkVEBApuZXdEYXRhU3RyCQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCBQ5uZXdOb2RlQWRkclN0cgIHUEVORElORwQRYXBwcm92ZWROb2RlTGlzdFMJAQ9nZXRTdHJpbmdPckZhaWwCBQR0aGlzCQETa2V5QXBwcm92ZWROb2RlTGlzdAADCQEBIQEJAQhjb250YWlucwIFEWFwcHJvdmVkTm9kZUxpc3RTBQ5vbGROb2RlQWRkclN0cgkAAgEJAKwCAgIiYXBwcm92ZWROb2RlTGlzdCBkb2VzIG5vdCBjb250YWluIAUOb2xkTm9kZUFkZHJTdHIEEHVwZGF0ZWROb2RlTGlzdFMJALkJAgkAtQkCBRFhcHByb3ZlZE5vZGVMaXN0UwUOb2xkTm9kZUFkZHJTdHIFDm5ld05vZGVBZGRyU3RyBAtvbGROb2RlQWRkcgkBEUBleHRyTmF0aXZlKDEwNjIpAQUOb2xkTm9kZUFkZHJTdHIEEmJlbmVmaWNpYXJ5QWRkcmVzcwkBFHJlc29sdmVCZW5lZmljaWFyaWVzAgULb2xkTm9kZUFkZHIFC29sZE5vZGVBZGRyBApkZXBvQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgkAtQkCBQpvbGREYXRhU3RyBQNTRVAFDm5SZWdJZHhEZXBvQW10BAdhY3Rpb25zCQDMCAIJAQtTdHJpbmdFbnRyeQIJARNrZXlBcHByb3ZlZE5vZGVMaXN0AAUQdXBkYXRlZE5vZGVMaXN0UwkAzAgCCQELRGVsZXRlRW50cnkBCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUOb2xkTm9kZUFkZHJTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBD2tleU5vZGVSZWdpc3RyeQEFDm5ld05vZGVBZGRyU3RyCQEZZm9ybWF0RGVwb3NpdENoYW5nZVN0YXR1cwIFCm5ld0RhdGFTdHICCEFQUFJPVkVEBQNuaWwJAJQKAgMJAGYCBQpkZXBvQW1vdW50BQ1wZW5hbHR5QW1vdW50CQDNCAIFB2FjdGlvbnMJAQ5TY3JpcHRUcmFuc2ZlcgMFEmJlbmVmaWNpYXJ5QWRkcmVzcwkAZQIFCmRlcG9BbW91bnQFDXBlbmFsdHlBbW91bnQFBHVuaXQFB2FjdGlvbnMFBHVuaXQBaQENcmV0dXJuRGVwb3NpdAEObm9kZUFkZHJlc3NTdHIDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAAJAAIBAhNObyBwYXltZW50cyBhbGxvd2VkBA1jYWxsZXJBZGRyZXNzCAUBaQZjYWxsZXIEC25vZGVBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBBQ5ub2RlQWRkcmVzc1N0cgQQYXBwcm92ZWROb2RlTGlzdAkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMJARNrZXlBcHByb3ZlZE5vZGVMaXN0AAMDCQECIT0CBQ1jYWxsZXJBZGRyZXNzBQR0aGlzCQECIT0CBQtub2RlQWRkcmVzcwUNY2FsbGVyQWRkcmVzcwcJAAIBAiByZXR1cm5EZXBvc2l0IHBlcm1pc3Npb25zIGRlbmllZAQPbm9kZVJlZ2lzdHJ5S0VZCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUObm9kZUFkZHJlc3NTdHIEC25vZGVEYXRhT3B0CQCdCAIFBHRoaXMFD25vZGVSZWdpc3RyeUtFWQMJAQEhAQkBCWlzRGVmaW5lZAEFC25vZGVEYXRhT3B0CQACAQkArAICAilBZGRyZXNzIGlzIG5vdCBhcHBsaWVkIGFzIG5ldXRyaW5vIG5vZGU6IAUObm9kZUFkZHJlc3NTdHIDCQEIY29udGFpbnMCBRBhcHByb3ZlZE5vZGVMaXN0BQ5ub2RlQWRkcmVzc1N0cgkAAgECTEltcG9zc2libGUgdG8gcmV0dXJuIGRlcG9zaXQgZnJvbSBhcHByb3ZlZCBOb2RlLCBwbGVhc2UgY29udGFjdCBzdXBwb3J0IHRlYW0ECG5vZGVEYXRhCQC1CQIJAQV2YWx1ZQEFC25vZGVEYXRhT3B0BQNTRVAEBnN0YXR1cwMJAGcCCQCQAwEFCG5vZGVEYXRhAAkJAJEDAgUIbm9kZURhdGEFDW5SZWdJZHhTdGF0dXMCB1BFTkRJTkcDCQECIT0CBQZzdGF0dXMCB1BFTkRJTkcJAAIBAiJBcHBsaWNhdGlvbiBzdGF0dXMgaXMgbm90IFBFTkRJTkchBApkZXBvQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIbm9kZURhdGEFDm5SZWdJZHhEZXBvQW10BBJiZW5lZmljaWFyeUFkZHJlc3MJARRyZXNvbHZlQmVuZWZpY2lhcmllcwIFC25vZGVBZGRyZXNzBQtub2RlQWRkcmVzcwkAzAgCCQELRGVsZXRlRW50cnkBBQ9ub2RlUmVnaXN0cnlLRVkJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUSYmVuZWZpY2lhcnlBZGRyZXNzBQpkZXBvQW1vdW50BQR1bml0BQNuaWwAZ6zrLQ==", "chainId": 87, "height": 3399892, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: EQe6z3Jxsh647gZt6doxoaH7as3Xz7ewKY5dTGLXj7En Next: AFKYtf6JWndJfUUdya7Sr2bLHfXiJfdQZAUH2vinafnR Diff:
OldNewDifferences
2323 func getAddressOrFail (key) = valueOrErrorMessage(addressFromString(getStringOrFail(this, key)), (("Fail to convert this." + key) + " value into Address"))
2424
2525
26-func asSwopfiResultSTRUCT (v) = match v {
27- case struct: (Int, ByteVector) =>
28- struct
26+func asAnyList (val) = match val {
27+ case valAnyList: List[Any] =>
28+ valAnyList
2929 case _ =>
30- throw("fail to cast into Tuple5 ints")
30+ throw("fail to cast into List[Any]")
3131 }
3232
3333
3636 i
3737 case _ =>
3838 throw("fail to cast into Int")
39+}
40+
41+
42+func asByteVecot (v) = match v {
43+ case i: ByteVector =>
44+ i
45+ case _ =>
46+ throw("fail to cast into ByteVector")
3947 }
4048
4149
256264
257265
258266 @Callable(i)
259-func distributeMinerReward (beneficiaryAddressStr) = if ((1 == 1))
260- then throw("temporary disable")
261- else {
262- let minDistributeAmount = valueOrElse(getInteger(this, keyMinDistributeAmount()), (24 * MULT8))
263- if ((size(i.payments) != 1))
264- then throw("exact 1 payment must be attached")
265- else if ((i.caller != i.originCaller))
266- then throw("dapp to dapp calls are not allowed")
267- else {
268- let pmt = i.payments[0]
269- let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
270- let feeAmt = i.fee
271- let feeAssetId = valueOrElse(i.feeAssetId, WAVESID)
272- let callReward = (feeAmt * 3)
273- let minedAmt = (pmt.amount - callReward)
274- if ((pmt.amount != minDistributeAmount))
275- then throw((("attached payment must be exact " + toString(minDistributeAmount)) + " Wavelets"))
276- else if ((pmtAssetId != WAVESID))
277- then throw("only Waves can be used in payment")
278- else if ((feeAssetId != WAVESID))
279- then throw("only Waves can be used in fees")
280- else if ((feeAmt != ((5 * MULT8) / 1000)))
281- then throw("fee amount couldn't exceed 0.005")
282- else {
283- let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
284- let masterNodeAddress = getAddressOrFail(keyMasterNodeAddressStr())
285- let minerAddress = i.caller
286- let beneficiaryFromParam = addressFromStringValue(beneficiaryAddressStr)
287- let beneficiaryAddress = resolveBeneficiaries(minerAddress, beneficiaryFromParam)
288- let txRewardReceiver = beneficiaryFromParam
289- let protocolPart = getIntOrFail(keyProtocolPartX6())
290- let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
291- let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
292- let protocolAmt = (minedAmt - beneficiaryAmt)
293- let protocolAmt1 = 0
294- let protocolAmt2 = (protocolAmt - protocolAmt1)
295- let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
296- let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [protocolAmt2], nil))
297- let swopfiAddress = addressFromStringValue(getStrOrElse(this, keySwopfiUsdtUsdnPoolAddress(), "3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG"))
298- let swopfiResult = asSwopfiResultSTRUCT(invoke(swopfiAddress, "exchange", [1], [AttachedPayment(unit, (protocolAmt2 + savingsAmt))]))
299- let receivedUsdnAmt = swopfiResult._1
300- let receivedAssetId = swopfiResult._2
301- if ((usdnAssetId != receivedAssetId))
302- then throw("invalid asset id received during swopfi exchange")
303- else [ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(masterNodeAddress, receivedUsdnAmt, usdnAssetId), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2)]
304- }
305- }
306- }
267+func distributeMinerReward (beneficiaryAddressStr) = {
268+ let minDistributeAmount = valueOrElse(getInteger(this, keyMinDistributeAmount()), (24 * MULT8))
269+ if ((size(i.payments) != 1))
270+ then throw("exact 1 payment must be attached")
271+ else if ((i.caller != i.originCaller))
272+ then throw("dapp to dapp calls are not allowed")
273+ else {
274+ let pmt = i.payments[0]
275+ let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
276+ let feeAmt = i.fee
277+ let feeAssetId = valueOrElse(i.feeAssetId, WAVESID)
278+ let callReward = (feeAmt * 3)
279+ let minedAmt = (pmt.amount - callReward)
280+ if ((pmt.amount != minDistributeAmount))
281+ then throw((("attached payment must be exact " + toString(minDistributeAmount)) + " Wavelets"))
282+ else if ((pmtAssetId != WAVESID))
283+ then throw("only Waves can be used in payment")
284+ else if ((feeAssetId != WAVESID))
285+ then throw("only Waves can be used in fees")
286+ else if ((feeAmt != ((5 * MULT8) / 1000)))
287+ then throw("fee amount couldn't exceed 0.005")
288+ else {
289+ let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
290+ let masterNodeAddress = getAddressOrFail(keyMasterNodeAddressStr())
291+ let minerAddress = i.caller
292+ let beneficiaryFromParam = addressFromStringValue(beneficiaryAddressStr)
293+ let beneficiaryAddress = resolveBeneficiaries(minerAddress, beneficiaryFromParam)
294+ let txRewardReceiver = beneficiaryFromParam
295+ let protocolPart = getIntOrFail(keyProtocolPartX6())
296+ let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
297+ let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
298+ let protocolAmt = (minedAmt - beneficiaryAmt)
299+ let protocolAmt1 = 0
300+ let protocolAmt2 = (protocolAmt - protocolAmt1)
301+ let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
302+ let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [protocolAmt2], nil))
303+ let swopfiAddress = addressFromStringValue(getStrOrElse(this, keySwopfiUsdtUsdnPoolAddress(), "3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG"))
304+ let swopfiResult = asAnyList(invoke(swopfiAddress, "exchange", [1], [AttachedPayment(unit, (protocolAmt2 + savingsAmt))]))
305+ let receivedUsdnAmt = asInt(swopfiResult[0])
306+ let receivedAssetId = asByteVecot(swopfiResult[1])
307+ if ((usdnAssetId != receivedAssetId))
308+ then throw("invalid asset id received during swopfi exchange")
309+ else [ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(masterNodeAddress, receivedUsdnAmt, usdnAssetId), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2)]
310+ }
311+ }
312+ }
307313
308314
309315
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
26-func asSwopfiResultSTRUCT (v) = match v {
27- case struct: (Int, ByteVector) =>
28- struct
26+func asAnyList (val) = match val {
27+ case valAnyList: List[Any] =>
28+ valAnyList
2929 case _ =>
30- throw("fail to cast into Tuple5 ints")
30+ 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")
39+}
40+
41+
42+func asByteVecot (v) = match v {
43+ case i: ByteVector =>
44+ i
45+ case _ =>
46+ throw("fail to cast into ByteVector")
3947 }
4048
4149
4250 func validateAddressOrFail (addressStr) = {
4351 let address = valueOrErrorMessage(addressFromString(addressStr), ("fail to convert into address " + addressStr))
4452 if ((0 > wavesBalance(address).available))
4553 then throw()
4654 else addressStr
4755 }
4856
4957
5058 func keyNodeRegistry (address) = ("%s__" + address)
5159
5260
5361 func keyNodeRewardsTotals (address) = ("%s%s__totals__" + address)
5462
5563
5664 func keyApprovedNodeList () = "%s__approvedNodeList"
5765
5866
5967 func keyDepositAmount () = "%s%s__cfg__depositAmount"
6068
6169
6270 func keyNeutrinoAddressStr () = "%s%s__cfg__neutrinoAddress"
6371
6472
6573 func keyMasterNodeAddressStr () = "%s%s__cfg__mainNeutrinoNodeAddress"
6674
6775
6876 func keyProtocolPartX6 () = "%s%s__cfg__protocolPartX6"
6977
7078
7179 func keyBenificaryPartX6 () = "%s%s__cfg__benificaryPartX6"
7280
7381
7482 func keyMinDistributeAmount () = "%s%s__cfg__minDistributeAmount"
7583
7684
7785 func keySwopfiUsdtUsdnPoolAddress () = "%s%s__cfg__swopfiUsdtUsdnPoolAddress"
7886
7987
8088 func keySavingsAddress () = "%s%s__cfg__savingsAddress"
8189
8290
8391 func keyBeneficiaryAddress () = "%s%s__cfg__beneficiaryAddress"
8492
8593
8694 let IdxControlCfgNeutrinoDapp = 1
8795
8896 let IdxControlCfgAuctionDapp = 2
8997
9098 let IdxControlCfgRpdDapp = 3
9199
92100 let IdxControlCfgMathDapp = 4
93101
94102 let IdxControlCfgLiquidationDapp = 5
95103
96104 let IdxControlCfgRestDapp = 6
97105
98106 let IdxControlCfgNodeRegistryDapp = 7
99107
100108 let IdxControlCfgNsbtStakingDapp = 8
101109
102110 let IdxControlCfgMediatorDapp = 9
103111
104112 let IdxControlCfgSurfStakingDapp = 10
105113
106114 let IdxControlCfgGnsbtControllerDapp = 11
107115
108116 let IdxControlCfgRestV2Dapp = 12
109117
110118 let IdxControlCfgGovernanceDapp = 13
111119
112120 func keyControlAddress () = "%s%s__config__controlAddress"
113121
114122
115123 func keyControlCfg () = "%s__controlConfig"
116124
117125
118126 func keyUsdnAssetId () = "neutrino_asset_id"
119127
120128
121129 func readControlCfgOrFail (control) = split_4C(getStringOrFail(control, keyControlCfg()), SEP)
122130
123131
124132 func getContractAddressOrFail (controlCfg,idx) = valueOrErrorMessage(addressFromString(controlCfg[idx]), ("Control cfg doesn't contain address at index " + toString(idx)))
125133
126134
127135 let controlContract = addressFromStringValue(valueOrElse(getString(this, keyControlAddress()), "3P5Bfd58PPfNvBM2Hy8QfbcDqMeNtzg7KfP"))
128136
129137 let controlCfg = readControlCfgOrFail(controlContract)
130138
131139 let neutrinoContract = getContractAddressOrFail(controlCfg, IdxControlCfgNeutrinoDapp)
132140
133141 let usdnAssetIdStr = getStrOrElse(neutrinoContract, keyUsdnAssetId(), "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p")
134142
135143 let usdnAssetId = fromBase58String(usdnAssetIdStr)
136144
137145 let nRegIdxTxAdd = 1
138146
139147 let nRegIdxHeightAdd = 2
140148
141149 let nRegIdxTimeAdd = 3
142150
143151 let nRegIdxDepoAmt = 4
144152
145153 let nRegIdxDepoAmtLeft = 5
146154
147155 let nRegIdxStatus = 6
148156
149157 let nRegIdxStatusChangeHeight = 7
150158
151159 let nRegIdxStatusChangeTime = 8
152160
153161 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)
154162
155163
156164 func formatDepositChangeStatus (origS,newStatus) = {
157165 let orig = split(origS, SEP)
158166 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)
159167 }
160168
161169
162170 func keyRewardHistory (nodeAddress,txId) = makeString(["%s%s%s", "history", toString(nodeAddress), toBase58String(txId)], SEP)
163171
164172
165173 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)
166174
167175
168176 func RewardHistoryEntry (nodeAddress,txId,minedAmt,beneficiaryAmt,protocolAmt,protocolAmt1,protocolAmt2) = StringEntry(keyRewardHistory(nodeAddress, txId), dataRewardHistory(minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2))
169177
170178
171179 func dataRewardTotals (minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = makeString(["%d%d%d%d%d", toString(minedAmt), toString(beneficiaryAmt), toString(protocolAmt), toString(protocolAmtPart1), toString(protocolAmtPart2)], SEP)
172180
173181
174182 func RewardTotalsEntry (miner,minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = {
175183 let nodeRewardsTotalsKEY = keyNodeRewardsTotals(toString(miner))
176184 let nodeRewardsArray = split(getStrOrElse(this, nodeRewardsTotalsKEY, dataRewardTotals(0, 0, 0, 0, 0)), SEP)
177185 let newMinedAmt = (parseIntValue(nodeRewardsArray[1]) + minedAmt)
178186 let newBeneficiaryAmt = (parseIntValue(nodeRewardsArray[2]) + beneficiaryAmt)
179187 let newProtocolAmt = (parseIntValue(nodeRewardsArray[3]) + protocolAmt)
180188 let newProtocolAmtPart1 = (parseIntValue(nodeRewardsArray[4]) + protocolAmtPart1)
181189 let newProtocolAmtPart2 = (parseIntValue(nodeRewardsArray[5]) + protocolAmtPart2)
182190 StringEntry(nodeRewardsTotalsKEY, dataRewardTotals(newMinedAmt, newBeneficiaryAmt, newProtocolAmt, newProtocolAmtPart1, newProtocolAmtPart2))
183191 }
184192
185193
186194 func resolveBeneficiaries (minerAddress,beneficiaryFromParam) = {
187195 let minerScriptHash = scriptHash(minerAddress)
188196 let beneficiaryFromMinerState = addressFromStringValue(getStringOrFail(minerAddress, keyBeneficiaryAddress()))
189197 if ((minerScriptHash == unit))
190198 then beneficiaryFromParam
191199 else beneficiaryFromMinerState
192200 }
193201
194202
195203 func readNodeDataAndValidateStatus (nodeAddr,expectedStatus) = {
196204 let nodeDataOpt = getString(keyNodeRegistry(nodeAddr))
197205 if (!(isDefined(nodeDataOpt)))
198206 then throw(("Unknown Node " + nodeAddr))
199207 else {
200208 let nodeDataStr = value(nodeDataOpt)
201209 let nodeData = split(nodeDataStr, SEP)
202210 let nodeStatus = if ((size(nodeData) >= 9))
203211 then nodeData[nRegIdxStatus]
204212 else "PENDING"
205213 if ((nodeStatus != expectedStatus))
206214 then throw(((((("Node " + nodeAddr) + " status should be ") + expectedStatus) + ", but actually ") + nodeStatus))
207215 else nodeDataStr
208216 }
209217 }
210218
211219
212220 @Callable(i)
213221 func constructor (depositAmount,neutrinoAddressStr,masterNodeAddressStr,protocolPartX6,benificaryPartX6) = if ((i.caller != this))
214222 then throw("permissions denied")
215223 else if ((0 > depositAmount))
216224 then throw("depositAmount less then zero")
217225 else if ((0 > protocolPartX6))
218226 then throw("protocolPartX6 less then zero")
219227 else if ((0 > benificaryPartX6))
220228 then throw("benificaryPartX6 less then zero")
221229 else if (((protocolPartX6 + benificaryPartX6) != MULT6))
222230 then throw("parts sum must be 1")
223231 else [IntegerEntry(keyDepositAmount(), depositAmount), StringEntry(keyNeutrinoAddressStr(), validateAddressOrFail(neutrinoAddressStr)), StringEntry(keyMasterNodeAddressStr(), validateAddressOrFail(masterNodeAddressStr)), IntegerEntry(keyProtocolPartX6(), protocolPartX6), IntegerEntry(keyBenificaryPartX6(), benificaryPartX6)]
224232
225233
226234
227235 @Callable(i)
228236 func constructorV2 (swopfiAddressStr,controlAddressStr,savingsAddressStr) = if ((i.caller != this))
229237 then throw("permissions denied")
230238 else [StringEntry(keySwopfiUsdtUsdnPoolAddress(), validateAddressOrFail(swopfiAddressStr)), StringEntry(keyControlAddress(), validateAddressOrFail(controlAddressStr)), StringEntry(keySavingsAddress(), validateAddressOrFail(savingsAddressStr))]
231239
232240
233241
234242 @Callable(i)
235243 func sumbitApplication () = if ((size(i.payments) != 1))
236244 then throw("exact 1 payment must be attached")
237245 else if ((i.caller != i.originCaller))
238246 then throw("dapp to dapp calls are not allowed")
239247 else {
240248 let pmt = i.payments[0]
241249 let deposit = pmt.amount
242250 let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
243251 let expectedDepositAmount = getIntOrFail(keyDepositAmount())
244252 let txId = toBase58String(i.transactionId)
245253 let nodeAddress = toString(i.caller)
246254 let nodeRegistryKEY = keyNodeRegistry(nodeAddress)
247255 if ((pmtAssetId != WAVESID))
248256 then throw("only Waves can be used for deposit")
249257 else if ((deposit != expectedDepositAmount))
250258 then throw((("exactly " + toString(expectedDepositAmount)) + " Wavelets are expected"))
251259 else if ((getStrOrElse(this, nodeRegistryKEY, "") != ""))
252260 then throw("your node already registered")
253261 else [StringEntry(nodeRegistryKEY, formatDepositAdd(txId, deposit, deposit, "PENDING"))]
254262 }
255263
256264
257265
258266 @Callable(i)
259-func distributeMinerReward (beneficiaryAddressStr) = if ((1 == 1))
260- then throw("temporary disable")
261- else {
262- let minDistributeAmount = valueOrElse(getInteger(this, keyMinDistributeAmount()), (24 * MULT8))
263- if ((size(i.payments) != 1))
264- then throw("exact 1 payment must be attached")
265- else if ((i.caller != i.originCaller))
266- then throw("dapp to dapp calls are not allowed")
267- else {
268- let pmt = i.payments[0]
269- let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
270- let feeAmt = i.fee
271- let feeAssetId = valueOrElse(i.feeAssetId, WAVESID)
272- let callReward = (feeAmt * 3)
273- let minedAmt = (pmt.amount - callReward)
274- if ((pmt.amount != minDistributeAmount))
275- then throw((("attached payment must be exact " + toString(minDistributeAmount)) + " Wavelets"))
276- else if ((pmtAssetId != WAVESID))
277- then throw("only Waves can be used in payment")
278- else if ((feeAssetId != WAVESID))
279- then throw("only Waves can be used in fees")
280- else if ((feeAmt != ((5 * MULT8) / 1000)))
281- then throw("fee amount couldn't exceed 0.005")
282- else {
283- let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
284- let masterNodeAddress = getAddressOrFail(keyMasterNodeAddressStr())
285- let minerAddress = i.caller
286- let beneficiaryFromParam = addressFromStringValue(beneficiaryAddressStr)
287- let beneficiaryAddress = resolveBeneficiaries(minerAddress, beneficiaryFromParam)
288- let txRewardReceiver = beneficiaryFromParam
289- let protocolPart = getIntOrFail(keyProtocolPartX6())
290- let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
291- let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
292- let protocolAmt = (minedAmt - beneficiaryAmt)
293- let protocolAmt1 = 0
294- let protocolAmt2 = (protocolAmt - protocolAmt1)
295- let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
296- let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [protocolAmt2], nil))
297- let swopfiAddress = addressFromStringValue(getStrOrElse(this, keySwopfiUsdtUsdnPoolAddress(), "3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG"))
298- let swopfiResult = asSwopfiResultSTRUCT(invoke(swopfiAddress, "exchange", [1], [AttachedPayment(unit, (protocolAmt2 + savingsAmt))]))
299- let receivedUsdnAmt = swopfiResult._1
300- let receivedAssetId = swopfiResult._2
301- if ((usdnAssetId != receivedAssetId))
302- then throw("invalid asset id received during swopfi exchange")
303- else [ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(masterNodeAddress, receivedUsdnAmt, usdnAssetId), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2)]
304- }
305- }
306- }
267+func distributeMinerReward (beneficiaryAddressStr) = {
268+ let minDistributeAmount = valueOrElse(getInteger(this, keyMinDistributeAmount()), (24 * MULT8))
269+ if ((size(i.payments) != 1))
270+ then throw("exact 1 payment must be attached")
271+ else if ((i.caller != i.originCaller))
272+ then throw("dapp to dapp calls are not allowed")
273+ else {
274+ let pmt = i.payments[0]
275+ let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
276+ let feeAmt = i.fee
277+ let feeAssetId = valueOrElse(i.feeAssetId, WAVESID)
278+ let callReward = (feeAmt * 3)
279+ let minedAmt = (pmt.amount - callReward)
280+ if ((pmt.amount != minDistributeAmount))
281+ then throw((("attached payment must be exact " + toString(minDistributeAmount)) + " Wavelets"))
282+ else if ((pmtAssetId != WAVESID))
283+ then throw("only Waves can be used in payment")
284+ else if ((feeAssetId != WAVESID))
285+ then throw("only Waves can be used in fees")
286+ else if ((feeAmt != ((5 * MULT8) / 1000)))
287+ then throw("fee amount couldn't exceed 0.005")
288+ else {
289+ let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
290+ let masterNodeAddress = getAddressOrFail(keyMasterNodeAddressStr())
291+ let minerAddress = i.caller
292+ let beneficiaryFromParam = addressFromStringValue(beneficiaryAddressStr)
293+ let beneficiaryAddress = resolveBeneficiaries(minerAddress, beneficiaryFromParam)
294+ let txRewardReceiver = beneficiaryFromParam
295+ let protocolPart = getIntOrFail(keyProtocolPartX6())
296+ let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
297+ let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
298+ let protocolAmt = (minedAmt - beneficiaryAmt)
299+ let protocolAmt1 = 0
300+ let protocolAmt2 = (protocolAmt - protocolAmt1)
301+ let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
302+ let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [protocolAmt2], nil))
303+ let swopfiAddress = addressFromStringValue(getStrOrElse(this, keySwopfiUsdtUsdnPoolAddress(), "3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG"))
304+ let swopfiResult = asAnyList(invoke(swopfiAddress, "exchange", [1], [AttachedPayment(unit, (protocolAmt2 + savingsAmt))]))
305+ let receivedUsdnAmt = asInt(swopfiResult[0])
306+ let receivedAssetId = asByteVecot(swopfiResult[1])
307+ if ((usdnAssetId != receivedAssetId))
308+ then throw("invalid asset id received during swopfi exchange")
309+ else [ScriptTransfer(beneficiaryAddress, beneficiaryAmt, unit), ScriptTransfer(masterNodeAddress, receivedUsdnAmt, usdnAssetId), ScriptTransfer(txRewardReceiver, callReward, unit), RewardHistoryEntry(minerAddress, i.transactionId, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2), RewardTotalsEntry(minerAddress, minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2)]
310+ }
311+ }
312+ }
307313
308314
309315
310316 @Callable(i)
311317 func validateAndApproveLeasings (nListS) = {
312318 let nIdxs = [0, 1, 2, 3, 4, 5, 6, 7]
313319 let nList = split(nListS, SEP)
314320 let expectedCount = size(nIdxs)
315321 let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
316322 if ((i.caller != neutrinoAddress))
317323 then throw("validateAndApproveLeasings not authorized")
318324 else if (((size(nList) % 2) != 0))
319325 then throw("Only even number of nodes is allowed")
320326 else if ((size(nList) != expectedCount))
321327 then throw((("Only " + toString(expectedCount)) + " of nodes' addresses can be passed"))
322328 else {
323329 func forEachNodeChangeStatus (acc,i) = {
324330 let nodeAddr = nList[i]
325331 let nodeDataStr = readNodeDataAndValidateStatus(nodeAddr, "PENDING")
326332 (acc :+ StringEntry(keyNodeRegistry(nodeAddr), formatDepositChangeStatus(nodeDataStr, "APPROVED")))
327333 }
328334
329335 let approvedNodesData = {
330336 let $l = nIdxs
331337 let $s = size($l)
332338 let $acc0 = nil
333339 func $f0_1 ($a,$i) = if (($i >= $s))
334340 then $a
335341 else forEachNodeChangeStatus($a, $l[$i])
336342
337343 func $f0_2 ($a,$i) = if (($i >= $s))
338344 then $a
339345 else throw("List size exceeds 8")
340346
341347 $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)
342348 }
343349 $Tuple2(approvedNodesData, nil)
344350 }
345351 }
346352
347353
348354
349355 @Callable(i)
350356 func replaceApprovedNode (oldNodeAddrStr,newNodeAddrStr,groupNum,penaltyAmount) = if ((i.caller != neutrinoContract))
351357 then throw("permissions denied")
352358 else {
353359 let oldDataStr = readNodeDataAndValidateStatus(oldNodeAddrStr, "APPROVED")
354360 let newDataStr = readNodeDataAndValidateStatus(newNodeAddrStr, "PENDING")
355361 let approvedNodeListS = getStringOrFail(this, keyApprovedNodeList())
356362 if (!(contains(approvedNodeListS, oldNodeAddrStr)))
357363 then throw(("approvedNodeList does not contain " + oldNodeAddrStr))
358364 else {
359365 let updatedNodeListS = makeString(split(approvedNodeListS, oldNodeAddrStr), newNodeAddrStr)
360366 let oldNodeAddr = addressFromStringValue(oldNodeAddrStr)
361367 let beneficiaryAddress = resolveBeneficiaries(oldNodeAddr, oldNodeAddr)
362368 let depoAmount = parseIntValue(split(oldDataStr, SEP)[nRegIdxDepoAmt])
363369 let actions = [StringEntry(keyApprovedNodeList(), updatedNodeListS), DeleteEntry(keyNodeRegistry(oldNodeAddrStr)), StringEntry(keyNodeRegistry(newNodeAddrStr), formatDepositChangeStatus(newDataStr, "APPROVED"))]
364370 $Tuple2(if ((depoAmount > penaltyAmount))
365371 then (actions :+ ScriptTransfer(beneficiaryAddress, (depoAmount - penaltyAmount), unit))
366372 else actions, unit)
367373 }
368374 }
369375
370376
371377
372378 @Callable(i)
373379 func returnDeposit (nodeAddressStr) = if ((size(i.payments) != 0))
374380 then throw("No payments allowed")
375381 else {
376382 let callerAddress = i.caller
377383 let nodeAddress = addressFromStringValue(nodeAddressStr)
378384 let approvedNodeList = getStringOrFail(this, keyApprovedNodeList())
379385 if (if ((callerAddress != this))
380386 then (nodeAddress != callerAddress)
381387 else false)
382388 then throw("returnDeposit permissions denied")
383389 else {
384390 let nodeRegistryKEY = keyNodeRegistry(nodeAddressStr)
385391 let nodeDataOpt = getString(this, nodeRegistryKEY)
386392 if (!(isDefined(nodeDataOpt)))
387393 then throw(("Address is not applied as neutrino node: " + nodeAddressStr))
388394 else if (contains(approvedNodeList, nodeAddressStr))
389395 then throw("Impossible to return deposit from approved Node, please contact support team")
390396 else {
391397 let nodeData = split(value(nodeDataOpt), SEP)
392398 let status = if ((size(nodeData) >= 9))
393399 then nodeData[nRegIdxStatus]
394400 else "PENDING"
395401 if ((status != "PENDING"))
396402 then throw("Application status is not PENDING!")
397403 else {
398404 let depoAmount = parseIntValue(nodeData[nRegIdxDepoAmt])
399405 let beneficiaryAddress = resolveBeneficiaries(nodeAddress, nodeAddress)
400406 [DeleteEntry(nodeRegistryKEY), ScriptTransfer(beneficiaryAddress, depoAmount, unit)]
401407 }
402408 }
403409 }
404410 }
405411
406412

github/deemru/w8io/786bc32 
58.87 ms