pdns-recursor-4.1.12-bp151.4.9.1<>,D_!M@eeeLV6):{%SFl;HÇmY?QM[Yސ&9xx*6>ࣘD`(0]|_ N4蠎. )K&\"Z5H͊ioFÂjȚ Kx1ד2LxƑhSb\7! 0RKi&P[Ab:m1jRXmsť-6`+9->Fz?zd # p ,0IRc |'         (      4 p :::(8*9*:"&*=rr>rz?r@rFrGr Hr Is XsYs \s\ ]s ^tEbtcurdvev$fv'lv)uv< vvlwxp xx yx5zyyyyzCpdns-recursor4.1.12bp151.4.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_armbuild22cSUSE Linux Enterprise 15openSUSEGPL-2.0-or-laterhttp://bugs.opensuse.orgProductivity/Networking/DNS/Servershttp://www.powerdns.com/linuxaarch64 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 [ $1 -eq 0 ]; then # Package removal for service in pdns-recursor.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 pdns-recursor.service ) || : fi fi+;K]F 䁠A큤________\9\9__8982fb8cb72ebf187fd67438f35019589c19544a34ba2eb57a0c76948df053e984d5499ee1d269602f645e5426934cbee9ab21caae27d76b9d598bc44006e21cf45aa768c839e79e953d6cbc90e14353dc131a5181bfe9a85e93eb3678025716053abc1aae505a1ed898d125c4ddd32d2eb77b91fdd98a0b7c58ceba965f4694e03c267225292850d578d50466b741acd335a166661ec04ecb3c510d8ae1fe809a79aafd37f06476a8719e9474526c83049e58349c05f0d2599ac291db359f99f9c375a1be4a41f7b70301dd83c91cb89e41567478859b77eef375a52d7825059cf9d2cc84f3e9da7a6776fad0b9ef9c0686b07ccac0b74d92ac8077876edfa397d43677806dce2f28f040b90f18b0e20f56bb92860b3ab0d36f05c795888ad845f84e3a3cac534781f014f97033ae90d4574b186d9455762948499fe512ae12servicerootrootrootrootrootrootrootrootrootrootrootrootpdnsrootrootrootrootrootrootrootrootrootrootrootpdns-recursor-4.1.12-bp151.4.9.1.src.rpmconfig(pdns-recursor)pdns-recursorpdns-recursor(aarch-64)  @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@     /bin/sh/bin/sh/bin/sh/bin/shconfig(pdns-recursor)coreutilsdiffutilsfillupgrepinsservld-linux-aarch64.so.1()(64bit)ld-linux-aarch64.so.1(GLIBC_2.17)(64bit)libboost_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_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-bp151.4.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/sharmbuild22 1602681580 4.1.12-bp151.4.9.14.1.12-bp151.4.9.14.1.12-bp151.4.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_Backports_SLE-15-SP1_Update/4327002b581b95627eb45e690176814d-pdns-recursor.openSUSE_Backports_SLE-15-SP1_Updatedrpmxz5aarch64-suse-linuxASCII textELF 64-bit LSB shared object, ARM aarch64, version 1 (GNU/Linux), dynamically linked, interpreter /lib/ld-, BuildID[sha1]=ac8905082d3acc2618ca5c055f3813e60d3d1a69, for GNU/Linux 3.7.0, strippedELF 64-bit LSB shared object, ARM aarch64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-, BuildID[sha1]=6cac5e5bdde76e539986a2191f4da343a6090350, for GNU/Linux 3.7.0, strippeddirectoryUTF-8 Unicode texttroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)%%R R.RRRRR&R"R(R R+R!R%RR'R#R,RR)R$R*RRR RRRR-RRRRRRRR R RR RRR)R%R#R,RR*R$RRRR R mUrc /Lutf-8687346bd6f3ca3417c80a83a8006474e6ebb2d9ca3425c426260a5de77c6f9ce?7zXZ !t/ ]"k%Y60G`spk =+ߠMbLu'$yǶmT&&D*?F[VTI3PyCѬ٭-} >\WAM&_/.?Lt ׃j&#bV;g%d?Y6Jr!9j(v<kŅCq+Z5,_i(JT%F4y8ߟqUX\Y`˽q⋚2&Ϊgςg5c*YF*Y.X{3J~pn V XC 8"VqE](Z5 +fp̖ ~Ǯ_s# ]NH͏AzV0ЏF]hM"R;ATA\Ug@3q>cU9؋ L@E;< FT>߸'#6Y: мQWx m{KPTr܇z.~1niw@(|_ }xb[!A9"Qg 3ʨMy% _c$἟kP;TvЩ4όIifZ[M9e *x~%hsOt[:5!r${X!#j`:5M^ËnUCY6ހĜ2CjcN>>`:.p|?c2*ά}5@-$6n.<:A`Տբ$6l<Ҟ͈zա)4bUA*)L\]R"G)A/(iYI._×o-~Ó ]U i%Nra6K75ʹ|D7E X)px̖ /\klTCy~J"^!:M^Xu%"dph|l /Ce$r+rVG[ix@5іON~`S^b˹2~h sS{iŕP)*jiDCz&PЃCB̋B!"SAHQ <#5e1ٽ"Jfp  \2z!hݲŠYlzy#yO][rkF;3mF)z VᲐJ<_wW `!kqu&=AOV7;0$l_$Lp^!36j[&s&qޛ Ql 枢Q(8/K 9 :F\?[rAϏ9dY o][vaG1Sɵԇ_0}~4zڮV@hʟ镹AEw"M=p:5.GȉUnt䑅% |GUmݦ*8]^B5oWsb ӉyM!qЕڗv4}`no= t>< FCrT47@$q^>X6CB`Fu J Y@*Ґ2&\09:~CTر^PF(&Bω9O.{-=؎h2"e zSpUCE'І\RrP)%')VdЊKuɦ#bEd/M&` 4D3nͱf?KZ-lHY2tmB^!'>xӬ4bqjFWFғF'KNy‹;:7nF4W,LSh޳]YfrNǕR ;A Ev Y9Pgj2lGFR`&w/Z'إYvFwޅ_t l]1׈͜(B`JsE۬M1a1[nTQJzh0 ȑ54*Ҁ@=bFQ[!NHdK9ʉ;W=Yl>6hg?c,Vht Lh[r{sS1,S%'**Ȧ_ ҁmRZ"lS*Gv_wB )xDC=‹K}A[ J*ŁKgd@ij[XcpH)50`&dt$ygcD+%&D9 WTsإQ0 ÕB>&N>lBK^]9sgs+@_2L8nc|u՗dC:ӕ-_И< )/yAjF\r.gh;]@8-M3ŚoƼػZ\pSFH̾SX\9o<@e*,r mx(x3 YlƥJU2upru&b^FξHiOQ:p+S, j^'ru&'W$\(-&ho|#͡([ߐK>,Bvͱ`f.j  $tΨKJV>%-!6r1K|С$٭m-DK'|ӊ Dž l9f3T>aBo66o vXMyErYsڮ<XzvSPrpq?<e4垻e`E\^JFI<Ȝ4ʠ#6P,HH:8q1e>M57 Mnֺ0[YlŮ fKgcLZV,3#(V~i#x+Z|u{piegRk]-O4#ne2g)%蹹g6Ee憝}4{F0&1sjX:gB0vp>=$DOxYHMs9P Y;uKBC؅;KpY1 Jm)}P3OV[\56>쬢8i#~xDyQ\wyevH ,a|vlϯ+A.XB +;Miml41UK Ӑ˚;c73.^DAo(19ݿ)fӰSԨ]q+ޠ[mX̂~jDH,n ߭f_+J+dRI"OSr$OHҐpN+ƚCP?mc }MAq" Q:u2N (kChCZxwk%z͘:h" 4Q~xAC%T{喂 8LH6G +;KY;erp+>udf}P8//!䉌(OZN1R'38P$^j3+ ڤ NYʉݑO5Q*q[5ܷ) 51i!9g=9Ƀ=.dTL F|qX~nl6b:zekou^H'_Q'rz_yc}4ަkh1pNk iWͶrϋ:IOV" >Pu2'tV EA| Fc,]I**C7uR0qzpjݍY). ^w EHV(9_BKv LŔ*_➙ ?Bz9C6mE[FGo_ gǓ pʲsEqU< pFr-FK"-“$eEy۶^! `NBT N xe h K[T_gFNj͒Pa>z ]`L_| A!XSUGz$>UYs٥l{ydEy0Yt}?qhJ=Ze!9KUi p6V!9ʯ l/";|ւrw5 䜴~R-5 /=C29H]y$P7 YE٬W,\ݣm6տ;3z%/eB)yk3>8 88]qu v!^y,^S䰃1E.d4:!$FNdY&߽U^ɊDJl a'؇M*7i4橝BV`xr70u=#QLƪ*-id/Vh{!&Zc<,w)u--<*xN;Z"˽,)%,CBBVjg7pDkqTG8ޡl4dM%'YNb K VTQpʊ?p*LT^ +dL O )?9d(7Z ai{QV}}ⱽ˸($\3p$5,=nyk({EIBUAl88fWqk9P_@e.Ȣ<29ĪȹUyni-7٪ݝ \f6$$2ًowACtjUrRqP]wZ ,G ̚B_zN2qU#Zyõ\/UەrO52'O+;Vxo)aڎ$OP3 xշA8Z ɇۭ^H?ݛfvT,J)ȪTÅ& iL%\]|?$)M!.OH+q 8PtW7C-Vw6F~ =..6\'Ty/UUY.Ml nlC?~P";+Yc.[+kLZy(4׫0p%ƙϋ7h1-$U夢Ӧ&G!+5r$/=KL 6ɲ4iȱl'Ԫ$KAҮ|y7A7 Tvk s\~^u+>Žp0lr=7Ny1o0ϸ>)澅35I㨅eĒYPحT+فUHQ%#cd&XGV̹LuܽS^^ oi$exn __4{-#QSwUdΰ;)&t͹T9o@W:1W)Ҳ6utp')gB ('Pޱw;.6sֳJj6gbm_b>!E!-fE^\(|A=c@\|$$5Q3s30/?xW;|7sei@,e@W!v)8N.P$+ޗ}8vQuc--E\+U[Li2A^ЫWJ_ (~ Ϩ͈E-uJӫ:,q :>b4$~RXu*I>m'?"':>fa$[leY!g[k:ke& _zڹ6YliY.GyUEYQ%=XmCOGbH.ˉQyZL3 m:;8.ki>P3ίo[ٲRaAZe͐ 5rPG4fILzTE>O^OMhԓoB D)<3GP6pﱏKp/{)qeOZxI Q_"_krDQ؎1$SwKAF]_DguV*zCb?VA~&H?sE83'Ni=L"HJ dr[c,n_d™f@Zn' @#IDzeĆXLcVvĂ%8@ے'ﳓoOhˤel@Vsd}fֳ*l(.B;wQTdO#" LWwHV߀Vܟg.v!iŽx`$._ Fg$ M4l6FcY:_.27z da o #Oh?k 0 8r>r740B+̿L&u?G;cjy'=9KffXI 22 K]BzmU~b*TWw kj_.'+>=m1Ha12v'(0D+{dbnGc^|_ 9 4;7P'RLi/ۍ'"x6ֳOl9 zr)q.ݮ}ajH>>TBؓCFE{Mee̢z)AeI1&7` X^r+#[ $ +S<օ55/yƚ- 仁v󿹖p!_ц]-Hz>MWi g`RoX~Pykр׷f<3Q8nѼrZAzAdYPRuƚ`=mwMq2XosZ,tw( I[+ #ؽDqȃ&"%\6zE?l~dRYnpG|g*L3F<xL9{ҾwkȯNjT8Ăd 7e^n3jФ N-ēTj.In!n`T[m{0UTkP7kLfM;L k_mƷ沈IVխW(S" g hM[VSttLͨ~Ϡt&,6(}_Kʈețe& iTbtXĵyGxKA-_ϑ8rqy")N[^YZwXțO"5HR!u\ŐWEi75"bӺEϺ"0NQ ED )SCZ_waEd OfXyxM-5!b5Cy7ςF;oH]%U֯8&eN꣥oݼ9U˨aU@v0/Os詁)j(2A=m|ۏ$B-r8D'4hxl@g7G" ц, nsgǓRh[-gnQ5Ul|Kl 6X~~ ltev?+?}Մ.Cח"o-r=9d{Eꅙd;Uo-Xp,8bR>4"-O"E&$xw cIƽx8Z2kʹl5:]or3k׭Iћ̕):_P,PfddfAgJYC !"W`nr};`m{WBfQ1SuA~cp ZG9C<_+${>iMZp i]! KwgZohfĺ"NƢ[Gi:Tk\ٿXFF,ſ8#KBRwĉ3ut+8ĉrN1w+O3Y f#Ղ =#0nJ|S_*dt|d;L% 꽘dmu kF;Gɤ*XXR) ކm",3H=>9E.ʱ] a#Z YBG𥁲ay)j wbdD LikP?*&IzW3w!3 o`ϟ%EY0OM> ʤ1* E3c 6BIX~?l%{ '6RE`0"$VmY|>|еaEEAM0e neO\.c|Yf-2h 3Sf&&-@'}*نr7ߎXOE5֬TY-h%bħg|\>"M & $9ULBhÈ]! #B/%.~ @Amp,ܪRwE$Cy㚖! i@8*{s4S9,摋6ġx@ NzC<M7Tc[z^_qO<5XXTdx!^5;j@tYF6كAWGsp{EWvdb\aյ 7%O(Q ZR23cZN)my$;3-~sYY9%J MڼҿK-fT! =zr%QsBc-C{< T_jSk/z[u0[_pWeB\m5ɦt}6e[IGkF ]WJ+i>!Ocm$@P>SW:9w (.눓ɅqùI s_.?ݯ(1h vŝ{EgX1JrdlFVjA<f&xwAȥ\p5 TbR(d5p L/PbO8ldP믜}y_i |,sCoJA [2 .G i F[26utGAAW{̯.ia&FjQ+{EY=Qc˝6.䰦԰xXY?F% yMBNP+E X=xa|uWAj۞xkK t/1oČS[b5L#ٕ610cR+\E3$x'8jYLql0>DC&ns9[ "el|Tsx猖\\vںe@f+<ˢQSKr&um8(QZB9jӫٱ Pdk݁XN*0U_:/]N뀴* ?fC\ݛa5 )s4׹vFT>W^,9jE6L%(tP|{ca AL]u{Yzt7M|:J'P6!/*5L#֕񀬾"^5gC)R"{kj_k* wEuqt˜\L\45+{Z2tZ9VwnQNu^8aظ@9aIpJ$\t.EE 䴛bҙ^M|B^:7)5'@8 B@*Ȕ)u8c) I.FNvPPɢdOe6n ʨգ"*fe߲0lg&^dt~;ny/'d*H[ۦ|={#'Ma.ۙV|!;Wvf,}Dos!}^ZURpi ڥ,LU,x(*i, PG_Z?2J n'Ic⢐,\6Nrv <˥]21GU$] u5*M[UUܢ?XpvNYd*K`R۴'%L]bA#ҼP'JƾZS;x3ũ,/3H+y-c}[sq_άʂ%^$8tD Ê!iVXϭΙ FkjՓD UڲTXG<"tNXCQ7 Y$ SJK!aCi5M㽣C@ h+kv8 /h534 b^[׸^%#Fv#z.4J\u:2}θQ㟋FnB;*ݒwLJ5&<s."KORİ 3swe8nR*7f&;K nd*5 T'NlbZolسYWl< *NOi383!g5p*RE?] =`gU/ܐ~{Kr]4{_=ථ\ 6*Mnq@;_ҳS)l',wxlcЇnEPM7gZ~OV_=61q.ɝQdCO_/Ÿր!PŪUQ|͂J0>íq u>籂bp2^bn^:7ШhZ<\іu< (őW{ѨS⿇ {74I.0=@0v?p䀣U)z I0'Ex┟*b۬@4Ͽ|8\i/Y%L[25τu>A[gU3-H8>r{nTGNg]YPIOBD=ޡ]J@P'O f6R;FDwOv#e" 2v)eՏ78[c5c{0!g ҁr.d_M?L)*/E%9{QCC6k9K4.$߯՝@@C 'CԮ%}HP%̠A&HsZ{pt .,4'6$aOqIi)IP5 p؛IBx|^^H)bd{rKKHzbE%XoWMC͜2(|g9TH3QOT}z ˤ*.yAj\Xp$*b(LW{#"rDkPa1e xj>'0iH+J)&boNt$vx4EW0-&vP1[%n8bA36p^=w ;K=qqo˕]!OQ(*$T&\K?qòfOHh^9ll7_|ƒwifX_j*z@+kS2( Ӥcb[beTs [F+tE7+6邵OtY JtSN+Oj%zQdK9̼}=3t`Nđ$'Wg ٌE3[/lG'2dSX ɔ?BߣقD& ~>>E3Xզz 0QQz!ANX$?#XA@cj3zC 0WiljgUGqZxtXDͬ\E<~<qP߹iv/'B 1-d__FvrPK̳9E=u#to ˇ0W`ۍCS(&cqA5XClEILY8$0,j PCA2vt?@sbP?U5QYlf=(4Xڍl[3J1Zk:idz'{e2WWusU,ӏѮr9|w+NS~ `ی2~ilqI>\!TK(l 棕D.2Um7{^`SM{;<` L/yٸkzalƌN7=]w;=*ќ^QΏ_S#Z@WCIrX}@5:u4+j<KT};x0k7AnH1󓭢)ݞ(70)go! e!ai̚e_I/~/ zġ!v1sg &*.?۽&`1n;9K>S뗨L|Ӵ"" m>yɠ0],%5k3ɶQ_;`}g?'UFASa#u+`iO>ŹO\'mg6BH&dԗЪJQfZƐ>>cgn{ėJC&+̑HS"R0Ǎ~IWd#\)  U$OKz/ ֭_9^b=s⪀D+D4IN0qne+jTO~H~UM*F!yB1Pr8|N/7Sbf)C-i>t_[<ʤ"IYd#?/75v:i4h0`/ _h0޴!\Y 050d~7+븙 h8^3(PMW',I WW^8>ãJbB٘km%#Z©x u| %7Z1(|%z ha0MшR:j8U"Z0ՙmHTGᚨx3o zĉ#Gx7Qh6i7̉#<&soI zK4U͢]辝 )YMq%_cZ0,Gcf^!r+jI&-ʧ VC/{Wn\2%׶ OQ*z~!/e1xs.Fg"8\npQ}D*/8g: tjJ_ȪNB՞i6[٢y4`qB>\{pS(á6Ih:: c`4Ztx+F18=P -)jo}yn4f#Gxc:@,'y@冂kAgB : ?.ef[2x QRZyHhQC c_ &:o.(}^V{xZn@عR ?N:Sk sfjA&+'m-M@a6 8zltA\pl-HH8RV FCX;|(WUUoRVc csCv)G![OR!ؑ%գpdmTg\3sgR|< 93O̰F^ߴ}ܥ)gZk !â9AgWM)nc[Ldc̜H/>ޅ_Ajq,>=;9BօO_dOT\&[>}=څQ|\u^m:H?oe ]Yu4鄥[iFf>Ŧ)>˘ĿkIUN0Up ߺά5r Phb: ҦQR#[cv\;/friL\ ,*|VWU.~jJ~~uWYm!\rr]L(SN`tjpk({֛Xd22OdN^*WfI62vt[fSEhi}$G{iAh!*b ylo5nFĞst|v`<{˗߃p÷IH`\˘b,a7b{?03EPNbx.e-,x7 &{mS ïp7Ŧ-deMx-<S w`Z!Pz)5)LYZ#tYq4Q7Hzq3>n Zh*L(T,%mnσ%-eI Hh jvֱ$2#vB i:JISMu\ !?;/*>w rFKOp}l@oc"roP -G3qeɏ;\9奿[t _c?A>fuesڙ br)[ O{$ )oYϦx8l&$dY99Y>JXM/cA/e+bĢ5evMdPxe6K+xԬ$%yAHjb˒YeA1y=;l-m>Hac]~fB2Gs0EDȝ&[l޺YvQD3Z|>>56լޢ @'RUvh]7"& DR. :ALŤ^RC1tV1!_fQ=S%bvr‹_`1mB+i7ܳޱS ,jG#:γ:bQEU8=yK_2Ǣgä'І@p&y]*jԨ<'}r{ŋJAW+Bx *xnp,uH .#B?RoۖwwHA(4b%GMg_,*!a#(ۂ#+RcUb!sZ(+'0!սRVg`iq&Ϟv|n< @e6Hș&lً`7۱ITسW C@3ыX=xe}brEpHo.czDf{@0JY6[uAJ\6%+m*^+j7]ܱrԻy|8log-OnvK%]:B]noſ3M#fyfMw{K%2nN ["#hVsMD[3rƱa Gq&Xo^"$abs%Aj-x$.ɡDK6A7\ao]TEA*"9ǤoqP҆Ƞ֋=S,EP-Y Mݵ:-ߦkWQ%8[|joޘ@;rtK}[вuY:W/H6D2q}+m *ڶC8J0-8 ^C(vf0y80R{=}bB?:rO}Ww4<0J FֳլK2 ~nVM&]EZ2kfcJ"ӸT]}kRD[|CgU=]1a&I*A8\8)އM)kGhZmp -}y dtS9#p*JbzaPt S$b7Q7H(9ql;aG/sn/x'/|j-?EJw1xr[i2d5LЈ{oFe :D;w'ؼ[(Ԟ?yc8sĎ[[3]L H| Ф0+=,d6e):=y jd7Ӣ| ,f~Rt zSk=DL\T*UystGNc r .\ ͈yb+D:<"]T s0nϓYfj& twIFмE `Z㤚; )lM- ; kOoG伵oWkE')&/VT_|/w*׭S7g[V&53u OOQ䷙r# nUdcmYP D UlJXeOꘃuKaP1qjPr_nox.lhO |o)}l殑b"i*`8H#Cu{yz3m^^1ˡW=BV)' s82t4`6z@\!@\kc+JJ"MĸuΒ$U2JE"[(a8c"O⌤M{،(Wa ,(\GmlHBfjsJC#j%G}t趨Ǣ~QZ 䀠,08ڕ^,bjIi|m `!YfLTq%h ލ&9];&١d̻0S0c]XCeB~۵`=$Qrz0p2NkO><8e 1BK}E:Z!d 0*8D2PJj|wfK鎎 4[HyNW@V9I&W֋;)xxuc8rGh2JkK dVӥY/WUuQ,[z2f/臬MFΣZTgVQ/uw v,IyΚ{oGܧi 1 |RWPDMަ͠tP ZZ_7 AW]!ZQvia.1FP^NIkT+kԛqex ]pwɂ_*\l/0#l$n I )1M ϿIk^T*]l!g {0& gH(dPɁ# PXBhMI0rxZK@S'Cs0΂; y6ү NC1?4keq1רQ5kWͺJ0lD<^ǡJGJ?.UlJ(]EO_SKE>\t9 ܤ]4&CjWYNSл[K!qf⚑!wb?BÏ94 (gT3uH$p"qieNDErV!I`D h3]N wyR~1gb0hȓ)1ݤk#ka3ׄ-vD+gسu(L -IZrezjkggg^I^ા5 1m͞6npm:#(yφZw%3[b,o7x@{?ŹL!Pc]}c':kgt5j~T=Rցkx|6B^eE<VS[]ȗWկ`|-|?GCAػ]]c+u Jh ץWΕeȳ6d2ݴm-=#QA[qHtA9Dzl?!jh]>s*6L p𛕤I:-qR8pF [,ѿo-ʠl(X 飼p-ߍ;?Kz[.O ҺhrT7S-Ԝwi\%y3w6`5~KU$\GPk+8|E<7` ЧɁt@A Vi Ĉi Nk;֋SL:st@*"1.=;%&!;zi+#o˯[~"YF j.H84*ڲ9;'ȚY5\^dYԥ:?=5]`]<\^42GG"7okaF$tdXn,:F2݂na"sύu& X_! Wh}xһI'Wl ck2MY<_-95%9d0৅HUGdq@P>#;j(s ?(RC%(2nsF.Qt!#=ub@HV$" hhӦϊb}zzcΡ<bDjfM{Glv#39ui,!JWmxnۘrN\pvn5_SWawy\K-`{-$n4MwPp:P,5lM~4NxR4aͽs|L 5Pc,%5 i[Io].d4Ic3bQ(֮ U~j0~yr)U+A/s^g~,MOmAÊK|fv7/G57oc^HJu/S#hw^{,xz,4B: FVho =]T-wS(%K͵t]CDe4~2d7T3DW'UX!ϔԓk}n}dc.un(pOJpʫ }tٸk?t$bNP۾{"Wj(ANR܋̫d~ET?`qP]'u֕F m~mO;'r% 6u! N0P<5k'_CtKǹ7BNNͻ&Rdlt`wmiX-RQƞJ4")qo|,ۅd1E+S,=ʼ@KsEA48H'+X,5{bڦYH&]H7ig>ݩ˨qh %0SYXc>sxҹWS8@M‡2 y'W`62CAkj\]#QR;dob19 -GcT%X.WOKski-p ?;76lSwǃ#,ð6G Nֳ:q"$y"BbbX/2:0 w#Z~ &BUנt,i& qHfv,w5ԫ8Ήl.ա2, y1jΪ $-)`bW~^ nb'.I)4F7sߊȑ0@G"+ТD4&e~1^B0veOvr h4aY^s]ەj/Eފٲ;ATL<\R"8:]QKXM3Vw?AYc6JǾyw 'iԚd]ꜴM I<931O!h0z-CABul@ݺUVI"J %ΞEM 0U߭ RѠå?Ȏ0K4!ea)kS܊G>*mdVZ :tԭ-8FD*n mܵ\xkoczMˣ]+XaoS`ߊv `{$jzɐ} muC\[ʱ_+( Ծ2rшV(d0x,T>J~c?ߖa@N hL5w*B,OmER?xV0sֱ! 'x#>eY; M]%jc2jA`9ߜt$R%}oiXȯ/ڠtQ3N!D)|X>܏D_8<RX  MdLuU&[}J/ek$FWKCM#,J@Ÿ*ꨆ:'uۉT-8KY\ssqBAKѾ" b9GYO3Eñ1/Mz,aB r 2,= sӺ9DŽ4b.XK.3恷npZ,Ge?7ӊî(O+;*p~p؆wa' ҝijih$/#H14TTqY¦u6tV^Rqs~}xbO[WeXmm+Xgf@NJ쫏δGANIPD(YåD2)gq}'ckC0CCfݎՁp@M< ɷ"6myɮlV_\mxB;{r-0'zaY6Bqip#vS&/;H7v<%UFδ=m[x.$RޓDih1ۓ7 8=n`I+8LUpgNVGFͯ9,9*?IR4H+޶Rw>iIssqk(uu1lq3YvW a4yߖf[ur3=_gιcD@)> >[\|Z'Oɔp#`tUQQFljI[4;v~R''UIdx|?%ylA>QBWVv/xb\/a'#']&ePPV|VM@8f4RϷ)-7[e9zɌjXШZTobUZzdNO[IE/6<$` 5疆c@ /H B1NQԁECM2WU%R▃ c"篖jV, 1ZrfTⒼ:W%-L'jWA%IZ3 VxN^w Cs$Q1Kp(u 2*UU 2o?4 .Xn1_Lsu4nDr~4UI,MVm@&ueq:Yb+hV} 螙Ut\X.tGaœ4-׏ǧ"s}3'ܼEZf0/a\9'(7pg3+cv 6{OV\;P3;V=yM!4u Fn-w`vH~EJe6A\ naV4^00.b٠1dzyKZǺjueRgdiA:L|+OaZ<0wR v?ͪ8 $M5h3=n7paҢx?=A2\=eB@L/ L V[RAPMeEI&#R#4Rz^Z顤[r[~)'ZJa=d0mOJǓ)Hp˰ 52dpd3ߧw.ܱ(2C?bN*iXuT,(L:薟*#>DTČXĜXe67XNWKyy؇٢%'Yˆǥ~.)4r& K̷[[D酉 3S{;y-+7iR <]FP8tu=W<2R29З}'k1՛+R Cݣ4ޓ͏Y!a[#E.F-ySD]p84~ sW:ma朦<][WB^3,ړh?2*U(γ2qo)dSo]ђ,#7Jp,{j,!G&fC-}|0-+m_ ޑ-ʒCNoFDYbZ 9- +Ssi}?[5lȓ@’4ѓuXMD8dOW$*1҂1 m#뺅~Q=B9L/$1g*C*4N(}Q"h hw6}..T!a}bO.Q:M9,Mf)z?RO%$j\?oSv  }b2 WqiqU׃up"˹2]OU{_%eGG(Aw\5TxֈE9 2xDvZ[ī7#^]gP{I<=IGrz7gX9Z1v \7j|K8yt!eS16 wƌсGrMK)U⵮5,~s ib;/Pf n't6vEF*xcbs9_<*裃BeGOv6UTƑw >f O~6 F[h-ħ\!y_.xnHN?ɭ|\u"Mr螫o|0}`$,՝ )SH\L,ʟ - wʧXJRG?jY"vQfNEr*\0K@]ǹW ,03d_zp׸ͮ>HLjG#UZ0sTe|X!jGas9 Z  gKwkrhfGlʊYJWI݂GbtD,LPJϨ<i7lBbP ZI ಀ h**Xk Ygv@J; }+F> "#.Oq~] a5B.L2o2٘$pQFBa> /sIWXЙkJq||}3GAx'u?$>9NR(EY2>h ٱ0 Ƭ;Sxh`C/3`בytd+ UT bx_4؁MuGc5BX4ctCtr3S _3O~I?zyR{N9OQc_y0L1ȕ0\øv$cy\f3X?Q^u?jNivVPN9D0@uv{INvP<~iӎ7<Hjع[s7m`3AI\5 b8.m\g6pd›v 6Si^)4\Ÿ-O*"T?; DA3cn-!#8\lkux{sm^ <fʉdߟ% Y_]+tc$~|b붘8YhqG[a]B16'QkgW n_۵_'=K/P8GȈv˟h_nC!a =0K]EK]U|VˬxbuCJB~rI5(C+m RZn..?_dk[)(GcxH,9d* ]")tmV _ RcZd+pX2ޡ{L8տX.-Ht}x&s˦qɍ@nM?" 5Hk-0ct3Xi1*0WV:ؾ.;ZH8O{mw#UdRjmf ƵߵFGX{6Wň\[SAB|oc,\곏06~v]Eň ds۱N 5zs x4N7D\SC[xMvJ/&c=밵:檺U d`Ix&5Ça 1a{!(6+{B1Zvўb O^o3A^S? O]sRXL圍ղVR%F ž޽C5JrcK3L"֞Z(Se*c []+Tjz?Њ~ ^iLs1,%Р5P94G\k]_B6-qnQpf$v[:/t7tł([/"hr ~za3#:" .A=#;YR𹠬Υ<1Aז)FK.§砄߲x;m XBfEk⨡_DaoT ; =)wFdp[1DVZ\DB6!FYz\oxk]Y#՘YX~FS7:f2HlR 2}<]g3|BRQz|ݎD5y㟝iOC|nۊElnVxD:Wl3+03(p}de.޹ڵq^@d#U3zVR) /j|(g/)٘F_߿{:c,91фQDh3DL@!}ɖZ ,Ɋx`KEЯL SC (jQf{_DLLKv!$WpX>%ERäh]&D~".ÚPyaRYt+.l1Utan\ 0 n@/f1+įYsS~[øgSGt ;f 8}YP#tzt&w v ݍw4 _QsVn<1&>+!$ޤ '/÷>em,D'0R "?W|lu |ZΎzmU*kuQ}ݯNI~=#?kٻ fyˉץ:⫬]AcOު "$`6֤ xJJejn4b]"yus)*']xB%u4sfK d v}޼m 㤚Ɵ!YwVUyjTzmQp__HǸJ4.Hi-%q' 9v?k']j.Jz yz0TqG]y9Xṃy^ogw߇K`Ml_Z@5fHVU-1ItQvR2e-{>k h9Pa})s*xE}:mnXF5 6" %h*UӐTD2ۉ0hվK|k{?'ޠݔmn|0DkٛFhm.4 )S]^_J0;fk5XpIaF4 Ӂ^@31C&fXTQ>!AW!P-xbX?˘vZ.M@+uw6ov5F _@&T2lj{_>OX[ )c겟X>G aFj8ܡV}%X?W}e`HDsaXlnl~9sm,gnКtGCV"꘤F6ɋ-X>8^18.ߚ-UYd#5#K@xaѧ4r]"S3ͶF;,'I5&x$׺o&\5D9w q2!kjG U}'U+p iSoY1U[pQV=+؛!MAF0,X }I䠺'go(,;vL$' 3o'vZϡ\WL> Z3X 黧]%AhU]F` LF=D?sEC ("Br#+o Y֥\Y .A:](+h E,|D{y}N*b:&W7_LN40^ߡ5u|R+Um|, +"0˰*JOV1bL B]Cufî((r@Gk ʦ23KSCh4G"+aU c6$ubB}1L'&  plL52kG,M:pw&uA#}y7=` LgxQhR d@/OAx wf4P=H%(mӝ32^c,7unK:d(+d$*xJ-Sn 4*0#1vt+lZ˿Qyz4^ڐJt|&%,SXi4-_,`={K]KbE=ȕ1YuӇ%O35f,)~ Ͷ>Ճ) n 4\a-8L8WaC=)u Ou%3GPg[knGNy2n2]Jٖ :ݜ`ghm^*xw;cr@Sэ6%|?~6fqjun٦F01Fu':kgE`:!;›C`K_)OkK$qLb]mhMmEeg=SZU4s[j1,+"!m;ldau)Yi'(?1!󶝍7uca߈*|&uW fC$B^1tFAAj2 H|=~l?n;zI8f s,7U3Bx06o蟮 #ojj;waT-}5If+wP k>?])e@t Dnd~ŷ8CGT xDcPPKt4 n@mA(&qM1RA3k&mk!8?Jqjn W~1"Vե ğ$n.Vk*k95vLYkXz۱AKk_V́8esYy$ O @Tҗ=ofbIb$m3,&I1?nٽz5h=J6F~r810#59:],#j6[/݀Vڃ(3sKw"3{QN}*,p5I4}UHyD)"-d2ɮ<*{sjf~KBHw掮yn'H.#ʍ!7KJ$6'IdFO;GDz 0!Qj&A tscK^FvFT x_1ܵ-~ TKy#wW,$ج&xRfH@?׎5}jUdUSQ׬Jd#Ns 21/3~w._sܭUXk?O ϲzZV!-#z=gC4R a1ǥmQ6/Y%,~?Ɖr:Oզ M ݘ|pK TC_mnv\CUaazƳ4+52AF 1vAǓXw 2&H[E,͌6L?M䦤, ef[c!$]M؟ZUCro2fg̘Ap̬B f U3andlpc+0x<6ˌTB7>Α -R[_„!! ]} Q$OzTTWKj ,۝iYכzxqWn%(]&[ Q f2VB5q8qBt?5`XGMcy a0%G?z7}J9)i,>?Ժ翸35]n~.m]|̼Z2gsd_;zJ'7?%,iv1"1)rlC!.w"ؼN6*ej7%7_]?B 3_G(P,6FGȇVCu(> J:.FS?"K,lgKp8qJŒtk`](z3.T򎮗TSMVU]>*Z{)3)(Ez&HAʜ c9&q4[iŸT2bRrYo`)woPTJ\JK wSv?qb;" ^|4^t\xAw&,DXU`F;>C8l=9m*aB@U|ãN@M 7u\."=td?ÌF7;tX:q*Qn6|3 0eH'55ӿḺTIe]>L(W'H{s¤|o.o~[ 4SaX\Rsj,vf،`y80,%sǖGh'7HF.MTn$e4ϐ$FԂ? [ljYy$&OWXcbq !LHvV\  m{r[w.*y6_mh쓆eS',x¿X$EoRX 'o]Q!%pM"% (R+1 |5)=I˼aCΝqkyh u,#Tw1,zjkݧcߋ%;ogI96s 䥫0RԺȠMȖwB7G#OU~Y:nV`_)izHc'E zOq]{(xQ"T40f*=sQi]ni.u'qbo=hZo(<6ȦSsTi)N$c@ԍ\mdw"Yį%BmIVWg^uf̓l6,BBfQ)R"H8s!JE>V@zM̓F[2k#N4234PJ>f&5V\ Ou ԾRb磳YdS~b;6bTH>zS'Wz*b@`~kHz]JZ1_.GJ?DQY`?/1;3jN/a8n-k6͈/N):J0=o*.A̡;:`Ȋ՚Y,rBݿٞ$-)!EMhS15VF[\h•‡壒!lw>\YaanEn(IJ~k6HOPy<Vv [8d(Z}W$[?./}Bh[۴MfBJI0Mz;{Yy,oO[ `\47.嗹 t3\E*aŪtٹ qI$cIdPscARM=Õ5(!@NMMf aԀt`^"9FϪ F(''ʿϪ8Jh(aoX=4^$❨Qk_LVLFo 8nŲT&g>ׇKl+5$._ [U;Ր}8ط˸Tf4_X1̳ }!ovQ?4<vg'6\OmH`u T$`{vQmH޷qrKUJ G8P8?):$qU04~"ۅ=-tSX&vN_U|0'}Ѐ,N\pHKꭄK,C b E5qנzD} &nש:8uݧ? OK9a'PE")^X$$C{v". ;vO!`J]U]lq/h\ZjؤEnk;n[!Qw=Yj{_FLUz@O)~0>UuG>~qMdݜH -vxۇ:rMAS\0{|n })JM!h@?RЕncCA`+es {A_]aKOay蝤1mCB- krKjK GC\0(TrCIN>NMHx/$gJI=p{h9' _TG\%̧}qln%}HkK2~h1!fIl_\J 5Iq\=Ue{Xc<$ҟ'LG[L R] ~3-Ya aw^&Ie6jR#yJA<" P|ؗ mc(42H\o+"; ŷQnbVNݵ;KN.NOR@)F`3C-a,2݉?B@so5'";:b?VNĀU.Iny8`՝[ؚ؅-53wn$5ܢ>ZU";dr<hNZ'⸋c?* (!"c9* 64-LE>jpF?ӽY)8pqxio˕\6?4 rd,ʋW ŗ<".a~]2!q4? ϴo9aJjnt::M5 ­k0YjWx³cYK1)SqPUq3fgb'wl!ڀ!3hNwAgIR\ɧ 1:淋f]0/v/TZjU40tn\e´TD.luE4w1kxXTWt{֑*Wr ">H@ ~/x) ȃq_OZ|˞bOVQJ ,74Ƣϣ:`l28z~>8fH OoX-jy~x-9E*SloX̎LtfJ̀WW>18ɇym ^ƭ;=LM}vPk'CĨ=ӟbmZ ~sP} ac. $3u2-3Tq%u.`˟|G|.[< ܘHF]ޒJьQJ[Etb_vz}ߴFjS\2R̠Gv5C0W^B\bјCIyfQ&H.ZfFZ#uQ \TLeG׿tEV/'C㷤*aŜR >䂋;AIB1QC*w=9_ NBIW" ̤Ǘi!}YH1#7!$g,jg0sbĽ5Q){G5>&H+ʟm /NY}N?k2GzE">ikC*Jn "el#1qe ~e$4PcF:#5Wj>6}edMӠ~Q}]Ii6tɊQ%⫝2m'oP'xKx2_@-oE>Z{[%-dFEl 0d!.@$ږ)z-v5ƴD쎨wZAhSx`U 2zʹ tvɱ"UfUcemJ0#]Ý0S>7Pçpy3ۖoTˎ)*’/ب6`i׹:ty1TJOxഞ1: _SYhfDpMFG93Sml+h{n!c_1= 5μ <֠[qτj%^p@0ui9)Q() ih(+O? UN$joF]didPW 'UT2H̊ުۗᤤ =%'_a,EVWw u2ķg֩}Ruw;:YKj`>4A$Sxҽq1.PӐ}#cMNjl:/v} |vB wp(w\$UtwPبɺSz01̥n3qjMkZGD ?[q0㷃㜹i(|{.r5[!*}Y(3LgNAZD4m)\eE9!#AU=3`]KJ} S}WkQmSOTHS3'P;_]CH?jUhAGĦ hy: ۓ/ij.痄giP#r -.Fbl+)H~7f'7mҗޔ#z "mx-cDDHKZXDer[2 :HiNSQ1\~bH/"'KID ~3X/p4[s T `]6N dKeFwր3TB8,WG͇8;y$zفlbg`Y9g𜧡$bJT޲?M%+̞J/m)b e-5N r7ԛq7y5 ֤ۧ:$4m%A` 5s-IO) y2Hf!be>] ]=زyJ}h hZR^(@9Zꭴ<Crz\?nabd؏ DUXY|Yc+Vf5s;F\͋?; Pőrok,O"Jy u'U٢ІwrHc_+煾fc/'k+$yKJ ^5@ -b!+kS)X٦N jDCD_ggnh'0,:;Aa8ѾF '}uօԀxEKEauUa_[SGI1z'/rs Ǯ8m{6+1|_u`?l'K9jIVPHu~t"g Jv1eR忋~A$EsIVzkLE*?Q(p"ֈVBp rtF)sU(]r-Ճԣ=Юbae'g#cca~z. TR{M\/tG&;)N;ꎢL≼l_9w0tfbDǛZܰ!ڱʋ4W>q=67qIPV},q6HhY?i 3F?v<Gmnwv/C ',:fX`PՄV O;3Iu jaAgq'c <&]?x.S ;Rody4p҃#WKN$PUFyi+3VUw+z7G?|Ù"UO>^~{)i_ș pP`姀4-T^3)fR(aТz15s0|\spږ ڭ-]x6nn!z#9׷LvU \3ǂ}ZtzI}:Kӷdef_h—:"jfKg=߽d)*군 ė5.t+~@DCYEXۣ` g _GNBu#&3_ۏ#f(J9.>xM)`wƗ?o D Ӟ?M SuXbkM|ԣF(Mag1!RYDkIhPYyJQ89\3t 4}_W6E|TI,8Qvjj-HUUH/#,l*1 Luah9)ESK#vSmoRDOcawIקOmG uBsOp(f~6zݾ̈́+N]w >; 擺ҳ%[6[Xi1c Ejc8-,κ=":h('G. M@ܨ-&CAEBC3Ͷ3f:]P5a+NVyA)@#vgeu ǦfNx7.FpLtY!~6z\JְLğ1ATE̘ $;%{݆rR iU ^"s"+Jy=Ch`7+on`gτ]\yU{[I l*3#۠EaK@:0ys a1Nlo2Rۂj,ws.X>\{ƲyJn,Z0J9 JW8ci%D^YS. PhVI[Q٪Õ!6AG"N#W?K=T&C#nE'Q]q=u'XL7Rz903©6bc9{"bհIF )G=xry4ע=:/w`P(SKP(dִTU X+E2Z{ۖ_qLFd7NbQ "]/P0Y5J'΢ Ae:FV1gв)(O~@k ЙZΨf5_U暅DI]rpYI=3E_uD"ӈ:'hhVprpjU(wb UF)*MD0 鳳2'R$ҡ5W'E;M˼뷭=nd8b۫>_Ĝy YZ