tx · 4wR9QRnwzw4fxLsSD92ah6jp8NKGNACNKtAd5Jnb2FfZ

3MsU936briqQ2XZMpkhWdrV8EsNwm5iCuRY:  -0.01700000 Waves

2023.05.11 13:11 [2573082] smart account 3MsU936briqQ2XZMpkhWdrV8EsNwm5iCuRY > SELF 0.00000000 Waves

{ "type": 13, "id": "4wR9QRnwzw4fxLsSD92ah6jp8NKGNACNKtAd5Jnb2FfZ", "fee": 1700000, "feeAssetId": null, "timestamp": 1683799946314, "version": 2, "chainId": 84, "sender": "3MsU936briqQ2XZMpkhWdrV8EsNwm5iCuRY", "senderPublicKey": "F471QhzucRgQCSkZK5opBNc55AoNgiibCabvTp6GZ9nq", "proofs": [ "5oTTtgm7kQuTKprfU58zbYdH6ZYAtEimigJd4Fqyr2rnzErjkoD4Kn7jNrfvQDwxsgwLd92wSikge6VwF22KEpsL" ], "script": "base64:BgIrCAISBwoFAQgIAQESBQoDCAgIEgASAwoBCBIDCgEIEgYKBAgIAQESAwoBCEEAA1NFUAICX18ABU1VTFQ2AMCEPQAFTVVMVDgAgMLXLwAKV0FWRVNJRFNUUgIFV0FWRVMAB1dBVkVTSUQJANkEAQUKV0FWRVNJRFNUUgEMZ2V0SW50T3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQR0aGlzBQNrZXkJAKwCAgkArAICAg9NYW5kYXRvcnkgdGhpcy4FA2tleQIPIGlzIG5vdCBkZWZpbmVkAQxnZXRTdHJPckVsc2UDB2FkZHJlc3MDa2V5CmRlZmF1bHRWYWwJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUHYWRkcmVzcwUDa2V5BQpkZWZhdWx0VmFsAQ9nZXRTdHJpbmdPckZhaWwCB2FkZHJlc3MDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUHYWRkcmVzcwUDa2V5CQCsAgIJAKwCAgIPTWFuZGF0b3J5IHRoaXMuBQNrZXkCDyBpcyBub3QgZGVmaW5lZAEQZ2V0QWRkcmVzc09yRmFpbAEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMFA2tleQkArAICCQCsAgICFUZhaWwgdG8gY29udmVydCB0aGlzLgUDa2V5AhMgdmFsdWUgaW50byBBZGRyZXNzAQlhc0FueUxpc3QBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACCUxpc3RbQW55XQQKdmFsQW55TGlzdAUHJG1hdGNoMAUKdmFsQW55TGlzdAkAAgECG2ZhaWwgdG8gY2FzdCBpbnRvIExpc3RbQW55XQEFYXNJbnQBAXYEByRtYXRjaDAFAXYDCQABAgUHJG1hdGNoMAIDSW50BAFpBQckbWF0Y2gwBQFpCQACAQIVZmFpbCB0byBjYXN0IGludG8gSW50AQthc0J5dGVWZWNvdAEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFpBQckbWF0Y2gwBQFpCQACAQIcZmFpbCB0byBjYXN0IGludG8gQnl0ZVZlY3RvcgEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQphZGRyZXNzU3RyBAdhZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUKYWRkcmVzc1N0cgkArAICAh1mYWlsIHRvIGNvbnZlcnQgaW50byBhZGRyZXNzIAUKYWRkcmVzc1N0cgMJAGYCAAAICQDvBwEFB2FkZHJlc3MJYXZhaWxhYmxlCQEFdGhyb3cABQphZGRyZXNzU3RyAQ9rZXlOb2RlUmVnaXN0cnkBB2FkZHJlc3MJAKwCAgIEJXNfXwUHYWRkcmVzcwEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBB2FkZHJlc3MJAKwCAgIOJXMlc19fdG90YWxzX18FB2FkZHJlc3MBE2tleUFwcHJvdmVkTm9kZUxpc3QAAhQlc19fYXBwcm92ZWROb2RlTGlzdAEQa2V5RGVwb3NpdEFtb3VudAACGCVzJXNfX2NmZ19fZGVwb3NpdEFtb3VudAEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAIaJXMlc19fY2ZnX19uZXV0cmlub0FkZHJlc3MBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAIiJXMlc19fY2ZnX19tYWluTmV1dHJpbm9Ob2RlQWRkcmVzcwERa2V5UHJvdG9jb2xQYXJ0WDYAAhklcyVzX19jZmdfX3Byb3RvY29sUGFydFg2ARNrZXlCZW5pZmljYXJ5UGFydFg2AAIbJXMlc19fY2ZnX19iZW5pZmljYXJ5UGFydFg2ARZrZXlNaW5EaXN0cmlidXRlQW1vdW50AAIeJXMlc19fY2ZnX19taW5EaXN0cmlidXRlQW1vdW50ARxrZXlTd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzAAIkJXMlc19fY2ZnX19zd29wZmlVc2R0VXNkblBvb2xBZGRyZXNzARFrZXlTYXZpbmdzQWRkcmVzcwACGSVzJXNfX2NmZ19fc2F2aW5nc0FkZHJlc3MBFWtleUJlbmVmaWNpYXJ5QWRkcmVzcwACHSVzJXNfX2NmZ19fYmVuZWZpY2lhcnlBZGRyZXNzABlJZHhDb250cm9sQ2ZnTmV1dHJpbm9EYXBwAAEAGElkeENvbnRyb2xDZmdBdWN0aW9uRGFwcAACABRJZHhDb250cm9sQ2ZnUnBkRGFwcAADABVJZHhDb250cm9sQ2ZnTWF0aERhcHAABAAcSWR4Q29udHJvbENmZ0xpcXVpZGF0aW9uRGFwcAAFABVJZHhDb250cm9sQ2ZnUmVzdERhcHAABgAdSWR4Q29udHJvbENmZ05vZGVSZWdpc3RyeURhcHAABwAcSWR4Q29udHJvbENmZ05zYnRTdGFraW5nRGFwcAAIABlJZHhDb250cm9sQ2ZnTWVkaWF0b3JEYXBwAAkAHElkeENvbnRyb2xDZmdTdXJmU3Rha2luZ0RhcHAACgAgSWR4Q29udHJvbENmZ0duc2J0Q29udHJvbGxlckRhcHAACwAXSWR4Q29udHJvbENmZ1Jlc3RWMkRhcHAADAAbSWR4Q29udHJvbENmZ0dvdmVybmFuY2VEYXBwAA0BEWtleUNvbnRyb2xBZGRyZXNzAAIcJXMlc19fY29uZmlnX19jb250cm9sQWRkcmVzcwENa2V5Q29udHJvbENmZwACESVzX19jb250cm9sQ29uZmlnAQ5rZXlVc2RuQXNzZXRJZAACEW5ldXRyaW5vX2Fzc2V0X2lkARRyZWFkQ29udHJvbENmZ09yRmFpbAEHY29udHJvbAkAvAkCCQEPZ2V0U3RyaW5nT3JGYWlsAgUHY29udHJvbAkBDWtleUNvbnRyb2xDZmcABQNTRVABGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIKY29udHJvbENmZwNpZHgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFCmNvbnRyb2xDZmcFA2lkeAkArAICAi1Db250cm9sIGNmZyBkb2Vzbid0IGNvbnRhaW4gYWRkcmVzcyBhdCBpbmRleCAJAKQDAQUDaWR4AA9jb250cm9sQ29udHJhY3QJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkBEWtleUNvbnRyb2xBZGRyZXNzAAIjM040TlM3ZDRKbzlhNkYxNExpRlVLS1lWZFVra2YyZVA0WngACmNvbnRyb2xDZmcJARRyZWFkQ29udHJvbENmZ09yRmFpbAEFD2NvbnRyb2xDb250cmFjdAAQbmV1dHJpbm9Db250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFCmNvbnRyb2xDZmcFGUlkeENvbnRyb2xDZmdOZXV0cmlub0RhcHAADnVzZG5Bc3NldElkU3RyCQEMZ2V0U3RyT3JFbHNlAwUQbmV1dHJpbm9Db250cmFjdAkBDmtleVVzZG5Bc3NldElkAAIsSGV6c2RRdVJEdHprc0FZVXk5N2dmaEt5N1oxTlcydVhZU0hBM2JncWVuTloAC3VzZG5Bc3NldElkCQDZBAEFDnVzZG5Bc3NldElkU3RyAAxuUmVnSWR4VHhBZGQAAQAQblJlZ0lkeEhlaWdodEFkZAACAA5uUmVnSWR4VGltZUFkZAADAA5uUmVnSWR4RGVwb0FtdAAEABJuUmVnSWR4RGVwb0FtdExlZnQABQANblJlZ0lkeFN0YXR1cwAGABluUmVnSWR4U3RhdHVzQ2hhbmdlSGVpZ2h0AAcAF25SZWdJZHhTdGF0dXNDaGFuZ2VUaW1lAAgBEGZvcm1hdERlcG9zaXRBZGQEB3R4SWRTdHINZGVwb3NpdEFtb3VudBZyZW1haW5pbmdEZXBvc2l0QW1vdW50BnN0YXR1cwkAuQkCCQDMCAICECVzJWQlZCVkJWQlcyVkJWQJAMwIAgUHdHhJZFN0cgkAzAgCCQCkAwEIBQlsYXN0QmxvY2sGaGVpZ2h0CQDMCAIJAKQDAQgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkApAMBBQ1kZXBvc2l0QW1vdW50CQDMCAIJAKQDAQUWcmVtYWluaW5nRGVwb3NpdEFtb3VudAkAzAgCBQZzdGF0dXMJAMwIAgIBMAkAzAgCAgEwBQNuaWwFA1NFUAEZZm9ybWF0RGVwb3NpdENoYW5nZVN0YXR1cwIFb3JpZ1MJbmV3U3RhdHVzBARvcmlnCQC1CQIFBW9yaWdTBQNTRVAJALkJAgkAzAgCAhAlcyVkJWQlZCVkJXMlZCVkCQDMCAIJAJEDAgUEb3JpZwUMblJlZ0lkeFR4QWRkCQDMCAIJAJEDAgUEb3JpZwUQblJlZ0lkeEhlaWdodEFkZAkAzAgCCQCRAwIFBG9yaWcFDm5SZWdJZHhUaW1lQWRkCQDMCAIJAJEDAgUEb3JpZwUOblJlZ0lkeERlcG9BbXQJAMwIAgkAkQMCBQRvcmlnBRJuUmVnSWR4RGVwb0FtdExlZnQJAMwIAgUJbmV3U3RhdHVzCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUDbmlsBQNTRVABEGtleVJld2FyZEhpc3RvcnkCC25vZGVBZGRyZXNzBHR4SWQJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIHaGlzdG9yeQkAzAgCCQClCAEFC25vZGVBZGRyZXNzCQDMCAIJANgEAQUEdHhJZAUDbmlsBQNTRVABEWRhdGFSZXdhcmRIaXN0b3J5BRB3YXZlc0Ftb3VudFRvdGFsDmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICDiVkJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQgFCWxhc3RCbG9jawZoZWlnaHQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQCkAwEFEHdhdmVzQW1vdW50VG90YWwJAMwIAgkApAMBBQ5iZW5lZmljaWFyeUFtdAkAzAgCCQCkAwEFC3Byb3RvY29sQW10CQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MQkAzAgCCQCkAwEFEHByb3RvY29sQW10UGFydDIFA25pbAUDU0VQARJSZXdhcmRIaXN0b3J5RW50cnkHC25vZGVBZGRyZXNzBHR4SWQIbWluZWRBbXQOYmVuZWZpY2lhcnlBbXQLcHJvdG9jb2xBbXQMcHJvdG9jb2xBbXQxDHByb3RvY29sQW10MgkBC1N0cmluZ0VudHJ5AgkBEGtleVJld2FyZEhpc3RvcnkCBQtub2RlQWRkcmVzcwUEdHhJZAkBEWRhdGFSZXdhcmRIaXN0b3J5BQUIbWluZWRBbXQFDmJlbmVmaWNpYXJ5QW10BQtwcm90b2NvbEFtdAUMcHJvdG9jb2xBbXQxBQxwcm90b2NvbEFtdDIBEGRhdGFSZXdhcmRUb3RhbHMFCG1pbmVkQW10DmJlbmVmaWNpYXJ5QW10C3Byb3RvY29sQW10EHByb3RvY29sQW10UGFydDEQcHJvdG9jb2xBbXRQYXJ0MgkAuQkCCQDMCAICCiVkJWQlZCVkJWQJAMwIAgkApAMBBQhtaW5lZEFtdAkAzAgCCQCkAwEFDmJlbmVmaWNpYXJ5QW10CQDMCAIJAKQDAQULcHJvdG9jb2xBbXQJAMwIAgkApAMBBRBwcm90b2NvbEFtdFBhcnQxCQDMCAIJAKQDAQUQcHJvdG9jb2xBbXRQYXJ0MgUDbmlsBQNTRVABEVJld2FyZFRvdGFsc0VudHJ5BgVtaW5lcghtaW5lZEFtdA5iZW5lZmljaWFyeUFtdAtwcm90b2NvbEFtdBBwcm90b2NvbEFtdFBhcnQxEHByb3RvY29sQW10UGFydDIEFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEUa2V5Tm9kZVJld2FyZHNUb3RhbHMBCQClCAEFBW1pbmVyBBBub2RlUmV3YXJkc0FycmF5CQC1CQIJAQxnZXRTdHJPckVsc2UDBQR0aGlzBRRub2RlUmV3YXJkc1RvdGFsc0tFWQkBEGRhdGFSZXdhcmRUb3RhbHMFAAAAAAAAAAAAAAUDU0VQBAtuZXdNaW5lZEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAEFCG1pbmVkQW10BBFuZXdCZW5lZmljaWFyeUFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAIFDmJlbmVmaWNpYXJ5QW10BA5uZXdQcm90b2NvbEFtdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAMFC3Byb3RvY29sQW10BBNuZXdQcm90b2NvbEFtdFBhcnQxCQBkAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFEG5vZGVSZXdhcmRzQXJyYXkABAUQcHJvdG9jb2xBbXRQYXJ0MQQTbmV3UHJvdG9jb2xBbXRQYXJ0MgkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBRBub2RlUmV3YXJkc0FycmF5AAUFEHByb3RvY29sQW10UGFydDIJAQtTdHJpbmdFbnRyeQIFFG5vZGVSZXdhcmRzVG90YWxzS0VZCQEQZGF0YVJld2FyZFRvdGFscwUFC25ld01pbmVkQW10BRFuZXdCZW5lZmljaWFyeUFtdAUObmV3UHJvdG9jb2xBbXQFE25ld1Byb3RvY29sQW10UGFydDEFE25ld1Byb3RvY29sQW10UGFydDIBFHJlc29sdmVCZW5lZmljaWFyaWVzAgxtaW5lckFkZHJlc3MUYmVuZWZpY2lhcnlGcm9tUGFyYW0EGWJlbmVmaWNpYXJ5RnJvbU1pbmVyU3RhdGUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQ9nZXRTdHJpbmdPckZhaWwCBQxtaW5lckFkZHJlc3MJARVrZXlCZW5lZmljaWFyeUFkZHJlc3MAAwkAAAIJAPEHAQUMbWluZXJBZGRyZXNzBQR1bml0BRRiZW5lZmljaWFyeUZyb21QYXJhbQUZYmVuZWZpY2lhcnlGcm9tTWluZXJTdGF0ZQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCCG5vZGVBZGRyDmV4cGVjdGVkU3RhdHVzBAtub2RlRGF0YU9wdAkAoggBCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUIbm9kZUFkZHIDCQEBIQEJAQlpc0RlZmluZWQBBQtub2RlRGF0YU9wdAkAAgEJAKwCAgINVW5rbm93biBOb2RlIAUIbm9kZUFkZHIEC25vZGVEYXRhU3RyCQEFdmFsdWUBBQtub2RlRGF0YU9wdAQIbm9kZURhdGEJALUJAgULbm9kZURhdGFTdHIFA1NFUAQKbm9kZVN0YXR1cwMJAGcCCQCQAwEFCG5vZGVEYXRhAAkJAJEDAgUIbm9kZURhdGEFDW5SZWdJZHhTdGF0dXMCB1BFTkRJTkcDCQECIT0CBQpub2RlU3RhdHVzBQ5leHBlY3RlZFN0YXR1cwkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgVOb2RlIAUIbm9kZUFkZHICEiBzdGF0dXMgc2hvdWxkIGJlIAUOZXhwZWN0ZWRTdGF0dXMCDywgYnV0IGFjdHVhbGx5IAUKbm9kZVN0YXR1cwULbm9kZURhdGFTdHIHAWkBDWNvbnN0cnVjdG9yVjEFDWRlcG9zaXRBbW91bnQSbmV1dHJpbm9BZGRyZXNzU3RyFG1hc3Rlck5vZGVBZGRyZXNzU3RyDnByb3RvY29sUGFydFg2EGJlbmlmaWNhcnlQYXJ0WDYDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhJwZXJtaXNzaW9ucyBkZW5pZWQDCQBmAgAABQ1kZXBvc2l0QW1vdW50CQACAQIcZGVwb3NpdEFtb3VudCBsZXNzIHRoZW4gemVybwMJAGYCAAAFDnByb3RvY29sUGFydFg2CQACAQIdcHJvdG9jb2xQYXJ0WDYgbGVzcyB0aGVuIHplcm8DCQBmAgAABRBiZW5pZmljYXJ5UGFydFg2CQACAQIfYmVuaWZpY2FyeVBhcnRYNiBsZXNzIHRoZW4gemVybwMJAQIhPQIJAGQCBQ5wcm90b2NvbFBhcnRYNgUQYmVuaWZpY2FyeVBhcnRYNgUFTVVMVDYJAAIBAhNwYXJ0cyBzdW0gbXVzdCBiZSAxCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEQa2V5RGVwb3NpdEFtb3VudAAFDWRlcG9zaXRBbW91bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBFWtleU5ldXRyaW5vQWRkcmVzc1N0cgAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRJuZXV0cmlub0FkZHJlc3NTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAkBFXZhbGlkYXRlQWRkcmVzc09yRmFpbAEFFG1hc3Rlck5vZGVBZGRyZXNzU3RyCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQERa2V5UHJvdG9jb2xQYXJ0WDYABQ5wcm90b2NvbFBhcnRYNgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBE2tleUJlbmlmaWNhcnlQYXJ0WDYABRBiZW5pZmljYXJ5UGFydFg2BQNuaWwBaQENY29uc3RydWN0b3JWMgMQc3dvcGZpQWRkcmVzc1N0chFjb250cm9sQWRkcmVzc1N0chFzYXZpbmdzQWRkcmVzc1N0cgMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECEnBlcm1pc3Npb25zIGRlbmllZAkAzAgCCQELU3RyaW5nRW50cnkCCQEca2V5U3dvcGZpVXNkdFVzZG5Qb29sQWRkcmVzcwAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRBzd29wZmlBZGRyZXNzU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQIJARFrZXlDb250cm9sQWRkcmVzcwAJARV2YWxpZGF0ZUFkZHJlc3NPckZhaWwBBRFjb250cm9sQWRkcmVzc1N0cgkAzAgCCQELU3RyaW5nRW50cnkCCQERa2V5U2F2aW5nc0FkZHJlc3MACQEVdmFsaWRhdGVBZGRyZXNzT3JGYWlsAQURc2F2aW5nc0FkZHJlc3NTdHIFA25pbAFpARFzdW1iaXRBcHBsaWNhdGlvbgADCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAiBleGFjdCAxIHBheW1lbnQgbXVzdCBiZSBhdHRhY2hlZAMJAQIhPQIIBQFpBmNhbGxlcggFAWkMb3JpZ2luQ2FsbGVyCQACAQIiZGFwcCB0byBkYXBwIGNhbGxzIGFyZSBub3QgYWxsb3dlZAQDcG10CQCRAwIIBQFpCHBheW1lbnRzAAAEB2RlcG9zaXQIBQNwbXQGYW1vdW50BApwbXRBc3NldElkCQELdmFsdWVPckVsc2UCCAUDcG10B2Fzc2V0SWQFB1dBVkVTSUQEFWV4cGVjdGVkRGVwb3NpdEFtb3VudAkBDGdldEludE9yRmFpbAEJARBrZXlEZXBvc2l0QW1vdW50AAQEdHhJZAkA2AQBCAUBaQ10cmFuc2FjdGlvbklkBAtub2RlQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIED25vZGVSZWdpc3RyeUtFWQkBD2tleU5vZGVSZWdpc3RyeQEFC25vZGVBZGRyZXNzAwkBAiE9AgUKcG10QXNzZXRJZAUHV0FWRVNJRAkAAgECIm9ubHkgV2F2ZXMgY2FuIGJlIHVzZWQgZm9yIGRlcG9zaXQDCQECIT0CBQdkZXBvc2l0BRVleHBlY3RlZERlcG9zaXRBbW91bnQJAAIBCQCsAgIJAKwCAgIIZXhhY3RseSAJAKQDAQUVZXhwZWN0ZWREZXBvc2l0QW1vdW50AhYgV2F2ZWxldHMgYXJlIGV4cGVjdGVkAwkBAiE9AgkBDGdldFN0ck9yRWxzZQMFBHRoaXMFD25vZGVSZWdpc3RyeUtFWQIAAgAJAAIBAhx5b3VyIG5vZGUgYWxyZWFkeSByZWdpc3RlcmVkCQDMCAIJAQtTdHJpbmdFbnRyeQIFD25vZGVSZWdpc3RyeUtFWQkBEGZvcm1hdERlcG9zaXRBZGQEBQR0eElkBQdkZXBvc2l0BQdkZXBvc2l0AgdQRU5ESU5HBQNuaWwBaQEVZGlzdHJpYnV0ZU1pbmVyUmV3YXJkARViZW5lZmljaWFyeUFkZHJlc3NTdHIEE21pbkRpc3RyaWJ1dGVBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBFmtleU1pbkRpc3RyaWJ1dGVBbW91bnQACQBoAgAYBQVNVUxUOAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECIGV4YWN0IDEgcGF5bWVudCBtdXN0IGJlIGF0dGFjaGVkAwkBAiE9AggFAWkGY2FsbGVyCAUBaQxvcmlnaW5DYWxsZXIJAAIBAiJkYXBwIHRvIGRhcHAgY2FsbHMgYXJlIG5vdCBhbGxvd2VkBANwbXQJAJEDAggFAWkIcGF5bWVudHMAAAQKcG10QXNzZXRJZAkBC3ZhbHVlT3JFbHNlAggFA3BtdAdhc3NldElkBQdXQVZFU0lEBAZmZWVBbXQIBQFpA2ZlZQQKZmVlQXNzZXRJZAkBC3ZhbHVlT3JFbHNlAggFAWkKZmVlQXNzZXRJZAUHV0FWRVNJRAQKY2FsbFJld2FyZAkAaAIFBmZlZUFtdAADBAhtaW5lZEFtdAkAZQIIBQNwbXQGYW1vdW50BQpjYWxsUmV3YXJkAwkBAiE9AggFA3BtdAZhbW91bnQFE21pbkRpc3RyaWJ1dGVBbW91bnQJAAIBCQCsAgIJAKwCAgIfYXR0YWNoZWQgcGF5bWVudCBtdXN0IGJlIGV4YWN0IAkApAMBBRNtaW5EaXN0cmlidXRlQW1vdW50AgkgV2F2ZWxldHMDCQECIT0CBQpwbXRBc3NldElkBQdXQVZFU0lECQACAQIhb25seSBXYXZlcyBjYW4gYmUgdXNlZCBpbiBwYXltZW50AwkBAiE9AgUKZmVlQXNzZXRJZAUHV0FWRVNJRAkAAgECHm9ubHkgV2F2ZXMgY2FuIGJlIHVzZWQgaW4gZmVlcwMJAQIhPQIFBmZlZUFtdAkAaQIJAGgCAAUFBU1VTFQ4AOgHCQACAQIgZmVlIGFtb3VudCBjb3VsZG4ndCBleGNlZWQgMC4wMDUED25ldXRyaW5vQWRkcmVzcwkBEGdldEFkZHJlc3NPckZhaWwBCQEVa2V5TmV1dHJpbm9BZGRyZXNzU3RyAAQRbWFzdGVyTm9kZUFkZHJlc3MJARBnZXRBZGRyZXNzT3JGYWlsAQkBF2tleU1hc3Rlck5vZGVBZGRyZXNzU3RyAAQMbWluZXJBZGRyZXNzCAUBaQZjYWxsZXIEFGJlbmVmaWNpYXJ5RnJvbVBhcmFtCQERQGV4dHJOYXRpdmUoMTA2MikBBRViZW5lZmljaWFyeUFkZHJlc3NTdHIEEmJlbmVmaWNpYXJ5QWRkcmVzcwkBFHJlc29sdmVCZW5lZmljaWFyaWVzAgUMbWluZXJBZGRyZXNzBRRiZW5lZmljaWFyeUZyb21QYXJhbQQQdHhSZXdhcmRSZWNlaXZlcgUUYmVuZWZpY2lhcnlGcm9tUGFyYW0EDHByb3RvY29sUGFydAkBDGdldEludE9yRmFpbAEJARFrZXlQcm90b2NvbFBhcnRYNgAED2JlbmVmaWNpYXJ5UGFydAkBDGdldEludE9yRmFpbAEJARNrZXlCZW5pZmljYXJ5UGFydFg2AAQOYmVuZWZpY2lhcnlBbXQJAGsDBQhtaW5lZEFtdAUPYmVuZWZpY2lhcnlQYXJ0BQVNVUxUNgQLcHJvdG9jb2xBbXQJAGUCBQhtaW5lZEFtdAUOYmVuZWZpY2lhcnlBbXQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUSYmVuZWZpY2lhcnlBZGRyZXNzBQ5iZW5lZmljaWFyeUFtdAUEdW5pdAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRBuZXV0cmlub0NvbnRyYWN0BQtwcm90b2NvbEFtdAUEdW5pdAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRB0eFJld2FyZFJlY2VpdmVyBQpjYWxsUmV3YXJkBQR1bml0CQDMCAIJARJSZXdhcmRIaXN0b3J5RW50cnkHBQxtaW5lckFkZHJlc3MIBQFpDXRyYW5zYWN0aW9uSWQFCG1pbmVkQW10BQ5iZW5lZmljaWFyeUFtdAULcHJvdG9jb2xBbXQFC3Byb3RvY29sQW10AAAJAMwIAgkBEVJld2FyZFRvdGFsc0VudHJ5BgUMbWluZXJBZGRyZXNzBQhtaW5lZEFtdAUOYmVuZWZpY2lhcnlBbXQFC3Byb3RvY29sQW10BQtwcm90b2NvbEFtdAAABQNuaWwBaQEadmFsaWRhdGVBbmRBcHByb3ZlTGVhc2luZ3MBBm5MaXN0UwQFbklkeHMJAMwIAgAACQDMCAIAAQkAzAgCAAIJAMwIAgADCQDMCAIABAkAzAgCAAUJAMwIAgAGCQDMCAIABwUDbmlsBAVuTGlzdAkAtQkCBQZuTGlzdFMFA1NFUAQNZXhwZWN0ZWRDb3VudAkAkAMBBQVuSWR4cwQPbmV1dHJpbm9BZGRyZXNzCQEQZ2V0QWRkcmVzc09yRmFpbAEJARVrZXlOZXV0cmlub0FkZHJlc3NTdHIAAwkBAiE9AggFAWkGY2FsbGVyBQ9uZXV0cmlub0FkZHJlc3MJAAIBAil2YWxpZGF0ZUFuZEFwcHJvdmVMZWFzaW5ncyBub3QgYXV0aG9yaXplZAMJAQIhPQIJAGoCCQCQAwEFBW5MaXN0AAIAAAkAAgECJE9ubHkgZXZlbiBudW1iZXIgb2Ygbm9kZXMgaXMgYWxsb3dlZAMJAQIhPQIJAJADAQUFbkxpc3QFDWV4cGVjdGVkQ291bnQJAAIBCQCsAgIJAKwCAgIFT25seSAJAKQDAQUNZXhwZWN0ZWRDb3VudAIiIG9mIG5vZGVzJyBhZGRyZXNzZXMgY2FuIGJlIHBhc3NlZAoBF2ZvckVhY2hOb2RlQ2hhbmdlU3RhdHVzAgNhY2MBaQQIbm9kZUFkZHIJAJEDAgUFbkxpc3QFAWkEC25vZGVEYXRhU3RyCQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCBQhub2RlQWRkcgIHUEVORElORwkAzQgCBQNhY2MJAQtTdHJpbmdFbnRyeQIJAQ9rZXlOb2RlUmVnaXN0cnkBBQhub2RlQWRkcgkBGWZvcm1hdERlcG9zaXRDaGFuZ2VTdGF0dXMCBQtub2RlRGF0YVN0cgIIQVBQUk9WRUQEEWFwcHJvdmVkTm9kZXNEYXRhCgACJGwFBW5JZHhzCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARdmb3JFYWNoTm9kZUNoYW5nZVN0YXR1cwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgOAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgJAJQKAgURYXBwcm92ZWROb2Rlc0RhdGEFA25pbAFpARNyZXBsYWNlQXBwcm92ZWROb2RlBA5vbGROb2RlQWRkclN0cg5uZXdOb2RlQWRkclN0cghncm91cE51bQ1wZW5hbHR5QW1vdW50AwkBAiE9AggFAWkGY2FsbGVyBRBuZXV0cmlub0NvbnRyYWN0CQACAQIScGVybWlzc2lvbnMgZGVuaWVkBApvbGREYXRhU3RyCQEdcmVhZE5vZGVEYXRhQW5kVmFsaWRhdGVTdGF0dXMCBQ5vbGROb2RlQWRkclN0cgIIQVBQUk9WRUQECm5ld0RhdGFTdHIJAR1yZWFkTm9kZURhdGFBbmRWYWxpZGF0ZVN0YXR1cwIFDm5ld05vZGVBZGRyU3RyAgdQRU5ESU5HBBFhcHByb3ZlZE5vZGVMaXN0UwkBD2dldFN0cmluZ09yRmFpbAIFBHRoaXMJARNrZXlBcHByb3ZlZE5vZGVMaXN0AAMJAQEhAQkBCGNvbnRhaW5zAgURYXBwcm92ZWROb2RlTGlzdFMFDm9sZE5vZGVBZGRyU3RyCQACAQkArAICAiJhcHByb3ZlZE5vZGVMaXN0IGRvZXMgbm90IGNvbnRhaW4gBQ5vbGROb2RlQWRkclN0cgQQdXBkYXRlZE5vZGVMaXN0UwkAugkCCQC8CQIFEWFwcHJvdmVkTm9kZUxpc3RTBQ5vbGROb2RlQWRkclN0cgUObmV3Tm9kZUFkZHJTdHIEC29sZE5vZGVBZGRyCQERQGV4dHJOYXRpdmUoMTA2MikBBQ5vbGROb2RlQWRkclN0cgQSYmVuZWZpY2lhcnlBZGRyZXNzCQEUcmVzb2x2ZUJlbmVmaWNpYXJpZXMCBQtvbGROb2RlQWRkcgULb2xkTm9kZUFkZHIECmRlcG9BbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCCQC1CQIFCm9sZERhdGFTdHIFA1NFUAUOblJlZ0lkeERlcG9BbXQEB2FjdGlvbnMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBE2tleUFwcHJvdmVkTm9kZUxpc3QABRB1cGRhdGVkTm9kZUxpc3RTCQDMCAIJAQtEZWxldGVFbnRyeQEJAQ9rZXlOb2RlUmVnaXN0cnkBBQ5vbGROb2RlQWRkclN0cgkAzAgCCQELU3RyaW5nRW50cnkCCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUObmV3Tm9kZUFkZHJTdHIJARlmb3JtYXREZXBvc2l0Q2hhbmdlU3RhdHVzAgUKbmV3RGF0YVN0cgIIQVBQUk9WRUQFA25pbAkAlAoCAwkAZgIFCmRlcG9BbW91bnQFDXBlbmFsdHlBbW91bnQJAM0IAgUHYWN0aW9ucwkBDlNjcmlwdFRyYW5zZmVyAwUSYmVuZWZpY2lhcnlBZGRyZXNzCQBlAgUKZGVwb0Ftb3VudAUNcGVuYWx0eUFtb3VudAUEdW5pdAUHYWN0aW9ucwUEdW5pdAFpAQ1yZXR1cm5EZXBvc2l0AQ5ub2RlQWRkcmVzc1N0cgMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAAkAAgECE05vIHBheW1lbnRzIGFsbG93ZWQEDWNhbGxlckFkZHJlc3MIBQFpBmNhbGxlcgQPbm9kZVJlZ2lzdHJ5S0VZCQEPa2V5Tm9kZVJlZ2lzdHJ5AQUObm9kZUFkZHJlc3NTdHIEC25vZGVEYXRhT3B0CQCdCAIFBHRoaXMFD25vZGVSZWdpc3RyeUtFWQMJAQEhAQkBCWlzRGVmaW5lZAEFC25vZGVEYXRhT3B0CQACAQkArAICAilBZGRyZXNzIGlzIG5vdCBhcHBsaWVkIGFzIG5ldXRyaW5vIG5vZGU6IAUObm9kZUFkZHJlc3NTdHIEEGFwcHJvdmVkTm9kZUxpc3QJAQ9nZXRTdHJpbmdPckZhaWwCBQR0aGlzCQETa2V5QXBwcm92ZWROb2RlTGlzdAADCQEIY29udGFpbnMCBRBhcHByb3ZlZE5vZGVMaXN0BQ5ub2RlQWRkcmVzc1N0cgkAAgECTEltcG9zc2libGUgdG8gcmV0dXJuIGRlcG9zaXQgZnJvbSBhcHByb3ZlZCBOb2RlLCBwbGVhc2UgY29udGFjdCBzdXBwb3J0IHRlYW0ECG5vZGVEYXRhCQC1CQIJAQV2YWx1ZQEFC25vZGVEYXRhT3B0BQNTRVAEBnN0YXR1cwMJAGcCCQCQAwEFCG5vZGVEYXRhAAkJAJEDAgUIbm9kZURhdGEFDW5SZWdJZHhTdGF0dXMCB1BFTkRJTkcDCQECIT0CBQZzdGF0dXMCB1BFTkRJTkcJAAIBAiJBcHBsaWNhdGlvbiBzdGF0dXMgaXMgbm90IFBFTkRJTkchBApkZXBvQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIbm9kZURhdGEFDm5SZWdJZHhEZXBvQW10BAtub2RlQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUObm9kZUFkZHJlc3NTdHIEEmJlbmVmaWNpYXJ5QWRkcmVzcwkBFHJlc29sdmVCZW5lZmljaWFyaWVzAgULbm9kZUFkZHJlc3MFC25vZGVBZGRyZXNzAwkBASEBAwMJAAACBQ1jYWxsZXJBZGRyZXNzBQR0aGlzBgMJAQIhPQIFEmJlbmVmaWNpYXJ5QWRkcmVzcwULbm9kZUFkZHJlc3MJAAACBQ1jYWxsZXJBZGRyZXNzBRJiZW5lZmljaWFyeUFkZHJlc3MHBgMJAAACBRJiZW5lZmljaWFyeUFkZHJlc3MFC25vZGVBZGRyZXNzCQAAAgUNY2FsbGVyQWRkcmVzcwULbm9kZUFkZHJlc3MHCQACAQIgcmV0dXJuRGVwb3NpdCBwZXJtaXNzaW9ucyBkZW5pZWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQUPbm9kZVJlZ2lzdHJ5S0VZCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFEmJlbmVmaWNpYXJ5QWRkcmVzcwUKZGVwb0Ftb3VudAUEdW5pdAUDbmlsAJCYUVc=", "height": 2573082, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 2Aizk9BvQhe4hE4fKr7ESsrye6nc7wiqJMWSHWinh8fb Next: G1vnLuVSWZN34BCWEe9gYcLS1Wkq2HJ6FkD3d8Ag7Hx1 Diff:
OldNewDifferences
1212 let WAVESID = fromBase58String(WAVESIDSTR)
1313
1414 func getIntOrFail (key) = valueOrErrorMessage(getInteger(this, key), (("Mandatory this." + key) + " is not defined"))
15-
16-
17-func getIntOrElse (key,val) = valueOrElse(getInteger(this, key), val)
1815
1916
2017 func getStrOrElse (address,key,defaultVal) = valueOrElse(getString(address, key), defaultVal)
8885 func keySwopfiUsdtUsdnPoolAddress () = "%s%s__cfg__swopfiUsdtUsdnPoolAddress"
8986
9087
91-func keyWxSwapAddress () = "%s%s__cfg__wxSwapAddress"
92-
93-
9488 func keySavingsAddress () = "%s%s__cfg__savingsAddress"
9589
9690
9791 func keyBeneficiaryAddress () = "%s%s__cfg__beneficiaryAddress"
98-
99-
100-func keyNodesVotingNextNum () = "%s%s__nodesVotingCfg__nextVotingNum"
101-
102-
103-func keyNodesVotingOptionKey (votingNum,optionNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, optionNum], SEP)
104-
105-
106-func keyNodesVotingDesc (votingNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, "description"], SEP)
107-
108-
109-func keyNodesVotingStartHeight (votingNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, "votingStartHeight"], SEP)
110-
111-
112-func keyNodesVotingEndHeight (votingNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, "votingEndHeight"], SEP)
113-
114-
115-func keyNodesVotingOptionTotalVotes (votingNum,optionNum) = makeString(["%s%d%s%s__nodesVotingData", votingNum, "optionTotalVotes", optionNum], SEP)
116-
117-
118-func keyNodesVotingNodeChoice (votingNum,nodeAddressStr) = makeString(["%s%d%s%s__nodesVotingData", votingNum, "nodeChoice", nodeAddressStr], SEP)
11992
12093
12194 let IdxControlCfgNeutrinoDapp = 1
322295 let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
323296 let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
324297 let protocolAmt = (minedAmt - beneficiaryAmt)
325- let buyBackAmt = (120 * MULT8)
326- let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
327- let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [buyBackAmt], nil))
328- let wxAssetIdStr = "Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on"
329- let wxSwapAddress = addressFromStringValue(getStrOrElse(this, keyWxSwapAddress(), "3P68zNiufsu1viZpu1aY3cdahRRKcvV5N93"))
330- let swapResult = invoke(wxSwapAddress, "swap", [1, wxAssetIdStr, toString(neutrinoContract)], [AttachedPayment(unit, savingsAmt)])
331- if ((swapResult == swapResult))
332- 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)]
333- else throw("Strict value is not equal to itself.")
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)]
334299 }
335300 }
336301 }
440405 }
441406
442407
443-
444-@Callable(i)
445-func initNodesVoting (startHeight,endHeight,options,description) = if ((i.caller != this))
446- then throw("permissions denied")
447- else {
448- let optionsArray = split(options, "__")
449- if (((size(optionsArray) % 2) != 0))
450- then throw("Not even number of options")
451- else if (((size(optionsArray) / 2) > 10))
452- then throw("Max 10 options can be specified")
453- else {
454- let nodesVotingNumKEY = keyNodesVotingNextNum()
455- let votingNum = getIntOrElse(nodesVotingNumKEY, 0)
456- let votingNumStr = toString(votingNum)
457- func transformOptions (accum,nextOpt) = {
458- let optData = split(nextOpt, ":")
459- let opt = optData[0]
460- let optKEY = keyNodesVotingOptionKey(votingNumStr, opt)
461- let optDescr = optData[1]
462- let optTotalVotesKEY = keyNodesVotingOptionTotalVotes(votingNumStr, opt)
463- ((accum :+ StringEntry(optKEY, optDescr)) :+ IntegerEntry(optTotalVotesKEY, 0))
464- }
465-
466- (((({
467- let $l = optionsArray
468- let $s = size($l)
469- let $acc0 = nil
470- func $f0_1 ($a,$i) = if (($i >= $s))
471- then $a
472- else transformOptions($a, $l[$i])
473-
474- func $f0_2 ($a,$i) = if (($i >= $s))
475- then $a
476- else throw("List size exceeds 10")
477-
478- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
479- } :+ IntegerEntry(nodesVotingNumKEY, (votingNum + 1))) :+ StringEntry(keyNodesVotingDesc(votingNumStr), description)) :+ IntegerEntry(keyNodesVotingStartHeight(votingNumStr), startHeight)) :+ IntegerEntry(keyNodesVotingEndHeight(votingNumStr), endHeight))
480- }
481- }
482-
483-
484-
485-@Callable(i)
486-func voteByNode (nodeAddressStr,votingNum,optionNum) = {
487- let validateNode = readNodeDataAndValidateStatus(nodeAddressStr, "APPROVED")
488- if ((validateNode == validateNode))
489- then {
490- let nodeAddress = addressFromStringValue(nodeAddressStr)
491- let nodeBeneficiary = getStringOrFail(nodeAddress, keyBeneficiaryAddress())
492- let voterAddressStr = toString(i.caller)
493- if ((voterAddressStr != nodeBeneficiary))
494- then throw("Only Node's beneficiary can do voting")
495- else {
496- let startHeight = getIntOrFail(keyNodesVotingStartHeight(votingNum))
497- let endHeight = getIntOrFail(keyNodesVotingEndHeight(votingNum))
498- if ((startHeight > height))
499- then throw("Voting has not been started yet")
500- else if ((height > endHeight))
501- then throw("Voting finished")
502- else {
503- let nodeChoiceKEY = keyNodesVotingNodeChoice(votingNum, nodeAddressStr)
504- let nodeChoice = getStrOrElse(this, nodeChoiceKEY, "")
505- if ((nodeChoice != ""))
506- then throw("Node has already voted. It is allowed to vote only once")
507- else {
508- let optionTotalVotesKEY = keyNodesVotingOptionTotalVotes(votingNum, optionNum)
509- let optionTotalVotes = getIntOrFail(optionTotalVotesKEY)
510-[IntegerEntry(optionTotalVotesKEY, (optionTotalVotes + 1)), StringEntry(nodeChoiceKEY, optionNum)]
511- }
512- }
513- }
514- }
515- else throw("Strict value is not equal to itself.")
516- }
517-
518-
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"))
15-
16-
17-func getIntOrElse (key,val) = valueOrElse(getInteger(this, key), val)
1815
1916
2017 func getStrOrElse (address,key,defaultVal) = valueOrElse(getString(address, key), defaultVal)
2118
2219
2320 func getStringOrFail (address,key) = valueOrErrorMessage(getString(address, key), (("Mandatory this." + key) + " is not defined"))
2421
2522
2623 func getAddressOrFail (key) = valueOrErrorMessage(addressFromString(getStringOrFail(this, key)), (("Fail to convert this." + key) + " value into Address"))
2724
2825
2926 func asAnyList (val) = match val {
3027 case valAnyList: List[Any] =>
3128 valAnyList
3229 case _ =>
3330 throw("fail to cast into List[Any]")
3431 }
3532
3633
3734 func asInt (v) = match v {
3835 case i: Int =>
3936 i
4037 case _ =>
4138 throw("fail to cast into Int")
4239 }
4340
4441
4542 func asByteVecot (v) = match v {
4643 case i: ByteVector =>
4744 i
4845 case _ =>
4946 throw("fail to cast into ByteVector")
5047 }
5148
5249
5350 func validateAddressOrFail (addressStr) = {
5451 let address = valueOrErrorMessage(addressFromString(addressStr), ("fail to convert into address " + addressStr))
5552 if ((0 > wavesBalance(address).available))
5653 then throw()
5754 else addressStr
5855 }
5956
6057
6158 func keyNodeRegistry (address) = ("%s__" + address)
6259
6360
6461 func keyNodeRewardsTotals (address) = ("%s%s__totals__" + address)
6562
6663
6764 func keyApprovedNodeList () = "%s__approvedNodeList"
6865
6966
7067 func keyDepositAmount () = "%s%s__cfg__depositAmount"
7168
7269
7370 func keyNeutrinoAddressStr () = "%s%s__cfg__neutrinoAddress"
7471
7572
7673 func keyMasterNodeAddressStr () = "%s%s__cfg__mainNeutrinoNodeAddress"
7774
7875
7976 func keyProtocolPartX6 () = "%s%s__cfg__protocolPartX6"
8077
8178
8279 func keyBenificaryPartX6 () = "%s%s__cfg__benificaryPartX6"
8380
8481
8582 func keyMinDistributeAmount () = "%s%s__cfg__minDistributeAmount"
8683
8784
8885 func keySwopfiUsdtUsdnPoolAddress () = "%s%s__cfg__swopfiUsdtUsdnPoolAddress"
8986
9087
91-func keyWxSwapAddress () = "%s%s__cfg__wxSwapAddress"
92-
93-
9488 func keySavingsAddress () = "%s%s__cfg__savingsAddress"
9589
9690
9791 func keyBeneficiaryAddress () = "%s%s__cfg__beneficiaryAddress"
98-
99-
100-func keyNodesVotingNextNum () = "%s%s__nodesVotingCfg__nextVotingNum"
101-
102-
103-func keyNodesVotingOptionKey (votingNum,optionNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, optionNum], SEP)
104-
105-
106-func keyNodesVotingDesc (votingNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, "description"], SEP)
107-
108-
109-func keyNodesVotingStartHeight (votingNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, "votingStartHeight"], SEP)
110-
111-
112-func keyNodesVotingEndHeight (votingNum) = makeString(["%s%d%s__nodesVotingCfg", votingNum, "votingEndHeight"], SEP)
113-
114-
115-func keyNodesVotingOptionTotalVotes (votingNum,optionNum) = makeString(["%s%d%s%s__nodesVotingData", votingNum, "optionTotalVotes", optionNum], SEP)
116-
117-
118-func keyNodesVotingNodeChoice (votingNum,nodeAddressStr) = makeString(["%s%d%s%s__nodesVotingData", votingNum, "nodeChoice", nodeAddressStr], SEP)
11992
12093
12194 let IdxControlCfgNeutrinoDapp = 1
12295
12396 let IdxControlCfgAuctionDapp = 2
12497
12598 let IdxControlCfgRpdDapp = 3
12699
127100 let IdxControlCfgMathDapp = 4
128101
129102 let IdxControlCfgLiquidationDapp = 5
130103
131104 let IdxControlCfgRestDapp = 6
132105
133106 let IdxControlCfgNodeRegistryDapp = 7
134107
135108 let IdxControlCfgNsbtStakingDapp = 8
136109
137110 let IdxControlCfgMediatorDapp = 9
138111
139112 let IdxControlCfgSurfStakingDapp = 10
140113
141114 let IdxControlCfgGnsbtControllerDapp = 11
142115
143116 let IdxControlCfgRestV2Dapp = 12
144117
145118 let IdxControlCfgGovernanceDapp = 13
146119
147120 func keyControlAddress () = "%s%s__config__controlAddress"
148121
149122
150123 func keyControlCfg () = "%s__controlConfig"
151124
152125
153126 func keyUsdnAssetId () = "neutrino_asset_id"
154127
155128
156129 func readControlCfgOrFail (control) = split_4C(getStringOrFail(control, keyControlCfg()), SEP)
157130
158131
159132 func getContractAddressOrFail (controlCfg,idx) = valueOrErrorMessage(addressFromString(controlCfg[idx]), ("Control cfg doesn't contain address at index " + toString(idx)))
160133
161134
162135 let controlContract = addressFromStringValue(valueOrElse(getString(this, keyControlAddress()), "3N4NS7d4Jo9a6F14LiFUKKYVdUkkf2eP4Zx"))
163136
164137 let controlCfg = readControlCfgOrFail(controlContract)
165138
166139 let neutrinoContract = getContractAddressOrFail(controlCfg, IdxControlCfgNeutrinoDapp)
167140
168141 let usdnAssetIdStr = getStrOrElse(neutrinoContract, keyUsdnAssetId(), "HezsdQuRDtzksAYUy97gfhKy7Z1NW2uXYSHA3bgqenNZ")
169142
170143 let usdnAssetId = fromBase58String(usdnAssetIdStr)
171144
172145 let nRegIdxTxAdd = 1
173146
174147 let nRegIdxHeightAdd = 2
175148
176149 let nRegIdxTimeAdd = 3
177150
178151 let nRegIdxDepoAmt = 4
179152
180153 let nRegIdxDepoAmtLeft = 5
181154
182155 let nRegIdxStatus = 6
183156
184157 let nRegIdxStatusChangeHeight = 7
185158
186159 let nRegIdxStatusChangeTime = 8
187160
188161 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)
189162
190163
191164 func formatDepositChangeStatus (origS,newStatus) = {
192165 let orig = split(origS, SEP)
193166 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)
194167 }
195168
196169
197170 func keyRewardHistory (nodeAddress,txId) = makeString(["%s%s%s", "history", toString(nodeAddress), toBase58String(txId)], SEP)
198171
199172
200173 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)
201174
202175
203176 func RewardHistoryEntry (nodeAddress,txId,minedAmt,beneficiaryAmt,protocolAmt,protocolAmt1,protocolAmt2) = StringEntry(keyRewardHistory(nodeAddress, txId), dataRewardHistory(minedAmt, beneficiaryAmt, protocolAmt, protocolAmt1, protocolAmt2))
204177
205178
206179 func dataRewardTotals (minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = makeString(["%d%d%d%d%d", toString(minedAmt), toString(beneficiaryAmt), toString(protocolAmt), toString(protocolAmtPart1), toString(protocolAmtPart2)], SEP)
207180
208181
209182 func RewardTotalsEntry (miner,minedAmt,beneficiaryAmt,protocolAmt,protocolAmtPart1,protocolAmtPart2) = {
210183 let nodeRewardsTotalsKEY = keyNodeRewardsTotals(toString(miner))
211184 let nodeRewardsArray = split(getStrOrElse(this, nodeRewardsTotalsKEY, dataRewardTotals(0, 0, 0, 0, 0)), SEP)
212185 let newMinedAmt = (parseIntValue(nodeRewardsArray[1]) + minedAmt)
213186 let newBeneficiaryAmt = (parseIntValue(nodeRewardsArray[2]) + beneficiaryAmt)
214187 let newProtocolAmt = (parseIntValue(nodeRewardsArray[3]) + protocolAmt)
215188 let newProtocolAmtPart1 = (parseIntValue(nodeRewardsArray[4]) + protocolAmtPart1)
216189 let newProtocolAmtPart2 = (parseIntValue(nodeRewardsArray[5]) + protocolAmtPart2)
217190 StringEntry(nodeRewardsTotalsKEY, dataRewardTotals(newMinedAmt, newBeneficiaryAmt, newProtocolAmt, newProtocolAmtPart1, newProtocolAmtPart2))
218191 }
219192
220193
221194 func resolveBeneficiaries (minerAddress,beneficiaryFromParam) = {
222195 let beneficiaryFromMinerState = addressFromStringValue(getStringOrFail(minerAddress, keyBeneficiaryAddress()))
223196 if ((scriptHash(minerAddress) == unit))
224197 then beneficiaryFromParam
225198 else beneficiaryFromMinerState
226199 }
227200
228201
229202 func readNodeDataAndValidateStatus (nodeAddr,expectedStatus) = {
230203 let nodeDataOpt = getString(keyNodeRegistry(nodeAddr))
231204 if (!(isDefined(nodeDataOpt)))
232205 then throw(("Unknown Node " + nodeAddr))
233206 else {
234207 let nodeDataStr = value(nodeDataOpt)
235208 let nodeData = split(nodeDataStr, SEP)
236209 let nodeStatus = if ((size(nodeData) >= 9))
237210 then nodeData[nRegIdxStatus]
238211 else "PENDING"
239212 if ((nodeStatus != expectedStatus))
240213 then throw(((((("Node " + nodeAddr) + " status should be ") + expectedStatus) + ", but actually ") + nodeStatus))
241214 else nodeDataStr
242215 }
243216 }
244217
245218
246219 @Callable(i)
247220 func constructorV1 (depositAmount,neutrinoAddressStr,masterNodeAddressStr,protocolPartX6,benificaryPartX6) = if ((i.caller != this))
248221 then throw("permissions denied")
249222 else if ((0 > depositAmount))
250223 then throw("depositAmount less then zero")
251224 else if ((0 > protocolPartX6))
252225 then throw("protocolPartX6 less then zero")
253226 else if ((0 > benificaryPartX6))
254227 then throw("benificaryPartX6 less then zero")
255228 else if (((protocolPartX6 + benificaryPartX6) != MULT6))
256229 then throw("parts sum must be 1")
257230 else [IntegerEntry(keyDepositAmount(), depositAmount), StringEntry(keyNeutrinoAddressStr(), validateAddressOrFail(neutrinoAddressStr)), StringEntry(keyMasterNodeAddressStr(), validateAddressOrFail(masterNodeAddressStr)), IntegerEntry(keyProtocolPartX6(), protocolPartX6), IntegerEntry(keyBenificaryPartX6(), benificaryPartX6)]
258231
259232
260233
261234 @Callable(i)
262235 func constructorV2 (swopfiAddressStr,controlAddressStr,savingsAddressStr) = if ((i.caller != this))
263236 then throw("permissions denied")
264237 else [StringEntry(keySwopfiUsdtUsdnPoolAddress(), validateAddressOrFail(swopfiAddressStr)), StringEntry(keyControlAddress(), validateAddressOrFail(controlAddressStr)), StringEntry(keySavingsAddress(), validateAddressOrFail(savingsAddressStr))]
265238
266239
267240
268241 @Callable(i)
269242 func sumbitApplication () = if ((size(i.payments) != 1))
270243 then throw("exact 1 payment must be attached")
271244 else if ((i.caller != i.originCaller))
272245 then throw("dapp to dapp calls are not allowed")
273246 else {
274247 let pmt = i.payments[0]
275248 let deposit = pmt.amount
276249 let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
277250 let expectedDepositAmount = getIntOrFail(keyDepositAmount())
278251 let txId = toBase58String(i.transactionId)
279252 let nodeAddress = toString(i.caller)
280253 let nodeRegistryKEY = keyNodeRegistry(nodeAddress)
281254 if ((pmtAssetId != WAVESID))
282255 then throw("only Waves can be used for deposit")
283256 else if ((deposit != expectedDepositAmount))
284257 then throw((("exactly " + toString(expectedDepositAmount)) + " Wavelets are expected"))
285258 else if ((getStrOrElse(this, nodeRegistryKEY, "") != ""))
286259 then throw("your node already registered")
287260 else [StringEntry(nodeRegistryKEY, formatDepositAdd(txId, deposit, deposit, "PENDING"))]
288261 }
289262
290263
291264
292265 @Callable(i)
293266 func distributeMinerReward (beneficiaryAddressStr) = {
294267 let minDistributeAmount = valueOrElse(getInteger(this, keyMinDistributeAmount()), (24 * MULT8))
295268 if ((size(i.payments) != 1))
296269 then throw("exact 1 payment must be attached")
297270 else if ((i.caller != i.originCaller))
298271 then throw("dapp to dapp calls are not allowed")
299272 else {
300273 let pmt = i.payments[0]
301274 let pmtAssetId = valueOrElse(pmt.assetId, WAVESID)
302275 let feeAmt = i.fee
303276 let feeAssetId = valueOrElse(i.feeAssetId, WAVESID)
304277 let callReward = (feeAmt * 3)
305278 let minedAmt = (pmt.amount - callReward)
306279 if ((pmt.amount != minDistributeAmount))
307280 then throw((("attached payment must be exact " + toString(minDistributeAmount)) + " Wavelets"))
308281 else if ((pmtAssetId != WAVESID))
309282 then throw("only Waves can be used in payment")
310283 else if ((feeAssetId != WAVESID))
311284 then throw("only Waves can be used in fees")
312285 else if ((feeAmt != ((5 * MULT8) / 1000)))
313286 then throw("fee amount couldn't exceed 0.005")
314287 else {
315288 let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
316289 let masterNodeAddress = getAddressOrFail(keyMasterNodeAddressStr())
317290 let minerAddress = i.caller
318291 let beneficiaryFromParam = addressFromStringValue(beneficiaryAddressStr)
319292 let beneficiaryAddress = resolveBeneficiaries(minerAddress, beneficiaryFromParam)
320293 let txRewardReceiver = beneficiaryFromParam
321294 let protocolPart = getIntOrFail(keyProtocolPartX6())
322295 let beneficiaryPart = getIntOrFail(keyBenificaryPartX6())
323296 let beneficiaryAmt = fraction(minedAmt, beneficiaryPart, MULT6)
324297 let protocolAmt = (minedAmt - beneficiaryAmt)
325- let buyBackAmt = (120 * MULT8)
326- let savingsAddress = addressFromStringValue(getStrOrElse(this, keySavingsAddress(), "3PC7DBimauyKytx8tXhKo5u2ECb6FsndYKH"))
327- let savingsAmt = asInt(invoke(savingsAddress, "withdraw", [buyBackAmt], nil))
328- let wxAssetIdStr = "Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on"
329- let wxSwapAddress = addressFromStringValue(getStrOrElse(this, keyWxSwapAddress(), "3P68zNiufsu1viZpu1aY3cdahRRKcvV5N93"))
330- let swapResult = invoke(wxSwapAddress, "swap", [1, wxAssetIdStr, toString(neutrinoContract)], [AttachedPayment(unit, savingsAmt)])
331- if ((swapResult == swapResult))
332- 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)]
333- else throw("Strict value is not equal to itself.")
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)]
334299 }
335300 }
336301 }
337302
338303
339304
340305 @Callable(i)
341306 func validateAndApproveLeasings (nListS) = {
342307 let nIdxs = [0, 1, 2, 3, 4, 5, 6, 7]
343308 let nList = split(nListS, SEP)
344309 let expectedCount = size(nIdxs)
345310 let neutrinoAddress = getAddressOrFail(keyNeutrinoAddressStr())
346311 if ((i.caller != neutrinoAddress))
347312 then throw("validateAndApproveLeasings not authorized")
348313 else if (((size(nList) % 2) != 0))
349314 then throw("Only even number of nodes is allowed")
350315 else if ((size(nList) != expectedCount))
351316 then throw((("Only " + toString(expectedCount)) + " of nodes' addresses can be passed"))
352317 else {
353318 func forEachNodeChangeStatus (acc,i) = {
354319 let nodeAddr = nList[i]
355320 let nodeDataStr = readNodeDataAndValidateStatus(nodeAddr, "PENDING")
356321 (acc :+ StringEntry(keyNodeRegistry(nodeAddr), formatDepositChangeStatus(nodeDataStr, "APPROVED")))
357322 }
358323
359324 let approvedNodesData = {
360325 let $l = nIdxs
361326 let $s = size($l)
362327 let $acc0 = nil
363328 func $f0_1 ($a,$i) = if (($i >= $s))
364329 then $a
365330 else forEachNodeChangeStatus($a, $l[$i])
366331
367332 func $f0_2 ($a,$i) = if (($i >= $s))
368333 then $a
369334 else throw("List size exceeds 8")
370335
371336 $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)
372337 }
373338 $Tuple2(approvedNodesData, nil)
374339 }
375340 }
376341
377342
378343
379344 @Callable(i)
380345 func replaceApprovedNode (oldNodeAddrStr,newNodeAddrStr,groupNum,penaltyAmount) = if ((i.caller != neutrinoContract))
381346 then throw("permissions denied")
382347 else {
383348 let oldDataStr = readNodeDataAndValidateStatus(oldNodeAddrStr, "APPROVED")
384349 let newDataStr = readNodeDataAndValidateStatus(newNodeAddrStr, "PENDING")
385350 let approvedNodeListS = getStringOrFail(this, keyApprovedNodeList())
386351 if (!(contains(approvedNodeListS, oldNodeAddrStr)))
387352 then throw(("approvedNodeList does not contain " + oldNodeAddrStr))
388353 else {
389354 let updatedNodeListS = makeString_2C(split_4C(approvedNodeListS, oldNodeAddrStr), newNodeAddrStr)
390355 let oldNodeAddr = addressFromStringValue(oldNodeAddrStr)
391356 let beneficiaryAddress = resolveBeneficiaries(oldNodeAddr, oldNodeAddr)
392357 let depoAmount = parseIntValue(split(oldDataStr, SEP)[nRegIdxDepoAmt])
393358 let actions = [StringEntry(keyApprovedNodeList(), updatedNodeListS), DeleteEntry(keyNodeRegistry(oldNodeAddrStr)), StringEntry(keyNodeRegistry(newNodeAddrStr), formatDepositChangeStatus(newDataStr, "APPROVED"))]
394359 $Tuple2(if ((depoAmount > penaltyAmount))
395360 then (actions :+ ScriptTransfer(beneficiaryAddress, (depoAmount - penaltyAmount), unit))
396361 else actions, unit)
397362 }
398363 }
399364
400365
401366
402367 @Callable(i)
403368 func returnDeposit (nodeAddressStr) = if ((size(i.payments) != 0))
404369 then throw("No payments allowed")
405370 else {
406371 let callerAddress = i.caller
407372 let nodeRegistryKEY = keyNodeRegistry(nodeAddressStr)
408373 let nodeDataOpt = getString(this, nodeRegistryKEY)
409374 if (!(isDefined(nodeDataOpt)))
410375 then throw(("Address is not applied as neutrino node: " + nodeAddressStr))
411376 else {
412377 let approvedNodeList = getStringOrFail(this, keyApprovedNodeList())
413378 if (contains(approvedNodeList, nodeAddressStr))
414379 then throw("Impossible to return deposit from approved Node, please contact support team")
415380 else {
416381 let nodeData = split(value(nodeDataOpt), SEP)
417382 let status = if ((size(nodeData) >= 9))
418383 then nodeData[nRegIdxStatus]
419384 else "PENDING"
420385 if ((status != "PENDING"))
421386 then throw("Application status is not PENDING!")
422387 else {
423388 let depoAmount = parseIntValue(nodeData[nRegIdxDepoAmt])
424389 let nodeAddress = addressFromStringValue(nodeAddressStr)
425390 let beneficiaryAddress = resolveBeneficiaries(nodeAddress, nodeAddress)
426391 if (!(if (if ((callerAddress == this))
427392 then true
428393 else if ((beneficiaryAddress != nodeAddress))
429394 then (callerAddress == beneficiaryAddress)
430395 else false)
431396 then true
432397 else if ((beneficiaryAddress == nodeAddress))
433398 then (callerAddress == nodeAddress)
434399 else false))
435400 then throw("returnDeposit permissions denied")
436401 else [DeleteEntry(nodeRegistryKEY), ScriptTransfer(beneficiaryAddress, depoAmount, unit)]
437402 }
438403 }
439404 }
440405 }
441406
442407
443-
444-@Callable(i)
445-func initNodesVoting (startHeight,endHeight,options,description) = if ((i.caller != this))
446- then throw("permissions denied")
447- else {
448- let optionsArray = split(options, "__")
449- if (((size(optionsArray) % 2) != 0))
450- then throw("Not even number of options")
451- else if (((size(optionsArray) / 2) > 10))
452- then throw("Max 10 options can be specified")
453- else {
454- let nodesVotingNumKEY = keyNodesVotingNextNum()
455- let votingNum = getIntOrElse(nodesVotingNumKEY, 0)
456- let votingNumStr = toString(votingNum)
457- func transformOptions (accum,nextOpt) = {
458- let optData = split(nextOpt, ":")
459- let opt = optData[0]
460- let optKEY = keyNodesVotingOptionKey(votingNumStr, opt)
461- let optDescr = optData[1]
462- let optTotalVotesKEY = keyNodesVotingOptionTotalVotes(votingNumStr, opt)
463- ((accum :+ StringEntry(optKEY, optDescr)) :+ IntegerEntry(optTotalVotesKEY, 0))
464- }
465-
466- (((({
467- let $l = optionsArray
468- let $s = size($l)
469- let $acc0 = nil
470- func $f0_1 ($a,$i) = if (($i >= $s))
471- then $a
472- else transformOptions($a, $l[$i])
473-
474- func $f0_2 ($a,$i) = if (($i >= $s))
475- then $a
476- else throw("List size exceeds 10")
477-
478- $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
479- } :+ IntegerEntry(nodesVotingNumKEY, (votingNum + 1))) :+ StringEntry(keyNodesVotingDesc(votingNumStr), description)) :+ IntegerEntry(keyNodesVotingStartHeight(votingNumStr), startHeight)) :+ IntegerEntry(keyNodesVotingEndHeight(votingNumStr), endHeight))
480- }
481- }
482-
483-
484-
485-@Callable(i)
486-func voteByNode (nodeAddressStr,votingNum,optionNum) = {
487- let validateNode = readNodeDataAndValidateStatus(nodeAddressStr, "APPROVED")
488- if ((validateNode == validateNode))
489- then {
490- let nodeAddress = addressFromStringValue(nodeAddressStr)
491- let nodeBeneficiary = getStringOrFail(nodeAddress, keyBeneficiaryAddress())
492- let voterAddressStr = toString(i.caller)
493- if ((voterAddressStr != nodeBeneficiary))
494- then throw("Only Node's beneficiary can do voting")
495- else {
496- let startHeight = getIntOrFail(keyNodesVotingStartHeight(votingNum))
497- let endHeight = getIntOrFail(keyNodesVotingEndHeight(votingNum))
498- if ((startHeight > height))
499- then throw("Voting has not been started yet")
500- else if ((height > endHeight))
501- then throw("Voting finished")
502- else {
503- let nodeChoiceKEY = keyNodesVotingNodeChoice(votingNum, nodeAddressStr)
504- let nodeChoice = getStrOrElse(this, nodeChoiceKEY, "")
505- if ((nodeChoice != ""))
506- then throw("Node has already voted. It is allowed to vote only once")
507- else {
508- let optionTotalVotesKEY = keyNodesVotingOptionTotalVotes(votingNum, optionNum)
509- let optionTotalVotes = getIntOrFail(optionTotalVotesKEY)
510-[IntegerEntry(optionTotalVotesKEY, (optionTotalVotes + 1)), StringEntry(nodeChoiceKEY, optionNum)]
511- }
512- }
513- }
514- }
515- else throw("Strict value is not equal to itself.")
516- }
517-
518-

github/deemru/w8io/169f3d6 
60.29 ms