vsftpd-3.0.3-lp152.8.3.1<>,``v/=„FEc$~?3:?N2x /#kJcۜOnw`cXTK]lUimѼjCEArVԛLh>+cY:+"ΝW^1iR>#u%/C CҘهdg'g [$TJ뀳oEfd9?N y ?6K_ Y>ƕD '3A*C K}0C F>FXX?XHd   I (L ee  %8`8 8 @8  8 8 888 ( L8!,!\#!#$)#($u8$|&9%&:(D&=I>I?J@JFJGJ,8HK 8IK8XL$YL4\Ll8]ML8^OubR7cRdSeSfSlSuS8vTwU8xV8yWzWWWXXDCvsftpd3.0.3lp152.8.3.1Very Secure FTP Daemon - Written from ScratchVsftpd is an FTP server, or daemon. The "vs" stands for Very Secure. Obviously this is not a guarantee, but the entire codebase was written with security in mind, and carefully designed to be resilient to attack. Recent evidence suggests that vsftpd is also extremely fast (and this is before any explicit performance tuning!). In tests against wu-ftpd, vsftpd was always faster, supporting over twice as many users in some tests.`vlamb05openSUSE Leap 15.2openSUSESUSE-GPL-2.0-with-openssl-exceptionhttp://bugs.opensuse.orgProductivity/Networking/Ftp/Servershttps://security.appspot.com/vsftpd.htmllinuxi586getent passwd ftpsecure >/dev/null || useradd -r -g nobody -s /bin/false -c "Secure FTP User" -d /var/lib/empty ftpsecure if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : for service in vsftpd.service vsftpd.socket ; do sysv_service=${service%.*} if [ ! -e /usr/lib/systemd/system/$service ] && [ ! -e /etc/init.d/$sysv_service ]; then mkdir -p /run/systemd/rpm/needs-preset touch /run/systemd/rpm/needs-preset/$service elif [ -e /etc/init.d/$sysv_service ] && [ ! -e /var/lib/systemd/migrated/$sysv_service ]; then /usr/sbin/systemd-sysv-convert --save $sysv_service || : mkdir -p /run/systemd/rpm/needs-sysv-convert touch /run/systemd/rpm/needs-sysv-convert/$service fi done fi if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$YAST_IS_RUNNING" != "instsys" ]; then /usr/bin/systemctl daemon-reload || : fi for service in vsftpd.service vsftpd.socket ; do sysv_service=${service%.*} if [ -e /run/systemd/rpm/needs-preset/$service ]; then /usr/bin/systemctl preset $service || : rm "/run/systemd/rpm/needs-preset/$service" || : elif [ -e /run/systemd/rpm/needs-sysv-convert/$service ]; then /usr/sbin/systemd-sysv-convert --apply $sysv_service || : rm "/run/systemd/rpm/needs-sysv-convert/$service" || : touch /var/lib/systemd/migrated/$sysv_service || : fi done fi test -f /usr/bin/firewall-cmd && firewall-cmd --reload --quiet || : test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ "$FIRST_ARG" -eq 0 -a -x /usr/bin/systemctl ]; then # Package removal, not upgrade /usr/bin/systemctl --no-reload disable vsftpd.service vsftpd.socket || : ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_STOP_ON_REMOVAL" && . /etc/sysconfig/services test "$DISABLE_STOP_ON_REMOVAL" = yes -o \ "$DISABLE_STOP_ON_REMOVAL" = 1 && exit 0 /usr/bin/systemctl stop vsftpd.service vsftpd.socket ) || : fi test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ $1 -eq 0 ]; then # Package removal for service in vsftpd.service vsftpd.socket ; do sysv_service="${service%.*}" rm "/var/lib/systemd/migrated/$sysv_service" || : done fi if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi if [ "$FIRST_ARG" -ge 1 ]; then # Package upgrade, not uninstall if [ -x /usr/bin/systemctl ]; then ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_RESTART_ON_UPDATE" && . /etc/sysconfig/services test "$DISABLE_RESTART_ON_UPDATE" = yes -o \ "$DISABLE_RESTART_ON_UPDATE" = 1 && exit 0 /usr/bin/systemctl try-restart vsftpd.service vsftpd.socket ) || : fi fimJ>hLp6 5/pe2Q$p}6)Gp8+AA큤A큤AA큤A큤A큤A큤A큤A큤A큤AA큤`v`v`v`v`v`v`v`v`v`v`v`vGǿOrUSGGGGGGGGGGGGGG`vGGG`vGGNUp`vGGǿJ`iJ`hGGGGGǿO|G`v`vGG`v`vd924ad4270611a453564df16c199410d08ecb3544ba19db19f3b12645a68859aa56c55569c44f61aeee475344dce61f4ea18df08c26782a1013f78a0f14d9a0b54a2643bf511596dabed3454abb2bd3774041a5d3b90044cf015e6e60469e6fcff59cefeded709da635c1212256e6d417d82fa456319f90e4db85ddb03f7d1a25a2a2b1b89b10cc22c9baaf7d55dc1cbc7d19c0c93601878beaba807f58f1e3a9fdbfd2ec0207170371ca3cf2b0ddca2dc2fe3d062e5792e0d3e51474c3198c96f5f21db930b9a8d89b56a6654780954bdc2a41d2bc9529c0b8efb3817c45ef189bbe0f164ebff26fcd08acf8c5a84f2381e5a4271f279262ec95499d33c95537dedf833fb8a3bcfa96b48d309f3892b3ae3340d271e518ecd998750fe11a0b74690662cf0bbf289900b0ddb4c2e0cfc555dda870633440d852f7d4b1b783d61b94af32e64a236252236cc554051cafe52751b96b0838ddf82033168f33702ea8b12b05b7d664e344d4d59a26c3f6b13c645f1b53ce6045780791350b278606b4326d89a39bea92a0dbcaaee0f658d7bf810c8f322688b6b1303f3b357a0971ffb26bd0055e5875fb2d1083326b272685de7b017da65000a21f99081c1a300156ed67ebc32ca688633732308ba23c7601a463df9a8f6d4d349cf1e0fc770c8f5ee162751cf714e1ab6b5894fd08b0a95e788a462311cf7da47988ee5fa55aa6247ffd29f468e22eb304a368bb987510fd44f0486894de293dc7dbd3d48e78f5c4935bc943f442e358d7a9c81f4ce2ae1ec098543e726868d423eac55beb91b7b87274257549cc60d5fd2d873326b22eb89a4d8199bb5841fed3bf6c82b5494f2519b63d63c4f1517a1e7cf3373f19df4c8a697d1823814f425340bbebf5fa8f17dad436bf918a2f81a540847a9a46946370c2d796ffd5bb5d98cb8a69b2e926e181e70be2fcc7d0dbf34f8626e2e026b10ee91108f84dea93670caac57b394c2182acb8b70a360dda945df11a1598cf493774f017db569a57f07447119bb0713c55f01df06b2d4ef2c26d0d679c6782a60331fcb0f3991d0015458820819893b60b8129dd74b2e4779f1ac8344127e47a7847584b8cd79eb36a055208ca553e3517941f8d5bbb5970cedbef05d0593cada2185557053b9574c11524841d80749eb5f86e9731c2ba8801f018680be063040ecf60be710ca3db3742bddcec1834961de85b72629f20996b3124be21877871518388548636459df9ad6cb5a3e31ba1f0b372b2f63fc08f5e195f0d1e958dfed03c57d8868a3f90317bcb3125852289cf0afbf0552928f37cd4b068a2cc039f4200175d65dcead6701de158a17c95797d0cab32f477176059b7799b3f92c90136440aa84ee7c5005f0d964a311df66595fd71183207e0297b8ea5d1f0f2ad1681e16c1df530ac11844e7fa010e7d5490c4a70c9df7c3b090e7a1822f3bb0cdff5a559a4cdd58f98c9536f23c5f43ba47a2ac8924cec7a864d3482f2fdb9bbef552c8c0123b8647b6ccbfc2d3cf717c0662397b33b84f9827d238703e7ac36fa9f129fa227640956bbf87e0233cdd821ce6627358df144f933424c8b81c40d70729bed51f634c6205ac6b8da43eec413bc084f62d987705c810dc2512fd4eec4269ae5e1373c19b9b21e5e089f31e173f54cac8362cd97c646c8e034e4676c2a053660b033e2011fe24297e93e0a74ec9cf119e2f9dbcf187fb805ba5aded105db26a693803636fb7228c98460ffbf22225485a2ca5e00cafd96ecb4336cfd34dc6064ec16f560c1d7b26d213de6e81bfc9c4e1891cf03481b69515e0dbc4849c6dea1739db4cb71a25c833ce8463056477bf3ae7199ce5c0604dc83fb34b04de1f91f96929532c4918c32caaf94bbaservicerootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootvsftpd-3.0.3-lp152.8.3.1.src.rpmconfig(vsftpd)ftp-servervsftpdvsftpd(x86-32) @@@@@@@@@@@@@@@@@    /bin/sh/bin/sh/bin/sh/bin/shconfig(vsftpd)group(nobody)group(nobody)libc.so.6libc.so.6(GLIBC_2.0)libc.so.6(GLIBC_2.1)libc.so.6(GLIBC_2.1.3)libc.so.6(GLIBC_2.15)libc.so.6(GLIBC_2.2)libc.so.6(GLIBC_2.3)libc.so.6(GLIBC_2.3.4)libc.so.6(GLIBC_2.4)libc.so.6(GLIBC_2.7)libcap.so.2libcrypto.so.1.1libcrypto.so.1.1(OPENSSL_1_1_0)libpam.so.0libpam.so.0(LIBPAM_1.0)libssl.so.1.1libssl.so.1.1(OPENSSL_1_1_0)logrotaterpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)shadowsystemdsystemdsystemdsystemduser(ftp)3.0.3-lp152.8.3.13.0.4-14.6.0-14.0-15.2-14.14.1_@_u@_=@]@]@]@[ @[4[+@Z@ZmZlZ1@Y4YA%@Y>@Y.@YtW@WWV@V3V@VaU@U@UUJ@U0U!#U@U@U@U@T!T@TeIsmail Dönmez psimons@suse.comDominique Leuenberger Josef Möllers Peter Simons Dominique Leuenberger Christian Boltz psimons@suse.compsimons@suse.compsimons@suse.compsimons@suse.comvcizek@suse.comtchvatal@suse.compsimons@suse.comtchvatal@suse.comdaniel.molkentin@suse.compsimons@suse.comkukuk@suse.depsimons@suse.comdimstar@opensuse.orgtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comjcejka@suse.comtchvatal@suse.comjoop.boonen@opensuse.orgtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comdimstar@opensuse.org- Add seccomp-fixes.patch to allow getdents64 syscall in seccomp sandbox, fixes bsc#1179553 Also in the same patch, fix the architecture offset from 4 to 5, this change was documented in https://lore.kernel.org/patchwork/patch/554803/- Apply "0001-Introduce-TLSv1.1-and-TLSv1.2-options.patch" and "0001-When-handling-FEAT-command-check-ssl_tlsv1_1-and-ssl.patch", which add the "ssl_tlsv1_1" and "ssl_tlsv1_2" options to the configuration file. Both options default to true. [SLE-4182]- Use %{_prefix}/lib instead of misused %{_libexecdir}.- Add pam_keyinit.so to PAM config file. [vsftpd.pam, bsc#1144062]- Apply "vsftpd-avoid-bogus-ssl-write.patch" to fix a segmentation fault that occurred while trying to write to an invalid TLS context. [bsc#1125951]- BuildRequire pkgconfig(systemd) instead of systemd: allow OBS to shortcut the build queues by allowing usage of systemd-mini- firewall-macros should be BuildRequires, not Requires(post) (the macro gets expanded during package build)- Extend "vsftpd-3.0.3-address_space_limit.patch" to mention the new 'address_space_limit' option in the installed vsftpd.conf(5) man page. [bsc#1075060]- Apply "vsftpd-support-dsa-only-setups.patch" to disable the problematic default setting for rsa_cert_file. Upstream initializes that value to "/usr/share/ssl/certs/vsftpd.pem" and vsftpd won't start up if that file does not exist (or if it does not contain an RSA certificate). Therefore, users who copy a DSA certificate into that location or properly configure a DSA certificate via dsa_cert_file without explicitly disabling the RSA certificate won't be able to start vsftpd. [bsc#975538]- Don't start/stop parameterized systemd units in pre/post actions. These units cannot be used without an explicit parameter and attempts to do so lead to a confusing "failed to try-restart" error message. [bsc#1093179, bsc#1010177]- vsftpd-enable-syscalls-needed-by-sle15.patch: Enable wait4(), sysinfo(), and shutdown() syscalls in seccomp sandbox. These are required for the daemon to work properly on SLE-15. [bsc#1089088]- Add firewalld service file (bsc#1083705)- Make sure to also require group nobody and user ftp bsc#1070653- Add "vsftpd-die-with-session.patch" to fix a bug in vsftpd that would cause SSL protocol errors, aborting the connection, whenever system errors occurred that were supposed to be non-fatal. [bsc#1044292] - Add "vsftpd-mdtm-in-utc.patch" to fix interoperability issue with various ftp clients that arose when vsftpd is configured with option "use_localtime=YES". Basically, it's fine to use local time stamps in directory listings, but responding to MDTM commands with any time zone other than UTC directly violates RFC3659 and leads FTP clients to misinterpret the file's time stamp. [bsc#1024961] - Add "vsftpd-append-seek-pipe.patch" to allow the FTP server to append to a file system pipe. [bsc#1048427] - Add "vsftpd-3.0.3-address_space_limit.patch" to create the new configuration option "address_space_limit", which determines the memory limit vsftpd configures for its own process (given in bytes). The previously hard-coded limit (100 MB) may not be sufficient for vsftpd servers running with certain PAM modules enabled, and in such cases administrators may wish to raise the limit to match their system's requirements. [bsc#1042137] - Don't rely on the vsf_findlibs.sh script to figure out the list of libraries the build needs to link. The script is wildly unreliable and it's hard to predict what results it will produce. Also, the results it *does* produce are invisble in the build log. We stumbled across this issue when vsftpd suddendly had build failures on i586 platforms because the script decided to try and link "-lnsl" even though the library was neither installed nor required. - Drop the explicit specification of the LDFLAGS and LINK variables from the call to make. The value of LDFLAGS we passed is the default anyway and giving LINK has no effect since it's not used anywhere in the Makefile.- Conditionally install xinetd service only on older releases * On current distributions we support the same functionality via systemd socket activation- Fix build against OpenSSL 1.1. Remove lock on 1.0.x libs adds vsftpd-3.0.3-build-with-openssl-1.1.patch (bsc#1042673)- Explicitly depend on OpenSSL version 1.0.x since vsftpd doesn't compile against the API provided by newer versions.- Adjust to new system user/group RPMs- Add vsftpd-3.0.2-fix-chown-uploads.patch to fix a bug in vsftpd where files uploaded by an anonymous user could not be chown()ed to the desired UID as specified in the daemon's configuration file. [bnc#996370]- Extend vsftpd-2.0.4-lib64.diff to also find libcap.so.* in /usr/lib64.- Do not bother with omc xml configs, useless nowdays- Require shadow and do not output the error out of useradd- Fix user creation to not report error when user alredy exist bnc#972169- Fix bnc#970982 hanging on pam_exec in pam.d * Add patch vsftpd-3.0.2-wnohang.patch- Fix memory leaks in ls.c bnc#968138 * Add patch vsftpd-ls-memleak.patch * Update patch vsftpd-path-normalize.patch - Fix wildcard ? matching bnc#969411 * Update patch vsftpd-2.3.4-sqb.patch- Clean-up the init.d support to be bit more readable and add missing dep- Brought back additional systemv support so it also builds for SLES 10 and 11- Version bump to 3.0.3: * Increase VSFTP_AS_LIMIT to 200MB; various reports. * Make the PWD response more RFC compliant; report from Barry Kelly . * Remove the trailing period from EPSV response to work around BT Internet issues; report from Tim Bishop . * Fix syslog_enable issues vs. seccomp filtering. Report from Michal Vyskocil . At least, syslogging seems to work on my Fedora now. * Allow gettimeofday() in the seccomp sandbox. I can't repro failures, but I probably have a different distro / libc / etc. and there are multiple reports. * Some kernels support PR_SET_NO_NEW_PRIVS but not PR_SET_SECCOMP, so handle this case gracefully. Report from Vasily Averin . * List the TLS1.2 cipher AES128-GCM-SHA256 as first preference by default. * Make some compile-time SSL defaults (such as correct client shutdown handling) stricter. * Disable Nagle algorithm during SSL data connection shutdown, to avoid 200ms delays. From Tim Kosse . * Kill the FTP session if we see HTTP protocol commands, to avoid cross-protocol attacks. A report from Jann Horn . * Kill the FTP session if we see session re-use failure. A report from Tim Kosse . * Enable ECDHE, Tim Kosse . * Default cipher list is now just ECDHE-RSA-AES256-GCM-SHA384. * Minor SSL logging improvements. * Un-default tunable_strict_ssl_write_shutdown again. We still have tunable_strict_ssl_read_eof defaulted now, which is the important one to prove upload integrity. - Drop patch vsftpd-allow-dev-log-socket.patch should be included upstream, se above bullet with mvyskocil's email- Fix logrotate script to not fail when vsftpd is not running, bnc#935279- Fix hide_file option wrt bnc#927612: * vsftpd-path-normalize.patch- bnc#925963 stat is sometimes run on wrong path and results with ENOENT, ensure we sent both dir+file to filter verification: * vsftpd-path-normalize.patch- Update patch bit more for sanity checks. Done by rsassu@suse.de: * vsftpd-path-normalize.patch- Add back patch attempting to fix bnc#900326 bnc#915522 and bnc#922538: * vsftpd-path-normalize.patch- Reset filter patch to match fedora, my work will be restarted in one-off patch to make the changes stand out. Add rest of RH filtering patches: * vsftpd-2.2.0-wildchar.patch * vsftpd-2.3.4-sqb.patch * vsftpd-2.1.0-filter.patch- Work on the filter patch and split out the normalisation of the path to separate str function, currently commented out so I avoid huge diffing. * vsftpd-2.1.0-filter.patch- Add service calls for other unit files too - Udate filter patch to work as expected: * vsftpd-2.1.0-filter.patch- Try to fix deny_file parsing to do more what is expected. Taken from fedora. bnc#900326 bnc#915522 CVE-2015-1419 * vsftpd-2.1.0-filter.patch- No longer perform gpg validation; osc source_validator does it implicit: + Drop gpg-offline BuildRequires. + No longer execute gpg_verify./bin/sh/bin/sh/bin/sh/bin/shlamb05 1618402292  !"#$%&'()*+,-./0123456783.0.3-lp152.8.3.13.0.3-lp152.8.3.13.0.3-lp152.8.3.1     vsftpdvsftpdvsftpd.conffirewalldservicesvsftpd.xmlvsftpd.servicevsftpd.socketvsftpd@.servicercvsftpdvsftpdvsftpdAUDITBUGSChangelogEXAMPLEINTERNET_SITEREADMEvsftpd.confvsftpd.xinetdINTERNET_SITE_NOINETDREADMEvsftpd.confPER_IP_CONFIGREADMEhosts.allowREADMEVIRTUAL_HOSTSREADMEVIRTUAL_USERSREADMElogins.txtvsftpd.confvsftpd.pamVIRTUAL_USERS_2READMEFAQREADMEREADME.SUSEREADME.securityREWARDSECURITYDESIGNIMPLEMENTATIONOVERVIEWTRUSTSIZESPEEDTODOTUNINGemptyvsftpdCOPYINGLICENSEvsftpd.conf.5.gzvsftpd.8.gz/etc/logrotate.d//etc/pam.d//etc//usr/lib//usr/lib/firewalld//usr/lib/firewalld/services//usr/lib/systemd/system//usr/sbin//usr/share/doc/packages//usr/share/doc/packages/vsftpd//usr/share/doc/packages/vsftpd/EXAMPLE//usr/share/doc/packages/vsftpd/EXAMPLE/INTERNET_SITE//usr/share/doc/packages/vsftpd/EXAMPLE/INTERNET_SITE_NOINETD//usr/share/doc/packages/vsftpd/EXAMPLE/PER_IP_CONFIG//usr/share/doc/packages/vsftpd/EXAMPLE/VIRTUAL_HOSTS//usr/share/doc/packages/vsftpd/EXAMPLE/VIRTUAL_USERS//usr/share/doc/packages/vsftpd/EXAMPLE/VIRTUAL_USERS_2//usr/share/doc/packages/vsftpd/SECURITY//usr/share//usr/share/licenses//usr/share/licenses/vsftpd//usr/share/man/man5//usr/share/man/man8/-fomit-frame-pointer -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:16080/openSUSE_Leap_15.2_Update/054de2f7e2c034ab522d7969881c500d-vsftpd.openSUSE_Leap_15.2_Updatedrpmxz5i586-suse-linuxASCII textdirectoryXML 1.0 document, ASCII textELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.2, BuildID[sha1]=35026e4ee51531e303680f2bb837ae4662134602, for GNU/Linux 3.2.0, strippedISO-8859 texttroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)RRRR R RRRR R R RRRRRRG[I{ҥDǽÓ6utf-804c49dce3627b3cd4f0f7a61fc92be67beaed330cfdc147b756c9b3c180c5a9c?7zXZ !t/d@]"k%fF1j(}̛.ox־؟KĆ5Cxq_ }z^55 ~+}^04<3MMDqnYS_v R(pebNJ(dR)7 _?^i`+KVl=tǖ$#aۣ *% V?xk2&Gb]kbH؉99y.2 8sFH]W0>sMGBEcb3MTVUlgoZqkB@<2Eq$ēĉ*De.7\2PX=AdH/ʃ-(_toN43wXqo+OŲ($qq;[i,M`$H>ܣŬy&t:(C@C ϹDC'':IB |;O0G܀@dAt{=ґy=:/7{׫į Os/TuKd<luGv)\3| ).aDhm!s@ٖ=Тpq}Ql1!YѰ l rIucEd5#<*]2X-Ghexk32,9ڜU P $K?ըv],a XoJOѹR4Kəl#]0 Gy,~דa_g57V" Zvˆ.5Xi$ʗbo7ѡBSXES$$ LO@mذ[}N@CC^v)?$ N~Ox|@|G7`'Mr.1pM4}}m*4BW4{),eڹEArCN"J ynΟD3I}䌖Q ;4]9OdpS%V.k}x`}I#* |ÿ]@q ?mWdolMm\4Þ|+ĩF_8nG%R$:"[>0Nx1oeqȝ3&Izio}7'9u-/`KQrA7#z([^T+lМoǺC:9G$d=#7Հ{|5m=®`w OK 48O`HT> P0 x ^k0,q,XW1P7a᫠vbPy)D8ugp]5_DO:)V&a~mXmХ5?B.}t9 B t,Cwxz5bs.,u\}PB/HVB; #ɘ0*Kȩ?6<M "FFlԏ,kvGT1}Jln$<$6Zl$x4;EtH1qj˸9 2}o%$lڧaQJ_(DRh+AD؍k,p %'8Q`)mʨy]].N>/|!BjIAiA=Pmx/:}g&VlLv47,^C S =:B\dCz 3}RK-om {D(7H/?G~`SdV~y} F# }cdK_Ս1װ&v zY:Q5 . „@F_[GkSu!P>iE "WqC Wp5h#ϫ `U2_/Z5jl\s*ow(=OEPFTIY>M3XɎ br<0Ix :! oS!Md.Zu[2\ru]&?/Pf?~hf 9<0ӓ e7w_/ B(Y&ZqT NoӨ#b/>ՅTp0ḑu~MUӅ<-;L#@=7e5Cۘ;K[[)~%ZV\9KF,"^+JwhiHkSy(\Clm[ P'  ,br /JV^O[;Yz}x nOiZ>ھx1d ze?']' xէ(syfBGy_v"ܝ7}vQGY%)4W_Cv Y=g~iA cjͻjŇJ$Y:=$`^p‡}e66HOcyoC[X:yI%*Z[a1N VXI; t;RF|$4s$,~SXKya $ƍ1;èw#SU|Qo\LL|8Iۨ7 gYH>Z)Pn^%!Dž ˩cEɦm/!V!o4aea‡ OJj*@!Iy$mEwDF|lra*j#Hd$b'ZyFX<\sgR_ :V7UdOXoXߢWLgD0tE`o ڹhCuZ !i3{Y;\Y]QJ]>iF%Ud$JLW/HFSpP۱k6[pL}NfgH¼, ]< xu6hL~pie?(f$ĖfTh/`O)71]ZjcDTS#vw:& @V{ ӈ1U k{+&VXToA6h>Xn#k+C׷gߚKCܥ/aQ9At.ȕU.~0o0YTO5ڗ晾 `2Y'R?w0y3vmnhWarȵ  62F:2cdKy;u*Y7%J8"qpmr}D=`8(*( HNїTbڲFquLoy¿Yș[d푻:1=8%9K5Fi1EUGrvm"6Wgm(;IiY;B,ӻ|˽F{*Kc"jyÅ 9؜6cpB~m۟ą-Pq`T'"aՊw t$1BLYSj89qFWޣ,ק~G˫-^ЂxwH6R ,K+# R^\੖.whGhOE:èVеJӫӇ$̖u>}0|wi=J<| h z3"ߺWF4fBU/l.iΣ A]ogu3-h\ꋱ~S.#cvN#J"W׸d-WJ!~=t52 m#"[&ʃC o"#8XXGe.22N Rx|lcbRM+yɝ3Vp#ª0uˤ%&*]u7QԆ3j>l*&9yxU8فH@Lr%W,Wֆ(y}^jDsh'].ģїB,j`1F"ftR%ة.n*UPTi5V5˛PdLu}ń$ϫ\O:̦YK~v%#x)rN4Jnv((^`ZTV$ ƙ9l!0 XC (C6~QvNTj({ ,{kvCpWNn+~ l!nfvQ7O?&i8BMC Kk ֒9q; QkΠ.mf#RCt< ֏_A〹YPw0ߨ N [z& li1K#ec +&YHlf3qP}g$px{5- uc we'q.hOL/tV71B>,P} yx[`f˛Y0(9xqh3coqa% ٖoL7S~T@v2B(P[H&lBr_SF!KLߖ}6(1"द` =*H>5+wﯥwctⳟ2h<k\n^Vֹ3uBw>ǫʬkLDXJ> VWe,Xw݂]C䞷?Z,8\8s`/LxA²J}:}]E3s+MnGz,v(4+GD=#,t~Ȩ|BHdף 9&CK!* _!+Cȵck[QVGeINa#4mK?p`+J ̲'rLT׵sU~4$-kMl}ȸ8[p͹G ӑ̹}["Ei_:FZ6꿃k[%34 ~x솸W91ߣὰW9rƒ5i-J,(䀻Ae;9<~=f2WIbw2k -IJ8F23̙dM/6ZM56̮>Q,:J!Ԗ}m걤Ul*m4-+l:K&(«RUcٚM8`{*^Ii{{AEλCndݛ=(=0zU/T8f˰ uYhC/L oGx#a(ݖai·d,`S'ô| >쁍y+;|`cvsN"Mrl;EKg3Apί-R>m)oYP%!~-o*8a ^E ?C* @S,]=RK0fv[ }W 7*p!o [SshaԏSn ey}BܝzUxZL"Vq~ |7\EuS;"$@(bhְ#U,YŨrP Q&43W՜VD*BLZ-bx2׺UW0.T^S_M4!%Y;g39.4=HTd!?ѵV΁ H7 \ȮxMǘE^G'0$e*l(*x66a53GJ"H,-`݄42! INQʧ-iϏnUk?$KPA)NʶiY0%VW["^$$yEqib\q-h\>\n 2lzyiž&T ǨɕQk83T:/O +ޒM7j6ի[”eT6yK{:҆9| aiD|(ؘRhe1!OȽu >e :X/,ר/ceZ%$26({lv2n@gTZbiozfen*٠'UZbu'f/@ȣB^1RoEx5__N;/H v6_hL 2dCM7%P{2A !}@O0 X>!g(OBYYM6OfF;M\ȕW O*SO:'{莫: @.Vj! @*%5n4u)2] =^ҳcׂ=⟉^Fsǭ5?lz‰.Ҩ^nv^b3?`Ju57΢2?^ݔy]uzxc݊e^ZU5O1[3 ev{2@fB~* ҃`~1a xҕ0wwə'_Ysb}߆]M|0d#YV+Coo+Puf.H}Bi//u]3+M[K9C_3D:ӤpOMfUx. 6fBgBAj5Rf#_HZƇJ@i~uI+@#@Ml,\Wy5΃ͶSwJ)<:(zPK) 6U l'M`OȂEMK50(һHr:m<.O]5E?#hM]VXJ]}"#|sqȋl^.6=oߊb7&{n13٤TZ¿PC{Kv1+u~KʭlxW`4~ى%Ea|郛jacEMVPs]p'DHgݐ3;{L7;CDmZLZklJ.d/?3NN.PrlO;I7&/ օӵf9 U[#4vd27xzJyWsSGwX̝>)UT\ԭe#UIճ쏦m`G \)q9Fj2o?4g}~{+, jr:VrVt*㐢W#FŽC(* Lc,GnY7熰D?C5a$wVy& o|EQ%dZԐ^ZB{L& E̅N$MI4IOras$8%L伌&a t1!Ԝ@CB[L8{K8cB֝´lt^,K l ٌ֕ONl&Ȃ.<x,x`9tRGLO!Ekd bF™124c7 *A3Vț咆yXQ"mۛ4Txp1skuVӅL20t pY7 i4زB(l3 })3+!h`Jӷ{ Y,E{UϪrF:QLlBڍ?eC3A* )3π$h謵v0wbS4E~ m9s qK&r2v'ظq9GhGuPX{w'ihU<h rrW@ŭ+Ȧ_]Apkoyn㉲ X6T-Uh둼%bB )f"c.ږ ({kd{ [T/fm4=U.ԺAXn",zXiv&-(xIi3OҍQ] n[J!m9O:`ѿtl9swM3j n@->’ȴP TD4}}dOVdAh:hZʍt6OY;ۏтw3 i?An9ȇtϬ](' ?Q+ʡHQ8^SX`qPbЀg65 )wiH@71 <[ܱմ+SQJ2&N#5,c`9/0\ gn8ḝi鹘j5DdByi_UnR*qg~"v\*cvf ԥkʺUP<ӭѤ=*I3 Ex% ,bcc6#Ȫ<mͺL]vA\Jkr.Q|(-Q7?;E8')>\?JiSb™C#lz2%G pheXbOd,c%WkB Ђ@+:W3Wrkf6&r "ĨG\b{c%K`REZ>\ PDA1q7tRU+X,\Ꮜ"_|4煊KaCKlO$>2h"dDȩ(@(V7B$ OSvM(]HwY4OIWV 4әɄؔX9(ëԤhqm. h|c:aKa %f$<*3/lDv"TD"coj^ϗtZj7uƬ^'#67mDn}'bϋVd9Q,(pe- :}> C ؟(ю-::A M& z N~f%1gÃpC7']HSٮO8C@;׃x=TT & ?!fuVN L(q!IGC2qe!\5}gr\w+ p.\dê:5ѻ::K6s,̅3 \3K@X.6,=!=U*ABׇUl.r5(ٔÓ?,zk(A a Dsk`nNўCD+0UFFbN}nQ>OgBtНyϲ$E vO,/?eG\cRv#ϢEc ˢ9qCiuasͫ@Z. o DT cOt94D&EeJ4dsej>BGNbpeCyQ .v}1 .$`F`4~aۧ+[ OC<*czMr*!b#ք/ĩ<"v/3>dWm`Lp|4^;0X٬^O%\5Az}1tB~G)q706.~e-.%mT$7-ݚҽYXAW1-!>l>|QOz>oԭ (45!U1`e!>=-O:fэj`#J݇ ʮf|;Aθtv/1y&mdfvLGt V yZKCޥHVZ͡Ͷھ. %Cn2OΣƾDk2I!+2;h9ʃ2#PPnՠ (~h1hqumECji5h/f`mg|)uey=?) &F'=}X[-@RЁwHW:-s #wZ} m_v`gQiBpM1,ݛ&)3R8%(όЅ;4W\+s*P_B8WѡP}GAuy{6(7.1mO=x#%8X\Cw"Ju{ȠF(.SN\īd v5Ɍ #E [ pG[z757st\}#ƪ{Tg? T]X\4 h'A\'4ɧ-ZA="I, $Ygq uLZ(/ϵh$hFYezуꇽU>$56ZfAW4A&F z*NɊxng #jGȱhz^[# ԡ8u"ʔnJ|7-#jJ`a^95I3VkM6Rsg[^%8;T\~b/i>XYfZg#E x!vnKeP$ yPPoGۄQa}{&y#j(`z~4DG|x1bFb-Ifo'YXn*T*ZzΨj1|1,x윞f RadB\NVoYl_8!sx g C# 4iy]GNfu+DK"Y&UVA|#Y ulO|DTxvHr ɥqAJ Hfޅ*~tX"f޶ϲ"臛M}bw!6Vvm R퓎"u #7Fc|7Ú4-@Pqʰa F;okeE[=ݬSG[)T_併EXy|bvث"!eFz5#B}Wc`ˎX" Rj0#у7(Gkst|8O="pMTy{Y)y qG5݄bEqL?_]!W1iJX唼)iD+/B,Sv7-~`׍F~@W ] U$9M!sd7$U=gdl:})hBj$eәHEQQ%T>TR/HyIRT7N>{Z_kRr扮_n'm> KԵ') `(+G1md ҿE4 >_)|mzWsߘrHU8ujRfNI SŠ>.xH] C$wXNK{:|LcV5q=^GƄ̳+D7f;»FvX'$ f p\TT{zMgWx h; UC1tz6K~$8%7O[&+n+8J$+:❮,) luZ(a$,JAO1KlLLI:aVe^DDxUK?.{ΰ y@`njfǟ')22KD*`A3ș6g0uhՁ/Ze,;Aۈ]a3DWP]n^JQh=^T N{b/'Rao^v"뚌brN:NTV$- e@kPw973wx?fcm:d\B`tˇ8LKAfc[C3;Edx ȼBնv~X\> 绽fאWX<NpFDXJmӰipfWkG4xAi^g BMvg!V&>.}t5CSӍC}$ (!Y'4:+<2[6Rq^h~& Yg!'r"V>Wxqiok:ї^ ],}j?20[!=f{x_I ']D9#S+:^l dl+RM$$J+M,wWVi؊k.Rr c  v8ψ V@SGPK'o-lCUZ 7yƝ٭K7apAiL e4-iNA3NC[|5* ;}, ٣jF/cz,L9ظ9V'xΔJ@>3 Zlg?O ccħšp{*^R6pX_ڒ葤;}ʩ#jw]zgלJ#niXDɜ8m%U6K8s^5z;ZF܂*{. ^Ű'fe7Ak(?y$sd{T#~$rӟ!:D@ц`fqP%4F&7DnLN'HLff7 ⁩"ޒ3^ ʏƦo$DVZ E%=cn?;*cT@*@c8$$kح3]Xϫ Ky%`#f}kL":}ܦEI}O \3- Td!Ь(6I&D9nk{tzCljrK")$yF>lLr\a o6c NqB*?C)bDR !jPEX//ߋ=nYn ^ToT;u2`NhuB3{?-F_ wLw6Y['2Fڝ*%D\w{o]AK\MC7`O^Phq "5mn 0fK݌睌G2;8EV ջ8`BS=-[ FCֱY$o?w Q.ylUN֙_lgfVxlgcW {c/in+ϒ9Yy PqfՋA8emҔ,N% H1n^TL \a4XLy풕vy8“yYr7&e^1'=]'T41J }}d-؝ux)$W`|B 2?B$fh} >[S* MT 5;4EG+ToV#lcTSD/yxW?\.?0a| nuxuX0͙|^]$O댭Cb$ZD2z?k~, K[}}R8('+N/%Csa_QԴSb,*eD_^'i8J7Rz/p79\S;P@ے#:gG*5csnWA(qe V(РᏙp`Sʡ} t I:5"e9M뵝kD $Z g!vHI_w1_@PJ\T.y3%^CpDN7·gr0b(Ϝ% >cIe߉'촱ƂA: B|3m6bou8p,?e'v-?[&1V0,pzjHjT._C4 (3(=uG"<过ޚɖ YI=ZVfG-arǫK\i% v}G:M4F,B`&PVhk̀szU^\*2tup4v+tˊ蓱 kj>a$ϝձ4UI{ &7-CQa$`-ra[܆9Qh *<;4*'-C3m ~~Zoln PB O&K3!я ߅V})wzH P"Ţ<Y^OM{Xx%^Fx#&8Aj$M2*sDG^}/Uي} Tt,O-eF8N_7>n&!qXD CX|S؛ |:cJhoTa+ ;sk '=yBuA H侖Ev hl-h?^gܥvU~M~ŊҘqh)>Iy' Úݲ$; :{OAw-$.sREJ!L ^rocYԞO(lp(T ˘]-YaGEAƪ+>#2$&mf-F*d\ a@ƿ`' $#GT B藔yS*?djn_v/gUfþ\SYǙ97si353RikBUwr\j9>1[SJ2^Job9x Y#%XBA|- yXME(5BR)\j{|RwI+ɺX씴 C?er;y#+J*Lt{T` Y&+Qp& "رpԒHɉT';wء(?ك^2j0E_t LOM.AZODAix!/\4vy2[HY ![VxY.l8Hc %?#"Ibm6Zlv7m te- iNkE#4,O簯as^jx:Ռ$UIT]BIŽ{ =rJP^UǢ_@ XsO3O"j$fѐ'hIC&ۊsOv5]J#`UA#(#́hFPħ23. !gh04eF/.vS0H*.J+7^ 5Dc+o2y`ҝsBYQagKia:xUl㥕0dtz[~F-'M<[ͷSݱm ;htWߡ& Y.m {i릜:V ãCb.4f>t!p;/* â"BMX2﹦Z]I\KkPꘆ*}W2u"2Tdu sd5_Qa#oX=fm:)2a8/]c"yb GHU7 r|%E9µkRdA:Gm7A#N9Yʗq p)7ui" wϻvLG5hDĖO]8Uh~gV˯+59jfQas,.ڢU2G Q8B^j쯲^@$d%\!/>2]nqٜPҨd2pz^D.exW㳙!X#hCʎ״/TrPRlϾCFJ30aXNNa?ʂBu Q.#eyic9VܛZ%R{alwQ͓D٨ά_(ZN-4'E!Q`JۮVW2&ro}/wp/=)aH(I3+*exD,ŒNvӴ?羮z۪r4#Ȋd-D;}8μ[s; ?< c5iOcj6N|%6`@@x֣o tOk|?uo*AM{)Q/pbwȩϸ;T% X)/ '6@wLŒU9qTLkˡo[17{l<mO\ԭr&$5?lѮm-aPw$RS ĬWXkѻx*=B_m'duġ a znTZQDT!8њ<ӫFgN8f+]1=t"gexcsm}宖R1i}C'0PBM ~EXf~KkC-W;WJ 0wK}2;{i¹\-~Tg1qhMcf0k^=: : wp5QO6}FZNo?@,XZth$M O Ӿm>ZVU$XL?6'=4d1Hj,aPLG!H2  Xߖ2yA\@D  xz H*h_Ț"xAcdPb}qXR!f) EUPlytQFn(^KL$s39k'Kaɟk"]-mfA2]䧼 s-SuQX7 -S U5mnXim15xmdr|#g[rDbԐvꉨ_<4FuigbyLG^'?qmMyKK@:;,JMo0Q ߍ|9XheUҕis:^jJ TlR*-%5=8*_j_^-gEC0wLDs`1;\bHڰ!?J|k[7$8(6fti@嘧69Cmgf 7$Λ0dG5AJZHaEJPHdKU1lRfU _ 4OzIhj93/c!1,&t@ɞ*p߅b~RockiUv۶ YZ