python2-cryptography-2.9.2-150200.13.1<>,HcIzgp9|72gȣ/vѧe I::;qu:/Hr dC.$Dʧ(3~6K?ڨU۞3? GfaNTnFu6=5IuK{o%߿#l"ŧcE ZV uXfkQ^K 1y=ySջת  MJ89d&.QU0hOس-h˧Gu[m5nM㡂qxXD~>D%0?% d ) k1Rm ,  X    Rr SW]NbbgDggj(j8jE9kE:q"EBFGHItXYZ[\]@^ dbcqdefl uvt wxy t z$$$$$$$%Cpython2-cryptography2.9.2150200.13.1Python library which exposes cryptographic recipes and primitivescryptography is a package designed to expose cryptographic recipes and primitives to Python developers. Our goal is for it to be your "cryptographic standard library". It supports Python 2.7, Python 3.4+, and PyPy-5.3+. cryptography includes both high level recipes, and low level interfaces to common cryptographic algorithms such as symmetric ciphers, message digests and key derivation functions.cIzgibs-power9-12-gSUSE Linux Enterprise 15SUSE LLC Apache-2.0 OR BSD-3-Clausehttps://www.suse.com/Development/Languages/Pythonhttps://cryptography.io/en/latest/linuxppc64le.Lj.0\\]] dUPP [ } }yy*N4N4Pv|KIB%'' ' ~ ~*>*Z*Z'-f-f1.44``<<\)ZZ | 6;<< 4 D>Q>Q # ZNfeyhP""+==?((N%%//5R{R{ [ __a(6:6  r%^  --'' s>)) EE bb)(  k  V $N$N HHpyKK !! : zz^]tWtWWAA(;; 9.<.<4DODO*&,&,  `,`AA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤cIucIucItcItcItcItcItcIt^cItcIt^īcItcIt^īcItcIt^īcItcItcIu^īcItcIt^īcItcIt^īcItcItcIu^īcItcIt^īcItcItcIu^īcItcIt^īcItcIt^cItcIt`EcItcIt^īcItcIt^īcItcIt^cItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt`EcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcItcIu^īcItcItcIucIucIucIu^īcItcIt^cItcIt^cItcItcIu^īcItcItcIu^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^cItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcItcIu^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^cItcIt^īcItcIt^īcItcItcIu^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcItcIu^īcItcIt^īcItcIt^īcItcIt^īcItcItcIu^īcItcIt^īcItcIt^īcItcIt^īcItcIt^cItcItcIu^īcItcIt^īcItcIt^īcItcIt^cItcIt^īcItcIt^īcItcIt^īcItcIt^īcItcItcIzX^īcIt^ī^īcIzX^ī^ī^ī66528a48a584978f498b23f5515bd924b00cf903933bed63168a5e0f3c3c963d4f9bb4c0a3cbb7430a3943aebc63440152d99d9a0e35d01ccb07dfe7d31c8b8301ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b01ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b58e9cd1a90d13bb3976c8e47e0bc05a1cf45b6dd16edd6cb83b6146f8004b019402918404e07241a6a22bf9a06a6ce67bd0d95f6de8ca9c313a3836cd814c30828dc5eefb4210a9993b276d4fd9f87b08a2c820591bc4669d17ae11199a950fb3a8a69e3ce36337720ee8c8394e14a8ac79a744e447b13077b73545b5a18fbce3a8a69e3ce36337720ee8c8394e14a8ac79a744e447b13077b73545b5a18fbce33b990adf08762e93b4e910fa5f63192173de5ca26ab13ade35c588cb6b9c220bb13b88343990191931711f38fa10672caa749236740d73b4b66e4153c3f1bb8bb13b88343990191931711f38fa10672caa749236740d73b4b66e4153c3f1bb834fb43a88ab596c43519bd415e48ec188bdb32b58c68a09a4fc7a9892822d35dabecf7b7eb63a64698c5c210a096ac104d385a2bcd36b2ea8aa067337ce4d4ceabecf7b7eb63a64698c5c210a096ac104d385a2bcd36b2ea8aa067337ce4d4ce080e22590bcf0de17d10dd085aaf31cae041a8cbdca44135ec88bc5466e2d7d69befa2275c91a11b394339d99720e096a1011245ff926df1ecda0f24dea5c30e9befa2275c91a11b394339d99720e096a1011245ff926df1ecda0f24dea5c30e8443cd430f1d82320f227e36a9a2f05cd44b0b24c6359792be441be7b0cf85bbfba2b416b8712e18fc97e438b57c56b0d6e1e5ff8fa85515607a7f082b12752afba2b416b8712e18fc97e438b57c56b0d6e1e5ff8fa85515607a7f082b12752af7057bbacb2c03efc8931a34879b9510925c63ab916f0e148658232e15d8b24db5004b3b0c89350341781370a7dd1955fdefa9b7a3df0de83625d20e24c3dd2bb5004b3b0c89350341781370a7dd1955fdefa9b7a3df0de83625d20e24c3dd2bbd3287968ade8c7c9265707b43d12325c73b23cceb8bb0f83c156dbc0deb58508089ea8890b49da0eab77fae7b8bae4b1459037cfed7973375de23e86552c0ad8089ea8890b49da0eab77fae7b8bae4b1459037cfed7973375de23e86552c0adf76519766a93c903ce600dae8b5eed92cca3c419d39a3d570ecc4308284bbf11cc6237e0ae2c469f83f5406666b9506ac7bb2ad38ed4150bbccf67d37515cd46cc6237e0ae2c469f83f5406666b9506ac7bb2ad38ed4150bbccf67d37515cd4632836b7dc68fe5ca43d3fc091f9bfabf21925c2f0eb1b0001e6e3ef53652214d4847dad78a33cc58558a985bb72a2d37d244023bd2e1eeae9fcb02fd12b118254847dad78a33cc58558a985bb72a2d37d244023bd2e1eeae9fcb02fd12b118259380cc7b6dbcfe14ee076918dcbc24eb625d23712609ded5915d35cc99b9ee9b26ebf327f3ef6d4c2cd60dd5b3f52cc943b2fd266934de8e73bb926c49850ba126ebf327f3ef6d4c2cd60dd5b3f52cc943b2fd266934de8e73bb926c49850ba153435cc34cf8fa9a84591c49bbd1b36433d3be9f18056e461c579b7246852d3b9e9a1462a47112a80e7bb84a7e210195e2a952ba3d010e62abecacc04a5c19c175e4287b3154a10f2999b05eb1ab9f854eed2c987751938d19937bcd5a20570c5c53577e49b0cfa050d79c3d4dbe6f4eb493588f32ce9e5acd307dddc7ff0010ec16b66cd2d21ad59c708666bcdc2fe103497e25237271b41702312f9d6e2a479c7ddfe3868eadc4682349997c52848361a6ddd01c768149ecb93ec7f09a6b9903f408fbe2bd88141682ea57f9c8995ec4c3508e7f509839040c67791da0afe8a48653c566983b7fab217062f86c2400b9f691428863e4a2495572b59758625aa48653c566983b7fab217062f86c2400b9f691428863e4a2495572b59758625ac310877df540105c5c9fa01330fcbb1c04c88d665632829d4d71c90a07947f8f22f5960d3b003ef43731cb333e2e78c111feb30884d16499c5c35ae7030f06fa22f5960d3b003ef43731cb333e2e78c111feb30884d16499c5c35ae7030f06fad76e35a6a264cf78eab80ba851d6c7e77224bd4ed044d6af75b0a1823fb0a6a8c704d2abce49c00e542366ce1a8e888c7224d9253b8310a1d33b478551cba5653c88fb9c64b0ae804cb179c024df4f9982fc2a38c029b0e3208106f6625564f29171f42d72ec828ec52cd6a7e95e418a2752df4cd5916370696b9567e9fa528813f39f00d500d873fc226e70420d161a8e76042193d1cb61298e6fc4db56cd4313f39f00d500d873fc226e70420d161a8e76042193d1cb61298e6fc4db56cd4360e14cfe6976278aba4c8e7ea21f0cf513d2deed9d7145b14f9d58c5fa5bb3ba914e4f207682043bb58c7e8ba68324a9cf942e3f2fdf76b6db1e01a001626f71914e4f207682043bb58c7e8ba68324a9cf942e3f2fdf76b6db1e01a001626f71a2467cec471a3894469a3114bc83ea0d5ec9a7ac5c932e2814f48de9f5db1abb26f53800bfdaae020be767e90fa4878e80d6a66ed991978f88f4f1e7c6c1e24a0eb0c463d4e655568f19d892e89f59b1dc52eba9722d63fe76c82b6026d6f7cfeba76424f67a82f50225203444fc9d8b5fb44365a386201c2b0bc3d91e7d67377c58ba1c0ff29ee29cf25f0fb94e1ca658e1a155551cd8c59ee9eea43592890c7c58ba1c0ff29ee29cf25f0fb94e1ca658e1a155551cd8c59ee9eea43592890cd96e8ac333d05cfbef91a359585c48fcbf2b20ff34be105c75955b2334b93266794233a8ad94ec009751f29fc81ce4c56ab2c0477b8c4e87526a95be9fe02722794233a8ad94ec009751f29fc81ce4c56ab2c0477b8c4e87526a95be9fe02722f1750e4dd1ab78e62f5a1895790b4bed756a941a4ffab9cbb83ae633b6c6e0b40e5f6c8c686a1148810e083f279a1c0b6e1397a2824aa023f1bd858238d1cdf2f4d02d36d623da859687637715390def580f9581132ce8198d12299bf44aa664fee61c2a3ad6cc289fcfdb8e34f14119b6bb402de8ebaf8acf191235fdae23f0f2bd473ed014f027ed857aa4c5fc23073904651a25851394ebc9c805b4843333f2bd473ed014f027ed857aa4c5fc23073904651a25851394ebc9c805b4843333fb932c36af7e03b22cfe752331dcf41673a9772dcc9e8c025aa0c618bebb87236a04e2cd66c0e44d43cc2e2f650f656922a48d7fcd4a74f42b64fae1efc34ba26a04e2cd66c0e44d43cc2e2f650f656922a48d7fcd4a74f42b64fae1efc34ba28a14715ecf9bc35eb4f714cb1545dea3a5011a5593b4292514bbc8a9ccf97106e86b9613744629834e020cb8cc44da1ad3e846b7069d05269fb15fac09cfbf47e86b9613744629834e020cb8cc44da1ad3e846b7069d05269fb15fac09cfbf4759a4372f2c4f0f69bd6aec92cb89b30cc3285b14d3e29c3fce1839e67d43e868d3b2a2cd806fa0f7573a56a99afb42831be7a7fc2bbeabca527c51c22a2541fed3b2a2cd806fa0f7573a56a99afb42831be7a7fc2bbeabca527c51c22a2541fe2af8c7c0fd269a01051e15deb39befaea3691c4016bf60914b439c9062dd0ffb2f9bbb80bed62eb97195e538e65225120dee15fb96427b0c01646ae4bfaf80482f9bbb80bed62eb97195e538e65225120dee15fb96427b0c01646ae4bfaf80482eace831f2db3b7dfce61f89815f11896423d1bbed472efa2f38a646a8c84f64a9542e241e08da737726f915d3ad40cd5f6fe9a16a7fb62180ed9e72db3c7a30a9542e241e08da737726f915d3ad40cd5f6fe9a16a7fb62180ed9e72db3c7a30064a5d4b8909ca62ce7f87ecb36c151c01b9a1b481a22e88dcf4df1382edef2a3598442efcba756fe7ec21dcf9ea318f2b17e840839405995c8597eeaecd92733598442efcba756fe7ec21dcf9ea318f2b17e840839405995c8597eeaecd9273faf3282092785f71dd0782eb5b1c6ad3fc69d2c0ccebd4ba54cfcff9daa27b6e5eba6146a86b31c5487b8e9ff279ace8f76e3d3bc655b842a4aac5a78dbe4e355eba6146a86b31c5487b8e9ff279ace8f76e3d3bc655b842a4aac5a78dbe4e3526397eb09890bed98cf426e7442a86b376f17b27d6f93ac3b14017d06bc7aab34a59830fe4ba45811a8a14443149d9046e7489e6054278188301398fcca57d7bf158dc59678de843065d0fbf488033358df1953413bc86f80624c1e01f7b6f32d301b0d8e17d47b7c75fb35610d0a6aec62281b5c7536a23827f8de11923b3d526f8f678f161b3886553ea620ce511a99de75b4051d578cc0f994195e9cf419b26f8f678f161b3886553ea620ce511a99de75b4051d578cc0f994195e9cf419b3e3d2c5ea59c972ca52f0796f8a2072eb654cb4bb138a08e5f0860d6f4912823d3396fa054de0d9ecd7cb3570aade7455975761cbc9a23b682c8d875243988d28d90cbf8add6806a6db8b1c1d651424f54b2d93b77126bb0f36a3d3dac01c9ecd301b0d8e17d47b7c75fb35610d0a6aec62281b5c7536a23827f8de11923b3d5f5dd9f62a603f3cc5aad01665f71de0fa5d8d57aa2aaa7255451ba4bc15a889bf5dd9f62a603f3cc5aad01665f71de0fa5d8d57aa2aaa7255451ba4bc15a889be013dd5541024ebe6a40011f17e2926bb2317247a06c90c6b3c08805c9d31ab6f7867cf442236e2aa106a3845f686652d80eed2b6fa039f8360892c561caba96f7867cf442236e2aa106a3845f686652d80eed2b6fa039f8360892c561caba964381f7f5045e300d4c79732fb24af87e3acd8aec51d3111b9d5fa371574a527b4f3326b98934405c725103717222b1215d6c44f95db3880e5576cb2a6eb763314f3326b98934405c725103717222b1215d6c44f95db3880e5576cb2a6eb76331d301b0d8e17d47b7c75fb35610d0a6aec62281b5c7536a23827f8de11923b3d5cce3f3ce6e69526d86802472072dd4b988d5b2dd0fb4a0daa6363e4609800e35cce3f3ce6e69526d86802472072dd4b988d5b2dd0fb4a0daa6363e4609800e355a1527ded1b1a0b031180b191c4949d9a3882d74a1e790198b4e0c06e7589900218f64020d17704eb17f911527d5efda022cdee502d1f02e3cf489362ed9faa4218f64020d17704eb17f911527d5efda022cdee502d1f02e3cf489362ed9faa4e97974d5b8d354714271d26bdcf876710ee1c6461879daa6f927a4669c679ed6716eabab0d665219b81169761456b1cfe8e0791df52b164762d34952bd61bb91716eabab0d665219b81169761456b1cfe8e0791df52b164762d34952bd61bb91bb32bbaa97b406da8792054b4ab346b6c91ad70dc949437fb99a7a5c00392cc670bbe3253985498c9caa2f5779671eff5d72de52774ef8786a02cbf2d9619fb970bbe3253985498c9caa2f5779671eff5d72de52774ef8786a02cbf2d9619fb9c45cae0dee77622e0c61d2f11d6a37d90fdbf9486d6b30f7a836005080dcddfcd005713ea7ee1ca99c6f11ce1f0ecef36ad4b2d6c7229e4591a99a4c0c6b55edd005713ea7ee1ca99c6f11ce1f0ecef36ad4b2d6c7229e4591a99a4c0c6b55ed2bb7461c43431263b4912d1fa9e4fa75c98c468f486ca2eeb36e9601f0c386335402c3819bb72120d86d4f7b27e6edf1c2e3a337d76a32b1880095c4eaa49b045402c3819bb72120d86d4f7b27e6edf1c2e3a337d76a32b1880095c4eaa49b047a8467880e723777e04f456eb6ea3e8fa8b5c9e88a10a03ffb8684ac93dd97ac082fd414453c75ed5d7afcb2fa7ad300bd6ad40066d5bf5cd74f23268ba5be89082fd414453c75ed5d7afcb2fa7ad300bd6ad40066d5bf5cd74f23268ba5be8968265ab54e7eabf596e6f6b305678a3c5f1965ad0023c856cdb25a551377456254478747b7ec4e5d62e94861cce540bfc1c2b3bda29223740ed584cc8b6b8dbdf5f29518f34f40827994c8c62846bdc06cac6ae44fbf96e3e7cd143fd75504a383bca042211c846c8c3d76bc02790fc8caec063038bf9b22584d56948fd24ce69e8e2bb6c974e8befb539544b9b1b615639ada52b8dd8cbfc804a2ce44f0de1de315b02b0a4d64d521938baaec4a8bc91373589918f6187f63f69820a39acd923a0e63671628084f4131bddd9aab8c4da9ed8ec8f3974cf69aaa1cf6cfb4e7cf3a466f9a6ab1420eb3bd849de364948d991d5be10b0298b40df6e48ab8b7d9c83a466f9a6ab1420eb3bd849de364948d991d5be10b0298b40df6e48ab8b7d9c8e905fc4b0115ee1e32d2ac0001806aec87eddf5191ff7cd8e6ffbd16320a098b8c10a3eb4ad4ff12462b41ae3d677fa28f5c10362148cd295aa8fe30f8bd818c8c10a3eb4ad4ff12462b41ae3d677fa28f5c10362148cd295aa8fe30f8bd818c81b67f51d548a3379957b15f769239aa9e2ddf59d61945e22b07e0318ac5da26b6b9f0c842fdc6f9d6b0ada879a3ec092ad9a942dbc6e7878d4dfcf737c47b93b6b9f0c842fdc6f9d6b0ada879a3ec092ad9a942dbc6e7878d4dfcf737c47b934316b17a37857f3e823e123573888dabfec3b22078d58fd0fae2dfccec7b7effca2eaae7d7fb4036c073645484faa547fee871caafbca590e02daa1ad9d39886ca2eaae7d7fb4036c073645484faa547fee871caafbca590e02daa1ad9d398869b51723515e2668d2a07d20f96ad7c3850605558cbb12578f7c2226379cba05de9b5aac13c1813b15b225ccddbf13f708ff8d380928e26d9b282b03ebfa89df6e9b5aac13c1813b15b225ccddbf13f708ff8d380928e26d9b282b03ebfa89df62171948fe49154ac877c3772a94911915772489e6cf6a8c87ac8c577e1086f025e746bae97e78f469dd2b1849e0ff7398e763f14c27364a61e479dda86b3f8dc5e746bae97e78f469dd2b1849e0ff7398e763f14c27364a61e479dda86b3f8dc8547b930f55e581fb6d5a928ebfc95188ec604d0a744e9244b9df3cbca123bea9e8ab42dbebdad0206a97578e9c686462c3231b695dc903ed338235641dff5e49e8ab42dbebdad0206a97578e9c686462c3231b695dc903ed338235641dff5e49d41de43d234008b37d0d8b6c3d4dc53dc3e01022978e03ac0b75f03ece44e627d27a46fc23f73765a8bc80d4e45112464b2d71af8b587404cb0efced8bd27857d27a46fc23f73765a8bc80d4e45112464b2d71af8b587404cb0efced8bd278542039700292f6bb4546d562f4aadebcb0d917592ce38982dff383208a066245eb56ebd652c17fc9fff39c8ad64920e37da4d1d378c85591eca08774b803b198db56ebd652c17fc9fff39c8ad64920e37da4d1d378c85591eca08774b803b198d4d81524649d6bca973ebcac2c1f74cc3ddf0d09cb5fb707917d3d0cf11f431b262208fd4c2884c5abbafd02b8b1cc7048a2a5fbd09720fd10b6105413559427862208fd4c2884c5abbafd02b8b1cc7048a2a5fbd09720fd10b6105413559427886a00e8d2bb897b64e1b453b909427d24487805b88e7ba399dbe284d0eef1a719815c5204881cb06d0301085e400dc60df386c77d5163dc49d976ea071b2ea979815c5204881cb06d0301085e400dc60df386c77d5163dc49d976ea071b2ea97306b15ac4fe0865656d07507ef4b1e578bc25a5219352520074bfd9f4e6f7068683c1c70b749f7a54121f8f50671fcd3caf9e357fdb5e74e69133e7f337c8d2d683c1c70b749f7a54121f8f50671fcd3caf9e357fdb5e74e69133e7f337c8d2d9e87791e33ecc2366bf30169e93b2ee9e9fd6e51d8177921817239474cc87273f10a8d4c624ddd680e4d4afb04fb74bbe7bf05cffa34120689f496ef0baf868cf10a8d4c624ddd680e4d4afb04fb74bbe7bf05cffa34120689f496ef0baf868c3126f869b17c8eb202835bfd352af441031f435af6dd10e85245345fcad0ae1115a363ffeb19848f128d7cc579ae40fc34eba659bf9e388138b921d6d1c2688e15a363ffeb19848f128d7cc579ae40fc34eba659bf9e388138b921d6d1c2688e95ca94d292371c52940bd2f92e93b88313d246c112fb1d6578f0dfaf2bb9538ce8a8cf4ac5588e9eb77143162fc65af4c89d71f742eb16e540d809cdff7bbbf3e8a8cf4ac5588e9eb77143162fc65af4c89d71f742eb16e540d809cdff7bbbf311678b14f20d1a5e748644898f7cfad96c1e3e9cd18aa18ca359ca9bb6add7f82ee2d0bd53dd6a490e98a0a9cf34fa03f500fccda1df60eb9827dcb28f3221e32ee2d0bd53dd6a490e98a0a9cf34fa03f500fccda1df60eb9827dcb28f3221e310adf10c3f98dbd0cb26e9508c7ada5abc17ee9b2a096b3b370493b68e18471bbdf4d5dfb2c2d9df38f9e1a8f8e4417326d14e116f300a51e7d96916fad5c4f3bdf4d5dfb2c2d9df38f9e1a8f8e4417326d14e116f300a51e7d96916fad5c4f3d81ac6c1bca4dd5bd8e2ccd0636101bd931a7fc0183d6957f386928fe4d72d79661c2d4b655f8416d8866fa0bd381a29530784f221377cb1e2a5b7fd186da990661c2d4b655f8416d8866fa0bd381a29530784f221377cb1e2a5b7fd186da99060bf3c20ba3878160ffcb86525c1202a732aa6eb643a607e1410accba299d91028c7b42eca32e4988acddcfc0cc19194a8ea31f873013ef5fa6b281638236cf228c7b42eca32e4988acddcfc0cc19194a8ea31f873013ef5fa6b281638236cf22ea8e4548b3bb9be48e60c266126fd21ad1575732a5961e69ca49d43b1ce18406468dd4fb807ef4c87101679fc4994eb90e9b0f6a354ede967ef50f8adc8bff379db7ab8fa468a0313fee64a80abc0879d56bbd3e29d19a4295f3ba33b306d920ad2818f69d1e749b8657140a273b10dcca65bc2648f403dc71b7b10c2dba496fe9fa02c4477cbebf55e94e21efc2ff700ed47a39908c2f2f51566adfa22dd91fe9fa02c4477cbebf55e94e21efc2ff700ed47a39908c2f2f51566adfa22dd919fb09b2171f71771f00ec5c869a1c9182f91b123d4b8b646d4c25e6f516a06ffa67b376db9597b51fcc5669ec398870be0b51eaf38c2f718f3a4694b142a1948a67b376db9597b51fcc5669ec398870be0b51eaf38c2f718f3a4694b142a194847ee3051bfd4329dd687fb569fc9c80495d6551ecea346518609b5c043c232316c5665474fc4e0bc4b4da601b72a40e0d8e8b44c76c6a35017ae208f52dc8d796c5665474fc4e0bc4b4da601b72a40e0d8e8b44c76c6a35017ae208f52dc8d79098f1ddd38d0db03e8b47a50a6467e9325640305bde72e93170d0937d2a96c53bf654f7940c85969bc57cd7311f92ada5b48c2fb67baba7f01bdede85df267c1bf654f7940c85969bc57cd7311f92ada5b48c2fb67baba7f01bdede85df267c12d6200e9254cc5ce279c0b528afb3cad3a701ba172de9a527c744388919d254cef9559dbed84b7076fbbeb26eee312da62fd518c497bb81c8639b15cadace4c5ef9559dbed84b7076fbbeb26eee312da62fd518c497bb81c8639b15cadace4c553de1c387238d819608aa4570e5b0fa2a51ae42fd6c3fbaebb6363afddddd5f0fc4f4669b6e2ff132c786ffff20e63344ea3877e787256ef000392f4f30399cafc4f4669b6e2ff132c786ffff20e63344ea3877e787256ef000392f4f30399ca056ae6dc3283a006b6f3513b53f9f3cfcbf8e0e9808979a523270572c7a1c1f1624349f768872c02d2f5b87eed40dc9c9064ed4dac22f972a78fdebd54ed8270624349f768872c02d2f5b87eed40dc9c9064ed4dac22f972a78fdebd54ed8270ebf1272a5fb346cd32097b87c5086cd931241daa6b5b16677c91ab423b39448889170a62b9c410be56eaba02ab88dde60ffe46c91bf28bc6088cf79cd7d4fe2989170a62b9c410be56eaba02ab88dde60ffe46c91bf28bc6088cf79cd7d4fe2928bdc0e1b8e9a9aab29d061df617cf564bece6f615a9fd49569b9c117eff75d35a88c6845e55e9e064c942381dcc7fc62f237dcb9157cac431ec08c00328ee6e5a88c6845e55e9e064c942381dcc7fc62f237dcb9157cac431ec08c00328ee6eef5817d5b25e3fd4d06be1db48fcde514270558efc00b61036fbaeb249d43b85cf0295d2108c1e87be022ee458140ab8cf337e7ab7824f9414b2fb07e1d95de6cf0295d2108c1e87be022ee458140ab8cf337e7ab7824f9414b2fb07e1d95de65f31987aa84c4aefa5782fabc80a44e4d21730cb216e5a3a72f1502b85a43e16939e52b71381ff0043bfbafb7cadbb47b1a9d2c2e4c1f44438595e6ef53df2111838b736f5f4bb254816da5e9d85b420fcfedcb5ffc4235d1af85b3aede248aa174d5930769e7e0b2f31e4ad8454046b5833feaef9e772cc6bf22a3aaf2d0fbcf6708bf38d28c4ce6e656067a11072f8512d85c2cb5e6374f4164e5a33e26ba2f6708bf38d28c4ce6e656067a11072f8512d85c2cb5e6374f4164e5a33e26ba21e59c340c0a93aa66efc045ccac93ace350dba530f3fb9ee433e7b2fc6d6f873e5798fd78d6f01c1b57a2284acef5385160e9b9249be3903762240ef7b40dd07e5798fd78d6f01c1b57a2284acef5385160e9b9249be3903762240ef7b40dd07789f65ac84ddc8c9f85ecadc55dad3685548fd147b997fd5ccc67289a1296e9bf23599db47f786475c43830800e7c208bc2d1e3ac5149ce0d864b06ee60e1ad4f23599db47f786475c43830800e7c208bc2d1e3ac5149ce0d864b06ee60e1ad4b7c86a391a013bd0f7f2a16e6781bd512c626bf9d0b902b6ae1d77d2c1f937df2297ceab25be28b42597ff06aa1ab68c7db6f5aad8e8878a8666287942ba61e12297ceab25be28b42597ff06aa1ab68c7db6f5aad8e8878a8666287942ba61e1730708d587b3d4af4e11d1b4c2e9035867d2fdbeb1376d5e1cec8f682aa3ac66598917160bc6d8ac0f20b5959bac6e14c9d369768698a26397fcbace2f8fed0d598917160bc6d8ac0f20b5959bac6e14c9d369768698a26397fcbace2f8fed0d2383e2a1b95b1317dcc7a0d52ff762743660da0da2bde15bf774f36e5999d0b0dcaec07e3d94e4f3988738197b6fadd951a5fe6108c5b5163d888ff1d11df9fcdcaec07e3d94e4f3988738197b6fadd951a5fe6108c5b5163d888ff1d11df9fc603ccb4fda9bfb370315ad794200382b2cc0cdd204ef522327f4af5ad95a652a6ab97ee19da4ee1f803a55b80a7e2c9004783dd9c7675f6b3cd4063c4ddacf2a6ab97ee19da4ee1f803a55b80a7e2c9004783dd9c7675f6b3cd4063c4ddacf2a88dd532ed0ae2358fe59e6ef2de40cff29e2f94bbdd2760e82518901708261aa0083193bf45ffbab583427c3ca9a98fe8fa2bfcff1c531452becaaa8650c443d0083193bf45ffbab583427c3ca9a98fe8fa2bfcff1c531452becaaa8650c443d32829394feb23a69cb0bf2976ab1d540fd2c22d064d7576d67b2f3574561341d107234b214d7154440ed264b5dbd93ebe5eaa37d701844981b351a12d6400465742a857005c7fa4b6ef4d5d4a1fd32726732140e9b086e95ba43a53b749649a0e1a46fc7b43aa9b1df999a14c49ff2df5e040567f85767b841b96fbcd96a7d1535452b557fab0efb1e80d7edb9c4e5118b9384082adaa051dde342102cb9de8daac73b3148f6d1d7111dbca32099f68d26c644c6813ae1e4f05f6579aa2663fe602c4c7482de6479dd2e9793cda275e5e63d773dacd1eca689232ab7008fb4fbrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpython-cryptography-2.9.2-150200.13.1.src.rpmpython-cryptographypython2-cryptographypython2-cryptography(ppc-64)@@@@@@@@@@@@@       libc.so.6()(64bit)libc.so.6(GLIBC_2.17)(64bit)libcrypto.so.1.1()(64bit)libcrypto.so.1.1(OPENSSL_1_1_0)(64bit)libcrypto.so.1.1(OPENSSL_1_1_0j)(64bit)libcrypto.so.1.1(OPENSSL_1_1_1)(64bit)libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.17)(64bit)libpython2.7.so.1.0()(64bit)libssl.so.1.1()(64bit)libssl.so.1.1(OPENSSL_1_1_0)(64bit)libssl.so.1.1(OPENSSL_1_1_1)(64bit)python(abi)python2python2-asn1cryptopython2-cffipython2-enum34python2-ipaddresspython2-packagingpython2-pyasn1python2-setuptoolspython2-sixrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)2.70.21.01.13.20.1.811.31.4.13.0.4-14.6.0-14.0.4-14.0-15.2-14.14.1`E`Ȗ@`6?_S_^@]W]@\ \t@\w@\J@\-@\ @\ @[h@[{[O+[ZZ@Z` . * Correctly allow passing a SubjectKeyIdentifier to :meth:`~cryptography.x509.AuthorityKeyIdentifier.from_issuer_subject_key_identifier` and deprecate passing an Extension object.- Simplify the test execution to be more understandable- update to 2.6.1: * BACKWARDS INCOMPATIBLE: Removedcryptography.hazmat.primitives.asymmetric.utils.encode_rfc6979_signature andcryptography.hazmat.primitives.asymmetric.utils.decode_rfc6979_signature, which had been deprecated for nearly 4 years. Use encode_dss_signature() and decode_dss_signature()instead. * BACKWARDS INCOMPATIBLE: Removed cryptography.x509.Certificate.serial, which had been deprecated for nearly 3 years. Use serial_number instead. * Updated Windows, macOS, and manylinux1 wheels to be compiled with OpenSSL 1.1.1b. * Added support for Ed448 signing when using OpenSSL 1.1.1b or newer. * Added support for Ed25519 signing when using OpenSSL 1.1.1b or newer. * load_ssh_public_key() can now load ed25519 public keys. * Add support for easily mapping an object identifier to its elliptic curve class viaget_curve_for_oid(). * Add support for OpenSSL when compiled with the no-engine (OPENSSL_NO_ENGINE) flag.- Dependency on python-idna changed to "Recommends" aligned with change in upstream source (see below) - update to 2.5: * BACKWARDS INCOMPATIBLE: U-label strings were deprecated in version 2.1, but this version removes the default idna dependency as well. If you still need this deprecated path please install cryptography with the idna extra: pip install cryptography[idna]. * BACKWARDS INCOMPATIBLE: The minimum supported PyPy version is now 5.4. * Numerous classes and functions have been updated to allow bytes-like types for keying material and passwords, including symmetric algorithms, AEAD ciphers, KDFs, loading asymmetric keys, and one time password classes. * Updated Windows, macOS, and manylinux1 wheels to be compiled with OpenSSL 1.1.1a. * Added support for SHA512_224 and SHA512_256 when using OpenSSL 1.1.1. * Added support for SHA3_224, SHA3_256, SHA3_384, and SHA3_512 when using OpenSSL 1.1.1. * Added support for X448 key exchange when using OpenSSL 1.1.1. * Added support for SHAKE128 and SHAKE256 when using OpenSSL 1.1.1. * Added initial support for parsing PKCS12 files with load_key_and_certificates(). * Added support for IssuingDistributionPoint. * Added rfc4514_string() method to x509.Name, x509.RelativeDistinguishedName, and x509.NameAttribute to format the name or component an RFC 4514 Distinguished Name string. * Added from_encoded_point(), which immediately checks if the point is on the curve and supports compressed points. Deprecated the previous method from_encoded_point(). * Added signature_hash_algorithm to OCSPResponse. * Updated X25519 key exchange support to allow additional serialization methods. Calling public_bytes() with no arguments has been deprecated. * Added support for encoding compressed and uncompressed points via public_bytes(). Deprecated the previous method encode_point().- Update to version 2.4.2: * Updated Windows, macOS, and manylinux1 wheels to be compiled with OpenSSL 1.1.0j.- Update to 2.4.1: * Dropped support for LibreSSL 2.4.x. * Deprecated OpenSSL 1.0.1 support. OpenSSL 1.0.1 is no longer supported by the OpenSSL project. At this time there is no time table for dropping support, however we strongly encourage all users to upgrade or install cryptography from a wheel. * Added initial :doc:`OCSP ` support. * Added support for cryptography.x509.PrecertPoison.- Fix fdupes call- bsc#1101820 CVE-2018-10903 GCM tag forgery via truncated tag in finalize_with_tag API * add disallow_implicit_tag_truncation.patch from https://github.com/pyca/cryptography/commit/688e0f673bfb.patch- Update to 2.3.1: * updated tests for upstream wycheproof changes * many other tiny test tweaks- update to 2.3: * SECURITY ISSUE: finalize_with_tag() allowed tag truncation by default which can allow tag forgery in some cases. The method now enforces the min_tag_length provided to the GCM constructor. * Added support for Python 3.7. * Added extract_timestamp() to get the authenticated timestamp of a Fernet token. * Support for Python 2.7.x without hmac.compare_digest has been deprecated. We will require Python 2.7.7 or higher (or 2.7.6 on Ubuntu) in the next cryptography release. * Fixed multiple issues preventing cryptography from compiling against LibreSSL 2.7.x. * Added get_revoked_certificate_by_serial_number for quick serial number searches in CRLs. * The RelativeDistinguishedName class now preserves the order of attributes. Duplicate attributes now raise an error instead of silently discarding duplicates. * aes_key_unwrap() and aes_key_unwrap_with_padding() now raise InvalidUnwrap if the wrapped key is an invalid length, instead of ValueError.- update to 2.2.2 * fix build on some systems with openssl 1.1.0h- Cleanup with spec-cleaner - Use %setup to unpack all archives do not rely on tar calls- Update to upstream release 2.2.1: * Reverted a change to GeneralNames which prohibited having zero elements, due to breakages. * Fixed a bug in :func:`~cryptography.hazmat.primitives.keywrap.aes_key_unwrap_with_padding` that caused it to raise InvalidUnwrap when key length modulo 8 was zero. * BACKWARDS INCOMPATIBLE: Support for Python 2.6 has been dropped. * Resolved a bug in HKDF that incorrectly constrained output size. * Added :class:`~cryptography.hazmat.primitives.asymmetric.ec.BrainpoolP256R1`, :class:`~cryptography.hazmat.primitives.asymmetric.ec.BrainpoolP384R1`, and :class:`~cryptography.hazmat.primitives.asymmetric.ec.BrainpoolP512R1` to support inter-operating with systems like German smart meters. * Added token rotation support to :doc:`Fernet ` with :meth:`~cryptography.fernet.MultiFernet.rotate`. * Fixed a memory leak in :func:`~cryptography.hazmat.primitives.asymmetric.ec.derive_private_key`. * Added support for AES key wrapping with padding via :func:`~cryptography.hazmat.primitives.keywrap.aes_key_wrap_with_padding` and :func:`~cryptography.hazmat.primitives.keywrap.aes_key_unwrap_with_padding` . * Allow loading DSA keys with 224 bit q.- fix deps for hypothesis, pytest- Fix previous change and explicitly require python2 instead of python because python itself is also provided by python3. This fixes: ImportError: No module named _ssl when using python-cryptography in a python2 build environment- Fix the previous change to not pull in py2 on py3 enviroment- fix requires on python ssl once more after the last change- Add proper conditional for the python2, the ifpython works only for the requires/etc- add missing dependency on python ssl- update to version 2.1.4: * Added X509_up_ref for an upcoming pyOpenSSL release.- update to version 2.1.3: * Updated Windows, macOS, and manylinux1 wheels to be compiled with OpenSSL 1.1.0g.- update to version 2.1.2: * Corrected a bug with the manylinux1 wheels where OpenSSL’s stack was marked executable.- fix BuildRequires conditions for python3- update to 2.1.1- Fix cffi version requirement.- Disable memleak tests to fix build with OpenSSL 1.1 (bsc#1055478) * add skip_openssl_memleak_test.patch- update to 2.0.3- update to 2.0.2- update to 2.0- update to 1.9- add python-packaging to requirements explicitly instead of relying on setuptools to pull it in- Switch to singlespec approach- update to 1.8.1 - Adust Requires and BuildRequires- update to 1.7.2- update to 1.7.1 which contains regression fix for 1.7- update to 1.7 * support for OpenSSL 1.0.0 has been removed. * Added support for Diffie-Hellman key exchange * The OS random engine for OpenSSL has been rewritten- update to 1.6- update to 1.5.3 - python-cryptography-enable-gost.patch is obsolete- python-cryptography-enable-gost.patch: temporary patch to run tests against 1.0.2i, GOST cert extraction now works.- Introduce requirement setuptools >= 11.3 to follow egg-info/requires.txt content- fix download urls- update to upstream release 1.3.4 * Added new OpenSSL functions to the bindings to support an upcoming ``pyOpenSSL`` release.- correct source urls- update to upstream release 1.3.2 * Updated Windows and OS X wheels to be compiled against OpenSSL 1.0.2h. * Fixed an issue preventing ``cryptography`` from compiling against LibreSSL 2.3.x.- removed obsolete cryptography-new-bio-new-type.patch - update to upstream release 1.3.1 * Fixed a bug that caused an AttributeError when using mock to patch some cryptography modules. * Added support for padding ANSI X.923 with ANSIX923. * Deprecated support for OpenSSL 0.9.8. Support will be removed in cryptography 1.4. * Added support for the PolicyConstraints X.509 extension including both parsing and generation using CertificateBuilder and CertificateSigningRequestBuilder. * Added is_signature_valid to CertificateSigningRequest. * Fixed an intermittent AssertionError when performing an RSA decryption on an invalid ciphertext, ValueError is now correctly raised in all cases. * Added from_issuer_subject_key_identifier().- fix license- Add pkg-config BuildRequires: in order for the last introduced condition to apply the patch to work, pkg-config has to be present.- cryptography-new-bio-new-type.patch: openssl 1.0.2g changed the type of BIO_new_mem_buf() (added a const).- update to upstream release 1.2.1 1.2.1 - 2016-01-08 * Reverts a change to an OpenSSL EVP_PKEY object that caused errors with pyOpenSSL. 1.2 - 2016-01-08 * BACKWARDS INCOMPATIBLE: RevokedCertificate extensions now uses extension classes rather than returning raw values inside the Extension value. The new classes are: o CertificateIssuer o CRLReason o InvalidityDate * Deprecated support for OpenSSL 0.9.8 and 1.0.0. At this time there is no time table for actually dropping support, however we strongly encourage all users to upgrade, as those versions no longer receive support from the OpenSSL project. * The Certificate class now has signature and tbs_certificate_bytes attributes. * The CertificateSigningRequest class now has signature and tbs_certrequest_bytes attributes. * The CertificateRevocationList class now has signature and tbs_certlist_bytes attributes. * NameConstraints are now supported in the CertificateBuilder and CertificateSigningRequestBuilder. * Support serialization of certificate revocation lists using the public_bytes() method of CertificateRevocationList. * Add support for parsing CertificateRevocationList extensions () in the OpenSSL backend. The following extensions are currently supported: o AuthorityInformationAccess o AuthorityKeyIdentifier o CRLNumber o IssuerAlternativeName * Added CertificateRevocationListBuilder and RevokedCertificateBuilder to allow creation of CRLs. * Unrecognized non-critical X.509 extensions are now parsed into an UnrecognizedExtension object.- update to 1.1.2: * Fixed a SIGBUS crash with the OS X wheels caused by redefinition of a method. * Fixed a runtime error ``undefined symbol EC_GFp_nistp224_method`` that occurred with some OpenSSL installations. * Updated Windows and OS X wheels to be compiled against OpenSSL 1.0.2e.- update to 1.1.1: * Fixed several small bugs related to compiling the OpenSSL bindings with unusual OpenSSL configurations. * Resolved an issue where, depending on the method of installation and which Python interpreter they were using, users on El Capitan (OS X 10.11) may have seen an ``InternalError`` on import.- fix build for sle11 (disable testsuite as it depends on python-hypothesis which is not available for sle11 anymore)- update to 1.1: * Added support for Elliptic Curve Diffie-Hellman with :class:`~cryptography.hazmat.primitives.asymmetric.ec.ECDH`. * Added :class:`~cryptography.hazmat.primitives.kdf.x963kdf.X963KDF`. * Added support for parsing certificate revocation lists (CRLs) using :func:`~cryptography.x509.load_pem_x509_crl` and :func:`~cryptography.x509.load_der_x509_crl`. * Add support for AES key wrapping with :func:`~cryptography.hazmat.primitives.keywrap.aes_key_wrap` and :func:`~cryptography.hazmat.primitives.keywrap.aes_key_unwrap`. * Added a ``__hash__`` method to :class:`~cryptography.x509.Name`. * Add support for encoding and decoding elliptic curve points to a byte string form using :meth:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicNumbers.encode_point` and :meth:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicNumbers.from_encoded_point`. * Added :meth:`~cryptography.x509.Extensions.get_extension_for_class`. * :class:`~cryptography.x509.CertificatePolicies` are now supported in the :class:`~cryptography.x509.CertificateBuilder`. * ``countryName`` is now encoded as a ``PrintableString`` when creating subject and issuer distinguished names with the Certificate and CSR builder classes. * **SECURITY ISSUE**: The OpenSSL backend prior to 1.0.2 made extensive use of assertions to check response codes where our tests could not trigger a failure. However, when Python is run with ``-O`` these asserts are optimized away. If a user ran Python with this flag and got an invalid response code this could result in undefined behavior or worse. Accordingly, all response checks from the OpenSSL backend have been converted from ``assert`` to a true function call. Credit **Emilia Käsper (Google Security Team)** for the report. * We now ship OS X wheels that statically link OpenSSL by default. When installing a wheel on OS X 10.10+ (and using a Python compiled against the 10.10 SDK) users will no longer need to compile. See :doc:`/installation` for alternate installation methods if required. * Set the default string mask to UTF-8 in the OpenSSL backend to resolve character encoding issues with older versions of OpenSSL. * Several new OpenSSL bindings have been added to support a future pyOpenSSL release. * Raise an error during install on PyPy < 2.6. 1.0+ requires PyPy 2.6+. - Remove 2293.patch . Applied in a different way upstream. - Add BuildRequires for python-hypothesis and python-pyasn1-modules for running unittests- require the cffi version it was built against to avoid (bsc#948198)- Add 2293.patch for "osrandom engine already registered" (bnc#947679)- Add disable-uneven-sizes-tests.patch (bnc#944204) openssl in SLE12SP1 doesn't allow uneven bit sizes for rsa keys- update to 1.0 (fate#318838): * Switched to the new `cffi`_ ``set_source`` out-of-line API mode for compilation. This results in significantly faster imports and lowered memory consumption. Due to this change we no longer support PyPy releases older than 2.6 nor do we support any released version of PyPy3 (until a version supporting cffi 1.0 comes out). * Fix parsing of OpenSSH public keys that have spaces in comments. * Support serialization of certificate signing requests using the ``public_bytes`` method of :class:`~cryptography.x509.CertificateSigningRequest`. * Support serialization of certificates using the ``public_bytes`` method of :class:`~cryptography.x509.Certificate`. * Add ``get_provisioning_uri`` method to :class:`~cryptography.hazmat.primitives.twofactor.hotp.HOTP` and :class:`~cryptography.hazmat.primitives.twofactor.totp.TOTP` for generating provisioning URIs. * Add :class:`~cryptography.hazmat.primitives.kdf.concatkdf.ConcatKDFHash` and :class:`~cryptography.hazmat.primitives.kdf.concatkdf.ConcatKDFHMAC`. * Raise a ``TypeError`` when passing objects that are not text as the value to :class:`~cryptography.x509.NameAttribute`. * Add support for :class:`~cryptography.x509.OtherName` as a general name type. * Added new X.509 extension support in :class:`~cryptography.x509.Certificate` The following new extensions are now supported: * :class:`~cryptography.x509.OCSPNoCheck` * :class:`~cryptography.x509.InhibitAnyPolicy` * :class:`~cryptography.x509.IssuerAlternativeName` * :class:`~cryptography.x509.NameConstraints` * Extension support was added to :class:`~cryptography.x509.CertificateSigningRequest`. * Add support for creating signed certificates with :class:`~cryptography.x509.CertificateBuilder`. This includes support for the following extensions: * :class:`~cryptography.x509.BasicConstraints` * :class:`~cryptography.x509.SubjectAlternativeName` * :class:`~cryptography.x509.KeyUsage` * :class:`~cryptography.x509.ExtendedKeyUsage` * :class:`~cryptography.x509.SubjectKeyIdentifier` * :class:`~cryptography.x509.AuthorityKeyIdentifier` * :class:`~cryptography.x509.AuthorityInformationAccess` * :class:`~cryptography.x509.CRLDistributionPoints` * :class:`~cryptography.x509.InhibitAnyPolicy` * :class:`~cryptography.x509.IssuerAlternativeName` * :class:`~cryptography.x509.OCSPNoCheck` * Add support for creating certificate signing requests with :class:`~cryptography.x509.CertificateSigningRequestBuilder`. This includes support for the same extensions supported in the ``CertificateBuilder``. * Deprecate ``encode_rfc6979_signature`` and ``decode_rfc6979_signature`` in favor of :func:`~cryptography.hazmat.primitives.asymmetric.utils.encode_dss_signature` and :func:`~cryptography.hazmat.primitives.asymmetric.utils.decode_dss_signature`. - Adjust Requires according to requires.txt- update to 0.9.3: * Updated Windows wheels to be compiled against OpenSSL 1.0.2d. * Updated Windows wheels to be compiled against OpenSSL 1.0.2c. * **SECURITY ISSUE**: Fixed a double free in the OpenSSL backend when using DSA to verify signatures. Note that this only affects PyPy 2.6.0 and (presently unreleased) CFFI versions greater than 1.1.0. * Removed support for Python 3.2. This version of Python is rarely used and caused support headaches. Users affected by this should upgrade to 3.3+. * Deprecated support for Python 2.6. At the time there is no time table for actually dropping support, however we strongly encourage all users to upgrade their Python, as Python 2.6 no longer receives support from the Python core team. * Add support for the :class:`~cryptography.hazmat.primitives.asymmetric.ec.SECP256K1` elliptic curve. * Fixed compilation when using an OpenSSL which was compiled with the ``no-comp`` (``OPENSSL_NO_COMP``) option. * Support :attr:`~cryptography.hazmat.primitives.serialization.Encoding.DER` serialization of public keys using the ``public_bytes`` method of :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPublicKeyWithSerialization`, :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPublicKeyWithSerialization`, and :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicKeyWithSerialization`. * Support :attr:`~cryptography.hazmat.primitives.serialization.Encoding.DER` serialization of private keys using the ``private_bytes`` method of :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPrivateKeyWithSerialization`, :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPrivateKeyWithSerialization`, and :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePrivateKeyWithSerialization`. * Add support for parsing X.509 certificate signing requests (CSRs) with :func:`~cryptography.x509.load_pem_x509_csr` and :func:`~cryptography.x509.load_der_x509_csr`. * Moved ``cryptography.exceptions.InvalidToken`` to :class:`cryptography.hazmat.primitives.twofactor.InvalidToken` and deprecated the old location. This was moved to minimize confusion between this exception and :class:`cryptography.fernet.InvalidToken`. * Added support for X.509 extensions in :class:`~cryptography.x509.Certificate` objects. The following extensions are supported as of this release: * :class:`~cryptography.x509.BasicConstraints` * :class:`~cryptography.x509.AuthorityKeyIdentifier` * :class:`~cryptography.x509.SubjectKeyIdentifier` * :class:`~cryptography.x509.KeyUsage` * :class:`~cryptography.x509.SubjectAlternativeName` * :class:`~cryptography.x509.ExtendedKeyUsage` * :class:`~cryptography.x509.CRLDistributionPoints` * :class:`~cryptography.x509.AuthorityInformationAccess` * :class:`~cryptography.x509.CertificatePolicies` Note that unsupported extensions with the critical flag raise :class:`~cryptography.x509.UnsupportedExtension` while unsupported extensions set to non-critical are silently ignored. Read the :doc:`X.509 documentation` for more information. - add python-pyasn1, python-ipaddress and python-idna as Requires/BuildRequires- Update to 0.8.2: * Fixed a race condition when initializing the OpenSSL or CommonCrypto backends in a multi-threaded scenario.- update to 0.8.1: * Updated Windows wheels to be compiled against OpenSSL 1.0.2a. * func:`~cryptography.hazmat.primitives.serialization.load_ssh_public_key` can now load elliptic curve public keys. * Added :attr:`~cryptography.x509.Certificate.signature_hash_algorithm` support to :class:`~cryptography.x509.Certificate`. * Added :func:`~cryptography.hazmat.primitives.asymmetric.rsa.rsa_recover_prime_factor s` * :class:`~cryptography.hazmat.primitives.kdf.KeyDerivationFunction` was moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.kdf`. * Added support for parsing X.509 names. See the :doc:`X.509 documentation` for more information. * Added :func:`~cryptography.hazmat.primitives.serialization.load_der_private_key` to support loading of DER encoded private keys and :func:`~cryptography.hazmat.primitives.serialization.load_der_public_key` to support loading DER encoded public keys. * Fixed building against LibreSSL, a compile-time substitute for OpenSSL. * FreeBSD 9.2 was removed from the continuous integration system. * Updated Windows wheels to be compiled against OpenSSL 1.0.2. * :func:`~cryptography.hazmat.primitives.serialization.load_pem_public_key` and :func:`~cryptography.hazmat.primitives.serialization.load_der_public_key` now support PKCS1 RSA public keys (in addition to the previous support for SubjectPublicKeyInfo format for RSA, EC, and DSA). * Added :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePrivateKeyWithSerialization` and deprecated :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePrivateKeyWithNumbers`. * Added :meth:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePrivateKeyWithSerialization.private_bytes` to :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePrivateKeyWithSerialization`. * Added :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPrivateKeyWithSerialization` and deprecated :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPrivateKeyWithNumbers`. * Added :meth:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPrivateKeyWithSerialization.private_bytes` to :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPrivateKeyWithSerialization`. * Added :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPrivateKeyWithSerialization` and deprecated :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPrivateKeyWithNumbers`. * Added :meth:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPrivateKeyWithSerialization.private_bytes` to :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPrivateKeyWithSerialization`. * Added :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPublicKeyWithSerialization` and deprecated :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPublicKeyWithNumbers`. * Added :meth:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPublicKeyWithSerialization.public_bytes` to :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPublicKeyWithSerialization`. * Added :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicKeyWithSerialization` and deprecated :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicKeyWithNumbers`. * Added :meth:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicKeyWithSerialization.public_bytes` to :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicKeyWithSerialization`. * Added :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPublicKeyWithSerialization` and deprecated :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPublicKeyWithNumbers`. * Added :meth:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPublicKeyWithSerialization.public_bytes` to :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPublicKeyWithSerialization`. * :class:`~cryptography.hazmat.primitives.hashes.HashAlgorithm` and :class:`~cryptography.hazmat.primitives.hashes.HashContext` were moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.hashes`. * :class:`~cryptography.hazmat.primitives.ciphers.CipherContext`, :class:`~cryptography.hazmat.primitives.ciphers.AEADCipherContext`, :class:`~cryptography.hazmat.primitives.ciphers.AEADEncryptionContext`, :class:`~cryptography.hazmat.primitives.ciphers.CipherAlgorithm`, and :class:`~cryptography.hazmat.primitives.ciphers.BlockCipherAlgorithm` were moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.ciphers`. * :class:`~cryptography.hazmat.primitives.ciphers.modes.Mode`, :class:`~cryptography.hazmat.primitives.ciphers.modes.ModeWithInitializationVector`, :class:`~cryptography.hazmat.primitives.ciphers.modes.ModeWithNonce`, and :class:`~cryptography.hazmat.primitives.ciphers.modes.ModeWithAuthenticationTag` were moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.ciphers.modes`. * :class:`~cryptography.hazmat.primitives.padding.PaddingContext` was moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.padding`. * :class:`~cryptography.hazmat.primitives.asymmetric.padding.AsymmetricPadding` was moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.asymmetric.padding`. * :class:`~cryptography.hazmat.primitives.asymmetric.AsymmetricSignatureContext` and :class:`~cryptography.hazmat.primitives.asymmetric.AsymmetricVerificationContext` were moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.asymmetric`. * :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAParameters`, :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAParametersWithNumbers`, :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPrivateKey`, :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPrivateKeyWithNumbers`, :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPublicKey` and :class:`~cryptography.hazmat.primitives.asymmetric.dsa.DSAPublicKeyWithNumbers` were moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.asymmetric.dsa` * :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurve`, :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurveSignatureAlgorithm`, :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePrivateKey`, :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePrivateKeyWithNumbers`, :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicKey`, and :class:`~cryptography.hazmat.primitives.asymmetric.ec.EllipticCurvePublicKeyWithNumbers` were moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.asymmetric.ec`. * :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPrivateKey`, :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPrivateKeyWithNumbers`, :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPublicKey` and :class:`~cryptography.hazmat.primitives.asymmetric.rsa.RSAPublicKeyWithNumbers` were moved from :mod:`~cryptography.hazmat.primitives.interfaces` to :mod:`~cryptography.hazmat.primitives.asymmetric.rsa`. * Updated Windows wheels to be compiled against OpenSSL 1.0.1l. * ``enum34`` is no longer installed on Python 3.4, where it is included in the standard library. * Added a new function to the OpenSSL bindings to support additional functionality in pyOpenSSL.- update to 0.7.1 * backwards-incompatible change: GCM module doesn't truncate tags by default anymore * removed deprecated arguments to MFG1 constructor * ECC support * added PEM and openssh key loading convenience methods * support for many new ciphers and new features of existing ones see CHANGELOG.rst for details - spec cleanup - reworked %check section - added changelog to docspython-cryptographyibs-power9-12 1665759847  !!#$$&'((*+,-./0113446789::<==?@ABCCEFFHIJKLLNOOQRRTUUWXXZ[[]^^`aacdefghhjklmgooqrrtuuwgyy{|}}     2.9.2-150200.13.12.9.2-150200.13.12.9.2-150200.13.12.9.2-150200.13.1     cryptographycryptography-2.9.2-py2.7.egg-infoPKG-INFOSOURCES.txtdependency_links.txtnot-zip-saferequires.txttop_level.txt__about__.py__about__.pyc__about__.pyo__init__.py__init__.pyc__init__.pyoexceptions.pyexceptions.pycexceptions.pyofernet.pyfernet.pycfernet.pyohazmat__init__.py__init__.pyc__init__.pyo_der.py_der.pyc_der.pyo_oid.py_oid.pyc_oid.pyobackends__init__.py__init__.pyc__init__.pyointerfaces.pyinterfaces.pycinterfaces.pyoopenssl__init__.py__init__.pyc__init__.pyoaead.pyaead.pycaead.pyobackend.pybackend.pycbackend.pyociphers.pyciphers.pycciphers.pyocmac.pycmac.pyccmac.pyodecode_asn1.pydecode_asn1.pycdecode_asn1.pyodh.pydh.pycdh.pyodsa.pydsa.pycdsa.pyoec.pyec.pycec.pyoed25519.pyed25519.pyced25519.pyoed448.pyed448.pyced448.pyoencode_asn1.pyencode_asn1.pycencode_asn1.pyohashes.pyhashes.pychashes.pyohmac.pyhmac.pychmac.pyoocsp.pyocsp.pycocsp.pyopoly1305.pypoly1305.pycpoly1305.pyorsa.pyrsa.pycrsa.pyoutils.pyutils.pycutils.pyox25519.pyx25519.pycx25519.pyox448.pyx448.pycx448.pyox509.pyx509.pycx509.pyobindings__init__.py__init__.pyc__init__.pyo_constant_time.so_openssl.so_padding.soopenssl__init__.py__init__.pyc__init__.pyo_conditional.py_conditional.pyc_conditional.pyobinding.pybinding.pycbinding.pyoprimitives__init__.py__init__.pyc__init__.pyoasymmetric__init__.py__init__.pyc__init__.pyodh.pydh.pycdh.pyodsa.pydsa.pycdsa.pyoec.pyec.pycec.pyoed25519.pyed25519.pyced25519.pyoed448.pyed448.pyced448.pyopadding.pypadding.pycpadding.pyorsa.pyrsa.pycrsa.pyoutils.pyutils.pycutils.pyox25519.pyx25519.pycx25519.pyox448.pyx448.pycx448.pyociphers__init__.py__init__.pyc__init__.pyoaead.pyaead.pycaead.pyoalgorithms.pyalgorithms.pycalgorithms.pyobase.pybase.pycbase.pyomodes.pymodes.pycmodes.pyocmac.pycmac.pyccmac.pyoconstant_time.pyconstant_time.pycconstant_time.pyohashes.pyhashes.pychashes.pyohmac.pyhmac.pychmac.pyokdf__init__.py__init__.pyc__init__.pyoconcatkdf.pyconcatkdf.pycconcatkdf.pyohkdf.pyhkdf.pychkdf.pyokbkdf.pykbkdf.pyckbkdf.pyopbkdf2.pypbkdf2.pycpbkdf2.pyoscrypt.pyscrypt.pycscrypt.pyox963kdf.pyx963kdf.pycx963kdf.pyokeywrap.pykeywrap.pyckeywrap.pyopadding.pypadding.pycpadding.pyopoly1305.pypoly1305.pycpoly1305.pyoserialization__init__.py__init__.pyc__init__.pyobase.pybase.pycbase.pyopkcs12.pypkcs12.pycpkcs12.pyossh.pyssh.pycssh.pyotwofactor__init__.py__init__.pyc__init__.pyohotp.pyhotp.pychotp.pyototp.pytotp.pyctotp.pyoutils.pyutils.pycutils.pyoutils.pyutils.pycutils.pyox509__init__.py__init__.pyc__init__.pyobase.pybase.pycbase.pyocertificate_transparency.pycertificate_transparency.pyccertificate_transparency.pyoextensions.pyextensions.pycextensions.pyogeneral_name.pygeneral_name.pycgeneral_name.pyoname.pyname.pycname.pyoocsp.pyocsp.pycocsp.pyooid.pyoid.pycoid.pyopython2-cryptographyAUTHORS.rstCHANGELOG.rstCONTRIBUTING.rstREADME.rstpython2-cryptographyLICENSELICENSE.APACHELICENSE.BSD/usr/lib64/python2.7/site-packages//usr/lib64/python2.7/site-packages/cryptography-2.9.2-py2.7.egg-info//usr/lib64/python2.7/site-packages/cryptography//usr/lib64/python2.7/site-packages/cryptography/hazmat//usr/lib64/python2.7/site-packages/cryptography/hazmat/backends//usr/lib64/python2.7/site-packages/cryptography/hazmat/backends/openssl//usr/lib64/python2.7/site-packages/cryptography/hazmat/bindings//usr/lib64/python2.7/site-packages/cryptography/hazmat/bindings/openssl//usr/lib64/python2.7/site-packages/cryptography/hazmat/primitives//usr/lib64/python2.7/site-packages/cryptography/hazmat/primitives/asymmetric//usr/lib64/python2.7/site-packages/cryptography/hazmat/primitives/ciphers//usr/lib64/python2.7/site-packages/cryptography/hazmat/primitives/kdf//usr/lib64/python2.7/site-packages/cryptography/hazmat/primitives/serialization//usr/lib64/python2.7/site-packages/cryptography/hazmat/primitives/twofactor//usr/lib64/python2.7/site-packages/cryptography/x509//usr/share/doc/packages//usr/share/doc/packages/python2-cryptography//usr/share/licenses//usr/share/licenses/python2-cryptography/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:26408/SUSE_SLE-15-SP2_Update/36108ee61e5682e7085405a59332f549-python-cryptography.SUSE_SLE-15-SP2_Updatedrpmxz5ppc64le-suse-linuxdirectoryASCII textPython script, ASCII text executablepython 2.7 byte-compiledELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=86c19bdf1510532a8692cd34250fb4c13fc2bf4f, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=2d005436ab0c733fd022cd7f990da37bc962d107, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=0e98ed5540634c0de9bf1b22a44a7825dd464c90, strippedUTF-8 Unicode text  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]botuvwxyz{|}~     R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R RRRRR RRR R RRRR RRRRR RRRRR R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R EWTވpython2-idna2.1 utf-8f1f143f32f433598ee782ff5c7fa774f934c50cdef7472accb18f7c65746462c?7zXZ !t/vn]"k%Ӆ) Htw<,J$Lլͤ0$pXMUBsͲ:<<@?%!Sp+c\fzaZ,'/ `0aߥj8r9Zu. 엤yFX]ECآrKNCP;KXfq,0AE\%P8 RmEu=LQ2_\s[Ӎ GW!]T - 9@5 &8b2U"kIj3\|utN vH},DK/&djOIJˏH餔ᓠ[rѭ}`uqz5" 0U}c*#Us4.f<F'9p.M)9`jԪˉ<0($} P^[?Wxnos"T+*ˌ&BǟǮ1m,Ò/S( a0#sƍȋ︝_ YʰMCoUO GNv6+>_.2!/U"YZ*B 0_ҏӝLJlbt]S9}2bcNH\p.;LMZZ-0ħţW&"xUURD*mky0Fxh \.% do6lR*kQ~"Yk31JkwF*@#fQ8,0ON_@ݐ~B *A|Q?kFetiʅS`ageeU7;; .o#luM[jکϒ宮D.ݎh/;=.Ner_Zqjج ( 'haBh>*|p\ǰ0Y ks ;TuIpUC%1d`y uQ^n3T޾4nt]O^.nK5Ɩ0={@~j*eFR~mQ$Bڙs!b7VjI‚*$.]9vH{|V@+|w{\@XU1O+dWwp`Jq ϱ#`a0cXCzσ 2NOǽuO.&]|te{D'3se)g&In5G@0Kʥ}]3Z uw쫞Z&vFhf;tbQC_vS/]wcow-LURtd_a`T-d7Zj[3C/hqܧd/"NSǿdWA~i =ŊQR#\>.rk@vu\; @9̰cvA^UO1hhA+W">Yy=ã($h v]km][ֵNIn2I`^F#Qz )6q5>9N"Klkq0RU7ܻ@-ZS_o]FCh2@8_xe櫆_;X'؅:Ղh|^*ere.ܾxъ!3w1(Q~ˆ?RDF6#hhTGh51|tuΘP^ѩZlh\~rptq*'Y;!&P$U\Mqݝ' ۗ"FwUd'21D 슌YhCd$^Ƹb%Ձ+'ݭZkLeĵ,Cdŝ"rN 6iUـpjB8K˂>HAٹ+aYp$7/( tlK٪.(UȖ dr&#%V~74 Aeo[!!|lo4YO-eY̸`71l#H0cu'Qa<QE =}BS(`CC۷Tw"4V*3qGyb8A;m!hLU:dQ6o@62{Y/|f4<#؂! G8f o$Z}xg+:cMXCBmWQҙʠM:0b?$PIC;O8Ǔw뜉rn$ISh?r!?y%eDu u9[~hGMCO8ߨAtMLERQ&M-ZLl_P`_{znH3A k'ua Ŵ# T[ Jg+YQs]/IϤRxT^9> dA>Q>z4'YVDpzfz2(Ósapgpܺ>NGlVj5ݗq`װ2WRM‰!dWP+䌃v:HLf@ _CMm A#"zٽpf: ړҖ,=P|90*oBТB<P4$tS3. X, z`8EIlk)[חzݵQ>xA`D.> T 21oS|w DGjYG0;1^,\)䦠^ّg!)HNn\FZK䶐%'< i⯑?d3_ItN_)Wus"3;DVl~QZ:"]P2Ff#Ac=mMيZ p`9F(.~f;0,GB`[v%;8d yCw]m Psm){hƷ G(j^`آrouǺTڐM̞r(g+T?U1c;d9sJi2]$*>w 3f"1 &!Si|s[37ZubiFƈ%B,@Y >=k=4Gj8HR+g8l{$c w o!1NV&d?h\";hSOH,-Jp+`k,RMu;έPm < +jMK(I݄L-Zmj+:L7b8PxsV֪LkgK1>*Sz }OU͢ EK/IŢǦG+miKhlI W CGCo0hS:S"A`nhΝ -d,6Ƴ}pk}xqt2,WdT3~fJǯl[*K3 O[yDy;ƌ\Ep}2VIIZ\MIt3!IPzɯk=ʏۊ3q{˩3lU|peF7lcEY8q!ϰp*u]foO;x+ǁ|zוX8b,ܣ$WMS8cT9UF o68݅ 'mRJpkbNfge2ĥ4l"5[dw,x]vJIe+ MwoVF&zXρb8,Bj𓏴-Ysi9ydAÒNx3Ї5w8ּ=Bw@)f@:,OSɥϠxBX\tNc^~ǀ]HNYkV?q"l+R\PU>t[KW\$տo+\tuJ%($(X#Fj+{E3l䴻%Ȼƶ.C A:8N^wǦ\j C5.~a`eK֋D3ڛș]Y09[ 2Lk~'Qlj:B{JC آu'om8#չ C O$)P Jq+!;4Vnp[1VR s59ˀOR0&>+6`WAukי._Xrx+)& ,xc~B ,Ui9K^EhܶĒz-BMscԇ U7^g'R?4&MybVmќRX'~F3&2FfW$4.,ѷܳXlq٭?5+#l\|:}!F]{1=N̂- JkcEX>- 0f`NyMJ;gɔY tH@O|2T 2)O%ò1C^z#_u:u(( &YG)ֺ~y$ua;'D0#LDn)rhbQARe^?`jCV#ZƱ̬v3&4i@jzom O 3t*.~FU~) h,ܶb5jiDM2W*Liܶ-֞O,-{=h(|lHIΜDqv}>4Wٸ%+vP]Ҡg#N̘kxotZ*!<۹nI]K{QH (QY&r''ԗ@C^0L>1Al{w m=70EI/Tzϧ,NNNWz|ө2jiy~Y! ]M+I'#ݷw+jTbAyLG2Pw&f5DGw=uuajِQ0M^ DΫYK 'unXI҂+n0^-'SE]2 ?D+ kJ[$tzdcעC:#vI$>@'[БT[ήmGT^:u02v#{.x 2 ?ǢܻZx7s-:&ׅ;Eb;CcK7!4yb/J Jj6DApIU\qG Ѧj0fWh0E`Y%5c29y}_7qȵA:/ؤed8l$d-p ohѱUDw|ŇXJ^S#bo6&;bRMY 7g٥kD!WcwYyQ 6S !8aTqB2^Us:@Bę}F< Lr>)_4g }XGZ{C%]#*dhBƦ#0dnZÍPFW1*oC&.dI 1bCTuEM$/ 3x[%h"1`D~1%R?[~ .R(`x1[q 1|SrfMP:] ;ƃ8[h-p<v~ Qaw0BU{ɴPormpE. |b2|Wj[NJQ%EbO̘~_ Cz%{_POUtՑ.C[l ƗXX){gzs Q(P5)U.M.ܲ3 A1ev=K~`|y.#Zʐ_NCGDkQJ Q?phߔ3GWrq5)kL!cۊccT=#2H& *kLU@ft0-=dvGޢ=ЊP+lFnfWCގ#X˔R:.)\psQ7%qO!Jb`gɮ!,x[ס-<%N>P%I&2g',$vA6[ dލTXQ; +|x(ݫdt?Pӌ>Z A69?14>1SnTJD1l1^ Cn1)Si,UӉD+>t8e&o/>MDd߮Enm5m DX=u">}4Xm{P9{FC4HEIX=V1;.Gd+Iy8/^1yךI*N8ټKKյPFz ;(&6qy&\Ha%$jVK45P&]Qf;kjL~eĝЯMh[0xۨXjp`4n,c}rà\YqK6TؼO+v1:drȖ]p@OOѽ/[95C(ń NQ0!xG#VG_5m ZLBI_wH=):Ai1T9~BPU֟+hN@:ଣ@3C: 6we ,|~Ʊw=W"*fHoBJkx<23.ܓ3킧 C.EGov`^}*YZxv@CxVJc6_ʺS3 [F` f L&o|̫(td=P s:tHF5q5 FkNZ[Ֆe2 _n!?Qi|[cQP|5a,d?oWA_lEvC6|Yk+HqH\&牥O/ڽ)؜M <tV%Y64<&_ :w]8Xpf AdT4_!*-S`2ܪq>4w?v {p:JWB==v05j?'*c ;]ҦȌR2a&ᆈl*_ 0eErM9k/ ԝE OXMsēKXɒպ]o{iґ3?>g B·ɟjQlS0 "Hj\WyJ>m$((1>O:@M 5*Hvae"+mႧȸzVΫ(} `v& >`Qf_WPۤr69":G܋Q"Y5#PuQmwW7߿wNlT|4jޙ,c'@zU=H}ŗ/`vKqoǐfGo ufD=wPR)kL;|w,)\iXs՜;I CDu}-*bp4@2ٚj{d[#XrE"Mq1`I,ѮAx@h1#7aj1-+wL L / c~V 샯踔~ե`ƮmTrL쁜6#3T\Ah{@W?0Je]]v7C\cjT]?u1oT7f@D+%"0S%mh%E9YwX{wrT_e&ߔv^.xAħ؁53yoh!~r `W%t#cA0j~4;gf17*:!BJcE:\0Ę&'@x2{0C~s*jؤfZ:Ymlω#XZ4 2]\GpJXyw9c H6bJVas2KF}Gdq>zf2µ\:$"봆i͢[Wb7Ooy a 86Ϟ@X̲)U W+|:k-"=EAB&.CrP6i,CR a&7Ahh)fix7Qcr -D!+sAK}Tsr_"`C%s/[R2pB:(/؄uܳla * tY TXp uWjEeޱI9VY=qQ#x%'RN\|x]=ׄE'Hv.aݨۧ;)>F@Ym*dŐ.ZnD.ĄVgs@_X#Z/ݛ[;32^{go:{qР2f ]u<4]$P݉Kj%LV52׻P5l1wyK̭K'D =30o}/'ІrtyhuI-{ gB4cV֕V.gxbf63^*LX#9"h"j A1olm#ϻUshRKM[3T`o2SU퍻LFUT࿍l2 Ai_d0fupTY݅١R` 03g4t7$o({َ `cxn2h>)0N `%PhKsn{zoT[ AЪCHhaiPY,mGĝOo?{V4'wδHE<_8_̿;4#..s k{\*_d L `R$mv`AM\ o ^l@@'Bg:G yKȁe*Nf GRbGuPݤ[fPdY65Uk+B.VKק)3դL:#4\y(Ԧ֣;-dD~]cljqن>QU=ƀ)c|[~ێ_6<9,m˦n; e 7jj+멎><\[p,&㡴!qf}GFWRGմ 7\Sg1{cmt =Um?^BӣP%Ď,te.ӲoD/A^ p Ϲ- 6+ Cxӛ@/*tf ׵od56fD<&ïc*Ҥl,birX "R׏o/r>\AgV K.!$)ľf+ <*4;1%.о?SME:C\$AVrO}t5G^ ΃ ˯L [ zx~qlkHTaj{){yK< :Q|VmclWN5_S9ƅQN8YܸEaip鏠ƔQ&f-BfXu152mn+(2a=*1%@gҥ8 +:H݄2ԸyuɫR50մ1,i7_M\M Z9\HxkDwm9zKr~6{SL5+ ?3D]pN˛wݷ)<Ύ,ihBNG QA.~(UZN.$1d?8]=2`v@@[fMmdƾC {:c`/@1%+ҟ 0?*qs5DpB AսjoۣF2rx/ ,7vnɗ8Uw8=5DFF䡞htMy[:WZS(ԉ;qmH}Ӆ)%p]=?uE) 5eYYopǩ^GTDDB1h[fH ڷL Ï\%. ו;}c_45Mq3 q`㕮KǧpE_[jf>u7kϿcPHD { D]B<x1sW~;BlNλE8qBVbu. 5NkkÕO IubpkGAȠx|UN^I ft!B≄]c.+adxeDZgʸ2N5u)Vr#cQ[#yCVydd͜o)s~}R?3&L6OˀCnC{15 j6۲$_y׶ed[5x9>htۮyӾ.ҹwIkjzmFt=#Μщ7Hxo|I")8 ɖjjy{;a9/d8_[.#FHo/vv{z]M YaEvj4\Y>keֻ!5TDfoO3j0Jϋ5QA n73:b& L;d&q[8Gt;+MH9nH=!)6-c/aZ_# 3; R,m8UsSi[8#8ϮeT<{2 z1_ZohxBa'/M[StLSᵺJdqK9/ `-#)jbV][@C1ϢMz,@eutXl,5JiOf@dt ONVp ߴJb@e>D,^Li>+5r2+)Atk, {IЃhmջ:wC?f>4ǦGW'2[ @zJ\dٟ"xbhQv (4i5Հ;S'3h5vy"m%9}DDZ` C<'<NņE6[HBwwQuv_.(˻[J];Uo!|+Eq1KS bň^Eݛv5זv{p-qBjXq o HN!u;Hy0 ^͎Q N8JN-OU)vj7V|k$ؽ>+f0JfRwcHvx-,M\l7۹" |S(xb"͵H7І\Tw7 bۑUʅ=6p.%]"+/6υq`<>bm |GInMWJ!Jd>Vb\W^D+)`'!F&60YEk-@UK+2ܩ,0qlB<훺h [p;<,**a NPChUW!Y2E4囹(aw} IU] xQ4j1?TitNyMB>EwIb.)&.>O.˕̳Dr6.jW92(~ ~啢F70.7{cdz4pc51++ad9ovךt~B g;M,]gzn޶\5k1Bgn^O^ժ-BqXR .vE[/bgju1&ۺE];+Yq>)1Qi=<wÃp1,ߋӔTLk]e0,_Gi¾$TV@hby~LFSxPvj%ӦЎ) @Kc ?ӺٻYX|vj/ ?'}UsYSҔ!Gry:=yݙM "Ĩ[Ϡ~7dKB9KpH5 4Fk C;x Ĉ4mvNfA}Q̀^ gV]ce &~/&kq06NBܢP31dBhѬtNzYL~`(ĭ12YZc젠LmEȠJ>Wp;J+h7Mi N E53@!gn  ?WBኬg:ΥzCZx1jԓg.^vvY Y#ژEzZ=XwnnjO@bXn;r; pSM_ٙD'*A'W~  [~Y@[>kDUNW\h߈QnmMM2T$ ^"ފ_uC8nfOjHX(-cmx}(v7廞,kb 02iPe#AFGB#'֬,w;c۷ Cw)"*fpHYuǵ1ec(PyJEj̧L׳>d=gS x TEvS]DrV=~4DT/׉q 'wX ?؅z#yunf%jaC ␮ E&#$|DKZsZ>}LIi[&5|bg_"TY{Q"x7{b8HB$K =GI5 <"7xYauv78Ù\S%c ʵ;՘^3Ⱐ3>a921!"v |*T6~K2 _ž֠ HL.n׏jaNg-;򌺲C4}}ZWhd7GW#HfN AWPz4&o XKĢAmg䃼kY!N17kK8){4n6 Ӌ8P*lEȐ ;$`Eq L*(Ѻ`#yl])穹姯'DI"* \ 3\F5YrEC|X ^Uto׸1E GEEG@fv; t}șƛ[QLRzh"2n $?'RaWxe #2yfLh ^kt\"x^C`_5E2៦iόjE;qVDiً*;%?iR9!,߉8 Ag{QW4/e".2V qumɚOW4z&TtĄ#tZtT*y+=|ՕN_ƮzP#eFZ{XY3DHZCXT]I#qˆvKƇuR#Cq2ae\fצTƦL.6x_ a'{KuJwv1RJ` y=(TjG}M:jKԪ(w@h.mQEL *3]Kq0Csfң nSzeA]CY:LSIfD8oWa-9͝ (h=9J_olO]:1 9{'El@|^h^(Zbɮlujw. c?9Zy!ԛֿ"\{ّ*gV]$\E^~Uj3@ȈER9aTNљ8 -w*4HMmH(133=9ʧu fjXq6X6k)x< 'ٱzS.Hb6Q8 8iDmS~]^M:8ViS\V/S" "dž (; 5v;Sͬ_"Ac{&8>eC aM]gm\gX,LG.fAփKXt*3%oLF°Hn<0eўu%} PEr@nI&UҒxyY9Q/1tŚ:/wε_ݚuMu3]6(D MA4߈p)|mG c }ꑙiC]wm n*6AD`<gb[ l1N -"p页׮Cx!+Pv~=y>~6zSWqTOq=w--.ɕ)XzD >l. 56 Al6C*s#+siR?SSPF<.zG 7C}:)@/\!Z$;)J |4>Z Tazf!*$;;YEtHedS.:unzu}<7;S{.ޤۚ#*5:+99#3G2$dU}*eٝ}G> ZA^8},H65=8g57y(J@9e`ζk{ov]7qt!{4 f[+?9Ř9Վ 211сגII8pZ1u%t؜ڒw49ٶ~RJ^' R'"U0_;k_*p>~0|V6B 8ԦdV z.jb̘n~+<۔'VONO=E=N& F[ӈ'ӫ!{mh`e2ҺHaeP >{<W=yBMOaٯ?PD'i tV`Vtp'aik 32ĄőCtW}<mzQ/nc>}e&4>6,a1 djMI9=/Ot(\"sr+WZ@Hŏ@A׻hYn_H+gN)D.Ml GG2. 2H6 ɠZ/^2=j`1glٱK$]eO/Zu &2K?h2?tUBzX:uRQ7n *!#K stĴC̚g?2 8zCB`!r/|GNl05>Iz9ɜ@Aχi6o]qσӿjWK_PygRħ5]FҾ?`QU+V>3O٭J]/956&z(a#aZ4} Y^Sd/ ϯٚ?Ԍ.7c N+`'{8cNf)33IA c׭%?BXȘFͿBȻc9麼zFcc%7Ǐ~AzEzyk"S?ciVвptx[tjʼ֞v̸:|ۏջLT ##sH8y<@mc DS)cH1CɔվԚM %4|e;A2'gE~xӀSoC^ɷ5)!Ѥln2Q@b;O,N%a$r `O9:|Wͷ벘bԏ<(KWr.pNцC=RS2pcaL!4bfxbe3.< ( O!W9:3-7_b`ikJה !ڂ N [09\6Q~zn\m3.I\{ %3T@GuI8wDWb[[㇓+־rxdV x|rvaXZ+\2-87 ÁrG^ kb?yIR{x6 ACs+3*^9Mp^x>- 8ZFeHJxo2!5 &s.˭y:N@܁w[CfhO֩0u>3dqGF>I 7+πRz '\9[[-D%S.4^!sPo(CDmz$?䶢Ь\q8KH]7\ ]Xۓ\s G4~\2GV\ݓ?a'zJHȻXi|bkh H/gЯmЁ-]Bԍgڋ\S& J3xokӿfWaζ-1DИ7ܟп C,F( q%*  zv>c+$d.V+H@q_M+*ק+IO +Tж6Ĺ@H )wSeR^7ru=tTSY~V? 2a I9̈8ZA$p03Ο#.~&Ie@ HeP*oa Bd(k= rI&UT|6mhR vGf3z jKr*MYgHޟI EϹ ^NT#f6coy mBg KM{%mh\ؖT cw~ja/xrnգ{S'dxS5: "j;JJ?dFyh6(l3E&c}˴[$$ vh%[2&KuLC:drf[ASUhJ1 }@#ڄMREjH&v/6:͍e,Ο{aĴ"r١~4V0GޜGD+Zn=?΂}}qZnk$cɱ>%BXDD,*OP!i@H0EPأ&5Ӹ<[`Xgr(WL(8x2g)©\F̸,ѩH9 tM:0&ѢýKh?!SFQ.~cڳK^ KJV_NךZ"P01Nܺ;v#;,Y2"lNnQv1Γ'Y366Ym1qZ5uim)eRe/O>ZCLmgx/L"g?t.\t#,^b~Gq@Z$QSYM;ʿ_Q睑$6G|%$qĿ5- DZK3jt7FGdq=^.KC,5CD1iT@͡Wzj_!z>$7CB;`k*g;u&5 ;_21 /bGfw WIen_GOC~&E nV4&Ќ V݂ykK8,#E-gp#f^ ]V¾r ]zef0b%Kbt=ʹ#HRXz9Q?|c8oKW[z:uw N$ au7 1Xcu>&NU6LO;CлMrr "e G-JrhņyvbIYt};m1FI,:Cв!(=%J&@hܕcظ 3 h4CQ.et뇓A=qL BEifVו,.V=Y)@ 䭊[;Mm'ahnŐG { Ss9 Ǡ8Cv?fG9$ 6ӐL9P޼AƋZ*Mtr}#]HmYsXRX4bu'S~ B2NQеU|R>%i.ȵ3ͦrVf(ҐZ4Rvv2]ļA}ygn)crYN5G* aWg/55x \hDޠa:'Yu+ p&ya~2L+b3)6|oYd-+Wi+ۏ 5"geGV8ΆlC, &x4Y7yZ40t+ Aף}m0a$%QwFҸٮ[LDJF.t4~T:"IQ+$@7v/R?А'Y"jzb:yqafDV%-f7K=N{P#l䂸{*%6I3SE5h</dgM=w[3 [Bj\-fNfɔk;'Ehk &C-9v=%9pͨ߄,z6K1kmJr4'햖NZpvc;!ٞ%\v~LdYMGA 9U3% 匞~gE6l':7mA]-bmd){e vJ ,W/e %H}K.AciWq(YƟes{Uׂ Ca,u]rZO GX\(^y8qDk Jf3a̎}s܈|Cp/[ѱc g%No^O'3$}-i[E{VhX hAtC~v$P2Rt?fVOr ;S  "[z:©@t4ͮgl䩲@{jK H D[@ھׅ@]RYIݣ\#X:K"eHHT$Cִҙ(xrc|lgJ8`U~7K̥1{DjL~X{ʆ랚 kPwӫ@pǜDzzRw>j}CpԖ4iG]b3v7{bj-PhKE)'"SNEXV7=||Gc$];<v W5=I5c{iWl蓣KoPD6}O-]43E\KM3 &rI.ptWxF)俓tѴaN=bgFjuWM%+?f-`vs#m4$ah$ 9IBsCYUSVHK 0h!}{t$E_EKjg%+LD"c_~P쑬f|tc c#7# ,-#VؐyN4Z60uh웥nQU1ݧo+L =8C ]{pG!RT feB8=L@{'  cݳ7T5DTF]swdޙm8x8X6bb zq#b@Y0u ,RX$2Q}0mm X `3+ytXLڅWr?7cv!WI@eLZGiK}ķTh[:lXeo% z-.ga/8C!ג[qUlW]'ހBtdA4b/S|yȇs 9t I4|X{w@RXv Si7MyĆ;Ý=jK9>J|Blč.ٕlְ:56^u1_et/^RHGJ>crQhˢΎGv25q^}ׇc͎6J$|ж{R=:iyI)ee{>%!rėb&Fr!FU8G.̒=)yAO/fxtVt@^{yk-x-#]24+W ` oj+$rrI&E1Ԁ<ĪW:3`fٷDBm{ Va0ٺ _؁I# (u҄9Z㢽qns_ %V"wA»; pX}zANP*TDݨ{G4<*H(T@B}Xطkd܅:,U>3Vv(&H GdoAI ΁ިm2!Yeg2b 30a@w+HD5N7 £XS̒ g&ΣS+.A J͟}g^KD)<o-2jBl|rī!ވ1r؇盛P)I$2[p 8=}Yţ `d8S[k3mrq҈ Izfцim#2.' C@cgT)Me  s} !߷x<<96wH=A!׋JщOgͽx_aaSn($me1_hURi4¦t&q2⺖XĪ{{fvKp)q躗9 WsxF/(Yf~;hm|)CmpVHW]s 3ڪc.喘>cNܾ"T$#Ә-6X[T鯑|sVI9Ȉ@@Ы8l"m.OD*Dw$&Δ q૎Dꢩ6^Z[Uɸ;->[kiR^ Y2a)ge*JiCkLQ*+B%}#z0x8&GVȢ{--5la"v@*5 $\K]}poVt6pZMU!Kҡ@qQ?d/M YlTVxχOY\5;K 3$>0c"+6_hU Y1 ?A/˅n R-OhG04]]-x ٫V͖йgmmaX]Fy#R@Lᛀs8 cYDtL/W1BUh[HލlT}ϊ\[7Ynn:yEb˝Wu+Gc)FU)nyh=DR'V~ܟq/2Q˖YF|R0jB o7$%$|hH[/T{AokQ;W Ƭ<G۬-NK> 4&sznX{3xM8~9=ѿYjZt[",+[ f=2-HUY^%jH%r:A ö JQ(t=j, gwȐR /[>I2C_]~U!ݜeza mTĔ }'5Z1Cڠ_q[cc:Eh3ߝ[Y)5c~6 &2[ڄNg:AgK.4eaKy+^6m32eY1ɛ+)]\DgbQ@4_ʛj-QEU #ௐCҜ~.&ѱX&Hjgqhc~%e*?<[GM7NlMKm9u@Z kJ=Rt3Û7V: ?ѪpH9KWQ}}«@-UjDfrn$U YU<)JZj7Blq5AbYM pn{JRQu~o8J{11RkL쓧-.ʏkDTR{9aqwnZ y P;xpQzÚFj&-Ѩ"e .ߨ6jUfC^¾. 57:&R]Ѳ:1)gřZTpzUzw| (W})pa\$nؠu~INz]MfwmHric5c}Jkԅ"n)Md`JU|i&xڞp^ ybu[cdϦTḓij #sz M<:d+^$C qk{ab͸dִLuX dx}, jqdKw/yEqZv۬.g ɽ<,@Yx7- C5P>{bJxX0&*3V#xL}#5|D3mhQ`oy=1 %) B"UWģ% ohTZ4SW 2ڼӁ5>*v&e'n,qj/`ßok"X1iԏBX"3hWOn? JH.z)D* p81`СyA~~W#GkY. J/@S3]W8[ rq̇?kZr^d VfJ4*qm"Pv=[OO4/v C)y3_5l"mkHi$}kX&3r?ãUq4H&8ҒLȀ~Mc1O ݾ:IvHI倠? ᫾4kj5G~eBD];ۖ;Qh ibFat~xLMG=sR1YB3Pj|dI\-Huv*;BÝ1/,ZyN}!NoiGE?Xŷn7lM,kԝWCsY+ D!IVM)x6VEQ{Ee1|/6t,%7SGgo)o3dګ(Wd.,ڐy4=1ws -| S0VG&Sl..= MBR.>iM!- [o3 7 :թ#Ns.IA_nL#Kfw,@=  R$2D0XNLmsU~i+ns2zɷyqY=MO|nrr IiFB=fj1|7CnN|JxMnvB5$, "xE81HERrSFm;3a"6U19I g|w+h;qrmir .(vv9PyL _|OWWZqzx` CJaB:Qi^zhw}8htnĐwt&)Q's{F2 ?3z++_ N/hw7aA՝FT⒘wL@8N_HȬ m ?}sMRj[dČ(Cr 졅 öŀ|ݸN[J1TFDgL rEPbEIB}`9 ]QD:Sfh>:m$DZ < [\4Fޭ/S]hQ$Z2i;`GcͰ+-$ - S-whR]׿o0Yxʾͮ Wni"ˏJAՀ/2o7Vյ~Hv3A*_K̦K;?bq MH-}{iSmw(!zڿ#, 7 0D?S2Dj.@{eܔ5;r`\u&p(hHWQ\0k7>,IxM<4-DBíA sA=|1,y?@b]K2 rOk2q|O7ۊ#r]]CnwB#%Yp/3jA!iuePUw yAW<@M?݋U_ҤM\=/tC57Ұ T_P84wqe> WrVQ?'}'5ޤ|ć 3YcIHl_" nXwNOuRP M+O*9SU޻2+FŔϽ]?<--]RTxF>˓rrO-~#$w:oVx)YSZ)IՂ\ 237c‚k2г$eW̨kՅ֒lalꔦ J=k4Ypii9'fӴp[͜bfBt;Znz*:텍PLcY,U:7kgs&`ׂs)վyM҇F| 'x؍:щ0TeTҭ+bʥUy75XdžNpXs6T9#NS-?b[7Pն8^Po>Pp F$?5U:C6u R. w k0'7tTAQOӧTwf}߯@fj(Cr-&qKNv(!ߪ?GA? 'O4=Vjg s`1FK^N`ׂR/Ca5̛ \V /,A&g=D8_W/,x͜YrLqjs}4|I{n: .\J)&U%lΤf=LqK]z5(x:Brb08!F 租n&ZIι𗽳#V~*vQǸ_y}a*!?c;"VKuva#2r$4XǏ ^NĔܲ~IPIS],RyIFބsz0*.l-F .mFٞDw.j-޼Cl( 7J)kc|nnS`gBhI76U~@)=.'+6ɔT<`1T8v%}JLIl;86>(BKXDX.4[9M((;#ԅ<=H`Y=W-KE#tevc9+Oq}#N- " ߖ>Ngk묟LNưJ'RMPq ;.ofm ^}g%]ʤy6꠪T/sgVs2i󥷇Lo Q#v1ۚ  OTܳTd_ͬl ,ۡΙԼ̷a'KK.~ML?a+DA6*EzO<8[SlzVŝnNK$vZ+ʤ:3ś?qgQ'aS,uIrR8>H>̦qAW ?97eV[yv}*}YuRa"4M^z s$r_u (q٬>]9x;_4Y'[:;.<$g uF+SԱ wㄫ߸SaNPW xctXPIDwX:pI[9z?7k:D8 AoTgǔO?ٿڳcT\Kq]AP5R+-g(񽫘bHIDED.7GT Z#yU'S,_ <>j TRh ~oOou/, b6+ \Az!:!"/mEn*tbhuAL2t8~ vuW˅;VErf/ݤ$m+Ʃ~ˊ RScw#ģ Hn|󍴰’meG2Xlٜl;}jNBЄg.!H}6'.n-=%IT8EYK!ի('îdv칤&`RA؀oY .o/@U"Rk}Ձ*v8'ڥ/פV (W\ U AJv""؞͒Y31z@w ִ~ b?~W ab4c :T1כ&dw=`X05TUNQa| ={:-3Rnt~9:r|"~*(*#~PⰇGatKh̓yU<wO*_itxVCCHm/:R_d8E M 4l|쐝Jјy5,a S?dRT-S:-z]ߙ}{"ZRn=8Pg#d]oUp1{#N\||DbqZ|4_Β-2Yɗ:,)>iqiX.W70!&p!8!T*GK<ۧgk!Yr{@F-}Ճ~kC+a8zk>+{ScU䟴OcP;-VUG)"AWuC"vYu{JVBFCQ}Owom`-,LXamCglW7(/{îwU~}}\a,2f^y8hAA  h{k\1cXaBUX4EoFhU0 Yu&Wq]'8˨7.O#Y/;!LB4"5}]%yUP`ݦvGX/[vtJ4M7侔pW.;kMK0%w;0ٷ%:}lUue-:Vfv9H>tGeguX? Kmj@Y6u@/I gb}Q1|;b*Jؿy|Ja_" ()wn]M3vhS.X< ؠO^1G]CxlHqWқxe*ehX[o}6bA-'êƄԡVF"^[L7LcKAa[- ^_('s*@vD3喛 #}<hE@z!qjՍڲQ4CQ+oh6 >"T)MxS̳<".|`>N`SWףHou;g=gU;K ҳxzζkl׷(Xt2k+M1DE_F=$Xo`DSNҞxH*IvkQj;#Ss9Qx=f0nwkQ 1G8J:к}ܴb{+!UB-LfPe(珏E{Tl`RoUYO7x`=^J1'vR-tSSm֊J&wGn>.$n| _cݹ$2-qZ P.Hr:KHvWe U4@ђ[Q]enJ" ':%aݗ̆E%9ԞMdh,Mr,rSYunܰ0o7._J꜓yJY?cFPH;tj2L?j_ Z^z:mEK5)IՖut|Z +)*BT>< r"1No`&:,L98m/?MOGѮq[TU8U@x,VހZ3ΚRXH;4W-N=Li8K虱L5(9G<1]oSPD߶#>Nxɘu*zk-ʩ;rv*E׫oe`2=ht/݇k/N"mwɁ&VFK$0'D6 FAa(OzC/$H$A,n}ѡrR)V.à c;0ikx)#CPB9taRc5]<8'(YxKltl6YLhup|!/ikI^*x=L]fd7+bC^) Ml "'Űr$fҥ3dl 8Em'оy/pt>[rs̜}!*9oa,WJ04Rڐ&\s@ :^N_WO >8Y&d9q CXUAsA籫7Y8H-b#m>U27٘vv8N'Oǯ܌qF5[.Cš`T DFbd`eż6(&в% c_!o[s=FU]1X#6qJ$|!r_{G#-)!t[1F|obkӗQMdE61H`ŢwI ;I'T5=WB`vZ!ˏCg.W\#G38lcv6>~.F3D+ց:CU(bIRgWhen+vΒn`Fbz?KFmJuc؜kwL7vhp}%~Ӧ%p0GhV17_9Z=Cx]}Zs|"R徨M[yNU)תUjX)E%`8VrGU|-ajY;WmYHL4/;[Oƥ+/5Tfaޗ5^} 8 6yK@&(qCQjj Cr/0#=᲏4NDI?A %~iNh.Ff ~ԧ7TaO>¢?̇<]q3j= k>i͊2d&V {z2ztww۪?`gd@wųsM+J n~?q;8OAR|lKW-]J̥ygEy>/uS;r^MӾ$lƠZ'UVhm& OǪx0'Mf\$2V\*j^HK<觇Nbh/ Y\}k Bk!0"zJCjF$`~rE򥥍,eg?iR .6c3lmmĚ:9k 7).HIF#Ay&VC< Bsؐ^`B.Y@|N.;佑6fAv2Et'4PCU_3O[]0`P(w(8;nSP7[H3cKHV\ {G11 Y()uΝ}Rao8%;9-}  %sGq?20IdE4䱉mwXݞ\K,ɦٲ$vۓrRq#fCu> ؀G]U Xr0-K1!~҈z ;/=h!xFCVȪ%;_2AQ g]gwi<͵8Z'`y_nY0G̒N1qyTF`g^$5Jd$m{w2YXYBq*wÓTtq*:ZBCOc!:ia^:pZڜK^صIf Efx(Cށ[` Vv6tT2 ?KDWr-41AD0f ־5ڈƎܬHb:_$ilq ' nMD^k=S"o`[TA;&D/]j1AVl̻`%ZQPdw7 >G/#v%X_4NsFļ]V9& jIr&žbsx9=MysկЀӲ[79fZ5&$ADK ǹD{aA4HF.}b"&)^mvItՇ[r7P[4ֻ^_ix:q/|U $!;VeOe -ݛrc^FgTTUWg|X6S] \ u$aT-] ]q$lJ Ei1b]#w!wV.+38$+p?ѝv7D/i-F ~Z. #Fjh(3mƀS(lGeenu؀% яmeX20 H 1G7NjΟ-$cv!%I?x[Wn4-J@`@ӧɕZsCm_kn@D>)'C3F m'9Vy"wG-Kjw(h ٜ~!`zV5 )YҒ6҇YquфP x9uURe?vN4 Zg SkjzICPoBI3E9D֯'* [OcZ4TԹ:=-&k$̴A#Sb\*ό<V Ys9=pjqp#}}Y22vyl흣}2Sf85iuXwm gx cžgcTj{mm9,#,x[V+dGUp!cSp&<mo56eF5 j]tPiWM*P q~6=l69,(g .P zsoZY0#iSAo!n|5Koqs0ObCx3m2Snyp,*\J77^| xV3ߙFlmm5vݾO@V7 ŅyumcV;Hob n ]bR`e}t#c:)6S/\8yh$U¥W`9^l=[Bpc|:j}RDHr@wzG|V[){clU=#АI}|z[(,|C@j|.U^&A43Q!SJyt1Mm&+yYBnD86x^|nawn}x^\O q(ϨڰsYDb*[(9"ݏL6rSx1J8k:UW]шe*RU_=JMEc떻Wb 'r)vE\RGڻKY#s=DrejF/DVY %DȓuGߓXfF@%ޫ*G~ [#7ݧUxzr]x2}D:L%"@Bz8Z?;;ڱfr4M8 !)"`OWu-^ IȤK(V2,DsT7. H|Kˌ9QȄ$YlЌF:X,H-V%+k3]͙J\I_14_>N^i OhO( O.ą%/I #rV(voU;1ŬDU/"8ԋFR$ bb5m\wś˸PPWl\ճS7-p` Q;ױ%x@SG)oeUe7p`a|(rȩ*F UqW.јEY#9^Gk5Gԣ`\kiI( _co:;Єj@!b;Vy6*#;g/Ǒ4R}I$|T[OlY|)t ^gGB&څѮMhhR 7zPt -Z=1NDMe=N9wfH"4RK ^rq!%Ǐ$!%i.Y3M&-h{ĬQF~'O_5x,Sk !E hP}ob3pOznq Md\'YmTԢBhT:ij@XUoNV7Jc&xu1P+qK͜@;8iwBž/ QPmn߻>D9?CYkx͢$vIznCnnI+ c}cӁ m#Z,- 4|]RRZ0Kd?^KtQܟ`33 ݽ/YT ;Xp$yWDyn/=yZurLuV2r xZ[_ݽIFŀ <H4%fvr-%@g:{rPh\~$Ag0~O7t}\ eĩK߳&.Mn8Ó(@v2HZ[rZ(EMĨ':\үJҫlТ-ΤgSZ;=z;8&~%Wݣ)? t4c`}+ ]-v7&gP'8}d94=r8W*`S]XOڀl| IOTٯ#*YnԔUA-ykE#{DD&.]7AZă{Yܯ3ǫ& vjM.(Wqk+Ac9]T1N*^*_-3G(kp[[kw/ ,)hYq>IS! vv{CRYÑZG-zTt VY!jȌnF ⓞ؈z4h$g}rdN:M,?\,{>(n6d t(>KieD.hDϬ{75An.%3;/Wg'>g#1}t\=vzqӓ=/һ2 #u@N‚=,(![cEi@U=ҟx3Lv_>E`2=mEȄvtAK*[ְچ wqI0!t]fI]ZJsؠ[N$o<ܴ!|?^7"Q8 cBZkp帝jdG;ݦ,B> "V9:k:]mh>cJ<¿0VlRDFu'b|Ww==*x#zCvTt8ԁj_--7@H(ǀ@%lt̥%! ^y{W=5J8- SFYE\5?l-;2Mg筛<#믾G7 ZoX8Dzpy!Ox23E+t_(2<,YLL3֩%[ΘIsߎSCoT0?NؙmL'_]:W,Li,^=/6S@.0{f %u :舡?B>7cJ \P@6 Z*S8oI^֕J`1&vKָ} G@HnJO8xwW䨊5׳X6>}cPTe(ܶD__F}lG1ʹyBz#)mt +χ}!.^,п$/MB )Y< U%Ѥ۶R_\Q'\A8g! ޵ ֿz42ANҌm)gtF,&x&WZM޴[0^ȧ~TVOuAvK `И>堝k,kMEr*C-ɤfE K]=wf| ~$аY"2D%|X0If }jZOUk76ӟH N2l?fW /]"dBgP`~;866avGHKYIf!=>fh"ܟ7Ir,.3:]e^‚>9b ?ޜeֽf6Jʔ]ы?p1aX{:~$}1- b&%ۡoyU`CH6.u>qb=6_zWEw80}F.#8X!h$yE~xB1" Yf A uL8(X+Im\\`z0.8/_+2a3Ew(W`T.o(=0Ȫ2?]ȳ \D7PNn=Qؑ1JZCp,Z5Y]3:GR% "'^na \W4sUK] HAى7VD+7+=;Z& ъ0Γ\rGΠgpJ _U1B EɅ+=)մ\~ycH@ך SK$I`}0-Ns鎉4MDDWk/Jg/GgK#Xm)GVN jJC   ޽sx/TXE+ʹv *qnդ碝6Xm|j]Zq7H9'7jN%͇w"iZF"gWE&cjTb@Rn6R|3X_T=. 'Ay?qy8in, xJSmYw0DtlmXz nJ& ?Ua\+iT> bM6Ӕţ{Ew qTUc]A'y5Yi2| WKmq_2? z~X]V1a\>v7_^f P=Di#KSZ5xBz XJcisS)~R[X%yzUI*ΖM_hN?g&xfӿ%iN/l8̚7 fכmkOGV`{;n7L\7NpL gv-֖ջ&ɼk88Ms)x;D( E%ZzbxJ 5=X Nce?agV֜U 1?XA~S?ߥ+VEja+W'|MF_N˄,=$᭍ f$#h@d[E\y[?j:d^M!geb.XŀIxÎ~})$@ h+qXp5daA䑮c',˝1hm?'vXڣ4@аɟf.M([Vő 6}B04cy>9pC 4L98zM]GV;٘xdF-S`#3Bx|8d]Dg1I۴,DLJ0x:-\6sd @?tSf0|AV>&`mB!H^mUU&NŞ6>[Nu&tZ2Ч֮ 熏%:Gx@CF֊ЙTKpdg&/9,5"$MZ#%r2zT H,˿Wq"ikE+ZIq{E6n{4ܖ%Uji~DVkJGrձ" ;1MOn7 f3[ÐxLa|.cd?C9mFGi R$y_%TI0ă)gfX-d|dK0ǡ";f̬Y@8}|ßM_isߖ*cܙDl=q>)qvb  [ `a\cZpW_r&QeVM訄C h60i5Ij?n~}L䮶Fn%yGZƒ,jn -7&") v3>}Sxf˓DG~NKٛtW@cw<!(X&^mY5׸vHdsʓObn]?RD YXr3cSrRRoJ.$%{Jjĕ|LӉ2WkHa}p2}K:׏DWV|SP!nB q͘/4T.2W7T̙YȘvrLq.;O8r x\D-]U aU&(MvuPgܰqh ,85DBqgcJL!}XaR Zȣ\cCѳ}HԚt)Ai[;t_Vh%5~ä%Hg,uWu=NO؁N3/YesʸX{jteUFKz~rzd̰D83lTdK$^gȕ1˒@'KF7gw ]8Ca)%~DkĞ_ 0+%\ܘkg`8qėrp"D< /~ЪS'pZ]$İTL, S/}睵"%&KOYFZ0lMe0L 0 FsǍϊStMZ̴oENϰZp+-\1!1?^4`̥iۯ'bVG7?)s&~f^نK!,(JNNWĜ pՓ+s<7h*8ןɓ^2] X4}LřHWehLI1xȀHTo%uJTϽ̟7>/i3p礙C3fXνPӷŰdvM)*Gă4OYB>RֳVyLױW6|1[36:WF1d]P:U=dZW{rniϤpK=?z1iW\{8,ExƊQ+ ER0XO3!J(uOH[k"}8cA%eUc}I7)ݝk~D6ĺ@6.`?m8$cTKg\73p}+˺H\J/x IN!dIuf}\80Zܠ'xT YZ