tx · avHZfkwH5ktSVWnNDoJDQPTGnAR7kSgnbtxj1GfZotm

3PAi1ePLQrYrY3jj9omBtT6isMkZsapbmks:  -0.01600000 Waves

2023.02.14 12:25 [3514695] smart account 3PAi1ePLQrYrY3jj9omBtT6isMkZsapbmks > SELF 0.00000000 Waves

{ "type": 13, "id": "avHZfkwH5ktSVWnNDoJDQPTGnAR7kSgnbtxj1GfZotm", "fee": 1600000, "feeAssetId": null, "timestamp": 1676366737346, "version": 2, "chainId": 87, "sender": "3PAi1ePLQrYrY3jj9omBtT6isMkZsapbmks", "senderPublicKey": "XrNmTusDFaLSz3wAjmdfcyC5h6uYyVbpdh18758UpFv", "proofs": [ "29z5R8uUnboNCQobXhxDmxpFbasXiAGeL9wQCVRip87s9GCSBqXRXJQPPqJn723sdsa5c2bFPiUNieYwiDFvbob4" ], "script": "base64:BgJMCAISAwoBCBIECgIBCBIECgIBCBIDCgEIEgMKAQgSBAoCCAgSBQoDCAEBEgMKAQgSABIAEgASBAoCCAgSAwoBARIAEgMKAQESAwoBCCsBF3N0YXRpY0tleV9vcmFjbGVBZGRyZXNzAAIUc3RhdGljX29yYWNsZUFkZHJlc3MBGHN0YXRpY0tleV9icmVlZGVyQWRkcmVzcwACFXN0YXRpY19icmVlZGVyQWRkcmVzcwEUc3RhdGljS2V5X2VnZ0Fzc2V0SWQAAhFzdGF0aWNfZWdnQXNzZXRJZAEac3RhdGljS2V5X3RydXN0ZWRDb250cmFjdHMAAhdzdGF0aWNfdHJ1c3RlZENvbnRyYWN0cwEYc3RhdGljS2V5X3JlYmlydGhBZGRyZXNzAAIVc3RhdGljX3JlYmlydGhBZGRyZXNzARFrZXlfYXJ0ZWZhY3RPd25lcgIMYXJ0ZWZhY3ROYW1lBW93bmVyCQCsAgIJAKwCAgkArAICBQxhcnRlZmFjdE5hbWUCAV8FBW93bmVyAgZfb3duZXIBEWtleV91bnN0YWtlSGVpZ2h0AgxhcnRlZmFjdE5hbWUKYXJ0ZWZhY3RJZAkArAICCQCsAgIJAKwCAgUMYXJ0ZWZhY3ROYW1lAgFfBQphcnRlZmFjdElkAg9fdW5zdGFrZV9oZWlnaHQBFWtleV9leHRlcm5hbEJvb3N0RHVjawEGZHVja0lkCQCsAgIFBmR1Y2tJZAIUX2R1Y2tfZXh0ZXJuYWxfYm9vc3QBGGtleV9leHRlcm5hbEJvb3N0QWRkcmVzcwEHYWRkcmVzcwkArAICBQdhZGRyZXNzAhRfdXNlcl9leHRlcm5hbF9ib29zdAERa2V5X3ByaWNlQ29zbWV0aWMBBGl0ZW0JAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQEUa2V5X21heFNhbGVzQ29zbWV0aWMBBGl0ZW0JAKwCAgkArAICAhBkaXJlY3RfY29zbWV0aWNfBQRpdGVtAgpfbWF4X3NhbGVzARBrZXlfc2FsZUNvc21ldGljAQRpdGVtCQCsAgIJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQIFX3NhbGUBFmtleV9wcmljZUFzc2V0Q29zbWV0aWMBBGl0ZW0JAKwCAgkArAICAhBkaXJlY3RfY29zbWV0aWNfBQRpdGVtAgtfcHJpY2VBc3NldAEaa2V5X2dyb3dQZXJjZW50YWdlQ29zbWV0aWMBBGl0ZW0JAKwCAgkArAICAhBkaXJlY3RfY29zbWV0aWNfBQRpdGVtAhNfZ3Jvd2luZ19wZXJjZW50YWdlARBrZXlfc29sZENvc21ldGljAQRpdGVtCQCsAgIJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQIFX3NvbGQBFWtleV9sYXN0UHJpY2VDb3NtZXRpYwEEaXRlbQkArAICCQCsAgICEGRpcmVjdF9jb3NtZXRpY18FBGl0ZW0CC19sYXN0X3ByaWNlARNrZXlfc3RhcnRUc0Nvc21ldGljAQRpdGVtCQCsAgIJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQIIX3N0YXJ0VHMBEWtleV9lbmRUc0Nvc21ldGljAQRpdGVtCQCsAgIJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQIGX2VuZFRzARdrZXlfcHJvY2Vzc0ZpbmlzaEhlaWdodAIHYWRkcmVzcwR0eElkCQCsAgIJAKwCAgkArAICBQdhZGRyZXNzAgFfCQDYBAEFBHR4SWQCA19maAAKZGV2QWRkcmVzcwEaAVcXd9hCTyE6CkZPy+KvhiJrE5znW6fefHsACmVnZ3NOZWVkZWQJAGgCAAMAgMLXLwAOYXJ0ZWZhY3RzTGltaXQJAGQCAK0CANgEAAlmcmVlR2VuZXMJAMwIAgIBQQkAzAgCAgFCCQDMCAICAUMJAMwIAgIBRAkAzAgCAgFFCQDMCAICAUYFA25pbAAMb2xkQXJ0ZWZhY3RzCQDMCAICCEFSVC1MQUtFCQDMCAICCUFSVC1IT1VTRQkAzAgCAgxBUlQtQklHSE9VU0UJAMwIAgILQVJULUZJWEdFTkUJAMwIAgIMQVJULUZSRUVHRU5FCQDMCAICCkFSVC1NSVJST1IJAMwIAgIIQVJULVBPTVAJAMwIAgIIQVJULUNBUEUJAMwIAgIHQVJULUhBVAkAzAgCAg5BUlQtQ1VTVE9NRFVDSwUDbmlsAAlhcnRlZmFjdHMJAMwIAgIKQVJULVhNSVNUTAkAzAgCAghBUlQtWEhBVAkAzAgCAgpBUlQtWFNDQVJGCQDMCAICDEFSVC1YU1dFQVRFUgkAzAgCAglBUlQtWFNPQ0sJAMwIAgIJQVJULVhUUkVFBQNuaWwAC2FsbEFydGVmYWN0CQDOCAIFCWFydGVmYWN0cwUMb2xkQXJ0ZWZhY3RzAQ10cnlHZXRCb29sZWFuAQNrZXkEByRtYXRjaDAJAJsIAgUEdGhpcwUDa2V5AwkAAQIFByRtYXRjaDACB0Jvb2xlYW4EAWIFByRtYXRjaDAFAWIHAQx0cnlHZXRTdHJpbmcBA2tleQQHJG1hdGNoMAkAnQgCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwBQFhAgABDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFhBQckbWF0Y2gwBQFhAAABD2dldFJhbmRvbU51bWJlcgQIdmFyaWFudHMEdHhJZAxmaW5pc2hIZWlnaHQGb2Zmc2V0BA9yYW5kb21TZWVkQmxvY2sJAQV2YWx1ZQEJAO0HAQkAZQIFDGZpbmlzaEhlaWdodAABBApyYW5kb21IYXNoCQD3AwEJAMsBAgkAywECAQQcQX3mBQR0eElkCQEFdmFsdWUBCAUPcmFuZG9tU2VlZEJsb2NrA3ZyZgkAagIJALIJAgUKcmFuZG9tSGFzaAUGb2Zmc2V0BQh2YXJpYW50cwERZ2V0UmFuZG9tQXJ0ZWZhY3QCBWJveElkAWgEDHJhbmRvbU51bWJlcgkBD2dldFJhbmRvbU51bWJlcgQABgUFYm94SWQFAWgAAQkAkQMCBQlhcnRlZmFjdHMFDHJhbmRvbU51bWJlcgEOZ2V0UmFuZG9tR2VuZXMCBHR4SWQBaAQMcmFuZG9tTnVtYmVyCQEPZ2V0UmFuZG9tTnVtYmVyBAAGBQR0eElkBQFoAAIJAJEDAgUJZnJlZUdlbmVzBQxyYW5kb21OdW1iZXIBFHRyeUdldFN0cmluZ0V4dGVybmFsAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAnQgCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwBQFhAgABCWdldE9yYWNsZQAJAQdBZGRyZXNzAQkA2QQBCQEMdHJ5R2V0U3RyaW5nAQkBF3N0YXRpY0tleV9vcmFjbGVBZGRyZXNzAAERZ2V0QnJlZWRlckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARhzdGF0aWNLZXlfYnJlZWRlckFkZHJlc3MAAQ1nZXRFZ2dBc3NldElkAAkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFHN0YXRpY0tleV9lZ2dBc3NldElkAAETZ2V0VHJ1c3RlZENvbnRyYWN0cwAJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEac3RhdGljS2V5X3RydXN0ZWRDb250cmFjdHMAARFnZXRSZWJpcnRoQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBGHN0YXRpY0tleV9yZWJpcnRoQWRkcmVzcwABF3RyeUdldENvc21ldGljSXRlbVByaWNlAQRpdGVtBANrZXkJARFrZXlfcHJpY2VDb3NtZXRpYwEFBGl0ZW0EByRtYXRjaDAJAJoIAgUEdGhpcwUDa2V5AwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQkAAgECMElUR0NJUDogVGhpcyBpdGVtIGlzIG5vdCBhdmFpbGFibGUgaW4gdGhlIHN0b3JlIQEIYXNTdHJpbmcBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEBnN0cmluZwUHJG1hdGNoMAUGc3RyaW5nCQACAQIcd3JvbmcgdHlwZSwgZXhwZWN0ZWQ6IFN0cmluZwEFYXNJbnQBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgNJbnQEA2ludAUHJG1hdGNoMAUDaW50CQACAQIZd3JvbmcgdHlwZSwgZXhwZWN0ZWQ6IEludAEObWFuaXB1bGF0ZU5hbWUDCWFzc2V0TmFtZQhwb3NpdGlvbgRjaGFyCQCsAgIJAKwCAgkArwICBQlhc3NldE5hbWUJAGUCBQhwb3NpdGlvbgABBQRjaGFyCQCyAgIFCWFzc2V0TmFtZQkAZQIAEAUIcG9zaXRpb24BEGl0ZW1Jc0luQ29vbERvd24CDGFydGVmYWN0TmFtZQphcnRlZmFjdElkBBF1bnN0YWtlSGVpZ2h0TGFzdAkBDXRyeUdldEludGVnZXIBCQERa2V5X3Vuc3Rha2VIZWlnaHQCBQxhcnRlZmFjdE5hbWUFCmFydGVmYWN0SWQEDmNvb2xkb3duUGVyaW9kAPABAwkAZgIFBmhlaWdodAkAZAIFEXVuc3Rha2VIZWlnaHRMYXN0BQ5jb29sZG93blBlcmlvZAcGEAFpAQ1kaXJlY3RCdXlJdGVtAQhpdGVtTmFtZQQJYmFzZVByaWNlCQEXdHJ5R2V0Q29zbWV0aWNJdGVtUHJpY2UBBQhpdGVtTmFtZQQEZ3JvdwkBDXRyeUdldEludGVnZXIBCQEaa2V5X2dyb3dQZXJjZW50YWdlQ29zbWV0aWMBBQhpdGVtTmFtZQQHc3RhcnRUcwkBDXRyeUdldEludGVnZXIBCQETa2V5X3N0YXJ0VHNDb3NtZXRpYwEFCGl0ZW1OYW1lBAVlbmRUcwkBDXRyeUdldEludGVnZXIBCQETa2V5X3N0YXJ0VHNDb3NtZXRpYwEFCGl0ZW1OYW1lAwMJAQIhPQIFB3N0YXJ0VHMAAAkAZgIFB3N0YXJ0VHMIBQlsYXN0QmxvY2sJdGltZXN0YW1wBwkAAgECIUlEQkk6IFRoZSBzYWxlIGRpZCBub3Qgc3RhcnQgeWV0IQMDCQECIT0CBQVlbmRUcwAACQBmAggFCWxhc3RCbG9jawl0aW1lc3RhbXAFBWVuZFRzBwkAAgECJElEQkk6IFRoZSBzYWxlIGhhcyBhbHJlYWR5IGZpbmlzaGVkIQMJAQEhAQkBDXRyeUdldEJvb2xlYW4BCQEQa2V5X3NhbGVDb3NtZXRpYwEFCGl0ZW1OYW1lCQACAQkArAICAh9JREJJOiBJdGVtIG5vdCBmb3Igc2FsZSBhbnltb3JlCQEQa2V5X3NhbGVDb3NtZXRpYwEFCGl0ZW1OYW1lBA1tYXhTYWxlc1ZhbHVlCQENdHJ5R2V0SW50ZWdlcgEJARRrZXlfbWF4U2FsZXNDb3NtZXRpYwEFCGl0ZW1OYW1lBAlzb2xkVmFsdWUJAQ10cnlHZXRJbnRlZ2VyAQkBEGtleV9zb2xkQ29zbWV0aWMBBQhpdGVtTmFtZQQFcHJpY2UDCQAAAgUEZ3JvdwAABQliYXNlUHJpY2UJAGQCBQliYXNlUHJpY2UJAGgCCQBpAgUJYmFzZVByaWNlAGQJAGgCBQlzb2xkVmFsdWUFBGdyb3cDAwkBAiE9AgUNbWF4U2FsZXNWYWx1ZQAACQBnAgUJc29sZFZhbHVlBQ1tYXhTYWxlc1ZhbHVlBwkAAgECGElEQkk6IE1heCBlZGl0aW9ucyBzb2xkIQQHYXNzZXRJZAMJAAACCQEMdHJ5R2V0U3RyaW5nAQkBFmtleV9wcmljZUFzc2V0Q29zbWV0aWMBBQhpdGVtTmFtZQIACQENZ2V0RWdnQXNzZXRJZAAJANkEAQkBDHRyeUdldFN0cmluZwEJARZrZXlfcHJpY2VBc3NldENvc21ldGljAQUIaXRlbU5hbWUEE2Ftb3VudFBhaWRCeUNvdXBvbnMAAAQJbGVmdFRvUGF5CQBlAgUFcHJpY2UFE2Ftb3VudFBhaWRCeUNvdXBvbnMEB3BheW1lbnQDCQECIT0CBQlsZWZ0VG9QYXkAAAQMZmlyc3RQYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAEBmFtb3VudAgFDGZpcnN0UGF5bWVudAZhbW91bnQDCQECIT0CCAUMZmlyc3RQYXltZW50B2Fzc2V0SWQFB2Fzc2V0SWQJAAIBCQCsAgICPklEQkk6IFlvdSBjYW4gYXR0YWNoIG9ubHkgdG9rZW5zIHdpdGggdGhlIGZvbGxvd2luZyBhc3NldCBpZDogCQDYBAEFB2Fzc2V0SWQDCQECIT0CBQZhbW91bnQFCWxlZnRUb1BheQkAAgEJAKwCAgIqSURCSTogUGxlYXNlIGF0dGFjaCB0aGUgZXhhY3QgYXNzZXQgYW1vdW50CQCkAwEFBXByaWNlBQlsZWZ0VG9QYXkAAAMJAAACBQdwYXltZW50BQdwYXltZW50BAd0eElkU3RyCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQEB2FkZHJlc3MIBQFpDG9yaWdpbkNhbGxlcgQIYXJ0ZWZhY3QJAMMIBwUIaXRlbU5hbWUJAKwCAgIiTkZUIGFydGVmYWN0IG9mIFdhdmVzIER1Y2tzIGdhbWU6IAUIaXRlbU5hbWUAAQAABwUEdW5pdAAABAphcnRlZmFjdElkCQC4CAEFCGFydGVmYWN0CQCUCgIJAMwIAgUIYXJ0ZWZhY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICCWFydGVmYWN0XwkA2AQBBQphcnRlZmFjdElkAgVfdHlwZQUIaXRlbU5hbWUJAMwIAgkBDEludGVnZXJFbnRyeQIJARVrZXlfbGFzdFByaWNlQ29zbWV0aWMBBQhpdGVtTmFtZQUFcHJpY2UJAMwIAgkBDEludGVnZXJFbnRyeQIJARBrZXlfc29sZENvc21ldGljAQUIaXRlbU5hbWUJAGQCBQlzb2xkVmFsdWUAAQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQdhZGRyZXNzAAEFCmFydGVmYWN0SWQFA25pbAkA2AQBBQphcnRlZmFjdElkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBD21hbmlwdWxhdGVCb29zdAIFYm9vc3QGZHVja0lkBBBhbGxvd2VkQ29udHJhY3RzCQETZ2V0VHJ1c3RlZENvbnRyYWN0cwAEFGFsbG93ZWRDb250cmFjdHNMaXN0CQC1CQIFEGFsbG93ZWRDb250cmFjdHMCATsECmRhcHBUb0NhbGwJAKUIAQgFAWkGY2FsbGVyAwkAAAIJAM8IAgUUYWxsb3dlZENvbnRyYWN0c0xpc3QFCmRhcHBUb0NhbGwFBHVuaXQJAAIBAjRJTUI6IFRoaXMgc21hcnQgY29udHJhY3QgY2FuJ3QgbWFuaXB1bGF0ZSB0aGUgYm9vc3QhBANrZXkJARVrZXlfZXh0ZXJuYWxCb29zdER1Y2sBBQZkdWNrSWQEC2FjdGl2ZUJvb3N0CQENdHJ5R2V0SW50ZWdlcgEFA2tleQQIbmV3Qm9vc3QJAGQCBQthY3RpdmVCb29zdAUFYm9vc3QDCQBmAgAABQhuZXdCb29zdAkAAgECQElNQjogU29tZXRoaW5nIHdlbnQgd3Jvbmcgd2l0aCBib29zdCwgcGxlYXNlIGNvbnRhY3QgdGhlIGFkbWlucyEJAMwIAgkBDEludGVnZXJFbnRyeQIFA2tleQUIbmV3Qm9vc3QFA25pbAFpARZtYW5pcHVsYXRlQm9vc3RBY2NvdW50AgVib29zdAdhZGRyZXNzBBBhbGxvd2VkQ29udHJhY3RzCQETZ2V0VHJ1c3RlZENvbnRyYWN0cwAEFGFsbG93ZWRDb250cmFjdHNMaXN0CQC1CQIFEGFsbG93ZWRDb250cmFjdHMCATsECmRhcHBUb0NhbGwJAKUIAQgFAWkGY2FsbGVyAwkAAAIJAM8IAgUUYWxsb3dlZENvbnRyYWN0c0xpc3QFCmRhcHBUb0NhbGwFBHVuaXQJAAIBAjVJTUJBOiBUaGlzIHNtYXJ0IGNvbnRyYWN0IGNhbid0IG1hbmlwdWxhdGUgdGhlIGJvb3N0IQQDa2V5CQEYa2V5X2V4dGVybmFsQm9vc3RBZGRyZXNzAQUHYWRkcmVzcwQLYWN0aXZlQm9vc3QJAQ10cnlHZXRJbnRlZ2VyAQUDa2V5BAhuZXdCb29zdAkAZAIFC2FjdGl2ZUJvb3N0BQVib29zdAMJAGYCAAAFCG5ld0Jvb3N0CQACAQJBSU1CQTogU29tZXRoaW5nIHdlbnQgd3Jvbmcgd2l0aCBib29zdCwgcGxlYXNlIGNvbnRhY3QgdGhlIGFkbWlucyEJAMwIAgkBDEludGVnZXJFbnRyeQIFA2tleQUIbmV3Qm9vc3QFA25pbAFpARRjaGVja0FydGVmYWN0RGV0YWlscwEHYXNzZXRJZAQFYXNzZXQJAQV2YWx1ZQEJAOwHAQkA2QQBBQdhc3NldElkBAlhc3NldE5hbWUJAQV2YWx1ZQEIBQVhc3NldARuYW1lAwMDCQEPY29udGFpbnNFbGVtZW50AgULYWxsQXJ0ZWZhY3QFCWFzc2V0TmFtZQYJAQlpc0RlZmluZWQBCQEXdHJ5R2V0Q29zbWV0aWNJdGVtUHJpY2UBBQlhc3NldE5hbWUJAAACCAUFYXNzZXQGaXNzdWVyBQR0aGlzBwkAlAoCBQNuaWwFCWFzc2V0TmFtZQkAAgECEEludmFsaWQgYXJ0ZWZhY3QBaQEPY29uZmlndXJlT3JhY2xlAQZvcmFjbGUDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgphZG1pbiBvbmx5CQDMCAIJAQtTdHJpbmdFbnRyeQIJARdzdGF0aWNLZXlfb3JhY2xlQWRkcmVzcwAFBm9yYWNsZQUDbmlsAWkBGmNhbGN1bGF0ZUZhcm1pbmdQb3dlckJvb3N0AgZkdWNrSWQHYWRkcmVzcwQRZXh0ZXJuYWxCb29zdER1Y2sJAQ10cnlHZXRJbnRlZ2VyAQkBFWtleV9leHRlcm5hbEJvb3N0RHVjawEFBmR1Y2tJZAQUZXh0ZXJuYWxCb29zdEFkZHJlc3MJAQ10cnlHZXRJbnRlZ2VyAQkBGGtleV9leHRlcm5hbEJvb3N0QWRkcmVzcwEFB2FkZHJlc3MECnRvdGFsQm9vc3QJAGQCBRFleHRlcm5hbEJvb3N0RHVjawUUZXh0ZXJuYWxCb29zdEFkZHJlc3MJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQZkdWNrSWQCC19sYXN0X2Jvb3N0BQp0b3RhbEJvb3N0BQNuaWwFCnRvdGFsQm9vc3QBaQEJZml4ZWRHZW5lAwd0eElkU3RyD3BhcmVudEZpeGVkR2VuZRFwb3NpdGlvbkZpeGVkR2VuZQQMZmlyc3RQYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAEDGZpcnN0QXNzZXRJZAkA2AQBCQEFdmFsdWUBCAUMZmlyc3RQYXltZW50B2Fzc2V0SWQDCQECIT0CCAUMZmlyc3RQYXltZW50BmFtb3VudAABCQACAQITTkZUIGlzIG5vdCBhdHRhY2hlZAQIYXJ0ZWZhY3QJAQhhc1N0cmluZwEJAPwHBAUEdGhpcwIUY2hlY2tBcnRlZmFjdERldGFpbHMJAMwIAgUMZmlyc3RBc3NldElkBQNuaWwFA25pbAMJAAACBQhhcnRlZmFjdAUIYXJ0ZWZhY3QDCQECIT0CBQhhcnRlZmFjdAILQVJULUZJWEdFTkUJAAIBAilZb3UgbmVlZCB0byBhdHRhY2ggYSBBUlQtRklYR0VORSBhcnRlZmFjdAQEdHhJZAkA2QQBBQd0eElkU3RyBA9maW5pc2hIZWlnaHRLZXkJARdrZXlfcHJvY2Vzc0ZpbmlzaEhlaWdodAIJAKUIAQgFAWkGY2FsbGVyBQR0eElkBBNwcm9jZXNzRmluaXNoSGVpZ2h0CQERQGV4dHJOYXRpdmUoMTA1MCkCCQERZ2V0QnJlZWRlckFkZHJlc3MABQ9maW5pc2hIZWlnaHRLZXkED2R1Y2tHZW5lc1N0cmluZwkBCGFzU3RyaW5nAQkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAgxnZW5lcmF0ZUR1Y2sJAMwIAgUEdHhJZAkAzAgCBRNwcm9jZXNzRmluaXNoSGVpZ2h0CQDMCAIFD3BhcmVudEZpeGVkR2VuZQkAzAgCBRFwb3NpdGlvbkZpeGVkR2VuZQkAzAgCAgAJAMwIAgAABQNuaWwFA25pbAMJAAACBQ9kdWNrR2VuZXNTdHJpbmcFD2R1Y2tHZW5lc1N0cmluZwQEY2FsbAkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhdmaW5pc2hEdWNrSGF0Y2hpbmdJdGVtcwkAzAgCBQd0eElkU3RyCQDMCAIFD2R1Y2tHZW5lc1N0cmluZwUDbmlsBQNuaWwDCQAAAgUEY2FsbAUEY2FsbAkAzAgCCQEEQnVybgIJAQV2YWx1ZQEIBQxmaXJzdFBheW1lbnQHYXNzZXRJZAABBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIZnJlZUdlbmUBB3R4SWRTdHIEDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABAxmaXJzdEFzc2V0SWQJANgEAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkAwkBAiE9AggFDGZpcnN0UGF5bWVudAZhbW91bnQAAQkAAgECE05GVCBpcyBub3QgYXR0YWNoZWQECGFydGVmYWN0CQEIYXNTdHJpbmcBCQD8BwQFBHRoaXMCFGNoZWNrQXJ0ZWZhY3REZXRhaWxzCQDMCAIFDGZpcnN0QXNzZXRJZAUDbmlsBQNuaWwDCQAAAgUIYXJ0ZWZhY3QFCGFydGVmYWN0AwkBAiE9AgUIYXJ0ZWZhY3QCDEFSVC1GUkVFR0VORQkAAgECKllvdSBuZWVkIHRvIGF0dGFjaCBhIEFSVC1GUkVFR0VORSBhcnRlZmFjdAQEdHhJZAkA2QQBBQd0eElkU3RyBA9maW5pc2hIZWlnaHRLZXkJARdrZXlfcHJvY2Vzc0ZpbmlzaEhlaWdodAIJAKUIAQgFAWkGY2FsbGVyBQR0eElkBBNwcm9jZXNzRmluaXNoSGVpZ2h0CQERQGV4dHJOYXRpdmUoMTA1MCkCCQERZ2V0QnJlZWRlckFkZHJlc3MABQ9maW5pc2hIZWlnaHRLZXkEDHNlbGVjdGVkR2VuZQkBDmdldFJhbmRvbUdlbmVzAgUEdHhJZAUTcHJvY2Vzc0ZpbmlzaEhlaWdodAQOcmFuZG9tUG9zaXRpb24JAQ9nZXRSYW5kb21OdW1iZXIEAAcFBHR4SWQFE3Byb2Nlc3NGaW5pc2hIZWlnaHQAAwQPZHVja0dlbmVzU3RyaW5nCQEIYXNTdHJpbmcBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACDGdlbmVyYXRlRHVjawkAzAgCBQR0eElkCQDMCAIFE3Byb2Nlc3NGaW5pc2hIZWlnaHQJAMwIAgAACQDMCAIAAAkAzAgCBQxzZWxlY3RlZEdlbmUJAMwIAgUOcmFuZG9tUG9zaXRpb24FA25pbAUDbmlsAwkAAAIFD2R1Y2tHZW5lc1N0cmluZwUPZHVja0dlbmVzU3RyaW5nBARjYWxsCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACF2ZpbmlzaER1Y2tIYXRjaGluZ0l0ZW1zCQDMCAIFB3R4SWRTdHIJAMwIAgUPZHVja0dlbmVzU3RyaW5nBQNuaWwFA25pbAMJAAACBQRjYWxsBQRjYWxsCQDMCAIJAQRCdXJuAgkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkAAEFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQhjb3B5RHVjawAEDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABA1zZWNvbmRQYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAEEDGZpcnN0QXNzZXRJZAkA2AQBCQEFdmFsdWUBCAUMZmlyc3RQYXltZW50B2Fzc2V0SWQECGNoaWxkcmVuCQEFYXNJbnQBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACFnZhbGlkYXRlQW5kR2V0Q2hpbGRyZW4JAMwIAgUMZmlyc3RBc3NldElkBQNuaWwFA25pbAMJAAACBQhjaGlsZHJlbgUIY2hpbGRyZW4DAwkBAiE9AggFDGZpcnN0UGF5bWVudAZhbW91bnQAAQYJAQIhPQIIBQ1zZWNvbmRQYXltZW50BmFtb3VudAABCQACAQITTkZUIGlzIG5vdCBhdHRhY2hlZAQIYXJ0ZWZhY3QJAQhhc1N0cmluZwEJAPwHBAUEdGhpcwIUY2hlY2tBcnRlZmFjdERldGFpbHMJAMwIAgkA2AQBCQEFdmFsdWUBCAUNc2Vjb25kUGF5bWVudAdhc3NldElkBQNuaWwFA25pbAMJAAACBQhhcnRlZmFjdAUIYXJ0ZWZhY3QDCQECIT0CBQhhcnRlZmFjdAIKQVJULU1JUlJPUgkAAgECKFlvdSBuZWVkIHRvIGF0dGFjaCBhIEFSVC1NSVJST1IgYXJ0ZWZhY3QEB25mdEluZm8JAQV2YWx1ZQEJAOwHAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkBAlhc3NldDFHZW4JALUJAggFB25mdEluZm8EbmFtZQIAAwMJAAACCQCRAwIFCWFzc2V0MUdlbgAOAgFHBgkAAAIJAJEDAgUJYXNzZXQxR2VuAA4CAUoJAAIBAhpZb3UgY2FuJ3QgbWlycm9yIHRoaXMgZHVjawQHZHVja0dlbggFB25mdEluZm8EbmFtZQQEY2FsbAkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhZjcmVhdGVEdWNrU3BlY2lhbEdlbmVzCQDMCAIICAUBaQZjYWxsZXIFYnl0ZXMJAMwIAgUHZHVja0dlbgkAzAgCBQhjaGlsZHJlbgUDbmlsBQNuaWwDCQAAAgUEY2FsbAUEY2FsbAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIAAQgFDGZpcnN0UGF5bWVudAdhc3NldElkCQDMCAIJAQRCdXJuAgkBBXZhbHVlAQgFDXNlY29uZFBheW1lbnQHYXNzZXRJZAABBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQERYWRkQXJ0ZUZhY3RUb0R1Y2sABAxmaXJzdFBheW1lbnQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQNc2Vjb25kUGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwABBAxmaXJzdEFzc2V0SWQJANgEAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkAwMJAQIhPQIIBQxmaXJzdFBheW1lbnQGYW1vdW50AAEGCQECIT0CCAUNc2Vjb25kUGF5bWVudAZhbW91bnQAAQkAAgECE05GVCBpcyBub3QgYXR0YWNoZWQECGNoaWxkcmVuCQEFYXNJbnQBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACFnZhbGlkYXRlQW5kR2V0Q2hpbGRyZW4JAMwIAgUMZmlyc3RBc3NldElkBQNuaWwFA25pbAMJAAACBQhjaGlsZHJlbgUIY2hpbGRyZW4DCQAAAgUIY2hpbGRyZW4AAAkAAgECJFlvdSBjYW4gb25seSBwaWNrIGEgc3RlcmlsZSBORlQtZHVjawQIYXJ0ZWZhY3QJAQhhc1N0cmluZwEJAPwHBAUEdGhpcwIUY2hlY2tBcnRlZmFjdERldGFpbHMJAMwIAgkA2AQBCQEFdmFsdWUBCAUNc2Vjb25kUGF5bWVudAdhc3NldElkBQNuaWwFA25pbAMJAAACBQhhcnRlZmFjdAUIYXJ0ZWZhY3QDAwkBAiE9AgUIYXJ0ZWZhY3QCCEFSVC1YSEFUCQECIT0CBQhhcnRlZmFjdAIIQVJULVBPTVAHCQACAQIyWW91IG5lZWQgdG8gYXR0YWNoIGEgQVJULVhIQVQgb3IgQVJULVBPTVAgYXJ0ZWZhY3QEB25mdEluZm8JAQV2YWx1ZQEJAOwHAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkBAlhc3NldDFHZW4JALUJAggFB25mdEluZm8EbmFtZQIAAwMJAAACCQCRAwIFCWFzc2V0MUdlbgAOAgFHBgkAAAIJAJEDAgUJYXNzZXQxR2VuAA4CAUoJAAIBAhpZb3UgY2FuJ3QgbWlycm9yIHRoaXMgZHVjawMDCQAAAgkAkQMCBQlhc3NldDFHZW4ABQIBUwYJAAACCQCRAwIFCWFzc2V0MUdlbgAFAgFUCQACAQIfeW91IGFscmVhZHkgYXR0YWNoZWQgYSBhcnRlZmFjdAQEY2hhcgMJAAACBQhhcnRlZmFjdAIIQVJULVhIQVQCAVQDCQAAAgUIYXJ0ZWZhY3QCCEFSVC1QT01QAgFTCQACAQIPTm8gY2hhciBkZWZpbmVkBApvbGREdWNrR2VuCAUHbmZ0SW5mbwRuYW1lBApvbGRGYXJtR2VuCQEIYXNTdHJpbmcBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACDmdldEdlbkZyb21OYW1lCQDMCAIFCm9sZER1Y2tHZW4FA25pbAUDbmlsAwkAAAIFCm9sZEZhcm1HZW4FCm9sZEZhcm1HZW4EB2R1Y2tHZW4JAQ5tYW5pcHVsYXRlTmFtZQMFCm9sZER1Y2tHZW4ABgUEY2hhcgQEY2FsbAkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhZjcmVhdGVEdWNrU3BlY2lhbEdlbmVzCQDMCAIICAUBaQZjYWxsZXIFYnl0ZXMJAMwIAgUHZHVja0dlbgkAzAgCBQhjaGlsZHJlbgUDbmlsBQNuaWwDCQAAAgUEY2FsbAUEY2FsbAQKY2FsbFJlZHVjZQkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAgxyZWR1Y2VSYXJpdHkJAMwIAgUMZmlyc3RBc3NldElkCQDMCAIFCm9sZEZhcm1HZW4FA25pbAUDbmlsAwkAAAIFCmNhbGxSZWR1Y2UFCmNhbGxSZWR1Y2UJAMwIAgkBBEJ1cm4CCQEFdmFsdWUBCAUMZmlyc3RQYXltZW50B2Fzc2V0SWQAAQkAzAgCCQEEQnVybgIJAQV2YWx1ZQEIBQ1zZWNvbmRQYXltZW50B2Fzc2V0SWQAAQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB3ByZUluaXQACQDMCAIJAQxJbnRlZ2VyRW50cnkCAhxzdGF0aWNfQVJULUxBS0VfZmFybWluZ1Nsb3RzAMgBCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhxzdGF0aWNfQVJULUxBS0VfZmFybWluZ0Jvb3N0AAIJAMwIAgkBDEludGVnZXJFbnRyeQICHXN0YXRpY19BUlQtSE9VU0VfZmFybWluZ1Nsb3RzAAQJAMwIAgkBDEludGVnZXJFbnRyeQICHXN0YXRpY19BUlQtSE9VU0VfZmFybWluZ0Jvb3N0AB4JAMwIAgkBDEludGVnZXJFbnRyeQICIHN0YXRpY19BUlQtQklHSE9VU0VfZmFybWluZ1Nsb3RzAAoJAMwIAgkBDEludGVnZXJFbnRyeQICIHN0YXRpY19BUlQtQklHSE9VU0VfZmFybWluZ0Jvb3N0AA8FA25pbAFpAQ1pc3N1ZUFydGVmYWN0AgR0eXBlCHJlY2VpdmVyAwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkBAiE9AggFAWkGY2FsbGVyCQERZ2V0UmViaXJ0aEFkZHJlc3MABwkAAgECCmFkbWluIG9ubHkEB3R4SWRTdHIJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAQHYWRkcmVzcwkBB0FkZHJlc3MBCQDZBAEFCHJlY2VpdmVyBAhhcnRlZmFjdAkAwwgHBQR0eXBlAipORlQgYXJ0ZWZhY3Qgb2YgV2F2ZXMgRHVja3MgZ2FtZS4gRHJvcCAjMi4AAQAABwUEdW5pdAAABAphcnRlZmFjdElkCQC4CAEFCGFydGVmYWN0CQCUCgIJAMwIAgUIYXJ0ZWZhY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICCWFydGVmYWN0XwkA2AQBBQphcnRlZmFjdElkAgVfdHlwZQUEdHlwZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQdhZGRyZXNzAAEFCmFydGVmYWN0SWQFA25pbAkA2AQBBQphcnRlZmFjdElkAWkBB3NldExvY2sBAW4DCQAAAggFAWkGY2FsbGVyBQR0aGlzCQDMCAIJAQxJbnRlZ2VyRW50cnkCAg1nbG9iYWxfbG9ja2VkBQFuBQNuaWwJAAIBAgphZG1pbiBvbmx5AWkBC2J1eUFydGVmYWN0AAMJAGYCCAUJbGFzdEJsb2NrCXRpbWVzdGFtcACAzI3C3C8JAAIBAiFUaGVyZSBhcmUgbm8gYWN0aXZlIHNhbGVzIG5vdy4uLiADCQBmAgkBDXRyeUdldEludGVnZXIBAg1nbG9iYWxfbG9ja2VkAAAJAAIBAh5jb250cmFjdCBpcyB0ZW1wb3JhcmlseSBsb2NrZWQDCQBnAgkBDXRyeUdldEludGVnZXIBAhBnbG9iYWxfYXJ0QW1vdW50BQ5hcnRlZmFjdHNMaW1pdAkAAgECElNPTERPVVQhISEgSHVycmF5IQMDCQBmAgCA/u+A3C8IBQlsYXN0QmxvY2sJdGltZXN0YW1wCQECIT0CCAUBaQZjYWxsZXIJAQdBZGRyZXNzAQUKZGV2QWRkcmVzcwcJAAIBAgxUb28gZWFybHkuLi4EDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AggFDGZpcnN0UGF5bWVudAdhc3NldElkCQENZ2V0RWdnQXNzZXRJZAAJAAIBCQCsAgICPFlvdSBjYW4gYXR0YWNoIG9ubHkgRUdHIHRva2VucyB3aXRoIHRoZSBmb2xsb3dpbmcgYXNzZXQgaWQ6IAkA2AQBCQENZ2V0RWdnQXNzZXRJZAADCQBmAgUKZWdnc05lZWRlZAgFDGZpcnN0UGF5bWVudAZhbW91bnQJAAIBCQCsAgICRFRvIGhhdGNoIGEgZHVjayB5b3UgY3VycmVudGx5IG5lZWQgdGhlIGZvbGxvd2luZyBhbW91bnQgb2YgRUdHbGV0czogCQCkAwEFCmVnZ3NOZWVkZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JANgEAQgFAWkNdHJhbnNhY3Rpb25JZAIHX3N0YXR1cwIHc3RhcnRlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JANgEAQgFAWkNdHJhbnNhY3Rpb25JZAINX2ZpbmlzaEhlaWdodAkAZAIFBmhlaWdodAACCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhBnbG9iYWxfYXJ0QW1vdW50CQBkAgkBDXRyeUdldEludGVnZXIBAhBnbG9iYWxfYXJ0QW1vdW50AAEFA25pbAFpARJzZXRHbG9iYWxBcnRBbW91bnQBCW5ld0Ftb3VudAMDCQAAAggFAWkGY2FsbGVyBQR0aGlzBgkAAAIIBQFpBmNhbGxlcgkBB0FkZHJlc3MBBQpkZXZBZGRyZXNzCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhBnbG9iYWxfYXJ0QW1vdW50BQluZXdBbW91bnQFA25pbAkAAgECEVBlcm1pc3Npb24gZGVuaWVkAWkBDWNsYWltQXJ0ZWZhY3QBCGJveElkU3RyBAR0eElkCQDZBAEFCGJveElkU3RyBAlzdGF0dXNLZXkJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfBQhib3hJZFN0cgIHX3N0YXR1cwQJaGVpZ2h0S2V5CQCsAgIJAKwCAgkArAICCQClCAEIBQFpBmNhbGxlcgIBXwUIYm94SWRTdHICDV9maW5pc2hIZWlnaHQDCQECIT0CCQERQGV4dHJOYXRpdmUoMTA1OCkBBQlzdGF0dXNLZXkCB3N0YXJ0ZWQJAAIBAg9jbGFpbWVkIGFscmVhZHkDCQBmAgkBEUBleHRyTmF0aXZlKDEwNTUpAQUJaGVpZ2h0S2V5BQZoZWlnaHQJAAIBAhR5b3UgY2Fubm90IGNsYWltIHlldAQHYXJ0VHlwZQkBEWdldFJhbmRvbUFydGVmYWN0AgUEdHhJZAkBEUBleHRyTmF0aXZlKDEwNTUpAQUJaGVpZ2h0S2V5BAVhc3NldAkAwwgHBQdhcnRUeXBlAiJBcnRlZmFjdCBvZiBXYXZlcyBEdWNrcyBtZXRhdmVyc2UuAAEAAAcFBHVuaXQJARFAZXh0ck5hdGl2ZSgxMDU1KQEFCWhlaWdodEtleQQHYXNzZXRJZAkAuAgBBQVhc3NldAkAzAgCCQELU3RyaW5nRW50cnkCBQlzdGF0dXNLZXkFB2FydFR5cGUJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8FCGJveElkU3RyAgtfYXJ0ZWZhY3RJZAkA2AQBBQdhc3NldElkCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkA2AQBBQdhc3NldElkAgVfdHlwZQUHYXJ0VHlwZQkAzAgCBQVhc3NldAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIAAQUHYXNzZXRJZAUDbmlsAQJ0eAEGdmVyaWZ5AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleXETFYw=", "height": 3514695, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: G1ceoQCEgHSZasWPkh1G4c18xxUJZXeJb9SqcMjxVUo1 Next: 9odj8JTtEYUaS7ea7MiucYwWsovade9vydPpdH6dNCD9 Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func staticKey_oracleAddress () = "static_oracleAddress"
55
66
77 func staticKey_breederAddress () = "static_breederAddress"
88
99
1010 func staticKey_eggAssetId () = "static_eggAssetId"
1111
1212
1313 func staticKey_trustedContracts () = "static_trustedContracts"
1414
1515
1616 func staticKey_rebirthAddress () = "static_rebirthAddress"
1717
1818
1919 func key_artefactOwner (artefactName,owner) = (((artefactName + "_") + owner) + "_owner")
2020
2121
2222 func key_unstakeHeight (artefactName,artefactId) = (((artefactName + "_") + artefactId) + "_unstake_height")
2323
2424
2525 func key_externalBoostDuck (duckId) = (duckId + "_duck_external_boost")
2626
2727
2828 func key_externalBoostAddress (address) = (address + "_user_external_boost")
2929
3030
3131 func key_priceCosmetic (item) = ("direct_cosmetic_" + item)
3232
3333
3434 func key_maxSalesCosmetic (item) = (("direct_cosmetic_" + item) + "_max_sales")
3535
3636
3737 func key_saleCosmetic (item) = (("direct_cosmetic_" + item) + "_sale")
3838
3939
4040 func key_priceAssetCosmetic (item) = (("direct_cosmetic_" + item) + "_priceAsset")
4141
4242
4343 func key_growPercentageCosmetic (item) = (("direct_cosmetic_" + item) + "_growing_percentage")
4444
4545
4646 func key_soldCosmetic (item) = (("direct_cosmetic_" + item) + "_sold")
4747
4848
4949 func key_lastPriceCosmetic (item) = (("direct_cosmetic_" + item) + "_last_price")
5050
5151
5252 func key_startTsCosmetic (item) = (("direct_cosmetic_" + item) + "_startTs")
5353
5454
5555 func key_endTsCosmetic (item) = (("direct_cosmetic_" + item) + "_endTs")
5656
5757
5858 func key_processFinishHeight (address,txId) = (((address + "_") + toBase58String(txId)) + "_fh")
5959
6060
6161 let devAddress = base58'3P44yqcpfhPF2iC1nptm2ZJCTaN7VYhz9og'
6262
6363 let eggsNeeded = (3 * 100000000)
6464
6565 let artefactsLimit = (301 + 600)
6666
6767 let freeGenes = ["A", "B", "C", "D", "E", "F"]
6868
6969 let oldArtefacts = ["ART-LAKE", "ART-HOUSE", "ART-BIGHOUSE", "ART-FIXGENE", "ART-FREEGENE", "ART-MIRROR", "ART-POMP", "ART-CAPE", "ART-HAT", "ART-CUSTOMDUCK"]
7070
7171 let artefacts = ["ART-XMISTL", "ART-XHAT", "ART-XSCARF", "ART-XSWEATER", "ART-XSOCK", "ART-XTREE"]
7272
7373 let allArtefact = (artefacts ++ oldArtefacts)
7474
7575 func tryGetBoolean (key) = match getBoolean(this, key) {
7676 case b: Boolean =>
7777 b
7878 case _ =>
7979 false
8080 }
8181
8282
8383 func tryGetString (key) = match getString(this, key) {
8484 case a: String =>
8585 a
8686 case _ =>
8787 ""
8888 }
8989
9090
9191 func tryGetInteger (key) = match getInteger(this, key) {
9292 case a: Int =>
9393 a
9494 case _ =>
9595 0
9696 }
9797
9898
9999 func getRandomNumber (variants,txId,finishHeight,offset) = {
100100 let randomSeedBlock = value(blockInfoByHeight((finishHeight - 1)))
101101 let randomHash = sha256(((base58'items' + txId) + value(randomSeedBlock.vrf)))
102102 (toInt(randomHash, offset) % variants)
103103 }
104104
105105
106106 func getRandomArtefact (boxId,h) = {
107107 let randomNumber = getRandomNumber(6, boxId, h, 1)
108108 artefacts[randomNumber]
109109 }
110110
111111
112112 func getRandomGenes (txId,h) = {
113113 let randomNumber = getRandomNumber(6, txId, h, 2)
114114 freeGenes[randomNumber]
115115 }
116116
117117
118118 func tryGetStringExternal (address,key) = match getString(address, key) {
119119 case a: String =>
120120 a
121121 case _ =>
122122 ""
123123 }
124124
125125
126126 func getOracle () = Address(fromBase58String(tryGetString(staticKey_oracleAddress())))
127127
128128
129129 func getBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_breederAddress())))
130130
131131
132132 func getEggAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_eggAssetId()))
133133
134134
135135 func getTrustedContracts () = tryGetStringExternal(getOracle(), staticKey_trustedContracts())
136136
137137
138138 func getRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_rebirthAddress())))
139139
140140
141141 func tryGetCosmeticItemPrice (item) = {
142142 let key = key_priceCosmetic(item)
143143 match getInteger(this, key) {
144144 case a: Int =>
145145 a
146146 case _ =>
147147 throw("ITGCIP: This item is not available in the store!")
148148 }
149149 }
150150
151151
152152 func asString (value) = match value {
153153 case string: String =>
154154 string
155155 case _ =>
156156 throw("wrong type, expected: String")
157157 }
158158
159159
160160 func asInt (value) = match value {
161161 case int: Int =>
162162 int
163163 case _ =>
164164 throw("wrong type, expected: Int")
165165 }
166166
167167
168168 func manipulateName (assetName,position,char) = ((take(assetName, (position - 1)) + char) + takeRight(assetName, (16 - position)))
169169
170170
171171 func itemIsInCoolDown (artefactName,artefactId) = {
172172 let unstakeHeightLast = tryGetInteger(key_unstakeHeight(artefactName, artefactId))
173173 let cooldownPeriod = 240
174174 if ((height > (unstakeHeightLast + cooldownPeriod)))
175175 then false
176176 else true
177177 }
178178
179179
180180 @Callable(i)
181181 func directBuyItem (itemName) = {
182182 let basePrice = tryGetCosmeticItemPrice(itemName)
183183 let grow = tryGetInteger(key_growPercentageCosmetic(itemName))
184184 let startTs = tryGetInteger(key_startTsCosmetic(itemName))
185185 let endTs = tryGetInteger(key_startTsCosmetic(itemName))
186186 if (if ((startTs != 0))
187187 then (startTs > lastBlock.timestamp)
188188 else false)
189189 then throw("IDBI: The sale did not start yet!")
190190 else if (if ((endTs != 0))
191191 then (lastBlock.timestamp > endTs)
192192 else false)
193193 then throw("IDBI: The sale has already finished!")
194194 else if (!(tryGetBoolean(key_saleCosmetic(itemName))))
195195 then throw(("IDBI: Item not for sale anymore" + key_saleCosmetic(itemName)))
196196 else {
197197 let maxSalesValue = tryGetInteger(key_maxSalesCosmetic(itemName))
198198 let soldValue = tryGetInteger(key_soldCosmetic(itemName))
199199 let price = if ((grow == 0))
200200 then basePrice
201201 else (basePrice + ((basePrice / 100) * (soldValue * grow)))
202202 if (if ((maxSalesValue != 0))
203203 then (soldValue >= maxSalesValue)
204204 else false)
205205 then throw("IDBI: Max editions sold!")
206206 else {
207207 let assetId = if ((tryGetString(key_priceAssetCosmetic(itemName)) == ""))
208208 then getEggAssetId()
209209 else fromBase58String(tryGetString(key_priceAssetCosmetic(itemName)))
210210 let amountPaidByCoupons = 0
211211 let leftToPay = (price - amountPaidByCoupons)
212212 let payment = if ((leftToPay != 0))
213213 then {
214214 let firstPayment = value(i.payments[0])
215215 let amount = firstPayment.amount
216216 if ((firstPayment.assetId != assetId))
217217 then throw(("IDBI: You can attach only tokens with the following asset id: " + toBase58String(assetId)))
218218 else if ((amount != leftToPay))
219219 then throw(("IDBI: Please attach the exact asset amount" + toString(price)))
220220 else leftToPay
221221 }
222222 else 0
223223 if ((payment == payment))
224224 then {
225225 let txIdStr = toBase58String(i.transactionId)
226226 let address = i.originCaller
227227 let artefact = Issue(itemName, ("NFT artefact of Waves Ducks game: " + itemName), 1, 0, false, unit, 0)
228228 let artefactId = calculateAssetId(artefact)
229229 $Tuple2([artefact, StringEntry((("artefact_" + toBase58String(artefactId)) + "_type"), itemName), IntegerEntry(key_lastPriceCosmetic(itemName), price), IntegerEntry(key_soldCosmetic(itemName), (soldValue + 1)), ScriptTransfer(address, 1, artefactId)], toBase58String(artefactId))
230230 }
231231 else throw("Strict value is not equal to itself.")
232232 }
233233 }
234234 }
235235
236236
237237
238238 @Callable(i)
239239 func manipulateBoost (boost,duckId) = {
240240 let allowedContracts = getTrustedContracts()
241241 let allowedContractsList = split(allowedContracts, ";")
242242 let dappToCall = toString(i.caller)
243243 if ((indexOf(allowedContractsList, dappToCall) == unit))
244244 then throw("IMB: This smart contract can't manipulate the boost!")
245245 else {
246246 let key = key_externalBoostDuck(duckId)
247247 let activeBoost = tryGetInteger(key)
248248 let newBoost = (activeBoost + boost)
249249 if ((0 > newBoost))
250250 then throw("IMB: Something went wrong with boost, please contact the admins!")
251251 else [IntegerEntry(key, newBoost)]
252252 }
253253 }
254254
255255
256256
257257 @Callable(i)
258258 func manipulateBoostAccount (boost,address) = {
259259 let allowedContracts = getTrustedContracts()
260260 let allowedContractsList = split(allowedContracts, ";")
261261 let dappToCall = toString(i.caller)
262262 if ((indexOf(allowedContractsList, dappToCall) == unit))
263263 then throw("IMBA: This smart contract can't manipulate the boost!")
264264 else {
265265 let key = key_externalBoostAddress(address)
266266 let activeBoost = tryGetInteger(key)
267267 let newBoost = (activeBoost + boost)
268268 if ((0 > newBoost))
269269 then throw("IMBA: Something went wrong with boost, please contact the admins!")
270270 else [IntegerEntry(key, newBoost)]
271271 }
272272 }
273273
274274
275275
276276 @Callable(i)
277277 func checkArtefactDetails (assetId) = {
278278 let asset = value(assetInfo(fromBase58String(assetId)))
279279 let assetName = value(asset.name)
280280 if (if (if (containsElement(allArtefact, assetName))
281281 then true
282282 else isDefined(tryGetCosmeticItemPrice(assetName)))
283283 then (asset.issuer == this)
284284 else false)
285285 then $Tuple2(nil, assetName)
286286 else throw("Invalid artefact")
287287 }
288288
289289
290290
291291 @Callable(i)
292292 func configureOracle (oracle) = if ((i.caller != this))
293293 then throw("admin only")
294294 else [StringEntry(staticKey_oracleAddress(), oracle)]
295295
296296
297297
298298 @Callable(i)
299299 func calculateFarmingPowerBoost (duckId,address) = {
300300 let externalBoostDuck = tryGetInteger(key_externalBoostDuck(duckId))
301301 let externalBoostAddress = tryGetInteger(key_externalBoostAddress(address))
302302 let totalBoost = (externalBoostDuck + externalBoostAddress)
303303 $Tuple2([IntegerEntry((duckId + "_last_boost"), totalBoost)], totalBoost)
304304 }
305305
306306
307307
308308 @Callable(i)
309309 func fixedGene (txIdStr,parentFixedGene,positionFixedGene) = {
310310 let firstPayment = value(i.payments[0])
311311 let firstAssetId = toBase58String(value(firstPayment.assetId))
312312 if ((firstPayment.amount != 1))
313313 then throw("NFT is not attached")
314314 else {
315315 let artefact = asString(invoke(this, "checkArtefactDetails", [firstAssetId], nil))
316316 if ((artefact == artefact))
317317 then if ((artefact != "ART-FIXGENE"))
318318 then throw("You need to attach a ART-FIXGENE artefact")
319319 else {
320320 let txId = fromBase58String(txIdStr)
321321 let finishHeightKey = key_processFinishHeight(toString(i.caller), txId)
322322 let processFinishHeight = getIntegerValue(getBreederAddress(), finishHeightKey)
323323 let duckGenesString = asString(invoke(getBreederAddress(), "generateDuck", [txId, processFinishHeight, parentFixedGene, positionFixedGene, "", 0], nil))
324324 if ((duckGenesString == duckGenesString))
325325 then {
326326 let call = invoke(getBreederAddress(), "finishDuckHatchingItems", [txIdStr, duckGenesString], nil)
327327 if ((call == call))
328328 then [Burn(value(firstPayment.assetId), 1)]
329329 else throw("Strict value is not equal to itself.")
330330 }
331331 else throw("Strict value is not equal to itself.")
332332 }
333333 else throw("Strict value is not equal to itself.")
334334 }
335335 }
336336
337337
338338
339339 @Callable(i)
340340 func freeGene (txIdStr) = {
341341 let firstPayment = value(i.payments[0])
342342 let firstAssetId = toBase58String(value(firstPayment.assetId))
343343 if ((firstPayment.amount != 1))
344344 then throw("NFT is not attached")
345345 else {
346346 let artefact = asString(invoke(this, "checkArtefactDetails", [firstAssetId], nil))
347347 if ((artefact == artefact))
348348 then if ((artefact != "ART-FREEGENE"))
349349 then throw("You need to attach a ART-FREEGENE artefact")
350350 else {
351351 let txId = fromBase58String(txIdStr)
352352 let finishHeightKey = key_processFinishHeight(toString(i.caller), txId)
353353 let processFinishHeight = getIntegerValue(getBreederAddress(), finishHeightKey)
354354 let selectedGene = getRandomGenes(txId, processFinishHeight)
355355 let randomPosition = getRandomNumber(7, txId, processFinishHeight, 3)
356356 let duckGenesString = asString(invoke(getBreederAddress(), "generateDuck", [txId, processFinishHeight, 0, 0, selectedGene, randomPosition], nil))
357357 if ((duckGenesString == duckGenesString))
358358 then {
359359 let call = invoke(getBreederAddress(), "finishDuckHatchingItems", [txIdStr, duckGenesString], nil)
360360 if ((call == call))
361361 then [Burn(value(firstPayment.assetId), 1)]
362362 else throw("Strict value is not equal to itself.")
363363 }
364364 else throw("Strict value is not equal to itself.")
365365 }
366366 else throw("Strict value is not equal to itself.")
367367 }
368368 }
369369
370370
371371
372372 @Callable(i)
373373 func copyDuck () = {
374374 let firstPayment = value(i.payments[0])
375375 let secondPayment = value(i.payments[1])
376376 let firstAssetId = toBase58String(value(firstPayment.assetId))
377377 let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [firstAssetId], nil))
378378 if ((children == children))
379379 then if (if ((firstPayment.amount != 1))
380380 then true
381381 else (secondPayment.amount != 1))
382382 then throw("NFT is not attached")
383383 else {
384384 let artefact = asString(invoke(this, "checkArtefactDetails", [toBase58String(value(secondPayment.assetId))], nil))
385385 if ((artefact == artefact))
386386 then if ((artefact != "ART-MIRROR"))
387387 then throw("You need to attach a ART-MIRROR artefact")
388388 else {
389389 let nftInfo = value(assetInfo(value(firstPayment.assetId)))
390390 let asset1Gen = split(nftInfo.name, "")
391391 if (if ((asset1Gen[14] == "G"))
392392 then true
393393 else (asset1Gen[14] == "J"))
394394 then throw("You can't mirror this duck")
395395 else {
396396 let duckGen = nftInfo.name
397397 let call = invoke(getBreederAddress(), "createDuckSpecialGenes", [i.caller.bytes, duckGen, children], nil)
398398 if ((call == call))
399399 then [ScriptTransfer(i.caller, 1, firstPayment.assetId), Burn(value(secondPayment.assetId), 1)]
400400 else throw("Strict value is not equal to itself.")
401401 }
402402 }
403403 else throw("Strict value is not equal to itself.")
404404 }
405405 else throw("Strict value is not equal to itself.")
406406 }
407407
408408
409409
410410 @Callable(i)
411411 func addArteFactToDuck () = {
412412 let firstPayment = value(i.payments[0])
413413 let secondPayment = value(i.payments[1])
414414 let firstAssetId = toBase58String(value(firstPayment.assetId))
415415 if (if ((firstPayment.amount != 1))
416416 then true
417417 else (secondPayment.amount != 1))
418418 then throw("NFT is not attached")
419419 else {
420420 let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [firstAssetId], nil))
421421 if ((children == children))
422422 then if ((children == 0))
423423 then throw("You can only pick a sterile NFT-duck")
424424 else {
425425 let artefact = asString(invoke(this, "checkArtefactDetails", [toBase58String(value(secondPayment.assetId))], nil))
426426 if ((artefact == artefact))
427427 then if (if ((artefact != "ART-XHAT"))
428428 then (artefact != "ART-POMP")
429429 else false)
430430 then throw("You need to attach a ART-XHAT or ART-POMP artefact")
431431 else {
432432 let nftInfo = value(assetInfo(value(firstPayment.assetId)))
433433 let asset1Gen = split(nftInfo.name, "")
434434 if (if ((asset1Gen[14] == "G"))
435435 then true
436436 else (asset1Gen[14] == "J"))
437437 then throw("You can't mirror this duck")
438438 else if (if ((asset1Gen[5] == "S"))
439439 then true
440440 else (asset1Gen[5] == "T"))
441441 then throw("you already attached a artefact")
442442 else {
443443 let char = if ((artefact == "ART-XHAT"))
444444 then "T"
445445 else if ((artefact == "ART-POMP"))
446446 then "S"
447447 else throw("No char defined")
448448 let oldDuckGen = nftInfo.name
449449 let oldFarmGen = asString(invoke(getBreederAddress(), "getGenFromName", [oldDuckGen], nil))
450450 if ((oldFarmGen == oldFarmGen))
451451 then {
452452 let duckGen = manipulateName(oldDuckGen, 6, char)
453453 let call = invoke(getBreederAddress(), "createDuckSpecialGenes", [i.caller.bytes, duckGen, children], nil)
454454 if ((call == call))
455455 then {
456456 let callReduce = invoke(getBreederAddress(), "reduceRarity", [firstAssetId, oldFarmGen], nil)
457457 if ((callReduce == callReduce))
458458 then [Burn(value(firstPayment.assetId), 1), Burn(value(secondPayment.assetId), 1)]
459459 else throw("Strict value is not equal to itself.")
460460 }
461461 else throw("Strict value is not equal to itself.")
462462 }
463463 else throw("Strict value is not equal to itself.")
464464 }
465465 }
466466 else throw("Strict value is not equal to itself.")
467467 }
468468 else throw("Strict value is not equal to itself.")
469469 }
470470 }
471471
472472
473473
474474 @Callable(i)
475475 func preInit () = [IntegerEntry("static_ART-LAKE_farmingSlots", 200), IntegerEntry("static_ART-LAKE_farmingBoost", 2), IntegerEntry("static_ART-HOUSE_farmingSlots", 4), IntegerEntry("static_ART-HOUSE_farmingBoost", 30), IntegerEntry("static_ART-BIGHOUSE_farmingSlots", 10), IntegerEntry("static_ART-BIGHOUSE_farmingBoost", 15)]
476476
477477
478478
479479 @Callable(i)
480480 func issueArtefact (type,receiver) = if (if ((i.caller != this))
481481 then (i.caller != getRebirthAddress())
482482 else false)
483483 then throw("admin only")
484484 else {
485485 let txIdStr = toBase58String(i.transactionId)
486486 let address = Address(fromBase58String(receiver))
487487 let artefact = Issue(type, "NFT artefact of Waves Ducks game. Drop #2.", 1, 0, false, unit, 0)
488488 let artefactId = calculateAssetId(artefact)
489489 $Tuple2([artefact, StringEntry((("artefact_" + toBase58String(artefactId)) + "_type"), type), ScriptTransfer(address, 1, artefactId)], toBase58String(artefactId))
490490 }
491491
492492
493493
494494 @Callable(i)
495495 func setLock (n) = if ((i.caller == this))
496496 then [IntegerEntry("global_locked", n)]
497497 else throw("admin only")
498498
499499
500500
501501 @Callable(i)
502502 func buyArtefact () = if ((lastBlock.timestamp > 1639742400000))
503503 then throw("There are no active sales now... ")
504504 else if ((tryGetInteger("global_locked") > 0))
505505 then throw("contract is temporarily locked")
506506 else if ((tryGetInteger("global_artAmount") >= artefactsLimit))
507507 then throw("SOLDOUT!!! Hurray!")
508508 else if (if ((1639605600000 > lastBlock.timestamp))
509509 then (i.caller != Address(devAddress))
510510 else false)
511511 then throw("Too early...")
512512 else {
513513 let firstPayment = value(i.payments[0])
514514 if ((firstPayment.assetId != getEggAssetId()))
515515 then throw(("You can attach only EGG tokens with the following asset id: " + toBase58String(getEggAssetId())))
516516 else if ((eggsNeeded > firstPayment.amount))
517517 then throw(("To hatch a duck you currently need the following amount of EGGlets: " + toString(eggsNeeded)))
518518 else [StringEntry((((toString(i.caller) + "_") + toBase58String(i.transactionId)) + "_status"), "started"), IntegerEntry((((toString(i.caller) + "_") + toBase58String(i.transactionId)) + "_finishHeight"), (height + 2)), IntegerEntry("global_artAmount", (tryGetInteger("global_artAmount") + 1))]
519519 }
520520
521521
522522
523523 @Callable(i)
524524 func setGlobalArtAmount (newAmount) = if (if ((i.caller == this))
525525 then true
526526 else (i.caller == Address(devAddress)))
527527 then [IntegerEntry("global_artAmount", newAmount)]
528528 else throw("Permission denied")
529529
530530
531531
532532 @Callable(i)
533533 func claimArtefact (boxIdStr) = {
534534 let txId = fromBase58String(boxIdStr)
535535 let statusKey = (((toString(i.caller) + "_") + boxIdStr) + "_status")
536536 let heightKey = (((toString(i.caller) + "_") + boxIdStr) + "_finishHeight")
537537 if ((getStringValue(statusKey) != "started"))
538538 then throw("claimed already")
539539 else if ((getIntegerValue(heightKey) > height))
540540 then throw("you cannot claim yet")
541541 else {
542542 let artType = getRandomArtefact(txId, getIntegerValue(heightKey))
543543 let asset = Issue(artType, "Artefact of Waves Ducks metaverse.", 1, 0, false, unit, getIntegerValue(heightKey))
544544 let assetId = calculateAssetId(asset)
545545 [StringEntry(statusKey, artType), StringEntry((((toString(i.caller) + "_") + boxIdStr) + "_artefactId"), toBase58String(assetId)), StringEntry((toBase58String(assetId) + "_type"), artType), asset, ScriptTransfer(i.caller, 1, assetId)]
546546 }
547547 }
548548
549549
550550 @Verifier(tx)
551551 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
552552

github/deemru/w8io/3ef1775 
50.20 ms