pdns-recursor-4.1.12-lp151.3.9.1<>,BD_ĸ/=„/p7eKWYRl4uˁ=3(c572hX?Y"LL]d喦K8qSqGR%HG^tj%mb9i͂@.|{*ÚnP}gNd3aEA^ y( hINyE3_k \c ł% *cH,&]j*ZtD7!emƼwCuZsune;gx11>Fw?wd # p ,0CL] v!  \         x     4` ::O:(8*9d*:*=p6>p>?pF@pNFpVGpl Hp Ip XpYp\q ]qP ^r brcs6dsesfslsus vt wv$ xvT yv5zwXwhwlwrwCpdns-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_armbuild24copenSUSE Leap 15.1openSUSEGPL-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 [ "$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큤_j_i_i_i____\9\9_i_i8982fb8cb72ebf187fd67438f35019589c19544a34ba2eb57a0c76948df053e984d5499ee1d269602f645e5426934cbee9ab21caae27d76b9d598bc44006e21cf45aa768c839e79e953d6cbc90e14353dc131a5181bfe9a85e93eb3678025716053abc1aae505a1ed898d125c4ddd32d2eb77b91fdd98a0b7c58ceba965f469420a6813f6ceecaa628b81031226a52aa773d9ee5e04f088f9b636aa86a7a5eb35ca5d75fd34f04966b55439f3a0f37406f3a8fce3e23d17b9fe605f7e534bc9ff9c375a1be4a41f7b70301dd83c91cb89e41567478859b77eef375a52d7825059cf9d2cc84f3e9da7a6776fad0b9ef9c0686b07ccac0b74d92ac8077876edfa397d43677806dce2f28f040b90f18b0e20f56bb92860b3ab0d36f05c795888ad845f84e3a3cac534781f014f97033ae90d4574b186d9455762948499fe512ae12servicerootrootrootrootrootrootrootrootrootrootrootrootpdnsrootrootrootrootrootrootrootrootrootrootrootpdns-recursor-4.1.12-lp151.3.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-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/sharmbuild24 1602681540 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_Updatedrpmxz5aarch64-suse-linuxASCII textELF 64-bit LSB shared object, ARM aarch64, version 1 (GNU/Linux), dynamically linked, interpreter /lib/ld-, BuildID[sha1]=0a7611887e88f42d3cf2387b7714b3534f37c063, for GNU/Linux 3.7.0, strippedELF 64-bit LSB shared object, ARM aarch64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-, BuildID[sha1]=4bcc85ed329fb569d537586eb0b6be233ef36732, 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 &^Cv7^jutf-8db3a53044d5a3fc172e98e6bcbf81cf6d5afea6510de3871568ab60e4b96fc59?7zXZ !t/ jű]"k%Y60G`spk =+ߠML7ѣk ;s*s,H7k,ɔTEM`k<󪱙+OW DNLin^yǡ. kÁ]b{E]UC\I2hT5 t:l|̵XC}嶿W1ɀ=H G)Yxy["75h=K0h՛H#XooяX[i$Q$rC.:=nW3'?{puBeMm,遻0Wܦ6wÚ6HK}=<`I/:Q0b)[|zj&㣪dNenBU{T"m0bhR̘-ԺؠA0(^sW]a2:ovRvUt})q]Dc=,RPLYֶR&yt=.uAP!v6# QpgE/ N9##^FBh]tgajv4m7:pSǩsXtlV _={Ԋ ]U*> OI^<kٌ(pp ^g݀8 _sZcd~B$.tW8?[yzY  |:XL.9[xFB2?9T{T?F`;zV<[anI ,Mm#>(Ql3{3GsWAӰΔ7=>*¿/ ^8KZV[$}?FcO`t1}樂vLA9 ;uѥ9R>aC- *4RR;i"/k^pFQJdd'-F<;nG@?XL@ZfA;hW& OSZۺO(M9E!J]LtX;-Bai<14 /yƢcx~X{^Qϻ ~M#ZX*jۋI>lG$^E :$*rEN5 eEr6JOrS4HYi,slh5Rا^ - ;kao|ݟ2Bꛂ6Ӂ_#*[aLq[0ѽNS|~U_Kn u?om /Zgn2l~3-!8A^GX0%Be(w&2;<1/#sj 0Y69oV;i,_{k܂qw]$(d"hm &8䨘4YtRh)twG2NTNptvCI0_oǐGY#?!<&9?ю$f,~{nXGv&9'?bG@1s05F%ẗjډ48CtNW#15r[#|kD?dH":Dv)jω,SzFOۊed@W[\:5~./,$31M,e[+e6S)$c9O_)w8?#UoFF7yҒ"H! eFYTb`p5:eYV &m3RkU5Ws(.A䃔R xxczӥQp7"y}l(3>dG&T'\(֯K@,l;|AЋ*($ T@323SS'&~\ݤ D_MSRL2ߧ^k]]@%6w51Ù#LJS$ONiS3p̿Yr_50o2-ʵ>ƛo&˴kLjJU$Tygy#o(~!Jٮ#%hoja2)Bi^D`q F_pq6L +VH?ly[BUrJ oN<醦ߒ c[*]ȥ?/aQͰ),Xq}0ľMSZqS7-q l:"4}=%2. WOSJz2b&fJ=;] }6YF(_ /L.B_ŵ'_BZ} 7ۥZ6O!̒e叀V<]O`0<( KUM9^]ph| fEDhap|N-\@f H*cxnūz=t+pZwX,ycs 뉜Z 띙#Ք2FgI{n1J;^͉j29h$-|ȜBlUnoRQiŭO2y:XrU ef&uzo ׂ0ۿN{B?)ŸP"Y߿lb_P`M1ze!=|&PR~UfTs Gr ˚BuvfZSBEgZ#`ӊQ3!O'bVoefaZDד dQ|"s%bڤa&H`t8'zp_­4d㼦32kLO YO""-,q2o]Q9No OP^olQpt@ 6X%,řqX5ݕy7u| %>aEz$,%zT22d_%=3[ zVEP ]Nޣ}m 싉JHm@S!0!if3hf%+&=/Y~ޔ,&?a;#E .5߿="**1]HC6]vmh5%ٛ6 _ob6cK_Q*a$VQ0rURccR9G!t>iZpɨG%v@8-ܪw\V'5~$ |1v@`uizb5ݵvYC8Ufi󐶷&Hn{PQur/ם\bC]vgj(t:FQ{TJejPy*m7ש3P.:ax >)" LIHʟfLF=,4xdM"L:f _q$;yyo 5oxݠ !WĞIQL :(^>*WEڌ9XK|oK)(j>J+rJ3[7_Yے?ë˽5Bl:'J ]b :AY BK+#hָBy¥|u*;PAۛJ/ +#Kd-FaCSwAJQHwD?d#Im'y}ԧ{<(h>.t[<'V@32<4OkB={sقmYBGxZRShYֲy6pRwT@=BV='yEӬL %Z3?94Ъ dGL%O)'*Ndy`í"p{(@-rg8gK(REUeH=$NB Ayct2]k%4VVKvyGiSZtVEMǤ/l|\᪷[.2^&O S~함U$J%kj5YWN4E7&vR#)`K'M;+r ]̶43H$RQ /Ce\Z2OiCU XL`f HLps`uc]p >4)!=D~K ]Gipy#Sq=5=TR<{Cu<y@ziJ2YFq mլsq0n-ZeAէV{Y %JmQ57"ȪT f_j )>l2q%rH O3lt<%G14\|a>9 Z?XJ>pvMT9~m:GV x.sCgȶ5[H\x? 82ZR7j]ae~!u1jOPBFBpցSr!6,T499|1c02!܎mSK1n8K025y1mEaWa\2y~ n*ay3fQ޺FrWtgRͼJt.wTD OvA-ǞH>ez}b lWJz pMW<lUcW\xbM)4NX?(B,{0LGŻoF=FIV4>k؟}z6k}яt/QӯWXn0QpN!~%70߭40Ye(tHcuWQ{)?LgKUFO%vTF@.a>Ph4 k!;ڔݾ+|̓wbz`_k.ZJ~F[ clF}O %TBsʚXH|Xĥ%X(fȗg{7ZIv`^e-+Fxo Va0)Ff½/8YIGlW`3τd)O*'zZ;Yi@H e6i~&PzrtwҼߒ} F:3mCEо%n0!=kv (5t8i}@.0R͋7Z3R^2멡."5a/sPQңVQQڛ {JX5G-f!Eܗ@:'L48Χog[Nr!vlV8Qzֱ$z.ͽWM-,nhIݢ7paUK^ 1E) M?Ȓ{+لX3-gY2Z\G6(sE(׻lmYC:?`Ag [;5WB`v:)4W߶@'X72Z:^BV ^H>Ycb1K}qrqS[mGp: 08A{ k>'ﴱe}qh"+AF'T ve@M$CȘE@;-%/8o7L'7kfP5"x*o$J&2j$Wn8( NJLK/&8Qk~H)|nagpsW 2kIx4oz+"O>xRLՔqURw6 hHeŵbR0bƧ/+ցĨ4-Ah>Ӎ,s-dN*o2QjCk33 gՇo7J;*cV)i\êp["Z꿉O |sq\hc \`5cų/A?@ŵ9Cs.`Xߓeu?Ңn|!.YeC 9MzBP4v?nh"#Q7/HՊ8 ">ϛ5 ߮Y7t%$yST7,'ٓ[)I>j3R?\,)\؆mtT 6:|eރ !4BY! xdԳ1崴{| ӑ| _v&Catۿ+ "|Fvq=ov5i g#5aB~'ư啛بsRN.t]~Nė14 ˠC HA nM (PyIwMSX/8PM?ɱ($'{tbץ݊rZu}wk%Й?O_x|ܗrzUėz0grOmX:t-54q:wXшY-ڳto^|X`Ԋ ^g9mV` sn݅^# Xpv3z2WF,AC)hmGjS4QK2wwC֏4wل@3RL.r{!t4w̺]=l&6{'S3=~#oL,8 eAs#dž Uuq t?뱏5Bmc;d!O W΀-/,5̟ѩ,$q={aβ'{㿟v9(h:ُwoL4hAi-rWw6_-Ct *XMŭAL˭/6.gM};0K\]ͳesX8Qϻ1gQU,ĥ aԳ*կ?=j}"uy!I_]rx*eƭM^8&2DB-i(^ʶYIR,=`wq;4\6"j]8|F" FOAl)/Gto"VN-6&?EN;/"=WPQ-5tpZAHNBqlG 5Q[noGNVʆ9ءh,TG$PEp<&$pX|y;r'QG:gy0M͍E.sja9I&49&}GOhKGQ[l% D<ׯSA}8l32YxT!iH[퇙8TzeN| U.a{a*taC+ߥDdM>4p1(A7 nK^W3b}ÄOa;e۳c>en[:;d1)\_zNQT!۪l#ŗK2MoӠgi.*,P1ug e(cNB.@F(޵ϋUҡ9/͝(ܪҮgO`^[jtQ%+2vzZ`5p˪+zk{6Cl$H0fv#ֶS7=uݲI=u= <ں f~\Pz`ZHs(:Ӭpdի =9^X/t K~Sܝqyj,y\z?\.fA:m=wsRBR07@USy5{}èC?hd#dl#׵XV޹tH8bF\;;e⹿9WvQv$*xu;2xɟ+bӬd/'@g5|jXvi,<ޒH`(AKitFw"\^Fc+x)ΐ` *P6  pC h'ԫUp"ϝ;'$e1*4hkIPڐkctKcˋlmGg؞_l%gVjKχTuJ(=dޱ 8roR_k"uVW yk/0r-M%M)~#@%7.Nnc7w`@x5ENU1!IB'ak )=) ۭ^V-Sq~_,}q툘ѿrO6X8=+0- ց?Uťz"KĬƷx/^#/խ%`^U@QE+9kx ssWxlɥDLy D"PPtۊ&o?Ӝ֤=@OL4uҌ 24Ćͥ#D6٪f_5&YNh.&LӶ>x NG=&&PnQ@e, ,' Y|z} DO s _DlS~uaLz2 4k"36"/q/$xEszk.8-?ɨu8PD̙(wF*ůJ=S̄TkP ~`*T:h̋vKdaFaVlGy}AfCT|Uti4՟>ouo[za^fS3 `H!3pn;Ş%2v䷞B ~2GW/`t4dNZTRbM9r).uɌ s>PK^9ƓZe2 sݕA |7[~[(;OeRCŀ$Eas{Lz>3IBJ0[= xZ…x) ̌-2wFO-)mH_F+e6Hx`9EE9!l/}T=g&8ouGPSSTa))$4Mx Lk,|nQ0wbo!Hȏ:ŊHzgWV!TŨﰑ9@LßaLw} qߴ*$uO>vA~q3K NDx4_; `ӹ>2,@MMW ׵Nso^ ;(ӰA2]5oK K򕑧 CiKߘ0s9߲H0:߈A|bZ Tf(z܍HTf@&Tѻ62$:5^|~=K3 eđgpCm D;*>[]z:.&O@D0EwIXXIӴjeiqC S} ]A8q$ǃ7t0u\f17N "DFLSF!F?Q|a~>_obyBnA(@YG+S[NUQb[9bs ;tb҂6\IBEBI5 )\ـC\Jb{ o|SI&~%q"/I]̇;z(qˑؼ[td$:}I++6\muz t?x;f~C?YtAoDCsK 2D&>䁳U`ץͱNT/O]^ T0eAyg$^F+sCb[uvvzC;p wfEgN$; B5E[VdYW'x+|@?:6F' <]ZP_/Ec@B4}X\V1*hjMp3<)pF .GsE}ZaG\F;&" anbޏ&֊g¿\>?CBJ ܼMI9Q}/ɎA_#HI>X$$؞Ew=QlyзHfM^I>P^@[,g!&X>"Hֳq_^b-϶LD0ʣп gzмҥ0۞0RUsMZeXR7Ea礞˅D=o9#Y5X@jP ,ܡbtw yL91m57; *YkUWwVw^] _m vすRi.MQ:>{ .D7[:C#4Ȭ@km fZ 7%?^.ޭ%"KSZ@C|\:A9 ,s1fW8Z%!@N^I."Ogg aOAW83#G4 +J͆sZDYƩ CϾW8N!TG#@#VA,td2L{y6n,^m& _z5a}Ee8)Pm|wj&xi3oMbt?@ԫ/z I.FgELSZY`_ nÛaˤ>m̞Pl'B ?k3'I C8 i"av{D~|N-f~v9kF=0:C1~YNH&KQٴx ܃]N|(NDc/+!dw޺)Ғ3\8=%Vhr.&xiZ֛aE.`L)79|mTYFoxZ+R0$w7\q$x6 jq-=Phpx'K5 o"Jwf>A`У"BO5gP}uߋt㣖bc困&0g_eHbs{d<9^^-q,$}y Q3 ) g8 g܋ƾ\zci&-*Qz9}OR>dh*<] =%0%Bg>KrCsQ1C â}G1L 41O}'pFI[{VE:8cI :'׶k[ >py[%uo&4ݏB<6TpRµ[۷WR־-CCy~D8??d@˲BSx\p. 'bwIxW3?Q%=O dc'R.|(mڲ M܉KTUe>ggmTyqZOݰۀJ 9}z2Lj ;3yLFl+N7[V;v*+.fr J[)8Chﱽ#lŴH[#hГ`)XSoE6nRðjs 96Iaj76|t3]6=.<0ݵس-Mw2Ηڿ>b9iU&({7.z{ S2p;8u t'أwFÞX(ڳFL6R<o-lL6+ R<o rM雦.#?>{4VAU7cCC%>xqa[g| _ SLF3>8p=HVzolp(4`iz#m8J(LJs;0) ,]g ZG$.?̘mh x!8F*pk,Ti6܊1:UO_-P(;f{m!F@ xCTfRz%]F#v3 ?+i+kp;5 UEsV}0d{NKnľx셑+fɛ%G~t(3)PV'WC^VUhvU0^btO⸡4$jn`."g4Ytڥ]#5m]W/:@wԞ y=5 LHl.SxT(8} b`k,nRh5g"| x{ϤjJvΰeA!͂BMG*tտ 5tރC`vrʁH}yN=Ѯ .Nq7#B\蕩]ZPI|e~r{ov zDl#EzӘbmXgzHIm#";u~\L_Q<Up(BI՛k8QG;9xEWiK!F̒ :>ݗ@}X,HZ,! 5FJ.Noy:pߣ%w%>7kC06}E5v ,/?rSe)gk}i (DI8;"H35(cy#^DczgE7 ّߎ -(,҉$qG¼n ~#=I5peïPo8Ɛ4I A\ {/<M+ҷQ+);<&\$5^)5A5ZsI P -U90\ew1VpfiV^Hq _P_Vw] ( ףY5'NXcm^ܼ@lp2ހ7. eci'Hn9py cY"&+Iyd@Ҋ]$jC(>)"uL 2KB &{SD K[Z?Iff 2ZErCz!2/^.+pjTdMjM[ j|(tYoQ Q߿;tNOQ_r`Vk&;e&<1h?ʑb㘟 @%T˶LܛX7ȤGںV@FfQFWxY6j;a'N":Ưx0lTz|"¿hɬHK\ pc}*]xSgtD*St~!{$t @a;i!Eȴ9*GSyS91IRgyrRأ 7]&uq$&9/[O[6ofd,%>$E8bZ'+Q`QځjD7>]-_&(SKC ӫupR#Ur `GQ%틋tUwrAF -R R, U~8A~8,P*+-O_ q4׹n$OAU 56Y K)$ΗXZ-3Q#"mְ6 uS0{ - *[y+eBK ԰Tހk&g)UqmVj"( \kiHE HKe !C?tBiw ,IgG=Ij*zT8E3֖ZF&@}$яJ*4CaȮ}ާ`PSܩV٤R^ZΜ O;זVrC( ]M`4=N'aAih߾Tc9ꞩZs]! 'ȑtP]^xb~/7?kh%p Q-MD*p:+Ѥ toFsQĶa*"@ d7:%V{kE0L.|_fќBǀK#T{ӳ,sk0G|^4ykaq=9+M(mdi@rR>hwlEhNE{6f/[?+uWPa'͂F=s _R+h;ZPf@G>\ _B.k*d#$>T|ZE:keA18ղ#j^'; d 6XӿZ'B7`|g\W%tL^ -6Bj%J >9k yM :Y+1y`7shqsɅ끣{i;YUC 6.ޛ!ɫ& 8l?TPƻnA3Mj'SR@$8F OC4.~XàUW~Bh?gZ^Ts=Ùwē ('{#x@{c* J6"6ſt%u0Mw(4MW󊒊hb-NoyU{?<Ō鑽H1JP6X:k&-8AIݝK OlZfHMA|_e]CZLfDJDV8qC__U,鈋1"ʜh!7'ܳí|P] _2[ss|HeB_nH$gRbbihG0eK_I}U/>=V)no\6uln zB$/y;=͛җ]KA"H8pvYx ;sœX)' fëcP^|gFБi3sQ@ȧE&LݑK,90rθj$!JR(6^bI  FMs@_9,ǗnYى]CIے?e]|sg=?όf "\`s *n~^K|W/s4,}W #kL1c<2{qҝAx)d}}B_To~V? &U鴂MCf#jO+Za|;ۡ Eqn,mgQ%Ʋ}.d=R>k4 QsՈf?\iH 3-WCgO~{k;K"A{&0U)]isj"=~/ ^/C 'Ŵ$&#JCm7d .~g8`u=E,V}ȹH q8x/ &ШzaݫZՓ'>X3jsI93s 2@sE"ȤT¬h6۩9FCkfV (Yl(KDCohzْѥ:G$)ssᲥWxROނK*zEyݦ$nxX+~Z#Bl82>bp!?X9xhhl$qUj&۫ȴfhg D'oׇ:RDU7E3qIX' O<}l8`=-bI\}gnj*f.Pk>q`M# ko =7C@#NV54FV }ӻFhi'WAp\+&*}0U|@ xQY_8 Y&hޞYF(dӼb oo4GPDLGJ}o)1_k}\sv'D!5קEx ~xv 5.շ/;1\*Y)~>ōQL! X#ֲ6D2xLn<޷wje&M^mK/;wQb\Wq;a%(pP |@>6Ƽj{,Iۭ/F`MhDPIV7Ee0Af{m6%us~Ö3G-JYaj=u7Iqx~E*3Ȓh7}y@-^ڃpg\11IBܑ$E &kW@f,)3}|lR^ S [buF;/ku/^L蒮497aά@F\Vwm<9[rќCoLT[aZ@55DOz!m6Mz繖 ::0S}or I_.JR;>>xzbfȍ03Sz| ()UPR0qGCq_oUR'{e*8Mj4NFAt6pn]YL M~|B@ Hr?H)0 Qm3qb#QqS*V*ץ_gn_[U&< OMP';6-fۀ5e~5tN=fh K:^E_5Yyz͊&? |H/t]i0iiT4PQ#NҘnu6bd @#}De؆YS&^({ܤHx5Rs.$?~ŷFa"j®Fэ~iiyt<[9$wQtw/L6i,Z86փKN- zJi4@C?'srhPrY!s<G֋X>9}b[mxKy)ڟ=T{>^].pS2ʾ_D k:0߲9լH%㙆qO+.AAiه&mr%BgTH#J 154 m ujTVvQL)7+&r)#K5T^|5˔Ǔ M?BquśF8EօP !N)|Ȫj*xIgI)S'vZ@Am@v'vR3 xokZ6I_|kcBE,0 >Jo؃֒D0-ϟC L.T#9 YeBq}~UC7)[+GKFWŤ*WR_`T%uvFS$N~ 7QpmlLkUǝJ%Dy:T̞p^6|K-r8uCU/:T[oXX=0=>8dt&  wɥvzI][|3N팂gJ\,ÃxEKd"g#@C,% obxj0iCr81Ͷ;>h-?L#ҟ}NoIA9YQL픈D70*4gTB֏up@&G ڥ`P&5JH;ASXZr=]p^-xT rDI(%9$$1P:gĪ0:7-ա;ʑvnWwN*lAk)U6R;Bdnnt::QMFh-\ʹAU.炟?7_">p:;4; |A|M>)=HX^'=xgݴ`PyuŎԺԋlS*1#PԺjt";u]ꬆlRp 8fm]@lh  OA $0?ّZ:M~{DAk9=֦eIw_U^: V>u+:H3&J1n5JγNvT{.0u.ilA_Vs% yS>ΪfXmǙa(2_ώ\9\+?د;QD\sl1ܙ\2V|&v`@)^t <ԣdn|y`͆Პ<4 []y܌̊,.'Sչp)zv0=K'v*n}4o6)S҈;5]kWzeU^#7uv}ʇv|L2 TN0L7ÇO<#i@`?Y=Х60E"Sw6 P|=‹([HI:*g+FusS@5 ?P")ĠߏO;xĄ[(F?7&CxK=-utz:BbDz&ChXz!Vs?p)9ՔJD9Pfa94DuX:h F~O()-ss$2B̟LQq qqٽC@V*H˭떝|qZJ!d"ƥeqgkKD3/sEPzjh.ȹ/{㔁 2 51[lwyqYsIW5lUنJɨLai}E>*}Ax;V!Y&%t!M0i@pΟHt^"NYi{Է5pniftBKIpQU0OhLѓ.:otLG Sz4R/}MpX uI@Pͽ-1h_DząoǶ۴{c0@ W/}se1BjSU@ ʹE0e+}4=I5>nUp6%IWtO r=R'_K7XiX}, rˁQہوkY0X5. yp$3en|wwY0x",_:V J #} jx ۦ+83̩%6.'O| n3enŭ+2z `- t+084"Lrj|Wv}dR4J=lJ eߞ;S^Zw`VBeNJ5)PaBNΏIAcʬYzzm)zFRVSg8(P- 1t΃}Or &i?wz e۪+g+>_&+ {~4 ɭ[2#FL-}?ø5OB#[u6sɅWLuL?He6rK˚u+~> K]S`SeJ.-l^>M)@4?N ceY^h_潥>6hj"T;Nx=)hWU)a@Цյ1KS(r9<ڃ}}Z0*37UYG.{v぀4ؤTWx*O!X,* U}`GYBDVѷ2 J|70`6\g^ !\QPk VT@@~{y>Z,;N_$+=bQx&f`z5rB}^**wc끳&(MUk:^f9ZԚsiYJFʵ^[gJe*SAG`7\4Z:GIg{$WWթ-}J:,BG9@ ֐7EU߮t)~>`h7l? rE'`] K 5b*zHB!*<ɬ ,8\Cdc_ fF a~Q0v/%<0mU p=yq[Wπ)dF'=DP.8Sv@nC _ 1nK~3\/hmtک5MW-ѬRYbOKWHVQ[& ^q4ؗ0?["` o <}LmHCtv+1L?d*Ϲ-_?Ap%֔ 8¥Z/ .C~ƌ $$[S4 D.W2ug(C\URJ+T!y+3K"UnɃEIvXA %pY:c;w[u9N߃pL66]1;"M84`*i UsW]m1RSzJv 3c麻ݕ0 qjf<<:he;BF9 ]E /ZRa޻DeP:xR+:u&j%$ =xK! <ݞCQm`zK(N\8\:m˄ͪQyF,z~*ŅV{^Uun6&0/l0i+,96(4p].d:Od*^Iŝ!<{F̻?zX-YZqIwԂH D QԅJowG$< Kb .@5Ϯ./ȸZ P,9MJL۫HU@iG72Ziyz&yMbAc?𖞜= {r>Dbs8PTW",hmJOJW9_qB^@R{R+S1݇u4g1Ѥ$@ : 4mU=!cz; 3$g Jx뗬B͖ 8ZyaSjxE*mVi#-a܇ؼ 5T_4SO?"M"ΆQV[^,i/+6;%xl:|9H$M0a=bo Z1cƦԁ=]sV7%kՊ{Fpə1])Vm}Ekb.tڗ%><{@Zmh-θ/10O_l7nG !jSBਧug |rrUK|Ÿ4HT{dpμ!%}xG"/ٺ\<5׿^vjmm5Eƛ5mW5TEQ{;zAqOËV_;e$S۸$ɻX v̥M.MN ig<90˕̑\loTjzvv0>ݔd5ЀJ!\56כvv+ aC<1,SWKlWiX4s(r$R dglSCKI BcY&=S@M -wnty2=Kü +yad,Y'_]UP54Q5 J4W!ԇ Ѐ?i3ubo+GuBBmbF=/V"ŋohҥL%wpH#Bnk0U@6°ݓDhC;%A1>F(. IQ*mU}|X ]}-R>w:\T|g$ބ+$T7J9)a,ҔT,X&ƗB-gVP G_'UI?QVK?Q˙xk:a2S(8 &Jo]f[wq䳁Glt_7xuB:韧Oz|VO;qVv2 vUBAF<>$}>Gף˶ڻj =P{ @ 3+7 G9C"^Z3mJgo(?9umW@քpk񻳤kӏt`f4^ a%hi] ոU˂rVa CJ덯o (~2ñYd֍Ό0'&SC@4Cg!0.3Oiܔ{?t,2\v4ќW7cSqPqA#&7L|{s$%L ɛ+*PYTI"鯎Ԍz\RުAT]Мޑ(߁bJxv1f/e-s K]|=+R !jx v t J@""O^o Id(싴_F F=Ν!Lhs&0T@Q~S1ݭTѫH1\ťwhSI\ki޿{N2q()fk#wt^fmS @}Rq͉_6ɾk.aR?^$PelS$B wMoV4}3ƸhGe5zG=§}lܳG@ T 6. KrHsH'c`=pvA2Hi˯Oq]"SǠ]ȼ\x_J&\؞ViN9b ~ҭ&F  &'v"U‱R>  6Zg@r"YJ1zH(("e1|p5v4pxU-!#O`\ˑ0Pi~VXxJ_'vvg |*Szُ>#P׷ŴfOw-v>SB{zʴIOUVDxKX,WJA`'<sFANk&'?=09"-nA>n0ֿD HgǞHHIE<|K cKBNc5 mѽ:^T+!mي+*Zz>QzZYCT;MnmgKl9N@mhx)b< s~?Ut?KCsy^7q6'v6.ْ4../Si{c?1upJIF2gnb}bGfsr:'m 4*"vzV:Cd6d+U?" GB@VRڇ rcOISt`( ;GB=r=f41Ngƛ]zNΧX~< ▥{qwu ?'MiIht?LbL Sp*YS#yP"ɒx;~z.BX R-ICcSē mZ$}Ub(zN"?yw>B, Si-Wf6ru29mKxFw]} v`džB-\xb^vwuCwD${*B%{,4 _ W`HF̷pe0lLvߤL``:Z_%\Jk1,Ej \ӥe1rq觚zBNb}^wD q]M.H^[!a48&#!EQ[4d8bg:nümYdav[AiۋcԼu똗qSce6WX:Z(T'uÎ}Auh9B3OpR,9uZS? *ݳ2AhX R>#?5q99:ǏyD\WUy"Ӆ4u6YU0+"&6Dr-&t"34C|^d9rV'$}+$16ڹe"qjCU%&i}oǻ }S2tM, RvobcB5BES'W\{78_%Raw;RhߤǂVAHSE_+~¼q02 ƁK73Y8,U=C<|)j&=v1Z TǺƪE^Uә4mG dX{].zn#>$!AaLɕ)|vHR΃tnEa2,\lMXMl͍ d-޽ȸh+sD4 H$pc8o-( yQ0鏞JgSmy$R.[?6l coa]bw.-@WX[vB w{Ψ 9'Ϩܕ5_à!^fיFiBY؁J־N땿(gց)`;vT@=TԒ׵z遥W&,Po1f5s@CA̔}H)4-Vkzz%YbYCԞչ= }ꌟh˸}~^H27.{lS%oce$PxhڽgemnA_-l*[BW 1ze 6[ (qoMJE4wWmPMƑM"̎f^b&t~!keh >1Y[M.^/4Sߩίq(?maN3fr)Wo348K =IMk<I.H?U.@fqCNb`jZJ/6ɀi/zq𣫍` XsRlx뎞%͓$7MKYpTCECLyQB-LZ,9 .DԲcmhU+-7_q.۟> ɾA?&Lۊ78v3&/$}~ `50huy _gJ+h% v)¥llu*R^?k-b&rŎwq~mHS7&-B?NT!3@ *>P[^\~Ю0 %n*urxIt&VL3Luo(_%|oc~Ov|=R"QG 73H~8OJ1hbn?;N>TvC8hLM;[C*f`>d01FG)$m|{S3VD29𶋷ü}GcE-݆ Cctkd An0jU`MGj(AVx#K*PR83nw/;r\a (.y7Sy@֨QpFWE(M-e3n$%6J,}ñarv#q}yr/CN-ٱ!02o v Gnx]Anwk,Bwj ~{Q @Sack"J:%Ųk4M pQЉu6X=p8k֑~ӗ}У]^GVis:*X%V }LBRtY:2in2g|<¾2(C7υ(*M?f3-3 OKXK>8G5 -`;%|A4m3;{@eԂu@dϮ"}$>-/Z/lj~t֩Sߠ۹jxGwM0^ kB<yzm"1f8{-ܻW3.cTmġ|k4CyCHbDea'HM`>L5& F-^&ppJCaE?8Δxō /Za^f!aA153]e{%gє**~ &2S?[6^jZC%f |6L1+L,eieN0ljz_ЁS47ZIYԥ ʷ">1?nԇv{X^H`J_ O:Տ*X`fPefFTt>n%;rʔk」<ȟ)B iv0c' ]wY ˝e,cR:Sr'~kW{DŘeb$=*zsmy1|gGdru9MT۪Ơ8&~DuVO tuB`>?#GYK'F/d a!b^gIU=HV(NQVY29 \ڗ&/BsaBz9{fBwjes*(;9]Vb@&YO@fQl{4g-cq13%mc+E`m"\n7R:<[_e{< $ ׮=tcf1i&N qkj7#5+Yq i&*tW6"V)S:l|@@]wcz?w(kJs>1s:Z|SrjdW\=1CzهnP3̛bʥ*/E۠_{Aᛙ~i:3,`@+,Bz}Y$u~7<Bc3R\uZkIkheG~Jd_> kk̇ƿޗ{!l_ R톈21XSzӱEv߰Hà^#6+x! Vٯ;)6ˍjV4yªZF7;p>@N6$Du#HQ9˭w/<7;/uQoSsڎ>6!<9(v`ݷ_ےTwfРC– [K Ҡw_Yƒ%*zNעkW SN,_5FUR9;8+*d]4;#ǐ P}(>IO*i]:P4_OIiK~gFRvX!Q"bP4mF:AH=bԍ2no`뙄p猸{yWP?Qk,e'#hvAeUA_qTFxEYl) [b2A/1gs۰)wp:NޗsW[*Wn7'-Kػ\=XI۬ͫFb&n_/^,EIz)ys _uܶ2M0Dȳ+]j#|BJUUiT K*e}'(m/9ɧ=M8FZ[{Lo;0dLZlSn}w|B%w/je)aClDb',% a%Y#ږɕ0Č|h E@xԜiI9>8 Zy eqO)gC_bL(ib;0f %L!˲bj7"ѝrg)j'h3(%u4MվOW/n0ޔfR{b5?͠Y~_]6{*du8`PZ|)M{QԮꇙX]2ONV:|l{hsy HYjW'0Pu+5 bW9qRMmܘȍ{l]+o& F|L}n9) ٲ!C]6D<}1c}k|rZrlbh46ܤa&\Qls4ǜp5}FkݖrZSU"?hx|55sww!'ʟ&nny d ]aCw#FZcJ1eԃUF^C7eiWjҶ̀GR'ݠM+ 18{,f6ULu{!FUU,`~Z4' DžL;ُ^|>WH.f*e4k*̉})СD.yUZ Pz5bGjs;$${Mv񁦞ma2V#D/N|;G>,cI_LS6/ BYGfêS5H.=AZ4. Rt|yyPa lC`U[ ҁDѐsH" (ea+) YBqknO̳8t;dEPhilnClɣ˩[6qhD>ً3}dA+@AeDE4ڥw&;(ȔLRXF(U1`D}",zo&:{Mw R4n%iZ$h;. I(K J()s-Yv<_2Et3y" u_qts{G!~rwFV^-0@|ς(DY%w#5OW-J!E ^Bn<ιyQԖr$h8o_ | Ғv'B\|Tg6ңw 5,g:CwmO6QSٻt.<ງN}nرWgj]0%zLق#hj+ 4Pv8otfqs ߚ##hc%+ת6 C yzprR=kaZKԚE[%N?y#B0A;yŀȨޘB0x`w"hQ NBlEI2sjgSN*t{s]䇢}LQt5xva};Jځ}fez2̲W*ΐE@78J>&/J IP/#9*,[i6UkuqS/>v4uwW9oݦ2Um+c2HՓsI=-l [Hi/(!( `ZG&D$I6y8W j{+F7/*<-sAZƭHgPsn, A8{|PkDTɊSN5by*^a{օwVN6j@Kc,'Gj2. ͒ϼMVBctRc2z<쬪:p `@9ǣS9rgdYa-,̯k,0GʧٽǠL)5xSb~h|9d|u1`PMJO!p3g,w?=׬oRPg=o|*&(SQ`? TK-kʿ./pJ)L&/MC2,d_lޯIFt ?tоI>9|1+vذ"F€AEB 4`2 YrV/{mQ.i`lM\"Ia[\Y6VMG_`aP2<K?/,lʸcĄ0Gɍ]-'K:7U'@#RR>ޖvN@}f{E{t#?aBɐk>{=}M>p"!NV*+=Sc.3M^Z/W籑VQ.1fBj: 6"C/q7tvXW5HIDߒvaGR8ژYú3ocd蔫EUvC("dɩبVՍ {Ʌ~"H5EZޅ6fG+,9GJR+tװ8Zt_<9;U b_Gi[W%hի&jawXĘu(\6ݏΚ ڜsR[Q5&ul:ƄMeó0e |> #\&7xA$m' f%&7Ƥټ3Oc"}ha"Rd4hߊ# Pϵ*EIvdӲϱKLՠ]uv%@.SbQYRʐa1%>؅{IQ5Z7YVxu`$d>VkOUԪENݔ\ƛ I6JSƥE> *x?2j7dvyl/Χ 0|F,1 SNA"a\n.WHM|Txl:R8E yFuW0ahN3``,2F:$%x ab`2^ůƊԄ w8IapȄHg:PTRe̹Z22'(ZZzNUvs]|bMm `p㥐q?Sٮ*H&7`7pYTX5Q19p8D?*}GPHxI2MNѺ -&Lw}R.t泙,Vtfe޿5)xbH%/;]JcF~#d_$<4=MYQ?sA *>3"?F*ZlFy "t';UHsnL/ȴDzRIb5U9 ٜ-us~nPA$Zo uӶDL&z,24WӬywT;z&Nxї_ EWJ d |Y]_+@j2I1kbKkˋ˫g_OnH>Gt`x\.O#e,X%S(d-n۱NQ/Ӆ7YO 0(%t=p9_Phk\8odY =T2!'fo%#J ػ^I~bZ$K3dGOc۽K.{v/ue;xE:8^v1GGPR>Rc[8pͬufmPG"{ϲm\LݯX[ ?(+2w<τqݝK,Y\dzz 'd7Ǧ^{郵Z+d!SrmK;fpAKv|٨ ?"S??%W`^1c T W:%\o LyIWRD)dDh@}%8dtIw{rqՓtOLalsgK@'@woR7l><8[եFRɩR R #I׿b&q)yj%? ɊϵeW9pbl{5u|+̙y]JU:ar7Fڮ 4kҬ( O]RroWuS۸'}YN[V^d̑;-.ڳ咍I)B67F5[}c>Er\46V<#OV%RTRe19O€NUp`۞⇛Eĵ#Hp9 N3;]򖨂a bapk64cr0(> :EILBJa9"& O]E|$< C ^sf,#=Hl="g.{>Ӽ64P9r!; /fؒ24bQxd€_+'17)hRSD8rym2 #**/HRJAܷqY,*a'G?L`*m {0<ۑM\B< Ag U ݫ5R'toP)6פ!SI(niV䲌j$G2kkBl j!ZV jv Q0M#]k~+'-.+TݔR1҆K写r`A0(9aj\ c*%p oU}Mm^1i*o+S !"&U/3U0 Nܻ3`mpr=t,M d9(H/83-*!s":7/džL}":4H22]v^h֌s"S#ߥ(AUl]Os"1*d쾺x%. 1 `Y)T8`pAըI텰= ɬK:!؆(]ͻE+2'դbf g{*=C2*W $66͠e^i݄F+h3 hUJչ[P,-JyW^`+&hI*Lö&|gDSv`$TIAmq'(Y&Uk꺯Pe _iIzk P KX0y'>WLmY6lQ&K/쏷Z|EWMO:ғI8rf\9&MuwU Z܍{IK,{uiF 6r ZКcuB95jyԛyϺ"_aͰ[3Ac2 f/4WBcp.|7elRۡ'%/nU Bue|ο}fpALkk%# fsT!^2;LwqbBi>L SO xYc$&=YO;c<Ȗǘd>PNASrS N'|/c9 *k`䯦Q M\^ⱮP0?'`PS^-W?!Rpd̕ΞwUNld3 - +J )Z`Mlp!ygFH3_6ퟁDGQs)Z¡usUhBDaDXK@)b!۟ 9clKy`b mt .Wɼ\ }?79ўtwyy!\ٍ,?S`h =V_2d(NA&~t5M J JFP\e7~\9Y5~8*NmsO3g |잤U]zG|cB]^ bbF39ȯq2v|n6_ciLRʔ,{D޿cЈ'J oBip*K 3*ڿމKOΛW \lOzÔu$BXO9 ̏/CI\p<;j)u"!I nr.,R~zV_uP`r0DV=yf\4OB֡$?tRUվq.diF`$7_UgErf[=D\[ qxbC. ECR3$Ň? -{ZQӠohVal%vX,Ō^S%az.xW6]˥ICr=BY4E Pqt.`21ˋ>/NMֽj8ZȲш L5X,˚TG8e (}fیL :º$So*ׂh/1{,P }@iJݵFYD ܐ7,6cWV;'P=9֡@(ΨT%1l^Kcz^0{͡#!gQ &#"G¤^Q0b>JAzͶ/ ĶY32Zq)`^U?٦;9:AۥX8Zchp'EiL|>~P9tUh6ْBm20OǕ|R}WsY@t*9k?(VRD& NB\f>2yЋ*+NoцqL&vN,6Ug$ɄaɟZˏ7cכod?Tt%_fclMO|JV.NHTm1Sm ubl|Rf_$+~,{'FE^|.#s˄4ӀZJ]>lX3pPD?WNjʪHړ+Em;)({QԽGH3R6#1+IeF pcoNC둼 $7gQATjuȖ G8p Y[LI/j+e3'Hoc3kR鸁7~ w9/!UhoZqUkUEaPPKNH / X{l;& [# d|Wc=+ci#4Z1w&mCmnR9'~S<>D"6\iX?IY `XrDy0r dI9R"AiWhgDq[.IpX)#q*$ k+5')k9VhI] `P#Ď R>oT(f&-ɝt7>ɻ.F(b/qhf{Ot5G‹uҲ-ޙ2%YC߆X@j~5ܢE1k.gVyr7B?!RB:*@Khd̉`Uz~)^> (K 20 X熏n[WxxTHIW,>ޓ =I_RJ+>yC[8q 6xB /^Yv݁f@+ U?$P^kU[hd쒾xxj-r@"V9AWD](F#z3'MV؀lDaK+jk"`2ߛ=-ϔuꥥdՆ%\p#8q4A{صhgozT Ȥ&(,cdUN\=3$ēV9w(sJDzkC祖'*эYȯ9gSAOb=䑆)8#`b ]N$# !YvqbOlEj ֻߔAFˋJ YZ