tx · 3KZoBF5Wp863goSDHWS5xZX1YPLvkTEHMtvCwRUWanTM

3PAi1ePLQrYrY3jj9omBtT6isMkZsapbmks:  -0.02200000 Waves

2023.04.29 17:19 [3621550] smart account 3PAi1ePLQrYrY3jj9omBtT6isMkZsapbmks > SELF 0.00000000 Waves

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

github/deemru/w8io/3ef1775 
64.15 ms