python3-firewall-1.3.4-150600.13.3.1<>,`hp9|}+-T/4Cy62|֟M/4 \/i(lK殚y^/E@⠎ZQvMS)1-J?9 CFQNmVm1,Cp2 *) y 쾍 FZۅS~I^fxrɹ~mk7~>qI{I3eJ ?Fnu9 ²|Vp}gL1i~CN_^hWv+L# +|8>>?d ' Flp| ",4 8 < D % &H(P*-d-// / 0 (181 R92TR:8oRFGHIXY\]^ bczde f lu$v,wxyzCpython3-firewall1.3.4150600.13.3.1Python3 bindings for FirewallDThe python3 bindings for firewalld.hh03-ch2d (SUSE Linux Enterprise 15SUSE LLC GPL-2.0-or-laterhttps://www.suse.com/Productivity/Networking/Securityhttps://www.firewalld.orglinuxnoarch_Fx; y^  _MA2sy2 oixo"_ZL .T $זXw) 'b #Dg$ <-^! *qR' (T"5],h<52-P /0'I2qy?y}K $,J+_1)G30tRy[ D*9I u_3YA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤hh@hhhhhhhhh@h@hh@hhhh@hh@hhhhhhhhhhhhhhhhhhhhhhhhhhhh@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@hh@hhhhhhhhhhhhhhh@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@h@hh@hhhhhhhhhhhhhh@h@h@h@h@h@h@h@h@h@h@e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855855c763d6695622905b4d2d83c91f7e871990bf17fa55ba4a9548763dc24fe8ce2dee8741011ad4d5fd5f95e7729db063ea55735e287bf182ea826a0dc8197a50469ef2403ae351d0500b1e86ab63afaf230a58314e627b076d221a41beb875815c6e8c65244db2a2afe6bdcbc8b02b4bed797e11a729dc68f9d4e5221df8e5653f74027bd1ea21545287c4ffe738b439573ea90a20245bb03b6c782ba0e8ff4f9a8fcb62b52d6338d36545571a198f8df93e0b702a993895dd6a99d177720a389b8c1d350a93da38e825c28adaa5590800fe7cd451fcfadfe7ab98b53e4f3153fb48a8527b346eac5c23ff373b3b3faf5eac80f71635ddb234da77e4409d2ff1f1e57527c0671eeb6b76ea1339b5e1c4bb151f97a1f8d556d78083c4050d2280f2155ec49d1d5c101025617f2428e8132c2559f7e1e9b3a8184346216407db4dcbb3dbabbffdab108ebb7313059e75cb1be4ae99cbf5aadcf5641ee45c89dc1cd1228083bdb4dc284894eada75ac711f56416d4c1741d13d0fd95abea0b2c7106dd28a10d8d2596f4b137f25d460f8aa962aeb4b564d059041d4c558d66e6d6e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855855c763d6695622905b4d2d83c91f7e871990bf17fa55ba4a9548763dc24fe8c6965beb81efc50948097fad818f126a82bbbe49c7a901c32bdfb19b5b8638db61e984bbd77b46c5a44c6a65ce909e44112188987101cf2112fc798e68b84ca49f39ca7e4ce5bd059c2a02dffbb9086ff6e999f10c3aeefe1a6a1d5ec1c3c25b61b629f72c154984e9680646cd674283f0e2e8667aea039c10ef8173d12c2a8dc71782d1f3ea13b35d725bccb258cb414f3d08e96e12a05663305cf213e2a0c8f888a1d2c6ea3e5f9d30476a456494682e9a3f90d1c4b2b59376e650a4e8d772f184e16b30013b5ebed9bca751e1df3b4d7efc3966876ba36221ce3493a55ee0741fefffcb9ebad18e5b35db9bcc1d69100e4e1d797e0a68cfe4b71479151a917df4201e624ff04f679920c1e1f944cae112a05e379ec3139c4a147f0a30e9effd0011d559fa249910f551ea8ee8371e0962b53628790e5a84ccf7b177347ca19403e0c83a1899f501d8bc2b39441ed25d1755c9b34724f8978d2f0196b23989c0f7f4ab197b14a909579248f9d5342d1a0bd9f2fde4562aff6efd142c0c00080b665eda8503d1048af4c1b9e616555c9abfa845a9d103aa9011d880a9d7c2204e6bec0adacc7213cc1a09ec618e9a8fc52a7ac97c011b954691f0a1edb7cce0518ebdb58d4063e498bbbd647f1f53c57dff69d71560c63ed1277ddda10be6ca89fa7937846dcbbaddd89ba82166c93219869b49956a85ec385fc2b142be37a95c912657986655f6d261989d2cec38087a2ee083c0fc5b719143cc763ab673a504e78b2b411a119fe20bb5824503c450f610ade86f0073bd7e8ba584d57e0fe4b673ab5e5bc487a31c372dec0adef2ef1291ac7759d3bc324cc54b696338dd7ec460637d19f07bf12ccf9565377e277d38e261fc14b9c12eabd2b1e29206a688c5cd3b797ad54e4494a28d7a55736e31fbdec03b8b7f3a7bc60955db27f555f5537f682a11293d008d08a06081f6407a96da63962a2361c14082efe8d74f3b7edfe7c88895f63d76dd285746122bae73d359dac8eed244d1db10ec7cd4310ae3e5d7a3f385e8a63d6263b9b1ec8f5b97036778a392c8bbaad4af8b1d668a378bf991594de6d02ff6fb3ccd7ed0c7fd9038c87b27fd5db3d45541b6be5d48fcdf6b70cdc0ff134dbe22611c1ffda66b29dc62bc62278106485c6e75f276cc62cd0b2d3503f3eb66a91f3fedb781b5a738b75224fe39fbcf34266b0f9bf9a6a5bdc83cba347d3a0ee35f01b2db5afb453db186b8d151853f1d5160847f96a12c612b81d479d9dfd0aea5e1ead53d9cb6b67aa2a71a37c20246340db7330834f8b42f1eb0221240601a78d9dd77605dd622df6f0a8b9e8f2e3661851eaf6d4b93f844fe976b93e18c8c36b3e8f0de0dd55ff96304094f0eece871efcf734aa8db1cc2b570262843f48cbd030d4ed8e6d6827e9dd661a930b064dd82b6277e8f411a9bf6f1be40bdada1c06eb773347abd8a04c4bab5222001f6fb17364c396c729706699b17f30bd19c9825dcfab6f4c2c26a6c939329b232ab2832117739c0073e1433940562c34fb5acb69937584ec10aed1a9bbd88f43eb568e16d065802248afc2a9f434961d189e215f4be965ee6b66e006b8712a7e2b8aa389972da51e7ee56bf7b5d3eb2753859c2fb63528f5ec93519a78fcc4c755b3241e6c96ec0068ecbe0403376e263e7fce8fb637f1011a98eef5b440579da8a89d949d2a1146ea907bde85001ece20b3206d00243abbcd3f6b74400f5fea1f89162972479c5f5b47d1c1c699a1920eb5528f395293d003ffeffc2be18031bf664f7fab59ce50af6893175e8bb77e19d46143ec1be133a10df0e646e4775b781d539cb07f269b1665214ffde9b8de7374f97cb143979ed21bed5f098313fd08d6f9a6e1c502b12eef39d05eb9a81e7d9212202fd3cec6f27f39cbd18a662172436402dc46675745c53c8b73763b6e9783e729a535709fa8d98d408b2d20b36e0e4fb1bc093c3ccd9ae667eca2e2eae8b9b50bf89c47a3f288632843fe6d966fbdad1c99b95a96379ed01a589c2bad669dc37043bbac024809373c193fd15bd6f77cdb1c53e2a4aa6fa8917540f0802ed4290cb6f16168349c304f3d34b686687ed9dc9b0388512013e03e91aac12658806951f642d2cea1b985013e12d47358b8794620dbf7b969f9550c449535a7c60e66eabecdbee94cddcccbdc793bbe124c81e9c3cb62fb44a7b0373633ac11a85faad96a5acdda94893c2bd8fa7d0ebe2599caa9a41668e7d9d36e0558fdd72da8eb518103232ca5d7184570ed3f99f385a88719ce4d4257c7130862950a5bf3a5690b2f0f864e510de434c7efddf9b80edfa9fdba6a391bed68160f05365bed9bf6a192bacadadf951cac02328654cc9584e45d00456dba4bd78d0b2a1e2e25b24d076b61068121c43b92e792f0718ac3ae09c50fdaf633fffa9ad61323c3ffeea701d7e4e9f7abf2babd98486e303fb4290f96199aeb11d044f7a86b077fe8b0d3a5985e2a9019a8826102cd4c091d7d74d4a2a00edd485137923c53419c95551a9b178c18dc9c910ef133bc8e09d32d1b11d2699dcbc120f6c2d2f693c34b40a9a917626bf9eb03a841c7c8290dd2af8d0fe9f489731cc35e33284e77d6cf493940169d595ab886bdc27a400bd95d6480608cffd8fccf894a3dd37dce1ffc8d067a70810871253f8736e8ca7f2b31574da8cada59ec6474f2cc3056bf1b8514e3cd9bebd22e2fb8ad9c2254c2f646a6c8f7964497d004d5dd4fe0c5ddb6697372a7b92abc690b1ff83e6937f96916a581524f0307a86f206b70a0ad929a80e28c2a7a84a4560b76f468b248219a64e71176ef5efcf2c5e59eacd798fb94dcdb0f10118cd481703a33eaf6dc54fba8ba7fc3295382f405d9f74deec69308f9f3f440630e0b6db668b2e30aa69d1a19f4d0b20ceec58d4d6cb0af572b9a16811ed5936ce07bb6e8056419f7ba05f4b8a882ebc2e6b42c3dd572528868541e32b9870eff74ed1626599f72c5cca53716b5c520b4ae328da55adf8018e029832b4bee23014a1bf7433c5091a46e1aeb89ee547a1f8533057149a81db7b1201a946c9f7bda66262571ac5d2f6935d7a005bcfa98e9d3818a86e9379d9ad9335f925d1676daddab5499b06ad9389b79e7de3db2949b202d9ce967f5b639fa136f3e4cebf631ae00ecb00bf38cd3eaa35fb3803dfee45be95f87ebd9e857675d3cfa85025d5d437bbacfd7a4057b766866e61c17c90617b1f3dda24acc1b4f8e1c91641b15e680f56c459bcbac18470cfc4d6e474e4b58a750de1e0e30d45b7709b3583d71b58a6b3caf903a3b1b82fcb102a17fed003661a9c69b184c335ce97c68103a2aaf2f74e96b53360ed56ab2c626a6f6704373c78f50a954ba1cef1f99f829cd45d7dd846c1b035e89eb8cba909ae3cb538ec1ecc15574174bf30ccdb37bca14859fe6ac90b4327fad59919331212ac371f61133bcbb1f039c15569b6675df4bd5dbcde277a56714fec4fe053e8e22e13950ec2123f1449ef930646a90398816abdd485551fe1c998d8bd27c432da3b7ff80cdf04c92d03290d5ac789a8152f47d283c516a6ccdbcfdfa9e802ffc573526044d932135efe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855855c763d6695622905b4d2d83c91f7e871990bf17fa55ba4a9548763dc24fe8c3351508c3da5fd608a3d3ce15bb6b139d0d0a8a086c58f6df2b2bd93f5b5bff7d3055bc054c252e16212e059625eedcb4c2d357d6aa965fdcdbc2455b9f410371c70a0e775733b0df3475288e01ea2cf6149ea60e661e1c938f2f32fe4eea9fa266c6a4798d75934a87f24a6ade98ac66c7b42b83fb90e49527de2a2dc4d7fca47ae0d9f4399190b4cb7146c0023c612b812f823375541bc2deba4e2c77df6b7cef4d0d45a6bdd9a77886cc31d2f29ea510cb6b32ea0f9910aa252c264ab7e466f3aeee890c5a306daecf934299f975a94ae8d9d370190e20a94dc14b4a2d94cfec856282a087b49f343465be9d82dff28008d91c23df4749c5ee486c5b500f3ff2ecaad9a4bf36aeef1cedb223749e7c39583b4d62a50bd5755364c8e205985e3d8886aef4e45555138ef26e724838f1b9059a85d7229aad652a01aef9fadf0480009e63316ac6d4d2da0b19d28d23ace8db9275dc1e480920d2667efa42fbd950bf7bc1a52d4a2dd13bb0fea4e2da103596718eb6499dbb542f25d6a354420a015e6c0d33822fe8c9ba2fc4ff55da3befa11ac38037dcb572ccde97b92f0d742553aa823f6d837dd6406075b12dddc60db788dbff0cca03b175b99397565ab1fccbe1d318d8c3945e7dc2913aa62bca4227b1cf56fa0ba664c9c4cf51be7fd928c1afd31f9fec849f4c3579bb3f49f145567c0db700354539d5407bc7dbb1b55952f9267b5909b80d9a77a197703d1cbcff83c8ebf70262cb6464872f9c8d33f327cfb204e1bd68ef831c1cab77fdf0c13f3e7401f61a39ac8f42022ff534c197e5aa487fb490de1d1072c9393ae58cf22a2dc9e6893b52e6241570a9fe73461c2948b35ca1de4f881542f71a63ed7325737568b3217f6c8c4c80d1e0ef7197e9746103ab48083dfdda019e99f9694c23b34d9a2041cc73195a0f2898bc7232d5848063c13fd1974912193718a60891d6372fe0ed682c78b43d465da7c34b9rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootfirewalld-1.3.4-150600.13.3.1.src.rpmpython3-firewall@     @@@dbus-1-python3python(abi)python3-dbus-pythonpython3-decoratorpython3-gobjectrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)typelib(GLib)typelib(Gio)typelib(NM)3.63.0.4-14.6.0-14.0.4-14.0-15.2-11.04.14.3h@hm@h0c@g#q@e@dD@cGby@bA@b1@b!@`m`@``2@_/@_[f_X_R,@_9_3^%@^d@^9\]p]@]4@]4@]v>\\\@\s\Z@\73[ā@[[@[[@[[qr[m~@[h8@[?YZz@Z3@ZZ@Zs@Zp^@Zk@Z;@Z@ZOZ@Zr@Z }Z ,@ZY6@XXXEVX)@X2@WiW@W{@WrfWj}WXWM|W,@W#LWV޾VՄ@V2V@V@VHjan.fooken@suse.comfvogt@suse.commeissner@suse.comdavide.benini@suse.commohd.saquib@suse.commohd.saquib@suse.commohd.saquib@suse.comsflees@suse.dewitold.bedyk@suse.commrostecki@suse.commwilck@suse.commrostecki@suse.commrostecki@suse.commrostecki@suse.comrfrohl@suse.commrostecki@suse.comfbui@suse.commrostecki@suse.comcallumjfarmer13@gmail.comdmueller@suse.commrostecki@suse.comMathias.Homann@opensuse.orghpj@urpla.netbjorn.lie@gmail.comngompa13@gmail.comMathias.Homann@opensuse.orgMathias.Homann@opensuse.orgMathias.Homann@opensuse.orgmrostecki@opensuse.orgmrostecki@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgmrostecki@opensuse.orgmrostecki@opensuse.orgmrostecki@suse.demchandras@suse.demchandras@suse.deluizluca@gmail.commchandras@suse.demchandras@suse.deluc14n0@linuxmail.orgmchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.desbrabec@suse.commchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.dedimstar@opensuse.orgmchandras@suse.derbrown@suse.commpluskal@suse.commchandras@suse.demchandras@suse.dempluskal@suse.commchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.dejengelh@inai.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.demchandras@suse.dejslaby@suse.commchandras@suse.de- downgrade to v1.3.4 due to slow firewall rule generation introduced in the 2.x.x series (jsc#PED-13314). The Version includes the following cherry picked commits from upstream * fix(fw_nm): use IP interface names for connection lookup * fix(fw_policy): raise exceptions * fix(service): include: when used with rich rule * fix(nftables): rich: log: limit was not taking effect * fix(build): rpm must build all as prerequisite * fix: use error codes for FirewallError instances * fix(ipset): chunk entries when restoring set * fix(reload): restore policy for old backend if it changed * fix(io): rich: tcp mss: handle value=None * fix(firewall-config): rich: set destination address * fix(policy): mixed IP families in ingress/egress * fix(nftables): always flush main table on start * fix(runtimeToPermanent): deepcopy settings before mangling * docs: fix reference to lockdown-whitelist.xml in SYNOPSIS section * fix(tests): avoid deprecated assertRaisesRegexp for assertRaisesRegex * fix(icmp): fix check_icmpv6_name() to use correct IPv6 names * fix(ipset): fix configuring IP range for ipsets with nftables * improvement(tests): add test showing the current wrong behavior for ipsets * fix(ipset): fix configuring "timeout","maxelem" values for ipsets with nftables * improvement(build): rename the "master" branch to "main" * fix(core): fix exception while parsing invalid "tcp-mss-clamp" in policy * docs(policy): fix wrong documentation of in `man firewalld.policy` * fix(applet): allows using KDE network connection editor * fix(applet): ActivationReason.Trigger - rebase and update patches with origin information - add the following patch from SLE-15-SP5:Update * 0003-firewall-offline-cmd-fail-fix.patch - add the following patch * 0004-fix-ipset-test-for-iifname-oifname-switch.patch- Do not recommend python311-firewalld (bsc#1246100)- added a python311 flavor- Fix for SG#69031, bsc#1231771: * 0001-fix-nftables-set-correctly-match-iifname-oifname.patch: [PATCH 1/2] fix(nftables): set: correctly match iifname/oifname * 0002-test-ipset-verify-match-with-iface.patch: [PATCH 2/2] test(ipset): verify match with iface- update to v2.0.1 (jsc#PED-5597) * fix(cli): all --list-all-zones output identical (d30bc61) * fix(cli): properly show default zone attribute (ea8d9a8) * fix(cli): properly show active attribute for zones and policies (b202403) * fix(cli): --get-active-zones should include the default zone (dae9112) * fix(nftables): always flush main table on start (cd20981) * fix(runtimeToPermanent): deepcopy settings before mangling (9c53639) * docs: fix reference to lockdown-whitelist.xml in SYNOPSIS section (1c77205) * fix(firewall-config): escape markup stored in bindings store (c876fd0) * fix(tests): avoid deprecated assertRaisesRegexp for assertRaisesRegex (2935119) * fix(icmp): fix check_icmpv6_name() to use correct IPv6 names (af3c35b) * fix(ipset): fix configuring IP range for ipsets with nftables (6a050ec) * fix(ipset): fix configuring "timeout","maxelem" values for ipsets with nftables (7d3340c) * fix(core): fix exception while parsing invalid "tcp-mss-clamp" in policy (ff61209) * docs(policy): fix wrong documentation of in man firewalld.policy (21026d9) * Correct Requires, python3-slip-dbus -> python3-dbus-python * This is a major release. The major version is being bumped symbolically to reflect significant changes done in commit f4d2b80 ("fix(policy): disallow zone drifting"). It does not contain any deliberate breaking changes * fix(reload): restore policy for old backend if it changed (de85849) * fix(io): rich: tcp mss: handle value=None (8016f10) * fix(firewall-config): rich: set destination address (f6641a9) * fix(policy): mixed IP families in ingress/egress (69ed4d6) - removed following patches: [- 0001-chore-fw_zone-call-permanent-config-checks-at-runtim.patch] [- 0003-firewall-offline-cmd-fail-fix.patch] [- 0004-fix_rich_source_address_with_netmask.patch] [- feature-upstream-new-check-config-1.patch] [- feature-upstream-new-check-config-2.patch]- Fix firewalld does not longer understand IPv4 network masks of type `255.255.255.0` Added following patch (boo#1212974) [+ 0004-fix_rich_source_address_with_netmask.patch]- Fix firewall-offline-cmd fails with ERROR: Calling pre func Added following patch (bsc#1206928) [+ 0003-firewall-offline-cmd-fail-fix.patch]- Fix regression introduced in previous patch (an api change to a function also needed backporting) (bsc#1198814) * feature-upstream-new-check-config-1.patch * feature-upstream-new-check-config-2.patch- Provide dummy firewalld-prometheus-config package (bsc#1197042)- Add patch which fixes the zone configuration (bsc#1191837) * 0001-chore-fw_zone-call-permanent-config-checks-at-runtim.patch- Fix modprobe.d directory for SLE15 SP3 - Always own %_modprobedir (bsc#1196275, jsc#SLE-20639)- Remove dependency on firewalld from firewall-macros (bsc#1183404)- Disable FlushAllOnReload option to not retain interface to zone assignments and direct rules when using --reload option. * 0002-Disable-FlushAllOnReload-option.patch- Update to 0.9.3 (jsc#SLE-17336): * docs(dbus): fix invalid method names * fix(forward): iptables: ipset used as zone source * fix(rich): non-printable characters removed from rich rules * docs(firewall-cmd): small description grammar fix * fix(rich): limit table to strip non-printables to C0 and C1 * fix(zone): add source with mac address- Add dependency for firewall-offline-cmd (bsc#1180883)- Remove the patch which enforces usage of iptables instead of nftables (jsc#SLE-16300): * 0001-firewall-backend-Switch-default-backend-to-iptables.patch - Add firewalld zone for the docker0 interface. This is the workaround for lack of nftables support in docker. Without that additional zone, containers have no Internet connectivity. (rhbz#1817022, jsc#SLE-16300) - Update to 0.9.1: * Bugfixes: * docs(firewall-cmd): clarify lockdown whitelist command paths * fix(dbus): getActivePolicies shouldn't return a policy if a zone is not active * fix(policy): zone interface/source changes should affect all using zone- Make use of %service_del_postun_without_restart And stop using DISABLE_RESTART_ON_UPDATE as this interface is obsolete.- Add python3-nftables as a requirement.- update to 0.9.0: * New major features * prevention of Zone Drifting * Intra Zone Forwarding * Policy Objects * For a full list of changes, see https://github.com/firewalld/firewalld/compare/v0.8.0...v0.9.0- update to 0.8.3: * nftables: convert to libnftables JSON interface * service: new “helper” element to replace “module” More accurately represents the conntrack helper. Deprecates “module”. * allow custom helpers using standard helper modules (rhbz 1733066) * testsuite is now shipped in the dist tarball * Typo in firewall-config(1) * Fix typo in TFTP service description * doc: README: add note about language translations * fix: rich: source/dest only matching with mark action * feat: AllowZoneDrifting config option * feat: nftables: support AllowZoneDrifting=yes * feat: ipXtables: support AllowZoneDrifting=yes * fix: firewall-offline-cmd: Don’t print warning about AllowZoneDrifting * fix: add logrotate policy * doc: direct: add CAVEATS section * fix: checkIP6: strip leading/trailing square brackets * fix: nftables: remove square brackets from IPv6 addresses * fix: ipXtables: remove square brackets from IPv6 addresses * fix: nftables: ipset types using “port” * fix: nftables: zone dispatch with multidimensional ipsets * fix: ipset: destroy runtime sets on reload/stop * fix: port: support querying sub ranges * fix: source_port: support querying sub ranges * doc: specify accepted characters for object names * fix: doc: address copy/paste mistakes in short/description * fix: configure: atlocal: quote variable values * fix: nftables: allow set intervals with concatenations * doc: clarify –set-target values “default” vs “reject” * fix: update dynamic DCE RPC ports in freeipa-trust service * fix: nftables: ipset: port ranges for non-default protocols * fix(systemd): Conflict with nftables.service * fix(direct): rule in a zone chain * fix(client): addService needs to reduce tuple size * fix(doc): dbus: signatures for zone tuple based APIs * fix(config): bool values in dict based import/export * fix(dbus): service: don’t cleanup config for old set APIs * fix(ipset): flush the set if IndividiualCalls=yes * fix(firewall-offline-cmd): remove instances of “[P]” in help text * fix(rich): source mac with nftables backend * docs: replace occurrences of the term blacklist with denylist * fix: core: rich: Catch ValueError on non-numeric priority values * docs(README): add libxslt for doc generation * fix(cli): add –zone is an invalid option with –direct * fix(cli): add ipset type hash:mac is incompatible with the family parameter- Update to version 0.7.5 (jsc#SLE-12281): * release: v0.7.5 * chore(translation): merge from master * fix(cli): add ipset type hash:mac is incompatible with the family parameter Fixes: rhbz1541077 * test(rhbz1483921): better test name * fix(cli): add --zone is an invalid option with --direct * fix: core: rich: Catch ValueError on non-numeric priority values * fix: update dynamic DCE RPC ports in freeipa-trust service * docs: replace occurrences of the term blacklist with denylist * docs(README): add libxslt for doc generation * test(rich): source mac with nftables backend * fix(firewall-offline-cmd): remove instances of "[P]" in help text * test(check-container): add support for centos8 stream * test(functions): use IndividualCalls if host doesn't support nft rule index * test(functions): add macro IF_HOST_SUPPORTS_NFT_RULE_INDEX * test(dbus): better way to check IPv6_rpfilter expected value * fix(ipset): flush the set if IndividiualCalls=yes * test(ipv6): skip square bracket address tests if ipv6 not available * test(gh509): only run test for nftables backend * fix(dbus): service: don't cleanup config for old set APIs * fix(config): bool values in dict based import/export * fix(doc): dbus: signatures for zone tuple based APIs * test(dbus): zone: fix zone runtime functional test title * test(dbus): zone: fix false failure due to list order * fix(client): addService needs to reduce tuple size * test(direct): rule in a zone chain * fix(direct): rule in a zone chain * test(dbus): zone: verify runtime config APIs * test(dbus): zone: verify permanent config APIs * fix(systemd): Conflict with nftables.service * fix: test/regression/gh599: use expr to be more portable * test: dbus: zone: verify runtime config API signatures * test: dbus: zone: verify permanent config API signatures * fix: test/regression/gh599: fix if not using debug output * test: log: verify logging still works after truncate * test: ipset: verify port ranges for non-default protocol- Update to 0.7.4 This is a bug fix only release. However, it does reintroduce the zone drifting bug as a feature. See #258 and #441. This behavior is disabled by default. * improvement: build: add an option to disable building documentation * Typo in firewall-config(1) * Fix typo in TFTP service description * doc: README: add note about language translations * fix: rich: source/dest only matching with mark action * feat: AllowZoneDrifting config option * feat: nftables: support AllowZoneDrifting=yes * feat: ipXtables: support AllowZoneDrifting=yes * fix: firewall-offline-cmd: Don't print warning about AllowZoneDrifting * fix: add logrotate policy * fix: tests: regenerate testsuite if .../{cli,python}/*.at changes * doc: direct: add CAVEATS section * fix: checkIP6: strip leading/trailing square brackets * fix: nftables: remove square brackets from IPv6 addresses * fix: ipXtables: remove square brackets from IPv6 addresses * fix: nftables: zone dispatch with multidimensional ipsets * fix: ipset: destroy runtime sets on reload/stop * fix: port: support querying sub ranges * fix: source_port: support querying sub ranges * doc: specify accepted characters for object names * fix: doc: address copy/paste mistakes in short/description * fix: configure: atlocal: quote variable values * fix: nftables: allow set intervals with concatenations * doc: clarify --set-target values "default" vs "reject"- Update to version 0.7.3: * release: v0.7.3 * chore: update translations * doc: README: add note about integration tests * test: check-container: also run check-integration * test: integration: NM zone overrides interface on reload * test: build: support integration tests * test: functions: add macro NMCLI_CHECK * test: functions: new macros for starting/stopping NetworkManager * fix: test: leave "cleanup" for tests cases * test: check-container: add support for fedora rawhide * test: check-container: add support for debian sid * test: build: add support for running in containers * fix: test/functions: FWD_END_TEST: improve grep for errors/warnings * fix: test: direct passthrough: no need to check for dummy module * fix: test: CHECK_NAT_COEXISTENCE: only check for kernel version * fix: reload: let NM interface assignments override permanent config * chore: tests: rename IF_IPV6_SUPPORTED to IF_HOST_SUPPORTS_IPV6_RULES * fix: tests: convert host ipv6 checks to runtime * fix: tests: convert ip6tables checks to runtime * fix: tests: convert probe of nft numeric args to runtime * fix: tests: convert nftables fib checks to runtime * fix: build: distribute testsuite * fix: don't probe for available kernel modules * fix: failure to load modules no longer fatal * fix: tests/functions: canonicalize XML output * chore: doc: update authors * fix: test: use debug output based on autotest variable * fix: src/tests/Makefile: distclean should clean atconfig- No longer recommend -lang: supplements are in use.- Replace incorrect usage of %_libexecdir with %_prefix/lib- rebased the original patch from revision 19- Added a patch to make iptables the default again on openSUSE- Update to version 0.7.2: This is a bug fix only release. * fix: direct: removeRules() was mistakenly removing all rules * fix: guarantee zone source dispatch is sorted by zone name * fix: nftables: fix zone dispatch using ipset sources in nat chains * doc: add --default-config and --system-config * fix: --add-masquerade should only affect ipv4 * fix: nftables: --forward-ports should only affect IPv4 * fix: direct: removeRules() not removing all rules in chain * dbus: service: fix service includes individual APIs * fix: allow custom helpers using standard helper modules * fix: service: usage of helpers with '-' in name * fix: Revert "ebtables: drop support for broute table" * fix: ebtables: don't use tables that aren't available * fix: fw: initialize _rfc3964_ipv4- Update to version 0.7.1: * Rich Rule Priorities * Service Definition Includes - Service definitions can now include lines like: which will include all the ports, etc from the https service. * RFC3964 IPv4 filtering - A new option RFC3964_IPv4 in firewalld.conf is available. It does filtering based on RFC3964 in regards to IPv4 addresses. This functionality was traditionally in network-scripts. * FlushAllOnReload - A new option FlushAllOnReload in firewalld.conf is available. Older release retained some settings (direct rules, interface to zone assignments) during a - -reload. With the introduction of this configuration option that is no longer the case. Old behavior can be restored by setting FlushAllOnReload=no. * 15 new service definitions * fix: firewall-offline-cmd: service: use dict based APIs * fix: client: service: use dict based dbus APIs * test: dbus: coverage for new service APIs * fix: dbus: new dict based APIs for services * test: dbus: service API coverage * test: functions: add macro DBUS_INTROSPECT * test: functions: add CHOMP macro for shell output * fix: tests/functions: use gdbus instead of dbus-send * fix: dbus: add missing APIs for service includes - Remove patch for using iptables instead of nftables - we should finally switch to nftables and fix its issues properly if they occur again: * 0001-firewall-backend-Switch-default-backend-to-iptables.patch - Remove patch which was released upstream: * 0002-Add-FlushAllOnReload-config-option.patch- Update to version 0.6.4: * chore: update translations * treewide: fix over indentation (flake8 E117) * test: travis: add another test matrix for omitting ip6tables * chore: travis: split test matrix by keywords * chore: tests: add AT_KEYWORDS for firewall-offline-cmd * improvement: tests: Use AT_KEYWORDS for backends * fix: tests: guard occurrences of IPv6 * fix: tests/functions: ignore warnings about missing ip6tables * test: add macro IF_IPV6_SUPPORTED- Move RPM macros to %_rpmmacrodir.- Revert last change: the macros DO reference firewall-cmd, but as they are expanded during build time of the package, not at runtime, the point in time is wrong to require firewalld. The consumer of the macro is responsible to ask for the right commands to be present at runtime of the scripts (boo#1125775#c9).- Add dependency between firewall-macros and firewalld. (boo#1125775)- Fix --with-ifcfgdir configure parameter. (boo#1124212)- Add upstream patch to make --reload/--complete-reload forget the runtime configuration and always load the permanent one (bsc#1121277) * 0002-Add-FlushAllOnReload-config-option.patch- Update to 0.6.3. Some of the changes are: * update translations * nftables: fix reject statement in "block" zone * shell-completion: bash: don't check firewalld state * firewalld: fix --runtime-to-permanent if NM not in use. * firewall-cmd: sort --list-protocols output * firewall-cmd: sort --list-services output * command: sort services/protocols in --list-all output * services: add audit * nftables: fix rich rule log/audit being added to wrong chain * nftables: fix destination checks not allowing masks * firewall/core/io/*.py: Let SAX handle the encoding of XML files (gh#firewalld/firewalld#395)(bsc#1083361) * fw_zone: expose _ipset_match_flags() * tests/firewall-cmd: exercise multiple interfaces and zones * fw_transaction: On clear zone transaction, must clear fw and other zones * Fix translating labels (gh#firewalld/firewalld#392) - Remove patches which have made it upstream: * 0001-Fix-translating-labels-392.patch * 0002-firewalld-0.6.x-rich-rule-with-ipset-regression.patch- Add upstream patch to mark more strings as translatable which is required by firewall UI when creating rich rules (bsc#1096542) * 0001-Fix-translating-labels-392.patch- Add upstream patch to fix rich rules that uses ipset (bsc#1104990) * 00002-firewalld-0.6.x-rich-rule-with-ipset-regression.patch- Update to 0.6.2. Some of the changes are: * update translations * nftables: fix log-denied with values other than "all" or "off" * fw_ipset: raise FirewallError if backend command fails * ipset: only use "-exist" on restore * fw_ipset: fix duplicate add of ipset entries * *tables: For opened ports/protocols/etc match ct state new,untracked (bsc#1105821) * ipXtables: increase wait lock to 10s * nftables: fix rich rules ports/protocols/source ports not considering ct state * ports: allow querying a single added by range * fw_zone: do not change rich rule errors into warnings * fw_zone: fix services with multiple destination IP versions (bsc#1105899) * fw_zone: consider destination for protocols * firewall/core/fw_nm: nm_get_zone_of_connection should return None or empty string instead of False (boo#1106319) * fw: If direct rules fail to apply add a "Direct" label to error msg * fw: if startup fails on reload, reapply non-perm config that survives reload * nftables: fix rich rule audit log * ebtables: replace RETURN policy with explicit RETURN at end of chain * direct backends: allow build_chain() to build multiple rules * fw: if failure occurs during startup set state to FAILED * fw: on restart set policy from same function * ebtables: drop support for broute table - Remove upstream patches * 0001-nftables-fix-rich-rules-ports-protocols-source-ports.patch * 0001-fw_zone-consider-destination-for-protocols.patch * 0002-fw_zone-fix-services-with-multiple-destination-IP-ve.patch * firewalld-fix-firewalld-config-crash.patch- Add upstream patch to fix Neighbor Discovery filtering for IPv6 (bsc#1105821) * 0001-nftables-fix-rich-rules-ports-protocols-source-ports.patch - Add upstream patch to fix building rules for multiple IP families (bsc#1105899) * 0001-fw_zone-consider-destination-for-protocols.patch * 0002-fw_zone-fix-services-with-multiple-destination-IP-ve.patch- Add firewalld-fix-firewalld-config-crash.patch: set nm_get_zone_of_connection to return 'None' instead of 'False' for automatically generated connections to avoid firewall-config crashes. Patch provided by upstream (boo#1106319, gh#firewalld/firewalld#370).- Also switch firewall backend fallback to 'iptables' (bsc#1102761) This ensures that existing configuration files will keep working even if FirewallBackend option is missing. * 0001-firewall-backend-Switch-default-backend-to-iptables.patch- Update to 0.6.1. Some of the changes are: * Correct source/destination in rich rule masquerade * Only modify ifcfg files for permanent configuration changes * Fix a backtrace when calling common_reverse_rule() * man firewalld.conf: Show nftables is the default FirewallBackend * firewall-config: fix some untranslated strings that caused a UI bug causing rich rules to not be modify-able (bsc#1096542) * fw_direct: avoid log for untracked passthrough queries * fixed many issues if iptables is actually iptables-nft * Use preferred location for AppData files * ipXtables: fix ICMP block inversion with set-log-denied * fixes ICMP block inversion with set-log-denied with IndividualCalls=yes * nftables: fix set-log-denied if target is not ACCEPT * fw_direct: strip _direct chain suffix if using nftables * NetworkManager integration bugfixes.- Switch back to 'iptables' backend as default (bsc#1102761)- Update to 0.6.0. Some of the changes are: * update translations * firewall-config: Add ipv6-icmp to the protocol dropdown box (#348, bsc#1099698) * core: logger: Remove world-readable bit from logfile (#349, bsc#1098986) * IPv6 rpfilter: explicitly allow neighbor solicitation * nftables backend (default) * Added loads of new services * firewall-cmd: add --check-config option * firewall-offline-cmd: add --check-config option * firewallctl: completely remove all code and references * dbus: expose FirewallBackend * dbus: fix erroneous fallback for AutomaticHelpers - Remove patches which have made it upstream * firewalld-add-additional-services.patch - spec-cleaner fixes- Update to 0.5.3 (bsc#1093120) * tests/regression: add test for ipset with timeout * ipset: allow adding entries to ipsets with timeout * translations: update * helpers: load helper module explicitly if no port given * helpers: nf_conntrack_proto-* helpers needs name cropped * config/Makefile: correct name of proto-gre helper * tests/regression: test helper nf_conntrack_proto_gre (#263) * functions: get_nf_nat_helpers() should look in other directories too * functions: Allow nf_conntrack_proto_* helpers * services: Add GRE * helpers: Add proto-gre * tests/regression: add test to verify ICMP block in forward chain * ipXtables: fix ICMP block not being present in FORWARD chain- Translations update (bsc#1081623).- Backport upstream patches to add additional services (bsc#1082033) * firewalld-add-additional-services.patch- Update to 0.5.2 * fix rule deduplication causing accidental removal of rules * log failure to parse direct rules xml as an error * firewall-config: Break infinite loop when firewalld is not running * fix set-log-denied not taking effect * po: update translations- Remove high-availability service. SUSE HA uses the cluster service provided by the yast2-cluster package (bsc#1078223)- Update to 0.5.1 * ipXtables: fix iptables-restore wait option detection * python3: use "foo in dict" not dict.has_key(foo) * Fix potential python3 keys() incompatibility in watcher * Fixed python3 compatibility * ebtables: fix missing default value to set_rule() * fw_zone: fix invalid reference to __icmp_block_inversion * zones: Correct and defer check_name for combined zones- Update to 0.5.0 * firewallctl: mark deprecated (gh#firewalld/firewalld##261) * Add nmea-0183 service * Add sycthing-gui service * Add syncthing service * Adding FirewallD jenkins service (gh#firewalld/firewalld#256) * services/high-availability: Add port 9929 * Fix and improve firewalld-sysctls.conf * firewalld: also reload dbus config interface for global options * Add MongoDB service definition * src: firewall: Add support for SUSE ifcfg scripts * Add UPnP client service * firewalld: Allow specifying log file location * firewalld/firewall-offline-cmd: Allow setting system config directories - Drop obsolete patch * 0001-suse-ifcfg-files.patch - Drop tests installation- Introduce new python3-firewall and firewall-macros subpackages. The first one contains the firewalld python3 bindings and the second one contains the RPM macros for firewalld.- Replace dbus-1-python requires with dbus-1-python3: since firewalld was migrated to python3, we also have to require the python3 dependencies (boo#1070310).- Add missing python3-gobject-Gdk dependency (boo#1069952)- Replace references to /var/adm/fillup-templates with new %_fillupdir macro (boo#1069468)- Make sure to use python3 everywhere (boo#1068778)- Add combined upstream patch to support SUSE ifcfg network files. * 0001-suse-ifcfg-files.patch (gh#firewalld/firewalld#262, fate#323460)- Update to version 0.4.4.6 * firewall.core.fw_config: Fix check for icmp builtin name * config.services: docker-swarm: fix incorrect attribute * xmlschema/service.xsd: Fix protocol looking for name instead of value * Add docker swarm service (gh#firewalld/firewalld#230) * Adding FirewallD redis service (gh#firewalld/firewalld#248) * Adding firewalld zabbix server and agent services (gh#firewalld/firewalld#221) * firewall-offline-cmd: Don't require root for help output * doc: firewall-cmd: Document --query-* options return codes * firewall-cmd: Use colors only if output is a TTY * core: Log unsupported ICMP types as informational only * add bgp service to predefined services edit to config/Makefile.am * Add git service * Add kprop service * minidlna definitions (gh#firewalld/firewalld#236) * SpiderOak ONE listens on port 21327 and 21328 * autogen.sh: Allow skipping configure via NOCONFIGURE env var * Add missing ports to RH-Satellite-6 service * Reload nf_conntrack sysctls after the module is loaded * Add NFSv3 service. * config/Makefile.am: Add murmur service (a95eed1) * add new service IRC * firewall.core.prog: Simplify runProg output: Combine stderr and stdout * firewall.core.fw: Fix possible dict size change in for loop * firewall.core.fw: Use new firewalld git repo in firewalld organization * config/firewall-config.appdata.xml.in: Use new firewalld git repo in firewalld organization * firewall.core.fw_zone: Rich-rule ICMP type: Error only for conflicting family * firewall.core.rich: Add checks for Rich_Source validation * Handle also IPv6 with the zone masquerade flag * Add IPv6 support for forward-ports in zones * firewall.command: Enable parse_forward_port to work with IPv6 adresses * firewall.core.fw_zone: Fix IPv6 address in rich rule forward ports * add Murmur (Mumble server) service - spec file fixes to avoid rpmlint warnings about duplicate files.- Switch to python3 - Run spec cleaner - Move autogen to build section - Add systemd requirements- Update to version 0.4.4.5 * firewall-offline-cmd: Fix --remove-service-from-zone option (rh#1438127) * Support sctp and dccp in ports, source-ports, forward-ports, helpers and rich rules * firewall-cmd: Fix --{set,get}-{short,description} for zone * firewall.core.ipXtables: Use new wait option for restore commands if available * Adding ovirt-vmconsole service file * Adding oVirt storage-console service. * Adding ctdb service file. * Adding service file for nrpe. * Rename extension for policy choices (server and desktop) to .policy.choice (rh#1449754) * D-Bus interfaces: Fix GetAll for interfaces without properties (rh#1452017) * firewall.core.fw_config: Fix wrong variable use in repr output * firewall.core.fw_icmptype: Add missing import for copy * firewall.core.fw_test: Fix wrong format string in repr * firewall.core.io.zone: Fix getattr use on super(Zone) * firewall.functions: New function get_nf_nat_helpers * firewall.core.fw: Get NAT helpers and store them internally. * firewall.core.fw_zone: Load NAT helpers with conntrack helpers * firewalld.dbus: Add missing properties nf_conntrach_helper_setting and nf_conntrack_helpers * firewall.server.firewalld: New property for NAT helpers supported by the kernel- Update to version 0.4.4.4 * Drop references to fedorahosted.org from spec file and Makefile.am * firewall-config: Show invalid ipset type in the ipset dialog in the bad label * firewall.core.fw: Show icmptypes and ipsets with type errors in permanent env * firewall.server.firewalld: Provide information about the supported icmp types * firewall.core.fw_icmptype: Add ICMP type only if the type is supported * firewall.core.fw: New attributes ip{4,6}tables_supported_icmp_types * firewall.core.ipXtables: New method supported_icmp_types * firewall-config: Deactivate edit buttons if there are no items * firewall.core.io.zone: Fix permanent rich rules using icmp-type (rh#1434594) * firewall.core.fw_ipset: get_ipset may not ckeck if set is applied by default * firewall.core.fw_transaction: Use LastUpdatedOrderedDict for zone transactions - Remove upstream patch: * 0001-firewall.core.fw_ipset-get_ipset-may-not-ckeck-if-se.patch- Update to version 0.4.4.3 * New service freeipa-trust (rh#1411650) * Complete icmp types for IPv4 and IPv6 * New h323 helper container * Support helper container: h323 * firewall.server.decorators: ALREADY_ errors should be logged as warnings * firewall.command: ALREADY_SET should also result in zero exit code * tests/firewall-offline-cmd_test.sh: Only use firewall-offline-cmd * Support more ipset types: hash:ip,port, hash:ip,port,ip, hash:ip,port,net, hash:ip,mark, hash:net,net, hash:net,port, hash:net,port,net, hash:net,iface * New checks for ipset entry validation * Use ipset dimension for match * firewall.core.base: New ZONE_SOURCE_IPSET_TYPES list * New firewall.core.icmp providing names and types for icmp and icmpv6 values * firewall.core.fw_ipset: New methods to get ipset dimension and applied state * firewall.errors: New error NOT_APPLIED * firewall-cmd man page: Add missing --get-ipset-types * firewall.core.fw_nm: No trace back on failed get_connection call (rh#1413345) * firewall.core.prog: Fix addition of the error output in runProg * Speed up ipset handling, (re)loading and import from file * Support --family option for --new-ipset * Handle FirewallError for query sequences in command line tools * Fail to alter entries of ipsets with timeout * Extended tests for ipset options * Return empty list for ipsets using timeouts * firewall.functions: Fix checks in checkIPnMask and checkIP6nMask (gh#t-woerner/firewalld#186) * firewalld.conf man page: New section about AutomaticHelpers * firewall-offline-cmd man page: Added -v and -q options, fixed section ids * firewall{-cmd, ctl}: Fix scope of final return in try_set_zone_of_interface * firewall.core.fw_zone: Limit masquerading forward rule to new connections * firewall-config: Update active zones on reloaded signal * firewall-applet: Update active zones and tooltip on reloaded signal * firewall.core.fw_zone: Fix missing chain for helper in rich rules using service (rh#1416578) * Support icmp-type usage in rich rules (rh#1409544) * firewall[-offline]-cmd: Fix --{set,get}-{short,description} for ipset and helper (rh#1416325) * firewall.core.ipset: Solve ipset creation issues with -exist and more flag tests * Speed up start and restart for ipsets with lots of entries (rh#1416817) * Speed up of ipset alteration by adding and removing entries using a file (rh#1416817) * Code cleanup and minor bug fixes * firewall.core.prog: Fix addition of the error output in runProg * New services mssql, kibana, elasticsearch, quassel, bitcoin-rpc, bitcoin-testnet-rpc, bitcoin-testnet, bitcoin and spideroak-lansync * Translation updates - Add upstream patch to fix ipset overloading from /etc/firewalld/ipsets (gh#t-woerner/firewalld#206) * 0001-firewall.core.fw_ipset-get_ipset-may-not-ckeck-if-se.patch- Update to version 0.4.4.2 * firewalld.spec: Added helpers and ipsets paths to firewalld-filesystem * firewall.core.fw_nm: create NMClient lazily * Do not use hard-coded path for modinfo, use autofoo to detect it * firewall.core.io.ifcfg: Dropped invalid option warning with bad format string * firewall.core.io.ifcfg: Properly handle quoted ifcfg values * firewall.core.fw_zone: Do not reset ZONE with ifdown * Updated translations from zanata * firewall-config: Extra grid at bottom to visualize firewalld settings- Update to version 0.4.4.1 * Translation updates form zanata * firewallctl: New support for helpers * firewallctl: Use sys.excepthook to force exception_handler usage always * firewall-config: Use proper source check in sourceDialog- Update to version 0.4.4 * firewall-applet: Use PyQt5 * firewall-config: New nf_conntrack_select dialog, use nf_conntrack_helpers D-Bus property * New helpers Q.931 and RAS from nf_conntrack_h323 * firewall.core.fw_zone: Add zone bingings for PREROUTING in the raw table * firewall.core.ipXtables: Add PREROUTING default rules for zones in raw table * New helper configuration files for amanda, ftp, irc, netbios-ns, pptp, sane, sip, snmp and tftp * firewall-cmd: Fixed --{get,set}-{description,short} for permanent zones * firewall.command: Do not use error code 254 for {ALREADY,NOT}_ENABLED sequences * Misc bug fixes. * For the complete list of changes please see: https://github.com/t-woerner/firewalld/releases/tag/v0.4.4- Relax permissions for default installation files. The files in /usr/lib/firewalld are the default ones as shipped by the package and there is nothing secret in them.- Update to version 0.4.3.3 * Fixes CVE-2016-5410 (bsc#992772) * Standard error is now used for errors and warnings * Several fixes for use in change roots * Systemd service file changes * Fixed translations in firewall-config * Command line clients * Fixes infinite event handling loop in firewall-{config,applet} (bsc#992082)- Update to version 0.4.3.2 * Fix regression with unavailable optional commands * All missing backend messages should be warnings * Individual calls for missing restore commands * Only one authenticate call for add and remove options and also sequences * New service RH-Satellite-6- Update to version 0.4.3.1 * firewall.command: Fix python3 DBusException message not interable error * src/Makefile.am: Fix path in firewall-[offline-]cmd_test.sh while installing * firewallctl: Do not trace back on list command without further arguments * firewallctl (man1): Added remaining sections zone, service, .. * firewallctl: Added runtime-to-permanent, interface and source parser, IndividualCalls setting * firewall.server.config: Allow to set IndividualCalls property in config interface * Fix missing icmp rules for some zones * runProg: Fix issue with running programs * firewall-offline-cmd: Fix issues with missing system-config-firewall * firewall.core.ipXtables: Split up source and dest addresses for transaction * firewall.server.config: Log error in case of loading malformed files in watcher * Install and package the firewallctl man page * Translation updates- Update to version 0.4.3 * New firewallctl utility (rh#1147959) * doc.xml.seealso: Show firewalld.dbus in See Also sections * firewall.core.fw_config: Create backup on zone, service, ipset and icmptype removal (rh#1339251) * {zone,service,ipset,icmptype}_writer: Do not fail on failed backup * firewall-[offline-]cmd: Fix --new-X-from-file options for files in cwd * firewall-cmd: Dropped duplicate setType call in --new-ipset * radius service: Support also tcp ports (RBZ#1219717) * xmlschemas: Support source-port, protocol, icmp-block-inversion and ipset sources * config.xmlschema.service.xsd: Fix service destination conflicts (rh#1296573) * firewall-cmd, firewalld man: Information about new NetworkManager and ifcfg * firewall.command: Only print summary and description in print_X_info with verbose * firewall.command: print_msg should be able to print empty lines * firewall-config: No processing of runtime passthroughs signals in permanent * Landspace.io fixes and pylint calm downs * firewall.core.io.zone: Add zone_reader and zone_writer to all, pylint fixes * firewall-config: Fixed titles of command and context dialogs, also entry lenths * firewall-config: pylint calm downs * firewall.core.fw_zone: Fix use of MAC source in rich rules without ipv limit * firewall-config: Use self.active_zoens in conf_zone_added_cb * firewall.command: New parse_port, extended parse methods with more checks * firewall.command: Fixed parse_port to use the separator in the split call * firewall.command: New [de]activate_exception_handler, raise error in parse_X * services ha: Allow corosync-qnetd port * firewall-applet: Support for kde5-nm-connection-editor * tests/firewall-offline-cmd_test.sh: New tests for service and icmptype modifications * firewall-offline-cmd: Use FirewallCommand for simplification and sequence options * tests/firewall-cmd_test.sh: New tests for service and icmptype modifications * firewall-cmd: Fixed set, remove and query destination options for services * firewall.core.io.service: Source ports have not been checked in _check_config * firewall.core.fw_zone: Method check_source_port is not used, removed * firewall.core.base: Added default to ZONE_TARGETS * firewall.client: Allow to remove ipv:address pair for service destinations * tests/firewall-offline-cmd_test.sh: There is no timeout option in permanent * firewall-cmd: Landscape.io fixes, pylint calm downs * firewall-cmd: Use FirewallCommand for simplification and sequence options * firewall.command: New FirewallCommand for command line client simplification * New services: kshell, rsh, ganglia-master, ganglia-client * firewalld: Cleanup of unused imports, do not translate some deamon messages * firewalld: With fd close interation in runProg, it is not needed here anymore * firewall.core.prog: Add fd close iteration to runProg * firewall.core.fw_nm: Hide NM typelib import, new nm_get_dbus_interface function * firewalld.spec: Require NetworkManager-libnm instead of NetworkManager-glib * firewall-config: New add/remove ipset entries from file, remove all entries * firewall-applet: Fix tooltip after applet start with connection to firewalld * firewall-config: Select new zone, service or icmptype if the view was empty * firewalld.spec: Added build requires for iptables, ebtables and ipset * Adding nf_conntrack_sip module to the service SIP * firewall: core: fw_ifcfg: Quickly return if ifcfg directory does not exist * Drop unneeded python shebangs * Translation updates - Remove obsolete patches: * 0001-src-firewall-core-Drop-unneeded-python-shebangs.patch * 0002-firewall-core-fw_ifcfg-Quickly-return-if-ifcfg-direc.patch * 0003-firewall.core.fw_nm-Hide-NM-typelib-import-new-nm_ge.patch - Add missing %{?_smp_mflags} during install. This will speed up the installation phase as well as expose build system's problems due to higher level of parallelism. - Run make during %build to ensure missing documentation is generated. - spec file cleanups.- Add upstream patch to prevent unconditional dependencies to the NetworkManager typelib (gh#t-woerner/firewalld#119) * 0003-firewall.core.fw_nm-Hide-NM-typelib-import-new-nm_ge.patch- Update to version 0.4.2 * New module to search for and change ifcfg files for interfaces not under control of NM * firewall_config: Enhanced messages in status bar * firewall-config: New message window as overlay if not connected * firewall-config: Fix sentivity of option, view menus and main paned if not connected * firewall-applet: Quit on SIGINT (Ctrl-C), reduced D-Bus calls, some cleanup * firewall-[offline]cmd: Show target in zone information * D-Bus: Completed masquerade methods in FirewallClientZoneSettings * Fixed log-denied rules for icmp-blocks * Keep sorting of interfaces, services, icmp-blocks and other settings in zones * Fixed runtime-to-permanent not to save interfaces under control of NM * New icmp-block-inversion flag in the zones * ICMP type filtering in the zones * New services: sip, sips, managesieve * rich rules: Allow destination action (rh#1163428) * firewall-offline-cmd: New option -q/--quiet * firewall-[offline-]cmd: New --add-[zone,service,ipset,icmptype]-from-file * firewall-[offline-]cmd: Fix option for setting the destination address * firewall-config: Fixed resizing behaviour * New transaction model for speed ups in start, restart, stop and other actions * firewall-cmd: New options --load{zone,service,ipset,icmptype}-defaults * Fixed memory leak in dbus_introspection_add_properties * Landscape.io fixes, pylint calm downs * New D-Bus getXnames methods to speed up firewall-config and firewall-cmd * ebtables-restore: No support for COMMIT command * Source port support in services, zones and rich rules * firewall-offline-cmd: Added --{add,remove}-entries-from-file for ipsets * firewall-config: New active bindings side bar for simple binding changes * Reworked NetworkManager module * Proper default zone handling for NM connections * Try to set zone binding with NM if interface is under control of NM * Code cleanup and bug fixes * Include test suite in the release and install in /usr/share/firewalld/tests * New Travis-CI configuration file * Fixed more broken frensh translations * Translation updates - Add upstream patches * 0001-src-firewall-core-Drop-unneeded-python-shebangs.patch: Removes unneeded python shebangs * 0002-firewall-core-fw_ifcfg-Quickly-return-if-ifcfg-direc.patch: Do not try to access the network-scripts ifcfg directory. - Drop rejected patch * drop-standard-output-error-systemd.patch - Minor spec file clean-up- Avoid runtime dependency on systemd, the macros can all deal with its absence.- Suggest the susefirewall2-to-firewalld package which could assist in migrating the SuSEFirewall2 iptables rules to FirewallD.- Update to version 0.4.1.2 * Install fw_nm module * firewalld: Do not fail if log file could not be opened * Make ipsets visible per default in firewall-config * Fixed translations with python3 [changes in 0.4.1.1] * Fix for broken frensh translation [changes in 0.4.1] * Enhancements of ipset handling * No cleanup of ipsets using timeouts while reloading * Only destroy conflicting ipsets * Only use ipset types supported by the system * Add and remove several ipset entries in one call using a file * Reduce time frame where builtin chains are on policy DROP while reloading * Include descriptions in --info-X calls * Command line interface support to get and alter descriptions of zones, * services, ipsets and icmptypes with permanent option * Properly watch changes in combined zones * Fix logging in rich rule forward rules * Transformed direct.passthrough errors into warnings * Rework of import structures * Reduced calls to get ids for port and protocol names (rh#1305434) * Build and installation fixes by Markos Chandras * Provide D-Bus properties in introspection data * Fix for flaws found by landscape.io * Fix for repeated SUGHUP * New NetworkManager module to get and set zones of connections, used in firewall-applet and firewall-config * configure: Autodetect backend tools ({ip,ip6,eb}tables{,-restore}, ipset) * Code cleanups * Bug fixes - Fix drop-standard-output-error-systemd.patch tagging - Add libxslt-tools build dependency- Do not recommend a specific version for the lang subpackage- Move translations to a new subpackage- Set DISABLE_RESTART_ON_UPDATE to 'yes' instead of '1'. The macros in /etc/rpm/macros.systemd only check for the 'yes' value so fix it to properly prevent the firewalld service from being restarted during updates.- Drop typelib(NetworkManager), NetworkManager-glib, gtk3 and libnotify dependencies (see OBS SR#360792)- firewall-config needs typelib(NetworkManager) to run- Initial commit. Version 0.4.0 * drop-standard-output-error-systemd.patch (gh#t-woerner/firewalld/pull/67)h03-ch2d 1761209003  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijkmnopqrstuvwxyz{|}~1.3.4-150600.13.3.1 firewall__init__.py__pycache____init__.cpython-36.pycclient.cpython-36.pyccommand.cpython-36.pycdbus_utils.cpython-36.pycerrors.cpython-36.pycfunctions.cpython-36.pycfw_types.cpython-36.pycclient.pycommand.pyconfig__init__.py__pycache____init__.cpython-36.pycdbus.cpython-36.pycdbus.pycore__init__.py__pycache____init__.cpython-36.pycbase.cpython-36.pycebtables.cpython-36.pycfw.cpython-36.pycfw_config.cpython-36.pycfw_direct.cpython-36.pycfw_helper.cpython-36.pycfw_icmptype.cpython-36.pycfw_ifcfg.cpython-36.pycfw_ipset.cpython-36.pycfw_nm.cpython-36.pycfw_policies.cpython-36.pycfw_policy.cpython-36.pycfw_service.cpython-36.pycfw_transaction.cpython-36.pycfw_zone.cpython-36.pychelper.cpython-36.pycicmp.cpython-36.pycipXtables.cpython-36.pycipset.cpython-36.pyclogger.cpython-36.pycmodules.cpython-36.pycnftables.cpython-36.pycprog.cpython-36.pycrich.cpython-36.pycwatcher.cpython-36.pycbase.pyebtables.pyfw.pyfw_config.pyfw_direct.pyfw_helper.pyfw_icmptype.pyfw_ifcfg.pyfw_ipset.pyfw_nm.pyfw_policies.pyfw_policy.pyfw_service.pyfw_transaction.pyfw_zone.pyhelper.pyicmp.pyio__init__.py__pycache____init__.cpython-36.pycdirect.cpython-36.pycfirewalld_conf.cpython-36.pycfunctions.cpython-36.pychelper.cpython-36.pycicmptype.cpython-36.pycifcfg.cpython-36.pycio_object.cpython-36.pycipset.cpython-36.pyclockdown_whitelist.cpython-36.pycpolicy.cpython-36.pycservice.cpython-36.pyczone.cpython-36.pycdirect.pyfirewalld_conf.pyfunctions.pyhelper.pyicmptype.pyifcfg.pyio_object.pyipset.pylockdown_whitelist.pypolicy.pyservice.pyzone.pyipXtables.pyipset.pylogger.pymodules.pynftables.pyprog.pyrich.pywatcher.pydbus_utils.pyerrors.pyfunctions.pyfw_types.pyserver__init__.py__pycache____init__.cpython-36.pycconfig.cpython-36.pycconfig_helper.cpython-36.pycconfig_icmptype.cpython-36.pycconfig_ipset.cpython-36.pycconfig_policy.cpython-36.pycconfig_service.cpython-36.pycconfig_zone.cpython-36.pycdbus.cpython-36.pycdecorators.cpython-36.pycfirewalld.cpython-36.pycserver.cpython-36.pycconfig.pyconfig_helper.pyconfig_icmptype.pyconfig_ipset.pyconfig_policy.pyconfig_service.pyconfig_zone.pydbus.pydecorators.pyfirewalld.pyserver.py/usr/lib/python3.6/site-packages//usr/lib/python3.6/site-packages/firewall//usr/lib/python3.6/site-packages/firewall/__pycache__//usr/lib/python3.6/site-packages/firewall/config//usr/lib/python3.6/site-packages/firewall/config/__pycache__//usr/lib/python3.6/site-packages/firewall/core//usr/lib/python3.6/site-packages/firewall/core/__pycache__//usr/lib/python3.6/site-packages/firewall/core/io//usr/lib/python3.6/site-packages/firewall/core/io/__pycache__//usr/lib/python3.6/site-packages/firewall/server//usr/lib/python3.6/site-packages/firewall/server/__pycache__/-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.suse.de/SUSE:Maintenance:41287/SUSE_SLE-15-SP6_Update/3ec1d7750b15ab550b02c4c024416bad-firewalld-legacy.SUSE_SLE-15-SP6_Updatedrpmxz5noarch-suse-linuxdirectoryemptypython 3.6 byte-compiledPython script, ASCII text executableASCII text  !"#$%&'()*+,-./01236789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^abcdefghijklmnopqrstuvwxyz{}RRRRRRRRRR RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR RR RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR R RRRRRRRRRRRRRRRRRRRRRRRRRRRR RR .usL3Xv9utf-80e82ff2c083ebb6c3555d189289fd4d3959ece56f62feb78d03dc488bda80dd4? 7zXZ !t/4]"k%w#) `>A\C&։6Ѻ-Rkbz;8,@ |h:(U瑶S]>cVTF5qsy +-RCX=/jD!v 0#ŹRaBQ.6"nYݻ1vY uBsT-/cPV{u&O!n?>nD"8joeʹb-R}t)>@'i  \ʔy9]z⧪HQ —ssbօ]ձyʒ;-*AqU`e-jmm g*yHU˙y\gnG|R]ag8ca@$˸Cb{M2 8D|GU̿Hfo4Xe1Y30iffni-"AV}bj[@/3 {\,s}4~aV=&R{8? B& DB#2z>_Ҹ,D6j-֝?q f`>|l)!WW^2>xuKOz*  <#gFvWpwFpGg놧xa-9!hqlxV]/pjXlǘ{ -etmfs OeXO aw6<$t9=FU{[W4Z#z}kFS-sloDSϐ>3 v4A 3lU kK:~j Rh4aXګj^>JvmNAco_aM`(oUb1$?&[w=j: QDكQ"ր~+z#;ۮIۤ.>iWIszxMKf&*IL* -/۫ݎ- >ؖ:[*G,^oG\cfW &|!E 6e,Tbw^*ڦ$g;4--`]qո*UDz <!7{HGF;vDw:˜ -9* 3Aiπ5m!ǴA 4@aHmaƦdž~6. +né?FN:E5h'$"&OX,BuQBާ!Rw%g7iTgC #(,-ѣy-ֈ FT 3rAD}Fq6#|= Li뫏צȭi9Zy"mIG j$֌i]gY3!'`ǩ2,iV}cdӀlw}*fvO 0R_Ozמ̮YI*!5 A'8S{d&{)2pmH-7ݞ9 d^2Ԛ<8K|i:00 vz~X3~:'ȥ*D#/@(`MC`ҋ2dFXrJU5_D|ZKt4pv (&*qds? z/H>MwGS;6Tv)hIlt]`-kǚ)qi%,\ \c'NS7]Ux=Cڌ}s(} #X/ӶM@åJAlTfUR\a|39^4*X:)_K%6Hђq&Ȁ<;ڮx`S/^Ce=>\\8BJft)xv&k$Rl!CoO1R4!ԭe-)$e A1 <8uNPP []E&*zr$>$!#gL0*Uǹ5q|&khK\TL~ؚ~Rl|"[$WAxC*ĝ.:4jﵒ^Іu@>*eIۥVE 9~bcݕe\ʯRW\"ԝ"z:phg_ˈ|0؉"!}T$Ғy Q;aZoV ͤw~HU;",yw:WMXƚ+=/9YY4^xVq;XO6"dj6vxqĘ..Tm @0Ƕ#,BD9| Kv]QälJ_aK6qs>Kq*D+QR$i|hސ3֟[ bKx"g|R^HZ ܈($DSHưpJ'6Z[NwO[GRfU=Q -Drbh|:Re즁lE7p Uǩ×C Q.2T6"Pemt]o{7C} ',5㬽y KenQ:Q 38Q싂.!rvsm2(^<y3pA{htJ S_ bYPv)ȟBh}ENnRǛ]qA(Óv$O;hKOj18pg8>;V=xaaG8kɃ9q] 3vW_bIo/et.糾V;:HQ`P|Z "F^8o#F9KWЂ4l%RwVe>J}mLqF-bT6ߥޅ[T̂4fYvК !d/rX$_eyOgs8Jl}S]n ߑSAJ_ /B j'=:vVꁎkss9Zn摒op QdUT'#Zak >1(.O9 W7Htos;Zk<@3vdک_5fMD{HJ_Đ0v)inQhCr=4d2uJus AԚ]jwS" %Z !*G}a2NL Ǯ@9iU}W9ÜO3ɸ+XWy+N˰'I`[mm⦮ ]Zŀ?Zf-(.P5ԉ _^i 0~k;Wmq%nOYrc{zT482s٣1&-Q͘V򽩍;`,,|=Ss}9*]] -nw^Xl[Η._Kijixx-VʡvKp&PRf7wCZa4e{V{&%N~z]ITyx0&}+YXc^9mszhN/~za >~ƾuDs!~#dOVOcHD|Iaѱكl(W`,6J nqW[ɍޭ'`\,~ Qe&EYP9 ʻx7-1S>)ަ9ΠaMdYT*KvNU3O2 K) GJ[[69'A6). [De[(wN`604o XSLgLc&Е?β'Pӻ ֮ ô~,?璲0] sg-vg+2uO*sY6ǧQFUȶүzHk,AG'ɲ%q6n@v)\\rSl ahF>(£wK(}Ft+.5cHIο${( 9>st%/qE $MV~5أ0qI嗄~r58rd[ߓ@mB S^~ZeDkvG7.0f߅Na@WJ Aא]uS`<_Xw笅ʏv)ۀz Mʹl*jV1,);HΓ %*vTav7 F˦::\N_[jߣ.TJGqnZmٸ ES NCaxg!L-lߦEZ7\=R9VRȷ"Z)_/|[z8ջ\YDG׈N Rʀ9L&Oi#|u!|cLp 0iՕ:@,}AOrG&fLLi#(eqtz5~n9n}hxʫrXP؏_L@vB ͙ QZP`у { 4j=5J*DE 9ꑎ[lVFʶnuxe8(`=br9DZ$"`ch=%kfeJP_:'S/: vp-/鹇oG6֜k$ "as8Iu*~*8j(fB͙Cφqsʺ -]]. 6t?;Zu:u&.g||(: T>쉉Gn/D 6b\H 'IRA^p)̞G%WByû{kTtܕ^]T 5ɡRCӳ A?󥁆h>\f:n4;a(^{0lb8KT.\5N5Ro=-#ZIY *Ό/44-e.٨pR$c4]u(^_"'U0='ƣ9{f(g0^"ҭSOaƍm?s4ů?=ͤҔ>%gf & +2bk7^J8z[ov˚'PMRV0Z(նŭi+Wpl9-ҤDП|Tߒtf@Jbt__S+X H}>#`UY"g.Ik+Yͮ,7bzhUF5ŐOj෱D& Z8>m Oᰵ^2%a{kIk$gv)?r1q~z*L.shǡӘxY5S/7)/eg:_Tr#v|Q)9xRUZT&̷k@V= c^\*1X%΂Y$!}1R#&ѷL4{ѵFр27ezZJJMM~ر@TDLΉ@FݴX+ͶMmo|()L 9.s!Fs*0. ^F?_j˝Vmѻ5[03z ?'Rfzyu䀎 dRl) zzD Vdceƍ}DnfyCc4&.u`VG&z6z ߸7,a/󀤀Hx' v/NڷԪ0;H:8:0`L9f5bcاqt}1> H }*L# ~x%nXYm{?N>b|Q{nx+ش<i(-Toex6Gl,eO ri<#btP)h]ߑN3!-eV 1*Okñ Q/KU('@5wǨ:g@q9SIDTBn5vrŪQ FY$B> :':BYcƭsz'ox?D)NjsǛq5uY%GCU%XPuת)i9pA hu6q)("\ ĔAk_hxI@{Ӌܪ,-$|Sh*^=&;ns}XfSL`sb@=pkgN|ck~jrLnDIp]YBF$C{ Nd%|@avA &15 uA4` #"|'2ޔc,5d GTeO>Rޛ#WZfGҚk+/ʁ~Z~LnIw؆~C2fkECrp W˗E~c?ezU]Kx* /#,~f V4JdHݐT4 %WH?R̀lL6w%ːBS\VLwVa$r%}i2fVT͗|=k:'n]N 5I+#Pӗ4xȨ^lH. sX+ aM4a^Z(IEG5]UqcΛ${f62^@J5*]OXۄ ֕.zk1]-}?;(I]GJB!:r򵞠nSp hI1@;8N%XM6 C[q,N|.X{I~ pxSkaUOEiäi@q#Z+]H?]4` @-܈Ƭ!q 2c%aw5dO=ty|9[kvMK5 Syx]OG| X+Z"%(AA$*:^γ-K5^iL'oثPs3U@~m;Wl|˯N&K0mȕpwq].ȽƑ`c i~#|ǞdUX.ciJ*Nrh#0$WA׽†4]o&eҥS6(=$1Zd,fKwC+XA G6Y#Q 3Us8l[ !n0Wp|o*QFE#8WE ņo2MWun#4Z (VeWKǙ?wG?аsVjZ5=wj6IRRꉨUU?: 4`KqVR`ɴuNw1 &K@ [VC_,b.2fgvXo}|&c[L%DՓ}[,%DD nIt63Tiӵ.%d 5O\(L6nh.2Ȉhs߆%`Т4F՜PB$93!^pqܷS}wԂ+_Yx}BB|ɧ06MWtgQ7C5C-6ͰjK4NA7?x{gCY5^M[)_eбѕNGg ~/g'gW9H6T8ؒ#5r׫85,{+O$vm<UC4'n:o[7VFȸHTQh&*u|k">mN&%5>A͖!IukZ30p]B<Wzbfj;.`i3Q/o*O^!/o Mg+P],I+!P+ ĺJ,SFJF(|6.ziq)r4B9GB S{:ZY.۬O8 nPOI8B&Xm{&zrb Wc' GnPmr9WzW>/tgG47X= 骇 8+Ζ cZB Q؟#P|5[ vb nQyrs"L8 XQAxǐy4Pr׫PMYG4bSuĉbp_/ee~#D6FӉJr-($myHT]ljRgf~OmOنn&ēީ>0 ѹN!Nd=~6:qPJvڛ#/U&K :Ϟҟl"leI>@N>2,p7PиOGteP{K}qo$EpA$q`S y+L,rơ0ⅻ}Tn爯 ʝ%&GwCMupǍ'K{e6+&OE<*j>cLPvGfA=4p_Dp]> w9 )3e?#_ _XX<5cHg[E꤈qQQe{ApNP#zۆa=UV tLFvf!nTէGqCU Ơ%ɽk" HNuM:%(mAĬ&՝n.A Kx*e~/*j285Խkqzo`G~=rlQQ=?#C`/ŻƤ5+M61|OnS'93N(5,@ѱT( f>Cߓ؆l{_(a{|RH!Դ5*#;>4OVD%ŻNŅ1ry~kP V:[ p9pLc5rrH¶nҺ$*8@ ?$ !m},jSAtJCAR x,"L5W1)b#;E%̪37CLE!ڤl+)>0`?~bsL!0"_ 1|>}LBEGDo!Wb^4fgn} x<\B7ѭGi]^\[:"5$!nƾ8-u}Ww[@?8k"ҏ֖ebYH?lC&F "@lb1 G) glN% ͵uDv(Bڜޯ1ȹUO 6o>>l07YCWH09Y{F}iJYM_GL϶w L=m\ ,#bQS:a%12gJT]:w9zb(@S<lE_u#bHF=3oZoС"wgg1i+ȗO@bbB%`$DTLΘ :.ȅ~RL}XmXڱu- 9FNW:nHI=̫25Gf<#4_ *-n.TGs|N,k91hKY9GP qrt5A )%,F (D( ̥"D/dFs^lkL񮳲 :H"b-t AZQjM&y2̸m+.I ^ѓ{/udo4ZoxJW?S4pEha"QIۯͮ'jH~zw6ÙztM9>ӊ!E;ߥ7s6œɺNz3?1}r A\Ji:(^C ,_iГlw;R"*wt(THXɑ5zG\lT|mY@܁;y8FǠ:lf `{ bF#o4"#M @%J[Tjh^a;>,@3v RFUS025L}ʱȬh l`ڏ^p5tm8 a%pmau6+$ Ŭ{/wͼl`xe@m  RW%^ƒ;v!1=ܙgLl_M <>ui@ḩ,)-rv~Eu'Qץ(ePgש(2Я% J jy'yZIy?Rfm34 ^pGϜ$ U<:؇&͎‹ g28Zi4+FYAճ@.Wڊ٘ zMg-GQbYq4ڐvɩG+sq7q’TR`fQx29Z8Aȫ΀|tls(xaeYXK-JpA8DA!m,!8*ĢUzYiҘ{;Kw? @S!!9n |Yk$&Gqur_TN{C]tco.T+( Ncf)KRGjy5/h=xY !kI7:6nRnfb#(r]$K>VNTiG/Fz8?4c_!TEB39}`.5fG'iy0H[bgo#p+!Xd\A/XwRN6YJ0|<$QD:fRE9 듵 gI tY63*-r*b,\*7 B.qÕR4,-td_g|n:1-:6[ eVQ+!Ěuj(g'SbmkLD!Դ7ԪSnsz|[L' Xցa(;ډ4jmE!o[pRU *+m|/J{(܁TBe%FK+.x>^{x[vG)/PR)/sL*x-%o vܓ}Ñ?T/FG!97quy⮡hLpXD&3!7"*d~ {8"{ND,gh ڲтtS==ª)6^1vODly<-ԂEը MӤ p{ıDrvdY_G2Rk|~#nQFƆ.+? ͪtHT3D n6E&OYSy?$6!]! z 5/ɦSȹ 쓢,%4e]eV{0cgڍJY/FjUr:B5?_%9)J]a֑CRG 8Y?U{B*N7wf)(~wmLq`??o`Q@o5< ֘CZ$.IQ)nťNzַ}3t=HLEاu|ÓHrbx%/wHT:YͥO8,;H ݡuil_@_גSˍM(u([TSzc^jy`\1yLsɟ4 oo賺1}7IV3Ց"0Js59@n,Cw ֽvyt%p9UڵJȝ Ԍbcl(4y>.BsJ~DbM}%]ڂa`K[Bi.lX~h48 XtNڂdX)O C&ȿK#R\|aPu,l,z]9?WB4͌_nߠ6.E5(!um5D;q+.J ѹNow HϚ'Wf-Ț=]CW-Mdž47 dΣwͨ'_Nc\s*|T.os Li%j+Yr]#J0 @w>aLٳE? |[M_+[cĉ<i%8 ̥GhI/McI|7qWdy?N^OJLY^ζ+7ӲNWe7>>|E‰[P*y6vk&M]x;KP mEC95Á-٭dkaG+]QIK2 Uv# \1^mǒH\uÕ)Ue=7筿I+pn >k':ȊoA>j> ߏp>F #MFа&h_ d_,R8'5;݉Di@EhEJO9iC+"rs+P gwV\B\q_D5-PJH\L;f)`rJWuk!* 5/?w lC͐\T ܉I869)*~bx~˓(Z V$W =o:jllE)O T!] WNs2 0JP&`rX3Ɍ9"qQ]N+ jƾ\8FI2}59 l6޹Y pwO0 zC4##Az~)dw&/Q4\)_/e?Ҕl X$e. /%mH|<'&l1kN>y}$9Y4P}G yK#w3xucyTl>&W&:#JPS_gA^;Œ spCcЇAqTgo4Io5ݒ憛F@3bW.+j=.i--[3l>ҽt7l+< VԴ^{>D; (!zKG Ie_dd1' z"L9CoPW CKimhÐEѭ01{ޕM}p9M)Xg ,c{~TE)֭ Mqh>/^[|XC#;?Ae)ڛ7QRݳ KKU\E/{G_?6Ώ'uymz_{=ٳPGz&?ٵ~ z vD]lZu(8j/ s9#-t^ЪGZN{`*q"g@wB})<9OOa~ ʋVo~- hp|mQJt{.qc@OF'r_b;@ N§jN>;dT5 L.zb.L/AK:QijՠMnr^ЬkZ.¿hp2ҟa灏Հl~yk%vh=@@Zws=vA5Q *-}LԹ}C F'pE\o1o<`m~ >ӞH7 yl8jt ndr?ڑ?s ?S|fzZ܎U[CrodIw2d fM඼L6Sm&'5s"K;Ͳơ]BFn0[yOD 8<-QLZFLШurҧ4 gݥP۽Vvܩ%$#z"揣uY O43-VmM)m3bCښzƙQc B#.Q+3yL>hx{?yZ#Ξ]ddEvn^4_@8_>pO= GVVo')OLvəq~kۍ)Db_M ,P=V)ӐGUԱ{agy$Ë\>ܕX$BHhd^9$ 5^AH)MuBdţƀ& 0s!7&͓Kk"T-ZVFCc;(Y2o(~4G] ϝ"m ~ TJUcцK=%^d'Jx( efz/ż {Wi"UE, E mk vRwT{vy#]nw"+F#Y"ϏIo @iJx+k"!XY&7"G {y{I9'yn=J\Q7{h+p`9z V*6Y,v2@e~i 4̃i{uxȇOaJ)#ZN"K`fųNI+W ֆ &#L_]i!(j A- +Fך/iQ,Z|L\9@ީ,M",!_]*;ٱX8 t`ȊȵrҪծcdLTQ1Lg~h#1u]CGJ1sgPP ijyBZ+K\4N2(J*z-'Q덞f㨞7Qgr#[)@1~XzT Ofep];RQ;0t7O9^0Dtl "1Re`d"jۘ }{)j3feѣ)i|Wr[Ky aƹ=,bS2%9Vq:}"܀82K Ǩ$~,N9ÓSva5U2KI];A"@z}ȅ6dz_)T>|ݩ.Սןgw[Hd>iGB90Po5!#+`i6S HݙLrRWxe݀6.yYm7&Hz|Z! RJ :[ֆLUY9]:u|o@x!8I*wo&WGs'艺I>nH@(O xŔGeEt~Enu/(B r+H:Y4Ds <*;J:8 {ZfY <Y;nɍ2̳9 r/̧^VSSFEon:w3˨咡9#|rTSI Cj9NS3MgG `_sZm#@$ίT@ 2~>ÿz-6wU哸Cݏg zQ0g@dfPPCzow?mu_ PD/ay1AܻVQ\DžSyօҴBI~߮^܆l<­OL}h70{IO2iyc!Ueի jxk\֮+Kj_xdp4x-g<0 5NqH0XJ b_U4I?)ZH-v ZF!sEʟuۗ!1e_PEJv?)aa&_"'<]zOtIrT4 ^=v&-}o+GkܺA ˕UG{f7uONiZ[*d.sTmFkY|Ɂ2ܽHm2WHǺFVφGX*z|bc[=%H( *E5A"nvn"g](2ZUL=Z;P9nV(;s_fSeVWt(ʙ~7X1[w`$类cK(bdn/@Z=ZgGo|f}).$9U`k{i%{k5B2>r" sϰf)he֋21.f,t֣_y wM`䉃/ԭ*BbJ4CDd?eCU?Naya=jGWJ[֯cӄƦ+ hwiB9cUe58?jTn~ q>徹 6g!%&\oal ؛W2F$4"J1e.D pût[2:"4FV"⽷stVKg,^f+ ~S$I.)L- ,Ѓ/Nz]qrW-Pr$%8f!vBaS#XOjs徆iH`oi{YL$X;6I5>Ιdպ㾼9Y/W~i&ȧ<mŰX+\3R:;J6CV̪Ѧ ˈ{eCT 5I\AUFF@ ( C֘hkFFW\OBZ:}4&&Eup<|,7za!2cКjzXY]jK :v2P~q&}UId4SE88=3B!l[T;0KTFg &E8q><7t9t'B?%ŧPC;5c?A2$0 c1y9ČQK9ihGSrI{/E:u 8Q ߌ%&a ${3*VA_f t)߀خd0d/D oV#|v,A&NQ!"}A*s)z_)8FRN8PM' 62px@gme;u9ep_iEbhQlXw?Xv6Fr-/ОߕRo簓r09eܸ-i,2PFv ,VQ)v73͖YY7%5Bןz+ ʾ<M-奾eUFe4 7,~ڦljL[oGEs?θh4I`ўj5xLuYyx0sڥUB"T!w/HXY#m3F<bT^)lqJW$`!uCUsTqnM>ٞMI)][P`IpSRh)ǬŪ|c޷\a8zѵBb柘sJz{p.ECwi$aj*W z!?mX$Aq0`!OZL+èڐfqZ:LM'u^A6+z*̡ gc:a{OiG>8im[pNyÕ/v5q*zr|%U{*89':||FJDåt# h590U>xZsYv|&D/T[%'ߕoc01+\_[ ,$zZQ J>ˠ4 6m;1^M7_"!ZJfHw.:'5qRMd71yw4A1MvaGT)LTON]Pc4.Vz=<9+hh6gJGIG"~BWx 8/ӰA"Q 0U83HO}"< Yԩ/}@aȘF_͗v4q"49T4=ّ9 yA\ͼfţVWM. %+6#,ɇΪ>0zM#$4U!%l} c{SFU;Qo+棸ibqiHOCN$\Fןw9i!+ӓ%U~0r)J/ fo?KXȍ o_'n!LǂJ:,I9hk.4Pev#Q#LM$ب(790 BʡD tnF5x([7~j@z6~6XncN:˦egAra$hJ| @XoL-34) t9+ zd|~ocmk3/냔K5G_o^y_"-b!#ߺ8yֱK0"Pz >S7+Pѓ'~xe먢^w:')%0atqEFz ,C(X.,Ht;42(L4ϓ>c"n2H­z?8eZ1̬JpCA:mD!)@fZ#7M=s?:o;~x͗9~TilQf.敭qws67ʡpqh8r9vOiTIa R] "1ֳn') G+`Fz5/j3q2NH5cC,c$dCȕvw d.())=nHcD@9c‹7}/>w$uW\#קyHNK 1VאPa);`1Jm(ER$(K )3Ǧ £Q*})9lWߟxGX+˞V.YZ"uRY2oPlA&Xo.ˁ MoE9Ŗ[f% {XuʉZƒ&`ha ;wUqֽLsGj>Uq)4kr3MۨԭvK\UM'&K(ZFu:FEmcyޑZB1NԳ;A&""`{{<KEomRx#_c+Jh|XW cL=I¢u'<@c|`ѽʔ_ǝ\aX|Џu$DzxFb{Pm_:O=+lc` Ol ?i钃ohr,& Oa==/l}y{E> +xԪՏ|k2=iϢ)&0DIgR ހ0X5f_2NEڮ:OP_ҫIV!Q&۶Gǥ %)iF~P|@S~tTXϻE/j츫noz˕@ Q`R#\|2N?}ak|yqɦCG DѾye?G`*wA`wɏG{X‡.+CT%7~MBQ$<Zr'@$Qjj' Nfε+up c#O[_*6_HGGa۬UDxRf-;So*Wk 좄f%y9C! LtJٝJ;wbwƹ-5BǾ _%@7 %vqt_g htpKJ;Aw]M;ů2$|^.=E6J7W{SL0tTVRR/㙂fI.3eqR7G-1 Ur0=g/cAXDmt'O *#0 2ƍzhعab49x+؄K){aHz# Q2Y2Z'"+0"^HPYp]B2 kBJ ދRMY)%@D~яpXY<q"\^l{qb'dLjIBP ~v}YUJ?W㝍'@7K"$\ !ØYDžϤjI0v&3Ґ2T+6J}"g"~ YbJE,J%J ūnmi2lMǟ,F_ߺ\_RVa'5sY9J(ǂhfp!3p,&FpƾFF|]oCH[NpW,$+pJ5/ (/-^sMH:$C5}oi_E}:<=uv.аGV\wKlM=zBؿ<¼20Ⱦ|c 1B I H4B-zeUFW%ķK[ޮ4FmJ(Iϙ^ke+2zd~/H #q6o?+ nKD/gt 4M o 9^Ӎ 1"f m|ǎpUZ *‰}l^fۨiqv@W[ag^UL^PEE8$Z.ve-#72'KSaX"L߁}1?K6UOp0Ϝثvi ԃfeS?7?;[Rd;%b11Zd|M eo]V@FmHP_%(gĮ/2n8o)vnF.t-h#"MDHtk[kwpɼ:Pɨ?\֘ ]SWJS~'"F% !nE75oeAT]uge7 ukžEPSjjf,"1R5blFq! -q֣TU D@ayyFR5q8lao^Y[qC&N2;Jۜv[<]bhйU]dQ ^ѝB G|pOއA.,2꽚*N)G>:3{-l5Gވj,k0s]n{<\\XZiT5 kY kbڐX#R<794H=YW+Ms|Nu u{TBv%B"}CP> Bh^Ɽ3Nbo @BY߇FP[ƻ%h4Q ;O,)/ȇrpӽP&B#km/'}H-ɩj|u(k.MyjJ)T?PkQٜSxŮaBMĝp47›hGP7ڍj}ɨm_h^nQ{W~ $!UQK Pnz*ډDg\@@e_֕ #alq +s5-җ46/AZkfL[ ¥I#H{,r[sYK@_'$@ae[~h0왱Ys0`TH;qSTdNǺbs =~M"9_qHL[\PFKkO~F{Rسׅo/'[ $]F1Eyh3rFJtiklICok;V`JoUKL$= hw)`|GFkf߭PV9'W/[[*BA9Ao1(oDdZ8m4p\n* !o#>`4ңem;юH攱ՑZ!H[? Z6Tv| 7LE%qg!_&K,}%Zyb^*Ɉ]A1S4|nXq]PD$2_ }~06Dp[wԒi^qB JϊM/ b[ؙNȧ TnurYܴkjWPz߀GBf.1>ⰳ? N=˾Cڟ:kMDIV_֧ s .kBzv]崐xIiYb0=θh&R!/(M[geSKKf֟KNA6*?F'|ANiiXgm2bKG(uCKs\1iU8iQ/xL C%hE`VMaSG,.y+'IwIQ"kmnq> F '@Y{^K+:[BpUVEȖ$"yx 6rCZ\a 'DlpEHWg^ApOuvΜJ;PeXߙsδ<N_LNZ;k?zr 1Ն6Qzs%[[}&7G䤩A^ș}v087w7.Ol[`<8ޭ]01 P"{͝cfȎ2Mi_#cCrKv3QCƯ 6 q,} 0@^wʟcyc:{~0""ZLէQ.]{&ellI]} 0&pٸؿ C--4CXiJ & *\7/xƋ_}c2?(21m?至=QL;O\Q%@F&|:*niߣbrӺnV#l!q~\HkYN;ttx'0ضUR56N::m (ܖ-4+\ﬠ:ĺf)r33sw`X3nb4o" 0lF O o'sD2{^i6ۮLzs჻)2 |YaY)9U@I1{͜{Fz|xp{h(_DTfN "BĩoޟPMk9tRёN"pzsPCG]J/R3q]|s2O[K6*SO{B)X:`yN{S œ"aƨot(pp#Å̬DH>r'&•qցy Zx{ghL0a)' קs]lc:<sm̃\Ȱ8wd2s+L3%[mT^ZIzԃ?-:GZ R j|xDE\kMOr-,SzP1%Dc<^A`t&ޖ+fpm9J8EL.=Pv_Gdȑe˹ ;5F9]f 3PэC"mn~ ~N^ cl9I٩35PPvϰ=DgLYatIAq,ԉ9cgw "QZ0k6h؉x([,ssE*ņ4#4ka=u{MXH$z3aYJ+;*^/uf?8S&R p>O/@A2H#:& ȲCvMƘ$H v/^Y!כVU3KJV&=aֿFr '2]J'EPQut "n}δW,y|NmLi7^6@37G4{s=3jH,"ɐ3;O> &{a9}ez2ZȕJe94 r$rjQLM=F+T] Z(,ޯi1;}ҝxEgH|U8U0X؈]̀ko\+Nhslϐhfo˥~ ܧ3H,PrA_-?kʈaUnor_g2,Hr\O YXВfCw(Qv&+S/v _U-NTZnG "eJC֦/΢PP;ՙʶƷ6Sʎce?f>lwMymvnD_ Nn7{1 T$Zp AXE E[YO>)AЫ"2 !xYJzowq.:\o_H4e&Pa / 2J!i9ͼu>ggEH 'F*LbZڲ|E[2k HK_YH7`iJ/xi Ue#Ŏb>Jc5 e?4>>]Bd)gCu&HŪZ"ͮUy_]x~؉OkZc?l끝EnoR_lϴ0 V\[ ۹\~֥v)'!; ް4gwq%y$Z'rGXBNc8/R'2`6*; R,Tn=lk21U!>Fm GdqX藹!M̥*rˑ3o:Rj+#_rR.F}kͥ}1V~1Rݾk ,d"[~A1KΝ#,Js?@j<ф]/*вj?oĭŸ2ldcFAg =H9Q!)Oøųxgpz5VϤґ:(wRCDQP ]Z:/%ԗM;^E8'Q]7/YEr.E\):V5(m m#r%aw7a{% &-ȌНPQ6b^?Iy5O-BzHTi\6T%08ٽ./1FY l܀*\_H \Q>=& jWq;n{B,'X1yӛx06Y&Ρz ]H~^l/O Y.'#^z 硡IrlK[6ߎrXt+pHR߱,mb@3"YwxL- 5*,&aIX`,_r/Ȧ#qO+&"B\n9gnc-YLDY+պ(wOKÍ( Y`#^>*LޓhiR⥋VO]m嗬nt /6C2;S<* `er-mǗm~)(ZQ՘:COfxfnT̀tH3w eavH!шYRP02%F~˵7{-83nLЀ ܉9U2;IP1X}`"hZ\3$" M~"(h:,O/߲rHMqm^PO?;  k[%aX<cݭ.KC\#w.]Nm 0dar|D6Dedn]޿,Ƹ<8M>MH,{DVף& _lj nJv'tO/qv)CU`޼X[(2F׬ djx*+ 1;_{l^j2t2 S.o_ZfHlʆѹ ճ]p]PKK8YGGA?ezѠU0\z^-l0Br.\Uu)2un- :"A~&0wUjک4e@c2& ]{o\Zu#KfUX7!1Oɍ'>1VfKAO@6ҰkۥT%ݓ$)8"gVx,B^[XR#o)4=V89"ƄD׆VAk0a=^ѬԘnG\*)g 0jbtOȔV؞~OM4 :{:OW$5Z+no 4tG.q25*5ɨ PP\U%W7qHݶiL*`. B`wW[2D!Ԩ2hªK PߴQWR\Lw/eEŷ^e{h9_L:h\lZ9S@ӋnO(4j muKpv%~ѦQrL ŧ&CnW  | {&Hu~Q)A)wKp L 1,\]|94=J/0gZsVJ@b ;U/|MHřrT^F| <[,ĹP͈`%Tegi ^aki|.۹"yA{УE&>a=Zkg[?~ ":bEl[qdHE@8S,(bK\wL)\Gq]QOGt7^P=MɾHFbK,1TV=ʡIu/vhx\9fd47 <,d:oZ䉰 21tˤ~BcWߥW/b/౸VX1AOm(Лm%UH=g-(*T(z O M)i" z ' WnRa&ѣ,`.\EZva[~-key ի9׬eG?KR;KmV;V<⁖!Wb CdAdc盻c;Ho9pD*4?)?N9؁dA-)ߨ`Xrmʥ?G$3;o`* Pdx p:3Dnnu=mVS͉YxgSQ(sMڼ$/ IJ *(ԜqϢLiVccATGKQ~CGGNv4CI^(mH~t)rۖr}!2V@kosxӯ`̪m/,FMv2b Cy°] +~l8Ze;_ȉNM, wZHVD4z0W&"L _.E&{$MeߍpB-ThMW< Bt0p(8P&ᶷOO]"C(AS H@|䕉ohh>F)$e]Kwı )lzϮB֢Za)kݿ> ?QF9Za[so73VK5rqhX=?C-:@+i8Q+Ey9F[ŵ!zŲ~ 318<.JiyOr3AOy,H758@?^V2_R:ҸܵLjg4r\O7FIHlM0]H0ke4Y͖hfc2iߙ)dL{|Y渂ښcF50֡v]JqoP#؋%I\Gpsz=ȉ"Ol;AiN^3GDFv R`Ʉ7-MG#,*rQ4 8Md+ZO޾;usEΤd.vx1϶ldJ!ڋ@h(Rz~T H<*g2 O \GuVGk=wcZv+O_3DCȻ}{:80%knYZI& x(sagb% %vH&nhwT-j/1*RóxgY?58X߫l ?Dʑ5U0E<₈W^`$xQ&B3W0 D gQs,ʯU -+ty@sp7em7Q+CC^ٝtP"&t zS:8N78IB̌,N⊺dͰS F 8)'HJ¬7bZ|5Y="ŘD6?(~8e66Zg"nuoT0 ,ZT q;9GYہ?h;ԧ Bе3ݤvӷn ~G VDiFT:WJYUSmpt܂1iy UX 4f?vA oi~!ک̿ZcOxk*y%1D^~*b4խ^_^29ktϳENשzXe5N ^+锵I9)W#1 K>/"Sx,P,OHv?SvB64j9-J.bP wS^Z:BP']?h 1͕H2y!P0-,=Ӑcf>_?P)]5 E0*ګOHY!^g Me"i/HPwЃwdʏv/ ڦe/djl7׈iA/f( f g  <FL...^*RYT_Oy:գmTޘ\/TӃ@W 1b9"DIćR66u)X;oE=EMyYsf筻 ї8_L 1At>V;SFFWņNjʰކ:($mz]/²q,r#I4‚O2oCìfZn蒗M4e'Zs~K ܆}s]/&x.{u+fP-)"D=_ItA`e #׼fD8iq,l3] 4:hɇ,)j蜯mQ1 S>;B:-6A һ@Lk(zBU-,\XK^fU|a:0)OL?ѓCټv9Eq5]w`y+Mg$vD{ۯr rln g%Ձ>k1B\g&\輒EEL9 y:#S21Dq]D {gZEE"Z8$qRajt?b}S#-"$|.$ȒI͉,isSf9: ,y=gl`8ih+7Rhw,]jZ1"W% .a!1֞Ztnf]}h[I˱5i*5r;zu2CRX.zK`mfCQbpƮ)hmOJvfn0ޝd D.q'$Hx)}"ژY.-ӽi;M~%\Ƒ F⭔xP>)$w3!gdg={|³:8-U g lS䶀{-|f5Je6DV/Yu5gN`W,ow*k꿠͜h0Hcm5u\196j@w^b5< YT\Sӛn%hN c iJu,*zT/wՒc0DRz* oN%(S8_匀MW୬F 6<#㘕ìrqsŃWy!%C<!Ң#78NTTiGu۰[A)EqB ;GSBHr AG=~\zi"#2ê@~WwEƌ%E?J|d9J '´PC2 .8ö J&Œuj sTt~ ťQh9S;vs̱xH_eE D1P\F(eaVw*xD|1n+ ߑ YbJ9]) #\#k9 4$eؠBϭ*vg4{Od f#ڻ-vՋBM_Կ-,Mה``eﲠU{Ŋ1[3;*jfQ9L*-[$E;.~i묯k5ը2_%1m)IҭG-j;M|gzϕCp$l$9@Jd_rǯk.A%X:kL-@ `[ 2w'`7$'_OxЧ o6q?|-f ڊ !{#H,VW?`Mo%7/_SQV'#qu]>psrpǜX}u]̀-xW5 5[!#<Vl+焊%0~ W=F x Xx']M@ܧodMFPkA"~0]Ou4-2+fC?@d\=q1ZcȜˢ#>ٮU_4&72|!-C|DJX'NP68tGg/˚>g4a|nk8Y ;}@-*As3`f^ZTMP!GO `*gF'GcR?*Ӂ#``y<0E;ypN}/qczD Ԝ­xK@N钷shcY>F\}l<# T&VKsl"OT;lN7L)IW%r{)p|H Q3In?]' Ae~jFgX uJ)Q'$+א|1ht&zi9''o/@$)lmMAT;]Is oL؆2k_< FMv,aÄSY/SA٤R}3 0^uq҆88}1& Ç2E<g^k&mל e'%!xXRlrIna 83C=~ ޚ&fצ+րjdr6pDUڧBȾ<(:yK^J]a״g9|4 mx dXfxØEwŕ;U?ZG!6,#,S~5fv;ua}Aƞ0g by|||%.o(?H!D [eDa9'u؂}'Eౚ{.Ӗr^TqX~Z 61xx'J(ƕ+" opTymrt]:F嫡M9,?m9e}s1|7mF9_]e]^H*\{Á?@z De.R꽫C8[Ӑ M||.u>fa?l~h*" A>"O s_ӴV3B'=H8cT467-&GCᕥۏH P&Z}XlMc(s,W͓PX^\SiC,rO]?.jfDOFJykPUbiKq̇@YB1B~fAxxh!.$ZޔSYN.* fp:*"@FRU*Yox FvNT&vlϠbP4dKM73aR4TOqlqNHԉ:=1xQ `&gÄ:KvEW4$1*yZ9^7J:qa I)~9E-(n(о(ᏺhiFLE?KbXB},9痧z?&kqEW }ݑwG1)\?O?7!2|!8art $դ׮j`b,zC&A <ў 뱩Dp`K8.> f7]I2Hܷ'q"[51e'S9T6K&3YJQt Leܷzsа c˪uv7Z)۞G; l!XOM ęZ;^Hjj|A Am1($ #x̎1uxFC4exr ]8 (TEJGh?3T.ܕ]QC~!ΐ_X!B6CH*Jh&#h:L;f #'>SRLLIP[ ,Xۯ?&9'4.?j/v"&Y¯TT|pr>|vA=bjaOh4Nv*-:́H ~8يSڧ?a=j:|M./LU{34YNqz&\Bs`NUR>n2i(ǖf,KAO?I`Mȋw\iC0F oցÚerOC*EaeoE/F5=x*pX>g"8] 2wO;A8 =稱2F|JhfY-fv`[}R ;US!䝓AvU//Rٕ3$W#/F$cJ-r.k+m9htČ?Q?7u8h"˶P'鬒MZ9 2kR' xҨo3>IŦ?b g|F_VV ʝi.ɲ?4-=-hT&89 0)f .lG75wFkyq/J[/Ɓ~_ʪ>o-}Xo;խ~HT(ZiZGu@ qO[&zcӵ=>PC| NTe1C-eM䎺GYŲʸO+?`ð4l6飣 =Jv;Pn$A!JYN)Vͮa 8R(Q1An| 7:7 + X9NjjhXLC H4` pǩ>N]Ā<"%Ƨ boNevAP^JUVwk2ȁC 6~ãR>},tL[yeemQ ]C % W &mnG|@;A`DApn'8̎-.S(Jm aUj䚒a u1%R?û6ynaUdgK@'ս'x{q*fr #ټSd-wg&rXЎH*/vQ#êmO[oxKij\džn ?DCAr̬0`>(, UCŒ  x0U9lY|5\f M{nW76϶VPˣF?rgzgIl"z@%x3?NΡÓV^v}?3!eYv~Zé,0V}.R(lН?ptgo:G3,(P:r>_" Nٳ}9[09HpHMDMdX_d455zrF]$;gC[{c n ;k;'=n;1cY)MƁC(I ~/5U}՜,)T3*gYݓ:ļv=ټFc*TTLB HUfB[,_QO-@)2h(Ҕg)j 0UQ(d쐀 /7\A߿bCw:A (sغSFtd)+/msJY_^1=6ƶ0  |J Z ``a^'} G1hYϴ| Ձ+X3GF8xZPzט' d;BA; !*2p*%}czοŰB1ns#ŐąmVy'BخN?Jp2c _žB0 3blRߘ-:B {;qk"u&{I8Ry’!~ؕ,'LFsbID i[EI5I.;KᢂS(o7x˚($R٪>vfIFԡԞG /Q WܢF&Eqp0.ur4z^Ax bDi KQ~H`Ux2V:`\s=J\`~ l.|r) _xs O:1bHѱ^YF Ѕ]޺W}[zG@aYIYL^PR#ojE'cw:u ]`eEpJb5 悛|M_N&HLiJ3H=3S&>T:+1 WMw iiL币ݚưΞ<H!'&t/t@4$dV'CE-Qghyg/' vHS$]u[^#!t&}tX{Y:Hdxߕ+K>l p0t9+2c^h6P xG^sU9urxyy q;C65K8wwL!l gwUg uY?R3ῡ/'xOC2h˹z?waد~WGT='+gr /I@.pg!l+3є)@h/@ٔ0&C+Pa|VȻ.wK2wN?PG =;0găR050CAT21V ;6x7ǍNR&@ &|T9<+f6'Eyu;G檓 ;7@}C&mzClܠ ?I鴃"rgYN謳vt3柧hc(=nXmN-Y>+5af!8'RUjőicdSmSt;CۜbMTi!\ ĹˬLlcމx+iZ>)5{^q,7iuɳ^WSqYP4zYI$Ψùd_[jLWD24|\1^vI$OreH{Wxnd_G?;8g> e]IAc# [;kQ5n+ ^R~AփB hVmL 򖶾7>1A_oKmd# ?"ŲX˒~j+8@\ԯ[9(x2.Ʀ|UD\L<@q>Q6XF޶54%oHPzSX6AzKP'N`FmAõ{~$!gN*. GC2߄>ꓺ (FL U߫;e^點G` ĺݚW%g/$Վz {I&M=p"VqpRZ+MɎ(=3JgLsXl=ߕ .Pr_cn]^++<]}7iz휝nA"N\!L 뇂|3ʣ ;݆@Y\=[oQae^)^-\SLlwgـ5? _H[/HljA߮jUNZ:)y]~:+"iK+Fð*tI0`$Ey;I=Ag }qqxnOVeA#AmIK"E>SOeg4`$;2W$wӢo ʂ٪+۸jk]BQoShU{_ *5tbj[!ށqYi(X/Ivmņ͇b)eN=nI۫&$D-D*J$aR D. tiEcЏ"0Ď|F\#yFi\'`Q3ѕ\J=gED_d7O290v}Ӓ]uUs_Tzw{wޕ(6, ճ`ϥhKl;`(GGypۭCNAprі\]Rk 9nX/-}ܸfdP(Dd&GsKƠOPWW$WҭCP~}dT & Ǯ XmnJggI ̜CBHO @UDf8=OXaQDryxæKsQsrqjkWnDZ57VO徟]J&Bmc+2ߋW^=0*!-C4Ǯ>X^bV0j LPs[8t֒c ܒ;`ee[\r<U:K|NU-]~—[2ўVVj:L6Nrkt  [=K^:--I6m߸:oLcK uD~}+>^ﻒaϵSaV6Ll{9r sdDC !yLO&WJfD鏣YdAnm PɟQ|F,w;aL:g~U@ۙOa oqF(͍mNo^!9i8I0hr6臝M/n"u=+"rķU#6 DcJ>6H>" d1 | oi~_,z^Hp %hgU] X_+*m$.)r=qu,Zq_M3]6>s]yS8t|z簗K穔^(61.^B"ɹL]nY]$=USo$Fva>z?DܣӉCTÙ%{<3"h#/ WAySguA8 nM/%l^dc+IRY-6t׭?f䷫u a2 _^aEX&#}f2F>9_oBא*yީm*TqUާJ\;Յ$,# crMNqݕҿO$µ Ul˶;nɂlZ^BV.C-hS 6M yE;Zd0C.υ%DU"O zZg*#)h|-Wg~K* ƊV#^4 \MZ&lZ#,Š+ A:t@̑ ! M E M+IlM.B]3@.L/| pos}g6i;N?h*hZ6[}\">dP$7ڳ}\+#C].5/VwJsX3Qcqe1' d:~qf%:>= ^K>QiAiߵG& >XiQNlùT @^E&C}1^i{X4TNOeg%[gD-Ĝ^Bvc h |+!䟳i>b<%hLĉ;Z"}aS4E`"|[hg ;q-zM bI.bd$\H< AG? 2y. ': (}i=$=_×{*eĴOM#-~n׀#;x2ocE:DPY~fiХ++/ Nbr&bϸ4vIH|z1Z(c``?F^AUh73) qȈ dL(auВ'B[AE$xҬݱ+WèbP0| \@'IF,ֵjc,=!#etV"qd6!U?,^j{skn,_QMmE_/yPvTybi UEӖkGr#Cj]CM)sQ׀WgqbݦP~bgl qIIQ#\葉nh;mf9C٣Ef*:n4ܽaT~?hE>FXGT]#pqi,ڑP>'rJwiQNWsjykIJ /}~KO ffSL2{էtJ0U>*`Sz9Y/??e CH3UZs[O& ', ΢ -9`D) d_p7k/Bv[\Ft٘ tuiX˯9uxYR ɮ*sq>ʋt~)z⏔q$)QBzLb%+YI17fܝ5]O_NP/ Ո>[$ d?D=r>oӽAN(iB{w xvh'l5mR`?rAEUCJДyy$gSp6O}8ʸ DV,H F u.p9%<`w D]p ߨi7와+eF{)c{;ǴGQdLfaXab+<SN l6}75kg`Hoݘr*f6<RV hvDhQ(8U%BJ@zl¼B* Q?ls?*Z9Zn匈M" ZEZ (F5^qNzO%j V6w2Ul_Gzp%K[||;g*G}#l'lþ0<ڱRVU7^ShQ!M)㊝vuIW'H 2JA.jϿ&v fWx>D-Q"66`Pcmk ܵrj2#8kG%`@y|-ȺhrkחW}zہgKL "'mI9K5;SSŌ1 A=AQ$*XuڨFkV[H3\S@0e0)56=0y1c/J8L!|.gx8fʾ ./4{baAs`eKm/pϗƍx/aL`l(|[5ɠyxw3MM|'-0P巇UTqRLE?޽D$4:Myo WPobOZW].#2+p#)fɣ&`>M;,uNJXd`g7r[Wn"i6f o/OYiAQQq<{ uHZrL#'l#d~=gaz#R!- xs)l Ɗ [7Dcyx]z,Q:_0sY=,ܔGFtQ_YOR.z5s [_=V;#,N-]\hOԳ tNVݐ[ܗ<7ޅU&Ќ)'אqO 톈m~x]$nI3h-~V]9 /uh)$ih\0 6y^.ff}ђB ap\!^2 u>mvzuFVq)bl|fk2-ZJN m’]x35&}Rzb3Cmq/0MB;[OSyb">\#qշ T*xB׊"#I_Rlhuloe>v!ݳG mjAL?q=̊hkQ>P095:& qtbXlVDXJ9~81k3>(u X1Fj|ōKP7^}K,Dx#5 Y? h;,ky,{:J= u˰E)׌jw72JG%R4 1Tz^#v[c}17^),uͷ0|y=z;Q7! N.j#H//m7De'_;qM| ){pL6KF-&؉v𾚆a6TPi޵5.F~Es u]_(f,ӌ eWv"l fQ:]#jujO$rvM|p6̲Y\W= 4ؾ`LS@bkraZDEE}B_#?MMvD.0Q(TN?h,E)$ c b6 OyrKVG-:[ iTWu}:ҵ5($O5 KKtb:Z)ԙA2nxL9*pKs*Ųմmo=q$Wu+TLѯ N05H_r 2[Ԇ]X!ecy ^ -ZM#bZHھF09k1gnjci6_G0߃ZV @1*L=O=mUfnaIQy";?MeR O+"9P"Ġ>:F/v0S(xS mŃ`4Ue0(c'<d!kFS)JZ|t#ԼZ%3zT݁oaB9bZH4"3X\en1lCx#+j6cWhsҀ:Ui۬Q=hZ)9A>HED>0b'UT go߻\OHN?ʵ62rPK_;jy.=xQ>O@AU7[Q65JyN5Dt8|ꬸq\U uUZ}"x~C^Uwtq/ly(FUǺorD< $0e--DӟL׺vg5 :.vzrҲ*,tao-淉җ! uB7%0!nA‰X_,9|CsnijZIstεrJjLϖ3͆f&E6`G.Uae%9l3`VAJ0E!<\m ъ-e3 i^mgq+kH ][,]@*6(&H4 {{cXEڜB:equόnڇ S?k8nLL-Ы{*4b~n;B4:rTÛP1aß@~;@!+_o@|:ǝ"vWt&c+:h. b^Ŀfsz .d! س4"?NzuW"STxR 2 [џC r͌n[= U6.:i{(=Cŏ`:$B ۺ` Ino禾_@6bGGI~k ԴCS_uJzאhS2W'~2R2T=e=C$HQ<~mAl݋Uۯ60dOGVm0%q2hY{5b&.ؤYuoؚBT}5fmS_NJ܊-a-]QTv9p O׾^ IezȀ*&ض!SH!{{1hr_OTTp[]j<,OvE6)D}/A,6 yBP1^v4m{8pu='S vͣ+裙ԲB{\eYSW}Bmn`cair,xd/8tESV^]Vg @iÿ҅Fgg7~%Slzx;Ǒ|8L&eM2IM9C?\28ev"eҕTbۡy:ef~},awe#UMt^zAnvQ[A0CWH:@Ӷ3SAx|uF:Y%]m>=c`7S~<_2-i e0n$a#{H[ DBZwz 3X=+<1 _ qiSȖOiO-&{͉ 5%`Ӝy]e@/"ߓ3P| K)i2_mS0>'kXe6'TQqR<NleQ&s.ZB~~g@Kckp5%]⾌C^!ii#7w0Ҝ0L!;R!)!p-fђ5R}n~iZd"8 1}'nެhbpp5Ue'( C\ #a(؈9@ &+ߖ3U SeDLzExq$51DoP_S탱%6]L<̷14_άhZ5{ۧ#i,ּމ[ٔyd?=-{Pm42HAGM²n`¤J{`[?J<6"b}ȴlA@ Wz"D-r4a;/{=.X#GJ]+V}z K֫.$b@-ԧ@ G'8a'=r fvIƲE+d 7qS Sg4 -f3T-Ѧ쮒l䊺0xRSZsOǝ vH6 jeT:ośDL,'6ٓ)pv:~rlx6}>2zj4׻kx"$W b˒/Uk;nr"vλir0y՟Ns%g<3f|(0*G/6.6Uj ]lv*!GR- :CGpt&%x\^/::7=jPNڶ\Ek$A7AMg -VsU=6H# tPݸ^a<h8Y2g+WRa .SV _j{+HUڿO?|C-Y3`+C %MZ*E**yfDBd|RU4F Xd9DY\)]@ B_E{ID,_oТXls[9a|Iv%ͅwF$":KOb[a5d)^ ;0=D7<i||1a iz>q#\*̈́E T)@R=ñ4s- YüMpR7(ɲtQo'm:\ 쳏vH_9y)bog˻Tu1 }J$#ք[-,Sa"qk%A.2z姟Q05y&s5#*~9yw~,˫25+'iΟM&0Mt_JOC`%ͮAPA^W]G`&E]ICd;XؗL#&n aM/Vk-BVRhR|n(_piLc|\Rv¸,%Nb?.郎 L2.dF8L'dQJU蓲Y51ioߔmҗ-ΥV\|$J%4aJo J\f]sqXiK?@^|U):Ngϝ4H~#Kru#EOb9 'EWnA+zT(iKYc1{%XHp cG[ na)Uv 7מP(83\P8[f8^Uw;lSf1fa"& :g+h;Al8W:"} IʛYܫ" 8#-q 0o`^BGoLnoRڞ/ґNʳIW~簐cȘ4:7{#۴X[ư.5ay4,#\N]&pzqs`L%! hTYY9Mm0ٟ Y$P9 &bkHL!yݔפdvT1ct0L!H4*k׋U>o^<۞1 O@[Fż݊0KĹ,L&(谶^ U08k S.60dG<0954_0W~Mxn }8t "{!Zb.{iܹ.I$c2r+ܝ c :HODI$77.OqV(uyF+J"\3WrqsV㍮ nOPPi[iUOȨKxnXlW*!,J ç^y+^ԋB;_~\N{7-Y`AnmNjf14ɸUtoH}IEj-#O-5+q΂hI[g5Q+,LĎ㞉g 8k@ 5iNyMRҒߑlW*sFO#z !; 'j*̀9TS&Θ5{Ą3wӅfo,a7 BVO Z&s>`` FCɚ ~PFXܼ=mgvݷnW3Xsbk{7g@{f_2p?*i߈AhNCޞѣNLGy҃nѝu6̀PbdAv ~]nN~ ݲʔQu) ZߟF:XqFT)b ]K xzpYWG,!6.+)3'EƑ~\i$n;Go@[IxР5B-KLPEu-O+̿m6 L/W+]WeO}&u7=sK,h6q\G)ҲJ1IM.eyE!PGO'B$fB?0g? rn*AkMnKYe6*ݷL;gWr 8^'QUz ,p`>/R9_];43mzh]wfOo‚@)|*:Y?75 7ąb`&@(w2z٪_Wck,_=NA2rhu6;`n)P+Ճ9Ql5NlNb.3 v\ĵ'+0g"x R7sæ$Y 7F׮~(.A\TCF"gt`i~_oI|7˜~Na HUw2ԀUwKc ;~q;T>U#>ӴO'v@vSee=}唓 0⼳w}b`iyT F5׏/XH{Lj>[/ں#6Y% Wv(D $;ީQrk4!"׾'#*ωC^LؘNz6}?P[?Y]zC?*q="|;^a2{s5<h-#U(1HZpj YAul=]Ъwΐ`{7Y!p` DtcnGvOAxUIe}`VO.JLI!שQSv8~,n+zL[U}t?ê613ݗTǯ OAo:4˜q*] U c>Wr26me1`Súlt=6t'Nofc}EF6}=kt"u׆.ƅ.Z A>,0A^ d\;iAϹ,vFnM0T p'X.1*ZU pd(<Ԩb]`C :I?6\ 2}rQ)CXT#= FwI=A~8L4Iܔ8lyM?z7Q9ÂڀH ȉ@nrm/`X鉫r ,[U`,Ӱaӳ4*man2Eזc+ *ϑnzQe"% 'C6/Ug zqЙށF2d<86., :AwyeH[4MɒG$ϳK<[}MA۔bKf2 qf Y#Ѯ; ag42[]Wռ;$Pҁf}Sk'D2|r!W ʒ۳5Et_FƲdy[c_Ք=W֐ua32p_e)@:rȢ"y"iu 5.W%!۷ⲊC96s wG|,W> Btş\f Pun]/&#ݲ.˚>„49U"OAHBFnvLF/@Flj\n}o x\'P*2>a`Xb&0#ݹ& sxeF5Re^A1 fEb݁&,4:`?, G55i+Ojm LMI{Ab44}YkgnoeO a9Tian|6eX8 R;K"FЈY|`u)8KH\83Re, XM)?`xu&7m2Uxk̈́ `+ x8_$8@˗Y-Lv$Tj6K40,Nc9; P\ۏ"#_-OI6/CwӒ+lZR [r/;ju4"i^N@hPhjZa$,"DMr Ie8IaE~ڣ8RXP{=gt'Pz$r$u4(x ԟxt@ 퀷 خWVD;LtXƟW0l~.oxTb9iӳ*D+ ^6+1mS 96s(#q3뮎; -G6cݝpE\EqM;Tsm_#`ņ ;%7d<%Qm 'țe=a{aY‘"eka-"88B=]bjE 2!+\+k-]jwn޼uqCgfSݷQ/3]ow߳#UմLΫ -@n; >_ sܰ|%C)~M~d*nBR.qtIS t>zv,g( ր7r(f:0HH/9N*e#\j+~~h~?+>,5ΫDz ~1F=!+/pk^P_V Ry#x!vj4ޟcq#tMWEd̐e<ɯn;-5Ľ̲s@9Eȏ҅`Yt \ lTyT[=Z)B^]2RzyEŀ{G)Ā/̟ AJp~r-*>.1KhlAJ^cvyt,xy,,- GudsÌa?!2xBR>W&Q<ć ׭Sm0occ"Y!]&40vcU*a؀DF'C6F'_MY_]+Xg3&xE@&N e#Z5b+zR6F,]8Iʬe=>JoGLޣܦ:B1I_Kdg͗Mǘbkߗ"q*)"[\Eط>s-qK ]I6brVtsGi7:I m8k ;v)#\ dM Grvz h59Sa_"h7~l5 .-> ʸϡ|7Re ,Bͦ&n{쌾ρlo6.q\hsb%M[82r2Vp%eИZP-0*0݋()QI"x\/-mq7d[ȆObqq57ؕv)sFx){Z36=P/D{kD*%,Lv[@N.'J.=EDY rTE $Z=^@F8렶 0K vM3}j?8Zn2Ҋs6n}0O_1[zi#"ѳ/E岪ޯWثk=mU@ y.v*@Ion߭妙-^fKc bV64|Dda:aViOy1p scx\)U27J]b8'gӊJOeb-(%z[Q#l=My.f%V,QzOʏ~jXcɂ'b Cfmet)//yn+4JEG@4y \TWcd·Hjj4͒%-3sRli}ذ]oJ)Xh1S!PMzbFW1*;B{4N@J~'e Uh e)B-+)QvF|h@Oa=BcXNLꅿr㱘kMAmۋAvwod_" V@2֛~H9̓η_91*w@Sj`IH1 ||Ω/!|_"]<_1o(xXc2 dI<?[ F̉^3>Y.ެο~ xXXmkٔ\ocƞ׎#gks )NzZp.ux?VS,9y06q_qͩ%~lڍ0-Kh=ۘ1ltdqR/ͮ)YC6yN}p>'p7QRhd's{G gJc,vG쵓s7|b I}(eixK=f8F1|,~QDY(<,pM+ m@Urw`8|Od=764^)rJC|7qb#HENHiR IƆs@ (jU_# Dj wIri39)P@ZPa\_3D* O\e袱AbD9;6{YAqrn&Cs>E{5hi?"~S&$ Dn~x\o'`=YSPLRql4F ,b`D-@35*ؙS ERs BWQ;Vͩ]oJNm8R]vXxdE 9҉wj@$@Ͻ:`, MXlgT,hqa1U'M.)+riDzݯ;'j$+4+x-Y4Z:Ң@<_<`ۭؗ-,]0yLJD(iGt'SCaARVrre]\β+qtoG7.ҁK"Tѓ-Q`mE)rL$~lMfCyZ㏱/,bo-+0+KYJtLg?]㫟Y@40_9wFO;S߹M.h^zq+pҠˠ$K~yDsT>;#s NH< T쫦ZЄhL!9~00\3\uЧ# zF, 7 ^p-r/k`@=,>ʦE{̵.7G1؊ۃqiid,K̀d/?p7*oRicOHTvBT>Ztp4 } -q5l"908T 5Hlt c0kD&B7a/[Ŭ#Tn(V2efyqu\׊.8Ub3Kz`pV5G ժ=D~֍hB}1)-cZݔvD.\KVWn )U,o o}]CPM6s<%:&D`>5AG:7%MUǁ =97-mWz\g*f FpхF !z%$kq+QI?aj^=D69Wn P(v& oC fYOMoUc_1 QndpHG԰#Rw)Pme]V'κX{=c"Dc8zLoL,dN+p'])*hEBvu=]~31TYנJ _5"Pg#z2t d:7 EBk.xJmBȓݔ0Eo,iَ 'tJμds7Vmy%5^OLY%`-%\{@ɞ )z>tFۺ& D,,{ agMg3.KZ!IH+ W-_W\.ll)(P?0rU>:ñJ 7 8<5Ѥ͂ M&m> +Y8M(j7PdLk>>,QK:qb"uIa7iC$~m!EN>q,6A2ѩ 4*+Xl`"\F(û`6p webz` V7 {g" V.S^V斋JhyVXtSq 1$NAHHA^>mcgZr{| CsPr6 *l57Q!`d*;O|%R?}|h3uVS,зdGܘrO(l>6(OcjG|c}OK "Wm7!Q;)jͧ0g'_`Se!WXioy'y'M­7%q<ڻU!n@SW]rk딱ֽ (Ab_RRpq.;͍eLR/k/s8?aN}ݷpj * j:³>0k>-P3p^m(] @2 vzk8(I㫬yCۍ-uߌ.3F<^8WhS4RG8lVUsh*JŅ>;j~j q}@̸ȱU\T`#T$~szz|x.7NJyA1蓾暎5k'-lK\ w휭}.~]SXu@-X <81 .6l9eiO]P%1isH~aW0f bR,\ǒ3&}烼aYIҏdH{ T0O,-.߇&;yO_#r=[3(O"#;l> \ax8\Awo}Pw-Ц1gLlzyRX_1=!weᬭ\OI'U4d~:ih2iUXFIA b]MOYY`C+Q}k7){p)kpLs4eN 22}Fl2i$mqvx/a B%!+=!FKש]pݴY5_G1bh Q@hz-i$[ޱG݌=/Ϣ0YxD/?;>?ЏwpP idJUUaa!X 4섮B1,F F)]YU7QQNR)>s?' $ Q:x%"gv6H}?)\Wx7ljtf֎z, 'G[h1Rcfg?.YI^NYϝ}yq"B`7;{mJyI6Zbڰg-F:b\Kİ2NzhKxc0ԫNʤv1N X:%ԙHObrڨVlC\JVROxIdiz3JumLhp^n@%n#e j-እTBZ9xr?^IC{,T‰HvGZ0Q^>iLYCqi31dz~XҝfWè0s/vxHd衣J#c)%g)]cׄJY !L^ȗk1FI;JP5'T$yAQXᐾvrzM~b/$FE:WfsܽjJ"FYy;%+1T. CKPY{xD1`G?-B}g$`1n=YAV;F~CغUl.3RT {bψnh ⺃m)߶(>茑 v]S> ˉDŻBeO>mzI|;7cq_Pm Jvk[4-g_; ~>{P,eiA|a?I?O\H$ȵLuRԪOxsNTdpQR6/X~ 4ν4@3G@NA 8s}-s,*_0jeA+viQc8:(6]yE.dmg5=nkۇv7u$@SJHd5W"`aH祚Gu xy*O.FСm uNB_փTǶ>&ϑUN`= Lv3mIS|/ aFD&㈂!n붹FBtiV!O d0 ԍ®lh_z'r$jms<7pi2Ӵ}Byt#-}:C MҬFSuMEyVJe,"BH7Hiޥ'yZx"$QMQɋ+A5%l!98c T~xkN<r`m $D9VT٥Iej֪A!^}ߚʼn0%$Z9ڗ1j7$Wcb2P6_(IYv0"3̟U :_J8egk''D- y4m_x[BE0٠D],PnΐWEC|IwVN'#aTdW?qЬ"$Ms*}$3-^oxәNޱQ+n ^~enϊ֪TJ,x`oC{fj7PHW’NLPqYNPYsӢ{f%-)-DBs6JCeVBYzD`Qٟ0Sؾ//ud#pǤ.^MAr)#ybڰ4NaaɰM2`aeـ% ΜK_z8q6n{#ru^pwOyR|0VLqD]]4=̊Ī*_;)g\i` 8'IB[f , -Xtv:g 'IWzl\_A8;8¥VՙS hJ/CB©R? BⴡԽEyv铪\WόZ)31FWbETaH|_ o>Om]k+V&UFhqԲӑA"?}eSL Q*'u%_MsQ!pG ~+?S#D~/ExډRMVnc! ڧ=ߜ*[\y=K+i3On\qK| VAAW,Y)̱Ig3Ag .Dz|SWjvW_9.J,ll1ZQγ[ƐT87>SG!h7$8V 3:a g҂7[6Yރy6kf!J"'LQ|ljv󐓹+=$OD4&~}Ǟ@bZ{m<+mܸS[16WnU}ظ}kQm$ֻ^ 4v3J}ꊛ羥eafRY/M|,V߯it5(BL [.WTnnJo'PcP eB(7tbVx,̀ i5/`ӲB3oY80b9 ..?n-Y.OmB-w@"RBB˷E4tm?(rFsB׾9+iMNvJuaҤ}۽>HT’%(=^~d؞n[e)sqU5oV*Z3K@dD%=Sa [荂 .df5/};vb&9s41vnnsk>Rűz@5oURKc8C_vב#`md 9VP][NN0RMc?zLA$AlrV ש~<qg_+3fިE9w{,|54Dɚ iUJҙFZȫLj+.,z6Oi[8OO_DV+ɭt {?u=ݝX #jkQ*Yw.z`kHtd hoV]]1yJT^MVi V&^Ig1\ NS2v~_O 87˲dDiSgI܊'u_M1QKnjFD!$)1mM(-EULĚ&跧;k*NK5p7'!bdz pJLD^|ӂ-ЗOƭSY#k9^T: a%IRbHͯ\ h\+B̐ߡ/̫k/"ia̋h~&% U瀡vϟ:E]=,hlK8mybOE)ɾaQEFMSG)˪yV%7g h$=o5+ N y%Vk-"@c& ՞v׾7@-#d#`xvYC:铆Փ4 >$8" Ҵ?PxP|$QU񣘩3y Go&3-ƳvehY!JFlq#dX7"vp )Sr?wwOa./[qadk<&Oyeh9|EC,̎jӻ fs͖iw/)#g|K/v0{E*+>mZ:3z0J¸_l.h>Kg~/GoqSxq2UW^g&R0\yb9-$YE0a~U&26Ή_rfC̉Y;Ip/ĜusK"Z嘆ls #1qV1Nm[}Ui5ZGzy.bzl4?G.5K?/c@"1ϼ3L1gѥI%Mf]$ˈ⹈{ nז7x_:,a|IK"(bC ϡGKa|o7AkL𩩎Η@^Ռ0pk훡5+H/[ط>D(H% Yx[{l,6Q!o0={U`L="T-%:5_Y^@֝^j[e(6%2@b P:Ǵz/U/t nZyԘ%{Ca&v*-n4d) >‹0Y*A_;,,\uV}Z0f(=Ȕђ-49}Qof%zDBcϰ7?RSv0Y,D(3-JUڢfaE`9BPے[u$>][ ҉͛&6_~@".x*D,I\gϳ@B'ͻ9%Gq{Ō7, fWq?gJEEaVbVEngY cxJ&o Dk>.5z43{ƳC"-Ut  ׬]jP ^}9q{R @j1';z<0咈JL@ Q1St [ JB-gn8L%H52O$VΆ WC8Zi}ךmø[ OpNn@OVb\ԴO SSQMۂ+ vC ane'aaVZ ϯr?Fz 1[Q`@J֯i"XQoL*}Wܛ0T∮66Ջ%tC$ 9IhQ5?>IVO`(MǞΞT\Ah8߄蘂CԞ1(s\(w-8o|DC J4/w[ã\Iӕ+׻ 6bxYf!;fDylv۳bm!ՙK(6cƹ}Qn(JRQ$K=]g- 3hY^_Kg1@pJ-zLv-¢ onhtnW{!o90;Df֍CmŔFA-'W 1yn&ĕHđg'Νn&IPp󫳁UkOh襘(L*(k1uQpal:z=UD`D[_Hrņ-5vy^ea: ue" 0MlwW %F%u^ XHrGzΛ$> <շ]D5Tgn[B6sD NaPܖ`g&s 5eDp@ʄˌї fgʞI ERx's\هVlh!yч^ֽ$H8*MfTs.e';0hKUBm;Wѩu4Tyy@FY*ڥS^ p#-UQk('^H֌Bk%K 8 t$(Y7ÎߕX$[ö^oQeA8h ]ی5f2oqZ%|Fǔ?>18ʜ¯5^s_ T[%Kn .0K5au]c!lg٣~aaEe*I!.Q-/:`|\ϥ-e~L.mʒ˕7o C@mjJX3޼hZU..[o5<-U !D6# fU/O;/\n>+)WN*V J[݄R:6fv|LƷ ѻT@/'X- 0D7 ໎l=nps[T Q˯~d(l2F gcKfob|ˌy *󦐚Me^>r9Ii@VhgрKѓt֩;Nt]!R XޱX® x{&,!@-i8f2W[JJڋNp/6l"[4A='OFd;CG͗WZ 2t~K+p[hfp%6 ڡw\tz:`ap\0Z 7#]g*Ӌ$S4f@b"f<-0R:2lZMK%W2ٮ9AܹEȘwDž $oSp(u7,PZN!>xe둡Mh%u+/~ uZoERF+9%߁v}Yٚ]GN84bF͓9pmP68Wz\g1Q\4o٢@ȧ3fIDz횡8YNcx1ye`w8G4f]E UHS0u\(9=#D'FP L%UȵM3%jA%4h ŋsj:$ʶBѸ;McBQ<\֣u =@¹ OxeT EyNk^>y#ޅbfT J]?׭%>܎;pϘ|b10fV7?p>xv!JmQb)Mgz&at2=Rש3Mڦз!ZBmE'0qm#14ndQLl_RQ f0G7Yҝ$~m!AՒ")X՚*Ep "AM)6k江yigT LB6X)@~8ChJrR`Ty8 >+B؜%pj0;{M+W\j ŗl~]6D5j7%<.@gPNd- i̇ԠL ́=TSpmP'|kw C"sVQ)g{ȡtK"L?᥌L7*5BK|>U/b\`sfÝ"YLz@ EN)dܺdIv`ח*9UBeud67bD[.vJ@V %}6liY1m5owyf:;WQ|y{3x>,EDͺb5dGfӫ.ŗ`dh h8tp1܋g]ngIu쑟.gwqV)=byy?LA"9_Ȁ],ppK^1,`/\#z= klA F+,K놷Xfֳ\٨! h:B~ʦ=%a`*Ya_"[! h-;.?6 Ii2*L 4.,sG*5 k1iW 8 )!AS ͦ8oº r-BMK {RU`dSXV{Lvqx?|ug_B=C{3nV;=Ȯ6 UGs-?x;"A=GgrQ׿e5!yC{u^/f!a2E ,E.y)+B*Ӣb$M[-3ihc}5QyQ7-=?gq_GLσu9XibjH$w I@EY3.7$VnV 82Qq߉5x?Ź[muC#][%c@,uI3 G'Rь؛gDNIPĜGQ+I+9V՘#˨]u>TYvu3?Llӝ!%xkaUBcu=Ҏ_B9"ϣfoC7!`@Y1ŽeѪVrHSku~G1NR0dͩtL%~p75M{TSƂYĪN6HFJF0hNKiC$ه 3HmGadM' c: $*/v0vۺl-^3%0R+3t*'f^(Kx;P̲KcZf̄-筑r@w (^eTQ1ßx[ظf›JS빿R_ZjKztCOnse.Bs9J!s:8G߳1Bh:F7溴vDJ$QJ!+3~%ۃd@"XW*CGĭ| {aǨCS?g\VDL2-2[ Q_3Yo\܁:mBn0Fek,PD%Ռ5nm'}CygTVs}Z`?eŪ|fo#ƥwAf,KaCf-TXpw~Ʃ3@> "3uVXŞHx .gJaO/N9]{!"76c`^K]œׄ{Ϩ ; ߒc{`H7f, g6B ?=ydK[gʬI_ҟRxRpD5~g"tX>\{oIJ-Q~qZٝ0ڣw~dpى/tRBb^r leLFA{ oVD%97fֺ@f,jg5/Aj:Q[n$<5pC[*5T<ȹ\WyfV~N}@6P{"7S]}0N F lE ƲPl"!ڥŮWGRt»BW'^A14&Uz{.@ȕ n6P} -l]6ܔ򦩕]=B h(45<*'lwnl d+QV-' TaD8f[Eu[`h2D^# o(峔WȇҀ)dzPT1?ޜ0x*O=Fʵ DK8\~Sgܚ:=ћx+..@aqć4⓷&GҾ>-3۫nJmtu7^b沫y5F<U@pn/j5|l4(ܧƁ ]%C ɴRKw>?wFz$d1$\»| {R?ةC&Y)]Fz.+lWU>`*攴0nZWYߜwxmMMk5_1['nS@i_YWOKe+/L)ʲ9&Q20o)J׫2:K[=HD/6aX6QGh^ 7,V'ʧdܤ ̱7\AEStoTaDs}AJ%2nMrWve€p} JfQ +aFX+F%[Qoj 31Q08 Z棆'_+=GLʴֶ'Q4 n?srҗN+yB.l38au.7r0H`B5UX;aԮy K(2GJ~ф ݿTjq.L\3Wwd+ 6#MOai5jH&= JʴY2NzK,ie{AC K7\pgʆC #Hd?J.lB_o֚ oîAOfxdAiVqIIXb{'Aʓ;Rc5}'oYp)թKM{KfNv,X1 8aљMqObю׍uߛvgYNJ=BĻk/&ߑ5CxmnL/SwgiY {1G #MڑxKCѷMD yñQ'q 8{ Sǒ~;psh_0 BA|`]H\&-G_P;}n Sbִ8`e/'b. Im̈)0`wX\I,o %jTgog;4'5~br %޷]VgktR+=8։ Q%jiXެI̘%Zd>HvE1솃 TuH]'k4DoXSs%/W$qB٣CD!ɡ|Y9fxBNخ0rݑ¬ǣ,G Lqew$E: =v/CsOaQ^tdHڅƀF \a O}D+RvK}e[i w<{؋Ev`:bc y u?q,C{ )!2pՔmf1a(Jڮq> [(ڋ6i=ރ8aȗ&[aPؿ>ۛOFY&4:nقL 40飈&lID]#wcwHi4-9_ A_n$8P,pUR&[(,ݣ7 >@V36~Nߐo3tPYiQR4HL?z ve2@RgpZ kx?jM<,7&"n$ 2`*9uQh9RE*A.ڼ5neD*G\dۗ9 r[Җa?ѰtQ: Q%n[0)gAΞMǴۊXN2d[.ň!k\9ߤ9n^ԞN,Ԧ>u5N^KcEzz4fev_ T?fYc-#fmgm. .rj-}Rs9sc8ioV_i##r&!?^ ^*]3UFU >vwպPYuQ0ࢋE r dUla7q%F='Ms q._ӽ4EJPudc[KX2Ybb{we /$@ 'zjZV8ce -|⡊(RR}EheW'*Pa]Gq>D tstrZ2N#N 䰌),DғeV2VП?9)X^"qކ.=Vn @ />qPV,֤Ό 3*򤡒aښFcn(h_:jEC|9 ԡ{]ʾ!fڧbvTUvEl?GF[&SE27Ǔ|;IOw:Z"O@|#w2YjzwN.Yg&'3݊i%K 6TZpHOc&y =yjo\ #(1H?IyMbJP75EqOzTfv3#Y߾*Mn֢YZO:\AҨue&B?ƌU~i=0c<9SHYLU@BFa`/[:H(N2n}r=ltY3=7`,ag$JY-Tx[:U莣Zյ@<&q aSYH&KH -V|(BT(exD4P6 [[B()=ѹ!Q믠~<& j'enJ/DLq\qkܖRwO匩':B</ KLhSۯlqCAh;|k.bp>?JusB!8(Lu7nT~9oSPY#zvۭ9Շ2<2\e`1i{-n#hԥY5(95Qd)aH} B'B JZd, vog~: yg& .yuSdshraH,Zn޼kMB@(cd ,YF9*\໙CGP#ېj΄TVX^Ay pSҾN2ٟڶbe"]F1޾)i3ZS d3/tŽG$י! '][̓G_O'&R]m*]n`C̴֖d}1oĂ'm̒ w9*di>!QUi2F%?ZS#lL *Z;; uH,?7nCog\c*!ͅH#Y H h|a$N0 HO!%#xuv*k,'F<$h@ e DP]Xfn1z&v808#UV F-LAcFڈȹ T$bh'BQ/BPK6V|=L]F-sCm/"n0lX ,jMIIX#Kbڷ{vI)~-$s d.*c[6br8Hţ:sNLdߺQ[]Nm􊙮1+:8JvE N}ݷ!f0jbX{-y| l ? Ad ~D(67U /LoX2Yo$\wlX,1ۀW4lCWXW_soҭo- >/6== u#>n )RļTLmUouO&E=TcbXcJWܦxrh۔,,&15@Kqڄ1œ.yEZU\+Us?4hƸ;aa䒤Y`V-'^`?}S3ƵOB@\LxN (78ꩀ?A15N,J]dmV#Tgŀ. P\e]F%T#}6 6:coYݷ{c ٍ2;͗af,y(ƌm3spt`fI;4IVȁ7܎E L7H9WZJ f3pG^n@dr~{bNiէ2|ͼ MVtkumޔr<;^Մ5#Sůf#rg+p%݌#\$Y-mu+;B X5w\`PGEO0Հ5p4ޔ4Ee &ۈ Q6EzCЙi*u[p[ ~Wx'hI%:N^~?t`֏*}M괓bp"-opNUqܫs2_<0ӌ6v]f)һ j@&DIM 9*ީNsũmd>|kJ;Fh?ghۘLL*9 rᭃ3{#w vCsPOɅ@jdG1 fWMy?~vm[(Q[oO&'B@~k`=%F7[e0rn>} R@eVHBA7dž;cKp6gHT{'yoJ%oeಋ F1 4-ހ1T s.3X`Ln/WF;8I m 9LtY=GC.XEgEMWn%>IdKZ; f H&%njPTQse3?EMNrܱcEa=_=K,%aCJo|?a"Xq a <_{LC#oh Eir(U *@&x|GƝA]'b&tt:-VoF{OL2o'Wev;Tv c|~r44kE p{oBb8 : Pl'&843mPN:St>Ow: o"a 5ΐM /cw^@>&bxf!ܔbXT] l:lezS,eهߣ( ('Eya i;ɐ"[`\lXX©" (*bn_G? h?'^,zEj/jt,*jŧtRЛMf9%#> ܨzr9j/VfA#n2QsoR=6\>Su8zr&~?R:$5Tt@W{jv{js8-!|Cl k zÛ ̵)~w.I?IbhJ1kPI 3ݜ5YKG}YBL|ˣ,SK}Xf-d~V]aD22R¯IS7Vw^۬|<ǝ&2m3;yX)-'@jda^nq }YRi+ CE^KGkf1<_X2:b/]2MJ:9l'.,`B(ZMN5 :Db(l w"D!缓 @%Q9ekU-F=aDs2VSjs7 ]:}ť;Í܋x*Eȥާ$QÄH@-#N&~|<Q,r!j'S&tqJOMizw)(p@3FSk !7I67i=#IMq6cmxFS_>j m @Їh3$[*;< &%a{8^_92$sr3IpG]6KtP!NNőj,Iب\ w@vgN +,W%T42ܤ~1yD3d }0(M:X+a]7v]4ĦGPPBc`J!E[!.wm*32 @ F{T'q~dk0`Yܓ鬦"BZ |np&q@@S]2HDij5kP7m}?esw⡰[(,b|9Lة{ utޤZjn9@g8Ӱ_Ͱ'qgg5?p#PXJqM|>٨,*E+N<̍Q :cqR7,N)?iddY9~ U> i\i wM}:@f-E"59:/7 @MO^K0dڽ#=w$~bn,B?8]3AHoo$:l(AX'ƒҮa[q~]>v4[[.8.b%qA3 fsͧ }')uBblSw⪵jpٽ`$w\wCu̒b%ioBtVEv'ax&5x3jOu**T<[/"l;Gf}jHWG=m_),"w%j޶},Xw!QErn,A J5Fͥ_!{>i3$.8kgO]);r [vzg:y^z|SwBA[\?ş,/=O7j5Ò,X~D iW}!/XH3GBH}'܎a> lSm] KD!K6u\&?\Hu}_RWj\Cwof-@wjiJv k>{"qB\)~ALF&JWGZ݇%8>%RЛNF_QoKFj,sH0ǹd}Я_YK?|d۔t-hژâX7tǹ1"b`f]TS:Q G/H恁'3F0Ţ;P-w6E0KgDn \p;AL蝙wMf0.q83:TڻpJ4Y*֢^9qĐZ:#JʒS. ixWgy_m`"-`5JH%'Z1;.ky"R!8ѱY|x˥?1P[$Q,.8w@W= d %fሜscB”s[+eŀ7êk@l [x4=NB;G,e Ŵ Kc9uZF3/h(;< d=*:n!ZrOOdŤvK鮋*ң<ŅCa~MoP) 2)&3AxF 7kcp@"9>m.%(5[5Ry-R hVITjz54Q}92.kcX;] vn,`nFڼa [8|K2YFV恤:֮='YH^m80Tg%vZ&m t:ʉ3cvMU uA\5v.[qc_KCQE.c~X7 bVsG+T]L3{PlLMUYRU`ꥹD`v# r[M 5ն嶤WLk+T2 ͊|sM.`ZvBjT,zZ&cr%I.4Zŋ\Z=P88KvsB@'f%WrpS#3U4<,4T9NկYNx1 $EfzB~d|s$jEFzyWɗ {쏚ez%wEKآt !GzL|}27ްR:dCZ?T14x%Q夲S?4?rֳwB~;bgy anQw?T'=dqw{o)ibJ5qWY$yzgwed2k|лG@~B&s6.a-P2 c,pn1$PFx ˦7seIVm*pN{8,H_wN}6eU `5H ".CZ ab׵定9UoB%Bz鿫+;ڰT#ܒG{JWS?q0nـfk'?Jp+rGiPUgp#(?C dvu.UϮ4:LQ,'`ެqN ;;LʃQ@f5HkEg- X\7:pm W*-+ݣ A:e:WIaRʡh;1b DX PK+?JXx)D`c8ӊRL<kbޙbf$&C @֪ $RV; ǮN9'_ov,1 ށU9=e(pDqkd|ul+[5[k+2`WP bnwcz_7NES)eozs]YvM 5S\e{O#{qJh_zDy -EDgIOZy*ۀ#9k$f'/c+"QLDRDVhlNX/E1si==g#(dLO/@.16+wIw-LoO*;.Tԗxt'{xZ;]g0QRgUKؗ+d`=F" dU Hbbq-tUs_3:vUȫ>U"R]f'\)c!U}ҐeyhG{y:ykN'pم,Uf?okB.G̲_,`1rפ${MfJ[h^O@{/ `T0Yggo&("pߘ[v2^"¡%(7:hVB1!-0 kH!y_l_ ʍJ̓/<&kd>JZ~_nftȽp8F a^2y}d@  vOP]ZG^'SL蕰hfȪϓNpq3Q~oMA(AtAk*^62m ܾfsu@PUi LY0vTT8qpjDul'Ɉ @AjȣȕÂyj+qO&&mU<6&eDek*Z30=* Wh9Gy71 obMoV|;^y5d8!,Nb04c"ע>}&۶{aQ@L[Kecn؇yA]Ƹ`@ YZ