dnsmasq-2.78-lp151.5.6.1<>,䀉`ؤ/=„ =U/h"[z%^ ]k ҔzPH2|iyQbyjQp~3SFmzղk_.O&(V}YHՐ}Ww21J*eLgJ,}3.yg0q -[h`cǜzGh!/αm{/9kǰRy6 p&9>F?d   X\`hl  <`` |` <` ` +` ,D`-`/`11`3(3\!3!6G!(68696:8=l>l?l@lFmGm`Hn`Ip`XpYp\p`]rT`^w,b}Ic~d~e~f~l~u~`v4w4`x`y4zCdnsmasq2.78lp151.5.6.1Lightweight, Easy-to-Configure DNS Forwarder and DHCP ServerDnsmasq is a lightweight, easy-to-configure DNS forwarder and DHCP server. It is designed to provide DNS and, optionally, DHCP, to a small network. It can serve the names of local machines that are not in the global DNS. The DHCP server integrates with the DNS server and allows machines with DHCP-allocated addresses to appear in DNS with names configured either in each host or in a central configuration file. Dnsmasq supports static and dynamic DHCP leases and BOOTP for network booting of diskless machines.`ؤbuild82openSUSE Leap 15.1openSUSEGPL-2.0-only OR GPL-3.0-onlyhttp://bugs.opensuse.orgProductivity/Networking/DNS/Servershttp://www.thekelleys.org.uk/dnsmasq/linuxi586if ! /usr/bin/getent group tftp >/dev/null; then /usr/sbin/groupadd -r tftp 2>/dev/null || : fi if ! /usr/bin/getent passwd tftp >/dev/null; then /usr/sbin/useradd -c "TFTP account" -d /srv/tftpboot -G tftp -g tftp \ -r -s /bin/false tftp 2>/dev/null || : fi if ! /usr/bin/getent passwd dnsmasq >/dev/null; then /usr/sbin/useradd -r -d /var/lib/empty -s /bin/false -c "dnsmasq" -g nogroup -G tftp dnsmasq || : fi if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$FIRST_ARG" -eq 1 ]; then # disable migration if initial install under systemd for service in dnsmasq.service ; do sysv_service="${service%.*}" touch "/var/lib/systemd/migrated/$sysv_service" || : done else for service in dnsmasq.service ; do sysv_service=${service%.*} if [ ! -e /usr/lib/systemd/system/$service ] && [ ! -e /etc/init.d/$sysv_service ]; then mkdir -p /run/systemd/rpm/needs-preset touch /run/systemd/rpm/needs-preset/$service fi if [ ! -e /var/lib/systemd/migrated/$sysv_service ]; then /usr/sbin/systemd-sysv-convert --save $sysv_service || : fi done fi fi if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$YAST_IS_RUNNING" != "instsys" ]; then /usr/bin/systemctl daemon-reload || : fi if [ "$FIRST_ARG" -eq 1 ]; then /usr/bin/systemctl preset dnsmasq.service || : else for service in dnsmasq.service ; do if [ -e /run/systemd/rpm/needs-preset/$service ]; then /usr/bin/systemctl preset $service || : rm -f /run/systemd/rpm/needs-preset/$service fi sysv_service=${service%.*} if [ ! -e /var/lib/systemd/migrated/$sysv_service ]; then /usr/sbin/systemd-sysv-convert --apply $sysv_service || : touch /var/lib/systemd/migrated/$sysv_service || : fi done fi fi # reload dbus after install or upgrade to apply new policies if [ -z "${TRANSACTIONAL_UPDATE}" -a -x /usr/bin/systemctl ]; then /usr/bin/systemctl reload dbus.service 2>/dev/null || : 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 dnsmasq.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 dnsmasq.service ) || : fi test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ $1 -eq 0 ]; then # Package removal for service in dnsmasq.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 dnsmasq.service ) || : fi fi # reload dbus after uninstall, our policies are gone again if [ ${FIRST_ARG:-$1} -eq 0 -a -z "${TRANSACTIONAL_UPDATE}" \ -a -x /usr/bin/systemctl ]; then /usr/bin/systemctl reload dbus.service 2>/dev/null || : fihSEf`sVks <-fEwlAlS& W3Xd Z=l ?^ P# hS'.FWKÕd921"3aA큤A큤A큤A큤AA큤A큤A큤A큤A큤큤AA큤A큤AA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤`آ`آ`آ`آ`آ`آ`آ`آ`آ`آ`أ`أ`أY;Y;`آY;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;`آY;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;`ؗY;`ؗY;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;Y;`ؗY;Y;`أY;Y;`آ`آ`آ`آ`آ`آ`آ`آ`آ`آ`آ`آ`آ65b25dc51ba9fd414201ed8146f1d23af6c20c3feff364638f136759648d8a42105896829d4142c8ace7681ccbe50cf83dfd9e1faa846aaaf257ad2c68a668c2751da48d283e73933d22c49422e488f701e0e51d8b73ad212fd060456d06867d7eb505f2605a3d121c0995399adf3f25c9f079c00335f5dda1afb9ed8e648a385a7ade166721fa1ba81bfabeea76ca9cd740887090a5b9553129e80e10675b0356f0859b9c71415928ccd9a15080b2a210148184188e618d3804bc5ab2e1ac181cc30f21b121e920ac4ec5c30619135aa8b771a3f91a38c71d596e81d35fc0b712f8a974ab194afd78416f319d5bf541b8239515fcb58ea951ed9c5b46ac3e04a446d790e44f2d5280767758a948674be531400db87643b2bbc0351ee70d33a280791de58818788dbb3e54557b85aa0f71f5d8b7d30486d5efb7279007dfb6ebca5b78c85afaf92bf423f74562311e87f3affc52fa07c42a593659d51db7b4c72c174d8ec4f11d8b168e308715b63e2f066fb8f3fa90f3a6c48bdcf285ae1a0c66d732a843e2ae4c8acb678d1fd3715362484eff6ab23877df608ac933bc9164e30dc229f359483f95f6af0a2d886a8f9870585380f7de906f462e1b46a76cf4a021a74cd3ba67985484c2e23381226820266ed6cc46ef657fc8a12f8333f4e02777e4eeb3440bd834286c258bba713905fcaf3eaf38f86a646be53f6f62e1df525ba862047b58c71c645ad3b9af10e54dbdbc2f75292c4dc08470b219a0a6b72f7c3bfb9c73d182acd7d8751c9c3fc1926db100f22dae0d0f71c98de090c78fed0ec432aeda33fbbab97b82b9d4eae3a1ded3710243beab2f344c6ca588949ba7fd5d2bd7858a440ca1a10e85c87c4af8d11aa02717ad4c823f17689112fc131e61ba13d73df9acbed61bf16c2590a39f2c8a681afc569851916f80df6c100497db11f354b4bd156d178f055e0e25e2cfcdd6ee95f1dd3bb10ff184f3ca90c8b4a2fdfc7a6dd0e11e02a5d4e45e36440250cdb1f77e3b592b470ad563d68e3d679707b0e10b867bb7bd7e5a4fe4f002ff9fcdf5c2354ccaeb8bc59a8e5d29c5c938e734286f2e0796c7eb67a135be6a5fede02fe749daaaebe3510d2b023f4e502edd5eb324bcf19307b19f3d50fec7a44c54d54f4032c3b052a3d4b05da802656b204b48f0bd8c5df471d37cc08246023dcf813c189b17482a66b0df0b25350c69e1d76b9cf57e2eef7397553da670a7981c10be01f34bfdeb54d7f61a1df7d7efb86bad399099dc7147a892bd47ba45c42bdf5d14a89665953b491126ba3bcd404f467ac923c398e89e29467519b740cff6bb1a842d56dd4a37bb4fc8384a8cbe71bf06395ac6bc6ff529e7238f89b08735eee3ff53b20552b23bfe8ac42dd20a519185c0ec606eac4e66e34020fd3703c8d4947cc73dfd13d473666f8f5c9fafe6be51614edf260539c9b47a46d955fc82d375eb30501eb17818a6ca5b21d0804b9a07ce1d0e0fbd58a736285a18713985817e2b408cb60e7f29ce0a115eb87ab8e96d6cf6d77d4181dddb7393ccf44c96d9967e10fb884b4a05affafd9f976004f8bd958fb65708f05dacfc4703972bf875b21bf9d0beefca382e274acd6a28853b7e40fb0f71d741aaf87d0da18e688efd697c39eb884efb0807ff9ee1fc47e062f1077e108f1dc4eddf91d04a7db2ad23d07929e2c91e28e4997104dc4cf493104bdef53e05c105465f3314384deda5c8553c81088b789b350ac6f1fdcd70cba62b3c56389dd4ad81b40ebca8a122bc020ac7bf4f724b7f494c6c896f9c98d4e1c4a33ec2d1325d57c47390cb46fd763aa1b30dd1c6b6ef813563cca1a1034e815282aa6265b2c9dc17d6b0df97874518db2515c073d16d845d13bcda98d196f00d6cacee33e78a2a8c56b2420902cf70c11bf3aeac54645c6bf093d85ad89524beeee4222c838354a43a29e747584b885a9f6288ee44747f80929c982e9fb863e933f682362933749abe46b6074226252dd68d09b3e86c26b1a77c0396fec5f060083f61900237d77f10604ea4d8e60ecff1bf4fae01f2d63d4a9865e94577c0c54e164dcb9324bfa2e6520a01b05f77899ac66105614b1582ff2445b8cb5eb2d16434e6c77fc760e98a8aaa3cc0df6695b91036505fe506b9b4f1891b01914b6ba8dc2696c1e6f75893d3337893124a44e2525018b4bfde9d858e11fed9db4f97eeb636244a5e1b5e93bd7423155ca3877211e916447a09843afccbd14385130a6d3e4101b049bf4f623c53e4a1ac9bfcc0471fe11d3f4047832473233e94f4b65ca2fcf075faa62447fadb508e26a52f1ef000dcd4fe8a0f8a7ff965b25dc51ba9fd414201ed8146f1d23af6c20c3feff364638f136759648d8a42105896829d4142c8ace7681ccbe50cf83dfd9e1faa846aaaf257ad2c68a668c28a3f150473468ca14dbfaecda4bd71d2cf69ca2e4e0c230f20812121fc7793ace6b975abd418fc7a5313dbf29c3c4606f78e8290571396a8d1804c6665c43d2bdcc100d4161cc0b7177545ab6e47216f84857cda3843847c792a25289852dcaa8ceb4b9ee5adedde47b31e975c1d90c73ad27b6b165a1dcd80c7c545eb65b90376865b5a0d6fc2aa2ee117162e4a59caa8b5e5c410578436dae53ec5f7e99b98a343bbd212067bf566dbb40c92b17b806633378190a2bd81bb3ba48f2babf30d42c6e8cb473670be1934a8c1397c0ab969f122687f1088190082564eab9605b6aa02ec034215e97603e92ae49b57f63dd9f39366cdb158756285bf240921fd603535acf37dbafe69d448d9266bba74b01828ac1d7842ebc1d6e58c5646ae66d9a3684c6a4940e3219c505ad29794b849b3084d000c59561838985119edbefd2ed3f6f152542daa61a63dde7936c5e97b12ee9c19b6c2d9e8dc3d680debe96421737b4678b9bb5fc16375144107dd1ed5009652b28879aee7ed329279cd9bc26228cce53b2af67c53fee5b8615c94a1eadc63c88b2347d209ef2ed9490cc0d1abfcf0386da0f115a8afe29b3476ddd523143da8c17040922253b1472f91dd9a58f9d931427bc280f2051b257c4a92b3b450b27d7062900762921443a7e17f9b422b67d35cc54ff3316ff4475b43caf18100339545edeb18a570b2b197f1ce18d1abaab1a948fa972e42d149a0fcd094a631ccbce712924775204898dfb0e7b32bservicerootrootrootrootrootrootrootroottftprootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroottftprootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootdnsmasq-2.78-lp151.5.6.1.src.rpmconfig(dnsmasq)dns_daemondnsmasqdnsmasq(x86-32)   @@@@@@@@@@@@@@@@@@@@@    /bin/mkdir/bin/sh/bin/sh/bin/sh/bin/sh/usr/sbin/useraddconfig(dnsmasq)group(nogroup)libc.so.6libc.so.6(GLIBC_2.0)libc.so.6(GLIBC_2.1)libc.so.6(GLIBC_2.1.3)libc.so.6(GLIBC_2.11)libc.so.6(GLIBC_2.2)libc.so.6(GLIBC_2.3)libc.so.6(GLIBC_2.3.4)libc.so.6(GLIBC_2.4)libc.so.6(GLIBC_2.9)libdbus-1.so.3libdbus-1.so.3(LIBDBUS_1_3)libgmp.so.10libhogweed.so.4libhogweed.so.4(HOGWEED_4)libidn.so.11libidn.so.11(LIBIDN_1.0)liblua5.3.so.5libnetfilter_conntrack.so.3libnettle.so.6libnettle.so.6(NETTLE_6)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)2.78-lp151.5.6.13.0.4-14.6.0-14.0-15.2-14.14.1`2@_ܙ]@[@[[LZ%8Z!D@Y*@Y@YXlWWbV@U@UUa@U4@T@TB@T@TT_W@Reinhard Max Reinhard Max Reinhard Max cgoll@suse.comdmueller@suse.comkukuk@suse.deidonmez@suse.comcbosdonnat@suse.commax@suse.comtchvatal@suse.comdmueller@suse.commartin.wilck@suse.commax@suse.commax@suse.commpluskal@suse.comstefan.bruens@rwth-aachen.destefan.bruens@rwth-aachen.decrrodriguez@opensuse.orgabergmann@suse.comjslaby@suse.comdimstar@opensuse.orgnemysis@gmx.chnemysis@gmx.chseife+obs@b1-systems.com- bsc#1177077: Fixed DNSpooq vulnerabilities (dnsmasq-dnspooq.patch) - CVE-2020-25684, CVE-2020-25685, CVE-2020-25686: Fixed multiple Cache Poisoning attacks. - CVE-2020-25681, CVE-2020-25682, CVE-2020-25683, CVE-2020-25687: Fixed multiple potential Heap-based overflows when DNSSEC is enabled.- Retry query to other servers on receipt of SERVFAIL rcode (bsc#1176076, dnsmasq-servfail.patch)- bsc#1154849, CVE-2019-14834, dnsmasq-CVE-2019-14834.patch: memory leak in the create_helper() function in /src/helper.c - bsc#1156543: include linux/sockios.h to get SIOCGSTAMP (dnsmasq-siocgstamp.patch). - bsc#1138743: remove cache size limit (dnsmasq-cache-size.patch). - bsc#1152539: include config files from /etc/dnsmasq.d/*.conf . - bsc#1076958, CVE-2017-15107, dnsmasq-CVE-2017-15107.patch: A vulnerability in DNSSEC implementation of Dnsmasq was found. Processing of wildcard synthesized NSEC records may result in improper validation for non-existance in some implementations of DNSSEC. While synthesis of NSEC records is allowed by RFC4592, the synthesized owner names should not be used in the NSEC processing. - Package contrib/lease-tools/dhcp_release6.- enabled lua scripting interface (FATE#327143).- add missing prereq on the group to be created (bsc#1106446)- Don't require systemd explicit, fix spec file to handle both cases correct. In containers we don't have systemd. - Adjust pre/post install for transactional updates. - Use %license instead of %doc [bsc#1082318]- Update keyring- Get rid of python dependency due to examples. (fate#323526)- Security update to version 2.78: * bsc#1060354, CVE-2017-14491: 2 byte heap based overflow. * bsc#1060355, CVE-2017-14492: heap based overflow. * bsc#1060360, CVE-2017-14493: stack based overflow. * bsc#1060361, CVE-2017-14494: DHCP - info leak. * bsc#1060362, CVE-2017-14495: DNS - OOM DoS. * bsc#1060364, CVE-2017-14496: DNS - DoS Integer underflow. * Fix DHCP relaying, broken in 2.76 and 2.77. * For other changes, see http://www.thekelleys.org.uk/dnsmasq/CHANGELOG - Obsoleted patches: * Fix-crash-introduced-in-2675f2061525bc954be14988d643.patch * Handle-binding-upstream-servers-to-an-interface.patch- Fix /srv/tftpboot permissions wrt bsc#940608- reload system dbus to pick up policy change on install (bsc#1054429)- Handle binding upstream servers to an interface if interface is destroyed and recreated (boo#1018160) Added two patches from upstream: * added Handle-binding-upstream-servers-to-an-interface.patch * added Fix-crash-introduced-in-2675f2061525bc954be14988d643.patch- Update to 2.76: * Include 0.0.0.0/8 in DNS rebind checks. * Enhance --add-subnet to allow arbitrary subnet addresses. * Respect the --no-resolv flag in inotify code. Fixes bug which caused dnsmasq to fail to start if a resolv-file was a dangling symbolic link, even of --no-resolv set. * Fix crash when an A or AAAA record is defined locally, in a hosts file, and an upstream server sends a reply that the same name is empty (CVE-2015-8899, bsc#983273). * Fix failure to correctly calculate cache-size when reading a hosts-file fails. * Fix wrong answer to simple name query when --domain-needed set, but no upstream servers configured. * Return REFUSED when running out of forwarding table slots, not SERVFAIL. * Add --max-port configuration. * Add --script-arp and two new functions for the dhcp-script. * Extend --add-mac to allow a new encoding of the MAC address as base64, by configurting --add-mac=base64 * Add --add-cpe-id option. * Don't crash with divide-by-zero if an IPv6 dhcp-range is declared as a whole /64. (ie xx::0 to xx::ffff:ffff:ffff:ffff) * Add support for a TTL parameter in --host-record and --cname. * Add --dhcp-ttl option. * Add --tftp-mtu option. * Check return-code of inet_pton() when parsing dhcp-option. * Fix wrong value for EDNS UDP packet size when using - -servers-file to define upstream DNS servers. * Add dhcp_release6 to contrib/lease-tools.- dnsmasq-groups.patch: Initialize the supplementary groups of the dnsmasq user (bsc#859298).- Add gpg signature- spec file cleanup, get rid of redifinition warnings- Update to 2.75, announce message: Fix reversion on 2.74 which caused 100% CPU use when a dhcp-script is configured. Thanks to Adrian Davey for reporting the bug and testing the fix. - Update to 2.74, announce message: Fix reversion in 2.73 where --conf-file would attempt to read the default file, rather than no file. Fix inotify code to handle dangling symlinks better and not SEGV in some circumstances. DNSSEC fix. In the case of a signed CNAME generated by a wildcard which pointed to an unsigned domain, the wrong status would be logged, and some necessary checks omitted. - Update to 2.73, announce message: Fix crash at startup when an empty suffix is supplied to - -conf-dir, also trivial memory leak. Thanks to Tomas Hozza for spotting this. Remove floor of 4096 on advertised EDNS0 packet size when DNSSEC in use, the original rationale for this has long gone. Thanks to Anders Kaseorg for spotting this. Use inotify for checking on updates to /etc/resolv.conf and friends under Linux. This fixes race conditions when the files are updated rapidly and saves CPU by noy polling. To build a binary that runs on old Linux kernels without inotify, use make COPTS=-DNO_INOTIFY Fix breakage of --domain=,,local - only reverse queries were intercepted. THis appears to have been broken since 2.69. Thanks to Josh Stone for finding the bug. Eliminate IPv6 privacy addresses and deprecated addresses from the answers given by --interface-name. Note that reverse queries (ie looking for names, given addresses) are not affected. Thanks to Michael Gorbach for the suggestion. Fix crash in DNSSEC code with long RRs. Thanks to Marco Davids for the bug report. Add --ignore-address option. Ignore replies to A-record queries which include the specified address. No error is generated, dnsmasq simply continues to listen for another reply. This is useful to defeat blocking strategies which rely on quickly supplying a forged answer to a DNS request for certain domains, before the correct answer can arrive. Thanks to Glen Huang for the patch. Revisit the part of DNSSEC validation which determines if an unsigned answer is legit, or is in some part of the DNS tree which should be signed. Dnsmasq now works from the DNS root downward looking for the limit of signed delegations, rather than working bottom up. This is both more correct, and less likely to trip over broken nameservers in the unsigned parts of the DNS tree which don't respond well to DNSSEC queries. Add --log-queries=extra option, which makes logs easier to search automatically. Add --min-cache-ttl option. I've resisted this for a long time, on the grounds that disbelieving TTLs is never a good idea, but I've been persuaded that there are sometimes reasons to do it. (Step forward, GFW). To avoid misuse, there's a hard limit on the TTL floor of one hour. Thansk to RinSatsuki for the patch. Cope with multiple interfaces with the same link-local address. (IPv6 addresses are scoped, so this is allowed.) Thanks to Cory Benfield for help with this. Add --dhcp-hostsdir. This allows addition of new host configurations to a running dnsmasq instance much more cheaply than having dnsmasq re-read all its existing configuration each time. Don't reply to DHCPv6 SOLICIT messages if we're not configured to do stateful DHCPv6. Thanks to Win King Wan for the patch. Fix broken DNSSEC validation of ECDSA signatures. Add --dnssec-timestamp option, which provides an automatic way to detect when the system time becomes valid after boot on systems without an RTC, whilst allowing DNS queries before the clock is valid so that NTP can run. Thanks to Kevin Darbyshire-Bryant for developing this idea. Add --tftp-no-fail option. Thanks to Stefan Tomanek for the patch. Fix crash caused by looking up servers.bind, CHAOS text record, when more than about five --servers= lines are in the dnsmasq config. This causes memory corruption which causes a crash later. Thanks to Matt Coddington for sterling work chasing this down. Fix crash on receipt of certain malformed DNS requests. Thanks to Nick Sampanis for spotting the problem. Note that this is could allow the dnsmasq process's memory to be read by an attacker under certain circumstances, so it has a CVE, CVE-2015-3294 Fix crash in authoritative DNS code, if a .arpa zone is declared as authoritative, and then a PTR query which is not to be treated as authoritative arrived. Normally, directly declaring .arpa zone as authoritative is not done, so this crash wouldn't be seen. Instead the relevant .arpa zone should be specified as a subnet in the auth-zone declaration. Thanks to Johnny S. Lee for the bugreport and initial patch. Fix authoritative DNS code to correctly reply to NS and SOA queries for .arpa zones for which we are declared authoritative by means of a subnet in auth-zone. Previously we provided correct answers to PTR queries in such zones (including NS and SOA) but not direct NS and SOA queries. Thanks to Johnny S. Lee for pointing out the problem. Fix logging of DHCPREPLY which should be suppressed by quiet-dhcp6. Thanks to J. Pablo Abonia for spotting the problem. Try and handle net connections with broken fragmentation that lose large UDP packets. If a server times out, reduce the maximum UDP packet size field in the EDNS0 header to 1280 bytes. If it then answers, make that change permanent. Check IPv4-mapped IPv6 addresses when --stop-rebind is active. Thanks to Jordan Milne for spotting this. Allow DHCPv4 options T1 and T2 to be set using --dhcp-option. Thanks to Kevin Benton for patches and work on this. Fix code for DHCPCONFIRM DHCPv6 messages to confirm addresses in the correct subnet, even of not in dynamic address allocation range. Thanks to Steve Hirsch for spotting the problem. Add AddDhcpLease and DeleteDhcpLease DBus methods. Thanks to Nicolas Cavallari for the patch. Allow configuration of router advertisements without the "on-link" bit set. Thanks to Neil Jerram for the patch. Extend --bridge-interface to DHCPv6 and router advertisements. Thanks to Neil Jerram for the patch.- dnsmasq.service: Order Before=nss-lookup.target and Wants=nss-lookup.target as this service may provide name resolution even for the localhost.- Move trust-anchors.conf into /etc/dnsmasq.d to be AppArmor conform. (bnc#908137)- The change from Wed Dec 24 messed group w/ user IDs. Switch them back and be more careful w/ what is changed.- Fix symlink of rcFOO to /usr/sbin/service, resolving a dangling symlink lint warning (and remove the same from rpmlintrc).- Remove from spec group_and_isc.patch, forgotten in previous commit- Update to 2.72, announce message: Add ra-advrouter mode, for RFC-3775 mobile IPv6 support. Add support for "ipsets" in *BSD, using pf. Thanks to Sven Falempim for the patch. Fix race condition which could lock up dnsmasq when an interface goes down and up rapidly. Thanks to Conrad Kostecki for helping to chase this down. Add DBus methods SetFilterWin2KOption and SetBogusPrivOption Thanks to the Smoothwall project for the patch. Fix failure to build against Nettle-3.0. Thanks to Steven Barth for spotting this and finding the fix. When assigning existing DHCP leases to intefaces by comparing networks, handle the case that two or more interfaces have the same network part, but different prefix lengths (favour the longer prefix length.) Thanks to Lung-Pin Chang for the patch. Add a mode which detects and removes DNS forwarding loops, ie a query sent to an upstream server returns as a new query to dnsmasq, and would therefore be forwarded again, resulting in a query which loops many times before being dropped. Upstream servers which loop back are disabled and this event is logged. Thanks to Smoothwall for their sponsorship of this feature. Extend --conf-dir to allow filtering of files. So - -conf-dir=/etc/dnsmasq.d,\*.conf will load all the files in /etc/dnsmasq.d which end in .conf Fix bug when resulted in NXDOMAIN answers instead of NODATA in some circumstances. Fix bug which caused dnsmasq to become unresponsive if it failed to send packets due to a network interface disappearing. Thanks to Niels Peen for spotting this. Fix problem with --local-service option on big-endian platforms Thanks to Richard Genoud for the patch. - Add dnsmasq-rpmlintrc, for false positive scripts and symlink - Add BuildRequires for dos2unix - Use sed instead of simple patch group_and_isc.patch- fix logging, PrivateDevices=yes kills it (bnc#902511, bnc#904537)/bin/sh/bin/sh/bin/sh/bin/shbuild82 1611061412  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`deesfifriditnbplptroesfr2.78-lp151.5.6.12.78-lp151.5.6.12.78-lp151.5.6.1                 !"#$%&'()*+dnsmasq.confdnsmasq.confdnsmasq.dtrust-anchors.confslp.reg.ddnsmasq.regdnsmasq-dhcpdnsmasq-dnstftpbootdnsmasq.servicednsmasqrcdnsmasqdnsmasqCHANGELOGFAQcontribCPE-WANREADMEconntrackREADMEdbus-testdbus-test.pydns-locREADMEdnsmasq2-loc-rfc1876.patchdnslistdhcp.cssdnslist.pldnslist.tt2dynamic-dnsmasqdynamic-dnsmasq.pllease-accessREADMElease.access.patchlease-toolsMakefiledhcp_lease_time.1dhcp_lease_time.cdhcp_release.1dhcp_release.cdhcp_release6.1dhcp_release6.cmactablemacscriptopenvpnREADMEdhclient-enter-hooksdnsmasq.patchport-forwarddnsmasq-portforwardportforwardreverse-dnsREADMEreverse_replace.shstatic-arpstatic-arpsystemdREADMEdbus_activationdnsmasq.servicetry-all-nsREADMEREADME-2.47README-2.78dnsmasq-2.35-try-all-ns.patchdnsmasq-2.47_no_nxdomain_until_end.patchdnsmasq-2.68-try-all-nsdnsmasq-2.78xx-try-all-ns.patchwebminREADMEdnsmasq.wbmwrtREADMElease_update.shdbusDBus-interfacednsmasq.confdnsmasq.conf.exampledoc.htmlsetup.htmldnsmasqCOPYINGCOPYING-v3dnsmasq.modnsmasq.modnsmasq.modnsmasq.modnsmasq.modnsmasq.modnsmasq.modnsmasq.modnsmasq.modnsmasq.modnsmasq.8.gzdnsmasq.8.gzdnsmasq.8.gz/etc/dbus-1/system.d//etc//etc/dnsmasq.d//etc/slp.reg.d//etc/sysconfig/SuSEfirewall2.d/services//srv//usr/lib/systemd/system//usr/sbin//usr/share/doc/packages//usr/share/doc/packages/dnsmasq//usr/share/doc/packages/dnsmasq/contrib//usr/share/doc/packages/dnsmasq/contrib/CPE-WAN//usr/share/doc/packages/dnsmasq/contrib/conntrack//usr/share/doc/packages/dnsmasq/contrib/dbus-test//usr/share/doc/packages/dnsmasq/contrib/dns-loc//usr/share/doc/packages/dnsmasq/contrib/dnslist//usr/share/doc/packages/dnsmasq/contrib/dynamic-dnsmasq//usr/share/doc/packages/dnsmasq/contrib/lease-access//usr/share/doc/packages/dnsmasq/contrib/lease-tools//usr/share/doc/packages/dnsmasq/contrib/mactable//usr/share/doc/packages/dnsmasq/contrib/openvpn//usr/share/doc/packages/dnsmasq/contrib/port-forward//usr/share/doc/packages/dnsmasq/contrib/reverse-dns//usr/share/doc/packages/dnsmasq/contrib/static-arp//usr/share/doc/packages/dnsmasq/contrib/systemd//usr/share/doc/packages/dnsmasq/contrib/try-all-ns//usr/share/doc/packages/dnsmasq/contrib/webmin//usr/share/doc/packages/dnsmasq/contrib/wrt//usr/share/doc/packages/dnsmasq/dbus//usr/share/licenses//usr/share/licenses/dnsmasq//usr/share/locale/de/LC_MESSAGES//usr/share/locale/es/LC_MESSAGES//usr/share/locale/fi/LC_MESSAGES//usr/share/locale/fr/LC_MESSAGES//usr/share/locale/id/LC_MESSAGES//usr/share/locale/it/LC_MESSAGES//usr/share/locale/nb/LC_MESSAGES//usr/share/locale/pl/LC_MESSAGES//usr/share/locale/pt_BR/LC_MESSAGES//usr/share/locale/ro/LC_MESSAGES//usr/share/man/es/man8//usr/share/man/fr/man8//usr/share/man/man8/-fomit-frame-pointer -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:15574/openSUSE_Leap_15.1_Update/cec53c85961b4600e49ef0a0837d2a94-dnsmasq.openSUSE_Leap_15.1_Updatedrpmxz5i586-suse-linux      exported SGML document, ASCII textASCII textdirectoryELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.2, BuildID[sha1]=c32a07c31edad6644563d4a7e4236758525e56e7, for GNU/Linux 3.2.0, strippedUTF-8 Unicode textPython script, ASCII text executableunified diff output, ASCII textPerl script text executableHTML document, ASCII textmakefile script, ASCII texttroff or preprocessor input, ASCII textC source, ASCII textBourne-Again shell script, ASCII text executableASCII text, with CRLF line terminatorsa /bin/ash script, ASCII text executablePOSIX shell script, ASCII text executablePOSIX tar archive (GNU)HTML document, UTF-8 Unicode texttroff or preprocessor input, ISO-8859 text, with very long lines (gzip compressed data, max compression, from Unix)troff or preprocessor input, UTF-8 Unicode text (gzip compressed data, max compression, from Unix)troff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)RRRRR RRRR RR R R RRRRRRRRjqeGUutf-894e00149395adbef3c4162923995318972057e878e85e57e3e7a60bfc996c07d?7zXZ !t/MW]"k%n5ӿ8`Qgr~?Ƞ2_=euQ􊏦EŽr=CvDGI26sNMIrmz4_ʼ_73@cL$2֔OD˵O0A!2ֽrpOr@niRS`ꐞEV+=_[~n3&[GwKO3MCP/,2%<+v|ҚMS'}4/Ku*g&mO~>zʘ 1Lʮ>QPSW8v޳}Sy%t7-k1d$S$_O NJJ]"P-[ۮ`8p,agJ˅#wieF>;+ҙnׅr̗:F$teZt;9qEU ZHp"RF 2o1r'lCgWŌ;tǓY:;IJY1$u4(a20Qg~Hz$a0ij# > Xf4 +rAѥ~Ons\1V'1v뭆G%ycu5}svyJ~ +rz:cvpv`'QcrzOו,$ʺrmxҖK͟#,1_oM+h2']Nr^#ukS_Nr6Fb5ษzqmnW71IdCd@MF7|oFZVa Tدy6*뗟Ead/ܴI$U9R%)^((E/0ХvLd-!BwgV=A.xw~"ôRX&&+cJ m W.J3@[tݏBd9`skSE mj095DlWm3XL6K+z Z_PŒq/BIj~+~Oqb;׼mPp{krƤjirK}^ \W+n "ie;LG栝oJz#mޱ@8Mv~UB83 Yქ<lʾFYvKDC_5i>}#vPNgj-;"S_b_܁Sx>0ǤV㠱+|#6 tKkj7 v7Nܪ ʬҺKy7*FrhWyfͽMٝp* `;Oiy$_Lr/hN+l/~k`PlV^"n<*sF|2*b]=oƙQavrX*X4J-Ir;P3n&E] F$dZpdЗlh<0vx'u{#PΪ4` ߎد9 NIhG[h3v!,^է12?T6q\lWF?|; {4GY6Rb$;7|Fھ {t`ʉ3Q:bZ,M]Hd)tt/]ݡd&U= y|A~&ycRU㬽.ǓA]azQ_ggaqX (^y>]HPҋ=H?7]l~Pmؤg"~ZYq]pG,%{wG\v]O֩%јj@nL$E{kSqɆ>O[EuXxN*O :fgx0evłfcl" i"^m_.'Ic0W28y}XV^ Rp*55{T't$Ұ% 1P epc o6]Gʒ ʢ*y]e2İR ʇ\doK5gج<}}[F/w_m3YcK&!z>$Q1r|*" [yhZx-ȭ5ob.-qNKn0RE%|!CU);L tY e=^p&N@"ײ'ǵ!+<}ן ~q-w**iW: dw^pP ʿޑiTw~L|mfmYi/@Wz>^ˀlԋd=$k3-!)To5zeqg BF6kB> 0P- _6 |PBPkêcZW'I)#F>3qvb,zY{T&6,{?U`LGӷ +1K/c5o q+'x+“t9lF7؟ j] @z=ܐF|w>,_.Ly{oX*hzɴ}9j1uSUO3ڮo1iTWϨB^l7 -hz(<$9كhh족6g/֠cRzNSp+^gZ-dOY8Ü9_HS}JZ΢ȏ/:(Lxl:0(ڇ_&QYb0Q]*hLvA w 9\4r6C GļMs+MP/,c3*:j97jz/fNoA}qޗ%}~C TSAY42xoݶE>PG[gf3I\~ !;:gPh[tIhmo]YbGOcT+[L51-lYᅀLӣ֝:WJ%^7O%#Y"=-idAA:Rg .ިhBhY]>2:6E|vP4HRgB8AѸ%ÒkoU!t}R!=J8? +јΗH[>Y'7lhxLAuUrlcw+DN ? ͤ ME$KW0 #⨏ܔ: ݤA5:+ޥ4#pi)6P_Xڽ5R+Tp*y`2#`g-W)d։7ɾ6J4f6&vRkgp9>hiyौ?reIPb1z[ZМdFE pfF+e" jg#|0opDIbXFƇ~"HI4< OзgΤߴhk囐b'q)M պ*h=1;qAE9'r][bsp j~xq4支z9=kz^3x[LM5xWD~#mpo2 ՔnJ뀖6MW6?kW:iX> _F:Y^<]i@Xg]7\9uلb6eHCݯS-L. $zSʚL,Y+óXYsq.q62XXMUdjl蔡yZM%\并DX25yKa /ŶeB4ѹiq2Q"[SzPVW]K ^th9=:=kX@zN&rcfүq {΀-B=IZŢ@~g~ҏXt˟)+ c)`(j&-I {s5ڟ+#co k5__HH2$#eg/P); lø0aű&0,mH*ك;0oDYw <> t"xHoFFch< 9q?wݿpȣj ׸q7`{C"(ߖGzܐd<[$Da@AK Rܕtm2 _uvSYwx8@qrQЉ0KU\HYh\I->80Nat v kzn ! 2xT"w9#kNF/3wE E_6r-cp;U-;R$ݑEѓV F lVeOR* %[[t6<_Ƽ/Ⱥd%'TCqb gwDFBU_K[u{@˺a5/(Ҏ@M*zB=a/DhqVc OBe\j0Oܦ0M@PE/Jɐ[Y0 A; S$'r[DKgF_ 5+c6j@mqm-X+4\i`az滒]I΃@ssIwq' ebSP%7Nndƒf/C:Gh˱X"gRO>%wS[ݑh82Ұ͗hyU8f-:f@9aA &8 d(ǎ+>e>i$# Ț_4 q,Sw&mB-߈#]MV6{숣fsBhPk4o]Joٙs*B^yxoj&ȵ# !#lh!Kxsb+*(s}RCRpp383v0{~rab0%z*7zE,|)1|z86=vCWz)pZgKlyn} nԤWngu-hXFjQ)1+C4b7ʁ! ݀=hA6@ݥa,L5|&gkWr0)WRe9GBIŽN@vf E҈mݶ`~v:bd$mC l{8_4 C1{PY Ciḻ8ZE` 3R:bQ Qd{osc`·-~=}Sc-0^6#g/,))}Gj0/mg&ocӃ;Q @ƙFSilOe=E鞽G>9vA D?OĚg êY2x44TO[ tG0Wd4 Lw^H2+ ѕs{@ZO~r9잰VTy28"\axB hLG7$\*R\U9\ew}F(VH)I,?~͑SϖVu#c"΀azR??f/Tu]uNb]=Oħ,]ԏq_BE\sӝ V}QE~]h/5殡oʤK+>!3\?Y+CBu9"d!yyKVPޱwLX#eА"^[ C6 #dK=ءEVtIr,2IyV" @216U4V@Ǘ]@C¯ym=FY)\FGD1})GO@؉J2 m7 `Nz>JS͌2ba1"I ckAdǕnBKu& {Ub?6IU &5Q[-Uw \U`gr}6ewٱO֨UEFR'u}i1j{xu((Od4" @>=mMDOa j!=H'r7YzkPD J(<C5CT.y#daK WEPoSK=ݶE)z@=Ts_a\ _!ZcF<L OJυ@rjrSbB9M@R\7c  ɴӛI`ڦ{-Z,]zՖw5|2U-4( _zzy=?c{j)el0&39%mcY/,s -g2n}sLQ`Or81%Vb$lT׫ }|g/oXc7o3!tR*5qTbwC#v5` m9 BVpEImE6  tBlİ˴C8}YwcC6UBp<]4V/5\}ZKZM@ T28 =%%'E҈ZwONDsBBUc 0᭸kJH~`箴-t*1[Y`?)G6.t#T0e|5Ү}LM"sj4NHmg+i tkPaݠ&gxl*>%xˠKnx^~4Tr {v<=zgbL?փp/3dw ӭey^q<TcEW9.CŹisc:@:?CpNJVRcWTh2;3HSpt˓+ׯȺ(f"%"f&!VBkVv`KMqˊCT.@'w/EpYR O!b]2q>VRxxEW$W=Zm^KVRc< 0fy@\&3a8Rld^x.쎬hT LCUijM0 ~$M|y[YA- sogQb(&KW1Zn~̢;!@ؽ"&Q@i ;<{4{_մ:4Q4wxjmj T Qo/9*5.Zai3wq9^XƼ.51@=;U1(U>[$`CWŔ)1Or/շZ(WX/Wɳ~=I Bjuy@Cz Cίt@P˖Wv ܒ!л6?aQQK z&\ՙYP3'lfc3KnC/yOKd \mBܖ3a#/w{:e{6YT-ZAbJ P@Fڑ"Y(y DWIc<;JKK@3>"c"돼K0nCyd|hY#-V,ĸޑO_KveOyFmzPNeo7iՐݎ>N;0H RDRJ߾/3tO~B"۴Wgl1@ 6VHl៍( }9_/$'o~^3-;1$R22h On-FPgp:!TEdd-ټsY (aHdTq8i2?40CeD ̗'2q]$)@#/Q?Ԝ i/5YpQp}=UgcC{~:M$BNZaX&̇Ί)Cȋ6V毼& ARA`p; ;͝\nF;YQc藇²yiqt"z'/_싹0u~RlT&d$W!d*g.a16u[oV Smy49~#} M\ҒC%mbQ*NOڷH;}SuM!i]ds#y cw]|{@B7Dzr1wD6Y8Kh"4aSDmro}QA3jnq?`dKdGEK@uXP5e.^| KECl*J$@5aZ劔l 4r۞}PKTfKӈFA?ؗCDQbV(^.+Љ6)JsOZQ /x vCE< 1Ss`ؿ=,LVyM#>/"N? ~)sWonO^O[UK>N4^nnNFaaCH# |ǿ8kϫW+S )հg>\V;!5.Zp`OE׎ࡱm׸#M}v<FPT{J8Esfa$I=X-oTɪg6B.W)l(i2">2O sP[VVoڜr3,\CK[{tAv9+^ h|sdKK aR\ٓ",|wG{"3}B䮇TV4KajK^}}Q5ái]QA#  En $SgxZv'BD-ΉiN:0/HjM滮ړB+?$$8 (-f fW$yZ|fW="IMU%[^؆ S)F7|C]Ә7ydx Rb}#S"_M_yMXpsnqBy 5CGY{RNxWtGB df~|aN8EOcqE5%$$gC2.=R@SLHg3 w[ug/ CQ+J0qMκI:w Z*glVT4,j<>g^I)DKAa_{N~{_VBԣc[>,kod᮷:)w+Bx 16Qw+vҦAΦ}Id =%mIǚbA_;_I[ˑ/8s'uϚW*) 4_ ӿC1Tq`&+TbCrp8Ð(cXN'zl#h{: }a5Kٲg Hbn QSxɨp2,q^ 6M7$M` ^F AׄʐdF2 {kt?^`!4.D׌0I @Q)If7:Қ@q_%ETqzrA鱠ވ{&ZE|2q6źғBXt&\CG ߡT-S5Z/抶dLm| c}xI'G] o0[n SԀLևv^Pf8m`GZq  &OWϣcNd&2U0>j4ɂ,4b_}N nThw4 U˃N/b^WTe\ SO] $ezyQ=ܰ[;/TGs,垷ib'VQ, 3 +=L\ >f>D XZ L\U+ksW7A* _|1MP$7垙gi]qDIPl6L|>|x-$}l9J-[@L~lqmX>Y3 u׀ULcxJV@n1Tv %;&< yJPa:XoOku 0ЩķPd,RSr;8d}H9c+i S:Fyyn -7~Gx9RT򆤽nehHǽC[;mM<5[ P'SYxުh9?}.O M­r(Us]ɝa+(QI PJ׏dӇTc38'N+gytW%Rڑ-7 3>Cڅk۴%UgfNhhsoۦiVG,.P?7@vp!:O"gQ^YBW9eJNy(|7 z'[4I}b%ǰtE8\d JJo'CѲ39 18 1{fCzU%aM+Lf^ٔN2ȧ x޾"1o3s9CweEϪTR3+x>g?}pq,;Byq.ΝxϰO6YLB9͇6hDΆ?H__թ0ӿR&S.\o¡To⣵j:n:.,bS)7uTЍ{JU.7C2}7b̓׉"8l[?c~/Z({t=-iQTdGUHM,GRvtίKQX\ $AN-q Gl+0vX7]û& _( U9Jj^LGq<9(MƖASJ3: eJG3.;UjƍadK6߰&JJ;Z_X(*2U9rέ7lCwxPnlR,_jnUqMvy4 DEhjϞJwbaiPRlѺnW]ii=&8k=XS$ !iGt F)bco#)&Ҭ?}O8>6X)0 zY.%=~l5`$ռ]Qh9Scу=dc:@s gB&$Ty`Y&, 8YA` DԬ[\6l,[r? !LVP|E~Kj`UCc>'=:%>pCJ m=sbgSˬSgO{CI^B{i _1` @No|wҖv]&#dϦvmݸ)5G\;3 VPyjmsً :~P V:50 u\46eyqfwXɷ1Ǫyty_E(DVbQFt!髧Q{+A]!I܊{:g\zA'W/)*_-scukƓŭ18Gj(n8f[/if#ls|I xm&ԮшZ!yr>)NsLudHZU<(?hmMs97 ` m7Q=b2B뜎 1L4w<`mKmLntN!5 g/1Il]Q(=n2(ɬ_J>SCVJrjCҵ aqOO bKxXx[ ÍeVs";cY=j1,DClbD9pmI$gۀ5\M0a?qۙE OTpLbH,, LyuǶQ~1ɻ3P@^UbwwK-8–bkdH05 A4NGU&@ ( R]0nfBHh'OEN-ôēE5lw0  i#Gh^nmq=T(9$Óv(9+jٞ{\\k"(.Q"E#ŁHoj /bw0agj65>{xw{a$ 2yv oW&v[@6¶,}i99J(5YZ+ B"g3ʲ&9GM`7Ӟ;l 3w1(z7|i}ᥓ9,8{PӺ`&ˍ@w믉'UE*HçȝF-`4̏EnW;36?1ppKj=_jj#`<Ć (0t`y5! FxL.#:)€깱+=e P@UMuiyxa/t+AvNXk=zu?Z0i #PUV_2^C"G1c;)N`ȓJ*x" Ȟ+8rL9Ӟ [<^Xp<%36sll+*]KncyZ4+H BC-vAs")vx~\:}n*)!LFvZ'Ÿ T.g_%*Mmdʜsag[8ӻ ?qu:0{-=;w?7Ov[/gX,ܚ@ .M7Mʹ\j>_~'@{;ot䜗2ii $[PTFgIu|RLm/% e XS92RbJӶ+i_g3 u$. X[ z&ÙsFvcjcG?Q-,@QNl}Y DxS-󟌌I*-x/ ۩y$ko6ֹkN 4uŐ2O)&*1ON1@g29mkÃ9tlknHXƩ+N&kCLsLk^~+ P]fXJ,E!sµ na^<*Dd[XׯUDG ;}ts*#3ȱJ`b(KTPKPgO%\YϕXms! |=g-/Yȝ#t:j5Rѱe~Uݶ(\x(Ri#th:1ۨ}Ss75D$ b&6wx+dzIٯH(rD; VN#bIN;7F*mGvkTtHK_ƨ،1pT='sLn^lZA6][ =G9Jo̵طpis(!YqrX7\ "|i&=w V5kZ1reGxPKe9@eg.;={+uR!uf6m|l ]ׄ\`cE=c e%[̚uGL@]A7$21XjSw[> }|*WٌL.9]JHV͚,3+l(whh肘u[Hybp4Nf),ay>RTkmطךIE9i҇) p:#?B2\(, U>a[huKezpI bq/ NOcS~l9%;#&z@4& _P~hnߍrsS@uf:"cUʐZ%g4%]Lu%yF =E|Qo3Z7QO-XFƱք&ELUk ;ɨ{y&qq$нVyxnhcjPj QapVJێW]DK&M-VK)bZ"WB+o`cPgZ|BO &y˻Xè(Ԗ(FxB,FMNV }e!(m̥JDj P-4ޠAI^vW.#wLԳT!X1"hrVa؂;kױ[8Fy mlzcPPSV2Oe9z?q'xv`vd] @?)A|-2=cƐ|FhK YĠ C? xg O-RV7;hgc}=]P AGP%ٱl^b_^\6*V>C=ΣS>ۚ4潷{je$_2u6 uAt_+tQI%YNK=f`U| Jr&:q&s,ށmyojڬCvH>f4^`H6I>VJnAPPL;edČ䒶/(1EטveM:EYzQ^M9%Ly}Oݽls/DWUsRyA"HO{<#v)5ER$_rk=_k !q>{A]su(K#5R Z\|LE?T`N 4QTCxdbYD< d8]M+(v{mT]Ƣmx(SK2&5ɶHV')L/#uVFxR!B҉ƾٰytΐ?!.S YZ