2023.04.04 20:29 [3585740] smart account 3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR > SELF 0.00000000 Waves

{ "type": 13, "id": "T51BRMYhF1KvnSSyD5Mkz1Suatxs3KHJxsm2EMQVoVu", "fee": 2100000, "feeAssetId": null, "timestamp": 1680629308540, "version": 2, "chainId": 87, "sender": "3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR", "senderPublicKey": "6DknLGEJHLXmZB6ni3tGa8M3gccMMmc3uaaPhvCSuKvM", "proofs": [ "TyDbsNFg7T3HApKEPpdGzPbdxuU4a48Zr7C2qh8bu5Ryum8HZ5nrLtE6rpvqGzx4hmKNykWeLxkZCtJRGmSvCq9", "5Wcm8LM7vM8QXCnp1rk5E3nncBaU1WES6jcfHTe4Cs1opkkCaNX7y3C34nQpWuD3C3dRHBYwmtMtscMYtj1eBhcT" ], "script": "base64:BgJYCAISAwoBCBIECgIBCBIECgIBCBIDCgEIEgMKAQgSBAoCCAgSBQoDCAEBEgMKAQgSABIAEgASBAoCCAgSAwoBARIAEgoKCAEIAQQIAQEBEgMKAQESAwoBCC0BF3N0YXRpY0tleV9vcmFjbGVBZGRyZXNzAAIUc3RhdGljX29yYWNsZUFkZHJlc3MBGHN0YXRpY0tleV9icmVlZGVyQWRkcmVzcwACFXN0YXRpY19icmVlZGVyQWRkcmVzcwEUc3RhdGljS2V5X2VnZ0Fzc2V0SWQAAhFzdGF0aWNfZWdnQXNzZXRJZAEac3RhdGljS2V5X3RydXN0ZWRDb250cmFjdHMAAhdzdGF0aWNfdHJ1c3RlZENvbnRyYWN0cwEYc3RhdGljS2V5X3JlYmlydGhBZGRyZXNzAAIVc3RhdGljX3JlYmlydGhBZGRyZXNzARZzdGF0aWNLZXlfcGlwZWxpbmVVc2VyAAITc3RhdGljX3BpcGVsaW5lVXNlcgERa2V5X2FydGVmYWN0T3duZXICDGFydGVmYWN0TmFtZQVvd25lcgkArAICCQCsAgIJAKwCAgUMYXJ0ZWZhY3ROYW1lAgFfBQVvd25lcgIGX293bmVyARFrZXlfdW5zdGFrZUhlaWdodAIMYXJ0ZWZhY3ROYW1lCmFydGVmYWN0SWQJAKwCAgkArAICCQCsAgIFDGFydGVmYWN0TmFtZQIBXwUKYXJ0ZWZhY3RJZAIPX3Vuc3Rha2VfaGVpZ2h0ARVrZXlfZXh0ZXJuYWxCb29zdER1Y2sBBmR1Y2tJZAkArAICBQZkdWNrSWQCFF9kdWNrX2V4dGVybmFsX2Jvb3N0ARhrZXlfZXh0ZXJuYWxCb29zdEFkZHJlc3MBB2FkZHJlc3MJAKwCAgUHYWRkcmVzcwIUX3VzZXJfZXh0ZXJuYWxfYm9vc3QBEWtleV9wcmljZUNvc21ldGljAQRpdGVtCQCsAgICEGRpcmVjdF9jb3NtZXRpY18FBGl0ZW0BFGtleV9tYXhTYWxlc0Nvc21ldGljAQRpdGVtCQCsAgIJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQIKX21heF9zYWxlcwEQa2V5X3NhbGVDb3NtZXRpYwEEaXRlbQkArAICCQCsAgICEGRpcmVjdF9jb3NtZXRpY18FBGl0ZW0CBV9zYWxlARZrZXlfcHJpY2VBc3NldENvc21ldGljAQRpdGVtCQCsAgIJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQILX3ByaWNlQXNzZXQBGmtleV9ncm93UGVyY2VudGFnZUNvc21ldGljAQRpdGVtCQCsAgIJAKwCAgIQZGlyZWN0X2Nvc21ldGljXwUEaXRlbQITX2dyb3dpbmdfcGVyY2VudGFnZQEQa2V5X3NvbGRDb3NtZXRpYwEEaXRlbQkArAICCQCsAgICEGRpcmVjdF9jb3NtZXRpY18FBGl0ZW0CBV9zb2xkARVrZXlfbGFzdFByaWNlQ29zbWV0aWMBBGl0ZW0JAKwCAgkArAICAhBkaXJlY3RfY29zbWV0aWNfBQRpdGVtAgtfbGFzdF9wcmljZQETa2V5X3N0YXJ0VHNDb3NtZXRpYwEEaXRlbQkArAICCQCsAgICEGRpcmVjdF9jb3NtZXRpY18FBGl0ZW0CCF9zdGFydFRzARFrZXlfZW5kVHNDb3NtZXRpYwEEaXRlbQkArAICCQCsAgICEGRpcmVjdF9jb3NtZXRpY18FBGl0ZW0CBl9lbmRUcwEXa2V5X3Byb2Nlc3NGaW5pc2hIZWlnaHQCB2FkZHJlc3MEdHhJZAkArAICCQCsAgIJAKwCAgUHYWRkcmVzcwIBXwkA2AQBBQR0eElkAgNfZmgACmRldkFkZHJlc3MBGgFXF3fYQk8hOgpGT8vir4YiaxOc51un3nx7AAplZ2dzTmVlZGVkCQBoAgADAIDC1y8ADmFydGVmYWN0c0xpbWl0CQBkAgCtAgDYBAAJZnJlZUdlbmVzCQDMCAICAUEJAMwIAgIBQgkAzAgCAgFDCQDMCAICAUQJAMwIAgIBRQkAzAgCAgFGBQNuaWwADG9sZEFydGVmYWN0cwkAzAgCAghBUlQtTEFLRQkAzAgCAglBUlQtSE9VU0UJAMwIAgIMQVJULUJJR0hPVVNFCQDMCAICC0FSVC1GSVhHRU5FCQDMCAICDEFSVC1GUkVFR0VORQkAzAgCAgpBUlQtTUlSUk9SCQDMCAICCEFSVC1QT01QCQDMCAICCEFSVC1DQVBFCQDMCAICB0FSVC1IQVQJAMwIAgIOQVJULUNVU1RPTURVQ0sFA25pbAAJYXJ0ZWZhY3RzCQDMCAICCkFSVC1YTUlTVEwJAMwIAgIIQVJULVhIQVQJAMwIAgIKQVJULVhTQ0FSRgkAzAgCAgxBUlQtWFNXRUFURVIJAMwIAgIJQVJULVhTT0NLCQDMCAICCUFSVC1YVFJFRQUDbmlsAAthbGxBcnRlZmFjdAkAzggCBQlhcnRlZmFjdHMFDG9sZEFydGVmYWN0cwENdHJ5R2V0Qm9vbGVhbgEDa2V5BAckbWF0Y2gwCQCbCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFiBQckbWF0Y2gwBQFiBwEMdHJ5R2V0U3RyaW5nAQNrZXkEByRtYXRjaDAJAJ0IAgUEdGhpcwUDa2V5AwkAAQIFByRtYXRjaDACBlN0cmluZwQBYQUHJG1hdGNoMAUBYQIAAQ10cnlHZXRJbnRlZ2VyAQNrZXkEByRtYXRjaDAJAJoIAgUEdGhpcwUDa2V5AwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQAAAQ9nZXRSYW5kb21OdW1iZXIECHZhcmlhbnRzBHR4SWQMZmluaXNoSGVpZ2h0Bm9mZnNldAQPcmFuZG9tU2VlZEJsb2NrCQEFdmFsdWUBCQDtBwEJAGUCBQxmaW5pc2hIZWlnaHQAAQQKcmFuZG9tSGFzaAkA9wMBCQDLAQIJAMsBAgEEHEF95gUEdHhJZAkBBXZhbHVlAQgFD3JhbmRvbVNlZWRCbG9jawN2cmYJAGoCCQCyCQIFCnJhbmRvbUhhc2gFBm9mZnNldAUIdmFyaWFudHMBEWdldFJhbmRvbUFydGVmYWN0AgVib3hJZAFoBAxyYW5kb21OdW1iZXIJAQ9nZXRSYW5kb21OdW1iZXIEAAYFBWJveElkBQFoAAEJAJEDAgUJYXJ0ZWZhY3RzBQxyYW5kb21OdW1iZXIBDmdldFJhbmRvbUdlbmVzAgR0eElkAWgEDHJhbmRvbU51bWJlcgkBD2dldFJhbmRvbU51bWJlcgQABgUEdHhJZAUBaAACCQCRAwIFCWZyZWVHZW5lcwUMcmFuZG9tTnVtYmVyARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIHYWRkcmVzcwNrZXkEByRtYXRjaDAJAJ0IAgUHYWRkcmVzcwUDa2V5AwkAAQIFByRtYXRjaDACBlN0cmluZwQBYQUHJG1hdGNoMAUBYQIAAQlnZXRPcmFjbGUACQEHQWRkcmVzcwEJANkEAQkBDHRyeUdldFN0cmluZwEJARdzdGF0aWNLZXlfb3JhY2xlQWRkcmVzcwABEWdldEJyZWVkZXJBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEYc3RhdGljS2V5X2JyZWVkZXJBZGRyZXNzAAENZ2V0RWdnQXNzZXRJZAAJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARRzdGF0aWNLZXlfZWdnQXNzZXRJZAABE2dldFRydXN0ZWRDb250cmFjdHMACQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBGnN0YXRpY0tleV90cnVzdGVkQ29udHJhY3RzAAERZ2V0UmViaXJ0aEFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARhzdGF0aWNLZXlfcmViaXJ0aEFkZHJlc3MAARd0cnlHZXRDb3NtZXRpY0l0ZW1QcmljZQEEaXRlbQQDa2V5CQERa2V5X3ByaWNlQ29zbWV0aWMBBQRpdGVtBAckbWF0Y2gwCQCaCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgNJbnQEAWEFByRtYXRjaDAFAWEJAAIBAjBJVEdDSVA6IFRoaXMgaXRlbSBpcyBub3QgYXZhaWxhYmxlIGluIHRoZSBzdG9yZSEBCGFzU3RyaW5nAQV2YWx1ZQQHJG1hdGNoMAUFdmFsdWUDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAZzdHJpbmcFByRtYXRjaDAFBnN0cmluZwkAAgECHHdyb25nIHR5cGUsIGV4cGVjdGVkOiBTdHJpbmcBBWFzSW50AQV2YWx1ZQQHJG1hdGNoMAUFdmFsdWUDCQABAgUHJG1hdGNoMAIDSW50BANpbnQFByRtYXRjaDAFA2ludAkAAgECGXdyb25nIHR5cGUsIGV4cGVjdGVkOiBJbnQBDm1hbmlwdWxhdGVOYW1lAwlhc3NldE5hbWUIcG9zaXRpb24EY2hhcgkArAICCQCsAgIJAK8CAgUJYXNzZXROYW1lCQBlAgUIcG9zaXRpb24AAQUEY2hhcgkAsgICBQlhc3NldE5hbWUJAGUCABAFCHBvc2l0aW9uARBpdGVtSXNJbkNvb2xEb3duAgxhcnRlZmFjdE5hbWUKYXJ0ZWZhY3RJZAQRdW5zdGFrZUhlaWdodExhc3QJAQ10cnlHZXRJbnRlZ2VyAQkBEWtleV91bnN0YWtlSGVpZ2h0AgUMYXJ0ZWZhY3ROYW1lBQphcnRlZmFjdElkBA5jb29sZG93blBlcmlvZADwAQMJAGYCBQZoZWlnaHQJAGQCBRF1bnN0YWtlSGVpZ2h0TGFzdAUOY29vbGRvd25QZXJpb2QHBgEJaXNUZXN0RW52AAkBDXRyeUdldEJvb2xlYW4BAgdURVNURU5WEQFpAQ1kaXJlY3RCdXlJdGVtAQhpdGVtTmFtZQQJYmFzZVByaWNlCQEXdHJ5R2V0Q29zbWV0aWNJdGVtUHJpY2UBBQhpdGVtTmFtZQQEZ3JvdwkBDXRyeUdldEludGVnZXIBCQEaa2V5X2dyb3dQZXJjZW50YWdlQ29zbWV0aWMBBQhpdGVtTmFtZQQHc3RhcnRUcwkBDXRyeUdldEludGVnZXIBCQETa2V5X3N0YXJ0VHNDb3NtZXRpYwEFCGl0ZW1OYW1lBAVlbmRUcwkBDXRyeUdldEludGVnZXIBCQERa2V5X2VuZFRzQ29zbWV0aWMBBQhpdGVtTmFtZQMDCQECIT0CBQdzdGFydFRzAAAJAGYCBQdzdGFydFRzCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAcJAAIBAiFJREJJOiBUaGUgc2FsZSBkaWQgbm90IHN0YXJ0IHlldCEDAwkBAiE9AgUFZW5kVHMAAAkAZgIIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQVlbmRUcwcJAAIBAiRJREJJOiBUaGUgc2FsZSBoYXMgYWxyZWFkeSBmaW5pc2hlZCEDCQEBIQEJAQ10cnlHZXRCb29sZWFuAQkBEGtleV9zYWxlQ29zbWV0aWMBBQhpdGVtTmFtZQkAAgEJAKwCAgIfSURCSTogSXRlbSBub3QgZm9yIHNhbGUgYW55bW9yZQkBEGtleV9zYWxlQ29zbWV0aWMBBQhpdGVtTmFtZQQNbWF4U2FsZXNWYWx1ZQkBDXRyeUdldEludGVnZXIBCQEUa2V5X21heFNhbGVzQ29zbWV0aWMBBQhpdGVtTmFtZQQJc29sZFZhbHVlCQENdHJ5R2V0SW50ZWdlcgEJARBrZXlfc29sZENvc21ldGljAQUIaXRlbU5hbWUEBXByaWNlAwkAAAIFBGdyb3cAAAUJYmFzZVByaWNlCQBkAgUJYmFzZVByaWNlCQBoAgkAaQIFCWJhc2VQcmljZQBkCQBoAgUJc29sZFZhbHVlBQRncm93AwMJAQIhPQIFDW1heFNhbGVzVmFsdWUAAAkAZwIFCXNvbGRWYWx1ZQUNbWF4U2FsZXNWYWx1ZQcJAAIBAhhJREJJOiBNYXggZWRpdGlvbnMgc29sZCEEB2Fzc2V0SWQDCQAAAgkBDHRyeUdldFN0cmluZwEJARZrZXlfcHJpY2VBc3NldENvc21ldGljAQUIaXRlbU5hbWUCAAkBDWdldEVnZ0Fzc2V0SWQAAwkAAAIJAQx0cnlHZXRTdHJpbmcBCQEWa2V5X3ByaWNlQXNzZXRDb3NtZXRpYwEFCGl0ZW1OYW1lAgVXQVZFUwUEdW5pdAkA2QQBCQEMdHJ5R2V0U3RyaW5nAQkBFmtleV9wcmljZUFzc2V0Q29zbWV0aWMBBQhpdGVtTmFtZQQTYW1vdW50UGFpZEJ5Q291cG9ucwAABAlsZWZ0VG9QYXkJAGUCBQVwcmljZQUTYW1vdW50UGFpZEJ5Q291cG9ucwQHcGF5bWVudAMJAQIhPQIFCWxlZnRUb1BheQAABAxmaXJzdFBheW1lbnQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQGYW1vdW50CAUMZmlyc3RQYXltZW50BmFtb3VudAMJAQIhPQIIBQxmaXJzdFBheW1lbnQHYXNzZXRJZAUHYXNzZXRJZAkAAgECOklEQkk6IFlvdSBjYW4gYXR0YWNoIG9ubHkgdG9rZW5zIHdpdGggdGhlIGNvcnJlY3QgcGF5bWVudCADCQECIT0CBQZhbW91bnQFCWxlZnRUb1BheQkAAgEJAKwCAgIqSURCSTogUGxlYXNlIGF0dGFjaCB0aGUgZXhhY3QgYXNzZXQgYW1vdW50CQCkAwEFBXByaWNlBQlsZWZ0VG9QYXkAAAMJAAACBQdwYXltZW50BQdwYXltZW50BAd0eElkU3RyCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQEB2FkZHJlc3MIBQFpDG9yaWdpbkNhbGxlcgQIYXJ0ZWZhY3QJAMMIBwUIaXRlbU5hbWUJAKwCAgIiTkZUIGFydGVmYWN0IG9mIFdhdmVzIER1Y2tzIGdhbWU6IAUIaXRlbU5hbWUAAQAABwUEdW5pdAAABAphcnRlZmFjdElkCQC4CAEFCGFydGVmYWN0CQCUCgIJAMwIAgUIYXJ0ZWZhY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICCWFydGVmYWN0XwkA2AQBBQphcnRlZmFjdElkAgVfdHlwZQUIaXRlbU5hbWUJAMwIAgkBDEludGVnZXJFbnRyeQIJARVrZXlfbGFzdFByaWNlQ29zbWV0aWMBBQhpdGVtTmFtZQUFcHJpY2UJAMwIAgkBDEludGVnZXJFbnRyeQIJARBrZXlfc29sZENvc21ldGljAQUIaXRlbU5hbWUJAGQCBQlzb2xkVmFsdWUAAQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQdhZGRyZXNzAAEFCmFydGVmYWN0SWQFA25pbAkA2AQBBQphcnRlZmFjdElkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBD21hbmlwdWxhdGVCb29zdAIFYm9vc3QGZHVja0lkBBBhbGxvd2VkQ29udHJhY3RzCQETZ2V0VHJ1c3RlZENvbnRyYWN0cwAEFGFsbG93ZWRDb250cmFjdHNMaXN0CQC1CQIFEGFsbG93ZWRDb250cmFjdHMCATsECmRhcHBUb0NhbGwJAKUIAQgFAWkGY2FsbGVyAwkAAAIJAM8IAgUUYWxsb3dlZENvbnRyYWN0c0xpc3QFCmRhcHBUb0NhbGwFBHVuaXQJAAIBAjRJTUI6IFRoaXMgc21hcnQgY29udHJhY3QgY2FuJ3QgbWFuaXB1bGF0ZSB0aGUgYm9vc3QhBANrZXkJARVrZXlfZXh0ZXJuYWxCb29zdER1Y2sBBQZkdWNrSWQEC2FjdGl2ZUJvb3N0CQENdHJ5R2V0SW50ZWdlcgEFA2tleQQIbmV3Qm9vc3QJAGQCBQthY3RpdmVCb29zdAUFYm9vc3QDCQBmAgAABQhuZXdCb29zdAkAAgECQElNQjogU29tZXRoaW5nIHdlbnQgd3Jvbmcgd2l0aCBib29zdCwgcGxlYXNlIGNvbnRhY3QgdGhlIGFkbWlucyEJAMwIAgkBDEludGVnZXJFbnRyeQIFA2tleQUIbmV3Qm9vc3QFA25pbAFpARZtYW5pcHVsYXRlQm9vc3RBY2NvdW50AgVib29zdAdhZGRyZXNzBBBhbGxvd2VkQ29udHJhY3RzCQETZ2V0VHJ1c3RlZENvbnRyYWN0cwAEFGFsbG93ZWRDb250cmFjdHNMaXN0CQC1CQIFEGFsbG93ZWRDb250cmFjdHMCATsECmRhcHBUb0NhbGwJAKUIAQgFAWkGY2FsbGVyAwkAAAIJAM8IAgUUYWxsb3dlZENvbnRyYWN0c0xpc3QFCmRhcHBUb0NhbGwFBHVuaXQJAAIBAjVJTUJBOiBUaGlzIHNtYXJ0IGNvbnRyYWN0IGNhbid0IG1hbmlwdWxhdGUgdGhlIGJvb3N0IQQDa2V5CQEYa2V5X2V4dGVybmFsQm9vc3RBZGRyZXNzAQUHYWRkcmVzcwQLYWN0aXZlQm9vc3QJAQ10cnlHZXRJbnRlZ2VyAQUDa2V5BAhuZXdCb29zdAkAZAIFC2FjdGl2ZUJvb3N0BQVib29zdAMJAGYCAAAFCG5ld0Jvb3N0CQACAQJBSU1CQTogU29tZXRoaW5nIHdlbnQgd3Jvbmcgd2l0aCBib29zdCwgcGxlYXNlIGNvbnRhY3QgdGhlIGFkbWlucyEJAMwIAgkBDEludGVnZXJFbnRyeQIFA2tleQUIbmV3Qm9vc3QFA25pbAFpARRjaGVja0FydGVmYWN0RGV0YWlscwEHYXNzZXRJZAQFYXNzZXQJAQV2YWx1ZQEJAOwHAQkA2QQBBQdhc3NldElkBAlhc3NldE5hbWUJAQV2YWx1ZQEIBQVhc3NldARuYW1lAwMDCQEPY29udGFpbnNFbGVtZW50AgULYWxsQXJ0ZWZhY3QFCWFzc2V0TmFtZQYJAQlpc0RlZmluZWQBCQEXdHJ5R2V0Q29zbWV0aWNJdGVtUHJpY2UBBQlhc3NldE5hbWUJAAACCAUFYXNzZXQGaXNzdWVyBQR0aGlzBwkAlAoCBQNuaWwFCWFzc2V0TmFtZQkAAgECEEludmFsaWQgYXJ0ZWZhY3QBaQEPY29uZmlndXJlT3JhY2xlAQZvcmFjbGUDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgphZG1pbiBvbmx5CQDMCAIJAQtTdHJpbmdFbnRyeQIJARdzdGF0aWNLZXlfb3JhY2xlQWRkcmVzcwAFBm9yYWNsZQUDbmlsAWkBGmNhbGN1bGF0ZUZhcm1pbmdQb3dlckJvb3N0AgZkdWNrSWQHYWRkcmVzcwQRZXh0ZXJuYWxCb29zdER1Y2sJAQ10cnlHZXRJbnRlZ2VyAQkBFWtleV9leHRlcm5hbEJvb3N0RHVjawEFBmR1Y2tJZAQUZXh0ZXJuYWxCb29zdEFkZHJlc3MJAQ10cnlHZXRJbnRlZ2VyAQkBGGtleV9leHRlcm5hbEJvb3N0QWRkcmVzcwEFB2FkZHJlc3MECnRvdGFsQm9vc3QJAGQCBRFleHRlcm5hbEJvb3N0RHVjawUUZXh0ZXJuYWxCb29zdEFkZHJlc3MJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQZkdWNrSWQCC19sYXN0X2Jvb3N0BQp0b3RhbEJvb3N0BQNuaWwFCnRvdGFsQm9vc3QBaQEJZml4ZWRHZW5lAwd0eElkU3RyD3BhcmVudEZpeGVkR2VuZRFwb3NpdGlvbkZpeGVkR2VuZQQMZmlyc3RQYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAEDGZpcnN0QXNzZXRJZAkA2AQBCQEFdmFsdWUBCAUMZmlyc3RQYXltZW50B2Fzc2V0SWQDCQECIT0CCAUMZmlyc3RQYXltZW50BmFtb3VudAABCQACAQITTkZUIGlzIG5vdCBhdHRhY2hlZAQIYXJ0ZWZhY3QJAQhhc1N0cmluZwEJAPwHBAUEdGhpcwIUY2hlY2tBcnRlZmFjdERldGFpbHMJAMwIAgUMZmlyc3RBc3NldElkBQNuaWwFA25pbAMJAAACBQhhcnRlZmFjdAUIYXJ0ZWZhY3QDCQECIT0CBQhhcnRlZmFjdAILQVJULUZJWEdFTkUJAAIBAilZb3UgbmVlZCB0byBhdHRhY2ggYSBBUlQtRklYR0VORSBhcnRlZmFjdAQEdHhJZAkA2QQBBQd0eElkU3RyBA9maW5pc2hIZWlnaHRLZXkJARdrZXlfcHJvY2Vzc0ZpbmlzaEhlaWdodAIJAKUIAQgFAWkGY2FsbGVyBQR0eElkBBNwcm9jZXNzRmluaXNoSGVpZ2h0CQERQGV4dHJOYXRpdmUoMTA1MCkCCQERZ2V0QnJlZWRlckFkZHJlc3MABQ9maW5pc2hIZWlnaHRLZXkED2R1Y2tHZW5lc1N0cmluZwkBCGFzU3RyaW5nAQkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAgxnZW5lcmF0ZUR1Y2sJAMwIAgUEdHhJZAkAzAgCBRNwcm9jZXNzRmluaXNoSGVpZ2h0CQDMCAIFD3BhcmVudEZpeGVkR2VuZQkAzAgCBRFwb3NpdGlvbkZpeGVkR2VuZQkAzAgCAgAJAMwIAgAABQNuaWwFA25pbAMJAAACBQ9kdWNrR2VuZXNTdHJpbmcFD2R1Y2tHZW5lc1N0cmluZwQEY2FsbAkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhdmaW5pc2hEdWNrSGF0Y2hpbmdJdGVtcwkAzAgCBQd0eElkU3RyCQDMCAIFD2R1Y2tHZW5lc1N0cmluZwUDbmlsBQNuaWwDCQAAAgUEY2FsbAUEY2FsbAkAzAgCCQEEQnVybgIJAQV2YWx1ZQEIBQxmaXJzdFBheW1lbnQHYXNzZXRJZAABBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIZnJlZUdlbmUBB3R4SWRTdHIEDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABAxmaXJzdEFzc2V0SWQJANgEAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkAwkBAiE9AggFDGZpcnN0UGF5bWVudAZhbW91bnQAAQkAAgECE05GVCBpcyBub3QgYXR0YWNoZWQECGFydGVmYWN0CQEIYXNTdHJpbmcBCQD8BwQFBHRoaXMCFGNoZWNrQXJ0ZWZhY3REZXRhaWxzCQDMCAIFDGZpcnN0QXNzZXRJZAUDbmlsBQNuaWwDCQAAAgUIYXJ0ZWZhY3QFCGFydGVmYWN0AwkBAiE9AgUIYXJ0ZWZhY3QCDEFSVC1GUkVFR0VORQkAAgECKllvdSBuZWVkIHRvIGF0dGFjaCBhIEFSVC1GUkVFR0VORSBhcnRlZmFjdAQEdHhJZAkA2QQBBQd0eElkU3RyBA9maW5pc2hIZWlnaHRLZXkJARdrZXlfcHJvY2Vzc0ZpbmlzaEhlaWdodAIJAKUIAQgFAWkGY2FsbGVyBQR0eElkBBNwcm9jZXNzRmluaXNoSGVpZ2h0CQERQGV4dHJOYXRpdmUoMTA1MCkCCQERZ2V0QnJlZWRlckFkZHJlc3MABQ9maW5pc2hIZWlnaHRLZXkEDHNlbGVjdGVkR2VuZQkBDmdldFJhbmRvbUdlbmVzAgUEdHhJZAUTcHJvY2Vzc0ZpbmlzaEhlaWdodAQOcmFuZG9tUG9zaXRpb24JAQ9nZXRSYW5kb21OdW1iZXIEAAcFBHR4SWQFE3Byb2Nlc3NGaW5pc2hIZWlnaHQAAwQPZHVja0dlbmVzU3RyaW5nCQEIYXNTdHJpbmcBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACDGdlbmVyYXRlRHVjawkAzAgCBQR0eElkCQDMCAIFE3Byb2Nlc3NGaW5pc2hIZWlnaHQJAMwIAgAACQDMCAIAAAkAzAgCBQxzZWxlY3RlZEdlbmUJAMwIAgUOcmFuZG9tUG9zaXRpb24FA25pbAUDbmlsAwkAAAIFD2R1Y2tHZW5lc1N0cmluZwUPZHVja0dlbmVzU3RyaW5nBARjYWxsCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACF2ZpbmlzaER1Y2tIYXRjaGluZ0l0ZW1zCQDMCAIFB3R4SWRTdHIJAMwIAgUPZHVja0dlbmVzU3RyaW5nBQNuaWwFA25pbAMJAAACBQRjYWxsBQRjYWxsCQDMCAIJAQRCdXJuAgkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkAAEFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQhjb3B5RHVjawAEDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABA1zZWNvbmRQYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAEEDGZpcnN0QXNzZXRJZAkA2AQBCQEFdmFsdWUBCAUMZmlyc3RQYXltZW50B2Fzc2V0SWQECGNoaWxkcmVuCQEFYXNJbnQBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACFnZhbGlkYXRlQW5kR2V0Q2hpbGRyZW4JAMwIAgUMZmlyc3RBc3NldElkBQNuaWwFA25pbAMJAAACBQhjaGlsZHJlbgUIY2hpbGRyZW4DAwkBAiE9AggFDGZpcnN0UGF5bWVudAZhbW91bnQAAQYJAQIhPQIIBQ1zZWNvbmRQYXltZW50BmFtb3VudAABCQACAQITTkZUIGlzIG5vdCBhdHRhY2hlZAQIYXJ0ZWZhY3QJAQhhc1N0cmluZwEJAPwHBAUEdGhpcwIUY2hlY2tBcnRlZmFjdERldGFpbHMJAMwIAgkA2AQBCQEFdmFsdWUBCAUNc2Vjb25kUGF5bWVudAdhc3NldElkBQNuaWwFA25pbAMJAAACBQhhcnRlZmFjdAUIYXJ0ZWZhY3QDCQECIT0CBQhhcnRlZmFjdAIKQVJULU1JUlJPUgkAAgECKFlvdSBuZWVkIHRvIGF0dGFjaCBhIEFSVC1NSVJST1IgYXJ0ZWZhY3QEB25mdEluZm8JAQV2YWx1ZQEJAOwHAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkBAlhc3NldDFHZW4JALUJAggFB25mdEluZm8EbmFtZQIAAwMJAAACCQCRAwIFCWFzc2V0MUdlbgAOAgFHBgkAAAIJAJEDAgUJYXNzZXQxR2VuAA4CAUoJAAIBAhpZb3UgY2FuJ3QgbWlycm9yIHRoaXMgZHVjawQHZHVja0dlbggFB25mdEluZm8EbmFtZQQEY2FsbAkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhZjcmVhdGVEdWNrU3BlY2lhbEdlbmVzCQDMCAIICAUBaQZjYWxsZXIFYnl0ZXMJAMwIAgUHZHVja0dlbgkAzAgCBQhjaGlsZHJlbgUDbmlsBQNuaWwDCQAAAgUEY2FsbAUEY2FsbAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIAAQgFDGZpcnN0UGF5bWVudAdhc3NldElkCQDMCAIJAQRCdXJuAgkBBXZhbHVlAQgFDXNlY29uZFBheW1lbnQHYXNzZXRJZAABBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQERYWRkQXJ0ZUZhY3RUb0R1Y2sABAxmaXJzdFBheW1lbnQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQNc2Vjb25kUGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwABBAxmaXJzdEFzc2V0SWQJANgEAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkAwMJAQIhPQIIBQxmaXJzdFBheW1lbnQGYW1vdW50AAEGCQECIT0CCAUNc2Vjb25kUGF5bWVudAZhbW91bnQAAQkAAgECE05GVCBpcyBub3QgYXR0YWNoZWQECGNoaWxkcmVuCQEFYXNJbnQBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACFnZhbGlkYXRlQW5kR2V0Q2hpbGRyZW4JAMwIAgUMZmlyc3RBc3NldElkBQNuaWwFA25pbAMJAAACBQhjaGlsZHJlbgUIY2hpbGRyZW4DCQAAAgUIY2hpbGRyZW4AAAkAAgECJFlvdSBjYW4gb25seSBwaWNrIGEgc3RlcmlsZSBORlQtZHVjawQIYXJ0ZWZhY3QJAQhhc1N0cmluZwEJAPwHBAUEdGhpcwIUY2hlY2tBcnRlZmFjdERldGFpbHMJAMwIAgkA2AQBCQEFdmFsdWUBCAUNc2Vjb25kUGF5bWVudAdhc3NldElkBQNuaWwFA25pbAMJAAACBQhhcnRlZmFjdAUIYXJ0ZWZhY3QDAwkBAiE9AgUIYXJ0ZWZhY3QCCEFSVC1YSEFUCQECIT0CBQhhcnRlZmFjdAIIQVJULVBPTVAHCQACAQIyWW91IG5lZWQgdG8gYXR0YWNoIGEgQVJULVhIQVQgb3IgQVJULVBPTVAgYXJ0ZWZhY3QEB25mdEluZm8JAQV2YWx1ZQEJAOwHAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkBAlhc3NldDFHZW4JALUJAggFB25mdEluZm8EbmFtZQIAAwMJAAACCQCRAwIFCWFzc2V0MUdlbgAOAgFHBgkAAAIJAJEDAgUJYXNzZXQxR2VuAA4CAUoJAAIBAhpZb3UgY2FuJ3QgbWlycm9yIHRoaXMgZHVjawMDCQAAAgkAkQMCBQlhc3NldDFHZW4ABQIBUwYJAAACCQCRAwIFCWFzc2V0MUdlbgAFAgFUCQACAQIfeW91IGFscmVhZHkgYXR0YWNoZWQgYSBhcnRlZmFjdAQEY2hhcgMJAAACBQhhcnRlZmFjdAIIQVJULVhIQVQCAVQDCQAAAgUIYXJ0ZWZhY3QCCEFSVC1QT01QAgFTCQACAQIPTm8gY2hhciBkZWZpbmVkBApvbGREdWNrR2VuCAUHbmZ0SW5mbwRuYW1lBApvbGRGYXJtR2VuCQEIYXNTdHJpbmcBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACDmdldEdlbkZyb21OYW1lCQDMCAIFCm9sZER1Y2tHZW4FA25pbAUDbmlsAwkAAAIFCm9sZEZhcm1HZW4FCm9sZEZhcm1HZW4EB2R1Y2tHZW4JAQ5tYW5pcHVsYXRlTmFtZQMFCm9sZER1Y2tHZW4ABgUEY2hhcgQEY2FsbAkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhZjcmVhdGVEdWNrU3BlY2lhbEdlbmVzCQDMCAIICAUBaQZjYWxsZXIFYnl0ZXMJAMwIAgUHZHVja0dlbgkAzAgCBQhjaGlsZHJlbgUDbmlsBQNuaWwDCQAAAgUEY2FsbAUEY2FsbAQKY2FsbFJlZHVjZQkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAgxyZWR1Y2VSYXJpdHkJAMwIAgUMZmlyc3RBc3NldElkCQDMCAIFCm9sZEZhcm1HZW4FA25pbAUDbmlsAwkAAAIFCmNhbGxSZWR1Y2UFCmNhbGxSZWR1Y2UJAMwIAgkBBEJ1cm4CCQEFdmFsdWUBCAUMZmlyc3RQYXltZW50B2Fzc2V0SWQAAQkAzAgCCQEEQnVybgIJAQV2YWx1ZQEIBQ1zZWNvbmRQYXltZW50B2Fzc2V0SWQAAQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB3ByZUluaXQACQDMCAIJAQxJbnRlZ2VyRW50cnkCAhxzdGF0aWNfQVJULUxBS0VfZmFybWluZ1Nsb3RzAMgBCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhxzdGF0aWNfQVJULUxBS0VfZmFybWluZ0Jvb3N0AAIJAMwIAgkBDEludGVnZXJFbnRyeQICHXN0YXRpY19BUlQtSE9VU0VfZmFybWluZ1Nsb3RzAAQJAMwIAgkBDEludGVnZXJFbnRyeQICHXN0YXRpY19BUlQtSE9VU0VfZmFybWluZ0Jvb3N0AB4JAMwIAgkBDEludGVnZXJFbnRyeQICIHN0YXRpY19BUlQtQklHSE9VU0VfZmFybWluZ1Nsb3RzAAoJAMwIAgkBDEludGVnZXJFbnRyeQICIHN0YXRpY19BUlQtQklHSE9VU0VfZmFybWluZ0Jvb3N0AA8FA25pbAFpAQ1pc3N1ZUFydGVmYWN0AgR0eXBlCHJlY2VpdmVyAwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkBAiE9AggFAWkGY2FsbGVyCQERZ2V0UmViaXJ0aEFkZHJlc3MABwkAAgECCmFkbWluIG9ubHkEB3R4SWRTdHIJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAQHYWRkcmVzcwkBB0FkZHJlc3MBCQDZBAEFCHJlY2VpdmVyBAhhcnRlZmFjdAkAwwgHBQR0eXBlAipORlQgYXJ0ZWZhY3Qgb2YgV2F2ZXMgRHVja3MgZ2FtZS4gRHJvcCAjMi4AAQAABwUEdW5pdAAABAphcnRlZmFjdElkCQC4CAEFCGFydGVmYWN0CQCUCgIJAMwIAgUIYXJ0ZWZhY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgICCWFydGVmYWN0XwkA2AQBBQphcnRlZmFjdElkAgVfdHlwZQUEdHlwZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQdhZGRyZXNzAAEFCmFydGVmYWN0SWQFA25pbAkA2AQBBQphcnRlZmFjdElkAWkBB3NldExvY2sBAW4DCQAAAggFAWkGY2FsbGVyBQR0aGlzCQDMCAIJAQxJbnRlZ2VyRW50cnkCAg1nbG9iYWxfbG9ja2VkBQFuBQNuaWwJAAIBAgphZG1pbiBvbmx5AWkBC2J1eUFydGVmYWN0AAMJAGYCCAUJbGFzdEJsb2NrCXRpbWVzdGFtcACAzI3C3C8JAAIBAiFUaGVyZSBhcmUgbm8gYWN0aXZlIHNhbGVzIG5vdy4uLiADCQBmAgkBDXRyeUdldEludGVnZXIBAg1nbG9iYWxfbG9ja2VkAAAJAAIBAh5jb250cmFjdCBpcyB0ZW1wb3JhcmlseSBsb2NrZWQDCQBnAgkBDXRyeUdldEludGVnZXIBAhBnbG9iYWxfYXJ0QW1vdW50BQ5hcnRlZmFjdHNMaW1pdAkAAgECElNPTERPVVQhISEgSHVycmF5IQMDCQBmAgCA/u+A3C8IBQlsYXN0QmxvY2sJdGltZXN0YW1wCQECIT0CCAUBaQZjYWxsZXIJAQdBZGRyZXNzAQUKZGV2QWRkcmVzcwcJAAIBAgxUb28gZWFybHkuLi4EDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AggFDGZpcnN0UGF5bWVudAdhc3NldElkCQENZ2V0RWdnQXNzZXRJZAAJAAIBCQCsAgICPFlvdSBjYW4gYXR0YWNoIG9ubHkgRUdHIHRva2VucyB3aXRoIHRoZSBmb2xsb3dpbmcgYXNzZXQgaWQ6IAkA2AQBCQENZ2V0RWdnQXNzZXRJZAADCQBmAgUKZWdnc05lZWRlZAgFDGZpcnN0UGF5bWVudAZhbW91bnQJAAIBCQCsAgICRFRvIGhhdGNoIGEgZHVjayB5b3UgY3VycmVudGx5IG5lZWQgdGhlIGZvbGxvd2luZyBhbW91bnQgb2YgRUdHbGV0czogCQCkAwEFCmVnZ3NOZWVkZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JANgEAQgFAWkNdHJhbnNhY3Rpb25JZAIHX3N0YXR1cwIHc3RhcnRlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JANgEAQgFAWkNdHJhbnNhY3Rpb25JZAINX2ZpbmlzaEhlaWdodAkAZAIFBmhlaWdodAACCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhBnbG9iYWxfYXJ0QW1vdW50CQBkAgkBDXRyeUdldEludGVnZXIBAhBnbG9iYWxfYXJ0QW1vdW50AAEFA25pbAFpAQ5hZGRJdGVtVG9TdG9yZQgFcHJpY2UEaXRlbQhtYXhTYWxlcwRzYWxlCXByaWNlc3NldBBncm93dGhQZXJjZW50YWdlB3N0YXJ0VHMFZW5kVHMDCQECIT0CCAUBaQZjYWxsZXIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEWc3RhdGljS2V5X3BpcGVsaW5lVXNlcgAJAAIBAh5JQUlUUzogT25seSBmb3IgdHJ1c3RlZCB1c2VycyEJAMwIAgkBDEludGVnZXJFbnRyeQIJARFrZXlfcHJpY2VDb3NtZXRpYwEFBGl0ZW0FBXByaWNlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEUa2V5X21heFNhbGVzQ29zbWV0aWMBBQRpdGVtBQhtYXhTYWxlcwkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBEGtleV9zYWxlQ29zbWV0aWMBBQRpdGVtBQRzYWxlCQDMCAIJAQtTdHJpbmdFbnRyeQIJARZrZXlfcHJpY2VBc3NldENvc21ldGljAQUEaXRlbQUJcHJpY2Vzc2V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEaa2V5X2dyb3dQZXJjZW50YWdlQ29zbWV0aWMBBQRpdGVtBRBncm93dGhQZXJjZW50YWdlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQETa2V5X3N0YXJ0VHNDb3NtZXRpYwEFBGl0ZW0FB3N0YXJ0VHMJAMwIAgkBDEludGVnZXJFbnRyeQIJARFrZXlfZW5kVHNDb3NtZXRpYwEFBGl0ZW0FBWVuZFRzBQNuaWwBaQESc2V0R2xvYmFsQXJ0QW1vdW50AQluZXdBbW91bnQDAwkAAAIIBQFpBmNhbGxlcgUEdGhpcwYJAAACCAUBaQZjYWxsZXIJAQdBZGRyZXNzAQUKZGV2QWRkcmVzcwkAzAgCCQEMSW50ZWdlckVudHJ5AgIQZ2xvYmFsX2FydEFtb3VudAUJbmV3QW1vdW50BQNuaWwJAAIBAhFQZXJtaXNzaW9uIGRlbmllZAFpAQ1jbGFpbUFydGVmYWN0AQhib3hJZFN0cgQEdHhJZAkA2QQBBQhib3hJZFN0cgQJc3RhdHVzS2V5CQCsAgIJAKwCAgkArAICCQClCAEIBQFpBmNhbGxlcgIBXwUIYm94SWRTdHICB19zdGF0dXMECWhlaWdodEtleQkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8FCGJveElkU3RyAg1fZmluaXNoSGVpZ2h0AwkBAiE9AgkBEUBleHRyTmF0aXZlKDEwNTgpAQUJc3RhdHVzS2V5AgdzdGFydGVkCQACAQIPY2xhaW1lZCBhbHJlYWR5AwkAZgIJARFAZXh0ck5hdGl2ZSgxMDU1KQEFCWhlaWdodEtleQUGaGVpZ2h0CQACAQIUeW91IGNhbm5vdCBjbGFpbSB5ZXQEB2FydFR5cGUJARFnZXRSYW5kb21BcnRlZmFjdAIFBHR4SWQJARFAZXh0ck5hdGl2ZSgxMDU1KQEFCWhlaWdodEtleQQFYXNzZXQJAMMIBwUHYXJ0VHlwZQIiQXJ0ZWZhY3Qgb2YgV2F2ZXMgRHVja3MgbWV0YXZlcnNlLgABAAAHBQR1bml0CQERQGV4dHJOYXRpdmUoMTA1NSkBBQloZWlnaHRLZXkEB2Fzc2V0SWQJALgIAQUFYXNzZXQJAMwIAgkBC1N0cmluZ0VudHJ5AgUJc3RhdHVzS2V5BQdhcnRUeXBlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfBQhib3hJZFN0cgILX2FydGVmYWN0SWQJANgEAQUHYXNzZXRJZAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJANgEAQUHYXNzZXRJZAIFX3R5cGUFB2FydFR5cGUJAMwIAgUFYXNzZXQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyAAEFB2Fzc2V0SWQFA25pbAECdHgBBnZlcmlmeQADCQEJaXNUZXN0RW52AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleQQJZmlyc3RVc2VyASDe1sZR5FMW0GWA6wGaKgvQ95dR+hx2kX6bjgZDdxe9JQQKc2Vjb25kVXNlcgEgwWzfju3TjXOPi6L5+okP9HXNRBtUclKjtJzSVqQt4HUECXRoaXJkVXNlcgEg51v0jqrS+UmeboQmuPl+H9xnqH3cK7jU6nvN8mgKwSUED2ZpcnN0VXNlclNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCWZpcnN0VXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAQUJZmlyc3RVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwACBQlmaXJzdFVzZXIAAQAABBBzZWNvbmRVc2VyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUKc2Vjb25kVXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAQUKc2Vjb25kVXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUKc2Vjb25kVXNlcgABAAAED3RoaXJkVXNlclNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCXRoaXJkVXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAQUJdGhpcmRVc2VyAAEDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwACBQl0aGlyZFVzZXIAAQAABA9zaWduYXR1cmVzQ291bnQJAGQCCQBkAgUPZmlyc3RVc2VyU2lnbmVkBRBzZWNvbmRVc2VyU2lnbmVkBQ90aGlyZFVzZXJTaWduZWQEByRtYXRjaDAFAnR4CQBnAgUPc2lnbmF0dXJlc0NvdW50AALYDMK7", "height": 3585740, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: HvnDBPr2Uz7iotQjRea6oMgUxLfwQXVcF754iKwGrGFH Next: 22zSspxeakqQtQ5c55XZ4YD7o2eWWWoHRy13hArkWJ9x Diff:
OldNewDifferences
212212 else {
213213 let assetId = if ((tryGetString(key_priceAssetCosmetic(itemName)) == ""))
214214 then getEggAssetId()
215- else fromBase58String(tryGetString(key_priceAssetCosmetic(itemName)))
215+ else if ((tryGetString(key_priceAssetCosmetic(itemName)) == "WAVES"))
216+ then unit
217+ else fromBase58String(tryGetString(key_priceAssetCosmetic(itemName)))
216218 let amountPaidByCoupons = 0
217219 let leftToPay = (price - amountPaidByCoupons)
218220 let payment = if ((leftToPay != 0))
220222 let firstPayment = value(i.payments[0])
221223 let amount = firstPayment.amount
222224 if ((firstPayment.assetId != assetId))
223- then throw(("IDBI: You can attach only tokens with the following asset id: " + toBase58String(assetId)))
225+ then throw("IDBI: You can attach only tokens with the correct payment ")
224226 else if ((amount != leftToPay))
225227 then throw(("IDBI: Please attach the exact asset amount" + toString(price)))
226228 else leftToPay
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 staticKey_pipelineUser () = "static_pipelineUser"
2020
2121
2222 func key_artefactOwner (artefactName,owner) = (((artefactName + "_") + owner) + "_owner")
2323
2424
2525 func key_unstakeHeight (artefactName,artefactId) = (((artefactName + "_") + artefactId) + "_unstake_height")
2626
2727
2828 func key_externalBoostDuck (duckId) = (duckId + "_duck_external_boost")
2929
3030
3131 func key_externalBoostAddress (address) = (address + "_user_external_boost")
3232
3333
3434 func key_priceCosmetic (item) = ("direct_cosmetic_" + item)
3535
3636
3737 func key_maxSalesCosmetic (item) = (("direct_cosmetic_" + item) + "_max_sales")
3838
3939
4040 func key_saleCosmetic (item) = (("direct_cosmetic_" + item) + "_sale")
4141
4242
4343 func key_priceAssetCosmetic (item) = (("direct_cosmetic_" + item) + "_priceAsset")
4444
4545
4646 func key_growPercentageCosmetic (item) = (("direct_cosmetic_" + item) + "_growing_percentage")
4747
4848
4949 func key_soldCosmetic (item) = (("direct_cosmetic_" + item) + "_sold")
5050
5151
5252 func key_lastPriceCosmetic (item) = (("direct_cosmetic_" + item) + "_last_price")
5353
5454
5555 func key_startTsCosmetic (item) = (("direct_cosmetic_" + item) + "_startTs")
5656
5757
5858 func key_endTsCosmetic (item) = (("direct_cosmetic_" + item) + "_endTs")
5959
6060
6161 func key_processFinishHeight (address,txId) = (((address + "_") + toBase58String(txId)) + "_fh")
6262
6363
6464 let devAddress = base58'3P44yqcpfhPF2iC1nptm2ZJCTaN7VYhz9og'
6565
6666 let eggsNeeded = (3 * 100000000)
6767
6868 let artefactsLimit = (301 + 600)
6969
7070 let freeGenes = ["A", "B", "C", "D", "E", "F"]
7171
7272 let oldArtefacts = ["ART-LAKE", "ART-HOUSE", "ART-BIGHOUSE", "ART-FIXGENE", "ART-FREEGENE", "ART-MIRROR", "ART-POMP", "ART-CAPE", "ART-HAT", "ART-CUSTOMDUCK"]
7373
7474 let artefacts = ["ART-XMISTL", "ART-XHAT", "ART-XSCARF", "ART-XSWEATER", "ART-XSOCK", "ART-XTREE"]
7575
7676 let allArtefact = (artefacts ++ oldArtefacts)
7777
7878 func tryGetBoolean (key) = match getBoolean(this, key) {
7979 case b: Boolean =>
8080 b
8181 case _ =>
8282 false
8383 }
8484
8585
8686 func tryGetString (key) = match getString(this, key) {
8787 case a: String =>
8888 a
8989 case _ =>
9090 ""
9191 }
9292
9393
9494 func tryGetInteger (key) = match getInteger(this, key) {
9595 case a: Int =>
9696 a
9797 case _ =>
9898 0
9999 }
100100
101101
102102 func getRandomNumber (variants,txId,finishHeight,offset) = {
103103 let randomSeedBlock = value(blockInfoByHeight((finishHeight - 1)))
104104 let randomHash = sha256(((base58'items' + txId) + value(randomSeedBlock.vrf)))
105105 (toInt(randomHash, offset) % variants)
106106 }
107107
108108
109109 func getRandomArtefact (boxId,h) = {
110110 let randomNumber = getRandomNumber(6, boxId, h, 1)
111111 artefacts[randomNumber]
112112 }
113113
114114
115115 func getRandomGenes (txId,h) = {
116116 let randomNumber = getRandomNumber(6, txId, h, 2)
117117 freeGenes[randomNumber]
118118 }
119119
120120
121121 func tryGetStringExternal (address,key) = match getString(address, key) {
122122 case a: String =>
123123 a
124124 case _ =>
125125 ""
126126 }
127127
128128
129129 func getOracle () = Address(fromBase58String(tryGetString(staticKey_oracleAddress())))
130130
131131
132132 func getBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_breederAddress())))
133133
134134
135135 func getEggAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_eggAssetId()))
136136
137137
138138 func getTrustedContracts () = tryGetStringExternal(getOracle(), staticKey_trustedContracts())
139139
140140
141141 func getRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_rebirthAddress())))
142142
143143
144144 func tryGetCosmeticItemPrice (item) = {
145145 let key = key_priceCosmetic(item)
146146 match getInteger(this, key) {
147147 case a: Int =>
148148 a
149149 case _ =>
150150 throw("ITGCIP: This item is not available in the store!")
151151 }
152152 }
153153
154154
155155 func asString (value) = match value {
156156 case string: String =>
157157 string
158158 case _ =>
159159 throw("wrong type, expected: String")
160160 }
161161
162162
163163 func asInt (value) = match value {
164164 case int: Int =>
165165 int
166166 case _ =>
167167 throw("wrong type, expected: Int")
168168 }
169169
170170
171171 func manipulateName (assetName,position,char) = ((take(assetName, (position - 1)) + char) + takeRight(assetName, (16 - position)))
172172
173173
174174 func itemIsInCoolDown (artefactName,artefactId) = {
175175 let unstakeHeightLast = tryGetInteger(key_unstakeHeight(artefactName, artefactId))
176176 let cooldownPeriod = 240
177177 if ((height > (unstakeHeightLast + cooldownPeriod)))
178178 then false
179179 else true
180180 }
181181
182182
183183 func isTestEnv () = tryGetBoolean("TESTENV")
184184
185185
186186 @Callable(i)
187187 func directBuyItem (itemName) = {
188188 let basePrice = tryGetCosmeticItemPrice(itemName)
189189 let grow = tryGetInteger(key_growPercentageCosmetic(itemName))
190190 let startTs = tryGetInteger(key_startTsCosmetic(itemName))
191191 let endTs = tryGetInteger(key_endTsCosmetic(itemName))
192192 if (if ((startTs != 0))
193193 then (startTs > lastBlock.timestamp)
194194 else false)
195195 then throw("IDBI: The sale did not start yet!")
196196 else if (if ((endTs != 0))
197197 then (lastBlock.timestamp > endTs)
198198 else false)
199199 then throw("IDBI: The sale has already finished!")
200200 else if (!(tryGetBoolean(key_saleCosmetic(itemName))))
201201 then throw(("IDBI: Item not for sale anymore" + key_saleCosmetic(itemName)))
202202 else {
203203 let maxSalesValue = tryGetInteger(key_maxSalesCosmetic(itemName))
204204 let soldValue = tryGetInteger(key_soldCosmetic(itemName))
205205 let price = if ((grow == 0))
206206 then basePrice
207207 else (basePrice + ((basePrice / 100) * (soldValue * grow)))
208208 if (if ((maxSalesValue != 0))
209209 then (soldValue >= maxSalesValue)
210210 else false)
211211 then throw("IDBI: Max editions sold!")
212212 else {
213213 let assetId = if ((tryGetString(key_priceAssetCosmetic(itemName)) == ""))
214214 then getEggAssetId()
215- else fromBase58String(tryGetString(key_priceAssetCosmetic(itemName)))
215+ else if ((tryGetString(key_priceAssetCosmetic(itemName)) == "WAVES"))
216+ then unit
217+ else fromBase58String(tryGetString(key_priceAssetCosmetic(itemName)))
216218 let amountPaidByCoupons = 0
217219 let leftToPay = (price - amountPaidByCoupons)
218220 let payment = if ((leftToPay != 0))
219221 then {
220222 let firstPayment = value(i.payments[0])
221223 let amount = firstPayment.amount
222224 if ((firstPayment.assetId != assetId))
223- then throw(("IDBI: You can attach only tokens with the following asset id: " + toBase58String(assetId)))
225+ then throw("IDBI: You can attach only tokens with the correct payment ")
224226 else if ((amount != leftToPay))
225227 then throw(("IDBI: Please attach the exact asset amount" + toString(price)))
226228 else leftToPay
227229 }
228230 else 0
229231 if ((payment == payment))
230232 then {
231233 let txIdStr = toBase58String(i.transactionId)
232234 let address = i.originCaller
233235 let artefact = Issue(itemName, ("NFT artefact of Waves Ducks game: " + itemName), 1, 0, false, unit, 0)
234236 let artefactId = calculateAssetId(artefact)
235237 $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))
236238 }
237239 else throw("Strict value is not equal to itself.")
238240 }
239241 }
240242 }
241243
242244
243245
244246 @Callable(i)
245247 func manipulateBoost (boost,duckId) = {
246248 let allowedContracts = getTrustedContracts()
247249 let allowedContractsList = split(allowedContracts, ";")
248250 let dappToCall = toString(i.caller)
249251 if ((indexOf(allowedContractsList, dappToCall) == unit))
250252 then throw("IMB: This smart contract can't manipulate the boost!")
251253 else {
252254 let key = key_externalBoostDuck(duckId)
253255 let activeBoost = tryGetInteger(key)
254256 let newBoost = (activeBoost + boost)
255257 if ((0 > newBoost))
256258 then throw("IMB: Something went wrong with boost, please contact the admins!")
257259 else [IntegerEntry(key, newBoost)]
258260 }
259261 }
260262
261263
262264
263265 @Callable(i)
264266 func manipulateBoostAccount (boost,address) = {
265267 let allowedContracts = getTrustedContracts()
266268 let allowedContractsList = split(allowedContracts, ";")
267269 let dappToCall = toString(i.caller)
268270 if ((indexOf(allowedContractsList, dappToCall) == unit))
269271 then throw("IMBA: This smart contract can't manipulate the boost!")
270272 else {
271273 let key = key_externalBoostAddress(address)
272274 let activeBoost = tryGetInteger(key)
273275 let newBoost = (activeBoost + boost)
274276 if ((0 > newBoost))
275277 then throw("IMBA: Something went wrong with boost, please contact the admins!")
276278 else [IntegerEntry(key, newBoost)]
277279 }
278280 }
279281
280282
281283
282284 @Callable(i)
283285 func checkArtefactDetails (assetId) = {
284286 let asset = value(assetInfo(fromBase58String(assetId)))
285287 let assetName = value(asset.name)
286288 if (if (if (containsElement(allArtefact, assetName))
287289 then true
288290 else isDefined(tryGetCosmeticItemPrice(assetName)))
289291 then (asset.issuer == this)
290292 else false)
291293 then $Tuple2(nil, assetName)
292294 else throw("Invalid artefact")
293295 }
294296
295297
296298
297299 @Callable(i)
298300 func configureOracle (oracle) = if ((i.caller != this))
299301 then throw("admin only")
300302 else [StringEntry(staticKey_oracleAddress(), oracle)]
301303
302304
303305
304306 @Callable(i)
305307 func calculateFarmingPowerBoost (duckId,address) = {
306308 let externalBoostDuck = tryGetInteger(key_externalBoostDuck(duckId))
307309 let externalBoostAddress = tryGetInteger(key_externalBoostAddress(address))
308310 let totalBoost = (externalBoostDuck + externalBoostAddress)
309311 $Tuple2([IntegerEntry((duckId + "_last_boost"), totalBoost)], totalBoost)
310312 }
311313
312314
313315
314316 @Callable(i)
315317 func fixedGene (txIdStr,parentFixedGene,positionFixedGene) = {
316318 let firstPayment = value(i.payments[0])
317319 let firstAssetId = toBase58String(value(firstPayment.assetId))
318320 if ((firstPayment.amount != 1))
319321 then throw("NFT is not attached")
320322 else {
321323 let artefact = asString(invoke(this, "checkArtefactDetails", [firstAssetId], nil))
322324 if ((artefact == artefact))
323325 then if ((artefact != "ART-FIXGENE"))
324326 then throw("You need to attach a ART-FIXGENE artefact")
325327 else {
326328 let txId = fromBase58String(txIdStr)
327329 let finishHeightKey = key_processFinishHeight(toString(i.caller), txId)
328330 let processFinishHeight = getIntegerValue(getBreederAddress(), finishHeightKey)
329331 let duckGenesString = asString(invoke(getBreederAddress(), "generateDuck", [txId, processFinishHeight, parentFixedGene, positionFixedGene, "", 0], nil))
330332 if ((duckGenesString == duckGenesString))
331333 then {
332334 let call = invoke(getBreederAddress(), "finishDuckHatchingItems", [txIdStr, duckGenesString], nil)
333335 if ((call == call))
334336 then [Burn(value(firstPayment.assetId), 1)]
335337 else throw("Strict value is not equal to itself.")
336338 }
337339 else throw("Strict value is not equal to itself.")
338340 }
339341 else throw("Strict value is not equal to itself.")
340342 }
341343 }
342344
343345
344346
345347 @Callable(i)
346348 func freeGene (txIdStr) = {
347349 let firstPayment = value(i.payments[0])
348350 let firstAssetId = toBase58String(value(firstPayment.assetId))
349351 if ((firstPayment.amount != 1))
350352 then throw("NFT is not attached")
351353 else {
352354 let artefact = asString(invoke(this, "checkArtefactDetails", [firstAssetId], nil))
353355 if ((artefact == artefact))
354356 then if ((artefact != "ART-FREEGENE"))
355357 then throw("You need to attach a ART-FREEGENE artefact")
356358 else {
357359 let txId = fromBase58String(txIdStr)
358360 let finishHeightKey = key_processFinishHeight(toString(i.caller), txId)
359361 let processFinishHeight = getIntegerValue(getBreederAddress(), finishHeightKey)
360362 let selectedGene = getRandomGenes(txId, processFinishHeight)
361363 let randomPosition = getRandomNumber(7, txId, processFinishHeight, 3)
362364 let duckGenesString = asString(invoke(getBreederAddress(), "generateDuck", [txId, processFinishHeight, 0, 0, selectedGene, randomPosition], nil))
363365 if ((duckGenesString == duckGenesString))
364366 then {
365367 let call = invoke(getBreederAddress(), "finishDuckHatchingItems", [txIdStr, duckGenesString], nil)
366368 if ((call == call))
367369 then [Burn(value(firstPayment.assetId), 1)]
368370 else throw("Strict value is not equal to itself.")
369371 }
370372 else throw("Strict value is not equal to itself.")
371373 }
372374 else throw("Strict value is not equal to itself.")
373375 }
374376 }
375377
376378
377379
378380 @Callable(i)
379381 func copyDuck () = {
380382 let firstPayment = value(i.payments[0])
381383 let secondPayment = value(i.payments[1])
382384 let firstAssetId = toBase58String(value(firstPayment.assetId))
383385 let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [firstAssetId], nil))
384386 if ((children == children))
385387 then if (if ((firstPayment.amount != 1))
386388 then true
387389 else (secondPayment.amount != 1))
388390 then throw("NFT is not attached")
389391 else {
390392 let artefact = asString(invoke(this, "checkArtefactDetails", [toBase58String(value(secondPayment.assetId))], nil))
391393 if ((artefact == artefact))
392394 then if ((artefact != "ART-MIRROR"))
393395 then throw("You need to attach a ART-MIRROR artefact")
394396 else {
395397 let nftInfo = value(assetInfo(value(firstPayment.assetId)))
396398 let asset1Gen = split(nftInfo.name, "")
397399 if (if ((asset1Gen[14] == "G"))
398400 then true
399401 else (asset1Gen[14] == "J"))
400402 then throw("You can't mirror this duck")
401403 else {
402404 let duckGen = nftInfo.name
403405 let call = invoke(getBreederAddress(), "createDuckSpecialGenes", [i.caller.bytes, duckGen, children], nil)
404406 if ((call == call))
405407 then [ScriptTransfer(i.caller, 1, firstPayment.assetId), Burn(value(secondPayment.assetId), 1)]
406408 else throw("Strict value is not equal to itself.")
407409 }
408410 }
409411 else throw("Strict value is not equal to itself.")
410412 }
411413 else throw("Strict value is not equal to itself.")
412414 }
413415
414416
415417
416418 @Callable(i)
417419 func addArteFactToDuck () = {
418420 let firstPayment = value(i.payments[0])
419421 let secondPayment = value(i.payments[1])
420422 let firstAssetId = toBase58String(value(firstPayment.assetId))
421423 if (if ((firstPayment.amount != 1))
422424 then true
423425 else (secondPayment.amount != 1))
424426 then throw("NFT is not attached")
425427 else {
426428 let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [firstAssetId], nil))
427429 if ((children == children))
428430 then if ((children == 0))
429431 then throw("You can only pick a sterile NFT-duck")
430432 else {
431433 let artefact = asString(invoke(this, "checkArtefactDetails", [toBase58String(value(secondPayment.assetId))], nil))
432434 if ((artefact == artefact))
433435 then if (if ((artefact != "ART-XHAT"))
434436 then (artefact != "ART-POMP")
435437 else false)
436438 then throw("You need to attach a ART-XHAT or ART-POMP artefact")
437439 else {
438440 let nftInfo = value(assetInfo(value(firstPayment.assetId)))
439441 let asset1Gen = split(nftInfo.name, "")
440442 if (if ((asset1Gen[14] == "G"))
441443 then true
442444 else (asset1Gen[14] == "J"))
443445 then throw("You can't mirror this duck")
444446 else if (if ((asset1Gen[5] == "S"))
445447 then true
446448 else (asset1Gen[5] == "T"))
447449 then throw("you already attached a artefact")
448450 else {
449451 let char = if ((artefact == "ART-XHAT"))
450452 then "T"
451453 else if ((artefact == "ART-POMP"))
452454 then "S"
453455 else throw("No char defined")
454456 let oldDuckGen = nftInfo.name
455457 let oldFarmGen = asString(invoke(getBreederAddress(), "getGenFromName", [oldDuckGen], nil))
456458 if ((oldFarmGen == oldFarmGen))
457459 then {
458460 let duckGen = manipulateName(oldDuckGen, 6, char)
459461 let call = invoke(getBreederAddress(), "createDuckSpecialGenes", [i.caller.bytes, duckGen, children], nil)
460462 if ((call == call))
461463 then {
462464 let callReduce = invoke(getBreederAddress(), "reduceRarity", [firstAssetId, oldFarmGen], nil)
463465 if ((callReduce == callReduce))
464466 then [Burn(value(firstPayment.assetId), 1), Burn(value(secondPayment.assetId), 1)]
465467 else throw("Strict value is not equal to itself.")
466468 }
467469 else throw("Strict value is not equal to itself.")
468470 }
469471 else throw("Strict value is not equal to itself.")
470472 }
471473 }
472474 else throw("Strict value is not equal to itself.")
473475 }
474476 else throw("Strict value is not equal to itself.")
475477 }
476478 }
477479
478480
479481
480482 @Callable(i)
481483 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)]
482484
483485
484486
485487 @Callable(i)
486488 func issueArtefact (type,receiver) = if (if ((i.caller != this))
487489 then (i.caller != getRebirthAddress())
488490 else false)
489491 then throw("admin only")
490492 else {
491493 let txIdStr = toBase58String(i.transactionId)
492494 let address = Address(fromBase58String(receiver))
493495 let artefact = Issue(type, "NFT artefact of Waves Ducks game. Drop #2.", 1, 0, false, unit, 0)
494496 let artefactId = calculateAssetId(artefact)
495497 $Tuple2([artefact, StringEntry((("artefact_" + toBase58String(artefactId)) + "_type"), type), ScriptTransfer(address, 1, artefactId)], toBase58String(artefactId))
496498 }
497499
498500
499501
500502 @Callable(i)
501503 func setLock (n) = if ((i.caller == this))
502504 then [IntegerEntry("global_locked", n)]
503505 else throw("admin only")
504506
505507
506508
507509 @Callable(i)
508510 func buyArtefact () = if ((lastBlock.timestamp > 1639742400000))
509511 then throw("There are no active sales now... ")
510512 else if ((tryGetInteger("global_locked") > 0))
511513 then throw("contract is temporarily locked")
512514 else if ((tryGetInteger("global_artAmount") >= artefactsLimit))
513515 then throw("SOLDOUT!!! Hurray!")
514516 else if (if ((1639605600000 > lastBlock.timestamp))
515517 then (i.caller != Address(devAddress))
516518 else false)
517519 then throw("Too early...")
518520 else {
519521 let firstPayment = value(i.payments[0])
520522 if ((firstPayment.assetId != getEggAssetId()))
521523 then throw(("You can attach only EGG tokens with the following asset id: " + toBase58String(getEggAssetId())))
522524 else if ((eggsNeeded > firstPayment.amount))
523525 then throw(("To hatch a duck you currently need the following amount of EGGlets: " + toString(eggsNeeded)))
524526 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))]
525527 }
526528
527529
528530
529531 @Callable(i)
530532 func addItemToStore (price,item,maxSales,sale,pricesset,growthPercentage,startTs,endTs) = if ((i.caller != addressFromStringValue(tryGetStringExternal(getOracle(), staticKey_pipelineUser()))))
531533 then throw("IAITS: Only for trusted users!")
532534 else [IntegerEntry(key_priceCosmetic(item), price), IntegerEntry(key_maxSalesCosmetic(item), maxSales), BooleanEntry(key_saleCosmetic(item), sale), StringEntry(key_priceAssetCosmetic(item), pricesset), IntegerEntry(key_growPercentageCosmetic(item), growthPercentage), IntegerEntry(key_startTsCosmetic(item), startTs), IntegerEntry(key_endTsCosmetic(item), endTs)]
533535
534536
535537
536538 @Callable(i)
537539 func setGlobalArtAmount (newAmount) = if (if ((i.caller == this))
538540 then true
539541 else (i.caller == Address(devAddress)))
540542 then [IntegerEntry("global_artAmount", newAmount)]
541543 else throw("Permission denied")
542544
543545
544546
545547 @Callable(i)
546548 func claimArtefact (boxIdStr) = {
547549 let txId = fromBase58String(boxIdStr)
548550 let statusKey = (((toString(i.caller) + "_") + boxIdStr) + "_status")
549551 let heightKey = (((toString(i.caller) + "_") + boxIdStr) + "_finishHeight")
550552 if ((getStringValue(statusKey) != "started"))
551553 then throw("claimed already")
552554 else if ((getIntegerValue(heightKey) > height))
553555 then throw("you cannot claim yet")
554556 else {
555557 let artType = getRandomArtefact(txId, getIntegerValue(heightKey))
556558 let asset = Issue(artType, "Artefact of Waves Ducks metaverse.", 1, 0, false, unit, getIntegerValue(heightKey))
557559 let assetId = calculateAssetId(asset)
558560 [StringEntry(statusKey, artType), StringEntry((((toString(i.caller) + "_") + boxIdStr) + "_artefactId"), toBase58String(assetId)), StringEntry((toBase58String(assetId) + "_type"), artType), asset, ScriptTransfer(i.caller, 1, assetId)]
559561 }
560562 }
561563
562564
563565 @Verifier(tx)
564566 func verify () = if (isTestEnv())
565567 then sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
566568 else {
567569 let firstUser = base58'FzsTVRXqD46KW5yj6qGNVrsouvWjpCQvD1446A96iGt4'
568570 let secondUser = base58'E23yUg8eun5nXB1nZRDf7RTyRADKxQhGNXdpTYonEvtU'
569571 let thirdUser = base58'Ga8WEBTPXbHuoXRD355mQ6ms8PsM2RFYKeA1mEP32CFe'
570572 let firstUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], firstUser))
571573 then 1
572574 else if (sigVerify(tx.bodyBytes, tx.proofs[1], firstUser))
573575 then 1
574576 else if (sigVerify(tx.bodyBytes, tx.proofs[2], firstUser))
575577 then 1
576578 else 0
577579 let secondUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], secondUser))
578580 then 1
579581 else if (sigVerify(tx.bodyBytes, tx.proofs[1], secondUser))
580582 then 1
581583 else if (sigVerify(tx.bodyBytes, tx.proofs[2], secondUser))
582584 then 1
583585 else 0
584586 let thirdUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], thirdUser))
585587 then 1
586588 else if (sigVerify(tx.bodyBytes, tx.proofs[1], thirdUser))
587589 then 1
588590 else if (sigVerify(tx.bodyBytes, tx.proofs[2], thirdUser))
589591 then 1
590592 else 0
591593 let signaturesCount = ((firstUserSigned + secondUserSigned) + thirdUserSigned)
592594 match tx {
593595 case _ =>
594596 (signaturesCount >= 2)
595597 }
596598 }
597599

github/deemru/w8io/786bc32 
83.05 ms