2022.12.06 22:31 [3414368] smart account 3P9vKqQKjUdmpXAfiWau8krREYAY1Xr69pE > SELF 0.00000000 Waves

{ "type": 13, "id": "De8F2gNrSRteu2mpi8V44r7ZTggt6aCGBRgVJL6u62Tq", "fee": 1900000, "feeAssetId": null, "timestamp": 1670358617968, "version": 1, "sender": "3P9vKqQKjUdmpXAfiWau8krREYAY1Xr69pE", "senderPublicKey": "7AUMX54ukYMYvPmma7yoFf5NjZhs4Bu5nz3Ez9EV8sur", "proofs": [ "2YQbDNrdnJQWkJDQPCesRfukKMxfGPDPkxjvjrKrW5XaZ1NLoC6bDHf4CHSF262B4bQKmq5hynKqtYJ91Eb33JWe" ], "script": "base64:BgIrCAISBwoFAQgIAQESBQoDCAgIEgASAwoBCBIDCgEIEgYKBAgIAQESAwoBCEEAA1NFUAICX18ABU1VTFQ2AMCEPQAFTVVMVDgAgMLXLwAKV0FWRVNJRFNUUgIFV0FWRVMAB1dBVkVTSUQJANkEAQUKV0FWRVNJRFNUUgEMZ2V0SW50T3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQR0aGlzBQNrZXkJAKwCAgkArAICAg9NYW5kYXRvcnkgdGhpcy4FA2tleQIPIGlzIG5vdCBkZWZpbmVkAQxnZXRTdHJPckVsc2UDB2FkZHJlc3MDa2V5CmRlZmF1bHRWYWwJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUHYWRkcmVzcwUDa2V5BQpkZWZhdWx0VmFsAQ9nZXRTdHJpbmdPckZhaWwCB2FkZHJlc3MDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUHYWRkcmVzcwUDa2V5CQCsAgIJAKwCAgIPTWFuZGF0b3J5IHRoaXMuBQNrZXkCDyBpcyBub3QgZGVmaW5lZAEQZ2V0QWRkcmVzc09yRmFpbAEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMFA2tleQkArAICCQCsAgICFUZhaWwgdG8gY29udmVydCB0aGlzLgUDa2V5AhMgdmFsdWUgaW50byBBZGRyZXNzAQlhc0FueUxpc3QBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACCUxpc3RbQW55XQQKdmFsQW55TGlzdAUHJG1hdGNoMAUKdmFsQW55TGlzdAkAAgECG2ZhaWwgdG8gY2FzdCBpbnRvIExpc3RbQW55XQEFYXNJbnQBAXYEByRtYXRjaDAFAXYDCQABAgUHJG1hdGNoMAIDSW50BAFpBQckbWF0Y2gwBQFpCQACAQIVZmFpbCB0byBjYXN0IGludG8gSW50AQthc0J5dGVWZWNvdAEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFpBQckbWF0Y2gwBQFpCQACAQIcZmFpbCB0byBjYXN0IGludG8gQnl0ZVZlY3RvcgEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQphZGRyZXNzU3RyBAdhZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUKYWRkcmVzc1N0cgkArAICAh1mYWlsIHRvIGNvbnZlcnQgaW50byBhZGRyZXNzIAUKYWRkcmVzc1N0cgMJAGYCAAAICQDvBwEFB2FkZHJlc3MJYXZhaWxhYmxlCQEFdGhyb3cABQphZGRyZXNzU3RyAQ9rZXlOb2RlUmVnaXN0cnkBB2FkZHJlc3MJAKwCAgIEJXNfXwUHYWRkcmVzcwEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBB2FkZHJlc3MJAKwCAgIOJXMlc19fdG90YWxzX18FB2FkZHJlc3MBE2tleUFwcHJvdmVkTm9kZUxpc3QAAhQlc19fYXBwcm92ZWROb2RlTGlzdAEQa2V5RGVwb3NpdEFtb3VudAACGCVzJXNfX2NmZ19fZGVwb3NpdEFtb3VudAEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAIaJXMlc19fY2ZnX19uZXV0cmlub0FkZHJlc3MBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAIiJXMlc19fY2ZnX19tYWluTmV1dHJpbm9Ob2RlQWRkcmVzcwERa2V5UHJvdG9jb2xQYXJ0WDYAAhklcyVzX19jZmdfX3Byb3RvY29sUGFydFg2ARNrZXlCZW5pZmljYXJ5UGFydFg2AAIbJXMlc19fY2ZnX19iZW5pZmljYXJ5UGFydFg2ARZrZXlNaW5EaXN0cmlidXRlQW1vdW50AAIeJXMlc19fY2ZnX19taW5EaXN0cmlidXRlQW1vdW50ARxrZXlTd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzAAIkJXMlc19fY2ZnX19zd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzARFrZXlTYXZpbmdzQWRkcmVzcwACGSVzJXNfX2NmZ19fc2F2aW5nc0FkZHJlc3MBFWtleUJlbmVmaWNpYXJ5QWRkcmVzcwACHSVzJXNfX2NmZ19fYmVuZWZpY2lhcnlBZGRyZXNzABlJZHhDb250cm9sQ2ZnTmV1dHJpbm9EYXBwAAEAGElkeENvbnRyb2xDZmdBdWN0aW9uRGFwcAACABRJZHhDb250cm9sQ2ZnUnBkRGFwcAADABVJZHhDb250cm9sQ2ZnTWF0aERhcHAABAAcSWR4Q29udHJvbENmZ0xpcXVpZGF0aW9uRGFwcAAFABVJZHhDb250cm9sQ2ZnUmVzdERhcHAABgAdSWR4Q29udHJvbENmZ05vZGVSZWdpc3RyeURhcHAABwAcSWR4Q29udHJvbENmZ05zYnRTdGFraW5nRGFwcAAIABlJZHhDb250cm9sQ2ZnTWVkaWF0b3JEYXBwAAkAHElkeENvbnRyb2xDZmdTdXJmU3Rha2luZ0RhcHAACgAgSWR4Q29udHJvbENmZ0duc2J0Q29udHJvbGxlckRhcHAACwAXSWR4Q29udHJvbENmZ1Jlc3RWMkRhcHAADAAbSWR4Q29udHJvbENmZ0dvdmVybmFuY2VEYXBwAA0BEWtleUNvbnRyb2xBZGRyZXNzAAIcJXMlc19fY29uZmlnX19jb250cm9sQWRkcmVzcwENa2V5Q29udHJvbENmZwACESVzX19jb250cm9sQ29uZmlnAQ5rZXlVc2RuQXNzZXRJZAACEW5ldXRyaW5vX2Fzc2V0X2lkARRyZWFkQ29udHJvbENmZ09yRmFpbAEHY29udHJvbAkAvAkCCQEPZ2V0U3RyaW5nT3JGYWlsAgUHY29udHJvbAkBDWtleUNvbnRyb2xDZmcABQNTRVABGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIKY29udHJvbENmZwNpZHgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFCmNvbnRyb2xDZmcFA2lkeAkArAICAi1Db250cm9sIGNmZyBkb2Vzbid0IGNvbnRhaW4gYWRkcmVzcyBhdCBpbmRleCAJAKQDAQUDaWR4AA9jb250cm9sQ29udHJhY3QJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkBEWtleUNvbnRyb2xBZGRyZXNzAAIjM1A1QmZkNThQUGZOdkJNMkh5OFFmYmNEcU1lTnR6ZzdLZlAACmNvbnRyb2xDZmcJARRyZWFkQ29udHJvbENmZ09yRmFpbAEFD2NvbnRyb2xDb250cmFjdAAQbmV1dHJpbm9Db250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFCmNvbnRyb2xDZmcFGUlkeENvbnRyb2xDZmdOZXV0cmlub0RhcHAADnVzZG5Bc3NldElkU3RyCQEMZ2V0U3RyT3JFbHNlAwUQbmV1dHJpbm9Db250cmFjdAkBDmtleVVzZG5Bc3NldElkAAIsREcyeEZrUGREd0tVb0JrekdBaFF0THBTR3pmWExpQ1lQRXplS0gyQWQyNHAAC3VzZG5Bc3NldElkCQDZBAEFDnVzZG5Bc3NldElkU3RyAAxuUmVnSWR4VHhBZGQAAQAQblJlZ0lkeEhlaWdodEFkZAACAA5uUmVnSWR4VGltZUFkZAADAA5uUmVnSWR4RGVwb0FtdAAEABJuUmVnSWR4RGVwb0FtdExlZnQABQANblJlZ0lkeFN0YXR1cwAGABluUmVnSWR4U3RhdHVzQ2hhbmdlSGVpZ2h0AAcAF25SZWdJZHhTdGF0dXNDaGFuZ2VUaW1lAAgBEGZvcm1hdERlcG9zaXRBZGQEB3R4SWRTdHINZGVwb3NpdEFtb3VudBZyZW1haW5pbmdEZXBvc2l0QW1vdW50BnN0YXR1cwkAuQkCCQDMCAICECVzJWQlZCVkJWQlcyVkJWQJAMwIAgUHdHhJZFN0cgkAzAgCCQCkAwEIBQlsYXN0QmxvY2sGaGVpZ2h0CQDMCAIJAKQDAQgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkApAMBBQ1kZXBvc2l0QW1vdW50CQDMCAIJAKQDAQUWcmVtYWluaW5nRGVwb3NpdEFtb3VudAkAzAgCBQZzdGF0dXMJAMwIAgIBMAkAzAgCAgEwBQNuaWwFA1NFUAEZZm9ybWF0RGVwb3NpdENoYW5nZVN0YXR1cwIFb3JpZ1MJbmV3U3RhdHVzBARvcmlnCQC1CQIFBW9yaWdTBQNTRVAJALkJAgkAzAgCAhAlcyVkJWQlZCVkJXMlZCVkCQDMCAIJAJEDAgUEb3JpZwUMblJlZ0lkeFR4QWRkCQDMCAIJAJEDAgUEb3JpZwUQblJlZ0lkeEhlaWdodEFkZAkAzAgCCQCRAwIFBG9yaWcFDm5SZWdJZHhUaW1lQWRkCQDMCAIJAJEDAgUEb3JpZwUOblJlZ0lkeERlcG9BbXQJAMwIAgkAkQMCBQRvcmlnBRJuUmVnSWR4RGVwb0FtdExlZnQJAMwIAgUJbmV3U3RhdHVzCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUDbmlsBQNTRVABEGtleVJld2FyZEhpc3RvcnkCC25vZGVBZGRyZXNzBHR4SWQJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIHaGlzdG9yeQkAzAgCCQClCAEFC25vZGVBZGRyZXNzCQDMCAIJANgEAQUEdHhJZAUDbmlsBQNTRVABEWRhdGFSZXdhcmRIaXN0b3J5BRB3YXZlc0Ftb3VudFRvdGFsDmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICDiVkJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQCkAwEFEHdhdmVzQW1vdW50VG90YWwJAMwIAgkApAMBBQ5iZW5lZmljaWFyeUFtdAkAzAgCCQCkAwEFC3Byb3RvY29sQW10CQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MQkAzAgCCQCkAwEFEHByb3RvY29sQW10UGFydDIFA25pbAUDU0VQARJSZXdhcmRIaXN0b3J5RW50cnkHC25vZGVBZGRyZXNzBHR4SWQIbWluZWRBbXQOYmVuZWZpY2lhcnlBbXQLcHJvdG9jb2xBbXQMcHJvdG9jb2xBbXQxDHByb3RvY29sQW10MgkBC1N0cmluZ0VudHJ5AgkBEGtleVJld2FyZEhpc3RvcnkCBQtub2RlQWRkcmVzcwUEdHhJZAkBEWRhdGFSZXdhcmRIaXN0b3J5BQUIbWluZWRBbXQFDmJlbmVmaWNpYXJ5QW10BQtwcm90b2NvbEFtdAUMcHJvdG9jb2xBbXQxBQxwcm90b2NvbEFtdDIBEGRhdGFSZXdhcmRUb3RhbHMFCG1pbmVkQW10DmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICCiVkJWQlZCVkJWQJAMwIAgkApAMBBQhtaW5lZEFtdAkAzAgCCQCkAwEFDmJlbmVmaWNpYXJ5QW10CQDMCAIJAKQDAQULcHJvdG9jb2xBbXQJAMwIAgkApAMBBRBwcm90b2NvbEFtdFBhcnQxCQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MgUDbmlsBQNTRVABEVJld2FyZFRvdGFsc0VudHJ5BgVtaW5lcghtaW5lZEFtdA5iZW5lZmljaWFyeUFtdAtwcm90b2NvbEFtdBBwcm90b2NvbEFtdFBhcnQxEHByb3RvY29sQW10UGFydDIEFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBCQClCAEFBW1pbmVyBBBub2RlUmV3YXJkc0FycmF5CQC1CQIJAQxnZXRTdHJPckVsc2UDBQR0aGlzBRRub2RlUmV3YXJkc1RvdGFsc0tFWQkBEGRhdGFSZXdhcmRUb3RhbHMFAAAAAAAAAAAAAAUDU0VQBAtuZXdNaW5lZEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAEFCG1pbmVkQW10BBFuZXdCZW5lZmljaWFyeUFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAIFDmJlbmVmaWNpYXJ5QW10BA5uZXdQcm90b2NvbEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAMFC3Byb3RvY29sQW10BBNuZXdQcm90b2NvbEFtdFBhcnQxCQBkAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFEG5vZGVSZXdhcmRzQXJyYXkABAUQcHJvdG9jb2xBbXRQYXJ0MQQTbmV3UHJvdG9jb2xBbXRQYXJ0MgkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAUFEHByb3RvY29sQW10UGFydDIJAQtTdHJpbmdFbnRyeQIFFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEQZGF0YVJld2FyZFRvdGFscwUFC25ld01pbmVkQW10BRFuZXdCZW5lZmljaWFyeUFtdAUObmV3UHJvdG9jb2xBbXQFE25ld1Byb3RvY29sQW10UGFydDEFE25ld1Byb3RvY29sQW10UGFydDIBFHJlc29sdmVCZW5lZmljaWFyaWVzAgxtaW5lckFkZHJlc3MUYmVuZWZpY2lhcnlGcm9tUGFyYW0EGWJlbmVmaWNpYXJ5RnJvbU1pbmVyU3RhdGUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQ9nZXRTdHJpbmdPckZhaWwCBQxtaW5lckFkZHJlc3MJARVrZXlCZW5lZmljaWFyeUFkZHJlc3MAAwkAAAIJAPEHAQUMbWluZXJBZGRyZXNzBQR1bml0BRRiZW5lZmljaWFyeUZyb21QYXJhbQUZYmVuZWZpY2lhcnlGcm9tTWluZXJTdGF0ZQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCCG5vZGVBZGRyDmV4cGVjdGVkU3RhdHVzBAtub2RlRGF0YU9wdAkAoggBCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUIbm9kZUFkZHIDCQEBIQEJAQlpc0RlZmluZWQBBQtub2RlRGF0YU9wdAkAAgEJAKwCAgINVW5rbm93biBOb2RlIAUIbm9kZUFkZHIEC25vZGVEYXRhU3RyCQEFdmFsdWUBBQtub2RlRGF0YU9wdAQIbm9kZURhdGEJALUJAgULbm9kZURhdGFTdHIFA1NFUAQKbm9kZVN0YXR1cwMJAGcCCQCQAwEFCG5vZGVEYXRhAAkJAJEDAgUIbm9kZURhdGEFDW5SZWdJZHhTdGF0dXMCB1BFTkRJTkcDCQECIT0CBQpub2RlU3RhdHVzBQ5leHBlY3RlZFN0YXR1cwkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgVOb2RlIAUIbm9kZUFkZHICEiBzdGF0dXMgc2hvdWxkIGJlIAUOZXhwZWN0ZWRTdGF0dXMCDywgYnV0IGFjdHVhbGx5IAUKbm9kZVN0YXR1cwULbm9kZURhdGFTdHIHAWkBC2NvbnN0cnVjdG9yBQ1kZXBvc2l0QW1vdW50Em5ldXRyaW5vQWRkcmVzc1N0chRtYXN0ZXJOb2RlQWRkcmVzc1N0cg5wcm90b2NvbFBhcnRYNhBiZW5pZmljYXJ5UGFydFg2AwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIScGVybWlzc2lvbnMgZGVuaWVkAwkAZgIAAAUNZGVwb3NpdEFtb3VudAkAAgECHGRlcG9zaXRBbW91bnQgbGVzcyB0aGVuIHplcm8DCQBmAgAABQ5wcm90b2NvbFBhcnRYNgkAAgECHXByb3RvY29sUGFydFg2IGxlc3MgdGhlbiB6ZXJvAwkAZgIAAAUQYmVuaWZpY2FyeVBhcnRYNgkAAgECH2JlbmlmaWNhcnlQYXJ0WDYgbGVzcyB0aGVuIHplcm8DCQECIT0CCQBkAgUOcHJvdG9jb2xQYXJ0WDYFEGJlbmlmaWNhcnlQYXJ0WDYFBU1VTFQ2CQACAQITcGFydHMgc3VtIG11c3QgYmUgMQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBEGtleURlcG9zaXRBbW91bnQABQ1kZXBvc2l0QW1vdW50CQDMCAIJAQtTdHJpbmdFbnRyeQIJARVrZXlOZXV0cmlub0FkZHJlc3NTdHIACQEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQUSbmV1dHJpbm9BZGRyZXNzU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQIJARdrZXlNYXN0ZXJOb2RlQWRkcmVzc1N0cgAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRRtYXN0ZXJOb2RlQWRkcmVzc1N0cgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBEWtleVByb3RvY29sUGFydFg2AAUOcHJvdG9jb2xQYXJ0WDYJAMwIAgkBDEludGVnZXJFbnRyeQIJARNrZXlCZW5pZmljYXJ5UGFydFg2AAUQYmVuaWZpY2FyeVBhcnRYNgUDbmlsAWkBDWNvbnN0cnVjdG9yVjIDEHN3b3BmaUFkZHJlc3NTdHIRY29udHJvbEFkZHJlc3NTdHIRc2F2aW5nc0FkZHJlc3NTdHIDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhJwZXJtaXNzaW9ucyBkZW5pZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBHGtleVN3b3BmaVVzZHRVc2RuUG9vbEFkZHJlc3MACQEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQUQc3dvcGZpQWRkcmVzc1N0cgkAzAgCCQELU3RyaW5nRW50cnkCCQERa2V5Q29udHJvbEFkZHJlc3MACQEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQURY29udHJvbEFkZHJlc3NTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEWtleVNhdmluZ3NBZGRyZXNzAAkBFXZhbGlkYXRlQWRkcmVzc09yRmFpbAEFEXNhdmluZ3NBZGRyZXNzU3RyBQNuaWwBaQERc3VtYml0QXBwbGljYXRpb24AAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIgZXhhY3QgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQDCQECIT0CCAUBaQZjYWxsZXIIBQFpDG9yaWdpbkNhbGxlcgkAAgECImRhcHAgdG8gZGFwcCBjYWxscyBhcmUgbm90IGFsbG93ZWQEA3BtdAkAkQMCCAUBaQhwYXltZW50cwAABAdkZXBvc2l0CAUDcG10BmFtb3VudAQKcG10QXNzZXRJZAkBC3ZhbHVlT3JFbHNlAggFA3BtdAdhc3NldElkBQdXQVZFU0lEBBVleHBlY3RlZERlcG9zaXRBbW91bnQJAQxnZXRJbnRPckZhaWwBCQEQa2V5RGVwb3NpdEFtb3VudAAEBHR4SWQJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAQLbm9kZUFkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBA9ub2RlUmVnaXN0cnlLRVkJAQ9rZXlOb2RlUmVnaXN0cnkBBQtub2RlQWRkcmVzcwMJAQIhPQIFCnBtdEFzc2V0SWQFB1dBVkVTSUQJAAIBAiJvbmx5IFdhdmVzIGNhbiBiZSB1c2VkIGZvciBkZXBvc2l0AwkBAiE9AgUHZGVwb3NpdAUVZXhwZWN0ZWREZXBvc2l0QW1vdW50CQACAQkArAICCQCsAgICCGV4YWN0bHkgCQCkAwEFFWV4cGVjdGVkRGVwb3NpdEFtb3VudAIWIFdhdmVsZXRzIGFyZSBleHBlY3RlZAMJAQIhPQIJAQxnZXRTdHJPckVsc2UDBQR0aGlzBQ9ub2RlUmVnaXN0cnlLRVkCAAIACQACAQIceW91ciBub2RlIGFscmVhZHkgcmVnaXN0ZXJlZAkAzAgCCQELU3RyaW5nRW50cnkCBQ9ub2RlUmVnaXN0cnlLRVkJARBmb3JtYXREZXBvc2l0QWRkBAUEdHhJZAUHZGVwb3NpdAUHZGVwb3NpdAIHUEVORElORwUDbmlsAWkBFWRpc3RyaWJ1dGVNaW5lclJld2FyZAEVYmVuZWZpY2lhcnlBZGRyZXNzU3RyBBNtaW5EaXN0cmlidXRlQW1vdW50CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJARZrZXlNaW5EaXN0cmlidXRlQW1vdW50AAkAaAIAGAUFTVVMVDgDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAiBleGFjdCAxIHBheW1lbnQgbXVzdCBiZSBhdHRhY2hlZAMJAQIhPQIIBQFpBmNhbGxlcggFAWkMb3JpZ2luQ2FsbGVyCQACAQIiZGFwcCB0byBkYXBwIGNhbGxzIGFyZSBub3QgYWxsb3dlZAQDcG10CQCRAwIIBQFpCHBheW1lbnRzAAAECnBtdEFzc2V0SWQJAQt2YWx1ZU9yRWxzZQIIBQNwbXQHYXNzZXRJZAUHV0FWRVNJRAQGZmVlQW10CAUBaQNmZWUECmZlZUFzc2V0SWQJAQt2YWx1ZU9yRWxzZQIIBQFpCmZlZUFzc2V0SWQFB1dBVkVTSUQECmNhbGxSZXdhcmQJAGgCBQZmZWVBbXQAAwQIbWluZWRBbXQJAGUCCAUDcG10BmFtb3VudAUKY2FsbFJld2FyZAMJAQIhPQIIBQNwbXQGYW1vdW50BRNtaW5EaXN0cmlidXRlQW1vdW50CQACAQkArAICCQCsAgICH2F0dGFjaGVkIHBheW1lbnQgbXVzdCBiZSBleGFjdCAJAKQDAQUTbWluRGlzdHJpYnV0ZUFtb3VudAIJIFdhdmVsZXRzAwkBAiE9AgUKcG10QXNzZXRJZAUHV0FWRVNJRAkAAgECIW9ubHkgV2F2ZXMgY2FuIGJlIHVzZWQgaW4gcGF5bWVudAMJAQIhPQIFCmZlZUFzc2V0SWQFB1dBVkVTSUQJAAIBAh5vbmx5IFdhdmVzIGNhbiBiZSB1c2VkIGluIGZlZXMDCQECIT0CBQZmZWVBbXQJAGkCCQBoAgAFBQVNVUxUOADoBwkAAgECIGZlZSBhbW91bnQgY291bGRuJ3QgZXhjZWVkIDAuMDA1BA9uZXV0cmlub0FkZHJlc3MJARBnZXRBZGRyZXNzT3JGYWlsAQkBFWtleU5ldXRyaW5vQWRkcmVzc1N0cgAEEW1hc3Rlck5vZGVBZGRyZXNzCQEQZ2V0QWRkcmVzc09yRmFpbAEJARdrZXlNYXN0ZXJOb2RlQWRkcmVzc1N0cgAEDG1pbmVyQWRkcmVzcwgFAWkGY2FsbGVyBBRiZW5lZmljaWFyeUZyb21QYXJhbQkBEUBleHRyTmF0aXZlKDEwNjIpAQUVYmVuZWZpY2lhcnlBZGRyZXNzU3RyBBJiZW5lZmljaWFyeUFkZHJlc3MJARRyZXNvbHZlQmVuZWZpY2lhcmllcwIFDG1pbmVyQWRkcmVzcwUUYmVuZWZpY2lhcnlGcm9tUGFyYW0EEHR4UmV3YXJkUmVjZWl2ZXIFFGJlbmVmaWNpYXJ5RnJvbVBhcmFtBAxwcm90b2NvbFBhcnQJAQxnZXRJbnRPckZhaWwBCQERa2V5UHJvdG9jb2xQYXJ0WDYABA9iZW5lZmljaWFyeVBhcnQJAQxnZXRJbnRPckZhaWwBCQETa2V5QmVuaWZpY2FyeVBhcnRYNgAEDmJlbmVmaWNpYXJ5QW10CQBrAwUIbWluZWRBbXQFD2JlbmVmaWNpYXJ5UGFydAUFTVVMVDYEC3Byb3RvY29sQW10CQBlAgUIbWluZWRBbXQFDmJlbmVmaWNpYXJ5QW10BAxwcm90b2NvbEFtdDEAAAQMcHJvdG9jb2xBbXQyCQBlAgULcHJvdG9jb2xBbXQFDHByb3RvY29sQW10MQQOc2F2aW5nc0FkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQxnZXRTdHJPckVsc2UDBQR0aGlzCQERa2V5U2F2aW5nc0FkZHJlc3MAAiMzUEM3REJpbWF1eUt5dHg4dFhoS281dTJFQ2I2RnNuZFlLSAQKc2F2aW5nc0FtdAkBBWFzSW50AQkA/AcEBQ5zYXZpbmdzQWRkcmVzcwIId2l0aGRyYXcJAMwIAgUMcHJvdG9jb2xBbXQyBQNuaWwFA25pbAQNc3dvcGZpQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBDGdldFN0ck9yRWxzZQMFBHRoaXMJARxrZXlTd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzAAIjM1BIYU5nb21Ca3J2RUwyUW51SmFyUVZKYTcxd2p3OXFpcUcEDHN3b3BmaVJlc3VsdAkBCWFzQW55TGlzdAEJAPwHBAUNc3dvcGZpQWRkcmVzcwIIZXhjaGFuZ2UJAMwIAgABBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBHVuaXQJAGQCBQxwcm90b2NvbEFtdDIFCnNhdmluZ3NBbXQFA25pbAQPcmVjZWl2ZWRVc2RuQW10CQEFYXNJbnQBCQCRAwIFDHN3b3BmaVJlc3VsdAAABA9yZWNlaXZlZEFzc2V0SWQJAQthc0J5dGVWZWNvdAEJAJEDAgUMc3dvcGZpUmVzdWx0AAEDCQECIT0CBQt1c2RuQXNzZXRJZAUPcmVjZWl2ZWRBc3NldElkCQACAQIwaW52YWxpZCBhc3NldCBpZCByZWNlaXZlZCBkdXJpbmcgc3dvcGZpIGV4Y2hhbmdlCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFEmJlbmVmaWNpYXJ5QWRkcmVzcwUOYmVuZWZpY2lhcnlBbXQFBHVuaXQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwURbWFzdGVyTm9kZUFkZHJlc3MFD3JlY2VpdmVkVXNkbkFtdAULdXNkbkFzc2V0SWQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUQdHhSZXdhcmRSZWNlaXZlcgUKY2FsbFJld2FyZAUEdW5pdAkAzAgCCQESUmV3YXJkSGlzdG9yeUVudHJ5BwUMbWluZXJBZGRyZXNzCAUBaQ10cmFuc2FjdGlvbklkBQhtaW5lZEFtdAUOYmVuZWZpY2lhcnlBbXQFC3Byb3RvY29sQW10BQxwcm90b2NvbEFtdDEFDHByb3RvY29sQW10MgkAzAgCCQERUmV3YXJkVG90YWxzRW50cnkGBQxtaW5lckFkZHJlc3MFCG1pbmVkQW10BQ5iZW5lZmljaWFyeUFtdAULcHJvdG9jb2xBbXQFDHByb3RvY29sQW10MQUMcHJvdG9jb2xBbXQyBQNuaWwBaQEadmFsaWRhdGVBbmRBcHByb3ZlTGVhc2luZ3MBBm5MaXN0UwQFbklkeHMJAMwIAgAACQDMCAIAAQkAzAgCAAIJAMwIAgADCQDMCAIABAkAzAgCAAUJAMwIAgAGCQDMCAIABwUDbmlsBAVuTGlzdAkAtQkCBQZuTGlzdFMFA1NFUAQNZXhwZWN0ZWRDb3VudAkAkAMBBQVuSWR4cwQPbmV1dHJpbm9BZGRyZXNzCQEQZ2V0QWRkcmVzc09yRmFpbAEJARVrZXlOZXV0cmlub0FkZHJlc3NTdHIAAwkBAiE9AggFAWkGY2FsbGVyBQ9uZXV0cmlub0FkZHJlc3MJAAIBAil2YWxpZGF0ZUFuZEFwcHJvdmVMZWFzaW5ncyBub3QgYXV0aG9yaXplZAMJAQIhPQIJAGoCCQCQAwEFBW5MaXN0AAIAAAkAAgECJE9ubHkgZXZlbiBudW1iZXIgb2Ygbm9kZXMgaXMgYWxsb3dlZAMJAQIhPQIJAJADAQUFbkxpc3QFDWV4cGVjdGVkQ291bnQJAAIBCQCsAgIJAKwCAgIFT25seSAJAKQDAQUNZXhwZWN0ZWRDb3VudAIiIG9mIG5vZGVzJyBhZGRyZXNzZXMgY2FuIGJlIHBhc3NlZAoBF2ZvckVhY2hOb2RlQ2hhbmdlU3RhdHVzAgNhY2MBaQQIbm9kZUFkZHIJAJEDAgUFbkxpc3QFAWkEC25vZGVEYXRhU3RyCQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCBQhub2RlQWRkcgIHUEVORElORwkAzQgCBQNhY2MJAQtTdHJpbmdFbnRyeQIJAQ9rZXlOb2RlUmVnaXN0cnkBBQhub2RlQWRkcgkBGWZvcm1hdERlcG9zaXRDaGFuZ2VTdGF0dXMCBQtub2RlRGF0YVN0cgIIQVBQUk9WRUQEEWFwcHJvdmVkTm9kZXNEYXRhCgACJGwFBW5JZHhzCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARdmb3JFYWNoTm9kZUNoYW5nZVN0YXR1cwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgOAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgJAJQKAgURYXBwcm92ZWROb2Rlc0RhdGEFA25pbAFpARNyZXBsYWNlQXBwcm92ZWROb2RlBA5vbGROb2RlQWRkclN0cg5uZXdOb2RlQWRkclN0cghncm91cE51bQ1wZW5hbHR5QW1vdW50AwkBAiE9AggFAWkGY2FsbGVyBRBuZXV0cmlub0NvbnRyYWN0CQACAQIScGVybWlzc2lvbnMgZGVuaWVkBApvbGREYXRhU3RyCQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCBQ5vbGROb2RlQWRkclN0cgIIQVBQUk9WRUQECm5ld0RhdGFTdHIJAR1yZWFkTm9kZURhdGFBbmRWYWxpZGF0ZVN0YXR1cwIFDm5ld05vZGVBZGRyU3RyAgdQRU5ESU5HBBFhcHByb3ZlZE5vZGVMaXN0UwkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMJARNrZXlBcHByb3ZlZE5vZGVMaXN0AAMJAQEhAQkBCGNvbnRhaW5zAgURYXBwcm92ZWROb2RlTGlzdFMFDm9sZE5vZGVBZGRyU3RyCQACAQkArAICAiJhcHByb3ZlZE5vZGVMaXN0IGRvZXMgbm90IGNvbnRhaW4gBQ5vbGROb2RlQWRkclN0cgQQdXBkYXRlZE5vZGVMaXN0UwkAuQkCCQC8CQIFEWFwcHJvdmVkTm9kZUxpc3RTBQ5vbGROb2RlQWRkclN0cgUObmV3Tm9kZUFkZHJTdHIEC29sZE5vZGVBZGRyCQERQGV4dHJOYXRpdmUoMTA2MikBBQ5vbGROb2RlQWRkclN0cgQSYmVuZWZpY2lhcnlBZGRyZXNzCQEUcmVzb2x2ZUJlbmVmaWNpYXJpZXMCBQtvbGROb2RlQWRkcgULb2xkTm9kZUFkZHIECmRlcG9BbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCCQC1CQIFCm9sZERhdGFTdHIFA1NFUAUOblJlZ0lkeERlcG9BbXQEB2FjdGlvbnMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBE2tleUFwcHJvdmVkTm9kZUxpc3QABRB1cGRhdGVkTm9kZUxpc3RTCQDMCAIJAQtEZWxldGVFbnRyeQEJAQ9rZXlOb2RlUmVnaXN0cnkBBQ5vbGROb2RlQWRkclN0cgkAzAgCCQELU3RyaW5nRW50cnkCCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUObmV3Tm9kZUFkZHJTdHIJARlmb3JtYXREZXBvc2l0Q2hhbmdlU3RhdHVzAgUKbmV3RGF0YVN0cgIIQVBQUk9WRUQFA25pbAkAlAoCAwkAZgIFCmRlcG9BbW91bnQFDXBlbmFsdHlBbW91bnQJAM0IAgUHYWN0aW9ucwkBDlNjcmlwdFRyYW5zZmVyAwUSYmVuZWZpY2lhcnlBZGRyZXNzCQBlAgUKZGVwb0Ftb3VudAUNcGVuYWx0eUFtb3VudAUEdW5pdAUHYWN0aW9ucwUEdW5pdAFpAQ1yZXR1cm5EZXBvc2l0AQ5ub2RlQWRkcmVzc1N0cgMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAAkAAgECE05vIHBheW1lbnRzIGFsbG93ZWQEDWNhbGxlckFkZHJlc3MIBQFpBmNhbGxlcgQPbm9kZVJlZ2lzdHJ5S0VZCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUObm9kZUFkZHJlc3NTdHIEC25vZGVEYXRhT3B0CQCdCAIFBHRoaXMFD25vZGVSZWdpc3RyeUtFWQMJAQEhAQkBCWlzRGVmaW5lZAEFC25vZGVEYXRhT3B0CQACAQkArAICAilBZGRyZXNzIGlzIG5vdCBhcHBsaWVkIGFzIG5ldXRyaW5vIG5vZGU6IAUObm9kZUFkZHJlc3NTdHIEEGFwcHJvdmVkTm9kZUxpc3QJAQ9nZXRTdHJpbmdPckZhaWwCBQR0aGlzCQETa2V5QXBwcm92ZWROb2RlTGlzdAADCQEIY29udGFpbnMCBRBhcHByb3ZlZE5vZGVMaXN0BQ5ub2RlQWRkcmVzc1N0cgkAAgECTEltcG9zc2libGUgdG8gcmV0dXJuIGRlcG9zaXQgZnJvbSBhcHByb3ZlZCBOb2RlLCBwbGVhc2UgY29udGFjdCBzdXBwb3J0IHRlYW0ECG5vZGVEYXRhCQC1CQIJAQV2YWx1ZQEFC25vZGVEYXRhT3B0BQNTRVAEBnN0YXR1cwMJAGcCCQCQAwEFCG5vZGVEYXRhAAkJAJEDAgUIbm9kZURhdGEFDW5SZWdJZHhTdGF0dXMCB1BFTkRJTkcDCQECIT0CBQZzdGF0dXMCB1BFTkRJTkcJAAIBAiJBcHBsaWNhdGlvbiBzdGF0dXMgaXMgbm90IFBFTkRJTkchBApkZXBvQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIbm9kZURhdGEFDm5SZWdJZHhEZXBvQW10BAtub2RlQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUObm9kZUFkZHJlc3NTdHIEEmJlbmVmaWNpYXJ5QWRkcmVzcwkBFHJlc29sdmVCZW5lZmljaWFyaWVzAgULbm9kZUFkZHJlc3MFC25vZGVBZGRyZXNzAwkBASEBAwMJAAACBQ1jYWxsZXJBZGRyZXNzBQR0aGlzBgMJAQIhPQIFEmJlbmVmaWNpYXJ5QWRkcmVzcwULbm9kZUFkZHJlc3MJAAACBQ1jYWxsZXJBZGRyZXNzBRJiZW5lZmljaWFyeUFkZHJlc3MHBgMJAAACBRJiZW5lZmljaWFyeUFkZHJlc3MFC25vZGVBZGRyZXNzCQAAAgUNY2FsbGVyQWRkcmVzcwULbm9kZUFkZHJlc3MHCQACAQIgcmV0dXJuRGVwb3NpdCBwZXJtaXNzaW9ucyBkZW5pZWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQUPbm9kZVJlZ2lzdHJ5S0VZCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFEmJlbmVmaWNpYXJ5QWRkcmVzcwUKZGVwb0Ftb3VudAUEdW5pdAUDbmlsAPbWYNA=", "chainId": 87, "height": 3414368, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: AFKYtf6JWndJfUUdya7Sr2bLHfXiJfdQZAUH2vinafnR Next: BvDuUbMwXNgvGidu2nvZNTWVoMo9Fr4Md3iX529aF4S8 Diff:
OldNewDifferences
361361 if (!(contains(approvedNodeListS, oldNodeAddrStr)))
362362 then throw(("approvedNodeList does not contain " + oldNodeAddrStr))
363363 else {
364- let updatedNodeListS = makeString(split(approvedNodeListS, oldNodeAddrStr), newNodeAddrStr)
364+ let updatedNodeListS = makeString(split_4C(approvedNodeListS, oldNodeAddrStr), newNodeAddrStr)
365365 let oldNodeAddr = addressFromStringValue(oldNodeAddrStr)
366366 let beneficiaryAddress = resolveBeneficiaries(oldNodeAddr, oldNodeAddr)
367367 let depoAmount = parseIntValue(split(oldDataStr, SEP)[nRegIdxDepoAmt])
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"
8686
8787
8888 func keySavingsAddress () = "%s%s__cfg__savingsAddress"
8989
9090
9191 func keyBeneficiaryAddress () = "%s%s__cfg__beneficiaryAddress"
9292
9393
9494 let IdxControlCfgNeutrinoDapp = 1
9595
9696 let IdxControlCfgAuctionDapp = 2
9797
9898 let IdxControlCfgRpdDapp = 3
9999
100100 let IdxControlCfgMathDapp = 4
101101
102102 let IdxControlCfgLiquidationDapp = 5
103103
104104 let IdxControlCfgRestDapp = 6
105105
106106 let IdxControlCfgNodeRegistryDapp = 7
107107
108108 let IdxControlCfgNsbtStakingDapp = 8
109109
110110 let IdxControlCfgMediatorDapp = 9
111111
112112 let IdxControlCfgSurfStakingDapp = 10
113113
114114 let IdxControlCfgGnsbtControllerDapp = 11
115115
116116 let IdxControlCfgRestV2Dapp = 12
117117
118118 let IdxControlCfgGovernanceDapp = 13
119119
120120 func keyControlAddress () = "%s%s__config__controlAddress"
121121
122122
123123 func keyControlCfg () = "%s__controlConfig"
124124
125125
126126 func keyUsdnAssetId () = "neutrino_asset_id"
127127
128128
129129 func readControlCfgOrFail (control) = split_4C(getStringOrFail(control, keyControlCfg()), SEP)
130130
131131
132132 func getContractAddressOrFail (controlCfg,idx) = valueOrErrorMessage(addressFromString(controlCfg[idx]), ("Control cfg doesn't contain address at index " + toString(idx)))
133133
134134
135135 let controlContract = addressFromStringValue(valueOrElse(getString(this, keyControlAddress()), "3P5Bfd58PPfNvBM2Hy8QfbcDqMeNtzg7KfP"))
136136
137137 let controlCfg = readControlCfgOrFail(controlContract)
138138
139139 let neutrinoContract = getContractAddressOrFail(controlCfg, IdxControlCfgNeutrinoDapp)
140140
141141 let usdnAssetIdStr = getStrOrElse(neutrinoContract, keyUsdnAssetId(), "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p")
142142
143143 let usdnAssetId = fromBase58String(usdnAssetIdStr)
144144
145145 let nRegIdxTxAdd = 1
146146
147147 let nRegIdxHeightAdd = 2
148148
149149 let nRegIdxTimeAdd = 3
150150
151151 let nRegIdxDepoAmt = 4
152152
153153 let nRegIdxDepoAmtLeft = 5
154154
155155 let nRegIdxStatus = 6
156156
157157 let nRegIdxStatusChangeHeight = 7
158158
159159 let nRegIdxStatusChangeTime = 8
160160
161161 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)
162162
163163
164164 func formatDepositChangeStatus (origS,newStatus) = {
165165 let orig = split(origS, SEP)
166166 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)
167167 }
168168
169169
170170 func keyRewardHistory (nodeAddress,txId) = makeString(["%s%s%s", "history", toString(nodeAddress), toBase58String(txId)], SEP)
171171
172172
173173 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)
174174
175175
176176 func RewardHistoryEntry (nodeAddress,txId,minedAmt,beneficiaryAmt,protocolAmt,protocolAmt1,protocolAmt2) = StringEntry(keyRewardHistory(nodeAddress, txId), dataRewardHistory(minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2))
177177
178178
179179 func dataRewardTotals (minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = makeString(["%d%d%d%d%d", toString(minedAmt), toString(beneficiaryAmt), toString(protocolAmt), toString(protocolAmtPart1), toString(protocolAmtPart2)], SEP)
180180
181181
182182 func RewardTotalsEntry (miner,minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = {
183183 let nodeRewardsTotalsKEY = keyNodeRewardsTotals(toString(miner))
184184 let nodeRewardsArray = split(getStrOrElse(this, nodeRewardsTotalsKEY, dataRewardTotals(0, 0, 0, 0, 0)), SEP)
185185 let newMinedAmt = (parseIntValue(nodeRewardsArray[1]) + minedAmt)
186186 let newBeneficiaryAmt = (parseIntValue(nodeRewardsArray[2]) + beneficiaryAmt)
187187 let newProtocolAmt = (parseIntValue(nodeRewardsArray[3]) + protocolAmt)
188188 let newProtocolAmtPart1 = (parseIntValue(nodeRewardsArray[4]) + protocolAmtPart1)
189189 let newProtocolAmtPart2 = (parseIntValue(nodeRewardsArray[5]) + protocolAmtPart2)
190190 StringEntry(nodeRewardsTotalsKEY, dataRewardTotals(newMinedAmt, newBeneficiaryAmt, newProtocolAmt, newProtocolAmtPart1, newProtocolAmtPart2))
191191 }
192192
193193
194194 func resolveBeneficiaries (minerAddress,beneficiaryFromParam) = {
195195 let beneficiaryFromMinerState = addressFromStringValue(getStringOrFail(minerAddress, keyBeneficiaryAddress()))
196196 if ((scriptHash(minerAddress) == unit))
197197 then beneficiaryFromParam
198198 else beneficiaryFromMinerState
199199 }
200200
201201
202202 func readNodeDataAndValidateStatus (nodeAddr,expectedStatus) = {
203203 let nodeDataOpt = getString(keyNodeRegistry(nodeAddr))
204204 if (!(isDefined(nodeDataOpt)))
205205 then throw(("Unknown Node " + nodeAddr))
206206 else {
207207 let nodeDataStr = value(nodeDataOpt)
208208 let nodeData = split(nodeDataStr, SEP)
209209 let nodeStatus = if ((size(nodeData) >= 9))
210210 then nodeData[nRegIdxStatus]
211211 else "PENDING"
212212 if ((nodeStatus != expectedStatus))
213213 then throw(((((("Node " + nodeAddr) + " status should be ") + expectedStatus) + ", but actually ") + nodeStatus))
214214 else nodeDataStr
215215 }
216216 }
217217
218218
219219 @Callable(i)
220220 func constructor (depositAmount,neutrinoAddressStr,masterNodeAddressStr,protocolPartX6,benificaryPartX6) = if ((i.caller != this))
221221 then throw("permissions denied")
222222 else if ((0 > depositAmount))
223223 then throw("depositAmount less then zero")
224224 else if ((0 > protocolPartX6))
225225 then throw("protocolPartX6 less then zero")
226226 else if ((0 > benificaryPartX6))
227227 then throw("benificaryPartX6 less then zero")
228228 else if (((protocolPartX6 + benificaryPartX6) != MULT6))
229229 then throw("parts sum must be 1")
230230 else [IntegerEntry(keyDepositAmount(), depositAmount), StringEntry(keyNeutrinoAddressStr(), validateAddressOrFail(neutrinoAddressStr)), StringEntry(keyMasterNodeAddressStr(), validateAddressOrFail(masterNodeAddressStr)), IntegerEntry(keyProtocolPartX6(), protocolPartX6), IntegerEntry(keyBenificaryPartX6(), benificaryPartX6)]
231231
232232
233233
234234 @Callable(i)
235235 func constructorV2 (swopfiAddressStr,controlAddressStr,savingsAddressStr) = if ((i.caller != this))
236236 then throw("permissions denied")
237237 else [StringEntry(keySwopfiUsdtUsdnPoolAddress(), validateAddressOrFail(swopfiAddressStr)), StringEntry(keyControlAddress(), validateAddressOrFail(controlAddressStr)), StringEntry(keySavingsAddress(), validateAddressOrFail(savingsAddressStr))]
238238
239239
240240
241241 @Callable(i)
242242 func sumbitApplication () = if ((size(i.payments) != 1))
243243 then throw("exact 1 payment must be attached")
244244 else if ((i.caller != i.originCaller))
245245 then throw("dapp to dapp calls are not allowed")
246246 else {
247247 let pmt = i.payments[0]
248248 let deposit = pmt.amount
249249 let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
250250 let expectedDepositAmount = getIntOrFail(keyDepositAmount())
251251 let txId = toBase58String(i.transactionId)
252252 let nodeAddress = toString(i.caller)
253253 let nodeRegistryKEY = keyNodeRegistry(nodeAddress)
254254 if ((pmtAssetId != WAVESID))
255255 then throw("only Waves can be used for deposit")
256256 else if ((deposit != expectedDepositAmount))
257257 then throw((("exactly " + toString(expectedDepositAmount)) + " Wavelets are expected"))
258258 else if ((getStrOrElse(this, nodeRegistryKEY, "") != ""))
259259 then throw("your node already registered")
260260 else [StringEntry(nodeRegistryKEY, formatDepositAdd(txId, deposit, deposit, "PENDING"))]
261261 }
262262
263263
264264
265265 @Callable(i)
266266 func distributeMinerReward (beneficiaryAddressStr) = {
267267 let minDistributeAmount = valueOrElse(getInteger(this, keyMinDistributeAmount()), (24 * MULT8))
268268 if ((size(i.payments) != 1))
269269 then throw("exact 1 payment must be attached")
270270 else if ((i.caller != i.originCaller))
271271 then throw("dapp to dapp calls are not allowed")
272272 else {
273273 let pmt = i.payments[0]
274274 let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
275275 let feeAmt = i.fee
276276 let feeAssetId = valueOrElse(i.feeAssetId, WAVESID)
277277 let callReward = (feeAmt * 3)
278278 let minedAmt = (pmt.amount - callReward)
279279 if ((pmt.amount != minDistributeAmount))
280280 then throw((("attached payment must be exact " + toString(minDistributeAmount)) + " Wavelets"))
281281 else if ((pmtAssetId != WAVESID))
282282 then throw("only Waves can be used in payment")
283283 else if ((feeAssetId != WAVESID))
284284 then throw("only Waves can be used in fees")
285285 else if ((feeAmt != ((5 * MULT8) / 1000)))
286286 then throw("fee amount couldn't exceed 0.005")
287287 else {
288288 let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
289289 let masterNodeAddress = getAddressOrFail(keyMasterNodeAddressStr())
290290 let minerAddress = i.caller
291291 let beneficiaryFromParam = addressFromStringValue(beneficiaryAddressStr)
292292 let beneficiaryAddress = resolveBeneficiaries(minerAddress, beneficiaryFromParam)
293293 let txRewardReceiver = beneficiaryFromParam
294294 let protocolPart = getIntOrFail(keyProtocolPartX6())
295295 let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
296296 let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
297297 let protocolAmt = (minedAmt - beneficiaryAmt)
298298 let protocolAmt1 = 0
299299 let protocolAmt2 = (protocolAmt - protocolAmt1)
300300 let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
301301 let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [protocolAmt2], nil))
302302 let swopfiAddress = addressFromStringValue(getStrOrElse(this, keySwopfiUsdtUsdnPoolAddress(), "3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG"))
303303 let swopfiResult = asAnyList(invoke(swopfiAddress, "exchange", [1], [AttachedPayment(unit, (protocolAmt2 + savingsAmt))]))
304304 let receivedUsdnAmt = asInt(swopfiResult[0])
305305 let receivedAssetId = asByteVecot(swopfiResult[1])
306306 if ((usdnAssetId != receivedAssetId))
307307 then throw("invalid asset id received during swopfi exchange")
308308 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)]
309309 }
310310 }
311311 }
312312
313313
314314
315315 @Callable(i)
316316 func validateAndApproveLeasings (nListS) = {
317317 let nIdxs = [0, 1, 2, 3, 4, 5, 6, 7]
318318 let nList = split(nListS, SEP)
319319 let expectedCount = size(nIdxs)
320320 let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
321321 if ((i.caller != neutrinoAddress))
322322 then throw("validateAndApproveLeasings not authorized")
323323 else if (((size(nList) % 2) != 0))
324324 then throw("Only even number of nodes is allowed")
325325 else if ((size(nList) != expectedCount))
326326 then throw((("Only " + toString(expectedCount)) + " of nodes' addresses can be passed"))
327327 else {
328328 func forEachNodeChangeStatus (acc,i) = {
329329 let nodeAddr = nList[i]
330330 let nodeDataStr = readNodeDataAndValidateStatus(nodeAddr, "PENDING")
331331 (acc :+ StringEntry(keyNodeRegistry(nodeAddr), formatDepositChangeStatus(nodeDataStr, "APPROVED")))
332332 }
333333
334334 let approvedNodesData = {
335335 let $l = nIdxs
336336 let $s = size($l)
337337 let $acc0 = nil
338338 func $f0_1 ($a,$i) = if (($i >= $s))
339339 then $a
340340 else forEachNodeChangeStatus($a, $l[$i])
341341
342342 func $f0_2 ($a,$i) = if (($i >= $s))
343343 then $a
344344 else throw("List size exceeds 8")
345345
346346 $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)
347347 }
348348 $Tuple2(approvedNodesData, nil)
349349 }
350350 }
351351
352352
353353
354354 @Callable(i)
355355 func replaceApprovedNode (oldNodeAddrStr,newNodeAddrStr,groupNum,penaltyAmount) = if ((i.caller != neutrinoContract))
356356 then throw("permissions denied")
357357 else {
358358 let oldDataStr = readNodeDataAndValidateStatus(oldNodeAddrStr, "APPROVED")
359359 let newDataStr = readNodeDataAndValidateStatus(newNodeAddrStr, "PENDING")
360360 let approvedNodeListS = getStringOrFail(this, keyApprovedNodeList())
361361 if (!(contains(approvedNodeListS, oldNodeAddrStr)))
362362 then throw(("approvedNodeList does not contain " + oldNodeAddrStr))
363363 else {
364- let updatedNodeListS = makeString(split(approvedNodeListS, oldNodeAddrStr), newNodeAddrStr)
364+ let updatedNodeListS = makeString(split_4C(approvedNodeListS, oldNodeAddrStr), newNodeAddrStr)
365365 let oldNodeAddr = addressFromStringValue(oldNodeAddrStr)
366366 let beneficiaryAddress = resolveBeneficiaries(oldNodeAddr, oldNodeAddr)
367367 let depoAmount = parseIntValue(split(oldDataStr, SEP)[nRegIdxDepoAmt])
368368 let actions = [StringEntry(keyApprovedNodeList(), updatedNodeListS), DeleteEntry(keyNodeRegistry(oldNodeAddrStr)), StringEntry(keyNodeRegistry(newNodeAddrStr), formatDepositChangeStatus(newDataStr, "APPROVED"))]
369369 $Tuple2(if ((depoAmount > penaltyAmount))
370370 then (actions :+ ScriptTransfer(beneficiaryAddress, (depoAmount - penaltyAmount), unit))
371371 else actions, unit)
372372 }
373373 }
374374
375375
376376
377377 @Callable(i)
378378 func returnDeposit (nodeAddressStr) = if ((size(i.payments) != 0))
379379 then throw("No payments allowed")
380380 else {
381381 let callerAddress = i.caller
382382 let nodeRegistryKEY = keyNodeRegistry(nodeAddressStr)
383383 let nodeDataOpt = getString(this, nodeRegistryKEY)
384384 if (!(isDefined(nodeDataOpt)))
385385 then throw(("Address is not applied as neutrino node: " + nodeAddressStr))
386386 else {
387387 let approvedNodeList = getStringOrFail(this, keyApprovedNodeList())
388388 if (contains(approvedNodeList, nodeAddressStr))
389389 then throw("Impossible to return deposit from approved Node, please contact support team")
390390 else {
391391 let nodeData = split(value(nodeDataOpt), SEP)
392392 let status = if ((size(nodeData) >= 9))
393393 then nodeData[nRegIdxStatus]
394394 else "PENDING"
395395 if ((status != "PENDING"))
396396 then throw("Application status is not PENDING!")
397397 else {
398398 let depoAmount = parseIntValue(nodeData[nRegIdxDepoAmt])
399399 let nodeAddress = addressFromStringValue(nodeAddressStr)
400400 let beneficiaryAddress = resolveBeneficiaries(nodeAddress, nodeAddress)
401401 if (!(if (if ((callerAddress == this))
402402 then true
403403 else if ((beneficiaryAddress != nodeAddress))
404404 then (callerAddress == beneficiaryAddress)
405405 else false)
406406 then true
407407 else if ((beneficiaryAddress == nodeAddress))
408408 then (callerAddress == nodeAddress)
409409 else false))
410410 then throw("returnDeposit permissions denied")
411411 else [DeleteEntry(nodeRegistryKEY), ScriptTransfer(beneficiaryAddress, depoAmount, unit)]
412412 }
413413 }
414414 }
415415 }
416416
417417

github/deemru/w8io/786bc32 
54.06 ms