LyoKICogWDExIGtleWJvYXJkIGRyaXZlcgogKgogKiBDb3B5cmlnaHQgMTk5MyBCb2IgQW1zdGFkdAogKiBDb3B5cmlnaHQgMTk5NiBBbGJyZWNodCBLbGVpbmUgCiAqIENvcHlyaWdodCAxOTk3IERhdmlkIEZhdXJlCiAqIENvcHlyaWdodCAxOTk4IE1vcnRlbiBXZWxpbmRlcgogKiBDb3B5cmlnaHQgMTk5OCBVbHJpY2ggV2VpZ2FuZAogKiBDb3B5cmlnaHQgMTk5OSBPdmUgS+V2ZW4KICovCgojaW5jbHVkZSAiY29uZmlnLmgiCgojaW5jbHVkZSA8WDExL1hhdG9tLmg+CiNpbmNsdWRlIDxYMTEva2V5c3ltLmg+CgojaW5jbHVkZSAidHNfeGxpYi5oIgojaW5jbHVkZSAidHNfeHJlc291cmNlLmgiCiNpbmNsdWRlICJ0c194dXRpbC5oIgoKI2luY2x1ZGUgPGN0eXBlLmg+CiNpbmNsdWRlIDxzdHJpbmcuaD4KCiNpbmNsdWRlICJ3aW5kZWYuaCIKI2luY2x1ZGUgIndpbmdkaS5oIgojaW5jbHVkZSAid2luZS93aW51c2VyMTYuaCIKI2luY2x1ZGUgImRpbnB1dC5oIgojaW5jbHVkZSAiZGVidWd0b29scy5oIgojaW5jbHVkZSAidXNlci5oIgojaW5jbHVkZSAia2V5Ym9hcmQuaCIKI2luY2x1ZGUgIm1lc3NhZ2UuaCIKI2luY2x1ZGUgIndpbm5scy5oIgojaW5jbHVkZSAid2luLmgiCiNpbmNsdWRlICJ4MTFkcnYuaCIKCkRFRkFVTFRfREVCVUdfQ0hBTk5FTChrZXlib2FyZCkKREVDTEFSRV9ERUJVR19DSEFOTkVMKGtleSkKREVDTEFSRV9ERUJVR19DSEFOTkVMKGRpbnB1dCkKCmV4dGVybiBCWVRFIElucHV0S2V5U3RhdGVUYWJsZVsyNTZdOwoKZXh0ZXJuIExQQllURSBwS2V5U3RhdGVUYWJsZTsKCmludCBtaW5fa2V5Y29kZSwgbWF4X2tleWNvZGUsIGtleXN5bXNfcGVyX2tleWNvZGU7CldPUkQga2V5YzJ2a2V5WzI1Nl0sIGtleWMyc2NhblsyNTZdOwoKc3RhdGljIGludCBOdW1Mb2NrTWFzaywgQWx0R3JNYXNrOyAvKiBtYXNrIGluIHRoZSBYS2V5RXZlbnQgc3RhdGUgKi8Kc3RhdGljIGludCBrY0NvbnRyb2wsIGtjQWx0LCBrY1NoaWZ0LCBrY051bUxvY2ssIGtjQ2Fwc0xvY2s7IC8qIGtleWNvZGVzICovCgpzdGF0aWMgY2hhciBLRVlCT0FSRF9NYXBEZWFkS2V5c3ltKEtleVN5bSBrZXlzeW0pOwoKLyogS2V5Ym9hcmQgdHJhbnNsYXRpb24gdGFibGVzICovCiNkZWZpbmUgTUFJTl9MRU4gNDgKc3RhdGljIGNvbnN0IGludCBtYWluX2tleV9zY2FuW01BSU5fTEVOXSA9CnsKLyogdGhpcyBpcyBteSAoMTAyLWtleSkga2V5Ym9hcmQgbGF5b3V0LCBzb3JyeSBpZiBpdCBkb2Vzbid0IHF1aXRlIG1hdGNoIHlvdXJzICovCiAgIDB4MjksMHgwMiwweDAzLDB4MDQsMHgwNSwweDA2LDB4MDcsMHgwOCwweDA5LDB4MEEsMHgwQiwweDBDLDB4MEQsCiAgIDB4MTAsMHgxMSwweDEyLDB4MTMsMHgxNCwweDE1LDB4MTYsMHgxNywweDE4LDB4MTksMHgxQSwweDFCLAogICAweDFFLDB4MUYsMHgyMCwweDIxLDB4MjIsMHgyMywweDI0LDB4MjUsMHgyNiwweDI3LDB4MjgsMHgyQiwKICAgMHgyQywweDJELDB4MkUsMHgyRiwweDMwLDB4MzEsMHgzMiwweDMzLDB4MzQsMHgzNSwKICAgMHg1NiAvKiB0aGUgMTAybmQga2V5IChhY3R1YWxseSB0byB0aGUgcmlnaHQgb2YgbC1zaGlmdCkgKi8KfTsKCi8qKiogREVGSU5FIFlPVVIgTkVXIExBTkdVQUdFLVNQRUNJRklDIE1BUFBJTkdTIEJFTE9XLCBTRUUgRVhJU1RJTkcgVEFCTEVTICovCgovKiB0aGUgVksgbWFwcGluZ3MgZm9yIHRoZSBtYWluIGtleWJvYXJkIHdpbGwgYmUgYXV0by1hc3NpZ25lZCBhcyBiZWZvcmUsCiAgIHNvIHdoYXQgd2UgaGF2ZSBoZXJlIGlzIGp1c3QgdGhlIGNoYXJhY3RlciB0YWJsZXMgKi8KLyogb3JkZXI6IE5vcm1hbCwgU2hpZnQsIEFsdEdyLCBTaGlmdC1BbHRHciAqLwovKiBXZSByZWNvbW1lbmQgeW91IHdyaXRlIGp1c3Qgd2hhdCBpcyBndWFyYW50ZWVkIHRvIGJlIGNvcnJlY3QgKGkuZS4gd2hhdCdzCiAgIHdyaXR0ZW4gb24gdGhlIGtleWNhcHMpLCBub3QgdGhlIGJ1bmNoIG9mIHNwZWNpYWwgY2hhcmFjdGVycyBiZWhpbmQgQWx0R3IKICAgYW5kIFNoaWZ0LUFsdEdyIGlmIGl0IGNhbiB2YXJ5IGFtb25nIGRpZmZlcmVudCBYIHNlcnZlcnMgKi8KLyogUmVtZW1iZXIgdGhhdCB5b3VyIDEwMm5kIGtleSAodG8gdGhlIHJpZ2h0IG9mIGwtc2hpZnQpIHNob3VsZCBiZSBvbiBhCiAgIHNlcGFyYXRlIGxpbmUsIHNlZSBleGlzdGluZyB0YWJsZXMgKi8KLyogSWYgV2luZSBmYWlscyB0byBtYXRjaCB5b3VyIG5ldyB0YWJsZSwgdXNlIC1kZWJ1Z21zZyAra2V5IHRvIGZpbmQgb3V0IHdoeSAqLwovKiBSZW1lbWJlciB0byBhbHNvIGFkZCB5b3VyIG5ldyB0YWJsZSB0byB0aGUgbGF5b3V0IGluZGV4IHRhYmxlIGZhciBiZWxvdyEgKi8KCi8qKiogVW5pdGVkIFN0YXRlcyBrZXlib2FyZCBsYXlvdXQgKG1vc3RseSBjb250cmlidXRlZCBieSBVd2UgQm9ubmVzKSAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9VU1tNQUlOX0xFTl1bNF0gPQp7CiAiYH4iLCIxISIsIjJAIiwiMyMiLCI0JCIsIjUlIiwiNl4iLCI3JiIsIjgqIiwiOSgiLCIwKSIsIi1fIiwiPSsiLAogInFRIiwid1ciLCJlRSIsInJSIiwidFQiLCJ5WSIsInVVIiwiaUkiLCJvTyIsInBQIiwiW3siLCJdfSIsCiAiYUEiLCJzUyIsImREIiwiZkYiLCJnRyIsImhIIiwiakoiLCJrSyIsImxMIiwiOzoiLCInXCIiLCJcXHwiLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDwiLCIuPiIsIi8/Igp9OwoKLyoqKiBVbml0ZWQgU3RhdGVzIGtleWJvYXJkIGxheW91dCAocGhhbnRvbSBrZXkgdmVyc2lvbikgKi8KLyogKFhGcmVlODYgcmVwb3J0cyB0aGUgPD4ga2V5IGV2ZW4gaWYgaXQncyBub3QgcGh5c2ljYWxseSB0aGVyZSkgKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfVVNfcGhhbnRvbVtNQUlOX0xFTl1bNF0gPQp7CiAiYH4iLCIxISIsIjJAIiwiMyMiLCI0JCIsIjUlIiwiNl4iLCI3JiIsIjgqIiwiOSgiLCIwKSIsIi1fIiwiPSsiLAogInFRIiwid1ciLCJlRSIsInJSIiwidFQiLCJ5WSIsInVVIiwiaUkiLCJvTyIsInBQIiwiW3siLCJdfSIsCiAiYUEiLCJzUyIsImREIiwiZkYiLCJnRyIsImhIIiwiakoiLCJrSyIsImxMIiwiOzoiLCInXCIiLCJcXHwiLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDwiLCIuPiIsIi8/IiwKICI8PiIgLyogdGhlIHBoYW50b20ga2V5ICovCn07CgovKioqIEJyaXRpc2gga2V5Ym9hcmQgbGF5b3V0ICovCnN0YXRpYyBjb25zdCBjaGFyIG1haW5fa2V5X1VLW01BSU5fTEVOXVs0XSA9CnsKICJgIiwiMSEiLCIyXCIiLCIzoyIsIjQkIiwiNSUiLCI2XiIsIjcmIiwiOCoiLCI5KCIsIjApIiwiLV8iLCI9KyIsCiAicVEiLCJ3VyIsImVFIiwiclIiLCJ0VCIsInlZIiwidVUiLCJpSSIsIm9PIiwicFAiLCJbeyIsIl19IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCI7OiIsIidAIiwiI34iLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDwiLCIuPiIsIi8/IiwKICJcXHwiCn07CgovKioqIEZyZW5jaCBrZXlib2FyZCBsYXlvdXQgKGNvbnRyaWJ1dGVkIGJ5IEVyaWMgUG91ZWNoKSAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9GUltNQUlOX0xFTl1bNF0gPQp7CiAisiIsIiYxIiwi6TJ+IiwiXCIzIyIsIic0eyIsIig1WyIsIi02fCIsIug3IiwiXzhcXCIsIuc5XrEiLCLgMEAiLCIpsF0iLCI9K30iLAogImFBIiwieloiLCJlRSIsInJSIiwidFQiLCJ5WSIsInVVIiwiaUkiLCJvTyIsInBQIiwiXqgiLCIko6QiLAogInFRIiwic1PfIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCJtTSIsIvklIiwiKrUiLAogIndXIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIiw/IiwiOy4iLCI6LyIsIiGnIiwKICI8PiIKfTsKCi8qKiogSWNlbGFuZGljIGtleWJvYXJkIGxheW91dCAoY29udHJpYnV0ZWQgYnkgUu1raGFy8HVyIEVnaWxzc29uKSAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9JU1tNQUlOX0xFTl1bNF0gPQp7CiAisCIsIjEhIiwiMlwiIiwiMyMiLCI0JCIsIjUlIiwiNiYiLCI3L3siLCI4KFsiLCI5KV0iLCIwPX0iLCL21lxcIiwiLV8iLAogInFRQCIsIndXIiwiZUUiLCJyUiIsInRUIiwieVkiLCJ1VSIsImlJIiwib08iLCJwUCIsIvDQIiwiJz9+IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCLmxiIsIrReIiwiKypgIiwKICJ6WiIsInhYIiwiY0MiLCJ2ViIsImJCIiwibk4iLCJtTSIsIiw7IiwiLjoiLCL+3iIsCiAiPD58Igp9OwoKLyoqKiBHZXJtYW4ga2V5Ym9hcmQgbGF5b3V0IChjb250cmlidXRlZCBieSBVbHJpY2ggV2VpZ2FuZCkgKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfREVbTUFJTl9MRU5dWzRdID0KewogIl6wIiwiMSEiLCIyXCIiLCIzpyIsIjQkIiwiNSUiLCI2JiIsIjcveyIsIjgoWyIsIjkpXSIsIjA9fSIsIt8/XFwiLCInIiwKICJxUSIsIndXIiwiZUUiLCJyUiIsInRUIiwieloiLCJ1VSIsImlJIiwib08iLCJwUCIsIvzcIiwiKyp+IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCL21iIsIuTEIiwiI7QiLAogInlZIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDsiLCIuOiIsIi1fIiwKICI8PiIKfTsKCi8qKiogR2VybWFuIGtleWJvYXJkIGxheW91dCB3aXRob3V0IGRlYWQga2V5cyAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9ERV9ub2RlYWRbTUFJTl9MRU5dWzRdID0KewogIl6wIiwiMSEiLCIyXCIiLCIzpyIsIjQkIiwiNSUiLCI2JiIsIjcveyIsIjgoWyIsIjkpXSIsIjA9fSIsIt8/XFwiLCK0IiwKICJxUSIsIndXIiwiZUUiLCJyUiIsInRUIiwieloiLCJ1VSIsImlJIiwib08iLCJwUCIsIvzcIiwiKyp+IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCL21iIsIuTEIiwiIyciLAogInlZIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDsiLCIuOiIsIi1fIiwKICI8PiIKfTsKCi8qKiogU3dpc3MgR2VybWFuIGtleWJvYXJkIGxheW91dCAoY29udHJpYnV0ZWQgYnkgSm9uYXRoYW4gTmF5bG9yKSAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9TR1tNQUlOX0xFTl1bNF0gPQp7CiAip7AiLCIxK3wiLCIyXCJAIiwiMyojIiwiNOciLCI1JSIsIjYmrCIsIjcvpiIsIjgooiIsIjkpIiwiMD0iLCInP7QiLCJeYH4iLAogInFRIiwid1ciLCJlRSIsInJSIiwidFQiLCJ6WiIsInVVIiwiaUkiLCJvTyIsInBQIiwi/OhbIiwiqCFdIiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCL26SIsIuTgeyIsIiSjfSIsCiAieVkiLCJ4WCIsImNDIiwidlYiLCJiQiIsIm5OIiwibU0iLCIsOyIsIi46IiwiLV8iLAogIjw+XFwiCn07CgovKioqIFN3aXNzIEZyZW5jaCBrZXlib2FyZCBsYXlvdXQgKGNvbnRyaWJ1dGVkIGJ5IFBoaWxpcHBlIEZyb2lkZXZhdXgpICovCnN0YXRpYyBjb25zdCBjaGFyIG1haW5fa2V5X1NGW01BSU5fTEVOXVs0XSA9CnsKICKnsCIsIjErfCIsIjJcIkAiLCIzKiMiLCI05yIsIjUlIiwiNiasIiwiNy+mIiwiOCiiIiwiOSkiLCIwPSIsIic/tCIsIl5gfiIsCiAicVEiLCJ3VyIsImVFIiwiclIiLCJ0VCIsInpaIiwidVUiLCJpSSIsIm9PIiwicFAiLCLo/FsiLCKoIV0iLAogImFBIiwic1MiLCJkRCIsImZGIiwiZ0ciLCJoSCIsImpKIiwia0siLCJsTCIsIun2Iiwi4OR7IiwiJKN9IiwKICJ5WSIsInhYIiwiY0MiLCJ2ViIsImJCIiwibk4iLCJtTSIsIiw7IiwiLjoiLCItXyIsCiAiPD5cXCIKfTsKCi8qKiogTm9yd2VnaWFuIGtleWJvYXJkIGxheW91dCAoY29udHJpYnV0ZWQgYnkgT3ZlIEvldmVuKSAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9OT1tNQUlOX0xFTl1bNF0gPQp7CiAifKciLCIxISIsIjJcIkAiLCIzI6MiLCI0pCQiLCI1JSIsIjYmIiwiNy97IiwiOChbIiwiOSldIiwiMD19IiwiKz8iLCJcXGC0IiwKICJxUSIsIndXIiwiZUUiLCJyUiIsInRUIiwieVkiLCJ1VSIsImlJIiwib08iLCJwUCIsIuXFIiwiqF5+IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCL42CIsIubGIiwiJyoiLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDsiLCIuOiIsIi1fIiwKICI8PiIKfTsKCi8qKiogRGFuaXNoIGtleWJvYXJkIGxheW91dCAoY29udHJpYnV0ZWQgYnkgQmVydGhvIFN0dWx0aWVucykgKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfREFbTUFJTl9MRU5dWzRdID0KewogIr2nIiwiMSEiLCIyXCJAIiwiMyOjIiwiNKQkIiwiNSUiLCI2JiIsIjcveyIsIjgoWyIsIjkpXSIsIjA9fSIsIis/IiwitGB8IiwKICJxUSIsIndXIiwiZUUiLCJyUiIsInRUIiwieVkiLCJ1VSIsImlJIiwib08iLCJwUCIsIuXFIiwiqF5+IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCLmxiIsIvjYIiwiJyoiLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDsiLCIuOiIsIi1fIiwKICI8PlxcIgp9OwoKLyoqKiBTd2VkaXNoIGtleWJvYXJkIGxheW91dCAoY29udHJpYnV0ZWQgYnkgUGV0ZXIgQm9ydGFzKSAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9TRVtNQUlOX0xFTl1bNF0gPQp7CiAip70iLCIxISIsIjJcIkAiLCIzI6MiLCI0pCQiLCI1JSIsIjYmIiwiNy97IiwiOChbIiwiOSldIiwiMD19IiwiKz9cXCIsIrRgIiwKICJxUSIsIndXIiwiZUUiLCJyUiIsInRUIiwieVkiLCJ1VSIsImlJIiwib08iLCJwUCIsIuXFIiwiqF5+IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCL21iIsIuTEIiwiJyoiLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDsiLCIuOiIsIi1fIiwKICI8PnwiCn07CgovKioqIENhbmFkaWFuIEZyZW5jaCBrZXlib2FyZCBsYXlvdXQgKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfQ0ZbTUFJTl9MRU5dWzRdID0KewogIiN8XFwiLCIxIbEiLCIyXCJAIiwiMy+jIiwiNCSiIiwiNSWkIiwiNj+sIiwiNyamIiwiOCqyIiwiOSizIiwiMCm8IiwiLV+9IiwiPSu+IiwKICJxUSIsIndXIiwiZUUiLCJyUiIsInRUIiwieVkiLCJ1VSIsImlJIiwib0+nIiwicFC2IiwiXl5bIiwiuKhdIiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCI7On4iLCJgYHsiLCI8Pn0iLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLCctIiwiLiIsIunJIiwKICKru7AiCn07CgovKioqIFBvcnR1Z3Vlc2Uga2V5Ym9hcmQgbGF5b3V0ICovCnN0YXRpYyBjb25zdCBjaGFyIG1haW5fa2V5X1BUW01BSU5fTEVOXVs0XSA9CnsKICJcXKYiLCIxISIsIjJcIkAiLCIzI6MiLCI0JKciLCI1JSIsIjYmIiwiNy97IiwiOChbIiwiOSldIiwiMD19IiwiJz8iLCKruyIsCiAicVEiLCAgIndXIiwiZUUiLCAgInJSIiwgInRUIiwgInlZIiwgInVVIiwgImlJIiwgIm9PIiwgInBQIiwgIisqXFyoIiwiXFwnXFxgIiwKICJhQSIsICAic1MiLCJkRCIsICAiZkYiLCAiZ0ciLCAiaEgiLCAiakoiLCAia0siLCAibEwiLCAi58ciLCAiuqoiLCAiXFx+XFxeIiwKICJ6WiIsICAieFgiLCJjQyIsICAidlYiLCAiYkIiLCAibk4iLCAibU0iLCAiLDsiLCAiLjoiLCAiLV8iLAogIjw+Igp9OwoKLyoqKiBJdGFsaWFuIGtleWJvYXJkIGxheW91dCAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9JVFtNQUlOX0xFTl1bNF0gPQp7CiAiXFx8IiwiMSG5IiwiMlwisiIsIjOjsyIsIjQkvCIsIjUlvSIsIjYmviIsIjcveyIsIjgoWyIsIjkpXSIsIjA9fSIsIic/YCIsIuxefiIsCiAicVFAIiwid1ciLCJlRSIsInJSIiwidFQiLCJ5WSIsInVVIiwiaUkiLCJvT/giLCJwUP4iLCLo6VsiLCIrKl0iLAogImFBIiwic1PfIiwiZETwIiwiZkYiLCJnRyIsImhIIiwiakoiLCJrSyIsImxMIiwi8udAIiwi4LAjIiwi+aciLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NtSIsIiw7IiwiLjq3IiwiLV8iLAogIjw+fCIKfTsKCi8qKiogRmlubmlzaCBrZXlib2FyZCBsYXlvdXQgKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfRklbTUFJTl9MRU5dWzRdID0KewogIiIsIjEhIiwiMlwiQCIsIjMjIiwiNCQiLCI1JSIsIjYmIiwiNy97IiwiOChbIiwiOSldIiwiMD19IiwiKz9cXCIsIlwnYCIsCiAicVEiLCJ3VyIsImVFIiwiclIiLCJ0VCIsInlZIiwidVUiLCJpSSIsIm9PIiwicFAiLCIiLCJcIl5+IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCIiLCIiLCInKiIsCiAieloiLCJ4WCIsImNDIiwidlYiLCJiQiIsIm5OIiwibU0iLCIsOyIsIi46IiwiLV8iLAogIjw+fCIKfTsKCi8qKiogUnVzc2lhbiBrZXlib2FyZCBsYXlvdXQgKGNvbnRyaWJ1dGVkIGJ5IFBhdmVsIFJvc2tpbikgKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfUlVbTUFJTl9MRU5dWzRdID0KewogImB+IiwiMSEiLCIyQCIsIjMjIiwiNCQiLCI1JSIsIjZeIiwiNyYiLCI4KiIsIjkoIiwiMCkiLCItXyIsIj0rIiwKICJxUcrqIiwid1fD4yIsImVF1fUiLCJyUsvrIiwidFTF5SIsInlZzu4iLCJ1VcfnIiwiaUnb+yIsIm9P3f0iLCJwUNr6IiwiW3vI6CIsIl193/8iLAogImFBxuYiLCJzU9n5IiwiZETX9yIsImZGweEiLCJnR9DwIiwiaEjS8iIsImpKz+8iLCJrS8zsIiwibEzE5CIsIjs61vYiLCInXCLc/CIsIlxcfCIsCiAielrR8SIsInhY3v4iLCJjQ9PzIiwidlbN7SIsImJCyekiLCJuTtT0IiwibU3Y+CIsIiw8wuIiLCIuPsDgIiwiLz8iCn07CgovKioqIFNwYW5pc2gga2V5Ym9hcmQgbGF5b3V0IChjb250cmlidXRlZCBieSBKb3PpIE1hcmNvcyBM83BleikgKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfRVNbTUFJTl9MRU5dWzRdID0KewogIrqqXFwiLCIxIXwiLCIyXCJAIiwiM7cjIiwiNCQiLCI1JSIsIjYmrCIsIjcvIiwiOCgiLCI5KSIsIjA9IiwiJz8iLCKhvyIsCiAicVEiLCJ3VyIsImVFIiwiclIiLCJ0VCIsInlZIiwidVUiLCJpSSIsIm9PIiwicFAiLCJgXlsiLCIrKl0iLAogImFBIiwic1MiLCJkRCIsImZGIiwiZ0ciLCJoSCIsImpKIiwia0siLCJsTCIsIvHRIiwiJ6h7Iiwi58d9IiwKICJ6WiIsInhYIiwiY0MiLCJ2ViIsImJCIiwibk4iLCJtTSIsIiw7IiwiLjoiLCItXyIsCiAiPD4iCn07CgovKioqIEJlbGdpYW4ga2V5Ym9hcmQgbGF5b3V0ICoqKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfQkVbTUFJTl9MRU5dWzRdID0KewogIiIsIiYxfCIsIukyQCIsIlwiMyMiLCInNCIsIig1IiwipzZeIiwi6DciLCIhOCIsIuc5eyIsIuAwfSIsIimwIiwiLV8iLAogImFBIiwieloiLCJlRaQiLCJyUiIsInRUIiwieVkiLCJ1VSIsImlJIiwib08iLCJwUCIsIl6oWyIsIiQqXSIsCiAicVEiLCJzU98iLCJkRCIsImZGIiwiZ0ciLCJoSCIsImpKIiwia0siLCJsTCIsIm1NIiwi+SW0IiwitaNgIiwKICJ3VyIsInhYIiwiY0MiLCJ2ViIsImJCIiwibk4iLCIsPyIsIjsuIiwiOi8iLCI9K34iLAogIjw+XFwiCn07CgovKioqIEh1bmdhcmlhbiBrZXlib2FyZCBsYXlvdXQgKGNvbnRyaWJ1dGVkIGJ5IFpvbHThbiBLb3bhY3MpICovCnN0YXRpYyBjb25zdCBjaGFyIG1haW5fa2V5X0hVW01BSU5fTEVOXVs0XSA9CnsKICIwpyIsIjEnfiIsIjJcIrciLCIzK14iLCI0IaIiLCI1JbAiLCI2L7IiLCI3PWAiLCI4KP8iLCI5KbQiLCL21r0iLCL83KgiLCLz07giLAogInFRXFwiLCJ3V3wiLCJlRSIsInJSIiwidFQiLCJ6WiIsInVVIiwiaUnNIiwib0/4IiwicFAiLCL11fciLCL62tciLAogImFBIiwic1PwIiwiZETQIiwiZkZbIiwiZ0ddIiwiaEgiLCJqSu0iLCJrS7MiLCJsTKMiLCLpySQiLCLhwd8iLCL726QiLAogInlZPiIsInhYIyIsImNDJiIsInZWQCIsImJCeyIsIm5OfSIsIm1NIiwiLD87IiwiLjq3IiwiLV8qIiwKICLtzTwiCn07CgovKioqIFBvbGlzaCAocHJvZ3JhbW1lcidzKSBrZXlib2FyZCBsYXlvdXQgKioqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9QTFtNQUlOX0xFTl1bNF0gPQp7CiAiYH4iLCIxISIsIjJAIiwiMyMiLCI0JCIsIjUlIiwiNl4iLCI3JqciLCI4KiIsIjkoIiwiMCkiLCItXyIsIj0rIiwKICJxUSIsIndXIiwiZUXqyiIsInJSIiwidFQiLCJ5WSIsInVVIiwiaUkiLCJvT/PTIiwicFAiLCJbeyIsIl19IiwKICJhQbGhIiwic1O2piIsImREIiwiZkYiLCJnRyIsImhIIiwiakoiLCJrSyIsImxMs6MiLCI7OiIsIidcIiIsIlxcfCIsCiAielq/ryIsInhYvKwiLCJjQ+bGIiwidlYiLCJiQiIsIm5O8dEiLCJtTSIsIiw8IiwiLj4iLCIvPyIsCiAiPD58Igp9OwoKLyoqKiBDcm9hdGlhbiBrZXlib2FyZCBsYXlvdXQgc3BlY2lmaWMgZm9yIG1lIDxqZWxseUBzcmsuZmVyLmhyPiAqKiovCnN0YXRpYyBjb25zdCBjaGFyIG1haW5fa2V5X0hSX2plbGx5W01BSU5fTEVOXVs0XSA9CnsKICJgfiIsIjEhIiwiMkAiLCIzIyIsIjQkIiwiNSUiLCI2XiIsIjcmIiwiOCoiLCI5KCIsIjApIiwiLV8iLCI9KyIsCiAicVEiLCJ3VyIsImVFIiwiclIiLCJ0VCIsInlZIiwidVUiLCJpSSIsIm9PIiwicFAiLCJbe7mpIiwiXX3w0CIsCiAiYUEiLCJzUyIsImREIiwiZkYiLCJnRyIsImhIIiwiakoiLCJrSyIsImxMIiwiOzroyCIsIidcIubGIiwiXFx8vq4iLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDwiLCIuPiIsIi8/IiwKICI8PnwiCn07CgovKioqIENyb2F0aWFuIGtleWJvYXJkIGxheW91dCAqKiovCnN0YXRpYyBjb25zdCBjaGFyIG1haW5fa2V5X0hSW01BSU5fTEVOXVs0XSA9CnsKICK4qCIsIjEhIiwiMlwityIsIjMjXiIsIjQkoiIsIjUlsCIsIjYmsiIsIjcvYCIsIjgo/yIsIjkptCIsIjA9vSIsIic/qCIsIisquCIsCiAicVFcXCIsIndXfCIsImVFIiwiclIiLCJ0VCIsInpaIiwidVUiLCJpSSIsIm9PIiwicFAiLCK5qfciLCLw0NciLAogImFBIiwic1MiLCJkRCIsImZGWyIsImdHXSIsImhIIiwiakoiLCJrS7MiLCJsTKMiLCLoyCIsIubG3yIsIr6upCIsCiAieVkiLCJ4WCIsImNDIiwidlZAIiwiYkJ7Iiwibk59IiwibU2nIiwiLDsiLCIuOiIsIi1fLyIsCiAiPD4iCn07CgovKioqIEphcGFuZXNlIDEwNiBrZXlib2FyZCBsYXlvdXQgKioqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9KQV9qcDEwNltNQUlOX0xFTl1bNF0gPQp7CiAiMSEiLCIyXCIiLCIzIyIsIjQkIiwiNSUiLCI2JiIsIjcnIiwiOCgiLCI5KSIsIjB+IiwiLT0iLCJefiIsIlxcfCIsCiAicVEiLCJ3VyIsImVFIiwiclIiLCJ0VCIsInlZIiwidVUiLCJpSSIsIm9PIiwicFAiLCJAYCIsIlt7IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCI7KyIsIjoqIiwiXX0iLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDwiLCIuPiIsIi8/IiwKICJcXF8iLAp9OwoKLyoqKiBKYXBhbmVzZSBwYzk4eDEga2V5Ym9hcmQgbGF5b3V0ICoqKi8Kc3RhdGljIGNvbnN0IGNoYXIgbWFpbl9rZXlfSkFfcGM5OHgxW01BSU5fTEVOXVs0XSA9CnsKICIxISIsIjJcIiIsIjMjIiwiNCQiLCI1JSIsIjYmIiwiNyciLCI4KCIsIjkpIiwiMCIsIi09IiwiXmAiLCJcXHwiLAogInFRIiwid1ciLCJlRSIsInJSIiwidFQiLCJ5WSIsInVVIiwiaUkiLCJvTyIsInBQIiwiQH4iLCJbeyIsCiAiYUEiLCJzUyIsImREIiwiZkYiLCJnRyIsImhIIiwiakoiLCJrSyIsImxMIiwiOysiLCI6KiIsIl19IiwKICJ6WiIsInhYIiwiY0MiLCJ2ViIsImJCIiwibk4iLCJtTSIsIiw8IiwiLj4iLCIvPyIsCiAiXFxfIiwKfTsKCi8qKiogQnJhemlsaWFuIEFCTlQtMiBrZXlib2FyZCBsYXlvdXQgKGNvbnRyaWJ1dGVkIGJ5IFJhdWwgR29tZXMgRmVybmFuZGVzKSAqLwpzdGF0aWMgY29uc3QgY2hhciBtYWluX2tleV9QVF9icltNQUlOX0xFTl1bNF0gPQp7CiAiJ1wiIiwiMSEiLCIyQCIsIjMjIiwiNCQiLCI1JSIsIjZcIiIsIjcmIiwiOCoiLCI5KCIsIjApIiwiLV8iLCI9KyIsCiAicVEiLCJ3VyIsImVFIiwiclIiLCJ0VCIsInlZIiwidVUiLCJpSSIsIm9PIiwicFAiLCInYCIsIlt7IiwKICJhQSIsInNTIiwiZEQiLCJmRiIsImdHIiwiaEgiLCJqSiIsImtLIiwibEwiLCLnxyIsIn5eIiwiXX0iLAogInpaIiwieFgiLCJjQyIsInZWIiwiYkIiLCJuTiIsIm1NIiwiLDwiLCIuPiIsIi8/Igp9OwoKCi8qKiogTGF5b3V0IHRhYmxlLiBBZGQgeW91ciBrZXlib2FyZCBtYXBwaW5ncyB0byB0aGlzIGxpc3QgKi8Kc3RhdGljIGNvbnN0IHN0cnVjdCB7CiBXT1JEIGxhbmcsIGFuc2lfY29kZXBhZ2UsIG9lbV9jb2RlcGFnZTsKIGNvbnN0IGNoYXIgKCprZXkpW01BSU5fTEVOXVs0XTsKfSBtYWluX2tleV90YWJbXT17CiB7TUFLRUxBTkdJRChMQU5HX0VOR0xJU0gsU1VCTEFOR19FTkdMSVNIX1VTKSwgICAgIDEyNTIsIDQzNywgJm1haW5fa2V5X1VTfSwKIHtNQUtFTEFOR0lEKExBTkdfRU5HTElTSCxTVUJMQU5HX0VOR0xJU0hfVVMpLCAgICAgMTI1MiwgNDM3LCAmbWFpbl9rZXlfVVNfcGhhbnRvbX0sCiB7TUFLRUxBTkdJRChMQU5HX0VOR0xJU0gsU1VCTEFOR19FTkdMSVNIX1VLKSwgICAgIDEyNTIsIDg1MCwgJm1haW5fa2V5X1VLfSwKIHtNQUtFTEFOR0lEKExBTkdfR0VSTUFOLFNVQkxBTkdfREVGQVVMVCksICAgICAgICAgMTI1MiwgODUwLCAmbWFpbl9rZXlfREV9LAoge01BS0VMQU5HSUQoTEFOR19HRVJNQU4sU1VCTEFOR19ERUZBVUxUKSwgICAgICAgICAxMjUyLCA4NTAsICZtYWluX2tleV9ERV9ub2RlYWR9LAoge01BS0VMQU5HSUQoTEFOR19HRVJNQU4sU1VCTEFOR19HRVJNQU5fU1dJU1MpLCAgICAxMjUyLCA4NTAsICZtYWluX2tleV9TR30sCiB7TUFLRUxBTkdJRChMQU5HX1NXRURJU0gsU1VCTEFOR19TV0VESVNIKSwgICAgICAgIDEyNTIsIDg1MCwgJm1haW5fa2V5X1NFfSwKIHtNQUtFTEFOR0lEKExBTkdfTk9SV0VHSUFOLFNVQkxBTkdfREVGQVVMVCksICAgICAgMTI1MiwgODY1LCAmbWFpbl9rZXlfTk99LAoge01BS0VMQU5HSUQoTEFOR19EQU5JU0gsU1VCTEFOR19ERUZBVUxUKSwgICAgICAgICAxMjUyLCA4NjUsICZtYWluX2tleV9EQX0sCiB7TUFLRUxBTkdJRChMQU5HX0ZSRU5DSCxTVUJMQU5HX0RFRkFVTFQpLCAgICAgICAgIDEyNTIsIDg1MCwgJm1haW5fa2V5X0ZSfSwKIHtNQUtFTEFOR0lEKExBTkdfRlJFTkNILFNVQkxBTkdfRlJFTkNIX0NBTkFESUFOKSwgMTI1MiwgODYzLCAmbWFpbl9rZXlfQ0Z9LAoge01BS0VMQU5HSUQoTEFOR19GUkVOQ0gsU1VCTEFOR19GUkVOQ0hfQkVMR0lBTiksICAxMjUyLCA4NTAsICZtYWluX2tleV9CRX0sCiB7TUFLRUxBTkdJRChMQU5HX0ZSRU5DSCxTVUJMQU5HX0ZSRU5DSF9TV0lTUyksICAgIDEyNTIsIDg1MCwgJm1haW5fa2V5X1NGfSwKIHtNQUtFTEFOR0lEKExBTkdfV0FMT04sU1VCTEFOR19ERUZBVUxUKSwgICAgICAgICAgMTI1MiwgODUwLCAmbWFpbl9rZXlfQkV9LAoge01BS0VMQU5HSUQoTEFOR19QT1JUVUdVRVNFLFNVQkxBTkdfREVGQVVMVCksICAgICAxMjUyLCA4NjAsICZtYWluX2tleV9QVH0sCiB7TUFLRUxBTkdJRChMQU5HX0ZJTk5JU0gsU1VCTEFOR19ERUZBVUxUKSwgICAgICAgIDEyNTIsIDg1MCwgJm1haW5fa2V5X0ZJfSwKIHtNQUtFTEFOR0lEKExBTkdfUlVTU0lBTixTVUJMQU5HX0RFRkFVTFQpLCAgICAgICAgMTI1MSwgODY2LCAmbWFpbl9rZXlfUlV9LAoge01BS0VMQU5HSUQoTEFOR19TUEFOSVNILFNVQkxBTkdfREVGQVVMVCksICAgICAgICAxMjUyLCA4NTAsICZtYWluX2tleV9FU30sCiB7TUFLRUxBTkdJRChMQU5HX0RVVENILFNVQkxBTkdfRFVUQ0hfQkVMR0lBTiksICAgIDEyNTIsIDg1MCwgJm1haW5fa2V5X0JFfSwKIHtNQUtFTEFOR0lEKExBTkdfSVRBTElBTixTVUJMQU5HX0RFRkFVTFQpLCAgICAgICAgMTI1MiwgODUwLCAmbWFpbl9rZXlfSVR9LAoge01BS0VMQU5HSUQoTEFOR19JQ0VMQU5ESUMsU1VCTEFOR19ERUZBVUxUKSwgICAgICAxMjUyLCA4NTAsICZtYWluX2tleV9JU30sCiB7TUFLRUxBTkdJRChMQU5HX0hVTkdBUklBTixTVUJMQU5HX0RFRkFVTFQpLCAgICAgIDEyNTIsIDg1MCwgJm1haW5fa2V5X0hVfSwKIHtNQUtFTEFOR0lEKExBTkdfUE9MSVNILFNVQkxBTkdfREVGQVVMVCksICAgICAgICAgMTI1MCwgODUyLCAmbWFpbl9rZXlfUEx9LAoge01BS0VMQU5HSUQoTEFOR19DUk9BVElBTixTVUJMQU5HX0NST0FUSUFOKSwgICAgICAxMjUwLCA4NTIsICZtYWluX2tleV9IUn0sCiB7TUFLRUxBTkdJRChMQU5HX0NST0FUSUFOLFNVQkxBTkdfQ1JPQVRJQU4pLCAgICAgIDEyNTAsIDg1MiwgJm1haW5fa2V5X0hSX2plbGx5fSwKIHtNQUtFTEFOR0lEKExBTkdfSkFQQU5FU0UsU1VCTEFOR19ERUZBVUxUKSwgICAgICAgIDkzMiwgOTMyLCAmbWFpbl9rZXlfSkFfanAxMDZ9LAoge01BS0VMQU5HSUQoTEFOR19KQVBBTkVTRSxTVUJMQU5HX0RFRkFVTFQpLCAgICAgICAgOTMyLCA5MzIsICZtYWluX2tleV9KQV9wYzk4eDF9LAoge01BS0VMQU5HSUQoTEFOR19QT1JUVUdVRVNFLFNVQkxBTkdfUE9SVFVHVUVTRV9CUkFaSUxJQU4pLCAxMjUyLCA4NjAsICZtYWluX2tleV9QVF9icn0sCgogezB9IC8qIHNlbnRpbmVsICovCn07CnN0YXRpYyB1bnNpZ25lZCBrYmRfbGF5b3V0PTA7IC8qIGluZGV4IGludG8gYWJvdmUgdGFibGUgb2YgbGF5b3V0cyAqLwoKLyogbWF5YmUgbW9yZSBvZiB0aGVzZSBzY2FuY29kZXMgc2hvdWxkIGJlIGV4dGVuZGVkPyAqLwogICAgICAgICAgICAgICAgLyogZXh0ZW5kZWQgbXVzdCBiZSBzZXQgZm9yIEFMVF9SLCBDVFJMX1IsCiAgICAgICAgICAgICAgICAgICBJTlMsIERFTCwgSE9NRSwgRU5ELCBQQUdFX1VQLCBQQUdFX0RPV04sIEFSUk9XIGtleXMsCiAgICAgICAgICAgICAgICAgICBrZXlwYWQgLyBhbmQga2V5cGFkIEVOVEVSIChTREsgMy4xIFZvbC4zIHAgMTM4KSAqLwogICAgICAgICAgICAgICAgLyogRklYTUUgc2hvdWxkIHdlIHNldCBleHRlbmRlZCBiaXQgZm9yIE51bUxvY2sgPyBNeQogICAgICAgICAgICAgICAgICogV2luZG93cyBkb2VzIC4uLiBERiAqLwogICAgICAgICAgICAgICAgLyogWWVzLCB0byBkaXN0aW5ndWlzaCBiYXNlZCBvbiBzY2FuIGNvZGVzLCBhbHNvCiAgICAgICAgICAgICAgICAgICBmb3IgUHJ0U2NuIGtleSAuLi4gR0EgKi8KCnN0YXRpYyBjb25zdCBpbnQgc3BlY2lhbF9rZXlfdmtleVtdID0KewogICAgVktfQkFDSywgVktfVEFCLCAwLCBWS19DTEVBUiwgMCwgVktfUkVUVVJOLCAwLCAwLCAgICAgICAgICAgLyogRkYwOCAqLwogICAgMCwgMCwgMCwgVktfUEFVU0UsIFZLX1NDUk9MTCwgMCwgMCwgMCwgICAgICAgICAgICAgICAgICAgICAgLyogRkYxMCAqLwogICAgMCwgMCwgMCwgVktfRVNDQVBFICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLyogRkYxOCAqLwp9OwpzdGF0aWMgY29uc3QgaW50IHNwZWNpYWxfa2V5X3NjYW5bXSA9CnsKICAgIDB4MEUsIDB4MEYsIDAsIC8qPyovIDAsIDAsIDB4MUMsIDAsIDAsICAgICAgICAgICAgICAgICAgICAgIC8qIEZGMDggKi8KICAgIDAsICAgIDAsICAgIDAsIDB4NDUsIDB4NDYsIDAgICAsIDAsIDAsICAgICAgICAgICAgICAgICAgICAgIC8qIEZGMTAgKi8KICAgIDAsICAgIDAsICAgIDAsIDB4MDEgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGMTggKi8KfTsKCnN0YXRpYyBjb25zdCBpbnQgY3Vyc29yX2tleV92a2V5W10gPQp7CiAgICBWS19IT01FLCBWS19MRUZULCBWS19VUCwgVktfUklHSFQsIFZLX0RPV04sIFZLX1BSSU9SLCAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVktfTkVYVCwgVktfRU5EICAgICAgICAgIC8qIEZGNTAgKi8KfTsKc3RhdGljIGNvbnN0IGludCBjdXJzb3Jfa2V5X3NjYW5bXSA9CnsKICAgIDB4MTQ3LCAweDE0QiwgMHgxNDgsIDB4MTRELCAweDE1MCwgMHgxNDksIDB4MTUxLCAweDE0RiAgICAgIC8qIEZGNTAgKi8KfTsKCnN0YXRpYyBjb25zdCBpbnQgbWlzY19rZXlfdmtleVtdID0KewogICAgVktfU0VMRUNULCBWS19TTkFQU0hPVCwgVktfRVhFQ1VURSwgVktfSU5TRVJULCAwLCAwLCAwLCAwLCAgLyogRkY2MCAqLwogICAgVktfQ0FOQ0VMLCBWS19IRUxQLCBWS19DQU5DRUwsIFZLX0NBTkNFTCAgICAgICAgICAgICAgICAgICAgLyogRkY2OCAqLwp9OwpzdGF0aWMgY29uc3QgaW50IG1pc2Nfa2V5X3NjYW5bXSA9CnsKICAgIC8qPyovIDAsIDB4MTM3LCAvKj8qLyAwLCAweDE1MiwgMCwgMCwgMCwgMCwgICAgICAgICAgICAgICAgIC8qIEZGNjAgKi8KICAgIC8qPyovIDAsIC8qPyovIDAsIDB4MzgsIDB4MTQ2ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGNjggKi8KfTsKCnN0YXRpYyBjb25zdCBpbnQga2V5cGFkX2tleV92a2V5W10gPQp7CiAgICAwLCBWS19OVU1MT0NLLCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAJLyogRkY3RSAqLwogICAgMCwgMCwgMCwgMCwgMCwgMCwgMCwgMCwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLyogRkY4MCAqLwogICAgMCwgMCwgMCwgMCwgMCwgVktfUkVUVVJOLCAwLCAwLCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLyogRkY4OCAqLwogICAgMCwgMCwgMCwgMCwgMCwgVktfSE9NRSwgVktfTEVGVCwgVktfVVAsICAgICAgICAgICAgICAgICAgICAgLyogRkY5MCAqLwogICAgVktfUklHSFQsIFZLX0RPV04sIFZLX1BSSU9SLCBWS19ORVhULCBWS19FTkQsIDAsCgkJCQkgVktfSU5TRVJULCBWS19ERUxFVEUsICAgICAgICAgIC8qIEZGOTggKi8KICAgIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGQTAgKi8KICAgIDAsIDAsIFZLX01VTFRJUExZLCBWS19BREQsIFZLX1NFUEFSQVRPUiwgVktfU1VCVFJBQ1QsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVktfREVDSU1BTCwgVktfRElWSURFLCAgICAgICAgICAgLyogRkZBOCAqLwogICAgVktfTlVNUEFEMCwgVktfTlVNUEFEMSwgVktfTlVNUEFEMiwgVktfTlVNUEFEMywgVktfTlVNUEFENCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgIFZLX05VTVBBRDUsIFZLX05VTVBBRDYsIFZLX05VTVBBRDcsIC8qIEZGQjAgKi8KICAgIFZLX05VTVBBRDgsIFZLX05VTVBBRDkgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGQjggKi8KfTsKc3RhdGljIGNvbnN0IGludCBrZXlwYWRfa2V5X3NjYW5bXSA9CnsKICAgIDB4MTM4LCAweDE0NSwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGN0UgKi8KICAgIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGODAgKi8KICAgIDAsIDAsIDAsIDAsIDAsIDB4MTFDLCAwLCAwLCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGODggKi8KICAgIDAsIDAsIDAsIDAsIDAsIDB4NDcsIDB4NEIsIDB4NDgsICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGOTAgKi8KICAgIDB4NEQsIDB4NTAsIDB4NDksIDB4NTEsIDB4NEYsIDB4NEMsIDB4NTIsIDB4NTMsICAgICAgICAgICAgIC8qIEZGOTggKi8KICAgIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGQTAgKi8KICAgIDAsIDAsIDB4MzcsIDB4NEUsIC8qPyovIDAsIDB4NEEsIDB4NTMsIDB4MTM1LCAgICAgICAgICAgICAgIC8qIEZGQTggKi8KICAgIDB4NTIsIDB4NEYsIDB4NTAsIDB4NTEsIDB4NEIsIDB4NEMsIDB4NEQsIDB4NDcsICAgICAgICAgICAgIC8qIEZGQjAgKi8KICAgIDB4NDgsIDB4NDkgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGQjggKi8KfTsKICAgIApzdGF0aWMgY29uc3QgaW50IGZ1bmN0aW9uX2tleV92a2V5W10gPQp7CiAgICBWS19GMSwgVktfRjIsICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvKiBGRkJFICovCiAgICBWS19GMywgVktfRjQsIFZLX0Y1LCBWS19GNiwgVktfRjcsIFZLX0Y4LCBWS19GOSwgVktfRjEwLCAgICAvKiBGRkMwICovCiAgICBWS19GMTEsIFZLX0YxMiwgVktfRjEzLCBWS19GMTQsIFZLX0YxNSwgVktfRjE2ICAgICAgICAgICAgICAvKiBGRkM4ICovCn07CnN0YXRpYyBjb25zdCBpbnQgZnVuY3Rpb25fa2V5X3NjYW5bXSA9CnsKICAgIDB4M0IsIDB4M0MsICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGQkUgKi8KICAgIDB4M0QsIDB4M0UsIDB4M0YsIDB4NDAsIDB4NDEsIDB4NDIsIDB4NDMsIDB4NDQsICAgICAgICAgICAgIC8qIEZGQzAgKi8KICAgIDB4NTcsIDB4NTgsIDAsIDAsIDAsIDAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIEZGQzggKi8KfTsKCnN0YXRpYyBjb25zdCBpbnQgbW9kaWZpZXJfa2V5X3ZrZXlbXSA9CnsKICAgIFZLX1NISUZULCBWS19TSElGVCwgVktfQ09OVFJPTCwgVktfQ09OVFJPTCwgVktfQ0FQSVRBTCwgMCwgLyogRkZFMSAqLwogICAgVktfTUVOVSwgVktfTUVOVSwgVktfTUVOVSwgVktfTUVOVSAgICAgICAgICAgICAgICAgICAgICAgICAvKiBGRkU3ICovCn07CnN0YXRpYyBjb25zdCBpbnQgbW9kaWZpZXJfa2V5X3NjYW5bXSA9CnsKICAgIDB4MkEsIDB4MzYsIDB4MUQsIDB4MTFELCAweDNBLCAwLCAgICAgICAgICAgICAgICAgICAgICAgICAgLyogRkZFMSAqLwogICAgMHgzOCwgMHgxMzgsIDB4MzgsIDB4MTM4ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvKiBGRkU3ICovCn07CgovKiBSZXR1cm5zIHRoZSBXaW5kb3dzIHZpcnR1YWwga2V5IGNvZGUgYXNzb2NpYXRlZCB3aXRoIHRoZSBYIGV2ZW50IDxlPiAqLwpzdGF0aWMgV09SRCBFVkVOVF9ldmVudF90b192a2V5KCBYS2V5RXZlbnQgKmUpCnsKICAgIEtleVN5bSBrZXlzeW07CgogICAgVFNYTG9va3VwU3RyaW5nKGUsIE5VTEwsIDAsICZrZXlzeW0sIE5VTEwpOwoKICAgIGlmICgoa2V5c3ltID49IDB4RkZBRSkgJiYgKGtleXN5bSA8PSAweEZGQjkpICYmIChrZXlzeW0gIT0gMHhGRkFGKSAKCSYmIChlLT5zdGF0ZSAmIE51bUxvY2tNYXNrKSkgCiAgICAgICAgLyogT25seSB0aGUgS2V5cGFkIGtleXMgMC05IGFuZCAuIHNlbmQgZGlmZmVyZW50IGtleXN5bXMKICAgICAgICAgKiBkZXBlbmRpbmcgb24gdGhlIE51bUxvY2sgc3RhdGUgKi8KICAgICAgICByZXR1cm4ga2V5cGFkX2tleV92a2V5WyhrZXlzeW0gJiAweEZGKSAtIDB4N0VdOwoKICAgIHJldHVybiBrZXljMnZrZXlbZS0+a2V5Y29kZV07Cn0KCnN0YXRpYyBCT09MIE51bVN0YXRlPUZBTFNFLCBDYXBzU3RhdGU9RkFMU0UsIEFsdEdyU3RhdGU9RkFMU0U7CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJS0VZQk9BUkRfR2VuZXJhdGVNc2cKICoKICogR2VuZXJhdGUgRG93bitVcCBtZXNzYWdlcyB3aGVuIE51bUxvY2sgb3IgQ2Fwc0xvY2sgaXMgcHJlc3NlZC4KICoKICogQ29udmVudGlvbiA6IGNhbGxlZCB3aXRoIHZrZXkgb25seSBWS19OVU1MT0NLIG9yIFZLX0NBUElUQUwKICoKICovCnN0YXRpYyB2b2lkIEtFWUJPQVJEX0dlbmVyYXRlTXNnKCBXT1JEIHZrZXksIFdPUkQgc2NhbiwgaW50IEV2dHlwZSwgSU5UIGV2ZW50X3gsIElOVCBldmVudF95LAogICAgICAgICAgICAgICAgICAgICAgICAgICBEV09SRCBldmVudF90aW1lICkKewogIEJPT0wgKiBTdGF0ZSA9ICh2a2V5PT1WS19OVU1MT0NLPyAmTnVtU3RhdGUgOiAmQ2Fwc1N0YXRlKTsKICBEV09SRCB1cCwgZG93bjsKCiAgaWYgKCpTdGF0ZSkgewogICAgLyogVGhlIElOVEVSTUVESUFSWSBzdGF0ZSBtZWFucyA6IGp1c3QgYWZ0ZXIgYSAncHJlc3MnIGV2ZW50LCBpZiBhICdyZWxlYXNlJyBldmVudCBjb21lcywKICAgICAgIGRvbid0IHRyZWF0IGl0LiBJdCdzIGZyb20gdGhlIHNhbWUga2V5IHByZXNzLiBUaGVuIHRoZSBzdGF0ZSBnb2VzIHRvIE9OLgogICAgICAgQW5kIGZyb20gdGhlcmUsIGEgJ3JlbGVhc2UnIGV2ZW50IHdpbGwgc3dpdGNoIG9mZiB0aGUgdG9nZ2xlIGtleS4gKi8KICAgICpTdGF0ZT1GQUxTRTsKICAgIFRSQUNFKCJJTlRFUk0gOiBkb25cJ3QgdHJlYXQgcmVsZWFzZSBvZiB0b2dnbGUga2V5LiBJbnB1dEtleVN0YXRlVGFibGVbJSN4XSA9ICUjeFxuIix2a2V5LHBLZXlTdGF0ZVRhYmxlW3ZrZXldKTsKICB9IGVsc2UKICAgIHsKICAgICAgICBkb3duID0gKHZrZXk9PVZLX05VTUxPQ0sgPyBLRVlFVkVOVEZfRVhURU5ERURLRVkgOiAwKTsKICAgICAgICB1cCA9ICh2a2V5PT1WS19OVU1MT0NLID8gS0VZRVZFTlRGX0VYVEVOREVES0VZIDogMCkgfCBLRVlFVkVOVEZfS0VZVVA7CglpZiAoIHBLZXlTdGF0ZVRhYmxlW3ZrZXldICYgMHgxICkgLyogaXQgd2FzIE9OICovCgkgIHsKCSAgICBpZiAoRXZ0eXBlIT1LZXlQcmVzcykKCSAgICAgIHsKCQlUUkFDRSgiT04gKyBLZXlSZWxlYXNlID0+IGdlbmVyYXRpbmcgRE9XTiBhbmQgVVAgbWVzc2FnZXMuXG4iKTsKCSAgICAgICAgS0VZQk9BUkRfU2VuZEV2ZW50KCB2a2V5LCBzY2FuLCBkb3duLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF94LCBldmVudF95LCBldmVudF90aW1lICk7CgkgICAgICAgIEtFWUJPQVJEX1NlbmRFdmVudCggdmtleSwgc2NhbiwgdXAsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF94LCBldmVudF95LCBldmVudF90aW1lICk7CgkJKlN0YXRlPUZBTFNFOwoJCXBLZXlTdGF0ZVRhYmxlW3ZrZXldICY9IH4weDAxOyAvKiBUb2dnbGUgc3RhdGUgdG8gb2ZmLiAqLyAKCSAgICAgIH0gCgkgIH0KCWVsc2UgLyogaXQgd2FzIE9GRiAqLwoJICBpZiAoRXZ0eXBlPT1LZXlQcmVzcykKCSAgICB7CgkgICAgICBUUkFDRSgiT0ZGICsgS2V5cHJlc3MgPT4gZ2VuZXJhdGluZyBET1dOIGFuZCBVUCBtZXNzYWdlcy5cbiIpOwoJICAgICAgS0VZQk9BUkRfU2VuZEV2ZW50KCB2a2V5LCBzY2FuLCBkb3duLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZXZlbnRfeCwgZXZlbnRfeSwgZXZlbnRfdGltZSApOwoJICAgICAgS0VZQk9BUkRfU2VuZEV2ZW50KCB2a2V5LCBzY2FuLCB1cCwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF94LCBldmVudF95LCBldmVudF90aW1lICk7CgkgICAgICAqU3RhdGU9VFJVRTsgLyogR29lcyB0byBpbnRlcm1lZGlhcnkgc3RhdGUgYmVmb3JlIGdvaW5nIHRvIE9OICovCgkgICAgICBwS2V5U3RhdGVUYWJsZVt2a2V5XSB8PSAweDAxOyAvKiBUb2dnbGUgc3RhdGUgdG8gb24uICovCgkgICAgfQogICAgfQp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIEtFWUJPQVJEX1VwZGF0ZU9uZVN0YXRlCiAqCiAqIFVwZGF0ZXMgaW50ZXJuYWwgc3RhdGUgZm9yIDx2a2V5PiwgZGVwZW5kaW5nIG9uIGtleSA8c3RhdGU+IHVuZGVyIFgKICoKICovCnN0YXRpYyB2b2lkIEtFWUJPQVJEX1VwZGF0ZU9uZVN0YXRlICggaW50IHZrZXksIGludCBzdGF0ZSApCnsKICAgIC8qIERvIHNvbWV0aGluZyBpZiBpbnRlcm5hbCB0YWJsZSBzdGF0ZSAhPSBYIHN0YXRlIGZvciBrZXljb2RlICovCiAgICBpZiAoKChwS2V5U3RhdGVUYWJsZVt2a2V5XSAmIDB4ODApIT0wKSAhPSBzdGF0ZSkKICAgIHsKICAgICAgICBUUkFDRSgiQWRqdXN0aW5nIHN0YXRlIGZvciB2a2V5ICUjLjJ4LiBTdGF0ZSBiZWZvcmUgJSMuMnggXG4iLAogICAgICAgICAgICAgIHZrZXksIHBLZXlTdGF0ZVRhYmxlW3ZrZXldKTsKCiAgICAgICAgLyogRmFrZSBrZXkgYmVpbmcgcHJlc3NlZCBpbnNpZGUgd2luZSAqLwoJS0VZQk9BUkRfU2VuZEV2ZW50KCB2a2V5LCAwLCBzdGF0ZT8gMCA6IEtFWUVWRU5URl9LRVlVUCwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAwLCAwLCBHZXRUaWNrQ291bnQoKSApOwoKICAgICAgICBUUkFDRSgiU3RhdGUgYWZ0ZXIgJSMuMnggXG4iLHBLZXlTdGF0ZVRhYmxlW3ZrZXldKTsKICAgIH0KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBYMTFEUlZfS0VZQk9BUkRfVXBkYXRlU3RhdGUKICoKICogVXBkYXRlIG1vZGlmaWVycyBzdGF0ZSAoQ3RybCwgQWx0LCBTaGlmdCkKICogd2hlbiB3aW5kb3cgaXMgYWN0aXZhdGVkIChjYWxsZWQgYnkgRVZFTlRfRm9jdXNJbiBpbiBldmVudC5jKQogKgogKiBUaGlzIGhhbmRsZXMgdGhlIGNhc2Ugd2hlcmUgb25lIHVzZXMgQ3RybCsuLi4gQWx0Ky4uLiBvciBTaGlmdCsuLiB0byBzd2l0Y2gKICogZnJvbSB3aW5lIHRvIGFub3RoZXIgYXBwbGljYXRpb24gYW5kIGJhY2suCiAqIFRvZ2dsZSBrZXlzIGFyZSBoYW5kbGVkIGluIEhhbmRsZUV2ZW50LiAoYmVjYXVzZSBYUXVlcnlLZXltYXAgc2F5cyBub3RoaW5nCiAqICBhYm91dCB0aGVtKQogKi8Kdm9pZCBYMTFEUlZfS0VZQk9BUkRfVXBkYXRlU3RhdGUgKCB2b2lkICkKewovKiBleHRyYWN0IGEgYml0IGZyb20gdGhlIGNoYXJbMzJdIGJpdCBzdWl0ZSAqLwojZGVmaW5lIEtleVN0YXRlKGtleWNvZGUpICgoa2V5c19yZXR1cm5ba2V5Y29kZS84XSAmICgxPDwoa2V5Y29kZSU4KSkpIT0wKQoKICAgIGNoYXIga2V5c19yZXR1cm5bMzJdOwoKICAgIFRSQUNFKCJjYWxsZWRcbiIpOwogICAgaWYgKCFUU1hRdWVyeUtleW1hcChkaXNwbGF5LCBrZXlzX3JldHVybikpIHsKICAgICAgICBFUlIoIkVycm9yIGdldHRpbmcga2V5bWFwICEiKTsKICAgICAgICByZXR1cm47CiAgICB9CgogICAgLyogQWRqdXN0IHRoZSBBTFQgYW5kIENPTlRST0wgc3RhdGUgaWYgYW55IGhhcyBiZWVuIGNoYW5nZWQgb3V0c2lkZSB3aW5lICovCiAgICBLRVlCT0FSRF9VcGRhdGVPbmVTdGF0ZShWS19NRU5VLCBLZXlTdGF0ZShrY0FsdCkpOwogICAgS0VZQk9BUkRfVXBkYXRlT25lU3RhdGUoVktfQ09OVFJPTCwgS2V5U3RhdGUoa2NDb250cm9sKSk7CiAgICBLRVlCT0FSRF9VcGRhdGVPbmVTdGF0ZShWS19TSElGVCwgS2V5U3RhdGUoa2NTaGlmdCkpOwojdW5kZWYgS2V5U3RhdGUKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBYMTFEUlZfS0VZQk9BUkRfSGFuZGxlRXZlbnQKICoKICogSGFuZGxlIGEgWCBrZXkgZXZlbnQKICovCnZvaWQgWDExRFJWX0tFWUJPQVJEX0hhbmRsZUV2ZW50KCBXTkQgKnBXbmQsIFhLZXlFdmVudCAqZXZlbnQgKQp7CiAgICBjaGFyIFN0clsyNF07IAogICAgWENvbXBvc2VTdGF0dXMgY3M7IAogICAgS2V5U3ltIGtleXN5bTsKICAgIFdPUkQgdmtleSA9IDAsIGJTY2FuOwogICAgRFdPUkQgZHdGbGFnczsKICAgIHN0YXRpYyBCT09MIGZvcmNlX2V4dGVuZGVkID0gRkFMU0U7IC8qIGhhY2sgZm9yIEFsdEdyIHRyYW5zbGF0aW9uICovCiAgICAKICAgIGludCBhc2NpaV9jaGFyczsKCiAgICBJTlQgZXZlbnRfeCA9IChwV25kPyBwV25kLT5yZWN0V2luZG93LmxlZnQgOiAwKSArIGV2ZW50LT54OwogICAgSU5UIGV2ZW50X3kgPSAocFduZD8gcFduZC0+cmVjdFdpbmRvdy50b3AgIDogMCkgKyBldmVudC0+eTsKICAgIERXT1JEIGV2ZW50X3RpbWUgPSBldmVudC0+dGltZSAtIFgxMURSVl9zZXJ2ZXJfc3RhcnR0aWNrczsKCiAgICAvKiB0aGlzIGFsbG93cyBzdXBwb3J0IGZvciBkZWFkIGtleXMgKi8KICAgIGlmICgoZXZlbnQtPmtleWNvZGUgPj4gOCkgPT0gMHgxMCkKCWV2ZW50LT5rZXljb2RlPShldmVudC0+a2V5Y29kZSAmIDB4ZmYpOwoKICAgIGFzY2lpX2NoYXJzID0gVFNYTG9va3VwU3RyaW5nKGV2ZW50LCBTdHIsIDEsICZrZXlzeW0sICZjcyk7CgogICAgVFJBQ0VfKGtleSkoInN0YXRlID0gJVhcbiIsIGV2ZW50LT5zdGF0ZSk7CgogICAgLyogSWYgWEtCIGV4dGVuc2lvbnMgaXMgdXNlZCwgdGhlIHN0YXRlIG1hc2sgZm9yIEFsdEdyIHdpbGwgdXNlZCB0aGUgZ3JvdXAKICAgICAgIGluZGV4IGluc3RlYWQgb2YgdGhlIG1vZGlmaWVyIG1hc2suIFRoZSBncm91cCBpbmRleCBpcyBzZXQgaW4gYml0cwogICAgICAgMTMtMTQgb2YgdGhlIHN0YXRlIGZpZWxkIGluIHRoZSBYS2V5RXZlbnQgc3RydWN0dXJlLiBTbyBpZiBBbHRHciBpcwogICAgICAgcHJlc3NlZCwgbG9vayBpZiB0aGUgZ3JvdXAgaW5kZXggaXMgZGlmZXJlbnQgdGhhbiAwLiBGcm9tIFhLQgogICAgICAgZXh0ZW5zaW9uIGRvY3VtZW50YXRpb24sIHRoZSBncm91cCBpbmRleCBzaG91bGQgZm9yIEFsdEdyIHNob3VsZCAKICAgICAgIGJlIDIgKGV2ZW50LT5zdGF0ZSA9IDB4MjAwMCkuIEl0J3MgcHJvYmFibHkgYmV0dGVyIHRvIG5vdCBhc3N1bWUgYQogICAgICAgcHJlZGVmaW5lZCBncm91cCBpbmRleCBhbmQgZmluZCBpdCBkeW5hbWljYWxseQoKICAgICAgIFJlZjogWCBLZXlib2FyZCBFeHRlbnNpb246IExpYnJhcnkgc3BlY2lmaWNhdGlvbiAoc2VjdGlvbiAxNC4xLjEgYW5kIDE3LjEuMSkgKi8KICAgIGlmICggQWx0R3JTdGF0ZSAmJiAoZXZlbnQtPnN0YXRlICYgMHg2MDAwKSApCiAgICAgICAgQWx0R3JNYXNrID0gZXZlbnQtPnN0YXRlICYgMHg2MDAwOwoKICAgIGlmIChrZXlzeW0gPT0gWEtfTW9kZV9zd2l0Y2gpCgl7CglUUkFDRV8oa2V5KSgiQWx0IEdyIGtleSBldmVudCByZWNlaXZlZFxuIik7CglldmVudC0+a2V5Y29kZSA9IGtjQ29udHJvbDsgLyogU2ltdWxhdGUgQ29udHJvbCAqLwoJWDExRFJWX0tFWUJPQVJEX0hhbmRsZUV2ZW50KCBwV25kLCBldmVudCApOwoKCWV2ZW50LT5rZXljb2RlID0ga2NBbHQ7IC8qIFNpbXVsYXRlIEFsdCAqLwoJZm9yY2VfZXh0ZW5kZWQgPSBUUlVFOwoJWDExRFJWX0tFWUJPQVJEX0hhbmRsZUV2ZW50KCBwV25kLCBldmVudCApOwoJZm9yY2VfZXh0ZW5kZWQgPSBGQUxTRTsKICAgIAogICAgLyogSGVyZSB3ZSBzYXZlIHRoZSBwcmVzc2VkL3JlbGVhc2VkIHN0YXRlIG9mIHRoZSBBbHRHciBrZXksIHRvIGJlIGFibGUgdG8gCiAgICAgICBpZGVudGlmeSB0aGUgZ3JvdXAgaW5kZXggYXNzb2NpYXRlZCB3aXRoIEFsdEdyIG9uIHRoZSBuZXh0IGtleSBwcmVzc2VkICoKICAgICAgIHNlZSBjb21tZW50IGFib3ZlLiAqLwogICAgQWx0R3JTdGF0ZSA9IChldmVudC0+dHlwZSA9PSBLZXlQcmVzcykgPyBUUlVFIDogRkFMU0U7CiAgICAKCXJldHVybjsKCX0KCiAgICBTdHJbYXNjaWlfY2hhcnNdID0gJ1wwJzsKICAgIGlmIChUUkFDRV9PTihrZXkpKXsKCWNoYXIJKmtzbmFtZTsKCglrc25hbWUgPSBUU1hLZXlzeW1Ub1N0cmluZyhrZXlzeW0pOwoJaWYgKCFrc25hbWUpCgkgIGtzbmFtZSA9ICJObyBOYW1lIjsKCVRSQUNFXyhrZXkpKCIlcyA6IGtleXN5bT0lbFggKCVzKSwgYXNjaWkgY2hhcnM9JXUgLyAlWCAvICclcydcbiIsIAogICAgICAgICAgICAgICAgICAgIChldmVudC0+dHlwZSA9PSBLZXlQcmVzcykgPyAiS2V5UHJlc3MiIDogIktleVJlbGVhc2UiLAogICAgICAgICAgICAgICAgICAgIGtleXN5bSwga3NuYW1lLCBhc2NpaV9jaGFycywgU3RyWzBdICYgMHhmZiwgU3RyKTsKICAgIH0KCiAgICB2a2V5ID0gRVZFTlRfZXZlbnRfdG9fdmtleShldmVudCk7CiAgICBpZiAoZm9yY2VfZXh0ZW5kZWQpIHZrZXkgfD0gMHgxMDA7CgogICAgVFJBQ0VfKGtleSkoImtleWNvZGUgMHgleCBjb252ZXJ0ZWQgdG8gdmtleSAweCV4XG4iLAogICAgICAgICAgICAgICAgZXZlbnQtPmtleWNvZGUsIHZrZXkpOwoKICAgaWYgKHZrZXkpCiAgIHsKICAgIHN3aXRjaCAodmtleSAmIDB4ZmYpCiAgICB7CiAgICBjYXNlIFZLX05VTUxPQ0s6ICAgIAogICAgICBLRVlCT0FSRF9HZW5lcmF0ZU1zZyggVktfTlVNTE9DSywgMHg0NSwgZXZlbnQtPnR5cGUsIGV2ZW50X3gsIGV2ZW50X3ksCiAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF90aW1lICk7CiAgICAgIGJyZWFrOwogICAgY2FzZSBWS19DQVBJVEFMOgogICAgICBUUkFDRSgiQ2FwcyBMb2NrIGV2ZW50LiAodHlwZSAlZCkuIFN0YXRlIGJlZm9yZSA6ICUjLjJ4XG4iLGV2ZW50LT50eXBlLHBLZXlTdGF0ZVRhYmxlW3ZrZXldKTsKICAgICAgS0VZQk9BUkRfR2VuZXJhdGVNc2coIFZLX0NBUElUQUwsIDB4M0EsIGV2ZW50LT50eXBlLCBldmVudF94LCBldmVudF95LAogICAgICAgICAgICAgICAgICAgICAgICAgICAgZXZlbnRfdGltZSApOyAKICAgICAgVFJBQ0UoIlN0YXRlIGFmdGVyIDogJSMuMnhcbiIscEtleVN0YXRlVGFibGVbdmtleV0pOwogICAgICBicmVhazsKICAgIGRlZmF1bHQ6CiAgICAgICAgLyogQWRqdXN0IHRoZSBOVU1MT0NLIHN0YXRlIGlmIGl0IGhhcyBiZWVuIGNoYW5nZWQgb3V0c2lkZSB3aW5lICovCglpZiAoIShwS2V5U3RhdGVUYWJsZVtWS19OVU1MT0NLXSAmIDB4MDEpICE9ICEoZXZlbnQtPnN0YXRlICYgTnVtTG9ja01hc2spKQoJICB7IAoJICAgIFRSQUNFKCJBZGp1c3RpbmcgTnVtTG9jayBzdGF0ZS4gXG4iKTsKCSAgICBLRVlCT0FSRF9HZW5lcmF0ZU1zZyggVktfTlVNTE9DSywgMHg0NSwgS2V5UHJlc3MsIGV2ZW50X3gsIGV2ZW50X3ksCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF90aW1lICk7CgkgICAgS0VZQk9BUkRfR2VuZXJhdGVNc2coIFZLX05VTUxPQ0ssIDB4NDUsIEtleVJlbGVhc2UsIGV2ZW50X3gsIGV2ZW50X3ksCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF90aW1lICk7CgkgIH0KICAgICAgICAvKiBBZGp1c3QgdGhlIENBUFNMT0NLIHN0YXRlIGlmIGl0IGhhcyBiZWVuIGNoYW5nZWQgb3V0c2lkZSB3aW5lICovCglpZiAoIShwS2V5U3RhdGVUYWJsZVtWS19DQVBJVEFMXSAmIDB4MDEpICE9ICEoZXZlbnQtPnN0YXRlICYgTG9ja01hc2spKQoJICB7CiAgICAgICAgICAgICAgVFJBQ0UoIkFkanVzdGluZyBDYXBzIExvY2sgc3RhdGUuXG4iKTsKCSAgICBLRVlCT0FSRF9HZW5lcmF0ZU1zZyggVktfQ0FQSVRBTCwgMHgzQSwgS2V5UHJlc3MsIGV2ZW50X3gsIGV2ZW50X3ksCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF90aW1lICk7CgkgICAgS0VZQk9BUkRfR2VuZXJhdGVNc2coIFZLX0NBUElUQUwsIDB4M0EsIEtleVJlbGVhc2UsIGV2ZW50X3gsIGV2ZW50X3ksCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF90aW1lICk7CgkgIH0KCS8qIE5vdCBOdW0gbm9yIENhcHMgOiBlbmQgb2YgaW50ZXJtZWRpYXJ5IHN0YXRlcyBmb3IgYm90aC4gKi8KCU51bVN0YXRlID0gRkFMU0U7CglDYXBzU3RhdGUgPSBGQUxTRTsKCgliU2NhbiA9IGtleWMyc2NhbltldmVudC0+a2V5Y29kZV0gJiAweEZGOwoJVFJBQ0VfKGtleSkoImJTY2FuID0gMHglMDJ4LlxuIiwgYlNjYW4pOwoKCWR3RmxhZ3MgPSAwOwoJaWYgKCBldmVudC0+dHlwZSA9PSBLZXlSZWxlYXNlICkgZHdGbGFncyB8PSBLRVlFVkVOVEZfS0VZVVA7CglpZiAoIHZrZXkgJiAweDEwMCApICAgICAgICAgICAgICBkd0ZsYWdzIHw9IEtFWUVWRU5URl9FWFRFTkRFREtFWTsKCWlmICggZm9yY2VfZXh0ZW5kZWQgKSAgICAgICAgICAgIGR3RmxhZ3MgfD0gS0VZRVZFTlRGX1dJTkVfRk9SQ0VFWFRFTkRFRDsKCglLRVlCT0FSRF9TZW5kRXZlbnQoIHZrZXkgJiAweGZmLCBiU2NhbiwgZHdGbGFncywgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudF94LCBldmVudF95LCBldmVudF90aW1lICk7CiAgICB9CiAgIH0KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVgxMURSVl9LRVlCT0FSRF9EZXRlY3RMYXlvdXQKICoKICogQ2FsbGVkIGZyb20gWDExRFJWX0luaXRLZXlib2FyZAogKiAgVGhpcyByb3V0aW5lIHdhbGtzIHRocm91Z2ggdGhlIGRlZmluZWQga2V5Ym9hcmQgbGF5b3V0cyBhbmQgc2VsZWN0cwogKiAgd2hpY2hldmVyIG1hdGNoZXMgbW9zdCBjbG9zZWx5LgogKi8Kc3RhdGljIHZvaWQKWDExRFJWX0tFWUJPQVJEX0RldGVjdExheW91dCAodm9pZCkKewogIHVuc2lnbmVkIGN1cnJlbnQsIG1hdGNoLCBtaXNtYXRjaCwgc2VxOwogIGludCBzY29yZSwga2V5YywgaSwga2V5LCBwa2V5LCBvaywgc3ltczsKICBLZXlTeW0ga2V5c3ltOwogIGNvbnN0IGNoYXIgKCpsa2V5KVtNQUlOX0xFTl1bNF07CiAgdW5zaWduZWQgbWF4X3NlcSA9IDA7CiAgaW50IG1heF9zY29yZSA9IDAsIGlzbWF0Y2ggPSAwOwogIGNoYXIgY2tleVs0XSA9CiAgezAsIDAsIDAsIDB9OwoKICBzeW1zID0ga2V5c3ltc19wZXJfa2V5Y29kZTsKICBpZiAoc3ltcyA+IDQpIHsKICAgIFdBUk4oIiVkIGtleXN5bXMgcGVyIGtleWNvZGUgbm90IHN1cHBvcnRlZCwgc2V0IHRvIDQiLCBzeW1zKTsKICAgIHN5bXMgPSA0OwogIH0KICBmb3IgKGN1cnJlbnQgPSAwOyBtYWluX2tleV90YWJbY3VycmVudF0ubGFuZzsgY3VycmVudCsrKSB7CiAgICBUUkFDRSgiQXR0ZW1wdGluZyB0byBtYXRjaCBhZ2FpbnN0IGxheW91dCAlMDR4XG4iLAoJICAgbWFpbl9rZXlfdGFiW2N1cnJlbnRdLmxhbmcpOwogICAgbWF0Y2ggPSAwOwogICAgbWlzbWF0Y2ggPSAwOwogICAgc2NvcmUgPSAwOwogICAgc2VxID0gMDsKICAgIGxrZXkgPSBtYWluX2tleV90YWJbY3VycmVudF0ua2V5OwogICAgcGtleSA9IC0xOwogICAgZm9yIChrZXljID0gbWluX2tleWNvZGU7IGtleWMgPD0gbWF4X2tleWNvZGU7IGtleWMrKykgewogICAgICAvKiBnZXQgZGF0YSBmb3Iga2V5Y29kZSBmcm9tIFggc2VydmVyICovCiAgICAgIGZvciAoaSA9IDA7IGkgPCBzeW1zOyBpKyspIHsKCWtleXN5bSA9IFRTWEtleWNvZGVUb0tleXN5bSAoZGlzcGxheSwga2V5YywgaSk7CgkvKiBBbGxvdyBib3RoIG9uZS1ieXRlIGFuZCB0d28tYnl0ZSBuYXRpb25hbCBrZXlzeW1zICovCglpZiAoKGtleXN5bSA8IDB4ODAwKSAmJiAoa2V5c3ltICE9ICcgJykpCgkgIGNrZXlbaV0gPSBrZXlzeW0gJiAweEZGOwoJZWxzZSB7CgkgIGNrZXlbaV0gPSBLRVlCT0FSRF9NYXBEZWFkS2V5c3ltKGtleXN5bSk7Cgl9CiAgICAgIH0KICAgICAgaWYgKGNrZXlbMF0pIHsKCS8qIHNlYXJjaCBmb3IgYSBtYXRjaCBpbiBsYXlvdXQgdGFibGUgKi8KCS8qIHJpZ2h0IG5vdywgd2UganVzdCBmaW5kIGFuIGFic29sdXRlIG1hdGNoIGZvciBkZWZpbmVkIHBvc2l0aW9ucyAqLwoJLyogKHVuZGVmaW5lZCBwb3NpdGlvbnMgYXJlIGlnbm9yZWQsIHNvIGlmIGl0J3MgZGVmaW5lZCBhcyAiMyMiIGluICovCgkvKiB0aGUgdGFibGUsIGl0J3Mgb2theSB0aGF0IHRoZSBYIHNlcnZlciBoYXMgIjMjoyIsIGZvciBleGFtcGxlKSAqLwoJLyogaG93ZXZlciwgdGhlIHNjb3JlIHdpbGwgYmUgaGlnaGVyIGZvciBsb25nZXIgbWF0Y2hlcyAqLwoJZm9yIChrZXkgPSAwOyBrZXkgPCBNQUlOX0xFTjsga2V5KyspIHsKCSAgZm9yIChvayA9IDAsIGkgPSAwOyAob2sgPj0gMCkgJiYgKGkgPCBzeW1zKTsgaSsrKSB7CgkgICAgaWYgKCgqbGtleSlba2V5XVtpXSAmJiAoKCpsa2V5KVtrZXldW2ldID09IGNrZXlbaV0pKQoJICAgICAgb2srKzsKCSAgICBpZiAoKCpsa2V5KVtrZXldW2ldICYmICgoKmxrZXkpW2tleV1baV0gIT0gY2tleVtpXSkpCgkgICAgICBvayA9IC0xOwoJICB9CgkgIGlmIChvayA+IDApIHsKCSAgICBzY29yZSArPSBvazsKCSAgICBicmVhazsKCSAgfQoJfQoJLyogY291bnQgdGhlIG1hdGNoZXMgYW5kIG1pc21hdGNoZXMgKi8KCWlmIChvayA+IDApIHsKCSAgbWF0Y2grKzsKCSAgLyogYW5kIGhvdyBtdWNoIHRoZSBrZXljb2RlIG9yZGVyIG1hdGNoZXMgKi8KCSAgaWYgKGtleSA+IHBrZXkpIHNlcSsrOwoJICBwa2V5ID0ga2V5OwoJfSBlbHNlIHsKCSAgVFJBQ0VfKGtleSkoIm1pc21hdGNoIGZvciBrZXljb2RlICVkLCBjaGFyYWN0ZXIgJWNcbiIsIGtleWMsCgkJIGNrZXlbMF0pOwoJICBtaXNtYXRjaCsrOwoJICBzY29yZSAtPSBzeW1zOwoJfQogICAgICB9CiAgICB9CiAgICBUUkFDRSgibWF0Y2hlcz0lZCwgbWlzbWF0Y2hlcz0lZCwgc2NvcmU9JWRcbiIsCgkgICBtYXRjaCwgbWlzbWF0Y2gsIHNjb3JlKTsKICAgIGlmICgoc2NvcmUgPiBtYXhfc2NvcmUpIHx8CgkoKHNjb3JlID09IG1heF9zY29yZSkgJiYgKHNlcSA+IG1heF9zZXEpKSkgewogICAgICAvKiBiZXN0IG1hdGNoIHNvIGZhciAqLwogICAgICBrYmRfbGF5b3V0ID0gY3VycmVudDsKICAgICAgbWF4X3Njb3JlID0gc2NvcmU7CiAgICAgIG1heF9zZXEgPSBzZXE7CiAgICAgIGlzbWF0Y2ggPSAhbWlzbWF0Y2g7CiAgICB9CiAgfQogIC8qIHdlJ3JlIGRvbmUsIHJlcG9ydCByZXN1bHRzIGlmIG5lY2Vzc2FyeSAqLwogIGlmICghaXNtYXRjaCkgewogICAgRklYTUUoCgkgICAiWW91ciBrZXlib2FyZCBsYXlvdXQgd2FzIG5vdCBmb3VuZCFcbiIKCSAgICJJbnN0ZWFkIHVzaW5nIGNsb3Nlc3QgbWF0Y2ggKCUwNHgpIGZvciBzY2FuY29kZSBtYXBwaW5nLlxuIgoJICAgIlBsZWFzZSBkZWZpbmUgeW91ciBsYXlvdXQgaW4gd2luZG93cy94MTFkcnYva2V5Ym9hcmQuYyBhbmQgc3VibWl0IHRoZW1cbiIKCSAgICJ0byB1cyBmb3IgaW5jbHVzaW9uIGludG8gZnV0dXJlIFdpbmUgcmVsZWFzZXMuXG4iCgkgICAiU2VlIGRvY3VtZW50YXRpb24va2V5Ym9hcmQgZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4iLAoJICAgbWFpbl9rZXlfdGFiW2tiZF9sYXlvdXRdLmxhbmcpOwogIH0KICBUUkFDRSgiZGV0ZWN0ZWQgbGF5b3V0IGlzICUwNHhcbiIsIG1haW5fa2V5X3RhYltrYmRfbGF5b3V0XS5sYW5nKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVgxMURSVl9Jbml0S2V5Ym9hcmQKICovCnZvaWQgWDExRFJWX0luaXRLZXlib2FyZCh2b2lkKQp7CiAgICBLZXlTeW0gKmtzcDsKICAgIFhNb2RpZmllcktleW1hcCAqbW1wOwogICAgS2V5U3ltIGtleXN5bTsKICAgIEtleUNvZGUgKmtjcDsKICAgIFhLZXlFdmVudCBlMjsKICAgIFdPUkQgc2NhbiwgdmtleSwgT0VNdmtleTsKICAgIGludCBrZXljLCBpLCBrZXluLCBzeW1zOwogICAgY2hhciBja2V5WzRdPXswLDAsMCwwfTsKICAgIGNvbnN0IGNoYXIgKCpsa2V5KVtNQUlOX0xFTl1bNF07CgogICAgVFNYRGlzcGxheUtleWNvZGVzKGRpc3BsYXksICZtaW5fa2V5Y29kZSwgJm1heF9rZXljb2RlKTsKICAgIGtzcCA9IFRTWEdldEtleWJvYXJkTWFwcGluZyhkaXNwbGF5LCBtaW5fa2V5Y29kZSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWF4X2tleWNvZGUgKyAxIC0gbWluX2tleWNvZGUsICZrZXlzeW1zX3Blcl9rZXljb2RlKTsKICAgIC8qIFdlIGFyZSBvbmx5IGludGVyZXN0ZWQgaW4ga2V5c3ltc19wZXJfa2V5Y29kZS4KICAgICAgIFRoZXJlIGlzIG5vIG5lZWQgdG8gaG9sZCBhIGxvY2FsIGNvcHkgb2YgdGhlIGtleXN5bXMgdGFibGUgKi8KICAgIFRTWEZyZWUoa3NwKTsKICAgIG1tcCA9IFRTWEdldE1vZGlmaWVyTWFwcGluZyhkaXNwbGF5KTsKICAgIGtjcCA9IG1tcC0+bW9kaWZpZXJtYXA7CiAgICBmb3IgKGkgPSAwOyBpIDwgODsgaSArPSAxKSAvKiBUaGVyZSBhcmUgOCBtb2RpZmllciBrZXlzICovCiAgICB7CiAgICAgICAgaW50IGo7CiAgICAgICAgCiAgICAgICAgZm9yIChqID0gMDsgaiA8IG1tcC0+bWF4X2tleXBlcm1vZDsgaiArPSAxLCBrY3AgKz0gMSkKCSAgICBpZiAoKmtjcCkKICAgICAgICAgICAgewoJCWludCBrOwogICAgICAgICAgICAgICAgCgkJZm9yIChrID0gMDsgayA8IGtleXN5bXNfcGVyX2tleWNvZGU7IGsgKz0gMSkKICAgICAgICAgICAgICAgICAgICBpZiAoVFNYS2V5Y29kZVRvS2V5c3ltKGRpc3BsYXksICprY3AsIGspID09IFhLX01vZGVfc3dpdGNoKQoJCSAgICB7CiAgICAgICAgICAgICAgICAgICAgICAgIEFsdEdyTWFzayA9IDEgPDwgaTsKICAgICAgICAgICAgICAgICAgICAgICAgVFJBQ0VfKGtleSkoIkFsdEdyTWFzayBpcyAleFxuIiwgQWx0R3JNYXNrKTsKCQkgICAgfQogICAgICAgICAgICAgICAgICAgIGVsc2UgaWYgKFRTWEtleWNvZGVUb0tleXN5bShkaXNwbGF5LCAqa2NwLCBrKSA9PSBYS19OdW1fTG9jaykKCQkgICAgewogICAgICAgICAgICAgICAgICAgICAgICBOdW1Mb2NrTWFzayA9IDEgPDwgaTsKICAgICAgICAgICAgICAgICAgICAgICAgVFJBQ0VfKGtleSkoIk51bUxvY2tNYXNrIGlzICV4XG4iLCBOdW1Mb2NrTWFzayk7CgkJICAgIH0KICAgICAgICAgICAgfQogICAgfQogICAgVFNYRnJlZU1vZGlmaWVybWFwKG1tcCk7CgogICAgLyogRGV0ZWN0IHRoZSBrZXlib2FyZCBsYXlvdXQgKi8KICAgIFgxMURSVl9LRVlCT0FSRF9EZXRlY3RMYXlvdXQoKTsKICAgIGxrZXkgPSBtYWluX2tleV90YWJba2JkX2xheW91dF0ua2V5OwogICAgc3ltcyA9IChrZXlzeW1zX3Blcl9rZXljb2RlID4gNCkgPyA0IDoga2V5c3ltc19wZXJfa2V5Y29kZTsKCiAgICAvKiBOb3cgYnVpbGQgdHdvIGNvbnZlcnNpb24gYXJyYXlzIDoKICAgICAqIGtleWNvZGUgLT4gdmtleSArIHNjYW5jb2RlICsgZXh0ZW5kZWQKICAgICAqIHZrZXkgKyBleHRlbmRlZCAtPiBrZXljb2RlICovCgogICAgZTIuZGlzcGxheSA9IGRpc3BsYXk7CiAgICBlMi5zdGF0ZSA9IDA7CgogICAgT0VNdmtleSA9IFZLX09FTV83OyAvKiBuZXh0IGlzIGF2YWlsYWJsZS4gICovCiAgICBmb3IgKGtleWMgPSBtaW5fa2V5Y29kZTsga2V5YyA8PSBtYXhfa2V5Y29kZTsga2V5YysrKQogICAgewogICAgICAgIGUyLmtleWNvZGUgPSAoS2V5Q29kZSlrZXljOwogICAgICAgIFRTWExvb2t1cFN0cmluZygmZTIsIE5VTEwsIDAsICZrZXlzeW0sIE5VTEwpOwogICAgICAgIHZrZXkgPSAwOyBzY2FuID0gMDsKICAgICAgICBpZiAoa2V5c3ltKSAgLyogb3RoZXJ3aXNlLCBrZXljb2RlIG5vdCB1c2VkICovCiAgICAgICAgewogICAgICAgICAgICBpZiAoKGtleXN5bSA+PiA4KSA9PSAweEZGKSAgICAgICAgIC8qIG5vbi1jaGFyYWN0ZXIga2V5ICovCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIGludCBrZXkgPSBrZXlzeW0gJiAweGZmOwoJCQogICAgICAgICAgICAgICAgaWYgKGtleSA+PSAweDA4ICYmIGtleSA8PSAweDFCKSB7ICAgICAgICAvKiBzcGVjaWFsIGtleSAqLwoJCSAgICB2a2V5ID0gc3BlY2lhbF9rZXlfdmtleVtrZXkgLSAweDA4XTsKCQkgICAgc2NhbiA9IHNwZWNpYWxfa2V5X3NjYW5ba2V5IC0gMHgwOF07CiAgICAgICAgICAgICAgICB9IGVsc2UgaWYgKGtleSA+PSAweDUwICYmIGtleSA8PSAweDU3KSB7IC8qIGN1cnNvciBrZXkgKi8KCQkgICAgdmtleSA9IGN1cnNvcl9rZXlfdmtleVtrZXkgLSAweDUwXTsKCQkgICAgc2NhbiA9IGN1cnNvcl9rZXlfc2NhbltrZXkgLSAweDUwXTsKICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAoa2V5ID49IDB4NjAgJiYga2V5IDw9IDB4NkIpIHsgLyogbWlzY2VsbGFuZW91cyBrZXkgKi8KCQkgICAgdmtleSA9IG1pc2Nfa2V5X3ZrZXlba2V5IC0gMHg2MF07CgkJICAgIHNjYW4gPSBtaXNjX2tleV9zY2FuW2tleSAtIDB4NjBdOwogICAgICAgICAgICAgICAgfSBlbHNlIGlmIChrZXkgPj0gMHg3RSAmJiBrZXkgPD0gMHhCOSkgeyAvKiBrZXlwYWQga2V5ICovCgkJICAgIHZrZXkgPSBrZXlwYWRfa2V5X3ZrZXlba2V5IC0gMHg3RV07CgkJICAgIHNjYW4gPSBrZXlwYWRfa2V5X3NjYW5ba2V5IC0gMHg3RV07CiAgICAgICAgICAgICAgICB9IGVsc2UgaWYgKGtleSA+PSAweEJFICYmIGtleSA8PSAweENEKSB7IC8qIGZ1bmN0aW9uIGtleSAqLwogICAgICAgICAgICAgICAgICAgIHZrZXkgPSBmdW5jdGlvbl9rZXlfdmtleVtrZXkgLSAweEJFXSB8IDB4MTAwOyAvKiBzZXQgZXh0ZW5kZWQgYml0ICovCiAgICAgICAgICAgICAgICAgICAgc2NhbiA9IGZ1bmN0aW9uX2tleV9zY2FuW2tleSAtIDB4QkVdOwogICAgICAgICAgICAgICAgfSBlbHNlIGlmIChrZXkgPj0gMHhFMSAmJiBrZXkgPD0gMHhFQSkgeyAvKiBtb2RpZmllciBrZXkgKi8KCQkgICAgdmtleSA9IG1vZGlmaWVyX2tleV92a2V5W2tleSAtIDB4RTFdOwoJCSAgICBzY2FuID0gbW9kaWZpZXJfa2V5X3NjYW5ba2V5IC0gMHhFMV07CiAgICAgICAgICAgICAgICB9IGVsc2UgaWYgKGtleSA9PSAweEZGKSB7ICAgICAgICAgICAgICAgIC8qIERFTCBrZXkgKi8KCQkgICAgdmtleSA9IFZLX0RFTEVURTsKCQkgICAgc2NhbiA9IDB4MTUzOwoJCX0KCQkvKiBzZXQgZXh0ZW5kZWQgYml0IHdoZW4gbmVjZXNzYXJ5ICovCgkJaWYgKHNjYW4gJiAweDEwMCkgdmtleSB8PSAweDEwMDsKICAgICAgICAgICAgfSBlbHNlIGlmIChrZXlzeW0gPT0gMHgyMCkgeyAgICAgICAgICAgICAgICAgLyogU3BhY2ViYXIgKi8KCSAgICAgICAgdmtleSA9IFZLX1NQQUNFOwoJCXNjYW4gPSAweDM5OwoJICAgIH0gZWxzZSB7CgkgICAgICAvKiB3ZSBzZWVtIHRvIG5lZWQgdG8gc2VhcmNoIHRoZSBsYXlvdXQtZGVwZW5kZW50IHNjYW5jb2RlcyAqLwoJICAgICAgaW50IG1heGxlbj0wLG1heHZhbD0tMSxvazsKCSAgICAgIGZvciAoaT0wOyBpPHN5bXM7IGkrKykgewoJCWtleXN5bSA9IFRTWEtleWNvZGVUb0tleXN5bShkaXNwbGF5LCBrZXljLCBpKTsKCQlpZiAoKGtleXN5bTwweDgwMCkgJiYgKGtleXN5bSE9JyAnKSkgewoJCSAgY2tleVtpXSA9IGtleXN5bSAmIDB4RkY7CgkJfSBlbHNlIHsKCQkgIGNrZXlbaV0gPSBLRVlCT0FSRF9NYXBEZWFkS2V5c3ltKGtleXN5bSk7CgkJfQoJICAgICAgfQoJICAgICAgLyogZmluZCBrZXkgd2l0aCBsb25nZXN0IG1hdGNoIHN0cmVhayAqLwoJICAgICAgZm9yIChrZXluPTA7IGtleW48TUFJTl9MRU47IGtleW4rKykgewoJCWZvciAob2s9KCpsa2V5KVtrZXluXVtpPTBdOyBvayYmKGk8NCk7IGkrKykKCQkgIGlmICgoKmxrZXkpW2tleW5dW2ldICYmICgqbGtleSlba2V5bl1baV0hPWNrZXlbaV0pIG9rPTA7CgkJaWYgKG9rfHwoaT5tYXhsZW4pKSB7CgkJICBtYXhsZW49aTsgbWF4dmFsPWtleW47CgkJfQoJCWlmIChvaykgYnJlYWs7CgkgICAgICB9CgkgICAgICBpZiAobWF4dmFsPj0wKSB7CgkJLyogZ290IGl0ICovCgkJc2NhbiA9IG1haW5fa2V5X3NjYW5bbWF4dmFsXTsKCSAgICAgIH0KCSAgICB9CgogICAgICAgICAgICAvKiBmaW5kIGEgc3VpdGFibGUgbGF5b3V0LWRlcGVuZGVudCBWSyBjb2RlICovCgkgICAgLyogKG1vc3QgV2luZWxpYiBhcHBzIG91Z2h0IHRvIGJlIGFibGUgdG8gd29yayB3aXRob3V0IGxheW91dCB0YWJsZXMhKSAqLwogICAgICAgICAgICBmb3IgKGkgPSAwOyAoaSA8IGtleXN5bXNfcGVyX2tleWNvZGUpICYmICghdmtleSk7IGkrKykKICAgICAgICAgICAgewogICAgICAgICAgICAgICAga2V5c3ltID0gVFNYTG9va3VwS2V5c3ltKCZlMiwgaSk7CiAgICAgICAgICAgICAgICBpZiAoKGtleXN5bSA+PSBWS18wICYmIGtleXN5bSA8PSBWS185KQogICAgICAgICAgICAgICAgICAgIHx8IChrZXlzeW0gPj0gVktfQSAmJiBrZXlzeW0gPD0gVktfWikpIHsKCQkgICAgdmtleSA9IGtleXN5bTsKCQl9CiAgICAgICAgICAgIH0KCiAgICAgICAgICAgIGZvciAoaSA9IDA7IChpIDwga2V5c3ltc19wZXJfa2V5Y29kZSkgJiYgKCF2a2V5KTsgaSsrKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBrZXlzeW0gPSBUU1hMb29rdXBLZXlzeW0oJmUyLCBpKTsKCQlzd2l0Y2ggKGtleXN5bSkKCQl7CgkJY2FzZSAnOyc6ICAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fMTsgYnJlYWs7CgkJY2FzZSAnLyc6ICAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fMjsgYnJlYWs7CgkJY2FzZSAnYCc6ICAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fMzsgYnJlYWs7CgkJY2FzZSAnWyc6ICAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fNDsgYnJlYWs7CgkJY2FzZSAnXFwnOiAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fNTsgYnJlYWs7CgkJY2FzZSAnXSc6ICAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fNjsgYnJlYWs7CgkJY2FzZSAnXCcnOiAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fNzsgYnJlYWs7CgkJY2FzZSAnLCc6ICAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fQ09NTUE7IGJyZWFrOwoJCWNhc2UgJy4nOiAgICAgICAgICAgICB2a2V5ID0gVktfT0VNX1BFUklPRDsgYnJlYWs7CgkJY2FzZSAnLSc6ICAgICAgICAgICAgIHZrZXkgPSBWS19PRU1fTUlOVVM7IGJyZWFrOwoJCWNhc2UgJysnOiAgICAgICAgICAgICB2a2V5ID0gVktfT0VNX1BMVVM7IGJyZWFrOwoJCX0KCSAgICB9CgogICAgICAgICAgICBpZiAoIXZrZXkpCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIC8qIE90aGVycyBrZXlzOiBsZXQncyBhc3NpZ24gT0VNIHZpcnR1YWwga2V5IGNvZGVzIGluIHRoZSBhbGxvd2VkIHJhbmdlLAogICAgICAgICAgICAgICAgICogdGhhdCBpcyAoWzB4YmEsMHhjMF0sIFsweGRiLDB4ZTRdLCAweGU2IChnaXZlbiB1cCkgZXQgWzB4ZTksMHhmNV0pICovCiAgICAgICAgICAgICAgICBzd2l0Y2ggKCsrT0VNdmtleSkKICAgICAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIGNhc2UgMHhjMSA6IE9FTXZrZXk9MHhkYjsgYnJlYWs7CiAgICAgICAgICAgICAgICBjYXNlIDB4ZTUgOiBPRU12a2V5PTB4ZTk7IGJyZWFrOwogICAgICAgICAgICAgICAgY2FzZSAweGY2IDogT0VNdmtleT0weGY1OyBXQVJOKCJObyBtb3JlIE9FTSB2a2V5IGF2YWlsYWJsZSFcbiIpOwogICAgICAgICAgICAgICAgfQoKICAgICAgICAgICAgICAgIHZrZXkgPSBPRU12a2V5OwoJCSAgCiAgICAgICAgICAgICAgICBpZiAoVFJBQ0VfT04oa2V5Ym9hcmQpKQogICAgICAgICAgICAgICAgewogICAgICAgICAgICAgICAgICAgIFRSQUNFKCJPRU0gc3BlY2lmaWMgdmlydHVhbCBrZXkgJVggYXNzaWduZWQgdG8ga2V5Y29kZSAlWDpcbiIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBPRU12a2V5LCBlMi5rZXljb2RlKTsKICAgICAgICAgICAgICAgICAgICBUUkFDRSgiKCIpOwogICAgICAgICAgICAgICAgICAgIGZvciAoaSA9IDA7IGkgPCBrZXlzeW1zX3Blcl9rZXljb2RlOyBpICs9IDEpCiAgICAgICAgICAgICAgICAgICAgewogICAgICAgICAgICAgICAgICAgICAgICBjaGFyCSprc25hbWU7CiAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICBrZXlzeW0gPSBUU1hMb29rdXBLZXlzeW0oJmUyLCBpKTsKICAgICAgICAgICAgICAgICAgICAgICAga3NuYW1lID0gVFNYS2V5c3ltVG9TdHJpbmcoa2V5c3ltKTsKICAgICAgICAgICAgICAgICAgICAgICAgaWYgKCFrc25hbWUpCgkJCSAgICBrc25hbWUgPSAiTm9TeW1ib2wiOwogICAgICAgICAgICAgICAgICAgICAgICBEUFJJTlRGKCAiJWxYICglcykgIiwga2V5c3ltLCBrc25hbWUpOwogICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICBEUFJJTlRGKCIpXG4iKTsKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgfQogICAgICAgIH0KICAgICAgICBrZXljMnZrZXlbZTIua2V5Y29kZV0gPSB2a2V5OwogICAgICAgIGtleWMyc2NhbltlMi5rZXljb2RlXSA9IHNjYW47CiAgICB9IC8qIGZvciAqLwoKICAgIC8qIElmIHNvbWUga2V5cyBzdGlsbCBsYWNrIHNjYW5jb2RlcywgYXNzaWduIHNvbWUgYXJiaXRyYXJ5IG9uZXMgdG8gdGhlbSBub3cgKi8KICAgIGZvciAoc2NhbiA9IDB4NjAsIGtleWMgPSBtaW5fa2V5Y29kZTsga2V5YyA8PSBtYXhfa2V5Y29kZTsga2V5YysrKQogICAgICBpZiAoa2V5YzJ2a2V5W2tleWNdJiYha2V5YzJzY2FuW2tleWNdKSB7CgljaGFyICprc25hbWU7CglrZXlzeW0gPSBUU1hLZXljb2RlVG9LZXlzeW0oZGlzcGxheSwga2V5YywgMCk7Cglrc25hbWUgPSBUU1hLZXlzeW1Ub1N0cmluZyhrZXlzeW0pOwoJaWYgKCFrc25hbWUpIGtzbmFtZSA9ICJOb1N5bWJvbCI7CgoJLyogc2hvdWxkIG1ha2Ugc3VyZSB0aGUgc2NhbmNvZGUgaXMgdW5hc3NpZ25lZCBoZXJlLCBidXQgPj0weDYwIGN1cnJlbnRseSBhbHdheXMgaXMgKi8KCglUUkFDRV8oa2V5KSgiYXNzaWduaW5nIHNjYW5jb2RlICUwMnggdG8gdW5pZGVudGlmaWVkIGtleWNvZGUgJTAyeCAoJXMpXG4iLHNjYW4sa2V5Yyxrc25hbWUpOwoJa2V5YzJzY2FuW2tleWNdPXNjYW4rKzsKICAgICAgfQoKICAgIC8qIE5vdyBzdG9yZSBvbmUga2V5Y29kZSBmb3IgZWFjaCBtb2RpZmllci4gVXNlZCB0byBzaW11bGF0ZSBrZXlwcmVzc2VzLiAqLwogICAga2NDb250cm9sID0gVFNYS2V5c3ltVG9LZXljb2RlKGRpc3BsYXksIFhLX0NvbnRyb2xfTCk7CiAgICBrY0FsdCA9IFRTWEtleXN5bVRvS2V5Y29kZShkaXNwbGF5LCBYS19BbHRfTCk7CiAgICBpZiAoIWtjQWx0KSBrY0FsdCA9IFRTWEtleXN5bVRvS2V5Y29kZShkaXNwbGF5LCBYS19NZXRhX0wpOwogICAga2NTaGlmdCA9IFRTWEtleXN5bVRvS2V5Y29kZShkaXNwbGF5LCBYS19TaGlmdF9MKTsKICAgIGtjTnVtTG9jayA9IFRTWEtleXN5bVRvS2V5Y29kZShkaXNwbGF5LCBYS19OdW1fTG9jayk7CiAgICBrY0NhcHNMb2NrID0gVFNYS2V5c3ltVG9LZXljb2RlKGRpc3BsYXksIFhLX0NhcHNfTG9jayk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJWDExRFJWX1ZrS2V5U2NhbgogKi8KV09SRCBYMTFEUlZfVmtLZXlTY2FuKENIQVIgY0NoYXIpCnsKCUtleUNvZGUga2V5Y29kZTsKCUtleVN5bSBrZXlzeW07ICAgIAkKCWludCBpLGluZGV4OwoJaW50IGhpZ2hieXRlPTA7CgoJLyogY2hhci0+a2V5c3ltIChzYW1lIGZvciBBTlNJIGNoYXJzKSAqLwoJa2V5c3ltPSh1bnNpZ25lZCBjaGFyKSBjQ2hhcjsvKiAoISkgY0NoYXIgaXMgc2lnbmVkICovCglpZiAoa2V5c3ltPD0yNykga2V5c3ltKz0weEZGMDA7LypzcGVjaWFsIGNoYXJzIDogcmV0dXJuLCBiYWNrc3BhY2UuLi4qLwoJCglrZXljb2RlID0gVFNYS2V5c3ltVG9LZXljb2RlKGRpc3BsYXksIGtleXN5bSk7ICAvKiBrZXlzeW0gLT4ga2V5Y29kZSAqLwoJaWYgKCFrZXljb2RlKQoJeyAvKiBJdCBkaWRuJ3Qgd29yayAuLi4gbGV0J3MgdHJ5IHdpdGggZGVhZGNoYXIgY29kZS4gKi8KCSAga2V5Y29kZSA9IFRTWEtleXN5bVRvS2V5Y29kZShkaXNwbGF5LCBrZXlzeW0gfCAweEZFMDApOwoJfQoKCVRSQUNFKCJWa0tleVNjYW4gJyVjJyglI2x4LCAlbHUpOiBnb3Qga2V5Y29kZSAlIy4yeFxuIiwKICAgICAgICAgICAgICBjQ2hhcixrZXlzeW0sa2V5c3ltLGtleWNvZGUpOwoJCglpZiAoa2V5Y29kZSkKCSAgewoJICAgIGZvciAoaW5kZXg9LTEsIGk9MDsgKGk8OCkgJiYgKGluZGV4PDApOyBpKyspIC8qIGZpbmQgc2hpZnQgc3RhdGUgKi8KCSAgICAgIGlmIChUU1hLZXljb2RlVG9LZXlzeW0oZGlzcGxheSxrZXljb2RlLGkpPT1rZXlzeW0pIGluZGV4PWk7CgkgICAgc3dpdGNoIChpbmRleCkgewoJICAgIGNhc2UgLTEgOgoJICAgICAgV0FSTigiS2V5c3ltICVseCBub3QgZm91bmQgd2hpbGUgcGFyc2luZyB0aGUga2V5Y29kZSB0YWJsZVxuIixrZXlzeW0pOyBicmVhazsKCSAgICBjYXNlIDAgOiBicmVhazsKCSAgICBjYXNlIDEgOiBoaWdoYnl0ZSA9IDB4MDEwMDsgYnJlYWs7CgkgICAgY2FzZSAyIDogaGlnaGJ5dGUgPSAweDA2MDA7IGJyZWFrOwoJICAgIGNhc2UgMyA6IGhpZ2hieXRlID0gMHgwNzAwOyBicmVhazsKCSAgICBkZWZhdWx0IDogRVJSKCJpbmRleCAlZCBmb3VuZCBieSBYS2V5Y29kZVRvS2V5c3ltLiBwbGVhc2UgcmVwb3J0ISBcbiIsaW5kZXgpOwoJICAgIH0KCSAgICAvKgoJICAgICAgaW5kZXggOiAwICAgICBhZGRzIDB4MDAwMAoJICAgICAgaW5kZXggOiAxICAgICBhZGRzIDB4MDEwMCAoc2hpZnQpCgkgICAgICBpbmRleCA6ID8gICAgIGFkZHMgMHgwMjAwIChjdHJsKQoJICAgICAgaW5kZXggOiAyICAgICBhZGRzIDB4MDYwMCAoY3RybCthbHQpCgkgICAgICBpbmRleCA6IDMgICAgIGFkZHMgMHgwNzAwIChjdHJsK2FsdCtzaGlmdCkKCSAgICAgKi8KCSAgfQoJVFJBQ0UoIiAuLi4gcmV0dXJuaW5nICUjLjJ4XG4iLCBrZXljMnZrZXlba2V5Y29kZV0raGlnaGJ5dGUpOwoJcmV0dXJuIGtleWMydmtleVtrZXljb2RlXStoaWdoYnl0ZTsgICAvKiBrZXljb2RlIC0+IChrZXljMnZrZXkpIHZrZXkgKi8KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlYMTFEUlZfTWFwVmlydHVhbEtleQogKi8KVUlOVDE2IFgxMURSVl9NYXBWaXJ0dWFsS2V5KFVJTlQxNiB3Q29kZSwgVUlOVDE2IHdNYXBUeXBlKQp7CiNkZWZpbmUgcmV0dXJuTVZLKHZhbHVlKSB7IFRSQUNFKCJyZXR1cm5pbmcgMHgleC5cbiIsdmFsdWUpOyByZXR1cm4gdmFsdWU7IH0KCglUUkFDRSgiTWFwVmlydHVhbEtleSB3Q29kZT0weCV4IHdNYXBUeXBlPSVkIC4uLiBcbiIsIHdDb2RlLHdNYXBUeXBlKTsKCXN3aXRjaCh3TWFwVHlwZSkgewoJCWNhc2UgMDoJeyAvKiB2a2V5LWNvZGUgdG8gc2Nhbi1jb2RlICovCgkJCS8qIGxldCdzIGRvIHZrZXkgLT4ga2V5Y29kZSAtPiBzY2FuICovCgkJCWludCBrZXljOwoJCQlmb3IgKGtleWM9bWluX2tleWNvZGU7IGtleWM8PW1heF9rZXljb2RlOyBrZXljKyspCgkJCQlpZiAoKGtleWMydmtleVtrZXljXSAmIDB4RkYpID09IHdDb2RlKQoJCQkJCXJldHVybk1WSyAoa2V5YzJzY2FuW2tleWNdICYgMHhGRik7CgkJCVRSQUNFKCJyZXR1cm5pbmcgbm8gc2Nhbi1jb2RlLlxuIik7CgkJICAgICAgICByZXR1cm4gMDsgfQoKCQljYXNlIDE6IHsgLyogc2Nhbi1jb2RlIHRvIHZrZXktY29kZSAqLwoJCQkvKiBsZXQncyBkbyBzY2FuIC0+IGtleWNvZGUgLT4gdmtleSAqLwoJCQlpbnQga2V5YzsKCQkJZm9yIChrZXljPW1pbl9rZXljb2RlOyBrZXljPD1tYXhfa2V5Y29kZTsga2V5YysrKQoJCQkJaWYgKChrZXljMnNjYW5ba2V5Y10gJiAweEZGKSA9PSAod0NvZGUgJiAweEZGKSkKCQkJCQlyZXR1cm5NVksgKGtleWMydmtleVtrZXljXSAmIDB4RkYpOwoJCQlUUkFDRSgicmV0dXJuaW5nIG5vIHZrZXktY29kZS5cbiIpOwoJCSAgICAgICAgcmV0dXJuIDA7IH0KCgkJY2FzZSAyOiB7IC8qIHZrZXktY29kZSB0byB1bnNoaWZ0ZWQgQU5TSSBjb2RlICovCgkJCS8qICh3YXMgRklYTUUpIDogd2hhdCBkb2VzIHVuc2hpZnRlZCBtZWFuID8gJ2EnIG9yICdBJyA/ICovCgkJICAgICAgICAvKiBNeSBXaW5kb3dzIHJldHVybnMgJ0EnLiAqLwoJCQkvKiBsZXQncyBkbyB2a2V5IC0+IGtleWNvZGUgLT4gKFhMb29rdXBTdHJpbmcpIGFuc2kgY2hhciAqLwoJCQlYS2V5RXZlbnQgZTsKCQkJS2V5U3ltIGtleXN5bTsKCQkJaW50IGtleWM7CgkJCWNoYXIgc1syXTsKCQkJZS5kaXNwbGF5ID0gZGlzcGxheTsKCQkJZS5zdGF0ZSA9IDA7IC8qIHVuc2hpZnRlZCAqLwoKCQkJZS5rZXljb2RlID0gMDsKCQkJLyogV2UgZXhpdCBvbiB0aGUgZmlyc3Qga2V5Y29kZSBmb3VuZCwgdG8gc3BlZWQgdXAgdGhlIHRoaW5nLiAqLwoJCQlmb3IgKGtleWM9bWluX2tleWNvZGU7IChrZXljPD1tYXhfa2V5Y29kZSkgJiYgKCFlLmtleWNvZGUpIDsga2V5YysrKQoJCQl7IC8qIEZpbmQgYSBrZXljb2RlIHRoYXQgY291bGQgaGF2ZSBnZW5lcmF0ZWQgdGhpcyB2aXJ0dWFsIGtleSAqLwoJCQkgICAgaWYgICgoa2V5YzJ2a2V5W2tleWNdICYgMHhGRikgPT0gd0NvZGUpCgkJCSAgICB7IC8qIFdlIGZpbHRlciB0aGUgZXh0ZW5kZWQgYml0LCB3ZSBkb24ndCBrbm93IGl0ICovCgkJCSAgICAgICAgZS5rZXljb2RlID0ga2V5YzsgLyogU3RvcmUgaXQgdGVtcG9yYXJpbHkgKi8KCQkJCWlmICgoRVZFTlRfZXZlbnRfdG9fdmtleSgmZSkgJiAweEZGKSAhPSB3Q29kZSkgewoJCQkJICAgIGUua2V5Y29kZSA9IDA7IC8qIFdyb25nIG9uZSAoZXg6IGJlY2F1c2Ugb2YgdGhlIE51bUxvY2sKCQkJCQkgc3RhdGUpLCBzbyBzZXQgaXQgdG8gMCwgd2UnbGwgZmluZCBhbm90aGVyIG9uZSAqLwoJCQkJfQoJCQkgICAgfQoJCQl9CgoJCQlpZiAoKHdDb2RlPj1WS19OVU1QQUQwKSAmJiAod0NvZGU8PVZLX05VTVBBRDkpKQoJCQkgIGUua2V5Y29kZSA9IFRTWEtleXN5bVRvS2V5Y29kZShlLmRpc3BsYXksIHdDb2RlLVZLX05VTVBBRDArWEtfS1BfMCk7CiAgICAgICAgICAKCQkJaWYgKHdDb2RlPT1WS19ERUNJTUFMKQoJCQkgIGUua2V5Y29kZSA9IFRTWEtleXN5bVRvS2V5Y29kZShlLmRpc3BsYXksIFhLX0tQX0RlY2ltYWwpOwoKCQkJaWYgKCFlLmtleWNvZGUpCgkJCXsKCQkJICBXQVJOKCJVbmtub3duIHZpcnR1YWwga2V5ICVYICEhISBcbiIsIHdDb2RlKTsKCQkJICByZXR1cm4gMDsgLyogd2hhdGV2ZXIgKi8KCQkJfQoJCQlUUkFDRSgiRm91bmQga2V5Y29kZSAlZCAoMHglMlgpXG4iLGUua2V5Y29kZSxlLmtleWNvZGUpOwoKCQkJaWYgKFRTWExvb2t1cFN0cmluZygmZSwgcywgMiwgJmtleXN5bSwgTlVMTCkpCgkJCSAgcmV0dXJuTVZLICgqcyk7CgkJCQoJCQlUUkFDRSgicmV0dXJuaW5nIG5vIEFOU0kuXG4iKTsKCQkJcmV0dXJuIDA7CgkJCX0KCgkJY2FzZSAzOiAgIC8qICoqTlQgb25seSoqIHNjYW4tY29kZSB0byB2a2V5LWNvZGUgYnV0IGRpc3Rpbmd1aXNoIGJldHdlZW4gICovCiAgICAgICAgICAgICAgCQkgIC8qICAgICAgICAgICAgIGxlZnQgYW5kIHJpZ2h0ICAqLwoJCSAgICAgICAgICBGSVhNRSgiIHN0dWIgZm9yIE5UXG4iKTsKICAgICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gMDsKCgkJZGVmYXVsdDogLyogcmVzZXJ2ZWQgKi8KCQkJV0FSTigiVW5rbm93biB3TWFwVHlwZSAlZCAhXG4iLCB3TWFwVHlwZSk7CgkJCXJldHVybiAwOwkKCX0KCXJldHVybiAwOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVgxMURSVl9HZXRLZXlOYW1lVGV4dAogKi8KSU5UMTYgWDExRFJWX0dldEtleU5hbWVUZXh0KExPTkcgbFBhcmFtLCBMUFNUUiBscEJ1ZmZlciwgSU5UMTYgblNpemUpCnsKICBpbnQgdmtleSwgYW5zaSwgc2NhbkNvZGU7CiAgS2V5Q29kZSBrZXljOwogIEtleVN5bSBrZXlzOwogIGNoYXIgKm5hbWU7CgkKICBzY2FuQ29kZSA9IGxQYXJhbSA+PiAxNjsKICBzY2FuQ29kZSAmPSAweDFmZjsgIC8qIGtlZXAgImV4dGVuZGVkLWtleSIgZmxhZyB3aXRoIGNvZGUgKi8KCiAgLyogRklYTUU6IHNob3VsZCB1c2UgTVZLIHR5cGUgMyAoTlQgdmVyc2lvbiB0aGF0IGRpc3Rpbmd1aXNoZXMgcmlnaHQgYW5kIGxlZnQgKi8KICB2a2V5ID0gWDExRFJWX01hcFZpcnR1YWxLZXkoc2NhbkNvZGUsIDEpOwoKICAvKiAgaGFuZGxlICJkb24ndCBjYXJlIiBiaXQgKDB4MDIwMDAwMDApICovCiAgaWYgKCEobFBhcmFtICYgMHgwMjAwMDAwMCkpIHsKICAgIHN3aXRjaCAodmtleSkgewogICAgICAgICBjYXNlIFZLX0xTSElGVDoKICAgICAgICAgY2FzZSBWS19SU0hJRlQ6CiAgICAgICAgICAgICAgICAgICAgICAgICAgdmtleSA9IFZLX1NISUZUOwogICAgICAgICAgICAgICAgICAgICAgICAgIGJyZWFrOwogICAgICAgY2FzZSBWS19MQ09OVFJPTDoKICAgICAgIGNhc2UgVktfUkNPTlRST0w6CiAgICAgICAgICAgICAgICAgICAgICAgICAgdmtleSA9IFZLX0NPTlRST0w7CiAgICAgICAgICAgICAgICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgICBjYXNlIFZLX0xNRU5VOgogICAgICAgICAgY2FzZSBWS19STUVOVToKICAgICAgICAgICAgICAgICAgICAgICAgICB2a2V5ID0gVktfTUVOVTsKICAgICAgICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICAgICAgZGVmYXVsdDoKICAgICAgICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgIH0KICB9CgogIGFuc2kgPSBYMTFEUlZfTWFwVmlydHVhbEtleSh2a2V5LCAyKTsKICBUUkFDRSgic2NhbiAweCUwNHgsIHZrZXkgMHglMDR4LCBBTlNJIDB4JTA0eFxuIiwgc2NhbkNvZGUsIHZrZXksIGFuc2kpOwoKICAvKiBmaXJzdCBnZXQgdGhlIG5hbWUgb2YgdGhlICJyZWd1bGFyIiBrZXlzIHdoaWNoIGlzIHRoZSBVcHBlciBjYXNlCiAgICAgdmFsdWUgb2YgdGhlIGtleWNhcCBpbXByaW50LiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqLwogIGlmICggKChhbnNpID49IDB4MjEpICYmIChhbnNpIDw9IDB4N2UpKSAmJgogICAgICAgKHNjYW5Db2RlICE9IDB4MTM3KSAmJiAgIC8qIFBydFNjbiAgICovCiAgICAgICAoc2NhbkNvZGUgIT0gMHgxMzUpICYmICAgLyogbnVtcGFkIC8gKi8KICAgICAgIChzY2FuQ29kZSAhPSAweDM3ICkgJiYgICAvKiBudW1wYWQgKiAqLwogICAgICAgKHNjYW5Db2RlICE9IDB4NGEgKSAmJiAgIC8qIG51bXBhZCAtICovCiAgICAgICAoc2NhbkNvZGUgIT0gMHg0ZSApICkgICAgLyogbnVtcGFkICsgKi8KICAgICAgewogICAgICAgIGlmICgoblNpemUgPj0gMikgJiYgbHBCdWZmZXIpCgl7CiAgICAgICAgKmxwQnVmZmVyID0gdG91cHBlcigoY2hhcilhbnNpKTsKICAgICAgICAgICoobHBCdWZmZXIrMSkgPSAwOwogICAgICAgICAgcmV0dXJuIDE7CiAgICAgICAgfSAKICAgICBlbHNlCiAgICAgICAgcmV0dXJuIDA7CiAgfQoKICAvKiBGSVhNRTogaG9ycmlibGUgaGFjayB0byBmaXggZnVuY3Rpb24ga2V5cy4gV2luZG93cyByZXBvcnRzIHNjYW5jb2RlCiAgICAgICAgICAgIHdpdGhvdXQgImV4dGVuZGVkLWtleSIgZmxhZy4gSG93ZXZlciBXaW5lIGdlbmVyYXRlcyBzY2FuY29kZQogICAgICAgICAgICAqd2l0aCogImV4dGVuZGVkLWtleSIgZmxhZy4gU2VlbXMgdG8gb2NjdXIgKm9ubHkqIGZvciB0aGUKICAgICAgICAgICAgZnVuY3Rpb24ga2V5cy4gU29vb28uLiBXZSB3aWxsIGxlYXZlIHRoZSB0YWJsZSBhbG9uZSBhbmQKICAgICAgICAgICAgZnVkZ2UgdGhlIGxvb2t1cCBoZXJlIHRpbGwgdGhlIG90aGVyIHBhcnQgaXMgZm91bmQgYW5kIGZpeGVkISEhICovCgogIGlmICggKChzY2FuQ29kZSA+PSAweDEzYikgJiYgKHNjYW5Db2RlIDw9IDB4MTQ0KSkgfHwKICAgICAgIChzY2FuQ29kZSA9PSAweDE1NykgfHwgKHNjYW5Db2RlID09IDB4MTU4KSkKICAgIHNjYW5Db2RlICY9IDB4ZmY7ICAgLyogcmVtb3ZlICJleHRlbmRlZC1rZXkiIGZsYWcgZm9yIEZ4IGtleXMgKi8KCiAgLyogbGV0J3MgZG8gc2NhbmNvZGUgLT4ga2V5Y29kZSAtPiBrZXlzeW0gLT4gU3RyaW5nICovCgogIGZvciAoa2V5Yz1taW5fa2V5Y29kZTsga2V5Yzw9bWF4X2tleWNvZGU7IGtleWMrKykKICAgICAgaWYgKChrZXljMnNjYW5ba2V5Y10pID09IHNjYW5Db2RlKQogICAgICAgICBicmVhazsKICBpZiAoa2V5YyA8PSBtYXhfa2V5Y29kZSkKICB7CiAgICAgIGtleXMgPSBUU1hLZXljb2RlVG9LZXlzeW0oZGlzcGxheSwga2V5YywgMCk7CiAgICAgIG5hbWUgPSBUU1hLZXlzeW1Ub1N0cmluZyhrZXlzKTsKICAgICAgVFJBQ0UoImZvdW5kIHNjYW49JTA0eCBrZXljPSUwNHgga2V5c3ltPSUwNHggc3RyaW5nPSVzXG4iLAogICAgICAgICAgICBzY2FuQ29kZSwga2V5YywgKGludClrZXlzLCBuYW1lKTsKICAgICAgaWYgKGxwQnVmZmVyICYmIG5TaXplICYmIG5hbWUpCiAgICAgIHsKICAgICAgICAgIGxzdHJjcHluQShscEJ1ZmZlciwgbmFtZSwgblNpemUpOwogICAgICAgICAgcmV0dXJuIDE7CiAgICAgIH0KICB9CgogIC8qIEZpbmFsbHkgaXNzdWUgRklYTUUgZm9yIHVua25vd24ga2V5cyAgICovCgogIEZJWE1FKCIoJTA4bHgsJXAsJWQpOiB1bnN1cHBvcnRlZCBrZXksIHZrZXk9JTA0eCwgYW5zaT0lMDR4XG4iLGxQYXJhbSxscEJ1ZmZlcixuU2l6ZSx2a2V5LGFuc2kpOwogIGlmIChscEJ1ZmZlciAmJiBuU2l6ZSkKICAgICpscEJ1ZmZlciA9IDA7CiAgcmV0dXJuIDA7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJWDExRFJWX0tFWUJPQVJEX01hcERlYWRLZXlzeW0KICovCnN0YXRpYyBjaGFyIEtFWUJPQVJEX01hcERlYWRLZXlzeW0oS2V5U3ltIGtleXN5bSkKewoJc3dpdGNoIChrZXlzeW0pCgkgICAgewoJLyogc3ltYm9saWMgQVNDSUkgaXMgdGhlIHNhbWUgYXMgZGVmaW5lZCBpbiByZmMxMzQ1ICovCiNpZmRlZiBYS19kZWFkX3RpbGRlCgkgICAgY2FzZSBYS19kZWFkX3RpbGRlIDoKI2VuZGlmCgkgICAgY2FzZSAweDEwMDBGRTdFIDogLyogWGZyZWUncyBYS19EdGlsZGUgKi8KCQlyZXR1cm4gJ34nOwkvKiAnPyAqLwojaWZkZWYgWEtfZGVhZF9hY3V0ZQoJICAgIGNhc2UgWEtfZGVhZF9hY3V0ZSA6CiNlbmRpZgoJICAgIGNhc2UgMHgxMDAwRkUyNyA6IC8qIFhmcmVlJ3MgWEtfRGFjdXRlX2FjY2VudCAqLwoJCXJldHVybiAweGI0OwkvKiAnJyAqLwojaWZkZWYgWEtfZGVhZF9jaXJjdW1mbGV4CgkgICAgY2FzZSBYS19kZWFkX2NpcmN1bWZsZXg6CiNlbmRpZgoJICAgIGNhc2UgMHgxMDAwRkU1RSA6IC8qIFhmcmVlJ3MgWEtfRGNpcmN1bWZsZXhfYWNjZW50ICovCgkJcmV0dXJuICdeJzsJLyogJz4gKi8KI2lmZGVmIFhLX2RlYWRfZ3JhdmUKCSAgICBjYXNlIFhLX2RlYWRfZ3JhdmUgOgojZW5kaWYKCSAgICBjYXNlIDB4MTAwMEZFNjAgOiAvKiBYZnJlZSdzIFhLX0RncmF2ZV9hY2NlbnQgKi8KCQlyZXR1cm4gJ2AnOwkvKiAnISAqLwojaWZkZWYgWEtfZGVhZF9kaWFlcmVzaXMKCSAgICBjYXNlIFhLX2RlYWRfZGlhZXJlc2lzIDoKI2VuZGlmCgkgICAgY2FzZSAweDEwMDBGRTIyIDogLyogWGZyZWUncyBYS19EZGlhZXJlc2lzICovCgkJcmV0dXJuIDB4YTg7CS8qICc6ICovCiNpZmRlZiBYS19kZWFkX2NlZGlsbGEKCSAgICBjYXNlIFhLX2RlYWRfY2VkaWxsYSA6CgkgICAgICAgIHJldHVybiAweGI4OwkvKiAnLCAqLwojZW5kaWYKI2lmZGVmIFhLX2RlYWRfbWFjcm9uCgkgICAgY2FzZSBYS19kZWFkX21hY3JvbiA6CgkgICAgICAgIHJldHVybiAnLSc7CS8qICdtIGlzbid0IGRlZmluZWQgb24gaXNvLTg4NTkteCAqLwojZW5kaWYKI2lmZGVmIFhLX2RlYWRfYnJldmUKCSAgICBjYXNlIFhLX2RlYWRfYnJldmUgOgoJICAgICAgICByZXR1cm4gMHhhMjsJLyogJyggKi8KI2VuZGlmCiNpZmRlZiBYS19kZWFkX2Fib3ZlZG90CgkgICAgY2FzZSBYS19kZWFkX2Fib3ZlZG90IDoKCSAgICAgICAgcmV0dXJuIDB4ZmY7CS8qICcuICovCiNlbmRpZgojaWZkZWYgWEtfZGVhZF9hYm92ZXJpbmcKCSAgICBjYXNlIFhLX2RlYWRfYWJvdmVyaW5nIDoKCSAgICAgICAgcmV0dXJuICcwJzsJLyogJzAgaXNuJ3QgZGVmaW5lZCBvbiBpc28tODg1OS14ICovCiNlbmRpZgojaWZkZWYgWEtfZGVhZF9kb3VibGVhY3V0ZQoJICAgIGNhc2UgWEtfZGVhZF9kb3VibGVhY3V0ZSA6CgkgICAgICAgIHJldHVybiAweGJkOwkvKiAnIiAqLwojZW5kaWYKI2lmZGVmIFhLX2RlYWRfY2Fyb24KCSAgICBjYXNlIFhLX2RlYWRfY2Fyb24gOgoJICAgICAgICByZXR1cm4gMHhiNzsJLyogJzwgKi8KI2VuZGlmCiNpZmRlZiBYS19kZWFkX29nb25lawoJICAgIGNhc2UgWEtfZGVhZF9vZ29uZWsgOgoJICAgICAgICByZXR1cm4gMHhiMjsJLyogJzsgKi8KI2VuZGlmCi8qIEZJWE1FOiBJIGRvbid0IGtub3cgdGhpcyB0aHJlZS4KCSAgICBjYXNlIFhLX2RlYWRfaW90YSA6CgkgICAgICAgIHJldHVybiAnaSc7CSAKCSAgICBjYXNlIFhLX2RlYWRfdm9pY2VkX3NvdW5kIDoKCSAgICAgICAgcmV0dXJuICd2JzsKCSAgICBjYXNlIFhLX2RlYWRfc2VtaXZvaWNlZF9zb3VuZCA6CgkgICAgICAgIHJldHVybiAncyc7CiovCgkgICAgfQoJVFJBQ0UoIm5vIGNoYXJhY3RlciBmb3IgZGVhZCBrZXlzeW0gMHglMDhseFxuIixrZXlzeW0pOwoJcmV0dXJuIDA7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJWDExRFJWX1RvQXNjaWkKICoKICogVGhlIFRvQXNjaWkgZnVuY3Rpb24gdHJhbnNsYXRlcyB0aGUgc3BlY2lmaWVkIHZpcnR1YWwta2V5IGNvZGUgYW5kIGtleWJvYXJkCiAqIHN0YXRlIHRvIHRoZSBjb3JyZXNwb25kaW5nIFdpbmRvd3MgY2hhcmFjdGVyIG9yIGNoYXJhY3RlcnMuCiAqCiAqIElmIHRoZSBzcGVjaWZpZWQga2V5IGlzIGEgZGVhZCBrZXksIHRoZSByZXR1cm4gdmFsdWUgaXMgbmVnYXRpdmUuIE90aGVyd2lzZSwKICogaXQgaXMgb25lIG9mIHRoZSBmb2xsb3dpbmcgdmFsdWVzOgogKiBWYWx1ZQlNZWFuaW5nCiAqIDAJVGhlIHNwZWNpZmllZCB2aXJ0dWFsIGtleSBoYXMgbm8gdHJhbnNsYXRpb24gZm9yIHRoZSBjdXJyZW50IHN0YXRlIG9mIHRoZSBrZXlib2FyZC4KICogMQlPbmUgV2luZG93cyBjaGFyYWN0ZXIgd2FzIGNvcGllZCB0byB0aGUgYnVmZmVyLgogKiAyCVR3byBjaGFyYWN0ZXJzIHdlcmUgY29waWVkIHRvIHRoZSBidWZmZXIuIFRoaXMgdXN1YWxseSBoYXBwZW5zIHdoZW4gYQogKiAgICAgIGRlYWQta2V5IGNoYXJhY3RlciAoYWNjZW50IG9yIGRpYWNyaXRpYykgc3RvcmVkIGluIHRoZSBrZXlib2FyZCBsYXlvdXQgY2Fubm90CiAqICAgICAgYmUgY29tcG9zZWQgd2l0aCB0aGUgc3BlY2lmaWVkIHZpcnR1YWwga2V5IHRvIGZvcm0gYSBzaW5nbGUgY2hhcmFjdGVyLgogKgogKiBGSVhNRSA6IHNob3VsZCBkbyB0aGUgYWJvdmUgKHJldHVybiAyIGZvciBub24gbWF0Y2hpbmcgZGVhZGNoYXIrY2hhciBjb21iaW5hdGlvbnMpCiAqCiAqLwpJTlQxNiBYMTFEUlZfVG9Bc2NpaSgKICAgIFVJTlQxNiB2aXJ0S2V5LFVJTlQxNiBzY2FuQ29kZSwgTFBCWVRFIGxwS2V5U3RhdGUsIAogICAgTFBWT0lEIGxwQ2hhciwgVUlOVDE2IGZsYWdzKQp7CiAgICBYS2V5RXZlbnQgZTsKICAgIEtleVN5bSBrZXlzeW07CiAgICBzdGF0aWMgWENvbXBvc2VTdGF0dXMgY3M7CiAgICBJTlQgcmV0OwogICAgaW50IGtleWM7CgogICAgaWYgKHNjYW5Db2RlPT0wKSB7CiAgICAgICAgLyogVGhpcyBoYXBwZW5zIHdoZW4gZG9pbmcgQWx0K2xldHRlciA6IGEgZmFrZSAnZG93biBhcnJvdycga2V5IHByZXNzCiAgICAgICAgICAgZXZlbnQgaXMgZ2VuZXJhdGVkIGJ5IHdpbmRvd3MuIEp1c3QgaWdub3JlIGl0LiAqLwogICAgICAgIFRSQUNFKCJzY2FuQ29kZT0wLCBkb2luZyBub3RoaW5nXG4iKTsKICAgICAgICByZXR1cm4gMDsKICAgIH0KICAgIGlmIChzY2FuQ29kZSAmIDB4ODAwMCkKICAgIHsKICAgICAgICBUUkFDRSgiS2V5IFVQLCBkb2luZyBub3RoaW5nXG4iICk7CiAgICAgICAgcmV0dXJuIDA7CiAgICB9CiAgICBlLmRpc3BsYXkgPSBkaXNwbGF5OwogICAgZS5rZXljb2RlID0gMDsKICAgIGUuc3RhdGUgPSAwOwogICAgaWYgKGxwS2V5U3RhdGVbVktfU0hJRlRdICYgMHg4MCkKCWUuc3RhdGUgfD0gU2hpZnRNYXNrOwogICAgaWYgKGxwS2V5U3RhdGVbVktfQ0FQSVRBTF0gJiAweDAxKQoJZS5zdGF0ZSB8PSBMb2NrTWFzazsKICAgIGlmIChscEtleVN0YXRlW1ZLX0NPTlRST0xdICYgMHg4MCkKICAgIHsKCWlmIChscEtleVN0YXRlW1ZLX01FTlVdICYgMHg4MCkKCSAgICBlLnN0YXRlIHw9IEFsdEdyTWFzazsKCWVsc2UKCSAgICBlLnN0YXRlIHw9IENvbnRyb2xNYXNrOwogICAgfQogICAgaWYgKGxwS2V5U3RhdGVbVktfTlVNTE9DS10gJiAweDAxKQoJZS5zdGF0ZSB8PSBOdW1Mb2NrTWFzazsKICAgIFRSQUNFXyhrZXkpKCIoJTA0WCwgJTA0WCkgOiBmYWtlZCBzdGF0ZSA9ICVYXG4iLAoJCXZpcnRLZXksIHNjYW5Db2RlLCBlLnN0YXRlKTsKICAgIC8qIFdlIGV4aXQgb24gdGhlIGZpcnN0IGtleWNvZGUgZm91bmQsIHRvIHNwZWVkIHVwIHRoZSB0aGluZy4gKi8KICAgIGZvciAoa2V5Yz1taW5fa2V5Y29kZTsgKGtleWM8PW1heF9rZXljb2RlKSAmJiAoIWUua2V5Y29kZSkgOyBrZXljKyspCiAgICAgIHsgLyogRmluZCBhIGtleWNvZGUgdGhhdCBjb3VsZCBoYXZlIGdlbmVyYXRlZCB0aGlzIHZpcnR1YWwga2V5ICovCiAgICAgICAgICBpZiAgKChrZXljMnZrZXlba2V5Y10gJiAweEZGKSA9PSB2aXJ0S2V5KQogICAgICAgICAgeyAvKiBXZSBmaWx0ZXIgdGhlIGV4dGVuZGVkIGJpdCwgd2UgZG9uJ3Qga25vdyBpdCAqLwogICAgICAgICAgICAgIGUua2V5Y29kZSA9IGtleWM7IC8qIFN0b3JlIGl0IHRlbXBvcmFyaWx5ICovCiAgICAgICAgICAgICAgaWYgKChFVkVOVF9ldmVudF90b192a2V5KCZlKSAmIDB4RkYpICE9IHZpcnRLZXkpIHsKICAgICAgICAgICAgICAgICAgZS5rZXljb2RlID0gMDsgLyogV3Jvbmcgb25lIChleDogYmVjYXVzZSBvZiB0aGUgTnVtTG9jawogICAgICAgICAgICAgICAgICAgICAgICAgc3RhdGUpLCBzbyBzZXQgaXQgdG8gMCwgd2UnbGwgZmluZCBhbm90aGVyIG9uZSAqLwogICAgICAgICAgICAgIH0KCSAgfQogICAgICB9CgogICAgaWYgKCh2aXJ0S2V5Pj1WS19OVU1QQUQwKSAmJiAodmlydEtleTw9VktfTlVNUEFEOSkpCiAgICAgICAgZS5rZXljb2RlID0gVFNYS2V5c3ltVG9LZXljb2RlKGUuZGlzcGxheSwgdmlydEtleS1WS19OVU1QQUQwK1hLX0tQXzApOwogICAgICAgICAgCiAgICBpZiAodmlydEtleT09VktfREVDSU1BTCkKICAgICAgICBlLmtleWNvZGUgPSBUU1hLZXlzeW1Ub0tleWNvZGUoZS5kaXNwbGF5LCBYS19LUF9EZWNpbWFsKTsKCiAgICBpZiAoIWUua2V5Y29kZSkKICAgICAgewoJV0FSTigiVW5rbm93biB2aXJ0dWFsIGtleSAlWCAhISEgXG4iLHZpcnRLZXkpOwoJcmV0dXJuIHZpcnRLZXk7IC8qIHdoYXRldmVyICovCiAgICAgIH0KICAgIGVsc2UgVFJBQ0UoIkZvdW5kIGtleWNvZGUgJWQgKDB4JTJYKVxuIixlLmtleWNvZGUsZS5rZXljb2RlKTsKCiAgICByZXQgPSBUU1hMb29rdXBTdHJpbmcoJmUsIChMUFZPSUQpbHBDaGFyLCAyLCAma2V5c3ltLCAmY3MpOwogICAgaWYgKHJldCA9PSAwKQoJewoJQllURSBkZWFkX2NoYXIgPSAwOwoKCSgoY2hhciopbHBDaGFyKVsxXSA9ICdcMCc7CglkZWFkX2NoYXIgPSBLRVlCT0FSRF9NYXBEZWFkS2V5c3ltKGtleXN5bSk7CglpZiAoZGVhZF9jaGFyKQoJICAgIHsKCSAgICAqKGNoYXIqKWxwQ2hhciA9IGRlYWRfY2hhcjsKCSAgICByZXQgPSAtMTsKCSAgICB9CgllbHNlCgkgICAgewoJICAgIGNoYXIJKmtzbmFtZTsKCgkgICAga3NuYW1lID0gVFNYS2V5c3ltVG9TdHJpbmcoa2V5c3ltKTsKCSAgICBpZiAoIWtzbmFtZSkKCQlrc25hbWUgPSAiTm8gTmFtZSI7CgkgICAgaWYgKChrZXlzeW0gPj4gOCkgIT0gMHhmZikKCQl7CgkJRVJSKCJQbGVhc2UgcmVwb3J0OiBubyBjaGFyIGZvciBrZXlzeW0gJTA0bFggKCVzKSA6XG4iLAogICAgICAgICAgICAgICAgICAgIGtleXN5bSwga3NuYW1lKTsKCQlFUlIoIih2aXJ0S2V5PSVYLHNjYW5Db2RlPSVYLGtleWNvZGU9JVgsc3RhdGU9JVgpXG4iLAogICAgICAgICAgICAgICAgICAgIHZpcnRLZXksIHNjYW5Db2RlLCBlLmtleWNvZGUsIGUuc3RhdGUpOwoJCX0KCSAgICB9Cgl9CiAgICBlbHNlIHsgIC8qIHJldCA9IDEgKi8KICAgICAgICAvKiBXZSBoYXZlIGEgc3BlY2lhbCBjYXNlIHRvIGhhbmRsZSA6IFNoaWZ0ICsgYXJyb3csIHNoaWZ0ICsgaG9tZSwgLi4uCiAgICAgICAgICAgWCByZXR1cm5zIGEgY2hhciBmb3IgaXQsIGJ1dCBXaW5kb3dzIGRvZXNuJ3QuIExldCdzIGVhdCBpdC4gKi8KICAgICAgICBpZiAoIShscEtleVN0YXRlW1ZLX05VTUxPQ0tdICYgMHgwMSkgIC8qIE51bUxvY2sgaXMgb2ZmICovCiAgICAgICAgICAgICYmIChscEtleVN0YXRlW1ZLX1NISUZUXSAmIDB4ODApIC8qIFNoaWZ0IGlzIHByZXNzZWQgKi8KICAgICAgICAgICAgJiYgKGtleXN5bT49WEtfS1BfMCkgJiYgKGtleXN5bTw9WEtfS1BfOSkpCiAgICAgICAgewogICAgICAgICAgICAqKGNoYXIqKWxwQ2hhciA9IDA7CiAgICAgICAgICAgIHJldCA9IDA7CiAgICAgICAgfQogICAgICAgIAogICAgICAgIC8qIFdlIGhhdmUgYW5vdGhlciBzcGVjaWFsIGNhc2UgZm9yIGRlbGV0ZSBrZXkgKFhLX0RlbGV0ZSkgb24gYW4KICAgICAgICAgZXh0ZW5kZWQga2V5Ym9hcmQuIFggcmV0dXJucyBhIGNoYXIgZm9yIGl0LCBidXQgV2luZG93cyBkb2Vzbid0ICovCiAgICAgICAgaWYgKGtleXN5bSA9PSBYS19EZWxldGUpCiAgICAgICAgewogICAgICAgICAgICAqKGNoYXIqKWxwQ2hhciA9IDA7CiAgICAgICAgICAgIHJldCA9IDA7CiAgICAgICAgfQogICAgfQoKICAgIFRSQUNFXyhrZXkpKCJUb0FzY2lpIGFib3V0IHRvIHJldHVybiAlZCB3aXRoIGNoYXIgJXhcbiIsCgkJcmV0LCAqKGNoYXIqKWxwQ2hhcik7CiAgICByZXR1cm4gcmV0Owp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVgxMURSVl9HZXRCZWVwQWN0aXZlCiAqLwpCT09MIFgxMURSVl9HZXRCZWVwQWN0aXZlKCkKewogIFhLZXlib2FyZFN0YXRlICBrZXlib2FyZF9zdGF0ZTsKCiAgVFNYR2V0S2V5Ym9hcmRDb250cm9sKGRpc3BsYXksICZrZXlib2FyZF9zdGF0ZSk7CgogIHJldHVybiBrZXlib2FyZF9zdGF0ZS5iZWxsX3BlcmNlbnQgIT0gMDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlYMTFEUlZfU2V0QmVlcEFjdGl2ZQogKi8Kdm9pZCBYMTFEUlZfU2V0QmVlcEFjdGl2ZShCT09MIGJBY3RpdmF0ZSkKewogIFhLZXlib2FyZENvbnRyb2wga2V5Ym9hcmRfdmFsdWU7CiAgCiAgaWYoYkFjdGl2YXRlKQogICAga2V5Ym9hcmRfdmFsdWUuYmVsbF9wZXJjZW50ID0gLTE7CiAgZWxzZQogICAga2V5Ym9hcmRfdmFsdWUuYmVsbF9wZXJjZW50ID0gMDsKICAKICBUU1hDaGFuZ2VLZXlib2FyZENvbnRyb2woZGlzcGxheSwgS0JCZWxsUGVyY2VudCwgJmtleWJvYXJkX3ZhbHVlKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlYMTFEUlZfQmVlcAogKi8Kdm9pZCBYMTFEUlZfQmVlcCgpCnsKICBUU1hCZWxsKGRpc3BsYXksIDApOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVgxMURSVl9HZXRESVN0YXRlCiAqLwpCT09MIFgxMURSVl9HZXRESVN0YXRlKERXT1JEIGxlbiwgTFBWT0lEIHB0cikKewogIGlmIChsZW49PTI1NikgewogICAgaW50IGtleWMsdmtleTsKICAgIAogICAgbWVtc2V0KHB0ciwwLDI1Nik7CiAgICBmb3IgKGtleWM9bWluX2tleWNvZGU7a2V5YzxtYXhfa2V5Y29kZTtrZXljKyspCiAgICAgIHsKCS8qIFgga2V5Y29kZSB0byB2aXJ0dWFsIGtleSAqLwoJdmtleSA9IGtleWMydmtleVtrZXljXSAmIDB4RkY7CgkvKiBUaGUgd2luZG93cyBzY2FuY29kZSBpcyBrZXljLW1pbl9rZXljb2RlICovCglpZiAoSW5wdXRLZXlTdGF0ZVRhYmxlW3ZrZXldJjB4ODApIHsKCSAgKChMUEJZVEUpcHRyKVtrZXljLW1pbl9rZXljb2RlXT0weDgwOwoJICAoKExQQllURSlwdHIpWyhrZXljLW1pbl9rZXljb2RlKXwweDgwXT0weDgwOwoJfQogICAgICB9CiAgICByZXR1cm4gVFJVRTsKICB9CiAgV0FSTigid2hvb3BzLCBnb3QgbGVuICVsZD9cbiIsIGxlbik7CiAgcmV0dXJuIFRSVUU7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJWDExRFJWX0dldERJRGF0YQogKi8KQk9PTCBYMTFEUlZfR2V0RElEYXRhKAogIEJZVEUgKmtleXN0YXRlLAogIERXT1JEIGRvZHNpemUsIExQRElERVZJQ0VPQkpFQ1REQVRBIGRvZCwKICBMUERXT1JEIGVudHJpZXMsIERXT1JEIGZsYWdzKQp7CiAgaW50IGtleWMsbix2a2V5LHhlbnRyaWVzOwogICAgCiAgLyogRklYTUUgISEhICovCiAgCiAgaWYgKGVudHJpZXMpCiAgICB4ZW50cmllcyA9ICplbnRyaWVzOyAKICBlbHNlCiAgICB4ZW50cmllcyA9IDE7CiAgCiAgbiA9IDA7CiAgCiAgZm9yIChrZXljPW1pbl9rZXljb2RlOyhrZXljPG1heF9rZXljb2RlKSAmJiAobjwqZW50cmllcyk7a2V5YysrKQogICAgewogICAgICAvKiBYIGtleWNvZGUgdG8gdmlydHVhbCBrZXkgKi8KICAgICAgdmtleSA9IGtleWMydmtleVtrZXljXSAmIDB4RkY7CiAgICAgIGlmIChrZXlzdGF0ZVt2a2V5XSA9PSAoSW5wdXRLZXlTdGF0ZVRhYmxlW3ZrZXldJjB4ODApKQoJY29udGludWU7CiAgICAgIGlmIChkb2QpIHsKCS8qIGFkZCBhbiBlbnRyeSAqLwoJZG9kW25dLmR3T2ZzCQk9IGtleWMtbWluX2tleWNvZGU7IC8qIHNjYW5jb2RlICovCglkb2Rbbl0uZHdEYXRhCQk9IElucHV0S2V5U3RhdGVUYWJsZVt2a2V5XSYweDgwOwoJZG9kW25dLmR3VGltZVN0YW1wCT0gMDsgLyogdW1tICovCglkb2Rbbl0uZHdTZXF1ZW5jZQk9IDA7IC8qIHVtbSAqLwoJbisrOwogICAgICB9CiAgICAgIGlmICghKGZsYWdzICYgRElHRERfUEVFSykpCglrZXlzdGF0ZVt2a2V5XSA9IElucHV0S2V5U3RhdGVUYWJsZVt2a2V5XSYweDgwOwogICAgICAKICAgIH0KICAKICBpZiAobikgVFJBQ0VfKGRpbnB1dCkoIiVkIGVudHJpZXNcbiIsbik7CiAgKmVudHJpZXMgPSBuOwoKICByZXR1cm4gVFJVRTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlYMTFEUlZfR2V0S2V5Ym9hcmRDb25maWcKICovCnZvaWQgWDExRFJWX0dldEtleWJvYXJkQ29uZmlnKEtFWUJPQVJEX0NPTkZJRyAqY2ZnKSB7CiAgWEtleWJvYXJkU3RhdGUgICB4a3M7CgogIC8qIEZvciB0aGUgbW9tZW50LCBvbmx5IGdldCB0aGUgYXV0by1yZXBlYXQgbW9kZSAqLwogIFRTWEdldEtleWJvYXJkQ29udHJvbChkaXNwbGF5LCAmeGtzKTsKICBjZmctPmF1dG9fcmVwZWF0ID0geGtzLmdsb2JhbF9hdXRvX3JlcGVhdDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlYMTFEUlZfU2V0S2V5Ym9hcmRDb25maWcKICovCmV4dGVybiB2b2lkIFgxMURSVl9TZXRLZXlib2FyZENvbmZpZyhLRVlCT0FSRF9DT05GSUcgKmNmZywgRFdPUkQgbWFzaykgewogIFhLZXlib2FyZENvbnRyb2wgeGtjOwogIHVuc2lnbmVkIGxvbmcgWF9tYXNrID0gMDsKICAKICBpZiAobWFzayAmIFdJTkVfS0VZQk9BUkRfQ09ORklHX0FVVE9fUkVQRUFUKSB7CiAgICBYX21hc2sgfD0gS0JBdXRvUmVwZWF0TW9kZTsKICAgIHhrYy5hdXRvX3JlcGVhdF9tb2RlID0gY2ZnLT5hdXRvX3JlcGVhdDsKICB9CiAgaWYgKFhfbWFzaykKICAgIFRTWENoYW5nZUtleWJvYXJkQ29udHJvbChkaXNwbGF5LCBYX21hc2ssICZ4a2MpOwp9Cgo=