tx · DcJUGEkmfhJH7BNG2UzCu3pa354A5vPJu1XH9jcykJ1c 3N2PjXqef29HexCE7PeGZa9eRjS2jVeaFe4: -0.04000000 Waves 2023.08.27 13:01 [2728930] smart account 3N2PjXqef29HexCE7PeGZa9eRjS2jVeaFe4 > SELF 0.00000000 Waves
{ "type": 13, "id": "DcJUGEkmfhJH7BNG2UzCu3pa354A5vPJu1XH9jcykJ1c", "fee": 4000000, "feeAssetId": null, "timestamp": 1693130590655, "version": 2, "chainId": 84, "sender": "3N2PjXqef29HexCE7PeGZa9eRjS2jVeaFe4", "senderPublicKey": "DU1U4j8FqHUMRr9WgfF3yo67ULEFkjp7dtMWMpjBK1ar", "proofs": [ "5hG2d8eSh6LCd5cwLKJoTy6y43fLruBYXU6cKbotxNAXn9AV8GfmnrEyLTN4DyYXM68KfGdEpgFZSja6Y3ZaSS5h", "25UkmLvs4TvrB2bcK5oc5XmRU5WcERax218Bek5KgvWQQAunvwfvNiw1RvPWxY5hougprUDBr2BUiR1a6Wb5BjWw" ], "script": "base64:BgIlCAISBgoECAgICBIAEgMKAQESABIAEgMKAQgSABIFCgMICAgSABsAC05GVF9QRVJDRU5UADIABlNDQUxFOACAwtcvAAlrSW50ZXJlc3QCCGludGVyZXN0AA1rVXNlckludGVyZXN0Ag1fdXNlckludGVyZXN0AA5rVXNlckF2YWlsYWJsZQITX3VzZXJBdmFpbGFibGVDbGFpbQAQa1VzZXJUb2tlblN0YWtlZAIQX3VzZXJUb2tlblN0YWtlZAARa1RvdGFsVG9rZW5TdGFrZWQCEV90b3RhbFRva2VuU3Rha2VkAAxrTkZUSW50ZXJlc3QCDF9ORlRJbnRlcmVzdAAQa05GVFVzZXJJbnRlcmVzdAIQX05GVFVzZXJJbnRlcmVzdAAWa05GVFVzZXJBdmFpbGFibGVDbGFpbQIWX05GVFVzZXJBdmFpbGFibGVDbGFpbQAPa05GVFRvdGFsU3Rha2VkAg9fTkZUVG90YWxTdGFrZWQADmt1c2VyTkZUU3Rha2VkAg5fdXNlck5GVFN0YWtlZAAQa3VzZXJORlRTdGFrZWRJZAIQX3VzZXJORlRTdGFrZWRJZAALa05GVENyZWF0ZWQCC19ORlRDcmVhdGVkAAhrVG9rZW5pZAIHdG9rZW5JZAAJa0FkbWluMVBLAgthZG1pbl9wdWJfMQAJa0FkbWluMlBLAgthZG1pbl9wdWJfMgAJa0FkbWluM1BLAgthZG1pbl9wdWJfMwAIYWRtaW4xUEsJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFCWtBZG1pbjFQSwISQ2FuJ3QgZ2V0IGFkbWluMVBLAAhhZG1pbjJQSwkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUJa0FkbWluMlBLAhJDYW4ndCBnZXQgYWRtaW4yUEsACGFkbWluM1BLCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQlrQWRtaW4zUEsCFENhbid0IGdldCBvcGVyYXRvclBLAAd0b2tlbklkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUIa1Rva2VuaWQCF0Nhbid0IGdldCBzdGFraW5nIHRva2VuAQtpc0FkbWluQ2FsbAEBaQMJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFCGFkbWluMVBLCQDMCAIFCGFkbWluMlBLCQDMCAIFCGFkbWluM1BLBQNuaWwIBQFpD2NhbGxlclB1YmxpY0tleQUEdW5pdAkAAgECIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgEKaXNTZWxmQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIFBHRoaXMFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQxhc3NldElkVG9TdHIBB2Fzc2V0SWQEByRtYXRjaDAFB2Fzc2V0SWQDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCaWQFByRtYXRjaDAJANgEAQUCaWQDCQABAgUHJG1hdGNoMAIEVW5pdAQFd2F2ZXMFByRtYXRjaDACBVdBVkVTCQACAQIMTm90IEFzc2V0IGlkAQljbGFpbUNhbGMBBHVzZXIEEHRvdGFsVG9rZW5TdGFrZWQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwURa1RvdGFsVG9rZW5TdGFrZWQAAAQLY3VySW50ZXJlc3QJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUJa0ludGVyZXN0AAAEEWF2YWlsYWJsZUZvckNsYWltCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEdXNlcgUOa1VzZXJBdmFpbGFibGUAAAQMdXNlckludGVyZXN0CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEdXNlcgUNa1VzZXJJbnRlcmVzdAULY3VySW50ZXJlc3QED3VzZXJUb2tlblN0YWtlZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIFBHVzZXIFEGtVc2VyVG9rZW5TdGFrZWQAAAQLY2xhaW1BbW91bnQJAGsDBQ91c2VyVG9rZW5TdGFrZWQJAGUCBQtjdXJJbnRlcmVzdAUMdXNlckludGVyZXN0BQZTQ0FMRTgJAJYKBAULY3VySW50ZXJlc3QJAGQCBQtjbGFpbUFtb3VudAURYXZhaWxhYmxlRm9yQ2xhaW0FD3VzZXJUb2tlblN0YWtlZAUQdG90YWxUb2tlblN0YWtlZAEMY2xhaW1DYWxjTmZ0AQR1c2VyBA50b3RhbE5mdFN0YWtlZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQ9rTkZUVG90YWxTdGFrZWQAAAQLY3VySW50ZXJlc3QJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUMa05GVEludGVyZXN0AAAEEWF2YWlsYWJsZUZvckNsYWltCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEdXNlcgUWa05GVFVzZXJBdmFpbGFibGVDbGFpbQAABAx1c2VySW50ZXJlc3QJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQR1c2VyBRBrTkZUVXNlckludGVyZXN0BQtjdXJJbnRlcmVzdAQNdXNlck5mdFN0YWtlZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIFBHVzZXIFDmt1c2VyTkZUU3Rha2VkAAAEC2NsYWltQW1vdW50CQBrAwUNdXNlck5mdFN0YWtlZAkAZQIFC2N1ckludGVyZXN0BQx1c2VySW50ZXJlc3QFBlNDQUxFOAkAlgoEBQtjdXJJbnRlcmVzdAkAZAIFC2NsYWltQW1vdW50BRFhdmFpbGFibGVGb3JDbGFpbQUNdXNlck5mdFN0YWtlZAUOdG90YWxOZnRTdGFrZWQJAWkBBGluaXQEB3Rva2VuSWQHYWRtMVB1YgdhZG0yUHViB2FkbTNQdWIJAQt2YWx1ZU9yRWxzZQIJAQppc1NlbGZDYWxsAQUBaQMJAQEhAQkBCWlzRGVmaW5lZAEJAOwHAQkA2QQBBQd0b2tlbklkCQACAQIgYXNzZXQgaWQgaXMgbm90IGNvcnJlY3QgYXNzZXQgaWQDCQECIT0CCQDIAQEJANkEAQUHYWRtMVB1YgAgCQACAQIhZ3JvdXAxQWRtaW4xUHViS2V5IGlzIG5vdCBjb3JyZWN0AwkBAiE9AgkAyAEBCQDZBAEFB2FkbTJQdWIAIAkAAgECIWdyb3VwMUFkbWluMVB1YktleSBpcyBub3QgY29ycmVjdAMJAQIhPQIJAMgBAQkA2QQBBQdhZG0zUHViACAJAAIBAiFncm91cDFBZG1pbjFQdWJLZXkgaXMgbm90IGNvcnJlY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgUIa1Rva2VuaWQFB3Rva2VuSWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUJa0FkbWluMVBLBQdhZG0xUHViCQDMCAIJAQtTdHJpbmdFbnRyeQIFCWtBZG1pbjJQSwUHYWRtMlB1YgkAzAgCCQELU3RyaW5nRW50cnkCBQlrQWRtaW4zUEsFB2FkbTNQdWIFA25pbAFpAQVzdGFrZQADCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAhRPbmUgcGF5bWVudCBleHBlY3RlZAQLJHQwMzUzNDM2MDkJAJQKAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAQJcG10QW1vdW50CAULJHQwMzUzNDM2MDkCXzEECnBtdEFzc2V0SWQIBQskdDAzNTM0MzYwOQJfMgMJAQIhPQIFCnBtdEFzc2V0SWQJANkEAQUHdG9rZW5JZAkAAgECE1dyb25nIHBheW1lbnQgYXNzZXQEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAskdDAzNzMwMzgyNgkBCWNsYWltQ2FsYwEFBHVzZXIED3VzZXJOZXdJbnRlcmVzdAgFCyR0MDM3MzAzODI2Al8xBBRjbGFpbUFtb3VudEF2YWlsYWJsZQgFCyR0MDM3MzAzODI2Al8yBA91c2VyVG9rZW5TdGFrZWQIBQskdDAzNzMwMzgyNgJfMwQQdG90YWxUb2tlblN0YWtlZAgFCyR0MDM3MzAzODI2Al80CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFDWtVc2VySW50ZXJlc3QFD3VzZXJOZXdJbnRlcmVzdAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQR1c2VyBQ5rVXNlckF2YWlsYWJsZQUUY2xhaW1BbW91bnRBdmFpbGFibGUJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEdXNlcgUQa1VzZXJUb2tlblN0YWtlZAkAZAIFD3VzZXJUb2tlblN0YWtlZAUJcG10QW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFEWtUb3RhbFRva2VuU3Rha2VkCQBkAgUQdG90YWxUb2tlblN0YWtlZAUJcG10QW1vdW50BQNuaWwBaQEHdW5zdGFrZQEGYW1vdW50BAR1c2VyCQClCAEIBQFpBmNhbGxlcgMJAGcCAAAFBmFtb3VudAkAAgECHUFtb3VudCBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAwBAskdDA0MjQ3NDM0MwkBCWNsYWltQ2FsYwEFBHVzZXIED3VzZXJOZXdJbnRlcmVzdAgFCyR0MDQyNDc0MzQzAl8xBBRjbGFpbUFtb3VudEF2YWlsYWJsZQgFCyR0MDQyNDc0MzQzAl8yBA91c2VyVG9rZW5TdGFrZWQIBQskdDA0MjQ3NDM0MwJfMwQQdG90YWxUb2tlblN0YWtlZAgFCyR0MDQyNDc0MzQzAl80AwkAZgIFBmFtb3VudAUPdXNlclRva2VuU3Rha2VkCQACAQIiWW91IGNhbid0IHVuc3Rha2UgbW9yZSB0aGFuIHN0YWtlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQR1c2VyBQ1rVXNlckludGVyZXN0BQ91c2VyTmV3SW50ZXJlc3QJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEdXNlcgUOa1VzZXJBdmFpbGFibGUFFGNsYWltQW1vdW50QXZhaWxhYmxlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFEGtVc2VyVG9rZW5TdGFrZWQJAGUCBQ91c2VyVG9rZW5TdGFrZWQFBmFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQR1c2VyBRFrVG90YWxUb2tlblN0YWtlZAkAZQIFEHRvdGFsVG9rZW5TdGFrZWQFBmFtb3VudAUDbmlsAWkBBWNsYWltAAQEdXNlcgkApQgBCAUBaQZjYWxsZXIECyR0MDQ3NjY0ODYyCQEJY2xhaW1DYWxjAQUEdXNlcgQPdXNlck5ld0ludGVyZXN0CAULJHQwNDc2NjQ4NjICXzEEFGNsYWltQW1vdW50QXZhaWxhYmxlCAULJHQwNDc2NjQ4NjICXzIED3VzZXJUb2tlblN0YWtlZAgFCyR0MDQ3NjY0ODYyAl8zBBB0b3RhbFRva2VuU3Rha2VkCAULJHQwNDc2NjQ4NjICXzQDCQAAAgUUY2xhaW1BbW91bnRBdmFpbGFibGUAAAkAAgECEE5vdGhpbmcgdG8gY2xhaW0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEdXNlcgUNa1VzZXJJbnRlcmVzdAUPdXNlck5ld0ludGVyZXN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFDmtVc2VyQXZhaWxhYmxlAAAJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBRRjbGFpbUFtb3VudEF2YWlsYWJsZQkA2QQBBQd0b2tlbklkBQNuaWwBaQEIc3Rha2VORlQAAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwAACQACAQIUT25lIHBheW1lbnQgZXhwZWN0ZWQECyR0MDUyMjc1MzAyCQCUCgIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQECXBtdEFtb3VudAgFCyR0MDUyMjc1MzAyAl8xBApwbXRBc3NldElkCAULJHQwNTIyNzUzMDICXzIEDXBtdEFzc2V0SWRTdHIJAQxhc3NldElkVG9TdHIBBQpwbXRBc3NldElkAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzCQCsAgIFDXBtdEFzc2V0SWRTdHIFC2tORlRDcmVhdGVkCQACAQIPV3JvbmcgbmZ0IGFzc2V0BAR1c2VyCQClCAEIBQFpBmNhbGxlcgQLJHQwNTQ4MzU1NzgJAQxjbGFpbUNhbGNOZnQBBQR1c2VyBA91c2VyTmV3SW50ZXJlc3QIBQskdDA1NDgzNTU3OAJfMQQUY2xhaW1BbW91bnRBdmFpbGFibGUIBQskdDA1NDgzNTU3OAJfMgQNdXNlck5GVFN0YWtlZAgFCyR0MDU0ODM1NTc4Al8zBA50b3RhbE5GVFN0YWtlZAgFCyR0MDU0ODM1NTc4Al80CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFEGtORlRVc2VySW50ZXJlc3QFD3VzZXJOZXdJbnRlcmVzdAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQR1c2VyBRZrTkZUVXNlckF2YWlsYWJsZUNsYWltBRRjbGFpbUFtb3VudEF2YWlsYWJsZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQR1c2VyBQ5rdXNlck5GVFN0YWtlZAkAZAIFDXVzZXJORlRTdGFrZWQFCXBtdEFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQR1c2VyBQ9rTkZUVG90YWxTdGFrZWQJAGQCBQ50b3RhbE5GVFN0YWtlZAUJcG10QW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICBQR1c2VyAgFfBQ1wbXRBc3NldElkU3RyBRBrdXNlck5GVFN0YWtlZElkAAEFA25pbAFpAQp1bnN0YWtlTkZUAQJpZAQEdXNlcgkApQgBCAUBaQZjYWxsZXIDCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzCQCsAgIJAKwCAgkArAICBQR1c2VyBQJpZAIBXwUQa3VzZXJORlRTdGFrZWRJZAkAAgECEVlvdSBkaWRuJ3Qgc3Rha2VkBAskdDA2MTEwNjIwNQkBDGNsYWltQ2FsY05mdAEFBHVzZXIED3VzZXJOZXdJbnRlcmVzdAgFCyR0MDYxMTA2MjA1Al8xBBRjbGFpbUFtb3VudEF2YWlsYWJsZQgFCyR0MDYxMTA2MjA1Al8yBA11c2VyTkZUU3Rha2VkCAULJHQwNjExMDYyMDUCXzMEDnRvdGFsTkZUU3Rha2VkCAULJHQwNjExMDYyMDUCXzQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEdXNlcgUQa05GVFVzZXJJbnRlcmVzdAUPdXNlck5ld0ludGVyZXN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFFmtORlRVc2VyQXZhaWxhYmxlQ2xhaW0FFGNsYWltQW1vdW50QXZhaWxhYmxlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFDmt1c2VyTkZUU3Rha2VkCQBlAgUNdXNlck5GVFN0YWtlZAABCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFD2tORlRUb3RhbFN0YWtlZAkAZQIFDnRvdGFsTkZUU3Rha2VkAAEJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgIJAKwCAgUEdXNlcgIBXwUCaWQFEGt1c2VyTkZUU3Rha2VkSWQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyAAEJANkEAQUCaWQFA25pbAFpAQhjbGFpbU5GVAAEBHVzZXIJAKUIAQgFAWkGY2FsbGVyBAskdDA2NjQ2Njc0MQkBDGNsYWltQ2FsY05mdAEFBHVzZXIED3VzZXJOZXdJbnRlcmVzdAgFCyR0MDY2NDY2NzQxAl8xBBRjbGFpbUFtb3VudEF2YWlsYWJsZQgFCyR0MDY2NDY2NzQxAl8yBA11c2VyTkZUU3Rha2VkCAULJHQwNjY0NjY3NDECXzMEDnRvdGFsTkZUU3Rha2VkCAULJHQwNjY0NjY3NDECXzQDCQAAAgUUY2xhaW1BbW91bnRBdmFpbGFibGUAAAkAAgECEE5vdGhpbmcgdG8gY2xhaW0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEdXNlcgUQa05GVFVzZXJJbnRlcmVzdAUPdXNlck5ld0ludGVyZXN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFFmtORlRVc2VyQXZhaWxhYmxlQ2xhaW0AAAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFFGNsYWltQW1vdW50QXZhaWxhYmxlCQDZBAEFB3Rva2VuSWQFA25pbAFpAQhpc3N1ZU5GVAMIdXNlckFkZHIEbmFtZQVkZXNjcgkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQQFdUFkZHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQh1c2VyQWRkcgISV3JvbmcgdXNlciBhZGRyZXNzBAVpc3N1ZQkAwggFBQRuYW1lBQVkZXNjcgABAAEHBAVuZnRJZAkAuAgBBQVpc3N1ZQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJANgEAQUFbmZ0SWQFC2tORlRDcmVhdGVkBQh1c2VyQWRkcgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQV1QWRkcgABBQVuZnRJZAUDbmlsAWkBB2FpcmRyb3AACQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQFpAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwAACQACAQIUT25lIHBheW1lbnQgZXhwZWN0ZWQECyR0MDc1MzA3NjA1CQCUCgIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQECXBtdEFtb3VudAgFCyR0MDc1MzA3NjA1Al8xBApwbXRBc3NldElkCAULJHQwNzUzMDc2MDUCXzIDCQECIT0CBQpwbXRBc3NldElkCQDZBAEFB3Rva2VuSWQJAAIBAhNXcm9uZyBwYXltZW50IGFzc2V0BBB0b3RhbFRva2VuU3Rha2VkCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFEWtUb3RhbFRva2VuU3Rha2VkAAAEDnRvdGFsTkZUU3Rha2VkCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFD2tORlRUb3RhbFN0YWtlZAAABAtjdXJJbnRlcmVzdAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQlrSW50ZXJlc3QAAAQOY3VyTkZUSW50ZXJlc3QJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUMa05GVEludGVyZXN0AAAEBnBtdE5GVAkAawMFCXBtdEFtb3VudAULTkZUX1BFUkNFTlQAZAQIcG10VG9rZW4JAGUCBQlwbXRBbW91bnQFBnBtdE5GVAQLaW50ZXJlc3ROZXcDCQBmAgUQdG90YWxUb2tlblN0YWtlZAAACQBkAgULY3VySW50ZXJlc3QJAGsDBQhwbXRUb2tlbgUGU0NBTEU4BRB0b3RhbFRva2VuU3Rha2VkBQtjdXJJbnRlcmVzdAQOaW50ZXJlc3RORlROZXcDCQBmAgUQdG90YWxUb2tlblN0YWtlZAAACQBkAgUOY3VyTkZUSW50ZXJlc3QJAGsDBQZwbXRORlQFBlNDQUxFOAUOdG90YWxORlRTdGFrZWQFDmN1ck5GVEludGVyZXN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrSW50ZXJlc3QFC2ludGVyZXN0TmV3CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQxrTkZUSW50ZXJlc3QFDmludGVyZXN0TkZUTmV3BQNuaWwBAnR4AQZ2ZXJpZnkABBNtdWx0aVNpZ25lZEJ5QWRtaW5zBBJhZG1pblB1YktleTFTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQhhZG1pbjFQSwABAAAEEmFkbWluUHViS2V5MlNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCGFkbWluMlBLAAEAAAQSYWRtaW5QdWJLZXkzU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUIYWRtaW4zUEsAAQAACQBnAgkAZAIJAGQCBRJhZG1pblB1YktleTFTaWduZWQFEmFkbWluUHViS2V5MlNpZ25lZAUSYWRtaW5QdWJLZXkzU2lnbmVkAAIEByRtYXRjaDAFAnR4AwkAAQIFByRtYXRjaDACF0ludm9rZVNjcmlwdFRyYW5zYWN0aW9uBANpbnYFByRtYXRjaDAEBmlzU2VsZgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleQQKaXNSaWdodEZlZQMJAAACCAUDaW52A2ZlZQCg9zYJAAACCAUDaW52CmZlZUFzc2V0SWQFBHVuaXQHBAppc0luaXRDYWxsCQAAAggFA2ludghmdW5jdGlvbgIEaW5pdAQMaXNub1BheW1lbnRzCQAAAgkAkAMBCAUDaW52CHBheW1lbnRzAAADAwMDBQppc1JpZ2h0RmVlBQppc0luaXRDYWxsBwUGaXNTZWxmBwUMaXNub1BheW1lbnRzBwYFE211bHRpU2lnbmVkQnlBZG1pbnMFE211bHRpU2lnbmVkQnlBZG1pbnPm+5+t", "height": 2728930, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: G3UbChRFVekeaBLVxAqGHtVQNZ2Drt6a873cNM426giT Next: ESNPMXKxMsjba52MvNX9BNp9FRRNX4M2J6GUAGBpo8sm Diff:
Old | New | Differences | |
---|---|---|---|
13 | 13 | ||
14 | 14 | let kUserTokenStaked = "_userTokenStaked" | |
15 | 15 | ||
16 | - | let kTotalTokenStaked = "totalTokenStaked" | |
16 | + | let kTotalTokenStaked = "_totalTokenStaked" | |
17 | 17 | ||
18 | - | let kNFTInterest = "NFTInterest" | |
18 | + | let kNFTInterest = "_NFTInterest" | |
19 | 19 | ||
20 | 20 | let kNFTUserInterest = "_NFTUserInterest" | |
21 | 21 | ||
22 | - | let kNFTUserAvailableClaim = "NFTUserAvailableClaim" | |
22 | + | let kNFTUserAvailableClaim = "_NFTUserAvailableClaim" | |
23 | 23 | ||
24 | - | let kNFTTotalStaked = "NFTTotalStaked" | |
24 | + | let kNFTTotalStaked = "_NFTTotalStaked" | |
25 | 25 | ||
26 | 26 | let kuserNFTStaked = "_userNFTStaked" | |
27 | 27 | ||
28 | 28 | let kuserNFTStakedId = "_userNFTStakedId" | |
29 | 29 | ||
30 | + | let kNFTCreated = "_NFTCreated" | |
31 | + | ||
30 | 32 | let kTokenid = "tokenId" | |
31 | - | ||
32 | - | let kNFTCreated = "_NFTCreated" | |
33 | 33 | ||
34 | 34 | let kAdmin1PK = "admin_pub_1" | |
35 | 35 | ||
104 | 104 | func stake () = if ((size(i.payments) != 1)) | |
105 | 105 | then throw("One payment expected") | |
106 | 106 | else { | |
107 | - | let $ | |
108 | - | let pmtAmount = $ | |
109 | - | let pmtAssetId = $ | |
107 | + | let $t035343609 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
108 | + | let pmtAmount = $t035343609._1 | |
109 | + | let pmtAssetId = $t035343609._2 | |
110 | 110 | if ((pmtAssetId != fromBase58String(tokenId))) | |
111 | 111 | then throw("Wrong payment asset") | |
112 | 112 | else { | |
113 | 113 | let user = toString(i.caller) | |
114 | - | let $ | |
115 | - | let userNewInterest = $ | |
116 | - | let claimAmountAvailable = $ | |
117 | - | let userTokenStaked = $ | |
118 | - | let totalTokenStaked = $ | |
114 | + | let $t037303826 = claimCalc(user) | |
115 | + | let userNewInterest = $t037303826._1 | |
116 | + | let claimAmountAvailable = $t037303826._2 | |
117 | + | let userTokenStaked = $t037303826._3 | |
118 | + | let totalTokenStaked = $t037303826._4 | |
119 | 119 | [IntegerEntry((user + kUserInterest), userNewInterest), IntegerEntry((user + kUserAvailable), claimAmountAvailable), IntegerEntry((user + kUserTokenStaked), (userTokenStaked + pmtAmount)), IntegerEntry((user + kTotalTokenStaked), (totalTokenStaked + pmtAmount))] | |
120 | 120 | } | |
121 | 121 | } | |
128 | 128 | if ((0 >= amount)) | |
129 | 129 | then throw("Amount must be greater than 0") | |
130 | 130 | else { | |
131 | - | let $ | |
132 | - | let userNewInterest = $ | |
133 | - | let claimAmountAvailable = $ | |
134 | - | let userTokenStaked = $ | |
135 | - | let totalTokenStaked = $ | |
131 | + | let $t042474343 = claimCalc(user) | |
132 | + | let userNewInterest = $t042474343._1 | |
133 | + | let claimAmountAvailable = $t042474343._2 | |
134 | + | let userTokenStaked = $t042474343._3 | |
135 | + | let totalTokenStaked = $t042474343._4 | |
136 | 136 | if ((amount > userTokenStaked)) | |
137 | 137 | then throw("You can't unstake more than staked") | |
138 | 138 | else [IntegerEntry((user + kUserInterest), userNewInterest), IntegerEntry((user + kUserAvailable), claimAmountAvailable), IntegerEntry((user + kUserTokenStaked), (userTokenStaked - amount)), IntegerEntry((user + kTotalTokenStaked), (totalTokenStaked - amount))] | |
144 | 144 | @Callable(i) | |
145 | 145 | func claim () = { | |
146 | 146 | let user = toString(i.caller) | |
147 | - | let $ | |
148 | - | let userNewInterest = $ | |
149 | - | let claimAmountAvailable = $ | |
150 | - | let userTokenStaked = $ | |
151 | - | let totalTokenStaked = $ | |
147 | + | let $t047664862 = claimCalc(user) | |
148 | + | let userNewInterest = $t047664862._1 | |
149 | + | let claimAmountAvailable = $t047664862._2 | |
150 | + | let userTokenStaked = $t047664862._3 | |
151 | + | let totalTokenStaked = $t047664862._4 | |
152 | 152 | if ((claimAmountAvailable == 0)) | |
153 | 153 | then throw("Nothing to claim") | |
154 | 154 | else [IntegerEntry((user + kUserInterest), userNewInterest), IntegerEntry((user + kUserAvailable), 0), ScriptTransfer(i.caller, claimAmountAvailable, fromBase58String(tokenId))] | |
160 | 160 | func stakeNFT () = if ((size(i.payments) != 0)) | |
161 | 161 | then throw("One payment expected") | |
162 | 162 | else { | |
163 | - | let $ | |
164 | - | let pmtAmount = $ | |
165 | - | let pmtAssetId = $ | |
163 | + | let $t052275302 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
164 | + | let pmtAmount = $t052275302._1 | |
165 | + | let pmtAssetId = $t052275302._2 | |
166 | 166 | let pmtAssetIdStr = assetIdToStr(pmtAssetId) | |
167 | 167 | if (!(isDefined(getString(this, (pmtAssetIdStr + kNFTCreated))))) | |
168 | 168 | then throw("Wrong nft asset") | |
169 | 169 | else { | |
170 | 170 | let user = toString(i.caller) | |
171 | - | let $ | |
172 | - | let userNewInterest = $ | |
173 | - | let claimAmountAvailable = $ | |
174 | - | let userNFTStaked = $ | |
175 | - | let totalNFTStaked = $ | |
171 | + | let $t054835578 = claimCalcNft(user) | |
172 | + | let userNewInterest = $t054835578._1 | |
173 | + | let claimAmountAvailable = $t054835578._2 | |
174 | + | let userNFTStaked = $t054835578._3 | |
175 | + | let totalNFTStaked = $t054835578._4 | |
176 | 176 | [IntegerEntry((user + kNFTUserInterest), userNewInterest), IntegerEntry((user + kNFTUserAvailableClaim), claimAmountAvailable), IntegerEntry((user + kuserNFTStaked), (userNFTStaked + pmtAmount)), IntegerEntry((user + kNFTTotalStaked), (totalNFTStaked + pmtAmount)), IntegerEntry((((user + "_") + pmtAssetIdStr) + kuserNFTStakedId), 1)] | |
177 | 177 | } | |
178 | 178 | } | |
185 | 185 | if (isDefined(getString(this, (((user + id) + "_") + kuserNFTStakedId)))) | |
186 | 186 | then throw("You didn't staked") | |
187 | 187 | else { | |
188 | - | let $ | |
189 | - | let userNewInterest = $ | |
190 | - | let claimAmountAvailable = $ | |
191 | - | let userNFTStaked = $ | |
192 | - | let totalNFTStaked = $ | |
188 | + | let $t061106205 = claimCalcNft(user) | |
189 | + | let userNewInterest = $t061106205._1 | |
190 | + | let claimAmountAvailable = $t061106205._2 | |
191 | + | let userNFTStaked = $t061106205._3 | |
192 | + | let totalNFTStaked = $t061106205._4 | |
193 | 193 | [IntegerEntry((user + kNFTUserInterest), userNewInterest), IntegerEntry((user + kNFTUserAvailableClaim), claimAmountAvailable), IntegerEntry((user + kuserNFTStaked), (userNFTStaked - 1)), IntegerEntry((user + kNFTTotalStaked), (totalNFTStaked - 1)), DeleteEntry((((user + "_") + id) + kuserNFTStakedId)), ScriptTransfer(i.caller, 1, fromBase58String(id))] | |
194 | 194 | } | |
195 | 195 | } | |
199 | 199 | @Callable(i) | |
200 | 200 | func claimNFT () = { | |
201 | 201 | let user = toString(i.caller) | |
202 | - | let $ | |
203 | - | let userNewInterest = $ | |
204 | - | let claimAmountAvailable = $ | |
205 | - | let userNFTStaked = $ | |
206 | - | let totalNFTStaked = $ | |
202 | + | let $t066466741 = claimCalcNft(user) | |
203 | + | let userNewInterest = $t066466741._1 | |
204 | + | let claimAmountAvailable = $t066466741._2 | |
205 | + | let userNFTStaked = $t066466741._3 | |
206 | + | let totalNFTStaked = $t066466741._4 | |
207 | 207 | if ((claimAmountAvailable == 0)) | |
208 | 208 | then throw("Nothing to claim") | |
209 | 209 | else [IntegerEntry((user + kNFTUserInterest), userNewInterest), IntegerEntry((user + kNFTUserAvailableClaim), 0), ScriptTransfer(i.caller, claimAmountAvailable, fromBase58String(tokenId))] | |
225 | 225 | func airdrop () = valueOrElse(isAdminCall(i), if ((size(i.payments) != 0)) | |
226 | 226 | then throw("One payment expected") | |
227 | 227 | else { | |
228 | - | let $ | |
229 | - | let pmtAmount = $ | |
230 | - | let pmtAssetId = $ | |
228 | + | let $t075307605 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
229 | + | let pmtAmount = $t075307605._1 | |
230 | + | let pmtAssetId = $t075307605._2 | |
231 | 231 | if ((pmtAssetId != fromBase58String(tokenId))) | |
232 | 232 | then throw("Wrong payment asset") | |
233 | 233 | else { |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let NFT_PERCENT = 50 | |
5 | 5 | ||
6 | 6 | let SCALE8 = 100000000 | |
7 | 7 | ||
8 | 8 | let kInterest = "interest" | |
9 | 9 | ||
10 | 10 | let kUserInterest = "_userInterest" | |
11 | 11 | ||
12 | 12 | let kUserAvailable = "_userAvailableClaim" | |
13 | 13 | ||
14 | 14 | let kUserTokenStaked = "_userTokenStaked" | |
15 | 15 | ||
16 | - | let kTotalTokenStaked = "totalTokenStaked" | |
16 | + | let kTotalTokenStaked = "_totalTokenStaked" | |
17 | 17 | ||
18 | - | let kNFTInterest = "NFTInterest" | |
18 | + | let kNFTInterest = "_NFTInterest" | |
19 | 19 | ||
20 | 20 | let kNFTUserInterest = "_NFTUserInterest" | |
21 | 21 | ||
22 | - | let kNFTUserAvailableClaim = "NFTUserAvailableClaim" | |
22 | + | let kNFTUserAvailableClaim = "_NFTUserAvailableClaim" | |
23 | 23 | ||
24 | - | let kNFTTotalStaked = "NFTTotalStaked" | |
24 | + | let kNFTTotalStaked = "_NFTTotalStaked" | |
25 | 25 | ||
26 | 26 | let kuserNFTStaked = "_userNFTStaked" | |
27 | 27 | ||
28 | 28 | let kuserNFTStakedId = "_userNFTStakedId" | |
29 | 29 | ||
30 | + | let kNFTCreated = "_NFTCreated" | |
31 | + | ||
30 | 32 | let kTokenid = "tokenId" | |
31 | - | ||
32 | - | let kNFTCreated = "_NFTCreated" | |
33 | 33 | ||
34 | 34 | let kAdmin1PK = "admin_pub_1" | |
35 | 35 | ||
36 | 36 | let kAdmin2PK = "admin_pub_2" | |
37 | 37 | ||
38 | 38 | let kAdmin3PK = "admin_pub_3" | |
39 | 39 | ||
40 | 40 | let admin1PK = fromBase58String(valueOrErrorMessage(getString(this, kAdmin1PK), "Can't get admin1PK")) | |
41 | 41 | ||
42 | 42 | let admin2PK = fromBase58String(valueOrErrorMessage(getString(this, kAdmin2PK), "Can't get admin2PK")) | |
43 | 43 | ||
44 | 44 | let admin3PK = fromBase58String(valueOrErrorMessage(getString(this, kAdmin3PK), "Can't get operatorPK")) | |
45 | 45 | ||
46 | 46 | let tokenId = valueOrErrorMessage(getString(this, kTokenid), "Can't get staking token") | |
47 | 47 | ||
48 | 48 | func isAdminCall (i) = if (containsElement([admin1PK, admin2PK, admin3PK], i.callerPublicKey)) | |
49 | 49 | then unit | |
50 | 50 | else throw("Only admin can call this function") | |
51 | 51 | ||
52 | 52 | ||
53 | 53 | func isSelfCall (i) = if ((i.caller == this)) | |
54 | 54 | then unit | |
55 | 55 | else throw("Only contract itself can call this function") | |
56 | 56 | ||
57 | 57 | ||
58 | 58 | func assetIdToStr (assetId) = match assetId { | |
59 | 59 | case id: ByteVector => | |
60 | 60 | toBase58String(id) | |
61 | 61 | case waves: Unit => | |
62 | 62 | "WAVES" | |
63 | 63 | case _ => | |
64 | 64 | throw("Not Asset id") | |
65 | 65 | } | |
66 | 66 | ||
67 | 67 | ||
68 | 68 | func claimCalc (user) = { | |
69 | 69 | let totalTokenStaked = valueOrElse(getInteger(this, kTotalTokenStaked), 0) | |
70 | 70 | let curInterest = valueOrElse(getInteger(this, kInterest), 0) | |
71 | 71 | let availableForClaim = valueOrElse(getInteger(this, (user + kUserAvailable)), 0) | |
72 | 72 | let userInterest = valueOrElse(getInteger(this, (user + kUserInterest)), curInterest) | |
73 | 73 | let userTokenStaked = valueOrElse(getInteger(this, (user + kUserTokenStaked)), 0) | |
74 | 74 | let claimAmount = fraction(userTokenStaked, (curInterest - userInterest), SCALE8) | |
75 | 75 | $Tuple4(curInterest, (claimAmount + availableForClaim), userTokenStaked, totalTokenStaked) | |
76 | 76 | } | |
77 | 77 | ||
78 | 78 | ||
79 | 79 | func claimCalcNft (user) = { | |
80 | 80 | let totalNftStaked = valueOrElse(getInteger(this, kNFTTotalStaked), 0) | |
81 | 81 | let curInterest = valueOrElse(getInteger(this, kNFTInterest), 0) | |
82 | 82 | let availableForClaim = valueOrElse(getInteger(this, (user + kNFTUserAvailableClaim)), 0) | |
83 | 83 | let userInterest = valueOrElse(getInteger(this, (user + kNFTUserInterest)), curInterest) | |
84 | 84 | let userNftStaked = valueOrElse(getInteger(this, (user + kuserNFTStaked)), 0) | |
85 | 85 | let claimAmount = fraction(userNftStaked, (curInterest - userInterest), SCALE8) | |
86 | 86 | $Tuple4(curInterest, (claimAmount + availableForClaim), userNftStaked, totalNftStaked) | |
87 | 87 | } | |
88 | 88 | ||
89 | 89 | ||
90 | 90 | @Callable(i) | |
91 | 91 | func init (tokenId,adm1Pub,adm2Pub,adm3Pub) = valueOrElse(isSelfCall(i), if (!(isDefined(assetInfo(fromBase58String(tokenId))))) | |
92 | 92 | then throw("asset id is not correct asset id") | |
93 | 93 | else if ((size(fromBase58String(adm1Pub)) != 32)) | |
94 | 94 | then throw("group1Admin1PubKey is not correct") | |
95 | 95 | else if ((size(fromBase58String(adm2Pub)) != 32)) | |
96 | 96 | then throw("group1Admin1PubKey is not correct") | |
97 | 97 | else if ((size(fromBase58String(adm3Pub)) != 32)) | |
98 | 98 | then throw("group1Admin1PubKey is not correct") | |
99 | 99 | else [StringEntry(kTokenid, tokenId), StringEntry(kAdmin1PK, adm1Pub), StringEntry(kAdmin2PK, adm2Pub), StringEntry(kAdmin3PK, adm3Pub)]) | |
100 | 100 | ||
101 | 101 | ||
102 | 102 | ||
103 | 103 | @Callable(i) | |
104 | 104 | func stake () = if ((size(i.payments) != 1)) | |
105 | 105 | then throw("One payment expected") | |
106 | 106 | else { | |
107 | - | let $ | |
108 | - | let pmtAmount = $ | |
109 | - | let pmtAssetId = $ | |
107 | + | let $t035343609 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
108 | + | let pmtAmount = $t035343609._1 | |
109 | + | let pmtAssetId = $t035343609._2 | |
110 | 110 | if ((pmtAssetId != fromBase58String(tokenId))) | |
111 | 111 | then throw("Wrong payment asset") | |
112 | 112 | else { | |
113 | 113 | let user = toString(i.caller) | |
114 | - | let $ | |
115 | - | let userNewInterest = $ | |
116 | - | let claimAmountAvailable = $ | |
117 | - | let userTokenStaked = $ | |
118 | - | let totalTokenStaked = $ | |
114 | + | let $t037303826 = claimCalc(user) | |
115 | + | let userNewInterest = $t037303826._1 | |
116 | + | let claimAmountAvailable = $t037303826._2 | |
117 | + | let userTokenStaked = $t037303826._3 | |
118 | + | let totalTokenStaked = $t037303826._4 | |
119 | 119 | [IntegerEntry((user + kUserInterest), userNewInterest), IntegerEntry((user + kUserAvailable), claimAmountAvailable), IntegerEntry((user + kUserTokenStaked), (userTokenStaked + pmtAmount)), IntegerEntry((user + kTotalTokenStaked), (totalTokenStaked + pmtAmount))] | |
120 | 120 | } | |
121 | 121 | } | |
122 | 122 | ||
123 | 123 | ||
124 | 124 | ||
125 | 125 | @Callable(i) | |
126 | 126 | func unstake (amount) = { | |
127 | 127 | let user = toString(i.caller) | |
128 | 128 | if ((0 >= amount)) | |
129 | 129 | then throw("Amount must be greater than 0") | |
130 | 130 | else { | |
131 | - | let $ | |
132 | - | let userNewInterest = $ | |
133 | - | let claimAmountAvailable = $ | |
134 | - | let userTokenStaked = $ | |
135 | - | let totalTokenStaked = $ | |
131 | + | let $t042474343 = claimCalc(user) | |
132 | + | let userNewInterest = $t042474343._1 | |
133 | + | let claimAmountAvailable = $t042474343._2 | |
134 | + | let userTokenStaked = $t042474343._3 | |
135 | + | let totalTokenStaked = $t042474343._4 | |
136 | 136 | if ((amount > userTokenStaked)) | |
137 | 137 | then throw("You can't unstake more than staked") | |
138 | 138 | else [IntegerEntry((user + kUserInterest), userNewInterest), IntegerEntry((user + kUserAvailable), claimAmountAvailable), IntegerEntry((user + kUserTokenStaked), (userTokenStaked - amount)), IntegerEntry((user + kTotalTokenStaked), (totalTokenStaked - amount))] | |
139 | 139 | } | |
140 | 140 | } | |
141 | 141 | ||
142 | 142 | ||
143 | 143 | ||
144 | 144 | @Callable(i) | |
145 | 145 | func claim () = { | |
146 | 146 | let user = toString(i.caller) | |
147 | - | let $ | |
148 | - | let userNewInterest = $ | |
149 | - | let claimAmountAvailable = $ | |
150 | - | let userTokenStaked = $ | |
151 | - | let totalTokenStaked = $ | |
147 | + | let $t047664862 = claimCalc(user) | |
148 | + | let userNewInterest = $t047664862._1 | |
149 | + | let claimAmountAvailable = $t047664862._2 | |
150 | + | let userTokenStaked = $t047664862._3 | |
151 | + | let totalTokenStaked = $t047664862._4 | |
152 | 152 | if ((claimAmountAvailable == 0)) | |
153 | 153 | then throw("Nothing to claim") | |
154 | 154 | else [IntegerEntry((user + kUserInterest), userNewInterest), IntegerEntry((user + kUserAvailable), 0), ScriptTransfer(i.caller, claimAmountAvailable, fromBase58String(tokenId))] | |
155 | 155 | } | |
156 | 156 | ||
157 | 157 | ||
158 | 158 | ||
159 | 159 | @Callable(i) | |
160 | 160 | func stakeNFT () = if ((size(i.payments) != 0)) | |
161 | 161 | then throw("One payment expected") | |
162 | 162 | else { | |
163 | - | let $ | |
164 | - | let pmtAmount = $ | |
165 | - | let pmtAssetId = $ | |
163 | + | let $t052275302 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
164 | + | let pmtAmount = $t052275302._1 | |
165 | + | let pmtAssetId = $t052275302._2 | |
166 | 166 | let pmtAssetIdStr = assetIdToStr(pmtAssetId) | |
167 | 167 | if (!(isDefined(getString(this, (pmtAssetIdStr + kNFTCreated))))) | |
168 | 168 | then throw("Wrong nft asset") | |
169 | 169 | else { | |
170 | 170 | let user = toString(i.caller) | |
171 | - | let $ | |
172 | - | let userNewInterest = $ | |
173 | - | let claimAmountAvailable = $ | |
174 | - | let userNFTStaked = $ | |
175 | - | let totalNFTStaked = $ | |
171 | + | let $t054835578 = claimCalcNft(user) | |
172 | + | let userNewInterest = $t054835578._1 | |
173 | + | let claimAmountAvailable = $t054835578._2 | |
174 | + | let userNFTStaked = $t054835578._3 | |
175 | + | let totalNFTStaked = $t054835578._4 | |
176 | 176 | [IntegerEntry((user + kNFTUserInterest), userNewInterest), IntegerEntry((user + kNFTUserAvailableClaim), claimAmountAvailable), IntegerEntry((user + kuserNFTStaked), (userNFTStaked + pmtAmount)), IntegerEntry((user + kNFTTotalStaked), (totalNFTStaked + pmtAmount)), IntegerEntry((((user + "_") + pmtAssetIdStr) + kuserNFTStakedId), 1)] | |
177 | 177 | } | |
178 | 178 | } | |
179 | 179 | ||
180 | 180 | ||
181 | 181 | ||
182 | 182 | @Callable(i) | |
183 | 183 | func unstakeNFT (id) = { | |
184 | 184 | let user = toString(i.caller) | |
185 | 185 | if (isDefined(getString(this, (((user + id) + "_") + kuserNFTStakedId)))) | |
186 | 186 | then throw("You didn't staked") | |
187 | 187 | else { | |
188 | - | let $ | |
189 | - | let userNewInterest = $ | |
190 | - | let claimAmountAvailable = $ | |
191 | - | let userNFTStaked = $ | |
192 | - | let totalNFTStaked = $ | |
188 | + | let $t061106205 = claimCalcNft(user) | |
189 | + | let userNewInterest = $t061106205._1 | |
190 | + | let claimAmountAvailable = $t061106205._2 | |
191 | + | let userNFTStaked = $t061106205._3 | |
192 | + | let totalNFTStaked = $t061106205._4 | |
193 | 193 | [IntegerEntry((user + kNFTUserInterest), userNewInterest), IntegerEntry((user + kNFTUserAvailableClaim), claimAmountAvailable), IntegerEntry((user + kuserNFTStaked), (userNFTStaked - 1)), IntegerEntry((user + kNFTTotalStaked), (totalNFTStaked - 1)), DeleteEntry((((user + "_") + id) + kuserNFTStakedId)), ScriptTransfer(i.caller, 1, fromBase58String(id))] | |
194 | 194 | } | |
195 | 195 | } | |
196 | 196 | ||
197 | 197 | ||
198 | 198 | ||
199 | 199 | @Callable(i) | |
200 | 200 | func claimNFT () = { | |
201 | 201 | let user = toString(i.caller) | |
202 | - | let $ | |
203 | - | let userNewInterest = $ | |
204 | - | let claimAmountAvailable = $ | |
205 | - | let userNFTStaked = $ | |
206 | - | let totalNFTStaked = $ | |
202 | + | let $t066466741 = claimCalcNft(user) | |
203 | + | let userNewInterest = $t066466741._1 | |
204 | + | let claimAmountAvailable = $t066466741._2 | |
205 | + | let userNFTStaked = $t066466741._3 | |
206 | + | let totalNFTStaked = $t066466741._4 | |
207 | 207 | if ((claimAmountAvailable == 0)) | |
208 | 208 | then throw("Nothing to claim") | |
209 | 209 | else [IntegerEntry((user + kNFTUserInterest), userNewInterest), IntegerEntry((user + kNFTUserAvailableClaim), 0), ScriptTransfer(i.caller, claimAmountAvailable, fromBase58String(tokenId))] | |
210 | 210 | } | |
211 | 211 | ||
212 | 212 | ||
213 | 213 | ||
214 | 214 | @Callable(i) | |
215 | 215 | func issueNFT (userAddr,name,descr) = valueOrElse(isAdminCall(i), { | |
216 | 216 | let uAddr = valueOrErrorMessage(addressFromString(userAddr), "Wrong user address") | |
217 | 217 | let issue = Issue(name, descr, 1, 1, false) | |
218 | 218 | let nftId = calculateAssetId(issue) | |
219 | 219 | [StringEntry((toBase58String(nftId) + kNFTCreated), userAddr), ScriptTransfer(uAddr, 1, nftId)] | |
220 | 220 | }) | |
221 | 221 | ||
222 | 222 | ||
223 | 223 | ||
224 | 224 | @Callable(i) | |
225 | 225 | func airdrop () = valueOrElse(isAdminCall(i), if ((size(i.payments) != 0)) | |
226 | 226 | then throw("One payment expected") | |
227 | 227 | else { | |
228 | - | let $ | |
229 | - | let pmtAmount = $ | |
230 | - | let pmtAssetId = $ | |
228 | + | let $t075307605 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
229 | + | let pmtAmount = $t075307605._1 | |
230 | + | let pmtAssetId = $t075307605._2 | |
231 | 231 | if ((pmtAssetId != fromBase58String(tokenId))) | |
232 | 232 | then throw("Wrong payment asset") | |
233 | 233 | else { | |
234 | 234 | let totalTokenStaked = valueOrElse(getInteger(this, kTotalTokenStaked), 0) | |
235 | 235 | let totalNFTStaked = valueOrElse(getInteger(this, kNFTTotalStaked), 0) | |
236 | 236 | let curInterest = valueOrElse(getInteger(this, kInterest), 0) | |
237 | 237 | let curNFTInterest = valueOrElse(getInteger(this, kNFTInterest), 0) | |
238 | 238 | let pmtNFT = fraction(pmtAmount, NFT_PERCENT, 100) | |
239 | 239 | let pmtToken = (pmtAmount - pmtNFT) | |
240 | 240 | let interestNew = if ((totalTokenStaked > 0)) | |
241 | 241 | then (curInterest + fraction(pmtToken, SCALE8, totalTokenStaked)) | |
242 | 242 | else curInterest | |
243 | 243 | let interestNFTNew = if ((totalTokenStaked > 0)) | |
244 | 244 | then (curNFTInterest + fraction(pmtNFT, SCALE8, totalNFTStaked)) | |
245 | 245 | else curNFTInterest | |
246 | 246 | [IntegerEntry(kInterest, interestNew), IntegerEntry(kNFTInterest, interestNFTNew)] | |
247 | 247 | } | |
248 | 248 | }) | |
249 | 249 | ||
250 | 250 | ||
251 | 251 | @Verifier(tx) | |
252 | 252 | func verify () = { | |
253 | 253 | let multiSignedByAdmins = { | |
254 | 254 | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin1PK)) | |
255 | 255 | then 1 | |
256 | 256 | else 0 | |
257 | 257 | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], admin2PK)) | |
258 | 258 | then 1 | |
259 | 259 | else 0 | |
260 | 260 | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], admin3PK)) | |
261 | 261 | then 1 | |
262 | 262 | else 0 | |
263 | 263 | (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2) | |
264 | 264 | } | |
265 | 265 | match tx { | |
266 | 266 | case inv: InvokeScriptTransaction => | |
267 | 267 | let isSelf = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
268 | 268 | let isRightFee = if ((inv.fee == 900000)) | |
269 | 269 | then (inv.feeAssetId == unit) | |
270 | 270 | else false | |
271 | 271 | let isInitCall = (inv.function == "init") | |
272 | 272 | let isnoPayments = (size(inv.payments) == 0) | |
273 | 273 | if (if (if (if (isRightFee) | |
274 | 274 | then isInitCall | |
275 | 275 | else false) | |
276 | 276 | then isSelf | |
277 | 277 | else false) | |
278 | 278 | then isnoPayments | |
279 | 279 | else false) | |
280 | 280 | then true | |
281 | 281 | else multiSignedByAdmins | |
282 | 282 | case _ => | |
283 | 283 | multiSignedByAdmins | |
284 | 284 | } | |
285 | 285 | } | |
286 | 286 |
github/deemru/w8io/169f3d6 59.25 ms ◑![]()