python3-firewall-1.3.4-150600.13.3.1<>,php9|& ) ]A?IEy^~#4=s OnV!uUxc0eO68·W[QjPq-ΎW˰,g mOzuZRVw*&$*Y/W,پUQh'tQ?Lf-]34lJ5S@taM6"MWjO\ ,vo`lYք++ގr5'9ie FhSp䰁GnM{kF >>?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%a h%#9LH6}n Ty[n7 rR}6Nw.Fz$|5%iW`|T,oܜK1B<2VΙfc$'B,uJ+N)& [>Lf汭ew0-f3hJ7q-`vI1طXCw_i˽ȥ&EҐNq9 OhǛc H'kW!!HI z\D@X&;|VA)  ✀[D|Ǩe}N6:F!_4vpw503;/3iJݜ)z  8ꂂi|^,nb1ZV }߽'ׁ] H+ӍU!RkPЫ ήؿ)\@x'V fQQ'Եm|=Kmw`UhK|-^<T=ΕlϹ1?() I A#g<WwHUo9HY3=7P$R&~hǒ깒f|lQ )ژ`nF&*N9WM -yOUTa:_C/dxSeTquLD"~AN.[;sE$ѵT!ہ,.o;˅L[ z9T&5 Ir\\._٬؉jX33[,֪mǟxQ~5{SxnugX㸾%DRhQ4:58i`F M6 H&Q-QX6T )kɻ|!?rlW}dY"|qU%oXȸ@?(eQ2ƋYp~xzndE`:DO\[,ml(/:bܠ(W C-96-\+%k3: 1@t/L:ԟϕ6V<I3W.c&ߗORvTtTrhaKT3|cUs;B? 4CA ȓ Fth@q\#EN6&f^_S:Jv҅x}DቂͭRL@88[UJ63?/ր5^W̩V0q8C 6$K]>đB44-"±w@`)jKT|QSUq`*U* v>@x!B4%Ld5`!gq}J?z9L:_ȣmP}E' _E$`zՏ +IJ|塔; Tg߱\23SE`1̽cNHܕ?bkmtvRxc W5QjMSU%d)*4yrwti%yjrYk/",54B7A2qyGjj;Xʰ03mؒ̇Poܵ?+)-PuS"ߣBd#(KlAhȆZYkZo6oh#U/a'nj.(bhD-r4ȷ`">E\\NCոܐO=RZ@ Gj|V%7 +ONɄ8ȟhVOObV.U > hŝ@Y얱J1y9/*c[#H2/yⰋ-B;wQYΨXk+qqXV` %>t"]:L? }ک HZ){&6ꮥ2%gW& tU.NWr5ۃM2S {`N̈́.,6hMib,xD?G!̈́bv5Ü[Ix?K0ʣ|5CK ^9EuHo5$zBLw?y208ݰkjt[_@#j;Ij@l$P>HHY]fV-pZG*` 㸝w2!oTK5xN1j̳1PrسQJ!ɮƹB4KϪ= -8t/Y91`ԯCu.=\6[鯻 M9?̨a0˵yfXե!J?A94)Ģ)2J|ĔDBI?D@\M%WpX(Ngd?vGU)11*=9Pk0 ߘƖXʹMOդH=ͫSJ9^ȞƝKqtmIo|6(.}HlEծ9ɗw ӝoR4M:cg ~]ϲjz-Wn @4?w<=Mӡ6*"ˉ:zˠfZ` C |YER5JZl92uzN9lEt6\MK}sP.p Jg̬wS{N:gEu\h ,;͸3 +i#8u[8UKqu.^)*Jr0_K|O\g (@Om;N zw 17nДEh{wX ,('ٗȕ/n5).1~+Vn'jϴ>Ȕ7OÔS 9_Z@Ƈpv6$/z:( )VXIsVc7}sZ%f&$Y;e8w/N<'[yk ۍ(v .&WkMQoB|˫]X3J(6gC{rd6,Q1SC׼B^/Z4vscFeics 5e:^Ľa*R< f8t!eF]5/xCh<~2CBˢT @L fP<]jte%NIk&?v=~kc*Է^^M`8ݼV#gB9|>x W}iNθ0ERVj͵mOh,+6no7*׋% gCWd뜿s=~FՐ)'C.J&?w=*Ev0&&=u ;a l~;6۸DWYt- mwH9 9> "TF6Ͱ7g5`)#>:T2VgɯhfKԓW0V |{|xcX%'PťJ+@xi㟳NTO:" fy[0.ne_rF-s2~i]h+RbH+W9L|Ù a,swboDT(z (Ƴ /K߹CW Bxglv91>$_"*A~7*`] U!!uQqGUԙdYe8kq~E soE(>w`ng$Fi4JKD)hzN)+{o٣t;s/#ơIN[<,60Ew$í`b7]4dHec[t #RPNQyՏz{t'0(]>#q7>zXs #2HHRp;%1^Q$SC?{;T$;Á EAcgPވ;$?wu⋄屭rj xP33Zb X S;Ѡ=*\ImsgHPK^d؏2@ Pz:+4=gkDűH:U[,k TV٥i\Aav"ӗ!'{`G6 W9㷥@2w yy,t @lbl.~2͑sHigR~|cW8D֙ow^fLͺq͟PsTA;~v"S %isҩòKnfaWuX|hwuj 8=W/NAۅ̔B0Me|-KЎAFqqbΌaTg,s&lԋ|ivmb6rȺWgx/b|ٚGK:k^~ e"A {$<QL-8I"aHzb$؍!FHL$W"Z$Su[FS%QjaRA_ BDXtx*؇Ű'*9jaj'x۷-M o_@~e`Hږ&)=(=:y0f6`ۭ2~jpQV׹@%ǫ= [ὧ\??^JZ`9ѥ1]8vt_j3F'ЀЏs;) Q.N4:.Ļ߯MPvҽ rbhZn:HcϘ2/(%qg;_-Y:3fiDx)kyr9y!6gP(Hw!`vV4hlI?`sWhrCPz%k)gqx&K_.4Y1Ƈi+߱Qmc$OsS~ W_69.t>/)JFM"% ]U*)zl&2zK̟nن- c?磪 o$x_: 58 +tS_G"R,>[t"B/g`A-I C,ŁJټ-Xܓ:}4& תrTs[T6! 1!nyz, =u1 lO4ɶ$;ڤ>nmHdP^ۋOw RBO;=0GRZP*wbWՕ}@̵;(\1BPEE/UV5ޔGv|x}E }zOty0D2>eG[8J Wb7twܼ?o\^vL !yB3CHR] w3g 1f(irE=`W(g{D_ItloanczXH_6` IY@߬<Ը{]c1 5:ZJďn+NA>_:D;:Ua!X?o#Tгv伓k<x%&c77G]O"ùPf[2͐O Sh~@lrARڈQ-]Jgl6t{ӀfO۞(ar_]#Qgv$2 j3U8 ;GߒBqJsc/d |/XlLiFv' r`lXޚXYV?+Mmbm{-AdpckCzl/7݃HlV}W%/}+jCniermr%A)OZͽw68 t`@MЈ2[Xy0$Ch;oZ4ӂ)p?u&+:P}MTm_ED/uc\zd/iu;WB,3&p.t3z]䶞#Z`2@xo)9Ibu7I@_‰,?ݜ0\ꬭz(HJ# W>P%\QҞ<`I=K (C!'D@/*'dk,j*Z4I9p; kTUiN(N#K(x?Dc+i9WZ>P ^c !>S4 gSȢ G ,zliW*C]˜1WUJrNR ƬQCr}C b +8@9PKO"=:Ox8^Q~uNQݓg$[s-Ԛ"c׆ҒO6boKvK D8)7@:(sAPd'DtQn*Ii Tۢ º@}Bsl]sAQ1g)'xo8\iI5d{mnkKG?$RȌjF G=! 9#Y~%6SA 1a Z?3{'&_>i-\;]gyayH`⏍Z l™D6^eC){kH9i#:@ 7hmb6dѝG20 5*3$1]HxuGC_3B0ߗJ\EEnеqE2N(' ?c;>CegYbdj|aTO?ݭ?YMy?bZar9g,]Ql>Z6(%_D5|: R%ޛ\2nt#1 EKp,qi|. I G6GC>:Y\֜!vX& I0Ne)..SzZr7G4dbAZeWS,{EgNJ``с 2UiEĠ  aT*<ږ/e u@}hgif->K]?L!AmI!KSţےE`3W6# p%47?NmE:j9^@A%$h6"{>ltU8"K]04Q;|Ex/ӻF/Fŷ>A|6 qI U56rTX+K"[_, yOQZvP?1p'I?H%?o~PRF}*2LsXs n"D O_H7fe=NhvfLi[y7w"?]4#ҹg ok?ĉA爅ͪ~E} o,<ȡhܲUJɓϵ77_ED3J T0,# ެ[X }V|5$!/"]#S8]-!88TΟTQQVuwc4{~74 d9Ȍ_K^С:N\T$g4+eͫwB{Zs ìTD_uRƲ?1#mqCmY${-;ȡkSHρP%Ti0Ʉ?Y"*i ^GИc2}6I4U761;zFČg>3J&j"F9* .39:N݄JD[oSK{ppC2*F,f 2WV0, Ótr>"E9:>xrUJ?XɊ& f,ӝz͈P,E߷T;@K mA߮&{ 82x }dd3pUATujRuZ0}AB'M ]3oLpߍ @ 1J)eS+wbPxD3@&0M"4!GE]oI>X~!́z7Dfc{ Hqi7n r3mIa ?媌䝗#VAu& !RG)K0omKGk쀙='"t'1.q'cR![\efoEʊްo)5~I[7EYvmSsǔCzJ=  {5^9(D{th4LC`Pޖ00RQЂoC!(EYx TEڳ־z1¨ E@(v8mYEs Du<+Z5fyFMEeYI"a%S(%5XmߧElǜ+ɼZ_CAt#`D%' KZdC?SfӖ%3|:8w?@_g8睄];Qا1? JOob+v:AږqNJ8ZO DOGOF3IR}wyQ[ -Xe,U i΍I}EG#uZSjҍ lUQ݈ZpS@;<)^k "Ch:q Uw01h]r[XǟZ`Bz|fZ.rS;<0$2ш YU!۪@ hg'Mt5b#9)]΢zmܱG>X=c"p 9Y׮AaWq?J;e6%5*?+iGŇ7U,d:*xyrdOQHYPʵb=9]]X%(BYqB;@GN#|ٟR\\7׳/G?HN崛YBMX yᾖ2;$d"Hm׆wL8&P9A$'YfZ1Ml!Ht9)N{s.q!n_[hɮK,^XTuLeK)':~XĴYVA76iK*7G"&Xn5Z ,!De(ֻ#lϙ\t#E^h0\+C[f7Rc1dNdp_LR[EZ$#Qt9LJNkO) V{y*%H+TFUu,"'U3@yL!$/5aʏgUöa` ֿau9 rlѰJ _l_VCd:,Dkj3.,(Gx(F'X ,4&^4FJn.gGG` iNO?[Gt_ !2C[ăX^J"`n,d'ý:* {cIXk.-/I_$1)5 dKIL~?oY>#C*ЕԾ" dz'IWPas m7o!ߩcy TS @wû&o4>\݈+GޞPRn.ss)%r4!/ߍL r既2guЉ06^wt6/yNu_L$2FuNy|f>]MɺDciEb| )γH04kPdf2^z5~ԌN/v—*%&E7IuQM,8ҴUԹǍpkV6yh$K.z9_=bQ^Nv\dzqq pw"72\dAȤtSxgЈPfQvB7^I j#?Dh?;%6~>|=d3xţprr^US51@jfv ,$rbuR>>hU~b@[tnFpS9Z{_@FoằFV'{C\%" Xi4.[~YM31AU^qF~5?N+|wu+LWOw[.]RBr}pLgZWz\Jv/Ug?W> '*M' '~ݟ٘sCAI]0oX {4TsMx05M%VC [:3No#~U"EbAI7hY .eD2+Hk5d$0޹_*n"0;J;c$irL:pT~S&m@tDԇ tvH^ejXSuNC@\=RSݒ^av$i+/C8S"j6ᓢ='%Fܩ %IHJSˡ@5hbKJpM+ͽH2<4,:WHS*ltQ6v@.O]r%xDzI u Gm/Lm3c~+ˏULجjQ֕al/S=}9-1Uf쳚_+EZw'K+pAxh|.)Y:TQ!ޘ7L1̥hf:d/]~M͔MϞYc;PmC5i[jhԮ~7#qQb4"h(27ddgl?]Y<Зl8𬣽3.$&tBfȶrQu4Ev9ll7/ />I Ou _b.m\m1_VTf5HZLJ1I Ͽ!gJm.f [ O5c6 |+jB.K8kOF˝צߵaUqcy</LJ ay f.Z;^!zx՚ cv|HMҐL(M5@b?7mf0B7D 6-b{_?APa#7^QkoUH[cϖMW?-F|bep8H4rUNqfgߟK'6П.q[@#J3q=|~ l(`J_" PЭB]BEE)1|qcW en,NؙHDL<9{VI](%jƟ'\2B򠱶夙'/:6x֦Y_33: Y/,< ~"&sW`}EI/DhȬ%ZkU/L[> |E z>&;VhBv#Xc@ [JSbTR#!4uyc6XX63C (\e hgn'UDhm+|]_K]i,X]NT>5rXͰ;9<;DRz0tD`nbk[@>$SR,j clw$zV{[{;͇eMZ ۉv1*Ty7+_7_cv@{|ė kVC,/SvbN+SACDvF=&.:|%ILEFDMXvI7#2vŒ3{Cu~XI܀6Qʟhn25Tˣ[*618Fx%Y^"..dxSn2F`3k=Z4Ngn~[y$ %En5g0 Y:0ҙ\8Q)M 34r nƮ) &}hmFMﵓX!f83e_ J=zE(jz7¼28>]Xwy#PE]MĶpA b+%H%;WeR ܔLacΏhG m-RBmV'iRC8-9#3>듇E}`"D5jUPQMfMLIA[tASKa/ڞY< ": ar &Н| +5Y3T&r' ɞ@@_q@Lw-Pڨ6!bK(%f ^Eo]R@ GԂGb y4}lcQWxc㘘t\+jxPM/l٦#߻ʞ, UCL%MN$U >GVjqҨk2+2sR=ppyMm&DZȨo &%* <Ձq^Z)lPvܶK4pL_Eڒ]aZePތ3U4_W! W2{(/LdYRLQN+A駞Z7nkȨ^@:9ڞ痟KhƦu ۖW6}Tf'* f!tF(_E~bf{y]GJHe:3Z&K ov$dgjہ̢\P/HiUT3ڑ^ pN\_ KJHbM.< ԴTMx-LhDsW`t{(䟕}$Nuv3txK].8NBp.(+8{fjK)u]* D&~G.:뒇A+ ]#!{>b& ֘<6d޾V݂<}"HLpCX FkFrEg;,9(+xΚPeBDYT~=;wjEm` GxN+D O1 \ 2 F6 qBqUL?"|ƹor e k={p~jU3fuA`٭}BI# `#:5ȳ 0F;m94o=k;}3F NлFrۓ9vi*l,P9[Zss'}Y%G)y煐βhSv qdPQ^4irӢׂ̪Ɍ`9ơudo!ܝt|B1d=nK-|?˱@Rd)V-=&{"fAMdI࣡Diùʆ xNA@b':k]bc\]g'h筏xht9ӼT}V0?-U0/l+);'EOȉ-sl]X:\ fBr"l&O,, hX-E: xC3 q<Яv0-rƱF(C)IX.b 3U`Mrv\7c 2ecUCHºt؆܀7^!*Mz)CL0wFkDW˖ϸycF岓 C8>҄yB-+CgsbSYWF0A*I%l`p_Nc,j` B n^yk!Ua9|YF~_iu5 hIaXO :BoE65 hX ( I\; yerFJYnK#ߣHo- 0K ߑn:5<؏ .P°vz},N8YB" #_a#2?NaMyKSo ॉ:Ծ8e.Uz#kQ(,o[H~@Y\V,0,JMNIK=UyPҾLWRv/>ܑ^zщZ2D,7JuK9`9J;1Eٹ}|S֚scG"ޘb3[-Œ=L#Q-[tG ݎ+3OC ē.9EoA!m%b.lM"}izHPd㹥zNuxU3-ir8)Kfx#z? &~@ ^ND=:T,MC{G0mG'L.$$= ` ʆ,h&Xj=v;AJ A3`,4Ò\T%'ry;qh$XwPHw ۔%|c\_f1xe%>jsL ND_+p:A*d:w26qez;3׵,z^  S*c)j `OkpAlo']3Gף#If+L`菠EpZAttX`JiݔƜg5I,dC\i ^Y-J ~=ګ}ԥY?}ٰj2 j ۽qoA0Am7q/v؆ؠ6\1Llb&ID z6,hxmaU|4QP&$rq&}[*%BzczVS-e"eZ\D&F/3ױN5,%i~+EI`0vh׎ÓX辤h(qu`<lSY/o{lݞZ (9%u*5vU1EUtιڋҳ0)gm摮Lpu0H 8qhlWa#rܥ7+WBKQfz"+jbFrAv5/( RѴV#*isݳS^j`0Pe4uBi]nuQg } ` G.)099il1>+Tс׫PַhΪW\DƿIH|g#[ ̇]7<-ug}JRsռJtQl^#oɋ;z*"bDF"b_t^glwo_ĮRϊC`Ea]T}9pZ {fd꒔O\(x{ʾϖUEýN~^wy%hW>޴eYd]︁ o JF*hVDZ?Fa6.e&Ut{45tL!e\J]*hb $Q9CZ۽I{uwsPt=To].CMl`0zya4ܾt~5Q3()sYi+`\kcn4O)zgX aN1NkjDtرyz32uoҨ[9wf7fZ!FC_ mݼ >s3%\5( J%*۩ʦ]u4+ܸ'e6*Y\-}M+=Ad.&o 7D]# VՐY05*"igAfL@:+O4HpʿsEv~&t1->qS1k?\,̮DZtM\k'-0sZKB.eu N]jKoøZ4VtcᎡ$@u,v '{Xx lLQHdB':· $xmUM,kI^MN X^H8[4{ g;$+9e[NU.@0UC^8INPL(U@ڳd4C9!^gtPcOZS; ujU%b邦׼TSyJ`r lzuȿIV95iAp1TͽY1Y  n<sPSl~ȹa. SΨlyD~Et\)]Y(sAAEg !9u<) yeh~Oa atҧ5WXVlV6 ~ DA@&w>paG{QƅTjG,J:RI}ӜCwl@t\ެ~o= WcS+*3= ]^$6iM][(<ӕX0">M2\t/P $JSmZhV8FG8u.Ҵ"^EX|{M`paƍ;Ɉm`Z6 dE?Cq5~8oV}z\45~&S]jķW&*`iG[6R>66\܍\&e—^%>;#D!9i=>pqCƴix +I= rjo$S\T2z!*\=PlmbXK vk+6;m:KL3=>a}y/ $9-F乏hDCJ,ocV5-+p=zk'>kV0{cwGsmϐ* Z6}#GLY)u8=R8PI'x = Wl_aT/'Bn'jEbK&:[Ɵ܀@ Z_h|A(v_# S QOГ/s_RMo\%$+jvii] X@4?Oqe q4%XϔM8_uvx]M~0G;!rO ʼP4g;@Z4<,`؜7i)Y}ELRJUi@eMzQ.90n5 Ӡ]^o=?-@wh&nDD@VLdi?Дow|3{q2.R~ ;n*yYRW^ߣm$2,X$.izjw1 hywobW"t "_6_PWVQV|WyGS(k8(/[$ĨTܯ2V5QR81%V{7]s9V# `JzpEP &5,@';/]U1^h:V:[y4)Gw$O@IB'l;@ Zk/>h^ ax=6+5u_09x?j!0~#z0줞BB\]?_^<#C+d(gZ4P j$o>+1E]m}m)HyuP<O7d+0CD_T'J8;be%k7LpFc ۸D8|ju ѻ@QB2PbMw$gιX5D щf<Ҙ(!6/#8ɲcs(Ygpۃ/}Wt'~>XbM!O d16Nn :g~.(ME=Asʑ*5r-QNG?q2.bfa_7 ",f:ˋۧڃn^ P oXjYhuߠu2ERu4jgg@8߱HLL<?QÍ8򗃟&Ʃ['7]>a[p .N9wIˎ+ KO3NpWB\[ &+nҤ5;wTںY`XŎr5*& 6eăi@$g\ˣ"w^Rї:RA-X) sK9AC`t6jҹlQ+cGւurQaTJ"k]= Qx #h`y?IƒpظgJ`v9~Gv𩷓hn$? (4=+HǻA _(\!(SqEb*TFu{cZ6xCFN dV 7zWZ^57\aۈ^ 囻^+K~ti%rw9ig߅)VTgZC# x'B& =|Ll,4z]4`zwEwQ @0) bQ%i ń%خ#m3J>_xvĶ.y3m&n *ɘJqf4a{B0:Y&v #46q0y7h PNJe$ blwl>!JP9L#_Zjh$ zDŅ(d f}W wbCQI#W(WS)Nat_rݺ'HLt |,*bp?zEa"L1w! 4,ּwO՗j1CU42Na ]LTìU惜gsw(!*p]w`m9-;#2q3←y1^<j>T'?mRZ[sBuL4%mFKh+(όnYJ_P:!HS_nǽk_shnaU&~VzW` `}I" acD&iE CRZH-p)Y~1~eO?ձsNmڈ"-k~r &F 1mv"}z}"Xύ_R)ysT.IÑOW4{E{饹1vnߗᘆz >VF4]X+tv JQj.si*;>yϳ;D%*3g  -1C$ Uթ|g~1E®bh+PUۣ(RIȑpƐqѺ_xJ`ŪAg`׻~Wob5^ϯ6h]kpV ࣟ! C) @_ql:SN2eURb =n> n@i #RH vXx~`1 ~N  4Z"H5}+H\q$mvv>m<^pA2II5Sؑuk G^s,) S"6lj/r(qGBeb؞nZC]`_D`_.gt ,B^X 5ҝ=D~)#̜g9G_a5v+?.jx9s85ĂcR硴XEtFG Bӄlge.RVJr.y⦦J0d¹ ovV{}t41tl~#؄9{wlY!Q;(Gs `,o@h/Ҹl b=]GqH6ǗCʲA,9_o^Yt+Q29hVqR{Nğӌπ2_⩼J >%+yF-zor vq]ML| 𰞣p\,Ey4BwV Mi'pP3_MAQEd3,7w .6%5kU@,?B,j~ ӒioX]7@cBF,A+)en`=> Jb]ָ>e,2YfتYf;T͵/VFbs0ʞ%iQw@ S>3scL5|!ɬ6kJ>Zj;>kf'L&a깶N70N`KDJv_>h$} \[N,߀1F2o昮6ѵrذCu{ ((;^QB耆NW`3?n)mãΈtbtMN$n0{K75 YE_zP_%(:sۜ=,.A@ڻ^N@S[btbEAnɺ2`xߥhH;"h#r`EE9I2tKB: Ȉ}12?!sO?L44*@F$k7~ 퐰D-e,Mu<0A-TD@ Ǹ)J;XD_gqH|\faM*0Q(* -O8PJ%  XON'Cayž_+A }(±,ӥ9KC駪n &Z0U,'$~&oĿ!p;wj́Mɇ+ "m^4MX6 J`\ i/Wo t[vz)T/a hу3] JzyENMNvi>4Zˮ]ލ62cwʹ f1&3$ ʥsД 20(ڠHNq:SieY(zAߏi3350z+[WALqZog4V"#Fh/F~Wj:t; _1)U5gHBgPu>b1)h>kFE+H0Pr`= &Sm\|:@!8|T*/aŮp)Xe89s7Qw@قB#Wf+q, π & {ec ~NJMrqj^sߔ[ְ{yi28'EdZHwrTh!57.Jo(\b`A(6#CLNPZn𤮘UVk.FKSw ͭMnk͍;E>CO9<+.o QF#*uUsoM.mcE=xXmW­F/DfؒE>$qKvSK D#QA탻.OIf9<3dBeQ_PcL?~c`˜ ^e,ŘF$]~c93qVv:7F`coyɰhDn [pBN1U?ʭX؈0>I+SU4H9-wFوjcFXs  ^diJ;^46ƽ#QCqK^rBSKm6n}R$qx -&Q䰊}-F?'NV?gWJ0jufE.;Kʏ(tnXזVT*@x9}ಡX8Jza4Pz6˻%m0ۏU۷boѮ_k2pm̫va#Y3Fm苻P hbIa5d@ȏ29U4Y_<e٫/,jΐg/t%؂{BU*V9x!KIKn6oE{w mk#o{M+J{FZ );-i V '`NH[MnF3aħRV4 ԾOST?Q 6;6@JB;2ౘهK8*jO6So|9@)pH W!mf\تzm-G fGyMD^:4٤j#[v"u'.蹯  t>i'}β;Kn9r7˽Px Cހvad}<ܐiV2ѽ 1) H\UMɵ,YtU{X\?s[%EjfEݏuަ 9agBZs eHyP6v+c'`q`;+kS'ˀW(2*Qžuܧ} ӍL0}n>gi)3{ *aKKY")|8|Hwx@j*L%l e,ȕP ϲ P+LϏ^Wcy+ y҃4uKE )_tk=QcزbW%_dqzp?zΧ>k;*7Z5$WctrXdQń*9=OMӒm7n* ̷oCxlvH&AS>Gb b8|wN~"Zf%ti|vYlE뀮yӱ -*RoҫC.L/i@F 亨12&I=IV@P צ"֓ G 7m>喎*eaBaw8K^-+ȑO^Zn~ *-G"Ai+cm7-ڣٲ1 2AW|C(hc'cЊVbS<3+;Q<psCp:.FB"GX牧ffp.s64("H;ct\wGzD‚^$ :[;NOwIA76]ƒ<?8qR'ʦ5u~HCy|S(Z`tfIteh6"P06-PZ]>f$ڍKV yb13fNՖYWF *0JgVz+.ҝ^9"NT-V^H,:] DAqi5 MYNmǦ4J+ŤEȞ-Wut6R#K}Ӏp@IzմNC͖vQ{ ig.?ἔiKO{ѴPC_b^ 5=<\]+P^nLx]9nÚ>BAJ/ov"iiDߛT$ Bv"=>"Z-zchP`7˾c(mQ|M<^fSkwBLm__8lĥ1"!t73G i_?pPd`R5=HH1{]L*y:#{cLRQp r3t] 3:3xq(=|glL.jw>Q}YVL/U`Zm8v/yt[̿dw1mnuVӭb;eՎXsV `y4G/p|P8,թi_ljԭU+bp*dgT~maPÖ J1fB"Y.#aHJb+Y "7ˬ%Ճ_ M)tPzI, @rnس~vDj~3u#@-(HXDEu$G%S:H0~uӵc<Ņ{!cl̜j-Q`k{tH?P5GCc].1HG2Ck}XK-L-a+v()2{2Zjw┕}c9䟐T[:JDGnpzඪ vx-b~b9 踘gFɩ{uhb/l!F|K64QSҵåU}I]Э]zRQrp7Tm4xwܥ"!|~8A wpikz~=XaK x&w+fpxi6+9uȶ[{"4F S vsE^V+8MvWOgdX8EČڬUsCciL'mqšn_n g?/7:w j,#:c_3^*KKvؘA۪: =rlCvأ#5p;,-rv6|m3gC\j qB ,ĴEp\^|zFC:dJ9%~cV-_G ScYE_ҳ8,pAaIBi& oⳆ 4v:#]7l?ԑAfx:iUn,P|ӕ\(ёt.8?V!{dNѐfj8^ٜ':4N>/tz3oܼq c҆9Hl"r/_ȥy{m6ƸxU 3>DRhmLv@9/_8 m:1(e{zB6 }i+T[oN'Pql5y-%A"tN@t_cf_$[cei?j%!U/ӝc~ x/d &*/o#S=H+pDukIi(sE, kMJ%O*dbP"rl֞UEm3n?k ?CJKAG?C.A.MJQ-i쨸Ē=NIyg@ 4{}|uƥ[ٟ#5]_SM~)'Zڭ} ò1lq^ ) 0jeG>z{+\%; bVH'JUS%Iy{qgxmǹeZ=GM>OQĒyOloUČߠ,#bן_#:n|s@RE'ez_:@ Eǚ7\Dl;|ŐJ޹c2:y8A@QFpY2N{4N3MMҟk]tRpw.^YBߧà^lZ+w.S=P/ ;J98DNX+7NĪo>4ܑ+4ޣ˜gEy4X(sg'd-f/:漺9BjDt}R1`䗎U:e0 Nإ~čx $WCӵ͊%p̼~ñޘo:zlAI -$dɽtM| @ sQ r*h`E4R;evN4pz4>Vi.TyL5Ogiܿ;,$JU'0j|?q6:eb˘M^6 \"i}w~{O%cS.(h=2.1ȩ-pK_JeUB˓J>0K|B6J8^ ꧛w߶PȧÊX}P|*.v$ GD9_A˻E//eI2pLK0"{GaG˲. 8;sn0tEKin<΍4&[Vu9CZ<|F&thI_ct-vQvR1#xI>,ָ[e`ӛu=$xY4"/,y(i+G'sRHh@iNLrVaǭMxA^'Ix?*GY `n=Tb+4Ӽu!9J4to sX fpM&^d^3GI%#Aj772h]q/LLT0HN)Fb̵͊\krI-Bv1wXbг~у;Hw}"HlEB5}$7x`.Lo,jmЍ)0muNm%H q] H gMMi'I}twJ"W[SBMe뉫OAles1Vt5rVuIzrc#fPNB8%UPU R!YTS-c=B>$KѠ>ГC'mƹ4u#qBU='|p- 6fOS%wSRLavI4me[Cs2AN3v-E͵VoS,tA@Oa9 MVz/k~'|+faMVGi$ e) 묂;]I" @)X:^t^XOT؈Pv]*1Qz媢ÍE+ F1R9ҙqT{n1Q}R9V?:ʉ#r/7m;;bCi aΠ.|eIky/cORPʡX#YJ@V#${3`Bn1K>H^ZVf+`mB$I*iCk y\}%gmBmuȁ.-09d np4R8G}! #^T!Gl% 3 )9=!55eY|8a?) ߼p h2Vw.P籫ѪvYVdqGYk*OKᜍ|k4\i="~,1hHthi=>mq؊[A釖Ksh!mYF>x[GzmEԵC.^2s" # P!w.@gv"q;qK-{5a'(Fl0H{oH,60 T3mse] W{ ۗk DXXjSË 6RH;G iu%"Փ]=il<M,jWqsM-Y3#W*㪈O_7ǔ$H,[ dj[ ~K <+:~O[%M@Dd;X#5g "Zg6V(Ni\OS/D1IC0| DwV/Nx?3߷NJ`?ݸ=|vV%QvSCC IkϠC55 &!mQ}N8P"NQl(,w;V WnjV qGSƺeV)eS{im~T+-=k7Z#ZUev'OW?FdI 0=D'mY\ayΚ{|p5,'Ic}|V]a=]Bմah$1򝒥rlY?Ϧwץ&UDDn]y5o؞i?FlX @ QU {/KDlMKKBb"O,8N|2-*3I|wƛϿo4%69#ϓ"WS!1#W0 7V3W}gicjdzxFyRQ^Qf%@̹N@͞[Ur2pp W~t%gx .a3)SgtL`$-bej]DXd;b4v dRM7xA>ml)_; dou/4OzL{B A=Ĉ\Qv:=Y{Ȣʬ` øx1/Ŝr:(TwT sgY#ٞӮ݀[V(b7' eqR/$dNuM4+tl[W{Ɖ]$@4ЄadW+B߸BGHXR . N=zF 7:?ͧ^4e@|Ns p.`#4UUB'"U92H}1]m? Uh~Cb6X@Q3xuWOI1qָQ#9M]2Q*݋^0ipcaVPw0@t!Tb?6fr`,bOU"jz.R y4~iyiLowܙ<1WhOLZ XvX`tϘ%L| mfMe1-{bkT:,:1nӟN0:;s5X<ף!pOK?O7^8`"Ӯs"c& 'Vde5QsY̹J$Q>m-#]mES!T'̕.Q`>7ᘇƾIysU5'z ڟ0.e_z禅o:faVPI< Jx-tL 侏C8cl#O/WVH.24&7݄DZAH+Olz/oiHR"F=HŸp*8ńrΏ(`bˢG6<6*8( oC-ռLv="Yyni7oq *",,% i9%Z/2>slAS`)ϡzzuO:[l, EdjhmvXF`ņDYtXTޔ |[:`6%PDqZMݠ(TS$chFnߔv*C0pb%4  >?(0+2#a~SZK3=પcX+BB5vsND26YZo{=ď#Wx q f'9%9 sxefƭS`==Wd^4P1.Qc mռ/ᒘQxy, .aClɃhn.ia#hÝLXxSTy8D6s5rL \ cqItHt|^L $=wzdLZGKK aȫ,.Ɏx\5+X2aL.O 륪RZ) ӭYa݉I1՗s? gHb::_3q0qx_‹E wM)asQ3lO)]qQY'=RIFFYA #_| /3}lS}8wZe#^y`_Ɩ02;Ωˠ@V^!pvA%_ 4qՌxC\!2FXMm{f5%nAd xj5exٟS4twҼu aPFҭyhE l׸R0WaEGo .&uBOT< 4z&oZ6H%inP "6"%bB>]:}.X-))iɠgŃ |tTbayg2fQ_ŬU KR"=LnyP!L0w9zxT>|1 {_'~'&sɇ f>L=2l¥y6?4#;4G;Qtl5h*eCU7j0E42DV#zj{ HQ+T#IBLfCdw:rG;VJ?t",WKTT_ mb3K< .w+nm3e9'h,LTt:O4J>cB(;PͳLgQ8:A.h W;ªۤ2j5(!}ч?݊ μK;7b<_BU;ͷi̮q8Nxx4v*?Vɡ@+ 7=Wk#v^@\pʀJY썵G1FqCR|MLylA}dN}򁛁aK:} ֯_u.pTs,dVӺ+,݀U^ vr)[(UD;xs<0^.F{skYͱUe翕-r:ΟzzX8,~s<69`G1БR8w zػn7")N[/uK'̟s«805C-~gWy <1;'ms K1 KDw dsuΛ)YCBNP*+BƠ'|5UsY7E,&7d'q+ou9vRJuKO#B73tCgk;WG7(T NKvg\RPr^U!6IN`Psh쁛YWobZYD$vyt9Tdҝx<د.|P4Ja}ek؁Vm*%YIv%F@,:>ßcI)^U򛧕j] ĉhQwLb n1ѱ`S󐉚JlH.s{vh 40 ?H3#פ%G-.zox Pُ3*wFZ I3~ˉ8\FJYM\k|=cD{ݏ/oN%G0}J@幬e fr6چ5j^>oxCőp jD b/Y\=i>(4S`Ju\! yw\|e7{tk&"] \9Em{8˂ﺔ ,GmdIgHe6fG5&P` (eQ9 8Wgpd-%/쩄zCȇsw U8g4h9-PeAW1LR4#FV^=Xjlee,+r[s=P8'5EL W2u$7_qUnk(HܦPk˻EXj%ߦ8Dl.w2M4Qf˰S̤Des3@0kG9VS I&er[hX>FkǮ9PTVш}xL)]a~\tMO[dDO(@;ű2ʥ_PGڅ&->JlK[鏆4\C G1 GnEl Ib_. m#bVr. vB< ʉ#"9>78 B%%ƷD`܂-ʦS1isP )N\O`-f:!B@{]DG Rjǟ%SK*z<GYqSz7Rw`]&C_ }nay7oi3z;LhF1-^cƱ$ZsBJJ~ CfX%҈9X+6'q(GsM+(Tӗ]za_h2g[]a ~ehs:rDi)uܒ`pZ/:AGǼ)hc*QܓCS@.aZf^])dq ]e1(&ZHWT|9kYsЄֳm1SpvʏjoiVPز"oИKӽq!N g?VA;:H*r>9^R{aؤsPUuK1V)>̗8저G1S1݉r- dXLƉFuVFn 5ʍ c^7x&P\*TEٚѥ5*]L¶1\m7xCBjg`֯E>OmbC.h^"f#8s$ s8wQ\렒U%e @><@ \BM -Y+cDzu$[K*aAnVeƐ+"=A7ߺɆ-3ڔʰ8~6O }bhn9lŇx{Q0yfTO%'eA7X'sE 1=inKa;d#70Bl3yدYZ#̞ gaԖvw٥Ŭ`ŠR֗䜉xn-5Y5V^9 x8rDL9"b}v1 (" J] ;8I1_Ko q:\:`PF11"6N&/YG$Uf+;a+jf]' rE)~fД?L8k_v"nv;]8+5B mh1wd%뉂t\o8g{].^ XuP֙ ezzKX:I. tc3  (HΫcn<*Fpg3Ie.$9+Wϩcw#"O'm HDַcΒ{*a\ N9/7ܴ)x}!:P\\mcUhLMzLc;sRޑ@GyoFluQpJOzGw줿\ $X֛͠Ryaͪr-Em]O*e6վn…VXFkؕj]d/זRgJ2F_n5sەm0l>X* *mP·}x m&O|ȝ(<فdr_*LܫY0;,is^˷5w4؀2} 0t~OJo9Ü;5"{TvCF֋49uʓ~-9xckц -}>BULιDFTLWe/ml 4 pg׳n!0\{zL4܂;w=͵!0Py-XsBJYphG6^Cq_j8@:zAI)suԘX7~ mΑ vF!Mg`{~=]`ílZ. ̰iU,{u(Nܙ/"{o&qO=/jĬȂ ]0Q ̒D\$/C:oXT˓R R) $=b089/5YY1ai119O"2Z 30jt_縨thVpM@ 客%zhn6z>2*q=@mL1]Q9.mّe7t(>TL S!qGYb}F0݉&'(uLZi?fʎr֧Qr{ceM'tn|XZ{#,BRfI4EGM1b${ j;4 5(WXq?2 RGqX4ʔe$%߬ yht#]%+﵂hOSN۪Tj񱽤"Pqg7l5FS+[I)ʯ i);4ՙ>fX%;!J݅Hqp0zȯs5݆8B[fʆȮOղ?@3'<4|{[$'#WH{h)O0d[]SyxqޢpvEͣG4մ_Hx)P-q|Zco VQ'|{ g5Nx,P5ಁYĄr~A>q?шRe@Z9 6 Itgm/ZDMEpb8|_TAME.1 ]||P`gCIfao_ԧ.F#d a/EX(ILO"ڋ,p}U2fe?Ѵ[J|2|$m Whr+wUOյ.t 0YN+>G#o}ưI0 ukLMٌj#u GՓNb@N}*JFCȕG|e yY(Yn%Jv6frS1j>!\ߗrtk&dُN-60KRKT [4:3 _svOyʏ>9S(EІh0E4_NOY`ƅJDqL&> b/0+|ߙFp!] V(T\Hx NW(R`䁊_ФQ 5BOo5<ȉ+'rj$|zv*FPzYZ&:5E{Až#Nme]ʶU( HA Zŗa x_z8MTLy#t JԵꐭ-{$q6c9nR>bV+cx7-n^kʹV_>f^IEcdlr]m㐑-~+wV`@@Z 0=gCϱ$UL<Z #MN >м2;,dCou}:A{4wJ_:ͤ3Ãe1Z {J0T](vw|_|G/ sqk;XFd4 &):5n3'$ٸJcbځ lK:b.HQ#R3q`7r~:[D0&ITJae֭sr9c3]XJb$%lz j|iO8xh>N_eK` %+1g|ﺊ"0~\^DX%9)C@)lzDE-AUWύD!zLr KBt<-1_Od0?VɧoR @7̨^⍾hbLYzSy:O}dhVNZtq8*Z|5/ԦU &/jd%?l Iٺ }zTyݿI/ü2Vse(\1 ץW7i_$126.?PL [̨)`/GNNU3QE0{ psl]@)пO+QoՔ1[⃛?':.?{Z-Ky( r\:fL䲲mV431r"Xpy#ӫwʬnj=r%rZcC˦Ĝup"˒5h4Gf)HaжS˰2V-|}Eg1lVA Q"x) eɚG@[@nYM}#Us2;wayw.ڡ - ׶Q?;`G4"mq7af{G|Ci~\-`},esA䏅;8DD~vEi|d&9^Lh}ϥb5+=>tTB& ^fħ,٠gB- $ ֪嗖 ^6cڦ2 epygL h2*ί yX:}1#\q'>^U=X׫f:ߠpC>|g^!}kGx/ץ&^ LcTZVf}fRr5)b$E7#8zNWXqFNɴCyʲPN|[A1ʼ M Ō%bNI %bkJ-k1"*FAB0-;(drir3o:%=DsUIb58ּ1Ƶj\Lρ;>0b H2lEɳfd ' |F]l(-[r"K%)w$%ʢ‹nZ1jU"$GeѣQYQl!Hv( 9F,ry!N;?Q=<-Pp*(G߹aǯxϓM6=D_dzMϧ=ş# 'O&S;%Pܐky4]BEZ2B,.4EFeZWr}i#5AĐC dFz]CrBy-UeYV׷ѓݘn1MF !T0M}O ٞsx3)ynJd8*k@l,.iFq${%Bv 54jI)wX夥1SFt 0bt5"*{6QmоF.ۭm }5TZws__p oH_ݣ=(SoخQYӴkmZ>5cJ c'¢`C}3[}8dշV[|'s-Rw=]µ2-M_( }L$1Z9mx^dXRf8OMsFͳ츅z8kCmnJଉtRE>Cu'->WD%1Y(@j!j3׏X0ZT֑r=+קZ77(҄:GUJf̨I^QuHߥA: n(Vxm EPY'n@?IsF'ϲT: 9^$sPA*e9R7r US뷚@YlN?#DLwh4J)yU :"9%\SY `;:aZkv $ ާہˁj oҫӁg4^, @ɒkBQ`a:XF|< eL~43 V+M8-R~#Lm?ޱV[jmp845L5-wA 72뱑/NFU8[h=: AChvè!KSO}-]~!je<ɳ)4g `?}&mK(tWeز+7Һgd=Y̓q$1+Sصi'SAUva_tBʑ*2!sBŕ̛7(0>! !`2ndr+{#ug"پÑni &`5A O\hK-5؞#XDf "{A񄁣2u, 䆏zW/gdIB"q΍(C "1vpjJs̥t(X{F2%;*\c/)&#A~emEkCͳj6о!W ߅&V0>Gm vmӘ<,x1{_~kݡfͬO\Kcƽ19 ҌI,`G}0ۈwh Z+"Gwz zhK~]^>%֪RۆY|h+3YBfɮHl'3lLgc198+rN KOƄd@&~Z<pP#}1,^5w*\%ߺ RF=ON78ޣ!82]"nNX?;+gRzIꁛ,?izfu8v}m Pa Y''R+2v iAR"jzl?Z^N|%viByK&"4FNsɞ(kܓ5'S{^]^ wqX;$MCA ;qփ+l ȉ|sD6ȡ+`4epcS(* 7Ɖ'H+U1vi厓X{Xagy !;"0ssNgVF2 ~ٲ' ;y ~U,[jucÅ(+h-/ L%I |0ߣ C,C(AtI,O!dD n}k$gge2PS ƽjKC|Kfe+%tV.Z N}1(?g>TX) hYQ3҃X8)oJy .8 ,GKoQBwYrI);_<8/HS <G &zB a+d1Z.c{ Roiu^ls ZliRo^'$2[i۠9f%zϝy(\@c^FfZYX6xWHllI=94-s~phG&6uu>R(e-Y6Lkj}6xpRv!}a c=jkJ}DC>F?*\a<0WA0qDz,WaDUf~GC"Z2آ Jā IPcE` (߁t1&0(t ໨ 蟃ʙ]{m}h,E=&߮4E?'3Mtgw "1UBMH(@c(]la/HC #P>#[w[jBXr }/щ;w,5 8D/ȠlU4GC Ӈ" : tU7_aCy1z}˗-Ё|u茡Wh"[}qU P7;8$ʹz-N{0ura_psi1SűL5%H#I;ZϦ(ܺ܄#Ym@5i,g<$K˾g]G T0)x NX f &4jh/e4l?U=b/[AfJ "8qÍy2` p'Xd{f @+q/Ye^ٌ;kaKJ^"yʇA7I#|gAj$k-SyfQVN 1_?Uf揽t75`OoZiXœwS99ŒZd__jΜ`_A%ѿΦbkzlLH@BPݕ.pi0 U5SvȲU@~R+_~6XZV,u Q{T 4<<-Q_&lڐɆ65u2H}fxƓL2@qKv]E/äp H :&ZwiC㾓мU1ЅW8΄Ow&rsۦviđ ǎ@dB`Mȅ˒|`^,S8l m "+`!_O fܶ؟=K 9O ` _5y\'Sv Bwt.d8`U[&Ѿy{ԨkJpuU$֚+VgZl$'U쭄[c!c`§R' {D_XuE}*D&LD )eL.,^^0{+,ؿ|yJ]ĤSKb P-8m`Bkn{?mHr^ tUk[~] V6FNIt}:%kycTioͫ.yӏQmOyG֍HPȤT=4M=Sɮ}t&NҧU&yY1IZ'_Cn-nԳnLYSg2+tLۓц >.@Yu뙇^/7t=NW$ $Yc1 z 72D15|fC,ն h>z<[< OGPV\_[v}f( B*Vg}h ޓ!9 pZ"fNYSI@ڲAx}! [՗oѦTWmOK!;RUL;*@:i?ROYn=2mpj鯑>Su`a^%'3f6gRau29P4uͯ$S- hd' AfF;cC2˵Ps.*tP`ZUSPWOi,W>ĢX2{ oFm: =P+11v33\U{t`zs-5ƹcѫE UliUѴepwcKɀx,%H;otac),ҹ3pA|Jh}r vˆ=O C;h^ 67אo>+F`I&4)J66o'غT }2d2]*_%&WD77%ȪG:zlbtK2ԱQ MG)R^LjG$RI;QΞ2ٸ iyR.CHLjP۷7-,uP&AiYԠcAbzIbX,FXjׁ$ܯ4K"u_8cRG\~+}u"meO½`hy#UqwmT=ht{YZm_Ws΢!O&!8n k1왿A& ouK#C4C :&wal-w>|Js?W6N 1ngfy M;磐8IA-rX_g|zR놐X ?&.ʶu|'t|sh@;lshmO2FM\5A4nMyy|2ۣ>LMLąI)IUpyvE94Oo!vJ1Ioo$M.ةmԏwT.ǵ LbyG_ oBr{:b/hwf٭qbs)Zu?47kڝQ.YP*Ī??L fzHW B*+`-Um_ ПpXםz2|fr4?7hhF#uE[A3d|D{QZXuH`zƘH]I27ؓ,0̱=mqpgW^{Uj(kA$^.Gڅmw piĸɚ:'y+L\_˞;* A&$-TRn8h}|HUDOϩN jJ/5噦hV )тj,aAV',c v }@Vսz h)0Ǣ`H;h+Z%^IfZ[K 6>2rDn{ m-էrsJݥa,.~RoeLFO4߁TWBLX`4ܿ{-ћ#|Fؑpγ;ib@H״=06‰pm:)%I޸0 )wLh0E:}}@jU([ZT5Yꌣ1gjVc(% Ò)e cFsXssS vA!Ј>`̵iC ->t7 թQ8lF-<"Yҥ IPi1PPbON:"Wl.Ν.H0R K[ ǢN]~;1-U^V{}fFy av|؅tOZVԗbu]YKɣ@R¥͓~@{ 3FJcτK f xg--SKK(3we0 y: v*jfrNJFn)5&~ft#V*uX7=^iqԉ` O!CpN)Ll2 ^aޘq8x,uNۚh r]o/ێ1IM.YE~#]惛cgW\ymM1Hvz!$FQ)K (*hxJr7waa/H4ʮu4UNV|Kfc/Hדy-֪܌ߌRo͉-P,̥n܄{0)=@L-Լ*W^Gd/͹JA!^0]:C~AǔRaDche>GJ䃂E.GbTs8xbq6?|}YGqxWdD@nz̃M2[|C '> <XE,9, e>+Lo@eX'+a0|EUVxM9)&;쒡8aPPTRJ"(nӆ0ov*| 3c){q\QyUeʭ?mϡ! I5̵k.5c!Ml)& 0 .m62 UG˴ıܺ6&khŤ 4N9*6ήa@h]t8VY)KXʾ4IV^4].zu?e;p4 WN IVkJNذ5Z-x_H@ ;[u !^CʯނR‘$ 5m,,uk nf reZMowW H$x)iqnǯ<^+!9IZ/+fIw5+: ùΪ"lb9z* έr#;;D5KI`?Đ2QmGQe7zJmAK&Ֆ)[b8U(By01i8vrnz5) G}`g&:;W~\%<("71zX<tf fWNoR/EŞnIjvN9;SD)ľ߰lDBAezB7)Sq~8y-|vV{:8H;S>Ѷ fcE)=OkNtU?w 69AIWPv_kZR3nk^)F~ ,ds0Ź$.BȔJMd9bs\اhFaPݝ*y ֬Mu9[%'pIUdNj$rˬvhPnr_h z<C = ÂEKNٴojknx4okJ-⢎]]P{'ȥ8緪-_t1&*Ŭ 0R/W./GAIA5DCt""}t w|6pĦdd) D A+PK6Еyk@c!cݎϥr#RN~Al1OW͒[9 pzqu2c> bH{lcn?| ,9< 6%b hpas:y1ĉi6 '^&|%&mr26Lt#c7?+АZŦcyr2|fޛt JQ:8݀iDO (YDB[ A6G 1 N e`$ lӼ7ܟ[6ӧ42x^I(M8[vXzɾO%(ji|ږvfwƹ5,Fzo;Zc4{4NYi#4)yL%I/*t<)tN+&?Mُ()t _ԯ~Mc.rKKz(G)n"@=vƷM;$ zeh?7~̴a" gOVmģ,K#eȿl0JC|QJf)U~`Qj{ٞNhmgCL;Jۻwu8#m$VyV@vy؀w q;71`eb6֩A %1[%kH mRez{7˥1r|21ZÐP+՞(RP6,k@9zO.FFv}& J,\0rsYm9CQ-]FKn9-* "sxvsªeNRj?scB)})`Ԃ9QDZ."렩Rb?辏YTc&S8[P"$>3iC*i£l-\txPFX~H@X=,5jp23{eCh{2U9ڛWrGi|ı$ r4-SDŽ2TCP:n#9ضo o2!S  Na- جmc#?]"jh=ߐ!&4z 9W&5%=^3A\Gj1pEU:醣,mt J^|7*4'X]R.O"?gv^BNșӷ7gx1$O_ZB}Mux+5F+' 6q|`3GڊySѪTq>eCU+GVRBG8l9 L׋oVU(FRJg@΋o~2^Ӕ{׾XTƆH^ 7B7B1BxS~u^;I!zI;sQXvr)t^ 7M1U˙Otzgă9%~h6̱NPzK~gc3"nS5ހȥֳp͚(w29>ur`7LYBʖVcyIS9o .&~J'_[3 v0m "N_ǵ, mB֯[Zyns eJPO=^K;֠cb{ュRK˓⦹YKh-g #n \1 ,_ taNy]fTRu PNJ *PcU"c8Ѥ+o=t {KYPp-̟qF݂N=[qBFڻN%[t|;G.`r\`"c[74}lټb0iP\ N3]Rv0a0x.eڲfxv ! {捎e4@ ¦QSUmjwge"_\B$CL(W|gtYJcA7/:Tg/v5% 4#2FB/%nVX|j95:,D$Jx3+ 7N;t1KlV燍<[qqȀ-kU)a\O WHM8UF vjcOǤu+/v\&R-fXp0+u~FR9sܔ/w!$eKly lg\l )X'wHOw\IU5@9Pwؐf,KA7ͫXV">UNC$E]GJ4.u[.dzK,gq=R wԘlܰGRFJZQ[G`:y{{`]gPu^oN\>\8TdPuL1]hTW[cznC 7`'w&= 2X39qfˤ$r $:¨*Y,X\ \ /vLd7َ3UϨe4~$<~ 8MJ[C?w؃a/\TD<93\1ߍժtA[ۅrk晇k5NMqxv}9anFݹˮ</i`" 'BVh1 !"/p45/ē#v¸cw]8k⨉LY… Tq8. a{yxo:~`bXK\,{R;~/#^|G]YxE KV#3 ۼdUx~< I60g/oSBSݗjW9*Լ[v$d/2fmP*<2\/5Bnű@:D?cr<9Cں51}XA׀aԉ #qE-nِo#ծ{钶3V)X 38{=֕$I>MzE-[*R{Ѕ#(\S[;;Nn6DU] $˰oKJ(!p D?_"$ h;7="4-cfTfE!5VhFK%'1z2#zK'ك@E{ޢ0J|>@j4 wI%8~=tzSqq=r5H+(!޵Jh_*J B4BIuTGj9Rs13&sec,f_Q+gZX"@0yrpFݙ+8?{Ӄ8mBrmμ7c1E޽#0y K 6ߖ]M^ f'H"(lV]Y-(}IR09\ab4!ln=ZAҶ1/a("1xEWs[ׂ(YЩ JMS|3{>R7+t ?gh"-R}YfBnPsPn&,x3(`d#BLO !FFNt4<>B'q-&M(X iS{d6m-4=zӟ^smY2mT.zK []+q1_Q &[( @"nzT[]*MIQ c?-r_WZ#k1RJV_4H5Ϗ L]cнAzK)bSxk@iq@ ApoP$: A Z`6"ږϕSt'h7>ǞgUS۵>'3B^r>jrwA~0^ƅG;mĤnyZi[WV4=%*o[OGRZ-_oDQR.0K 尿X;֡i^=)F QҨT|BJ a ~Q%Š@{sGJJTw!k2^kഃ_ y+l$Zf 2ĐrKDf/%pтȜBcO!ޡ3ϚB O4M>sK^_k<,[髲z%+E6*b! (>f]rgsّ8luN)7̠( .KQxk2/myZu7T{:;̘ǕVTB 4=l;=_qE3ҧFqhdfDJ >Rsq4͂ijyVFLh96I_٢oA$fL>J`H!c{ 31Cu Kf(&dН/e8iȏIJLpDܽo¶쳒L *„>,eGI&aP&(2,am]"+,kN9J Ed`zQ^u8VcjWA=-HWs>aSB(t#7l=1Ѧ}af;s/GNUx͛+5#7D)lRAOeFHJ5gם҉FQJ [ oj{yJنO#W[wcDG8}ӉZ a׸׹J¾v HT'2,A:8w5MN-QcN\Y7sic_@))wVԅ˦r?мټ(~RA%~G\D}vUqҬŅw܌buml$Y`^j OCk)&JRД^#A69t"aj,vZ;)?L^/ E4g_jТ{$`1;=LS~BKAmmmƛ;mhSS3V.o`bFT#PjP@?}h6+ ;=oPU2Ut(l Ȼ|F $]^bR|0w/,nI%n4.EoA r]?əƊ#a&>j,3Uk p)~Rִo@k2SKpKvIc*H2M; aO>Ō}R4QJHXD~j_2p0`w Em},6|ܚHX6m9W-sMw E>0!527"p9qQ !p—8B\x>V."=@K$e ym{su@brBiP'e3Qё;`*(*!^J%w}+IXL L~y!ߐU>G(dbuid̅x-W 뚜aqWN[{:uu~J?ZΦa.ӝ1bs06r9;D@[@7TWT$o5{9F.I/"I,D(MjNo$6wڗ&$j`eq*qR/ OO܆=D\ت$1zyF4ek-䚧8SŐ*H`#_f^ !m Hh۩9fp Rqp)G0XN=˞Iy5aMv+}[k ߧ?FTؚ"wC +ua Dcut}bu/9_'.٢l1&q^P2VBMoMţME;'ltLҠoJx6_h? ,mH2+ܶgL錓+:;<>|zk+&N[|cm 3v;=9QʏsiBN٤4}OJ(KeP,\pWU^ CReß.<=5Z[U4@A&.5 CEx-`0Zej9rS0v0UZۡ gJņr9|J )Ll0$M0xaJh^Ot ݓ:'?+F 4HJ{IˮExĖUzeUuA7)<ѭ'lD3s)3L E 7B>IDʄ2Iz28pt@]D"S@#`hTjD8hDdL Oy5T TgDE.[ơ5D~C@ɗ8F09j?cfJ‡誋^Q̫S9…SU}`U"to &o8t>)$}N~IƢֈI |uk ,1$yY b&kGf"L$Hr, tvZ_W; eOm[)l#r `qjcO;\)S, ? 3S V qvBY±DIV@ш= ,X`pߜ&Ѭyz;Qe6nN^"ny6o m pQ<\%h~.¶{ı=o4/#8\}" P fI:4#5,Nvxt2零tb-R=7.cWiᘈڸl92}.Ž~B% [.tYg)4Vm]+w*åǠдoQo]@68cd6*C{V5qR&~ KMxqTcD=wK?Zg6rH@K/skc Xv/xag}7J)nڝu_-HЁ>qv"gYC vv՟[a閛z[Tn.efQIm׺Qi.!UޜPF`KW:Ax"Y1}m?h}W6q@"|!s7o?tj`L ~TT d?U%vd_Q.7`~h"2 3ʭW,nW g^T_>XQ2 RAd<˪TMssz 1SY([AL~̃M)pXP$S+ Yfͱzk[A8νX!kLt+bDY)? s @^|HV!4 zUjr`Ca_dVpttCa*`.{:n`F򿅳prx){tD{GEN6h9ʸJz=F2ccnh%}Gu鍕=q iHQ&G:y;s|'t^jIckSX(Ǻ)bIZٙU z5H9m ;]xА #Zd>ϑ{nW;cκaGM~( Qwֺ7!Ń׬)h%Zv1.: e9pM3MTA~ׂf<蜩i'/l/n_(GffHA{2 X.xd#} h,ɪ\ w#YaLkcFxBY \s&jUz$+Itiq7V@/kqMe WJ {IV®]R(s݄Y 6xx&R**R D/c hΣj"T¦{rfFu]@ T+2Y~`{&꒽SxP%(Ab-\JuJ˜pVi m&:xCQQ ofs]'kc q)(L_?wU8H;Zn^Yl%"݆9|MnFH((⏄}BJkRP󥏶p!"GV*Ĥ6 +Ao0V4:FqJ购q0F=}уoWY@YbwU $4#yUJǟjrc 6©g!5=@bc\,n6TBt\F %G'..nrhf^B/|pQy7Y]w7=@~m1qx$24A l=I0Q-U!@vUqn 2&Bv/94[8_ ~;dÌ5qgD "a=EaB,̸!>T,|x˚Z\m;P?(t ? `!`ԊGrZ8yD=^զq1Xp֠R2^@`Qde?v>{-Ա1\y !suFUogQFA:(5wa,2VbY?(i )XL!uҽ 0!]*⾾po)\~YLzYPoi1 >͇tw.m8Nʪ$\a%+5ݯLa~X22G[D W ė8-j-AANq7Or5f{aě+.0;AnX]ßǂ_c`kIHMU\,t:Z㶬f#=>.[֣i8"/Dssy|j̼A0F/ HBįc ]UҨX WtATp\ ,wtA˞Fq! rXd:I|rY,0=W$X51f He1hv UKŝ7m[S'xkۢEc|Y7_QlK|wcm5LƒxMYrɨԏDEP,xmea-L1us{0ywaV FC^Q=Ak1P.Se &i*3agxYfkq~091!hNP"]LN;gnx X 7̲O)\e <$j?fMM]Ȏ1c/QTZk-+"&; !r,WALFb<[P-w&.NSٵc*ɷ4_Wu63~@%b9CFkRɺPc"4*KB&,LlVj? @➢uI4RFvE>fRva>3jn W zQ5f n.E> ;]0{wyUc.J~УZGDÃ38w2rSa61oakjTz`)}[M2Vs}z&ן(Y@cEu#&RGb Boh/훀L&GGcR!fy͋NU3oq篘VsGƠwŽky=(A ڪ𱄗CbޞMG"H۫2f6=i/ɶيIJy93+ɸ˷ .ؐg%^UM:kYf~x'݈$p4GЦVdAI-ČGLU;ȑP`+c^zZ6jF@V~s~N]ہ*w9?4W鴣(}%($cv r!DκtloYjs !|c#Y7HpOhY֏lc$[ 3odL!4ib?j8@Yg:wa,7cJYTXIF*UJŠ ƇryVd_)+b/LOKt@ixNݱUЎ(eD-l{wk 3t@ksYg"gXK] jC{U+E>R!'Ƞ)'9Z,&BP]1]E]#cGL 5$60*âM=sRLM0pB?Q^ NѸƃm yW+Cڇ(za_h'HƟɚNi >x߭ Da>TDHDA\T? \rmckMM*kwZnIߖ QA,s!r7ky=E[-iXGfʁxttS:09yMϒM+(6"E, a@SC7cYΨ)@@ʕ.X?3 1(Vˀ U7¶@j:,O[J"0f% kffjK!?3bY+pt2;dX)75l֪QQ1Y />/z{¶9_{J4zڶ ]\@}pnDi@(LLHs6<]l%TO]/ YSZ7Oyt]Z\L'DrW'N$.\ɢvH8% <[aGBѻZT8\-"q9/͍vf^jV޾¢ 4L0zԀˑyɸy4垚 $) $+=AԹ*<-w?phQ5^)F;2Yrw~v l^άٽfKCA<\G eνe4,!\ ߤ~=&.Tctق 1UW:D+ծ͈_ԻnFtH,pPB' 9;`:=ṿe) 8)D>;vh;n&]sLliB~\P4EĔYQʉ/4; W$>\䶗Қ$a6ĂMD⮕R^˯IFC·hU4-QG>i.$*wZ硥4;of;$>^|gX_[ کl0؝UFSI1If(s%O.i|~66{%1)߆nj]xh99|>Z ({$C~\_ z^C70o'6nĹR{`Zgsqrv_WDZ@(b}eȜqb TlE\JE*SQޡy,#=j$q.I&:u)."^?(Z9c%O- ~gqS q]k/pT ȻNZ^ 2Mo׏ [ [GSZGiIr]N3%_"5kgRsOzmB'|L3 KqpPP zV=(c&>,:@ XW P ?kRQRӚHJr-Ɓ.e-kxFWcvga޵VPr# %r2xI<;ʣ yh8_kd5bı1S)H2bTfCn2]fەgh<cǷO28?JLn^[ՅWqJ]%g,SX|\7| 1GpF!@orP#ٙk rhQj}Vofʬ;T1!پ`)[14)&w=Au3ڊ%iSrfA;PS ,ӝ8znb=d?I^H`@y!398k V[ (E7vy|msNƒL*ƊxĀDFѦiQ?ݟCxdV~Д2ջiFỲlXhfwN@qsI>K':1B:ڏ U˃1 7RtJ/6P ?Xj F_f,,Ôd5{}ж{4⼺+<+8oTGmΛ܈(ls he%2ޮ1῜|}X=D* Tl)g 8:_ Ȧ%J[Jb/ȡm*9>d OĦՕ(*U1إpdY0""f)& Qx@17wQ #M64>ɧv~b Cp=+gX;m˶gp-`n[=rx= "& j%j .#y VBMrx',lۭ*;IW:Ẇ^#4R BKY4Q!-{3I::k'훂hM[G*ll z _IlYaףە½/LiZ2Il1_1$AGݧ!85R@*Y'@o7u75B-$ S]dI׏J ;zRÍNb !D-k7_cweQG}Hl %f"?a4X$]*}sUt*x h3Wiy6MgYe`G5Kݺ|םXGa0IKV~qUl ;oNб&# .T`'եO87ʗ<哾Yn"gvX߬D>.&IX[Pp#Mz)ʨ5-e $ DѴ#.:kIqZm2p cATBBcYlo/Mu{ C=|R- >`4i05xWED M{tdY"Xo&Nդ}Z kvR7WpT OQZ^ \GchVTLN#-p8@ub(˾M@5 7VBy{᷷hu9="BfX"_KɓYuY9F~ (1]E`8?ɚ^I罁ywGu1 s2pO\X26{Ĩ]cX# RVe{vS_^٦;J'MrcW Zg&#'vr:Aa"ٙh3~ >i)4I$sˏG=5 w JI_4g8x'bh>$ ԅ&A[ѿo1duec!s=M@f MgIPvLQo`4>Vm9 ~Phl>?c (BUF'2hȽBzU YgeF\]\c1ŗ@FN٨ i ;KnAҵt <kL''knG'1r΃CE ҷYy \W#LC;o Z4ʦk|iF*6"1CυH.w/m6q<_z {)\b$0Ů-P4;[K^3dn;pݘ9V!RhBʪ{;}+ 5Ez`™7ȚV,)QN*#<}l>}q~*g,"f|#~Gi99[)E /&EO 6Hޞ\^2Bmsd ;{>e008t߲=O~ZoR}*q5E61HZ9g eޕKdPNHKx#cWTKR ՟\ ܿ"ldXH &y]OS`ưO<ҍ;+k_S`ch6#*`At̺nNW9kjR)((iP oxZ5HD--+9!o|&Jq2bYzHIIhqdb%dU >N>tU<׉H<$$ ~Jǝ}}4[{kK,-)Ĩ!0\$aW٢J<l9BQ)e(!Ífͤ4}*_<=Wڶ/DJ{/ʓ!ZKpO%)} 5OSs.,y~$W]uĢك|Əō+l^†i@V_/S(>Dk[P\&`3i=缕^dXUC,vW6~+B=g@>Nu+a(R%a\ Z^mg!C@r>cG4Ky{b/FI:ׂ<-=$4~a­`'~"!8jƟk901G`sԶ}]ӓdsºè\/G }^(~l` cy1 ţ[9WrwWZgr4=u_ѡH2&` Q@fNнRbW3cHH|6e_gP0/NHx K& 2d="T{fuOiXfAK-~/vvqk (+NA$lJ:ܮ,0b!:.̰$kTifL4u0]}#1e}I` Nz9E\eMH՘/(dڄ/Etjfn=) }Go*н2z?O $![Vg`W8sa SR_'ҥA`WҔ9MnIS*֌IMOs>DG@B5T)0jDcCwJD'?5\V9sqŐ9I ZFuڴWdgI>HNIĩuB>۫q棺k{y/Upp>v::1ݩmZC$٘r0&:FSu=7`"t[˨G#J{`|-o(`; Ñ$Oֹ|CuZڥvl=סry{) Ґ?Wfmd]oNٟms|-^ ֿ/u MЌeI@ 3=M"vGZ`Чe7"xL8!&pɄ60QȜljˮ.~~V0pd|pu{3OL[)4Rg0VjZ3Q9Qϼٟ . v]LezI: R[~)S}tȹGZNTYi/q.o|7ݠ6̍Θ붛!i<;[)nHF~*jO Xh5qº#/}o;\_K|ȖnQo~XJ)~ڰ$Zs =pq:Bd/7Ijk^*[ۤN;|bkgKQ@͔E+g'`:CE@E$+l\r=f|LbƗř/]̸6]QSϤ#a _b<\.b.RxNT`1hg}Cw̭to"=Em jR.K$C[&'>Vl |<``#=V$~!\+"6`T9̹ X%΂ZOt\7k C@QeF' Ȗ _E12ؙJ{z=u{Z9el/$O4J.YP|o:?^5ta '?tHC!(1GDc/b-7ם'v?kć0~_#Ww]D&Kc|;Ⱦu/oSPigJR%[V4U$CtL7 96|Yvpo ja'ܟ;W r\v`[:|~*,ɮPC$һßȉg?ҺULHRS=ApVV`+kG-"3ӻd-t ju ~K30=S3fծyM<^*%Q Gh*@?1M7ja')L(کqCQ._\&3 ˲@-|/E:diI~9XHqpobH0uBw\t=yxIs7kꮮ$)gP<*ʬ F/]OН'ߺc"vt63Yo<n22>Dj|0ucDKT('|pSfӆN1aq_v̡PED`Dp?kҟKI:l[DLAgihKMZܥ4:akJgۦdַdGaB5[_X{Hɨd+r;6fq堲:L]^3E籴%nspQtqb1͑1Zؘ‹x)%pMU!jD(7j[jӀ_c enBT9ic;WD3( "Zqϼ. $e`{˫Bb.Y)#L16gƴqJ=6nAQG2OS{[~Yg!;'& >ukImPWO临B# %s4̡!pA\=kናQQ/3cIO>*e~bO'\hq^*4|÷I`jJ*#wYig?i+o㗘`/܄|9Z ãa5pu֭ WT0vW%X&,FAV _fEPOtM/ITeD?ԗ'(AH6Eukkp7f0к9[*9x^aWHUzÃӫ4ÊYfST-wIUE HT~mAiѻEw35J|VS2d6njѶ&?w voNj‚me {:*s_@V ~k-ݝŀR~سxTUcviN9*!qR2(vH?;l7*Qz\,޻n-0b<۶8隈Ck I@[V[nXxs4XjY='I\ G=_-)xkkWJ7fRO6ώT|I 02nQ~4Lx͘x]+l܎Ks[bƬ?G&K=Ūc^ݿ/3.ԅ`T'2f#tTXkxk <(YUr5NҒl/|#Po-F_4air&3?hD/=j0pk?򯪤=+Dh/֫Sq7B"⥑sX t=`0 ݔx1S[u6Rd3JEZ4'hP~\۰6x -f$M_-^59s#^ *ng;{b-C-ӷ_Q3v35 *S#!o9CW0x2΋r%jɬ$OPKΚ+!$<&ne,1iwJ{ g K 0IMQ&DžI!: (ByOzgh|h)8 ^l!<.٪+5bNSx n-ȪfFSzEtգl>IOh Xd '8ڙ ~.Cw̟)h-}tn`qY> \u0k.5sz/[{J//f5ܥt1iJc2omH~iǑ䈘Ge+o)Rܚ"`)^ӊ B$@vfĜ`[@VשhY(Pr_D :g{xzA LeP`TCdQ-gD`*13#h1R.;COcoQJp[((K:S` qȏ^q^RtU/} Œ l\`ݴJ^043>ATcRQ˭}lǂF6͡,}~ 9 ۼ[,60u[w$|T\!h79%R1r(o HyfLԤk E^E kylk&jDMeП8XIob">C1d)arpʏzi\'Wأg;9m#:*Ĥ!..=ހiw=!i˘r!k 3~ 3'6,Q=ϰf\!y?othoivM͖$@z@mcHd>f ^rI='pgŝCǔ;6w?d*ЋQu);n2X0SiZO`7ӲL-K^,},:8y aGA2G`_o{8拇2%J⧆/:1ɥ%."\aձ/"mK # PiY{(j[59'TwIM,B8G" TVscf4'4qL5a!B;X?makz N3ŧ{鈣]lpn9ByMxt&0UG~] SbImZ)rp5Q+7CsȜ=tHca!al15OM٨X[n7w}Ic;o# c8ע.75iwdDf3 t-+@5;=sfK^eZd[vizD_Z?B'3yHTuev m>SGa^A0OkwEk3.tg))+{C~/*1y3&#I{8OfuLi@h |bH͒nV#Lhcb?%7xLL ]V -7 4|wH,~vhfK Í8đknCFmfnK4뀆|$zGv)Ag>ÂnVc(d%.ƚ(\ZF_h!\4ͣ=&7̈́:%@ŽF`iΆs~6-ٖd3GLOx{}~;QHs+53Mkz(?n^'BHH60Cƈws}i{xNiO̷޳\-b~)jGb,EjwPY <UI7`i ⑋w yVfd0˔4&ݿ!>)Dk<ߌOU(iT jU,=Wӯ-?fa,ɀgbL(p l_^0bU8Iee2j?1!L aCx[6J:bNM0qge<\ljq Ous!xٚcl@ Oy@8 jD1BT {vސlӁoհ?u &6>8J)cc\ v3nKq 4*^60HS|tۗG0`R8ҏ]fQgU3-#i=CZ04֦W mHIֈʘ.ZMP:s פu' L륆L~2N=?@&\c4"^J9zp*-LGrAI0n<(otgxvz͓ȁO{~VoLţ<FnS\%MHԇ}!ȴ"[Ѡ]L0ƏΡNDDƩe(80D ?ީ꜌:Go|vSZh_=t@f2(CF$,1}$d6FIf@fr䓌V\04I'cu%)5}~.G;YJTZ ϮO9K"h&߶ 2Ԥ+NJvR'g٧&|lT=zluuY|SSջA]gq Կ?0}T<뇍K60ܳѨh| qnJxlLh)WOⓎUk->Ϭ{7Ah}i]fA&޵^ .V~dG  _#eݒ@}?!:!Ʈ{8>VeLQO0?7 veUy*L86/M+y=_ #YlTDȁ+[.vAHS0BlC2⺥Ke dV3=˭VQ91EBɖYx".W%j< O^ 5;rO0Θe l'1k7)+Zq4|g.X4!REٹQ褢|C}(Wdߦ CY 4U8԰KQr"oZ4,ckdi*3r˲9RaA_ZX2ihgD<79[Ylu甧_qWq[ 6/1772IpF_ƦZ]?qV>="ctnDM%v^qy,} ,>V K sbU#B5ew&J? u^Z 揇-2>xfv3z~}uiW^s,7oG,ޏiŜ}v,&b18"iyP?B_Xѷ|ȆR#@x M[W6R+p+h')Qvn}ecnw/b>| YGjoG(u;eǃxg6[ 1a?yYAD9"7/+|UVjH2M?<^zBL!)glyay >~))Z\2鲒Ra\;g_eytsj~ aMpbf|L)Ψ/U94M`lZxk; jbU5֑}981n`yTh/ xHw9@\?ؓ:DķWWؚ }p>ʏY!r_1IY79QJ ='"m.O  cddop_Son)sw /)Xu'M읔j%04W\prLB1\"{eƢPV{lC!|@)sN=/D x d@KQ\5$ )lwt~؊ ț m֋j6wCwlM{7KYfEbu/ 3w6hj7 V<@T =I3{L|'e#hHYeNĤ ̖ie mp ?_N .;Rkxbn5RC+\KG3tnv^ c繚,. IOݰU]qG:x0\1 -Rw2߂~~]U{pLGMEҾxSJ:2 VUck$l`@8X_pW"-,92Tŏvoot$MDThi2FD^BNhbftI+Mup@iK>]ڜQ~ӳX$$ 1,JUh-  )lvE>}9T ck1:%4;@@Y'[l}GPIX#C#Uڥ  F4E8= decY=',r.E 9_٭fG1"wր`_0,XH'8&KM9gzܴ0ЎLYŦyt1@EHWp/ Tly/ͷx:u!霻Ler%Dl:BP M: 9>E:Y)s|jKNo?IJ"{FI$8 Ycsb%H|q"kHiQqH VY)B/fY Kef։3DԧzCPYv^|k>5 S{K_813й >2cHN# %a IZȼsVa-uDJ[VgW߃eL6"d|x,@JaWۮK L.' p.v3d}m1Qxd)kM?Mo23K@AC cHӟ%UQT<*/lU[,eT{Pg& ҁx!ƃ)uw,U$nc8ϑ뼽F'7`Gh2=FwvlhrCVn3~-w뢽wq||#rr =O ez`c 9JkeKHSaO%Vm_]gʍ`/=ɩ< ~/z 5t`R\Nh%;=Hqs{ JhfMGoI=dw4R`t{}dAu ?_Ahv.b<4Jvq%ǨE& ;#ab&ZUHvJ4M~]!/\yĤEoG:Hw{J]K=Y /$_`6Ύx_@RBhHb,6_Cmnu6ǴO ozP&Qh&Z? =!53J2VP,UusdU4QD)2{B#F Y{tAp4R h#V-p7jJ]B@I^c`ud;Y >F? 7N"&v-Oߟ5rO( y",:6n99T}Rq65vˑ|,Q܇4A{/p^5 U8}n 4BP:).soo'َӫG l%4b}!_*9hsgEpRhl)C;3I#O<،DbJc Gn4+6UDv^+kݝ_^ځ-W9,̒=SJ ^O \şeWkJE=)iGYZDzO9h3 ؊}#_ЁOCJ Z%%th.^ۘ[~a&UܞDr@q|4 ٥Whx>mGO >{0&~6>]c>Աd4j2p E985+}WU0C+@AC5pDЮ]D?sQ^(blm=<[0-q),D?+QhYC2,cq3:Gʋ7tИ*Zj!@!d*tթh$W3fxZrPUր^ʈ.".+>SkUׇkVv&!'z>$-':F!3S)Px],MriC.g'{bq ES8GvO̤!@WP:X{`J-Cm.y !ʱb:E+PG(yw+w3K@Õ"s-GZVk\^cC FFWE2uqgsj4?SToخ7tu1lC2*)UJMVu ߦl&zw9ÈF.: }}3җA:y٠9SUp=&z Y3B1̧ EoE&!%6,a rN܎4Nݗ $jLQc{,>6^ .Ysm)-J.BYCj!?T-xΟI!٥ȑ8y Qħ1縡^%1pP`ͧpO93sĴ1ZwquI[Q̾Q3JИhXwsSm:jѻIU;gn| 'C6M]C#r$ߏu8]& 3I =Zk#`ZXip/VH)^Rd"dc2mTYDZ׉޺S`B'DwViaZF%^v`V6%Ÿhɍ7 e/5_ Gcp,Q7Ptnس #άlgܚ2eHB#"*;[{  $HOmIE5\ 5 %W۳l͠!Nef)Y91hcdMNm -Zg@9"ǝQdXLhli m_/vYXlΣڧ}O7VQaʸжi=V~kw|_T6dDbNw&%ZoOys" -wz;F!`F3$+^݂L8.-a_|y/NQ-hʲE;t-;8H&L.N,S )ܳ7)f@1IXdq2TCbkE-qn7IC3fƋG12y30 )M+mBd#ĽMѱdAA|/>8cRcn6* Dԫglf:@1v_lɣU2hP^DM2b0滓Kj^ayghq'?PʎD Ngp?AJi$;]*RW=J'^ Tq#ZnS[KZ)a2͟d[ugKEb2/lgaR <^e,X!NGf/n}G B.eohC"z)?0 ãL;߶ŕ_kԦ-B~OeI]a'AmiMy"uhmuT z❱;"}ARUyHr\ǞGjq΀B]`J<[ a<gH18#oQcdy :pnJfk_a>˫jpg)nq %P)O?HS~SڴG}Yc5p3l_|}:I(+O=>ڭ]yǡ\/td(vvAH&o5w UҒα|e(f1R}Oi.\/.FXP=8h\`W /jLU6Lr/I}9}Rd8Mzп[z Ϊ9)l}0(Zj| wWnkQ}Ƅ&n lWG/ H]6_NAm9t>=?P_ ҖpSnP2hAɌW[r*LwS%^mMDΏtL EXߌo.:Rpҹ91m|'E[2X.vȼu^pE;nJ1hi3TwEȴfG\S< ެ?aCfFmV•s \~[P-;*(F)C/tJ7O1r伵Dk)r@g)Jgo?Y$@Y1/h@jݓn;6RA{1)OƨJ))-"V :Ydدr|1fbxUiatzM4a@n*Ý`T9EYaӢ1H},_׫zw,~-$.Kfc;GOv3^T8fWq᪩Fp{Z݅Ʀ$MxgZr)u玒WS/oy .d+yHs7h`KȠ`Hʻdݕ.yJ_YK`>F]qNb/%?%~M }c j+A9mVr Uv,Ȓ^;R`@p(pix|#Vϸūڅ;0\EF-8FHcNQKDNm5f#Nd1*Q|ճq_ҘkO駋Gؘq55=m/eFy=H泫b:Ll[ӄK{<* Zad!p_B7FFR-0rEtb:٩)Pպg П&@H7U1I V?x|BDvDMis[%$8`?| 60?Љ PU-?]+$G9ǀwCg`Rޯi/Uk+)3w/!.=)I͑G}(0Ĩ,0MxL&[<;YVr A*Ҩ3Ʀ?O mw0LδcYXƾ#P 'ԗuXW'C|#)1=qwA71_c&yX㐗gk[l\M-֧0}C5B5V P@tx)b- a+T:>|+.ĒFПQatۖ-duɰ`DSPØ-XFhB#;B^I?>wRx%q+(vQNxqV')AF ;YW#Cԗrm!퇯PV(9]4YeuVI$srN{.8Zz?FDYOc#HA{;Objіv: yIog@Y}p%fYzqQЂv")U #d1]y~/S>ޘgq#k[[i#37UFn˵%ف1:t~x7l2K+3zQrֳG e& BW1p@K.2uwP.tǗ+z/@.a: [glaݧk|IjD/Yg=?!3O`~,|Uz? 0k0)EZ[(E0%2ng{ܭJ>PBbp{/oF{.js uS­alR=DkEP׫-ΕH+8/x|Q\ `\OZrEwL%WhoY+~PkF%8g%Rm&X j?' \=΋Ed GPr?I:.eӱA !C;G229!tIm/[F+.meā?I#>Yw!!C*5,i+<Ov<"++:I,xt0M}ׁ[?OG{h,;r;3[`אGzu+"=V")re#~o-e,[ ,(5Tܐ?]f~9A',w" gv~uCm|kG_KcE \|W6m12sCY,8  }<ăE+n*+nocgE_!.xƀd v I#$C_xVXiW_Q"/%S|{^kVH٥Ӟ6B_$ws|74Íڛt~im+hrAU0B5scLR}C˱e٫Syn Ji*bM9ĜrrX\ltɴ RA6j}^еk:l?,⪆S<2uz"@2:Ui"9uyL ]/G}Ľl?Wʧy (F}uH-*4&Ľy%nk,BX:!'0ÎT!5( ycD6#8Ν73mVm.o6vdsAK/#\I3@B`{׈/yS 3 |H%z;7mkT]!QSg7 '~]_'r^Su[ϝ'C7WmMif:g.HXXm`i,^jw\=B<IJP `x҆I&9u)Im@ 'MxI|!'.1E{EcS"9Ol@6l8FOcWL޴:o##2o C}T *Ft[I0&!Oo.[t6dFp8"a~}썗}7AU5d Xgff7%qӶͣTuoE`c@ᝀIy*<ĈQBԬ PHXJʳI b.}}50]k5rNr.~{ %\E zT($ٸf&ZZ:UҹbVJ2D,'7QEdi Vws&m`PҽTduhy!m|0rɤFn(e,A[ 9D(#JbKpAPf8}# ޴I%5XHь!竚9 [1sl&뵫y屽;{O7\^%tWb)% ޮ`Z~M ̠u(~gAe34c[#r%t\ǡ?e@A\1OFO衘>z' 6-+\!"I |((XCb񋿽"mzB! a \Z@$M֕^UK. )> SyñM`䊑3Ӱ 9^&E) !63+mx!xK{ٵh拚6*l -E.Sz gP@ g]?“)M|h;#\ CAn孽îl<(ifj\b!? v'y7 qJ'8ۡqMŎꀻ.eӾ 3냇X?/C bg1Ayy;m_7גEU:>$(ѻxy)Q:_JEfۢ&#\$3@ 87/6K^}fҜyeM^Ey/0[]o`Zے"Zuu&?S?!JXf6Vio"J33'sW?lBl`QjxRvkch9"Jh[*Vm SXzYCmiYZ1Y[V^ db,1>,DH$qB IN$Fx跫x JK!6RIHrgmtxҸ |0ŵ{wzioť{ֱ' mU@ J9d?CW8P~dŸ卞-XZa?B-$OPM LwS< AN>&U&n*q|R3h$.z?_ܫl+ƿLK~<ЁɚX;u.|kg/ڦþ :u7ѻ=D'w8#CCZ G]Rݢ,1 뗻.Jx0p3jU~:`Eq-)eT Q(f|T&ҳAMD͍%./7f^^f>Ôu7r[ۃ7I{VE*땢S%𻠨Rk.>i _ lGHV-ݕ y%-WCIĒǐ9M2l-nO2ly6Kgo@hO&QE+Z~Am[oh5~w<:tq#h,t{IKUQQAvQBK_ `E7VާuDd-{iB$ґO")嘮[g tՠN:Dm5O :p:V=CsW}΃ƯQ Js\BZcxz2АN#F*dZ>BrV[i:b' h>jdZu Laq@q_Db9*-kĠ;m?K۾8̖ǘin\|WRog0Ȓ9aPLJ|<^m$q/}DİCShnL1 ĘC%UTuy(m%LoMu) p]eo[]a0u{KJ13(dS[qcVP7NKаͻ\pf #x5<%xh8C, #ju\ ?ps3V2 z~X% c%|NMFV>"8oLCֲve YZ