tx · JCAi6bvqJrBXAVTH8xk8pWdYvSJekwZAwU5A3CT15iza

3N6o2j6N9vuWruU51gEZ1quncAXCLRksuf5:  -0.09000000 Waves

2024.04.28 23:37 [3083188] smart account 3N6o2j6N9vuWruU51gEZ1quncAXCLRksuf5 > SELF 0.00000000 Waves

{ "type": 13, "id": "JCAi6bvqJrBXAVTH8xk8pWdYvSJekwZAwU5A3CT15iza", "fee": 9000000, "feeAssetId": null, "timestamp": 1714336235988, "version": 2, "chainId": 84, "sender": "3N6o2j6N9vuWruU51gEZ1quncAXCLRksuf5", "senderPublicKey": "CSBog5DyfZ75B1usog9TncmEvV1gdLj4kV8NCbTvNwDx", "proofs": [ "4uHKxLRTFqS1MZBZgUBHhCTC3QwJGZCR4yyp5UT8uaRU56sZJ9TJgJYbh9rrwjXX6tLmJKAnN7ejtJMJfKUUusWy" ], "script": "base64:BgJbCAISCAoGCAgICAgBEgASABIDCgEEEgMKAQQSABIDCgEIEgMKAQESABIDCgEIEgQKAggBEgUKAwgIARIDCgEIEgMKAQESBwoFCAgIAQESABIDCgEIEgUKAwgICFMAB1ZFUlNJT04CDVBaLTEuMi4zIFBST0QACWNvbmZpZ1N0cgkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzAg1jb25maWdBZGRyZXNzAiMzTjJKcFFmcXRoNWVhcGJ4OGJIWjNlZUNYR2tOZmNZRWR5bwAOQ09ORklHX0FERFJFU1MDCQAAAgUJY29uZmlnU3RyAgAFBHRoaXMJAQdBZGRyZXNzAQkA2QQBBQljb25maWdTdHIAFUFzc2V0c1dlaWdodHNEZWNpbWFscwAEAAVTY2FsZQCQTgAGU2NhbGU4AIDC1y8AB1NjYWxlMTYAgICE/qbe4REACEZlZVNjYWxlAJBOABFQb29sVG9rZW5EZWNpbWFscwAIAA5Qb29sVG9rZW5TY2FsZQkAbAYACgAABRFQb29sVG9rZW5EZWNpbWFscwAAAAAFBkhBTEZVUAAQTUlOX1NURVBTX0FNT1VOVAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ5DT05GSUdfQUREUkVTUwIQbWluX3N0ZXBzX2Ftb3VudAABABBNQVhfU1RFUFNfQU1PVU5UCQELdmFsdWVPckVsc2UCCQCaCAIFDkNPTkZJR19BRERSRVNTAhBtYXhfc3RlcHNfYW1vdW50APQDABJNSU5fU1RFUFNfSU5URVJWQUwJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOQ09ORklHX0FERFJFU1MCEm1pbl9zdGVwc19pbnRlcnZhbAABABJNQVhfU1RFUFNfSU5URVJWQUwJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOQ09ORklHX0FERFJFU1MCEm1heF9zdGVwc19pbnRlcnZhbACQTgAKTUlOX1dFSUdIVAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ5DT05GSUdfQUREUkVTUwIKbWluX3dlaWdodABkAApNQVhfV0VJR0hUCQELdmFsdWVPckVsc2UCCQCaCAIFDkNPTkZJR19BRERSRVNTAgptYXhfd2VpZ2h0AKxNAQ10cnlHZXRJbnRlZ2VyAQNrZXkEByRtYXRjaDAJAJoIAgUEdGhpcwUDa2V5AwkAAQIFByRtYXRjaDACA0ludAQBYgUHJG1hdGNoMAUBYgAAAQx0cnlHZXRCaW5hcnkBA2tleQQHJG1hdGNoMAkAnAgCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQBYgUHJG1hdGNoMAUBYgEAAQx0cnlHZXRTdHJpbmcBA2tleQQHJG1hdGNoMAkAnQgCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFiBQckbWF0Y2gwBQFiAgABE3RyeUdldFN0cmluZ09yVGhyb3cBA2tleQQHJG1hdGNoMAkAnQgCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFiBQckbWF0Y2gwBQFiCQACAQkArAICAh1ubyBzdWNoIGtleSBpbiBkYXRhIHN0b3JhZ2U6IAUDa2V5AQ5nZXRBc3NldFN0cmluZwEHYXNzZXRJZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFiBQckbWF0Y2gwCQDYBAEFAWICBVdBVkVTAQ1nZXRBc3NldEJ5dGVzAQphc3NldElkU3RyAwkAAAIFCmFzc2V0SWRTdHICBVdBVkVTBQR1bml0CQDZBAEFCmFzc2V0SWRTdHIBD2dldFRva2VuQmFsYW5jZQEHYXNzZXRJZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAF0BQckbWF0Y2gwCQDwBwIFBHRoaXMFAXQICQDvBwEFBHRoaXMJYXZhaWxhYmxlARNhZGRBc3NldEJ5dGVzVG9MaXN0AgVhY2N1bQRpdGVtCQDOCAIFBWFjY3VtCQDMCAIJAQ1nZXRBc3NldEJ5dGVzAQUEaXRlbQUDbmlsARRhZGRBc3NldFdlaWdodFRvTGlzdAIFYWNjdW0EaXRlbQkAzggCBQVhY2N1bQkAzAgCCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdzdGF0aWNfCQEOZ2V0QXNzZXRTdHJpbmcBBQRpdGVtAgdfd2VpZ2h0BQNuaWwBF2FkZEFzc2V0V2VpZ2h0VG9TdHJMaXN0AgVhY2N1bQRpdGVtCQDOCAIFBWFjY3VtCQDMCAIJAKQDAQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHc3RhdGljXwUEaXRlbQIHX3dlaWdodAUDbmlsARZhZGRBc3NldERlY2ltYWxzVG9MaXN0AgVhY2N1bQRpdGVtCQDOCAIFBWFjY3VtCQDMCAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB3N0YXRpY18JAQ5nZXRBc3NldFN0cmluZwEFBGl0ZW0CCV9kZWNpbWFscwUDbmlsARNhZGRBc3NldFNjYWxlVG9MaXN0AgVhY2N1bQRpdGVtCQDOCAIFBWFjY3VtCQDMCAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB3N0YXRpY18JAQ5nZXRBc3NldFN0cmluZwEFBGl0ZW0CBl9zY2FsZQUDbmlsAQxhZGRJbnRUb0xpc3QCBWFjY3VtBGl0ZW0JAM4IAgUFYWNjdW0JAMwIAgkBDXBhcnNlSW50VmFsdWUBBQRpdGVtBQNuaWwADnVzZG5Bc3NldElkU3RyCQELdmFsdWVPckVsc2UCCQCdCAIFDkNPTkZJR19BRERSRVNTAg51c2RuQXNzZXRJZFN0cgIsMjVGRXFFalJrcUs2eUNraVQ3THo2U0FZejdnVUZDdHhmQ0NobnJWRkQ1QVQAEHB1enpsZUFzc2V0SWRTdHIJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUOQ09ORklHX0FERFJFU1MCEHB1enpsZUFzc2V0SWRTdHICLDZmUVJhTDNMMjVuR3FldlhUOGt4d2pCUzI4ZmtCRXJySjY5SlljajdxS2dXAA51c2R0QXNzZXRJZFN0cgkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ5DT05GSUdfQUREUkVTUwIOdXNkdEFzc2V0SWRTdHICLDVTaDlLZ2hma1p5aGp3dW9kb3ZEaEI2UGdoRFVHQkhpQVBaNE1rclBnS3RYABF1c2R0UHB0QXNzZXRJZFN0cgkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ5DT05GSUdfQUREUkVTUwIRdXNkdFBwdEFzc2V0SWRTdHICLERLOFJDS1NSdjZ4b3ZmWWNpaVhnejgyQXBpdTF0aUVyYUgzaUJTZVptQWhwAA5yb21lQXNzZXRJZFN0cgkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ5DT05GSUdfQUREUkVTUwIOcm9tZUFzc2V0SWRTdHICLENZWlJENUZ0Tkt3VVU0emhuMzFXUEVtZFVYa1htR0UxdUxQOFVaaE1zY0hUAA93YXZlc0Fzc2V0SWRTdHICBVdBVkVTAAt1c2RuQXNzZXRJZAkA2QQBBQ51c2RuQXNzZXRJZFN0cgANcHV6emxlQXNzZXRJZAkA2QQBBRBwdXp6bGVBc3NldElkU3RyAAt1c2R0QXNzZXRJZAkA2QQBBQ51c2R0QXNzZXRJZFN0cgAOdXNkdFBwdEFzc2V0SWQJANkEAQURdXNkdFBwdEFzc2V0SWRTdHIAC3JvbWVBc3NldElkCQDZBAEFDnJvbWVBc3NldElkU3RyAAx3YXZlc0Fzc2V0SWQFBHVuaXQAFXN1cHBvcnRlZEZlZUFzc2V0c1N0cgkAzAgCBQ51c2RuQXNzZXRJZFN0cgkAzAgCBRBwdXp6bGVBc3NldElkU3RyCQDMCAIFDnVzZHRBc3NldElkU3RyCQDMCAIFEXVzZHRQcHRBc3NldElkU3RyCQDMCAIFD3dhdmVzQXNzZXRJZFN0cgkAzAgCBQ5yb21lQXNzZXRJZFN0cgUDbmlsABFwYXJlbnRQb29sQWRkcmVzcwkBB0FkZHJlc3MBCQDZBAEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUOQ09ORklHX0FERFJFU1MCEXBhcmVudFBvb2xBZGRyZXNzAiMzTXlRTFRDbkszVWk0Um0yWllBU2I4ZTdFTXF3THNIaFpwYgANbWFzdGVyQWRkcmVzcwkBB0FkZHJlc3MBCQDZBAEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUOQ09ORklHX0FERFJFU1MCDW1hc3RlckFkZHJlc3MCIzNOMkVhY1kzdEQ4OXpDUFJ6U3NXODdBTE1YVVBBM29FTHBkAAxtYXN0ZXJQdWJLZXkJANkEAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ5DT05GSUdfQUREUkVTUwIMbWFzdGVyUHViS2V5AixFVUZyTWZLTU05aWhHZTZrc3lZTUdYQXZLVzgxeXUzQXhIYzhOR1ZRU0pINAANb3JhY2xlQWRkcmVzcwkBB0FkZHJlc3MBCQDZBAEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUOQ09ORklHX0FERFJFU1MCDW9yYWNsZUFkZHJlc3MCIzNNcjNoZWFGclplVDRpTWFmdTlhaGp2WHdqUTdYcWVXQWVSAA5zdGFraW5nQWRkcmVzcwkBB0FkZHJlc3MBCQDZBAEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUOQ09ORklHX0FERFJFU1MCDnN0YWtpbmdBZGRyZXNzAiMzTXU3VkhBV216RnVDOENDMWpMNjZlZ3dXZHpNbVUzR01kTgALZmVlc0FkZHJlc3MJAQdBZGRyZXNzAQkA2QQBCQELdmFsdWVPckVsc2UCCQCdCAIFDkNPTkZJR19BRERSRVNTAgtmZWVzQWRkcmVzcwIjM040NGNYWGhkN1hrN2hyN0prTGEzbVRTdExRbkZwVWZLZ0MAD3Bvb2xzSHViQWRkcmVzcwkBB0FkZHJlc3MBCQDZBAEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUOQ09ORklHX0FERFJFU1MCD3Bvb2xzSHViQWRkcmVzcwIjM05BRDNXdzVEOGQ0N3F6WGtrOWFla1FOcm9ZVVV0dzRqZEwAEnNodXRkb3duQWRkcmVzc1N0cgkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ5DT05GSUdfQUREUkVTUwIPc2h1dGRvd25BZGRyZXNzAiMzTXRpTWpLaUZ1TVpBQTNOVzlZWkg4OWJZbWlZVVFVQmV6eAAPbGF5ZXIyQWRkcmVzc2VzCQELdmFsdWVPckVsc2UCCQCdCAIFDkNPTkZJR19BRERSRVNTAg9sYXllcjJBZGRyZXNzZXMCRzNNc3A3VzlySHlIa3Z2S0JLVTNyQjQ0U3FxY0RBTE1iZ2JnLDNNc3A3VzlySHlIa3Z2S0JLVTNyQjQ0U3FxY0RBTE1iZ2JnAApnb3ZBZGRyZXNzCQEHQWRkcmVzcwEJANkEAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ5DT05GSUdfQUREUkVTUwIKZ292QWRkcmVzcwIjM01zQWRMc0hGbUFyU3lFdVlGRzl4UlJic3V0VUJvdnpCaG4AEWNvbGRNYXN0ZXJBZGRyZXNzCQEHQWRkcmVzcwEJANkEAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ5DT05GSUdfQUREUkVTUwIRY29sZE1hc3RlckFkZHJlc3MCIzNOM0xGZXluWVRGRXJDR1hjQUJYZW5tWWFtMXFiaGJjTkFIAAFUCQENdHJ5R2V0SW50ZWdlcgECE3N0YXRpY190b2tlbnNBbW91bnQACGFzc2V0SWRzCgACJGwJALUJAgkBDHRyeUdldFN0cmluZwECD3N0YXRpY190b2tlbklkcwIBLAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQETYWRkQXNzZXRCeXRlc1RvTGlzdAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgANQXNzZXRzV2VpZ2h0cwoAAiRsBQhhc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMV8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEUYWRkQXNzZXRXZWlnaHRUb0xpc3QCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjFfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGYxXzICCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACERlY2ltYWxzCgACJGwFCGFzc2V0SWRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYyXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARZhZGRBc3NldERlY2ltYWxzVG9MaXN0AgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYyXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMl8yAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgkBBSRmMl8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAZTY2FsZXMKAAIkbAUIYXNzZXRJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjNfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBE2FkZEFzc2V0U2NhbGVUb0xpc3QCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjNfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGYzXzICCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECCQEFJGYzXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoAA0ZlZQkBDXRyeUdldEludGVnZXIBAgpzdGF0aWNfZmVlAAxlYXJuZWRBc3NldHMFCGFzc2V0SWRzAQppc1NodXRkb3duAAQPc2h1dGRvd25BZGRyZXNzCQCmCAEFEnNodXRkb3duQWRkcmVzc1N0cgMJAAACBQ9zaHV0ZG93bkFkZHJlc3MFBHVuaXQHBAckbWF0Y2gwCQCbCAIJAQV2YWx1ZQEFD3NodXRkb3duQWRkcmVzcwILaXNfc2h1dGRvd24DCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBeAUHJG1hdGNoMAUBeAcBFmdldEN1cnJlbnRUb2tlbkJhbGFuY2UBCHRva2VuTnVtBAp0b2tlbklkU3RyCQEOZ2V0QXNzZXRTdHJpbmcBCQCRAwIFCGFzc2V0SWRzBQh0b2tlbk51bQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwUKdG9rZW5JZFN0cgIIX2JhbGFuY2UBCGdldEtNdWx0AAQHJG1hdGNoMAkAnwgBAgxzdGF0aWNfS011bHQDCQABAgUHJG1hdGNoMAIDSW50BAF4BQckbWF0Y2gwBQF4BQdTY2FsZTE2ARJzYXZlQ3VycmVudFdlaWdodHMABAphc3NldElkc0xpCQC1CQIJAQx0cnlHZXRTdHJpbmcBAg9zdGF0aWNfdG9rZW5JZHMCASwKAQFzAgVhY2N1bQdhc3NldElkCQDOCAIFBWFjY3VtCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgICFnJlYmFsYW5jZV9zdGFydFdlaWdodF8FB2Fzc2V0SWQJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB3N0YXRpY18FB2Fzc2V0SWQCB193ZWlnaHQFA25pbAoAAiRsBQphc3NldElkc0xpCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQFzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKARlnZXRWaXJ0dWFsUG9vbFRva2VuQW1vdW50AAkAawMJAQ10cnlHZXRJbnRlZ2VyAQIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQJAQhnZXRLTXVsdAAFB1NjYWxlMTYBEGNhbGN1bGF0ZVBJc3N1ZWQCBmFtb3VudAd0b2tlbklkBAdQc3VwcGx5CQEZZ2V0VmlydHVhbFBvb2xUb2tlbkFtb3VudAAEB0JhbGFuY2UJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFB3Rva2VuSWQCCF9iYWxhbmNlBAJ0MQkAbgQFBmFtb3VudAUHUHN1cHBseQUHQmFsYW5jZQUERE9XTgUCdDEBDWdldE1pblBJc3N1ZWQBCHBheW1lbnRzCgEHaGFuZGxlcgIFYWNjdW0HY3VycmVudAQHUElzc3VlZAkBEGNhbGN1bGF0ZVBJc3N1ZWQCCAUHY3VycmVudAZhbW91bnQIBQdjdXJyZW50B2Fzc2V0SWQDCQAAAgUHUElzc3VlZAAACQACAQIkb25lIG9mIHRoZSB0b2tlbnMgYW1vdW50cyBpcyB0b28gbG93AwMJAAACBQVhY2N1bQAABgkAZgIFBWFjY3VtBQdQSXNzdWVkBQdQSXNzdWVkBQVhY2N1bQQJbWluUElzc2VkCgACJGwFCHBheW1lbnRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQdoYW5kbGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBQltaW5QSXNzZWQBEmNhbGN1bGF0ZVVzZG5WYWx1ZQQHYXNzZXRJZAZhbW91bnQIYUJhbGFuY2UQZ2l2ZW5Vc2RuQmFsYW5jZQQKdXNkbkluUG9vbAkAzwgCBQhhc3NldElkcwULdXNkbkFzc2V0SWQEDHB1enpsZUluUG9vbAkAzwgCBQhhc3NldElkcwUNcHV6emxlQXNzZXRJZAQKdXNkdEluUG9vbAkAzwgCBQhhc3NldElkcwULdXNkdEFzc2V0SWQEDXVzZHRQcHRJblBvb2wJAM8IAgUIYXNzZXRJZHMFDnVzZHRQcHRBc3NldElkBAt3YXZlc0luUG9vbAkAzwgCBQhhc3NldElkcwUEdW5pdAQLYXNzZXRXZWlnaHQJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB3N0YXRpY18JAQ5nZXRBc3NldFN0cmluZwEFB2Fzc2V0SWQCB193ZWlnaHQEC2ZlZUFzc2V0U3RyCQEMdHJ5R2V0U3RyaW5nAQIPc3RhdGljX2ZlZVRva2VuAwkAAAIFC2ZlZUFzc2V0U3RyBRBwdXp6bGVBc3NldElkU3RyBAxwdXp6bGVXZWlnaHQJAJEDAgUNQXNzZXRzV2VpZ2h0cwkBBXZhbHVlAQkAzwgCBQhhc3NldElkcwUNcHV6emxlQXNzZXRJZAQNcHV6emxlQmFsYW5jZQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwUQcHV6emxlQXNzZXRJZFN0cgIIX2JhbGFuY2UEDmFtb3VudEluUHV6emxlCQBrAwUGYW1vdW50CQBpAgUNcHV6emxlQmFsYW5jZQUMcHV6emxlV2VpZ2h0CQBpAgUIYUJhbGFuY2UFC2Fzc2V0V2VpZ2h0BAtwdXp6bGVQcmljZQkBEUBleHRyTmF0aXZlKDEwNTApAgURcGFyZW50UG9vbEFkZHJlc3MCFmdsb2JhbF9sYXN0UHV6emxlUHJpY2UJAGsDCQBoAgUOYW1vdW50SW5QdXp6bGUFC3B1enpsZVByaWNlAAEFBlNjYWxlOAMJAAACBQtmZWVBc3NldFN0cgUOdXNkdEFzc2V0SWRTdHIECnVzZHRXZWlnaHQJAJEDAgUNQXNzZXRzV2VpZ2h0cwkBBXZhbHVlAQUKdXNkdEluUG9vbAQLdXNkdEJhbGFuY2UJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8FDnVzZHRBc3NldElkU3RyAghfYmFsYW5jZQkAawMFBmFtb3VudAkAaQIFC3VzZHRCYWxhbmNlBQp1c2R0V2VpZ2h0CQBpAgUIYUJhbGFuY2UFC2Fzc2V0V2VpZ2h0AwkAAAIFC2ZlZUFzc2V0U3RyBRF1c2R0UHB0QXNzZXRJZFN0cgQKdXNkdFdlaWdodAkAkQMCBQ1Bc3NldHNXZWlnaHRzCQEFdmFsdWUBBQ11c2R0UHB0SW5Qb29sBAt1c2R0QmFsYW5jZQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwURdXNkdFBwdEFzc2V0SWRTdHICCF9iYWxhbmNlCQBrAwUGYW1vdW50CQBpAgULdXNkdEJhbGFuY2UFCnVzZHRXZWlnaHQJAGkCBQhhQmFsYW5jZQULYXNzZXRXZWlnaHQDCQAAAgULZmVlQXNzZXRTdHIFDnVzZG5Bc3NldElkU3RyBAp1c2RuV2VpZ2h0CQCRAwIFDUFzc2V0c1dlaWdodHMJAQV2YWx1ZQEJAM8IAgUIYXNzZXRJZHMFC3VzZG5Bc3NldElkBAt1c2RuQmFsYW5jZQQHJG1hdGNoMAUQZ2l2ZW5Vc2RuQmFsYW5jZQMJAAECBQckbWF0Y2gwAgNJbnQEAXgFByRtYXRjaDAFEGdpdmVuVXNkbkJhbGFuY2UJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFC3VzZG5Bc3NldElkAghfYmFsYW5jZQkAawMFBmFtb3VudAkAaQIJAQV2YWx1ZQEFC3VzZG5CYWxhbmNlBQp1c2RuV2VpZ2h0CQBpAgUIYUJhbGFuY2UFC2Fzc2V0V2VpZ2h0BAt3YXZlc1dlaWdodAC4FwQId0JhbGFuY2UJAGkCCQENdHJ5R2V0SW50ZWdlcgECFGdsb2JhbF9XQVZFU19iYWxhbmNlADIJAGsDBQZhbW91bnQJAGkCBQh3QmFsYW5jZQULd2F2ZXNXZWlnaHQJAGkCBQhhQmFsYW5jZQULYXNzZXRXZWlnaHQBEmdldFByaWNlRnJvbU9yYWNsZQEKYXNzZXRJZFN0cgQHJG1hdGNoMAkAmggCBQ1vcmFjbGVBZGRyZXNzCQCsAgIFCmFzc2V0SWRTdHICB190d2FwNUIDCQABAgUHJG1hdGNoMAIDSW50BAF4BQckbWF0Y2gwBQF4AAABEWNhbGN1bGF0ZVVzZFZhbHVlAwdhc3NldElkBmFtb3VudAhhQmFsYW5jZQQLYXNzZXRXZWlnaHQJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB3N0YXRpY18JAQ5nZXRBc3NldFN0cmluZwEFB2Fzc2V0SWQCB193ZWlnaHQEC2ZlZUFzc2V0U3RyCQEMdHJ5R2V0U3RyaW5nAQIPc3RhdGljX2ZlZVRva2VuBA1mZWVBc3NldFNjYWxlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIJAKwCAgIHc3RhdGljXwULZmVlQXNzZXRTdHICBl9zY2FsZQQLZmVlQXNzZXROdW0JAQV2YWx1ZQEJAM8IAgUIYXNzZXRJZHMJAQ1nZXRBc3NldEJ5dGVzAQULZmVlQXNzZXRTdHIEDmZlZUFzc2V0V2VpZ2h0CQCRAwIFDUFzc2V0c1dlaWdodHMFC2ZlZUFzc2V0TnVtBA9mZWVBc3NldEJhbGFuY2UJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8FC2ZlZUFzc2V0U3RyAghfYmFsYW5jZQQNdmFsSW5GZWVBc3NldAkAawMFBmFtb3VudAkAaQIFD2ZlZUFzc2V0QmFsYW5jZQUOZmVlQXNzZXRXZWlnaHQJAGkCBQhhQmFsYW5jZQULYXNzZXRXZWlnaHQEDWZlZUFzc2V0UHJpY2UJARJnZXRQcmljZUZyb21PcmFjbGUBBQtmZWVBc3NldFN0cgkAawMFDXZhbEluRmVlQXNzZXQFDWZlZUFzc2V0UHJpY2UFDWZlZUFzc2V0U2NhbGUBE2NoZWNrVG9rZW5zVmFsaWRpdHkBCHBheW1lbnRzCgEIaGFuZGxlcjECBWFjY3VtB3BheW1lbnQJAM4IAgUFYWNjdW0JAMwIAggFB3BheW1lbnQHYXNzZXRJZAUDbmlsBANpZHMKAAIkbAUIcGF5bWVudHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjRfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBCGhhbmRsZXIxAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAwkAAAIFA2lkcwUDaWRzCgEIaGFuZGxlcjICBWFjY3VtB2Fzc2V0SWQDCQECIT0CCQDPCAIFA2lkcwUHYXNzZXRJZAUEdW5pdAkAZAIFBWFjY3VtAAEJAAIBCQCsAgICFGFzc2V0IG5vdCBhdHRhY2hlZDogCQEOZ2V0QXNzZXRTdHJpbmcBBQdhc3NldElkBAZjaGVja3MKAAIkbAUIYXNzZXRJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjVfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBCGhhbmRsZXIyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY1XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNV8yAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAwkAAAIFBmNoZWNrcwUGY2hlY2tzBgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgETaGFuZGxlUG9vbFRva2Vuc0FkZAQHUElzc3VlZAhwYXltZW50cwt1c2VyQWRkcmVzcwpuZWVkQ2hhbmdlCgEVZ2V0VG9rZW5QYXltZW50QW1vdW50AQd0b2tlbklkCgEHaGFuZGxlcgIFYWNjdW0HcGF5bWVudAMJAAACCAUHcGF5bWVudAdhc3NldElkBQd0b2tlbklkCAUHcGF5bWVudAZhbW91bnQFBWFjY3VtCgACJGwFCHBheW1lbnRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQdoYW5kbGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKCgERaGFuZGxlVG9rZW5DaGFuZ2UCBWFjY3VtB3Rva2VuSWQEAkJrCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBBQd0b2tlbklkAghfYmFsYW5jZQQHUFN1cHBseQkBGWdldFZpcnR1YWxQb29sVG9rZW5BbW91bnQABA10b2tlbkRlY2ltYWxzCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdzdGF0aWNfCQEOZ2V0QXNzZXRTdHJpbmcBBQd0b2tlbklkAgZfc2NhbGUEAmExCQC9AgQJALkCAgkAtgIBCQBkAgUHUFN1cHBseQUHUElzc3VlZAkAtgIBBQZTY2FsZTgJALYCAQUNdG9rZW5EZWNpbWFscwkAtgIBBQdQU3VwcGx5BQdDRUlMSU5HBAJEawkAoAMBCQC9AgQJALgCAgUCYTEJALkCAgkAtgIBBQ10b2tlbkRlY2ltYWxzCQC2AgEFBlNjYWxlOAkAtgIBBQJCawkAuQICCQC2AgEFDXRva2VuRGVjaW1hbHMJALYCAQUGU2NhbGU4BQdDRUlMSU5HBA1wYXltZW50QW1vdW50CQEVZ2V0VG9rZW5QYXltZW50QW1vdW50AQUHdG9rZW5JZAQIdG9SZXR1cm4JAGUCBQ1wYXltZW50QW1vdW50BQJEawQBdAMDBQpuZWVkQ2hhbmdlCQBmAgUIdG9SZXR1cm4AAAcJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwULdXNlckFkZHJlc3MFCHRvUmV0dXJuBQd0b2tlbklkBQNuaWwFA25pbAkAzggCCQDOCAIFBWFjY3VtBQF0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIHZ2xvYmFsXwkBDmdldEFzc2V0U3RyaW5nAQUHdG9rZW5JZAIIX2JhbGFuY2UJAGQCBQJCawUCRGsFA25pbAoAAiRsBQhhc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmNF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQERaGFuZGxlVG9rZW5DaGFuZ2UCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjRfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY0XzICCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoBFmhhbmRsZVBvb2xUb2tlbnNSZWRlZW0CCVBSZWRlZW1lZAt1c2VyQWRkcmVzcwoBEWhhbmRsZVRva2VuUmVkZWVtAgVhY2N1bQd0b2tlbklkBAJCawkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwkBDmdldEFzc2V0U3RyaW5nAQUHdG9rZW5JZAIIX2JhbGFuY2UEB1BTdXBwbHkJARlnZXRWaXJ0dWFsUG9vbFRva2VuQW1vdW50AAQNdG9rZW5EZWNpbWFscwkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHc3RhdGljXwkBDmdldEFzc2V0U3RyaW5nAQUHdG9rZW5JZAIGX3NjYWxlBAZwc3VwcGwJAL0CBAkAuQICCQC2AgEJAGUCBQdQU3VwcGx5BQlQUmVkZWVtZWQJALYCAQUGU2NhbGU4CQC2AgEFBlNjYWxlOAkAtgIBBQdQU3VwcGx5BQRET1dOBAZhbW91bnQJAKADAQkAvQIECQC4AgIJALYCAQUHU2NhbGUxNgUGcHN1cHBsCQC2AgEFAkJrCQC2AgEFB1NjYWxlMTYFB0NFSUxJTkcJAM4IAgUFYWNjdW0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBBQd0b2tlbklkAghfYmFsYW5jZQkAZQIFAkJrBQZhbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwULdXNlckFkZHJlc3MFBmFtb3VudAUHdG9rZW5JZAUDbmlsCgACJGwFCGFzc2V0SWRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARFoYW5kbGVUb2tlblJlZGVlbQIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmNF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjRfMgIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgESY2FsY3VsYXRlT3V0QW1vdW50BQhBbW91bnRJbgdhc3NldEluCGFzc2V0T3V0CUJhbGFuY2VJbgpCYWxhbmNlT3V0BAdJbmRleEluCQEFdmFsdWUBCQDPCAIFCGFzc2V0SWRzBQdhc3NldEluBAhJbmRleE91dAkBBXZhbHVlAQkAzwgCBQhhc3NldElkcwUIYXNzZXRPdXQDCQAAAgUHSW5kZXhJbgUISW5kZXhPdXQFCEFtb3VudEluCQBuBAUKQmFsYW5jZU91dAkAZQIJAGgCBQZTY2FsZTgFBlNjYWxlOAkAoAMBCQB2BgkAvQIECQC5AgIJALYCAQUJQmFsYW5jZUluCQC2AgEAkE4JALYCAQkAaAIFBlNjYWxlOAUGU2NhbGU4CQC5AgIJALYCAQkAZAIFCUJhbGFuY2VJbgUIQW1vdW50SW4JALYCAQCQTgUGSEFMRlVQABAJALYCAQkAawMJAJEDAgUNQXNzZXRzV2VpZ2h0cwUHSW5kZXhJbgCAoJSljR0JAJEDAgUNQXNzZXRzV2VpZ2h0cwUISW5kZXhPdXQADAAQBQdDRUlMSU5HCQBoAgUGU2NhbGU4BQZTY2FsZTgFCEhBTEZFVkVOAR1jYWxjdWxhdGVDdXJyZW50QXNzZXRJbnRlcmVzdAQHYXNzZXRJZAphc3NldElkU3RyCGFCYWxhbmNlFnRva2VuRWFybmluZ3NMYXN0Q2hlY2sEC3RvdGFsU3Rha2VkCQENdHJ5R2V0SW50ZWdlcgECEmdsb2JhbF9pbmRleFN0YWtlZAQVdG9rZW5CYWxhbmNlTGFzdENoZWNrBRZ0b2tlbkVhcm5pbmdzTGFzdENoZWNrBBNjdXJyZW50QmFsYW5jZURlbHRhCQBlAgkBD2dldFRva2VuQmFsYW5jZQEFB2Fzc2V0SWQFCGFCYWxhbmNlBBRjdXJyZW50VG9rZW5FYXJuaW5ncwMJAGYCBRNjdXJyZW50QmFsYW5jZURlbHRhBRV0b2tlbkJhbGFuY2VMYXN0Q2hlY2sFE2N1cnJlbnRCYWxhbmNlRGVsdGEFFXRva2VuQmFsYW5jZUxhc3RDaGVjawQLbmV3RWFybmluZ3MJAGUCBRRjdXJyZW50VG9rZW5FYXJuaW5ncwUVdG9rZW5CYWxhbmNlTGFzdENoZWNrBAtuZXdJbnRlcmVzdAMJAAACBQt0b3RhbFN0YWtlZAAAAAAJAGsDBQtuZXdFYXJuaW5ncwUGU2NhbGU4BQt0b3RhbFN0YWtlZAQRbGFzdENoZWNrSW50ZXJlc3QJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICEWdsb2JhbF9sYXN0Q2hlY2tfBQphc3NldElkU3RyAglfaW50ZXJlc3QJAGQCBRFsYXN0Q2hlY2tJbnRlcmVzdAULbmV3SW50ZXJlc3QBC2NsYWltUmVzdWx0AQdhZGRyZXNzBAphZGRyZXNzU3RyCQClCAEFB2FkZHJlc3MEDHB1enpsZUFtb3VudAkBDXRyeUdldEludGVnZXIBCQCsAgIFCmFkZHJlc3NTdHICDF9pbmRleFN0YWtlZAoBB2hhbmRsZXICBWFjY3VtB2Fzc2V0SWQECmFzc2V0SWRTdHIJAQ5nZXRBc3NldFN0cmluZwEFB2Fzc2V0SWQECGFCYWxhbmNlCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBBQdhc3NldElkAghfYmFsYW5jZQQWdG9rZW5FYXJuaW5nc0xhc3RDaGVjawkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIRZ2xvYmFsX2xhc3RDaGVja18FCmFzc2V0SWRTdHICCV9lYXJuaW5ncwQUY3VycmVudFRva2VuSW50ZXJlc3QJAR1jYWxjdWxhdGVDdXJyZW50QXNzZXRJbnRlcmVzdAQFB2Fzc2V0SWQFCmFzc2V0SWRTdHIFCGFCYWxhbmNlBRZ0b2tlbkVhcm5pbmdzTGFzdENoZWNrBBRjdXJyZW50VG9rZW5FYXJuaW5ncwkAlgMBCQDMCAIFFnRva2VuRWFybmluZ3NMYXN0Q2hlY2sJAMwIAgkAZQIJAQ9nZXRUb2tlbkJhbGFuY2UBBQdhc3NldElkBQhhQmFsYW5jZQUDbmlsBAxyZXdhcmRBbW91bnQJAGsDBQxwdXp6bGVBbW91bnQJAGUCBRRjdXJyZW50VG9rZW5JbnRlcmVzdAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgkArAICBQphZGRyZXNzU3RyAgtfbGFzdENoZWNrXwUKYXNzZXRJZFN0cgIJX2ludGVyZXN0BQZTY2FsZTgECHRyYW5zZmVyAwkAAAIFDHJld2FyZEFtb3VudAAABQNuaWwJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUHYWRkcmVzcwUMcmV3YXJkQW1vdW50BQdhc3NldElkBQNuaWwJAJQKAgkAzggCCQDOCAIIBQVhY2N1bQJfMQUIdHJhbnNmZXIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAhFnbG9iYWxfbGFzdENoZWNrXwUKYXNzZXRJZFN0cgIJX2Vhcm5pbmdzCQBlAgUUY3VycmVudFRva2VuRWFybmluZ3MFDHJld2FyZEFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICEWdsb2JhbF9sYXN0Q2hlY2tfBQphc3NldElkU3RyAglfaW50ZXJlc3QFFGN1cnJlbnRUb2tlbkludGVyZXN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICBQphZGRyZXNzU3RyAgtfbGFzdENoZWNrXwUKYXNzZXRJZFN0cgIJX2ludGVyZXN0BRRjdXJyZW50VG9rZW5JbnRlcmVzdAUDbmlsCQBkAggFBWFjY3VtAl8yCQERY2FsY3VsYXRlVXNkVmFsdWUDBQdhc3NldElkBQxyZXdhcmRBbW91bnQFCGFCYWxhbmNlBAVhY2N1bQoAAiRsBQxlYXJuZWRBc3NldHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFA25pbAAACgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQdoYW5kbGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKCQCUCgIJAM4IAggFBWFjY3VtAl8xCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCmFkZHJlc3NTdHICEV9jbGFpbWVkUmV3YXJkVVNECQBkAgkBDXRyeUdldEludGVnZXIBCQCsAgIFCmFkZHJlc3NTdHICEV9jbGFpbWVkUmV3YXJkVVNECAUFYWNjdW0CXzIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUKYWRkcmVzc1N0cgIKX2xhc3RDbGFpbQgFCWxhc3RCbG9jawl0aW1lc3RhbXAFA25pbAgFBWFjY3VtAl8yARBpbmRleFN0YWtlUmVzdWx0AgphZGRyZXNzU3RyBmFtb3VudAQCbGkICQELY2xhaW1SZXN1bHQBCQERQGV4dHJOYXRpdmUoMTA2MikBBQphZGRyZXNzU3RyAl8xCQDOCAIFAmxpCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCmFkZHJlc3NTdHICDF9pbmRleFN0YWtlZAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICBQphZGRyZXNzU3RyAgxfaW5kZXhTdGFrZWQFBmFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgISZ2xvYmFsX2luZGV4U3Rha2VkCQBkAgkBDXRyeUdldEludGVnZXIBAhJnbG9iYWxfaW5kZXhTdGFrZWQFBmFtb3VudAUDbmlsAQNzdW0CBWFjY3VtAW4JAGQCBQVhY2N1bQkBDXBhcnNlSW50VmFsdWUBBQFuAQ1jaGVja0ZlZUFzc2V0AgVhY2N1bQRuZXh0AwMJAQIhPQIJAM8IAgUVc3VwcG9ydGVkRmVlQXNzZXRzU3RyBQRuZXh0BQR1bml0CQAAAgUFYWNjdW0CAAcFBG5leHQFBWFjY3VtARJnZXRUbXBSZWJhbGFuY2VJZHMBDW5ld0Fzc2V0SWRzTGkEEWN1cnJlbnRBc3NldElkc0xpCQC1CQIJAQx0cnlHZXRTdHJpbmcBAg9zdGF0aWNfdG9rZW5JZHMCASwEBnJlc3VsdAUNbmV3QXNzZXRJZHNMaQoBAWYCBWFjY3VtB2Fzc2V0SWQDCQAAAgkAzwgCBQZyZXN1bHQFB2Fzc2V0SWQFBHVuaXQJAM4IAgUFYWNjdW0JAMwIAgUHYXNzZXRJZAUDbmlsBQVhY2N1bQoAAiRsBRFjdXJyZW50QXNzZXRJZHNMaQoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFBnJlc3VsdAoBBSRmNF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEBZgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmNF8yAgIkYQIkaQMJAGcCBQIk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JGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoJAMwIAgkBC1N0cmluZ0VudHJ5AgIPc3RhdGljX3Rva2VuSWRzBQthc3NldElkc1N0cgkAzAgCCQELU3RyaW5nRW50cnkCAg9zdGF0aWNfZmVlVG9rZW4FC2ZlZUFzc2V0U3RyCQDMCAIJAQtTdHJpbmdFbnRyeQICE3N0YXRpY190b2tlbldlaWdodHMFD2Fzc2V0V2VpZ2h0c1N0cgkAzAgCCQEMSW50ZWdlckVudHJ5AgITc3RhdGljX3Rva2Vuc0Ftb3VudAkAkAMBBQphc3NldElkc0xpCQDMCAIJAQtTdHJpbmdFbnRyeQICEXN0YXRpY19wb29sRG9tYWluBQpwb29sRG9tYWluCQDMCAIJAQtTdHJpbmdFbnRyeQICEnN0YXRpY19iYXNlVG9rZW5JZAUOYmFzZVRva2VuSWRTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgIQc3RhdGljX3Bvb2xPd25lcgUJcG9vbE93bmVyCQDMCAIJAQxJbnRlZ2VyRW50cnkCAgpzdGF0aWNfZmVlBQNmZWUJAMwIAgkBDEludGVnZXJFbnRyeQICDHN0YXRpY19LTXVsdAUHU2NhbGUxNgkAzAgCCQEMSW50ZWdlckVudHJ5AgITZ2xvYmFsX3dhc1ByZUluaXRlZAABBQNuaWwBaQEGZGVJbml0AAMJAQppc1NodXRkb3duAAkAAgECE2NvbnRyYWN0IGlzIG9uIHN0b3ADCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgphZG1pbiBvbmx5CQDMCAIJAQxJbnRlZ2VyRW50cnkCAhBnbG9iYWxfd2FzSW5pdGVkAAAFA25pbAFpAQRpbml0AAoBC3ByZXBhcmVMaXN0AAoBB2hhbmRsZXICBWFjY3VtAW4JAM4IAgUFYWNjdW0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBCAUBbgdhc3NldElkAghfYmFsYW5jZQgFAW4GYW1vdW50BQNuaWwKAAIkbAgFAWkIcGF5bWVudHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjRfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBB2hhbmRsZXICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjRfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY0XzICCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECCQEFJGY0XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoKARljYWxjdWxhdGVQb29sVG9rZW5zQW1vdW50AQhwYXltZW50cwoBB2hhbmRsZXICBWFjY3VtA3BtdAQHYXNzZXRJZAgFA3BtdAdhc3NldElkCgEIaGFuZGxlcjICBWFjY3VtAW4DCQAAAgUBbgUHYXNzZXRJZAkBBXZhbHVlAQkAzwgCBQhhc3NldElkcwUBbgUFYWNjdW0EBVRva2VuCgACJGwFCGFzc2V0SWRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAABCgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQhoYW5kbGVyMgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmNF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjRfMgIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgkAawMFBWFjY3VtCQBsBggFA3BtdAZhbW91bnQJAJEDAgUIRGVjaW1hbHMFBVRva2VuCQCRAwIFDUFzc2V0c1dlaWdodHMFBVRva2VuBRVBc3NldHNXZWlnaHRzRGVjaW1hbHMACAUFRkxPT1IFBlNjYWxlOAoAAiRsBQhwYXltZW50cwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFDlBvb2xUb2tlblNjYWxlCgEFJGY0XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQdoYW5kbGVyAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY0XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNF8yAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgkBBSRmNF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAwkBCmlzU2h1dGRvd24ACQACAQITY29udHJhY3QgaXMgb24gc3RvcAMJAGYCCQENdHJ5R2V0SW50ZWdlcgECEGdsb2JhbF93YXNJbml0ZWQAAAkAAgECE3Bvb2wgYWxyZWFkeSBpbml0ZWQEEWluaXRpYWxQb29sVG9rZW5zCQEZY2FsY3VsYXRlUG9vbFRva2Vuc0Ftb3VudAEIBQFpCHBheW1lbnRzAwkAAAIFEWluaXRpYWxQb29sVG9rZW5zAAAJAAIBAjJ5b3UgbmVlZCBhIGJpZ2dlciB0b2tlbnMgYW1vdW50IHRvIGxhdW5jaCB0aGUgcG9vbAQOcG9vbFRva2VuSXNzdWUJAMMIBwkArAICAgNQWiAJAQx0cnlHZXRTdHJpbmcBAhFzdGF0aWNfcG9vbERvbWFpbgIdUHV6emxlIFN3YXA6IHBvb2wgaW5kZXggdG9rZW4FEWluaXRpYWxQb29sVG9rZW5zBRFQb29sVG9rZW5EZWNpbWFscwYFBHVuaXQAAAQLcG9vbFRva2VuSWQJALgIAQUOcG9vbFRva2VuSXNzdWUJAM4IAgkBC3ByZXBhcmVMaXN0AAkAzAgCBQ5wb29sVG9rZW5Jc3N1ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQFEWluaXRpYWxQb29sVG9rZW5zCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhBnbG9iYWxfd2FzSW5pdGVkAAEJAMwIAgkBC0JpbmFyeUVudHJ5AgITZ2xvYmFsX3Bvb2xUb2tlbl9pZAULcG9vbFRva2VuSWQJAMwIAgkBC1N0cmluZ0VudHJ5AgIWc3RhdGljX3Bvb2xUb2tlbl9pZFN0cgkBDmdldEFzc2V0U3RyaW5nAQULcG9vbFRva2VuSWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkApQgBCAUBaQZjYWxsZXICDF9pbmRleFN0YWtlZAURaW5pdGlhbFBvb2xUb2tlbnMJAMwIAgkBDEludGVnZXJFbnRyeQICEmdsb2JhbF9pbmRleFN0YWtlZAURaW5pdGlhbFBvb2xUb2tlbnMFA25pbAFpAQ1nZW5lcmF0ZUluZGV4AQpuZWVkQ2hhbmdlAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwUBVAkAAgEJAKwCAgI7eW91IG5lZWQgdG8gYXR0YWNoIGFsbCBwb29sIHRva2Vucy4gYW1vdW50IG9mIHBvb2wgdG9rZW5zOiAJAKQDAQUBVAMJAQEhAQkBE2NoZWNrVG9rZW5zVmFsaWRpdHkBCAUBaQhwYXltZW50cwkAAgECFXdyb25nIGFzc2V0cyBhdHRhY2hlZAQNUElzc3VlZE5vTXVsdAkBDWdldE1pblBJc3N1ZWQBCAUBaQhwYXltZW50cwQGcmVzdWx0CQETaGFuZGxlUG9vbFRva2Vuc0FkZAQFDVBJc3N1ZWROb011bHQIBQFpCHBheW1lbnRzCAUBaQxvcmlnaW5DYWxsZXIFCm5lZWRDaGFuZ2UED1BJc3N1ZWRXaXRoTXVsdAkAbgQFDVBJc3N1ZWROb011bHQFB1NjYWxlMTYJAQhnZXRLTXVsdAAFBERPV04EB3JlaXNzdWUJAQdSZWlzc3VlAwkBEUBleHRyTmF0aXZlKDEwNTcpAQITZ2xvYmFsX3Bvb2xUb2tlbl9pZAUPUElzc3VlZFdpdGhNdWx0BgkAlAoCCQDOCAIFBnJlc3VsdAkAzAgCBQdyZWlzc3VlCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUPUElzc3VlZFdpdGhNdWx0CQEMdHJ5R2V0QmluYXJ5AQITZ2xvYmFsX3Bvb2xUb2tlbl9pZAkAzAgCCQEMSW50ZWdlckVudHJ5AgIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQJAGQCCQENdHJ5R2V0SW50ZWdlcgECF2dsb2JhbF9wb29sVG9rZW5fYW1vdW50BQ9QSXNzdWVkV2l0aE11bHQFA25pbAUPUElzc3VlZFdpdGhNdWx0AWkBC3JlZGVlbUluZGV4AQxzZW5kVG9PcmlnaW4EA3BtdAkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AggFA3BtdAdhc3NldElkCQEMdHJ5R2V0QmluYXJ5AQITZ2xvYmFsX3Bvb2xUb2tlbl9pZAkAAgECHnBsZWFzZSBhdHRhY2ggcG9vbCBzaGFyZSB0b2tlbgMJAQppc1NodXRkb3duAAkAAgECE2NvbnRyYWN0IGlzIG9uIHN0b3AEEVBSZWRlZW1lZFdpdGhNdWx0CAUDcG10BmFtb3VudAQTUFJlZGVlbWVkV2l0aE5vTXVsdAkAbgQFEVBSZWRlZW1lZFdpdGhNdWx0CQEIZ2V0S011bHQABQdTY2FsZTE2BQRET1dOBAZyZXN1bHQJARZoYW5kbGVQb29sVG9rZW5zUmVkZWVtAgUTUFJlZGVlbWVkV2l0aE5vTXVsdAMFDHNlbmRUb09yaWdpbggFAWkMb3JpZ2luQ2FsbGVyCAUBaQZjYWxsZXIJAM4IAgUGcmVzdWx0CQDMCAIJAQRCdXJuAgkBDHRyeUdldEJpbmFyeQECE2dsb2JhbF9wb29sVG9rZW5faWQFEVBSZWRlZW1lZFdpdGhNdWx0CQDMCAIJAQxJbnRlZ2VyRW50cnkCAhdnbG9iYWxfcG9vbFRva2VuX2Ftb3VudAkAZQIJAQ10cnlHZXRJbnRlZ2VyAQIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQFEVBSZWRlZW1lZFdpdGhNdWx0BQNuaWwBaQEKc3Rha2VJbmRleAAECmFkZHJlc3NTdHIJAKUIAQgFAWkMb3JpZ2luQ2FsbGVyBANwbXQJAJEDAggFAWkIcGF5bWVudHMAAAMJAQIhPQIJAQV2YWx1ZQEIBQNwbXQHYXNzZXRJZAkBDHRyeUdldEJpbmFyeQECE2dsb2JhbF9wb29sVG9rZW5faWQJAAIBAhR3cm9uZyBhc3NldCBhdHRhY2hlZAkBEGluZGV4U3Rha2VSZXN1bHQCBQphZGRyZXNzU3RyCAUDcG10BmFtb3VudAFpAQ1zdGFrZUluZGV4Rm9yAQphZGRyZXNzU3RyBANwbXQJAJEDAggFAWkIcGF5bWVudHMAAAMJAQIhPQIJAQV2YWx1ZQEIBQNwbXQHYXNzZXRJZAkBDHRyeUdldEJpbmFyeQECE2dsb2JhbF9wb29sVG9rZW5faWQJAAIBAhR3cm9uZyBhc3NldCBhdHRhY2hlZAkBEGluZGV4U3Rha2VSZXN1bHQCBQphZGRyZXNzU3RyCAUDcG10BmFtb3VudAFpAQx1bnN0YWtlSW5kZXgBC2luZGV4QW1vdW50BAphZGRyZXNzU3RyAwkBAiE9AgkAswkCBQ9sYXllcjJBZGRyZXNzZXMJAKUIAQgFAWkGY2FsbGVyBQR1bml0CQClCAEIBQFpDG9yaWdpbkNhbGxlcgkApQgBCAUBaQZjYWxsZXIEDmluZGV4QXZhaWxhYmxlCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgUKYWRkcmVzc1N0cgIMX2luZGV4U3Rha2VkAwkBCmlzU2h1dGRvd24ACQACAQITY29udHJhY3QgaXMgb24gc3RvcAMJAGYCBQtpbmRleEFtb3VudAUOaW5kZXhBdmFpbGFibGUJAAIBAiV5b3UgZG9uJ3QgaGF2ZSBpbmRleCB0b2tlbnMgYXZhaWxhYmxlAwkBCmlzU2h1dGRvd24ACQACAQITY29udHJhY3QgaXMgb24gc3RvcAkAzggCCAkBC2NsYWltUmVzdWx0AQkBEUBleHRyTmF0aXZlKDEwNjIpAQUKYWRkcmVzc1N0cgJfMQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQphZGRyZXNzU3RyAgxfaW5kZXhTdGFrZWQJAGUCBQ5pbmRleEF2YWlsYWJsZQULaW5kZXhBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQICEmdsb2JhbF9pbmRleFN0YWtlZAkAZQIJAQ10cnlHZXRJbnRlZ2VyAQISZ2xvYmFsX2luZGV4U3Rha2VkBQtpbmRleEFtb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFC2luZGV4QW1vdW50CQERQGV4dHJOYXRpdmUoMTA1NykBAhNnbG9iYWxfcG9vbFRva2VuX2lkBQNuaWwBaQERY2xhaW1JbmRleFJld2FyZHMAAwkBCmlzU2h1dGRvd24ACQACAQITY29udHJhY3QgaXMgb24gc3RvcAkBC2NsYWltUmVzdWx0AQgFAWkGY2FsbGVyAWkBDWV2YWx1YXRlQ2xhaW0BBHVzZXIJAJQKAgUDbmlsCAkBC2NsYWltUmVzdWx0AQkBEUBleHRyTmF0aXZlKDEwNjIpAQUEdXNlcgJfMgFpAQRzd2FwAghhc3NldE91dAdtaW5pbXVtBANwbXQDCQAAAgkAkAMBCAUBaQhwYXltZW50cwABCQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAJAAIBAiFwbGVhc2UgYXR0YWNoIGV4YWN0bHkgb25lIHBheW1lbnQECEFtb3VudEluCQEFdmFsdWUBCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQHQXNzZXRJbggFA3BtdAdhc3NldElkBAhBc3NldE91dAkBDWdldEFzc2V0Qnl0ZXMBBQhhc3NldE91dAQHYXNzZXRJbgkBDmdldEFzc2V0U3RyaW5nAQUHQXNzZXRJbgQHc2NhbGVJbgkAaQIFBlNjYWxlOAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHc3RhdGljXwUHYXNzZXRJbgIGX3NjYWxlBAhzY2FsZU91dAkAaQIFBlNjYWxlOAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHc3RhdGljXwUIYXNzZXRPdXQCBl9zY2FsZQQOZmVlQXNzZXRPdXRTdHIJAQx0cnlHZXRTdHJpbmcBAg9zdGF0aWNfZmVlVG9rZW4EC2ZlZUFzc2V0T3V0AwkAAAIFDmZlZUFzc2V0T3V0U3RyAgAFC3VzZG5Bc3NldElkCQENZ2V0QXNzZXRCeXRlcwEFDmZlZUFzc2V0T3V0U3RyBA5Bc3NldEluQmFsYW5jZQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwkBDmdldEFzc2V0U3RyaW5nAQUHQXNzZXRJbgIIX2JhbGFuY2UED0Fzc2V0T3V0QmFsYW5jZQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwUIYXNzZXRPdXQCCF9iYWxhbmNlBBRBc3NldEluQmFsYW5jZVNjYWxlZAkAaAIFDkFzc2V0SW5CYWxhbmNlBQdzY2FsZUluBBVBc3NldE91dEJhbGFuY2VTY2FsZWQJAGgCBQ9Bc3NldE91dEJhbGFuY2UFCHNjYWxlT3V0BAtmZWVBbW91bnRJbgkAawMFCEFtb3VudEluBQNGZWUFCEZlZVNjYWxlBA1jbGVhbkFtb3VudEluCQBlAgUIQW1vdW50SW4FC2ZlZUFtb3VudEluBBNjbGVhbkFtb3VudEluU2NhbGVkCQBoAgUNY2xlYW5BbW91bnRJbgUHc2NhbGVJbgQKQW1vdW50T3V0MQkBEmNhbGN1bGF0ZU91dEFtb3VudAUFE2NsZWFuQW1vdW50SW5TY2FsZWQFB0Fzc2V0SW4FCEFzc2V0T3V0BRRBc3NldEluQmFsYW5jZVNjYWxlZAUVQXNzZXRPdXRCYWxhbmNlU2NhbGVkBAlBbW91bnRPdXQJAGsDBQpBbW91bnRPdXQxAAEFCHNjYWxlT3V0BBBBc3NldE91dEJhbGFuY2UyCQBlAgUPQXNzZXRPdXRCYWxhbmNlBQlBbW91bnRPdXQED0Fzc2V0SW5CYWxhbmNlMgkAZAIFDkFzc2V0SW5CYWxhbmNlBQ1jbGVhbkFtb3VudEluBBJmZWVBc3NldE91dEJhbGFuY2UDCQAAAgULZmVlQXNzZXRPdXQFB0Fzc2V0SW4FD0Fzc2V0SW5CYWxhbmNlMgMJAAACBQtmZWVBc3NldE91dAUIQXNzZXRPdXQFEEFzc2V0T3V0QmFsYW5jZTIJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFC2ZlZUFzc2V0T3V0AghfYmFsYW5jZQQMZmVlQW1vdW50T3V0CQESY2FsY3VsYXRlT3V0QW1vdW50BQULZmVlQW1vdW50SW4FB0Fzc2V0SW4FC2ZlZUFzc2V0T3V0BQ5Bc3NldEluQmFsYW5jZQUSZmVlQXNzZXRPdXRCYWxhbmNlAwkAZgIFB21pbmltdW0FCUFtb3VudE91dAkAAgECKWFtb3VudCB0byByZWNpZXZlIGlzIGxvd2VyIHRoYW4gZ2l2ZW4gb25lAwkAAAIFCEFzc2V0T3V0BQdBc3NldEluCQACAQIYdGhpcyBzd2FwIGlzIG5vdCBhbGxvd2VkAwkAZgIAAAkAZQIFD0Fzc2V0T3V0QmFsYW5jZQUJQW1vdW50T3V0CQACAQIbY29udHJhY3QgaXMgb3V0IG9mIHJlc2VydmVzAwkBCmlzU2h1dGRvd24ACQACAQITY29udHJhY3QgaXMgb24gc3RvcAQKY3JlYXRvckZlZQkAawMFDGZlZUFtb3VudE91dAABAAoEC3Byb3RvY29sRmVlCQBrAwUMZmVlQW1vdW50T3V0AAQACgQMbmV3QmFsYW5jZUluBQ9Bc3NldEluQmFsYW5jZTIEDW5ld0JhbGFuY2VPdXQJAGUCBRBBc3NldE91dEJhbGFuY2UyAwkAAAIFCEFzc2V0T3V0BQtmZWVBc3NldE91dAUMZmVlQW1vdW50T3V0AAAEEm5ld0JhbGFuY2VGZWVBc3NldAMDCQECIT0CBQtmZWVBc3NldE91dAUHQXNzZXRJbgkBAiE9AgULZmVlQXNzZXRPdXQFCEFzc2V0T3V0BwkAZQIFEmZlZUFzc2V0T3V0QmFsYW5jZQUMZmVlQW1vdW50T3V0BQR1bml0BA1hc3NldEluQ2hhbmdlCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICB2dsb2JhbF8JAQ5nZXRBc3NldFN0cmluZwEFB0Fzc2V0SW4CCF9iYWxhbmNlBQxuZXdCYWxhbmNlSW4EDmFzc2V0T3V0Q2hhbmdlCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICB2dsb2JhbF8FCGFzc2V0T3V0AghfYmFsYW5jZQUNbmV3QmFsYW5jZU91dAQRZmVlQXNzZXRPdXRDaGFuZ2UDCQECIT0CBRJuZXdCYWxhbmNlRmVlQXNzZXQFBHVuaXQJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIHZ2xvYmFsXwkBDmdldEFzc2V0U3RyaW5nAQULZmVlQXNzZXRPdXQCCF9iYWxhbmNlCQEFdmFsdWUBBRJuZXdCYWxhbmNlRmVlQXNzZXQJAQtTdHJpbmdFbnRyeQICBWhlbGxvAgV3b3JsZAQMdm9sdW1lVXBkYXRlCQESY2FsY3VsYXRlVXNkblZhbHVlBAUHQXNzZXRJbgUIQW1vdW50SW4FDkFzc2V0SW5CYWxhbmNlBRJmZWVBc3NldE91dEJhbGFuY2UED3ZvbHVtZVVzZFVwZGF0ZQkBEWNhbGN1bGF0ZVVzZFZhbHVlAwUHQXNzZXRJbgUIQW1vdW50SW4FDkFzc2V0SW5CYWxhbmNlCQCUCgIJAMwIAgUOYXNzZXRPdXRDaGFuZ2UJAMwIAgUNYXNzZXRJbkNoYW5nZQkAzAgCBRFmZWVBc3NldE91dENoYW5nZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFCUFtb3VudE91dAUIQXNzZXRPdXQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBDHRyeUdldFN0cmluZwECEHN0YXRpY19wb29sT3duZXIFCmNyZWF0b3JGZWUFC2ZlZUFzc2V0T3V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCAhRnbG9iYWxfZWFybmVkQnlPd25lcgkAZAIJAQ10cnlHZXRJbnRlZ2VyAQIUZ2xvYmFsX2Vhcm5lZEJ5T3duZXIFCmNyZWF0b3JGZWUJAMwIAgkBDEludGVnZXJFbnRyeQICDWdsb2JhbF92b2x1bWUJAGQCCQENdHJ5R2V0SW50ZWdlcgECDWdsb2JhbF92b2x1bWUFDHZvbHVtZVVwZGF0ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgIRZ2xvYmFsX3ZvbHVtZV91c2QJAGQCCQENdHJ5R2V0SW50ZWdlcgECEWdsb2JhbF92b2x1bWVfdXNkBQ92b2x1bWVVc2RVcGRhdGUJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwULZmVlc0FkZHJlc3MFC3Byb3RvY29sRmVlBQtmZWVBc3NldE91dAUDbmlsBQlBbW91bnRPdXQBaQEMc3dhcFJlYWRPbmx5Awdhc3NldEluCGFzc2V0T3V0CEFtb3VudEluBAdBc3NldEluCQENZ2V0QXNzZXRCeXRlcwEFB2Fzc2V0SW4ECEFzc2V0T3V0CQENZ2V0QXNzZXRCeXRlcwEFCGFzc2V0T3V0BAdzY2FsZUluCQBpAgUGU2NhbGU4CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdzdGF0aWNfBQdhc3NldEluAgZfc2NhbGUECHNjYWxlT3V0CQBpAgUGU2NhbGU4CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdzdGF0aWNfBQhhc3NldE91dAIGX3NjYWxlBA5mZWVBc3NldE91dFN0cgkBDHRyeUdldFN0cmluZwECD3N0YXRpY19mZWVUb2tlbgQLZmVlQXNzZXRPdXQDCQAAAgUOZmVlQXNzZXRPdXRTdHICAAULdXNkbkFzc2V0SWQJAQ1nZXRBc3NldEJ5dGVzAQUOZmVlQXNzZXRPdXRTdHIEDkFzc2V0SW5CYWxhbmNlCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfCQEOZ2V0QXNzZXRTdHJpbmcBBQdBc3NldEluAghfYmFsYW5jZQQPQXNzZXRPdXRCYWxhbmNlCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdnbG9iYWxfBQhhc3NldE91dAIIX2JhbGFuY2UEFEFzc2V0SW5CYWxhbmNlU2NhbGVkCQBoAgUOQXNzZXRJbkJhbGFuY2UFB3NjYWxlSW4EFUFzc2V0T3V0QmFsYW5jZVNjYWxlZAkAaAIFD0Fzc2V0T3V0QmFsYW5jZQUIc2NhbGVPdXQEC2ZlZUFtb3VudEluCQBrAwUIQW1vdW50SW4FA0ZlZQUIRmVlU2NhbGUEDWNsZWFuQW1vdW50SW4JAGUCBQhBbW91bnRJbgULZmVlQW1vdW50SW4EE2NsZWFuQW1vdW50SW5TY2FsZWQJAGgCBQ1jbGVhbkFtb3VudEluBQdzY2FsZUluBApBbW91bnRPdXQxCQESY2FsY3VsYXRlT3V0QW1vdW50BQUTY2xlYW5BbW91bnRJblNjYWxlZAUHQXNzZXRJbgUIQXNzZXRPdXQFFEFzc2V0SW5CYWxhbmNlU2NhbGVkBRVBc3NldE91dEJhbGFuY2VTY2FsZWQECUFtb3VudE91dAkAawMFCkFtb3VudE91dDEAAQUIc2NhbGVPdXQEEEFzc2V0T3V0QmFsYW5jZTIJAGUCBQ9Bc3NldE91dEJhbGFuY2UFCUFtb3VudE91dAQPQXNzZXRJbkJhbGFuY2UyCQBkAgUOQXNzZXRJbkJhbGFuY2UFDWNsZWFuQW1vdW50SW4EEmZlZUFzc2V0T3V0QmFsYW5jZQMJAAACBQtmZWVBc3NldE91dAUHQXNzZXRJbgUPQXNzZXRJbkJhbGFuY2UyAwkAAAIFC2ZlZUFzc2V0T3V0BQhBc3NldE91dAUQQXNzZXRPdXRCYWxhbmNlMgkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwkBDmdldEFzc2V0U3RyaW5nAQULZmVlQXNzZXRPdXQCCF9iYWxhbmNlBAxmZWVBbW91bnRPdXQJARJjYWxjdWxhdGVPdXRBbW91bnQFBQtmZWVBbW91bnRJbgUHQXNzZXRJbgULZmVlQXNzZXRPdXQFDkFzc2V0SW5CYWxhbmNlBRJmZWVBc3NldE91dEJhbGFuY2UDCQAAAgUIQXNzZXRPdXQFB0Fzc2V0SW4JAAIBAhh0aGlzIHN3YXAgaXMgbm90IGFsbG93ZWQDCQBmAgAACQBlAgUPQXNzZXRPdXRCYWxhbmNlBQlBbW91bnRPdXQJAAIBAhtjb250cmFjdCBpcyBvdXQgb2YgcmVzZXJ2ZXMDCQEKaXNTaHV0ZG93bgAJAAIBAhNjb250cmFjdCBpcyBvbiBzdG9wCQCUCgIFA25pbAUJQW1vdW50T3V0AWkBEXRyYW5zZmVyT3duZXJzaGlwAQ9uZXdPd25lckFkZHJlc3MDCQECIT0CCQClCAEIBQFpBmNhbGxlcgkBDHRyeUdldFN0cmluZwECEHN0YXRpY19wb29sT3duZXIJAAIBAid0aGlzIGNhbGwgYXZhaWxhYmxlIG9ubHkgZm9yIHBvb2wgb3duZXIJAMwIAgkBC1N0cmluZ0VudHJ5AgIQc3RhdGljX3Bvb2xPd25lcgUPbmV3T3duZXJBZGRyZXNzBQNuaWwBaQEGc2V0RmVlAQZuZXdGZWUDCQECIT0CCQClCAEIBQFpBmNhbGxlcgkBDHRyeUdldFN0cmluZwECEHN0YXRpY19wb29sT3duZXIJAAIBAid0aGlzIGNhbGwgYXZhaWxhYmxlIG9ubHkgZm9yIHBvb2wgb3duZXIDCQBmAgABCQELdmFsdWVPckVsc2UCCQCaCAIFCmdvdkFkZHJlc3MJAKwCAgILYXBwcm92ZWRUeF8JANgEAQgFAWkNdHJhbnNhY3Rpb25JZAAACQACAQIzdGhpcyB0cmFuc2FjdGlvbiBuZWVkcyBhcHByb3ZhbCBmcm9tIHB1enpsZSBuZXR3b3JrCQDMCAIJAQxJbnRlZ2VyRW50cnkCAgpzdGF0aWNfZmVlBQZuZXdGZWUFA25pbAFpARJzZXRSZWJhbGFuY2luZ1BsYW4FC2Fzc2V0SWRzU3RyD2Fzc2V0V2VpZ2h0c1N0cg5iYXNlVG9rZW5JZFN0cgtzdGVwc0Ftb3VudA1zdGVwc0ludGVydmFsAwkBAiE9AggFAWkGY2FsbGVyCQERQGV4dHJOYXRpdmUoMTA2MikBCQEMdHJ5R2V0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C2FkZGVkQXNzZXRzCAUBaQhwYXltZW50cwQMdmFsaWRXZWlnaHRzCQEPdmFsaWRhdGVXZWlnaHRzAQUUbmV3QXNzZXRXZWlnaHRzU3RyTGkDCQAAAgUMdmFsaWRXZWlnaHRzBQx2YWxpZFdlaWdodHMDCQECIT0CBQ12YWxpZFBheW1lbnRzCQBkAgkAkAMBBQthZGRlZEFzc2V0cwkAkAMBCAUBaQhwYXltZW50cwkAAgECMVBheW1lbnRzIG5vdCBwcmVzZW50IG9yIHNvbWV0aGluZyB3cm9uZyB3aXRoIHRoZW0DCQECIT0CCQCQAwEFEG5ld0Fzc2V0SWRzU3RyTGkJAJADAQUUbmV3QXNzZXRXZWlnaHRzU3RyTGkJAAIBAjFhc3NldElkcyBhbmQgYXNzZXRXZWlnaHRzIHNob3VsZCBoYXZlIHNhbWUgbGVuZ3RoAwkBAiE9AgUNdmFsaWRQYXltZW50cwkAZAIJAJADAQULYWRkZWRBc3NldHMJAJADAQgFAWkIcGF5bWVudHMJAAIBAjFQYXltZW50cyBub3QgcHJlc2VudCBvciBzb21ldGhpbmcgd3Jvbmcgd2l0aCB0aGVtAwkAAAIFC2ZlZUFzc2V0U3RyAgAJAAIBAkFwb29sIG11c3QgaGF2ZSBvbmUgb2YgdGhlIHN1cHBvcnRlZCBmZWUgYXNzZXRzIGluIHRoZSBjb21wb3NpdGlvbgMJAAACCQDPCAIFEG5ld0Fzc2V0SWRzU3RyTGkFDmJhc2VUb2tlbklkU3RyBQR1bml0CQACAQIpYmFzZVRva2VuSWQgc2hvdWxkIGJlIHByZXNlbnQgaW4gYXNzZXRJZHMDAwkAZgIFEE1JTl9TVEVQU19BTU9VTlQFC3N0ZXBzQW1vdW50BgkAZgIFC3N0ZXBzQW1vdW50BRBNQVhfU1RFUFNfQU1PVU5UCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgICH1N0ZXBzIGFtb3VudCBzaG91bGQgYmUgYmV0d2VlbiAJAKQDAQUQTUlOX1NURVBTX0FNT1VOVAIFIGFuZCAJAKQDAQUQTUFYX1NURVBTX0FNT1VOVAILLCBjdXJyZW50OiAJAKQDAQULc3RlcHNBbW91bnQDAwkAZgIFEk1JTl9TVEVQU19JTlRFUlZBTAUNc3RlcHNJbnRlcnZhbAYJAGYCBQ1zdGVwc0ludGVydmFsBRJNQVhfU1RFUFNfSU5URVJWQUwJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIhU3RlcHMgaW50ZXJ2YWwgc2hvdWxkIGJlIGJldHdlZW4gCQCkAwEFEk1JTl9TVEVQU19JTlRFUlZBTAIFIGFuZCAJAKQDAQUSTUFYX1NURVBTX0lOVEVSVkFMAgssIGN1cnJlbnQ6IAkApAMBBQ1zdGVwc0ludGVydmFsAwkBAiE9AgUPYXNzZXRXZWlnaHRzU3VtAJBOCQACAQkArAICAjZzdW0gb2YgdG9rZW4gd2VpZ2h0cyBtdXN0IGJlIGVxdWFsIHRvIDEwMDAwLCBjdXJyZW50OiAJAKQDAQUPYXNzZXRXZWlnaHRzU3VtCgEBZgIFYWNjdW0KYXNzZXRJZFN0cgQJb2xkV2VpZ2h0CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgdzdGF0aWNfBQphc3NldElkU3RyAgdfd2VpZ2h0BAluZXdXZWlnaHQDCQAAAgkAzwgCBRBuZXdBc3NldElkc1N0ckxpBQphc3NldElkU3RyBQR1bml0AAAJAQ1wYXJzZUludFZhbHVlAQkBBXZhbHVlAQkAkQMCBRRuZXdBc3NldFdlaWdodHNTdHJMaQkBBXZhbHVlAQkAzwgCBRBuZXdBc3NldElkc1N0ckxpBQphc3NldElkU3RyBAxkZWx0YVBlclN0ZXAJAGsDCQBlAgUJbmV3V2VpZ2h0BQlvbGRXZWlnaHQAkE4FC3N0ZXBzQW1vdW50CQDOCAIFBWFjY3VtCQDMCAIJAKQDAQUMZGVsdGFQZXJTdGVwBQNuaWwEDXRtcEFzc2V0SWRzTGkJARJnZXRUbXBSZWJhbGFuY2VJZHMBBRBuZXdBc3NldElkc1N0ckxpBAthc3NldERlbHRhcwoAAiRsBQ10bXBBc3NldElkc0xpCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGY4XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQFmAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY4XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmOF8yAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBA5uZXdUb2tlbnNBZGRlZAkAZgIJARFjaGVja1Rva2Vuc0NoYW5nZQEFEG5ld0Fzc2V0SWRzU3RyTGkAAAoBEnJlY29yZEFzc2V0UGF5bWVudAIFYWNjdW0EbmV4dAkAzggCBQVhY2N1bQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICAhpyZWJhbGFuY2VfYXR0YWNoZWRQYXltZW50XwkBDmdldEFzc2V0U3RyaW5nAQgFBG5leHQHYXNzZXRJZAgFBG5leHQGYW1vdW50BQNuaWwEDnBheW1lbnRFbnRyaWVzCgACJGwIBQFpCHBheW1lbnRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGY5XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARJyZWNvcmRBc3NldFBheW1lbnQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjlfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY5XzICCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECCQEFJGY5XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoEDHN0b3JlV2VpZ2h0cwkBEnNhdmVDdXJyZW50V2VpZ2h0cwAEEHJlcXVlc3RHb3ZJbnZva2UJAPwHBAUKZ292QWRkcmVzcwIScmVxdWVzdFJlYmFsYW5jaW5nCQDMCAIJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAUDbmlsBQNuaWwDCQAAAgUQcmVxdWVzdEdvdkludm9rZQUQcmVxdWVzdEdvdkludm9rZQkAzggCCQDOCAIJAMwIAgkBC1N0cmluZ0VudHJ5AgIVcmViYWxhbmNlX2FkZGVkQXNzZXRzCQC5CQIFC2FkZGVkQXNzZXRzAgEsCQDMCAIJAQtTdHJpbmdFbnRyeQICF3JlYmFsYW5jZV9yZW1vdmVkQXNzZXRzCQC5CQIFDXJlbW92ZWRBc3NldHMCASwJAMwIAgkBC1N0cmluZ0VudHJ5AgIVdG1wX3JlYmFsYW5jZUFzc2V0SWRzCQC5CQIFDXRtcEFzc2V0SWRzTGkCASwJAMwIAgkBDEJvb2xlYW5FbnRyeQICFHJlYmFsYW5jZV9pblByb2dyZXNzBgkAzAgCCQEMQm9vbGVhbkVudHJ5AgIYcmViYWxhbmNlX25ld1Rva2Vuc0FkZGVkBQ5uZXdUb2tlbnNBZGRlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgITcmViYWxhbmNlX3N0ZXBzRG9uZQAACQDMCAIJAQxJbnRlZ2VyRW50cnkCAhhyZWJhbGFuY2VfbGFzdFN0ZXBIZWlnaHQFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgIVcmViYWxhbmNlX3N0ZXBzQW1vdW50BQtzdGVwc0Ftb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgIXcmViYWxhbmNlX3N0ZXBzSW50ZXJ2YWwFDXN0ZXBzSW50ZXJ2YWwJAMwIAgkBC1N0cmluZ0VudHJ5AgIScmViYWxhbmNlX2Fzc2V0SWRzBQthc3NldElkc1N0cgkAzAgCCQELU3RyaW5nRW50cnkCAhhyZWJhbGFuY2VfbmV3QmFzZVRva2VuSWQFDmJhc2VUb2tlbklkU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQICFXJlYmFsYW5jZV9hc3NldERlbHRhcwkAuQkCBQthc3NldERlbHRhcwIBLAUDbmlsBQ5wYXltZW50RW50cmllcwUMc3RvcmVXZWlnaHRzCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBD3N0ZXBSZWJhbGFuY2luZwAEBXJlYklkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUKZ292QWRkcmVzcwkArAICAhVwb29sX2xhc3RSZWJhbGFuY2luZ18JAKUIAQUEdGhpcwIscmViYWxhbmNpbmcgaXMgbm90IHJlZ2lzdGVyZWQgYXQgZ292IGFkZHJlc3MDCQEBIQEJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwIUcmViYWxhbmNlX2luUHJvZ3Jlc3MHCQACAQIabm8gcmViYWxhbmNpbmcgaW4gcHJvZ3Jlc3MDCQECIT0CCQELdmFsdWVPckVsc2UCCQCaCAIFCmdvdkFkZHJlc3MJAKwCAgITcmViYWxhbmNpbmdfc3RhdHVzXwUFcmViSWQAAAACCQACAQIzdGhpcyB0cmFuc2FjdGlvbiBuZWVkcyBhcHByb3ZhbCBmcm9tIHB1enpsZSBuZXR3b3JrBA5sYXN0U3RlcEhlaWdodAkBEUBleHRyTmF0aXZlKDEwNTUpAQIYcmViYWxhbmNlX2xhc3RTdGVwSGVpZ2h0BAxzdGVwSW50ZXJ2YWwJARFAZXh0ck5hdGl2ZSgxMDU1KQECF3JlYmFsYW5jZV9zdGVwc0ludGVydmFsBAlzdGVwc0RvbmUJARFAZXh0ck5hdGl2ZSgxMDU1KQECE3JlYmFsYW5jZV9zdGVwc0RvbmUEDm5leHRTdGVwSGVpZ2h0CQBkAgUObGFzdFN0ZXBIZWlnaHQFDHN0ZXBJbnRlcnZhbAMJAGYCBQ5uZXh0U3RlcEhlaWdodAUGaGVpZ2h0CQACAQIRY2FuJ3QgYmUgZG9uZSB5ZXQEC2Fzc2V0RGVsdGFzCQC1CQIJARFAZXh0ck5hdGl2ZSgxMDU4KQECFXJlYmFsYW5jZV9hc3NldERlbHRhcwIBLAQObmV3QXNzZXRJZHNTdHIJARFAZXh0ck5hdGl2ZSgxMDU4KQECFXRtcF9yZWJhbGFuY2VBc3NldElkcwQLbmV3QXNzZXRJZHMJALUJAgUObmV3QXNzZXRJZHNTdHICASwKAQFmAgVhY2N1bQphc3NldElkU3RyCQDOCAIFBWFjY3VtCQDMCAIJAKQDAQkAbgQJAGQCCQBoAgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQCsAgICFnJlYmFsYW5jZV9zdGFydFdlaWdodF8FCmFzc2V0SWRTdHIAAACQTgkAaAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQthc3NldERlbHRhcwkBBXZhbHVlAQkAzwgCBQtuZXdBc3NldElkcwUKYXNzZXRJZFN0cgkAZAIFCXN0ZXBzRG9uZQABAAEAkE4FBkhBTEZVUAUDbmlsBAluZXdTaGFyZXMJALkJAgoAAiRsBQtuZXdBc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmNF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEBZgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmNF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjRfMgIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIJAQUkZjRfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgIBLAQObmV3VG9rZW5zQWRkZWQJARFAZXh0ck5hdGl2ZSgxMDU2KQECGHJlYmFsYW5jZV9uZXdUb2tlbnNBZGRlZAQDaW52AwMFDm5ld1Rva2Vuc0FkZGVkCQAAAgUJc3RlcHNEb25lAAAHCQD8BwQFBHRoaXMCGmRvUmViYWxhbmNpbmdXaXRoTmV3VG9rZW5zCQDMCAIFDm5ld0Fzc2V0SWRzU3RyCQDMCAIFCW5ld1NoYXJlcwkAzAgCCQERQGV4dHJOYXRpdmUoMTA1OCkBAhhyZWJhbGFuY2VfbmV3QmFzZVRva2VuSWQFA25pbAUDbmlsCQD8BwQFBHRoaXMCDWRvUmViYWxhbmNpbmcJAMwIAgUJbmV3U2hhcmVzBQNuaWwFA25pbAMJAAACBQNpbnYFA2ludgQMbm90aWZ5SW52b2tlCQD8BwQFD3Bvb2xzSHViQWRkcmVzcwIQbm90aWZ5UG9vbENoYW5nZQUDbmlsBQNuaWwDCQAAAgUMbm90aWZ5SW52b2tlBQxub3RpZnlJbnZva2UECmlzRmluaXNoZWQJAGcCCQBkAgUJc3RlcHNEb25lAAEJARFAZXh0ck5hdGl2ZSgxMDU1KQECFXJlYmFsYW5jZV9zdGVwc0Ftb3VudAQHYWN0aW9ucwkAzAgCCQEMQm9vbGVhbkVudHJ5AgIUcmViYWxhbmNlX2luUHJvZ3Jlc3MJAQEhAQUKaXNGaW5pc2hlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgITcmViYWxhbmNlX3N0ZXBzRG9uZQkAZAIFCXN0ZXBzRG9uZQABCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhhyZWJhbGFuY2VfbGFzdFN0ZXBIZWlnaHQFBmhlaWdodAUDbmlsAwkAAAIFCXN0ZXBzRG9uZQAACQDOCAIFB2FjdGlvbnMJAMwIAgkBC1N0cmluZ0VudHJ5AgIPc3RhdGljX3Rva2VuSWRzBQ5uZXdBc3NldElkc1N0cgUDbmlsAwUKaXNGaW5pc2hlZAQPcmVtb3ZlZEFzc2V0c0xpCQC1CQIJAQx0cnlHZXRTdHJpbmcBAhdyZWJhbGFuY2VfcmVtb3ZlZEFzc2V0cwIBLAoBBnJtRGF0YQIFYWNjdW0HYXNzZXRJZAkAzggCBQVhY2N1bQkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgIHc3RhdGljXwUHYXNzZXRJZAIGX3NjYWxlCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICAgdzdGF0aWNfBQdhc3NldElkAglfZGVjaW1hbHMJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgICB3N0YXRpY18FB2Fzc2V0SWQCB193ZWlnaHQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgICB2dsb2JhbF8FB2Fzc2V0SWQCCF9iYWxhbmNlCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgIacmViYWxhbmNlX2F0dGFjaGVkUGF5bWVudF8FB2Fzc2V0SWQFA25pbAQCcm0KAAIkbAUPcmVtb3ZlZEFzc2V0c0xpCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGY1XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQZybURhdGECBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjVfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY1XzICCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECCQEFJGY1XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoEDWFkZGVkQXNzZXRzTGkJALUJAgkBDHRyeUdldFN0cmluZwECFXJlYmFsYW5jZV9hZGRlZEFzc2V0cwIBLAoBEWFkZFJlbW92ZVBheW1lbnRzAgVhY2N1bQdhc3NldElkCQDOCAIFBWFjY3VtCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgIacmViYWxhbmNlX2F0dGFjaGVkUGF5bWVudF8FB2Fzc2V0SWQFA25pbAQKcm1QYXltZW50cwoAAiRsBQ1hZGRlZEFzc2V0c0xpCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGY2XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARFhZGRSZW1vdmVQYXltZW50cwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmNl8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjZfMgIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIJAQUkZjZfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgQRZmluYWxBc3NldHNJZHNTdHIJAQx0cnlHZXRTdHJpbmcBAhJyZWJhbGFuY2VfYXNzZXRJZHMEEEFzc2V0c1dlaWdodHNTdHIKAAIkbAkAtQkCBRFmaW5hbEFzc2V0c0lkc1N0cgIBLAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmN18xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEXYWRkQXNzZXRXZWlnaHRUb1N0ckxpc3QCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjdfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY3XzICCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoEBm5vdGlmeQkA/AcEBQpnb3ZBZGRyZXNzAhVub3RpZnlSZWJhbGFuY2luZ0RvbmUJAMwIAgUFcmViSWQFA25pbAUDbmlsAwkAAAIFBm5vdGlmeQUGbm90aWZ5CQDOCAIJAM4IAgkAzggCBQdhY3Rpb25zBQJybQUKcm1QYXltZW50cwkAzAgCCQELU3RyaW5nRW50cnkCAg9zdGF0aWNfdG9rZW5JZHMFEWZpbmFsQXNzZXRzSWRzU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQICE3N0YXRpY190b2tlbldlaWdodHMJALkJAgUQQXNzZXRzV2VpZ2h0c1N0cgIBLAkAzAgCCQEMSW50ZWdlckVudHJ5AgITc3RhdGljX3Rva2Vuc0Ftb3VudAkAkAMBCQC1CQIFEWZpbmFsQXNzZXRzSWRzU3RyAgEsBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EEWZpbmFsQXNzZXRzSWRzU3RyCQEMdHJ5R2V0U3RyaW5nAQIScmViYWxhbmNlX2Fzc2V0SWRzBBBBc3NldHNXZWlnaHRzU3RyCgACJGwJALUJAgURZmluYWxBc3NldHNJZHNTdHICASwKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjVfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBF2FkZEFzc2V0V2VpZ2h0VG9TdHJMaXN0AgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY1XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmNV8yAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgkBBSRmNV8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKCQDOCAIFB2FjdGlvbnMJAMwIAgkBC1N0cmluZ0VudHJ5AgITc3RhdGljX3Rva2VuV2VpZ2h0cwkAuQkCBRBBc3NldHNXZWlnaHRzU3RyAgEsBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQENZG9S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Y2VlZHMgMTAJAQUkZjdfMgIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIJAQUkZjdfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgQGd2VpZ2h0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUUbmV3QXNzZXRXZWlnaHRzU3RyTGkFCFRva2VuTnVtBA5iYWxhbmNlSW5TdGF0ZQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIHZ2xvYmFsXwUKYXNzZXRJZFN0cgIIX2JhbGFuY2UEEGJhbGFuY2VJblBheW1lbnQJAJEDAgUQYXR0YWNoZWRCYWxhbmNlcwUIVG9rZW5OdW0EB2JhbGFuY2UJAGQCBQ5iYWxhbmNlSW5TdGF0ZQUQYmFsYW5jZUluUGF5bWVudAQNYXNzZXREZWNpbWFscwMJAAACBQdhc3NldElkBQR1bml0AAgICQEFdmFsdWUBCQDsBwEJAQV2YWx1ZQEFB2Fzc2V0SWQIZGVjaW1hbHMDCQBnAgAABQdiYWxhbmNlCQACAQkArAICAkR5b3UgbmVlZCB0byBhdHRhY2ggYWxsIG5ldyBhc3NldHMgaW4gcGF5bWVudC4gdGhpcyBhc3NldCBpcyBtaXNzZWQ6IAUKYXNzZXRJZFN0cgkAawMFCGN1cnJlbnRLCQBsBgUHYmFsYW5jZQUNYXNzZXREZWNpbWFscwUGd2VpZ2h0BRVBc3NldHNXZWlnaHRzRGVjaW1hbHMACAUFRkxPT1IFBlNjYWxlOAQEbmV3SwoAAiRsBQtuZXdBc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFDlBvb2xUb2tlblNjYWxlCgEFJGY3XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARJteWx0aXBseUFzc2V0c0ZvcksCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjdfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGY3XzICCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECCQEFJGY3XzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoECG5ld0tNdWx0CQBrAwUIb2xkS011bHQFBG5ld0sFBG9sZEsKARNhZGRUb2tlbkRhdGFFbnRyaWVzAgVhY2N1bQhhc3NldE51bQQKYXNzZXRJZFN0cgkAkQMCBRBuZXdBc3NldElkc1N0ckxpBQhhc3NldE51bQQHYXNzZXRJZAkAkQMCBQtuZXdBc3NldElkcwUIYXNzZXROdW0EDWFzc2V0RGVjaW1hbHMDCQAAAgUHYXNzZXRJZAUEdW5pdAAICAkBBXZhbHVlAQkA7AcBCQEFdmFsdWUBBQdhc3NldElkCGRlY2ltYWxzBAxuZXdBc3NldERhdGEDCQECIT0CCQDPCAIFC2FkZGVkQXNzZXRzBQphc3NldElkU3RyBQR1bml0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIHZ2xvYmFsXwUKYXNzZXRJZFN0cgIIX2JhbGFuY2UJAJEDAgUQYXR0YWNoZWRCYWxhbmNlcwUIYXNzZXROdW0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdzdGF0aWNfBQphc3NldElkU3RyAgZfc2NhbGUJAGwGAAoAAAUNYXNzZXREZWNpbWFscwAAAAAFBERPV04JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgdzdGF0aWNfBQphc3NldElkU3RyAglfZGVjaW1hbHMFDWFzc2V0RGVjaW1hbHMFA25pbAUDbmlsAwkAZwIFCGFzc2V0TnVtCQCQAwEFFG5ld0Fzc2V0V2VpZ2h0c1N0ckxpBQVhY2N1bQkAzggCCQDOCAIFBWFjY3VtCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIHc3RhdGljXwUKYXNzZXRJZFN0cgIHX3dlaWdodAkBBXZhbHVlAQkAtgkBCQCRAwIFFG5ld0Fzc2V0V2VpZ2h0c1N0ckxpBQhhc3NldE51bQUDbmlsBQxuZXdBc3NldERhdGEJAM4IAgoAAiRsCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQUDbmlsCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGY4XzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARNhZGRUb2tlbkRhdGFFbnRyaWVzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGY4XzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmOF8yAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgkBBSRmOF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKCQDMCAIJAQtTdHJpbmdFbnRyeQICD3N0YXRpY190b2tlbklkcwULYXNzZXRJZHNTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgIPc3RhdGljX2ZlZVRva2VuBQtmZWVBc3NldFN0cgkAzAgCCQELU3RyaW5nRW50cnkCAhNzdGF0aWNfdG9rZW5XZWlnaHRzBQ9hc3NldFdlaWdodHNTdHIJAMwIAgkBDEludGVnZXJFbnRyeQICE3N0YXRpY190b2tlbnNBbW91bnQJAJADAQULbmV3QXNzZXRJZHMJAMwIAgkBDEludGVnZXJFbnRyeQICDHN0YXRpY19LTXVsdAUIbmV3S011bHQFA25pbAECdHgBBnZlcmlmeQADAwkAAAIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQITZ2xvYmFsX3dhc1ByZUluaXRlZAAAAAADCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMbWFzdGVyUHViS2V5BwYEByRtYXRjaDAFAnR4AwkAAQIFByRtYXRjaDACFFNldFNjcmlwdFRyYW5zYWN0aW9uBAJ0eAUHJG1hdGNoMAQKc2NyaXB0RnVsbAkBBXZhbHVlAQgFAnR4BnNjcmlwdAQEaGFzaAkA2AQBCQD3AwEFCnNjcmlwdEZ1bGwDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQxtYXN0ZXJQdWJLZXkJAGYCCQELdmFsdWVPckVsc2UCCQCaCAIFEWNvbGRNYXN0ZXJBZGRyZXNzCQCsAgICD2FwcHJvdmVkU2NyaXB0XwUEaGFzaAAABQZoZWlnaHQHAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMbWFzdGVyUHViS2V5CQBmAgkBC3ZhbHVlT3JFbHNlAgkAmggCBRFjb2xkTWFzdGVyQWRkcmVzcwkArAICAgthcHByb3ZlZFR4XwkA2AQBCAUCdHgCaWQAAAAAB6Uvdis=", "height": 3083188, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: G962JVNuyfmmhpcMJ75matmq1KfF4ATEZyPiHxShoVUM Next: none Diff:
OldNewDifferences
126126
127127 let L = valueOrElse(getString(c, "usdnAssetIdStr"), "25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT")
128128
129-let M = valueOrElse(getString(c, "puzzleAssetIdStr"), "HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS")
129+let M = valueOrElse(getString(c, "puzzleAssetIdStr"), "6fQRaL3L25nGqevXT8kxwjBS28fkBErrJ69JYcj7qKgW")
130130
131131 let N = valueOrElse(getString(c, "usdtAssetIdStr"), "5Sh9KghfkZyhjwuodovDhB6PghDUGBHiAPZ4MkrPgKtX")
132132
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = "PZ-1.2.3 PROD"
55
66 let b = valueOrElse(getString(this, "configAddress"), "3N2JpQfqth5eapbx8bHZ3eeCXGkNfcYEdyo")
77
88 let c = if ((b == ""))
99 then this
1010 else Address(fromBase58String(b))
1111
1212 let d = 4
1313
1414 let e = 10000
1515
1616 let f = 100000000
1717
1818 let g = 10000000000000000
1919
2020 let h = 10000
2121
2222 let i = 8
2323
2424 let j = pow(10, 0, i, 0, 0, HALFUP)
2525
2626 let k = valueOrElse(getInteger(c, "min_steps_amount"), 1)
2727
2828 let l = valueOrElse(getInteger(c, "max_steps_amount"), 500)
2929
3030 let m = valueOrElse(getInteger(c, "min_steps_interval"), 1)
3131
3232 let n = valueOrElse(getInteger(c, "max_steps_interval"), 10000)
3333
3434 let o = valueOrElse(getInteger(c, "min_weight"), 100)
3535
3636 let p = valueOrElse(getInteger(c, "max_weight"), 9900)
3737
3838 func q (r) = {
3939 let s = getInteger(this, r)
4040 if ($isInstanceOf(s, "Int"))
4141 then {
4242 let t = s
4343 t
4444 }
4545 else 0
4646 }
4747
4848
4949 func u (r) = {
5050 let s = getBinary(this, r)
5151 if ($isInstanceOf(s, "ByteVector"))
5252 then {
5353 let t = s
5454 t
5555 }
5656 else base58''
5757 }
5858
5959
6060 func v (r) = {
6161 let s = getString(this, r)
6262 if ($isInstanceOf(s, "String"))
6363 then {
6464 let t = s
6565 t
6666 }
6767 else ""
6868 }
6969
7070
7171 func w (r) = {
7272 let s = getString(this, r)
7373 if ($isInstanceOf(s, "String"))
7474 then {
7575 let t = s
7676 t
7777 }
7878 else throw(("no such key in data storage: " + r))
7979 }
8080
8181
8282 func x (y) = {
8383 let s = y
8484 if ($isInstanceOf(s, "ByteVector"))
8585 then {
8686 let t = s
8787 toBase58String(t)
8888 }
8989 else "WAVES"
9090 }
9191
9292
9393 func z (A) = if ((A == "WAVES"))
9494 then unit
9595 else fromBase58String(A)
9696
9797
9898 func B (y) = {
9999 let s = y
100100 if ($isInstanceOf(s, "ByteVector"))
101101 then {
102102 let C = s
103103 assetBalance(this, C)
104104 }
105105 else wavesBalance(this).available
106106 }
107107
108108
109109 func D (E,F) = (E ++ [z(F)])
110110
111111
112112 func G (E,F) = (E ++ [q((("static_" + x(F)) + "_weight"))])
113113
114114
115115 func H (E,F) = (E ++ [toString(q((("static_" + F) + "_weight")))])
116116
117117
118118 func I (E,F) = (E ++ [q((("static_" + x(F)) + "_decimals"))])
119119
120120
121121 func J (E,F) = (E ++ [q((("static_" + x(F)) + "_scale"))])
122122
123123
124124 func K (E,F) = (E ++ [parseIntValue(F)])
125125
126126
127127 let L = valueOrElse(getString(c, "usdnAssetIdStr"), "25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT")
128128
129-let M = valueOrElse(getString(c, "puzzleAssetIdStr"), "HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS")
129+let M = valueOrElse(getString(c, "puzzleAssetIdStr"), "6fQRaL3L25nGqevXT8kxwjBS28fkBErrJ69JYcj7qKgW")
130130
131131 let N = valueOrElse(getString(c, "usdtAssetIdStr"), "5Sh9KghfkZyhjwuodovDhB6PghDUGBHiAPZ4MkrPgKtX")
132132
133133 let O = valueOrElse(getString(c, "usdtPptAssetIdStr"), "DK8RCKSRv6xovfYciiXgz82Apiu1tiEraH3iBSeZmAhp")
134134
135135 let P = valueOrElse(getString(c, "romeAssetIdStr"), "CYZRD5FtNKwUU4zhn31WPEmdUXkXmGE1uLP8UZhMscHT")
136136
137137 let Q = "WAVES"
138138
139139 let R = fromBase58String(L)
140140
141141 let S = fromBase58String(M)
142142
143143 let T = fromBase58String(N)
144144
145145 let U = fromBase58String(O)
146146
147147 let V = fromBase58String(P)
148148
149149 let W = unit
150150
151151 let X = [L, M, N, O, Q, P]
152152
153153 let Y = Address(fromBase58String(valueOrElse(getString(c, "parentPoolAddress"), "3MyQLTCnK3Ui4Rm2ZYASb8e7EMqwLsHhZpb")))
154154
155155 let Z = Address(fromBase58String(valueOrElse(getString(c, "masterAddress"), "3N2EacY3tD89zCPRzSsW87ALMXUPA3oELpd")))
156156
157157 let aa = fromBase58String(valueOrElse(getString(c, "masterPubKey"), "EUFrMfKMM9ihGe6ksyYMGXAvKW81yu3AxHc8NGVQSJH4"))
158158
159159 let ab = Address(fromBase58String(valueOrElse(getString(c, "oracleAddress"), "3Mr3heaFrZeT4iMafu9ahjvXwjQ7XqeWAeR")))
160160
161161 let ac = Address(fromBase58String(valueOrElse(getString(c, "stakingAddress"), "3Mu7VHAWmzFuC8CC1jL66egwWdzMmU3GMdN")))
162162
163163 let ad = Address(fromBase58String(valueOrElse(getString(c, "feesAddress"), "3N44cXXhd7Xk7hr7JkLa3mTStLQnFpUfKgC")))
164164
165165 let ae = Address(fromBase58String(valueOrElse(getString(c, "poolsHubAddress"), "3NAD3Ww5D8d47qzXkk9aekQNroYUUtw4jdL")))
166166
167167 let af = valueOrElse(getString(c, "shutdownAddress"), "3MtiMjKiFuMZAA3NW9YZH89bYmiYUQUBezx")
168168
169169 let ag = valueOrElse(getString(c, "layer2Addresses"), "3Msp7W9rHyHkvvKBKU3rB44SqqcDALMbgbg,3Msp7W9rHyHkvvKBKU3rB44SqqcDALMbgbg")
170170
171171 let ah = Address(fromBase58String(valueOrElse(getString(c, "govAddress"), "3MsAdLsHFmArSyEuYFG9xRRbsutUBovzBhn")))
172172
173173 let ai = Address(fromBase58String(valueOrElse(getString(c, "coldMasterAddress"), "3N3LFeynYTFErCGXcABXenmYam1qbhbcNAH")))
174174
175175 let aj = q("static_tokensAmount")
176176
177177 let ak = {
178178 let al = split(v("static_tokenIds"), ",")
179179 let am = size(al)
180180 let an = nil
181181 func ao (ap,aq) = if ((aq >= am))
182182 then ap
183183 else D(ap, al[aq])
184184
185185 func ar (ap,aq) = if ((aq >= am))
186186 then ap
187187 else throw("List size exceeds 10")
188188
189189 ar(ao(ao(ao(ao(ao(ao(ao(ao(ao(ao(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
190190 }
191191
192192 let as = {
193193 let al = ak
194194 let am = size(al)
195195 let an = nil
196196 func at (ap,aq) = if ((aq >= am))
197197 then ap
198198 else G(ap, al[aq])
199199
200200 func au (ap,aq) = if ((aq >= am))
201201 then ap
202202 else throw("List size exceeds 10")
203203
204204 au(at(at(at(at(at(at(at(at(at(at(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
205205 }
206206
207207 let av = {
208208 let al = ak
209209 let am = size(al)
210210 let an = nil
211211 func aw (ap,aq) = if ((aq >= am))
212212 then ap
213213 else I(ap, al[aq])
214214
215215 func ax (ap,aq) = if ((aq >= am))
216216 then ap
217217 else throw("List size exceeds 10")
218218
219219 ax(aw(aw(aw(aw(aw(aw(aw(aw(aw(aw(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
220220 }
221221
222222 let ay = {
223223 let al = ak
224224 let am = size(al)
225225 let an = nil
226226 func az (ap,aq) = if ((aq >= am))
227227 then ap
228228 else J(ap, al[aq])
229229
230230 func aA (ap,aq) = if ((aq >= am))
231231 then ap
232232 else throw("List size exceeds 10")
233233
234234 aA(az(az(az(az(az(az(az(az(az(az(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
235235 }
236236
237237 let aB = q("static_fee")
238238
239239 let aC = ak
240240
241241 func aD () = {
242242 let aE = addressFromString(af)
243243 if ((aE == unit))
244244 then false
245245 else {
246246 let s = getBoolean(value(aE), "is_shutdown")
247247 if ($isInstanceOf(s, "Boolean"))
248248 then {
249249 let aF = s
250250 aF
251251 }
252252 else false
253253 }
254254 }
255255
256256
257257 func aG (aH) = {
258258 let aI = x(ak[aH])
259259 q((("global_" + aI) + "_balance"))
260260 }
261261
262262
263263 func aJ () = {
264264 let s = getInteger("static_KMult")
265265 if ($isInstanceOf(s, "Int"))
266266 then {
267267 let aF = s
268268 aF
269269 }
270270 else g
271271 }
272272
273273
274274 func aK () = {
275275 let aL = split(v("static_tokenIds"), ",")
276276 func aM (E,y) = (E ++ [IntegerEntry(("rebalance_startWeight_" + y), q((("static_" + y) + "_weight")))])
277277
278278 let al = aL
279279 let am = size(al)
280280 let an = nil
281281 func aN (ap,aq) = if ((aq >= am))
282282 then ap
283283 else aM(ap, al[aq])
284284
285285 func aO (ap,aq) = if ((aq >= am))
286286 then ap
287287 else throw("List size exceeds 10")
288288
289289 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
290290 }
291291
292292
293293 func aP () = fraction(q("global_poolToken_amount"), aJ(), g)
294294
295295
296296 func aQ (aR,aS) = {
297297 let aT = aP()
298298 let aU = q((("global_" + x(aS)) + "_balance"))
299299 let aV = fraction(aR, aT, aU, DOWN)
300300 aV
301301 }
302302
303303
304304 func aW (aX) = {
305305 func aY (E,aZ) = {
306306 let ba = aQ(aZ.amount, aZ.assetId)
307307 if ((ba == 0))
308308 then throw("one of the tokens amounts is too low")
309309 else if (if ((E == 0))
310310 then true
311311 else (E > ba))
312312 then ba
313313 else E
314314 }
315315
316316 let bb = {
317317 let al = aX
318318 let am = size(al)
319319 let an = 0
320320 func aN (ap,aq) = if ((aq >= am))
321321 then ap
322322 else aY(ap, al[aq])
323323
324324 func aO (ap,aq) = if ((aq >= am))
325325 then ap
326326 else throw("List size exceeds 10")
327327
328328 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
329329 }
330330 bb
331331 }
332332
333333
334334 func bc (y,aR,bd,be) = {
335335 let bf = indexOf(ak, R)
336336 let bg = indexOf(ak, S)
337337 let bh = indexOf(ak, T)
338338 let bi = indexOf(ak, U)
339339 let bj = indexOf(ak, unit)
340340 let bk = q((("static_" + x(y)) + "_weight"))
341341 let bl = v("static_feeToken")
342342 if ((bl == M))
343343 then {
344344 let bm = as[value(indexOf(ak, S))]
345345 let bn = q((("global_" + M) + "_balance"))
346346 let bo = fraction(aR, (bn / bm), (bd / bk))
347347 let bp = getIntegerValue(Y, "global_lastPuzzlePrice")
348348 fraction((bo * bp), 1, f)
349349 }
350350 else if ((bl == N))
351351 then {
352352 let bq = as[value(bh)]
353353 let br = q((("global_" + N) + "_balance"))
354354 fraction(aR, (br / bq), (bd / bk))
355355 }
356356 else if ((bl == O))
357357 then {
358358 let bq = as[value(bi)]
359359 let br = q((("global_" + O) + "_balance"))
360360 fraction(aR, (br / bq), (bd / bk))
361361 }
362362 else if ((bl == L))
363363 then {
364364 let bs = as[value(indexOf(ak, R))]
365365 let bt = {
366366 let s = be
367367 if ($isInstanceOf(s, "Int"))
368368 then {
369369 let aF = s
370370 be
371371 }
372372 else q((("global_" + x(R)) + "_balance"))
373373 }
374374 fraction(aR, (value(bt) / bs), (bd / bk))
375375 }
376376 else {
377377 let bu = 3000
378378 let bv = (q("global_WAVES_balance") / 50)
379379 fraction(aR, (bv / bu), (bd / bk))
380380 }
381381 }
382382
383383
384384 func bw (A) = {
385385 let s = getInteger(ab, (A + "_twap5B"))
386386 if ($isInstanceOf(s, "Int"))
387387 then {
388388 let aF = s
389389 aF
390390 }
391391 else 0
392392 }
393393
394394
395395 func bx (y,aR,bd) = {
396396 let bk = q((("static_" + x(y)) + "_weight"))
397397 let bl = v("static_feeToken")
398398 let by = getIntegerValue(this, (("static_" + bl) + "_scale"))
399399 let bz = value(indexOf(ak, z(bl)))
400400 let bA = as[bz]
401401 let bB = q((("global_" + bl) + "_balance"))
402402 let bC = fraction(aR, (bB / bA), (bd / bk))
403403 let bD = bw(bl)
404404 fraction(bC, bD, by)
405405 }
406406
407407
408408 func bE (aX) = {
409409 func bF (E,bG) = (E ++ [bG.assetId])
410410
411411 let bH = {
412412 let al = aX
413413 let am = size(al)
414414 let an = nil
415415 func aN (ap,aq) = if ((aq >= am))
416416 then ap
417417 else bF(ap, al[aq])
418418
419419 func aO (ap,aq) = if ((aq >= am))
420420 then ap
421421 else throw("List size exceeds 10")
422422
423423 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
424424 }
425425 if ((bH == bH))
426426 then {
427427 func bI (E,y) = if ((indexOf(bH, y) != unit))
428428 then (E + 1)
429429 else throw(("asset not attached: " + x(y)))
430430
431431 let bJ = {
432432 let al = ak
433433 let am = size(al)
434434 let an = 0
435435 func bK (ap,aq) = if ((aq >= am))
436436 then ap
437437 else bI(ap, al[aq])
438438
439439 func bL (ap,aq) = if ((aq >= am))
440440 then ap
441441 else throw("List size exceeds 10")
442442
443443 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
444444 }
445445 if ((bJ == bJ))
446446 then true
447447 else throw("Strict value is not equal to itself.")
448448 }
449449 else throw("Strict value is not equal to itself.")
450450 }
451451
452452
453453 func bM (ba,aX,bN,bO) = {
454454 func bP (aS) = {
455455 func aY (E,bG) = if ((bG.assetId == aS))
456456 then bG.amount
457457 else E
458458
459459 let al = aX
460460 let am = size(al)
461461 let an = 0
462462 func aN (ap,aq) = if ((aq >= am))
463463 then ap
464464 else aY(ap, al[aq])
465465
466466 func aO (ap,aq) = if ((aq >= am))
467467 then ap
468468 else throw("List size exceeds 10")
469469
470470 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
471471 }
472472
473473 func bQ (E,aS) = {
474474 let bR = q((("global_" + x(aS)) + "_balance"))
475475 let bS = aP()
476476 let bT = q((("static_" + x(aS)) + "_scale"))
477477 let bU = fraction((toBigInt((bS + ba)) * toBigInt(f)), toBigInt(bT), toBigInt(bS), CEILING)
478478 let bV = toInt(fraction((bU - (toBigInt(bT) * toBigInt(f))), toBigInt(bR), (toBigInt(bT) * toBigInt(f)), CEILING))
479479 let bW = bP(aS)
480480 let bX = (bW - bV)
481481 let C = if (if (bO)
482482 then (bX > 0)
483483 else false)
484484 then [ScriptTransfer(bN, bX, aS)]
485485 else nil
486486 ((E ++ C) ++ [IntegerEntry((("global_" + x(aS)) + "_balance"), (bR + bV))])
487487 }
488488
489489 let al = ak
490490 let am = size(al)
491491 let an = nil
492492 func aN (ap,aq) = if ((aq >= am))
493493 then ap
494494 else bQ(ap, al[aq])
495495
496496 func aO (ap,aq) = if ((aq >= am))
497497 then ap
498498 else throw("List size exceeds 10")
499499
500500 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
501501 }
502502
503503
504504 func bY (bZ,bN) = {
505505 func ca (E,aS) = {
506506 let bR = q((("global_" + x(aS)) + "_balance"))
507507 let bS = aP()
508508 let bT = q((("static_" + x(aS)) + "_scale"))
509509 let cb = fraction((toBigInt((bS - bZ)) * toBigInt(f)), toBigInt(f), toBigInt(bS), DOWN)
510510 let aR = toInt(fraction((toBigInt(g) - cb), toBigInt(bR), toBigInt(g), CEILING))
511511 (E ++ [IntegerEntry((("global_" + x(aS)) + "_balance"), (bR - aR)), ScriptTransfer(bN, aR, aS)])
512512 }
513513
514514 let al = ak
515515 let am = size(al)
516516 let an = nil
517517 func aN (ap,aq) = if ((aq >= am))
518518 then ap
519519 else ca(ap, al[aq])
520520
521521 func aO (ap,aq) = if ((aq >= am))
522522 then ap
523523 else throw("List size exceeds 10")
524524
525525 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
526526 }
527527
528528
529529 func cc (cd,ce,cf,cg,ch) = {
530530 let ci = value(indexOf(ak, ce))
531531 let cj = value(indexOf(ak, cf))
532532 if ((ci == cj))
533533 then cd
534534 else fraction(ch, ((f * f) - toInt(pow(fraction((toBigInt(cg) * toBigInt(10000)), toBigInt((f * f)), (toBigInt((cg + cd)) * toBigInt(10000)), HALFUP), 16, toBigInt(fraction(as[ci], 1000000000000, as[cj])), 12, 16, CEILING))), (f * f), HALFEVEN)
535535 }
536536
537537
538538 func ck (y,A,bd,cl) = {
539539 let cm = q("global_indexStaked")
540540 let cn = cl
541541 let co = (B(y) - bd)
542542 let cp = if ((co > cn))
543543 then co
544544 else cn
545545 let cq = (cp - cn)
546546 let cr = if ((cm == 0))
547547 then 0
548548 else fraction(cq, f, cm)
549549 let cs = q((("global_lastCheck_" + A) + "_interest"))
550550 (cs + cr)
551551 }
552552
553553
554554 func ct (cu) = {
555555 let cv = toString(cu)
556556 let cw = q((cv + "_indexStaked"))
557557 func aY (E,y) = {
558558 let A = x(y)
559559 let bd = q((("global_" + x(y)) + "_balance"))
560560 let cl = q((("global_lastCheck_" + A) + "_earnings"))
561561 let cx = ck(y, A, bd, cl)
562562 let cp = max([cl, (B(y) - bd)])
563563 let cy = fraction(cw, (cx - q((((cv + "_lastCheck_") + A) + "_interest"))), f)
564564 let cz = if ((cy == 0))
565565 then nil
566566 else [ScriptTransfer(cu, cy, y)]
567567 $Tuple2(((E._1 ++ cz) ++ [IntegerEntry((("global_lastCheck_" + A) + "_earnings"), (cp - cy)), IntegerEntry((("global_lastCheck_" + A) + "_interest"), cx), IntegerEntry((((cv + "_lastCheck_") + A) + "_interest"), cx)]), (E._2 + bx(y, cy, bd)))
568568 }
569569
570570 let E = {
571571 let al = aC
572572 let am = size(al)
573573 let an = $Tuple2(nil, 0)
574574 func aN (ap,aq) = if ((aq >= am))
575575 then ap
576576 else aY(ap, al[aq])
577577
578578 func aO (ap,aq) = if ((aq >= am))
579579 then ap
580580 else throw("List size exceeds 10")
581581
582582 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
583583 }
584584 $Tuple2((E._1 ++ [IntegerEntry((cv + "_claimedRewardUSD"), (q((cv + "_claimedRewardUSD")) + E._2)), IntegerEntry((cv + "_lastClaim"), lastBlock.timestamp)]), E._2)
585585 }
586586
587587
588588 func cA (cv,aR) = {
589589 let cB = ct(addressFromStringValue(cv))._1
590590 (cB ++ [IntegerEntry((cv + "_indexStaked"), (q((cv + "_indexStaked")) + aR)), IntegerEntry("global_indexStaked", (q("global_indexStaked") + aR))])
591591 }
592592
593593
594594 func cC (E,cD) = (E + parseIntValue(cD))
595595
596596
597597 func cE (E,cF) = if (if ((indexOf(X, cF) != unit))
598598 then (E == "")
599599 else false)
600600 then cF
601601 else E
602602
603603
604604 func cG (cH) = {
605605 let cI = split(v("static_tokenIds"), ",")
606606 let cJ = cH
607607 func cK (E,y) = if ((indexOf(cJ, y) == unit))
608608 then (E ++ [y])
609609 else E
610610
611611 let al = cI
612612 let am = size(al)
613613 let an = cJ
614614 func aN (ap,aq) = if ((aq >= am))
615615 then ap
616616 else cK(ap, al[aq])
617617
618618 func aO (ap,aq) = if ((aq >= am))
619619 then ap
620620 else throw("List size exceeds 10")
621621
622622 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
623623 }
624624
625625
626626 func cL (cH) = {
627627 let cI = split(v("static_tokenIds"), ",")
628628 func cM (E,y) = if ((indexOf(cH, y) == unit))
629629 then (E + 1)
630630 else E
631631
632632 func cN (E,y) = if ((indexOf(cI, y) == unit))
633633 then (E + 1)
634634 else E
635635
636636 let cO = {
637637 let al = cI
638638 let am = size(al)
639639 let an = 0
640640 func aN (ap,aq) = if ((aq >= am))
641641 then ap
642642 else cM(ap, al[aq])
643643
644644 func aO (ap,aq) = if ((aq >= am))
645645 then ap
646646 else throw("List size exceeds 10")
647647
648648 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
649649 }
650650 let cP = {
651651 let al = cH
652652 let am = size(al)
653653 let an = 0
654654 func bK (ap,aq) = if ((aq >= am))
655655 then ap
656656 else cN(ap, al[aq])
657657
658658 func bL (ap,aq) = if ((aq >= am))
659659 then ap
660660 else throw("List size exceeds 10")
661661
662662 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
663663 }
664664 (cO + cP)
665665 }
666666
667667
668668 func cQ (cR,aX) = {
669669 func cS (E,cF) = if ((0 >= cF.amount))
670670 then throw(((("Too low payment amount for " + x(cF.assetId)) + ": ") + toString(cF.amount)))
671671 else (E ++ [x(cF.assetId)])
672672
673673 let cT = {
674674 let al = aX
675675 let am = size(al)
676676 let an = nil
677677 func aN (ap,aq) = if ((aq >= am))
678678 then ap
679679 else cS(ap, al[aq])
680680
681681 func aO (ap,aq) = if ((aq >= am))
682682 then ap
683683 else throw("List size exceeds 10")
684684
685685 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
686686 }
687687 func cU (E,cF) = if ((indexOf(cR, cF) == unit))
688688 then throw(((cF + " asset is present in payments, but is not in new assets: ") + makeString(cR, ",")))
689689 else (E + 1)
690690
691691 func cV (E,cF) = if ((indexOf(cT, cF) == unit))
692692 then throw(((cF + " asset is present in new assets, but is not in payments: ") + makeString(cT, ",")))
693693 else (E + 1)
694694
695695 let bU = {
696696 let al = cT
697697 let am = size(al)
698698 let an = 0
699699 func bK (ap,aq) = if ((aq >= am))
700700 then ap
701701 else cU(ap, al[aq])
702702
703703 func bL (ap,aq) = if ((aq >= am))
704704 then ap
705705 else throw("List size exceeds 10")
706706
707707 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
708708 }
709709 let cW = {
710710 let al = cR
711711 let am = size(al)
712712 let an = 0
713713 func cX (ap,aq) = if ((aq >= am))
714714 then ap
715715 else cV(ap, al[aq])
716716
717717 func cY (ap,aq) = if ((aq >= am))
718718 then ap
719719 else throw("List size exceeds 10")
720720
721721 cY(cX(cX(cX(cX(cX(cX(cX(cX(cX(cX(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
722722 }
723723 (bU + cW)
724724 }
725725
726726
727727 func cZ (da) = {
728728 func db (E,dc) = {
729729 let dd = valueOrErrorMessage(parseInt(dc), ("Wrong weight format: " + dc))
730730 if (if ((o > dd))
731731 then true
732732 else (dd > p))
733733 then throw(((((("Weight should be in range " + toString(o)) + " - ") + toString(p)) + ", current: ") + dc))
734734 else E
735735 }
736736
737737 let al = da
738738 let am = size(al)
739739 let an = 0
740740 func aN (ap,aq) = if ((aq >= am))
741741 then ap
742742 else db(ap, al[aq])
743743
744744 func aO (ap,aq) = if ((aq >= am))
745745 then ap
746746 else throw("List size exceeds 10")
747747
748748 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
749749 }
750750
751751
752752 @Callable(de)
753753 func preInit (df,dg,dh,di,dj,dk) = {
754754 let dl = Address(fromBase58String(dj))
755755 let dm = split(df, ",")
756756 let aL = {
757757 let al = dm
758758 let am = size(al)
759759 let an = nil
760760 func aN (ap,aq) = if ((aq >= am))
761761 then ap
762762 else D(ap, al[aq])
763763
764764 func aO (ap,aq) = if ((aq >= am))
765765 then ap
766766 else throw("List size exceeds 10")
767767
768768 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
769769 }
770770 let bl = {
771771 let al = dm
772772 let am = size(al)
773773 let an = ""
774774 func bK (ap,aq) = if ((aq >= am))
775775 then ap
776776 else cE(ap, al[aq])
777777
778778 func bL (ap,aq) = if ((aq >= am))
779779 then ap
780780 else throw("List size exceeds 10")
781781
782782 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
783783 }
784784 if (aD())
785785 then throw("contract is on stop")
786786 else if ((this != de.caller))
787787 then throw("admin only")
788788 else if ((bl == ""))
789789 then throw("pool must have one of the supported fee assets in the composition")
790790 else if ((size(di) > 13))
791791 then throw("too large pool domain")
792792 else if (if ((dk > 500))
793793 then true
794794 else (0 > dk))
795795 then throw("fee value must be between 50 and 500 (0.5-5%)")
796796 else {
797797 let dn = split(dg, ",")
798798 let do = {
799799 let al = dn
800800 let am = size(al)
801801 let an = 0
802802 func cX (ap,aq) = if ((aq >= am))
803803 then ap
804804 else cC(ap, al[aq])
805805
806806 func cY (ap,aq) = if ((aq >= am))
807807 then ap
808808 else throw("List size exceeds 10")
809809
810810 cY(cX(cX(cX(cX(cX(cX(cX(cX(cX(cX(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
811811 }
812812 func dp (E,dq) = if ((dq >= size(aL)))
813813 then E
814814 else {
815815 let dr = {
816816 let s = aL[dq]
817817 if ($isInstanceOf(s, "ByteVector"))
818818 then {
819819 let aF = s
820820 value(assetInfo(aF)).decimals
821821 }
822822 else 8
823823 }
824824 (E ++ [IntegerEntry((("static_" + dm[dq]) + "_scale"), pow(10, 0, dr, 0, 0, DOWN)), IntegerEntry((("static_" + dm[dq]) + "_decimals"), dr), IntegerEntry((("static_" + dm[dq]) + "_weight"), value(parseInt(dn[dq])))])
825825 }
826826
827827 if ((do != 10000))
828828 then throw("sum of token weights must be equal to 10000")
829829 else ({
830830 let al = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
831831 let am = size(al)
832832 let an = nil
833833 func ds (ap,aq) = if ((aq >= am))
834834 then ap
835835 else dp(ap, al[aq])
836836
837837 func dt (ap,aq) = if ((aq >= am))
838838 then ap
839839 else throw("List size exceeds 10")
840840
841841 dt(ds(ds(ds(ds(ds(ds(ds(ds(ds(ds(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
842842 } ++ [StringEntry("static_tokenIds", df), StringEntry("static_feeToken", bl), StringEntry("static_tokenWeights", dg), IntegerEntry("static_tokensAmount", size(aL)), StringEntry("static_poolDomain", di), StringEntry("static_baseTokenId", dh), StringEntry("static_poolOwner", dj), IntegerEntry("static_fee", dk), IntegerEntry("static_KMult", g), IntegerEntry("global_wasPreInited", 1)])
843843 }
844844 }
845845
846846
847847
848848 @Callable(de)
849849 func deInit () = if (aD())
850850 then throw("contract is on stop")
851851 else if ((de.caller != this))
852852 then throw("admin only")
853853 else [IntegerEntry("global_wasInited", 0)]
854854
855855
856856
857857 @Callable(de)
858858 func init () = {
859859 func du () = {
860860 func aY (E,cD) = (E ++ [IntegerEntry((("global_" + x(cD.assetId)) + "_balance"), cD.amount)])
861861
862862 let al = de.payments
863863 let am = size(al)
864864 let an = nil
865865 func aN (ap,aq) = if ((aq >= am))
866866 then ap
867867 else aY(ap, al[aq])
868868
869869 func aO (ap,aq) = if ((aq >= am))
870870 then ap
871871 else throw("List size exceeds 10")
872872
873873 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
874874 }
875875
876876 func dv (aX) = {
877877 func aY (E,dw) = {
878878 let y = dw.assetId
879879 func bI (E,cD) = if ((cD == y))
880880 then value(indexOf(ak, cD))
881881 else E
882882
883883 let dx = {
884884 let al = ak
885885 let am = size(al)
886886 let an = 1
887887 func aN (ap,aq) = if ((aq >= am))
888888 then ap
889889 else bI(ap, al[aq])
890890
891891 func aO (ap,aq) = if ((aq >= am))
892892 then ap
893893 else throw("List size exceeds 10")
894894
895895 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
896896 }
897897 fraction(E, pow(dw.amount, av[dx], as[dx], d, 8, FLOOR), f)
898898 }
899899
900900 let al = aX
901901 let am = size(al)
902902 let an = j
903903 func aN (ap,aq) = if ((aq >= am))
904904 then ap
905905 else aY(ap, al[aq])
906906
907907 func aO (ap,aq) = if ((aq >= am))
908908 then ap
909909 else throw("List size exceeds 10")
910910
911911 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
912912 }
913913
914914 if (aD())
915915 then throw("contract is on stop")
916916 else if ((q("global_wasInited") > 0))
917917 then throw("pool already inited")
918918 else {
919919 let dy = dv(de.payments)
920920 if ((dy == 0))
921921 then throw("you need a bigger tokens amount to launch the pool")
922922 else {
923923 let dz = Issue(("PZ " + v("static_poolDomain")), "Puzzle Swap: pool index token", dy, i, true, unit, 0)
924924 let dA = calculateAssetId(dz)
925925 (du() ++ [dz, IntegerEntry("global_poolToken_amount", dy), IntegerEntry("global_wasInited", 1), BinaryEntry("global_poolToken_id", dA), StringEntry("static_poolToken_idStr", x(dA)), IntegerEntry((toString(de.caller) + "_indexStaked"), dy), IntegerEntry("global_indexStaked", dy)])
926926 }
927927 }
928928 }
929929
930930
931931
932932 @Callable(de)
933933 func generateIndex (bO) = if ((size(de.payments) != aj))
934934 then throw(("you need to attach all pool tokens. amount of pool tokens: " + toString(aj)))
935935 else if (!(bE(de.payments)))
936936 then throw("wrong assets attached")
937937 else {
938938 let dB = aW(de.payments)
939939 let cJ = bM(dB, de.payments, de.originCaller, bO)
940940 let dC = fraction(dB, g, aJ(), DOWN)
941941 let dD = Reissue(getBinaryValue("global_poolToken_id"), dC, true)
942942 $Tuple2((cJ ++ [dD, ScriptTransfer(de.caller, dC, u("global_poolToken_id")), IntegerEntry("global_poolToken_amount", (q("global_poolToken_amount") + dC))]), dC)
943943 }
944944
945945
946946
947947 @Callable(de)
948948 func redeemIndex (dE) = {
949949 let dw = de.payments[0]
950950 if ((dw.assetId != u("global_poolToken_id")))
951951 then throw("please attach pool share token")
952952 else if (aD())
953953 then throw("contract is on stop")
954954 else {
955955 let dF = dw.amount
956956 let dG = fraction(dF, aJ(), g, DOWN)
957957 let cJ = bY(dG, if (dE)
958958 then de.originCaller
959959 else de.caller)
960960 (cJ ++ [Burn(u("global_poolToken_id"), dF), IntegerEntry("global_poolToken_amount", (q("global_poolToken_amount") - dF))])
961961 }
962962 }
963963
964964
965965
966966 @Callable(de)
967967 func stakeIndex () = {
968968 let cv = toString(de.originCaller)
969969 let dw = de.payments[0]
970970 if ((value(dw.assetId) != u("global_poolToken_id")))
971971 then throw("wrong asset attached")
972972 else cA(cv, dw.amount)
973973 }
974974
975975
976976
977977 @Callable(de)
978978 func stakeIndexFor (cv) = {
979979 let dw = de.payments[0]
980980 if ((value(dw.assetId) != u("global_poolToken_id")))
981981 then throw("wrong asset attached")
982982 else cA(cv, dw.amount)
983983 }
984984
985985
986986
987987 @Callable(de)
988988 func unstakeIndex (dH) = {
989989 let cv = if ((indexOf(ag, toString(de.caller)) != unit))
990990 then toString(de.originCaller)
991991 else toString(de.caller)
992992 let dI = q((cv + "_indexStaked"))
993993 if (aD())
994994 then throw("contract is on stop")
995995 else if ((dH > dI))
996996 then throw("you don't have index tokens available")
997997 else if (aD())
998998 then throw("contract is on stop")
999999 else (ct(addressFromStringValue(cv))._1 ++ [IntegerEntry((cv + "_indexStaked"), (dI - dH)), IntegerEntry("global_indexStaked", (q("global_indexStaked") - dH)), ScriptTransfer(de.caller, dH, getBinaryValue("global_poolToken_id"))])
10001000 }
10011001
10021002
10031003
10041004 @Callable(de)
10051005 func claimIndexRewards () = if (aD())
10061006 then throw("contract is on stop")
10071007 else ct(de.caller)
10081008
10091009
10101010
10111011 @Callable(de)
10121012 func evaluateClaim (dJ) = $Tuple2(nil, ct(addressFromStringValue(dJ))._2)
10131013
10141014
10151015
10161016 @Callable(de)
10171017 func swap (cf,dK) = {
10181018 let dw = if ((size(de.payments) == 1))
10191019 then value(de.payments[0])
10201020 else throw("please attach exactly one payment")
10211021 let cd = value(de.payments[0].amount)
10221022 let dL = dw.assetId
10231023 let dM = z(cf)
10241024 let ce = x(dL)
10251025 let dN = (f / q((("static_" + ce) + "_scale")))
10261026 let dO = (f / q((("static_" + cf) + "_scale")))
10271027 let dP = v("static_feeToken")
10281028 let dQ = if ((dP == ""))
10291029 then R
10301030 else z(dP)
10311031 let dR = q((("global_" + x(dL)) + "_balance"))
10321032 let dS = q((("global_" + cf) + "_balance"))
10331033 let dT = (dR * dN)
10341034 let dU = (dS * dO)
10351035 let dV = fraction(cd, aB, h)
10361036 let dW = (cd - dV)
10371037 let dX = (dW * dN)
10381038 let dY = cc(dX, dL, dM, dT, dU)
10391039 let dZ = fraction(dY, 1, dO)
10401040 let ea = (dS - dZ)
10411041 let eb = (dR + dW)
10421042 let ec = if ((dQ == dL))
10431043 then eb
10441044 else if ((dQ == dM))
10451045 then ea
10461046 else q((("global_" + x(dQ)) + "_balance"))
10471047 let ed = cc(dV, dL, dQ, dR, ec)
10481048 if ((dK > dZ))
10491049 then throw("amount to recieve is lower than given one")
10501050 else if ((dM == dL))
10511051 then throw("this swap is not allowed")
10521052 else if ((0 > (dS - dZ)))
10531053 then throw("contract is out of reserves")
10541054 else if (aD())
10551055 then throw("contract is on stop")
10561056 else {
10571057 let ee = fraction(ed, 1, 10)
10581058 let ef = fraction(ed, 4, 10)
10591059 let eg = eb
10601060 let eh = (ea - (if ((dM == dQ))
10611061 then ed
10621062 else 0))
10631063 let ei = if (if ((dQ != dL))
10641064 then (dQ != dM)
10651065 else false)
10661066 then (ec - ed)
10671067 else unit
10681068 let ej = IntegerEntry((("global_" + x(dL)) + "_balance"), eg)
10691069 let ek = IntegerEntry((("global_" + cf) + "_balance"), eh)
10701070 let el = if ((ei != unit))
10711071 then IntegerEntry((("global_" + x(dQ)) + "_balance"), value(ei))
10721072 else StringEntry("hello", "world")
10731073 let em = bc(dL, cd, dR, ec)
10741074 let en = bx(dL, cd, dR)
10751075 $Tuple2([ek, ej, el, ScriptTransfer(de.caller, dZ, dM), ScriptTransfer(addressFromStringValue(v("static_poolOwner")), ee, dQ), IntegerEntry("global_earnedByOwner", (q("global_earnedByOwner") + ee)), IntegerEntry("global_volume", (q("global_volume") + em)), IntegerEntry("global_volume_usd", (q("global_volume_usd") + en)), ScriptTransfer(ad, ef, dQ)], dZ)
10761076 }
10771077 }
10781078
10791079
10801080
10811081 @Callable(de)
10821082 func swapReadOnly (ce,cf,cd) = {
10831083 let dL = z(ce)
10841084 let dM = z(cf)
10851085 let dN = (f / q((("static_" + ce) + "_scale")))
10861086 let dO = (f / q((("static_" + cf) + "_scale")))
10871087 let dP = v("static_feeToken")
10881088 let dQ = if ((dP == ""))
10891089 then R
10901090 else z(dP)
10911091 let dR = q((("global_" + x(dL)) + "_balance"))
10921092 let dS = q((("global_" + cf) + "_balance"))
10931093 let dT = (dR * dN)
10941094 let dU = (dS * dO)
10951095 let dV = fraction(cd, aB, h)
10961096 let dW = (cd - dV)
10971097 let dX = (dW * dN)
10981098 let dY = cc(dX, dL, dM, dT, dU)
10991099 let dZ = fraction(dY, 1, dO)
11001100 let ea = (dS - dZ)
11011101 let eb = (dR + dW)
11021102 let ec = if ((dQ == dL))
11031103 then eb
11041104 else if ((dQ == dM))
11051105 then ea
11061106 else q((("global_" + x(dQ)) + "_balance"))
11071107 let ed = cc(dV, dL, dQ, dR, ec)
11081108 if ((dM == dL))
11091109 then throw("this swap is not allowed")
11101110 else if ((0 > (dS - dZ)))
11111111 then throw("contract is out of reserves")
11121112 else if (aD())
11131113 then throw("contract is on stop")
11141114 else $Tuple2(nil, dZ)
11151115 }
11161116
11171117
11181118
11191119 @Callable(de)
11201120 func transferOwnership (eo) = if ((toString(de.caller) != v("static_poolOwner")))
11211121 then throw("this call available only for pool owner")
11221122 else [StringEntry("static_poolOwner", eo)]
11231123
11241124
11251125
11261126 @Callable(de)
11271127 func setFee (ep) = if ((toString(de.caller) != v("static_poolOwner")))
11281128 then throw("this call available only for pool owner")
11291129 else if ((1 > valueOrElse(getInteger(ah, ("approvedTx_" + toBase58String(de.transactionId))), 0)))
11301130 then throw("this transaction needs approval from puzzle network")
11311131 else [IntegerEntry("static_fee", ep)]
11321132
11331133
11341134
11351135 @Callable(de)
11361136 func setRebalancingPlan (df,dg,dh,eq,er) = if ((de.caller != addressFromStringValue(v("static_poolOwner"))))
11371137 then throw("this call available only for pool owner")
11381138 else if (valueOrElse(getBoolean(this, "rebalance_inProgress"), false))
11391139 then throw("rebalancing in progress")
11401140 else {
11411141 let es = split(dg, ",")
11421142 let et = split(df, ",")
11431143 let bl = {
11441144 let al = et
11451145 let am = size(al)
11461146 let an = ""
11471147 func aN (ap,aq) = if ((aq >= am))
11481148 then ap
11491149 else cE(ap, al[aq])
11501150
11511151 func aO (ap,aq) = if ((aq >= am))
11521152 then ap
11531153 else throw("List size exceeds 10")
11541154
11551155 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
11561156 }
11571157 let do = {
11581158 let al = es
11591159 let am = size(al)
11601160 let an = 0
11611161 func bK (ap,aq) = if ((aq >= am))
11621162 then ap
11631163 else cC(ap, al[aq])
11641164
11651165 func bL (ap,aq) = if ((aq >= am))
11661166 then ap
11671167 else throw("List size exceeds 10")
11681168
11691169 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
11701170 }
11711171 let eu = getStringValue("static_tokenIds")
11721172 let ev = split(eu, ",")
11731173 func ew (E,cF) = if ((indexOf(ev, cF) == unit))
11741174 then (E ++ [cF])
11751175 else E
11761176
11771177 func ex (E,cF) = if ((indexOf(et, cF) == unit))
11781178 then (E ++ [cF])
11791179 else E
11801180
11811181 let ey = {
11821182 let al = et
11831183 let am = size(al)
11841184 let an = nil
11851185 func cX (ap,aq) = if ((aq >= am))
11861186 then ap
11871187 else ew(ap, al[aq])
11881188
11891189 func cY (ap,aq) = if ((aq >= am))
11901190 then ap
11911191 else throw("List size exceeds 10")
11921192
11931193 cY(cX(cX(cX(cX(cX(cX(cX(cX(cX(cX(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
11941194 }
11951195 let ez = {
11961196 let al = ev
11971197 let am = size(al)
11981198 let an = nil
11991199 func ds (ap,aq) = if ((aq >= am))
12001200 then ap
12011201 else ex(ap, al[aq])
12021202
12031203 func dt (ap,aq) = if ((aq >= am))
12041204 then ap
12051205 else throw("List size exceeds 10")
12061206
12071207 dt(ds(ds(ds(ds(ds(ds(ds(ds(ds(ds(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
12081208 }
12091209 let eA = cQ(ey, de.payments)
12101210 let eB = cZ(es)
12111211 if ((eB == eB))
12121212 then if ((eA != (size(ey) + size(de.payments))))
12131213 then throw("Payments not present or something wrong with them")
12141214 else if ((size(et) != size(es)))
12151215 then throw("assetIds and assetWeights should have same length")
12161216 else if ((eA != (size(ey) + size(de.payments))))
12171217 then throw("Payments not present or something wrong with them")
12181218 else if ((bl == ""))
12191219 then throw("pool must have one of the supported fee assets in the composition")
12201220 else if ((indexOf(et, dh) == unit))
12211221 then throw("baseTokenId should be present in assetIds")
12221222 else if (if ((k > eq))
12231223 then true
12241224 else (eq > l))
12251225 then throw(((((("Steps amount should be between " + toString(k)) + " and ") + toString(l)) + ", current: ") + toString(eq)))
12261226 else if (if ((m > er))
12271227 then true
12281228 else (er > n))
12291229 then throw(((((("Steps interval should be between " + toString(m)) + " and ") + toString(n)) + ", current: ") + toString(er)))
12301230 else if ((do != 10000))
12311231 then throw(("sum of token weights must be equal to 10000, current: " + toString(do)))
12321232 else {
12331233 func cK (E,A) = {
12341234 let eC = q((("static_" + A) + "_weight"))
12351235 let eD = if ((indexOf(et, A) == unit))
12361236 then 0
12371237 else parseIntValue(value(es[value(indexOf(et, A))]))
12381238 let eE = fraction((eD - eC), 10000, eq)
12391239 (E ++ [toString(eE)])
12401240 }
12411241
12421242 let eF = cG(et)
12431243 let eG = {
12441244 let al = eF
12451245 let am = size(al)
12461246 let an = nil
12471247 func eH (ap,aq) = if ((aq >= am))
12481248 then ap
12491249 else cK(ap, al[aq])
12501250
12511251 func eI (ap,aq) = if ((aq >= am))
12521252 then ap
12531253 else throw("List size exceeds 10")
12541254
12551255 eI(eH(eH(eH(eH(eH(eH(eH(eH(eH(eH(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
12561256 }
12571257 let eJ = (cL(et) > 0)
12581258 func eK (E,cF) = (E ++ [IntegerEntry(("rebalance_attachedPayment_" + x(cF.assetId)), cF.amount)])
12591259
12601260 let eL = {
12611261 let al = de.payments
12621262 let am = size(al)
12631263 let an = nil
12641264 func eM (ap,aq) = if ((aq >= am))
12651265 then ap
12661266 else eK(ap, al[aq])
12671267
12681268 func eN (ap,aq) = if ((aq >= am))
12691269 then ap
12701270 else throw("List size exceeds 10")
12711271
12721272 eN(eM(eM(eM(eM(eM(eM(eM(eM(eM(eM(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
12731273 }
12741274 let eO = aK()
12751275 let eP = invoke(ah, "requestRebalancing", [toBase58String(de.transactionId)], nil)
12761276 if ((eP == eP))
12771277 then (([StringEntry("rebalance_addedAssets", makeString(ey, ",")), StringEntry("rebalance_removedAssets", makeString(ez, ",")), StringEntry("tmp_rebalanceAssetIds", makeString(eF, ",")), BooleanEntry("rebalance_inProgress", true), BooleanEntry("rebalance_newTokensAdded", eJ), IntegerEntry("rebalance_stepsDone", 0), IntegerEntry("rebalance_lastStepHeight", height), IntegerEntry("rebalance_stepsAmount", eq), IntegerEntry("rebalance_stepsInterval", er), StringEntry("rebalance_assetIds", df), StringEntry("rebalance_newBaseTokenId", dh), StringEntry("rebalance_assetDeltas", makeString(eG, ","))] ++ eL) ++ eO)
12781278 else throw("Strict value is not equal to itself.")
12791279 }
12801280 else throw("Strict value is not equal to itself.")
12811281 }
12821282
12831283
12841284
12851285 @Callable(de)
12861286 func stepRebalancing () = {
12871287 let eQ = valueOrErrorMessage(getString(ah, ("pool_lastRebalancing_" + toString(this))), "rebalancing is not registered at gov address")
12881288 if (!(valueOrElse(getBoolean(this, "rebalance_inProgress"), false)))
12891289 then throw("no rebalancing in progress")
12901290 else if ((valueOrElse(getInteger(ah, ("rebalancing_status_" + eQ)), 0) != 2))
12911291 then throw("this transaction needs approval from puzzle network")
12921292 else {
12931293 let eR = getIntegerValue("rebalance_lastStepHeight")
12941294 let eS = getIntegerValue("rebalance_stepsInterval")
12951295 let eT = getIntegerValue("rebalance_stepsDone")
12961296 let eU = (eR + eS)
12971297 if ((eU > height))
12981298 then throw("can't be done yet")
12991299 else {
13001300 let eG = split(getStringValue("rebalance_assetDeltas"), ",")
13011301 let eV = getStringValue("tmp_rebalanceAssetIds")
13021302 let eW = split(eV, ",")
13031303 func cK (E,A) = (E ++ [toString(fraction(((valueOrElse(getInteger(("rebalance_startWeight_" + A)), 0) * 10000) + (parseIntValue(eG[value(indexOf(eW, A))]) * (eT + 1))), 1, 10000, HALFUP))])
13041304
13051305 let eX = makeString({
13061306 let al = eW
13071307 let am = size(al)
13081308 let an = nil
13091309 func aN (ap,aq) = if ((aq >= am))
13101310 then ap
13111311 else cK(ap, al[aq])
13121312
13131313 func aO (ap,aq) = if ((aq >= am))
13141314 then ap
13151315 else throw("List size exceeds 10")
13161316
13171317 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
13181318 }, ",")
13191319 let eJ = getBooleanValue("rebalance_newTokensAdded")
13201320 let eY = if (if (eJ)
13211321 then (eT == 0)
13221322 else false)
13231323 then invoke(this, "doRebalancingWithNewTokens", [eV, eX, getStringValue("rebalance_newBaseTokenId")], nil)
13241324 else invoke(this, "doRebalancing", [eX], nil)
13251325 if ((eY == eY))
13261326 then {
13271327 let eZ = invoke(ae, "notifyPoolChange", nil, nil)
13281328 if ((eZ == eZ))
13291329 then {
13301330 let fa = ((eT + 1) >= getIntegerValue("rebalance_stepsAmount"))
13311331 let fb = [BooleanEntry("rebalance_inProgress", !(fa)), IntegerEntry("rebalance_stepsDone", (eT + 1)), IntegerEntry("rebalance_lastStepHeight", height)]
13321332 if ((eT == 0))
13331333 then (fb ++ [StringEntry("static_tokenIds", eV)])
13341334 else if (fa)
13351335 then {
13361336 let fc = split(v("rebalance_removedAssets"), ",")
13371337 func fd (E,y) = (E ++ [DeleteEntry((("static_" + y) + "_scale")), DeleteEntry((("static_" + y) + "_decimals")), DeleteEntry((("static_" + y) + "_weight")), DeleteEntry((("global_" + y) + "_balance")), DeleteEntry(("rebalance_attachedPayment_" + y))])
13381338
13391339 let fe = {
13401340 let al = fc
13411341 let am = size(al)
13421342 let an = nil
13431343 func bK (ap,aq) = if ((aq >= am))
13441344 then ap
13451345 else fd(ap, al[aq])
13461346
13471347 func bL (ap,aq) = if ((aq >= am))
13481348 then ap
13491349 else throw("List size exceeds 10")
13501350
13511351 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
13521352 }
13531353 let ff = split(v("rebalance_addedAssets"), ",")
13541354 func fg (E,y) = (E ++ [DeleteEntry(("rebalance_attachedPayment_" + y))])
13551355
13561356 let fh = {
13571357 let al = ff
13581358 let am = size(al)
13591359 let an = nil
13601360 func cX (ap,aq) = if ((aq >= am))
13611361 then ap
13621362 else fg(ap, al[aq])
13631363
13641364 func cY (ap,aq) = if ((aq >= am))
13651365 then ap
13661366 else throw("List size exceeds 10")
13671367
13681368 cY(cX(cX(cX(cX(cX(cX(cX(cX(cX(cX(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
13691369 }
13701370 let fi = v("rebalance_assetIds")
13711371 let fj = {
13721372 let al = split(fi, ",")
13731373 let am = size(al)
13741374 let an = nil
13751375 func ds (ap,aq) = if ((aq >= am))
13761376 then ap
13771377 else H(ap, al[aq])
13781378
13791379 func dt (ap,aq) = if ((aq >= am))
13801380 then ap
13811381 else throw("List size exceeds 10")
13821382
13831383 dt(ds(ds(ds(ds(ds(ds(ds(ds(ds(ds(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
13841384 }
13851385 let fk = invoke(ah, "notifyRebalancingDone", [eQ], nil)
13861386 if ((fk == fk))
13871387 then (((fb ++ fe) ++ fh) ++ [StringEntry("static_tokenIds", fi), StringEntry("static_tokenWeights", makeString(fj, ",")), IntegerEntry("static_tokensAmount", size(split(fi, ",")))])
13881388 else throw("Strict value is not equal to itself.")
13891389 }
13901390 else {
13911391 let fi = v("rebalance_assetIds")
13921392 let fj = {
13931393 let al = split(fi, ",")
13941394 let am = size(al)
13951395 let an = nil
13961396 func bK (ap,aq) = if ((aq >= am))
13971397 then ap
13981398 else H(ap, al[aq])
13991399
14001400 func bL (ap,aq) = if ((aq >= am))
14011401 then ap
14021402 else throw("List size exceeds 10")
14031403
14041404 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
14051405 }
14061406 (fb ++ [StringEntry("static_tokenWeights", makeString(fj, ","))])
14071407 }
14081408 }
14091409 else throw("Strict value is not equal to itself.")
14101410 }
14111411 else throw("Strict value is not equal to itself.")
14121412 }
14131413 }
14141414 }
14151415
14161416
14171417
14181418 @Callable(de)
14191419 func doRebalancing (dg) = {
14201420 let dn = split(dg, ",")
14211421 let do = {
14221422 let al = dn
14231423 let am = size(al)
14241424 let an = 0
14251425 func aN (ap,aq) = if ((aq >= am))
14261426 then ap
14271427 else cC(ap, al[aq])
14281428
14291429 func aO (ap,aq) = if ((aq >= am))
14301430 then ap
14311431 else throw("List size exceeds 10")
14321432
14331433 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
14341434 }
14351435 let dm = split(v("static_tokenIds"), ",")
14361436 if ((de.caller != this))
14371437 then throw("this call available only for admin")
14381438 else {
14391439 let fl = aJ()
14401440 func aY (fm,y) = {
14411441 let E = fm._1
14421442 let A = x(y)
14431443 func bI (E,cD) = if ((cD == y))
14441444 then value(indexOf(ak, cD))
14451445 else E
14461446
14471447 let dx = {
14481448 let al = ak
14491449 let am = size(al)
14501450 let an = 1
14511451 func bK (ap,aq) = if ((aq >= am))
14521452 then ap
14531453 else bI(ap, al[aq])
14541454
14551455 func bL (ap,aq) = if ((aq >= am))
14561456 then ap
14571457 else throw("List size exceeds 10")
14581458
14591459 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
14601460 }
14611461 let fn = q((("global_" + A) + "_balance"))
14621462 let fo = if ((fm._2 == "new"))
14631463 then parseIntValue(dn[dx])
14641464 else q((("static_" + A) + "_weight"))
14651465 $Tuple2(fraction(E, pow(fn, av[dx], fo, d, 8, FLOOR), f), fm._2)
14661466 }
14671467
14681468 let fp = ( let al = ak
14691469 let am = size(al)
14701470 let an = $Tuple2(j, "new")
14711471 func bK (ap,aq) = if ((aq >= am))
14721472 then ap
14731473 else aY(ap, al[aq])
14741474
14751475 func bL (ap,aq) = if ((aq >= am))
14761476 then ap
14771477 else throw("List size exceeds 10")
14781478
14791479 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10))._1
14801480 let fq = ( let al = ak
14811481 let am = size(al)
14821482 let an = $Tuple2(j, "old")
14831483 func cX (ap,aq) = if ((aq >= am))
14841484 then ap
14851485 else aY(ap, al[aq])
14861486
14871487 func cY (ap,aq) = if ((aq >= am))
14881488 then ap
14891489 else throw("List size exceeds 10")
14901490
14911491 cY(cX(cX(cX(cX(cX(cX(cX(cX(cX(cX(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10))._1
14921492 let fr = fraction(fl, fp, fq)
14931493 func dp (E,dq) = if ((dq >= size(dn)))
14941494 then E
14951495 else (E ++ [IntegerEntry((("static_" + dm[dq]) + "_weight"), value(parseInt(dn[dq])))])
14961496
14971497 ({
14981498 let al = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
14991499 let am = size(al)
15001500 let an = nil
15011501 func ds (ap,aq) = if ((aq >= am))
15021502 then ap
15031503 else dp(ap, al[aq])
15041504
15051505 func dt (ap,aq) = if ((aq >= am))
15061506 then ap
15071507 else throw("List size exceeds 10")
15081508
15091509 dt(ds(ds(ds(ds(ds(ds(ds(ds(ds(ds(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
15101510 } ++ [IntegerEntry("static_KMult", fr)])
15111511 }
15121512 }
15131513
15141514
15151515
15161516 @Callable(de)
15171517 func doRebalancingWithNewTokens (df,dg,dh) = {
15181518 let es = split(dg, ",")
15191519 let fs = split(v("static_tokenIds"), ",")
15201520 let et = split(df, ",")
15211521 let eW = {
15221522 let al = et
15231523 let am = size(al)
15241524 let an = nil
15251525 func aN (ap,aq) = if ((aq >= am))
15261526 then ap
15271527 else D(ap, al[aq])
15281528
15291529 func aO (ap,aq) = if ((aq >= am))
15301530 then ap
15311531 else throw("List size exceeds 10")
15321532
15331533 aO(aN(aN(aN(aN(aN(aN(aN(aN(aN(aN(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
15341534 }
15351535 let bl = {
15361536 let al = et
15371537 let am = size(al)
15381538 let an = ""
15391539 func bK (ap,aq) = if ((aq >= am))
15401540 then ap
15411541 else cE(ap, al[aq])
15421542
15431543 func bL (ap,aq) = if ((aq >= am))
15441544 then ap
15451545 else throw("List size exceeds 10")
15461546
15471547 bL(bK(bK(bK(bK(bK(bK(bK(bK(bK(bK(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
15481548 }
15491549 let ey = split(v("rebalance_addedAssets"), ",")
15501550 func ft (y) = valueOrElse(getInteger(("rebalance_attachedPayment_" + x(y))), 0)
15511551
15521552 func fu (cB,y) = (cB ++ [ft(y)])
15531553
15541554 let fv = {
15551555 let al = eW
15561556 let am = size(al)
15571557 let an = nil
15581558 func cX (ap,aq) = if ((aq >= am))
15591559 then ap
15601560 else fu(ap, al[aq])
15611561
15621562 func cY (ap,aq) = if ((aq >= am))
15631563 then ap
15641564 else throw("List size exceeds 10")
15651565
15661566 cY(cX(cX(cX(cX(cX(cX(cX(cX(cX(cX(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
15671567 }
15681568 if ((de.caller != this))
15691569 then throw(("this call available only for admin, " + toString(de.caller)))
15701570 else {
15711571 let fl = aJ()
15721572 let fq = aP()
15731573 func fw (fm,y) = {
15741574 func fx (E,cD) = if ((cD == y))
15751575 then value(indexOf(eW, cD))
15761576 else E
15771577
15781578 let fy = fm
15791579 let A = x(y)
15801580 let fz = {
15811581 let al = eW
15821582 let am = size(al)
15831583 let an = 1
15841584 func ds (ap,aq) = if ((aq >= am))
15851585 then ap
15861586 else fx(ap, al[aq])
15871587
15881588 func dt (ap,aq) = if ((aq >= am))
15891589 then ap
15901590 else throw("List size exceeds 10")
15911591
15921592 dt(ds(ds(ds(ds(ds(ds(ds(ds(ds(ds(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
15931593 }
15941594 let fo = parseIntValue(es[fz])
15951595 let fA = q((("global_" + A) + "_balance"))
15961596 let fB = fv[fz]
15971597 let fn = (fA + fB)
15981598 let dr = if ((y == unit))
15991599 then 8
16001600 else value(assetInfo(value(y))).decimals
16011601 if ((0 >= fn))
16021602 then throw(("you need to attach all new assets in payment. this asset is missed: " + A))
16031603 else fraction(fy, pow(fn, dr, fo, d, 8, FLOOR), f)
16041604 }
16051605
16061606 let fp = {
16071607 let al = eW
16081608 let am = size(al)
16091609 let an = j
16101610 func ds (ap,aq) = if ((aq >= am))
16111611 then ap
16121612 else fw(ap, al[aq])
16131613
16141614 func dt (ap,aq) = if ((aq >= am))
16151615 then ap
16161616 else throw("List size exceeds 10")
16171617
16181618 dt(ds(ds(ds(ds(ds(ds(ds(ds(ds(ds(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
16191619 }
16201620 let fr = fraction(fl, fp, fq)
16211621 func dp (E,dq) = {
16221622 let A = et[dq]
16231623 let y = eW[dq]
16241624 let dr = if ((y == unit))
16251625 then 8
16261626 else value(assetInfo(value(y))).decimals
16271627 let fC = if ((indexOf(ey, A) != unit))
16281628 then [IntegerEntry((("global_" + A) + "_balance"), fv[dq]), IntegerEntry((("static_" + A) + "_scale"), pow(10, 0, dr, 0, 0, DOWN)), IntegerEntry((("static_" + A) + "_decimals"), dr)]
16291629 else nil
16301630 if ((dq >= size(es)))
16311631 then E
16321632 else ((E ++ [IntegerEntry((("static_" + A) + "_weight"), value(parseInt(es[dq])))]) ++ fC)
16331633 }
16341634
16351635 ({
16361636 let al = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
16371637 let am = size(al)
16381638 let an = nil
16391639 func eH (ap,aq) = if ((aq >= am))
16401640 then ap
16411641 else dp(ap, al[aq])
16421642
16431643 func eI (ap,aq) = if ((aq >= am))
16441644 then ap
16451645 else throw("List size exceeds 10")
16461646
16471647 eI(eH(eH(eH(eH(eH(eH(eH(eH(eH(eH(an, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10)
16481648 } ++ [StringEntry("static_tokenIds", df), StringEntry("static_feeToken", bl), StringEntry("static_tokenWeights", dg), IntegerEntry("static_tokensAmount", size(eW)), IntegerEntry("static_KMult", fr)])
16491649 }
16501650 }
16511651
16521652
16531653 @Verifier(fD)
16541654 func fE () = if (if ((valueOrElse(getInteger("global_wasPreInited"), 0) == 0))
16551655 then if (sigVerify(fD.bodyBytes, fD.proofs[0], fD.senderPublicKey))
16561656 then true
16571657 else sigVerify(fD.bodyBytes, fD.proofs[0], aa)
16581658 else false)
16591659 then true
16601660 else {
16611661 let s = fD
16621662 if ($isInstanceOf(s, "SetScriptTransaction"))
16631663 then {
16641664 let fD = s
16651665 let fF = value(fD.script)
16661666 let fG = toBase58String(sha256(fF))
16671667 if (sigVerify(fD.bodyBytes, fD.proofs[0], aa))
16681668 then (valueOrElse(getInteger(ai, ("approvedScript_" + fG)), 0) > height)
16691669 else false
16701670 }
16711671 else if (sigVerify(fD.bodyBytes, fD.proofs[0], aa))
16721672 then (valueOrElse(getInteger(ai, ("approvedTx_" + toBase58String(fD.id))), 0) > 0)
16731673 else false
16741674 }
16751675

github/deemru/w8io/026f985 
147.66 ms