Created
July 19, 2016 21:49
-
-
Save daniilyar-confyrm/986a97747589e75016acfa482435c44c to your computer and use it in GitHub Desktop.
The full error stacktrace from browser
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
StackStorm Stanley | |
<html> <head> <title>Pecan - Application Error</title> <link rel="stylesheet" type="text/css" href="data:text/css;base64,LyoqCiAqIFN5bnRheEhpZ2hsaWdodGVyCiAqIGh0dHA6Ly9hbGV4Z29yYmF0Y2hldi5jb20vU3ludGF4SGlnaGxpZ2h0ZXIKICoKICogU3ludGF4SGlnaGxpZ2h0ZXIgaXMgZG9uYXRpb253YXJlLiBJZiB5b3UgYXJlIHVzaW5nIGl0LCBwbGVhc2UgZG9uYXRlLgogKiBodHRwOi8vYWxleGdvcmJhdGNoZXYuY29tL1N5bnRheEhpZ2hsaWdodGVyL2RvbmF0ZS5odG1sCiAqCiAqIEB2ZXJzaW9uCiAqIDMuMC44MyAoSnVseSAwMiAyMDEwKQogKgogKiBAY29weXJpZ2h0CiAqIENvcHlyaWdodCAoQykgMjAwNC0yMDEwIEFsZXggR29yYmF0Y2hldi4KICoKICogQGxpY2Vuc2UKICogRHVhbCBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIGFuZCBHUEwgbGljZW5zZXMuCiAqLwouc3ludGF4aGlnaGxpZ2h0ZXIgYSwKLnN5bnRheGhpZ2hsaWdodGVyIGRpdiwKLnN5bnRheGhpZ2hsaWdodGVyIGNvZGUsCi5zeW50YXhoaWdobGlnaHRlciB0YWJsZSwKLnN5bnRheGhpZ2hsaWdodGVyIHRhYmxlIHRkLAouc3ludGF4aGlnaGxpZ2h0ZXIgdGFibGUgdHIsCi5zeW50YXhoaWdobGlnaHRlciB0YWJsZSB0Ym9keSwKLnN5bnRheGhpZ2hsaWdodGVyIHRhYmxlIHRoZWFkLAouc3ludGF4aGlnaGxpZ2h0ZXIgdGFibGUgY2FwdGlvbiwKLnN5bnRheGhpZ2hsaWdodGVyIHRleHRhcmVhIHsKICAtbW96LWJvcmRlci1yYWRpdXM6IDAgMCAwIDAgIWltcG9ydGFudDsKICAtd2Via2l0LWJvcmRlci1yYWRpdXM6IDAgMCAwIDAgIWltcG9ydGFudDsKICBiYWNrZ3JvdW5kOiBub25lICFpbXBvcnRhbnQ7CiAgYm9yZGVyOiAwICFpbXBvcnRhbnQ7CiAgYm90dG9tOiBhdXRvICFpbXBvcnRhbnQ7CiAgZmxvYXQ6IG5vbmUgIWltcG9ydGFudDsKICBoZWlnaHQ6IGF1dG8gIWltcG9ydGFudDsKICBsZWZ0OiBhdXRvICFpbXBvcnRhbnQ7CiAgbGluZS1oZWlnaHQ6IDEuMWVtICFpbXBvcnRhbnQ7CiAgbWFyZ2luOiAwICFpbXBvcnRhbnQ7CiAgb3V0bGluZTogMCAhaW1wb3J0YW50OwogIG92ZXJmbG93OiB2aXNpYmxlICFpbXBvcnRhbnQ7CiAgcGFkZGluZzogMCAhaW1wb3J0YW50OwogIHBvc2l0aW9uOiBzdGF0aWMgIWltcG9ydGFudDsKICByaWdodDogYXV0byAhaW1wb3J0YW50OwogIHRleHQtYWxpZ246IGxlZnQgIWltcG9ydGFudDsKICB0b3A6IGF1dG8gIWltcG9ydGFudDsKICB2ZXJ0aWNhbC1hbGlnbjogYmFzZWxpbmUgIWltcG9ydGFudDsKICB3aWR0aDogYXV0byAhaW1wb3J0YW50OwogIGJveC1zaXppbmc6IGNvbnRlbnQtYm94ICFpbXBvcnRhbnQ7CiAgZm9udC1mYW1pbHk6ICJDb25zb2xhcyIsICJCaXRzdHJlYW0gVmVyYSBTYW5zIE1vbm8iLCAiQ291cmllciBOZXciLCBDb3VyaWVyLCBtb25vc3BhY2UgIWltcG9ydGFudDsKICBmb250LXdlaWdodDogbm9ybWFsICFpbXBvcnRhbnQ7CiAgZm9udC1zdHlsZTogbm9ybWFsICFpbXBvcnRhbnQ7CiAgZm9udC1zaXplOiAxZW0gIWltcG9ydGFudDsKICBtaW4taGVpZ2h0OiBpbmhlcml0ICFpbXBvcnRhbnQ7CiAgbWluLWhlaWdodDogYXV0byAhaW1wb3J0YW50Owp9Cgouc3ludGF4aGlnaGxpZ2h0ZXIgewogIHdpZHRoOiAxMDAlICFpbXBvcnRhbnQ7CiAgbWFyZ2luOiAxZW0gMCAxZW0gMCAhaW1wb3J0YW50OwogIHBvc2l0aW9uOiByZWxhdGl2ZSAhaW1wb3J0YW50OwogIG92ZXJmbG93OiBhdXRvICFpbXBvcnRhbnQ7CiAgZm9udC1zaXplOiAxZW0gIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIuc291cmNlIHsKICBvdmVyZmxvdzogaGlkZGVuICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC5ib2xkIHsKICBmb250LXdlaWdodDogYm9sZCAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuaXRhbGljIHsKICBmb250LXN0eWxlOiBpdGFsaWMgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIgLmxpbmUgewogIHdoaXRlLXNwYWNlOiBwcmUgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIgdGFibGUgewogIHdpZHRoOiAxMDAlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIHRhYmxlIGNhcHRpb24gewogIHRleHQtYWxpZ246IGxlZnQgIWltcG9ydGFudDsKICBwYWRkaW5nOiAuNWVtIDAgMC41ZW0gMWVtICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIHRhYmxlIHRkLmNvZGUgewogIHdpZHRoOiAxMDAlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIHRhYmxlIHRkLmNvZGUgLmNvbnRhaW5lciB7CiAgcG9zaXRpb246IHJlbGF0aXZlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIHRhYmxlIHRkLmNvZGUgLmNvbnRhaW5lciB0ZXh0YXJlYSB7CiAgYm94LXNpemluZzogYm9yZGVyLWJveCAhaW1wb3J0YW50OwogIHBvc2l0aW9uOiBhYnNvbHV0ZSAhaW1wb3J0YW50OwogIGxlZnQ6IDAgIWltcG9ydGFudDsKICB0b3A6IDAgIWltcG9ydGFudDsKICB3aWR0aDogMTAwJSAhaW1wb3J0YW50OwogIGhlaWdodDogMTAwJSAhaW1wb3J0YW50OwogIGJvcmRlcjogbm9uZSAhaW1wb3J0YW50OwogIGJhY2tncm91bmQ6IHdoaXRlICFpbXBvcnRhbnQ7CiAgcGFkZGluZy1sZWZ0OiAxZW0gIWltcG9ydGFudDsKICBvdmVyZmxvdzogaGlkZGVuICFpbXBvcnRhbnQ7CiAgd2hpdGUtc3BhY2U6IHByZSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciB0YWJsZSB0ZC5ndXR0ZXIgLmxpbmUgewogIHRleHQtYWxpZ246IHJpZ2h0ICFpbXBvcnRhbnQ7CiAgcGFkZGluZzogMCAwLjVlbSAwIDFlbSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciB0YWJsZSB0ZC5jb2RlIC5saW5lIHsKICBwYWRkaW5nOiAwIDFlbSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5ub2d1dHRlciB0ZC5jb2RlIC5jb250YWluZXIgdGV4dGFyZWEsIC5zeW50YXhoaWdobGlnaHRlci5ub2d1dHRlciB0ZC5jb2RlIC5saW5lIHsKICBwYWRkaW5nLWxlZnQ6IDBlbSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5zaG93IHsKICBkaXNwbGF5OiBibG9jayAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5jb2xsYXBzZWQgdGFibGUgewogIGRpc3BsYXk6IG5vbmUgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIuY29sbGFwc2VkIC50b29sYmFyIHsKICBwYWRkaW5nOiAwLjFlbSAwLjhlbSAwZW0gMC44ZW0gIWltcG9ydGFudDsKICBmb250LXNpemU6IDFlbSAhaW1wb3J0YW50OwogIHBvc2l0aW9uOiBzdGF0aWMgIWltcG9ydGFudDsKICB3aWR0aDogYXV0byAhaW1wb3J0YW50OwogIGhlaWdodDogYXV0byAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5jb2xsYXBzZWQgLnRvb2xiYXIgc3BhbiB7CiAgZGlzcGxheTogaW5saW5lICFpbXBvcnRhbnQ7CiAgbWFyZ2luLXJpZ2h0OiAxZW0gIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIuY29sbGFwc2VkIC50b29sYmFyIHNwYW4gYSB7CiAgcGFkZGluZzogMCAhaW1wb3J0YW50OwogIGRpc3BsYXk6IG5vbmUgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIuY29sbGFwc2VkIC50b29sYmFyIHNwYW4gYS5leHBhbmRTb3VyY2UgewogIGRpc3BsYXk6IGlubGluZSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAudG9vbGJhciB7CiAgcG9zaXRpb246IGFic29sdXRlICFpbXBvcnRhbnQ7CiAgcmlnaHQ6IDFweCAhaW1wb3J0YW50OwogIHRvcDogMXB4ICFpbXBvcnRhbnQ7CiAgd2lkdGg6IDExcHggIWltcG9ydGFudDsKICBoZWlnaHQ6IDExcHggIWltcG9ydGFudDsKICBmb250LXNpemU6IDEwcHggIWltcG9ydGFudDsKICB6LWluZGV4OiAxMCAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAudG9vbGJhciBzcGFuLnRpdGxlIHsKICBkaXNwbGF5OiBpbmxpbmUgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIgLnRvb2xiYXIgYSB7CiAgZGlzcGxheTogYmxvY2sgIWltcG9ydGFudDsKICB0ZXh0LWFsaWduOiBjZW50ZXIgIWltcG9ydGFudDsKICB0ZXh0LWRlY29yYXRpb246IG5vbmUgIWltcG9ydGFudDsKICBwYWRkaW5nLXRvcDogMXB4ICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC50b29sYmFyIGEuZXhwYW5kU291cmNlIHsKICBkaXNwbGF5OiBub25lICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLmllIHsKICBmb250LXNpemU6IC45ZW0gIWltcG9ydGFudDsKICBwYWRkaW5nOiAxcHggMCAxcHggMCAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5pZSAudG9vbGJhciB7CiAgbGluZS1oZWlnaHQ6IDhweCAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5pZSAudG9vbGJhciBhIHsKICBwYWRkaW5nLXRvcDogMHB4ICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5saW5lLmFsdDEgLmNvbnRlbnQsCi5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAubGluZS5hbHQyIC5jb250ZW50LAouc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLmxpbmUuaGlnaGxpZ2h0ZWQgLm51bWJlciwKLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5saW5lLmhpZ2hsaWdodGVkLmFsdDEgLmNvbnRlbnQsCi5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAubGluZS5oaWdobGlnaHRlZC5hbHQyIC5jb250ZW50IHsKICBiYWNrZ3JvdW5kOiBub25lICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5saW5lIC5udW1iZXIgewogIGNvbG9yOiAjYmJiYmJiICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5saW5lIC5jb250ZW50IHsKICBjb2xvcjogYmxhY2sgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLnRvb2xiYXIgewogIGRpc3BsYXk6IG5vbmUgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgYSB7CiAgdGV4dC1kZWNvcmF0aW9uOiBub25lICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5wbGFpbiwgLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5wbGFpbiBhIHsKICBjb2xvcjogYmxhY2sgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLmNvbW1lbnRzLCAuc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLmNvbW1lbnRzIGEgewogIGNvbG9yOiAjMDA4MjAwICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5zdHJpbmcsIC5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAuc3RyaW5nIGEgewogIGNvbG9yOiBibHVlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5rZXl3b3JkIHsKICBjb2xvcjogIzAwNjY5OSAhaW1wb3J0YW50OwogIGZvbnQtd2VpZ2h0OiBib2xkICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5wcmVwcm9jZXNzb3IgewogIGNvbG9yOiBncmF5ICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC52YXJpYWJsZSB7CiAgY29sb3I6ICNhYTc3MDAgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLnZhbHVlIHsKICBjb2xvcjogIzAwOTkwMCAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAuZnVuY3Rpb25zIHsKICBjb2xvcjogI2ZmMTQ5MyAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAuY29uc3RhbnRzIHsKICBjb2xvcjogIzAwNjZjYyAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAuc2NyaXB0IHsKICBmb250LXdlaWdodDogYm9sZCAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAuY29sb3IxLCAuc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLmNvbG9yMSBhIHsKICBjb2xvcjogZ3JheSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAuY29sb3IyLCAuc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLmNvbG9yMiBhIHsKICBjb2xvcjogI2ZmMTQ5MyAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5wcmludGluZyAuY29sb3IzLCAuc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLmNvbG9yMyBhIHsKICBjb2xvcjogcmVkICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5icmVhaywgLnN5bnRheGhpZ2hsaWdodGVyLnByaW50aW5nIC5icmVhayBhIHsKICBjb2xvcjogYmxhY2sgIWltcG9ydGFudDsKfQo%3D" /> <link rel="stylesheet" type="text/css" href="data:text/css;base64,LyoqCiAqIFN5bnRheEhpZ2hsaWdodGVyCiAqIGh0dHA6Ly9hbGV4Z29yYmF0Y2hldi5jb20vU3ludGF4SGlnaGxpZ2h0ZXIKICoKICogU3ludGF4SGlnaGxpZ2h0ZXIgaXMgZG9uYXRpb253YXJlLiBJZiB5b3UgYXJlIHVzaW5nIGl0LCBwbGVhc2UgZG9uYXRlLgogKiBodHRwOi8vYWxleGdvcmJhdGNoZXYuY29tL1N5bnRheEhpZ2hsaWdodGVyL2RvbmF0ZS5odG1sCiAqCiAqIEB2ZXJzaW9uCiAqIDMuMC44MyAoSnVseSAwMiAyMDEwKQogKgogKiBAY29weXJpZ2h0CiAqIENvcHlyaWdodCAoQykgMjAwNC0yMDEwIEFsZXggR29yYmF0Y2hldi4KICoKICogQGxpY2Vuc2UKICogRHVhbCBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIGFuZCBHUEwgbGljZW5zZXMuCiAqLwouc3ludGF4aGlnaGxpZ2h0ZXIgewogIGJhY2tncm91bmQtY29sb3I6IHdoaXRlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC5saW5lLmFsdDEgewogIGJhY2tncm91bmQtY29sb3I6IHdoaXRlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC5saW5lLmFsdDIgewogIGJhY2tncm91bmQtY29sb3I6IHdoaXRlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC5saW5lLmhpZ2hsaWdodGVkLmFsdDEsIC5zeW50YXhoaWdobGlnaHRlciAubGluZS5oaWdobGlnaHRlZC5hbHQyIHsKICBiYWNrZ3JvdW5kLWNvbG9yOiAjZTBlMGUwICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC5saW5lLmhpZ2hsaWdodGVkLm51bWJlciB7CiAgY29sb3I6IGJsYWNrICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIHRhYmxlIGNhcHRpb24gewogIGNvbG9yOiBibGFjayAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuZ3V0dGVyIHsKICBjb2xvcjogI2FmYWZhZiAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuZ3V0dGVyIC5saW5lIHsKICBib3JkZXItcmlnaHQ6IDNweCBzb2xpZCAjNmNlMjZjICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC5ndXR0ZXIgLmxpbmUuaGlnaGxpZ2h0ZWQgewogIGJhY2tncm91bmQtY29sb3I6ICM2Y2UyNmMgIWltcG9ydGFudDsKICBjb2xvcjogd2hpdGUgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIucHJpbnRpbmcgLmxpbmUgLmNvbnRlbnQgewogIGJvcmRlcjogbm9uZSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlci5jb2xsYXBzZWQgewogIG92ZXJmbG93OiB2aXNpYmxlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLmNvbGxhcHNlZCAudG9vbGJhciB7CiAgY29sb3I6IGJsdWUgIWltcG9ydGFudDsKICBiYWNrZ3JvdW5kOiB3aGl0ZSAhaW1wb3J0YW50OwogIGJvcmRlcjogMXB4IHNvbGlkICM2Y2UyNmMgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIuY29sbGFwc2VkIC50b29sYmFyIGEgewogIGNvbG9yOiBibHVlICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyLmNvbGxhcHNlZCAudG9vbGJhciBhOmhvdmVyIHsKICBjb2xvcjogcmVkICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC50b29sYmFyIHsKICBjb2xvcjogd2hpdGUgIWltcG9ydGFudDsKICBiYWNrZ3JvdW5kOiAjNmNlMjZjICFpbXBvcnRhbnQ7CiAgYm9yZGVyOiBub25lICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC50b29sYmFyIGEgewogIGNvbG9yOiB3aGl0ZSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAudG9vbGJhciBhOmhvdmVyIHsKICBjb2xvcjogYmxhY2sgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIgLnBsYWluLCAuc3ludGF4aGlnaGxpZ2h0ZXIgLnBsYWluIGEgewogIGNvbG9yOiBibGFjayAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuY29tbWVudHMsIC5zeW50YXhoaWdobGlnaHRlciAuY29tbWVudHMgYSB7CiAgY29sb3I6ICMwMDgyMDAgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIgLnN0cmluZywgLnN5bnRheGhpZ2hsaWdodGVyIC5zdHJpbmcgYSB7CiAgY29sb3I6IGJsdWUgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIgLmtleXdvcmQgewogIGNvbG9yOiAjMDA2Njk5ICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC5wcmVwcm9jZXNzb3IgewogIGNvbG9yOiBncmF5ICFpbXBvcnRhbnQ7Cn0KLnN5bnRheGhpZ2hsaWdodGVyIC52YXJpYWJsZSB7CiAgY29sb3I6ICNhYTc3MDAgIWltcG9ydGFudDsKfQouc3ludGF4aGlnaGxpZ2h0ZXIgLnZhbHVlIHsKICBjb2xvcjogIzAwOTkwMCAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuZnVuY3Rpb25zIHsKICBjb2xvcjogI2ZmMTQ5MyAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuY29uc3RhbnRzIHsKICBjb2xvcjogIzAwNjZjYyAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuc2NyaXB0IHsKICBmb250LXdlaWdodDogYm9sZCAhaW1wb3J0YW50OwogIGNvbG9yOiAjMDA2Njk5ICFpbXBvcnRhbnQ7CiAgYmFja2dyb3VuZC1jb2xvcjogbm9uZSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuY29sb3IxLCAuc3ludGF4aGlnaGxpZ2h0ZXIgLmNvbG9yMSBhIHsKICBjb2xvcjogZ3JheSAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuY29sb3IyLCAuc3ludGF4aGlnaGxpZ2h0ZXIgLmNvbG9yMiBhIHsKICBjb2xvcjogI2ZmMTQ5MyAhaW1wb3J0YW50Owp9Ci5zeW50YXhoaWdobGlnaHRlciAuY29sb3IzLCAuc3ludGF4aGlnaGxpZ2h0ZXIgLmNvbG9yMyBhIHsKICBjb2xvcjogcmVkICFpbXBvcnRhbnQ7Cn0KCi5zeW50YXhoaWdobGlnaHRlciAua2V5d29yZCB7CiAgZm9udC13ZWlnaHQ6IGJvbGQgIWltcG9ydGFudDsKfQo%3D" /> <script type="text/javascript" src="data:application/javascript;base64,Ly8gWFJlZ0V4cCAxLjUuMQovLyAoYykgMjAwNy0yMDEyIFN0ZXZlbiBMZXZpdGhhbgovLyBNSVQgTGljZW5zZQovLyA8aHR0cDovL3hyZWdleHAuY29tPgovLyBQcm92aWRlcyBhbiBhdWdtZW50ZWQsIGV4dGVuc2libGUsIGNyb3NzLWJyb3dzZXIgaW1wbGVtZW50YXRpb24gb2YgcmVndWxhciBleHByZXNzaW9ucywKLy8gaW5jbHVkaW5nIHN1cHBvcnQgZm9yIGFkZGl0aW9uYWwgc3ludGF4LCBmbGFncywgYW5kIG1ldGhvZHMKCnZhciBYUmVnRXhwOwoKaWYgKFhSZWdFeHApIHsKICAgIC8vIEF2b2lkIHJ1bm5pbmcgdHdpY2UsIHNpbmNlIHRoYXQgd291bGQgYnJlYWsgcmVmZXJlbmNlcyB0byBuYXRpdmUgZ2xvYmFscwogICAgdGhyb3cgRXJyb3IoImNhbid0IGxvYWQgWFJlZ0V4cCB0d2ljZSBpbiB0aGUgc2FtZSBmcmFtZSIpOwp9CgovLyBSdW4gd2l0aGluIGFuIGFub255bW91cyBmdW5jdGlvbiB0byBwcm90ZWN0IHZhcmlhYmxlcyBhbmQgYXZvaWQgbmV3IGdsb2JhbHMKKGZ1bmN0aW9uICh1bmRlZmluZWQpIHsKCiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gIENvbnN0cnVjdG9yCiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKICAgIC8vIEFjY2VwdHMgYSBwYXR0ZXJuIGFuZCBmbGFnczsgcmV0dXJucyBhIG5ldywgZXh0ZW5kZWQgYFJlZ0V4cGAgb2JqZWN0LiBEaWZmZXJzIGZyb20gYSBuYXRpdmUKICAgIC8vIHJlZ3VsYXIgZXhwcmVzc2lvbiBpbiB0aGF0IGFkZGl0aW9uYWwgc3ludGF4IGFuZCBmbGFncyBhcmUgc3VwcG9ydGVkIGFuZCBjcm9zcy1icm93c2VyCiAgICAvLyBzeW50YXggaW5jb25zaXN0ZW5jaWVzIGFyZSBhbWVsaW9yYXRlZC4gYFhSZWdFeHAoL3JlZ2V4LylgIGNsb25lcyBhbiBleGlzdGluZyByZWdleCBhbmQKICAgIC8vIGNvbnZlcnRzIHRvIHR5cGUgWFJlZ0V4cAogICAgWFJlZ0V4cCA9IGZ1bmN0aW9uIChwYXR0ZXJuLCBmbGFncykgewogICAgICAgIHZhciBvdXRwdXQgPSBbXSwKICAgICAgICAgICAgY3VyclNjb3BlID0gWFJlZ0V4cC5PVVRTSURFX0NMQVNTLAogICAgICAgICAgICBwb3MgPSAwLAogICAgICAgICAgICBjb250ZXh0LCB0b2tlblJlc3VsdCwgbWF0Y2gsIGNociwgcmVnZXg7CgogICAgICAgIGlmIChYUmVnRXhwLmlzUmVnRXhwKHBhdHRlcm4pKSB7CiAgICAgICAgICAgIGlmIChmbGFncyAhPT0gdW5kZWZpbmVkKQogICAgICAgICAgICAgICAgdGhyb3cgVHlwZUVycm9yKCJjYW4ndCBzdXBwbHkgZmxhZ3Mgd2hlbiBjb25zdHJ1Y3Rpbmcgb25lIFJlZ0V4cCBmcm9tIGFub3RoZXIiKTsKICAgICAgICAgICAgcmV0dXJuIGNsb25lKHBhdHRlcm4pOwogICAgICAgIH0KICAgICAgICAvLyBUb2tlbnMgYmVjb21lIHBhcnQgb2YgdGhlIHJlZ2V4IGNvbnN0cnVjdGlvbiBwcm9jZXNzLCBzbyBwcm90ZWN0IGFnYWluc3QgaW5maW5pdGUKICAgICAgICAvLyByZWN1cnNpb24gd2hlbiBhbiBYUmVnRXhwIGlzIGNvbnN0cnVjdGVkIHdpdGhpbiBhIHRva2VuIGhhbmRsZXIgb3IgdHJpZ2dlcgogICAgICAgIGlmIChpc0luc2lkZUNvbnN0cnVjdG9yKQogICAgICAgICAgICB0aHJvdyBFcnJvcigiY2FuJ3QgY2FsbCB0aGUgWFJlZ0V4cCBjb25zdHJ1Y3RvciB3aXRoaW4gdG9rZW4gZGVmaW5pdGlvbiBmdW5jdGlvbnMiKTsKCiAgICAgICAgZmxhZ3MgPSBmbGFncyB8fCAiIjsKICAgICAgICBjb250ZXh0ID0geyAvLyBgdGhpc2Agb2JqZWN0IGZvciBjdXN0b20gdG9rZW5zCiAgICAgICAgICAgIGhhc05hbWVkQ2FwdHVyZTogZmFsc2UsCiAgICAgICAgICAgIGNhcHR1cmVOYW1lczogW10sCiAgICAgICAgICAgIGhhc0ZsYWc6IGZ1bmN0aW9uIChmbGFnKSB7cmV0dXJuIGZsYWdzLmluZGV4T2YoZmxhZykgPiAtMTt9LAogICAgICAgICAgICBzZXRGbGFnOiBmdW5jdGlvbiAoZmxhZykge2ZsYWdzICs9IGZsYWc7fQogICAgICAgIH07CgogICAgICAgIHdoaWxlIChwb3MgPCBwYXR0ZXJuLmxlbmd0aCkgewogICAgICAgICAgICAvLyBDaGVjayBmb3IgY3VzdG9tIHRva2VucyBhdCB0aGUgY3VycmVudCBwb3NpdGlvbgogICAgICAgICAgICB0b2tlblJlc3VsdCA9IHJ1blRva2VucyhwYXR0ZXJuLCBwb3MsIGN1cnJTY29wZSwgY29udGV4dCk7CgogICAgICAgICAgICBpZiAodG9rZW5SZXN1bHQpIHsKICAgICAgICAgICAgICAgIG91dHB1dC5wdXNoKHRva2VuUmVzdWx0Lm91dHB1dCk7CiAgICAgICAgICAgICAgICBwb3MgKz0gKHRva2VuUmVzdWx0Lm1hdGNoWzBdLmxlbmd0aCB8fCAxKTsKICAgICAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgICAgIC8vIENoZWNrIGZvciBuYXRpdmUgbXVsdGljaGFyYWN0ZXIgbWV0YXNlcXVlbmNlcyAoZXhjbHVkaW5nIGNoYXJhY3RlciBjbGFzc2VzKSBhdAogICAgICAgICAgICAgICAgLy8gdGhlIGN1cnJlbnQgcG9zaXRpb24KICAgICAgICAgICAgICAgIGlmIChtYXRjaCA9IG5hdGl2LmV4ZWMuY2FsbChuYXRpdmVUb2tlbnNbY3VyclNjb3BlXSwgcGF0dGVybi5zbGljZShwb3MpKSkgewogICAgICAgICAgICAgICAgICAgIG91dHB1dC5wdXNoKG1hdGNoWzBdKTsKICAgICAgICAgICAgICAgICAgICBwb3MgKz0gbWF0Y2hbMF0ubGVuZ3RoOwogICAgICAgICAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgICAgICAgICBjaHIgPSBwYXR0ZXJuLmNoYXJBdChwb3MpOwogICAgICAgICAgICAgICAgICAgIGlmIChjaHIgPT09ICJbIikKICAgICAgICAgICAgICAgICAgICAgICAgY3VyclNjb3BlID0gWFJlZ0V4cC5JTlNJREVfQ0xBU1M7CiAgICAgICAgICAgICAgICAgICAgZWxzZSBpZiAoY2hyID09PSAiXSIpCiAgICAgICAgICAgICAgICAgICAgICAgIGN1cnJTY29wZSA9IFhSZWdFeHAuT1VUU0lERV9DTEFTUzsKICAgICAgICAgICAgICAgICAgICAvLyBBZHZhbmNlIHBvc2l0aW9uIG9uZSBjaGFyYWN0ZXIKICAgICAgICAgICAgICAgICAgICBvdXRwdXQucHVzaChjaHIpOwogICAgICAgICAgICAgICAgICAgIHBvcysrOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICB9CiAgICAgICAgfQoKICAgICAgICByZWdleCA9IFJlZ0V4cChvdXRwdXQuam9pbigiIiksIG5hdGl2LnJlcGxhY2UuY2FsbChmbGFncywgZmxhZ0NsaXAsICIiKSk7CiAgICAgICAgcmVnZXguX3hyZWdleHAgPSB7CiAgICAgICAgICAgIHNvdXJjZTogcGF0dGVybiwKICAgICAgICAgICAgY2FwdHVyZU5hbWVzOiBjb250ZXh0Lmhhc05hbWVkQ2FwdHVyZSA/IGNvbnRleHQuY2FwdHVyZU5hbWVzIDogbnVsbAogICAgICAgIH07CiAgICAgICAgcmV0dXJuIHJlZ2V4OwogICAgfTsKCgogICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vICBQdWJsaWMgcHJvcGVydGllcwogICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiAgICBYUmVnRXhwLnZlcnNpb24gPSAiMS41LjEiOwoKICAgIC8vIFRva2VuIHNjb3BlIGJpdGZsYWdzCiAgICBYUmVnRXhwLklOU0lERV9DTEFTUyA9IDE7CiAgICBYUmVnRXhwLk9VVFNJREVfQ0xBU1MgPSAyOwoKCiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gIFByaXZhdGUgdmFyaWFibGVzCiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKICAgIHZhciByZXBsYWNlbWVudFRva2VuID0gL1wkKD86KFxkXGQ/fFskJmAnXSl8eyhbJFx3XSspfSkvZywKICAgICAgICBmbGFnQ2xpcCA9IC9bXmdpbXldK3woW1xzXFNdKSg/PVtcc1xTXSpcMSkvZywgLy8gTm9ubmF0aXZlIGFuZCBkdXBsaWNhdGUgZmxhZ3MKICAgICAgICBxdWFudGlmaWVyID0gL14oPzpbPyorXXx7XGQrKD86LFxkKik/fSlcPz8vLAogICAgICAgIGlzSW5zaWRlQ29uc3RydWN0b3IgPSBmYWxzZSwKICAgICAgICB0b2tlbnMgPSBbXSwKICAgICAgICAvLyBDb3B5IG5hdGl2ZSBnbG9iYWxzIGZvciByZWZlcmVuY2UgKCJuYXRpdmUiIGlzIGFuIEVTMyByZXNlcnZlZCBrZXl3b3JkKQogICAgICAgIG5hdGl2ID0gewogICAgICAgICAgICBleGVjOiBSZWdFeHAucHJvdG90eXBlLmV4ZWMsCiAgICAgICAgICAgIHRlc3Q6IFJlZ0V4cC5wcm90b3R5cGUudGVzdCwKICAgICAgICAgICAgbWF0Y2g6IFN0cmluZy5wcm90b3R5cGUubWF0Y2gsCiAgICAgICAgICAgIHJlcGxhY2U6IFN0cmluZy5wcm90b3R5cGUucmVwbGFjZSwKICAgICAgICAgICAgc3BsaXQ6IFN0cmluZy5wcm90b3R5cGUuc3BsaXQKICAgICAgICB9LAogICAgICAgIGNvbXBsaWFudEV4ZWNOcGNnID0gbmF0aXYuZXhlYy5jYWxsKC8oKT8/LywgIiIpWzFdID09PSB1bmRlZmluZWQsIC8vIGNoZWNrIGBleGVjYCBoYW5kbGluZyBvZiBub25wYXJ0aWNpcGF0aW5nIGNhcHR1cmluZyBncm91cHMKICAgICAgICBjb21wbGlhbnRMYXN0SW5kZXhJbmNyZW1lbnQgPSBmdW5jdGlvbiAoKSB7CiAgICAgICAgICAgIHZhciB4ID0gL14vZzsKICAgICAgICAgICAgbmF0aXYudGVzdC5jYWxsKHgsICIiKTsKICAgICAgICAgICAgcmV0dXJuICF4Lmxhc3RJbmRleDsKICAgICAgICB9KCksCiAgICAgICAgaGFzTmF0aXZlWSA9IFJlZ0V4cC5wcm90b3R5cGUuc3RpY2t5ICE9PSB1bmRlZmluZWQsCiAgICAgICAgbmF0aXZlVG9rZW5zID0ge307CgogICAgLy8gYG5hdGl2ZVRva2Vuc2AgbWF0Y2ggbmF0aXZlIG11bHRpY2hhcmFjdGVyIG1ldGFzZXF1ZW5jZXMgb25seSAoaW5jbHVkaW5nIGRlcHJlY2F0ZWQgb2N0YWxzLAogICAgLy8gZXhjbHVkaW5nIGNoYXJhY3RlciBjbGFzc2VzKQogICAgbmF0aXZlVG9rZW5zW1hSZWdFeHAuSU5TSURFX0NMQVNTXSA9IC9eKD86XFwoPzpbMC0zXVswLTddezAsMn18WzQtN11bMC03XT98eFtcZEEtRmEtZl17Mn18dVtcZEEtRmEtZl17NH18Y1tBLVphLXpdfFtcc1xTXSkpLzsKICAgIG5hdGl2ZVRva2Vuc1tYUmVnRXhwLk9VVFNJREVfQ0xBU1NdID0gL14oPzpcXCg/OjAoPzpbMC0zXVswLTddezAsMn18WzQtN11bMC03XT8pP3xbMS05XVxkKnx4W1xkQS1GYS1mXXsyfXx1W1xkQS1GYS1mXXs0fXxjW0EtWmEtel18W1xzXFNdKXxcKFw/Wzo9IV18Wz8qK11cP3x7XGQrKD86LFxkKik/fVw/PykvOwoKCiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gIFB1YmxpYyBtZXRob2RzCiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKICAgIC8vIExldHMgeW91IGV4dGVuZCBvciBjaGFuZ2UgWFJlZ0V4cCBzeW50YXggYW5kIGNyZWF0ZSBjdXN0b20gZmxhZ3MuIFRoaXMgaXMgdXNlZCBpbnRlcm5hbGx5IGJ5CiAgICAvLyB0aGUgWFJlZ0V4cCBsaWJyYXJ5IGFuZCBjYW4gYmUgdXNlZCB0byBjcmVhdGUgWFJlZ0V4cCBwbHVnaW5zLiBUaGlzIGZ1bmN0aW9uIGlzIGludGVuZGVkIGZvcgogICAgLy8gdXNlcnMgd2l0aCBhZHZhbmNlZCBrbm93bGVkZ2Ugb2YgSmF2YVNjcmlwdCdzIHJlZ3VsYXIgZXhwcmVzc2lvbiBzeW50YXggYW5kIGJlaGF2aW9yLiBJdCBjYW4KICAgIC8vIGJlIGRpc2FibGVkIGJ5IGBYUmVnRXhwLmZyZWV6ZVRva2Vuc2AKICAgIFhSZWdFeHAuYWRkVG9rZW4gPSBmdW5jdGlvbiAocmVnZXgsIGhhbmRsZXIsIHNjb3BlLCB0cmlnZ2VyKSB7CiAgICAgICAgdG9rZW5zLnB1c2goewogICAgICAgICAgICBwYXR0ZXJuOiBjbG9uZShyZWdleCwgImciICsgKGhhc05hdGl2ZVkgPyAieSIgOiAiIikpLAogICAgICAgICAgICBoYW5kbGVyOiBoYW5kbGVyLAogICAgICAgICAgICBzY29wZTogc2NvcGUgfHwgWFJlZ0V4cC5PVVRTSURFX0NMQVNTLAogICAgICAgICAgICB0cmlnZ2VyOiB0cmlnZ2VyIHx8IG51bGwKICAgICAgICB9KTsKICAgIH07CgogICAgLy8gQWNjZXB0cyBhIHBhdHRlcm4gYW5kIGZsYWdzOyByZXR1cm5zIGFuIGV4dGVuZGVkIGBSZWdFeHBgIG9iamVjdC4gSWYgdGhlIHBhdHRlcm4gYW5kIGZsYWcKICAgIC8vIGNvbWJpbmF0aW9uIGhhcyBwcmV2aW91c2x5IGJlZW4gY2FjaGVkLCB0aGUgY2FjaGVkIGNvcHkgaXMgcmV0dXJuZWQ7IG90aGVyd2lzZSB0aGUgbmV3bHkKICAgIC8vIGNyZWF0ZWQgcmVnZXggaXMgY2FjaGVkCiAgICBYUmVnRXhwLmNhY2hlID0gZnVuY3Rpb24gKHBhdHRlcm4sIGZsYWdzKSB7CiAgICAgICAgdmFyIGtleSA9IHBhdHRlcm4gKyAiLyIgKyAoZmxhZ3MgfHwgIiIpOwogICAgICAgIHJldHVybiBYUmVnRXhwLmNhY2hlW2tleV0gfHwgKFhSZWdFeHAuY2FjaGVba2V5XSA9IFhSZWdFeHAocGF0dGVybiwgZmxhZ3MpKTsKICAgIH07CgogICAgLy8gQWNjZXB0cyBhIGBSZWdFeHBgIGluc3RhbmNlOyByZXR1cm5zIGEgY29weSB3aXRoIHRoZSBgL2dgIGZsYWcgc2V0LiBUaGUgY29weSBoYXMgYSBmcmVzaAogICAgLy8gYGxhc3RJbmRleGAgKHNldCB0byB6ZXJvKS4gSWYgeW91IHdhbnQgdG8gY29weSBhIHJlZ2V4IHdpdGhvdXQgZm9yY2luZyB0aGUgYGdsb2JhbGAKICAgIC8vIHByb3BlcnR5LCB1c2UgYFhSZWdFeHAocmVnZXgpYC4gRG8gbm90IHVzZSBgUmVnRXhwKHJlZ2V4KWAgYmVjYXVzZSBpdCB3aWxsIG5vdCBwcmVzZXJ2ZQogICAgLy8gc3BlY2lhbCBwcm9wZXJ0aWVzIHJlcXVpcmVkIGZvciBuYW1lZCBjYXB0dXJlCiAgICBYUmVnRXhwLmNvcHlBc0dsb2JhbCA9IGZ1bmN0aW9uIChyZWdleCkgewogICAgICAgIHJldHVybiBjbG9uZShyZWdleCwgImciKTsKICAgIH07CgogICAgLy8gQWNjZXB0cyBhIHN0cmluZzsgcmV0dXJucyB0aGUgc3RyaW5nIHdpdGggcmVnZXggbWV0YWNoYXJhY3RlcnMgZXNjYXBlZC4gVGhlIHJldHVybmVkIHN0cmluZwogICAgLy8gY2FuIHNhZmVseSBiZSB1c2VkIGF0IGFueSBwb2ludCB3aXRoaW4gYSByZWdleCB0byBtYXRjaCB0aGUgcHJvdmlkZWQgbGl0ZXJhbCBzdHJpbmcuIEVzY2FwZWQKICAgIC8vIGNoYXJhY3RlcnMgYXJlIFsgXSB7IH0gKCApICogKyA/IC0gLiAsIFwgXiAkIHwgIyBhbmQgd2hpdGVzcGFjZQogICAgWFJlZ0V4cC5lc2NhcGUgPSBmdW5jdGlvbiAoc3RyKSB7CiAgICAgICAgcmV0dXJuIHN0ci5yZXBsYWNlKC9bLVtcXXt9KCkqKz8uLFxcXiR8I1xzXS9nLCAiXFwkJiIpOwogICAgfTsKCiAgICAvLyBBY2NlcHRzIGEgc3RyaW5nIHRvIHNlYXJjaCwgcmVnZXggdG8gc2VhcmNoIHdpdGgsIHBvc2l0aW9uIHRvIHN0YXJ0IHRoZSBzZWFyY2ggd2l0aGluIHRoZQogICAgLy8gc3RyaW5nIChkZWZhdWx0OiAwKSwgYW5kIGFuIG9wdGlvbmFsIEJvb2xlYW4gaW5kaWNhdGluZyB3aGV0aGVyIG1hdGNoZXMgbXVzdCBzdGFydCBhdC1vci0KICAgIC8vIGFmdGVyIHRoZSBwb3NpdGlvbiBvciBhdCB0aGUgc3BlY2lmaWVkIHBvc2l0aW9uIG9ubHkuIFRoaXMgZnVuY3Rpb24gaWdub3JlcyB0aGUgYGxhc3RJbmRleGAKICAgIC8vIG9mIHRoZSBwcm92aWRlZCByZWdleCBpbiBpdHMgb3duIGhhbmRsaW5nLCBidXQgdXBkYXRlcyB0aGUgcHJvcGVydHkgZm9yIGNvbXBhdGliaWxpdHkKICAgIFhSZWdFeHAuZXhlY0F0ID0gZnVuY3Rpb24gKHN0ciwgcmVnZXgsIHBvcywgYW5jaG9yZWQpIHsKICAgICAgICB2YXIgcjIgPSBjbG9uZShyZWdleCwgImciICsgKChhbmNob3JlZCAmJiBoYXNOYXRpdmVZKSA/ICJ5IiA6ICIiKSksCiAgICAgICAgICAgIG1hdGNoOwogICAgICAgIHIyLmxhc3RJbmRleCA9IHBvcyA9IHBvcyB8fCAwOwogICAgICAgIG1hdGNoID0gcjIuZXhlYyhzdHIpOyAvLyBSdW4gdGhlIGFsdGVyZWQgYGV4ZWNgIChyZXF1aXJlZCBmb3IgYGxhc3RJbmRleGAgZml4LCBldGMuKQogICAgICAgIGlmIChhbmNob3JlZCAmJiBtYXRjaCAmJiBtYXRjaC5pbmRleCAhPT0gcG9zKQogICAgICAgICAgICBtYXRjaCA9IG51bGw7CiAgICAgICAgaWYgKHJlZ2V4Lmdsb2JhbCkKICAgICAgICAgICAgcmVnZXgubGFzdEluZGV4ID0gbWF0Y2ggPyByMi5sYXN0SW5kZXggOiAwOwogICAgICAgIHJldHVybiBtYXRjaDsKICAgIH07CgogICAgLy8gQnJlYWtzIHRoZSB1bnJlc3RvcmFibGUgbGluayB0byBYUmVnRXhwJ3MgcHJpdmF0ZSBsaXN0IG9mIHRva2VucywgdGhlcmVieSBwcmV2ZW50aW5nCiAgICAvLyBzeW50YXggYW5kIGZsYWcgY2hhbmdlcy4gU2hvdWxkIGJlIHJ1biBhZnRlciBYUmVnRXhwIGFuZCBhbnkgcGx1Z2lucyBhcmUgbG9hZGVkCiAgICBYUmVnRXhwLmZyZWV6ZVRva2VucyA9IGZ1bmN0aW9uICgpIHsKICAgICAgICBYUmVnRXhwLmFkZFRva2VuID0gZnVuY3Rpb24gKCkgewogICAgICAgICAgICB0aHJvdyBFcnJvcigiY2FuJ3QgcnVuIGFkZFRva2VuIGFmdGVyIGZyZWV6ZVRva2VucyIpOwogICAgICAgIH07CiAgICB9OwoKICAgIC8vIEFjY2VwdHMgYW55IHZhbHVlOyByZXR1cm5zIGEgQm9vbGVhbiBpbmRpY2F0aW5nIHdoZXRoZXIgdGhlIGFyZ3VtZW50IGlzIGEgYFJlZ0V4cGAgb2JqZWN0LgogICAgLy8gTm90ZSB0aGF0IHRoaXMgaXMgYWxzbyBgdHJ1ZWAgZm9yIHJlZ2V4IGxpdGVyYWxzIGFuZCByZWdleGVzIGNyZWF0ZWQgYnkgdGhlIGBYUmVnRXhwYAogICAgLy8gY29uc3RydWN0b3IuIFRoaXMgd29ya3MgY29ycmVjdGx5IGZvciB2YXJpYWJsZXMgY3JlYXRlZCBpbiBhbm90aGVyIGZyYW1lLCB3aGVuIGBpbnN0YW5jZW9mYAogICAgLy8gYW5kIGBjb25zdHJ1Y3RvcmAgY2hlY2tzIHdvdWxkIGZhaWwgdG8gd29yayBhcyBpbnRlbmRlZAogICAgWFJlZ0V4cC5pc1JlZ0V4cCA9IGZ1bmN0aW9uIChvKSB7CiAgICAgICAgcmV0dXJuIE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChvKSA9PT0gIltvYmplY3QgUmVnRXhwXSI7CiAgICB9OwoKICAgIC8vIEV4ZWN1dGVzIGBjYWxsYmFja2Agb25jZSBwZXIgbWF0Y2ggd2l0aGluIGBzdHJgLiBQcm92aWRlcyBhIHNpbXBsZXIgYW5kIGNsZWFuZXIgd2F5IHRvCiAgICAvLyBpdGVyYXRlIG92ZXIgcmVnZXggbWF0Y2hlcyBjb21wYXJlZCB0byB0aGUgdHJhZGl0aW9uYWwgYXBwcm9hY2hlcyBvZiBzdWJ2ZXJ0aW5nCiAgICAvLyBgU3RyaW5nLnByb3RvdHlwZS5yZXBsYWNlYCBvciByZXBlYXRlZGx5IGNhbGxpbmcgYGV4ZWNgIHdpdGhpbiBhIGB3aGlsZWAgbG9vcAogICAgWFJlZ0V4cC5pdGVyYXRlID0gZnVuY3Rpb24gKHN0ciwgcmVnZXgsIGNhbGxiYWNrLCBjb250ZXh0KSB7CiAgICAgICAgdmFyIHIyID0gY2xvbmUocmVnZXgsICJnIiksCiAgICAgICAgICAgIGkgPSAtMSwgbWF0Y2g7CiAgICAgICAgd2hpbGUgKG1hdGNoID0gcjIuZXhlYyhzdHIpKSB7IC8vIFJ1biB0aGUgYWx0ZXJlZCBgZXhlY2AgKHJlcXVpcmVkIGZvciBgbGFzdEluZGV4YCBmaXgsIGV0Yy4pCiAgICAgICAgICAgIGlmIChyZWdleC5nbG9iYWwpCiAgICAgICAgICAgICAgICByZWdleC5sYXN0SW5kZXggPSByMi5sYXN0SW5kZXg7IC8vIERvaW5nIHRoaXMgdG8gZm9sbG93IGV4cGVjdGF0aW9ucyBpZiBgbGFzdEluZGV4YCBpcyBjaGVja2VkIHdpdGhpbiBgY2FsbGJhY2tgCiAgICAgICAgICAgIGNhbGxiYWNrLmNhbGwoY29udGV4dCwgbWF0Y2gsICsraSwgc3RyLCByZWdleCk7CiAgICAgICAgICAgIGlmIChyMi5sYXN0SW5kZXggPT09IG1hdGNoLmluZGV4KQogICAgICAgICAgICAgICAgcjIubGFzdEluZGV4Kys7CiAgICAgICAgfQogICAgICAgIGlmIChyZWdleC5nbG9iYWwpCiAgICAgICAgICAgIHJlZ2V4Lmxhc3RJbmRleCA9IDA7CiAgICB9OwoKICAgIC8vIEFjY2VwdHMgYSBzdHJpbmcgYW5kIGFuIGFycmF5IG9mIHJlZ2V4ZXM7IHJldHVybnMgdGhlIHJlc3VsdCBvZiB1c2luZyBlYWNoIHN1Y2Nlc3NpdmUgcmVnZXgKICAgIC8vIHRvIHNlYXJjaCB3aXRoaW4gdGhlIG1hdGNoZXMgb2YgdGhlIHByZXZpb3VzIHJlZ2V4LiBUaGUgYXJyYXkgb2YgcmVnZXhlcyBjYW4gYWxzbyBjb250YWluCiAgICAvLyBvYmplY3RzIHdpdGggYHJlZ2V4YCBhbmQgYGJhY2tyZWZgIHByb3BlcnRpZXMsIGluIHdoaWNoIGNhc2UgdGhlIG5hbWVkIG9yIG51bWJlcmVkIGJhY2stCiAgICAvLyByZWZlcmVuY2VzIHNwZWNpZmllZCBhcmUgcGFzc2VkIGZvcndhcmQgdG8gdGhlIG5leHQgcmVnZXggb3IgcmV0dXJuZWQuIEUuZy46CiAgICAvLyB2YXIgeHJlZ2V4cEltZ0ZpbGVOYW1lcyA9IFhSZWdFeHAubWF0Y2hDaGFpbihodG1sLCBbCiAgICAvLyAgICAge3JlZ2V4OiAvPGltZ1xiKFtePl0rKT4vaSwgYmFja3JlZjogMX0sIC8vIDxpbWc%2BIHRhZyBhdHRyaWJ1dGVzCiAgICAvLyAgICAge3JlZ2V4OiBYUmVnRXhwKCcoP2l4KSBcXHMgc3JjPSIgKD88c3JjPiBbXiJdKyApJyksIGJhY2tyZWY6ICJzcmMifSwgLy8gc3JjIGF0dHJpYnV0ZSB2YWx1ZXMKICAgIC8vICAgICB7cmVnZXg6IFhSZWdFeHAoIl5odHRwOi8veHJlZ2V4cFxcLmNvbSgvW14jP10rKSIsICJpIiksIGJhY2tyZWY6IDF9LCAvLyB4cmVnZXhwLmNvbSBwYXRocwogICAgLy8gICAgIC9bXlwvXSskLyAvLyBmaWxlbmFtZXMgKHN0cmlwIGRpcmVjdG9yeSBwYXRocykKICAgIC8vIF0pOwogICAgWFJlZ0V4cC5tYXRjaENoYWluID0gZnVuY3Rpb24gKHN0ciwgY2hhaW4pIHsKICAgICAgICByZXR1cm4gZnVuY3Rpb24gcmVjdXJzZUNoYWluICh2YWx1ZXMsIGxldmVsKSB7CiAgICAgICAgICAgIHZhciBpdGVtID0gY2hhaW5bbGV2ZWxdLnJlZ2V4ID8gY2hhaW5bbGV2ZWxdIDoge3JlZ2V4OiBjaGFpbltsZXZlbF19LAogICAgICAgICAgICAgICAgcmVnZXggPSBjbG9uZShpdGVtLnJlZ2V4LCAiZyIpLAogICAgICAgICAgICAgICAgbWF0Y2hlcyA9IFtdLCBpOwogICAgICAgICAgICBmb3IgKGkgPSAwOyBpIDwgdmFsdWVzLmxlbmd0aDsgaSsrKSB7CiAgICAgICAgICAgICAgICBYUmVnRXhwLml0ZXJhdGUodmFsdWVzW2ldLCByZWdleCwgZnVuY3Rpb24gKG1hdGNoKSB7CiAgICAgICAgICAgICAgICAgICAgbWF0Y2hlcy5wdXNoKGl0ZW0uYmFja3JlZiA/IChtYXRjaFtpdGVtLmJhY2tyZWZdIHx8ICIiKSA6IG1hdGNoWzBdKTsKICAgICAgICAgICAgICAgIH0pOwogICAgICAgICAgICB9CiAgICAgICAgICAgIHJldHVybiAoKGxldmVsID09PSBjaGFpbi5sZW5ndGggLSAxKSB8fCAhbWF0Y2hlcy5sZW5ndGgpID8KICAgICAgICAgICAgICAgIG1hdGNoZXMgOiByZWN1cnNlQ2hhaW4obWF0Y2hlcywgbGV2ZWwgKyAxKTsKICAgICAgICB9KFtzdHJdLCAwKTsKICAgIH07CgoKICAgIC8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyAgTmV3IFJlZ0V4cCBwcm90b3R5cGUgbWV0aG9kcwogICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiAgICAvLyBBY2NlcHRzIGEgY29udGV4dCBvYmplY3QgYW5kIGFyZ3VtZW50cyBhcnJheTsgcmV0dXJucyB0aGUgcmVzdWx0IG9mIGNhbGxpbmcgYGV4ZWNgIHdpdGggdGhlCiAgICAvLyBmaXJzdCB2YWx1ZSBpbiB0aGUgYXJndW1lbnRzIGFycmF5LiB0aGUgY29udGV4dCBpcyBpZ25vcmVkIGJ1dCBpcyBhY2NlcHRlZCBmb3IgY29uZ3J1aXR5CiAgICAvLyB3aXRoIGBGdW5jdGlvbi5wcm90b3R5cGUuYXBwbHlgCiAgICBSZWdFeHAucHJvdG90eXBlLmFwcGx5ID0gZnVuY3Rpb24gKGNvbnRleHQsIGFyZ3MpIHsKICAgICAgICByZXR1cm4gdGhpcy5leGVjKGFyZ3NbMF0pOwogICAgfTsKCiAgICAvLyBBY2NlcHRzIGEgY29udGV4dCBvYmplY3QgYW5kIHN0cmluZzsgcmV0dXJucyB0aGUgcmVzdWx0IG9mIGNhbGxpbmcgYGV4ZWNgIHdpdGggdGhlIHByb3ZpZGVkCiAgICAvLyBzdHJpbmcuIHRoZSBjb250ZXh0IGlzIGlnbm9yZWQgYnV0IGlzIGFjY2VwdGVkIGZvciBjb25ncnVpdHkgd2l0aCBgRnVuY3Rpb24ucHJvdG90eXBlLmNhbGxgCiAgICBSZWdFeHAucHJvdG90eXBlLmNhbGwgPSBmdW5jdGlvbiAoY29udGV4dCwgc3RyKSB7CiAgICAgICAgcmV0dXJuIHRoaXMuZXhlYyhzdHIpOwogICAgfTsKCgogICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vICBPdmVycmlkZW4gbmF0aXZlIG1ldGhvZHMKICAgIC8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgogICAgLy8gQWRkcyBuYW1lZCBjYXB0dXJlIHN1cHBvcnQgKHdpdGggYmFja3JlZmVyZW5jZXMgcmV0dXJuZWQgYXMgYHJlc3VsdC5uYW1lYCksIGFuZCBmaXhlcyB0d28KICAgIC8vIGNyb3NzLWJyb3dzZXIgaXNzdWVzIHBlciBFUzM6CiAgICAvLyAtIENhcHR1cmVkIHZhbHVlcyBmb3Igbm9ucGFydGljaXBhdGluZyBjYXB0dXJpbmcgZ3JvdXBzIHNob3VsZCBiZSByZXR1cm5lZCBhcyBgdW5kZWZpbmVkYCwKICAgIC8vICAgcmF0aGVyIHRoYW4gdGhlIGVtcHR5IHN0cmluZy4KICAgIC8vIC0gYGxhc3RJbmRleGAgc2hvdWxkIG5vdCBiZSBpbmNyZW1lbnRlZCBhZnRlciB6ZXJvLWxlbmd0aCBtYXRjaGVzLgogICAgUmVnRXhwLnByb3RvdHlwZS5leGVjID0gZnVuY3Rpb24gKHN0cikgewogICAgICAgIHZhciBtYXRjaCwgbmFtZSwgcjIsIG9yaWdMYXN0SW5kZXg7CiAgICAgICAgaWYgKCF0aGlzLmdsb2JhbCkKICAgICAgICAgICAgb3JpZ0xhc3RJbmRleCA9IHRoaXMubGFzdEluZGV4OwogICAgICAgIG1hdGNoID0gbmF0aXYuZXhlYy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOwogICAgICAgIGlmIChtYXRjaCkgewogICAgICAgICAgICAvLyBGaXggYnJvd3NlcnMgd2hvc2UgYGV4ZWNgIG1ldGhvZHMgZG9uJ3QgY29uc2lzdGVudGx5IHJldHVybiBgdW5kZWZpbmVkYCBmb3IKICAgICAgICAgICAgLy8gbm9ucGFydGljaXBhdGluZyBjYXB0dXJpbmcgZ3JvdXBzCiAgICAgICAgICAgIGlmICghY29tcGxpYW50RXhlY05wY2cgJiYgbWF0Y2gubGVuZ3RoID4gMSAmJiBpbmRleE9mKG1hdGNoLCAiIikgPiAtMSkgewogICAgICAgICAgICAgICAgcjIgPSBSZWdFeHAodGhpcy5zb3VyY2UsIG5hdGl2LnJlcGxhY2UuY2FsbChnZXROYXRpdmVGbGFncyh0aGlzKSwgImciLCAiIikpOwogICAgICAgICAgICAgICAgLy8gVXNpbmcgYHN0ci5zbGljZShtYXRjaC5pbmRleClgIHJhdGhlciB0aGFuIGBtYXRjaFswXWAgaW4gY2FzZSBsb29rYWhlYWQgYWxsb3dlZAogICAgICAgICAgICAgICAgLy8gbWF0Y2hpbmcgZHVlIHRvIGNoYXJhY3RlcnMgb3V0c2lkZSB0aGUgbWF0Y2gKICAgICAgICAgICAgICAgIG5hdGl2LnJlcGxhY2UuY2FsbCgoc3RyICsgIiIpLnNsaWNlKG1hdGNoLmluZGV4KSwgcjIsIGZ1bmN0aW9uICgpIHsKICAgICAgICAgICAgICAgICAgICBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGggLSAyOyBpKyspIHsKICAgICAgICAgICAgICAgICAgICAgICAgaWYgKGFyZ3VtZW50c1tpXSA9PT0gdW5kZWZpbmVkKQogICAgICAgICAgICAgICAgICAgICAgICAgICAgbWF0Y2hbaV0gPSB1bmRlZmluZWQ7CiAgICAgICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgfSk7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgLy8gQXR0YWNoIG5hbWVkIGNhcHR1cmUgcHJvcGVydGllcwogICAgICAgICAgICBpZiAodGhpcy5feHJlZ2V4cCAmJiB0aGlzLl94cmVnZXhwLmNhcHR1cmVOYW1lcykgewogICAgICAgICAgICAgICAgZm9yICh2YXIgaSA9IDE7IGkgPCBtYXRjaC5sZW5ndGg7IGkrKykgewogICAgICAgICAgICAgICAgICAgIG5hbWUgPSB0aGlzLl94cmVnZXhwLmNhcHR1cmVOYW1lc1tpIC0gMV07CiAgICAgICAgICAgICAgICAgICAgaWYgKG5hbWUpCiAgICAgICAgICAgICAgICAgICAgICAgbWF0Y2hbbmFtZV0gPSBtYXRjaFtpXTsKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgfQogICAgICAgICAgICAvLyBGaXggYnJvd3NlcnMgdGhhdCBpbmNyZW1lbnQgYGxhc3RJbmRleGAgYWZ0ZXIgemVyby1sZW5ndGggbWF0Y2hlcwogICAgICAgICAgICBpZiAoIWNvbXBsaWFudExhc3RJbmRleEluY3JlbWVudCAmJiB0aGlzLmdsb2JhbCAmJiAhbWF0Y2hbMF0ubGVuZ3RoICYmICh0aGlzLmxhc3RJbmRleCA%2BIG1hdGNoLmluZGV4KSkKICAgICAgICAgICAgICAgIHRoaXMubGFzdEluZGV4LS07CiAgICAgICAgfQogICAgICAgIGlmICghdGhpcy5nbG9iYWwpCiAgICAgICAgICAgIHRoaXMubGFzdEluZGV4ID0gb3JpZ0xhc3RJbmRleDsgLy8gRml4IElFLCBPcGVyYSBidWcgKGxhc3QgdGVzdGVkIElFIDkuMC41LCBPcGVyYSAxMS42MSBvbiBXaW5kb3dzKQogICAgICAgIHJldHVybiBtYXRjaDsKICAgIH07CgogICAgLy8gRml4IGJyb3dzZXIgYnVncyBpbiBuYXRpdmUgbWV0aG9kCiAgICBSZWdFeHAucHJvdG90eXBlLnRlc3QgPSBmdW5jdGlvbiAoc3RyKSB7CiAgICAgICAgLy8gVXNlIHRoZSBuYXRpdmUgYGV4ZWNgIHRvIHNraXAgc29tZSBwcm9jZXNzaW5nIG92ZXJoZWFkLCBldmVuIHRob3VnaCB0aGUgYWx0ZXJlZAogICAgICAgIC8vIGBleGVjYCB3b3VsZCB0YWtlIGNhcmUgb2YgdGhlIGBsYXN0SW5kZXhgIGZpeGVzCiAgICAgICAgdmFyIG1hdGNoLCBvcmlnTGFzdEluZGV4OwogICAgICAgIGlmICghdGhpcy5nbG9iYWwpCiAgICAgICAgICAgIG9yaWdMYXN0SW5kZXggPSB0aGlzLmxhc3RJbmRleDsKICAgICAgICBtYXRjaCA9IG5hdGl2LmV4ZWMuY2FsbCh0aGlzLCBzdHIpOwogICAgICAgIC8vIEZpeCBicm93c2VycyB0aGF0IGluY3JlbWVudCBgbGFzdEluZGV4YCBhZnRlciB6ZXJvLWxlbmd0aCBtYXRjaGVzCiAgICAgICAgaWYgKG1hdGNoICYmICFjb21wbGlhbnRMYXN0SW5kZXhJbmNyZW1lbnQgJiYgdGhpcy5nbG9iYWwgJiYgIW1hdGNoWzBdLmxlbmd0aCAmJiAodGhpcy5sYXN0SW5kZXggPiBtYXRjaC5pbmRleCkpCiAgICAgICAgICAgIHRoaXMubGFzdEluZGV4LS07CiAgICAgICAgaWYgKCF0aGlzLmdsb2JhbCkKICAgICAgICAgICAgdGhpcy5sYXN0SW5kZXggPSBvcmlnTGFzdEluZGV4OyAvLyBGaXggSUUsIE9wZXJhIGJ1ZyAobGFzdCB0ZXN0ZWQgSUUgOS4wLjUsIE9wZXJhIDExLjYxIG9uIFdpbmRvd3MpCiAgICAgICAgcmV0dXJuICEhbWF0Y2g7CiAgICB9OwoKICAgIC8vIEFkZHMgbmFtZWQgY2FwdHVyZSBzdXBwb3J0IGFuZCBmaXhlcyBicm93c2VyIGJ1Z3MgaW4gbmF0aXZlIG1ldGhvZAogICAgU3RyaW5nLnByb3RvdHlwZS5tYXRjaCA9IGZ1bmN0aW9uIChyZWdleCkgewogICAgICAgIGlmICghWFJlZ0V4cC5pc1JlZ0V4cChyZWdleCkpCiAgICAgICAgICAgIHJlZ2V4ID0gUmVnRXhwKHJlZ2V4KTsgLy8gTmF0aXZlIGBSZWdFeHBgCiAgICAgICAgaWYgKHJlZ2V4Lmdsb2JhbCkgewogICAgICAgICAgICB2YXIgcmVzdWx0ID0gbmF0aXYubWF0Y2guYXBwbHkodGhpcywgYXJndW1lbnRzKTsKICAgICAgICAgICAgcmVnZXgubGFzdEluZGV4ID0gMDsgLy8gRml4IElFIGJ1ZwogICAgICAgICAgICByZXR1cm4gcmVzdWx0OwogICAgICAgIH0KICAgICAgICByZXR1cm4gcmVnZXguZXhlYyh0aGlzKTsgLy8gUnVuIHRoZSBhbHRlcmVkIGBleGVjYAogICAgfTsKCiAgICAvLyBBZGRzIHN1cHBvcnQgZm9yIGAke259YCB0b2tlbnMgZm9yIG5hbWVkIGFuZCBudW1iZXJlZCBiYWNrcmVmZXJlbmNlcyBpbiByZXBsYWNlbWVudCB0ZXh0LAogICAgLy8gYW5kIHByb3ZpZGVzIG5hbWVkIGJhY2tyZWZlcmVuY2VzIHRvIHJlcGxhY2VtZW50IGZ1bmN0aW9ucyBhcyBgYXJndW1lbnRzWzBdLm5hbWVgLiBBbHNvCiAgICAvLyBmaXhlcyBjcm9zcy1icm93c2VyIGRpZmZlcmVuY2VzIGluIHJlcGxhY2VtZW50IHRleHQgc3ludGF4IHdoZW4gcGVyZm9ybWluZyBhIHJlcGxhY2VtZW50CiAgICAvLyB1c2luZyBhIG5vbnJlZ2V4IHNlYXJjaCB2YWx1ZSwgYW5kIHRoZSB2YWx1ZSBvZiByZXBsYWNlbWVudCByZWdleGVzJyBgbGFzdEluZGV4YCBwcm9wZXJ0eQogICAgLy8gZHVyaW5nIHJlcGxhY2VtZW50IGl0ZXJhdGlvbnMuIE5vdGUgdGhhdCB0aGlzIGRvZXNuJ3Qgc3VwcG9ydCBTcGlkZXJNb25rZXkncyBwcm9wcmlldGFyeQogICAgLy8gdGhpcmQgKGBmbGFnc2ApIHBhcmFtZXRlcgogICAgU3RyaW5nLnByb3RvdHlwZS5yZXBsYWNlID0gZnVuY3Rpb24gKHNlYXJjaCwgcmVwbGFjZW1lbnQpIHsKICAgICAgICB2YXIgaXNSZWdleCA9IFhSZWdFeHAuaXNSZWdFeHAoc2VhcmNoKSwKICAgICAgICAgICAgY2FwdHVyZU5hbWVzLCByZXN1bHQsIHN0ciwgb3JpZ0xhc3RJbmRleDsKCiAgICAgICAgLy8gVGhlcmUgYXJlIHRvbyBtYW55IGNvbWJpbmF0aW9ucyBvZiBzZWFyY2gvcmVwbGFjZW1lbnQgdHlwZXMvdmFsdWVzIGFuZCBicm93c2VyIGJ1Z3MgdGhhdAogICAgICAgIC8vIHByZWNsdWRlIHBhc3NpbmcgdG8gbmF0aXZlIGByZXBsYWNlYCwgc28gZG9uJ3QgdHJ5CiAgICAgICAgLy9pZiAoLi4uKQogICAgICAgIC8vICAgIHJldHVybiBuYXRpdi5yZXBsYWNlLmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7CgogICAgICAgIGlmIChpc1JlZ2V4KSB7CiAgICAgICAgICAgIGlmIChzZWFyY2guX3hyZWdleHApCiAgICAgICAgICAgICAgICBjYXB0dXJlTmFtZXMgPSBzZWFyY2guX3hyZWdleHAuY2FwdHVyZU5hbWVzOyAvLyBBcnJheSBvciBgbnVsbGAKICAgICAgICAgICAgaWYgKCFzZWFyY2guZ2xvYmFsKQogICAgICAgICAgICAgICAgb3JpZ0xhc3RJbmRleCA9IHNlYXJjaC5sYXN0SW5kZXg7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgc2VhcmNoID0gc2VhcmNoICsgIiI7IC8vIFR5cGUgY29udmVyc2lvbgogICAgICAgIH0KCiAgICAgICAgaWYgKE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChyZXBsYWNlbWVudCkgPT09ICJbb2JqZWN0IEZ1bmN0aW9uXSIpIHsKICAgICAgICAgICAgcmVzdWx0ID0gbmF0aXYucmVwbGFjZS5jYWxsKHRoaXMgKyAiIiwgc2VhcmNoLCBmdW5jdGlvbiAoKSB7CiAgICAgICAgICAgICAgICBpZiAoY2FwdHVyZU5hbWVzKSB7CiAgICAgICAgICAgICAgICAgICAgLy8gQ2hhbmdlIHRoZSBgYXJndW1lbnRzWzBdYCBzdHJpbmcgcHJpbWl0aXZlIHRvIGEgU3RyaW5nIG9iamVjdCB3aGljaCBjYW4gc3RvcmUgcHJvcGVydGllcwogICAgICAgICAgICAgICAgICAgIGFyZ3VtZW50c1swXSA9IG5ldyBTdHJpbmcoYXJndW1lbnRzWzBdKTsKICAgICAgICAgICAgICAgICAgICAvLyBTdG9yZSBuYW1lZCBiYWNrcmVmZXJlbmNlcyBvbiBgYXJndW1lbnRzWzBdYAogICAgICAgICAgICAgICAgICAgIGZvciAodmFyIGkgPSAwOyBpIDwgY2FwdHVyZU5hbWVzLmxlbmd0aDsgaSsrKSB7CiAgICAgICAgICAgICAgICAgICAgICAgIGlmIChjYXB0dXJlTmFtZXNbaV0pCiAgICAgICAgICAgICAgICAgICAgICAgICAgICBhcmd1bWVudHNbMF1bY2FwdHVyZU5hbWVzW2ldXSA9IGFyZ3VtZW50c1tpICsgMV07CiAgICAgICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgLy8gVXBkYXRlIGBsYXN0SW5kZXhgIGJlZm9yZSBjYWxsaW5nIGByZXBsYWNlbWVudGAgKGZpeCBicm93c2VycykKICAgICAgICAgICAgICAgIGlmIChpc1JlZ2V4ICYmIHNlYXJjaC5nbG9iYWwpCiAgICAgICAgICAgICAgICAgICAgc2VhcmNoLmxhc3RJbmRleCA9IGFyZ3VtZW50c1thcmd1bWVudHMubGVuZ3RoIC0gMl0gKyBhcmd1bWVudHNbMF0ubGVuZ3RoOwogICAgICAgICAgICAgICAgcmV0dXJuIHJlcGxhY2VtZW50LmFwcGx5KG51bGwsIGFyZ3VtZW50cyk7CiAgICAgICAgICAgIH0pOwogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAgIHN0ciA9IHRoaXMgKyAiIjsgLy8gVHlwZSBjb252ZXJzaW9uLCBzbyBgYXJnc1thcmdzLmxlbmd0aCAtIDFdYCB3aWxsIGJlIGEgc3RyaW5nIChnaXZlbiBub25zdHJpbmcgYHRoaXNgKQogICAgICAgICAgICByZXN1bHQgPSBuYXRpdi5yZXBsYWNlLmNhbGwoc3RyLCBzZWFyY2gsIGZ1bmN0aW9uICgpIHsKICAgICAgICAgICAgICAgIHZhciBhcmdzID0gYXJndW1lbnRzOyAvLyBLZWVwIHRoaXMgZnVuY3Rpb24ncyBgYXJndW1lbnRzYCBhdmFpbGFibGUgdGhyb3VnaCBjbG9zdXJlCiAgICAgICAgICAgICAgICByZXR1cm4gbmF0aXYucmVwbGFjZS5jYWxsKHJlcGxhY2VtZW50ICsgIiIsIHJlcGxhY2VtZW50VG9rZW4sIGZ1bmN0aW9uICgkMCwgJDEsICQyKSB7CiAgICAgICAgICAgICAgICAgICAgLy8gTnVtYmVyZWQgYmFja3JlZmVyZW5jZSAod2l0aG91dCBkZWxpbWl0ZXJzKSBvciBzcGVjaWFsIHZhcmlhYmxlCiAgICAgICAgICAgICAgICAgICAgaWYgKCQxKSB7CiAgICAgICAgICAgICAgICAgICAgICAgIHN3aXRjaCAoJDEpIHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNhc2UgIiQiOiByZXR1cm4gIiQiOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgY2FzZSAiJiI6IHJldHVybiBhcmdzWzBdOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgY2FzZSAiYCI6IHJldHVybiBhcmdzW2FyZ3MubGVuZ3RoIC0gMV0uc2xpY2UoMCwgYXJnc1thcmdzLmxlbmd0aCAtIDJdKTsKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNhc2UgIiciOiByZXR1cm4gYXJnc1thcmdzLmxlbmd0aCAtIDFdLnNsaWNlKGFyZ3NbYXJncy5sZW5ndGggLSAyXSArIGFyZ3NbMF0ubGVuZ3RoKTsKICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8vIE51bWJlcmVkIGJhY2tyZWZlcmVuY2UKICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRlZmF1bHQ6CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLy8gV2hhdCBkb2VzICIkMTAiIG1lYW4/CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLy8gLSBCYWNrcmVmZXJlbmNlIDEwLCBpZiAxMCBvciBtb3JlIGNhcHR1cmluZyBncm91cHMgZXhpc3QKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvLyAtIEJhY2tyZWZlcmVuY2UgMSBmb2xsb3dlZCBieSAiMCIsIGlmIDEtOSBjYXB0dXJpbmcgZ3JvdXBzIGV4aXN0CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLy8gLSBPdGhlcndpc2UsIGl0J3MgdGhlIHN0cmluZyAiJDEwIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8vIEFsc28gbm90ZToKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvLyAtIEJhY2tyZWZlcmVuY2VzIGNhbm5vdCBiZSBtb3JlIHRoYW4gdHdvIGRpZ2l0cyAoZW5mb3JjZWQgYnkgYHJlcGxhY2VtZW50VG9rZW5gKQogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8vIC0gIiQwMSIgaXMgZXF1aXZhbGVudCB0byAiJDEiIGlmIGEgY2FwdHVyaW5nIGdyb3VwIGV4aXN0cywgb3RoZXJ3aXNlIGl0J3MgdGhlIHN0cmluZyAiJDAxIgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8vIC0gVGhlcmUgaXMgbm8gIiQwIiB0b2tlbiAoIiQmIiBpcyB0aGUgZW50aXJlIG1hdGNoKQogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZhciBsaXRlcmFsTnVtYmVycyA9ICIiOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICQxID0gKyQxOyAvLyBUeXBlIGNvbnZlcnNpb247IGRyb3AgbGVhZGluZyB6ZXJvCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKCEkMSkgLy8gYCQxYCB3YXMgIjAiIG9yICIwMCIKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuICQwOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHdoaWxlICgkMSA%2BIGFyZ3MubGVuZ3RoIC0gMykgewogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsaXRlcmFsTnVtYmVycyA9IFN0cmluZy5wcm90b3R5cGUuc2xpY2UuY2FsbCgkMSwgLTEpICsgbGl0ZXJhbE51bWJlcnM7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICQxID0gTWF0aC5mbG9vcigkMSAvIDEwKTsgLy8gRHJvcCB0aGUgbGFzdCBkaWdpdAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gKCQxID8gYXJnc1skMV0gfHwgIiIgOiAiJCIpICsgbGl0ZXJhbE51bWJlcnM7CiAgICAgICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICAvLyBOYW1lZCBiYWNrcmVmZXJlbmNlIG9yIGRlbGltaXRlZCBudW1iZXJlZCBiYWNrcmVmZXJlbmNlCiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgICAgICAgICAgICAgLy8gV2hhdCBkb2VzICIke259IiBtZWFuPwogICAgICAgICAgICAgICAgICAgICAgICAvLyAtIEJhY2tyZWZlcmVuY2UgdG8gbnVtYmVyZWQgY2FwdHVyZSBuLiBUd28gZGlmZmVyZW5jZXMgZnJvbSAiJG4iOgogICAgICAgICAgICAgICAgICAgICAgICAvLyAgIC0gbiBjYW4gYmUgbW9yZSB0aGFuIHR3byBkaWdpdHMKICAgICAgICAgICAgICAgICAgICAgICAgLy8gICAtIEJhY2tyZWZlcmVuY2UgMCBpcyBhbGxvd2VkLCBhbmQgaXMgdGhlIGVudGlyZSBtYXRjaAogICAgICAgICAgICAgICAgICAgICAgICAvLyAtIEJhY2tyZWZlcmVuY2UgdG8gbmFtZWQgY2FwdHVyZSBuLCBpZiBpdCBleGlzdHMgYW5kIGlzIG5vdCBhIG51bWJlciBvdmVycmlkZGVuIGJ5IG51bWJlcmVkIGNhcHR1cmUKICAgICAgICAgICAgICAgICAgICAgICAgLy8gLSBPdGhlcndpc2UsIGl0J3MgdGhlIHN0cmluZyAiJHtufSIKICAgICAgICAgICAgICAgICAgICAgICAgdmFyIG4gPSArJDI7IC8vIFR5cGUgY29udmVyc2lvbjsgZHJvcCBsZWFkaW5nIHplcm9zCiAgICAgICAgICAgICAgICAgICAgICAgIGlmIChuIDw9IGFyZ3MubGVuZ3RoIC0gMykKICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBhcmdzW25dOwogICAgICAgICAgICAgICAgICAgICAgICBuID0gY2FwdHVyZU5hbWVzID8gaW5kZXhPZihjYXB0dXJlTmFtZXMsICQyKSA6IC0xOwogICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gbiA%2BIC0xID8gYXJnc1tuICsgMV0gOiAkMDsKICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICB9KTsKICAgICAgICAgICAgfSk7CiAgICAgICAgfQoKICAgICAgICBpZiAoaXNSZWdleCkgewogICAgICAgICAgICBpZiAoc2VhcmNoLmdsb2JhbCkKICAgICAgICAgICAgICAgIHNlYXJjaC5sYXN0SW5kZXggPSAwOyAvLyBGaXggSUUsIFNhZmFyaSBidWcgKGxhc3QgdGVzdGVkIElFIDkuMC41LCBTYWZhcmkgNS4xLjIgb24gV2luZG93cykKICAgICAgICAgICAgZWxzZQogICAgICAgICAgICAgICAgc2VhcmNoLmxhc3RJbmRleCA9IG9yaWdMYXN0SW5kZXg7IC8vIEZpeCBJRSwgT3BlcmEgYnVnIChsYXN0IHRlc3RlZCBJRSA5LjAuNSwgT3BlcmEgMTEuNjEgb24gV2luZG93cykKICAgICAgICB9CgogICAgICAgIHJldHVybiByZXN1bHQ7CiAgICB9OwoKICAgIC8vIEEgY29uc2lzdGVudCBjcm9zcy1icm93c2VyLCBFUzMgY29tcGxpYW50IGBzcGxpdGAKICAgIFN0cmluZy5wcm90b3R5cGUuc3BsaXQgPSBmdW5jdGlvbiAocyAvKiBzZXBhcmF0b3IgKi8sIGxpbWl0KSB7CiAgICAgICAgLy8gSWYgc2VwYXJhdG9yIGBzYCBpcyBub3QgYSByZWdleCwgdXNlIHRoZSBuYXRpdmUgYHNwbGl0YAogICAgICAgIGlmICghWFJlZ0V4cC5pc1JlZ0V4cChzKSkKICAgICAgICAgICAgcmV0dXJuIG5hdGl2LnNwbGl0LmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7CgogICAgICAgIHZhciBzdHIgPSB0aGlzICsgIiIsIC8vIFR5cGUgY29udmVyc2lvbgogICAgICAgICAgICBvdXRwdXQgPSBbXSwKICAgICAgICAgICAgbGFzdExhc3RJbmRleCA9IDAsCiAgICAgICAgICAgIG1hdGNoLCBsYXN0TGVuZ3RoOwoKICAgICAgICAvLyBCZWhhdmlvciBmb3IgYGxpbWl0YDogaWYgaXQncy4uLgogICAgICAgIC8vIC0gYHVuZGVmaW5lZGA6IE5vIGxpbWl0CiAgICAgICAgLy8gLSBgTmFOYCBvciB6ZXJvOiBSZXR1cm4gYW4gZW1wdHkgYXJyYXkKICAgICAgICAvLyAtIEEgcG9zaXRpdmUgbnVtYmVyOiBVc2UgYE1hdGguZmxvb3IobGltaXQpYAogICAgICAgIC8vIC0gQSBuZWdhdGl2ZSBudW1iZXI6IE5vIGxpbWl0CiAgICAgICAgLy8gLSBPdGhlcjogVHlwZS1jb252ZXJ0LCB0aGVuIHVzZSB0aGUgYWJvdmUgcnVsZXMKICAgICAgICBpZiAobGltaXQgPT09IHVuZGVmaW5lZCB8fCArbGltaXQgPCAwKSB7CiAgICAgICAgICAgIGxpbWl0ID0gSW5maW5pdHk7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgbGltaXQgPSBNYXRoLmZsb29yKCtsaW1pdCk7CiAgICAgICAgICAgIGlmICghbGltaXQpCiAgICAgICAgICAgICAgICByZXR1cm4gW107CiAgICAgICAgfQoKICAgICAgICAvLyBUaGlzIGlzIHJlcXVpcmVkIGlmIG5vdCBgcy5nbG9iYWxgLCBhbmQgaXQgYXZvaWRzIG5lZWRpbmcgdG8gc2V0IGBzLmxhc3RJbmRleGAgdG8gemVybwogICAgICAgIC8vIGFuZCByZXN0b3JlIGl0IHRvIGl0cyBvcmlnaW5hbCB2YWx1ZSB3aGVuIHdlJ3JlIGRvbmUgdXNpbmcgdGhlIHJlZ2V4CiAgICAgICAgcyA9IFhSZWdFeHAuY29weUFzR2xvYmFsKHMpOwoKICAgICAgICB3aGlsZSAobWF0Y2ggPSBzLmV4ZWMoc3RyKSkgeyAvLyBSdW4gdGhlIGFsdGVyZWQgYGV4ZWNgIChyZXF1aXJlZCBmb3IgYGxhc3RJbmRleGAgZml4LCBldGMuKQogICAgICAgICAgICBpZiAocy5sYXN0SW5kZXggPiBsYXN0TGFzdEluZGV4KSB7CiAgICAgICAgICAgICAgICBvdXRwdXQucHVzaChzdHIuc2xpY2UobGFzdExhc3RJbmRleCwgbWF0Y2guaW5kZXgpKTsKCiAgICAgICAgICAgICAgICBpZiAobWF0Y2gubGVuZ3RoID4gMSAmJiBtYXRjaC5pbmRleCA8IHN0ci5sZW5ndGgpCiAgICAgICAgICAgICAgICAgICAgQXJyYXkucHJvdG90eXBlLnB1c2guYXBwbHkob3V0cHV0LCBtYXRjaC5zbGljZSgxKSk7CgogICAgICAgICAgICAgICAgbGFzdExlbmd0aCA9IG1hdGNoWzBdLmxlbmd0aDsKICAgICAgICAgICAgICAgIGxhc3RMYXN0SW5kZXggPSBzLmxhc3RJbmRleDsKCiAgICAgICAgICAgICAgICBpZiAob3V0cHV0Lmxlbmd0aCA%2BPSBsaW1pdCkKICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICAgfQoKICAgICAgICAgICAgaWYgKHMubGFzdEluZGV4ID09PSBtYXRjaC5pbmRleCkKICAgICAgICAgICAgICAgIHMubGFzdEluZGV4Kys7CiAgICAgICAgfQoKICAgICAgICBpZiAobGFzdExhc3RJbmRleCA9PT0gc3RyLmxlbmd0aCkgewogICAgICAgICAgICBpZiAoIW5hdGl2LnRlc3QuY2FsbChzLCAiIikgfHwgbGFzdExlbmd0aCkKICAgICAgICAgICAgICAgIG91dHB1dC5wdXNoKCIiKTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgICBvdXRwdXQucHVzaChzdHIuc2xpY2UobGFzdExhc3RJbmRleCkpOwogICAgICAgIH0KCiAgICAgICAgcmV0dXJuIG91dHB1dC5sZW5ndGggPiBsaW1pdCA/IG91dHB1dC5zbGljZSgwLCBsaW1pdCkgOiBvdXRwdXQ7CiAgICB9OwoKCiAgICAvLy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gIFByaXZhdGUgaGVscGVyIGZ1bmN0aW9ucwogICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiAgICAvLyBTdXBwb3J0aW5nIGZ1bmN0aW9uIGZvciBgWFJlZ0V4cGAsIGBYUmVnRXhwLmNvcHlBc0dsb2JhbGAsIGV0Yy4gUmV0dXJucyBhIGNvcHkgb2YgYSBgUmVnRXhwYAogICAgLy8gaW5zdGFuY2Ugd2l0aCBhIGZyZXNoIGBsYXN0SW5kZXhgIChzZXQgdG8gemVybyksIHByZXNlcnZpbmcgcHJvcGVydGllcyByZXF1aXJlZCBmb3IgbmFtZWQKICAgIC8vIGNhcHR1cmUuIEFsc28gYWxsb3dzIGFkZGluZyBuZXcgZmxhZ3MgaW4gdGhlIHByb2Nlc3Mgb2YgY29weWluZyB0aGUgcmVnZXgKICAgIGZ1bmN0aW9uIGNsb25lIChyZWdleCwgYWRkaXRpb25hbEZsYWdzKSB7CiAgICAgICAgaWYgKCFYUmVnRXhwLmlzUmVnRXhwKHJlZ2V4KSkKICAgICAgICAgICAgdGhyb3cgVHlwZUVycm9yKCJ0eXBlIFJlZ0V4cCBleHBlY3RlZCIpOwogICAgICAgIHZhciB4ID0gcmVnZXguX3hyZWdleHA7CiAgICAgICAgcmVnZXggPSBYUmVnRXhwKHJlZ2V4LnNvdXJjZSwgZ2V0TmF0aXZlRmxhZ3MocmVnZXgpICsgKGFkZGl0aW9uYWxGbGFncyB8fCAiIikpOwogICAgICAgIGlmICh4KSB7CiAgICAgICAgICAgIHJlZ2V4Ll94cmVnZXhwID0gewogICAgICAgICAgICAgICAgc291cmNlOiB4LnNvdXJjZSwKICAgICAgICAgICAgICAgIGNhcHR1cmVOYW1lczogeC5jYXB0dXJlTmFtZXMgPyB4LmNhcHR1cmVOYW1lcy5zbGljZSgwKSA6IG51bGwKICAgICAgICAgICAgfTsKICAgICAgICB9CiAgICAgICAgcmV0dXJuIHJlZ2V4OwogICAgfQoKICAgIGZ1bmN0aW9uIGdldE5hdGl2ZUZsYWdzIChyZWdleCkgewogICAgICAgIHJldHVybiAocmVnZXguZ2xvYmFsICAgICA/ICJnIiA6ICIiKSArCiAgICAgICAgICAgICAgIChyZWdleC5pZ25vcmVDYXNlID8gImkiIDogIiIpICsKICAgICAgICAgICAgICAgKHJlZ2V4Lm11bHRpbGluZSAgPyAibSIgOiAiIikgKwogICAgICAgICAgICAgICAocmVnZXguZXh0ZW5kZWQgICA/ICJ4IiA6ICIiKSArIC8vIFByb3Bvc2VkIGZvciBFUzQ7IGluY2x1ZGVkIGluIEFTMwogICAgICAgICAgICAgICAocmVnZXguc3RpY2t5ICAgICA/ICJ5IiA6ICIiKTsKICAgIH0KCiAgICBmdW5jdGlvbiBydW5Ub2tlbnMgKHBhdHRlcm4sIGluZGV4LCBzY29wZSwgY29udGV4dCkgewogICAgICAgIHZhciBpID0gdG9rZW5zLmxlbmd0aCwKICAgICAgICAgICAgcmVzdWx0LCBtYXRjaCwgdDsKICAgICAgICAvLyBQcm90ZWN0IGFnYWluc3QgY29uc3RydWN0aW5nIFhSZWdFeHBzIHdpdGhpbiB0b2tlbiBoYW5kbGVyIGFuZCB0cmlnZ2VyIGZ1bmN0aW9ucwogICAgICAgIGlzSW5zaWRlQ29uc3RydWN0b3IgPSB0cnVlOwogICAgICAgIC8vIE11c3QgcmVzZXQgYGlzSW5zaWRlQ29uc3RydWN0b3JgLCBldmVuIGlmIGEgYHRyaWdnZXJgIG9yIGBoYW5kbGVyYCB0aHJvd3MKICAgICAgICB0cnkgewogICAgICAgICAgICB3aGlsZSAoaS0tKSB7IC8vIFJ1biBpbiByZXZlcnNlIG9yZGVyCiAgICAgICAgICAgICAgICB0ID0gdG9rZW5zW2ldOwogICAgICAgICAgICAgICAgaWYgKChzY29wZSAmIHQuc2NvcGUpICYmICghdC50cmlnZ2VyIHx8IHQudHJpZ2dlci5jYWxsKGNvbnRleHQpKSkgewogICAgICAgICAgICAgICAgICAgIHQucGF0dGVybi5sYXN0SW5kZXggPSBpbmRleDsKICAgICAgICAgICAgICAgICAgICBtYXRjaCA9IHQucGF0dGVybi5leGVjKHBhdHRlcm4pOyAvLyBSdW5uaW5nIHRoZSBhbHRlcmVkIGBleGVjYCBoZXJlIGFsbG93cyB1c2Ugb2YgbmFtZWQgYmFja3JlZmVyZW5jZXMsIGV0Yy4KICAgICAgICAgICAgICAgICAgICBpZiAobWF0Y2ggJiYgbWF0Y2guaW5kZXggPT09IGluZGV4KSB7CiAgICAgICAgICAgICAgICAgICAgICAgIHJlc3VsdCA9IHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgIG91dHB1dDogdC5oYW5kbGVyLmNhbGwoY29udGV4dCwgbWF0Y2gsIHNjb3BlKSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1hdGNoOiBtYXRjaAogICAgICAgICAgICAgICAgICAgICAgICB9OwogICAgICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0KICAgICAgICB9IGNhdGNoIChlcnIpIHsKICAgICAgICAgICAgdGhyb3cgZXJyOwogICAgICAgIH0gZmluYWxseSB7CiAgICAgICAgICAgIGlzSW5zaWRlQ29uc3RydWN0b3IgPSBmYWxzZTsKICAgICAgICB9CiAgICAgICAgcmV0dXJuIHJlc3VsdDsKICAgIH0KCiAgICBmdW5jdGlvbiBpbmRleE9mIChhcnJheSwgaXRlbSwgZnJvbSkgewogICAgICAgIGlmIChBcnJheS5wcm90b3R5cGUuaW5kZXhPZikgLy8gVXNlIHRoZSBuYXRpdmUgYXJyYXkgbWV0aG9kIGlmIGF2YWlsYWJsZQogICAgICAgICAgICByZXR1cm4gYXJyYXkuaW5kZXhPZihpdGVtLCBmcm9tKTsKICAgICAgICBmb3IgKHZhciBpID0gZnJvbSB8fCAwOyBpIDwgYXJyYXkubGVuZ3RoOyBpKyspIHsKICAgICAgICAgICAgaWYgKGFycmF5W2ldID09PSBpdGVtKQogICAgICAgICAgICAgICAgcmV0dXJuIGk7CiAgICAgICAgfQogICAgICAgIHJldHVybiAtMTsKICAgIH0KCgogICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vICBCdWlsdC1pbiB0b2tlbnMKICAgIC8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgogICAgLy8gQXVnbWVudCBYUmVnRXhwJ3MgcmVndWxhciBleHByZXNzaW9uIHN5bnRheCBhbmQgZmxhZ3MuIE5vdGUgdGhhdCB3aGVuIGFkZGluZyB0b2tlbnMsIHRoZQogICAgLy8gdGhpcmQgKGBzY29wZWApIGFyZ3VtZW50IGRlZmF1bHRzIHRvIGBYUmVnRXhwLk9VVFNJREVfQ0xBU1NgCgogICAgLy8gQ29tbWVudCBwYXR0ZXJuOiAoPyMgKQogICAgWFJlZ0V4cC5hZGRUb2tlbigKICAgICAgICAvXChcPyNbXildKlwpLywKICAgICAgICBmdW5jdGlvbiAobWF0Y2gpIHsKICAgICAgICAgICAgLy8gS2VlcCB0b2tlbnMgc2VwYXJhdGVkIHVubGVzcyB0aGUgZm9sbG93aW5nIHRva2VuIGlzIGEgcXVhbnRpZmllcgogICAgICAgICAgICByZXR1cm4gbmF0aXYudGVzdC5jYWxsKHF1YW50aWZpZXIsIG1hdGNoLmlucHV0LnNsaWNlKG1hdGNoLmluZGV4ICsgbWF0Y2hbMF0ubGVuZ3RoKSkgPyAiIiA6ICIoPzopIjsKICAgICAgICB9CiAgICApOwoKICAgIC8vIENhcHR1cmluZyBncm91cCAobWF0Y2ggdGhlIG9wZW5pbmcgcGFyZW50aGVzaXMgb25seSkuCiAgICAvLyBSZXF1aXJlZCBmb3Igc3VwcG9ydCBvZiBuYW1lZCBjYXB0dXJpbmcgZ3JvdXBzCiAgICBYUmVnRXhwLmFkZFRva2VuKAogICAgICAgIC9cKCg/IVw/KS8sCiAgICAgICAgZnVuY3Rpb24gKCkgewogICAgICAgICAgICB0aGlzLmNhcHR1cmVOYW1lcy5wdXNoKG51bGwpOwogICAgICAgICAgICByZXR1cm4gIigiOwogICAgICAgIH0KICAgICk7CgogICAgLy8gTmFtZWQgY2FwdHVyaW5nIGdyb3VwIChtYXRjaCB0aGUgb3BlbmluZyBkZWxpbWl0ZXIgb25seSk6ICg/PG5hbWU%2BCiAgICBYUmVnRXhwLmFkZFRva2VuKAogICAgICAgIC9cKFw/PChbJFx3XSspPi8sCiAgICAgICAgZnVuY3Rpb24gKG1hdGNoKSB7CiAgICAgICAgICAgIHRoaXMuY2FwdHVyZU5hbWVzLnB1c2gobWF0Y2hbMV0pOwogICAgICAgICAgICB0aGlzLmhhc05hbWVkQ2FwdHVyZSA9IHRydWU7CiAgICAgICAgICAgIHJldHVybiAiKCI7CiAgICAgICAgfQogICAgKTsKCiAgICAvLyBOYW1lZCBiYWNrcmVmZXJlbmNlOiBcazxuYW1lPgogICAgWFJlZ0V4cC5hZGRUb2tlbigKICAgICAgICAvXFxrPChbXHckXSspPi8sCiAgICAgICAgZnVuY3Rpb24gKG1hdGNoKSB7CiAgICAgICAgICAgIHZhciBpbmRleCA9IGluZGV4T2YodGhpcy5jYXB0dXJlTmFtZXMsIG1hdGNoWzFdKTsKICAgICAgICAgICAgLy8gS2VlcCBiYWNrcmVmZXJlbmNlcyBzZXBhcmF0ZSBmcm9tIHN1YnNlcXVlbnQgbGl0ZXJhbCBudW1iZXJzLiBQcmVzZXJ2ZSBiYWNrLQogICAgICAgICAgICAvLyByZWZlcmVuY2VzIHRvIG5hbWVkIGdyb3VwcyB0aGF0IGFyZSB1bmRlZmluZWQgYXQgdGhpcyBwb2ludCBhcyBsaXRlcmFsIHN0cmluZ3MKICAgICAgICAgICAgcmV0dXJuIGluZGV4ID4gLTEgPwogICAgICAgICAgICAgICAgIlxcIiArIChpbmRleCArIDEpICsgKGlzTmFOKG1hdGNoLmlucHV0LmNoYXJBdChtYXRjaC5pbmRleCArIG1hdGNoWzBdLmxlbmd0aCkpID8gIiIgOiAiKD86KSIpIDoKICAgICAgICAgICAgICAgIG1hdGNoWzBdOwogICAgICAgIH0KICAgICk7CgogICAgLy8gRW1wdHkgY2hhcmFjdGVyIGNsYXNzOiBbXSBvciBbXl0KICAgIFhSZWdFeHAuYWRkVG9rZW4oCiAgICAgICAgL1xbXF4/XS8sCiAgICAgICAgZnVuY3Rpb24gKG1hdGNoKSB7CiAgICAgICAgICAgIC8vIEZvciBjcm9zcy1icm93c2VyIGNvbXBhdGliaWxpdHkgd2l0aCBFUzMsIGNvbnZlcnQgW10gdG8gXGJcQiBhbmQgW15dIHRvIFtcc1xTXS4KICAgICAgICAgICAgLy8gKD8hKSBzaG91bGQgd29yayBsaWtlIFxiXEIsIGJ1dCBpcyB1bnJlbGlhYmxlIGluIEZpcmVmb3gKICAgICAgICAgICAgcmV0dXJuIG1hdGNoWzBdID09PSAiW10iID8gIlxcYlxcQiIgOiAiW1xcc1xcU10iOwogICAgICAgIH0KICAgICk7CgogICAgLy8gTW9kZSBtb2RpZmllciBhdCB0aGUgc3RhcnQgb2YgdGhlIHBhdHRlcm4gb25seSwgd2l0aCBhbnkgY29tYmluYXRpb24gb2YgZmxhZ3MgaW1zeDogKD9pbXN4KQogICAgLy8gRG9lcyBub3Qgc3VwcG9ydCB4KD9pKSwgKD8taSksICg/aS1tKSwgKD9pOiApLCAoP2kpKD9tKSwgZXRjLgogICAgWFJlZ0V4cC5hZGRUb2tlbigKICAgICAgICAvXlwoXD8oW2ltc3hdKylcKS8sCiAgICAgICAgZnVuY3Rpb24gKG1hdGNoKSB7CiAgICAgICAgICAgIHRoaXMuc2V0RmxhZyhtYXRjaFsxXSk7CiAgICAgICAgICAgIHJldHVybiAiIjsKICAgICAgICB9CiAgICApOwoKICAgIC8vIFdoaXRlc3BhY2UgYW5kIGNvbW1lbnRzLCBpbiBmcmVlLXNwYWNpbmcgKGFrYSBleHRlbmRlZCkgbW9kZSBvbmx5CiAgICBYUmVnRXhwLmFkZFRva2VuKAogICAgICAgIC8oPzpccyt8Iy4qKSsvLAogICAgICAgIGZ1bmN0aW9uIChtYXRjaCkgewogICAgICAgICAgICAvLyBLZWVwIHRva2VucyBzZXBhcmF0ZWQgdW5sZXNzIHRoZSBmb2xsb3dpbmcgdG9rZW4gaXMgYSBxdWFudGlmaWVyCiAgICAgICAgICAgIHJldHVybiBuYXRpdi50ZXN0LmNhbGwocXVhbnRpZmllciwgbWF0Y2guaW5wdXQuc2xpY2UobWF0Y2guaW5kZXggKyBtYXRjaFswXS5sZW5ndGgpKSA/ICIiIDogIig/OikiOwogICAgICAgIH0sCiAgICAgICAgWFJlZ0V4cC5PVVRTSURFX0NMQVNTLAogICAgICAgIGZ1bmN0aW9uICgpIHtyZXR1cm4gdGhpcy5oYXNGbGFnKCJ4Iik7fQogICAgKTsKCiAgICAvLyBEb3QsIGluIGRvdGFsbCAoYWthIHNpbmdsZWxpbmUpIG1vZGUgb25seQogICAgWFJlZ0V4cC5hZGRUb2tlbigKICAgICAgICAvXC4vLAogICAgICAgIGZ1bmN0aW9uICgpIHtyZXR1cm4gIltcXHNcXFNdIjt9LAogICAgICAgIFhSZWdFeHAuT1VUU0lERV9DTEFTUywKICAgICAgICBmdW5jdGlvbiAoKSB7cmV0dXJuIHRoaXMuaGFzRmxhZygicyIpO30KICAgICk7CgoKICAgIC8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyAgQmFja3dhcmQgY29tcGF0aWJpbGl0eQogICAgLy8tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiAgICAvLyBVbmNvbW1lbnQgdGhlIGZvbGxvd2luZyBibG9jayBmb3IgY29tcGF0aWJpbGl0eSB3aXRoIFhSZWdFeHAgMS4wLTEuMjoKICAgIC8qCiAgICBYUmVnRXhwLm1hdGNoV2l0aGluQ2hhaW4gPSBYUmVnRXhwLm1hdGNoQ2hhaW47CiAgICBSZWdFeHAucHJvdG90eXBlLmFkZEZsYWdzID0gZnVuY3Rpb24gKHMpIHtyZXR1cm4gY2xvbmUodGhpcywgcyk7fTsKICAgIFJlZ0V4cC5wcm90b3R5cGUuZXhlY0FsbCA9IGZ1bmN0aW9uIChzKSB7dmFyIHIgPSBbXTsgWFJlZ0V4cC5pdGVyYXRlKHMsIHRoaXMsIGZ1bmN0aW9uIChtKSB7ci5wdXNoKG0pO30pOyByZXR1cm4gcjt9OwogICAgUmVnRXhwLnByb3RvdHlwZS5mb3JFYWNoRXhlYyA9IGZ1bmN0aW9uIChzLCBmLCBjKSB7cmV0dXJuIFhSZWdFeHAuaXRlcmF0ZShzLCB0aGlzLCBmLCBjKTt9OwogICAgUmVnRXhwLnByb3RvdHlwZS52YWxpZGF0ZSA9IGZ1bmN0aW9uIChzKSB7dmFyIHIgPSBSZWdFeHAoIl4oPzoiICsgdGhpcy5zb3VyY2UgKyAiKSQoPyFcXHMpIiwgZ2V0TmF0aXZlRmxhZ3ModGhpcykpOyBpZiAodGhpcy5nbG9iYWwpIHRoaXMubGFzdEluZGV4ID0gMDsgcmV0dXJuIHMuc2VhcmNoKHIpID09PSAwO307CiAgICAqLwoKfSkoKTsKCg%3D%3D"></script> <script type="text/javascript" src="data:application/javascript;base64,LyoqCiAqIFN5bnRheEhpZ2hsaWdodGVyCiAqIGh0dHA6Ly9hbGV4Z29yYmF0Y2hldi5jb20vU3ludGF4SGlnaGxpZ2h0ZXIKICoKICogU3ludGF4SGlnaGxpZ2h0ZXIgaXMgZG9uYXRpb253YXJlLiBJZiB5b3UgYXJlIHVzaW5nIGl0LCBwbGVhc2UgZG9uYXRlLgogKiBodHRwOi8vYWxleGdvcmJhdGNoZXYuY29tL1N5bnRheEhpZ2hsaWdodGVyL2RvbmF0ZS5odG1sCiAqCiAqIEB2ZXJzaW9uCiAqIEBWRVJTSU9OQCAoQERBVEVAKQogKiAKICogQGNvcHlyaWdodAogKiBDb3B5cmlnaHQgKEMpIDIwMDQtMjAxMCBBbGV4IEdvcmJhdGNoZXYuCiAqCiAqIEBsaWNlbnNlCiAqIER1YWwgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBhbmQgR1BMIGxpY2Vuc2VzLgogKi8KCi8vCi8vIEJlZ2luIGFub255bW91cyBmdW5jdGlvbi4gVGhpcyBpcyB1c2VkIHRvIGNvbnRhaW4gbG9jYWwgc2NvcGUgdmFyaWFibGVzIHdpdGhvdXQgcG9sdXR0aW5nIGdsb2JhbCBzY29wZS4KLy8KaWYgKHR5cGVvZihTeW50YXhIaWdobGlnaHRlcikgPT0gJ3VuZGVmaW5lZCcpIHZhciBTeW50YXhIaWdobGlnaHRlciA9IGZ1bmN0aW9uKCkgeyAKCi8vIENvbW1vbkpTCmlmICh0eXBlb2YocmVxdWlyZSkgIT0gJ3VuZGVmaW5lZCcgJiYgdHlwZW9mKFhSZWdFeHApID09ICd1bmRlZmluZWQnKQp7CglYUmVnRXhwID0gcmVxdWlyZSgnWFJlZ0V4cCcpLlhSZWdFeHA7Cn0KCi8vIFNob3J0Y3V0IG9iamVjdCB3aGljaCB3aWxsIGJlIGFzc2lnbmVkIHRvIHRoZSBTeW50YXhIaWdobGlnaHRlciB2YXJpYWJsZS4KLy8gVGhpcyBpcyBhIHNob3J0aGFuZCBmb3IgbG9jYWwgcmVmZXJlbmNlIGluIG9yZGVyIHRvIGF2b2lkIGxvbmcgbmFtZXNwYWNlIAovLyByZWZlcmVuY2VzIHRvIFN5bnRheEhpZ2hsaWdodGVyLndoYXRldmVyLi4uCnZhciBzaCA9IHsKCWRlZmF1bHRzIDogewoJCS8qKiBBZGRpdGlvbmFsIENTUyBjbGFzcyBuYW1lcyB0byBiZSBhZGRlZCB0byBoaWdobGlnaHRlciBlbGVtZW50cy4gKi8KCQknY2xhc3MtbmFtZScgOiAnJywKCQkKCQkvKiogRmlyc3QgbGluZSBudW1iZXIuICovCgkJJ2ZpcnN0LWxpbmUnIDogMSwKCQkKCQkvKioKCQkgKiBQYWRzIGxpbmUgbnVtYmVycy4gUG9zc2libGUgdmFsdWVzIGFyZToKCQkgKgoJCSAqICAgZmFsc2UgLSBkb24ndCBwYWQgbGluZSBudW1iZXJzLgoJCSAqICAgdHJ1ZSAgLSBhdXRvbWF0aWNhbHkgcGFkIG51bWJlcnMgd2l0aCBtaW5pbXVtIHJlcXVpcmVkIG51bWJlciBvZiBsZWFkaW5nIHplcm9lcy4KCQkgKiAgIFtpbnRdIC0gbGVuZ3RoIHVwIHRvIHdoaWNoIHBhZCBsaW5lIG51bWJlcnMuCgkJICovCgkJJ3BhZC1saW5lLW51bWJlcnMnIDogZmFsc2UsCgkJCgkJLyoqIExpbmVzIHRvIGhpZ2hsaWdodC4gKi8KCQknaGlnaGxpZ2h0JyA6IG51bGwsCgkJCgkJLyoqIFRpdGxlIHRvIGJlIGRpc3BsYXllZCBhYm92ZSB0aGUgY29kZSBibG9jay4gKi8KCQkndGl0bGUnIDogbnVsbCwKCQkKCQkvKiogRW5hYmxlcyBvciBkaXNhYmxlcyBzbWFydCB0YWJzLiAqLwoJCSdzbWFydC10YWJzJyA6IHRydWUsCgkJCgkJLyoqIEdldHMgb3Igc2V0cyB0YWIgc2l6ZS4gKi8KCQkndGFiLXNpemUnIDogNCwKCQkKCQkvKiogRW5hYmxlcyBvciBkaXNhYmxlcyBndXR0ZXIuICovCgkJJ2d1dHRlcicgOiB0cnVlLAoJCQoJCS8qKiBFbmFibGVzIG9yIGRpc2FibGVzIHRvb2xiYXIuICovCgkJJ3Rvb2xiYXInIDogdHJ1ZSwKCQkKCQkvKiogRW5hYmxlcyBxdWljayBjb2RlIGNvcHkgYW5kIHBhc3RlIGZyb20gZG91YmxlIGNsaWNrLiAqLwoJCSdxdWljay1jb2RlJyA6IHRydWUsCgkJCgkJLyoqIEZvcmNlcyBjb2RlIHZpZXcgdG8gYmUgY29sbGFwc2VkLiAqLwoJCSdjb2xsYXBzZScgOiBmYWxzZSwKCQkKCQkvKiogRW5hYmxlcyBvciBkaXNhYmxlcyBhdXRvbWF0aWMgbGlua3MuICovCgkJJ2F1dG8tbGlua3MnIDogdHJ1ZSwKCQkKCQkvKiogR2V0cyBvciBzZXRzIGxpZ2h0IG1vZGUuIEVxdWF2YWxlbnQgdG8gdHVybmluZyBvZmYgZ3V0dGVyIGFuZCB0b29sYmFyLiAqLwoJCSdsaWdodCcgOiBmYWxzZSwKCgkJJ3VuaW5kZW50JyA6IHRydWUsCgkJCgkJJ2h0bWwtc2NyaXB0JyA6IGZhbHNlCgl9LAoJCgljb25maWcgOiB7CgkJc3BhY2UgOiAnJm5ic3A7JywKCQkKCQkvKiogRW5hYmxlcyB1c2Ugb2YgPFNDUklQVCB0eXBlPSJzeW50YXhoaWdobGlnaHRlciIgLz4gdGFncy4gKi8KCQl1c2VTY3JpcHRUYWdzIDogdHJ1ZSwKCQkKCQkvKiogQmxvZ2dlciBtb2RlIGZsYWcuICovCgkJYmxvZ2dlck1vZGUgOiBmYWxzZSwKCQkKCQlzdHJpcEJycyA6IGZhbHNlLAoJCQoJCS8qKiBOYW1lIG9mIHRoZSB0YWcgdGhhdCBTeW50YXhIaWdobGlnaHRlciB3aWxsIGF1dG9tYXRpY2FsbHkgbG9vayBmb3IuICovCgkJdGFnTmFtZSA6ICdwcmUnLAoJCQoJCXN0cmluZ3MgOiB7CgkJCWV4cGFuZFNvdXJjZSA6ICdleHBhbmQgc291cmNlJywKCQkJaGVscCA6ICc/JywKCQkJYWxlcnQ6ICdTeW50YXhIaWdobGlnaHRlclxuXG4nLAoJCQlub0JydXNoIDogJ0NhblwndCBmaW5kIGJydXNoIGZvcjogJywKCQkJYnJ1c2hOb3RIdG1sU2NyaXB0IDogJ0JydXNoIHdhc25cJ3QgY29uZmlndXJlZCBmb3IgaHRtbC1zY3JpcHQgb3B0aW9uOiAnLAoJCQkKCQkJLy8gdGhpcyBpcyBwb3B1bGF0ZWQgYnkgdGhlIGJ1aWxkIHNjcmlwdAoJCQlhYm91dERpYWxvZyA6ICdAQUJPVVRAJwoJCX0KCX0sCgkKCS8qKiBJbnRlcm5hbCAnZ2xvYmFsJyB2YXJpYWJsZXMuICovCgl2YXJzIDogewoJCWRpc2NvdmVyZWRCcnVzaGVzIDogbnVsbCwKCQloaWdobGlnaHRlcnMgOiB7fQoJfSwKCQoJLyoqIFRoaXMgb2JqZWN0IGlzIHBvcHVsYXRlZCBieSB1c2VyIGluY2x1ZGVkIGV4dGVybmFsIGJydXNoIGZpbGVzLiAqLwoJYnJ1c2hlcyA6IHt9LAoKCS8qKiBDb21tb24gcmVndWxhciBleHByZXNzaW9ucy4gKi8KCXJlZ2V4TGliIDogewoJCW11bHRpTGluZUNDb21tZW50cwkJCTogL1wvXCpbXHNcU10qP1wqXC8vZ20sCgkJc2luZ2xlTGluZUNDb21tZW50cwkJCTogL1wvXC8uKiQvZ20sCgkJc2luZ2xlTGluZVBlcmxDb21tZW50cwkJOiAvIy4qJC9nbSwKCQlkb3VibGVRdW90ZWRTdHJpbmcJCQk6IC8iKFteXFwiXG5dfFxcLikqIi9nLAoJCXNpbmdsZVF1b3RlZFN0cmluZwkJCTogLycoW15cXCdcbl18XFwuKSonL2csCgkJbXVsdGlMaW5lRG91YmxlUXVvdGVkU3RyaW5nCTogbmV3IFhSZWdFeHAoJyIoW15cXFxcIl18XFxcXC4pKiInLCAnZ3MnKSwKCQltdWx0aUxpbmVTaW5nbGVRdW90ZWRTdHJpbmcJOiBuZXcgWFJlZ0V4cCgiJyhbXlxcXFwnXXxcXFxcLikqJyIsICdncycpLAoJCXhtbENvbW1lbnRzCQkJCQk6IC8oJmx0O3w8KSEtLVtcc1xTXSo/LS0oJmd0O3w%2BKS9nbSwKCQl1cmwJCQkJCQkJOiAvXHcrOlwvXC9bXHctLlwvPyUmPTpAOyNdKi9nLAoJCQoJCS8qKiA8Pz0gPz4gdGFncy4gKi8KCQlwaHBTY3JpcHRUYWdzIAkJCQk6IHsgbGVmdDogLygmbHQ7fDwpXD8oPzo9fHBocCk/L2csIHJpZ2h0OiAvXD8oJmd0O3w%2BKS9nLCAnZW9mJyA6IHRydWUgfSwKCQkKCQkvKiogPCU9ICU%2BIHRhZ3MuICovCgkJYXNwU2NyaXB0VGFncwkJCQk6IHsgbGVmdDogLygmbHQ7fDwpJT0/L2csIHJpZ2h0OiAvJSgmZ3Q7fD4pL2cgfSwKCQkKCQkvKiogPHNjcmlwdD4gdGFncy4gKi8KCQlzY3JpcHRTY3JpcHRUYWdzCQkJOiB7IGxlZnQ6IC8oJmx0O3w8KVxzKnNjcmlwdC4qPygmZ3Q7fD4pL2dpLCByaWdodDogLygmbHQ7fDwpXC9ccypzY3JpcHRccyooJmd0O3w%2BKS9naSB9Cgl9LAoKCXRvb2xiYXI6IHsKCQkvKioKCQkgKiBHZW5lcmF0ZXMgSFRNTCBtYXJrdXAgZm9yIHRoZSB0b29sYmFyLgoJCSAqIEBwYXJhbSB7SGlnaGxpZ2h0ZXJ9IGhpZ2hsaWdodGVyIEhpZ2hsaWdodGVyIGluc3RhbmNlLgoJCSAqIEByZXR1cm4ge1N0cmluZ30gUmV0dXJucyBIVE1MIG1hcmt1cC4KCQkgKi8KCQlnZXRIdG1sOiBmdW5jdGlvbihoaWdobGlnaHRlcikKCQl7CgkJCXZhciBodG1sID0gJzxkaXYgY2xhc3M9InRvb2xiYXIiPicsCgkJCQlpdGVtcyA9IHNoLnRvb2xiYXIuaXRlbXMsCgkJCQlsaXN0ID0gaXRlbXMubGlzdAoJCQkJOwoJCQkKCQkJZnVuY3Rpb24gZGVmYXVsdEdldEh0bWwoaGlnaGxpZ2h0ZXIsIG5hbWUpCgkJCXsKCQkJCXJldHVybiBzaC50b29sYmFyLmdldEJ1dHRvbkh0bWwoaGlnaGxpZ2h0ZXIsIG5hbWUsIHNoLmNvbmZpZy5zdHJpbmdzW25hbWVdKTsKCQkJfTsKCQkJCgkJCWZvciAodmFyIGkgPSAwOyBpIDwgbGlzdC5sZW5ndGg7IGkrKykKCQkJCWh0bWwgKz0gKGl0ZW1zW2xpc3RbaV1dLmdldEh0bWwgfHwgZGVmYXVsdEdldEh0bWwpKGhpZ2hsaWdodGVyLCBsaXN0W2ldKTsKCQkJCgkJCWh0bWwgKz0gJzwvZGl2Pic7CgkJCQoJCQlyZXR1cm4gaHRtbDsKCQl9LAoJCQoJCS8qKgoJCSAqIEdlbmVyYXRlcyBIVE1MIG1hcmt1cCBmb3IgYSByZWd1bGFyIGJ1dHRvbiBpbiB0aGUgdG9vbGJhci4KCQkgKiBAcGFyYW0ge0hpZ2hsaWdodGVyfSBoaWdobGlnaHRlciBIaWdobGlnaHRlciBpbnN0YW5jZS4KCQkgKiBAcGFyYW0ge1N0cmluZ30gY29tbWFuZE5hbWUJCUNvbW1hbmQgbmFtZSB0aGF0IHdvdWxkIGJlIGV4ZWN1dGVkLgoJCSAqIEBwYXJhbSB7U3RyaW5nfSBsYWJlbAkJCUxhYmVsIHRleHQgdG8gZGlzcGxheS4KCQkgKiBAcmV0dXJuIHtTdHJpbmd9CQkJCQlSZXR1cm5zIEhUTUwgbWFya3VwLgoJCSAqLwoJCWdldEJ1dHRvbkh0bWw6IGZ1bmN0aW9uKGhpZ2hsaWdodGVyLCBjb21tYW5kTmFtZSwgbGFiZWwpCgkJewoJCQlyZXR1cm4gJzxzcGFuPjxhIGhyZWY9IiMiIGNsYXNzPSJ0b29sYmFyX2l0ZW0nCgkJCQkrICcgY29tbWFuZF8nICsgY29tbWFuZE5hbWUKCQkJCSsgJyAnICsgY29tbWFuZE5hbWUKCQkJCSsgJyI%2BJyArIGxhYmVsICsgJzwvYT48L3NwYW4%2BJwoJCQkJOwoJCX0sCgkJCgkJLyoqCgkJICogRXZlbnQgaGFuZGxlciBmb3IgYSB0b29sYmFyIGFuY2hvci4KCQkgKi8KCQloYW5kbGVyOiBmdW5jdGlvbihlKQoJCXsKCQkJdmFyIHRhcmdldCA9IGUudGFyZ2V0LAoJCQkJY2xhc3NOYW1lID0gdGFyZ2V0LmNsYXNzTmFtZSB8fCAnJwoJCQkJOwoKCQkJZnVuY3Rpb24gZ2V0VmFsdWUobmFtZSkKCQkJewoJCQkJdmFyIHIgPSBuZXcgUmVnRXhwKG5hbWUgKyAnXyhcXHcrKScpLAoJCQkJCW1hdGNoID0gci5leGVjKGNsYXNzTmFtZSkKCQkJCQk7CgoJCQkJcmV0dXJuIG1hdGNoID8gbWF0Y2hbMV0gOiBudWxsOwoJCQl9OwoJCQkKCQkJdmFyIGhpZ2hsaWdodGVyID0gZ2V0SGlnaGxpZ2h0ZXJCeUlkKGZpbmRQYXJlbnRFbGVtZW50KHRhcmdldCwgJy5zeW50YXhoaWdobGlnaHRlcicpLmlkKSwKCQkJCWNvbW1hbmROYW1lID0gZ2V0VmFsdWUoJ2NvbW1hbmQnKQoJCQkJOwoJCQkKCQkJLy8gZXhlY3V0ZSB0aGUgdG9vbGJhciBjb21tYW5kCgkJCWlmIChoaWdobGlnaHRlciAmJiBjb21tYW5kTmFtZSkKCQkJCXNoLnRvb2xiYXIuaXRlbXNbY29tbWFuZE5hbWVdLmV4ZWN1dGUoaGlnaGxpZ2h0ZXIpOwoKCQkJLy8gZGlzYWJsZSBkZWZhdWx0IEEgY2xpY2sgYmVoYXZpb3VyCgkJCWUucHJldmVudERlZmF1bHQoKTsKCQl9LAoJCQoJCS8qKiBDb2xsZWN0aW9uIG9mIHRvb2xiYXIgaXRlbXMuICovCgkJaXRlbXMgOiB7CgkJCS8vIE9yZGVyZWQgbGlzIG9mIGl0ZW1zIGluIHRoZSB0b29sYmFyLiBDYW4ndCBleHBlY3QgYGZvciAodmFyIG4gaW4gaXRlbXMpYCB0byBiZSBjb25zaXN0ZW50LgoJCQlsaXN0OiBbJ2V4cGFuZFNvdXJjZScsICdoZWxwJ10sCgoJCQlleHBhbmRTb3VyY2U6IHsKCQkJCWdldEh0bWw6IGZ1bmN0aW9uKGhpZ2hsaWdodGVyKQoJCQkJewoJCQkJCWlmIChoaWdobGlnaHRlci5nZXRQYXJhbSgnY29sbGFwc2UnKSAhPSB0cnVlKQoJCQkJCQlyZXR1cm4gJyc7CgkJCQkJCQoJCQkJCXZhciB0aXRsZSA9IGhpZ2hsaWdodGVyLmdldFBhcmFtKCd0aXRsZScpOwoJCQkJCXJldHVybiBzaC50b29sYmFyLmdldEJ1dHRvbkh0bWwoaGlnaGxpZ2h0ZXIsICdleHBhbmRTb3VyY2UnLCB0aXRsZSA/IHRpdGxlIDogc2guY29uZmlnLnN0cmluZ3MuZXhwYW5kU291cmNlKTsKCQkJCX0sCgkJCQoJCQkJZXhlY3V0ZTogZnVuY3Rpb24oaGlnaGxpZ2h0ZXIpCgkJCQl7CgkJCQkJdmFyIGRpdiA9IGdldEhpZ2hsaWdodGVyRGl2QnlJZChoaWdobGlnaHRlci5pZCk7CgkJCQkJcmVtb3ZlQ2xhc3MoZGl2LCAnY29sbGFwc2VkJyk7CgkJCQl9CgkJCX0sCgoJCQkvKiogQ29tbWFuZCB0byBkaXNwbGF5IHRoZSBhYm91dCBkaWFsb2cgd2luZG93LiAqLwoJCQloZWxwOiB7CgkJCQlleGVjdXRlOiBmdW5jdGlvbihoaWdobGlnaHRlcikKCQkJCXsJCgkJCQkJdmFyIHduZCA9IHBvcHVwKCcnLCAnX2JsYW5rJywgNTAwLCAyNTAsICdzY3JvbGxiYXJzPTAnKSwKCQkJCQkJZG9jID0gd25kLmRvY3VtZW50CgkJCQkJCTsKCQkJCQkKCQkJCQlkb2Mud3JpdGUoc2guY29uZmlnLnN0cmluZ3MuYWJvdXREaWFsb2cpOwoJCQkJCWRvYy5jbG9zZSgpOwoJCQkJCXduZC5mb2N1cygpOwoJCQkJfQoJCQl9CgkJfQoJfSwKCgkvKioKCSAqIEZpbmRzIGFsbCBlbGVtZW50cyBvbiB0aGUgcGFnZSB3aGljaCBzaG91bGQgYmUgcHJvY2Vzc2VzIGJ5IFN5bnRheEhpZ2hsaWdodGVyLgoJICoKCSAqIEBwYXJhbSB7T2JqZWN0fSBnbG9iYWxQYXJhbXMJCU9wdGlvbmFsIHBhcmFtZXRlcnMgd2hpY2ggb3ZlcnJpZGUgZWxlbWVudCdzIAoJICogCQkJCQkJCQkJcGFyYW1ldGVycy4gT25seSB1c2VkIGlmIGVsZW1lbnQgaXMgc3BlY2lmaWVkLgoJICogCgkgKiBAcGFyYW0ge09iamVjdH0gZWxlbWVudAlPcHRpb25hbCBlbGVtZW50IHRvIGhpZ2hsaWdodC4gSWYgbm9uZSBpcwoJICogCQkJCQkJCXByb3ZpZGVkLCBhbGwgZWxlbWVudHMgaW4gdGhlIGN1cnJlbnQgZG9jdW1lbnQgCgkgKiAJCQkJCQkJYXJlIHJldHVybmVkIHdoaWNoIHF1YWxpZnkuCgkgKgoJICogQHJldHVybiB7QXJyYXl9CVJldHVybnMgbGlzdCBvZiA8Y29kZT57IHRhcmdldDogRE9NRWxlbWVudCwgcGFyYW1zOiBPYmplY3QgfTwvY29kZT4gb2JqZWN0cy4KCSAqLwoJZmluZEVsZW1lbnRzOiBmdW5jdGlvbihnbG9iYWxQYXJhbXMsIGVsZW1lbnQpCgl7CgkJdmFyIGVsZW1lbnRzID0gZWxlbWVudCA/IFtlbGVtZW50XSA6IHRvQXJyYXkoZG9jdW1lbnQuZ2V0RWxlbWVudHNCeVRhZ05hbWUoc2guY29uZmlnLnRhZ05hbWUpKSwgCgkJCWNvbmYgPSBzaC5jb25maWcsCgkJCXJlc3VsdCA9IFtdCgkJCTsKCgkJLy8gc3VwcG9ydCBmb3IgPFNDUklQVCBUWVBFPSJzeW50YXhoaWdobGlnaHRlciIgLz4gZmVhdHVyZQoJCWlmIChjb25mLnVzZVNjcmlwdFRhZ3MpCgkJCWVsZW1lbnRzID0gZWxlbWVudHMuY29uY2F0KGdldFN5bnRheEhpZ2hsaWdodGVyU2NyaXB0VGFncygpKTsKCgkJaWYgKGVsZW1lbnRzLmxlbmd0aCA9PT0gMCkgCgkJCXJldHVybiByZXN1bHQ7CgkKCQlmb3IgKHZhciBpID0gMDsgaSA8IGVsZW1lbnRzLmxlbmd0aDsgaSsrKSAKCQl7CgkJCXZhciBpdGVtID0gewoJCQkJdGFyZ2V0OiBlbGVtZW50c1tpXSwgCgkJCQkvLyBsb2NhbCBwYXJhbXMgdGFrZSBwcmVjZWRlbmNlIG92ZXIgZ2xvYmFscwoJCQkJcGFyYW1zOiBtZXJnZShnbG9iYWxQYXJhbXMsIHBhcnNlUGFyYW1zKGVsZW1lbnRzW2ldLmNsYXNzTmFtZSkpCgkJCX07CgoJCQlpZiAoaXRlbS5wYXJhbXNbJ2JydXNoJ10gPT0gbnVsbCkKCQkJCWNvbnRpbnVlOwoJCQkJCgkJCXJlc3VsdC5wdXNoKGl0ZW0pOwoJCX0KCQkKCQlyZXR1cm4gcmVzdWx0OwoJfSwKCgkvKioKCSAqIFNob3J0aGFuZCB0byBoaWdobGlnaHQgYWxsIGVsZW1lbnRzIG9uIHRoZSBwYWdlIHRoYXQgYXJlIG1hcmtlZCBhcyAKCSAqIFN5bnRheEhpZ2hsaWdodGVyIHNvdXJjZSBjb2RlLgoJICogCgkgKiBAcGFyYW0ge09iamVjdH0gZ2xvYmFsUGFyYW1zCQlPcHRpb25hbCBwYXJhbWV0ZXJzIHdoaWNoIG92ZXJyaWRlIGVsZW1lbnQncyAKCSAqIAkJCQkJCQkJCXBhcmFtZXRlcnMuIE9ubHkgdXNlZCBpZiBlbGVtZW50IGlzIHNwZWNpZmllZC4KCSAqIAoJICogQHBhcmFtIHtPYmplY3R9IGVsZW1lbnQJT3B0aW9uYWwgZWxlbWVudCB0byBoaWdobGlnaHQuIElmIG5vbmUgaXMKCSAqIAkJCQkJCQlwcm92aWRlZCwgYWxsIGVsZW1lbnRzIGluIHRoZSBjdXJyZW50IGRvY3VtZW50IAoJICogCQkJCQkJCWFyZSBoaWdobGlnaHRlZC4KCSAqLyAKCWhpZ2hsaWdodDogZnVuY3Rpb24oZ2xvYmFsUGFyYW1zLCBlbGVtZW50KQoJewoJCXZhciBlbGVtZW50cyA9IHRoaXMuZmluZEVsZW1lbnRzKGdsb2JhbFBhcmFtcywgZWxlbWVudCksCgkJCXByb3BlcnR5TmFtZSA9ICdpbm5lckhUTUwnLCAKCQkJaGlnaGxpZ2h0ZXIgPSBudWxsLAoJCQljb25mID0gc2guY29uZmlnCgkJCTsKCgkJaWYgKGVsZW1lbnRzLmxlbmd0aCA9PT0gMCkgCgkJCXJldHVybjsKCQoJCWZvciAodmFyIGkgPSAwOyBpIDwgZWxlbWVudHMubGVuZ3RoOyBpKyspIAoJCXsKCQkJdmFyIGVsZW1lbnQgPSBlbGVtZW50c1tpXSwKCQkJCXRhcmdldCA9IGVsZW1lbnQudGFyZ2V0LAoJCQkJcGFyYW1zID0gZWxlbWVudC5wYXJhbXMsCgkJCQlicnVzaE5hbWUgPSBwYXJhbXMuYnJ1c2gsCgkJCQljb2RlCgkJCQk7CgoJCQlpZiAoYnJ1c2hOYW1lID09IG51bGwpCgkJCQljb250aW51ZTsKCgkJCS8vIEluc3RhbnRpYXRlIGEgYnJ1c2gKCQkJaWYgKHBhcmFtc1snaHRtbC1zY3JpcHQnXSA9PSAndHJ1ZScgfHwgc2guZGVmYXVsdHNbJ2h0bWwtc2NyaXB0J10gPT0gdHJ1ZSkgCgkJCXsKCQkJCWhpZ2hsaWdodGVyID0gbmV3IHNoLkh0bWxTY3JpcHQoYnJ1c2hOYW1lKTsKCQkJCWJydXNoTmFtZSA9ICdodG1sc2NyaXB0JzsKCQkJfQoJCQllbHNlCgkJCXsKCQkJCXZhciBicnVzaCA9IGZpbmRCcnVzaChicnVzaE5hbWUpOwoJCQkJCgkJCQlpZiAoYnJ1c2gpCgkJCQkJaGlnaGxpZ2h0ZXIgPSBuZXcgYnJ1c2goKTsKCQkJCWVsc2UKCQkJCQljb250aW51ZTsKCQkJfQoJCQkKCQkJY29kZSA9IHRhcmdldFtwcm9wZXJ0eU5hbWVdOwoJCQkKCQkJLy8gcmVtb3ZlIENEQVRBIGZyb20gPFNDUklQVC8%2BIHRhZ3MgaWYgaXQncyBwcmVzZW50CgkJCWlmIChjb25mLnVzZVNjcmlwdFRhZ3MpCgkJCQljb2RlID0gc3RyaXBDRGF0YShjb2RlKTsKCQkJCQoJCQkvLyBJbmplY3QgdGl0bGUgaWYgdGhlIGF0dHJpYnV0ZSBpcyBwcmVzZW50CgkJCWlmICgodGFyZ2V0LnRpdGxlIHx8ICcnKSAhPSAnJykKCQkJCXBhcmFtcy50aXRsZSA9IHRhcmdldC50aXRsZTsKCQkJCQoJCQlwYXJhbXNbJ2JydXNoJ10gPSBicnVzaE5hbWU7CgkJCWhpZ2hsaWdodGVyLmluaXQocGFyYW1zKTsKCQkJZWxlbWVudCA9IGhpZ2hsaWdodGVyLmdldERpdihjb2RlKTsKCQkJCgkJCS8vIGNhcnJ5IG92ZXIgSUQKCQkJaWYgKCh0YXJnZXQuaWQgfHwgJycpICE9ICcnKQoJCQkJZWxlbWVudC5pZCA9IHRhcmdldC5pZDsKCQkJCgkJCXRhcmdldC5wYXJlbnROb2RlLnJlcGxhY2VDaGlsZChlbGVtZW50LCB0YXJnZXQpOwoJCX0KCX0sCgoJLyoqCgkgKiBNYWluIGVudHJ5IHBvaW50IGZvciB0aGUgU3ludGF4SGlnaGxpZ2h0ZXIuCgkgKiBAcGFyYW0ge09iamVjdH0gcGFyYW1zIE9wdGlvbmFsIHBhcmFtcyB0byBhcHBseSB0byBhbGwgaGlnaGxpZ2h0ZWQgZWxlbWVudHMuCgkgKi8KCWFsbDogZnVuY3Rpb24ocGFyYW1zKQoJewoJCWF0dGFjaEV2ZW50KAoJCQl3aW5kb3csCgkJCSdsb2FkJywKCQkJZnVuY3Rpb24oKSB7IHNoLmhpZ2hsaWdodChwYXJhbXMpOyB9CgkJKTsKCX0KfTsgLy8gZW5kIG9mIHNoCgovKioKICogQ2hlY2tzIGlmIHRhcmdldCBET00gZWxlbWVudHMgaGFzIHNwZWNpZmllZCBDU1MgY2xhc3MuCiAqIEBwYXJhbSB7RE9NRWxlbWVudH0gdGFyZ2V0IFRhcmdldCBET00gZWxlbWVudCB0byBjaGVjay4KICogQHBhcmFtIHtTdHJpbmd9IGNsYXNzTmFtZSBOYW1lIG9mIHRoZSBDU1MgY2xhc3MgdG8gY2hlY2sgZm9yLgogKiBAcmV0dXJuIHtCb29sZWFufSBSZXR1cm5zIHRydWUgaWYgY2xhc3MgbmFtZSBpcyBwcmVzZW50LCBmYWxzZSBvdGhlcndpc2UuCiAqLwpmdW5jdGlvbiBoYXNDbGFzcyh0YXJnZXQsIGNsYXNzTmFtZSkKewoJcmV0dXJuIHRhcmdldC5jbGFzc05hbWUuaW5kZXhPZihjbGFzc05hbWUpICE9IC0xOwp9OwoKLyoqCiAqIEFkZHMgQ1NTIGNsYXNzIG5hbWUgdG8gdGhlIHRhcmdldCBET00gZWxlbWVudC4KICogQHBhcmFtIHtET01FbGVtZW50fSB0YXJnZXQgVGFyZ2V0IERPTSBlbGVtZW50LgogKiBAcGFyYW0ge1N0cmluZ30gY2xhc3NOYW1lIE5ldyBDU1MgY2xhc3MgdG8gYWRkLgogKi8KZnVuY3Rpb24gYWRkQ2xhc3ModGFyZ2V0LCBjbGFzc05hbWUpCnsKCWlmICghaGFzQ2xhc3ModGFyZ2V0LCBjbGFzc05hbWUpKQoJCXRhcmdldC5jbGFzc05hbWUgKz0gJyAnICsgY2xhc3NOYW1lOwp9OwoKLyoqCiAqIFJlbW92ZXMgQ1NTIGNsYXNzIG5hbWUgZnJvbSB0aGUgdGFyZ2V0IERPTSBlbGVtZW50LgogKiBAcGFyYW0ge0RPTUVsZW1lbnR9IHRhcmdldCBUYXJnZXQgRE9NIGVsZW1lbnQuCiAqIEBwYXJhbSB7U3RyaW5nfSBjbGFzc05hbWUgQ1NTIGNsYXNzIHRvIHJlbW92ZS4KICovCmZ1bmN0aW9uIHJlbW92ZUNsYXNzKHRhcmdldCwgY2xhc3NOYW1lKQp7Cgl0YXJnZXQuY2xhc3NOYW1lID0gdGFyZ2V0LmNsYXNzTmFtZS5yZXBsYWNlKGNsYXNzTmFtZSwgJycpOwp9OwoKLyoqCiAqIENvbnZlcnRzIHRoZSBzb3VyY2UgdG8gYXJyYXkgb2JqZWN0LiBNb3N0bHkgdXNlZCBmb3IgZnVuY3Rpb24gYXJndW1lbnRzIGFuZCAKICogbGlzdHMgcmV0dXJuZWQgYnkgZ2V0RWxlbWVudHNCeVRhZ05hbWUoKSB3aGljaCBhcmVuJ3QgQXJyYXkgb2JqZWN0cy4KICogQHBhcmFtIHtMaXN0fSBzb3VyY2UgU291cmNlIGxpc3QuCiAqIEByZXR1cm4ge0FycmF5fSBSZXR1cm5zIGFycmF5LgogKi8KZnVuY3Rpb24gdG9BcnJheShzb3VyY2UpCnsKCXZhciByZXN1bHQgPSBbXTsKCQoJZm9yICh2YXIgaSA9IDA7IGkgPCBzb3VyY2UubGVuZ3RoOyBpKyspIAoJCXJlc3VsdC5wdXNoKHNvdXJjZVtpXSk7CgkJCglyZXR1cm4gcmVzdWx0Owp9OwoKLyoqCiAqIFNwbGl0cyBibG9jayBvZiB0ZXh0IGludG8gbGluZXMuCiAqIEBwYXJhbSB7U3RyaW5nfSBibG9jayBCbG9jayBvZiB0ZXh0LgogKiBAcmV0dXJuIHtBcnJheX0gUmV0dXJucyBhcnJheSBvZiBsaW5lcy4KICovCmZ1bmN0aW9uIHNwbGl0TGluZXMoYmxvY2spCnsKCXJldHVybiBibG9jay5zcGxpdCgvXHI/XG4vKTsKfQoKLyoqCiAqIEdlbmVyYXRlcyBIVE1MIElEIGZvciB0aGUgaGlnaGxpZ2h0ZXIuCiAqIEBwYXJhbSB7U3RyaW5nfSBoaWdobGlnaHRlcklkIEhpZ2hsaWdodGVyIElELgogKiBAcmV0dXJuIHtTdHJpbmd9IFJldHVybnMgSFRNTCBJRC4KICovCmZ1bmN0aW9uIGdldEhpZ2hsaWdodGVySWQoaWQpCnsKCXZhciBwcmVmaXggPSAnaGlnaGxpZ2h0ZXJfJzsKCXJldHVybiBpZC5pbmRleE9mKHByZWZpeCkgPT0gMCA/IGlkIDogcHJlZml4ICsgaWQ7Cn07CgovKioKICogRmluZHMgSGlnaGxpZ2h0ZXIgaW5zdGFuY2UgYnkgSUQuCiAqIEBwYXJhbSB7U3RyaW5nfSBoaWdobGlnaHRlcklkIEhpZ2hsaWdodGVyIElELgogKiBAcmV0dXJuIHtIaWdobGlnaHRlcn0gUmV0dXJucyBpbnN0YW5jZSBvZiB0aGUgaGlnaGxpZ2h0ZXIuCiAqLwpmdW5jdGlvbiBnZXRIaWdobGlnaHRlckJ5SWQoaWQpCnsKCXJldHVybiBzaC52YXJzLmhpZ2hsaWdodGVyc1tnZXRIaWdobGlnaHRlcklkKGlkKV07Cn07CgovKioKICogRmluZHMgaGlnaGxpZ2h0ZXIncyBESVYgY29udGFpbmVyLgogKiBAcGFyYW0ge1N0cmluZ30gaGlnaGxpZ2h0ZXJJZCBIaWdobGlnaHRlciBJRC4KICogQHJldHVybiB7RWxlbWVudH0gUmV0dXJucyBoaWdobGlnaHRlcidzIERJViBlbGVtZW50LgogKi8KZnVuY3Rpb24gZ2V0SGlnaGxpZ2h0ZXJEaXZCeUlkKGlkKQp7CglyZXR1cm4gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoZ2V0SGlnaGxpZ2h0ZXJJZChpZCkpOwp9OwoKLyoqCiAqIFN0b3JlcyBoaWdobGlnaHRlciBzbyB0aGF0IGdldEhpZ2hsaWdodGVyQnlJZCgpIGNhbiBkbyBpdHMgdGhpbmcuIEVhY2gKICogaGlnaGxpZ2h0ZXIgbXVzdCBjYWxsIHRoaXMgbWV0aG9kIHRvIHByZXNlcnZlIGl0c2VsZi4KICogQHBhcmFtIHtIaWdoaWxnaHRlcn0gaGlnaGxpZ2h0ZXIgSGlnaGxpZ2h0ZXIgaW5zdGFuY2UuCiAqLwpmdW5jdGlvbiBzdG9yZUhpZ2hsaWdodGVyKGhpZ2hsaWdodGVyKQp7CglzaC52YXJzLmhpZ2hsaWdodGVyc1tnZXRIaWdobGlnaHRlcklkKGhpZ2hsaWdodGVyLmlkKV0gPSBoaWdobGlnaHRlcjsKfTsKCi8qKgogKiBMb29rcyBmb3IgYSBjaGlsZCBvciBwYXJlbnQgbm9kZSB3aGljaCBoYXMgc3BlY2lmaWVkIGNsYXNzbmFtZS4KICogRXF1aXZhbGVudCB0byBqUXVlcnkncyAkKGNvbnRhaW5lcikuZmluZCgiLmNsYXNzTmFtZSIpCiAqIEBwYXJhbSB7RWxlbWVudH0gdGFyZ2V0IFRhcmdldCBlbGVtZW50LgogKiBAcGFyYW0ge1N0cmluZ30gc2VhcmNoIENsYXNzIG5hbWUgb3Igbm9kZSBuYW1lIHRvIGxvb2sgZm9yLgogKiBAcGFyYW0ge0Jvb2xlYW59IHJldmVyc2UgSWYgc2V0IHRvIHRydWUsIHdpbGwgZ28gdXAgdGhlIG5vZGUgdHJlZSBpbnN0ZWFkIG9mIGRvd24uCiAqIEByZXR1cm4ge0VsZW1lbnR9IFJldHVybnMgZm91bmQgY2hpbGQgb3IgcGFyZW50IGVsZW1lbnQgb24gbnVsbC4KICovCmZ1bmN0aW9uIGZpbmRFbGVtZW50KHRhcmdldCwgc2VhcmNoLCByZXZlcnNlIC8qIG9wdGlvbmFsICovKQp7CglpZiAodGFyZ2V0ID09IG51bGwpCgkJcmV0dXJuIG51bGw7CgkJCgl2YXIgbm9kZXMJCQk9IHJldmVyc2UgIT0gdHJ1ZSA/IHRhcmdldC5jaGlsZE5vZGVzIDogWyB0YXJnZXQucGFyZW50Tm9kZSBdLAoJCXByb3BlcnR5VG9GaW5kCT0geyAnIycgOiAnaWQnLCAnLicgOiAnY2xhc3NOYW1lJyB9W3NlYXJjaC5zdWJzdHIoMCwgMSldIHx8ICdub2RlTmFtZScsCgkJZXhwZWN0ZWRWYWx1ZSwKCQlmb3VuZAoJCTsKCglleHBlY3RlZFZhbHVlID0gcHJvcGVydHlUb0ZpbmQgIT0gJ25vZGVOYW1lJwoJCT8gc2VhcmNoLnN1YnN0cigxKQoJCTogc2VhcmNoLnRvVXBwZXJDYXNlKCkKCQk7CgkJCgkvLyBtYWluIHJldHVybiBvZiB0aGUgZm91bmQgbm9kZQoJaWYgKCh0YXJnZXRbcHJvcGVydHlUb0ZpbmRdIHx8ICcnKS5pbmRleE9mKGV4cGVjdGVkVmFsdWUpICE9IC0xKQoJCXJldHVybiB0YXJnZXQ7CgkKCWZvciAodmFyIGkgPSAwOyBub2RlcyAmJiBpIDwgbm9kZXMubGVuZ3RoICYmIGZvdW5kID09IG51bGw7IGkrKykKCQlmb3VuZCA9IGZpbmRFbGVtZW50KG5vZGVzW2ldLCBzZWFyY2gsIHJldmVyc2UpOwoJCglyZXR1cm4gZm91bmQ7Cn07CgovKioKICogTG9va3MgZm9yIGEgcGFyZW50IG5vZGUgd2hpY2ggaGFzIHNwZWNpZmllZCBjbGFzc25hbWUuCiAqIFRoaXMgaXMgYW4gYWxpYXMgdG8gPGNvZGU%2BZmluZEVsZW1lbnQoY29udGFpbmVyLCBjbGFzc05hbWUsIHRydWUpPC9jb2RlPi4KICogQHBhcmFtIHtFbGVtZW50fSB0YXJnZXQgVGFyZ2V0IGVsZW1lbnQuCiAqIEBwYXJhbSB7U3RyaW5nfSBjbGFzc05hbWUgQ2xhc3MgbmFtZSB0byBsb29rIGZvci4KICogQHJldHVybiB7RWxlbWVudH0gUmV0dXJucyBmb3VuZCBwYXJlbnQgZWxlbWVudCBvbiBudWxsLgogKi8KZnVuY3Rpb24gZmluZFBhcmVudEVsZW1lbnQodGFyZ2V0LCBjbGFzc05hbWUpCnsKCXJldHVybiBmaW5kRWxlbWVudCh0YXJnZXQsIGNsYXNzTmFtZSwgdHJ1ZSk7Cn07CgovKioKICogRmluZHMgYW4gaW5kZXggb2YgZWxlbWVudCBpbiB0aGUgYXJyYXkuCiAqIEBpZ25vcmUKICogQHBhcmFtIHtPYmplY3R9IHNlYXJjaEVsZW1lbnQKICogQHBhcmFtIHtOdW1iZXJ9IGZyb21JbmRleAogKiBAcmV0dXJuIHtOdW1iZXJ9IFJldHVybnMgaW5kZXggb2YgZWxlbWVudCBpZiBmb3VuZDsgLTEgb3RoZXJ3aXNlLgogKi8KZnVuY3Rpb24gaW5kZXhPZihhcnJheSwgc2VhcmNoRWxlbWVudCwgZnJvbUluZGV4KQp7Cglmcm9tSW5kZXggPSBNYXRoLm1heChmcm9tSW5kZXggfHwgMCwgMCk7CgoJZm9yICh2YXIgaSA9IGZyb21JbmRleDsgaSA8IGFycmF5Lmxlbmd0aDsgaSsrKQoJCWlmKGFycmF5W2ldID09IHNlYXJjaEVsZW1lbnQpCgkJCXJldHVybiBpOwoJCglyZXR1cm4gLTE7Cn07CgovKioKICogR2VuZXJhdGVzIGEgdW5pcXVlIGVsZW1lbnQgSUQuCiAqLwpmdW5jdGlvbiBndWlkKHByZWZpeCkKewoJcmV0dXJuIChwcmVmaXggfHwgJycpICsgTWF0aC5yb3VuZChNYXRoLnJhbmRvbSgpICogMTAwMDAwMCkudG9TdHJpbmcoKTsKfTsKCi8qKgogKiBNZXJnZXMgdHdvIG9iamVjdHMuIFZhbHVlcyBmcm9tIG9iajIgb3ZlcnJpZGUgdmFsdWVzIGluIG9iajEuCiAqIEZ1bmN0aW9uIGlzIE5PVCByZWN1cnNpdmUgYW5kIHdvcmtzIG9ubHkgZm9yIG9uZSBkaW1lbnNpb25hbCBvYmplY3RzLgogKiBAcGFyYW0ge09iamVjdH0gb2JqMSBGaXJzdCBvYmplY3QuCiAqIEBwYXJhbSB7T2JqZWN0fSBvYmoyIFNlY29uZCBvYmplY3QuCiAqIEByZXR1cm4ge09iamVjdH0gUmV0dXJucyBjb21iaW5hdGlvbiBvZiBib3RoIG9iamVjdHMuCiAqLwpmdW5jdGlvbiBtZXJnZShvYmoxLCBvYmoyKQp7Cgl2YXIgcmVzdWx0ID0ge30sIG5hbWU7CgoJZm9yIChuYW1lIGluIG9iajEpIAoJCXJlc3VsdFtuYW1lXSA9IG9iajFbbmFtZV07CgkKCWZvciAobmFtZSBpbiBvYmoyKSAKCQlyZXN1bHRbbmFtZV0gPSBvYmoyW25hbWVdOwoJCQoJcmV0dXJuIHJlc3VsdDsKfTsKCi8qKgogKiBBdHRlbXB0cyB0byBjb252ZXJ0IHN0cmluZyB0byBib29sZWFuLgogKiBAcGFyYW0ge1N0cmluZ30gdmFsdWUgSW5wdXQgc3RyaW5nLgogKiBAcmV0dXJuIHtCb29sZWFufSBSZXR1cm5zIHRydWUgaWYgaW5wdXQgd2FzICJ0cnVlIiwgZmFsc2UgaWYgaW5wdXQgd2FzICJmYWxzZSIgYW5kIHZhbHVlIG90aGVyd2lzZS4KICovCmZ1bmN0aW9uIHRvQm9vbGVhbih2YWx1ZSkKewoJdmFyIHJlc3VsdCA9IHsgInRydWUiIDogdHJ1ZSwgImZhbHNlIiA6IGZhbHNlIH1bdmFsdWVdOwoJcmV0dXJuIHJlc3VsdCA9PSBudWxsID8gdmFsdWUgOiByZXN1bHQ7Cn07CgovKioKICogT3BlbnMgdXAgYSBjZW50ZXJlZCBwb3B1cCB3aW5kb3cuCiAqIEBwYXJhbSB7U3RyaW5nfSB1cmwJCVVSTCB0byBvcGVuIGluIHRoZSB3aW5kb3cuCiAqIEBwYXJhbSB7U3RyaW5nfSBuYW1lCQlQb3B1cCBuYW1lLgogKiBAcGFyYW0ge2ludH0gd2lkdGgJCVBvcHVwIHdpZHRoLgogKiBAcGFyYW0ge2ludH0gaGVpZ2h0CQlQb3B1cCBoZWlnaHQuCiAqIEBwYXJhbSB7U3RyaW5nfSBvcHRpb25zCXdpbmRvdy5vcGVuKCkgb3B0aW9ucy4KICogQHJldHVybiB7V2luZG93fQkJCVJldHVybnMgd2luZG93IGluc3RhbmNlLgogKi8KZnVuY3Rpb24gcG9wdXAodXJsLCBuYW1lLCB3aWR0aCwgaGVpZ2h0LCBvcHRpb25zKQp7Cgl2YXIgeCA9IChzY3JlZW4ud2lkdGggLSB3aWR0aCkgLyAyLAoJCXkgPSAoc2NyZWVuLmhlaWdodCAtIGhlaWdodCkgLyAyCgkJOwoJCQoJb3B0aW9ucyArPQknLCBsZWZ0PScgKyB4ICsgCgkJCQknLCB0b3A9JyArIHkgKwoJCQkJJywgd2lkdGg9JyArIHdpZHRoICsKCQkJCScsIGhlaWdodD0nICsgaGVpZ2h0CgkJOwoJb3B0aW9ucyA9IG9wdGlvbnMucmVwbGFjZSgvXiwvLCAnJyk7CgoJdmFyIHdpbiA9IHdpbmRvdy5vcGVuKHVybCwgbmFtZSwgb3B0aW9ucyk7Cgl3aW4uZm9jdXMoKTsKCXJldHVybiB3aW47Cn07CgovKioKICogQWRkcyBldmVudCBoYW5kbGVyIHRvIHRoZSB0YXJnZXQgb2JqZWN0LgogKiBAcGFyYW0ge09iamVjdH0gb2JqCQlUYXJnZXQgb2JqZWN0LgogKiBAcGFyYW0ge1N0cmluZ30gdHlwZQkJTmFtZSBvZiB0aGUgZXZlbnQuCiAqIEBwYXJhbSB7RnVuY3Rpb259IGZ1bmMJSGFuZGxpbmcgZnVuY3Rpb24uCiAqLwpmdW5jdGlvbiBhdHRhY2hFdmVudChvYmosIHR5cGUsIGZ1bmMsIHNjb3BlKQp7CglmdW5jdGlvbiBoYW5kbGVyKGUpCgl7CgkJZSA9IGUgfHwgd2luZG93LmV2ZW50OwoJCQoJCWlmICghZS50YXJnZXQpCgkJewoJCQllLnRhcmdldCA9IGUuc3JjRWxlbWVudDsKCQkJZS5wcmV2ZW50RGVmYXVsdCA9IGZ1bmN0aW9uKCkKCQkJewoJCQkJdGhpcy5yZXR1cm5WYWx1ZSA9IGZhbHNlOwoJCQl9OwoJCX0KCQkJCgkJZnVuYy5jYWxsKHNjb3BlIHx8IHdpbmRvdywgZSk7Cgl9OwoJCglpZiAob2JqLmF0dGFjaEV2ZW50KSAKCXsKCQlvYmouYXR0YWNoRXZlbnQoJ29uJyArIHR5cGUsIGhhbmRsZXIpOwoJfQoJZWxzZSAKCXsKCQlvYmouYWRkRXZlbnRMaXN0ZW5lcih0eXBlLCBoYW5kbGVyLCBmYWxzZSk7Cgl9Cn07CgovKioKICogRGlzcGxheXMgYW4gYWxlcnQuCiAqIEBwYXJhbSB7U3RyaW5nfSBzdHIgU3RyaW5nIHRvIGRpc3BsYXkuCiAqLwpmdW5jdGlvbiBhbGVydChzdHIpCnsKCXdpbmRvdy5hbGVydChzaC5jb25maWcuc3RyaW5ncy5hbGVydCArIHN0cik7Cn07CgovKioKICogRmluZHMgYSBicnVzaCBieSBpdHMgYWxpYXMuCiAqCiAqIEBwYXJhbSB7U3RyaW5nfSBhbGlhcwkJQnJ1c2ggYWxpYXMuCiAqIEBwYXJhbSB7Qm9vbGVhbn0gc2hvd0FsZXJ0CVN1cHByZXNzZXMgdGhlIGFsZXJ0IGlmIGZhbHNlLgogKiBAcmV0dXJuIHtCcnVzaH0JCQkJUmV0dXJucyBidXJzaCBjb25zdHJ1Y3RvciBpZiBmb3VuZCwgbnVsbCBvdGhlcndpc2UuCiAqLwpmdW5jdGlvbiBmaW5kQnJ1c2goYWxpYXMsIHNob3dBbGVydCkKewoJdmFyIGJydXNoZXMgPSBzaC52YXJzLmRpc2NvdmVyZWRCcnVzaGVzLAoJCXJlc3VsdCA9IG51bGwKCQk7CgkKCWlmIChicnVzaGVzID09IG51bGwpIAoJewoJCWJydXNoZXMgPSB7fTsKCQkKCQkvLyBGaW5kIGFsbCBicnVzaGVzCgkJZm9yICh2YXIgYnJ1c2ggaW4gc2guYnJ1c2hlcykgCgkJewoJCQl2YXIgaW5mbyA9IHNoLmJydXNoZXNbYnJ1c2hdLAoJCQkJYWxpYXNlcyA9IGluZm8uYWxpYXNlcwoJCQkJOwoJCQkKCQkJaWYgKGFsaWFzZXMgPT0gbnVsbCkgCgkJCQljb250aW51ZTsKCQkJCgkJCS8vIGtlZXAgdGhlIGJydXNoIG5hbWUKCQkJaW5mby5icnVzaE5hbWUgPSBicnVzaC50b0xvd2VyQ2FzZSgpOwoJCQkKCQkJZm9yICh2YXIgaSA9IDA7IGkgPCBhbGlhc2VzLmxlbmd0aDsgaSsrKSAKCQkJCWJydXNoZXNbYWxpYXNlc1tpXV0gPSBicnVzaDsKCQl9CgkJCgkJc2gudmFycy5kaXNjb3ZlcmVkQnJ1c2hlcyA9IGJydXNoZXM7Cgl9CgkKCXJlc3VsdCA9IHNoLmJydXNoZXNbYnJ1c2hlc1thbGlhc11dOwoKCWlmIChyZXN1bHQgPT0gbnVsbCAmJiBzaG93QWxlcnQpCgkJYWxlcnQoc2guY29uZmlnLnN0cmluZ3Mubm9CcnVzaCArIGFsaWFzKTsKCQoJcmV0dXJuIHJlc3VsdDsKfTsKCi8qKgogKiBFeGVjdXRlcyBhIGNhbGxiYWNrIG9uIGVhY2ggbGluZSBhbmQgcmVwbGFjZXMgZWFjaCBsaW5lIHdpdGggcmVzdWx0IGZyb20gdGhlIGNhbGxiYWNrLgogKiBAcGFyYW0ge09iamVjdH0gc3RyCQkJSW5wdXQgc3RyaW5nLgogKiBAcGFyYW0ge09iamVjdH0gY2FsbGJhY2sJCUNhbGxiYWNrIGZ1bmN0aW9uIHRha2luZyBvbmUgc3RyaW5nIGFyZ3VtZW50IGFuZCByZXR1cm5pbmcgYSBzdHJpbmcuCiAqLwpmdW5jdGlvbiBlYWNoTGluZShzdHIsIGNhbGxiYWNrKQp7Cgl2YXIgbGluZXMgPSBzcGxpdExpbmVzKHN0cik7CgkKCWZvciAodmFyIGkgPSAwOyBpIDwgbGluZXMubGVuZ3RoOyBpKyspCgkJbGluZXNbaV0gPSBjYWxsYmFjayhsaW5lc1tpXSwgaSk7CgkJCgkvLyBpbmNsdWRlIFxyIHRvIGVuYWJsZSBjb3B5LXBhc3RlIG9uIHdpbmRvd3MgKGllOCkgd2l0aG91dCBnZXR0aW5nIGV2ZXJ5dGhpbmcgb24gb25lIGxpbmUKCXJldHVybiBsaW5lcy5qb2luKCdcclxuJyk7Cn07CgovKioKICogVGhpcyBpcyBhIHNwZWNpYWwgdHJpbSB3aGljaCBvbmx5IHJlbW92ZXMgZmlyc3QgYW5kIGxhc3QgZW1wdHkgbGluZXMKICogYW5kIGRvZXNuJ3QgYWZmZWN0IHZhbGlkIGxlYWRpbmcgc3BhY2Ugb24gdGhlIGZpcnN0IGxpbmUuCiAqIAogKiBAcGFyYW0ge1N0cmluZ30gc3RyICAgSW5wdXQgc3RyaW5nCiAqIEByZXR1cm4ge1N0cmluZ30gICAgICBSZXR1cm5zIHN0cmluZyB3aXRob3V0IGVtcHR5IGZpcnN0IGFuZCBsYXN0IGxpbmVzLgogKi8KZnVuY3Rpb24gdHJpbUZpcnN0QW5kTGFzdExpbmVzKHN0cikKewoJcmV0dXJuIHN0ci5yZXBsYWNlKC9eWyBdKltcbl0rfFtcbl0qWyBdKiQvZywgJycpOwp9OwoKLyoqCiAqIFBhcnNlcyBrZXkvdmFsdWUgcGFpcnMgaW50byBoYXNoIG9iamVjdC4KICogCiAqIFVuZGVyc3RhbmRzIHRoZSBmb2xsb3dpbmcgZm9ybWF0czoKICogLSBuYW1lOiB3b3JkOwogKiAtIG5hbWU6IFt3b3JkLCB3b3JkXTsKICogLSBuYW1lOiAic3RyaW5nIjsKICogLSBuYW1lOiAnc3RyaW5nJzsKICogCiAqIEZvciBleGFtcGxlOgogKiAgIG5hbWUxOiB2YWx1ZTsgbmFtZTI6IFt2YWx1ZSwgdmFsdWVdOyBuYW1lMzogJ3ZhbHVlJwogKiAgIAogKiBAcGFyYW0ge1N0cmluZ30gc3RyICAgIElucHV0IHN0cmluZy4KICogQHJldHVybiB7T2JqZWN0fSAgICAgICBSZXR1cm5zIGRlc2VyaWFsaXplZCBvYmplY3QuCiAqLwpmdW5jdGlvbiBwYXJzZVBhcmFtcyhzdHIpCnsKCXZhciBtYXRjaCwgCgkJcmVzdWx0ID0ge30sCgkJYXJyYXlSZWdleCA9IG5ldyBYUmVnRXhwKCJeXFxbKD88dmFsdWVzPiguKj8pKVxcXSQiKSwKCQlyZWdleCA9IG5ldyBYUmVnRXhwKAoJCQkiKD88bmFtZT5bXFx3LV0rKSIgKwoJCQkiXFxzKjpcXHMqIiArCgkJCSIoPzx2YWx1ZT4iICsKCQkJCSJbXFx3LSUjXSt8IiArCQkvLyB3b3JkCgkJCQkiXFxbLio/XFxdfCIgKwkJLy8gW10gYXJyYXkKCQkJCSciLio/InwnICsJCQkvLyAiIiBzdHJpbmcKCQkJCSInLio/JyIgKwkJCS8vICcnIHN0cmluZwoJCQkiKVxccyo7PyIsCgkJCSJnIgoJCSkKCQk7CgoJd2hpbGUgKChtYXRjaCA9IHJlZ2V4LmV4ZWMoc3RyKSkgIT0gbnVsbCkgCgl7CgkJdmFyIHZhbHVlID0gbWF0Y2gudmFsdWUKCQkJLnJlcGxhY2UoL15bJyJdfFsnIl0kL2csICcnKSAvLyBzdHJpcCBxdW90ZXMgZnJvbSBlbmQgb2Ygc3RyaW5ncwoJCQk7CgkJCgkJLy8gdHJ5IHRvIHBhcnNlIGFycmF5IHZhbHVlCgkJaWYgKHZhbHVlICE9IG51bGwgJiYgYXJyYXlSZWdleC50ZXN0KHZhbHVlKSkKCQl7CgkJCXZhciBtID0gYXJyYXlSZWdleC5leGVjKHZhbHVlKTsKCQkJdmFsdWUgPSBtLnZhbHVlcy5sZW5ndGggPiAwID8gbS52YWx1ZXMuc3BsaXQoL1xzKixccyovKSA6IFtdOwoJCX0KCQkKCQlyZXN1bHRbbWF0Y2gubmFtZV0gPSB2YWx1ZTsKCX0KCQoJcmV0dXJuIHJlc3VsdDsKfTsKCi8qKgogKiBXcmFwcyBlYWNoIGxpbmUgb2YgdGhlIHN0cmluZyBpbnRvIDxjb2RlLz4gdGFnIHdpdGggZ2l2ZW4gc3R5bGUgYXBwbGllZCB0byBpdC4KICogCiAqIEBwYXJhbSB7U3RyaW5nfSBzdHIgICBJbnB1dCBzdHJpbmcuCiAqIEBwYXJhbSB7U3RyaW5nfSBjc3MgICBTdHlsZSBuYW1lIHRvIGFwcGx5IHRvIHRoZSBzdHJpbmcuCiAqIEByZXR1cm4ge1N0cmluZ30gICAgICBSZXR1cm5zIGlucHV0IHN0cmluZyB3aXRoIGVhY2ggbGluZSBzdXJyb3VuZGVkIGJ5IDxzcGFuLz4gdGFnLgogKi8KZnVuY3Rpb24gd3JhcExpbmVzV2l0aENvZGUoc3RyLCBjc3MpCnsKCWlmIChzdHIgPT0gbnVsbCB8fCBzdHIubGVuZ3RoID09IDAgfHwgc3RyID09ICdcbicpIAoJCXJldHVybiBzdHI7CgoJc3RyID0gc3RyLnJlcGxhY2UoLzwvZywgJyZsdDsnKTsKCgkvLyBSZXBsYWNlIHR3byBvciBtb3JlIHNlcXVlbnRpYWwgc3BhY2VzIHdpdGggJm5ic3A7IGxlYXZpbmcgbGFzdCBzcGFjZSB1bnRvdWNoZWQuCglzdHIgPSBzdHIucmVwbGFjZSgvIHsyLH0vZywgZnVuY3Rpb24obSkKCXsKCQl2YXIgc3BhY2VzID0gJyc7CgkJCgkJZm9yICh2YXIgaSA9IDA7IGkgPCBtLmxlbmd0aCAtIDE7IGkrKykKCQkJc3BhY2VzICs9IHNoLmNvbmZpZy5zcGFjZTsKCQkKCQlyZXR1cm4gc3BhY2VzICsgJyAnOwoJfSk7CgoJLy8gU3BsaXQgZWFjaCBsaW5lIGFuZCBhcHBseSA8c3BhbiBjbGFzcz0iLi4uIj4uLi48L3NwYW4%2BIHRvIHRoZW0gc28gdGhhdAoJLy8gbGVhZGluZyBzcGFjZXMgYXJlbid0IGluY2x1ZGVkLgoJaWYgKGNzcyAhPSBudWxsKSAKCQlzdHIgPSBlYWNoTGluZShzdHIsIGZ1bmN0aW9uKGxpbmUpCgkJewoJCQlpZiAobGluZS5sZW5ndGggPT0gMCkgCgkJCQlyZXR1cm4gJyc7CgkJCQoJCQl2YXIgc3BhY2VzID0gJyc7CgkJCQoJCQlsaW5lID0gbGluZS5yZXBsYWNlKC9eKCZuYnNwO3wgKSsvLCBmdW5jdGlvbihzKQoJCQl7CgkJCQlzcGFjZXMgPSBzOwoJCQkJcmV0dXJuICcnOwoJCQl9KTsKCQkJCgkJCWlmIChsaW5lLmxlbmd0aCA9PSAwKSAKCQkJCXJldHVybiBzcGFjZXM7CgkJCQoJCQlyZXR1cm4gc3BhY2VzICsgJzxjb2RlIGNsYXNzPSInICsgY3NzICsgJyI%2BJyArIGxpbmUgKyAnPC9jb2RlPic7CgkJfSk7CgoJcmV0dXJuIHN0cjsKfTsKCi8qKgogKiBQYWRzIG51bWJlciB3aXRoIHplcm9zIHVudGlsIGl0J3MgbGVuZ3RoIGlzIHRoZSBzYW1lIGFzIGdpdmVuIGxlbmd0aC4KICogCiAqIEBwYXJhbSB7TnVtYmVyfSBudW1iZXIJTnVtYmVyIHRvIHBhZC4KICogQHBhcmFtIHtOdW1iZXJ9IGxlbmd0aAlNYXggc3RyaW5nIGxlbmd0aCB3aXRoLgogKiBAcmV0dXJuIHtTdHJpbmd9CQkJUmV0dXJucyBhIHN0cmluZyBwYWRkZWQgd2l0aCBwcm9wZXIgYW1vdW50IG9mICcwJy4KICovCmZ1bmN0aW9uIHBhZE51bWJlcihudW1iZXIsIGxlbmd0aCkKewoJdmFyIHJlc3VsdCA9IG51bWJlci50b1N0cmluZygpOwoJCgl3aGlsZSAocmVzdWx0Lmxlbmd0aCA8IGxlbmd0aCkKCQlyZXN1bHQgPSAnMCcgKyByZXN1bHQ7CgkKCXJldHVybiByZXN1bHQ7Cn07CgovKioKICogUmVwbGFjZXMgdGFicyB3aXRoIHNwYWNlcy4KICogCiAqIEBwYXJhbSB7U3RyaW5nfSBjb2RlCQlTb3VyY2UgY29kZS4KICogQHBhcmFtIHtOdW1iZXJ9IHRhYlNpemUJU2l6ZSBvZiB0aGUgdGFiLgogKiBAcmV0dXJuIHtTdHJpbmd9CQkJUmV0dXJucyBjb2RlIHdpdGggYWxsIHRhYnMgcmVwbGFjZXMgYnkgc3BhY2VzLgogKi8KZnVuY3Rpb24gcHJvY2Vzc1RhYnMoY29kZSwgdGFiU2l6ZSkKewoJdmFyIHRhYiA9ICcnOwoJCglmb3IgKHZhciBpID0gMDsgaSA8IHRhYlNpemU7IGkrKykKCQl0YWIgKz0gJyAnOwoKCXJldHVybiBjb2RlLnJlcGxhY2UoL1x0L2csIHRhYik7Cn07CgovKioKICogUmVwbGFjZXMgdGFicyB3aXRoIHNtYXJ0IHNwYWNlcy4KICogCiAqIEBwYXJhbSB7U3RyaW5nfSBjb2RlICAgIENvZGUgdG8gZml4IHRoZSB0YWJzIGluLgogKiBAcGFyYW0ge051bWJlcn0gdGFiU2l6ZSBOdW1iZXIgb2Ygc3BhY2VzIGluIGEgY29sdW1uLgogKiBAcmV0dXJuIHtTdHJpbmd9ICAgICAgICBSZXR1cm5zIGNvZGUgd2l0aCBhbGwgdGFicyByZXBsYWNlcyB3aXRoIHJvcGVyIGFtb3VudCBvZiBzcGFjZXMuCiAqLwpmdW5jdGlvbiBwcm9jZXNzU21hcnRUYWJzKGNvZGUsIHRhYlNpemUpCnsKCXZhciBsaW5lcyA9IHNwbGl0TGluZXMoY29kZSksCgkJdGFiID0gJ1x0JywKCQlzcGFjZXMgPSAnJwoJCTsKCQoJLy8gQ3JlYXRlIGEgc3RyaW5nIHdpdGggMTAwMCBzcGFjZXMgdG8gY29weSBzcGFjZXMgZnJvbS4uLiAKCS8vIEl0J3MgYXNzdW1lZCB0aGF0IHRoZXJlIHdvdWxkIGJlIG5vIGluZGVudGF0aW9uIGxvbmdlciB0aGFuIHRoYXQuCglmb3IgKHZhciBpID0gMDsgaSA8IDUwOyBpKyspIAoJCXNwYWNlcyArPSAnICAgICAgICAgICAgICAgICAgICAnOyAvLyAyMCBzcGFjZXMgKiA1MAoJCQkKCS8vIFRoaXMgZnVuY3Rpb24gaW5zZXJ0cyBzcGVjaWZpZWQgYW1vdW50IG9mIHNwYWNlcyBpbiB0aGUgc3RyaW5nCgkvLyB3aGVyZSBhIHRhYiBpcyB3aGlsZSByZW1vdmluZyB0aGF0IGdpdmVuIHRhYi4KCWZ1bmN0aW9uIGluc2VydFNwYWNlcyhsaW5lLCBwb3MsIGNvdW50KQoJewoJCXJldHVybiBsaW5lLnN1YnN0cigwLCBwb3MpCgkJCSsgc3BhY2VzLnN1YnN0cigwLCBjb3VudCkKCQkJKyBsaW5lLnN1YnN0cihwb3MgKyAxLCBsaW5lLmxlbmd0aCkgLy8gcG9zICsgMSB3aWxsIGdldCByaWQgb2YgdGhlIHRhYgoJCQk7Cgl9OwoKCS8vIEdvIHRocm91Z2ggYWxsIHRoZSBsaW5lcyBhbmQgZG8gdGhlICdzbWFydCB0YWJzJyBtYWdpYy4KCWNvZGUgPSBlYWNoTGluZShjb2RlLCBmdW5jdGlvbihsaW5lKQoJewoJCWlmIChsaW5lLmluZGV4T2YodGFiKSA9PSAtMSkgCgkJCXJldHVybiBsaW5lOwoJCQoJCXZhciBwb3MgPSAwOwoJCQoJCXdoaWxlICgocG9zID0gbGluZS5pbmRleE9mKHRhYikpICE9IC0xKSAKCQl7CgkJCS8vIFRoaXMgaXMgcHJldHR5IG11Y2ggYWxsIHRoZXJlIGlzIHRvIHRoZSAnc21hcnQgdGFicycgbG9naWMuCgkJCS8vIEJhc2VkIG9uIHRoZSBwb3NpdGlvbiB3aXRoaW4gdGhlIGxpbmUgYW5kIHNpemUgb2YgYSB0YWIsCgkJCS8vIGNhbGN1bGF0ZSB0aGUgYW1vdW50IG9mIHNwYWNlcyB3ZSBuZWVkIHRvIGluc2VydC4KCQkJdmFyIHNwYWNlcyA9IHRhYlNpemUgLSBwb3MgJSB0YWJTaXplOwoJCQlsaW5lID0gaW5zZXJ0U3BhY2VzKGxpbmUsIHBvcywgc3BhY2VzKTsKCQl9CgkJCgkJcmV0dXJuIGxpbmU7Cgl9KTsKCQoJcmV0dXJuIGNvZGU7Cn07CgovKioKICogUGVyZm9ybXMgdmFyaW91cyBzdHJpbmcgZml4ZXMgYmFzZWQgb24gY29uZmlndXJhdGlvbi4KICovCmZ1bmN0aW9uIGZpeElucHV0U3RyaW5nKHN0cikKewoJdmFyIGJyID0gLzxiclxzKlwvPz58Jmx0O2JyXHMqXC8/Jmd0Oy9naTsKCQoJaWYgKHNoLmNvbmZpZy5ibG9nZ2VyTW9kZSA9PSB0cnVlKQoJCXN0ciA9IHN0ci5yZXBsYWNlKGJyLCAnXG4nKTsKCglpZiAoc2guY29uZmlnLnN0cmlwQnJzID09IHRydWUpCgkJc3RyID0gc3RyLnJlcGxhY2UoYnIsICcnKTsKCQkKCXJldHVybiBzdHI7Cn07CgovKioKICogUmVtb3ZlcyBhbGwgd2hpdGUgc3BhY2UgYXQgdGhlIGJlZ2lubmluZyBhbmQgZW5kIG9mIGEgc3RyaW5nLgogKiAKICogQHBhcmFtIHtTdHJpbmd9IHN0ciAgIFN0cmluZyB0byB0cmltLgogKiBAcmV0dXJuIHtTdHJpbmd9ICAgICAgUmV0dXJucyBzdHJpbmcgd2l0aG91dCBsZWFkaW5nIGFuZCBmb2xsb3dpbmcgd2hpdGUgc3BhY2UgY2hhcmFjdGVycy4KICovCmZ1bmN0aW9uIHRyaW0oc3RyKQp7CglyZXR1cm4gc3RyLnJlcGxhY2UoL15ccyt8XHMrJC9nLCAnJyk7Cn07CgovKioKICogVW5pbmRlbnRzIGEgYmxvY2sgb2YgdGV4dCBieSB0aGUgbG93ZXN0IGNvbW1vbiBpbmRlbnQgYW1vdW50LgogKiBAcGFyYW0ge1N0cmluZ30gc3RyICAgVGV4dCB0byB1bmluZGVudC4KICogQHJldHVybiB7U3RyaW5nfSAgICAgIFJldHVybnMgdW5pbmRlbnRlZCB0ZXh0IGJsb2NrLgogKi8KZnVuY3Rpb24gdW5pbmRlbnQoc3RyKQp7Cgl2YXIgbGluZXMgPSBzcGxpdExpbmVzKGZpeElucHV0U3RyaW5nKHN0cikpLAoJCWluZGVudHMgPSBuZXcgQXJyYXkoKSwKCQlyZWdleCA9IC9eXHMqLywKCQltaW4gPSAxMDAwCgkJOwoJCgkvLyBnbyB0aHJvdWdoIGV2ZXJ5IGxpbmUgYW5kIGNoZWNrIGZvciBjb21tb24gbnVtYmVyIG9mIGluZGVudHMKCWZvciAodmFyIGkgPSAwOyBpIDwgbGluZXMubGVuZ3RoICYmIG1pbiA%2BIDA7IGkrKykgCgl7CgkJdmFyIGxpbmUgPSBsaW5lc1tpXTsKCQkKCQlpZiAodHJpbShsaW5lKS5sZW5ndGggPT0gMCkgCgkJCWNvbnRpbnVlOwoJCQoJCXZhciBtYXRjaGVzID0gcmVnZXguZXhlYyhsaW5lKTsKCQkKCQkvLyBJbiB0aGUgZXZlbnQgdGhhdCBqdXN0IG9uZSBsaW5lIGRvZXNuJ3QgaGF2ZSBsZWFkaW5nIHdoaXRlIHNwYWNlCgkJLy8gd2UgY2FuJ3QgdW5pbmRlbnQgYW55dGhpbmcsIHNvIGJhaWwgY29tcGxldGVseS4KCQlpZiAobWF0Y2hlcyA9PSBudWxsKSAKCQkJcmV0dXJuIHN0cjsKCQkJCgkJbWluID0gTWF0aC5taW4obWF0Y2hlc1swXS5sZW5ndGgsIG1pbik7Cgl9CgkKCS8vIHRyaW0gbWluaW11bSBjb21tb24gbnVtYmVyIG9mIHdoaXRlIHNwYWNlIGZyb20gdGhlIGJlZ2lubmluZyBvZiBldmVyeSBsaW5lCglpZiAobWluID4gMCkgCgkJZm9yICh2YXIgaSA9IDA7IGkgPCBsaW5lcy5sZW5ndGg7IGkrKykgCgkJCWxpbmVzW2ldID0gbGluZXNbaV0uc3Vic3RyKG1pbik7CgkKCXJldHVybiBsaW5lcy5qb2luKCdcbicpOwp9OwoKLyoqCiAqIENhbGxiYWNrIG1ldGhvZCBmb3IgQXJyYXkuc29ydCgpIHdoaWNoIHNvcnRzIG1hdGNoZXMgYnkKICogaW5kZXggcG9zaXRpb24gYW5kIHRoZW4gYnkgbGVuZ3RoLgogKiAKICogQHBhcmFtIHtNYXRjaH0gbTEJTGVmdCBvYmplY3QuCiAqIEBwYXJhbSB7TWF0Y2h9IG0yICAgIFJpZ2h0IG9iamVjdC4KICogQHJldHVybiB7TnVtYmVyfSAgICAgUmV0dXJucyAtMSwgMCBvciAtMSBhcyBhIGNvbXBhcmlzb24gcmVzdWx0LgogKi8KZnVuY3Rpb24gbWF0Y2hlc1NvcnRDYWxsYmFjayhtMSwgbTIpCnsKCS8vIHNvcnQgbWF0Y2hlcyBieSBpbmRleCBmaXJzdAoJaWYobTEuaW5kZXggPCBtMi5pbmRleCkKCQlyZXR1cm4gLTE7CgllbHNlIGlmKG0xLmluZGV4ID4gbTIuaW5kZXgpCgkJcmV0dXJuIDE7CgllbHNlCgl7CgkJLy8gaWYgaW5kZXggaXMgdGhlIHNhbWUsIHNvcnQgYnkgbGVuZ3RoCgkJaWYobTEubGVuZ3RoIDwgbTIubGVuZ3RoKQoJCQlyZXR1cm4gLTE7CgkJZWxzZSBpZihtMS5sZW5ndGggPiBtMi5sZW5ndGgpCgkJCXJldHVybiAxOwoJfQoJCglyZXR1cm4gMDsKfTsKCi8qKgogKiBFeGVjdXRlcyBnaXZlbiByZWd1bGFyIGV4cHJlc3Npb24gb24gcHJvdmlkZWQgY29kZSBhbmQgcmV0dXJucyBhbGwKICogbWF0Y2hlcyB0aGF0IGFyZSBmb3VuZC4KICogCiAqIEBwYXJhbSB7U3RyaW5nfSBjb2RlICAgIENvZGUgdG8gZXhlY3V0ZSByZWd1bGFyIGV4cHJlc3Npb24gb24uCiAqIEBwYXJhbSB7T2JqZWN0fSByZWdleCAgIFJlZ3VsYXIgZXhwcmVzc2lvbiBpdGVtIGluZm8gZnJvbSA8Y29kZT5yZWdleExpc3Q8L2NvZGU%2BIGNvbGxlY3Rpb24uCiAqIEByZXR1cm4ge0FycmF5fSAgICAgICAgIFJldHVybnMgYSBsaXN0IG9mIE1hdGNoIG9iamVjdHMuCiAqLyAKZnVuY3Rpb24gZ2V0TWF0Y2hlcyhjb2RlLCByZWdleEluZm8pCnsKCWZ1bmN0aW9uIGRlZmF1bHRBZGQobWF0Y2gsIHJlZ2V4SW5mbykKCXsKCQlyZXR1cm4gbWF0Y2hbMF07Cgl9OwoJCgl2YXIgaW5kZXggPSAwLAoJCW1hdGNoID0gbnVsbCwKCQltYXRjaGVzID0gW10sCgkJZnVuYyA9IHJlZ2V4SW5mby5mdW5jID8gcmVnZXhJbmZvLmZ1bmMgOiBkZWZhdWx0QWRkCgkJOwoJCgl3aGlsZSgobWF0Y2ggPSByZWdleEluZm8ucmVnZXguZXhlYyhjb2RlKSkgIT0gbnVsbCkKCXsKCQl2YXIgcmVzdWx0TWF0Y2ggPSBmdW5jKG1hdGNoLCByZWdleEluZm8pOwoJCQoJCWlmICh0eXBlb2YocmVzdWx0TWF0Y2gpID09ICdzdHJpbmcnKQoJCQlyZXN1bHRNYXRjaCA9IFtuZXcgc2guTWF0Y2gocmVzdWx0TWF0Y2gsIG1hdGNoLmluZGV4LCByZWdleEluZm8uY3NzKV07CgoJCW1hdGNoZXMgPSBtYXRjaGVzLmNvbmNhdChyZXN1bHRNYXRjaCk7Cgl9CgkKCXJldHVybiBtYXRjaGVzOwp9OwoKLyoqCiAqIFR1cm5zIGFsbCBVUkxzIGluIHRoZSBjb2RlIGludG8gPGEvPiB0YWdzLgogKiBAcGFyYW0ge1N0cmluZ30gY29kZSBJbnB1dCBjb2RlLgogKiBAcmV0dXJuIHtTdHJpbmd9IFJldHVybnMgY29kZSB3aXRoIDwvYT4gdGFncy4KICovCmZ1bmN0aW9uIHByb2Nlc3NVcmxzKGNvZGUpCnsKCXZhciBndCA9IC8oLiopKCgmZ3Q7fCZsdDspLiopLzsKCQoJcmV0dXJuIGNvZGUucmVwbGFjZShzaC5yZWdleExpYi51cmwsIGZ1bmN0aW9uKG0pCgl7CgkJdmFyIHN1ZmZpeCA9ICcnLAoJCQltYXRjaCA9IG51bGwKCQkJOwoJCQoJCS8vIFdlIGluY2x1ZGUgJmx0OyBhbmQgJmd0OyBpbiB0aGUgVVJMIGZvciB0aGUgY29tbW9uIGNhc2VzIGxpa2UgPGh0dHA6Ly9nb29nbGUuY29tPgoJCS8vIFRoZSBwcm9ibGVtIGlzIHRoYXQgdGhleSBnZXQgdHJhbnNmb3JtZWQgaW50byAmbHQ7aHR0cDovL2dvb2dsZS5jb20mZ3Q7CgkJLy8gV2hlcmUgYXMgJmd0OyBlYXNpbHkgbG9va3MgbGlrZSBwYXJ0IG9mIHRoZSBVUkwgc3RyaW5nLgoJCgkJaWYgKG1hdGNoID0gZ3QuZXhlYyhtKSkKCQl7CgkJCW0gPSBtYXRjaFsxXTsKCQkJc3VmZml4ID0gbWF0Y2hbMl07CgkJfQoJCQoJCXJldHVybiAnPGEgaHJlZj0iJyArIG0gKyAnIj4nICsgbSArICc8L2E%2BJyArIHN1ZmZpeDsKCX0pOwp9OwoKLyoqCiAqIEZpbmRzIGFsbCA8U0NSSVBUIFRZUEU9InN5bnRheGhpZ2hsaWdodGVyIiAvPiBlbGVtZW50c3MuCiAqIEByZXR1cm4ge0FycmF5fSBSZXR1cm5zIGFycmF5IG9mIGFsbCBmb3VuZCBTeW50YXhIaWdobGlnaHRlciB0YWdzLgogKi8KZnVuY3Rpb24gZ2V0U3ludGF4SGlnaGxpZ2h0ZXJTY3JpcHRUYWdzKCkKewoJdmFyIHRhZ3MgPSBkb2N1bWVudC5nZXRFbGVtZW50c0J5VGFnTmFtZSgnc2NyaXB0JyksCgkJcmVzdWx0ID0gW10KCQk7CgkKCWZvciAodmFyIGkgPSAwOyBpIDwgdGFncy5sZW5ndGg7IGkrKykKCQlpZiAodGFnc1tpXS50eXBlID09ICdzeW50YXhoaWdobGlnaHRlcicpCgkJCXJlc3VsdC5wdXNoKHRhZ3NbaV0pOwoJCQkKCXJldHVybiByZXN1bHQ7Cn07CgovKioKICogU3RyaXBzIDwhW0NEQVRBW11dPiBmcm9tIDxTQ1JJUFQgLz4gY29udGVudCBiZWNhdXNlIGl0IHNob3VsZCBiZSB1c2VkCiAqIHRoZXJlIGluIG1vc3QgY2FzZXMgZm9yIFhIVE1MIGNvbXBsaWFuY2UuCiAqIEBwYXJhbSB7U3RyaW5nfSBvcmlnaW5hbAlJbnB1dCBjb2RlLgogKiBAcmV0dXJuIHtTdHJpbmd9IFJldHVybnMgY29kZSB3aXRob3V0IGxlYWRpbmcgPCFbQ0RBVEFbXV0%2BIHRhZ3MuCiAqLwpmdW5jdGlvbiBzdHJpcENEYXRhKG9yaWdpbmFsKQp7Cgl2YXIgbGVmdCA9ICc8IVtDREFUQVsnLAoJCXJpZ2h0ID0gJ11dPicsCgkJLy8gZm9yIHNvbWUgcmVhc29uIElFIGluc2VydHMgc29tZSBsZWFkaW5nIGJsYW5rcyBoZXJlCgkJY29weSA9IHRyaW0ob3JpZ2luYWwpLAoJCWNoYW5nZWQgPSBmYWxzZSwKCQlsZWZ0TGVuZ3RoID0gbGVmdC5sZW5ndGgsCgkJcmlnaHRMZW5ndGggPSByaWdodC5sZW5ndGgKCQk7CgkKCWlmIChjb3B5LmluZGV4T2YobGVmdCkgPT0gMCkKCXsKCQljb3B5ID0gY29weS5zdWJzdHJpbmcobGVmdExlbmd0aCk7CgkJY2hhbmdlZCA9IHRydWU7Cgl9CgkKCXZhciBjb3B5TGVuZ3RoID0gY29weS5sZW5ndGg7CgkKCWlmIChjb3B5LmluZGV4T2YocmlnaHQpID09IGNvcHlMZW5ndGggLSByaWdodExlbmd0aCkKCXsKCQljb3B5ID0gY29weS5zdWJzdHJpbmcoMCwgY29weUxlbmd0aCAtIHJpZ2h0TGVuZ3RoKTsKCQljaGFuZ2VkID0gdHJ1ZTsKCX0KCQoJcmV0dXJuIGNoYW5nZWQgPyBjb3B5IDogb3JpZ2luYWw7Cn07CgoKLyoqCiAqIFF1aWNrIGNvZGUgbW91c2UgZG91YmxlIGNsaWNrIGhhbmRsZXIuCiAqLwpmdW5jdGlvbiBxdWlja0NvZGVIYW5kbGVyKGUpCnsKCXZhciB0YXJnZXQgPSBlLnRhcmdldCwKCQloaWdobGlnaHRlckRpdiA9IGZpbmRQYXJlbnRFbGVtZW50KHRhcmdldCwgJy5zeW50YXhoaWdobGlnaHRlcicpLAoJCWNvbnRhaW5lciA9IGZpbmRQYXJlbnRFbGVtZW50KHRhcmdldCwgJy5jb250YWluZXInKSwKCQl0ZXh0YXJlYSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3RleHRhcmVhJyksCgkJaGlnaGxpZ2h0ZXIKCQk7CgoJaWYgKCFjb250YWluZXIgfHwgIWhpZ2hsaWdodGVyRGl2IHx8IGZpbmRFbGVtZW50KGNvbnRhaW5lciwgJ3RleHRhcmVhJykpCgkJcmV0dXJuOwoKCWhpZ2hsaWdodGVyID0gZ2V0SGlnaGxpZ2h0ZXJCeUlkKGhpZ2hsaWdodGVyRGl2LmlkKTsKCQoJLy8gYWRkIHNvdXJjZSBjbGFzcyBuYW1lCglhZGRDbGFzcyhoaWdobGlnaHRlckRpdiwgJ3NvdXJjZScpOwoKCS8vIEhhdmUgdG8gZ28gb3ZlciBlYWNoIGxpbmUgYW5kIGdyYWIgaXQncyB0ZXh0LCBjYW4ndCBqdXN0IGRvIGl0IG9uIHRoZQoJLy8gY29udGFpbmVyIGJlY2F1c2UgRmlyZWZveCBsb3NlcyBhbGwgXG4gd2hlcmUgYXMgV2Via2l0IGRvZXNuJ3QuCgl2YXIgbGluZXMgPSBjb250YWluZXIuY2hpbGROb2RlcywKCQljb2RlID0gW10KCQk7CgkKCWZvciAodmFyIGkgPSAwOyBpIDwgbGluZXMubGVuZ3RoOyBpKyspCgkJY29kZS5wdXNoKGxpbmVzW2ldLmlubmVyVGV4dCB8fCBsaW5lc1tpXS50ZXh0Q29udGVudCk7CgkKCS8vIHVzaW5nIFxyIGluc3RlYWQgb2YgXHIgb3IgXHJcbiBtYWtlcyB0aGlzIHdvcmsgZXF1YWxseSB3ZWxsIG9uIElFLCBGRiBhbmQgV2Via2l0Cgljb2RlID0gY29kZS5qb2luKCdccicpOwoKICAgIC8vIEZvciBXZWJraXQgYnJvd3NlcnMsIHJlcGxhY2UgbmJzcCB3aXRoIGEgYnJlYWtpbmcgc3BhY2UKICAgIGNvZGUgPSBjb2RlLnJlcGxhY2UoL1x1MDBhMC9nLCAiICIpOwoJCgkvLyBpbmplY3QgPHRleHRhcmVhLz4gdGFnCgl0ZXh0YXJlYS5hcHBlbmRDaGlsZChkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZShjb2RlKSk7Cgljb250YWluZXIuYXBwZW5kQ2hpbGQodGV4dGFyZWEpOwoJCgkvLyBwcmVzZWxlY3QgYWxsIHRleHQKCXRleHRhcmVhLmZvY3VzKCk7Cgl0ZXh0YXJlYS5zZWxlY3QoKTsKCQoJLy8gc2V0IHVwIGhhbmRsZXIgZm9yIGxvc3QgZm9jdXMKCWF0dGFjaEV2ZW50KHRleHRhcmVhLCAnYmx1cicsIGZ1bmN0aW9uKGUpCgl7CgkJdGV4dGFyZWEucGFyZW50Tm9kZS5yZW1vdmVDaGlsZCh0ZXh0YXJlYSk7CgkJcmVtb3ZlQ2xhc3MoaGlnaGxpZ2h0ZXJEaXYsICdzb3VyY2UnKTsKCX0pOwp9OwoKLyoqCiAqIE1hdGNoIG9iamVjdC4KICovCnNoLk1hdGNoID0gZnVuY3Rpb24odmFsdWUsIGluZGV4LCBjc3MpCnsKCXRoaXMudmFsdWUgPSB2YWx1ZTsKCXRoaXMuaW5kZXggPSBpbmRleDsKCXRoaXMubGVuZ3RoID0gdmFsdWUubGVuZ3RoOwoJdGhpcy5jc3MgPSBjc3M7Cgl0aGlzLmJydXNoTmFtZSA9IG51bGw7Cn07CgpzaC5NYXRjaC5wcm90b3R5cGUudG9TdHJpbmcgPSBmdW5jdGlvbigpCnsKCXJldHVybiB0aGlzLnZhbHVlOwp9OwoKLyoqCiAqIFNpbXVsYXRlcyBIVE1MIGNvZGUgd2l0aCBhIHNjcmlwdGluZyBsYW5ndWFnZSBlbWJlZGRlZC4KICogCiAqIEBwYXJhbSB7U3RyaW5nfSBzY3JpcHRCcnVzaE5hbWUgQnJ1c2ggbmFtZSBvZiB0aGUgc2NyaXB0aW5nIGxhbmd1YWdlLgogKi8Kc2guSHRtbFNjcmlwdCA9IGZ1bmN0aW9uKHNjcmlwdEJydXNoTmFtZSkKewoJdmFyIGJydXNoQ2xhc3MgPSBmaW5kQnJ1c2goc2NyaXB0QnJ1c2hOYW1lKSwKCQlzY3JpcHRCcnVzaCwKCQl4bWxCcnVzaCA9IG5ldyBzaC5icnVzaGVzLlhtbCgpLAoJCWJyYWNrZXRzUmVnZXggPSBudWxsLAoJCXJlZiA9IHRoaXMsCgkJbWV0aG9kc1RvRXhwb3NlID0gJ2dldERpdiBnZXRIdG1sIGluaXQnLnNwbGl0KCcgJykKCQk7CgoJaWYgKGJydXNoQ2xhc3MgPT0gbnVsbCkKCQlyZXR1cm47CgkKCXNjcmlwdEJydXNoID0gbmV3IGJydXNoQ2xhc3MoKTsKCQoJZm9yKHZhciBpID0gMDsgaSA8IG1ldGhvZHNUb0V4cG9zZS5sZW5ndGg7IGkrKykKCQkvLyBtYWtlIGEgY2xvc3VyZSBzbyB3ZSBkb24ndCBsb3NlIHRoZSBuYW1lIGFmdGVyIGkgY2hhbmdlcwoJCShmdW5jdGlvbigpIHsKCQkJdmFyIG5hbWUgPSBtZXRob2RzVG9FeHBvc2VbaV07CgkJCQoJCQlyZWZbbmFtZV0gPSBmdW5jdGlvbigpCgkJCXsKCQkJCXJldHVybiB4bWxCcnVzaFtuYW1lXS5hcHBseSh4bWxCcnVzaCwgYXJndW1lbnRzKTsKCQkJfTsKCQl9KSgpOwoJCglpZiAoc2NyaXB0QnJ1c2guaHRtbFNjcmlwdCA9PSBudWxsKQoJewoJCWFsZXJ0KHNoLmNvbmZpZy5zdHJpbmdzLmJydXNoTm90SHRtbFNjcmlwdCArIHNjcmlwdEJydXNoTmFtZSk7CgkJcmV0dXJuOwoJfQoJCgl4bWxCcnVzaC5yZWdleExpc3QucHVzaCgKCQl7IHJlZ2V4OiBzY3JpcHRCcnVzaC5odG1sU2NyaXB0LmNvZGUsIGZ1bmM6IHByb2Nlc3MgfQoJKTsKCQoJZnVuY3Rpb24gb2Zmc2V0TWF0Y2hlcyhtYXRjaGVzLCBvZmZzZXQpCgl7CgkJZm9yICh2YXIgaiA9IDA7IGogPCBtYXRjaGVzLmxlbmd0aDsgaisrKSAKCQkJbWF0Y2hlc1tqXS5pbmRleCArPSBvZmZzZXQ7Cgl9CgkKCWZ1bmN0aW9uIHByb2Nlc3MobWF0Y2gsIGluZm8pCgl7CgkJdmFyIGNvZGUgPSBtYXRjaC5jb2RlLAoJCQltYXRjaGVzID0gW10sCgkJCXJlZ2V4TGlzdCA9IHNjcmlwdEJydXNoLnJlZ2V4TGlzdCwKCQkJb2Zmc2V0ID0gbWF0Y2guaW5kZXggKyBtYXRjaC5sZWZ0Lmxlbmd0aCwKCQkJaHRtbFNjcmlwdCA9IHNjcmlwdEJydXNoLmh0bWxTY3JpcHQsCgkJCXJlc3VsdAoJCQk7CgoJCS8vIGFkZCBhbGwgbWF0Y2hlcyBmcm9tIHRoZSBjb2RlCgkJZm9yICh2YXIgaSA9IDA7IGkgPCByZWdleExpc3QubGVuZ3RoOyBpKyspCgkJewoJCQlyZXN1bHQgPSBnZXRNYXRjaGVzKGNvZGUsIHJlZ2V4TGlzdFtpXSk7CgkJCW9mZnNldE1hdGNoZXMocmVzdWx0LCBvZmZzZXQpOwoJCQltYXRjaGVzID0gbWF0Y2hlcy5jb25jYXQocmVzdWx0KTsKCQl9CgkJCgkJLy8gYWRkIGxlZnQgc2NyaXB0IGJyYWNrZXQKCQlpZiAoaHRtbFNjcmlwdC5sZWZ0ICE9IG51bGwgJiYgbWF0Y2gubGVmdCAhPSBudWxsKQoJCXsKCQkJcmVzdWx0ID0gZ2V0TWF0Y2hlcyhtYXRjaC5sZWZ0LCBodG1sU2NyaXB0LmxlZnQpOwoJCQlvZmZzZXRNYXRjaGVzKHJlc3VsdCwgbWF0Y2guaW5kZXgpOwoJCQltYXRjaGVzID0gbWF0Y2hlcy5jb25jYXQocmVzdWx0KTsKCQl9CgkJCgkJLy8gYWRkIHJpZ2h0IHNjcmlwdCBicmFja2V0CgkJaWYgKGh0bWxTY3JpcHQucmlnaHQgIT0gbnVsbCAmJiBtYXRjaC5yaWdodCAhPSBudWxsKQoJCXsKCQkJcmVzdWx0ID0gZ2V0TWF0Y2hlcyhtYXRjaC5yaWdodCwgaHRtbFNjcmlwdC5yaWdodCk7CgkJCW9mZnNldE1hdGNoZXMocmVzdWx0LCBtYXRjaC5pbmRleCArIG1hdGNoWzBdLmxhc3RJbmRleE9mKG1hdGNoLnJpZ2h0KSk7CgkJCW1hdGNoZXMgPSBtYXRjaGVzLmNvbmNhdChyZXN1bHQpOwoJCX0KCQkKCQlmb3IgKHZhciBqID0gMDsgaiA8IG1hdGNoZXMubGVuZ3RoOyBqKyspCgkJCW1hdGNoZXNbal0uYnJ1c2hOYW1lID0gYnJ1c2hDbGFzcy5icnVzaE5hbWU7CgkJCQoJCXJldHVybiBtYXRjaGVzOwoJfQp9OwoKLyoqCiAqIE1haW4gSGlnaGxpdGhlciBjbGFzcy4KICogQGNvbnN0cnVjdG9yCiAqLwpzaC5IaWdobGlnaHRlciA9IGZ1bmN0aW9uKCkKewoJLy8gbm90IHB1dHRpbmcgYW55IGNvZGUgaW4gaGVyZSBiZWNhdXNlIG9mIHRoZSBwcm90b3R5cGUgaW5oZXJpdGFuY2UKfTsKCnNoLkhpZ2hsaWdodGVyLnByb3RvdHlwZSA9IHsKCS8qKgoJICogUmV0dXJucyB2YWx1ZSBvZiB0aGUgcGFyYW1ldGVyIHBhc3NlZCB0byB0aGUgaGlnaGxpZ2h0ZXIuCgkgKiBAcGFyYW0ge1N0cmluZ30gbmFtZQkJCQlOYW1lIG9mIHRoZSBwYXJhbWV0ZXIuCgkgKiBAcGFyYW0ge09iamVjdH0gZGVmYXVsdFZhbHVlCQlEZWZhdWx0IHZhbHVlLgoJICogQHJldHVybiB7T2JqZWN0fQkJCQkJUmV0dXJucyBmb3VuZCB2YWx1ZSBvciBkZWZhdWx0IHZhbHVlIG90aGVyd2lzZS4KCSAqLwoJZ2V0UGFyYW06IGZ1bmN0aW9uKG5hbWUsIGRlZmF1bHRWYWx1ZSkKCXsKCQl2YXIgcmVzdWx0ID0gdGhpcy5wYXJhbXNbbmFtZV07CgkJcmV0dXJuIHRvQm9vbGVhbihyZXN1bHQgPT0gbnVsbCA/IGRlZmF1bHRWYWx1ZSA6IHJlc3VsdCk7Cgl9LAoJCgkvKioKCSAqIFNob3J0Y3V0IHRvIGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoKS4KCSAqIEBwYXJhbSB7U3RyaW5nfSBuYW1lCQlOYW1lIG9mIHRoZSBlbGVtZW50IHRvIGNyZWF0ZSAoRElWLCBBLCBldGMpLgoJICogQHJldHVybiB7SFRNTEVsZW1lbnR9CVJldHVybnMgbmV3IEhUTUwgZWxlbWVudC4KCSAqLwoJY3JlYXRlOiBmdW5jdGlvbihuYW1lKQoJewoJCXJldHVybiBkb2N1bWVudC5jcmVhdGVFbGVtZW50KG5hbWUpOwoJfSwKCQoJLyoqCgkgKiBBcHBsaWVzIGFsbCByZWd1bGFyIGV4cHJlc3Npb24gdG8gdGhlIGNvZGUgYW5kIHN0b3JlcyBhbGwgZm91bmQKCSAqIG1hdGNoZXMgaW4gdGhlIGB0aGlzLm1hdGNoZXNgIGFycmF5LgoJICogQHBhcmFtIHtBcnJheX0gcmVnZXhMaXN0CQlMaXN0IG9mIHJlZ3VsYXIgZXhwcmVzc2lvbnMuCgkgKiBAcGFyYW0ge1N0cmluZ30gY29kZQkJCVNvdXJjZSBjb2RlLgoJICogQHJldHVybiB7QXJyYXl9CQkJCVJldHVybnMgbGlzdCBvZiBtYXRjaGVzLgoJICovCglmaW5kTWF0Y2hlczogZnVuY3Rpb24ocmVnZXhMaXN0LCBjb2RlKQoJewoJCXZhciByZXN1bHQgPSBbXTsKCQkKCQlpZiAocmVnZXhMaXN0ICE9IG51bGwpCgkJCWZvciAodmFyIGkgPSAwOyBpIDwgcmVnZXhMaXN0Lmxlbmd0aDsgaSsrKSAKCQkJCS8vIEJVRzogbGVuZ3RoIHJldHVybnMgbGVuKzEgZm9yIGFycmF5IGlmIG1ldGhvZHMgYWRkZWQgdG8gcHJvdG90eXBlIGNoYWluIChvaXNpbmdAZ21haWwuY29tKQoJCQkJaWYgKHR5cGVvZiAocmVnZXhMaXN0W2ldKSA9PSAib2JqZWN0IikKCQkJCQlyZXN1bHQgPSByZXN1bHQuY29uY2F0KGdldE1hdGNoZXMoY29kZSwgcmVnZXhMaXN0W2ldKSk7CgkJCgkJLy8gc29ydCBhbmQgcmVtb3ZlIG5lc3RlZCB0aGUgbWF0Y2hlcwoJCXJldHVybiB0aGlzLnJlbW92ZU5lc3RlZE1hdGNoZXMocmVzdWx0LnNvcnQobWF0Y2hlc1NvcnRDYWxsYmFjaykpOwoJfSwKCQoJLyoqCgkgKiBDaGVja3MgdG8gc2VlIGlmIGFueSBvZiB0aGUgbWF0Y2hlcyBhcmUgaW5zaWRlIG9mIG90aGVyIG1hdGNoZXMuIAoJICogVGhpcyBwcm9jZXNzIHdvdWxkIGdldCByaWQgb2YgaGlnaGxpZ3RlZCBzdHJpbmdzIGluc2lkZSBjb21tZW50cywgCgkgKiBrZXl3b3JkcyBpbnNpZGUgc3RyaW5ncyBhbmQgc28gb24uCgkgKi8KCXJlbW92ZU5lc3RlZE1hdGNoZXM6IGZ1bmN0aW9uKG1hdGNoZXMpCgl7CgkJLy8gT3B0aW1pemVkIGJ5IEpvc2UgUHJhZG8gKGh0dHA6Ly9qb3NlcHJhZG8uY29tKQoJCWZvciAodmFyIGkgPSAwOyBpIDwgbWF0Y2hlcy5sZW5ndGg7IGkrKykgCgkJeyAKCQkJaWYgKG1hdGNoZXNbaV0gPT09IG51bGwpCgkJCQljb250aW51ZTsKCQkJCgkJCXZhciBpdGVtSSA9IG1hdGNoZXNbaV0sCgkJCQlpdGVtSUVuZFBvcyA9IGl0ZW1JLmluZGV4ICsgaXRlbUkubGVuZ3RoCgkJCQk7CgkJCQoJCQlmb3IgKHZhciBqID0gaSArIDE7IGogPCBtYXRjaGVzLmxlbmd0aCAmJiBtYXRjaGVzW2ldICE9PSBudWxsOyBqKyspIAoJCQl7CgkJCQl2YXIgaXRlbUogPSBtYXRjaGVzW2pdOwoJCQkJCgkJCQlpZiAoaXRlbUogPT09IG51bGwpIAoJCQkJCWNvbnRpbnVlOwoJCQkJZWxzZSBpZiAoaXRlbUouaW5kZXggPiBpdGVtSUVuZFBvcykgCgkJCQkJYnJlYWs7CgkJCQllbHNlIGlmIChpdGVtSi5pbmRleCA9PSBpdGVtSS5pbmRleCAmJiBpdGVtSi5sZW5ndGggPiBpdGVtSS5sZW5ndGgpCgkJCQkJbWF0Y2hlc1tpXSA9IG51bGw7CgkJCQllbHNlIGlmIChpdGVtSi5pbmRleCA%2BPSBpdGVtSS5pbmRleCAmJiBpdGVtSi5pbmRleCA8IGl0ZW1JRW5kUG9zKSAKCQkJCQltYXRjaGVzW2pdID0gbnVsbDsKCQkJfQoJCX0KCQkKCQlyZXR1cm4gbWF0Y2hlczsKCX0sCgkKCS8qKgoJICogQ3JlYXRlcyBhbiBhcnJheSBjb250YWluaW5nIGludGVnZXIgbGluZSBudW1iZXJzIHN0YXJ0aW5nIGZyb20gdGhlICdmaXJzdC1saW5lJyBwYXJhbS4KCSAqIEByZXR1cm4ge0FycmF5fSBSZXR1cm5zIGFycmF5IG9mIGludGVnZXJzLgoJICovCglmaWd1cmVPdXRMaW5lTnVtYmVyczogZnVuY3Rpb24oY29kZSkKCXsKCQl2YXIgbGluZXMgPSBbXSwKCQkJZmlyc3RMaW5lID0gcGFyc2VJbnQodGhpcy5nZXRQYXJhbSgnZmlyc3QtbGluZScpKQoJCQk7CgkJCgkJZWFjaExpbmUoY29kZSwgZnVuY3Rpb24obGluZSwgaW5kZXgpCgkJewoJCQlsaW5lcy5wdXNoKGluZGV4ICsgZmlyc3RMaW5lKTsKCQl9KTsKCQkKCQlyZXR1cm4gbGluZXM7Cgl9LAoJCgkvKioKCSAqIERldGVybWluZXMgaWYgc3BlY2lmaWVkIGxpbmUgbnVtYmVyIGlzIGluIHRoZSBoaWdobGlnaHRlZCBsaXN0LgoJICovCglpc0xpbmVIaWdobGlnaHRlZDogZnVuY3Rpb24obGluZU51bWJlcikKCXsKCQl2YXIgbGlzdCA9IHRoaXMuZ2V0UGFyYW0oJ2hpZ2hsaWdodCcsIFtdKTsKCQkKCQlpZiAodHlwZW9mKGxpc3QpICE9ICdvYmplY3QnICYmIGxpc3QucHVzaCA9PSBudWxsKSAKCQkJbGlzdCA9IFsgbGlzdCBdOwoJCQoJCXJldHVybiBpbmRleE9mKGxpc3QsIGxpbmVOdW1iZXIudG9TdHJpbmcoKSkgIT0gLTE7Cgl9LAoJCgkvKioKCSAqIEdlbmVyYXRlcyBIVE1MIG1hcmt1cCBmb3IgYSBzaW5nbGUgbGluZSBvZiBjb2RlIHdoaWxlIGRldGVybWluaW5nIGFsdGVybmF0aW5nIGxpbmUgc3R5bGUuCgkgKiBAcGFyYW0ge0ludGVnZXJ9IGxpbmVOdW1iZXIJTGluZSBudW1iZXIuCgkgKiBAcGFyYW0ge1N0cmluZ30gY29kZSBMaW5lCUhUTUwgbWFya3VwLgoJICogQHJldHVybiB7U3RyaW5nfQkJCQlSZXR1cm5zIEhUTUwgbWFya3VwLgoJICovCglnZXRMaW5lSHRtbDogZnVuY3Rpb24obGluZUluZGV4LCBsaW5lTnVtYmVyLCBjb2RlKQoJewoJCXZhciBjbGFzc2VzID0gWwoJCQknbGluZScsCgkJCSdudW1iZXInICsgbGluZU51bWJlciwKCQkJJ2luZGV4JyArIGxpbmVJbmRleCwKCQkJJ2FsdCcgKyAobGluZU51bWJlciAlIDIgPT0gMCA/IDEgOiAyKS50b1N0cmluZygpCgkJXTsKCQkKCQlpZiAodGhpcy5pc0xpbmVIaWdobGlnaHRlZChsaW5lTnVtYmVyKSkKCQkgCWNsYXNzZXMucHVzaCgnaGlnaGxpZ2h0ZWQnKTsKCQkKCQlpZiAobGluZU51bWJlciA9PSAwKQoJCQljbGFzc2VzLnB1c2goJ2JyZWFrJyk7CgkJCQoJCXJldHVybiAnPGRpdiBjbGFzcz0iJyArIGNsYXNzZXMuam9pbignICcpICsgJyI%2BJyArIGNvZGUgKyAnPC9kaXY%2BJzsKCX0sCgkKCS8qKgoJICogR2VuZXJhdGVzIEhUTUwgbWFya3VwIGZvciBsaW5lIG51bWJlciBjb2x1bW4uCgkgKiBAcGFyYW0ge1N0cmluZ30gY29kZQkJCUNvbXBsZXRlIGNvZGUgSFRNTCBtYXJrdXAuCgkgKiBAcGFyYW0ge0FycmF5fSBsaW5lTnVtYmVycwlDYWxjdWxhdGVkIGxpbmUgbnVtYmVycy4KCSAqIEByZXR1cm4ge1N0cmluZ30JCQkJUmV0dXJucyBIVE1MIG1hcmt1cC4KCSAqLwoJZ2V0TGluZU51bWJlcnNIdG1sOiBmdW5jdGlvbihjb2RlLCBsaW5lTnVtYmVycykKCXsKCQl2YXIgaHRtbCA9ICcnLAoJCQljb3VudCA9IHNwbGl0TGluZXMoY29kZSkubGVuZ3RoLAoJCQlmaXJzdExpbmUgPSBwYXJzZUludCh0aGlzLmdldFBhcmFtKCdmaXJzdC1saW5lJykpLAoJCQlwYWQgPSB0aGlzLmdldFBhcmFtKCdwYWQtbGluZS1udW1iZXJzJykKCQkJOwoJCQoJCWlmIChwYWQgPT0gdHJ1ZSkKCQkJcGFkID0gKGZpcnN0TGluZSArIGNvdW50IC0gMSkudG9TdHJpbmcoKS5sZW5ndGg7CgkJZWxzZSBpZiAoaXNOYU4ocGFkKSA9PSB0cnVlKQoJCQlwYWQgPSAwOwoJCQkKCQlmb3IgKHZhciBpID0gMDsgaSA8IGNvdW50OyBpKyspCgkJewoJCQl2YXIgbGluZU51bWJlciA9IGxpbmVOdW1iZXJzID8gbGluZU51bWJlcnNbaV0gOiBmaXJzdExpbmUgKyBpLAoJCQkJY29kZSA9IGxpbmVOdW1iZXIgPT0gMCA/IHNoLmNvbmZpZy5zcGFjZSA6IHBhZE51bWJlcihsaW5lTnVtYmVyLCBwYWQpCgkJCQk7CgkJCQkKCQkJaHRtbCArPSB0aGlzLmdldExpbmVIdG1sKGksIGxpbmVOdW1iZXIsIGNvZGUpOwoJCX0KCQkKCQlyZXR1cm4gaHRtbDsKCX0sCgkKCS8qKgoJICogU3BsaXRzIGJsb2NrIG9mIHRleHQgaW50byBpbmRpdmlkdWFsIERJViBsaW5lcy4KCSAqIEBwYXJhbSB7U3RyaW5nfSBjb2RlCQkJQ29kZSB0byBoaWdobGlnaHQuCgkgKiBAcGFyYW0ge0FycmF5fSBsaW5lTnVtYmVycwlDYWxjdWxhdGVkIGxpbmUgbnVtYmVycy4KCSAqIEByZXR1cm4ge1N0cmluZ30JCQkJUmV0dXJucyBoaWdobGlnaHRlZCBjb2RlIGluIEhUTUwgZm9ybS4KCSAqLwoJZ2V0Q29kZUxpbmVzSHRtbDogZnVuY3Rpb24oaHRtbCwgbGluZU51bWJlcnMpCgl7CgkJaHRtbCA9IHRyaW0oaHRtbCk7CgkJCgkJdmFyIGxpbmVzID0gc3BsaXRMaW5lcyhodG1sKSwKCQkJcGFkTGVuZ3RoID0gdGhpcy5nZXRQYXJhbSgncGFkLWxpbmUtbnVtYmVycycpLAoJCQlmaXJzdExpbmUgPSBwYXJzZUludCh0aGlzLmdldFBhcmFtKCdmaXJzdC1saW5lJykpLAoJCQlodG1sID0gJycsCgkJCWJydXNoTmFtZSA9IHRoaXMuZ2V0UGFyYW0oJ2JydXNoJykKCQkJOwoKCQlmb3IgKHZhciBpID0gMDsgaSA8IGxpbmVzLmxlbmd0aDsgaSsrKQoJCXsKCQkJdmFyIGxpbmUgPSBsaW5lc1tpXSwKCQkJCWluZGVudCA9IC9eKCZuYnNwO3xccykrLy5leGVjKGxpbmUpLAoJCQkJc3BhY2VzID0gbnVsbCwKCQkJCWxpbmVOdW1iZXIgPSBsaW5lTnVtYmVycyA/IGxpbmVOdW1iZXJzW2ldIDogZmlyc3RMaW5lICsgaTsKCQkJCTsKCgkJCWlmIChpbmRlbnQgIT0gbnVsbCkKCQkJewoJCQkJc3BhY2VzID0gaW5kZW50WzBdLnRvU3RyaW5nKCk7CgkJCQlsaW5lID0gbGluZS5zdWJzdHIoc3BhY2VzLmxlbmd0aCk7CgkJCQlzcGFjZXMgPSBzcGFjZXMucmVwbGFjZSgnICcsIHNoLmNvbmZpZy5zcGFjZSk7CgkJCX0KCgkJCWxpbmUgPSB0cmltKGxpbmUpOwoJCQkKCQkJaWYgKGxpbmUubGVuZ3RoID09IDApCgkJCQlsaW5lID0gc2guY29uZmlnLnNwYWNlOwoJCQkKCQkJaHRtbCArPSB0aGlzLmdldExpbmVIdG1sKAoJCQkJaSwKCQkJCWxpbmVOdW1iZXIsIAoJCQkJKHNwYWNlcyAhPSBudWxsID8gJzxjb2RlIGNsYXNzPSInICsgYnJ1c2hOYW1lICsgJyBzcGFjZXMiPicgKyBzcGFjZXMgKyAnPC9jb2RlPicgOiAnJykgKyBsaW5lCgkJCSk7CgkJfQoJCQoJCXJldHVybiBodG1sOwoJfSwKCQoJLyoqCgkgKiBSZXR1cm5zIEhUTUwgZm9yIHRoZSB0YWJsZSB0aXRsZSBvciBlbXB0eSBzdHJpbmcgaWYgdGl0bGUgaXMgbnVsbC4KCSAqLwoJZ2V0VGl0bGVIdG1sOiBmdW5jdGlvbih0aXRsZSkKCXsKCQlyZXR1cm4gdGl0bGUgPyAnPGNhcHRpb24%2BJyArIHRpdGxlICsgJzwvY2FwdGlvbj4nIDogJyc7Cgl9LAoJCgkvKioKCSAqIEZpbmRzIGFsbCBtYXRjaGVzIGluIHRoZSBzb3VyY2UgY29kZS4KCSAqIEBwYXJhbSB7U3RyaW5nfSBjb2RlCQlTb3VyY2UgY29kZSB0byBwcm9jZXNzIG1hdGNoZXMgaW4uCgkgKiBAcGFyYW0ge0FycmF5fSBtYXRjaGVzCURpc2NvdmVyZWQgcmVnZXggbWF0Y2hlcy4KCSAqIEByZXR1cm4ge1N0cmluZ30gUmV0dXJucyBmb3JtYXR0ZWQgSFRNTCB3aXRoIHByb2Nlc3NlZCBtYXRoZXMuCgkgKi8KCWdldE1hdGNoZXNIdG1sOiBmdW5jdGlvbihjb2RlLCBtYXRjaGVzKQoJewoJCXZhciBwb3MgPSAwLCAKCQkJcmVzdWx0ID0gJycsCgkJCWJydXNoTmFtZSA9IHRoaXMuZ2V0UGFyYW0oJ2JydXNoJywgJycpCgkJCTsKCQkKCQlmdW5jdGlvbiBnZXRCcnVzaE5hbWVDc3MobWF0Y2gpCgkJewoJCQl2YXIgcmVzdWx0ID0gbWF0Y2ggPyAobWF0Y2guYnJ1c2hOYW1lIHx8IGJydXNoTmFtZSkgOiBicnVzaE5hbWU7CgkJCXJldHVybiByZXN1bHQgPyByZXN1bHQgKyAnICcgOiAnJzsKCQl9OwoJCQoJCS8vIEZpbmFsbHksIGdvIHRocm91Z2ggdGhlIGZpbmFsIGxpc3Qgb2YgbWF0Y2hlcyBhbmQgcHVsbCB0aGUgYWxsCgkJLy8gdG9nZXRoZXIgYWRkaW5nIGV2ZXJ5dGhpbmcgaW4gYmV0d2VlbiB0aGF0IGlzbid0IGEgbWF0Y2guCgkJZm9yICh2YXIgaSA9IDA7IGkgPCBtYXRjaGVzLmxlbmd0aDsgaSsrKSAKCQl7CgkJCXZhciBtYXRjaCA9IG1hdGNoZXNbaV0sCgkJCQltYXRjaEJydXNoTmFtZQoJCQkJOwoJCQkKCQkJaWYgKG1hdGNoID09PSBudWxsIHx8IG1hdGNoLmxlbmd0aCA9PT0gMCkgCgkJCQljb250aW51ZTsKCQkJCgkJCW1hdGNoQnJ1c2hOYW1lID0gZ2V0QnJ1c2hOYW1lQ3NzKG1hdGNoKTsKCQkJCgkJCXJlc3VsdCArPSB3cmFwTGluZXNXaXRoQ29kZShjb2RlLnN1YnN0cihwb3MsIG1hdGNoLmluZGV4IC0gcG9zKSwgbWF0Y2hCcnVzaE5hbWUgKyAncGxhaW4nKQoJCQkJCSsgd3JhcExpbmVzV2l0aENvZGUobWF0Y2gudmFsdWUsIG1hdGNoQnJ1c2hOYW1lICsgbWF0Y2guY3NzKQoJCQkJCTsKCgkJCXBvcyA9IG1hdGNoLmluZGV4ICsgbWF0Y2gubGVuZ3RoICsgKG1hdGNoLm9mZnNldCB8fCAwKTsKCQl9CgoJCS8vIGRvbid0IGZvcmdldCB0byBhZGQgd2hhdGV2ZXIncyByZW1haW5pbmcgaW4gdGhlIHN0cmluZwoJCXJlc3VsdCArPSB3cmFwTGluZXNXaXRoQ29kZShjb2RlLnN1YnN0cihwb3MpLCBnZXRCcnVzaE5hbWVDc3MoKSArICdwbGFpbicpOwoKCQlyZXR1cm4gcmVzdWx0OwoJfSwKCQoJLyoqCgkgKiBHZW5lcmF0ZXMgSFRNTCBtYXJrdXAgZm9yIHRoZSB3aG9sZSBzeW50YXggaGlnaGxpZ2h0ZXIuCgkgKiBAcGFyYW0ge1N0cmluZ30gY29kZSBTb3VyY2UgY29kZS4KCSAqIEByZXR1cm4ge1N0cmluZ30gUmV0dXJucyBIVE1MIG1hcmt1cC4KCSAqLwoJZ2V0SHRtbDogZnVuY3Rpb24oY29kZSkKCXsKCQl2YXIgaHRtbCA9ICcnLAoJCQljbGFzc2VzID0gWyAnc3ludGF4aGlnaGxpZ2h0ZXInIF0sCgkJCXRhYlNpemUsCgkJCW1hdGNoZXMsCgkJCWxpbmVOdW1iZXJzCgkJCTsKCQkKCQkvLyBwcm9jZXNzIGxpZ2h0IG1vZGUKCQlpZiAodGhpcy5nZXRQYXJhbSgnbGlnaHQnKSA9PSB0cnVlKQoJCQl0aGlzLnBhcmFtcy50b29sYmFyID0gdGhpcy5wYXJhbXMuZ3V0dGVyID0gZmFsc2U7CgoJCWNsYXNzTmFtZSA9ICdzeW50YXhoaWdobGlnaHRlcic7CgoJCWlmICh0aGlzLmdldFBhcmFtKCdjb2xsYXBzZScpID09IHRydWUpCgkJCWNsYXNzZXMucHVzaCgnY29sbGFwc2VkJyk7CgkJCgkJaWYgKChndXR0ZXIgPSB0aGlzLmdldFBhcmFtKCdndXR0ZXInKSkgPT0gZmFsc2UpCgkJCWNsYXNzZXMucHVzaCgnbm9ndXR0ZXInKTsKCgkJLy8gYWRkIGN1c3RvbSB1c2VyIHN0eWxlIG5hbWUKCQljbGFzc2VzLnB1c2godGhpcy5nZXRQYXJhbSgnY2xhc3MtbmFtZScpKTsKCgkJLy8gYWRkIGJydXNoIGFsaWFzIHRvIHRoZSBjbGFzcyBuYW1lIGZvciBjdXN0b20gQ1NTCgkJY2xhc3Nlcy5wdXNoKHRoaXMuZ2V0UGFyYW0oJ2JydXNoJykpOwoKCQljb2RlID0gdHJpbUZpcnN0QW5kTGFzdExpbmVzKGNvZGUpCgkJCS5yZXBsYWNlKC9cci9nLCAnICcpIC8vIElFIGxldHMgdGhlc2UgYnVnZ2VycyB0aHJvdWdoCgkJCTsKCgkJdGFiU2l6ZSA9IHRoaXMuZ2V0UGFyYW0oJ3RhYi1zaXplJyk7CgoJCS8vIHJlcGxhY2UgdGFicyB3aXRoIHNwYWNlcwoJCWNvZGUgPSB0aGlzLmdldFBhcmFtKCdzbWFydC10YWJzJykgPT0gdHJ1ZQoJCQk/IHByb2Nlc3NTbWFydFRhYnMoY29kZSwgdGFiU2l6ZSkKCQkJOiBwcm9jZXNzVGFicyhjb2RlLCB0YWJTaXplKQoJCQk7CgoJCS8vIHVuaW5kZW50IGNvZGUgYnkgdGhlIGNvbW1vbiBpbmRlbnRhdGlvbgoJCWlmICh0aGlzLmdldFBhcmFtKCd1bmluZGVudCcpKQoJCQljb2RlID0gdW5pbmRlbnQoY29kZSk7CgoJCWlmIChndXR0ZXIpCgkJCWxpbmVOdW1iZXJzID0gdGhpcy5maWd1cmVPdXRMaW5lTnVtYmVycyhjb2RlKTsKCQkKCQkvLyBmaW5kIG1hdGNoZXMgaW4gdGhlIGNvZGUgdXNpbmcgYnJ1c2hlcyByZWdleCBsaXN0CgkJbWF0Y2hlcyA9IHRoaXMuZmluZE1hdGNoZXModGhpcy5yZWdleExpc3QsIGNvZGUpOwoJCS8vIHByb2Nlc3NlcyBmb3VuZCBtYXRjaGVzIGludG8gdGhlIGh0bWwKCQlodG1sID0gdGhpcy5nZXRNYXRjaGVzSHRtbChjb2RlLCBtYXRjaGVzKTsKCQkvLyBmaW5hbGx5LCBzcGxpdCBhbGwgbGluZXMgc28gdGhhdCB0aGV5IHdyYXAgd2VsbAoJCWh0bWwgPSB0aGlzLmdldENvZGVMaW5lc0h0bWwoaHRtbCwgbGluZU51bWJlcnMpOwoKCQkvLyBmaW5hbGx5LCBwcm9jZXNzIHRoZSBsaW5rcwoJCWlmICh0aGlzLmdldFBhcmFtKCdhdXRvLWxpbmtzJykpCgkJCWh0bWwgPSBwcm9jZXNzVXJscyhodG1sKTsKCQkKCQlpZiAodHlwZW9mKG5hdmlnYXRvcikgIT0gJ3VuZGVmaW5lZCcgJiYgbmF2aWdhdG9yLnVzZXJBZ2VudCAmJiBuYXZpZ2F0b3IudXNlckFnZW50Lm1hdGNoKC9NU0lFLykpCgkJCWNsYXNzZXMucHVzaCgnaWUnKTsKCQkKCQlodG1sID0gCgkJCSc8ZGl2IGlkPSInICsgZ2V0SGlnaGxpZ2h0ZXJJZCh0aGlzLmlkKSArICciIGNsYXNzPSInICsgY2xhc3Nlcy5qb2luKCcgJykgKyAnIj4nCgkJCQkrICh0aGlzLmdldFBhcmFtKCd0b29sYmFyJykgPyBzaC50b29sYmFyLmdldEh0bWwodGhpcykgOiAnJykKCQkJCSsgJzx0YWJsZSBib3JkZXI9IjAiIGNlbGxwYWRkaW5nPSIwIiBjZWxsc3BhY2luZz0iMCI%2BJwoJCQkJCSsgdGhpcy5nZXRUaXRsZUh0bWwodGhpcy5nZXRQYXJhbSgndGl0bGUnKSkKCQkJCQkrICc8dGJvZHk%2BJwoJCQkJCQkrICc8dHI%2BJwoJCQkJCQkJKyAoZ3V0dGVyID8gJzx0ZCBjbGFzcz0iZ3V0dGVyIj4nICsgdGhpcy5nZXRMaW5lTnVtYmVyc0h0bWwoY29kZSkgKyAnPC90ZD4nIDogJycpCgkJCQkJCQkrICc8dGQgY2xhc3M9ImNvZGUiPicKCQkJCQkJCQkrICc8ZGl2IGNsYXNzPSJjb250YWluZXIiPicKCQkJCQkJCQkJKyBodG1sCgkJCQkJCQkJKyAnPC9kaXY%2BJwoJCQkJCQkJKyAnPC90ZD4nCgkJCQkJCSsgJzwvdHI%2BJwoJCQkJCSsgJzwvdGJvZHk%2BJwoJCQkJKyAnPC90YWJsZT4nCgkJCSsgJzwvZGl2PicKCQkJOwoJCQkKCQlyZXR1cm4gaHRtbDsKCX0sCgkKCS8qKgoJICogSGlnaGxpZ2h0cyB0aGUgY29kZSBhbmQgcmV0dXJucyBjb21wbGV0ZSBIVE1MLgoJICogQHBhcmFtIHtTdHJpbmd9IGNvZGUgICAgIENvZGUgdG8gaGlnaGxpZ2h0LgoJICogQHJldHVybiB7RWxlbWVudH0gICAgICAgIFJldHVybnMgY29udGFpbmVyIERJViBlbGVtZW50IHdpdGggYWxsIG1hcmt1cC4KCSAqLwoJZ2V0RGl2OiBmdW5jdGlvbihjb2RlKQoJewoJCWlmIChjb2RlID09PSBudWxsKSAKCQkJY29kZSA9ICcnOwoJCQoJCXRoaXMuY29kZSA9IGNvZGU7CgoJCXZhciBkaXYgPSB0aGlzLmNyZWF0ZSgnZGl2Jyk7CgoJCS8vIGNyZWF0ZSBtYWluIEhUTUwKCQlkaXYuaW5uZXJIVE1MID0gdGhpcy5nZXRIdG1sKGNvZGUpOwoJCQoJCS8vIHNldCB1cCBjbGljayBoYW5kbGVycwoJCWlmICh0aGlzLmdldFBhcmFtKCd0b29sYmFyJykpCgkJCWF0dGFjaEV2ZW50KGZpbmRFbGVtZW50KGRpdiwgJy50b29sYmFyJyksICdjbGljaycsIHNoLnRvb2xiYXIuaGFuZGxlcik7CgkJCgkJaWYgKHRoaXMuZ2V0UGFyYW0oJ3F1aWNrLWNvZGUnKSkKCQkJYXR0YWNoRXZlbnQoZmluZEVsZW1lbnQoZGl2LCAnLmNvZGUnKSwgJ2RibGNsaWNrJywgcXVpY2tDb2RlSGFuZGxlcik7CgkJCgkJcmV0dXJuIGRpdjsKCX0sCgkKCS8qKgoJICogSW5pdGlhbGl6ZXMgdGhlIGhpZ2hsaWdodGVyL2JydXNoLgoJICoKCSAqIENvbnN0cnVjdG9yIGlzbid0IHVzZWQgZm9yIGluaXRpYWxpemF0aW9uIHNvIHRoYXQgbm90aGluZyBleGVjdXRlcyBkdXJpbmcgbmVjZXNzYXJ5CgkgKiBgbmV3IFN5bnRheEhpZ2hsaWdodGVyLkhpZ2hsaWdodGVyKClgIGNhbGwgd2hlbiBzZXR0aW5nIHVwIGJydXNoIGluaGVyaXRhbmNlLgoJICoKCSAqIEBwYXJhbSB7SGFzaH0gcGFyYW1zIEhpZ2hsaWdodGVyIHBhcmFtZXRlcnMuCgkgKi8KCWluaXQ6IGZ1bmN0aW9uKHBhcmFtcykKCXsKCQl0aGlzLmlkID0gZ3VpZCgpOwoJCQoJCS8vIHJlZ2lzdGVyIHRoaXMgaW5zdGFuY2UgaW4gdGhlIGhpZ2hsaWdodGVycyBsaXN0CgkJc3RvcmVIaWdobGlnaHRlcih0aGlzKTsKCQkKCQkvLyBsb2NhbCBwYXJhbXMgdGFrZSBwcmVjZWRlbmNlIG92ZXIgZGVmYXVsdHMKCQl0aGlzLnBhcmFtcyA9IG1lcmdlKHNoLmRlZmF1bHRzLCBwYXJhbXMgfHwge30pCgkJCgkJLy8gcHJvY2VzcyBsaWdodCBtb2RlCgkJaWYgKHRoaXMuZ2V0UGFyYW0oJ2xpZ2h0JykgPT0gdHJ1ZSkKCQkJdGhpcy5wYXJhbXMudG9vbGJhciA9IHRoaXMucGFyYW1zLmd1dHRlciA9IGZhbHNlOwoJfSwKCQoJLyoqCgkgKiBDb252ZXJ0cyBzcGFjZSBzZXBhcmF0ZWQgbGlzdCBvZiBrZXl3b3JkcyBpbnRvIGEgcmVndWxhciBleHByZXNzaW9uIHN0cmluZy4KCSAqIEBwYXJhbSB7U3RyaW5nfSBzdHIgICAgU3BhY2Ugc2VwYXJhdGVkIGtleXdvcmRzLgoJICogQHJldHVybiB7U3RyaW5nfSAgICAgICBSZXR1cm5zIHJlZ3VsYXIgZXhwcmVzc2lvbiBzdHJpbmcuCgkgKi8KCWdldEtleXdvcmRzOiBmdW5jdGlvbihzdHIpCgl7CgkJc3RyID0gc3RyCgkJCS5yZXBsYWNlKC9eXHMrfFxzKyQvZywgJycpCgkJCS5yZXBsYWNlKC9ccysvZywgJ3wnKQoJCQk7CgkJCgkJcmV0dXJuICdcXGIoPzonICsgc3RyICsgJylcXGInOwoJfSwKCQoJLyoqCgkgKiBNYWtlcyBhIGJydXNoIGNvbXBhdGlibGUgd2l0aCB0aGUgYGh0bWwtc2NyaXB0YCBmdW5jdGlvbmFsaXR5LgoJICogQHBhcmFtIHtPYmplY3R9IHJlZ2V4R3JvdXAgT2JqZWN0IGNvbnRhaW5pbmcgYGxlZnRgIGFuZCBgcmlnaHRgIHJlZ3VsYXIgZXhwcmVzc2lvbnMuCgkgKi8KCWZvckh0bWxTY3JpcHQ6IGZ1bmN0aW9uKHJlZ2V4R3JvdXApCgl7CgkJdmFyIHJlZ2V4ID0geyAnZW5kJyA6IHJlZ2V4R3JvdXAucmlnaHQuc291cmNlIH07CgoJCWlmKHJlZ2V4R3JvdXAuZW9mKQoJCQlyZWdleC5lbmQgPSAiKD86KD86IiArIHJlZ2V4LmVuZCArICIpfCQpIjsKCQkKCQl0aGlzLmh0bWxTY3JpcHQgPSB7CgkJCWxlZnQgOiB7IHJlZ2V4OiByZWdleEdyb3VwLmxlZnQsIGNzczogJ3NjcmlwdCcgfSwKCQkJcmlnaHQgOiB7IHJlZ2V4OiByZWdleEdyb3VwLnJpZ2h0LCBjc3M6ICdzY3JpcHQnIH0sCgkJCWNvZGUgOiBuZXcgWFJlZ0V4cCgKCQkJCSIoPzxsZWZ0PiIgKyByZWdleEdyb3VwLmxlZnQuc291cmNlICsgIikiICsKCQkJCSIoPzxjb2RlPi4qPykiICsKCQkJCSIoPzxyaWdodD4iICsgcmVnZXguZW5kICsgIikiLAoJCQkJInNnaSIKCQkJCSkKCQl9OwoJfQp9OyAvLyBlbmQgb2YgSGlnaGxpZ2h0ZXIKCnJldHVybiBzaDsKfSgpOyAvLyBlbmQgb2YgYW5vbnltb3VzIGZ1bmN0aW9uCgovLyBDb21tb25KUwp0eXBlb2YoZXhwb3J0cykgIT0gJ3VuZGVmaW5lZCcgPyBleHBvcnRzLlN5bnRheEhpZ2hsaWdodGVyID0gU3ludGF4SGlnaGxpZ2h0ZXIgOiBudWxsOwo%3D"> /** * SyntaxHighlighter * http://alexgorbatchev.com/SyntaxHighlighter * * SyntaxHighlighter is donationware. If you are using it, please donate. * http://alexgorbatchev.com/SyntaxHighlighter/donate.html * * @version * 3.0.83 (July 02 2010) * * @copyright * Copyright (C) 2004-2010 Alex Gorbatchev. * * @license * Dual licensed under the MIT and GPL licenses. */ </script> <script type="text/javascript" src="data:application/javascript;base64,LyoqCiAqIFN5bnRheEhpZ2hsaWdodGVyCiAqIGh0dHA6Ly9hbGV4Z29yYmF0Y2hldi5jb20vU3ludGF4SGlnaGxpZ2h0ZXIKICoKICogU3ludGF4SGlnaGxpZ2h0ZXIgaXMgZG9uYXRpb253YXJlLiBJZiB5b3UgYXJlIHVzaW5nIGl0LCBwbGVhc2UgZG9uYXRlLgogKiBodHRwOi8vYWxleGdvcmJhdGNoZXYuY29tL1N5bnRheEhpZ2hsaWdodGVyL2RvbmF0ZS5odG1sCiAqCiAqIEB2ZXJzaW9uCiAqIDMuMC44MyAoSnVseSAwMiAyMDEwKQogKgogKiBAY29weXJpZ2h0CiAqIENvcHlyaWdodCAoQykgMjAwNC0yMDEwIEFsZXggR29yYmF0Y2hldi4KICoKICogQGxpY2Vuc2UKICogRHVhbCBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIGFuZCBHUEwgbGljZW5zZXMuCiAqLwooZnVuY3Rpb24oKQp7CgkvLyBDb21tb25KUwoJdHlwZW9mKHJlcXVpcmUpICE9ICd1bmRlZmluZWQnID8gU3ludGF4SGlnaGxpZ2h0ZXIgPSByZXF1aXJlKCdzaENvcmUnKS5TeW50YXhIaWdobGlnaHRlciA6IG51bGw7CgoJZnVuY3Rpb24gQnJ1c2goKQoJewoJCS8vIENvbnRyaWJ1dGVkIGJ5IEdoZW9yZ2hlIE1pbGFzIGFuZCBBaG1hZCBTaGVyaWYKCgkJdmFyIGtleXdvcmRzID0gICdhbmQgYXNzZXJ0IGJyZWFrIGNsYXNzIGNvbnRpbnVlIGRlZiBkZWwgZWxpZiBlbHNlICcgKwoJCQkJCQknZXhjZXB0IGV4ZWMgZmluYWxseSBmb3IgZnJvbSBnbG9iYWwgaWYgaW1wb3J0IGluIGlzICcgKwoJCQkJCQknbGFtYmRhIG5vdCBvciBwYXNzIHByaW50IHJhaXNlIHJldHVybiB0cnkgeWllbGQgd2hpbGUnOwoKCQl2YXIgZnVuY3MgPSAnX19pbXBvcnRfXyBhYnMgYWxsIGFueSBhcHBseSBiYXNlc3RyaW5nIGJpbiBib29sIGJ1ZmZlciBjYWxsYWJsZSAnICsKCQkJCQknY2hyIGNsYXNzbWV0aG9kIGNtcCBjb2VyY2UgY29tcGlsZSBjb21wbGV4IGRlbGF0dHIgZGljdCBkaXIgJyArCgkJCQkJJ2Rpdm1vZCBlbnVtZXJhdGUgZXZhbCBleGVjZmlsZSBmaWxlIGZpbHRlciBmbG9hdCBmb3JtYXQgZnJvemVuc2V0ICcgKwoJCQkJCSdnZXRhdHRyIGdsb2JhbHMgaGFzYXR0ciBoYXNoIGhlbHAgaGV4IGlkIGlucHV0IGludCBpbnRlcm4gJyArCgkJCQkJJ2lzaW5zdGFuY2UgaXNzdWJjbGFzcyBpdGVyIGxlbiBsaXN0IGxvY2FscyBsb25nIG1hcCBtYXggbWluIG5leHQgJyArCgkJCQkJJ29iamVjdCBvY3Qgb3BlbiBvcmQgcG93IHByaW50IHByb3BlcnR5IHJhbmdlIHJhd19pbnB1dCByZWR1Y2UgJyArCgkJCQkJJ3JlbG9hZCByZXByIHJldmVyc2VkIHJvdW5kIHNldCBzZXRhdHRyIHNsaWNlIHNvcnRlZCBzdGF0aWNtZXRob2QgJyArCgkJCQkJJ3N0ciBzdW0gc3VwZXIgdHVwbGUgdHlwZSB0eXBlIHVuaWNociB1bmljb2RlIHZhcnMgeHJhbmdlIHppcCc7CgoJCXZhciBzcGVjaWFsID0gICdOb25lIFRydWUgRmFsc2Ugc2VsZiBjbHMgY2xhc3NfJzsKCgkJdGhpcy5yZWdleExpc3QgPSBbCgkJCQl7IHJlZ2V4OiBTeW50YXhIaWdobGlnaHRlci5yZWdleExpYi5zaW5nbGVMaW5lUGVybENvbW1lbnRzLCBjc3M6ICdjb21tZW50cycgfSwKCQkJCXsgcmVnZXg6IC9eXHMqQFx3Ky9nbSwgCQkJCQkJCQkJCWNzczogJ2RlY29yYXRvcicgfSwKCQkJCXsgcmVnZXg6IC8oWydcIl17M30pKFteXDFdKSo/XDEvZ20sIAkJCQkJCWNzczogJ2NvbW1lbnRzJyB9LAoJCQkJeyByZWdleDogLyIoPyEiKSg/OlwufFxcXCJ8W15cIiJcbl0pKiIvZ20sIAkJCQkJY3NzOiAnc3RyaW5nJyB9LAoJCQkJeyByZWdleDogLycoPyEnKSg/OlwufChcXFwnKXxbXlwnJ1xuXSkqJy9nbSwgCQkJCWNzczogJ3N0cmluZycgfSwKCQkJCXsgcmVnZXg6IC9cK3xcLXxcKnxcL3xcJXw9fD09L2dtLCAJCQkJCQkJY3NzOiAna2V5d29yZCcgfSwKCQkJCXsgcmVnZXg6IC9cYlxkK1wuP1x3Ki9nLCAJCQkJCQkJCQljc3M6ICd2YWx1ZScgfSwKCQkJCXsgcmVnZXg6IG5ldyBSZWdFeHAodGhpcy5nZXRLZXl3b3JkcyhmdW5jcyksICdnbWknKSwJCWNzczogJ2Z1bmN0aW9ucycgfSwKCQkJCXsgcmVnZXg6IG5ldyBSZWdFeHAodGhpcy5nZXRLZXl3b3JkcyhrZXl3b3JkcyksICdnbScpLCAJCWNzczogJ2tleXdvcmQnIH0sCgkJCQl7IHJlZ2V4OiBuZXcgUmVnRXhwKHRoaXMuZ2V0S2V5d29yZHMoc3BlY2lhbCksICdnbScpLCAJCWNzczogJ2NvbG9yMScgfQoJCQkJXTsKCgkJdGhpcy5mb3JIdG1sU2NyaXB0KFN5bnRheEhpZ2hsaWdodGVyLnJlZ2V4TGliLmFzcFNjcmlwdFRhZ3MpOwoJfTsKCglCcnVzaC5wcm90b3R5cGUJPSBuZXcgU3ludGF4SGlnaGxpZ2h0ZXIuSGlnaGxpZ2h0ZXIoKTsKCUJydXNoLmFsaWFzZXMJPSBbJ3B5JywgJ3B5dGhvbiddOwoKCVN5bnRheEhpZ2hsaWdodGVyLmJydXNoZXMuUHl0aG9uID0gQnJ1c2g7CgoJLy8gQ29tbW9uSlMKCXR5cGVvZihleHBvcnRzKSAhPSAndW5kZWZpbmVkJyA/IGV4cG9ydHMuQnJ1c2ggPSBCcnVzaCA6IG51bGw7Cn0pKCk7Cg%3D%3D"> /** * SyntaxHighlighter * http://alexgorbatchev.com/SyntaxHighlighter * * SyntaxHighlighter is donationware. If you are using it, please donate. * http://alexgorbatchev.com/SyntaxHighlighter/donate.html * * @version * 3.0.83 (July 02 2010) * * @copyright * Copyright (C) 2004-2010 Alex Gorbatchev. * * @license * Dual licensed under the MIT and GPL licenses. */ </script> <style type="text/css"> body { color: #000; background: #FFF; font-family: 'Helvetica Neue', 'Helvetica', 'Verdana', sans-serif; font-size: 12px; padding: 0; margin: 0; } a { color: #FAFF78; } h1, h2, h3, h4, h5, h6 { font-family: 'Helvetica', sans-serif; } h1 { margin: 0; padding: .75em 1.5em 1em 1.5em; color: #F90; font-size: 14px; font-weight: bold; } h1 img { padding-right: 5px; } h2 { color: #311F00; } header { width: 100%; background: #311F00; } div#error-content { padding: 0 2em; } .syntaxhighlighter a, .syntaxhighlighter div, .syntaxhighlighter code, .syntaxhighlighter table, .syntaxhighlighter table td, .syntaxhighlighter table tr, .syntaxhighlighter table tbody, .syntaxhighlighter table thead, .syntaxhighlighter table caption, .syntaxhighlighter textarea { font-family: monospace !important; } .syntaxhighlighter .container { background: #FDF6E3 !important; padding: 1em !important; } .syntaxhighlighter .container .line { background: #FDF6E3 !important; } .syntaxhighlighter .container .line .python.string { color: #C70 !important; } #debug { background: #FDF6E3; padding: 10px !important; margin-top: 10px; font-family: monospace; } </style> <script type="text/javascript"> SyntaxHighlighter.defaults['gutter'] = false; SyntaxHighlighter.defaults['toolbar'] = false; SyntaxHighlighter.all() </script> <script type="text/javascript"> function get_request() { /* ajax sans jquery makes me sad */ var request = false; // Mozilla/Safari if (window.XMLHttpRequest) { request = new XMLHttpRequest(); } // IE else if (window.ActiveXObject) { request = new ActiveXObject("Microsoft.XMLHTTP"); } return request; } function debug_request(btn) { btn.disabled = true; request = get_request(); request.open('GET', '/__pecan_initiate_pdb__', true); request.onreadystatechange = function() { if (request.readyState == 4) { btn.disabled = false; } } request.send(''); /* automatically timeout after 5 minutes, re-enabling the button */ setTimeout(function() { request.abort(); }, 5 * 60 * 1000); } </script> </head> <body> <header> <h1> <img style="padding-top: 7px" align="center" alt="pecan logo" height="25" src="%2BfAp30Hc8TziHS4miFhheJbjLMMzHB8POFPqKGKWi6TXtSriJcT9MzH5bAzzHIK1I08t6hq6zHpRdu2aYdJYuk9Q/881bzZa8Xrx6fLmJo/iu4/VXnfH1BB/rmu5ScQvI77m%2BBkmfxXxvcZcJY14L0DymZp7pML5yTcW61PvIN6JuGr4halQvmjNlCa4bXJ5zj6qhpxrujeKPYMXEd%2Bq00KR5yNAlWZzrF%2BIe%2BuNsdC/MO4tTOZafhbroyXuR3Df08bLiHsQf%2Bja6gTPWVimZl7l/oUrjl8OcxDWLbNU5D6JRL2gxkDu16fGuC054OMhclsyXTOOFEL%2BkmMGs4i5kfNuQ62EnBuam8tzP%2BQ%2BtSqhz9SuqpZlvR1EfBiOJTSgYMMM7jpYsAEyqJCHDL4dcFFTAwNMlFDUUpQYiadhDmXteeWAw3HEmA2s15k1RmnP4RHuhBybdBOF7MfnICmSQ2SYjIBM3iRvkcMki9IRcnDTthyLz2Ld2fTzPjTQK%2BMdg8y5nkZfFO%2Bse9LQr3/09xZr%2B5GcaSufeAfAww60mAPx%2Bq8u/bAr8rFCLrx7s%2BvqEkw8qb%2Bp26n11Aruq6m1iJH6PbWGv1VIY25mkNE8PkaQhxfLIF7DZXx80HD/A3l2jLclYs061xNpWCfoB6WHJTjbH0mV35Q/lRXlC%2BW8cndbl9t2SfhU%2BFb4UfhO%2BF74GWThknBZ%2BEm4InwjXIyd1ePnY/Psg3pb1TJNu15TMKWMtFt6ScpKL0ivSMXIn9QtDUlj0h7U7N48t3i8eC0GnMC91dX2sTivgloDTgUVeEGHLTizbf5Da9JLhkhh29QOs1luMcScmBXTIIt7xRFxSBxnuJWfuAd1I7jntkyd/pgKaIwVr3MgmDo2q8x6IdB5QH162mcX7ajtnHGN2bov71OU1%2BU0fqqoXLD0wX5ZM005UHmySz3qLtDqILDvIL%2BiH6jB9y2x83ok898GOPQX3lk3Itl0A%2BBrD6D7tUjWh3fis58BXDigN9yF8M5PJH4B8Gr79/F/XRm8m241mw/wvur4BGDj42bzn%2BVmc%2BNL9L8GcMn8F1kAcXjEKMJAAAAACXBIWXMAAAsTAAALEwEAmpwYAAANHElEQVR4nO2bf6xlVXXHP/uce2fmMc9xADsOCqJWO4WKEKIVSPmVkNRqFElFKP1h/9D6T1stCjFp/yJtbNqY2NBorBGhWqtN/BF/tGpURAutMkNkHEh0qiDOwFCZnw5v3r33nP3tH3uve9Y979z77jBgw%2BStZL9z7jlrr71%2B7b3XXuu8IIkOCPkqoATqLiQHZcaNq%2BB5KPI4q9EOGXc1vC6emLNfj8T7LP7n5dfTrEl6OV7wOp933E47BUkv9L%2BBJeBA/t0HRvn%2BAuA1wFkxxvUUHFStB8uyvAf434zTA6o5BPB4zwEuBM4DzgDWAUfquv5xWZbfBX58nLQDSVjDPbWiuqBH7xxgK7CQZfwp8APgfmCYcac58/j5oUOHNm/evPmVwLbM72KMUUVRHK7r%2BpGyLHcCOx0vgW7H2Zxlr2kmFMDjmfe2HFvqur60LMtfz30HwB7gXmBHxlmpI0mHJR2OMR6WdCjGeFDSRyStk4Sky2KM39Z0OFDX9T9KOjXj9/K1qwVJZb5/vqS/l/SzGbSXJX1R0oW5T5FpTKNfuvvzJH00Ku6bQV%2BSfiTpLyUtdNDwv7dIulXSo6vQk6T7JP2Ro1F00PuHhBr3K9ngUL7ulnSNw1%2BU9AFJB2aMd4%2BkV3Xxz4xOV0m6vvVsZC3GOJJU2YsY4x5Jv6npRg5O0Gujomc4KhlzKbdjeZwx1HX9Z45Ol5G9YH8rqW7RH%2BYxrE3Ql7RraWnprBYtu75Y0iNtejHGY7N4lvRvTma7Gs2PajocVtLhi5QMblBJGkZF0/8o86Is71VtXeCErSXVMUZTzNccw4NMvFJj5NoRHkhSjHE4GAxeqW4j26B/7hge5uaNMYaoWOX3Bu%2BcQruQxO7du9dL%2Buq4f%2BOEQ6cIe1c7mZbzs7vV4ZAxxs/nbkumpy5%2BMxhN4/tj6jbwB/P7J9Xo3ibMLyRdGWM04x7TpJ28/m1ySNLPJZ3ux/Mz2CvAC1BpCmQlGa4NslONAWym2e83NYPFqjXOLkl3SPpg1MSWYIYwuECTivKz%2BQsZZ5DlsWb8Ho6Ke5UU2JbbeLko0%2Brn63MkPex0UWdaI0lfkfQhpS3tP1s0o%2BGORqMrnR5KSdR1/UmtBOPlCUk78v2xDjwDr79Bvt7k%2BUdp/3nAdYhZgCOSjjgC%2B2OM35H0SaV90S9ZZgDz2pudQOa5myU9nt97DzxQVdV1WrnkviHGuOQEN9r/rm7neU9LUC/8Z5SWrzMkbZK0taqqP3b8DLPBJOn1mZ7FIKdK2uv4MHhtB8/XqFn1orv/uJpZVUiiqqqrJd0i6Z81HUzmo3Vd31HX9Z9IulbSjUqxg5fTxrpLTj/G2I2JoziKiibEPklXSLp0NBpdLGlrS5iNkt6hZjbY0qQ8uM0AU9RfOaa9oi5VMyPXuYakt0vjlcL6RKUAys%2ByLcpBSAtXkt6mlYawdotWwhtbfG%2BWojmzOc%2BjWX7D66txtA9lHB%2Bj/FDSenXHEIuSDmY875Rm3LuVYoA276dLeijj%2BNVwr6TnZpwCpeXiZseUYqOfV3cQLjUZFb5Cae23gazz5U6gvqQHHY552/s66LfbAx39/iK/s8jXZu/I4UrSu9XM8r6aGWTGuz7GuEtpeb1HKfq9RBK6c2ywUtI2Jaf6DUnn5/tT1B3svT6P7bevw5LO1ORebM55htOf4Rv/2x2eOVEvj42k90ppYqrR%2B5OSXmK89wCKopg4jIfmWHZKvq4nnYcjkwfwdcAu4O3A5/KzCujHGC8piuIuQKPR6MJ%2Bv3%2BO9ZMUQgiQzqFnA89dcX5LtJ4EHgXOxSUMYowXFkUBzfn1ja5fnc%2BPu4D3Wxcmz6LW71MhhE/RBVeM%2BamBH3biJCiBTbkdy7IY/zbmArCY7025tbv6c7AllwDeQdL7etK5tw07E8FQ5H52du4bQq%2BjkyEuA4/lZxUrD%2BsxDxqAzwPbgVdlhvtFUWwzxH6//wonTJmNK6HbAyEwO9tjwlpmiKIoXuDoPR8YO4/j89M2PE2y5qnCWMFHjx7dsri4%2BFukpM95wFnA6cApkvohhNL1y4KqCCEUc45Vk2T9BimBUdJtXEgJG4SKQPD2GetzqoEl7Q0h7MnPpqXwRJM9%2BRbJwAZb3f3Z7YGBEJhQxjTwq4bNznWtcU43mvk9dV3vKMuyPWYXhNbvNn4JDAbw0vVw0%2BLi4puB53USCuGppCWbgdPKZjS%2Bka%2Brp2ltSnbANAMD7Cd7yJxg6co8lBbcqBunsDSPV3ucfuqsDbaNVFQbe/S8eAGgLMuDc/I9yyim3OvXodsgLABIqkMII2BDC3%2BKmueDbFyT93/m4G9VWGFg2x9DCJtJAiyvQsMY2DL5O9g%2BR4xxkPdMex%2BAXwD/mumXzCdIBBYD4b8bAXrt5cvot53qeMHyz78PfCI71AgIIYRefn%2BMtD8/DPEAFEdIW8Z1JEPNmFtTIQDUdb2UV6ATgq4ZbJb4NVJwcx%2BTSe82M7Z8n9d6t39MsCj2Onw/e98LzDvT2mAGeAI4SgpiRBOknENa5uZVsK%2BI2cw9TehWZ9xepjcE/gb4OPBw6jd24F8Frn%2BKMjXMPA3GhY4lMgdAFUCM8d35se21E6g0StlAEszDj%2BymqiqrrpQ0kfZG4Ib8fGN%2B1%2Btotueuo4kQSxrH2gM85Pi022vzTTtKXSFyplnTGNf0cnUgnAqMhPqOzpuBW/K4tqzacn0R0ytIv3SYtgeWgIqiuAH4U5LwvoRly4/N6o00gY45wn/la9i3b992mrKfV/iNJOU%2BSRMlV66Zwoe51aSZZHVWm8UWkNizCOEy4A8yjT7N7LNW0BwnRsBlwG9nfJs%2B41UpECzQuRf4Io1D2qpkkbo5VmTSsYzmvNH0icB4rGmDecZuBT5AilZF4%2BmQ6pmbSMHY4/lZT9JjwN35d//MM888Bth5MwKlUA281D0fsDL4ijSKex9wuzHe4vcTNjaTe/lHgDeQnKOiWcJtKR7l%2Bz8E7pT0YZLRBwAxRh%2BtG9gzc1RbVWrgtcDVkqBRsgVPh/PPEz2yzQPNWDnjcVMrE6ScIfEpvyOSvlrX9W2SPi3pe0q13CdijN9TkzaTpL/Wylz0aS5j08443S/pdS5DY22rpLfGGO93tF/naPuiwx35/XLm3af9blcqImxyfV4g6bqOWrfxPs4UKacNY6OOt2plBuvyXFP3ciVWErxL0rnLy8vbWnxvUSouSJPZL8uJd5Vee5IYjUZXOL68rd6plHV7%2BUwDqyk%2BtJ93QMx/4x6lwoJPyxmTv5dxxkrIVSWDnyhVaD4r6TuS9rt3lgd%2BQI2hfI35eZIea%2BG2y3o/lXSvpO9rsoBuJThTkhXPL82yRavBOGE/LOm6LFNXbTc6WT18WZM6OXEDW31o5VifXc3AUpPItnql1YMrV1NdcviXT2HMPPZmhzuQFDPdFdy58a1ubHBDawy7nq/GcFbDnuWgnrYpdsfS0tILHd//kZ9b2W4an8bfbkk/yPfjmm2MsV0N6zKwLxqsamClYpCN4x3KHPxzXXtwBJB0H/AFmqAq5r3EghSFECwgWQCqmvoa4C66v5%2ByoOPvSLnrirSfWV66kjQknYutDUEW5dre%2BC6aNKQFPlUe8/7BYPAaUo7Wom6DUaLHILchaf812gVwG3DxwsLCXpoA7G2SHiFFyZZVGwkNHL3ljC/gd2miesvfy2WourJSFtOodT8NBDAcDn%2Bef9uxLuaUpQAkxa4ZbEvmd5WWv/fP8FqDr0k6Z4bHWfNL6jZJ/6LmQ4FZcEDSP0l6WYtWp2dv3769L%2Bk9Unx4DtqKMX5Tk/Xd9ic7Z6iZydPgQVklKpUch1Pw7tSknraqmXEertZ0fXrZPzaDp6%2BkojDcRJpZ/ij0AGBFgm0xxrcURXGRpC3ZG58gJUG%2BBFhm6al8VfkS4CrgYuDFkjZl%2BgdJZ%2Bl7gK8z%2BeXmrM9R/ZeRC8CVMcbLi6I4V%2BhXAqEPHIsx/qwoih2j0ejr/X7/%2B24mwOQZ1tO7DHgTcD6pajSMMT5UFMWXSatKTS5uLC8vn71hw4ZXA72aGmpUluU60tec36Y5Xm0AfifzauP0gW%2BSKmnTijH%2B%2BSXAi9y7mOn%2BZJaBd5KKBxWzlwsb7Hi/Xe78bjmEEJSZaoEdgeYZI2T8riNJl8Lan6h28Tpe%2BmbQMcf1Va1p/M2Tml0Nb1U6XalKDyaU4fmZM67c5OfH%2B2G64ZeO0doZ15zGskLzrAwGlniwrJTtbXYGpuPdLPp25vVO1qZjSRpokiVdGbQuJ%2B2ywzwfzfsacOf71QzcNZj/r4fjUfos2gbtwvfxOk0b2oX%2BMOPdauDlnYfO8fB%2BInqcaYd5Ddwm%2BEzBM0n76aT/TPP5tMEvIy%2B6Bv%2BPsGbgkxzWDHySw5qBT3JYM/BJDmsGPsnBDGxhvz/TPWuOAmswHewcbJkQ/wVDnzV41oPNYPv09Ajpc1ZIXyquwbMcrNiwCTiNZnkuSEZ/bEq/NXiWwP8BUFwRoWrkjx4AAAAASUVORK5CYII%3D" /> application error </h1> </header> <div id="error-content"> <p> <b>To disable this interface, set </b> <pre class="brush: python">conf.app.debug = False</pre> </p> <h2>Traceback</h2> <div id="traceback"> <pre class="brush: python">Traceback (most recent call last): File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/pecan/middleware/debug.py", line 289, in __call__ return self.app(environ, start_response) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/pecan/middleware/recursive.py", line 56, in __call__ return self.application(environ, start_response) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/pecan/core.py", line 768, in __call__ return super(Pecan, self).__call__(environ, start_response) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/pecan/core.py", line 660, in __call__ e File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/pecan/core.py", line 793, in handle_hooks return super(Pecan, self).handle_hooks(hooks, *args, **kw) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/pecan/core.py", line 320, in handle_hooks result = getattr(hook, hook_type)(*args) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/hooks.py", line 268, in on_error LOG.exception('API call failed: %s', error_msg, extra=extra) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 100, in func_wrapper return func(*args, **kwargs) File "/usr/lib/python2.7/logging/__init__.py", line 1185, in exception self.error(msg, *args, **kwargs) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 100, in func_wrapper return func(*args, **kwargs) File "/usr/lib/python2.7/logging/__init__.py", line 1178, in error self._log(ERROR, msg, args, **kwargs) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1271, in _log self.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 1281, in handle self.callHandlers(record) File "/usr/lib/python2.7/logging/__init__.py", line 1321, in callHandlers hdlr.handle(record) File "/usr/lib/python2.7/logging/__init__.py", line 749, in handle self.emit(record) File "/usr/lib/python2.7/logging/__init__.py", line 879, in emit self.handleError(record) File "/usr/lib/python2.7/logging/__init__.py", line 802, in handleError None, sys.stderr) File "/usr/lib/python2.7/traceback.py", line 124, in print_exception _print(file, 'Traceback (most recent call last):') File "/usr/lib/python2.7/traceback.py", line 13, in _print file.write(str+terminator) File "/opt/stackstorm/st2/local/lib/python2.7/site-packages/st2common/log.py", line 154, in write self._logger._log(self._level, message, None) File "/usr/lib/python2.7/logging/__init__.py", line 1270, in _log record = self.makeRecord(self.name, level, fn, lno, msg, args, exc_info, func, extra) File "/usr/lib/python2.7/logging/__init__.py", line 1244, in makeRecord rv = LogRecord(name, level, fn, lno, msg, args, exc_info, func) File "/usr/lib/python2.7/logging/__init__.py", line 266, in __init__ self.levelname = getLevelName(level) File "/usr/lib/python2.7/logging/__init__.py", line 167, in getLevelName return _levelNames.get(level, ("Level %s" % level)) RuntimeError: maximum recursion depth exceeded while getting the str of an object </pre> </div> <b>Want to debug this request?</b> <div id="debug"> You can <button onclick="debug_request(this)"> repeat this request </button> with a Python debugger breakpoint. </div> <h2>WSGI Environment</h2> <div id="environ"> <pre class="brush: python">{'CONTENT_LENGTH': '0', 'HTTP_ACCEPT': 'application/json, text/plain, */*', 'HTTP_ACCEPT_ENCODING': 'gzip, deflate, br', 'HTTP_ACCEPT_LANGUAGE': 'ru-RU,ru;q=0.8,en-US;q=0.6,en;q=0.4,uk;q=0.2', 'HTTP_AUTHORIZATION': 'Basic c3QyYWRtaW46c3QyYWRtaW4=', 'HTTP_COOKIE': '_reamaze_sc=1; _reamaze_uc=%7B%22fs%22%3A%222016-07-19T19%3A44%3A55.605Z%22%7D', 'HTTP_HOST': 'stackstorm.dev.confyrm.com,stackstorm.dev.confyrm.com', 'HTTP_ORIGIN': 'https://stackstorm.dev.confyrm.com', 'HTTP_REFERER': 'https://stackstorm.dev.confyrm.com/', 'HTTP_USER_AGENT': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.75 Safari/537.36', 'HTTP_X_FORWARDED_FOR': '10.144.101.18', 'HTTP_X_REAL_IP': '10.144.101.18', 'PATH_INFO': '/tokens', 'QUERY_STRING': '', 'RAW_URI': '/tokens', 'REMOTE_ADDR': '127.0.0.1', 'REMOTE_PORT': '51490', 'REQUEST_METHOD': 'POST', 'SCRIPT_NAME': '', 'SERVER_NAME': '127.0.0.1', 'SERVER_PORT': '9100', 'SERVER_PROTOCOL': 'HTTP/1.0', 'SERVER_SOFTWARE': 'gunicorn/19.6.0', 'gunicorn.socket': <eventlet.greenio.base.GreenSocket object at 0x7fc5d0d87110>, 'pecan.recursive.script_name': '', 'webob._body_file': (<_io.BufferedReader>, <gunicorn.http.body.Body object at 0x7fc5d07f3690>), 'webob._parsed_post_vars': (MultiDict([]), <_io.BytesIO object at 0x7fc5d0860650>), 'webob._parsed_query_vars': (GET([]), ''), 'webob.adhoc_attrs': {'context': {}, 'pecan': {'content_type': 'application/json', 'extension': None, 'routing_path': '/tokens'}}, 'webob.is_body_seekable': True, 'wsgi.errors': <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7fc5d07f3a50>, 'wsgi.file_wrapper': <class 'gunicorn.http.wsgi.FileWrapper'>, 'wsgi.input': <_io.BytesIO object at 0x7fc5d0860650>, 'wsgi.multiprocess': False, 'wsgi.multithread': True, 'wsgi.run_once': False, 'wsgi.url_scheme': 'http', 'wsgi.version': (1, 0)}</pre> </div> </div> </body> </html> | |
st2admin | |
•••••••• | |
CONNECT | |
remember | |
Documentation |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment