tx · ovpcsZnbKjoEq79eq2Ycohf1Zj8USiv3BW2zLRdw1PQ

3NCWFHDzdPHZC6636ZkMLNDup9mjpbTLs7h:  -0.01100000 Waves

2024.02.12 20:32 [2973341] smart account 3NCWFHDzdPHZC6636ZkMLNDup9mjpbTLs7h > SELF 0.00000000 Waves

{ "type": 13, "id": "ovpcsZnbKjoEq79eq2Ycohf1Zj8USiv3BW2zLRdw1PQ", "fee": 1100000, "feeAssetId": null, "timestamp": 1707759135464, "version": 2, "chainId": 84, "sender": "3NCWFHDzdPHZC6636ZkMLNDup9mjpbTLs7h", "senderPublicKey": "3z8Q6Zu3KppVmn6fJJvrLc1Wo3krVHSvfaNcerm82md2", "proofs": [ "2wb9qkSTgFrj7a8UMiJ7nJqHqMq4tkAgh5UCSEwk4t8RFQEmQxNNxzgBdCkvbz2jAyR4WJMVjYbDMLYqq9RnGRgh" ], "script": "base64:BgIvCAISAwoBARIDCgEIEgMKAQgSBAoCCAgSAwoBCBIECgIIARIECgIIARIDCgEBEgAgAAxjb250cmFjdEZpbGUCEWwybXBfbGVhc2luZy5yaWRlAANTRVACAl9fAQh0aHJvd0VycgEDbXNnCQACAQkArAICCQCsAgIFDGNvbnRyYWN0RmlsZQICOiAFA21zZwAKa2V5QXNzZXRJZAkAuQkCCQDMCAICAiVzCQDMCAICB2Fzc2V0SWQFA25pbAUDU0VQABFrZXlQZXJpb2RPZmZzZXRJZAkAuQkCCQDMCAICAiVzCQDMCAICCG9mZnNldElkBQNuaWwFA1NFUAAVa2V5UGVyaW9kT2Zmc2V0SGVpZ2h0CQC5CQIJAMwIAgICJXMJAMwIAgIMb2Zmc2V0SGVpZ2h0BQNuaWwFA1NFUAAPa2V5UGVyaW9kTGVuZ3RoCQC5CQIJAMwIAgICJXMJAMwIAgIMcGVyaW9kTGVuZ3RoBQNuaWwFA1NFUAAOcGVyaW9kT2Zmc2V0SWQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwURa2V5UGVyaW9kT2Zmc2V0SWQAAAAMcGVyaW9kTGVuZ3RoCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFD2tleVBlcmlvZExlbmd0aACQTgAScGVyaW9kT2Zmc2V0SGVpZ2h0CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFFWtleVBlcmlvZE9mZnNldEhlaWdodAD///////////8BAA9jdXJyZW50UGVyaW9kSWQDAwkAZgIFBmhlaWdodAUScGVyaW9kT2Zmc2V0SGVpZ2h0CQECIT0CBRJwZXJpb2RPZmZzZXRIZWlnaHQA////////////AQcJAGQCCQBpAgkAZQIFBmhlaWdodAUScGVyaW9kT2Zmc2V0SGVpZ2h0BQxwZXJpb2RMZW5ndGgFDnBlcmlvZE9mZnNldElkCQCWAwEJAMwIAgAACQDMCAIJAGUCBQ5wZXJpb2RPZmZzZXRJZAABBQNuaWwAE2N1cnJlbnRQZXJpb2RIZWlnaHQJAGQCBRJwZXJpb2RPZmZzZXRIZWlnaHQJAGgCCQBlAgUPY3VycmVudFBlcmlvZElkBQ5wZXJpb2RPZmZzZXRJZAUMcGVyaW9kTGVuZ3RoABBuZXh0UGVyaW9kSGVpZ2h0CQBkAgUTY3VycmVudFBlcmlvZEhlaWdodAUMcGVyaW9kTGVuZ3RoARJrZXlMZWFzaW5nTm9kZURhdGEBC25vZGVBZGRyZXNzCQC5CQIJAMwIAgICJXMJAMwIAgULbm9kZUFkZHJlc3MFA25pbAUDU0VQAQ5rZXlVc2VyVG9DbGFpbQELdXNlckFkZHJlc3MJALkJAgkAzAgCAgQlcyVzCQDMCAICB3RvQ2xhaW0JAMwIAgULdXNlckFkZHJlc3MFA25pbAUDU0VQARZrZXlVc2VyTGVhc2luZ05vZGVEYXRhAgt1c2VyQWRkcmVzcwtub2RlQWRkcmVzcwkAuQkCCQDMCAICBCVzJXMJAMwIAgULbm9kZUFkZHJlc3MJAMwIAgULdXNlckFkZHJlc3MFA25pbAUDU0VQARZrZXlOb2RlTGVhc2luZ0J5SGVpZ2h0AQtub2RlQWRkcmVzcwkAuQkCCQDMCAICBCVzJWQJAMwIAgULbm9kZUFkZHJlc3MJAMwIAgkApAMBBQZoZWlnaHQFA25pbAUDU0VQARZrZXlVc2VyTGVhc2luZ0J5SGVpZ2h0Agtub2RlQWRkcmVzcwt1c2VyQWRkcmVzcwkAuQkCCQDMCAICBiVzJXMlZAkAzAgCBQtub2RlQWRkcmVzcwkAzAgCBQt1c2VyQWRkcmVzcwkAzAgCCQCkAwEFBmhlaWdodAUDbmlsBQNTRVAADWFzc2V0SWRTdHJpbmcJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUKa2V5QXNzZXRJZAIFV0FWRVMADGFzc2V0SWRCeXRlcwMJAAACBQ1hc3NldElkU3RyaW5nAgVXQVZFUwUEdW5pdAkA2QQBBQ1hc3NldElkU3RyaW5nAQ5pc1ZhbGlkQWRkcmVzcwEHYWRkcmVzcwQHJG1hdGNoMAkApggBBQdhZGRyZXNzAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEAWEFByRtYXRjaDAGBwETZ2V0TGVhc2luZ05vZGVFbnRyeQMLbm9kZUFkZHJlc3MNY3VycmVudExlYXNlZApuZXh0TGVhc2VkBAt2YWx1ZVN0cmluZwkAuQkCCQDMCAICCCVkJWQlZCVkCQDMCAIJAKQDAQUTY3VycmVudFBlcmlvZEhlaWdodAkAzAgCCQCkAwEFDWN1cnJlbnRMZWFzZWQJAMwIAgkApAMBBRBuZXh0UGVyaW9kSGVpZ2h0CQDMCAIJAKQDAQUKbmV4dExlYXNlZAUDbmlsBQNTRVAJAQtTdHJpbmdFbnRyeQIJARJrZXlMZWFzaW5nTm9kZURhdGEBBQtub2RlQWRkcmVzcwULdmFsdWVTdHJpbmcBEmdldExlYXNpbmdOb2RlRGF0YQELbm9kZUFkZHJlc3MEGGxlYXNpbmdOb2RlRGF0YVN0cmluZ1JhdwkAnQgCBQR0aGlzCQESa2V5TGVhc2luZ05vZGVEYXRhAQULbm9kZUFkZHJlc3MEByRtYXRjaDAFGGxlYXNpbmdOb2RlRGF0YVN0cmluZ1JhdwMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAmRzBQckbWF0Y2gwBAhkYXRhTGlzdAkAtQkCBQJkcwUDU0VQBBFub2RlQ3VycmVudFBlcmlvZAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGRhdGFMaXN0AAEEEW5vZGVDdXJyZW50TGVhc2VkCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIZGF0YUxpc3QAAgQObm9kZU5leHRQZXJpb2QJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhkYXRhTGlzdAADBA5ub2RlTmV4dExlYXNlZAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGRhdGFMaXN0AAQDCQBmAgUObm9kZU5leHRQZXJpb2QFBmhlaWdodAkAlAoCBRFub2RlQ3VycmVudExlYXNlZAUObm9kZU5leHRMZWFzZWQJAJQKAgUObm9kZU5leHRMZWFzZWQFDm5vZGVOZXh0TGVhc2VkCQCUCgIAAAAAARNnZXRVc2VyTGVhc2luZ0VudHJ5BAtub2RlQWRkcmVzcwt1c2VyQWRkcmVzcxF1c2VyQ3VycmVudExlYXNlZA51c2VyTmV4dExlYXNlZAQLdmFsdWVTdHJpbmcJALkJAgkAzAgCAgglZCVkJWQlZAkAzAgCCQCkAwEFE2N1cnJlbnRQZXJpb2RIZWlnaHQJAMwIAgkApAMBBRF1c2VyQ3VycmVudExlYXNlZAkAzAgCCQCkAwEFEG5leHRQZXJpb2RIZWlnaHQJAMwIAgkApAMBBQ51c2VyTmV4dExlYXNlZAUDbmlsBQNTRVAJAQtTdHJpbmdFbnRyeQIJARZrZXlVc2VyTGVhc2luZ05vZGVEYXRhAgULdXNlckFkZHJlc3MFC25vZGVBZGRyZXNzBQt2YWx1ZVN0cmluZwESZ2V0VXNlckxlYXNpbmdEYXRhAgtub2RlQWRkcmVzcwt1c2VyQWRkcmVzcwQYbGVhc2luZ1VzZXJEYXRhU3RyaW5nUmF3CQCdCAIFBHRoaXMJARZrZXlVc2VyTGVhc2luZ05vZGVEYXRhAgULdXNlckFkZHJlc3MFC25vZGVBZGRyZXNzBAckbWF0Y2gwBRhsZWFzaW5nVXNlckRhdGFTdHJpbmdSYXcDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAJkcwUHJG1hdGNoMAQIZGF0YUxpc3QJALUJAgUCZHMFA1NFUAQRdXNlckN1cnJlbnRQZXJpb2QJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhkYXRhTGlzdAABBBF1c2VyQ3VycmVudExlYXNlZAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGRhdGFMaXN0AAIEDnVzZXJOZXh0UGVyaW9kCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIZGF0YUxpc3QAAwQOdXNlck5leHRMZWFzZWQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhkYXRhTGlzdAAEAwkAZgIFDnVzZXJOZXh0UGVyaW9kBQZoZWlnaHQJAJQKAgURdXNlckN1cnJlbnRMZWFzZWQFDnVzZXJOZXh0TGVhc2VkCQCUCgIFDnVzZXJOZXh0TGVhc2VkBQ51c2VyTmV4dExlYXNlZAkAlAoCAAAAAAETZ2V0VXNlclRvQ2xhaW1FbnRyeQMLdXNlckFkZHJlc3MHdG9DbGFpbQh0b1VubG9jawQLdmFsdWVTdHJpbmcJALkJAgkAzAgCAgglZCVkJWQlZAkAzAgCCQCkAwEFE2N1cnJlbnRQZXJpb2RIZWlnaHQJAMwIAgkApAMBBQd0b0NsYWltCQDMCAIJAKQDAQUQbmV4dFBlcmlvZEhlaWdodAkAzAgCCQCkAwEFCHRvVW5sb2NrBQNuaWwFA1NFUAkBC1N0cmluZ0VudHJ5AgkBDmtleVVzZXJUb0NsYWltAQULdXNlckFkZHJlc3MFC3ZhbHVlU3RyaW5nARVnZXRVc2VyVG9DbGFpbUJhbGFuY2UBC3VzZXJBZGRyZXNzBBh1c2VyVG9DbGFpbURhdGFTdHJpbmdSYXcJAJ0IAgUEdGhpcwkBDmtleVVzZXJUb0NsYWltAQULdXNlckFkZHJlc3MEByRtYXRjaDAFGHVzZXJUb0NsYWltRGF0YVN0cmluZ1JhdwMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAmRzBQckbWF0Y2gwBAhkYXRhTGlzdAkAtQkCBQJkcwUDU0VQBA1jdXJyZW50UGVyaW9kCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIZGF0YUxpc3QAAQQHdG9DbGFpbQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGRhdGFMaXN0AAIECm5leHRQZXJpb2QJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhkYXRhTGlzdAADBAh0b1VubG9jawkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGRhdGFMaXN0AAQDCQBmAgUKbmV4dFBlcmlvZAUGaGVpZ2h0CQCUCgIFB3RvQ2xhaW0FCHRvVW5sb2NrCQCUCgIJAGQCBQd0b0NsYWltBQh0b1VubG9jawAACQCUCgIAAAAAAQ9nZXRTdGFrZUFjdGlvbnMDC25vZGVBZGRyZXNzC3VzZXJBZGRyZXNzAWkEBmNoZWNrcwkAzAgCAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQYJAQh0aHJvd0VycgECIHBheW1lbnQgc2l6ZSBzaG91bGQgYmUgZXhhY3RseSAxCQDMCAIDCQAAAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQxhc3NldElkQnl0ZXMGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIacGF5bWVudCBhc3NldElkIHNob3VsZCBiZToJAMwIAgUNYXNzZXRJZFN0cmluZwUDbmlsAgEgCQDMCAIDCQEOaXNWYWxpZEFkZHJlc3MBBQtub2RlQWRkcmVzcwYJAQh0aHJvd0VycgEJALkJAgkAzAgCAhpub2RlIGFkZHJlc3MgaXMgbm90IHZhbGlkOgkAzAgCBQtub2RlQWRkcmVzcwUDbmlsAgEgCQDMCAIDCQEOaXNWYWxpZEFkZHJlc3MBBQt1c2VyQWRkcmVzcwYJAQh0aHJvd0VycgEJALkJAgkAzAgCAhp1c2VyIGFkZHJlc3MgaXMgbm90IHZhbGlkOgkAzAgCBQt1c2VyQWRkcmVzcwUDbmlsAgEgBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MEEXVzZXJMZWFzaW5nQW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQLJHQwNTc3NzU4NTAJARJnZXRMZWFzaW5nTm9kZURhdGEBBQtub2RlQWRkcmVzcwQRbm9kZUN1cnJlbnRMZWFzZWQIBQskdDA1Nzc3NTg1MAJfMQQObm9kZU5leHRMZWFzZWQIBQskdDA1Nzc3NTg1MAJfMgQQbmV3Tm9kZU5leHRMZWFzZQkAZAIFDm5vZGVOZXh0TGVhc2VkBRF1c2VyTGVhc2luZ0Ftb3VudAQLJHQwNTkxODYwMDQJARJnZXRVc2VyTGVhc2luZ0RhdGECBQtub2RlQWRkcmVzcwULdXNlckFkZHJlc3MEEXVzZXJDdXJyZW50TGVhc2VkCAULJHQwNTkxODYwMDQCXzEEDnVzZXJOZXh0TGVhc2VkCAULJHQwNTkxODYwMDQCXzIEEW5ld1VzZXJOZXh0TGVhc2VkCQBkAgUOdXNlck5leHRMZWFzZWQFEXVzZXJMZWFzaW5nQW1vdW50CQDMCAIJARNnZXRMZWFzaW5nTm9kZUVudHJ5AwULbm9kZUFkZHJlc3MFEW5vZGVDdXJyZW50TGVhc2VkBRBuZXdOb2RlTmV4dExlYXNlCQDMCAIJARNnZXRVc2VyTGVhc2luZ0VudHJ5BAULbm9kZUFkZHJlc3MFC3VzZXJBZGRyZXNzBRF1c2VyQ3VycmVudExlYXNlZAURbmV3VXNlck5leHRMZWFzZWQJAMwIAgkBDEludGVnZXJFbnRyeQIJARZrZXlOb2RlTGVhc2luZ0J5SGVpZ2h0AQULbm9kZUFkZHJlc3MFEG5ld05vZGVOZXh0TGVhc2UJAMwIAgkBDEludGVnZXJFbnRyeQIJARZrZXlVc2VyTGVhc2luZ0J5SGVpZ2h0AgULbm9kZUFkZHJlc3MFC3VzZXJBZGRyZXNzBRFuZXdVc2VyTmV4dExlYXNlZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARFnZXRVbnN0YWtlQWN0aW9ucwMLbm9kZUFkZHJlc3MLdXNlckFkZHJlc3MNdW5zdGFrZUFtb3VudAQLJHQwNjUxNjY1ODkJARJnZXRMZWFzaW5nTm9kZURhdGEBBQtub2RlQWRkcmVzcwQRbm9kZUN1cnJlbnRMZWFzZWQIBQskdDA2NTE2NjU4OQJfMQQObm9kZU5leHRMZWFzZWQIBQskdDA2NTE2NjU4OQJfMgQLJHQwNjU5NDY2ODAJARJnZXRVc2VyTGVhc2luZ0RhdGECBQtub2RlQWRkcmVzcwULdXNlckFkZHJlc3MEEXVzZXJDdXJyZW50TGVhc2VkCAULJHQwNjU5NDY2ODACXzEEDnVzZXJOZXh0TGVhc2VkCAULJHQwNjU5NDY2ODACXzIEBmNoZWNrcwkAzAgCAwkAZgIFDXVuc3Rha2VBbW91bnQAAAYJAQh0aHJvd0VycgECJ3Vuc3Rha2UgYW1vdW50IHNob3VsZCBiZSBncmVhdGVyIHRoYW4gMAkAzAgCAwkAZwIFDnVzZXJOZXh0TGVhc2VkBQ11bnN0YWtlQW1vdW50BgkBCHRocm93RXJyAQI5dW5zdGFrZSBhbW91bnQgc2hvdWxkIGJlIGxlc3Mgb3IgZXF1YWwgdXNlciBzdGFrZWQgYW1vdW50CQDMCAIDCQBnAgUObm9kZU5leHRMZWFzZWQFDXVuc3Rha2VBbW91bnQGCQEIdGhyb3dFcnIBAjl1bnN0YWtlIGFtb3VudCBzaG91bGQgYmUgbGVzcyBvciBlcXVhbCBub2RlIHN0YWtlZCBhbW91bnQJAMwIAgMJAQ5pc1ZhbGlkQWRkcmVzcwEFC25vZGVBZGRyZXNzBgkBCHRocm93RXJyAQkAuQkCCQDMCAICGm5vZGUgYWRkcmVzcyBpcyBub3QgdmFsaWQ6CQDMCAIFC25vZGVBZGRyZXNzBQNuaWwCASAJAMwIAgMJAQ5pc1ZhbGlkQWRkcmVzcwEFC3VzZXJBZGRyZXNzBgkBCHRocm93RXJyAQkAuQkCCQDMCAICGnVzZXIgYWRkcmVzcyBpcyBub3QgdmFsaWQ6CQDMCAIFC3VzZXJBZGRyZXNzBQNuaWwCASAFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQQbmV3Tm9kZU5leHRMZWFzZQkAZQIFDm5vZGVOZXh0TGVhc2VkBQ11bnN0YWtlQW1vdW50BBFuZXdVc2VyTmV4dExlYXNlZAkAZQIFDnVzZXJOZXh0TGVhc2VkBQ11bnN0YWtlQW1vdW50BAskdDA3MzczNzQ3OAkBFWdldFVzZXJUb0NsYWltQmFsYW5jZQEFC3VzZXJBZGRyZXNzBAd0b0NsYWltCAULJHQwNzM3Mzc0NzgCXzEECHRvVW5sb2NrCAULJHQwNzM3Mzc0NzgCXzIEC25ld1RvVW5sb2NrCQBkAgUIdG9VbmxvY2sFDXVuc3Rha2VBbW91bnQJAMwIAgkBE2dldExlYXNpbmdOb2RlRW50cnkDBQtub2RlQWRkcmVzcwURbm9kZUN1cnJlbnRMZWFzZWQFEG5ld05vZGVOZXh0TGVhc2UJAMwIAgkBE2dldFVzZXJMZWFzaW5nRW50cnkEBQtub2RlQWRkcmVzcwULdXNlckFkZHJlc3MFEXVzZXJDdXJyZW50TGVhc2VkBRFuZXdVc2VyTmV4dExlYXNlZAkAzAgCCQETZ2V0VXNlclRvQ2xhaW1FbnRyeQMFC3VzZXJBZGRyZXNzBQd0b0NsYWltBQtuZXdUb1VubG9jawkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFmtleU5vZGVMZWFzaW5nQnlIZWlnaHQBBQtub2RlQWRkcmVzcwUQbmV3Tm9kZU5leHRMZWFzZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFmtleVVzZXJMZWFzaW5nQnlIZWlnaHQCBQtub2RlQWRkcmVzcwULdXNlckFkZHJlc3MFEW5ld1VzZXJOZXh0TGVhc2VkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BF2dldENsYWltVW5sb2NrZWRBY3Rpb25zAgt1c2VyQWRkcmVzcwtjbGFpbUFtb3VudAQLJHQwODAyMTgwODEJARVnZXRVc2VyVG9DbGFpbUJhbGFuY2UBBQt1c2VyQWRkcmVzcwQHdG9DbGFpbQgFCyR0MDgwMjE4MDgxAl8xBAh0b1VubG9jawgFCyR0MDgwMjE4MDgxAl8yBAZjaGVja3MJAMwIAgMJAGYCBQtjbGFpbUFtb3VudAAABgkBCHRocm93RXJyAQIlY2xhaW0gYW1vdW50IHNob3VsZCBiZSBncmVhdGVyIHRoYW4gMAkAzAgCAwkAZwIFB3RvQ2xhaW0FC2NsYWltQW1vdW50BgkBCHRocm93RXJyAQI0Y2xhaW0gYW1vdW50IHNob3VsZCBiZSBsZXNzIG9yIGVxdWFsIHVubG9ja2VkIGFtb3VudAkAzAgCAwkBDmlzVmFsaWRBZGRyZXNzAQULdXNlckFkZHJlc3MGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIadXNlciBhZGRyZXNzIGlzIG5vdCB2YWxpZDoJAMwIAgULdXNlckFkZHJlc3MFA25pbAIBIAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBApuZXdUb0NsYWltCQBlAgUHdG9DbGFpbQULY2xhaW1BbW91bnQJAMwIAgkBE2dldFVzZXJUb0NsYWltRW50cnkDBQt1c2VyQWRkcmVzcwUKbmV3VG9DbGFpbQUIdG9VbmxvY2sJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQULdXNlckFkZHJlc3MFC2NsYWltQW1vdW50BQxhc3NldElkQnl0ZXMFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEbZ2V0U3Rha2VGcm9tVW5sb2NrZWRBY3Rpb25zAwtub2RlQWRkcmVzcwt1c2VyQWRkcmVzcxF1c2VyTGVhc2luZ0Ftb3VudAQLJHQwODcyMTg3ODEJARVnZXRVc2VyVG9DbGFpbUJhbGFuY2UBBQt1c2VyQWRkcmVzcwQHdG9DbGFpbQgFCyR0MDg3MjE4NzgxAl8xBAh0b1VubG9jawgFCyR0MDg3MjE4NzgxAl8yBAlhdmFpbGFibGUJAGQCBQh0b1VubG9jawUHdG9DbGFpbQQGY2hlY2tzCQDMCAIDCQBmAgURdXNlckxlYXNpbmdBbW91bnQAAAYJAQh0aHJvd0VycgECH2Ftb3VudCBzaG91bGQgYmUgZ3JlYXRlciB0aGFuIDAJAMwIAgMJAGcCBQlhdmFpbGFibGUFEXVzZXJMZWFzaW5nQW1vdW50BgkBCHRocm93RXJyAQIrYW1vdW50IHNob3VsZCBiZSBsZXNzIG9yIGVxdWFsIHRvIGF2YWlsYWJsZQkAzAgCAwkBDmlzVmFsaWRBZGRyZXNzAQULbm9kZUFkZHJlc3MGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIabm9kZSBhZGRyZXNzIGlzIG5vdCB2YWxpZDoJAMwIAgULbm9kZUFkZHJlc3MFA25pbAIBIAkAzAgCAwkBDmlzVmFsaWRBZGRyZXNzAQULdXNlckFkZHJlc3MGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIadXNlciBhZGRyZXNzIGlzIG5vdCB2YWxpZDoJAMwIAgULdXNlckFkZHJlc3MFA25pbAIBIAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBAskdDA5MjU4OTMzMQkBEmdldExlYXNpbmdOb2RlRGF0YQEFC25vZGVBZGRyZXNzBBFub2RlQ3VycmVudExlYXNlZAgFCyR0MDkyNTg5MzMxAl8xBA5ub2RlTmV4dExlYXNlZAgFCyR0MDkyNTg5MzMxAl8yBBBuZXdOb2RlTmV4dExlYXNlCQBkAgUObm9kZU5leHRMZWFzZWQFEXVzZXJMZWFzaW5nQW1vdW50BAskdDA5Mzk5OTQ4NQkBEmdldFVzZXJMZWFzaW5nRGF0YQIFC25vZGVBZGRyZXNzBQt1c2VyQWRkcmVzcwQRdXNlckN1cnJlbnRMZWFzZWQIBQskdDA5Mzk5OTQ4NQJfMQQOdXNlck5leHRMZWFzZWQIBQskdDA5Mzk5OTQ4NQJfMgQRbmV3VXNlck5leHRMZWFzZWQJAGQCBQ51c2VyTmV4dExlYXNlZAURdXNlckxlYXNpbmdBbW91bnQEC25ld1RvVW5sb2NrCQCWAwEJAMwIAgAACQDMCAIJAGUCBQh0b1VubG9jawURdXNlckxlYXNpbmdBbW91bnQFA25pbAQKbmV3VG9DbGFpbQkAlwMBCQDMCAIFB3RvQ2xhaW0JAMwIAgkAZAIFB3RvQ2xhaW0JAGUCBQh0b1VubG9jawURdXNlckxlYXNpbmdBbW91bnQFA25pbAkAzAgCCQETZ2V0TGVhc2luZ05vZGVFbnRyeQMFC25vZGVBZGRyZXNzBRFub2RlQ3VycmVudExlYXNlZAUQbmV3Tm9kZU5leHRMZWFzZQkAzAgCCQETZ2V0VXNlckxlYXNpbmdFbnRyeQQFC25vZGVBZGRyZXNzBQt1c2VyQWRkcmVzcwURdXNlckN1cnJlbnRMZWFzZWQFEW5ld1VzZXJOZXh0TGVhc2VkCQDMCAIJARNnZXRVc2VyVG9DbGFpbUVudHJ5AwULdXNlckFkZHJlc3MFCm5ld1RvQ2xhaW0FC25ld1RvVW5sb2NrCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEWa2V5Tm9kZUxlYXNpbmdCeUhlaWdodAEFC25vZGVBZGRyZXNzBRBuZXdOb2RlTmV4dExlYXNlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEWa2V5VXNlckxlYXNpbmdCeUhlaWdodAIFC25vZGVBZGRyZXNzBQt1c2VyQWRkcmVzcwURbmV3VXNlck5leHRMZWFzZWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEcZ2V0U2V0TmV3UGVyaW9kTGVuZ3RoQWN0aW9ucwEPbmV3UGVyaW9kTGVuZ3RoBAVjaGVjawkAzAgCAwkAZgIFD25ld1BlcmlvZExlbmd0aAAABgkBCHRocm93RXJyAQImcGVyaW9kIGxlbmd0aCBzaG91bGQgYmUgZ3JlYXRlciB0aGFuIDAFA25pbAMJAAACBQVjaGVjawUFY2hlY2sDCQAAAgUScGVyaW9kT2Zmc2V0SGVpZ2h0AP///////////wEJAMwIAgkBDEludGVnZXJFbnRyeQIFD2tleVBlcmlvZExlbmd0aAUPbmV3UGVyaW9kTGVuZ3RoCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRVrZXlQZXJpb2RPZmZzZXRIZWlnaHQFBmhlaWdodAUDbmlsCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRFrZXlQZXJpb2RPZmZzZXRJZAkAZAIFD2N1cnJlbnRQZXJpb2RJZAABCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRVrZXlQZXJpb2RPZmZzZXRIZWlnaHQFEG5leHRQZXJpb2RIZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFD2tleVBlcmlvZExlbmd0aAUPbmV3UGVyaW9kTGVuZ3RoBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAWkBEnNldE5ld1BlcmlvZExlbmd0aAEPbmV3UGVyaW9kTGVuZ3RoCQEcZ2V0U2V0TmV3UGVyaW9kTGVuZ3RoQWN0aW9ucwEFD25ld1BlcmlvZExlbmd0aAFpARNnZXROb2RlRGF0YVJFQURPTkxZAQtub2RlQWRkcmVzcwQNJHQwMTA4ODAxMDk0NAkBEmdldExlYXNpbmdOb2RlRGF0YQEFC25vZGVBZGRyZXNzBAxjdXJyZW50TGVhc2UIBQ0kdDAxMDg4MDEwOTQ0Al8xBApuZXh0TGVhc2VkCAUNJHQwMTA4ODAxMDk0NAJfMgkAlAoCBQNuaWwJAJcKBQUTY3VycmVudFBlcmlvZEhlaWdodAUMY3VycmVudExlYXNlBRBuZXh0UGVyaW9kSGVpZ2h0BQpuZXh0TGVhc2VkBQZoZWlnaHQBaQETZ2V0VXNlckRhdGFSRUFET05MWQELdXNlckFkZHJlc3MEDSR0MDExMTAwMTExNjAJARVnZXRVc2VyVG9DbGFpbUJhbGFuY2UBBQt1c2VyQWRkcmVzcwQHdG9DbGFpbQgFDSR0MDExMTAwMTExNjACXzEECHRvVW5sb2NrCAUNJHQwMTExMDAxMTE2MAJfMgkAlAoCBQNuaWwJAJcKBQUTY3VycmVudFBlcmlvZEhlaWdodAUHdG9DbGFpbQUQbmV4dFBlcmlvZEhlaWdodAUIdG9VbmxvY2sFBmhlaWdodAFpAQhzdGFrZUZvcgILbm9kZUFkZHJlc3MLdXNlckFkZHJlc3MJAQ9nZXRTdGFrZUFjdGlvbnMDBQtub2RlQWRkcmVzcwULdXNlckFkZHJlc3MFAWkBaQEFc3Rha2UBC25vZGVBZGRyZXNzBAt1c2VyQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIJAQ9nZXRTdGFrZUFjdGlvbnMDBQtub2RlQWRkcmVzcwULdXNlckFkZHJlc3MFAWkBaQERc3Rha2VGcm9tVW5sb2NrZWQCC25vZGVBZGRyZXNzBmFtb3VudAQLdXNlckFkZHJlc3MJAKUIAQgFAWkGY2FsbGVyCQEbZ2V0U3Rha2VGcm9tVW5sb2NrZWRBY3Rpb25zAwULbm9kZUFkZHJlc3MFC3VzZXJBZGRyZXNzBQZhbW91bnQBaQEHdW5zdGFrZQILbm9kZUFkZHJlc3MGYW1vdW50BAt1c2VyQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIJARFnZXRVbnN0YWtlQWN0aW9ucwMFC25vZGVBZGRyZXNzBQt1c2VyQWRkcmVzcwUGYW1vdW50AWkBBWNsYWltAQZhbW91bnQEC3VzZXJBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgkBF2dldENsYWltVW5sb2NrZWRBY3Rpb25zAgULdXNlckFkZHJlc3MFBmFtb3VudAFpAQhjbGFpbUFsbAAEC3VzZXJBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgQNJHQwMTIwNzgxMjEzOAkBFWdldFVzZXJUb0NsYWltQmFsYW5jZQEFC3VzZXJBZGRyZXNzBAd0b0NsYWltCAUNJHQwMTIwNzgxMjEzOAJfMQQIdG9VbmxvY2sIBQ0kdDAxMjA3ODEyMTM4Al8yBAZjaGVja3MJAMwIAgMJAGYCBQd0b0NsYWltAAAGCQEIdGhyb3dFcnIBAhBub3RoaW5nIHRvIGNsYWltBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MJARdnZXRDbGFpbVVubG9ja2VkQWN0aW9ucwIFC3VzZXJBZGRyZXNzBQd0b0NsYWltCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAGDhSn0=", "height": 2973341, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: BnxhjRvsFxx5GWYAGufgqtCv1BbJxM2tH3hs67eYkZd7 Next: 4FG8tqN6QasBdHEH4Fac2CZDVHPaPL6rL9UUAPGMJCCK Diff:
OldNewDifferences
3939
4040
4141 func keyUserLeasingNodeData (userAddress,nodeAddress) = makeString(["%s%s", nodeAddress, userAddress], SEP)
42+
43+
44+func keyNodeLeasingByHeight (nodeAddress) = makeString(["%s%d", nodeAddress, toString(height)], SEP)
45+
46+
47+func keyUserLeasingByHeight (nodeAddress,userAddress) = makeString(["%s%s%d", nodeAddress, userAddress, toString(height)], SEP)
4248
4349
4450 let assetIdString = valueOrElse(getString(this, keyAssetId), "WAVES")
140146 if ((checks == checks))
141147 then {
142148 let userLeasingAmount = i.payments[0].amount
143- let $t055095582 = getLeasingNodeData(nodeAddress)
144- let nodeCurrentLeased = $t055095582._1
145- let nodeNextLeased = $t055095582._2
149+ let $t057775850 = getLeasingNodeData(nodeAddress)
150+ let nodeCurrentLeased = $t057775850._1
151+ let nodeNextLeased = $t057775850._2
146152 let newNodeNextLease = (nodeNextLeased + userLeasingAmount)
147- let $t056505736 = getUserLeasingData(nodeAddress, userAddress)
148- let userCurrentLeased = $t056505736._1
149- let userNextLeased = $t056505736._2
153+ let $t059186004 = getUserLeasingData(nodeAddress, userAddress)
154+ let userCurrentLeased = $t059186004._1
155+ let userNextLeased = $t059186004._2
150156 let newUserNextLeased = (userNextLeased + userLeasingAmount)
151-[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased)]
157+[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), IntegerEntry(keyNodeLeasingByHeight(nodeAddress), newNodeNextLease), IntegerEntry(keyUserLeasingByHeight(nodeAddress, userAddress), newUserNextLeased)]
152158 }
153159 else throw("Strict value is not equal to itself.")
154160 }
155161
156162
157163 func getUnstakeActions (nodeAddress,userAddress,unstakeAmount) = {
158- let $t060806153 = getLeasingNodeData(nodeAddress)
159- let nodeCurrentLeased = $t060806153._1
160- let nodeNextLeased = $t060806153._2
161- let $t061586244 = getUserLeasingData(nodeAddress, userAddress)
162- let userCurrentLeased = $t061586244._1
163- let userNextLeased = $t061586244._2
164+ let $t065166589 = getLeasingNodeData(nodeAddress)
165+ let nodeCurrentLeased = $t065166589._1
166+ let nodeNextLeased = $t065166589._2
167+ let $t065946680 = getUserLeasingData(nodeAddress, userAddress)
168+ let userCurrentLeased = $t065946680._1
169+ let userNextLeased = $t065946680._2
164170 let checks = [if ((unstakeAmount > 0))
165171 then true
166172 else throwErr("unstake amount should be greater than 0"), if ((userNextLeased >= unstakeAmount))
176182 then {
177183 let newNodeNextLease = (nodeNextLeased - unstakeAmount)
178184 let newUserNextLeased = (userNextLeased - unstakeAmount)
179- let $t069377042 = getUserToClaimBalance(userAddress)
180- let toClaim = $t069377042._1
181- let toUnlock = $t069377042._2
185+ let $t073737478 = getUserToClaimBalance(userAddress)
186+ let toClaim = $t073737478._1
187+ let toUnlock = $t073737478._2
182188 let newToUnlock = (toUnlock + unstakeAmount)
183-[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, toClaim, newToUnlock)]
189+[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, toClaim, newToUnlock), IntegerEntry(keyNodeLeasingByHeight(nodeAddress), newNodeNextLease), IntegerEntry(keyUserLeasingByHeight(nodeAddress, userAddress), newUserNextLeased)]
184190 }
185191 else throw("Strict value is not equal to itself.")
186192 }
187193
188194
189195 func getClaimUnlockedActions (userAddress,claimAmount) = {
190- let $t074177477 = getUserToClaimBalance(userAddress)
191- let toClaim = $t074177477._1
192- let toUnlock = $t074177477._2
196+ let $t080218081 = getUserToClaimBalance(userAddress)
197+ let toClaim = $t080218081._1
198+ let toUnlock = $t080218081._2
193199 let checks = [if ((claimAmount > 0))
194200 then true
195201 else throwErr("claim amount should be greater than 0"), if ((toClaim >= claimAmount))
207213
208214
209215 func getStakeFromUnlockedActions (nodeAddress,userAddress,userLeasingAmount) = {
210- let $t081178177 = getUserToClaimBalance(userAddress)
211- let toClaim = $t081178177._1
212- let toUnlock = $t081178177._2
216+ let $t087218781 = getUserToClaimBalance(userAddress)
217+ let toClaim = $t087218781._1
218+ let toUnlock = $t087218781._2
213219 let available = (toUnlock + toClaim)
214220 let checks = [if ((userLeasingAmount > 0))
215221 then true
222228 else throwErr(makeString(["user address is not valid:", userAddress], " "))]
223229 if ((checks == checks))
224230 then {
225- let $t086548727 = getLeasingNodeData(nodeAddress)
226- let nodeCurrentLeased = $t086548727._1
227- let nodeNextLeased = $t086548727._2
231+ let $t092589331 = getLeasingNodeData(nodeAddress)
232+ let nodeCurrentLeased = $t092589331._1
233+ let nodeNextLeased = $t092589331._2
228234 let newNodeNextLease = (nodeNextLeased + userLeasingAmount)
229- let $t087958881 = getUserLeasingData(nodeAddress, userAddress)
230- let userCurrentLeased = $t087958881._1
231- let userNextLeased = $t087958881._2
235+ let $t093999485 = getUserLeasingData(nodeAddress, userAddress)
236+ let userCurrentLeased = $t093999485._1
237+ let userNextLeased = $t093999485._2
232238 let newUserNextLeased = (userNextLeased + userLeasingAmount)
233239 let newToUnlock = max([0, (toUnlock - userLeasingAmount)])
234240 let newToClaim = min([toClaim, (toClaim + (toUnlock - userLeasingAmount))])
235-[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, newToClaim, newToUnlock)]
241+[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, newToClaim, newToUnlock), IntegerEntry(keyNodeLeasingByHeight(nodeAddress), newNodeNextLease), IntegerEntry(keyUserLeasingByHeight(nodeAddress, userAddress), newUserNextLeased)]
236242 }
237243 else throw("Strict value is not equal to itself.")
238244 }
257263
258264 @Callable(i)
259265 func getNodeDataREADONLY (nodeAddress) = {
260- let $t01010810172 = getLeasingNodeData(nodeAddress)
261- let currentLease = $t01010810172._1
262- let nextLeased = $t01010810172._2
266+ let $t01088010944 = getLeasingNodeData(nodeAddress)
267+ let currentLease = $t01088010944._1
268+ let nextLeased = $t01088010944._2
263269 $Tuple2(nil, $Tuple5(currentPeriodHeight, currentLease, nextPeriodHeight, nextLeased, height))
264270 }
265271
267273
268274 @Callable(i)
269275 func getUserDataREADONLY (userAddress) = {
270- let $t01032810388 = getUserToClaimBalance(userAddress)
271- let toClaim = $t01032810388._1
272- let toUnlock = $t01032810388._2
276+ let $t01110011160 = getUserToClaimBalance(userAddress)
277+ let toClaim = $t01110011160._1
278+ let toUnlock = $t01110011160._2
273279 $Tuple2(nil, $Tuple5(currentPeriodHeight, toClaim, nextPeriodHeight, toUnlock, height))
274280 }
275281
315321 @Callable(i)
316322 func claimAll () = {
317323 let userAddress = toString(i.caller)
318- let $t01130611366 = getUserToClaimBalance(userAddress)
319- let toClaim = $t01130611366._1
320- let toUnlock = $t01130611366._2
324+ let $t01207812138 = getUserToClaimBalance(userAddress)
325+ let toClaim = $t01207812138._1
326+ let toUnlock = $t01207812138._2
321327 let checks = [if ((toClaim > 0))
322328 then true
323329 else throwErr("nothing to claim")]
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let contractFile = "l2mp_leasing.ride"
55
66 let SEP = "__"
77
88 func throwErr (msg) = throw(((contractFile + ": ") + msg))
99
1010
1111 let keyAssetId = makeString(["%s", "assetId"], SEP)
1212
1313 let keyPeriodOffsetId = makeString(["%s", "offsetId"], SEP)
1414
1515 let keyPeriodOffsetHeight = makeString(["%s", "offsetHeight"], SEP)
1616
1717 let keyPeriodLength = makeString(["%s", "periodLength"], SEP)
1818
1919 let periodOffsetId = valueOrElse(getInteger(this, keyPeriodOffsetId), 0)
2020
2121 let periodLength = valueOrElse(getInteger(this, keyPeriodLength), 10000)
2222
2323 let periodOffsetHeight = valueOrElse(getInteger(this, keyPeriodOffsetHeight), -1)
2424
2525 let currentPeriodId = if (if ((height > periodOffsetHeight))
2626 then (periodOffsetHeight != -1)
2727 else false)
2828 then (((height - periodOffsetHeight) / periodLength) + periodOffsetId)
2929 else max([0, (periodOffsetId - 1)])
3030
3131 let currentPeriodHeight = (periodOffsetHeight + ((currentPeriodId - periodOffsetId) * periodLength))
3232
3333 let nextPeriodHeight = (currentPeriodHeight + periodLength)
3434
3535 func keyLeasingNodeData (nodeAddress) = makeString(["%s", nodeAddress], SEP)
3636
3737
3838 func keyUserToClaim (userAddress) = makeString(["%s%s", "toClaim", userAddress], SEP)
3939
4040
4141 func keyUserLeasingNodeData (userAddress,nodeAddress) = makeString(["%s%s", nodeAddress, userAddress], SEP)
42+
43+
44+func keyNodeLeasingByHeight (nodeAddress) = makeString(["%s%d", nodeAddress, toString(height)], SEP)
45+
46+
47+func keyUserLeasingByHeight (nodeAddress,userAddress) = makeString(["%s%s%d", nodeAddress, userAddress, toString(height)], SEP)
4248
4349
4450 let assetIdString = valueOrElse(getString(this, keyAssetId), "WAVES")
4551
4652 let assetIdBytes = if ((assetIdString == "WAVES"))
4753 then unit
4854 else fromBase58String(assetIdString)
4955
5056 func isValidAddress (address) = match addressFromString(address) {
5157 case a: Address =>
5258 true
5359 case _ =>
5460 false
5561 }
5662
5763
5864 func getLeasingNodeEntry (nodeAddress,currentLeased,nextLeased) = {
5965 let valueString = makeString(["%d%d%d%d", toString(currentPeriodHeight), toString(currentLeased), toString(nextPeriodHeight), toString(nextLeased)], SEP)
6066 StringEntry(keyLeasingNodeData(nodeAddress), valueString)
6167 }
6268
6369
6470 func getLeasingNodeData (nodeAddress) = {
6571 let leasingNodeDataStringRaw = getString(this, keyLeasingNodeData(nodeAddress))
6672 match leasingNodeDataStringRaw {
6773 case ds: String =>
6874 let dataList = split(ds, SEP)
6975 let nodeCurrentPeriod = parseIntValue(dataList[1])
7076 let nodeCurrentLeased = parseIntValue(dataList[2])
7177 let nodeNextPeriod = parseIntValue(dataList[3])
7278 let nodeNextLeased = parseIntValue(dataList[4])
7379 if ((nodeNextPeriod > height))
7480 then $Tuple2(nodeCurrentLeased, nodeNextLeased)
7581 else $Tuple2(nodeNextLeased, nodeNextLeased)
7682 case _ =>
7783 $Tuple2(0, 0)
7884 }
7985 }
8086
8187
8288 func getUserLeasingEntry (nodeAddress,userAddress,userCurrentLeased,userNextLeased) = {
8389 let valueString = makeString(["%d%d%d%d", toString(currentPeriodHeight), toString(userCurrentLeased), toString(nextPeriodHeight), toString(userNextLeased)], SEP)
8490 StringEntry(keyUserLeasingNodeData(userAddress, nodeAddress), valueString)
8591 }
8692
8793
8894 func getUserLeasingData (nodeAddress,userAddress) = {
8995 let leasingUserDataStringRaw = getString(this, keyUserLeasingNodeData(userAddress, nodeAddress))
9096 match leasingUserDataStringRaw {
9197 case ds: String =>
9298 let dataList = split(ds, SEP)
9399 let userCurrentPeriod = parseIntValue(dataList[1])
94100 let userCurrentLeased = parseIntValue(dataList[2])
95101 let userNextPeriod = parseIntValue(dataList[3])
96102 let userNextLeased = parseIntValue(dataList[4])
97103 if ((userNextPeriod > height))
98104 then $Tuple2(userCurrentLeased, userNextLeased)
99105 else $Tuple2(userNextLeased, userNextLeased)
100106 case _ =>
101107 $Tuple2(0, 0)
102108 }
103109 }
104110
105111
106112 func getUserToClaimEntry (userAddress,toClaim,toUnlock) = {
107113 let valueString = makeString(["%d%d%d%d", toString(currentPeriodHeight), toString(toClaim), toString(nextPeriodHeight), toString(toUnlock)], SEP)
108114 StringEntry(keyUserToClaim(userAddress), valueString)
109115 }
110116
111117
112118 func getUserToClaimBalance (userAddress) = {
113119 let userToClaimDataStringRaw = getString(this, keyUserToClaim(userAddress))
114120 match userToClaimDataStringRaw {
115121 case ds: String =>
116122 let dataList = split(ds, SEP)
117123 let currentPeriod = parseIntValue(dataList[1])
118124 let toClaim = parseIntValue(dataList[2])
119125 let nextPeriod = parseIntValue(dataList[3])
120126 let toUnlock = parseIntValue(dataList[4])
121127 if ((nextPeriod > height))
122128 then $Tuple2(toClaim, toUnlock)
123129 else $Tuple2((toClaim + toUnlock), 0)
124130 case _ =>
125131 $Tuple2(0, 0)
126132 }
127133 }
128134
129135
130136 func getStakeActions (nodeAddress,userAddress,i) = {
131137 let checks = [if ((size(i.payments) == 1))
132138 then true
133139 else throwErr("payment size should be exactly 1"), if ((i.payments[0].assetId == assetIdBytes))
134140 then true
135141 else throwErr(makeString(["payment assetId should be:", assetIdString], " ")), if (isValidAddress(nodeAddress))
136142 then true
137143 else throwErr(makeString(["node address is not valid:", nodeAddress], " ")), if (isValidAddress(userAddress))
138144 then true
139145 else throwErr(makeString(["user address is not valid:", userAddress], " "))]
140146 if ((checks == checks))
141147 then {
142148 let userLeasingAmount = i.payments[0].amount
143- let $t055095582 = getLeasingNodeData(nodeAddress)
144- let nodeCurrentLeased = $t055095582._1
145- let nodeNextLeased = $t055095582._2
149+ let $t057775850 = getLeasingNodeData(nodeAddress)
150+ let nodeCurrentLeased = $t057775850._1
151+ let nodeNextLeased = $t057775850._2
146152 let newNodeNextLease = (nodeNextLeased + userLeasingAmount)
147- let $t056505736 = getUserLeasingData(nodeAddress, userAddress)
148- let userCurrentLeased = $t056505736._1
149- let userNextLeased = $t056505736._2
153+ let $t059186004 = getUserLeasingData(nodeAddress, userAddress)
154+ let userCurrentLeased = $t059186004._1
155+ let userNextLeased = $t059186004._2
150156 let newUserNextLeased = (userNextLeased + userLeasingAmount)
151-[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased)]
157+[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), IntegerEntry(keyNodeLeasingByHeight(nodeAddress), newNodeNextLease), IntegerEntry(keyUserLeasingByHeight(nodeAddress, userAddress), newUserNextLeased)]
152158 }
153159 else throw("Strict value is not equal to itself.")
154160 }
155161
156162
157163 func getUnstakeActions (nodeAddress,userAddress,unstakeAmount) = {
158- let $t060806153 = getLeasingNodeData(nodeAddress)
159- let nodeCurrentLeased = $t060806153._1
160- let nodeNextLeased = $t060806153._2
161- let $t061586244 = getUserLeasingData(nodeAddress, userAddress)
162- let userCurrentLeased = $t061586244._1
163- let userNextLeased = $t061586244._2
164+ let $t065166589 = getLeasingNodeData(nodeAddress)
165+ let nodeCurrentLeased = $t065166589._1
166+ let nodeNextLeased = $t065166589._2
167+ let $t065946680 = getUserLeasingData(nodeAddress, userAddress)
168+ let userCurrentLeased = $t065946680._1
169+ let userNextLeased = $t065946680._2
164170 let checks = [if ((unstakeAmount > 0))
165171 then true
166172 else throwErr("unstake amount should be greater than 0"), if ((userNextLeased >= unstakeAmount))
167173 then true
168174 else throwErr("unstake amount should be less or equal user staked amount"), if ((nodeNextLeased >= unstakeAmount))
169175 then true
170176 else throwErr("unstake amount should be less or equal node staked amount"), if (isValidAddress(nodeAddress))
171177 then true
172178 else throwErr(makeString(["node address is not valid:", nodeAddress], " ")), if (isValidAddress(userAddress))
173179 then true
174180 else throwErr(makeString(["user address is not valid:", userAddress], " "))]
175181 if ((checks == checks))
176182 then {
177183 let newNodeNextLease = (nodeNextLeased - unstakeAmount)
178184 let newUserNextLeased = (userNextLeased - unstakeAmount)
179- let $t069377042 = getUserToClaimBalance(userAddress)
180- let toClaim = $t069377042._1
181- let toUnlock = $t069377042._2
185+ let $t073737478 = getUserToClaimBalance(userAddress)
186+ let toClaim = $t073737478._1
187+ let toUnlock = $t073737478._2
182188 let newToUnlock = (toUnlock + unstakeAmount)
183-[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, toClaim, newToUnlock)]
189+[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, toClaim, newToUnlock), IntegerEntry(keyNodeLeasingByHeight(nodeAddress), newNodeNextLease), IntegerEntry(keyUserLeasingByHeight(nodeAddress, userAddress), newUserNextLeased)]
184190 }
185191 else throw("Strict value is not equal to itself.")
186192 }
187193
188194
189195 func getClaimUnlockedActions (userAddress,claimAmount) = {
190- let $t074177477 = getUserToClaimBalance(userAddress)
191- let toClaim = $t074177477._1
192- let toUnlock = $t074177477._2
196+ let $t080218081 = getUserToClaimBalance(userAddress)
197+ let toClaim = $t080218081._1
198+ let toUnlock = $t080218081._2
193199 let checks = [if ((claimAmount > 0))
194200 then true
195201 else throwErr("claim amount should be greater than 0"), if ((toClaim >= claimAmount))
196202 then true
197203 else throwErr("claim amount should be less or equal unlocked amount"), if (isValidAddress(userAddress))
198204 then true
199205 else throwErr(makeString(["user address is not valid:", userAddress], " "))]
200206 if ((checks == checks))
201207 then {
202208 let newToClaim = (toClaim - claimAmount)
203209 [getUserToClaimEntry(userAddress, newToClaim, toUnlock), ScriptTransfer(addressFromStringValue(userAddress), claimAmount, assetIdBytes)]
204210 }
205211 else throw("Strict value is not equal to itself.")
206212 }
207213
208214
209215 func getStakeFromUnlockedActions (nodeAddress,userAddress,userLeasingAmount) = {
210- let $t081178177 = getUserToClaimBalance(userAddress)
211- let toClaim = $t081178177._1
212- let toUnlock = $t081178177._2
216+ let $t087218781 = getUserToClaimBalance(userAddress)
217+ let toClaim = $t087218781._1
218+ let toUnlock = $t087218781._2
213219 let available = (toUnlock + toClaim)
214220 let checks = [if ((userLeasingAmount > 0))
215221 then true
216222 else throwErr("amount should be greater than 0"), if ((available >= userLeasingAmount))
217223 then true
218224 else throwErr("amount should be less or equal to available"), if (isValidAddress(nodeAddress))
219225 then true
220226 else throwErr(makeString(["node address is not valid:", nodeAddress], " ")), if (isValidAddress(userAddress))
221227 then true
222228 else throwErr(makeString(["user address is not valid:", userAddress], " "))]
223229 if ((checks == checks))
224230 then {
225- let $t086548727 = getLeasingNodeData(nodeAddress)
226- let nodeCurrentLeased = $t086548727._1
227- let nodeNextLeased = $t086548727._2
231+ let $t092589331 = getLeasingNodeData(nodeAddress)
232+ let nodeCurrentLeased = $t092589331._1
233+ let nodeNextLeased = $t092589331._2
228234 let newNodeNextLease = (nodeNextLeased + userLeasingAmount)
229- let $t087958881 = getUserLeasingData(nodeAddress, userAddress)
230- let userCurrentLeased = $t087958881._1
231- let userNextLeased = $t087958881._2
235+ let $t093999485 = getUserLeasingData(nodeAddress, userAddress)
236+ let userCurrentLeased = $t093999485._1
237+ let userNextLeased = $t093999485._2
232238 let newUserNextLeased = (userNextLeased + userLeasingAmount)
233239 let newToUnlock = max([0, (toUnlock - userLeasingAmount)])
234240 let newToClaim = min([toClaim, (toClaim + (toUnlock - userLeasingAmount))])
235-[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, newToClaim, newToUnlock)]
241+[getLeasingNodeEntry(nodeAddress, nodeCurrentLeased, newNodeNextLease), getUserLeasingEntry(nodeAddress, userAddress, userCurrentLeased, newUserNextLeased), getUserToClaimEntry(userAddress, newToClaim, newToUnlock), IntegerEntry(keyNodeLeasingByHeight(nodeAddress), newNodeNextLease), IntegerEntry(keyUserLeasingByHeight(nodeAddress, userAddress), newUserNextLeased)]
236242 }
237243 else throw("Strict value is not equal to itself.")
238244 }
239245
240246
241247 func getSetNewPeriodLengthActions (newPeriodLength) = {
242248 let check = [if ((newPeriodLength > 0))
243249 then true
244250 else throwErr("period length should be greater than 0")]
245251 if ((check == check))
246252 then if ((periodOffsetHeight == -1))
247253 then [IntegerEntry(keyPeriodLength, newPeriodLength), IntegerEntry(keyPeriodOffsetHeight, height)]
248254 else [IntegerEntry(keyPeriodOffsetId, (currentPeriodId + 1)), IntegerEntry(keyPeriodOffsetHeight, nextPeriodHeight), IntegerEntry(keyPeriodLength, newPeriodLength)]
249255 else throw("Strict value is not equal to itself.")
250256 }
251257
252258
253259 @Callable(i)
254260 func setNewPeriodLength (newPeriodLength) = getSetNewPeriodLengthActions(newPeriodLength)
255261
256262
257263
258264 @Callable(i)
259265 func getNodeDataREADONLY (nodeAddress) = {
260- let $t01010810172 = getLeasingNodeData(nodeAddress)
261- let currentLease = $t01010810172._1
262- let nextLeased = $t01010810172._2
266+ let $t01088010944 = getLeasingNodeData(nodeAddress)
267+ let currentLease = $t01088010944._1
268+ let nextLeased = $t01088010944._2
263269 $Tuple2(nil, $Tuple5(currentPeriodHeight, currentLease, nextPeriodHeight, nextLeased, height))
264270 }
265271
266272
267273
268274 @Callable(i)
269275 func getUserDataREADONLY (userAddress) = {
270- let $t01032810388 = getUserToClaimBalance(userAddress)
271- let toClaim = $t01032810388._1
272- let toUnlock = $t01032810388._2
276+ let $t01110011160 = getUserToClaimBalance(userAddress)
277+ let toClaim = $t01110011160._1
278+ let toUnlock = $t01110011160._2
273279 $Tuple2(nil, $Tuple5(currentPeriodHeight, toClaim, nextPeriodHeight, toUnlock, height))
274280 }
275281
276282
277283
278284 @Callable(i)
279285 func stakeFor (nodeAddress,userAddress) = getStakeActions(nodeAddress, userAddress, i)
280286
281287
282288
283289 @Callable(i)
284290 func stake (nodeAddress) = {
285291 let userAddress = toString(i.caller)
286292 getStakeActions(nodeAddress, userAddress, i)
287293 }
288294
289295
290296
291297 @Callable(i)
292298 func stakeFromUnlocked (nodeAddress,amount) = {
293299 let userAddress = toString(i.caller)
294300 getStakeFromUnlockedActions(nodeAddress, userAddress, amount)
295301 }
296302
297303
298304
299305 @Callable(i)
300306 func unstake (nodeAddress,amount) = {
301307 let userAddress = toString(i.caller)
302308 getUnstakeActions(nodeAddress, userAddress, amount)
303309 }
304310
305311
306312
307313 @Callable(i)
308314 func claim (amount) = {
309315 let userAddress = toString(i.caller)
310316 getClaimUnlockedActions(userAddress, amount)
311317 }
312318
313319
314320
315321 @Callable(i)
316322 func claimAll () = {
317323 let userAddress = toString(i.caller)
318- let $t01130611366 = getUserToClaimBalance(userAddress)
319- let toClaim = $t01130611366._1
320- let toUnlock = $t01130611366._2
324+ let $t01207812138 = getUserToClaimBalance(userAddress)
325+ let toClaim = $t01207812138._1
326+ let toUnlock = $t01207812138._2
321327 let checks = [if ((toClaim > 0))
322328 then true
323329 else throwErr("nothing to claim")]
324330 if ((checks == checks))
325331 then getClaimUnlockedActions(userAddress, toClaim)
326332 else throw("Strict value is not equal to itself.")
327333 }
328334
329335

github/deemru/w8io/169f3d6 
88.59 ms