openssh-server-8.4p1-150300.3.37.1<>,K<f3p9|%sMfw~2Ahp}SU`~$HE_Qړ4"KnxʘSO\(G+8UeC NTWJ>K?θd % ? )J_ u52  8   4 T99#9($7$"8$hd9%d:,d=>?@CFGH`IƨXƼY\]X^b8cdcehfklmuʀvwx0yx5zL\`fhlrδCopenssh-server8.4p1150300.3.37.1SSH (Secure Shell) serverSSH (Secure Shell) is a program for logging into and executing commands on a remote machine. It replaces rsh (rlogin and rsh) and provides secure encrypted communication between two untrusted hosts over an insecure network. xorg-x11 (X Window System) connections and arbitrary TCP/IP ports can also be forwarded over the secure channel. This package contains the Secure Shell daemon, which allows clients to securely connect to your server.f3s390zp35SUSE Linux Enterprise 15SUSE LLC BSD-2-Clause AND MIThttps://www.suse.com/Productivity/Networking/SSHhttps://www.openssh.com/linuxs390x # See %pre. mkdir -p /var/lib/sshd || : if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl is-enabled sshd > /var/lib/sshd/is-enabled.rpmtmp || : else if find /etc/init.d/rc[35].d -type l -regex '.*/S[0-9]+sshd' \ -exec readlink -f {} \; | grep '/etc/init.d/sshd$' >/dev/null 2>&1 then echo "enabled" > /var/lib/sshd/is-enabled.rpmtmp || :; fi 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 || : for service in sshd.service ; 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 #!/bin/bash tail -n 1 $0 | /usr/sbin/sysusers2shadow RET=$? test -f /.buildenv && exit 0 exit $RET ######## data below ######## u sshd - "SSH daemon" /var/lib/sshd PNAME=ssh SUBPNAME= SYSC_TEMPLATE=/usr/share/fillup-templates/sysconfig.$PNAME$SUBPNAME # If template not in new /usr/share/fillup-templates, fallback to old TEMPLATE_DIR if [ ! -f $SYSC_TEMPLATE ] ; then TEMPLATE_DIR=/var/adm/fillup-templates SYSC_TEMPLATE=$TEMPLATE_DIR/sysconfig.$PNAME$SUBPNAME fi SD_NAME="" if [ -x /bin/fillup ] ; then if [ -f $SYSC_TEMPLATE ] ; then echo "Updating /etc/sysconfig/$SD_NAME$PNAME ..." mkdir -p /etc/sysconfig/$SD_NAME touch /etc/sysconfig/$SD_NAME$PNAME /bin/fillup -q /etc/sysconfig/$SD_NAME$PNAME $SYSC_TEMPLATE fi else echo "ERROR: fillup not found. This should not happen. Please compare" echo "/etc/sysconfig/$PNAME and $TEMPLATE_DIR/sysconfig.$PNAME and" echo "update by hand." 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 sshd.service ; 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 if [ -x /usr/bin/chkstat ]; then /usr/bin/chkstat -n --set --system /etc/ssh/sshd_config fi # Work around %service_add_post disabling the service on upgrades where # the package name changed. if [ -x /usr/bin/systemctl ] && [ -f /var/lib/sshd/is-enabled.rpmtmp ] \ && [ x$(cat /var/lib/sshd/is-enabled.rpmtmp || :) == "xenabled" ]; then systemctl enable sshd || : fi rm -f /var/lib/sshd/is-enabled.rpmtmp 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 sshd.service || : ( 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 sshd.service ) || : fi# The openssh-fips trigger script for openssh will normally restart sshd once # it gets installed, so only restart the service here if openssh-fips is not # present. if rpm -q openssh-fips >/dev/null 2>/dev/null; then if [ $1 -eq 0 ]; then # Package removal for service in sshd.service ; do sysv_service="${service%.*}" rm -f "/var/lib/systemd/migrated/$sysv_service" || : done fi if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi else test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ $1 -eq 0 ]; then # Package removal for service in sshd.service ; do sysv_service="${service%.*}" rm -f "/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 sshd.service ) || : fi fi fi \I@=& +A큤AA큤큤큤$$$Af2f2f2f2f2f2f2f2f2f2f2f2f2f2f2f2f2f228d19d7f20fa597be7904cdf6d4999afb4e80e3e6d0a25af8237ab2c4fec84da05faafbe214f8e098ea66307a1cbe747f8796e3c62eba9df1ec4233ca1195bf36610510ac772c25ac58ed5f9c2e7bd04e6141b4e424305ba01ab43dd68a5eba0387af7c493f6e151cd3af375328e1f5da7d9c05f6bf09128d443a40314cad88525a2b8938110ef2f1edf5cfe2a0aca26eff88e158d4cfe3f2fe98ca0aae2cb3f39d26d57e62906f0613d9cb1840d249aab64eadc894b387088c688e0a5983c262bc82fb62af9360d862e14e16d89dd69bccb326fa0f886ccec58adf0969fcac03f11b17ae2be07611ebf6230e26cb77745db485f20523242b8dd77d397c4abc2edf1a33679966c18e28cd84cd671f8589059a8fae45374449ba5cb6471ca18f4238433b63d6a5b548acde065f164b6773b3e1c44b3b959608bb9db74e93ed56db3543263048fc358b3715765cc590975f077b8d08c5ea224495e6945f2d3e16f3fd24d9ed04464b0496fbd7f64ffcfc6005fdcb81752ff6aceabaeaaaebb99ae1343b3f840e3c7d4db7cc76d10d60f28af167a56421bfb2e04245d911001128fservicerootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootopenssh-8.4p1-150300.3.37.1.src.rpmconfig(openssh-server)openssh-serveropenssh-server(s390-64)openssh:/usr/sbin/sshduser(sshd) !@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@    /bin/sh/bin/sh/bin/sh/bin/sh/bin/sh/bin/shconfig(openssh-server)coreutilsdiffutilsfillupfindutilsgrepgreplibaudit.so.1()(64bit)libc.so.6()(64bit)libc.so.6(GLIBC_2.16)(64bit)libc.so.6(GLIBC_2.17)(64bit)libc.so.6(GLIBC_2.2)(64bit)libc.so.6(GLIBC_2.2.4)(64bit)libc.so.6(GLIBC_2.25)(64bit)libc.so.6(GLIBC_2.26)(64bit)libc.so.6(GLIBC_2.3)(64bit)libc.so.6(GLIBC_2.3.4)(64bit)libc.so.6(GLIBC_2.4)(64bit)libc.so.6(GLIBC_2.6)(64bit)libc.so.6(GLIBC_2.7)(64bit)libc.so.6(GLIBC_2.8)(64bit)libcom_err.so.2()(64bit)libcrypt.so.1()(64bit)libcrypt.so.1(XCRYPT_2.0)(64bit)libcrypto.so.1.1()(64bit)libcrypto.so.1.1(OPENSSL_1_1_0)(64bit)libcrypto.so.1.1(OPENSSL_1_1_0d)(64bit)libcrypto.so.1.1(OPENSSL_1_1_1d)(64bit)libdl.so.2()(64bit)libdl.so.2(GLIBC_2.2)(64bit)libfido2.so.1()(64bit)libgssapi_krb5.so.2()(64bit)libgssapi_krb5.so.2(gssapi_krb5_2_MIT)(64bit)libkrb5.so.3()(64bit)libkrb5.so.3(krb5_3_MIT)(64bit)libpam.so.0()(64bit)libpam.so.0(LIBPAM_1.0)(64bit)libselinux.so.1()(64bit)libsystemd.so.0()(64bit)libsystemd.so.0(LIBSYSTEMD_209)(64bit)libutil.so.1()(64bit)libutil.so.1(GLIBC_2.2)(64bit)libz.so.1()(64bit)openssh-commonpermissionsrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)shadowsysuser-shadow8.4p1-150300.3.37.18.4p1-150300.3.37.13.0.4-14.6.0-14.0-15.2-14.14.3 /usr/bin/chkstat -n --warn --system -e /etc/ssh/sshd_config 1>&2ff@f @e@eyehy@ds@dD@d&@b@bbaA@a@` @`` ` @` @` @`x@`x@_I@_@_@_@_@_~@_m_m_cO_Z@^3^Ӝ@^Y^K^B@]|@]X]W]c@]c@]c@]@]Z@]5@\@\@\@\M\w@\v{\j@\eX@\eX@\N\J@\I\I\?\8@\-@\[@[ٙ@[ͻ[@[@[@[$@[$@[@[@[[[0@[Z@Z@Zľ@ZZqZhu@Z]@ZX@ZWQZ@Y|Y@X}@W@WW@WV@WL+@WH6W#LW@VT@T@alarrosa@suse.commartin.sirringhaus@suse.comalarrosa@suse.comhpj@suse.comhpj@suse.comjsegitz@suse.comsflees@suse.demeissner@suse.comvliaskovitis@suse.comvliaskovitis@suse.comvliaskovitis@suse.comhpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comkukuk@suse.comdmueller@suse.comhpj@suse.comkukuk@suse.comhpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comdimstar@opensuse.orgfbui@suse.comjengelh@inai.dehpj@suse.comhpj@suse.comandreas.stieger@gmx.delnussel@suse.defvogt@suse.comhpj@suse.comhpj@suse.comcrrodriguez@opensuse.orghpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comhpj@suse.comkukuk@suse.defabian@ritter-vogt.devcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.comtchvatal@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.compmonrealgonzalez@suse.comvcizek@suse.comcrrodriguez@opensuse.orgpmonrealgonzalez@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comschwab@suse.detchvatal@suse.comastieger@suse.compcerny@suse.comdimstar@opensuse.orgpcerny@suse.comkukuk@suse.depcerny@suse.compcerny@suse.compcerny@suse.comdimstar@opensuse.orgpcerny@suse.compcerny@suse.comrbrown@suse.comjsegitz@suse.compcerny@suse.comcrrodriguez@opensuse.orgpcerny@suse.compcerny@suse.commeissner@suse.compcerny@suse.compcerny@suse.compcerny@suse.compcerny@suse.comkukuk@suse.comastieger@suse.commeissner@suse.comledest@gmail.com- Add patches from upstream to change the default value of UpdateHostKeys to Yes (unless VerifyHostKeyDNS is enabled). This makes ssh update the known_hosts stored keys with all published versions by the server (after it's authenticated with an existing key), which will allow to identify the server with a different key if the existing key is considered insecure at some point in the future (bsc#1222831). * 0001-upstream-enable-UpdateHostkeys-by-default-when-the.patch * 0002-upstream-disable-UpdateHostkeys-by-default-if.patch- Add patches openssh-7.7p1-seccomp_getuid.patch and openssh-bsc1216474-s390-leave-fds-open.patch (bsc#1216474, bsc#1218871)- Fix hostbased ssh login failing occasionally with "signature unverified: incorrect signature" by fixing a typo in patch (bsc#1221123): * openssh-7.8p1-role-mls.patch- Added openssh-cve-2023-51385.patch (bsc#1218215, CVE-2023-51385). This limits the use of shell metacharacters in host- and user names.- Added openssh-cve-2023-48795.patch (bsc#1217950, CVE-2023-48795). This mitigates a prefix truncation attack that could be used to undermine channel security.- Enhanced SELinux functionality. Added * openssh-7.8p1-role-mls.patch Proper handling of MLS systems and basis for other SELinux improvements * openssh-6.6p1-privsep-selinux.patch Properly set contexts during privilege separation * openssh-6.6p1-keycat.patch Add ssh-keycat command to allow retrival of authorized_keys on MLS setups with polyinstantiation * openssh-6.6.1p1-selinux-contexts.patch Additional changes to set the proper context during privilege separation * openssh-7.6p1-cleanup-selinux.patch Various changes and putting the pieces together For now we don't ship the ssh-keycat command, but we need the patch for the other SELinux infrastructure This change fixes issues like bsc#1214788, where the ssh daemon needs to act on behalf of a user and needs a proper context for this- Add openssh-CVE-2023-38408-PKCS11-execution.patch, Abort if requested to load a PKCS#11 provider that isnt a PKCS#11 provider (bsc#1213504,CVE-2023-38408)- openssh-7.7p1-fips_checks.patch: close the right filedescriptor to avoid fd leads, and also close fdh in read_hmac (bsc#1209536)- Revert addition of openssh-dbus.sh, openssh-dbus.csh, openssh-dbus.fish: This caused invalid and irrelevant environment assignments (bsc#1207014).- Add openssh-dbus.sh, openssh-dbus.csh, openssh-dbus.fish: Make ssh connections update their dbus environment (bsc#1179465).- Add openssh-do-not-send-empty-message.patch: Prevent empty messages from being sent. This avoids a superfluous new line (bsc#1192439).- Add openssh-CVE-2021-28041-agent-double-free.patch (bsc#1183137, CVE-2021-28041), from upstream.- Add openssh-bsc1190975-CVE-2021-41617-authorizedkeyscommand.patch (bsc#1190975, CVE-2021-41617), backported from upstream by Ali Abdallah.- Add openssh-mitigate-lingering-secrets.patch (bsc#1186673), which attempts to mitigate instances of secrets lingering in memory after a session exits. (bsc#1213004 bsc#1213008)- Add openssh-7.6p1-audit_race_condition.patch, fixing sshd termination of multichannel sessions with non-root users (error on 'mm_request_receive_expect') (bsc#1115550, bsc#1174162).- Add openssh-fix-ssh-copy-id.patch, which fixes breakage introduced in 8.4p1 (bsc#1181311).- Improve robustness of sshd init detection when upgrading from a pre-systemd distribution.- Add openssh-reenable-dh-group14-sha1-default.patch, which adds diffie-hellman-group14-sha1 key exchange back to the default list (bsc#1180958). This is needed for backwards compatibility with older platforms.- Make sure sshd is enabled correctly when upgrading from a pre-systemd distribution (bsc#1180083).- sysusers-sshd.conf: use sysusers.d configuration file to create sshd user (avoid hard dependency on shadow).- update to 8.4p1: Security ======== * ssh-agent(1): restrict ssh-agent from signing web challenges for FIDO/U2F keys. * ssh-keygen(1): Enable FIDO 2.1 credProtect extension when generating a FIDO resident key. * ssh(1), ssh-keygen(1): support for FIDO keys that require a PIN for each use. These keys may be generated using ssh-keygen using a new "verify-required" option. When a PIN-required key is used, the user will be prompted for a PIN to complete the signature operation. New Features - ----------- * sshd(8): authorized_keys now supports a new "verify-required" option to require FIDO signatures assert that the token verified that the user was present before making the signature. The FIDO protocol supports multiple methods for user-verification, but currently OpenSSH only supports PIN verification. * sshd(8), ssh-keygen(1): add support for verifying FIDO webauthn signatures. Webauthn is a standard for using FIDO keys in web browsers. These signatures are a slightly different format to plain FIDO signatures and thus require explicit support. * ssh(1): allow some keywords to expand shell-style ${ENV} environment variables. The supported keywords are CertificateFile, ControlPath, IdentityAgent and IdentityFile, plus LocalForward and RemoteForward when used for Unix domain socket paths. bz#3140 * ssh(1), ssh-agent(1): allow some additional control over the use of ssh-askpass via a new $SSH_ASKPASS_REQUIRE environment variable, including forcibly enabling and disabling its use. bz#69 * ssh(1): allow ssh_config(5)'s AddKeysToAgent keyword accept a time limit for keys in addition to its current flag options. Time- limited keys will automatically be removed from ssh-agent after their expiry time has passed. * scp(1), sftp(1): allow the -A flag to explicitly enable agent forwarding in scp and sftp. The default remains to not forward an agent, even when ssh_config enables it. * ssh(1): add a '%k' TOKEN that expands to the effective HostKey of the destination. This allows, e.g., keeping host keys in individual files using "UserKnownHostsFile ~/.ssh/known_hosts.d/%k". bz#1654 * ssh(1): add %-TOKEN, environment variable and tilde expansion to the UserKnownHostsFile directive, allowing the path to be completed by the configuration (e.g. bz#1654) * ssh-keygen(1): allow "ssh-add -d -" to read keys to be deleted from stdin. bz#3180 * sshd(8): improve logging for MaxStartups connection throttling. sshd will now log when it starts and stops throttling and periodically while in this state. bz#3055 Bugfixes - ------- * ssh(1), ssh-keygen(1): better support for multiple attached FIDO tokens. In cases where OpenSSH cannot unambiguously determine which token to direct a request to, the user is now required to select a token by touching it. In cases of operations that require a PIN to be verified, this avoids sending the wrong PIN to the wrong token and incrementing the token's PIN failure counter (tokens effectively erase their keys after too many PIN failures). * sshd(8): fix Include before Match in sshd_config; bz#3122 * ssh(1): close stdin/out/error when forking after authentication completes ("ssh -f ...") bz#3137 * ssh(1), sshd(8): limit the amount of channel input data buffered, avoiding peers that advertise large windows but are slow to read from causing high memory consumption. * ssh-agent(1): handle multiple requests sent in a single write() to the agent. * sshd(8): allow sshd_config longer than 256k * sshd(8): avoid spurious "Unable to load host key" message when sshd load a private key but no public counterpart * ssh(1): prefer the default hostkey algorithm list whenever we have a hostkey that matches its best-preference algorithm. * sshd(1): when ordering the hostkey algorithms to request from a server, prefer certificate types if the known_hosts files contain a key marked as a @cert-authority; bz#3157 * ssh(1): perform host key fingerprint comparisons for the "Are you sure you want to continue connecting (yes/no/[fingerprint])?" prompt with case sensitivity. * sshd(8): ensure that address/masklen mismatches in sshd_config yield fatal errors at daemon start time rather than later when they are evaluated. * ssh-keygen(1): ensure that certificate extensions are lexically sorted. Previously if the user specified a custom extension then the everything would be in order except the custom ones. bz#3198 * ssh(1): also compare username when checking for JumpHost loops. bz#3057 * ssh-keygen(1): preserve group/world read permission on known_hosts files across runs of "ssh-keygen -Rf /path". The old behaviour was to remove all rights for group/other. bz#3146 * ssh-keygen(1): Mention the [-a rounds] flag in the ssh-keygen manual page and usage(). * sshd(8): explicitly construct path to ~/.ssh/rc rather than relying on it being relative to the current directory, so that it can still be found if the shell startup changes its directory. bz#3185 * sshd(8): when redirecting sshd's log output to a file, undo this redirection after the session child process is forked(). Fixes missing log messages when using this feature under some circumstances. * sshd(8): start ClientAliveInterval bookkeeping before first pass through select() loop; fixed theoretical case where busy sshd may ignore timeouts from client. * ssh(1): only reset the ServerAliveInterval check when we receive traffic from the server and ignore traffic from a port forwarding client, preventing a client from keeping a connection alive when it should be terminated. bz#2265 * ssh-keygen(1): avoid spurious error message when ssh-keygen creates files outside ~/.ssh * sftp-client(1): fix off-by-one error that caused sftp downloads to make one more concurrent request that desired. This prevented using sftp(1) in unpipelined request/response mode, which is useful when debugging. bz#3054 * ssh(1), sshd(8): handle EINTR in waitfd() and timeout_connect() helpers. bz#3071 * ssh(1), ssh-keygen(1): defer creation of ~/.ssh until we attempt to write to it so we don't leave an empty .ssh directory when it's not needed. bz#3156 * ssh(1), sshd(8): fix multiplier when parsing time specifications when handling seconds after other units. bz#3171- Update openssh-8.1p1-audit.patch (bsc#1180501). This fixes occasional crashes on connection termination caused by accessing freed memory.- Support /usr/etc/pam.d- Fix build breakage caused by missing security key objects: + Modify openssh-7.7p1-cavstest-ctr.patch. + Modify openssh-7.7p1-cavstest-kdf.patch. + Add openssh-link-with-sk.patch.- Add openssh-fips-ensure-approved-moduli.patch (bsc#1177939). This ensures only approved DH parameters are used in FIPS mode.- Add openssh-8.1p1-ed25519-use-openssl-rng.patch (bsc#1173799). This uses OpenSSL's RAND_bytes() directly instead of the internal ChaCha20-based implementation to obtain random bytes for Ed25519 curve computations. This is required for FIPS compliance.- Work around %service_add_post disabling sshd on upgrade with package name change (bsc#1177039).- Fix fillup-template usage: + %post server needs to reference ssh (not sshd), which matches the sysconfig.ssh file name the package ships. + %post client does not need any fillup_ calls, as there is no client-relevant sysconfig file present. The naming of the sysconfig file (ssh instead of sshd) is unfortunate.- Use of DISABLE_RESTART_ON_UPDATE is deprecated. Replace it with %service_del_postun_without_restart- Move some Requires to the right subpackage. - Avoid ">&" bashism in %post. - Upgrade some old specfile constructs/macros and drop unnecessary %{?systemd_*}. - Trim descriptions and straighten out the grammar.- Split openssh package into openssh, openssh-common, openssh-server and openssh-clients. This allows for the ssh clients to be installed without the server component (bsc#1176434).- Version update to 8.3p1: = Potentially-incompatible changes * sftp(1): reject an argument of "-1" in the same way as ssh(1) and scp(1) do instead of accepting and silently ignoring it. = New features * sshd(8): make IgnoreRhosts a tri-state option: "yes" to ignore rhosts/shosts, "no" allow rhosts/shosts or (new) "shosts-only" to allow .shosts files but not .rhosts. * sshd(8): allow the IgnoreRhosts directive to appear anywhere in a sshd_config, not just before any Match blocks. * ssh(1): add %TOKEN percent expansion for the LocalFoward and RemoteForward keywords when used for Unix domain socket forwarding. * all: allow loading public keys from the unencrypted envelope of a private key file if no corresponding public key file is present. * ssh(1), sshd(8): prefer to use chacha20 from libcrypto where possible instead of the (slower) portable C implementation included in OpenSSH. * ssh-keygen(1): add ability to dump the contents of a binary key revocation list via "ssh-keygen -lQf /path". - Additional changes from 8.2p1 release: = Potentially-incompatible changes * ssh(1), sshd(8), ssh-keygen(1): this release removes the "ssh-rsa" (RSA/SHA1) algorithm from those accepted for certificate signatures (i.e. the client and server CASignatureAlgorithms option) and will use the rsa-sha2-512 signature algorithm by default when the ssh-keygen(1) CA signs new certificates. * ssh(1), sshd(8): this release removes diffie-hellman-group14-sha1 from the default key exchange proposal for both the client and server. * ssh-keygen(1): the command-line options related to the generation and screening of safe prime numbers used by the diffie-hellman-group-exchange-* key exchange algorithms have changed. Most options have been folded under the -O flag. * sshd(8): the sshd listener process title visible to ps(1) has changed to include information about the number of connections that are currently attempting authentication and the limits configured by MaxStartups. * ssh-sk-helper(8): this is a new binary. It is used by the FIDO/U2F support to provide address-space isolation for token middleware libraries (including the internal one). It needs to be installed in the expected path, typically under /usr/libexec or similar. = New features * This release adds support for FIDO/U2F hardware authenticators to OpenSSH. U2F/FIDO are open standards for inexpensive two-factor authentication hardware that are widely used for website authentication. In OpenSSH FIDO devices are supported by new public key types "ecdsa-sk" and "ed25519-sk", along with corresponding certificate types. * sshd(8): add an Include sshd_config keyword that allows including additional configuration files via glob(3) patterns. * ssh(1)/sshd(8): make the LE (low effort) DSCP code point available via the IPQoS directive. * ssh(1): when AddKeysToAgent=yes is set and the key contains no comment, add the key to the agent with the key's path as the comment. * ssh-keygen(1), ssh-agent(1): expose PKCS#11 key labels and X.509 subjects as key comments, rather than simply listing the PKCS#11 provider library path. * ssh-keygen(1): allow PEM export of DSA and ECDSA keys. * ssh(1), sshd(8): make zlib compile-time optional, available via the Makefile.inc ZLIB flag on OpenBSD or via the --with-zlib configure option for OpenSSH portable. * sshd(8): when clients get denied by MaxStartups, send a notification prior to the SSH2 protocol banner according to RFC4253 section 4.2. * ssh(1), ssh-agent(1): when invoking the $SSH_ASKPASS prompt program, pass a hint to the program to describe the type of desired prompt. The possible values are "confirm" (indicating that a yes/no confirmation dialog with no text entry should be shown), "none" (to indicate an informational message only), or blank for the original ssh-askpass behaviour of requesting a password/phrase. * ssh(1): allow forwarding a different agent socket to the path specified by $SSH_AUTH_SOCK, by extending the existing ForwardAgent option to accepting an explicit path or the name of an environment variable in addition to yes/no. * ssh-keygen(1): add a new signature operations "find-principals" to look up the principal associated with a signature from an allowed- signers file. * sshd(8): expose the number of currently-authenticating connections along with the MaxStartups limit in the process title visible to "ps". - Rebased patches: * openssh-7.7p1-cavstest-ctr.patch * openssh-7.7p1-cavstest-kdf.patch * openssh-7.7p1-fips.patch * openssh-7.7p1-fips_checks.patch * openssh-7.7p1-ldap.patch * openssh-7.7p1-no_fork-no_pid_file.patch * openssh-7.7p1-sftp_print_diagnostic_messages.patch * openssh-8.0p1-gssapi-keyex.patch * openssh-8.1p1-audit.patch * openssh-8.1p1-seccomp-clock_nanosleep.patch - Removed openssh-7.7p1-seed-prng.patch (bsc#1165158).- add upstream signing key to actually verify source signature- Don't recommend xauth to avoid pulling in X.- Add patches to fix the sandbox blocking glibc on 32bit platforms (boo#1164061): * openssh-8.1p1-seccomp-clock_nanosleep_time64.patch * openssh-8.1p1-seccomp-clock_gettime64.patch- Add openssh-8.1p1-use-openssl-kdf.patch (jsc#SLE-9443). This performs key derivation using OpenSSL's SSHKDF facility, which allows OpenSSH to benefit from the former's FIPS certification status.- Make sure ssh-keygen runs if SSHD_AUTO_KEYGEN variable is unset or contains an unrecognized value (bsc#1157176).- Add openssh-8.1p1-seccomp-clock_nanosleep.patch, allow clock_nanosleep glibc master implements multiple functions using that syscall making the privsep sandbox kill the preauth process.- Update openssh-7.7p1-audit.patch to fix crash (bsc#1152730). Fix by Enzo Matsumiya (ematsumiya@suse.com). This was integrated in a separate code stream merged with the Oct. 10 update; the patch was also rebased and renamed to openssh-8.1p1-audit.patch.- Add openssh-7.9p1-keygen-preserve-perms.patch (bsc#1150574). This attempts to preserve the permissions of any existing known_hosts file when modified by ssh-keygen (for instance, with -R). - Added openssh-7.9p1-revert-new-qos-defaults.patch, which reverts an upstream commit that caused compatibility issues with other software (bsc#1136402).- Run 'ssh-keygen -A' on startup only if SSHD_AUTO_KEYGEN="yes" in /etc/sysconfig/ssh. This is set to "yes" by default, but can be changed by the system administrator (bsc#1139089).- Add openssh-7.9p1-keygen-preserve-perms.patch (bsc#1150574). This attempts to preserve the permissions of any existing known_hosts file when modified by ssh-keygen (for instance, with -R).- Version update to 8.1p1: * ssh-keygen(1): when acting as a CA and signing certificates with an RSA key, default to using the rsa-sha2-512 signature algorithm. Certificates signed by RSA keys will therefore be incompatible with OpenSSH versions prior to 7.2 unless the default is overridden (using "ssh-keygen -t ssh-rsa -s ..."). * ssh(1): Allow %n to be expanded in ProxyCommand strings * ssh(1), sshd(8): Allow prepending a list of algorithms to the default set by starting the list with the '^' character, E.g. "HostKeyAlgorithms ^ssh-ed25519" * ssh-keygen(1): add an experimental lightweight signature and verification ability. Signatures may be made using regular ssh keys held on disk or stored in a ssh-agent and verified against an authorized_keys-like list of allowed keys. Signatures embed a namespace that prevents confusion and attacks between different usage domains (e.g. files vs email). * ssh-keygen(1): print key comment when extracting public key from a private key. * ssh-keygen(1): accept the verbose flag when searching for host keys in known hosts (i.e. "ssh-keygen -vF host") to print the matching host's random-art signature too. * All: support PKCS8 as an optional format for storage of private keys to disk. The OpenSSH native key format remains the default, but PKCS8 is a superior format to PEM if interoperability with non-OpenSSH software is required, as it may use a less insecure key derivation function than PEM's. - Additional changes from 8.0p1 release: * scp(1): Add "-T" flag to disable client-side filtering of server file list. * sshd(8): Remove support for obsolete "host/port" syntax. * ssh(1), ssh-agent(1), ssh-add(1): Add support for ECDSA keys in PKCS#11 tokens. * ssh(1), sshd(8): Add experimental quantum-computing resistant key exchange method, based on a combination of Streamlined NTRU Prime 4591^761 and X25519. * ssh-keygen(1): Increase the default RSA key size to 3072 bits, following NIST Special Publication 800-57's guidance for a 128-bit equivalent symmetric security level. * ssh(1): Allow "PKCS11Provider=none" to override later instances of the PKCS11Provider directive in ssh_config, * sshd(8): Add a log message for situations where a connection is dropped for attempting to run a command but a sshd_config ForceCommand=internal-sftp restriction is in effect. * ssh(1): When prompting whether to record a new host key, accept the key fingerprint as a synonym for "yes". This allows the user to paste a fingerprint obtained out of band at the prompt and have the client do the comparison for you. * ssh-keygen(1): When signing multiple certificates on a single command-line invocation, allow automatically incrementing the certificate serial number. * scp(1), sftp(1): Accept -J option as an alias to ProxyJump on the scp and sftp command-lines. * ssh-agent(1), ssh-pkcs11-helper(8), ssh-add(1): Accept "-v" command-line flags to increase the verbosity of output; pass verbose flags though to subprocesses, such as ssh-pkcs11-helper started from ssh-agent. * ssh-add(1): Add a "-T" option to allowing testing whether keys in an agent are usable by performing a signature and a verification. * sftp-server(8): Add a "lsetstat@openssh.com" protocol extension that replicates the functionality of the existing SSH2_FXP_SETSTAT operation but does not follow symlinks. * sftp(1): Add "-h" flag to chown/chgrp/chmod commands to request they do not follow symlinks. * sshd(8): Expose $SSH_CONNECTION in the PAM environment. This makes the connection 4-tuple available to PAM modules that wish to use it in decision-making. * sshd(8): Add a ssh_config "Match final" predicate Matches in same pass as "Match canonical" but doesn't require hostname canonicalisation be enabled. * sftp(1): Support a prefix of '@' to suppress echo of sftp batch commands. * ssh-keygen(1): When printing certificate contents using "ssh-keygen -Lf /path/certificate", include the algorithm that the CA used to sign the cert. - Rebased patches: * openssh-7.7p1-IPv6_X_forwarding.patch * openssh-7.7p1-X_forward_with_disabled_ipv6.patch * openssh-7.7p1-cavstest-ctr.patch * openssh-7.7p1-cavstest-kdf.patch * openssh-7.7p1-disable_openssl_abi_check.patch * openssh-7.7p1-fips.patch * openssh-7.7p1-fips_checks.patch * openssh-7.7p1-hostname_changes_when_forwarding_X.patch * openssh-7.7p1-ldap.patch * openssh-7.7p1-seed-prng.patch * openssh-7.7p1-sftp_force_permissions.patch * openssh-7.7p1-sftp_print_diagnostic_messages.patch * openssh-8.0p1-gssapi-keyex.patch (formerly openssh-7.7p1-gssapi_key_exchange.patch) * openssh-8.1p1-audit.patch (formerly openssh-7.7p1-audit.patch) - Removed patches (integrated upstream): * 0001-upstream-Fix-two-race-conditions-in-sshd-relating-to.patch * openssh-7.7p1-seccomp_ioctl_s390_EP11.patch * openssh-7.9p1-CVE-2018-20685.patch * openssh-7.9p1-brace-expansion.patch * openssh-CVE-2019-6109-force-progressmeter-update.patch * openssh-CVE-2019-6109-sanitize-scp-filenames.patch * openssh-CVE-2019-6111-scp-client-wildcard.patch - Removed patches (obsolete): * openssh-openssl-1_0_0-compatibility.patch- don't install SuSEfirewall2 service on Factory, since SuSEfirewall2 has been replaced by firewalld, see [1]. [1]: https://lists.opensuse.org/opensuse-factory/2019-01/msg00490.html- ssh-askpass: Try a fallback if the other option is not available- Fix a crash with GSSAPI key exchange (bsc#1136104) * modify openssh-7.7p1-gssapi_key_exchange.patch- Fix a double free() in the KDF CAVS testing tool (bsc#1065237) * modify openssh-7.7p1-cavstest-kdf.patch- Minor clean-up of the fips patches, modified openssh-7.7p1-fips.patch openssh-7.7p1-fips_checks.patch- Fix two race conditions in sshd relating to SIGHUP (bsc#1119183) * 0001-upstream-Fix-two-race-conditions-in-sshd-relating-to.patch- Correctly filter out non-compliant algorithms when in FIPS mode (bsc#1126397) * A hunk was applied to a wrong place due to a patch fuzz when the fips patch was being ported to openssh 7.9p1 - update openssh-7.7p1-fips.patch- Remove the "KexDHMin" config keyword (bsc#1127180) It used to allow lowering of the minimal allowed DH group size, which was increased to 2048 by upstream in the light of the Logjam attack. The code was broken since the upgrade to 7.6p1, but nobody noticed. As apparently no one needs the functionality any more, let's drop the patch. It's still possible to use the fixed 1024-bit diffie-hellman-group1-sha1 key exchange method when working with legacy systems. - drop openssh-7.7p1-disable_short_DH_parameters.patch - updated patches: openssh-7.7p1-fips.patch openssh-7.7p1-fips_checks.patch openssh-7.7p1-gssapi_key_exchange.patch- Handle brace expansion in scp when checking that filenames sent by the server side match what the client requested [bsc#1125687] * openssh-7.9p1-brace-expansion.patch- Updated security fixes: * [bsc#1121816, CVE-2019-6109] Sanitize scp filenames via snmprintf and have progressmeter force an update at the beginning and end of each transfer. Added patches: - openssh-CVE-2019-6109-sanitize-scp-filenames.patch - openssh-CVE-2019-6109-force-progressmeter-update.patch * [bsc#1121821, CVE-2019-6111] Check in scp client that filenames sent during remote->local directory copies satisfy the wildcard specified by the user. Added patch: - openssh-CVE-2019-6111-scp-client-wildcard.patch * Removed openssh-7.9p1-scp-name-validator.patch- Change the askpass wrapper to not use x11 interface: * by default we use the -gnome UI (which is gtk3 only, no gnome dep) * if desktop is KDE/LxQt we use ksshaskpass- Remove old conditionals- Move ssh-ldap* man pages into openssh-helpers [bsc#1051531]- Allow root login by default [bsc#1118114, bsc#1121196] * Added/updated previous patch openssh-7.7p1-allow_root_password_login.patch * Mention the change in README.SUSE- Added SLE conditionals in the spec files: * Keep gtk2-devel in openssh-askpass-gnome in SLE * Keep krb5-mini-devel in SLE - Removed obsolete configure options: * SSH protocol 1 --with-ssh1 * Smart card --with-opensc - Cleaned spec file with spec-cleaner- Security fix: * [bsc#1121816, CVE-2019-6109] scp client spoofing via object name * [bsc#1121818, CVE-2019-6110] scp client spoofing via stderr * [bsc#1121821, CVE-2019-6111] scp client missing received object name validation * Added patch openssh-7.9p1-scp-name-validator.patch- Security fix: [bsc#1121571, CVE-2018-20685] * The scp client allows remote SSH servers to bypass intended access restrictions * Added patch openssh-7.9p1-CVE-2018-20685.patch- Added compatibility with SuSEfirewall2 [bsc#1118044]- Update the firewall rules in Tumbleweed- Fix build with openssl < 1.1.0 * add openssh-openssl-1_0_0-compatibility.patch- openssh-7.7p1-audit.patch: fix sshd fatal error in mm_answer_keyverify: buffer error: incomplete message [bnc#1114008]- Version update to 7.9p1 * ssh(1), sshd(8): the setting of the new CASignatureAlgorithms option (see below) bans the use of DSA keys as certificate authorities. * sshd(8): the authentication success/failure log message has changed format slightly. It now includes the certificate fingerprint (previously it included only key ID and CA key fingerprint). * ssh(1), sshd(8): allow most port numbers to be specified using service names from getservbyname(3) (typically /etc/services). * sshd(8): support signalling sessions via the SSH protocol. A limited subset of signals is supported and only for login or command sessions (i.e. not subsystems) that were not subject to a forced command via authorized_keys or sshd_config. bz#1424 * ssh(1): support "ssh -Q sig" to list supported signature options. Also "ssh -Q help" to show the full set of supported queries. * ssh(1), sshd(8): add a CASignatureAlgorithms option for the client and server configs to allow control over which signature formats are allowed for CAs to sign certificates. For example, this allows banning CAs that sign certificates using the RSA-SHA1 signature algorithm. * sshd(8), ssh-keygen(1): allow key revocation lists (KRLs) to revoke keys specified by SHA256 hash. * ssh-keygen(1): allow creation of key revocation lists directly from base64-encoded SHA256 fingerprints. This supports revoking keys using only the information contained in sshd(8) authentication log messages. - Removed obsolete configuration option --with-tcp-wrappers, and - -with-opensc for s390 and s390x. - Removed patch merged upstream * openssh-7.7p1-openssl_1.1.0.patch - Refreshed patches * openssh-7.7p1-audit.patch * openssh-7.7p1-disable_short_DH_parameters.patch * openssh-7.7p1-fips.patch * openssh-7.7p1-gssapi_key_exchange.patch * openssh-7.7p1-seccomp_ipc_flock.patch * openssh-7.7p1-cavstest-ctr.patch * openssh-7.7p1-ldap.patch- Mention upstream bugs on multiple local patches - Adjust service to not spam restart and reload only on fails- Update openssh-7.7p1-sftp_force_permissions.patch from the upstream bug, and mention the bug in the spec- Drop patch openssh-7.7p1-allow_root_password_login.patch * There is no reason to set less secure default value, if users need the behaviour they can still set it up themselves - Drop patch openssh-7.7p1-blocksigalrm.patch * We had a bug way in past about this but it was never reproduced or even confirmed in the ticket, thus rather drop the patch- Disable ssh1 protocol support as neither RH or Debian enable this protocol by default anymore either.- Remove the mention of the SLE12 in the README.SUSE - Install firewall rules only when really needed ( ::1) before they are matched against known_hosts. bz#2763 * ssh(1): Don't accept junk after "yes" or "no" responses to hostkey prompts. bz#2803 * sftp(1): Have sftp print a warning about shell cleanliness when decoding the first packet fails, which is usually caused by shells polluting stdout of non-interactive startups. bz#2800 * ssh(1)/sshd(8): Switch timers in packet code from using wall-clock time to monotonic time, allowing the packet layer to better function over a clock step and avoiding possible integer overflows during steps. * Numerous manual page fixes and improvements.- Use TIRPC on suse_version >= 1500: sunrpc is deprecated and should be replaced by TIRPC.- additional rebased patches (bsc#1080779) * auditing support * LDAP integration * various distribution tweaks from SLE12 (X forwarding over IPv6, sftp forced permissions and verbose batch mode)- Use %license instead of %doc [bsc#1082318]- add OpenSSL 1.0 to 1.1 shim to remove dependency on old OpenSSL (update tracker: bsc#1080779)- Add missing crypto hardware enablement patches for IBM mainframes (FATE#323902)- add missing part of systemd integration (unit type)- BuildRequire pkgconfig(libsystemd) instead of systemd-devel: allow the scheduler to pick systemd-mini flavors to get build going.- Replace forgotten references to /var/adm/fillup-templates with new %_fillupdir macro (boo#1069468) - tighten configuration access rights- Update to vanilla 7.6p1 Most important changes (more details below): * complete removal of the ancient SSHv1 protocol * sshd(8) cannot run without privilege separation * removal of suport for arcfourm blowfish and CAST ciphers and RIPE-MD160 HMAC * refuse RSA keys shorter than 1024 bits Distilled upstream log: - OpenSSH 7.3 - --- Security * sshd(8): Mitigate a potential denial-of-service attack against the system's crypt(3) function via sshd(8). An attacker could send very long passwords that would cause excessive CPU use in crypt(3). sshd(8) now refuses to accept password authentication requests of length greater than 1024 characters. Independently reported by Tomas Kuthan (Oracle), Andres Rojas and Javier Nieto. * sshd(8): Mitigate timing differences in password authentication that could be used to discern valid from invalid account names when long passwords were sent and particular password hashing algorithms are in use on the server. CVE-2016-6210, reported by EddieEzra.Harari at verint.com * ssh(1), sshd(8): Fix observable timing weakness in the CBC padding oracle countermeasures. Reported by Jean Paul Degabriele, Kenny Paterson, Torben Hansen and Martin Albrecht. Note that CBC ciphers are disabled by default and only included for legacy compatibility. * ssh(1), sshd(8): Improve operation ordering of MAC verification for Encrypt-then-MAC (EtM) mode transport MAC algorithms to verify the MAC before decrypting any ciphertext. This removes the possibility of timing differences leaking facts about the plaintext, though no such leakage has been observed. Reported by Jean Paul Degabriele, Kenny Paterson, Torben Hansen and Martin Albrecht. * sshd(8): (portable only) Ignore PAM environment vars when UseLogin=yes. If PAM is configured to read user-specified environment variables and UseLogin=yes in sshd_config, then a hostile local user may attack /bin/login via LD_PRELOAD or similar environment variables set via PAM. CVE-2015-8325, found by Shayan Sadigh. - --- New Features * ssh(1): Add a ProxyJump option and corresponding -J command-line flag to allow simplified indirection through a one or more SSH bastions or "jump hosts". * ssh(1): Add an IdentityAgent option to allow specifying specific agent sockets instead of accepting one from the environment. * ssh(1): Allow ExitOnForwardFailure and ClearAllForwardings to be optionally overridden when using ssh -W. bz#2577 * ssh(1), sshd(8): Implement support for the IUTF8 terminal mode as per draft-sgtatham-secsh-iutf8-00. * ssh(1), sshd(8): Add support for additional fixed Diffie-Hellman 2K, 4K and 8K groups from draft-ietf-curdle-ssh-kex-sha2-03. * ssh-keygen(1), ssh(1), sshd(8): support SHA256 and SHA512 RSA signatures in certificates; * ssh(1): Add an Include directive for ssh_config(5) files. * ssh(1): Permit UTF-8 characters in pre-authentication banners sent from the server. bz#2058 - --- Bugfixes * ssh(1), sshd(8): Reduce the syslog level of some relatively common protocol events from LOG_CRIT. bz#2585 * sshd(8): Refuse AuthenticationMethods="" in configurations and accept AuthenticationMethods=any for the default behaviour of not requiring multiple authentication. bz#2398 * sshd(8): Remove obsolete and misleading "POSSIBLE BREAK-IN ATTEMPT!" message when forward and reverse DNS don't match. bz#2585 * ssh(1): Close ControlPersist background process stderr except in debug mode or when logging to syslog. bz#1988 * misc: Make PROTOCOL description for direct-streamlocal@openssh.com channel open messages match deployed code. bz#2529 * ssh(1): Deduplicate LocalForward and RemoteForward entries to fix failures when both ExitOnForwardFailure and hostname canonicalisation are enabled. bz#2562 * sshd(8): Remove fallback from moduli to obsolete "primes" file that was deprecated in 2001. bz#2559. * sshd_config(5): Correct description of UseDNS: it affects ssh hostname processing for authorized_keys, not known_hosts; bz#2554 * ssh(1): Fix authentication using lone certificate keys in an agent without corresponding private keys on the filesystem. bz#2550 * sshd(8): Send ClientAliveInterval pings when a time-based RekeyLimit is set; previously keepalive packets were not being sent. bz#2252 - --- Portability * ssh(1), sshd(8): Fix compilation by automatically disabling ciphers not supported by OpenSSL. bz#2466 * misc: Fix compilation failures on some versions of AIX's compiler related to the definition of the VA_COPY macro. bz#2589 * sshd(8): Whitelist more architectures to enable the seccomp-bpf sandbox. bz#2590 * ssh-agent(1), sftp-server(8): Disable process tracing on Solaris using setpflags(__PROC_PROTECT, ...). bz#2584 * sshd(8): On Solaris, don't call Solaris setproject() with UsePAM=yes it's PAM's responsibility. bz#2425 - OpenSSH 7.4 - --- Potentially-incompatible changes * ssh(1): Remove 3des-cbc from the client's default proposal. 64-bit block ciphers are not safe in 2016 and we don't want to wait until attacks like SWEET32 are extended to SSH. As 3des-cbc was the only mandatory cipher in the SSH RFCs, this may cause problems connecting to older devices using the default configuration, but it's highly likely that such devices already need explicit configuration for key exchange and hostkey algorithms already anyway. * sshd(8): Remove support for pre-authentication compression. Doing compression early in the protocol probably seemed reasonable in the 1990s, but today it's clearly a bad idea in terms of both cryptography (cf. multiple compression oracle attacks in TLS) and attack surface. Pre-auth compression support has been disabled by default for >10 years. Support remains in the client. * ssh-agent will refuse to load PKCS#11 modules outside a whitelist of trusted paths by default. The path whitelist may be specified at run-time. * sshd(8): When a forced-command appears in both a certificate and an authorized keys/principals command= restriction, sshd will now refuse to accept the certificate unless they are identical. The previous (documented) behaviour of having the certificate forced-command override the other could be a bit confusing and error-prone. * sshd(8): Remove the UseLogin configuration directive and support for having /bin/login manage login sessions. - --- Security * ssh-agent(1): Will now refuse to load PKCS#11 modules from paths outside a trusted whitelist (run-time configurable). Requests to load modules could be passed via agent forwarding and an attacker could attempt to load a hostile PKCS#11 module across the forwarded agent channel: PKCS#11 modules are shared libraries, so this would result in code execution on the system running the ssh-agent if the attacker has control of the forwarded agent-socket (on the host running the sshd server) and the ability to write to the filesystem of the host running ssh-agent (usually the host running the ssh client). Reported by Jann Horn of Project Zero. * sshd(8): When privilege separation is disabled, forwarded Unix- domain sockets would be created by sshd(8) with the privileges of 'root' instead of the authenticated user. This release refuses Unix-domain socket forwarding when privilege separation is disabled (Privilege separation has been enabled by default for 14 years). Reported by Jann Horn of Project Zero. * sshd(8): Avoid theoretical leak of host private key material to privilege-separated child processes via realloc() when reading keys. No such leak was observed in practice for normal-sized keys, nor does a leak to the child processes directly expose key material to unprivileged users. Reported by Jann Horn of Project Zero. * sshd(8): The shared memory manager used by pre-authentication compression support had a bounds checks that could be elided by some optimising compilers. Additionally, this memory manager was incorrectly accessible when pre-authentication compression was disabled. This could potentially allow attacks against the privileged monitor process from the sandboxed privilege-separation process (a compromise of the latter would be required first). This release removes support for pre-authentication compression from sshd(8). Reported by Guido Vranken using the Stack unstable optimisation identification tool (http://css.csail.mit.edu/stack/) * sshd(8): Fix denial-of-service condition where an attacker who sends multiple KEXINIT messages may consume up to 128MB per connection. Reported by Shi Lei of Gear Team, Qihoo 360. * sshd(8): Validate address ranges for AllowUser and DenyUsers directives at configuration load time and refuse to accept invalid ones. It was previously possible to specify invalid CIDR address ranges (e.g. user@127.1.2.3/55) and these would always match, possibly resulting in granting access where it was not intended. Reported by Laurence Parry. - --- New Features * ssh(1): Add a proxy multiplexing mode to ssh(1) inspired by the version in PuTTY by Simon Tatham. This allows a multiplexing client to communicate with the master process using a subset of the SSH packet and channels protocol over a Unix-domain socket, with the main process acting as a proxy that translates channel IDs, etc. This allows multiplexing mode to run on systems that lack file- descriptor passing (used by current multiplexing code) and potentially, in conjunction with Unix-domain socket forwarding, with the client and multiplexing master process on different machines. Multiplexing proxy mode may be invoked using "ssh -O proxy ..." * sshd(8): Add a sshd_config DisableForwarding option that disables X11, agent, TCP, tunnel and Unix domain socket forwarding, as well as anything else we might implement in the future. Like the 'restrict' authorized_keys flag, this is intended to be a simple and future-proof way of restricting an account. * sshd(8), ssh(1): Support the "curve25519-sha256" key exchange method. This is identical to the currently-supported method named "curve25519-sha256@libssh.org". * sshd(8): Improve handling of SIGHUP by checking to see if sshd is already daemonised at startup and skipping the call to daemon(3) if it is. This ensures that a SIGHUP restart of sshd(8) will retain the same process-ID as the initial execution. sshd(8) will also now unlink the PidFile prior to SIGHUP restart and re-create it after a successful restart, rather than leaving a stale file in the case of a configuration error. bz#2641 * sshd(8): Allow ClientAliveInterval and ClientAliveCountMax directives to appear in sshd_config Match blocks. * sshd(8): Add %-escapes to AuthorizedPrincipalsCommand to match those supported by AuthorizedKeysCommand (key, key type, fingerprint, etc.) and a few more to provide access to the contents of the certificate being offered. * Added regression tests for string matching, address matching and string sanitisation functions. * Improved the key exchange fuzzer harness. - --- Bugfixes * ssh(1): Allow IdentityFile to successfully load and use certificates that have no corresponding bare public key. bz#2617 certificate id_rsa-cert.pub (and no id_rsa.pub). * ssh(1): Fix public key authentication when multiple authentication is in use and publickey is not just the first method attempted. bz#2642 * regress: Allow the PuTTY interop tests to run unattended. bz#2639 * ssh-agent(1), ssh(1): improve reporting when attempting to load keys from PKCS#11 tokens with fewer useless log messages and more detail in debug messages. bz#2610 * ssh(1): When tearing down ControlMaster connections, don't pollute stderr when LogLevel=quiet. * sftp(1): On ^Z wait for underlying ssh(1) to suspend before suspending sftp(1) to ensure that ssh(1) restores the terminal mode correctly if suspended during a password prompt. * ssh(1): Avoid busy-wait when ssh(1) is suspended during a password prompt. * ssh(1), sshd(8): Correctly report errors during sending of ext- info messages. * sshd(8): fix NULL-deref crash if sshd(8) received an out-of- sequence NEWKEYS message. * sshd(8): Correct list of supported signature algorithms sent in the server-sig-algs extension. bz#2547 * sshd(8): Fix sending ext_info message if privsep is disabled. * sshd(8): more strictly enforce the expected ordering of privilege separation monitor calls used for authentication and allow them only when their respective authentication methods are enabled in the configuration * sshd(8): Fix uninitialised optlen in getsockopt() call; harmless on Unix/BSD but potentially crashy on Cygwin. * Fix false positive reports caused by explicit_bzero(3) not being recognised as a memory initialiser when compiled with - fsanitize-memory. * sshd_config(5): Use 2001:db8::/32, the official IPv6 subnet for configuration examples. - --- Portability * On environments configured with Turkish locales, fall back to the C/POSIX locale to avoid errors in configuration parsing caused by that locale's unique handling of the letters 'i' and 'I'. bz#2643 * sftp-server(8), ssh-agent(1): Deny ptrace on OS X using ptrace(PT_DENY_ATTACH, ..) * ssh(1), sshd(8): Unbreak AES-CTR ciphers on old (~0.9.8) OpenSSL. * Fix compilation for libcrypto compiled without RIPEMD160 support. * contrib: Add a gnome-ssh-askpass3 with GTK+3 support. bz#2640 * sshd(8): Improve PRNG reseeding across privilege separation and force libcrypto to obtain a high-quality seed before chroot or sandboxing. * All: Explicitly test for broken strnvis. NetBSD added an strnvis and unfortunately made it incompatible with the existing one in OpenBSD and Linux's libbsd (the former having existed for over ten years). Try to detect this mess, and assume the only safe option if we're cross compiling. - OpenSSH 7.5 - --- Potentially-incompatible changes * This release deprecates the sshd_config UsePrivilegeSeparation option, thereby making privilege separation mandatory. Privilege separation has been on by default for almost 15 years and sandboxing has been on by default for almost the last five. * The format of several log messages emitted by the packet code has changed to include additional information about the user and their authentication state. Software that monitors ssh/sshd logs may need to account for these changes. For example: Connection closed by user x 1.1.1.1 port 1234 [preauth] Connection closed by authenticating user x 10.1.1.1 port 1234 [preauth] Connection closed by invalid user x 1.1.1.1 port 1234 [preauth] Affected messages include connection closure, timeout, remote disconnection, negotiation failure and some other fatal messages generated by the packet code. * [Portable OpenSSH only] This version removes support for building against OpenSSL versions prior to 1.0.1. OpenSSL stopped supporting versions prior to 1.0.1 over 12 months ago (i.e. they no longer receive fixes for security bugs). - --- Security * ssh(1), sshd(8): Fix weakness in CBC padding oracle countermeasures that allowed a variant of the attack fixed in OpenSSH 7.3 to proceed. Note that the OpenSSH client disables CBC ciphers by default, sshd offers them as lowest-preference options and will remove them by default entriely in the next release. Reported by Jean Paul Degabriele, Kenny Paterson, Martin Albrecht and Torben Hansen of Royal Holloway, University of London. * sftp-client(1): [portable OpenSSH only] On Cygwin, a client making a recursive file transfer could be maniuplated by a hostile server to perform a path-traversal attack. creating or modifying files outside of the intended target directory. Reported by Jann Horn of Google Project Zero. - --- New Features * ssh(1), sshd(8): Support "=-" syntax to easily remove methods from algorithm lists, e.g. Ciphers=-*cbc. bz#2671 - --- Bugfixes * sshd(1): Fix NULL dereference crash when key exchange start messages are sent out of sequence. * ssh(1), sshd(8): Allow form-feed characters to appear in configuration files. * sshd(8): Fix regression in OpenSSH 7.4 support for the server-sig-algs extension, where SHA2 RSA signature methods were not being correctly advertised. bz#2680 * ssh(1), ssh-keygen(1): Fix a number of case-sensitivity bugs in known_hosts processing. bz#2591 bz#2685 * ssh(1): Allow ssh to use certificates accompanied by a private key file but no corresponding plain *.pub public key. bz#2617 * ssh(1): When updating hostkeys using the UpdateHostKeys option, accept RSA keys if HostkeyAlgorithms contains any RSA keytype. Previously, ssh could ignore RSA keys when only the ssh-rsa-sha2-* methods were enabled in HostkeyAlgorithms and not the old ssh-rsa method. bz#2650 * ssh(1): Detect and report excessively long configuration file lines. bz#2651 * Merge a number of fixes found by Coverity and reported via Redhat and FreeBSD. Includes fixes for some memory and file descriptor leaks in error paths. bz#2687 * ssh-keyscan(1): Correctly hash hosts with a port number. bz#2692 * ssh(1), sshd(8): When logging long messages to stderr, don't truncate "\r\n" if the length of the message exceeds the buffer. bz#2688 * ssh(1): Fully quote [host]:port in generated ProxyJump/-J command- line; avoid confusion over IPv6 addresses and shells that treat square bracket characters specially. * ssh-keygen(1): Fix corruption of known_hosts when running "ssh-keygen -H" on a known_hosts containing already-hashed entries. * Fix various fallout and sharp edges caused by removing SSH protocol 1 support from the server, including the server banner string being incorrectly terminated with only \n (instead of \r\n), confusing error messages from ssh-keyscan bz#2583 and a segfault in sshd if protocol v.1 was enabled for the client and sshd_config contained references to legacy keys bz#2686. * ssh(1), sshd(8): Free fd_set on connection timeout. bz#2683 * sshd(8): Fix Unix domain socket forwarding for root (regression in OpenSSH 7.4). * sftp(1): Fix division by zero crash in "df" output when server returns zero total filesystem blocks/inodes. * ssh(1), ssh-add(1), ssh-keygen(1), sshd(8): Translate OpenSSL errors encountered during key loading to more meaningful error codes. bz#2522 bz#2523 * ssh-keygen(1): Sanitise escape sequences in key comments sent to printf but preserve valid UTF-8 when the locale supports it; bz#2520 * ssh(1), sshd(8): Return reason for port forwarding failures where feasible rather than always "administratively prohibited". bz#2674 * sshd(8): Fix deadlock when AuthorizedKeysCommand or AuthorizedPrincipalsCommand produces a lot of output and a key is matched early. bz#2655 * Regression tests: several reliability fixes. bz#2654 bz#2658 bz#2659 * ssh(1): Fix typo in ~C error message for bad port forward cancellation. bz#2672 * ssh(1): Show a useful error message when included config files can't be opened; bz#2653 * sshd(8): Make sshd set GSSAPIStrictAcceptorCheck=yes as the manual page (previously incorrectly) advertised. bz#2637 * sshd_config(5): Repair accidentally-deleted mention of %k token in AuthorizedKeysCommand; bz#2656 * sshd(8): Remove vestiges of previously removed LOGIN_PROGRAM; bz#2665 * ssh-agent(1): Relax PKCS#11 whitelist to include libexec and common 32-bit compatibility library directories. * sftp-client(1): Fix non-exploitable integer overflow in SSH2_FXP_NAME response handling. * ssh-agent(1): Fix regression in 7.4 of deleting PKCS#11-hosted keys. It was not possible to delete them except by specifying their full physical path. bz#2682 - --- Portability * sshd(8): Avoid sandbox errors for Linux S390 systems using an ICA crypto coprocessor. * sshd(8): Fix non-exploitable weakness in seccomp-bpf sandbox arg inspection. * ssh(1): Fix X11 forwarding on OSX where X11 was being started by launchd. bz#2341 * ssh-keygen(1), ssh(1), sftp(1): Fix output truncation for various that contain non-printable characters where the codeset in use is ASCII. * build: Fix builds that attempt to link a kerberised libldns. bz#2603 * build: Fix compilation problems caused by unconditionally defining _XOPEN_SOURCE in wide character detection. * sshd(8): Fix sandbox violations for clock_gettime VSDO syscall fallback on some Linux/X32 kernels. bz#2142 - OpenSSH 7.6 - --- Potentially-incompatible changes This release includes a number of changes that may affect existing configurations: * ssh(1): delete SSH protocol version 1 support, associated configuration options and documentation. * ssh(1)/sshd(8): remove support for the hmac-ripemd160 MAC. * ssh(1)/sshd(8): remove support for the arcfour, blowfish and CAST ciphers. * Refuse RSA keys <1024 bits in length and improve reporting for keys that do not meet this requirement. * ssh(1): do not offer CBC ciphers by default. - --- Security * sftp-server(8): in read-only mode, sftp-server was incorrectly permitting creation of zero-length files. Reported by Michal Zalewski. - --- New Features * ssh(1): add RemoteCommand option to specify a command in the ssh config file instead of giving it on the client's command line. This allows the configuration file to specify the command that will be executed on the remote host. * sshd(8): add ExposeAuthInfo option that enables writing details of the authentication methods used (including public keys where applicable) to a file that is exposed via a $SSH_USER_AUTH environment variable in the subsequent session. * ssh(1): add support for reverse dynamic forwarding. In this mode, ssh will act as a SOCKS4/5 proxy and forward connections to destinations requested by the remote SOCKS client. This mode is requested using extended syntax for the - R and RemoteForward options and, because it is implemented solely at the client, does not require the server be updated to be supported. * sshd(8): allow LogLevel directive in sshd_config Match blocks; bz#2717 * ssh-keygen(1): allow inclusion of arbitrary string or flag certificate extensions and critical options. * ssh-keygen(1): allow ssh-keygen to use a key held in ssh-agent as a CA when signing certificates. bz#2377 * ssh(1)/sshd(8): allow IPQoS=none in ssh/sshd to not set an explicit ToS/DSCP value and just use the operating system default. * ssh-add(1): added -q option to make ssh-add quiet on success. * ssh(1): expand the StrictHostKeyChecking option with two new settings. The first "accept-new" will automatically accept hitherto-unseen keys but will refuse connections for changed or invalid hostkeys. This is a safer subset of the current behaviour of StrictHostKeyChecking=no. The second setting "off", is a synonym for the current behaviour of StrictHostKeyChecking=no: accept new host keys, and continue connection for hosts with incorrect hostkeys. A future release will change the meaning of StrictHostKeyChecking=no to the behaviour of "accept-new". bz#2400 * ssh(1): add SyslogFacility option to ssh(1) matching the equivalent option in sshd(8). bz#2705 - --- Bugfixes * ssh(1): use HostKeyAlias if specified instead of hostname for matching host certificate principal names; bz#2728 * sftp(1): implement sorting for globbed ls; bz#2649 * ssh(1): add a user@host prefix to client's "Permission denied" messages, useful in particular when using "stacked" connections (e.g. ssh -J) where it's not clear which host is denying. bz#2720 * ssh(1): accept unknown EXT_INFO extension values that contain \0 characters. These are legal, but would previously cause fatal connection errors if received. * ssh(1)/sshd(8): repair compression statistics printed at connection exit * sftp(1): print '?' instead of incorrect link count (that the protocol doesn't provide) for remote listings. bz#2710 * ssh(1): return failure rather than fatal() for more cases during session multiplexing negotiations. Causes the session to fall back to a non-mux connection if they occur. bz#2707 * ssh(1): mention that the server may send debug messages to explain public key authentication problems under some circumstances; bz#2709 * Translate OpenSSL error codes to better report incorrect passphrase errors when loading private keys; bz#2699 * sshd(8): adjust compatibility patterns for WinSCP to correctly identify versions that implement only the legacy DH group exchange scheme. bz#2748 * ssh(1): print the "Killed by signal 1" message only at LogLevel verbose so that it is not shown at the default level; prevents it from appearing during ssh -J and equivalent ProxyCommand configs. bz#1906, bz#2744 * ssh-keygen(1): when generating all hostkeys (ssh-keygen -A), clobber existing keys if they exist but are zero length. zero-length keys could previously be made if ssh-keygen failed or was interrupted part way through generating them. bz#2561 * ssh(1): fix pledge(2) violation in the escape sequence "~&" used to place the current session in the background. * ssh-keyscan(1): avoid double-close() on file descriptors; bz#2734 * sshd(8): avoid reliance on shared use of pointers shared between monitor and child sshd processes. bz#2704 * sshd_config(8): document available AuthenticationMethods; bz#2453 * ssh(1): avoid truncation in some login prompts; bz#2768 * sshd(8): Fix various compilations failures, inc bz#2767 * ssh(1): make "--" before the hostname terminate argument processing after the hostname too. * ssh-keygen(1): switch from aes256-cbc to aes256-ctr for encrypting new-style private keys. Fixes problems related to private key handling for no-OpenSSL builds. bz#2754 * ssh(1): warn and do not attempt to use keys when the public and private halves do not match. bz#2737 * sftp(1): don't print verbose error message when ssh disconnects from under sftp. bz#2750 * sshd(8): fix keepalive scheduling problem: activity on a forwarded port from preventing the keepalive from being sent; bz#2756 * sshd(8): when started without root privileges, don't require the privilege separation user or path to exist. Makes running the regression tests easier without touching the filesystem. * Make integrity.sh regression tests more robust against timeouts. bz#2658 * ssh(1)/sshd(8): correctness fix for channels implementation: accept channel IDs greater than 0x7FFFFFFF. - --- Portability * sshd(9): drop two more privileges in the Solaris sandbox: PRIV_DAX_ACCESS and PRIV_SYS_IB_INFO; bz#2723 * sshd(8): expose list of completed authentication methods to PAM via the SSH_AUTH_INFO_0 PAM environment variable. bz#2408 * ssh(1)/sshd(8): fix several problems in the tun/tap forwarding code, mostly to do with host/network byte order confusion. bz#2735 * Add --with-cflags-after and --with-ldflags-after configure flags to allow setting CFLAGS/LDFLAGS after configure has completed. These are useful for setting sanitiser/fuzzing options that may interfere with configure's operation. * sshd(8): avoid Linux seccomp violations on ppc64le over the socketcall syscall. * Fix use of ldns when using ldns-config; bz#2697 * configure: set cache variables when cross-compiling. The cross- compiling fallback message was saying it assumed the test passed, but it wasn't actually set the cache variables and this would cause later tests to fail. * Add clang libFuzzer harnesses for public key parsing and signature verification. - packaging: * moving patches into a separate archive * first round of rebased patches: [-X11_trusted_forwarding] [-allow_root_password_login] [-blocksigalrm] [-cavstest-ctr] [-cavstest-kdf] [-disable_short_DH_parameters] [-eal3] [-enable_PAM_by_default] [-fips] [-fips_checks] [-gssapi_key_exchange] [-hostname_changes_when_forwarding_X] [-lastlog] [-missing_headers] [-pam_check_locks] [-pts_names_formatting] [-remove_xauth_cookies_on_exit] [-seccomp_geteuid] [-seccomp_getuid] [-seccomp_stat] [-seed-prng] [-send_locale] [-systemd-notify] * not rebased (obsoleted) patches (so far): [-additional_seccomp_archs] [-allow_DSS_by_default] [-default_protocol] [-dont_use_pthreads_in_PAM] [-eal3_obsolete] [-gssapimitm] [-saveargv-fix] * obviously removing all standalone patch files: [openssh-7.2p2-allow_root_password_login.patch] [openssh-7.2p2-allow_DSS_by_default.patch] [openssh-7.2p2-X11_trusted_forwarding.patch] [openssh-7.2p2-lastlog.patch] [openssh-7.2p2-enable_PAM_by_default.patch] [openssh-7.2p2-dont_use_pthreads_in_PAM.patch] [openssh-7.2p2-eal3.patch] [openssh-7.2p2-blocksigalrm.patch] [openssh-7.2p2-send_locale.patch] [openssh-7.2p2-hostname_changes_when_forwarding_X.patch] [openssh-7.2p2-remove_xauth_cookies_on_exit.patch] [openssh-7.2p2-pts_names_formatting.patch] [openssh-7.2p2-pam_check_locks.patch] [openssh-7.2p2-disable_short_DH_parameters.patch] [openssh-7.2p2-seccomp_getuid.patch] [openssh-7.2p2-seccomp_geteuid.patch] [openssh-7.2p2-seccomp_stat.patch] [openssh-7.2p2-additional_seccomp_archs.patch] [openssh-7.2p2-fips.patch] [openssh-7.2p2-cavstest-ctr.patch] [openssh-7.2p2-cavstest-kdf.patch] [openssh-7.2p2-seed-prng.patch] [openssh-7.2p2-gssapi_key_exchange.patch] [openssh-7.2p2-audit.patch] [openssh-7.2p2-audit_fixes.patch] [openssh-7.2p2-audit_seed_prng.patch] [openssh-7.2p2-login_options.patch] [openssh-7.2p2-disable_openssl_abi_check.patch] [openssh-7.2p2-no_fork-no_pid_file.patch] [openssh-7.2p2-host_ident.patch] [openssh-7.2p2-sftp_homechroot.patch] [openssh-7.2p2-sftp_force_permissions.patch] [openssh-7.2p2-X_forward_with_disabled_ipv6.patch] [openssh-7.2p2-ldap.patch] [openssh-7.2p2-IPv6_X_forwarding.patch] [openssh-7.2p2-ignore_PAM_with_UseLogin.patch] [openssh-7.2p2-prevent_timing_user_enumeration.patch] [openssh-7.2p2-limit_password_length.patch] [openssh-7.2p2-keep_slogin.patch] [openssh-7.2p2-kex_resource_depletion.patch] [openssh-7.2p2-verify_CIDR_address_ranges.patch] [openssh-7.2p2-restrict_pkcs11-modules.patch] [openssh-7.2p2-prevent_private_key_leakage.patch] [openssh-7.2p2-secure_unix_sockets_forwarding.patch] [openssh-7.2p2-ssh_case_insensitive_host_matching.patch] [openssh-7.2p2-disable_preauth_compression.patch] [openssh-7.2p2-s390_hw_crypto_syscalls.patch] [openssh-7.2p2-s390_OpenSSL-ibmpkcs11_syscalls.patch]- Replace references to /var/adm/fillup-templates with new %_fillupdir macro (boo#1069468)- sshd_config is has now permissions 0600 in secure mode- Fix preauth seccomp separation on mainframes (bsc#1016709) [openssh-7.2p2-s390_hw_crypto_syscalls.patch] [openssh-7.2p2-s390_OpenSSL-ibmpkcs11_syscalls.patch] - enable case-insensitive hostname matching (bsc#1017099) [openssh-7.2p2-ssh_case_insensitive_host_matching.patch] - add CAVS tests [openssh-7.2p2-cavstest-ctr.patch] [openssh-7.2p2-cavstest-kdf.patch] - Adding missing pieces for user matching (bsc#1021626) - Properly verify CIDR masks in configuration (bsc#1005893) [openssh-7.2p2-verify_CIDR_address_ranges.patch] - Remove pre-auth compression support from the server to prevent possible cryptographic attacks. (CVE-2016-10012, bsc#1016370) [openssh-7.2p2-disable_preauth_compression.patch] - limit directories for loading PKCS11 modules (CVE-2016-10009, bsc#1016366) [openssh-7.2p2-restrict_pkcs11-modules.patch] - Prevent possible leaks of host private keys to low-privilege process handling authentication (CVE-2016-10011, bsc#1016369) [openssh-7.2p2-prevent_private_key_leakage.patch] - Do not allow unix socket forwarding when running without privilege separation (CVE-2016-10010, bsc#1016368) [openssh-7.2p2-secure_unix_sockets_forwarding.patch] - prevent resource depletion during key exchange (bsc#1005480, CVE-2016-8858) [openssh-7.2p2-kex_resource_depletion.patch] - fix suggested command for removing conflicting server keys from the known_hosts file (bsc#1006221) - enable geteuid{,32} syscalls on mainframes, since it may be called from libica/ibmica on machines with hardware crypto accelerator (bsc#1004258) [openssh-7.2p2-seccomp_geteuid.patch] - fix regression of (bsc#823710) [openssh-7.2p2-audit_fixes.patch] - add slogin (removed upstreams) [openssh-7.2p2-keep_slogin.patch] - require OpenSSL < 1.1 where that one is a default- sshd.service: Set TasksMax=infinity, as there should be no limit on the amount of tasks sshd can run.- remaining patches that were still missing since the update to 7.2p2 (FATE#319675): - allow X forwarding over IPv4 when IPv6 sockets is not available [openssh-7.2p2-X_forward_with_disabled_ipv6.patch] - do not write PID file when not daemonizing [openssh-7.2p2-no_fork-no_pid_file.patch] - use correct options when invoking login [openssh-7.2p2-login_options.patch] - helper application for retrieving users' public keys from an LDAP server [openssh-7.2p2-ldap.patch] - allow forcing permissions over sftp [openssh-7.2p2-sftp_force_permissions.patch] - do not perform run-time checks for OpenSSL API/ABI change [openssh-7.2p2-disable_openssl_abi_check.patch] - suggest commands for cleaning known hosts file [openssh-7.2p2-host_ident.patch] - sftp home chroot patch [openssh-7.2p2-sftp_homechroot.patch] - ssh sessions auditing [openssh-7.2p2-audit.patch] - enable seccomp sandbox on additional architectures [openssh-7.2p2-additional_seccomp_archs.patch] - fix forwarding with IPv6 addresses in DISPLAY (bnc#847710) [openssh-7.2p2-IPv6_X_forwarding.patch] - ignore PAM environment when using login (bsc#975865, CVE-2015-8325) [openssh-7.2p2-ignore_PAM_with_UseLogin.patch] - limit accepted password length (prevents possible DoS) (bsc#992533, CVE-2016-6515) [openssh-7.2p2-limit_password_length.patch] - Prevent user enumeration through the timing of password processing (bsc#989363, CVE-2016-6210) [openssh-7.2p2-prevent_timing_user_enumeration.patch] - Add auditing for PRNG re-seeding [openssh-7.2p2-audit_seed_prng.patch]- FIPS compatibility (no selfchecks, only crypto restrictions) [openssh-7.2p2-fips.patch] - PRNG re-seeding [openssh-7.2p2-seed-prng.patch] - preliminary version of GSSAPI KEX [openssh-7.2p2-gssapi_key_exchange.patch]- added gpg signature- enable support for SSHv1 protocol and discourage its usage (bsc#983307) - enable DSA by default for backward compatibility and discourage its usage (bsc#983784) [openssh-7.2p2-allow_DSS_by_default.patch]- enable trusted X11 forwarding by default [openssh-7.2p2-X11_trusted_forwarding.patch] - set UID for lastlog properly [openssh-7.2p2-lastlog.patch] - enable use of PAM by default [openssh-7.2p2-enable_PAM_by_default.patch] - copy command line arguments properly [openssh-7.2p2-saveargv-fix.patch] - do not use pthreads in PAM code [openssh-7.2p2-dont_use_pthreads_in_PAM.patch] - fix paths in documentation [openssh-7.2p2-eal3.patch] - prevent race consitions triggered by SIGALRM [openssh-7.2p2-blocksigalrm.patch] - do send and accept locale environment variables by default [openssh-7.2p2-send_locale.patch] - handle hostnames changes during X forwarding [openssh-7.2p2-hostname_changes_when_forwarding_X.patch] - try to remove xauth cookies on exit [openssh-7.2p2-remove_xauth_cookies_on_exit.patch] - properly format pts names for ?tmp? log files [openssh-7.2p2-pts_names_formatting.patch] - check locked accounts when using PAM [openssh-7.2p2-pam_check_locks.patch] - chenge default PermitRootLogin to 'yes' to prevent unwanted surprises on updates from older versions. See README.SUSE for details [openssh-7.2p2-allow_root_password_login.patch] - Disable DH parameters under 2048 bits by default and allow lowering the limit back to the RFC 4419 specified minimum through an option (bsc#932483, bsc#948902) [openssh-7.2p2-disable_short_DH_parameters.patch] - Add getuid() and stat() syscalls to the seccomp filter (bsc#912436) [openssh-7.2p2-seccomp_getuid.patch, openssh-7.2p2-seccomp_stat.patch]- upgrade to 7.2p2 upstream package without any SUSE patches Distilled upstream log: - OpenSSH 6.7 Potentially-incompatible changes: * sshd(8): The default set of ciphers and MACs has been altered to remove unsafe algorithms. In particular, CBC ciphers and arcfour* are disabled by default. The full set of algorithms remains available if configured explicitly via the Ciphers and MACs sshd_config options. * sshd(8): Support for tcpwrappers/libwrap has been removed. * OpenSSH 6.5 and 6.6 have a bug that causes ~0.2% of connections using the curve25519-sha256@libssh.org KEX exchange method to fail when connecting with something that implements the specification correctly. OpenSSH 6.7 disables this KEX method when speaking to one of the affected versions. New Features: * ssh(1), sshd(8): Add support for Unix domain socket forwarding. A remote TCP port may be forwarded to a local Unix domain socket and vice versa or both ends may be a Unix domain socket. * ssh(1), ssh-keygen(1): Add support for SSHFP DNS records for ED25519 key types. * sftp(1): Allow resumption of interrupted uploads. * ssh(1): When rekeying, skip file/DNS lookups of the hostkey if it is the same as the one sent during initial key exchange * sshd(8): Allow explicit ::1 and 127.0.0.1 forwarding bind addresses when GatewayPorts=no; allows client to choose address family * sshd(8): Add a sshd_config PermitUserRC option to control whether ~/.ssh/rc is executed, mirroring the no-user-rc authorized_keys option * ssh(1): Add a %C escape sequence for LocalCommand and ControlPath that expands to a unique identifer based on a hash of the tuple of (local host, remote user, hostname, port). Helps avoid exceeding miserly pathname limits for Unix domain sockets in multiplexing control paths * sshd(8): Make the "Too many authentication failures" message include the user, source address, port and protocol in a format similar to the authentication success / failure messages Bugfixes: * sshd(8): Fix remote forwarding with the same listen port but different listen address. * ssh(1): Fix inverted test that caused PKCS#11 keys that were explicitly listed in ssh_config or on the commandline not to be preferred. * ssh-keygen(1): Fix bug in KRL generation: multiple consecutive revoked certificate serial number ranges could be serialised to an invalid format. Readers of a broken KRL caused by this bug will fail closed, so no should-have-been-revoked key will be accepted. * ssh(1): Reflect stdio-forward ("ssh -W host:port ...") failures in exit status. Previously we were always returning 0 * ssh(1), ssh-keygen(1): Make Ed25519 keys' title fit properly in the randomart border * ssh-agent(1): Only cleanup agent socket in the main agent process and not in any subprocesses it may have started (e.g. forked askpass). Fixes agent sockets being zapped when askpass processes fatal() * ssh-add(1): Make stdout line-buffered; saves partial output getting lost when ssh-add fatal()s part-way through (e.g. when listing keys from an agent that supports key types that ssh-add doesn't) * ssh-keygen(1): When hashing or removing hosts, don't choke on @revoked markers and don't remove @cert-authority markers * ssh(1): Don't fatal when hostname canonicalisation fails and a ProxyCommand is in use; continue and allow the ProxyCommand to connect anyway (e.g. to a host with a name outside the DNS behind a bastion) * scp(1): When copying local->remote fails during read, don't send uninitialised heap to the remote end. * sftp(1): Fix fatal "el_insertstr failed" errors when tab-completing filenames with a single quote char somewhere in the string * ssh-keyscan(1): Scan for Ed25519 keys by default. * ssh(1): When using VerifyHostKeyDNS with a DNSSEC resolver, down-convert any certificate keys to plain keys and attempt SSHFP resolution. Prevents a server from skipping SSHFP lookup and forcing a new-hostkey dialog by offering only certificate keys. - OpenSSH 6.8 Potentially-incompatible changes: * sshd(8): UseDNS now defaults to 'no'. Configurations that match against the client host name (via sshd_config or authorized_keys) may need to re-enable it or convert to matching against addresses. New Features: * Add FingerprintHash option to ssh(1) and sshd(8), and equivalent command-line flags to the other tools to control algorithm used for key fingerprints. The default changes from MD5 to SHA256 and format from hex to base64. Fingerprints now have the hash algorithm prepended. An example of the new format: SHA256:mVPwvezndPv/ARoIadVY98vAC0g+P/5633yTC4d/wXE Please note that visual host keys will also be different. * ssh(1), sshd(8): Experimental host key rotation support. Add a protocol extension for a server to inform a client of all its available host keys after authentication has completed. The client may record the keys in known_hosts, allowing it to upgrade to better host key algorithms and a server to gracefully rotate its keys. The client side of this is controlled by a UpdateHostkeys config option (default off). * ssh(1): Add a ssh_config HostbasedKeyType option to control which host public key types are tried during host-based authentication. * ssh(1), sshd(8): fix connection-killing host key mismatch errors when sshd offers multiple ECDSA keys of different lengths. * ssh(1): when host name canonicalisation is enabled, try to parse host names as addresses before looking them up for canonicalisation. fixes bz#2074 and avoiding needless DNS lookups in some cases. * ssh-keygen(1), sshd(8): Key Revocation Lists (KRLs) no longer require OpenSSH to be compiled with OpenSSL support. * ssh(1), ssh-keysign(8): Make ed25519 keys work for host based authentication. * sshd(8): SSH protocol v.1 workaround for the Meyer, et al, Bleichenbacher Side Channel Attack. Fake up a bignum key before RSA decryption. * sshd(8): Remember which public keys have been used for authentication and refuse to accept previously-used keys. This allows AuthenticationMethods=publickey,publickey to require that users authenticate using two _different_ public keys. * sshd(8): add sshd_config HostbasedAcceptedKeyTypes and PubkeyAcceptedKeyTypes options to allow sshd to control what public key types will be accepted. Currently defaults to all. * sshd(8): Don't count partial authentication success as a failure against MaxAuthTries. * ssh(1): Add RevokedHostKeys option for the client to allow text-file or KRL-based revocation of host keys. * ssh-keygen(1), sshd(8): Permit KRLs that revoke certificates by serial number or key ID without scoping to a particular CA. * ssh(1): Add a "Match canonical" criteria that allows ssh_config Match blocks to trigger only in the second config pass. * ssh(1): Add a -G option to ssh that causes it to parse its configuration and dump the result to stdout, similar to "sshd -T". * ssh(1): Allow Match criteria to be negated. E.g. "Match !host". * The regression test suite has been extended to cover more OpenSSH features. The unit tests have been expanded and now cover key exchange. Bugfixes: * ssh-keyscan(1): ssh-keyscan has been made much more robust again servers that hang or violate the SSH protocol. * ssh(1), ssh-keygen(1): Fix regression: Key path names were being lost as comment fields. * ssh(1): Allow ssh_config Port options set in the second config parse phase to be applied (they were being ignored). * ssh(1): Tweak config re-parsing with host canonicalisation - make the second pass through the config files always run when host name canonicalisation is enabled (and not whenever the host name changes) * ssh(1): Fix passing of wildcard forward bind addresses when connection multiplexing is in use * ssh-keygen(1): Fix broken private key conversion from non-OpenSSH formats. * ssh-keygen(1): Fix KRL generation bug when multiple CAs are in use. * Various fixes to manual pages - OpenSSH 6.9 Security: * ssh(1): when forwarding X11 connections with ForwardX11Trusted=no, connections made after ForwardX11Timeout expired could be permitted and no longer subject to XSECURITY restrictions because of an ineffective timeout check in ssh(1) coupled with "fail open" behaviour in the X11 server when clients attempted connections with expired credentials. This problem was reported by Jann Horn. * ssh-agent(1): fix weakness of agent locking (ssh-add -x) to password guessing by implementing an increasing failure delay, storing a salted hash of the password rather than the password itself and using a timing-safe comparison function for verifying unlock attempts. This problem was reported by Ryan Castellucci. New Features: * ssh(1), sshd(8): promote chacha20-poly1305@openssh.com to be the default cipher * sshd(8): support admin-specified arguments to AuthorizedKeysCommand * sshd(8): add AuthorizedPrincipalsCommand that allows retrieving authorized principals information from a subprocess rather than a file. * ssh(1), ssh-add(1): support PKCS#11 devices with external PIN entry devices * sshd(8): allow GSSAPI host credential check to be relaxed for multihomed hosts via GSSAPIStrictAcceptorCheck option * ssh-keygen(1): support "ssh-keygen -lF hostname" to search known_hosts and print key hashes rather than full keys. * ssh-agent(1): add -D flag to leave ssh-agent in foreground without enabling debug mode Bugfixes: * ssh(1), sshd(8): deprecate legacy SSH2_MSG_KEX_DH_GEX_REQUEST_OLD message and do not try to use it against some 3rd-party SSH implementations that use it (older PuTTY, WinSCP). * Many fixes for problems caused by compile-time deactivation of SSH1 support (including bz#2369) * ssh(1), sshd(8): cap DH-GEX group size at 4Kbits for Cisco implementations as some would fail when attempting to use group sizes >4K * ssh(1): fix out-of-bound read in EscapeChar configuration option parsing * sshd(8): fix application of PermitTunnel, LoginGraceTime, AuthenticationMethods and StreamLocalBindMask options in Match blocks * ssh(1), sshd(8): improve disconnection message on TCP reset; bz#2257 * ssh(1): remove failed remote forwards established by muliplexing from the list of active forwards * sshd(8): make parsing of authorized_keys "environment=" options independent of PermitUserEnv being enabled * sshd(8): fix post-auth crash with permitopen=none * ssh(1), ssh-add(1), ssh-keygen(1): allow new-format private keys to be encrypted with AEAD ciphers * ssh(1): allow ListenAddress, Port and AddressFamily configuration options to appear in any order * sshd(8): check for and reject missing arguments for VersionAddendum and ForceCommand * ssh(1), sshd(8): don't treat unknown certificate extensions as fatal * ssh-keygen(1): make stdout and stderr output consistent * ssh(1): mention missing DISPLAY environment in debug log when X11 forwarding requested * sshd(8): correctly record login when UseLogin is set * sshd(8): Add some missing options to sshd -T output and fix output of VersionAddendum and HostCertificate. bz#2346 * Document and improve consistency of options that accept a "none" argument" TrustedUserCAKeys, RevokedKeys (bz#2382), AuthorizedPrincipalsFile (bz#2288) * ssh(1): include remote username in debug output * sshd(8): avoid compatibility problem with some versions of Tera Term, which would crash when they received the hostkeys notification message (hostkeys-00@openssh.com) * sshd(8): mention ssh-keygen -E as useful when comparing legacy MD5 host key fingerprints * ssh(1): clarify pseudo-terminal request behaviour and use make manual language consistent * ssh(1): document that the TERM environment variable is not subject to SendEnv and AcceptEnv - OpenSSH 7.0: This focuses primarily on deprecating weak, legacy and/or unsafe cryptography. Security: * sshd(8): OpenSSH 6.8 and 6.9 incorrectly set TTYs to be world- writable. Local attackers may be able to write arbitrary messages to logged-in users, including terminal escape sequences. Reported by Nikolay Edigaryev. * sshd(8): Portable OpenSSH only: Fixed a privilege separation weakness related to PAM support. Attackers who could successfully compromise the pre-authentication process for remote code execution and who had valid credentials on the host could impersonate other users. Reported by Moritz Jodeit. * sshd(8): Portable OpenSSH only: Fixed a use-after-free bug related to PAM support that was reachable by attackers who could compromise the pre-authentication process for remote code execution. Also reported by Moritz Jodeit. * sshd(8): fix circumvention of MaxAuthTries using keyboard- interactive authentication. By specifying a long, repeating keyboard-interactive "devices" string, an attacker could request the same authentication method be tried thousands of times in a single pass. The LoginGraceTime timeout in sshd(8) and any authentication failure delays implemented by the authentication mechanism itself were still applied. Found by Kingcope. Potentially-incompatible Changes: * Support for the legacy SSH version 1 protocol is disabled by default at compile time. * Support for the 1024-bit diffie-hellman-group1-sha1 key exchange is disabled by default at run-time. It may be re-enabled using the instructions in README.legacy or http://www.openssh.com/legacy.html * Support for ssh-dss, ssh-dss-cert-* host and user keys is disabled by default at run-time. These may be re-enabled using the instructions at http://www.openssh.com/legacy.html * Support for the legacy v00 cert format has been removed. * The default for the sshd_config(5) PermitRootLogin option has changed from "yes" to "prohibit-password". * PermitRootLogin=without-password/prohibit-password now bans all interactive authentication methods, allowing only public-key, hostbased and GSSAPI authentication (previously it permitted keyboard-interactive and password-less authentication if those were enabled). New Features: * ssh_config(5): add PubkeyAcceptedKeyTypes option to control which public key types are available for user authentication. * sshd_config(5): add HostKeyAlgorithms option to control which public key types are offered for host authentications. * ssh(1), sshd(8): extend Ciphers, MACs, KexAlgorithms, HostKeyAlgorithms, PubkeyAcceptedKeyTypes and HostbasedKeyTypes options to allow appending to the default set of algorithms instead of replacing it. Options may now be prefixed with a '+' to append to the default, e.g. "HostKeyAlgorithms=+ssh-dss". * sshd_config(5): PermitRootLogin now accepts an argument of 'prohibit-password' as a less-ambiguous synonym of 'without- password'. Bugfixes: * ssh(1), sshd(8): add compatability workarounds for Cisco and more PuTTY versions. * Fix some omissions and errors in the PROTOCOL and PROTOCOL.mux documentation relating to Unix domain socket forwarding * ssh(1): Improve the ssh(1) manual page to include a better description of Unix domain socket forwarding * ssh(1), ssh-agent(1): skip uninitialised PKCS#11 slots, fixing failures to load keys when they are present. * ssh(1), ssh-agent(1): do not ignore PKCS#11 hosted keys that wth empty CKA_ID * sshd(8): clarify documentation for UseDNS option - OpenSSH 7.1: Security: * sshd(8): OpenSSH 7.0 contained a logic error in PermitRootLogin= prohibit-password/without-password that could, depending on compile-time configuration, permit password authentication to root while preventing other forms of authentication. This problem was reported by Mantas Mikulenas. Bugfixes: * ssh(1), sshd(8): add compatability workarounds for FuTTY * ssh(1), sshd(8): refine compatability workarounds for WinSCP * Fix a number of memory faults (double-free, free of uninitialised memory, etc) in ssh(1) and ssh-keygen(1). Reported by Mateusz Kocielski. - OpenSSH 7.1p2: * SECURITY: ssh(1): The OpenSSH client code between 5.4 and 7.1 contains experimential support for resuming SSH-connections (roaming). The matching server code has never been shipped, but the client code was enabled by default and could be tricked by a malicious server into leaking client memory to the server, including private client user keys. The authentication of the server host key prevents exploitation by a man-in-the-middle, so this information leak is restricted to connections to malicious or compromised servers. MITIGATION: For OpenSSH >= 5.4 the vulnerable code in the client can be completely disabled by adding 'UseRoaming no' to the gobal ssh_config(5) file, or to user configuration in ~/.ssh/config, or by passing -oUseRoaming=no on the command line. PATCH: See below for a patch to disable this feature (Disabling Roaming in the Source Code). This problem was reported by the Qualys Security Advisory team. * SECURITY: Eliminate the fallback from untrusted X11-forwarding to trusted forwarding for cases when the X server disables the SECURITY extension. Reported by Thomas Hoger. * SECURITY: Fix an out of-bound read access in the packet handling code. Reported by Ben Hawkes. * PROTOCOL: Correctly interpret the 'first_kex_follows' option during the intial key exchange. Reported by Matt Johnston. * Further use of explicit_bzero has been added in various buffer handling code paths to guard against compilers aggressively doing dead-store removal. Potentially-incompatible changes: * This release disables a number of legacy cryptographic algorithms by default in ssh: + Several ciphers blowfish-cbc, cast128-cbc, all arcfour variants and the rijndael-cbc aliases for AES. + MD5-based and truncated HMAC algorithms. - OpenSSH 7.2: Security: * ssh(1), sshd(8): remove unfinished and unused roaming code (was already forcibly disabled in OpenSSH 7.1p2). * ssh(1): eliminate fallback from untrusted X11 forwarding to trusted forwarding when the X server disables the SECURITY extension. * ssh(1), sshd(8): increase the minimum modulus size supported for diffie-hellman-group-exchange to 2048 bits. * sshd(8): pre-auth sandboxing is now enabled by default (previous releases enabled it for new installations via sshd_config). New Features: * all: add support for RSA signatures using SHA-256/512 hash algorithms based on draft-rsa-dsa-sha2-256-03.txt and draft-ssh-ext-info-04.txt. * ssh(1): Add an AddKeysToAgent client option which can be set to 'yes', 'no', 'ask', or 'confirm', and defaults to 'no'. When enabled, a private key that is used during authentication will be added to ssh-agent if it is running (with confirmation enabled if set to 'confirm'). * sshd(8): add a new authorized_keys option "restrict" that includes all current and future key restrictions (no-*-forwarding, etc.). Also add permissive versions of the existing restrictions, e.g. "no-pty" -> "pty". This simplifies the task of setting up restricted keys and ensures they are maximally-restricted, regardless of any permissions we might implement in the future. * ssh(1): add ssh_config CertificateFile option to explicitly list certificates. bz#2436 * ssh-keygen(1): allow ssh-keygen to change the key comment for all supported formats. * ssh-keygen(1): allow fingerprinting from standard input, e.g. "ssh-keygen -lf -" * ssh-keygen(1): allow fingerprinting multiple public keys in a file, e.g. "ssh-keygen -lf ~/.ssh/authorized_keys" bz#1319 * sshd(8): support "none" as an argument for sshd_config Foreground and ChrootDirectory. Useful inside Match blocks to override a global default. bz#2486 * ssh-keygen(1): support multiple certificates (one per line) and reading from standard input (using "-f -") for "ssh-keygen -L" * ssh-keyscan(1): add "ssh-keyscan -c ..." flag to allow fetching certificates instead of plain keys. * ssh(1): better handle anchored FQDNs (e.g. 'cvs.openbsd.org') in hostname canonicalisation - treat them as already canonical and remove the trailing '.' before matching ssh_config. Bugfixes: * sftp(1): existing destination directories should not terminate recursive uploads (regression in openssh 6.8) * ssh(1), sshd(8): correctly send back SSH2_MSG_UNIMPLEMENTED replies to unexpected messages during key exchange. * ssh(1): refuse attempts to set ConnectionAttempts=0, which does not make sense and would cause ssh to print an uninitialised stack variable. * ssh(1): fix errors when attempting to connect to scoped IPv6 addresses with hostname canonicalisation enabled. * sshd_config(5): list a couple more options usable in Match blocks. * sshd(8): fix "PubkeyAcceptedKeyTypes +..." inside a Match block. * ssh(1): expand tilde characters in filenames passed to -i options before checking whether or not the identity file exists. Avoids confusion for cases where shell doesn't expand (e.g. "-i ~/file" vs. "-i~/file"). * ssh(1): do not prepend "exec" to the shell command run by "Match exec" in a config file, which could cause some commands to fail in certain environments. * ssh-keyscan(1): fix output for multiple hosts/addrs on one line when host hashing or a non standard port is in use * sshd(8): skip "Could not chdir to home directory" message when ChrootDirectory is active. * ssh(1): include PubkeyAcceptedKeyTypes in ssh -G config dump. * sshd(8): avoid changing TunnelForwarding device flags if they are already what is needed; makes it possible to use tun/tap networking as non-root user if device permissions and interface flags are pre-established * ssh(1), sshd(8): RekeyLimits could be exceeded by one packet. * ssh(1): fix multiplexing master failure to notice client exit. * ssh(1), ssh-agent(1): avoid fatal() for PKCS11 tokens that present empty key IDs. * sshd(8): avoid printf of NULL argument. * ssh(1), sshd(8): allow RekeyLimits larger than 4GB. * ssh-keygen(1): sshd(8): fix several bugs in (unused) KRL signature support. * ssh(1), sshd(8): fix connections with peers that use the key exchange guess feature of the protocol. * sshd(8): include remote port number in log messages. * ssh(1): don't try to load SSHv1 private key when compiled without SSHv1 support. * ssh-agent(1), ssh(1): fix incorrect error messages during key loading and signing errors. * ssh-keygen(1): don't leave empty temporary files when performing known_hosts file edits when known_hosts doesn't exist. * sshd(8): correct packet format for tcpip-forward replies for requests that don't allocate a port * ssh(1), sshd(8): fix possible hang on closed output. * ssh(1): expand %i in ControlPath to UID. * ssh(1), sshd(8): fix return type of openssh_RSA_verify. * ssh(1), sshd(8): fix some option parsing memory leaks. * ssh(1): add a some debug output before DNS resolution; it's a place where ssh could previously silently stall in cases of unresponsive DNS servers. * ssh(1): remove spurious newline in visual hostkey. * ssh(1): fix printing (ssh -G ...) of HostKeyAlgorithms=+... * ssh(1): fix expansion of HostkeyAlgorithms=+... Documentation: * ssh_config(5), sshd_config(5): update default algorithm lists to match current reality. * ssh(1): mention -Q key-plain and -Q key-cert query options. * sshd_config(8): more clearly describe what AuthorizedKeysFile=none does. * ssh_config(5): better document ExitOnForwardFailure. * sshd(5): mention internal DH-GEX fallback groups in manual. * sshd_config(5): better description for MaxSessions option. Portability: * sshd(8): fix multiple authentication using S/Key. - OpenSSH 7.2p2: Security: * sshd(8): sanitise X11 authentication credentials to avoid xauth command injection when X11Forwarding is enabled. (removing patches from previous version: * CVE-2016-0777_CVE-2016-0778.patch * openssh-6.6p1-X11-forwarding.patch * openssh-6.6p1-X_forward_with_disabled_ipv6.patch * openssh-6.6p1-audit1-remove_duplicit_audit.patch * openssh-6.6p1-audit2-better_audit_of_user_actions.patch * openssh-6.6p1-audit3-key_auth_usage-fips.patch * openssh-6.6p1-audit3-key_auth_usage.patch * openssh-6.6p1-audit4-kex_results-fips.patch * openssh-6.6p1-audit4-kex_results.patch * openssh-6.6p1-audit5-session_key_destruction.patch * openssh-6.6p1-audit6-server_key_destruction.patch * openssh-6.6p1-audit7-libaudit_compat.patch * openssh-6.6p1-audit8-libaudit_dns_timeouts.patch * openssh-6.6p1-blocksigalrm.patch * openssh-6.6p1-curve25519-6.6.1p1.patch * openssh-6.6p1-default-protocol.patch * openssh-6.6p1-disable-openssl-abi-check.patch * openssh-6.6p1-eal3.patch * openssh-6.6p1-fingerprint_hash.patch * openssh-6.6p1-fips-checks.patch * openssh-6.6p1-fips.patch * openssh-6.6p1-gssapi_key_exchange.patch * openssh-6.6p1-gssapimitm.patch * openssh-6.6p1-host_ident.patch * openssh-6.6p1-key-converter.patch * openssh-6.6p1-lastlog.patch * openssh-6.6p1-ldap.patch * openssh-6.6p1-login_options.patch * openssh-6.6p1-no_fork-no_pid_file.patch * openssh-6.6p1-pam-check-locks.patch * openssh-6.6p1-pam-fix2.patch * openssh-6.6p1-pam-fix3.patch * openssh-6.6p1-pts.patch * openssh-6.6p1-saveargv-fix.patch * openssh-6.6p1-seccomp_getuid.patch * openssh-6.6p1-seccomp_stat.patch * openssh-6.6p1-seed-prng.patch * openssh-6.6p1-send_locale.patch * openssh-6.6p1-sftp_force_permissions.patch * openssh-6.6p1-sftp_homechroot.patch * openssh-6.6p1-xauth.patch * openssh-6.6p1-xauthlocalhostname.patch)- update seccomp sandbox that broke after OpenSSL update (bsc#912436, bsc#977812) [openssh-6.6p1-seccomp_stat.patch]- openssh-6.6p1-ldap.patch: replace TRUE/FALSE with 1/0, since this defines did come via an indirect header inclusion and are not everywhere defined.- CVE-2016-0777, bsc#961642, CVE-2016-0778, bsc#961645 Add CVE-2016-0777_CVE-2016-0778.patch to disable the roaming code to prevent information leak and buffer overflow- gpg signature and keyring added. pub 3200R/6D920D30 2013-12-10 [expires: 2021-01-01] uid Damien Miller sub 3200R/672A1105 2013-12-10 [expires: 2021-01-01]- fix bashisms in sshd.init script/bin/sh/bin/sh/bin/sh/bin/sh/bin/shs390zp35 1713189635 8.4p1-150300.3.37.18.4p1-150300.3.37.18.4p1-150300.3.37.1 sshdslp.reg.dssh.regsshd_configSuSEfirewall2.dservicessshdsftp-serversshd.servicesshd.confrcsshdsshdsshd-gen-keys-startsysconfig.sshsshd_config.5.gzsftp-server.8.gzsshd.8.gzsshd/etc/pam.d//etc//etc/slp.reg.d//etc/ssh//etc/sysconfig//etc/sysconfig/SuSEfirewall2.d//etc/sysconfig/SuSEfirewall2.d/services//usr/lib/ssh//usr/lib/systemd/system//usr/lib/sysusers.d//usr/sbin//usr/share/fillup-templates//usr/share/man/man5//usr/share/man/man8//var/lib/-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:33331/SUSE_SLE-15-SP3_Update/f71c47e5d820071b5da8be7eaa5ced7d-openssh.SUSE_SLE-15-SP3_Updatedrpmxz5s390x-suse-linuxASCII textdirectoryELF 64-bit MSB shared object, IBM S/390, version 1 (SYSV), dynamically linked, interpreter /lib/ld64.so.1, BuildID[sha1]=4f83144bfcae9bc399b32a659ffc1c2ceea0d0f5, for GNU/Linux 3.2.0, strippedELF 64-bit MSB shared object, IBM S/390, version 1 (SYSV), dynamically linked, interpreter /lib/ld64.so.1, BuildID[sha1]=4b7b90421c59f67f39742d9444f10188e526c518, for GNU/Linux 3.2.0, strippedPOSIX shell script, ASCII text executabletroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)4!R#RRRRRRRRRRR!RRR"R0R$RPRR-R(R*R/R!R RRRRRRRRRRRRRR&R R)R,RR.R0RR+R%R'RRRD^#uy‘]vݥ/auditutf-8eb996e61f5df180e1cda31cdd1bcd548efc8253ff71e55c9c2d98a4c126297dc?P7zXZ !t/[]"k%r.5wW(hLƒ~xhK^Xt?n4=肻j/*fQ2Sd$X`1k}g֕xgP׶Jِ6 T.v}me@u $ KFXuM~Z5 .r&y7!G86@Y5Z4Dϐ < %$n}Ug Lۓ\:9^F`Q| %zI $ӟJy@ۧEn^Or);оY U䐰:oD@8Td^P+zԌK"&]&2 !K(2Az 58v7yèsL!9R 7-݆لWڣ37rb!$+wX05ѳlզR9x1,h_{$ng.}]gwRXp*P".fx@elK\Ȍ߃_p `V>Ou; ۍM^)S^1h' T߂fb:E9LK-࿹9e|؃}a׳2ڌɈ%j22#HިR&S` m[FQ`0!tS+A܏j=Qd k1+*]R\7g\m#[~ <]{ovƠqjzv]9Zj.XrtU \!0idSd+!kUKdG+yzZBEJx0l/l mg;:5-V AY2F ]jkfQ'd7%eʗ|0 0pO&c= T쮚4s uUQ֩ḱۉ8bW=I=Q$e9xgUn'?טx5̠\sg`ai gL)@Zey{3G8֮gAOnл1}hp}'ʢM^I*Tv\2yIBiBb3czW+`:N !k5$7Mϳ\rFaIVځT]BCX!Odsă)VxZTEmh)E];(<ѤJ19ZͳA}Ck`:j%`wߝf#n`_Tp3BZ/H(JZ甚.]4񛀟 ~gBR[KyhBhht%ċ?"R$٫M;3PLpwLkIƨ.0|kLa>,4ZaCs=!j..T!~4Gz<3F*kzD=8)A]#n+1ô=ӂ_P/hs%B'1{cH boEu竀 ;?&D.t.RnJ) ZdwO~TNZcѥn;KĽO]Pfoȑq:Wc앱ˌb)5bn0vzW@p/mUlG\Y5?YT$ދa>a}4 Nѳ ~n10ДGB4("&1z$ڣތ9aP}7fMx&o^;dGjЇb6<pf!HzS2Ӗ U]K3ĪS# agqHW˗Qŀ[%ʝ_ &E+Gʧ&H2+9Y+ ' xJ72XN)s4L* LF{tOq8Tc Ka pJaQ2;דlN- 08UE9Qr>-M.״Vt,KTH Rr@gڤ}ǜ!0DoJF,w<lS˫ sV>l,& 1JNM5Ko1jZپ݆hT4S5ej=35'[}eo^2dCjմLA d޻J nJ?2bg#5JlbhmU#ͳ" 4ImUB` Doh0CMl z:Cxa[3zFzM0:Ţ5!%'h]Q4ffpduFbS`@q\rHZ29j‘p2'#֠ p8- Aܩ( DoPQ h$&pLfTEM[&A8n5B~Lgvw_7_W$ J(bF@x\Fw2fâ@ȃMN b&v P{, o ѡC GqHq|[N S#4"E}Ҭd¹Ŕ: ; P{K^Uikq̢:PG!_鰈<@U꟔×[234]51z,]RWSEx@E ib+[>TdX̗Hu[t @T@ d䇣fi L=sRM)XfjtizLa<nY -ϊ$^]}K5-Y" ]{A*#6 Mjo-X6nxX L_K wMv Mwm3aDnYS . # 7BEbݔ&A>cy9,fjC[&``VTXibka)|}BF;Ѹ?Uuc 8ҕ}M( M)O{K|G)n=Ї5"X-yA(E7`=n'5ubbE.?p U9U[ \6饟fF`ibm 8,V32 XD'œ;57iûd[IvqC|xvdE:SfQ^nؗhՖ@aBEKoծXk!G}rO5u#mH&eEP =UԎ )r뮆e5f˫xZDhʷ`{@_>!bBgU_T鸁ᙣ*[9k%D@n6=g0}3oYGK(gˏ׬$Q`$sZH׍}$k+ɫp;pyXVR Vr EI w\"ABw)|iVpO:6.kf!ˤٚxDSo֊FEv{q+{T{] W%z.SXAq݇3n6إ\HkW}Օ^1+LKzq18X+:\aN茶$̪5;Q;[;%uu\7)w#$ޅ+/~@i|K: (DL]<: XD76S!dQAupa[.h)Z ^~m`<_&Vyׁ%g0i诗njůWOhrVD( a |7ƫϊEܫaKM&XjnimXe*Z&h(B# mj_2KBPCA :0GO:}> ״>Ƈ)90lN 4FzhZķ!Bi!78]ajTn޳e)Όu΍An#O( lv1=36).mc=埛,ŀd*گcR7Aܙ/M8J$.%fu;]8l" /LHeԷp6qx' .7 ^/]=KW7w1M]Z &ol)J/n@UXF:eT+JS[;H [A_I&?/ 0{ =&ijҥy H԰\Z)YeWu|zoj2|~M(GyamqE:oz 7eF5肷"=^D,I|ZlcyЃx܇P7wJlǤ@D od9.D6Kg&,=o㶗jAVŐ/-^R s;z11_i3Wn_~ISU-Rݖ#1gep?>1hO5Fmbò'N]9[?H,H4FCOo<\~8/. _]H R/0%FUpyQ:X{S`#>,Jև|P&ŕM \ظ#DY-S{w[äIӕ̠7QUEkH"-CmO Y֪92[8'ʄ۶߸ R)/;hmm]rX".kI4ٲbkp긞~oj}Te lƘ!Y5Gץ)E9p9*R_tuxx{?y~/$VדͺWqw 3ΤN p 2RN_ͭD ~C5N]uŵw; ~p|ή'a;ʌ w=Zhk&6.ik 'z)p?e$%P[>[0k{R|ٓ-ĕعiikPt!K"D|_þ9|q RO$L!@'o@OU@19(i1 >~(KZI+䡎Rg>^",G1Z:{ȯH:0&W "3 fh$Ί#7\ZZ5[#\g zFԪ-={S?iHṂÚАRt mJ4dm-.,G+|xb}z!2427 >]yg(* L /´0qqd=MS<2^=&ڃ͐d uQM5N&}[)"NT=ߤ2?]{W.P\SGsv{0W1 #C-!9'L*p0T(%c'_5,@N.ru;|~"i&|olgO^\u82)ޤ #0&/KY7H%[A (|Qƭ2q7\Zŏ+JL[eA/F޵o u:)VHn}ՠj0p6@\x7vw%$lO\ n <`5E|TѡOK7k<`u/"l/x`;@f0XeV G&E0ٶU$I%5#LOY ]4/|܌AtQR^] #!} oҺ+{9R ! ]Tኀ&uBñ_{DpjFr 2!@[_)L6k\X=of^3 ;iջ<*ɮlS/Dvz'C«(Ymm"W(`,r~7́y.Ž<^zKaY B< ) d,h[/8'ߟ,g\ә R~SfsI}rv5U_{\Ry?0qÇO8L`1~Em3xz&mB}\?*nm!5* "eS b$K ⊨DHWs /$0ٟ38z;nYR0C7ӬG哢`sj[~!]?DȻL}g| =Ĝ"C+Fq@L IBD~.1Zbors GPM CK>96*9a;dӎIqia狕Fᧀz/z@f}POEw֙ԃ`bOf O`[9}9>ƏׁIsZ8(թ"nsiR *"gKmaW(* ;K"]vJeH˿up-:%ʐ*h0ټ,. J'v%\zBo[As\UѱK0h[I)98zGpy RkkVE: oD̃bn{:EM 4UU4]cJۈ:ymxob5mu7.BJڅxt|Krԕ+MrPFԜq ߭]^.ke+q- uQCZp.p v;X/GVE]1!I9u9&cesgSh&?Е~q;Z)Z3-f߁l@ԪojW d -"+y5b"`HȲ+?I'*u_* ǒA٫[K}Q>{ 0` }uZI=8^9zjnsH.'_GIB xks2s]$EemǶO&fMq6BD'JH>r%iDeH}E ޒObRI`fT} lɂݘ/^Q X?,YHYWnZ fV\7P6Ut3خsl=ԽO$$~Pt|>§|/;)0 0{fo\FLp:?X6k6Rm Sca G )J9{hy;orW^OWh%6@VŎSz=RM ay5y Y66JupgXc䞅{G$JU!-ކF8ǿH6~5gegd-=p% ͹K9v`獣+.32O0[sjש$Н=^ {s&׈9}qKI OےK;{A5Sj' mXcwB&Mf5`,ۻS SpaD{((5XHЇȟi@B &T2$%oS\ZyE& R9XX10aB yy ]n~8|Ϝ9}?:Fr錛jG+6roӍΧ1Xv*^sKzbdvMS4eY -D3Lw މnd+v?To6%uhа7R!sJM3Kr@?d70x+w?Yt'=sQ*"KC8?>yCdպ;&%ޛGc]>@2tE]riAF Q8ff?GBUIՒG =Vk3l^_2 lUc'm k}UhiT#Hךd|şCXлƈ޼[Oe^s7tF炳w|.\ wy֕gk_r5 o":AMm/--eҗ?FJ/ze5d7VAHȔ&=gh~Ã+wޤ*y],B* ՇP#졆Nh!332p{L-L=F?)=~nc5=.X|'ȃ閊G)/fU9<:4t KT":ݼ:z24µ (R \qHx#DujqvDlA\WO-A穆+9T]Y7xo)]w{>Y(|}=YTkFaHVq4%t8BJmb .O&`Bm}Qy1cb̯3[J  =*CC}/Oj&ȥ"o:g}s$SZhZ4<%\i~Bfv s1NaQ+yr9=zǡX̞F[ӡeQw%URK$mەR N yڰ@;XyFvB+8pN){a8 ƀ޾Z$)vjlVt|r$o% ӄJE6EzqVm%K}r8>˪b6v\ܑ<;~` ^[XOo G<ȟ%:yޓ |2ewM+hoD +PdM1Z5EoZ&8oU?-9ѻ.GOT_)^byX1A_ʖy)̦ITj[ Wz9vCIAgGKP8;N(ܕA; re[ hFmpēEBݥ=J`5 Ӣ}$+a_ ;c#HJFrէv^"5{K3(,!2Z$TaA"1^"taa&?(38 |sNnJ_,;#NY y!E+DW=nDn>6?:`{+ʉ@pbbAMnqÁZe }|N מ9Vj@*8~#ԔyHaNciX%$UQIٹ(ׯ}pAKH}&?;RVϸc|铺)< Ɵд2ZWi[lT#iL_ vB,櫝T X5C)E9I.s2lry=$4k"[_z93S/8mb"~pnZn^Saz`~IºRٻW[d/DMKphqM>2&Tʺd~2ـ]lb*85]R7'橿L>cwR*=Gѥ-l؄qxg0BlQ:YN3bʤ UZ;x. -A7}Qiť98;MI 8#HRx1ugF&7ĩ?fCxo-Ek_N| |Wkߴp[1Ӎa(ݘ#f[u|%[_cŕ7GTQ෴KG&޳  PJ B}NF'^ЉŘ.t+uSG]N.Swmh7gzQ Ұ4$..>fz d: d:^5~izI^%qYM-q`3sh inqWaLe˪Fď TC r?LZ*J|=ܑv0}OC}:G-JqyN6r1n&UHJ!> \ |9O+RwqgQg5ίb`xR1T.;> lsB3FS [ܺJp80W %||ӸIx)e&#!UHhCB3 q6Ӳ0ǂ>R`w\~I;$P@ED[=3|ۅgcW{>a*h_i _1vH&vMZdOAԜt%v8tYR4_s@$XUF<9Q'ɼI$P-D>1!LIK|G ifتςe5aPA * ^1P[d9ءZ(>ݷnUK)F.PE&|1&ey"AʕIl)Nւ֋PC'M{s iず$~\l`M5{goGjs%4jvVS!{{F/CQ+x+[pICN,IuzFkK<>'SID/PM;.+\l cYc@]{W%Sܯa A!gѪ)"YK.ḡk;'DkgWg7 O5YwbSw̼?VJV+` d%.=+7 YO]t2jRKSOHSջ4{iѯ΍MUxݰ:'*%fodMesl9"C&;sewvѻb5Lx=Ll yLcg3iᒑ i5ãD,KU,L /bJ`rz[c_c&sLк7 ,x.^;߱0H{ب s6DWYexj#t+W' {[Z@arFkZQ,eZF {>f(BD"kq 8=66p{I.dq˜Ewu荲VrⱢLw|[JBXCK֔{n|ȭ+0 @v3 $ [MBFa[W#L_8Ԝ v@̉rogo& se݅e,rM@XbZ&;wp|D\K*~ں?215bG E-hW*HC~s<yDшUZ4ꗔ' hbM]Ve_TL+SjEPۯ]gŬR?o!'S'ltNׇmZmHh[dy-B\e.D`J*ވ*@%Dj5#ƀ21<⬲ÂBO< U:&އd.j ,9r t[PGx)ٰw!s{J Ffw7viH*X yMo&I*xm)Jdq?y*-INӣ[,7_qgRDz 4`v:ՇK}+mbɪ8w꤂S4+K{&݌MQ)VTmq˵i{ϟm˂$? ;h sgf r53nrT^*! Ttܶ^Y CDy˵ybpf 'xL %Th2.n%G)WG1Xǐ~hQ Qz UkS>~"y"tUЦ|{}U a6(C3ZIbÐٌ5,~Im؏|͒R]sy!dŢ6H/HMsV&g`e-0҃۹iO7G*&s0| }xe&L:suά%?QUX'Լhyjw#=isvA:'YY 3U%,AA,;Pb{^;BvTq5_Z( A*e -8w{qkچ(LqY|sk| L IrM$맦p@Vd8 3y׳B]Zi>](Vh߽Ae,h(ї٩ ,j NįXWCP r XT2Ѥ`[wn 9a޵0W#R7O0tQ[Y8/fHc$} 0MYyQJctBIu֔CVfUEe>d)]]8ܕUjX rb[сGpAቒrŤ,oʕ WBùq7H=\{‚"tX6psB61c\VIϵ7.F^[oIxM V sF.`wˌҫ$檢TzBr櫓+}/J)V 050Ҡq4C1Ϛ|dcn3,Lr RDTv nzrt8)9 'hC3 B;s~!~\YT ~bmGU%R:ЉdU c%g5ɐj>$rt^A=I*"W!-CSɛyc*@;y,Src\ JM l{ 6MN@iFBK-H ߅htr+RY0 VC\J'1nr@ ]nJ)q~}wpX™В,G"+ϒPDҒ%WnɀOŞf8h`;ͤEY'@%]JS`Fu,/7,{~fqveWL^28x;><%xhvd6sx]+pqb_<H݊c2 qst&pIG Se%,u4g'd\3jPi4dYn9RJEjkxdh^K VǞ>U{(C8=RC:0Zr( w' m7^[/ph~4,v;,&:D'2O,rm3rEI̠v/;&)lm̐{ LXȠ: %wfЀۯ|<2%yw A#='w"s^hA#IeQ@&?(w0E gp>OAA^#<QG_p 3C]? a${ԗi~,>Vq>3ΊQ_ CgBB!#S5Rd޻kVp5]i%3ul-ܞtVW;"^tީ8І;}ZƮ\5&`+l@YT`X J\>$ rg\ @몷J{Sm\ҁ1' @+hU+-kL?ZCгI4~>d% DDqWDQGYV [waI)oXD-Wa[r̊20 mR89:aq{ZDi-{ǰg;^!H9 %Mah5"$p {V(o.R:Fg\hp[B2Bs͝MI Ĩ])59CE@7E`?ΐ{Y̭1FCVf&d=|$ ?8LosW:Kj\ J&\79Nb2Kw|oK]:CWH qXYDHBWx ePkbÞsf̣&8S-Q{ݏE'ޖmӾ+WɈm@fφ %\(i5R #CM4Sz6N&F.?frB+u bIK oJ2(xqNJZ8X 2SvE6TASyF` sHh`kz|~rYˏkb%e`ukZ݈(հp8 '.bo n4WJ\NU ;_ GzL: HmtޮD\+fL҂H|p66PZ8]SZKTD8sW .y2$MfAo23Qk l 1l;pRД,Of$I]r^s&wOvm)-o8hHJ&GNKNFh*QEoGfk(_mBhU!%ě}卢튰aRoNξW>셍Gɯ8wۀ -^_N8;7cUD#JU7EhAJfu5\)dhtc|ٰmTٻ/W4 =cm٨F䯅,\;L .0Vjg[6q1 ӣT3&}e$zDZ.]TVI X[mӊeڪ.̊#Ļ/e5ky/ikG0;KdG/ㇼ ^t\-à{ E܈Z&r;DefW_ϰv63@vnJ$r>F BS:B#C`ۋ9Js1ld$xk`ްmq٠|.s&rDhpX-ž7_UrD<Xko.wt$-M.]0SAŽfnӚ&@cc.]?D[vԼ8yn9ro⩁ &:=): c(\(f{!CY-0_ɀINfDfQ;0 {ӂ9Lr<%g:pfFH<h SۇI{VmV6s'LbT[)l#vnL+y_H*@&+h cq{ts/[8 EI7b7sn2h6q!XP'-l]HXjWXF#4օK#>lKI1=pHvdX QGz;W}gjج={!Gxe($x/Y}Q/ޭLoҦ ]Չ O RWn nL;hgNq>uF>@&Iջ| EfAr۬9o)[iT Y!2TfH:{#x9҄b `l$viQQf03=b͑+jHYq&\ נ26$xւ7ypBsp 鄉R.`PD󱒙eM{_KCR6E+j/z-6:!W8y(*!ݭ+tK@T7!s5C{(6J,QP%{dg,8ae3cސ˚A*D]&C8?oK*[;X.c2rJqp+\ew^F+'RfzqndrGg{)'o +N&q-*W3!kG#y%KQl[*,_LJ͛^(a%@7rM9I;3ȿ)ޘm`dP ]xjBփ4pIUALjEӺ oʣRu8X٫:*Q.#Կ?L5]MP@c{[ @arbl{LlZ7{5Ȇκ^r]$Jneݨ}m.0|'7ʳFJ=s c8C. 92g=ɴu抿S\ע(3H˥CeV$mqCl#C^ Hly`@YO wY3]\>)V495׼"i@NqtDͦC,S!]韵IZe(ц>6^ύKn\o+9hX4DEdY'JLZ}Hr3K f&o*#&zj)izظsuʵ!蕻Uqnt523J*td PSHr !]Q, }0/C`$cJ7x-'< m3ߍ =`<4BncB]bT(&fvw䕐z{.\_\ж8*V H͒ju1ÜRXumQ\Z< X.ku. :}R.feQI92ЀAqQzWAϣԕr JVږ4OoE .}CanJgvթ0eXU$!5CFg7`.3f/ si3,} 55{~"jP &7E2[F*uvՁQ5=@p}@OQ*cfmJIԨY '=>-%$(I8P hZxfnGj>MVS]gvٚ `BI% í_wޗL4ZrzY ҵ BF>P6Chع4:eU؊(6.|$ܱwٵl)bTWw܏du弑 (aZŸ,D" LWV^/x`nXݝ\F>=ÚEZu!v@+fHs*Z__=|߭-@if9-ĵhHgs2iއ@(ݒ6ҳ7 ~9]dz`X2S:oJfqr} gedj2*b 2#;Y72]V;s)0NȊP2sSVNiփ݂kk\!Yzԝ`psy `1UZT{ !;~N<4GO~f Gkq.wLRB2S[oJ6SC%A4fsn* bh~ץl(3w!1RIK13/uAp2iHÆ b'/p왐_b<~x:+~Hb(:24/wpŚ*rmXYF2v}eiƯ]S(n dZ ֞lzs#g |T66ٞ[FXpF>E3TiA-{ *n?[_&X[|i75biN2SC];;צ݂s7Zf0Pp$>Kzufbr~uAb5)m':RS;{+U14zWQ8Jz Hr{= 슷ݶIzkÆ۰$v\_deV$@˂"{FRٌѝm(Pzi| xwchG/Mϖ +]S5`6s4Ge+iȱHz^|v-rljmA~h^bC &i5'H|@ŰdWg,`psKпǶP ljD-3c49p)#,[ y2 va$;nN54|PXvjF:&hԭ([D E"W4܉%#25$=8Py!uzW]^^SeݺYHGk75^7LllݏpU/ŝOt:HBH7 w6 c.XY_w"O(.aL塭aK44'f'v?x0Xe.Omي[?6]v_a}g!DuB`MRKwRYuVf%(VNDޓ:ַgOqo PYK&$b~ZY]*4q `oGƢmnJIEP9Bd(M,lĘ H/Pv_=PѧUqPH7&GM=CTih fS_c5 wr-:Lu"ɀ#?K NRJ"{uNM撅Քn W\Uw2&J0idY=VLyJ՚o'Y໤<_HS@o KVDޗMh eʗ`7s|ϟP Ye{-~02vR{Ŭbя &wc $kNt󗼬5 IR`aknYaA |?' |ŷb߇ Gmo~$.nr9&g 3':isևd3?2S{aK)q` ,f+ŗXjIn\ˈ2E^pLi.T ߜ:b_q^,7LN56(GXh}1c˂؝]D.#k BX> 0Pst_^ ^+ZBi_͏0*̑u1/Jӡ#~i-1=8QGHW{᱉O}gG"0N<$(zshdu?qc0⛑] rAWb(3,,Da[~QR`BJ{V 4b "֏犇,ūne g{='_]hAN& ^σ$<0*_D248ho'޴&ˮy-@" hXqKy!5드j5߻e<+ORA? | 6m w7?\Bw+jv&[nIZΠ}Ђ`<**DW}|yeK'89^~<Fz-9q)\FnM;1@^iR]1!UҼq_tnZʄWf=-/xDT&O,&<}*F 5Ï㇦,iQum]k:֑ۆ$O6OiFy'! ? H:]V:W?4́m‡Zl}yDrvKE=J4`ՄVv9*lk5y#C7wX!,#F#!ndᣒf Y_n!| Q`j/;?p9ЫZΉȟ@7g3Q>}6gs {;Kz< Lx&[0vFupড়+SiNT˘HZrj L]O"V-?o*K ʭ/CҴx\8arLmIdh]di6OGU@r/-\YkhHR(kϤ{c*Iޣw9|L*dc5sۓ<\C[zj mЯ  :-r$ QXv"ΊM,.L"ώ'^c]\(N{w6gǁ0.YO" n?k#_$`zfsb0jO47c7LmNb)_OUֿ?HdDbA~)v nA*媲!?-ÇCv*}jr_A:NS0*$2ny@9*HR>x7vkڊ1_7+jJPR:*eq9m&N{Cj8F3Sy3ҵcΥ AlBĤ?8&2U/ΦaR({Kᄪ|UD~2ҭLvĉ&3L*,1]XL#襝{{1Rn?r԰ ,'kڎXyg˚>}b @I[oZ |aJ혪IxO\V4{y2\#)9Ykj=^241`#L֯Rmq{qəBjY*켶#b\H^IBgg]W H;V0 )D+; xs|f;.T? N6/} hS/!Cedi9wg (?49h-!G7WxI1LqKGvRDޣ8Y@J/Ku;0! IGl-1O&~2G/a<;5++S Uy!HiƺhN Az X3f@bPyS8~yjj-ݢޠ cM=ŶU  rBu2?p$9#)w8/;B[V+JT]Xя7.#߭氄8ZΒU M#wCwP:zğpz͵sdm8YѮaQBs# ts_u*c<4 y{pU /g.A5[%>P~s:ȯڿ%_CZ0 k#WΆ7|osHעwfW7bzEg8@]'Ɗjsxia 6Z#lP=fdM - PtM )3#Y1: jHDB>>G:܏*sB?콮sCH~j4Ntݹ&XDZ^d]_{9.قkc}FU in,7t+4 iqϱ 38Z-]uom)=ۍ,;8tJ>wSgK@X&>:ͅ#L}pUB] =/ΒzyixƩI+ 1S)\ya+y1˰zWܪhVN#zdOǽacZH9h B;yEyh{y6FoWLUs! |AX(ԷJ>숱C1lǽ2o&yNDo-טt ␁uG ,8GҚ)r 6$@&|1Hi7V@a7gm n櫝Ft&^I`Ns *z#Gh$T}SOauB(-):@q5{/`Ns-z(M])tQ)yE=y8g`<{=`50K6$O1& B$_Yn"ɶ+\F5+[|iDelj.ۿJWu 7 1rW#S^ʦr҃ǺA*_{1feNB@u !oy MSPȆc{2.V 7j˘2.!?f*9^q`XG8 vB.ֱL89qWu]:]&_hΏuR((=\3<zUiZm'ltZtPYʩI( S1["I GzպE( "qҚHZ=$0oerlwVTKk%8BRڊ埋!w(N@'X6Q u F3pmz eCgd~-]g 11J8SAĘ#Iw`9$RLfcVym1 πثlde|v'ɷ#Ps0մR,bVZ+86010ySNv,ʉ*zj}RΘlD>̑d'꥾|30=gsۍT_ϻ7f[~ fd_ieV)!ʻFJ{wSz+t ǞT b[p2]SW+kJnoN1Gl1esjOȵV1SpG@?;bK[W'xBi=pNǍUD lFYZzD%U7"#YDkOu=&9Sg9u?^ր%/{i/ jY!KC"ot[sr~ۢvz|{z=Ch΅wU VRvn|{V k#0w$s#[zޚ 3C3*bۨ'f(y3 [I*}\})]ħ] %f|.d7$RLk BsIa^ fy 8*\\#*_ܑI6Oph^\ RaO Zc| 6NK mSpf8r -|QW0z.shU3./cҊQ|s}=h3$$PM̓vͧG!2-~,[ 8әHnY Z&A}MtTKh73 &sYX6ݤUIk21[B"'a 4@?;_tiNy+z7jL*]H3ZO%Vuh/sH|uxN/~JpG㦹Ϧ#coC$j{lPjg4Ʈn0>ct(j.bJ.* ˰<0ո#H?M߂*b:k% )t6 T+;z;`FHR%+R.CӅ8Wф"ܢ]GBhet!4mz,胨Y||Pt@JYok_w+IRi"[ 9 2LdKe JdH?jtĀ6@5u'&Iu4hTh8=w6m41W]DeC=^Ƕr2-}Rgxˑܕ]?G0Xfhdϟ%)X(兩Ҳ2$r(b}Y/ͤ*ĕOvW x *%t֋vR0C,x]A6: 5RWpP0tO+&V ޤg_)k8 6rDH)#-͹?vn̐SaayRWAXh"EzB1vֽy}[6jO+~JdH7qςeUr -ɚ lDn0N\{EkܙX&pA 6Lr>!H<Ԙa5IϹqV1~api2tGc')h:gv ,$=ew"ygLG&pdmi񙄘7?mH)4`!:lgFkd~k$Ԇ(|S蠮S5`%pNW !X XoZx Xk}]Ƽh{ 8|^z_23\&$_7 Z?ś)__H%UӓXI[@Мï @#$?,1WYnmˁ;f7=KV2KfB _PϥV]&!vr.!þ ߨH3ވ-.F-SڍWq}#j",MXS_eJf=CQڥ_.9:²R^ JM:-6$" #G.;Τ62* t @"s80ʼnVkyw|& )` }!.]9 lFR WRIǙc,<|@a KdzYP@;;bh_@BpZI=bS(=Q,7$\韴 ~F 0$0#yf"',,u-W3ōݦ %śڮuY/+K2x\:i).P*7f mAB;[0Q~)f3jVc_t._΄q ){3= 1 [#"b5hf>l'Nuf/H]|ZLuX ǛF½+o!|P[{,zy7)ol]R%Obw {Yd1?-b%lDlx6$"KBccP^W SMi V%)U XzD\nZJ%{ Na94) xׯ#3q<8{\7cՑֺpC|S_ . 'ۻrCwyu. gpGTi\X<&T*ăR 9" =R[)͔%Ho_Ip~ 9.GCy?:=aG{ހ&.Hogב@HM=hlBxS՝osO\Jbf"kF'ޯأhFɷ"~3^j$S: IQ֙` IM[LQ΄kHy嵯"S.Yr Za@ 7m^Յv^3>IZ,5Pٜjl4.ɲÿQr1ڗ;:<ـ@eV c۪#=@# [VH\!"!Iəbx U=ܦ{bnׄ!n ऻ-_pu |2!R+GzoP{8`6X} LL%@UD_,<}oQO&AyRjPʛH ,'SN iWS$ϖH:o6`tE*L`ƇGNp)5S_˵j:O!.2c/1GGW`P fwHE9:fChI=V, %\@iJ?LgrI$&m$s%Q0Y y5V{w`HÚ@Lw>z9Į_ZRzh ~7YKAѦ Nv#!ou+̻ a59D~uQt>i@[_Pa)ʨnqqkcqe@?E _UdCY> j͢&ͱ.֜>8LAXg}o,Xvo !hTy.l?n|M~#ďI=+ېBE3EY6O2|I`#̂_uD H-rXҶ^E_Ljr^J fngBG/=7d!, kϪ }Q'Mc'.ɮh~&,_zAlBbtBR9dߍ)i(8w۶ Vt=r~LsP] δE[׃(&'ۦC0ie>">]:`A#bb*hh0V}]&kw88|~m`u4vȐ.l-ERT)둷&x?r#_ #n[N lۅ-2]ռ@MrTvvg}!XӧrDCkӕ 6 c hPE0gb 9#VOȱ;#\FWπF꯺P_~cLhI^r:rV~S\dN<ա".T0Ŵ|~l%=DJlIeЛ8/xz.^)z:$;&E*\N7yZ9ǻ]h7T:']S2M"ӈu7bZn.TkuMݢք7D0؆$=1Uoz]*{7N&sSփ8F@ I| nLlA'[XDCX9Nr]ā:-d Q\"1phP$d,p5)i:27qrݓF$Nkjv#[Ļ Zy Te#xJ 0eܙk3*cn.L'+cCCe!G{dQkQ0XIp;*EZ uDHRfb`3'VC}NFAG9}([ =I̩_$ӭ{.4k8h_.wՉ822CElm\?0sטMĶLW <1iwY_Qe#qۇ,YGKWq-u9a_@!-.^l_gӖl-Oe.MLtZ~^Abeu7j'}Ɖnps Z Sz:>𞚱;/fP~'< _S=S՟YbWuermnᵗ#pqN\1|(4sռJ!y¡bNlhF1J-q;APDd]Fʬ`bP"HG`q۷ )o]cxU@)pCVrtД5zJuW4"tk\M[bZ F'yw(7}N ;;d,apz>;V <%L 9yG{6ʋXXe%3: &ڒXuE;N0U7#9 ^siCIT?v"(֤jjV؁o6b6bR9?eu{xVmvIEs&sV-8 C[6pф#g!ʨ# ܻKOi^oOk@0EZ*Uk _zz F#)iި'ܯ MV}~`l> UЌ0s:]كrBT<,p}_iOnk;+T "ʽhE P81Òkh/} quZ}I}W=Dy#mB wXhMm_ƫCv-lpdm8[L+aR癜`2Qx'0ۥoxgn!sJq\ Ctidq?|4g׭g$L+ Vl_pBg 1 3N1Z 81?0@ɫR:6ާ8dXTQD2ݖo15ij2h:xqfcsk tpY&<&Wcdw. pNk`eI#khϚ0^Wi^ˊ[*60PbT4`f C VYR-h3o F2lBMGmM[raQ {@p7t]%`k G6J]H%d/E 0FaTotN>$i%*tf@6LFfE.@hk4o϶?IJ>c\:@ qd;+H7!=k>J=;`2Y]g Γ_ed3UĞ hϹg?*q1MA$ [5S;F)E~c)tCmaTlw20yBztBUDѹRW ,;x[3{X{uk+` F0UK<0vs#:aCiU>Hj|F]7 1LmEb~sMC[x!^ss66-?xK$#=a)52nvx7iףI^ .z7+{H.w3v⫊%Џok#&.t(Vi~[yzKJD(C$S]R0tbЇVvlv"h}MS\ PXxE ,[ys *FA@J `r8#`#1B5&f2 i)=n1ីQcL8 `A68?-/pPzm0('_'k6 "eD'L i$yФ5ji>h -7N6m:ck\ɬ/i!,x{@Ը/#1- >+6 ?VvG?65P3wkkFwYȗ}mV32.xoYFwRKV.PԳڷ]M . ́+Nnw&J6\בtzMتa0hEO׿/>[ MWŌ~}.]j9$^&"Mk i̖*Oj㨜3JBSСrT{2*Zv\/Fp}U6p].ȩm*1kh92@A_I͂El&b. "o8QQN3R\:tnD Fx5=C:=oCPOCEDNfWe^ةGK PtNJqXūWU=|{h?\L]ݛEhsAQg{qW*pXT@4}9v+BE*l[^rx|7JbWÈN&U={AT]A ua$*3s7Cއe&z4fijt&ԍt`K sÓ  Tlzr-zDt8zܞڗqTl \oʃM+Z'6 d,a18!ܰO/qNIh[i5$g$6v3 qpV:힦k5iI3_# ИX"0~P%^ UƮZV'2{"ˣW`,̋9Egu\43',\P W ѳ,(E ~Wޞz4D4oz!!)9$"X<>(b%U|a"8XnQiڴ 8Cc"D>ր(-ϕ=b}z_A5/_L1(D]h{wYſvP7Fꘚyqp2uD[2Q#}A#oX1j^2,6D';ĩbцyW*1EωZ/`emcur.!'XYNs^?DS9#mpe}"bMT9<~CJ'пEF0Z}: #LJqv|drfWEY$"Q @VY%GjeH2+jwP}ޯ`» ?qklh뮎2+]cW՚I:P4P1QSk/cT#d G`TV^Xel x~X@{V.D@⍯H2u9Yj s=NxKwt^v}@(#$6O&cs@t,Kȣ&ĽoJ+:ddg0%3Ckԃ.[uJ V=ӻӎu'^uzO2OB@a?4liZ*;@BÜ8Y6[|d%ڦĶO~~&!`x:oog7ySo LX5mE:'_ uը۲}J|/q/&QxF>/'"NX3S^;Zk 3-zldN 8D\qE.D(_qMʸ?ofʡ)LP?Q 8Y;;~?; USƃ~,ۯ܏# }R [z#$ip5g|=o0 4;g+rMWC١ƎUc+>F -U4꥘ u2G%IE{oz:;ĨkyՖf| MP,G92et\.:ʆ56ꅅ (DF~M:멶Xh"iE~Ìao7aFU fH$뺯'vuLB*l`ճt`L 0b**\;辬s:bp=(Ԇ特?<'جKR"Q4sX/}IE6n-/b84B&Y~RPnzƝ6U!`/{ Mw t[sa7Uzhⴏ RL2s~- `}oף~sFVtf S^r^!a|rzntdDrtʙEX( _dY2m8DM°ԨӰ:X9Bvr=P^}G〳cUͭ][V5q ū6xh[rfj-yB2'qe&gv-0Yhs/Ux;^][[fSy4MfG*#%ɀhtffɎ! r]Z^9Ɂ4硓Z~ن&XO>!CNhr,'ޮxBD T'NŰuBʳDǂe!'Li[cO)8Ka{\e 9ueisktaۺS܉`XEs.I҅2]Am񿭇tdғu9Ane6"Գ;/K+:_\gY(ˇ#Nk-X(h=5C)tRRŔ1EVAA;/J&im-qFS:CL΢J!}tRV5qMN2Dj =H*+9Y{µ r|'{!G݂U,HēaPwn^3]Q\ZmRW?B`Vk+$4\_ηK {?>ݽpfj/Ԭ1fiG/le :^2B;aK;7sКQk=]Iؼ^z[5_o-ߪ5~*=O\^z ~%>9/ ̻PHWO>C2O: ia'D?*^0.fO{x$7VCۻO#>wƞfpeePI5 $2lx9GuD EY "fdGB0k)yH(:n1f舽ğkZs0~;ތ/om5i<x>[(`J&Dalt3qA5[xDa/,D{ R+6&%˰3_] x LXlċ \/S]~եd_vp5j58)LES6;+vp2A KPd" 5YOy&Fv9*oG]7H\L)nw0(`&9䑷 J^J쏾B^xY}&UQ Ic.7OS! '=ufBPðqxfBdXD=hbU^hCWSɈnSuU1K YrϤ̘-"l޴|dDl2Sgx3U.9JHp.eƼ nK')ӻŖy~_a 2g{'tYP'KY2[ղ0}}0 @+ZۭIϐ(J=KiIWn']c}URغQ%??Ukl9h2^N^hlx*(c(憘6nh{h$!O=t>|﯀vޛgyjYwȕx_9`ZLJ[%ɦ{KRMJRd7XT<1\*sA> b &߬J[ ͒nYG@;I7ALI!_BIU!㛟-ۈ'p[z`-PfJ Eu3S I@Q;K[yTaL׮OYNJsΎu2 39W-]I7ҀyQCH16,Xy4R5 ^U[䧳U؍m1Y*ރj  z.Pr<c3Q\2o?n2WxgKywĉMScMRO5+,TF-dUϣUULsQ%} Ԓ<>Qka.~iVPXb~S}>vfo.r{؁3}RE ϫdg/ɇ#&9~A p֑ʖ)Lc23i{kYVjD}+ +wC[;u2mR4J}9?>Nt6SW"/6~jy; Ypb3Y9۠O@#C}ɔ4(K$T*#rcvfw5_TUU~L\Tƾ/ΈE݊BE\.ݮ"]00>gMDE2!I)<%]3A-A0y9KҐs6թ_7hZǃʝLq<(EE^$;0C"ƛ hwdROt۹x1l CWaf^M'3(b_ ^-zϱceOhʁIÊ[M9IHˎ6תi &G"{D/pG?1" Ԣ]e@guxLGǮaBSBq_t+.;:K[$٘9>`e_+g{d>-̮HZNC#*$iQHzur< ȔG^!L3 媄ЭJVT7n]!0ug4L)_s?hL0XTt,24mv ~̆h67@_^9VCퟎ fP"pl0jN߆FbZ_`i48!Ex #H"*"Cő/dzL*Zq2ҟwdWѪ=hdo=rQo=wОJ֮["z1ۦ\Ϣ8F3btVD2?\Oڔ`Mz0Uʷ~z$3(wc@ٽ^x$+O.})7b - W [-"/c=yH,&I D| >-1`+8tOu9s92&z`hzAfG2z+, i"]+F%x1%*]ׄ2k?DBYÑڡ΁/_`gk'&b{Eggd'à@Ԫ K5s(W|޿P{26޳M*.ܹla-,hc*{JkV>jaX0>)=N量"D>NFj$r OƱWB.2(/Wq8$%Q$Ѵw3ώH!}~ހ+qPjL-b(.i$L~&bLE4k3DY{pyN?QE<N!ཪm2 6[nSnA! {ʭZldO53#3W7ׅ+P6&,=RE$׃Ac7P]vG|V1(~ װ=P#zD3.#aʛeNnzyކ| ^Z+4xtτU&uT}zY`iF*UC:ss~T\ YCQclm3Zb &k1 􏏆mT-qiF L^lSx+qoڤCϿ`%  m ;i͉zcCm.QԜ̾`ݯͦᕓ5>˩*oj=@f˴*` `Al R-ijO^WFI?Ъ1vNPU_EA^ފ 8Nv${c>(RfVs,[M۾=aa!E?*g\z?&/sq "Lfۻؖy{ *=8O#K6p5_-$FdU&4Tb8Sc8/ Wo"kہdj sxCwFe l&V-%!]TDN¬sƼ់8D/8Io+شďKTHuCVOԌ9b1i͕dMY\J @RD-Um&ybD5}MxnUDC a鏤-d#Hejct>=h? 'fTClpc+"T G"w2 2C^mCym$!v/jD_ ǰ8 :j`ZS7vJZ.nbWUr^bE3N`JN@r@ݨ!B\Do&[t}f~/>ꐱbO:&iHKU1gK0l}`r{dSFkFO-G{ә*8]S9rkջ*H7Fe7f3c>K(c1vwD& 8aSNgUs0p0y&iY~'R 5#us@:/4s(Zz;%mpIͰmKW|paaj ?)WOa Ghs5i.;f4mlQPK"h"UfO3P BR0}@Ťt_BkT^/e̜܊-U(WZtih] ;m$UɨP͍aD{xg_O>ABly`7_`Z'lw f_;"s@W(j?uJ7CoP΋;-(DMCSZo_2Ji>%!!f7+? rsHjCٞZ\DQ-tg78K=,i/m ry?if)Ǔg%sNx Fţ `[,%R;KZގ~OY#9VؠdSy 4?`WK@;? v۞-!E S$[E]a9oT#m UUWE7=ezwq7koufHݹcpL<R[%)|KAxjgA-F|LEޖPٵVn- ]"٘x'>}A Q !qf`5ĔdI I7;t3dU%![mb ; #9/2,cQZ~4Q=h:9Cp6Arzl_ݢ v1]xVkeO6B:j$!aV/Zjč^OŰ*A3g˹yjJ7ͲuOq\*;YX`pGrX4ol;:>Q[WegJQCIM[ mKR<(кS]80yp^CSGP\#:7ٟrk6󗌫s;冄H$(TaF,yp0=sd]躒RsNձZmJJs*#O< 7U& {*!Ί?wY /)[];hBMфvW$%ٟ8Ku0|1ߙ ]N73: Xe%E! q0Id83XZ,RQ"V*@:"fCrl/ߌV0l/ `ţ` V(M<\C_., $ JHU x8?.DH _>χpX)xX^)Ðz9ܣ:Z~#z5Um>٣ x/[y*Oq֩G V/Za5sR ~  ~U%[E\T+g]qEcvx\ 'ඨ/u\0@=<o_TZ{cEg $8'}"̼1BG*KBdZ}Qs0s-=I@0y3\K[P&[+ttDP#(?`\щY9AaQchs;tφ ]!:ԕ&y#L:Uא$k߁ŸұiQMF4=D KR+~g9e?쪎#Cqy]ڇw¨8!\h7gL ?'Q^pyed $!c=PEۺ'\H?=.*oίXOͷigC6]  2:~lZFJE ?[QQo@r̋8>v^YLB8K* G]z[Z!Sg'";E׽H;Kp¾f7wujҲ+ K wm+SY+nLOdIxJC%~e+o?]Iӻ O0tx3Q餥t۴_K`2XA"r%C')"S7 ^?cWԓ0خ{=`Aؚ<,& tv^N(Gq1Eq-H!lAC3$5(:&Jg+D+7cuX=489=u.M߻BFč()#w=<$iyOPEJTY6*:qKU%"p̒4!AI̦Lw:2/3~h΢62\gF?10AL$5'=!sio .U=Ѐ3ENCś\LIY>ME="R]J8Ze5#BcO2ւr~x o"`š7cMO1uxksbہRW}3bos6vXc2]-b<ᱻZKɗ;&I2(cfx7VL*Vm1*0e0sCRArz1j6 W)j01gDAPvur_L4gs0咉*mY8nmԶ6ʏyzgeP~WØ3T|]ypPᑷ4t|EU(1̜Vv S^ 4[aoV i-j#Z|qJtJBU}nz|X+!5W[4lpӧO} mDW518.rάG^G9T5Y'tSM,~m06C*=aQDo^pNa'Z5! ``I>:ԧq٬#^(^\/]*eG m䴷]Fx_ǖ\D]5V뿩nN骠, ѷ5"f䁙+VF$˜_,&rgm uR-T+ߣAEK{生NPqP@Tqd5!>  ]5 ǔŚdEFnȄf,S=+Jv-iQdZ rrDA_7x>{bRD3dp&$ pٚ^'+k8㟬/qÌbW0rv;#V]@ilYkˠo*1Ĭ Y:BnH4V(oO.6?tY .\eS:Z~9]MC0xDqBc/$G&'Kgai,+ga|RŔB[G%19AÉb[PsKW $ \^£ ^!f3їc'Т-^_"Bmu`>-t !rڧ4G} 0VOnplWdRsRhegչ,ꇩش=FB:|zNkRVcx'E+3.F6C\ԄEQݝI ݮt/Xc  qSχ/Vb)J}4y9q`Z Wd[F!DJ跂 @i%GC#z ,Cʾk\\O"<}4ik`"9;:F7S%hJc[q wqBƇl",6&~axH `E`<ũ_T/ܤFz.гF‹Wi2#+7 N )1%:ӌjJFSb;b {WKWߖ0*`1DEc V47GIyx>=^fQ=h,YMnT,"n:j;T\ڢ|Sm@#)ֺܾyC3)ȔƘ8V/Bmqd=.43RIW$ѝ9ĭ^' ϭWExbۼ!H&֐sN6Ru+i_d5~}@. #:gzjeDh5\fcil.m_L`{N<9%;߼bm,8y>۠/FZ-ǒ XA;W](D)χs³-aA_iXFWsd )ӠygpQ1BCTPvn&en2+[6%# xO,r{ўt7U#Px876*ʪHm/^2WA06P G97Eaj6 &*.c9lb{e#d`5$@)JkS4ڳ oET&ze?8>ɚZ{Ⱥn\A):TӻוAaZ2VAk)65S+v:ָnLEWх0#o"dk/08g\qPK*gmͫev|4%I_#Sy*)0,jwqЙSU O!ܔ5up"?~Jk{w ܦC E?ZhI4*i.H BaUp TGJKW:}Het- sq!8Ga)^F;E֎RHIuig*O/Z,rG#=\iN[I.wg]m5E |G?1̨FtJoRr񿞔NEf\=j cu2XPukX_c)ygd..ͩ]֫zt3b;VD=;bԵOoVadcѥ488np1Wg:b A{YZZvU9p2E=jTQH]>ҊG䊎oi&tv[O3(C.#_.!a>OY㕎Q6uQF1[XYpP:m/Gu:Dh{nl/t@b ܧ$ bWqk~f0Mݎ0[?+P:69zq+n4T̗, #V5|e4 ̆~g8 ۾Hr,D`pGL4Ka L%|QH/KѹQm_ -WGJy(H^wdGidfVt-룂_‒3ɲmteX<ZfMUvBBڳ~Μe.PʲسWԼd.dPo#Ag>F0"obP}QAY KBQGWɎxMt-9ĞW$rg,XGb7s~BQ3+/!m0M"$3Uxtcx}DJ6r~kU|0{Z\xz kv[64;9y2`EaoiO:`*mj&R7 Nrޖ!i$0bBJG;h{?Ec{*n.F\)3a/LZOX3 w-uxzr |g/|WLRO€Wxvޚ&8/|}ԙ˴l-C9MU"ACd~%{kQ8{;/̔;,v;RH&i#M#P얼X󝶋KnN2*aϑ2Y${fؠg7'e;6R A>WC*6{yL˾ 75}ag=ٲ ˰ }O:|g(6bfAb ZNToj BB-&Q6C}ߕI%:""E3YF;G ˎoL1_AG+-ꕅ1tn&w0q8ZQ4MיrS4Ù4AhnO}qY~v.R nqǒmI" ^U^A65#14 ,NWo֍OPZSAH/r-ʥhWқ eIE[DNj0[(TR,qQ>9͖e U N.T }d^UĶJ82Х18ix mp^2|=Ԏ 2-an^Mf4Qķqbܯ!tݳ^1˫NfG-#JUvh|bz<9P`墟J[oţ+ KysvX/W 7O]`QADN4zq(tk5W5^}]gwU#IQX7-m $u:\ؗ4AiM`@J-ȃOgAYPLIU2Y`]T#EvxB gcyѐL 臡as}}U Oްw'x=fa`CAXgK}.4/\{0-KJ-UF0^^3ҷt+M_cCGgq'.OJI `Ҥ>8 : XuUg:?7yX'ϋ)q¹zy.i{ݾ *3cWnvV@>mn Mjp/7fםe3w-M`fu:Yo=#XÚy OSч\kt)'++7%+})skzjL5 DxhOϩ.{s:Tѫ[B)dM]0=iHctx~tLTw{-htNIq11}Yxfj ӿ5JQWQi0W ƗM"Rp CV`H:NIs5{_|sO+[A{[=Fo{[ 'Cmq{͸:*ڇ2w3ڨ$j#g@mT}"w\`z8Tݯ5F9=B@ۺW!zDJ_Ҿ{\tq>[F(2S1Ww+|Gށ /RD.'ڤ1w tR '!ݡΏW/NS#XkaD 9N_t[߇ѐ}Cv=6 U׻fnP"Ync"DM cNcB@O_Dk="!F"VW-^sӍ-;~6)M?4#pgP2 IEm\0vboߥ13/:R8Z4ART#P9=(ǘa; emr>2Q+HA 3+qVB8TFx& AO嚔jK7 4P_pRj%2@ k *2d̽X8QۜY09_u1jjG=`=C麦h}EOgg8 PI%j\tK~yZq=ح"euL񷝗){D^F޷vOWJs32Fi6YmPiJ9֚:qE(kܷ__ӛyiGCEy@{OCfY1tFhz)R5T7aFk3P?~aQ< t,rxyFkr)By Wv$cᒭ%i xkM=Dn],E I+#^#tbJ@@[(@;\Y] Y&$ޣgq_=usD=ID6GP9/0 ?蒐iS[gV'p;^r.Q'T.4ޕIo,6M/KU^a_|D=e`aUrOG%;v4{9y{I$u6[= |Ōb>UO_邆Տ!X0;yT(Ej֑Mϝ))[[sbs[FZEiz6uIYLeJ0 H!釷O{D:[ ?]Gy'LVK\:tc؟rBS7-GmC 9'yܕYoY; МtB AdZGվ>'M 0,SLbWI~9_^w +&+1!ߜ^.Ӻ=ii E:>oì:TZG|=X}hE6b)@{r GѕggEԺ4f|Ф1DLn#*KPzҵnNaEX ,-V6{̹x¾ 5U* ֺt:Dĸe;RkhdݽgsEP ,"nǜ׈uk'gL`@BC[ؼV$nqYvR#3" ߬B,72-o@qrA~^Τ$WL^eJqt),{EDWrBfR1j9iS{nygot"Pr> 2o&X5n;av5'仸ᯣ-v᫅ȥjIdHhc4tNGb[SI^ >@#c;ڃle.M(dgM,fDk9ZKWAEcJ[+/M*+Zc*P#W>dX ?Pm̆u:3-32SMN  *b{fUcY$ny^q<](bT!2 ؂jIw [!=,e+x]3 X2'A& ħwXXs#rgΩ f[hd`)p&#w 5B3|5s2ځ~2g ZK&Q=c,5h.` {t29%#DK9#Si1!(P:Qʆm9K8Yaq=M@\4/[}un܏ư' < ћs~V 5(J8u ~VѲ[\BWDS:vl'38Y uEM'J/g&@`JuHxS>vj}I^ˇ\SDzуѹRSCi3,7BS69В^.ßr5L)MNԷbxNqӕ#]?<2Gv1Ch^%31;T!#:V0É+HR)0tɒ\U+8lKv!uE~iԍoTbhQ7֞T ϮɆJηU@t+L #ˤ?PEYH†D"M2('a&u#y`) 47^==S"ckT. ` :c>DeNJ \Ϥݕ?{i?ӑ׭*OyqJݑ1UjZ0\Xte|m-U8hseG~+dL_jZȁ 5>N , }b)"es2ZW+D;2_wxW$ߏ  (08%p%9bfd# m Pe;'+!-qz!S8-;G EEt*wXZP\-Sv3sB~/'OtKb¸U<Ͳաkh߰{>`G7*m6n@˹ Ӣ<E4-%eφ3qUz0,N*q\xӲ\3jY*$;jV j# w:VdaOۗlz],h˂ʻJGimxú@a̖g=ɝ,1TS44 w"B \39Ӎe>"Mue{^<鶤8$>j(Z(4{6)e'NW^tmt=hg#(C `Q1_tLT8F2]QGFȉ\vɾ阕o4ʶ0[  4比v;)=C節R٤YO1qRc8p$øQ2+X7196~Qlf`WUSmmӬ0J]w0QVBQ[Qͯ0&> ݋epwXooUG"&uՔ)zo水a, ymwi{:׋Nw cH7 ޣՊJ}]e u%U@1o~ Zn)HܟԦ㑓ϸ=ќJ e(oN<-#= aDz|"D) s͍  T*?xoIR% Nw 簰b8MQ5nq߿'g4RkIed[2o 6q>۴^gO}`Gf zw@*Żѡr1ŊO9[SiiP@/c%M`#bU XG@K/C¶vK `EQּB ]F!/Lj1ʓ3g1P@ 8(x*p}=[&ZS%o Ҟ̀g}h&)=FZ1 _gp#w!l/p #Ă%92m!R 8KuWqya`j8Vpp{Gn$bhK3h87ԗDu~b_Ѓ\O5$>"rKr8)ݮ"c1vun.Y-U(nۿ`X89F՝- #r| 'UkO>\՗TOiޤI[F3aߣHG:JN[OBK*KxYM"?NFŧgTQ,jw\nK3"IkzSˎ*flO+U^:f@E*CũS:53" MܳwjaUyD(%Ys /++Q)NHBuZK>W.>^w3f\m$&|қQٴ9jwJ/U(&=֜@.VZ*eb<,MF{ RZ#R @0G)BAjZ?9-˦m4 eׅ˪BasK`L p)SO"@jy a+z'fm#KB\Vsak7^9D7tU}#G5qQ-T& T'[INX5}.E)OMu[~7` "f #?o%:(g<$kݑpaN1=}K P쥴0UWI WTz=N-<8x-9բ2UWy3JG 6bzԔ0@@0K%cJꆁ Y[ nyc0ƩU֦d~QyV~DEs! ݮܡHX9=/QY3 8)4Qd&piX=/Șw ȿ)fIp]e%AZ5=2bX~ۏ| 8>P׹F ?-!ׯ'{8^6uLJ!4 0}[05$5XӴ#gXX m2=2P;܋d%3~3=GN)e>121o,:!8vEe:嬳z`_\6jtE,l!:E vN^J./|Ѹ:= A͇RKE@6P!iphu3 Tz)n_ wN"thp>qJTKՄ"ShzoB4C/,;_Rd&e}D )j}ƞ7g0s1',M)U 杬̉=yyks w}X`jnN9%_&=>$JX0D/fٕw~G3S ^j#'$ ([q%r=&+&NDyC.ztGn$(wWCXٸfad.v9pYԳF"mo/@i;^L8?yc gdx@xص?y&Ygl81'8o3k9lQZOܸR"¬rp'kx\]-3"e@F$\ ~G >n5$uOϠ@7[k%VYJ@V $_HLGӕ~3Y2(#Nӆ`^k*<$:jp[] jIs80lڒajq5z&+{M{VThԈFì"D #fw$2sޢTzΛSn~j~u+gj5)\[H[_zϧWלvW6B >pzkwcb|,V cY}Lk,L]):K !0lT8ΞS.TXK͉&󗔘 .9Gyb}[bHuFTipi.N3fb ae\R=[ 7*vR#68,?!DҒt?R.d՝$lerx8\[6g5R(wCb|u $HxF9Q*o:23Y,(NߕrpV0OFIv{lWЉsb󳍰 -!o,ؤ٬¯2al4-?xTppD'),UA-cb͘X@ѻ f*eY*MKqF )HJ(0As/.Pv' 74ZzJj7eu%7̙Xjߝ9UXu*9;:Fjbda[{j}VHSt-tFFzs'WÍ0QsI1 <o͒u%QjhHPQv%gaop˫ӴPM&'j.W BN/yJ|Mrr@ǀA@_:H{>,W ?$V1ګ 3Q8੶Yi=rݪEYKou:FdW ,/DX])4}Ytd:kU!%둨:8]%ةUW!,UdmyuFsv@ 521\H3yb'͘,j~I~DD^"*O>n  ;K#O.&rWdɪu ;ެ-X9Xᡅ$+"]KGܭNsFNF(ndapwRc# !surLhYmX1$.7w.6s i :zI]ҳ@&lHq 7!wvYkYy(HAw< ?Ʀ q3CY?TD5bQmW3SM >~L,|tʳM<~2%E o%LޢጥG?c xˤ^$z7QeKiξ$1N4 ųϙ\82H L|JN s}M/.cl ]|J/U4? uiƂBB-nnQ۟g@ ֟܈Ӹ"UFRObP ǯ=>P6nQJ^g}]-?%4BAzНNm:4fIey^qT;|jvEvHNdm!GXT'"``Z d3UN;-'oo("_ F9w$4,4.H2#-`8+GEj;a}v SgYL+vGT-EB1=JUܻ'Vys{VYCMf_{:GbbkWuZM`Gg,4|E;SP1>IFȭ62$+,(;$"=Bei>v `-`a;?҆JT,F,6$Uv"rڰ;ar4Q6(Tpbniv_O^=mӞ#2 Ep%l1ٳ-ݼ!o'O0jR W $cr :d6I99=|S&:*~|mgӠ"a^%_8u' ^ght>VRs ۫Tx}tGz=< (%ԸNPÀ,e,N̸,aMSr,@G pȉe9f~Ny]μ9KaB!Cv.r zڂ_2:=MyVbqqBדeBlWLx1˫uu1:DKAx"ckBK13:$^Aau w+EIG ؋}˟J7"g$lJrHC{SYSo/ܟ'-tCWuoซC{.OC/Lfy빐3Bc[V^~R])TQv/42^[K-[)H:0Ev̬v>aBpo+qS|Y<8:V6j9Z&L]ܤ +B-5ƼKp84A{ʓYMERU *>l,ex  )^)< lv| ,6m~ RGT菉t%Hp1 X(dIpU|ݽIm<*k +WUN\x"oLmiMh P\p`U6z})8Qs,CdkBP%je 7,E)P"OyA H.L9r[Y0|A~E;;GD+˙/uκ6 I/%F=甠8陸 od+*INUKv!eGhCOݮ!Z*4 _cŦЍ;!^]50S^VĿ26 ͈ԏ_*ORs9]< m6E3N,yXȴ{o)p#Gohp kz(:(=&ݴԹS zY+[N r*i&%U, 8H1S$fV7ݟHUI$N k0[1ΗSO%IdӗO#@4!C^b6Ё\dP*Kޠ/TWmя궪Q @"t,Pr4p!p N }b3} 0HշS!MA.uAL_anlY<36tkE'KNĩ8)BzxW~`' 5O;Ѹΐ) bP} 3ٔ9 ۈq%`^;M.B8xF. Z!L n'8رZD{8]WF 39"ܰˬHdàsN/+ |G5'd5/9zN]4Ɩ#G<6@j Aq1eOgJbI߭#EBixܙ[v۲z#8 42ZЀW:ׁ}˱}q#}dc/ʈtZk׶ 49E+`ʻYeۓR;Bę!8|nDz[s`'`OL2kueF4K,ڷrB՗}:}.>?vT@4֯R\:EUʢ$PęA_MЩ$ ~|a}V;k<(nU*ɢߒI+o+a n nգ4>~ޫ`E7Cb0e յE={bTE$ &oGnw?_Ӻ.0\*$NhBo2qLH6ROdB7^%0̕a_:%ۈEbb$K:@^*/GG*/B3n:錪icls~eIW 3^21cjˆ=L:H ?wf(nFtp#VUO" Mo~dk} nW0К.&6 ɥŏ6n0Żk8\mA!YLJsN٧6ںl3hCGjYK4 Gr?PtjM ` 0^~xok h@OFQRt4үFZidMD!YDNŨ%П;v1_ x9 n9o#WrlI@T?uμNᧂM MTCYE]2ߘ/5[njQI+G (4eiq= qȎ٦<[DVbjCG96@p䌧HӖu D%ߥhMO8ɍeIJ{2+i> Œ9ٔf ,] 5†2yb ~Ȯ{'1bi|eQ=73qS۠Z割n2܏*Q,ήf=W9QQ< r3SϊctYv[35p84Y#!>j[ŏ*/Jz!}i5jj)-`PW%¬ NͩiAkZt[{ ED{9Ҏ,ޔOz2kS 6ۅfc"h+*q#v3LTpWidg+OE3rQJIXǩs Ի6?+aV[OIhT𲰱vڱ=ipoc<0fE$- ُJ/ݓX {hz[ODh֛5/d< ݧ7S&)"םץ*(5GN\ϝװmCخA뵖?0wjHkXoFTy+{zH@CۃrůZBPYSw!ɮ*1;𑣥Fc> @.ȲݝAN "ZVW'`U3c[ko}[?ž?E]9xgn1h>`[ 7n?РZQLu9#H$ao'2RYc3xyN/0!h \ӳԑ%ڝ(5;yE^'*e֡)]+L4g*WjGNKTBh ظF\x=xT@'JXq]"t oߋh_QS^ Q@)KX݋*#U[ 04J;:%(#@1X;7|XLaJ</ghe#TEU Z&OW.Uh]h |)(5η#$۰N2=Zx$eˮr6 N&g ɹf0ڀVoL߮Qj%ч7ms$p3m`഻p|2ou7G:ݰIрC\_ r0w#nnXrIJ 3*g)"t-ʼntqG'iLcS}VAMM R]0 q!_}Cŗr?eT Isaҕg}rk#B+_d٧eΈ-H3lYu5Gm_LV2H*x!mdIA3'fl5@VHV&`7%? F՝13 {i~Z:yKLVbΐUQ`z ENyI,6O#aG,x_\nW+ kkF]|IBQ1sӖ'd+|3u\# @.3mՔ&j =I^ٛXKI׶9Sk#771&™PI^/A{,5 vO팎6UJ(x@1Bߎ;-l!LؠVEiaLx lp95$gR{)XyH3 o3e=S1 啂JPϣN+|A{c|AOu|U5vK;䤠 OGF؋"X ǡxHe?=I8Ķ3]pieVr DzI1똰Cv: :#C{_DN6 fGN0ۖEwA[vn,G]&5") u!$5Ȥ-]D6$.Upr)x*2К :o~)c0d >DԂ~_Ov8kڟ+Xہw%X؋}'(ftj?>3N\@M/sR{pMƪ᭜Ϫ⮰͡89`~ DH`X.T]-<>y) XDj-4\86!*/PڋiZ#7y3(BiSM| ;ZC{Rc>ivVWb4)CJhHaSE]R(?(SeKrF`CtCfԲ ވC|4)qٴ%$qe--1^YBH3L>yn-!0] NɾtC(H%"ȶpf_ڞoJ%Hg , >qɶ}k˾"u2w>d,p,M%\&P7Zki^{;|l`d KPWsK[KPI{4|~jh4H;G:R5 ` UM'N $y\K;aD.ocp=`b'8|W7$ɝjlU G‡#QƂFZ*~s+B4v2.(tO({\vp k;:F@SF@S5Y뤶sAh^P_(95X䈣RTQpt[6O M =39N0EgAK++O1}w쌢?-s_ce>Ŭ`-!Ewn^^ `e G䈐~b#֭ ~Jv<'كG);>c0m!ԭ.=عbм5 9%H+ǖž,?n썢ɮNvF4x Dk1Q˻<Ob)E8JozFCGk["ߥ'WqZ㬢 B7{\VIF43 2lwh E xm6,/^UiAIX",Jo[PѹZNVN>Hv .4f~$\ܠ;ЗT)I?M&·"p𻵳XFgg>_pusP|C(wn%'i@?GMR[GjIg߽,-^QE!6 +W0c+ym Ҏ?{E2Av YT랅`:SӖ|V=Yb+:W Vzdqtke凎;M{.= lͻ0Bkjg}"MR5s~~qpS:Y+ċ 64 Cu* FT_Y EOx|r ~#Dp'2,ߜhaBI 1KoBEz[S@čA .ԇH҃n j<^Qq4q-Gl?OZ\b1 ,lhάti>+(Dxm]xbhGQVJ~N|:M$x2 Ύ,ס\8OO lnqQ3lv7ʠQkrU(NyO&2qʞiΪZ8LPAw]pyނhN  \}6t0Wꨗv#PO[iv^&N#5 }/slS4|cezx$0 ȫ%?<.D#>0Vc+reLE1¯*҆dNjAa>->O(ŔnaQ_< c}E'\p뢚ĮV2lt܆eSYA ,^0i҈_Ge)|ͷԳpd9Q[+PC(|.7tBBe9$3<\6- gM-꺄w3Y*_0;LoR9@%[V/aJvԓ&1d_7r!EI 䕲D">gv9ؔ,3-e?K@ІKoDLkblV.?9g I  0.6A猄*2NB-zG73>tJ_ ;J*G5yEϱ.EĤ^T0LT^ :p!V/kwESOcDҀp, 0s M19fr"wӦwKIu)2tˋ9Vڃ%}PH1Æu,r/l,&s+垐5󴰹pPQ >.绵I8u_OWɜ !Um8dhYtT8P[ƁFElP)j_\mS*7 E;sf&Dw8ɒ={͋U".'rqd [9‡סU#yҕ6_>uX- {i`2jE'_촩RG"~w H35eDumP#1}瘇:d-thr0aޝyhrbtci!Uz3["Ah4%4pK㽫Fa_;9{e `{`)RVS#wkXz~^f]P >4C~\Y ?[AINfBCBdXǘ+{m7Vx) ".%8F@]y<=kM?/uf? ذس2y>"b&p Xqt1*+ P_s<(ؚ=jV%m!*?S>|{^a\<(ԯ|\ fXlZ;o`e1 @rr1-19ޥ/pc,!B^?ԗ8E)/Qܗ) hyٯt4Znfh›;)}53x|w=s]ڶLJRnHc⾔y#n$JW;BJɕWZ8 v'0/qHZF`}iŸqLs3 ~7 өBoEře^\?LV! Ȕf2`anN9Mͨ~7cD5H9Щ&mДvtM#|x&,iRk <@j2ٽ9gXtkku<xV[~QBt;SM]x'[p^f7}g99#Q[j|W u2<@BN@{.|K5" YNNRja_Q[ly(J(J:*AIus FX; j'>_NH&8$ӱmϤ9UmKw29tH3[#(z[f mRӗ!~n AW.)Y7i6^MX[𲸐UkSn=]0C}9 ^KTkLO_WtRR rdO54[*>ɬg6z/W,ΉqA4DiSNN#퓄[j 5" )mό&$=Cm$VeUly(8Cjfɢ]羿අ$Od=Am׳£18aWt6rQKJŞT"hi @U'rH"u貾Q)CQ}Fi/܈zU蔥G+!r젓aY+7eWA :hH}&LY,#wΥ9ȴ _.a8ʭ((6Dx[G4Y,L×2_t? D6)a-J7Oks=YGhT%Z/tG.P!E,s XXH30Je^FØIv ci)qXS`WRkA#MOr;9(\`%ӁӸi#P+:n fJyKM1\cMZa& Nh8y N7{f2'0%0晒e)-v'Zaq" .+QB"\GߝI4 ~ŒFCW_x>Jnzra#bsno1 =';̪釋׹qn+{>d͌%22ͦSNɶw!_TM:e"-Md ߌɃ䰑bN+@fI*Vl`=ߔ{7d*1m; *pSb<0Dď}iQu>AaU,FbFRaݥo3b) 5K7\B BB WN9L ZCReHuLp5QG()]Of0{\Jm |snR"< )hPMsH׵ͪ[b_=% ˶^'lK𾍀!tW?]TәgIQL÷:L ز&CVS-C꤆Di1c_x<7C7@jn"„ $gc.\VTW<O%* [ | Z,Ѵd-3c<#u֣LN+J(uD䒻t%J{/6 J2rڣ[Qn0xB͜g( ,⃢ . QTAbC[16H@yw IsR!;uҤұ;Y^IDSi+4<"\LSULS"P9'; Uo[qŜ)"9}`(};uLܳTPQ)TӮN!Rׄ*Lҹ9I=5\98g qc VbcDyYr[gbZf9/{-?>TW|t}@;k@cʫs?]sUs֣<|C1?I-Ցq ޻f6;egJȝf+NܨCl}w`.1veFx9DL4:Ai]R9?rM<ۙ؈ p}ww aK]NJ^eûFt3 w o 8q="MCwm|iiF7xd K5%3.5t=Eu(>flcvhEuWsDkjаo§m5Q/ %_"Ou{ w,[8`߼\Y4zi^g[0LAw.4e5ggGmfvaMqw 6pv+imW7$h]rgGrK+,n§5;3ċSfctݨ^@6zSh腊x}W+M ~clwNqr"S@ɲA,œ!?%FT{$1/brlxV~v&Ӧb/~.\{GWu_ q*䄰%TE,I4&]*D*VXQVG LddFFh3VIA"JN4csǞmzw&Je-X:g?58l dB }^(X} ? P8CecTp|4&6o$zHD*ʸNV 7C6+O'ztll^cZvש+(~yO%C'iC&6ișG#K4?#_ DDw|Ia0ؚyݼ(t?JX53&}fܐ/!֛R1tF ^;s)VË`߳+/Y|2iO/ -\35F˺NID(+{P;%0&o%GHjf՟ _mөה~pg-覚( ?ؼ5"C- o[x~TֿJq'k^>sy^'pFP_'L(NwqL1Ӆ)2j.t'zDy[u 窋,=ܥOSs˗:׹D\UE,rcJ P RcP@0]>8aC`zDh L< tS [ Sج-:̎\$Y2n-سS,z!Px8"R$]iV=6β RdNPwFxYVfmA j>1ӿT (E`Ď )vUPRrt.^(17jqng&3}{],(c;>G4u&:qq%%H{NQ:J1MNc4)mųgcH\D:W`x׋/Bް_@g\B_k<DPk~kN8o,9ӌHӫ̶LVΟiW4Xtv:)C Zh+2gwO@»p 7_UgWDnf Z ^F* D n,a3A{oKkM=2# eQu?bNEhj3@ʏ!:.uH b(S3W_q`OX8f3*ڣ^2s@vAj\fs~JlLgd荫J/k6UQ9#d^2 DaW_ٸ|wPz, }W>p*dI7c7)Bw!zثYl0ND:NMjkԶw9@qshKcsJMQw듿tI$,bT"2N7(h4J+pӑTϥvt\CB@oaMqmfDu`NCE6,FF *|iNCѣE-?hy=c]wƗ^(!vx[zt70/iZƉUTFa3J'AC#)g?ՑCD{鱶ubqd%W2TZu1mK 6Oɑs#Ы:2`AAZBdFAxg&g) &[̤p~aāK%;ԑJyW_Zzt:yqEMt,MݬPܸͶE&.0Ŋ)o=]$  ),Tx ~󜓁[rNu%hyz9VNMoBqfzIAFC0}mzo6HoMHZj΁nXrj>3̖j m,|)%eVF駥S:ZRBpxxNO=/Fx_&ۑy59ikrFq_8h.<-MsAQ/;V-e)Mm";˄VDF ~azȾgўuj'I:?8mȉ$ Mza ܹ2qo1=nQ[YQ|v$X ^ h3[7"XwJśX ~YNrfFP>l~;4PD8FpU˧r1ƽF_&N5 : QәE!v܎% YN㜦M} 7LJiZko7yڪکѝ|ߡϜA/m33P*%^_ACKѦ#mt%팉՗qR|Ƈܥ8UyHùw$UpT[]nY;-M刘VT*Н:R)mDN;Pz)9eF,Y#OT@"C(Vnf'xI\*H|3Z#\4տ=o hOU? @ ;ww6/{9cs Kۍ '8~'e=βhؓ.riT%z[1zۇ5aRG|S5 lj&hĢsG &eRďd@:Io]~e"?oY;3O-~w='&ΧdqjnPo'gתgrDIQ''c^ sWŤ^  9B88'(:.0?zr-q*v<Rd] Yҿ˔mL g.bL5(O։Ș{&բ6,Z(?}%R{`ƃfn3n+<&`Z::P:]$vCgqE~Jz]V$}@PK%"SkDŽIc?jȓ3=cdWG?y)ơt:T9˙m݈Qn{# 'm2ïxwPtzhʘ7sB)d5nTM;J2>}cUlg$%+(AB'*V;}:X$E_ô|ֽNR6H_tuNL]j^܊} K"+E} Ul'k|l蔹Cx)UI 9T|DKvJrІ9~ /a5ք1 Zg&3.@$5/AGcS\iޜ@XUnK[ↁo0@ .]B;ӶcsePF=eمj+Xqw?`2Sٵ#"u/]uFCUٽ{}j [j+H AO'ui Ɂ~P+N$Мr+ϑHCz> L˚}'澖:Mbo)K-؏ },Nvou/B27T L8j0IW `71Y;6o^s*?Uh\avU,;/].t& 0Yuate ֽD#JOtGz2.=O|k#Qn:@ʃ?k~L*{./|V;e\Gdg?03MYo c6Xuk#z}Flo?#[oÈIkRȹ.GA`*ÙRk\{Q%n93v#l X嗂@89 H7:Y/*F™ ;=/AYG\!x: ZQp#4t@㖝ZꚘ}CQ4yQQuV*R01"< #oiY YiO T)z+u,E,fmSEcػEHoe#85Ч~WK2YĂ}ty:œDW[~i}8џ+{zl{pq C0x爽t|QWVfY@c]`hM"J#&.XKҡ:ߚ.p2v_lptj9y{đ+{Gn1:É 8|-G*v-Ta݈鞐ĬSOrb[`+ ,{>UsƂǻĩ~#THB4JN>UpHid.ߐ64Yo'Yy!()r+} lza6'>ZF ICPtl5} ۓO+zrvy3%sԴ<ᢟ퓜M̃s/BcCo4%3Ir7A;vڠ?tD_0AG/8Z݆\$M0vSj 2;v7]1vq=[$SM?go(KL_,;@ۨ ;&KΤ@شϷb7!͏pq^\X7ϑY: _QUcthإ ,M4g4Va|\؃[o A?d4^9CFj:}9.~D)*tD!Yݹ .7_O_tmBCtF7SaΆ!A6Wˍ5Pqmd"dql~|ƅNљZ;gĨ6П0V8f򢚴^ۓ0c>CFuCW`-Z1 wpkg(VI7[4gm&*NG{ rp%?8Ф)!n@IȾ`OϦr1Z\LNj~z 4I:21=>6t iS18ONHn{]w@{2Iu*$0[S"mȒr;wfs蠔>(X.JvV~`/f4NwUόF[͖ b|ҾO^*˖esf 8k`,|+F`j0cJUg],-!y'){`} e&τ5SD:.UzIwXokr[JZ ag_Z. u l_ln %[hoU@t &T>{Wm>qEl&>ف#122׈֖<:)FKiUa ##};1D,'&[QP+S_8`gvRgu82׵Gc?"d5(ʺ uoFg ̀e-S 69U!Qzv8$Œl3 \秞5ޚ#fQ{w?g~Vc8e)OM{hqUN7*8312:1 |oӏRN*٨07^Tpkfמ%(QKJ\h8ra' I 2R:r=xO)v|EeՌ F+JCf1NǀBD}ujbIoEʎYHS$b;ߘM珚)~(RU lnqaLX]Ohͺ`i eEΩ足᫳Jh9N/RNK۱eg 䉆5 R{ґ9L&|c·4_6ѥP\; (2գ 0dWtGdX )2G(2=y @iXf>Cy뚫n'}&n@Ȇ7{k5{"a)\k6uWs'-#z-+˒̆uݰ)b׿  p,+$OHӸ nIdfR{ހ׬&Py#qP0 ]Y0)+1 $**Hh.fq$Y^|Ǫ Eiad7uKSnYn4)>TYEmGlSJH4s'BC糝JoЂ=&5쐝z &!bByƔYRpHQ܎;nRޡz^=xVhM ~vQuN4,=+vo둙E4o h|Jĕ@>=↑N@ɐ-|Kƻ»z-NvN'[/p>ܦʰTuH]r|ƙ f_juOs*(~Z7:)udS~cyAR{p. &Q|}yYMiϱ@:ꈧs=i\a,=dϪc )7SN J7 L8[dXäl{`]vlsz?B(4|59[ q3")|׶,m 3q'MsZ mXQqՋܕFh t{/*[^,`k"MnwY*3s%X-nsqtRFuHW;vR{ "⦨^;SqҲJC-h$PZ?^Mڇv{3çs2*ٺ#A@UBUՄz&ɚpli4`&[YkgVjOյ{(o{dbd 5\Bq6XJW~a£14_Op䰚)ƏF2RxU썗YӤ *MXJ= CCj )sB)7Bi%}#A؅@#a%TL*\hCR`XN$tH| >>ݦi ])U9~])]$4kh޴aĤlFB96N#&ҫq/B^h"ɥSH[̰iHxHxJ J:BQ"~n>h(-Dz(*r:Gd2l\.+mX;+#:Tcn!_-'e{DQe}_dm]ZoXv f̆ۃ:;۽:7@[X! e} C a~k`evg[ (2ESJw~Xu", $Vqw5Ӎ Go"jH5 طp箂qf#Rî 㦉]F]*CUOߋdϫjU9MbJjBy/)D]lch,F% s;ߚ{9i,_ d%vIsnZ=i{`t9go.OGzx O×2/c fItk s"ϱ}MF>rTSyX~?>5AGh??WPоQ ,!/nG BBP6%vt) }4lMĸklv9+xm"Kfy/eTIQ`I aI.ER9rBJ ۇ X$#&&]b(롤xc``|zIk>w[LdKiW7h`_ A,!DO(.Vb^km#%lQ2G;Ŷ YZ