pdns-recursor-4.1.12-lp151.3.9.1<>,U؉_2/=„͝[PH#m(\t9+SaHL߰{*b$H(l53t[{o3q-MKc [p% ?_R y0ES9A;:bw5TVRӪ?px'-٧=v0K0Y%.RyOq(d7P: YHFX\cNxId ) z,c--7ZVXbTEy͵c>Fw?wd # p 04GPa z%  `         |     8d 99'9(8*9<*:*=p>p?p@p&Fp.GpH Hpx Ip XpYp\p ]q, ^qbricsdsesfslsus vswv$ xvT yv2zwLw\w`wfwCpdns-recursor4.1.12lp151.3.9.1Modern, advanced and high performance recursing/non authoritative nameserverPowerDNS Recursor is a non authoritative/recursing DNS server. Use this package if you need a dns cache for your network. Authors: -------- http://www.powerdns.com_2obs-power8-04ropenSUSE Leap 15.1openSUSEGPL-2.0-or-laterhttp://bugs.opensuse.orgProductivity/Networking/DNS/Servershttp://www.powerdns.com/linuxppc64le test -n "$FIRST_ARG" || FIRST_ARG="$1" # disable migration if initial install under systemd [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$FIRST_ARG" -eq 1 ]; then for service in pdns-recursor.service ; do sysv_service="${service%.*}" touch "/var/lib/systemd/migrated/$sysv_service" || : done else for service in pdns-recursor.service ; do # The tag file might have been left by a preceding # update (see 1059627) rm -f "/run/rpm-pdns-recursor-update-$service-new-in-upgrade" if [ ! -e "/usr/lib/systemd/system/$service" ]; then touch "/run/rpm-pdns-recursor-update-$service-new-in-upgrade" fi done for service in pdns-recursor.service ; do sysv_service="${service%.*}" if [ -e /var/lib/systemd/migrated/$sysv_service ]; then continue fi if [ ! -x /usr/sbin/systemd-sysv-convert ]; then continue fi /usr/sbin/systemd-sysv-convert --save $sysv_service || : done fi test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$YAST_IS_RUNNING" != "instsys" -a -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi if [ "$FIRST_ARG" -eq 1 ]; then if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl preset pdns-recursor.service || : fi elif [ "$FIRST_ARG" -gt 1 ]; then for service in pdns-recursor.service ; do if [ ! -e "/run/rpm-pdns-recursor-update-$service-new-in-upgrade" ]; then continue fi rm -f "/run/rpm-pdns-recursor-update-$service-new-in-upgrade" if [ ! -x /usr/bin/systemctl ]; then continue fi /usr/bin/systemctl preset "$service" || : done for service in pdns-recursor.service ; do sysv_service=${service%.*} if [ -e /var/lib/systemd/migrated/$sysv_service ]; then continue fi if [ ! -x /usr/sbin/systemd-sysv-convert ]; then continue fi /usr/sbin/systemd-sysv-convert --apply $sysv_service || : touch /var/lib/systemd/migrated/$sysv_service || : done fi 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 pdns-recursor.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 pdns-recursor.service ) || : fi test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ "$FIRST_ARG" -ge 1 ]; then # Package upgrade, not uninstall if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : ( 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 pdns-recursor.service ) || : fi else # package uninstall for service in pdns-recursor.service ; do sysv_service="${service%.*}" rm -f "/var/lib/systemd/migrated/$sysv_service" || : done if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi fi+;Kk  F 䁠A큤_#_#_#_#_0_0_0_1\9\9_#_#8982fb8cb72ebf187fd67438f35019589c19544a34ba2eb57a0c76948df053e984d5499ee1d269602f645e5426934cbee9ab21caae27d76b9d598bc44006e21cf45aa768c839e79e953d6cbc90e14353dc131a5181bfe9a85e93eb3678025716053abc1aae505a1ed898d125c4ddd32d2eb77b91fdd98a0b7c58ceba965f46940820cf51955d947116285a1b6f88dbef0f352ddac5b4869ed11f2130e626c79fc12833e02c3e118c75dcfa7014e2b6140ef7de2c39478c8cd621f70cc87aa00df9c375a1be4a41f7b70301dd83c91cb89e41567478859b77eef375a52d7825059cf9d2cc84f3e9da7a6776fad0b9ef9c0686b07ccac0b74d92ac8077876edfa397d43677806dce2f28f040b90f18b0e20f56bb92860b3ab0d36f05c795888ad845f84e3a3cac534781f014f97033ae90d4574b186d9455762948499fe512ae12servicerootrootrootrootrootrootrootrootrootrootrootrootpdnsrootrootrootrootrootrootrootrootrootrootrootpdns-recursor-4.1.12-lp151.3.9.1.src.rpmconfig(pdns-recursor)pdns-recursorpdns-recursor(ppc-64)  @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@     /bin/sh/bin/sh/bin/sh/bin/shconfig(pdns-recursor)coreutilsdiffutilsfillupgrepinsservlibboost_context.so.1.66.0()(64bit)libc.so.6()(64bit)libc.so.6(GLIBC_2.17)(64bit)libcrypto.so.1.1()(64bit)libcrypto.so.1.1(OPENSSL_1_1_0)(64bit)libgcc_s.so.1()(64bit)libgcc_s.so.1(GCC_3.0)(64bit)libgcc_s.so.1(GCC_3.4.4)(64bit)libgcc_s.so.1(GCC_4.2.0)(64bit)liblua5.3.so.5()(64bit)libm.so.6()(64bit)libm.so.6(GLIBC_2.17)(64bit)libnetsnmp.so.30()(64bit)libnetsnmpagent.so.30()(64bit)libprotobuf.so.15()(64bit)libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.17)(64bit)libsodium.so.23()(64bit)libstdc++.so.6()(64bit)libstdc++.so.6(CXXABI_1.3)(64bit)libstdc++.so.6(CXXABI_1.3.3)(64bit)libstdc++.so.6(CXXABI_1.3.5)(64bit)libstdc++.so.6(CXXABI_1.3.7)(64bit)libstdc++.so.6(CXXABI_1.3.8)(64bit)libstdc++.so.6(CXXABI_1.3.9)(64bit)libstdc++.so.6(GLIBCXX_3.4)(64bit)libstdc++.so.6(GLIBCXX_3.4.11)(64bit)libstdc++.so.6(GLIBCXX_3.4.14)(64bit)libstdc++.so.6(GLIBCXX_3.4.15)(64bit)libstdc++.so.6(GLIBCXX_3.4.18)(64bit)libstdc++.so.6(GLIBCXX_3.4.20)(64bit)libstdc++.so.6(GLIBCXX_3.4.21)(64bit)libstdc++.so.6(GLIBCXX_3.4.22)(64bit)libstdc++.so.6(GLIBCXX_3.4.9)(64bit)libsystemd.so.0()(64bit)libsystemd.so.0(LIBSYSTEMD_209)(64bit)pdns-commonrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)sedshadowsystemdsystemdsystemdsystemd4.1.12-lp151.3.9.13.0.4-14.6.0-14.0-15.2-14.14.1_^z^@\\N\J@\E@[@[v[[[-[@ZЛZZe@ZF.@Z%8Z%8Z@YY5Y^&@Y[@Y?YR@X@Xx@XN@W@WίW WW@U4@Uv@U@U8TܕT_W@TR(@TO@Adam Majer Adam Majer Adam Majer mvetter@suse.comMichael Ströder Michael Ströder adam.majer@suse.deadam.majer@suse.deadam.majer@suse.deadam.majer@suse.deMichael Ströder adam.majer@suse.demichael@stroeder.comadam.majer@suse.demrueckert@suse.deadam.majer@suse.deadam.majer@suse.demrueckert@suse.deadam.majer@suse.deadam.majer@suse.deadam.majer@suse.devcizek@suse.comadam.majer@suse.deadam.majer@suse.deadam.majer@suse.demrueckert@suse.deadam.majer@suse.deadam.majer@suse.dedimstar@opensuse.orgadam.majer@suse.demrueckert@suse.demichael@stroeder.commichael@stroeder.commrueckert@suse.demrueckert@suse.demichael@stroeder.commrueckert@suse.demichael@stroeder.commrueckert@suse.demichael@stroeder.commichael@stroeder.commrueckert@suse.de- any-cache-update-4.1.17.diff: fixes cache pollution related to DNSSEC validation. (CVE-2020-25829, bsc#1177383)- rec-acl-4.1.16.diff: fixes access restriction bypass. While API key and password authentication is performed, the ACL set by `webserver-allow-from` was not enforced. (CVE-2020-14196, bsc#1173302)- bogus-empty-nxd-4.1.15.diff: fixes an issue where records in the answer section of a NXDOMAIN response lacking an SOA were not properly validated (CVE-2020-12244, bsc#1171553) - hostname-4.1.15.diff: fixes an issue where invalid hostname on the server can result in disclosure of invalid memory (CVE-2020-10030, bsc#1171553) - ns-ampl-4.1.15.diff: fixes an issue in the DNS protocol has been found that allows malicious parties to use recursive DNS services to attack third party authoritative name servers (CVE-2020-10995, bsc#1171553)- bsc#1130588: Require shadow instead of old pwdutils- update to 4.1.12: * Improvements - Provide CPU usage statistics per thread (worker & distributor). - Use a bounded load-balancing algo to distribute queries. - Implement a configurable ECS cache limit so responses with an ECS scope more specific than a certain threshold and a TTL smaller than a specific threshold are not inserted into the records cache at all. * Bug Fixes - Correctly interpret an empty AXFR response to an IXFR query. - update to 4.1.11: * Improvements - Add an option to export only responses over protobuf to the Lua protobufServer() directive. - Reduce systemcall usage in protobuf logging. (See #7428.)- update to 4.1.10 - #7403: Fix compilation in handleRunningTCPQuestion without protobuf support- update to 4.1.9 https://blog.powerdns.com/2019/01/21/powerdns-recursor-4-1-9-released/ - Fixes case when Lua hooks are not called over TCP (CVE-2019-3806, bsc#1121887) - Fixes DNSSEC validation is not performed for AA=0 responses (CVE-2019-3807, bsc#1121889)- update to 4.1.8 https://blog.powerdns.com/2018/11/26/powerdns-recursor-4-1-8-released/ - Fixes case where a crafted query can cause a denial of service (CVE-2018-16855, bsc#1116592)- update to 4.1.7 https://blog.powerdns.com/2018/11/09/powerdns-recursor-4-1-7-released/ - Revert ‘Keep the EDNS status of a server on FormErr with EDNS’ - Refuse queries for all meta-types- update to 4.1.6 - Revert "rec: Authority records in AA=1 CNAME answer are authoritative" https://github.com/PowerDNS/pdns/issues/7158- update to 4.1.5 - Improvements * Add pdnslog to lua configuration scripts * Fix compilation with libressl 2.7.0+ * Export outgoing ECS value and server ID in protobuf (if any) * Switch to devtoolset 7 for el6 * Allow the signature inception to be off by number of seconds - Bug Fixes * Crafted answer can cause a denial of service (bsc#1114157, CVE-2018-10851) * Packet cache pollution via crafted query (bsc#1114169, CVE-2018-14626) * Crafted query for meta-types can cause a denial of service (bsc#1114170, CVE-2018-14644) * Delay creation of rpz threads until we dropped privileges * Cleanup the netmask trees used for the ecs index on removals * Make sure that the ecs scope from the auth is < to the source * Authority records in aa=1 cname answer are authoritative * Avoid a memory leak in catch-all exception handler * Don’t require authoritative answers for forward-recurse zones * Release memory in case of error in openssl ecdsa constructor * Convert a few uses to toLogString to print DNSName’s that may be empty in a safer manner * Avoid a crash on DEC Alpha systems * Clear all caches on (N)TA changes- update to 4.1.4 - Improvements * Split pdns_enable_unit_tests. * Add a new max-udp-queries-per-round setting. * Fix warnings reported by gcc 8.1.0. * Tests: replace awk command by perl. * Allow the snmp thread to retrieve statistics. - Bug Fixes * Don’t account chained queries more than once. * Make rec_control respect include-dir. * Load lua scripts only in worker threads. * Purge all auth/forward zone data including subtree.- update to 4.1.3 - Improvements * Add a subtree option to the API cache flush endpoint * Use a separate, non-blocking pipe to distribute queries * Move carbon/webserver/control/stats handling to a separate thread * Add _raw versions for QName / ComboAddresses to the FFI API * Fix a warning on botan >= 2.5.0 - Bug Fixes * Count a lookup into an internal auth zone as a cache miss * Don’t increase the DNSSEC validations counters when running with process-no-validate * Respect the AXFR timeout while connecting to the RPZ server * Increase MTasker stacksize to avoid crash in exception unwinding * Use the SyncRes time in our unit tests when checking cache validity * Add -rdynamic to C{,XX}FLAGS when we build with LuaJIT * Delay the loading of RPZ zones until the parsing is done, fixing a race condition * Reorder includes to avoid boost L conflict (bsc#1089814)- protobuf support is available in SLE-15 - Boost.Context library is not available on s390x- update to 4.1.2 - New Features - #6344: Add FFI version of gettag(). - Improvements - #6298, #6303, #6268, #6290: Add the option to set the AXFR timeout for RPZs. - #6172: IXFR: correct behavior of dealing with DNS Name with multiple records and speed up IXFR transaction (Leon Xu). - #6379: Add RPZ statistics endpoint to the API. - Bug Fixes - #6336, #6293, #6237: Retry loading RPZ zones from server when they fail initially. - #6300: Fix ECS-based cache entry refresh code. - #6320: Fix ECS-specific NS AAAA not being returned from the cache.- update to version 4.1.1: + Fixes security vulnerability where man-in-the-middle to send a NXDOMAIN answer for a DNSSEC name that does exist. (bsc#1077154, CVE-2018-1000003) + Don't validate signature for "glue" CNAME, since anything else than the initial CNAME can’t be considered authoritative.- _constraints: we seem to need at least 8GB RAM to build on S390x and ppc64- enable ed25519 support (new BR: libsodium-devel) - enable net-snmp support (new BR: net-snmp-devel) - simplify BR for lua: lua-devel everywhere now- update to version 4.1.0: + Improved DNSSEC support + Improved documentation + Improved RPZ support + Improved EDNS Client Subnet support + SNMP support + Lua engine has gained access to more parts of the recursor + CPU affinity can now be specified + TCP Fast Open support + New performance metrics + For complete changes see: https://blog.powerdns.com/2017/12/04/powerdns-recursor-4-1/- update to version 4.0.7: (bsc#1069242) + fixes CVE-2017-15090: Insufficient validation of DNSSEC signatures + fixes CVE-2017-15092: Cross-Site Scripting in the web interface + fixes CVE-2017-15093: Configuration file injection in the API + fixes CVE-2017-15094: Memory leak in DNSSEC parsing + Fix validation at the exact RRSIG inception or expiration time + Extract nested exception from Luawrapper + Throw an error when lua-conf-file can’t be loaded + Lowercase all outgoing qnames when lowercase-outgoing is set- Added pdns-recursor.keyring linked from https://dnsdist.org/install.html- Don't BuildRequire Botan 1.x * Botan will be dropped as the 1.x branch is EOL and won't get OpenSSL 1.1 support backported (bsc#1055322)- update to version 4.0.6 + fixes ed25519 signer + update root-servers.net entries + fixes handling of expired cache entries so they expire faster- Enable DNSSEC validation by default.- update to version 4.0.5 + adds ed25519 (algorithm 15) support for DNSSEC + adds the 2017 DNSSEC root key + complete changeset is available at, https://doc.powerdns.com/md/changelog/#powerdns-recursor-405- move autoreconf into the build section- use individual libboost-*-devel packages instead of boost-devel - add signature file for upstream release- update to version 4.0.4 The following security advisories were fixed - 2016-02: Crafted queries can cause abnormal CPU usage (CVE-2016-7068, boo#1018326) - 2016-04: Insufficient validation of TSIG signatures (CVE-2016-2120, boo#1018329) complete changeset is availalbe at, https://doc.powerdns.com/md/changelog/#powerdns-recursor-404 - remove 4462.patch: in upstream release.- BuildRequire pkgconfig(libsystemd) instead of pkgconfig(libsystemd-daemon): these libs were merged in systemd 209 times. The build system is capable of finding either one.- 4462.patch: Disable fcontext usage with Boost 1.61+ and revert back to slower SystemV ucontext. This fixes failure to build with newer Boost version. (boo#998408)- update to 4.0.3 A new release for the PowerDNS Recursor with version 4.0.3 is available. This release has many fixes and improvements in the Policy Engine (RPZ) and the Lua bindings to it. Therefore, we recommend users of RPZ to upgrade to this release. We would like to thank Wim (42wim on github) for testing and reporting on the RPZ module. Bug fixes - #4350: Call gettag() for TCP queries - #4376: Fix the use of an uninitialized filtering policy - #4381: Parse query-local-address before lua-config-file - #4383: Fix accessing an empty policyCustom, policyName from Lua - #4387: ComboAddress: don’t allow invalid ports - #4388: Fix RPZ default policy not being applied over IXFR - #4391: DNSSEC: Actually follow RFC 7646 §2.1 - #4396: Add boost context ldflags so freebsd builds can find the libs - #4402: Ignore NS records in a RPZ zone received over IXFR - #4403: Fix build with OpenSSL 1.1.0 final - #4404: Don’t validate when a Lua hook took the query - #4425: Fix a protobuf regression (requestor/responder mix-up) Additions and Enhancements - #4394: Support Boost 1.61+ fcontext - #4402: Add Lua binding for DNSRecord::d_place- update to 4.0.2 Bug fixes - #4264: Set dq.rcode before calling postresolve - #4294: Honor PIE flags. - #4310: Fix build with LibreSSL, for which OPENSSL_VERSION_NUMBER is irrelevant - #4340: Don't shuffle CNAME records. (thanks to Gert van Dijk for the extensive bug report!) - #4354: Fix delegation-only Additions and enhancements - #4288: Respect the timeout when connecting to a protobuf server - #4300: allow newDN to take a DNSName in; document missing methods - #4301: expose SMN toString to lua - #4318: Anonymize the protobuf ECS value as well (thanks to Kai Storbeck of XS4All for finding this) - #4324: Allow Lua access to the result of the Policy Engine decision, skip RPZ, finish RPZ implementation - #4349: Remove unused DNSPacket::d_qlen - #4351: RPZ: Use query-local-address(6) by default (thanks to Oli Schacher of switch.ch for the bug report) - #4357: Move the root DNSSEC data to a header file- update to 4.0.1 Bug fixes - #4119 Improve DNSSEC record skipping for non dnssec queries (Kees Monshouwer) - #4162 Don't validate zones from the local auth store, go one level down while validating when there is a CNAME - #4187: - Don't go bogus on islands of security - Check all possible chains for Insecures - Don't go Bogus on a CNAME at the apex - #4215 RPZ: default policy should also override local data RRs - #4243 Fix a crash when the next name in a chained query is empty and rec_control current-queries is invoked Improvements - #4056 OpenSSL 1.1.0 support (Christian Hofstaedtler) - #4140 Fix warnings with gcc on musl-libc (James Taylor) - #4160 Also validate on +DO - #4164 Fail to start when the lua-dns-script does not exist - #4168 Add more Netmask methods for Lua (Aki Tuomi) - #4210 Validate DNSSEC for security polling - #4217 Turn on root-nx-trust by default and log-common-errors=off - #4207 Allow for multiple trust anchors per zone - #4242 Fix compilation warning when building without Protobuf - #4133 Add limits to the size of received {A,I}XFR (CVE-2016-6172)- update to 4.0.0 https://blog.powerdns.com/2016/07/11/powerdns-recursor-4-0-0-released/ https://blog.powerdns.com/2016/07/11/welcome-to-powerdns-4-0-0/ - packaging changes: - enabled protobuf based stats - enabled botan based code - use upstream systemd files- do not use /run/pdns instead of /var/run/pdns in the init script for the rest we have the systemd unit file- update to 3.7.3 will prevent short bursts of high resource usage with malformed qnames.- call systemd-tmpfiles during installation- update to 3.7.2 with a fix for CVE-2015-1868 (boo# 927569) Bug fixes: - commit adb10be commit 3ec3e0f commit dc02ebf Fix handling of forward references in label compressed packets; fixes CVE-2015-1868 - commit a7be3f1: make sure we never call sendmsg with msg_control!=NULL && msg_controllen>0. Fixes ticket #2227 - commit 9d835ed: Improve robustness of root-nx-trust. Improvements: - commit 99c595b: Silence warnings that always occur on FreeBSD (Ruben Kerkhof)- update to 3.7.1 This version contains a mix of speedups and improvements, the combined effect of which is vastly improved resilience against traffic spikes and malicious query overloads. Minor changes: - Removal of dead code here and there 04dc6d618734fc630122de4c56dff641ebaf0988 - Per-qtype response counters are now 64 bit 297bb6acf7902068693a4aae1443c424d0e8dd52 on 64 bit systems - Add IPv6 addresses for b and c.root-servers.net hints efc2595423c9a1be6f2d8f4da25445198ceb8b57 - Add IP address to logging about terminated queries 37aa9904d1cc967ba4b5d5e17dbe41485f8cdece - Improve qtype name logging fab3ed3453e15ae88e29a0e4071b214eb19caad9 (Aki Tuomi) - Redefine 'BAD_NETS' for dont-query based on newer IANA guidance 12cd44ee0fcde5893f85dccc499bfc35152c5fff (lochiiconnectivity) - Add documentation links to systemd unit eb154adfdffa5c78624e2ea98e938d7b5787119e (Ruben Kerkhof) Improvements: - Upgrade embedded PolarSSL to 1.3.9: d330a2ea1a93d7675ef680311f8aa0306aeefcf1 - yahttp upgrade c290975778942ed1082ca66918695a5bd2d6bac4 c65a57e888ee48eaa948e590c90c51420bffa847 (Aki Tuomi) - Replace . in hostnames by - for Carbon so as not to confuse Metronome 46541751ed1c3bc051d78217543d5fc76733e212 - Manpages got a lot of love and are now built from Markdown (Pieter Lexis) - Move to PolarSSL base64 488360551009784ab35c43ee4580e773a2a8a227 (Kees Monshouwer) - The quiet=no query logging is now more informative 461df9d20c560d240285f772c09b3beb89d46daa - We can finally bind to 0.0.0.0 and :: and guarantee answers from the correct source b71b60ee73ef3c86f80a2179981eda2e61c4363f - We use per-packet timestamps to drop ancient traffic in case of overload b71b60ee73ef3c86f80a2179981eda2e61c4363f, non-Linux portability in d63f0d83631c41eff203d30b0b7c475a88f1db59 - Builtin webserver can be queried with the API key in the URL again c89f8cd022c4a9409b95d22ffa3b03e4e98dc400 - Ringbuffers are now available via API c89f8cd022c4a9409b95d22ffa3b03e4e98dc400 - Lua 5.3 compatibility 59c6fc3e3931ca87d484337daee512e716bc4cf4 (Kees Monshouwer) - No longer leave a stale UNIX domain socket around from rec_control if the recursor was down 524e4f4d81f4ed9eb218715cbc8a59f0b9868234, ticket #2061 - Running with 'quiet=no' would strangely actually prevent debug messages from being logged f48d7b657ec32517f8bfcada3bfe6353ca313314 - Webserver now implements CORS for the API ea89a97e864c43c1cb03f2959ad04c4ebe7580ad, fixing ticket #1984 - Houskeeping thread would sometimes run multiple times simultaneously, which worked, but was odd cc59bce675e62e2b9657b42614ce8be3312cae82 New features: - New `root-nx-trust` flag makes PowerDNS generalize NXDOMAIN responses from the root-servers 01402d56846a3a61811ebd4e6bc97e53f908e568 - `getregisteredname()` for Lua, which turns 'www.bbc.co.uk' into 'bbc.co.uk' 8cd4851beb78bc6ab320926fb5cb6a09282016b1 - Lua preoutquery filter 3457a2a0ec41d3b3aff7640f30008788e1228a6e - Lua IP-based filter (ipfilter) before parsing packets 4ea949413c495254acb0bd19335142761c1efc0c - `iputils` class for Lua, to quickly process IP addresses and netmasks in their native format - `getregisteredname` function for Lua, to find the registered domain for a given name - Various new ringbuffers: top-servfail-remotes, top-largeanswer-remotes, top-servfail-queries Speedups: - Remove unneeded malloc traffic 93d4a89096e64d53740790f58fadec56f6a0af14 8682c32bc45b6ffa7c0f6da778e1b223ae7f03ce a903b39cfe7364c56324038264d3db50b8cece87 - Our nameserver-loop detection carried around a lot of baggage for complex domain names, plus did not differentiate IPv4 and IPv6 well enough 891fbf888ccac074e3edc38864641ca774f2f03c - Prioritize new queries over nameserver responses, improving latency under query bursts bf3b0cec366c090af000b066267b6f6bbb3a512a - Remove escaping in case there was nothing to escape 83b746fd1d94c8742d8bd87a44beb44c154230c7 - Our logging infrastructure had a lot of locking d1449e4d073595e1e1581804f121fc90e37158bf - Reduce logging level of certain common messages, which locked up synchronously logging systems 854d44e31c76aa650520e6d462dd3a02b5936f7a - Add limit on total wall-clock time spent on a query 9de3e0340fa066d4c59449e1643a1de8c343f8f2 - Packet cache is now case-insensitive, which increases hitrate 90974597aadaf1096e3fd0dc450be7422ea591a5 Security relevant: - Check for PIE, RELRO and stack protector during configure 8d0354b189c12e1e14f5309d3b49935c17f9eeb0 (Aki Tuomi) - Testing for support of PIE etc was improved in b2053c28ccb9609e2ce7bcb6beda83f98a062aa3 and beyond, fixes [#2125] (Ruben Kerkhof) - Max query-per-query limit (max-qperq) is now configurable 173d790ead08f67733010ca4c6fc404a040fe699 Bugs fixed: - IPv6 outgoing queries had a disproportionate effect on our query load. Fixed in 76f190f2a0877cd79ede2994124c1a58dc69ae49 and beyond. - rec_control gave incorrect output on a timeout 12997e9d800734da51b808767e1e2477244c30eb - When using the webserver AND having an error in the Lua script, recursor could crash during startup 62f0ae62984adadab687c23fe1b287c1f219b2cb - Hugely long version strings would trip up security polling 18b7333828a1275ae5f5574a9c8330290d8557ff (Kees Monshouwer) - The 'remotes' ringbuffer was sized incorrectly f8f243b01215d6adcb59389f09ef494f1309041f - Cache sizes had an off-by-one scaling problem, with the wrong number of entries allocated per thread f8f243b01215d6adcb59389f09ef494f1309041f - Our automatic file descriptor limit raising was attempted * after* setuid, which made it a lot less effective. Found and fixed by Aki Tuomi a6414fdce9b0ec32c340d1f2eea2254f3fedc1c1 - Timestamps used for dropping packets were occasionaly wrong 183eb8774e4bc2569f06d5894fec65740f4b70b6 and 4c4765c104bacc146533217bcc843efb244a8086 (RC2) with thanks to Winfried for debugging. - In RC1, our new DoS protection measures would crash the Recursor if too many root servers were unreachable. 6a6fb05ad81c519b4002ed1db00f3ed9b7bce6b4. Debugging and testing by Fusl. - remove pdns-rec-lua52.patch: no longer needed- Fixed broken _localstatedir- update to upstream release 3.6.2 (boo# 906583) CVE-2014-8601 This is a bugfix update to 3.6.1. A list of changes since 3.6.1 follows. * gab14b4f: expedite servfail generation for ezdns-like failures (fully abort query resolving if we hit more than 50 outqueries) * g42025be: PowerDNS now polls the security status of a release at startup and periodically. More detail on this feature, and how to turn it off, can be found in Section 2, "Security polling". * g5027429: We did not transmit the right 'local' socket address to Lua for TCP/IP queries in the recursor. In addition, we would attempt to lookup a filedescriptor that wasn't there in an unlocked map which could conceivably lead to crashes. Closes t1828, thanks Winfried for reporting * g752756c: Sync embedded yahttp copy. API: Replace HTTP Basic auth with static key in custom header * g6fdd40d: add missing #include to rec-channel.hh (this fixes building on OS X).- sync permissions/ownership of home and config dir with the pdns package/bin/sh/bin/sh/bin/sh/bin/shobs-power8-04 1602680114 4.1.12-lp151.3.9.14.1.12-lp151.3.9.14.1.12-lp151.3.9.1recursor.confrecursor.conf-distpdns-recursor.servicepdns-recursor@.servicepdns_recursorrcpdns-recursorrec_controlpdns-recursorCOPYINGREADMEpdns_recursor.1.gzrec_control.1.gz/etc/pdns//usr/lib/systemd/system//usr/sbin//usr/share/doc/packages//usr/share/doc/packages/pdns-recursor//usr/share/man/man1/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.opensuse.org/openSUSE:Maintenance:13513/openSUSE_Leap_15.1_Update_ports/3cc9ec284fb274608b1c42b49616e403-pdns-recursor.openSUSE_Leap_15.1_Updatedrpmxz5ppc64le-suse-linuxASCII textELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (GNU/Linux), dynamically linked, interpreter /lib64/l, BuildID[sha1]=7042ce93da38be354271feafef3eee10c8b5b0c3, for GNU/Linux 3.10.0, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, interpreter /lib64/l, BuildID[sha1]=446d910d95fa1dc057fae65f00cd2740a873ac0b, for GNU/Linux 3.10.0, strippeddirectoryUTF-8 Unicode texttroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)$$R-RRRRRR%R!R'RR*R R$RR&R"R+RR(R#R)RR R RRR R,RRRRRRRR RRR R(R$R"R+RR)R#RRRR |_e< 5hputf-829ff3e0d008bed55c4560426de515d0f10a8855d42dfc3d254439b7a3a57935b?7zXZ !t/R]"k%Y60G`spk =+ߠML7ѣk |0=)6`{C!|6 1ࣄ SB`c6ZYO3iP%2o 0J $)W+OѲh+F>=:a[CU.9*APYic|dHeQ@V!؀AV70;$]Є}c}ZY_m}8G#4kuv<'Z{O:f:V3rVo᫰P*kXm].kbiѥ}Kx'U˖1zC5ODShl oH7uɚ QX:ඦ[]rE_.])>F挤셱 ;E[VXG,a$d$^j݌)!߱ܐvpbXנGpkT@yU i@;&P#_* &R4Q;.8 民|$P WRʵ4URU#afhQt9q<$hsg`WZ'd#E͍#8^uq0ȘOl#Ry¶ځ.BOT~cY?ETM+' #[ \+t21@1`hqM6~=0TH ~F|{P4?ߠ-,1`&K}Ҏӫ_akD g*,Y#d+ڲ-iW Ca Ljы;k3F:d{ K@uYy;YIuނ!v抈t9DZqX` b7*@qqbpJ_rOB[pr MhG,i>F$d2% @bez"-0-^w@- ЙZ v|ljб >%6G$T6Jˀ0@noݦy`"fVv4/nHJ,̛dQ!!g19e(JHxU12)$Rm8ؑE5;-i1y^ Dܚ}86?D&!w3rYy~’ǒT9<#G4U:咩 O ת ?>$Q%ܧDѢBkymHtE(lK.YJi 6ʨ',hVN^(̋9yn@`9=CkK?1AkXF & YZ]lƀhJϠ"^{AOՇF o>IQI}ܭK+ B5,qXM+TA@Xoެbv/XX&F%vAb؜q.H@N/qq-6/J*W bN'` */Q鼗 -)Ҧ^ uK@lO?qϻuCMvH̋SlњXrJ Kl+?:Qgku"A2LrٌzBz2'j760G*%e _ /c"/Rzj}<8[.?:!g~yx&i*`cFxC;֖ȥ7@j-'E}|$_E{X-fOOZсSR;3KŅ* S7Jr1?vpMᨔ'/`)DF,HLQ 裍l+eP#mD.cݽxwaGyErhrk~o!DD3ET)76Վ!Mqc YWWq+ag&!bXĬԐmo*$b9d6qcfͨruI+ϺM2hV˵3B'Ú s9oi!:&+l/8!`{G()A'#=ӟ@:?Ȑ&j򽁚hy(=et4*Sևw̑RV%̖=Z,ώ?tEgM3Lډu׹;{A`HFf&їԈJw+8GI5߹~ļ&..02k 8Gr'ڔ4;XYn _p+MZfY .]ճt+Kp-yT`BWCtpX>XF+\0x 8F$A4;\_f,gkU,Ce`Ҍ>vDRE?:Ū]*E V(?yR)Xa B.<ނQ1*Y}8)D<[%;?H@Z,ILe LyKʽt<S8jhު__Lb%Z4d;vL>o5KKm:ߟNk[8RkiJ:ꖏ`Sr7n˘6#}!V}ʅbww4pS=OKs~/mtmo?Zq@V9xQ\:R F!U)+ٛ^4[J)<1_Άp(Zp yҟɩ]FҾ[k[e{UaF췴$'&2cy5n~{\e*T%L#?|7L`u-;cEx|.Pss-^NW>v;ZOƚ9K )gk!#^M_vEe# d?OW;ԣ'.b+][J_Ev`_]Ov|֘u&`u7&f0LDngu}@k".t3c`P2j#P7/bWJXt䙽R_?H3\PcTtp'-جXm5I ts%a"0qBDq3{nVN&]rQ6A]<&x 1>I 8(*/l/=/%?6kp&bJo ! w%1j۷'u΁ js4>Ya̸NT7w33,Rk"5~ 3`ABξ9[in|ZJ XOy2g32B޼$jİzq ]OKD* { DT]d$WhS:fxP:u{b''\FT:1A q ޵mEF~ƲY('@9c^ICf[,/3&M{{P^`JZNMGͨv p"bSyID*1>)*BU~ZcJڤ©g)&%bl_8CºO!Vv~ϟ/]j2%AՖ k˜ L 1w5 _(g<<6 Z_=ՑCAЮfuLYt 06'or&gỉc5?D^кhprZ}0`dvZSYXWM1 3BF/LΟ <dWU;h?>`NK1,gL\8% UhN:} 6J+K[ H_ Vj"=qnX%r]lrqEY/[)A#YHLN+~Hb alc%0(fw`=CijG Ɗ6C.mm @5yOWmD;GՑ]V 5Mb(az 9VGthrFŰ!FЮQ0ӄ/ jVk J1Nz8bwFTT"yNΡ1*EZ8 >͚e |E͎v_~_+۱ aPpM^dL|]3OM0/t >uy<%)# X6jquvG 3c~x5T!,^襕wo ~&Vlac|Ly@zI=n`\>=p੐aFD pe;aJ !k8zh[幸)OiHM$Cd #{|H߶֬d2ocud'D\Nt+ o&'x GxQnX9 K&ΜQU͇2}!@4ĚŶ!ֈLPZ eL"FpiǪױP 2RݞG788F= { [;1?+\pxE3?9WTk)aiI""0S ?f8B翮9I]Xw)ɽ:w~GICY=֐8pa#ٗ-;4[4lHEM _[ȗ\k:̛.uakFN%~DӚJ + #Uҁla!8g[謣pLB֥")7CكYnA,xr47q4@B7Z#0æ &N&rd@&ڡ"{?⧑CH%hBe>Yss96Yq@?l+ k|νF0@if)_8gLOۣ/ +Ś6 gJ  Yu_{w6 MFYbXR!%FW|ػRrf6g?3GJtuÉjg'tHq _W: 2V BOe@@b܁C!.W/cDB{I 6m2Q%쫐Iw`Eo=k@_`8O:FFO'-`(Q& L-~l/h["*?:ImSqgkޣ7 GYbk<):iq.TudmE ?G_;Ehw݄o$QTql2{BNUO,91#.񒃭_+v2^3ߨke03ֿOž){6fRSa%,URf!ni&y4g/.,`0;g@'d)VmMoȚ{=>?)M߹&ƣ`k8E#8thHA9>lvNHIdjxŃbL!nǕ`(iw(y<0yRq hUS瑞fh _#o"hPLdBNpi( NA QMgʫA-28ANˋH:ce^\^P-o qBc\'{7\OX*bۨ-fGpTdv*^WvrlCg?)aYN*ԞA U?4XK~l4QCͲxK[Jc*js!+DOL @J9{Ҍ,k;l {cpR崫^d򱼤OAllC$YgȲ(kK ֗YW5B"hBZ&yP/ tFE"K:AשVec~枏HϹ¬ Pw5I+Cx|sˢ"#eeLɸ68ɕe}Z؝\'`7l$F_B%c&NG PE*#w]Z(gBwk2=7e,vG;k%/J|I]m|4FÕwI);G[֋G1pT]Z44歟P2"0.H#x=bߞқ9>^n93ݠ/M XaAJI.4WsZ=$=ņ8x_PW Cz5 d.XZ;%[J0: 1bǞ=}E`V'kuU[*߷GϑngP9LFllkZZOa,S HvĔPHyigJ;Ynw=m.e1fZ9">R9 اL.'oE3 E iOMIQ7;Ү8 u1Ʃ2@8|җJ3B&_]Ru8H3z%MΫjOV.ejFb]6ޑ+e#q`]ʸŨn׿LBΊ_6Â{`Q(˒ *PЇYO $=k֛:\ͬf8iqP*XnCk?"v-6)<3;P,q?ԢT<@d)*>+W$,Pz:).IN .N-3v!#OL3pa_*%l f1C®(Cݕqi3>F,}zUe1E]8" aұOL.6Y9@ G+8hH?;Ni]~1t.WybB⢤=JP;, cA#[Y-\,*/"M'7I1NSNPvyO)&i'3ĭ9qj3jQW^F\D[]A\^h4P@?lkA26Wf){^Cإ=a#ӛ4K\R-\Y@>-U-F4<$TsQUGq+&bx>EMY/EzӯqH Fo4rN/g|^= ԁ@x`gp]~elJ1q5uDe5W u =y!,bdllD?ÛL6 ^T^:QIQ!V;Yv3Aߓ. Ӷ 7xN;~ll/7DAIm'u\q~{0QTru;yف]ÞR15|%ӷVCD9f'P%{Uh1VFw._eZJowK{%O/Vtr䰄;]&WR$xAhwsevpjiϖvN5xbv.}ym9z _D"%bEu=x\)tp.H ϥz+/xۚ֨| <*-8&U?Oc eumh+Ԋ⛐jg.w[6pg̉σxD<:Q:g {M_NXu$G=X&`:>mo_ZuEqZǫTѴx_hMv$tfuŁxIYqKdd U3J66dOel>t ~gVrr\0J$~:Ӧ^|Of2,txR6ށqZB : Z2<3I;I͑C<X朳Vs阬Zoe%+cXi5a0g%蒴3+[XCq/In~# Yy,0N{(aw Dأwgrv_t)PfgWW'EefIO{Ώ WןfLFy+f {9n F^cn @-j}탁r 2)7Y-Tk:> %3l*Zcؐ^?|v˝/R/r4AudnS'j5-RͮHsWN(c=EۻRsHȳVׯ82Q x>(vGQWd٭ Ͻbo;JgaV-yq-&޺>Gu0zScpC"k>cG>E؛vHlJl? űlK Yu Ȑ0pЗdw aيWa'Z0DI"[aƚ} flDPV+l ZgN̬3mWoM`P ]JXQ43ִZ픣%1zH|͢=ۡ1L˜HiET)K%x*`.wDhSjHwujBjb$̹淽GrĮ-n\ tnS& Hirl6;uJ)݂""Ꞃ~띙k& 3^G ȶR {kΑzꛑ-}9˰ E'.{>0` x{4i?(ͿuCy)a!h]mo>jBՏNƹ3@ǖ}9Lq; N}>&)[VIbմ"Km6ʔ.6:8)M0v{![D &hSH{\ZIf{l_\SO<7L/ajz;aV.GqNleO]TȚ[ V $^",Hh2rWHW:ښRd?dGà˶XBC1G 9wBRzhHTt!ZEuXl/q1%LeRTN#VR}('!qMt1h%4M==i c$Xђ#&nmFN(T锷 (;@_׾e9@StGkTC֘Di1 R1+ \5ys.-4j}ٲBqxM =}A!ǠPGaA׾H*pi# ~NW2+$~AghQ0X7 &a39`'{Zj/I!/lfJzWQ]vhʮeA3)0WWdžtaHA@ʓt3&Tf3 O4I\^3%8K,+? ùҜ3i_KR(T 0+ѧkuLY2f#(zǓ@O@([Q3bFQ*Qcr%dn&|={'1 O#kh7#Lגz YwSisT:;4hsԗA (񇅵IN$k;`zTC2 hf$og9AHG(QD9~g#D˧Д7d T:Ȯ!LW\Ԉgw#[QIZF#ˊaR4:[EыfTl+M <Ю45svxLj !nN_H,J=%<>ܑV) U:sj穑-p(EŽ.PF Fre=d3]A[ݣϡׯRQijUsf{6RxA =0Nnѳmף% ӬƅH;u6wpOC.LJ89Lv=m@ MmmQqעmV욱o+.;N`s]ݍf 8#K%駖V/lx G=n(3g%Ӹ+(H%)DdaXSg]|QlOk펖Z~:CDIsJFxt"1`73PplQ9SQ9%oV9 sR,*L&,_Y nY Ia PJr0K'8Vo`,P3Og{~3һFbFYv4U־SJ>&bl!lwwө?R.Rwj6Iy!7%l9.w ,Y[ZYi<Z7y?HѢ'(Y3VZYeziSvDAm]5 ϿkHYź0K1 {ک ΀M7Fgk3@1 ߯@y\.0p-3PBJ')xWXC Agă5̴ rM{# w%ܯI]^`ƇuBN*,l[+/ P/#wR4++D6蔀 _l> qG*{@*S.3ɯvL}G, 6+eoњhm`1"K6~bP E;u#Mhtxtu׳K6ֿ 0 [BQr|!u{ i)j;W>X,w8$ˇioИXl*DI-tꒄ2{[ZKwh'06aY-ɂBK5)PR,ߖ>2qV-=_N A|w2.8zM{^~jezc93 [HHSk su<.I=ZixrAXMBS-h9_Nֹk\.D} >U锺d![=rHRl_r S;S_tb9oaj$>.X1__Gΰ8I [eApr(BDMetjɺ~GklAiuK >p˜W+oAܡOVQ#Y*pOυϊBNhofǺX} w$fdbܪZd|a,ѐNI繲%+X)g?3~C~6`x<*kЩ]V@7PR>s'(If)[qYUK-HM/߆"W*4Wqlf_r+U!`]au6g-U2ZeÊ ~;]Յ*LdZoFc-].r ]'2opYC72_52Dq*L#8|%^Ϙf)i1)sJmwl0#g+c뿑 ?B7qH4Z}+/jF.J$ty&0;&~ysDhm_HԳ܀gH Ḏ[5 ^4,>W1{la s`2Ȧkd.kBm>Y X_twi9bɎ@y!,J,È !]2K;D1|w?ζe \ē%r#: L1禒2Y6ձր'T5a*5)1w~hYŸaQ8QaW獾~4Xd1 y֎lsz&Svb'ClO%qLmwJf%)yD4 .ĻFy%&Tw) pZ*Jb8vD%vMj!@0V0e6˽/{QQLI1ݱ~# U86k%&x!)(V}GX'.ilʹqƉ?_1s; a0vdHzUy`@^I1vs/Lk|7KI=<둳ִqthy?"ΟgI`'{v7m>Ie,[0 PE;T0pG"L'D\<$W,OyŅGLzN~xU,9mh.+-BEl~)sdQ(i6;@:ܲ dW=ZHOۆWbKJvVKD!]QlOWPʿduB$+ÇTѓ.3c},MsC83E]0x2y)nMW%{jKA !Jʄ_nnxh'}3\֥61rBWyxaM`[)i7`MdTöP)[TB_;~ .B6AG<{w]K5[`jn~7RBs?_5 22@ZC+ovpB0냖Rbʡ\Š|pQ< UL[<ީVAS2lmʉhY۹1_֩"M1Q@D!)<|R~r:s̠ԹTCJvT oAWW?A& ݀(z36) g(4h/Us5?x8T Wx0kWns* hRpu+6Q0?%|kbd&nsK+$!@|aSYnlб1Vcl?aa/$Q9 b8V53j|g(#݀:Hy tܕV(o()L4  L`_ 4uNf&jdͨQmFq[z>$dRwKK"a ޏ8,#5|pA]a'83\ qX1M˟!ӹ/? SZ- /m&S"k0N#6nG2oAa>`yuO8Ed,aOKべoPHF{dhݲ jAx;؝JH᮫Zn( I]s4z5(#`Ƃ6 ^NƬ!ݙ僴Vů,⾆)P U|:q+D1M/.1Gv]lj87ry̹S[:?|ۋё- $S,Fw]peOPMܴqeS,vݻw^JCB-i&ҢE~XtSB! ~ }ʴy@8Đc. ~\ ;H yjvrF5#\]w>}oBzDɗzl2Ws@z0䆍-AQ~^aS?#T`Ȓ؆"?ҍV#(S!8.5\ O5&Gv엑2JGhJCGw"^h~p)ӱ@K?NN> ¯ 3tz]ؾ4AH)mT,)gl&02dLbЮsJ+Ւ&eq6sm9\u Zva#x̳A48EQ?X \*GA ^ke 2zzYX?¨l=ٛ7 MP]-̥G𩗷{`6nj6%qsbY=wd˱ &`%p.*M2)4TES9)_rgV"Il]|`eP5 1Ϯ!XSucULOn7P”FEhkXﶡu*O:g?0vbggC`YJ82G{[z-ӷ#ZkX{eSV5!  "+7ÛOLFiuX)AY^(x;Hk7X#[\¯0ώUqg\HhMدL"4e$GzK^oNēS4-ײys }'/", x5 H UknXXwtq3YCx>[%J*4vvB́MQņv. Ҁ*gk/9b FqnP-mB&',ļR㹛OU4&x5{79WnODA5 P+;k-rZV7V}%Mq-;vүZVy4X5۷ u_bm9g3hf \"@ƙ;Z% oZ<@_/oTk=5=~X >chy:qp"NwXF!O2'͚2֢l%H XXjVPzv}34HxW.p~m3lO>ylCdxzr(n jff@ձ8|ͥݫ*8D@J5ttdU:Ag `>l 3 [#eӇK{iKBTn~MT[0V:s c"`$QmʠhA򄖜|'8 ]/@gwF/ѥ@[ٺ-ZPYssDƩ$DrOyD`<Ń=?[-WA7ezsJ5$ Dh_#O\cq/~Om iOs2”c×+2A@K?M"Q7=|ҳpb͑klͥbPzJ`yأkHE*{c_ʦSv%ggO*8,TJ&.75̱ac;7K N;mmx,_986hI El=hyA7Gߵ``Po59IMNukY*w& 't4jPb6RCř ?w^`C \<h QA16e&Z&݊o{LcfYoۋ~ H≢s6M \_Wߊ7][2Q2#ޭarKT5b .m7Ǧhq3</1G'mΘ.A|Y8XG@{ssD*u)#xeh´h(}`%wD-כ*,>Eic-*ՉuXm㠇DS+B7s\v%^[ebuUf +̖.F}H~uj=M&oNMF! 9~|b dVr.NAؾ}tL[U/ʿ䙋+rr9Ÿ9"+5"V6[đ`<K_ R ϋIFS'dɢhcEv3l{v&|ªNiC~^[+Km2s1%W'[ϟmѥfpd dV roC(&:T %I#ueJP W6u6ee*cgb,[ZBQ֧x%RgEa9`g/{x !9L{a7M+$I.ӾoNMX,o=حK&H5*|~Ou<:Y [w0iZhBwKz$хu $%a~;|CqrJ<qe\ XJDF㉗F;5&v(4w^\0<2 ~n_~*63AzXv>o2zӈ0klYE8؊m#*+@JS~ &8̈310NTF88m|Pzn@B7XL%"f ~BdzU+$khFH[#5nC4s; + _"'BCǮBP:BLhɖbEmdKX{E rmNNUUi둷<]wcű}yo.D6!&5>}*MbsEuK[`:+8 `K Г~uS8)2K1uU%k|5Į0|&beַ$2{^=Dnxsq99-V+q@aTgQ6;M~8ghл#x~HX=ɟk~i=$ YGP-_8tơr ѝixi4,[ @ )[8;@ 9O9u&d|*$<`".]^;5wy*)Qec@$W*lS>sL)r,ۂmOYMh>+BnEA5iYG(Ȏ39\{7xUenvp@eIz@*Khq . Cpy9[:fcVT)@ g=74g˪(k/E 3K#(t{ Nk&Sܘ"'K8MQޅ0ڼ"XbEO^H7́ _XML .{wP"(x])8.2K[8hgع`aAԹ=9botAQ9N | a>u(h@}" $eebl&|[u skˆ):xB\VFc:EBTGM򀏀=qY`>5cOz鵌 w?*LA MQzO{R7[ax?z qECtRvZs@crp(럵ڙٟc7TxDzDZ)RYI_p0V]@5>Z{h3/.G#Z݀%2D|XQ1XpAՆەo#W5cā9JWaJnZ"59$ԃu0vB-Fq}wJ>Msv"5}c"oC;Vo g-R~ԡ@GFLPXnkZn[XUP 0Dj0*;gYnIXpiߍ|Ù@.Z_ ~ǠOW䂷; dJ,R"BVxC)Y]{n:Hȅ: <ܷ_;爽t$ 809j*BdY'M;NJ."-!9wRD l<)s%Pgi z9YP*!(RCS:Q.OgbMb_lB nExd (}BwX'۶ ;J[="IdzSޭ9""1bO ğ}}7ڟsFTΎwԧ0r\ׂW{8"nD~ׯa#e7o\uU 2|  JҦ^aMfxLP@=7}+klXϩ> ҔFybd Ic\Ih< `N"%ۅ,^#CL J_`aHlm붼R>x fN^?CQS#suٸlEZ.fՓ>lZN6g֩DjnE1 ^[ۨ8*WvO|pԵ.ZU3'1 jq-uB^QTw4& =u.0 %mvW|ذ1fEu4YF'@f0KNGMERdgTB`I/h⊗"dwBEEvW9TXAp5!Et.(B7Fڍyy=[<'+y@!7,[YG00 QNE6+7kC?UU;?V[6FE{4n8gXx? B_b:*I{<||J.~*TdqC#z$O?6bj]v)X*nW4d?BѭiSm(qmwj3{dA# N 4FD%Az-pɡȶܐ  ^adNGxUFˎPٿ̤ 4I^ S')ԮĘhkQ\ׄ$+89T W Ym"{ uR$H.5A&Eع(NA=W[?vw$%3d)Z޹4CP hD >$g#}GY.DڼeȦ8EC ԹH[v|⳪9OwI Re4XްNAz 0(3,9Zŵ6F^?Hf&[K]<|S`*sZ7ݼYYgWW/pCS$QTNȰ~9%ru; Yؠ/;6t%]n;S$%HxI-H9J(=oQgbvmq@YiԮ= + ASO^])P0@EF{bmmp ^'Ǔ #SIʑew + {c5 Ce!l0tA[_:@}m@}nM.Lߤ+kfV=NP{(!#uwiJ4g@X{!9`-qRN4:»]|TyXH~d }1j5v$3NfU6.>YS4vtQ:^N /cV.yPR&MD p>13f3"scBH)wGCMMlArնN^eh|;K)!rGr;ਰJ+(yg>Bg(-7*8?[*ߑj[XJF.\~^ձ1TDy Gy|m1$=CL +6$Vى <2bZZ]x)Vt\)p@i@G#gXCڝWƐzJ@@y𒢃[2>i\ v՞`Pp[3L !< wiaQtHq,ƹM"Y>u9iCl{L?NIZĨ!?E̬df"kGv[H_+%%bfr$A[^Т7B8{T-Tڲ>NxEj ERʄgs|i( v4SFb; LpXQ_{M$XDH,}mڍrMF1T9dY<nqfC yBlQPs7mӋː@A -rzRHr|K``gX*hu Mx6bx Om.(B> /eLcߕ~t[pI dž c?G݄J-^a 0f4sbw4șOnS8ey}擿)yɅgGV$7,fc侏[4xEtׂf8ykSj5c -bMNcft!k뾽 C_^\t_'; \"ӠY6 ׁƼ`<‡RSu$j 2+>&!ͥ% u nrA9X_igex,o1ota= dOʯN:n;xCvG\^Eǂ+ |W _C ~"<թ &M*% rn=Yw ,fH!_\$q$l?@ qO[S"}(;,]2N-X^(}i琑䙶60jxgE r1 }jjj~AOW?í p&"\{sv\ F^C*ܗRz/Ʀ+s;N G чײpyN1[C*s;tRg-?b.00%,F/e* !֤7tuU'wv7-* ;:ߧ-ٶyA3W{殭fkB\gL*8#ؤ!^Kɘ6BUJO}a%~zsXGJHPd^Q_Cb¿$VÓY HЏdw0+ };p*EwuU;8#IW"N EwߜOMU+c7E@ii"C)~t*p=̚Ď7tEfٚA>ipTY([ѱHjKm ?@?H[B&M?;v=C %սa|9u Vs%]T‘Pё s7J{?ϵKS OmEGv߽cA[Ќu~'6~R(8gD畤-R6>#ߺːysd >'4zFK %!&WZAq8c (uZŽy)3IDHhSy'w;bWЬ D/NZ,2?R**Ußjx#lXh2h ǣ}q2 ( +M_h^,Un>P!ghJa mPuXTkuG!=ա s;uGWsglhM%sG^ܬ'2qOhI<{tV/#]EEۚ}&Od9[;:Ty77H LT{rs62a~qO|ipo6u1GiEild+YcG%N5Á{:h5zJ;%'^%ci:DYgcH3"Co)֓˻`PP\3=FR5~'n0ش ZHWXe1Ĭu7822+a+ZvT_!(vb+ں\Ph R 1]fmۺglمHM6H:2Y-bNz@b5 k.t43:SmK^n>>xAd|NSkFC۴$Б+x;_('sN}WKoҧ8&,ŋn+:PfL\W1a],L~p~:j ^߂=?SƵQRAy:ۈ)Ei~ .mnXqIHAvWDoN3YG&tײַYӬ8r{ u7Ϩ/W{!$:fIPfXym0zo:U s^eUo`OXmoM1l(ٕ|]e|-Z%JOqMYN<4VktjT*" VUb.Qv#J_bxzs *b]~Oa̟҆һH BvY G:]]Y.JCIhE̻%W,\26pOߣ*"E K|LD1eT?)_E}#q!9 }l R[O~M#  vǸ7غBVxx;v)PrX/JYXfʗ Fn "oE=Jmg.o*B͹&36GHZ ;t5bJ vl-ÎWG+ 3X% u apjt胓ZU=VQu9x Ȧ,k70^ڪe=cr2:ev O 9*ЄfqpDW*/KJ5ݴ%IeL9\9t9ֱ;m yG6EKqM{hyMth0' 8zIa"j}(Zbv+m1pܼK=,ZsQH=PFw=w1NxTbݼ6ytu>.,5GL]_=&<~CxZZ8Uf23@ k2&zp_"bwqQaY:wf$,N:ҤSmU&V6V󳬥I0356iV˽ BRrV?S-}MIY4:t8@޺pe芕j-9)6kbTOQeӗkAe[B`,7!)+Io08}c ,׾ ϝReҸP&|l d}cHKOEyX͝7!p×Mߑj,bTX|ﵥpjYMI =yֆ̃|P3vORcPdԁm;E1L5X3?~΂'Ke, s`32׺r<֊HmVK=ڰ`uPnW,I6J׏Hq`Yc䃔'ʲKH%t 0[(z5i>ȅә=.6D6t${㱫Z4S%hD,,X%?\Nk nrߨΩXG◒6n&~֍igoˍ`OkV)f\a]FQvp( 47T4TnMAHz;lg!ǰ2e''$aw1`Nhgm?'i8J<ÕIBld}Pc"ag +ݝ\0XL,HfW%ڙ#w&Tx&@&%=@lk5G޽MH.ht(Phtϛ*+VO.JTakC]gJa{~zZ'6@{&gZ~Ď#fT:F# <#l$2c(2"?P +u z[a;8X4N ش+uURvzjƋO(7Di =vΠ[@T_ʲJfJ?4>C+`1_1C5']'N`פQҹnT\^&zS@00= ܡ)&mB.614^bг]}(e\,آ,i{^l{uǬp1 Cwsф.X5m,\ۦV6n>;$r}km[0^pqE} /}X\O?h8t 3bӮGJC8NY&"m߀J9[Z n @5]#"΢!߃!>!hFz`@@ 0o.bn(zf}v ǦC=<2*ɢ+06zBLHy.6 /;FL6`ZruG6@|[HV:I-;nA_wݐ))&}Tb9` 헳zKKq"<T%j1k~ ah?g$z_G}J%6}&]V˨!=SH7'> A~#9,((|[; %V -O1a +Ć-z,}0dؕn ;,x";'ƀ}2 g zH{!ca,"6tagז!G魃z-QFǸtAwl~-؏yǓCƵ8󧮅QUJk?lbL2DSnʦ-#Ng$mB:ZEbdIvnQ2ˠe4!#89/rW|)O?󧤆sxt INѺaOQZڄwA-AO<3L[MTV4!zwJh@z9@ҩjCՔ-QZLIw<|99Cu.]Q/ĔuK;k:wFN /!q>44nȁuUx:\v$Pգxw-wݶٲ-[2UN2&ec^۝}ʛPi_]X9Ƃ0q=}Ve6 y}5t dV1n䚒Aƪ2}2,3:XN>NE[D<^c ̬vJ'AӗWġwc :̅#ɈjßdCfDG՝6&?"<kBᲸav_wJV2NcV2nM5+_МDx orש# ᲓV-BN&EV 88F \A/ְ+o TPa7MΌ{"G5(h?SAOi_߽Y4ϊ3c5zWKQeYvO23}ӳ~7>6#\%N&@XUdKG0AQx@L*~8 FA+P>-bB# }`^`$u'A DR}_}/t@_j+vKKAbw[.0~19HGCH۟,M/k9C"mo[Z"ZJ (˗.)#R y@#_%0:>[)н $e|tLJO R8(b#``BC,yO .wr GŷX#GȐFsܪ_ܸj .O4剦k?Dӧz63G0Bh-bRxcvpT(Uנ9ߓ vw~0.{vbڨ:.f7}4h#(&_6Xs}(iYMB[H<̃=W쥮pݎ*U:41e94<kvAP:s)'+Gz܋6Z$ ڑEDh %iЛN.*2%$*;t}߃p4a IYcʭMt;ڥqEecg &>e#kߊc\WddabR`r6]j}6CERjdT`$Sb`õnxy ֍o y揪)Ԡp/#73<ש6 ơK'S{t'S-ӜC݌#6d ]'n?ӳFB 9Xʯ5LC݇ FHlE}k+}[AFP57]]grnN 9c3-y2{6NQ%.hH4OW䇈"օTBIReaA5J+4?۹:H'z3<%RkʁV3Yd~<U-eAPL~hxW2Z%ͫ龤%Þl*w3&0OVkF|sWp-X7ۛύ1%lR_H?>)iQS1:SL&GA9~`8ENY7SS%qvJZexH%^sok2\B[ a'řU=wۮA"[N-Wg $j!;8؎xȝ_&PG{P/|[ÀA D a *#v{,cHb^*cy5$ɮJkτvJXa_V^o3`oz[%Bj9EݍOȂaa7Y҉_'߇B=^ I%ٟQPojEZ_(U6g~zu`t%VB n[-oD'bk:LTpZ̒VeJRBd;Ű]HP!hO 'ru&. A[p&TZxv395#sB=gI_u)iq+۴j䃇mEbv{eW1F>og'dgڝ[St[)p1d2;{9=ۙ^\Zr/Fh7QrBfp6Ni=2 ݸFL6:"@oO㱝UM[&EQn `#Eˍsd{U+%@!}?toxͬQ Z.,wO8o?$nSւNlXÈFt>Bˆ a&>'TFg{TiT@aF`̕ޔ\˙r QǍwerhm}&aq&^=˘EyXoKv0`t}~)NK!boHxR^4au4UpRG0|tpI2x "#nVqۦx'7)(4:71q_dgd;-D\K]@a;hf^Y7M]W& ޓ}2RMqwL.\_qޞpY>/_y@G5U_] Va!3-dU(I2Tb1ʨScT9ڣ\9*ߍ;EŇ/n5PURo+T&ubsi D #]B S\ 1(Ck$@nv[O˄5IV+ 6|m#.YyD48#]F{ҋXN~MQC.?4915,X)6aObZ]wD6V {:үN _L$irbN1AicF~'ݶ<F%}g#Q`VOz7:HXdXTujGL7xءiQ @\Gi9<3zg;kk̭֤LQA>6Goz62um( sKd_Gr(<b[x˲)}A.D;AJn ՄjQcc.&LYFZqhۗX.$k8ICzzO.I d$ ^`|Bo1‡ֈF@Éxe^@^/N8XWLZ4I6HZv r3|>1bke@u i)Uie0_Qz{ҩw>~LĶC -U7"į@ƛnӍL*(f'/h,֏ڎWjwQWͫPڣ#K}5Ymb?V1@X!Y ΘKՑtZ͠e `6_Hg"$l>EkYGٝέ77׻ ^Pj#e2ʓsZF66DZy ~Yݪ1iN5RNJtuF7VjbdAסCXXH ;Bm~sJ&Z(mBOUP%4V l7*m{zMrlrt@vϾGhC[CsT +&) q\KٻۘwG/9ZHZ\ R^}I&nOu_M\6EJN݂p(&3otJkڃ|zi|5U6XI̿'tl50QEIi::՞.4Ap/b9 $lkwݼ&nڢޱwʌ=sΐWʍZVdZs8|R`x)zWMJ=w `D9 }_Ɩ;ggnWD+4ЯC8:"W`Xei"ʂҮ.%{036 X4P$t5BHM3KTލg@Qap7y' '\d]c$yRu'6#qݻ n {#AusT' ϟA{['6Bl IP0Z:Ƚ1gs3̻wP zOď^ā-14䐘rr+N˷?@%BXq<_('4S,''5=2V'>Y+P*Mhh|g\ IIۛú|WS ;1sbǧ% _ Z A>+-[LC|um]zE Pb}O ɻhPoiBZInɲ `wVMI:@!%y=حk֋ O,ϴOL 半17vZQ l0{$z#Tr]l΁w͉Q`O؃7A\CVK9Mx]T>WlE[ C \TC¡A| ^-Z :Iuy&˵{Ƚ:TZ8kr)ewe{v+{o寒ovoj7īe-ҀFDCk=Q fl!h) Lh+6O.nPdCTIUu=)Wb,҈eG X[lTujڕ%P/Im40--^C%Bcbk " 'D%l3Ws ]`$woEr EZqMX!m`DR\݋-l=bg u˝('k>*3M$Lҗ.fa"u2δ9C݊|&6lU=dV\aouY 8ϽXFWuFyyHv}qHdr*c@_E$S )ao`R+noptfezNЅ9〙̲RN"D+ȏ`ڳՆ[7k@y*%al+z!=4 lJ4N r~ M,n_jVhs,87#<!s7(~~ ?3#[h<, Eªx[1wYt $.b[/̑xYI[)#.װq;\%J]Y` X&V޿ Bl%OvHh9D/u,I1X1-y@ }mE(]ס\[^xױF^+ȲC`Ģ&JaQ"Tr2.| OƦ#Լjf&gn8BBVeU~ITzD⾅Mӳ(FNn1dk&@&n۝{X#977!\LLL `CD\5;3EIE@8I1yO/q@CNqV}sIk +`%Fir2_{ظ#&X~VMBm m:F8b2);%!',buIyʑF[!rۆLK^oۿ: ´)7ɳ( 8.h+bnRV)=aMv+JMx>!نē/^,Xw&PqJٷ1:&"B%RU^&UZeATf6-}@Qt -)r%cW_JԕXW>ىS2EV죏١ :ieoڲ֟r17 r]Z].59 =&*9 u|8#IkϏ<,F]y}$e00\ @(;u EBW(% .oh= غşЌ7Y԰"pseHIe_lKRA I!kNW> A0gOp`[?F %/P1 qOsp)==bJK[Lp[]g3a90H^ Z'pqsP r94BC^LBNX"X_ ͨ巰,kQ},mĖyoR4$OD&J`&!PDGtf 2hbESrѐ͈^x/eI.Ecl~Ht0(0ZnWp=#p c-3uA%&p"dzi(ޯyk3{ LHjV'l6#/R y<ұxct?5Trr,4Cjk 5}C*1_䭨`Ѥ?yc & U"5~3Վ&0ѡ oodwRNp A,ɓ؋\,+:c#-XY1Ir_n6<ć<ڠ2 h bͯ_6]tew=PU52xVTRy@lڑN , i;l4=ߊL-ZrSeyHM10YoY6$ިeB uy>g`Xǥ=b5TU> D I`"KSkMF(\ȑoJ?A9gzGp-.22ͽl$c1@lʗ}RD)) S p8jP]]x۲, r~*@ŝxS3' &vƝtLxbݜMW3r29xѼxg5:`G5_eK㏞ƾf:Ћ,AAkwPN9e ^*uUauCE =@Ƽpf@H"s/lLMF_ח}m%lNQxųy F` V4񓗣NqVg#p`nTM=}MB&_ʳa+P'>/U z#W̼/sc;iu717wZ\Y݂&&/cG`ww09LU5?ǖPĦemWeY1H-Y%*'lg#q(>3"&OE-FMЧd>DvWQJ]ELȄ|6Zb1<崃tjdRõX>niַ_xRzmEru.bBk'TŲ#i|coxNJ;U|u`߁k.ױb;uJEYFZȌǴ.W*bM z`e&:ٲBv9-ԝR3!HN@2vCym9psB,hNK@2>  Q9;e 2U|uZ@{*\OdBi~I񜸩lu߭D N=%Lơ {V`>{Nj?1i)"=coG/l\Q[{ W*6t:`̥Jlޒ$`ڵ` 1_n<&ѥ;w#xŸŊ &b!FaQCcN;/W]컱 _d>R*>L##cQ%r.Te/whj)[䰊3vi `€6EgN?[<2P.\')!s\Ag@4岮H3_~<ŝa⣮[جw6u"㊉a@PZ[2 .4yAq؞FIUyDIo)~ϺP.~`ѲN?zy9tR}ANC_<IY^\F߫"V{;xNF4J’zY(. ߱U8EÚ(s\DWaQZH< na{`CT B"Ga&>c5V%ٲ6]$Eրp3DD8lΪSz׌CźC[P˦mU=v#H/ߧGr~\bd%q"NHtqX^du%-I `yAIENt8:%}99:Nkb4\tBcar U^ca?&FY%ڇ83N,b-eD4+y y݃I'MCt:ߟ>d\&{`7)ϲ'/R WiqzEŚvuBu6.68TO7$Bx_u*muޖ:=HɍM'\u^nwq! *(9 {>HXYMъ,'a5W`@̯V187_ Uo7 3wbrTe,﮺ + qGU}eHteÃR3mLJ>M2Vڦi /beou'gt:\KiG|f8-|/ {KՐpl u~iNڱ?zu\s&f F xS~C"J;\{}wdBvA!8+biK'({X@}HPoC -!K_"6w\NSAޢbg 3mPoN5D9yc \IM)=]s_4L@hxUm͆,\.OW`§"' U~P^0cjиVÕt̗gL쀶2AYYDby| ̝Sg7J WSx,;4rkné{P@۸APy+EtR+Zj`7 b$2 UN;;a&/;5ǂY7E!*U˽>V/^8zتJe lh8 mԗ,3 FSTiznqu۴neVcARfJy$ȣ Hi ȧF7΁#P9[)f/^l͌ NPE 4y# JmbH'׾(DM&(Oi2Zsٱ ڃ#\Sop6z_f#vRe!{F́,롅Ur>5/0Vp6@w`K~'Cq6aD:%a 2Z|UV;Iߟ mJtXEDao5!*R([+5K -Ü-k#=yƖ_C⚝bUu$Ig4\9@J|uRcZ`p ueo\KCXyEcl}ن}U@rJI$՝2~.ό õ@] V*}C[qPlvGh/ثm+_-B8p87A.#'mۏ k y`a/1zsg.~d[BpZ&f+[Pl:M\ripR[AZnUkkΌ,W\ukx3p.Cȳ6s_8XjwOG0y 1y`*\VJ; <Ι.4٤~ .I4YTWKѼ&u(}v`\0֞9?q[x i| 17jN])(֡KJE wVVӺ/4,L._`܋FlWǚM$Rc^[@ghG%Z53Zh.9`1-"1/{y^.yEXSAAlFY]3yjB/V \;Խ5tNߤ5uYtv"SZTm † D[kzY3xA3Ɗj\)^>FSK@ =^)0IHu~fė/HWк^Bsvԗ>gU;HlELў zN}jc~'E,9>~#:՗tqTٛ,ӱ3  ;n.E9FJ!"@ ȄBa:!^]p-搙'c( !k, SP1$eF)EN=w)\>mWF,:f~ EW]JUS!9zu~jh!{v8ݜ'ju2J9Xm8>)󓉺Flzsb -ĞoSK/S],ݱris(Ŷ!o*b&u#~[qf;טC.!dA wǯTj/:$ hxC6&uA}8TG s2k9l( ܒcSY{3e`MHgaprZ <:J_Bm1oS J,@b,' ܐ4:3$ᡘs~q<1xЀGy?_hrx\a7<7 Tpv?VůҒ_'*L´g쀑nTyn2b vi!q)]f*_ʈb 2p<!mB ^KU55B64c^{DY]kn <.ȄNDx?pXqi~Y@C%Rw-~*Tq#OݼaFK/$* #»mmpSlظ#$4: ̩F#'B#ib+|N.\f'L&`߁2R#wڤΐa6V?xj֐Sq>-sJr;>@s팭v18귗"ޅ xf QLu^ DS?q~Xd)|Ireʮ?._ly<@LKzB TQ=6Oz8p TLKB}ث M1! G.$!5B{[HDQ