tx · meEohJXz5oMDLVnnc8nHWdTgY4moNt11HSq8KWSJaqT

3MwukwUkp3PsyCrkjMgqiAnSfc1hBD5FQhH:  -0.02600000 Waves

2023.03.21 15:29 [2499777] smart account 3MwukwUkp3PsyCrkjMgqiAnSfc1hBD5FQhH > SELF 0.00000000 Waves

{ "type": 13, "id": "meEohJXz5oMDLVnnc8nHWdTgY4moNt11HSq8KWSJaqT", "fee": 2600000, "feeAssetId": null, "timestamp": 1679401779631, "version": 2, "chainId": 84, "sender": "3MwukwUkp3PsyCrkjMgqiAnSfc1hBD5FQhH", "senderPublicKey": "5JqBVJpMCyD7dJLJttqYjL6CmJc4zahBHSFjFb7qQTga", "proofs": [ "DvXCvm4GAAZgQn61UzHP45prNCjSQE7jh6tvyGHEHnfUfDyBJRUfCks53PSutHAEYbkauJAYZT573LKgxZzHnDd" ], "script": "base64:BgIhCAISBAoCAQESBgoECAgICBIDCgEYEgASAwoBCBIDCgEBRgADU0VQAgFfAA5fbWluTG9ja3BlcmlvZAABAA1fdW5pdERlY2ltYWxzAIDC1y8ADl9taW5Mb2NrQW1vdW50CQBoAgABBQ1fdW5pdERlY2ltYWxzAA5fbWF4TG9ja0Ftb3VudAkAaAIA6AcFDV91bml0RGVjaW1hbHMAA19EdACAuJkpAQRfUHB5AQpsb2NrUGVyaW9kCQBrAwUNX3VuaXREZWNpbWFscwDtAgUKbG9ja1BlcmlvZAANX2luY3JlbWVudFJlZgDAhD0ADl9wZXJjZW50YWdlRmVlCQBrAwUNX3VuaXREZWNpbWFscwAKAGQAGl9wZXJjZW50YWdlUmVkdWN0aW9uRmFjdG9yAilDdXJyZW50X1BlcmNlbnRhZ2VSZWR1Y3Rpb25fRmFjdG9yX0Zvcl9NcgADX01yAgxNaW50aW5nX1JhdGUADF9zdGF3QXNzZXRJZAIMU3Rhd19Bc3NldElkAAhfbWFuYWdlcgIHbWFuYWdlcgAEX0RmeAIDRGZ4ABVfY2lyY3VsYXRpb25JbmNySW5kZXgCGUNpcmN1bGF0aW9uSW5jcmVtZW50SW5kZXgADl9sZXNzZWVBZGRyZXNzAglMZWFzZU5vZGUAGl91c2VyRW1pc3Npb25BbW91bnRDbGFpbWVkAhVFbWlzc2lvbkFtb3VudENsYWltZWQAG191c2VyQ2FuQ2xhaW1FbWlzc2lvbkFtb3VudAIWQ2FuQ2xhaW1FbWlzc2lvbkFtb3VudAAMX3VzZXJBZGRyZXNzAg1XYWxsZXRBZGRyZXNzABRfdXNlckxvY2FsSW5kZXhDb3VudAIUVG90YWxFbnRyeUluZGV4Q291bnQAEF91c2VyVG90YWxMb2NrZWQCC1RvdGFsTG9ja2VkAA1fbG9ja0R1cmF0aW9uAgxMb2NrRHVyYXRpb24ACl9sb2NrSW5kZXgCD0dsb2JhbExvY2tJbmRleAAHX2xvY2tJZAIOTG9ja0lkZW50aWZpZXIADF93YXZlc0Ftb3VudAINQW1vdW50SW5XYXZlcwALX3N0YXdBbW91bnQCDEFtb3VudEluU3RhdwANX3N0YXdMUEFtb3VudAIOQW1vdW50SW5TdGF3TFAABV90eElkAgRUWElEAA1fbG9ja0F0SGVpZ2h0AgxMb2NrQXRIZWlnaHQAFF9sb2NrUGVyaW9kSW5NaWxpU2VjAhRMb2NLUGVyaW9kSW5NaWxsaVNlYwASX3RvdGFsV2F2ZXNDbGFpbWVkAhFUb3RhbFdhdmVzQ2xhaW1lZAAPX3VzZXJMZWFzZVN0YXRlAgpMZWFzZVN0YXRlAApfdG90YWxTdGF3Ag9Ub3RhbFN0YXdNaW50ZWQADl90b3RhbFdhdmVzUmVmAhBUb3RhbFdhdmVzTG9ja2VkAAxfdG90YWxTdGF3TFACC1RvdGFsU3Rhd0xQABFfZ2xvYmFsSW5kZXhDb3VudAIKSW5kZXhDb3VudAAUX2RheXNBZnRlckxvY2tQZXJpb2QCGkRheXNBZnRlckxvY2tQZXJpb2RFbGFzcGVkAQVfZ2V0SQEDa2V5CQCaCAIFBHRoaXMFA2tleQEFX2dldFMBA2tleQkAnQgCBQR0aGlzBQNrZXkBBV9nZXRCAQNrZXkJAJsIAgUEdGhpcwUDa2V5AQZfZ2V0QlYBA2tleQkBBXZhbHVlAQkAmwgCBQR0aGlzBQNrZXkBBl9nZXRJVgEDa2V5CQEFdmFsdWUBCQCaCAIFBHRoaXMFA2tleQEGX2dldFNWAQNrZXkJAQV2YWx1ZQEJAJ0IAgUEdGhpcwUDa2V5AQxfc2V0UGFyYW1WYWwCA2tleQpkZWZhdWx0VmFsBAckbWF0Y2gwBQpkZWZhdWx0VmFsAwkAAQIFByRtYXRjaDACBlN0cmluZwQKZGVmYXVsdFZhbAUHJG1hdGNoMAMJAQlpc0RlZmluZWQBCQEFX2dldFMBBQNrZXkJAQZfZ2V0U1YBBQNrZXkFCmRlZmF1bHRWYWwDCQABAgUHJG1hdGNoMAIDSW50BApkZWZhdWx0VmFsBQckbWF0Y2gwAwkBCWlzRGVmaW5lZAEJAQVfZ2V0SQEFA2tleQkBBl9nZXRJVgEFA2tleQUKZGVmYXVsdFZhbAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBApkZWZhdWx0VmFsBQckbWF0Y2gwAwkBCWlzRGVmaW5lZAEJAQVfZ2V0QgEFA2tleQkBBl9nZXRCVgEFA2tleQUKZGVmYXVsdFZhbAkAAgEJAKwCAgIddmFsdWUgdHlwZSBub3Qgc3VwcG9ydGVkIGZvciAFA2tleQEPX3Rocm93T3JSZXR1cm5TAgN2YWwFZXJyb3IEByRtYXRjaDAFA3ZhbAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEA3ZhbAUHJG1hdGNoMAUDdmFsCQACAQUFZXJyb3IBD190aHJvd09yUmV0dXJuSQIDdmFsBWVycm9yBAckbWF0Y2gwBQN2YWwDCQABAgUHJG1hdGNoMAIDSW50BAN2YWwFByRtYXRjaDAFA3ZhbAkAAgEFBWVycm9yARJfdGhyb3dPclJldHVybkJvb2wCA3ZhbAVlcnJvcgQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACB0Jvb2xlYW4EA3ZhbAUHJG1hdGNoMAUDdmFsCQACAQUFZXJyb3IBCV93cml0ZUludAIDa2V5BXZhbHVlAwkAZgIAAAUFdmFsdWUJAAIBCQCsAgIJAKwCAgkArAICAhd3cml0aW5nIG5lZ2F0aXZlIHZhbHVlIAkApAMBBQV2YWx1ZQIJIGZvciBrZXkgBQNrZXkJAQxJbnRlZ2VyRW50cnkCBQNrZXkFBXZhbHVlAQlfd3JpdGVTdHICA2tleQV2YWx1ZQMJAAACAgEgBQV2YWx1ZQkAAgEJAKwCAgIYd3JpdGluZyBhbiBlbXB0eSBzdHJpbmcgBQV2YWx1ZQkBC1N0cmluZ0VudHJ5AgUDa2V5BQV2YWx1ZQEIX3Rocm93SWYCCWNvbmRpdGlvbgVlcnJvcgMFCWNvbmRpdGlvbgkAAgEFBWVycm9yBgERX3dyaXRlR2xvYmFsUGFyYW0CA2tleQZfdmFsdWUEByRtYXRjaDAFBl92YWx1ZQMJAAECBQckbWF0Y2gwAgNJbnQEBl92YWx1ZQUHJG1hdGNoMAQFZW50cnkJALkJAgkAzAgCAgIlZAkAzAgCCQCkAwEFBl92YWx1ZQUDbmlsBQNTRVAJAQlfd3JpdGVTdHICBQNrZXkFBWVudHJ5AwkAAQIFByRtYXRjaDACBlN0cmluZwQGX3ZhbHVlBQckbWF0Y2gwBAVlbnRyeQkAuQkCCQDMCAICAiVzCQDMCAIFBl92YWx1ZQUDbmlsBQNTRVAJAQlfd3JpdGVTdHICBQNrZXkFBWVudHJ5AwkAAQIFByRtYXRjaDACB0Jvb2xlYW4EBl92YWx1ZQUHJG1hdGNoMAQFZW50cnkJALkJAgkAzAgCAgIlYgkAzAgCCQClAwEFBl92YWx1ZQUDbmlsBQNTRVAJAQlfd3JpdGVTdHICBQNrZXkFBWVudHJ5CQACAQISdHlwZSBub3Qgc3VwcG9ydGVkARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQNrZXkECV9yYXdWYWx1ZQkBD190aHJvd09yUmV0dXJuUwIJAQVfZ2V0UwEFA2tleQkArAICAhRlbnRyeSBub3QgZm91bmQgZm9yIAUDa2V5AwkAAAIFCV9yYXdWYWx1ZQUJX3Jhd1ZhbHVlBAF4CQC1CQIFCV9yYXdWYWx1ZQUDU0VQBA9mb3JtYXRTcGVjaWZpZXIJALICAgkAkQMCBQF4AAAAAQQMX3ZhbHVlU3RyaW5nCQCRAwIFAXgJAGUCCQCQAwEFAXgAAQQGX3ZhbHVlAwkAAAIFD2Zvcm1hdFNwZWNpZmllcgIBcwUMX3ZhbHVlU3RyaW5nAwkAAAIFD2Zvcm1hdFNwZWNpZmllcgIBZAkBDXBhcnNlSW50VmFsdWUBBQxfdmFsdWVTdHJpbmcDCQAAAgUPZm9ybWF0U3BlY2lmaWVyAgFiCQDZBAEFDF92YWx1ZVN0cmluZwkAAgEJAKwCAgIjY291bGQgbm90IHBhcnNlIHJlZ2lzdHJ5IHZhbHVlIGZvciAFA2tleQUGX3ZhbHVlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ5fZGF5c1RvTWlsaVNlYwEEZGF5cwQFY2hlY2sJAQhfdGhyb3dJZgIJAGcCAAAFBGRheXMCFWludmFsaWQgbG9ja2luZyBkYXlzIQMJAAACBQVjaGVjawUFY2hlY2sJAGgCBQRkYXlzBQNfRHQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BEV93cml0ZUNvbnN0U3RyaW5nAgNrZXkFdmFsdWUDCQEBIQEJAQlpc0RlZmluZWQBCQEFX2dldFMBBQNrZXkJAQlfd3JpdGVTdHICBQNrZXkFBXZhbHVlCQACAQkArAICAhtlbnRyeSBhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQESX3dyaXRlQ29uc3RJbnRlZ2VyAgNrZXkFdmFsdWUDCQEBIQEJAQlpc0RlZmluZWQBCQEFX2dldFMBBQNrZXkJAQlfd3JpdGVJbnQCBQNrZXkFBXZhbHVlCQACAQkArAICAhwgZW50cnkgYWxyZWFkeSBpbml0aWFsaXplZDogBQNrZXkBDF9vbmx5TWFuYWdlcgEBaQQHbWFuYWdlcgQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBQhfbWFuYWdlcgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEA3ZhbAUHJG1hdGNoMAUDdmFsAhVmYWlsZWQgdG8gZ2V0IG1hbmFnZXIDCQAAAgUHbWFuYWdlcgUHbWFuYWdlcgkBCF90aHJvd0lmAgkBAiE9AgkA2AQBCAgFAWkGY2FsbGVyBWJ5dGVzBQdtYW5hZ2VyAhZhZGRyZXNzIG5vdCBhdXRob3JpemVkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQRfYWJzAQN2YWwDCQBmAgAABQN2YWwJAQEtAQUDdmFsBQN2YWwBEF92YWxpZGF0ZUFkZHJlc3MCB2FkZHJlc3MIZXJyb3JNc2cEByRtYXRjaDAFB2FkZHJlc3MDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAdhZGRyZXNzBQckbWF0Y2gwBAhfYWRkcmVzcwkApggBBQdhZGRyZXNzBAckbWF0Y2gxBQhfYWRkcmVzcwMJAAECBQckbWF0Y2gxAgdBZGRyZXNzBAhfYWRkcmVzcwUHJG1hdGNoMQYEByRtYXRjaDIFCGVycm9yTXNnAwkAAQIFByRtYXRjaDICBlN0cmluZwQDbXNnBQckbWF0Y2gyCQACAQUDbXNnBwMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAdhZGRyZXNzBQckbWF0Y2gwBAhfYWRkcmVzcwkApwgBBQdhZGRyZXNzBAckbWF0Y2gxBQhfYWRkcmVzcwMJAAECBQckbWF0Y2gxAgdBZGRyZXNzBAhfYWRkcmVzcwUHJG1hdGNoMQYEByRtYXRjaDIFCGVycm9yTXNnAwkAAQIFByRtYXRjaDICBlN0cmluZwQDbXNnBQckbWF0Y2gyCQACAQUDbXNnBwkAAgECEmludmFsaWQgaW5wdXQgdHlwZQEOX3ZhbGlkYXRlQXNzZXQCB2Fzc2V0SUQIZXJyb3JNc2cEByRtYXRjaDAJAOwHAQkA2QQBBQdhc3NldElEAwkAAQIFByRtYXRjaDACBUFzc2V0BAVhc3NldAUHJG1hdGNoMAYEByRtYXRjaDEFCGVycm9yTXNnAwkAAQIFByRtYXRjaDECBlN0cmluZwQDbXNnBQckbWF0Y2gxCQACAQUDbXNnBwEKX2NvbXB1dGVNcgAEEGN1cnJlbnRDaXJjSW5kZXgEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUVX2NpcmN1bGF0aW9uSW5jckluZGV4AwkAAQIFByRtYXRjaDACA0ludAQBdAUHJG1hdGNoMAUBdAkAAgECKGNpcmN1bGF0aW9uIGluZGV4IG5vdCBwcmV2aW91c2x5IGRlZmluZWQDCQAAAgUQY3VycmVudENpcmNJbmRleAUQY3VycmVudENpcmNJbmRleAQLc3Rhd0Fzc2V0SWQEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUMX3N0YXdBc3NldElkAwkAAQIFByRtYXRjaDACBlN0cmluZwQBdAUHJG1hdGNoMAUBdAkAAgECH2Fzc2V0IGlkIG5vdCBwcmV2aW91c2x5IGRlZmluZWQDCQAAAgULc3Rhd0Fzc2V0SWQFC3N0YXdBc3NldElkBBVzdGF3Q2lyY3VsYXRpbmdTdXBwbHkEByRtYXRjaDAJAOwHAQkA2QQBBQtzdGF3QXNzZXRJZAMJAAECBQckbWF0Y2gwAgVBc3NldAQFYXNzZXQFByRtYXRjaDAJAGkCCAUFYXNzZXQIcXVhbnRpdHkFDV91bml0RGVjaW1hbHMJAAIBCQCsAgICFGFzc2V0IG5vdCBmb3VuZCBmb3IgBQtzdGF3QXNzZXRJZAQNdW5pdEluY3JlbWVudAkAaQIJAQRfYWJzAQkAZQIFFXN0YXdDaXJjdWxhdGluZ1N1cHBseQUNX2luY3JlbWVudFJlZgUNX2luY3JlbWVudFJlZgQXbmV3Q2lyY3VsYXRpb25JbmNySW5kZXgDCQBmAgUNdW5pdEluY3JlbWVudAUQY3VycmVudENpcmNJbmRleAkAZAIFDXVuaXRJbmNyZW1lbnQFEGN1cnJlbnRDaXJjSW5kZXgFEGN1cnJlbnRDaXJjSW5kZXgECWN1cnJlbnRNcgQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBQNfTXIDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIbZmFpbGVkIHRvIGdldCBtaW5pdGluZyByYXRlAwkAAAIFF25ld0NpcmN1bGF0aW9uSW5jckluZGV4BRBjdXJyZW50Q2lyY0luZGV4CQCUCgIFCWN1cnJlbnRNcgUDbmlsBBJuZXdyZWR1Y3Rpb25GYWN0b3IEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUaX3BlcmNlbnRhZ2VSZWR1Y3Rpb25GYWN0b3IDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwCQBkAgUBdAAKCQACAQIpZmFpbGVkIHRvIGdldCBwZXJjZW50YWdlIHJlZHVjdGlvbiBmYWN0b3IEDG5ld0N1cnJlbnRNcgkAZQIFCWN1cnJlbnRNcgkAawMFCWN1cnJlbnRNcgUSbmV3cmVkdWN0aW9uRmFjdG9yAGQEBnN0b3JlMQkBEV93cml0ZUdsb2JhbFBhcmFtAgUDX01yBQxuZXdDdXJyZW50TXIEBnN0b3JlMgkBEV93cml0ZUdsb2JhbFBhcmFtAgUaX3BlcmNlbnRhZ2VSZWR1Y3Rpb25GYWN0b3IFEm5ld3JlZHVjdGlvbkZhY3RvcgQGc3RvcmUzCQERX3dyaXRlR2xvYmFsUGFyYW0CBRVfY2lyY3VsYXRpb25JbmNySW5kZXgFF25ld0NpcmN1bGF0aW9uSW5jckluZGV4CQCUCgIFDG5ld0N1cnJlbnRNcgkAzAgCBQZzdG9yZTEJAMwIAgUGc3RvcmUyCQDMCAIFBnN0b3JlMwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARJfdXBkYXRlR2xvYmFsRW50cnkEC3dhdmVzQW1vdW50CnN0YXdBbW91bnQGc3Rhd1BMCmluZGV4Q291bnQEGl9uZXdHbG9iYWxUb3RhbFdhdmVzQW10UmVmBAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFDl90b3RhbFdhdmVzUmVmAwkAAQIFByRtYXRjaDACA0ludAQBdAUHJG1hdGNoMAkAZAIFAXQFC3dhdmVzQW1vdW50CQACAQIgZmFpbGVkIHRvIGdldCBnbG9iYWwgdG90YWwgd2F2ZXMDCQAAAgUaX25ld0dsb2JhbFRvdGFsV2F2ZXNBbXRSZWYFGl9uZXdHbG9iYWxUb3RhbFdhdmVzQW10UmVmBBlfbmV3R2xvYmFsVG90YWxTdGF3TWludGVkBAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFCl90b3RhbFN0YXcDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwCQBkAgUBdAUKc3Rhd0Ftb3VudAkAAgECJmZhaWxlZCB0byBnZXQgZ2xvYmFsIHRvdGFsIHN0YXcgbWludGVkAwkAAAIFGV9uZXdHbG9iYWxUb3RhbFN0YXdNaW50ZWQFGV9uZXdHbG9iYWxUb3RhbFN0YXdNaW50ZWQEFV9uZXdHbG9iYWxUb3RhbFN0YXdQTAQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBQxfdG90YWxTdGF3TFADCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwCQBkAgUBdAUGc3Rhd1BMCQACAQIhZmFpbGVkIHRvIGdldCBnbG9iYWwgdG90YWwgc3Rhd3BsAwkAAAIFFV9uZXdHbG9iYWxUb3RhbFN0YXdQTAUVX25ld0dsb2JhbFRvdGFsU3Rhd1BMBBNfbmV3R2xvYmFJbmRleENvdW50BAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFEV9nbG9iYWxJbmRleENvdW50AwkAAQIFByRtYXRjaDACA0ludAQBdAUHJG1hdGNoMAkAZAIFAXQFCmluZGV4Q291bnQJAAIBAiBmYWlsZWQgdG8gZ2V0IGdsb2JhbCBpbmRleCBjb3VudAMJAAACBRNfbmV3R2xvYmFJbmRleENvdW50BRNfbmV3R2xvYmFJbmRleENvdW50CQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFDl90b3RhbFdhdmVzUmVmBRpfbmV3R2xvYmFsVG90YWxXYXZlc0FtdFJlZgkAzAgCCQERX3dyaXRlR2xvYmFsUGFyYW0CBQpfdG90YWxTdGF3BRlfbmV3R2xvYmFsVG90YWxTdGF3TWludGVkCQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFDF90b3RhbFN0YXdMUAUVX25ld0dsb2JhbFRvdGFsU3Rhd1BMCQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFEV9nbG9iYWxJbmRleENvdW50BRNfbmV3R2xvYmFJbmRleENvdW50BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BEl9yZWdpc3RlclVzZXJFbnRyeQ0NdHJhbnNhY3Rpb25JRAt1c2VyQWRkcmVzcwxsb2NrRHVyYXRpb24SbG9ja0R1cmF0aW9uSW5NaWxpCWxvY2tJbmRleAt3YXZlc0Ftb3VudApzdGF3QW1vdW50DHN0YXdMUEFtb3VudAxsb2NrQXRIZWlnaHQGbG9ja0lkC3RvdGFsTG9ja2VkD2xvY2FsSW5kZXhDb3VudApsZWFzZVN0YXRlBAhfdHhJZEtleQkAuQkCCQDMCAIFC3VzZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUFX3R4SWQFA25pbAUDU0VQBBBfbG9ja0R1cmF0aW9uS2V5CQC5CQIJAMwIAgULdXNlckFkZHJlc3MJAMwIAgUNdHJhbnNhY3Rpb25JRAkAzAgCBQ1fbG9ja0R1cmF0aW9uBQNuaWwFA1NFUAQNX2xvY2tJbmRleEtleQkAuQkCCQDMCAIFC3VzZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUKX2xvY2tJbmRleAUDbmlsBQNTRVAED193YXZlc0Ftb3VudEtleQkAuQkCCQDMCAIFC3VzZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUMX3dhdmVzQW1vdW50BQNuaWwFA1NFUAQOX3N0YXdBbW91bnRLZXkJALkJAgkAzAgCBQt1c2VyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFC19zdGF3QW1vdW50BQNuaWwFA1NFUAQQX3N0YXdMUEFtb3VudEtleQkAuQkCCQDMCAIFC3VzZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUNX3N0YXdMUEFtb3VudAUDbmlsBQNTRVAEEF9sb2NrQXRIZWlnaHRLZXkJALkJAgkAzAgCBQt1c2VyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFDV9sb2NrQXRIZWlnaHQFA25pbAUDU0VQBApfbG9ja0lkS2V5CQC5CQIJAMwIAgULdXNlckFkZHJlc3MJAMwIAgUNdHJhbnNhY3Rpb25JRAkAzAgCBQdfbG9ja0lkBQNuaWwFA1NFUAQPX3RvdGFsTG9ja2VkS2V5CQC5CQIJAMwIAgULdXNlckFkZHJlc3MJAMwIAgUQX3VzZXJUb3RhbExvY2tlZAUDbmlsBQNTRVAEEl9sb2NhbExvY2tJbmRleEtleQkAuQkCCQDMCAIFC3VzZXJBZGRyZXNzCQDMCAIFFF91c2VyTG9jYWxJbmRleENvdW50BQNuaWwFA1NFUAQXX2xvY2tQZXJpb2RJbk1pbGlTZWNLZXkJALkJAgkAzAgCBQt1c2VyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFFF9sb2NrUGVyaW9kSW5NaWxpU2VjBQNuaWwFA1NFUAQVX3RvdGFsV2F2ZXNDbGFpbWVkS2V5CQC5CQIJAMwIAgULdXNlckFkZHJlc3MJAMwIAgUNdHJhbnNhY3Rpb25JRAkAzAgCBRJfdG90YWxXYXZlc0NsYWltZWQFA25pbAUDU0VQBBJfdXNlckxlYXNlU3RhdGVLZXkJALkJAgkAzAgCBQt1c2VyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFD191c2VyTGVhc2VTdGF0ZQUDbmlsBQNTRVAECnRyeElkRW50cnkJALkJAgkAzAgCAgIlcwkAzAgCBQ10cmFuc2FjdGlvbklEBQNuaWwFA1NFUAQRbG9ja0R1cmF0aW9uRW50cnkJALkJAgkAzAgCAgIlZAkAzAgCCQCkAwEFDGxvY2tEdXJhdGlvbgUDbmlsBQNTRVAEDmxvY2tJbmRleEVudHJ5CQC5CQIJAMwIAgICJWQJAMwIAgkApAMBBQlsb2NrSW5kZXgFA25pbAUDU0VQBBB3YXZlc0Ftb3VudEVudHJ5CQC5CQIJAMwIAgICJWQJAMwIAgkApAMBBQt3YXZlc0Ftb3VudAUDbmlsBQNTRVAED3N0YXdBbW91bnRFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQUKc3Rhd0Ftb3VudAUDbmlsBQNTRVAEEXN0YXdMUEFtb3VudEVudHJ5CQC5CQIJAMwIAgICJWQJAMwIAgkApAMBBQxzdGF3TFBBbW91bnQFA25pbAUDU0VQBBFsb2NrQXRIZWlnaHRFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQUMbG9ja0F0SGVpZ2h0BQNuaWwFA1NFUAQLbG9ja0lkRW50cnkJALkJAgkAzAgCAgIlYgkAzAgCBQZsb2NrSWQFA25pbAUDU0VQBBB0b3RhbExvY2tlZEVudHJ5CQC5CQIJAMwIAgICJWQJAMwIAgkApAMBBQt0b3RhbExvY2tlZAUDbmlsBQNTRVAEE3VzZXJMb2NhbEluZGV4RW50cnkJALkJAgkAzAgCAgIlZAkAzAgCCQCkAwEFD2xvY2FsSW5kZXhDb3VudAUDbmlsBQNTRVAEGGxvY2tQZXJpb2RJbk1pbGlTZWNFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQUSbG9ja0R1cmF0aW9uSW5NaWxpBQNuaWwFA1NFUAQWdG90YWxXYXZlc0NsYWltZWRFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQAABQNuaWwFA1NFUAQTdXNlckxlYXNlU3RhdGVFbnRyeQkAuQkCCQDMCAICAiVzCQDMCAIFCmxlYXNlU3RhdGUFA25pbAUDU0VQCQDMCAIJARFfd3JpdGVDb25zdFN0cmluZwIFCF90eElkS2V5BQp0cnhJZEVudHJ5CQDMCAIJARFfd3JpdGVDb25zdFN0cmluZwIFDV9sb2NrSW5kZXhLZXkFDmxvY2tJbmRleEVudHJ5CQDMCAIJAQlfd3JpdGVTdHICBRJfbG9jYWxMb2NrSW5kZXhLZXkFE3VzZXJMb2NhbEluZGV4RW50cnkJAMwIAgkBCV93cml0ZVN0cgIFD190b3RhbExvY2tlZEtleQUQdG90YWxMb2NrZWRFbnRyeQkAzAgCCQERX3dyaXRlQ29uc3RTdHJpbmcCBRBfbG9ja0R1cmF0aW9uS2V5BRFsb2NrRHVyYXRpb25FbnRyeQkAzAgCCQERX3dyaXRlQ29uc3RTdHJpbmcCBRdfbG9ja1BlcmlvZEluTWlsaVNlY0tleQUYbG9ja1BlcmlvZEluTWlsaVNlY0VudHJ5CQDMCAIJARFfd3JpdGVDb25zdFN0cmluZwIFD193YXZlc0Ftb3VudEtleQUQd2F2ZXNBbW91bnRFbnRyeQkAzAgCCQERX3dyaXRlQ29uc3RTdHJpbmcCBQ5fc3Rhd0Ftb3VudEtleQUPc3Rhd0Ftb3VudEVudHJ5CQDMCAIJAQlfd3JpdGVTdHICBRBfc3Rhd0xQQW1vdW50S2V5BRFzdGF3TFBBbW91bnRFbnRyeQkAzAgCCQEJX3dyaXRlU3RyAgUVX3RvdGFsV2F2ZXNDbGFpbWVkS2V5BRZ0b3RhbFdhdmVzQ2xhaW1lZEVudHJ5CQDMCAIJARFfd3JpdGVDb25zdFN0cmluZwIFEF9sb2NrQXRIZWlnaHRLZXkFEWxvY2tBdEhlaWdodEVudHJ5CQDMCAIJARFfd3JpdGVDb25zdFN0cmluZwIFCl9sb2NrSWRLZXkFC2xvY2tJZEVudHJ5CQDMCAIJAQlfd3JpdGVTdHICBRJfdXNlckxlYXNlU3RhdGVLZXkFE3VzZXJMZWFzZVN0YXRlRW50cnkFA25pbAEHX3N0YXdNRgIKbG9ja1BlcmlvZA9jb2xsYXRlcmFsV2F2ZXMEC19hZGp1c3RlZE1yCQEKX2NvbXB1dGVNcgAEA3JldAkAaQIJAGsDBQ9jb2xsYXRlcmFsV2F2ZXMJAGgCBQNfRHQIBQtfYWRqdXN0ZWRNcgJfMQkBBF9QcHkBBQpsb2NrUGVyaW9kBQ1fdW5pdERlY2ltYWxzAwkAAAIJAJADAQgFC19hZGp1c3RlZE1yAl8yAAAJAJQKAgUDcmV0BQNuaWwJAJQKAgUDcmV0CAULX2FkanVzdGVkTXICXzIBEl9lbWlzc2lvblJhdGVXYXZlcwIKbG9ja1BlcmlvZApjb2xsYXRlcmFsBA9leHRlbnNpb25GYWN0b3IJAGsDBQpsb2NrUGVyaW9kAA8ACgQBcgkAaQIJAGsDCQBrAwABAAEFA19EdAUKY29sbGF0ZXJhbAkAZQIFD2V4dGVuc2lvbkZhY3RvcgUKbG9ja1BlcmlvZAACBAxlbWlzc2lvblJhdGUFAXIFDGVtaXNzaW9uUmF0ZQEQX2luY3JUb3RhbFN0YXdMUAEGYW1vdW50BAlvbGRTdGF3TFAJAQ9fdGhyb3dPclJldHVybkkCCQEFX2dldEkBBQxfdG90YWxTdGF3TFACIGNvdWxkIG5vdCBnZXQgdGhlIHJ1bm5pbmcgU3Rhd0xQCQDMCAIJAQlfd3JpdGVJbnQCBQxfdG90YWxTdGF3TFAJAGQCBQlvbGRTdGF3TFAFBmFtb3VudAUDbmlsARBfZGVjclRvdGFsU3Rhd0xQAQZhbW91bnQECW9sZFN0YXdMUAkBD190aHJvd09yUmV0dXJuSQIJAQVfZ2V0SQEFDF90b3RhbFN0YXdMUAIgY291bGQgbm90IGdldCB0aGUgcnVubmluZyBTdGF3TFAJAMwIAgkBCV93cml0ZUludAIFDF90b3RhbFN0YXdMUAkAZQIFCW9sZFN0YXdMUAUGYW1vdW50BQNuaWwBEl9pbmNyVG90YWxXYXZlc1JlZgEGYW1vdW50BAtvbGRXYXZlc1JlZgkBD190aHJvd09yUmV0dXJuSQIJAQVfZ2V0SQEFDl90b3RhbFdhdmVzUmVmAiBjb3VsZCBub3QgZ2V0IHRvdGFsIGxvY2tlZCB3YXZlcwkAzAgCCQEJX3dyaXRlSW50AgUOX3RvdGFsV2F2ZXNSZWYJAGQCBQtvbGRXYXZlc1JlZgUGYW1vdW50BQNuaWwBEl9kZWNyVG90YWxXYXZlc1JlZgEGYW1vdW50BAtvbGRXYXZlc1JlZgkBD190aHJvd09yUmV0dXJuSQIJAQVfZ2V0SQEFDl90b3RhbFdhdmVzUmVmAiBjb3VsZCBub3QgZ2V0IHRvdGFsIGxvY2tlZCB3YXZlcwkAzAgCCQEJX3dyaXRlSW50AgUOX3RvdGFsV2F2ZXNSZWYJAGUCBQtvbGRXYXZlc1JlZgUGYW1vdW50BQNuaWwBEF9nZXROZXdUaW1lU3RhbXABC2Jsb2NrSGVpZ2h0BAR0aW1lBAckbWF0Y2gwCQDtBwEFC2Jsb2NrSGVpZ2h0AwkAAQIFByRtYXRjaDACCUJsb2NrSW5mbwQIdGltZUluZm8FByRtYXRjaDAIBQh0aW1lSW5mbwl0aW1lc3RhbXAJAAIBAhRjb3VubGQgZ2V0IHRpbWVzdGFtcAUEdGltZQEQZ2V0QXNzZXRRdWFudGl0eQEHYXNzZXRJRAQHJG1hdGNoMAkA7AcBCQDZBAEFB2Fzc2V0SUQDCQABAgUHJG1hdGNoMAIFQXNzZXQEAXQFByRtYXRjaDAIBQF0CHF1YW50aXR5CQACAQIPYXNzZXQgbm90IGZvdW5kBgFpAQtnZXRFbWlzc2lvbgIKbG9ja1BlcmlvZApjb2xsYXRlcmFsBAZjaGVjazEJAQxfb25seU1hbmFnZXIBBQFpAwkAAAIFBmNoZWNrMQUGY2hlY2sxCQCUCgIFA25pbAkBEl9lbWlzc2lvblJhdGVXYXZlcwIFCmxvY2tQZXJpb2QFCmNvbGxhdGVyYWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEEaW5pdAQHbWFuYWdlcgNkZngHYXNzZXRJRAlsZWFzZU5vZGUEFG1hbmFnZXJBbHJlYWR5RXhpc3RzAwkBCWlzRGVmaW5lZAEJAQVfZ2V0UwEFCF9tYW5hZ2VyCQEMX29ubHlNYW5hZ2VyAQUBaQYDCQAAAgUUbWFuYWdlckFscmVhZHlFeGlzdHMFFG1hbmFnZXJBbHJlYWR5RXhpc3RzBAZjaGVjazEJARBfdmFsaWRhdGVBZGRyZXNzAgUHbWFuYWdlcgIPaW52YWxpZCBhZGRyZXNzAwkAAAIFBmNoZWNrMQUGY2hlY2sxBAZjaGVjazIJARBfdmFsaWRhdGVBZGRyZXNzAgUDZGZ4Ag9pbnZhbGlkIGFkZHJlc3MDCQAAAgUGY2hlY2syBQZjaGVjazIEBmNoZWNrMwkBEF92YWxpZGF0ZUFkZHJlc3MCBQlsZWFzZU5vZGUCD2ludmFsaWQgYWRkcmVzcwMJAAACBQZjaGVjazMFBmNoZWNrMwQGY2hlY2s0AwkBDl92YWxpZGF0ZUFzc2V0AgUHYXNzZXRJRAINaW52YWxpZCBhc3NldAYJAAIBAhBpbnZhbGlkIGFzc2V0IElkAwkAAAIFBmNoZWNrNAUGY2hlY2s0BBBjaXJjdWxhdGlvbkluZGV4CQEMX3NldFBhcmFtVmFsAgUVX2NpcmN1bGF0aW9uSW5jckluZGV4AAAEF3BlcmNlbnRhZ2VSZWR1Y3Rpb25Jbk1yCQEMX3NldFBhcmFtVmFsAgUaX3BlcmNlbnRhZ2VSZWR1Y3Rpb25GYWN0b3IAAAQCTXIJAQxfc2V0UGFyYW1WYWwCBQNfTXIFDV91bml0RGVjaW1hbHMED3RvdGFsU3Rhd01pbnRlZAkBDF9zZXRQYXJhbVZhbAIFCl90b3RhbFN0YXcAAAQYdG90YWxTdGF3TFBJbkNpcmN1bGF0aW9uCQEMX3NldFBhcmFtVmFsAgUMX3RvdGFsU3Rhd0xQAAAEEGdsb2JhbEluZGV4Q291bnQJAQxfc2V0UGFyYW1WYWwCBRFfZ2xvYmFsSW5kZXhDb3VudAAABA10b3RhbFdhdmVzUmVmCQEMX3NldFBhcmFtVmFsAgUOX3RvdGFsV2F2ZXNSZWYAAAkAzAgCCQERX3dyaXRlR2xvYmFsUGFyYW0CBQhfbWFuYWdlcgUHbWFuYWdlcgkAzAgCCQERX3dyaXRlR2xvYmFsUGFyYW0CBQRfRGZ4BQNkZngJAMwIAgkBEV93cml0ZUdsb2JhbFBhcmFtAgUMX3N0YXdBc3NldElkBQdhc3NldElECQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFDl9sZXNzZWVBZGRyZXNzBQlsZWFzZU5vZGUJAMwIAgkBEV93cml0ZUdsb2JhbFBhcmFtAgUVX2NpcmN1bGF0aW9uSW5jckluZGV4BRBjaXJjdWxhdGlvbkluZGV4CQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFA19NcgUCTXIJAMwIAgkBEV93cml0ZUdsb2JhbFBhcmFtAgUaX3BlcmNlbnRhZ2VSZWR1Y3Rpb25GYWN0b3IFF3BlcmNlbnRhZ2VSZWR1Y3Rpb25Jbk1yCQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFDl90b3RhbFdhdmVzUmVmBQ10b3RhbFdhdmVzUmVmCQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFDF90b3RhbFN0YXdMUAUYdG90YWxTdGF3TFBJbkNpcmN1bGF0aW9uCQDMCAIJARFfd3JpdGVHbG9iYWxQYXJhbQIFCl90b3RhbFN0YXcFD3RvdGFsU3Rhd01pbnRlZAkAzAgCCQERX3dyaXRlR2xvYmFsUGFyYW0CBRFfZ2xvYmFsSW5kZXhDb3VudAUQZ2xvYmFsSW5kZXhDb3VudAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBEm1vZGlmeUdsb2JhbFBhcmFtcwEDdmFsBAZjaGVjazEJAQxfb25seU1hbmFnZXIBBQFpAwkAAAIFBmNoZWNrMQUGY2hlY2sxBAhlcnJvck1zZwkAuQkCCQDMCAICA2dvdAkAzAgCAgxsaXN0IHNpemUgb2YJAMwIAgkApAMBCQCQAwEFA3ZhbAkAzAgCAiVidXQgZXhwZWN0ZWQgW2dsb2JhbF9rZXksIHZhbHVlXSBwYWlyBQNuaWwCASAEBmNoZWNrMgkBCF90aHJvd0lmAgkBAiE9AgkAkAMBBQN2YWwAAgUIZXJyb3JNc2cDCQAAAgUGY2hlY2syBQZjaGVjazIEA2tleQkAkQMCBQN2YWwAAAQHdmFsVHlwZQkAtgkBCQCRAwIFA3ZhbAABBAckbWF0Y2gwBQd2YWxUeXBlAwkAAQIFByRtYXRjaDACA0ludAQBeAUHJG1hdGNoMAQLdmFsaWRhdGVLZXkJAQhfdGhyb3dJZgIJAAACCQEFX2dldFMBBQNrZXkFBHVuaXQJAKwCAgkArAICAgRrZXkgBQNrZXkCDyBub3QgcmVjb2duaXplZAMJAAACBQt2YWxpZGF0ZUtleQULdmFsaWRhdGVLZXkEEGVuc3VyZVZhbGlkUGFpcnMEByRtYXRjaDEJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUDa2V5AwkAAQIFByRtYXRjaDECA0ludAQBdAUHJG1hdGNoMQYJAAIBAhZpbnZhbGlkIGtleS12YWx1ZSBwYWlyAwkAAAIFEGVuc3VyZVZhbGlkUGFpcnMFEGVuc3VyZVZhbGlkUGFpcnMJAMwIAgkBEV93cml0ZUdsb2JhbFBhcmFtAgUDa2V5BQF4BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQABAgUHJG1hdGNoMAIEVW5pdAQBeAUHJG1hdGNoMAQLdmFsaWRhdGVLZXkJAQhfdGhyb3dJZgIJAAACCQEFX2dldFMBBQNrZXkFBHVuaXQJAKwCAgkArAICAgRrZXkgBQNrZXkCDyBub3QgcmVjb2duaXplZAMJAAACBQt2YWxpZGF0ZUtleQULdmFsaWRhdGVLZXkEC3N0cmluZ1ZhbHVlCQCRAwIFA3ZhbAABBApyZWZBZGRyZXNzCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFCF9tYW5hZ2VyBAZjaGVjazQEByRtYXRjaDEFCnJlZkFkZHJlc3MDCQABAgUHJG1hdGNoMQIGU3RyaW5nBAdzdHJUeXBlBQckbWF0Y2gxAwkAAAIJALECAQUHc3RyVHlwZQkAsQIBBQtzdHJpbmdWYWx1ZQkBEF92YWxpZGF0ZUFkZHJlc3MCBQtzdHJpbmdWYWx1ZQIjc3RyaW5nIHR5cGUgZm9yIHZhbHVlIG5vdCBzdXBwb3J0ZWQJAQ5fdmFsaWRhdGVBc3NldAIFC3N0cmluZ1ZhbHVlAiNzdHJpbmcgdHlwZSBmb3IgdmFsdWUgbm90IHN1cHBvcnRlZAcDCQAAAgUGY2hlY2s0BQZjaGVjazQJAMwIAgkBEV93cml0ZUdsb2JhbFBhcmFtAgUDa2V5BQtzdHJpbmdWYWx1ZQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQkArAICAhFmYWlsZWQgdG8gbW9kaWZ5IAkAkQMCBQN2YWwAAAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQpyZXZva2VMb2NrAAQGY2hlY2sxCQEMX29ubHlNYW5hZ2VyAQUBaQMJAAACBQZjaGVjazEFBmNoZWNrMQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBWNsYWltAQ10cmFuc2FjdGlvbklEBA1jYWxsZXJBZGRyZXNzCQDYBAEICAUBaQZjYWxsZXIFYnl0ZXMEDWNvbGxhdGVyYWxLZXkJALkJAgkAzAgCBQ1jYWxsZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUMX3dhdmVzQW1vdW50BQNuaWwFA1NFUAQNbG9ja3BlcmlvZEtleQkAuQkCCQDMCAIFDWNhbGxlckFkZHJlc3MJAMwIAgUNdHJhbnNhY3Rpb25JRAkAzAgCBQ1fbG9ja0R1cmF0aW9uBQNuaWwFA1NFUAQJbG9ja0lkS2V5CQC5CQIJAMwIAgUNY2FsbGVyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFB19sb2NrSWQFA25pbAUDU0VQBBNsb2NrcGVyaW9kSW5NaWxpS2V5CQC5CQIJAMwIAgUNY2FsbGVyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFFF9sb2NrUGVyaW9kSW5NaWxpU2VjBQNuaWwFA1NFUAQUdG90YWxXYXZlc0NsYWltZWRLZXkJALkJAgkAzAgCBQ1jYWxsZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUSX3RvdGFsV2F2ZXNDbGFpbWVkBQNuaWwFA1NFUAQPc3Rhd0xQQW1vdW50S2V5CQC5CQIJAMwIAgUNY2FsbGVyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFDV9zdGF3TFBBbW91bnQFA25pbAUDU0VQBA53YXZlc0Ftb3VudEtleQkAuQkCCQDMCAIFDWNhbGxlckFkZHJlc3MJAMwIAgUNdHJhbnNhY3Rpb25JRAkAzAgCBQxfd2F2ZXNBbW91bnQFA25pbAUDU0VQBBd1c2VyVG90YWxXYXZlc0xvY2tlZEtleQkAuQkCCQDMCAIFDWNhbGxlckFkZHJlc3MJAMwIAgUQX3VzZXJUb3RhbExvY2tlZAUDbmlsBQNTRVAEEXVzZXJMZWFzZVN0YXRlS2V5CQC5CQIJAMwIAgUNY2FsbGVyQWRkcmVzcwkAzAgCBQ10cmFuc2FjdGlvbklECQDMCAIFD191c2VyTGVhc2VTdGF0ZQUDbmlsBQNTRVAEDWxlYXNlU3RhdGVLZXkJALkJAgkAzAgCBQ1jYWxsZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUPX3VzZXJMZWFzZVN0YXRlBQNuaWwFA1NFUAQdZGF5c0FmdGVyTG9ja1BlcmlvZEVsYXNwZWRLZXkJALkJAgkAzAgCBQ1jYWxsZXJBZGRyZXNzCQDMCAIFDXRyYW5zYWN0aW9uSUQJAMwIAgUUX2RheXNBZnRlckxvY2tQZXJpb2QFA25pbAUDU0VQBA5nbG9iYWxXYXZlc1JlZgQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBQ5fdG90YWxXYXZlc1JlZgMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAiBmYWlsZWQgdG8gZ2V0IGdsb2JhbCB0b3RhbCB3YXZlcwMJAAACBQ5nbG9iYWxXYXZlc1JlZgUOZ2xvYmFsV2F2ZXNSZWYEDGdsb2JhbFN0YXdQTAQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBQxfdG90YWxTdGF3TFADCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIgZmFpbGVkIHRvIGdldCBnbG9iYWwgdG90YWwgd2F2ZXMDCQAAAgUMZ2xvYmFsU3Rhd1BMBQxnbG9iYWxTdGF3UEwEBmxvY2tJZAQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBQlsb2NrSWRLZXkDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQBdAUHJG1hdGNoMAUBdAkAAgECFmZhaWxlZCB0byBnZXQgbGVhc2UgaWQDCQAAAgUGbG9ja0lkBQZsb2NrSWQEFHVzZXJUb3RhbFdhdmVzTG9ja2VkBAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFF3VzZXJUb3RhbFdhdmVzTG9ja2VkS2V5AwkAAQIFByRtYXRjaDACA0ludAQBdAUHJG1hdGNoMAUBdAkAAgECMGZhaWxlZCB0byBnZXQgdG90YWwgd2F2ZXMgbG9ja2VkIGJ5IHRoaXMgYWRkcmVzcwMJAAACBRR1c2VyVG90YWxXYXZlc0xvY2tlZAUUdXNlclRvdGFsV2F2ZXNMb2NrZWQEC3dhdmVzQW1vdW50BAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFDndhdmVzQW1vdW50S2V5AwkAAQIFByRtYXRjaDACA0ludAQBdAUHJG1hdGNoMAUBdAkAAgECIGZhaWxlZCB0byBnZXQgdG90YWwgd2F2ZXMgbG9ja2VkAwkAAAIFC3dhdmVzQW1vdW50BQt3YXZlc0Ftb3VudAQRdG90YWxXYXZlc0NsYWltZWQEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUUdG90YWxXYXZlc0NsYWltZWRLZXkDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIhZmFpbGVkIHRvIGdldCB0b3RhbCB3YXZlcyBjbGFpbWVkAwkAAAIFEXRvdGFsV2F2ZXNDbGFpbWVkBRF0b3RhbFdhdmVzQ2xhaW1lZAQMc3Rhd0xQQW1vdW50BAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFD3N0YXdMUEFtb3VudEtleQMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAhRmYWlsZWQgdG8gZ2V0IHN0YXdQTAMJAAACBQxzdGF3TFBBbW91bnQFDHN0YXdMUEFtb3VudAQQbG9ja1BlcmlvZEluTWlsaQQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBRNsb2NrcGVyaW9kSW5NaWxpS2V5AwkAAQIFByRtYXRjaDACA0ludAQBdAUHJG1hdGNoMAUBdAkAAgECImZhaWxlZCB0byBnZXQgbG9jayBwZXJpb2QgdGltZXNwYW0DCQAAAgUQbG9ja1BlcmlvZEluTWlsaQUQbG9ja1BlcmlvZEluTWlsaQQQY3VycmVudFRpbWVTdGFtcAQHJG1hdGNoMAkBEF9nZXROZXdUaW1lU3RhbXABBQZoZWlnaHQDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIfZmFpbGVkIHRvIGdldCBjdXJyZW50IHRpbWVzdGFtcAMJAAACBRBjdXJyZW50VGltZVN0YW1wBRBjdXJyZW50VGltZVN0YW1wBApjb2xsYXRlcmFsBAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFDWNvbGxhdGVyYWxLZXkDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIYZmFpbGVkIHRvIGdldCBjb2xsYXRlcmFsAwkAAAIFCmNvbGxhdGVyYWwFCmNvbGxhdGVyYWwECmxvY2tQZXJpb2QEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUNbG9ja3BlcmlvZEtleQMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAhhmYWlsZWQgdG8gZ2V0IGxvY2tQZXJpb2QDCQAAAgUKbG9ja1BlcmlvZAUKbG9ja1BlcmlvZAQRY3VycmVudExlYXNlU3RhdGUEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQURdXNlckxlYXNlU3RhdGVLZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAF0BQckbWF0Y2gwBQF0CQACAQIZZmFpbGVkIHRvIGdldCBsZWFzZSBzdGF0ZQMJAAACBRFjdXJyZW50TGVhc2VTdGF0ZQURY3VycmVudExlYXNlU3RhdGUECmxlYXNlU3RhdGUEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUNbGVhc2VTdGF0ZUtleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXQFByRtYXRjaDAFAXQJAAIBAiJmYWlsZWQgdG8gZ2V0IGxlYXNlIHN0YXRlIGZvciB1c2VyAwkAAAIFCmxlYXNlU3RhdGUFCmxlYXNlU3RhdGUEGmRheXNBZnRlckxvY2tQZXJpb2RFbGFzcGVkBAckbWF0Y2gwCQEFX2dldFMBBR1kYXlzQWZ0ZXJMb2NrUGVyaW9kRWxhc3BlZEtleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXQFByRtYXRjaDAEByRtYXRjaDEJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUdZGF5c0FmdGVyTG9ja1BlcmlvZEVsYXNwZWRLZXkDCQABAgUHJG1hdGNoMQIDSW50BAF6BQckbWF0Y2gxBQF6AAAAAAMJAAACBRpkYXlzQWZ0ZXJMb2NrUGVyaW9kRWxhc3BlZAUaZGF5c0FmdGVyTG9ja1BlcmlvZEVsYXNwZWQEBmNoZWNrMQkBCF90aHJvd0lmAgkAZgIFEGxvY2tQZXJpb2RJbk1pbGkFEGN1cnJlbnRUaW1lU3RhbXACKmxvY2sgcGVyaW9kIGZvciB0aGlzIGVudHJ5IGhhcyBub3QgZWxhcHNlZAMJAAACBQZjaGVjazEFBmNoZWNrMQQLbGVhc2VBY3Rpb24DCQAAAgURY3VycmVudExlYXNlU3RhdGUCBmxlYXNlZAkAlAoCCQELTGVhc2VDYW5jZWwBBQZsb2NrSWQJAQlfd3JpdGVTdHICBRF1c2VyTGVhc2VTdGF0ZUtleQIJY2FuY2VsbGVkCQCUCgIJAQlfd3JpdGVTdHICBRF1c2VyTGVhc2VTdGF0ZUtleQIJY2FuY2VsbGVkCQEJX3dyaXRlU3RyAgURdXNlckxlYXNlU3RhdGVLZXkCCWNhbmNlbGxlZAQGY2hlY2syCQEIX3Rocm93SWYCAwkAAAIAAAULd2F2ZXNBbW91bnQGCQAAAgAABQxzdGF3TFBBbW91bnQCIWFsbCBjbGFpbXMgZXhoYXVzdGVkIGZvciB0aGlzIHRyeAMJAAACBQZjaGVjazIFBmNoZWNrMgQSZW1pc3Npb25WYWx1ZVBlckRUCQESX2VtaXNzaW9uUmF0ZVdhdmVzAgUKbG9ja1BlcmlvZAUKY29sbGF0ZXJhbAQLY2xhaW1BY3Rpb24EDXRpbWVTdGFtcERpZmYJAGUCBRBjdXJyZW50VGltZVN0YW1wBRBsb2NrUGVyaW9kSW5NaWxpBAV4ZGF5cwkAaQIFDXRpbWVTdGFtcERpZmYFA19EdAMJAAACBQV4ZGF5cwAACQACAQIibGVzcyB0aGFuIDI0aHJzIGJlZm9yZSBmaXJzdCBjbGFpbQMJAGcCBRpkYXlzQWZ0ZXJMb2NrUGVyaW9kRWxhc3BlZAUFeGRheXMJAAIBAh8yNGhycyBvciBsZXNzIGJlZm9yZSBuZXh0IGNsYWltBBR0b3RhbEFtb3VudENsYWltYWJsZQkAaAIFGmRheXNBZnRlckxvY2tQZXJpb2RFbGFzcGVkBRJlbWlzc2lvblZhbHVlUGVyRFQECGNoZWNrM18xCQEIX3Rocm93SWYCCQAAAgUUdG90YWxBbW91bnRDbGFpbWFibGUFEXRvdGFsV2F2ZXNDbGFpbWVkAhxjYW4gb25seSBjbGFpbSBvbmNlIGluIDI0aHJzAwkAAAIFCGNoZWNrM18xBQhjaGVjazNfMQQIY2hlY2szXzIJAQhfdGhyb3dJZgIJAGYCCQBkAgUUdG90YWxBbW91bnRDbGFpbWFibGUFEXRvdGFsV2F2ZXNDbGFpbWVkBQt3YXZlc0Ftb3VudAIUYWxsIGNsYWltcyBleGhhdXN0ZWQDCQAAAgUIY2hlY2szXzIFCGNoZWNrM18yBBFjbGFpbUFtb3VudFRvU2VuZAMJAAACBRpkYXlzQWZ0ZXJMb2NrUGVyaW9kRWxhc3BlZAABBRR0b3RhbEFtb3VudENsYWltYWJsZQkAZQIFFHRvdGFsQW1vdW50Q2xhaW1hYmxlBRF0b3RhbFdhdmVzQ2xhaW1lZAQSbmV3VG90YWxXYXZlc0NsYWltBRR0b3RhbEFtb3VudENsYWltYWJsZQQObmV3V2F2ZXNBbW91bnQDCQAAAgUaZGF5c0FmdGVyTG9ja1BlcmlvZEVsYXNwZWQAAQkAZQIFC3dhdmVzQW1vdW50BRR0b3RhbEFtb3VudENsYWltYWJsZQkAZQIFC3dhdmVzQW1vdW50CQBlAgUUdG90YWxBbW91bnRDbGFpbWFibGUFEXRvdGFsV2F2ZXNDbGFpbWVkBA9uZXdTdGF3TFBBbW91bnQDCQAAAgUaZGF5c0FmdGVyTG9ja1BlcmlvZEVsYXNwZWQAAQkAZQIFDHN0YXdMUEFtb3VudAUUdG90YWxBbW91bnRDbGFpbWFibGUJAGUCBQxzdGF3TFBBbW91bnQJAGUCBRR0b3RhbEFtb3VudENsYWltYWJsZQURdG90YWxXYXZlc0NsYWltZWQEEG5ld0dsb2JhbFdhdmVSZWYJAGUCBQ5nbG9iYWxXYXZlc1JlZgUObmV3V2F2ZXNBbW91bnQED25ld0dsb2JhbFN0YXdQTAkAZQIFDGdsb2JhbFN0YXdQTAUPbmV3U3Rhd0xQQW1vdW50BBduZXdVc2VyVG90YWxXYXZlc0xvY2tlZAkAZQIFFHVzZXJUb3RhbFdhdmVzTG9ja2VkBRFjbGFpbUFtb3VudFRvU2VuZAQQd2F2ZXNBbW91bnRFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQUObmV3V2F2ZXNBbW91bnQFA25pbAUDU0VQBBFzdGF3TFBBbW91bnRFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQUPbmV3U3Rhd0xQQW1vdW50BQNuaWwFA1NFUAQWdG90YWxXYXZlc0NsYWltZWRFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQUSbmV3VG90YWxXYXZlc0NsYWltBQNuaWwFA1NFUAQcbmV3VXNlclRvdGFsV2F2ZXNMb2NrZWRFbnRyeQkAuQkCCQDMCAICAiVkCQDMCAIJAKQDAQUXbmV3VXNlclRvdGFsV2F2ZXNMb2NrZWQFA25pbAUDU0VQBB9kYXlzQWZ0ZXJMb2NrUGVyaW9kRWxhc3BlZEVudHJ5CQC5CQIJAMwIAgICJWQJAMwIAgkApAMBBQV4ZGF5cwUDbmlsBQNTRVAJAMwIAggFC2xlYXNlQWN0aW9uAl8xCQDMCAIIBQtsZWFzZUFjdGlvbgJfMgkAzAgCCQEJX3dyaXRlU3RyAgUOd2F2ZXNBbW91bnRLZXkFEHdhdmVzQW1vdW50RW50cnkJAMwIAgkBCV93cml0ZVN0cgIFD3N0YXdMUEFtb3VudEtleQURc3Rhd0xQQW1vdW50RW50cnkJAMwIAgkBCV93cml0ZVN0cgIFFHRvdGFsV2F2ZXNDbGFpbWVkS2V5BRZ0b3RhbFdhdmVzQ2xhaW1lZEVudHJ5CQDMCAIJAQlfd3JpdGVTdHICBRd1c2VyVG90YWxXYXZlc0xvY2tlZEtleQUcbmV3VXNlclRvdGFsV2F2ZXNMb2NrZWRFbnRyeQkAzAgCCQEJX3dyaXRlU3RyAgUdZGF5c0FmdGVyTG9ja1BlcmlvZEVsYXNwZWRLZXkFH2RheXNBZnRlckxvY2tQZXJpb2RFbGFzcGVkRW50cnkJAMwIAgkBEV93cml0ZUdsb2JhbFBhcmFtAgUOX3RvdGFsV2F2ZXNSZWYFEG5ld0dsb2JhbFdhdmVSZWYJAMwIAgkBEV93cml0ZUdsb2JhbFBhcmFtAgUMX3RvdGFsU3Rhd0xQBQ9uZXdHbG9iYWxTdGF3UEwJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBB0FkZHJlc3MBCAgFAWkGY2FsbGVyBWJ5dGVzBRFjbGFpbUFtb3VudFRvU2VuZAUEdW5pdAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFC2NsYWltQWN0aW9uBQtjbGFpbUFjdGlvbgULY2xhaW1BY3Rpb24JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIbWludFN0YXcBCmxvY2tQZXJpb2QEDWNhbGxlckFkZHJlc3MJANgEAQgIBQFpBmNhbGxlcgVieXRlcwQFdHJ4SUQJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAQGY2hlY2sxCQEIX3Rocm93SWYCCQECIT0CAAEJAJADAQgFAWkIcGF5bWVudHMCFG5vIHBheW1lbnRzIGF0dGFjaGVkAwkAAAIFBmNoZWNrMQUGY2hlY2sxBAZjaGVjazIDCQEJaXNEZWZpbmVkAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkCQACAQIUb25seSB3YXZlcyBzdXBwb3J0ZWQGAwkAAAIFBmNoZWNrMgUGY2hlY2syBA1hbW91bnRJbldhdmVzCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQGY2hlY2szAwMJAGYCBQ5fbWluTG9ja0Ftb3VudAUNYW1vdW50SW5XYXZlcwYJAGYCBQ1hbW91bnRJbldhdmVzBQ5fbWF4TG9ja0Ftb3VudAkAAgECP2xvY2sgYW1vdW50IG91dCBvZiByYW5nZSwgbWluaW11bTogMSB3YXZlcywgbWF4aW11bTogMTAwMCB3YXZlcwYDCQAAAgUGY2hlY2szBQZjaGVjazMEBmNoZWNrNAMJAGYCBQ5fbWluTG9ja3BlcmlvZAUKbG9ja1BlcmlvZAkAAgECHm1pbmltdW0gb2YgMTQgZGF5cyBsb2NrIHBlcmlvZAYDCQAAAgUGY2hlY2s0BQZjaGVjazQEDXRvdGFsU3Rhd01pbnQJAQdfc3Rhd01GAgUKbG9ja1BlcmlvZAUNYW1vdW50SW5XYXZlcwQGc3Rhd1BMBQ1hbW91bnRJbldhdmVzBANmZWUJAGsDCAUNdG90YWxTdGF3TWludAJfMQAKAGQEEXVzZXJHZXRTdGF3QW1vdW50CQBlAggFDXRvdGFsU3Rhd01pbnQCXzEFA2ZlZQQTbG9ja1BlcmlvZFRvTWlsaXNlYwkAZAIJARBfZ2V0TmV3VGltZVN0YW1wAQUGaGVpZ2h0CQEOX2RheXNUb01pbGlTZWMBBQpsb2NrUGVyaW9kAwkAAAIFE2xvY2tQZXJpb2RUb01pbGlzZWMFE2xvY2tQZXJpb2RUb01pbGlzZWMECW5ld19pbmRleAQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBRFfZ2xvYmFsSW5kZXhDb3VudAMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAJAGQCBQF0AAEJAAIBAihmYWlsZWQgdG8gZ2V0IGN1cnJlbnQgZ2xvYmFsIGluZGV4IGNvdW50AwkAAAIFCW5ld19pbmRleAUJbmV3X2luZGV4BAphZGRyZXNzRmVlBAckbWF0Y2gwCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFBF9EZngDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAF0BQckbWF0Y2gwCQEHQWRkcmVzcwEJANkEAQUBdAkAAgECGWZhaWxlZCB0byBnZXQgZGZ4IGFkZHJlc3MDCQAAAgUKYWRkcmVzc0ZlZQUKYWRkcmVzc0ZlZQQLc3Rhd0Fzc2V0SWQEByRtYXRjaDAJARZfZ2V0UmVnaXN0cnlFbnRyeVZhbHVlAQUMX3N0YXdBc3NldElkAwkAAQIFByRtYXRjaDACBlN0cmluZwQBdAUHJG1hdGNoMAkA2QQBBQF0CQACAQIWZmFpbGVkIHRvIGdldCBhc3NldCBpZAMJAAACBQtzdGF3QXNzZXRJZAULc3Rhd0Fzc2V0SWQEBmxlc3NlZQQHJG1hdGNoMAkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBQ5fbGVzc2VlQWRkcmVzcwMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXQFByRtYXRjaDAJAQdBZGRyZXNzAQkA2QQBBQF0CQACAQIgZmFpbGVkIHRvIGdldCBsZWFzZSBub2RlIGFkZHJlc3MDCQAAAgUGbGVzc2VlBQZsZXNzZWUEEHVzZXJMb2NrSW5kZXhLZXkJALkJAgkAzAgCBQ1jYWxsZXJBZGRyZXNzCQDMCAIFFF91c2VyTG9jYWxJbmRleENvdW50BQNuaWwFA1NFUAQSdXNlclRvdGFsTG9ja2VkS2V5CQC5CQIJAMwIAgUNY2FsbGVyQWRkcmVzcwkAzAgCBRBfdXNlclRvdGFsTG9ja2VkBQNuaWwFA1NFUAQOdXNlckluZGV4Q291bnQEByRtYXRjaDAJAQVfZ2V0UwEFEHVzZXJMb2NrSW5kZXhLZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAF4BQckbWF0Y2gwBAckbWF0Y2gxCQEWX2dldFJlZ2lzdHJ5RW50cnlWYWx1ZQEFEHVzZXJMb2NrSW5kZXhLZXkDCQABAgUHJG1hdGNoMQIDSW50BAF0BQckbWF0Y2gxCQBkAgUBdAABAAEAAQMJAAACBQ51c2VySW5kZXhDb3VudAUOdXNlckluZGV4Q291bnQED3VzZXJUb3RhbExvY2tlZAQHJG1hdGNoMAkBBV9nZXRTAQUSdXNlclRvdGFsTG9ja2VkS2V5AwkAAQIFByRtYXRjaDACBlN0cmluZwQBeAUHJG1hdGNoMAQHJG1hdGNoMQkBFl9nZXRSZWdpc3RyeUVudHJ5VmFsdWUBBRJ1c2VyVG90YWxMb2NrZWRLZXkDCQABAgUHJG1hdGNoMQIDSW50BAF0BQckbWF0Y2gxCQBkAgUBdAUNYW1vdW50SW5XYXZlcwUNYW1vdW50SW5XYXZlcwUNYW1vdW50SW5XYXZlcwMJAAACBQ91c2VyVG90YWxMb2NrZWQFD3VzZXJUb3RhbExvY2tlZAQIbGVhc2VPdXQJAMQIAgUGbGVzc2VlBQ1hbW91bnRJbldhdmVzBApsZWFzZUlkU3RyCQDYBAEJALkIAQUIbGVhc2VPdXQJAM4IAgkAzggCCQDOCAIJAMwIAgUIbGVhc2VPdXQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUKYWRkcmVzc0ZlZQUDZmVlBQtzdGF3QXNzZXRJZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQEHQWRkcmVzcwEICAUBaQZjYWxsZXIFYnl0ZXMFEXVzZXJHZXRTdGF3QW1vdW50BQtzdGF3QXNzZXRJZAUDbmlsCQESX3JlZ2lzdGVyVXNlckVudHJ5DQUFdHJ4SUQFDWNhbGxlckFkZHJlc3MFCmxvY2tQZXJpb2QFE2xvY2tQZXJpb2RUb01pbGlzZWMFCW5ld19pbmRleAUNYW1vdW50SW5XYXZlcwURdXNlckdldFN0YXdBbW91bnQFBnN0YXdQTAUGaGVpZ2h0BQpsZWFzZUlkU3RyBQ91c2VyVG90YWxMb2NrZWQFDnVzZXJJbmRleENvdW50AgZsZWFzZWQJARJfdXBkYXRlR2xvYmFsRW50cnkEBQ1hbW91bnRJbldhdmVzCAUNdG90YWxTdGF3TWludAJfMQUGc3Rhd1BMBQluZXdfaW5kZXgIBQ10b3RhbFN0YXdNaW50Al8yCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAM/0r0I=", "height": 2499777, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 89BvCeFYBQokQWxnR2LjsG8tV5deDHdfmQa3sRZzP1ds Next: Eg2nBBkkEwv71cDbETRf7DFPMVx6HEjH7F1YJUTVUqU9 Diff:
OldNewDifferences
407407
408408 func _emissionRateWaves (lockPeriod,collateral) = {
409409 let extensionFactor = fraction(lockPeriod, 15, 10)
410- let r = (fraction(_Dt, collateral, (extensionFactor - lockPeriod)) / 2)
411- let emissionRate = (fraction(_unitDecimals, r, 1) * _Dt)
410+ let r = (fraction(fraction(1, 1, _Dt), collateral, (extensionFactor - lockPeriod)) / 2)
411+ let emissionRate = r
412412 emissionRate
413413 }
414414
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let SEP = "_"
55
66 let _minLockperiod = 1
77
88 let _unitDecimals = 100000000
99
1010 let _minLockAmount = (1 * _unitDecimals)
1111
1212 let _maxLockAmount = (1000 * _unitDecimals)
1313
1414 let _Dt = 86400000
1515
1616 func _Ppy (lockPeriod) = fraction(_unitDecimals, 365, lockPeriod)
1717
1818
1919 let _incrementRef = 1000000
2020
2121 let _percentageFee = fraction(_unitDecimals, 10, 100)
2222
2323 let _percentageReductionFactor = "Current_PercentageReduction_Factor_For_Mr"
2424
2525 let _Mr = "Minting_Rate"
2626
2727 let _stawAssetId = "Staw_AssetId"
2828
2929 let _manager = "manager"
3030
3131 let _Dfx = "Dfx"
3232
3333 let _circulationIncrIndex = "CirculationIncrementIndex"
3434
3535 let _lesseeAddress = "LeaseNode"
3636
3737 let _userEmissionAmountClaimed = "EmissionAmountClaimed"
3838
3939 let _userCanClaimEmissionAmount = "CanClaimEmissionAmount"
4040
4141 let _userAddress = "WalletAddress"
4242
4343 let _userLocalIndexCount = "TotalEntryIndexCount"
4444
4545 let _userTotalLocked = "TotalLocked"
4646
4747 let _lockDuration = "LockDuration"
4848
4949 let _lockIndex = "GlobalLockIndex"
5050
5151 let _lockId = "LockIdentifier"
5252
5353 let _wavesAmount = "AmountInWaves"
5454
5555 let _stawAmount = "AmountInStaw"
5656
5757 let _stawLPAmount = "AmountInStawLP"
5858
5959 let _txId = "TXID"
6060
6161 let _lockAtHeight = "LockAtHeight"
6262
6363 let _lockPeriodInMiliSec = "LocKPeriodInMilliSec"
6464
6565 let _totalWavesClaimed = "TotalWavesClaimed"
6666
6767 let _userLeaseState = "LeaseState"
6868
6969 let _totalStaw = "TotalStawMinted"
7070
7171 let _totalWavesRef = "TotalWavesLocked"
7272
7373 let _totalStawLP = "TotalStawLP"
7474
7575 let _globalIndexCount = "IndexCount"
7676
7777 let _daysAfterLockPeriod = "DaysAfterLockPeriodElasped"
7878
7979 func _getI (key) = getInteger(this, key)
8080
8181
8282 func _getS (key) = getString(this, key)
8383
8484
8585 func _getB (key) = getBoolean(this, key)
8686
8787
8888 func _getBV (key) = value(getBoolean(this, key))
8989
9090
9191 func _getIV (key) = value(getInteger(this, key))
9292
9393
9494 func _getSV (key) = value(getString(this, key))
9595
9696
9797 func _setParamVal (key,defaultVal) = match defaultVal {
9898 case defaultVal: String =>
9999 if (isDefined(_getS(key)))
100100 then _getSV(key)
101101 else defaultVal
102102 case defaultVal: Int =>
103103 if (isDefined(_getI(key)))
104104 then _getIV(key)
105105 else defaultVal
106106 case defaultVal: Boolean =>
107107 if (isDefined(_getB(key)))
108108 then _getBV(key)
109109 else defaultVal
110110 case _ =>
111111 throw(("value type not supported for " + key))
112112 }
113113
114114
115115 func _throwOrReturnS (val,error) = match val {
116116 case val: String =>
117117 val
118118 case _ =>
119119 throw(error)
120120 }
121121
122122
123123 func _throwOrReturnI (val,error) = match val {
124124 case val: Int =>
125125 val
126126 case _ =>
127127 throw(error)
128128 }
129129
130130
131131 func _throwOrReturnBool (val,error) = match val {
132132 case val: Boolean =>
133133 val
134134 case _ =>
135135 throw(error)
136136 }
137137
138138
139139 func _writeInt (key,value) = if ((0 > value))
140140 then throw(((("writing negative value " + toString(value)) + " for key ") + key))
141141 else IntegerEntry(key, value)
142142
143143
144144 func _writeStr (key,value) = if ((" " == value))
145145 then throw(("writing an empty string " + value))
146146 else StringEntry(key, value)
147147
148148
149149 func _throwIf (condition,error) = if (condition)
150150 then throw(error)
151151 else true
152152
153153
154154 func _writeGlobalParam (key,_value) = match _value {
155155 case _value: Int =>
156156 let entry = makeString(["%d", toString(_value)], SEP)
157157 _writeStr(key, entry)
158158 case _value: String =>
159159 let entry = makeString(["%s", _value], SEP)
160160 _writeStr(key, entry)
161161 case _value: Boolean =>
162162 let entry = makeString(["%b", toString(_value)], SEP)
163163 _writeStr(key, entry)
164164 case _ =>
165165 throw("type not supported")
166166 }
167167
168168
169169 func _getRegistryEntryValue (key) = {
170170 let _rawValue = _throwOrReturnS(_getS(key), ("entry not found for " + key))
171171 if ((_rawValue == _rawValue))
172172 then {
173173 let x = split(_rawValue, SEP)
174174 let formatSpecifier = takeRight(x[0], 1)
175175 let _valueString = x[(size(x) - 1)]
176176 let _value = if ((formatSpecifier == "s"))
177177 then _valueString
178178 else if ((formatSpecifier == "d"))
179179 then parseIntValue(_valueString)
180180 else if ((formatSpecifier == "b"))
181181 then fromBase58String(_valueString)
182182 else throw(("could not parse registry value for " + key))
183183 _value
184184 }
185185 else throw("Strict value is not equal to itself.")
186186 }
187187
188188
189189 func _daysToMiliSec (days) = {
190190 let check = _throwIf((0 >= days), "invalid locking days!")
191191 if ((check == check))
192192 then (days * _Dt)
193193 else throw("Strict value is not equal to itself.")
194194 }
195195
196196
197197 func _writeConstString (key,value) = if (!(isDefined(_getS(key))))
198198 then _writeStr(key, value)
199199 else throw(("entry already initialized: " + key))
200200
201201
202202 func _writeConstInteger (key,value) = if (!(isDefined(_getS(key))))
203203 then _writeInt(key, value)
204204 else throw((" entry already initialized: " + key))
205205
206206
207207 func _onlyManager (i) = {
208208 let manager = match _getRegistryEntryValue(_manager) {
209209 case val: String =>
210210 val
211211 case _ =>
212212 "failed to get manager"
213213 }
214214 if ((manager == manager))
215215 then _throwIf((toBase58String(i.caller.bytes) != manager), "address not authorized")
216216 else throw("Strict value is not equal to itself.")
217217 }
218218
219219
220220 func _abs (val) = if ((0 > val))
221221 then -(val)
222222 else val
223223
224224
225225 func _validateAddress (address,errorMsg) = match address {
226226 case address: String =>
227227 let _address = addressFromString(address)
228228 match _address {
229229 case _address: Address =>
230230 true
231231 case _ =>
232232 match errorMsg {
233233 case msg: String =>
234234 throw(msg)
235235 case _ =>
236236 false
237237 }
238238 }
239239 case address: ByteVector =>
240240 let _address = addressFromPublicKey(address)
241241 match _address {
242242 case _address: Address =>
243243 true
244244 case _ =>
245245 match errorMsg {
246246 case msg: String =>
247247 throw(msg)
248248 case _ =>
249249 false
250250 }
251251 }
252252 case _ =>
253253 throw("invalid input type")
254254 }
255255
256256
257257 func _validateAsset (assetID,errorMsg) = match assetInfo(fromBase58String(assetID)) {
258258 case asset: Asset =>
259259 true
260260 case _ =>
261261 match errorMsg {
262262 case msg: String =>
263263 throw(msg)
264264 case _ =>
265265 false
266266 }
267267 }
268268
269269
270270 func _computeMr () = {
271271 let currentCircIndex = match _getRegistryEntryValue(_circulationIncrIndex) {
272272 case t: Int =>
273273 t
274274 case _ =>
275275 throw("circulation index not previously defined")
276276 }
277277 if ((currentCircIndex == currentCircIndex))
278278 then {
279279 let stawAssetId = match _getRegistryEntryValue(_stawAssetId) {
280280 case t: String =>
281281 t
282282 case _ =>
283283 throw("asset id not previously defined")
284284 }
285285 if ((stawAssetId == stawAssetId))
286286 then {
287287 let stawCirculatingSupply = match assetInfo(fromBase58String(stawAssetId)) {
288288 case asset: Asset =>
289289 (asset.quantity / _unitDecimals)
290290 case _ =>
291291 throw(("asset not found for " + stawAssetId))
292292 }
293293 let unitIncrement = (_abs((stawCirculatingSupply - _incrementRef)) / _incrementRef)
294294 let newCirculationIncrIndex = if ((unitIncrement > currentCircIndex))
295295 then (unitIncrement + currentCircIndex)
296296 else currentCircIndex
297297 let currentMr = match _getRegistryEntryValue(_Mr) {
298298 case t: Int =>
299299 t
300300 case _ =>
301301 throw("failed to get miniting rate")
302302 }
303303 if ((newCirculationIncrIndex == currentCircIndex))
304304 then $Tuple2(currentMr, nil)
305305 else {
306306 let newreductionFactor = match _getRegistryEntryValue(_percentageReductionFactor) {
307307 case t: Int =>
308308 (t + 10)
309309 case _ =>
310310 throw("failed to get percentage reduction factor")
311311 }
312312 let newCurrentMr = (currentMr - fraction(currentMr, newreductionFactor, 100))
313313 let store1 = _writeGlobalParam(_Mr, newCurrentMr)
314314 let store2 = _writeGlobalParam(_percentageReductionFactor, newreductionFactor)
315315 let store3 = _writeGlobalParam(_circulationIncrIndex, newCirculationIncrIndex)
316316 $Tuple2(newCurrentMr, [store1, store2, store3])
317317 }
318318 }
319319 else throw("Strict value is not equal to itself.")
320320 }
321321 else throw("Strict value is not equal to itself.")
322322 }
323323
324324
325325 func _updateGlobalEntry (wavesAmount,stawAmount,stawPL,indexCount) = {
326326 let _newGlobalTotalWavesAmtRef = match _getRegistryEntryValue(_totalWavesRef) {
327327 case t: Int =>
328328 (t + wavesAmount)
329329 case _ =>
330330 throw("failed to get global total waves")
331331 }
332332 if ((_newGlobalTotalWavesAmtRef == _newGlobalTotalWavesAmtRef))
333333 then {
334334 let _newGlobalTotalStawMinted = match _getRegistryEntryValue(_totalStaw) {
335335 case t: Int =>
336336 (t + stawAmount)
337337 case _ =>
338338 throw("failed to get global total staw minted")
339339 }
340340 if ((_newGlobalTotalStawMinted == _newGlobalTotalStawMinted))
341341 then {
342342 let _newGlobalTotalStawPL = match _getRegistryEntryValue(_totalStawLP) {
343343 case t: Int =>
344344 (t + stawPL)
345345 case _ =>
346346 throw("failed to get global total stawpl")
347347 }
348348 if ((_newGlobalTotalStawPL == _newGlobalTotalStawPL))
349349 then {
350350 let _newGlobaIndexCount = match _getRegistryEntryValue(_globalIndexCount) {
351351 case t: Int =>
352352 (t + indexCount)
353353 case _ =>
354354 throw("failed to get global index count")
355355 }
356356 if ((_newGlobaIndexCount == _newGlobaIndexCount))
357357 then [_writeGlobalParam(_totalWavesRef, _newGlobalTotalWavesAmtRef), _writeGlobalParam(_totalStaw, _newGlobalTotalStawMinted), _writeGlobalParam(_totalStawLP, _newGlobalTotalStawPL), _writeGlobalParam(_globalIndexCount, _newGlobaIndexCount)]
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 else throw("Strict value is not equal to itself.")
365365 }
366366
367367
368368 func _registerUserEntry (transactionID,userAddress,lockDuration,lockDurationInMili,lockIndex,wavesAmount,stawAmount,stawLPAmount,lockAtHeight,lockId,totalLocked,localIndexCount,leaseState) = {
369369 let _txIdKey = makeString([userAddress, transactionID, _txId], SEP)
370370 let _lockDurationKey = makeString([userAddress, transactionID, _lockDuration], SEP)
371371 let _lockIndexKey = makeString([userAddress, transactionID, _lockIndex], SEP)
372372 let _wavesAmountKey = makeString([userAddress, transactionID, _wavesAmount], SEP)
373373 let _stawAmountKey = makeString([userAddress, transactionID, _stawAmount], SEP)
374374 let _stawLPAmountKey = makeString([userAddress, transactionID, _stawLPAmount], SEP)
375375 let _lockAtHeightKey = makeString([userAddress, transactionID, _lockAtHeight], SEP)
376376 let _lockIdKey = makeString([userAddress, transactionID, _lockId], SEP)
377377 let _totalLockedKey = makeString([userAddress, _userTotalLocked], SEP)
378378 let _localLockIndexKey = makeString([userAddress, _userLocalIndexCount], SEP)
379379 let _lockPeriodInMiliSecKey = makeString([userAddress, transactionID, _lockPeriodInMiliSec], SEP)
380380 let _totalWavesClaimedKey = makeString([userAddress, transactionID, _totalWavesClaimed], SEP)
381381 let _userLeaseStateKey = makeString([userAddress, transactionID, _userLeaseState], SEP)
382382 let trxIdEntry = makeString(["%s", transactionID], SEP)
383383 let lockDurationEntry = makeString(["%d", toString(lockDuration)], SEP)
384384 let lockIndexEntry = makeString(["%d", toString(lockIndex)], SEP)
385385 let wavesAmountEntry = makeString(["%d", toString(wavesAmount)], SEP)
386386 let stawAmountEntry = makeString(["%d", toString(stawAmount)], SEP)
387387 let stawLPAmountEntry = makeString(["%d", toString(stawLPAmount)], SEP)
388388 let lockAtHeightEntry = makeString(["%d", toString(lockAtHeight)], SEP)
389389 let lockIdEntry = makeString(["%b", lockId], SEP)
390390 let totalLockedEntry = makeString(["%d", toString(totalLocked)], SEP)
391391 let userLocalIndexEntry = makeString(["%d", toString(localIndexCount)], SEP)
392392 let lockPeriodInMiliSecEntry = makeString(["%d", toString(lockDurationInMili)], SEP)
393393 let totalWavesClaimedEntry = makeString(["%d", toString(0)], SEP)
394394 let userLeaseStateEntry = makeString(["%s", leaseState], SEP)
395395 [_writeConstString(_txIdKey, trxIdEntry), _writeConstString(_lockIndexKey, lockIndexEntry), _writeStr(_localLockIndexKey, userLocalIndexEntry), _writeStr(_totalLockedKey, totalLockedEntry), _writeConstString(_lockDurationKey, lockDurationEntry), _writeConstString(_lockPeriodInMiliSecKey, lockPeriodInMiliSecEntry), _writeConstString(_wavesAmountKey, wavesAmountEntry), _writeConstString(_stawAmountKey, stawAmountEntry), _writeStr(_stawLPAmountKey, stawLPAmountEntry), _writeStr(_totalWavesClaimedKey, totalWavesClaimedEntry), _writeConstString(_lockAtHeightKey, lockAtHeightEntry), _writeConstString(_lockIdKey, lockIdEntry), _writeStr(_userLeaseStateKey, userLeaseStateEntry)]
396396 }
397397
398398
399399 func _stawMF (lockPeriod,collateralWaves) = {
400400 let _adjustedMr = _computeMr()
401401 let ret = (fraction(collateralWaves, (_Dt * _adjustedMr._1), _Ppy(lockPeriod)) / _unitDecimals)
402402 if ((size(_adjustedMr._2) == 0))
403403 then $Tuple2(ret, nil)
404404 else $Tuple2(ret, _adjustedMr._2)
405405 }
406406
407407
408408 func _emissionRateWaves (lockPeriod,collateral) = {
409409 let extensionFactor = fraction(lockPeriod, 15, 10)
410- let r = (fraction(_Dt, collateral, (extensionFactor - lockPeriod)) / 2)
411- let emissionRate = (fraction(_unitDecimals, r, 1) * _Dt)
410+ let r = (fraction(fraction(1, 1, _Dt), collateral, (extensionFactor - lockPeriod)) / 2)
411+ let emissionRate = r
412412 emissionRate
413413 }
414414
415415
416416 func _incrTotalStawLP (amount) = {
417417 let oldStawLP = _throwOrReturnI(_getI(_totalStawLP), "could not get the running StawLP")
418418 [_writeInt(_totalStawLP, (oldStawLP + amount))]
419419 }
420420
421421
422422 func _decrTotalStawLP (amount) = {
423423 let oldStawLP = _throwOrReturnI(_getI(_totalStawLP), "could not get the running StawLP")
424424 [_writeInt(_totalStawLP, (oldStawLP - amount))]
425425 }
426426
427427
428428 func _incrTotalWavesRef (amount) = {
429429 let oldWavesRef = _throwOrReturnI(_getI(_totalWavesRef), "could not get total locked waves")
430430 [_writeInt(_totalWavesRef, (oldWavesRef + amount))]
431431 }
432432
433433
434434 func _decrTotalWavesRef (amount) = {
435435 let oldWavesRef = _throwOrReturnI(_getI(_totalWavesRef), "could not get total locked waves")
436436 [_writeInt(_totalWavesRef, (oldWavesRef - amount))]
437437 }
438438
439439
440440 func _getNewTimeStamp (blockHeight) = {
441441 let time = match blockInfoByHeight(blockHeight) {
442442 case timeInfo: BlockInfo =>
443443 timeInfo.timestamp
444444 case _ =>
445445 throw("counld get timestamp")
446446 }
447447 time
448448 }
449449
450450
451451 func getAssetQuantity (assetID) = match assetInfo(fromBase58String(assetID)) {
452452 case t: Asset =>
453453 t.quantity
454454 case _ =>
455455 throw("asset not found")
456456 }
457457
458458
459459 @Callable(i)
460460 func getEmission (lockPeriod,collateral) = {
461461 let check1 = _onlyManager(i)
462462 if ((check1 == check1))
463463 then $Tuple2(nil, _emissionRateWaves(lockPeriod, collateral))
464464 else throw("Strict value is not equal to itself.")
465465 }
466466
467467
468468
469469 @Callable(i)
470470 func init (manager,dfx,assetID,leaseNode) = {
471471 let managerAlreadyExists = if (isDefined(_getS(_manager)))
472472 then _onlyManager(i)
473473 else true
474474 if ((managerAlreadyExists == managerAlreadyExists))
475475 then {
476476 let check1 = _validateAddress(manager, "invalid address")
477477 if ((check1 == check1))
478478 then {
479479 let check2 = _validateAddress(dfx, "invalid address")
480480 if ((check2 == check2))
481481 then {
482482 let check3 = _validateAddress(leaseNode, "invalid address")
483483 if ((check3 == check3))
484484 then {
485485 let check4 = if (_validateAsset(assetID, "invalid asset"))
486486 then true
487487 else throw("invalid asset Id")
488488 if ((check4 == check4))
489489 then {
490490 let circulationIndex = _setParamVal(_circulationIncrIndex, 0)
491491 let percentageReductionInMr = _setParamVal(_percentageReductionFactor, 0)
492492 let Mr = _setParamVal(_Mr, _unitDecimals)
493493 let totalStawMinted = _setParamVal(_totalStaw, 0)
494494 let totalStawLPInCirculation = _setParamVal(_totalStawLP, 0)
495495 let globalIndexCount = _setParamVal(_globalIndexCount, 0)
496496 let totalWavesRef = _setParamVal(_totalWavesRef, 0)
497497 [_writeGlobalParam(_manager, manager), _writeGlobalParam(_Dfx, dfx), _writeGlobalParam(_stawAssetId, assetID), _writeGlobalParam(_lesseeAddress, leaseNode), _writeGlobalParam(_circulationIncrIndex, circulationIndex), _writeGlobalParam(_Mr, Mr), _writeGlobalParam(_percentageReductionFactor, percentageReductionInMr), _writeGlobalParam(_totalWavesRef, totalWavesRef), _writeGlobalParam(_totalStawLP, totalStawLPInCirculation), _writeGlobalParam(_totalStaw, totalStawMinted), _writeGlobalParam(_globalIndexCount, globalIndexCount)]
498498 }
499499 else throw("Strict value is not equal to itself.")
500500 }
501501 else throw("Strict value is not equal to itself.")
502502 }
503503 else throw("Strict value is not equal to itself.")
504504 }
505505 else throw("Strict value is not equal to itself.")
506506 }
507507 else throw("Strict value is not equal to itself.")
508508 }
509509
510510
511511
512512 @Callable(i)
513513 func modifyGlobalParams (val) = {
514514 let check1 = _onlyManager(i)
515515 if ((check1 == check1))
516516 then {
517517 let errorMsg = makeString(["got", "list size of", toString(size(val)), "but expected [global_key, value] pair"], " ")
518518 let check2 = _throwIf((size(val) != 2), errorMsg)
519519 if ((check2 == check2))
520520 then {
521521 let key = val[0]
522522 let valType = parseInt(val[1])
523523 match valType {
524524 case x: Int =>
525525 let validateKey = _throwIf((_getS(key) == unit), (("key " + key) + " not recognized"))
526526 if ((validateKey == validateKey))
527527 then {
528528 let ensureValidPairs = match _getRegistryEntryValue(key) {
529529 case t: Int =>
530530 true
531531 case _ =>
532532 throw("invalid key-value pair")
533533 }
534534 if ((ensureValidPairs == ensureValidPairs))
535535 then [_writeGlobalParam(key, x)]
536536 else throw("Strict value is not equal to itself.")
537537 }
538538 else throw("Strict value is not equal to itself.")
539539 case x: Unit =>
540540 let validateKey = _throwIf((_getS(key) == unit), (("key " + key) + " not recognized"))
541541 if ((validateKey == validateKey))
542542 then {
543543 let stringValue = val[1]
544544 let refAddress = _getRegistryEntryValue(_manager)
545545 let check4 = match refAddress {
546546 case strType: String =>
547547 if ((size(strType) == size(stringValue)))
548548 then _validateAddress(stringValue, "string type for value not supported")
549549 else _validateAsset(stringValue, "string type for value not supported")
550550 case _ =>
551551 false
552552 }
553553 if ((check4 == check4))
554554 then [_writeGlobalParam(key, stringValue)]
555555 else throw("Strict value is not equal to itself.")
556556 }
557557 else throw("Strict value is not equal to itself.")
558558 case _ =>
559559 throw(("failed to modify " + val[0]))
560560 }
561561 }
562562 else throw("Strict value is not equal to itself.")
563563 }
564564 else throw("Strict value is not equal to itself.")
565565 }
566566
567567
568568
569569 @Callable(i)
570570 func revokeLock () = {
571571 let check1 = _onlyManager(i)
572572 if ((check1 == check1))
573573 then nil
574574 else throw("Strict value is not equal to itself.")
575575 }
576576
577577
578578
579579 @Callable(i)
580580 func claim (transactionID) = {
581581 let callerAddress = toBase58String(i.caller.bytes)
582582 let collateralKey = makeString([callerAddress, transactionID, _wavesAmount], SEP)
583583 let lockperiodKey = makeString([callerAddress, transactionID, _lockDuration], SEP)
584584 let lockIdKey = makeString([callerAddress, transactionID, _lockId], SEP)
585585 let lockperiodInMiliKey = makeString([callerAddress, transactionID, _lockPeriodInMiliSec], SEP)
586586 let totalWavesClaimedKey = makeString([callerAddress, transactionID, _totalWavesClaimed], SEP)
587587 let stawLPAmountKey = makeString([callerAddress, transactionID, _stawLPAmount], SEP)
588588 let wavesAmountKey = makeString([callerAddress, transactionID, _wavesAmount], SEP)
589589 let userTotalWavesLockedKey = makeString([callerAddress, _userTotalLocked], SEP)
590590 let userLeaseStateKey = makeString([callerAddress, transactionID, _userLeaseState], SEP)
591591 let leaseStateKey = makeString([callerAddress, transactionID, _userLeaseState], SEP)
592592 let daysAfterLockPeriodElaspedKey = makeString([callerAddress, transactionID, _daysAfterLockPeriod], SEP)
593593 let globalWavesRef = match _getRegistryEntryValue(_totalWavesRef) {
594594 case t: Int =>
595595 t
596596 case _ =>
597597 throw("failed to get global total waves")
598598 }
599599 if ((globalWavesRef == globalWavesRef))
600600 then {
601601 let globalStawPL = match _getRegistryEntryValue(_totalStawLP) {
602602 case t: Int =>
603603 t
604604 case _ =>
605605 throw("failed to get global total waves")
606606 }
607607 if ((globalStawPL == globalStawPL))
608608 then {
609609 let lockId = match _getRegistryEntryValue(lockIdKey) {
610610 case t: ByteVector =>
611611 t
612612 case _ =>
613613 throw("failed to get lease id")
614614 }
615615 if ((lockId == lockId))
616616 then {
617617 let userTotalWavesLocked = match _getRegistryEntryValue(userTotalWavesLockedKey) {
618618 case t: Int =>
619619 t
620620 case _ =>
621621 throw("failed to get total waves locked by this address")
622622 }
623623 if ((userTotalWavesLocked == userTotalWavesLocked))
624624 then {
625625 let wavesAmount = match _getRegistryEntryValue(wavesAmountKey) {
626626 case t: Int =>
627627 t
628628 case _ =>
629629 throw("failed to get total waves locked")
630630 }
631631 if ((wavesAmount == wavesAmount))
632632 then {
633633 let totalWavesClaimed = match _getRegistryEntryValue(totalWavesClaimedKey) {
634634 case t: Int =>
635635 t
636636 case _ =>
637637 throw("failed to get total waves claimed")
638638 }
639639 if ((totalWavesClaimed == totalWavesClaimed))
640640 then {
641641 let stawLPAmount = match _getRegistryEntryValue(stawLPAmountKey) {
642642 case t: Int =>
643643 t
644644 case _ =>
645645 throw("failed to get stawPL")
646646 }
647647 if ((stawLPAmount == stawLPAmount))
648648 then {
649649 let lockPeriodInMili = match _getRegistryEntryValue(lockperiodInMiliKey) {
650650 case t: Int =>
651651 t
652652 case _ =>
653653 throw("failed to get lock period timespam")
654654 }
655655 if ((lockPeriodInMili == lockPeriodInMili))
656656 then {
657657 let currentTimeStamp = match _getNewTimeStamp(height) {
658658 case t: Int =>
659659 t
660660 case _ =>
661661 throw("failed to get current timestamp")
662662 }
663663 if ((currentTimeStamp == currentTimeStamp))
664664 then {
665665 let collateral = match _getRegistryEntryValue(collateralKey) {
666666 case t: Int =>
667667 t
668668 case _ =>
669669 throw("failed to get collateral")
670670 }
671671 if ((collateral == collateral))
672672 then {
673673 let lockPeriod = match _getRegistryEntryValue(lockperiodKey) {
674674 case t: Int =>
675675 t
676676 case _ =>
677677 throw("failed to get lockPeriod")
678678 }
679679 if ((lockPeriod == lockPeriod))
680680 then {
681681 let currentLeaseState = match _getRegistryEntryValue(userLeaseStateKey) {
682682 case t: String =>
683683 t
684684 case _ =>
685685 throw("failed to get lease state")
686686 }
687687 if ((currentLeaseState == currentLeaseState))
688688 then {
689689 let leaseState = match _getRegistryEntryValue(leaseStateKey) {
690690 case t: String =>
691691 t
692692 case _ =>
693693 throw("failed to get lease state for user")
694694 }
695695 if ((leaseState == leaseState))
696696 then {
697697 let daysAfterLockPeriodElasped = match _getS(daysAfterLockPeriodElaspedKey) {
698698 case t: String =>
699699 match _getRegistryEntryValue(daysAfterLockPeriodElaspedKey) {
700700 case z: Int =>
701701 z
702702 case _ =>
703703 0
704704 }
705705 case _ =>
706706 0
707707 }
708708 if ((daysAfterLockPeriodElasped == daysAfterLockPeriodElasped))
709709 then {
710710 let check1 = _throwIf((lockPeriodInMili > currentTimeStamp), "lock period for this entry has not elapsed")
711711 if ((check1 == check1))
712712 then {
713713 let leaseAction = if ((currentLeaseState == "leased"))
714714 then $Tuple2(LeaseCancel(lockId), _writeStr(userLeaseStateKey, "cancelled"))
715715 else $Tuple2(_writeStr(userLeaseStateKey, "cancelled"), _writeStr(userLeaseStateKey, "cancelled"))
716716 let check2 = _throwIf(if ((0 == wavesAmount))
717717 then true
718718 else (0 == stawLPAmount), "all claims exhausted for this trx")
719719 if ((check2 == check2))
720720 then {
721721 let emissionValuePerDT = _emissionRateWaves(lockPeriod, collateral)
722722 let claimAction = {
723723 let timeStampDiff = (currentTimeStamp - lockPeriodInMili)
724724 let xdays = (timeStampDiff / _Dt)
725725 if ((xdays == 0))
726726 then throw("less than 24hrs before first claim")
727727 else if ((daysAfterLockPeriodElasped >= xdays))
728728 then throw("24hrs or less before next claim")
729729 else {
730730 let totalAmountClaimable = (daysAfterLockPeriodElasped * emissionValuePerDT)
731731 let check3_1 = _throwIf((totalAmountClaimable == totalWavesClaimed), "can only claim once in 24hrs")
732732 if ((check3_1 == check3_1))
733733 then {
734734 let check3_2 = _throwIf(((totalAmountClaimable + totalWavesClaimed) > wavesAmount), "all claims exhausted")
735735 if ((check3_2 == check3_2))
736736 then {
737737 let claimAmountToSend = if ((daysAfterLockPeriodElasped == 1))
738738 then totalAmountClaimable
739739 else (totalAmountClaimable - totalWavesClaimed)
740740 let newTotalWavesClaim = totalAmountClaimable
741741 let newWavesAmount = if ((daysAfterLockPeriodElasped == 1))
742742 then (wavesAmount - totalAmountClaimable)
743743 else (wavesAmount - (totalAmountClaimable - totalWavesClaimed))
744744 let newStawLPAmount = if ((daysAfterLockPeriodElasped == 1))
745745 then (stawLPAmount - totalAmountClaimable)
746746 else (stawLPAmount - (totalAmountClaimable - totalWavesClaimed))
747747 let newGlobalWaveRef = (globalWavesRef - newWavesAmount)
748748 let newGlobalStawPL = (globalStawPL - newStawLPAmount)
749749 let newUserTotalWavesLocked = (userTotalWavesLocked - claimAmountToSend)
750750 let wavesAmountEntry = makeString(["%d", toString(newWavesAmount)], SEP)
751751 let stawLPAmountEntry = makeString(["%d", toString(newStawLPAmount)], SEP)
752752 let totalWavesClaimedEntry = makeString(["%d", toString(newTotalWavesClaim)], SEP)
753753 let newUserTotalWavesLockedEntry = makeString(["%d", toString(newUserTotalWavesLocked)], SEP)
754754 let daysAfterLockPeriodElaspedEntry = makeString(["%d", toString(xdays)], SEP)
755755 [leaseAction._1, leaseAction._2, _writeStr(wavesAmountKey, wavesAmountEntry), _writeStr(stawLPAmountKey, stawLPAmountEntry), _writeStr(totalWavesClaimedKey, totalWavesClaimedEntry), _writeStr(userTotalWavesLockedKey, newUserTotalWavesLockedEntry), _writeStr(daysAfterLockPeriodElaspedKey, daysAfterLockPeriodElaspedEntry), _writeGlobalParam(_totalWavesRef, newGlobalWaveRef), _writeGlobalParam(_totalStawLP, newGlobalStawPL), ScriptTransfer(Address(i.caller.bytes), claimAmountToSend, unit)]
756756 }
757757 else throw("Strict value is not equal to itself.")
758758 }
759759 else throw("Strict value is not equal to itself.")
760760 }
761761 }
762762 if ((claimAction == claimAction))
763763 then claimAction
764764 else throw("Strict value is not equal to itself.")
765765 }
766766 else throw("Strict value is not equal to itself.")
767767 }
768768 else throw("Strict value is not equal to itself.")
769769 }
770770 else throw("Strict value is not equal to itself.")
771771 }
772772 else throw("Strict value is not equal to itself.")
773773 }
774774 else throw("Strict value is not equal to itself.")
775775 }
776776 else throw("Strict value is not equal to itself.")
777777 }
778778 else throw("Strict value is not equal to itself.")
779779 }
780780 else throw("Strict value is not equal to itself.")
781781 }
782782 else throw("Strict value is not equal to itself.")
783783 }
784784 else throw("Strict value is not equal to itself.")
785785 }
786786 else throw("Strict value is not equal to itself.")
787787 }
788788 else throw("Strict value is not equal to itself.")
789789 }
790790 else throw("Strict value is not equal to itself.")
791791 }
792792 else throw("Strict value is not equal to itself.")
793793 }
794794 else throw("Strict value is not equal to itself.")
795795 }
796796 else throw("Strict value is not equal to itself.")
797797 }
798798
799799
800800
801801 @Callable(i)
802802 func mintStaw (lockPeriod) = {
803803 let callerAddress = toBase58String(i.caller.bytes)
804804 let trxID = toBase58String(i.transactionId)
805805 let check1 = _throwIf((1 != size(i.payments)), "no payments attached")
806806 if ((check1 == check1))
807807 then {
808808 let check2 = if (isDefined(i.payments[0].assetId))
809809 then throw("only waves supported")
810810 else true
811811 if ((check2 == check2))
812812 then {
813813 let amountInWaves = i.payments[0].amount
814814 let check3 = if (if ((_minLockAmount > amountInWaves))
815815 then true
816816 else (amountInWaves > _maxLockAmount))
817817 then throw("lock amount out of range, minimum: 1 waves, maximum: 1000 waves")
818818 else true
819819 if ((check3 == check3))
820820 then {
821821 let check4 = if ((_minLockperiod > lockPeriod))
822822 then throw("minimum of 14 days lock period")
823823 else true
824824 if ((check4 == check4))
825825 then {
826826 let totalStawMint = _stawMF(lockPeriod, amountInWaves)
827827 let stawPL = amountInWaves
828828 let fee = fraction(totalStawMint._1, 10, 100)
829829 let userGetStawAmount = (totalStawMint._1 - fee)
830830 let lockPeriodToMilisec = (_getNewTimeStamp(height) + _daysToMiliSec(lockPeriod))
831831 if ((lockPeriodToMilisec == lockPeriodToMilisec))
832832 then {
833833 let new_index = match _getRegistryEntryValue(_globalIndexCount) {
834834 case t: Int =>
835835 (t + 1)
836836 case _ =>
837837 throw("failed to get current global index count")
838838 }
839839 if ((new_index == new_index))
840840 then {
841841 let addressFee = match _getRegistryEntryValue(_Dfx) {
842842 case t: String =>
843843 Address(fromBase58String(t))
844844 case _ =>
845845 throw("failed to get dfx address")
846846 }
847847 if ((addressFee == addressFee))
848848 then {
849849 let stawAssetId = match _getRegistryEntryValue(_stawAssetId) {
850850 case t: String =>
851851 fromBase58String(t)
852852 case _ =>
853853 throw("failed to get asset id")
854854 }
855855 if ((stawAssetId == stawAssetId))
856856 then {
857857 let lessee = match _getRegistryEntryValue(_lesseeAddress) {
858858 case t: String =>
859859 Address(fromBase58String(t))
860860 case _ =>
861861 throw("failed to get lease node address")
862862 }
863863 if ((lessee == lessee))
864864 then {
865865 let userLockIndexKey = makeString([callerAddress, _userLocalIndexCount], SEP)
866866 let userTotalLockedKey = makeString([callerAddress, _userTotalLocked], SEP)
867867 let userIndexCount = match _getS(userLockIndexKey) {
868868 case x: String =>
869869 match _getRegistryEntryValue(userLockIndexKey) {
870870 case t: Int =>
871871 (t + 1)
872872 case _ =>
873873 1
874874 }
875875 case _ =>
876876 1
877877 }
878878 if ((userIndexCount == userIndexCount))
879879 then {
880880 let userTotalLocked = match _getS(userTotalLockedKey) {
881881 case x: String =>
882882 match _getRegistryEntryValue(userTotalLockedKey) {
883883 case t: Int =>
884884 (t + amountInWaves)
885885 case _ =>
886886 amountInWaves
887887 }
888888 case _ =>
889889 amountInWaves
890890 }
891891 if ((userTotalLocked == userTotalLocked))
892892 then {
893893 let leaseOut = Lease(lessee, amountInWaves)
894894 let leaseIdStr = toBase58String(calculateLeaseId(leaseOut))
895895 ((([leaseOut, ScriptTransfer(addressFee, fee, stawAssetId), ScriptTransfer(Address(i.caller.bytes), userGetStawAmount, stawAssetId)] ++ _registerUserEntry(trxID, callerAddress, lockPeriod, lockPeriodToMilisec, new_index, amountInWaves, userGetStawAmount, stawPL, height, leaseIdStr, userTotalLocked, userIndexCount, "leased")) ++ _updateGlobalEntry(amountInWaves, totalStawMint._1, stawPL, new_index)) ++ totalStawMint._2)
896896 }
897897 else throw("Strict value is not equal to itself.")
898898 }
899899 else throw("Strict value is not equal to itself.")
900900 }
901901 else throw("Strict value is not equal to itself.")
902902 }
903903 else throw("Strict value is not equal to itself.")
904904 }
905905 else throw("Strict value is not equal to itself.")
906906 }
907907 else throw("Strict value is not equal to itself.")
908908 }
909909 else throw("Strict value is not equal to itself.")
910910 }
911911 else throw("Strict value is not equal to itself.")
912912 }
913913 else throw("Strict value is not equal to itself.")
914914 }
915915 else throw("Strict value is not equal to itself.")
916916 }
917917 else throw("Strict value is not equal to itself.")
918918 }
919919
920920

github/deemru/w8io/169f3d6 
88.27 ms