python3-paramiko-2.4.2-lp150.2.3.1<>,5T\K)'/=„v4Rtl%U7}$B%Q}w0Gjp9eVJi5:l *j'=X&>H?8d % ;PT`dw $ > X  + +-03^355 5 6 (787 %97%::g%FG$HXIXY \4]h^bIcdefluvwlx yz4Cpython3-paramiko2.4.2lp150.2.3.1SSH2 protocol libraryThis is a library for making SSH2 connections (client or server). Emphasis is on using SSH2 as an alternative to SSL for making secure connections between python scripts. All major ciphers and hash methods are supported. SFTP client and server mode are both supported too.\K)'cloud1287openSUSE Leap 15.0openSUSELGPL-2.1-or-laterhttp://bugs.opensuse.orgDevelopment/Languages/Pythonhttp://www.paramiko.org/linuxnoarchJ<  ; ;$$4(4(II ]]uu\\~~""%%88//88VV))C;C;%%5h5huuEE  <<{o{oNNssDDDD/M/M2V2V``AA@@ q qP,^1|&Q{)(L3b(>^`#2ORQQ]`v Pf L1R!JgDAA큤A큤A큤A큤\K(N\K(O\K(O\K(O\K(O\K(O\K(O[\K(O\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(O\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(O\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N\K(O\K(N[[m[[[[m[[[,[[[[[[[[[[[m[[[[m[[[m[[[[m[[[[m[[Ζ[\?[[[\K)%[\K)%ZIOb13592d61f4aeed1db5600e0d985d6b6721941f08960b53900e4b013364b9656417af4da69d1a146ca38821d3c6aafd6f499cc9daa170959fd4b15521eb6107101ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546bc225cceb08ced5c0dc8d3cf3734b61b254ea997259c97d13bde1ef251038d1e547d9fe78273fd64c750e78a317b1a59a6f87ebb93d8d4cf9ae6d98a0f2fc9f9ecb0b6f48d5b3de730a167c5c77f785a80024a4febea1a9f326d4cf8c397a217e080ee4e9f5a429fd862280e5b4b55bb8c01305f8c7030a8298bcb61bea3530bb9775cbeb2d66734934b3a40fec94ba756ec39a32b27e7cd993c6b57a7d5cd0a24b87bdeb4fe641b6c99a6e00054969c8f130379582de8fd98f0c5a289c1e78b3faba0e812e104869a52794b1b153d0b4870acafd66726719022d38d59800fc7425bb0b0ce33ecc30a327055499b080887ca18edab3c5702b8cc0711ba9ff906ab3c4dac46de8fabb6c17e0cc4bb33d62a8002c234a5e84123e160d0074cefd750c5f638e680f6afe4a63b87b78381e1e188b1a663de8ca74c665ba5e805ae163b3b06817637c673c9f1d053def7248f598c9a99a3f2a19e250669f3918dea8c3b75f71a97855c2024e371e4beffc6bce32a9dac3c226a731fa86587a542261e45c706f90f0820a549fb54484829b6da44b9ef3db5186c3ed08b592ddea43fc0d2a450eb7080d15661e8ff88da25b0d27a961be2db5b459dd45bd7ac3f49812922a450eb7080d15661e8ff88da25b0d27a961be2db5b459dd45bd7ac3f4981292e1456216e8844dfbd23179f41e774ad851f4ebb84eca2ecddc799ebba7e925878caecb70eada928f42d4c18e2ca940edc51b7427dd9a3d0c37caad69e8dc67dee7a28594838f16aa0f945e5acfef94731995a394a1c8ada15ca21f377bb2f7b24f881a3fd1c026c71e8cc60695cf1fafb71fac8e02dc67ce2096753f51c1a772ac0f1e1982de7a0ef59ddeaf52010fa546e36728974c1cf055ff9c7748b66e1cd818d3123a647f0aeed151d36e24377aa39dfacec2d8f6f6ac5f236ecbaa902625ec964928799fded7b6445e87635b0d494d57dcbc88db9950ed0374538a7bb125ec964928799fded7b6445e87635b0d494d57dcbc88db9950ed0374538a7bb11ee91f89525b674b09e16fc61724f8462c4527ce716691b371c85ef1129305b7227dc8ec690d7f245fd3bfb40939ca6a66a9af8ff5dc45ed81e280313a9d017de2b965b509c7e8dc200a80a8dc000c248e96dff4bf1639ba511fd0b51884c8f49e0e39c8ffa7b59948f2475dbe34abd3f9611c73614c81e633a2e9ee3880a29b926517ca1ad474dc84c716522946c61841e8ac8271239ca3ac89609f19107c64c1f0f14e783ad9064c4d2a8784b20c40033c0084dc7b83fb13a06a6de9dffd478ace6b3610a97d3f7d874f1afc43c43e281c4bb4d1e378a6730b105e802b791c82352daa9b6b291d865e90640e7406fe9c9e415fb3b50d33d3503cf66ccbb13dc1e2ddab121f485a497064f563645c93c2d07e079d33f7bb4bb696dd9faa15de04f35bf6f8193df29aeb3616c719d63ca38bceba78f8bf7a825072d78930a1d72bf55be4d65564d1ce151a046cce339385482a2f8311dc041414b5d621bef46062b97ec0dd48c3ad44738daae342cf90dddbf91ec2e72679994257c2716d1397263b840ba3631ef03e33f00c7dda5a2ba3061f80003f8c61467949fe1fea680d6c85c7c9fd1b2b9298427de2f775134d725aa37ce890aade70944b55b4f807ee036e5ea1a212a495dc9c0636cec7e700be3ea606fda10e92223ecf27869bfb5a02e355c66d20a783c412fda041e076f9773e2e35979ca8974eda9b5deab250cf94108a44ef9e8ac26dc2b32276f1340c4df66c4ca12acd9d5efe0484b48ea1143bec9d9a1aa0be1ff7a6a9efff530e19d749f7aa3bcf68b69ff683201411dbc0dec592386cbdeffa9f3bd7c6441ed33d7977fe7d72bfe4fbfc22098d9ce503835368afa49b466ec157e6965f1c0e2858559b7be8553b133085053663af1efee39134f16ec621fdbfff92edcc542812ff87ee0b47aea285497487521f37de0a893afd46a3b3fa1b70eebcedf2c908e46ac921201a977bd811d957a11efe829e7c4c52bd33b57e415bda423c880c0c19893a3446677d9da18113851476c01639809ae4500b417fc5bcc411ef6dfbb2b78bfc7265ce523acf883f686cbf01756c7deb98df43e5abbd79fb3c3503e524db109f3a51547257ab1f2b5d9b7c8c5fc95175d631ed9b1d7522dc05aa607c296c8dd0fd2327a6a00c310be9977352cd964636cb9155fa8baee8bbfbf24e0c387ca2b5da941e13d24262a55e9531fb658c2662e6c55e7c6cd7b25a1430c8f748307672850469182d2e5a2c7d7f6eff7e402866b0fd76c0357defebcc6947480dcb17173b6ba7566c96b779b90ac172a7dd9380f53ac6fab3dd45a01dae0e25007225bb3d1a9343c2ff9c1bc67422eb043d9c53615bbf90023eb4833c880a9dacfa8166e02151e0584624f3fd2207c18025567fa6427d870892abc193d45967a300d1f09d0b190a80c40424c76eeb14381a2bea6b69de7a205501748efe7c8927b70c7b43b0da3fb34841310c0987a041b7b8759107b831d05042be51d92177ad479e9b290d69f09f0633f699d93659ebacada98af87fbce7c292c731489defd2dfadcd01b0fd37704923c4a7f00cf957debb34174638e8938e71c6a1850c23064f32061234c9d0a5d9879a4d2f5b49b7b87284638a7c5fb9abd303596aa869800f1b85607c3ab862679397f03d9ba27d354bcb74edd43e54d0c71c7050ebe5a0afdd5b1097ab3a45b7d9965313575e87593d685e395484efab8622eec00400320d2141371a467aa63d556aed05b4a7f18b688118bbfe530f6ac743922aa2f3a8d74af042ec5d4134f9b6a30b414bc2b9c8e9aa4898b53fbd693954658d55432fc89842c8becdaf4f7188feca396913a2980f53abfd67b980cc83ed659a71a6f6bb32a71885e20c4d6a3f9af8f3b25c1fb016c272bf508dc3cd4ebededabcabc10a3a00183d7cf291f96bc9434ebf22600b2db066d9cb9a2a3ea8561954fa63258a17937c85d933212c671cf34f4f4be9a0c188331e6be6796f950576d61216cffd61049c03c04fa432e0d95568aa505965be2364bed714e11cb2eab2b035c63ce6652744b933d5893531f53355a9272d5ee981a7e883c06d4d8b364bf0fc579fc57ca3702962c231496a1a877950961d86d4a2a5bd6b64e56a8c7e97d98630a8f1eb7f28f5db3a9535389454fbb85f6e85822b144d78c1d67ecde612c94005a983ab79bb52f33f0ea26b3fbb0665a203759beb6e12aa3830e513cf5610bd75630569dd2cc62021dd5b6b0ee6d5d24d7758750a6e0a45c089e7f7eb749b10910281128f6378c31a6eb1b9cb7f60bc2c08740a22359572455b51deb264276c488bc7be76960b79a9e3729ca64226e2eb6e016d4b86252224ad57e0ca961fe8c4e52d7c26c1a698307f3173fa406bed73f0f7910180664e25a70d1b386c3271dfa12b0045769acd12b8cc0a64ea04b1cf2740a1014bf514bb8f683c1a33bd0e35054fd6191efcce168d349dc1392c6dee63da2b45da356527cbd2b40647c7e15f15a3763c753751bc7da22d4e4c8b7728da6ca34c2f96f318a2ac436274cf9fd1fc0f501d2d1404581def0ebbdfdf1ba663714fd84cfe49a8e79c168bf256cb6ea41355284c215497e56b234448c2c163eb71c06be861b92708a59fde88f9f6b539c3788ef428ec86051f45944b5054ad2a61d4ed850851ba6e3d26c0c67c7de472e3d51b627a064115fe51f68d0acc9aa6494d33d08f3501e63d1d904263ae3b210bf37ff207a90186789447bcb8e6c6eb64cdb9f2b82ca825f6b1d9c2f4bfb35a4aaa4013221a1962ceb248a8f8b13efe037faaa1121acd2494a4d75539138943a8a46ef17bee0523813c27b49b83e663cd90b16f0e3ca024136ab4c260de024e7f429f2308430cf6ff9e87f435b0c6c0dea6e75531311651d8f38d88b5a90d19b97bf6a867735e2b81a906e1a945e91c6e39457b4f2f8496bd51576b9a9e5395cd34d0815aba54a36352c6df7d3481704c61038f1c717f014f01ea94ee692aabbec9b0e04d3f9b18c5a22e0873e07ad5df58febbde8a1afb8abc7b2f12b424da58ee8138165b6c4958353a2661b9c2e5544c8957f269d9488e9d989d190249607ea2cfb54ba1245a0969b40acce404d226423ebe623fb9557f7ebf1dd3e1f17451b07b8737e0433c93a83af77ec9149180acfc0bb41cfaa4bcb0e4512e14b1dbb240eb11c93ac89a5a6372d7979197fd176d388557f7b6c1404f5dfca109967ca71ec87815a6e86590d2613903f0783fbb3ec00e3a69f1f0e0b246e751028dbe0a4451ff151205d9aca445a114f4b2c900decc601a423a9151d9100d18afbe9d2af7b705a698d014bcd19dafde967067037b18c0beb58d01ced99ea71dd6a9981e50e6e57339a5e7905c94a50fceb2ce6fd88bc444ab53573e0f87b8a1a2dcc4d544c18eb039d03a14b8414bbd3a177a50b2d783dba5022e53a2fada645e98afce7a628d88b71ca7d45bf10837ccd695c7ac7742ca56b0e52bf72d10b28ad5214eaf50773c8caccc82c3a402179d41f9243cb96e73d0aa14ad8c7f8cb542b2c654e43d2e98c92cc19185bfd11a864f4b08aae48db540ae6e605e9ec80f2c301e1f64188cfe4498d19b68c848c07d8ab9cdc9337098faa76d479f09785a680be571c1ac2ebb32cb3420d33baeb9b27460914ff1d69e5574b4796b6d04a4a0cf21d973484580783fee9ea8b42637b8b1ac3f3415340de7bd0e548e0b04cf76e3e159e70575ca3df17f2db62a4dc42ac7d87130eb2d3a65695d4760f25a98cc0cd2c8e3b8770fc957dfa0bbecf38708c5e9420397db6b36e4141d35c45afdbbedf6f89fb165a7476ff42cb74f1d606283a8e8df2ecd20b4023e1d80a362c903c5c2bdef8b28801f6332a8a6261c03cdacbc99c2e983739000481ea63ffb835afcf2e69be78ed10924f0b915c45d255d70c67ab850ddc626a9e6735577b24b9517b0adcab6c17fb1431191afebe4203abc63aed748f11a27cc040a3844118098808422765574bb932f472f8a0005aea987aa36a20eb73a1de04f9450843abc1b7fb2a7fcd3b4258e2f4535d035bf49360d394388f01d33efe0ff26a77a5a372e1461393fbcdfaf3cf60d1f087102b47b36e52d154b47a7ee590ce1444ae5ece6600530c541de466cfb699184882aa26dc8325f30c20d455180a1f442596d50037cdc27138e7c6d0a80d0987da77569c603a77cb38ad7788115bcb5c2e103085fdfcccb2a60ed3d8f2d30fbe2c1f22360e1c86920857de76ab4c46345a4a6a5316219bb0183ae6132c96eed0e75a8c97f654b474750037a5fd14abc2277da0bd8c998b9c0a7fbb9bc579bfda835d96eaa01cd24c06c9576df447dbee46bbf0380afbfef415b4c62165f004268a964656d7a879836f030fad113ba4432775da8d1a200769ca7b41d42b30815b88efe6d5f8093384f2f561ebbdcd08e8be706bc21e3618be1a1fab4bf6cb6ba00e3e17bdd12a7b999d0ea127ff3bc57ac3687ac3d5fef1b6c9c66e2d49d251f501b0a9dc07e2e92064f52ae29c69308e9caee2d5cd7988d9af469be76c82038f1b39b2e98a3b1589108b63a3a44fa09ef9d87efd599d4d4059d254569d3b3c4c1a62bce871027d9dc52923fc09f1c122b52c0087057065b341f85a7f190d63fb9b25f5d6ba3798e2f690f5e62b6017150e68a713c5228c01ba495b2de93d5d0cc10aa3b357db84280f55b96990b2cff9f95081eecffeed924ffbb46454236e20b70b0c7775fa28930a0cce0af4cc96d4ab54a0f4087b87e0d11496e148ca44f53c7a267596ef9dfc2b4c8ad88db1d0d6be23d741c32c0c8d8fbc197f75d7c4b67a8b6b34c44d3d4f3b2f4bb938f6d0a57c04c915f2d0f1b6997d8277253bc563170d1b72af98085ac20eb2325340cc3522d5fe29e2ef3c3fa53473e2a9750c02e8738cf036127efa35fa25bf5f395fd26e701c2e1de4ca7d162816986dc791c22f8f4226857ad1bb2rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpython-paramiko-2.4.2-lp150.2.3.1.src.rpmpython3-paramiko@      python(abi)python3-PyNaClpython3-bcryptpython3-cryptographypython3-pyasn1rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.61.0.13.1.31.50.1.73.0.4-14.6.0-14.0.4-14.0-15.2-14.14.1\?\l@[[R@Z`@Z`@Z }YYYJY=0XQ@XX~@X @XOW@W@W\@WWUeW/*@VHT T->@S@SQR@Rm@R%@Q~`P@O@O]@Nx@L@Lmcepl@suse.comMatej Cepl Ondřej Súkup Ondřej Súkup ro@suse.detbechtold@suse.commimi.vx@gmail.commimi.vx@gmail.commimi.vx@gmail.comtbechtold@suse.commimi.vx@gmail.comtoddrme2178@gmail.comrjschwei@suse.comrjschwei@suse.commimi.vx@gmail.commimi.vx@gmail.comtbechtold@suse.commichael@stroeder.commichael@stroeder.comdmueller@suse.comdmueller@suse.comhpj@urpla.nettoddrme2178@gmail.comtbechtold@suse.comandrea@opensuse.orgdmueller@suse.comrschweikert@suse.comp.drouand@gmail.comlukas@wunner.dedmueller@suse.comdmueller@suse.comsaschpe@suse.deos-dev@jacraig.comsaschpe@gmx.desaschpe@suse.denix@opensuse.orgcoolo@novell.com- Synchronize SLE 15 package with openSUSE:Factory (bsc#1121846) - Also add disable-gssapi.patch and update paramiko-test_extend_timeout.patch- Remove superfluous devel dependency for noarch package- add disable-gssapi.patch - workaround for boo#1115769- update to 2.4.2 (bsc#1111151, CVE-2018-1000805) - refresh paramiko-test_extend_timeout.patch * Fix exploit (CVE pending) in Paramiko's server mode (not client mode) where hostile clients could trick the server into thinking they were authenticated without actually submitting valid authentication. * Modify protocol message handling such that Transport does not respond to MSG_UNIMPLEMENTED with its own MSG_UNIMPLEMENTED * Updated SSHConfig.lookup so it returns a new, type-casting-friendly dict subclass (~paramiko.config.SSHConfigDict) in lieu of dict literals.- add paramiko-test_extend_timeout.patch (bsc#1085529) extend timeout in testsuite to pass on ppc64leupdate to version 2.4.1 (bsc#1085276, CVE-2018-7750): * changelog: update for #1039 / #1051 * Screen off dev version of Python from test matrix * ensure ed25519 password is bytes * Cut 2.0.8 * Cut 2.3.2 * Initial tests proving CVE-2018-7750 / #1175 * Guess something else added this prior to the merge * Fixes CVE-2018-7750 / #1175 * Uncaught typo in test suite * Initial tests proving CVE-2018-7750 / #XXX * Test proving #1039 / efficacy of #1051 * Changelog closes #1175 * Cut 2.1.5 * Allow overriding test client connect kwargs in Transport test suite * Cut 2.4.1 * Fixes CVE-2018-7750 / #XXX * Cut 2.2.3 * flake8- update to 2.4.0 + new pytest based testsuite * dd a new passphrase kwarg to SSHClient.connect so users may disambiguate key-decryption passphrases from password-auth passwords. * Drop Python 2.6 and Python 3.3 support- update to 2.3.1 + cert_support.tar.gz - missing test certificates for testsuite * Certificate support broke the no-certificate case for Ed25519 keys (symptom is an AttributeError about public_blob.) This went uncaught due to cert autoload behavior (i.e. our test suite never actually ran the no-cert case, because the cert existed!) Both issues have been fixed. * Implement basic client-side certificate authentication (as per the OpenSSH vendor extension.) * Added pre-authentication banner support for the server interface (ServerInterface.get_banner plus related support in Transport/AuthHandler.) * Update Ed25519Key so its constructor offers the same file_obj parameter as its sibling key classes. * Add a gss_trust_dns option to Client and Transport to allow explicitly setting whether or not DNS canonicalization should occur when using GSSAPI. * Paramiko originally defaulted to zlib compression level 9 (when one connects with compression=True; it defaults to off.) This has been found to be quite wasteful and tends to cause much longer transfers in most cases, than is necessar * Enhance documentation around the new SFTP.posix_rename method so it’s referenced in the ‘standard’ rename method for increased visibility. * Modify logic around explicit disconnect messages, and unknown-channel situations, so that they rely on centralized shutdown code instead of running their own. This is at worst removing some unnecessary code, and may help with some situations where Paramiko hangs at the end of a session. * Display exception type and message when logging auth-rejection messages (ones reading Auth rejected: unsupported or mangled public key); previously this error case had a bare except and did not display exactly why the key failed. * Ed25519 keys never got proper API documentation support; this has been fixed. * Update how we use Cryptography‘s signature/verification methods so we aren’t relying on a deprecated API.- update to 2.2.2: * SSHClient now requests the type of host key it has (e.g. from known_hosts) and does not consider a different type to be a “Missing” host key. This fixes a common case where an ECDSA key is in known_hosts and the server also has an RSA host key. * Fix up host-key checking in our GSSAPI support, which was previously using an incorrect API call * Fix key exchange (kex) algorithm list for GSSAPI authentication; reviously, the list used solely out-of-date algorithms, and now contains newer ones listed preferentially before the old * Clean up GSSAPI authentication procedures so they do not prevent normal fallback to other authentication methods on failure. * Add rekeying support to GSSAPI connections, which was erroneously missing.- update to 2.2.1: * Missed a spot * Update .travis.yml * Whitespace * Having this in a mini-toctree made the nav look funny and is also just unintuitive * Changelog re #471, re #65 * these are bytes * changelog: update for #990 and #993 * ecdh kex support * flake8/whitespace * Trailing comma * Add test for posix-rename@openssh.com extension for SFTP client * Changelog re #921 * Add a note about new Python-level deps to changelog re: Ed25519 support * Add method for "posix-rename@openssh.com" extension for SFTP client. * Add IOError in posix-rename@openssh.com test for python 2 support. * this isnt bytes * Added a auth_timeout to handle situations where SSH server stops responding during auth. * small cleanups * More changelog flimflammery * Added changelog entry * python 3 compatibility * Incorrect comparison, should be <= * DDD re #857 * Improve __hash__ functions * Hrm that should always have been an h1 * No idea how this got past all the earlier flake8 work... * comments * Fixed test to support python 2.6 * Note ecdh-sha2 preferred-kex placement in changelog entry for #951, re #983 * Changelog language tweaks * Reorder cipher and key preferences to make more sense * Added a test to check that the auth_timeout argument is passed through and applied. * Changelog tweak * Cut 2.2.1 * transport: change order of preferred kex and hmac algorithms * need bcrypt >= 3.1.3 for kdf() ignore_few_rounds kwarg * Changelog re #972, re #325, closes #325 * cleanup/simplify auth_timeout tests * Missed a merge conflict lolol * flake8 * Changelog re #951 * Perplexed at why flake8 did not report this earlier * Add Python 3.6 to classifiers * Add support for posix-rename@openssh.com for the SFTP server side and fix tests accordingly. * sphinx nitpick fixes * Fixed encoding/decoding of the public key on the wire * Added test for authentication timeout from a non-responsive server * refactor files * fixed comment + consistency * Changelog re #857 * Cut 2.2.0 * integration test, with ourselves * TODO * That was easy. Closes #857 * Add sanity note to changelog re #869 * Unit tests * Fixes #325 -- add support for Ed25519 keys * Happy New Year * implement __hash__() method for Ed25519Key * pep8 * Increased auth_timeout to 30 seconds * py3k * fixed long line * Link to the spec * set a minimum version * Support decrypting keys * Failing test proving need for #857 - move demos/ to extra -doc package- update to 2.1.3 * Make util.log_to_file append instead of replace. * SSHClient and Transport could cause a memory leak if there’s a connection problem or protocol error, even if Transport.close() is called. * Prior support for ecdsa-sha2-nistp(384|521) algorithms didn’t fully extend to covering host keys, preventing connection to hosts which only offer these key types and no others. This is now fixed. * Prefer newer ecdsa-sha2-nistp keys over RSA and DSA keys during host key selection. This improves compatibility with OpenSSH, both in terms of general behavior, and also re: ability to properly leverage OpenSSH-modified known_hosts files. * The RC4/arcfour family of ciphers has been broken since version 2.0; but since the algorithm is now known to be completely insecure, we are opting to remove support outright instead of fixing it. * Move sha1 above the now-arguably-broken md5 in the list of preferred MAC algorithms, as an incremental security improvement for users whose target systems offer both. * Writing encrypted/password-protected private key files was silently broken since 2.0 due to an incorrect API call Includes a directly related fix, namely adding the ability to read AES-256-CBC ciphered private keys (which is now what we tend to write out as it is Cryptography’s default private key cipher.) * Allow any type implementing the buffer API to be used with BufferedFile, Channel, and SFTPFile. This resolves a regression introduced in 1.13 with the Python 3 porting changes, when using types such as memoryview. * Enhance default cipher preference order such that aes(192|256)-cbc are preferred over blowfish-cbc. * SSHClient now requests the type of host key it has (e.g. from known_hosts) and does not consider a different type to be a “Missing” host key. This fixes a common case where an ECDSA key is in known_hosts and the server also has an RSA host key. * Overhaul the codebase to be PEP-8- Implement single-spec version.- Fix version setting for cryptography for build- Add python-pyasn1 as Buildrequires for testing- update to 2.1.2 * Fix a bug in server-mode concerning multiple interactive auth steps * SSHClient now gives its internal Transport a handle on itself, preventing garbage collection of the client until the session is closed. Without this, some code which returns stream or transport objects without the client that generated them, would result in premature session closure when the client was GCd * Avoid test suite exceptions on platforms lacking errno.ETIME * weak how RSAKey.__str__ behaves so it doesn’t cause TypeError under Python 3.- update to 2.1.1 * A tweak to the original patch implementing gh#398 was not fully applied, causing calls to ~paramiko.client.SSHClient.invoke_shell to fail with AttributeError. This has been fixed. * Fix the implementation of PKey.write_private_key_file (this method is only publicly defined on subclasses; the fix was in the private real implementation) so it passes the correct params to open() * Add an optional timeout parameter to Transport.start_clienti (and feed it the value of the configured connection timeout when used within SSHClient .) * Catch AssertionError thrown by Cryptography when attempting to load bad ECDSA keys, turning it into an SSHException. * Add a missing .closed attribute (plus ._closed because reasons) to ProxyCommand * Make the subprocess import in proxy.py lazy so users on platforms without it (such as Google App Engine) can import Paramiko successfully * Fix incorrect docstring/param-list for Transport.auth_gssapi_keyex so it matches the real signature. * Add an environment dict argument to Client.exec_command- Fix Requires for python-cryptography - Add missing Requires for python-pyasn1- update to 2.0.2 * [Bug] #758: Apply type definitions to _winapi module from jaraco.windows 3.6.1. This should address issues on Windows platforms that often result in errors like ArgumentError: [...] int too long to convert. Thanks to @swohlerLL for the report and Jason R. Coombs for the patch. * [Bug] #774: Add a _closed private attribute to Channel objects so that they continue functioning when used as proxy sockets under Python 3 (e.g. as direct-tcpip gateways for other Paramiko connections.) * [Bug] #673: (via #681) Fix protocol banner read errors (SSHException) which would occasionally pop up when using ProxyCommand gatewaying. Thanks to @Depado for the initial report and Paul Kapp for the fix.- updated homepage URL - update to 2.0.1: * [Bug] #537: Fix a bug in BufferedPipe.set_event which could cause deadlocks/hangs when one uses select.select against Channel objects (or otherwise calls Channel.fileno after the channel has closed). * [Bug] #520: (Partial fix) Fix at least one instance of race condition driven threading hangs at end of the Python interpreter session. (Includes a docs update as well - always make sure to .close() your clients!)- fix build- fix source url- update to 2.0.0: * Add support for 384- and 512-bit elliptic curve groups in ECDSA key types (aka ecdsa-sha2-nistp384 / ecdsa-sha2-nistp521). * Due to an earlier bugfix, less-specific Host blocks' ProxyCommand values were overriding ProxyCommand none in more-specific Host blocks. This has been fixed in a backwards compatible manner (i.e. ProxyCommand none continues to appear as a total lack of any proxycommand key in parsed config structures). * Fix a backwards incompatibility issue that cropped up in SFTPFile.prefetch <~paramiko.sftp_file.prefetch> re: the erroneously non-optional file_size parameter. Should only affect users who manually call prefetch. * Replace PyCrypto with the Python Cryptographic Authority (PyCA) 'Cryptography' library suite. This improves security, installability, and performance; adds PyPy support; and much more. * Fix stalled/hung SFTP downloads by cleaning up some threading lock issues. * Fix a Python 3 compatibility issue when handling two-factor authentication. * Clean up setup.py to always use setuptools, not doing so was a historical artifact from bygone days. * Update the module in charge of handling SSH moduli so it's consistent with OpenSSH behavior re: prime number selection. * Fix up ~paramiko.ssh_exception.NoValidConnectionsError so it pickles correctly, and fix a related Python 3 compatibility issue. * Update to jaraco.windows 3.4.1 to fix some errors related to ctypes on Windows platforms. * Annotate some public attributes on ~paramiko.channel.Channel such as .closed. * Fix logic bug in the SFTP client's callback-calling functionality; previously there was a chance the given callback would fire twice at the end of a transfer. * Identify & work around a race condition in the test for handshake timeouts, which was causing frequent test failures for a subset of contributors as well as Travis-CI (usually, but not always, limited to Python 3.5). * Remove whitespace in our setup.py's install_requires as it triggers occasional bugs in some versions of setuptools. * Strip trailing/leading whitespace from lines when parsing SSH config files - this brings things in line with OpenSSH behavior. * Fix behavior of gssapi-with-mic auth requests so they fail gracefully (allowing followup via other auth methods) instead of raising an exception. * Add missing file-like object methods for ~paramiko.file.BufferedFile and ~paramiko.sftp_file.SFTPFile. * Clean up and enhance the README (and rename it to README.rst from just README).- Add --no-transport to fix a known issue with the tests https://github.com/paramiko/paramiko/issues/574 Check if still failing on next release. The tests is currently failing on Python 3.5, but it is not actually Python 3.5 specific, it is just more likely to be encountered on Python 3.5 - update to version 1.16.0: * Streamline use of stat when downloading SFTP files via SFTPClient.get ; this avoids triggering bugs in some off-spec SFTP servers such as IBM Sterling. Thanks to @muraleee for the initial report and to Torkil Gustavsen for the patch. * Fully enable two-factor authentication (e.g. when a server requires AuthenticationMethods pubkey,keyboard-interactive). Thanks to @perryjrandall for the patch and to @nevins-b and Matt Robenolt for additional support. * Fix 'exec' requests in server mode to use get_string instead of get_text to avoid UnicodeDecodeError on non-UTF-8 input. Thanks to Anselm Kruis for the patch & discussion. * Fix line number reporting in log output regarding invalid known_hosts line entries. Thanks to Dylan Thacker-Smith for catch & patch. * Update the vendored Windows API addon to a more recent edition. Also fixes :issue:`193`, :issue:`488`, :issue:`498`. Thanks to Jason Coombs.- update to version 1.15.2 (bsc#962291) * [Bug] #320: Update our win_pageant module to be Python 3 compatible * [Bug] #429: Server-level debug message logging was overlooked during the Python 3 compatibility update; Python 3 clients attempting to log SSH debug packets encountered type errors. This is now fixed * [Bug] #459: Tighten up agent connection closure behavior to avoid spurious ResourceWarning display in some situations * [Bug] #266: Change numbering of Transport channels to start at 0 instead of 1 for better compatibility with OpenSSH & certain server implementations which break on 1-indexed channels * [Support] #419: Modernize a bunch of the codebase internals to leverage decorators. Props to @beckjake for realizing we’re no longer on Python 2.2 :D * [Support] #421: Modernize threading calls to user newer API * [Support] #422: Clean up some unused imports * [Support] #431: Replace handrolled ssh_config parsing code with use of the shlex module * [Bug] #415: Fix ssh_config parsing to correctly interpret ProxyCommand none as the lack of a proxy command, instead of as a literal command string of "none" * [Bug] #428: Fix an issue in BufferedFile (primarily used in the SFTP modules) concerning incorrect behavior by readlines on files whose size exceeds the buffer size * [Bug] #455: Tweak packet size handling to conform better to the OpenSSH RFCs; this helps address issues with interactive program cursors * [Bug] #413: (also #414, #420, #454) Be significantly smarter about polling & timing behavior when running proxy commands, to avoid unnecessary (often 100%!) CPU usage- new upsteam version 1.15.1 * fixed from previous version: Bug] #399: SSH agent forwarding would hang due to incorrect values passed into the new window size arguments for Transport * detailed changelog available on pramiko website: http://paramiko-www.readthedocs.org/en/latest/changelog.html- update to 1.13.1: * :support:`256 backported` Convert API documentation to Sphinx, yielding a new API docs website to replace the old Epydoc one. * :bug:`-` Use constant-time hash comparison operations where possible, to protect against `timing-based attacks `_. Thanks to Alex Gaynor for the patch. * :feature:`58` Allow client code to access the stored SSH server banner via `Transport.get_banner `. Thanks to ``@Jhoanor`` for the patch. * :bug:`252` (`Fabric #1020 `_) Enhanced the implementation of ``ProxyCommand`` to avoid a deadlock/hang condition that frequently occurs at ``Transport`` shutdown time. Thanks to Mateusz Kobos, Matthijs van der Vleuten and Guillaume Zitta for the original reports and to Marius Gedminas for helping test nontrivial use cases. * :bug:`268` Fix some missed renames of ``ProxyCommand`` related error classes. Thanks to Marius Gedminas for catch & patch. * :bug:`34` (PR :issue:`35`) Fix SFTP prefetching incompatibility with some SFTP servers regarding request/response ordering. Thanks to Richard Kettlewell. * :bug:`193` (and its attentant PRs :issue:`230` & :issue:`253`) Fix SSH agent problems present on Windows. Thanks to David Hobbs for initial report and to Aarni Koskela & Olle Lundberg for the patches. * :bug:`225 (1.12+)` Note ecdsa requirement in README. Thanks to Amaury Rodriguez for the catch. * :bug:`176` Fix AttributeError bugs in known_hosts file (re)loading. Thanks to Nathan Scowcroft for the patch & Martin Blumenstingl for the initial test case.- include in SLE 12 (FATE #315990)- Update to version 1.12 * #152: Add tentative support for ECDSA keys. *This adds the ecdsa module as a new dependency of Paramiko.* The module is available at [warner/python-ecdsa on Github](https://github.com/warner/python-ecdsa) and [ecdsa on PyPI](https://pypi.python.org/pypi/ecdsa). * Note that you might still run into problems with key negotiation -- Paramiko picks the first key that the server offers, which might not be what you have in your known_hosts file. * Mega thanks to Ethan Glasser-Camp for the patch. * #136: Add server-side support for the SSH protocol's 'env' command - Use local source instead of service - Add python-ecdsa requirement; new dependency- update to 1.11.2: * #156: Fix potential deadlock condition when using Channel objects as sockets (e.g. when using SSH gatewaying). Thanks to Steven Noonan and Frank Arnold for catch & patch. * #179: Fix a missing variable causing errors when an ssh_config file has a non-default AddressFamily set. Thanks to Ed Marshall & Tomaz Muraus for catch & patch. * #200: Fix an exception-causing typo in `demo_simple.py`. Thanks to Alex Buchanan for catch & Dave Foster for patch. * #199: Typo fix in the license header cross-project. Thanks to Armin Ronacher for catch & patch. * #162: Clean up HMAC module import to avoid deadlocks in certain uses of SSHClient. Thanks to Gernot Hillier for the catch & suggested fix. * #36: Fix the port-forwarding demo to avoid file descriptor errors. Thanks to Jonathan Halcrow for catch & patch. * #168: Update config handling to properly handle multiple 'localforward' and 'remoteforward' keys. Thanks to Emre Yilmaz for the patch.- update to 1.11.0: * #98: On Windows, when interacting with the PuTTY PAgeant, Paramiko now creates the shared memory map with explicit Security Attributes of the user, which is the same technique employed by the canonical PuTTY library to avoid permissions issues when Paramiko is running under a different UAC context than the PuTTY Ageant process. Thanks to Jason R. Coombs for the patch. * #100: Remove use of PyWin32 in `win_pageant` module. Module was already dependent on ctypes for constructing appropriate structures and had ctypes implementations of all functionality. Thanks to Jason R. Coombs for the patch. * #87: Ensure updates to `known_hosts` files account for any updates to said files after Paramiko initially read them. (Includes related fix to guard against duplicate entries during subsequent `known_hosts` loads.) Thanks to `@sunweaver` for the contribution.- update to 1.10.1: * SFTP put of empty file will still return the attributes of the put file. Thanks to Jason R. Coombs for the patch. * Forwarded SSH agent connections left stale local pipes lying around, which could cause local (and sometimes remote or network resource starvation when running many agent-using remote commands. Thanks to * Batch SFTP writes to help speed up file transfers * Fix handling of window-change events to be on-spec * Overhaul SSH config parsing to be in line with `man ssh_config` * Forego random padding for packets when running under `*-ctr` ciphers * Add `SFTPClient.putfo` and `.getfo` methods to allow direct uploading/downloading of file-like objects * Add `timeout` parameter to `SSHClient.exec_command` for easier setting of the command's internal channel object's timeout * Expose the internal "is closed" property of the file transfer class BufferedFile` as `.closed`, better conforming to Python's file interface- Update to version 1.9.0: + #97 (with a little #93): Improve config parsing of ProxyCommand directives and provide a wrapper class to allow subprocess-driven proxy commands to be used as sock= arguments for SSHClient.connect. + #77: Allow SSHClient.connect() to take an explicit sock parameter overriding creation of an internal, implicit socket object. - Changes from version 1.8.1: + #90: Ensure that callbacks handed to SFTPClient.get() always fire at least once, even for zero-length files downloaded. Thanks to Github user @enB for the catch. + #85: Paramiko's test suite overrides unittest.TestCase.assertTrue/assertFalse to provide these modern assertions to Python 2.2/2.3, which lacked them. However on newer Pythons such as 2.7, this now causes deprecation warnings. The overrides have been patched to only execute when necessary. Thanks to @Arfrever for catch & patch. - Changes from version 1.8.0: + #17 ('ssh' 28): Fix spurious NoneType has no attribute 'error' and similar exceptions that crop up on interpreter exit. + 'ssh' 32: Raise a more useful error explaining which known_hosts key line was problematic, when encountering binascii issues decoding known host keys. Thanks to @thomasvs for catch & patch. + 'ssh' 33: Bring ssh_config parsing more in line with OpenSSH spec, re: order of setting overrides by Host specifiers. Specifically, the overrides now go by file order instead of automatically sorting by Host value length. In addition, the first value found per config key (e.g. Port, User etc) wins, instead of the last. Thanks to Jan Brauer for the contribution. + 'ssh' 36: Support new server two-factor authentication option (RequiredAuthentications2), at least re: combining key-based & password auth. Thanks to Github user bninja. + 'ssh' 11: When raising an exception for hosts not listed in known_hosts (when RejectPolicy is in effect) the exception message was confusing/vague. This has been improved somewhat. Thanks to Cal Leeming for highlighting the issue. + 'ssh' 40: Fixed up & expanded EINTR signal handling. Thanks to Douglas Turk. + 'ssh' 15: Implemented parameter substitution in SSHConfig, matching the implementation of ssh_config(5). Thanks to Olle Lundberg for the patch. + 'ssh' 24: Switch some internal type checking to use isinstance to help prevent problems with client libraries using subclasses of builtin types. Thanks to Alex Morega for the patch. + Fabric #562: Agent forwarding would error out (with Authentication response too long) or freeze, when more than one remote connection to the local agent was active at the same time. This has been fixed. Thanks to Steven McDonald for assisting in troubleshooting/patching, and to GitHub user @lynxis for providing the final version of the patch. + 'ssh' 5: Moved a fcntl import closer to where it's used to help avoid ImportError problems on Windows platforms. Thanks to Jason Coombs for the catch + suggested fix. + 'ssh' 4: Updated implementation of WinPageant integration to work on 64-bit Windows. Thanks again to Jason Coombs for the patch. + Added an IO loop sleep() call to avoid needless CPU usage when agent forwarding is in use. + Handful of internal tweaks to version number storage. + Updated setup.py with ==dev install URL for pip users. + Updated setup.py to account for packaging problems in PyCrypto 2.4.0 + Added an extra atfork() call to help prevent spurious RNG errors when running under high parallel (multiprocess) load. + Merge PR #28: https://github.com/paramiko/paramiko/pull/28 which adds a ssh-keygen like demo module. (Sofian Brabez)- Update to 1.7.7.2: * Merge pull request #63: https://github.com/paramiko/paramiko/pull/63 which fixes exceptions that occur when re-keying over fast connections. - Add unit tests to build- Simplified macro usage- Update to version 0.7.7: * Various bug fixes (upstream provides no further changes)- Require newer python-crypto- updte to 1.7.6 "Fanny" various bug fixes, "Ernest" brought ARC4 & CTR support and IP6 supportcloud128 1548429607  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~2.4.2-lp150.2.3.1paramikoparamiko-2.4.2-py3.6.egg-infoPKG-INFOSOURCES.txtdependency_links.txtrequires.txttop_level.txt__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pyc_version.cpython-36.opt-1.pyc_version.cpython-36.pyc_winapi.cpython-36.opt-1.pyc_winapi.cpython-36.pycagent.cpython-36.opt-1.pycagent.cpython-36.pycauth_handler.cpython-36.opt-1.pycauth_handler.cpython-36.pycber.cpython-36.opt-1.pycber.cpython-36.pycbuffered_pipe.cpython-36.opt-1.pycbuffered_pipe.cpython-36.pycchannel.cpython-36.opt-1.pycchannel.cpython-36.pycclient.cpython-36.opt-1.pycclient.cpython-36.pyccommon.cpython-36.opt-1.pyccommon.cpython-36.pyccompress.cpython-36.opt-1.pyccompress.cpython-36.pycconfig.cpython-36.opt-1.pycconfig.cpython-36.pycdsskey.cpython-36.opt-1.pycdsskey.cpython-36.pycecdsakey.cpython-36.opt-1.pycecdsakey.cpython-36.pyced25519key.cpython-36.opt-1.pyced25519key.cpython-36.pycfile.cpython-36.opt-1.pycfile.cpython-36.pychostkeys.cpython-36.opt-1.pychostkeys.cpython-36.pyckex_ecdh_nist.cpython-36.opt-1.pyckex_ecdh_nist.cpython-36.pyckex_gex.cpython-36.opt-1.pyckex_gex.cpython-36.pyckex_group1.cpython-36.opt-1.pyckex_group1.cpython-36.pyckex_group14.cpython-36.opt-1.pyckex_group14.cpython-36.pyckex_gss.cpython-36.opt-1.pyckex_gss.cpython-36.pycmessage.cpython-36.opt-1.pycmessage.cpython-36.pycpacket.cpython-36.opt-1.pycpacket.cpython-36.pycpipe.cpython-36.opt-1.pycpipe.cpython-36.pycpkey.cpython-36.opt-1.pycpkey.cpython-36.pycprimes.cpython-36.opt-1.pycprimes.cpython-36.pycproxy.cpython-36.opt-1.pycproxy.cpython-36.pycpy3compat.cpython-36.opt-1.pycpy3compat.cpython-36.pycrsakey.cpython-36.opt-1.pycrsakey.cpython-36.pycserver.cpython-36.opt-1.pycserver.cpython-36.pycsftp.cpython-36.opt-1.pycsftp.cpython-36.pycsftp_attr.cpython-36.opt-1.pycsftp_attr.cpython-36.pycsftp_client.cpython-36.opt-1.pycsftp_client.cpython-36.pycsftp_file.cpython-36.opt-1.pycsftp_file.cpython-36.pycsftp_handle.cpython-36.opt-1.pycsftp_handle.cpython-36.pycsftp_server.cpython-36.opt-1.pycsftp_server.cpython-36.pycsftp_si.cpython-36.opt-1.pycsftp_si.cpython-36.pycssh_exception.cpython-36.opt-1.pycssh_exception.cpython-36.pycssh_gss.cpython-36.opt-1.pycssh_gss.cpython-36.pyctransport.cpython-36.opt-1.pyctransport.cpython-36.pycutil.cpython-36.opt-1.pycutil.cpython-36.pycwin_pageant.cpython-36.opt-1.pycwin_pageant.cpython-36.pyc_version.py_winapi.pyagent.pyauth_handler.pyber.pybuffered_pipe.pychannel.pyclient.pycommon.pycompress.pyconfig.pydsskey.pyecdsakey.pyed25519key.pyfile.pyhostkeys.pykex_ecdh_nist.pykex_gex.pykex_group1.pykex_group14.pykex_gss.pymessage.pypacket.pypipe.pypkey.pyprimes.pyproxy.pypy3compat.pyrsakey.pyserver.pysftp.pysftp_attr.pysftp_client.pysftp_file.pysftp_handle.pysftp_server.pysftp_si.pyssh_exception.pyssh_gss.pytransport.pyutil.pywin_pageant.pypython3-paramikoREADME.rstpython3-paramikoLICENSE/usr/lib/python3.6/site-packages//usr/lib/python3.6/site-packages/paramiko-2.4.2-py3.6.egg-info//usr/lib/python3.6/site-packages/paramiko//usr/lib/python3.6/site-packages/paramiko/__pycache__//usr/share/doc/packages//usr/share/doc/packages/python3-paramiko//usr/share/licenses//usr/share/licenses/python3-paramiko/-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.opensuse.org/openSUSE:Maintenance:9536/openSUSE_Leap_15.0_Update/5b785459e912d9c841d313f3d5587966-python-paramiko.openSUSE_Leap_15.0_Updatedrpmxz5noarch-suse-linuxdirectoryASCII textPython script, ASCII text executablepython 3.6 byte-compiledPython script, ASCII text executable, with very long lines  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRYU\_3USDutf-8c844e4a60d0efc1a16a12f7a563a95dd96191d0e246755514ad722212b31382e? 7zXZ !t/oi]"k%pa ða@I-QK:V%G._(NAf5L[\=ֵ7[읶RHQ/+kP1ō2-J:MSh rom.mb[qAsbK H9-qyEWl{ ]y ƕ51gF'? Fa(yN5sFc۪-~RdL15TS hq_ތZ7/=+IXU&M"ZoǶ12 Ov.78N>,8iqXfztQ/YN ѽ]rFS7m;d¿bһ@b\~@e"<`X"?j&٨fS{y'g{OİSW0Jxq0ش9.r{hNmTQGvn&Ib$ {VDV{Ԉڕa~o`IZC7yk#}>eQEJ.u5\W(_S 8C ) '*vw0!6EەfȦOמBL5^^:B& : Y4Y1 y<O9SP\g4b'7K|BwQ@5dj{IEOځePwd_$t>6ogšɦtj6_ɢG3N"Gȍxn&-=Q)mշ8 5;M˓jI<*۴F~IOa>ey(NbX/@gM07 ')}-g.F\A칖5L&a-k2j0Jzq$;_ku}lוK07 *$ꋵUEtbD!SXm/'pjo_7/먷 L9Xl) Ǣz*WOϢbb6w2#!\y»KP極EyT[*>:PЩ иah B^/kN`2"u_|;v= MPPЩpJNV#@pjqW? ,ESHHOn,Tp.2u ꨘᄍOb.aL*drp k< a?UmrFKLJJͬ1oRZ̯ -;x[J']۠3Mr5bֶ/6{L:hK\YreGDG>TWd;u;mHɍgӵ|F5jyT(k%×±xKJ8[R=]]{%TϏK!cI`'1}U_;ΐ8yWydIr ZXFjXň_TVGe|0ӧ P,N͇q=Bd\tqRnUȂT2Xo]7cnCa"/(ruId74"-@YV_CrZ֧>H| mwu?J=+OCn ,1DDzޝ)צcr{oV3\ꃙAH6Ȓ׼[HE@>߉sErg{r L_1@)U|yHWrVqB.%qz]+~we5 Nxf&߶a:7Q7*Q?Fi".][t 'Lyo7wGZ@v@6~ B xG8v.e`#덄Z1? rR;ETa suQE 4>OM wڊpWVd娡1 H N w7]{)28h%S!;*ީ6`svɈo3) uinPb:KᄉZ`ȑ{_ޥw#V+r\~]yܨ|R4p`0ȇ?>k@ U1>}<ƶ/#ƞh;9Ѯs pZ5acB&ʹ1<HBĐ@a^TYB  a͍hl>a @2iqUjR]TP׷H,|㰸D$P>Wlzx gD-!V(Shk@52:-jmzKpꭜ98y rGfIJv1U>.T;vv/X8 (*2a-˙Jk(P>|)XyW 2ZLZ{cz4s(xy۾Ș{p#mݔGpU4IL8s-X(I>|~Oݚn]ǽk~;ww)1rw6ơlbP ZT`a1ѷ;`U0+oU2I ^T'X?Q~Q(l`0/y? ih/d[tJ*${KAv.N~* hوuRTdSbv'4jH[",*v#ye_&e0NP)sx}HTzx\,ZgYdԹ1!(MeG`h%Q>~ԭxfR?I jIBυE/Qt+r $~G?a4Ã_ZIϳb~Xu_q S͈`{>GaҞzr8xCHI,h w͋fpߌaEL;=šH ^eF;x2Bk'ȰثO`$@PT#X\Kߦ .ȯ7Rxh:TJ6g ,f圵(5Chtw"%J2mB c,O39XHdfӍy?qqm*3' N".Opc61x5$~UƐ5;OGԜ0&yVMgh2i$gb_( MVru{`B9LV?y:' u =֍ʇ1]WbWBMֶ[;hq]4)nn'P0 ZtP>V5$ï܍6__WJJK{^^"$k-L Rp@)=2 KCPSW&e $sXl;?.[*Xh,۷h%. !ixʽ ,$ڑCpucsGSJm鬳%ʕi-&}XZPBV= vT>lU$UfC֎ }1Kyl(H?-}Q5MDm𽞅>dL*qEnkDɧYsH.!hܛ!StWb6 Y{q:}5_]AIP@ &F3A "T@f8Peh q~2j52sxp/3÷ c#%w)1ݔ\6zgbG)U0܆󩬾j.|MoiOzzW  칮oyG4wb5{N@i;4DtXFX-bd|JAqat~}+Hr'ZW=%2!<2 &^bNi :fGD #W tSŠyn|-Ms'`z=iE;vʰ녃b_;Ju! 8Uc ٨^ \Μiuv-38Vmʊr/ ƿP[wxՍb{Z͞**hk7nD"v"H각xP< z%=NʇcDٯO1?j *Sp:30b>7ɱȂ':=-0 '23Kvz.cEdfAMҩ1uAm_>9Kĕ+aW7Zc= 2]A(m4ok# `KU/#СFD U~ܖ d.6RۑU?8Lx:&+(Pj4?ℴ`Z欿_l''AD=@\Yj$8iژvd*dp.c$42:S6h+,EN(mOیnd??F*9.Y tسcIuät'3:=#ÑE=ja6bv+2&J'Y()}i3Vm9㣶2jH\1m}h7Uw]GhEx*gMMŜϿPZ({2 OCvzR14d?XP1];zqz HpfQ菭7IOܨe,&Kj 'M]ٰ,Zo[rkjZ$c|x/ƄΑIWf1VXG4A/ QεJWv.0F޵QrX08F}栗h!Wu_|G+d?Snm`.6 o{GwSa $w<=/(ˍ)N{7JK F=DS8z构 A7, (!lǃcEMgwiJ1Wˡ]aud8awO @_{ݔ  mŦ̹ֆr$hvo`jsaE:6%d (;ADPj9$q`=?#O$Dh♮'nJnp?\RU2m<1[A!~.w7Q)_H~2 WUsv,Kn]pS^zei,G o\M%3!Tּ+ˎ"ObbJFr=ַV`1 OQ~DYrTX z!H{XDoy:ߺr݉XF,A>\d?i 2Jq( Ro8 ~@vH{0$ZSDY6;]w?Cbd?3LGNqy9ү>!E^viJ'oG$M?l}/5P#*r3q g/(FEޝ7#BJ,sg$oVDdV!)el=4tF)7A7;[ -C,]x _M3fT- 䔟2M\Kz DhN^ E,FaC&cȓ ~刑AG>+)KEqea,Yj }!AA6申'u0MuR8shW-Dᣯ5 jn=rq9U'`9 H@h10*zEJ{4(J Nr.;On 9 E ?k%1員'hasiWJǙg<TZ2,!p xxh/6%^C\H*:}$MVd ܥV]C{%7'@70E>qeUGO% @}ȭkU=:)*dLǽPxUʇ|b>aJ۶KX8jKJkH^^‘|G~GC9A-PhLO Sv6E5.SUOv+gu{ z~Y%ZU"(}V-,(ک3Zlf)C}Vt@lBx-6c&:Ti Zk f$8Е/卂)fa @fEHvw}WcҬO0mAXFd*}iR H9xq@kIMujN^zw -WJPMdnHfjpw]_0fǢ*Ɍȫ7w rx^cS!bFӭ1>A u􇸞 S &q9#jXDd/ɆIݩrYKq0yՂX!@{~ ,D}pN1=lf1qsmD+a.=7n:!ȾK_nt޺NTS6[Y [e4ǫc;j al\'VLS,dYsjم]/IC,Z5yi6FY9⩘rZ|Zq3Re PBV#U)'jIxNG^L̠:tqMȒM1,94H%44,%nE}*IA#L)z`p7!aZ]ޖsA\vT1ɗl& _sc]paDz O˅CNopx[i?҈t¥l'mDD08P8/]s?=@%3+ҝ%zL^]Dz`5)X -x3.8$u^Yv>t#jv򾧚nW+(Y=rrz R_6}bߍE^HKg߉,mr\ߜW?oq=$A~!LPlMxKgD#kI7ApNf$M 1l 0OwsfKA:_n/Q\Lm2)bB  D0.JY5ɐUԍi۴"ϟ:J d B% /7 Azq W^B+N0}ŊAŞ(G̽X哾XX \o%rAB}.ox ^CPd)t.$a ӎw$Q9%GH޷z#+Qs-gZDr8lSJl>8:x.VѰ#xFi"h<$L[Ĺ|Y);׹2cpfsyB,ĨFYkX0Vc>4gпV|>wئbIz"la /6) z[,^([z+ƻi>K}{NjӏW)=q9>S` wӚ+)#?B˺~?&p=sTAUj-rJy@سd帉G5c$ HSyg#"Tb(Q*H&=~ⓘg 8så YIvXTI3s/ʂfՍj4 vܘ#ҝL ^5[uQjxWaItYOHL_:po9K<r4bJo7XZkza!sE9I!QSA"݅$԰#h;ԅx=#>}!907FMco!\*;ؚ+2)gpvċk\h#1[=8^/vJ8.`c0O7P +n[ =\E&TٵcwByLZ=bZ *Qا# V>DB3,[&{|okZ#|Y[,!rY6<[:+ u1Oڠ}BY91F;˱|v~WCl~\_ KBK;#pw_a+4 yfQg|j5 7R?CTR5Z:pg`"E{[D^PZkb[>mRs;Ltpt19vՐޑh࠴詝70<$N([vTҫDG,V?T.~7nB)1 嚕seĢ){h2`q:+Wnf{OmMuVSn7R !NB3M0u ˃,㒶?V T"f=E9r@z2+]}p.soGkOFv_-EyBKrUqK<)3J!}m\f|6I_ӼPQa #lux-F nPL!aPmkb p#(_ф?Cl,zy;&jV#;GdAguNiv_"4ܸjxPllDjgD DP¬e=T+^SeXB}qޔ:1_c1&΂Ȟ -O)z)*ʫJ=kZ,Ez ~U0dp?{ek>A8Xp}zN.P/E[L,A5íWJ{36kYMrW.2YpP1;Q2kf:(?zֽ@iPXDYP3x7盢c{EFZԟ\_ٓtqbB F[SuLߖ@jm}h tG*ʌf azf!0 嫑3GԩBN2P6.IRcySd}Gih^MJubz"ht3,bd'@^(` Z8*p)ؘG4υs-ap'e+k KJ^ Fw8b2ϤtpnT68ߵb&@.p^ TәPFN?[T`eĕ^&f$HMP-s㣈TծAmz Ss Ց s̠~ksFKF/?!X99 `S>zU 9拉y]ul0#<-ND|W_H]Yuu%-Sga?\:U_zR!YDslBvq]B4SS]89HHo {m Q+xE=$BNeۡg&S DFhذDc;,b8OE.7yx`1IF Tq=UO$tJhw)_c~(Yf"/ =-CZ֧o21J e*4plB>"P0 M^|C.=|:Hw{B,(0o*qqU=a_`bScT7[`z?d [¶ĢTQfk3J͟*4匄[3k¯Y/7NNmB@|UuuÃSJ)Mg \W/Ag$V6~Mb 5Q~P&Mٌ XjR_>s9^J5[ F`NQ4a>AGid'3🌮+*MFaHn}r)gJuw/ŚT-^o.-8iIE^ Hgq륏.C˛ e@-\l@qP/zCϚ.kX |Hc[>tt)Z\i2tnTGN2gBZVrHHՐhE*|ofU!`B$ .J6kjRsuOS +G`m%nWϭ|F![A= Ski(4K}QZgڍmGk_ɖ6b:Ss 6)Fحa"/Nsjƚ 6g)xeՇ[7&~EF@,=Dҋ,~&JJ{GA#D!&spJ4c@+rF!5T@%hG+p+$i}E⽽)T>_RM0saqXHGҕ^\)ZC,Ҙ׭n>TS5w7(*Nrl&QJXrVbnfdxq'\y*+p-X4jEQŤ`̆;[9@ ޕz@]^I]C V<xOzX5]Ӷ#Qc$d*3FP+~~o=6.L%P|k6iL"̰b?!Ol".8g /LH#[չRmy>Bu)M>mԢ_l,'Cj=;o:I"+To@=L郒K<_,A/H&mkn(pZOƸ%#̠?|RtTEGi duoccΆ"7sǎ-m%?L37^Q"y0'u"d'~ޒО [L^#nP^~27j6,>$ 6!N0"GƞFtJBEˠk2[k 86 N,j0U(ہKgg,iZ+H=2töbDz!Ȕ) 0a 5\rFIQ=L~j#x[r#IKwG{=wZ%6BdG锲n)2H2^Հ[ ]A46t55UA3IN&x{F[eDn6ߌP.,"GJ|K? \ONDnJǬ0jʪ%l.$t6̉(zP:҃zݝU_Ԕp?eo XdD6Qthw RckJ_cX৪5aEb;~b XwN˶A,V-//waEuVa}ďU?.ÙL,%UHGa"ё# ^hu&cGJV9%1[y &*'ZVK2e~./p1Ϡ wHpR<(rv&Uq:wE忨(;h-ϒRH.BzUtr\)NaIU?GHgͅ񺝾=Pz0hM?^)/; L A{\1Y?dcׯ"/2V':]zM:2UMmBgaX,BDoyᄬ̧ه(fG mJ4&cv*j82⍅dWh!?oR^k%)Finص]x?}DNr$]_9VR|+DNZ\~7'w&{ t3+)T`crHj{$4VhdɆ>/2&'`WGG᳸-u=y.h;p GG!|Rq7 ӼPtt Vzah[Ժ\!|XRp `nDp&H_Aa9Η`- L֟*%zp|/B.SwfpPhVi`PheYVHFC:I ijY},7܇O)lb殮lM/b3=~ UĢe1i64t0gD+].`.4#w䶭}wp|,G]MKMfCAENLxڋ-}~U\:'];AoZ'p2UdžCHӕc5 KclfQu6,U1&b?/2CO@ldfdHz}=Il8l@הITH5SΝo!Ø cv1jiSڄpd8M Ilv g_ l ow[ʎ`o~9[zyl 5QDEѩt,As{w(VW$@dC 1ۉLgtVLZ+)5流ꯙMlb.۲77'c:tnV"),ޜԍpzO9Fxkp[ЪDѾ.jKRmF|.28"e!uPen9i~y+au&H ?IhvДՕF)FGvthVFYCK"j P.4d~H[=g<:X >2`VQ?"nc#qWl2uԫ `@M9n@*ܴkGۖƪTN\|T$S{"q*Q2 oqÇ2 Kh/=*moaIQ_@N^6qYౄwODf2!Pl(һt?X{)yLSM=] D`D՛ 2Mus l}ΑBDqZ2AJ'bo)=)WnLv FY|E(=BlX,[1u&ӄZ0b_Hhn!CǨR$[:a}KKMx IjMQGC KB|"($G\YUk`JXnG_R_BXsZE\jy *CFX~t{gB|d;8%ynHǞgrWF~W χV#2]]τb Od˖cߟXf5(g6?c{RTyz KWg7=g8Oزr-wSX"d0A9&j'Pken!7`P˿͋Ft`@MU@c(M7p䏊NoAgs%6bڸOtn`rϺ16C'ߦ"Bi0?=bgVl]B5+h] 8r!e7'vAbxLK6Q!QwOxyq %}˭?RX,< |[ grȻ㶲8n 5Ҋܩ6xqA'|~>c}­㧾˰0M8M0-e vw X.iP?ЈwihBC: `&Û44ݑ;fOg~SAcY:93WT#n0묈(NMV~ $8A );"W(h3K"E_F&kv[" _[Gk^VN˷Z7W'qnvPR8{ܐ7_sPo58JSl<z2f7;mN7lCAfd Ic~vN~yvx [fiiwdV ſLFwO_ o$m͵89H-zF;C_f>2+Z BKa\'14pQLE4 T; 9?\<=GAm.epbRw!lW C %}m^< l,s^h/6^% {QeE[4xIuhн9؊ zS].6ſKK;)mHt>I@y764MEjbUi3Q63f~{ayKH ;媱 #sBI8%n1P! nzdYrsBg篨Dr=kWA)=Vd,b[}Vz'(Wo ]nH+h1 `qVJP&[GGI,1*#)q:Z:]Ӏ $^dD^G *_M 8_2;c7+ZaOd ŸwkgV|b'jyd40QMo}6bA$MS9G0c 8Zu'ho#EsSdԛPμƠZY_G=Yܪ}]Hz'#UB.y@Y T? SNv7lOtKgQA=A8B-03z İtuq fύqq) s•<`(G4̗ZGp:l3/~Qid XB)Ҏ­GG[=7ǹJ$9WUh=51k>b;Y g89q8c3$nʬI=ϙrKC,2ApvtL 1ZU.e֒Gy r[BޞXy^׮ls8I]T#6$A ">ɂR\^,oTn?OƎq%)6V5)$Cت'Gepvm# Jلʗߔֺ/D;; j oTmICV fPy:n7yl}xk-Νf Ii>$I~z[k{`@uH@KP}" — ӵSL&=ԈoL˞G#,{CZO}MD7]fy!NJSEVX!҄獘@&pSIPM>A0SbN#/ zyKARc ;ʝs$.\y^E862;L OgZ.H $:R,*x_? ՈNjeY8AXrҤ =ȱlvz0Q3D.r,OQLνodk@|b ?~\`AIL>"& y/a1aۼ_'ړ$gOaD1+&-)-?qLG=_NF}D 8 "'8bB.B+)>?ڰo5 y E2͡0 So RPUQu#"٥X][?VwmmG OzPYR쿙'Qu;>.*1M[,QP. mZ L$ELÛvTQtohTkU[+=iVhG^#0i08Vru!x T (VW{+_Y5T)YN%ßplYcR2оj/g(8.nqsar;ө{bԀ܋TV"w`L%˟13Y-jfV,U.?* ?GtKrOD9;smt.%TS6v;k7H/n #ꇐU}5H|@HzCWy@j(ʶ\蛧vg#F .0#+(vW'g^SӀ/;@SRL;unb hBzqJMɛHaLZ5.qjZܓ{|T׵$T&+*Tf 9 :׻elkl %F7fУ> 3Vg<\6R{ Y23 B,?d9&$b׎`Rl` [GD7'-rR9[BR0Xc?pcNԹUK4{'uw /c"XeQ]TOAM1ďoΪK P<yFBiII 7l]8K߻L Maj\}A]#1T׏d: Ȇh57v6tT0W< ꚤ3&4zBg>ys d @(gAL׊cRWF>@!ʮL::Szm\4m lEivG L"V'F_>hԊ6ɶ<(ӹO" 4‰>VXCĨ5[BB* ?/z1}#̲~RzNHNN69(x J2O3 ppQͲ5| %" 9޷Z(G  =2LB>݈Dxc쌵EP"KTXN .QCھRþA=8hi&hLOds=ŦK1?`% arS~j 7/O%$wn˫ja1C/Q*рRm|+qg~/GvHHi * ^1;ͬcnr֤й閏On2Ro#K VxBc\>Ў"(1;fhN'D?w|jE9od6C m;t.=l?wv J ]%H',#' ֧ 2CF^yNOXI,a}Qf0~ Gw5Wߣ3яrE}ngH3RזfDg>|S6K([LBuA4Q2m;ȓI^}A\!麬5Vj_{o7S\yX1W4 aWHu , `B>70@(iP:|-!hN(tAl(*Fs =|`Axt`ٸ"Q<"-垻32[0BٸuuW?iԥԏ6T$\0HX#3\Jlc4ȳ>xWֺkQalZB%qAͿiPnwd @yCJ,Qyע1:%Rd_Y/eP7cmg}"fIZΐtb^h>A)?eExsE|&b%n@սKxwj[y1.oAY\amWj>/>'1bֻ{iy'SIDe#%НZhMf]5/^PJ$n UW˹ vTp;-#n+B4IC,ݿP@lʨоilB 1txy(>:Fb7&fA൉DMuMMQ#,X=#SkCd6l,X8羗[uEՌ>agK8^:'!B- eG>qRX Mh)n{7Uvog(ۘ/ )zG1%Y2w׬ީ#t*J)us']qT#l|v3{+AڵZS飇y3PlxO9_3eygBhftO{;j Zμ!<.I\7戚h? 8LOO8<DAAVL0*PG޻ỲR{&>N*aT垵X+B:\YǼ|큧Gvsjm5>]f&հJߐ>Cw^ӪX@Hrވs+`~f2vW2q YZ