knot-devel-3.1.8-lp153.2.3.1 4>$  Apbr:T/=„,EoLʛs_bY`bYc?zo6֬CH†)&H,B=X{a};OĿS.hELLjtKj\׊4ysVm /Bi_@x+np” mԗlƠl$>c=w=+l6AҪ{~ 5Jl"XG*1~'`~%W '!/s>_{ǐ Ë,7OLa3f5b777adcba48b8f528627fd6645c7341d8b951d65520901e1a7221e881d023cb1e4f81a5112f0971d798f2b5b98314dafe72eFbr:T/=„aK]%kp, 84:wU y?bH&[膙 M YD>`͊ នsb]fQi:hT4xu *4'Hh9`6zu QqyC%(uk,ƙTNaޢ]v"`fbu,>hLzrAsp>?|d   H<@LPcl} U0U U U U U |UUyU"DU 4  ( 88 @=9!4=:(=F.GDUHUIUXDY\\U]U^bYcdefluUvwLUxUy z,06xCknot-devel3.1.8lp153.2.3.1Development files for the knot librariesKnot DNS is a DNS server. It implements only the authoritative domain name service. It uses a multi-threaded and mostly lock-free implementation and can operate non-stop during zone addition or removal. This package contains headers for knot.br:+cloud132RropenSUSE Leap 15.3openSUSEGPL-3.0-or-laterhttp://bugs.opensuse.orgDevelopment/Libraries/C and C++https://www.knot-dns.cz/linuxx86_64H %~ B QzR N*- ^ J 0''Kv , tgj U  GK}& r  >"" 9,)AA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br:br: br: br: br:br:br:br:09f99b6ca2eaabc9b6d7214cb872d10c83e8d8d2326b7fb803f4f762677bf5ddb4fbe48c632018c0e15b531c25797c3b380cb0ec35f0a597a1f1c94008220b58f676aed7ec38307f1d7282f86ec4f894dd4875c2429109cab92b9621525966da759f07a1c22a4825047d93059c1b52328484334b7f8594b3511234325224fbd8bc13139bb264cedbb87f2c05521f7485d1933527c92e8a7a212c6f8ef2464203dbf9aaff8cea91313f84aa0debeb5dec8320826f796327da580a004cc05b2a3b984d4b743dd141778bdfd3bf2d5fec12b0d5308299b64e0e505bbb47a5ee8e158e9c208cedc89ed277c48b97086e1455d2534705619218a1229e97234bfb0b9e85dc895d1c2610cef7f07c2ed8f7ff2636a55034385513452f53e85c2754a05492ea22cde12acc55b67f797071c03119cac1d0ecacb187646052b5ec9bf692e8f6cdd36b572a22aea68204f86f208c5f2a052cccfe73a5430b0dc4dbe6a9db0bb9fa74795774ffc71a964f8b7132997957fc0ff8ea37b1f21d1f49c112b28d74c3ab9738bf7c69f7db401b34ed31bd9e48c08cfa8342be5a4da775ca1f4b1dd6919f3837757036c1766ffddfe13b4756a180dd56c94acd798fed6d1d35454f28c3e7b2c6cc75abeb22f94d2eb7162ccfaefa2a224dfd135c8186472796d057e91d8c9c03cf80b51c99e670863a9772efcaa888a1232ac92720f08b308cdb3dab7d3c4103bfb975bb72df32b83b0f1454b68af76d0a322e6012bdfe33e314ea56356c8cbb03da42bea5782d1be42b41537bcbc3ad7c9e8402b43e0cf953756671e4abf7b397aa3969243bd0a581b3ec836e045d4fe0f248e39b31cb774b2cb3aff32a58f74c4c364ddfd5c442ed029357db68f678a26dc4201233061a783ebe9f67af608031639b271fecd0b35ab0054e67bace684a983d9c96599ea7ac28049709e7cc98c3de9f322e232b419b010057a85ae809040bfd1d4f7980d352ae3a6573aeabfe39a9aab4f6bcdbf0693805d8fbdd906c78ab0e955f39e7eea5977a041757fd765e25974c4b01ba40214d4cab0626fc506a1ad7a0e8577b3aef19a925a76fba7b07eb4c209be33f8f7154df31d7aedf3457e9148651e346aa504e1462c92f4510920eafba45fe1de8648af2abdc249bd6d9b66715b5b8a54ed85c04a98339221ed02745e1eaea274398e0baf56241e8a2200a107016679baeb184705345c1a06bae79ef63c42672bc930378393ca1581c00d473c52452f2175a51ec4458e98e645dc38c07683155eddb86de7923433eab30ad72bc2daad46bdf6d2baf7191d36950be3a402aac76dcf9f532c6dfbb60228158cd280701096ce5420acbe8eedd1ffd1b8d6b4a571ac894a971feaa6f8c22733f678fd15b7ed149c6a64fa554f47b5e1b3c0d5a226d9720bb3cbf391fee27b1a70850972b4469ce0948db81b62373ec7b7f48dc28d3b26cacca029b46cfe7d4815c72d5253618e526d5f9a68f1993f6d90e0428b4585ca5be835eeceab21017198d81b3819c40046ea8ea9156c5acc89c8272ed367a5e39697095241155a9b48283f7e206fdc4345c99e734245ed008a00c55b022308f1e325cdd2ccd6476828068ee18c484d9aa5d85a9d55ee1bcd8a6c512fbaab8e00b5a31d025c978aecbda25a32caccf45d637996c8c1f236013b0d9444d41938e9731025dca6c6b6d23855ed43a96e608cb59f50b819eaf771ec0e6d899266644885dd3b825b7137307935b3ba7f3af24b8b3536fff1cded7df7fe32ed047aabdbfbc878e4a090daddf8cbcf961b104eef29eee38761e4d542ee9df287a6e20403a08a75476d01eb55697b3903695fc4e8ff5dfb39fe9b4c0f6fcac6f57d1fabd5792d97708c868ffa8985c98f69b4b0062de6517423284635714ee1a820a82bc17197d1334667b6b06ef1258a93c21649c8a8b4b91b4063489f544e810bc10ffcf7834cef2549c53a9b6b81cdb937c0bd08f121aba302841a71120e7dd3194c3f3e51dd2b2db50acaa6e0adf5a10b15d83dfcc30161dcdbfe3e0ec3bcd4ecd1b35415214c84ec3728b93cde1d58ef253337548c27d48246cdfa95df787ca6e01968b1165e23e9f213a3e8092e3d55141db8a229a257e33b5b78d6e416ca902cf8a68b2a28e1e3e89a775b91a6df6110fd6a82ec30fecd5f27716fb25bd2f32491a381a61b4864685d60c8d14c3ee0e1e6b27e0aa20460dd0826474ef99b3feb5995b966efbca6ad38bb81c182910e67024f718eed5fda756c4efca40cd701630d5b70efa38e8858ddc6237adf9676eb48ef1be78d484dc095525cf47421ac58917ea5c09e68bacb516577967c3a2ffd12022371430ab2a2e74d275401c78b36c467a06a1e2ced136266ed33508ea1410b3054429eabfee04ff1f14beb1df7ee29fd647dbd56960a62b25caf376211b0be3034b55d8f7790b8ec45a0fa786c1f831fdbd4e539b8ecd63e8f077dc9d0c500f34a77f04b6fafbaf42aafeda061486f3a0cd57ee6661cbb3472354758d8f194182e0e372d1c5b0c964f5b0e272006722d7b9cea85bc01a4a7b2691463264f07587df648545f7e3d73ead612f342602a9d67001c6b31d9bf1817c6692b00909c46644e42631003298e74a56c98121799d00246d344841cb4a4e1cb60499185a8bf7068c0421e33dab3a30ae46a8ccd14e3e4e3438f3167de92fb6d2f04ee6418c41366efad12e59fe2b5c332c6e971c6ee71a317a56253e05e712dd37186e9d1fbf2460d537ac1bc5636d5fdb8a6cc17007197f83ca431b327084bca54022011cb92d30b44fc417912d2af87f0a8a0027d7b857395c8566c5c6773fb43be48a6b25855cd7495e9907dc46930b276cf7b2ec1c5c2b3032312fc404f217416a54005443f8b198f4650054f59842a247de965fd8883792388e3a6cc74c05dcdda579d46b8dcbf76c7f5cb1ac8982be3a2d0c294d411b0f13f4fda39ec1c710b1f62c1554b119ab9bf9634d89f57100ee58f807c37fec92d67d9f242011d1a25b3180f9e2874b8fcba618b81adb3a0785585a360e2697dec1442b336d1b1ed2e354300e0355100272a46f60106c75a2daa961cf856369c1bd7b869f655985d72e82ea4abd03917d8bedd77dc03262aa8868e13beb7c49ea46a8ef9ae2cee9b6dda3a88081063d6878168ad85962b035c92ae204bb3064c14cc312cefb29091a8dadaeab1ee8libdnssec.so.8.0.0libknot.so.12.0.0libzscanner.so.4.0.0rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootknot-3.1.8-lp153.2.3.1.src.rpmknot-develknot-devel(x86-64)pkgconfig(knotd)pkgconfig(libdnssec)pkgconfig(libknot)pkgconfig(libzscanner)@@ @    /usr/bin/pkg-configknotlibdnssec8libknot12libzscanner4pkgconfig(gnutls)pkgconfig(libdnssec)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.1.83.1.83.1.83.1.83.33.1.83.0.4-14.6.0-14.0-15.2-14.14.3bjbDF@b[@ap@ap@a@an@aD@a @a @`ݮ@`f@`@`q`_@`\{@`@`_@____^@@^@@^@@^@]\HW@\3?@\*[@[@[ݍ[IZ@Z@ZWQYYYXWDB@W1@VwV@V@V@V@VTQ@VCU6@U6@U@U&iU&iTTq@T@T@Tk4Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky Jan Engelhardt Michal Hrusecky Jan Engelhardt Michal Hrusecky Michal Hrusecky pgajdos@suse.comMichal Hrusecky Marcus Rueckert Marcus Rueckert Michal Hrusecky Michal Hrusecky Michal Hrusecky Michal Hrusecky pgajdos@suse.comMarcus Rueckert Marcus Rueckert Petr Gajdos Marcus Rueckert Marcus Rueckert Marcus Rueckert mrueckert@suse.dekbabioch@suse.commrueckert@suse.dei@marguerite.sumrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.detchvatal@suse.comondrej@sury.orgondrej@sury.orgpgajdos@suse.com- update to version 3.1.8, see: https://www.knot-dns.cz/2022-04-28-version-318.html- update to version 3.1.7, see: https://www.knot-dns.cz/2022-03-30-version-317.html- update to version 3.1.6, see: https://www.knot-dns.cz/2022-02-08-version-316.html- drop conditions for openSUSE 13 and older - knot.conf is owned by knot as is it's parent directory- update to version 3.1.5, see: https://www.knot-dns.cz/2021-12-20-version-315.html- update to version 3.1.4, see: https://www.knot-dns.cz/2021-11-04-version-314.html- update to version 3.1.3, see: https://www.knot-dns.cz/2021-10-18-version-313.html- migrate to user creation via sysuser-tools - run spec-cleaner on spec file - update to version 3.1.2, see: https://www.knot-dns.cz/2021-09-08-version-312.html- update to version 3.1.1, see: https://www.knot-dns.cz/2021-08-10-version-311.html- update to version 3.1.0, see: https://www.knot-dns.cz/2021-08-02-version-310.html- update to version 3.0.7, see: https://www.knot-dns.cz/2021-06-16-version-307.html- make sure we have getent and groupadd/useradd in pre * added dependency on shadow and glibc * might be related to bnc#1186023- update to version 3.0.6, see: https://www.knot-dns.cz/2021-05-12-version-306.html- Make /etc/knot directory owned by knot - fix reload action- Update descriptions, remove unsubstantiated claims.- update to version 3.0.5, see: https://www.knot-dns.cz/2021-03-25-version-305.html - Update description based on homepage- Trim marketing wording from description. - Drop old rpm constructs.- version update to 3.0.4, see: https://www.knot-dns.cz/2021-01-20-version-304.html- add incompatibility warning about 1.6.X version when updateing - rename back to knot- version update to 3.0.3- version update to 2.9.7, see: https://www.knot-dns.cz/2020-08-31-version-296.html https://www.knot-dns.cz/2020-10-09-version-297.html - obsolete only pre-2.0 version- remove rosedb conditional as lmdb is required in general now- replace conflicts with Provides/Obsoletes- fix dependency: python-Sphinx -> python3-Sphinx- use upstream example config file with correct syntax- version update to 2.9.5 - Bugfixes - Old ZSK can be withdrawn too early during a ZSK rollover if maximum zone TTL is computed automatically - Server responds SERVFAIL to ANY queries on empty non-terminal nodes - Improvements - Also module onlinesign returns minimized responses to ANY queries - Linking against libcap-ng can be disabled via a configure option- version update to 2.9.4 see NEWS- version update to 2.9.2 see NEWS- update to 2.7.6 - Improvements - Zone status also shows when the zone load is scheduled - Server workers status also shows background workers utilization - Default control timeout for knotc was increased to 10 seconds - Pkg-config files contain auxiliary variable with library filename - Bugfixes - Configuration commit or server reload can drop some pending zone events - Nonempty zone journal is created even though it's disabled [#635] - Zone is completely re-signed during empty dynamic update processing - Server can crash when storing a big zone difference to the journal - Failed to link on FreeBSD 12 with Clang- update to 2.7.5 - Features: - Keymgr supports NSEC3 salt handling - Improvements: - Zone history in journal is dropped apon AXFR-like zone update - Libdnssec is no longer linked against libm #628 - Libdnssec is explicitly linked against libpthread if PKCS #11 enabled #629 - Better support for libknot packaging in Python - Manually generated KSK is 'ready' by default - Kdig supports '+timeout' as an alias for '+time' - Kdig supports '+nocomments' option - Kdig no longer prints empty lines between retries - Kdig returns failure if operations not successfully resolved [#632] - Fixed repeating of the 'KSK submission, waiting for confirmation' log - Various improvements in documentation, Dockerfile, and tests - Bugfixes: - Knotc fails to unset huge configuration section - Kjournalprint sometimes fails to display zone journal content - Improper timing of ZSK removal during ZSK rollover - Missing UTC time zone indication in the 'iso' keymgr list output - A race condition in the online signing module- update to 2.7.4 Features: - -------- - Added SNI configuration for TLS in kdig (Thanks to Alexander Schultz) Improvements: - ------------ - Added warning log when DNSSEC events not successfully scheduled - New semantic check on timer values in keymgr - DS query no longer asks other addresses if got a negative answer - Reintroduced 'rollover' configuration option for CDS/CDNSKEY publication - Extended logging for zone loading - Various documentation improvements Bugfixes: - -------- - Failed to import module configuration #613 - Improper Cflags value in libknot.pc if built with embedded LMDB #615 - IXFR doesn't fall back to AXFR if malformed reply - DNSSEC events not correctly scheduled for empty zone updates - During algorithm rollover old keys get removed before DS TTL expires #617 - Maximum zone's RRSIG TTL not considered during algorithm rollover #620- seems we no longer need jansson- limit geoip support to opensuse- update to 2.7.3 - Features: - New queryacl module for query access control - Configurable answer rrset rotation #612 - Configurable NSEC bitmap in online signing - Improvements: - Better error logging for KASP DB operations #601 - Some documentation improvements - Bugfixes: - Keymgr "list" output doesn't show key size for ECDSA algorithms #602 - Failed to link statically with embedded LMDB - Configuration commit causes zone reload for all zones - The statistics module overlooks TSIG record in a request - Improper processing of an AXFR-style-IXFR response consisting of one-record messages - Race condition in online signing during key rollover #600 - Server can crash if geoip module is enabled in the geo mode - changes from 2.7.2 - Improvements: - Keymgr list command displays also key size - Kjournalprint displays total occupied size in the debug mode - Server doesn't stop if failed to load a shared module from the module directory - Libraries libcap-ng, pthread, and dl are linked selectively if needed - Bugfixes: - Sometimes incorrect result from dnssec_nsec_bitmap_contains (libdnssec) - Server can crash when loading zone file difference and zone-in-journal is set - Incorrect treatment of specific queries in the module RRL - Failed to link module Cookies as a shared library - changes from 2.7.1 - Improvements: - Added zone wire size information to zone loading log message - Added debug log message for each unsuccessful remote address operation - Various improvements for packaging - Bugfixes: - Incompatible handling of RRSIG TTL value when creating a DNS message - Incorrect RRSIG TTL value in zone differences and knotc zone operation outputs - Default configure prefix is ignored - changes from 2.7.0 - Features: - New DNS Cookies module and related '+cookie' kdig option - New module for response tailoring according to client's subnet or geographic location - General EDNS Client Subnet support in the server - OSS-Fuzz integration (Thanks to Jonathan Foote) - New '+ednsopt' kdig option (Thanks to Jan Včelák) - Online Signing support for automatic key rollover - Non-normal file (e.g. pipe) loading support in zscanner #542 - Automatic SOA serial incrementation if non-empty zone difference - New zone file load option for ignoring zone file's SOA serial - New build-time option for alternative malloc specification - Structured logging for DNSSEC key submission event - Empty QNAME support in kdig - Improvements: - Various library and server optimizations - Reduced memory consumption of outgoing IXFR processing - Linux capabilities use overhaul #546 (Thanks to Robert Edmonds) - Online Signing properly signs delegations and CNAME records - CDS/CDNSKEY rrset is signed with KSK instead of ZSK - DNSSEC-related records are ignored when loading zone difference with signing enabled - Minimum allowed RSA key length was increased to 1024 - Bugfixes: - Possible uninitialized address buffer use in zscanner - Possible index overflow during multiline record parsing in zscanner - kdig +tls sometimes consumes 100 % CPU #561 - Single-Type Signing doesn't work with single ZSK key #566 - Zone not flushed after re-signing during zone load #594 - Server crashes when committing empty zone transaction - Incoming IXFR with on-slave signing sometimes leads to memory corruption #595 - Compatibility: - Removed obsolete RRL configuration - Removed obsolete module names 'mod-online-sign' and 'mod-synth-record' - Removed obsolete 'ixfr-from-differences' configuration option - Removed old journal migration - Removed module rosedb - changes from 2.6.9 - Improvements: - Added zone wire size to zone loading log message - Added debug log message for each unsuccessful remote address operation - Bugfixes: - Zone not flushed after re-signing during zone load #594 - Server crashes when committing empty zone transaction - Incoming IXFR with on-slave signing sometimes leads to memory corruption #595 - packaging changes: - enabled geoip module: new BR: pkgconfig(libmaxminddb) - enabled cookies module - enabled queryacl module- update to 2.6.8 - Features: - New 'import-pkcs11' command in keymgr - Improvements: - Unixtime serial policy mimics Bind – increment if lower #593 - Bugfixes: - Creeping memory consuption upon server reload #584 - Kdig incorrectly detects QNAME if 'notify' is a prefix - Server crashes when zone sign fails #587 - CSK->KZSK rollover retires CSK early #588 - Server crashes when zone expires during outgoing multi-message transfer - Kjournalprint doesn't convert zone name argument to lower-case - Cannot switch to a previously used ksk-shared dnssec policy [#589] - update to 2.6.7 - Features: - Added 'dateserial' (YYYYMMDDnn) serial policy configuration (Thanks to Wolfgang Jung) - Improvements: - Trailing data indication from the packet parser (libknot) - Better configuration check for a problematical option combination - Bugfixes: - Incomplete configuration option item name check - Possible buffer overflow in 'knot_dname_to_str' (libknot) - Module dnsproxy doesn't preserve letter case of QNAME - Module dnsproxy duplicates OPT and TSIG in the non-fallback mode- Update to 2.6.6 - Features: - New EDNS option counters in the statistics module - New '+orphan' filter for the 'zone-purge' operation - Improvements: - Reduced memory consuption of disabled statistics metrics - Some spelling fixes (Thanks to Daniel Kahn Gillmor) - Server no longer fails to start if MODULE_DIR doesn't exist - Configuration include doesn't fail if empty wildcard match - Added a configuration check for a problematical option combination - Bugfixes: - NSEC3 chain not re-created when SOA minimum TTL changed - Failed to start server if no template is configured - Possibly incorrect SOA serial upon changed zone reload with DNSSEC signing - Inaccurate outgoing zone transfer size in the log message - Invalid dname compression if empty question section - Missing EDNS in EMALF responses- update to 2.6.5 - Features: - New 'zone-notify' command in knotc - Kdig uses '@server' as a hostname for TLS authenticaion if '+tls-ca' is set - Improvements: - Better heap memory trimming for zone operations - Added proper polling for TLS operations in kdig - Configuration export uses stdout as a default output - Simplified detection of atomic operations - Added '--disable-modules' configure option - Small documentation updates - Bugfixes: - Zone retransfer doesn't work well if more masters configured - Kdig can leak or double free memory in corner cases - Inconsistent error outputs from dynamic configuration operations- update to 2.6.4 see /usr/share/doc/packages/knot2/NEWS- fix tmpfiles scriptlet- package /var/lib/knot - run tmpfiles scriptlet during install- update to 2.5.3 see /usr/share/doc/packages/knot2/NEWS - use libidn2 on TW and 42.3 - following modules stay static: - dnsproxy - onlinesign - moved modules to shared building: - dnstap - noudp - rosedb - rrl - stats - synthrecord - whoami- update to 2.4.1 see /usr/share/doc/packages/knot2/NEWS- update to 2.2.1 - Bugfixes: - Fix separate logging of server and zone events - Fix concurrent zone file flushing with many zones - Fix possible server crash with empty hostname on OpenWRT - Fix control timeout parsing in knotc - Fix "Environment maxreaders limit reached" error in knotc - Don't apply journal changes on modified zone file - Remove broken LTO option from configure script - Enable multiple zone names completion in interactive knotc - Set the TC flag in a response if a glue doesn't fit the response - Disallow server reload when there is an active configuration transaction - Improvements: - Distinguish unavailable zones from zones with zero serial in log messages - Log warning and error messages to standard error output in all utilities - Document tested PKCS #11 devices - Extended Python configuration interface- update to 2.2.0 - Bugfixes: - Fix build dependencies on FreeBSD - Fix query/response message type setting in dnstap module - Fix remote address retrieval from dnstap capture in kdig - Fix global modules execution for queries hitting existing zones - Fix execution of semantic checks after an IXFR transfer - Fix PKCS#11 support detection at build time - Fix kdig failure when the first AXFR message contains just the SOA record - Exclude non-authoritative types from NSEC/NSEC3 bitmap at a delegation - Mark PKCS#11 generated keys as sensitive (required by Luna SA) - Fix error when removing the only zone from the server - Don't abort knotc transaction when some check fails - Features: - URI and CAA resource record types support - RRL client address based white list - knotc interactive mode - Improvements: - Consistent IXFR error messages - Various fixes for better compatibility with PKCS#11 devices - Various keymgr user interface improvements - Better zone event scheduler performance with many zones - New server control interface - kdig uses local resolver if resolv.conf is empty - new BR libedit-devel for the interactive mode- update to 2.1.1 - Bugfixes: - DNSSEC: Allow import of duplicate private key into the KASP - DNSSEC: Avoid duplicate NSEC for Wildcard No Data answer - Fix server crash when an incomming transfer is in progress and reload is issued - Fix socket polling when configured with many interfaces and threads - Fix compilation against Nettle 3.2 - Improvements: - Select correct source address for UDP messages recieved on ANY address - Extend documentation of knotc commands - drop knot-2.1.0_pkcs11_check.patch- enable libcap-ng- fix configure check for pkcs11 support: adds knot-2.1.0_pkcs11_check.patch- fix soversions- update to 2.1.0 - Features: - Per-thread UDP socket binding using SO_REUSEPORT on Linux - Support for dynamic configuration database - DNSSEC: Support for cryptographic tokens via PKCS #11 interface - DNSSEC: Experimental support for online signing - Improvements: - Support for zone file name patterns - Configurable location of zone timer database - Non-blocking network operations and better timeout handling - Caching of Critical configuration values for better performance - Logging of ACL failures - RRL: Add rate-limit-slip zero support to drop all responses - RRL: Document behavior for different rate-limit-slip options - kdig: Warning instead of error on TSIG validation failure - Cleanup of support libraries interfaces (libknot, libzscanner, libdnssec) - Remove possibly insecure server control over a network socket - Remove implementation limit for the number of network interfaces - Bugfixes: - synth-record module: Fix application of default configuration options - TSIG: Allow compressed TSIG name when forwarding DDNS updates - Schedule zone bootstrap after slave zone fails to load from disk - avoid activating the intree copy of lmdb- update to 2.0.2 - Out-of-bound read in packet parser for malformed NAPTR records (LibFuzzer)- split out shared libraries, knot-resolver uses some of them and atm we are forced to install the whole knot2 package.- lmdb seems no longer optional- create a new branch for knot 2.x starting with 2.0.1 - Bugfixes: - Do not reload expired zones on 'knotc reload' and server startup - Fix rare race-condition in event scheduling causing delayed event execution - Fix skipping of non-authoritative nodes in NSEC proofs - Fix TC flag setting in RRL slipped answers - Disable domain name compression for root label - Log via journald only when running under systemd - Fix CNAME following when quering for NSEC RR type - Fix refreshing of DNSSEC signatures for zone keys - Fix binding an unavailable IPv6 address on Linux (IP_FREEBIND) - Fix infinite loop in knotc zonestatus and memstats - Fix memory leak in configuration on server shutdown - Fix broken dnsproxy module - Fix DNSSEC KASP timestamps parsing in strict POSIX environment - fix multi value parsing on big-endian - Adapt to Nettle 3 API break causing base64 decoding failures on big-endian - Features: - Add 'keymgr zone key ds' to show key's DS record - Add 'keymgr tsig generate' to generate TSIG keys - Add query module scoping to process either all queries or zone queries only - Add support for file name globbing in config file includes - Add 'request-edns-option' config option to add custom EDNS0 option into server initiated queries - Improvements: - Send minimal responses (remove NS from Authority section for NOERROR) - Update persistent timers only on shutdown for better performance - Allow change of RR TTL over DDNS - Documentation fixes, updates, and improvements in formatting - Install yparser and zscanner header files - Improve lookup of libsystemd build dependencies - Fix compilation warnings in endian conversion functions on OpenBSD - changes in knot 2.0.0 - Bugfixes: - Fix lost NOTIFY message if received during zone transfer - Disable fast zone parser when compiled in Clang (workaround for Clang bug) - kdig: Record correct dnstap SocketProtocol when retrying over TCP - kdig: Hide TSIG section with +noall - Do not set AA flag for AXFR/IXFR queries - Features: - DNSSEC: separate library, switch to GnuTLS, new utilities - DNSSEC: basic KASP support (generate initial keys, ZSK rollover) - Configuration: New text format in YAML, binary store in LMDB - Zone parser: Split long TXT/SPF strings into multiple strings - kdig: Add generic dump style option (+generic) - Try all master servers in multi-master environment - Improved remotes and ACLs (multiple addresses, multiple keys) - Basic support for zone file patterns (%s to substitute zone name) - Disable zone file synchronization by setting 'zonefile_sync' to '-1' - knsupdate: Add input prompt in interactive mode and 'quit' command - knsupdate: Allow TSIG algorithm specification in interactive prompt - Improvements: - Zone dump: Do not write class for SOA record (unified with other RR types) - Zone dump: Do not write master server address into the zone file - Documentation: Manual pages are included in HTML and PDF - drop patches which are included upstream: 0001-loosen-openssl-dependency.patch 0002-make-configure.ac-compatible-with-old-tools.patch - also drop all buildrequires just needed for autoreconf - new buildrequires: pkgconfig(gnutls) >= 3 pkgconfig(nettle) pkgconfig(jansson) - create devel subpackage - enable rosedb and bash completion- local state dir should be just /var- enable dnstap support for factory and newer: - new BR: protobuf-c and libfstrm-devel - prepared lto support but not enabled yet, still need to find out which distros support it- update to 1.6.3 - Performance drop for NSEC-signed zones - Proper handling of TCP short-writes - Out-of-bound read in zone parser for long domain names in origin (AFL fuzzer) - Out-of-bound read in packet parser for TSIG RR without RDATA (AFL fuzzer) - Out-of-bound read in packet parser for malformed NAPTR RR (AFL fuzzer) - CDS and CDNSKEY support in zone parser - Add defaults for TCP config options into documentation - Detailed error message if zone reload fails - refreshed patches to apply cleanly again: 0002-make-configure.ac-compatible-with-old-tools.patch- update to 1.6.2 - Limiting number of parallel TCP clients (max-tcp-clients config option) - Ignore refresh and transfer events on non-slave zones - Compilation with Dnstap support on FreeBSD - Possible file descriptor leak when terminating inactive TCP clients - refreshed patches to apply cleanly again: 0002-make-configure.ac-compatible-with-old-tools.patch - moved autoreconf -fi to %build so it wont be tried in quilt setup or similar tools - move up the %if case for systemd in for the preun scriptlet to avoid warning about empty scripts on non systemd distributions. - used xz tarball: new buildrequires xz- Add deps on the docu packages to regen documentation - Enable systemd integration fully - Add dep on libidn - Cleanup with spec-cleaner- Only require lmdb-devel on (Open)SUSE 13.2 and higher- Updated to 1.6.1 Bugfixes: - Journal file would sometimes outgrow its set limit - Fixed incompatibility with OpenSSL 0.9.8 - Proper handling when machine hostname cannot be retreived Features: - Support for DNSSEC Single Type Signing Scheme - Compile with lmdb-devel to add support for persistent timers- Updated to 1.6.0 Bugfixes: - Fix zone expiration when AXFR/IXFR is being refused by master - Fix forced zone refresh on slave (knotc refresh -f) - Persistent timers database opening after privileges has been dropped - DNSSEC: RFC compliant processing of letter case in RDATA domain names - EDNS: Return minimal error response for queries with unsupported version - EDNS: Fix interpretation of Extended RCODE Improvements: - Maximal size of persistent timers database increased from 10 MB to 100 MB - Added logging of persistent timers database errors Features: - Persistent timers for slave zones (expire, refresh, and flush)cloud132 1651653163  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTU3.1.8-lp153.2.3.13.1.8-lp153.2.3.13.1.83.1.83.1.83.1.8   knotknotmodule.hlibdnssecbinary.hcrypto.hdigest.hdnssec.herror.hkey.hkeyid.hkeystore.hkeytag.hnsec.hpem.hrandom.hsign.htsig.hversion.hlibknotattribute.hcodes.hconsts.hcontrolcontrol.hcookies.hdbdb.hdb_lmdb.hdb_trie.hdescriptor.hdname.hdynarray.hendian.herrcode.herror.hlibknot.hlookup.hmm_ctx.hpacketcompr.hpkt.hrrset-wire.hwire.hprobedata.hprobe.hrdata.hrdataset.hrrset-dump.hrrset.hrrtypednskey.hds.hnaptr.hnsec.hnsec3.hnsec3param.hopt.hrdname.hrrsig.hsoa.htsig.hzonemd.htsig-op.htsig.hversion.hwire.hxdp.hyparseryparser.hypformat.hypschema.hyptrafo.hlibzscannererror.hscanner.hversion.hlibdnssec.solibknot.solibzscanner.soknotd.pclibdnssec.pclibknot.pclibzscanner.pc/usr/include//usr/include/knot//usr/include/knot/knot//usr/include/knot/libdnssec//usr/include/knot/libknot//usr/include/knot/libknot/control//usr/include/knot/libknot/db//usr/include/knot/libknot/packet//usr/include/knot/libknot/probe//usr/include/knot/libknot/rrtype//usr/include/knot/libknot/yparser//usr/include/knot/libzscanner//usr/lib64//usr/lib64/pkgconfig/-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:17475/openSUSE_Leap_15.3_Update/513be1e66e456dc3648198626ef73598-knot.openSUSE_Leap_15.3_Updatecpioxz5x86_64-suse-linuxdirectoryC source, ASCII textAlgol 68 source, ASCII textpkgconfig filePRPRRPRRPR$K{`utf-82db135b56e9ae11149ff37da11dbc728f1562b9e35d930926c2f6cb8a4e837c4? 7zXZ !t/] crt:bLL <퐼i\.o-\c.hQwʽ7o;Y38ɾA]xI`V }J <4tIJ<.)x1*rO|јkdl~Ԯ"`^FA'JH-9 #Nbn-=3Iýdĵ@z ʳȏ*U J?p$׫}tf{=At=f}+B)+~ =D<Ͼia9:"nkD3uVML&P YaVw" N=YFp;\hZ6>-< *Zp,X:$\7fc(=eK|5Rg^ *i\E[)4'6tq;;Uu6nZ.θN U\30B`#Q1/ܡg P< | ~cYZbWU`Bo:5 5:T9kp]:n `w5~F:(HU5Cl}d'qND^j.k.V thijjɕیBta෈BCHhiʂ-5LxG Yۜp[Kf3y|V)/yv$ \Fw[}z#Om+w?i`fKl'݋PWn8tKDttoQh#/Q4AQA'뭱M$NYgD^ vnVpLckI+!VjCP~< -nM#ƨ(v-EQv3TvcĢ{n'C=&Maҥ "GOyg:r?~([QN*t*$>rUϣD7)HHǞ no`=Cnq9\YKj<' ALnMWXjrN^XK6fz6!w|NK= x ,gdNϣ2D7\<۠r5o3cņFO$yOtQꍞ J1"wT+X|v LZr j<"2Rpd}mv ܷ®O@k N%خy/gV$2tIIj*)7(@H$eu]drѥq_n_$|[#+  ?`^thbN1BB J٩ʔ8䞽Hğ1jgL',w| iKǶrSj5TV$ Nw:uSno+TDHy a~z ncFn Z-`hEn%\uu$jGBkU W1ȕ8><ܠTZ\-nZ>dom))\;[B\uwzuy %3h?Xĕ"dgNigёߠ)UH 4ubżnH|}n0G|LgN-)yѲ$oY?Bὣ}"loq:hRB;?B|Wnπ= 1-b6X._<=A,^^O?V=ivl ^zIl9H AV8ij\ԫ_ΨN  6=Jb12t%7P*YH.S7hy4/ kz~,i5ųW'7N]:LY[LGR)ixr,X-@.Ň`=ځv Rg7, 36JvYw>l;,jM6m%9qVH=0I"*`Pzu!SZ9R|&LDR?y,Ǒ4H ?yr eք.2_wʰV|D-./ 5SKGo˱mė<E'Eiy<'>&I ;r1u5uE̢(A 0nV.eA!%& GGmcAt7R G/bGO&@e3jVH} 7G'PmҢҽ{TAwokNF)nj?W*=߃E ;ve$وZ?&*ժьR:˙(pVobo PqPkf,vّRHuG_Ӛv><%NK|{c^/C6 Veچ ϲmlMN]Z_2sfJ%h%_0RاF8|u(ٸM'E,g!)pf'AV _Gsl?"/6s\<3`0*S~D ~r0]Pu-B ;{хŎ/r `EwW3X" Kl@tHlyJR9Ǒv"P#{pl j$MzpejFJkKK6nڸ 75 X= XUBmyx99z|"J/LڹZȇadpk\061=uV:+ׅ\f[bj8~O1D;xqH8ZDΦku=Xum ӵz\싰p6Ӥv~!30K}zSo u()ӡĪ&f_q#eW@fyqD }:@~}i3(mvԧ@<AyW) ;3HH> 9o|K~ֈzurr]qS/<&V5bMQxU`7O},՗dʶ)\⌻Ԭg҃Ze_l {D\T@(3LBmЉk}K-"0zڡuy)6<d|rxm=} r/ 29(_;Qg%ȣr. (-Z.6hY}⏆ܘ cώPV-;/^']#ȥ{!n 0?c1,U`2CTp( Qt~a\̔<*Dp,$ S9Y/py2_ծMEmz|3H]|v3A,(1XXX ; i󳃬ōCKz:1x*sy_nJ/g~A}3wLRg UJ:^%>!W%JElyQgm %`! E=]& gH(qy̲qJ eM))nf~D5eD+cQ-6OKX?CyLKCaCA:ᏸvisC过`kfiW._+l*>s"IV]ߘ<EB#o-)s(ppDh{ xAAK5 I~l QFr˾7AQn%L@D_B}֛"%wqgBCϞj?~ = ϤL.@3j^뎽Lݸu26Ƭ *Z](qΙI:weu(sЛJ0LN9T [/Ɠj]vJAA͈?G-Пg6tY1)/~pE!jx }JlqQ2鶱jȋPeu3+Gv2@70{hlHg=õS.ʰcPD [z4&ʏMA ǭf Ь97aV݇n͛jБ(plv\POZ' 87cr; @H<$Xds0qn$ ]=9KQWȲx:ˮSߒ״n&F\7Tա=9qky3PD~d14Q|6 "0N@8ID˟ƗzIٲϖ,b8BY Ѭwǻ7*c#[@KM`G\z}1p<,mgFp>NCLjݻH QB?Y ;V-E!8ߑQN`]5E ^h(LjG!6\zשXu)T8p ҭ(7ƦI+G6 [(`NUBH84 =8K 7V5v<= *?Qh! L4{z (D9$Փ`/C gEA"!m?0|2{d{=mvϰG'L!`{#of4:k|fo*VMu1Mo2AZC&.2fu}M\ 0͋ لt0 ̣j#[玄8Jh*Ύظo9rMM&)yzY kJYSoї etMn_e>fu"c4~'~m ic]سasTՀYt}c2c6ktZ$sH di^rV2`8yP >EFV|r9zi/ N.~# ْ8;d,A`c7t>c`q#M.@](n_$ntQ֭u1 . `mϋ젹PnLY'g[ s4.CΚg|F F 숴 6αU'| ֔#{Ȱ&KZU1DJp eqTD ĦIzi;&Y? B^BT(FJvgR@IFFݩS$cÚŨܼ=K`2jpiAUTnX\ or[iHxU kR=!b&łSL}1]Nz9=LfOp K/[ jOҹT%SIZ*H蜣<Ȃ5Cj+mzʐng,Ӱ^(>xN?~n ]B}K=eϚΒKZKˎ׼OXi̲*q+5ho˿fF6OK&ys,7W:0/ 0H#ŠUފǢ#54h=Rs%]16JK#%Y5cYg@L9߳Ħފxi]?,Elhap-*V{~>ZV2gRKa8c=1pslP9bRj,W5XK<8qdeZ^%i-V[:!_75Bu-&MM*BDL9PE.Sz7]x9IұPzo>~=5E1Zi[XR"w#+cTGB?)Nv9{fU=CЃ#3'kR촄,ͿÃ]a\B2jᯟ?zӬ?gUV>@&q>u!/S@).?A$Ձ;Ӡq(״(9'ڥI"'Jx"уAζ7iE^苨^9&.Zxp_xD=xWakwDH\e:"Mw f&UXB5,{ ֛BK!9{Ȗx+yC  pY3j=ySc^'m] `/U0BDugf3z| @5-e's`p{7&y?H8z+JE^!3ՂDD :]cY0[oU1Z `at1c#<d"!xv>}"3}'x?}Kј,<Aپ=+5|wYa惾bГ;@fÑnho(xKNx9Ľdžpp8b a,f-|UF\yG@"xQ"Tξ"dyT=l4h;+0Ơj"fiL"}ʛg|o93i%u;"fx P4vqe!R mkhzDK85TF7n Y^pCBx\ w>HH&_ڂUz5%taЖM[^9*eY忣LNdߠ872nvD]=ji δfnlHI%)0[಻kpm4'[Հb3x g4?wr^9&j^a:.9#3 F;G.0ٌ^oQCu:%ܩZr?‰d жuw2 { Ɨ<@XG 4ܔx3]투VAv?K Ecgۓ@&=^CRlΥpgN5KS*kBپdYs:6[z, --JVC`omϥ$GE`!-;԰u;"߶N )RBל̑!IuTH:ksM+K̘ s/d2* s陲s>lu=$'[y~D oae8(NJgl44D?GrPp5<3 L+#RV' M"Idcp`:(f~\AMȿ]Cl$';4;tJ_ɯs M/I~jx)P5߆=iB9iZI=Ғ:6,y άf;Z%kgN 5>>?IA)'qW$7nOSX:d89oMagP \,0r`#2CFoæ59*^ėf0,ej>} W$s> wRf۳tǨ nUi£C#JEtj#7Dх(ӏ ; ,!`Iܔb؃deN6Jo憌-~ t̂c66C`r真 ubvTY7@L$p95y-ƈh2OdyF5`DI Ѭ.ًX\EZTҩEԛ4_WPxg8_hreqfr;4ʝy)WK*gǹf"[Ǩ72шv)T|,y jSuُ+TH#sۻӒ H h@MeAxҜk =CmϺ5`M5+8x %F7Lx lڈ'2jXڸ.7 zѰ"8qhsƧ1󈏳Kʧ͝K[XyZlD$jHhrw!k/&qXpfjLh;Ed՗k[ `*%` AT.Yr挛R[+-iU^+8/QGȘ EBݵPVc̜L1C0aM1,\zK嬮v# 8Ɛ`fX62Fr$yA°9[Ǘ6Xm^0 t}>5FRڄ$m~G5ǹZ8FGd'l$j+ewi9PXإ|x+CGonNi(48|*xp|;ǷY]par+p2H;#zM*czQ)̗1Z5nˊ8ͧ)ͷaOzF|,8p}`&gHkxX,=ieU>LbB~ˌ&wW1Oavilϛ^X;I,!X#tK0(s6'jm  ٱmҁtP]&с`~ϣ t2t)5Y\wJm1Y%2 UY.&k̀HHM:3 KT;Ƴ;y~)t\q+KH0xDP_L.nQN-ls^|@W'/2Cy $N~ ĥ^TR]jIEH3B^Ϭ+(Ɋ%䗐D7,Q,I\Z4H,ل@RD~{/*x GoWT8bil2"ܵc=SR* hO c9ɦG%c"l~t+xn7V9c*C]l_ p;(r(]ۋUi+ PA/ZnT!F{*M#H,ى(&l3y۰D}d+$K3|YT\[X%.I\]:`l!W{A%դN/K{**H|Aǒ`oW.~cԥ,\)enyl%[Zӟ@t4\s=fHe5A>h =;Mԅ1sr,M`K7yXSn?a܃ ̫^ J@^vKk6` Q^*s]?9WUPt1VVC^J <֋/ZSpĀ(RڽNk/dy{Ho.Lj,O:^\~njjkv7FF!T.,4bv_&X 5f2]rCEt#)8Kar@j;cJF Sp˛>3`jWz)g$' }Tf%5M?I *inY"Q[ 밇b!'qhǦ% lK"nJ*>җ{Es\\"/'zL{GaJ@f`L. 8>:gb,wڥ+h4xZB#4[xhV횅|J7%䒯Dp_t8"^n!}m@[  aï^qAdӞ}Ga헯wƒa7]U"J[+ pHRbgpsQbPZN5Dٓ`:l nއ3}.Lj|(xu_߳`8U0=oDOC^'0N7~;|,ֱ}5j¤iy!l`rKzG5iӈgjJ~t1212zyz˲NNFf ,”/OeLim..+>/SdxqNeOѨɚD7?PS*ۀ|*66 D(Q# O^JrPaUrAZO!y@aUDT݁hUIkʰđʴ{Δ3cx<1;EpM7A3U ;o3|$KzJэrkNjꅅ]]Yd^fobcg£7:@,Be>67HB ٮazX7/X+ݘ Gn+ sC6l/N$3]F:A<< @6]YD-?T8f׼}- *}ޜ }zM7Sgut,a)SɏM@XQfbo@3Yd}TcKN2A=7lML(-`˭l|3H< ̗SZ\L]Q/Egc$n)*`wi~@6_{8=}zD^Ԏ"v픬d:a~MƐ`t*wk\*_kj'íwodY 94*V4lI=ǸS*Bl5yX"kH𧵈j`Qh\wl+i!O|o3ߡieFaDŒen~/R?(?xd(c~5oyc9gJ@Mdۂ4 ا1^XF+A෵AR#/|k\<3 #sb b{g5{fо9%Q@Q1`(Oͤ9؃TX90ek+ 1$|hWTs w5}7WϊR'”[FoX{x6TwI&ja7z[0Cx!MjSt: nF~ K#gH:"܊`a+SZɳyղEeW@ T2*0$(q i =>=wlԘ6n`OɈ+Op1(@NEq P-]=7SFw=$ȢyTa/AX % "nvk-ןǻ0ؘĊb[kACcg>? bZl׆`gS `yS{T7t\!4(5vFqpKv:ո ׀LA!<>@Ӷ &hD)23OBŕcs~x¢_1<{2G $'5ӟ3h?Oqu YbO|3QݏބW4ՂN8O# FDpSOVYoP,n8xcVԉ$_9"ɿP'تYU'O1o1<{in\&)/#]eG`uIx2uՖ= {\ /i*#볙tBcwj] R"4Ǧ`-⟳<[KN/RqGz u C9EdAlgjUo^ ?zֈ&sC1u}O:kU&7d28|zܥs0 6X(9 9K1f˴P? mp# }oj[;]c\ށˊ?بfFsSZ˫<DVDAK:w3trnr,CYJJZo`\`!vU3 /G*fu!~M4縑K|$bN)0l`|⬝tΜ{ gހ<֗Z@flܰ #V\ >/1jm_d |b3C 9zgEPq ɗ"_ᾄ/?Hn,~u<~'S[(KImb{-[ؿefzS<Ȉxį2M{f_q}<o9?"ZeQgNWhAJI*ǜ|([cSa4STmЛ;}&Mx{ ".(dޛY$QP;Nq. ɨ&W pD1uD` Lz`ҚMb\>&')H<< Fc+]xʴ8 j-$NK[f @v[o'L ^14}cg?#N@_0~-#ڡ|osN)e>''㐮%.%--x0LpL"`"4*ޯ%<=q _xj''nMݾ5V<(G Y:}H_üBi`1p*t lOju,[&وWU'{J>~c{5D\*~z :K+ͼji;E?OmFP±cHQ<CéqN|9=SK~Cs譍$a(2 R=)=W6bX>TD2a) N|1#&Ϥ\-[m7T{ q˼l>e8\ͲI Ջ#4G+dqzHcQqRȂzkTmH*}1 xA4.WAr9.qOVÎ .э+sic(pEh YlLEUg`d{\g?BjaI~n(?o}ԅ$<ԃK@#1W7"c¡`\($X .Ў-,kی;4\6剌*QqީDK=@'z 4J) Zp@w5[p7% FNB[ȣ^d2 -8Q@=uݯ}/4SCjvN7"{aܛBy0xqwb>,ә*H/rLXǤ8J.A|HyQ|Vj.F* eXe< δF5(PSZG@?W"fi eN^ےS)K΍PN7rXUc&-hN؉Xpw!yO ѻ3+L:ف6_rxhf,c^ۻ+0iDFvw{8G&/úoHh~p[=YIFBxKݴL>ϓzJ*5ʒc%Zʱ8/v󏞢pd=㒿>;%j?c ;&@J8L'7ͩ )$NV~Ն^EdH30/3 J{_G<{T~PzP=\ 'H>ؾZeA[Гt p8˿Ea((h[qdEZrT.N}`nf: (]47QPD>D w{S,W|Gܦ>8gPЈ) @jDn!QaFc~ZJnZ! `2Jiu{cZ;\^ǁ20w l6~f[[Yz7[أ#iR`?!ICڄ::a[<7?NI\%~=ֽ+6sbtrj,M/ " Ի`T| 8[9MZ1'=fW{z&?9L*aMmXD` :Sy^=9d1?o ` IN)r=-Lr?(ouGufb-}Y䥭+*L*#HLv-4Cd=^X5 z_Ώ)V3Pztag2xX˓\!K}?BOdIh (KP-Tl"T'T懕+NVĕrb>ӂwCInP՛౭HGt~0B4~]wF!:>}v: +HTvS,T ѓ1'I#|ڢa!ȳMv"öV:ip]- vƁ̡H<88T>u8IE9UENeR mш>1,id?=a#;UTot>5@agrI'ƽT;Ho_|# 3@ KvcHI1E' / ˸ 3s^B#si4NN~X0<:TA r8MTt/ 䋯έmݧswjX)3d  WLrYFLa|N]=89{uKKA-\Z.RIktU JT&-roo9kGu@ݲ+'Ty.hS \V֯LLo)'tV#82d~ڭkSc*,"Fgw_g~}EOByن$2 zd‚ اH%2܁rf΃^LM^V!n907M=,"zʛ9ܛ+ѯ/L5iYI(Іئ#ۼ@=;L:^D G`Voa<w|c^"4 ,o$ӣŽaL&-1e"iɨ w}l. _Xū߫vhv39~_&gm[)h5N·ǿZ):[-y2;g{ɷY%L6]ie#{ @Y<,/Dx#*u]g3jzYNe^WGzz:hyXʖ 6_t8|ϏQ7 LQڇ]Ux !B}?pKEG$&`W!:x^F>}~u!qgqQfSSUﻲa tpGܜ7+FO2::2&ajFZpz҆,j+RG_U0zjoX+2Ha TnS1[~Bcs?c5y!>qbTĉ~Eo!F~.p2%ݬ3Ot!)/fq~e5n,ov gE?M7 X OpLڣh56jmؙ{;rX@<+k>Mdm")BxK|$:֦,'m|5P&CmhMbjp=m>p6=uW 82XzBpx b4= j$_5#$S{P lq˟Mj.4afqxN/Z,4a,*u /߱ǰѨ@b8o)kwYzb[^޴b$b?'-X–f9od)A_7"UtX\{Ì"[+y]+~;l?Ou; Q횸"G ږ6luv8 #`+Nc-Q:u=lU冗;/| /ӃIavu'vheZP+6r|h)p\ZC4^P=lQvK!Y%l jTE2e ȩqR١y\V)Qlls>J݁ 9e !m@ewEg `j2Ֆs YDP)XD0J"X :<CQ> -C4 yk5é =eU垼sͰRtQ1Y EuU]0ʁW,ꖷ[_җi\=nT6斡DdpŞ| wdwM}>yuxa\+BMzN3+8mlZCXPVw 7%ƚY #qv3{,ta{뽤 C[fiTSSM(EIB8?P uiEɉp7$`,Po|3R-g~3]V_7QXn'vXk= -*2@ٔHߋPDfJ]0>JA2QsfW ͢M"pdDs>9Q KvM͙o*_Zs|kgyži1_r`.L {U{͊8La#tn,éVH3?a)b.Vpd<*"Uڦ#?(NQeVԵ'cb0vR [J/}Yb xj]sSԟrtk6Áf*Nb9)Ah$Lx\9KV>zV,\32Lq}xW+Q5g{@fJMuh#+\Ie¿ɸ8ajHUS&t UfᙩF@YC;86Q5z/o&X .gGB*@lɿ{e gYJ0@O{(R8U75v?t퓣. PYÜu*H8KvTT_zKYBp~FnaE֒Y1&Xò[>kkVR'X(>oKT筏\Jpt mP8EibH'jΪ]?܊\R P! X <=u*e{l?SGO9Ba%\ k{s"z1'A!3EoA;gܒ/"nab$>f^*8YmA&Àe04˦ DwyCX\0+l]vb#+3@^wܮ/4νI&S@Ͳ$ڔk*`/F5MPL])lHr O_+f`˓)LE\XC$Qj„?AH*_jK)#hvmU0^ø)@eDFmd;sv8UbFL rua+9i8YV.1z Sz;@PXw NDxfDbTIkQBqE%ZtT\| Kޛ1*W넢ʄ)!vp19h";SۻϧR5b$e B64Hc-f[`mWa]ȱ 13ܻh*ݱ4})~(#e>(CONX3Ppxgp,y䆝d@|(ЌT\! lLy;r;IraI"/QoST`GxB>ռoA+*ӆ vpryV/Rtx/Ր独&> ,5؍O-;WNNRѼ&eO#H}<(||@x>"0T յ5`UG٘j׹F,mzB*p?߁Y6d/(saSx[Guҟ&8ygr^\^5ˬ.8Vxptu*5!wnԟZhRk$e1َGg.W뢳ptwZZY kC08{;dDރo*H*eT<q{h'5REe9vxLQ ŤEXKa>`72swRt ԑT؇zzxt j>T. i D {Ps3$6a|C&.*V _lփ¶qN RKTe@y );dSST؃!ke*;|l;2Z< f[yeT i1D-Z^g{垬UaFƝZ^z(4oU!AnT5*=OGgS݈ [Ev*xlf Ư702x ߀Mʁ$GS2U(n *VI-oڳe}c~q:,' otmPx5߻5tZQ?VךRԐHSv Pj9iO yH]$M3])O*-Yk2WGe𨷢Fwo45sMңf\д܃<{l!m3;2@uflVaӶPk&[N o5dC &2^# 1;$Fg/Cu7Q(:kZp6ʐIʮ$7\21p@H&$Du.=DǪ4+w--pHP/JNQI|B8pzLT #A Cg,Č":QoD,Ew/~7|y۲DFx/*o %ޕbKX^a>9 xPqMJR:gµ EX hh~?NM9X['jsJK*˝&)nP#+E"R&Nvw.hDϙnBj,"KC~<)u~dN*Iޕn~hǬU1RdA'Jeq? 27B]V|Z63DPEDQ3g<@2MUz =X]]w.qL*Z֠*(y'(l5&f+ &EQ5MXl(1<|o_c \=f`W2Yq.Gn$AUO'!ox®z@ҒUTo O+}Χj2[^F><ߟHn]33xNêՂ5E9E60"ptVkYNE4|Ga/r£0JךN7RkqpΧl*fksix~M[IX ;[bjC$FA/j##KJB]r2 #7\08gȱ}CpNS7Ć/["x0T6^LG`l\L鏥26nn:̀|LL~Wh92ECfsg|իΌoe!Ozh IyXl{0⮢:Ku~9k#RbDC͸ {ea^lB:|te8l/!-U2FQ^v{ĥޘFmY<²2vhzNkZPXJMܶ 'Y3SlXtd9 ؀dhUdEO7 ~eI2c3AES_Wuz&i$+i8=rﱥ,ʋ/ߝWT\1\uf _hZH\b_F)!:s3]̄.QT)Ǩ߅03": &Poz/ # 盗H&[2ڗ`Ef.{(>&B%,ICAP1d) >wT qϜ \A|%\}.ܱ@ǾKzzLq3fop"rR2ч <8~_ho:PjDDz`EMw4fW$'mԀ-*~l{d;>PS\q7D8Rmy>bN||7u&]%@5Łf\I&Eעs6 aB[W$#o4 Jj}̖S 'ѥ'P_4elh|暏@GXAex2ѭ,;|k`mY -7]N"dJɺ͵=Z(!Q?8|{ Jcg$EFDgT}C&'+oQ?&~jբ o Z,O.eK)p9jXsJrVQtW{@YX-؞͚'-)!Js%D[9&^(-dJMIr؝]&^̺L?ݩ| pB!{34@Bb˱g@LK Y&j 6< } vInS~F@k%u|].L# CGTeևmrɿkGOd2t2QDovj,ʧ\b)R=b uBzuI,hk .ԗ-qf Pe%En38Ҙ:3Dk&rw%GB@h b # yyRZvV6:.#&=+; |=e.Di T?r! 4 ]WGb@OLƜF!`2ϵ0Q,hR@L=T"%GwQk@BX۬'Bkȯ`lJn{3^Gt'A>"%SVa(2b%[D7~GmBiSFrIHJUD"e(aN̯)]1N!{̶r537 Ug 7m Ȼ{\3inrGf_ϫ `s7f0*=.JϺ c7D%袪%P@s ̿>;`@^E$66d]J9 A o\dN:Dm 1UѱlE)_w sm6v9kxͅ+Anc[ښ4w|UG]Vs8V_uua (y?̵E.@ҷTfg NOAZ@+#J4Q@e Jtՙyex$%!'56;2eS>0T|יmN)G(dNiZ82eY>B:vEJ9lҨ(%;'{j;'JϸK͵f[ќ(z+_lFm5SYaУfgToWF5ҹ7tb5j?,~v#jN2Mg;Ua`.^t5ޚ=i 77+@jL4"n@̪"CG3L$;"cb^=.*Jk>&Còlנt) cFނ q_ 5AވY|L,FY[q-o>劉[Փ0•GW.Vs"XuQ/ |z|<Ɨ59hE wo/U?)B 6EZ_x1%BxM}p H«|⽳NDpu|ݦոhC, ѓг0vѠyôk KG:-9/. ԍ-i*3rS23]-_ MP5–㲇Ј*>G+4W ;T ?"ۙVg;O+XZq#`8Y1><_=;'1hEN,?10lƜ+ Ӌ%Qߥ&Ǿa^X\~n[TU'ڔV˴hZ)S!YD0b3efGl[n^Ɗ?̢f=MƇb,&t_1\ҏRsFZPCpa4vq/?_$xTc=&';6?~/xXhK! ab%O͔i&FL_.C}%!gEqI:R磉Cyd|$,f6_^ANOaC+^=z]ESΣ= 5w<Իgh +G{CG!,6P,'a\$3!-ƭc{cw.&g۴XyJs-<,-enag9w `Ċ)3Hkfp\ Rs3_⼹AsRЦ覡0ήIԃ;G90P Z[WpAs4(hc# ӬvW$L{H(5*Ҍ1:0O:gqe%bx^n@:$(\Fm+hmݒ=k݇'t܍YB38彑Bp`)=>׿y0W+TiFF([}w]]|$!o<.]*w>)K޳F7CnRs԰N2L&5z=oJ2W 5V WVW}t׸5)_q!.}&>6RZMTR.T<3& G/ s@P>Vr8x%o3K\?}(3%f}tǥ0e99Z^Z=aׄ-Ҕo9{R+ Kql_^⛡N$Vt=?BnVk. ڼpVooFP5Ӕ?TEI1qb䄗llMZ9-rڬDtm@6kfIχYQ NSLē9?09gv+L\C}g1S"4N)7]XJ cn,U ϓkrl[gZ)Qۤp  (h#9rFbm)zE0=h?"+`㤍! m>=4rYzaOt E\`Ie;+FxV;nӻ9$gW˾f̾\yzS_ǼxsXELDdks\%ݟи~xfԆs zpACQWnV$lW%Ȫ\ KsM4i8,=R ݶWH^6 R~^ppp:l܍vrK++%Z TQa[궥lݷ7 /XVWgV|hF̟ ~,m$} 46``Tx(c о>R$fc*/Zog73#<إ][D2򿔃Bӻ | h[y&TSLt ,%)uǃ_xsB~^b}<ے>-K8Y 6ٗLmʻePe7o HcD[Q*o1kEg`km$KPu^_+ڢ{ eM/vdo󵠡9쌡!petszIb}䷇u~us- qw~: h]Pm{t1W_"xCI˜pZ/K`u#5\֊=GJv ,U1'M e)[=V|el`"51 WOF@=gPv)1@]eECx )w%(9] 3:^Y,7{E1z1_ȹ((8zwZYN.QImE='A#~ßZycMLYǚBwƽH4bS LAZ7h[:H&IU;pTOWQݏk&gR(H7ni;s^HAQ)#FCUɗQn oZ:50 ne-<޳b$7!MV3+#n'ZJ͒M&js MKX/o6FNR2Q:˷;LCv&V\5ҷLWْj! As3{qA$LjY+pAVj}4#M"NNm9/ڲ])}h1q k/͒jT)^ס$ڧ,TyDLPs7 l^қH J XbYN.]tsZ%y` us굠i8Hv +s# L֚p>#bϝWٲk}Cf|H ^O\9 \a%JQ>M&Koo] كC93P&$lJ>4}WSD)/TٰHRe{3;^UGϵG[ԕ€h%alL+;+VɧE}R>G$,=pg[~|@OoXJp!}aa* 2WҖDNAOHJZˍ-APTbVpUV!xҮ:޻+@Yvszk/C9j !ֱ.KA 6 RD ά'cHrRc. `˙.H,g~բx[YZWG|˻8Y?0C@ Uv׼3/`e':4G.!Q+C,;Ͼ.˕ @UGU 7|a3ˎ  7W7ri0k[ObH= }8-|fxG~MV!5B#ZYT~ tyz`|;t$[[C\x.\|CngbhI}auyR.Z_-^͎/( QTp6HpFq487mȭ_=Cr&aHdIpC;ɭf elEz2ZD䮅d =uj=6'-U/8|FJmB%AIw(qrt%p@hܞ&|"JRlLHPnBxH$ #MfF:֊jsjgYk >' gi͸sj.7oFaw%dcلV9ApIvN U|9l*&'Q-ÑnqUY9l}Bw, łt[_l%z̭b$Zi-J2 ~öo:QвA^]:)ed ڧ ӵŵ*{/+X\"h0a a6]#h,9O E~ G>]fx-b[h'R\"F1~ЧH(;8r]um_: װ6RenQͣn* u ;WTt ND(C{5[ޱr\98VS.ktA)dMb3 p~2=C]\L@o5Tʻ}]#U + RZk6A48w>COz_*= eeηip9-nòIO`_L[w6-y#)V:EzfH~yoR>lkIlV7N~fy %/ݣ蚑`&yʼnZh<IƱwoVF\غ)ߺ3pJpy aNNgƒ-ѹu*1^Z?IQY=IUpWrCA/W-qu1`UP;ee @/JfȆ*vDdo xOTA1'PG wBw { Q{i[}E<\ Kr$;V莋.+]q/lH`: kQdzg)9 G9J^*PK!j0vm 8,T(5VգYqA[,!dWCC,'N}m?=z; P :VGʤ3C/@v7 z a_SdƖ@ NN )LY(dHY5ׯSDiQ 48·z EUĺ&r1JԜD;*|\" / O-7v(:TeGN#@ 9du>V.z!bNӀ@!ִUXҧ: j OaPOm\ Yr} $S U,s4/&s â  һ#tUp纸F>]SBp]K%MQ+9{12JPZT3T'Z }y.03H +xR 38i6II$w>=Zoe$\kJEUQB,V:jRk\"ߘP>V`%a @yoi u#Ћ+VbCFScD{Tw {Wμ2-'MC d(vup[8\@\b~uRHUa-UD ΎF=X  6EsrFY!'p}ՑwI LG"#aI-U B:/sgS 9\a8r;}cv] 1lH6KA6 A>NN3WtKAڕD[V=N\ɽ &&teA{ya2CRym);t3l*ҙ9a1 U[CmPMG?u(I"ljHC[b!~٣hߨ hZ9N/6.cdB j~u$C_C1z^slCYb T1/IR r&Jx̹kN/\B8!2OUeh}KcAz+{" P,B'*T‚:J9*h{?@fk×hY7[^`E9nHM;)}WDxցuԆis>l%#1]:U{YqyeUd7[c{yT cooWu{iYֆ> q_3V,`f`N ǧ |jTSJ0EV<4 HDZ?Q0~.0LX kY6=_= .ukCpG dEOSX e蛕&sR5j0J dI׸@_SKˠLK=sY{/. X3I ^M%;KRi7\רKjzMZh$GZ ثq}ݛd }3)̡Ϲ"*[9m EAה@(Ӕͺ;ެ?hs]vPTB^;qqmIpR =8 t~,R.KoZg_RXхpVb ;xއA"5i%V&`k'*Xfohza;3~⹬!36J%)n,HFH]!<(k*dcU^׵2H 򼣸mzLǎ#o}q‰H'u0?vj+6ڰQmo#LXxSkT.%>G}NPjtd_եgiLj:4.NOqiy?lטּJK|>OY+i*+g:6aZbDѰjBȆ3[%4zd@~btrWw'Cz&I #g"RR#;hמ.?lzZmf<=fG /LUy]eeTq'lނ9o ?:<'%HؼhZ^EI֊#.x:ttSXUã˼UP;,]\pYX-y>No9,vYУ䕖ˈvFjXl\sjgO5lM CrHT'NJ*$ %nK4#9UT6LnEÙ Qm/ittl۫&Ԓ%&̈́ԙ5Qet~2NЄ2h9r9o̟+ ]/yˁ&/ڪ^]rCF#=՞<ٰi" j%l)JT3qo_s,'(+DȪ [Q/׶woSr %~@*pZW>w>sjFrQ /Z| hxfҒǡ?xGMAY)o5H.Sۿ8QlEH<$K$RLXQ#vej5"00h@6O_v y"#͜!Wr4Vt&KLLq XgD32o4O>yml{0cthkxxNjC98Dݞ7ʋAi=VtyRjOG4Lհs u3tL:5R|nA T;2UIsel6U 't1;(9P߮Vc.D F3"Y~HGFN+?c<=nl0_$?Dsz- uH+Pd8M]ΰ̞v_ By[<Y4pH9 1v?,jST}PjW ,NRH[08dGLM#UhV?,+Q;zVqp$C \M5 Slt"^UW7AdVXbw 룉87IKJR4W37pӗrEX=ªK}F2Y8ЪY Wi]9RfN(SBKP;)Cm?Bq_3W.)Rq3I:(,"a vzt6)lCA/] 'Ւ=nӋ:Jj}(wN.-/j\_W0ee8?aΒiE33w! "]*71^Kx:zRUu."|bᩉT#mD7G-,I^a ) (H #%ᮀΈ2 8?f:yhfU=6WMVY+he?nM*i@)Eds_ht=r9Ͻ9 @_ \ cu{QV*ԑ0Q}ly0'oZ;(5V͈䝢eOJ>g2?`Xw,??BMm,}NtYY9;6'1lҷk`nܦ˭`W)ٸ}{(z.r Ĉ /QA (2½el@r"~^ hg֭~Cj+6Rـg?ԇ{ueA@+UTG5~x sfcWM W\>rf'`vk@J#ؿX+5N<F_GꓪM]`@*k^`WNIu s5CDxJy~0[,bؤǷ⇫utqJGB0!f\ԑ[\X3/vCQt8gl"#v&9!nu-=ĶJ06]Lfk.Ԧl>m 8Ixy=VE@%,i!ۉBҳyK`P7uLdbK^6PioFdN~0缃`!19EFsa@Awm)K/;0.Sd ,^Ds^cmDj<:/#E!jHw!hг]d+/E Z2r Ws#Vp 80'Ù?&|r1'tλX:E_wкiv+&nk <'.NR%?F" TqhNb/m<).K"rd+!Z[Bd?9qbL&v=˩q+ݰ\br9Ezuk[@J44Ǽ?ee/W(Fț5h`)KD,0|x XFܞ6Рbt(*20co%yGPۆeBk}%$[M+[1%/uaA riB LU>b@;:Wtw{@Q#]t Fhҷu) #pf }SODUWuD\WXs_r H׸ö]Ji%t^ Qg3Z. C5v Sd\O`NFaX^@ z+T8oS0gjKYgmrDoTG@~$/ 2M³dkLߋ'b͔S \7fC tyMTKJ):TZ-fT(whJJ|2^s aN2RѨD3}r%{/E/7,>6kY3Y|-Y"7 E )R nO)*JWZIW=:jx{hwd'τq.T (1c~A SGgJL[p Vh0EMZ3pn] R 0blKM|IH8\).rx>Ԧc|S-mfVϴJB.K6g̪vy0=Q-=q)v橠&ZNv@Ϸw[n[U#Y_[B;"qT3()4F)N0psV l@Af9JMU]Zzgs3ԚB]GO, n6J}Q%7\<~[-{l>učߪadTN ȸ\ϾkX^[nOg2nNVBv~zy/ʔcqɵ_.""2(\ˇVy4L+Ȓfbޕ*Hp̭^- ?Ri?\@:'Di)-;\wA:zi g7“t(ԅ RWl5AYb}`[$AvW'T?NQ>h[),ʒ$h#woJI9l`nrx%dc'6#e֢ zr a"đ4F;=l@Q}6E]؆r :$#s5~R}ͥÈSIJ:񢦠mmrpP^8½y?P ȔQ9|;Eǩ[ "(u ;RcE5ZT,YbbJ##MyA\tKYxLK)#ս5#d)>Uu{eʝHUeYϻv{Vn/uq>#aく4}Ye~&: ,s0ب-K:D&ڀ±0RvKzl&Yc_m )