firewall-config-0.9.11-1.el8 >  Hd U]^ ;}r~8ȓkWMS&O҄VGRZ^  hV RXW5B0u@-S,6Q1 0gUw!7-?uo6UP >Զ* P{wjWʨdn%^_#:-Ȩ 4 uLhR썵zmJh%u|ZVGvs$Xc?uW|Sf?m+O<,J:ZS Kf&bנP+ 2-V;d*n^GXԥl[]I#"Ko% J+p%'y0Y+-cGe6VtW/_܏7M۠|w\t7 g>}OyO[D>HK5w:,稚G&Vה䖇ʲuӎ`Έsq\Eɲ,,7` 3#2 @M<89F S(?#-UA4벴_ DЁlLͭaF&DIlAﵐ^Ub>TYKQ".,< "%8wҷ[B&L7#;~BÖ7@Q3뗼u->[]@r&(5cpnbNb,xdYwVfz;4 hI>KHwgN6 } zU#m+|~ar&Soo; M$SxPa CD"vuJN%rD9;Y_jOXٌ_=۶]]! ">Wqu堽:%vg}O$Cمs3qn2%_P@>P<&?&d  B  X t   V d(H   (8(9 p:%`G$H\IXY\]^ C b!d#e##f#&l#(t#@u#xv# w%x&0y&h&|&&&Cfirewall-config0.9.111.el8Firewall configuration applicationThe firewall configuration application provides an configuration interface for firewalld.dx86-03.stream.rdu2.redhat.com,CentOSCentOSGPLv2+builder@centos.orgUnspecifiedhttp://www.firewalld.orglinuxnoarchgi  m ́큤dddddddddddddd37d916af7674f831354a6a82afc07c2ec028ce24e4e836d86c5746460e27c9ff6080b60f10952847a02ff58463edbd845e860124698410551ad9cf1b8bf76a4592654f2a9bbb1f82ae2dacae50dd540ef05c6be4894bab0e7e1588ac1bb42f236d5b33efad002f15b318e63482706e01a2b1df6ed9b902970374b51a7234dfe7f06bca8b424798b7eab76800bbd9c9b6d8e31cc2615c0055f2e49d221c470eeb7f76ffea9100006823452188c954696a7c9dd92d6801937a23ecbcea2ca0323318536ed118fe42b6a27c94891454fdc709a79d4e34171048154b26c3fb2c9fe44ecf3ba61c8daac7e13a258c9bc490dd6692b0494a7f83b9ef655084146dec152732f3501a2b9262bb1458713f5f5a980655f7ef5d48cde66902643f6134bb4742de1cff244f46065694258388751f164866b9a8faaa6ae2494f2cbc5aceef511af9a194fca0292ebb1458274d5d874e4ca86aaf437a1a051ef6cf721ea70e546b9c7b22d21db4f44072f92bf8b71ed68df0dc8ea48a071e15d6d9298c0cc8eda6a4ee7e2cfaac8c72d8f4964f7faac325104cab29d554a5305caa43e2d264a7da605e96218fccdb19a26bc8d1e4cd09f6c8e5b53c4759377dd149538f01753brootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootfirewalld-0.9.11-1.el8.src.rpmapplication()application(firewall-config.desktop)firewall-configmetainfo()metainfo(firewall-config.appdata.xml)@    /usr/libexec/platform-pythonNetworkManager-libnmdbus-x11firewalldgtk3hicolor-icon-themepython3-gobjectrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)0.9.11-1.el83.0.4-14.6.0-14.0-15.2-14.14.3d>@aap@a@a@a@a@`@`@`````7@```_@_)M^^W@^8 @]ʞ]d@]R@]Ik]6]:]@\;(@\4\@\I[[[;@[\[ug@[r@[m~@[l,[CN@[?YZVZI@ZI@Z@Z}@Zz@Zz@ZOhZ6\@YYx@Y:XX+X@X@XOXEVX@X#X=W@W@WzOWs@WrfWL+@W0{Wo@WV@V@VVHVA@UU@UUa@Ua@UUzUzUKSU/@U@U@T@T@TLT=@S@S%@SSR@S@SSSR'R@RR@RxR_@RNRM\@RL RIgQQQ@QyQ@Q@QnQT0QIQ8@Q$Q@P@P@P@P @PpP~PIP3x@P(@P!@OOOc+@OaOU@OTOC@O1@O/MY@M!@M!@ME@Eric Garver - 0.9.11-1Eric Garver - 0.9.3-13Eric Garver - 0.9.3-12Eric Garver - 0.9.3-11Eric Garver - 0.9.3-10Eric Garver - 0.9.3-9Eric Garver - 0.9.3-8Eric Garver - 0.9.3-7Eric Garver - 0.9.3-6Eric Garver - 0.9.3-5Eric Garver - 0.9.3-4Eric Garver - 0.9.3-3Eric Garver - 0.9.3-2Eric Garver - 0.9.3-1Eric Garver - 0.8.2-6Eric Garver - 0.8.2-5Eric Garver - 0.8.2-4Eric Garver - 0.8.2-3Eric Garver - 0.8.2-2Eric Garver - 0.8.2-1Eric Garver - 0.8.0-4Eric Garver - 0.8.0-3Eric Garver - 0.8.0-2Eric Garver - 0.8.0-1Eric Garver - 0.7.0-5Eric Garver - 0.7.0-4Eric Garver - 0.7.0-3Eric Garver - 0.7.0-2Eric Garver - 0.7.0-1Eric Garver - 0.6.3-7Eric Garver - 0.6.3-6Eric Garver - 0.6.3-5Eric Garver - 0.6.3-4Eric Garver - 0.6.3-3Eric Garver - 0.6.3-2Eric Garver - 0.6.3-1Eric Garver - 0.6.1-5Eric Garver - 0.6.1-4Eric Garver - 0.6.1-3Eric Garver - 0.6.1-2Eric Garver - 0.6.1-1Eric Garver - 0.6.0-2Eric Garver - 0.6.0-1Eric Garver - 0.6.0-0.1.alpha1Eric Garver - 0.5.2-3Eric Garver - 0.5.2-2Eric Garver - 0.5.2-1Igor Gnatenko - 0.5.1-2Eric Garver - 0.5.1-1Fedora Release Engineering - 0.4.4.5-6Igor Gnatenko - 0.4.4.5-5Zbigniew Jędrzejewski-Szmek - 0.4.4.5-4Thomas Woerner - 0.4.4.5-3Fedora Release Engineering - 0.4.4.5-2Thomas Woerner - 0.4.4.5-1Thomas Woerner - 0.4.4.4-1Thomas Woerner - 0.4.4.3-2Thomas Woerner - 0.4.4.3-1Fedora Release Engineering - 0.4.4.2-4Stratakis Charalampos - 0.4.4.2-3Thomas Woerner - 0.4.4.2-2Thomas Woerner - 0.4.4.2-1Thomas Woerner - 0.4.4.1-1Thomas Woerner - 0.4.4-1Thomas Woerner - 0.4.3.3-1Fedora Release Engineering - 0.4.3.2-2Thomas Woerner - 0.4.3.2-1Thomas Woerner - 0.4.3.1-2Thomas Woerner - 0.4.3.1-1Thomas Woerner - 0.4.2-1Thomas Woerner - 0.4.1.2-2Thomas Woerner - 0.4.1.2-1Thomas Woerner - 0.4.1-1Jiri Popelka - 0.4.0-4Jiri Popelka - 0.4.0-3Fedora Release Engineering - 0.4.0-2Thomas Woerner - 0.4.0-1Fedora Release Engineering - 0.3.14.2-5Adam Williamson - 0.3.14.2-4Thomas Woerner - 0.3.14.2-3Thomas Woerner - 0.3.14.2-2Thomas Woerner - 0.3.14.2-1Fedora Release Engineering - 0.3.14.1-3Stephen Gallagher 0.3.14.1-2Thomas Woerner - 0.3.14.1-1Thomas Woerner - 0.3.14-1Stephen Gallagher 0.3.13-7Stephen Gallagher 0.3.13-6Stephen Gallagher 0.3.13-5Stephen Gallagher 0.3.13-4Jiri Popelka - 0.3.13-3Thomas Woerner - 0.3.13-2Jiri Popelka - 0.3.13-1Jiri Popelka - 0.3.12-1Jiri Popelka - 0.3.11-3Jiri Popelka - 0.3.11-2Jiri Popelka - 0.3.11-1Thomas Woerner - 0.3.10-5Thomas Woerner - 0.3.10-4Thomas Woerner - 0.3.10-3Fedora Release Engineering - 0.3.10-2Jiri Popelka - 0.3.10-1Jiri Popelka - 0.3.9.3-1Jiri Popelka - 0.3.9.2-1Jiri Popelka - 0.3.9.1-1Jiri Popelka - 0.3.9-1Jiri Popelka - 0.3.8-1Jiri Popelka - 0.3.7-1Jiri Popelka - 0.3.6.2-1Jiri Popelka - 0.3.6.1-1Jiri Popelka - 0.3.6-1Jiri Popelka - 0.3.5-1Thomas Woerner 0.3.4-1Jiri Popelka Thomas Woerner 0.3.3-2Thomas Woerner 0.3.3-1Jiri Popelka - 0.3.2-2Jiri Popelka - 0.3.2-1Jiri Popelka - 0.3.1-2Thomas Woerner 0.3.1-1Thomas Woerner 0.3.0-1Jiri Popelka - 0.2.12-5Jiri Popelka - 0.2.12-4Fedora Release Engineering - 0.2.12-3Jiri Popelka - 0.2.12-2Thomas Woerner 0.2.12-1Thomas Woerner 0.2.11-2Thomas Woerner 0.2.11-1Thomas Woerner 0.2.10-1Thomas Woerner 0.2.9-1Thomas Woerner 0.2.8-1Jiri Popelka 0.2.7-2Thomas Woerner 0.2.7-1Thomas Woerner 0.2.6-1Thomas Woerner 0.2.5-1Thomas Woerner 0.2.4-1Thomas Woerner 0.2.3-1Thomas Woerner 0.2.2-1Thomas Woerner Thomas Woerner 0.2.1-1Thomas Woerner 0.2.0-2Thomas Woerner 0.2.0-1Thomas Woerner 0.1.3-1Thomas Woerner 0.1.2-1Thomas Woerner 0.1.1-1Thomas Woerner 0.1-1- rebase to v0.9.11- change default CleanupModulesOnExit=yes- feat(config): add CleanupModulesOnExit configuration option - change default CleanupModulesOnExit=yes- fix(zone): detect same source/interface in zones- fix(nftables): rich: source address with netmask- fix(nftables): do not log icmp block if inversion- docs(firewall-*cmd): client conntrack helpers must use a policy- fix(ipset): disallow overlapping entries- fix(policy): warn instead of error for overlapping ports- docs(conf): note that IPv6_rpfilter has a performance penalty- fix(nm): reload: only consider NM connections with a real interface- fix(ipset): fix hash:net,net functionality- fix(direct): rule order with multiple address with -s/-d- rebase to v0.9.3 - fixes from upstream branch stable-0.9- feat(service): add galera service- fix(zone): add source with mac address- fix(rich): non-printable characters removed from rich- fix(nftables): packet marks with masks - fix(nftables): icmp types with code == 0 - fix(rich icmptype): verify rule and icmptype families - fix(zone): cache rule_str for rich rules - improvement(service): IPsec: Update description and add TCP port 4500 - feat(service): add collectd service - feat(service): Add rpc-rquotad.service- fix(cli): add ipset type hash:mac is incompatible with the family parameter - fix(cli): add --zone is an invalid option with --direct - fix: update dynamic DCE RPC ports in freeipa-trust service - fix: core: rich: Catch ValueError on non-numeric priority values - fix(rich): icmptypes with one family - fix(direct): rule in a zone chain - plus additional upstream stable fixes- rebase to v0.8.2- doc: direct: add CAVEATS section- restore zone drifting as a feature- fix: CLI: service: also output helpers for service info- rebase to v0.8.0- bump nftables version requirements- backport patches to sort source-based zone dispatch by zone name- backport patch to show service includes in service output - backport patches to fix dbus API break- package rebuild- rebase to v0.7.0- backport additional patches for RFC3964_IPv4 filter feature- backport nftables support for wildcard interfaces - backport RFC3964_IPv4 filter feature- backport fix for lost NM interfaces in default zone during reload- backport recent stable fixes - backport fix for lost NM interfaces during reload - backport rich rule priorities - backport fix for set entries not applied - update translations- backport FlushAllOnReload feature- use py3_shbang_opts for lockdown-whitelist - fix cockpit patch causing test failure- rebase package to v0.6.3 - use py3_shbang_opts for interpreter invocations- python3-firewalld can get by with python3-gobject-base - firewall-config can get by with python3-qt5-base- backports for new failed state if startup fails - backports to use explicit RETURN on user defined ebtables chains - backports to fix nftables AUDIT log support- drop support for ebtables broute table- add more ports to high-availability service- rebase to v0.6.1 - fix patch adding cockpit by default, fixes testsuite- Use correct conflicts version for cockpit-ws - Enable cockpit by default in some zones- rebase to v0.6.0- rebase to v0.6.0-alpha- remove fedora-isms and clean up spec file- remove python2-firewall subpackage- rebase package to v0.5.2- Escape macros in %changelog- rebase package to v0.5.1- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild- Remove obsolete scriptlets- Python 2 binary package renamed to python2-firewall See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3- Fix spec file for next RHEL versions- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild- Rebase to firewalld-0.4.4.5 http://www.firewalld.org/2017/06/firewalld-0-4-4-5-release - Fix build from spec - Fix –remove-service-from-zone option (RHBZ#1438127) - Support sctp and dccp in ports, source-ports, forward-ports, helpers and rich rules (RHBZ#1429808) - firewall-cmd: Fix –{set,get}-{short,description} for zone (RHBZ#1445238) - firewall.core.ipXtables: Use new wait option for restore commands if available - New services for oVirt: ctdb, ovirt-imageio, ovirt-storageconsole, ovirt-vmconsole and nrpe - Rename extension for policy choices (server and desktop) to .policy.choice (RHBZ#1449754) - D-Bus interfaces: Fix GetAll for interfaces without properties (RHBZ#1452017) - Load NAT helpers with conntrack helpers (RHBZ#1452681) - Translation updates - Additional upstream patches: - Rich-rule source validation (d69b7cb) - IPv6 ICMP type only rich-rule fix (cf50bd0)- Rebase to firewalld-0.4.4.4 http://www.firewalld.org/2017/03/firewalld-0-4-4-4-release - Drop references to fedorahosted.org from spec file and Makefile.am, use archive from github - Fix inconsistent ordering of rules in INPUT_ZONE_SOURCE (issue#166) - Fix ipset overloading from /etc/firewalld/ipsets - Fix permanent rich rules using icmp-type elements (RHBZ#1434594) - firewall-config: Deactivate edit, remove, .. buttons if there are no items - Check if ICMP types are supported by kernel before trying to use them - firewall-config: Show invalid ipset type in the ipset configuration dialog in a special label- Fixed ipset overloading, dropped applied check in get_ipset (issue#206)- Rebase to firewalld-0.4.4.3 http://www.firewalld.org/2017/02/firewalld-0-4-4-3-release - Speed up of large file loading - Support for more ipset types - Speed up of adding or removing entries for ipsets from files - Support icmp-type usage in rich rules - Support for more icmp types - Support for h323 conntrack helper - New services - Code cleanup and several other bug fixes - Translation updates- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild- Rebuild for Python 3.6- Dropping firewalld-selinux package again as the required fix made it into selinux-policy packages for F-23+, updated selinux-policy version conflicts- New firewalld-selinux sub package delivering the SELinux policy module for firewalld (RHBZ#1396765) (RHBZ#1394625) (RHBZ#1394578) (RHBZ#1394573) (RHBZ#1394569) - New firewalld release 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- firewall-config: Use proper source check in sourceDialog (fixes issue#162) - firewallctl: New support for helpers - Translation updates- Fix dist-check - src/Makefile.am: Install new helper files - config/Makefile.am: Install helpers - Merged translations - Updated translations from zanata - firewalld.spec: Adapt requires for PyQt5 - firewall-applet: Fix fromUTF8 for python2 PyQt5 usage - firewall-applet: Use PyQt5 - firewall-config: New nf_conntrack_select dialog, use nf_conntrack_helpers D-Bus property - shell-completion/bash/firewall-cmd: Updates for helpers and also some fixes - src/tests/firewall-[offline-]cmd_test.sh: New helper tests, adapted module tests for services - doc/xml/seealso.xml: Add firewalld.helper(5) man page - doc/xml/seealso.xml: Add firewalld.ipset(5) man page - Fixed typo in firewalld.ipset(5) man page - Updated firewalld.dbus(5) man page - New firewalld.helper(5) man page - doc/xml/firewall-offline-cmd.xml: Updated firewall-offline-cmd man page - doc/xml/firewall-cmd.xml: Updated firewall-cmd man page - firewall-offline-cmd: New support for helpers - firewall-cmd: New support for helpers - firewall.command: New check_helper_family, check_module and print_helper_info methods - firewall.core.fw_test: Add helpers also to offline backend - firewall.server.config: New AutomaticHelpers property (rw) - firewall.server.config: Fix an dict size changed error for firewall.conf file changes - firewall.server.config: Make LogDenied property readwrite to be consistent - Some renames of nf_conntrack_helper* functions and structures, helpers is a dict - firewall.core.fw: Properly check helper setting in set_automatic_helpers - firewall.errors: Add missing BUILTIN_HELPER error code - No extra interface for helpers needed in runtime, dropped DBUS_INTERFACE_HELPER - firewall.server.firewalld: Drop unused queryHelper D-Bus method - New helpers Q.931 and RAS from nf_conntrack_h323 - firewall.core.io.helper: Allow dots in helper names, remove underscore - firewall.core.io.firewalld_conf: Fixed typo in FALLBACK_AUTOMATIC_HELPERS - firewall-[offline-]cmd: Use sys.excepthook to force exception_handler usage always - firewall.core.fw_config: new_X methods should also check builtins - firewall.client: Set helper family to "" if None - firewall.client: Add missing module string to FirewallClientHelperSettings.settings - config/firewalld.conf: Add possible values description for AutomaticHelpers - helpers/amanda.xml: Fix typo in helper module - firewall-config: Added support for helper module setting - firewall.client: Added support for helper module setting - firewall.server.config_helper: Added support for helper module setting - firewall.core.io.service, firewall.server.config_service: Only replace underscore by dash if module start with nf_conntrack_ - firewall.core.fw_zone: Use helper module instead of a generated name from helper name - helpers: Added kernel module - firewall.core.io.helper: Add module to helper - firewall-cmd: Removed duplicate --get-ipset-types from help output - 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 - firewall-config: New support to handle helpers, new dialogs, new helper tab, .. - config/org.fedoraproject.FirewallConfig.gschema.xml.in: New show-helpers setting - firewall.client: New helper management for runtime and permanent configuration - firewall.server.firewalld: New runtime helper management, new nf_conntrack_helper property - firewall.server.config_service: Fix module name handling (no nf_conntrack_ prefix needed) - firewall.server.config: New permanent D-Bus helper management - New firewall.server.config_helper to provide the permanent D-Bus interface for helpers - firewall.core.fw_zone: Use helpers fw.nf_conntrack_helper for services using helpers - firewall.core.fw: New helper management, new _automatic_helpers and nf_conntrack_helper settings - firewall.core.fw_config: Add support for permanent helper handling - firewall.core.io.service: The module does not need to start with nf_conntrack_ anymore - firewall.functions: New functions to get and set nf_conntrack_helper kernel setting - firewall.core.io.firewalld_conf: New support for AutomaticHelpers setting - firewall.config.dbus: New D-Bus definitions for helpers, new DBUS_INTERFACE_REVISION 12 - New firewall.core.fw_helper providing FirewallHelper backend - New firewall.core.helper with HELPER_MAXNAMELEN definition - config/firewalld.conf: New AutomaticHelpers setting with description - firewall.config.__init__.py.in: New helpers variables - firewalld.spec: Add new helpers directory - config/Makefile.am: Install new helpers - New helper configuration files for amanda, ftp, irc, netbios-ns, pptp, sane, sip, snmp and tftp - firewall.core.io.helper: New IO handler for netfilter helpers - firewall.errors: New INVALID_HELPER error code - firewall.core.io.ifcfg: Use .bak for save files - firewall-config: Set internal log_denied setting after changing - firewall.server.config: Copy props before removing items - doc/xml/firewalld.ipset: Replaced icmptype name remains with ipset - firewall.core.fw_zone: Fix LOG rule placement for LogDenied - firewall.command: Use "source-ports" in print_zone_info - firewall.core.logger: Use syslog.openlog() and syslog.closelog() - firewall-[offline-]cmd man pages: Document --path-{zone,icmptype,ipset,service} - firewall-cmd: Enable --path-{zone,icmptype,service} options again - firewall.core.{ipXtables,ebtables}: Copy rule before extracting items in set_rules - firewall.core.fw: Do not abort transaction on failed ipv6_rpfilter rules - config/Makefile.am: Added cfengine, condor-collector and smtp-submission services - Makefile.am: New dist-check used in the archive target - src/Makefile.am: Reordered nobase_dist_python_DATA to be sorted - config/Makefile.am: New CONFIG_FILES variable to contain the config files - Merge pull request #150 from hspaans/master - Merge pull request #146 from canvon/bugfix/spelling - Merge pull request #145 from jcpunk/condor - Command line tools man pages: New section about sequence options and exit codes - Creating service file for SMTP-Submission. - Creating service file for CFEngine. - Fix typo in documentation: iptables mangle table - Only use sort on lists of main items, but not for item properties - firewall.core.io.io_object: import_config should not change ordering of lists - firewall.core.fw_transaction: Load helper modules in FirewallZoneTransaction - firewall.command: Fail with NOT_AUTHORIZED if authorization fails (RHBZ#1368549) - firewall.command: Fix sequence exit code with at least one succeeded item - Add condor collector service - firewall-cmd: Fixed --{get,set}-{description,short} for permanent zones - firewall.command: Do not use error code 254 for {ALREADY,NOT}_ENABLED sequences- Fix CVE-2016-5410: Firewall configuration can be modified by any logged in user - firewall/server/firewalld: Make getXSettings and getLogDenied CONFIG_INFO - Update AppData configuration file. - tests/firewalld_rich.py: Use new import structure and FirewallClient classes - tests/firewalld_direct.py: Use new import structure - tests: firewalld_direct: Fix assert to check for True instead of False - tests: firewalld_config: Fix expected value when querying the zone target - tests: firewalld_config: Use real nf_conntrack modules - firewalld.spec: Added comment about make call for %build - firewall-config: Use also width_request and height_request with default size - Updated firewall-config screenshot - firewall-cmd: Fixed typo in help output (RHBZ#1367171) - test-suite: Ignore stderr to get default zone also for missing firewalld.conf - firewall.core.logger: Warnings should be printed to stderr per default - firewall.core.fw_nm: Ignore NetworkManager if NM.Client connect fails - firewall-cmd, firewallctl: Gracefully fail if SystemBus can not be aquired - firewall.client: Generate new DBUS_ERROR if SystemBus can not be aquired - test-suite: Do not fail on ALREADY_ENABLED --add-destination tests - firewall.command: ALREADY_ENABLED, NOT_ENABLED, ZONE_ALREADY_SET are warnings - doc/xml/firewalld.dbus.xml: Removed undefined reference - doc/xml/transform-html.xsl.in: Fixed references in the document - doc/xml/firewalld.{dbus,zone}.xml: Embed programlisting in para - doc/xml/transform-html.xsl.in: Enhanced html formatting closer to the man page - firewall: core: fw_nm: Instantiate the NM client only once - firewall/core/io/*.py: Do not traceback on a general sax parsing issue - firewall-offline-cmd: Fix --{add,remove}-entries-from-file - firewall-cmd: Add missing action to fix --{add,remove}-entries-from-file - firewall.core.prog: Do not output stderr, but return it in the error case - firewall.core.io.ifcfg.py: Fix ifcfg file reader and writer (RHBZ#1362171) - config/firewall.service.in: use KillMode=mixed - config/firewalld.service.in: use network-pre.target - firewall-config: Add missing gettext.textdomain call to fix translations - Add UDP to transmission-client.xml service - tests/firewall-[offline-]cmd_test.sh: Hide errors and warnings - firewall.client: Fix ALREADY_ENABLED errors in icmptype destination calls - firewall.client: Fix NOT_ENABLED errors in icmptype destination calls - firewall.client: Use {ALREADY,NOT}_ENABLED errors in icmptype destination calls - firewall.command: Add the removed FirewallError handling to the action (a17ce50) - firewall.command: Do not use query methods for sequences and also single options - Add missing information about MAC and ipset sources to man pages and help output - firewalld.spec: Add BuildRequires for libxslt to enable rebuild of man pages - firewall[-offline]-cmd, firewallctl, firewall.command: Use sys.{stdout,stderr} - firewallctl: Fix traceback if not connected to firewalld - firewall-config: Initialize value in on_richRuleDialogElementChooser_clicked - firewall.command: Convert errors to string for Python3 - firewall.command: Get proper firewall error code from D-BusExceptions - firewall-cmd: Fixed traceback without args - Add missing service files to Makefile.am - shell-completion: Add shell completion support for --{get,set}--{description,short} - Updated RHEL-7 selinux-policy and squid conflict- https://fedoraproject.org/wiki/Changes/Automatic_Provides_for_Python_RPM_Packages- 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 - Fixed selinux-policy conflict version for RHEL-7- Fixed selinux-policy conflict version for Fedora 24- New firewalld release 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 - New firewallctl utility (RHBZ#1147959) - doc.xml.seealso: Show firewalld.dbus in See Also sections - firewall.core.fw_config: Create backup on zone, service, ipset and icmptype removal (RHBZ#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 (RHBZ#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- 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 (RHBZ#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- Fixed ebtables-restore does not support the COMMIT command issue- Fixed translations with python3 - Fixed exception for failed NM import, new doc string - Make ipsets visible per default in firewall-config - Install new fw_nm module - Do not fail if log file could not be opened - Fixed broken fr translation- 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 (RHBZ#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- Revert one commit to temporary work-around RHBZ#1309754- Make sure tempdir is created even in offline mode. (RHBZ#1305175)- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild- Version 0.4.0 - Speed ups - ipset support - MAC address support - Log of denied packets - Mark action in rich rules - Enhanced alteration of config files with command line tools - Use of zone chains in direct interface - firewall-applet enhancement - New services: ceph-mon, ceph, docker-registry, imap, pop3, pulseaudio, smtps, snmptrap, snmp, syslog-tls and syslog - Several bug fixes - Code optimizations- Rebuilt for https://fedoraproject.org/wiki/Changes/python3.5- bump versions on old config package obsoletes (f21 is on 0.3.14 now)- Require python3-gobject-base for fedora >= 23 and rhel >= 8 (RHBZ#1242076) - Fix rhel defines: No python3 for rhel-7- Fixed 'pid_file' referenced before assignment (RHBZ#1233232)- reunification of the firewalld spec files for all Fedora releases - fix dependencies for -applet and -config: use_python3 is the proper switch not with_python3 (RHBZ#1232493) - firewalld.spec: - fixed requirements for -applet and -config - man pages: - adapted firewall-applet man page to new version - firewall-applet: - Only honour active connections for zone changes - Change QSettings path and file names - firewall-config: - Only honour active connections for zone changes in the “Change Zones of Connections” menu - Translations: - updated translations - marked translations for “Connections” for review- Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild- Fix issue with missing polkit policy when installing firewalld on Cloud Edition.- firewall-applet - do not use isSystemTrayAvailable check to fix KDE5 startup - dropped gtk applet remain: org.fedoraproject.FirewallApplet.gschema.xml- renamed python2-firewall to python-firewall - fixed requirements for GUI parts with Python3 - dropped upstream merged python3 patch - firewalld: - print real zone names in error messages - iptables 1.4.21 does not accept limits of 1/day, minimum is 2/day now - rate limit fix for rich rules - fix readdition of removed permanent direct settings - adaption of the polkit domains to use PK_ACTION_DIRECT_INFO - fixed two minor Python3 issues in firewall.core.io.direct - fixed use of fallback configuration values - fixed use without firewalld.conf - firewalld main restructureization - IPv6_rpfilter now also available as a property on D-Bus in the config interface - fixed wait option use for ipXtables - added --concurrent support for ebtables - richLanguage: allow masquerading with destination - richLanguage: limit masquerading forward rule to new connections - ipXtables: No dns lookups in available_tables and _detect_wait_option - full ebtables support: start, stop, reload, panic mode, direct chains and rules - fix for reload with direct rules - fix or flaws found by landscape.io - pid file handling fixes in case of pid file removal - fix for client issue in case of a dbus NoReply error - configuration - new services: dropbox-lansync, ptp - new icmptypes: timestamp-request, timestamp-reply - man pages: - firewalld.zones(5): fixed typos - firewalld.conf(5): Fixed wrong reference to firewalld.lockdown-whitelist page - firewall-applet: - new version using Qt4 fixing several issues with the Gtk version - spec file: - enabled Python3 support: new backends python-firewall and python3-firewall - some cleanup - git: - migrated to github - translations: - migrated to zanata - build environment: - no need for autoconf-2.69, 2.68 is sufficient- Use VARIANT_ID instead of VARIANT for making decisions- Switch to using $VARIANT directly from /etc/os-release- Fix bugs with posttrans - Remove nonexistent fedora-cloud.conf symlink- Remove per-edition config files - Decide on default configuration based on /etc/os-release- use python3 bindings on fedora >=23- enable python2 and python3 bindings for fedora >= 20 and rhel >= 7 - use python3 bindings on fedora >= 22 and rhel >= 8 for firewalld, firewall-config and firewall-applet- firewalld: - ipXtables: use -w or -w2 if supported (RHBZ#1161745, RHBZ#1151067) - DROP INVALID packets (RHBZ#1169837) - don't use ipv6header for protocol matching. (RHBZ#1065565) - removeAllPassthroughs(): remove passthroughs in reverse order (RHBZ#1167100) - fix config.service.removeDestination() (RHBZ#1164584) - firewall-config: - portProtoDialog: other protocol excludes port number/range - better fix for updating zoneStore also in update_active_zones() - fix typo in menu - configuration: - new services: tinc, vdsm, mosh, iscsi-target, rsyncd - ship and install XML Schema files. (#8) - man pages: - firewalld.dbus, firewalld.direct, firewalld, firewall-cmd - spec file: - filesystem subpackage - make dirs&files in /usr/lib/ world-readable (RHBZ#915988)- firewalld: - new runtimeToPermanent and tracked passsthrough support - make permanent D-Bus interfaces more fine grained like the runtime versions (RHBZ#1127706) - richLanguage: allow using destination with forward-port - Rich_Rule.check(): action can't be used with icmp-block/forward-port/masquerade - fixed Python specific D-Bus exception (RHBZ#1132441) - firewall-cmd: - new --runtime-to-permanent to create permanent from runtime configuration - use new D-Bus methods for permanent changes - show target REJECT instead of %REJECT% (RHBZ#1058794) - --direct: make fail messages consistent (RHBZ#1141835) - firewall-config: - richRuleDialog - OK button tooltip indicates problem - use new D-Bus methods for permanent changes - show target REJECT instead of %REJECT% (RHBZ#1058794) - update "Change Zones of Connections" menu on default zone change (RHBZ#11120212) - fixed rename of zones, services and icmptypes to not create new entry (RBHZ#1131064) - configuration: - new service for Squid HTTP proxy server - new service for Kerberos admin server - new services for syslog and syslog-tls - new services for SNMP and SNMP traps - add Keywords to .desktop to improve software searchability - docs: - updated translations - firewalld.richlanguage: improvements suggested by Rufe Glick - firewalld.dbus: various improvements - firewalld.zone: better description of Limit tag - mention new homepage everywhere- Quiet systemctl if cups-browsed.service is not installed- add few Requires to spec (RHBZ#1133167)- firewalld: - improve error messages - check built-in chains in direct chain handling functions (RHBZ#1120619) - dbus_to_python() check whether input is of expected type (RHBZ#1122018) - handle negative timeout values (RHBZ#1124476) - warn when Command/Uid/Use/Context already in lockdown whitelist (RHBZ#1126405) - make --lockdown-{on,off} work again (RHBZ#1111573) - firewall-cmd: - --timeout now accepts time units (RHBZ#994044) - firewall-config: - show active (not default) zones in bold (RHBZ#993655) - configuration: - remove ipp-client service from all zones (RHBZ#1105639). - fallbacks for missing values in firewalld.conf - create missing dirs under /etc if needed - add -Es to python command in lockdown-whitelist.xml (RHBZ#1099065) - docs: - 'direct' methods concern only chains/rules added via 'direct' (RHBZ#1120619) - --remove-[interface/source] don't need a zone to be specified (RHBZ#1125851) - various fixes in firewalld.zone(5), firewalld.dbus(5), firewalld.direct(5) - others: - rpm macros for easier packaging of e.g. services- Fixed wrong default zone names for server and workstation (RHBZ#1120296)- renamed fedora specific zones to FedoraServer and FedoraWorkstation for zone name limitations (length and allowed chars)- New support for Fedora per-product configuration settings for Fedora.next https://fedoraproject.org/wiki/Per-Product_Configuration_Packaging_Draft - Added Fedora server zone (RHBZ#1110711) - Added Fedora workstation zone(RHBZ#1113775)- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild- new services: freeipa-*, puppermaster, amanda-k5, synergy, xmpp-*, tor, privoxy, sane - do not use at_console in D-Bus policies (RHBZ#1094745) - apply all rich rules for non-default targets - AppData file (RHBZ#1094754) - separate Polkit actions for desktop & server (RHBZ#1091068) - sanitize missing ip6t_rpfilter (RHBZ#1074427) - firewall/core/io/*: few improvements (RHBZ#1065738) - no load failed error for absent direct.xml file - new DBUS_INTERFACE.getZoneSettings to get all run-time zone settings - fixed creation and deletion of zones, services and icmptypes over D-Bus signals - FirewallClientZoneSettings: Set proper default target - if Python2 then encode strings from sax parser (RHBZ#1059104, RHBZ#1058853) - firewall-cmd: - don't colour output of query commands (RHBZ#1097841) - use "default" instead of {chain}_{zone} (RHBZ#1075675) - New --get-target and --set-target - Create and remove permanent zones, services and icmptypes - firewall-config: - Adding services and icmptypes resulted in duplicates in UI - Use left button menu of -applet in Option menu - firewall-offline-cmd: same functionality as 'firewall-cmd --permanent' - firewall-applet: ZoneConnectionEditor was missing the Default Zone entry - bash-completion: getting zones/services/icmps is different with/without --permanent - firewalld.zone(5): removed superfluous slash (RHBZ#1091575) - updated translations- Fixed persistent port forwarding (RHBZ#1056154) - Stop default zone rules being applied to all zones (RHBZ#1057875) - Enforce trust, block and drop zones in the filter table only (RHBZ#1055190) - Allow RAs prior to applying IPv6_rpfilter (RHBZ#1058505) - Fix writing of rule.audit in zone_writer()- fix regression introduced in 0.3.9 (RHBZ#1053932)- fix regressions introduced in 0.3.9 (RHBZ#1054068, RHBZ#1054120)- translation updates - New IPv6_rpfilter setting to enable source address validation (RHBZ#847707) - Do not mix original and customized zones in case of target changes, apply only used zones - firewall-cmd: fix --*_lockdown_whitelist_uid to work with uid 0 - Don't show main window maximized. (RHBZ#1046811) - Use rmmod instead of 'modprobe -r' (RHBZ#1031102) - Deprecate 'enabled' attribute of 'masquerade' element - firewall-config: new zone was added twice to the list - firewalld.dbus(5) - Enable python shebang fix again - firewall/client: handle_exceptions: Use loop in decorator - firewall-offline-cmd: Do not mask firewalld service with disabled option - firewall-config: richRuleDialogActionRejectType Entry -> ComboBox - Rich_Rule: fix parsing of reject element (RHBZ#1027373) - Show combined zones in permanent configuration (RHBZ#1002016) - firewall-cmd(1): document exit code 2 and colored output (RHBZ#1028507) - firewall-config: fix RHBZ#1028853- fix memory leaks - New option --debug-gc - Python3 compatibility - Better non-ascii support - several firewall-config & firewall-applet fixes - New --remove-rules commands for firewall-cmd and removeRules methods for D-Bus - Fixed FirewallDirect.get_rules to return proper list - Fixed LastUpdatedOrderedDict.keys() - Enable rich rule usage in trusted zone (RHBZ#994144) - New error codes: INVALID_CONTEXT, INVALID_COMMAND, INVALID_USER and INVALID_UID- Don't fail on missing ip[6]tables/ebtables table. (RHBZ#967376) - bash-completion: --permanent --direct options - firewall/core/fw.py: fix checking for iptables & ip6tables (RHBZ#1017087) - firewall-cmd: use client's exception_handler instead of catching exceptions ourselves - FirewallClientZoneSettings: fix {add|remove|query}RichRule() - Extend amanda-client service with 10080/tcp (RHBZ#1016867) - Simplify Rich_Rule()_lexer() by using functions.splitArgs() - Fix encoding problems in exception handling (RHBZ#1015941)- firewall-offline-cmd: --forward-port 'toaddr' is optional (RHBZ#1014958) - firewall-cmd: fix variable name (RHBZ#1015011)- remove superfluous po files from archive- firewalld.richlanguage.xml: correct log levels (RHBZ#993740) - firewall-config: Make sure that all zone settings are updated properly on firewalld restart - Rich_Limit: Allow long representation for duration (RHBZ#994103 - firewall-config: Show "Changes applied." after changes (RHBZ#993643) - Use own connection dialog to change zones for NM connections - Rename service cluster-suite to high-availability (RHBZ#885257) - Permanent direct support for firewall-config and firewall-cmd - Try to avoid file descriptor leaking (RHBZ#951900) - New functions to split and join args properly (honoring quotes) - firewall-cmd(1): 2 simple examples - Better IPv6 NAT checking. - Ship firewalld.direct(5).- Only use one PK action for configuration (RHBZ#994729) - firewall-cmd: indicate non-zero exit code with red color - rich-rule: enable to have log without prefix & log_level & limit - log-level warn/err -> warning/error (RHBZ#1009436) - Use policy DROP while reloading, do not reset policy in restart twice - Add _direct chains to all table and chain combinations - documentation improvements - New firewalld.direct(5) man page docbook source - tests/firewall-cmd_test.sh: make rich language tests work - Rich_Rule._import_from_string(): improve error messages (RHBZ#994150) - direct.passthrough wasn't always matching out_signature (RHBZ#967800) - firewall-config: twist ICMP Type IP address family logic. - firewall-config: port-forwarding/masquerading dialog (RHBZ#993658) - firewall-offline-cmd: New --remove-service= option (BZ#969106) - firewall-config: Options->Lockdown was not changing permanent. - firewall-config: edit line on doubleclick (RHBZ#993572) - firewall-config: System Default Zone -> Default Zone (RHBZ#993811) - New direct D-Bus interface, persistent direct rule handling, enabled passthough - src/firewall-cmd: Fixed help output to use more visual parameters - src/firewall-cmd: New usage output, no redirection to man page anymore - src/firewall/core/rich.py: Fixed forwad port destinations - src/firewall-offline-cmd: Early enable/disable handling now with mask/unmask - doc/xml/firewalld.zone.xml: Added more information about masquerade use - Prefix to log message is optional (RHBZ#998079) - firewall-cmd: fix --permanent --change-interface (RHBZ#997974) - Sort zones/interfaces/service/icmptypes on output. - wbem-https service (RHBZ#996668) - applet&config: add support for KDE NetworkManager connection editor - firewall/core/fw_config.py: New method update_lockdown_whitelist - Added missing file watcher for lockdown whitelist in config D-Bus interface - firewall/core/watcher: New add_watch_file for lockdown-whitelist and direct - Make use of IPv6 NAT conditional, based on kernel number (RHBZ#967376)- several rich rule check enhancements and fixes - firewall-cmd: direct options - check ipv4|ipv6|eb (RHBZ#970505) - firewall-cmd(1): improve description of direct options (RHBZ#970509) - several firewall-applet enhancements and fixes - New README - several doc and man page fixes - Service definitions for PCP daemons (RHBZ#972262) - bash-completion: add lockdown and rich language options - firewall-cmd: add --permanent --list-all[-zones] - firewall-cmd: new -q/--quiet option - firewall-cmd: warn when default zone not active (RHBZ#971843) - firewall-cmd: check priority in --add-rule (RHBZ#914955) - add dhcpv6 (for server) service (RHBZ#917866) - firewall-cmd: add --permanent --get-zone-of-interface/source --change-interface/source - firewall-cmd: print result (yes/no) of all --query-* commands - move permanent-getZoneOf{Interface|Source} from firewall-cmd to server - Check Interfaces/sources when updating permanent zone settings. - FirewallDConfig: getZoneOfInterface/Source can actually return more zones - Fixed toaddr check in forward port to only allow single address, no range - firewall-cmd: various output improvements - fw_zone: use check_single_address from firewall.functions - getZoneOfInterface/Source does not need to throw exception - firewall.functions: Use socket.inet_pton in checkIP, fixed checkIP*nMask - firewall.core.io.service: Properly check port/proto and destination address - Install applet desktop file into /etc/xdg/autostart - Fixed option problem with rich rule destinations (RHBZ#979804) - Better exception creation in dbus_handle_exceptions() decorator (RHBZ#979790) - Updated firewall-offline-cmd - Use priority in add, remove, query and list of direct rules (RHBZ#979509) - New documentation (man pages are created from docbook sources) - firewall/core/io/direct.py: use prirority for rule methods, new get_all_ methods - direct: pass priority also to client.py and firewall-cmd - applet: New blink and blink-count settings - firewall.functions: New function ppid_of_pid - applet: Check for gnome3 and fix it, use new settings, new size-changed cb - firewall-offline-cmd: Fix use of systemctl in chroot - firewall-config: use string.ascii_letters instead of string.letters - dbus_to_python(): handle non-ascii chars in dbus.String. - Modernize old syntax constructions. - dict.keys() in Python 3 returns a "view" instead of list - Use gettext.install() to install _() in builtins namespace. - Allow non-ascii chars in 'short' and 'description' - README: More information for "Working With The Source Repository" - Build environment fixes - firewalld.spec: Added missing checks for rhel > 6 for pygobject3-base - firewall-applet: New setting show-inactive - Don't stop on reload when lockdown already enabled (RHBZ#987403) - firewall-cmd: --lockdown-on/off did not touch firewalld.conf - FirewallApplet.gschema.xml: Dropped unused sender-info setting - doc/firewall-applet.xml: Added information about gsettings - several debug and log message fixes - Add chain for sources so they can be checked before interfaces (RHBZ#903222) - Add dhcp and proxy-dhcp services (RHBZ#986947) - io/Zone(): don't error on deprecated family attr of source elem - Limit length of zone file name (to 12 chars) due to Netfilter internals. - It was not possible to overload a zone with defined source(s). - DEFAULT_ZONE_TARGET: {chain}_ZONE_{zone} -> {chain}_{zone} - New runtime getSettings for services and icmptypes, fixed policies callbacks - functions: New functions checkUser, checkUid and checkCommand - src/firewall/client: Fixed lockdown-whitelist-updated signal handling - firewall-cmd(1): move firewalld.richlanguage(5) reference in --*-rich-rule - Rich rule service: Only add modules for accept action - firewall/core/rich: Several fixes and enhanced checks - Fixed reload of direct rules - firewall/client: New functions to set and get the exception handler - firewall-config: New and enhanced UI to handle lockdown and rich rules - zone's immutable attribute is redundant - Do not allow to set settings in config for immutable zones. - Ignore deprecated 'immutable' attribute in zone files. - Eviscerate 'immutable' completely. - FirewallDirect.query_rule(): fix it - permanent direct: activate firewall.core.io.direct:Direct reader - core/io/*: simplify getting of character data - FirewallDirect.set_config(): allow reloading- Remove migrating to a systemd unit file from a SysV initscript - Remove pointless "ExclusiveOS" tag- Fixed rich rule check for use in D-Bus- new service files - relicensed logger.py under GPLv2+ - firewall-config: sometimes we don't want to use client's exception handler - When removing Service/IcmpType remove it from zones too (RHBZ#958401) - firewall-config: work-around masquerade_check_cb() being called more times - Zone(IO): add interfaces/sources to D-Bus signature - Added missing UNKNOWN_SOURCE error code - fw_zone.check_source: Raise INVALID_FAMILY if family is invalid - New changeZoneOfInterface method, marked changeZone as deprecated - Fixed firewall-cmd man page entry for --panic-on - firewall-applet: Fixed possible problems of unescaped strings used for markup - New support to bind zones to source addresses and ranges (D-BUS, cmd, applet - Cleanup of unused variables in FirewallD.start - New firewall/fw_types.py with LastUpdatedOrderedDict - direct.chains, direct.rules: Using LastUpdatedOrderedDict - Support splitted zone files - New reader and writer for stored direct chains and rules - LockdownWhitelist: fix write(), add get_commands/uids/users/contexts() - fix service_writer() and icmptype_writer() to put newline at end of file - firewall-cmd: fix --list-sources - No need to specify whether source address family is IPv4 or IPv6 - add getZoneOfSource() to D-Bus interface - Add tests and bash-completion for the new "source" operations - Convert all input args in D-Bus methods - setDefaultZone() was calling accessCheck() *after* the action - New uniqify() function to remove duplicates from list whilst preserving order - Zone.combine() merge also services and ports - config/applet: silence DBusException during start when FirewallD is not running (RHBZ#966518) - firewall-applet: more fixes to make the address sources family agnostic - Better defaults for lockdown white list - Use auth_admin_keep for allow_any and allow_inactive also - New D-Bus API for lockdown policies - Use IPv4, IPv6 and BRIDGE for FirewallD properties - Use rich rule action as audit type - Prototype of string-only D-Bus interface for rich language - Fixed wrongly merged source family check in firewall/core/io/zone.py - handle_cmr: report errors, cleanup modules in error case only, mark handling - Use audit type from rule action, fixed rule output - Fixed lockdown whitelist D-Bus handling method names - New rich rule handling in runtime D-Bus interface - Added interface, source and rich rule handling (runtime and permanent) - Fixed dbus_obj in FirewallClientConfigPolicies, added queryLockdown - Write changes in setLockdownWhitelist - Fixed typo in policies log message in method calls - firewall-cmd: Added rich rule, lockdown and lockdown whitelist handling - Don't check access in query/getLockdownWhitelist*() - firewall-cmd: Also output masquerade flag in --list-all - firewall-cmd: argparse is able to convert argument to desired type itself - firewall-cmd_test.sh: tests for permanent interfaces/sources and lockdown whitelist - Makefile.am: add missing files - firewall-cmd_test.sh: tests for rich rules - Added lockdown, source, interface and rich rule docs to firewall-cmd - Do not masquerade lo if masquerade is enabled in the default zone (RHBZ#904098) - Use in metavar for firewall-cmd parser- removed unintentional en_US.po from tarball- Fix signal handling for SIGTERM - Additional service files (RHBZ#914859) - Updated po files - s/persistent/permanent/ (Trac Ticket #7) - Better behaviour when running without valid DISPLAY (RHBZ#955414) - client.handle_exceptions(): do not loop forever - Set Zone.defaults in zone_reader (RHBZ#951747) - client: do not pass the dbus exception name to handler - IO_Object_XMLGenerator: make it work with Python 2.7.4 (RHBZ#951741) - firewall-cmd: do not use deprecated BaseException.message - client.py: fix handle_exceptions() (RHBZ#951314) - firewall-config: check zone/service/icmptype name (RHBZ#947820) - Allow 3121/tcp (pacemaker_remote) in cluster-suite service. (RHBZ#885257) - firewall-applet: fix default zone hangling in 'shields-up' (RHBZ#947230) - FirewallError.get_code(): check for unknown error- Make permanenent changes work with Python 2.7.4 (RHBZ#951741)- Use explicit file lists for make dist - New rich rule validation check code - New global check_port and check_address functions - Allow source white and black listing with the rich rule - Fix error handling in case of unsupported family in rich rule - Enable ip_forwarding in masquerade and forward-port - New functions to read and write simple files using filename and content - Add --enable-sysconfig to install Fedora-specific sysconfig config file. - Add chains for security table (RHBZ#927015) - firewalld.spec: no need to specify --with-systemd-unitdir - firewalld.service: remove syslog.target and dbus.target - firewalld.service: replace hard-coded paths - Move bash-completion to new location. - Revert "Added configure for new build env" - Revert "Added Makefile.in files" - Revert "Added po/Makefile.in.in" - Revert "Added po/LINGUAS" - Revert "Added aclocal.m4" - Amend zone XML Schema- Added rich language support - Added lockdown feature - Allow to bind interfaces and sources to zones permanently - Enabled IPv6 NAT support masquerading and port/packet forwarding for IPv6 only with rich language - Handle polkit errors in client class and firewall-config - Added priority description for --direct --add-rule in firewall-cmd man page - Add XML Schemas for zones/services/icmptypes XMLs - Don't keep file descriptors open when forking - Introduce --nopid option for firewalld - New FORWARD_IN_ZONES and FORWARD_OUT_ZONES chains (RHBZ#912782) - Update cluster-suite service (RHBZ#885257) - firewall-cmd: rename --enable/disable-panic to --panic-on/off (RHBZ#874912) - Fix interaction problem of changed event of gtk combobox with polkit-kde by processing all remaining events (RHBZ#915892) - Stop default zone rules being applied to all zones (RHBZ#912782) - Firewall.start(): don't call set_default_zone() - Add wiki's URL to firewalld(1) and firewall-cmd(1) man pages - firewalld-cmd: make --state verbose (RHBZ#886484) - improve firewalld --help (RHBZ#910492) - firewall-cmd: --add/remove-* can be used multiple times (RHBZ#879834) - Continue loading zone in case of wrong service/port etc. (RHBZ#909466) - Check also services and icmptypes in Zone() (RHBZ#909466) - Increase the maximum length of the port forwarding fields from 5 to 11 in firewall-config - firewall-cmd: add usage to fail message - firewall-cmd: redefine usage to point to man page - firewall-cmd: fix visible problems with arg. parsing - Use argparse module for parsing command line options and arguments - firewall-cmd.1: better clarify where to find ACTIONs - firewall-cmd Bash completion - firewall-cmd.1: comment --zone= usage and move some options - Use zone's target only in %s_ZONES chains - default zone in firewalld.conf was set to public with every restart (#902845) - man page cleanup - code cleanup- Another fix for RHBZ#912782- Stop default zone rules being applied to all zones (RHBZ#912782)- Rebuilt for https://fedoraproject.org/wiki/Fedora_19_Mass_Rebuild- Default zone in firewalld.conf was reseted with every restart (RHBZ#902845) - Add icon cache related scriptlets for firewall-config (RHBZ#902680) - Fix typo in firewall-config (RHBZ#895812) - Fix few mistakes in firewall-cmd(1) man page- firewall-cmd: use -V instead of -v for version info (RHBZ#886477) - firewall-cmd: don't check reload()'s return value (RHBZ#886461) - actually install firewalld.zones.5 - firewall-config: treat exceptions when adding new zone/service/icmp (RHBZ#886602) - firewalld.spec: Fixed requirements of firewall-config to use gtk2 and pygobject3 - Fail gracefully when running in non X environment.(RHBZ#886551) - offline-cmd: fail gracefully when no s-c-f config - fix duplicated iptables rules (RHBZ#886515) - detect errors and duplicates in config file (RHBZ#886581) - firewall-config: don't make 'Edit Service' and 'Edit ICMP Type' insensitive - firewalld.spec: fixed requirements, require pygobject3-base - frewall-applet: Unused code cleanup - firewall-applet: several usability fixes and enhancements (RHBZ#886531) (RHBZ#886534) - firewall/server/server.py: fixed KeyboardInterrupt message (RHBZ#886558) - Moved fallback zone and minimal_mark to firewall.config.__init__ - Do not raise ZONE_ALREADY_SET in change_zone if old zone is set again (RHBZ#886432) - Make default zone default for all unset connections/interfaces (RHBZ#888288) (RHBZ#882736) - firewall-config: Use Gtk.MessageType.WARNING for warning dialog - firewall-config: Handle unknown services and icmptypes in persistent mode - firewall-config: Do not load settings more than once - firewall-config: UI cleanup and fixes (RHBZ#888242) - firewall-cmd: created alias --change-zone for --change-interface - firewall-cmd man page updates (RHBZ#806511) - Merged branch 'build-cleanups' - dropped call to autogen.sh in build stage, not needed anymore due to 'build-cleanups' merge- require pygobject3-base instead of pygobject3 (no cairo needed) (RHBZ#874378) - fixed dependencies of firewall-config to use gtk3 with pygobject3-base and not pygtk2- Fixed more _xmlplus (PyXML) incompatibilities to python xml - Several man page updates - Fixed error in addForwardPort, removeForwardPort and queryForwardPort - firewall-cmd: use already existing queryForwardPort() - Update firewall.cmd man page, use man page as firewall-cmd usage (rhbz#876394) - firewall-config: Do not force to show labels in the main toolbar - firewall-config: Dropped "Change default zone" from toolbar - firewall-config: Added menu entry to change zones of connections - firewall-applet: Zones can be changed now using nm-connection-editor (rhbz#876661) - translation updates: cs, hu, ja- tests/firewalld_config.py: tests for config.service and config.icmptype - FirewallClientConfigServiceSettings(): destinations are dict not list - service/zone/icmptype: do not write deprecated name attribute - New service ntp - firewall-config: Fixed name of about dialog - configure.in: Fixed getting of error codes - Added coding to all pyhton files - Fixed copyright years - Beautified file headers - Force use of pygobject3 in python-slip (RHBZ#874378) - Log: firewall.server.config_icmptype, firewall.server.config_service and firewall.server.config_zone: Prepend full path - Allow ":" in interface names for interface aliases - Add name argument to Updated and Renamed signal - Disable IPv4, IPv6 and EB tables if missing - for IPv4/IPv6 only environments - firewall-config.glade file cleanup - firewall-config: loadDefaults() can throw exception - Use toolbars for Add/Edit/Remove/LoadDefaults buttons for zones, services and icmp types - New vnc-server service, opens ports for displays :0 to :3 (RHBZ#877035) - firewall-cmd: Fix typo in help output, allow default zone usage for permanenent options - Translation updates: cs, fr, ja, pt_BR and zh_CN- firewall-config: some UI usability changes - firewall-cmd: New option --list-all-zones, output of --list-all changed, more option combination checks - firewall-applet: Replaced NMClient by direct DBUS calls to fix python core dumps in case of connection activates/deactivates - Use fallback 'C' locale if current locale isn't supported (RHBZ#860278) - Add interfaces to zones again after reload - firewall-cmd: use FirewallClient().connected value - firewall-cmd: --remove-interface was not working due to a typo - Do not use restorecon for new and backup files - Fixed use of properties REJECT and DROP - firewalld_test.py: check interfaces after reload - Translation updates - Renamed firewall-convert-scfw-config to firewall-offline-cmd, used by anaconda for firewall configuration (e.g. kickstart) - Fix python shebang to use -Es at installation time for bin_SCRIPTS and sbin_SCRIPTS and at all times in gtk3_chooserbutton.py - tests/firewalld_config.py: update test_zones() test case - Config interface: improve renaming of zones/services/icmp_types - Move emiting of Added signals closer to source. - FirewallClient(): config:ServiceAdded signal was wrongly mapped - Add argument 'name' to Removed signal - firewall-config: Add callbacks for config:[service|icmp]-[added|removed] - firewall-config: catch INVALID_X error when removing zone/service/icmp_type - firewall-config: remove unused code - Revert "Neutralize _xmlplus instead of conforming it" - firewall-applet: some UI usability changes - firewall-cmd: ALREADY_ENABLED, NOT_ENABLED, ZONE_ALREADY_SET are warnings- Do not apply old settings to zones after reload - FirewallClient: Added callback structure for firewalld signals - New firewall-config with full zone, service and icmptype support - Added Shields Up/Down configuration dialog to firewall-applet - Name attribute of main tag deprecated for zones, services and icmptypes, will be ignored if present - Fixed wrong references in firewalld man page - Unregister DBus interfaces after sending out the Removed signal - Use proper DBus signature in addIcmpType, addService and addZone - New builtin property for config interfaces - New test case for Config interface - spec: use new systemd-rpm macros (rhbz#850110) - More config file verifications - Lots of smaller fixes and enhancements- use new systemd-rpm macros (rhbz#850110)- Update of firewall-config - Some bug fixes- New D-BUS interface for persistent configuration - Aded support for persistent zone configuration in firewall-cmd - New Shields Up feature in firewall-applet - New requirements for python-decorator and pygobject3 - New firewall-config sub-package - New firewall-convert-scfw-config config script- Fixed traceback in firewall-cmd for failed or canceled authorization, return proper error codes, new error codes NOT_RUNNING and NOT_AUTHORIZED - Enhanced firewalld service file (RHBZ#806868) and (RHBZ#811240) - Fixed duplicates in zone after reload, enabled timed settings after reload - Removed conntrack --ctstate INVALID check from default ruleset, because it results in ICMP problems (RHBZ#806017). - Update interfaces in default zone after reload (rhbz#804814) - New man pages for firewalld(1), firewalld.conf(5), firewalld.icmptype(5), firewalld.service(5) and firewalld.zone(5), updated firewall-cmd man page (RHBZ#811257) - Fixed firewall-cmd help output - Fixed missing icon for firewall-applet (RHBZ#808759) - Added root user check for firewalld (RHBZ#767654) - Fixed requirements of firewall-applet sub package (RHBZ#808746) - Update interfaces in default zone after changing of default zone (RHBZ#804814) - Start firewalld before NetworkManager (RHBZ#811240) - Add Type=dbus and BusName to service file (RHBZ#811240)- fixed firewalld.conf save exception if no temporary file can be written to /etc/firewalld/- firewall-cmd: several changes and fixes - code cleanup - fixed icmp protocol used for ipv6 (rhbz#801182) - added and fixed some comments - properly restore zone settings, timeout is always set, check for 0 - some FirewallError exceptions were actually not raised - do not REJECT in each zone - removeInterface() don't require zone - new tests in firewall-test script - dbus_to_python() was ignoring certain values - added functions for the direct interface: chains, rules, passthrough - fixed inconsistent data after reload - some fixes for the direct interface: priority positions are bound to ipv, table and chain - added support for direct interface in firewall-cmd: - added isImmutable(zone) to zone D-Bus interface - renamed policy file - enhancements for error messages, enables output for direct.passthrough - added allow_any to firewald policies, using at leas auth_admin for policies - replaced ENABLE_FAILED, DISABLE_FAILED, ADD_FAILED and REMOVE_FAILED by COMMAND_FAILED, resorted error codes - new firewalld configuration setting CleanupOnExit - enabled polkit again, found a fix for property problem with slip.dbus.service - added dhcpv6-client to 'public' (the default) and to 'internal' zones. - fixed missing settings form zone config files in "firewall-cmd --list=all --zone=" call - added list functions for services and icmptypes, added --list=services and --list=icmptypes to firewall-cmd- enabled dhcpv6-client service for zones home and work - new dhcpv6-client service - firewall-cmd: query mode returns reversed values - new zone.changeZone(zone, interface) - moved zones, services and icmptypes to /usr/lib/firewalld, can be overloaded by files in /etc/firewalld (no overload of immutable zones block, drop, trusted) - reset MinimalMark in firewalld.cnf to default value - fixed service destination (addresses not used) - fix xmlplus to be compatible with the python xml sax parser and python 3 by adding __contains__ to xml.sax.xmlreader.AttributesImpl - use icon and glib related post, postun and posttrans scriptes for firewall - firewall-cmd: fix typo in state - firewall-cmd: fix usage() - firewall-cmd: fix interface action description in usage() - client.py: fix definition of queryInterface() - client.py: fix typo in getInterfaces() - firewalld.service: do not fork - firewall-cmd: fix bug in --list=port and --port action help message - firewall-cmd: fix bug in --list=service- moved zones, services and icmptypes to /usr/lib/firewalld, can be overloaded by files in /etc/firewalld (no overload of immutable zones block, drop, trusted)- added missing firewall.dbus_utils- added glib2-devel to build requires, needed for gsettings.m4 - added --with-system-unitdir arg to fix installaiton of system file - added glib-compile-schemas calls for postun and posttrans - added EXTRA_DIST file lists- version 0.2.0 with new FirewallD1 D-BUS interface - supports zones with a default zone - new direct interface as a replacement of the partial virt interface with additional passthrough functionality - dropped custom rules, use direct interface instead - dropped trusted interface funcionality, use trusted zone instead - using zone, service and icmptype configuration files - not using any system-config-firewall parts anymore- new version 0.1.3 - restore all firewall features for reload: panic and virt rules and chains - string fixes for firewall-cmd man page (by Jiri Popelka) - fixed firewall-cmd port list (by Jiri Popelka) - added firewall dbus client connect check to firewall-cmd (by Jiri Popelka) - translation updates: de, es, gu, it, ja, kn, ml, nl, or, pa, pl, ru, ta, uk, zh_CN- fixed package according to package review (rhbz#665395): - non executable scripts: dropped shebang - using newer GPL license file - made /etc/dbus-1/system.d/FirewallD.conf config(noreplace) - added requires(post) and (pre) for chkconfig- new version 0.1.1 - fixed source path in POTFILES* - added missing firewall_config.py.in - added misssing space for spec_ver line - using firewall_config.VARLOGFILE - added date to logging output - also log fatal and error logs to stderr and firewall_config.VARLOGFILE - make log message for active_firewalld fatal- initial package (proof of concept implementation) 0.9.11-1.el8 firewall-configfirewall-config.desktopfirewall-config.gladegtk3_chooserbutton.pygtk3_niceexpander.pyorg.fedoraproject.FirewallConfig.gschema.xmlfirewall-config.pngfirewall-config.pngfirewall-config.pngfirewall-config.pngfirewall-config.pngfirewall-config.svgfirewall-config.1.gzfirewall-config.appdata.xml/usr/bin//usr/share/applications//usr/share/firewalld//usr/share/glib-2.0/schemas//usr/share/icons/hicolor/16x16/apps//usr/share/icons/hicolor/22x22/apps//usr/share/icons/hicolor/24x24/apps//usr/share/icons/hicolor/32x32/apps//usr/share/icons/hicolor/48x48/apps//usr/share/icons/hicolor/scalable/apps//usr/share/man/man1//usr/share/metainfo/-O2 -g -pipe -Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS -fexceptions -fstack-protector-strong -grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -specs=/usr/lib/rpm/redhat/redhat-annobin-cc1 -m32 -march=x86-64 -mtune=generic -mfpmath=sse -mstackrealign -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protectioncpioxz2noarch-redhat-linux-gnu Python script, ASCII text executableUTF-8 Unicode textXML 1.0 document, UTF-8 Unicode text, with very long linesXML 1.0 document, ASCII textPNG image data, 16 x 16, 8-bit/color RGBA, non-interlacedPNG image data, 22 x 22, 8-bit/color RGBA, non-interlacedPNG image data, 24 x 24, 8-bit/color RGBA, non-interlacedPNG image data, 32 x 32, 8-bit/color RGBA, non-interlacedPNG image data, 48 x 48, 8-bit/color RGBA, non-interlacedSVG Scalable Vector Graphics imagetroff or preprocessor input, ASCII text, with very long lines (gzip compressed data, max compression, from Unix)RPPPPutf-884f6ee07142a035a761e631ca89197e4e9c298a11b9d185eec380339c8067aed?@7zXZ !#,*:] b2u y-iSql Yu9r+`zm;^nԲAt`*"#꩙uI9V|-2WZxt"1%;0Q&ƮnKu跹HE1 /v0hI"v>ue<)θOD\v3"9ѹi)y- ` L*^wB%F];_j;`cDcDo=tqsTȦB>W0ڔ;v>*\rF @-` NI>'-K14$RT]k-NϏRk%xЉ^JO`Y/&8.hfoVa3TCBBN&`n~Z )g~m%] '6s$ׯH\Jcv@#*V)ez$eǮכ!HFXYwͅbP?;=(JIEt/=gw[E0Ю?>t hJ O &@,,~ Hފm:1WFX- ׮3}Y'Ξ%mMYvfVc zt ^=l ޲(ݥȋ*qD+kX"ci~cz F.3;p؉p;|NiK1aEm7[$Wu'i˔/VcTj;ݶxR0ss_Ս`Mqj=u)12zPwvl@F2 _5ز.O|;BvaʰāYH;,g f:xnѩ?dj,lEفFʠj\9mRV2+ڞ ߬׳HOWX~򈋸UJg"WY$vaԴYڕKQ^oKaz@?(8|E@Âx(U߄*!w*}\*Ҭ20zQ\ZTWQnLܡ*I1A+N n w 5rx L5!ǧj)ȉ(mL_(7b~P[َkl* ʹc5F{=3ъjm÷2IH+FΑP&B24gv'!0QK5ft_/apOl@)A]ҧ.a'W:VgiU ?Y&eNȫTdϩC T@f-±.CI-m }tx~2 eO}g P oQC[,x.g}Fw\z~Je e.]{O|>4&=ӆ~?Ӡ$c2sS]?]J 6"^U4vJt)$b u)[Dj&{늍ȯ3\{hy5@If#5Xq51'%#Iߓ+zmBS̙֢.l;  9jSxifSOgJ ?2"fҚI 5aTI^xˊ,cжQn*їDž}r|ԥELj$&òvzfwG 0 rG~ζ;V@Osˏ=_v٥K8,^`#~=jܱ 0iFJn?2'H彫u!ݲ@ySX[B!E2iDڑż9m}\ž.aN"nXžSJ8D4/NX!jy΢Fia&*_tQi3$S*l PAq !:lvWEۑ+ÛiIv/}q:sfZ֭Nė0-8>( yw\:7}a ]sɲ>DrhUڟ D0WnG>:U! ;knt BCHu#DH4h|䨏'4^r u9% VJL\Ze5J: Ĭ(ҵy%FÊr m#4`$B:G5,oLw9O[1ebr%`ާЮCRmcHУL-zI,jt/XDN$D쬭-*^`@ӂL D[6mM]RtƁ#<xr>/轆4RxU0~rV0[lB 8Ϙh^ܮ MI ,.l_ג 1zu-/zZ-?,?f)Cw.=1`iˉ7MHf{'K '^JSy9mw壪Fge 1P,Q4E)fhp .ҵ{W%%zchJ%jd.K$&rgQԇO7F*6dvy'm8f8H5~` ڗ?r c::}_PbެztnXF3'Y!7ʕ3ü=KIba1Jc۞UVwh!7uQl\&tvKY>}7;ml%^a4>-])|bQ!   Ͷ&7*:e՜F|顃eמkr[B>~ |I W CҟOA sUXU,1].2CֺT+xD~f?r( #^U!1f$VZ{:*KoS큓XŽ@Jjo=ӡzinV'"y;Jޙ#vHQ>D~ H^~GɨxQLj= n)XAفzkN#H-9+\ix yo^4% M#ۦ}?ET6 -)NF:9H!YzF&c>D0'~Bf:R:$`6'K1YpDuZ-yOjOy _LJSoZ"A\&UT [ a<Vu^.Oj'xKSG^ ƙ4e0f _ݐ5QhG߁iY::sTdUt$YUl}up'  ;N%$7RrζsB`)h80`st25S9Fl71Bܢ};w{"N1;lH=ur9K3#̀Ͱ% .U6ca|HA+J"ŲY>(@}E͊n#Cl-|܄ܤfQ?uw` m oeϬھm+nPC8~-&9\v*+)ݪ}8J5O~™  Y"0K*ZWkݿĩWy/ U.N7q Hƈ4_-W19jH.6F}J!-& Ad tNos|^I5iVyv@p@2eaa~NBŊT҇Wҧ8APf~ ՞%eXv^h@pE&q'Q+^!8=2hREL%J_uD_*:""u\BVGj@xJ<>Vz$_CXRzN}O2^(ߠ)|K;L2ʟ ؀翁G4(MWIǃVYEX6UQ&.GY>8\8`,l[_%<   P=55<2 jY J=B*ᑈ772#,_}=URaPGIƵK4ݚ Cc^JdQۡ C(ʏϓ{mI쿖~Y:аr ]UH~32SС\cSvq6\2j5[":s4- $3ʵۛ[5selDEXN}|۬ \3@iY)hجQd=C4H5.*3M~_*6j_zo7D(E0aVow/"ߺ%1Cmqi$8 D2/'M4`i*1&2j}B{3$@OT<4|Sou1ȖA<\ u&H-dX7I8[)iRI;mJ32p)x+זʥdQ<‰ʆ[;2eX:;* /OwmQn,91:MV}8"@T.x*>vK0A3d`=y̿54j4J^S KwSxdRCN{C5*ޮZf u*ȋ&|r2FdvQǔ\Uxmb.\Տgh= =*K%zӱh1PPv/*Ǖw%jM0|s ]fB<q THE5k)&B1Q[֘81+FPqqS8 pd<ӐWd!\\6gPOR7VM2.CLpFzHB [Dp x[q4OɒOm6 / B= |c*ED&ғON"0% >WRPAElxvY6h-WS 5U1| V!ML*L{7Yg3 ygx4+B4oTr(viNj(Z["ב-0CcSg.|(2@I2 bX0wL.jrI2rINOK4 ۄxpW= y,"h#Oppy]\=^/ҏ p6ljGrW6bS΂ X?gsMO]S{ HEQuª , *zXmJ11ȇqc^=>A'r /qIG3;Otv#IGk:PE騦HfEv5)Blvkڥ6 p_PYwM6F, j焔R܉,m__f|Gꑳ mC1jɑi,m t dw#e{2F*bF,PƩf%dwPtfH`ZDdMgv@Z0T6!ZۗB-.mΤ8)+M\)Q?G4;X1gGuk-=+7-<#'tF-eN[{6$ǓkÈ.]{i ]E`D3/#j;~! .?Cf&SnMjh_!$!)-6zES&B6{H_xZyJP ڊͯ?CƷT?3QtÝm=Dp+uG3W)?/H{=\IJ1ۉnW2XNॺ!?UPx-P&$I}/!k>4Bw 2U TDIa-4 tcг9xܗ>,s5mD z2{Y qg/1-׷.l|LEEKi+4j͡VTfӺe@NUWw+̐[Yv ;+{H$)#:iiqs"PUiF_qt$ , ?7;Hkv3_!y69{h(mSu!Wܮ3,Y/6FdێDRjhZ!cSQlYrL=4&ӌVn4c^?xl(ueuo:Rh=״TKV/рO#xQ 0ٯ)S=J,5z:Jr62fSOB(8txy02x闤3!qؖO:@c⠊h;zXDꢣgdn6nE"GbaY\;ե$`ݙHb8Z$O@Jl1) nՓCORx=/[޴6{o-iPpǬ t* $-8 o_D zw!RK;uLDk1aNšPQmBBO0-#b9SY}%6(b`Oh\![rQd2c@۪ɱY)Kr͔6Z+$M#g@3D[d(SsNDCEx2n7DY4mgo|J#mz=1`LzHPQ8/R }H\7$ikӕ\_|̫Nwu?]bw PdbCԚg^jv/mZ" 2+巜(N9/h<] o }؛"~B:6Mf /q9"%G/. "0 Eu\#wT{&Nw)x6KXq2An$UĶPleT6:3EzwA\#A:FZ }$N~*,Dz4GEןWkGwoSv\PܴK4y'֜=ngLJG$҆^3~ & Qmc3+`mEjalU?i3n m5P;k:!-gҝb.@c8F;&EE!,Ŗ͖\&gqˋ 5tlzn2ic49Y`ea1IG ҩZ!ɸI?bp?c׿`Cf#%r!LMv`BP+˔7DWkGMc](P_'g >A)(#/vT 6]0a^0 B<ǐrBmu[6ײ#*Hw*·hkt[AF{;E&n(ɠ"u{lB*#r?p›ͱٔO)v|mO_rwfԐ泄8ٺu9FI+o9(3bLX'NT{Mnt1gMv&~ZF롡rϹRY✘_e* w$&+BhضA6]ۙMCo<7LuŹw^Љ}P9Mm-u<5{ʪqǎ*ۻ/?ƀLعRUzuYPIEJ:9#l |4mUeGtc`j7XޖҬqvr4mqgebj\cg1 r8.f"~ڷ}D} 腽o'1F-}iI;;NZ Ӓ$ms%.b^tyU>=ŁlIz:i!;c2aG'⡻L_fh[g'TЧ͵ѡLGjiO1Qp~XՌwX [~"ń͛hz/Hri QٱՂܡQȖUUVK_x`0+/S_[Y4+}ZEnF:#tqqIu'Z nhpgg*]й%*ؐZ:ۨ}!RC:ǎ/]q*WtuU݅gddo*@'Q)cseiHT9\4ekM+ܧпzwk{I*h-2B6y*>d@Lq7i[,55I|.5/gKOwF&azŃSJcâtx =ٻ}\>ȿ '=8x0MsQnm @"2;@i;Sm*azn f^%״Jga]>90=+:nfRg,lQar5 _O' %. ]2Bո̲*_Bkn[t]D̓,('j%{0&AHzꙦCac,h=&=LtW6 p?mǓ>qH?E\6-\,-+.}A{:i Dm`l=zj~tD0O0bhУ|QnXOY!` y| \M/oOт[  KSRU'/J(RP1f ~3rjNJ5 v$|AU_0^oP '~ٝvP&Kh>zfCT-nMm:{ ؙ->9_a٤U(fSJ U+};us-lqdaעӖ*X. &7Tx3VtDPO`'v(׷zzXxJ޳}Ǧ4< 88L`"F@$?̲ĈnY3))F.#*Ħuԛid{ )GWBX0.7%ؤjt{XQNZFgl/dG7{TIdjI  C"*{%Ǘ"8Vn)mn<\5#-__{?LbB"^BB .[ж[Sz49Wg=yM{QQJM;u]Qb CJ!8=HGĘOxx%9WvT院"ʢ2Q K&e~U3'Fn?-^kJ_FClJV3O!CpA})gaݑF(3]%ܶݾݰ EENmgtP+0:/02duy]<B8U ˓k|8kIzEC$[/RDoֹHE'o:Ep|b-a`%(ԇ\nK+Pb*1Ցyʣ{e/Ȅ_"0"tu7i:"du:!눪*/J cNr2WA]&'M1 U7N u] )0cw-$ibE-κ1NrœgCe݌\˫E8nv FL1e:?KYAAW%LIժd*C ?QOd.kUzgA#:(\m05)bc%zU4P<;mޘ^.-޲* )^_{B]KNɠ4R+P iެ}闩^<7貲O ǀGZV4,w6[$)b0b>:WCf˔ ap0Z6*wއqE?\IJ`Tw>=h?OF#@ {S~"\{Z)k|̱obG lK@>y)Cv,`'& ታ֮Lc~@\$L[v"/sP@σ9˟5 u9*R;~K@ WU`TggqX@d@5n[^RC0𮓫LVU,&Qe& pxJ[T/@/vɕCgQ L(ت&l񑂍ˣ#pޕJ_uaӨ՘9]O\Ύ?(S${UqɎȭ@s[f'ϓă2#7WWsw9/ !hTHC2c_RAaVR)WKf!0j^<DXǢ-)! 'oyڝ֤U{uP_bwE'~X n|u `5Q96QxOes;w/63u=c7M"R;nF5"Ǭ&}:e̓gKU {VGym4{S3۱>,C_5AHC,ΣMr5n?!\6Xa֎[<#ig5ܚWGIa T||1k1BuyA14z7pq,!،XedaJU)Mlrz 6Єx+N49|+[FCIa`fPճYOM`DVEc1MlyN9aB"}@qo4jVO CiYg(ḿg%[Xv|qj M?/97R D`PSNo)F~vdp p~_t|[]%UQq⹜ۄV=AZ+CޔsɛnVL5حYCka\Il_*N(@uc:.N;MC͗ >\&C Y: eaA ;9]oTL eI2Mx"o!q]Pfx2ugs> S /{Zg\c(/7tEHj yV+J#e ^>M)ۗK$4'tR&9~pAekH+zz*RMo5ߨ=UDh Útw!,4gpq%w:ע4n'ӑ_İyj)x8=tg7洷(pه2. 0[$LȐyي45T`+F ־Vf;}ϣ n-¡֓ݬ8WJ>:ӧ;3i!jC[T.##%ԓMSn:V[0l+sޖĤCwN()ܷfKs :PduS_9o1s `RR'*#U#MRe1xuǂjеXq>ސ]WuD -QR N"R; 5FPU6@A rn{|uގ( hILq_NҒY ['׸"AIk><+gbQ}+ ";Z{3w6}zKm ~xU?:Z&@~*9ǷaF%KCX)fAĠW6J>IJčeY&=2 WwOsW~QA{88/_L"rA)iltxJS:/pɁ/Rjﳆ[+ YmSg .FaFʹ);5m`-U 2-v(%'?Fjg%<2o:3YH|Flh.V̠RkoiA a]7_*Iqڨ:C",; BFUrJׂGV f3y[/\*K[[qg"-)^AFjlsXoI.RỞ3 Wu嶼Q$;*>5Wȴ~E\ k!LPBR+af4nϠHt4n6yK"{^2kT@/gcpWaj%Ltq5>N$L53nΑ!-]/Xh z{ /pM8ܘ[R xwSĹyY/*cuZ|(V66D`[-S IdUڶZZ?V[ ]߾*l/2+2~*k*Dž*ݬ(>:vE D"1HOlNMj(BwӸG۞{lӼR`LIJmlucui߯3!-nnʯ^}R)\8563~;KQHd=`vU6P98mNuњzܹl ދHft-*:+.GՄ1'1奫jV1!bOꖳ@a룖~b|PrAU[Eݣ26}޴oRSmCH<<>K* dAFA/臙_\fɁruQkI<s?̣#1]Pb4bJ-{1%d )(?ɘ:t-"|CI7[fX ڷ_yTw7_% Xh4~vF\m>X{qN0slI$!<0U~58FvuR*9$퀕*%BFբ&JO/4௑*m$maYuOX|tȱULXjS J ;[~H `Όݱ}SܫFOn2.AU,l "B)VD:N7 qk=dM'R,rЃw5Tm(G~Wbn {bWw -?"$Nh9}BZg2~Z?k`D`{T Ѕx0t Vd>>ߒ-S-pWF2crU_M06<M]Iǯ9!`LZJ$dwS!g_Y@j ɍv{^t1+H.^bx[Z/V=U&cRާ ϚYxf==yFʔ.L✑ kVMŚNśڭS$e_LM qf $,NQC|7A ^0n,^8ë=or*wAEĻœ@r(:{{qCxIrASPBA0tx&ٱoJ'uOdq^k$?md]=3է>&YHG/ifbVQ G-Aȕۢȧ,Pmi5 ޸4!+{C?~*֎ @\Ho͠ L( e6 òg!;uEXc;phJb1ka w-*szD-`9F %PY|ox Mmaض2XF@zVЈJcxaRM4;d.VOr@;qY-ȭI>FF C{sljFIsio۳lkG|=ZK}?yjqXO HW|މKC)^";m٬[$D(;E_ph0*7|^D*6mC(AQIa&I mp:쫟Q ?fHi>̌T|7Cå!V,̨+_[7vM!URtQjc1`bgPD7@HDyi5#DuD M0s㱻Ӈ.16ֵL&)-1M60,O1,ewSoSlsgkQmFj7~f.1c8YAm}z U2s]o]߻CLCѓ'✨4򪩬%Fu'0LOlСmvP;}1uB!.faJU!Z˪ G~ vS@*to݊A#MPstvvuǭ8]1oN 'o-^`I>f- L-"^G1!Zj!X=Ho:&ybNTȧnb^syO=l [b7q e'ny)ocÈH԰Oآ'tȴCVza&a4HGؾ{v_cʐy(b%:ǂ3ȨW;}V@b z[vJz۲$Wdvge[Hū' lyqkxM@'Ew-iHB%h˘ i=T:D%Y `+`254mlV-l I\;?9xܟ/r*( "UzDxwj=Ƶ L&Q9r(i$Ш#Mj ?;'/UeSuL6k `5W ? ˧bC hwF;p{0ss0 흷s+9xo8CS1YA{Mfdu?"`0hda$[7Dv"RCr ,N :)T.2ڍw^ jg O!ƺ|h̝-ǕvTP!29V# + -xlY]ahbpn/N! d2esB`.7M.Of 37UCZUr%vؠ8 Qvo"8=Ejo8u6C0>*8MA$HpҎfs b|D}.aJ=ٺ'.%D"HTَ(NV 7$UH"2Ĵy?5x@2UlMw"8`9-6Rڊ(r^ dr#^FǮ)]܆w^qN#k9 G*4FV %i=E'ih2[MܞѓjIStF揠{C2jƞ҃hN-#I%e&3ZHH~Ӑf#<;y׎pcK^#pgs)x>45"\oGCz dS1xLZ`9j"J0v֛{~#ѡ#zm_(_m,4%~+fޘ*F:(gO4, ˇB3LZB48Y4uYiOaWNs9?HmNqg 5V}]XBpMXC4+1L#eΡHu!Tc:@uA0h _q·jdkAk˒;Z?]!茋Rp;٫YtgC{. aID!io)D4/Qj͋A2T7DC:;“q#,A`v ]\:X<u܅|Es1]g96 6 W|YvkC&[GGCaĶx_$ieu1 q/" NΧLhUB%Ъ^gE'd1VKR ɪ'nwVe7/͋޴y80-hb؈ < !~ݒfTS9K fUfe픁Iy][sZ&3o!Aܿ6lO)PGXmJhÜĿ!EXq䅱Ji5 !#3E]1<9pן*Ǟ>߰{D] `6s-'e珔 d4eB:hLl튰| PUMQTLV#&C?Ag߻5P}nݦshql*t㕤5U% ZZl/ꇢijcxLGol(9z"3Cw<{F5r~rF!Fy$\̕0싳.\rly B@/b({qˀM_ N8QyiiAi,fWя1Q70RaB͓Z1:VY~l*~A?Drloam GcTFɭϫ:ftk@@IX%&Л7T9I+>g9Us k_%Wovc$lYdb})y迓c0hJA_;ʾ2n%J:{Mtd˂N.Fʕ>OOuQ/JQPlG$:N/1b,Pխ-IS3jx`ڣN>fEOQB0'#v6N=?t6{՝7urwTqy-/3lYhs[)kfgxX/h}57A룐uCꢱ+`$H6h8KemjnٗP&9 PLEwxo1 QXq9~MT 4j0H|E?L\'kWx˝4( 4K<S'L NF\jov\Nsц>SiJ+p5+BtB+ܴD/]W) 0eZ;X eg7Q틗i䆬11HfVY;Sy3}vezYA)nZl6xh0-tXYjzS}뢱TC4gmw\!OlS)TQscbRE$Lj"֒Rڅ~U_rr+@n 7PvjϏy#)ՈM[ԌV`I32ajV0D0 Df_Ka ʴm tKdp)*"wLEz/ i2qݩDަщ D/nr];\-+FH~:3K%qnS`Zӧ#)YzmZMVlTu-pBԙ2FUZ%);0*6j0y ;qhVa#[[<_K?U?}wb@Qraʬ|cnHcMbA@kK㵳[iǴ äU#f *Vpgûg{iIP!E%dwFdܞL)|/l~$;=Ga1˯uR@њ~!Wr K,ډ}ٍWXo*֕Lm 2 D3)RGHqfG_1  U=XS@dm[eA-\sD"mIyj9sbK$UFBSְW4>qm&-YmgrEе.L v NO)DVo9Q}iVR2~>$$ϋ ;쉸E ;iC| Qgs!v?tƯ4{߅ۨa,5 ! UH HHuJ@3eN}ʋ![C!j 'GEp1^&|ʈe͢}`,@e ksL@4Hu> Gs^7[M,hw+N .^Jl(Ukxӿ9xX>Y(V_7<}X?䡐aG-*&PLA Sa@6 jPkUG3 bR-\%vv߇b@(̾FQ3;$@2 7nirMar&8Mu-:%Ĺ4r9P鵲#$ݨKqВƓ^7l.o18S$TVNI1n5̸iiͭGcvj,w~6 1X2V)K7Õ~0D(qWj";Qܫl~c4F~NY:bwc$hƨ_1වufpOx4/#. 7XMHv.VFpvwD;?pKP6 e-}&9]5nc&t-[73ռ -_2G\qQ26Z/=HeLTТ׎wDI/0)a{ۺ`?4-u=DAJV.RrMb 儗K}m|UCn go1A<^R]$ʽ?r:6(R=ԆO+CunF!R1ЗVs -)OpY+$o"11Rs c_BWS$BRJj|%EKD~0MÿຜΫ,riv&4@(]N%fVF39=Abrh_CJ~&+tCnD1WߔFdy5t~>F]=A-,`ulx\0p;9d\p*gc=~Feh28Wo4GVTeǃIiʿotЪ`EM 6h"jWV1K^\'h+L9d֩~Md]++nBg(C%y2?Ml/p,3Rע,Cڴ:ȴvQjY\ۡRyB`Mxi&FI@BG@ |qCPJaU$[؋1ڧ(}woH#ߌ(!S0eؤ_R/|rڿeOBoJsrF1ZP:kY1\BFDj@ 1+&[yqh=ij7_1tSXYz^gGg:E*wlY}!U-ߙt\h T,oضruBNxpX*w1ٍ>-/©.")ĽŔ/>r'`qKVyK|" TvzJ 5U76a嵘!^܌7> wR4*tSl8b w@ \@E5Ҍ*78NM&3>q=*GrUwǎCZԔZK,:4\)҂.qb|t^X9 c_$*TCA!^T4NFd`upC|:,˂a@$:?,Q2F?'~/PN;L0L>@bfkE89,ÖXX-0g^8~G+jz^jZ0M*[6Eɿ vFjEFLw4X<6l Dzw\Vn~o X*%tEd>6dNPB4Ԁڶ'U~I 9%*˦FǑU1 'N`{/XivxB7 FىToWFP8}0l8yL a{{cdQ'l_E-͈DXFob$<ܭwQreyZg^fcX=ͤqҐ=*CY2X] *qkM<25ʎ% y=_ 'vR&b16+?Ճ]n7CQkBaYMtI$ӗ^H][*6+ha>@>C!h6õ vKQiћTʔ@AzUȇ@jPy®[=o 77I{;bJe$izFQ#{:JHؓYOۢN*?Yf.=z̗vlVUio?B2yu;Y߹W09Ra+A#U씍AivNV}2NLCe. JIxK,.)t|`N ?94tk2V ܢ#O؂ qvZQFݝ֬ \nϓwkewJM#2:˸ 1E l~nUuyKfer3 g,rk*ϬhxJ5?% K:9"2@\/73l|n1dLlt`@xU^|nV}0~_AU!;IUn!F+Me_ʙW xVgNjK2Xy}7bs/>dsvRG3,>ޫh ݧR^2 dˢm(#ۜ-{Ciy[w{˚;x*TokFNU\7% C*#\7$Xw_wc?9Us-ҍ %rDozgo y|hCЊx~A%CyO0J\~z#jC P._ ~8]YH~SӔc EowWŒmCRw߬fY/2 Gk}|bj{E ̴Kp ;B|Gwょ

'И B LӅ0iͶG6kc60RWLHDDGCxQ+͔6+N, 1UuA)9T#L.5%mߨU (10HÀ$a@lzi8!ANh6"$d%>mgs$o+t򃁽k21Ʉ653`hX@  ԃQ.B}꬛2—lӑFɎ x˩9CYmOʎ ίC#BC}4A.@Aq׉g-VXn.Mnn~c;Y8:d-H!Np2Tvr"uQ;OvOl~ZT_)1t^'k2Ov T(=}cPLUJXia'8+-D1#buwZa732-j qi4kO< яqHRYC)Ȁ64ֆΌ!y@+9gL~<R<LO) Y}{_.6SÐ$8׽^~qՙN!8>[ v؈eL0>7z_0FEeh2dSta- NK|09+@N)~>Ȗ.F<$'2s"@6067:ӵ.JVz}#7 ̺&"н/Q>{tTU,$mWNxs~Jr@k15;mn|xqyw/$r>՗IFn|Z2`H%:dhmWEaf!uXV'/9Fdsi&ySN@#A$9k 54 G{~U*¼OQ 2H lNB"ۉM#$nn AC;0iKQ ӒrmP#q1}QZiſM`dԟ P]|Gg.ԮM40BzV'Ar'qboPW\X?Lf"3d`G%v5?}ʜ}^dzy/Axr~Vrq7<˒x):~(Eg'A yȴU Y2VWe^kdDEX8fI j8}@塧$Q2 #",@_nVܥ$,Wp Ў oH`Kɩ}xjoCÒ:}YC{^i0S#2\Eflމ'eyS̺[al\Ao7*P-!w836g臘fҀ1avɫ#bY0cNӄ0nS(.έJ2š*i?͐.wgm7L|wa\숵!F)G$!ah3\-ከ7(DR+(^eGp;mJ%GӞhRhV< *:gtKaS/ ޡ)cz~!wh#)Mb` G0 T]xJÛKUݎ%]QPzr«aS FZL;YG ff̺dߑO ^CZ`tkSwD#t ? c[:4$ cXxd4|o^Y64-ft A]J^^w0Qt^[eS𩼪 ,$\K̻O,Us{ tv7KJ" rHabdž]޵X0S?'A-=31kjkroLzwca-u991"&+1FUhgA }0\Jk4tyqu:ĞKLdvɑm4Hz1vRGVZC9Jʫ6F/k$"|*zc93rP0(= bjĢs볮V ,vDwbBٜ٪j2}hO~&|S#eY~9r$43Ι=3|~W(xC8 l c8G$ԶcDie%&U&o[Le|{Ov2p7?(M"D7wt{r^j(Hr0F@ &rG '\85.7<ѧZR p=t6_Y1u~91\coVJRUP} 5bz ɟCg 䑗ZKmV# q16# -B z#Fb0vD()"=֕uEFrT)w"kIU`zϿiIwXۤ|aXnf2j1?p(A&b|JNIKR.BS2u׌/;a "tU\WEX΂OU!)N^:?!0^G"ٍ.\W-m$9/u߂̮f-hDR/k+R,8FiX,ȟ?Tnn`YV,4Dhu[wK5 k]_; 9~m0yڜ k37al*e# nteLaPDUs͖C.'(] Rz@X1R&vՄEF G&ݳ9k~hM\!/%]2>*r2Bf EU3 ?}΂Fxjv1@}!iѴ?2= ,ϔǔQ=xNəj4+;F'3_ިk@IUj\]ԎB!!\Hvj )o>X5)"0@.!]1A7BzI@J˸[NĤPZuY+CFWd{/`#3y SZ0MB Tא$S!<L Ckjlo1+{CB-7s6Upفǔx$K䔒_ӓn4n ܀\-ǖ#b3z"$J,b=} `4D%!#`n7V0RJa~=(_y{j_n7Y94׸][ˮՎKD>[FlNW8jښYo!eXT`-v?W,׬U$[~ +BfLSiEh2q}B*r~]yM4~<#'&f}\S*Օer)D9a2mSne?M_j>7L~MV~Ԏ;oID]݁@ռ+(CZ^쒑(m[ =W{B sTZzF%DydRNE&u"g.)"?u>^+3M衜hdgoJ:yȕPz6]pj[wqN4~)<8 JQP~=ţtc42VjRL?V =\t%n--3h ~,-qjwVv(nIJ(+=~b:XRIքsn^ёS 缦]#8;ǜJxXS3D]ubUlx"3E>һj5RQ+H*?mLj+? )veRkFP{ց}j! l~h2@b~SEi'a 8Mj:9ফ #ꁒ/YPY}xFC%,Dw8nXܷ a *w[s.+nu$Ğo"EZ-)}|կ~ 0&>ҜEy4w)vЦ,qc!bi<~H^^a42ӺئS\NXs|\kI1> %.vnrn+1uO*~u/teDD"$3>U9Ca켊F\ *o-AL^ٓLn>;2QSX:? F;K1#}&e)kgArQiܻ_ϑox 49+W&,e|HTxVd:2YY!v+|2Lĥ]wεg`\JqQ|軦>j>U7lof;) Y0܌v`O3htk#W]*>gEʤd7Dn`ִY5QMH }>@v (}{rԥz<(H~-ֹ?`s.ߖSa9NW>Q瘾(f( BdY~j[&ޠXLЧpn~V/f! #FkI0w~n$.7mI5-xm}- Oa=~\>&uɐ19rErBlE*_H8Q8O>fX:"2e-0 th,mJr˜@ 0JdkL5JT_Ȩu+qʾU@,m+p; 2Q\ܻsKfAlF?G@ ܍G5P!,'UH*$L)~ѵI ?iEKO!`D i?D}*i@p]ėnġ)zN" ߚdzҦX#VA`rlx/bX@Q") 2r=a^Q%+ǰ \,.=jAgTKIa-f~7Dsۨ˰G3(t$`xQ ;jAtQ4r W053T\ ?՞C,n) ;_zk <ތ&BY)Oƀ ;Rd*ðzbjd!(#IEFdk(;)G_Jΐ$a?rjB 9Ʃ8juABQ>=Ӗ鞌P:4,g:LPͺKefvbW҅H:-f?;](3W݂#iUǔd[ V`'@q8/"X9e]z+oY1{i x%t.=DC%tֲj襩RkQ.eN?%PݎCOi~V `lt$o$F2XWڻ$oxUd˱fd8eUSsKK\s%GBP  hT fעpmkiG9N86q/,Hvm{g/H^D .*kR!L8x`mLҬ ޵ 3b2t=r}z"v%n䁟[P%܃:Bʭ"MҼ1)"m[x{In~㪱XHNkMhbBd2"Śz/mڝogWMzm~jC|wgS-}9}l<(!Ksfj3bN2-5\o G^@㡿Y2oFz2+5EN4 `,Bbfg'Ѷȍflӻ3#vYR^f^Vt!8`z2C dj[yl풭lHCD !C>Msaπ?\)rb_M[֨:E&t  }[-*E8NLO-&fW 7pc }̵Ӏu T^\d6&7^Eu;щp!@(LL`vy6sAaQJEWh!Aۅ _lN,GZ=g*j:r\z1U}8.)$4JmAg="U&С;?X¬|q莘kԿhn4XR|5 GPU" .*fRQĭ_- ٳs6"@:d)ȉ<.ۈZ|bĆ5]\~%oQ*YWƐނH8w8 )H y5.nˆ3CBټuB$ezpm;11x6D.@~7c B5%e>H͸B`'ԱOma9o[WIaZncz.v+y7`j+!KP5ى' (,f"=D)= %U*hOF00̥`%@̜.  -(My"+sհuy ]#t 'nyQ椌K!KIYꆕ/`cړ,+w[/;&\[Pxq¥7W$2#*ݨ! 'lʛtѿ.#_>HmRJ*(K.~[;V5-1 mSq zw|.px=ŗ 1dk_]ṖRDu{Ye |( |=̷&JLBNArxEY*9"͉Fzetޯ1׏S31#Wf؀Tn }^_pBǕI栝|LǗE:j ]ⶱ{O$-.V'xcGD2w}>dP8Kᏺ05=Y-siLe7%ǙQd gȖ*r6Ͱp=6ـW XSxĕ4(aK>Yq`uUu"gK`n]|x?&rt$ב^TҀTͺ))լֆM1Zg4̍>"ckEZۭ'jEnpl߹\&߽S̈́Pzg٨ B&7r"8%IZ">Nu>mX*Lbt'͔~w\\Z&;<_u!;ZݳѦ8e=(y{]Ik5"xtcCE:Q=nbi):%YBDJbGo/Ke_RqEji'.(WqgPi)!cpmf~4y=(R,YL&ߓΈd MvKF]*]8Q(`@45A-Ug0:Jeԯ-MŠF$r+E(㟷,kt\ƪOcpF^ `Y4nˎ1@!*j Wvz;/bY30uȰ'ZSy? ORf$;xz2fx30Z4}~ yXIEvTKY#}Ӑxة/lN0uf h9cNQNpGyqL_*S+_ <+B  ӊӖLtE(CtɢW9!Rhoe,01zAis_y*wT4ƽmbdkܤ1Xgb.y)hVC9*>[ /C 0^-3n 1𻷱C6·GA;9|SdtDٝijgDT 8guyZnto43q07́u ~b% vd|a JpGx7cC(R*nS+Auׅг qbl#^Ƶ6ވ}ӗ}TIS0ZǂFhV,lWJ]]7KQ!8 'a'TMFMJL wtnϠFbizSļi4L%v-8QRd\._"\*nv]m?;^1F\hpv.5^4J@?!qW^7E"\NY܆֟S0 xkyK!ꓴ?oFح4o,'3kU6LVOcewW" n2>DͺSߠ¡I~ZƯI._:03yk Y؍!y7| :pAٵÌe{AJ`_G3gBU iX -뢉L@O/>hFǾ #џqVP흳E/pi#.bF7Z!6IĬ I4u\j.ǐ  j|Ζ[6<1O~Ac!vCh.}M_m8Gv)dT%* &  ) gnQ)1JW?s&75-e(ve`ԃadQRB*= 48ᖎ *"6{l Dɭd~4mlee\qR s5Hp' N/*/}6LzTqwSUhl#ICJy'1!f`b*Z@*C<+p4a׏Ԗ\C%CCU6L^Kepl͸R \ƸdV1D+ȱ?|h PrJr7_SFtTP-p%s Q(u04At#lU2~V ]ޮNYf=Ȯ#FF7!&rzw8fQ~A(du}ю&[km1*Org?CqOz*9 (]eyj߸I<(Eə$ c7eN 7dk\tgoY%řŎ#^>p&aM[M%Ae+ ~Wsoy=! r[+c[xd@R][M95Vљ6pnعvr+k_a0=j

!0;/Nj1,7Wf~ѠL ?,On}@ s>0 ${\Si/3/XZ٩e|~ h6|/$k7'miUY5P/J@}h݌$^GX/ 4.,nզr+0h]F@Q<:fY4g%H]*> ^]yEE9F|(uK괁NԖW|Bݏ'[+AcV~ _܁˲2b.KX HxXG^>֧L؃^F8[^u$~]m)$Jm8'tTRGmG<Ҧ&9$fg/P[CŁTo8.B'0 'x ⢍Pw@)c LGeRFL @,8:7L!MpdH%;.O;|e|(.i$>]8bzFQbѠij,z`3=VNPfǎn[C}t=yGտa+kA& !5w W}i#tX6p2 OI,W.^,q)dٌA;a4߇TG3=)!Ѳ9F^w(+-gyWb"BUƿ9qOW 5^yn(<.6cpG(DUGCA:$O\Fwϛ[or0<9`/r3˙,4,k̝Dnts"Me3?>ȌpiwM'hR"m^ ̐>nɜ6)WqAsdv ^ Z䮜EcS/ݭTA#־w2ޜXO@{PG%,$&Ǹ9pNM~OՇ9l-;R 2Q?{Ey%Sk^Lwv Ѯ$rYuAHmR슁x ?2=d1;ߠ/%PC#S|h dn^4\M9"Ř쉩ۢ^T0MH8xq٫LB#DS:N ޘ[rtPphDh])dvut1Aߗ_isb qyQxXQIEPL}VEῺzr.p{f禡0:P@[8 Ι@?~>ZܽP@Pt,#Q9_G|F'Vj[]42txܳhȺ^lhу6&"e^{y' OkH\DqrUT*vHؤTCα"cJ1>07j)s ͇$ūzO6(`xoΕq$9<A&IJ;&,i um E_[Q'XSˤLWZ֪1E W+W%2~;n3)m>׮k?JdQ=d !R7e4 ŰPُ_wZ*:r0f1แճ0.덱^UU(_(ZlNh:̪cdDɼ$. PBm屆_|Zz ],=~TD!xk v?p؟AqNy -O|6..`(kN{sX?z4n2M8-zýNtt9'D_\j0%8nT6ʖ~DgScJʌ_bT`y*X!@#1 Xki=9hQ!ֶUIJڻ8AReLW\3,VX榩T[9jD . WfY^g0`gIq%D61 o 6lܼ]9yLYvgWJS]"N|8cT3 Q;.7i5R[+QL Z[omɫ."PlY^7yCSJ␪@fCdQ=5+|.t>l 7p ] GWrn]眵`Z7&meDe i:A;LVe.eЛAqg3/M) AKj~eMjOF~…qӊF2jX< `_ ~򟮫=)RbڙD69oADp>XIfr()¿Ap wt+I8[͗ AJuՖpFG&s\ jU:.N!'/3]EG7 nE0kVqKyc+1Ȭ@d6A\>y6gǟ[$1+8s JHgKp~&ȣ퟈/;cӝ5 9 J#a Gw5YO,v)(&ayn`mC'@ 9r?,Q[Tk1&vJP5[tשiQfI^;(pL&ێkxd&!y$4&>mA\s-[ CP/t_;!iN7<օKr8. ¿ֈ?̏,q  ~.z/Oڶ"D#Yplha N-]S=}=pW7ȫx%R)!}etP:T]Iyb9t(cY@8g`|A6[<(eqOu~H+pD5q{_Wi8g编rU7V й.~@uSgK«qvñƶ8*cCD^m9^Iid{x&fPmۯ!~J-@tW;sߥ&Vv JM;X * 3Y$_axTMB>k{}"`;sd kf)_zgna/rMTrUFrKO=0  oW ᕵ}}}? >[Udw&Mj_2lq{zLyF .XG#KuՁQq}y'~}`Cfu1xLsI\G{+(K y[X. Gw! ͘~{vJƖ"DVx#.O^,0nD.K:ZW曖Qy}_VZŦ ,4~`RG\yd?qwZ,t0UV GU'*])N FINp1^1BB{iZO֤XX)ےt/q}[Yﰵs痒4C0^$eY(z5Z(j6|&a#ˇ[2<u$R[dQp"'&:HodՉ@r`.M8 }!FPg.1&O( ABG/% .uT>h{[OfKYAS9@עPfY\4k eqLRC`F$L}a"Kz;z<Ћ}$n7͜.iELD&MU~d g2ͩ'm@/+? 6ppppB !4J%˯iEXUqӇ@V`yj~0G~ik`breZu3E\!R# Qb`yNH[-L%$.܇OOu~Xy,) 1Ku: HMRлQ1uXZa:I35ߒ7?/)jTY^$q!Md${@ܡ!D&Fӕ1jnݤ[[bP f ]vR2?\`$Gɟ3GR2D×ߣgRd3oz*]GYbњA8@I6\ۧJvy"ku=J[R c]2_䳑u +#: sPVɪ爌en޺ʢyuXl:SpC; CqS@/נ$d?Gq=J\&Q! UgvBWO3)ؤFGq,y|&R/3Eyp~NN6A$`( L*`< 5h4y̿`Q[y,Ċ|X8^U'I'/q? 6) v1x?~&LHtbԣyJ(Cg_L{a 1{Ib/ (  p:J"J.:6߃&GHGH=x!0KWE`x , )j$s~Z*Ϩ7_E>} !?T:C*Fʴ$/WQO]~oӤ 0Pmyr+Lq Nq!=PQG߬Kev>hj'PUz?4f JØ3SCn;g0.e"vIN |Zb\Rm 'Fh֚$Xv x;/{׋zpZ.djp.cJR*ړ!MrtN !KΉCpbxY&n@Xm X~uΑW;N0 yzeKKgg]'k[9 LiL7gEc5qӦp^ Ҁ|:tFm󡫰K/j&@` f }MP9RZ WڴJgk3L]l(sX*HCJt"cRUsi~@t!]_ht(:C0[w$r(v '›iPH+&1w9̠Qp.iok'gxk!W24 y.gɥy$ ̻pJG1*qWIPᅪ~upYazIk_U{?Y \$WZgNM`n@MMa>:"iosz%HiKS}$a^͍ΧF[Xg BP?<fl-v/{Ghߛqpw\i-b6I=x*hx*F'6Lu#Kޏ؀@#{ s l{W+f'8(I# 2$Ix I^Oˬ̋P"Gvq' nq{m)vCX@ǃcVX,j~.3o`k ʴ#hP5n[S2.P::vZq7)UE T] BܛXr,CFdoWFG!oN&u:,^Y$"eA c&t$ꖢ{@ ɼn$! 7*e 4KJ!ƶQY>\_;d*ݻm8.bh|" \ǫ7P F׻Ԃr"8mܿGS*C [Rf'i@GIaHi ~Fl lUE{$B0;/&H\a{׾CцhPTT^wT?g_N5S$+ARhs53TwmnR TpBuD̮Є;-qhvG/,A˵Viz ΐBsn!ES R8]pȤ6 (NHyHaL9~i~Ѩh41ȩ fămM=#\#_i ƭFA$\>[=XfSq5%->%A3eu4>pؐXtd\cHɿT*T"z@ ts6`̈́rݪ caYí) 4q:aKt8872N6<|X0e}!̖^='Ѵ^X/qJcw=0yad?{T d3iW6RoVeQ05t{6Ɣ^*Hnrp:Hrc$*1Zuf&+x.Bzϱw7 EF>sH/|6"595&6J+*| VX:4᥂ơoghZ(9-샩ȝ)9La5q2P>k^?{`W4 Rg ۋ78 #cDB G̳Pu 9&0B-ןX^.5A7qZ9S[ ;1+ϔx㽟&oG?;(lqvq =QC./'2@oJkо0Wvi nc - pc1ŗS{iwE`^]V/ְXb"h;{LW8]8 \YiaM] I+H\I8G18P{/e; #7s@DݿfN~$91%OA[+/#s(SPw۟ZYn[ zƦX7ޮ4< MJ4p,]<jhq :'Ӛܰ6K F4,0S-f {͢9`OixY^w*m7d$?0L qƍ;i# =ka2m&P%~;ڧ.?q{\vHX3 o$t Oģ3m'9n]=YSAgnCp';Arjf!6vpmz:,N@S4iߑ+ÖF^VvJF^2`MdZ4*ִ`ǜDЖ8Af=?*xV"62sF{*/򚓸A~/PeK~E6݂NPA;W|7 D 92wH)J_|W%k踼LoQ./p[ B1d:*@pn~ j 6kMA|Nq $ͿoǎW$%Ї #|p8V :K34$>; (MOHjx7bg-$"|b. D%EtdQϒJ:2wv4ҁPR)}~'5~ *]!0#8nO2U[/FPo2ǟ>m̃>JQPgUY qߍwEdLRH-vk쵙Eаxwd#֛fRՌ>#*ߏ֭wVlQˇvQ.dYxN8 o(KѴ~'rG>xh 5(wAu8;%x~4MP;ֿf<6".+\[E[C[G8Vv/Kp/LS3([hJ[M%+O b/[:" qsF~ N>"K rގt""{(AFnq&dLKVvMO@kҒ8RkeG~|Mj dmzy;9SJk5iۼcP"Fy;I/I0 f1s;$}wŃB;=uklG3+X2=Lj8:lBw{@ZHH≙ؕ@q]]wbۡ{eÎr0Tx-A}-ظqzX=yXY+/^)㨁mؠ7 YWT͑т5=E嬩HtH2gb㧳ʿ*C[1~oUq&S!?42'G^~3/{֯gF?eiBw-d6żםg A}w{:2YcS)Hc#χw e7Pf4OtU<]sV3Y>wN:WS 9 oE9 2 |tvu _}p댪7˛P\(sfa8w 'UچdPK:v,-ڇO(F[ȸ<VbO,*Gl]Iayu=@Ձl|g0'41> syC7|QEbW'5>bpǰ _<8hZ2mX%w-rU@sªa;zDAe][!Qw:w 2T[8@ +4{߰z [OWg,OZ}JϙSꦷo Nci=!>&Dxe6 ՝>@@&CE@͐zU^I0&@?]xB]sn9kN:uq26[fcȬY14 ,4w_CT3QlKԙ)$39`GI|ۮ<"'8Z?0Vb`Hb;i#>0yfa!sEel}ߟ"jA 3Fj {W*GoӔli<ځcue 7b^q\ dYCBp\<)cy@U/I<}Fidh]c}Jd5_EKmkPP ?&Np-v*mF+g"u[cF8,MټGZSJa:`8po79t~<]\:@Ti#)bgdp_ј$ԠrϵESĢ@_*И&7qTw~} MyY|>Jsij(h}Zl1g8_h\BL<<=,j˲u}f@2:]Wg4HTKtA<8\Jb,\SQQچ DsfE[Bm%jF yvt}9u6yCKb͜kXohB` 9vWF257b2XvY6G@|,~**rmsfX'qkN`J]F)y_XUK@I vĔ?BV2r>r}l:~y\cGiE{K?0 zd+[,:"6Xt[M|nɻ0-1:vwrCǦK "%VUӢ?#|>fX5"^upK:ܫXVbs &7# + ^Jhj%׀UY֜KOa+ōf 4(E>Jը9ÝRZ,X5$϶eơZ'DqA{) :r,KPa=FK^.۽t#P{MbzuX^׀mnσ 4LOȢ)lIA}^S^g!YmSjSeuΌg#):ZQ [@=aZ%cH S{&|X*$lf^?f7E: BS@Dvrx1!p7=O[H \o:"PgR Dk&ZroV_D@\3[_v+\#f?acgUX&鑳D-j*ś<{,Jn78*S}0S^kFWI7x |g#vlT<àvVgWc-cڂqajGM9JՏ[]Qӽ`Ũxm|m<6`>E 4=>(E(Mq`i9lGIpZcaZIbaDj_Zw_%:h8NE)2JuB˭SܧW(Dݒf/3I.~ N &OeSo5wS*;8jm~@*m Tl7Nz,*t^gLR@?]*)t(+/ $'\SH'kw$} * ƺz-劅 _I2/W}IlNM^//L 憶Ti<Bx+vBCx맣Aq=,_',ލ6_\! E-\%c{UgF2,G@$%gm/ScX|Wk4[֕O+Y#q3zIh:(T1)>y/ѝ(@f1?p ty?b5|@%'9u9ӆ;6꯺>!]bGSOM 20&^vSKB@'QiTBxPY]ޗRbkque02rTU!LBfc&~2Ey >h̯fRς`2d.:Sʶp?B;Ԛ0KS?+? ]VRg !t]Maʴ ߱_{5[;$6 X}ګDHcpfF^U߁S ~ubqa'Lۢk]hbn5 F)!0 4_NAyݢ12$+?#?8 M<۟bƩ^ɪ?z } 3美_xm<)F41*F<؎ @[Pd#&l(U*!yHMv&2$*qAPiTl;`Vobgg[ƂPޫ#E݇EU߲tu A4̹t`9^~Ҿ lgv@ `;kka-o~Jb6Cqoө8e+|Q4nJPq82A WzojQ9.C߈J/`%tٖHZK@}]TY&g{15k^Qob4ÌF%";%DaHW Gn8 gAH3!*@m5k+RV35 z}:ȃz?{2bCc*[jЧ"YuiXsSi3=4Ѽ蛥`fẑ }/}h>Fw,1d?-bRcN M"d]\$ J |ՍM \2\V5@D3efu)=}o3PЪ b1+շk -d.5oi%6_`Js/Utu!*U^6wkgZUؓcW T(A鞘ʴy{+vbl)Xn8]-/j|/@TYbBW  NcYHyG4<%KǺMJ}5,tJb@176T1h#.zd# dO/ޙ 3]]RR GbO݅1iك.RM֛7S8ec~ 'Dĝ6g~J.)Պqsfƿ$ tHpA'zH){^<xfNpɂ*;Co/S'*&DŽzvM0仚N^0lfz6bW%Ġz}dq7 /y\A0ogP-ׄn ՟oU;roN=mvj:>4j*k?%^+=H:1VN7//V_LK=~"aoON|y(ЬtRi]([3%"IOK}'* 4SJWضzku󻿋[«ϸqr`l<ˏ+!U:@,qR846ˈ2VzZmiՅ.GݗK]Ƌee! ԅ[gG)JI%, 0m󛞊ٺQMv.Wr`HǰƇj.[(qʶg~JZoIp:&m~lTW,_(|۸u3 P߂#xCxVBx:xN R.VfnnV *pR'nW@R&HqJOK;bŰ?Ƃl%eIIx']Q |AyTX5 $sQg /V4C%zuBs{5 O&"ZUpٛɈa#4Bihh?Є>Biz] ܭM s5#;YxИ72x˘4Һ,\1| ř0[u=5ܚGZ:|Ǘb\~x&rtq#;Rkw`"0VS PZkWDGX3؆ԳϞ0ށtxiտz!:x'fN=|q@lVzFCdtaq姴s鯬޻'qvhD(I6e=N6xiQ%Pnπnz5"y -VYk&@(=EgmK-p4& A?<[ bNiPDbڵ.uIOF#ALX'sU(-Y5WWōzZMpcmY[Eƨ/UJϋ]_У7 h8 }>~|5J я4mFY f`>갽0ٌ UHn26xI-4hthZh 53hYw*Ky DwIeÎbJ2 4I/9d N~3^+8vi<˺u4ӎ I?kU-[KjG1K9Ix} WnE^Arop4 p20D*S۰OV-k['Ɂ# *U~C1s@Ob*b5?| o jF  5zw'jN]Kۦ$.6eo0QUZ^\k|DZuv'<+tQt fƽL~A,z"Q*\ވ.nlm+9)& Dxk[= Vy=۶6LG4(,y#2/{쾪ˢìq(]\f/S3s ͑Ѫ?_G~,:hE\sG.μF MX63°vPIT7a~f} _ٖ=ޛ0*z\nWEGٯ̋g{au);לfQF[~/["17o Z3/ e{}DBs$ (RM0M Ds6{P+@-&zQ\j,IY]2 2#2LusG.h;FM腘ںˑ{\h/3=6@cf8?棆vL`k gXO`/RT[#2ޤg-}/OlPA[CH+NIʐy"TMc^Xpv.֚ial.~ \/>: Ye$7$dJQw1O7rL)BeKID-5O򼡧s`!K3F DŲHD6Qi5a|nLNGrÛPڎROLtUYZTN2%X^)ԱjUoB][5˕Vq K)*oRf{q" !rֽWw*ߋ=x`'cS/QWnA)tŮFcQ9c%bnфrbEZ<2`V}67(fjvwibL;vN %9k%H vR5/G^4,/lmCZķ!)8M.+8mr*K%?.暜_fӉfi,8'Ҭ~o&,1}8ZcrY:ӌ#11Y?d#ɐ)"O~;魈RY;kgVcr2o'ӎW+:ǯu 7'q aNK8@ߝmPUX?+/ G3}*jn3"w`E J)!&ggw.m.ZĜM:v¤}t M-YF5s6 'AB 2Og}pQ ష݆ܩR\ Zk3?O[x;~ 0u Vlx &%įYFۅciw4gK' Tz.dzmw{u7ֿUڟqZDR0Kȩ@|n8muʟWڑx𭈓ax~EE7=R1"MuϤCkYѵ?6ϱxLR}2KWP Ma3Uns2ec|*]PCCZ%ZMs!6RyI;u]xo:sFz4 z/|iwg)jwx3z;GSE TK-J $'Y^NseIp *[' _( F>/VMx6Zn9!ӃYLr{= 0娣$"`ucl/l3$;RPQkJ| F)eEǕXex<6bvwH(H$P)fq4cs" Ny}wBnҸsw%g NpJϐgy8\3y\8"e9b9=ƿ4G7i93kfڒ' {kw#+$$P':QW+S rkB2^;=\ qJD oeFݦ>MG??(6dqQwQ}: ȓE]M1`VI;:طSz7Ssźj@%.A9(زJt;;id7oDɿ6@:,wYYw+ɥn*rER.-C^U FᕮˑA)n,|%1&k[Œ%bjB</~9U"}̴wK~B.05y !ɹEtB/`T2*̒K<-z^)T5Nbqokfp⹄iqnH ]}rLe$,+aMš  R /IozWkx+f !OdA ]20t'J϶=qzV@tt0!nc2͐2 !LoH˗K(TJ /x6dIp#!_g<4ƺr1n퐀+'ZT!:tS4+xxI?k`E(8w)rqskF.n$U3o50v ̉/}-[Ҳ0H,Tݨ!KƞyFV2c - #& qNߜ ObI`Ѫ GM731Rk|h! C  u4yAk̀s :R8cɰ{B)?:%޺;f-Mpar7ǃ(o2W[e$uir%<&5IC=$xfv>bڕ pg5b(ʭ:wu'ۋ۳CGdʗUH0S֗sT|daYNM0UУtYE|!WjG g8)E' 2$$8Mdepdz'H >MkuեMLa/LÊg?';#6rݭ:h- iaܓ$(ܗ|~` 1[ 87Z|i>/@f@(3MԦ$ C4(NЅʰd@93|֕#pAg\GZtBES̖S!#$ŋHw6e!edMFTѽNU~7+ȹM LO͟K·b`qT&a~@5AM#KFհh 4Iwx9A*esyWr&0\-0~q7jV7Bϯm!&,O{ӣqw(iYWx^lX:3,ͦhP ]=׋Tc_:gMfesn(.޳eM !TAoB|(& 2 ~!*w) #TQ !ݻE#5e>:A {yQ3.D<;ؐZlvvZ9(*uLMcY1͍"p }Kȗj.Zǥ2#2m3ѽEg9YLS|]6`hyQ@䳥נao8ꅾ&raVmqmA$1j+H>uX` F[ZJ$[:6ID_n=_>Dk>F8*v1h%Ӣ?s[mJ,$I!2>[B螯@i_?p߷fh2]p9FJpa[W,Ro"~ Hi5>ص%Nhq5ZEIL1jG %-ē}n*y}m1G?_`m MZ7{O(/-\#&1U~2#_Bxd} RSnKEZIJل0t̟=D/"UCeV׻A&鑯b==hm㒑秿 fҋh!ꢹkHzK]dQ_OiK$&̲,f}o+c&@q͖/I)B)W*`[G&I=!NP#Xl%](SVw=Gmr1d 6t2<zX)oiK i帏 >81DIg}.|Ρ<WSڝ@)U0JX5hS7ZRD#ȀLLBiBw#0WY~sqB62sC={1ڒIs I 4q+2<ѷ9+-L~t810)$C<7 azݶjzQHĠfrGbf`F7R  Ǯ(}CHbfJWvtk䓲KA7+|= 4Ig񫎣=`U}xMdrE\u (wv9*A_СvOX`E;`W_BWOITzCs@#qE2Q%$lu㰞yQ/ 棈܎^`8Sa=F9gůEP~kXO+8=ո`?Kܨga'cdNgzhn6k|41aݚYQc h*媴%^ås/*Ts8r}} 08!Wg ('DwGk-r5=OuV.+U0cLIzÒ@m7!H$Mʭ_4uuJqHv .'MMٻ20=c 1{kǸ4f!F,i2A.7YA5KT/0MAh''FVvocBٓ6woNjhi~wf[7\ /ᮻ'NT1=#A `C^S7#h :ڣpAwʣ{LWAio2> ^+Hx ]l{J! BWZs}LO*hiCh)@iI{GEY%]u/ ܭ%YHe !(El睋P ԗ䖼5YN3K zm"QXx7eY#F `}9EYۂ|O6 QV 4@YY V"caH}X-px#C&A4Z޲& r4,yhͮ!\Ǽ4EŽE&N;t C Zp|#Po&4ud6̆mCϾmDTB4=[;Cp[@bi6 ܱ%iFEP`6M;xLf>5 4f{8 ;uYr%zrt]wbk7ܶ<)$=DU/p*VܒHSTS\N\ό0^|< d5@3weB榙g;x CPzw05*9Y? 0*יn酦fow< NlҺը ~L^)=Ԑv>*v=q뎄kf[ @4"Ɏү1 $lߵ W&܎Z}2nEC~_alb܇exff< ի ݳUo4#ZD=!q$ |i3EE$H0 0GplHް QcX /V)Lp0554r(o8ۛՋJb:=8)o數7G {'!2}YRNG$iN!T=[ҺJ ł> Z0}[7Π~p K]PPʓaxZ\.z$Ab7WkpK_!eB~M*;lVQs0{>"R,'اhP0Wj"iO#v= EҕP ELz!!4 7%dj)\d Ơ˿Ϲwcɢ+_հPDWP@ZkdF]v)n^;!8 $iYH*o*=hֱ+&f+zR JdBŌDl-B`SܨLQg/&lӂj\Cآ@'84(5!}U2kdǶ9z eF-r2 1FA_*z˙7}K*L/g\]=P^(\䓸w|/dDXdK N? M=!h.M8|y k6F?<`u~}&|#C*ZL|']ĜD}H!X* ypJj0mi-B!|s>/~udޞmrfS <1 9vt4YFM["j`lmR`kaC˖cm30qB„#Q.BO t|%lz?Όcv?G3Nh2R)p ҨGHJWұNQxGLyU7y`Eȴuk?9kZ8 \'>^[PYyKC_Rn\)Ew mUĂ ;Ri4C]r].fu> ʶC07QZ7@mhV v~К3Bu./5ltE砐ܘC"ƿ Og 9 / [rߍߏS': ,!}6ղe,O.Í1'BX!/D_:Kۤw}d(EOtkn frI~n&82!>s|AU}ռNϧs ߳MU7ebvʖjJF҂sϣ1\( r¬!W$TlŚKBOY D uN8dMP`U 3e{!cow2ڛ \h|NtxKYqK(ĭal8H|Fp =i[̬eYi9;b~x}Ƙxh.!p#e6 :H$-M]zS⽶T8Q`K~)e18@g;`#2<~ S"#Y]1i#zRD;_X]4-5/\_;X(pBٖ"i qIQ)aڐ8S u TtH2̼'QZ;deYӹ\Y7$c.#uZClmm95j'V9b+j|jiL3K#TBTER5.ևUB2:^c].u^iǢYx<:-iT̟Yp~u&7Mjt4,_IoƏwY ^ta#w#aK :~ :;@yg嵮:1P˟50^jK?Yϫx+I:p~6J 8]fz[i+5[)c@_c_b 7ڌphx(/#,@׍>kP=a)FPQf#*mHJ6v#zk' F:|8qjl>;m2Zo ĿeA%4#Z;$u\^ fWIД!B9҃tq+;<YC5!Sa Ð.iK=84 JPB#>3+TހĘ8f4/z= |'$DAnI(]LqA vxc9ה `c6 h`O'o{A$uCiLk֗1 SO[X,G|4haBM=O3q|DvtSI,(ч{qt>~m{ 2X|48Hw.1>4GtdļF⻬j0ar  1N}[4uYG\`hvc#D>g/pa}mb9tYWgxDCu$Wk1= 3j2j[NUNՖ8۵&^/C|jG9 y`ȯ/l9ⓕfCn?KEJS$";6YY}`?NglSnr@8! ^`m.."r6qcd>n+Tczo,xm/5:ޯCv/8襼~ =n]1U_Axġ'\^IaiyYmD3Jp^}ޒߚRۛ0˻M ur"$ cvZ#a"Qϳr1#!91 P8A0#l|5 B<1E%pgXU?Ir G1~0]*ԹN|sn ž-7G: ,ݶO|b^2j|˅棡D5jI*n{V օR=~pôȨs/fJNb#y YXU bx Y%' ^0]{ 'Ikw kzꊚji^\jApΞ #Vkה`g:HM҉. >K!~x41~`-dye7ݝ!Hdй竟uPb8Y()RΰOFi7D=ch Ecf5VX$nIK` s$=BAˇ,,>57zJN""ʲD}Ԥ$-|[C\xlˠdj.AuDU՗/˗a}xFvݥh‹M.f0}V 'z^ )~jG! `!VGzK&)Y(I߆kgSI>WTз gOQo~Swu. 5A,@I J^D-4dE Azlzd Wb~I(o`ΐ c&KTD~pCG݉3ƀnB9gZ_5(N9PkзsAN}VA%:Dc|o/}M폡TQ0S"e0eQ*5='d}GG[> #gAYj8YH{=c<[:<@U@É*i UҘMx*,~mźq\rMxXpW_6>3;3Fv8:X,Y 0!jD]׊ 8gtVKp%q.1e" qJmFSkf+R6qQ9L~+#13N넏 oƸTOؼ(уT֪ g{TO~F-[d1FZ^rh*$ctmhY,D*68[_ryK|8 |&+ )ua4u lGK2Ilj;D!?2Ԉ|fR Xd-LjBH(8Q-80ӣmpύ Zng|n}i3Bv:boUfW:^*ŭĄsEeYv7k GƒKC)S-I6`Q/jWk}aM %}OTaqsi^{jR4QA4i,o#w'߲k}ۚI\ ÛG%HAof,K׫Nnz4Ǩq}+j3먻ղ?L #LEH@ߙE`ٍCKCyϓӔvb8c~kG;a vү$ 25.p4 #냠Gzdܴ?0H9{C5Hz: 1b ΢p&%QTvC.lL/{U nI0|Eg%r복ns^FԟGQPɦ=B$5ن)+&ǁ-YԗᢝӑiKUns!`, 5e%W&{ |Ei(oz‚9~OPRn64BX20VXޙC;3=Zi NЖ>\$nBLg[@,K7ڇckѮY܈Ze9 BU$,) 8;t{!KRᓚ?iN^^FmKZt k=*УMkax!Y){yjbw|-gE7XX޼B$q1K6{Da$bvjVyLR-cj7SEw p$o7)H0)ER5#e7"}L q7Ϩľ7PɵвBoU/{:,# ʙIƭVpHa z,n|{m \$nɋH.TI8ZVfn!p& z@av &9zݿ>bK"|} yx[?}fc@"er \o,4Unϻ!޴U<9nL-XjIupvm- /K\8~3l&Y唠3Sp\>_+%/#0L

5GM>m t9E<&%:#@%ݒȈa  !\,%̽. T-vfL?]'D!Czp\_@H^Fa YZ