python3-cryptography-2.9.2-150200.13.1<>,)cI}p9|PQ7+Nن]eRTU>j|t"98{y8ttMO)uW5"M %m3 *LhØͅ7C'nguJ@~L5%B/ם#f<4K1U $ Ӈ>M% D%t(:_ur9¤"iWwY&pG<7"ݩZץ(o,2rQ<3^myOf>Oe{>A5x?5hd ) k-Ni #\#  #  # t# S# T<#X#^w#d&dT#hiil4(l8lE9mE:rEFDG\#H#It#XY\#]P#^ bc 4d e f l u #v%l w'#x,#y0z4555555"5dCpython3-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.cI}ibs-arm-4*wSUSE Linux Enterprise 15SUSE LLC Apache-2.0 OR BSD-3-Clausehttps://www.suse.com/Development/Languages/Pythonhttps://cryptography.io/en/latest/linuxaarch64.Lj.0 C C55vvd  >>U [??*Pff [&[&!!()()AA Y Y < <-f-f**..GGO'O'v|% '*>'1.\) | 6; 4D #ZN 8+;+;+?yy77@@ff"o"o<< 2 2  '' p p N NN5 [ (rIIqq!!%^s>66  )(kV  = =py  $$\\ :^^__--%%66]]]W( 94*  `,`AA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤cItcItcItcItcItcItcItcIt^^īcItcItcItcItcItcItcItcItcItcItcIt^ī^īcIt^īcItcItcItcItcItcItcIt^ī^īcIt^īcItcItcItcItcIt^īcIt^īcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcIt^ī^`E^ī^ī^^ī^ī^ī^ī^ī^ī^ī^ī^ī`E^ī^ī^ī^īcIt^īcItcItcItcItcItcItcIt^īcItcItcItcItcItcItcIt^^cIt^īcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcIt^īcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcIt^ī^ī^ī^ī^ī^^ī^ī^ī^īcIt^īcItcItcItcItcItcItcItcItcItcItcIt^ī^ī^ī^ī^ī^^ī^īcIt^īcItcItcItcItcItcItcItcItcItcItcItcItcItcItcIt^ī^ī^ī^ī^ī^ī^ī^ī^īcIt^īcItcItcItcItcItcItcItcItcIt^ī^ī^īcIt^īcItcItcItcItcItcItcItcItcIt^ī^ī^ī^cIt^īcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcItcIt^ī^ī^^ī^ī^ī^īcI}^īcIt4^ī^īcI}^ī^ī^ī4f6088fa476071611b59f9c7372db7b858037d536c8e0a8fc3e68d1ab3a31bed4f9bb4c0a3cbb7430a3943aebc63440152d99d9a0e35d01ccb07dfe7d31c8b8301ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b01ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b58e9cd1a90d13bb3976c8e47e0bc05a1cf45b6dd16edd6cb83b6146f8004b019402918404e07241a6a22bf9a06a6ce67bd0d95f6de8ca9c313a3836cd814c30828dc5eefb4210a9993b276d4fd9f87b08a2c820591bc4669d17ae11199a950fb33b990adf08762e93b4e910fa5f63192173de5ca26ab13ade35c588cb6b9c2204202015fccba25556302be96bc2fc760d75d4ac3dc1b6837a06a481cbbd911822f2c5dcd8ac93a6c6caf564f9a068db7c8ab802ce466de8b0c54e60d887ee7183b71ad0090a36213848b655bc0a7316d0578fed8e23beba15270876d6a6ab59808ada7e2deca1ef685e29fdc9b9667f1eacdef8b3057feac8550d9af87a397082416f050f393521f3957f652ab0cf27a704abd78835ba2c219697616ebeeb622d997d7e8bbcc745842381e896f2b9c35b7a579fb74c18632af5268a9c6f34e48e7cb201bebbc153f3ca085167c5491853622dc8116942e352c4fdcf8cbb85df2ae3b2dfdc72d5254742c5599ccd9f64e2531a72c84f1f4a0a9ab6a1add05e4d00d78263bca56c16e9802100f782ebeacf25c5c8e3aa0227039fc0fef51de4829564bac6bb89f13a6c96cf67a72b2ef65f6d64e42d1dfedbf3cd4c965b3a008de34fb43a88ab596c43519bd415e48ec188bdb32b58c68a09a4fc7a9892822d35d080e22590bcf0de17d10dd085aaf31cae041a8cbdca44135ec88bc5466e2d7d68443cd430f1d82320f227e36a9a2f05cd44b0b24c6359792be441be7b0cf85bba9d76b7aecd3001a9aa7047bca6b6bdb39b43e9519f73250131c019ba329b0cb671b86ce135ba6339da0f4eb82fb21e027e9c043d7470383f3a884a8cfeb77853448c372c3f967ec1487c1ec4c34006db9c6c2f277dd7256e456d49e75462511439c27f5d9620e0be67a1cd96f567ce50a4e922d2d27b30badd07acfe7c7b4b51b0c99656096d5d3bcd3853de747038a83bc791ecf22ff026f883f134bebe81806c731a9889b4ffcf60ab0ace790620eb947c68a4a667e7e03c3e0b31640667ff7057bbacb2c03efc8931a34879b9510925c63ab916f0e148658232e15d8b24dbd3287968ade8c7c9265707b43d12325c73b23cceb8bb0f83c156dbc0deb5850f76519766a93c903ce600dae8b5eed92cca3c419d39a3d570ecc4308284bbf119ac7366ed95fd81394b94389a23af3263214fcf683de1c20514a94691d509803c16d1676c63fab39ba1a8089b3512b84d83aa1fc576c850db6ff5eb39a658641effbba3ad15b69f37cb01c5dcf9cc26de4a1c304e7f0df07c0a90a96dd53348b057bb73c3a52f97046a2b6218e4d4d1b12d4a9fb9482f817f173ad60f331af6632836b7dc68fe5ca43d3fc091f9bfabf21925c2f0eb1b0001e6e3ef53652214d9380cc7b6dbcfe14ee076918dcbc24eb625d23712609ded5915d35cc99b9ee9ba12b4a7ae8977ef4975410c5c338141ce1603bdf29cf6880ef4df48e628c08e729e919a0ff3e50dc37356e6f538a66039e65dc3abdd7c1e5efdefb5527cd2ad5324d2c9621248e2853a65c3580277031c8d6e0b14ba83ea8c74d7476ef4891a5d36a49411e1efcbd343b8943e44aa94804dfa204ba6870ac25822031af37f71a5d0c4dc6558edb039c43caa65c11bbcd62a560d23a096f8e13bcbef507267ddc2be2de9225863b041b5c0a81381ef353dcb42b3ad9d09752f36154cf0e461dc377f8c81c64c6e9615bc44d3f753b3e575a24241f477d732635bc075f1fbffcf6168bdbfcb47d1e549695fbc184e411cbb733dad84aa52c49d0db00be1323c259ac2c168f0eac6e849758efddbec82a33725485a8922d06e6f4eadb12d04de364727aad37160b0eab0253378e67f4ead335ddd08322f1312a80cbc11637fffe9a5eb619a647884b767fed9bd7cceed1b9f9adc6339fcaaf9bc6e87ad03c7661f88246d11a1ae16d5ddf372df17673ce95337ea9500b3f44fd700f817b6ce531646749db6ae1a6461fa141190e342825edb9d451fe3456929d58b94e1e1f36e76577d0e8016870fa8fc8a535800f7704fb65a7fba7d8fda7df6539e5e653d04c02966f2c39f83bfb7a8809d9ba9a21ebcf8b775ac3759faa50595af531501d8d86b0120bf7a78fa99bc499b476c343af29cd07644f9496a015962b9863a5f3d3368cb0f90dcf7ed7dc6ea5d14f64b5f6ccc6b0822cdae396acffdafa9f543b46496c56d1c30521e06cf5159c426acc694803494c17c9da764644036816a63d241ae9f9d73dc42d7b99d03cbf5def63c45b2b67e828828afc7273e2d157ee6471424391a9535252655ec062a2f520e9966f34f7c3db79cfab28b763c3c750f024b913b05f346491ae4937b3290a1ee5374083367e10c37af198a7370d04e6c034f27d3825dbecd3d2da07e2de3c7515f01d2db46d5282f8c78fd05217c7e72f82016bebff1bf55661ca69eb12b389cd4ea98e048abfbf6d1fbc18b3048872e1c6a2119a8be389c5258c2e51d41d0fcf5638f0e46953f330120e068f6a452d80f51582aa1066b6f8d96df69164556c8d11bbe6a580e3cf3e9d09978f8bc6d444909fa716df2e26c40b6268562fb6ad32198f053a446ff9c7c3ed0110420867df952e8e627a9a220c4f5e21b8eb719995637169d7ed9204bfe9c55aa102757485020a104fb01036134dbcce85a23ecc164fdb9656566bb9a71f6c11043f55903df2ea167fd88a32a880c343a362c27ce8b9bdea443ea53930320f62ef78b996e5e94771307c3bef2b3a0eaeabfddeb4239dc3debf9050b1c688333a96a22e93faba4dac8ceddd67c3d608143ec4172eae6d9e964504e5c436bff0afa2c379ddf94948e1508b68f49b2ef2ff8736134bece814708e94f643c5d7572247f0444d8b3709163a3825ef175aa0f3d3bd64f18d77f200c9199a9d8d358488f8c8798c034313e0ca16d3ffaae20526d64066fa6d3622a637aad116f3e46808ed69b0eb6dd6884c4f400aec6cacb77f8284c5565ab12d3ee49fce29b6830e250e92b9a93452fcaabbcb6cd6dceb70281e44e7ec01cf7ee8eeca0e98ecaff1b5c7ba34c79f5f6193aea2fa75283ce86733533ddff01d5cced878804bc73564859ff19f9dbb4fc7df00a117f18451a841bba4a45a6b2226abea23c452cebc83f3480a880e6f6be4abf5d1785af069be64954827ac66e67a4f3a98216664eae42e97eb6067b3979da8875f302a9c1e8bfbf0b6341f3ec9a580cd52be11a5a4e6c4e03e06744d00106480a114d27742a7057fc03f7908675419c54f878fdc5fb023b4856f7c81fd404e4482aec58cd6ae7bed726ca5926c2f55c7a397d49caa5c0d7ccad913373c0753435cc34cf8fa9a84591c49bbd1b36433d3be9f18056e461c579b7246852d3b5c53577e49b0cfa050d79c3d4dbe6f4eb493588f32ce9e5acd307dddc7ff001003f408fbe2bd88141682ea57f9c8995ec4c3508e7f509839040c67791da0afe8c310877df540105c5c9fa01330fcbb1c04c88d665632829d4d71c90a07947f8fd76e35a6a264cf78eab80ba851d6c7e77224bd4ed044d6af75b0a1823fb0a6a89171f42d72ec828ec52cd6a7e95e418a2752df4cd5916370696b9567e9fa528860e14cfe6976278aba4c8e7ea21f0cf513d2deed9d7145b14f9d58c5fa5bb3baa2467cec471a3894469a3114bc83ea0d5ec9a7ac5c932e2814f48de9f5db1abbeba76424f67a82f50225203444fc9d8b5fb44365a386201c2b0bc3d91e7d6737d96e8ac333d05cfbef91a359585c48fcbf2b20ff34be105c75955b2334b93266f1750e4dd1ab78e62f5a1895790b4bed756a941a4ffab9cbb83ae633b6c6e0b4fee61c2a3ad6cc289fcfdb8e34f14119b6bb402de8ebaf8acf191235fdae23f0fb932c36af7e03b22cfe752331dcf41673a9772dcc9e8c025aa0c618bebb87238a14715ecf9bc35eb4f714cb1545dea3a5011a5593b4292514bbc8a9ccf9710659a4372f2c4f0f69bd6aec92cb89b30cc3285b14d3e29c3fce1839e67d43e8682af8c7c0fd269a01051e15deb39befaea3691c4016bf60914b439c9062dd0ffb2eace831f2db3b7dfce61f89815f11896423d1bbed472efa2f38a646a8c84f64064a5d4b8909ca62ce7f87ecb36c151c01b9a1b481a22e88dcf4df1382edef2afaf3282092785f71dd0782eb5b1c6ad3fc69d2c0ccebd4ba54cfcff9daa27b6e26397eb09890bed98cf426e7442a86b376f17b27d6f93ac3b14017d06bc7aab3d301b0d8e17d47b7c75fb35610d0a6aec62281b5c7536a23827f8de11923b3d5431418cab69e9aadf88efe6c1ed23e8206d87d3d878a48924732d6ae4ec7a9b37e9d97221a97c6715a3c4129c38335581e52e71dc68b4d6a1a08c7e5fb59f06312a27958eef3284600c2e26c8cd1f27ac1f7b6929af8f73238ebd12fedafe77323a95952fa597e8ca7251fae5ea85be9391e1c8c9f4a7a1192e1d08d3f6f0a590dd07cfde4a65e1c4954b990b5a744459161b2d1096c7c2507625214afa3b658d301b0d8e17d47b7c75fb35610d0a6aec62281b5c7536a23827f8de11923b3d55da817a098b956a36629915f0fff80241969f98e8b3150b1ef642d48597a066dbcd6b4edf4363ead59ab17c725ac45d49abe777c76440e63cb4b1c0af87100712e02ed58455c102073fb207b743cbdc3acf4b264f36c4ead68df7c4a7d17c722b86555b400d0ecd5c640d50ece518e4641663e49805ae8550f17e21da2cdb93b60927e4deed79221cf2aa6f904a08428f52ef5f7c58d5c09bee2604339eb5aa9fb6f48ee657c361cb912005b182d359859b532c2939162efdcdc49647e6fba22e013dd5541024ebe6a40011f17e2926bb2317247a06c90c6b3c08805c9d31ab64381f7f5045e300d4c79732fb24af87e3acd8aec51d3111b9d5fa371574a527bd301b0d8e17d47b7c75fb35610d0a6aec62281b5c7536a23827f8de11923b3d563dd8984c50354aafda7d6194552464e37b1eb6bf257b07bfdca97affe9a504fc69e6714a13dd944962d175ac7219bc047aab584a0c597d161831086a2cea166c9836e0eb63bf6d91294414f1669ae673cc7c310be09915d6f01c4218afbc853fe7176e612e6a352c493b5bf808ddd4b64d5626601f4410b754a4f410ec5d4373e10fba3a067d888b9296e51f692738ae2acad9537a2535c2a2f20c442ebaa932ed8c27cb0aefc4ab65c464ae9be69b53f17626b00d349846f2ac10a2bd2cfaec8d9ed7054732084ddcecf00909abc0ca0bd409d059cf7f1838d65a975d71c60430b19156f2bd7457616d3e07a03df93aeb5242ae0034c86540127dc37ceeea296b24e9cd68a042f742d8a8d93183f66a5e848d6497a8a2aadd9e39bf387ccf9f601ff4e2d77cc057ff5e5abdb3dde7da570a29f29c9e2ed49168c9a3c03ecefba1551a1750755e046439ca94d6b24b272fb480632e9f5545476f5f5a3e0031da2e6cc677295478398600ebfdbddfc6a240b14fed801f6f1315c20664ac4a7f0f4248df6e16b4b1578ffd300b61edd63eb8f7fbc040641f6ac18a83eeb8a671a0b552b5b376966678dfab57df04950b6cb723da829c405e9c7c461fbf3298e75fe6fd6ba3a5f61437661a687b65972fc3434e47be934131d15f21e471b5794cc683686fc42fca5ddbaaecf4cb7ef2c14698a0fb7fef7c9f92ef69869eb347d465a1527ded1b1a0b031180b191c4949d9a3882d74a1e790198b4e0c06e7589900022cee27bc0ec2c386fb0f1d065296d8f6df7e4866f3a2949f00c8bd38a80858cffecc9646ebe55967cd543c0ab999ca95e83fecec01686cd9a44ec98f38fbe82aed6dc878173bdae2d2e798dd303b8a5087cbd94ff5b51ba7039f92b28f0637c110ba5f1eac20cacfbd28e88d34f575a90fd047f2afee6e1e44a84b18e797f6cc0cd0f96afd27b76f0c1ef22efa87435bc91d46026824446a5758689fc11b7823aa29888949003437d8afd99130e05ec0215034d0e317f6e387974c6769961f629f23a9ddb07390ee864f54d38e032d36bdf1e7a5008f57287dd2948f18402f26c47aafa8652ee85df3ab81b182304a5c3e7261e0b1d1a44448c4648a6fba16eb13c306d2f6061fa5fd71a5181bea4abb910ca32473213bf9d12c2d48c2cba9c164c6c3e15e8bd969da76be78b3b2e8d91b46e1f833698875427dd8b0025c9eec06b3f7dcb348abb66e50a8e21b3703f1a528a8acb6b9961edbaeb3733edc4333cd36ed433aa8c0ea3ec1d7698a9ed04c6be5676708c6e3dc920a1657137beaa36d894704a9b203d82c0af1d7035bdae07845b6fb39d7d41da70b3f0e3a813f1b47b5bd5fe42b1bcfb4dec8caeb41711b2dfbb2d94ed45b5a0d6df467945490dcd85d98d0f36069bc1b2f2fcd2817de0b97987a854647b739a8b07d6312e522e2f940272ea94250023b63e45019cc8aa69646968ab59d57e578a40ddd18efd0ec69f2073a7d30061205b3583d4b64280c50889db4067e0433704607ffb20f5360e4c93a862b644c103512242a07bc2b4dfedb3057c739f8b11e6952a98cb3af8e90ff56ee0a47ba80fdf77ff04ac37f319cdf754bb16734f36a994487bc22f99cd146a775f032fe8b55ac8ce8e3f8ca4dfc2a9513e4c491dca05ef39bd2b4f06e284503ecc931d17efebda07a618f2781bdfe3f55f89f933bb0c48295ab7d0fc138f4a5818054b52b27cd9f05d25f931af96640149858a18aed6dbe2c099215e97974d5b8d354714271d26bdcf876710ee1c6461879daa6f927a4669c679ed6bb32bbaa97b406da8792054b4ab346b6c91ad70dc949437fb99a7a5c00392cc6c45cae0dee77622e0c61d2f11d6a37d90fdbf9486d6b30f7a836005080dcddfc2bb7461c43431263b4912d1fa9e4fa75c98c468f486ca2eeb36e9601f0c386337a8467880e723777e04f456eb6ea3e8fa8b5c9e88a10a03ffb8684ac93dd97ac68265ab54e7eabf596e6f6b305678a3c5f1965ad0023c856cdb25a551377456283bca042211c846c8c3d76bc02790fc8caec063038bf9b22584d56948fd24ce63a0e63671628084f4131bddd9aab8c4da9ed8ec8f3974cf69aaa1cf6cfb4e7cfe905fc4b0115ee1e32d2ac0001806aec87eddf5191ff7cd8e6ffbd16320a098b81b67f51d548a3379957b15f769239aa9e2ddf59d61945e22b07e0318ac5da264316b17a37857f3e823e123573888dabfec3b22078d58fd0fae2dfccec7b7eff19399f98e517d2a8f4c4a7ee054858c5875edb4e2759b003eedc84a27290ff13ada0d006231ae11542042b5a1a71d230f63ca4abfee88d64730a5e8e5fb3b45dfdbb4ea6f38a9d873d53b63ef7067206dbf3985b6fa1b88e510034c94334ad9e6a47fcccb63d06f639bab35f8e506796929f51c259bf8097abe97d16ee084c003eda01bb31b5cea6ea4d6c912edcb6abfb8557e6dab76be9292380a06fefed4fa4bd5192c884e0afe1f2f5f3a5c4ad381e272ec17869d7a9818a741e02da8ea2169a42b0ed7c0de3b39005be31f0434841768abe5b24988eaf4645b27df5b5c8fc8f4ccfe3f358fc299853c66779f4875227b6c15f12c8e00860c428d4b8af2d94c55568328136116aef82d225a4bb079db111e4896e25d7a04b55ae98108c39f405c7b89732eb53e47ab8550fe2bfaa42a7f039a5c3a13b1789cef6e63d88859b51723515e2668d2a07d20f96ad7c3850605558cbb12578f7c2226379cba05d2171948fe49154ac877c3772a94911915772489e6cf6a8c87ac8c577e1086f028547b930f55e581fb6d5a928ebfc95188ec604d0a744e9244b9df3cbca123bea9d41de43d234008b37d0d8b6c3d4dc53dc3e01022978e03ac0b75f03ece44e6242039700292f6bb4546d562f4aadebcb0d917592ce38982dff383208a066245e4d81524649d6bca973ebcac2c1f74cc3ddf0d09cb5fb707917d3d0cf11f431b286a00e8d2bb897b64e1b453b909427d24487805b88e7ba399dbe284d0eef1a71306b15ac4fe0865656d07507ef4b1e578bc25a5219352520074bfd9f4e6f70689e87791e33ecc2366bf30169e93b2ee9e9fd6e51d8177921817239474cc87273c9be2fd6545d35d4074eb40a7f151688f46faa9c00b0d1cbcb2c7a1cb3e88684d8ddc04bad46008007cb92cb14b296654e098e29298f02f8aaad3b52541d66f1e9a38c6251d08c32558814c14a74f84a9db240be9c4183b03e408f4b2d7f4fab2c62370c5c8148a322345c7fe213dee9fb2c9780a7cfbdd5a06a248ffc1f515f6a3cb6be5042848bd40aa1c5443293a6f6c22233f499e848a8902dac35365bb048584a1b983a66fe1ac53a8728a0104d8e99a457783e10fd9f3786994692b6cb6b3b59181ad71262d7c6e69056fea4f5abafae3897697728f742e42b9cda54fe1aac9eac4a762e596c8bb4d624a7f60ab0903e889a34441c93f2b0b55eff967d7de2753a93acdfe86bd1349605835faf41630c04e7829fccff6684de2c077b226a064d9774d1b74d562cf38b59820662cf757534e2e35af1a0c66b8ba0ae1554e2efc659b5936ab056b82f3a37c04a928742eea87dbcc16516ad9354b24571ab40e21a0a318be71712649795ac627697a59857a6c986e3eafe43619eec6534fbb50ea4ff67283ff612c588f71888bccd0d8a0838f48b571890d720290c56aeb3b02f51c96d61329043b7ad87817163ee3dbac3d7d602c245bead34de36881d183126f869b17c8eb202835bfd352af441031f435af6dd10e85245345fcad0ae1195ca94d292371c52940bd2f92e93b88313d246c112fb1d6578f0dfaf2bb9538c11678b14f20d1a5e748644898f7cfad96c1e3e9cd18aa18ca359ca9bb6add7f810adf10c3f98dbd0cb26e9508c7ada5abc17ee9b2a096b3b370493b68e18471bd81ac6c1bca4dd5bd8e2ccd0636101bd931a7fc0183d6957f386928fe4d72d7960bf3c20ba3878160ffcb86525c1202a732aa6eb643a607e1410accba299d9102ea8e4548b3bb9be48e60c266126fd21ad1575732a5961e69ca49d43b1ce18400ad2818f69d1e749b8657140a273b10dcca65bc2648f403dc71b7b10c2dba4969fb09b2171f71771f00ec5c869a1c9182f91b123d4b8b646d4c25e6f516a06ff47ee3051bfd4329dd687fb569fc9c80495d6551ecea346518609b5c043c23231da286f0e6ab8827877caf1f72c4ec0c0d9b91754d28d1548ae5d1723f9531b07956c4cec8f985d2d064161d9f118faeea52ee49ceb91eed9c38d6890289d7c03d9c07568ab52089d093f8b2b14a6bea8ab66554eabe176c5e64ae3a7617cd780e6c96c236f3ca2d77d8c44b63697d0c82af5362ba84e8a9fd758a6e2448a29a92e7774ec2ec94821c6c7a3c20db1bda3ad63892a5cf563a542a39938e75596c0669f70b530f1d9574c0257809f88fa886ff5047b2311a791be2fd81e0be1c1da5a1b8eabcb25511527a0a6906fafd5b56e944feec10102c3c74b1c963a89db2a87dfa1eb9195c3498de269d73e6b08ffa50b07aaab35bacd72d3417914e07163098f1ddd38d0db03e8b47a50a6467e9325640305bde72e93170d0937d2a96c532d6200e9254cc5ce279c0b528afb3cad3a701ba172de9a527c744388919d254c53de1c387238d819608aa4570e5b0fa2a51ae42fd6c3fbaebb6363afddddd5f0056ae6dc3283a006b6f3513b53f9f3cfcbf8e0e9808979a523270572c7a1c1f1b60bb175dfbe569439d01a50f97c263d7229414f0d1164a0799fc153067812d63104fcd06b8fced64b86a816ebf810d56603050589d754d7e498185297a9cc34c5d932a543e73931438024a315aaf825ceeb77cb050e93f50cb58e0f5be20229942d524fe294b751c215ccfa5dd609de01e7afa42c1b132b3557f2010df1e1349d257e90445a4704f85fe14dc7decb332dbc1944a0e3a846f7680831066d2a44a0c92bf9ebd493e199cac1a75634375a8c0230fd21e2174d64d8dfcf3e6f8e9600066e893424bfa313e7505f5882a41819d170d962fb8c80bb4d86ca2a5543727f95382c56c9c95f6b4ada871bcb8a38986e7ae6b76526c4ba0120f47d42c956ebf1272a5fb346cd32097b87c5086cd931241daa6b5b16677c91ab423b39448828bdc0e1b8e9a9aab29d061df617cf564bece6f615a9fd49569b9c117eff75d3ef5817d5b25e3fd4d06be1db48fcde514270558efc00b61036fbaeb249d43b855f31987aa84c4aefa5782fabc80a44e4d21730cb216e5a3a72f1502b85a43e16174d5930769e7e0b2f31e4ad8454046b5833feaef9e772cc6bf22a3aaf2d0fbc108fea5c2b842d8348c426c1bfa36c4110a984446ea47954e3ef5a2ccb7630c0d14c3954eade95adec60def3c036d35db0d3103df23432d6f785ad98f4fcca618784077d1e7fff911d043e735abd96d97bc5223bce2d9057a7acfae6e3c9b695a09bd5add7f521e0740f76de397d07342af937a54a236ea1efd12ee52745d5dcfe1296285c15fad1c0f3a85717f0564068fdf7bf5328682fc9093af803c27cec2e5f60f67aa9e5b75bfb7568ea07960df235e488a9ed624c42e92cb2a7905f397c1c4714d2e042c1f6b9cb1afd3f082d983e7d1e85e666b7d39ca262ded76b6483b24a56eff63b9193353864801a46fac8259cbdbc1df25c2cf4f5751363361fa66786719e2ee0aee1467f14cab6452b31d210fd9aace115675bc8b20cccb568ffe765e18839f4999efe3e0f3e588cb8ce7881f91fe21c61394fe08ca6956a6df6931824c53c5a26f8f00d40b95a0a6e5c00d4bf8c0a36f6130dd83d0671605f7d556d21b2372cada40648f6879a952388a6f9785f495483b4bd34b456c3e331ed3def4869d047fc32440d688a7d3f5318b666e0bc0b1229f8c0404086ce8113b343e19fe1abf03dfef6d0edada246c543840f45cf1668ff8d9081a902b34091d8f1e8dce7929503b2837da04d24833092c77efa06e34ec0704ab4292c568dc6240364a35ad9ca2754ed1c8278688db7911803323a72e0abf7857bb53c1ba0b31e59c340c0a93aa66efc045ccac93ace350dba530f3fb9ee433e7b2fc6d6f873789f65ac84ddc8c9f85ecadc55dad3685548fd147b997fd5ccc67289a1296e9bb7c86a391a013bd0f7f2a16e6781bd512c626bf9d0b902b6ae1d77d2c1f937df730708d587b3d4af4e11d1b4c2e9035867d2fdbeb1376d5e1cec8f682aa3ac662383e2a1b95b1317dcc7a0d52ff762743660da0da2bde15bf774f36e5999d0b0603ccb4fda9bfb370315ad794200382b2cc0cdd204ef522327f4af5ad95a652a88dd532ed0ae2358fe59e6ef2de40cff29e2f94bbdd2760e82518901708261aa32829394feb23a69cb0bf2976ab1d540fd2c22d064d7576d67b2f3574561341d107234b214d7154440ed264b5dbd93ebe5eaa37d701844981b351a12d6400465742a857005c7fa4b6ef4d5d4a1fd32726732140e9b086e95ba43a53b749649a0e1a46fc7b43aa9b1df999a14c49ff2df5e040567f85767b841b96fbcd96a7d1535452b557fab0efb1e80d7edb9c4e5118b9384082adaa051dde342102cb9de8daac73b3148f6d1d7111dbca32099f68d26c644c6813ae1e4f05f6579aa2663fe602c4c7482de6479dd2e9793cda275e5e63d773dacd1eca689232ab7008fb4fbrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpython-cryptography-2.9.2-150200.13.1.src.rpmpython3-cryptographypython3-cryptography(aarch-64)@@@@@@@@@@@@@@@       ld-linux-aarch64.so.1()(64bit)ld-linux-aarch64.so.1(GLIBC_2.17)(64bit)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)libpython3.6m.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)python3python3-asn1cryptopython3-cffipython3-packagingpython3-pyasn1python3-setuptoolspython3-sixrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.60.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 docsibs-arm-4 1665760658  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstmvwxyz{|}~m      !"#2.9.2-150200.13.12.9.2-150200.13.1  cryptographycryptography-2.9.2-py3.6.egg-infoPKG-INFOSOURCES.txtdependency_links.txtnot-zip-saferequires.txttop_level.txt__about__.py__init__.py__pycache____about__.cpython-36.opt-1.pyc__about__.cpython-36.pyc__init__.cpython-36.opt-1.pyc__init__.cpython-36.pycexceptions.cpython-36.opt-1.pycexceptions.cpython-36.pycfernet.cpython-36.opt-1.pycfernet.cpython-36.pycutils.cpython-36.opt-1.pycutils.cpython-36.pycexceptions.pyfernet.pyhazmat__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pyc_der.cpython-36.opt-1.pyc_der.cpython-36.pyc_oid.cpython-36.opt-1.pyc_oid.cpython-36.pyc_der.py_oid.pybackends__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycinterfaces.cpython-36.opt-1.pycinterfaces.cpython-36.pycinterfaces.pyopenssl__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycaead.cpython-36.opt-1.pycaead.cpython-36.pycbackend.cpython-36.opt-1.pycbackend.cpython-36.pycciphers.cpython-36.opt-1.pycciphers.cpython-36.pyccmac.cpython-36.opt-1.pyccmac.cpython-36.pycdecode_asn1.cpython-36.opt-1.pycdecode_asn1.cpython-36.pycdh.cpython-36.opt-1.pycdh.cpython-36.pycdsa.cpython-36.opt-1.pycdsa.cpython-36.pycec.cpython-36.opt-1.pycec.cpython-36.pyced25519.cpython-36.opt-1.pyced25519.cpython-36.pyced448.cpython-36.opt-1.pyced448.cpython-36.pycencode_asn1.cpython-36.opt-1.pycencode_asn1.cpython-36.pychashes.cpython-36.opt-1.pychashes.cpython-36.pychmac.cpython-36.opt-1.pychmac.cpython-36.pycocsp.cpython-36.opt-1.pycocsp.cpython-36.pycpoly1305.cpython-36.opt-1.pycpoly1305.cpython-36.pycrsa.cpython-36.opt-1.pycrsa.cpython-36.pycutils.cpython-36.opt-1.pycutils.cpython-36.pycx25519.cpython-36.opt-1.pycx25519.cpython-36.pycx448.cpython-36.opt-1.pycx448.cpython-36.pycx509.cpython-36.opt-1.pycx509.cpython-36.pycaead.pybackend.pyciphers.pycmac.pydecode_asn1.pydh.pydsa.pyec.pyed25519.pyed448.pyencode_asn1.pyhashes.pyhmac.pyocsp.pypoly1305.pyrsa.pyutils.pyx25519.pyx448.pyx509.pybindings__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pyc_constant_time.abi3.so_openssl.abi3.so_padding.abi3.soopenssl__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pyc_conditional.cpython-36.opt-1.pyc_conditional.cpython-36.pycbinding.cpython-36.opt-1.pycbinding.cpython-36.pyc_conditional.pybinding.pyprimitives__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pyccmac.cpython-36.opt-1.pyccmac.cpython-36.pycconstant_time.cpython-36.opt-1.pycconstant_time.cpython-36.pychashes.cpython-36.opt-1.pychashes.cpython-36.pychmac.cpython-36.opt-1.pychmac.cpython-36.pyckeywrap.cpython-36.opt-1.pyckeywrap.cpython-36.pycpadding.cpython-36.opt-1.pycpadding.cpython-36.pycpoly1305.cpython-36.opt-1.pycpoly1305.cpython-36.pycasymmetric__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycdh.cpython-36.opt-1.pycdh.cpython-36.pycdsa.cpython-36.opt-1.pycdsa.cpython-36.pycec.cpython-36.opt-1.pycec.cpython-36.pyced25519.cpython-36.opt-1.pyced25519.cpython-36.pyced448.cpython-36.opt-1.pyced448.cpython-36.pycpadding.cpython-36.opt-1.pycpadding.cpython-36.pycrsa.cpython-36.opt-1.pycrsa.cpython-36.pycutils.cpython-36.opt-1.pycutils.cpython-36.pycx25519.cpython-36.opt-1.pycx25519.cpython-36.pycx448.cpython-36.opt-1.pycx448.cpython-36.pycdh.pydsa.pyec.pyed25519.pyed448.pypadding.pyrsa.pyutils.pyx25519.pyx448.pyciphers__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycaead.cpython-36.opt-1.pycaead.cpython-36.pycalgorithms.cpython-36.opt-1.pycalgorithms.cpython-36.pycbase.cpython-36.opt-1.pycbase.cpython-36.pycmodes.cpython-36.opt-1.pycmodes.cpython-36.pycaead.pyalgorithms.pybase.pymodes.pycmac.pyconstant_time.pyhashes.pyhmac.pykdf__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycconcatkdf.cpython-36.opt-1.pycconcatkdf.cpython-36.pychkdf.cpython-36.opt-1.pychkdf.cpython-36.pyckbkdf.cpython-36.opt-1.pyckbkdf.cpython-36.pycpbkdf2.cpython-36.opt-1.pycpbkdf2.cpython-36.pycscrypt.cpython-36.opt-1.pycscrypt.cpython-36.pycx963kdf.cpython-36.opt-1.pycx963kdf.cpython-36.pycconcatkdf.pyhkdf.pykbkdf.pypbkdf2.pyscrypt.pyx963kdf.pykeywrap.pypadding.pypoly1305.pyserialization__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycbase.cpython-36.opt-1.pycbase.cpython-36.pycpkcs12.cpython-36.opt-1.pycpkcs12.cpython-36.pycssh.cpython-36.opt-1.pycssh.cpython-36.pycbase.pypkcs12.pyssh.pytwofactor__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pychotp.cpython-36.opt-1.pychotp.cpython-36.pyctotp.cpython-36.opt-1.pyctotp.cpython-36.pycutils.cpython-36.opt-1.pycutils.cpython-36.pychotp.pytotp.pyutils.pyutils.pyx509__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycbase.cpython-36.opt-1.pycbase.cpython-36.pyccertificate_transparency.cpython-36.opt-1.pyccertificate_transparency.cpython-36.pycextensions.cpython-36.opt-1.pycextensions.cpython-36.pycgeneral_name.cpython-36.opt-1.pycgeneral_name.cpython-36.pycname.cpython-36.opt-1.pycname.cpython-36.pycocsp.cpython-36.opt-1.pycocsp.cpython-36.pycoid.cpython-36.opt-1.pycoid.cpython-36.pycbase.pycertificate_transparency.pyextensions.pygeneral_name.pyname.pyocsp.pyoid.pypython3-cryptographyAUTHORS.rstCHANGELOG.rstCONTRIBUTING.rstREADME.rstpython3-cryptographyLICENSELICENSE.APACHELICENSE.BSD/usr/lib64/python3.6/site-packages//usr/lib64/python3.6/site-packages/cryptography-2.9.2-py3.6.egg-info//usr/lib64/python3.6/site-packages/cryptography//usr/lib64/python3.6/site-packages/cryptography/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat//usr/lib64/python3.6/site-packages/cryptography/hazmat/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/backends//usr/lib64/python3.6/site-packages/cryptography/hazmat/backends/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/backends/openssl//usr/lib64/python3.6/site-packages/cryptography/hazmat/backends/openssl/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/bindings//usr/lib64/python3.6/site-packages/cryptography/hazmat/bindings/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/bindings/openssl//usr/lib64/python3.6/site-packages/cryptography/hazmat/bindings/openssl/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/asymmetric//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/asymmetric/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/ciphers//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/ciphers/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/kdf//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/kdf/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/serialization//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/serialization/__pycache__//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/twofactor//usr/lib64/python3.6/site-packages/cryptography/hazmat/primitives/twofactor/__pycache__//usr/lib64/python3.6/site-packages/cryptography/x509//usr/lib64/python3.6/site-packages/cryptography/x509/__pycache__//usr/share/doc/packages//usr/share/doc/packages/python3-cryptography//usr/share/licenses//usr/share/licenses/python3-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_Updatedrpmxz5aarch64-suse-linuxdirectoryASCII textPython script, ASCII text executablepython 3.6 byte-compiledELF 64-bit LSB shared object, ARM aarch64, version 1 (SYSV), dynamically linked, BuildID[sha1]=14a8837e893e5ffe4427c56a4c40a90b0f9e17b6, strippedELF 64-bit LSB shared object, ARM aarch64, version 1 (SYSV), dynamically linked, BuildID[sha1]=d0444f38be11fcddce831cd4e0fb0ced5f14b43b, strippedELF 64-bit LSB shared object, ARM aarch64, version 1 (SYSV), dynamically linked, BuildID[sha1]=a4f810b97960bfd77de0d1a9ade666cb22eaced4, strippedUTF-8 Unicode text  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_fu|}~     RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR RRRRR RRR R RRRR RRR RRRRRR RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR~ ެnA"RRfpython3-idna2.1 utf-82baab185e305f713ac4947b03378b8dbb986f1293cd26259b46f330e503c0193?7zXZ !t// ]"k%Ӆ) `=tw<,J$LլͤҺQ7{Ps+~魏eb̗-Ɋ*6~)~CKn`hSy9&aD+"+o2 ti` o9!Lr-Go{ 0:X>|'Arz36|媒pi40s+ΏiʗiN/yBg!%9\.s̟)+? Vd {RAd>.th#r[yd:3Y/Q- Ș4y@Q@/SP)|d z}E+2vxk|2%sL6͆x&]{~in계N/P*Dc>a@%@iTt>m >%,Dϼ_T1r`o+.(!OfliAvdO%@AԛD5e1Ibdi48l߱nm:#+ƭ^-}8VNyJ>f sB[.#DY얷pi ֟ŸL[m?-8:DuOcؓHE><2VIO:d RSJ[D Z%IwWOw@J|s'&ͯ1굁N0lVNjE|3V:)=|c!)~%+0Ɨ.7r.s@C`wK4bt%'|pJo eVv[ޡ $d/=H%סyW8TX"r@UKza*f}^Y^`z¹c"6LeEK`~: 6,78I &*Ԭ3*URL.vgSvMeBI_"&ml5ʽHk#Ր4Ͷ{EU1p],?fcӋKQM1j 0i9] Z?3kp98_LRElp0^WG 滂 (ÒC.4 C'*R]Y!F+f`*y(~F\rAzSGlXش+qÐƟl OK/NrgPO .XKo! 8E 8jJqYabZR\Q>DA93#@lpK،wu$Yjs-^.QW8YfA "IE[x|.lXAD9$-4 Ui;؅/]ħЬ,sY5^ޝEoWrϊ]}Χuo`̭FoxBU< `j摵E3~ީ,YlƎÐy4沥gvze P3/KȲdFYz1J;x͂Q<'ۉu$|:il 'n% 8* v@;L/#g)۵~=s@Ų@D#(o<ِ~Ԭ.S"[Xx=L;vC8/eUKĠhfWܱp^BεfJ#O V{-m EC"EFϗhq䮬r_a ѳڄoYvrqa մ¯{*/dKrE[l!`dԃι,3.ҧSnh'YmڸS]{>™.S+՗5xOף_҃h@/eMRMSPrex.w:jߨvaeh{|H>d$ovz N\:m/3(O63?nSp:XoW{9l"cuOɡFYpT\\$HQI!탍T0`=5MӋ[-t[>Ѻ˼\>{Bx2V]rTeqLࢭ̄섋HIXq샇Tڳ ',ΫD+ P~G*qxKWa38O:Ӡ۠džbD|V`^F LV3XP`SnNC}c6 Mݏl ?"oaOt*L9N(&јp`Rɝ57T?Pᵪ27wkO]:vV =k,W7?Bx> 4^vB\ݬV辐KB"&- ]v):ק~=q“V1# Fw _7 )r~/f brjIaa nU?/8k¥GZѿf;8c;`C/pK[RrUßLBbFu%N*劣~%+^ 2I\MX/v`b 2uug@MKzCRHl0"SKbgJ`UfXp ,a6hɌCeE`@dS^xb׭UQE?>릺ɤ<֘:qjڃ6~vvI "? ;0M.сto٬Fxrd^n }=̧Uz3'p.;Pvo,ji#aN#)wz#펉aJLmB V1d09Kହ Q~/nesՆ|^k,7$(00weOt1_a_2l;1(+<&Q8ZԱ P̞*Gȉ /Xր%D10T?/2ӀNQťҸ]4 E $x 'Fod@J(@µtE|)ҜZ?1L}sg-ս?* U QOz0@' n0)mU$f:Igz!Ӧou"43,Ip!‡GHCiIVH{(0uaS?!OZG9mjќcz t_G}-;\Q V%}e7t+@3es I AaVklFT]WijD>AH2W>NqIj@u$CWbNЕoG++&8$P̂^qw`ۮNQfIQdM=3,VoB<|=60* 1_hA}5Hεܢ(z3?ߤZ#muj;~tֻFBD|Is-)WgS\A܇r|Me K6:uߨC"_?Yg#elG/9=a3y$1\!j0`R'x+;;J`'e}wvj^Sg0SZl)HhL =Yr'[Zs^-jg:m GPRCVZZdˊhW}ߜޫ(K!qmA(AX[R^AHZ>rx[乃a 34R".[o čI|o'39١ zPЃO^$o 5O[Q4(#5NDߪ]ƠƇ'Z-CYVurJ֥=cÜ&r/μ].wdAȏ)USD$}¼h}:2fLv&^Vۙx!h!1@L+څ+D`haH.# CJ:tv \T#+;` djX>o87M:)hu~N|efkf$&s|:& =.- o)ALF&v}cnErE=TjZPl0U :pԯGanZ  .Չ 4ڏe"|Ab,DcnuLe`}5Ȭ+Syɛm="Ofָm x:Qg#&%^=(] ]DEj*B}HwoRrvB+گ=a0jₗ ´O,߬Z+Mon"FW?}@jƴ ;;zJ|@ GiEJd`X%r]W-_47-ZإKg$`cMFG[0:KXq ;?*S/i#JOLXط#i"Jm469dt(qNrWkVn:L:} '*dyE?L̊> #l J;ں]]O2Zݭjy"9(91AP˰KsV('6:*~~_xEIJ2QMz_w)B '~ʴR9^Eۉ}űźֹMizYN֟XFYOfAÈ$@R[p&}$7[[wJd&1ClL[t®7lOדq6}Pd,ԌZGg~kdqd,'ZBq| ^jڹ u Z#aElnƁi7Wi%j~1Zp⢘zM΀-b/ѹ(zӰhGr8HUx&8U3_sk v=i"D"zҲ/{k_ V8҆%%:Q>&&M:b0`(e%g'*}n{RK jہBU;&%,1]lWlP53.2OIAώ1k*OyȬɄ:)ş/ji;D(%62UD<ҩxrjn5:ݚ<=:vl2F#9 DЛR%%8Ju-L^;>c [Z~1v} ~  ht M曪rA!pG/5~6+ZOEw#O ;kviU{S7SúODXZPdkC]mAQU0fN1`bDX%{yW|m Px%g ע ]?mGE7^|dG{T %=E0EGT;?7g,)}vA^L"? :W=:+vxvfNRr*0 HP R6Iȉ/eƕwx{E>d6{N% o戶`1$ѝfm>ԢG嗩a?ѯt9 #D >W&2z1nC="DWqewtM y=>2KiteF<{ L):jI]G6ȸr8;{Ft =f` eT o9.6S`0{䡘9#`?qWr d݁sH..SRww8g c:h_/t~7b=5W#]<~K_# Lw [2RS6(JJ$Y^=QdZ3ҕkR8 J\h2i?cĵԿS[]!n[ї-ELͫ<3K @$)2Y.?xO(1Z\&onJC_Zb(Ujn܍燬ҚlA,jr ^OzWl+0e~) smJjL*YeյG 9EgH9Ut*FtqmZ!&O5'zg@$%7$+y1F1w|AwЩf{ &2˕gZt `n%-BaCjZl}7j *w;<$ԃVDl.hFP&!s}^1^b<#jߛa2У9IQ1[A<`bԳa c6s$q:m#!=jkJ ׯz\/ǽϿOwûC?%d9,Y L ?EiM69qȂYG 6}Z 6}h#Id@QLE&6hɌYk#~&F٠hvהfεK%gPO.c&Dwd/}dOG"7IxDFgbl%]z-jLtk~(XPkpxWrxTo?.roIR,/L03W jXDn_w*(.q!J6M[i{*5}?yZ:(f糇B|2L-jME x89#[Q&JӪIIe7a-P^6A`ػH ФhN.b(wSt HJ &NQ a;X)pc޲H/m6%$VPPI'ǀwg>I\؊v6 .ndQX(x7eF!|C$a TUel=Nu½Tvst]U GB4x^L,{ 9S1+xM[cpƚqz9,4|RnA~AiL4a%{+ޜS[|ѡaoimыE_Jz۰Zeuۄ쳥8=4%65:򕹠IhF%ϱ o"R-{F1E{EњG;^3{LmNuݬ7 E%d*$ratX,0&iGNuO #U4Ufxvj ֻs]w35JzTwSbiUσ>.O1&h9iવj%E wAa-5&NXj~+FEegjG5xRV#RcK2!/vh`>r4l-]21ɝlKBjkVŨ6YEoqk- gq̎2^e^LcJIb/6vRx(u|j8ym=8(\ e9EQ Tbc_ $+dL^B߂Mij~![<[0v|+tg;jj/<$}Um%@fDbc <| =tTL "j -wOջIOc-H p2Q *Rqx9[>7Nj6cBE߸QqzF0(԰/s.8nCC|\9B܋Kk;{czM&J8>n{ӋjX01)=&O?'uB )R4B3 |fonx#o[24 B7\D&fHDԩmџ[ &%g+>d2>`9Ty -y_UT C\*.I\Nd_|2<\n ҪW|nz<4 Sݪb ֝fyX"tV3^Ma]5КLO1 iF;e:2I@shL^X%RzgWR wb#um3,+[ʅ mQG1 K h&Evv)}rHq(3o1,Տ5 7ZWV.D.+6i7h#Ԯ@)Gj,0"O2O|evKazg|՞rG!#U>3ܓ$/25܏淩;}3]nn3p>&aJJ9QR}!xSpfbo#kxp1BXT[r+Ԑ=, bU|.bh0]ȥ1yQ5F04Euhn[O5Y2ELȢ9nNoCG^X;rֺ[q<RpK4R#eM@!:9@k8k,e4@dM|y㮩:Og E4kl1XՎ\jk84rRomMgS]ܯo^Cdr3=L3kHF/aT+_pf1׃sx, *?-E-\@ UݕѰ"זu3T+^j5`P$K5 ) q$]W2njT셏:vOi`}1j>Y٨GHZSF{h+? NWDq5`2-c L͋u'{Lm 28j;;Z,(swXTMUHm?˸g9nSFMOQ-9(U:6O%[z?(߇oؐNK} `1:cG#TII߿:TMPQ( .AmT9wMq]tcnB_nZkfw(/OIK!E4u}eXOG^b|qLɰfHqfEHĭ]AVDEӡǹَ(5\vCxj\VIx;qr˨cB8a?EOXPqV%A4kB%Rs   ҙi#f%%I7g#?чDI 9K}F3 "=\4v:ò+ 6pkN>R뛌DSx#Y}qOE=|=d0zOLU*_8| p]JQSΙaTL,Dz ,h`,u xo9ˁ<3g[t'(@A`}T3qvkV;{TG- |5pޢceL ytsk|TsZb{ݔG-zHw[jiBܙ6/XIjM)VTB*0" .2qʊq&`zd99DȃYmh){vAڽ65n>mw G?|Sͯeu {#7`U`UrXjW}\t#W/$ٌ;_y9 ԷjgΞ[C~V-",_̩q fO+7˲=T^ˊW@y hP3C#PmEuqZ@~9zf !y ­vJD3 X:-yY0lEcK0 DCN=h2RTV}k-t k3Γ#Oᬲ,L{S>. RKsk| !+]3ҰuP}h^@qwI ty߃l9͚L82] -luk/;Y;o̘k=ݏ:Ep[}"oR(|f[ c'>ل)s\NkVEnjh*<,K )>vH{ˡzP1x9οߞ҈-$T VdlˣFIǼ_2$m[#d"++u~QtC nkwXq+*XB ΖNDCNbbU*@6R}8]8o -i=݂^r'Wvw1QN-ñI7BI,wOWm|=d3.>Zjsʿy"ơ|mol[:76c?=')2_پ: K3F .Ne\d[Kk6TKؒ-lHW _3"DDZaפ G{ĨDXRð|.n]iE_+pbV;gY0w$00JLrʑz5zֈP+% :%SO>[A 6-V YkKь$ǡO9?,4h|f"ʷSxy90St%_ a~ccvQ co)̖F4BQ5‘<*W[ԡ@/·hmbCTfL3:)\V q5bZvMH laLPpAܘ~prOg9;2~<0c7 Pkn+joԉBcM!qB@P65"kzFIpk?BA>@+S2SC&GWcgfh9g_>^zΎiN%9J;#@YDߐ1~ƍE](iHoRC0JCâI2+Yig܌aY彞o=J_1ȗ "\ٽ+ j^'g~>rߍ 60GŐW+~SqQ0iU荷⻕Nۚ]BtmBl}Fb s4܌_L 4zk37fv1 fd"FA7Izu&rG_H_"9UX*4!U'?$"dLE8'#+I =TP\`y\Bx`\|P6K֎S=QߊsgKĜ,7V@k[ R` oY6n#X ,ÊQ(" 24^kB !-"-\9( vںAN鎗:`q~={ibON-Ӟ~ 7Aאqxs82Hhً?̸"ԴL{jkxq>R6n יdZJJlAN(8r= U8qv,,@G?qn,4uZR#GPQ$]𹟔jZEZS(,1iE_8:Ӷ{GP" \[^pFw7="pɥ*V2]C:' e K~Pӿ3u9ygN(Ks&:6E:ٜq',oMx )SY akx溧9B2T`ݡ. Yxg GgiUs`_ƒy@I:& Gug3x.i=~و8]{CN֚' L94@S0^!t(~r()aIN?i ?zXۿmlUȕY=6FƼ@iKJ$FW8(G,>q)lYyZn{asF3{ ׭j3pN<s?Gr"Ūɖ2v_AMN.ڤ ԉϳWWnX  M5AO1Z^ VsPÂ/|2W='_p>>5 aRݖmBr .!ZANc^٬ VH(6=*.Vm,-3M"@ bF¹?E'.;:gg\- tKDڙVԨD7˦֑{{&*^" Eȃ@n$Dnlk@fJ ( iH; |x~_l4 Bp<7M Ğ`Iy O͹3.D$:p7/F$Bǔ?~Ia鈞E3ȺQ=nԉO@4o=ɷXW`Sn0L%*<|6W@ Sޕ Yi"}>V RyS  VO-N[+ 4B*X$B]:D/;n1A?^O !UЏ]N|#;;pgk>k\V.M7:8 -EمwԸoV!Y?]>!qM jК'..e~5"V[AjT]Xy^۵-avuNL eCN+#԰ cе~j^#,, 뻿GR$|*peؓYll{5&ɁV_ i>XlJ {G]ڂc`qRۭB<@kp6KCXq6M'c03;1/+ p]6@q&.x$v\Dǁmn?cdږI̬׳Yc֥+?}@" 4T_՜')&|ERE?6 \,"^]zKJ6BoR q[ @$!$~8i8Qvt%ڔm?y>]awϚ"'. zki>pW,Aw &ƻ/]L gO]*U%e 2ZYi!t䢑>H@"7=ȍd0͎'~$'<]Sep(.phRu6]x\P42LڶT-JwbT2OJIrǩU3ռԀx*]jXR@",U[feGZ;aͱD6"*RCm"*k](HYne%h\tr6{s{C C$`DD0JC_zsЋD-9(s7q-)w8*Y|G `b\ʮ96ڰr.dc~ #N.[YЬ¾\R'>x:;"<l7ڑ=oQS >Vt xf~p%OpT(QzC]1'D> /VqsA ɮrđu>c-76Sɴj4wb5'ܻm g2U>̿c7 (BҢ(.%lŽH[zE9 ,1ToS&P,R4܍Zf{5PqVLIF)0=Jlq1'"Zs"fB J(q^WPDY)ZDOۨU$<|*m_i74Ny/Q,{Xt^ %T`BKTuԣ2+xCoR_~ Ps|L̷2}ӿ"tM K©Ykv,-\vLoݞ[T LC=~HacаWx3AWͺ1{gCR5"+:Յ桭<[ :.G%Y6c~Txm:w~R6l ,ઑyE^.f;9W>dY,yJ>4$,FLZ{כC`(FAH@>@R>7j{;|3dtEe ho>W*"4ߌF(v2xYm2:BTb+ /84ߟo?Ch*Sa<*۞ŧ`3<<ͳ%4YC~)Y@IBiμ+Er{5MM'^eRԾf^3mBDF2bI' NEm#qCgU.4l:uy ̵+zըHNʣc!r{"~*[c(Qsǡkd g<_2[2^C#DEϧmnҊ@"CyM0HXYP\ !k x\ ^Rd\rGyV|ՆEoL[Vqr'd yUScIOAݽ|faq{Us٫y&*m GŖ-4G{]vaXw[:"(G6A/DU)Hr /0^).FD6~+"@~:kI zHuKVIL ԥ]x 1'LGi:@?6r"i$_8V c/lJΜuÂK Jz/U%oh/k&Oӛb6&Ң;LQUC4+ʑeS5nt1ՇA);e5; *cE%p4MSV O(^ @1>; E||6ϼ5El=6rg?yLmVNFq4T y${eӪU4l?)[z} 9,K;Q ;@ju SP6ޱg._ bgkCķ\M"Br:8@eFm0.g3N6)vPb D$?ZCj`d[3!B*egpxQ(fYUtiM8S$fۿUk)-S1sR 4*ؑ+RLrAQXutfzѣ v)t;YbaMsßYpyL/'eK- EiiuDxTqiP ?`\eBB*]qwT[*e k8`'9̥VHO8>ռHòfkܐrW(U J~kh7Hm36Y٨ЇqƍKUn8k Yi01s9_J#oSKeQl#$:}?bKװk$;j' ֋B SXkMX%埄㷶 f[Tr⬒g4ąӰ-B܍8V捴V,KmK;r_{\3B}t'RJ \(icf ŀ\)̪L<$O|7Ac,5 OeсcUӘoT8 IS8*x~YWSOi%U * ݂<Z3JWe@8Z */8AMRꁚ`y WY:pꉅ>^ź&h޸Kf b/M_q$5A0<`hWͰF B8lET i%(ʧO?_TL=Q,n{Zt# ͮJR5E{ڦc-͎AZDMN#D7쇛PX\B)cTI̿BJfk .WC=_* 5Ў8]cJ&|)!az]6OGR?1ۍjcS 1{u J.ۗ%vU~hA1%X|5ugۼ= ۖ44;|K%w,HY-*l&a(܃m+]3ze<MtRcT~"fA?*{_MuYk& MCNM&S&=^v} e\< 6jZBs*)PO14 4a{ZV!"eORaF@Э Km-W͸'m96&YxAʳz/2t)-W($.ĦY^?7M̞eKFѱf9vg$t+?Yg"R<m`';fZT-ZGX́7)3T@u`3m@#떊dq.z1ffCK*1^7h\ ^{\UQdP?kDX6ߞJ{pj4pOf`jH:- zF,B&f(g2ErRV::F&.64thI RdI)k?NaW@E/T|md?d5ZSnx.Ъռa*TShوOGԁV6 ɩ]OZEWԩ&!XSV1dP! qK^G;10憉r\q>G4vyE`|O-5 %ZZ7e8] fGng\ g%6V4\@'rc5̋U;t}ׁ,,+9 hJv)Re 'a¥v瀏HN>{a즑SXyuަs@!(&Dbxz\̱47 g|_DpYc] (,=}L#s_,~a#"kfpmY.`[=ә:9rx<Z7~fAZ]<X*q^gMv\;`/"\.s09"97|XzG9Ds1Ik+by"'V -ZVXWq>8uT@ˆ5*MQޓd7'"F=PC徂/nx~5lpE HirFӪi6Pe\uM|jAAK T[1KJh-C{`pPb瓙iSd .ƄtC5= qk cg?8?VBJ],wmg ܇{e.w/蒩3V ޓ>Գwcg럯QC}|W\+ȭ8j+Ϲ G 1R22= /Q84@͠:"F=:۳ǜ=Wld"Æȑu Ezu34ڮʚ@,qf86 fk~,%Im baH*X/Yob9m7NN(~/3=`-dwUOG\kn(@A~KbZyeR7&1$GLy`*J03*?`E!|;-N_T6^ O<5 C>0l׳Ww*jF:U?IbܮD11 i0QfW֫RNE EO.7K"<\lƘkdT#S +euPՄE2VΑუ6I%cyMH%j ,I"9K)R3*˧ZL2 ~&=4i0̮p^*?$oz6A|Bl/ 5D.Tޜa.G`E-rY^3Ǜ)/rY&)q% tY9nN| J@4R`&mIӶ9PHs:ΐK~3 (gW"j}+$&=aY3X`P6׈.CZGA`6m3QYhP"m gmYrzĺ.y @1=^7ʟV"8a S>#;:+P6òFa&3`AlwY{c }HzQ<响]T ԻsI ,XPsn %t3Sr'S#ҠEf Wxv6f-%ys`a@ c[p_:<&m>leλ 0?su P!͝H8b\6rT^ͬ6W֢a|"ȥ&FW|6%PwĝE R_j\J6dP::M|'^m%e?PY*'ʯbN,5޻%+dn(ÙEYsbǹޥyw!c೼?h?3[-5{ k~=͘6׻rsGuV@Pq6+rZ1c)D"@]ghu']<1/@q)0oR3:aɘ%%~#+pGq`GFZ0D~}[\]5M5y5(v8E(Zf8mBQtn 5s@>lQW0ɬb)R^E^:@sL}'^}[pT?E6S4Kk#ypM~LNTDyO Z}Obpnըz{J5 `|~Zn_jT,TRrN^.H< )+&R4WqɆT^!XvAN4 ۱MMa˹\jy4jJ|ۋا]nRR;+'!;R+Q>Gq ܾt{ya\IhT}T=[ d3\ҋY2`P}vJQu[xݽ_M~ԡe|yqXōtExEWQ8ŘnGjwޱҚh޳HuE `"{Jv)K'{*4( 1 gnIףNeENp%/VzlE gп><]݁U/ 꼦Spx3~QOԫ,#-'O5 ^y\2Ӟ]G`_,HVt!oAkP*^3 Cj,Pc= /fO EZ-=`nPv؞scje#ǓFTj=z%* ))WyiG>^JyvnU,ܳ "4,a^EaO}ٲeu! #v[y:h-Gy3ܒ2ij'A!vT]7؇6г O8.5Y^_ȫpy@WmA "A€עE $x/7|y4n]t`R&< qx~բt B&?0vr+z'ی>1>-Wi@ b䜯 7ծY!BM&zr/ #w<x dнyZnFLuӍykKsi|'\soVw:#3FnXfë_ תCdvv:U1&j'Z&'\sLSѠʳ w؟Ky~W٬J,Ԃ94<~h8OgɖV/%DH]zhU ·΂gCFAV zp>i"EVx2;&O@{ѹ#bH:udq[]}" m`x͗D 1kUD΁ɬ"!A%k2#"X2 piW^>pE\~(1Sa؃f4Y j ϛ'c^5gMO5%(f_,b|@P^mv-9Z֏w~D/H*2^xD=8$MyXC (+/F+/3̐XCY,Lr[W=ѨLi>"3Uql;a,q U]L)oj~2jsg}b^/an2vtߖ^4Z'6p8ҬkA+ߺ;RAbJHg$=h=hlq(X cxEJl槷 C}e`1oW<o%SxZpu9p+%Y{E[0ٝ+Cԡ3)I'M,sFiv-L^Ҟ'Zd|^Z٭4௯ 9zϸ/*L6&exko9߻ihL;Og=zd=gC}c~:"ǂ LIq$uo@@4[U@cix2 $%Qs#5:`POO{OK=UIKDPܱI\u&u:P9E}9(m7`E4ϧW,wLF& &> tYE@=8X1cN 2HbrZGk:nsPֆQU§=?Mݓ+t ;Em FB*:Ux:㘟@I'k>Sz4k&a°/~_x*amk ǡ ͪ˦+wt.3q処kQY1y*5rRڪޏ~>Mv5g(cZn=E= ƞRS8AugG;SBMUkUhdzeKq1s#F^E(ԷPp뱠]p|8Mxa4`\Iԃǖ>>6FVH;o~O+å&dm,ۖ PJL?o顗.V RT&Iᣋ mxjKh@m; .MxK}*J$7qrj; 4+.= JeZ WVɧmZ84barVQΰ<.qJ-?s!N^QqB a !᤻9tܒwS: Qbs^v5^1a_*ͦqt!y:݁0zɊ sGL]6ulӅkThy,?Pת]9>|q$r#!=P脮_1R8aBcI8rп4"IC$>F dҍ'.]Jo@^*x ]2[#;@ݍLL/#f/jl19=PM%YL p3Z|9 Ml{bl!2J@ ǚL#*b,]dab$I} 9sTגuYN[^@Р佃"(ЅaB" kw>e /u@'xp$P/d$Z0;5sA iR1sK{³^VpjU&j^NSָ/TKqZ2 ls12$hб>w|3,O({}K%b+1֒Ԉ6n%"~7vlY: >SCc/0G5Qx=:>2L]t雠5+E?[hʌ2C/NmőD2MϠ*V9I24`Vz,D|^]~T;kx:Sn5(@{Y裏ot+FKdS5Q} \_B*#\&͒/c.{p] 01qDQ.CCDNVЁ`3}ML/-.-CB2Hg`J*+2ȩ^[q:GHԻZ:2 fmepo|{wGv }`pgݸBD{Dd _y+  稭W׻6$z6ɺkE!.Y} ( J.JkD;EAϿ/YWoű[WT.B_biP-b0}Z1;ޒJ{ \J$0ʙa6T+w~P0F" N f2hyo<06a=8ޥV=hKesEI^TRp}{]<r+}a/Իqy\4悢"PC Q=^Pb3Vl*2#fU|J"a7~ dw(rf搱! քvK6U0b1!twa!aCZ?(2H^/IvPߵ*aӽZǠn:cr2Jq GQ&(;bK<{xĠ2;yyHZQS1m+/Lv *u*znjUZߏ=VPP|*Mbxofi_oMsyN|z,#a>LG6;CnfBMpIc։܆g?Baa[6kC:KH>E= @?Q?߲}Z8m Bo0H2 h~CUA&ӧLJFyO;SM[<}(9Ks$qU[`< :3ذ̭zȑ1M}ҷ %g#O\r+r$ bpdN;qoZe !lQ=RlS c]96z+foB!i ͿeCpNb@ROpŁ̏tZv}=95,FQ 88J$]O:AbN2H(+r;;r^5耭w?ۂ:{rmɜD';u=& '1>#nD]/kL{Ǽ?h2Ljx>AoEiTC|oAo+fV!9J &+Ӷ7kV*3ϔ` fo8  <'g o%SmuC?8MG"*J c3X3f TX~6 C?!T 7/Y4)AܿBL GT!Gǭ9U_ۅu BZ sßYY.]f۟L* ӹ6t>Qf8O$FV\l;t5d4))=]fѯ@k9}p~]|Ԕ޹&zڶ :zRLv\Dz^Q#LXUYg8Pq/޿A2EõchkXs0J! XsvYWM8\rAݶU#wS4ݾGrO.,EE`|v3j-Mcwz} g"Z5)q5[/feI8>;X~|+bR(IuTt] 'I+AnV<!r:Zɩ:'Ѐ9H#Eo­L2tNoj0Bje77$ʡjV ý^ AqYa9Ce[2$ӨhQi[)fŐe?_62_Q뤲aܼTZݾ\osX .|ibX\ie=bjاKH^;S 18T˭2M#3%.OyY aGXdg g,߬Y6`V8(FՊ޷?@YC:)\Ĵ +< yz5.˄9a@ ";; YwLAv"/b"DƫwOqAQron1~z0=X( \z e_|1?I9!Uz1Jb}.;ߦdMAr'gLWAį ,ڨģ8[ T'`6Z/qoTGPϒ|c5#4#֋ vd'XL}sb#·S+I^!?7WŻlp\x$w`Fo] I;zĺD?,Z $_plpÿ4G* 3 -1!Rڇ6v .͆[Z{ [2 ͜P58 ^ע}˰B\o_[/Fr^*?|[a w>J~b$$Lԧ;dj-4ƺ CO$ TVbLtuİJq+4@CRU۽ ۸a$surGC/F /҄sX_üG1?!tnr 4rQ`޿ ͡E/쒨=Ol֠PO%.RA=Ѩ1ԍx8Ž"\l.v*.e4JO8[2dpYޗ;{ \JQ}Fm%̺ 5c+B$dٝh(֋,yQ$k  &s̼sG9hY7>OfՊsK1eL>^yCfXs%`u|۴FP=/m-ґЩаr`>vƫKO<܋7rQV(trDC:0n̕G%7$=|=<.8'}&:\~ceKyP6]̞ cKR`A;FCj>-1*Y:H>Œ$'wZ_\4>nfjp\[%M>/Q&IFS(yIdܑ6!:7#Oh4v?boA_5ߟv'; bQխf.J4(§,rU}Q}$$}* (h3Ω𠹣dqf*TaC%٫>h*\3Lt*{݉h|g6SBd%8W`X]ܟ( >f0SYX%]|ƢLI)qzj͌p*]j []&(W)(za+uraL~YޘmR(~Gup ɹem@6z&뷺7i7~Gݺ8S=8p3:H:N VP1R0MˋaBSo",ٰss=cy9NS|T/3;F?;0EPR( kb3ǷyU 'mXY ót(QMn~:3(f)r^:)s!0[Eߏb4(8(j((P~5s_&&0QuX+x<\ 4rxʣrYH)7ܿcg~D?!;t*ܓJq oY?z]:Xn=Ƕ&lyփ?azEBKWR["J7;mFifcH^t ~{*[mF:f{Jp<p%/g& `k>c0%}rBx-@W&$FaOa,C0+7j +W lk1>j5 s/KhΆ&8*W4f7Ksymx그ԼXFg2%dzXRn x?U]:gg;zRu 3-s',>_D%ъTdwMd ߮OyE" TXվ(#Bq -.tmj3E9d?eޙqVȁܛ.:O6XĹnӼ $&/eMsiݬH;+S/dm%e(5[œ4F$v=\6Dn 1| /X5mܭio#f&aTQ'ûX4_&cZ7 ̍~5yD/+pI9Pc &mnR~蠏?O"9@5%ʜo#v{ MfhW THfjV@/-q7#v`tOIQ8-bpg$+y"?CZr$|*M\ܬl/uuL"6)nhEo X=#X-u/G^Y49kx*cpe98#d6X^[; R?_҈f܍9B 26N޿T_Rd8q§Nk}M_%OØ*A )f ,2*Fb!HMSC7k9Ey9iʧ0zn WPLxz{ĢBdU(XmT:`:qf*s/P,]씩菩-0/Njb1xśm-=Ա]x%nUGM./xV 3RJ_)]p Ε?o[VW#&/}v)gG)IQ{W&fPy&UOr4>xVE4rFa+S喿|e1ؽƆȰ- JCOWKϴWIE|˶Y ;*cX. `̒])na!Ew0:~Bs̫g )Ƽ~BX֙qQ(ׇX}DeT֣b6R}*9جRZ҄S,VCpw|dVב8Q.o|9zۢB @Rddl$HK.wHioҪGy=fGNn`;De𡂹H 7co[fDS3l!sVV!iǘgg/ Ęwuv èͮA.ˀ^ۭ#3Y'1ڷXaZ5kF3&FtE~RD─̙I E=#q6hc^DM֫S_cJ}I C4:L$<C0OC8Wy]ϕ - kۭ9#ST=i3~Dh'б/d_"S' .+jYsI dd&{#4}w}uG4 ~&x2Uo-}r[GەuϾ7׽<OH拝Bb;lV3)#~1Y|S 63o3IejGW B326XԵkjFF7Zk💫Z(E'OrީiwPL}]̋խ "H%HDW_ ({]tݎ[ ;&R՝7x !{MNF.M;e ׊/r9.}xF٪\7:?2Jn.+t ;Ga0$R͵OC\FnK?C깞܌~]a34*" |g ժpQ-?C.w*Yh,_4cp߅7Uщ㞃gwty[v~,4D adkk観<-wX-姛0_\Z~{2eIqmD~C}FX 2!^on\we]`@.=ʲKG}1?,Ѯrl93ޒ?8& 4!YH8|KJ^ҋaZ+Ӱ3X j=Al>ʙRShn# <&=]ujAAUh~O; O< ?%1h+!ZgRFE^D!]U)%D$9펷 6'Khg|N'cM.H0Im$xcMԼ%gaշhXLhQ]t qNL/թo";9sCc_[wǏoj/ t,Ƹ&q+>:V\Sh'ELs)HY,9I/)~o7Dhrʮ&)ĝ?_&Na `U?TI0w,r]a: ׽ԮR+`߯w #5">_ҧ{=]Op_9Yɇ'D4Ei!X501vIyWRI+-<#GB.gw5Գd "sZw}Jpq BX؃;l'z^`k~ɫw$uh,мD2/OZŷC88Ә @avoDR9\5v"4@}ŨgʙN^$a$E* 3A#fEeA 'JmrYO ̶.ax;ll0_cYi&џL>-"8*҉Rp.l n`ٓDI nÍ12c=#. %~j'")K̤ޡ?YbƸ1pN,i3ԝO)z60+<$Zt1Z22l@5޵>q`yEHc7ȩtuc6Co d3@sDVw&#ncC9d[3&^{0U mTv'm羹$?^10Y,usN!aa3}Ǵ|baZ?̮C7b\v. Pe!cf!I|7(!_))Pپ rEܚI{юr@#8ua 0qEL2@Q H~k%-Rm{8LvɃ~RcBY>ĘUuh"u/39`W嵨 b5=a4.Z&:TJKHj#GKNEjF瀹ڋz) *nם yCiњVW!k=E 0Rp[=f@"W!7kM9 NVUx},? isi$fm#h/|EKXJ0d㛮p5Wְ[1ZhUORr &BYֆ\oR@@!NVY/h64rB~skgmFq fT~'}Ɛ[ Q7- tDJt*U ZTynojzzSmn/PBLKv=V~Zm[Ey2+Gp;48^lL[x]t{,NUHcDLŜD/11:Ua9Teg?r"d¬g]W=EFJuى$d#b^ul5.bMJ.lMENI5rϱ4F$0GfEeWK2YƵZ-LI5|EĠFqZnN@aڠ ;6 Xs?O:*D+'\Q BU{F#[>2$4]{H(:9}(d?3tpH"3 UxDX5>,4."N[MN!||L;^ c]xK~Dd)GBʤ 0*>kق`4 az!U.F>{K:(7?T*RG Ay5ҁD*t lqh#+j׼e Fa'5p烖e-$#3( Z(X_sP {fqf0|ŭ]ָ=!e6=|n{Zߤn- @> r|;AC PX]ùn_Oqf"GAJ:R24VfMRx3E& zBRcYs Qi3oh  ǦVHNΈփz3SLY:lՌv;LFԵ16)Gӡ? n FF!Np h&#Q;Dd~k:L`]WsO6Tr]B}J[]B}k*zMfɮ=o{R2BFEIU|PZ;"7.+@CGҭ#3HiQ̚EӚUی#`Jf%f[ߺkK{TW$_9M$ssJw&y3XkpVFű<۴8qCgժU WjCW֞Q=%Ltbg A C \F%ρxzɆn1WkJbHwC R7N@<}JoWj&k]EQTmIߐ%U/?e~0)TwLhK&`k)+1 }HHMKh,dfeK^e]b&|mG m 3z4M݃`W&| ,գ}sw8:]y(,L. R DʢP?o|~-as 2^)|?~5iuOFFG[C ' J)mIDn {ݘ`cj Zs#~י[qm-FНq:]ch"_dža`R܋[DR[2vkWvD|hD6t֯x1\@%Y:$E;g۬mS ݷx?'ޥ: ]'?gj0W(ВU ^!\[敾h[9چ(gU v謊>,|͘cD,|TXtXm jQQ U-Ԉ@bEGH_> j 9.w_\{ނkP@| $j<YaQCѳ/cĝՉ2PIpov*ђe29(aOi(RƃM)mg&i£ڈ4oJg+\~ e.h"+3zOG z&0p׮r)ښnc!. 8?Kܞw#2):/^P[uGvQ8Uzq_|A~:88\j?5t#MIyD/}.@*W@U^s2B=~1´6!cץ,^?EO竞ck 3/ tՕ*k^9jK}F&6iUP Iϑjuy]ONZ>=^zEdÔ jƔ1/;G\3o'f@n gwԎlJC VJhL4V+@3GN?dZ;IFHs ^ATʧm | v vo00-uIJ <>"ȿes|@g9UxnCOH Xl+JUSFc*7&!G9,ڂ䪟<5FI_L->!Q[U N<9pR}9>o>amZZn'+1Q ,UQo r[acD^򑩘7{kaSKIo!~GLyw9r\UJF}ەFÔ"'?ŧ4 V2: { 0b6YlNg/ *[\5ҹ7,֑q b=8@5euQ;0@yx/yBa@Mx#vGCX=ͤ Ji~'z6``|7GI41~f皠n#wkFGX2k?<ﱆz˴CdlRA=Y]'"'|X'_O(?`whu* A*10or~n*j5+FtNo\nYwP$t?G$HS R gTsjjxuGJoR©ps+kpHf "[$[~39.~3 p~G9Y X<8&1܎Pl+[ L{u;g:B׃ƆY%;tNǁ+k!+)KqK('SS8IȖ帱ӉiAa6Ghdff8fko}U#whYpZwT( f6'ЮU}wJVjyX}A⥁8ՋFW'YvsюnݹgVU+$of2ý wO}hsAOfV2횓1DTg;gI.J06!S! HLʨoN+Xт;_6\zEC:{[ C!߆MPo)8>ԅJ*(#5md=dۈL [L%ԴZ{UP"DKri)+QW$l/(Ř6A5ibke/Z;ш= DB=[xy!PfBY]p4j\ Ve &#&0͂yw/t>d}tfe5,w!fr1\W.'$9syW#×OA,::槺`k:r+=Dn<苅PFFS[ϏW;ÞFa]>UWѵYz$VCZl`! S7Hf _c*xщ&u38_ѓT d~.v~7hVk3r զkA3gP1Kw4K" j0}4 =A` Q`Ϻ+eNv#e+=ڔG1[;_.]lj6Ўȷ5a)Xv7Sbx@/6cqH\#uusmyf8: vuvvEDS#B&PC|V\TޔBS5`p>;ͻ9{nMcTK%#DMXl2YjPN%4n-l*a߇xqϮJ1 `CK~˪]F4CTK/!Zorx>FlV1! OvFW0{ 7-zfa^,65ԂP es8E)o?s;b(tE&@ %f1!WU" (#OΤ"I /rޒ_[\Ds;2y 08Xn+0Yܧ)IWH԰3`A(P|"_ vo4#sRA ^fUR̖ !3KўRPUo7 bLH2ACY:W8R$&s0X>]P[oK:Ԧ;"!=4<77h Xg3ġ&Z8C2Y0tWY`mF:c52&ʰy$,zxpU&69в,se )bg·P:(s78rWqȔaac.9Z2+POa)=d^i3RY@wkVw&.u[&#y>Qi&'|ߗu;aQSP0"R+14u o* K#lr^d`UWcoSe'q4*mW) CHVy \m*rCgs:uRiȨ "5\MKא嘶UKݫD[\e+?hOiP=+A:)o\uF"aRY@CmUB{p:<>yƊX>>b67{;ln1nODOa0n&)Gkhz9&6Ԅ RHC?d$9;jLϝq k)mާ4,j.g+o軐W66jL˚FHg=a`U"i\G.ߧMuH6EdI1^/鞡tʯk-E0w 1̈6)iI^=nQhruTilR1Ov4_ &ѿH) C\:uߚ HČDN{P kTZOBw~=v|(f:wT[ -Mq#~8_pOc]BIp&q˿GE k|TbLTܿ\0j Ned]w[_*ٚ'vlC"NZ2@y5WwOÙ.>xKtx^c.A3\y] -cO3 eo `+4t^ZJl~lm',݌Ԫ?oԙ|xC_E'~(>"[vy0OFXfB||}`KG&l}©'Z-FW`u25i| q1ݍr!hqk7u)yh0< i vep ,8e }#.jL{"YFA>/1Db#*t( ?* N25Т82  W5㩓.#UvӐ5?wZ^ 肍 b> _d,{q"u^5`b^sO?HqP+)§GKf9ݙ-|lh)BS~9XqGCJC`e%FXߌʠtYOE7BQOB f6]҈QHD_@]YPmx'<,ĄҞ%'`q7kU S?]ǁrcpKa?dϨ7 9f5$.Rc/0eI` K|!QQ*?( m*݌WPZ`̅g2K>%H*:ymޱEsIL&Qп6@ nVU f`~;= ]+a@0y&(]v5IٲNXeHjPMЏo(:C:zhq:Z$DZ7l! 3ǎ!`gs]qMA[{&"A»|52uSW;-쟡WiB,_a&Í`B&/D/޷%=E ds5],pKT6}:kM%yT9'{B860]h0KY7 k82zPVtxǑa|7Grq·e"2_?;j0B5=7.E kpJ i@k>@D3R[c $OUwwBJI36l`0n:mQxؗIS:|[սEeTX@d4BXպoeɈ-*矺b*4BG3Q = >}a7r)N֮rxgcۮ"ט|e⓼5:Q.uyC{( r}FM*5=Ġ5K,4b@5צRUdOb>Xt*j2+,sGx]6bPdRFTL ) ;t2^AWlYrr:x{?iEšXd{a3k'S:-*ڹ b￴-E߬NhyэdFaxś\"S6,h&-8&fERwŪ\gXD gzj7 KLشD7ELMW/ԊxmydE#\X9^_R1M㉫Rifi*btPU]M6Z{8"*`+k V4ӫ +c-Ch`֎X@%&vw\xT P6=N$HlU,d$14fF{Mfv[MXj`)dK#,0ԧUg-(ΕhQ#E>FGr{n0<7 ^zfgs4䉽X:A>7*ȤQ\I ;{7RSp0vc4bjyHUX#40sGQz׿duaqfl\s7Zh@+\rf1&Zc ]?s,-': "3Ț·ARa.(16p6 4w&Zs4yYT2w#545M*jy])?) qFүM(?0 *_@8 '/#E*f˪B |nrylb/C:5;u6*b t_Zi؉N۝ܫXx;f</\14pPE0^+Ϛ~CϥwQK4%WՁϔFB: p͆Z$TX=^(_y+%#dd&@SR`3$)a̕m/RrmwEu q xGDbg i9v$zCDK ) mG¯eO%(9di@KPј+]J /H_8yN"Hb0+%R:ͺ$C? #H٥^M];ޭe6]Qz,C*MJ%0eԚ#y)GlKHYr:=oV y!U'"ZyQ󱺆esDwU6u9eնvGM'~wjkk|Q\ȀV3ZC8D (U›+u鉈dtW0>ɮNNwߚ[$̲guB '~*E|\`Gwg!Ko[(D0P7>/ZfpT^z.KRUI^`GS/Ywy º4,R(YR.1:oN!.`iZ y )exsF'b" m= !N]?9~d(k Cx_ >WhnRӥȖ#=IIZ@ مd)šžn4MZw{~~l]Z̐NwA^}PjU%x`G2F75WXO5-|.IuRڭnduRb>P秴*+].KXb ۜ9#00--q8괛/30Lǎ\?abS$,&]!C ֙MpT![B(N}seZ78A3,!w= Sİ.1gVOͦE&]q1 ֘M%4>w(ᆄt`Xܶtb6=pD71> `ExZU?"^,y/fV w;s8ƜfY rp(u9.KKYuOiAƲNG>~b(Q՚u@jLell_6/l.*axAvlX@BlnyMe6"@R2Q0Y g#0Đ,bIF7`4) g7oy6ms@VWtK(8 #̌<:!6ܤ=bUE(^Rօ@N%A,_ΜZBFݞǞIPT1QFZ(f6c6Gw/f s#Ѱ+]Lj@{YW'~hP]5OEl/>Di[ v cK IRKVrs-gJdorstƒ~$㸸ҢA0{P1Xt=N<As l'*4уb~In-8wGȂ>vaŐw)@`<+CY5)5ĉ7z}dΣ-EltEN7I;R :KIpIa3$T%+6ϭvB.Y%GE9Xd FH;/@Zd}6QJ>w9ԎUB4@ dC{=_U:lYpbWNR)Ϊ*q *سHG.yx?w%/PFK_u/y3A1X+G$L3=)>[ dC$ -9*ܐ6wh߀v%IFU lȋ&\>~.ūf%ʷٿ(sMpE h2GjJ=)U!272^<&21yz$32/6;/MNa.eld]byFXkŭ!y JBh]'q߾65.QNZ>0P?Xoٕ1+%]ז3doi GPOǵۓ%q~u+ Bn.;\Lz_8Gn%X&=G5,~9?7'gʌ)߭܋rxсoKC iY 0@[ABͲ({,#x2~wgzO{$VRyɅW(,U1vF].N;}}ݣ+zٙLe!X KIx8]]ZS-Q@˸#_VO-B3f8mb W5/IG35J݈;]8$arX%@>#(0uWsSAX"B )4[+|'_$GX]eb=S.Ɗ/:ۻO*Grى!anB^?c=,+wF &~Km$fn nĊ6=8(5 ƒ> r0Uơ6j2B^{v'>=i/.?lFW?ĊuThdJ_+l<[U0#x,N}A#Z#Z" mji3Ĺ HyVKK)F_BR5-bc.j{א KۮJ̨ Uĝ:M;Ȯ;^}hq4o211Bqa*,b7?Ii 3AMs?:e[ STx~{>Jt1*t1fd}^R(]i5rIo4bdǖ)`hLEѿZ ,^ɿ~L8ZI0lT|mA,vޞ  ncj0%Ncgs{_w7AbѦT@guxXVJXS],3e<nSG*+(%|*K7S[p?uA]b-+e4U:Zh30&7_j\'aGm"#=iX#ع"wy%pҀ-eBCRrMwXBe")8UF* Fh}lERd߄R^ObXGU'V<ŗ_[ x~C,#}bMmC6Ejf֛ ,8!փ bjӏ;ˀO./ϥ5\CFCLP,.`يXLE$fڭ!lb4',N9TO*1`pS*yk-XI bj៲Ti3+6zVdƓS2)N0)נ*޵4Sۘ>&駖z`Zzڡ̨ [MGfG =Ţ BuBђKww3+A4/K[~WDW}r7 fv5P.X:->B-`@6f\´unqxZ*ZX?‚K.O/:?>Y]1T}ɍcGnʩ`#/4&3c$S0V7™~.c>V}z jY1;׼˅;{ 8)ʎewzj[=Y寈\*F%Ly[ڝx$nMPI8'ou+ Xy 2_/2:AS  l'3.x{PՌz yR?3OTOI=BԢ,'yKwb) q_'dac Em2g k;:~~U`fXG*5`,9Sf!TM ӜvW28^B_G; (x̶Hs j^w­H@ h,V kBY[ydr9;D-G)h&h%c:^Vnvgo㇟M8vs A\"4@utxcS^yv7O$qt~}̺rvQy'.yX~cwF`eNi(w.k؇2 q6yP٨ xn**tUGBΖPX򐁵d<,u2QPKU{_Da xz!0-b˝ (Nl˱W#qRL׆/ˮ;m?㺃p@cÝül0\K&">yF{\uUM.B+}2ƛptpwޑo\8sޑ~MǓwT/ ĽWFK1o5|X(;VRRbO!fV&wv_ wߘ:|ehA ɟG37-0I`s\*`X~:#X(Fӂ}}᪉ ='[yחZK9uc{|IPSa@=uw>PXzΉزWҷlJ U7'Ӳ.gn(=z77˪[` OV0: iPvR >@ +RQs@̺o?`uzG{yfhj|V=G?<@1R =;?}DA?7Qpi߷9wUiF*1!3-PHbz߳?BAXRQL -KwM˝qS7r~IX 8 i蹲QRwgks6iajy%T\AT!?ΠxA,ыIw5w0Te+~O6G@(snj~~pyz.n0%)1hآ/Qx?مס}~׳{;vZsf2 ܓǂf!kFQ'TWLZ) j83#oc}gw WF;.J1ZuSSãT%F{ 3)n`h qND[94Ȁ^}zȸyY'<>y. r^4aZD>tBCt  aȵ@CY|4 ?ÂY /JcPL((jp[Dm]  8Oo5u$PbFP-|ͳ^/["I!u;` (4>jK5)w ,VYUW s0".%j:%)JTDxZ:CHD][Ob6dtխj~5,K!zpJ)ҮR-)Oi֮s*s=(R[256id}Ox%s&M#edѣxs@cLH$EU6<;@_ 7X%\>m-z}PL$SX |/;D6 8ʂ;B/ȗ )ct^gYJJF먑& 7ʩ&ŐS=#nQ6&2 mIN3N"4Oan9Z7ev *L9d-nn2~`+N_~K<ʖ>as^"F%CHÞ{YdWFu ڡbDK̦~')GކrPhK YZ