tx · 3TNwSiNHpdapQgiYciuZcCweAXBHAxZZk8xCSEoHSYuf

3MwyBKGZcdChEK9Z55HwLn3A2EgwEJJpqC1:  -0.01200000 Waves

2024.01.09 16:32 [2924014] smart account 3MwyBKGZcdChEK9Z55HwLn3A2EgwEJJpqC1 > SELF 0.00000000 Waves

{ "type": 13, "id": "3TNwSiNHpdapQgiYciuZcCweAXBHAxZZk8xCSEoHSYuf", "fee": 1200000, "feeAssetId": null, "timestamp": 1704807159967, "version": 2, "chainId": 84, "sender": "3MwyBKGZcdChEK9Z55HwLn3A2EgwEJJpqC1", "senderPublicKey": "7c3qLtcJ7EaPS2JDjXv8MBbd4kpyc6R27wcn5GgvZhur", "proofs": [ "5MFqAsq3NUwxaA1aaDgzPCKJ8r9SALrZy1pNvSWH9U6ngmfPEQqF4DywgR9MsmQWp7tPugJb48EFFQ829AbdxKWP" ], "script": "base64:BgIbCAISBgoECAEBARIDCgEIEgMKAQgSABIDCgEIHQAMY29udHJhY3RGaWxlAhB2ZXN0aW5nX25lby5yaWRlAANTRVACAl9fAAhJRFNfTElTVAkAzAgCAAAJAMwIAgABCQDMCAIAAgkAzAgCAAMJAMwIAgAECQDMCAIABQkAzAgCAAYJAMwIAgAHCQDMCAIACAkAzAgCAAkJAMwIAgAKCQDMCAIACwkAzAgCAAwJAMwIAgANCQDMCAIADgkAzAgCAA8JAMwIAgAQCQDMCAIAEQkAzAgCABIJAMwIAgATCQDMCAIAFAkAzAgCABUJAMwIAgAWCQDMCAIAFwkAzAgCABgJAMwIAgAZCQDMCAIAGgkAzAgCABsJAMwIAgAcCQDMCAIAHQUDbmlsABFNQVhfVkVTVElOR19DT1VOVAkAkAMBBQhJRFNfTElTVAEIdGhyb3dFcnIBA21zZwkAAgEJAKwCAgkArAICBQxjb250cmFjdEZpbGUCAjogBQNtc2cACmtleUFzc2V0SWQJALkJAgkAzAgCAgIlcwkAzAgCAgdhc3NldElkBQNuaWwFA1NFUAANYXNzZXRJZFN0cmluZwkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBQprZXlBc3NldElkAgVXQVZFUwAMYXNzZXRJZEJ5dGVzAwkAAAIFDWFzc2V0SWRTdHJpbmcCBVdBVkVTBQR1bml0CQDZBAEFDWFzc2V0SWRTdHJpbmcADGtleUFkbWluTGlzdAkAuQkCCQDMCAICAiVzCQDMCAICCWFkbWluTGlzdAUDbmlsBQNTRVAACmtleUJhbkxpc3QJALkJAgkAzAgCAgIlcwkAzAgCAgdiYW5MaXN0BQNuaWwFA1NFUAAJYWRtaW5MaXN0BAckbWF0Y2gwCQCdCAIFBHRoaXMFDGtleUFkbWluTGlzdAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAJALUJAgUBcwUDU0VQBQNuaWwAB2Jhbkxpc3QEByRtYXRjaDAJAJ0IAgUEdGhpcwUKa2V5QmFuTGlzdAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDADCQAAAgUBcwIABQNuaWwJAL0JAgUBcwUDU0VQBQNuaWwBFGlzVmFsaWRBZGRyZXNzU3RyaW5nAQ1hZGRyZXNzU3RyaW5nBAckbWF0Y2gwCQCmCAEFDWFkZHJlc3NTdHJpbmcDCQABAgUHJG1hdGNoMAIHQWRkcmVzcwQBYQUHJG1hdGNoMAYHAQ5rZXlVc2VyVmVzdGluZwILdXNlckFkZHJlc3MCaWQEBmNoZWNrcwkAzAgCAwkBFGlzVmFsaWRBZGRyZXNzU3RyaW5nAQULdXNlckFkZHJlc3MGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIVYWRkcmVzcyBpcyBub3QgdmFsaWQ6CQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwCASAJAMwIAgMDCQBnAgUCaWQAAAkAZgIFEU1BWF9WRVNUSU5HX0NPVU5UBQJpZAcGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIWaWQgc2hvdWxkIGJlIGxlc3MgdGhhbgkAzAgCCQCkAwEFEU1BWF9WRVNUSU5HX0NPVU5UCQDMCAICBGdvdDoJAMwIAgkApAMBBQJpZAUDbmlsAgEgBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MJALkJAgkAzAgCAgYlcyVzJWQJAMwIAgIHdmVzdGluZwkAzAgCBQt1c2VyQWRkcmVzcwkAzAgCCQCkAwEFAmlkBQNuaWwFA1NFUAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgESa2V5VXNlckFjY3VtdWxhdGVkAQt1c2VyQWRkcmVzcwQGY2hlY2tzCQDMCAIDCQEUaXNWYWxpZEFkZHJlc3NTdHJpbmcBBQt1c2VyQWRkcmVzcwYJAQh0aHJvd0VycgEJALkJAgkAzAgCAhVhZGRyZXNzIGlzIG5vdCB2YWxpZDoJAMwIAgULdXNlckFkZHJlc3MFA25pbAIBIAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzCQC5CQIJAMwIAgIEJXMlcwkAzAgCAgthY2N1bXVsYXRlZAkAzAgCBQt1c2VyQWRkcmVzcwUDbmlsBQNTRVAJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BEWZvcm1hdFVzZXJWZXN0aW5nAw12ZXN0aW5nQW1vdW50CnN0YXJ0QmxvY2sKbG9ja0xlbmd0aAQGY2hlY2tzCQDMCAIDCQBnAgUNdmVzdGluZ0Ftb3VudAAABgkBCHRocm93RXJyAQIhdmVzdGluZyBhbW91bnQgY2Fubm90IGJlIG5lZ2F0aXZlCQDMCAIDCQBnAgUKc3RhcnRCbG9jawAABgkBCHRocm93RXJyAQIec3RhcnQgYmxvY2sgY2Fubm90IGJlIG5lZ2F0aXZlCQDMCAIDCQBnAgUKbG9ja0xlbmd0aAAABgkBCHRocm93RXJyAQIebG9jayBsZW5ndGggY2Fubm90IGJlIG5lZ2F0aXZlBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MJALkJAgkAzAgCAgYlZCVkJWQJAMwIAgkApAMBBQ12ZXN0aW5nQW1vdW50CQDMCAIJAKQDAQUKc3RhcnRCbG9jawkAzAgCCQCkAwEFCmxvY2tMZW5ndGgFA25pbAUDU0VQCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARBwYXJzZVVzZXJWZXN0aW5nAgt1c2VyQWRkcmVzcwJpZAQHJG1hdGNoMAkAnQgCBQR0aGlzCQEOa2V5VXNlclZlc3RpbmcCBQt1c2VyQWRkcmVzcwUCaWQDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAlyYXdTdHJpbmcFByRtYXRjaDAEC3NwbGl0U3RyaW5nCQC1CQIFCXJhd1N0cmluZwUDU0VQBA12ZXN0aW5nQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgULc3BsaXRTdHJpbmcAAQQKc3RhcnRCbG9jawkBDXBhcnNlSW50VmFsdWUBCQCRAwIFC3NwbGl0U3RyaW5nAAIECmxvY2tMZW5ndGgJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQtzcGxpdFN0cmluZwADCQCVCgMFDXZlc3RpbmdBbW91bnQFCnN0YXJ0QmxvY2sFCmxvY2tMZW5ndGgJAJUKAwAAAAAAAAERa2V5VmVzdGluZ0hpc3RvcnkDBmFjdGlvbgt1c2VyQWRkcmVzcwR0eElkCQC5CQIJAMwIAgIIJXMlcyVzJXMJAMwIAgIHaGlzdG9yeQkAzAgCBQt1c2VyQWRkcmVzcwkAzAgCBQZhY3Rpb24JAMwIAgUEdHhJZAUDbmlsBQNTRVABEmNhbGNVbmxvY2tlZEFtb3VudAMGYW1vdW50CnN0YXJ0QmxvY2sKbG9ja0xlbmd0aAQNZWxhcHNlZEJsb2NrcwkAZQIFBmhlaWdodAUKc3RhcnRCbG9jawQOdW5sb2NrZWRBbW91bnQDAwkBAiE9AgUKbG9ja0xlbmd0aAAACQBmAgUNZWxhcHNlZEJsb2NrcwAABwkAlwMBCQDMCAIJAGsDBQZhbW91bnQFDWVsYXBzZWRCbG9ja3MFCmxvY2tMZW5ndGgJAMwIAgUGYW1vdW50BQNuaWwAAAkAlAoCBQ51bmxvY2tlZEFtb3VudAkAZQIFBmFtb3VudAUOdW5sb2NrZWRBbW91bnQBFWdldFVzZXJVbmxvY2tlZEFtb3VudAILdXNlckFkZHJlc3MCaWQECyR0MDMyMDkzMjg4CQEQcGFyc2VVc2VyVmVzdGluZwIFC3VzZXJBZGRyZXNzBQJpZAQNdmVzdGluZ0Ftb3VudAgFCyR0MDMyMDkzMjg4Al8xBApzdGFydEJsb2NrCAULJHQwMzIwOTMyODgCXzIECmxvY2tMZW5ndGgIBQskdDAzMjA5MzI4OAJfMwQLJHQwMzI5MTMzODgJARJjYWxjVW5sb2NrZWRBbW91bnQDBQ12ZXN0aW5nQW1vdW50BQpzdGFydEJsb2NrBQpsb2NrTGVuZ3RoBA51bmxvY2tlZEFtb3VudAgFCyR0MDMyOTEzMzg4Al8xBA9yZW1haW5pbmdBbW91bnQIBQskdDAzMjkxMzM4OAJfMgkAlAoCBQ51bmxvY2tlZEFtb3VudAUPcmVtYWluaW5nQW1vdW50ARdnZXRVcGRhdGVWZXN0aW5nQWN0aW9ucwILdXNlckFkZHJlc3MCaWQECyR0MDM0OTUzNTc0CQEQcGFyc2VVc2VyVmVzdGluZwIFC3VzZXJBZGRyZXNzBQJpZAQNdmVzdGluZ0Ftb3VudAgFCyR0MDM0OTUzNTc0Al8xBApzdGFydEJsb2NrCAULJHQwMzQ5NTM1NzQCXzIECmxvY2tMZW5ndGgIBQskdDAzNDk1MzU3NAJfMwQLJHQwMzU3NzM2NTUJARVnZXRVc2VyVW5sb2NrZWRBbW91bnQCBQt1c2VyQWRkcmVzcwUCaWQEDnVubG9ja2VkQW1vdW50CAULJHQwMzU3NzM2NTUCXzEED3JlbWFpbmluZ0Ftb3VudAgFCyR0MDM1NzczNjU1Al8yBA9yZW1haW5pbmdCbG9ja3MJAJYDAQkAzAgCCQBlAgkAZAIFCnN0YXJ0QmxvY2sFCmxvY2tMZW5ndGgFBmhlaWdodAkAzAgCAAAFA25pbAQUdXBkYXRlVmVzdGluZ0FjdGlvbnMDCQECIT0CBQ51bmxvY2tlZEFtb3VudAAAAwkBAiE9AgUPcmVtYWluaW5nQmxvY2tzAAAJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDmtleVVzZXJWZXN0aW5nAgULdXNlckFkZHJlc3MFAmlkCQERZm9ybWF0VXNlclZlc3RpbmcDBQ9yZW1haW5pbmdBbW91bnQFBmhlaWdodAUPcmVtYWluaW5nQmxvY2tzBQNuaWwJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBDmtleVVzZXJWZXN0aW5nAgULdXNlckFkZHJlc3MFAmlkBQNuaWwFA25pbAkAlAoCBRR1cGRhdGVWZXN0aW5nQWN0aW9ucwUOdW5sb2NrZWRBbW91bnQBE2dldFVzZXJDbGFpbUFjdGlvbnMCC3VzZXJBZGRyZXNzAmlkBAskdDA0MTE5NDIwNAkBF2dldFVwZGF0ZVZlc3RpbmdBY3Rpb25zAgULdXNlckFkZHJlc3MFAmlkBBR1cGRhdGVWZXN0aW5nQWN0aW9ucwgFCyR0MDQxMTk0MjA0Al8xBA51bmxvY2tlZEFtb3VudAgFCyR0MDQxMTk0MjA0Al8yBA90cmFuc2ZlckFjdGlvbnMDCQECIT0CBQ51bmxvY2tlZEFtb3VudAAACQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFC3VzZXJBZGRyZXNzBQ51bmxvY2tlZEFtb3VudAUMYXNzZXRJZEJ5dGVzBQNuaWwFA25pbAkAlAoCCQDOCAIFFHVwZGF0ZVZlc3RpbmdBY3Rpb25zBQ90cmFuc2ZlckFjdGlvbnMFDnVubG9ja2VkQW1vdW50ARZnZXRBbGxVc2VyQ2xhaW1BY3Rpb25zAQt1c2VyQWRkcmVzcwoBDWFjdGlvbnNIZWxwZXICA2FjYwFhBAskdDA0NTc3NDYxNwUDYWNjBBdhbGxWZXN0aW5nc0NsYWltQWN0aW9ucwgFCyR0MDQ1Nzc0NjE3Al8xBANzdW0IBQskdDA0NTc3NDYxNwJfMgQLJHQwNDYyMjQ2OTgJARNnZXRVc2VyQ2xhaW1BY3Rpb25zAgULdXNlckFkZHJlc3MFAWEEE3Zlc3RpbmdDbGFpbUFjdGlvbnMIBQskdDA0NjIyNDY5OAJfMQQLY2xhaW1BbW91bnQIBQskdDA0NjIyNDY5OAJfMgkAlAoCCQDOCAIFF2FsbFZlc3RpbmdzQ2xhaW1BY3Rpb25zBRN2ZXN0aW5nQ2xhaW1BY3Rpb25zCQBkAgUDc3VtBQtjbGFpbUFtb3VudAoAAiRsBQhJRFNfTElTVAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgUDbmlsAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDWFjdGlvbnNIZWxwZXICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDMwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAAVABYAFwAYABkAGgAbABwAHQAeASZnZXRNb3ZlQWxsVW5sb2NrZWRUb0FjY3VtdWxhdG9yQWN0aW9ucwELdXNlckFkZHJlc3MKAQ1hY3Rpb25zSGVscGVyAgNhY2MBYQQLJHQwNDk5MDUwMzEFA2FjYwQYdXBkYXRlQWxsVmVzdGluZ3NBY3Rpb25zCAULJHQwNDk5MDUwMzECXzEEA3N1bQgFCyR0MDQ5OTA1MDMxAl8yBAskdDA1MDM2NTEyMAkBF2dldFVwZGF0ZVZlc3RpbmdBY3Rpb25zAgULdXNlckFkZHJlc3MFAWEEFHVwZGF0ZVZlc3RpbmdBY3Rpb25zCAULJHQwNTAzNjUxMjACXzEEDnVubG9ja2VkQW1vdW50CAULJHQwNTAzNjUxMjACXzIJAJQKAgkAzggCBRh1cGRhdGVBbGxWZXN0aW5nc0FjdGlvbnMFFHVwZGF0ZVZlc3RpbmdBY3Rpb25zCQBkAgUDc3VtBQ51bmxvY2tlZEFtb3VudAQLJHQwNTIwNjUyOTQKAAIkbAUISURTX0xJU1QKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFA25pbAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQ1hY3Rpb25zSGVscGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAzMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQAFQAWABcAGAAZABoAGwAcAB0AHgQYdXBkYXRlQWxsVmVzdGluZ3NBY3Rpb25zCAULJHQwNTIwNjUyOTQCXzEEC3VubG9ja2VkU3VtCAULJHQwNTIwNjUyOTQCXzIEDm9sZEFjY3VtdWxhdGVkCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJARJrZXlVc2VyQWNjdW11bGF0ZWQBBQt1c2VyQWRkcmVzcwAABBh1cGRhdGVBY2N1bXVsYXRlZEFjdGlvbnMDCQECIT0CBQt1bmxvY2tlZFN1bQAACQDMCAIJAQxJbnRlZ2VyRW50cnkCCQESa2V5VXNlckFjY3VtdWxhdGVkAQULdXNlckFkZHJlc3MJAGQCBQ5vbGRBY2N1bXVsYXRlZAULdW5sb2NrZWRTdW0FA25pbAUDbmlsCQCUCgIJAM4IAgUYdXBkYXRlQWxsVmVzdGluZ3NBY3Rpb25zBRh1cGRhdGVBY2N1bXVsYXRlZEFjdGlvbnMFC3VubG9ja2VkU3VtARpnZXRDbGFpbUFjY3VtdWxhdGVkQWN0aW9ucwELdXNlckFkZHJlc3MEDm9sZEFjY3VtdWxhdGVkCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJARJrZXlVc2VyQWNjdW11bGF0ZWQBBQt1c2VyQWRkcmVzcwAAAwkBAiE9AgUOb2xkQWNjdW11bGF0ZWQAAAkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFC3VzZXJBZGRyZXNzBQ5vbGRBY2N1bXVsYXRlZAUMYXNzZXRJZEJ5dGVzCQDMCAIJAQtEZWxldGVFbnRyeQEJARJrZXlVc2VyQWNjdW11bGF0ZWQBBQt1c2VyQWRkcmVzcwUDbmlsBQ5vbGRBY2N1bXVsYXRlZAkAlAoCBQNuaWwAAAESZ2V0Q2xhaW1BbGxBY3Rpb25zAQt1c2VyQWRkcmVzcwQLJHQwNjA2MjYxOTUDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQdiYW5MaXN0BQt1c2VyQWRkcmVzcwkBFmdldEFsbFVzZXJDbGFpbUFjdGlvbnMBBQt1c2VyQWRkcmVzcwkAlAoCBQNuaWwAAAQMY2xhaW1BY3Rpb25zCAULJHQwNjA2MjYxOTUCXzEEDnVubG9ja2VkQW1vdW50CAULJHQwNjA2MjYxOTUCXzIECyR0MDYxOTg2Mjg4CQEaZ2V0Q2xhaW1BY2N1bXVsYXRlZEFjdGlvbnMBBQt1c2VyQWRkcmVzcwQXY2xhaW1BY2N1bXVsYXRlZEFjdGlvbnMIBQskdDA2MTk4NjI4OAJfMQQRYWNjdW11bGF0ZWRBbW91bnQIBQskdDA2MTk4NjI4OAJfMgQLdG90YWxBbW91bnQJAGQCBQ51bmxvY2tlZEFtb3VudAURYWNjdW11bGF0ZWRBbW91bnQJAJQKAgkAzggCBQxjbGFpbUFjdGlvbnMFF2NsYWltQWNjdW11bGF0ZWRBY3Rpb25zBQt0b3RhbEFtb3VudAESZ2V0VmVzdGluZ1VzZXJJbmZvAQt1c2VyQWRkcmVzcwoBBmhlbHBlcgIDYWNjAmlkBAskdDA2NTAyNjU4MQkBEHBhcnNlVXNlclZlc3RpbmcCBQt1c2VyQWRkcmVzcwUCaWQEDXZlc3RpbmdBbW91bnQIBQskdDA2NTAyNjU4MQJfMQQKc3RhcnRCbG9jawgFCyR0MDY1MDI2NTgxAl8yBApsb2NrTGVuZ3RoCAULJHQwNjUwMjY1ODECXzMECyR0MDY1ODY2NjY0CQEVZ2V0VXNlclVubG9ja2VkQW1vdW50AgULdXNlckFkZHJlc3MFAmlkBA51bmxvY2tlZEFtb3VudAgFCyR0MDY1ODY2NjY0Al8xBA9yZW1haW5pbmdBbW91bnQIBQskdDA2NTg2NjY2NAJfMgMDCQAAAgUNdmVzdGluZ0Ftb3VudAAABgkBD2NvbnRhaW5zRWxlbWVudAIFB2Jhbkxpc3QFC3VzZXJBZGRyZXNzBQNhY2MJAM0IAgUDYWNjCQDMCAIFDXZlc3RpbmdBbW91bnQJAMwIAgkAZAIFCnN0YXJ0QmxvY2sFCmxvY2tMZW5ndGgJAMwIAgUOdW5sb2NrZWRBbW91bnQJAMwIAgUPcmVtYWluaW5nQW1vdW50BQNuaWwKAAIkbAUISURTX0xJU1QKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBBmhlbHBlcgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMzAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUABUAFgAXABgAGQAaABsAHAAdAB4BFWdldEF2YWlsYWJsZVZlc3RpbmdJZAELdXNlckFkZHJlc3MKAQZoZWxwZXICC2F2YWlsYWJsZUlkAmlkBAskdDA2OTg4NzA2NwkBEHBhcnNlVXNlclZlc3RpbmcCBQt1c2VyQWRkcmVzcwUCaWQEDXZlc3RpbmdBbW91bnQIBQskdDA2OTg4NzA2NwJfMQQKc3RhcnRCbG9jawgFCyR0MDY5ODg3MDY3Al8yBApsb2NrTGVuZ3RoCAULJHQwNjk4ODcwNjcCXzMDCQBmAgUNdmVzdGluZ0Ftb3VudAAABQthdmFpbGFibGVJZAMJAAACBQthdmFpbGFibGVJZAD///////////8BBQJpZAkAlwMBCQDMCAIFC2F2YWlsYWJsZUlkCQDMCAIFAmlkBQNuaWwEC2F2YWlsYWJsZUlkCgACJGwFCElEU19MSVNUCgACJHMJAJADAQUCJGwKAAUkYWNjMAD///////////8BCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQZoZWxwZXICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDMwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAAVABYAFwAYABkAGgAbABwAHQAeAwkAAAIFC2F2YWlsYWJsZUlkAP///////////wEJAQh0aHJvd0VycgEJALkJAgkAzAgCAih1c2VyIGV4Y2VlZGVkIG1heCBhY3RpdmUgdmVzdGluZyBjb3VudDogCQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwCASAFC2F2YWlsYWJsZUlkARRnZXROZXdWZXN0aW5nQWN0aW9ucwULdXNlckFkZHJlc3MCaWQNdmVzdGluZ0Ftb3VudApzdGFydEJsb2NrCmxvY2tMZW5ndGgJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDmtleVVzZXJWZXN0aW5nAgULdXNlckFkZHJlc3MFAmlkCQERZm9ybWF0VXNlclZlc3RpbmcDBQ12ZXN0aW5nQW1vdW50BQpzdGFydEJsb2NrBQpsb2NrTGVuZ3RoBQNuaWwFAWkBDnZlc3RpbmdGb3JVc2VyBAt1c2VyQWRkcmVzcw12ZXN0aW5nQW1vdW50CnN0YXJ0QmxvY2sKbG9ja0xlbmd0aAQFY2hlY2sJAMwIAgMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEGCQEIdGhyb3dFcnIBAiBzaG91bGQgYmUgd2l0aCBleGFjdGx5IDEgcGF5bWVudAkAzAgCAwkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUMYXNzZXRJZEJ5dGVzBgkBCHRocm93RXJyAQkAuQkCCQDMCAICG3BheW1lbnQgYXNzZXRJZCBzaG91bGQgYmU6IAkAzAgCBQ1hc3NldElkU3RyaW5nBQNuaWwCASAJAMwIAgMJAAACCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUNdmVzdGluZ0Ftb3VudAYJAQh0aHJvd0VycgECL3BheW1lbnQgYW1vdW50IHNob3VsZCBiZSBlcXVhbCB0byB2ZXN0aW5nQW1vdW50CQDMCAIDAwkAAAIFCWFkbWluTGlzdAUDbmlsBgkBD2NvbnRhaW5zRWxlbWVudAIFCWFkbWluTGlzdAkApQgBCAUBaQZjYWxsZXIGCQEIdGhyb3dFcnIBAhF5b3UgbXVzdCBiZSBhZG1pbgUDbmlsAwkAAAIFBWNoZWNrBQVjaGVjawQCaWQJARVnZXRBdmFpbGFibGVWZXN0aW5nSWQBBQt1c2VyQWRkcmVzcwQOaGlzdG9yeUFjdGlvbnMJAMwIAgkBDEludGVnZXJFbnRyeQIJARFrZXlWZXN0aW5nSGlzdG9yeQMCBnZlc3RlZAULdXNlckFkZHJlc3MJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAUNdmVzdGluZ0Ftb3VudAUDbmlsCQDOCAIJARRnZXROZXdWZXN0aW5nQWN0aW9ucwUFC3VzZXJBZGRyZXNzBQJpZAUNdmVzdGluZ0Ftb3VudAUKc3RhcnRCbG9jawUKbG9ja0xlbmd0aAUOaGlzdG9yeUFjdGlvbnMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEDYmFuAQt1c2VyQWRkcmVzcwQGY2hlY2tzCQDMCAIDAwkAAAIFCWFkbWluTGlzdAUDbmlsBgkBD2NvbnRhaW5zRWxlbWVudAIFCWFkbWluTGlzdAkApQgBCAUBaQZjYWxsZXIGCQEIdGhyb3dFcnIBAhF5b3UgbXVzdCBiZSBhZG1pbgkAzAgCAwkBASEBCQEPY29udGFpbnNFbGVtZW50AgUHYmFuTGlzdAULdXNlckFkZHJlc3MGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIbdXNlciBhbHJlYWR5IGluIGEgYmFuIGxpc3Q6CQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwCASAFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQLJHQwODc2Njg4NTQJASZnZXRNb3ZlQWxsVW5sb2NrZWRUb0FjY3VtdWxhdG9yQWN0aW9ucwEFC3VzZXJBZGRyZXNzBBhtb3ZlVG9BY2N1bXVsYXRlZEFjdGlvbnMIBQskdDA4NzY2ODg1NAJfMQQCX2EIBQskdDA4NzY2ODg1NAJfMgQTYWRkVG9CYW5MaXN0QWN0aW9ucwkAzAgCCQELU3RyaW5nRW50cnkCBQprZXlCYW5MaXN0CQC7CQIJAM0IAgUHYmFuTGlzdAULdXNlckFkZHJlc3MCAl9fBQNuaWwJAM4IAgUYbW92ZVRvQWNjdW11bGF0ZWRBY3Rpb25zBRNhZGRUb0Jhbkxpc3RBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBXVuYmFuAQt1c2VyQWRkcmVzcwQGY2hlY2tzCQDMCAIDAwkAAAIFCWFkbWluTGlzdAUDbmlsBgkBD2NvbnRhaW5zRWxlbWVudAIFCWFkbWluTGlzdAkApQgBCAUBaQZjYWxsZXIGCQEIdGhyb3dFcnIBAhF5b3UgbXVzdCBiZSBhZG1pbgkAzAgCAwkBD2NvbnRhaW5zRWxlbWVudAIFB2Jhbkxpc3QFC3VzZXJBZGRyZXNzBgkBCHRocm93RXJyAQkAuQkCCQDMCAICF3VzZXIgbm90IGluIGEgYmFuIGxpc3Q6CQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwCASAFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQKbmV3QmFuTGlzdAQHJG1hdGNoMAkAzwgCBQdiYW5MaXN0BQt1c2VyQWRkcmVzcwMJAAECBQckbWF0Y2gwAgNJbnQEA2luZAUHJG1hdGNoMAkA0QgCBQdiYW5MaXN0BQNpbmQJAQh0aHJvd0VycgECK3VzZXIgYWRkcmVzcyBpbmRleCBpbiBiYW4gbGlzdCBpcyBub3QgZm91bmQDCQAAAgUKbmV3QmFuTGlzdAUDbmlsCQDMCAIJAQtEZWxldGVFbnRyeQEFCmtleUJhbkxpc3QFA25pbAkAzAgCCQELU3RyaW5nRW50cnkCBQprZXlCYW5MaXN0CQC7CQIFCm5ld0Jhbkxpc3QCAl9fBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIY2xhaW1BbGwABAt1c2VyQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIECyR0MDk3MDQ5NzY5CQESZ2V0Q2xhaW1BbGxBY3Rpb25zAQULdXNlckFkZHJlc3MEDGNsYWltQWN0aW9ucwgFCyR0MDk3MDQ5NzY5Al8xBAt0b3RhbEFtb3VudAgFCyR0MDk3MDQ5NzY5Al8yBA5oaXN0b3J5QWN0aW9ucwkAzAgCCQEMSW50ZWdlckVudHJ5AgkBEWtleVZlc3RpbmdIaXN0b3J5AwIHY2xhaW1lZAULdXNlckFkZHJlc3MJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAULdG90YWxBbW91bnQFA25pbAMJAGYCBQt0b3RhbEFtb3VudAAACQDOCAIFDGNsYWltQWN0aW9ucwUOaGlzdG9yeUFjdGlvbnMJAQh0aHJvd0VycgECEG5vdGhpbmcgdG8gY2xhaW0BaQEQdXNlckluZm9SRUFET05MWQELdXNlckFkZHJlc3MEDSR0MDEwMDgwMTAxMzUJARJnZXRDbGFpbUFsbEFjdGlvbnMBBQt1c2VyQWRkcmVzcwQCX2EIBQ0kdDAxMDA4MDEwMTM1Al8xBAt0b3RhbEFtb3VudAgFDSR0MDEwMDgwMTAxMzUCXzIEEWFjY3VtdWxhdGVkQW1vdW50CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJARJrZXlVc2VyQWNjdW11bGF0ZWQBBQt1c2VyQWRkcmVzcwAACQCUCgIFA25pbAkAlQoDBQt0b3RhbEFtb3VudAURYWNjdW11bGF0ZWRBbW91bnQJARJnZXRWZXN0aW5nVXNlckluZm8BBQt1c2VyQWRkcmVzcwD8QOax", "height": 2924014, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 2vZvNzE12untPy6REKjUMyssnbkAC7xu6CQRfD5FJJYK Next: FBs4yRa3mNLd5GD5HS8DSssPwVTHcVbxYYV9BNmWmwYh Diff:
OldNewDifferences
390390
391391
392392 @Callable(i)
393-func claimAllREADONLY (userAddress) = {
393+func userInfoREADONLY (userAddress) = {
394394 let $t01008010135 = getClaimAllActions(userAddress)
395395 let _a = $t01008010135._1
396396 let totalAmount = $t01008010135._2
397- let accumulatedAmount = getInteger(this, keyUserAccumulated(userAddress))
397+ let accumulatedAmount = valueOrElse(getInteger(this, keyUserAccumulated(userAddress)), 0)
398398 $Tuple2(nil, $Tuple3(totalAmount, accumulatedAmount, getVestingUserInfo(userAddress)))
399399 }
400400
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let contractFile = "vesting_neo.ride"
55
66 let SEP = "__"
77
88 let IDS_LIST = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29]
99
1010 let MAX_VESTING_COUNT = size(IDS_LIST)
1111
1212 func throwErr (msg) = throw(((contractFile + ": ") + msg))
1313
1414
1515 let keyAssetId = makeString(["%s", "assetId"], SEP)
1616
1717 let assetIdString = valueOrElse(getString(this, keyAssetId), "WAVES")
1818
1919 let assetIdBytes = if ((assetIdString == "WAVES"))
2020 then unit
2121 else fromBase58String(assetIdString)
2222
2323 let keyAdminList = makeString(["%s", "adminList"], SEP)
2424
2525 let keyBanList = makeString(["%s", "banList"], SEP)
2626
2727 let adminList = match getString(this, keyAdminList) {
2828 case s: String =>
2929 split(s, SEP)
3030 case _ =>
3131 nil
3232 }
3333
3434 let banList = match getString(this, keyBanList) {
3535 case s: String =>
3636 if ((s == ""))
3737 then nil
3838 else split_51C(s, SEP)
3939 case _ =>
4040 nil
4141 }
4242
4343 func isValidAddressString (addressString) = match addressFromString(addressString) {
4444 case a: Address =>
4545 true
4646 case _ =>
4747 false
4848 }
4949
5050
5151 func keyUserVesting (userAddress,id) = {
5252 let checks = [if (isValidAddressString(userAddress))
5353 then true
5454 else throwErr(makeString(["address is not valid:", userAddress], " ")), if (if ((id >= 0))
5555 then (MAX_VESTING_COUNT > id)
5656 else false)
5757 then true
5858 else throwErr(makeString(["id should be less than", toString(MAX_VESTING_COUNT), "got:", toString(id)], " "))]
5959 if ((checks == checks))
6060 then makeString(["%s%s%d", "vesting", userAddress, toString(id)], SEP)
6161 else throw("Strict value is not equal to itself.")
6262 }
6363
6464
6565 func keyUserAccumulated (userAddress) = {
6666 let checks = [if (isValidAddressString(userAddress))
6767 then true
6868 else throwErr(makeString(["address is not valid:", userAddress], " "))]
6969 if ((checks == checks))
7070 then makeString(["%s%s", "accumulated", userAddress], SEP)
7171 else throw("Strict value is not equal to itself.")
7272 }
7373
7474
7575 func formatUserVesting (vestingAmount,startBlock,lockLength) = {
7676 let checks = [if ((vestingAmount >= 0))
7777 then true
7878 else throwErr("vesting amount cannot be negative"), if ((startBlock >= 0))
7979 then true
8080 else throwErr("start block cannot be negative"), if ((lockLength >= 0))
8181 then true
8282 else throwErr("lock length cannot be negative")]
8383 if ((checks == checks))
8484 then makeString(["%d%d%d", toString(vestingAmount), toString(startBlock), toString(lockLength)], SEP)
8585 else throw("Strict value is not equal to itself.")
8686 }
8787
8888
8989 func parseUserVesting (userAddress,id) = match getString(this, keyUserVesting(userAddress, id)) {
9090 case rawString: String =>
9191 let splitString = split(rawString, SEP)
9292 let vestingAmount = parseIntValue(splitString[1])
9393 let startBlock = parseIntValue(splitString[2])
9494 let lockLength = parseIntValue(splitString[3])
9595 $Tuple3(vestingAmount, startBlock, lockLength)
9696 case _ =>
9797 $Tuple3(0, 0, 0)
9898 }
9999
100100
101101 func keyVestingHistory (action,userAddress,txId) = makeString(["%s%s%s%s", "history", userAddress, action, txId], SEP)
102102
103103
104104 func calcUnlockedAmount (amount,startBlock,lockLength) = {
105105 let elapsedBlocks = (height - startBlock)
106106 let unlockedAmount = if (if ((lockLength != 0))
107107 then (elapsedBlocks > 0)
108108 else false)
109109 then min([fraction(amount, elapsedBlocks, lockLength), amount])
110110 else 0
111111 $Tuple2(unlockedAmount, (amount - unlockedAmount))
112112 }
113113
114114
115115 func getUserUnlockedAmount (userAddress,id) = {
116116 let $t032093288 = parseUserVesting(userAddress, id)
117117 let vestingAmount = $t032093288._1
118118 let startBlock = $t032093288._2
119119 let lockLength = $t032093288._3
120120 let $t032913388 = calcUnlockedAmount(vestingAmount, startBlock, lockLength)
121121 let unlockedAmount = $t032913388._1
122122 let remainingAmount = $t032913388._2
123123 $Tuple2(unlockedAmount, remainingAmount)
124124 }
125125
126126
127127 func getUpdateVestingActions (userAddress,id) = {
128128 let $t034953574 = parseUserVesting(userAddress, id)
129129 let vestingAmount = $t034953574._1
130130 let startBlock = $t034953574._2
131131 let lockLength = $t034953574._3
132132 let $t035773655 = getUserUnlockedAmount(userAddress, id)
133133 let unlockedAmount = $t035773655._1
134134 let remainingAmount = $t035773655._2
135135 let remainingBlocks = max([((startBlock + lockLength) - height), 0])
136136 let updateVestingActions = if ((unlockedAmount != 0))
137137 then if ((remainingBlocks != 0))
138138 then [StringEntry(keyUserVesting(userAddress, id), formatUserVesting(remainingAmount, height, remainingBlocks))]
139139 else [DeleteEntry(keyUserVesting(userAddress, id))]
140140 else nil
141141 $Tuple2(updateVestingActions, unlockedAmount)
142142 }
143143
144144
145145 func getUserClaimActions (userAddress,id) = {
146146 let $t041194204 = getUpdateVestingActions(userAddress, id)
147147 let updateVestingActions = $t041194204._1
148148 let unlockedAmount = $t041194204._2
149149 let transferActions = if ((unlockedAmount != 0))
150150 then [ScriptTransfer(addressFromStringValue(userAddress), unlockedAmount, assetIdBytes)]
151151 else nil
152152 $Tuple2((updateVestingActions ++ transferActions), unlockedAmount)
153153 }
154154
155155
156156 func getAllUserClaimActions (userAddress) = {
157157 func actionsHelper (acc,a) = {
158158 let $t045774617 = acc
159159 let allVestingsClaimActions = $t045774617._1
160160 let sum = $t045774617._2
161161 let $t046224698 = getUserClaimActions(userAddress, a)
162162 let vestingClaimActions = $t046224698._1
163163 let claimAmount = $t046224698._2
164164 $Tuple2((allVestingsClaimActions ++ vestingClaimActions), (sum + claimAmount))
165165 }
166166
167167 let $l = IDS_LIST
168168 let $s = size($l)
169169 let $acc0 = $Tuple2(nil, 0)
170170 func $f0_1 ($a,$i) = if (($i >= $s))
171171 then $a
172172 else actionsHelper($a, $l[$i])
173173
174174 func $f0_2 ($a,$i) = if (($i >= $s))
175175 then $a
176176 else throw("List size exceeds 30")
177177
178178 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($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), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30)
179179 }
180180
181181
182182 func getMoveAllUnlockedToAccumulatorActions (userAddress) = {
183183 func actionsHelper (acc,a) = {
184184 let $t049905031 = acc
185185 let updateAllVestingsActions = $t049905031._1
186186 let sum = $t049905031._2
187187 let $t050365120 = getUpdateVestingActions(userAddress, a)
188188 let updateVestingActions = $t050365120._1
189189 let unlockedAmount = $t050365120._2
190190 $Tuple2((updateAllVestingsActions ++ updateVestingActions), (sum + unlockedAmount))
191191 }
192192
193193 let $t052065294 = {
194194 let $l = IDS_LIST
195195 let $s = size($l)
196196 let $acc0 = $Tuple2(nil, 0)
197197 func $f0_1 ($a,$i) = if (($i >= $s))
198198 then $a
199199 else actionsHelper($a, $l[$i])
200200
201201 func $f0_2 ($a,$i) = if (($i >= $s))
202202 then $a
203203 else throw("List size exceeds 30")
204204
205205 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($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), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30)
206206 }
207207 let updateAllVestingsActions = $t052065294._1
208208 let unlockedSum = $t052065294._2
209209 let oldAccumulated = valueOrElse(getInteger(this, keyUserAccumulated(userAddress)), 0)
210210 let updateAccumulatedActions = if ((unlockedSum != 0))
211211 then [IntegerEntry(keyUserAccumulated(userAddress), (oldAccumulated + unlockedSum))]
212212 else nil
213213 $Tuple2((updateAllVestingsActions ++ updateAccumulatedActions), unlockedSum)
214214 }
215215
216216
217217 func getClaimAccumulatedActions (userAddress) = {
218218 let oldAccumulated = valueOrElse(getInteger(this, keyUserAccumulated(userAddress)), 0)
219219 if ((oldAccumulated != 0))
220220 then $Tuple2([ScriptTransfer(addressFromStringValue(userAddress), oldAccumulated, assetIdBytes), DeleteEntry(keyUserAccumulated(userAddress))], oldAccumulated)
221221 else $Tuple2(nil, 0)
222222 }
223223
224224
225225 func getClaimAllActions (userAddress) = {
226226 let $t060626195 = if (!(containsElement(banList, userAddress)))
227227 then getAllUserClaimActions(userAddress)
228228 else $Tuple2(nil, 0)
229229 let claimActions = $t060626195._1
230230 let unlockedAmount = $t060626195._2
231231 let $t061986288 = getClaimAccumulatedActions(userAddress)
232232 let claimAccumulatedActions = $t061986288._1
233233 let accumulatedAmount = $t061986288._2
234234 let totalAmount = (unlockedAmount + accumulatedAmount)
235235 $Tuple2((claimActions ++ claimAccumulatedActions), totalAmount)
236236 }
237237
238238
239239 func getVestingUserInfo (userAddress) = {
240240 func helper (acc,id) = {
241241 let $t065026581 = parseUserVesting(userAddress, id)
242242 let vestingAmount = $t065026581._1
243243 let startBlock = $t065026581._2
244244 let lockLength = $t065026581._3
245245 let $t065866664 = getUserUnlockedAmount(userAddress, id)
246246 let unlockedAmount = $t065866664._1
247247 let remainingAmount = $t065866664._2
248248 if (if ((vestingAmount == 0))
249249 then true
250250 else containsElement(banList, userAddress))
251251 then acc
252252 else (acc :+ [vestingAmount, (startBlock + lockLength), unlockedAmount, remainingAmount])
253253 }
254254
255255 let $l = IDS_LIST
256256 let $s = size($l)
257257 let $acc0 = nil
258258 func $f0_1 ($a,$i) = if (($i >= $s))
259259 then $a
260260 else helper($a, $l[$i])
261261
262262 func $f0_2 ($a,$i) = if (($i >= $s))
263263 then $a
264264 else throw("List size exceeds 30")
265265
266266 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($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), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30)
267267 }
268268
269269
270270 func getAvailableVestingId (userAddress) = {
271271 func helper (availableId,id) = {
272272 let $t069887067 = parseUserVesting(userAddress, id)
273273 let vestingAmount = $t069887067._1
274274 let startBlock = $t069887067._2
275275 let lockLength = $t069887067._3
276276 if ((vestingAmount > 0))
277277 then availableId
278278 else if ((availableId == -1))
279279 then id
280280 else min([availableId, id])
281281 }
282282
283283 let availableId = {
284284 let $l = IDS_LIST
285285 let $s = size($l)
286286 let $acc0 = -1
287287 func $f0_1 ($a,$i) = if (($i >= $s))
288288 then $a
289289 else helper($a, $l[$i])
290290
291291 func $f0_2 ($a,$i) = if (($i >= $s))
292292 then $a
293293 else throw("List size exceeds 30")
294294
295295 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($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), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30)
296296 }
297297 if ((availableId == -1))
298298 then throwErr(makeString(["user exceeded max active vesting count: ", userAddress], " "))
299299 else availableId
300300 }
301301
302302
303303 func getNewVestingActions (userAddress,id,vestingAmount,startBlock,lockLength) = [StringEntry(keyUserVesting(userAddress, id), formatUserVesting(vestingAmount, startBlock, lockLength))]
304304
305305
306306 @Callable(i)
307307 func vestingForUser (userAddress,vestingAmount,startBlock,lockLength) = {
308308 let check = [if ((size(i.payments) == 1))
309309 then true
310310 else throwErr("should be with exactly 1 payment"), if ((i.payments[0].assetId == assetIdBytes))
311311 then true
312312 else throwErr(makeString(["payment assetId should be: ", assetIdString], " ")), if ((i.payments[0].amount == vestingAmount))
313313 then true
314314 else throwErr("payment amount should be equal to vestingAmount"), if (if ((adminList == nil))
315315 then true
316316 else containsElement(adminList, toString(i.caller)))
317317 then true
318318 else throwErr("you must be admin")]
319319 if ((check == check))
320320 then {
321321 let id = getAvailableVestingId(userAddress)
322322 let historyActions = [IntegerEntry(keyVestingHistory("vested", userAddress, toBase58String(i.transactionId)), vestingAmount)]
323323 (getNewVestingActions(userAddress, id, vestingAmount, startBlock, lockLength) ++ historyActions)
324324 }
325325 else throw("Strict value is not equal to itself.")
326326 }
327327
328328
329329
330330 @Callable(i)
331331 func ban (userAddress) = {
332332 let checks = [if (if ((adminList == nil))
333333 then true
334334 else containsElement(adminList, toString(i.caller)))
335335 then true
336336 else throwErr("you must be admin"), if (!(containsElement(banList, userAddress)))
337337 then true
338338 else throwErr(makeString(["user already in a ban list:", userAddress], " "))]
339339 if ((checks == checks))
340340 then {
341341 let $t087668854 = getMoveAllUnlockedToAccumulatorActions(userAddress)
342342 let moveToAccumulatedActions = $t087668854._1
343343 let _a = $t087668854._2
344344 let addToBanListActions = [StringEntry(keyBanList, makeString_11C((banList :+ userAddress), "__"))]
345345 (moveToAccumulatedActions ++ addToBanListActions)
346346 }
347347 else throw("Strict value is not equal to itself.")
348348 }
349349
350350
351351
352352 @Callable(i)
353353 func unban (userAddress) = {
354354 let checks = [if (if ((adminList == nil))
355355 then true
356356 else containsElement(adminList, toString(i.caller)))
357357 then true
358358 else throwErr("you must be admin"), if (containsElement(banList, userAddress))
359359 then true
360360 else throwErr(makeString(["user not in a ban list:", userAddress], " "))]
361361 if ((checks == checks))
362362 then {
363363 let newBanList = match indexOf(banList, userAddress) {
364364 case ind: Int =>
365365 removeByIndex(banList, ind)
366366 case _ =>
367367 throwErr("user address index in ban list is not found")
368368 }
369369 if ((newBanList == nil))
370370 then [DeleteEntry(keyBanList)]
371371 else [StringEntry(keyBanList, makeString_11C(newBanList, "__"))]
372372 }
373373 else throw("Strict value is not equal to itself.")
374374 }
375375
376376
377377
378378 @Callable(i)
379379 func claimAll () = {
380380 let userAddress = toString(i.caller)
381381 let $t097049769 = getClaimAllActions(userAddress)
382382 let claimActions = $t097049769._1
383383 let totalAmount = $t097049769._2
384384 let historyActions = [IntegerEntry(keyVestingHistory("claimed", userAddress, toBase58String(i.transactionId)), totalAmount)]
385385 if ((totalAmount > 0))
386386 then (claimActions ++ historyActions)
387387 else throwErr("nothing to claim")
388388 }
389389
390390
391391
392392 @Callable(i)
393-func claimAllREADONLY (userAddress) = {
393+func userInfoREADONLY (userAddress) = {
394394 let $t01008010135 = getClaimAllActions(userAddress)
395395 let _a = $t01008010135._1
396396 let totalAmount = $t01008010135._2
397- let accumulatedAmount = getInteger(this, keyUserAccumulated(userAddress))
397+ let accumulatedAmount = valueOrElse(getInteger(this, keyUserAccumulated(userAddress)), 0)
398398 $Tuple2(nil, $Tuple3(totalAmount, accumulatedAmount, getVestingUserInfo(userAddress)))
399399 }
400400
401401

github/deemru/w8io/026f985 
47.12 ms