tomcat-docs-webapp-9.0.85-150200.60.1<>,$He) p9|?ƗuVS?ڭ~< @0֧ 6 Frݾ/E+&StMb툚lUEhXm'GMVU2.b'sK aH-v}гhZ{2~}`CtD%] U蝉`W):TekAB_-$;Mec~v}U!1IB=F0"Ƃ!08M~4#Pйx(DO\!7/s%n>=?d ( U #=CJ|     . /2,5t88;;;@l:F>l>ݝFݥGݼH\IXY\]\^bicdefluvPz$48>Ctomcat-docs-webapp9.0.85150200.60.1The "docs" web application for Apache TomcatThe documentation of web application for Apache Tomcat.e) h01-ch2c4SUSE 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 fiOS@yA@l5 8I@lH L>i*   x_!T 3/+T- l+HļQ%rZUN042A8)0.8|&:QfJF)"-"&HN%#UZ$GFPy48/m PR`YURdXLSXRs+:=\ }Tz\#'&+*o~1FX R ZBM R p B N'2'Qd2A큤A큤AA큤A큤A큤A큤A큤A큤AA큤AA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(e(280889f5bf5f053ac46ee93850b25fe826e14c8a48725ab1220793e0637c44dd539ad0b2450e83e306f9e54b4a40c00aee470cbda377451026345655e1a1033e4d55ca6d6f6043073c37c3e681752de9a6431a4e1227a90c6e96494a462513e24da999e0db4e50e944915188b1ed4bbd4b3f843768bb27340ea28e80b9db8f4418ae0f6852f87a9f6a9720b19ed633a67d38caf7dfaea2fcd0ff2f1c7efc75763fdc9027fcf3d363d3e563da8a3dc0d514a957021cf72f389040a97ffc5dad04947e7d1e43d547c9241a5fe2ecdcd74d9834659035aea7271041de2bae712431f40071254ce811e75e90b4416c834d0b6da2f7e6d9804322a9f55c1660563a0ab191581414009ac8efb486df8aed81ab9828ef4eaab4e826c49230241f73889bff7fdb1c70875875216ee3a18630a52140eab628d9cce7bcd7f69f56b5e4d0944c626dc41745d3a38847a533f3378ce64f4b64116d2e7557472b79168d235056c1e57d076cf42000e7c8dc0127ff417b134f8236563fbd0c81be9d5b0d47d568b6b0168f8c88825f5adf85578b6e94d20a4322fb1b8ef37ab1f5c6f54cff37091f85c90926a6450ca828af5fa4c96f290d921667a3dedabb37abd3246f2c270be44f080241bd6f83621d431ec24eef72eb107db69393867f091be5bc16d63729ff7fdb1c70875875216ee3a18630a52140eab628d9cce7bcd7f69f56b5e4d09477f84b68ac01984d8566203b324eae905f1883f5dcffd6d8c7a6342a76547458d4825ba7885174a0632cf2a30c124a3900cea0f044a3e1b42550658cefee7ce491c5d006427e6b15a0abb444afd59c50e4a943b0422b01a566c636b62fc20067db1562deabb7b81f1f0f52882bbeaf1332f7c20bca3f771233cbf9db4226d9a57b8134b028f5b8c206e18075b05790d27cc29c431bb9575033b37319751036f8dc5d18af5aebf5ad183db10b5d17d0caabb65a1b5371af6d4c2e1160c16649d6d9fdacbd36cf39f746e789faee0d09e629b6051395bae804fc88d309fdc8d50df77e32bdf6b6e5b8908c765decca84a9c3626b9fb2df9cf266205fbdc6e3308764924c65f06bbed78297991638d5c7e20274427a75727623bfb2516cf0028bb683c5467f7e6af13dc7c8e5dbb03c32f9a25694c35aca145895e42562430a8b43266eb58279e7ad936e8465100a7ab156775c7832c53a43dba90d3afb02f6c52f784fbeea34d60cfee13a51ccc2baa8f5717dbeeaef469a331a00cddfb9d70a3b5781868c44cdb6398eeae92566c51140e0bc783d53181fec0afadc750e9dbea6db692e24785f79099a558d554c83ca452afbf731dbe3f1d8d8e3d9a6136cf571a1f77a86b92cc872ba86a4ac538720debe5a075f56cf6ede6a52c1b1ec91b741574fc8a8f43344709f244f2877fa01151a5061772c06eb8dda6820351cb295f3ba2f4c6806ed4a3e2ca487b25b66d6cdb3f7869a9c724950c2c8a8b9ed1e2b03558e9400ae513fce8ea9ec4afaec9ead16c9ae918b5c8e8b5d4ead351f7c5fae60a5010fac77bfd70683a1e57f7c06f6415aa0ab2b3cf8984e5397a892f18ecb8492d5a6a46b9a9ae6291e5b8b93bfd2519186b49a6a8d58a26466b763384c24e14600992030af0c81ebbb0def659bee9b42215769b8f0d3341c4bb285a000e8cef2d0e5c5014dfb83e42e289edca0d049177b09d08b704e196341cd670fd60e1377451faafb8908a6faf7618b644d4bd38bab90bd93225f0cbaf3675e341555f1d0ecdd3370157df3d239b87ed96dc10ed2cc1ab53c3f807251ab96b919038fc1a482a1a5935a26a904331c5f4c4b1fc75255365cc992f0a6c6ff54b0e0d850e4a6e546985a8668c1e34b56f4f1734201c7a230dbad5e21fc470a1cb5e97d74edf2ac8fa524b8feb6cbd8285b7c9f700614e44338860f7c3abd668600581777b24fa8d01ea14779c519d653bc8cd1f0f00d74c668b986b6de250a686456932340bb774313bf7f5962d896b23d2782624d7f47c99a1702b7276bb052476c3f9694a21393a0fe6ef495235fe5ce759f5b441160783131465de68bb106d89bb13cdf58f0a415cfe238edbaa0ebd7e0dc47b375280534d4f5c53f6fad938fe5b46c57e7fc51f7940d82a668c730ee00e1ef4c6492245a85c180f54d7f465e488cab9b8aa1605f2d6ede0b9bafbdbfa83ba1c4ee0486c5f75176d8925d71ee5c86cf231953f75899017d18b779308e5b3c36916ee4623ee62bac486b322dc4d41a17242f8bf369f721e5b545d6aebff03b973d0a81e41c34819c07dfa52034d320416c109563450d94a1e6a843cd4d2d5f5752f11b7c88024f88aa216edb79a91aef515b501eb7036eb8ebb614f930d15b1e25b8af760ef26f0b09d77923c585224c30f4e847fb9c8cdd76981a652aaf1401d8daf15e921158c3cc1bd55754a7df586ef1e0d9c3fd40b3ef1fc6d9e1fc070db676a6491375e8bb502e12b28f97f708df0b46aa52a68c7d17987016a6ee9ab8801cb0470324b354725e9440d90fc2d0399605cfa8bb86bcabf59191cdd8131a91004471b3745173bbd8bbb496a1724b6e87d7ed7081a7b7caebb77656ad54526826b2e88faa98e69ba0d34e0a9fa056f719d86d07126f3cd68a855c2208ee8ebedf1ba3270c5abc9ec0d68bae6a99956aa587038f203dd345b3c1ff7bdc98932ba4881e7c71d6cfdcd571d82523796fb01b59e707d1628a7e7914280e320f3b4ff7c4e3bf42435c7004dc37f99f0f4c56a356154381f8c6302ed827d8c41dacec3018fc3a83744ed87bc5ef4ed22068817053c113fafb8dd16dad67852518d5b39c3bfe5905be731d3f733a74dc17650e756ef6544cc261546fce07b05ae23d165a1b8c3fdbe3d71ebef319850d68e32464c249669b5a557eb3338fa7f17e583a67e4b76cf2cc9c06a1fe7f05e4a3d051936401d502b6842d4a6d95ab2869c5199d41f68f89889d8bac9176293cb90f6788146cff11a6facfe2e1e9fa6c447e4694e2042e68dfabb2491ebcfab262b62e832ebdd143dfd380215a26d78fa96ed5f2d75fdb1141b4e2e7cfcd3dc0c822d7c9013e57cbde9977526b48b954675402faab770821f86118b47b4e9937e4d53998f21ba6228502ea7247c934d9d8a80ba594b3121d9abc99cd9bf66b5e8d125461089e2b012e7d6e7609e2a659bec08cfd7af166d004af796438e2642aeec7c0baa866242568c11613afdf69fc4162c37083fddc688b850d14ec940016c735047100fe3e7015ec06ec24df6215d98fcc174d865fa8f0826da5ad3484e519e23a18dd42734b4d49d11da5f3fcf4118bbf65295415715d0d2c9dfa6ff38617460c98d78778c40e13b8b3dcb1240dcf732a3b8bd47afcdc060d104a38c8393578f630656fd29d2581a6ee6ace10b6217d20f56bbec7d836331b1e553c0103e2539ea8bd495591088adc7385a75c66455eb1034b4f35f65d8bc2d94dd9a9c473b458f797d13a16568d6aba2db91cf7804c29f1ecbed467cd9787c89d6dd6d4e9cea42d6437d226d0111ff75d98efed05937417f90d9a3e308257381d1a95163f27529e4522c3fdfa0f05d3bb94c3b28924ed35badc8dc7402e771376ad3786c483d134d309a58190e19474aa3e14aece340e7a35a86d9cff2ac49c3feb46e6003ad7b1520744e01edc10febdfb2e751474aa2cbe5c2b07334a97b11103112462b38b0cd100a3b6079a735cfa125beabac45635f96f9c5426a6b6f11be03d9aa3bcbc7152593e116bae830bc9faa3c170d03d7bc9df2845b09a79f4a005091783cb59ba82b2acef429d3cdc21de68a6391c5612eee7970099d473b01d3a310696387753638b2a528f0ef4a2b8850a4ecf8af7f32e650989f8da506ac7d724078a74a7fd1451cf919e7466d378a3096021a792bf37fe7879898c1a286e80d122f54bd52112c36fa422d381aec5ffb57c31912b60ca0e47b56634beaae1a4eb8c826f1329a1d49820814f018ba95a5b2ae5c8e349d57c6663aa87559d4b6c86b1b6a0cac0dba2ac0d6abdb2d037f07499a84df7f9a949e5e76a4d89dd3913b96e3ec691568f1581537f57b4e62863524bd1511017e7f252f23ac6c125160c39b14a2a0410d16b47d3901eee99d0090e19fdb28ab78e3fff49f571c5ece6cca5eaa4ca9bff421ce09b2021f4e4bc64a8264732de30b162cb05943d9b2e92bf27138de083e056ba73609403a3ef0ac82395a4fccae251ecef1878c569a3a5ee2f4e94f2b56e19054224482be0aa7b444ab8324ed0b0c25e3abacbd87be29732356c9bb890556675373ea9ed1d0e9b5678426d69296b6801c906ca378bb426aa3d6acdc3ba392abf7aa1d006749331fa8e97ac2202596a819dd382b46d051a28dca74875a851d97fcc71c78ca279754fabc2289a600aabecec4d9e4387cab9c7400aa2d0868a21c493df0e5da1622b319e915303b1aa2b72f3cb836057eed5699f522693cd0e6f9fbe497b6a0346fde3934cbcbd7c557a334c27bb34e69c7ed430ed4a4588c27f2a933b428f5a13403157e395a9d869d176c8dd256a5f28a042e4f863b42117f27a13e776a0e6ee6d54739b08b35741f43f5776bf51a193810b51d60285dc5d18af5aebf5ad183db10b5d17d0caabb65a1b5371af6d4c2e1160c16649d65d4dbfc82ee715a653291fb987dd565b6fc567ffee828d9e4c5f181c75eca0be63b93e248018e9520b508c50c9f61fb190bb7ed7c057598111baf79d07c3ad14afe0dcfca292a0fae8bce08a48c14d3e59c9d82c6052ab6d48a22ecc6c48f27793e4c441a0102436ad4bfeeca5f572a5530bc6aa9cdc9cd45506fd43728f9b101d6bc70bb8c8dfad14bc46b91c113c8496fee24401e0ec06649a85ae2fb66c58a0a6381b4f1fc34c4d51347cd66fb6bfe8dc6a62fae4c9d767e79e700c7f8061946c15c016ada6c6a3a5f766a91bf8a27f7aedf01b70070dd8da60b53ae4fba43d32a30b6077c9c3f1a13776ccffa64905955cb81ca8abf5b81c5fa91127f6a01449088d449f9ba4099eb830e488d7903370dff0e126b6574c5b376e4f1bab9e754c9ccd7f23b26e723bc3724878d4d135d3b1d1d42d9a08eefbd557bd4dab1d76950a94d43ffee2e85c43dc121d152f50b39156c12aae4feaa9211e29f0756997b21dafb80915a8e6045c217121efb838dd25cc1fc0f82ff5a4acf5cec2b3ee2f4fec247e1275978cc158d6bad2a4dd39a12bb01551ae2ed94adde760cb11e6da70ece6fe85d8b536e27ec4d336bc1770bc9bab78931f01bf0be2c6505f00c551f50b99f62a67d144a12df61bc06b54cbefae696ef1c394843d650ad9dff4dd5ddbd3c1ac87bcf2df87bc93c0dd903a2467ced795dcd5c0d746f5c133a8123e6299a9343916778dfab2d9d192eb9b9b937457a0ce0ec98d414b342fb9ca08a59c2dc2462bd65edafcd39b62ac1096511116bbe5f96342ad7cc3c639ee4af787356504b5100e24f8d35a5feb82a00c46a079fdb7998abe923fcf6b2d6f3219bceb19d146adb7047a5c082e7f48281cf0b03e053952303feca2e696547b22f7284f25976c7453c01904aa0955b4bab6b297b8e1e53a9b32f62720782519ced31313d1c12c5167454de600aabeeb574c97334891a11324f82f0fe60754504e5ac96458316305365d75524ee414588f9bd52eedc4895db85dd87a80335712e3b3f1668ff0d8a66dbe8c8a60de98258080dbd3fd9acdf0f15119ad33e4fba4f24ed092d16e059a8b3eab462cd3a71ecdeac26542d7e865144d85fadbccbaaeb8b15e374205acd092ac32c41f5a34bbc5ffbdbf28bbaeba4ae959ee0e231f2f80b2c355223246073a57e87e3ff2679a1c594d8c9b53be9dbd55da822dbf4146de568e61a4d5d578ad9a4d0d305fafb79faa8ab931a8dcf6bc048af79b0c6e392071c2891da6378fa33d5363f8193e25f013a4f316a12da9cf1719b9f3ac0e12a5d53008bfa0a7d1551e5827f07fe456bce24a8de067abbd436e7ce261696541c7645172a21332c5d1350bd0c4c488a93bf85835eecee4620d420f7c2c42bf49351135db9890bb9feec6c57f0f6b47259cb9f15ff669ce6bb1ef474c25df0c552b7fdb1a3718059cdf6713428eb88772cd4a84aa847ee358b980959fc884adc86a6408dffd91bc449c6b6a02a91fef09086934b98a180979ef19458c22dec95910e777383821c6fc6f8f66a29e9b2dab7e7962fd553e181ec6f3a855d4558cbf12232628f0cf723792cf92f54d63e883464539c7e3ee080b8d3457ac3662a39dab6e867404ffc3dea4290fe66178e407fe8176a045aca8e5b666a8c42b66f5e61fd0fd5f6c004af0917da4d13cc1621d7fba178325761d1aad841174683fd5e80052b0113b9899387ad26e1d61474bc4fc37528bff0c3c3444204fb690ce92c2043cf7rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroottomcat-9.0.85-150200.60.1.src.rpmtomcat-docs-webapp     /bin/shlibxslt-toolsrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)tomcat3.0.4-14.6.0-14.0.4-14.0-15.2-19.0.85-150200.60.14.14.1eП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и@fstrba@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- 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-ch2c 1708337420  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{$}~9.0.85-150200.60.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:32640/SUSE_SLE-15-SP2_Update/83fa4d4efe8f79c779bd08029bd5d910-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_UJ ~#\xGutf-8858af98bc46f0ec14f8004476bec92b59283b3b393855ee359d3bbcb6e174011?07zXZ !t/]"k%a3 Ț~>o~NbEܠ= a,   oq2kUkdF EBfRu.yX vi+N1־)̑:.V\CB0vzCE+-wIvqp5ftt !l%ӠVn>xq\\ zO8C\Ew+ } HVPK7n1KmqK!'MNdrlC^&~6!øxIN.( n7Ysc\;@*<8"kޏ^l_9+e7B1U}ڙu?)Z=A(OHl[*>HFio1bn?$x77Ic@fvjC$$I&겖t5Nm fӮ85T&?\g`wݬNTq?|[sDƊW'يP6 @:sKUY!{鬲VyV'JꂥA Kv^d=1ѫb GyM~|FOҴ_W_ZΰgƂ.Ь@K7uƷjJ>&G(4dRoMkE:%v@Ph Rh}= yd`ъ6nQJ?H LO{vÃ-=J~);MNژx.wqCV$S2k<\]fKSc"|x cy1Ϥ0z筥n˞RcDj/MVK)\ Sߝ b} FecoGeY^`Z&J`^w tS5`A^M AO1]/rƇ_}v$?V Si³}x1ib&p#t0Umc޴Se'.G/j:9䯽VS PDuu|UUmQ,dCs)=,I צdznCHb9xD(&EPvhs%~ H?ǐ/AL&$%GݱP5_yPc$[콟k0[L4?35O|-qG4?1d lj<ۊSL}N(mhR; {G* bw[fb:h 7)I:~zV0 Mmg19=r/![R[xQt,Y y j_Nj IF Ѫ+ UR[,zk-g?̍50)$rDHag:}q61+|9`C U{aʫccJëO\kD*q7d 0J.Kaw<-'vZZJp}e[]Y)x+cҖA]Krlf'9 \ڰWO$q[hEmp%fǽ}yFo9'y|4Љ?% B8 ck{;2b&\(FYHdkBNi9=J0(ISi3\n)dˁS/p ; XWy>g.&KrB/ <׳Cw k~J^Q(M_5=XfH"!C m #_ !GģWTnGfSgBWXt3)#VnbASsVf[)iݼi\K#xÀzoZK=4:?`ś S-b}U Zn2Ft^+!>y4Ú8giJc*AbC(If )X /EdT\p772dGQBO%4D$*_ "]o>s[[H[ZЗƲI[9F_M50 )+- 9g⧮|fJG ݵt@qBxCE?z'f?. `".r4)Y4AU66 )HJnvD] 4!$~VXۉHF#:t͑xAj}3 Q^epy{O]1+\)LjveAPݛ 5\oRGGMs| oB3YA3 Dӌn9fǭGیqY]PKp~?VD}av8W: f,n ̯j 4uY{8H(yW(Q2+w}[L<[Od?'23dDU.W5bWn%{|4@a_L"اk W/RZHxO%zM(6(!j-QO4uX+8LqÝ;FYIvĹwBnLP4*Wi6d?-Gvv.*wksZRJ1F\=1cBB]=`hp %RI,T:̶h%^ gL ^wI hIdkV_0 <jxrgbոYOVZ?cM#PS}vcڛsTM^;Q"NXG $(ԟP|QY<4w*zo0+Fc:adIWb# 'ό1_ށcGK+׈Nk(B\&J[ti̳V#p6 9aZ3ą>~JL|`;I, |F uӎ6f0thkhY9l#^MEM swyA6d8viݹ902(>t#TO)8L !u?3q1bب ڥ5HeY`TU#&<"]s-c6W"laˠ8qsE,7E+tes>f~bܴ209ݯ\5bfۓ/έOMk[g0 zAXci0k04ܞqfxx %oLXoW;űoZ vbA*oߦJ]P9hMhB'PnᬂswrXO-E}HmC84JܝXB=L'{Q3NF !1gfj< !9-Uг+׺?o !W/w4{o,GS Vaj3(\O-q϶OܞXׂ9m#I>jpToO>#OM"<ܹE'nj^ '2gnf{3;@E!:k?6fU `v bب1Bi~DlXk/wzO$>M%5)E%C:G?/2X!ݙ|?锝sTHo+R<g1BEVCڞg9a\;ueob; 7W;J)YtP,׾`/h D`k4XZ-.~U=*$ !:6@}-s;NU* C%"aT.@1|04Z迩gM$ͨSdb$|q0\(y7QݟZL2 9u^ VBEc+&я46= X8Qf֛C+.:ECHQ\ 8}PEIB&RǍCPf۾oĆ* ֐VE[1]*j&e&V\aB 2d1 F{7ňKO"뗻ح2QDP0F}$V(DbzHpa G/olzu @7s=%"j`z7}U09Z'/΄Aqaonokf|Lh[C"cKExѠؤf%"6)_Nɲ;㔜@Axjjͻ?$>Q%.PkFզH~c xdFE&8  <=l2yc#|f3#Wȩ<]ɥsg*q {z3v( _$Se+hC"@k~:K%8sr˪StмjQ;e] Gaz!A8 e-C FVH1]7'+̜7W+J3vt EL\A%w| 팯l^EvL4EgFZ28&og*'Fx)G rY%9o;VgRsYkḛ7S0%uHm4DE(ê:&N{}+[G -ܟ"7 L`f;q0648h(Lp}o^a Q#"̧],G|"Nm۫\rAgk%۝)R-dDvFZQ [/8yV] ^N_y }s[우ړǤޫfb(l7/|>Qk/dPuT?SRj3$Ëak2ފskTiW+t95bTͦkgKsRݹvV'^l ~ݠI_xhork,EiB1صi W1rM{5 3 K?Z'O. t5>8Џ2BAZ?."k%JŤA`KLwofF7-$ <0uW T$#͎O1]ϯZH(d4Q&н\{ՠkCqG6D Pt=F7"Z#ŤMs-6:^#{hָN>.: \OC}+vBfq_~򐙟-XN7S3>b1N,\Nn<^"B`5vp PRй]2kfsJ :CTdj_/,<ݷϿu1"r;YD6]\m!xpp.le#@C,3 RN& EYtjYTf YX'WWHֆSL ۠ءh 4hb\f*쵱ig}k.Fk> &R/`l9Ce6I[تRTuЈwVxPXx.#Awjc4~;aBKC B(;)¼ðJ54` -Ժ>!17Ȱff0 s>rYq8[{Yt`&-FlҡOfdH!9J KPg,0êD0W*ixP-x91c㯬>"LkDϐcf%FJ */Lz'>J%o)v8%v-Jt8H8iKH"/%VBͻoy+fVyލq G 2Y2B< ˊe斈!Fs=/" AG{[:0dMKZjb) m.*S%d_UR6[SH]a!ժ˖Ý+zB[3:Z RaQRX*oe:XSӣSs

\1א!\kŐQy`qeoksE+|$>W1~\%D;?yY{4Dt6 ^]*q[2Q W#T-)t bp1e_XuzýePD^iam[3&po.ȃEdԣ>QRe@ }0zkA]N^<-qacJ!{~ITsWG֧ڱYSsULyDdޭԚ[iH8? >A6Wwɧx*hBViR#mg9<])@7^Tz4 SP^Ԙ 3A|w1,#3P~NF ܀3L_"D)05Ki6:.$3d5B*GY&:>{l῍ SU _3$AgqG.<&!i覛p0fEu՛a,wch!=e6In_Et&rmhwKI`0 `$:43lbh n\p;O]?v@::_TV–XXqìjC]\ &,IV&S1| !8V@BZ?+z@BҪr,iW#%6d> x@z TPUԟO]kߦ$r'0F[+`DdC>x2}gЂ٘J0fF=x#dp`pNJH|Avz ,U?-L j8C>aY7a~irqv*:>}ܢr9u2RxpN/xQz%>\wgGTtXGW<TQV4aXaZ%+d[Fd6"g;<E{A=b?;4:6|>t^Nҙ? o;*kԈZ#Ǿ޴pdSӰh!fWaMϖ 38Hߎ(1qxk/,®d=bV9 w[})8ؼ-p;Tz>…@!%PjMHOeҋD|wZB?࡯TŰ.yq*"x| 7xS,+-cH֍Wc]a(pQzD=X@:"[2܎*e R/t0}սms^QتsK}AWH ߘfE>Z~"ܛF}6[~ 'qLS1.uCevXLJ j)K41I%5s@|3TAA^&$R`2 hnfPUNHqn~ ^$ҍIP|A`N%tmʠp] V­,ROM$u4 |u#P' *u7g̝7b+ŪkO:4`64oa,;5e^S6:fEKװDҰ KвtyEВWӧ5VW qIcn]KLT꓃e닭IϜp&7,r/ر]7FHI=X@i!&-7[VI}GGлA6Yq߲K<'B6p)Le\\!hֺBQS,qdH*,SAћPއw%Ip|{dv]|Q9%j ?=ON'}66-"T NBIYú+KI'35fߧ$uA[۰ŧv-Y`5Y*M?oFҒ"[k%n]u~Tf(: f{|dS_ 2Z$')5/f**k7w1L.ѯfZ*h'Y-r-ǍaG;Oү öj@!z屼T%D(:+ʵɉ^Kxy#LW蓎)XІdU#G(bK QZ{IYVZ>W 61?W(6i"tUDNJ%WL8"@^OĻqZyQ%sJDR?^-ﰻ 0^m@7ߥ>t< [AhZz{b}0RRo dzPMxB^l'~fUN9/,BmT@Հ8o}Od imgh?RB9Mi J`ٖtPLC^deMw(QP¡?'qrb4B\}{0gڿ0ov\/%Q I+ Xpxq=dJ_3>=gg*n7Mv" ~''pm=l!L Itݏ9idAm>FûQY̼"kO/Vf P?#0sY0D|t09 ASr+5c*j~V#ofW -%n{ ' c3@}_3d_0 9Ƽh \\ɗVbk0S]=Wrg>dHe1F-Xp+|;I"ހ)8|ǵba;EGdF+K]k>y9.g=C#0Ӕ0 Oc.etE '\ g4Y)@_NсȤP Ҹxg}TB@+oY߈U#o7NX_ql5c"Xw s/0&֡ѕX#k9u{GRPqA/C"I 3Qh&NJimi=X{Q C6tArRj6rd$jQ fF`f% t tUZxĽpt|4!W6-x3k K4\d8|hй6`FY5TF:C| AwD=$\qXQvB@qpR!7-:@!C?;mXgzBlSj _VJ;SgoҋQ fnv[(;gav^ XY >taFRMG,3>.j#Czk[ 3Ŵi|Y|3m v׆cZw GWo.,{]L&7T+Ik$n.y͎?]0H?="dWvX%of2+v1 @>pٜv ⽸ $(ɵG+RВR 򺪘VdW(Z+#[i]w/Cg >+NM?:G#YZFO=oQ$JK6.^٣ 29L6)WTci(V Ǵ>%ssf]^ap|la.pQa~!z/ļ؞ʅ?arﴖa$z$|{ڍp,$xCIdJ*MS`zoħZKkz*<LΗͳ8*c"~7TuB >چ$չ5D |p1J*Qi1[K _@R㣻jz8YyS}kՐϣj޽ ?'$c} Y-fZLCTOC: (%ƣkl\*Р=Nmu.@2ל=g:[ğl7mA|H~T .1c-2jϵy =[ V9ˁ?vL[PhaPcm A RfӗyE=L^BrOaKF̳́4of݊V 1ަ I`<-hn!tQ ꬦߐ u;Z4k4T'aXQIiJ5x"_dA>~͎1E1ji'JH{jTrwȢǩՄ!~0 5|dRB-٦y=p s,b?z([A9 /ceŐx TU^kﵕN.qCF+&r}ʔUV4GuRVye&ůP _:rВؾ(|w Uc_ ?/ƣi9 Ŷm r]L';7Tӭ5^"$NoD)*)#mWЈ<ڵ 7MJ<,:V2HM]Da' ,M_ K,NRD ?g%z{ŴrS:C-ǽY7^/ĨC}TQOA0emQ0CpCSˏhzG]MeJ0[doD8Rl&WIn_j?Q^,LZi\(Q3m7whDǢdCM[:h~bܞ-s_,#B߫'9҈*+9\KWŗ 3n[2x6)O=:*]cHJNjŴE9<''I=v VFu ron^{M:Чpc^O_ |t {./s@$OmC%fZC Yp}lNCuRceNMLC')QPgo" ~i~uǡm O.%IVbf0NlB&o|-DSˢn-hkOF)ٓ<9PM #2:3=-lFMv {R L5>"eZvAwP QQR|G1\FO?`KL8v sJb>`7+5:%)oq7A`v+ڞYT^%s*n~WTLժ=ih[_DR`Wv{.*W:[dxJ`=!Rw>avfVfÅmnuܮ׼-|MQ>s0pN|r/hzIڙ[ ~#߉`Tr8pI(Lt,`oMv܀;x#6,h%'t=fW(be!7:Cu L )r`5'hD%+3RR<^2.0N[_!LS7F`pH:lYlPKcE 5W޸lzƪ,CoD=Էy=,-"Aхg~ h KH%K xk7*?líPUVn 뢏[$<鸺T0%| XdIz%F4K.SuK$j(](;K qY]*o"9*|.3?i{G & ^Z=ptl譞mbD P!4<tzL"doR[TKWo:o>ai#Yj!Օ!ul L|sLvWymJE99J/{`NJwotMR4@أ膆ei(P&g%&\wk~LHa>dtlw"955/\ujJVךZhA:SX :͒;IH ǩ1WBFC\mj%H=[^\pP0Ww6Pb\5W3iOvI"b_(ċqfI-2jbk¼9|8Ď_3K > =xo@1`r琱y 1 :=ϰKJi b0Xc)--L[7F 1?`ItȔ=QV:ھnƞŽhhssVtnO$;2Gc#.*g"nS؟_Q!oL/nŨ*{yP J _ [6K@INsnu?NeUJtJڧn<^gfDaS "4 rRq@S/G^b}˔ZЅ%;@gԟrcNs,I@kqc*ÀXM~߯ҬR[EXJBZrC%@JLE"悊mC&v~]!j{Mg!~^rs{^xNlaۜKXi%tY;LI⩩IAU%>98ފ$ךØ[C<'G70*Ju3"*>hwFj!:OMPn;)%k|YmEҥS{z[u|fV<*Ѧi "1/ )׍*Sqr8ZdW 8A%i/S0=ۺ+䜇{zkޣhcit# JfVn~b?s_Յ,* <QVm,dS@2X0\R)TH9:0+2HX^@ AЪN?y9rrޱ GP;s~woZ^.>#OeeAÿٴ}%G)SM͔ZK q\uPQ:*cfJt)5'AqPyR#fڂxpS]Nj004$P%myv$8TE!vLţ"-_: Bft6rҧrV}6=6G|ٯbrʍZ5{y:]8lJfoҧs2oqC )'ՙ:2vahCNϦ\9BBPrG' cy,n2ɶJWbWbffQQܔK5BюjS sYiK[.3M X:}n. %v0g̙?i;\Gn5ƨfܼNc;I߲JYE U4Oktܻrrׇ^]H:9fW5o*jǐ^5*&>Jx-4Bae PFA +T N$2b3J]Y YYOBǀq7E 0$ HjKMc|nsبxa]q@B K2W,9"Ѳ%O@;E\"N+EV潱-zZunD7ߔ=Q ]"EÁīӚ:j/ftc~?9߄D3AqF>@ȃnwX4N?>lF*aK\"I.S2Cy*S/Azٝr1 c,aZa C)31^9 {`cSPט}*K(%μвXL|h'VYsw+]{LK߃f°t6<,ړe)Ns<`)];6j9G5`>IFG;UE`ݩ ;hE95{")uT6(E GA?;w&ʒC@ife,+ ďhΫ[Y- \t-Z272,Gc-XdcaV<D?U<˲׵o; x 4p]R584{G{u' b~LY~ܟ~~ rdɩ͐+˩ꢼ0~G}.+4I/?uQϕrzu:O4umWI Ɏ\fsrVqNQ!v|~۫Xn\R_E<17#`<8ݶ?oE .vy)/7)0l{MJ`T&JfIiDyCyad!YNRww!Q$*@]7щ(Ԭ"=`)S:ւ2͓>0!1WC&%k#ȏI ,+ ۚ@RiˬH*r 4Ba] ^ٽ#M ӓZv?d]99ʇQ~Ce: NhSVZ%@<5`@_!#mB]5PXBOU?hK:QQʋxndMuw\B[eaUxk`gqVBbYsC~JPP2+ȱ/\AP_ [uIa}-XG?Q>Oܶ!]1u2FJHqSZ #GHCu3ig(mF?)uCt,$leAS Pܓ(n;dsv\|W#LpV>S˪~ֲ[QGT5I#7 }^?ގւʮ9\poa9Soy5aB~^%k6m='PK¢HZB./~H︕UZ$ ?dDx(0E.J6 ƸO'Z\>>7+:1 ؕ$\\,ͤߍtG,=N,;ގ*;aD" ~N\sg(`K}UrhuU& ݡ# 7Bl/3žDnB]7IZRN J̫ߓkPϳ@AgD u-:rǎyxv*FՈB^wFtbxH(5f&liw9e|N媔n{iBJhe^_G4۔dś2|Jk[V[tV@7x INʉ+w1ffx[4^ea5kggL1e#r8&6 M gƞlJK: r%L2M󘇔#Qr߰\6(5K[ZYuy4ܫ 5֣D7<[- Gt=OYH)1DQ.|G9)RT:&fp-_i$1fz絧dbBh" ػ:d !u{[BWpcJFWtcKI!'S)FHa٬*A(LSLn_[yV^br(4k<įQVP$Y9曚8s^>P|?TL×6I~--?ks6$h_ %ҹ Y Ʌ74AI+82JCɏx$ي!ȤDF5 rv~/m,|?2i_@7צ7^$gf&9_Df<.\n8=S d8b01,Y `oMZ4LHy#qV-l$r3h9ZR4SR\V g|i=4]R6n>X,Oe ^VYY%cZ6IhYG0,HyCY~./pIЃyѢd8 KYJ6d"O֏bWȱMb;2eaHP> 1:J[CTw16m9(jjXPSD3^A+(|P++ϷECZ RDBoa.{C~`\h33@Γwϩg5:1yam ﮇ$ȸ\t/>ufn_ꔢI% 0ŻL>D0{ v(Socg.sK&jDA:|2]eeIDRFP2L.a[t˸;ޒ hoq[Z>r)E- UЇE=x媰CWP\5cӈjWyv=΀~%cP_jr QF>Ws [|(U窀٫58eE2Ȓuh :Z]٧XB"<]Kk UPY^K#b8X|#׍ ؕR1u>;sێ:LzPwYl,P12^² >Uv,ۗt1Nu`] Hka›J(Hu^hLj̜ L*}qG@>ic 4K^Tag 6mdX,!KZvSk!rl/X64'n"."0>APQYPH Hr%(?>-v86O!6:A%xϻUYNFۿS+ER]#djpNa ?B1`JVK9bYjQNDplTq`&3|' "T u&Z_TbaxF]q-yPRgs .o \_˰=^U{[?(Iz$r2`^3 {W&xA֭;~˼B->Z=RXӮ:ۨDc'k"7HD4U:`_R{%P[& KHCC}nzЬ<ճekf^9]vl__I{v–  xĒ Y#/Sg.Qvőp7a?$OR9!$v.jN; uF>1pLhP;dB@+;>1Ѽrbnm_7C" RMQ}#Ӵp|7~K|XїcqڂvU7Fq„6fY\PwɹoeuU%&ԤAɢ>eE]B'-aْ߀(j-N5~Ej;iFh_W~RLL'P df\Y{%nlN'HViF10g^ HaQI@vn8 >`;>H8͵70aɬ 6wS;Ip{uDq"EE@L#FDO_1eTpGw?rO+Ry]~yvC̪VZp{^GqS<)C)?pwu/G`Z;)i\+kf.M 33mU#R<bd_IWؾb$d`ΈaE Y ik $mWlFwLVpD^n̬J,N +|. ~EЏ&Z}p@GFh&FI畒 ^{BHenD4l󨘧 sЋ/5*߂ eWkwߚWtC&cO] c ENeS"gC4,0PEUѰ Skwg :$Sݷț &ig'py1Q'+(^f&HˬLs& \X%I!%dC|koMt"34nxQ1W0\OE:_cbfQ ѽziGIE`ig Ve}s=gS֠p bggN^S 2]1Qcf@No>ŷ)D Fl/6P$|6k.>rǽHbuIȋL;VgV{^!$T->FwĽ# aPO%bbIgj+p {հK77Om'" n߸ ɁI2NSvRd&d"\IL`3&+%m)YX`$sr8;fhB'Dt vnz`kF!W!`jߘK/<{trq;QKb]) uvȶ-B^.Z;;] ױX],|yl.MzA}Q.d|Cu8Hk8ˊu;Wԑ9%oWtD:֟+. J{_D0mpS8ndxeYIY8fݏ_[Rᦢ47(nzvbRsQRo3}Db5GI^zzWA!I\AHP ڧ^5 }M|$aoG%3'41NfK|ozi?ph?!8 foVqU#THQvA؅3gUZHvr3BH]G49Z3THNâu<ڕsaXo2t)ǜPajHXϟO)Y!6xiSJYoe3/ՁF+H XmXӚ;x<$;vy?؉׃%e24vH;I^/o2x~s~8]O[VG!1"q01WlNo6:(e(Z"ܢKc] 3aH@U+Q8?s&hU-gBGIf(v}֘Ik -a?F.m6t H{@GzgUOn΢@ᰈ+Z45?qlbkT uӶ3 n-j@ 5~#F!w(%,A+<2Ts~=?MLҐO*:8QMS+t ~maE]݅ ^Q8<'gcv\¨55S+e[l] CNP'[&nms/66ipd[5I*V~`Z*xPVuRT;r޸+mug^!9ia%u7 mQ۠0:@(='G|ZbZfE@Q7K"͝l;r_2ƀSwpIWWы6 Xk/o_P5I_JZoe |\e*"uD鈻\^Naz>JĉgkOV tL2| <]Odڤܳեs2s)n ^<Tá~EycD:E T[!j$˵ .,&T0-v@d$.PALX 1H[dAeI MdN P3$0dC&wfiHgCR-AJR p7cTLO᱁KBG L굎t v`Ch{O&t~ac*zI;~o^3~r>h7Mv?`$`H'12:ϭD47TU=)ݰs7pw8_`;ݲM$uV Q1m,k#mv7GN8(mePRRV';&)EEV)RLE^ڊH5G…Ŏ?ћTԬQ1SZnɱoQ=*AQ3vZ$Zst݌'.4}#ϳD }`?F7]mDžM#*o4wicoET0l+'.@څ/ktj@s7>'])VyPmuD/3H4y D+=J!$ݵ9O5El9kqfn֢ڞ=}}?TNHXN",wFI<.Hƀ/X}D@@Iʦ!$ ̺|V nѶ%tiZ~SiNF^膆Ѵ!G՞NZq3v،Qi]Ae5Ӵt )3NﮔQ_|=Qop^Pb3ʝ@IrQ3Kf=НPe[zZ=mFrbjM ljFk-K*=,(e?_$[A|xe5E l9TvPYv 8w+VUɣze:7@:$qkpPkvxI/҆uMXuʔ$'ary|I ؾ6peS0y,}Jjj{NĿбe@EGAURVڻ@c0IhF$0[%_& r[=@ؕ@ě@c_, dX1뮁aK~Ў0uoc'9jm˭sji–TaEUD/[ic)jaIx>]yl:3g drȼ]0YJè;a+mR^h]\ ?JF~ kV- J$ثWpd7$7$Megi-{X܀YS<o<$}1* kPY?sA6.j)ǔ$Ԛe1Deyǔ7GOxx8,0}WC~C]Z͋\_ gߟyGzk3gZ60du" ܴ<#p3V??u EJ 2<8M 2yjjHIIBJF7c[z”=V\0_Sɜ,?# yNtAXGĎtzH%A)s;|c㗤ꮫu@}zeAp/6`ހ\,+3"RFg BFRb_ނ}DR^C,ulҒitn hj[lj΂wz`=pr&i; N?hfȾVdpIUiFCwoWXfo3 Wd^>sȃ|{IM5pfLJb+c-&T )W 1i]B SZn.p֌?\DU%wHpk3@9g}LrP01 !1 El1a)gpݽ|Ұ>*J ×z C,G!-7$N}حj\eڀJ?x 1Fw8#uNloTz#|WL{F3sFåڻkA]?KPř`0Pv7xޅ/&SCϚw AiVnvxc :cR?BqZfg3);b{NC.mΞ/$lcT3 Fm25j9EԞhcI1BB3)fk/Y.m6VDܰےDB9sGE_kzg8B4%L፩1q[Bu@*w HD ׮i ΊO=dCuK+}8Lb qThj //5b&)1`JBszvVRd%/R#2@,gE^8Qs5{ _EeXcĠnw 7Q/.-3T;N;etBW{FҾak&n ;+/^Fn2I@5+*Dz٭Xg|y,X*&!8 T%6_Pm['K.0*\q\10e,h>8ٯl)W><ی@"+lJa.wS:]#0\ d&N;nJk'&9zQ)7ٿOp@%Wk <7i &pQCUk- D >&yQ9GD qrfz6g%Xq`CwWyPw*blт06~8, ir&JM~_]vD"o< .=BVޅl^(ǂ>Ò8WTn҄ƴgU/ F\\|W~}*I%Z:ˋRh }hЙjN43ww6+PVفx8Qq!VsVG]Ec7@t#]m'u@B u|v_W׋,o'uy-2 霒f {7|'ҡ Bcǣ=t숭!xһ7 h F0}+Jn1ff% aKgIB*Xryobp1n3oBm'S+)B߽jv؞fYJS¬ ֊pef]er5d&0B%'y:VL\%oPxUKpd|%C7$=>ԄĹX H7V) qQ> tfWlu)숕,oCmSY0,C(([bf}~b=%|h5gw!)ÕW1_ʅ0|(j7~$"쓫j )ZxJrz0]Ww`d[ К!BԜ'2Z'YW0_%_D lZ0漬ՀC}ktt~S0 DQNJrkX(P7n$hD -q}t tw2su~x+>+'B˓{Xx{1Cv 6{]A *BlɮʭΩcҥnmRe\4AK2];8aC$ >ܐ;5;71ݛ.M(6 ]ߵt+NÞjo}bp7)vKV_7f_j{]r1_RC=(Jn{&?VhtX{kɹzeSn5Wy?44hlLc9lkО\-:^H,k߈<vX[W:U\ju5xA|9|` w͝'GCۉ:`^P^w$ó'N:e1Pq@eȐ8K>cwP+ 8pr*SJwGѸ k̕HgB܀XX-;"{NxcpnɌP9D?,  4O4$@Q]K0BӴϥu tG,$!r.  A0.oFQm5Q _G4d7Zo^œ&Vb & l?ե`׻We,301V4+c\.fEiHq0pumB :=՟,BX_ Y6ـr4C}:tJ Akr+X ,9 8>7FՂue D&AhP(878tLΙ:` 5$B0ZkʒOB> =V)e ">)*\N̋\yR*w|n [= AwCÁ JjG.aYOa2f.:HӬʫ7iF;5jxѭeOs"??, uRuKYuxg-4fum2[W^;/luOXtk»p'>q fVanKk{RY/]ԅ|%`iGQi:Ք%Z©&.*?_([_\QD<:QL_*aTmG³$Lo?#"/Vq֘8r`JjەQʿ؂F_M -`ɇevNj\--q}|bvhϡ7auUR3?#C:YńRoy+LZRNnȪ9)!\O@p`O\#=o2 D5,̧ƾ6OMael1LZws҂!Lx#@yOwYbWb}4LtY~ygyluYoUHEW0[PXjxlj^Hh#sc5SBr'ljיBVAk p?6ߎMN ćDcޥdUS%1Nsc`x*53_@@̒L;}[\g¼7tAF߮~ 3mY??iJZN) AʑDf(wLGl'wQ`o=ZLޢb1 `B͐6sU6;9m EH2Yx }vk[\t5Oi)yJB#;IJqe={i&zO;S(ۨ4e N~s};IdA2D́ȥsh壓;T/M=#o^.JXyj،3?M$akQ$M6ԴXɹ@!<t.w;:" Kl3DeN{#|twS7 =ByDkop~2.iT߈.H l]407tnb`(l qMžyr-+[:$9̡Ap\k^l:D̨B!Q (OHeFXS^7괤}`(v~\ @ `5U{\Hf. Ki,-^&ʑ $Ր-C¸~3oM-B_u ɥ$o~k#!hR}#9>|Gdyd͵E<:75~P>Zh67,䜼$b.&+`gsu޽d%#j< ղ`{ݻh7?16V8˒[6L `LRK@;y54&{ %]t/<:v,UNVƸulYwS.VNJz~h]ث-:ͯxB~0}ΆwcJ.H*GbX'kRN.P#ob_c9@䈑 #U߂u/R'7SWm4۔Dl s)?^т8Ajf/raZ/BC]bW^JswXjT5.@=Fzq%],fP"|(12v}(hd1D54k!ٓf5!uZ iXڲ/yX5e^Xz=g @EN%hV{^iZ]ժ 6)|[މWN[Q`Ȟٰ8MR=*O)Q֨&G?[%T{lRP|Wc*G;LKtи0naitND.Ԯs0*J^Wp"4 ЏC<]UFs)}|BUEq>zSE|28VJׂ݊ iXC*s ŽbP! e/8eG֒u"Ż x)_j{=.Kkӹ;fBms2D !UF(Ƕ#n4:5|k 4p9&SDi$!fjުO/J/1Sȁ% ]\+yQB*ϠG&*7[:S*4b%67` > /JUb!џ\+/d7~O]\Qlcr\Fo$E$rI(@A*ojJø XqrwZ'ꪃz/3+&Zov珜j>F*ҥWEpMmrgQ+r𐺎5Dܣ;Gm+!my%!Sk"^y_+|߅P+LxU tnmS]+!1!_ð_wۚX,㋋wl}7^π ȰjXĒnf\X{F7͒23u:JشK.;u *ު:m`:yFٍCB9ZgFR`O]HA\7ZڍlLBנ&[Dmpx6uoY!ӀnΥ*<&C^DUpO}0I]Aa{j/ۯp! j)v 6PMu,e0Jb1,BR3L.<%r`#(Z\w>"*vC&ěj*y,uMmtZ ~zve6k_A`}BktpxN)SF5A <({pHަ uwq]}@iyv M.X'Tbە\syք!XS,iw-a U{%ʈnw틒d|٦ Fɞl>qR̀IV٣~MC*m4uvo2}J \y r;n~8<J\QGCE—),.@K.> [}n`&,yoCCy]o&W i[YgK"?D Y:O_1t65[Oū6 H.ϽMp`yf:bP^:8w;:RGXTpFreQJ"d1=JUҠ|@Un&1Dzn|j\|ͅnA8}OʨޝY냬.̲8P:)5E \֨X'].30'W~kl꠵lEѲY7E(^jQJܴ,0֕ ܔUP*1ֱwkŕE j?+nJєPeі%AUy&r,ID(G[#r )#HdƪB]!I@pi҂S|Bxb1"T3HH5Hq6J! UiQ;p9.M01lf9Q#\uNŠgE7^ (k,18D)S{]9}L6ӧ0RWÖ>ݹ|q[b`u(SvDN[.i7VTdB%Fn`( ꛦ\> B#A ڿ?aYa\"Ŕ4_2Z$۰9b,>:: c1eKmpx(=j${O*"We9l\g;%]ARB!>TsIl xjiuN#EPndnj;"yEAQg_1n6}3}3Xy HQ$r½`\k{{ܞtCXNSt&Z -mw@mﬢl}mY2T.c$h[  ܳmE\3 |?/868t4\w wⴺƚ_+/ HSC}F+sLk{E7Lmz𴄤t8/9⟨#,c)5 F՜jcL^?e+KrBUCCcĺ 4աOtc(^[jX^|+G$ۏ4f 4kk*54J}d#q2We՚YR+hei[UIX^m;}8vS9r9s5EbƊK7;Df#1`[mJQ3I-s0a>>R t] )StBψ/,T+[?~28 ڷN3].|5DTP ?$,Gkff%䯖'Ȓ_@LD`4ɠ|,! nlL2{$1ٶȭg/ś#?Wf+#&]f=7MVqQ?EQ6f]9&0͗WV<^a3avAcdmR8=jX?lE@@=7p-2{8? 3>Ԡ.i\H2<0[Cg&8u%12OwA}a gVmqy@A\s\X SQ>vlݚ I$7^kޘ/2X ޫDS [TV@}ظN9*AJY۽$#vY\YX HGzݚs%EtX(Qp/adg bH3/vX"zPiwUd>fbݹ=E0#HQZOPB Z=XTp){EITd61HOtwiPQ><,E=|\^,̼ (ZHCu(JS=aUW/S]{8>}ֻrp%ƉDMBz<\[i A]!){s,Kj jd#t1v} Aiq ےCY1\y}_ NW礎-TMNUfbcf GMF nºsLS20[ rΙRJMqSC9侲r^f&]MGw=߰[jI^;~vې-ZuQ6NdH]3P쌲T7WL Rҳ< tLѻF0?v`qYn\E' 4TkDQ(+Q:m]owڰ?pӫ>ЍJd0-jg2Mt ໂbI)Iv߱d:H=[Z{ikOzOudZ%^cirU]'9ZV#V[4dQPDMʊ7*;C#<ٻ<7 'zlz^l& eeZb S[j;}LUkD&[n)XާT&*Sf.BVYrFH)ѰSΓ>)Su9{zBryyS*TUL'nN˞j^bƏWP!*OuX>Zv!,n e:M1(4Z*C!ѰJw-S vJ 1>P탿j4 JHb قźuPy u)d-v2bA`dL-zɒYy;LvJDZSIe gWHR`%'z%?^#$JPGO\A"=R0U5 C_F&0T@F~ja#Qn)Z`7Rؒx,+Q;|Oj.}L:bz{ ny}.-1=ͧm0QެIi$罶ٗI Obp)Zyle\" (%|Bĉ$kswP?c681 bcPfPri` kesZ$n&E 1k>DnĜ[׉r5":߯pX漓 >d LՐFy=$vYB@V~!ԁc7@s0"=΍q^{gVW^Š:rf!GAM{ 6Q4%cAQH.#3$+iQ%DqU-om,|ܜ%1@ E=M$=UmۨRSSz $pE*qjĝ*[֍EU/$"; B +a!{#l d^Lj.(-C\4@f ̇|X!@%uʣf$_l1&u,?zj`ꦰZK^$ʅ @ `ɴ8=wt/bhi35<7hd sx8ݤ }$7QI:6l#1^#%5j7ᷘϭjbCmRQsµb`Mc tΝόb#*kF5"5h'w@vw_D ⵦ4`*HْYrwqϵ(e ύ716=8s6;la`K} m ? |'ҥJ0$ zYYRǣfPu%0n؈TߎA);on'3F٩VζsݶЖF4"}!A۞ڽr[h%$iDÕvVinj0PalyeM2)j!!BӍNNlΘыmv+#T,o{}+ Seۡ#=,<7,É0g Dsގ%-*Ӧ }{!sVh'+ʢW!RD-:Ubwo/nX=;ەqAopN2|5=vHiK׍.|=q8]\p#K<1fv<=J@`72<M{h]nnH֯ZQ4SKz2п;IG/UM 8QV}VWT=Cdl*xX=8qz}Y9`%gRh1% zMZ5,R:Fh@h.sxau\]|7{36pO> tGD*?VcI\MrMu/ >FhS?|J?Ђy6ݣ/hY&6ڜO@nI!<όĖO$e2LOW$yB ˪>8؟T)O( =cY@c>ʡ-#M3=4l{rl7D4qȗ :>;1Đ852E%4rR0!ĵGv=ɕEUK[V9}"ޚrv%OxuZ凞 t$8# _U p,Åoj;]H !j8F}-D~js=te ;iYkPtiީ?#bz{9#,'g"fx;/ /|%8y Z!^@Dh2ĕr^e>edS-xuМSL)1; /ؠ':M~q fG&]BZqd:#J[75JS'4g-:Nx6A09[s[=#} Q*bߞ<uاҐF#Ha.1 5KVY?ko_LJ98qٖo MS+FZ r2'WhW+#L%0\Ps$63~ ֝7I=Ϯ .]azbVec3* d5q\/.'R~ <%+k$(b"p `LcA@-O{\P  I9Ʈx"W2($1_A:_dIyZQS.Cy^V"#qQ~߅72mc};1蛋N0 6 hQج=I $-}MޟGSco :X@x[VI/Ԍ'o ,C4/{JIq؀%TИAH8 I0^0cv t J$oxWfoi8Gn;3kQC0yL5c ÈM6NjfD`w Heo:>ɦ!Ai;/_҈[lɵ ]E:h;#<.o+28\p+=`Sq͞o{N{IZ)br.4 l3Yg@cFM jdY:>` 'Qd{hlw߇:TyAQN>?/?Tou 3%pϿ׋|a[A nL 쏏Hf`A!Oy qC1!_6fՔnݐ=vL)F-oưbԉԶ]P~!P1 bDnIjJvY#t؅A㣷&miuJ싸F&^SSi07P?haWhRB m-"&rzɊ0KW ǿQiQhK0L#.ISTT5#9GQjOP*]KChYy,YKܫgg$wI|9:1'L+@` ÷|ꗝNF1VL|I;׋7c?;Wd8~J0\!6%B~4o^72 M{'+!4B73B0)P-.=Y ]8$ Wjt2|]r"Q츿$R1آE\d).$">$@s<,`og$jpNǤ!=vr)o' \Rk+vBq&\>!X<#-kZoz5I< =\-v.ߜ$QIo-f ۗ{ϙ qgyNaT5= l <)cEKP\^#'Z4Gu<$%@W,eu8Ҏn|+ai4%t~y GBۖN1Ѫ˲ }0i-MJd$o߿ ,֏q]eeoux0g)R-,ss.gQ]Γ(aۑAi`̋08^_h :w[:.y(YXX3TnWxOhM-c:hlѣ/o ?n}<\ ģcSG I% KXv,ZKa/MEJx>SDMouq{;'g&kc/E%/ׁ_[- my]}I'f"@˝0j K(ѫJMa0pɖsf9IZəIH ܙ30ƿC?yϻzV.d1dz/;elOmu׹5phTÌ-UAKOЗyE:WYR&WQ~LIߠJg81* E2uv=!B$MIg~t[&WSR O9n7ۛeLq=y+tWF+_;E8-F4$pì2p٣PͶ~ `Wl:g!ZFl+DQwoJ`Zc1}qC ,Ąգ} tjx 0m?Hw==] q#lz?Z_w׍q,d;T/Iݶ%  NE98fPSf iI*oyӏC zMS'֮jpҺi,؃ Kj.?;e2 񜞣o ~Z+̊$S#X Fa{糅"ZQ,eN eNk`{Fl3$Mm6J={ꐗ:]\ӺiPAԇ (*D=]e6>\sbj 4:}qyNVP{ 86;-彲 Rܢ%?ϞIw`;ꈃg-eYWZiDW݃|Io}AoNOѸQ ~7Q_7;")1j}ʔxw;ЯIWLgpaA9NlV^=ғ .!־r]aj3VyļUw[\,K:_Q#ߴ܅ x8 \S'"rت}$0[yR%` r8ג 6Iٖ*IޭeD3@-oFlswVZz%UjnT5/aUen|6;cKU I︱3Ԏq.M 0YʇxD JqmHJlx}o, D$d͢:B}"Am&'&XA<ލJ%虩@Q$-{fಅOGKSnlXLސ %TH]EyŌp:|Pk&I~EE5 Kd=>E9z4#a04Њ ,*B1Qà[3ئBJQeXOBOR{3r+#axl"$y<&!hA /՟6ǥ;M{ZF,U1L]՜Uqhif}&N1 PMowl,ْY>] "ލjWQ#nD:iqq}φ݈1)%'wnyW 7хuv$#@95 '9tTҶOSos,ŷ7lǰ&Zj8Ê`DnSn!'.z>nDcӄ?.((mw(-ٔ ڡ*~W >VK} dneKw9smJ9V9C:zÝj^KIEe6`|fA1-T<"T;~*Cx@ADN+}vҦ>6 K5Z!`K٥~VMA~fB׻v6KjbX#3XE6iEiiEEmd_v]&C׿K$.s+dr㱏惩WfRp_Wh#6{WD d4n3*5l_yl,|;sZ'q4lߑHe0BBj`V<6a;렱\5uqqʼyXB`rfq3>e"Udz]OVD[J@Wp?]k^m8*ZaAKv]^X qiL]Tqq]a -܊(=f3U;lS%`٣uD!Iʶp2| x&gǔEt8~h޽ "}Sx;ֱrQKC/z{$.c=`Aa쫱>=ɥL HTjn,{r P_##(_IKTUgOeZ@r;5o3i+/|enb_y[fG='cP,faFGK'0 ʴP;tI{kj赤$.KN~@(EZ7> jsQynզdn MEr%*Vݲ+[^=`*76Ctdp`f/if_ӨE$0bJkFڂ߯4 $27_ \b/(rҶrۆH_$ُȒ(~0;vaE4cZ`qbRzb?*T$_H%g-BYfVDCu lGLAjh7pW6g<-Tk6Us2=wqv|N|.0YwLHZKVd5AU "T+՚{ * >qupA)yZOI#P=:S+_CW6XݷXM6(o$/[4pjG[gK)aI58FQskn TZlU"胓^;ZWͧ r E A-@5'd$g^,쥣=DFF+纈1@Ĭ B@QSw \IYRg "-1]4'}I 6szjZȰk}?a<:!zYk3IjM>ejNg/*3"-Qj3j[A ]ojMma'nଧdףcW;,@IɏMcg$t,uvoۨ6LU2P7= sIӹv*kW^0( C6yl OKa5KJe A j0dNq&`^ /5us}s|`J1H]zޡ0}aOW8iC0sγj]NhHDhc/+4nb:u+=P%F}X`8ժCrE.fo$sD'%7 Ky^_9˝Ξsi* _jv:*1 y(\a!1&նTޣNy],r!?@AZխMOd^C)Mj9i;!1ȱ i3 tr`Vjy=N%- I 2h=[ڂ#] }Xr8?n5} *3[;PfY4[vL(Bs5=tn-phȤ[ۏSt, ψKe-p=P̜%|ȵWұ%j]q]S)f'2?Qz{|&$(< ?LD n\H?QNe8> oc~xֿ*ؖ{7TQ}a:4dd+5J"05C}1t6ȄYΈpר*I<^@L'Zt*;7H%Ko+p ,ln~p'˟z^v_K؈Go{OģҍIPB]a%9څn  !Q]SO1 2-8QXv@̬O[R^UTꇁ=Ʈ>We"^`kOf4 (o$BE>J-Jg.p`Bi@+Z"C )mtUGd!:{]J#FV;d*V(4- F4}ҽGهIq5ۚ. D/(h-Lܺ%(rT&!JZIiJdJۭ: 47jAџzu"t"~Mbm-|͹ ոuսwۺ݌a@Px`~zGtt _:i1v4Qf|u8̙w61j(toGc?M. Q#NUm,.xP>29x'ty ~ᠥWQ? aëRa(Ng^w[nt*Uⅅ[q vW-$Wcۣ=ۢV難\)+KY,a/#j_DJ%!\^(6T9ka %'M5yDA>>RrsQ׺,/md_rܵPqt$T2_Fg8ccqfzGRۨV2"MXV5\"97쑹ہ(lkƓBSq+1~xM%w1[M7X3Y=>v|0jkP ZU?5D-\ ®SVbN7-Eޗ3׍~v%+9h)H`@(cjn=="aWFcXΖ>S\Ek 6,L]pu޵⧦Z]9 <fZPў,4:p0($v C] 8ɜ7M>Duekܨ[3Vj =2Q pZ?c<,Vц==*&r9y2}a?^{j;k]7|evA:Wǩї]z<< ڐ~%nҽ[_ HIf#,oTXI&/{("49I9Ҙl .<:/_H&SU Ƥ7'*j n$1ۏcF>Cuռ@ !K%Ϋ!}*|WOpyRq}}\dEQR3\m1l){HMYp[5ÕSJWKZk)O&: `[ʲ eE7[|ک,~Vp Dh/I[+eQ-E)#"0}s %ڤ ؗ"٧x}I\V6t,&\"}e80U,Ur HU6P1%16)؉qWTiƺS᧏`;1KL\ύtnz dq9Gig7bmfU]DlƠ-- Nam MĞ'k_]Q};F%XCI~Mߴ)y#rG]duuLA.ӚC(0PYt}F|O}Ny1 UQ`jo:);zڰc9o[$6` q*RUEӗ%G0O]q(gݫ  hZn!-jD),&P/q̓C>!S┉ iRԼ>"㕐Z pzT. NًN鮩[ j@:ŒnB 3GA[vo?ސ)- &ÒO`2nZQl{NTZ ngw[uL}ujL$ɚ8hN$0%qt Q6XmIٙsJt0/3P]8tEWΏʄŃgTl=ě7qd2jkaBL:5G a?~s/a^9UTL0i-6?VoVY`aaͺYxRAONԂZֻ̬.3tK_ޔ\;=uOԴ֭'-ϩ[?<"ylQ܇[\n|ܺ`<*Ssȸ$1g}q>c&JtV@RxemS|t 퓧".;u_&43XkuGQ~JW<ߑn^R-϶i(``Y 4>X䗡V1V2ȍx}ӭ, _chM+"[F.~ hF*>ʐ/vK 貚pIJczB!]ɜ۾x~X=WGyL꼙zlA'I1t¾trf:aB:2XFe69 ʣ)EUeB⁥}>q*cYH IUb\} dm~)"L| 2]"y}!nYDE}ՃƲD*Jy&󐑂Z=b;2v 4}t|8RJ٬MO@Z`oJ n5ŵ5RgʙDXb/L෉"?faBn4 <>&l DtU$9,Jh&2(]v| Ɉ^j2QȘdm\>AkWCP7 -~%iCxTvfR9x=a"x?%+s'x[n/ {ݞ,  /.ө.pLPz7hio}!2 2_89>3砯7澞Ԝ'Zk>̲R1$36Y9CrZ[kgȘYj+7VpvBa'҄z<_ޏ\~_otp,]';X.[8&Xm:B= ] Hl<4&c0X[VEh \Em}lRѓ)7F 7DfHVxtNĦX2EJ Gg{ yi 8EM@V"e/B5̍ *鈈ĕ*b\W^2- 2: ;? 1<[ʉ1Xݟ苜T"(A'e\Ń5ہ]\#6]z~Jf-N*9z iU]9}&芐Wтd~ SkdW&O~S W`:_vfcRgڡؕ[CpP&S1@a-X!n aiǶO Xz 6-@jBԪpIW3F-uIh*V"3>E قXb?>_|F4I^KAzx 2}'F$~[I>ntHw[v%=@FJFA:vl4< u||n(T3 ӣ+r̓8s& (S#mdz6MiHrAAK[zH!jړZE"-WuSɥbQ&k)J=ȃ*-ǯPfjD3NX0UeЏҀzS\os%t WEltFgH} iٲtbo+3:TC<+J,l5K 5fܢi%XIQA4(ݒ'j1a%1Hѳ˜bj&o1E$ z7_wj Blu\mWwaf<|̅F@vI!Ch`AR5+s"T,*G&4Q2uYCD-gh5 HJYt%\qTy,74 @)Á!z6U6Jh09S~Z+cbx`8s9|xC̰>߉N3 Ӿ^\~~ *0S_i>RJMrVK͂TT+#DJ7GטYzaa`wŠV5eb\4٠̘w fSH˘Jn^*p¸=Rf5wf&0ogAYͯ mjc :D9 *`-$J)+b$>-N5ղaK e)UJU<H②P 0SWykc3f}x-~ E_1.[Ϙ.|9A[Fˣ`D(ߺ5Gw䒓Zkl]^ji(#MV͎aޏanV _\vR"j6V'wfrj$,s Kb+%T7btMGeyTEyb-"O2d(Nڠy:=!m3Tm_ K])b&VYQd}fok bMB2k!lLU6G\ u1Qd=p^CzZmA3$Xpx#m7OsgxgeT`"/Zr`8>=^ic)bdq+=־YuQh?xG"FR1qD[0&N/$EN.v@!PDa &RӔG0Gv;m 4ۚ |m潓[h>*LؕASv m8CSoڥ+5ddi_.lErxډ i sH:e( vLf!^ Փ4S|;0pp=->^RdNN Hq1L2ar7Wft/DN :J;cEeďh bjͨ^\Ix$<-uSlK@␛BcZ[qwK$h]v^ HXZ>I1~@+_r` OPSs;~"Њ-Ze(D~1:nj>ط ݞE'FQ@z"Y/9N9Fӹi4}įJ5drL*lD<F 4ޢEDBJ!૶%S[8~[NeYIѦFf"c1YkLy:b k}[LBxUB3 i^`f\+RChy_}X% 'rҠ5GX+}pچ 'Y܅ᅙRi%i[dڪܜ3p\tΟˢg7;*ō+l2Z|42tE sbl9NV&Rd+"=HL4ȁ<Ѳ<;1t Ŋ+ҵvVj o̬LMnfBui!fGN./ %Iu]3,? 2e@D3(Ea> )3c)&WS+ &1 qGR9rg | x`o6a M~Esrµ&\y)^}ZzYP@/vr\q\.ԨkJ&HȪqq{NJA҄&*01sti H<^+UU:4D QuM$B G#Zߤ I`C}?R{NrwoZNߑvX5T]/4 tRpcy.:ݼҐ`:؃{$v?}Fh~Lř`%6̝06zqk&i3%`# `D7[XbFw{V;W_lJH%]4F(F"@ 1.z5b%yx2Cf5F*:yMbVW8nRknp$&A;MYBsORǘOuClҰZ1X1lJ#DwP[-UskQیL Ŕ=$ꮰ- \HAWa<ӹ˚$V"5G`;qn~y,9Ua)C#*G5~y濌ھvvdH@O r8?BVι49 j?7XMYMC} ePgM)l=rBffynyn1fP=Wf6Fq4aRj?0yUf\k pLbV\^OkH٫LeUտ}%L򈽊8ݮ9Vmg[g~L]W 0 Z Vd1qr|6iWƚU$ J\<=lE6Kz]r%b~٨FZN|Ivrkp͝D,o \f[T@!=k";UqjxAwRD=K:XT (i~ CU,ޞ£}b͌xnNL*Ĝ,@9i"78IC2i z u3U>UBÑ͙v'XĪ479 PFe*𫞟8J$~b sqb_[mAiys9MaOs3|}lqvQM?9pvx# 4 ;"%ZF_qMѕz(54St6 Y\jD&]e=x\+J^$81ŃؐMα%y_P @P{ZIx~ f=jϕ?MYYy#.\>9\SuZqc-3SfsA9Dv@^t֒_V"퀐.MN*)pXkg /Ƞ{i}OTR4:pW$Lػ(=zPkv2/WNۋZx+ xz?ѷ[q=Nd[E|C,Yl_)epX,QҋHG 5y?J `QNKF#5j Sb 0e`LRLj_zIL/RJK@U.Fn_DR5VRr zTx?TCk>/ X` mOAGx;6B}v]$Ǎ e}Ad?9}6ΝV;pY7ᄆ=R[5وO62j P+K, % +6fᴱsWf,{3"{:9J2j)vJ&F0Rܳ,(cdEJKGΕu6)EZqmڴٯje\劾z8H0)KA/܋.b'SO [/tAh{g8`OgWcL1"m(,H׶uAXH9gr.SKG7'DI~)Mo-]G\*Cz`v1F^M O%gEiqeu>ڙ K fwa .bX4d%4Z0垰G$)o4 TחNdlvz k3cVnj!7ڨ!̐TAx7$PT3 dy/ 7^Bպegz'P -˽~:})cPKS爧snkBu;Ax\9մYhUﲲB~m!$\ᑼ,ڨ,jkD @-r@+]TS<2蟴`6ݗC:dRD?G4*/4m瞶蝥LOG⤝Yx^ka{OH GfiBww Q|6SoQ6R%D]`|Nxbray%/Łj Zo;A!0+DIx|QVh>ݍs]rD#z/=qE35F1A~ AÙ48z)^yEePNe$D=E(b?iD`U${^2E֛| i. :֡0_up8#l2s{\y:4FܳY)=s'&t˞zi6Vh]$KeG 9D>[AҘcgfY#S;U 6I7 6ǹ]܌wIF(dAL3?d϶2"6J1CLDnJu0YfBY'݂%tD>X%|V0)X2.LQ8b {÷$&$1j4eG#%`ѻF똖1fν#=Cm{}hJ )SR t"%JأGP|ǠEo@A,-8!llLd usq.kGxyp!5硶{H`~@OJ1mn3 yMLaL`!KÛ`Ŷ>9 bhM Rtu$l%7>Z5 ij1jH|uJ4˱&j.-QnǸYNLR59h\.b2O y#;m L-(*:=s`@z~J'˂Hc[6\}\yCMXe W@Ot1Ó@5,y9 [x< 1/m;%-rfzz>w I; ѨK&Iq"jsI9DD7&s?Խ0/iybIl#!(XCuv~ n!j6%/=t+K^ lgIYżg!:; L&C_PrV_7uvBŃ^vW|ШBځ!N 1JAq2v ,[؅ʬd;?,rk <Rj7W蠙#ڰm}kuhtIquAwr>qylMޱw qcM5OSܙM8שBwPnbjf]а;aH 81cN_\0k&^5DVvnʙSN^saސY(m'4%bX8:JV:k7*qQ_:R V.6P+:uF;h" b1ʄ}ze)ޜH` |QV2pAc!u7k a}~\[aP_9ATy8HJˆW븙 GY)5Zְ,ݲ65U1rqTi͚`u2qӓD@gOͧ,GYO@2V!ڏ9Hx6 rOwx^+  2ndIڬg~O<9]d hAjt-%Lo+)r/X59cʼnEjcV&,saT-pj׉⎤iqv Y0 a/D[uh >@5yױ=2I uqDTDZ}g݇RЁc?8rb wIo{FEr MO\g惜-jg!8b`Z3kMZ Va,BjչLeGS$Z)_3hϿtC(wp@;b "'za+_=ZxÝ#12T9o+ ӆ.ٍ9ȟ<;h\_ItMԏJY O\R qVP +xp b>\T˸kvx6cGP t*-:e3H v,> IepK[V?Fea0NrJ&8lJ1 A3ڐa1<"pIyھw9udBV9&=#E6}5b w$'c#0 x}i-G a 66SO@oFV=)} w\#-ms5֫ȇi{Y{@ mdC*Sq# DXiHڍb{}.2-=ҵBtw89aDnBY$?5u@-^Ȣ51Z'yls/Qt6M\_Tb iUt-P:V|)5a؅< HGWFF!jJ%ŵ+kKܒiqmaD3 g Qrs.m=z"t r[$Bf]Dͷa28dv7AT?hl-i/@\L96j :Wm8/eUTCqNoW6 d #}.34HAI^!E՜>5"VL x/,4d y  +% R#ٞ~mBuA\Q?\-qGy( )D0k7@Cz8 ;e޴.f'tY* sBՠԡ@ =O)%-؆)zreWupF PO)/[3w(ީr ?>Au dJ Jg} OuZ(n]E<7ACh@JS`)^;DzG} YZ