pdns-recursor-4.1.12-lp151.3.9.1<>,_􌸋/=„i!0Ęg{N75"Dnhj>b>5NXz"2~?䌐rlPEOi8djԤq4=Ӹd۵Pa")Yim;B##~Rv뫮='dn5M;Sn֙'LRKgj|n-/y4!Q=S>]@vmXwaP)0lH$^p1ѯ_A0k~wR6XݟNMw' tO用BCJ(!>Fxx?xhd # p (,?HY r  T         p     ,X ???(O8X*9*: *=p>p?p@pFpGq Hq4 Iqd XqpYq|\q ]q ^rbs%csdteetjftmltout vtwv xv yw>zxxxx"xdCpdns-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_lamb54c_openSUSE Leap 15.1openSUSEGPL-2.0-or-laterhttp://bugs.opensuse.orgProductivity/Networking/DNS/Servershttp://www.powerdns.com/linuxx86_64 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+;K^F 䁠A큤_|_|_|_|____\9\9_|_|8982fb8cb72ebf187fd67438f35019589c19544a34ba2eb57a0c76948df053e984d5499ee1d269602f645e5426934cbee9ab21caae27d76b9d598bc44006e21cf45aa768c839e79e953d6cbc90e14353dc131a5181bfe9a85e93eb3678025716053abc1aae505a1ed898d125c4ddd32d2eb77b91fdd98a0b7c58ceba965f4694a93a34b38cc18a9b9a005528ede48a571af6aab091e088fe75a83e4cb30b022a8c65003c18c676e3a48e7eb01be4db6ad201dc29d3672350b52733e43a2ae5f4f9c375a1be4a41f7b70301dd83c91cb89e41567478859b77eef375a52d7825059cf9d2cc84f3e9da7a6776fad0b9ef9c0686b07ccac0b74d92ac8077876edfa397d43677806dce2f28f040b90f18b0e20f56bb92860b3ab0d36f05c795888ad845f84e3a3cac534781f014f97033ae90d4574b186d9455762948499fe512ae12servicerootrootrootrootrootrootrootrootrootrootrootrootpdnsrootrootrootrootrootrootrootrootrootrootrootpdns-recursor-4.1.12-lp151.3.9.1.src.rpmconfig(pdns-recursor)pdns-recursorpdns-recursor(x86-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.14)(64bit)libc.so.6(GLIBC_2.15)(64bit)libc.so.6(GLIBC_2.16)(64bit)libc.so.6(GLIBC_2.17)(64bit)libc.so.6(GLIBC_2.2.5)(64bit)libc.so.6(GLIBC_2.3.2)(64bit)libc.so.6(GLIBC_2.3.4)(64bit)libc.so.6(GLIBC_2.4)(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)liblua5.3.so.5()(64bit)libm.so.6()(64bit)libm.so.6(GLIBC_2.2.5)(64bit)libnetsnmp.so.30()(64bit)libnetsnmpagent.so.30()(64bit)libprotobuf.so.15()(64bit)libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.2.5)(64bit)libpthread.so.0(GLIBC_2.3.4)(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/shlamb54 1602679948 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/3cc9ec284fb274608b1c42b49616e403-pdns-recursor.openSUSE_Leap_15.1_Updatedrpmxz5x86_64-suse-linuxASCII textELF 64-bit LSB shared object, x86-64, version 1 (GNU/Linux), dynamically linked, interpreter /lib64/l, BuildID[sha1]=275a29d7b9edc205bc189584469154f96d7f5af9, for GNU/Linux 3.2.0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/l, BuildID[sha1]=5f94419a6bc95fa7797d21aef5559b317239d620, for GNU/Linux 3.2.0, strippeddirectoryUTF-8 Unicode texttroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)**R3RR RRRR RRRR RRRR+R'R-R%R0R&R*R$R,R(R1R#R.R)R/R RRRR2R!RRRR"RRR RRR RR RRR RR.R*R(R1R#R/R)R"RRR {ˋ3"Qy8Asutf-8f07f970761503cfe1a2d5acb76078109cb6db72532904742ce93932db5c47d28?7zXZ !t/h]"k%Y60G`spk =+ߠML7ѣk ?N_08^ iU戢09☺U~L/5+KvOgz R$SG7m%n )Kzْo?A7ok]}[1 2>Y*~kNO* ދ D^sNA 4!*Rgt. Hԣlҝ o2-~O[ n|S`HzW W^eœlJ6M"j7w C:_hTG҂ztPhqVsPS9gR4砪.ĕۧϕs:9/(׌Nc@1AV(c>ch#xQc2\ԚtgbI s^hZȪt(+9mOzGFN*R@|neR6D6@z_TtyxFQNŽN^K!yI[fLBPYrwwh3.F}D@~Y72C0;G5d}թ82>>|10GF`4@ _nfPIx9B1g/[RglY%WQ2˫#$a Jw C #_ZgxZ*nUO$B3E\ Dzm꺱Z -PɖZ|\E՟H<76q< PLf&v;}Ԧel]>.M̤ƸgzQkŠG M%)1|`#]~\ƃbWgqR\";I; p0پet/\aJaAEBMz@+!Z4I $ aI*8c[93"1]z}Zvx:D^) 9$1.֦s%Fxأc0!P}/=I#đeݪU%4!-h΢%Yr~%\|YƺE9t7/ŵkg> _~Bqw;K%v88H,ZR󠋟j()d}Jfq0W}'9 `% U(M&P" Ώjqk_`I#,7BWzxL#D9)9 d(U#%֌ZÆ>ݗj]n 10̰qiHlӅN"o6DiV0BJ2/Z3}ߪ]Z4O$# 4Qakd7;EVd2bS g *jĥ dv ?9@'yRp5Ջp@YQe8Y) r:qȮ"n:x8v_׻Qnř ZP09nW ?npMSL^sߊ^_E[݋6/ґjc6É.^sg4F:s^_sKkF``-6g!! P=ƴvJ)S(Σ q W8o~KSM?$[(lc3W-c1jj42$ckA;)4GУ2Y xHuyWX4ݔ;IOPφ]&SLw!C^ς/o!^2dm"Þ[ '4nJH5 phf}gqDvYyY39瀒NPe`+ ڦ*AM!?ZSq%]C\ 6)֫F1]'"+U SzdK؜v'2,%͂U+#5q9Q)_<_ byLd5虘iY ~mӁ$rnZ@ұnzt?Ǡ[~U^?!T}Uk#^->HWk#z|ECo_w+j]]>Ϲҧ@| K%p_| 9bk7;gP.mY_ /w櫞]CDxjd]'H4\9V΋X!U9tg jYW]!pK"nkv ""W@bq= PԀ,vYpHxP$,ioy|e0cGXǂbxC&7*]Aߛu~w~!#%V7A)}PO얚4 Ԋ]c<ԂӾAv7S,i]}JzXv[vsKKYR!:{%O(i PQ&A 2R`d Mӂ>︐3[IֺW⫕Z¢voK6tF+5vN$EoN ė9=8Fz|_nZ0t_ai&A%jBYO .$ǥyd~~c%7l>KKQ! }yl fz=X+1ӛ9Q ; !sР0 :fL(rFkDXOR ] 'S9IkcօA҃4fyk\+9``/{]>ey-cwRvәar!O{5FǘS)1/׬ GVàԦ֓\"T 旯 H5;֎y X0P"˞i0s='02Dgqa "ijLuo7heHݙJ $hzHNöWQGn.m w7TcwۑW4lCem u͹{CYvRB+1U 5>ftnQX޳( ʻD@xbWoe(QeV“"a-vFW[ӑ)#M[x uK SJ{u@'~%]:d<9XD%@Y#bSjJo(̹@*/9 FzB=d[ʱT*G`>hĩE,FOJ+~z(`bg(=}^FB` ziNVfJZKLr#\HhT^dB@KNi`f[7 ZWQDʍA%fokb7,M߭n <ޘʷpS8Nj Q}R0ObA4|!\*KqYݏ -fDU-S[LQ@\](jMG^%R#b$ )''ZNJhR40 ޜp<tO[#/(~ Мwv5tyۍh~^]!{|~i(Y$Ey3!}&0CXOrDr?. \MT[˸$E(L7Z8C8@El̲¿*UOx:8 (\u . b_^[]0pV( P(  i}v%/HZUE̝uy_3 A`F^F IEu`ws _׌JĬxkS ܞ '2]*0%&UF:0Ԅ\i-})jC{27&- CYJpD*? :ro;*)=2<|]rZW`@R4['sd'ϥ̼v4avO^)_ ygɺ?w1ȴAURI׊|zӺp`H:-"Ě·F`3mGIe#{ ;6M"s9EpssT$55 okǹSXX;4FA$6k֮3&9(FN|G>vNFMHoH:NW*bK+VDr,Pμg"K,_4a`dU؆v脩5tr w((ПHWsNKپF1ɖ+tXND/]mqyawkt͂੢K DeE^WgBws$7 RVSKWAkJ{gɄ2&H"͠N+Sb88iMcu>n(iـ% P[/l U^c?{뭂4<(ü ;:QKjU25;"6[2C9J9%7`c\i4OH_,O<Ǐt5nN:UPyr-> F!k!G@0BNGi W4|I[Ĵx~py*繕Kż,6B[3,9:ݽbܱc\})`:c?KWY&F4k| 4KSm6IjqJ qZnj$o:b"ր"Zq-X'DЫ/(҆Zj CZ9hU\;<bJŽ_ {0D(hIFl~=P 9KWG8 .6^ru"\Yj;,H}pS(fPZ pI0 7@|Tb"?zDU|*$̗36ED#c<ͨ)6e0LRa|מ*4uμCQpD #CG3F3Ikd ]]`FZǣV@fTXk!$dĿqy6㸖˅RGꀹX4 ` ?DӨjKaHi0D= |+Х'iNH u@n,h X_\ ҞB;TSV:<1恨`xLڭv122 LLX+0iNQk+(w &2byx 6 vJ2BS(O@AHm fL UT]vf#`kP`Ԍh(|Ð`Qר#o">w)y!IkZ]^Mqj6 s(S£yk 4 c`Li1=;UI5/Mum!5EHw):Tqߪ洉'zXs^VvQgP/_kPpd-`&QT+hLШ1y y$:#~F 8QyV励P?Us/B)aI]t= YcDPfM!~Nhg[N-RE~ъ3EkX U \C_`" Δ@WdoK ~وm'JEGL q!Wqk(ۊ&%\`0~p5C+@oA5d@O)XB[)m%ItQgϤɖ(3?3rY[$0j+18TYkHw돆>$k 4ڦo?̛ w%!ȍkhbSe[\yb첳jiJe%~ޱu9$Ƚ>1.(̏2y4*o"uWr%qx^w++Dkt$Vs-/ػ C?D9f(e:[e#2l[ x 9|~Ԇʲq= fJeVv{0kdH_\xmfy DfߵP`: )i&.K.5(B\!TA2Ė"X]uDޙ,77ѫdV%#lqDkKcBQ+r .I4ɯ=movB>U |6?íMV+O4),ןl!T~tP8XX$>@9 \ӫ_|sS5iC!AXyj%(E^n4$}m|5ҙw7a##Evm_%{n 1gC_;rm53rh.ah#fAmZ{?z8JįkNbr=Dn3ŅL@O> DBW\{HeFUDeCyQ84FXpYÑV wY`WVq ˱;IA޳cITͧE`9fXhmRD Μz : 2)ݗGeA=zK:R,ٲz8qV rRmNt;r>KH+؋gM#b…1W@^fk`@Ffx  El>C~JURZ7K[3ֽ<."uhȐKz%.4O Y_oW;#zb~yVv];7Y&'Hoqa$2j#DŽo:`kf*ڵItpe&yJ H B VϱmmkB|j/ GJ\.t +Zׂ;dG"|iPlwUE ߇OhȻ/t3DޓƋZ* \;|P>O>֫$sKO7+:̥껬[y(d$Ɔv6:65! +i6(/BERqpTL>{S֒rN/, X0u_ۜXje vd-`To.Jݸәyy<[Z3SVC#_s+ly*eO-jY`#h@(-,U߹f,M [ԡɍ#j#?NB߈Pf ~FoXF.7cjVa}4252C%Xu 7A%^ 5vz04fApcٟNxV y}9F{*#I9^Fd*B؀eBic@0&}+hOk)j1Gj^ݫnL@sUna"2zݗ N͎tFj"J#_h zA:Iyo s$ ʒ1 2{ena7N,3$"sB:HI@-Kf+RՍ8z15;բW{N̘@2we!Nx#6V[Ptt=7-i8_(Ʌ{b}jRKNY=`2+c qew|]kVH3cq`γYqHڐ"o732IZ8xÖwz.1 {cn6.찖%^?k SH?vuCZWŸ"ѲZS,[[!O"~3FȌTn(.=FDJ zXϥcK slA߀6y^U)[>Q|N1P /yj HUKSʣ@_:ĘΩՋWqH%`L u% Ó]/NR5E($V_?Psxa6 VO;̺gn6RVOھA6}U)X2r{ Q2LLWY!W;?vP 78pers~d]ˢg݀^1GXe=!t| 0Eƚ\©USU To 8!eC*/&SnH7I!oD[z6RwLXXS: 2r"=hCqKȂGܧ:=F9ş%TلVzix Z(EjF ې_9-j]TtJlVRxʓd$56|mB͌ic]0sm1%TWQ:O'reyu% neaHY`nG/Wd+. L K%J :͆r AK WU"]w>(xܟ&)R"`6KY<@Nw193M4WІabEa*B{)yMS@ I[VAŰR>`eLzyCiJбGNFBkd(,`Zω,J_B |NN [9{gًP3hG;ïjr}%)b\9:b+2nosڿut;AiOCoV=ƾ5w]#zWAA%+p $;4 LA  |fQN^\XC ݜ 5HVAw-~SA<i8~Ml9§q~ymaf+R% xe %3"G fqf )iny`',xI۩s"3f+a/7%ZN 2{{%Kn[SLA٘cQlNXBDKvk7##_wm0ADAC>bﭕU95Κ4wDv L`mFBf?!l-7/*s?K\³QClă_7]GeF!8إSӂZ씮nO Y A&uʌ4",A+q5B<{@J g@ D}z]B)'*#I,p?0 bv$=rL$I3`Iw.2 $ /`gȅ9}"}t!r5XkXfM(\sTtDeC y!c Rp3fTPk@؁%*.6 t麹wR"'RK8t 8>6ʝݡY%2Ϥf{Ğd9@~}y霉dXC!!:`z&t-|[L) rri?QZȣkTp{+ReOŠ"S<@1fy PCpv~߇Bod?ɔ3F3UwdM@ 1&ċwa݋^ѫ(*{T|[i(]-@Xg9?zOSjH^rj]y7nlF6XQ#bm>xMӭ?J# l^$]cWJx1,>r-}w?YϠK|{$cZvDV'ց%py{6oٝi% -(F51MxR!Y̪iӽ\<@W<4nQFwi @/>L PKWGPc24XmÖasOpՎ]qX"Eh:b*I!qD 3X$WB_. 1ic!'`FzV_{f 1k9Q~@9"ãKzõ{X֖tm 4 S0XCFU4-7Z[MK%P@gKzq1=B~Mpy lASK=|`RpV>u}wud lTKFZU\ӷ*5g>!4{UW qQ>m:d;L05 O&rč0p{G"<ڙrA9kG]AcSRZ^ P=q Z7]Sk_`'NDAזWwoa4"0+X'6L2Q >[/# "C4 e$w9O`l)2'3m}X7/(Fu6>bѣ7 ݍ<lE*y?%2t\* V`MX3@!q@@+{JEu<BC2k_ݺUmL32OMO֞S8n\hF!4i`5%@p=D}fgma(?81Ue($y1rG;t$WhF Nu }Hdpp$ p: f+څ5а2P֙ 6g$骎z$QKrE6ě ٤w0߂bӧyQƳ}.|@3yR#oIkmm[ Ut[5–IJt˽代QM6:0TutzDZIC]BGs}VSWc%TZZa,72VUi1Ǝte~awB"ǣ|5MCi3" 8+D\sƈ)@OQ%kS@@L,XS*BuSýt0k^.r \WY#h9*uڍ 9ޓ>.(O0ju R b[tURuh޵4.[&z.VR?90cE`;sx9p\nB;:p#1^(1rz _N ;~|b1i +~str۵vO, ,7*pn'Gf[܀D"fE :/9]!ǚA]B)uxd׳.:>$aF;ov],CRWONcv?G ó͜%hy)7Xlpc_.M^.Bpi=兤HHlP z/2LZ)U)?OU]ӥI8E^+WJjsnS%" =1b"uѧE`I니H GȽ`etk6&4FI$mgz>e*]ϡX* -VN$3?9E 3*V9ž{274&}9ZV"vvKl ZHsKm ϑi.(FSkO챎%Iߐ~qDAKm}Ǒ n eրM[Va\&ҶBuuͰGɑ6ˉ' @k4KSMid,@nG<^i\Y0ԗ/[d.EQc&S JTh:>a%$<֮"{] 6?O\zVU& >rJWX6B|gw SS(PO&&'Dq#urAE0`ػ< mŭ}(ox>ּLAyr=faY!qa;JL12 Z%N3Z D]EEc>&fU`8qxզeH~C)ΈŲp1%Alv% (ږ l)@ ; CA2^ejc[+6Ӎ.v8(Nn5?-"`ƪKdM#ozXk :B7/ 8rsy͔By 2j_h9 D3k5Yo DB7K1d:$V|zG]氐J]m\U';&ΆXu获&^S ~S8|-7UcmZ@L׮;7B` IG ҙkSu|uxݖPPSڭڔ'{*s 5 xYм ۙ ^ ;hO;$(Ge)tnıvs}! H{33RQNrzNWRm6Y|<:A]nX㞾? aZ8Y2vۂ8PH|h*Ra<ҙ^V@Н"D'^|ϋ;]u ;}ԘeMR!MaeCW󺓸l*ed+lfP&qg$RY7Had Jk 4_ p_Sz撯^c:#ڊ1WQ!.L:HU+nYςs X"96D#8(0wfG+iMl|"PR@9r+L_,y+ DLS4kPa= nDŸ%Y@Z-L\6uKyWtSbR;}*P9vDWp{P& ̤QY*h`?GPuɣ\yQbk*#Wͬ 0@, 7t1ICE'$Ћ]_›/fRՃm5"@ hyb" [V ~v!I/ݎ9I?ފ-WmXMbhhimwf=[>o[2tXe9DهCdq4>?6cؾ1|VP?Ø Dzg'qHOȍB;R;<_ms $ ӗrc{ye}l@PkB<8V"DUt:+~KDĂ ՓOj'p%Q2hy ࣧz>myآXWвCVm.~ޟ]o)ɏ6N*o]`-|00q 3Wr^rPI^[+}/Zs$8/po l R`.aqꤖAzPWct\X!BF'ۂM|+,aޥF 6%x6V;y "-nn>l=mVzn`|UG&u(ל*tV&)'ML-L?T ܡs>G 4Z1uSނ9Od5uB%uf;ё6 'gU/EV5P4qə\f!h›>JgW/]zJEM>O:/4aUlG" zJKCeAngAKkцZx'cl]>ORb|ڦČUPDD`PNQg%qEI u1x4 4j>JY)3% 'ԎՇ\ vppOj#w1Dn?(HaHe L4?j}1C7l.0 MCZ 4 SkYNx&T_~nf\U;PrlURyi8b񓜴_14[?eG<5 {<R3Q!V >>0IՊpS|d+QXVn^=>X" 9jB;sWhڔN !CȣWn֛8J); r6+TkH)GfBv\ڕaSchv,6;,eJt##T5r*VwG Bn/ w]l(QܐJͬ!z,twT}DyBTa<9v>>QfW&<٭BԩR`H~fE*NN/"9`a0c6:3Fv`a˓0n,f0;8_].L魔 9 O# ^/M8]@g1*C٧?7R)7Sh,I6}Weo#VK,ޖcr$Gu'B1 v iN l4= 9VtXXI'10\9>"`ӢhH q&wDn2 $:FΩX#Xӝ x=+@L L[g$FerK!!cPUkV>;hR;1rZ?QK}Sf_лJ6!kJ ["ZB:P{e!qѶIFRW>j2`9@S'B_htj̈&r 3dPy%oFI*_笃2wNSAX&0FFJ*/p?y4ߝWm𾴷v,/NX62DT2P;-@6U:nE`vh{_P/}-5}A!yccc$6{4܃UJ-UM;UxhBg88uヒ)xͶ> Zkkue?#ִI)?;H3$[܈*,&1q;T>֔OlAǛcp(B$nQ0>!Vrpҿ15&y*`Q·c1T'io˯R9й6"BSXOPEZcW||THceݷ-l*1 6ȞoR3f߯Q%O@S{ʸ9 $'=H!8(pL1x 1-`"`z0aC &H!>"<>,ӣR]ףZwE65e3c0?cB5xl#'" }2ÊrC!t*j' JeL{LqdOSOrIutRao)+]k=r-5Ou*LW¯եWaz(Q%>Vn8o5IyA_jӌX) a%#H 0FyB=h>dvm8jp.^ͧyEy1 )]9=ƣMC!0)т$t?+ДU[Jh%hhaCP5)ӧz2_%m u=*L.3!'JlK]8~t (zdzT{x`; aS/` bWEz8XM*X,egku#1psA8~Y]לi:QS)hdNoh6렦=H h͟kӪC)rδipԉVXSut(MvqY|vP{yV98v=0#Hg!T|@+b w y}G+qBVa;|NRqL_Zӵ3xqm'^8I硋aNG?8mWH)A[06Z|)`q)ʝVL ˜%-SJnN~JUL F@El\9rѓmEo%J}% F{i~M^OJ6{(Q !?F}Z;ډUUHvȼ&[n:$pHv?PTn?(-npʨͫ6bGwGz:C 4@p3mL2_i}iv:I5$8 ×̳ {)XmzG&{$2\]ˋfE \5#v0w{-/n|-8ҧ¹^'(]>'w$IjRa:g1hhvbg#oKy>!\Xfm#۰y녏#>{ Lwyjv'.3;:m6y%3Exor@2"XUd %Q#[ IJ<3%VyOWp()ZP' B12o}^k+8a^*vXBjȣt(e$Yn dȍhNWm e ?FM:޲p5 Xx.t݀I9b@J>e\otઽԹ5F@({!a o}} Td[UB0 4%@⏈/\>= ƒ\ + l C`iv:#9.t7Zi2S3z} H$I#MLeH_1}Zuv!Y. P7Sj1'F(-(1%gèLwͯ אE#?+oiWO+e"e|-*A NIE`Ln;떘A4މ(9s;~,m|,[ж*n.(g:~zLq혼ap7GS2͞",p2|) z'Šomp:@+{)XCu|i}_# dU&7q)j S-wTꂧ[Rɲgp'`sBʥMB(w\?TlIt?ժC.V?X˱UinTvF J=4 Hh44 VgbKoӦY\QG+.'.!ez MZ43;r´ J??\4=1Jtb69zEڊb rP!TãfH2Bzq]cRsΐ0U{W{Vg#9eW$ c `ڏW+9z,}ŗ ) b(~[VYX=<}҂ IH6pF(Ab*Ƣ2[htt% 15gS6R&F|*7z3B|/P"̘o1ሖ@Kfn-x"Fy3/~v[g<{,E<GlyJ~qk?m x1%8+#t 7`s9n^ A`Ц5)A] [)j|no -1ZJ}4ޭHbv͹@{ϕ1oˬs\c#5Ƅi {_"'P"'(x1ocHm) Jh^H˫q>`9L ^SS,Xݼ0 >]p`BP#Uϲ@OgRQƔl_W8⚔;Ukp:Q*gJ&za2!\ '<< RW1lnݱ晓yV-GR@V?sQC$I%RVysKxlGje"ik4v]qŻqOm?\` W^v 4%TbvT3^`īr n "hn.CA}fP^H 'Njނq6d.yw!{{ťu+rKj0m 2n3nMf$UݵuBc53VgqXg; &Ǚ~10ڝ$sѮ!Šv"Y"3S%'dJLeQ,Hcd FX;)rne'֘eɃAam(s]8Vx?;t#w{n/-/= :.³0Xm[&w`X%P vPwBv$W5n'}2ηSړY6UK^'x;$WɊ7<(%h UxISOs̟ߗ~MdoNeg7@  aWj,M3\UR "5)_ ?Tm(U<\MTM9vfsTapS!XAȐ~gXX8rӿ3`Y>.?8 #Oj)~la'n̗sic9>sͥhᰶ 0~/J\VGoL)^$?k'eЕֵi9 cO+\xY@q0w޻uZ!>|Aij>jc?7[+a}X3lVNcיȉqh7)3b }OWI(azX2g*{MV3NJ2, NE2]yeyLD?sGx.տܖD6K1 T* 0  +XǛ8i `WQf嚴'*WޯPlѳJ‚j!p{j1A9Ѱ(,jh7iEEWmdDk%nQL9 +=ARLĸ4P ϡBzJ<5W 9`'#*Q 9?وuEg]w͒?\W_);%LÈ`l+6 {Ӊ;ye߃6j u W8bo c$= jWdQRvF4_M5z8kUHDMw@j_ُ̿腀 3C%acy*S P.zDZoX3a6LzO'O>Γs6_zh~܊7vv1UamsQI](h/".+cDQ8ps3oSޥ#{ }x=ɮ~jzL)q_r.bzf&b8ƩYG`r; l)D }Xz8dsL& +6xvk²:Gel=~M6CZm":spTp۫;D xѲ#~yIru}ڥZmVG:)-ޔS" T(׭z˔ h=sQY 1G u3T Ka/q L/Crv"*6o9lVEY=X`F3; Er4U3]l;2)w_ sƣH9N3^BP2б_WseI ;+>KeOރ7ءk):t{7Bڛ竞s7;*<5]056yWk!gj0<%zuyt0)%۝+f jHyu-M/_oa`(IW9i뾿zYFm3onpʲKOS&CRl@qpHrIT$G7nH*., #o٭o=q0ߛ$n" YzT3 "ݚiZ'3 ,3 ＀1(h\7L sG^Je^N!u"̇K$M@Z,̪T.@<%~X&?ɮKOiv|Gؙj4P:n`.+:ZƯ~q|!g$!$s+!ۆ뚈QmӀ߮wg^FGw#( GeW(I=?e̳.8< 卫pFqu{A#W@emЩ7nTuo)`]%\<`yS>*^GTǹu.: =4J6#icV@j1Gw08zǕ C\`c됝*]jL_ȜH~Ot G^{ˀ'ԣzRG}ƠT3ׁ<C^ MJv:0#Ms0iRCdy; c7[TEy] 0w0d2|162^F(ɍG1E%%.l a#k듒."M2hNqo'|@0=óept3uF?H@oTW\9x oI`dty EW#Z GM$\A>%YKAnXp\ǡ@ vRb U"Q吮RboTCY& OVzE*qL i3| tt"mraqyO1.`L8KRxZ̾=t_'7~]6oݍq/GCj^֬ &bcZNexUkyΓaE6 }bZ/7/QMKsۘNǕmASRyPQelFͲ6Ľ ^YMl32-2PI| Yfiz 4 WF{(gB\Hf9ą8:@,M_.z$   1\K;A:NXOS)Gnb#iыP[ (CY"j)Q^ ! tgޕ -J*? EU} \2k7qHΝiO*EqB`Bnx*媃еBjZ`Q@57!ܻzKRi=Ǟ rL ~'2R$l L[pf=CSgEk\U|ܣ߄gç*|]~!yЙ)}壂v%fY4tᓆrPr39Wb{UNF8t~x3xw emaAPzOes$*"wK1yNG0nJ\һlP<So ];e \ *?RMY2% g4a AԚҕ2BjM|xpZשvp:Ã̟qI5])Q?q&4L֗R1`v&$Kbvco'O'ebP~(pWJλȼW~;DL& qP`{֍r$ɼ~I)΂n`6ԅwЅ]Oe.H{ ?o;,,"DʘbO:{jmyE8x t ͯPwEGtGWX=N)A)*.@J!{c [CeD_A6$֎sR4ifmۑ$n7Jf |g<7{Y&vvNX%1*Td1 1G/k[7ۿ%aWZaٗg2%40!A,.;vt[chvÕmW3_q9}~ TGy2fT&alNQm JV$~zEVbgtN܋Fj^W )k[NIyTQ˩TOjOt{D<\tX0zN@ D)J‰v*nU*!.",Z]Dſ\*ZBxFFYm ;S%[(kwHNj85_ }9-vB )5ز>,i0&' <݁9yqZQgw*m6˲6A+[OG /u"6^;}>18g'DA{{9ʊ_EOL;3J rU8hSc.NbW-b2< t6%IPJmX@>_M3u׌v`+<>_3._q0e]"ˉ駈h8Y OØZw$7gɖP;&M )08GJ1@9$FPh[_9 yE I܊uh':?bey7_XR~M̨1j+#S Ԋ1m);x}fcJ[Y2%d˟45EvO$\r玜q([#'X!C%56/>N0;`>0esSƬ9Yo妦}HD||%V3ԶC~DD.ZɰnHy+^kQ ttGىgP{5ݑffJ =Vť&>|qC='Wp=·)AK˕zo@~|l&Xӡ#sRtnu2$x{^>C@ܩ4鐸p^[Ie2s8iʁaҸ({p ^z+9Ү:: GoC5Z.Uw^{d},cTl 4Eıdm^gC9w,|ܟ˦k<~[!/7aSW'u0sEX^,Sul3,3ЖPgG.;肻Š%ac,BP JB\7>'csJe⦖:eg.pLPy5܍CN8YIǏyS.AMc3E>` ԽQ^ "Jh@LTvE[29[eKm!H*$_9C5 a|H$k(ޱwغ{r~4' ^U9S;9Hi8|&Q[n̝OrE<+ü;B'ytѺESӨԞeE?8 d}PcH{WжBBy?HGWڥ@([L$g7V E.øO׀#[Q\Qݯ HSMƥDlpx|v";4|e]_r-0y֐gӲϠpz[74laJ>ɩ}ArUlaI\ӱj̾Ey^}^nGqc WO hk@1 yj )BfJ 8͚Q9 + X xՊ)S~.|A7 -Vo =`u{CTkL `$ 4i4]x=PL\L&ڎ[2C=MV^a! ݪG!8 KRKlo0E i+PՅԺx[Jۀ*MVqZ EK8--])6p`E{GƽT5\I`o'dzuP@N7@bqJ8[E?`WRlGHG*pФ6k$sA{Zns'32#u,^)J0;>zO)i355e]*yə[YLVo=T=)~mAͤ~Z7L{C-AEm9"po;hX;,^_t dY*ojuXHq5(I#hJIOC.bvx1Yx2/ChTI*вgy(O +K5zr.mm=OlOG!u+mM8!V{Q75L&u4vl ?]I߉|̟jW34fp63OmAx'! S3 bH[Ք7бlz3M; pt{SOW)Ygy.X)4&5ߊHA?ܴ?׵5%85a'go:wg Y78ˤJ_ iCt?8A%$mi /K6 j|2K 6ٍ [ N} 90Q#`70DJ#N|H8)ǙH*;"$ƊVr`h䓲+e,hrf@Qa@W{:d.orFJ+GNdG._8{/I|󔻭&sG8%Ta* P؆$2k1Zw_j(h e # tW6FĀ{ěR( BEd~DD7O7*ޢiHee:{$@#o@Ρ)G;ٕ?B.[/KgV/-Y&@M;6p$k{փ~=uҗ𯑟d#I#ELH(~)C}] 7!C; UNhnyR{!ZZ\С`` 3_T7{~LV=,0;lg|Wp!(?| `5XH,;A8@+kNMaED%;b#3ۉeD{23`{,ج (zϷڿ D6}rg6})IxJyJ46z<=\t2T`+aWvm{'5\=2 D_L;Ո":?mg:u5,zv3+0ak޻Vb&K h)=Dk :IRl}X5d/KLȔv[! u6)9bV7='NUrtUtCOrf1l[o.>fVqp-V%V:FÝ~Yz-wJpFhX VIwl6nd^{zk\a+uF_R 9W)0WN]i&U|_*# (Mŗ%|i ə~5wrI3Pu'%&^QT>$RuzػF{-оMḅd {OJV5ɾ5-vs4K-W' &_eq5'= JC=)D(qsdWt]}~)zw9ąVk:dʕVWֱp7 eFw^%P^Nf ] s-Yv1*^:PA5Ҩě%b_қD aUq̗4Qif) YHg(He|1#@ft^ѬV+5`*Po|AC`6#%ZKG[wE13FYK4GPjf6Uo˼1c#GჅ)N^vؖJ]<Ҏ@9ߛj;[R^z~Ȳ&\WA7Xm;7+3۾j/pII`i _3JrO|:=(”VRIG8%ͮC9Җ浞kа/$wzs)^rEݍmeEp?YGVipĊņ&-9Jys€f"c.jFLRdV?zWƃp'>[6>qQcXq_e-sϳ?SL*2+ᔕ-is!AY0gvFE4tpS M9 ْ+ X51/PYl0Am|Z9h oC>6Z^ŎTVbPO^q2gҔrXWe#- s31g^,OfbgwUMڡkVA睒cƤ6Y¿^;9+pDG G jS.!ʥbڧ,ǀ\˞P.UQRkJutƉ:9j"K)Y)|P嚯 -0jI2?f"ʡdN! |eCz[gS tgՍN4,12J6x!̆GtL1Cy11$_#!*u10[:lrI fQ %eth.pobgeO!ӌ&hLOn/_Dy&E~VOj.E/0iPs-+TON Z"F3F3WkzXxAV<ԄW"6-OP ![{nc *T T~6Lloo/Y V-))҉_*̱s!A6f%oaކtpU܇p;qrQsB^$1a| lW-C'WliNy;Ns"gԤdPN9u ZA$si9