tx · BZ2LsFFSnNda7cdDdLG4BFaK3HsjvToJG4eF1AjkUbYw

3N7dQeENwSgKPp9Ki4aEHhRWWKVjn1DE9Qg:  -0.02000000 Waves

2023.11.27 22:51 [2862256] smart account 3N7dQeENwSgKPp9Ki4aEHhRWWKVjn1DE9Qg > SELF 0.00000000 Waves

{ "type": 13, "id": "BZ2LsFFSnNda7cdDdLG4BFaK3HsjvToJG4eF1AjkUbYw", "fee": 2000000, "feeAssetId": null, "timestamp": 1701114758209, "version": 2, "chainId": 84, "sender": "3N7dQeENwSgKPp9Ki4aEHhRWWKVjn1DE9Qg", "senderPublicKey": "5BN6FQeKuMm2XJYToUZvbBX4UELGpE3Z47P4q6sP46PG", "proofs": [ "B5Ktr8BpJ2ywxYiJzJDsevYJpZBYfuGJDP41pBZQuatE94HLjyG9NocNMddJu5Hk2eMLqPkq5P25p5tHroUyiiC" ], "script": "base64:BgI2CAISBAoCCAESAwoBARIAEgASBAoCCAESBQoDCAEBEgMKAQESABIDCgEIEgASAwoBARIDCgEBQQAITUlMTElPTjYAgIDpg7HeFgAJREFZTUlMTElTAIC4mSkBGmtleUFjcmVzU3Rha2VkQW1vdW50QnlVc2VyAQRhZGRyCQCsAgICGGFjcmVzU3Rha2VkQW1vdW50QnlVc2VyXwUEYWRkcgEaa2V5QWNyZXNMb2NrZWRBbW91bnRCeVVzZXIBBGFkZHIJAKwCAgIYYWNyZXNMb2NrZWRBbW91bnRCeVVzZXJfBQRhZGRyARdrZXlBY3Jlc0xvY2tlZEV0YUJ5VXNlcgEEYWRkcgkArAICAhVhY3Jlc0xvY2tlZEV0YUJ5VXNlcl8FBGFkZHIAE2FjcmVzU3Rha2VkVG90YWxLZXkCFmFjcmVzU3Rha2VkQW1vdW50VG90YWwACnhwTmV3U0xhbmQAwJaxAgAPREFJTFlSRVNCWVBJRUNFAID40gEAFVVTRFQyQUNSRVNfTVVMVElQTElFUgAKARprZXlJc0F3YXJkZWRCeVByb21vQW5kVXNlcgIHcHJvbW9JZARhZGRyCQC5CQIJAMwIAgIfJXMlZCVzX19pc0F3YXJkZWRCeVByb21vQW5kVXNlcgkAzAgCCQCkAwEFB3Byb21vSWQJAMwIAgUEYWRkcgUDbmlsAgJfXwEWa2V5VGlja2V0c1RvdGFsQnlQcm9tbwEHcHJvbW9JZAkArAICAhslcyVkX190aWNrZXRzVG90YWxCeVByb21vX18JAKQDAQUHcHJvbW9JZAEea2V5VGlja2V0c1RvdGFsQnlQcm9tb0FuZFJvdW5kAgdwcm9tb0lkB3JvdW5kSWQJALkJAgkAzAgCAiMlcyVkJWRfX3RpY2tldHNUb3RhbEJ5UHJvbW9BbmRSb3VuZAkAzAgCCQCkAwEFB3Byb21vSWQJAMwIAgkApAMBBQdyb3VuZElkBQNuaWwCAl9fAAVjaGFpbgkAyQECCQDKAQIIBQR0aGlzBWJ5dGVzAAEAAQALdXNkdEFzc2V0SWQEByRtYXRjaDAFBWNoYWluAwkAAAIBAVcFByRtYXRjaDABIITaerIIAz9O0bvKju6Lk7zJgt0LXfoHlqjUI/moD/+5AwkAAAIBAVQFByRtYXRjaDABIFWx2J9yh4Lv5eNbjawFq2XemkOhLxa7BfMat4el8cUYCQACAQINVW5rbm93biBjaGFpbgAVZGVmYXVsdFJlc3RBZGRyZXNzU3RyBAckbWF0Y2gwBQVjaGFpbgMJAAACAQFXBQckbWF0Y2gwAiMzUFFDdXZGYnZoNExrUFVucm5VMXozam5iQTFwOW0zV05odgMJAAACAQFUBQckbWF0Y2gwAiMzTXVta0dHenRDS0FYcFdEcXhrZGRvZnFYU1VicVFrdlNKeQkAAgECDVVua25vd24gY2hhaW4ADHByb21vMk1hcEtleQIJcHJvbW8yTWFwARRrZXlQcm9tbzJNYXBGb3JSb3VuZAEHcm91bmRJZAkArAICAhNwcm9tbzJNYXBGb3JSb3VuZF9fCQCkAwEFB3JvdW5kSWQAA1NFUAICX18ABU1VTFQ2AMCEPQAFTVVMVDgAgMLXLwAGSVRFUjIwCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQkAzAgCAAoJAMwIAgALCQDMCAIADAkAzAgCAA0JAMwIAgAOCQDMCAIADwkAzAgCABAJAMwIAgARCQDMCAIAEgkAzAgCABMFA25pbAEPZ2V0U3RyaW5nT3JGYWlsAgdhZGRyZXNzA2tleQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFB2FkZHJlc3MFA2tleQkAuQkCCQDMCAICCm1hbmRhdG9yeSAJAMwIAgkApQgBBQdhZGRyZXNzCQDMCAICAS4JAMwIAgUDa2V5CQDMCAICDyBpcyBub3QgZGVmaW5lZAUDbmlsAgAAEUlkeENmZ1N0YWtpbmdEYXBwAAEAEUlkeENmZ0Vjb25vbXlEYXBwAAIADUlkeENmZ1dsZ0RhcHAABAAPSWR4Q2ZnQWNyZXNEYXBwAAgBCmtleVJlc3RDZmcAAg4lc19fcmVzdENvbmZpZwEOa2V5UmVzdEFkZHJlc3MAAgwlc19fcmVzdEFkZHIBEXJlYWRSZXN0Q2ZnT3JGYWlsAQRyZXN0CQC8CQIJAQ9nZXRTdHJpbmdPckZhaWwCBQRyZXN0CQEKa2V5UmVzdENmZwAFA1NFUAEYZ2V0Q29udHJhY3RBZGRyZXNzT3JGYWlsAgdyZXN0Q2ZnA2lkeAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJAJEDAgUHcmVzdENmZwUDaWR4CQCsAgICKlJlc3QgY2ZnIGRvZXNuJ3QgY29udGFpbiBhZGRyZXNzIGF0IGluZGV4IAkApAMBBQNpZHgADHJlc3RDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzCQEOa2V5UmVzdEFkZHJlc3MABRVkZWZhdWx0UmVzdEFkZHJlc3NTdHIAB3Jlc3RDZmcJARFyZWFkUmVzdENmZ09yRmFpbAEFDHJlc3RDb250cmFjdAAPc3Rha2luZ0NvbnRyYWN0CQEYZ2V0Q29udHJhY3RBZGRyZXNzT3JGYWlsAgUHcmVzdENmZwURSWR4Q2ZnU3Rha2luZ0RhcHAAD2Vjb25vbXlDb250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFB3Jlc3RDZmcFEUlkeENmZ0Vjb25vbXlEYXBwAAt3bGdDb250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFB3Jlc3RDZmcFDUlkeENmZ1dsZ0RhcHAADWFjcmVzQ29udHJhY3QJARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCBQdyZXN0Q2ZnBQ9JZHhDZmdBY3Jlc0RhcHAAFGFjcmVzSXNzdWVkQW1vdW50S2V5AhFhY3Jlc0lzc3VlZEFtb3VudAAPYWNyZXNBc3NldElkS2V5AgxhY3Jlc0Fzc2V0SWQADGFjcmVzQXNzZXRJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCcCAIFDWFjcmVzQ29udHJhY3QFD2FjcmVzQXNzZXRJZEtleQIXQUNSRVMgaXMgbm90IGlzc3VlZCB5ZXQBGGtleUFjcmVzU3Rha2VkVGltZUJ5VXNlcgEEYWRkcgkArAICAhZhY3Jlc1N0YWtlZFRpbWVCeVVzZXJfBQRhZGRyAAtJZHhFZmZUb3RhbAAAAAtyYW5kb21EZWxheQACAQlrZXlDb21taXQBB2FkZHJlc3MJAKwCAgIPZmluaXNoQmxvY2tGb3JfBQdhZGRyZXNzARFrZXlSZXNQcm9wb3J0aW9ucwACE3Jlc1R5cGVzUHJvcG9ydGlvbnMBFmtleVN0YWtlZFBpZWNlc0J5T3duZXIBCW93bmVyQWRkcgkArAICAhRzdGFrZWRQaWVjZXNCeU93bmVyXwUJb3duZXJBZGRyAQVhc0ludAEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgNJbnQEAW4FByRtYXRjaDAFAW4JAAIBAhVmYWlsIHRvIGNhc3QgaW50byBJbnQBDmFzVHdvSW50c1R1cGxlAQN2YWwEByRtYXRjaDAFA3ZhbAMJAAECBQckbWF0Y2gwAgooSW50LCBJbnQpBAJ0MgUHJG1hdGNoMAUCdDIJAAIBAhxmYWlsIHRvIGNhc3QgaW50byAoSW50LCBJbnQpARFrZXlMYXN0VHhJZEJ5VXNlcgEEYWRkcgkArAICAg9sYXN0VHhJZEJ5VXNlcl8FBGFkZHIBDmdldFZvdGluZ1Bvd2VyARJ1c2VyQWRkclN0ck9yRW1wdHkEBXByb3BzCQC1CQIJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUPc3Rha2luZ0NvbnRyYWN0CQERa2V5UmVzUHJvcG9ydGlvbnMAAgswXzBfMF8wXzBfMAIBXwoBBWFkZGVyAgNhY2MEaXRlbQkAZAIFA2FjYwkBDXBhcnNlSW50VmFsdWUBBQRpdGVtBAp0b3RhbFBvd2VyCgACJGwFBXByb3BzCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQVhZGRlcgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgNgkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgQKdXNlcnNQb3dlcgkBC3ZhbHVlT3JFbHNlAgkAmggCBQ9zdGFraW5nQ29udHJhY3QJARZrZXlTdGFrZWRQaWVjZXNCeU93bmVyAQUSdXNlckFkZHJTdHJPckVtcHR5AAAJAMwIAgUKdG90YWxQb3dlcgkAzAgCBQp1c2Vyc1Bvd2VyBQNuaWwBCmZpeGVkUG9pbnQCA3ZhbAhkZWNpbWFscwQGdGVuUG93CQBsBgAKAAAFCGRlY2ltYWxzAAAAAAUERE9XTgQHbG93UGFydAkApAMBCQBqAgUDdmFsBQZ0ZW5Qb3cEBnplcm9lcwkAsAICCQCkAwEFBnRlblBvdwkAZAIAAQkAsQIBBQdsb3dQYXJ0CQCsAgIJAKwCAgkArAICCQCkAwEJAGkCBQN2YWwFBnRlblBvdwIBLgUGemVyb2VzBQdsb3dQYXJ0AQRwYWRMAgN2YWwDbGVuBAR2YWxTCQCkAwEFA3ZhbAQGemVyb2VzCQCwAgIJAKQDAQkAbAYACgAACQBlAgUDbGVuCQCxAgEFBHZhbFMAAAAABQRET1dOAAEJAKwCAgUGemVyb2VzBQR2YWxTAQ9nZXRSYW5kb21OdW1iZXIDCG1heFZhbHVlBHNhbHQHZW50cm9weQMJAGcCAAAFCG1heFZhbHVlCQACAQIWbWF4VmFsdWUgc2hvdWxkIGJlID4gMAQKcmFuZG9tSGFzaAkA9wMBCQDLAQIFBHNhbHQFB2VudHJvcHkJAGoCCQCxCQEFCnJhbmRvbUhhc2gFCG1heFZhbHVlAB1NSU5fQUNSRVNfQU1PVU5UX0RVUklOR19QUk9NTwCAreIEAAxCTEFDS0xJU1RFRDEC3wYzUDJOR1g0UTVuZ2UxTUNhdXdRVzVhcVlMZGtjY1NHajFFcF8zUDJ4RkFIVzl5aHlOb2hZb3pXZDRIRmhFWFp1M2JzTlNvUl8zUDJ5S2FaMmd2bjlYZTV0dGk4MWE3UDlMWmhIZ2p2VG9WOV8zUDM3elEzY2YyZWN1NTVSbUpxRWlHU2l2ZHpOOWF2dDNtOV8zUDRhejZkdHpzdkdDV0ZBeGE5NFVkZXZLelh5RXd4RWlGR18zUDRrWlU2WDNUVExGY1NVZTU1SlN5OEJ5U3FpdGNQZ01Cel8zUDVoQ3hCRWgzTmdOaXpaaE5CcmV5QlNxdGJoSllMa0tQRF8zUDdITHZ1Y3kxMXl4eU1KVXdqelhGSEhLTUVEd2kxRXdmQ18zUDhKdWFxSDlQVFFBdjhENUhCR2dRZkthdUxUWXQyTlFmdF8zUDlnVERCNHJ0REVWYnBYM2FzVTYzSDRaaW5oMkVuVG1aRV8zUDlpTjNxcnRmSmljVVZ5N2FtWmVWc2V0VkQzdlVNazhiZV8zUENhMkJzQWE2SkJMaXJzelFmVjVyOWZKcnVqZmh3dHdmUF8zUEQzaTRYTjhLdHlnY0Z4NHJ5NU03VUdxZGZIOFZZdnRSVF8zUERFTW5uSk5jMmt4OWNQRW12VnZoWFVyOFN2aEFOS2hzYV8zUERHRTl0S1FpemFlWkZlRERxNWFZU3Y4OW53WWJmaXJwWl8zUERNS1FUQ3JVUFpFQ1ZYRUpKOG0xc0h0dXRTdTFuYVNmMV8zUEdoMlF1Nll2eDhHVENSUlZOdkJVVlpMZGFpZFlTYXhvNV8zUEtrbUF0YlNLNUQyaFFkbzFSZkVnOGVYeU1iRGNSVWM5Ml8zUExNbmJ4enNzUDhXOEU4WGpKMVJMQkJnOFVaTDhDejNQMl8zUE11eG80UENBb3g5czRhN1IxZXN6aDRpcXF1OGdTN2pIdl8zUE5yTXRFUUNodzg3V1pVMUpBSjdhR0h5a0NhOFRqbkROS18zUFB1QlhmV29CeTNFRW9yeTdjN3ZnaTlVc2prYTdvNXRCal8zUFF3eWV5RWhUNFk2YUdBTDZ0ZzczYVFXSnRWMXpSdDNuUl8zUFJHRFNodU1HYjg0TUp0VEp2dFRnOHFEZnN3a1lXY20zZQANUFJPTU8xX0FNT1VOVADCra8CABdQUk9NT18yX1NUQVJUX1RJTUVTVEFNUAQHJG1hdGNoMAUFY2hhaW4DCQAAAgEBVwUHJG1hdGNoMACA8LT5vjEDCQAAAgEBVAUHJG1hdGNoMACA59DHvjEJAAIBAg1Vbmtub3duIGNoYWluABVQUk9NT18yX0VORF9USU1FU1RBTVAEByRtYXRjaDAFBWNoYWluAwkAAAIBAVcFByRtYXRjaDAA/7/N8MAxAwkAAAIBAVQFByRtYXRjaDAAgIjX674xCQACAQINVW5rbm93biBjaGFpbgAZUFJPTU9fMl9ESVNUUklCVVRJT05fRlVORACAlOvcAwAXcHJvbW8yTnVtUHJpemVzUGVyUm91bmQJAMwIAgABCQDMCAIAAwkAzAgCAAUJAMwIAgAUBQNuaWwAE3Byb21vMkF3YXJkUGVyUm91bmQJAMwIAgCAyrXuAQkAzAgCAICEr18JAMwIAgCAwtcvCQDMCAIAgNrECQUDbmlsARNpc0JsYWNrbGlzdGVkUHJvbW8xAQRhZGRyCQEIY29udGFpbnMCBQxCTEFDS0xJU1RFRDEFBGFkZHIBBnByb2xvZwAJAQVhc0ludAEJAP0HBAUPc3Rha2luZ0NvbnRyYWN0AgpzYXZlTGFzdFR4BQNuaWwFA25pbAESY2xhaW1BY3Jlc0ludGVybmFsAwRhZGRyC2FjcmVzQW1vdW50DWxhc3RDbGFpbVRpbWUECWRlbHRhVGltZQkAZQIIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQ1sYXN0Q2xhaW1UaW1lBAhhdmFpbFJlcwkAawMFCWRlbHRhVGltZQkAaAIFD0RBSUxZUkVTQllQSUVDRQULYWNyZXNBbW91bnQJAGgCBQlEQVlNSUxMSVMFBU1VTFQ4BApjYW5HZXRVc2R0CQEFYXNJbnQBCQD8BwQFD2Vjb25vbXlDb250cmFjdAIac2VsbFJlc291cmNlc1dvcmxkUkVBRE9OTFkJAMwIAgUIYXZhaWxSZXMFA25pbAUDbmlsBAdnb3RVc2R0CQCWAwEJAMwIAgAACQDMCAIFCmNhbkdldFVzZHQFA25pbAkAaAIFB2dvdFVzZHQFFVVTRFQyQUNSRVNfTVVMVElQTElFUgENY2xhaW1JbnRlcm5hbAMEYWRkcgthY3Jlc0Ftb3VudA1sYXN0Q2xhaW1UaW1lBAlkZWx0YVRpbWUJAGUCCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUNbGFzdENsYWltVGltZQMJAGYCAAAFCWRlbHRhVGltZQkAAgEJAKwCAgkArAICCQCsAgICJlNhdmVkIHRpbWVzdGFtcCBpcyBpbiBmdXR1cmUsIHNhdmVkID0gCQCkAwEFDWxhc3RDbGFpbVRpbWUCDCwgY3VycmVudCA9IAkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAQIYXZhaWxSZXMJAGsDBQlkZWx0YVRpbWUJAGgCBQ9EQUlMWVJFU0JZUElFQ0UFC2FjcmVzQW1vdW50CQBoAgUJREFZTUlMTElTBQVNVUxUOAQKY2FuR2V0VXNkdAkBBWFzSW50AQkA/AcEBQ9lY29ub215Q29udHJhY3QCGnNlbGxSZXNvdXJjZXNXb3JsZFJFQURPTkxZCQDMCAIFCGF2YWlsUmVzBQNuaWwFA25pbAQHZ290VXNkdAMJAGcCAAAFCmNhbkdldFVzZHQAAAgJAQ5hc1R3b0ludHNUdXBsZQEJAPwHBAUPZWNvbm9teUNvbnRyYWN0AhJzZWxsUmVzb3VyY2VzV29ybGQJAMwIAgUEYWRkcgkAzAgCBQhhdmFpbFJlcwUDbmlsBQNuaWwCXzEJAGgCBQdnb3RVc2R0BRVVU0RUMkFDUkVTX01VTFRJUExJRVIBC21lcmdlTG9ja2VkBAlvbGRBbW91bnQGb2xkRVRBCW5ld0Ftb3VudAZuZXdFVEEEA25vdwgFCWxhc3RCbG9jawl0aW1lc3RhbXAEA2R0MQkAlgMBCQDMCAIAAAkAzAgCCQBlAgUGb2xkRVRBBQNub3cFA25pbAQDZHQyCQCWAwEJAMwIAgAACQDMCAIJAGUCBQZuZXdFVEEFA25vdwUDbmlsBANzdW0JAGQCBQlvbGRBbW91bnQFCW5ld0Ftb3VudAQCZHQDCQAAAgUDc3VtAAAAAAkAZAIJAGsDBQNkdDEFCW9sZEFtb3VudAUDc3VtCQBrAwUDZHQyBQluZXdBbW91bnQFA3N1bQkAZAIFA25vdwUCZHQMAWkBDWNvbnN0cnVjdG9yVjECCHJlc3RBZGRyDnVuc3Rha2VkUGllY2VzAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIRUGVybWlzc2lvbiBkZW5pZWQDCQEJaXNEZWZpbmVkAQkAoQgBBQ9hY3Jlc0Fzc2V0SWRLZXkJAAIBAhNBbHJlYWR5IGluaXRpYWxpemVkBAhuZnRBY3JlcwkAZAIJAJEDAgkBDmdldFZvdGluZ1Bvd2VyAQIABQtJZHhFZmZUb3RhbAUOdW5zdGFrZWRQaWVjZXMEDGlzc3VlZEFtb3VudAkAZQIFCE1JTExJT042CQBoAgUIbmZ0QWNyZXMFBU1VTFQ4BAVpc3N1ZQkAwwgHAgVBQ1JFUwImV2F2ZXNMYW5kcyBsYW5kIGFjcmVzIGludmVzdG1lbnQgdG9rZW4FDGlzc3VlZEFtb3VudAAIBwUEdW5pdAAABAdhc3NldElkCQC4CAEFBWlzc3VlCQDMCAIFBWlzc3VlCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRRhY3Jlc0lzc3VlZEFtb3VudEtleQUMaXNzdWVkQW1vdW50CQDMCAIJAQtCaW5hcnlFbnRyeQIFD2FjcmVzQXNzZXRJZEtleQUHYXNzZXRJZAkAzAgCCQELU3RyaW5nRW50cnkCCQEOa2V5UmVzdEFkZHJlc3MABQhyZXN0QWRkcgUDbmlsAWkBDHVuc3Rha2VBY3JlcwEGYW1vdW50BAxwcm9sb2dSZXN1bHQJAQZwcm9sb2cAAwkAAAIFDHByb2xvZ1Jlc3VsdAUMcHJvbG9nUmVzdWx0AwkAZwIAAAUGYW1vdW50CQACAQIZQW1vdW50IHNob3VsZCBiZSBwb3NpdGl2ZQQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAAJAAIBAhRObyBwYXltZW50cyByZXF1aXJlZAQHdGltZUtleQkBGGtleUFjcmVzU3Rha2VkVGltZUJ5VXNlcgEFB2FkZHJlc3MECWFtb3VudEtleQkBGmtleUFjcmVzU3Rha2VkQW1vdW50QnlVc2VyAQUHYWRkcmVzcwQOb2xkQWNyZXNBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUJYW1vdW50S2V5AAADCQBmAgUGYW1vdW50BQ5vbGRBY3Jlc0Ftb3VudAkAAgEJAKwCAgkArAICCQCsAgICDllvdSBoYXZlIG9ubHkgCQEKZml4ZWRQb2ludAIFDm9sZEFjcmVzQW1vdW50AAgCICBBQ1JFUyBzdGFrZWQsIHRyaWVkIHRvIHVuc3Rha2UgCQEKZml4ZWRQb2ludAIFBmFtb3VudAAIBAxsb2NrZWRBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBGmtleUFjcmVzTG9ja2VkQW1vdW50QnlVc2VyAQUHYWRkcmVzcwAABAlsb2NrZWRFVEEJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBF2tleUFjcmVzTG9ja2VkRXRhQnlVc2VyAQUHYWRkcmVzcwAABANub3cIBQlsYXN0QmxvY2sJdGltZXN0YW1wAwMJAGcCBQNub3cFF1BST01PXzJfU1RBUlRfVElNRVNUQU1QCQBnAgUVUFJPTU9fMl9FTkRfVElNRVNUQU1QBQNub3cHCQACAQImWW91IGNhbm5vdCB1bnN0YWtlIEFDUkVTIGR1cmluZyBQcm9tbzIEEHVuc3Rha2FibGVBbW91bnQDCQETaXNCbGFja2xpc3RlZFByb21vMQEFB2FkZHJlc3MJAGUCCQBlAgUOb2xkQWNyZXNBbW91bnQFDGxvY2tlZEFtb3VudAUNUFJPTU8xX0FNT1VOVAkAZQIFDm9sZEFjcmVzQW1vdW50BQxsb2NrZWRBbW91bnQDAwkAZgIFCWxvY2tlZEVUQQUDbm93CQBmAgUGYW1vdW50BRB1bnN0YWthYmxlQW1vdW50BwkAAgEJAKwCAgkArAICCQCsAgICBU9ubHkgCQEKZml4ZWRQb2ludAIFEHVuc3Rha2FibGVBbW91bnQACAInIEFDUkVTIGNhbiBiZSB1bnN0YWtlZCBub3csIHdhaXQgdW50aWwgCQCkAwEFCWxvY2tlZEVUQQQIb2xkVG90YWwJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUTYWNyZXNTdGFrZWRUb3RhbEtleQAABAl3bGdSZXN1bHQJAPwHBAULd2xnQ29udHJhY3QCEm9uU3Rha2VVbnN0YWtlTGFuZAkAzAgCBQdhZGRyZXNzBQNuaWwFA25pbAQMY2xhaW1lZEFjcmVzCQENY2xhaW1JbnRlcm5hbAMFB2FkZHJlc3MFDm9sZEFjcmVzQW1vdW50CQELdmFsdWVPckVsc2UCCQCfCAEFB3RpbWVLZXkAAAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQd0aW1lS2V5CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQEMSW50ZWdlckVudHJ5AgUJYW1vdW50S2V5CQBlAgUOb2xkQWNyZXNBbW91bnQFBmFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgUTYWNyZXNTdGFrZWRUb3RhbEtleQkAZQIFCG9sZFRvdGFsBQZhbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyCQBkAgUGYW1vdW50BQxjbGFpbWVkQWNyZXMFDGFjcmVzQXNzZXRJZAUDbmlsCQCUCgIFDHByb2xvZ1Jlc3VsdAUJd2xnUmVzdWx0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCnN0YWtlQWNyZXMABAxwcm9sb2dSZXN1bHQJAQZwcm9sb2cAAwkAAAIFDHByb2xvZ1Jlc3VsdAUMcHJvbG9nUmVzdWx0BAdhZGRyZXNzCQClCAEIBQFpBmNhbGxlcgMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECImV4YWN0bHkgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQEA3BtdAkAkQMCCAUBaQhwYXltZW50cwAABANhbXQIBQNwbXQGYW1vdW50AwMJAQEhAQkBCWlzRGVmaW5lZAEIBQNwbXQHYXNzZXRJZAYJAQIhPQIJAQV2YWx1ZQEIBQNwbXQHYXNzZXRJZAUMYWNyZXNBc3NldElkCQACAQIUQUNSRVMgcGF5bWVudHMgb25seSEECXdsZ1Jlc3VsdAkA/AcEBQt3bGdDb250cmFjdAISb25TdGFrZVVuc3Rha2VMYW5kCQDMCAIFB2FkZHJlc3MFA25pbAUDbmlsAwkAAAIFCXdsZ1Jlc3VsdAUJd2xnUmVzdWx0BANub3cIBQlsYXN0QmxvY2sJdGltZXN0YW1wAwMJAGYCBRdQUk9NT18yX1NUQVJUX1RJTUVTVEFNUAUDbm93BgkAZgIFA25vdwUVUFJPTU9fMl9FTkRfVElNRVNUQU1QBAd0aW1lS2V5CQEYa2V5QWNyZXNTdGFrZWRUaW1lQnlVc2VyAQUHYWRkcmVzcwQJYW1vdW50S2V5CQEaa2V5QWNyZXNTdGFrZWRBbW91bnRCeVVzZXIBBQdhZGRyZXNzBA5vbGRBY3Jlc0Ftb3VudAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQlhbW91bnRLZXkAAAQIb2xkVG90YWwJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUTYWNyZXNTdGFrZWRUb3RhbEtleQAABAxjbGFpbWVkQWNyZXMJAQ1jbGFpbUludGVybmFsAwUHYWRkcmVzcwUOb2xkQWNyZXNBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUHdGltZUtleQAACQCUCgIJAM0IAgkAzQgCCQDNCAIDCQAAAgUMY2xhaW1lZEFjcmVzAAAFA25pbAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFDGNsYWltZWRBY3JlcwUMYWNyZXNBc3NldElkBQNuaWwJAQxJbnRlZ2VyRW50cnkCBQd0aW1lS2V5CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkBDEludGVnZXJFbnRyeQIFCWFtb3VudEtleQkAZAIFDm9sZEFjcmVzQW1vdW50BQNhbXQJAQxJbnRlZ2VyRW50cnkCBRNhY3Jlc1N0YWtlZFRvdGFsS2V5CQBkAgUIb2xkVG90YWwFA2FtdAkAlAoCBQxwcm9sb2dSZXN1bHQFCXdsZ1Jlc3VsdAMJAGYCBR1NSU5fQUNSRVNfQU1PVU5UX0RVUklOR19QUk9NTwUDYW10CQACAQkArAICCQCsAgICOU1pbiBzdGFrZWQgYW1vdW50IGR1cmluZyBwcm9tbyBhY3Rpb24gc2hvdWxkIGJlIGF0IGxlYXN0IAkBCmZpeGVkUG9pbnQCBR1NSU5fQUNSRVNfQU1PVU5UX0RVUklOR19QUk9NTwAIAgYgQUNSRVMEC3N0YWtlUmVzdWx0CQD8BwQFBHRoaXMCD3NlbmRMb2NrZWRBY3JlcwkAzAgCBQdhZGRyZXNzCQDMCAIFA2FtdAkAzAgCAB4FA25pbAUDbmlsBAlwcm9tbzJNYXAJAQt2YWx1ZU9yRWxzZQIJAKIIAQUMcHJvbW8yTWFwS2V5AgAEB25ld01hcDIDCQEIY29udGFpbnMCBQlwcm9tbzJNYXAFB2FkZHJlc3MEBXBhcnRzCQC9CQIFCXByb21vMk1hcAUHYWRkcmVzcwQJb2xkQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAK8CAgkAsAICCQCRAwIFBXBhcnRzAAEAAQAOCQCsAgIJAKwCAgkArAICCQCsAgIJAJEDAgUFcGFydHMAAAUHYWRkcmVzcwIBOgkBBHBhZEwCCQBkAgUJb2xkQW1vdW50BQNhbXQADgkAsAICCQCRAwIFBXBhcnRzAAEADwQJZmluYWxQYXJ0CQCsAgIJAKwCAgUHYWRkcmVzcwIBOgkBBHBhZEwCBQNhbXQADgMJAAACBQlwcm9tbzJNYXACAAUJZmluYWxQYXJ0CQCsAgIJAKwCAgUJcHJvbW8yTWFwAgFfBQlmaW5hbFBhcnQJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCBQxwcm9tbzJNYXBLZXkFB25ld01hcDIFA25pbAkAlQoDBQxwcm9sb2dSZXN1bHQFCXdsZ1Jlc3VsdAULc3Rha2VSZXN1bHQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIYnV5QWNyZXMABAxwcm9sb2dSZXN1bHQJAQZwcm9sb2cAAwkAAAIFDHByb2xvZ1Jlc3VsdAUMcHJvbG9nUmVzdWx0BAdhZGRyZXNzCQClCAEIBQFpBmNhbGxlcgMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECImV4YWN0bHkgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQEA3BtdAkAkQMCCAUBaQhwYXltZW50cwAABANhbXQIBQNwbXQGYW1vdW50AwMJAQEhAQkBCWlzRGVmaW5lZAEIBQNwbXQHYXNzZXRJZAYJAQIhPQIJAQV2YWx1ZQEIBQNwbXQHYXNzZXRJZAULdXNkdEFzc2V0SWQJAAIBAhNVU0RUIHBheW1lbnRzIG9ubHkhAwkAZgIFBU1VTFQ2BQNhbXQJAAIBCQCsAgIJAKwCAgIWTWluIHBheW1lbnQgc2hvdWxkIGJlIAkBCmZpeGVkUG9pbnQCBQVNVUxUNgAGAgUgVVNEVAQLYWNyZXNBbW91bnQJAGgCBQNhbXQFFVVTRFQyQUNSRVNfTVVMVElQTElFUgQOYWNjU3RhdHNSZXN1bHQJAQVhc0ludAEJAPwHBAUPc3Rha2luZ0NvbnRyYWN0Ag51cGRhdGVBY2NTdGF0cwkAzAgCBQdhZGRyZXNzCQDMCAIJAGsDBQp4cE5ld1NMYW5kBQthY3Jlc0Ftb3VudAkAaAIAGQUFTVVMVDgFA25pbAUDbmlsCQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUPZWNvbm9teUNvbnRyYWN0BQNhbXQFC3VzZHRBc3NldElkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULYWNyZXNBbW91bnQFDGFjcmVzQXNzZXRJZAUDbmlsCQCUCgIFDHByb2xvZ1Jlc3VsdAUOYWNjU3RhdHNSZXN1bHQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEJc2VuZEFjcmVzAgRhZGRyBmFtb3VudAMJAQIhPQIIBQFpBmNhbGxlcgUPZWNvbm9teUNvbnRyYWN0CQACAQIRUGVybWlzc2lvbiBkZW5pZWQJAJQKAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQERQGV4dHJOYXRpdmUoMTA2MikBBQRhZGRyBQZhbW91bnQFDGFjcmVzQXNzZXRJZAUDbmlsBQZhbW91bnQBaQEPc2VuZExvY2tlZEFjcmVzAwRhZGRyBmFtb3VudAhsb2NrRGF5cwMDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAQIhPQIIBQFpBmNhbGxlcgUMcmVzdENvbnRyYWN0BwkAAgECEVBlcm1pc3Npb24gZGVuaWVkBANub3cIBQlsYXN0QmxvY2sJdGltZXN0YW1wBAd0aW1lS2V5CQEYa2V5QWNyZXNTdGFrZWRUaW1lQnlVc2VyAQUEYWRkcgQJYW1vdW50S2V5CQEaa2V5QWNyZXNTdGFrZWRBbW91bnRCeVVzZXIBBQRhZGRyBA5vbGRBY3Jlc0Ftb3VudAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQlhbW91bnRLZXkAAAQIb2xkVG90YWwJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUTYWNyZXNTdGFrZWRUb3RhbEtleQAABAp0aW1lQWN0aW9uAwkBCWlzRGVmaW5lZAEJAJ8IAQUHdGltZUtleQUDbmlsCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQd0aW1lS2V5BQNub3cFA25pbAQGZXRhS2V5CQEXa2V5QWNyZXNMb2NrZWRFdGFCeVVzZXIBBQRhZGRyBA9sb2NrZWRBbW91bnRLZXkJARprZXlBY3Jlc0xvY2tlZEFtb3VudEJ5VXNlcgEFBGFkZHIED29sZExvY2tlZEFtb3VudAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQ9sb2NrZWRBbW91bnRLZXkAAAQMb2xkTG9ja2VkRVRBCQELdmFsdWVPckVsc2UCCQCfCAEFBmV0YUtleQAABAltZXJnZWRFVEEJAQttZXJnZUxvY2tlZAQFD29sZExvY2tlZEFtb3VudAUMb2xkTG9ja2VkRVRBBQZhbW91bnQJAGQCBQNub3cJAGgCBQhsb2NrRGF5cwUJREFZTUlMTElTCQCUCgIJAM0IAgkAzQgCCQDNCAIJAM0IAgUKdGltZUFjdGlvbgkBDEludGVnZXJFbnRyeQIFCWFtb3VudEtleQkAZAIFDm9sZEFjcmVzQW1vdW50BQZhbW91bnQJAQxJbnRlZ2VyRW50cnkCBRNhY3Jlc1N0YWtlZFRvdGFsS2V5CQBkAgUIb2xkVG90YWwFBmFtb3VudAkBDEludGVnZXJFbnRyeQIFBmV0YUtleQUJbWVyZ2VkRVRBCQEMSW50ZWdlckVudHJ5AgUPbG9ja2VkQW1vdW50S2V5CQBkAgUPb2xkTG9ja2VkQW1vdW50BQZhbW91bnQFBmFtb3VudAFpAQlidXJuQWNyZXMBBmFtb3VudAMJAQIhPQIIBQFpBmNhbGxlcgUPc3Rha2luZ0NvbnRyYWN0CQACAQIRUGVybWlzc2lvbiBkZW5pZWQECmFtb3VudExlZnQJAGUCCQELdmFsdWVPckVsc2UCCQCfCAEFFGFjcmVzSXNzdWVkQW1vdW50S2V5AAAFBmFtb3VudAMJAGYCAAAFCmFtb3VudExlZnQJAAIBAidBdHRlbXB0IHRvIGJ1cm4gbW9yZSBBQ1JFUywgdGhhbiBleGlzdHMJAJQKAgkAzAgCCQEEQnVybgIFDGFjcmVzQXNzZXRJZAUGYW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRRhY3Jlc0lzc3VlZEFtb3VudEtleQUKYW1vdW50TGVmdAUDbmlsBQZhbW91bnQBaQEKY2xhaW1BY3JlcwAEDHByb2xvZ1Jlc3VsdAkBBnByb2xvZwADCQAAAgUMcHJvbG9nUmVzdWx0BQxwcm9sb2dSZXN1bHQEB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwAACQACAQIUTm8gcGF5bWVudHMgcmVxdWlyZWQEB3RpbWVLZXkJARhrZXlBY3Jlc1N0YWtlZFRpbWVCeVVzZXIBBQdhZGRyZXNzBAlhbW91bnRLZXkJARprZXlBY3Jlc1N0YWtlZEFtb3VudEJ5VXNlcgEFB2FkZHJlc3MEC2FjcmVzQW1vdW50CQELdmFsdWVPckVsc2UCCQCfCAEFCWFtb3VudEtleQAABAl3bGdSZXN1bHQJAPwHBAULd2xnQ29udHJhY3QCEm9uU3Rha2VVbnN0YWtlTGFuZAkAzAgCBQdhZGRyZXNzBQNuaWwFA25pbAQMY2xhaW1lZEFjcmVzCQENY2xhaW1JbnRlcm5hbAMFB2FkZHJlc3MFC2FjcmVzQW1vdW50CQELdmFsdWVPckVsc2UCCQCfCAEFB3RpbWVLZXkAAAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQd0aW1lS2V5CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFDGNsYWltZWRBY3JlcwUMYWNyZXNBc3NldElkBQNuaWwJAJQKAgUMcHJvbG9nUmVzdWx0BQl3bGdSZXN1bHQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQESY2xhaW1BY3Jlc1JFQURPTkxZAQdhZGRyZXNzBAd0aW1lS2V5CQEYa2V5QWNyZXNTdGFrZWRUaW1lQnlVc2VyAQUHYWRkcmVzcwQJYW1vdW50S2V5CQEaa2V5QWNyZXNTdGFrZWRBbW91bnRCeVVzZXIBBQdhZGRyZXNzBAthY3Jlc0Ftb3VudAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQlhbW91bnRLZXkAAAQIbGFzdFRpbWUJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUHdGltZUtleQAABAxjbGFpbWVkQWNyZXMJARJjbGFpbUFjcmVzSW50ZXJuYWwDBQdhZGRyZXNzBQthY3Jlc0Ftb3VudAUIbGFzdFRpbWUJAJQKAgUDbmlsCQDMCAIFDGNsYWltZWRBY3JlcwkAzAgCBQhsYXN0VGltZQUDbmlsAWkBC2NsYWltUHJvbW8yAAQMcHJvbG9nUmVzdWx0CQEGcHJvbG9nAAMJAAACBQxwcm9sb2dSZXN1bHQFDHByb2xvZ1Jlc3VsdAQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAAJAAIBAhRObyBwYXltZW50cyByZXF1aXJlZAQDbm93CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAMJAGYCBRVQUk9NT18yX0VORF9USU1FU1RBTVAFA25vdwkAAgECF1Byb21vIDIgaXMgbm90IG92ZXIgeWV0BAphd2FyZGVkS2V5CQEaa2V5SXNBd2FyZGVkQnlQcm9tb0FuZFVzZXICAAIFB2FkZHJlc3MDCQELdmFsdWVPckVsc2UCCQCgCAEFCmF3YXJkZWRLZXkHCQACAQkArAICCQCsAgICDFlvdXIgd2FsbGV0IAUHYWRkcmVzcwIeIGlzIGFscmVhZHkgYXdhcmRlZCBpbiBwcm9tbyAyBAlwcm9tbzJNYXAJAQt2YWx1ZU9yRWxzZQIJAKIIAQUMcHJvbW8yTWFwS2V5AgADCQEBIQEJAQhjb250YWlucwIFCXByb21vMk1hcAUHYWRkcmVzcwkAAgECIllvdSBhcmUgbm90IHBhcnRpY2lwYW50IG9mIHByb21vIDIEBXBhcnRzCQC9CQIFCXByb21vMk1hcAUHYWRkcmVzcwQLYWNyZXNBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkArwICCQCwAgIJAJEDAgUFcGFydHMAAQABAA4EB3RpY2tldHMJAGkCBQthY3Jlc0Ftb3VudAUdTUlOX0FDUkVTX0FNT1VOVF9EVVJJTkdfUFJPTU8EC3RvdGFsVGlrZXRzCQELdmFsdWVPckVsc2UCCQCfCAEJARZrZXlUaWNrZXRzVG90YWxCeVByb21vAQACAAAEDSR0MDEyMzgxMTI4MjEDCQAAAgULdG90YWxUaWtldHMAAAoBDGNvdW50VGlja2V0cwIDYWNjAmVsCQBkAgUDYWNjCQBpAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIJALUJAgUCZWwCAToAAQUdTUlOX0FDUkVTX0FNT1VOVF9EVVJJTkdfUFJPTU8EDHRpY2tldHNDb3VudAoAAiRsCQC9CQIFCXByb21vMk1hcAIBXwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEMY291bnRUaWNrZXRzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyA1MAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQAFQAWABcAGAAZABoAGwAcAB0AHgAfACAAIQAiACMAJAAlACYAJwAoACkAKgArACwALQAuAC8AMAAxADIJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFmtleVRpY2tldHNUb3RhbEJ5UHJvbW8BAAIFDHRpY2tldHNDb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBHmtleVRpY2tldHNUb3RhbEJ5UHJvbW9BbmRSb3VuZAIAAgABBQx0aWNrZXRzQ291bnQFA25pbAUMdGlja2V0c0NvdW50CQCUCgIFA25pbAULdG90YWxUaWtldHMEDnRpY2tldHNBY3Rpb25zCAUNJHQwMTIzODExMjgyMQJfMQQKdG90YWxDb3VudAgFDSR0MDEyMzgxMTI4MjECXzIEBWF3YXJkCQBrAwUZUFJPTU9fMl9ESVNUUklCVVRJT05fRlVORAUHdGlja2V0cwUKdG90YWxDb3VudAQLc3Rha2VSZXN1bHQJAPwHBAUEdGhpcwIPc2VuZExvY2tlZEFjcmVzCQDMCAIFB2FkZHJlc3MJAMwIAgUFYXdhcmQJAMwIAgAeBQNuaWwFA25pbAkAlAoCCQDNCAIJAM0IAgUOdGlja2V0c0FjdGlvbnMJAQxCb29sZWFuRW50cnkCBQphd2FyZGVkS2V5BgkBC1N0cmluZ0VudHJ5AgkBFGtleVByb21vMk1hcEZvclJvdW5kAQABBQlwcm9tbzJNYXAFC3N0YWtlUmVzdWx0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFGNvbW1pdEZvclByb21vMlJvdW5kAQdyb3VuZElkAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIRUGVybWlzc2lvbiBkZW5pZWQDAwkAZgIAAQUHcm91bmRJZAYJAGYCBQdyb3VuZElkAAQJAAIBCQCsAgICEUludmFsaWQgcm91bmRJZDogCQCkAwEFB3JvdW5kSWQEC2ZpbmlzaEJsb2NrCQBkAgUGaGVpZ2h0BQtyYW5kb21EZWxheQkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEJa2V5Q29tbWl0AQkArAICAgIyXwkApAMBBQdyb3VuZElkBQtmaW5pc2hCbG9jawUDbmlsBQtmaW5pc2hCbG9jawFpAQ9kcmF3UHJvbW8yUm91bmQBB3JvdW5kSWQDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhFQZXJtaXNzaW9uIGRlbmllZAMDCQBmAgABBQdyb3VuZElkBgkAZgIFB3JvdW5kSWQABAkAAgEJAKwCAgIRSW52YWxpZCByb3VuZElkOiAJAKQDAQUHcm91bmRJZAQJZmluaXNoS2V5CQEJa2V5Q29tbWl0AQkArAICAgIyXwkApAMBBQdyb3VuZElkBAtmaW5pc2hCbG9jawkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFCWZpbmlzaEtleQkArAICCQCsAgICIVlvdSBoYXZlIHRvIGNvbW1pdEZvclByb21vMlJvdW5kKAkApAMBBQdyb3VuZElkAggpIGZpcnN0IQMJAGYCBQtmaW5pc2hCbG9jawUGaGVpZ2h0CQACAQkArAICCQCsAgIJAKwCAgkArAICAjRSYW5kb20gbnVtYmVyIGlzIG5vdCByZWFkeSB5ZXQsIHdhaXQgdW50aWwgaGVpZ2h0ID0gCQCkAwEFC2ZpbmlzaEJsb2NrAhMgKGN1cnJlbnQgaGVpZ2h0ID0gCQCkAwEFBmhlaWdodAIBKQQIbWF4VmFsdWUJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBHmtleVRpY2tldHNUb3RhbEJ5UHJvbW9BbmRSb3VuZAIAAgUHcm91bmRJZAAAAwkAAAIFCG1heFZhbHVlAAAJAAIBAidQbGVhc2UgY2FsbCBjbGFpbVByb21vMigpIGF0IGxlYXN0IG9uY2UEB2VudHJvcHkJAQV2YWx1ZQEICQEFdmFsdWUBCQDtBwEFC2Zp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", "height": 2862256, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6S6WPYt6hPANHCPzTeRSQJC1KxobjcrtxwqZf8WzMgSQ Next: KDZbuaYuM5yQNSeet7Nq97R8X9KckCCFTc8fBaf6Nv1 Diff:
OldNewDifferences
435435 let bx = c(d)
436436 let by = valueOrElse(getInteger(bx), 0)
437437 let bC = valueOrElse(getInteger(g), 0)
438- let bO = valueOrElse(getInteger(bw), bi)
438+ let bO = if (isDefined(getInteger(bw)))
439+ then nil
440+ else [IntegerEntry(bw, bi)]
439441 let bP = f(d)
440442 let bQ = e(d)
441443 let bR = valueOrElse(getInteger(bQ), 0)
442444 let bS = valueOrElse(getInteger(bP), 0)
443445 let bT = bd(bR, bS, bu, (bi + (bN * b)))
444- $Tuple2([IntegerEntry(bw, bO), IntegerEntry(bx, (by + bu)), IntegerEntry(g, (bC + bu)), IntegerEntry(bP, bT), IntegerEntry(bQ, (bR + bu))], bu)
446+ $Tuple2(((((bO :+ IntegerEntry(bx, (by + bu))) :+ IntegerEntry(g, (bC + bu))) :+ IntegerEntry(bP, bT)) :+ IntegerEntry(bQ, (bR + bu))), bu)
445447 }
446448
447449
622624 }
623625 let cp = co._3
624626 if ((cp == ""))
625- then throw("no winner")
627+ then cj
626628 else {
627629 let cq = split_51C(cj._3, cp)
628630 let cr = if ((cq[0] == ""))
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = 100000000000000
55
66 let b = 86400000
77
88 func c (d) = ("acresStakedAmountByUser_" + d)
99
1010
1111 func e (d) = ("acresLockedAmountByUser_" + d)
1212
1313
1414 func f (d) = ("acresLockedEtaByUser_" + d)
1515
1616
1717 let g = "acresStakedAmountTotal"
1818
1919 let h = 5000000
2020
2121 let i = 3456000
2222
2323 let j = 10
2424
2525 func k (l,d) = makeString(["%s%d%s__isAwardedByPromoAndUser", toString(l), d], "__")
2626
2727
2828 func m (l) = ("%s%d__ticketsTotalByPromo__" + toString(l))
2929
3030
3131 func n (l,o) = makeString(["%s%d%d__ticketsTotalByPromoAndRound", toString(l), toString(o)], "__")
3232
3333
3434 let p = take(drop(this.bytes, 1), 1)
3535
3636 let q = {
3737 let r = p
3838 if ((base58'2W' == r))
3939 then base58'9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi'
4040 else if ((base58'2T' == r))
4141 then base58'6mWwf9mZBjVgkC54idpyaZLQfAosD914wT8fGf2iiY63'
4242 else throw("Unknown chain")
4343 }
4444
4545 let s = {
4646 let r = p
4747 if ((base58'2W' == r))
4848 then "3PQCuvFbvh4LkPUnrnU1z3jnbA1p9m3WNhv"
4949 else if ((base58'2T' == r))
5050 then "3MumkGGztCKAXpWDqxkddofqXSUbqQkvSJy"
5151 else throw("Unknown chain")
5252 }
5353
5454 let t = "promo2Map"
5555
5656 func u (o) = ("promo2MapForRound__" + toString(o))
5757
5858
5959 let v = "__"
6060
6161 let w = 1000000
6262
6363 let x = 100000000
6464
6565 let y = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
6666
6767 func z (A,B) = valueOrErrorMessage(getString(A, B), makeString(["mandatory ", toString(A), ".", B, " is not defined"], ""))
6868
6969
7070 let C = 1
7171
7272 let D = 2
7373
7474 let E = 4
7575
7676 let F = 8
7777
7878 func G () = "%s__restConfig"
7979
8080
8181 func H () = "%s__restAddr"
8282
8383
8484 func I (J) = split_4C(z(J, G()), v)
8585
8686
8787 func K (L,M) = valueOrErrorMessage(addressFromString(L[M]), ("Rest cfg doesn't contain address at index " + toString(M)))
8888
8989
9090 let N = addressFromStringValue(valueOrElse(getString(this, H()), s))
9191
9292 let L = I(N)
9393
9494 let O = K(L, C)
9595
9696 let P = K(L, D)
9797
9898 let Q = K(L, E)
9999
100100 let R = K(L, F)
101101
102102 let S = "acresIssuedAmount"
103103
104104 let T = "acresAssetId"
105105
106106 let U = valueOrErrorMessage(getBinary(R, T), "ACRES is not issued yet")
107107
108108 func V (d) = ("acresStakedTimeByUser_" + d)
109109
110110
111111 let W = 0
112112
113113 let X = 2
114114
115115 func Y (A) = ("finishBlockFor_" + A)
116116
117117
118118 func Z () = "resTypesProportions"
119119
120120
121121 func aa (ab) = ("stakedPiecesByOwner_" + ab)
122122
123123
124124 func ac (ad) = {
125125 let r = ad
126126 if ($isInstanceOf(r, "Int"))
127127 then {
128128 let ae = r
129129 ae
130130 }
131131 else throw("fail to cast into Int")
132132 }
133133
134134
135135 func af (ag) = {
136136 let r = ag
137137 if ($isInstanceOf(r, "(Int, Int)"))
138138 then {
139139 let ah = r
140140 ah
141141 }
142142 else throw("fail to cast into (Int, Int)")
143143 }
144144
145145
146146 func ai (d) = ("lastTxIdByUser_" + d)
147147
148148
149149 func aj (ak) = {
150150 let al = split(valueOrElse(getString(O, Z()), "0_0_0_0_0_0"), "_")
151151 func am (an,ao) = (an + parseIntValue(ao))
152152
153153 let ap = {
154154 let aq = al
155155 let ar = size(aq)
156156 let as = 0
157157 func at (au,av) = if ((av >= ar))
158158 then au
159159 else am(au, aq[av])
160160
161161 func aw (au,av) = if ((av >= ar))
162162 then au
163163 else throw("List size exceeds 6")
164164
165165 aw(at(at(at(at(at(at(as, 0), 1), 2), 3), 4), 5), 6)
166166 }
167167 let ax = valueOrElse(getInteger(O, aa(ak)), 0)
168168 [ap, ax]
169169 }
170170
171171
172172 func ay (ag,az) = {
173173 let aA = pow(10, 0, az, 0, 0, DOWN)
174174 let aB = toString((ag % aA))
175175 let aC = drop(toString(aA), (1 + size(aB)))
176176 (((toString((ag / aA)) + ".") + aC) + aB)
177177 }
178178
179179
180180 func aD (ag,aE) = {
181181 let aF = toString(ag)
182182 let aC = drop(toString(pow(10, 0, (aE - size(aF)), 0, 0, DOWN)), 1)
183183 (aC + aF)
184184 }
185185
186186
187187 func aG (aH,aI,aJ) = if ((0 >= aH))
188188 then throw("maxValue should be > 0")
189189 else {
190190 let aK = sha256((aI + aJ))
191191 (toInt(aK) % aH)
192192 }
193193
194194
195195 let aL = 10000000
196196
197197 let aM = "3P2NGX4Q5nge1MCauwQW5aqYLdkccSGj1Ep_3P2xFAHW9yhyNohYozWd4HFhEXZu3bsNSoR_3P2yKaZ2gvn9Xe5tti81a7P9LZhHgjvToV9_3P37zQ3cf2ecu55RmJqEiGSivdzN9avt3m9_3P4az6dtzsvGCWFAxa94UdevKzXyEwxEiFG_3P4kZU6X3TTLFcSUe55JSy8BySqitcPgMBz_3P5hCxBEh3NgNizZhNBreyBSqtbhJYLkKPD_3P7HLvucy11yxyMJUwjzXFHHKMEDwi1EwfC_3P8JuaqH9PTQAv8D5HBGgQfKauLTYt2NQft_3P9gTDB4rtDEVbpX3asU63H4Zinh2EnTmZE_3P9iN3qrtfJicUVy7amZeVsetVD3vUMk8be_3PCa2BsAa6JBLirszQfV5r9fJrujfhwtwfP_3PD3i4XN8KtygcFx4ry5M7UGqdfH8VYvtRT_3PDEMnnJNc2kx9cPEmvVvhXUr8SvhANKhsa_3PDGE9tKQizaeZFeDDq5aYSv89nwYbfirpZ_3PDMKQTCrUPZECVXEJJ8m1sHtutSu1naSf1_3PGh2Qu6Yvx8GTCRRVNvBUVZLdaidYSaxo5_3PKkmAtbSK5D2hQdo1RfEg8eXyMbDcRUc92_3PLMnbxzssP8W8E8XjJ1RLBBg8UZL8Cz3P2_3PMuxo4PCAox9s4a7R1eszh4iqqu8gS7jHv_3PNrMtEQChw87WZU1JAJ7aGHykCa8TjnDNK_3PPuBXfWoBy3EEory7c7vgi9Usjka7o5tBj_3PQwyeyEhT4Y6aGAL6tg73aQWJtV1zRt3nR_3PRGDShuMGb84MJtTJvtTg8qDfswkYWcm3e"
198198
199199 let aN = 4970178
200200
201201 let aO = {
202202 let r = p
203203 if ((base58'2W' == r))
204204 then 1700524800000
205205 else if ((base58'2T' == r))
206206 then 1700420400000
207207 else throw("Unknown chain")
208208 }
209209
210210 let aP = {
211211 let r = p
212212 if ((base58'2W' == r))
213213 then 1701043199999
214214 else if ((base58'2T' == r))
215215 then 1700496000000
216216 else throw("Unknown chain")
217217 }
218218
219219 let aQ = 1000000000
220220
221221 let aR = [1, 3, 5, 20]
222222
223223 let aS = [500000000, 200000000, 100000000, 20000000]
224224
225225 func aT (d) = contains(aM, d)
226226
227227
228228 func aU () = ac(reentrantInvoke(O, "saveLastTx", nil, nil))
229229
230230
231231 func aV (d,aW,aX) = {
232232 let aY = (lastBlock.timestamp - aX)
233233 let aZ = fraction(aY, (i * aW), (b * x))
234234 let ba = ac(invoke(P, "sellResourcesWorldREADONLY", [aZ], nil))
235235 let bb = max([0, ba])
236236 (bb * j)
237237 }
238238
239239
240240 func bc (d,aW,aX) = {
241241 let aY = (lastBlock.timestamp - aX)
242242 if ((0 > aY))
243243 then throw(((("Saved timestamp is in future, saved = " + toString(aX)) + ", current = ") + toString(lastBlock.timestamp)))
244244 else {
245245 let aZ = fraction(aY, (i * aW), (b * x))
246246 let ba = ac(invoke(P, "sellResourcesWorldREADONLY", [aZ], nil))
247247 let bb = if ((0 >= ba))
248248 then 0
249249 else af(invoke(P, "sellResourcesWorld", [d, aZ], nil))._1
250250 (bb * j)
251251 }
252252 }
253253
254254
255255 func bd (be,bf,bg,bh) = {
256256 let bi = lastBlock.timestamp
257257 let bj = max([0, (bf - bi)])
258258 let bk = max([0, (bh - bi)])
259259 let bl = (be + bg)
260260 let bm = if ((bl == 0))
261261 then 0
262262 else (fraction(bj, be, bl) + fraction(bk, bg, bl))
263263 (bi + bm)
264264 }
265265
266266
267267 @Callable(bn)
268268 func constructorV1 (bo,bp) = if ((bn.caller != this))
269269 then throw("Permission denied")
270270 else if (isDefined(getBinary(T)))
271271 then throw("Already initialized")
272272 else {
273273 let bq = (aj("")[W] + bp)
274274 let br = (a - (bq * x))
275275 let bs = Issue("ACRES", "WavesLands land acres investment token", br, 8, false, unit, 0)
276276 let bt = calculateAssetId(bs)
277277 [bs, IntegerEntry(S, br), BinaryEntry(T, bt), StringEntry(H(), bo)]
278278 }
279279
280280
281281
282282 @Callable(bn)
283283 func unstakeAcres (bu) = {
284284 let bv = aU()
285285 if ((bv == bv))
286286 then if ((0 >= bu))
287287 then throw("Amount should be positive")
288288 else {
289289 let A = toString(bn.caller)
290290 if ((size(bn.payments) != 0))
291291 then throw("No payments required")
292292 else {
293293 let bw = V(A)
294294 let bx = c(A)
295295 let by = valueOrElse(getInteger(bx), 0)
296296 if ((bu > by))
297297 then throw(((("You have only " + ay(by, 8)) + " ACRES staked, tried to unstake ") + ay(bu, 8)))
298298 else {
299299 let bz = valueOrElse(getInteger(e(A)), 0)
300300 let bA = valueOrElse(getInteger(f(A)), 0)
301301 let bi = lastBlock.timestamp
302302 if (if ((bi >= aO))
303303 then (aP >= bi)
304304 else false)
305305 then throw("You cannot unstake ACRES during Promo2")
306306 else {
307307 let bB = if (aT(A))
308308 then ((by - bz) - aN)
309309 else (by - bz)
310310 if (if ((bA > bi))
311311 then (bu > bB)
312312 else false)
313313 then throw(((("Only " + ay(bB, 8)) + " ACRES can be unstaked now, wait until ") + toString(bA)))
314314 else {
315315 let bC = valueOrElse(getInteger(g), 0)
316316 let bD = invoke(Q, "onStakeUnstakeLand", [A], nil)
317317 let bE = bc(A, by, valueOrElse(getInteger(bw), 0))
318318 $Tuple2([IntegerEntry(bw, lastBlock.timestamp), IntegerEntry(bx, (by - bu)), IntegerEntry(g, (bC - bu)), ScriptTransfer(bn.caller, (bu + bE), U)], $Tuple2(bv, bD))
319319 }
320320 }
321321 }
322322 }
323323 }
324324 else throw("Strict value is not equal to itself.")
325325 }
326326
327327
328328
329329 @Callable(bn)
330330 func stakeAcres () = {
331331 let bv = aU()
332332 if ((bv == bv))
333333 then {
334334 let A = toString(bn.caller)
335335 if ((size(bn.payments) != 1))
336336 then throw("exactly 1 payment must be attached")
337337 else {
338338 let bF = bn.payments[0]
339339 let bG = bF.amount
340340 if (if (!(isDefined(bF.assetId)))
341341 then true
342342 else (value(bF.assetId) != U))
343343 then throw("ACRES payments only!")
344344 else {
345345 let bD = invoke(Q, "onStakeUnstakeLand", [A], nil)
346346 if ((bD == bD))
347347 then {
348348 let bi = lastBlock.timestamp
349349 if (if ((aO > bi))
350350 then true
351351 else (bi > aP))
352352 then {
353353 let bw = V(A)
354354 let bx = c(A)
355355 let by = valueOrElse(getInteger(bx), 0)
356356 let bC = valueOrElse(getInteger(g), 0)
357357 let bE = bc(A, by, valueOrElse(getInteger(bw), 0))
358358 $Tuple2(((((if ((bE == 0))
359359 then nil
360360 else [ScriptTransfer(bn.caller, bE, U)]) :+ IntegerEntry(bw, lastBlock.timestamp)) :+ IntegerEntry(bx, (by + bG))) :+ IntegerEntry(g, (bC + bG))), $Tuple2(bv, bD))
361361 }
362362 else if ((aL > bG))
363363 then throw((("Min staked amount during promo action should be at least " + ay(aL, 8)) + " ACRES"))
364364 else {
365365 let bH = invoke(this, "sendLockedAcres", [A, bG, 30], nil)
366366 let bI = valueOrElse(getString(t), "")
367367 let bJ = if (contains(bI, A))
368368 then {
369369 let bK = split_51C(bI, A)
370370 let be = parseIntValue(take(drop(bK[1], 1), 14))
371371 ((((bK[0] + A) + ":") + aD((be + bG), 14)) + drop(bK[1], 15))
372372 }
373373 else {
374374 let bL = ((A + ":") + aD(bG, 14))
375375 if ((bI == ""))
376376 then bL
377377 else ((bI + "_") + bL)
378378 }
379379 $Tuple2([StringEntry(t, bJ)], $Tuple3(bv, bD, bH))
380380 }
381381 }
382382 else throw("Strict value is not equal to itself.")
383383 }
384384 }
385385 }
386386 else throw("Strict value is not equal to itself.")
387387 }
388388
389389
390390
391391 @Callable(bn)
392392 func buyAcres () = {
393393 let bv = aU()
394394 if ((bv == bv))
395395 then {
396396 let A = toString(bn.caller)
397397 if ((size(bn.payments) != 1))
398398 then throw("exactly 1 payment must be attached")
399399 else {
400400 let bF = bn.payments[0]
401401 let bG = bF.amount
402402 if (if (!(isDefined(bF.assetId)))
403403 then true
404404 else (value(bF.assetId) != q))
405405 then throw("USDT payments only!")
406406 else if ((w > bG))
407407 then throw((("Min payment should be " + ay(w, 6)) + " USDT"))
408408 else {
409409 let aW = (bG * j)
410410 let bM = ac(invoke(O, "updateAccStats", [A, fraction(h, aW, (25 * x))], nil))
411411 $Tuple2([ScriptTransfer(P, bG, q), ScriptTransfer(bn.caller, aW, U)], $Tuple2(bv, bM))
412412 }
413413 }
414414 }
415415 else throw("Strict value is not equal to itself.")
416416 }
417417
418418
419419
420420 @Callable(bn)
421421 func sendAcres (d,bu) = if ((bn.caller != P))
422422 then throw("Permission denied")
423423 else $Tuple2([ScriptTransfer(addressFromStringValue(d), bu, U)], bu)
424424
425425
426426
427427 @Callable(bn)
428428 func sendLockedAcres (d,bu,bN) = if (if ((bn.caller != this))
429429 then (bn.caller != N)
430430 else false)
431431 then throw("Permission denied")
432432 else {
433433 let bi = lastBlock.timestamp
434434 let bw = V(d)
435435 let bx = c(d)
436436 let by = valueOrElse(getInteger(bx), 0)
437437 let bC = valueOrElse(getInteger(g), 0)
438- let bO = valueOrElse(getInteger(bw), bi)
438+ let bO = if (isDefined(getInteger(bw)))
439+ then nil
440+ else [IntegerEntry(bw, bi)]
439441 let bP = f(d)
440442 let bQ = e(d)
441443 let bR = valueOrElse(getInteger(bQ), 0)
442444 let bS = valueOrElse(getInteger(bP), 0)
443445 let bT = bd(bR, bS, bu, (bi + (bN * b)))
444- $Tuple2([IntegerEntry(bw, bO), IntegerEntry(bx, (by + bu)), IntegerEntry(g, (bC + bu)), IntegerEntry(bP, bT), IntegerEntry(bQ, (bR + bu))], bu)
446+ $Tuple2(((((bO :+ IntegerEntry(bx, (by + bu))) :+ IntegerEntry(g, (bC + bu))) :+ IntegerEntry(bP, bT)) :+ IntegerEntry(bQ, (bR + bu))), bu)
445447 }
446448
447449
448450
449451 @Callable(bn)
450452 func burnAcres (bu) = if ((bn.caller != O))
451453 then throw("Permission denied")
452454 else {
453455 let bU = (valueOrElse(getInteger(S), 0) - bu)
454456 if ((0 > bU))
455457 then throw("Attempt to burn more ACRES, than exists")
456458 else $Tuple2([Burn(U, bu), IntegerEntry(S, bU)], bu)
457459 }
458460
459461
460462
461463 @Callable(bn)
462464 func claimAcres () = {
463465 let bv = aU()
464466 if ((bv == bv))
465467 then {
466468 let A = toString(bn.caller)
467469 if ((size(bn.payments) != 0))
468470 then throw("No payments required")
469471 else {
470472 let bw = V(A)
471473 let bx = c(A)
472474 let aW = valueOrElse(getInteger(bx), 0)
473475 let bD = invoke(Q, "onStakeUnstakeLand", [A], nil)
474476 let bE = bc(A, aW, valueOrElse(getInteger(bw), 0))
475477 $Tuple2([IntegerEntry(bw, lastBlock.timestamp), ScriptTransfer(bn.caller, bE, U)], $Tuple2(bv, bD))
476478 }
477479 }
478480 else throw("Strict value is not equal to itself.")
479481 }
480482
481483
482484
483485 @Callable(bn)
484486 func claimAcresREADONLY (A) = {
485487 let bw = V(A)
486488 let bx = c(A)
487489 let aW = valueOrElse(getInteger(bx), 0)
488490 let bV = valueOrElse(getInteger(bw), 0)
489491 let bE = aV(A, aW, bV)
490492 $Tuple2(nil, [bE, bV])
491493 }
492494
493495
494496
495497 @Callable(bn)
496498 func claimPromo2 () = {
497499 let bv = aU()
498500 if ((bv == bv))
499501 then {
500502 let A = toString(bn.caller)
501503 if ((size(bn.payments) != 0))
502504 then throw("No payments required")
503505 else {
504506 let bi = lastBlock.timestamp
505507 if ((aP > bi))
506508 then throw("Promo 2 is not over yet")
507509 else {
508510 let bW = k(2, A)
509511 if (valueOrElse(getBoolean(bW), false))
510512 then throw((("Your wallet " + A) + " is already awarded in promo 2"))
511513 else {
512514 let bI = valueOrElse(getString(t), "")
513515 if (!(contains(bI, A)))
514516 then throw("You are not participant of promo 2")
515517 else {
516518 let bK = split_51C(bI, A)
517519 let aW = parseIntValue(take(drop(bK[1], 1), 14))
518520 let bX = (aW / aL)
519521 let bY = valueOrElse(getInteger(m(2)), 0)
520522 let bZ = if ((bY == 0))
521523 then {
522524 func ca (an,cb) = (an + (parseIntValue(split(cb, ":")[1]) / aL))
523525
524526 let cc = {
525527 let aq = split_51C(bI, "_")
526528 let ar = size(aq)
527529 let as = 0
528530 func at (au,av) = if ((av >= ar))
529531 then au
530532 else ca(au, aq[av])
531533
532534 func aw (au,av) = if ((av >= ar))
533535 then au
534536 else throw("List size exceeds 50")
535537
536538 aw(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(as, 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), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40), 41), 42), 43), 44), 45), 46), 47), 48), 49), 50)
537539 }
538540 $Tuple2([IntegerEntry(m(2), cc), IntegerEntry(n(2, 1), cc)], cc)
539541 }
540542 else $Tuple2(nil, bY)
541543 let cd = bZ._1
542544 let ce = bZ._2
543545 let cf = fraction(aQ, bX, ce)
544546 let bH = invoke(this, "sendLockedAcres", [A, cf, 30], nil)
545547 $Tuple2(((cd :+ BooleanEntry(bW, true)) :+ StringEntry(u(1), bI)), bH)
546548 }
547549 }
548550 }
549551 }
550552 }
551553 else throw("Strict value is not equal to itself.")
552554 }
553555
554556
555557
556558 @Callable(bn)
557559 func commitForPromo2Round (o) = if ((bn.caller != this))
558560 then throw("Permission denied")
559561 else if (if ((1 > o))
560562 then true
561563 else (o > 4))
562564 then throw(("Invalid roundId: " + toString(o)))
563565 else {
564566 let cg = (height + X)
565567 $Tuple2([IntegerEntry(Y(("2_" + toString(o))), cg)], cg)
566568 }
567569
568570
569571
570572 @Callable(bn)
571573 func drawPromo2Round (o) = if ((bn.caller != this))
572574 then throw("Permission denied")
573575 else if (if ((1 > o))
574576 then true
575577 else (o > 4))
576578 then throw(("Invalid roundId: " + toString(o)))
577579 else {
578580 let ch = Y(("2_" + toString(o)))
579581 let cg = valueOrErrorMessage(getInteger(ch), (("You have to commitForPromo2Round(" + toString(o)) + ") first!"))
580582 if ((cg > height))
581583 then throw((((("Random number is not ready yet, wait until height = " + toString(cg)) + " (current height = ") + toString(height)) + ")"))
582584 else {
583585 let aH = valueOrElse(getInteger(n(2, o)), 0)
584586 if ((aH == 0))
585587 then throw("Please call claimPromo2() at least once")
586588 else {
587589 let aJ = value(value(blockInfoByHeight(cg)).vrf)
588590 let aI = bn.transactionId
589591 let bI = valueOrElse(getString(u(o)), "")
590592 func ci (cj,ck) = if ((ck >= aR[(o - 1)]))
591593 then cj
592594 else {
593595 let cl = aG(cj._1, cj._2, aJ)
594596 let cm = if ((cj._3 == ""))
595597 then nil
596598 else split_51C(cj._3, "_")
597599 func ca (an,cb) = {
598600 let bK = split(cb, ":")
599601 let d = bK[0]
600602 let bX = (parseIntValue(bK[1]) / aL)
601603 let cn = (an._1 + bX)
602604 if (if ((an._3 == ""))
603605 then (cn > cl)
604606 else false)
605607 then $Tuple3(cn, bX, d)
606608 else $Tuple3(cn, an._2, an._3)
607609 }
608610
609611 let co = {
610612 let aq = cm
611613 let ar = size(aq)
612614 let as = $Tuple3(0, 0, "")
613615 func at (au,av) = if ((av >= ar))
614616 then au
615617 else ca(au, aq[av])
616618
617619 func aw (au,av) = if ((av >= ar))
618620 then au
619621 else throw("List size exceeds 50")
620622
621623 aw(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(as, 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), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40), 41), 42), 43), 44), 45), 46), 47), 48), 49), 50)
622624 }
623625 let cp = co._3
624626 if ((cp == ""))
625- then throw("no winner")
627+ then cj
626628 else {
627629 let cq = split_51C(cj._3, cp)
628630 let cr = if ((cq[0] == ""))
629631 then drop(cq[1], 16)
630632 else (dropRight(cq[0], 1) + drop(cq[1], 15))
631633 let bH = invoke(this, "sendLockedAcres", [cp, aS[(o - 1)], 30], nil)
632634 $Tuple4((cj._1 - co._2), fromBase58String(getStringValue(O, ai(cp))), cr, (cj._4 :+ bH))
633635 }
634636 }
635637
636638 let cs = {
637639 let aq = y
638640 let ar = size(aq)
639641 let as = $Tuple4(aH, bn.transactionId, bI, nil)
640642 func at (au,av) = if ((av >= ar))
641643 then au
642644 else ci(au, aq[av])
643645
644646 func aw (au,av) = if ((av >= ar))
645647 then au
646648 else throw("List size exceeds 20")
647649
648650 aw(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(at(as, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
649651 }
650652 $Tuple2([DeleteEntry(ch), StringEntry(u((o + 1)), cs._3), IntegerEntry(n(2, (o + 1)), cs._1)], cs._4)
651653 }
652654 }
653655 }
654656
655657

github/deemru/w8io/169f3d6 
73.82 ms