python3-firewall-1.3.4-150600.13.3.1<>,hp9|:DTԚC"Դo Ne̛_ѩπC7gUjNMehkXY6CCAz\I=ܪD-}<%c|}ڮ_MlZ9ctKyZ>/%B a)BI SzUdw/jZ,%4<#Ǧ++Rrܘ%#쇹"Y7sS !z BkNSTh,>>?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/]"k%na h%#9L=M>j L;d%:f/}0dc]pYE{ L?Nu J9 K|oX UZ m3'9B)>xG|Q P##'c 5Wg+hx6B}^i%_@8s`0 wwKJ-@ Yodo?4Ma\rE6ofIa9ޭ; U)?kw.QG _g~#[p9U#\خAkw>vLNmwTAtb jxsY;Z:WxG,CeiGBu<,- zjW?5CRm[vA~ Gψk@ Z =з/OB4& *6gM{}/A΀M'L3v:"_v[ȭ gВAB.c{aܠقcCbV֑5%\eͷg旝E:Ζub.Ct b?cFI5ަoCm=δo&bOX,ML:y;_gרN~0a޷Y, ]3l$ZTȪ橂V8xvOA=o$jZ_B\ ˖OҭۣJ2;3Qۛ-ry0dG+%8,ߑsF~go^2hR[B 1,ٔM4#2']aՀ&JővCCYWX~/"J!NQnSG1qamTv?~ԌU'U biCb*-ДͦgОG#/Vj  4`)pr\WL]DVȪtscNvR,75@^g`Y2'={/`8oYiLh^OƳ(#:$Să$c[n;4n~ڣT/Z-?+%i2blو12-er pKlR~~ks8NAPZϙq8o~L=mDcE1r}8Naギ]&`vWPu~"X+Ev-?*^Jlf-Qܮĉ%٢Ca6c4#TNcҕ\4dB;rm""Tq`euhOY*>6b&hg4͌«%?ކ_ H9헤v=j(d;_@ׯz(cU*TaD\tDxrIX_4@îy|Аwǭ>UC%5+0UȮ(4HIj<| t$A墌ݚ11f}mJJU ӫU۷Ւ^UP%agMM)񷌃&|x6FF'ݪ޶E)Vbk* 9d)xWӃ聅{m2}ƴET],v @MMdW4Z#!40V8Š7L:~̥-~RzüZmG <(4r|0QTJ0Ӗx~xE^'ψolN!-@Fth:m &mmx&GH>+J6+ F Ks *fߒpK @Y'nW24T@1kX[S2k\Jj}I֯-`>{hIYZZVi_KS3ύYl3 ^n  w%x/alʽ}hY'BH6lYKBc_ߨ&0TUN1G3r Gsߑ_'F} <4ͬUb߻26Bm|V~n;Xj<2([ރln%ym⡂?8sem~@^@hw0B[P^W4#:d|ar؃#2tE~"&$3s$v2M6Y S!p+I2#UF?SCcPABvv0| 7բOˍsABmS1l ZbAL6M;ůJ#F5[?+cZά7xywr&۪3g21+V&-HWpk ;6>§70|h$8 6 -I)|4r0v*BKDk\;z[},Ջ T=+%ʖ1=#끊a O I[IKQ-> 烃{q$6 <#"= h:CnLl `Q8ȏJwx#ޕsI{rm'Zx]>۩4쁖R`xw.WCn z* TnvZh^kì Qny)NQlghΙm:{'W_e?,~h@̀a^,:y(Xt:ts_^ІJ5] %vI4`m []k| crGn9y,('PƉ&w?gr]Oʋa(AW]2UV+3lX:8VQW̵)&C7?kBi Wa0T?Y;SsΕ2+{9V:YzCa.CD\!b;(3vy)axS/fS>q9G,\gCqFWn4|2] ߔ)[DԯJT4r,_I7Ctf1y3Fӱ#LW%j"#682>T\7D bn>HqOP/^Pi(!l8>!S: ?t`ZLWY|T+aI9tIb3O*knb-4nO0F_[SY (zGEQ_ELi7 恿!-4J!Ix;"Go+]I%܋#Nhv…ھGGٲ 3֍6!VT[U,%qDv}{r$ H -¬>;ʑG+ 3QLk%s 6gM u^H ムx( !]LQ1R un4mLijT|\& hœ0 > tpHFbi}QӈO:+b^k_)#'n^KXfC`Ŕ!Y?k (P,o= i=Ȭg2;K xGC4aZ i* ?X?h$I_@5`a;CtvQ/=*wFߴ^ܢL6f#OssA9$=7,iTyH+=DZJ+H_6n5%$C)&F Es~+G\s%{j~cVȀ<׮}TH?sHa*42iP J~O]l.V qW3R2T&@ Qyq0")Ҡqzԣ8lŕ:b㨥H[ yY Stei]e:Urfv6j]|q,&ܿh;< .pINX˼!H?W)l+<1vKwrĜTgFmz[0hP92K>` PXꅲ(בRutb9_wS8Ph܆=fu*Hrr4>LEBfLuBj׋p,f,fl>=TuwqBtYJøB] 2+wK3QR/XuhiE@+ߕۄt3xʧA?pƤd+?uw-*$meõI6:A:G?UBN Cb~cXް :MJ."yIRXJ%jH1V]5"4o"ݷP9:Ϫ[+!T㽲o9oѩx1-UbT7ɻ2M2jvt@qޥgKr\ܫscwk=Sfzs_ii )N/sˆExɘ@Ξ1N.sGJP5B.MTIui L'lzB)@rNg6je6H]n [|h<7@ES)Bx8aڸcڟ"1f\yPQ|kFBnLgM9<+Uީf{ݪ1vr_MU̥rӃ:#$B?x!f)d"Z;7DL]6- ȭZ!P:}nDȪZFfjVF H!/Dߕ( h18ʵބ\Bꥱ +G e4g[@EωurUx%d+QNuL&MnmANhwcUyQuҖqq*Zvq 6\_]rpKB۶4c#սJJm7^=v_q˜襽E̹eq1X4"b!r䝄ֽzX}r@aTIѪȡCuɲ0O{XUB#x1rQj*Cde:B׵>||S7$beX~F դe :( kq˄QU[vefQm].{oV'Aи-`ԋqpr.y<k4h#-Zs@ BI}0evc̣6V 301pZ¡TO1q<.%A}H_/lт0Fְ *&KW{:x3thXnk%PL;NP_;\r۔oR ʘZYcmC-hdL1]keVZV>lUV\cP1!'l`pXO;KX.pHGWdJ_@GXV|r38xgUFj!8p'^/Xp>>„8co(^=p5]3 Hm#.+!we;ioQrƶ}T."hH m$N!*'f+sL* pyq/YS83MJ* %l, @( f%q# ؿN}baw|C_QY`$fR!c3WQNA p\;g<0 _\]Vy}tCv"@kZ:v X˾ ҝ'ZԢz6==9fl2c\q%F|hͦg3x'tTq!ѳᕴXArbtFE;4\uVozʣ "sN~8/`qq+W:o`k8NR=% Q[Le$ :Ka­=@y/`ajg" "7StHi:da~!*il.2рIXi4"6 Ww#.iLե7!_({1>U=">/5D1Ƕ6hh~3GdV#@n͐2SDikK˝Oሃ0+,3(!fn8nE͍霓.s;㯖sӑ|X@٩-EQdā}kB;մϩ.^ |%pmN+ҔJ4G: eɢ( {&N=yș& 8Otvp$U㵱 Vyop>F"X;ivy;zs. F9p]Q[-UEWJl`Zfw-l܀)I7i?O g]Pm.9': ^y T768 [h;3QyەԯYai:v7&ΌkSǰz]}[^ &hcpCi wIxO+˪cjmJ\m^4NhTr {J~ *o:z4*in=;sec M$Y7ʨV R ֕zX"G ^4~~֘EFIfS,|n m}WĂ5?V8Qje|(UW%X& %aASx%HIi\,rb+kt)5m^5TM/釔!FrY  r۟7MPwr/cZ?@#"Xɫ^bC~ɏ"T{R^Mx;wKZ@̦̀PD/ (`olO :ޢ>};:^v8LQI9y&:+1n >6WN^ɛErK'h: ~D b݃%9t&f mՀ⊽n _}!Ou 7m%\fH"xxbqݼ>@3 s)9x@oƋX|$ϖq7ÈRE1تNdnhQ@Ԋ@2W"P߽ c^{f9q`AL-l+tMV2cOTؽ6F`T>et|ĩFV _pPc3OКքEt>lD'tėȧ΁=)o,„ͅ703μ ~u9$Ƽ|wjv>cz)eo@VskW9y){7`C rCoG{ xGm -^җ*^ wdΏdG9krP"L5b*yWwp)| [H"*5d|[eM#[]z/2bi4S#H%>jת vK\g v `N9A>o!hG@4DYSMo%EOox27=xJ2AoWN`.Hp 88* sƿ+7f#Gpյ'@bT K[h3"qՖ=ͽ Gh5v(;)ꭲ2 MlJUP |z#f>]{˛lqPA>(aGrZ8yrψ5?`H*u/HW.]OYlT8qʙ.߫(~=CC~TtUpk B;D" UA[p4+H67pf%ը,xzjb r[@>8EU,&x!^ƊȞIGE^דiQҨq;s12s]D vN^%+1e3y}m=`HJxl@0ܯIT/d3/򭁩0| o0!q!j'1I?HHU1hB}$#Te@(S7ſm'QK)m\-{?:.M>ХQU]dWS(I$11 MbBC=p4*Ra5:f6^eVF W7Ō3ޕKSCcMAF["] zVu)jkMºxN{; G1r?$§5Wkw=rnHo+{:B41zr+9S,XT@Ǐ_G:<" w^?7.Ƃ3.2a|Wr\'#jW`8 ˾!SM}SBbj-P3װ=R垴qQ8Y>lnn%b\Xs (*Y'!LAХ%aSe *EN:}t-%B8BԆx}\߭MZBFc[5w!eҊpnBe8}>Cz,2ZIk)F]fqif`'\Z? pB7N}^$q`<ճ(pd0A{Ai(^?Jtk/BCh) OW;Vxtir"Na޹GFJ+f7͗JnA-}@tUqTv?0SdRQ>pgSgr`vwZᷧNxD'-bD+˷uppĪK`ڦ>^Jf/t7xM> uZ.|-o]~y4m>xɎTB/{?32_?6 ȣEwnη6S/+dH6"ӹgF+(@Y4WYU*DBYz23qBiKA9wS m^/hw5`aI2+V]#Be$S]#ql֑WL$0@k4A:.U)3^&|weUYnإ^s huPR! 09B$ |0VPF )H (H0]yIl+OH*±_/iyhܮ˯t%9kS06"A^>B>k2"NO`n)h#"D/]vmˍo:~?:Z"_T;p`[UzL73z^*gir}s|R!f-Ni f:)jX LJSd|_||텠.5vǸXSZH+OL~*&{23¶Ojв_GY~F30g $'B4q &Diad[aOrL7$Hlm™VK8__~CXY:S6^\r4[&5f^3CZ _i p۳wȆ𩻸CѴ:R{5|WPe$Vͅmhy/:IFBqY _E!7 T?>\)ep7xIّ eOc&ZmdY3cs::4ke3ѻg>yOLAlLiZGsr1SolUmaC<B~ʒ}<&η)[e2v'|niZ5[4;Xմ+Vc匳A?C g'>6T;'#)MB,y3%+>̋W&VCYDʦK7fQ%USEzGB ^.ǻ~Ѩzh#y>T>'5&J~a75t *쾡a?/0x_4.(J4~VR}5κJbJlHWqTt9,R+DǼYiޥAv#w &~]p ~@0U Gz9T_G4q'05͘YV&>(x98q,egPWvtc/ %ޢܵU 3;4ɽ4ꨬxc ~DuVh\(M2fbOJ.LkkVC|Lĕ ev=FxpzspiuF'p𫤷UY7|<=("p$x[MEh=Kܜ˲b-SUe$647N ( 5G_.=AgMsXHn(k:Q ib烯ﱓ$M9M ~<%!K,|}/rZڶP"0(X]AU%[.X9͋'hmY)X$|CXJcJ^dN:څKmx+|7,SZ;¤}4KAvZ#։ Ŷ."DM.*QŢ#i3v+YϧڬNx{1ʋ?0OzAiqieʁ3:Qs0/ۤ k"I.}j>6Fn=\b..]I! )vC]Uj+@qtz-Dž ~؜O_}@ہ Wi{al򽸏*8DGaDj3tY9rMl~F$4k%63= Gn rE| aDixœ,v}Ђ.g_kEH-aY^V i{/⽹ch9NpK|qO;ԴjJYijp*2^~=阁Ӽ_ex- |^ ^z4J s.5N)uy8'rq_&XMsbXoϠhȥ.ֺWS[g3q8\M0'Ƴ&v4}7-KB8 l::T UF hShW>CдJOyJ]\5n,CϧXD)amexv^^Kf"X"홉OQ=h<6v㺅NEK7[6w\&W믊 hknfҾ)ɑR1bY'߮<$3=D5"g `#@Ā;E{gsmC?19ɠ݊B*MHOIL$]࿪2ߛױF_Q$OpsR [V >mPtIR˛8g܎40c/PAq2Й%H<ٷrI,>; DIZ9F)@kYEV>幧´lj&Pʾ2fVkEc0?ϙ=ÄRrPDQ&vwaGz:z(\3<p.0R Ҥ[dr$Yi\ A֟H}֖i)TMiKZnxB@5SdB'o HvN"N!alF &Z;qIÚXZΰ.{@qJ9/"s.d*Fw*VRn R_:d_$);7\*ɡT:S]Ӈc3D=^Lzq}It;~RaE}iLpVaeBQNB\hrNh^U#NR?nffُXɊzUcf>R:iIUUma݁ |%:ӟMD❆§pO:b>J'ߝ$OϾ#w/7 He{M6ʆQ%KR[ $1y haw},r'?F~!BS?=#SBFa|ǒ}z1=}a'#Dsu_|%\EI@?zUݦ|Н r|Uv8 6:IIG1j#Q6e: nգtT3Z/48H`v@7j23q1#߷Ց\8`3B4dm (A%1"Abl6hBRΊ9g{ٳ@yjwܦεXQ=?2DS0I;wrQ 3*96 =]:GBI$o?XEHΒsc_!"=Î]qnke^x0\03f`!IŸ`ʐ4v:;™\] ۽;aH01jmӘj0AB@Jض'}M:#a0vԗh 2Rs[¦nrIV2xOAX3X"7.\P0}-5S\ y 8-!h2vhaWtӋ9]JKvۓ^pp`Q;60g}ȄݎgjEGIJ|:ovfZg[PP@^9wخd=zmrzdXLf}Y Wqks (RMitaz =ڊ1!ZlOGtW:>~ZG@ lC$Z TG|@D0"l;$E[aɱ"`uw 閲%K|Di* Iy O8=66<4HuC.!d!]d1ݦq?b_`ǹ%BVM \F)ӕj[g:TI=c5$?eQ<5iyYa'Lꤴ槬sEQXLX:Pye~xk(\EDT/N_?ŸfYɠͩJ ˲]n.; hA?8ZOdӏnj"I!d n4#Y{tXH]pJʎ4Ř׽JΘI 7J\@125+[Rڛ8ʑ~o3-6^56H{z#ɇ!jܤ^ Nx&lvh d}8.ヲlNc10 kdw|Ҿ\~ZFMנjf+F^* B>LgbOMUol)% g "8 &TIo;z2 nn䇞yy\h(Hp>vƖ"n1P^aK}챕8CEPWFg8_.nuZAˌsp(m]*Ѥ&4" X6[>SB(>=84(EFjd\=+ ߱#o.TZ':.FH&TI_ QxG݆f!HywBv[-4.S50'5{eҐ 篮Dۜ[>z>%w4xwe\bnxؼV>B>A1kC ^ Ll|* 0SrEKӃ-Dk9/{um-J%p.Dvc&?dj%EKu1:{k xIE>j˝NĄQhT͉jX$Q-dtkcq1ol-GG.}Q$NEeNb =xh?c Uޢڥ~>#,1B0L۰#f6Jgt55_U Z_)r_gu(JWsb7u}Xɹ[VsR*V6a4HCBs 6+|SO'1}{Q7a[ _g9g>>Ͻ|i`nk972VojpQM1 &a[ϊR̋&fN9L4zBD(L>|ԞX=;0҅t Ds7bN n[  ei9AVZ5ʯ@5)N ^u)[sg1-CvA r2T9rNgLmP^I ߪn2H mN)?2]t(3M2utB>CƘ؅O,BVnDKi%QD$T7OȃI;N" o'4;o ؓkO'4h]O';Z(|(c8L'_s3 _5_HLw3KUk@J]SNr"9P.0xۅI4`p"$m| 醻0acM.;XPW};y똝j&p~cqrm9'|9z̩֕6 P1As#G:1H`,YNtmT,_ ZMHtES|GQmȄIaFOJUszPL)SAqzCG~i:7&Qev"yzԷ3c&wfɁH 5PIu:ZO󛍇LOBL'}Ո#͆.wҼե:s^:fYr;> pM!ӯVBp' )DbFbߪKYpX~l_VGWG[<Fq_@fW3Dl YTH4*cOX\I%\fUd:k(ⱎ7T1[j񽟔XđmpԮ#nxWBs].m CT$f LMky^L]JβH̩zIϑXAI'c 7a8~y "w޸5} :(^t$!X7ˉobSZi;]EJ+ gsj|H7hs"ۅ޾QPb&8AXZ m-#Ap,g-%a˭a9LX-Iʼn ;QAfV@Y_"a}a^2{q2a;"~hG?"/Dz'ڭeuk  s5h>2k䆸}؋E['e~h+L.>ڡ5$qo ׽But4Qǥ5qT,i'p72F=Ow4)C8,Ձ~A]YE/  T5'b<=b#u) C,nh]$K5fRA*U=kvֻJƷɕ7 y%(8YO[bzZc":<^N>J5٫O- -+v6ݔEb ZVLv7V j?߬۶?/ nK KxG( NJ'6,y]z|) o$q?]j-. kqv2z¾=3, :VKGK}qܛ 3b3 DAT9wct0N? sK7(t g_bw &PiRJ"1I(<3J/뫁#ݒOЇL|PyWdղ-tD P#G},}{Ϙ} 6/qmu \ڷVz|Fb@6[nqʹTj- =#>8v3p9EhNq E%'A iwtfUc/"rN f$$-:!D<խj{+>ל"SxFRyr7?, $zU'98+&|1;$C`L @Wz3̖a u ;,Gz IWICf [C6G7:.5f5OߵJQ24 ]a|p v/&j Fe؝##F9G^:dibb h{8nNp+5 BOr[+$CPyBQ Cp=fi7Ngibzf` ̳Sǘ9xb9 X2x7lI稽+;لJ[8kn|Z7=)nf23WҥY@NMqZū~RDH `rGM)Ip04K8bS+c3}#"zgO ʅy^ko;`R ןGL!Gş.1<ִ39>el֖io)%ǜzqB~\/[N˩\_R΂? .cFeU%3/$~$rb#Ƒ &6'!8ں;M']ؕlP A=`ؘ\VǷ}Z;6 E2D3'-9E[+'ĨJc WS"MxteYyD.Q3;KbPw1NxvT~/!]OmQ !^͟2։G*놵aD=f}0F&9+]Ur*Q+AAE[zʎʡ|u籃mz!:'dQq:^V\5 'ɕ֪_*;kw^SgЈ!<|Ѓi|h<>%CJ~F+ N_ $xF̾4߻إ&W T:Рu&qϤҒDvG1wrfCSm6&r%RY=$J95}&`7ܺlM`j.w7"wHLhh+)'NO W mv>'Zs{sQ{ndyN#r6!Ze"zH['esi߆ɖ6}R "2&yYؐ ۴]EE+iTk'vWbŵ "n*D좚ZP&UFsôqPu1/ReLc:<èmB-\^8"15On^ES5Qk[>YL,\NGfźYd/a1 1Ks}BW"O2SI!J/Y=Sa}TG!^ˆ-.4kq$fQ v"N.;3Q'hpvAOɽVDvybDfjnzpwBG{_lE"#)~},:F%Ř< [riH3#6ڢ 4WAMfnrrn1f&h\MTT[7x09QV(r9Odi+<0(M`>@T킋Ў8}8^r1*Lհf9SeK$헅>a`sX8 dR1it*ON)sژ(ev' ]@++@dR. ڸO;Ǣ5!Q^b#I):Ī}I W=#F1nf^oȑ>6 ^M_tZoh(pHA,Emɳ *Kq Tn0Sv.q4mUcpbVbVǕHY6ry;T˥!,Ag֐v {fZ>::X"kq&IϥE -(l"uίiXAK[f"|#`wLAWI`oGeCc:0ϗl9]JUy^)@Υ ._\xXG>|3{S7k `_ @ҵH*W7׍eZ+R(b9er<;V@ј lELlOѺTG6`'AuC ˨M7h8)>H&Pi&%Kr[089F~|e;*I*<wq/n Rm1 q>Ӈn,39h]8TZ:6Z(& @9hel0a^0> bp"vr F.4;N#{vs.bMǝ@QfehPv0RxD1b]}h} f'jm&'QTi#%EQ(禤KKHl臶jT$&e[LOF9 nZbSڟ qHS{l=y: $e_=,l}ewT[vUdX0ITzExg4r%MЃ7 , :i`cfD/4Um,80s=" D#]WSM|I'k›BvHŬ5!:S'V*lP2L_09AHbݯPrZ# ~A 9dauC/KLLh(ς:P!k5!TI H(x^<7zq'] sP>YtN) aoDJ'3a|= ,[Vpf 1\(4NbJw7 6EWKdr{R慱dW$TyOF'N?xFpSZjkg.,u)yB"pm|zIʾ%(껧.z^Xʎ)DWP1Mz`J%hWf4:^c.3O<,ZsJ#8}\(g:. Ǵ}/EH`Ig7AmN =gR~di XlHZWk@b?ъq:cX*260\XoM!d+TKAٰ`DIC OۦǫֈaPc7 U,wz-G4;/KCܛy"vuQu` le SKHAs::+$ۅIfFsƟX6{)BN;hn+E,-!$%5sJ+LuDw5]*-Pń]%`Ou"KeVm@%v gNjHW0! 2MIU~/5:zٴ\!~5,cGP^es$d̒1Pm1m=~=5~_o{紊gѡW[VunP:ą4nD:#^*_:5#7FzOFuy@Bww>4!HeK,1 G"&wWLs~)fY@]Y;n/{9Hj OLX/\,_3s 2@COud5=}(vv.Nel ڨoGof$R1^ OzSw:c3J]d"%-(>Ძ9YS.HK__ٻqNtWz2ҩV}-] %/1`bH(%m)/.SEc$ lko)ʥlIMj4a8cƂچ[wjڤ%SZj6m8$VJ9CPr̪,`gS# o\̖e2W^SȎAg֬$ @2{\uj/I>pFzݩZ lj32$fz_mPk 1fShyW4<v'}^g?~PcyF2N?bG Z~i]DD!?v/?<+L0bȉ]-ek8$3B!1D| X3nVr a컎^#; zz)YDZ@27(\xX;>ӫj#mov PNo~Z|>T ߹) [a|EvFܜ`(V(TW9tSeP-A|:oUcILnl "#(K}2fpZi(%]`ci^oDJG'-]q8 P;V_.]XYtR۟}\峛B;PlGrl٬ 䗈>Y|D>f6rJRi?6MJWUGs-@-KZ*2}zIUR aO5{Ћg֪"Lŝ,ۘ nfE> .L b_~_(a!U,b·.c,> 1Lnu1q `RoSZ$hŎlj}5wQ3,*(Ǎ@gjmrF5MyQS1s75]'S O^I(lQM h:>Yyz^S/riM]w-.Qɠd~\)BW<xl)ܥ0idh;Q ̇ybjEީ{Q;뫱!$/6Cd_D Ld?oqSW{)uþ ?2J5y}oz hZN`D@PҤFGe_|ɯ1,Nr1s26_lɓy'w1Q-OvϢ$zyv;W%#YOJ5aZ3&:[Q,MKؐ ؃} ^ r^**. N[7~ژ Γ|TM+_coK ֞?s'fצsWj MGw˸̭~0TC,KQ%M_ΙUo<L/ _}&WR14s9_tWJ.Ws+8Ca}m;xAI-:b]bd! Eoh&7?(#Va7,A%VC* r硎"!'*v} #EJO<<tRK+VЅ E^NB>U_` FǛŘ+DC}@tr"6Ǔ)%Gl{ ;A<,\$:^AFĽ_-kl0:'Y)ۤTՐf͚~М|WV0Y˞!vaW:C/Qj{?:1bI]&'$tz ,&*N_ b;fRg5~'2Â#ef-aiq(fcȜߋd_,~>؍VUMA^Y?ir;+`.-E+t5{vЈ  g[ G =uY3}s2*;ZD\>vZE`ƣjh =D#L8=fcLL:5I"6I]N>[JlR+Д{%u=0ŖWGܵ0񈺳fBɝ;aJhB>*>wzKMx߽ё0}QM4ݍzJiG+d`E]x4'yxكT>7?R~赒Saӄ6e^).;`sFz'=M0{Rp_g#-͟F~5E16}B ϥ+pr gIv=ۣX-^<_#]bnV |teP#.o#& D\F6uH-}Oq@ջ"|6†mld1O}b`ZoeŌ~_ljb̑e?-gv'^Ku&T | 05#ƑFx?THgII1pb"?N;dMԡ51Y߻VrAP,:bvQ\Y$Tb zҡTJg}j-uCt̡75θq-CVK<S?UFp4;܌뭀_?71:R`ޱWJl+Y qF 2Qm1ϔNNk#]l}2m |j:YF>pmcLTiƹp>$C8Đ|C>fT~ H|Hf8>h1;msNdU?i̱eG$swfI-~/)D(Dg9ehN~@j~=r©'7M!ڢb6HRb%|z_:c]B닝9>|$Ix;<:|y y9HPH= R[&Ĭ֢[O\D'\ҙ,OdY:m!1Θ$skdy|04?6{",|4 vw}jY>Sue>)_M% n,G:9nWXFRV;YX_h?jν9p;"dSQ=yfbz!]#YmMT xrͯ(Eå1,JίBsW2HV?suS0/e>}y2:oO6 oQkIxrw_(ÿp˄:=%`yِɂ5*˵{GY&q5lN-BY2ih'-d[ǿ8_NaEr䑣9& },?8Gd3X$}HLIAa$?Ђ^EFeȃ{V(䤄oJw6һ,V{(i:Z#rY)} ?^L469w4Nyۚ8> \יi>!)cD"wNbM:۰l99K/}k#ﮦxj9vHR~P_Tj<6źн u/i%D{V+l [4mKCWvhV0 #џR&)#mE%QD|0 _M+}7Z)NղЗi,3AE!'=#$c_qbzTu_^ve4z F:3~>NY&x}Mĩ/b]utw6I:rW?]i.ˌSw*?]u&z /ο̷g3fV{Ù-@[ެhဠ=D;CAę}iZcK[Pm"\xO|$L%MNY1jL!WhX3BMT]5̈ZXj wa,v;k"P=:.@|E: gVwnu|4ي OEotqiXa6 r'dm{A7\w4 V,Tmıۛ&.)5T2?8CaWq+ W^gVҀqQ2P8/EdmSy{} W<VC@'҅ 8e6uX~"^M38agg_d+\atB2+ :EjϞ4UL lי$A'st&3A%%_[OY)t;'& }F"\a ( Qhy7cN8.U q% ?Z)j~chb +uɊmiWWaZXrzR4Βziم٣{I03>К./=# ,4m("ZQ :NhGb0E(q䯕 õKm`޳ҊJ0008K,׎6*>Pc-d"C4q55UhM6lģŋ6A6gYs0) nd`_bߔHi^ u@Kz?Kiw_$6DӏLbPWu|jȺcN[`L" Kv6@4 Б! g50%l_W[KZJoL kY F7{th~%"Cfຶɫ 5cbz\ΏKTzI/-%lLLku-e9qI+AiyfӲ;#%o:Ҧ\5(g[NCT=@'p!SyIqx};M#G"&$Rt% #2ocnBӈ!Xc_5#DL!_[r*~"MRx^/c\)y}9C :l9u_OV<(NZJMffB*V!-peytqeә2 (;ټn Ad&@p0l$em~ 6:t2E0oU+ra$[v~ ݑ%ިsϏb֌x.G/k&a.uX$߃ !ZEU3fNY/4WG+OC?)-@^H;آi#*%Ќ%*1-3",YN _;ҀG"V7R?E'Y6kHovq(Wd:IFyIyIB0Ho[:<2Ƶ7#" BFN>#Є~(B^*HNwKt1/y>$.V;sdRNy(a"LSDy 1 !7geÔd`J@k94nJ5سV~AIBGjuf$\se#H*`cJ9ՙ*r03k7Jb*ǰdlhB$bh$ed ݫ'rf dӆЇ4{EXwm0 RCj*~(+yC&=FFQPnl,x '"ȯ~=٬#tǖfq;W]/e*O4H4YN;/JAyVf`wjU!Rxգ\kSc .M5Key],:V%Q%o@wS(K'i\ZHt yo4.i>ذ~J r<Zl]`ĬnLrCa])IW(Xc9GŤe=Uj4O\ >82 e慤gaFQ L{r uv 5:w_ 0΍찱ԅmf+fMb4t$xlG6a_byCr~ \t^PGpbgazdKhfYU2)bL~qRJ/bۣ]c-u,n1\B&~}lVlcrLӖQGBe̾v(`֣pmpiB*'nA@ƹ7$*D>fKZC?$Op !+O^jlWSݼvF˰m^))bzbӱkIlc%亩h/ΏYwʦFI~vpQҜGxlEB$_=Tv_h?vTGオs~9YW/d դy] ITq暛"="ի U&!FʼnYO#mD)9#f9A4;.m9KEF]Qb?} g^ɏ@dU$"j@aR̟yB Л/Oڶk@ڗ l_s"W FX̦PŸF^씸#4: ĭc'ϳ>L48j ڈq9HHFE^Φtxnu' 2:8h޳@$T`va3=OW$O'f9R񷫹cٯNΓ(|HXМJ+ԧ73~Vd"aQ|dUѡ"i0gru |{ߢyGQG5(r.Aiڃ2+r0=u ᾃ7[OHzHƾLc."PWj_t3[l k.&1[S/t^;"$gd_ziВ×:4Nl43pD#|DĞ&e%E}č2LVV",tM!qT@1Zy/a< c#zȣ(RSNOĂvAskF.E-FŦ^JnjKy'f> /=TAV钩 %456C8ĄKY. Qu3 _%{q$DB)wsqRs$ O6?Z&ԥFvp]LZPqV$2^G zlP`䳫 3+Ph?}1rPSTz XJM?5'ٞHWk@KxC:o`aVvcܨE2O~6l>pd GvR\83v;\cE1EXըJpgoQ5M#A Wԑ>Xڗ.L1YKm~9 9YUkUWQWrOې)NڌCV:c1t͒5\*[WÕpR殟#O7]R~gxw䅜AV ?gjJ#54A18)4%1 r&3-5-E֜"1_ïYW-C8 Ӆz8N iMeJ 0r gAp1stG kO@q0TK/%p|kЀB";;u"q39,#ʬ" ]#^%&7DYm߉kfs1C$Cc8C+NYHV3'伈sAFvӍHWu oFF*+p]Pѹi5"M drVOoˋ:+oG{]DgQw4jfkG} FjjD+&g ?K]l Yjdet,,D^{W+mS.jd6-n}!7Z|rL !βNJ*T^/:p4pWjcK=9'mW=ŠT^ozJ{=Z}BE]PK=~\6%<U fߍ& 2ɕPe'IgyD$%dWL^F+^l$CqQA5Zâ?̡Di0-\;bűMNA''I6<0h*nH 4Mc3]IqɹғkfkBȇS,%ͮ`ptJGBHj4ڎce[1f<_ASRqO*vRxֹo,RCdVQvJ'&lM;j٢T^~6fI&x1/pdžFGvPU}?N>4k;@2q~BiCwƼ-66# 6UG oz":,Lf|wsG63O9Djۉ!T1=$޺9iCJC,;qVYA? . s软.>?(ƨ:CK [3 jnf)(ސ""4ҭ-gTT׈xa2+{7tYĨj+M?7fD#gaE~Ml6Mï||m)/f0epT@_QKtLA#/w]Y'L|ܰDi)j[88)C2w 76g,@u,s]L|KG!#JHKcÂgcd}{2yAoEn1F@dZn%sۈ^; *cK'gEi8 8)i u cJ9P1OD/EmcRIV@]x8ϴU0w5yۖ!ЙϏoX~Q#,e$AT=舯>K "תiO0W-z b^ƞ,,"##^GH ̘(^w: '%^:`GbUZL%7 I9}󝐦c9ڷ ";6}|λ#n-)OM̫8*+./H^,0Uq=aWd/w<T|zӆ?`Dm- O8muDHё/5@{S VZt+B }:?Yj]#8C6"T&"_ ~A]j]~UwMwם{GA]` Lp̸#}mLvlHaGHͨ輻B CTI=R oc@oiԒ !~oa0by,UK+} ^ɞB*2`RLhI,_*Vrvuv41n Hܻup["x=ȯ4<2:?t={䙌x э+fTPٿji9Pi@|;Of%TQb%Ovy8P_#ÿGmMXTF-m~*I)?^rPalxC *o{%C/*U &Jy+%/N QunA:%B?y"떇wطLu]ƹ-fF S nty/Y,)$[sbew t[,uW`mɖ0 RG:jxEp]g/O*zD4mAw$*Cʌ؀7sR'pۧuzM;:1-XȘuA qzːAf\_t($2ѯy4׺Q=؎bCP=O:$9jfʒ?A|ӌBgA6 2ܮ1%ǖn[)3Y":S9"b/ȧ|aK G;ꆧG{j}0iBHNqny?|^@Z䴚|7ԯUf;˙g_S+W8isXKB^N^ Dyz&"QDjg~*eGpm[ Ck.voQ|oOy*|2$bE7lhlhl$,HIkNCXv42 O,xKhrK'+jo݆YeYf\) T BXmΥ&D9Iyt:DMT6ԓX.b9{&02V+C2?1Q)R`rٜ!}!i>Ln46j"$o:P3|_X/JbJ5 Ed_W?o +.Fmsx ZPCX%|@h|*=R|x՛͈kPW!+mEx0sb00_cCڏ\dLolDi]LClw~rwVa E5|@" F \j-z$a|VQ"\dJjwHadTAҢU؉1͚V%!rr»S{\ϽS]@)(vh9 wlf&H1Y$g;d6ٰkr)򼷩2/P'Ckؤ$W>$n?ýv*p\3@kV\reĝ-\ ꇌGtirUF p9&=gFEI1 b1XCAiղ͗J K>0ndBmʗxq.Gk)z^%U^ޙyA$;ۘ>i &g.d]RH5.:C~<1M$酙^ MFD+}~πnk5B) -նXhj&"Cbm (5WK23.8þ8sFO?@cA{t.`Նz~] 5;u82%Jcie"bz߭;F*l0{h[ک$CB],Gß*"*$t4V=?69a2re"4ܺ%<[h7,wKpjRR`~1ou`ۗXn58s-G"V|~o"kCpdOHm&`8 QE-J{.JUl:JTMJs;bi2 e';zd̳ %mj֨,ƘxYF Z-%-a)f4U%ǜRL:Gl}0`ڠ{ìN+>nP?+hl-Qܬ-F~x7 \ q]u| 僒`Fcʀa`ꮸ`݁ M~,g9G +1ձ9gh @2eƻ~'<(N|tՌAFH MMB(EuƔ ʎy_eg**9^M}A"Qd?{TJ[p{%\jvf 7hCVb%%/H)G)Ih`P< uP$j̤%ۧSlSh eSX!W6KrfC.*3:iYBVy ޳$PzAv%ئsk.q`uT&%ij،o+MG]%h|GN͈m̳Rgb qGXj!ATLKD]oy \ Cv87Z$v7f"PAxߙ L]F#A3e\0yH;]Wt襭] BA\l]ǖam;wEnhp#m۽(#]ԡ4CQgPFx ۏEDܬ%b.TH7Cc{jBP-Eb8F&wL՗sIlWIFT_j.q$cH,|R#̈'\|i3 =f| Ac>XyɄ8>`z)UL4!A8ő"QW3nd /VЯi׸}QdY*dU$Qo$TECaq 7ؘ7Q;êwCoA3_&QslnY tleߺU4DMkdxNBz)G.+(Ƣ1=DǫU^ @eՁk2C6}i*z+mrkS{}Q 3 ZQ.ٜ zYذӉpl*1ATK7 &+ԡz|ٔ X$6gmz>niO.9& $P ~;E?`է2s&ւM۞Sg+;K'\6MO6)n,ԡs;*8 Oi Bz猘e}A An]cdAP{x*^џm0\{ )ҊdqA,ME=l 0t8ʠfE@է9Y>6͘@FKUuho aPS]הTFaMf0 glG|SsNG5[_S!Ky36Ҭ[uk?!YfN.g::># NTSg5Wpei r[7+|ч9p}sIa5_Zg!!`M2w1&B_jrZ+Rvh*G9 g _RPxEPLu M! CDyޔrsvi@/INy33d6.-jM H,1QmamPy!67k|mߒ6k&!X<|Xubm6 kzo]$Mp7ԶBxeoԼ샹iL 껻ef LǕB;:nM+=ڠ]։fDZ1tXEۋ<GA⮲&6)6:sXѿ9pR&6-Kے{1O{P-î=LwWV6SUN&)I:EsJUI2 `&yQu}@m; a\Nq@Pa%Շp9 9ik2``ө\ze i8\ XQv}.mTMd#q۟=Ęੜ84{;yk0 NkN0W.GZU=nOd5y.pCK( VMiOwc,״ %"tSB袙yW`>Ւ (pE1Yx&S=x#`^r{8;4l6 sz[BYߛ&c&q}C ^:NWzZ)B9IPM%V "`8TR>J|ZS0DNvݫX0~]{v,RKH6pIwc.d_s4#GuAݟs p=&_);錵S/k)Zg)X˙<¼d!dՀ_*mp&(}Kori}G7G/JŌ;fs+G6 q;|l)5b?~?+\( UӜȰf^x@@TA_h>Y=%$Zy,^gNgz5XN6Hmմo XM@n c=.ԝ&?s16rduQoOסvxp蜧kpOcΨ#&*_mh8r3ط𤣐Y>_xȣI\J:uaYG)ץsLW_bRX"xa)Rvl7;ȣCPnxg_.X)"[$hfFY[lEʠեßQ|խn7%*GB8ƦٙvBI J QtVߚI*[ IW;gBKLW7jH6߅TdF"7HF7[$&K̮n{J1+b+*/Z &w,p̒)R& WѶPjoP:3ڎ\a d<0J0דnY'Vp(.Tи]HC>S ]PN7]:4=1O68w z&!\xڣc~1[6)I υ oAAN-U*&І("!;O+MpjTL&-$^1#-UrEE(UBCY(MCCD"Q%yGD:']#AhC8FT)$Cݖ'dK*aEc8KQ I4y`nF Vi?1_nb2fTn*5CH+ Vµ,:TWM'h^hDG3Xyp8X|V9d}ҳQq7;+ʣ f/#sm`(sv 4ٍ;v7[d\yky%Fn=ІM>#jU|g%y2uVZbM88< >|+vl0΍*E\>˘iLo١_gJ Ʈ`q߅)s'3GL,myب=yT"WX=0a /|WΛ$\LV;b`s}-2Ugj?7 ;EI~Y{LJkO8{u])@ `k}2$`"YgTxxf>Q@[KO%` ؞Q r6fn 9}&/ϫ~2gr >Ĉdq53]}(/;ak߀,J3 \!<)-*:Uّp>ofZ:ՏX׊nj?̔KQoHfRJ/>?iafP~;,)3y 9ܹy 92GlAM;SuENc%湔v&Mgӭ!횜0.uՃ1OcQw%R$0SUR5@ax|~{ٕ9Hݿ]bp5.nH[M5F6 f\Dш'pv)uh&܎C ƲY$4 [Z`{kN\q*NWA<1`A,^L K \Ec=_caEJT_yЉ04V$(w߉E˜DKjYӌM1VV8G~a2-&ě?흉!lw/(*]5pDJUl"٫(<)FjyDX'(tB4(g.n7К$.ҵN=!-6V /kŝF¡/Z׻{G),lC_kj|!:BLkޠ7sD~ tl_?lƵ :%5ODG4*m^\oH:Nz/} (49De:=RWwڸKi-w -IK6C/0e䛹6.B8Ipka}:;a*F$)\78yU1<̩ -KkZ0~ZX@9Fh8cM>U6A+}LY|myckZAEUNuiUF7&\WPm4qIk]GQk򢸬wiMiǰoL3wr.PYkUڻוVc[ֳ\n,(1-iCxC6K$" 'FpVڼ)q Gj~YVhIo#!cain\Í*z]aP#pIᩞI8 _ˠv9n{ 0-df3c*kyU4p+jt]4=sOnR9hIoA|>`?*(lN8Ͽ3{b Aht)8W6Ci>d&@ 5 F4nHG-.略K})O[kA3 *ӕ#,U"@a Z{3 }nt(JPf d'p`$YP ){2:\+u7^=EijQ}kgY9%[doǝ[WPqZ #p!.5cf< {S2m,!S<˱^՝Yhw%/X֕bתFI>L=;u#+<OV6x.0,)#-d#b ~oC/b^9`>4<1b:F$d(9ȺeM09b4HTX]|܂A^'Aok𒺠}|rhyf~i6!Եa+:t.𾪍2\C(V \AZP#1״wIJ3G=fBaA?vV@?G*sIPJ 'Ÿ&MͮTh mvz8uŁϙRY,}0JD:#f6T":V[CQ%m8Gpm 0dd.Xdo zX‚ :Afɝ:5 f,IUGwbg.|Cou. 8[-9n"C@!8Rt6w iͳX6i-ݛni8 Do" G)oyzFmy.(TihlbWhTsU_)xV}\*Wҋ iD|y)8-4eIQ#ypj 4 ^&GMr>ôX#&TͫA~+8.0=݈KÓcfjN0D͙(?4:S^J  #iqr yh%Y^e 1\Gl냉WH%<}}w~mB 8ס}Q+k%qxo /9*+wlrQZL!AǦLVF0/gF,!(6['jP8&ԙ H)`'/ٗ~ZZMWVy)FCz^BS+QAgmFV LBbAo-^MƠU$ϩ%b_YUb9De#b6 A!H,KlFuϩf gl =ڍ 4W@ %f4MɛyBF:? ֌NE 1;^V 鼴68^i9~!.lւzo}BUl{:-yoA yQG *Sv-Fd{|ZdFTe)2ؐ[X^,cZu+Ǧkラ=׌Gnk8q\n1K: ,OA b:l-#WY:=^è3p7 AA䁓noym~EtZF|1M}<|QZ^4D6cQ EX3aeD"v@2 uL[`HZ3>46wo0꺵˳h@E_ ௕PH*$L,"Zƴ!}'|: 1mۀg)dE?X2KEfr)k8e/Sb !)BBBkt:% G}Ì{7W:9kizEyacc=Ïऻ]t$PXq`f/ruIKbM$*4mEF@/ȊjX6Bnf oȩe(-|8$rF%8YM.' ^3^0<-NV*@]%^p8ċԞkM5,.Pdl{] FZʕ]P̈́}4d_7!  צR.4YVuP50<N[G77}`({s7r\%QAզXjеWK !2hL\ꖷ '~^28Xv_wl1wuvEbt\,L;gԄ=u]sfSfŒ/Pe2֓Bc+XɈV%V&Ò6B䒏Ib0ܨNS z7n (?O귩\i_׊jΜJ[ȕg82$AI  ,q_^3 SA)~`5a N\-_N&BifƲˆ¶<:Ou%M;dk>vMqiԠugք{=r4_‚Mus$59t қkk("|IΙ ~v`@`juH3hQm-9; eFzQn橣fIhL"OUTcgR8ȠJ d\ .Ä$ѶX(0mJ'5<{mxFccWhC*rOo<ZG X=yy==L 5$ D:az&{D,s2;(g PQ1-$1>cikn-\ircҏ&" Hr# &xsO!WdM1Ai 2&&U4,ϥj 5btΊB6~G;@@N wkH2lŦ)b|7&gJF m;>zV*7gmMITl%#J}Z@`'vE٨ʠCzFQHqFRlк‡E<Z+.t",I/E!v؏ ԐI/S n:HxW Lo# NmJߍ30n<KC! f}?s E9^s*<5H}dV9jlG%Qd/et*]i38bLap abS9_y} Ɵ&V/Snk#J}"B|1vI|H&d?t0/UgCbaMwg*+`ϖT#ρxTDWe f?FPco9^e5j7ӵi6Fp7N-?%փ4n߀@fv {_S|%Oe$l^=9(+9M |)Rc3+Iu?•\|ĤEyhDZ9̸&X[B!k| Q[CO/W9`PNh-Bx5x֖Xhٕq1tԪM,qsCW}<쵑^X=*XOq_αt)CY?(KV!|: Wp; φŠTcBƯkh2Udt%.L*d>bKTs$P׬-5jٵINt`?5$tiN v&!ѿ),ps 76 I1&-i1Sw*s;=A~O}횋=.#؄D #…ȷl,hWqPW*5L<}̯L\)1Lw^ [=318 ޶Әa&D{7+[$J?W4fٻ܎SM}wtuOm*-{#Dҷijt6|ܭm{ rڡ1yd^oV@7.9G$BX0p4;I.~Eg'Hd'?R01 $n\<:s5Or-̚r#}d쵼h$$T1hvIL(;v쾭xH6'?mg=c~F @B}W@jqPy`|Pbdq~X˼Q O#Vmm3Αԉ[ i>=KP}(g(uMv 5$X_I.QL3Uo6.}xX àn'Up < Z U)~q /võ jjjj,; zQP+_*0P=ELW_^~͜[(j  FSB%z](}kGh!#ħwdǚbJ^ ErjCxrk|Abszobw>Ġ {ӓB-;YG4+~#r }!ɌPD/?ݴqٻk؍c"v+?̹5&騇]A '.-zn%%PegQ+2a}oJUGRJץ BB$"TnխfU V4 :rlv٨lQ0TPԢ\>_DLC@kgxpύ!ȪXNxASJe7RJ3sna$HR(d>K3 ވN9iE߲`H D|/*`=uL^ 35G}֖\'c')!({ "l Dws)vt=iXlڡ>\q?j!3jU!yPO՚!,_LQ~az$SI{Y.,`4%a !mF,72u#))I*hpiPJ"#?@c..xc! J8rXV.7ka@ p-u/,B;xٷfD}z 5/HԠY0($n%)- ,v%o4 jGiV EJ 5/6oHڭ<7 ͦ/[Vz1:#.ŽkF>m`;ֿahamPベU/>aOSڕ\VaFmW_iy.YRJCbn^f7ߢ`8G_;qSEx2%DȤ6M3 0iF {-`n%q22ү(f\_\l | g{jVDP=RD6VCL}4Lsn#2r%#EOخ:D'–Y2է!&2OQu݄ x$Q!Z+l c4(ru^E tErc@H[y)_1B\oǸÍ}5?O*Hx;|{QR'ALaDٟag|O/Se,BL!_-f -J0xK ̨*0'G$#=AP)퍔 )vcQCJfx]mfA#EA6"bNKrc>&=ep;:~82/tR84ܭzj/.#SX /Q} A2$?4F=勣o]1oVkU?K:|94mt.Fz(Nr0Cmd OhDAe7G9OPt iAnBީx^'\{3fFۣ,pHh;n6 3opMLԘdn4#ViX6r r\#(ĔvEq#s4Ġ7p2}^KR˩fb-##}Թj qޒ5$eFjljR#bC+ O)pV!91C:T.ġ>ʨlڋӤY5-/wagaÉK_6IJ?&Uʌ`?eq .[zu Fh>:::ŃtkuS5U&L؀=\E6 L;֝;ڊ< Z3:Z:^|s<>D6)ss/яІfyTH@ aQ*x& jҸb̧sJn삷#zv*FcZYhefp~r izfբC2A`X&TAm(Jе(k9q3ʔzϦvwddqq2Z-Nߛ#^]:Ƶ~AEyWXht[Ȗ|sSnRߖ)?̚zO1W <vnxd[ Ю]vj'XN? $kdTF3uz Hìx>8E 1m+5/qC*8,T5p=4~i)-n' d(ܶHMDФ]#CL(Mص$0x.o0j)bІa))jSvbü(tB: Z|{7:J|lyeލn6ehʙk$ۨCĆ>U;4IG`y*< STJ麃}%V#c()͝?Rt\9f};w:Fq~#b<==f4pA:{Ql7- N}߱}\®~W$Dǎ[S1^ ʓ8¡Cȧ&0W/| 8zSw%ScaV$66*Hr If(_NJa_)l0h&rF~Fgp%ʹKck.NPnW,MmP'd/D߆mjώle ňZ~vL㲟`c+Yst)R~R#_nUzږb-(t]rYPM(D239uvɺ\'|Zdr! Atzܱw E㔬q̖=y7w qvK37: J+r2 e( dZa ly}d}87%%Wt@蜽2Чٶ&Ϯ]6QLSM|Ěϙ0[ݧvԚ1an 7 6 bꫪ}XZ0y]sO~j5xwQ1dOd3je /AB(5$2ۙ$qSFj ]Q I+ދn_P"faH%=>\x?C?Ohwu8[q.K]\qm! nÎӝC{[bLL0}G_pyJt+d~ ʺІŤd.D"2Uf5_q)/w/E&⥉5|9Ɏ_d, &QU-"M~"7GrdId+.rC,ҥe] Q.CbYUơDmTOF:C\?ubf 0^{SgSnxz P(6TB2 vwp FN2/帣y8JC05'{!rV{~SѦ_hx4 qkƤ0)GL'&>Dk| Ab b" W˫X!>s .ה bx&pn$n1^=`%DbW@|~d&Xݳo> \wB( ZHZOArUv+Hy`OHT.Yln)On|WKb}LMj9GoQJ?#_9QIff}X]jsAq\wFˋk9)p[#0:ԤbqIQbw,֕ ܟ`T#q?zTĿuی+IO-a)a2,+kB4\VT١ Ѓd:-99u}E-+M?֧o&m䷺Z^iVCxvAI Fq8OF;܋l{GQ;<ݩ7cbYXrN^F΃^0J33wa}q7ygчP͏ b<Β~^ݾA?1I+?{Di/ *5`w*Ş?=@sdY :B͑ν4/A]4:RbA7<w0\_z(ҌX7͞Rt!vA OuTNQ 9VmڻPʐ>PVx'ƛ~;xjVGl7J$)B>e[uRoX\/tcdI_>eWo+^쏯^xs J! wVeܬĪЎ  y 3q NDuJs \죚(x% .kΔԯp_qHYDw8;F 9یw)zzzMJ-ja 9%6<__hJٗ fa{^L$jUH 3\hʑ%!Yliko2De$5ކ:z"*7pZB d`rUp5ܳ:7go)BLe3&OBXl|Ks3v %RfҳMK݅ɓ:&PDGpHdJBuu?Ks/~|F^W0]&M2߄KUh>ڠótp,{1]wk;}no,lJomjHxcS!Q%ft1Uo?< S( r OUǑXC/ d4#*MK?WC]lpsXѕYg؜FmF@H)r-¬i$x9s׎}(q'u 7 rX_u,VRL%ڎ 6K aP%ciNyIgEz0ӼdƜ L)lI6`o+ svGʒւ'%Y6{gN,$Eis扠H ej( $> C"H)7%6|hk[j?7ՊP|*|:Um{k<*Ɨfʏ;>xGsy?xUVXU_byEyNCEĔT) `M]UazA !9?\duMp|g"(l*|-љ{Řռ ,\K$"lp S]ϷBJxt~&ҲOŀ;f=ꩯTmQtKr>Dޙ\auX/'FK+o5>5GJ{ƈ@Kt7-zԦfŪ:bTF16! |?0LMGu^Ձ** 8$ib3VEr-*7mޡUd}+Qo#t QpDq=crfk[c:ލ Fg/ +H pD$\ U7/L^Vz ?HфF%@\3]38yڝn"r#g)gIu$sφ-D6U) `.qW> 7O~awq[0Y ajU۹hkkLeٱ@\4zsDzO0ȯC|AS]aW({H뱑&Åh?Eb}be/MS}_Iљ :$["i,|gQ|#PRӰF:YE+gC E;5:ڐ[VKI3)>nHp:y"J_;}F6}ʑ^@=11WY5. '^qkC|tF2ZטًR,Žds<sP[ճ\r€Zm,~x9;.) >?Jrp,"6b Mߙ#$ IUj 2)ً6;P$|s.H(FXΙ݅N\'ih pNG81M0Ǯqe3p1D1ZF23UԵ\N%dgD-p$>c )31f{}XruhWX:sF&g/ՃsBZ_5p<$WlHbgjnв/X|sV%+X>ь&ƃv"UUQk{= fJaGP pBpkH 85Wxm|o%6ps;fd1chֽI <d~_MŔjUrK61Ϡ_Ç1NkԕK& (MC,sGٿS&Au'D4|1[PlW:P4$@ +Y غ&<ELzu/BCu}Q5d4# 8XL]. \{B=BiM2wh|R?` }=:FPv eY>3 l/Y Ćbl܎I,U/:.Vk3떴C/q,pyߜEg1M@@&E2`و˴ok<\^GNX~hj/ #rK֮o;}/nCzou jg)N稳?Tn"= O@-;`Z\qt=PtfFs\5lT8ޯh-GOzMLsj Lb~>J"ӑ5蛪FS" 6?R9xxIh]_ƒOIB3 oLN78Ao.%++H6㜦p  ?FO怆ׯW8:k볪2yv8pȟoe;aVXJp1u/k)2}%A[-]6*>ȝȻe^0FD%5Ky*Wnmq"2`3klY^b \ lfUo6~{r0|TFHEtdvdrA:YE$.X(0x@I¹-f_жͅ͵8nO&az}9g ijxLxl6Ng扡0"/ۗzu ,o@]q$#R'_\^{!a'RI;|8$)9쉧k 8vjy-rgԺUEKIV@=saN7(c76/>;@$o(/B I~픚 w>eC1Nv[elBU0Se)  a/܎ SˀEX+"*]Zz+!ª*Sh!Ħg:L]35j_lYvRB#؍&[',#94!_ MKe=q^  1lOq9SajgUùɰ_[/QʔY@X.SOR#FIDHDw,gYYb0V"W &9M>')~$qGA鈴dGBUX[$0FJ7 60 GZhGUJ<-Qm)jۆRWڜ$BDWuur&@\ sB^]jM5O7z&p;UAKV_z &ZݴHr뵾o= H]1d>kȔ([zJK,{ڧ/F~>"zDވR~4u;_ !bM/CLؼ@wVv63ƇF)# ڰm _ϛ *XB8=l.MG EZl m4=`Rm5~aRigC|JQNMϯ_ZjcjkRLrq ekѹt"24(>-]`r𶠲o^x̥d~66F\o֍t#H  ;y{ K澴MGW,p.wW3n 3Gx-ng?Cѐi23=֦ϐ㳄=Qd;PӴmhN!q uxTd" oW_)9Y+d %H ODrMX` NϘI23.6.;蚄k{nmvW#t>xc'T+TY|+pA> Dr$ٶS |ˆ q|7rD,~0:Dmr4|1RIxcfQxX'i0$Lh ōV72`Ytt֬tY%Tt21<|;>庹ª0!I\-N ]VHcwˡ/CCp{EG-=d]-C1^(֩$*>l&A![l( L:~6\Y0tw~E'Ф^#% :6 ժ\+lG>N밢!%3̀. EnޗPa(DYޘ,vx|?jlי@zR)ɩމ=}@gRoS~}YB3ݗVM3Sz<' ;A͜lv(j}B|ޭO Br* ڧM^?2L|>"39%"Q_=uWA=7[ճzaVCa~ZJ4OXꦒqZx`hH캤G}0ȌȊPL1+SZ悏3ӱmP諩q?d:Zg)-pڐ>UGϕ1rE~2^HA&'[:a5@iE|Bc=ekLw*|Uo/#J,>SyMutIJZٝfB/`{U[_)MWrtOABCpHC~;bp %cAۦC=rߦ qZ |*#%8%Kq I!m7暺'Cm~鮂t9fu QG]YbcUuq) 8$i'E s+ݘD_)Ϊ9f3'Ve7r$(-W:!A\'N>ƌRY u<9Jh}}kbVFK&Ղ8ȑ$I->dض?Tuhʧ'Xpd{yjiCRc.bQkii2ֶi/ؽL)U:m65n "@W,4zmwIePPTsm襧8u?囤;ĺ쫗 [oK^N[Ck9m<3U%C726>\b0*9D⃑eS߲Wy qu ,VR>DzN=t<'v8E!ҽ䱷<Еx 'uKY2U;|W}"Ux\-:BlꞮ =@ښ wT9=K8%ͷr%e\%zWV?dޝ` ~BxۢM^LZf l-KiW ܀ a|e׼|݈L]SK7OUZP{㠹&^\IըM (6!Zݳ\k%:=?s dw#)?ylآ6-)ݿ>mC>+çًԫy^r1QBB^{#D5YfgMW>%OYH0oHg@)UmjE$InD|涔q<Xg>1R?.л`JКgv*t:R _C; I&%ds@e _to~DqnP$FpIq>lzAH2AiVKϽQ(Dmg2N]LPVKxp97Vx7i/iޣ6A%U6]` `V  x =VtԳ_G 7$Pq[CSvT{J%ZR_#yƒ (6Cyh,>?K}ɡ\K:]-'%ߊqEs"1~CZځ.!7J^i*%ٽ}IԹP=[R#!+i :wwG1 8@}< p*Y2}r EĆXYZg`Hd $m~Z,ƏbQl< L)Nʧ $ICǀ>>!/wyq:ytV%VTMo ӻ`PiE˹7z:+1%Ω}Oм3P@q[QacvTɣ|8P´2@P#B5axd-ϠyͬwZӭmNTՓ!_, <Þv> @w DBF׆@6,.2m#Xj:/Yu eT$&' FC\ ؼ'''S K:DB{3U#ы&4$lx}Zvq];J=<GNǓ-;g"gU-U>AW+O*>{ 4N-aF"{+ՔALj<_5W=hN؄_U4.'pĭd>TR:+`UtKsIe{{|Zw(:lzm]HfL˯v3* :X/D6RL}̯Ե?ʽ9ʦXUjDTD5O`u:a'sTE`k[Ȅ@fΌT!jnثҮPӫ*bb[R/UwJBY\ 6G wGp;C2~c0 e`v֞mpL HS(T&Uiq(W+p0Ö-nVB5]ۃ/W}<θJ='GyeFً(Qk8dK^ -bb98I׃\VZ24'i[⼙>Y};S=,ꌉ+HDmD 02Y]"cV>'OU ̦sg(u=g؄pTDmn)B(!rP7i}.,|V$Ɣa;'Ew0 M::E;3j M]ӎ7DPqZp"עƼfp1l7Udi8SٮoC;.{R|4 )0`+b/4R D伊,o4V wlZː{#߉Ls;& 3Qpuٝ,M}F$a-v26Hf܆3e+ {wex)(9c tE|&A_NGMP DòI_d-*iIH9\{1n_A}EƃcEW0ЮOpz_q Ŗ# 10wYgф'=d'O:021ZMFD<*U80k}  hx 2jPݫ=|b5$^NyELpįE/=uPfXRr"'.$/UW~whmϢX 5*pY܊H^~~:o6bwnqߊJ{I>i~@ilm>\tj~BOg!+ᵠ_OǨA]ĒQ?$9Pxh.Zj’Asdp*nd x[BZO"#-6QE ݉>RM#~sn?EhtlԺE'4RSuF`e 6rZ)' ?C뻂|j#:(J;(̰eYvf?hvlk Ӊ+ ITAńMV0ײw x# ݦj{N~C?1Ռ='Nd#ˊP6r-?{.TAi!ʚ?(Z h , K<}Wlzg>BV(AmT\\* +P7=e4sl7ybn  t@?I$] x2+G_3d~Ƹ g-ݽ^1Ǧ4*2UuOMk_Y? lsRܥ[#v$y1 .F%I%YܔKGW8.0k1ZO6e Ԙ@.q8~0% Fy83ܖ_4yJ@Lȿlm=|VifUo2{[0*:?;:ہ a"9>5CI'=`B]'3w{$ |  dsUS]BjE㎌Z!Tw=Ѝ_R7ѳċ/p}N@<]DL,޺VW9n,"~B XM7JcH6KoS<$H?S SNRQ!Ƭm,s2Ai17"M`+Qc$j(H; Щ=-(!AȄ2f>RFxV1d#CPՆR>՛@hy_o^}ؖi2VѕW$Z{ 6u} o xdVIB\Dt}uP`>/uJ^c\)}4q<[)˿}0`O_dJ" ="js9ߤtM}v6*eYCF~}wКs>Pl{2 2lGzhbe)PAr`z M=%(\EP]  I,C}cS*4~}ɱLNJq%9%YG9epF=|s~Ą^;'S  5*D/" ;!릩G0yD.k L@ CW9eTAd\V]1L2cEq ԫEM:E@~1~KIaro%<҆U :V<O1d 'MHfL<.;c۾m&palp|Կg`\ >d(0tF~ $,»ajFg /VIuw0*cbPgpB?RL虴3/IЧZYXwނwȇ>xD^tv1.0]ax5 VPs"BV=Ǧ C_3;G fZ6/}Hmk.ᚴvtItm-gl*ݢo&맇)kDࣈ/ZMHg^T|WE^v<<)%<`Ggzc`:iu#A@ͦ=W厩]=T`Oh϶eY"u >6Mo4Ќ}tsؤ$LikV ʄȮ:CzexO_UnEt]=7 g2X[bݫh]"]ɺbXڲ5.0n9.K#Jx~i^&X#`}_?Q0'+oTuR=sFl9^y?KaBV dEIjM,} 2M(k/~3i_wV9 c#P;tj93J8u"wМgG~r.,IVg)1lcE*Qf0OC`OxX!72߲2=eK(i"?K;!E)&S^gڈǰh0A/*_Zݲ3dgk\2(\> @ֲS[N|+j~*NyZqKe( hǹXP,Z}b8qIRSTx՚JCŗS4%uNoE<@05W`m'FuyI3N͌EuXp dE&ahۮR1SܥigB'1rV:`` b.WWͥR&z)Hq޾‹Fsw19-%ƕET'_Ym =dA$iTNDI u+K6$?9[f%H5Bhør+-[w-J 371oq,}8cbc쥛l:fgpIx-߇F"TI/ }sϘMјA{ʵ,ҭ c#<L""۟wl=4+NF̃ZIm1>Dͷ`rV=!;Za9!]Sֻ:<W8@^MIEs59N&[{6'u&ȕz j j[ä{ʴJ*mKm)׺.\59;dž] **u]%+X KZoy2"k Ҟ:{SV]lCQ?^?7 ʼmJ*_e09)1 tZ j(uXpEL-vQRF,zbzz))B64`@ #Q]#]N y1 4[l%nV2otJ |.1˄{%z̟4%E~9JtudO|WrfK?m:r9p#x& RO+ z*٣V[פKeXɂյ6'@/}靛MxEa7)FExck@a2$3I[oOEr=d,x\ZG:LA}̀nk~SIs'*H 05Œ8ۂDzxhFl}[NYR^a?k&hZ5DЕ~8oKv!޶ AT^Y v9ϲHH @R9&]Cjğqxp{CARGmٟFB.=fR wϱH|$FXD׆>5RUBw~Qvl +U%U?R)Uaul73qkOq66O}>iuoXs_0zs4&&*V'R(%,6 } tm d_53{'XBTJ=X4q: c]jwٛ}tbe#^rlj6p埫zl !->`R<7хCV_ EK}&p%\#n̉p2X47%mqc32y1,t_0MҠMp=]^Թ-Lg[0E'okj%(W]$wHEzAb<HOǺrP4'A}:톑&YFƝy3lJ0kKMWWszWKH^;C͜K^͛qpY$F cN6y&JȱQFdA>q3MF|{Y!XN@BtF1R}<NSN6_qS6,G`,AF0RElmow⚸OU6GO$rq@z`>!ϚqX)2arҽqM@?0!q ,-b˘" P8xְYZJZ rsv+)VMH6e3PFG>%gݫw>@濊.Z#p#[(Z~EB JmQ/ d\kMz^Nbiܣk4zmVUKM*;T'+/;wF\ s괙VP/E7V›)}+>q﹄'%T܆s%#'+ Yl2!ᎊU-\f;d:q5uEׯjM0g!]Q%st! bc>!Z$>3,YL2y$iR|ӑt^8 [V#JsX%$[eh$5&!*9,.dDez a6Կ ]$dXfUh>_hXwFM[dRVtJ ~IZӀXYS0ʇDE't, "<4?!/0_fHTO,QpI'۠nd⼀49-?N|7Pۢ/β ,\F'n:v $VDPmG$Pm2_fM%Ѱc7gBj< BKW UfSU0eD El/ _AQyz;.cWF8A% ΎY\O0R͞U*Em5䜽Դ:1/6+0IeI7:LԬ#r5= tF6ôk6_vYA" >PDF$Lo@U[26NVFYbuƞVw@Nu'EbH!_} U5૳:@[@|RstׁwRP.jk =^S~R@!)_+stn1)_j'Qb_BJhӬ<0 36whG<ߕC p8LMcd$&l5+ڑk*])\4 kD絆O-Eh@NNzس>M K%jb(%u ?$WF0:ӺW-J,GSR?GSHwoT#~kw2'g[(MU\𬤚CQs_r|YX)OÆx|Rꆔk[FE%)R^C3IKC&^}=Rk<*`H΅kH짓Lw$Hf}2-4i.y8 b;q@T@VZTcV6+[_lq?lGӶ%sCqZ3Gp N+}u\`Jɴ@ VY;, )F8̲GW}C4q L- yҒO亓OxW|#tZJrxSi/ CWt-,\{h@g؜dO.FOlu-) ],, h:W{ J?a,40v{b&]1;Oif ? E 9%",?ݢ0C4Fϸ#~}eA}+?~M hhn:huo";XaP~!2%OK]=PɩsWLz|*i%3Vc!:Z0>JZ{qMy4;S; TPJ"6[+ǯ6ހN-N(-9fROExˁN򺄄[{ )G 6 FGSTIJ(H[6.GT"߱V3y9)tZz4/Y/U 'ߒZ:u'y}WJ'T_ЮzR vyFBUԽz.Rz>UPQRC? "+fQ/&&H߽bKk {[Tx D1-nFMW'܇ Y.up8jtUMcFDFH R 1.r9|.`G}󙺟9a~>iSiu5 ?=>5CC (9?ϩx7-9Rsy˛fA&c*;C! Zv(%w*߬ lǥP{Nji0ߺIPvP$P(mΫM+煘6!a;?f䇕50թClلh5C띏_>-.*(SR8M%<#5k_e8նk=Mмlʬ+iTP5pt - ZPb}K+A1#ːi(K`!1AQ=$Bw~|n>5רP_4dYaZ :?gqI!jZ=˼k|5jQ$33[I`O K7rlO2z.1\7sS#r&c0[3gI/$MdpZƔQKhZ*\C"mĽx#țleyK&T"8u(ߧõ RHF`PZiA _\{d@9`KOϞ.lFoe sq C@*cl?(բ/J&" <)ٞ=-͘N7[M1!pek =)5|qk:t=`XcZ*)GJّhA'6X̞z 5rg[D i8!U0㋳>;Ovk2Vu8P%% 迏W ۩hk-{Y,SR'";yw@a/`bL&tQǠy!WJe/'@&͓nۏ{:jSC, ї(.57Tė6IYwx]\k)M4gސ6ߊ2 j3Zpcw<ӣ^ g٣͆BA!Drգi?t1 N%68W5fiSGD 1nC{ DtXYC긇°uP2۬j2Ȃhq};RU9N6Z J%%慎;:H~e@rF8{m61fލ).8 uFdgYFb-*Θ@_Ucy`:A~]WLg}n|cSDa[W4w#+f\j̟N~)-aֳSZgD1}X&`(</bd)G MC?P,T}*8Me)+bf)Z6֠ǥු NBq_8˟11>  [o.E `6eR'ۍauZ. h UOI 'I4ëgѾ:Jj[ h$u ;8;ksnt!9,{E"~Zm-s%ۼSx9Tj!iKxaaTA&XhØQV(em] +}bXtS)`UZrl R[\Rt`V:yX*7H?ۢé^PąqdS%3IK寂 δF 6?lyuͱ:V $ zƺDgLt!79臞hajZpRTE1'!23ʾ]$զo]b> ,)rPт.ij#ЇVqiAScCDWrLaIw rdERF:JV&KZ=vq ϩ[Y!oM{ޠxԤLG(WG[k\ley֎*2pƖ5cO )˝$O_*Sx2?F`U3XWI xb63Qd ' r҃3YSѶPw7mocwT8v6 9B ؃YXHcC PPJ|Th͹0 >[>-&[Q[v\STpK!;)?gaU +<'[F>Ao\7a/<9ӧdY%8 +Y' $-W^s]WTxte?:I6|RI G,1[y|^>)iH{yF6?hĹi0u:w?VO*c3N/oCtJs5l'i6V;,"ّJ"B:DX?k3J;ľ^ٜlD0}4zq3uRUM"^qC7Ϋ |AFZ:q%q8Z5"-x DZ]ȣsV?, \f^T!w@='C_J "O!4v^Y!-.M mg`i~~NDg]+}W3F"BHj.1~V`.tx[9׈}ׁy4v\ -kfjh]ef)Rv$DlQU]:E EKڤB2ZgngFl@6nf-C?HK -ԕѳ Ehx2 JQ_GP7#֮(N\\ %pٱ]7b5 sڒ_tA_<'Z4Ϊm,m`z.'ɞ-+ I {ci=C]Lckɸj0z. W=vJ<]I`Bu))]g+s8liPs*vj>"Ma\mI8sZLfBU+9cxz đRBcIB|)G BP=:am?*@M-ryG{ԣL0^l-uJ} õ/ 1uGPIvo=@j1<= Y$v5nGswэ1y:Ek"V{1m Npfjv!KU?l/s 6 FkH1m5W;u,-N^^+Wio/]`Em xA"ϳ_!QmIiK1e (yˡ,? ,4Sӊ-$\D8#UjlM,zЎ0 r Y 7C_0PE#殃h!ΗXRKVB(uxl M!glg 8xM{4XKVНd=aonU;8ޭ0(q'Vن-*!YfeH:R4ÎjFf!QtmFLKrz`I%"f ƪW $^!j}IY,lm"pŶxsf'[[Qhh2O!rW j"ͺJWğ)Khgˠp7WM {·SLwIܮXހ]DoY@*\c?nXʓyXOԹ [4qk Sd(PB2Q7(<7 z_`]4N41DVs#+E&!8%AMvb\C+KE!ʽh?E;~1ZX쐕Op'.pزJOys~le/ m%nk!bmLpq̞GbvYdusz]| Mj"P~ xvխ5cSX%ܽπta0i+^xp['^ $LۘR: ]@ߕM "&xd`tBC}4۶w/Hh@E$J#>Ҹ"y9.mQQ,~b0>m)) O5bxN{_MN€_Y`)MC>7Qm >'nTMGh"Q<(^t6ܻ_h]fWw{|T(m!rq`b~r[cJEj;,)->b,wY`2l;:ewռʻxW[gwpZ+wSCWVpI:"ߝ4MLdgA} *' fuvT;} 9PXLl>`@>v,B4n0XPӻ7=8Dml LiO z QA•`2BuAz xrHx~mt0t|IgSq JPpqS"b Y$):W5Q58I[6Z>2MHrjR`g"D5``J%Z W¢ ]i!2efwGp}jG'}:(.3BMyyk}_2B>8ko:vi%qECʿX8~Q]#U$a!ޓj7PJp{aF͕yJo մ3:k4Gw2TfSdtg]T9 4XH7[ ߁'߫FhEZk]ЬB|[:{ظrTUZO_9R-4&dM7Й>7(j{!{<UpԤ q]6>>nec@oC1۬b3.%TĨ0S sRTAE^NVMof᭽O6(nNBԪGvԑo|E#pQy5*>Ocja?=`f~*0bN\C~un *Y'rCK{PhX2HpOE6Ltξ\H4c̮Fp/!6d1 +78Tv߶Z usz$Lh2 anjyO-uq9(30_HɤC}q¥f"cod쬕QS&PY@ _1q1ra%}>SVVC3^x! ZB T.˻,$b Qگ1%\sO3H}{XxJZ҇,`<nRwǚ])WFj1JL+z{S'ଜ;F?( Ī L|=}ζ'(=AQ;0KJ5.67[* 6vmNE9 G'0w*BpPo2̢tH\+C4{ͅ8|6ǻ}ܫʇbѿ9uo.WxZh2mDVG-*w)IT1}:b>bd9{?Eg2<%5C`PfD cŦT{>Lƣ]%ȷ&3$rH~>6{e%1@mٝ{Wj3Mobٗ1&*\ե#2U}y csYPSU[\) O!8ƻ%!K.5jZR(3LՑj;9۠2Kӑ=>AD5IH%Sr+b$~<7*gҔ,\ƩbIy pz1L`BԹ[EJ=wI؇8 Cیq7ǥA`1㏮ A:I/ 9kInk9 "\X8^)Jr@d$(zHB%*:ЋQgW -I5(ᬀaD58yKRAӿv5TP3MXPu)c`CINzҩmTpٛղoʍg]0;uYBbvG/#5iwUθOœG7hbkdzk&lf)m>3ǚrրQk=魈1kU$+1w[) |/v@fiPH~vҊ^=wEŝFh^0E;5~MRˣ f zx`|OvKA,`GYAsQUۼH8z^ q,~LOݒ HTJQTp-Ecv];8OJiS=hV|``?ۏ*gnЂ0\7*o~_ҙط!9$ۍdvޏ-]*,V@,By*> zBT΍A^N RG_Y72p0]'Vr'@2'&@TP%Ʒ{)IgygxWOqN {δ{뤼Eֺ}$B!WOɩTaqt Vݱ@G^,^TM=MjSўa: { {BѶ Qy">DxαKѤ"/b0-UbضCgn1uԄ'kUܲXp0Nod7S)=KtqB刵ZZ(Uk|^fcV`Hn`>: [ 7櫪 *Q 7$0JUU llo6JQv C~֦ /Q} nڢ˜!0%`ۄdb Ja!$ev= ۯxkfnjBAB_ͣ*V{FAV Fڂ_<;wrcB˜h'vğCn5Vʂ 5lqGW̍FBRὉ8Җ9SH*Als^J; g8ᥪ_!Ih%|ʈR ܎ ,E;=yw9Wܳǭ]'pųW{%ls{1UW 9 ª=¸6[jqgQjJBʤ?h-sTl/C <ڻ >vq<({k6+5~czzs_҄\(Ke_PVסk'l[I,098 yXXrc>7c` ӿb6n(Y6N<$V[隄/y_qP({c>y"3敞2;1 [ #݇U>mA1z諜WnH|ͅoSe8>6ۗo _;&ObӒLQj0 WxobFm"" qNjҠ#E2'a|Nk!L0ͅv%ĝ`z`Ϊ=fT=5X<aY[[S"ӎ>=G!ޙ w#ƈiLDwG)> uB=.OI6}1]LheNLve|N&ubm<hp'sr};!T St\BjdUNJCduIѫc4RQ=R-A;'s7@?73bWm62:b0drCגpmT #ś8lN}+xȞYu퇗sh^}R\EPAj~a\v;oj - #h"G[6mk]snyd2aKŕ\}k,W'J9&ޚҜѢx4s,DCM>XsC s=n[JBHBr5L3 oiU'V)M}rڀ?EiQ IEUF$bUpz| a>uTbnjF"ۑc("Ʊ&0nJtN*Du6pwc2㧬jW|Xwq^ B?>cv |Eb.G*^V}[96w MnC{0ĵ.أ tC=@2o`5޵:ЧzY~ p\ǐ0\F&v#:L;*]烗j֗6e^r΃$K:/% Uf0UJ|SgL'8~? zS~FnS3_^、ސo~S@@ɨ$hl?z $Ϟ@{=ƍ ~u+waU$QvD(` %¶U}uAs―rM DKDSxWi*Ɏ>?R|~70U^wHڲF^8yCCXFi7d)͋0rZTIɤ5\eJwka '1jMC $DBO'o?l'B~c.'e\1(Ic199Ļ;oᙴllp)_Amt>< 6ۼQis^x5{^si7 av{ɒƌZIO5y?/E{٢G.xu ڨO,)i̷߉Ilh.1пAjՒw~JQQfG?)P$1+?&b)GtY%`dޘ*E52ya[* ~m$]:C8Clzc#gzJ*/~/wxKb*N7FūS7=Cim-2z[VFNHyZ7:Rq&or3ւt6 xvCKbOA㘫Ҷ3qL^Tcei"+Q O\k?(,XEuc~bG&4 271#ejpV6dPD!"7L<\3 ރ_hUilNdUBmY I=Ѳ~LI7Pbգg`9DAWN` >}D~lzesE=Wgj6. HӖLhtv֞,.ю1iAÎt]r$P6m\Xq n]|^ظJN\a3"\@lŒS5h],KVח!2<ϖ-Y6teaSJ+T='uڪwܕ{!ոK$TX}&:blj1ŮkؤDzP.*8'ŐY|uCSh&00kVvsl2saDo!7 ѣ'fjʺGdgv&F$?{r6&߈uQ 0=0~1Xٱ ROȗ[5esV6Vf?dit^pCZ?lOtB'POpK.M N:Cq(1iwu4eu8AaJTYA^K։m/Ͽ@ΨhJnRWA^nJJO'Ƃpݦxo+_VG=qٟV_Ɯ{1H9SK' bo fBAiSbQʁaaW1ٝh> GH"Mp!׵ -rFpS p0ў.1 ß^:yKp &&4˕ݴK[+ƬDrErN .`l }貉[f2YNI^@r:NBo./cA) U o{è^%g-F k'#'M&Cq@-Tsx+5#kx{RGλa5\g~{H%,p\kOqZe3G&Gx{&C7 Rm/ϴ+!"/GAuxKvXڕ,.mVտB`5(hJWkQ2uתyl= x!˽gK@hM~3C0S95)+}χPXʻm*C5~5Pu&|?߹]nXt.dT+ifa@:ùA*!=) N/XPyAguBq0bzX/P(7l+շ&>Ff%g,+nvK!谇Ю<@vD!9/ {'5[1Fͥ!롢"Q\X2KIK%R"! A'yr@ײZ]ƃJ('rG{WU9(ى! 8j=Qpޞr1M|dzv.㠹.T7iFF0"lV:Rü6~4L}{; Ḥ-V3Q!uv;܊ꉘbW\84-Sۈ4 $f,mY`` ^(|6hF3GYEul2Chz(]4ۅu.);0U XK@##Ԉð=XkygCYMHGֶwc*QG Cq,^9J]x>2(H%z1p@|ј$ec˜@jhw&a))%{'V+K(j ĞNQ&4˲ $fߔ! Iv{ )؈ rl2{_ND),M FB@/C_n7HCs ENgaiê٩2gy _ROe_ {7i%IgqvT8S#*|IՌ!;}yV;mއй Bзao)>jj7. Qg@ ,\Ĭx^&ֱ*;4*عd;\\/<9j?ŐJJ=ES:v01yՀ89CF#" .q8RC):(ąCPm-ie#$q 5٠.՜HL9b .I+]us\K9GzԎivZ/? jjO3hˤ)Y+_ol]􄊪8P3nyayLòb?;6bT| CfDˍ9YS`9[5y% v u:݂ÊkB-n)_^'nFo~!!Ӷe 2Eub 8UZkbGW<r*~}2|6_-E lVxS#K,/2/QfO VruU,|2NijֵZ2yi  2&@wkf>vxj&:-M׺w@Ap|ZQ>-M yeaCkvjnЀeX–AbBBHD9-nHeJ\}]֨ۗPTGvs "K%E)8W8 LbT|iyqmU,O :HXl2V66tͣ _EM 'krmqey㬽5%xSWB߿)zX eUM$C'KqTsjw$bܵJKbegJ*D1ub!? ߝ<ʽX"бiN)츹t;50 [|Sf?Z~dWYO=usNa޾B%jABe#wPF!lϪ+~ӦT :hw]ˁr2EӒ= "? $j'3Wfvv񲼻?ܻm ڋ[3w7]3mY+o Ԕ-ǯO7ۉ"6y:+#mE)/|mw@(viEn'H79ኒ ko7JIx)=H-I,jZw5޳ﭷ9p+7Ji;5΀n R>;O^0S ]v}zpKH06юmQԋgVFNuQ*,S_C 'V hznТFK69+n'BJ/NWGo_|'9@VvcșqTC.s1+f> y} ?e+qn~ؒLw$r,u֤z 9,jRNi3^mO#]8&gW2'."L z~DQzjȵ /s 4eg}\dV_$ttdF㣈A3wp[hP A\pvcb/(hP, bH9$he3-vգ/G/ncpb$A>芜4xr'FqBօ盳+zs($oЗ5AS]%_ch,/&c[0 H/r$iNaQf0a8HG8۴)3 Ռ*W#]691KQO#@{0)>&)8WOӆ ~@(7蔴rm&:A!+).8!iT"/C}*hs+u U}r̙6biʋ.WOeOY*RHRɲO7Ckj1xvGnèb&׌~ԜoUB%EdLb81{~*_= NBBk7Z,]i{(Zԃ0#`+b5Ub)5PPdPzxam_A`s]|#;66mcuSѴJhZ۽fJ ]NC WGj34-c? 4o'D yr-NCB׳0'mѹGHLm/72"@Q>#8ߤ["S#F̧XFA d^Fyk0=;*:V!N BË1ɜ6ɫ?[qNVyGp?(bMa7P,("jP885 IFMN>2-cf V+V2ṯ2BԄQ;Zڐp%ԛMmg'=ZvJzJfbCq?ne[?.]?zw ¬oZT6jH<6 ')AL],_!]"n}k|@e IL;1z[0oO#HI4/ D7JS!ֻj*FŠ:7^]<axw+,ikB)CL_wbEoζ0)aϲX}CiJ2NY[0>\JŜPxcBHf/FozA pLn7ں'1}ٜ^^;9f4˽Fz)\x)۶\;pZpreD2.ӒӈR0~/)~9( UoW)rܐ>ohV!k^ VG#0T$ 7"rjO&k⛆};N8o KЊW qՊvVi&PGwFx6H3$iBIiW6 ${2a,s VӤ.!Qp Tl4FdCˬ=Ab(Sߖj;)CljзlA##Q!|0p| GsJuG|4Y]\E.<1ogg84 {Nӡ&ёgh]XF=f&8NËr-ީ)BmHåʳ%Fx|hVLrtп4Ɍ1|NKYYst(h[DᴁVYz3? +!VLhOc ~ O&3@`tzOU%2>V3,ӂ25X-4 Ǟ]1>mbB!4(ACnT#(%m<(le]*q +bXY2h*]#V -dcpTl)-ҝxQW81`XTk"ڊW)1k7 ٞa YZ