tomcat-docs-webapp-9.0.91-150200.68.1<>, fG)p9|_V1!+rq!aMYSaC a*+^{ R sgT]2ȗQ G 7Mgc7>ӖsC^-:T(5zle9(HclۄCaZjn&3d1u]ot#Tqʹ|еUU@ "bqu?% !X[W#qk Lj>=J?Jd ( U #=CJ|     . /2,5t88;; ; <_ (<8<p9>`p:Fp>*F+G+H-I0XX1Y1\1]3^=TbBcCndCeCfClCuD vFzJJJJJCtomcat-docs-webapp9.0.91150200.68.1The "docs" web application for Apache TomcatThe documentation of web application for Apache Tomcat.fG)h01-ch3b6SUSE Linux Enterprise 15SUSE LLC Apache-2.0https://www.suse.com/Productivity/Networking/Web/Servershttps://tomcat.apache.orglinuxnoarchchown -R tomcat:tomcat /usr/share/tomcat/tomcat-webapps/docs/META-INF runuser -u tomcat -g tomcat -- xsltproc --output /usr/share/tomcat/tomcat-webapps/docs/META-INF/context.xml /etc/tomcat/allowLinking.xslt /usr/share/tomcat/tomcat-webapps/docs/META-INF/context.xml if [ ! -e /usr/share/tomcat/webapps/docs ]; then ln -sf /usr/share/tomcat/tomcat-webapps/docs /usr/share/tomcat/webapps/docs fiQ@yA@l5 8I@lH L>i*   x_!T 2+T- HQ' fO_U497 ::Q409(:=]PF+#X-'N(Pu$YK GFPy48/m PR`YURdXLSXRs+:=\ }Vz\'*'&+*o~1FX R ZBM R p B N'6AQd2A큤A큤AA큤A큤A큤A큤A큤A큤AA큤AA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤fGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfGfG5278de5f3beac707d1e5c05d351f27ca4b94a48f8ff9eec86c817f067676beb7539ad0b2450e83e306f9e54b4a40c00aee470cbda377451026345655e1a1033eeeb47c0a22e0245c34334f27269a099267072e7130e8aa31a872a662b9a714a64da999e0db4e50e944915188b1ed4bbd4b3f843768bb27340ea28e80b9db8f4418ae0f6852f87a9f6a9720b19ed633a67d38caf7dfaea2fcd0ff2f1c7efc75763fdc9027fcf3d363d3e563da8a3dc0d514a957021cf72f389040a97ffc5dad04a83451d55361185875e9699a9e6c3919636de6ce5e02c62426befe30a3e90b34f40071254ce811e75e90b4416c834d0b6da2f7e6d9804322a9f55c1660563a0ab191581414009ac8efb486df8aed81ab9828ef4eaab4e826c49230241f73889bff7fdb1c70875875216ee3a18630a52140eab628d9cce7bcd7f69f56b5e4d094578d61045b51f4700ade58a0becd088c2327d874a54701d763bdff242f6facf19f4b9db59cc0ef31327eb88b1652d1d2b71b3d4fbc6ad8fb4f06e3c7f363dd9d0063b3ca0e4898b6365fbbba3937819244c18c817f4364e159ec36cbad8923861c74cd0a04b1f57f11efe5dc0cc1b534b9c8acdbb827b587215bf454ed90ef5db2cd6d35f6f1521736682fa080b58608655451d9f0b11595581a6e3e62124122ff7fdb1c70875875216ee3a18630a52140eab628d9cce7bcd7f69f56b5e4d09477f84b68ac01984d8566203b324eae905f1883f5dcffd6d8c7a6342a76547458d4825ba7885174a0632cf2a30c124a3900cea0f044a3e1b42550658cefee7ce491c5d006427e6b15a0abb444afd59c50e4a943b0422b01a566c636b62fc20067db1562deabb7b81f1f0f52882bbeaf1332f7c20bca3f771233cbf9db4226d9a57b8134b028f5b8c206e18075b05790d27cc29c431bb9575033b37319751036f8dc5d18af5aebf5ad183db10b5d17d0caabb65a1b5371af6d4c2e1160c16649d6d9fdacbd36cf39f746e789faee0d09e629b6051395bae804fc88d309fdc8d50def1a54314ffb542dfa079a0357573a9eb9483a019ae7be89e66fd137b67bef0f64924c65f06bbed78297991638d5c7e20274427a75727623bfb2516cf0028bb605a970d5f204c5901a0033203c35b14752f69a523df8cc6248704cf5fa00b1e6b5167a13d96610921a50babdca9b51067de446ab72c8dfdeb6b52cb881919bb24c6ddb50d8df627a416ff7346f0091a5216dcafada75ac1adaf8b4299bcbe33043d340f3ff5b830ec787543b89f6a3efb219527fea666b50612475e0f76c7dfadb692e24785f79099a558d554c83ca452afbf731dbe3f1d8d8e3d9a6136cf571a1f77a86b92cc872ba86a4ac538720debe5a075f56cf6ede6a52c1b1ec91b741ab2831a52b621106a695a68049fffc3457a0b6868439d8eda6d393f86948a6feba2f4c6806ed4a3e2ca487b25b66d6cdb3f7869a9c724950c2c8a8b9ed1e2b03558e9400ae513fce8ea9ec4afaec9ead16c9ae918b5c8e8b5d4ead351f7c5fae1d8bcf6b2f674a6ce272bbb818d835e6e431dbde60601e10abf5cd0a1ffc260308189afb9cb455866ae82da5c1627c6d1f7a048bacd063ca041677fba051bdb7b1e1cab56e9aa1e4bd5e88c1ee2cd98dc23e5941aabf6fc5adda0351f152d8afd185ad31cb2551e2a9f41ad83c4208090c13f527996c2d2bcabe9dddecf91a2771e96a424577f6fea0d7ea99fc21c4c7cc19692679eafc072987fd0fbacea163d4353ebf1dee5a54f7f4a7de20e31970d495a17863a9d2d28808f6eeee7d0a3efc093c9af8dc2324c299188af36cae86d813c795e47e4efecb3eef2c08c8eb5af110f7b62619849e1217f8362bd965cd407761cdaf23b7d7f19bfef00abe8d7fe8cba8e877951bde3f1978a1be67917d41cb0cf2986a6778309f74d208bb0af0a3bc0e4884d7f288a21079d62d2c8c2cb541288577688bc8d945734ceb88779316ebd913d91d69397920a3e36fd924105a9c9a4f00c07bbdb1229d725356fd693fbda706ba2a8644399b925136a7bd8265236c0df9c97db6455b1caadddd831046bf364eadeaecbcd1689872279e167c11b7a48ca927e2c55410be57ce10ca147bb25a1a55bfae10e3adc8f1cbb545c7ff40ec9e6554497ec7404c2ea6eeb06b25eb28332a50cee14d8171b55885640dbbb70b0880f53881002e8f7916f40b1a5fcdb2e1a19af04240bc997f1090032bd8ee68c2060b931300dc053fa67dd1d8bcc87b238e6594150b32a9cee6854986754468716ed7e5fe2a31617313c7cd3294261d2553c80bcc727e7e8465072d71d7c21a9b23799626c223c9ab9d378246ba09cb5c2b3289d84aae68d2a0564adb915421988096d7f8b6bf0548e9f31603dee7dacb1ab82e7cc9625bcf25eb699448eb7d0234c9d13c6b30896ed4f498f8c233da71ef3315626f64b79868fc0c7cc5129aa41d038eaa119efdde07c8b59b792f807f29a8e5a3fa90b92fe1c7d8ba5c2e33cdd8bfeca3e97e02acaf986cb62554837a5a13a45a732add3dc0e4b371b1691c1086fb15c39bd91b29cc4746ec8b4a85f0f6ecaf3feab91bbb65bce2e61baf1d223b966d6ed3afc02f260b7298411ce42db7ae55412a0c0cfc21f5c8e0681987b526fd953c4691c04ab0b0cf007e4cd72a46839626cbc8a9d56f2648825a38c8ed61434751012dde0eba9359604a5357ce1de5a50b10e20add5a895593d3bb4906d533b86bf600551b73527a9e738f3453d5cefb37198cd1fc13b421743d1bb4cf22dfd280c1b7c751129c6c050f626cb0401a4a576db9f74882129a14e950659a4a431d857698e9b79e2ca56f22e6cca27f505c6c4f0158fa2c87e5a175b23e71864a1bb0a5fdbc77a91e3e0638fce1821aa11489607cca4e2fb3f9ca10f60bdf44f1235c03553d637f3a8c2f15311273a2d624151ee93c1ca3965125826929e0e7df765d90d4721ff3d4d41bc9661ae8126ee0ef837dd255428b8f492d6d4b52d7b3604ab18219467a51fb6f5bba702c425143058648e20d53d32f27ac0a270cbc8c4fdffd9dc6278cd88122ab70f2485a5922e2bc89b6e6095d9710c788188c6b2c09aa95762aae9117aa43f7e637acdf9703a27c29ee1672444440635ec8f80320462c0f10dcd77543d9d7b8cc47d8af59aff2b701a4ba3d159fb32040be5418f51795f30fd7e412bcd69b6c9f615a0e2ee3d1f9dfea23f5efa9eca33d8a559bc610d673320610bd3128550dff0631733706b2ea0cbf8bd83df49030cdea6397b73d38899bc722e0609fa795a920dd718bcba1f461cc97585eee21e14123a4ea958ceff84b5bd01fa1398ffbf5802b6c1384fab2b968f4a3c3ac9825fb5ca73be399ad5ba162fdb59e4fb147b45ea1c2ec7d697131864746fe54b479a3a50d241dc36c75eb81850ebbaac62108e2acc91917db2e8847e9b385026b612318320790985c4aab34284515aabca309ee52bfe4e85ebce03b43e250417db4b4bc6eb2cecf664d96b38ab5f094e6dabe2c85713faf303e1234cfe1808c1e18c16d44dce508ab27e1a14af9451f8f63bd01b3a31034c4d3f81fa0c02951eec968650a369b2152933eceab3062f2dcceb07ed8851c12fc417761f4648aafc216c45805962d30d2f07c679b6c2fafcf0ba2ce471b45fcad2914b160bbb55b93526576283cf766cdf85c58a9fb63a7628b0cd100a3b6079a735cfa125beabac45635f96f9c5426a6b6f11be03d9aa3bc78ed1fc968f42da2be8d6281af398e3c0cb4ed6ca144d7233c115624b70d6da7ebcd8c052a22558b899f94a111d73eef39fe8a3e877988904bc5501c3ff5ee745353bf28de0929ef2b7e5bbd88113edbb97042e8779e01db5f00c200366560bdbbb797f62b2cf1457e2add4bb1680f87811d9e7a29f4e4aca898bd80527c5b6ad52112c36fa422d381aec5ffb57c31912b60ca0e47b56634beaae1a4eb8c826f1329a1d49820814f018ba95a5b2ae5c8e349d57c6663aa87559d4b6c86b1b6a0cac0dba2ac0d6abdb2d037f07499a84df7f9a949e5e76a4d89dd3913b96e3ec691568f1581537f57b4e62863524bd1511017e7f252f23ac6c125160c39b14a2a0410d16b47d3901eee99d0090e19fdb28ab78e3fff49f571c5ece6cca5eaa4ca9bff421ce09b2021f4e4bc64a8264732de30b162cb05943d9b2e92bf27138de083e056ba73609403a3ef0ac82395a4fccae251ecef1878c569a3a5ee2f4e94f2b56e19054224482be0aa7b444ab8324ed0b0c25e3abacbd87be29732356c9bb890556675373ea9ed1d0e9b5678426d69296b6801c906ca378bb426aa3d6acdc3ba392abf7aa1d006749331fa8e97ac2202596a819dd382b46d051a28dca74875a851d97fcc71c78ca279754fabc2289a600aabecec4d9e4387cab9c7400aa2d0868a21c493df0e5da1622b319e915303b1aa2b72f3cb836057eed5699f522693cd0e6f9fbe497b6a0346fde3934cbcbd7c557a334c27bb34e69c7ed430ed4a4588c27f2a933b428f5a13403157e395a9d869d176c8dd256a5f28a042e4f863b42117f27a13e776a0e6ee6d54739b08b35741f43f5776bf51a193810b51d60285dc5d18af5aebf5ad183db10b5d17d0caabb65a1b5371af6d4c2e1160c16649d65d4dbfc82ee715a653291fb987dd565b6fc567ffee828d9e4c5f181c75eca0be63b93e248018e9520b508c50c9f61fb190bb7ed7c057598111baf79d07c3ad14afe0dcfca292a0fae8bce08a48c14d3e59c9d82c6052ab6d48a22ecc6c48f2775e504e4155b526c645f69e4e7f73adf86840072511dc56cade8c65a279e856d2853e254df996b4cb48c1dd963706f6e3504294e440265bfcdbb1f72a56f4eac81e5625a5514ec5bdf5a0a1deaf78978fdfe9b1db74edc46ef708af6dbb586a75946c15c016ada6c6a3a5f766a91bf8a27f7aedf01b70070dd8da60b53ae4fba411b34e1b47510180328b2392e2cb7d88eb5927f72836baf2204f30a11334f5f0c553dcf354c37fc3c5331ef8ed32c5fb046403355bd99be61df1f6a2e7dedb8f594e1b7c8c114b3316f4ff92dd3ae776426187b31a59d523d232b5c5c4a7d47176950a94d43ffee2e85c43dc121d152f50b39156c12aae4feaa9211e29f07569f18c98af027152dfd0eb8c54774d5285b46f98a48ff2e24727859d18f73e9f0652db28d77621dfffbdbb792d0150e8ffb3c4c671ffeb9fb4321ca4e9ce22bdc6ddd1206c2cd691339c7baf8d098437fab442471f11156ca5bddd985fc16fec0305d8f3e03b2e7f6c10a2ff106ccb9d7a5db39e4f63f82b6d8d5e7665f88517355ddbd3c1ac87bcf2df87bc93c0dd903a2467ced795dcd5c0d746f5c133a8123e208cdf881f0d7aee0701486a0c710fdd2e42a0855223911a0cac9d2446c46b4814eb30a85c47623cb16e506462178a358bcb4a55e6ec87ddd8dc628d0636166c37997f45a97ea40268d856d81fa41bf978fff93c3c084b5a47fd4abb89d7380ea44c9f34c11b35bb819caced36a5909f7c42caaaf13c243fa57a99b0764c653005126e09d0acf6f68fe7b48708f1476352fdb80433bc4d228e34ea81738b5fcbacd162ea2cf139a33543a42e16f960ed95675643e9c46e8c40c7c90afcbb50746458316305365d75524ee414588f9bd52eedc4895db85dd87a80335712e3b3f144bbe06c4b391fe9082755789d5589d6db531edc1b3d550a6b11d38d5f66192e8249a532a48e4e377fccefa5b24694c445cc058738bae2c2653dc95481ffbe9ccc92986884fea417786e6ecacef9e419bc68ffbc4c9a3de5b29d640cae63cc578ce80340ae2089f183514fda43673c1804c4e9849764b5daf957f370b39c3d37aab4e00c708fb47ee453cc498557bf75bb9ba16f093fb2766dd0f25fb40d731f6c1babfbce26ef4e5e0808b7bd20d5da66a56e1d1ccc73abc6bcc8e0c4a770aaa1cb1883c6c28b7e0f306342d26546fcd2e95c0ae2efa71207731a19c89d2b200c4cc2a84b01d9ee8b1533316fe2c2e8bf449276305136753cfd473535b3fff12d3847d4104c9e783530e45f8d4ba65995d06b88fc67b3a8a60a05979b88979e1b41a950f0ff3ccbd42f98e8abdc6044b3c872c5f1edab3d1efd95b10a4b6f82b7923d845fd8c056b3f7bbf2f52971d67ef5dab79c77112bc197bf8d3e63ed59812d03cbb5b5ff315ebb18f123b3d1614ec1eec922cc6bdf3a458b99873100333dd3bd47ccc1386f493044f0c7a8a9e3d722db256a8f9932de7699c595bfbd337404ffc3dea4290fe66178e407fe8176a045aca8e5b666a8c42b66f5e61fd0fd1306c4f64dc4f5993e8090b9f96793d4b7cc932ddfd2a60ac0fa4e1907a5d57dacaa06dbb98bff08a1b701edb4acf1b7cdc80bb32e2c2ebcd6bdeff9d19cc307rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroottomcat-9.0.91-150200.68.1.src.rpmtomcat-docs-webapp     /bin/shlibxslt-toolsrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)tomcatutil-linux3.0.4-14.6.0-14.0.4-14.0-15.2-19.0.91-150200.68.14.14.1f&@feZeeПe@ee@e@e)e_>e)1@e 0@e 0@e;eRdld0d?@cc@c@c{h@cQ8@bγbbN@b!b@aaaA@a@a{@azamaamaama`X`Q@`OL@`OL@`3__F@_@___FN_!d^@^^_^@^Y^U @^1s^%@^!^@]҇]Γ@]4@]?]V]@\\\r@\k\j@\Yz\X)@\LK\?\8@\'a\[v[u[@[@[ug@ZZ_:Z!D@Z@YYYY:Y@Y@XZnW@WiW|W'A@WWKV@V2V`VA@UlI@UlI@UlI@UQU hU hTTи@ricardo.mestre@suse.comricardo.mestre@suse.comdcermak@suse.comfstrba@suse.comfstrba@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.comricardo.mestre@suse.comfstrba@suse.comfstrba@suse.commichele.bussolotto@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.comfstrba@suse.comfstrba@suse.commichele.bussolotto@suse.comfstrba@suse.comfstrba@suse.commichele.bussolotto@suse.comolaf@aepfle.demichele.bussolotto@suse.comfstrba@suse.commichele.bussolotto@suse.commichele.bussolotto@suse.comwittemar@googlemail.comwittemar@googlemail.comwittemar@googlemail.comamehmood@suse.comamehmood@suse.comwittemar@googlemail.comwittemar@googlemail.comwittemar@googlemail.comamehmood@suse.commalbu@suse.commalbu@suse.commalbu@suse.comjengelh@inai.defstrba@suse.commalbu@suse.comfstrba@suse.commalbu@suse.comjavier@opensuse.orgmalbu@suse.commalbu@suse.comfstrba@suse.commalbu@suse.comfstrba@suse.commalbu@suse.commalbu@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comdimstar@opensuse.orgmalbu@suse.commalbu@suse.comfstrba@suse.commalbu@suse.commalbu@suse.commalbu@suse.commalbu@suse.comfstrba@suse.commalbu@suse.commalbu@suse.comecsos@opensuse.orgfstrba@suse.comsean@suspend.netmalbu@suse.comecsos@opensuse.orgmalbu@suse.commalbu@suse.commalbu@suse.defstrba@suse.commalbu@suse.comrbrown@suse.commalbu@suse.comecsos@opensuse.orgfstrba@suse.comecsos@opensuse.orgdziolkowski@suse.commalbu@suse.comastieger@suse.comtchvatal@suse.commalbu@suse.commalbu@suse.comdmacvicar@suse.dejcnengel@gmail.comtchvatal@suse.comdmacvicar@suse.dedmacvicar@suse.detchvatal@suse.comdmacvicar@suse.detchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comwittemar@googlemail.combmaryniuk@suse.com- Update to Tomcat 9.0.91 * Fixed CVEs: + CVE-2024-34750: Improper handling of exceptional conditions (bsc#1227399) * Catalina + Fix: Allow JAASRealm to use the configuration source to load a configured configFile, for easier use with testing. (remm) + Fix: Add missing algorithm callback to the JAASCallbackHandler. (remm) + Fix: 69131: Expand the implementation of the filter value of the Authenticator attribute allowCorsPreflight, so that it applies to all requests that match the configured URL patterns for the CORS filter, rather than only applying if the CORS filter is mapped to /*. (markt) + Add: Add support for shallow copies when using WebDAV. (markt) + Code: Deprecate the WebdavFixFilter as it is no longer required. (markt) + Fix: 69066: Fix regression in SPNEGO authenticator when processing Base64. Submitted by Daniel Lyko. (remm) + Update: Update minimum recommended version of Tomcat Native to 1.3.0. Pull request #728 provided by Dimitrios Soumis. (markt) + Update: The system property org.apache.catalina.connector.RECYCLE_FACADES will now default to true if not specified, which will in turn set the default value for the discardFacades connector attribute, thus causing facade objects to be discarded by default. (remm) + Add: Add RealmBase.getPrincipal(GSSName, GSSCredential, GSSContext) for retrieving extended/additional information from an established GSS context. (michaelo) + Fix: Correct a regression in the fix for 68721 that caused some instances of LinkageError to be reported as ClassNotFoundException. (markt) + Fix: Ensure that static resources deployed via a JAR file remain accessible when the context is configured to use a bloom filter. Based on pull request #730 provided by bergander. (markt) + Add: Introduce reference counting so the AprLifecycleListener is more robust. This particularly targets more complex embedded configurations with multiple server instances with independent lifecycles where more than one server instance requires the AprLifecycleListener. (markt) + Update: Deprecate and remove sessionCounter (replaced by the addition of the active session count and the expired session count, as a reasonable approximation) and duplicates (which does not represent a possible event in current implementations) statistics from the session manager. (remm) + Fix: 68890 Align output encoding of JSPs in the Manager webapp with the XML declarations in those same files. (schultz) + Fix: Update Basic authentication to implement the requirements of RFC 7617 including the changing of the trimCredentials setting which is now defaults to false. Note that the trimCredentials setting will be removed in Tomcat 11. (markt) + Add: Small performance optimization when logging cookies with no values. (schultz) + Fix: Correct error handling for asynchronous requests. If the application performs an dispatch during AsyncListener.onError() the dispatch is now performed rather than completing the request using the error page mechanism. (markt) + Fix: Fix WebDAV lock null (locks for non existing resources) thread safety and removal. (remm) + Fix: Add periodic checking for WebDAV locks expiration. (remm) + Fix: Extend Asn1Parser to parse UTF8Strings. (michaelo) + Update: Add highConcurrencyStatus attribute to the SemaphoreValve to optionally allow the valve to return an error status code to the client when a permit cannot be acquired from the semaphore. (remm) + Add: Add checking of the "age" of the running Tomcat instance since its build-date to the SecurityListener, and log a warning if the server is old. (schultz) + Fix: When using the AsyncContext, throw an IllegalStateException, rather than allowing an NullPointerException, if an attempt is made to use the AsyncContext after it has been recycled. (markt) + Fix: Change the thread-safety mechanism for protecting StandardServer.services from a simple synchronized lock to a ReentrantReadWriteLock to allow multiple readers to operate simultaneously. Based upon a suggestion by Markus Wolfe. (schultz) + Fix: Improve Service connectors, Container children and Service executors access sync using a ReentrantReadWriteLock. (remm) + Fix: Improve handling of integer overflow if an attempt is made to upload a file via the Servlet API and the file is larger than Integer.MAX_VALUE. (markt) + Fix: 68862: Handle possible response commit when processing read errors. (remm) * Jasper + Fix: Update the optimisation in jakarta.el.ImportHandler so it is aware of new classes added to the java.lang package in Java 23. (markt) + Fix: Ensure that an exception in toString() still results in an ELException when an object is coerced to a String using ExpressionFactory.coerceToType(). (markt) + Add: Add support for specifying Java 24 (with the value 24) as the compiler source and/or compiler target for JSP compilation. If used with an Eclipse JDT compiler version that does not support these values, a warning will be logged and the default will used. (markt) + Fix: 69135: When using include directives in a tag file packaged in a JAR file, ensure that context relative includes are processed correctly. ( markt) + Fix: 69135: When using include directives in a tag file packaged in a JAR file, ensure that file relative includes are processed correctly. (markt) + Fix: 69135: When using include directives in a tag file packaged in a JAR file, ensure that file relative includes are are not permitted to access files outside of the /META_INF/tags/ directory nor outside of the JAR file. (markt) + Fix: 68546: Small additional optimisation for initial loading of Servlet code generated for JSPs. Based on a suggestion by Dan Armstrong. (markt) + Add: Add support for specifying Java 23 (with the value 23) as the compiler source and/or compiler target for JSP compilation. If used with an Eclipse JDT compiler version that does not support these values, a warning will be logged and the default will used. (markt) + Fix: Handle the case where the JSP engine forwards a request/response to a Servlet that uses an OutputStream rather than a Writer. This was triggering an IllegalStateException on code paths where there was a subsequent attempt to obtain a Writer. (markt) + Fix: Correctly handle the case where a tag library is packaged in a JAR file and the web application is deployed as a WAR file rather than an unpacked directory. (markt) + Fix: Prevent the web application's ClassLoader from being pinned by the JSP compiler if an application uses a custom XMLInputFactory. Based upon a suggestion from Simon Niederberger. (schultz) * Web applications + Fix: Fix status servlet detailed view of the connectors when using automatic port. (remm) + Add: Add the ability to set a sub-title for the Manager web application main page. This is intended to allow users with lots of instances to easily distinguish them. Based on pull request #724 by Simon Arame. (markt) + Fix: Examples: Improve performance of WebSocket chat application when multiple clients disconnect at the same time. (markt) + Update: Examples: Increase the number of previous messages displayed when using the WebSocket chat application. (markt) + Fix: Examples: Improve performance of WebSocket snake application when multiple clients disconnect at the same time. (markt) * Coyote + Fix: Improve the algorithm used to identify the IP address to use to unlock the acceptor thread when a Connector is listening on all local addresses. Interfaces that are configured for point to point connections or are not currently up are now skipped. (markt) + Fix: 69121: Ensure that the onComplete() event is triggered if AsyncListener.onError() dispatches to a target that throws an exception. (markt) + Fix: Following the trailer header field refactoring, -1 is no longer an allowed value for maxTrailerSize. Adjust documentation accordingly. (remm) + Fix: 69068: Ensure read timouts are triggered for asynchronous, non-blocking reads when using HTTP/2. (markt) + Update: 69133: Add task queue size configuration on the Connector element, similar to the Executor element, for consistency. (remm) + Fix: Make counting of active HTTP/2 streams per connection more robust. (markt) + Add: Add support for TLS 1.3 client initiated re-keying. (markt) + Fix: Align non-secure and secure writes with NIO and skip the write attempt when there are no bytes to be written. (markt) + Fix: Allow any positive value for socket.unlockTimeout. If a negative or zero value is configured, the default of 250ms will be used. (mark) + Fix: Reduce the time spent waiting for the connector to unlock. The previous default of 10s was noticeably too long for cases where the unlock has failed. The wait time is now 100ms plus twice socket.unlockTimeout. (markt) + Fix: Ensure that the onAllDataRead() event is triggered when the request body uses chunked encoding and is read using non-blocking IO. (markt) + Fix: 68934: Add debug logging in the latch object when exceeding maxConnections. (remm) + Fix: Refactor trailer field handling to use a MimeHeaders instance to store trailer fields. (markt) + Fix: Ensure that multiple instances of the same trailer field are handled correctly. (markt) + Fix: Fix non-blocking reads of chunked request bodies. (markt) + Fix: When an invalid HTTP response header was dropped, an off-by-one error meant that the first header in the response was also dropped. Fix based on pull request #710 by foremans. (markt) + Fix: Add threadsMaxIdleTime attribute to the endpoint, to allow configuring the amount of time before an internal executor will scale back to the configured minSpareThreads size. (remm) * WebSocket + Fix: 68884: Reduce the write timeout when writing WebSocket close messages for abnormal closes. The timeout defaults to 50 milliseconds and may be controlled using the org.apache.tomcat.websocket.ABNORMAL_SESSION_CLOSE_SEND_TIMEOUT property in the user properties collection associated with the WebSocket session. (markt) * Other + Update: Add test-only build target to allow running only the testsuite, supporting Java versions down to the minimum supported to run Tomcat. (rjung) + Update: Update UnboundID to 7.0.1. (markt) + Update: Update to SpotBugs 4.8.6. (markt) + Update: Remove cglib dependency as it is not required by the version of EasyMock used by the unit tests. (markt) + Update: Update EasyMock to 5.3.0. This adds a test dependency on Byte-Buddy 1.14.17. (markt) + Add: Improvements to Czech translations by Vladimír Chlup. (markt) + Add: Improvements to French translations. (remm) + Add: Improvements to Japanese translations by tak7iji. (markt) + Add: Improvements to Chinese translations by fangzheng. (markt) + Update: Revert Derby to 10.16.1.1 as that is the latest version of Derby that runs on Java 17. (markt) + Update: Update to Commons Daemon 1.4.0. (markt) + Update: Update to Objenesis 3.4. (markt) + Update: Update to Checkstyle 10.17.0. (markt) + Update: Update to SpotBugs 4.8.5. (markt) + Add: Improvements to French translations. (remm) + Add: Improvements to Japanese translations by tak7iji. (markt) + Update: Switch to using the Base64 encoder and decoder provided by the JRE rather than the version provided by Commons Codec. The internal fork of Commons Codec has been deprecated and will be removed in Tomcat 11. (markt) + Update: Update NSIS to 3.10. (mark0t) + Update: Update UnboundID to 7.0.0. (markt) + Update: Update Checkstyle to 10.16.0. (markt) + Update: Update JaCoCo to 0.8.12. (markt) + Update: Update SpotBugs to 4.8.4. (markt) + Update: Update the internal fork of Apache Commons BCEL to 6.9.0. (markt) + Update: Update the internal fork of Apache Commons DBCP to 2.12.0. (markt) + Add: Improvements to Japanese translations by tak7iji. (markt) + Update: Update Checkstyle to 10.14.1. (markt) + Update: Update the internal fork of Apache Commons BCEL to 6.8.2. (markt) + Update: Update the internal fork of Apache Commons Codec to 1.16.1. (markt) + Add: Improvements to French translations. (remm) + Add: Improvements to Japanese translations by tak7iji. (remm) + Add: Improvements to Chinese translations by leeyazhou. (remm) - Modified patch: * tomcat-9.0-build-with-java-11.patch + rediff to changed context * tomcat-9.0-osgi-build.patch + move the definition of bnd.classpath out of the setup-bnd task since it is one component in build.classpath- Update to Tomcat 9.0.87 * Fixed CVEs: + CVE-2024-24549: Improved request header validation for HTTP/2 stream (bsc#1221386) + CVE-2024-23672: Ensure that WebSocket connection closure completes if the connection is closed when the server side has used the proprietary suspend/resume feature to suspend the connection (bsc#1221385) * Catalina + Fix: Minor performance improvement for building filter chains. Based on ideas from #702 by Luke Miao. (remm) + Fix: Align error handling for Writer and OutputStream. Ensure use of either once the response has been recycled triggers a NullPointerException provided that discardFacades is configured with the default value of true. (markt) + Fix: 68692: The standard thread pool implementations that are configured using the Executor element now implement ExecutorService for better support NIO2. (remm) + Fix: 68495: When restoring a saved POST request after a successful FORM authentication, ensure that neither the URI, the query string nor the protocol are corrupted when restoring the request body. (markt) + Fix: 68721: Workaround a possible cause of duplicate class definitions when using ClassFileTransformers and the transformation of a class also triggers the loading of the same class. (markt) + Fix: The rewrite valve should not do a rewrite if the output is identical to the input. (remm) + Update: Add a new valveSkip (or VS) rule flag to the rewrite valve to allow skipping over the next valve in the Catalina pipeline. (remm) + Fix: Correct JPMS and OSGi meta-data for tomcat-enbed-core.jar by removing reference to org.apache.catalina.ssi package that is no longer included in the JAR. Based on pull request #684 by Jendrik Johannes. (markt) + Fix: Fix ServiceBindingPropertySource so that trailing \r\n sequences are correctly removed from files containing property values when configured to do so. Bug identified by Coverity Scan. (markt) + Add: Add improvements to the CSRF prevention filter including the ability to skip adding nonces for resource name and subtree URL patterns. (schultz) + Fix: Review usage of debug logging and downgrade trace or data dumping operations from debug level to trace. (remm) + Fix: 68089: Further improve the performance of request attribute access for ApplicationHttpRequest and ApplicationRequest. (markt) + Fix: 68559: Allow asynchronous error handling to write to the response after an error during asynchronous processing. (markt) * Coyote + Fix: Improve the HTTP/2 stream prioritisation process. If a stream uses all of the connection windows and still has content to write, it will now be added to the backlog immediately rather than waiting until the write attempt for the remaining content. (markt) + Fix: Make asynchronous error handling more robust. Ensure that once a connection is marked to be closed, further asynchronous processing cannot change that. (markt) + Fix: Make asynchronous error handling more robust. Ensure that once the call to AsyncListener.onError() has returned to the container, only container threads can access the AsyncContext. This protects against various race conditions that woudl otherwise occur if application threads continued to access the AsyncContext. + Fix: Review usage of debug logging and downgrade trace or data dumping operations from debug level to trace. In particular, most of the HTTP/2 debug logging has been changed to trace level. (remm) + Fix: Add support for user provided SSLContext instances configured on SSLHostConfigCertificate instances. Based on pull request #673 provided by Hakan Altındağ. (markt) + Fix: Improve the Tomcat Native shutdown process to reduce the likelihood of a JVM crash during Tomcat shutdown. (markt) + Fix: Partial fix for 68558: Cache the result of converting to String for request URI, HTTP header names and the request Content-Type value to improve performance by reducing repeated byte[] to String conversions. (markt) + Fix: Improve error reporting to HTTP/2 clients for header processing errors by reporting problems at the end of the frame where the error was detected rather than at the end of the headers. (markt) + Fix: Remove the remaining reference to a stream once the stream has been recycled. This makes the stream eligible for garbage collection earlier and thereby improves scalability. (markt) * Jasper + Add: Add support for specifying Java 22 (with the value 22) as the compiler source and/or compiler target for JSP compilation. If used with an Eclipse JDT compiler version that does not support these values, a warning will be logged and the default will used. (markt) + Fix: 68546: Generate optimal size and types for JSP imports maps, as suggested by John Engebretson. (remm) + Fix: Review usage of debug logging and downgrade trace or data dumping operations from debug level to trace. (remm) * Cluster + Fix: Avoid updating request count stats on async. (remm) * WebSocket + Fix: Correct a regression in the fix for 66508 that could cause an UpgradeProcessor leak in some circumstances. (markt) + Fix: Review usage of debug logging and downgrade trace or data dumping operations from debug level to trace. (remm) + Fix: Ensure that WebSocket connection closure completes if the connection is closed when the server side has used the proprietary suspend/resume feature to suspend the connection. (markt) * Web applications + Add: Add support for responses in JSON format from the examples application RequestHeaderExample. (schultz) * Other + Add: Improvements to French translations. (remm) + Add: Improvements to Japanese translations by tak7iji. (markt) + Update: Update Checkstyle to 10.13.0. (markt) + Update: Update JSign to 6.0. (markt) + Update: Add strings for debug level messages. (remm) + Update: Update Tomcat Native to 1.3.0. (markt) + Add: Improvements to French translations. (remm) + Add: Improvements to Japanese translations by tak7iji. (markt)- Add missing Requires(post): util-linux to have runuser into post- Add %%systemd_ordering to packages with systemd unit files, so that the order is the right one if those packages find themselves in the same transaction with systemd- Link ecj.jar into the install instead of copying it- rpm 4.19 requires dependencies on tomcat user and group (bsc#1219530)- Fixed CVEs: * CVE-2024-22029: run xsltproc as tomcat group (bsc#1219208)- Update to Tomcat 9.0.85 * Fixed CVEs: + CVE-2023-46589: Apache Tomcat: HTTP request smuggling due to incorrect headers parsing (bsc#1217649) * Catalina + Update: 68378: Align extension to MIME type mappings in the global web.xml with those in httpd by adding application/vnd.geogebra.slides for ggs, text/javascript for mjs and audio/ogg for opus. (markt) + Fix: Background processes should not be run concurrently with lifecycle operations of a container. (remm) + Fix: Correct unintended escaping of XML in some WebDAV responses. The XML list of support locks when provided in response to a PROPFIND request was incorrectly XML escaped. (markt) + Fix: 68227: Ensure that AsyncListener.onComplete() is called if AsyncListener.onError() calls AsyncContext.dispatch(). (markt) + Fix: 68228: Use a 408 status code if a read timeout occurs during HTTP request processing. Includes a test case based on code provided by adwsingh. (markt) + Fix: 67667: TLSCertificateReloadListener prints unreadable rendering of X509Certificate#getNotAfter(). (michaelo) + Update: The status servlet included in the manager webapp can now output statistics as JSON, using the JSON=true URL parameter. (remm) + Update: Optionally allow ServiceBindingPropertySource to trim a trailing newline from a file containing a property-value. (schultz) + Fix: 67793: Ensure the original session timeout is restored after FORM authentication if the user refreshes a page during the FORM authentication process. Based on a suggestion by Mircea Butmalai. (markt) + Update: 67926: PEMFile prints unidentifiable string representation of ASN.1 OIDs. (michaelo) + Fix: 66875: Ensure that setting the request attribute jakarta.servlet.error.exception is not sufficient to trigger error handling for the current request and response. (markt) + Fix: 68054: Avoid some file canonicalization calls introduced by the fix for 65433. (remm) + Fix: 68089: Improve performance of request attribute access for ApplicationHttpRequest and ApplicationRequest. (markt) + Fix: Use a 400 status code to report an error due to a bad request (e.g. an invalid trailer header) rather than a 500 status code. (markt) + Fix: Ensure that an IOException during the reading of the request triggers always error handling, regardless of whether the application swallows the exception. (markt) * Coyote + Fix: Refactor the VirtualThreadExecutor so that it can be used by the NIO2 connector which was using platform threads even when configured to use virtual threads. (markt) + Fix: Correct a regression in the fix for 67675 that broke TLS key file parsing for PKCS#8 format keys that do not specify an explicit pseudo-random function and rely on the default. This typically affects keys generated by OpenSSL 1.0.2. (markt) + Fix: Allow multiple operations with the same name on introspected mbeans, fixing a regression caused by the introduction of a second addSslHostConfig method. (remm) + Fix: Relax the check that the HTTP Host header is consistent with the host used in the request line, if any, to make the check case insensitive since host names are case insensitive. (markt) + Add: 68348: Add support for the partitioned attribute for cookies. (markt) + Add: 66670: Add SSLHostConfig#certificateKeyPasswordFile and SSLHostConfig#certificateKeystorePasswordFile. (michaelo) + Add: When calling SSLHostConfigCertificate.setCertificateKeystore(ks), automatically call setCertificateKeystoreType(ks.getType()). (markt) + Fix: 67628: Clarify how the ciphers attribute of the SSLHostConfig is used. (markt) + Fix: 67666: Ensure TLS connectors using PEM files either work with the TLSCertificateReloadListener or, in the rare case that they do not, log a warning on Connector start. (markt) + Fix: 67675: Support a wider range of KDF and ciphers for PEM files than the combinations supported by the JVM by default. Specifically, support the OpenSSL default of HmacSHA256 and DES-EDE3-CBC. (markt) + Fix: 67927: Reloading TLS configuration can cause the Connector to refuse new connections or the JVM to crash. (markt) + Fix: 67934: If both Tomcat Native 1.2.x and 2.0.x are available, prefer 1.2.x since it supports the APR/Native connector whereas 2.0.x does not. (markt) + Fix: 67938: Correct handling of large TLS client hello messages that were causing the TLS handshake to fail. (markt) + Fix: 68026: Convert selected MessageByte values to String when first accessed to speed up subsequent accesses and reduce garbage collection. (markt) * Jasper + Code: 68119: Refactor the CompositeELResolver to improve performance during type conversion operations. (markt) + Fix: 68068: Performance improvement for EL. Based on a suggestion by John Engebretson. (markt) * Web Applications + Fix: 68035: Additional fix to the Manager application to enable the deployment of a web application located in a Host's appBase where the web application is specified by a bare (no path) WAR or directory name as shown in the documentation. (markt) + Fix: Examples. Improve the error handling so snakes associated with a user that drops from the network are removed from the game. (markt) + Fix: 68035: Correct a regression in the fix for 56248 that prevented deployment via the Manager of a WAR or directory that was already present in the appBase or a context file that was already present in the xmlBase. (markt) * Other + Update: Update Checkstyle to 10.12.7. (markt) + Update: Update SpotBugs to 4.8.3. (markt) + Add: Improvements to French translations. (remm) + Add: Improvements to Japanese translations by tak7iji. (markt) + Update: Update UnboundID to 6.0.11. (markt) + Update: Update Checkstyle to 10.12.5. (markt) + Update: Update SpotBugs to 4.8.2. (markt) + Update: Update Derby to 10.17.1. (markt) + Add: Improvements to French translations. (remm) + Add: Improvements to Japanese translations by tak7iji. (markt) + Add: Improvements to Brazilian Portuguese translations by John William Vicente. (markt) + Add: Improvements to Russian translations by usmazat and remm. (markt) + Add: 67538: Make use of Ant's task to enfore the mininum Java build version. (michaelo) + Update: Update Checkstyle to 10.12.4. (markt) + Update: Update JaCoCo to 0.8.11. (markt) + Update: Update SpotBugs to 4.8.0. (markt) + Update: Update BND to 7.0.0. (markt) + Update: The minimum Java version required to build Tomcat has been raised to Java 17. (markt) - Added patches: * tomcat-9.0-build-with-java-11.patch- change server.xml during %post instead of %posttrans- Fix server.xml permission (bsc#1217768, bsc#1217402) - remove serverxmltool and use xsltproc- replace prep setup and patches macro with autosetup- Update to Tomcat 9.0.82 * Fixed CVEs: + CVE-2023-45648: Improve trailer header parsing (bsc#1216118) + CVE-2023-42794: FileUpload: remove tmp files to avoid DoS on Windows (bsc#1216120) + CVE-2023-42795: Improve handling of failures during recycle() methods (bsc#1216119) * Catalina + Add: 65770: Provide a lifecycle listener that will automatically reload TLS configurations a set time before the certificate is due to expire. This is intended to be used with third-party tools that regularly renew TLS certificates. + Fix: Fix handling of an error reading a context descriptor on deployment. + Fix: Fix rewrite rule qsd (query string discard) being ignored if qsa was also use, while it should instead take precedence. + Fix: 67472: Send fewer CORS-related headers when CORS is not actually being engaged. + Add: Improve handling of failures within recycle() methods. * Coyote + Fix: 67670: Fix regression with HTTP compression after code refactoring. + Fix: 67198: Ensure that the AJP connector attribute tomcatAuthorization takes precedence over the tomcatAuthentication attribute when processing an auth_type attribute received from a proxy server. + Fix: 67235: Fix a NullPointerException when an AsyncListener handles an error with a dispatch rather than a complete. + Fix: When an error occurs during asynchronous processing, ensure that the error handling process is only triggered once per asynchronous cycle. + Fix: Fix logic issue trying to match no argument method in IntropectionUtil. + Fix: Improve thread safety around readNotify and writeNotify in the NIO2 endpoint. + Fix: Avoid rare thread safety issue accessing message digest map. + Fix: Improve statistics collection for upgraded connections under load. + Fix: Align validation of HTTP trailer fields with standard fields. + Fix: Improvements to HTTP/2 overhead protection (bsc#1216182, CVE-2023-44487) * jdbc-pool + Fix: 67664: Correct a regression in the clean-up of unnecessary use of fully qualified class names in 9.0.81 that broke the jdbc-pool. * Jasper + Fix: 67080: Improve performance of EL expressions in JSPs that use implicit objects- Update to Tomcat 9.0.80 * Catalina + Add RateLimitFilter which can be used to mitigate DoS and Brute Force attacks + Move the management of the utility executor from the init()/destroy() methods of components to the start()/stop() methods. + Add org.apache.catalina.core.StandardVirtualThreadExecutor, a virtual thread based executor that may be used with one or more Connectors to process requests received by those Connectors using virtual threads. This Executor requires a minimum Java version of Java 21. + 66513: Add a per session Semaphore to the PersistentValve that ensures that, within a single Tomcat instance, there is no more than one concurrent request per session. Also expand the debug logging to include whether a request bypasses the Valve and the reason if a request fails to obtain the per session Semaphore. + 66609: Ensure that the default servlet correctly escapes file names in directory listings when using XML output. + 66618: Add a numeric last modified field to the XML directory listings produced by the default servlet to enable sorting in the XSLT. + 66621: Attempts to lock a collection with WebDAV may incorrectly fail if a child collection has an expired lock. + 66622: Deprecate the xssProtectionEnabled setting from the HttpHeaderSecurityFilter and change the default value to false as support for the associated HTTP header has been removed from all major browsers. + 59232: Add org.apache.catalina.core.ContextNamingInfoListener, a listener which creates context naming information environment entries. + 66665: Add org.apache.catalina.core.PropertiesRoleMappingListener, a listener which populates the context's role mapping from a properties file. + Fix an edge case where intra-web application symlinks would be followed if the web applications were deliberately crafted to allow it even when allowLinking was set to false. + Add utility config file resource lookup on Context to allow looking up resources from the webapp (prefixed with webapp:) and make the resource lookup API more visible. + Fix potential database connection leaks in DataSourceUserDatabase identified by Coverity Scan. + Make parsing of ExtendedAccessLogValve patterns more robust. + Fix failure trying to persist configuration for an internal credential handler. + 66680: When serializing a session during the session presistence process, do not log a warning that null Principals are not serializable. + Catch NamingException in JNDIRealm#getPrincipal. It is used in Java up to 17 to signal closed connections. + 66822: Use the same naming format in log messages for Connector instances as the associated ProtocolHandler instance. + The parts count should also lower the actual maxParameterCount used for parsing parameters if parts are parsed first. + If an application or library sets both a non-500 error code and the javax.servlet.error.exception request attribute, use the provided error code during error page processing rather than assuming an error code of 500. + Update code comments and Tomcat output to use MiB for 1024 * 1024 bytes and KiB for 1024 bytes rather than MB and kB. + Avoid protocol relative redirects in FORM authentication (CVE-2023-41080, bsc#1214666). * Coyote + Update the HTTP/2 implementation to use the prioritization scheme defined in RFC 9218 rather than the one defined in RFC 7540. + 66602: not sending WINDOW_UPDATE when dataLength is ZERO on call SwallowedDataFramePayload. + 66627: Restore the documented behaviour of MessageBytes.getType() that it returns the type of the original content rather than reflecting the most recent conversion. + 66635: Correct certificate logging on start-up so it differentiates between keystore based keys/certificates and PEM file based keys/certificates and logs the relevant information for each. + Refactor blocking reads and writes for the NIO connector to remove code paths that could allow a notification from the Poller to be missed resuting in a timeout rather than the expected read or write. + Refactor waiting for an HTTP/2 stream or connection window update to handle spurious wake-ups during the wait. + Correct a regression introduced in 9.0.78 and use the correct constant when constructing the default value for the certificateKeystoreFile attribute of an SSLHostConfigCertificate instance. + Refactor HTTP/2 implementation to reduce pinning when using virtual threads. + Pass through ciphers referring to an OpenSSL profile, such as PROFILE=SYSTEM instead of producing an error trying to parse it. + 66841: Ensure that AsyncListener.onError() is called after an error during asynchronous processing with HTTP/2. + 66842: When using asynchronous I/O (the default for NIO and NIO2), include DATA frames when calculating the HTTP/2 overhead count to ensure that connections are not prematurely terminated. + Correct a race condition that could cause spurious RST messages to be sent after the response had been written to an HTTP/2 stream. * WebSocket + 66548: Expand the validation of the value of the Sec-Websocket-Key header in the HTTP upgrade request that initiates a WebSocket connection. The value is not decoded but it is checked for the correct length and that only valid characters from the base64 alphabet are used. + Improve handling of error conditions for the WebSocket server, particularly during Tomcat shutdown. + Correct a regression in the fix for 66574 that meant the WebSocket session could return false for onOpen() before the onClose() event had been completed. + 66681: Fix a NullPointerException when flushing batched messages with compression enabled using permessage-deflate. * Web applications + Documentation. Expand the security guidance to cover the embedded use case and add notes on the uses made of the java.io.tmpdir system property. + 66662: Documentation. Fix a typo in the name of the algorithms attribute in the configuration section for the Digest authentication value. + Documentation. Update documentation to use MiB for 1024 * 1024 bytes and KiB for 1024 bytes rather than MB and kB. * jdbc-pool + Fix the releaseIdleCounter does not increment when testAllIdle releases them. + Fix the ConnectionState state will be inconsistent with actual state on the connection when an exception occurs while writing. * Other + Update to Commons Daemon 1.3.4. + Improvements to French translations. + Update Checkstyle to 10.12.0. + Update the packaged version of the Apache Tomcat Native Library to 1.2.37 to pick up the Windows binaries built with with OpenSSL 1.1.1u. + Include the Windows specific binary distributions in the files uploaded to Maven Central. + Improvements to French translations. + Improvements to Japanese translations. + Update UnboundID to 6.0.9. + Update Checkstyle to 10.12.1. + Update BND to 6.4.1. + Update JSign to 5.0. + Correct properties for JSign dependency. + Align documentation for maxParameterCount to match hard-coded defaults. + Update NSIS to 3.0.9. + Update Checkstyle to 10.12.2. + Improvements to French translations. + Improvements to Japanese translations. + 66829: Fix quoting so users can use the _RUNJAVA environment variable as intended on Windows when the path to the Java executable contains spaces. + Update Tomcat Native to 1.2.38 to pick up Windows binaries built with OpenSSL 1.1.1v. + Improvements to Chinese translations. + Improvements to French translations. + Improvements to Japanese translations - Removed patch: * tomcat-9.0.75-CVE-2023-41080.patch + integrated in this version- Fixed CVEs: * CVE-2023-41080: Avoid protocol relative redirects in FORM authentication. (bsc#1214666) - Added patches: * tomcat-9.0.75-CVE-2023-41080.patch- Modified patch: * tomcat-9.0-osgi-build.patch + make it more robust to change in number of artifacts in bnd + do not enumerate jars, just take all jars from the aqute-bnd directory into the classpath- Require(pre) shadow because groupadd is needed early- Update to Tomcat 9.0.75. * See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.75_(markt) * Fixes: + bsc#1211608, CVE-2023-28709 + bsc#1208513, CVE-2023-24998 (previous incomplete fix) - Remove patches: * tomcat-9.0-CVE-2021-30640.patch * tomcat-9.0-CVE-2021-33037.patch * tomcat-9.0-CVE-2021-41079.patch * tomcat-9.0-CVE-2022-23181.patch * tomcat-9.0-NPE-JNDIRealm.patch * tomcat-9.0-hardening_getResources.patch * tomcat-9.0.43-CVE-2021-43980.patch * tomcat-9.0.43-CVE-2022-42252.patch * tomcat-9.0.43-CVE-2022-45143.patch * tomcat-9.0.43-CVE-2023-24998.patch * tomcat-9.0.43-CVE-2023-28708.patch + integrated in this version * tomcat-9.0.43-java8compat.patch + problem with Java 8 compatibility solved in this version - Modified patch: * tomcat-9.0.31-secretRequired-default.patch - > tomcat-9.0.75-secretRequired-default.patch + rediffed to changed context * tomcat-9.0-javadoc.patch + drop integrated hunks * tomcat-9.0-osgi-build.patch + fix to work with current version - Added patch: * tomcat-9.0-jdt.patch + fix build against our ecj- Fixed CVEs: * CVE-2022-45143: JsonErrorReportValve: add escape for type, message or description (bsc#1206840) - Added patches: * tomcat-9.0.43-CVE-2022-45143.patch- Fixed CVEs: * CVE-2023-28708: tomcat: not including the secure attribute causes information disclosure (bsc#1209622) - Added patches: * tomcat-9.0.43-CVE-2023-28708.patch- Fixed CVEs: * CVE-2023-24998: tomcat,tomcat6: FileUpload DoS with excessive parts (bsc#1208513) - Added patches: * tomcat-9.0.43-CVE-2023-24998.patch- set logrotate for localhost.log, manager.log, host-manager.log and localhost_access_log.txt - use logrotate for catalina.out * update tomcat-serverxml-tool and spec to configure server.xml - Added patch: * tomcat-9.0-logrotate_everything.patch * tomcat-serverxml-tool.tar.gz - Removed: * tomcat-serverxml-tool-1.0.tar.gz- Use catalina.out for logging (bsc#1205647) - Added patches: * tomcat-9.0-fix_catalina.patch- Fixed CVEs: * CVE-2022-42252: reject invalid content-length requests. (bsc#1204918) - Added patches: * tomcat-9.0.43-CVE-2022-42252.patch- Fixed CVEs: * CVE-2021-43980: Improve the recycling of Processor objects to make it more robust. (bsc#1203868) - Added patches: * tomcat-9.0.43-CVE-2021-43980.patch- Do not hardcode /usr/libexec but use %%_libexecdir during the build * Fixes for platforms, where /usr/libexec and %%_libexecdir are different- Fix bsc#1201081 by building with release=8 all files that can be built this way. The one file remaining, build it with source=8 and target=8 - Modified patch: * tomcat-9.0.43-java8compat.patch + Do not cast ByteBuffer to Buffer to call the Java 8 compatible methods. Build with release=8 instead- Security hardening. Deprecate getResources() and always return null. (bsc#1198136) - Added patch: tomcat-9.0-hardening_getResources.patch- Remove dependency on log4j/reload4j completely (bsc#1196137)- Do not build against the log4j12 packages, use the new reload4j- Fixed CVEs: * CVE-2022-23181: Make calculation of session storage location more robust (bsc#1195255) - Added patches: * tomcat-9.0-CVE-2022-23181.patch- remove instance units from post scripts, they can not be reloaded- Fix NPE in JNDIRealm, when userRoleAttribute is not set (bsc#1193569) - Added patch: * tomcat-9.0-NPE-JNDIRealm.patch- Modified patch: * tomcat-9.0-osgi-build.patch + account for biz.aQute.bnd.ant artifact in aqute-bnd >= 5.2.0- Fixed CVEs: * CVE-2021-30640: Escape parameters in JNDI Realm queries (bsc#1188279) * CVE-2021-33037: Process T-E header from both HTTP 1.0 and HTTP 1.1. clients (bsc#1188278) - Added patches: * tomcat-9.0-CVE-2021-30640.patch * tomcat-9.0-CVE-2021-33037.patch- Fixed CVEs: * CVE-2021-41079: Validate incoming TLS packet (bsc#1190558) - Added patches: * tomcat-9.0-CVE-2021-41079.patch- Update to Tomcat 9.0.43. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.43_(markt) - Removed Patches because fixed upstream now: * tomcat-9.0-CVE-2021-25122.patch * tomcat-9.0-CVE-2021-25329.patch - Rebased patch: tomcat-9.0.39-java8compat.patch -> tomcat-9.0.43-java8compat.patch- Update to Tomcat 9.0.41. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.41_(markt)- Update to Tomcat 9.0.40. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.40_(markt) - Removed Patches because fixed upstream now: * tomcat-9.0-CVE-2020-17527.patch * tomcat-9.0-CVE-2021-24122.patch- Fixed CVEs: * CVE-2021-25122: Apache Tomcat h2c request mix-up (bsc#1182912) * CVE-2021-25329: Complete fix for CVE-2020-9484 (bsc#1182909) - Added patches: * tomcat-9.0-CVE-2021-25122.patch * tomcat-9.0-CVE-2021-25329.patch- Log if file access is blocked due to symlinks: CVE-2021-24122 (bsc#1180947) - Added patch: * tomcat-9.0-CVE-2021-24122.patch- Update to Tomcat 9.0.39. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.39_(markt) - Rebased patches: * tomcat-9.0.38-java8compat.patch -> tomcat-9.0.39-java8compat.patch- Update to Tomcat 9.0.38. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.38_(markt) - Rebased patches: * tomcat-9.0.37-java8compat.patch -> tomcat-9.0.38-java8compat.patch - Removed tomcat-9.0-CVE-2020-13943.patch because that fix is upstream now- Update to Tomcat 9.0.37. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.37_(markt) - Fixed CVEs: * CVE-2020-13934 (bsc#1174121) * CVE-2020-13935 (bsc#1174117) - Rebased patches: * tomcat-9.0-osgi-build.patch * tomcat-9.0.31-java8compat.patch -> tomcat-9.0.37-java8compat.patch- Fix HTTP/2 request header mix-up: CVE-2020-17527 (bsc#1179602) - Added patch: * tomcat-9.0-CVE-2020-17527.patch- Add source url for tomcat-serverxml-tool - Fix typo in tomcat-webapps %postun that caused /examples context to remain in server.xml when package was removed - Remove tomcat-9.0.init and /usr/lib/tmpfiles.d/tomcat.conf from package. They're not used anymore becuse of systemd (bsc#1178396)- Fix tomcat-servlet-4_0-api package alternatives to use /usr/share/java/servlet.jar instead of /usr/share/java/tomcat-servlet.jar. Keep /usr/share/java/tomcat-servlet.jar symlink for compatibility. (bsc#1092163) - Change default file ownership in tomcat-webapps from tomcat:tomcat to root:tomcat- Fix CVE-2020-13943 (bsc#1177582) - Added patch: * tomcat-9.0-CVE-2020-13943.patch - Change /usr/lib/tomcat to /usr/libexec/tomcat in startup scripts (bsc#1177601)- Replace old specfile constructs. Remove support for SUSE 11.x. - Drop %systemd_requires, which is considered a no-op. - Trim redundant license mention from description. - Make documentation noarch. - Do not suppress errors from useradd.- Avoid hardcoding /usr/lib as libexecdir- Don't give write permissions for the tomcat group on files and directories where it's not needed (bsc#1172562) - Change tomcat.pid location from /var/run to /run (bsc#1173103) - Use the /sbin/nologin shell when creating the tomcat user - Use %tmpfiles_create macro in %post instead of calling systemd-tmpfiles directly- Update to Tomcat 9.0.36. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.36_(markt) - Fixed CVEs: CVE-2020-11996 (bsc#1173389)- Update to Tomcat 9.0.35. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.35_(markt) - Fixed CVEs: - CVE-2020-9484 (bsc#1171928) - Rebased patches: * tomcat-9.0-javadoc.patch * tomcat-9.0-osgi-build.patch * tomcat-9.0.31-java8compat.patch- Update to Tomcat 9.0.34. See changelog at https://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.34_(markt) - Notable changes: * Add support for default values when using ${...} property replacement in configuration files. Based on a pull request provided by Bernd Bohmann. * When configuring an HTTP Connector, warn if the encoding specified for URIEncoding is not a superset of US-ASCII as required by RFC 7230. * Replace the system property org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH with the Connector attribute encodedSolidusHandling that adds an additional option to pass the %2f sequence through to the application without decoding it in addition to rejecting such sequences and decoding such sequences.- Update to Tomcat 9.0.33. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.33_(markt) - Notable fix: corrected a regression in the improvements to HTTP header parsing (bsc#1167438) - Rebased patches: * tomcat-9.0-javadoc.patch * tomcat-9.0-osgi-build.patch * tomcat-9.0.31-java8compat.patch- Change default value of AJP connector secretRequired to false - Added patch: * tomcat-9.0.31-secretRequired-default.patch- Update to Tomcat 9.0.31. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.30_(markt) - Fixed CVEs: * CVE-2019-17569 (bsc#1164825) * CVE-2020-1935 (bsc#1164860) * CVE-2020-1938 (bsc#1164692) - Modified patch * tomcat-9.0.30-java8compat.patch - > tomcat-9.0.31-java8compat.patch + Adapt to changed context- Modified patch: * tomcat-9.0.30-java8compat.patch + add missing casts (bsc#1162081)- Change back the build to build with any Java >= 1.8 - Added patch: * tomcat-9.0.30-java8compat.patch + Cast java.nio.ByteBuffer and java.nio.CharBuffer to java.nio.Buffer in order to avoid calling Java 9+ APIs (functions with co-variant return types) - Renamed patch: * tomcat-9.0-disable-osgi-build.patch - > tomcat-9.0-osgi-build.patch + Do not disable, but fix OSGi build since we have now aqute-bnd- Change build to always use Java 1.8 (bsc#1161025).- Update to Tomcat 9.0.30. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.30_(markt) - Fixed CVEs: - CVE-2019-0221 (bsc#1136085) - CVE-2019-10072 (bsc#1139924) - CVE-2019-12418 (bsc#1159723) - CVE-2019-17563 (bsc#1159729) - Removed patch: * tomcat-9.0-JDTCompiler-java.patch + It was not applied- Update to Tomcat 9.0.27. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.27_(markt) - Uset aqute-bnd to generate OSGi manifest, since we have that package now in openSUSE:Factory - Removed patch: * tomcat-9.0-disable-osgi-build.patch + not needed- Add maven pom files for tomcat-jni and tomcat-jaspic-api- Distribute the pom file also for tomcat-util-scan artifact- Build against compatibility log4j12 package- Adapt to the new ecj directory layout- BuildRequire pkgconfig(systemd) instead of systemd: allow OBS to shortcut the build queues by allowing usage of systemd-mini- Update to Tomcat 9.0.20. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.20_(markt) - increase maximum number of threads and open files for tomcat (bsc#1111966)- Update to Tomcat 9.0.19. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.19_(markt) Notable packaging changes: - File /usr/share/java/tomcat/catalina-jmx-remote.jar was removed. The classes contained in this jar were merged into /usr/share/java/tomcat/catalina.jar. - Fixed CVEs: - CVE-2019-0199 (bsc#1131055) - Rebased patch: - tomcat-9.0-JDTCompiler-java.patch - tomcat-9.0-javadoc.patch- Build classpath directly with the geronimo jars instead of with symlinks to them- Don't overwrite changes made to server.xml contexts when updating bundled webapps.- Set javac target to 1.8 when building docs samples and serverxmltool- Move webapps bundled with Tomcat to /usr/share/tomcat/tomcat-webapps (bsc#1092341). Affected packages: - tomcat-webapps - tomcat-admin-webapps - tomcat-docs-webapp - Remove %doc directive from tomcat-docs-webapps files section so that zypper installs files even if rpm.install.excludedocs is set to yes.- Require Java 1.8 or later (bsc#1123407)- Clean up OSGi manifest injection - Put embed maven metadata into embed subpackage - Use the .mfiles* lists generated by %%add_maven_depmap macro- Fix tomcat-tool-wrapper classpath error (bsc#1120745)- Fix tomcat-digest classpath error (bsc#1120745)- Update to Tomcat 9.0.14. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.14_(markt)- Add pom files for tomcat-jdbc and tomcat-dbcp - Add org.eclipse.jetty.orbit* aliases to correspondant artifacts- Update to Tomcat 9.0.13. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.13_(markt)- Update to Tomcat 9.0.12. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.12_(markt) - Fixed CVEs: - CVE-2018-11784 (bsc#1110850) - Rebased patches: - tomcat-9.0-disable-osgi-build.patch - tomcat-9.0-javadoc.patch - tomcat-9.0-sle.catalina.policy.patch - tomcat-9.0-tomcat-users-webapp.patch- Declare following files to config(noreplace) to prevent override access rights: - host-manager/META-INF/context.xml - manager/META-INF/context.xml- Empty tomcat-9.0.sysconfig to avoid overwriting of customer's configuration during update (bsc#1067720)- Update to Tomcat 9.0.10. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.10_(markt) - Fixed CVEs: - CVE-2018-1336 (bsc#1102400) - CVE-2018-8014 (bsc#1093697) - CVE-2018-8034 (bsc#1102379) - CVE-2018-8037 (bsc#1102410) - Rebased patch tomcat-9.0-JDTCompiler-java.patch - Added patch tomcat-9.0-disable-osgi-build.patch to disable adding OSGi metadata to JAR files- Update to Tomcat 9.0.5. See changelog at http://tomcat.apache.org/tomcat-9.0-doc/changelog.html#Tomcat_9.0.5_(markt)- Modified patch: * tomcat-9.0-javadoc.patch + Don't append to javadoc --add-modules since we are building with source=8 + Avoid accessing Internet URLs from build environment- Update to Tomcat 9.0.2: * Major update for tomcat8 from tomcat9 * For full changelog please read upstream changes at: + http://tomcat.apache.org/tomcat-9.0-doc/changelog.html * Rename all tomcat-8.0-* files to tomcat-9.0-* - Changed patches: * Deleted: tomcat-8.0-bootstrap-MANIFEST.MF.patch * Deleted: tomcat-8.0-sle.catalina.policy.patch * Deleted: tomcat-8.0-tomcat-users-webapp.patch * Deleted: tomcat-8.0.33-JDTCompiler-java.patch * Deleted: tomcat-8.0.44-javadoc.patch * Deleted: tomcat-8.0.9-property-build.windows.patch * Added: tomcat-9.0-JDTCompiler-java.patch * Added: tomcat-9.0-bootstrap-MANIFEST.MF.patch * Added: tomcat-9.0-javadoc.patch * Added: tomcat-9.0-sle.catalina.policy.patch * Added: tomcat-9.0-tomcat-users-webapp.patch - Renamed subpackage tomcat-3_1-api to tomcat-4_0-api to reflect the new Servlet API version. - Commented out JAVA_HOME in /etc/tomcat/tomcat.conf - Added "tomcat-" prefix to lib symlinks under /usr/share/java to avoid file conflicts with servletapi5 and geronimo-specs - Fixed wrong %ghost file paths for alternatives symlinks- Replace references to /var/adm/fillup-templates with new %_fillupdir macro (boo#1069468)- Build with JDK 8 to fix runtime errors when running with JDK 7 and 8 - Fix tomcat-digest classpath error (bsc#977410) - Fix packaged /etc/alternatives symlinks for api libs that caused rpm -V to report link mismatch (bsc#1019016)- update to 8.0.47 http://tomcat.apache.org/tomcat-8.0-doc/changelog.html * Fixed CVE: - CVE-2017-12617 - rebase tomcat-8.0-sle.catalina.policy.patch- Added patch: * tomcat-8.0.44-javadoc.patch - generate documentation with the same source level as class files - fixes build with jdk9- Version update to 8.0.44: http://tomcat.apache.org/tomcat-8.0-doc/changelog.html * Fixed CVE: - CVE-2017-5664 (bsc#1042910)- New build dependency: javapackages-local- Version update to 8.0.43: * Another bugfix release, for full details see: http://tomcat.apache.org/tomcat-8.0-doc/changelog.html * Fixed CVEs: - CVE-2017-5647 (bnc#1033448) - CVE-2017-5648 (bnc#1033447) - CVE-2016-8745 - Renamed and rebased patches: * tomcat-7.0-sle.catalina.policy.patch -> tomcat-8.0-sle.catalina.policy.patch - Enable optional setenv.sh script. See section "(3.4) Using the "setenv" script (optional, recommended)" in http://tomcat.apache.org/tomcat-8.0-doc/RUNNING.txt (bnc#1002662) - Fix file conflicts when upgrading from SLES 12 to SLES 12 SP1 (bnc#1023412). Added explicit obsoletes for tomcat-el-2_2-api, tomcat-jsp-2_2-api, tomcat-servlet-3_0-api- update to 8.0.39: (boo#1003911) * Improve handling of I/O errors with async processing * Fail earlier on invalid HTTP request - includes changes from 8.0.38: * Refactoring the non-container thread Async complete()/dispatch() handling to remove the possibility of deadlock * Improved UTF-8 handling for the RewriteValve - includes changes from 8.0.37: * Treat paths used to obtain a request dispatcher as encoded (configurable) * Various jdbc-pool fixes - drop tomcat-8.0.36-jar-scanner-loop.patch, upstream- Switch to commons-dbcp2 fate#321029- Backport fix for inifinite loop in the jar scanner for 8.0.36. (bnc#993862) Added: tomcat-8.0.36-jar-scanner-loop.patch- Version update to 8.0.36: * Another bugfix release for the 8.0 series. Full details: http://tomcat.apache.org/tomcat-8.0-doc/changelog.html#Tomcat_8.0.36_(markt) - CVE fixed by the version update: - CVE-2016-3092 (bnc#986359) - Fixed a deployment error in the examples webapp by changing the context.xml format to the new one introduced by Tomcat 8. See http://tomcat.apache.org/migration-8.html#Web_application_resources- fix maven fragments paths to build in multiple distribution versions- Version update to 8.0.33: * Another bugfix release for 8.0 series, full details: http://tomcat.apache.org/tomcat-8.0-doc/changelog.html#Tomcat_8.0.33_(markt) - Rebase tomcat-8.0-tomcat-users-webapp.patch - Rebase tomcat-7.0.53-JDTCompiler-java.patch to tomcat-8.0.33-JDTCompiler-java.patch- Fix fixme for the prereq preamble value - It seems systemd prints error on adding the @ services to macros so do not do that- package was partly merged with the scripts used in the Fedora distribution - support running multiple tomcat instances on the same server (fate#317783) - add catalina-jmx-remote.jar (fate#318403) - remove sysvinit support: systemd is required- update changes file for CVE information - Fixed CVEs: - CVE-2015-5346 (bnc#967814) in 8.0.32 - CVE-2015-5351 (bnc#967812) in 8.0.32 - CVE-2016-0706 (bnc#967815) in 8.0.32 - CVE-2016-0714 (bnc#967964) in 8.0.32 - CVE-2016-0763 (bnc#967966) in 8.0.32 - CVE-2015-5345 (bnc#967965) in 8.0.30 - CVE-2015-5174 (bnc#967967) in 8.0.27- Version update to 8.0.32: * Another bugfix release for 8.0 series, full details: http://tomcat.apache.org/tomcat-8.0-doc/changelog.html#Tomcat_8.0.32_(markt) - Rebase patch: * tomcat-8.0.9-property-build.windows.patch- update to Tomcat 8.0.28 * Multiple fixes, read upstream changelog at: https://tomcat.apache.org/tomcat-8.0-doc/changelog.html#Tomcat_8.0.28_(markt)- Some whitespace cleanups- Remove pointless conflicts on provide/obsolete symbols- Version bump to 8.0.23 fate#318913: * Multiple testfixes all around, read upstream changelog at: http://tomcat.apache.org/tomcat-8.0-doc/changelog.html#Tomcat_8.0.23_(markt)- Fix previous commit. Fix one rpmlint warning- Drop gpg verification from spec, it is done by obs- Fix build with new jpackage-tools- update to Tomcat 8.0.18: * Major update for tomcat8 from tomcat7 * For full changelog please read upstream changes at: + http://tomcat.apache.org/tomcat-8.0-doc/changelog.html * Rename all tomcat-7.0-* files to tomcat-8.0-* * Update keyring file - Update windows patch to apply again: * Deleted: tomcat-7.0.52-property-build.windows.patch * Added: tomcat-8.0.9-property-build.windows.patch * Added:tomcat-8.0-tomcat-users-webapp.patch * Deleted: tomcat-7.0-tomcat-users-webapp.patch * Added: tomcat-8.0-bootstrap-MANIFEST.MF.patch * Deleted: tomcat-7.0-bootstrap-MANIFEST.MF.patch- Version 1.1.30 or higher is required for APR listener (bnc#914725)/bin/shh01-ch3b 1720534825  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{$}~9.0.91-150200.68.1    docsBUILDING.txtMETA-INFcontext.xmlRELEASE-NOTES.txtRUNNING.txtWEB-INFjsp403.jspweb.xmlaio.htmlannotationapiindex.htmlapiindex.htmlappdevbuild.xml.txtdeployment.htmlindex.htmlinstallation.htmlintroduction.htmlprocesses.htmlsamplebuild.xmldocsREADME.txtindex.htmlsrcmypackageHello.javawebWEB-INFweb.xmlhello.jspimagestomcat.gifindex.htmlsource.htmlweb.xml.txtapr.htmlarchitectureindex.htmloverview.htmlrequestProcessrequestProcess.htmlauthentication-process.pngrequest-process.pngstartupstartup.htmlserverStartup.pdfserverStartup.txtbalancer-howto.htmlbuilding.htmlcdi.htmlcgi-howto.htmlchangelog.htmlclass-loader-howto.htmlcluster-howto.htmlcomments.htmlconfigajp.htmlautomatic-deployment.htmlcluster-channel.htmlcluster-deployer.htmlcluster-interceptor.htmlcluster-listener.htmlcluster-manager.htmlcluster-membership.htmlcluster-receiver.htmlcluster-sender.htmlcluster-valve.htmlcluster.htmlcontext.htmlcookie-processor.htmlcredentialhandler.htmlengine.htmlexecutor.htmlfilter.htmlglobalresources.htmlhost.htmlhttp.htmlhttp2.htmlindex.htmljar-scan-filter.htmljar-scanner.htmljaspic.htmllisteners.htmlloader.htmlmanager.htmlrealm.htmlresources.htmlserver.htmlservice.htmlsessionidgenerator.htmlsystemprops.htmlvalve.htmlconnectors.htmldefault-servlet.htmldeployer-howto.htmldevelopers.htmlelapiindex.htmlgraal.htmlhost-manager-howto.htmlhtml-host-manager-howto.htmlhtml-manager-howto.htmlimagesadd.gifasf-logo.svgcode.gifcors-flowchart.pngdesign.gifdocs-stylesheet.cssdocs.giffix.giffontsOpenSans400.woffOpenSans400italic.woffOpenSans600.woffOpenSans600italic.woffOpenSans700.woffOpenSans700italic.wofffonts.csstomcat.giftomcat.pngupdate.gifvoid.gifindex.htmlintroduction.htmljasper-howto.htmljaspicapiindex.htmljdbc-pool.htmljndi-datasource-examples-howto.htmljndi-resources-howto.htmljspapiindex.htmllogging.htmlmanager-howto.htmlmaven-jars.htmlmbeans-descriptors-howto.htmlmbeans-descriptors.dtdmonitoring.htmlproxy-howto.htmlrealm-howto.htmlrewrite.htmlsecurity-howto.htmlsecurity-manager-howto.htmlservletapiindex.htmlsetup.htmlssi-howto.htmlssl-howto.htmltribesdevelopers.htmlfaq.htmlinterceptors.htmlintroduction.htmlmembership.htmlsetup.htmlstatus.htmltransport.htmlvirtual-hosting-howto.htmlweb-socket-howto.htmlwebsocketapiindex.htmlwindows-auth-howto.htmlwindows-service-howto.html/usr/share/tomcat/tomcat-webapps//usr/share/tomcat/tomcat-webapps/docs//usr/share/tomcat/tomcat-webapps/docs/META-INF//usr/share/tomcat/tomcat-webapps/docs/WEB-INF//usr/share/tomcat/tomcat-webapps/docs/WEB-INF/jsp//usr/share/tomcat/tomcat-webapps/docs/annotationapi//usr/share/tomcat/tomcat-webapps/docs/api//usr/share/tomcat/tomcat-webapps/docs/appdev//usr/share/tomcat/tomcat-webapps/docs/appdev/sample//usr/share/tomcat/tomcat-webapps/docs/appdev/sample/docs//usr/share/tomcat/tomcat-webapps/docs/appdev/sample/src//usr/share/tomcat/tomcat-webapps/docs/appdev/sample/src/mypackage//usr/share/tomcat/tomcat-webapps/docs/appdev/sample/web//usr/share/tomcat/tomcat-webapps/docs/appdev/sample/web/WEB-INF//usr/share/tomcat/tomcat-webapps/docs/appdev/sample/web/images//usr/share/tomcat/tomcat-webapps/docs/architecture//usr/share/tomcat/tomcat-webapps/docs/architecture/requestProcess//usr/share/tomcat/tomcat-webapps/docs/architecture/startup//usr/share/tomcat/tomcat-webapps/docs/config//usr/share/tomcat/tomcat-webapps/docs/elapi//usr/share/tomcat/tomcat-webapps/docs/images//usr/share/tomcat/tomcat-webapps/docs/images/fonts//usr/share/tomcat/tomcat-webapps/docs/jaspicapi//usr/share/tomcat/tomcat-webapps/docs/jspapi//usr/share/tomcat/tomcat-webapps/docs/servletapi//usr/share/tomcat/tomcat-webapps/docs/tribes//usr/share/tomcat/tomcat-webapps/docs/websocketapi/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:34708/SUSE_SLE-15-SP2_Update/56ff2ab83dbfb246ba18314b4b496edc-tomcat.SUSE_SLE-15-SP2_Updatedrpmxz5noarch-suse-linux       directoryASCII textXML 1.0 document, ASCII textHTML document, ASCII textHTML document, ASCII text, with very long linesexported SGML document, ASCII textPerl5 module source, ASCII textGIF image data, version 89a, 146 x 92PNG image data, 1873 x 846, 8-bit/color RGB, non-interlacedPNG image data, 2901 x 1431, 8-bit/color RGB, non-interlacedHTML document, UTF-8 Unicode text, with very long linesGIF image data, version 89a, 20 x 20SVG Scalable Vector Graphics imagePNG image data, 976 x 756, 8-bit/color RGB, non-interlacedWeb Open Font Format, TrueType, length 21956, version 1.1Web Open Font Format, TrueType, length 21092, version 1.1Web Open Font Format, TrueType, length 22604, version 1.1Web Open Font Format, TrueType, length 21252, version 1.1Web Open Font Format, TrueType, length 22748, version 1.1Web Open Font Format, TrueType, length 21184, version 1.1PNG image data, 146 x 92, 8-bit/color RGBA, non-interlacedGIF image data, version 89a, 1 x 1 Autf-81fdd4eb47112867e6567cc310e06522249bf510325a07bf9be9ffe8464277e33?07zXZ !t/{]"k%a3 Ț~>o~NbEܠ= a,   oq2kUkdF$#K?d21D@GWKݓ',MtTZ8es Պ] ļNVa;LHѼSHQik~#T(*:RG!ayܒGdׇֻRi'7wicnywj KPg<pP*FfN6tukELrN eն0x !C4mJN{ݼ~u4T(=ɶeu;!_ZR.ﱙ-?n}HQM(hݒ{0uΕ:H+ȪJˍ9IDtOR18(ZO(;2 „]D@9Bj{4S NPY vt$Zg[@˘n`l`&)ת,Czct6xvi9wȻ'Lj[SJ:{ՇzA`9&ҁ/`ݡ1ϑ?*h-ovrwxSdMwz\۬9'_9gF*μ8+1qB_SQTf!^&̤EXqtrx㷚RVƠ:FJ7 ,G~|֖F B-mw#LuMnN<6\[6伴x%&%9|!(3N67]_US<76xf^…Rhĸ}bx1ZX'qpf,a;VQ95ܿ}Hې\3ֿ\ȝы~<.{g*|o g,(uF2A%eKD%eIy%f]7E᎑Q4,Y=Z}WP)}" _>?ܷ!_Ƹ܄1A~@%6p']!f0K;*1Y5!^i̬` aZFCh_xq$CN Tm0 ,ja:"kL0Z5$6dz(yӂ$([42mَXT.[H=c60JgqkgO #80,i秇W߈7>/؁#V3\=\{$j^VӿXQdf\88z@>~MDvRh?".}6e-Jef* !wdĕh*P5-skin^>8@敤gtѰn;VLG>tzZ"usTR!=(}ܲ0)ZQl?D'rs~'dpm1%!=R/f `+b4wq3DSzZOwOj,:"4}$śMNx;&gX:N#G#3)/~L>mN.t"hWkXBwMY\/FyX`=s_Y9ҶZh)|~EAYB{̨?ۤ*~B] (gJw FPX58v.>g$Ru׊fYSҲEw=-_ ?wf7Q7cxu fuQTNȾfXJ"w!^h,oi6nM!PvTLlt on=k} _+i:HQ6ڎ{B\4pG㼑 ay [jm/ {!7KB&JY",!#Ln 6;Hﴔ*Y^}.t`ᢸ[K@uŤ]0 nTeN'L bLOsiԘ@齑6&ۍ~f|0E'S`/Պg ؍l΅b&m̜E)cM`4)V߰E}a'W_20[m.P q: :' Ru56Ce d䆶 =rEx5..Y^cJ}/ &؈̞A6S00`5Ws]UP40gfJe`p2wRx8}oVr- Ŭe5+k\c !~c̼pj3ib޳0PG#NOVf2O;Z 5AVCmgceίKp 1nZ{8(sDn;sk|@-Q-@ q>DZ?j' $ʛ1;Sx]l3jhtDvbL !L?ufQN l[s1\( w3âo#>1 zd%N CL~jXl$U锘awv&e:D[&|TFIH,hxW[E; ^usd+*W_;A{/\Lz иͦh[i׶DA5S+tuN@c {g<_RliOAlQ[VexGqUTCtq)⧨4)"4دO|);k׼ob}!fkRo9 cEkAJyctxy6(|=\2a[ &)Cגu~M!qIqAJ2\@D$ڮQYNf,+}1%1-QKYO(";-OMhKocZ$cq寧t@%) z* 0Q~-|'>}t}I9;^Y /p;%S>\U%1 ,IV"?@C+W"kS ߋ:YMo{uȽq'M UJ9pxB ff!YYЉYgnȕn a"0Ψ X*(0p8m:p$zR|="GA@ߦ(ֵ$7Q2V zPiEdA5/s6[a^/Gy!ڟ vͤv x i Aqr$@hk\G#YjUqcY\:Dyl.m]*ːVP_^-f]X艥z :S/?4>{I(>}bz#2wnZߔh/"ge!9Š= L+5M3KXƻNCnnWk746!+zFZϵ6Pu&ޔN @2&d>xS]{2;ރf#^ͻ3?(lڨ5ZkhFS0vڴrvW?ynɹ<0Ьy;bW8Zd@{(Hд0h^$M"+ y91kpڭW<;Pbr^ܗ8es`Ϩ]bώ<~=XUg{2Pu]Z@ pk3/4F{$lӔ%(7:Dc|4Q4v:K`.e0R,[oHpnù)2K[[JCo#!cU;7ز[LkJJ8Qݘ1 >`]JGkѺ(@/gB\Y!%|Ph 9Oy0 +DPgP`v+5тP;7Zӌ[+E=^[z!n64XgrWy І!:͏"(C}@3.!6ۮXb, ` @ޣaGzj( r EU:kJ13z5ZYHU_kUnzQEr`;!3̓suz pkմ=X]×8W!a K9!=pSk#jբ28DwI@Rd&T? r;9!fyOdj a{CBQٛ$q']Ԣ12u-,=X篶UoՄC^|N҅8^ٴ;-W1 mEX31tjQGj>`6sG[, ,י([OĨGqNdc|Irsƪ +XOXCV'>j|@R R0 %u]mg@[5l _~v~Bp#?ҸqL`n:G-?\;h78+:g=9 c+"4\GʈLNR.6ϯ`HI=%x >o)zƠ:f"K*,ٴvp֯a8q p3+w{dOgڗ\yTkP@ǭ8F*%p_<t8<YKʗym@ \<\u]_5IQG7ʉUn' qQ_SkMvtrfx'|}ݚm(lKaw]CI(>`E{^y$##?LY]VctCXNppD'&׹0 lĽ?-0U';^8M69FS/[Q0qi5NnK8&nO`g &g/ldzJ5) NDP `aj%1Z)l;ev6^$"HJm- ++#@}\5> P8C/HfY"P ܮU'X oID=j!fQ#㣓C$6|_WuXR*!)bB=~2<{nޮTbɦOhI&l?ZϞߒʑ6#9$g]Li!?VH iVh]ڣ&>Qj2z pe${i`*X(r@5C[IŌY:/Ȟ}M6&j}yX@V-sEZFL/kr`úVBV D͞_r(=,UY(Y!i"eZb̛m<k`L|AtڨDzZ6*7?/˹=3~rp9PE2/dHDrkqL9˅|ϖ_b!U^:_~Ҡ>eMe&l⯭PS5Vi KsrtSt\(Рe w#WAu<<^=!m@w 8E vZ˿(;C¡nUpW=\._QOho/VmԔZipa0xaC.F CeXUMf'N륥3ah5%^NX6J})ln ;Na4Х}\aU6RNbgw7T<>[#5xX*}P@Юμ$>Er A&pGNbѼ){hѷs~hYR ֎Ӟ V4?3{s? BlcP!y 3&xרyBvUN~En>s=BH 󶩸!Y;$Drz Eiw8𣐈§wc]!|:C}ȩXAXXlV8?AB3M;J"sޱ\nx)H/ pC ;6A@5鈱 N`E4LJO*_"R"Vuz34X`X^(&oӠ87ba |86&u1|GN-VYAacL-{7<_N+UimğnX}ZRD>=t6,S@,ʴ8L+fr&gDFQso7NK6F/ӵ: OhB<,tqˠ?OZ3QrFэIXwJ:'DAo&Is笽^BhF6]Iz "]ܐnGj/=2aqX'#ÙZv1_~VX#YB܁ð kK; 0* Վ$A+x\Zg' DHӉ {*vN, SȬ<LXl*^tb[wkVJQ}OON_F I f7ж2 O,`gvÜ9Q)EIK ic(cM(RxqUXȡ9sS>(<# Kh)?UAET42r RT% 2nQ,{3c{HMF7Ed„>@ OzHj.X-,#:# ᕫFTd/@c!N><*c.ĉ'[`bkD֙~Y60y'g+o~S-VRT xݕQJiZ$*r1r*$(w}cI Qwڛ`!T2AouU-ة;Mfg ?&@wXf$un4QP/]l!'G<0h oC5L?ȼFkK Rj?Hr*PY[kPv5T4Yg|ֺ> Lz!)F6kghh\d ֦:$sҬw{h(9[w]B:&y7|Z_h s$׹2YeYGUYR/@Z끸缝~)_>+_S#BDU_bD3qȥ0YRn2 4}!]]*K?vI2:ʁ2ˇ) oQKs'fnC'ŸwA`4A记1`3b[oe@ۄHB?>;[X3Z5OX12l+nT*LQ x;,^e%cFGMPzxK&S^ 7g:mTe9áQ؃X+9]kTyHrboBye n#dB$T,qJbB.af c',@,iO|cBI?ROn:{Y>v 3P} *&xQިs@5Eׯc34+iKth'"`BbHpg~rMؒYEP;&.L=R(ؓ~Gӽ0w/푐5* v2d Z&/&K`"]BPEsfJBE-y.<'w,'wnq7˭-nT U~g;&~ݴkRNiI10HQ)C*+Σ+1/oPY¶pw7f AEիAgw*@w[qn]`6vdxK>2()6jُ|KDW,%K)ˆ)Xۊ0p;HCqhvP[EWͥ!&݀MHSCK+/M mN6dB^eKu~X΋_']c~Dǀ]7F}W;{nN""]>+Ggdwi^vkn5bLadAIj34aZ*@`=H7%@X1&Yֽ,@hO{K V2zs\u9iJ+HB_rSָ~ OUGO)) G}wT]i q]/*iREIcx#K7@CaDp9ɃFk0 #n)s69ł޿'/r{I%5|4˦6@VW?:tKF$.!lc ~`A a,M֜Z:bGT{0j9wKDWm j\WW3iZBiPx wW" Mď)Jr\L :&Aۭuzp94 uge$ DZKDoJ}xW0v*ӟ<CK(ӌc ŭWhҘOq3D &&^2:nV}cwyex[Gn*+7zKsɝw q'm\1eb߽ 4/?6XkHi\#A1̭{pGKLr3g;Eڋ}]3YsdehWu| FB`# %P/\[M*JIiA;.2dEs?Ĝq-Uj*[_` U $ h̏Q{gH~V,jؽ9stD|rwď,uB!ە+*Bh#oZl{v $R߼^G(0=Ԃctw[Ⱥ8sM#m#BZTﶂ. "JّK0mы1z 3cM<ыN$XbK~uCMߐx/\*̑VKLkx8׷Bl,wog c W$xt:a K^Vk`Ide's'LYT: ^Lgd{r"?(D/*uK]B1+}9 xLX֘6R!Q[u<^}(|F=Y/|~>iav/oUFt,qX&^*&pԩ=2|2^{<1G #f)"a`~N,s_+‡ЇPُq[Kecdߟqn@ZH=kxXI]9XtX< ?.sfQ?/!30:^N!KoQ?hɝ۬܇ bhvD8JD^à=GOx^AA(=䄠NP8[L}?L}Q J@dd \*r@Ʀ7m s3۴|S :O "f@sP={_%_T;b@R"x ՆX?wleE ~񲳚YԳLQZR;֜KY~ϥ x'?ePNoOe5Kn%-\y)Y9am f4 p9f&He'G(4&l%5uҌ%]Æ'M^wui̯Bj!"|>R޷dnv"̋YKnG?\cdeL0z5=r7 n$ _za$JM/] Ɖ<>Z[b7B[H^e7uF:00w/b;uNĶ1뽛TB ԉ*tzGWAU23:1U<&?$B Z|Gû A|CG<,e~0PIrO4]cl̩%ol3)ۗ|Y[&4%'?lri# I.*|rѯ)G'7CO` r<1<4}~¼u!Cw!t0ϹGЪ ukv=oHFcܾ~≕S;?p~ >'x0=Xl!/n.DøcutD,͡W=/(oDRPJ #EY0K}Kͼop#M}B2$ڜk*to:p#6g_1 +^%]hfd r}U,<֕£!G* x`3N1O%Y ((^XC?P <;[+Tቕ_Ք< 8.Ԅo~3&Fʹ=Cd-dg\WD违cr6@?UiD˜c/nUıxUO:,Qal FWO%Q3|MpvT6>7.J ~ 02:@ƘůlRR$rqmGzoQͩĔIsy ^]-k''e(倮ɳJ~+$GbG@ONKeX^aIwՖ4ŕoͫ`x#X]pUer31@3$i^67^. hw!(ƧΛ p8d1:R>YB/F= \FVF%Vk)n9bRv_1(4 YYl2i>e@U6Ągvu$9DA+F,`k %XRy$# @&3͟;P5 T$խזʵ;]>Z}_A d"<'ce4Ddp0|#Cy !?_HjQkU/'%P-S( Ss3#9h18Α;fCh*+.!1R1~%m\C55A̎INL_3*\Ymu1㘟!0Kh g|WF$jwdH(͚KuO_ Efl"tCWm :?ό!6c7vl9"P^I%:$CeP9ck0G{_>Y!O?Rv4҂L1''Y1Q>xHI"xBpT$C{vnfXFgO f1}/Kج2uf:7tԣd6^nKPT/Nd6ӡ;0ժ@O+Ot9Yqd~npz\l8Iid66ÕvB6ռ"H|I~HMYyլZGۿ&VgZȰOGˆ^Ԑ ]lWt k;Niwl2i1:,NG|ZiE&dң.~ݷZ#6Ws@챂 1)3s=eCe,Vfț-嶞+9۬f/)\]0mץ!Uɇ)n0Fɒ'5u ߍu "?89b"K.3_n"4(O-GMZh_ug.o6)T_k>]!+ȇ}kq >^'3Fgy"F넆|K-lu RxrA{دZ+4;]*%Zor /lK6cNO{b3vٞ8|ڧ'MgSi/,_^x "4E:I;Fb%C }^p=> CPQ< ܿEZmu rYϘ"0 rvn`:<&*뤕o{rCNnJ6bR;> gn}~vmb m6jݎK  /!Sf펦3~65EK]eٴu Q9RdY#I=؂냋{?0ޑ rckkP:n/UtH3mZOWdڟ)-o.Z% Q-E YZLҺ7&(pD].qitP&l#/܏I^smJ߃ܟ #BGS/CY.*vC.qX*{{l? WZ>3(-dW!W)jPqF XKןQ H­5~`}Zjz/ p)Oc@ # Ŋt_Ԋpxn-AWbvNJxOJeQ-AkY`u,Y(qaG h7?ڶ;Yޒ%`PqD+,G{3- *XƷudhVgQX[D8ޘe;XBviOy(؊E=_d&8A!cn q@XbHZ !oT3 R|~?!K+E?"N~X*zA%K9@ݸM`@m:k̅[j苕> ɻP@asxaFFnSc]:NkBF}y*z ~bCKD]cNҟr (b˭ ^-y3ulxixPƔ|.F8elys,$P 8Kӵt,bF*EnVaPnR.bUvipKs+  d{W !T3 9|ҎM92F?OlEo#U6 RݖjS{H3>dR<.tv\d>qk/p^\dś&ZN°RWZRirpJ'l%L;VF&|)${,t> Rwsq*۱1eFz`6㘛 ʋConFC;LyW\_!3&/_355?uǰvYu)חW'uvAX2lVᰧCaLI-lETAGo%"牃x}4Y2;`n:\w }XP"⴪zs@S O L#ivFVv&"Nд@8{&&y#r8&p&2nٴ=٤%^7qJa(%"469!UBj KH(2;.ئ,Ofu<\ÑTXw[09[oi4 =u/YȤ 1՛r4fwT[6!=aĖYAU,O/ =WJ=eZ 3fiIFVEZW9>zI/,Sb;fKQYb 3k1Uc@3'LZd2t1WM_͡:~~GrF~~Q|+xw g%12N#fOJk?| QA*?ril-3H Q`ҭ"K>U:](˫˟>4/$__dFM`@&=J^^ O%@L7*VKUMpd\PbX"\Cf*Ԉa7O|Aa͵emiN0aHQ /KϚZ]L SG/Mzv׮lܜ\CqʬV'Y)_-Ѵ"ZMl6f{/E*qZ(JVtN _-lJ4ߔR$DyUެo;!' 'T5=,& GQ}RȌ\ObiYe;^ sTLd2OXN~9ӃԼh|  rt'-#!!BJSaIu u[}aAfa_ ]!7J& tB.~<螵 $V֫[R#Z\_nbbqDIw1r8:V߯ Q;I[[6#|Lϊ D׼] qJ9ՙ%6k';6.$鳜M%ZuV}F@O] r)PdXR,/^EJzlHпC@_d9E^uRZ(5& rHb^D8@kX1aͦgQ#!5kJ ~;HiCX82,OV"c#YpyrN b 'Y c',!-k]T vxJ/ı׈ratxJxX%*vu< Q:eٺH89 t!X&IM, VkîHzJݭ7iPˊNn$8da d7R GtQ:ⴰy@ѴAPr(='֥K) {@m)썯^Y9+gUd61 n-+Q nGt)h鶛0&d4К[4l%%)=jtn5ݽ).ѿZptKV H/?6hY?\)l'\6H]%3W1+A:ߙ/,{uF. mhc5߮5|ߌ?B*.8!F5zPQ0Q;1ҊUTc-iG,p}?wŕ ?K#/Ux Bt[crF +YC-2->\]ƯuMtd@[;Ӵ1p^/d<=lg9Q OtF- i'y/<78J$('Y~8ۊNiA0TOCʬJ6+%}BdQ;.?~;ɑ|y;(⇻odnlVۏܐS5;+Ax_h$g Oj;u +^s,[L%I]_Oj6\QT*ݏ/8y4:4g!UM1Okp ܞh*&n4Yō#6Hg 1?蔛~}/]; 8 B r~+uTâ()[9Qc)IU"d -oX|)p8^Qֿcbr<$;- uy~ICb=x'unV`)1[$`u@4n aiٻ,翓vZ ϵ,>0!C,H_7541aAdܢp Xn<4x~.&:sU]ޅT1# BI9*Z;`iDz1!Ha_KSBȠ̞H9tmY^kVT=}; c ΑCD@DEÀJfxYт.@zK~ $$? u% Hv<8yx[VIeO ijCWtM_:u!N;(lJUTO3J""4kLگ:h `15{P'uGRhwm4;ȼ@=L?LLf2jfU(&6 IѥcdFX/lW6#|9]`dQ`ij;X,zB10m:rX2~:t+UU"@#L`,?欝Hb]1zǘ\TfhH ?D8qa,)ʸ:;#E{?j]oJ|{HIc;D32 H ؾwVt+&#D%PGiN J?:r$"ui|e{ZE@YF~=N)]eNg M! VR0C_M&6:4`sXG!2yE$p .3ɚPi/Fs'[PuJׅ&H(,|ٸj|9o=F/BJ= wA[U*i%@B۶0tnx6AOyȏ6o7ְ+I /!gh-SJlXa]f1s%4F=,N]дB tt9m)L5D*7? Ǹ0Q͘* /cz੗h8J,JG:-N^*R~_^ЕYLsWް[1/K c1aeCWF#SzCfTˁ1թ2*r4\ځ|bm-:.nS8dp<}Iv҈6B ә=LHBM S՗c^N6Somq)IBX_E؍%JJƯ#L\6"ѳMτHn8\VZouc80s;Sɺ+ql ~DWGopSry 6U$\bkg/JYeٰ?3w#j %(a|qF|QZI׫zUטV`@>筟I_]FjA*е3I|>V+zx5r1R>V ɟ~>12D+r+>@_Yu4XG_/?yڟhZ%>Љ> -M,5Ii<nkGױ#z>۟}U=7r=bZ8Af.wcڄǫ8|,{rJL6NZ]57gz_K!uiy[NaH휜{ "oĆSY\dR&C_WW o1ϑ?:Q5&-tsE~1;ù"$>Z?wWÖE*}IcA%5J z q58\OZ`(8g?2Ӛ+;.KjÅyQ hYh(O{2 nc SuZy}͜Q gjU83" s@aI,7~z{9x]RhYA+8DJR 2 B ԈTBjw1~5-IPjCB&2Ιwg|$LPYZ5e)f]!ld6Mݢ\D̿JӠfM,0tfh8f~'~e$` t*R#@B\ x^ HܥD}j?ĆZupdO'wdb:^ƒi9 0-$ J"\0lHA]jY_ʠ=q I aG -a=zik(D= BuD-;l2I<2<)/fvfBO)-7bݤ4)gLqh Tϸ6( OޕvYv쫄A<=&!o=[m:'@_fLHeJ@l5"eO+Jۣ5i;H;q:MzOy%HÅev?I4ׄwS`ׂ/Ǹ4k Ox^CŌ|t]DX` >(x`H'4z@LqL􄊉15v{vЦa NYx3"+jDQKSaWvݞ`U౱:9U6GML Ip?%6+T (ޤWx'Dģ Va>B%d%?u>S;:/)e v*D6$ۚ8, Q<<;eUxHCZbnRGkZ% P.@-樚sFY{mӭ1!V-X1al<%|O,w'M{aۘZKGDs/IEǢ}92Z6tG'={}@!H9~zzSZ4|y֙R;pjbBuxG%"uZ7nկvX3Em [[ +2}7^}p%/!-N럟} u[S[b'+C՚)x)>US2=0G"?Nb߮Ѻ^}o(`D dc?XW)fnd?بU|ؒ5V5RIrḸ4xO]Fp0fzpL/hO,OAYmjVb!׽ T^?ȡVpM2GO3F}|RXrS\93C#;1g8qR0.:8m7/(H!1h,7Z6s9lXd !) i3" +?Oջ:9H^ڣG{A2 E@گjYIA՚}MEF_>&Kxa7-'>\)J}؁{ZWZ:p f~4 NopLe)L͠+(i/J$EI jbq{:nUN v~2!@h-e$tI760P'"jjbpœ%Sd`sLq4lL]`Q k'ڐwDrOe=[jAen1^ҲAplP%9Dِ%8Kߙl8Srj}j Q酆Нk7DRJD\ e# 0- tx2 k%e>Lh\^Ll+^64w"qZc-]U]Przpk#4 Q83&C-u]k&V&=yB21InpK-t^"ca׆To"SQ]7$IJ_/@}פ2S?W_$qW-wѩ|)wycEAȹ&S]) ҍZR&$|@nw'W3uە6MEN{U<~68E0YL^g3/MYyڽ n6Q観uwb{[RJPӬ'diGMuv/1F kmn=[DLwH]rw;:}b8|ފV.GAOLHL)C1\JSA@(\$ V.P.TM4H :Tmg|hEE&\y12\dxaD9Z) IDx~3G}b1@6v7ȼط'JEة,x˥A<6,Tv;DFZ_趗#” T9:;ima~\j=ܥM-.!ks~̚-J xf+f*gvO$([ k踅U"&dM"jҏCDw/ kKkӃ2n+/ù= 3sIq4wu1e^+7lY[ #10Ujc|,a-S4t̑T,ap7!k?CSve6C F*e 5?}lVLvi:Hj,Ӯvq^r{l:dp1h¼A;&Qdbv+)q}xc?^Ah%#vPxcS9)-T"|6ÊV-WSi$D -w|Pr]&KE݅Y9U}y#}`^{S!xCPyHn4'"d;I*7{!d H 66 l 1PLMs|] A Ti'a@}P'<~R5c׺p3?Idq((֍fp NW 5jXM 1_*SKݒtK0*ïH=qw|L]nYFN@)=H飅qo=xfE[='ta6//39~Wj!$Qs^$OR7!KȂh GW Ml!wh@ijj,5\D7/C8/laSl“$y)*IS|\EG_4z1E@v O~:U&lДk k"aFY"6gw?B)h>D+bt"cU]+ndR7LX$gYmLar4Y)n׻FMMU@Jr<كHB,\qoW4V(/]׾j,cqn]C_/ R" 6a# j.dTqm_MI!7iLcA rB1X[sA\OT@ÕbmC^Q aҿsSg@l.q}ĸE,A"S+f"|L%0˹ ^5r!_RPa5E&[yֱ'jq;Jc4RJ*ӓ <u3 BI^{uB> ;3.0uQڐb`Eʊ+mY+@SEW(W-b6Qd@\)5KGDH](A::!3HK2]8Z1 }( =2ZcsI`ѽ?~iD P6:#&уHZ9w(g8t>u,Njn6 =l6Fa`6?Qt>uՙ "'4y]*M#* ƤnM6QͶA<^!fH$X@ԟ1ôL3VÒVqouZj0z La**Ijݥ O csFbۀ`\HB*WcvgٖO:FBjf4l[@; OHCr?<7vIjyG땱ĕv*P߀LL $7|Neh-g&{DtY:7#8*>*Lhbh}u%:VT"㼩7G6p_u-ŇbSDcIS5V0mlڹ]Zۙ[ \A a,!P/.DѬQA`|<޿ixyL=ڱ(ċKc8]ƌjЂ=a%- n aC$?-M#>h7=f:G.W\H调fۄh=~91]L/étꁷ.OhvN=,tP[\REMPb\g1w^C-'>2-$~uW80om bIm]|"xKsy6zns+B0k*R&{!agV,15 * " .v3m洍Hh^8완2ȌFCpy\|[Wgzc'}։SN-2^vFk! TjNˋۀoY-_`U:DpF Ex bOUw9<1,H_}_0FMrO~5/N(GA I~YwwIw*e>kc|w4t.76c%=KH.ݩKq'/a>2ӮnFfZd X|;nNb= Gp ` G($pm : Km>z=II0\~,ʗx¬\Lf0~.Og"._$=I{E0]WFK Ә%) lt k m0ԑG4>ZmB ˳3t} +HRpn"熾'n\>F|x.1l99w:Tx]lA搨CC6R)Il=qwbi:JypjdͿl7_pOBcdE#"ˣs]ګJ=U+x3ݨzB4~b祼K1;͚~pŔ2(mT܍x!&!1t7$F/䵀Em *S^WWAO>@D~Uoz^ ]BVjFUGV<;D:qBؼeXX*}G+@UeYM"cOb?hoۈ> :7>ę!Ųe{g[yzxuA$MUZEkH*o)@@&))YpR ;>?ߛ5ȞI;<`MFOڑ5ޜ Umw\XWo|t~";h w(mt=N-ⷌ24Wlk@^sM\1 $H:"R>OQ,3 *[_*5}E_kBJN#caȼkjp0ҼirYE۸ +aX qV0F2*^(% Ar!'*&\P㓨5`@{Z>0Ƿ|x)K@zz±a^ܰ95Cǰ'dՔsKT F\r~=98L'$|&"ma#xD.ˁUFWv9'eeb{ 6SE%#]ׄ2kYCި&K krft'K43B )Sw994yt~C GTY2|O1^ͬ!~mmF}Wߋ ҏrVL +m>HN%11CJlZ+A 7.5d/ݏ>sk\2F+y]o& YΖ%}b깊P2H_JoY$3juZ%y1+S474i.nP} µi4j'ӪEt2r8Y<ь&LET܍zO}CLVɁOo@k,FQe4#\* +G>AНzQg~ mY; OꎋeJoM$ .3q.M3),~-"$)>r&̼sA1Wzvk74*JS4؈H3q yɐ_' fg}tzK.$׿G0%PVNgYTfE@*=$ܗw3"m)?)ڳ-J|rl%Qhq1,EÜrc|mQj乃\|#Kg8V, U$7Rp6/eyNib]kf$#j7RP/G͢ %gfwUp~Ctyq-~ukm$NFVSjEl~;sG Ž{Ou}bW'8jNodDχNc-d9d=c`kjEDH]qa>ÑdH$z নWڦb݅>L̕5t%MO1}AAkl]DͶSC5wؙ3c5:c}Wg 9Sk.8@9 nV{w`E XHV7:)DŸz''Q17XV)TP2;F+} qg:RZ?Fɀ^ (bwR:d Cׁѱ,D mjQ։rm7^L(=W' `^@g PKIxR@]M )6ULkIrEK_Xrbz IIqxHFg~saِaޯ  3Hl _e )BuU>ըQr.m$^GEueEJC~.DYb9,iQr#m?hRs'#`ʎƐ-r}b,B nN-#3} }~'lB\ܥ#p BUSF (4a\lc ka͇ {ߊ8i?s{~ފ>05}׭@ ,W 9rE ގj1Apm-5x Ot Y 0`&E\jP7^_`H9qOܐ*w!L?a{NUu@^vy5)`_Ḅ'G|ʍZF"~/ ~'NΖ ~ y~ nbqCV|X ?.lmLdABZxˬB^>똞{QN"^eO3VzrD!ʜHv%9W=`U%KA0FjZKZH! ={V}w1p΄ 6w"}_O hd$QwL݁1 ƷIxz'^, TL 5#z~u9'+*x R2wb9*vtyh Ґl1y$_ *t?%$'4+aqIQO2apO\x'6XQiĀvPzY:.gXsRj plKH*%;Q)T#Ýr%v']jlB\笁K<>@{S<ɂϊc7B,b9}t6g(m_aGs"s$GsLd YвE[%$<*GJ[ˋaw,82GJfT[RnT_gg TԦ%RwK_tAϵܛ7ܬ]/|:(xbpYC[Ϣ\#&I Y1h`B_׸ )gJ]Nd-:s#e\TU("?@O)i$8 " cvFs1mr i aЉU^sys+9ur8sy/‡r!:ϳ`ȴ%O c8߱?Bjc|MSfo]Vo2T߫'Krc>)%Q &wY[:K<̀,.5M,yׁk 0őMh:9yߟ< 9x片/:>7:k*䬇 F$$ Uw Nee*9x},|dzU딏xox]yȠWT(Y7b&`LH탲 s.slI`ͅR~u9hAiNjm(v#.pxozK.)Aw OqtKT4)?L57rFKF L[E5XR}!m `E*7u%TOSwQJAdDsCJ=Vlb!ӥEW`(:\Q 87%[gj'<%[Â9tN4ff@礀cQ?zyz2&R!|ZD+*E$9#S|[saldbOpYDdm 9V 62 \0؇߰ȭ3@ЮWP܅Ist*1M`+#u{/ZNj2Q8aY.{%1.f>nm0îwu .ثآ!&5ސ}l|S *.Ojƅ}`*wK67Fi5*{_%'69^nh{:E+LoaG<<4 iAk40(ZcF k{Pso뉘ӓ)*.l:Kxl /lvL 3(u̾rY4yRcj&;^6m(O%S2-fUI.T2lpOwavz]ؒA.fW} 3)+D&\%r?L]_3XIV] Twg$r߬2vPH()tc'e WHP>?2dG݋ÚәKƐ5YegVI-qyٿa$/t-[" =}0x&fQWNB_mp:- $:WճQAFf7ȏImU&1C ޕs]Wzˤ[E`#G}`Gxq8 5 yB}Gٰ;7h!DOh'lKv5\D@BZhWQb,gGxY{lF ME6ҚLA\ 4pӪ|l*ޖ^:Ð!`jh<,Ϣ ʹ֎7Vas9sgD 7څ[9tĤ;ۂp5;YVV9r"{wz~q'@;Dj^O×v"?F 弒fEt"|NdtPjvʚZLFטB,"OP/dZ{N]5%"G(Y_.Nށ3ɝmmBO_)I2 *pƺ8+̻QK:C@5Tղ3Z2U%r um8>\FB T. ;){}##ҋ}l ގHRO.?Ԕ{ Ry,arl8%0!p2+2 0K)/ϴuU{mؾzt`H]GCT@ 呺.z>ǭv%.XN64ՔTXD)HNcĈߞ] pzM.BqȫYuB߀46oS%{!l(lyR|"=)xQt)<{֮/T:_}wY*\ ta|Bsus΄da3z91Y:]7C@} *Ir"8#F.hbx̾F@Ra5 Vxm!pK%sH6>ꛁ#lӦxZ1=/w*H^.2;=a8 MУ'>G_T?У 5 ,[rli~pT B~mpF4x{8 5!&fd}'9Hya ~YE,xvWa7GxNGdr  {(2- 20Ru^x~= GgnTsC74< 5z!A n$Fd 8F!LJ;d KV#:8oyS3s&wTPC ?tj[=1x01{Ad*Bz+*h,-!'L v :S!*lRc/IfZVO->7pIpwOC`rA%\Q%)"LN?Y D?BP{W G2 29T|~vz5C1$֓rc;T0~ϝ抅5AťB0 ηw|k|c..%(SEtK$ٶnNmiQɌ A>WM5pY?#e}2ԕ@ X}UQҽ>7$7*BIxr<rwuVbunVّ;4pG%LB?mْN |XaV8B2nJMh,:@q}@?1fMJUpo/nu{gσSGhMmDm㤱M 82 gc>W!YEidEYЈg)6/^v׆WȈh?CNWSw ݁KsSt3b+-]h3G]_.rDﴃr\D |?;Q? ^:,ӗˏwvC7}L G[݀ XvYk,ѕpsjHPGRrbPAuޱ%&]-o O Cj&[\%i4u@(#_٭▬c` ;Kf$*|Cnf ^M˷l.M"fB\EHbfE #mrbR+5ЛDܙ=9.|Z5{ [0h-Z4e;,ir2S~bň9"P^z_7#X2]'a2a\d2_!?|Yς)w#LB Yck>B[L4u}tLj7~JeVoj{t!&o͇lF#Lf~6vMUn/')14Ek߂τGSMٷ#\UN$|IERלB~WdIqF ~%% CQ5Y)GrPH+LyES]]5cIHHݬWҘ`O}xS3 jBᄌk.ԓC+>]R(XV o_H|bFϓӹ*uTZq\Pi G(ÄN'NHY͗I|Xb^MBDl䚭.LD 9_y3PL: To8iUΕXg(Ri9*Bq錓s]\s'[o?NI4n ?)ƹAmuECn~`T_VЭc Sќ\BMA0^9O}l+_;~ЏaƊur-AK랛 7#!K=$CvH. h4%a(c^'OSzov潭Im*6xnYYYQ:Ba(# 108S^*d,/R$*~ئ-jZlBUT?LiÉ,-<{I6ADyKC++])M1R}2ݚ!{C֢S%j_})5D,@dMTsWey >XN%F kkb؞5Ng&|ObR)P㥐id՜>s~q_$*JۺM[V Wė+q8Bo_-_ѫYs+s#hKp)Տ/#-#DU5Р"Oc iLW9q7Ŵ9[tzƱGoBK؄R:*btK|6ٺ%t HI[[7ȴ9(I \B7caU+:~A=F 2<_y6fPiy^ "Hx,%sm$,trC8@F.i>>SCG]BXbs8{.gsz\U{āۿ㠭B'dQ-=yb|I]Xu8|+cN{l7>],cJ<_Rrw'0.ZVukW+ĸ4tՓ$yؒ#jvW+(I"JqֽO;s/xh$m~m@uƼ\'lկM %8%'Uݛ =@;¾z/'dbb/|CrXRp%1+}יNS:\V,DZ> B(^C9.tVЀqc r͏q˅%H~]CܴBͽz̜ʷⲘo(vb])^i=e/U{ҹq1jPP ?Zd" dȔ1`s/[\3=q~5PրMSr<tD[,u=sS %AD> ^_+DC7vN\e'P5b[H>5T*:&y^gp s5l#^}P@,&b¥y),A1Kw@D^ ̚q*tq_5YVF2za@tyRi1L H+>p:'p):82V{Fe=:=[^n*^>6#j\KB.gwwB"!X>LROLK7{#HW@ @qpϯIt)?~Mn9(qxgjppFaѬ+ҍVZ~rkEqk/L9{;G/'НY̺TXMRn. bq7//v^YxvE$4LΕ:!u1 /d)Ju܌3$lRSM4xP 3f(BTB2ч˾3l@^Bpwűji)$5@{O>b#+/(p3Dɀ&Њ}4u:PWd+jyB80<~%#ya M赁Y֧w7)$-_хYu(&Z"Pps/#2=l#]_n7MfZ=I>%i SNkiI#,(^эqn͖V|p'b bz>Dwm}#\AP!h m[}¨{^fw)Ccͣ&:7<3TN^̔;qߞ>VVqe)+svW]BQ&@<Z24B`9y]yG NR6oe]cUQ[2ʐ%8\rjM)שּ|v[#n?f7+ha%{0y0!Q(B|B|&0ʠh\ބaAbKڜy˾L$tKB-*[`ZMUb *8e8PCt1^7Mm-kXUg ؃IǦBe;-7Yj~i˱Di!"*xBADyR0лEKe)G䜈G%7J]ps1va _j&LΓW40kJs6M5BÆK/șP M s_ɮ"ӻsY@^ܢ9:\L_b`{~o4ʺmQʸ$/$\\E*<)6GOD$T&:G7F$eӘ,i/~Iu6#W#Kǹ}8(Ow39`(PMF%Z~ Q| ZMgŹvCP ;d Oɐғ6{@\S B+0w5wMfBPMmDBlYRtH: ND2Ub{AVgc*H:T//~"jInD (rq ~khQ^;Q\l]5%-ԩV1+)ԬMC6@gd g&}?HHBk&nSRNX09*'ү{ܪ!t+d^I!='qJ$?Z%$d He''T#!D#]4"F9oYˣܽ AߵEKʯv9(Քo˛q=3rÛ4dR;sy qCPT M˼%)0+/46By`G92K')]:kX7'4dVc, Q7:d|&I? 7xz`=T\ZL8-]IlVPS42A0]GY[-C=׵9k Moa9K$ u eխOBgkLAȡeR .`BYKT:ߞ2Kda]ܣn}j#1QA@_mep%P85poH tx?[j[Hk){2U@Ȼe7ީP6d>Y \Py:u#l$iaR Aؘ+|8xCOTs{ɽoӍjmn*/"x:+Nda˻nZZY{\ʜ2뵈b棰ׁITMZ ʫI g| =hX;Ѣ1r=vg+B1g'pgq[W=4ihX H 2_&yNJ}w;%oa# @<ʁk'ΦV|cu}Ѷ).]hg Q-ڕ7gGK5MM 6˾zL z-2:kRӎ@<0* _VJEVl[k"ߕˍ#rKd: g)eüoDFZ=D -^0[ӣXT,d{2oLK.*~fFv:8R_&uk},pmBc(,gqt +Z~-j ` ={jtwcAB`3;N'Ѝk$mV/Cم:N)s-_*s;usX7',RXz !*4n$)^u[5ROߠhUdhR^ lGLKJ[n pw]2ڔݻ?L'(ex@A1YHtcwN7UTHmȜO#BA=4QFU&izbqX-^`Ϲ*Bح LVq4Od)x={1ԐH؞]+VeO tW7o37l9;+^ W/W^-TH۽ Z[++˨TyfJv Y(<17L\5COA5"~ʲF<GQ|S_ ]%aj+G6'\ q{r F6q"ۧvݰL G&m86" *A"Y=jRp/3s nψ$!kʘ0Kh&O9͐.)]+VuɺZAIn,7?c1̈́w0Xd%SAޏ쬦BZ|I"hlTMkKY{7?y_16Tr ܧupiW9'=T"Bo }Y8YUƨ05 @g*Kny#îUtߡW3J1'MWWJZZ؃9R6Hl0}?`ڟSk[r(n ]S–&|-q?6 rRbC!Wrr`ZUL}Y.Wx>ZPqv۵ۤkE߭žy;k꽃NR=&z9־4 !E,2>cXu>J>3|BnÇU\K:Ѡ8Vt|݇ES9vתjǻN^;C\&[.(d'`K!#ᕾ'#տr)伾2 4&@"IĘ0RXv+Tؠ+ ,=6r=&qɼ.wP^o#6`a\H0.$wX:Zemd!eDLލe`X7&P >2y Z;m){KL3B_WwDgh4M"m};)A#@Cv$^q9k)z-yJ=ϩ]=QH֡M¾6pg%h!O{b TdmL-yb!Fk /o 6% x=a\!<# ` nR?[%<3%"8Zh^BSx 7qY\Ϲ 081Kd2|cs ho;E_IEMRM59%.sZ1) K4\p!6 "JvɕK|?dt2"F%1$҉6EayiP׋/v*=s0S NhXJ3t/#hl c;/"h(0ml秋 G_jk3lX#卂q^_E``4+Yfo_T'9,hO a |/  yH TIjlyJ?nf e[#tp#?Yդ} ~^|"di ĔWlݨt'b/?Y{p؋Jח? ~ Fc 5~95PUgr,/K+v$KYmnƽx\^oI`BFI\c3g[j[Pi^~N /J~ 70ZŜC\#+gj!ȉcPMw{l*hܽRW_$@8IÁPl'x<jdka%'%;rcw㵶'Dnr<>~tLA{oQ*Vn_hR] fkIד,_Kh0HtCQ}& [io@xHɬ[KXɨ@MgYC0o:+ A};A'K;Pj:}.#ܡ; ɝTۃӇeлuw;f_70jKA'v8B>NٮBھO1ˡwO©T<Ў rй)@`ΦbՠH焰CX,t#82?SLqUBQgֽP4z*VA^W Z?='5% ^l b3 ݚDjFшߒW~T-HJ{4@?X})+_tOJJYhƬ7n zpmrPk+CInE/Uj 3߁o:u# ZzSpm9ThێϤ-Jj s˿ >dQ7 @땢A yD9VJ.':c6Yy20$M}d=`" s(\'tnW:+%M_n sIh!kHhH;f˲-ו3\W*g؉h0+ni^SȮ<_Ầ)8W u6 %ʄ 3Y PڂgydВ߄+y-le;IS*(nohjo7Iplb2:_\wml$ `vj~ʯͬfї ]'x[sU+W|h W$N#<{򀛂ѬňL8w%~h0/뻁$KVSfYOBk[֬="b˭Y>xV Y ,x0dP| <$q0 IlTtЌ!xcUcKL0: %1kOJߑXi ^t6#jFKdڄ)y|#a\dyxt[4 3Q?s9X"C5%&q_y8=Q['_nawopRRgUw*vwˁ~Q/:& sb$~3S .͵ʽT6NGIYRj2O2 #K<{HK^V˴4;:]o.BAr>_ަd(B")Sk`9.: _2-U˻#:Dsh_0R>Tvj=f:FrNvŜ3c)h_5r{VDRO vCޥB2q#sȺhBB֑*GE2|_ђ1>vDͰ$e"‡os-ۆ-*ojo}r@ҀjTZ =g L`/И tDAI0Iîxo^Dšuoʁ{rDo]W4OADO~K9}Fx]r. 0w:vF jh0zߛh HɄB.B-e;%ZQkg_ U\8ZHV@-/bLא x /F:ϴ03}Bl%KRQx ) RhrV*.U޷%qo'y<xi w`u_$5ͯ9u-AdF#L&Bˣh-7ZbD4}1e+ 0{B]A%5*S݌ae (X[.L & /#os.ipE|Y z=_ylC 5T3pXr9iWځ^ = ŕ ~Y _!N@tWSy Ј/L3BP~eƱa&vj=Ĕn,Azi/H !f@^Cڹ`kK=*;_sdyF6;BcU*KSG yt)jx7WjCQwEv2WI{:։oa6vDXk.~t.h O&.QAHԭ%Cg+yJS5.n ,!⤇h8w s)'{bO">Q)&"f,@]yqD.䉨݉󓬗ӽ%(J;F_kS*s=4rɧ%PA}Bvɰx-jgSK@w(n7brN.XfyILߗ7>*V#P)2Z4p6W&0d;W>Ab,&??CK 2F$o7:sY p̮SO*ql?zYi!+#"1"@Y\BոE!ZcNN 2:+_n~Iy8t&d _d'q,;\{L rkO;|$z\D>1=ly};2^+Bn,sX" Eyag* N~37G3ػ A(-ڢGҭ})&f5lzCr@R]q2 s^B,qC1ثn ?Ix>Zm 4G[c:yѦ+~m% sN5.z^k1W.i\y=wҮ!#HS;9_e_M.{{>9q:s[Ѧm3#12/DC(6`Ln -`R/<^h d~OŻI+?E5]^xVEhr=)U"v]|[)n YnB+ 5VypҬqV[R%; &-i30꽲A^ ZR9zf @ѻHp/͵=?ɬaopCyqK; {eu;xZ;QpNXc;NpAW(设egU6&*+}Y!EL;0,Q}E`; ^ &A,)3q]^'`_ܡ."e )z5Z-|di/xyC3?pY.hSۖ{xlg4cÓ(Sk*df;+ZiװE_z&m QcX'TεW,HIUȑT skOP ,\ϝrO+Vu\.1[}C0߫d  u˿U5 Dd0]m aM}[< aۑ0gY-ސV ӦK$:'?DLseLjsn*d)7l1ru|xA7a?Pbٱfio,r`ZКsC"YË'mTpat/i+)~ =yMl=~CNi؎AN3G"`}HO--cE4/]-.w8m+ z7K"۟Mѷ#2R"qju4Ė> D4LMlXj$ʉqC;' z:Je1$"GFʄH̸Յh}1xA65za!:bzX5i^M6dp(d-ELi >犛B pYlCZG788U %<'Rpk?( T?}-n1C2L2RʢAZMPG{+@B"Hp2H~7 fj M+";d2^Eb_~ԤCҀQWJMVW羚K/.3=U$7T U$Q)B`o\yM4d"Omfu)E`Sn4|AZ}W4d,UYVҼ^w(1*W/IeH{=1~' v'|Gy-4=QU惇*{k)W^i To|q8>.H@M %s)y-{),7(:0mr{l.M6Lqse% R)pRch<kVMi$r+_ aK)"5|r*]:l #sx9=Ճ$Vv? Ym}OltAR>5NLhiSgeNvq02qCaR2ccˣmU H˸۫x|^b,i'~pޢaoZtSeϚAATcFEə6;VxNrB9Nʮ;rJBl|SFÊ\Ӿ#-1=32ᬃRog%ve9p ?SNVõ6D⾆ai8T%R&%, vYڳ?iF*[? 93Jp|:ZR./29)zw /10WӤ$"XZ ŵH :o 'ea2hRX64x5 } ;!}b4MvלV5׃*Pؖ*; ݽ*7kwi*-Rl8fYQuDK=0x5w }+p0 KQ%]kDpsk>9S*7<}QcrFP SgH$Lx3v 1tdɁ1jBR]TMMb>P,sカb9Z ] 86b U }PC n<2*6(4Q{-~-l‰qE ]v 0nMB)jPoY)yԁjئq^';h=Izwʓ)[a纋[ "2^j?[8;1~B_ý4D8;䌌2,{cOJQGxyGAXwACj_\0p>wwՋ)kY_fS0Qeh TL䦽Ӗ!PA#̤RgstOx85컏BdOvZvi6B˃d\0}&]X*]dy MaqO ("lCtp:kCҖ8H.5 4۶?c9GЃ+RŸ9LDݐ?qR}(ź&mg~L:mtU9|h8'7ԕ5;qx@ajQt{FI" mӮbT]*P`OdnU.}q]ܤKmP;wTͪѲ**X{ޠ jDuum!*kYR{]!} 4A[JFhE*qāA9 k]4y)j OW]8^+rշY8j /e xEV7Qb\5 qfzBC<-df{`l$>CHmRW"-?cgm7͌4kS?-ULw:%dk# el-Gc[,Q~E$#ضA[OB4fbۧTF7T'ʇL~ bJc k.PE e/ZO#>.?S/vDXhGV %)P#]#{8= QGIjCb\߮'g̦>Z;( i~ַvF!862\c%O8ޕn7U3HA׻0I*ۓQ*}T&܇2N|[Y?_elTp֫8Qw3]s]پ8Q0(?+ XQ(aL o+oB c6:c!Qlۤp;RWýhT-,DD;6[.9zݎT9򕁠v:=c\sn+Y@bJT]x懧O{xRs5,/H4eJ>{B2tϔ` *a.|p(m#B'od1lB)0rBy_lŒ\$B;H"vlυWPSebp@dzAdʹ.iZ]oed_tLg! aLɪU"*z"QZTacBv73 >g$JqS˿c!^G+Ku?ɣ5Q Ȍn؝&$q^N0גэb*ǀ0{ &6eV̸-!v[6hH avsS5ȸ`\9)|&$Ѥy!To/KJ}Dr_%֣p]jg!T<1+5쭆.ljowtӵ][tI1ToCLԪEֶ>"vl6Э9S!p {$2_]#l0|䈿4bL^|El%pAA^$o!:`|n G xÖN%[-#$*۸;U\̒,C k1f= fh ӱ&<]c5"f-W~ً4%\ɟSZ uќs;;? xCtcSL& 4+pLO'CyS=PS0 $@*vᶟ r֨\+ jDNL$g<@L {O /՞%7깇P& Xhct?V!LG{ \TT$eG^vExrIlUWk}QtдUZOh/-Xa-?O}²7gp{IlKwbsywdmGJC򙂿hmKBIMR&^Ž|Bۭ<츷a`|CmH9a\a>U$;Cr1b=`| GFI4"_\k ]S<:Jw],xELQ&(I`ox;3;I!nT)M-.̎G ` PQ˲#I~/ SA -s>,DX9SL'&\Br_xm61y玫lBW]T$RO]NWN199~9i-@BU>'=BYPpDTXKBמ;4V 9iR9.[W,<ϝQ L*bJځiӤs=|)c6zdystOLymbkF?uJp =NlUIZ촐~>|Еu fw,t-8&7~c/w9^LU #'Q@;GtދtZ76q(Ib@fq;# R]2E7=U}z!WdĽz]^j8 8̚'^`=/wc'ȤDi0Mmr^JsM)/);+cFRWAkM-q=D! /ja~Td~`aKRdR#alf바'oNྎjP4^ 90@Y $0&;5bڙJT%:xY|J~X/Àn({?lLS uzK^_ DQ$®lsnfT}!11=<60*AL6[$JߕK8j-xJ Nصx+\Q%p橬lH"e.!YYfz8G㥞CV^ Ǭ%yR_drrvZTIڢc^J2dkËteZ3?,3F"(0RmsJ /32- F,(x v4&V 3@0!=zPstH>:aMpp x>:Oe$q8a 85b]A:ɼ|BW) %`p{B!ϱrPz ?7$zw+}8MPhO]MHx/ : Ea$D t4V5fp*n_=m#F*4FKo^}1+{UK_n\dY^XВD# t ;!9**.͎sfW B| W,bF]>qPZ,"\fzngdK]űG Av 3XcUl*Jp6ply v#_ ۠_4j4@g|CڮxfkJYyWeGVu^١5)&TꔰA[b (F@{qa#u'IIdn jd߉ KgFXlJgwD ^ \^[o*#ZZey[N$//!75 y3 D<._2ʂBF|qVdMXG~A+H_hV)Z%3u?ge7݇ jAc sBg'/ӓp߭&ˣOxxEr\& $NJ)sBZGxw+Wzk:c۾A6\בGΞ,^Ídn[= _SmY4gs}F$f׮N+5zP:Ú o>-wC.j$`aF=\Z9ջs *6yB>kaSxw)\1|Q\KV9GcaWӌ,t/8t')քΞw/X" KuQA tG 0{^jE;J?CEe.k5[շ"He=QOc)e딉LR D0JdZ& mR l-,TzѺDJ*(2pKBȔC$>v~Y5Q*Rkh.?aq9 De֔(ڤQ1bErm3TΟQtұzD G(w˺!V(ĹhNHG}KcfFGY[妉箵{^OiUJjCR-@"[OǬTSw.oj*p`p1iZ03/HT͑wa"×E{ l=,_8o|aH3/tU@&F1wA2& gOz0f|y˾5\=ם1d`;Chh2'Hd :/ Ib˝1*[arS"Q)K+9NKO쫱xZl1ĻK&S F]#"T3mW+;Kk1f%a=c.Jv#Sw'\CJGi0D@= izek-#H}NCY$)\ d([j 5oa(~%uu sBc_]D Y{1s}tgm:EN']ެoﮙ5ha8I ?AyЅtUI6r6p|զBbRdQgt@\l<#nξ+l՝uywq\W4AwΗ]QL)%xEłXGNfs}Zi$J(#tNcg<XƖ8%Zu S 99Rȸc g^G#%6?d@gT1!<iS2%=f{_b*Um9_ XU.OS- rw #o*8hSkdy^9JTOL~rn z^=.C/ދ[<0N{@@;5V2ᨐ#|GpC֡C>Ύ jr&T))i0?8~ᖾMv2!pY.3y%,\yo 0=ьCDXaE59FolFRCI#>iM͚!`4R뵲6_.!)Kk~ ׊* /F(Ę㯧jPFfpcmSOӔ; ȼp9(K? o!fԢk!ehmվjF\"Ke\ Η4'P  Yj;^;LG[$_'h=8DUQycN/P2@!j3 Q9f G4ġ*~9^ [^oo+CLi'_0zȮTIɞCn(oM9ԱlI@g78^a) d]Ȼk%-!Vhf*js۲tk4\<)Ɖ.4¹Y-Q8ad)ݶ<z$Q37VS#;8PةK=M噯\@cr @ʂcVGGeR!9lCP#]!`伹N4Mۦ$]Yܫ5ο.!0[5􇚳WZa7tgBԍ tG:&πٮ83cYܦ 6/!Jac7TVR_lEʒKNu\ A|("d"yʮ{b#Pu9F.}cG:VApIGy.o6ԛ}϶T~'?_ d/ ]2 ڜx3_`K3"0Am)y{@}bn Ԧ3DHh?:EEb9sEpίr 6#uQ>Gr3"礌3! F#,6oƟ5U߽߸:\ Ѭ%9դp)cDl0E:.#s~eKd2o=71@U뤹CDblBZAJN Ls .|qTkU#?zX-Vrsq1NCs]oYK eCvIDJd(񢢯2S{ 1ghن-+6r'A@쳚#I[>#JlXY#MmP̐H>*?~UkEm] RAC aD,T U3F9hS4sQUM0_ =N{GhhI,Q0h=oQ9J2U-iDV\R?v`: [`n, ͓ʤ jX^(6JF~ZaWli *&s> oCP$wBƚb!3+rӄ6q)!~S"# T-Cpit*oPybV^^wՖ:Rbd!3q@*|z8]<|N>WLF|iV[PQeڒklzN{ļ2j.W>{DG9-O}Mt_DX?F-$. F}w8T1PKt`,P%=e|G*K̔bJDriWЛq\ {y3ʝKg1W]Rξ? lz#2jd3ŵwR*b}>V O ˍ^zTw&U2vZ:O2WuՖލPPX!V2 D{\Vn SXTj_ oV?:y@Ѱud)D;ֹ/rAEOVm(f51.cVȪ/,]LV~*P2@;(``-h!p$c`0s S$=ڃl!,XVcѻpbcp- xI :*p;4T?t=P[zZ.WvRzB9AśCxyKEp}ҪzM!=6}NDĆlĠ%dM/wػ"QpRX&3.x$1t ÜpUQͤ_(:5D}|'=tM4/>[0C\@BSTH$aIDQݙ /kp %MUD;sē-[e/K`h)dIڒ)@\!9hg1xCQDa;|H3 Ԛ문M |j_Xԟ{!O;dQ ~0Wn>Q7:b0 ?Vq Z~nPmWƪ̻TsAqH/c--{%qᰟH;ηqӕo}j~yrG >O8ߪPX1O@qK ( ]Zrw0T.p-EK4Lsu0^jhNc@T]FxFQxk)vtN`kYy^hѝO`'cnF()jxC+شTOc _-iu() k^eD5oQ.au^dл?h9-D [Ѡ|b.-P}M :vN FLeф®qo^D+!.[> `bŻXOSOU>+"Txm=XJɛZw^&:TX7_Ʌv$9QS6~[hk[.~Əwha`>zՖ5ȬurtBFUs#VPPM?c_1W!;ގة,U~涌 K\k_ORHl<7"sUWZk}TbW!nME c G, 5n9h٠8R7t_+HX;|}݋qDڦ և(&ں'hԫ"Wg ptTɆѡp" %p{ ԪamC`7pR[ Sl(R^T jTV+Cc"cZ ZO'ܧy1Cs_=c\<+5v4'h$YG e OheWyƄĜ4𨲍0E4A1~ڃ~\W)b٦ ,.T3`yӱ=pVUOl2zt7Csn񧖪lh(q~T?b0Sr@^LJnV@ۚ(4 s%%H蚤xĔ6qiV[Xk~M¾3:@ .X gŲ@7Ky<[@8#kl?ce"ƌˮJab{\Gݧ M;耇|{Tz$uZb/A>w4eCGTd\OdϺ7ЉSK',g\FG|a;f IBYs{/#=rGoEwu$gg5Ag'W챗TI6 j!BC )\qGJyij |ݰ< ``4m˿5)x4f8WʼRb$H-S]4?]quPgQPjFqg ǡI&:\䷛?X诫|͐tmLJ5W8?& g%xbL5uMbdGёٺĐ!l-@*'W XZ3JGu|6BL *#z]2/ $%hpd.7b.>Ҵ,(H'RXULէ g* )i$9{b|C4V9(EVq z1ՅΣL qOtrG;E=ƒ8=zw:Z~2 nPEn%.Q>7g= `i<5-pm5 "1 >rXGi]oѢqit CQS4|!q4Ť(1ٯ3R],|>;\nb xǩ7+ʜL^=Ҭu|rpЙȇwLѱx?Y䃩ukI 2ր-qECj 0 AE)X9ልV8 m+\E4K*u"\P-VF4.4#.R6Zl 2IM#c7dP)c8hV4p+;&\Iė-jeꌓߴ[UFA.ʵ8[(E֘:Y\x"%\sPVݸ\ҜlBIz{u4sUhbӊ]쵎𜊰8cT4AC{t_ͩ}t)W q`O#1Gua(e KA>f'8eǨ(eW7xt$엡|cǖ0^SB]yL^ARH 󾰓aJ?Asc4z]ЩmIbn$}%wq`<YhqI1? L׀=,<'&Gt᷈}Soy aş$)@7&wFR:|M=QZѴڸyO[{^wI2m]Z[pZ U\i?EױsRs`-f#^S$0J:_Y@ xe7T0+xj "}z_j̩w kP ߀ `q +_TŴ\^ "/Ox*%F˴(Hkkv;*pǝrʲRo ڀw=d IePQ̴ʹ -N6s:`L r4>37Q{ǓB4_=.h#B("W|3n:LW`VO1 `T"IN;/bzL`fQߍ/xZmHP}G SŤgu/A{0?o{[ClsKfQ|W_c mo9kϠ; p,3ӵXp|M>^Na pw<~'.+h=`*>lWo#,Ww>iSyu9 19_ˣ/wL)|9%`n4yLCF[7"CF_.~ő@[-G7iVu[V40k7"Bg9,ĬO;9_y A*=Ŝ'>f|[U=Лpc&p?GY):ܵ\,O}t`3 "0&JS< v$nq\FӭZ u .H pfJsݦ6?N G?ݍB'dVpҤ72 upk r ~#򎥍^>Zh&/sꜶc4 StRscnC& yZx0 ZIm.6e¡` =%c/oZakv (@o}ZA/!+X{j:;ZgwnvCih_fƹ'ڽU-87HW%P H@‘1Ŷ8hu+)z|Cwh'R8HQSQ1g\ M|#41ڱ!8NO{j֠D|, 12uoiE KHEfO6TJL ۍB>AE8jTSJZw^C\t]lʦ)rpS,q\4D1ց7pT"ys\XHA(37+m{JeksD@?6x71 h*8E {VB8P( UsZY)ʯ_u@ՕưWCox#P"Z(chsMf,V;!L@w[ƬnCce%a~] skl׏xpuG4L8;׽J#uwf͇rx9U3].;UIG<76xdqTR[hQjKV>8slnsj_$#}D7W)HnC53Hк ]ж@T=m=fC# ([S" >>J-tB%#5x (Yz*|{BZ ؍?9'9|kmv$?v3ΐ ,9@ ձo9)Dp$$֞ OV)'3yA"uV\=*? -"v?.0S/>I[IUî߶jpʺ1Żc_E(<dSڂ0/Q.^SlYw"v ~.$;K@30Bq^MT7(Nc1Ӕ`S\jmHQ(z,W>A q)~sXXʟ娟vP'm_qNb m_i'Bmih9w0cG@SXt9o68\IKHeUC#j`j?MNY%aɓ ߬?^E+_+0/rn2҃0>s $O$]:"q*A2Pp pZYo/#5#YaKEg`>|zB\>>dޤP4z+҉>sa$ J8$ayj$pN'Lme9>H_KɆZ Kl9#*r*H4diN] R@YI y,OUprbr{/xÁQga!S2}@\y*!}D*=bu5rՄ,VI2+0||=s'L^] QQʹ5?Ƞ Y#JlBsf}rOWIwU3 0mHӽ XlN Bq ! Pnt~t_%mK~ҡU#Rޭ/zθJp@/b3LTc*)ۅ-7sە`Zl]D"otZq"r~ d&nrepW֣-_jbMeBEKu4SS/,{MTն< q%]@Ka[^.j%ؤ[&AJzu`y`N:Aׂ H'xeِ="OpEL)#0n3%fv\97[ %%M'f gԈ$W!FEjsv2T՟$_"j>p[ڥi8ԇ2Cnkwř!%셼?4<1Bi\Q qKWP"݈LEɭQv$U(/v=%YW#QbrHoaW}b?MyV!/ӫfDT%υмfUxH‚,:<2@$?EnEk*ӄy nqL*mbW)* ku_OU<0u#5bOJC…*wa/j)McBQQb5&ٷ=QrJX_!^Ir ZȦP OGZ3P]YY%H2>呾s¹w9j%UCH E K{,Rʧx 6X$m-xǞ_\Pc{- ;D9Y>͠ˏ;kyrF53Zo"`ZuCxnJe4Fur+YSzzv 6V{tGq^fc;*H6̥?A``_2 S D ݙӥcߥߐВ`; g{_Ҙmu5u@\@ť9ֲ[Xd; 9n _JZզka5byCК2CQrUtpm@8vOhtIT:99ƷH. Js:I' Y:SϠpQH8'д@`5V2"0Hm%3ڴE%uK[&C @^Q)3tsT_t0ň7-k1'sWByHBsRsD2Y'@4) AM@&m.kCW٨{}c59,txU"B)S'a'V|kmɋw jX hA#G75%װ8j \:ez#ZG+ӰsI:s<轎Yb҂[TXd4B3^$uUa7"jwQdqcfY9?+…"> &qtq%f"?sםU^}g.caXCyW b7Z޹2AG dtgmҖ ]tcIKK rvۨ]hy#s^܈JXܜu=4l.R_,&^ma#XP$bnK wVՉ1?ԁRStO%e.#`8;9 K~geV݉ Ił3r'ЈG9̍W)FVJѧE萸y/+"&f>,樺t D:iêBA8*|>Ɣ'Hkp@-옽wA݁e9@o.1ᬑ(b"j26׀sA R)w%6 K D@;iS37f7?!7Ny̒bIHC^6윐ٻ2յ/0ͮ{|H6"io9NXe#Z C)>jˊ^4H)b≒M[:vO;N40k< qpkJC ]33 :"m{&k LQH-6 z+J.J If=T[gu)9֥+$Dp,ȡf)]6]F*+.5X$2kB>=n&;_\mm_WhUiU3+ɫ8ynS;^mZmݞ /,g!9R%Ȍuwߋ&?C.hIY['<~{c5}Qw6yif\.9hjV^35B2ZіQCcL00)CץT|NEg[H+(8R'~ MiR(|jfmcqLav[ner353?=U-J_?1їu MyL\͋"ɎҔyo.LS2~p9H^l^M]&=:D3Dl{6O{4BE4iefr׃*Ns69 SX 8H,*c_@_w]2>MzRDʥ :{ݤc8V))_+.pJ6\:dm ]~T9Ye'-޿8E_ tI3P]*XEp݂x!})aq*z=~[a4^I2N,_ wO\<ۋjkQ&ںG[7̾_Ž@*dy_WN )mu;ʵ7Eq1g"+ZkRE!\!# E1uHj0kvӫ>'xGg(⻮Hn8X-]1U@FqKI)Jdcׇxy͊)kү{I !8ÑYvD漿 $?!nnD ̵ɧL_0hXj3Uk*[vN@ݽ)*Q9v߷ w(uw4mWOI&~PkŶpGNǓD]Ovg[nd?H}㮌z4M^,S4)&:y3] /*i)~ v{0ٽ R߰Y Iخ_HAtћf/^ajj^=lQ3w}jDǏ^VZrt#~0tZEii/WVV֞z*i #l 6jl]vĖ1ż 7*a:{se+q0׶I\y:Iد3빼nިtP$/cڟoEnyo6|*jHTH! `QvؗZRKJ iMmcTuLZ߯gxkV0~ZsNt 9Slh1j.Ϊ"y^nζ՘ϻ9EfHN4ѻ7*3n–I-|;ΨZD~ V8:P03hYdR$k`# V"+phaaeBp ..d3Ή_S7$a,oC"k=ky[ z\6Ya2' cMiSaTlZ:FIپ '6)z.c¦SJS3 e.OpG{3dr{ =ᦖЍ>`~M0z/ctSW;wYcTD=|55&L[.sl&Sx`XLSfoqIx! e+|G:4S66d;蘏>/0?m {Lf-Ud?A-;iy Bc $eiKU8+QOXS9h[ ;ahwhJ^ܳ}7БҩH870v4FE8wUSBV>bhl|U\ݼp2(&^J/)䃼z{Xb<@эGA hpݓ]4_&?0GQz7߬-/;!\;[Okue 3Īc[CRyp܄7֍47F¢\/2_|[BOدEY.'P[ӴeYuҩ}HpאMFy# i)xN-|X+`Dם TVeL+V)[J?t@ȸ S>j QQ~ێ,޽`0w*@DpBmdw޾z.җ":p`"&c)E-o~#Gu0"_"";d*JE ?Hu}a`_M7%*&6TdLABim%FH=N7ܟbrnD~0N}W BH5Ik?ǪP0cx~'p.yխٮ3jay$#VMҩK1UQBmMl QT`\gCX5(25f{ K.dGJU${SS/@D6 R=L;;); 2%5Ij| B72b 2ϳ22ջ)nnCNp bd/P`^ř_* fwql:eg(͎(eA+STrB I['b<Q*؏Yжj`SIcŵ5.D/O0 0ْY0ih/T^b7NW sDN3cp1qpof}&o`݈Ri(iFG^Ίu qUêf. u[0hWZNVB

æb]@lg,h5y#'[f*}n:> -x{DDsrN1;c/~H6QT^ax\kL`MHѧCVȂ(o|koZ-ZC${ vEY =y*1rW-Gd?E>7Q\Ԕſ176ȍv)Pv]Ql3 .d\p+QX‡'I8!Ϥ ~=.0_"^yG<7_l>W`@(xF%!MBƩSh}Bx-FiXKq&yfإ{ }j̿W>LV!rAS[fw}nn:p;5O^džEPm `co:0qdHT}𔧑(IiTLLh}0>!# t$_/r s( Y:Fz8zjeOh}gFOiTYYZ@ڐW}`E@](T8:U=kCG6AQt; ޠ#烻$չ*$*8Ēd3Ѹ:z`1E͞\I9^r4g:f9'c@ZH0<ީQI#2Ltd8\琉?C}b'}|oQWX45jcdb&/KkA!@QHخhB-]ϾT-Ww#S _ _^GB[ U2.D!/A(s ~)Q!8-Ml0-NWpѥtҋH3*SFLBD׾/ONSq~0'] d "b"s6`~#U߶)dO '$ tZcɫj.gFPy6 FQ.8J,(G%4h}%i+&1o7:ݻ__|Wx8b q";b%d&gPNݞ dShȝTv|9ʏ8&Դoj ŝ'TԦJrXh*g3 sʌ?ȦGMoL2[k!%E\v^ժeT)jzS[ ZH*)gc9fX^7"$)8٧H m$yzYJ~Oߴ__&x&4/So 3e 4ҋ>KITߥx: ̬ An%iQ* La^r]j&{lm*<xI 7jS%48FD|Ѯ*^ء X`H2(1|FFk^{jX7}̴{HWwBnn|]bx$H8Y/ ƭKe̱۸sij"H&i36sSF+3vFɹ B?) ȃxXdm|HJ.*;51:rP{Y;R"#||%nȕ$1ՑC//ݵ9JTRUp <|PK ӗv73_NB^$.}~! ˤן '(7 P V 7-nfp65I$^3bsљZN _Nm˚o!eVݠk(:]S⬱Y nX~ӗB!B4hT锩 \vYjH6=6xi9ЋAIڊma' Mo]۷SAQ0W-)/M(%h֞d> gLՐדID{[$uCléJG7۸c#TR\jw)[E7q G 7!Kif*1!bpZ@q vu}ѿ"N`*]9fʘ.ZLI^LUSl.f]MߦT܆]#x.å"ዎo^t@eB]+9NBH(giᗸW~i o—}"*5ll9sqn\Hdh -=۬FuA z pzц0PU4@Cec}Nwd dgJa> ֵc 4;ѯ/=ū+ _b\ .oC2pcA]u /?>s]gZ*a J0 lhowMG5e(tB$ȩ,7_HjJU39(Vܲgf;USE &32'Q$=˯P=a9v0ƒQ\?lWWH?_RDrVhib*P\Rklq!@SYzB1ZczKƮ?IyS}g5ؤT"ԛ!ݹNYeZc{R A,A/^ ODX$ 21"U&%D"qs>OY|FvC5++6zeҰM.a?Fџ4i ykRX'@%8,X2G=l04Tjst Ll0Xd9>_js)SE2p%aB20)FW+h؃n94cfel>;D ^P>%MZV*}S7\未Qu2mX 3jS?T+<2·#&>?ݠݾEaZQs,?0~ [gV6[&Zr';3b0f\>ѕK7#~^$)!xPR}GЁbUq&A u4j삀viN~9 nv;EjM3 :Wm+hg{E0q_Ź!!)~~4V ѝZ ,0nx juiPiC%Rvq\? K3jAwiQLGJh;9Gppm&ד]*[cTN'׎-y$ iGϡ`Aې; ;3Ph6Yԏ&oS^NPtvq_\FC``mHAPx4($1ņ20cEDGVghkX./K o|?kFtPl7!rc-:R'C/ܲL HJZ"Bv 1AfEߦڣ1&_?n5_}4oOR6)fts7"ZJ掁/x+5'U6uk}>< cwTo`֜>h븨K 7imi{8^5;KEtzt*%g-(VK# 3KGxg7Ⱚye'= gV"7ǣNx;>wHj9V~s/QcX o0M:jKE0/uҡ%~(YRϏK/$6 ͒*cF,{ PNpR] ?[1.2+fP_Z Jpm_j6'+բ}8l\nWkV!yj~v7S+)Sg+6WXlD1BfŽֺ8JN{i\~?,.y3%9BS\EOħT2h]qN'&KYwpFx+7QO:߿uMbOsoMR@M>05<^f  ۃDY=>^ICq?&b8_8`6^cky~e}dsȐHjdkB?s߾3I# ӑLql?7ޯgyqIqP06^pq;1x"-y*UƁ^Du1 u{oﰭ6յ~d#d8 cޙ1 (B)K_k9$˱^Ω軒ȧVl.*C AWjAyi*W C?sܪ9izv$M?"-g#HFW*5ԣp_4L؋" 8;) CA7Z0?-N֯TUHv W2Xz14`@[U͵7LC^`xA5X]"Qǎ{'ly޵iY4δTxvxk)&E2 !@獢?`X֎-áhBMj75%X媮ۊ$B:Fl 6li CϊGzY,V-M(pf5YnAQU uzokcޏR+G|-`iS@^MP~EeX6KOػxNEGZ'ی3X)Sz!H ܳKF;y GRӉNpyeԅJO!TFB^FoJ)O O@_1.%F0|\K7 \ɱ:|ٲb Y])! ¹Z'rYxWکLf-ÑKwHj (HӠ$%D K1p$畵ޠ㺲#S@2`m՚L晣T\ˈ.} @MTq'UK=bx| W00A>e}llu-t|NVccH6uhũ{6)%MI3Uv`i8.jp|88@N Ua9@6 Ih3㢪^6x%h#w )ϡBѴDmFHG4a\74L%m0a9|s3 "8UxNu, E ͥ /IRuGaS]ً^9|Hmb? j;i;atr(*A,¢ާO_YD)զ/upbDiTZoodSdӊg 4(7Aq)]6&y U7W 8DMu)eKḎZrU_wݪYLQzݕ!H^C&3ks%iO0Jג*ƠdZ }P;^eD 5G 8Qx;Y@8xV0v2U\sGdFZw'D3߈"`-G󙒢;KS3xr:Rk~bĶ5ۧ\&BvU+nU\ϛG$e1$M*s6hE??FhW7$3p~%g2<%Ut\} C.iDBe9/{u[U(mR1vѩo6%W\4@C4bcp\,#)bKCfMqز?ת`gt(ZքS7YȂxG""4'+dZvAA|fMU|H?X¢%Tԩ_V.堁 qx[ tk1Qhj4/gֆJ6J޺{]h%`H+74]S#Qp}s>ײ8e>UaՆ_W WSzNR%;<.2괧;ܾޏ9GD]0?s6}ZtH۫l?N )?K"]˕ͧ(z j+HlTdDܩ㗋WhNgCk®tH:ltIJqvD굿ZC^XW8@S|@2\*D~+MxQ.}YٟcҺN—f:EoMLyreԞ H[1A֢}9%|=#UȃѸSI;km7:%_/#0ttfx7m_m<+ۂwonWM{ -[& .X4T?*USQ'*zeo1f*^O|]~>xA47F͒qŇV2lEuCSTa+Y' '`erTsz3}~t^t8{#Ll6|h\iEke"c )2"UN"v cK0m`eybep8fx1vhG:3i/H5Fu #9 c! :jv]e!ШSnF4Y`iȳ<}d,X`+&H%+Ok2˳~C<oԻɴHU1&#Rٳڞn~8^$cyՑ[pdĔW-$|ÍA}< =]U9 8bd7va4rO9jjZ1 *; Ը5@BPe;4E0?C)9*ůT|}å_Gi vn,bpF,Z/F Om69^,jP4p^EK MVVDZSyXz볯FR  ÍZ n?`oՖzkd DkrӻP!TL(Z`: b\s[pGSvuVLAm"lj}yqw 6i^s|~+aSOjBd^Tڣ|5`K j&Qd0 J-/>i+ۢ: Z6$x26ޠ6֣%䳸mT, 7Trm&UBx$_pPvf(>n嶶 Ei" ephQ`/ ïsXNK!Ψ+v K([yVrb*=) 2&\kUGRʔ@K^3OMn٢S%{oMCeg^`toj kdawNtX# l`a\`wʌaґ }jTHk,{4BI,x9:PYD 'C%6Z :ԭ4i a]u_d֐:$  f޵oBEJ3 7EJasu[/ ڬw[R=;EPnjJ<8_V|Ӗcw#> |FS"XܐJp9sbABgjP;p<04%4~y00.]υa獵s[M?v{H%}m-/"XhM $[-@E5jh=Ҹn;vpLw,rR  eWo?M&v}QճDQ2rЌQ1r*( D_kؚ䩟x0`Y;B!.#5"zy{όeR)L.tg!Y|]v/{\屶KҴ"MJ[M1f+P:+G쓻h{1w-=z+pePF$0xz&nj{j j"M(h̪eSc'~4 Iydlv\ dt:0khGSƍZCuN%V15p;J5U\Z Z 'fNhN!'So2w"&uDZ90ٔ2b˃ )Nqwb5+{uT&'ī/lNdž<ak|l)˹8].%>._0{I,nO78[+\gV"g_h:,ưob> ktt 7-N_L< `53xӝǁQl6]t4QH|Xp&-p$ h4[tu/ܫX2Q4H-q Pݎ+N ;VT\CJlX4aZ'E)IGnO+IC{ѩve_pHbzQe򌶆x S2c9({Q0׿qpĬ\֌dkepE; k}I&]6_)4A2Z>;S )*3VBaXT|<t$:ꩁ|F*<ь ʘ{,l?$EOk̡֫#il HZAo0&_K^G^[n_e o!?p̙>p0؜ðO R"!HV_ET.+Q-srj̸0YK7"``IIJ{IT R= |b}%eֲ`'6n"4IR6i>c?porRŘ-/7SQ0>:. 37q H*g{h &fDV4дѾNzӹh(¾MM #%G֯VN// r@@diKJ)ز0uY ($mO s՟G&)T"LWXˆdVgZfkGr`J$Aibo@ yb{BڛNuGl,Aɓ`] ߵoCLdFZTP |-VD]  OQ5bD$}LCw,=';wƃ!(Au0Rs%JWxda@TgJ 8Zݐjx͠և_@ֿ8fTlGa}sRAUa7'"S@?gj-I[~\[O4\3dPMy ȶ\lq["̰VRcV߼FɨG[/]zs L=G \\Xz>_?DFw?"OB#`D ,}Ъivc{Y\]"Uz6n]%mI', h Gߦ2k6&i[q6I#$Jf,} \W/֋)\,WaJt'?#9\U^ObCեwe8*&9my[4MR2?te wgpWC&a^"PFW^gdPz8YWwu%갑*A&AFc!D4:cW=ۡ"Hpiiʆo2exI^izcx0:T%PS9$1C cvg-%Ӗ$s$ӫi1>hd3Y.{!nsb[a.$6T!߉^KKۯVa&kceOGL-L 9晍P V>iQ׮#JpWQ_Hf`k`_ٺeS̝Wg1dݪdA#N1ܨS F~J4T$8=-sIKERU[VzybaˆVܕ&G Bqrݴm<| ݙ7Sᦢ1Y0%fP)|prBk"mF G>&I^ڃSoa8O`w9K&SIv~Jlt%Q|gFމNK ]M]cA_~ʹKN#ڨoG:6u!ROC+a0Sasqx8EAQ[K[[UUJ<i"K Э|Q!YeޯA*(zS# ouhHza+;1H$9*hܔ<*lV.#kf1DԨ7gc% NMoFP5i<>'K S-L|͆U8G \؍5K{xKMVT%#9I0l&Xb߯ r]aKQhUs0 sF @E?IMROnZD^ͫm"HgE%v&#oSl*UgF\"T8򜃷{b񯮊<|59: 6"6wK`AO04fe[{bZL$z+bqq6E KRpóGXIW)%PJ}:j7p1?ݷ+mM%d…R@\hcʏcuY+``ޯH^H;[MFIg~ĺMNT2!F障n'Ăr|B̙I(#67XԳeSwzYUsOt YS\uCsٔߎG=VNSM,~OۭtNW;V`aϾyQhJ;4XF-  ĞSDML7āBVgdXxOiߜ-XV H"ua. (Z4U* !cTٞ7\JXRt-{Ԋq0kWiܦ3)HP{B'jQN {I 1ɶ`ebw&O_|6 q m9UkX'EybM=d=dl*P,ϫ0J_s1"~Ӕv'+j S$ؓ7`} b  QȬ,t,@K[)t'(q U꡸a:3Gm>DxR: &?Q?Dh5 [gY}$A Y=J8JdԚ][;:m5^q `kd@_]t?}*`ߴE%5h!N\Qν9I,4f$UZPE:Oj I:̀#xd$wBYλϳSRJ0dWkyM !@>\׆ (ǘ\0Lb.8CLW'U`v#hm1k5?KփG߮sи Ii~],Rnn,&(GQoLg>T+pr(d3sFpC(:`.ꛛ|ۉ)y+=e.hJ:\{wM~X׵kՁ':u g$7sV͇Sc$`%coob ѳ3HQf6 OV=(,hf2Tr&C/T"ʳ