tx · Hwg5UiBh4vCjqTvDT9bBFjL4KBGXL15UV6u9x16wrUjr

3MuaSDLcYLvdTzcPqrD1y65RP3B1hFK6Fig:  -0.06000000 Waves

2023.02.08 16:12 [2440682] smart account 3MuaSDLcYLvdTzcPqrD1y65RP3B1hFK6Fig > SELF 0.00000000 Waves

{ "type": 13, "id": "Hwg5UiBh4vCjqTvDT9bBFjL4KBGXL15UV6u9x16wrUjr", "fee": 6000000, "feeAssetId": null, "timestamp": 1675861987527, "version": 2, "chainId": 84, "sender": "3MuaSDLcYLvdTzcPqrD1y65RP3B1hFK6Fig", "senderPublicKey": "4q8pLMkbsmuse4oZeSsXQrB3o78jHbscP1tZb9ZBXhww", "proofs": [ "2Z3aK9GFLB97Q1agJy85M1ad5BpNsWYZv3FqbzFtrvPdPHVwp7adTYfAgvoBcZnUJMwRxDcFPdBA5sZ3zug4cv1J" ], "script": "base64:BgJJCAISAwoBBBIECgIEARIGCgQBAQQBEgMKAQESBgoEAQgBARIECgIBARIDCgEBEgASABIAEgMKAQESBQoDBAEIEgASBAoCAQESAGoAB3ZlcnNpb24CBTIuMC4wAAhrVmVyc2lvbgIHdmVyc2lvbgAHa0FjdGl2ZQIGYWN0aXZlAAtrQWN0aXZlR2xvYgIUYWN0aXZlX2FsbF9jb250cmFjdHMACWtBc3NldElkQQIKQV9hc3NldF9pZAAJa0Fzc2V0SWRCAgpCX2Fzc2V0X2lkAAlrQmFsYW5jZUECD0FfYXNzZXRfYmFsYW5jZQAJa0JhbGFuY2VCAg9CX2Fzc2V0X2JhbGFuY2UADWtTaGFyZUFzc2V0SWQCDnNoYXJlX2Fzc2V0X2lkABFrU2hhcmVBc3NldFN1cHBseQISc2hhcmVfYXNzZXRfc3VwcGx5AARrRmVlAgpjb21taXNzaW9uAAprSW52YXJpYW50AglpbnZhcmlhbnQABmtDYXVzZQIOc2h1dGRvd25fY2F1c2UADGtVU0ROQWRkcmVzcwIYc3Rha2luZ191c2RubnNidF9hZGRyZXNzAAxrRVVSTkFkZHJlc3MCFHN0YWtpbmdfZXVybl9hZGRyZXNzAAprRGlzY291bnRzAglkaXNjb3VudHMAD2tEaXNjb3VudFZhbHVlcwIPZGlzY291bnRfdmFsdWVzAA5rVXNlclN3b3BJbkdvdgIMX1NXT1BfYW1vdW50AA9rVXNlckdTd29wSW5Hb3YCDV9HU3dvcF9hbW91bnQADWtGaXJzdEhhcnZlc3QCDWZpcnN0X2hhcnZlc3QAE2tGaXJzdEhhcnZlc3RIZWlnaHQCFGZpcnN0X2hhcnZlc3RfaGVpZ2h0AAtrU2hhcmVMaW1pdAIcc2hhcmVfbGltaXRfb25fZmlyc3RfaGFydmVzdAALa0Jhc2VQZXJpb2QCC2Jhc2VfcGVyaW9kAA1rUGVyaW9kTGVuZ3RoAg1wZXJpb2RfbGVuZ3RoAAxrU3RhcnRIZWlnaHQCDHN0YXJ0X2hlaWdodAAOa0RBcHBUaHJlc2hvbGQCDmRBcHBfdGhyZXNob2xkAA1rQWRtaW5QdWJLZXkxAgthZG1pbl9wdWJfMQANa0FkbWluUHViS2V5MgILYWRtaW5fcHViXzIADWtBZG1pblB1YktleTMCC2FkbWluX3B1Yl8zABJrQWRtaW5JbnZva2VQdWJLZXkCEGFkbWluX2ludm9rZV9wdWIAEGtNb25leUJveEFkZHJlc3MCEW1vbmV5X2JveF9hZGRyZXNzAAtrR292QWRkcmVzcwISZ292ZXJuYW5jZV9hZGRyZXNzAA9rRmFybWluZ0FkZHJlc3MCD2Zhcm1pbmdfYWRkcmVzcwAOa1ZvdGluZ0FkZHJlc3MCDnZvdGluZ19hZGRyZXNzAAxrVVNETkFzc2V0SWQCDXVzZG5fYXNzZXRfaWQADmtTdGFraW5nQXNzZXRzAg5zdGFraW5nX2Fzc2V0cwAGb3JhY2xlCQEHQWRkcmVzcwEBGgFUSBOXDMDTM8wlMoC2KfenZGiAq+PMe0uZARNnZXRCYXNlNThGcm9tT3JhY2xlAQNrZXkEByRtYXRjaDAJAJ0IAgUGb3JhY2xlBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAZzdHJpbmcFByRtYXRjaDAJANkEAQUGc3RyaW5nBAdub3RoaW5nBQckbWF0Y2gwCQACAQkArAICBQNrZXkCCGlzIGVtcHR5AAxhZG1pblB1YktleTEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUNa0FkbWluUHViS2V5MQAMYWRtaW5QdWJLZXkyCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDWtBZG1pblB1YktleTIADGFkbWluUHViS2V5MwkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQ1rQWRtaW5QdWJLZXkzABFhZG1pblB1YktleUludm9rZQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBRJrQWRtaW5JbnZva2VQdWJLZXkAD21vbmV5Qm94QWRkcmVzcwkBB0FkZHJlc3MBCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFEGtNb25leUJveEFkZHJlc3MACmdvdkFkZHJlc3MJAQdBZGRyZXNzAQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQtrR292QWRkcmVzcwASc3Rha2luZ1VTRE5BZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUMa1VTRE5BZGRyZXNzAA12b3RpbmdBZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUOa1ZvdGluZ0FkZHJlc3MADmZhcm1pbmdBZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUPa0Zhcm1pbmdBZGRyZXNzAARVU0ROCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDGtVU0ROQXNzZXRJZAANc3Rha2luZ0Fzc2V0cwkBEUBleHRyTmF0aXZlKDEwNTMpAgUGb3JhY2xlBQ5rU3Rha2luZ0Fzc2V0cwAKYmFzZVBlcmlvZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDXZvdGluZ0FkZHJlc3MFC2tCYXNlUGVyaW9kAhFFbXB0eSBrQmFzZVBlcmlvZAALc3RhcnRIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ12b3RpbmdBZGRyZXNzBQxrU3RhcnRIZWlnaHQCEkVtcHR5IGtTdGFydEhlaWdodAAMcGVyaW9kTGVuZ3RoCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNdm90aW5nQWRkcmVzcwUNa1BlcmlvZExlbmd0aAITRW1wdHkga1BlcmlvZExlbmd0aAAVZmlyc3RIYXJ2ZXN0RW5kUGVyaW9kCQBkAgkAZAIFCmJhc2VQZXJpb2QJAGkCCQBlAgUGaGVpZ2h0BQtzdGFydEhlaWdodAUMcGVyaW9kTGVuZ3RoAAMABmFjdGl2ZQkBEUBleHRyTmF0aXZlKDEwNTEpAgUEdGhpcwUHa0FjdGl2ZQAKYWN0aXZlR2xvYgkBC3ZhbHVlT3JFbHNlAgkAmwgCBQZvcmFjbGUFC2tBY3RpdmVHbG9iBgALc3RyQXNzZXRJZEEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMFCWtBc3NldElkQQALc3RyQXNzZXRJZEIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMFCWtBc3NldElkQgAIYXNzZXRJZEEDCQAAAgULc3RyQXNzZXRJZEECBVdBVkVTBQR1bml0CQDZBAEFC3N0ckFzc2V0SWRBAAhhc3NldElkQgMJAAACBQtzdHJBc3NldElkQgIFV0FWRVMFBHVuaXQJANkEAQULc3RyQXNzZXRJZEIACmFzc2V0TmFtZUEEByRtYXRjaDAFCGFzc2V0SWRBAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwCAkBBXZhbHVlAQkA7AcBBQJpZARuYW1lAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwAgVXQVZFUwkAAgECC01hdGNoIGVycm9yAAphc3NldE5hbWVCBAckbWF0Y2gwBQhhc3NldElkQgMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJpZAUHJG1hdGNoMAgJAQV2YWx1ZQEJAOwHAQUCaWQEbmFtZQMJAAECBQckbWF0Y2gwAgRVbml0BAV3YXZlcwUHJG1hdGNoMAIFV0FWRVMJAAIBAgtNYXRjaCBlcnJvcgAIYmFsYW5jZUEJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMFCWtCYWxhbmNlQQAIYmFsYW5jZUIJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMFCWtCYWxhbmNlQgAMc2hhcmVBc3NldElkCQDZBAEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMFDWtTaGFyZUFzc2V0SWQAEHNoYXJlQXNzZXRTdXBwbHkJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMFEWtTaGFyZUFzc2V0U3VwcGx5AAlpbnZhcmlhbnQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMFCmtJbnZhcmlhbnQAA2ZlZQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwUEa0ZlZQANZmVlR292ZXJuYW5jZQkAawMFA2ZlZQAoAGQACWZlZVNjYWxlNgDAhD0ABnNjYWxlMwDoBwAGc2NhbGU4AIDC1y8AB3NjYWxlMTYAgICE/qbe4REAB2RpZ2l0czgACAAVZXhjaGFuZ2VSYXRpb0xpbWl0TWluAICOzhwAFWV4Y2hhbmdlUmF0aW9MaW1pdE1heACA9uBCAAVhbHBoYQAyAAthbHBoYURpZ2l0cwACAARiZXRhAICA3q/P9ZUIAQ5hY2NvdW50QmFsYW5jZQEHYXNzZXRJZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJpZAUHJG1hdGNoMAkA8AcCBQR0aGlzBQJpZAMJAAECBQckbWF0Y2gwAgRVbml0BAV3YXZlcwUHJG1hdGNoMAgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAAIBAgtNYXRjaCBlcnJvcgEMc3Rha2VkQW1vdW50AQdhc3NldElkBBZzdGFrZWRBbW91bnRDYWxjdWxhdGVkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEA2FJZAUHJG1hdGNoMAMJAAACBQNhSWQFBFVTRE4JAJoIAgUSc3Rha2luZ1VTRE5BZGRyZXNzCQCsAgIJAKwCAgkArAICAgxycGRfYmFsYW5jZV8JANgEAQUDYUlkAgFfCQClCAEFBHRoaXMAAAMJAAECBQckbWF0Y2gwAgRVbml0AAAJAAIBAgtNYXRjaCBlcnJvcgQHJG1hdGNoMAUWc3Rha2VkQW1vdW50Q2FsY3VsYXRlZAMJAAECBQckbWF0Y2gwAgNJbnQEAWkFByRtYXRjaDAFAWkAAAANc3Rha2VkQW1vdW50QQkBDHN0YWtlZEFtb3VudAEFCGFzc2V0SWRBAA1zdGFrZWRBbW91bnRCCQEMc3Rha2VkQW1vdW50AQUIYXNzZXRJZEIAEWF2YWlsYWJsZUJhbGFuY2VBCQBlAgUIYmFsYW5jZUEFDXN0YWtlZEFtb3VudEEAEWF2YWlsYWJsZUJhbGFuY2VCCQBlAgUIYmFsYW5jZUIFDXN0YWtlZEFtb3VudEIAGWFjY291bnRCYWxhbmNlV2l0aFN0YWtlZEEJAGQCCQEOYWNjb3VudEJhbGFuY2UBBQhhc3NldElkQQUNc3Rha2VkQW1vdW50QQAZYWNjb3VudEJhbGFuY2VXaXRoU3Rha2VkQgkAZAIJAQ5hY2NvdW50QmFsYW5jZQEFCGFzc2V0SWRCBQ1zdGFrZWRBbW91bnRCABBoYXNFbm91Z2hCYWxhbmNlAwkAZwIFGWFjY291bnRCYWxhbmNlV2l0aFN0YWtlZEEFCGJhbGFuY2VBCQBnAgUZYWNjb3VudEJhbGFuY2VXaXRoU3Rha2VkQgUIYmFsYW5jZUIHAQhza2V3bmVzcwIBeAF5CQBpAgkAZAIJAGsDBQdzY2FsZTE2BQF4BQF5CQBrAwUHc2NhbGUxNgUBeQUBeAACAQ1pbnZhcmlhbnRDYWxjAgF4AXkEAnNrCQEIc2tld25lc3MCBQF4BQF5CQBkAgkAawMJAGQCBQF4BQF5BQdzY2FsZTE2CQBsBgUCc2sFB2RpZ2l0czgFBWFscGhhBQthbHBoYURpZ2l0cwUHZGlnaXRzOAUHQ0VJTElORwkAaAIAAgkAawMJAKADAQkAdgYJALwCAwkAtgIBBQF4CQC2AgEFAXkJALYCAQUGc2NhbGU4AAAJALYCAQAFAAEJAGkCBQdkaWdpdHM4AAIFBERPV04JAGwGCQBlAgUCc2sFBGJldGEFB2RpZ2l0czgFBWFscGhhBQthbHBoYURpZ2l0cwUHZGlnaXRzOAUERE9XTgUGc2NhbGU4ARNjYWxjdWxhdGVTZW5kQW1vdW50BxVhbW91bnRUb1NlbmRFc3RpbWF0ZWQVbWluVG9rZW5SZWNlaXZlQW1vdW50EnRva2VuUmVjZWl2ZUFtb3VudAd0b2tlbklkBWJhbGNBBWJhbGNCBmludkN1cgQdd29yc3RBbGxvd2VkTmV3SW52YXJpYW50UmF0aW8JAGUCBQdzY2FsZTE2CQBpAgkAaAIFB3NjYWxlMTYAAQCAreIEBB5kZWx0YUJldHdlZW5NYXhBbmRNaW5TZW5kVmFsdWUJAGUCBRVhbW91bnRUb1NlbmRFc3RpbWF0ZWQFFW1pblRva2VuUmVjZWl2ZUFtb3VudAQBeAkAZAIFBWJhbGNBBRJ0b2tlblJlY2VpdmVBbW91bnQEAXkJAGQCBQViYWxjQgUSdG9rZW5SZWNlaXZlQW1vdW50CgENZ2V0U3RlcEFtb3VudAIDYWNjBHN0ZXADCQAAAggFA2FjYwJfMQD///////////8BBAxhbW91bnRUb1NlbmQJAGUCBRVhbW91bnRUb1NlbmRFc3RpbWF0ZWQJAGkCCQBpAgkAaAIFBHN0ZXAFHmRlbHRhQmV0d2Vlbk1heEFuZE1pblNlbmRWYWx1ZQADBQZzY2FsZTMEDXN0ZXBJbnZhcmlhbnQDCQAAAgUHdG9rZW5JZAUIYXNzZXRJZEEJAQ1pbnZhcmlhbnRDYWxjAgUBeAkAZQIFBWJhbGNCBQxhbW91bnRUb1NlbmQJAQ1pbnZhcmlhbnRDYWxjAgkAZQIFBWJhbGNBBQxhbW91bnRUb1NlbmQFAXkDCQBmAgUNc3RlcEludmFyaWFudAUGaW52Q3VyCQCUCgIFDGFtb3VudFRvU2VuZAUNc3RlcEludmFyaWFudAkAlAoCAP///////////wEAAAUDYWNjBA9hbW91bnRUb1NlbmRNaW4JAQ1nZXRTdGVwQW1vdW50AgkAlAoCAP///////////wEAAAC4FwMJAGYCAAAIBQ9hbW91bnRUb1NlbmRNaW4CXzEJAAIBAh9QcmljZSBpcyB3b3JzZSB0aGFuIG1pblJlY2VpdmVkBAxpbnZFc3RpbWF0ZWQDCQAAAgUHdG9rZW5JZAUIYXNzZXRJZEEJAQ1pbnZhcmlhbnRDYWxjAgUBeAkAZQIFBWJhbGNCBRVhbW91bnRUb1NlbmRFc3RpbWF0ZWQDCQAAAgUHdG9rZW5JZAUIYXNzZXRJZEIJAQ1pbnZhcmlhbnRDYWxjAgkAZQIFBWJhbGNBBRVhbW91bnRUb1NlbmRFc3RpbWF0ZWQFAXkJAAIBAhZXcm9uZyBhc3NldCBpbiBwYXltZW50AwkAZgIFBmludkN1cgUMaW52RXN0aW1hdGVkAwkAZwIFHXdvcnN0QWxsb3dlZE5ld0ludmFyaWFudFJhdGlvCQBrAwUHc2NhbGUxNgUGaW52Q3VyBQxpbnZFc3RpbWF0ZWQJAAIBAjJUaGUgcmVxdWVzdGVkIHByaWNlIGlzIHRvbyBub3QgcHJvZml0YWJsZSBmb3IgdXNlcgQBYQoAAiRsCQDMCAIAGQkAzAgCAMgBCQDMCAIA9AMFA25pbAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgD///////////8BAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDWdldFN0ZXBBbW91bnQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDMJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMDCQBmAgAACAUBYQJfMQgFD2Ftb3VudFRvU2VuZE1pbgJfMQgFAWECXzEEAWEKAAIkbAkAzAgCAIz8/////////wEJAMwIAgC4/v////////8BCQDMCAIA5///////////AQUDbmlsCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlAoCAP///////////wEAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQENZ2V0U3RlcEFtb3VudAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgMwkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwQPdHVwbGVTZW5kQmV0dGVyAwkAZgIAAAgFAWECXzEJAJQKAgUVYW1vdW50VG9TZW5kRXN0aW1hdGVkBQxpbnZFc3RpbWF0ZWQFAWEDCQBnAgUdd29yc3RBbGxvd2VkTmV3SW52YXJpYW50UmF0aW8JAGsDBQdzY2FsZTE2BQZpbnZDdXIIBQ90dXBsZVNlbmRCZXR0ZXICXzIJAAIBAjJUaGUgcmVxdWVzdGVkIHByaWNlIGlzIHRvbyBub3QgcHJvZml0YWJsZSBmb3IgdXNlcggFD3R1cGxlU2VuZEJldHRlcgJfMQEMZ2V0QXNzZXRJbmZvAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwBAhzdHJpbmdJZAkA2AQBBQJpZAQEaW5mbwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFAmlkCQCsAgIJAKwCAgIGQXNzZXQgBQhzdHJpbmdJZAIOIGRvZXNuJ3QgZXhpc3QJAJUKAwUIc3RyaW5nSWQIBQRpbmZvBG5hbWUIBQRpbmZvCGRlY2ltYWxzAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwCQCVCgMCBVdBVkVTAgVXQVZFUwAICQACAQILTWF0Y2ggZXJyb3IBB3N1c3BlbmQBBWNhdXNlCQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBwkAzAgCCQELU3RyaW5nRW50cnkCBQZrQ2F1c2UFBWNhdXNlBQNuaWwBDXRocm93SXNBY3RpdmUACQACAQIWREFwcCBpcyBhbHJlYWR5IGFjdGl2ZQEIaXNBY3RpdmUAAwMFBmFjdGl2ZQUKYWN0aXZlR2xvYgcFBHVuaXQJAAIBAh9EQXBwIGlzIGluYWN0aXZlIGF0IHRoaXMgbW9tZW50AQtpc0FkbWluQ2FsbAEBaQMJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFDGFkbWluUHViS2V5MQkAzAgCBQxhZG1pblB1YktleTIJAMwIAgUMYWRtaW5QdWJLZXkzBQNuaWwIBQFpD2NhbGxlclB1YmxpY0tleQUEdW5pdAkAAgECIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgEKaXNTZWxmQ2FsbAEBaQMJAAACBQR0aGlzCAUBaQZjYWxsZXIFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQt0aHJvd0Fzc2V0cwAJAAIBCQCsAgIJAKwCAgkArAICAiVJbmNvcnJlY3QgYXNzZXRzIGF0dGFjaGVkLiBFeHBlY3RlZDogBQtzdHJBc3NldElkQQIFIGFuZCAFC3N0ckFzc2V0SWRCAQ90aHJvd09uZVBheW1lbnQACQACAQIdT25lIGF0dGFjaGVkIHBheW1lbnQgZXhwZWN0ZWQBEXN1c3BlbmRTdXNwaWNpb3VzAAkBB3N1c3BlbmQBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAiNTdXNwaWNpb3VzIHN0YXRlLiBBY3R1YWwgYmFsYW5jZXM6IAkApAMBBQhiYWxhbmNlQQIBIAUKYXNzZXROYW1lQQICLCAJAKQDAQUIYmFsYW5jZUICASAFCmFzc2V0TmFtZUICCS4gU3RhdGU6IAkApAMBCQEOYWNjb3VudEJhbGFuY2UBBQhhc3NldElkQQIBIAUKYXNzZXROYW1lQQICLCAJAKQDAQkBDmFjY291bnRCYWxhbmNlAQUIYXNzZXRJZEICASAFCmFzc2V0TmFtZUIBGGNhbGNTdGFraW5nRnVuY0FuZEFkZHJlcwIFc3Rha2UHYXNzZXRJZAMFBXN0YWtlCQCUCgICDGxvY2tOZXV0cmlubwUSc3Rha2luZ1VTRE5BZGRyZXNzCQCUCgICDnVubG9ja05ldXRyaW5vBRJzdGFraW5nVVNETkFkZHJlc3MBEWNhbGNTdGFraW5nUGFyYW1zAwVzdGFrZQZhbW91bnQHYXNzZXRJZAMFBXN0YWtlBA0kdDAxMDIwNzEwMjczCQEYY2FsY1N0YWtpbmdGdW5jQW5kQWRkcmVzAgUFc3Rha2UFB2Fzc2V0SWQEBGNhbGwIBQ0kdDAxMDIwNzEwMjczAl8xBAtzdGFraW5nQWRkcggFDSR0MDEwMjA3MTAyNzMCXzIJAJYKBAUEY2FsbAULc3Rha2luZ0FkZHIFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUHYXNzZXRJZAUGYW1vdW50BQNuaWwEDSR0MDEwMzU5MTA0MjUJARhjYWxjU3Rha2luZ0Z1bmNBbmRBZGRyZXMCBQVzdGFrZQUHYXNzZXRJZAQEY2FsbAgFDSR0MDEwMzU5MTA0MjUCXzEEC3N0YWtpbmdBZGRyCAUNJHQwMTAzNTkxMDQyNQJfMgkAlgoEBQRjYWxsBQtzdGFraW5nQWRkcgkAzAgCBQZhbW91bnQJAMwIAgkA2AQBBQdhc3NldElkBQNuaWwFA25pbAEUY2FsY3VsYXRlRmVlRGlzY291bnQBCHVzZXJBZGRyBApzd29wQW1vdW50CQELdmFsdWVPckVsc2UCCQCaCAIFCmdvdkFkZHJlc3MJAKwCAgkApQgBBQh1c2VyQWRkcgUOa1VzZXJTd29wSW5Hb3YAAAQLZ1N3b3BBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUKZ292QWRkcmVzcwkArAICCQClCAEFCHVzZXJBZGRyBQ9rVXNlckdTd29wSW5Hb3YFCnN3b3BBbW91bnQEDmRpc2NvdW50VmFsdWVzCQC1CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBm9yYWNsZQUPa0Rpc2NvdW50VmFsdWVzAgEsBAlkaXNjb3VudHMJALUJAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUGb3JhY2xlBQprRGlzY291bnRzAgEsAwMJAGcCBQtnU3dvcEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDmRpc2NvdW50VmFsdWVzAAAJAGYCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUOZGlzY291bnRWYWx1ZXMAAQULZ1N3b3BBbW91bnQHCQBlAgUJZmVlU2NhbGU2CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUJZGlzY291bnRzAAADAwkAZwIFC2dTd29wQW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUOZGlzY291bnRWYWx1ZXMAAQkAZgIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ5kaXNjb3VudFZhbHVlcwACBQtnU3dvcEFtb3VudAcJAGUCBQlmZWVTY2FsZTYJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQlkaXNjb3VudHMAAQMDCQBnAgULZ1N3b3BBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ5kaXNjb3VudFZhbHVlcwACCQBmAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDmRpc2NvdW50VmFsdWVzAAMFC2dTd29wQW1vdW50BwkAZQIFCWZlZVNjYWxlNgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCWRpc2NvdW50cwACAwMJAGcCBQtnU3dvcEFtb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDmRpc2NvdW50VmFsdWVzAAMJAGYCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUOZGlzY291bnRWYWx1ZXMABAULZ1N3b3BBbW91bnQHCQBlAgUJZmVlU2NhbGU2CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUJZGlzY291bnRzAAMDCQBnAgULZ1N3b3BBbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQ5kaXNjb3VudFZhbHVlcwAECQBlAgUJZmVlU2NhbGU2CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUJZGlzY291bnRzAAQFCWZlZVNjYWxlNgESY2hlY2tEQXBwVGhyZXNob2xkAwtuZXdCYWxhbmNlQQtuZXdCYWxhbmNlQgpwbXRBc3NldElkBA1kQXBwVGhyZXNob2xkCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQ5rREFwcFRocmVzaG9sZAQFcmF0aW8DAwkAAAIFCnBtdEFzc2V0SWQFCGFzc2V0SWRBCQBmAgULbmV3QmFsYW5jZUEFC25ld0JhbGFuY2VCBwkAbgQFC25ld0JhbGFuY2VBAAEFC25ld0JhbGFuY2VCBQdDRUlMSU5HAwMJAAACBQpwbXRBc3NldElkBQhhc3NldElkQgkAZgIFC25ld0JhbGFuY2VCBQtuZXdCYWxhbmNlQQcJAG4EBQtuZXdCYWxhbmNlQgABBQtuZXdCYWxhbmNlQQUHQ0VJTElORwAAAwkAZgIFBXJhdGlvBQ1kQXBwVGhyZXNob2xkBA0kdDAxMjE3MDEyMjc4AwkAAAIFCnBtdEFzc2V0SWQFCGFzc2V0SWRBCQCUCgIFCmFzc2V0TmFtZUIFCmFzc2V0TmFtZUEJAJQKAgUKYXNzZXROYW1lQQUKYXNzZXROYW1lQgQGdG9rZW4xCAUNJHQwMTIxNzAxMjI3OAJfMQQGdG9rZW4yCAUNJHQwMTIxNzAxMjI3OAJfMgkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgIHQnV5aW5nIAUGdG9rZW4xAicgaXMgdGVtcG9yYXJpbHkgdW5hdmFpbGFibGUgZHVlIHRvIHRoZSAFBnRva2VuMgIGIGRlcGVnBgEacmVwbGVuaXNoV2l0aFR3b1Rva2Vuc0NhbGMDAWkMc3Rha2VGYXJtaW5nCGxvY2tUeXBlBAtwbXRBc3NldElkQQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBAtwbXRBc3NldElkQggJAJEDAggFAWkIcGF5bWVudHMAAQdhc3NldElkBBNyYXRpb1NoYXJlVG9rZW5zSW5BCQBrAwUGc2NhbGU4CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUIYmFsYW5jZUEEE3JhdGlvU2hhcmVUb2tlbnNJbkIJAGsDBQZzY2FsZTgICQCRAwIIBQFpCHBheW1lbnRzAAEGYW1vdW50BQhiYWxhbmNlQgQNJHQwMTI3MzgxMjgxNQkBDGdldEFzc2V0SW5mbwEFC3BtdEFzc2V0SWRBBA5wbXRTdHJBc3NldElkQQgFDSR0MDEyNzM4MTI4MTUCXzEEDXBtdEFzc2V0TmFtZUEIBQ0kdDAxMjczODEyODE1Al8yBAxwbXREZWNpbWFsc0EIBQ0kdDAxMjczODEyODE1Al8zBA0kdDAxMjgyMDEyOTM3CQEMZ2V0QXNzZXRJbmZvAQULcG10QXNzZXRJZEIEDnBtdFN0ckFzc2V0SWRCCAUNJHQwMTI4MjAxMjkzNwJfMQQNcG10QXNzZXROYW1lQggFDSR0MDEyODIwMTI5MzcCXzIEDHBtdERlY2ltYWxzQggFDSR0MDEyODIwMTI5MzcCXzMEDSR0MDEyOTQyMTM0NDYDCQBmAgUTcmF0aW9TaGFyZVRva2Vuc0luQgUTcmF0aW9TaGFyZVRva2Vuc0luQQQDcG10CQBuBAUIYmFsYW5jZUIFE3JhdGlvU2hhcmVUb2tlbnNJbkEFBnNjYWxlOAUHQ0VJTElORwkAlwoFCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUDcG10CQBlAggJAJEDAggFAWkIcGF5bWVudHMAAQZhbW91bnQFA3BtdAULcG10QXNzZXRJZEIFE3JhdGlvU2hhcmVUb2tlbnNJbkEEA3BtdAkAbgQFCGJhbGFuY2VBBRNyYXRpb1NoYXJlVG9rZW5zSW5CBQZzY2FsZTgFB0NFSUxJTkcJAJcKBQUDcG10CAkAkQMCCAUBaQhwYXltZW50cwABBmFtb3VudAkAZQIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQNwbXQFC3BtdEFzc2V0SWRBBRNyYXRpb1NoYXJlVG9rZW5zSW5CBApwbXRBbW91bnRBCAUNJHQwMTI5NDIxMzQ0NgJfMQQKcG10QW1vdW50QggFDSR0MDEyOTQyMTM0NDYCXzIEBmNoYW5nZQgFDSR0MDEyOTQyMTM0NDYCXzMEDWNoYW5nZUFzc2V0SWQIBQ0kdDAxMjk0MjEzNDQ2Al80BA9zaGFyZVRva2VuUmF0aW8IBQ0kdDAxMjk0MjEzNDQ2Al81BBVzaGFyZVRva2VuVG9QYXlBbW91bnQJAGsDBQ9zaGFyZVRva2VuUmF0aW8FEHNoYXJlQXNzZXRTdXBwbHkFBnNjYWxlOAMDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAIJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAwcJAAIBAh5Ud28gb3IgdGhyZWUgcGF5bWVudHMgZXhwZWN0ZWQDAwkBAiE9AgULcG10QXNzZXRJZEEFCGFzc2V0SWRBBgkBAiE9AgULcG10QXNzZXRJZEIFCGFzc2V0SWRCCQELdGhyb3dBc3NldHMAAwkAAAIFFXNoYXJlVG9rZW5Ub1BheUFtb3VudAAACQACAQIdVG9vIHNtYWxsIGFtb3VudCB0byByZXBsZW5pc2gDCQBmAgAABQZjaGFuZ2UJAAIBAgpDaGFuZ2UgPCAwAwkBASEBBRBoYXNFbm91Z2hCYWxhbmNlCQDOCAIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQpwbXRBbW91bnRBBQtwbXRBc3NldElkQQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFCnBtdEFtb3VudEIFC3BtdEFzc2V0SWRCBQNuaWwJARFzdXNwZW5kU3VzcGljaW91cwAEBnN0YWtlMQMJAQhjb250YWlucwIFDXN0YWtpbmdBc3NldHMFDnBtdFN0ckFzc2V0SWRBCQD8BwQFBHRoaXMCDHN0YWtlVW5zdGFrZQkAzAgCBgkAzAgCBQpwbXRBbW91bnRBCQDMCAIFDnBtdFN0ckFzc2V0SWRBBQNuaWwFA25pbAAAAwkAAAIFBnN0YWtlMQUGc3Rha2UxBAZzdGFrZTIDCQEIY29udGFpbnMCBQ1zdGFraW5nQXNzZXRzBQ5wbXRTdHJBc3NldElkQgkA/AcEBQR0aGlzAgxzdGFrZVVuc3Rha2UJAMwIAgYJAMwIAgUKcG10QW1vdW50QgkAzAgCBQ5wbXRTdHJBc3NldElkQgUDbmlsBQNuaWwAAAMJAAACBQZzdGFrZTIFBnN0YWtlMgQNc2NyaXB0QWN0aW9ucwkAzAgCCQEMSW50ZWdlckVudHJ5AgUJa0JhbGFuY2VBCQBkAgUIYmFsYW5jZUEFCnBtdEFtb3VudEEJAMwIAgkBDEludGVnZXJFbnRyeQIFCWtCYWxhbmNlQgkAZAIFCGJhbGFuY2VCBQpwbXRBbW91bnRCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRFrU2hhcmVBc3NldFN1cHBseQkAZAIFEHNoYXJlQXNzZXRTdXBwbHkFFXNoYXJlVG9rZW5Ub1BheUFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgUKa0ludmFyaWFudAkBDWludmFyaWFudENhbGMCCQBkAgUIYmFsYW5jZUEFCnBtdEFtb3VudEEJAGQCBQhiYWxhbmNlQgUKcG10QW1vdW50QgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFBmNoYW5nZQUNY2hhbmdlQXNzZXRJZAUDbmlsAwUMc3Rha2VGYXJtaW5nBApzdFBheW1lbnRzCQDOCAIJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFDHNoYXJlQXNzZXRJZAUVc2hhcmVUb2tlblRvUGF5QW1vdW50BQNuaWwDCQAAAgkAkAMBCAUBaQhwYXltZW50cwADCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCAwkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAIHYXNzZXRJZAEABQR1bml0CAkAkQMCCAUBaQhwYXltZW50cwACB2Fzc2V0SWQICQCRAwIIBQFpCHBheW1lbnRzAAIGYW1vdW50BQNuaWwFA25pbAQCcmUJAPwHBAUEdGhpcwIMcmVpc3N1ZVNoYXJlCQDMCAIFFXNoYXJlVG9rZW5Ub1BheUFtb3VudAUDbmlsBQNuaWwDCQAAAgUCcmUFAnJlBAFzCQD8BwQFDmZhcm1pbmdBZGRyZXNzAhdsb2NrU2hhcmVUb2tlbnNGcm9tUG9vbAkAzAgCCAgFAWkGY2FsbGVyBWJ5dGVzCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQhsb2NrVHlwZQUDbmlsBQpzdFBheW1lbnRzAwkAAAIFAXMFAXMFDXNjcmlwdEFjdGlvbnMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAM4IAgUNc2NyaXB0QWN0aW9ucwkAzAgCCQEHUmVpc3N1ZQMFDHNoYXJlQXNzZXRJZAUVc2hhcmVUb2tlblRvUGF5QW1vdW50BgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFFXNoYXJlVG9rZW5Ub1BheUFtb3VudAUMc2hhcmVBc3NldElkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BGXJlcGxlbmlzaFdpdGhPbmVUb2tlbkNhbGMFAWkTdmlydHVhbFN3YXBUb2tlblBheRN2aXJ0dWFsU3dhcFRva2VuR2V0DHN0YWtlRmFybWluZwhsb2NrVHlwZQQNJHQwMTU4MzYxNTkxMQkAlAoCCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBAlwbXRBbW91bnQIBQ0kdDAxNTgzNjE1OTExAl8xBApwbXRBc3NldElkCAUNJHQwMTU4MzYxNTkxMQJfMgQNJHQwMTU5MTYxNTk4OQkBDGdldEFzc2V0SW5mbwEFCnBtdEFzc2V0SWQEDXBtdFN0ckFzc2V0SWQIBQ0kdDAxNTkxNjE1OTg5Al8xBAxwbXRBc3NldE5hbWUIBQ0kdDAxNTkxNjE1OTg5Al8yBAtwbXREZWNpbWFscwgFDSR0MDE1OTE2MTU5ODkCXzMED3BtdE1pblRocmVzaG9sZADAlrECBB10aHJlc2hvbGRWYWx1ZUZvck1pblRvbGVyYW5jZQCA4esXBAl0b2xlcmFuY2UDCQBmAgUddGhyZXNob2xkVmFsdWVGb3JNaW5Ub2xlcmFuY2UFCXBtdEFtb3VudACgjQYAAQQcc2xpcHBhZ2VWYWx1ZU1pbkZvclJlcGxlbmlzaAkAZQIFBnNjYWxlOAkAaQIJAGgCBQZzY2FsZTgFCXRvbGVyYW5jZQCAreIEBBxzbGlwcGFnZVZhbHVlTWF4Rm9yUmVwbGVuaXNoCQBkAgUGc2NhbGU4CQBpAgkAaAIFBnNjYWxlOAUJdG9sZXJhbmNlAICt4gQEF3NsaXBwYWdlVmFsdWVNaW5Gb3JTd2FwCQBlAgUGc2NhbGU4CQBpAgkAaAIFBnNjYWxlOAABAICt4gQDCQBmAgUPcG10TWluVGhyZXNob2xkBQlwbXRBbW91bnQJAAIBCQCsAgIJAKwCAgkArAICCQCsAgICD1BheW1lbnQgYW1vdW50IAkApAMBBQlwbXRBbW91bnQCJyBkb2VzIG5vdCBleGNlZWQgdGhlIG1pbmltdW0gYW1vdW50IG9mIAkApAMBBQ9wbXRNaW5UaHJlc2hvbGQCByB0b2tlbnMDAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAIHCQACAQIcT25lIG9yIHR3byBwYXltZW50cyBleHBlY3RlZAMJAQEhAQUQaGFzRW5vdWdoQmFsYW5jZQkAzggCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUJcG10QW1vdW50BQpwbXRBc3NldElkBQNuaWwJARFzdXNwZW5kU3VzcGljaW91cwADAwkBAiE9AgUKcG10QXNzZXRJZAUIYXNzZXRJZEEJAQIhPQIFCnBtdEFzc2V0SWQFCGFzc2V0SWRCBwkBC3Rocm93QXNzZXRzAAQNJHQwMTY5OTExNzYzMwMJAAACBQpwbXRBc3NldElkBQhhc3NldElkQQkAmAoGCQBlAgUJcG10QW1vdW50BRN2aXJ0dWFsU3dhcFRva2VuUGF5BRN2aXJ0dWFsU3dhcFRva2VuR2V0CQBkAgUIYmFsYW5jZUEFE3ZpcnR1YWxTd2FwVG9rZW5QYXkJAGUCBQhiYWxhbmNlQgUTdmlydHVhbFN3YXBUb2tlbkdldAkAZAIFCGJhbGFuY2VBBQlwbXRBbW91bnQFCGJhbGFuY2VCCQCYCgYFE3ZpcnR1YWxTd2FwVG9rZW5HZXQJAGUCBQlwbXRBbW91bnQFE3ZpcnR1YWxTd2FwVG9rZW5QYXkJAGUCBQhiYWxhbmNlQQUTdmlydHVhbFN3YXBUb2tlbkdldAkAZAIFCGJhbGFuY2VCBRN2aXJ0dWFsU3dhcFRva2VuUGF5BQhiYWxhbmNlQQkAZAIFCGJhbGFuY2VCBQlwbXRBbW91bnQEEXZpcnR1YWxSZXBsZW5pc2hBCAUNJHQwMTY5OTExNzYzMwJfMQQRdmlydHVhbFJlcGxlbmlzaEIIBQ0kdDAxNjk5MTE3NjMzAl8yBBFiYWxhbmNlQWZ0ZXJTd2FwQQgFDSR0MDE2OTkxMTc2MzMCXzMEEWJhbGFuY2VBZnRlclN3YXBCCAUNJHQwMTY5OTExNzYzMwJfNAQLbmV3QmFsYW5jZUEIBQ0kdDAxNjk5MTE3NjMzAl81BAtuZXdCYWxhbmNlQggFDSR0MDE2OTkxMTc2MzMCXzYEDGludmFyaWFudE5ldwkBDWludmFyaWFudENhbGMCBRFiYWxhbmNlQWZ0ZXJTd2FwQQURYmFsYW5jZUFmdGVyU3dhcEIEJXJhdGlvVmlydHVhbEJhbGFuY2VUb1ZpcnR1YWxSZXBsZW5pc2gJAGkCCQBrAwUHc2NhbGUxNgURYmFsYW5jZUFmdGVyU3dhcEEFEWJhbGFuY2VBZnRlclN3YXBCCQBrAwUGc2NhbGU4BRF2aXJ0dWFsUmVwbGVuaXNoQQURdmlydHVhbFJlcGxlbmlzaEIDAwkAZwIFF3NsaXBwYWdlVmFsdWVNaW5Gb3JTd2FwCQBrAwUGc2NhbGU4BQlpbnZhcmlhbnQFDGludmFyaWFudE5ldwYJAGYCBQlpbnZhcmlhbnQFDGludmFyaWFudE5ldwkAAgECOkluY29ycmVjdCB2aXJ0dWFsU3dhcFRva2VuUGF5IG9yIHZpcnR1YWxTd2FwVG9rZW5HZXQgdmFsdWUDAwkAZgIFHHNsaXBwYWdlVmFsdWVNaW5Gb3JSZXBsZW5pc2gFJXJhdGlvVmlydHVhbEJhbGFuY2VUb1ZpcnR1YWxSZXBsZW5pc2gGCQBmAgUlcmF0aW9WaXJ0dWFsQmFsYW5jZVRvVmlydHVhbFJlcGxlbmlzaAUcc2xpcHBhZ2VWYWx1ZU1heEZvclJlcGxlbmlzaAkAAgECbFN3YXAgd2l0aCB2aXJ0dWFsU3dhcFRva2VuUGF5IGFuZCB2aXJ0dWFsU3dhcFRva2VuR2V0IGlzIHBvc3NpYmxlLCBidXQgcmF0aW8gYWZ0ZXIgdmlydHVhbCBzd2FwIGlzIGluY29ycmVjdAMJAQEhAQkBEmNoZWNrREFwcFRocmVzaG9sZAMFC25ld0JhbGFuY2VBBQtuZXdCYWxhbmNlQgUKcG10QXNzZXRJZAkBBXRocm93AAQTcmF0aW9TaGFyZVRva2Vuc0luQQkAawMFEXZpcnR1YWxSZXBsZW5pc2hBBQZzY2FsZTgFEWJhbGFuY2VBZnRlclN3YXBBBBNyYXRpb1NoYXJlVG9rZW5zSW5CCQBrAwURdmlydHVhbFJlcGxlbmlzaEIFBnNjYWxlOAURYmFsYW5jZUFmdGVyU3dhcEIEFXNoYXJlVG9rZW5Ub1BheUFtb3VudAkAawMJAJcDAQkAzAgCBRNyYXRpb1NoYXJlVG9rZW5zSW5BCQDMCAIFE3JhdGlvU2hhcmVUb2tlbnNJbkIFA25pbAUQc2hhcmVBc3NldFN1cHBseQUGc2NhbGU4BB1zaGFyZVRva2VuVG9QYXlBbW91bnRBZnRlckZlZQkAawMFFXNoYXJlVG9rZW5Ub1BheUFtb3VudAkAZQIFCWZlZVNjYWxlNgkAaQIFA2ZlZQACBQlmZWVTY2FsZTYEGnNoYXJlVG9rZW5Hb3Zlcm5hbmNlUmV3YXJkCQBrAwUVc2hhcmVUb2tlblRvUGF5QW1vdW50CQBpAgUNZmVlR292ZXJuYW5jZQACBQlmZWVTY2FsZTYEFmdvdmVybmFuY2VSZXdhcmRUb2tlbkEJAGsDBRpzaGFyZVRva2VuR292ZXJuYW5jZVJld2FyZAUIYmFsYW5jZUEFEHNoYXJlQXNzZXRTdXBwbHkEFmdvdmVybmFuY2VSZXdhcmRUb2tlbkIJAGsDBRpzaGFyZVRva2VuR292ZXJuYW5jZVJld2FyZAUIYmFsYW5jZUIFEHNoYXJlQXNzZXRTdXBwbHkEDSR0MDE5Mzg0MTk2NjcDCQAAAgUNcG10U3RyQXNzZXRJZAULc3RyQXNzZXRJZEEJAJUKAwkAZQIFCXBtdEFtb3VudAUWZ292ZXJuYW5jZVJld2FyZFRva2VuQQUWZ292ZXJuYW5jZVJld2FyZFRva2VuQgULc3RyQXNzZXRJZEIJAJUKAwkAZQIFCXBtdEFtb3VudAUWZ292ZXJuYW5jZVJld2FyZFRva2VuQgUWZ292ZXJuYW5jZVJld2FyZFRva2VuQQULc3RyQXNzZXRJZEEEC3N0YWtlQW1vdW50CAUNJHQwMTkzODQxOTY2NwJfMQQNdW5zdGFrZUFtb3VudAgFDSR0MDE5Mzg0MTk2NjcCXzIEDHVuc3Rha2VBc3NldAgFDSR0MDE5Mzg0MTk2NjcCXzMEBnN0YWtlMQMJAQhjb250YWlucwIFDXN0YWtpbmdBc3NldHMFDXBtdFN0ckFzc2V0SWQJAPwHBAUEdGhpcwIMc3Rha2VVbnN0YWtlCQDMCAIGCQDMCAIFC3N0YWtlQW1vdW50CQDMCAIFDXBtdFN0ckFzc2V0SWQFA25pbAUDbmlsAAADCQAAAgUGc3Rha2UxBQZzdGFrZTEEBnN0YWtlMgMJAQhjb250YWlucwIFDXN0YWtpbmdBc3NldHMFDHVuc3Rha2VBc3NldAkA/AcEBQR0aGlzAgxzdGFrZVVuc3Rha2UJAMwIAgcJAMwIAgUNdW5zdGFrZUFtb3VudAkAzAgCBQx1bnN0YWtlQXNzZXQFA25pbAUDbmlsAAADCQAAAgUGc3Rha2UyBQZzdGFrZTIEDXNjcmlwdEFjdGlvbnMJAMwIAgkBDEludGVnZXJFbnRyeQIFCWtCYWxhbmNlQQkAZQIFC25ld0JhbGFuY2VBBRZnb3Zlcm5hbmNlUmV3YXJkVG9rZW5BCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrQmFsYW5jZUIJAGUCBQtuZXdCYWxhbmNlQgUWZ292ZXJuYW5jZVJld2FyZFRva2VuQgkAzAgCCQEMSW50ZWdlckVudHJ5AgURa1NoYXJlQXNzZXRTdXBwbHkJAGQCBRBzaGFyZUFzc2V0U3VwcGx5BR1zaGFyZVRva2VuVG9QYXlBbW91bnRBZnRlckZlZQkAzAgCCQEMSW50ZWdlckVudHJ5AgUKa0ludmFyaWFudAkBDWludmFyaWFudENhbGMCCQBlAgULbmV3QmFsYW5jZUEFFmdvdmVybmFuY2VSZXdhcmRUb2tlbkEJAGUCBQtuZXdCYWxhbmNlQgUWZ292ZXJuYW5jZVJld2FyZFRva2VuQgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQ9tb25leUJveEFkZHJlc3MFFmdvdmVybmFuY2VSZXdhcmRUb2tlbkEFCGFzc2V0SWRBCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFD21vbmV5Qm94QWRkcmVzcwUWZ292ZXJuYW5jZVJld2FyZFRva2VuQgUIYXNzZXRJZEIFA25pbAMFDHN0YWtlRmFybWluZwQKc3RQYXltZW50cwkAzggCCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQxzaGFyZUFzc2V0SWQFHXNoYXJlVG9rZW5Ub1BheUFtb3VudEFmdGVyRmVlBQNuaWwDCQAAAgkAkAMBCAUBaQhwYXltZW50cwACCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCAwkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAEHYXNzZXRJZAEABQR1bml0CAkAkQMCCAUBaQhwYXltZW50cwABB2Fzc2V0SWQICQCRAwIIBQFpCHBheW1lbnRzAAEGYW1vdW50BQNuaWwFA25pbAQCcmUJAPwHBAUEdGhpcwIMcmVpc3N1ZVNoYXJlCQDMCAIFHXNoYXJlVG9rZW5Ub1BheUFtb3VudEFmdGVyRmVlBQNuaWwFA25pbAMJAAACBQJyZQUCcmUEAXMJAPwHBAUOZmFybWluZ0FkZHJlc3MCF2xvY2tTaGFyZVRva2Vuc0Zyb21Qb29sCQDMCAIICAUBaQZjYWxsZXIFYnl0ZXMJAMwIAgkApQgBBQR0aGlzCQDMCAIFCGxvY2tUeXBlBQNuaWwFCnN0UGF5bWVudHMDCQAAAgUBcwUBcwUNc2NyaXB0QWN0aW9ucwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAzggCBQ1zY3JpcHRBY3Rpb25zCQDMCAIJAQdSZWlzc3VlAwUMc2hhcmVBc3NldElkBR1zaGFyZVRva2VuVG9QYXlBbW91bnRBZnRlckZlZQYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBR1zaGFyZVRva2VuVG9QYXlBbW91bnRBZnRlckZlZQUMc2hhcmVBc3NldElkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDHdpdGhkcmF3Q2FsYwIBaQx1bmxvY2tBbW91bnQEDSR0MDIxNTE2MjE4NTEDCQAAAgkAkAMBCAUBaQhwYXltZW50cwABAwkBAiE9AggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQxzaGFyZUFzc2V0SWQJAAIBCQCsAgICJEluY29ycmVjdCBhc3NldCBhdHRhY2hlZC4gRXhwZWN0ZWQ6IAkA2AQBBQxzaGFyZUFzc2V0SWQJAJQKAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAkAlAoCAAAFDHNoYXJlQXNzZXRJZAQJcG10QW1vdW50CAUNJHQwMjE1MTYyMTg1MQJfMQQKcG10QXNzZXRJZAgFDSR0MDIxNTE2MjE4NTECXzIDCQEBIQEFEGhhc0Vub3VnaEJhbGFuY2UJAM4IAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFCXBtdEFtb3VudAUKcG10QXNzZXRJZAUDbmlsCQERc3VzcGVuZFN1c3BpY2lvdXMABAZ1bmxvY2sDCQBmAgUMdW5sb2NrQW1vdW50AAAJAPwHBAUOZmFybWluZ0FkZHJlc3MCG3dpdGhkcmF3U2hhcmVUb2tlbnNGcm9tUG9vbAkAzAgCCAgFAWkGY2FsbGVyBWJ5dGVzCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQx1bmxvY2tBbW91bnQFA25pbAUDbmlsAAADCQAAAgUGdW5sb2NrBQZ1bmxvY2sEDndpdGhkcmF3QW1vdW50CQBkAgUJcG10QW1vdW50BQx1bmxvY2tBbW91bnQEDGFtb3VudFRvUGF5QQkAawMFDndpdGhkcmF3QW1vdW50BQhiYWxhbmNlQQUQc2hhcmVBc3NldFN1cHBseQQMYW1vdW50VG9QYXlCCQBrAwUOd2l0aGRyYXdBbW91bnQFCGJhbGFuY2VCBRBzaGFyZUFzc2V0U3VwcGx5BBNpbnZhcmlhbnRDYWxjdWxhdGVkCQENaW52YXJpYW50Q2FsYwIJAGUCBQhiYWxhbmNlQQUMYW1vdW50VG9QYXlBCQBlAgUIYmFsYW5jZUIFDGFtb3VudFRvUGF5QgQGc3Rha2UxAwkBCGNvbnRhaW5zAgUNc3Rha2luZ0Fzc2V0cwULc3RyQXNzZXRJZEEJAPwHBAUEdGhpcwIMc3Rha2VVbnN0YWtlCQDMCAIHCQDMCAIFDGFtb3VudFRvUGF5QQkAzAgCBQtzdHJBc3NldElkQQUDbmlsBQNuaWwAAAMJAAACBQZzdGFrZTEFBnN0YWtlMQQGc3Rha2UyAwkBCGNvbnRhaW5zAgUNc3Rha2luZ0Fzc2V0cwULc3RyQXNzZXRJZEIJAPwHBAUEdGhpcwIMc3Rha2VVbnN0YWtlCQDMCAIHCQDMCAIFDGFtb3VudFRvUGF5QgkAzAgCBQtzdHJBc3NldElkQgUDbmlsBQNuaWwAAAMJAAACBQZzdGFrZTIFBnN0YWtlMgkAzAgCCQEMSW50ZWdlckVudHJ5AgUJa0JhbGFuY2VBCQBlAgUIYmFsYW5jZUEFDGFtb3VudFRvUGF5QQkAzAgCCQEMSW50ZWdlckVudHJ5AgUJa0JhbGFuY2VCCQBlAgUIYmFsYW5jZUIFDGFtb3VudFRvUGF5QgkAzAgCCQEMSW50ZWdlckVudHJ5AgURa1NoYXJlQXNzZXRTdXBwbHkJAGUCBRBzaGFyZUFzc2V0U3VwcGx5BQ53aXRoZHJhd0Ftb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgUKa0ludmFyaWFudAUTaW52YXJpYW50Q2FsY3VsYXRlZAkAzAgCCQEEQnVybgIFDHNoYXJlQXNzZXRJZAUOd2l0aGRyYXdBbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxhbW91bnRUb1BheUEFCGFzc2V0SWRBCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUMYW1vdW50VG9QYXlCBQhhc3NldElkQgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuDwFpAQRpbml0AQxmaXJzdEhhcnZlc3QEDSR0MDIzNDAzMjM0ODAJAJQKAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAQKcG10QW1vdW50QQgFDSR0MDIzNDAzMjM0ODACXzEEC3BtdEFzc2V0SWRBCAUNJHQwMjM0MDMyMzQ4MAJfMgQNJHQwMjM0ODUyMzU2MgkAlAoCCAkAkQMCCAUBaQhwYXltZW50cwABBmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAQdhc3NldElkBApwbXRBbW91bnRCCAUNJHQwMjM0ODUyMzU2MgJfMQQLcG10QXNzZXRJZEIIBQ0kdDAyMzQ4NTIzNTYyAl8yBA0kdDAyMzU2NzIzNjQ0CQEMZ2V0QXNzZXRJbmZvAQULcG10QXNzZXRJZEEEDnBtdFN0ckFzc2V0SWRBCAUNJHQwMjM1NjcyMzY0NAJfMQQNcG10QXNzZXROYW1lQQgFDSR0MDIzNTY3MjM2NDQCXzIEDHBtdERlY2ltYWxzQQgFDSR0MDIzNTY3MjM2NDQCXzMEDSR0MDIzNjQ5MjM3MjYJAQxnZXRBc3NldEluZm8BBQtwbXRBc3NldElkQgQOcG10U3RyQXNzZXRJZEIIBQ0kdDAyMzY0OTIzNzI2Al8xBA1wbXRBc3NldE5hbWVCCAUNJHQwMjM2NDkyMzcyNgJfMgQMcG10RGVjaW1hbHNCCAUNJHQwMjM2NDkyMzcyNgJfMwMJAQlpc0RlZmluZWQBCQCbCAIFBHRoaXMFB2tBY3RpdmUJAQ10aHJvd0lzQWN0aXZlAAMJAAACBQtwbXRBc3NldElkQQULcG10QXNzZXRJZEIJAAIBAhhBc3NldHMgbXVzdCBiZSBkaWZmZXJlbnQECXNoYXJlTmFtZQkArAICCQCsAgIJAKwCAgIBcwkArwICBQ1wbXRBc3NldE5hbWVBAAcCAV8JAK8CAgUNcG10QXNzZXROYW1lQgAHBBBzaGFyZURlc2NyaXB0aW9uCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIiU2hhcmVUb2tlbiBvZiBTd29wRmkgcHJvdG9jb2wgZm9yIAUNcG10QXNzZXROYW1lQQIFIGFuZCAFDXBtdEFzc2V0TmFtZUICDCBhdCBhZGRyZXNzIAkApQgBBQR0aGlzBA1zaGFyZURlY2ltYWxzCQBpAgkAZAIFDHBtdERlY2ltYWxzQQUMcG10RGVjaW1hbHNCAAIEEnNoYXJlSW5pdGlhbFN1cHBseQkAawMJAGwGBQpwbXRBbW91bnRBBQxwbXREZWNpbWFsc0EABQABBQxwbXREZWNpbWFsc0EFBERPV04JAGwGBQpwbXRBbW91bnRCBQxwbXREZWNpbWFsc0IABQABBQxwbXREZWNpbWFsc0IFBERPV04JAGwGAAoAAAUNc2hhcmVEZWNpbWFscwAAAAAFBERPV04ECnNoYXJlSXNzdWUJAMIIBQUJc2hhcmVOYW1lBRBzaGFyZURlc2NyaXB0aW9uBRJzaGFyZUluaXRpYWxTdXBwbHkFDXNoYXJlRGVjaW1hbHMGBAxzaGFyZUlzc3VlSWQJALgIAQUKc2hhcmVJc3N1ZQQTaW52YXJpYW50Q2FsY3VsYXRlZAkBDWludmFyaWFudENhbGMCBQpwbXRBbW91bnRBBQpwbXRBbW91bnRCBAZzdGFrZTEDCQEIY29udGFpbnMCBQ1zdGFraW5nQXNzZXRzBQ5wbXRTdHJBc3NldElkQQkA/AcEBQR0aGlzAgxzdGFrZVVuc3Rha2UJAMwIAgYJAMwIAgUKcG10QW1vdW50QQkAzAgCBQ5wbXRTdHJBc3NldElkQQUDbmlsBQNuaWwAAAMJAAACBQZzdGFrZTEFBnN0YWtlMQQGc3Rha2UyAwkBCGNvbnRhaW5zAgUNc3Rha2luZ0Fzc2V0cwUOcG10U3RyQXNzZXRJZEIJAPwHBAUEdGhpcwIMc3Rha2VVbnN0YWtlCQDMCAIGCQDMCAIFCnBtdEFtb3VudEIJAMwIAgUOcG10U3RyQXNzZXRJZEIFA25pbAUDbmlsAAADCQAAAgUGc3Rha2UyBQZzdGFrZTIECWJhc2VFbnRyeQkAzAgCCQELU3RyaW5nRW50cnkCBQhrVmVyc2lvbgUHdmVyc2lvbgkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQYJAMwIAgkBC1N0cmluZ0VudHJ5AgUJa0Fzc2V0SWRBBQ5wbXRTdHJBc3NldElkQQkAzAgCCQELU3RyaW5nRW50cnkCBQlrQXNzZXRJZEIFDnBtdFN0ckFzc2V0SWRCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrQmFsYW5jZUEFCnBtdEFtb3VudEEJAMwIAgkBDEludGVnZXJFbnRyeQIFCWtCYWxhbmNlQgUKcG10QW1vdW50QgkAzAgCCQEMSW50ZWdlckVudHJ5AgUKa0ludmFyaWFudAUTaW52YXJpYW50Q2FsY3VsYXRlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUEa0ZlZQkBEUBleHRyTmF0aXZlKDEwNTApAgUGb3JhY2xlAg1iYXNlX2ZlZV9mbGF0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ5rREFwcFRocmVzaG9sZAADCQDMCAIFCnNoYXJlSXNzdWUJAMwIAgkBC1N0cmluZ0VudHJ5AgUNa1NoYXJlQXNzZXRJZAkA2AQBBQxzaGFyZUlzc3VlSWQJAMwIAgkBDEludGVnZXJFbnRyeQIFEWtTaGFyZUFzc2V0U3VwcGx5BRJzaGFyZUluaXRpYWxTdXBwbHkJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBRJzaGFyZUluaXRpYWxTdXBwbHkFDHNoYXJlSXNzdWVJZAUDbmlsAwUMZmlyc3RIYXJ2ZXN0CQDOCAIFCWJhc2VFbnRyeQkAzAgCCQEMQm9vbGVhbkVudHJ5AgUNa0ZpcnN0SGFydmVzdAUMZmlyc3RIYXJ2ZXN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNrRmlyc3RIYXJ2ZXN0SGVpZ2h0CQBkAgULc3RhcnRIZWlnaHQJAGgCBRVmaXJzdEhhcnZlc3RFbmRQZXJpb2QFDHBlcmlvZExlbmd0aAUDbmlsBQliYXNlRW50cnkJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEYcmVwbGVuaXNoV2l0aFR3b1Rva2Vuc1YyAgxzdGFrZUZhcm1pbmcIbG9ja1R5cGUJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJARpyZXBsZW5pc2hXaXRoVHdvVG9rZW5zQ2FsYwMFAWkFDHN0YWtlRmFybWluZwUIbG9ja1R5cGUBaQEXcmVwbGVuaXNoV2l0aE9uZVRva2VuVjIEE3ZpcnR1YWxTd2FwVG9rZW5QYXkTdmlydHVhbFN3YXBUb2tlbkdldAxzdGFrZUZhcm1pbmcIbG9ja1R5cGUJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJARlyZXBsZW5pc2hXaXRoT25lVG9rZW5DYWxjBQUBaQUTdmlydHVhbFN3YXBUb2tlblBheQUTdmlydHVhbFN3YXBUb2tlbkdldAUMc3Rha2VGYXJtaW5nBQhsb2NrVHlwZQFpAQp3aXRoZHJhd1YyAQx1bmxvY2tBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJAQx3aXRoZHJhd0NhbGMCBQFpBQx1bmxvY2tBbW91bnQBaQEQd2l0aGRyYXdPbmVUb2tlbgQMdW5sb2NrQW1vdW50DXdpdGhkcmF3QXNzZXQYZXN0aW1hdGVkQW1vdW50VG9SZWNlaXZlEm1pbkFtb3VudFRvUmVjZWl2ZQkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAQNJHQwMjcxNDEyNzQ3NgMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEDCQECIT0CCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFDHNoYXJlQXNzZXRJZAkAAgEJAKwCAgIkSW5jb3JyZWN0IGFzc2V0IGF0dGFjaGVkLiBFeHBlY3RlZDogCQDYBAEFDHNoYXJlQXNzZXRJZAkAlAoCCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkCQCUCgIAAAUMc2hhcmVBc3NldElkBAlwbXRBbW91bnQIBQ0kdDAyNzE0MTI3NDc2Al8xBApwbXRBc3NldElkCAUNJHQwMjcxNDEyNzQ3NgJfMgQOd2l0aGRyYXdBbW91bnQJAGQCBQlwbXRBbW91bnQFDHVubG9ja0Ftb3VudAMDCQECIT0CBQ13aXRoZHJhd0Fzc2V0BQtzdHJBc3NldElkQQkBAiE9AgUNd2l0aGRyYXdBc3NldAULc3RyQXNzZXRJZEIHCQACAQIYSW5jb3JyZWN0IHdpdGhkcmF3IGFzc2V0AwkAZwIAAAUOd2l0aGRyYXdBbW91bnQJAAIBAiV3aXRoZHJhdyBhbW91bnQgbXVzdCBiZSBncmF0ZXIgdGhhbiAwAwkBASEBBRBoYXNFbm91Z2hCYWxhbmNlCQDOCAIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQlwbXRBbW91bnQFCnBtdEFzc2V0SWQFA25pbAkBEXN1c3BlbmRTdXNwaWNpb3VzAAQGdW5sb2NrAwkAZgIFDHVubG9ja0Ftb3VudAAACQD8BwQFDmZhcm1pbmdBZGRyZXNzAht3aXRoZHJhd1NoYXJlVG9rZW5zRnJvbVBvb2wJAMwIAggIBQFpBmNhbGxlcgVieXRlcwkAzAgCCQClCAEFBHRoaXMJAMwIAgUMdW5sb2NrQW1vdW50BQNuaWwFA25pbAAAAwkAAAIFBnVubG9jawUGdW5sb2NrBAxhbW91bnRUb1BheUEJAGsDBQ53aXRoZHJhd0Ftb3VudAUIYmFsYW5jZUEFEHNoYXJlQXNzZXRTdXBwbHkEDGFtb3VudFRvUGF5QgkAawMFDndpdGhkcmF3QW1vdW50BQhiYWxhbmNlQgUQc2hhcmVBc3NldFN1cHBseQQMbmV3VmlydEJhbGNBCQBlAgUIYmFsYW5jZUEFDGFtb3VudFRvUGF5QQQMbmV3VmlydEJhbGNCCQBlAgUIYmFsYW5jZUIFDGFtb3VudFRvUGF5QgQLZmVlRGlzY291bnQJARRjYWxjdWxhdGVGZWVEaXNjb3VudAEIBQFpDG9yaWdpbkNhbGxlcgQWYW1vdW50RXhjaGFuZ2VkV2l0aEZlZQMJAAACBQ13aXRoZHJhd0Fzc2V0BQtzdHJBc3NldElkQQkBE2NhbGN1bGF0ZVNlbmRBbW91bnQHBRhlc3RpbWF0ZWRBbW91bnRUb1JlY2VpdmUFEm1pbkFtb3VudFRvUmVjZWl2ZQUMYW1vdW50VG9QYXlCBQhhc3NldElkQgUMbmV3VmlydEJhbGNBBQxuZXdWaXJ0QmFsY0IJAQ1pbnZhcmlhbnRDYWxjAgUMbmV3VmlydEJhbGNBBQxuZXdWaXJ0QmFsY0IJARNjYWxjdWxhdGVTZW5kQW1vdW50BwUYZXN0aW1hdGVkQW1vdW50VG9SZWNlaXZlBRJtaW5BbW91bnRUb1JlY2VpdmUFDGFtb3VudFRvUGF5QQUIYXNzZXRJZEEFDG5ld1ZpcnRCYWxjQQUMbmV3VmlydEJhbGNCCQENaW52YXJpYW50Q2FsYwIFDG5ld1ZpcnRCYWxjQQUMbmV3VmlydEJhbGNCBAlnb3ZSZXdhcmQJAGsDBRZhbW91bnRFeGNoYW5nZWRXaXRoRmVlCQBuBAUNZmVlR292ZXJuYW5jZQULZmVlRGlzY291bnQFCWZlZVNjYWxlNgUHQ0VJTElORwUJZmVlU2NhbGU2BA9hbW91bnRFeGNoYW5nZWQJAGsDBRZhbW91bnRFeGNoYW5nZWRXaXRoRmVlCQBlAgUJZmVlU2NhbGU2CQBuBAUDZmVlBQtmZWVEaXNjb3VudAUJZmVlU2NhbGU2BQdDRUlMSU5HBQlmZWVTY2FsZTYEDSR0MDI5MDc5Mjk0NDEDCQAAAgUNd2l0aGRyYXdBc3NldAULc3RyQXNzZXRJZEEJAJYKBAkAZAIFDGFtb3VudFRvUGF5QQUPYW1vdW50RXhjaGFuZ2VkCQBlAgkAZQIJAGUCBQhiYWxhbmNlQQUMYW1vdW50VG9QYXlBBQ9hbW91bnRFeGNoYW5nZWQFCWdvdlJld2FyZAUIYmFsYW5jZUIFCGFzc2V0SWRCCQCWCgQJAGQCBQxhbW91bnRUb1BheUIFD2Ftb3VudEV4Y2hhbmdlZAUIYmFsYW5jZUEJAGUCCQBlAgkAZQIFCGJhbGFuY2VCBQxhbW91bnRUb1BheUIFD2Ftb3VudEV4Y2hhbmdlZAUJZ292UmV3YXJkBQhhc3NldElkQQQLYW1vdW50VG9QYXkIBQ0kdDAyOTA3OTI5NDQxAl8xBAtiYWxhbmNlQU5ldwgFDSR0MDI5MDc5Mjk0NDECXzIEC2JhbGFuY2VCTmV3CAUNJHQwMjkwNzkyOTQ0MQJfMwQLdmlydEFzc2V0SWQIBQ0kdDAyOTA3OTI5NDQxAl80AwkBASEBCQESY2hlY2tEQXBwVGhyZXNob2xkAwULYmFsYW5jZUFOZXcFC2JhbGFuY2VCTmV3BQt2aXJ0QXNzZXRJZAkBBXRocm93AAQTaW52YXJpYW50Q2FsY3VsYXRlZAkBDWludmFyaWFudENhbGMCBQtiYWxhbmNlQU5ldwULYmFsYW5jZUJOZXcEBnN0YWtlMQMJAQhjb250YWlucwIFDXN0YWtpbmdBc3NldHMFDXdpdGhkcmF3QXNzZXQJAPwHBAUEdGhpcwIMc3Rha2VVbnN0YWtlCQDMCAIHCQDMCAIJAGQCBQthbW91bnRUb1BheQUJZ292UmV3YXJkCQDMCAIFDXdpdGhkcmF3QXNzZXQFA25pbAUDbmlsAAADCQAAAgUGc3Rha2UxBQZzdGFrZTEJAMwIAgkBDEludGVnZXJFbnRyeQIFCWtCYWxhbmNlQQULYmFsYW5jZUFOZXcJAMwIAgkBDEludGVnZXJFbnRyeQIFCWtCYWxhbmNlQgULYmFsYW5jZUJOZXcJAMwIAgkBDEludGVnZXJFbnRyeQIFEWtTaGFyZUFzc2V0U3VwcGx5CQBlAgUQc2hhcmVBc3NldFN1cHBseQUOd2l0aGRyYXdBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFCmtJbnZhcmlhbnQFE2ludmFyaWFudENhbGN1bGF0ZWQJAMwIAgkBBEJ1cm4CBQxzaGFyZUFzc2V0SWQFDndpdGhkcmF3QW1vdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULYW1vdW50VG9QYXkJANkEAQUNd2l0aGRyYXdBc3NldAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQ9tb25leUJveEFkZHJlc3MFCWdvdlJld2FyZAkA2QQBBQ13aXRoZHJhd0Fzc2V0BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIZXhjaGFuZ2UCGGVzdGltYXRlZEFtb3VudFRvUmVjZWl2ZRJtaW5BbW91bnRUb1JlY2VpdmUJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAEDSR0MDMwNDA0MzA0NzkJAJQKAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAQJcG10QW1vdW50CAUNJHQwMzA0MDQzMDQ3OQJfMQQKcG10QXNzZXRJZAgFDSR0MDMwNDA0MzA0NzkCXzIDCQBnAgAABRhlc3RpbWF0ZWRBbW91bnRUb1JlY2VpdmUJAAIBCQCsAgICK0VzdGltYXRlZCBhbW91bnQgbXVzdCBiZSBwb3NpdGl2ZS4gQWN0dWFsOiAJAKQDAQUYZXN0aW1hdGVkQW1vdW50VG9SZWNlaXZlAwkAZgIFEm1pbkFtb3VudFRvUmVjZWl2ZQUYZXN0aW1hdGVkQW1vdW50VG9SZWNlaXZlCQACAQIvTWluaW1hbCBhbW91bnQgY2FuJ3QgYmUgZ3JlYXRlciB0aGFuIGVzdGltYXRlZC4DCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAQ90aHJvd09uZVBheW1lbnQAAwkBASEBBRBoYXNFbm91Z2hCYWxhbmNlCQDOCAIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQlwbXRBbW91bnQFCnBtdEFzc2V0SWQFA25pbAkBEXN1c3BlbmRTdXNwaWNpb3VzAAMDCQECIT0CBQpwbXRBc3NldElkBQhhc3NldElkQQkBAiE9AgUKcG10QXNzZXRJZAUIYXNzZXRJZEIHCQELdGhyb3dBc3NldHMAAwkAZgIAgK3iBAUJcG10QW1vdW50CQACAQIwT25seSBzd2FwIG9mIDEwLjAwMDAwMCBvciBtb3JlIHRva2VucyBpcyBhbGxvd2VkAwMJAGYCBRVleGNoYW5nZVJhdGlvTGltaXRNaW4JAGsDBQZzY2FsZTgFEm1pbkFtb3VudFRvUmVjZWl2ZQUJcG10QW1vdW50BgkAZgIJAGsDBQZzY2FsZTgFGGVzdGltYXRlZEFtb3VudFRvUmVjZWl2ZQUJcG10QW1vdW50BRVleGNoYW5nZVJhdGlvTGltaXRNYXgJAAIBAhxJbmNvcnJlY3QgYXJncyBhbmQgcG10IHJhdGlvBAtzZW5kQXNzZXRJZAMJAAACBQpwbXRBc3NldElkBQhhc3NldElkQQUIYXNzZXRJZEIFCGFzc2V0SWRBBAZhbW91bnQJARNjYWxjdWxhdGVTZW5kQW1vdW50BwUYZXN0aW1hdGVkQW1vdW50VG9SZWNlaXZlBRJtaW5BbW91bnRUb1JlY2VpdmUFCXBtdEFtb3VudAUKcG10QXNzZXRJZAUIYmFsYW5jZUEFCGJhbGFuY2VCBQlpbnZhcmlhbnQEC2ZlZURpc2NvdW50CQEUY2FsY3VsYXRlRmVlRGlzY291bnQBCAUBaQxvcmlnaW5DYWxsZXIEEGdvdmVybmFuY2VSZXdhcmQJAGsDBQZhbW91bnQJAG4EBQ1mZWVHb3Zlcm5hbmNlBQtmZWVEaXNjb3VudAUJZmVlU2NhbGU2BQdDRUlMSU5HBQlmZWVTY2FsZTYEDmFtb3VudE1pbnVzRmVlCQBrAwUGYW1vdW50CQBlAgUJZmVlU2NhbGU2CQBuBAUDZmVlBQtmZWVEaXNjb3VudAUJZmVlU2NhbGU2BQdDRUlMSU5HBQlmZWVTY2FsZTYEDSR0MDMxOTYzMzIyMjUDCQAAAgUKcG10QXNzZXRJZAUIYXNzZXRJZEEJAJQKAgkAZAIFCGJhbGFuY2VBBQlwbXRBbW91bnQJAGUCCQBlAgUIYmFsYW5jZUIFDmFtb3VudE1pbnVzRmVlBRBnb3Zlcm5hbmNlUmV3YXJkCQCUCgIJAGUCCQBlAgUIYmFsYW5jZUEFDmFtb3VudE1pbnVzRmVlBRBnb3Zlcm5hbmNlUmV3YXJkCQBkAgUIYmFsYW5jZUIFCXBtdEFtb3VudAQLbmV3QmFsYW5jZUEIBQ0kdDAzMTk2MzMyMjI1Al8xBAtuZXdCYWxhbmNlQggFDSR0MDMxOTYzMzIyMjUCXzIDCQEBIQEJARJjaGVja0RBcHBUaHJlc2hvbGQDBQtuZXdCYWxhbmNlQQULbmV3QmFsYW5jZUIFCnBtdEFzc2V0SWQJAQV0aHJvdwAEDSR0MDMyMzIzMzIzOTYJAQxnZXRBc3NldEluZm8BBQpwbXRBc3NldElkBA1wbXRTdHJBc3NldElkCAUNJHQwMzIzMjMzMjM5NgJfMQQMcG10QXNzZXROYW1lCAUNJHQwMzIzMjMzMjM5NgJfMgQLcG10RGVjaW1hbHMIBQ0kdDAzMjMyMzMyMzk2Al8zBA0kdDAzMjQwNTMyNDgyCQEMZ2V0QXNzZXRJbmZvAQULc2VuZEFzc2V0SWQEDnNlbmRTdHJBc3NldElkCAUNJHQwMzI0MDUzMjQ4MgJfMQQNc2VuZEFzc2V0TmFtZQgFDSR0MDMyNDA1MzI0ODICXzIEDHNlbmREZWNpbWFscwgFDSR0MDMyNDA1MzI0ODICXzMEBnN0YWtlMQMJAQhjb250YWlucwIFDXN0YWtpbmdBc3NldHMFDXBtdFN0ckFzc2V0SWQJAPwHBAUEdGhpcwIMc3Rha2VVbnN0YWtlCQDMCAIGCQDMCAIFCXBtdEFtb3VudAkAzAgCBQ1wbXRTdHJBc3NldElkBQNuaWwFA25pbAAAAwkAAAIFBnN0YWtlMQUGc3Rha2UxBAZzdGFrZTIDCQEIY29udGFpbnMCBQ1zdGFraW5nQXNzZXRzBQ5zZW5kU3RyQXNzZXRJZAkA/AcEBQR0aGlzAgxzdGFrZVVuc3Rha2UJAMwIAgcJAMwIAgkAZAIFDmFtb3VudE1pbnVzRmVlBRBnb3Zlcm5hbmNlUmV3YXJkCQDMCAIFDnNlbmRTdHJBc3NldElkBQNuaWwFA25pbAAAAwkAAAIFBnN0YWtlMgUGc3Rha2UyCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFCWtCYWxhbmNlQQULbmV3QmFsYW5jZUEJAMwIAgkBDEludGVnZXJFbnRyeQIFCWtCYWxhbmNlQgULbmV3QmFsYW5jZUIJAMwIAgkBDEludGVnZXJFbnRyeQIFCmtJbnZhcmlhbnQJAQ1pbnZhcmlhbnRDYWxjAgULbmV3QmFsYW5jZUEFC25ld0JhbGFuY2VCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUOYW1vdW50TWludXNGZWUFC3NlbmRBc3NldElkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFD21vbmV5Qm94QWRkcmVzcwUQZ292ZXJuYW5jZVJld2FyZAULc2VuZEFzc2V0SWQFA25pbAkAzAgCBQ5hbW91bnRNaW51c0ZlZQkAzAgCBQtzZW5kQXNzZXRJZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuA21zZwEMcmVpc3N1ZVNoYXJlAQZhbW91bnQJAQt2YWx1ZU9yRWxzZQIJAQppc1NlbGZDYWxsAQUDbXNnCQDMCAIJAQdSZWlzc3VlAwUMc2hhcmVBc3NldElkBQZhbW91bnQGBQNuaWwBaQEIc2h1dGRvd24ACQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQFpAwkBASEBBQZhY3RpdmUJAAIBCQCsAgICIkRBcHAgaXMgYWxyZWFkeSBzdXNwZW5kZWQuIENhdXNlOiAJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUGa0NhdXNlAhp0aGUgY2F1c2Ugd2Fzbid0IHNwZWNpZmllZAkBB3N1c3BlbmQBAg9QYXVzZWQgYnkgYWRtaW4BaQEIYWN0aXZhdGUACQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQFpAwUGYWN0aXZlCQENdGhyb3dJc0FjdGl2ZQAJAMwIAgkBDEJvb2xlYW5FbnRyeQIFB2tBY3RpdmUGCQDMCAIJAQtEZWxldGVFbnRyeQEFBmtDYXVzZQUDbmlsAWkBGXRha2VJbnRvQWNjb3VudEV4dHJhRnVuZHMACQELdmFsdWVPckVsc2UCCQEIaXNBY3RpdmUABAVjbGFpbQMDCQAAAgUIYXNzZXRJZEEFBFVTRE4GCQAAAgUIYXNzZXRJZEIFBFVTRE4JAPwHBAUSc3Rha2luZ1VTRE5BZGRyZXNzAgxjbGFpbVJld2FyZHMFA25pbAUDbmlsAAADCQAAAgUFY2xhaW0FBWNsYWltBA1hbW91bnRFbnJvbGxBCQBlAgUZYWNjb3VudEJhbGFuY2VXaXRoU3Rha2VkQQUIYmFsYW5jZUEEDWFtb3VudEVucm9sbEIJAGUCBRlhY2NvdW50QmFsYW5jZVdpdGhTdGFrZWRCBQhiYWxhbmNlQgQMaW52YXJpYW50TmV3CQENaW52YXJpYW50Q2FsYwIJAGQCBQhiYWxhbmNlQQUNYW1vdW50RW5yb2xsQQkAZAIFCGJhbGFuY2VCBQ1hbW91bnRFbnJvbGxCAwkBAiE9AggFAWkGY2FsbGVyBQ9tb25leUJveEFkZHJlc3MJAAIBAilPbmx5IHRoZSBtb25leSBib3ggY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgMDCQBmAgAABQ1hbW91bnRFbnJvbGxBBgkAZgIAAAUNYW1vdW50RW5yb2xsQgkBB3N1c3BlbmQBAhZFbnJvbGwgYW1vdW50IG5lZ2F0aXZlAwMJAAACBQ1hbW91bnRFbnJvbGxBAAAJAAACBQ1hbW91bnRFbnJvbGxCAAAHCQACAQIQTm8gbW9uZXkgdG8gdGFrZQQGc3Rha2UxAwMJAQhjb250YWlucwIFDXN0YWtpbmdBc3NldHMFC3N0ckFzc2V0SWRBCQBmAgUNYW1vdW50RW5yb2xsQQAABwkA/AcEBQR0aGlzAgxzdGFrZVVuc3Rha2UJAMwIAgYJAMwIAgUNYW1vdW50RW5yb2xsQQkAzAgCBQtzdHJBc3NldElkQQUDbmlsBQNuaWwAAAMJAAACBQZzdGFrZTEFBnN0YWtlMQQGc3Rha2UyAwMJAQhjb250YWlucwIFDXN0YWtpbmdBc3NldHMFC3N0ckFzc2V0SWRCCQBmAgUNYW1vdW50RW5yb2xsQgAABwkA/AcEBQR0aGlzAgxzdGFrZVVuc3Rha2UJAMwIAgYJAMwIAgUNYW1vdW50RW5yb2xsQgkAzAgCBQtzdHJBc3NldElkQgUDbmlsBQNuaWwAAAMJAAACBQZzdGFrZTIFBnN0YWtlMgkAzAgCCQEMSW50ZWdlckVudHJ5AgUKa0ludmFyaWFudAUMaW52YXJpYW50TmV3CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrQmFsYW5jZUEJAGQCBQhiYWxhbmNlQQUNYW1vdW50RW5yb2xsQQkAzAgCCQEMSW50ZWdlckVudHJ5AgUJa0JhbGFuY2VCCQBkAgUIYmFsYW5jZUIFDWFtb3VudEVucm9sbEIFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARhrZWVwTGltaXRGb3JGaXJzdEhhcnZlc3QBCnNoYXJlTGltaXQJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkJAMwIAgkBDEludGVnZXJFbnRyeQIFC2tTaGFyZUxpbWl0BQpzaGFyZUxpbWl0BQNuaWwBaQEMc3Rha2VVbnN0YWtlAwVzdGFrZQZhbW91bnQNYXNzZXRJZFN0cmluZwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECLU9ubHkgY29udHJhY3QgaXRzZWxmIGNhbiBpbnZva2UgdGhpcyBmdW5jdGlvbgQNJHQwMzU4NDUzNTk0OAkBEWNhbGNTdGFraW5nUGFyYW1zAwUFc3Rha2UFBmFtb3VudAkA2QQBBQ1hc3NldElkU3RyaW5nBARjYWxsCAUNJHQwMzU4NDUzNTk0OAJfMQQEYWRkcggFDSR0MDM1ODQ1MzU5NDgCXzIEBnBhcmFtcwgFDSR0MDM1ODQ1MzU5NDgCXzMECHBheW1lbnRzCAUNJHQwMzU4NDUzNTk0OAJfNAQDaW52CQD8BwQFBGFkZHIFBGNhbGwFBnBhcmFtcwUIcGF5bWVudHMDCQAAAgUDaW52BQNpbnYFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARZyZXBsZW5pc2hXaXRoVHdvVG9rZW5zAAkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAkBGnJlcGxlbmlzaFdpdGhUd29Ub2tlbnNDYWxjAwUBaQcAAAFpARVyZXBsZW5pc2hXaXRoT25lVG9rZW4CE3ZpcnR1YWxTd2FwVG9rZW5QYXkTdmlydHVhbFN3YXBUb2tlbkdldAkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAkBGXJlcGxlbmlzaFdpdGhPbmVUb2tlbkNhbGMFBQFpBRN2aXJ0dWFsU3dhcFRva2VuUGF5BRN2aXJ0dWFsU3dhcFRva2VuR2V0BwAAAWkBCHdpdGhkcmF3AAkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAkBDHdpdGhkcmF3Q2FsYwIFAWkAAAECdHgBBnZlcmlmeQAEE211bHRpU2lnbmVkQnlBZG1pbnMEEmFkbWluUHViS2V5MVNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFDGFkbWluUHViS2V5MQABAAAEEmFkbWluUHViS2V5MlNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFDGFkbWluUHViS2V5MgABAAAEEmFkbWluUHViS2V5M1NpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFDGFkbWluUHViS2V5MwABAAAJAGcCCQBkAgkAZAIFEmFkbWluUHViS2V5MVNpZ25lZAUSYWRtaW5QdWJLZXkyU2lnbmVkBRJhZG1pblB1YktleTNTaWduZWQAAgQHJG1hdGNoMAUCdHgDCQABAgUHJG1hdGNoMAIXSW52b2tlU2NyaXB0VHJhbnNhY3Rpb24EA2ludgUHJG1hdGNoMAQTY2FsbFRha2VJbnRvQWNjb3VudAMJAAACCAUDaW52BGRBcHAFBHRoaXMJAAACCAUDaW52CGZ1bmN0aW9uAhl0YWtlSW50b0FjY291bnRFeHRyYUZ1bmRzBwQNc2lnbmVkQnlBZG1pbgMDAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMYWRtaW5QdWJLZXkxBgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMYWRtaW5QdWJLZXkyBgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMYWRtaW5QdWJLZXkzBgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAURYWRtaW5QdWJLZXlJbnZva2UDAwUTY2FsbFRha2VJbnRvQWNjb3VudAUNc2lnbmVkQnlBZG1pbgcGBRNtdWx0aVNpZ25lZEJ5QWRtaW5zBRNtdWx0aVNpZ25lZEJ5QWRtaW5ztQB2Rg==", "height": 2440682, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: FjvTQ3qRLx53jVZcSHKYeoxVpe1HdedCzPMvZiC2GpiD Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 6 #-}
2+{-# SCRIPT_TYPE ACCOUNT #-}
3+{-# CONTENT_TYPE DAPP #-}
4+let version = "2.0.0"
5+
6+let kVersion = "version"
7+
8+let kActive = "active"
9+
10+let kActiveGlob = "active_all_contracts"
11+
12+let kAssetIdA = "A_asset_id"
13+
14+let kAssetIdB = "B_asset_id"
15+
16+let kBalanceA = "A_asset_balance"
17+
18+let kBalanceB = "B_asset_balance"
19+
20+let kShareAssetId = "share_asset_id"
21+
22+let kShareAssetSupply = "share_asset_supply"
23+
24+let kFee = "commission"
25+
26+let kInvariant = "invariant"
27+
28+let kCause = "shutdown_cause"
29+
30+let kUSDNAddress = "staking_usdnnsbt_address"
31+
32+let kEURNAddress = "staking_eurn_address"
33+
34+let kDiscounts = "discounts"
35+
36+let kDiscountValues = "discount_values"
37+
38+let kUserSwopInGov = "_SWOP_amount"
39+
40+let kUserGSwopInGov = "_GSwop_amount"
41+
42+let kFirstHarvest = "first_harvest"
43+
44+let kFirstHarvestHeight = "first_harvest_height"
45+
46+let kShareLimit = "share_limit_on_first_harvest"
47+
48+let kBasePeriod = "base_period"
49+
50+let kPeriodLength = "period_length"
51+
52+let kStartHeight = "start_height"
53+
54+let kDAppThreshold = "dApp_threshold"
55+
56+let kAdminPubKey1 = "admin_pub_1"
57+
58+let kAdminPubKey2 = "admin_pub_2"
59+
60+let kAdminPubKey3 = "admin_pub_3"
61+
62+let kAdminInvokePubKey = "admin_invoke_pub"
63+
64+let kMoneyBoxAddress = "money_box_address"
65+
66+let kGovAddress = "governance_address"
67+
68+let kFarmingAddress = "farming_address"
69+
70+let kVotingAddress = "voting_address"
71+
72+let kUSDNAssetId = "usdn_asset_id"
73+
74+let kStakingAssets = "staking_assets"
75+
76+let oracle = Address(base58'3MvVBtsXroQpy1tsPw21TU2ET9A8WfmrNjz')
77+
78+func getBase58FromOracle (key) = match getString(oracle, key) {
79+ case string: String =>
80+ fromBase58String(string)
81+ case nothing =>
82+ throw((key + "is empty"))
83+}
84+
85+
86+let adminPubKey1 = getBase58FromOracle(kAdminPubKey1)
87+
88+let adminPubKey2 = getBase58FromOracle(kAdminPubKey2)
89+
90+let adminPubKey3 = getBase58FromOracle(kAdminPubKey3)
91+
92+let adminPubKeyInvoke = getBase58FromOracle(kAdminInvokePubKey)
93+
94+let moneyBoxAddress = Address(getBase58FromOracle(kMoneyBoxAddress))
95+
96+let govAddress = Address(getBase58FromOracle(kGovAddress))
97+
98+let stakingUSDNAddress = Address(getBase58FromOracle(kUSDNAddress))
99+
100+let votingAddress = Address(getBase58FromOracle(kVotingAddress))
101+
102+let farmingAddress = Address(getBase58FromOracle(kFarmingAddress))
103+
104+let USDN = getBase58FromOracle(kUSDNAssetId)
105+
106+let stakingAssets = getStringValue(oracle, kStakingAssets)
107+
108+let basePeriod = valueOrErrorMessage(getInteger(votingAddress, kBasePeriod), "Empty kBasePeriod")
109+
110+let startHeight = valueOrErrorMessage(getInteger(votingAddress, kStartHeight), "Empty kStartHeight")
111+
112+let periodLength = valueOrErrorMessage(getInteger(votingAddress, kPeriodLength), "Empty kPeriodLength")
113+
114+let firstHarvestEndPeriod = ((basePeriod + ((height - startHeight) / periodLength)) + 3)
115+
116+let active = getBooleanValue(this, kActive)
117+
118+let activeGlob = valueOrElse(getBoolean(oracle, kActiveGlob), true)
119+
120+let strAssetIdA = getStringValue(this, kAssetIdA)
121+
122+let strAssetIdB = getStringValue(this, kAssetIdB)
123+
124+let assetIdA = if ((strAssetIdA == "WAVES"))
125+ then unit
126+ else fromBase58String(strAssetIdA)
127+
128+let assetIdB = if ((strAssetIdB == "WAVES"))
129+ then unit
130+ else fromBase58String(strAssetIdB)
131+
132+let assetNameA = match assetIdA {
133+ case id: ByteVector =>
134+ value(assetInfo(id)).name
135+ case waves: Unit =>
136+ "WAVES"
137+ case _ =>
138+ throw("Match error")
139+}
140+
141+let assetNameB = match assetIdB {
142+ case id: ByteVector =>
143+ value(assetInfo(id)).name
144+ case waves: Unit =>
145+ "WAVES"
146+ case _ =>
147+ throw("Match error")
148+}
149+
150+let balanceA = getIntegerValue(this, kBalanceA)
151+
152+let balanceB = getIntegerValue(this, kBalanceB)
153+
154+let shareAssetId = fromBase58String(getStringValue(this, kShareAssetId))
155+
156+let shareAssetSupply = getIntegerValue(this, kShareAssetSupply)
157+
158+let invariant = getIntegerValue(this, kInvariant)
159+
160+let fee = getIntegerValue(this, kFee)
161+
162+let feeGovernance = fraction(fee, 40, 100)
163+
164+let feeScale6 = 1000000
165+
166+let scale3 = 1000
167+
168+let scale8 = 100000000
169+
170+let scale16 = 10000000000000000
171+
172+let digits8 = 8
173+
174+let exchangeRatioLimitMin = 60000000
175+
176+let exchangeRatioLimitMax = 140000000
177+
178+let alpha = 50
179+
180+let alphaDigits = 2
181+
182+let beta = 4600000000000000
183+
184+func accountBalance (assetId) = match assetId {
185+ case id: ByteVector =>
186+ assetBalance(this, id)
187+ case waves: Unit =>
188+ wavesBalance(this).available
189+ case _ =>
190+ throw("Match error")
191+}
192+
193+
194+func stakedAmount (assetId) = {
195+ let stakedAmountCalculated = match assetId {
196+ case aId: ByteVector =>
197+ if ((aId == USDN))
198+ then getInteger(stakingUSDNAddress, ((("rpd_balance_" + toBase58String(aId)) + "_") + toString(this)))
199+ else 0
200+ case _: Unit =>
201+ 0
202+ case _ =>
203+ throw("Match error")
204+ }
205+ match stakedAmountCalculated {
206+ case i: Int =>
207+ i
208+ case _ =>
209+ 0
210+ }
211+ }
212+
213+
214+let stakedAmountA = stakedAmount(assetIdA)
215+
216+let stakedAmountB = stakedAmount(assetIdB)
217+
218+let availableBalanceA = (balanceA - stakedAmountA)
219+
220+let availableBalanceB = (balanceB - stakedAmountB)
221+
222+let accountBalanceWithStakedA = (accountBalance(assetIdA) + stakedAmountA)
223+
224+let accountBalanceWithStakedB = (accountBalance(assetIdB) + stakedAmountB)
225+
226+let hasEnoughBalance = if ((accountBalanceWithStakedA >= balanceA))
227+ then (accountBalanceWithStakedB >= balanceB)
228+ else false
229+
230+func skewness (x,y) = ((fraction(scale16, x, y) + fraction(scale16, y, x)) / 2)
231+
232+
233+func invariantCalc (x,y) = {
234+ let sk = skewness(x, y)
235+ (fraction((x + y), scale16, pow(sk, digits8, alpha, alphaDigits, digits8, CEILING)) + (2 * fraction(toInt(pow(fraction(toBigInt(x), toBigInt(y), toBigInt(scale8)), 0, toBigInt(5), 1, (digits8 / 2), DOWN)), pow((sk - beta), digits8, alpha, alphaDigits, digits8, DOWN), scale8)))
236+ }
237+
238+
239+func calculateSendAmount (amountToSendEstimated,minTokenReceiveAmount,tokenReceiveAmount,tokenId,balcA,balcB,invCur) = {
240+ let worstAllowedNewInvariantRatio = (scale16 - ((scale16 * 1) / 10000000))
241+ let deltaBetweenMaxAndMinSendValue = (amountToSendEstimated - minTokenReceiveAmount)
242+ let x = (balcA + tokenReceiveAmount)
243+ let y = (balcB + tokenReceiveAmount)
244+ func getStepAmount (acc,step) = if ((acc._1 == -1))
245+ then {
246+ let amountToSend = (amountToSendEstimated - (((step * deltaBetweenMaxAndMinSendValue) / 3) / scale3))
247+ let stepInvariant = if ((tokenId == assetIdA))
248+ then invariantCalc(x, (balcB - amountToSend))
249+ else invariantCalc((balcA - amountToSend), y)
250+ if ((stepInvariant > invCur))
251+ then $Tuple2(amountToSend, stepInvariant)
252+ else $Tuple2(-1, 0)
253+ }
254+ else acc
255+
256+ let amountToSendMin = getStepAmount($Tuple2(-1, 0), 3000)
257+ if ((0 > amountToSendMin._1))
258+ then throw("Price is worse than minReceived")
259+ else {
260+ let invEstimated = if ((tokenId == assetIdA))
261+ then invariantCalc(x, (balcB - amountToSendEstimated))
262+ else if ((tokenId == assetIdB))
263+ then invariantCalc((balcA - amountToSendEstimated), y)
264+ else throw("Wrong asset in payment")
265+ if ((invCur > invEstimated))
266+ then if ((worstAllowedNewInvariantRatio >= fraction(scale16, invCur, invEstimated)))
267+ then throw("The requested price is too not profitable for user")
268+ else {
269+ let a = {
270+ let $l = [25, 200, 500]
271+ let $s = size($l)
272+ let $acc0 = $Tuple2(-1, 0)
273+ func $f0_1 ($a,$i) = if (($i >= $s))
274+ then $a
275+ else getStepAmount($a, $l[$i])
276+
277+ func $f0_2 ($a,$i) = if (($i >= $s))
278+ then $a
279+ else throw("List size exceeds 3")
280+
281+ $f0_2($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3)
282+ }
283+ if ((0 > a._1))
284+ then amountToSendMin._1
285+ else a._1
286+ }
287+ else {
288+ let a = {
289+ let $l = [-500, -200, -25]
290+ let $s = size($l)
291+ let $acc0 = $Tuple2(-1, 0)
292+ func $f0_1 ($a,$i) = if (($i >= $s))
293+ then $a
294+ else getStepAmount($a, $l[$i])
295+
296+ func $f0_2 ($a,$i) = if (($i >= $s))
297+ then $a
298+ else throw("List size exceeds 3")
299+
300+ $f0_2($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3)
301+ }
302+ let tupleSendBetter = if ((0 > a._1))
303+ then $Tuple2(amountToSendEstimated, invEstimated)
304+ else a
305+ if ((worstAllowedNewInvariantRatio >= fraction(scale16, invCur, tupleSendBetter._2)))
306+ then throw("The requested price is too not profitable for user")
307+ else tupleSendBetter._1
308+ }
309+ }
310+ }
311+
312+
313+func getAssetInfo (assetId) = match assetId {
314+ case id: ByteVector =>
315+ let stringId = toBase58String(id)
316+ let info = valueOrErrorMessage(assetInfo(id), (("Asset " + stringId) + " doesn't exist"))
317+ $Tuple3(stringId, info.name, info.decimals)
318+ case waves: Unit =>
319+ $Tuple3("WAVES", "WAVES", 8)
320+ case _ =>
321+ throw("Match error")
322+}
323+
324+
325+func suspend (cause) = [BooleanEntry(kActive, false), StringEntry(kCause, cause)]
326+
327+
328+func throwIsActive () = throw("DApp is already active")
329+
330+
331+func isActive () = if (if (active)
332+ then activeGlob
333+ else false)
334+ then unit
335+ else throw("DApp is inactive at this moment")
336+
337+
338+func isAdminCall (i) = if (containsElement([adminPubKey1, adminPubKey2, adminPubKey3], i.callerPublicKey))
339+ then unit
340+ else throw("Only admin can call this function")
341+
342+
343+func isSelfCall (i) = if ((this == i.caller))
344+ then unit
345+ else throw("Only contract itself can call this function")
346+
347+
348+func throwAssets () = throw(((("Incorrect assets attached. Expected: " + strAssetIdA) + " and ") + strAssetIdB))
349+
350+
351+func throwOnePayment () = throw("One attached payment expected")
352+
353+
354+func suspendSuspicious () = suspend(((((((((((((((("Suspicious state. Actual balances: " + toString(balanceA)) + " ") + assetNameA) + ", ") + toString(balanceB)) + " ") + assetNameB) + ". State: ") + toString(accountBalance(assetIdA))) + " ") + assetNameA) + ", ") + toString(accountBalance(assetIdB))) + " ") + assetNameB))
355+
356+
357+func calcStakingFuncAndAddres (stake,assetId) = if (stake)
358+ then $Tuple2("lockNeutrino", stakingUSDNAddress)
359+ else $Tuple2("unlockNeutrino", stakingUSDNAddress)
360+
361+
362+func calcStakingParams (stake,amount,assetId) = if (stake)
363+ then {
364+ let $t01020710273 = calcStakingFuncAndAddres(stake, assetId)
365+ let call = $t01020710273._1
366+ let stakingAddr = $t01020710273._2
367+ $Tuple4(call, stakingAddr, nil, [AttachedPayment(assetId, amount)])
368+ }
369+ else {
370+ let $t01035910425 = calcStakingFuncAndAddres(stake, assetId)
371+ let call = $t01035910425._1
372+ let stakingAddr = $t01035910425._2
373+ $Tuple4(call, stakingAddr, [amount, toBase58String(assetId)], nil)
374+ }
375+
376+
377+func calculateFeeDiscount (userAddr) = {
378+ let swopAmount = valueOrElse(getInteger(govAddress, (toString(userAddr) + kUserSwopInGov)), 0)
379+ let gSwopAmount = valueOrElse(getInteger(govAddress, (toString(userAddr) + kUserGSwopInGov)), swopAmount)
380+ let discountValues = split(getStringValue(oracle, kDiscountValues), ",")
381+ let discounts = split(getStringValue(oracle, kDiscounts), ",")
382+ if (if ((gSwopAmount >= parseIntValue(discountValues[0])))
383+ then (parseIntValue(discountValues[1]) > gSwopAmount)
384+ else false)
385+ then (feeScale6 - parseIntValue(discounts[0]))
386+ else if (if ((gSwopAmount >= parseIntValue(discountValues[1])))
387+ then (parseIntValue(discountValues[2]) > gSwopAmount)
388+ else false)
389+ then (feeScale6 - parseIntValue(discounts[1]))
390+ else if (if ((gSwopAmount >= parseIntValue(discountValues[2])))
391+ then (parseIntValue(discountValues[3]) > gSwopAmount)
392+ else false)
393+ then (feeScale6 - parseIntValue(discounts[2]))
394+ else if (if ((gSwopAmount >= parseIntValue(discountValues[3])))
395+ then (parseIntValue(discountValues[4]) > gSwopAmount)
396+ else false)
397+ then (feeScale6 - parseIntValue(discounts[3]))
398+ else if ((gSwopAmount >= parseIntValue(discountValues[4])))
399+ then (feeScale6 - parseIntValue(discounts[4]))
400+ else feeScale6
401+ }
402+
403+
404+func checkDAppThreshold (newBalanceA,newBalanceB,pmtAssetId) = {
405+ let dAppThreshold = getIntegerValue(this, kDAppThreshold)
406+ let ratio = if (if ((pmtAssetId == assetIdA))
407+ then (newBalanceA > newBalanceB)
408+ else false)
409+ then fraction(newBalanceA, 1, newBalanceB, CEILING)
410+ else if (if ((pmtAssetId == assetIdB))
411+ then (newBalanceB > newBalanceA)
412+ else false)
413+ then fraction(newBalanceB, 1, newBalanceA, CEILING)
414+ else 0
415+ if ((ratio > dAppThreshold))
416+ then {
417+ let $t01217012278 = if ((pmtAssetId == assetIdA))
418+ then $Tuple2(assetNameB, assetNameA)
419+ else $Tuple2(assetNameA, assetNameB)
420+ let token1 = $t01217012278._1
421+ let token2 = $t01217012278._2
422+ throw((((("Buying " + token1) + " is temporarily unavailable due to the ") + token2) + " depeg"))
423+ }
424+ else true
425+ }
426+
427+
428+func replenishWithTwoTokensCalc (i,stakeFarming,lockType) = {
429+ let pmtAssetIdA = i.payments[0].assetId
430+ let pmtAssetIdB = i.payments[1].assetId
431+ let ratioShareTokensInA = fraction(scale8, i.payments[0].amount, balanceA)
432+ let ratioShareTokensInB = fraction(scale8, i.payments[1].amount, balanceB)
433+ let $t01273812815 = getAssetInfo(pmtAssetIdA)
434+ let pmtStrAssetIdA = $t01273812815._1
435+ let pmtAssetNameA = $t01273812815._2
436+ let pmtDecimalsA = $t01273812815._3
437+ let $t01282012937 = getAssetInfo(pmtAssetIdB)
438+ let pmtStrAssetIdB = $t01282012937._1
439+ let pmtAssetNameB = $t01282012937._2
440+ let pmtDecimalsB = $t01282012937._3
441+ let $t01294213446 = if ((ratioShareTokensInB > ratioShareTokensInA))
442+ then {
443+ let pmt = fraction(balanceB, ratioShareTokensInA, scale8, CEILING)
444+ $Tuple5(i.payments[0].amount, pmt, (i.payments[1].amount - pmt), pmtAssetIdB, ratioShareTokensInA)
445+ }
446+ else {
447+ let pmt = fraction(balanceA, ratioShareTokensInB, scale8, CEILING)
448+ $Tuple5(pmt, i.payments[1].amount, (i.payments[0].amount - pmt), pmtAssetIdA, ratioShareTokensInB)
449+ }
450+ let pmtAmountA = $t01294213446._1
451+ let pmtAmountB = $t01294213446._2
452+ let change = $t01294213446._3
453+ let changeAssetId = $t01294213446._4
454+ let shareTokenRatio = $t01294213446._5
455+ let shareTokenToPayAmount = fraction(shareTokenRatio, shareAssetSupply, scale8)
456+ if (if ((size(i.payments) != 2))
457+ then (size(i.payments) != 3)
458+ else false)
459+ then throw("Two or three payments expected")
460+ else if (if ((pmtAssetIdA != assetIdA))
461+ then true
462+ else (pmtAssetIdB != assetIdB))
463+ then throwAssets()
464+ else if ((shareTokenToPayAmount == 0))
465+ then throw("Too small amount to replenish")
466+ else if ((0 > change))
467+ then throw("Change < 0")
468+ else if (!(hasEnoughBalance))
469+ then ([ScriptTransfer(i.caller, pmtAmountA, pmtAssetIdA), ScriptTransfer(i.caller, pmtAmountB, pmtAssetIdB)] ++ suspendSuspicious())
470+ else {
471+ let stake1 = if (contains(stakingAssets, pmtStrAssetIdA))
472+ then invoke(this, "stakeUnstake", [true, pmtAmountA, pmtStrAssetIdA], nil)
473+ else 0
474+ if ((stake1 == stake1))
475+ then {
476+ let stake2 = if (contains(stakingAssets, pmtStrAssetIdB))
477+ then invoke(this, "stakeUnstake", [true, pmtAmountB, pmtStrAssetIdB], nil)
478+ else 0
479+ if ((stake2 == stake2))
480+ then {
481+ let scriptActions = [IntegerEntry(kBalanceA, (balanceA + pmtAmountA)), IntegerEntry(kBalanceB, (balanceB + pmtAmountB)), IntegerEntry(kShareAssetSupply, (shareAssetSupply + shareTokenToPayAmount)), IntegerEntry(kInvariant, invariantCalc((balanceA + pmtAmountA), (balanceB + pmtAmountB))), ScriptTransfer(i.caller, change, changeAssetId)]
482+ if (stakeFarming)
483+ then {
484+ let stPayments = ([AttachedPayment(shareAssetId, shareTokenToPayAmount)] ++ (if ((size(i.payments) == 3))
485+ then [AttachedPayment(if ((i.payments[2].assetId == base58''))
486+ then unit
487+ else i.payments[2].assetId, i.payments[2].amount)]
488+ else nil))
489+ let re = invoke(this, "reissueShare", [shareTokenToPayAmount], nil)
490+ if ((re == re))
491+ then {
492+ let s = invoke(farmingAddress, "lockShareTokensFromPool", [i.caller.bytes, toString(this), lockType], stPayments)
493+ if ((s == s))
494+ then scriptActions
495+ else throw("Strict value is not equal to itself.")
496+ }
497+ else throw("Strict value is not equal to itself.")
498+ }
499+ else (scriptActions ++ [Reissue(shareAssetId, shareTokenToPayAmount, true), ScriptTransfer(i.caller, shareTokenToPayAmount, shareAssetId)])
500+ }
501+ else throw("Strict value is not equal to itself.")
502+ }
503+ else throw("Strict value is not equal to itself.")
504+ }
505+ }
506+
507+
508+func replenishWithOneTokenCalc (i,virtualSwapTokenPay,virtualSwapTokenGet,stakeFarming,lockType) = {
509+ let $t01583615911 = $Tuple2(i.payments[0].amount, i.payments[0].assetId)
510+ let pmtAmount = $t01583615911._1
511+ let pmtAssetId = $t01583615911._2
512+ let $t01591615989 = getAssetInfo(pmtAssetId)
513+ let pmtStrAssetId = $t01591615989._1
514+ let pmtAssetName = $t01591615989._2
515+ let pmtDecimals = $t01591615989._3
516+ let pmtMinThreshold = 5000000
517+ let thresholdValueForMinTolerance = 50000000
518+ let tolerance = if ((thresholdValueForMinTolerance > pmtAmount))
519+ then 100000
520+ else 1
521+ let slippageValueMinForReplenish = (scale8 - ((scale8 * tolerance) / 10000000))
522+ let slippageValueMaxForReplenish = (scale8 + ((scale8 * tolerance) / 10000000))
523+ let slippageValueMinForSwap = (scale8 - ((scale8 * 1) / 10000000))
524+ if ((pmtMinThreshold > pmtAmount))
525+ then throw((((("Payment amount " + toString(pmtAmount)) + " does not exceed the minimum amount of ") + toString(pmtMinThreshold)) + " tokens"))
526+ else if (if ((size(i.payments) != 1))
527+ then (size(i.payments) != 2)
528+ else false)
529+ then throw("One or two payments expected")
530+ else if (!(hasEnoughBalance))
531+ then ([ScriptTransfer(i.caller, pmtAmount, pmtAssetId)] ++ suspendSuspicious())
532+ else if (if ((pmtAssetId != assetIdA))
533+ then (pmtAssetId != assetIdB)
534+ else false)
535+ then throwAssets()
536+ else {
537+ let $t01699117633 = if ((pmtAssetId == assetIdA))
538+ then $Tuple6((pmtAmount - virtualSwapTokenPay), virtualSwapTokenGet, (balanceA + virtualSwapTokenPay), (balanceB - virtualSwapTokenGet), (balanceA + pmtAmount), balanceB)
539+ else $Tuple6(virtualSwapTokenGet, (pmtAmount - virtualSwapTokenPay), (balanceA - virtualSwapTokenGet), (balanceB + virtualSwapTokenPay), balanceA, (balanceB + pmtAmount))
540+ let virtualReplenishA = $t01699117633._1
541+ let virtualReplenishB = $t01699117633._2
542+ let balanceAfterSwapA = $t01699117633._3
543+ let balanceAfterSwapB = $t01699117633._4
544+ let newBalanceA = $t01699117633._5
545+ let newBalanceB = $t01699117633._6
546+ let invariantNew = invariantCalc(balanceAfterSwapA, balanceAfterSwapB)
547+ let ratioVirtualBalanceToVirtualReplenish = (fraction(scale16, balanceAfterSwapA, balanceAfterSwapB) / fraction(scale8, virtualReplenishA, virtualReplenishB))
548+ if (if ((slippageValueMinForSwap >= fraction(scale8, invariant, invariantNew)))
549+ then true
550+ else (invariant > invariantNew))
551+ then throw("Incorrect virtualSwapTokenPay or virtualSwapTokenGet value")
552+ else if (if ((slippageValueMinForReplenish > ratioVirtualBalanceToVirtualReplenish))
553+ then true
554+ else (ratioVirtualBalanceToVirtualReplenish > slippageValueMaxForReplenish))
555+ then throw("Swap with virtualSwapTokenPay and virtualSwapTokenGet is possible, but ratio after virtual swap is incorrect")
556+ else if (!(checkDAppThreshold(newBalanceA, newBalanceB, pmtAssetId)))
557+ then throw()
558+ else {
559+ let ratioShareTokensInA = fraction(virtualReplenishA, scale8, balanceAfterSwapA)
560+ let ratioShareTokensInB = fraction(virtualReplenishB, scale8, balanceAfterSwapB)
561+ let shareTokenToPayAmount = fraction(min([ratioShareTokensInA, ratioShareTokensInB]), shareAssetSupply, scale8)
562+ let shareTokenToPayAmountAfterFee = fraction(shareTokenToPayAmount, (feeScale6 - (fee / 2)), feeScale6)
563+ let shareTokenGovernanceReward = fraction(shareTokenToPayAmount, (feeGovernance / 2), feeScale6)
564+ let governanceRewardTokenA = fraction(shareTokenGovernanceReward, balanceA, shareAssetSupply)
565+ let governanceRewardTokenB = fraction(shareTokenGovernanceReward, balanceB, shareAssetSupply)
566+ let $t01938419667 = if ((pmtStrAssetId == strAssetIdA))
567+ then $Tuple3((pmtAmount - governanceRewardTokenA), governanceRewardTokenB, strAssetIdB)
568+ else $Tuple3((pmtAmount - governanceRewardTokenB), governanceRewardTokenA, strAssetIdA)
569+ let stakeAmount = $t01938419667._1
570+ let unstakeAmount = $t01938419667._2
571+ let unstakeAsset = $t01938419667._3
572+ let stake1 = if (contains(stakingAssets, pmtStrAssetId))
573+ then invoke(this, "stakeUnstake", [true, stakeAmount, pmtStrAssetId], nil)
574+ else 0
575+ if ((stake1 == stake1))
576+ then {
577+ let stake2 = if (contains(stakingAssets, unstakeAsset))
578+ then invoke(this, "stakeUnstake", [false, unstakeAmount, unstakeAsset], nil)
579+ else 0
580+ if ((stake2 == stake2))
581+ then {
582+ let scriptActions = [IntegerEntry(kBalanceA, (newBalanceA - governanceRewardTokenA)), IntegerEntry(kBalanceB, (newBalanceB - governanceRewardTokenB)), IntegerEntry(kShareAssetSupply, (shareAssetSupply + shareTokenToPayAmountAfterFee)), IntegerEntry(kInvariant, invariantCalc((newBalanceA - governanceRewardTokenA), (newBalanceB - governanceRewardTokenB))), ScriptTransfer(moneyBoxAddress, governanceRewardTokenA, assetIdA), ScriptTransfer(moneyBoxAddress, governanceRewardTokenB, assetIdB)]
583+ if (stakeFarming)
584+ then {
585+ let stPayments = ([AttachedPayment(shareAssetId, shareTokenToPayAmountAfterFee)] ++ (if ((size(i.payments) == 2))
586+ then [AttachedPayment(if ((i.payments[1].assetId == base58''))
587+ then unit
588+ else i.payments[1].assetId, i.payments[1].amount)]
589+ else nil))
590+ let re = invoke(this, "reissueShare", [shareTokenToPayAmountAfterFee], nil)
591+ if ((re == re))
592+ then {
593+ let s = invoke(farmingAddress, "lockShareTokensFromPool", [i.caller.bytes, toString(this), lockType], stPayments)
594+ if ((s == s))
595+ then scriptActions
596+ else throw("Strict value is not equal to itself.")
597+ }
598+ else throw("Strict value is not equal to itself.")
599+ }
600+ else (scriptActions ++ [Reissue(shareAssetId, shareTokenToPayAmountAfterFee, true), ScriptTransfer(i.caller, shareTokenToPayAmountAfterFee, shareAssetId)])
601+ }
602+ else throw("Strict value is not equal to itself.")
603+ }
604+ else throw("Strict value is not equal to itself.")
605+ }
606+ }
607+ }
608+
609+
610+func withdrawCalc (i,unlockAmount) = {
611+ let $t02151621851 = if ((size(i.payments) == 1))
612+ then if ((i.payments[0].assetId != shareAssetId))
613+ then throw(("Incorrect asset attached. Expected: " + toBase58String(shareAssetId)))
614+ else $Tuple2(i.payments[0].amount, i.payments[0].assetId)
615+ else $Tuple2(0, shareAssetId)
616+ let pmtAmount = $t02151621851._1
617+ let pmtAssetId = $t02151621851._2
618+ if (!(hasEnoughBalance))
619+ then ([ScriptTransfer(i.caller, pmtAmount, pmtAssetId)] ++ suspendSuspicious())
620+ else {
621+ let unlock = if ((unlockAmount > 0))
622+ then invoke(farmingAddress, "withdrawShareTokensFromPool", [i.caller.bytes, toString(this), unlockAmount], nil)
623+ else 0
624+ if ((unlock == unlock))
625+ then {
626+ let withdrawAmount = (pmtAmount + unlockAmount)
627+ let amountToPayA = fraction(withdrawAmount, balanceA, shareAssetSupply)
628+ let amountToPayB = fraction(withdrawAmount, balanceB, shareAssetSupply)
629+ let invariantCalculated = invariantCalc((balanceA - amountToPayA), (balanceB - amountToPayB))
630+ let stake1 = if (contains(stakingAssets, strAssetIdA))
631+ then invoke(this, "stakeUnstake", [false, amountToPayA, strAssetIdA], nil)
632+ else 0
633+ if ((stake1 == stake1))
634+ then {
635+ let stake2 = if (contains(stakingAssets, strAssetIdB))
636+ then invoke(this, "stakeUnstake", [false, amountToPayB, strAssetIdB], nil)
637+ else 0
638+ if ((stake2 == stake2))
639+ then [IntegerEntry(kBalanceA, (balanceA - amountToPayA)), IntegerEntry(kBalanceB, (balanceB - amountToPayB)), IntegerEntry(kShareAssetSupply, (shareAssetSupply - withdrawAmount)), IntegerEntry(kInvariant, invariantCalculated), Burn(shareAssetId, withdrawAmount), ScriptTransfer(i.caller, amountToPayA, assetIdA), ScriptTransfer(i.caller, amountToPayB, assetIdB)]
640+ else throw("Strict value is not equal to itself.")
641+ }
642+ else throw("Strict value is not equal to itself.")
643+ }
644+ else throw("Strict value is not equal to itself.")
645+ }
646+ }
647+
648+
649+@Callable(i)
650+func init (firstHarvest) = {
651+ let $t02340323480 = $Tuple2(i.payments[0].amount, i.payments[0].assetId)
652+ let pmtAmountA = $t02340323480._1
653+ let pmtAssetIdA = $t02340323480._2
654+ let $t02348523562 = $Tuple2(i.payments[1].amount, i.payments[1].assetId)
655+ let pmtAmountB = $t02348523562._1
656+ let pmtAssetIdB = $t02348523562._2
657+ let $t02356723644 = getAssetInfo(pmtAssetIdA)
658+ let pmtStrAssetIdA = $t02356723644._1
659+ let pmtAssetNameA = $t02356723644._2
660+ let pmtDecimalsA = $t02356723644._3
661+ let $t02364923726 = getAssetInfo(pmtAssetIdB)
662+ let pmtStrAssetIdB = $t02364923726._1
663+ let pmtAssetNameB = $t02364923726._2
664+ let pmtDecimalsB = $t02364923726._3
665+ if (isDefined(getBoolean(this, kActive)))
666+ then throwIsActive()
667+ else if ((pmtAssetIdA == pmtAssetIdB))
668+ then throw("Assets must be different")
669+ else {
670+ let shareName = ((("s" + take(pmtAssetNameA, 7)) + "_") + take(pmtAssetNameB, 7))
671+ let shareDescription = ((((("ShareToken of SwopFi protocol for " + pmtAssetNameA) + " and ") + pmtAssetNameB) + " at address ") + toString(this))
672+ let shareDecimals = ((pmtDecimalsA + pmtDecimalsB) / 2)
673+ let shareInitialSupply = fraction(pow(pmtAmountA, pmtDecimalsA, 5, 1, pmtDecimalsA, DOWN), pow(pmtAmountB, pmtDecimalsB, 5, 1, pmtDecimalsB, DOWN), pow(10, 0, shareDecimals, 0, 0, DOWN))
674+ let shareIssue = Issue(shareName, shareDescription, shareInitialSupply, shareDecimals, true)
675+ let shareIssueId = calculateAssetId(shareIssue)
676+ let invariantCalculated = invariantCalc(pmtAmountA, pmtAmountB)
677+ let stake1 = if (contains(stakingAssets, pmtStrAssetIdA))
678+ then invoke(this, "stakeUnstake", [true, pmtAmountA, pmtStrAssetIdA], nil)
679+ else 0
680+ if ((stake1 == stake1))
681+ then {
682+ let stake2 = if (contains(stakingAssets, pmtStrAssetIdB))
683+ then invoke(this, "stakeUnstake", [true, pmtAmountB, pmtStrAssetIdB], nil)
684+ else 0
685+ if ((stake2 == stake2))
686+ then {
687+ let baseEntry = [StringEntry(kVersion, version), BooleanEntry(kActive, true), StringEntry(kAssetIdA, pmtStrAssetIdA), StringEntry(kAssetIdB, pmtStrAssetIdB), IntegerEntry(kBalanceA, pmtAmountA), IntegerEntry(kBalanceB, pmtAmountB), IntegerEntry(kInvariant, invariantCalculated), IntegerEntry(kFee, getIntegerValue(oracle, "base_fee_flat")), IntegerEntry(kDAppThreshold, 3), shareIssue, StringEntry(kShareAssetId, toBase58String(shareIssueId)), IntegerEntry(kShareAssetSupply, shareInitialSupply), ScriptTransfer(i.caller, shareInitialSupply, shareIssueId)]
688+ if (firstHarvest)
689+ then (baseEntry ++ [BooleanEntry(kFirstHarvest, firstHarvest), IntegerEntry(kFirstHarvestHeight, (startHeight + (firstHarvestEndPeriod * periodLength)))])
690+ else baseEntry
691+ }
692+ else throw("Strict value is not equal to itself.")
693+ }
694+ else throw("Strict value is not equal to itself.")
695+ }
696+ }
697+
698+
699+
700+@Callable(i)
701+func replenishWithTwoTokensV2 (stakeFarming,lockType) = valueOrElse(isActive(), replenishWithTwoTokensCalc(i, stakeFarming, lockType))
702+
703+
704+
705+@Callable(i)
706+func replenishWithOneTokenV2 (virtualSwapTokenPay,virtualSwapTokenGet,stakeFarming,lockType) = valueOrElse(isActive(), replenishWithOneTokenCalc(i, virtualSwapTokenPay, virtualSwapTokenGet, stakeFarming, lockType))
707+
708+
709+
710+@Callable(i)
711+func withdrawV2 (unlockAmount) = valueOrElse(isActive(), withdrawCalc(i, unlockAmount))
712+
713+
714+
715+@Callable(i)
716+func withdrawOneToken (unlockAmount,withdrawAsset,estimatedAmountToReceive,minAmountToReceive) = valueOrElse(isActive(), {
717+ let $t02714127476 = if ((size(i.payments) == 1))
718+ then if ((i.payments[0].assetId != shareAssetId))
719+ then throw(("Incorrect asset attached. Expected: " + toBase58String(shareAssetId)))
720+ else $Tuple2(i.payments[0].amount, i.payments[0].assetId)
721+ else $Tuple2(0, shareAssetId)
722+ let pmtAmount = $t02714127476._1
723+ let pmtAssetId = $t02714127476._2
724+ let withdrawAmount = (pmtAmount + unlockAmount)
725+ if (if ((withdrawAsset != strAssetIdA))
726+ then (withdrawAsset != strAssetIdB)
727+ else false)
728+ then throw("Incorrect withdraw asset")
729+ else if ((0 >= withdrawAmount))
730+ then throw("withdraw amount must be grater than 0")
731+ else if (!(hasEnoughBalance))
732+ then ([ScriptTransfer(i.caller, pmtAmount, pmtAssetId)] ++ suspendSuspicious())
733+ else {
734+ let unlock = if ((unlockAmount > 0))
735+ then invoke(farmingAddress, "withdrawShareTokensFromPool", [i.caller.bytes, toString(this), unlockAmount], nil)
736+ else 0
737+ if ((unlock == unlock))
738+ then {
739+ let amountToPayA = fraction(withdrawAmount, balanceA, shareAssetSupply)
740+ let amountToPayB = fraction(withdrawAmount, balanceB, shareAssetSupply)
741+ let newVirtBalcA = (balanceA - amountToPayA)
742+ let newVirtBalcB = (balanceB - amountToPayB)
743+ let feeDiscount = calculateFeeDiscount(i.originCaller)
744+ let amountExchangedWithFee = if ((withdrawAsset == strAssetIdA))
745+ then calculateSendAmount(estimatedAmountToReceive, minAmountToReceive, amountToPayB, assetIdB, newVirtBalcA, newVirtBalcB, invariantCalc(newVirtBalcA, newVirtBalcB))
746+ else calculateSendAmount(estimatedAmountToReceive, minAmountToReceive, amountToPayA, assetIdA, newVirtBalcA, newVirtBalcB, invariantCalc(newVirtBalcA, newVirtBalcB))
747+ let govReward = fraction(amountExchangedWithFee, fraction(feeGovernance, feeDiscount, feeScale6, CEILING), feeScale6)
748+ let amountExchanged = fraction(amountExchangedWithFee, (feeScale6 - fraction(fee, feeDiscount, feeScale6, CEILING)), feeScale6)
749+ let $t02907929441 = if ((withdrawAsset == strAssetIdA))
750+ then $Tuple4((amountToPayA + amountExchanged), (((balanceA - amountToPayA) - amountExchanged) - govReward), balanceB, assetIdB)
751+ else $Tuple4((amountToPayB + amountExchanged), balanceA, (((balanceB - amountToPayB) - amountExchanged) - govReward), assetIdA)
752+ let amountToPay = $t02907929441._1
753+ let balanceANew = $t02907929441._2
754+ let balanceBNew = $t02907929441._3
755+ let virtAssetId = $t02907929441._4
756+ if (!(checkDAppThreshold(balanceANew, balanceBNew, virtAssetId)))
757+ then throw()
758+ else {
759+ let invariantCalculated = invariantCalc(balanceANew, balanceBNew)
760+ let stake1 = if (contains(stakingAssets, withdrawAsset))
761+ then invoke(this, "stakeUnstake", [false, (amountToPay + govReward), withdrawAsset], nil)
762+ else 0
763+ if ((stake1 == stake1))
764+ then [IntegerEntry(kBalanceA, balanceANew), IntegerEntry(kBalanceB, balanceBNew), IntegerEntry(kShareAssetSupply, (shareAssetSupply - withdrawAmount)), IntegerEntry(kInvariant, invariantCalculated), Burn(shareAssetId, withdrawAmount), ScriptTransfer(i.caller, amountToPay, fromBase58String(withdrawAsset)), ScriptTransfer(moneyBoxAddress, govReward, fromBase58String(withdrawAsset))]
765+ else throw("Strict value is not equal to itself.")
766+ }
767+ }
768+ else throw("Strict value is not equal to itself.")
769+ }
770+ })
771+
772+
773+
774+@Callable(i)
775+func exchange (estimatedAmountToReceive,minAmountToReceive) = valueOrElse(isActive(), {
776+ let $t03040430479 = $Tuple2(i.payments[0].amount, i.payments[0].assetId)
777+ let pmtAmount = $t03040430479._1
778+ let pmtAssetId = $t03040430479._2
779+ if ((0 >= estimatedAmountToReceive))
780+ then throw(("Estimated amount must be positive. Actual: " + toString(estimatedAmountToReceive)))
781+ else if ((minAmountToReceive > estimatedAmountToReceive))
782+ then throw("Minimal amount can't be greater than estimated.")
783+ else if ((size(i.payments) != 1))
784+ then throwOnePayment()
785+ else if (!(hasEnoughBalance))
786+ then ([ScriptTransfer(i.caller, pmtAmount, pmtAssetId)] ++ suspendSuspicious())
787+ else if (if ((pmtAssetId != assetIdA))
788+ then (pmtAssetId != assetIdB)
789+ else false)
790+ then throwAssets()
791+ else if ((10000000 > pmtAmount))
792+ then throw("Only swap of 10.000000 or more tokens is allowed")
793+ else if (if ((exchangeRatioLimitMin > fraction(scale8, minAmountToReceive, pmtAmount)))
794+ then true
795+ else (fraction(scale8, estimatedAmountToReceive, pmtAmount) > exchangeRatioLimitMax))
796+ then throw("Incorrect args and pmt ratio")
797+ else {
798+ let sendAssetId = if ((pmtAssetId == assetIdA))
799+ then assetIdB
800+ else assetIdA
801+ let amount = calculateSendAmount(estimatedAmountToReceive, minAmountToReceive, pmtAmount, pmtAssetId, balanceA, balanceB, invariant)
802+ let feeDiscount = calculateFeeDiscount(i.originCaller)
803+ let governanceReward = fraction(amount, fraction(feeGovernance, feeDiscount, feeScale6, CEILING), feeScale6)
804+ let amountMinusFee = fraction(amount, (feeScale6 - fraction(fee, feeDiscount, feeScale6, CEILING)), feeScale6)
805+ let $t03196332225 = if ((pmtAssetId == assetIdA))
806+ then $Tuple2((balanceA + pmtAmount), ((balanceB - amountMinusFee) - governanceReward))
807+ else $Tuple2(((balanceA - amountMinusFee) - governanceReward), (balanceB + pmtAmount))
808+ let newBalanceA = $t03196332225._1
809+ let newBalanceB = $t03196332225._2
810+ if (!(checkDAppThreshold(newBalanceA, newBalanceB, pmtAssetId)))
811+ then throw()
812+ else {
813+ let $t03232332396 = getAssetInfo(pmtAssetId)
814+ let pmtStrAssetId = $t03232332396._1
815+ let pmtAssetName = $t03232332396._2
816+ let pmtDecimals = $t03232332396._3
817+ let $t03240532482 = getAssetInfo(sendAssetId)
818+ let sendStrAssetId = $t03240532482._1
819+ let sendAssetName = $t03240532482._2
820+ let sendDecimals = $t03240532482._3
821+ let stake1 = if (contains(stakingAssets, pmtStrAssetId))
822+ then invoke(this, "stakeUnstake", [true, pmtAmount, pmtStrAssetId], nil)
823+ else 0
824+ if ((stake1 == stake1))
825+ then {
826+ let stake2 = if (contains(stakingAssets, sendStrAssetId))
827+ then invoke(this, "stakeUnstake", [false, (amountMinusFee + governanceReward), sendStrAssetId], nil)
828+ else 0
829+ if ((stake2 == stake2))
830+ then $Tuple2([IntegerEntry(kBalanceA, newBalanceA), IntegerEntry(kBalanceB, newBalanceB), IntegerEntry(kInvariant, invariantCalc(newBalanceA, newBalanceB)), ScriptTransfer(i.caller, amountMinusFee, sendAssetId), ScriptTransfer(moneyBoxAddress, governanceReward, sendAssetId)], [amountMinusFee, sendAssetId])
831+ else throw("Strict value is not equal to itself.")
832+ }
833+ else throw("Strict value is not equal to itself.")
834+ }
835+ }
836+ })
837+
838+
839+
840+@Callable(msg)
841+func reissueShare (amount) = valueOrElse(isSelfCall(msg), [Reissue(shareAssetId, amount, true)])
842+
843+
844+
845+@Callable(i)
846+func shutdown () = valueOrElse(isAdminCall(i), if (!(active))
847+ then throw(("DApp is already suspended. Cause: " + valueOrElse(getString(this, kCause), "the cause wasn't specified")))
848+ else suspend("Paused by admin"))
849+
850+
851+
852+@Callable(i)
853+func activate () = valueOrElse(isAdminCall(i), if (active)
854+ then throwIsActive()
855+ else [BooleanEntry(kActive, true), DeleteEntry(kCause)])
856+
857+
858+
859+@Callable(i)
860+func takeIntoAccountExtraFunds () = valueOrElse(isActive(), {
861+ let claim = if (if ((assetIdA == USDN))
862+ then true
863+ else (assetIdB == USDN))
864+ then invoke(stakingUSDNAddress, "claimRewards", nil, nil)
865+ else 0
866+ if ((claim == claim))
867+ then {
868+ let amountEnrollA = (accountBalanceWithStakedA - balanceA)
869+ let amountEnrollB = (accountBalanceWithStakedB - balanceB)
870+ let invariantNew = invariantCalc((balanceA + amountEnrollA), (balanceB + amountEnrollB))
871+ if ((i.caller != moneyBoxAddress))
872+ then throw("Only the money box can call this function")
873+ else if (if ((0 > amountEnrollA))
874+ then true
875+ else (0 > amountEnrollB))
876+ then suspend("Enroll amount negative")
877+ else if (if ((amountEnrollA == 0))
878+ then (amountEnrollB == 0)
879+ else false)
880+ then throw("No money to take")
881+ else {
882+ let stake1 = if (if (contains(stakingAssets, strAssetIdA))
883+ then (amountEnrollA > 0)
884+ else false)
885+ then invoke(this, "stakeUnstake", [true, amountEnrollA, strAssetIdA], nil)
886+ else 0
887+ if ((stake1 == stake1))
888+ then {
889+ let stake2 = if (if (contains(stakingAssets, strAssetIdB))
890+ then (amountEnrollB > 0)
891+ else false)
892+ then invoke(this, "stakeUnstake", [true, amountEnrollB, strAssetIdB], nil)
893+ else 0
894+ if ((stake2 == stake2))
895+ then [IntegerEntry(kInvariant, invariantNew), IntegerEntry(kBalanceA, (balanceA + amountEnrollA)), IntegerEntry(kBalanceB, (balanceB + amountEnrollB))]
896+ else throw("Strict value is not equal to itself.")
897+ }
898+ else throw("Strict value is not equal to itself.")
899+ }
900+ }
901+ else throw("Strict value is not equal to itself.")
902+ })
903+
904+
905+
906+@Callable(i)
907+func keepLimitForFirstHarvest (shareLimit) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), [IntegerEntry(kShareLimit, shareLimit)]))
908+
909+
910+
911+@Callable(i)
912+func stakeUnstake (stake,amount,assetIdString) = if ((i.caller != this))
913+ then throw("Only contract itself can invoke this function")
914+ else {
915+ let $t03584535948 = calcStakingParams(stake, amount, fromBase58String(assetIdString))
916+ let call = $t03584535948._1
917+ let addr = $t03584535948._2
918+ let params = $t03584535948._3
919+ let payments = $t03584535948._4
920+ let inv = invoke(addr, call, params, payments)
921+ if ((inv == inv))
922+ then nil
923+ else throw("Strict value is not equal to itself.")
924+ }
925+
926+
927+
928+@Callable(i)
929+func replenishWithTwoTokens () = valueOrElse(isActive(), replenishWithTwoTokensCalc(i, false, 0))
930+
931+
932+
933+@Callable(i)
934+func replenishWithOneToken (virtualSwapTokenPay,virtualSwapTokenGet) = valueOrElse(isActive(), replenishWithOneTokenCalc(i, virtualSwapTokenPay, virtualSwapTokenGet, false, 0))
935+
936+
937+
938+@Callable(i)
939+func withdraw () = valueOrElse(isActive(), withdrawCalc(i, 0))
940+
941+
942+@Verifier(tx)
943+func verify () = {
944+ let multiSignedByAdmins = {
945+ let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1))
946+ then 1
947+ else 0
948+ let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2))
949+ then 1
950+ else 0
951+ let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3))
952+ then 1
953+ else 0
954+ (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2)
955+ }
956+ match tx {
957+ case inv: InvokeScriptTransaction =>
958+ let callTakeIntoAccount = if ((inv.dApp == this))
959+ then (inv.function == "takeIntoAccountExtraFunds")
960+ else false
961+ let signedByAdmin = if (if (if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1))
962+ then true
963+ else sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey2))
964+ then true
965+ else sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey3))
966+ then true
967+ else sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKeyInvoke)
968+ if (if (callTakeIntoAccount)
969+ then signedByAdmin
970+ else false)
971+ then true
972+ else multiSignedByAdmins
973+ case _ =>
974+ multiSignedByAdmins
975+ }
976+ }
977+

github/deemru/w8io/169f3d6 
48.08 ms