haproxy-2.0.14-11.11.1<>,լa2}p9|g L4;*4 uN` tmxe|t)-]추F/qָvq\j7?@Pl0CK`k 0f7`zTѾBV=6HK>@onvB6ԨC*mqH wȄ;BLo&g}Ӻn^e)e.a pg:؛:o~FhD̐ Md+Ad7,k/$zZLEap2A/%I[ PW3.>Lt?dd   O1 Gi|      3 4T6P8;O;p=l=/>h/B/(C:8CDl9Dl:Ll=i>i?i@iBjFjGj0Hl,In(XnYnZn[o\o]q ^xb{c{d|+e|0f|3l|5u|Hv~Dw\xXyT%z`Chaproxy2.0.1411.11.1The Reliable, High Performance TCP/HTTP Load BalancerHAProxy implements an event-driven, mono-process model which enables support for very high number of simultaneous connections at very high speeds. Multi-process or multi-threaded models can rarely cope with thousands of connections because of memory limits, system scheduler limits, and lock contention everywhere. Event-driven models do not have these problems because implementing all the tasks in user-space allows a finer resource and time management. The down side is that those programs generally don't scale well on multi-processor systems. That's the reason why they must be optimized to get the most work done from every CPU cycle.a2}sheep04PSUSE Linux Enterprise 15SUSE LLC GPL-3.0+ and LGPL-2.1+https://www.suse.com/Productivity/Networking/Web/Proxyhttp://www.haproxy.org/linuxx86_64getent group haproxy >/dev/null || /usr/sbin/groupadd -r haproxy getent passwd haproxy >/dev/null || \ /usr/sbin/useradd -g haproxy -s /bin/false -r \ -c "user for haproxy" -d /var/lib/haproxy haproxy if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : for service in haproxy.service ; do sysv_service=${service%.*} if [ ! -e /usr/lib/systemd/system/$service ] && [ ! -e /etc/init.d/$sysv_service ]; then mkdir -p /run/systemd/rpm/needs-preset touch /run/systemd/rpm/needs-preset/$service elif [ -e /etc/init.d/$sysv_service ] && [ ! -e /var/lib/systemd/migrated/$sysv_service ]; then /usr/sbin/systemd-sysv-convert --save $sysv_service || : mkdir -p /run/systemd/rpm/needs-sysv-convert touch /run/systemd/rpm/needs-sysv-convert/$service fi done fi if [ "$YAST_IS_RUNNING" != "instsys" ]; then if /usr/bin/systemctl is-active --quiet apparmor.service; then /sbin/apparmor_parser -r -T -W /etc/apparmor.d/usr.sbin.haproxy &> /dev/null || : fi fi if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$YAST_IS_RUNNING" != "instsys" ]; then /usr/bin/systemctl daemon-reload || : fi for service in haproxy.service ; do sysv_service=${service%.*} if [ -e /run/systemd/rpm/needs-preset/$service ]; then /usr/bin/systemctl preset $service || : rm "/run/systemd/rpm/needs-preset/$service" || : elif [ -e /run/systemd/rpm/needs-sysv-convert/$service ]; then /usr/sbin/systemd-sysv-convert --apply $sysv_service || : rm "/run/systemd/rpm/needs-sysv-convert/$service" || : touch /var/lib/systemd/migrated/$sysv_service || : fi done fi test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ "$FIRST_ARG" -eq 0 -a -x /usr/bin/systemctl ]; then # Package removal, not upgrade /usr/bin/systemctl --no-reload disable haproxy.service || : ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_STOP_ON_REMOVAL" && . /etc/sysconfig/services test "$DISABLE_STOP_ON_REMOVAL" = yes -o \ "$DISABLE_STOP_ON_REMOVAL" = 1 && exit 0 /usr/bin/systemctl stop haproxy.service ) || : fi test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ $1 -eq 0 ]; then # Package removal for service in haproxy.service ; do sysv_service="${service%.*}" rm "/var/lib/systemd/migrated/$sysv_service" || : done fi if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi if [ "$FIRST_ARG" -ge 1 ]; then # Package upgrade, not uninstall if [ -x /usr/bin/systemctl ]; then ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_RESTART_ON_UPDATE" && . /etc/sysconfig/services test "$DISABLE_RESTART_ON_UPDATE" = yes -o \ "$DISABLE_RESTART_ON_UPDATE" = 1 && exit 0 /usr/bin/systemctl try-restart haproxy.service ) || : fi fiFV"^p  -E B q!X%hi;_ % $ e 5%?R - FFC '!L  6y='5qi3{1] #T:yBFSHDGgD Hb@EFeIeqvv10 ".T>}yw9 >A聠A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤Aa2va2va2va2va2va2xa2xa2va2x^^^^^^^^^^^^^^^^^^^^^^^^^^^^^a2va2 a2 ^^^^^^^^^a2 ^a2 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^a2x^a2va2va2v11f9339571329a5ab34e17dccd6386ca3e39822c947c947a1af61a5e1db657dd5794e09695c029721bdea4a5d35a95c5cecda0b5dbbec6069c9857296ed72ad8cbd7ecd2cc5345c85af175c4497548b3d12999bc42fad268e594ca46b6b1d77af044b159de4752bd81a5eddae3490cf481a0ce11ae01500b829736ac92e90b71c2116eea0acd4fea1cf1fd92a0671601b3663dd3f27b66371a76c0b6c0d30d9c2f10a6fc2695be95b71bebde50697ad01e7a3c67a1d24ce7ed3e8d21b5fec20fd4917a80520d52ac07e2081817885231aca6034582f1a1f9b0b74bbead60f5438d5ec4f8af446d5ecb23d306ec6ac82959b07ae5040375ef94557a6c81a066d2647f068a16d842175410d4b41da5c3f57306aacb74217500d4fa8822f550bfd94739782b06489350a37a8d3753d97f4d34021a3ef3b595ee43b74d762d35c3bce5120fc7e8f576ad299158bbde68e8cd56425b1dda1427e43a2292ecb2cc583da1682cb28a8690cb90edeaa61f3d0207e8f282b7a50be46e5aa37606339f9c27037ef4bd293d32fd4fa65a251fe49c588416b6406cbca9ff2f17fd4c2d03edb362c9edd7608ff2b88cda9e0e6803dab5c6042e10e67b4415698ae2dbd5411380c4fce4f65e4df4b3154b05e8e7b99e54c8122438898b831768bca002f00c352eceaf73aa3bb160e535c3b69c9c91696c913a6373d388ddbaaf334888d4f1b489e8ac8a342e7ac6f97f864fde1ccadd0f194443ac722e159be552514d8e4990b97f335ca9b86bde572d76f8f618f7132e63bbbb82ec7836a581118e426afb4913864e08ed7085c7e15033737c94d3f0d840335c8dd3dc58e3c488297291a590ce1c2371e2effd1ceb80d1087f6b36194312860f79c135ded8c129490078beac53daec4e7e15c5a9dd9590395722f38df3faae087f02f388ae1dd4594a0d4a1fb5a2286746a00d5986be9390f3c532811a97f884a8d99e970515e9c7ec2e05824e6307a254873823854929a072c6ea5f18c7b58348eb53a77314d4db606c737461f9dedcd550de481fcf0a25b3dde843e082dc377e21604024710f8cc662b0de60beeab05b3c2918107f640cce6fcdfcc2287974bc840b28d5f20d8f0d79f2c1238ffa2e010c4fb6c2672074a0ee92816189cd71df18d515ca85e08b53e91501378065efcbc5006ad6b13ccb8655a586332d43723469435d1be34ba0caf0d5f40a2f8b1a15ed36f0fdeab5d27c6d77c5e8a5efa5c4473589bae29ab49409abda03d2f9d0338e447654aab22b5ac618036191fcc912c4b271d3be121a3f8cfb068541d854071ef50acf6f6a955d8b31c8c3f72aa00572964ece1cbcdd589cddcf0eb6f9bf7e48e73c9404f5aaa8ac5b2c346c5b5532d6f3affb8ca2c2ac1872c8b126c4180905a63b6db5b242a9b0c66159f10755eecb2b07d4baba5dbfd471d0e4d028ff74221702450647838cef1bc7e5b1bfda273e17c98d2f0aa8c9bf186b70f99bc04c0a6818e513c09cf7e0f59ec748d2b78d3d169e33d52452fa4abe24327087af4a1625bc4da102f9e9d8c07f8372e31caf7420df9755f2b43af7056fa11101dfe12cc7ab96535e642a76d86d66bbc983d82700aafbbb30dd5392d6ccad52646d932f52e68df43417ff910f45aa52157702f4d2a4a5b875545e047f434c9fa69cf584383c71c67cfea0349f9c236b4bffac3da6f9bd7b320d35b59dc05bac1e1a0791101f4e4db2772fcf852353e921a38ede1d0705d1be9983ad4c7bff1a15755124dd229112203f34fffe1ed8951a4a1fe0832af9aaf02f0bd8b0591e59efe86cf5e2d6767ab90bdb1446d49393862fba2f761dd5a23c43373e17336c799602bc1ef35d2208c0519c1288516147a703f16c2837eb8802deb27f83beaa0ac0c626a1ac4d322f40710ace0faa6a234f7225c8f9704de47de79cdd537eca68c228b43fd0815a63c0c25edfdb2973e1e35f80f11e96b54c1ba6ebd99acb147cfd530085d317dcfa3a574346dd436ea7655ee1d7f6a7ffda00c8f82489af9d16d2add72376d97d081e70f90eaa106d8bc3db6d06f8b03f45537630643d37c3edc7cde5d24edae1fcfad953e8fef11c5a28bd9238051b48c45ad1b9058b36c93c4b34ccb9b1971585ba7ef6f21c033ed03c266ac171adf29977e7bbf3004fe7ddb9db7630752f8fdc6898f7c99a99eaeeac5213627ecb093df9c82f56175dc72bffe5e5980187af2a62dd053f390b109be3302d60b9190c3def0b805208283c645afc7c8ec346db063190f2637913788e018e2d2d9ad655e114d7deb94cbbc3315b631e8bd8597b846c53ebd6cb979681b9e77e5e1380b22d4fb367d57ec069bc2dc6f1d39bf4c74fccfd6c106f31720454e8965253cd2c5dda78adf2692dfa3f28821753af9ec235dbbedff69ad9ff24a2c3902377ea1f1c596959b8fb7d912dc5b54429fd37ab30e43b21ff0664c6d44ae47c51a9f47a739cf08dceff350d26fc8fb3d1e2c5c87fc6c7effb84e7f3f675a653b1b9801e232c9ca6ac66afda4395d057cc3cf0b13c5ac788c7643000990331ccb7684a6ec449c32fc9f35dde6e1d407d7f7d220aa0d09e820f069280bc5f8d51ffac6b28fc85e73eb2e859285526d6a176a9d4d631354266f84d7e943a30cfb3d6a5e9e58d7292331ae7a3d767cba8d40707250a7b2c96a9d3666184e5457c91710d04510ec2ff397a49c0f54eb9d16cc9d36e6ea07195e479a7239d286250bf9f17ecd99b62da2466fd505e8881411c52a05da7917038389bede4fe9864209ac47461b5df79f8a1478d2008768592d7047f4507686e97b04bf5b066283789212096f1869a469a5bce224ab0be03aef9969a56a496e6bbd2f27d2ab365fa43020a375a523ae493ced3779dc72819c4ab859b6799fb9abfa6dbd3774c5a724d2004b0c36ddd7620ce70bbecd320bfecd8dd15384410c0af22ff1a43078c84dcb81b2d5f77c2e7f1835e232e7519fc70a9d5ae57995e069afc89379f17a2ee209afeaf58a62fe426d0b09bec61c8ddc3ebad4e250cbcc3e86dc9317e03223b905db8b3fe3704d478c4cb56b9cfc59c5f11634d9f332892179a99552c488c521b6968aba98a2e0a3aa790a167c57ae1a1e0bc7978869b7f7688d13aa941a99901ea5230066029a23a16d5ce32532499c475052250f6b0efc26c451c059749a6966885235bfccbe1d4fecd09bd2250056678bcca805f5f35c85eb9df481317f1fedaa293244d54fc1bc0527ef867316eda08e96d1708307243a4268d575e352e8f15c9f53015f7e66b4f614087fe73c2d61c0b8491f194c4dfd665a46251c54f89c8d904726f6bb790c5c1ec009b85371563d22bb4780732b6192969e137abaab72b67620cd6513b00dabc1659121ddd5fa373c6b0956ebb50eb0af8066dd3628579c61638e42b066be5437788e3769da6372403ef5b062d13520dd34598a6d75db6958c831f6061c6ee57f6088f04434f7979cfca879931da27a2e4bb428c1ad46ef08c7a04586792f367a11d434522de1204b84871e2886848361e2258a2827c46ed9580fb8805a8f08997c58551992bf3076ecd574b8da972232cc571070ee027e8f1b598f9c5a07026373351a67c8c18e38c83f59f5de06e05a8d8008438b8e468383381bcbc57c5fc9cc1904c10f3752f22d451fde8d389d36e194e1edffead5e5ebe7967736f691ea94b343642980a7cb2ba3df1655bda1ccd0686fe5e961f0affc0aab8bd90152f19f7685df07007198989c622f5d41de8d703e7bef3d0e79d62e24332ee739a452af62aa20dcc3994852776b8552b9820c1a562196da33b81b224d4441c9fcdec3ca01476bf9cf3d942c6bd5ae671bb085c16b62b1610a6f4e3c278bbd0624b5127164ae7ea3f2d38da55e9226339e79c7e8dccd9449fd2d46d6f959c898c0157da420649e853756c3bbc50bd78c1e86484ab1e10ad8306b47a02b8022874c5927485055ef30b40bee05aee79617246a9758b90f5cb8937ad211f013b0de4d223a4b63e029e6537399d13acc661b4df591e7c58e23affa336f762e758a3cf56b33d81fdb421fa49f39eebee03d411b1dde856ed3581c8daaca7d77bf8b3ed236ec539695fc771d5d4f4070f3ebb1bedd948ee669648b75f61c602ec1f718582e78783ec418b96e4805efc0cfa7ec523796f745d8f44cc62e814cdbdb9d8b60943f3f54eec0ded52ec03d1e500ca9f0acdb33653875f12e4348540c4d6d69aeefb269a3576850c0a699d2c1249eb119cf96a0b677426656367a6afef0e5b00a6cea6f46d7569c249f9dc0f0705da67e4ceeb4c398fce82f60279ce44075294f0e2cd53b76c85ba36bf1085b90cf2849180003347f3df9e88df2d3abf3837f7d408abaf24cd77e4f3b946be3e5a770bd33c6399fc2e06f3dd456c8085859a6dc20bdfd3e0d0024b6b9f2aff837f31b3eee39315d1195a26adea2269aca42603727845be2630dd24c803f6ca1824328fbc160690f9dcb99a4235531898d73827e6e3a9bd7700648f72f159454c31029bdaad74b68532a76681d217a23e254f43201430108b718bdf7ef1909bf1c0a307c8984ee00d08c86a237f640646f05d0d1bf2825d8ca0dc7bbd079159a6266c33c2ab4f99fc9a94539d8a4020cc070083534fb9c5e6b65b4cbc3e490a43e9d5f9316354830f908ada652a734c489a8f58e36ae13957257628aa1f6e175570127e3e2716b6b5529c780a92198755fff6973ef4ab38465ff89d109a9fc57e71324afebe843e184b695e20140d0571dba7adc7f031148d1d01891ba5d10cd6fbcd162a52776a36514ca09dad6966db41ecb0b627362076e160b7814ec9b1406c78e89e16281331eb69a6f5ac21492414fea1d18b34195cec3ecefa11afc1ecc0b705f82e1365fcdc1f896d3c4978110913366d23c19f36a768a4f245953fc1fefe14bcadbf739cb3ea0c2e22cc93b70ff9c305e031bb4f50eaa35d72cff4e2ee4f74c6eb349a5b717516e2d97fbfa1fcb602777f67643e0717ca51fceaa25ac9e5ccc62e0c727dcf27796057201fb5fded56a25ff6ca288206d49cd3f68b69a7782142062defb6d40ac731cce51db00a2224f7e1f083590818d35142ac0614971f722ec764b2eb507b0b9ad50520a78355f9d7ab8dd71c/sbin/servicerootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroothaproxyhaproxyrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroothaproxyhaproxy-2.0.14-11.11.1.src.rpmconfig(haproxy)haproxyhaproxy(x86-64)haproxy-1.5haproxy-doc @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@    /bin/sh/bin/sh/bin/sh/bin/shconfig(haproxy)libc.so.6()(64bit)libc.so.6(GLIBC_2.10)(64bit)libc.so.6(GLIBC_2.11)(64bit)libc.so.6(GLIBC_2.14)(64bit)libc.so.6(GLIBC_2.15)(64bit)libc.so.6(GLIBC_2.16)(64bit)libc.so.6(GLIBC_2.2.5)(64bit)libc.so.6(GLIBC_2.3)(64bit)libc.so.6(GLIBC_2.3.2)(64bit)libc.so.6(GLIBC_2.3.4)(64bit)libc.so.6(GLIBC_2.4)(64bit)libc.so.6(GLIBC_2.5)(64bit)libc.so.6(GLIBC_2.6)(64bit)libcrypt.so.1()(64bit)libcrypt.so.1(GLIBC_2.2.5)(64bit)libcrypto.so.1.1()(64bit)libcrypto.so.1.1(OPENSSL_1_1_0)(64bit)libcrypto.so.1.1(OPENSSL_1_1_1)(64bit)liblua5.3.so.5()(64bit)libpcre.so.1()(64bit)libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.2.5)(64bit)libpthread.so.0(GLIBC_2.3.2)(64bit)libpthread.so.0(GLIBC_2.3.4)(64bit)librt.so.1()(64bit)librt.so.1(GLIBC_2.2.5)(64bit)librt.so.1(GLIBC_2.3.3)(64bit)libssl.so.1.1()(64bit)libssl.so.1.1(OPENSSL_1_1_0)(64bit)libssl.so.1.1(OPENSSL_1_1_1)(64bit)libsystemd.so.0()(64bit)libsystemd.so.0(LIBSYSTEMD_209)(64bit)libz.so.1()(64bit)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)systemdsystemdsystemdsystemdvim2.0.14-11.11.13.0.4-14.6.0-14.0-15.2-14.14.1a,@a @_^@^@]@]@]@]@]@](]]^][][][]@1@]$]@]@]@]\-@\ac\73\[[[[[[v[ug@[3|@[3|@[0@[ @Z?ZȲZZ%ZZU@UcUPUG_@UD@U4@U/@UTE@TD@TԬT@T@T@TdTxcTuTuTmT_W@TSyTPTBV@TAvarkoly@suse.comemil.penchev@suse.comvarkoly@suse.compablo.bravo@suse.comdmaiocchi@suse.commrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.dekgronlund@suse.comkgronlund@suse.comkukuk@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.dekgronlund@suse.comkgronlund@suse.comjengelh@inai.demrueckert@suse.demrueckert@suse.dekgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.commrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.dekgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.commrueckert@suse.dekgronlund@suse.commrueckert@suse.dejengelh@inai.dekgronlund@suse.comkgronlund@suse.comkgronlund@suse.commrueckert@suse.demrueckert@suse.dekgronlund@suse.comkgronlund@suse.commrueckert@suse.demrueckert@suse.demrueckert@suse.dekgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.commrueckert@suse.dekgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.commrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.dee.istomin@edss.eemrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.dedmueller@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.comkgronlund@suse.commrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.dekgronlund@suse.commrueckert@suse.deaspiers@suse.commrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.demrueckert@suse.deledest@gmail.commrueckert@suse.dekgronlund@suse.comledest@gmail.commrueckert@suse.dekgronlund@suse.commrueckert@suse.dekgronlund@suse.com- CVE-2021-40346: haproxy: request smuggling vulnerability in HTX (>= 2.0) (bsc#1189877) Added patch: 0001-2.0-2.3-BUG-MAJOR-htx-fix-missing-header-name-length-check-i.patch- Fixes HAProxy vulnerabilities on H2 (bsc#1189366) Added patch: haproxy-2.0-h2_enforce_checks_on_the_method_syntax_bef.patch.- bsc#1178277 - L3: SLES15sp2: haproxy does not support TLS1.3, it is still build with openssl version 1.1.0. Branch for SLE15-SP2 to build against openssl-1.1.1d- Removed patch: haproxy-2.0-hpack-tbl.patch as already fixed in 2.0.14 - Update to version 2.0.14: (bsc#1169457) * [RELEASE] Released version 2.0.14 * BUG/MINOR: namespace: avoid closing fd when socket failed in my_socketat * BUG/MEDIUM: muxes: Use the right argument when calling the destroy method. * SCRIPTS: announce-release: use mutt -H instead of -i to include the draft * MINOR: http-htx: Add a function to retrieve the headers size of an HTX message * MINOR: filters: Forward data only if the last filter forwards something * BUG/MINOR: filters: Count HTTP headers as filtered data but don't forward them * BUG/MINOR: http-ana: Matching on monitor-uri should be case-sensitive * BUG/MAJOR: http-ana: Always abort the request when a tarpit is triggered * MINOR: ist: add an iststop() function * BUG/MINOR: http: http-request replace-path duplicates the query string * BUG/MEDIUM: shctx: make sure to keep all blocks aligned * MINOR: compiler: move CPU capabilities definition from config.h and complete them * BUG/MEDIUM: ebtree: don't set attribute packed without unaligned access support * BUILD: fix recent build failure on unaligned archs * CLEANUP: cfgparse: Fix type of second calloc() parameter * BUG/MINOR: sample: fix the json converter's endian-sensitivity * BUG/MEDIUM: ssl: fix several bad pointer aliases in a few sample fetch functions * BUG/MINOR: connection: make sure to correctly tag local PROXY connections * MINOR: compiler: add new alignment macros * BUILD: ebtree: improve architecture-specific alignment * BUG/MINOR: sample: Make sure to return stable IDs in the unique-id fetch * BUG/MINOR: dns: ignore trailing dot * MINOR: contrib/prometheus-exporter: Add heathcheck status/code in server metrics * MINOR: contrib/prometheus-exporter: Add the last heathcheck duration metric * BUG/MEDIUM: random: initialize the random pool a bit better * MINOR: tools: add 64-bit rotate operators * BUG/MEDIUM: random: implement a thread-safe and process-safe PRNG * MINOR: backend: use a single call to ha_random32() for the random LB algo * BUG/MINOR: checks/threads: use ha_random() and not rand() * BUG/MAJOR: list: fix invalid element address calculation * MINOR: debug: report the task handler's pointer relative to main * BUG/MEDIUM: debug: make the debug_handler check for the thread in threads_to_dump * MINOR: haproxy: export main to ease access from debugger * BUG/MINOR: wdt: do not return an error when the watchdog couldn't be enabled * DOC: fix incorrect indentation of http_auth_* * OPTIM: startup: fast unique_id allocation for acl. * BUG/MINOR: pattern: Do not pass len = 0 to calloc() * DOC: configuration.txt: fix various typos * DOC: assorted typo fixes in the documentation and Makefile * BUG/MINOR: init: make the automatic maxconn consider the max of soft/hard limits * BUG/MAJOR: proxy_protocol: Properly validate TLV lengths * REGTEST: make the PROXY TLV validation depend on version 2.2 * MINOR: htx: Add a function to return a block at a specific offset * BUG/MEDIUM: cache/filters: Fix loop on HTX blocks caching the response payload * BUG/MEDIUM: compression/filters: Fix loop on HTX blocks compressing the payload * BUG/MINOR: http-ana: Reset request analysers on a response side error * BUG/MINOR: lua: Ignore the reserve to know if a channel is full or not * BUG/MINOR: http-rules: Preserve FLT_END analyzers on reject action * BUG/MINOR: http-rules: Fix a typo in the reject action function * BUG/MINOR: rules: Preserve FLT_END analyzers on silent-drop action * BUG/MINOR: rules: Increment be_counters if backend is assigned for a silent-drop * DOC: fix typo about no-tls-tickets * DOC: improve description of no-tls-tickets * DOC: ssl: clarify security implications of TLS tickets * BUILD: wdt: only test for SI_TKILL when compiled with thread support * BUG/MEDIUM: random: align the state on 2*64 bits for ARM64 * BUG/MINOR: haproxy: always initialize sleeping_thread_mask * BUG/MINOR: listener/mq: do not dispatch connections to remote threads when stopping * BUG/MINOR: haproxy/threads: try to make all threads leave together * DOC: proxy_protocol: Reserve TLV type 0x05 as PP2_TYPE_UNIQUE_ID * BUILD: on ARM, must be linked to libatomic. * BUILD: makefile: fix regex syntax in ARM platform detection * BUILD: makefile: fix expression again to detect ARM platform * BUG/MEDIUM: peers: resync ended with RESYNC_PARTIAL in wrong cases. * DOC: assorted typo fixes in the documentation * MINOR: wdt: Move the definitions of WDTSIG and DEBUGSIG into types/signal.h. * BUG/MEDIUM: wdt: Don't ignore WDTSIG and DEBUGSIG in __signal_process_queue(). * MINOR: memory: Change the flush_lock to a spinlock, and don't get it in alloc. * BUG/MINOR: connections: Make sure we free the connection on failure. * REGTESTS: use "command -v" instead of "which" * REGTEST: increase timeouts on the seamless-reload test * BUG/MINOR: haproxy/threads: close a possible race in soft-stop detection * BUG/MINOR: peers: init bind_proc to 1 if it wasn't initialized * BUG/MINOR: peers: avoid an infinite loop with peers_fe is NULL * BUG/MINOR: peers: Use after free of "peers" section. * MINOR: listener: add so_name sample fetch * BUILD: ssl: only pass unsigned chars to isspace() * BUG/MINOR: stats: Fix color of draining servers on stats page * DOC: internals: Fix spelling errors in filters.txt * MINOR: http-rules: Add a flag on redirect rules to know the rule direction * BUG/MINOR: http_ana: make sure redirect flags don't have overlapping bits * MINOR: http-rules: Handle the rule direction when a redirect is evaluated * BUG/MINOR: filters: Use filter offset to decude the amount of forwarded data * BUG/MINOR: filters: Forward everything if no data filters are called * BUG/MINOR: http-ana: Reset request analysers on error when waiting for response * BUG/CRITICAL: hpack: never index a header into the headroom after wrapping 2020/02/13 : 2.0.13 * BUG/MINOR: checks: refine which errno values are really errors. * BUG/MEDIUM: checks: Only attempt to do handshakes if the connection is ready. * BUG/MEDIUM: connections: Hold the lock when wanting to kill a connection. * MINOR: config: disable busy polling on old processes * MINOR: ssl: Remove unused variable "need_out". * BUG/MINOR: h1: Report the right error position when a header value is invalid * BUG/MINOR: proxy: Fix input data copy when an error is captured * BUG/MEDIUM: http-ana: Truncate the response when a redirect rule is applied * BUG/MINOR: channel: inject output data at the end of output * BUG/MEDIUM: session: do not report a failure when rejecting a session * BUG/MINOR: stream-int: Don't trigger L7 retry if max retries is already reached * BUG/MINOR: mux-h2: use a safe list_for_each_entry in h2_send() * BUG/MEDIUM: mux-h2: fix missing test on sending_list in previous patch * BUG/MEDIUM: mux-h2: don't stop sending when crossing a buffer boundary * BUG/MINOR: cli/mworker: can't start haproxy with 2 programs * REGTEST: mcli/mcli_start_progs: start 2 programs * BUG/MEDIUM: mworker: remain in mworker mode during reload * BUG/MEDIUM: mux_h1: Don't call h1_send if we subscribed(). * BUG/MAJOR: hashes: fix the signedness of the hash inputs * REGTEST: add sample_fetches/hashes.vtc to validate hashes * BUG/MEDIUM: cli: _getsocks must send the peers sockets * BUG/MINOR: stream: don't mistake match rules for store-request rules * BUG/MEDIUM: connection: add a mux flag to indicate splice usability * BUG/MINOR: pattern: handle errors from fgets when trying to load patterns * BUG/MINOR: cache: Fix leak of cache name in error path * BUG/MINOR: dns: Make dns_query_id_seed unsigned * BUG/MINOR: 51d: Fix bug when HTX is enabled * BUILD: pattern: include errno.h * BUG/MINOR: http-ana/filters: Wait end of the http_end callback for all filters * BUG/MINOR: http-rules: Remove buggy deinit functions for HTTP rules * BUG/MINOR: stick-table: Use MAX_SESS_STKCTR as the max track ID during parsing * BUG/MINOR: tcp-rules: Fix memory releases on error path during action parsing * MINOR: proxy/http-ana: Add support of extra attributes for the cookie directive * BUG/MINOR: http_act: don't check capture id in backend * BUG/MEDIUM: 0rtt: Only consider the SSL handshake. * BUG/MINOR: stktable: report the current proxy name in error messages * BUG/MEDIUM: mux-h2: make sure we don't emit TE headers with anything but "trailers" * BUILD: cfgparse: silence a bogus gcc warning on 32-bit machines * BUG/MINOR: dns: allow srv record weight set to 0 * BUG/MEDIUM: ssl: Don't forget to free ctx->ssl on failure. * BUG/MINOR: tcpchecks: fix the connect() flags regarding delayed ack * BUG/MEDIUM: pipe: fix a use-after-free in case of pipe creation error * BUG/MINOR: connection: fix ip6 dst_port copy in make_proxy_line_v2 * BUG/MEDIUM: connections: Don't forget to unlock when killing a connection. * BUG/MEDIUM: memory_pool: Update the seq number in pool_flush(). * MINOR: memory: Only init the pool spinlock once. * BUG/MEDIUM: memory: Add a rwlock before freeing memory. * BUG/MAJOR: memory: Don't forget to unlock the rwlock if the pool is empty. * BUG/MINOR: ssl: we may only ignore the first 64 errors * CONTRIB: debug: add missing flags SF_HTX and SF_MUX * CONTRIB: debug: add the possibility to decode the value as certain types only * CONTRIB: debug: support reporting multiple values at once * MINOR: acl: Warn when an ACL is named 'or' * CONTRIB: debug: also support reading values from stdin * SCRIPTS: announce-release: place the send command in the mail's header * SCRIPTS: announce-release: allow the user to force to overwrite old files * MINOR: build: add linux-glibc-legacy build TARGET * BUG/MINOR: unix: better catch situations where the unix socket path length is close to the limit * MINOR: http: add a new "replace-path" action * BUG/MINOR: ssl: Possible memleak when allowing the 0RTT data buffer. * BUG/MINOR: dns: allow 63 char in hostname * BUG/MEDIUM: listener: only consider running threads when resuming listeners * BUG/MINOR: listener: enforce all_threads_mask on bind_thread on init * BUG/MINOR: tcp: avoid closing fd when socket failed in tcp_bind_listener * DOC: word converter ignores delimiters at the start or end of input string * BUG/MINOR: tcp: don't try to set defaultmss when value is negative * SCRIPTS: make announce-release executable again 2019/12/21 : 2.0.12 * DOC: Improve documentation of http-re(quest|sponse) replace-(header|value|uri) * DOC: clarify the fact that replace-uri works on a full URI * BUG/MINOR: sample: fix the closing bracket and LF in the debug converter * BUG/MINOR: sample: always check converters' arguments * BUG/MEDIUM: ssl: Don't set the max early data we can receive too early. * MINOR: task: only check TASK_WOKEN_ANY to decide to requeue a task * BUG/MAJOR: task: add a new TASK_SHARED_WQ flag to fix foreing requeuing * BUG/MEDIUM: ssl: Revamp the way early data are handled. * MINOR: fd/threads: make _GET_NEXT()/_GET_PREV() use the volatile attribute * BUG/MEDIUM: fd/threads: fix a concurrency issue between add and rm on the same fd * BUG/MINOR: ssl: openssl-compat: Fix getm_ defines * BUG/MEDIUM: stream: Be sure to never assign a TCP backend to an HTX stream * BUILD: ssl: improve SSL_CTX_set_ecdh_auto compatibility 2019/12/11 : 2.0.11 * BUG/MINOR: stream: init variables when the list is empty * BUG/MINOR: contrib/prometheus-exporter: Use HTX errors and not legacy ones * BUG/MINOR: contrib/prometheus-exporter: decode parameter and value only * BUG/MINOR: http-htx: Don't make http_find_header() fail if the value is empty * DOC: Clarify behavior of server maxconn in HTTP mode * DOC: clarify matching strings on binary fetches * DOC: move the "group" keyword at the right place * BUG/MEDIUM: stream-int: don't subscribed for recv when we're trying to flush data * BUG/MINOR: stream-int: avoid calling rcv_buf() when splicing is still possible * BUG/MEDIUM: listener/thread: fix a race when pausing a listener * BUG/MINOR: ssl: certificate choice can be unexpected with openssl >= 1.1.1 * BUG/MEDIUM: mux-h1: Never reuse H1 connection if a shutw is pending * BUG/MINOR: mux-h1: Don't rely on CO_FL_SOCK_RD_SH to set H1C_F_CS_SHUTDOWN * BUG/MINOR: mux-h1: Fix conditions to know whether or not we may receive data * BUG/MEDIUM: tasks: Make sure we switch wait queues in task_set_affinity(). * BUG/MEDIUM: checks: Make sure we set the task affinity just before connecting. * BUG/MINOR: mux-h1: Be sure to set CS_FL_WANT_ROOM when EOM can't be added * BUG/MINOR: proxy: make soft_stop() also close FDs in LI_PAUSED state * BUG/MINOR: listener/threads: always use atomic ops to clear the FD events * BUG/MINOR: listener: also clear the error flag on a paused listener * BUG/MEDIUM: listener/threads: fix a remaining race in the listener's accept() * DOC: document the listener state transitions * BUG/MAJOR: dns: add minimalist error processing on the Rx path * BUG/MEDIUM: proto_udp/threads: recv() and send() must not be exclusive. * BUG/MEDIUM: kqueue: Make sure we report read events even when no data. * DOC: listeners: add a few missing transitions * BUG/MINOR: tasks: only requeue a task if it was already in the queue * DOC: proxies: HAProxy only supports 3 connection modes * BUILD/MINOR: ssl: shut up a build warning about format truncation * BUILD/MINOR: tools: shut up the format truncation warning in get_gmt_offset() * BUILD: do not disable -Wformat-truncation anymore * DOC: remove references to the outdated architecture.txt * BUG/MINOR: log: fix minor resource leaks on logformat error path * BUG/MINOR: mworker: properly pass SIGTTOU/SIGTTIN to workers * BUG/MINOR: listener: do not immediately resume on transient error * BUG/MINOR: server: make "agent-addr" work on default-server line * BUG/MINOR: listener: fix off-by-one in state name check * BUILD/MINOR: unix sockets: silence an absurd gcc warning about strncpy()- CVE-2020-11100: Fixed an H2/HPAC vulnerability (bsc#1168023) - Added patch: haproxy-2.0-hpack-tbl.patch- Update to version 2.0.10+git0.ac198b92: (bsc#1157712) (bsc#1157714) * [RELEASE] Released version 2.0.10 * SCRIPTS: git-show-backports: add "-s" to proposed cherry-pick commands * SCRIPTS: create-release: show the correct origin name in suggested commands * BUG/MAJOR: mux-h2: don't try to decode a response HEADERS frame in idle state * BUG/MAJOR: h2: make header field name filtering stronger * BUG/MAJOR: h2: reject header values containing invalid chars * MINOR: ist: add ist_find_ctl() * BUG/MINOR: ssl: fix curve setup with LibreSSL * BUG/MINOR: cli: fix out of bounds in -S parser * DOC: Add documentation about the use-service action * DOC: Add missing stats fields in the management manual * BUG/MINOR: mux-h1: Adjust header case when chunked encoding is add to a message * BUG/MINOR: mux-h1: Fix a UAF in cfg_h1_headers_case_adjust_postparser() * MEDIUM: mux-h1: Add the support of headers adjustment for bogus HTTP/1 apps * REGTEST: vtest can now enable mcli with its own flag * MINOR: stats: Report max times in addition of the averages for sessions * BUG/MINOR: stream-int: Fix si_cs_recv() return value * MINOR: contrib/prometheus-exporter: Add a param to ignore servers in maintenance * MINOR: contrib/prometheus-exporter: filter exported metrics by scope * MINOR: contrib/prometheus-exporter: report the number of idle conns per server * BUG/MINOR: contrib/prometheus-exporter: Rename some metrics * MINOR: contrib/prometheus-exporter: Report metrics about max times for sessions * MINOR: counters: Add fields to store the max observed for {q,c,d,t}_time * MINOR: stream: Remove the lock on the proxy to update time stats * MINOR: freq_ctr: Make the sliding window sums thread-safe * BUG/MINOR: http-ana: Properly catch aborts during the payload forwarding * BUG/MINOR: mux-h1: Fix tunnel mode detection on the response path * BUILD: debug: Avoid warnings in dev mode with -02 because of some BUG_ON tests * BUG/MEDIUM: stream-int: Don't loose events on the CS when an EOS is reported * BUILD/MINOR: ssl: fix compiler warning about useless statement * BUG/MINOR: peers: "peer alive" flag not reset when deconnecting. * BUG/MEDIUM: mworker: don't fill the -sf argument with -1 during the reexec- Update to version 2.0.9+git6.26b7b800: * BUG/MINOR: ssl: fix crt-list neg filter for openssl < 1.1.1 * BUG/MINOR: peers: Wrong null "server_name" data field handling. * MINOR: peers: Add debugging information to "show peers". * MINOR: peers: Add TX/RX heartbeat counters. * MINOR: peers: Alway show the table info for disconnected peers.- Update to version 2.0.9+git1.caf02113: * BUG/MINOR: init: fix set-dumpable when using uid/gid- Update to version 2.0.9+git0.efac87ee (bsc#1154980) (CVE-2019-18277): * [RELEASE] Released version 2.0.9 * BUG/MINOR: mux-h1: Don't set CS_FL_EOS on a read0 when receiving data to pipe * BUG/MEDIUM: filters: Don't call TCP callbacks for HTX streams * BUG/MINOR: log: limit the size of the startup-logs * BUILD: contrib/da: remove an "unused" warning * MINOR: memory: also poison the area on freeing * CLEANUP: session: slightly simplify idle connection cleanup logic * BUG/MEDIUM: Make sure we leave the session list in session_free(). * BUG/MEDIUM: listeners: always pause a listener on out-of-resource condition * BUG/MINOR: queue/threads: make the queue unlinking atomic * DOC: management: fix typo on "cache_lookups" stats output * DOC: management: document cache_hits and cache_lookups in the CSV format * DOC: management: document reuse and connect counters in the CSV format * BUG: dns: timeout resolve not applied for valid resolutions * BUG/MINOR: action: do-resolve now use cached response * BUG/MEDIUM: stream: Be sure to release allocated captures for TCP streams * MINOR: doc: http-reuse connection pool fix * BUG/MEDIUM: stream: Be sure to support splicing at the mux level to enable it * BUG/MEDIUM: mux-h1: Disable splicing for chunked messages * BUG/MEDIUM: mux-h2: immediately report connection errors on streams * BUG/MEDIUM: mux-h2: immediately remove a failed connection from the idle list * BUG/MEDIUM: mux-h2: report no available stream on a connection having errors * BUG/MINOR: config: Update cookie domain warn to RFC6265 * BUG/MEDIUM: servers: Only set SF_SRV_REUSED if the connection if fully ready. * BUG/MEDIUM: stream_interface: Only use SI_ST_RDY when the mux is ready. * MINOR: mux: Add a new method to get informations about a mux. * BUG/MINOR: spoe: fix off-by-one length in UUID format string * BUG/MAJOR: stream-int: Don't receive data from mux until SI_ST_EST is reached * BUG/MINOR: mux-h2: Don't pretend mux buffers aren't full anymore if nothing sent * BUG/MINOR: cli: don't call the kw->io_release if kw->parse failed * MINOR: tcp: avoid confusion in time parsing init * BUG/MINOR: mux-h2: do not emit logs on backend connections * MINOR: config: warn on presence of "\n" in header values/replacements- Update to version 2.0.8+git0.60e6020c: * [RELEASE] Released version 2.0.8 * BUG/MEDIUM: pattern: make the pattern LRU cache thread-local and lockless * BUG/MINOR: stick-table: fix an incorrect 32 to 64 bit key conversion * BUG/MINOR: ssl: fix memcpy overlap without consequences. * BUG/MEDIUM: http: unbreak redirects in legacy mode * BUG/MINOR: mux-h2: also make sure blocked legacy connections may expire * BUG/MINOR: sample: Make the `field` converter compatible with `-m found` * BUG/MINOR: cache: alloc shctx after check config * BUG/MINOR: stick-table: Never exceed (MAX_SESS_STKCTR-1) when fetching a stkctr * BUG/MINOR: ssl: Fix fd leak on error path when a TLS ticket keys file is parsed * BUG/MINOR: mworker/cli: reload fail with inherited FD * BUG/MEDIUM: ssl: 'tune.ssl.default-dh-param' value ignored with openssl > 1.1.1 * CLEANUP: bind: handle warning label on bind keywords parsing. * CLEANUP: ssl: make ssl_sock_load_dh_params handle errcode/warn * CLEANUP: ssl: make ssl_sock_put_ckch_into_ctx handle errcode/warn * CLEANUP: ssl: make ssl_sock_load_cert*() return real error codes * REGTEST: mcli/mcli_show_info: launch a 'show info' on the master CLI * BUG/MEDIUM: mux_pt: Only call the wake emthod if nobody subscribed to receive. * BUG/MEDIUM: mux_pt: Don't destroy the connection if we have a stream attached. * Revert e8826ded5fea3593d89da2be5c2d81c522070995. * BUG/MAJOR: idle conns: schedule the cleanup task on the correct threads * BUG/MEDIUM: mux_pt: Make sure we don't have a conn_stream before freeing. * BUG/MINOR: tcp: Don't alter counters returned by tcp info fetchers * BUG/MINOR: mworker/ssl: close openssl FDs unconditionally * BUG/MINOR: http-htx: Properly set htx flags on error files to support keep-alive * MINOR: version: make the version strings variables, not constants * BUG/MINOR: WURFL: fix send_log() function arguments * BUG/MINOR: mux-h1: Capture ignored parsing errors * BUG/MINOR: mux-h1: Mark the output buffer as full when the xfer is interrupted * BUG/MINOR: chunk: Fix tests on the chunk size in functions copying data * BUG/MEDIUM: htx: Catch chunk_memcat() failures when HTX data are formatted to h1 * BUILD: ssl: wrong #ifdef for SSL engines code * BUG/MINOR: ssl: abort on sni_keytypes allocation failure * BUG/MINOR: ssl: free the sni_keytype nodes * BUG/MINOR: ssl: abort on sni allocation failure * BUG/MEDIUM: applet: always check a fast running applet's activity before killing * MINOR: stats: mention in the help message support for "json" and "typed" * DOC: fix typo in Prometheus exporter doc * DOC: clarify some points around http-send-name-header's behavior * BUG/MEDIUM: cache: make sure not to cache requests with absolute-uri * BUG/MINOR: peers: crash on reload without local peer. * BUG/MEDIUM: mux-h2: do not enforce timeout on long connections * BUILD: ebtree: make eb_is_empty() and eb_is_dup() take a const * MINOR: mux-h2: add a per-connection list of blocked streams * BUG/MINOR: action: do-resolve does not yield on requests with body * BUG/MEDIUM: lua: Store stick tables into the sample's `t` field * BUG/MINOR: lua: Properly initialize the buffer's fields for string samples in hlua_lua2(smp|arg) * BUG/MINOR: stats: Add a missing break in a switch statement- Update to version 2.0.7+git0.1909aa1e: * [RELEASE] Released version 2.0.7 * BUG/MEDIUM: namespace: fix fd leak in master-worker mode * DOC: Fix documentation about the cli command to get resolver stats * BUG/MINOR: contrib/prometheus-exporter: Return the time averages in seconds * MINOR: stats: Add the support of float fields in stats * MINOR: spoe: Support the async mode with several threads * MINOR: spoe: Improve generation of the engine-id * BUG/MEDIUM: spoe: Use a different engine-id per process * BUG/MINOR: mux-h1: Do h2 upgrade only on the first request * BUG/MAJOR: mux_h2: Don't consume more payload than received for skipped frames * BUG/MINOR: mux-h2: Use the dummy error when decoding headers for a closed stream * BUG/MEDIUM: mux-h2: don't reject valid frames on closed streams * BUG/MEDIUM: namespace: close open namespaces during soft shutdown * BUG/MINOR: mux-h2: do not wake up blocked streams before the mux is ready * BUG/MEDIUM: checks: make sure the connection is ready before trying to recv * BUG/MEDIUM: stream-int: Process connection/CS errors during synchronous sends * BUG/MINOR: stream-int: Process connection/CS errors first in si_cs_send() * BUG/MEDIUM: check/threads: make external checks run exclusively on thread 1 * BUG/MAJOR: mux-h2: Handle HEADERS frames received after a RST_STREAM frame * BUG/MINOR: mux-h2: Be sure to have a connection to unsubcribe * BUG/MEDIUM: stick-table: Properly handle "show table" with a data type argument- Update to version 2.0.6+git0.58706ab4: * [RELEASE] Released version 2.0.6 * MINOR: sample: Add UUID-fetch * BUG/MINOR: Missing stat_field_names (since f21d17bb) * BUG/MINOR: backend: Fix a possible null pointer dereference * BUG/MINOR: acl: Fix memory leaks when an ACL expression is parsed * BUG/MINOR: filters: Properly set the HTTP status code on analysis error * BUG/MEDIUM: http: also reject messages where "chunked" is missing from transfer-enoding * BUG/MINOR: ssl: always check for ssl connection before getting its XPRT context * BUG/MINOR: listener: Fix a possible null pointer dereference * MINOR: stats: report the number of idle connections for each server * BUG/MEDIUM: connection: don't keep more idle connections than ever needed * BUG/MAJOR: ssl: ssl_sock was not fully initialized. * BUG/MINOR: lb/leastconn: ignore the server weights for empty servers * MINOR: contrib/prometheus-exporter: Report DRAIN/MAINT/NOLB status for servers * BUG/MINOR: checks: do not uselessly poll for reads before the connection is up * BUG/MINOR: checks: make __event_chk_srv_r() report success before closing * BUG/MINOR: checks: start sending the request right after connect() * BUG/MINOR: checks: stop polling for write when we have nothing left to send * BUG/MEDIUM: cache: Don't cache objects if the size of headers is too big * BUG/MEDIUM: cache: Properly copy headers splitted on several shctx blocks * BUG/MINOR: mux-h1: Be sure to update the count before adding EOM after trailers * BUG/MINOR: mux-h1: Don't stop anymore input processing when the max is reached * BUG/MINOR: mux-h1: Fix size evaluation of HTX messages after headers parsing * BUG/MINOR: h1: Properly reset h1m when parsing is restarted * BUG/MINOR: http-ana: Reset response flags when 1xx messages are handled * BUG/MEDIUM: peers: local peer socket not bound. * BUG/MEDIUM: proto-http: Always start the parsing if there is no outgoing data * BUG/MEDIUM: url32 does not take the path part into account in the returned hash. * BUG/MEDIUM: listener/threads: fix an AB/BA locking issue in delete_listener() * BUG/MINOR: mworker: disable SIGPROF on re-exec * DOC: fixed typo in management.txt * BUG/MEDIUM: mux-h1: do not report errors on transfers ending on buffer full * BUG/MEDIUM: mux-h1: do not truncate trailing 0CRLF on buffer boundary * MEDIUM: debug: make the thread dump code show Lua backtraces * MINOR: lua: export applet and task handlers * MINOR: tools: add append_prefixed_str() * MINOR: debug: indicate the applet name when the task is task_run_applet()- Use %license instead of %doc [bsc#1082318] - Recommend apparmor, it's not required to work (make haproxy useable in a container)- enable prometheus exporter- enable verbose make output- Update to version 2.0.5+git0.d905f49a: * [RELEASE] Released version 2.0.5 * BUG/MEDIUM: mux_pt: Don't call unsubscribe if we did not subscribe. * MINOR: fd: make sure to mark the thread as not stuck in fd_update_events() * BUG/MINOR: stats: Wait the body before processing POST requests * BUG/MEDIUM: lua: Fix test on the direction to set the channel exp timeout * BUG/MEDIUM: mux_h1: Don't bother subscribing in recv if we're not connected. * BUG/MINOR: Fix prometheus '# TYPE' and '# HELP' headers * BUG/MINOR: lua: fix setting netfilter mark * BUG/MEDIUM: proxy: Don't use cs_destroy() when freeing the conn_stream. * BUG/MEDIUM: proxy: Don't forget the SF_HTX flag when upgrading TCP=>H1+HTX. * BUG/MINOR: buffers/threads: always clear a buffer's head before releasing it * MINOR: ssl: ssl_fc_has_early should work for BoringSSL * BUG/MINOR: ssl: fix 0-RTT for BoringSSL * BUG/MEDIUM: stick-table: Wrong stick-table backends parsing. * [RELEASE] Released version 2.0.4 * BUG/MEDIUM: checks: make sure to close nicely when we're the last to speak * BUG/MINOR: mux-h2: always reset rcvd_s when switching to a new frame * BUG/MINOR: mux-h2: always send stream window update before connection's * BUG/MEDIUM: mux-h2: do not recheck a frame type after a state transition * BUG/MINOR: mux-h2: do not send REFUSED_STREAM on aborted uploads * BUG/MINOR: mux-h2: use CANCEL, not STREAM_CLOSED in h2c_frt_handle_data() * BUG/MINOR: mux-h2: don't refrain from sending an RST_STREAM after another one * BUG/MEDIUM: fd: Always reset the polled_mask bits in fd_dodelete(). * BUG/MEDIUM: proxy: Make sure to destroy the stream on upgrade from TCP to H2 * BUG/MEDIUM: mux-h2: split the stream's and connection's window sizes * BUG/MEDIUM: mux-h2: unbreak receipt of large DATA frames * BUG/MINOR: stream-int: also update analysers timeouts on activity * BUG/MAJOR: http/sample: use a static buffer for raw -> htx conversion * BUG/MEDIUM: lb-chash: Ensure the tree integrity when server weight is increased * MINOR: wdt: also consider that waiting in the thread dumper is normal * BUG/MINOR: debug: fix a small race in the thread dumping code- Update to version 2.0.3+git14.0ff395c1 (bsc#1142529) (CVE-2019-14241): * BUG/MAJOR: queue/threads: avoid an AB/BA locking issue in process_srv_queue() * BUG/MINOR: htx: Fix free space addresses calculation during a block expansion * BUG/MINOR: hlua: Only execute functions of HTTP class if the txn is HTTP ready * MINOR: hlua: Add a flag on the lua txn to know in which context it can be used * MINOR: hlua: Don't set request analyzers on response channel for lua actions * BUG/MEDIUM: hlua: Check the calling direction in lua functions of the HTTP class * BUG/MINOR: hlua/htx: Reset channels analyzers when txn:done() is called * DOC: improve the wording in CONTRIBUTING about how to document a bug fix * BUG/MINOR: log: make sure writev() is not interrupted on a file output * BUG/MEDIUM: streams: Don't switch the SI to SI_ST_DIS if we have data to send. * BUG/MEDIUM: lb-chash: Fix the realloc() when the number of nodes is increased * BUILD: threads: add the definition of PROTO_LOCK * BUG/MINOR: proxy: always lock stop_proxy() * BUG/MEDIUM: protocols: add a global lock for the init/deinit stuff * [RELEASE] Released version 2.0.3 * BUG/CRITICAL: http_ana: Fix parsing of malformed cookies which start by a delimiter * BUG/MINOR: http_htx: Support empty errorfiles * BUG/MINOR: http_ana: Be sure to have an allocated buffer to generate an error * BUG/MEDIUM: tcp-checks: do not dereference inexisting conn_stream * BUG/MINOR: mux-h1: Close server connection if input data remains in h1_detach() * BUG/MEDIUM: mux-h1: Trim excess server data at the end of a transaction * BUG/MINOR: checks: do not exit tcp-checks from the middle of the loop * BUG/MINOR: session: Send a default HTTP error if accept fails for a H1 socket * BUG/MINOR: session: Emit an HTTP error if accept fails only for H1 connection * BUG/MINOR: debug: Remove flags CO_FL_SOCK_WR_ENA/CO_FL_SOCK_RD_ENA * DOC: htx: Update comments in HTX files * BUG/MINOR: hlua: Make the function txn:done() HTX aware * BUG/MINOR: cache/htx: Make maxage calculation HTX aware * BUG/MINOR: http_htx: Initialize HTX error messages for TCP proxies * BUG/MINOR: http_fetch: Fix http_auth/http_auth_group when called from TCP rules * BUG/MINOR: backend: do not try to install a mux when the connection failed * BUG/MEDIUM: http/htx: unbreak option http_proxy * BUG/MEDIUM: checks: Don't attempt to receive data if we already subscribed. * BUG/MINOR: dns: remove irrelevant dependency on a client connection * [RELEASE] Released version 2.0.2 * BUG/MEDIUM: threads: cpu-map designating a single thread/process are ignored * BUG/MEDIUM: tcp-check: unbreak multiple connect rules again * BUG/MINOR: mux-pt: do not pretend there's more data after a read0 * BUG/MEDIUM: streams: Don't redispatch with L7 retries if redispatch isn't set. * BUG/MEDIUM: streams: Don't give up if we couldn't send the request. * BUG/MINOR: mux-h1: Correctly report Ti timer when HTX and keepalives are used * BUG/MEDIUM: mux-h1: Don't release h1 connection if there is still data to send * BUG/MAJOR: listener: fix thread safety in resume_listener() * MINOR: task: introduce work lists * BUG/MEDIUM: servers: Fix a race condition with idle connections. * DOC: Fix typos and grammer in configuration.txt * BUG/MEDIUM: da: cast the chunk to string. * BUG/MEDIUM: checks: Don't attempt to read if we destroyed the connection. * BUG/MINOR: server: Be really able to keep "pool-max-conn" idle connections * BUG/MEDIUM: fd/threads: fix excessive CPU usage on multi-thread accept- Update to version 2.0.1+git27.5db881ff: * BUG/MINOR: ssl: revert empty handshake detection in OpenSSL <= 1.0.2 * BUG/MEDIUM: servers: Don't forget to set srv_cs to NULL if we can't reuse it. * BUG/MEDIUM: stream-int: Don't rely on CF_WRITE_PARTIAL to unblock opposite si * MINOR: stream-int: Factorize processing done after sending data in si_cs_send() * BUG/MINOR: mux-h1: Don't process input or ouput if an error occurred * BUG/MEDIUM: mux-h1: Handle TUNNEL state when outgoing messages are formatted * BUG/MEDIUM: lb_fas: Don't test the server's lb_tree from outside the lock * BUG/MEDIUM: http/applet: Finish request processing when a service is registered * MINOR: action: Add the return code ACT_RET_DONE for actions * BUG/MINOR: contrib/prometheus-exporter: Don't try to add empty data blocks * MINOR: server: Add "no-tfo" option. * BUG/MEDIUM: sessions: Don't keep an extra idle connection in sessions. * BUG/MEDIUM: servers: Authorize tfo in default-server. * BUG/MEDIUM: connections: Make sure we're unsubscribe before upgrading the mux. * BUG/MINOR: contrib/prometheus-exporter: Respect the reserve when data are sent * BUG/MINOR: hlua/htx: Respect the reserve when HTX data are sent * BUG/MEDIUM: channel/htx: Use the total HTX size in channel_htx_recv_limit() * BUG/MINOR: hlua: Don't use channel_htx_recv_max() * BUG/MINOR: contrib/prometheus-exporter: Don't use channel_htx_recv_max() * BUG/MEDIUM: checks: Make sure the tasklet won't run if the connection is closed. * BUG/MEDIUM: connections: Always call shutdown, with no linger. * BUG/MINOR: mux-h1: Don't return the empty chunk on HEAD responses * BUG/MINOR: mux-h1: Skip trailers for non-chunked outgoing messages * BUG/MEDIUM: checks: unblock signals in external checks * BUG/MEDIUM: mux-h1: Always release H1C if a shutdown for writes was reported * BUG/MEDIUM: ssl: Don't attempt to set alpn if we're not using SSL. * BUG/MINOR: mworker/cli: don't output a \n before the response * BUG/MINOR: mux-h1: Make format errors during output formatting fatal * BUG/MEDIUM: mux-h1: Use buf_room_for_htx_data() to detect too large messages * BUG/MEDIUM: proto_htx: Don't add EOM on 1xx informational messages * BUG/MINOR: log: Detect missing sampling ranges in config * BUG/MINOR: memory: Set objects size for pools in the per-thread cache * BUG/MAJOR: mux-h1: Don't crush trash chunk area when outgoing message is formatted * BUG/MINOR: htx: Save hdrs_bytes when the HTX start-line is replaced * BUG/MEDIUM: ssl: Don't do anything in ssl_subscribe if we have no ctx. * BUG/MEDIUM: connections: Always add the xprt handshake if needed. * BUG/MEDIUM: stream_interface: Don't add SI_FL_ERR the state is < SI_ST_CON. * BUG/MINOR: spoe: Fix memory leak if failing to allocate memory * BUG/MEDIUM: mworker/cli: command pipelining doesn't work anymore * BUG/MEDIUM: mworker: don't call the thread and fdtab deinit * BUG/MINOR: mworker-prog: Fix segmentation fault during cfgparse * BUG/MAJOR: sample: Wrong stick-table name parsing in "if/unless" ACL condition. * BUG/MEDIUM: lb_fwlc: Don't test the server's lb_tree from outside the lock * BUG/MEDIUM: mux-h2: Remove the padding length when a DATA frame size is checked * BUG/MEDIUM: mux-h2: Reset padlen when several frames are demux- Correct version line, which should be 2.0.0+git6.- allow the new master socket path in the apparmor profile- Update to version 2.0.0~git6.41dc8432: * BUG/MEDIUM: htx: Fully update HTX message when the block value is changed * MINOR: htx: Add the function htx_change_blk_value_len() * BUG/MEDIUM: compression: Set Vary: Accept-Encoding for compressed responses * BUG/MINOR: mux-h1: Add the header connection in lower case in outgoing messages * BUG/MINOR: lua/htx: Make txn.req_req_* and txn.res_rep_* HTX aware * BUG/MEDIUM: h2/htx: Update data length of the HTX when the cookie list is built- Update to version 2.0.0~git0.ba23630a: - new internal native HTTP representation called HTX, was already in 1.9 and is now enabled by default in 2.0 ; - end-to-end HTTP/2 support including trailers and continuation frames, as needed for gRPC ; HTTP/2 may also be upgraded from HTTP/1.1 using the H2 preface; - server connection pooling and more advanced reuse, with ALPN protocol negotiation (already in 1.9) ; - layer 7 retries, allowing to use 0-RTT and TCP Fast Open to the servers as well as on the frontend ; - much more scalable multi-threading, which is even enabled by default on platforms where it was successfully tested ; by default, as many threads are started as the number of CPUs haproxy is allowed to run on. This removes a lot of configuration burden in VMs and containers ; - automatic maxconn setting for the process and the frontends, directly based on the number of available FDs (easier configuration in containers and with systemd) ; - logging to stdout for use in containers and systemd (already in 1.9). Logs can now provide micro-second resolution for some events ; - peers now support SSL, declaration of multiple stick-tables directly in the peers section, and synchronization of server names, not just IDs ; - In master-worker mode, the master process now exposes its own CLI and can communicate with all other processes (including the stopping ones), even allowing to connect to their CLI and check their state. It is also possible to start some sidecar programs and monitor them from the master, and the master can automatically kill old processes that survived too many reloads ; - the incoming connections are load-balanced between all threads depending on their load to minimize the processing time and maximize the capacity (already in 1.9) ; - the SPOE connection load-balancing was significantly improved in order to reduce high percentiles of SPOA response time (already in 1.9) ; - the "random" load balancing algorithm and a power-of-two-choices variant were introduced ; - statistics improvements with per-thread counters for certain things, and a prometheus exporter for all our statistics; - lots of debugging help, it's easier to produce a core dump, there are new commands on the CLI to control various things, there is a watchdog to fail cleanly when a thread deadlock or a spinning task are detected, so overall it should provide a better experience in field and less round trips between users and developers (hence less stress during an incident). - all 3 device detection engines are now compatible with multi-threading and can be build-tested without any external dependencies ; - "do-resolve" http-request action to perform a DNS resolution on any, sample, and resolvers now support relying on /etc/resolv.conf to match the local resolver ; - log sampling and balancing : it's now possible to send 1 log every 10 to a server, or to spread the logging load over multiple log servers; - a new SPOA agent (spoa_server) allows to interface haproxy with Python and Lua programs ; - support for Solaris' event ports (equivalent of kqueue or epoll) which will significantly improve the performance there when dealing with numerous connections ; - some warnings are now reported for some deprecated options that will be removed in 2.1. Since 2.0 is long term supported, there's no emergency to convert them, however if you see these warnings, you need to understand that you're among their extremely rare users and just because of this you may be taking risks by keeping them ; - A new SOCKS4 server-side layer was provided ; it allows outgoing connections to be forwarded through a SOCKS4 proxy (such as ssh -D). - priority- and latency- aware server queues : it is possible now to assign priorities to certain requests and/or to give them a time bonus or penalty to refine control of the traffic and be able to engage on SLAs. - internally the architecture was significantly redesigned to allow to further improve performance and make it easier to implement protocols that span over multiple layers (such as QUIC). This work started in 1.9 and will continue with 2.1. - the I/O, applets and tasks now share the same multi-threaded scheduler, giving a much better responsiveness and fairness between all tasks as is visible with the CLI which always responds instantly even under extreme loads (started in 1.9) ; - the internal buffers were redesigned to ease zero-copy operations, so that it is possible to sustain a high bandwidth even when forwarding HTTP/1 to/from HTTP/2 (already in 1.9) ;- Update to version 1.8.20~git0.6fb9fadc: * [RELEASE] Released version 1.8.20 * BUG/MINOR: spoe: Don't systematically wakeup SPOE stream in the applet handler * BUG/MINOR: da: Get the request channel to call CHECK_HTTP_MESSAGE_FIRST() * BUG/MINOR: 51d: Get the request channel to call CHECK_HTTP_MESSAGE_FIRST() * BUG/MEDIUM: thread/http: Add missing locks in set-map and add-acl HTTP rules * BUG/MINOR: acl: properly detect pattern type SMP_T_ADDR * BUG/MEDIUM: maps: only try to parse the default value when it's present * BUG/MAJOR: http_fetch: Get the channel depending on the keyword used * MINOR: skip get_gmtime where tm is unused * BUILD/MINOR: listener: Silent a few signedness warnings. * BUG/MEDIUM: listener: make sure the listener never accepts too many conns * BUG/MEDIUM: listener: use a self-locked list for the dequeue lists * MAJOR: listener: do not hold the listener lock in listener_accept() * BUG/MEDIUM: list: fix incorrect pointer unlocking in LIST_DEL_LOCKED() * BUG/MEDIUM: list: fix again LIST_ADDQ_LOCKED * BUG/MEDIUM: list: correct fix for LIST_POP_LOCKED's removal of last element * MINOR: list: make the delete and pop operations idempotent * BUG/MEDIUM: list: add missing store barriers when updating elements and head * BUG/MEDIUM: list: fix LIST_POP_LOCKED's removal of the last pointer * BUG/MEDIUM: list: fix the rollback on addq in the locked liss * BUG/MEDIUM: lists: Properly handle the case we're removing the first elt. * MINOR: lists: Implement locked variations. * BUG/MINOR: threads: fix the process range of thread masks * BUG/MEDIUM: spoe: Return an error if nothing is encoded for fragmented messages * BUG/MEDIUM: spoe: Queue message only if no SPOE applet is attached to the stream * BUG/MEDIUM: pattern: assign pattern IDs after checking the config validity * BUILD: connection: fix naming of ip_v field * BUILD: use inttypes.h instead of stdint.h * BUG/MEDIUM: peers: fix a case where peer session is not cleanly reset on release. * MINOR: cli: start addresses by a prefix in 'show cli sockets' * BUG/MINOR: cli: correctly handle abns in 'show cli sockets' * BUILD: Makefile: disable shared cache on AIX 5.1 * BUILD: makefile: add _LINUX_SOURCE_COMPAT to build on AIX-51 * BUILD: makefile: fix build of IPv6 header on aix51 * MINOR: tools: make memvprintf() never pass a NULL target to vsnprintf() * BUILD: makefile: work around an old bug in GNU make-3.80 * BUG/MAJOR: checks: segfault during tcpcheck_main * DOC: The option httplog is no longer valid in a backend. * BUG/MEDIUM: ssl: ability to set TLS 1.3 ciphers using ssl-default-server-ciphersuites * BUG/MINOR: http/counters: fix missing increment of fe->srv_aborts * BUG/MAJOR: stats: Fix how huge POST data are read from the channel * BUG/MAJOR: spoe: Fix initialization of thread-dependent fields * BUG/MEDIUM: threads/fd: do not forget to take into account epoll_fd/pipes * MEDIUM: threads: Use __ATOMIC_SEQ_CST when using the newer atomic API. * BUG/MINOR: ssl: fix warning about ssl-min/max-ver support * BUG/MEDIUM: 51d: fix possible segfault on deinit_51degrees() * BUG/MEDIUM: logs: Only attempt to free startup_logs once. * BUG/MINOR: listener: keep accept rate counters accurate under saturation * BUG/MAJOR: listener: Make sure the listener exist before using it.- Update to version 1.8.19~git0.ebf033b4: * [RELEASE] Released version 1.8.19 * BUG/MINOR: config: Reinforce validity check when a process number is parsed * BUG/MAJOR: stream: avoid double free on unique_id * BUG/MAJOR: spoe: Don't try to get agent config during SPOP healthcheck * BUG/MEDIUM: server: initialize the idle conns list after parsing the config * BUG/MEDIUM: spoe: initialization depending on nbthread must be done last * BUG/MINOR: lua: initialize the correct idle conn lists for the SSL sockets * BUG/MINOR: spoe: do not assume agent->rt is valid on exit * DOC: ssl: Stop documenting ciphers example to use * DOC: ssl: Clarify when pre TLSv1.3 cipher can be used * [RELEASE] Released version 1.8.18 * BUG/MINOR: config: make sure to count the error on incorrect track-sc/stick rules * BUG/MAJOR: spoe: verify that backends used by SPOE cover all their callers' processes * BUG/MAJOR: config: verify that targets of track-sc and stick rules are present * BUG/MINOR: config: fix bind line thread mask validation * BUG/MEDIUM: stream: Don't forget to free s->unique_id in stream_free(). * BUG/MEDIUM: mux-h2: do not close the connection on aborted streams * MINOR: connstream: have a new flag CS_FL_KILL_CONN to kill a connection * MINOR: stream-int: add a new flag to mention that we want the connection to be killed * MINOR: stream-int: expand the flags to 32-bit * BUG/MEDIUM: mux-h2: wait for the mux buffer to be empty before closing the connection * BUG/MEDIUM: mux-h2: make sure never to send GOAWAY on too old streams * BUG/MEDIUM: mux-h2: fix two half-closed to closed transitions * BUG/MEDIUM: mux-h2: wake up flow-controlled streams on initial window update * MINOR: xref: Add missing barriers. * BUG/MINOR: stream: don't close the front connection when facing a backend error * SCRIPTS: add the issue tracker URL to the announce script * SCRIPTS: add the slack channel URL to the announce script * BUG/MINOR: deinit: tcp_rep.inspect_rules not deinit, add to deinit * BUG/MINOR: spoe: corrected fragmentation string size * DOC: nbthread is no longer experimental. * BUG/MINOR: hpack: return a compression error on invalid table size updates * BUG/MINOR: mux-h2: make it possible to set the error code on an already closed stream * BUG/MINOR: mux-h2: headers-type frames in HREM are always a connection error * BUG/MINOR: mux-h2: CONTINUATION in closed state must always return GOAWAY * MINOR: h2: declare new sets of frame types * MINOR: h2: add a bit-based frame type representation * DOC: mention the effect of nf_conntrack_tcp_loose on src/dst * BUG/MEDIUM: ssl: Fix handling of TLS 1.3 KeyUpdate messages * BUG/MINOR: check: Wake the check task if the check is finished in wake_srv_chk() * BUG/MINOR: server: don't always trust srv_check_health when loading a server state * BUG/MINOR: stick_table: Prevent conn_cur from underflowing * BUG/MINOR: backend: BE_LB_LKUP_CHTREE is a value, not a bit * BUG/MINOR: backend: balance uri specific options were lost across defaults * BUG/MINOR: backend: don't use url_param_name as a hint for BE_LB_ALGO_PH * BUG/MEDIUM: ssl: missing allocation failure checks loading tls key file * DOC: Be a bit more explicit about allow-0rtt security implications. * BUG/MEDIUM: ssl: Disable anti-replay protection and set max data with 0RTT. * BUG/MAJOR: cache: fix confusion between zero and uninitialized cache key * DOC: http-request cache-use / http-response cache-store expects cache name- Update to version 1.8.17~git0.e89d25b2 (bsc#1121283) (CVE-2018-20615): * BUG/CRITICAL: mux-h2: re-check the frame length when PRIORITY is used * BUG/MEDIUM: lua: dead lock when Lua tasks are trigerred * BUG/MINOR: lua: bad args are returned for Lua actions * BUG/MINOR: lua: Return an error if a legacy HTTP applet doesn't send anything * BUG/MEDIUM: cli: make "show sess" really thread-safe * MINOR: stream/cli: report more info about the HTTP messages on "show sess all" * MINOR: stream/cli: fix the location of the waiting flag in "show sess all" * MINOR: lb: allow redispatch when using consistent hash * BUG/MEDIUM: server: Also copy "check-sni" for server templates. * BUG/MEDIUM: mux-h2: mark that we have too many CS once we have more than the max * MINOR: mux-h2: only increase the connection window with the first update * BUG/MAJOR: stream-int: Update the stream expiration date in stream_int_notify() * BUG/MEDIUM: dns: overflowed dns name start position causing invalid dns error * BUG/MEDIUM: dns: Don't prevent reading the last byte of the payload in dns_validate_response() * BUG/MINOR: logs: leave startup-logs global and not per-thread- Update to version 1.8.15~git0.6b6a350a: (bsc#1119419) (CVE-2018-20103) (VUL-0) (bsc#1119368) (CVE-2018-20102) * DOC: Update configuration doc about the maximum number of stick counters. * BUG: dns: Fix off-by-one write in dns_validate_dns_response() * BUG: dns: Fix out-of-bounds read via signedness error in dns_validate_dns_response() * BUG: dns: Prevent out-of-bounds read in dns_validate_dns_response() * BUG: dns: Prevent out-of-bounds read in dns_read_name() * BUG: dns: Prevent stack-exhaustion via recursion loop in dns_read_name * DOC: refer to check-sni in the documentation of sni * DOC: clarify that check-sni needs an argument. * MINOR: servers: Free [idle|safe|priv]_conns on exit. * MINOR: stats: report the number of active jobs and listeners in "show info" * BUG/MINOR: mux-h2: advertise a larger connection window size * BUG/MINOR: mux-h2: refrain from muxing during the preface * BUG/MINOR: hpack: fix off-by-one in header name encoding length calculation * BUG/MEDIUM: sample: Don't treat SMP_T_METH as SMP_T_STR. * BUG/MINOR: lb-map: fix unprotected update to server's score * BUG/MINOR: cfgparse: Fix the call to post parser of the last sections parsed * BUG/MINOR: cfgparse: Fix transition between 2 sections with the same name * BUG/MINOR: ssl: ssl_sock_parse_clienthello ignores session id * BUG/MEDIUM: hpack: fix encoding of "accept-ranges" field * BUG/MINOR: config: Copy default error messages when parsing of a backend starts * BUG/MEDIUM: Make sure stksess is properly aligned. * BUG/MINOR: config: better detect the presence of the h2 pattern in npn/alpn * BUG/MEDIUM: auth/threads: use of crypt() is not thread-safe * BUG/MAJOR: http: http_txn_get_path() may deference an inexisting buffer * BUG/MINOR: only auto-prefer last server if lb-alg is non-deterministic * BUG/MINOR: only mark connections private if NTLM is detected * DOC: cache: Missing information about "total-max-size" * BUG/MINOR: ssl: Wrong usage of shctx_init(). * BUG/MINOR: cache: Wrong usage of shctx_init(). * BUG/MINOR: cache: Crashes with "total-max-size" > 2047(MB). * BUG/MEDIUM: h2: Close connection if no stream is left an GOAWAY was sent. * BUG/MEDIUM: pools: Fix the usage of mmap()) with DEBUG_UAF. * DOC: fix reference to map files in MAINTAINERS * MINOR: peers: use defines instead of enums to appease clang. * MINOR: cfgparse: Write 130 as 128 as 0x82 and 0x80. * MINOR: server: Use memcpy() instead of strncpy(). * CLEANUP: stick-tables: Remove unneeded double (()) around conditional clause * MINOR: lua: all functions calling lua_yieldk() may return * BUG/MEDIUM: threads: make sure threads_want_sync is marked volatile * BUG/MEDIUM: threads: fix thread_release() at the end of the rendez-vous point * BUG/MEDIUM: stream: don't crash on out-of-memory * BUG/MEDIUM: mworker: segfault receiving SIGUSR1 followed by SIGTERM. * BUG/MINOR: checks: queues null-deref * BUG/MEDIUM: Cur/CumSslConns counters not threadsafe. * MEDIUM: ssl: add support for ciphersuites option for TLSv1.3 * BUG/MEDIUM: buffers: Make sure we don't wrap in buffer_insert_line2/replace2. * BUG/MINOR: backend: check that the mux installed properly * BUG/MINOR: connection: avoid null pointer dereference in send-proxy-v2 * DOC: clarify force-private-cache is an option * MINOR: threads: Make sure threads_sync_pipe is initialized before using it.- also fix the systemd case for the apparmor_reload change- only reload the apparmor profile on newer distros, seems older distros do not have apparmor-rpm-macros yet- only use network namespaces on 12.x and newer, failed to build on sle11- guard all parts referring to systemd to fix build on sle 11- Update to version 1.8.14~git0.52e4d43b: (bsc#1108683) (CVE-2018-14645) * [RELEASE] Released version 1.8.14 * BUG/CRITICAL: hpack: fix improper sign check on the header index value * BUG/MINOR: cli: make sure the "getsock" command is only called on connections * BUG/MINOR: tools: fix set_net_port() / set_host_port() on IPv4 * BUG/MEDIUM: patterns: fix possible double free when reloading a pattern list * DOC: Fix typos in lua documentation * BUG/MINOR: server: Crash when setting FQDN via CLI. * BUG/MAJOR: kqueue: Don't reset the changes number by accident. * BUG/MEDIUM: snapshot: take the proxy's lock while dumping errors * BUG/MINOR: http/threads: atomically increment the error snapshot ID * BUG/MINOR: dns: check and link servers' resolvers right after config parsing * BUG/MEDIUM: h2: fix risk of memory leak on malformated wrapped frames * BUG/MEDIUM: session: fix reporting of handshake processing time in the logs * BUG/MINOR: stream: use atomic increments for the request counter * MINOR: thread: implement HA_ATOMIC_XADD() * BUG/MEDIUM: ECC cert should work with TLS < v1.2 and openssl >= 1.1.1 * BUG/MEDIUM: dns/server: fix incomatibility between SRV resolution and server state file * BUG/MEDIUM: hlua: Don't call RESET_SAFE_LJMP if SET_SAFE_LJMP returns 0. * BUG/MAJOR: thread: lua: Wrong SSL context initialization. * BUG/MEDIUM: hlua: Make sure we drain the output buffer when done. * BUG/MEDIUM: lua: reset lua transaction between http requests * BUG/MEDIUM: mux_pt: dereference the connection with care in mux_pt_wake() * BUG/MINOR: lua: Bad HTTP client request duration. * BUG/MEDIUM: unix: provide a ->drain() function * DOC: Fix spelling error in configuration doc * BUG/MEDIUM: cli/threads: protect some server commands against concurrent operations * BUG/MEDIUM: cli/threads: protect all "proxy" commands against concurrent updates * BUG/MEDIUM: lua: socket timeouts are not applied * DOC: ssl: Use consistent naming for TLS protocols * DOC: dns: explain set server ... fqdn requires resolver * BUG/MINOR: map: fix map_regm with backref * BUG/MEDIUM: ssl: loading dh param from certifile causes unpredictable error. * BUG/MEDIUM: ssl: fix missing error loading a keytype cert from a bundle. * BUG/MINOR: ssl: empty connections reported as errors. * BUG/MEDIUM: cli: make "show fd" thread-safe * MEDIUM: hathreads: implement a more flexible rendez-vous point * BUG/MEDIUM: threads: fix the no-thread case after the change to the sync point * MINOR: threads: add more consistency between certain variables in no-thread case * BUG/MEDIUM: threads: fix the double CAS implementation for ARMv7 * MINOR: threads: Introduce double-width CAS on x86_64 and arm. * BUG/MEDIUM: lua: possible CLOSE-WAIT state with '\n' headers- Require apparmor-abstractions to reduce dependencies (bsc#1100787)- Update to version 1.8.13~git4.c1bfcd00: * MINOR: dns: new DNS options to allow/prevent IP address duplication * MINOR: dns: fix wrong score computation in dns_get_ip_from_response * BUG/MEDIUM: queue: prevent a backup server from draining the proxy's connections * BUG/MEDIUM: servers: check the queues once enabling a server * MEDIUM: proxy_protocol: Convert IPs to v6 when protocols are mixed * BUG/MEDIUM: threads: unbreak "bind" referencing an incorrect thread number * MINOR: threads: move "nbthread" parsing to hathreads.c * BUG/MEDIUM: threads: properly fix nbthreads == MAX_THREADS * BUG/MINOR: threads: Handle nbthread == MAX_THREADS. * BUG/MINOR: config: stick-table is not supported in defaults section * BUG/MEDIUM: h2: prevent orphaned streams from blocking a connection forever * BUG/MEDIUM: threads/sync: use sched_yield when available * BUG/MINOR: servers: Don't make "server" in a frontend fatal. * BUG/MEDIUM: stats: don't ask for more data as long as we're responding * BUG/MEDIUM: stream-int: don't immediately enable reading when the buffer was reportedly full * MINOR: h2: add the error code and the max/last stream IDs to "show fd" * BUG/MEDIUM: threads: Fix the exit condition of the thread barrier * MINOR: debug: Add checks for conn_stream flags * MINOR: debug: Add check for CO_FL_WILL_UPDATE * BUG/MINOR: http: Set brackets for the unlikely macro at the right place * BUG/MEDIUM: h2: make sure the last stream closes the connection after a timeout * BUG/MEDIUM: h2: never leave pending data in the output buffer on close * BUG/MEDIUM: h2: don't accept new streams if conn_streams are still in excess * MINOR: h2: add the mux and demux buffer lengths on "show fd" * MINOR: h2: keep a count of the number of conn_streams attached to the mux * BUG/MINOR: h2: remove accidental debug code introduced with show_fd function * MINOR: h2: implement a basic "show_fd" function * MINOR: mux: add a "show_fd" function to dump debugging information for "show fd" * BUG/MINOR: ssl: properly ref-count the tls_keys entries * MINOR: systemd: consider exit status 143 as successful- Update to version 1.8.12~git0.8a200c71: * MINOR: stick-tables: make stktable_release() do nothing on NULL * BUG/MAJOR: stick_table: Complete incomplete SEGV fix- Update to version 1.8.11~git0.1d6ef58d: * BUG/BUILD: threads: unbreak build without threads * BUG/MAJOR: Stick-tables crash with segfault when the key is not in the stick-table- Update to version 1.8.10~git0.ec17d7a9: * MINOR: threads: Be sure to remove threads from all_threads_mask on exit * BUG/MEDIUM: threads: Use the sync point to check active jobs and exit * BUG/MEDIUM: fd: Don't modify the update_mask in fd_dodelete(). * BUG/MAJOR: ssl: OpenSSL context is stored in non-reserved memory slot * BUG/MAJOR: ssl: Random crash with cipherlist capture * BUG/MINOR: lua: Segfaults with wrong usage of types. * BUG/MAJOR: map: fix a segfault when using http-request set-map * MINOR: lua: Increase debug information * BUG/MINOR: signals: ha_sigmask macro for multithreading * BUG/MINOR: don't ignore SIG{BUS,FPE,ILL,SEGV} during signal processing * BUG/MEDIUM: threads: handle signal queue only in thread 0 * BUG/MINOR: unix: Make sure we can transfer abns sockets on seamless reload. * BUG/MINOR: contrib/modsecurity: update pointer on the end of the frame * BUG/MINOR: contrib/mod_defender: update pointer on the end of the frame * BUG/MINOR: contrib/modsecurity: Don't reset the status code during disconnect * BUG/MINOR: contrib/mod_defender: Don't reset the status code during disconnect * BUG/MINOR: contrib/spoa_example: Don't reset the status code during disconnect * MAJOR: spoe: upgrade the SPOP version to 2.0 and remove the support for 1.0 * BUG/MEDIUM: lua/socket: Buffer error, may segfault * BUG/MEDIUM: lua/socket: Sheduling error on write: may dead-lock * BUG/MEDIUM: lua/socket: Notification error * BUG/MAJOR: lua: Dead lock with sockets * BUG/MEDIUM: lua/socket: wrong scheduling for sockets * MINOR: task/notification: Is notifications registered ? * BUG/MEDIUM: spoe: Return an error when the wrong ACK is received in sync mode * BUG/MEDIUM: stick-tables: Decrement ref_cnt in table_* converters * BUG/MEDIUM: lua/socket: Length required read doesn't work * BUG/MEDIUM: servers: Add srv_addr default placeholder to the state file * BUG/MEDIUM: fd: Only check update_mask against all_threads_mask.- Update to version 1.8.9~git9.6d82e611: * BUG/MEDIUM: cache: don't cache when an Authorization header is present (VUL-1) (bsc#1094846) (CVE-2018-11469) * BUG/MEDIUM: dns: Delay the attempt to run a DNS resolution on check failure. * BUG/MINOR: ssl/lua: prevent lua from affecting automatic maxconn computation * BUG/MEDIUM: contrib/modsecurity: Use network order to encode/decode flags * BUG/MEDIUM: contrib/mod_defender: Use network order to encode/decode flags * BUG/MEDIUM: spoe: Flags are not encoded in network order * BUG/MINOR: lua: Socket.send threw runtime error: 'close' needs 1 arguments. * BUG/MINOR: spoe: Mistake in error message about SPOE configuration * BUG/MEDIUM: ssl: properly protect SSL cert generation * BUG/MEDIUM: pollers: Use a global list for fd shared between threads. * BUG/MEDIUM: http: don't always abort transfers on CF_SHUTR * BUG/MINOR: lua: ensure large proxy IDs can be represented * BUG/MINOR: lua: schedule socket task upon lua connect() * BUG/MEDIUM: task: Don't free a task that is about to be run. * BUG/MINOR: map: correctly track reference to the last ref_elt being dumped * DOC/MINOR: clean up LUA documentation re: servers & array/table. * BUG/MINOR: lua: Put tasks to sleep when waiting for data * BUG/MEDIUM: threads: Fix the sync point for more than 32 threads * BUG/MINOR: checks: Fix check->health computation for flapping servers * BUG/MINOR: config: disable http-reuse on TCP proxies * BUG/MINOR: lua/threads: Make lua's tasks sticky to the current thread * BUG/MEDIUM: h2: implement missing support for chunked encoded uploads * MINOR: h2: detect presence of CONNECT and/or content-length * BUG/MEDIUM: lua: Fix segmentation fault if a Lua task exits * BUG/MINOR: log: t_idle (%Ti) is not set for some requests * BUG/MAJOR: channel: Fix crash when trying to read from a closed socket * BUG/MINOR: pattern: Add a missing HA_SPIN_INIT() in pat_ref_newid()- Update to version 1.8.8: * BUG/CRITICAL: h2: fix incorrect frame length check (VUL-0) (bsc#1089837) * MINOR: cli: Ensure the CLI always outputs an error when it should * BUG/MINOR: cli: Guard against NULL messages when using CLI_ST_PRINT_FREE * BUG/MEDIUM: kqueue: When adding new events, provide an output to get errors. * BUG/MINOR: http: Return an error in proxy mode when url2sa fails * BUG/MEDIUM: connection: Make sure we have a mux before calling detach(). * BUG/MEDIUM: threads: Fix the max/min calculation because of name clashes- Update to version 1.8.7: * [RELEASE] Released version 1.8.7 * MINOR: servers: Support alphanumeric characters for the server templates names * BUG/MAJOR: cache: always initialize newly created objects * [RELEASE] Released version 1.8.6 * BUG/MINOR: spoe: Don't release the context buffer in .check_timeouts callbaclk * BUG/MINOR: spoe: Initialize variables used during conf parsing before any check * BUG/MAJOR: cache: fix random crashes caused by incorrect delete() on non-first blocks * BUG/MINOR: fd: Don't clear the update_mask in fd_insert. * BUG/MINOR: cache: fix "show cache" output * BUG/MINOR: email-alert: Set the mailer port during alert initialization * BUG/MINOR: checks: check the conn_stream's readiness and not the connection * BUG/MEDIUM: h2: always add a stream to the send or fctl list when blocked * BUILD/MINOR: threads: always export thread_sync_io_handler() * BUG/MEDIUM: h2: don't consider pending data on detach if connection is in error * BUG/MEDIUM: h2/threads: never release the task outside of the task handler * MINOR: h2: fuse h2s_detach() and h2s_free() into h2s_destroy() * MINOR: h2: always call h2s_detach() in h2_detach() * BUG/MAJOR: h2: remove orphaned streams from the send list before closing * MINOR: h2: provide and use h2s_detach() and h2s_free() * CLEANUP: h2: rename misleading h2c_stream_close() to h2s_close() * BUG/MINOR: hpack: fix harmless use of uninitialized value in hpack_dht_insert * BUILD/MINOR: cli: fix a build warning introduced by last commit * MINOR: cli: make "show fd" report the mux and mux_ctx pointers when available * MINOR: cli/threads: make "show fd" report thread_sync_io_handler instead of "unknown" * BUILD/MINOR: fix build when USE_THREAD is not defined * BUG/MINOR: lua funtion hlua_socket_settimeout don't check negative values * BUG/MINOR: lua: the function returns anything- Update to version 1.8.5: * BUG/MINOR: listener: Don't decrease actconn twice when a new session is rejected * BUG/MINOR: h2: ensure we can never send an RST_STREAM in response to an RST_STREAM * BUG/MEDIUM: h2: properly account for DATA padding in flow control * DOC: don't suggest using http-server-close * DOC: log: more than 2 log servers are allowed * BUILD/BUG: enable -fno-strict-overflow by default * MINOR: log: stop emitting alerts when it's not possible to write on the socket * BUG/MEDIUM: threads/queue: wake up other threads upon dequeue * BUG/MINOR: tcp-check: use the server's service port as a fallback * BUG/MEDIUM: tcp-check: single connect rule can't detect DOWN servers * BUG/MINOR: lua: return bad error messages * BUG/MINOR: spoa-example: unexpected behavior for more than 127 args * BUG/MINOR: cli: Fix a crash when sending a command with too many arguments * BUG/MINOR: seemless reload: Fix crash when an interface is specified. * BUG/MINOR: dns: don't downgrade DNS accepted payload size automatically * BUG/MAJOR: threads/queue: Fix thread-safety issues on the queues management * BUG/MEDIUM: threads/unix: Fix a deadlock when a listener is temporarily disabled * BUG/MEDIUM: spoe: Remove idle applets from idle list when HAProxy is stopping * BUG/MINOR: force-persist and ignore-persist only apply to backends * BUG/MEDIUM: fix a 100% cpu usage with cpu-map and nbthread/nbproc * BUG/MINOR: cli: Fix a typo in the 'set rate-limit' usage * BUG/MINOR: cli: Fix a crash when passing a negative or too large value to "show fd" * BUG/MEDIUM: h2: also arm the h2 timeout when sending * BUG/MINOR: unix: Don't mess up when removing the socket from the xfer_sock_list. * BUG/MINOR: session: Fix tcp-request session failure if handshake. * MINOR: systemd: Add SystemD's SystemCallFilter option to the unit file * MINOR: systemd: Add SystemD's Protect*= options to the unit file * MINOR: systemd: Add section for SystemD sandboxing to unit file * BUG/MEDIUM: buffer: Fix the wrapping case in bi_putblk * BUG/MEDIUM: buffer: Fix the wrapping case in bo_putblk * BUG/MEDIUM: h2: always consume any trailing data after end of output buffers * MINOR: stats: display the number of threads in the statistics. * BUG/MINOR: h2: Set the target of dbuf_wait to h2c * MINOR: debug/pools: make DEBUG_UAF also detect underflows * BUG/MINOR: debug/pools: properly handle out-of-memory when building with DEBUG_UAF * DOC: cfgparse: Warn on option (tcp|http)log in backend * DOC: lua: new prototype for function "register_action()" * BUG/MEDIUM: ssl/sample: ssl_bc_* fetch keywords are broken. * BUG/MEDIUM: http: Switch the HTTP response in tunnel mode as earlier as possible * BUG/MINOR: ssl/threads: Make management of the TLS ticket keys files thread-safe * BUG/MINOR: init: Add missing brackets in the code parsing -sf/-st * BUG/MEDIUM: ssl: Shutdown the connection for reading on SSL_ERROR_SYSCALL * BUG/MEDIUM: ssl: Don't always treat SSL_ERROR_SYSCALL as unrecovarable. * BUG/MINOR: threads: fix missing thread lock labels for 1.8- if we lock down the permissions the home directory has to be owned by haproxy (bsc#1077716)- Avoid %__-type macro indirections. Remove redundant %clean section. Do not ignore errors from useradd.- Ensure haproxy home directory is not world readable (bsc#1077716)- Update to version 1.8.4 (bsc#1080069): * BUG/MINOR: config: don't emit a warning when global stats is incompletely configured * DOC: Mention -Ws in the list of available options * DOC: Describe routing impact of using interface keyword on bind lines * MINOR: init: emit warning when -sf/-sd cannot parse argument * BUG/MEDIUM: standard: Fix memory leak in str2ip2() * BUG/MINOR: time/threads: ensure the adjusted time is always correct * BUG/MEDIUM: spoe: Allow producer to read and to forward shutdown on request side * BUG/MEDIUM: spoe: Always try to receive or send the frame to detect shutdowns * BUG/MINOR: epoll/threads: only call epoll_ctl(DEL) on polled FDs * BUG/MINOR: threads: Update labels array because of changes in lock_label enum * BUG/MINOR: cli: use global.maxsock and not maxfd to list all FDs * CLEANUP: Fix typo in ARGT_MSK6 comment * BUG/MINOR: sample: Fix output type of c_ipv62ip * CLEANUP: sample: Fix outdated comment about sample casts functions * CLEANUP: sample: Fix comment encoding of sample.c * BUILD: kqueue/threads: Add test on MAX_THREADS to avoid warnings when complied without threads * BUILD: epoll/threads: Add test on MAX_THREADS to avoid warnings when complied without threads * MINOR: threads: Use __decl_hathreads instead of #ifdef/#endif * BUG/MINOR: kqueue/threads: Don't forget to close kqueue_fd[tid] on each thread * BUG/MEDIUM: checks: Don't try to release undefined conn_stream when a check is freed * BUG/MEDIUM: threads/server: Fix deadlock in srv_set_stopping/srv_set_admin_flag * BUG/MINOR: threads: always set an owner to the thread_sync pipe * MINOR: threads: Fix build when we're not compiling with threads. * BUG/MINOR: mworker: only write to pidfile if it exists * BUG/MEDIUM: threads/mworker: fix a race on startup * BUG/MEDIUM: kqueue/threads: use one kqueue_fd per thread * BUG/MEDIUM: epoll/threads: use one epoll_fd per thread * MINOR: fd: add a bitmask to indicate that an FD is known by the poller * BUG/MEDIUM: fd: maintain a per-thread update mask * BUG/MEDIUM: threads/polling: Use fd_cache_mask instead of fd_cache_num * MINOR: threads/fd: Use a bitfield to know if there are FDs for a thread in the FD cache * MINOR: global: add some global activity counters to help debugging * MINOR: threads: add a MAX_THREADS define instead of LONGBITS * MINOR: global/threads: move cpu_map at the end of the global struct * MINOR: servers: Don't report duplicate dyncookies for disabled servers. * BUG/MEDIUM: peers: fix expire date wasn't updated if entry is modified remotely. * BUG/MINOR: poll: too large size allocation for FD events * CONTRIB: debug: fix a few flags definitions * DOC: clarify the scope of ssl_fc_is_resumed * BUG/MEDIUM: stream: properly handle client aborts during redispatch * BUILD/MINOR: ancient gcc versions atomic fix * BUG/MEDIUM: mworker: execvp failure depending on argv[0] * MINOR: dns: Handle SRV record weight correctly. * BUG/MINOR: lua: Fix return value of Socket.settimeout * BUG/MEDIUM: lua: Fix IPv6 with separate port support for Socket.connect * DOC: lua: Fix typos in comments of hlua_socket_receive * BUG/MINOR: lua: Fix default value for pattern in Socket.receive * BUG/MEDIUM: ssl: cache doesn't release shctx blocks * BUG/MEDIUM: h2: properly handle the END_STREAM flag on empty DATA frames- Add dependency on apparmor-profiles (bsc#1079985)- Update to version 1.8.3: * [RELEASE] Released version 1.8.3 * MEDIUM: h2: prepare a graceful shutdown when the frontend is stopped * BUG/MAJOR: hpack: don't return direct references to the dynamic headers table * BUG/MEDIUM: http: don't automatically forward request close * MINOR: don't close stdio anymore * BUG/MEDIUM: mworker: don't close stdio several time * BUG/MEDIUM: h2: ensure we always know the stream before sending a reset * DOC/MINOR: configuration: typo, formatting fixes * BUG/MEDIUM: h2: improve handling of frames received on closed streams * BUG/MEDIUM: h2: properly handle and report some stream errors- Update to version 1.8.2: * [RELEASE] Released version 1.8.2 * BUG/MEDIUM: checks: properly set servers to stopping state on 404 * BUG/MAJOR: connection: refine the situations where we don't send shutw() * BUG/MEDIUM: cache: don't cache the response on no-cache="set-cookie" * BUG/MEDIUM: cache: respect the request cache-control header * BUG/MEDIUM: cache: replace old object on store * BUG/MEDIUM: cache: do not try to retrieve host-less requests from the cache * MINOR: http: add a function to check request's cache-control header field * BUG/MINOR: cache: do not force the TX_CACHEABLE flag before checking cacheability * BUG/MINOR: http: properly detect max-age=0 and s-maxage=0 in responses * BUG/MINOR: http: do not ignore cache-control: public * MINOR: http: start to compute the transaction's cacheability from the request * MINOR: http: update the list of cacheable status codes as per RFC7231 * MINOR: http: adjust the list of supposedly cacheable methods * BUG/MEDIUM: lua: fix crash when using bogus mode in register_service() * BUG/MEDIUM: checks: a server passed in maint state was not forced down. * MEDIUM: netscaler: add support for standard NetScaler CIP protocol * MEDIUM: netscaler: do not analyze original IP packet size * MINOR: netscaler: check in one-shot if buffer is large enough for IP and TCP header * BUG/MEDIUM: stream: don't consider abortonclose on muxes which close cleanly * MINOR: stream-int: set flag SI_FL_CLEAN_ABRT when mux supports clean aborts * MINOR: mux: add flags to describe a mux's capabilities * BUG/MINOR: h2: properly report a stream error on RST_STREAM * CONTRIB: halog: Fix compiler warnings in halog.c * CONTRIB: iprange: Fix compiler warning in iprange.c * BUG/MAJOR: netscaler: address truncated CIP header detection * BUG/MEDIUM: netscaler: use the appropriate IPv6 header size * MINOR: netscaler: rename cip_len to clarify its uage * MINOR: netscaler: remove the use of cip_magic only used once * MINOR: netscaler: respect syntax * DOC/MINOR: intro: typo, wording, formatting fixes * BUG/MEDIUM: mworker: Set FD_CLOEXEC flag on log fd * BUILD/MINOR: Makefile : enabling USE_CPU_AFFINITY * BUG: MINOR: http: don't check http-request capture id when len is provided * BUG: MAJOR: lb_map: server map calculation broken * BUG/MINOR: stream-int: don't try to receive again after receiving an EOS * BUG/MEDIUM: h2: fix stream limit enforcement * BUG/MEDIUM: http: don't disable lingering on requests with tunnelled responses * BUG/MEDIUM: h2: don't close after the first DATA frame on tunnelled responses * BUG/MEDIUM: h2: don't switch the state to HREM before end of DATA frame * MINOR: h2: don't demand that a DATA frame is complete before processing it * BUG/MEDIUM: h2: support uploading partial DATA frames * MINOR: h2: store the demux padding length in the h2c struct * BUG/MEDIUM: h2: debug incoming traffic in h2_wake() * BUG/MEDIUM: h2: work around a connection API limitation * BUG/MEDIUM: h2: enable recv polling whenever demuxing is possible * BUG/MEDIUM: h2: automatically set CS_FL_RCV_MORE when the output buffer is full * BUG/MEDIUM: stream-int: always set SI_FL_WAIT_ROOM on CS_FL_RCV_MORE * MINOR: conn_stream: add new flag CS_FL_RCV_MORE to indicate pending data * BUG/MEDIUM: lua/notification: memory leak * DOC: notifications: add precisions about thread usage * MINOR: systemd: remove comment about HAPROXY_STATS_SOCKET * BUG/MEDIUM: threads/vars: Fix deadlock in register_name * BUG/MEDIUM: email-alert: don't set server check status from a email-alert task * CONTRIB: halog: Add help text for -s switch in halog program * MINOR: mworker: Improve wording in `void mworker_wait()` * MINOR: mworker: Update messages referencing exit-on-failure * BUG/MEDIUM: h2: fix handling of end of stream again * BUG/MEDIUM: peers: set NOLINGER on the outgoing stream interface * BUG/MEDIUM: checks: a down server going to maint remains definitely stucked on down state. * BUG/MEDIUM: ssl engines: Fix async engines fds were not considered to fix fd limit automatically. * BUG/MEDIUM: mworker: also close peers sockets in the master * BUG/MINOR: ssl: support tune.ssl.cachesize 0 again * BUG/MAJOR: hpack: don't pretend large headers fit in empty table * BUG/MINOR: action: Don't check http capture rules when no id is defined- Update to version 1.8.1 (bsc#1069954): * BUG/MAJOR: h2: correctly check the request length when building an H1 request * BUG/MAJOR: thread: Be sure to request a sync between threads only once at a time * BUG/MAJOR: thread/peers: fix deadlock on peers sync. * BUG/MEDIUM: h2: do not accept upper case letters in request header names * BUG/MEDIUM: h2: remove connection-specific headers from request * BUG/MEDIUM: h2: enforce the per-connection stream limit * BUG/MEDIUM: checks: Be sure we have a mux if we created a cs. * BUG/MEDIUM: peers: fix some track counter rules dont register entries for sync. * BUG/MEDIUM: h2: don't report an error after parsing a 100-continue response * BUG/MEDIUM: threads/peers: decrement, not increment jobs on quitting * BUG/MEDIUM: stream: fix session leak on applet-initiated connections * BUG/MEDIUM: cache: bad computation of the remaining size * BUG/MEDIUM: ssl: don't allocate shctx several time * BUG/MEDIUM: tcp-check: Don't lock the server in tcpcheck_main * BUG/MEDIUM: kqueue: Don't bother closing the kqueue after fork. * BUG/MINOR: h2: use the H2_F_DATA_* macros for DATA frames * BUG/MINOR: h2: reject response pseudo-headers from requests * BUG/MINOR: h2: properly check PRIORITY frames * BUG/MINOR: h2: reject incorrect stream dependencies on HEADERS frame * BUG/MINOR: h2: do not accept SETTINGS_ENABLE_PUSH other than 0 or 1 * BUG/MINOR: h2: the TE header if present may only contain trailers * BUG/MINOR: h2: fix a typo causing PING/ACK to be responded to * BUG/MINOR: h2: ":path" must not be empty * BUG/MINOR: h2: try to abort closed streams as soon as possible * BUG/MINOR: h2: immediately close if receiving GOAWAY after the last stream * BUG/MINOR: hpack: dynamic table size updates are only allowed before headers * BUG/MINOR: hpack: reject invalid header index * BUG/MINOR: hpack: must reject huffman literals padded with more than 7 bits * BUG/MINOR: hpack: fix debugging output of pseudo header names * BUG/MINOR: mworker: detach from tty when in daemon mode * BUG/MINOR: mworker: fix validity check for the pipe FDs * BUG/MINOR: ssl: CO_FL_EARLY_DATA removal is managed by stream- License is now GPL-3.0+ and LGPL-2.1+- [apparmor]: allow haproxy to restart itself. needed for seamless restart. also reload the apparmor profile on update.- enable network namespaces on 42.3 - Enabled systemd notify mode: new BR: pkgconfig(libsystemd) This fixes problems with starting 1.8 on 42.3. - apply build option changes as adviced by upstream- Update to version 1.8.0 (bsc#1069954): https://www.mail-archive.com/haproxy@formilux.org/msg28004.html- Update to version 1.7.9: * BUG/MINOR: peers: peer synchronization issue (with several peers sections). * BUG/MINOR: lua: In error case, the safe mode is not removed * BUG/MINOR: lua: executes the function destroying the Lua session in safe mode * BUG/MAJOR: lua/socket: resources not detroyed when the socket is aborted * BUG/MEDIUM: lua: bad memory access * DOC: update the list of OpenSSL versions in the README * DOC: Updated 51Degrees git URL to point to a stable version. * BUG/MINOR: http: Set the response error state in http_sync_res_state * MINOR: http: Reorder/rewrite checks in http_resync_states * MINOR: http: Switch requests/responses in TUNNEL mode only by checking txn flags * BUG/MEDIUM: http: Switch HTTP responses in TUNNEL mode when body length is undefined * BUG/MAJOR: http: Fix possible infinity loop in http_sync_(req|res)_state * BUG/MINOR: lua: Fix Server.get_addr() port values * BUG/MINOR: lua: Correctly use INET6_ADDRSTRLEN in Server.get_addr() * BUG/MINOR: lua: always detach the tcp/http tasks before freeing them * BUG/MINOR: lua: Fix bitwise logic for hlua_server_check_* functions.- Update to version 1.7.8: * BUG/MINOR: stream: flag TASK_WOKEN_RES not set if task in runqueue * BUG/MAJOR: cli: fix custom io_release was crushed by NULL. * BUG/MAJOR: map: fix segfault during 'show map/acl' on cli. * BUG/MAJOR: compression: Be sure to release the compression state in all cases * DOC: fix references to the section about time format. * BUG/MEDIUM: map/acl: fix unwanted flags inheritance. * BUG/MINOR: stream: Don't forget to remove CF_WAKE_ONCE flag on response channel * BUG/MINOR: http: Don't reset the transaction if there are still data to send * BUG/MEDIUM: filters: Be sure to call flt_end_analyze for both channels * BUG/MINOR: http: properly handle all 1xx informational responses- Update to version 1.7.7: * BUG/MINOR: Wrong peer task expiration handling during synchronization processing. * BUG/MEDIUM: http: Drop the connection establishment when a redirect is performed * BUG/MEDIUM: cfgparse: Check if tune.http.maxhdr is in the range 1..32767 * DOC: fix references to the section about the unix socket * BUG/MINOR: log: pin the front connection when front ip/ports are logged- Update to version 1.7.6: * DOC: changed "block"(deprecated) examples to http-request deny * DOC: add few comments to examples. * DOC: update sample code for PROXY protocol * DOC: mention lighttpd 1.4.46 implements PROXY * DOC: stick-table is available in frontend sections * BUG/MINOR: dns: Wrong address family used when creating IPv6 sockets. * BUG/MINOR: config: missing goto out after parsing an incorrect ACL character * BUG/MINOR: arg: don't try to add an argument on failed memory allocation * BUG/MEDIUM: arg: ensure that we properly unlink unresolved arguments on error * BUG/MEDIUM: acl: don't free unresolved args in prune_acl_expr() * MINOR: lua: ensure the memory allocator is used all the time * CLEANUP: logs: typo: simgle => single * BUG/MEDIUM: acl: proprely release unused args in prune_acl_expr() * BUG/MAJOR: Use -fwrapv. * BUG/MINOR: server: don't use "proxy" when px is really meant. * BUG/MINOR: server: missing default server 'resolvers' setting duplication. * DOC: add layer 4 links/cross reference to "block" keyword. * DOC: errloc/errorloc302/errorloc303 missing status codes. * BUG/MEDIUM: lua: memory leak * MEDIUM: config: don't check config validity when there are fatal errors * BUG/MINOR: hash-balance-factor isn't effective in certain circumstances * MINOR/DOC: lua: just precise one thing * BUG/MINOR: http: Fix conditions to clean up a txn and to handle the next request * DOC: update RFC references * BUG/MINOR: checks: don't send proxy protocol with agent checks * BUG/MEDIUM: lua: segfault if a converter or a sample doesn't return anything * BUG/MAJOR: http: call manage_client_side_cookies() before erasing the buffer * BUG/MINOR: buffers: Fix bi/bo_contig_space to handle full buffers * BUG/MINOR: acls: Set the right refflag when patterns are loaded from a map * BUG/MINOR: http/filters: Be sure to wait if a filter loops in HTTP_MSG_ENDING * BUG/MEDIUM: peers: Peers CLOSE_WAIT issue. * BUG/MAJOR: server: Segfault after parsing server state file. * BUG/MEDIUM: unix: never unlink a unix socket from the file system- Update to version 1.7.5: * BUG/MEDIUM: peers: fix buffer overflow control in intdecode. * BUG/MEDIUM: buffers: Fix how input/output data are injected into buffers * BUG/MEDIUM: http: Fix blocked HTTP/1.0 responses when compression is enabled * BUG/MINOR: filters: Don't force the stream's wakeup when we wait in flt_end_analyze * MINOR: config parsing: add warning when log-format/tcplog/httplog is overriden in "defaults" sections- Update to version 1.7.4: * MINOR: config: warn when some HTTP rules are used in a TCP proxy * BUG/MINOR: spoe: Fix soft stop handler using a specific id for spoe filters * BUG/MINOR: spoe: Fix parsing of arguments in spoe-message section * BUG/MEDIUM: ssl: Clear OpenSSL error stack after trying to parse OCSP file * BUG/MEDIUM: cli: Prevent double free in CLI ACL lookup * BUG/MINOR: Fix "get map " CLI command * BUG/MAJOR: connection: update CO_FL_CONNECTED before calling the data layer * BUG/MEDIUM: ssl: switchctx should not return SSL_TLSEXT_ERR_ALERT_WARNING * BUG/MINOR: checks: attempt clean shutw for SSL check * BUG/MEDIUM: listener: do not try to rebind another process' socket * BUG/MEDIUM: filters: Fix channels synchronization in flt_end_analyze * BUG/MAJOR: stream-int: do not depend on connection flags to detect connection * BUG/MEDIUM: connection: ensure to always report the end of handshakes * BUG: payload: fix payload not retrieving arbitrary lengths * BUG/MAJOR: http: fix typo in http_apply_redirect_rule * BUG/MEDIUM: stream: fix client-fin/server-fin handling * MINOR: fd: add a new flag HAP_POLL_F_RDHUP to struct poller * BUG/MINOR: raw_sock: always perfom the last recv if RDHUP is not available * DOC/MINOR: Fix typos in proxy protocol doc * DOC: Protocol doc: add checksum, TLV type ranges * DOC: Protocol doc: add SSL TLVs, rename CHECKSUM * DOC: Protocol doc: add noop TLV * MEDIUM: global: add a 'hard-stop-after' option to cap the soft-stop time * BUG/MINOR: cfgparse: loop in tracked servers lists not detected by check_config_validity(). * MINOR: server: irrelevant error message with 'default-server' config file keyword. * MINOR: doc: fix use-server example (imap vs mail) * BUG/MEDIUM: tcp: don't require privileges to bind to device- Update to version 1.7.3: * BUG/MINOR: stream: Fix how backend-specific analyzers are set on a stream * BUG/MEDIUM: tcp: don't poll for write when connect() succeeds * BUG/MINOR: unix: fix connect's polling in case no data are scheduled * BUG/MINOR: lua: Map.end are not reliable because "end" is a reserved keyword * MINOR: dns: give ability to dns_init_resolvers() to close a socket when requested * BUG/MAJOR: dns: restart sockets after fork() * MINOR: chunks: implement a simple dynamic allocator for trash buffers * BUG/MEDIUM: http: prevent redirect from overwriting a buffer * BUG/MEDIUM: filters: Do not truncate HTTP response when body length is undefined * BUG/MEDIUM: http: Prevent replace-header from overwriting a buffer * BUG/MINOR: http: Return an error when a replace-header rule failed on the response * BUG/MINOR: sendmail: The return of vsnprintf is not cleanly tested * BUG/MAJOR: lua segmentation fault when the request is like 'GET ?arg=val HTTP/1.1' * BUG/MEDIUM: config: reject anything but "if" or "unless" after a use-backend rule * MINOR: http: don't close when redirect location doesn't start with "/"- Update to version 1.7.2 (bsc#1023141): * BUG/MEDIUM: lua: In some case, the return of sample-fetches is ignored (2) * BUG/MINOR: stream-int: automatically release SI_FL_WAIT_DATA on SHUTW_NOW * DOC: lua: documentation about time parser functions * DOC: lua: section declared twice * BUG/MINOR: lua/cli: bad error message * DOC: fix small typo in fe_id (backend instead of frontend) * BUG/MINOR: Fix the sending function in Lua's cosocket * BUG/MINOR: lua: memory leak executing tasks * BUG/MINOR: lua: bad return code * BUG/MEDIUM: ssl: properly reset the reused_sess during a forced handshake * BUG/MEDIUM: ssl: avoid double free when releasing bind_confs * BUG/MINOR: stats: fix be/sessions/current out in typed stats * BUG/MINOR: backend: nbsrv() should return 0 if backend is disabled * BUG/MEDIUM: ssl: for a handshake when server-side SNI changes * BUG/MINOR: systemd: potential zombie processes * DOC: Add timings events schemas * BUG/MINOR: option prefer-last-server must be ignored in some case * MINOR: stats: Support "select all" for backend actions * BUG/MINOR: sample-fetches/stick-tables: bad type for the sample fetches sc*_get_gpt0 * BUG/MAJOR: channel: Fix the definition order of channel analyzers * BUG/MINOR: http: report real parser state in error captures * BUG/MAJOR: http: fix risk of getting invalid reports of bad requests * MINOR: http: custom status reason. * MINOR: connection: add sample fetch "fc_rcvd_proxy" * BUG/MINOR: config: emit a warning if http-reuse is enabled with incompatible options * BUG/MINOR: tools: fix off-by-one in port size check * BUG/MEDIUM: server: consider AF_UNSPEC as a valid address family * MEDIUM: server: split the address and the port into two different fields * MINOR: tools: make str2sa_range() return the port in a separate argument * MINOR: server: take the destination port from the port field, not the addr * MEDIUM: server: disable protocol validations when the server doesn't resolve * BUG/MEDIUM: tools: do not force an unresolved address to AF_INET:0.0.0.0 * BUG/MINOR: ssl: EVP_PKEY must be freed after X509_get_pubkey usage * MINOR: proto_http.c 502 error txt typo. * DOC: add deprecation notice to "block" * BUG/MINOR: Reset errno variable before calling strtol(3)- Update to version 1.7.1: * BUG/MAJOR: stream: fix session abort on resource shortage * BUG/MINOR: cli: allow the backslash to be escaped on the CLI * BUG/MEDIUM: cli: fix "show stat resolvers" and "show tls-keys" * DOC: Fix map table's format * DOC: Added 51Degrees conv and fetch functions to documentation. * BUG/MINOR: http: don't send an extra CRLF after a Set-Cookie in a redirect * DOC: mention that req_tot is for both frontends and backends * BUG/MEDIUM: variables: some variable name can hide another ones * BUG/MINOR: stats: fix be/sessions/max output in html stats * MINOR: proxy: Add fe_name/be_name fetchers next to existing fe_id/be_id * DOC: lua: Documentation about some entry missing * MINOR: Do not forward the header "Expect: 100-continue" when the option http-buffer-request is set * DOC: Add undocumented argument of the trace filter * DOC: Fix some typo in SPOE documentation * BUG/MINOR: cli: be sure to always warn the cli applet when input buffer is full * MINOR: applet: Count number of (active) applets * MINOR: task: Rename run_queue and run_queue_cur counters * BUG/MEDIUM: stream: Save unprocessed events for a stream * BUG/MAJOR: Fix how the list of entities waiting for a buffer is handled * BUILD/MEDIUM: Fixing the build using LibreSSL * [RELEASE] Released version 1.7.1- Update to version 1.7.0: * BUG/MEDIUM: proxy: return "none" and "unknown" for unknown LB algos * BUG/MINOR: stats: make field_str() return an empty string on NULL * BUG/MEDIUM: http: Fix tunnel mode when the CONNECT method is used * BUG/MINOR: http: Keep the same behavior between 1.6 and 1.7 for tunneled txn * BUG/MINOR: filters: Protect args in macros HAS_DATA_FILTERS and IS_DATA_FILTER * BUG/MINOR: filters: Invert evaluation order of HTTP_XFER_BODY and XFER_DATA analyzers * BUG/MINOR: http: Call XFER_DATA analyzer when HTTP txn is switched in tunnel mode- Update to version 1.6.10: * BUG/MEDIUM: systemd-wrapper: return correct exit codes * BUG/MEDIUM: srv-state: properly restore the DRAIN state * BUG/MINOR: srv-state: allow to have both CMAINT and FDRAIN flags * BUG/MEDIUM: servers: properly propagate the maintenance states during startup * BUG: vars: Fix 'set-var' converter because of a typo * BUG/MEDIUM: channel: bad unlikely macro * CLEANUP: lua: move comment * CLEANUP: lua: control executed twice * CLEANUP: ssl: Fix bind keywords name in comments * DOC: ssl: Use correct wording for ca-sign-pass * BUG/MINOR: stick-table: handle out-of-memory condition gracefully * BUG/MEDIUM: connection: check the control layer before stopping polling * BUG/MEDIUM: stick-table: fix regression caused by recent fix for out-of-memory * CONTRIB: initiate a debugging suite to make debugging easier * BUG/MINOR: cli: properly decrement ref count on tables during failed dumps * BUG/MEDIUM: lua: In some case, the return of sample-fetche is ignored- Update to version 1.6.9+git.1477940904.ab45181 (fate#321723) * BUILD: poll: remove unused hap_fd_isset() which causes a warning with clang * MINOR: cfgparse: few memory leaks fixes. * MINOR: build: Allow linking to device-atlas library file * DOC: Fix typo in description of `-st` parameter in man page * BUG/MEDIUM: peers: on shutdown, wake up the appctx, not the stream * BUG/MEDIUM: peers: fix use after free in peer_session_create() * BUG/MEDIUM: systemd: let the wrapper know that haproxy has completed or failed * MINOR: systemd: report it when execve() fails * BUG/MINOR: systemd: check return value of calloc() * BUG/MINOR: systemd: always restore signals before execve() * BUG/MINOR: systemd: make the wrapper return a non-null status code on error * BUG/MINOR: ssl: prevent multiple entries for the same certificate * BUG/MINOR: ssl: Check malloc return code * BUG/MINOR: vars: smp_fetch_var() doesn't depend on HTTP but on the session * BUG/MINOR: vars: make smp_fetch_var() more robust against misuses * BUG/MINOR: vars: use sess and not s->sess in action_store() * MEDIUM: make SO_REUSEPORT configurable * MINOR: Add fe_req_rate sample fetch * MINOR: show Running on zlib version * MINOR: show Built with PCRE version * BUG/MINOR: displayed PCRE version is running release- Update to 1.6.9 (bsc#1003264) - MINOR: cli: allow the semi-colon to be escaped on the CLI - BUG/MINOR: payload: fix SSLv2 version parser - BUG/MAJOR: stream: properly mark the server address as unset on connect retry - DOC: Updated 51Degrees readme. - BUG/MAJOR: stick-counters: possible crash when using sc_trackers with wrong table - BUG/MINOR: peers: empty chunks after a resync. - BUG/MINOR: peers: some updates are pushed twice after a resync. - MINOR: sample: use smp_make_rw() in upper/lower converters - BUG/MEDIUM: stick-table: properly convert binary samples to keys - BUG/MEDIUM: stick-tables: do not fail on string keys with no allocated size - BUG/MAJOR: server: the "sni" directive could randomly cause trouble - MINOR: sample: provide smp_is_rw() and smp_make_rw() - MINOR: sample: implement smp_is_safe() and smp_make_safe() - BUG/MEDIUM: samples: make smp_dup() always duplicate the sample - BUG/MAJOR: compression: initialize avail_in/next_in even during flush - BUILD: make proto_tcp.c compatible with musl library - DOC: minor typo fixes to improve HTML parsing by haproxy-dconv - BUG/MEDIUM: stream-int: completely detach connection on connect error - BUG/MEDIUM: lua: somme HTTP manipulation functions are called without valid requests - DOC: lua: remove old functions - BUG/MINOR: peers: Fix peers data decoding issue - BUG/MEDIUM: lua: the function txn_done() from action wrapper can crash - BUG/MEDIUM: lua: the function txn_done() from sample fetches can crash- update to 1.6.7 - MINOR: new function my_realloc2 = realloc + free upon failure - CLEANUP: fixed some usages of realloc leading to memory leak - Revert "BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params()" - BUG/MEDIUM: dns: fix alignment issues in the DNS response parser - BUG/MINOR: Fix endiness issue in DNS header creation code - changes from 1.6.6 - BUG/MAJOR: fix listening IP address storage for frontends - BUG/MINOR: fix listening IP address storage for frontends (cont) - DOC: Fix typo so fetch is properly parsed by Cyril's converter - BUG/MAJOR: http: fix breakage of "reqdeny" causing random crashes - BUG/MEDIUM: stick-tables: fix breakage in table converters - BUG/MEDIUM: dns: unbreak DNS resolver after header fix - BUILD: fix build on Solaris 11 - CLEANUP: connection: fix double negation on memcmp() - BUG/MEDIUM: stats: show servers state may show an servers from another backend - BUG/MEDIUM: fix risk of segfault with "show tls-keys" - BUG/MEDIUM: sticktables: segfault in some configuration error cases - BUG/MEDIUM: lua: converters doesn't work - BUG/MINOR: http: add-header: header name copied twice - BUG/MEDIUM: http: add-header: buffer overwritten - BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params() - BUG/MINOR: http: url32+src should use the big endian version of url32 - BUG/MINOR: http: url32+src should check cli_conn before using it - DOC: http: add documentation for url32 and url32+src - BUG/MINOR: fix http-response set-log-level parsing error - MINOR: systemd: Use variable for config and pidfile paths - MINOR: systemd: Perform sanity check on config before reload (cherry picked from commit 68535bddf305fdd22f1449a039939b57245212e7) - BUG/MINOR: init: always ensure that global.rlimit_nofile matches actual limits - BUG/MINOR: init: ensure that FD limit is raised to the max allowed - BUG/MEDIUM: external-checks: close all FDs right after the fork() - BUG/MAJOR: external-checks: use asynchronous signal delivery - BUG/MINOR: external-checks: do not unblock undesired signals - BUILD/MEDIUM: rebuild everything when an include file is changed - BUILD/MEDIUM: force a full rebuild if some build options change - BUG/MINOR: srv-state: fix incorrect output of state file - BUG/MINOR: ssl: close ssl key file on error - BUG/MINOR: http: fix misleading error message for response captures - BUG/BUILD: don't automatically run "make" on "make install" - DOC: add missing doc for http-request deny [deny_status ] - drop patches which were pulled from git before 0001-BUG-MAJOR-fix-listening-IP-address-storage-for-front.patch 0002-BUG-MINOR-fix-listening-IP-address-storage-for-front.patch 0003-DOC-Fix-typo-so-fetch-is-properly-parsed-by-Cyril-s-.patch 0004-BUG-MAJOR-http-fix-breakage-of-reqdeny-causing-rando.patch 0005-BUG-MEDIUM-stick-tables-fix-breakage-in-table-conver.patch 0006-BUG-MEDIUM-dns-unbreak-DNS-resolver-after-header-fix.patch 0007-BUILD-fix-build-on-Solaris-11.patch 0008-CLEANUP-connection-fix-double-negation-on-memcmp.patch 0009-BUG-MEDIUM-stats-show-servers-state-may-show-an-serv.patch 0010-BUG-MEDIUM-fix-risk-of-segfault-with-show-tls-keys.patch 0011-BUG-MEDIUM-sticktables-segfault-in-some-configuratio.patch 0012-BUG-MEDIUM-lua-converters-doesn-t-work.patch 0013-BUG-MINOR-http-add-header-header-name-copied-twice.patch 0014-BUG-MEDIUM-http-add-header-buffer-overwritten.patch- pull patches from git to fix some important issues (bsc#983972) (bsc#983974): 0001-BUG-MAJOR-fix-listening-IP-address-storage-for-front.patch 0002-BUG-MINOR-fix-listening-IP-address-storage-for-front.patch 0003-DOC-Fix-typo-so-fetch-is-properly-parsed-by-Cyril-s-.patch 0004-BUG-MAJOR-http-fix-breakage-of-reqdeny-causing-rando.patch 0005-BUG-MEDIUM-stick-tables-fix-breakage-in-table-conver.patch 0006-BUG-MEDIUM-dns-unbreak-DNS-resolver-after-header-fix.patch 0007-BUILD-fix-build-on-Solaris-11.patch 0008-CLEANUP-connection-fix-double-negation-on-memcmp.patch 0009-BUG-MEDIUM-stats-show-servers-state-may-show-an-serv.patch 0010-BUG-MEDIUM-fix-risk-of-segfault-with-show-tls-keys.patch 0011-BUG-MEDIUM-sticktables-segfault-in-some-configuratio.patch 0012-BUG-MEDIUM-lua-converters-doesn-t-work.patch 0013-BUG-MINOR-http-add-header-header-name-copied-twice.patch 0014-BUG-MEDIUM-http-add-header-buffer-overwritten.patch- update to 1.6.5 - BUG/MINOR: log: Don't use strftime() which can clobber timezone if chrooted - BUILD: namespaces: fix a potential build warning in namespaces.c - DOC: add encoding to json converter example - BUG/MINOR: conf: "listener id" expects integer, but its not checked - DOC: Clarify tunes.vars.xxx-max-size settings - BUG/MEDIUM: peers: fix incorrect age in frequency counters - BUG/MEDIUM: Fix RFC5077 resumption when more than TLS_TICKETS_NO are present - BUG/MAJOR: Fix crash in http_get_fhdr with exactly MAX_HDR_HISTORY headers - BUG/MINOR: lua: can't load external libraries - DOC: "addr" parameter applies to both health and agent checks - DOC: timeout client: pointers to timeout http-request - DOC: typo on stick-store response - DOC: stick-table: amend paragraph blaming the loss of table upon reload - DOC: typo: ACL subdir match - DOC: typo: maxconn paragraph is wrong due to a wrong buffer size - DOC: regsub: parser limitation about the inability to use closing square brackets - DOC: typo: req.uri is now replaced by capture.req.uri - DOC: name set-gpt0 mismatch with the expected keyword - BUG/MEDIUM: stick-tables: some sample-fetch doesn't work in the connection state. - DOC: fix "needed" typo - BUG/MINOR: dns: inapropriate way out after a resolution timeout - BUG/MINOR: dns: trigger a DNS query type change on resolution timeout - BUG/MINOR : allow to log cookie for tarpit and denied request - OPTIM/MINOR: session: abort if possible before connecting to the backend - BUG/MEDIUM: trace.c: rdtsc() is defined in two files - BUG/MEDIUM: channel: fix miscalculation of available buffer space (2nd try) - BUG/MINOR: cfgparse: couple of small memory leaks. - BUG/MEDIUM: sample: initialize the pointer before parse_binary call. - DOC: fix discrepancy in the example for http-request redirect - DOC: Clarify IPv4 address / mask notation rules - CLEANUP: fix inconsistency between fd->iocb, proto->accept and accept() - BUG/MEDIUM: fix maxaccept computation on per-process listeners - BUG/MINOR: listener: stop unbound listeners on startup - BUG/MINOR: fix maxaccept computation according to the frontend process range - MEDIUM: unblock signals on startup. - BUG/MEDIUM: channel: don't allow to overwrite the reserve until connected - BUG/MEDIUM: channel: incorrect polling condition may delay event delivery - BUG/MEDIUM: channel: fix miscalculation of available buffer space (3rd try) - BUG/MEDIUM: log: fix risk of segfault when logging HTTP fields in TCP mode - BUG/MEDIUM: lua: protects the upper boundary of the argument list for converters/fetches. - BUG/MINOR: log: fix a typo that would cause %HP to log - MINOR: channel: add new function channel_congested() - BUG/MEDIUM: http: fix risk of CPU spikes with pipelined requests from dead client - BUG/MAJOR: channel: fix miscalculation of available buffer space (4th try) - BUG/MEDIUM: stream: ensure the SI_FL_DONT_WAKE flag is properly cleared - BUG/MEDIUM: channel: fix inconsistent handling of 4GB-1 transfers - BUG/MEDIUM: stats: show servers state may show an empty or incomplete result - BUG/MEDIUM: stats: show backend may show an empty or incomplete result - MINOR: stats: fix typo in help messages - MINOR: stats: show stat resolvers missing in the help message - BUG/MINOR: dns: fix DNS header definition - BUG/MEDIUM: dns: fix alignment issue when building DNS queries - CLEANUP/MINOR: stats: fix accidental addition of member "env" in the applet ctx - refreshed patches to apply cleanly again - haproxy-1.6.0-makefile_lib.patch - haproxy-1.6.0-sec-options.patch- update to 1.6.4 (fate#320607) (bsc#937202) - BUG/MINOR: http: fix several off-by-one errors in the url_param parser - BUG/MINOR: http: Be sure to process all the data received from a server - BUG/MINOR: chunk: make chunk_dup() always check and set dst->size - MINOR: chunks: ensure that chunk_strcpy() adds a trailing zero - MINOR: chunks: add chunk_strcat() and chunk_newstr() - MINOR: chunk: make chunk_initstr() take a const string - MINOR: lru: new function to delete least recently used keys - DOC: add Ben Shillito as the maintainer of 51d - BUG/MINOR: 51d: Ensures a unique domain for each configuration - BUG/MINOR: 51d: Aligns Pattern cache implementation with HAProxy best practices. - BUG/MINOR: 51d: Releases workset back to pool. - BUG/MINOR: 51d: Aligned const pointers to changes in 51Degrees. - CLEANUP: 51d: Aligned if statements with HAProxy best practices and removed casts from malloc. - DOC: fix a few spelling mistakes (cherry picked from commit cc123c66c2075add8524a6a9925382927daa6ab0) - DOC: fix "workaround" spelling - BUG/MINOR: examples: Fixing haproxy.spec to remove references to .cfg files - MINOR: fix the return type for dns_response_get_query_id() function - MINOR: server state: missing LF (\n) on error message printed when parsing server state file - BUG/MEDIUM: dns: no DNS resolution happens if no ports provided to the nameserver - BUG/MAJOR: servers state: server port is erased when dns resolution is enabled on a server - BUG/MEDIUM: servers state: server port is used uninitialized - BUG/MEDIUM: config: Adding validation to stick-table expire value. - BUG/MEDIUM: sample: http_date() doesn't provide the right day of the week - BUG/MEDIUM: channel: fix miscalculation of available buffer space. - MEDIUM: pools: add a new flag to avoid rounding pool size up - BUG/MEDIUM: buffers: do not round up buffer size during allocation - BUG/MINOR: stream: don't force retries if the server is DOWN - BUG/MINOR: counters: make the sc-inc-gpc0 and sc-set-gpt0 touch the table - MINOR: unix: don't mention free ports on EAGAIN - BUG/CLEANUP: CLI: report the proper field states in "show sess" - MINOR: stats: send content-length with the redirect to allow keep-alive - BUG: stream_interface: Reuse connection even if the output channel is empty - DOC: remove old tunnel mode assumptions - BUG/MAJOR: http-reuse: fix risk of orphaned connections - BUG/MEDIUM: http-reuse: do not share private connections across backends - BUG/MINOR: ssl: Be sure to use unique serial for regenerated certificates - BUG/MINOR: stats: fix missing comma in stats on agent drain - BUG/MINOR: lua: unsafe initialization - DOC: lua: fix somme errors - DOC: add server name at rate-limit sessions example - BUG/MEDIUM: ssl: fix off-by-one in ALPN list allocation - BUG/MEDIUM: ssl: fix off-by-one in NPN list allocation - DOC: LUA: fix some typos and syntax errors - MINOR: cfgparse: warn for incorrect 'timeout retry' keyword spelling in resolvers - MINOR: mailers: increase default timeout to 10 seconds - MINOR: mailers: use for all line endings - BUG/MAJOR: lua: applets can't sleep. - BUG/MINOR: server: some prototypes are renamed - BUG/MINOR: lua: Useless copy - BUG/MEDIUM: stats: stats bind-process doesn't propagate the process mask correctly - BUG/MINOR: server: fix the format of the warning on address change - BUG/MEDIUM: chunks: always reject negative-length chunks - BUG/MINOR: systemd: ensure we don't miss signals - BUG/MINOR: systemd: report the correct signal in debug message output - BUG/MINOR: systemd: propagate the correct signal to haproxy - MINOR: systemd: ensure a reload doesn't mask a stop - BUG/MEDIUM: cfgparse: wrong argument offset after parsing server "sni" keyword - CLEANUP: stats: Avoid computation with uninitialized bits. - CLEANUP: pattern: Ignore unknown samples in pat_match_ip(). - CLEANUP: map: Avoid memory leak in out-of-memory condition. - BUG/MINOR: tcpcheck: fix incorrect list usage resulting in failure to load certain configs - BUG/MAJOR: samples: check smp->strm before using it - MINOR: sample: add a new helper to initialize the owner of a sample - MINOR: sample: always set a new sample's owner before evaluating it - BUG/MAJOR: vars: always retrieve the stream and session from the sample - CLEANUP: payload: remove useless and confusing nullity checks for channel buffer - BUG/MINOR: ssl: fix usage of the various sample fetch functions - MINOR: cfgparse: warn when uid parameter is not a number - MINOR: cfgparse: warn when gid parameter is not a number - BUG/MINOR: standard: Avoid free of non-allocated pointer - BUG/MINOR: pattern: Avoid memory leak on out-of-memory condition - CLEANUP: http: fix a build warning introduced by a recent fix - BUG/MINOR: log: GMT offset not updated when entering/leaving DST- update to 1.6.3 (fate#320607) - BUG/MEDIUM: lua: clean output buffer - BUG/MEDIUM: http: switch the request channel to no-delay once done. - BUG/MEDIUM: http: don't enable auto-close on the response side - BUG/MEDIUM: stream: fix half-closed timeout handling - BUG/MEDIUM: cli: changing compression rate-limiting must require admin level - BUG/MEDIUM: sample: urlp can't match an empty value - BUG/MEDIUM: da: stop DeviceAtlas processing in the convertor if there is no input. - BUG/MEDIUM: checks: email-alert not working when declared in defaults - BUG/MEDIUM: http: fix http-reuse when frontend and backend differ - BUG/MEDIUM: config: properly adjust maxconn with nbproc when memmax is forced - BUG/MEDIUM: peers: table entries learned from a remote are pushed to others after a random delay. - BUG/MEDIUM: peers: old stick table updates could be repushed - BUG/MEDIUM: lua: Lua applets must not fetch samples using http_txn - BUG/MEDIUM: lua: Forbid HTTP applets from being called from tcp rulesets - BUG/MAJOR: lua: Do not force the HTTP analysers in use-services for all the details see /usr/share/doc/packages/haproxy/CHANGELOG or http://www.haproxy.org/download/1.6/src/CHANGELOG- on sle11 we still need to own /etc/apparmor.d/local- instead of owning the apparmor directories, BR apparmor-profiles.- fix link to tarball- update to 1.6.2 - BUILD: ssl: fix build error introduced in commit 7969a3 with OpenSSL < 1.0.0 - DOC: fix a typo for a "deviceatlas" keyword - FIX: small typo in an example using the "Referer" header - BUG/MEDIUM: config: count memory limits on 64 bits, not 32 - BUG/MAJOR: dns: first DNS response packet not matching queried hostname may lead to a loop - BUG/MINOR: dns: unable to parse CNAMEs response - BUG/MINOR: examples/haproxy.init: missing brace in quiet_check() - DOC: deviceatlas: more example use cases. - BUG/BUILD: replace haproxy-systemd-wrapper with $(EXTRA) in install-bin. - BUG/MAJOR: http: don't requeue an idle connection that is already queued - DOC: typo on capture.res.hdr and capture.req.hdr - BUG/MINOR: dns: check for duplicate nameserver id in a resolvers section was missing - CLEANUP: use direction names in place of numeric values - BUG/MEDIUM: lua: sample fetches based on response doesn't work - drop haproxy-1.6.0-ssl-098.patch: included upstream- update to 1.6.1 - DOC: specify that stats socket doc (section 9.2) is in management - BUILD: install only relevant and existing documentation - CLEANUP: don't ignore debian/ directory if present - BUG/MINOR: dns: parsing error of some DNS response - BUG/MEDIUM: namespaces: don't fail if no namespace is used - BUG/MAJOR: ssl: free the generated SSL_CTX if the LRU cache is disabled - MEDIUM: dns: Don't use the ANY query type - drop haproxy-1.6.0-ssl.crash.patch included in update- add haproxy-1.6.0-ssl-098.patch: fix building on openssl 0.9.8- added haproxy-1.6.0-ssl.crash.patch: fix SNI related crash- only use network namespace support on distros newer than 13.2- update to 1.6.0 The most user-visible changes, we can cite the simpler handling of multiple configuration files, the support for quotes and environment variables in the configuration, a significant reduction of the memory usage thanks to a new dynamic buffer allocator, notifications over e-mail, server state keeping across reloads, dynamic DNS-based server address resolution, new scripting capabilities thanks to the embedded Lua interpreter, use of variables in the configuration to manipulate samples, request body buffering and analysis, support for two third-party device identification products (DeviceAtlas and 51Degrees), a lot of new sample converters including arithmetic operators and table lookups, TLS ticket secret sharing between nodes, TLS SNI to the server, full tables replication between peers, ability to instruct the kernel to quickly kill dead connections, support for Linux namespaces, and a number of other less visible goodies. The performance has also been improved a lot with support for server connection multiplexing, much faster and cheaper HTTP compression via libslz, and the addition of a pattern cache to speed up certain expensive ACLs. The great flexibility offered by this version will allow many users to significantly simplify their configurations. Some users will notice a huge performance boost after they enable the features designed for them. for all the details see /usr/share/doc/packages/haproxy/CHANGELOG - drop patches we pulled from upstream git: 0001-BUG-MINOR-log-missing-some-ARGC_-entries-in-fmt_dire.patch 0002-DOC-usesrc-root-privileges-requirements.patch 0003-BUILD-ssl-Allow-building-against-libssl-without-SSLv.patch 0004-DOC-MINOR-fix-OpenBSD-versions-where-haproxy-works.patch 0005-BUG-MINOR-http-sample-gmtime-localtime-can-fail.patch 0006-DOC-typo-in-redirect-302-code-meaning.patch 0007-DOC-mention-that-ms-is-left-padded-with-zeroes.patch 0008-CLEANUP-.gitignore-ignore-more-test-files.patch 0009-CLEANUP-.gitignore-finally-ignore-everything-but-wha.patch 0010-MEDIUM-config-emit-a-warning-on-a-frontend-without-l.patch 0011-BUG-MEDIUM-counters-ensure-that-src_-inc-clr-_gpc0-c.patch 0012-DOC-ssl-missing-LF.patch 0013-DOC-fix-example-of-http-request-using-ssl_fc_session.patch 0014-BUG-MINOR-http-remove-stupid-HTTP_METH_NONE-entry.patch 0015-BUG-MAJOR-http-don-t-call-http_send_name_header-afte.patch - refresh/redo patches to apply cleanly again: old: haproxy-1.2.16_config_haproxy_user.patch new: haproxy-1.6.0_config_haproxy_user.patch old: haproxy-makefile_lib.patch new: haproxy-1.6.0-makefile_lib.patch old: sec-options.patch new: haproxy-1.6.0-sec-options.patch - added new haproxy.cfg to have a minimal config we can actually launch! - drop patch haproxy-1.5.8-fix-bashisms.patch: patched files no longer exist - drop haproxy.vim: we will use the copy which ships with the upstream tarball now.- fix haproxy status checks (bsc#947204)- Backport patches from upstream: - BUG/MINOR: http: remove stupid HTTP_METH_NONE entry - BUG/MAJOR: http: don't call http_send_name_header() after an error - Add 0014-BUG-MINOR-http-remove-stupid-HTTP_METH_NONE-entry.patch - Add 0015-BUG-MAJOR-http-don-t-call-http_send_name_header-afte.patch- Backport patches from upstream: - BUG/MINOR: log: missing some ARGC_* entries in fmt_directives() - DOC: usesrc root privileges requirements - BUILD: ssl: Allow building against libssl without SSLv3. - DOC/MINOR: fix OpenBSD versions where haproxy works - BUG/MINOR: http/sample: gmtime/localtime can fail - DOC: typo in 'redirect', 302 code meaning - DOC: mention that %ms is left-padded with zeroes. - CLEANUP: .gitignore: ignore more test files - CLEANUP: .gitignore: finally ignore everything but what is known. - MEDIUM: config: emit a warning on a frontend without listener - BUG/MEDIUM: counters: ensure that src_{inc,clr}_gpc0 creates a missing entry - DOC: ssl: missing LF - DOC: fix example of http-request using ssl_fc_session_id - Add 0001-BUG-MINOR-log-missing-some-ARGC_-entries-in-fmt_dire.patch - Add 0002-DOC-usesrc-root-privileges-requirements.patch - Add 0003-BUILD-ssl-Allow-building-against-libssl-without-SSLv.patch - Add 0004-DOC-MINOR-fix-OpenBSD-versions-where-haproxy-works.patch - Add 0005-BUG-MINOR-http-sample-gmtime-localtime-can-fail.patch - Add 0006-DOC-typo-in-redirect-302-code-meaning.patch - Add 0007-DOC-mention-that-ms-is-left-padded-with-zeroes.patch - Add 0008-CLEANUP-.gitignore-ignore-more-test-files.patch - Add 0009-CLEANUP-.gitignore-finally-ignore-everything-but-wha.patch - Add 0010-MEDIUM-config-emit-a-warning-on-a-frontend-without-l.patch - Add 0011-BUG-MEDIUM-counters-ensure-that-src_-inc-clr-_gpc0-c.patch - Add 0012-DOC-ssl-missing-LF.patch - Add 0013-DOC-fix-example-of-http-request-using-ssl_fc_session.patch- Update to 1.5.14 (CVE-2015-3281) (bsc#937042) + BUILD/MINOR: tools: rename popcount to my_popcountl + BUG/MAJOR: buffers: make the buffer_slow_realign() function respect output data- Update to 1.5.13 - Dropped all patches backported from git, no further changes than those patches provided. - Removed patches: + Remove 0001-BUG-MEDIUM-stats-properly-initialize-the-scope-befor.patch + Remove 0002-BUG-MEDIUM-http-don-t-forward-client-shutdown-withou.patch + Remove 0003-BUG-MINOR-check-fix-tcpcheck-error-message.patch + Remove 0004-CLEANUP-checks-fix-double-usage-of-cur-current_step-.patch + Remove 0005-BUG-MEDIUM-checks-do-not-dereference-head-of-a-tcp-c.patch + Remove 0006-CLEANUP-checks-simplify-the-loop-processing-of-tcp-c.patch + Remove 0007-BUG-MAJOR-checks-always-check-for-end-of-list-before.patch + Remove 0008-BUG-MEDIUM-checks-do-not-dereference-a-list-as-a-tcp.patch + Remove 0009-BUG-MEDIUM-peers-apply-a-random-reconnection-timeout.patch + Remove 0010-DOC-Update-doc-about-weight-act-and-bck-fields-in-th.patch + Remove 0011-MINOR-ssl-add-a-destructor-to-free-allocated-SSL-res.patch + Remove 0012-BUG-MEDIUM-ssl-fix-tune.ssl.default-dh-param-value-b.patch + Remove 0013-BUG-MINOR-cfgparse-fix-typo-in-option-httplog-error-.patch + Remove 0014-BUG-MEDIUM-cfgparse-segfault-when-userlist-is-misuse.patch + Remove 0015-MEDIUM-ssl-replace-standards-DH-groups-with-custom-o.patch + Remove 0016-BUG-MINOR-debug-display-null-in-place-of-meth.patch + Remove 0017-CLEANUP-deinit-remove-codes-for-cleaning-p-block_rul.patch + Remove 0018-BUG-MINOR-ssl-fix-smp_fetch_ssl_fc_session_id.patch + Remove 0019-MEDIUM-init-don-t-stop-proxies-in-parent-process-whe.patch + Remove 0020-MINOR-peers-store-the-pointer-to-the-signal-handler.patch + Remove 0021-MEDIUM-peers-unregister-peers-that-were-never-starte.patch + Remove 0022-MEDIUM-config-propagate-the-table-s-process-list-to-.patch + Remove 0023-MEDIUM-init-stop-any-peers-section-not-bound-to-the-.patch + Remove 0024-MEDIUM-config-validate-that-peers-sections-are-bound.patch + Remove 0025-MAJOR-peers-allow-peers-section-to-be-used-with-nbpr.patch + Remove 0026-DOC-relax-the-peers-restriction-to-single-process.patch + Remove 0027-CLEANUP-config-fix-misleading-information-in-error-m.patch + Remove 0028-MINOR-config-report-the-number-of-processes-using-a-.patch + Remove 0029-BUG-MEDIUM-config-properly-compute-the-default-numbe.patch- Backport upstream patches: + DOC: Update doc about weight, act and bck fields in the statistics + MINOR: ssl: add a destructor to free allocated SSL ressources + BUG/MEDIUM: ssl: fix tune.ssl.default-dh-param value being overwritten + BUG/MINOR: cfgparse: fix typo in 'option httplog' error message + BUG/MEDIUM: cfgparse: segfault when userlist is misused + MEDIUM: ssl: replace standards DH groups with custom ones + BUG/MINOR: debug: display (null) in place of "meth" + CLEANUP: deinit: remove codes for cleaning p->block_rules + BUG/MINOR: ssl: fix smp_fetch_ssl_fc_session_id + MEDIUM: init: don't stop proxies in parent process when exiting + MINOR: peers: store the pointer to the signal handler + MEDIUM: peers: unregister peers that were never started + MEDIUM: config: propagate the table's process list to the peers sections + MEDIUM: init: stop any peers section not bound to the correct process + MEDIUM: config: validate that peers sections are bound to exactly one process + MAJOR: peers: allow peers section to be used with nbproc > 1 + DOC: relax the peers restriction to single-process + CLEANUP: config: fix misleading information in error message. + MINOR: config: report the number of processes using a peers section in the error case + BUG/MEDIUM: config: properly compute the default number of processes for a proxy - Added patches: + Add 0010-DOC-Update-doc-about-weight-act-and-bck-fields-in-th.patch + Add 0011-MINOR-ssl-add-a-destructor-to-free-allocated-SSL-res.patch + Add 0012-BUG-MEDIUM-ssl-fix-tune.ssl.default-dh-param-value-b.patch + Add 0013-BUG-MINOR-cfgparse-fix-typo-in-option-httplog-error-.patch + Add 0014-BUG-MEDIUM-cfgparse-segfault-when-userlist-is-misuse.patch + Add 0015-MEDIUM-ssl-replace-standards-DH-groups-with-custom-o.patch + Add 0016-BUG-MINOR-debug-display-null-in-place-of-meth.patch + Add 0017-CLEANUP-deinit-remove-codes-for-cleaning-p-block_rul.patch + Add 0018-BUG-MINOR-ssl-fix-smp_fetch_ssl_fc_session_id.patch + Add 0019-MEDIUM-init-don-t-stop-proxies-in-parent-process-whe.patch + Add 0020-MINOR-peers-store-the-pointer-to-the-signal-handler.patch + Add 0021-MEDIUM-peers-unregister-peers-that-were-never-starte.patch + Add 0022-MEDIUM-config-propagate-the-table-s-process-list-to-.patch + Add 0023-MEDIUM-init-stop-any-peers-section-not-bound-to-the-.patch + Add 0024-MEDIUM-config-validate-that-peers-sections-are-bound.patch + Add 0025-MAJOR-peers-allow-peers-section-to-be-used-with-nbpr.patch + Add 0026-DOC-relax-the-peers-restriction-to-single-process.patch + Add 0027-CLEANUP-config-fix-misleading-information-in-error-m.patch + Add 0028-MINOR-config-report-the-number-of-processes-using-a-.patch + Add 0029-BUG-MEDIUM-config-properly-compute-the-default-numbe.patch- BUG/MINOR: check: fix tcpcheck error message - CLEANUP: checks: fix double usage of cur / current_step in tcp-checks - BUG/MEDIUM: checks: do not dereference head of a tcp-check at the end - CLEANUP: checks: simplify the loop processing of tcp-checks - BUG/MAJOR: checks: always check for end of list before proceeding - BUG/MEDIUM: checks: do not dereference a list as a tcpcheck struct - BUG/MEDIUM: peers: apply a random reconnection timeout - Add 0003-BUG-MINOR-check-fix-tcpcheck-error-message.patch - Add 0004-CLEANUP-checks-fix-double-usage-of-cur-current_step-.patch - Add 0005-BUG-MEDIUM-checks-do-not-dereference-head-of-a-tcp-c.patch - Add 0006-CLEANUP-checks-simplify-the-loop-processing-of-tcp-c.patch - Add 0007-BUG-MAJOR-checks-always-check-for-end-of-list-before.patch - Add 0008-BUG-MEDIUM-checks-do-not-dereference-a-list-as-a-tcp.patch - Add 0009-BUG-MEDIUM-peers-apply-a-random-reconnection-timeout.patch- added 0002-BUG-MEDIUM-http-don-t-forward-client-shutdown-withou.patch BUG/MEDIUM: http: don't forward client shutdown without NOLINGER except for tunnels- added first patch from the 1.5 branch after the update: 0001-BUG-MEDIUM-stats-properly-initialize-the-scope-befor.patch- update to 1.5.12 - BUG/MINOR: ssl: Display correct filename in error message - DOC: Fix L4TOUT typo in documentation - BUG/MEDIUM: Do not consider an agent check as failed on L7 error - BUG/MINOR: pattern: error message missing - BUG/MEDIUM: pattern: some entries are not deleted with case insensitive match - BUG/MEDIUM: buffer: one byte miss in buffer free space check - BUG/MAJOR: http: don't read past buffer's end in http_replace_value - BUG/MEDIUM: http: the function "(req|res)-replace-value" doesn't respect the HTTP syntax - BUG/MEDIUM: peers: correctly configure the client timeout - BUG/MINOR: compression: consider the expansion factor in init - BUG/MEDIUM: http: hdr_cnt would not count any header when called without name - BUG/MEDIUM: listener: don't report an error when resuming unbound listeners - BUG/MEDIUM: init: don't limit cpu-map to the first 32 processes only - BUG/MEDIUM: stream-int: always reset si->ops when si->end is nullified - BUG/MEDIUM: http: remove content-length from chunked messages - DOC: http: update the comments about the rules for determining transfer-length - BUG/MEDIUM: http: do not restrict parsing of transfer-encoding to HTTP/1.1 - BUG/MEDIUM: http: incorrect transfer-coding in the request is a bad request - BUG/MEDIUM: http: remove content-length form responses with bad transfer-encoding - MEDIUM: http: restrict the HTTP version token to 1 digit as per RFC7230 - MEDIUM: http: add option-ignore-probes to get rid of the floods of 408 - BUG/MINOR: config: clear proxy->table.peers.p for disabled proxies - MINOR: stick-table: don't attach to peers in stopped state - MEDIUM: config: initialize stick-tables after peers, not before - MEDIUM: peers: add the ability to disable a peers section - DOC: document option http-ignore-probes - DOC: fix the comments about the meaning of msg->sol in HTTP - BUG/MEDIUM: http: wait for the exact amount of body bytes in wait_for_request_body - BUG/MAJOR: http: prevent risk of reading past end with balance url_param - DOC: update the doc on the proxy protocol - remove patches that we pulled from the 1.5 tree 0001-BUG-MINOR-pattern-error-message-missing.patch 0002-BUG-MEDIUM-pattern-some-entries-are-not-deleted-with.patch 0003-BUG-MEDIUM-Do-not-consider-an-agent-check-as-failed-.patch 0004-BUG-MEDIUM-peers-correctly-configure-the-client-time.patch 0005-BUG-MEDIUM-buffer-one-byte-miss-in-buffer-free-space.patch 0006-BUG-MAJOR-http-don-t-read-past-buffer-s-end-in-http_.patch 0007-BUG-MEDIUM-http-the-function-req-res-replace-value-d.patch 0008-BUG-MINOR-compression-consider-the-expansion-factor-.patch 0009-BUG-MEDIUM-http-hdr_cnt-would-not-count-any-header-w.patch 0010-BUG-MINOR-ssl-Display-correct-filename-in-error-mess.patch 0011-BUG-MEDIUM-listener-don-t-report-an-error-when-resum.patch 0012-BUG-MEDIUM-init-don-t-limit-cpu-map-to-the-first-32-.patch- pull 3 patches from upstream: 0010-BUG-MINOR-ssl-Display-correct-filename-in-error-mess.patch 0011-BUG-MEDIUM-listener-don-t-report-an-error-when-resum.patch 0012-BUG-MEDIUM-init-don-t-limit-cpu-map-to-the-first-32-.patch- pull 3 patches from upstream: 0007-BUG-MEDIUM-http-the-function-req-res-replace-value-d.patch 0008-BUG-MINOR-compression-consider-the-expansion-factor-.patch 0009-BUG-MEDIUM-http-hdr_cnt-would-not-count-any-header-w.patch- pull 3 patches from upstream: - BUG/MEDIUM: peers: correctly configure the client timeout - BUG/MEDIUM: buffer: one byte miss in buffer free space check - BUG/MAJOR: http: don't read past buffer's end in http_replace_value - Add 0004-BUG-MEDIUM-peers-correctly-configure-the-client-time.patch - Add 0005-BUG-MEDIUM-buffer-one-byte-miss-in-buffer-free-space.patch - Add 0006-BUG-MAJOR-http-don-t-read-past-buffer-s-end-in-http_.patch- added another fix from upstream: 0003-BUG-MEDIUM-Do-not-consider-an-agent-check-as-failed-.patch- haproxy.init: fix reload and force-reload not to start a stopped service- pulled 2 patches from upstream: 0001-BUG-MINOR-pattern-error-message-missing.patch 0002-BUG-MEDIUM-pattern-some-entries-are-not-deleted-with.patch- update to 1.5.11 - BUG/MEDIUM: backend: correctly detect the domain when use_domain_only is used - MINOR: ssl: load certificates in alphabetical order - BUG/MINOR: checks: prevent http keep-alive with http-check expect - BUG/MEDIUM: Do not set agent health to zero if server is disabled in config - MEDIUM/BUG: Only explicitly report "DOWN (agent)" if the agent health is zero - BUG/MINOR: stats:Fix incorrect printf type. - DOC: add missing entry for log-format and clarify the text - BUG/MEDIUM: http: fix header removal when previous header ends with pure LF - BUG/MEDIUM: channel: fix possible integer overflow on reserved size computation - BUG/MINOR: channel: compare to_forward with buf->i, not buf->size - MINOR: channel: add channel_in_transit() - MEDIUM: channel: make buffer_reserved() use channel_in_transit() - MEDIUM: channel: make bi_avail() use channel_in_transit() - BUG/MEDIUM: channel: don't schedule data in transit for leaving until connected - BUG/MAJOR: log: don't try to emit a log if no logger is set - BUG/MINOR: args: add missing entry for ARGT_MAP in arg_type_names - BUG/MEDIUM: http: make http-request set-header compute the string before removal - BUG/MINOR: http: fix incorrect header value offset in replace-hdr/replace-value - BUG/MINOR: http: abort request processing on filter failure - drop patch included in update: 0001-BUG-MEDIUM-backend-correctly-detect-the-domain-when-.patch- pull fix from usptream: 0001-BUG-MEDIUM-backend-correctly-detect-the-domain-when-.patch BUG/MEDIUM: backend: correctly detect the domain when use_domain_only is used- update to 1.5.10 - DOC: fix a few typos - BUG/MINOR: http: fix typo: "401 Unauthorized" => "407 Unauthorized" - BUG/MINOR: parse: refer curproxy instead of proxy - DOC: httplog does not support 'no' - MINOR: map/acl/dumpstats: remove the "Done." message - BUG/MEDIUM: sample: fix random number upper-bound - BUG/MEDIUM: patterns: previous fix was incomplete - BUG/MEDIUM: payload: ensure that a request channel is available - BUG/MINOR: tcp-check: don't condition data polling on check type - BUG/MEDIUM: tcp-check: don't rely on random memory contents - BUG/MEDIUM: tcp-checks: disable quick-ack unless next rule is an expect - BUG/MINOR: config: fix typo in condition when propagating process binding - BUG/MEDIUM: config: do not propagate processes between stopped processes - BUG/MAJOR: stream-int: properly check the memory allocation return - BUG/MEDIUM: memory: fix freeing logic in pool_gc2() - BUG/MEDIUM: compression: correctly report zlib_mem - drop patches that we pulled from git before: 0001-BUG-MEDIUM-patterns-previous-fix-was-incomplete.patch 0002-BUG-MEDIUM-payload-ensure-that-a-request-channel-is-.patch 0003-BUG-MINOR-tcp-check-don-t-condition-data-polling-on-.patch 0004-BUG-MEDIUM-tcp-check-don-t-rely-on-random-memory-con.patch 0005-BUG-MEDIUM-tcp-checks-disable-quick-ack-unless-next-.patch 0006-DOC-fix-a-few-typos.patch 0007-BUG-MEDIUM-sample-fix-random-number-upper-bound.patch 0008-DOC-httplog-does-not-support-no.patch 0009-BUG-MINOR-http-fix-typo-401-Unauthorized-407-Unautho.patch 0010-BUG-MINOR-parse-refer-curproxy-instead-of-proxy.patch 0011-BUG-MINOR-config-fix-typo-in-condition-when-propagat.patch 0012-BUG-MEDIUM-config-do-not-propagate-processes-between.patch- pulled some more fixes from git: 0003-BUG-MINOR-tcp-check-don-t-condition-data-polling-on-.patch 0004-BUG-MEDIUM-tcp-check-don-t-rely-on-random-memory-con.patch 0005-BUG-MEDIUM-tcp-checks-disable-quick-ack-unless-next-.patch 0006-DOC-fix-a-few-typos.patch 0007-BUG-MEDIUM-sample-fix-random-number-upper-bound.patch 0008-DOC-httplog-does-not-support-no.patch 0009-BUG-MINOR-http-fix-typo-401-Unauthorized-407-Unautho.patch 0010-BUG-MINOR-parse-refer-curproxy-instead-of-proxy.patch 0011-BUG-MINOR-config-fix-typo-in-condition-when-propagat.patch 0012-BUG-MEDIUM-config-do-not-propagate-processes-between.patch see patch headers for details.- pulled 2 fixes from git: - 0001-BUG-MEDIUM-patterns-previous-fix-was-incomplete.patch Dmitry Sivachenko reported that commit 315ec42 ("BUG/MEDIUM: pattern: don't load more than once a pattern list.") relies on an uninitialised variable in the stack. While it used to work fine during the tests, if the uninitialized variable is non-null, some patterns may be aggregated if loaded multiple times, resulting in slower processing, which was the original issue it tried to address. - 0002-BUG-MEDIUM-payload-ensure-that-a-request-channel-is-.patch Denys Fedoryshchenko reported a segfault when using certain sample fetch functions in the "tcp-request connection" rulesets despite the warnings. This is because some tests for the existence of the channel were missing.- fix bashisms in example scripts - add patches: * haproxy-1.5.8-fix-bashisms.patch- update to 1.5.9 - BUILD: fix "make install" to support spaces in the install dirs - BUG/MEDIUM: checks: fix conflicts between agent checks and ssl healthchecks - BUG/MEDIUM: ssl: fix bad ssl context init can cause segfault in case of OOM. - BUG/MINOR: samples: fix unnecessary memcopy converting binary to string. - BUG/MEDIUM: connection: sanitize PPv2 header length before parsing address information - BUG/MEDIUM: pattern: don't load more than once a pattern list. - BUG/MEDIUM: ssl: force a full GC in case of memory shortage - BUG/MINOR: config: don't inherit the default balance algorithm in frontends - BUG/MAJOR: frontend: initialize capture pointers earlier - BUG/MINOR: stats: correctly set the request/response analysers - DOC: fix typo in the body parser documentation for msg.sov - BUG/MINOR: peers: the buffer size is global.tune.bufsize, not trash.size - MINOR: sample: add a few basic internal fetches (nbproc, proc, stopping) - BUG/MAJOR: sessions: unlink session from list on out of memory - Drop patches pulled from git - 0001-BUILD-fix-make-install-to-support-spaces-in-the-inst.patch - 0002-BUG-MEDIUM-ssl-fix-bad-ssl-context-init-can-cause-se.patch - 0003-BUG-MEDIUM-ssl-force-a-full-GC-in-case-of-memory-sho.patch - 0004-BUG-MEDIUM-checks-fix-conflicts-between-agent-checks.patch - 0005-BUG-MINOR-config-don-t-inherit-the-default-balance-a.patch - 0006-BUG-MAJOR-frontend-initialize-capture-pointers-earli.patch- BUILD: fix "make install" to support spaces in the install dirs - BUG/MEDIUM: ssl: fix bad ssl context init can cause segfault in case of OOM. - BUG/MEDIUM: ssl: force a full GC in case of memory shortage - BUG/MEDIUM: checks: fix conflicts between agent checks and ssl healthchecks - BUG/MINOR: config: don't inherit the default balance algorithm in frontends - BUG/MAJOR: frontend: initialize capture pointers earlier - Add patches: - 0001-BUILD-fix-make-install-to-support-spaces-in-the-inst.patch - 0002-BUG-MEDIUM-ssl-fix-bad-ssl-context-init-can-cause-se.patch - 0003-BUG-MEDIUM-ssl-force-a-full-GC-in-case-of-memory-sho.patch - 0004-BUG-MEDIUM-checks-fix-conflicts-between-agent-checks.patch - 0005-BUG-MINOR-config-don-t-inherit-the-default-balance-a.patch - 0006-BUG-MAJOR-frontend-initialize-capture-pointers-earli.patch- fix bashisms in pre script- update to 1.5.8 - BUG/MAJOR: buffer: check the space left is enough or not when input data in a buffer is wrapped - BUG/BUILD: revert accidental change in the makefile from latest SSL fix - changes in 1.5.7 - BUG/MEDIUM: regex: fix pcre_study error handling - BUG/MINOR: log: fix request flags when keep-alive is enabled - MINOR: ssl: add fetchs 'ssl_c_der' and 'ssl_f_der' to return DER formatted certs - MINOR: ssl: add statement to force some ssl options in global. - BUG/MINOR: ssl: correctly initialize ssl ctx for invalid certificates - BUG/MEDIUM: http: don't dump debug headers on MSG_ERROR - BUG/MAJOR: cli: explicitly call cli_release_handler() upon error - BUG/MEDIUM: tcp: fix outgoing polling based on proxy protocol - BUG/MEDIUM: tcp: don't use SO_ORIGINAL_DST on non-AF_INET sockets - Dropped patches: - 0001-BUG-MEDIUM-http-don-t-dump-debug-headers-on-MSG_ERRO.patch - 0002-BUG-MAJOR-cli-explicitly-call-cli_release_handler-up.patch - 0003-BUG-MINOR-log-fix-request-flags-when-keep-alive-is-e.patch - 0004-BUG-MEDIUM-tcp-fix-outgoing-polling-based-on-proxy-p.patch- BUG/MEDIUM: http: don't dump debug headers on MSG_ERROR - BUG/MAJOR: cli: explicitly call cli_release_handler() upon error - BUG/MINOR: log: fix request flags when keep-alive is enabled - BUG/MEDIUM: tcp: fix outgoing polling based on proxy protocol - Added patches: - 0001-BUG-MEDIUM-http-don-t-dump-debug-headers-on-MSG_ERRO.patch - 0002-BUG-MAJOR-cli-explicitly-call-cli_release_handler-up.patch - 0003-BUG-MINOR-log-fix-request-flags-when-keep-alive-is-e.patch - 0004-BUG-MEDIUM-tcp-fix-outgoing-polling-based-on-proxy-p.patch- update to 1.5.6 - BUG/MEDIUM: systemd: set KillMode to 'mixed' - MINOR: systemd: Check configuration before start - BUG/MEDIUM: config: avoid skipping disabled proxies - BUG/MINOR: config: do not accept more track-sc than configured - BUG/MEDIUM: backend: fix URI hash when a query string is present - dropped patches that were pulled from upstream 0001-BUG-MEDIUM-config-avoid-skipping-disabled-proxies.patch 0001-BUG-MEDIUM-systemd-set-KillMode-to-mixed.patch 0004-BUG-MINOR-config-do-not-accept-more-track-sc-than-co.patch 0005-BUG-MEDIUM-backend-fix-URI-hash-when-a-query-string-.patch - dropped patch we sent upstream haproxy-1.5_check_config_before_start.patch- BUG/MINOR: config: do not accept more track-sc than configured - BUG/MEDIUM: backend: fix URI hash when a query string is present - Add patch: 0004-BUG-MINOR-config-do-not-accept-more-track-sc-than-co.patch - Add patch: 0005-BUG-MEDIUM-backend-fix-URI-hash-when-a-query-string-.patch/bin/sh/bin/sh/bin/sh/bin/shhaproxy-1.5haproxy-docsheep04 1630672509  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~2.0.14-11.11.12.0.14-11.11.12.0.14-11.11.12.0.142.0.142.0.142.0.14   usr.sbin.haproxyusr.sbin.haproxyhaproxyhaproxy.cfghaproxy.servicehaproxyhaproxy-halogrchaproxyhaproxy51Degrees-device-detection.txtCHANGELOGDeviceAtlas-device-detection.txtREADMEROADMAPSOCKS4.protocol.txtSPOE.txtWURFL-device-detection.txtacl.figarchitecture.txtclose-options.txtcoding-style.txtconfiguration.txtcookie-options.txtdesign-thoughtsbackends-v0.txtbackends.txtbe-fe-changes.txtbinding-possibilities.txtconfig-language.txtconnection-reuse.txtconnection-sharing.txtdynamic-buffers.txtentities-v2.txthow-it-works.txthttp2.txthttp_load_time.urlrate-shaping.txtsess_par_sec.txtexamplesacl-content-sw.cfgcontent-sw-sample.cfgerrorfiles400.http403.http408.http500.http502.http503.http504.httpREADMEoption-http_proxy.cfgsocks4.cfgtransparent_proxy.cfgwurfl-example.cfggpl.txthaproxy.1internalsacl.txtbody-parsing.txtbuffer-api.txtconnect-status.txtconnection-header.txtconnection-scale.txtentities-v2.txtentities.figentities.pdfentities.svgentities.txtfilters.txthashing.txtheader-parser-speed.txtheader-tree.txthttp-cookies.txthttp-docs.txthttp-parsing.txtlist.figlistener-states.figlistener-states.pnglua_socket.figlua_socket.pdfnaming.txtnotes-layers.txtpattern.diapattern.pdfpolling-states.figrepartition-be-fe-fi.txtsequence.figstats-v2.txtstream-sock-states.figintro.txtlgpl.txtlinux-syn-cookies.txtlua-apiMakefile_staticchannel.figchannel.pngconf.pyindex.rstlua.txtmanagement.txtnetscaler-client-ip-insertion-protocol.txtnetsnmp-perlREADMEcacti_data_query_haproxy_backends.xmlcacti_data_query_haproxy_frontends.xmlhaproxy.plhaproxy_backend.xmlhaproxy_frontend.xmlhaproxy_socket.xmlnetwork-namespaces.txtpeers-v2.0.txtpeers.txtproxy-protocol.txtqueuing.figregression-testing.txtseamless_reload.txtselinuxREADMEhaproxy.fchaproxy.ifhaproxy.tehaproxyLICENSEhaproxy.1.gzhaproxy.vimhaproxy/etc/apparmor.d/local//etc/apparmor.d//etc//etc/haproxy//usr/lib/systemd/system//usr/sbin//usr/share/doc/packages//usr/share/doc/packages/haproxy//usr/share/doc/packages/haproxy/design-thoughts//usr/share/doc/packages/haproxy/examples//usr/share/doc/packages/haproxy/examples/errorfiles//usr/share/doc/packages/haproxy/internals//usr/share/doc/packages/haproxy/lua-api//usr/share/doc/packages/haproxy/lua-api/_static//usr/share/doc/packages/haproxy/netsnmp-perl//usr/share/doc/packages/haproxy/selinux//usr/share/licenses//usr/share/licenses/haproxy//usr/share/man/man1//usr/share/vim/vim80/syntax//var/lib/-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:21035/SUSE_SLE-15-SP2_Update/9d60a9106c0d7bb8121d0caa8867a4ce-haproxy.SUSE_SLE-15-SP2_Updatedrpmxz5x86_64-suse-linux      ASCII textC source, ASCII textdirectoryELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=ae2b7b2c20c9d372cc2855e331acc6739bc031f9, for GNU/Linux 3.2.0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=9209f3e0fc4a0373b1dc423a99d918fbb414df17, for GNU/Linux 3.2.0, strippedASCII text, with no line terminatorsFIG image text, version 3.2, ASCII textISO-8859 textHTML document, ASCII textHTML document, ASCII text, with CRLF, LF line terminatorstroff or preprocessor input, ASCII textSVG Scalable Vector Graphics imageUTF-8 Unicode textPNG image data, 974 x 768, 8-bit/color RGB, non-interlacedXML 1.0 document, UTF-8 Unicode text (gzip compressed data, max compression, from Unix)PNG image data, 596 x 180, 8-bit/color RGB, non-interlacedSE Linux policy interface sourcetroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)!!RRRR$RRRR"R!RRR R RRRR RRRR R RRR%RRR RRR#RRRRR Rod7Zd)hQapparmor-abstractionsutf-801bee9e4310eeff89b78d3cd2090a2e19f5a5aee445690e8665889e178348bb4?@7zXZ !t/_]"k%a/hIVaM;L޾!mb_|ppbFe<ӫ bTlY4{(!&IZGM"d!Főz'dK" l0"OOkA5!i*]: H7_˕ $wv[-VrJ;N7<$N;RIRr[]odU0I;} ;z7=Ö3:qw.l4ߑЂ\#י E=<Z c6~m9Mo8A늒N´iF=oP&A,̵ep>X_Iؔ =6IŽ"Hץ5h/wc"qh '|vR cF:O@爂oL(R`,ޓlW%oDJ>e(aD 9ME:T~$&XmnLzA m(f%֏I⊔ƳsD1Y<IQ, I'lebIDDlx.e},J߷ʭB7AMrx6k̿ *&j{ N rZsK ˰Fä:4- څقIxKAF%Ȫ4s[XM%۠CT1[FKLjݙdCQveS(0qݲL\K+bgME/U.%}&hB)&T*'K1/';,,v4QG* _"#S\g"W^Ek@cȇѻɪP4U/z#±k S t<BN<&s+?YMVl"]?T2j'kh,1MQ;XQ7T|{.oЏ ;4Hd  PdNcÁ=Aeֶ P}AxN${?AeVيyy0C[G^PyvTIB$.ɡ4-%OFa1uj9D6.+UEO([iuo`r`7y 􅝈cpO{WBյ%'N)%yh{fjOJĆ7PY/s Y&ѺGDC,3H= !0Qh75Y=JL&ḧ́,FHӧGĚ0;B2"bStQj_Q#h[AF~]kèඥ ڰ; I-kyc"0W0hf)vax|vQ%&˞>,.&2ve:$Hşഎ/8GZj ?V EhX}_2BQBVp~Cq7d;prCĔ3r8}^$j J+?Hj($HdܥW:Y NT,n+'& 7>H:NA*:uAn͌X іP ہz>qÍ7T:ext(ko\K/Ԭ#Yލ]fqMf{5MzgO3hOK饈@ǒrVdDhvН7XjOш(!^Ҽ&=tTꆗ%W:W\9OP$rxY]řwe̷jua\PrV x⮨IPw!czX6E9VdǜҸwcx>~ؚ"N|AA ڿ.䇊B W' :2@{sgnn6E]Β܈G~Y*s,R$0mƯ!Ftij-Qo]AgCk$x>)GPv9#a? p jo@C1<UiU 3<6Eܭ"Tf=Zlt;cܕP0w9gec -dbAD;L"{2hb$K']A08ݧXT%x.q<bW8dHhҽ3I#2:0.X.hu>y>Z؜-Rߕ ՙ.|#k[0SKɪ;QC0α]z Ys-/QeDbԒl\GI?G- Z7#fK>T"4Q19O! FM8Nݿ!1@O| g%ƬH*v5wwD "& 5qUn:bY1&44 1F>9 AVh, 1*;'j UuI2j\Q}p59p{ PaiIiWhrfqM3v(WrzCPp v*L[ o!* j(Wkvß5 \$`2A%t q#=̠d^)y-b{}TLUQ2q|k+>b0y3.eIlYutAIpbVYP#fD&nrب!CDbS$Zh<భ2p4oC/HӰ 1*:Y,{&xcϮ| Lj2*`gh;δ▁iAeѼv`]wD\Wحl2mL w AYKu5v-͝)u\l١ Ϋ@0//Sk ⭖н K]}-57WEM @yQYo^ ,k$.-}<˧t8zu[K.{\ !ȭSyAsoTAsHTrJ ;MУ(S m$\%=iJqZq)ōmٌ.CMQ+e] h @-*R4\.mkR e|;(='٢NS*foԳ!1-\i.Cd$afƬnTKDr[xXzZ:?a"f$ k3`ԉ8m(Q}1Rc SHu놣3IR)ҡFD <ZӒ^] L1.|=Eƈm!O y>ّ4e˔N)v~u^¤<.N!iͦnPBNz: ֜OXKK n/ӎ9Rnhh-*$AQMl,g;uȾO(t*O5$ֹ`{(N2kqa]Բ17.(7O@ rRSJ[6T>>1fOK<63l/TMdIgbYs GnYI/tYB.f"i-t~$&Y] c43떴TΫrʥHY?TuF;g`,.=+PUD3~FJk')+쑟^yx4n"u'ː&236 ^̛A S.XgY47t^g N]-H0iRޛ(eUyf$bq1؟cF386;=0WT;M:Dz[1 W ԁ̫.b;(SUT^ A 6!$k'el;|œwOd%^/8gI.`8D楯N[\4YFfiI-]+ IC"Nĕ)8fϘ)^Ǿ$U?&BTلy5bӛ!ٺW3ۊRn>[ee*_卺XN66$ ~J-㶼[ɼ:"$a"v<N*u mjw  )Rƒ{QCѝ,-i@ƠSH^M 0! Nv?w|e'y#Nyں_fS?J si@}H%Ib1⺹ Bv")DžԦLp2I%^m.e0XƩT/DtߒD fqJ\pD+=>=+;t qZ|!+wj}Pˇ[ Θ2ȿ\;D fDKj5x|4kg)z Z)2УS2^C^V> olD,R!Nl u~rߨ93f{ąO[7fWS1ƇhKm[iT}j&4%a<] Jq k#j5S.1gi 3[i-KF&9usrVu wlggUO XOb%Nϻ2h_m5=%?$n5N[!?xv#0el ]Wˆ#BQ([Ҋ.I } # (VVEԕrzHܧ7JGTL%$׋ KQM"}V@/7-ְ8A)>撉1{LHQ$?ek՜LQzD/UӹI˓:  lT$ćG. gd Vsxnս#f2JmlW*V :]9cE4;+5EKs=[J*E#Aq#S<{@<hehHC^c#xMg:L Y:hq?n=f; mUmI$AgB`;k;I2pEtnvL`p+{.c/Fka䙈XHAo1a{OP C+-,Ũ=R)u ]kCe_a0I.d!}:Xepqr͇y3IN)'YK@~uIO<fޡIπ ySQjlj2)0iOܹ0Ps0nO$z9<;X:IBKnbOns߳Q@c*\ 2$Uo.ӝ e/e$H7|+ƍW7"3l ]kT]1 DҶa @*k&72z:~*;V& `"q<$;; Tq6 ֳ(Mj v}/T} W(mt0&Gѝ狓I "Vd61p~V]g )ͷ6H\).^Թֽe/3D3Hyy6#9MǗP ظ~c'ǾݽirIxFh?ɶeF'L1xeQFx7)i LZZ}rQwW ~!ˣj>DZ[с\?("lru'I&T8_<]35i ׸y?z"$GryaO4q]kљMTH؇od`(\>hE%U8yOȤ ǩh2 GlXVO0M=tqJ$p$/R{Njirc2W7qT5>]#ʹGa/hE6{ph;塑4FYr9{VQUܔ4L\]Y0uo-_MO;e|* #MYNJ07 BvYqg[^J;RHSt%'h{&NG.Hj̎c)J,%B%lE~Y4D5)˺a[Pqr@`ڨ? GW5`%nU-l:H$_gEnBxu__SzY]@}va֩NHx$Ѹme!aBM:be_xz ,rBl0^&`BX@HBGRnRv( ٔ8ؒ/5z zSC~iV=#bs3*w&:TZ[Fܞ!. Ҥ\Zw4;hf9UQuf7:|}  M uO``(ۨ6(0tOh 5]qR ߈DX L2(+2 LsҮ7.E@K|Sv^.h${e^<6V:]UdmUmCD>U}a)nž3*d*◗Ȭ =t?d' t,}6GLw}'Wm^V՚nT۸Z@i~G ^LmLA~c@I@gg2۲O}Ľ\DΧD̍^dv_0:tHh3 -'Dڇ'd: '^z)ƈ/7`z| nC,w\Ps<-el j@]8Oԗt\ImM(VC;&cf;jG챐tCR{ Mn H. -`I,TIиdRPH&C,2LJߵJPv |u\DOGXy4E1/ۣw6<}@[p߲ > nB{1RbΥǥO "-[gS XEC7O:IqCWV0{ݿp(rcuhS5LU3;QAV%&0q"%?$300 >f2)q%$eI 4>(P9_1tii)<˼MI:25G귤2vj!G6ygQ[>ܾa'1Vz~M^ʻ^$eot>:n5ԙOp*U猎#{iZ:7}#}Vu<7(c{I]mM`D%?05;G&"d[}j9кG+Q 6:T6Z3.,s?fg'h?xˆ(`*QiŨoû )yVS9e\LuyO{c4$|>M<8(w%?u?,09-w}:vMQ$)s eW^W~u1mgYjoErH! 'd~<$BSq s?o>|J 4u qweҝ6؅]K rTvzُ3'fmB"c^z XđnМ =)h[W[{V?Bڹ}o  ҉#*ՅԽ*&/.vgQI苬v]tL2,㽟'ZҥgS>_ Kaw_ղ?F y~Sî3*9U+2`S#FYDl 1.=*XW%W`bĨjG)(3?[ jLC=/JSh;]4vVG\J߯?Бwaz[tp ݍ_EBMǻƬSaD7)&rǭm[CCYnc5}NjNM ʪbta 2ٻn@pq?t'q4lXb g5b_B 8؀KE, EN-QU 36483N:܇_ZGvwvxƭ}A"U>4% n\tl|O`ifbtK |6fP}OՑ7G.aƧs:rPP!;dڡXE,++_Ѵ~(>po쯀 rhA9ƵUf.9o`0њt>R93$C0wtZk@FVj@pXEVA=/$.RnLʒ%6'짉!%%ʓ[rd rz~dzk{.G12v_oXOL FiTàIPVOy%_B;g)6dƌzU`c~V !pձ>*'W(R *^Gژ.,: oJ3$\i NsoRXB^fiH30Sl#&::kZ>jӫɝ6W9kB}Hp;Z `_߷CعI.il,9Pgnr2$N眾yyJeϺ!psRߜ9*7lо67lvcԙC&FA܁ QNűU"I)7(flNl8597`@HB TDN5/Zd 򞯰j-7G'Tn§&(]BبpE X1*8r4uc쐗b$x4Jf{TYKBi-^Aw*p@'yYzU;zsq̜qԔo.Vƥ5ދF0kzݔh۪qF,arDjyjH4.jpIOʍ1is?¡NP 6L#Qv^^1Oף\Flo$MeU؊7]`<3cieXW!LNفANh0{pђ'⒈3R,-8"'pjߚhc&>L_&V)hqƑ–VNMt{ ^m&6]?78G<ö|F61ݧ.=4V 3'/ݖXDfH O_;P&ItEtؕrTiS,݆SZ;͘ϵjɨ(n bW4 (;퍞)ˊD[zܗi %wo ov'˃SQ[kWj2M G[LU1T].'`펚iSeZٍ%Nz /ay%}.FhBmUը:3]TFVߜU9ՁH; ڄ*CmRO iϪg2%Q6HzҪJqQ |\+%J6D1^t-|?#tAӛO:1w_d3 6LZx Kb2r; Jk*Zܾ;dH=SI `~Űӑ~}/-؝jy{qZdYQds;14Zpv]ζ'Ts`>W3C@m;ktG p\Tks&~HuUJB5ۚ5 | x$LJ5H;PS,p0AP:Us_p9bϺ[V aj;Nɒ"jb2)ķx5yӨG/0.,%ݐlfʎ* ehd[]ώ U$Gm9>PdCzGgD޶Vs5Te;ADKk 3:ltٍB|ɢv&aq|{bv`]uUHC hώD~v q/CKݚ+0N=7P(U_ua}Ynq/»uR,_Q|-G" {y"t1rCչ53VmOX<r? ;T~G=RmFYx#G 7B%ќiDWhW_MPM~ ΟXy5׮~:N E2O{Teƫizu۷nc12i* <yEQv?g4a{oW.^]}@rJAYeQ LL+4bAn2FBZE:RөhR_6ʮLҋ=Qyo4,TE{d@x`hSD' 8o;: :|l&eMobhz]JTL&!WSt"^ bY*[%{v/6nibc,_/pQoA(JmwJ%fҹ> d7p5LR+BHt] ( 䴗:EE&Ƹ6ÚHwYsu 'cdß z51k)*;l6ɛq(etaμj3["©9c*Ӄ`ޯG}>M#nMe9Z9j(2fVzp >kRM?J?&'Lm&dM9:'2{}_LES!$Zl&}Hn+~o,K-O)l^ŤP6t \LBFP(ϯhELR@&ٺ``' \5{~؋nHSKt]MӌW%z)+]yYꝛR]jҪt9(% uQ%Ir9"~Ȣ> SN~U,aptTd!Y13w-j``^4[*J85ӷg/ϻ"ExbKOkW8؋GeI~':9)Ye|̥VѨK[zpuhgTybOR.pT}*"xUvEh'Bke!)'r'裋`.%V~O!YC:b Ez5; rk]ܽ{kâͻE1qq_냬ÆY OPDq#l5RC^AO+ کj,HΜ>V]7{jkUk 9[68pyn;df#2}@GWLYA}Mi]bh'=j_pJ7 Cgo@Ȗ(9vV]Y_ڑ};.eExI-Fw*7]Y ‚DIχw#K,WpX5Ao1M_4+u2;jbm.mb.zåd/8@Ε-s1ko1/;Q#ף/W/QP|Ey*q{_5c@2R '⤬/Jxh܈1Gp r"/cz[f5YbG0|1NjB_8OBGX;-/o2S3aSFPf\&kcǘVļ!NӶws+g<< ;fn(똱IWBQ:lRH(Wޝjϙ;ʽ~e3( E(=FkybkѴiaev-"BY톯~ゴJ6IP.frooE2gb 5v[;KŰ%](v'B˿N|uuM&zORX@\5bNCAz/yW B IYVve_ߋ: |\kˠ=puM~/{jT DL[ΖF~4nQ{OZOP~j^ĕwtg!1i%VF 6N|jd~lD%]ʮc8Zp{Įl8hp̯@5fp(XX`+yyd{)0AtLPcH])S*k7#  X7Vn`LX,EЃ'PqƢ%V 7)i7\&L4RF+%zufAmtF`q@2s=P5wLwpw6t]5gOI;m3l2IZN2 wg ɹfe6TιkࣚcZx?e¶BX5-YbOoFY4Nz_2[Y`>4xDaRt%aBbT>׻95p|mS$kDTu ,T/]i_ajG^E!}6֕;|zDlٝn 9"b FiYۙe=mS+upۈKUWXAnsYEPF;,$DL @A4tmPť7@rgrq"l ʦol.v M%x]^6bOO 9! Ae06qn`"ҜkIr۪y$m0$)DVcooIhHi2[=/ ]# HZ)9-akY(q0?$okDngܤϹ%D1U!:-t͇EiV403ް>Z+EuE*umWvUz; 9 8Z@ 7.ͷ,5^9) hD: "S}LrN$F}zn.`$PqXEͮ#y'<áQZY~ކ' !+b3o%?ְp&1KGJZy'!rDx{I{Ep#}QO`)אCކ8ZnlQLvr,o$^v6$H hד%>F{$P_FzFd }n_x,mEmȀѝ\r;"@g&NuHв,u(238]ˑ!_wўoRUcqxUVsx]]iQ-̮OKcٞOZ&nƽ'5UsҮRfz!ՇG&udDpڂӭbxxٵ"߆k䯐ȹoTE9K$"ju{wq})'zl=Q7;ɩӕ_: JܳuUp=iK5ެttgc0F2_(V*G3 )DLa̦w[&Q,Hvv2My%UpOrm%vB"tv py28-$k.d,ZCNs cK}` 57nfTJECK W88qYƆGN95\#%yR A6 coHUБkjBcvwjY%t*Sb 3&YgvaOF$%4^ܼ?!śfD$ѺX{e;Ru\YN7GP-9X1R-# mds]!н hH3ŇP/-''xF#%tg(g%{ 1]n`,֥b`+[}>\4j'p ={ݬ06 ap[zn?riW\mfA]:ppqQ+8/XIT"MfوՄ\"!۳ 8K+LZBΥioR'>7~aTA^ gpqrb3TRe`P#FC9,ȴ}w`9M2Iw&&rA(rSD1F9rrC" xGGƒ??ȃzO֣ͨLpo8q1Y"$ 2 >E zU9HJ7$21wPhc^.MY3PEq3Uވe4luJSҙ꘯vn4;-%Z^~Ąpq@cmXnGu*"{n "g$wV̷DX`` ,c(R L4/s Se8GHF: %"A*i) ZŴ'`>ak?V|>ݻ{"wFW&KniRdG3F?E,xP …DF)Sy,0)ǰlgD3ͿZFfz v</1#3+:|!MWbIȨIJ;Rs+ܢ6 $ 7`i"+ҪZ{/1UT u4 Gߣ]eKW] ĭm=M,=QN ϔw&Y ]u`t,*;F|m \lcSIJ=TTOFnXs"mi Z7ٗ}mx^e^ DhGbGt8[8UT~[h?_[6%+p,v6uCDRI ,ied*c(RQU #_~6a6atA42|u+V#=H'`R-{,- L6%  gq)]0]9ɳ߭Dc$,-4UKuS}y14߼{ ݗf. nfڪbJw*â4F ${$$ZS\lZq_.Dbr@/< =AV;Px\ =Syx϶rG@]˕S Im[>1՜wܚ'?HrC0f9[]Rah:L5>g'%PFe72NNKh p_ST‘/ۀR.aOnY?Uz.1#55Lfsyil&TeWU >+~B}Ql. I~.+ hHWŢMnDI2rv ,䶀y[Vۜf: !l:Uݾ\/qa\; i)h*CL@ӄ *SPfr C'$a\{rv)IZ!([G94~?i@d0j}=#Ø4cW˵ j7JdFGuzYOasK5Bxã6%RT/ JAҢ՞5W/=Lڊued@*DӽUc Osb@k"I ,x4z @T>J\Ɲhv{u,ި4δ_ŏ((G3%()].ܒbM\*O30Î:w#_^=J$|kJ[7n>λ{w(|gb}AaM\U/c6'(ɦK٤Nޣ/uٔ,Pckf#r}߁0gWOXUJ6vb_ZR Pd I (n qSIQD*ZahiuR"Lm9)"P{AviR(7rWN=[xY'%;66}~k?MQ &)e/V݆|>4%O:Pphlͱg3f1\e %AKgf@u֝)6=مײ޴lҧjg2yrc"iWPT>wq۟bڼq|=C[^Ixŷ,EcR)pkrwy 'YX@LkvFU$[*ֈTyV&Y|!yyqET᷼@-*TXAw!QJp@] V[ v.MJ쭚;`5(l]#BHi vGꨱdD\baL]ERKOL1"yj^w*yS2 ])c=7N/@*\i1̀u*pq:u ^sYmZs8 (Qe\LX5F9Mݹg-MS3hk`JtK <% m!v-6{"r>bt/ZE,xBsJc"9#[4L:c8=Pzdb-'{/ TPCĤeG{v \fraયލ<@3u]UBG8g`{^pӁ1* ͋ndνqn[7 c3MP 0 g#7'_bk3`PIg* 5*va6 em|S}O2U$-;֖\#=$LA7"Ӕ](:L%+4Ld}Aqq=XMDʵKX>qזM![([y5qH^<˄ OC׻uG햘7 Y㊊HRVNB*@4qa)<L- Y޿+[D,9.>V)^c6ů]5RHr O}n MM-O7x@B}r)< 6P?#' E}oc@5UXKV _8ټ9)/fÌV 1H0|>f7Jb)iX觨؛N yRI-+Aa%.̖!ǶgőU[@"#GjlGYR5G~OF@uÿ~fljWam șO':_@0-Iop6*#4V02m紊1c}kb#7!` A<܊x )>SΏ˻heUWyb})ޠqV.Z ě'&S>9WH[X W&KmMn#OaYS., )J yv|K4쿟_ng#{ l|h;sߥʽ3^6\mp, hHځo۠7& N)X> $"/}# ][4nUi-y'=dKhOܤWt,fN ~^cײ$[.@^#X9RVle*2qD*9'1'ӟoȃd)WzroMN[sW$Q&(-Tc;D7&7[6[Et0C*~'/cSK8ItW ף-&]z[T7YB`xV`cIJw|hP$-h?]5@58Ϝ-"U))TǷSRN{m,ҀrOi( Hyı4M_C >y@( ,޳D^LDkΗ(i0s6Q)b9hRz%P9ɔ:a}46lg!Ƹso_ϪuQN´XXJz}l8N\DH\l( 謃vK(D7܁-_Τzcai:B%͏7w:MpiUs``~8SW?4FkQ=b $0B fO6#~TZ_` ۏ$/}89"5}ɗE%·3'+Hwrwu-yZ?6]wٱFt߂OZi0ʙ3SHeT[ݮ^nV>/ qztiBqhCBvDJcxr|5>/ifMZdpl>IH_0:ƺS|%+S8!= ifT*a{I:KS!썜cbf<;X|)/-GSm[80>s RIu9^jMwD@Ϲ_!_Eؠ >/.4桍7mS^Z_݂V"4e"Ӣ @t ,NKװmßbуq[&6-i?+La_cBUeǾA>O4KvzB,먶`_17p]^ӗy!"Mꑰdқ1T~z@-ޯLǓvr+ea3Sd aښ} >{3xj0xK[hS kBl14]ݴL*WA|G iDsΏx3y+\)BHaq(?xRjM.#Zg (ɧ8w.' ϐf+5C!DptA;1-@O6A4Y:N- =;pѩ`th\qSbcq9$?ݙA5] ̺Dly^u&;#v #՜b ZoNIܴYN4>݈.ִXV0Q(0i}YxR ߎ-&2sF6, b`@8+oy لHѬm`JO;RPM]Ñ?6q3j**p ,!Sd_kؖ;q뒬2c_M׋K=\h yW9wȸY pɁh4z,|0Uѯ8Nw-&U\7#Fw[Ա9F#Op%{s=[mr'I=o1cg4Xةg yߓW _A7#DfU'K$ e{?f:|4r8K g' kA%e1P]~&ona( 9_&Mܿ&<25j8H6Сtxj?d rKxۤHܔ u'I۹x+hܓu:I&S.?)#0,OurAe5o#I)ZKlDxDڹm˿ bςg]1(?pA1@v !g:"Q>{W`??L$&xLWs1D4mso-y `W>k! *uZ&wϒN∏&L[5otVLE$nI ck(S[ aIϦ.iMs[O!UL "эw@Pa6U;1tNoXP!spfZ3Pb7?".MLi/urg_ $4T5N;I-`=V@qFc2fh,c7.4b A] Seȋq9jˬug:tiP=HNIO*"F"מ+SvR@R <J&چ$1b>3 Nv0yp6=yh5޴3ӍtMJw$R],HBkD!>+ci8' HE3E~l{GT^CRCg;Z(G8fn2:hx}u[IM#ԧfeȥBr`'SDy*2^OT`03(Qc #hN UBPm[e0;{u;{=*![J)\tYjw{b1M,("PߗlL^1,hÕ97ɃAVz͌y5iǏ]BlR=A4ܾ]jo㽰gfQ1~4}fof5XIn-ƧEY)w1{(qSl3OIƳ5Qej3E)ylnZJ`䮳8fӌ*R懊?1Ijaŧ8?y|͹;o@5A n'B&g4z2X:q8Acyϊy/7iM~5YYkQk@N τm^+*1"xrA[Ǣ8rdQ=<^ʰ`Tr9nDa K5{#Sk-3>00"ҷ:DX\?z``-$"N8pU8 yEdA~Ջ82nvY[S(&zU Q^K+IAB™;K8o_rKwW1Jj1B tRΔz(P%Z7Mguk:lh=K.Ǯ>kYFsn6Bst;u 4RjkA#O'y-=Ɣi\"P8%ro0剘*☀#T[FwMZè&ᚏH/Cρ yArP7GeJ+gm y'<POYS eŠ #Ԛs:D fT(V4Bdfjzm^6C9tg`t@%qpf}ko2snჲbHήp ]+( ؇rPɺi PL.i:Si(,A.bpr ^l!l+d%HRmJ*a1SMǿU|zaC$gpХv ϝT+!gs5JI 87db@ү&+R",[(NH1_tsa@mr{13OC1uFL~>?$$hcxn Q Cܛ.͗X:"FfkVLWju)R9YƕEiܶ혍6(44I>$SQ+26&le3p`?[yJ_±Nx Ign"òHFpBv,u_wj@+kCycö2 S$LqrvFTDUYx yt5sW#$@ճlLBp \%(Bgِ3*x'uf"!ܹiS2 ,g 9 Ί&NJ[ 3(ɛY?NDѕք L\JvnŢT9lO?t002p&<#e`QG̒3y/Š-VcПPU_?ϡH?F1[B1P4@g,q6_fv @6M~sLd2F\||1o% lũ/3< _jmMíd%˓""{ȗg-ꞿ2Ϫ ~rjxsi9D5׎TѪDU͒8sng桔fR<%uoLaNĵ;[TN)xRA$khӞN(8&1V_:B7`쪰.w\Iv!\ fH GZZ5b oiZ !xo獃gA%,h3,ebo&K3C g]a- ^vm !PKDžJ19Kq҃ߨ#/k*^{tYWܯRw^?@~K))#Zsnro2~cStx`Ӧ>{1#3(H]w@ [7fݪW:yO 0 }7ehVk,BiD~e6dr̂OaxuiNVcR7" _"(Cz*QkbSQM^X<-5TQg :#!)O[́Rd_5b38W7;'T6!?9om'̒p׭}I.Iܯ"CCI)܎u/of+`*W愮G[=\c2`Wbwq5UOZqTz%Q?Dk"S )Bؒ7i]=sGDӥ!-"Dv1+r%B5j~JF9GIՕtc޴njI["`A5Gc{H>o9yOniP]ݞ+_ߒ'ʥ;!a \Lת-|ŷ7"T QVG՗ZHbRn{EuvIT`h3~KU+!h\xx{h!!7&ovUc2q6M:ѵV V +#$;5hלG$H<9[FjܖѪ lv$= :s^~&TYt7@%N^lQӥFֲ@֗`LPҒ;CU {^= Ĕה`OL½"i &q"24~M9ssܿQ1gׁ.#|H'bU謌f)[=nA^&@ FDw鋹>TPo };>@w1? 9Y`,fV3j`qc"b3wsڻBa"5a`e$ִ5$B{؁P̴hzMjt\5/U+yLX(BM%2==&Uޑ H8G}Iuo;}ɋq\Ѥkz!S HPh="p` V PM!2@1k9h'S]s)*@@-*z8!<_Or to]̹wcz\%Cҁzi^&ga[kpO!mSߋA֬Gk",Bpa1^9. ldo nkjktW 5<-6ӳ.:GK,cdžf_H9oO{JQL># ]37 sǎ5q; za2I2?J_.\1fGY4gUW3\>[y"7%( _+JnYkG_<ԄF}7;ҩ{FX49nc~4~r4a*$BF餆ybcvp GzwP08ڜ.hSƑU%х1\]5vP D'Z2b7fֹ.77fƤ6u+RnL0wꖹ"(_f KoO MI9s65 QG&*t7KAc_!m>{[N&86fQny?sYS%k(kc(_sD4x~K&\1 C2ɟ|yDlRSkj7 rz^] A±8ުh[K/9^f#.TV&}8Hy뤮ĵ=YKքE@#8լS3)s\W[ĤEdՂ\l\lNg OrOQ+Ɂ 1sb!#S@|Fc̞}B)͌Y% ql{=|&Qq)5soWGka8aJ}j{P7X[g R̙bdE?9}U>f'OXR1X{XWE#C~0-8oFf@'uVVRU+<Ę] BI|IkDt!-$c zlA{t~kjJ~_ҽC{:rFZgtK: KC¯L27m[hۍLz%$xo#s(4Mr0i,fCfqlNQXנ3;)kuǗ#ָl tcwlm<;VϊQni~iaehsftNTF:x^)(|3PEjQQ-?1174:CYIY2ͲZ`xL'/*trG &ηEi*rhVu2XD!'o"E$\nO M!u|p܊WiI;='qZ.G*r`Z3@BW6F`ͤl~0&weSr a= ůL}\NN)$9tN !o4LÚGCAPM]*Nl)~Ir2͚-W8rU ^12s{1c\A̵8ܷLb>RxiJ3f&;53z:J3maJ[dhU=1ɥ+bݤ߰;Qf% FIC'4E:?k t_+jz|E`+s'RXKКd^-xul6FB IϣQgqPB1y:9Ĵ{z›K>;6#-*/>#+ݸ*ƨIqnI.ySDsD$_+Ot%̝dqI'9LGXTO"7nH׃JX438HkϞBh $uRGgxB_uy,oQFS7;Ye vxmB6:m _;"VHС#ݘGQUQxg4[9'{ jJ8#+o~J8oJzUe˄zA| QMuo5td%v`q}hnm l'FLJ/s6X%́$߮8ȭ"LaBeuYm'n,?=*ocK iQⒽ9[0O5%skvN pIo ڼ4 7%S_ExstW_H`eIn Φ9zz߉e-siO˨h\*'5aOw,rz6 W'wʾAn^=k؊˻/=R7q%ջE3"FN'4op!U<3DآSl>Cਜ8cqqHZms/ _ۈfC|# 3-;H2,"3: ~Suw.M\l)]Ph >tRs Α+"f{&Ӳ0+D0/Mx 0>>rC62_ZVS@V1yG;&ÈHVާF'`bU vEp)?hH8|1~ ?hL_2̏L}+1535=$1gf!`?T.wpFut2,B+)BDAoQ?-CrEOLBOI0~,;5W Yo A_3 1!s_k9kҹOH-bI 2s5rH \(D2i*AVimœt LwpҵAI]4_ }Z$\ޏLj =:q iԫ *٬ ;# א@wzkB{xc[H.2l@\9cH^Oh[CN6"yμmmCa}B0\۰&IႿ̋;ҕ^L׶w c^VIv^jXoTվBI1]u,a0k=. Un7'M4#{< {ICXkKgn$kT࿫q-uc8їT$ZgEq$gҼ"LI.?wY%Q! 8YFքt:Eެ ۟R H \<9 ލ7>G|\1m]ܜs* ,zH=DFnͧj$w`*n 陿ѣ>HH|}U9[5!CSxn}xRe|S%"1W0!CG`֒ R( PMCaRU>]L xs[9f]BӹBQՙch)pDc\3+{s>&Th:Jz wDV 6dKKoׇ=lU,x*%|)$t,g.ld"XmPq@NN/)d>7RD1q30TڹQO)ɨpGso[$F wdSAf\xITJn?L o)>0 r_DRûlT.}Efv dS߆q8 q#»p0Q4wD?IoBdNaRn棹 rͅ`]iuNcn9q2pST=Raկ*D@tcFt81wgx vʰ;>&з**A.`N;d1GgE~\D;oSTJSPa@z\hiv6\a9t>ZPʞ |%f'Trn<(u!gkZ1vd4+,zsB{Zn=鶵a ֚O)ښOp)llB폜0_ ᫬wDtǸL/s9?wm/a=pg- &+S +ncC*!{ݩY{MqlPf}6g-eFŰ:7,DΠ¸_g6o;zls)<^-^3%aU{46TCfv+'~`)ߡl_RM?)+)ua8r&w%MzRlT '25K E$M%}3Is&eG>I/wAx#MgbdQXuab#rW^nZtC$kt[Y^,\#cX'?45r/A渝L(TdVW#q,X(q{CdU(}בKBVlDˮBc ^S9:c B*un-e4}ŽVG{_0,9~Mo(ʷ c8M?%iۼ=c`G-a]9^E꽪FBT67C>ˮMU*˴m뀶68= n"5Y!ҳ*na]8~qzK㎹Y -QI vb^3+ YZ=L i ƪqOjh:_>('K#86e+a's<}!8?z# {m=]YJjPtUw?%.(9'{<]6v'[W 6NfbZ.4ok\lz+,pa/)$g /ߪ,FN*UC#ˊ蠫e=I. .}ieL`flavEH]0hW> s.ؾδ*F ?:zhc ͖G>iZ?FǏ2&~m-낵y<"fZg{r|.J=} -MMq,8j@r*'? |%Z\v3FGnrՁƽA J. ]dlBV#e9_nfǭT$WY](q."΃wxǬRƒŰܝt猠I }մ9Bd&-SͭƮlPJ΋R )\'\ A৺z7U_ynBg(dQ=K4ߊC0+"LRr˷X4w׬eEv&\ WۻҾ΂}W/5 CTJY ֏ ?gmHrB/R~~j](w;qr,0Ut&L ҭnF%ɊT:~ǖEl^ll.6B}H=&(F? 0z#Ce%zu0v0\J3$1D~.ձ1}[V}D\=,.>9ML@i58j;k̬HBx +1v &Q1^i.;j[{Qw^}Ɓ 1ZAҜuw]¯F/KI&'<[^].u`?,lٞ[ۯ^=O/"v~`]]0olýT$),y_g?Xx:}G\Ac.w[/}d/J2,OR)Njxn\݁ ]H+[ !q[^'`)6- R8bJ|IxdS٭TouAJQHj}'Ӕr,8k y<2ϒ}DჩpK䢑9S#n[f"d ̅5aZ~sxE谒6O(\ho0؂C16Xg'n&3(Kc.%\Qt,mNp|O.P7g _q|I{.6#A>ݵ-ITJUzZu(}lDlKL7Dm&"aqso)K#( 1/I%K^U(KACW"rD08+ctd!]Cxd LAU^u⮽f-.HԝQJ0@g;zI0Iֺyq ʞneOnkݪR`*E"a_V^R^4@M1 Gqn)uy1IW'(Q$o4iMYe:N L=`r}u < rCh_^=ޗlndCSZWYcq ,]maKm W%3DCmILeFCDT5*>^?A`6G.@,r=NX򖍚wn'YFmtٮ)˽h9VOqCRxv)]n WRPqQ$7Za\AMo4'8_ *- V :Ev"jJ=Dx>lG7݉aZGm T$xGOGZp:a0c.ah M`5V5WbO7 `׌;B Pߐu1{S>yf Uj1Tx y$X>;|n{X 'S$,Ajg1i|:~ʃMG‡eV)T hә=y՟3Vu$K0.`ȥCސ_b:-㒰ov3hߘ˾0INV PCCx[ߙ3sAy6Cm ~ze(Ex/v\();:Pc8ʂ;F+!hbF|5sz}iy5QQpa5 >iAh*w!-+r_OXg Ep6O 3Gz= U .)l6*7$⛙CC<@XPˁ$s3o..`k`_Cݸ(1Ybfx/f.m2{42Y5?BUZpPȑ~9k<ԸDor8d#+b˿)RQ6x/+U4* }:"*t5XK[GImhZy2F~%(wpϢ?]K'v%;28$lik戨y{fLI#*ČP/vvb|Q3%^,nlLO TEe>Tj6[ 6̒PDBIB)Zk'WptgΙꦎoo|i 'ͦ{.΅Svʊ.zOYHNx2V^$|$~"paTNGL*޶_@`<'Rs֥dl=qKeuh-E͂yVV .LV2s78$ ë qF|ٳ~n8|KUcucn:7W%"-ϫ׏=T54i+dQヒԗC`zSi~ @CGTX_lj4[/~1sZdJ^#q3p8q]cR0 ȁV"ҪBGutԅ 2)X_8hc$0og$k:o^ .\Csp 9ē>ٗ-ٍk}GP~0=L.:/YeZP HǴM"R81uRY7tSQ1j}o(mlmUU?tgmLS>4-%7"ժ|~q@kj˃>鐠KͶbNVxGUT|Áb0LJ{ʞDe/G6M?b60#T%O"[Yd(b2$dIgnʢȋa/3bɉǽCّ& M1[#5n'ZToㇳ M>tXtVvn`Xdt1(m GccX+Qq'D$>sȝQ,/q🉧Vcz1Sql{?'^W-+t"Z(ixa_);"K$ v kb@"GL_.^~6fqdCXҐЦi`c-ܡ; Bis1qy1Pk QvnEUpӋ'}Y J˃|:wzK{\SQLG#9ΏuНEO2CuS-v]،iz k1# vEp/HbULATڤl}$+p꣓ٰ&N:^wb0ެȺ +t Aຮ*]LiM'{Dzd5_$eWǦXqC 6wߎ!h:n&(CfԩGxuVyT>7b2ZY~(u ,3N4~J<˅B2 Z=_:˳*.S7e Kb'" D77_ "PW`LO V|8 '`#K=ئբĸ;{vەs_שŖ/( ql0L8* 4+[x1yX<5}ѷ+٪FD|f ς-1h^ԛћ -Pp:4jVPn^-/h΄-B2GwL':č8&}HgREЁžDx[*OZ^l$Bߚ$B=<4'oW(j Duň7ؓl>$_EqÈQg#[6 gv&~w&QKj`e7UNqҗbg:3Z:r>Fb䊸y Y+t>H"cQrIUX@a|ͺEq]TIqE#`axmK'Ez.:$AqVVE!I`͞;!}oj`/[Ii l3/{~B\7Y SI>XHáhSyYOR`R qolIK5[ubFM^Ua۽f(گrCiԾP,d/&^5fm< MWG kU~˱mU^3sN]EQ|qU}dQT`ȞzȲaKH]Øh@_oRItbD20YѽO~% иaX#4?Q * |;:DN^gT3c#V]"Ԥ,; R6mB/r6&O0ig= !Qa8c(A<T>:;Ep,,Burr|.㎉}A7ӤMĕ?.yrj6o{‹'K?̅tIUnFrDXr֚ wf4.jM0T~Y"qW Ue}4c:wJnl ؊6Mav5<*IG茺Q`gߪIՆ] o9BM;vJL[{0\X`.YM[_ł'c9[|m%{GyRq?ZLcDg -H0фv)D4UgQ*;1^'Ծ"'F9YQbd2oPZ@\v=(e]{lAm⚍ ,TY4˓ꁧH :Г"(VkQ]ڤ-23dc y,1SE^Xdz#COSnPe ^6~ L#i ࿣,0vƝvoi. }PΧ'~#Ҿ⒢Pl<,L;P:]eHv23=D|.A2/vbLcCZ&2F^?2bF r8OOAa}12ސ;@.q6iKK;=\PV^vs* [R^jP7ѣhYSa$^dȸW?0QiWi!FqHDH.]kGč Fo=qHc*{Ng0Qna5Xz<*V_Oawl<hjt uSL˻>X#1Bj?6ܮ5_&߈ms ʏĄ朳pL\K XHT_g $сJY2poJ_,'[ -1O".Xo'!Th6^mƇ ٱ U*>r/ 73H"q j cH\wVae4-KA;{F*6'YfX+wJq|iR,2,qj;wA$`XI^ ު?XUN*3P7I|\?O?. 4$KR\9#<iHdOo~ 2􏇺1v5iL۽yy_yG>qKiD-.8`R+ t#+Os 0XKgiO>ZzR0qR*˳98:[`]oS:LC%GФqSR]Q>]a|3,|I·H2?^P8-p P;.,=Vcvhw %HQdwy@LG}6~<{e) .X ]X잲V]odS\E(/8;e[HKuk8 8xWRQ{tWR<oE;Ccz+I]bNځOv}҃[`/bPׁS~h~O1TmM-h,8Ad4 x[p-A$Y/=Qfbþрg@=-kMFi_^*U8=0胟S%'՗Ql]d܀ԁ3k )vv P黗K;q]sT#g/<TmGHBFΧs<QE;]S/57f8x8ˊs~r7ƱXoA7'`Ȅ\BM .LocoNLކƧ`zC)bVIN.Mxkp#.8u~k25Qop= 糋fý5' ^S+F;VAvK$X!\|92d"U⛷NagVx%r'gyPE iM6c,y'BSi|0V+:}}Үw᦮z( PoĒ񇜳2[U 'p恧F*(+֎'-ܲ5>&!iƲ/ @ӰS{ZN9| ^[HN+1ӧ6#q؝B汘*ۇa弱[mn&_iw<6pxR,1C|PB:L^{p N Z WM&D Gσ -X})FNM qs0!{I-yvQ'klŽ ㋭mr!{ PQ_΃!YoVS$]h21rgqMyqk.#(Jh3sV|@5 v si#<-}Eoam\a}J( ogT5wJ=j.S覄a<aiC)K%BGfa9o) aW&r-\ p:(uA*?٨.(C@&sݩ*Mgˍ=kQB@"#򐮏2 X\C&8Ԯ*YZLC59BQͬ3 qtúfYTJɊE? &zbs)q17W`{j{i""Upy %E rYsSdqFZ2#g+ѥw}g!FfOF6ՍxRihg^0MmCYe$(PzhWQF_L\JHg!*Rp#ܽӹ_P0|T%I=Ggll w  tOvf9CTSkA瘎ɢKrǟ/ԮT1L˜"S9lJ܈]_g#*G-G׎ϒ-Ɂ`J#ɷb<k$a |rPݠ\&P/^U\S(/R!ż2?5 U huq+uGoQٛzj"&h1H̉JMuWjI']G*HKaJAQ{YBY fTg}&gTߒTEY ~2u9$o ۫=>3`26F[?龓6%)xw)l]٪I<-AhV89uM2QՒVG|eqwI6$]O}2]YI\}'‰ -SMYpu^&trZ ~bG,NˬJn"gs扪)si `H?QUxN2|hKo>Wf ]i2[{6m|"p+4`ڿAsǗȓQP&Aַ. U%ϴ>=^;j#g1g+Ny%F5=ep dK}g P?cj,`\&㼬9haIO.nqT"Rud'\p?#ӇǔNR8g$A0!&K񆰶feN3TPįc]?F/:g<[l@y5IDnj4&l ˌ4v1xTmV8l1II 8GbPN+Tgal@LC_2_V_p#y] ضYwҭ.U|{iTE|PڅV0tqpɀNZ;8D4"ԧˤNPrXy TC d9 `!u3\EVhexf$2mcߙM-sWJm*az\OJm(]?##<}=2~f̄ gWp[?+Wdֻk,NOTTỢb >zըU =^^V>$ysʟm$ur\OS*xE??B#k;LxbSkZ(s8Α=UӵA1fW.2TTetqI9ޥFUTVsYLAM*u4VgaF-i&-FX ެQx:Vc;r`w]菆(} .a+GqD;3S; 3x;}6AA޾y,,+=hIlOhi=4PeYM=$cy~A#vmPB3ӦXc.bԤ)y\0 DQ1[3\.+b?^:2,2^/3/=a Տ^ )wP$m(3<_`u W7\oz [VŊczR˱w,uv&Sᄅ*  a ]c2ЈB\cWͧ c*pyU)OfhAh0Fu}@Zέ sj-2ӪNtzv* 1 T ^RO]}6֖IP)PCV(lj\HZhA+kP!Kt˖0fۭu;+CԋtC@`Ϝה=0^;,5N6˦v5xߴ#Ky578#ۤ)G^H/%Jj18r\J%zA1@]qxoehLn;^s1*Vf.#GVy1 V22E(=/Va O1L#.✀$\9ޙnm1dQ,Lph}x6IM#`~w:Xw)|I5ƛo4A*}4ٞ<4n2Hɿ ՗?<Z|ir%(57‡v h`it}T`4d(w]A> 0a>؇̛%Kt^\NxݗBxpVpOxQcJP[\OMVaJP*M i$}AM|=}aW@5dlݛUjMpNcTbxSD Er&*ʞA#[u={g5oÝyrVLGf^Bwƴ,]0,lzU7%9CFAƌk B(y{S;c0sGYcOe 6Ǜ>Uӟ?"c˻Wrz e_8ۘܐ[<%FwKxԈʰSE|PWfYAOZw:V,!!4uKɮm|`[֦ L;K$fZx۶QOVFLX E$կ;X"Om_qKr94m=&J/N3WW|,],*ڱUpOQt2x\o-1]Xz,.53]At GH&r/fPãy8g@Lmzq%R9-!H+o]1O-˦3#%P ^en~ӛd%8'x'xtl#L!R:H̯7LHd5we4YQ !IPеF:Ǿ~jTFB3Ԯ{lz$θ,OD)FۢK|bm&9n >cђޞ# J70XEՅM`t1$*1*3"܊w{Dqu]Ẉi"㛤iJZ=#j׵bbu(T ߃) "w]8X%}Pp'brHI5$[N)#t%j-P7lvl@T',jDڹR\vxaL 8y6g12RCd4s(,-\439B|{O.tޏ{;{Oma! {B^%e&AM RUIw`@@`(I4+^Y\ >Lb96#MZ6 FVGw_Q,FE$/9#,)1ܸ8@!TDRE (e]&5 =NwKtcx 䥧o6lswc2nhNPw kdzXEڥ@Gͥ+/d@B# soiL!F 6b7,Gm˳ hmSG.4*x9qUe}=u$Qw]NX"SO%G_zuy ǛX8mNI g $AQ$^XːurwT/r3>ݫ/2#^r${ huؽ[hhW>QOQ ?L6,hu *\ N)0j54݂b*axim#TCNDQ |GHF14tb3伺"^0QTukU 7xX0bb=@YG}@ )^- ^o7j E)Ph7n0\ix(x_A45}j)G= % 86~y[bT2aذ : }Yiz N_6aҲ-ѝ:XR~g <ڷ(StlpKuO۹ۭڦ6_~̕x vrY0GTƛvdHFfX|;nܨ-?~1NsX$9_^m,鸺_D͌ IQ7DwY: v@Rc!ӢI9vf[IV_.54!g/~DѭOʾbhWOpSrɜ"Fqd$dB|S ruDZJ`%f3ۇ׆L]Ǵ+.lcg :V# 긱Œ:8Dxi. }wCߢ R,8#<5l|ҞE2$`[eƽmPn\Ԥfzm#/ 4'~%Bfr +0^PLQ|1EX@TGSn)16\O~1( !OV+ATi_Z0vZ kz6[pTjB5<}yX7!Eʕ~fcYnw*߿[kgFJjq^9aءVχs81kouL{_aM?QoXk'I/ӷ]LN֘_htk $6p)a.: ,ڭG9,B5PЊT8yUK\+HD7P|T2s/E=Р٫BWl Re::a,yw-(DػoRe[IDD"RuoyO_Qخ F`X+9w/Ғ@ f|0pfJ}zw=To9X)Cvܪ2[nv/dEBB C?q,^P.)B2KPHYe˾F1*xnQZ?$T~\DR SI-c2|Ɩ| "΁isҗ?p > 5 jPZ;|N20GcD~lニ it4=qyQp$;'.uo-ګ*uO1^P>}4$XX3 A ao7fR3EuԴُ\+x,/]z$%%*LXAa"P XLfPg0-SQ6$p4$[S^"`0=4@-XjQө}"WM6*bRZ4+3T:WKǻoT2Ԯ=z"y)^e^3sP.(@(煔z^aE}9b ##ɧz+@AMQ$nt0<ݦw7>VD` KI;vة+k1E 3ݏxb~T &<,Nǿ&f. z1T/Z/6v= [ӜsgA?zҙSQ鷭Zu\ 2PD*-m}`i =P*d\IkK{p< p7%ĚDyN`U%_F͵@]q\Bi|(5:ׯ@JRkV?wRϡ"|b|լKI-xZEk<|u+=j>^;@c6.iʑ'U jςӨO|K I V@ke5͏ygHBFK}\{3V]^ʿ(#JWC{}5QS.+ {-Vt^>CХ G矗fpoy~Sj^(P@?Z U^ejNK k9:}OCۑ;B]?_kp_6>Cդ2(&Jop68Չ@T-jp $\ q! :TUp3wo_iL'Eڤ̜}#݃ia$$&yċ9u|׷Mq.WLy;$,E4}pDpcmB&,U{Sqhb`y-?SV{4|ҌAQdTiN`,c cف޾HSy f, gU.5Q$98".AM j6ZXdRɫ?eZm}+ SKR~-}zKZέ5jBuG*cY!d;);{`@.VJߩ_Oolo:&Sԥ&NC\@](^.DxQ V^sNVC>`2rz>?eSa<. Bn_ܕcd57F՝%A_/ɫ`[ng #wY};Ps^;=omhrB$z ?g#Qd BT,kg Wiru DET  ,vu"I}92_v̐"/tBQs8Ejj~r\Nkf yﳖ`%0BJKlev#-<70gr#Ń$G teIؑXj߱Y|l_qg6L4bf.$I!|D~;':"(v5yo=<4} 6 2hS3]-J0!C)=$$s* QKP5Y+>*`dQЪ̊;8MV@bAaT.H t`uF,i/R0.!V ](@S_`Sww~}PfjO}e+UMSj(2 1@{Ê̳xmZpQ>P((rRf59vY'&Yoe{cogŐ)'g5Zaaa'- (2 URujQig滔޺%t}zRp'fM9dU+?vPG &P- ""ij(1idX%걥RpZcUe^?xfz^3].i 9x_?MCY)ڨQN<#g̽&|h`[W | FkSun?{wrp^OCƙ2uqj8G+o;c+t=\|@Αp})|4W 63gtso%nҒ h`5#)!1\RdX+(lLs.-T c](X![jN&SR ټ)։<ybH@\B LUPn'jzdqHK?U6~ ,/K<) KW]~:aͷO0ۘ }ՆS Dʟ=>՞lVthL{XTž(L/ߨ $z?t*Gȃj EKY0\%aG%hR$d!oD+[FkCBdz˞R ʸ@Ӧ҄AcAw9/X{_>oXǓƟX$g C1  dBH=P}zWƬww>:@3K!) :{8Wo۽nkc/ !$R,Ad$I @ leZmhճp,|OI$?7h7PJy-2IݲI~0yoC35;ki-%.r Bv[U:rğǃh5 x{$NA@ dI(`cjUؽ{kw;mq醊B0 cHʁoFxeDɡzk__o~l *ǡRNK"Mq.?;ǜrPZN7gUӼ]~Lб'ˤCwwy;θwx/$"-"QDDZCǒu{yyh#n NZP$+;ywxu]xwr֯< XJ(ᣉ'?0 f5i$3j"8e 5dj+S%1TF )03Ov C(@v,%BPc wt<|N=:zo@@'t$FDI $h}K̑~O1#'醰jh0F0)k~5Cı[M'^aQF>KX]榣u@3()M3@|-x;8V}gl$Y;H Dm6li o_*֤$T!N$+eoUt'9_.օx ז~|J$>PA R |<څpB"BB B@r9R9&> -! @c!P%;lC^ďj# kq.ǕѶ21=Ha:ƶ>r|ϿӳH7m}b9QjY^e'Px:pk@ȰYBI"sTZFضksU_ч`(NKl~}D0*6jXLY/x%j;C:7>^7|gy[] D 'RP S)JS?={,x\:ݝEF;#݇v8I8PI $T ;O侶!GCnC3[̘*4qVo]ck~ĚKQaE* W{~X 7]Ϳ؟?'7FlF(kߎM;q'O@ϩa|X.F $B((@TQV/i qdbOjI)a9^Ƨ%/H ^gb&c3 |q8MﳺFlBD@(jbC -hL<~Vz?#nMb )@i˵ׅ!n~&*fT `5=$O.ƮZ-Yέ^N?u6]mH7IvInj+KЩ o|k:k~>٤n{k#a9Gy$ ` cbA;fV[5Dő"KUF9c8˳WO]-]}Xqc0iAcYTEK^]Vf[R FL%FQ7v8YMB 4UkSER~:^#$mP (D40O`PD{O >V\xBB|j,! E$S״zb?꾺s}|6#5` &]Z\4OO﫶k2r׍sy2  @؅AX@C)B|~LvGG1s/bVٖNA9;ݞ3NVU7gcA׌3;5ٻ^t"WoTEt]A/?!=e1G3۪̉!x[_o2E7F/ j+Ig^G QsXf#MBȝ|?Cq6$ʡc`i#!bZ;*/~SӪj|&9K!y=a@! ! yjޱӚF52dPXbB)Vɛam0!NkW;(1b4Cmm/k,?Qy "#_e,Y[ _uG~TAtƤ0Ԓ*'Vѭ$Fmo|6jh IGqm|n{y>d@2@P{JI'=ScxݯC[N H) Q,ȒCjٷ}W?MϧUj5ԆjTHw͍@ @$R aNfN=";mqIw,XzBO=@b x80&)DFZc wP]I`=}%\r0(L968y7nr^Qy!SD "R !d60ϗYdz*$}9ty-/|ȏC@ АH˓H@A?M mu{:02Ѻ# h$&Ldz3G+<$!*{?&b8/-C9^<x^7eCdqvwBDF ,RaC (8[5qYhNs&ݳma☁@cb omQk!ڃ`#1c*V p:5wXFe1o#0 ubַWJ:ښn:ry M(,IaF݂n`W#ZL~62ꍹq?ۉ[m!k#)R|㟧K=jt:[۞Oyغ w]5S6i4T́[޹51P$J0Vo܁bn"6/ԼyUM Uld}y]mt#;" U>+3v,]ǢtJT\TbHd;S`w;T9*Ez\U7 7(VuX1D 4j'@ +;_!ּ6U2P#BU+v^D*@L·XKSlD՞ !_.:€bL#!8kFb0s#5%k֐{= g AU840oi`"{"4+ ap#!EEv#Y.-<@y-sWrn/Eө, ोD KCT8c#OŌ!CĢc֠}'o&Btéb]g=xawc?JlNR. Psoem۰L6j@L@h 6HLwI\M@TE[ohfa=Z=9\"LJ3__hfr1*󎘤촨B#, 'OP]7iF  4/d26vjAl>_fڢ4k?éZ6~NM`a:,8 @sE#5 2k\|P8yNv\gW:p:P^jG(HUL劜{]x;,T\'cكͰ0"X9ùb"\,Y1l(2Mo#[oe؊LqHB$JSTLGd.,hloI2z_=F1qB~gƌ4'I&ydMieWtX3$aR@YY `ie\,~X?7+!_WTrrŊUFTQ9;F6' {nпr%4"]B|1CkqO|!?BTH Z B)Mk{:¢2ThnP5 gc^eouU ԍt& c [\-bSaMY6q .&rZr8c Fx"ZE&Ǧ1_-.zq,뇻߹:]!٘d ԨE/h3=Kq?r3,6oκSziz``;@ieՕocbSCjKkbx,Q U%E_qc_^"2ԣITm+4loYYA:=L~smOmJ5B@!Qv`A6oO7Pq M=3Xgd! 4¤({mm J.@q|Mʼ=d`yI4͆!n[5qv=B~@-VAw8sy,ߛoOGKj0L/?̘m$BX)I H:..gw]9r$*0aM%rD2 cM.G#y{9]h5p@֋o_g`>忴ьi`b`Amstabn}|[+G J0>;ĀxY3}E͒oC6 IB>g綶\TQ5m`ad8U]өzUa ~=dyI,}(E$OL)a <߭GKGGfŘ\b۸Xn1q9b+hvmgpvir{=m8]vfTwh('wtF7+vELgM^%#쿃;/+f̰dL~-Ū`bז~ Ysϳw%1\Д1D@D5"! H~߾7k/( xQSP2Av?~o.xM+!ĠŬj aD apnp`2i˧%77rgXm"޽(A7j@رD7tme7O=iyM0&ѯu >r}{>}u˒J!;$oC\Gߑm@>!U ,1Ъ5#B7 k& >(g v?h0ۢ,iAdAu/yvywޟ7M6$"H G~R r%U6o,Pen[ܾ +o~pU&/kreT` x?@ hE" &I? rTZsW00" JzV=G#{=IG*uVqP_4 ۟GoFul <&$q1!S)Ѕ<Ǒzb1@(k=HYom!UgUz\6 . "1 {+Ǫ(=|s~ROzZs?*`as" g.ǃCZZ5t1˺qJ!ZarXQtSR-MzH#'$U„ ~_pXY oa3q9c?FEdǚw&vK|Y!P@F#``3U$xpt['f@?5|.?6 mM11i]sΖ%0"ӋOI 4j'qDgV{0Tֈa+t,Wst @0~W-::zX]Bj 9@`c>ް?j \X"8F2"%_?~GԈX=A rN݄93vְ23$kZz?U<#˚f̈́ZR; Г0ӄl6.~GU'_Kb!U5t>eMm|mU#}oQՋGigG΁֜KT7p f=c$ yCOn|D'éė~EղoA2;c:AAsz<+,RfY>Wkh?gc{j*_XEѫѽ`0|1v"a4)dN-YewtIDkϥpz?Җ :745A͓$prG/09lUk)ŏkUwJwuqeDxT//1m"̓;i-[]+@7eب~fvZ?Fl^;)AinB. GCMeFBh\ꔕrѢ"Wɘ [ GNJZ"V!Rhv& A2 Bpt-qI*1MD[9YTJ+ЉC?Dnɥ 6_ݡ[XVe0}XBM* '7lĕH'UW#牋۫g>(ײ>rmlz͹4gBbkX NKA GH pXDʚkP&ue2Җ}zIH|7RȶH{ 祧oBitPP kӔۋھ6>rMƶLQ?.~^n A<8*!{d416p$8, "hb&E^}lvWu>EeN-u(Dt$ ǥr }5/OԯWC@ʤEd*RSRSфe?i)fPWLä!ݖh`ԤL6mY_kgmLγcP-1V1jZ`߉wޜm{+_ۛ8v:~ h6/<^~??K:3R0QE@ 5DЊ=JHz@fcPtu SǩƲ@IHeV{3T1 {5;>-gK}_}u= b{i=#eQa,^O>Mneo:&Z̍Z ]Ag|!JMZF8ҵ-kӹٻZ 5ݠ+YLxzɿf|' }3E}=l]kxp 7d)2M;#(GQRll*,Ԅb{\#T(A_88D\罘|=Pn ((+i6V*_K.Ny0.,L0psI/Q{LFFB#<;yJ+qx:6 !^X <0X#:hAxLM8q}GFm8K m/|@"";` `şs:Os{KiiР%Cf `cQCH@6-{Gygڟ?f{l;̜Qx}/ vv3gY_1'=$bHH^4|lSrrkkq?}c0011U9`젎(`2Et$FJǗv6=_\wp??^3fX=8[V3 DN&vgllд_6uUwt@f/0) zB)j"&Br :5˛W7P0p뮰vp܊QvN?6\%7_DTu&aa ƻPH@2a ;s=^S'%HL qd@Rh\`֭GVƮ=;kZbSJb0ヘ ENխZ2Ӫ_`@҇wF<{#Ǜ-Cc 4{vNan 3sK㘷}X% `)"$*ngu|='cgCv獭RȲ<$V'[a)KRTdG1F098A8%KSɀ 5-]+IEH*&c 0ڔ۾ 6y# xe_br , U0;8 t5vd>ؿ"ۻ,{^͛Cf^Ҏ9'"1h0`ZJo$`H0 pcDYz)M|o=/q?R{zm}ɐa A}pZ F1#blp\o Jev odEd${ 'ÐF6o;ahf+=z`Db-b|@)`lcP/d|TN^`&i,YY?%;;}dID{GvP>w _Dū(bR1'Ȍ`3=],Lᨼb0n{:hEIt)'&o cx_{;\MNno_6fύRC=ӖxgK;w^HyPOHT}o7rC!D X'm;&mvGOy8~ \ €1XXGNBd C CK AcjkT!d,Xye#L n$wIDbPvYL7e% 7QLTiPw* Oس4w~obgw_) JCEi%sQ!  DH# l%~}7 {6mݮF'|pw<;?U \MNA@H$ ;-\ƃ9ߥ[= 6y>{/D"zsY&H^slQL ~~'}֍B\!EopSF}~ila1Q{Ԇمj 8qh[Rh*<*z>4pTJ%tLUʭEXiT{8"%uLd b),?UfNYH3#6W$vz -S._C@[Hz1~x9;׮kZTEfxV:f]éJa˧X|^v[*1ӎ/a{)1"*߻}3yW2;Z É[,3y!+Kqrv.4NӯeU/iV3*;H*^Jbf-EWX[~;w|CƟ6e)RTYdMw,,hn VUvޢ,9Pi+BWЖ+6\^nõقXrBԒ8#oD} f cn fiB+\;o!Δrشz[x5[Pۓc&Г}ܵDmQ~"GT[=憡86_ve!y:1\ 0#@8A>Oi/dsX1Ԡm;O t;.0dEc.%BJIKhy$!F1 *cPF#+V~'Dp {@UVs>ép]7Bcژ`!eDپn-YVͲ$^1*=(WSx/0pk}NMcb0D)J\uDŎ^&  [Ě0@)eh ~T,9-Lql^as6my Tۼbyp WW.*g 058\ZvD]7 B&ƩUHc8̞lo+?auCkF]&7pa>JFlNcZk\%Սsle7 |j}[#j- b'[Z(}5Ё¢0ͷLlt'D-uUϸRBm0* @7&rީJȋ~7MØ 79Q[%d rX=Og!@"0FN|0"ᒰ ooS}Akw֕JgR}ۚT CCC{?L0 4͕˟%]CN-?+m×88z9wS}u6՟ vz+kdU+Oqy s =/Qa(nߒm[ dԀ1+F0>23k~ ;5mW3PCU~bI8 aa, |04Y+D |Gũs;[;}+U5%X\ă_nR xNb{x_"/%2iQ1EUM%;~9{.x?MB$:Frpo~XXJSsY-(HNVCwqv%_X -[>1umW{Yf'Mcb|R/{ZtI;K$Yօɼk/Ư[ЎA}6y)8!uM3] g]m'y9W9Osޘg/f.SzqⳚ>.s;ZZ̰1i=G+Kwd /v?1O-Ǽ5VG̯#[oEy He#3/OY_0Wes1CQYK % y0 [k|o;(fl*+{|}<4;\^,F}MЬ;9*kelD2=t'Y+*֏a.NVnI{eٿ::+O'Ex'cI@f^엠XOsmyjrzյSRYcfȐ0&8LzY[~/w6!aM~ &c/|,? ֵkZVխkZͤLS3335+Y'wwPVx+QZֵ̉~~~?wvt>_7 mUAfsk|}hUty"z@áI0V77<<7}r=@CƇ7zOx^/yfZq}..++;Ri1|ρew= ^ nfO?'S$e"_'U{nfdCK?O˦BCY< x)4Z>Fp|w:z5\,q]3뭼/5'X:>֓۝c}>'ؼcLgaۖM7 p@2/\Eo7E8ٯCx7 Ϲj1űԛ ,=LF%6-rKzo#ɉ5͇c0ոlZXN*g=@ o3}tJ̏8c's0wxjܦN;ػR_U}yn6m3Lm8 ٳ(.^>,'>@%{ b(v{\VRW.Bp:8/7D FO `h3}Wn}&6f^Lnuk~H[WOuuBWX?5].ɍܳg >PX: 1Wm)bl$O v~vcx\_ !_駸뵙mOo(tOE7%}t~{=<[eH&Mcn~:C@:)g9-XPW3V;s.}SO;}_X=Ć'e ^6ocm5Զ>oshˀWx,xzmjʥt[| yvrW`Tf-5Y !W#oeo<єbЊu1 p)tpP6+<%5ʲJxHcc ޘE W] EFOyAŹ ~_gQ+i}Gá;<9n;_Z޾ffmɗf2Z+$m~OsgrYϰ66׉2GMs2ײ7wYL \3mlY U׮nQ(J$Dv!!2<$g6ܿ(89[OL_|ޏW/VSyqG}H7GmXglCPY;OKSBpؗnO/ d7Ȍm7 ݾӯm\U}DDAOW8rI;;܌LW)qE~OΧ ^-Q,aK'rk[9+{;dw&ڎF49m2p+x911Nr8er;G'f\g%s&B*7mWu'N/׋y}._nELݕϯz1y;9̒8%>ӝ3;E_ qKQv=1U3,68<Yz>LNz }WomV?m?^~psw:pw0?=8p~)@>{;۸=~zoTU~~/Yk뼷ry>"2EA0> &+3kv_'u)VtwXjgf͸^.M:KTjۯgxnpU5 ؞,v+FK& 7Mgr{k(/iMnEJj.[-5+zI\|"F, M͠yvϣ}o1 r@a8 K̅xQ}]T=oRMK n|N|>Xl95Fp@_j\7=2y,m9~`OW+9"Ǫ<^_,j|&C9 A҃9hL#$/Us}ϧ>g3s9g3ܾs)B2 G(B BH@(q QUa ^l8/?}b u?_[}Wsan8Cu9^N%._O5B4L05_:BRDa#^8{z/D@@(A@g:9'd7xk?q5(kٸD7h@{i^h+zT|Gіcx|^0_o%es oz\ hig0 ( BvQxvtր,   L l X08@@ )0h(kC 8U4߷KgO+| e␕$̠@@I999999999999999999999999998rqr% 񷆓GBR]Nk2 @Bi0 ;0G#׵Z" c4H?Clgwͭ9@R^NI1x>Ui=X;_<0r0" BpppppppppppppppppppppppWna@$ѱf(((ehsxaxnaYڐ LҒX*!|G C(t.}4y/d>H` I %2,Vgs@m0W08'mհZ@ٿa?6d5{Udad#a>[yjȚ+F; ni D+uo>e-}5n)d7O 6]( P+,VVT[Uխ\"nRĤ#pL`JgfŪִodYB}4  o6 !PS$Icuz_n_UU|9FaJ@€Ah@%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%#K,$7IOĪ`DI"clzmli>G?޿sLxMsgPOSJ8c>Z l@ SӬ_OOOOOOOOOOOOOOOOOOOOOOON=CR""r2+n$: 9c7 ǹU af=oD`($yiiiiiiiiiihm_R`)C2}U9|֮nKlԀ >'w4|C _^aD J5555555250*jjjjjjjjj^TRp>ݗ_G~Oqy},;:*ECe|`=': Iv$R'~ѨRx) b jqQiBB)rY7TtT kgOM58yľyVC |@  xw%QV@9KU[kV:.m̖lZс>WWnuo/*:#wb@A0+m"E2ožk 5z~ӱn>uڷruxr˗?1Di9MGg`OޮlFvup>kն7+Vh}GGKޝ$Qf#w~~`OgU[?j GkjTEj?`jmbe $DHwkο☊L8 pb# CidLBKx_۪??ln8>.\9 Mi^D-&A2:64^f>]^r5y~of-*+**f Hl3tO24iL ]DDD y*J Ek`"U> mA?eQY_ftr;uF=RAew\s>QmwdlDpFF oѱ.%.4EGc&zkv|bs ׷GeVtT7nΉxРHTt0F0x"r6A!##Z-'m3Mε r/mf'l36n9׽B>2e59@ ,V+XeK%MO/>=d+Ebwu1QDHSҘwz/9Tbuݧ c:-wE|Io(.$9 iWSe Ɉ]SA]9vq2ُ =dN(D vij9KdRvVd  : `(6Ц aĸ_qy;}o[_xo,AHB# U/ܷI~XWzͼxal0"1oaFR'%Dzl4_%$-XSܨCeؠ=xl>/Md%1޹Lr:?='\#hs|}?cc\YJxu8^UĜz(?{Φ4:f=ˣ˰@DDc 1'R23W{uVdˁxbWGnвQ2n՗ĵSݴJ"2*)hu? ǎsLD(7L }~.r`F891Lz7o^;ݜ4 ٲ W6J= z&av,j"h꺝.s7x:l$HHFbp|C $i!p2dD 4aǖ[kgA0r1{€q$?ϊ?ܛ/{w8Ifa&laI K'!ߓlcd2( ,Dp*Xcse";23s\mFGYUJC"t,eVlt$"2\eZm_*4~';'[MyG0rKVO~Gc3^wM %7afg񘼫LlY} %Xd1PU|;9SqZI!͹؏Ȥ7$'P@09CzٝͭZoLSi?U+S_DB#_=W* qs1Z}TIӋSA5-kHNM#8)"B{y/4G3p09WFڎc7{ \nEvJ1,ăbRqg>٤G#YqŦC׻4d:Ԃpt6t5ZhQ:] wNBC--C0Qnjfnw}xgBڶl!PFgרd2=JAW)&|,֛Od*VN -ޗ9炖V>nmroǯp]Ivf=>HEȶllE#sM;Ju']VbcR'x0j k@Ea81;o-A/9_!fQPZDZ%gmk@hI)&.NL ,O_7?'ig,s&ҜE0pM(jzLWbI/]u|}pXےeex4m@3iq ex S5k1XǬgu0fZȆn-a0d>T1:菅tE]/ ^ ƥ [#c&{ gz{0Kc뵵:W%Ƹ "ާWQSЄs2SNw4H~ j7nSlZ7SEDVېj_p?CCV8t6\=[Yh(YՎJq<;vn/nk:ς32C잢{(RS]Ψ|Tߌei{ѓ$}IER>44?Ck'<#^:'W 9\ytM>7(n%Ԡ})&Y`0~?ƍJ:7]zjg=Ոv4{-YusvYmS%:۝W~6GMernCN.ԟc"Tn 셼+%!}ɶw-|‹9@!]%zן3w콾FX:uAdy!B Map T]=6.ը> gVD2WEЙ,H}_-fVk2 Jcl>nѝxs_WX͖<)5O좛$]ea_JGKy<>1c{V*TK?Չ''wla·*)Jo5]O2Q ~z}3R&HuFџCэT:U¤ARS$B:.!㋹?r.]?=ufo}UbF <  3j%LIhu+D rљi'SWW3]㘎C\1K-5%/Y $cDszf*^"YhAulE +R$K%%)Ta4d $dc+xeaQvQ)sRe"1y/!߿ ϐZ16"]1|{ZgYOngP9 yr{r*+ nl {EǞ,'^JtVnwj?6 㛴U=;+7D$zR} `y{lݞɍ:;aFB0+ɭիU11s5_O9H}.u+-oCL2 _*IR'O.,A3FryTh]X}?+cMs3 =l^oc#YVhl(drr$w 3q5|$-] ݔ$'_[9,0~v=0)FDDՈKagn"`*uunZ@94'޵2@~$5#t>-φ_@mc[BW<(\,xѲaO{]XJ쭵Ϥ: 6,߅~س99[Vs,yz%JZ3"B[۫$n0(47887t:}C+$P.'!!7_wϖ鍲^#_X'GSAvPhW.ff2QV>`Bqzf`j=AOv66o+T73sUV-:TBkE%yRZag~EPeUܯ#T|>]!wL/+ nq ~&sQEa`?҂A ኬx'GBy{HdVy)+?mB|ZFE ;.ݯ±*.xbӦƼg ]zauջz/ƧN5,T@NVZ#y.N'< ʜmjXr.$0c!};*.v1E=lKu&6V a"6_qOY,uE&.Ca}f@yM3@J3B{ԞѧO'Qӛsq.}\")`mf]r8z7*w5ʴP,Fr~5ڡ6niP 8[JZpE &su5\?X)hNAT5sX~#=WwY{l̐c$ߴ!ewq$)qu_cFGrY8Ag ѐ Xe=_87g6t#(~=ռ?Joj]KhC"{t7iF!}wgrohvхuU \Z˚+$/(8(zD8g+y>xզ`Jms:ADA @?I}|lItzG>T^@sx8~N"!?Ui2dg*~ks:;$(40l*"I gr{kϿ:?Maj>U"{J*6=C|Sh!jHjB,XFF]!Q) w޷`UP!* 0(j|dQyWqYӸRkO**sOy :u%96.^(sblǃ')&m z*,F(ܮf\ߩmZ3"'byu*!>Ñ콆BMn·eA4H(EX S{OMf~qn'ry!`3T-cv=~3D ɬ}TC o<<^gg(d@t o  @6Ks>m,ccldO^ R'۠7ỏP<_3]Qb:Lp@7"( 0@ӓK~u*"&\ +o?S5W&8`"~S)w~G,F(9"Ť\ZGJyМTSRH(#)| FL~9,@%ßgqO-CQ T*Y1G`  (N>!Hɉ֊޿^ۯsc!Ky} A-t xE{u҄?@~7"%=Sӽx -. 0HHd>@#L)bǦ=ǀo=_ 'kpK!4~GO.B?>HSu {7ӭCM?9Nfhx?CgRD>> Yb6o~qc}Ky,d!hZ'LiP>5}7рަ :M_p ^ТIӶj *ek[ sgkkk[ͭ`Y1o1d d540 ,jWk-Q˾^1QXlr5&ّ_+E!#$AG=iH\Zj!z*ֽg-] voda4/;&"zo?;9_*/1CXZWl3fś4#"#47ĕs8~T>PlsݯW%8q$H@Hs( rYW @^)6SŜtQGOwʶyhpWu2o! fĮ\>X$#SL57@7AoUV84B$ ~΍%#]`95bJE I)<ȝ.?vz/;_1ja"!Icvx T۷y|Vc4`aIoO6˾^t΃c˾,#Y] Q%$RR2ivnb@0N׃\;z}\t7oH!`%QxiN2W1#p;v(+\`{Q=SP=fԠ傀 D:V TH"?B':V1@jP *ևEHTj?[x _?b_*#cUכ}Kڊh9 v<$uǰ11`!F/T+Ʋ~2-'64LľM>X#Pwd+'E 14ϓ֢j7uˍR=g42SnsՖ$ ÝcT@#s#!?CŁe>uܶsjhQPs_ s8oD ]V=!_o٤FZ|s7tf/uN DD_?ŏ{T)1VZ+߬=ls:cĖD5F 2=o}h3ڞ20?K mmDihlߝ<=L3J #v 2WXv 'ա9]+6^S|n1] -0hN.ľk5<8{:gmTwW*ڶD=vym\$ w_"{N+ݝ+PexF$]La!'iʫwfݗ8a(P8E%Qu+F k :q&&ǻ8[)@4: DpA#4"uYEn5o_̙ETYB~~,3S:!|~J"81䗑=x]WTtG؃߶nJ |C Ԑ[-V[YǃV<7lN^7wK|t.ޔtuRߒanԏu0[v J~W]$<#Vznᆳnxw=@'(N12>!%̈9.ͼx#RSbRAIWJtGR{$5~ԫ)h}[.Ȣ{Ƶ=̈́hq?5" 6l$~]QěY>GBg1wy7Y &G)S^FFn5LP_.9&W9:J=">x+b 8-q?H!,gɣʕ.Or?&B(ogZjzait 4d /2˸Z HL>|zOPz{ [ӖqLNY_CgQ#.5vI;734Zvsj_0F]d59yR *MaihCIbկ]kܗ)HB9Dr 5ujir)yKAHǖR  ϝO~e4A:QJ| ԄceOjp>ؿ~ش]:}Kd1:z:::Z4]!UVQ-8}ƼsJݭUmdiȉs:ԡ ܐKm(I$Ts 0͏qOM_auqֹWtjvR=a=;4QKᱜ "Ȥiz=e5O <^qڌ 5R-xFwpx+r ,fn20C\-禐 tg% J|\2}2~:lm +ՆyGDMnHǸܽLjW[o~Rz[%ޣvn٬4YO}+a)OqaeQm}(SL:^E/{O1*m1 pyHUpixI%A\(\V+=ɋ9ryVT ߡH#T>k\5z/ d)=5EF')hםg E' (3Y o:C#qI;vXTxSovT]Sl0Y̗U=]AS8Y2#2w՞W!+֘r+ԫƍNM/EGIE^R 7Xq7y9j"[P?#V'~SzJ _kgz$-q(~ʅ΂;m$3B(KSI 2(ؗ$>BXJd$MTɑ*ԍ]׎ѳZ[[uVJĆ/[csЩ@~/r&ݹ%ˀson)n/z(f:?6d?*(K <)xi->/<)AOAn"S| iA'|T8s!xZ&/ǖg|pzE i=wcl~r_/y'F*"p5ӟ=ȜܱR_909sr7֍٥1_5b^UUR0;Yjnr}獭U"/W`M*g@6*j)nb A*x^ ֏oWb ?+\L4D~)՘ !.pCMi@!)[C;gg+TcEaHkE̷…hԁP35hcƁɬ;Pf-z{ "c BtÙU&?4{d6cL|<6ֺT.w4YY>AUz~DQ: D\M\W 9+JeN䧇Υ84 cOv}c0~3H4Badj֐Se),:R mjF*]aT_k_aTSZ**E V((Q:MkU@FUf:9b~ *Q2o*S1of௶QtsOnƍ&=l#M_q\aUyɌ-/ 'eϩہ%mڢ&3w\V;t/l9]˂LkN {]ia1k60먖tkX+X9wjoOXvxX qRsЃbA.eM./5dA;q xl//3b49\ [v}댛 H^ۡ0mz7ᗐOA@Ae$(02o[﫥L?]HB 6F[ /+\C!n]9tqJuJ~*ܿ?xüdB{f{5X0/| L ""(%K0Xf~{FcNz` `aSizNVv5t==ˇ   H A>H` U6(l1 iPoӈ}/O(@zk54zs,Zձګ?z1"θEV4p 2g_LvH;'+ ?Ӂ"3sB #l?Ƀ"V3G2a01g; F [sin'5$rzԫBc!6Uu]km[=H{֣8(Pr d b ut6HՂT@ @@$H_@$ f-O~ߕJM[k lvO Of~WeDI1S%B<^IB]iQ ?q4sxxp \.pSGFg8Oq b)x!4 $bDDe*ZF=c5ıwl3.1SG4hp =ȴ,&s!'NՖ7'm2`1_vuTIa:Vce n\O"@Eqo xNS$sjVT: 3X(ɛ7^?{M}?}yo_'~7CU `XB~$ yC1w<@-ɤ?3rj7ҏ̳<&c|bp[kb_>mX@``J;yfbk}G'R.6;_CkxAZ(^L֢D?l?&/5QRNXD -|7<֪Z ϭ\IfN? ~%cWgSFiw, tqYysE^-+>_>Q.'{dчRcAn蝹bG>RA}LtQxw}WI t8I~%fެ8(@e-)' lV}v}<̞ \PA%ˡC^ C:mMI5 Q(n/9#՜u3mc/㡤nʰWӏN♗U*1ܴZr:jt0qNmcK^&PQn{lz0:`yȸ>tH2]}dBr`q0g03bgjvG2#MRr r^ynz Rv 46֨12O_C<`5PEI.j K6IvI e-JM6*stRtUTA*=1Awl>\{&<9 Pג!n#N"6m݊wh?)V X)~z59Ih#/>*ذa3ET,a) qwԫn-3O a>`VbWR}wS8zۨ_rFe}ϠT;>~gėWF>|,o?1z?;v%jD2lT9Q9#q㬲уiiOen2yuVI sd) zIQΠT7A{G(I^|zDz?^ŧ'.WYs`Wy7o!qۂl8Ğy]yVt7BK64—\y_qI\z}X]uG16^嘭co_t\YjVꞞ=&em}uR_EFJj$Q , M4PQKc"sc#X*B ;㪐H}V1'0:U..==2լ5X]HКt,a#cq2Ne$z[/窀I@ @(&k0%MpvEP1sTcσ  4DDrn-5S d"\hB(+AF`V[tXSG#_s 1Tg#@p~80@BR@udl:܁%b^-.مX9d'۸A6=qؾ 'RQyrc85*ćDlv] ?ᝌrNR0,4i "2߯bcDFqZOϣg:A"H z5lضC.Tῧik[kk]LdCC·c8<ݮG0cFh2@%̙1I+m珦@K[W_k ߭WP(u<)}C}nW \@Um4  qSv(̹L<@  xgcuWFٴV wc MrP6D +HNEĵsG o$؄Md#[Yṿcb- 3^.'ТPV^4ZJz=hƱ-KQ=eb ΏPD xN뵨o_w,c<Ѧ yhi u75lKEc824Ѓ6idxu|bgbF C(-ǭT Xeb cQUEs8;bVCS|^}/ZPlwt.Ӷ4ua\E]uţ=V5:urgfQMYVy0pfn_͓e|VNoLO[SΨ* ]Tz4mC0zeRpӟxVT=K ?Lah[hm^~x] T\u"ŞZ{ĝ'n v"zLWOEd!(0ZFF+37th(PҰYp7SHZFdbؒ>:]ZlyS2< m($,+rXX!س8cfʈXJSE^Qvڻ[6%m,L,ȶU~ '>$G. pu2x\.F0~WT}gۃXOl6,ׄ1~#bTNBC7-pH{r=_&ihfkԖbo3bUJuY7뼮4 g?a8l k(57wX^};0DsޗEaT]QEtd5 pDbcf@ĔNQ6fͰJy {ULB~c^h7ǒ299j6M9{]4_ çGPq׭F3e3y֜ (Gh 7ei>5qF]\lϣ*ڽjo"qߒ^4n i Ʒ+Aw*uiv73W3bg%هB<^Md\h9[RL-ؠ]`eW?^.Jht<|A~"eH`;kw-#׷ߎh7VPN(!=GU'y.>+1^C(lY[I޳[̶&ş!hu^+K0z(= & _sZxt(RR')`APh?hcc`kǧ[5{+@f#d$^b1c( ?stCX$ 5CU# _ )2N#͜S3U@{]/#Y 3""C@BB nTdY;"MʄT5f7Rk[[9潄9JMx Hbف1r6HH]$"3!L f\͗ $^zb% MiуrRYVAļ5Vk)$1Y ɧ|C_CSVF EּI o[sVW[r,1b@,M8c.6> @-KB2QR:P L۬wbÁz9qw^?4iddZ!\{OOݯc3CCC,"d dK}[țI=v"1EL|仑";u#1;cu’Veaw tWǁQcD#P,kތgCGd-,9 pob7b=Y ¨Γk??4-)!@ 1hs ,g30ue 1*Dփ<(H\x,%na0B1,U*P\l5Z7P. l6ҫ#0?h}e6\q0kt/ J{w*[>&|f-7BJHxV!czLHت&BRIGg^b"NW_k<F##gWr~ae G}Ŏ[l3VOtO?BLEW9gGjR,\QIRe0 &O0O ) Ѵ}lnc@rα϶YA%uj@1T~|Vك`sy}Xmxj0ek)ߵ"a_[; ?t.P/SGRmڭl`O )S73{>J9W3:`<bpq]'0>9'j, Ƿ v!RbƧ#7;ɤ|y)WEvD;b;}*cֿk[[^CYJwA\ d5N ƢsBjg^L!IF!0v^~pNt܆I>_Gdo3RK!06uoplg$І[Wkv[r[W4kSO^=Kd(R">%zyx1.jSbV$H8 uOduJ0Ш'K60_=:GI0Eba N . }|-Y,,5P4b1FPU>0[ͪ-ϻҾ/$$a^BIN0זw8h)z J)As-!E rʰM%f[Unwsӟl&Y>1@'VEAǀr\K#m L ayubZ ]TUW鵤LH@%BCx@sHX=ʿ~Lb}X*Y?z;O#@ч!C:yLt_ϣ߿zAB=AhHƤf?͙]ƴF0/՝Q~6WY=4}E'wћ\CJ"1\qku6qp+ -6*xĢeG;F dhkHDŷ1pH 2 oE6b`/Nm.6:w6~]!s]bt2`2XHLaẕw+u:I@܀4yuȅUoBQG geYQLr`:6vcMդtHO={[1*H!@?<,twHȀd!HHQ$>Ըm y9pcfV3E#d#q:7OkJ8zovP3a7g^,x˙a ~߷@lpMypg_pqYPv=t_/x۬3ȣZwd+,NK=pv/f'!:ZFq( CaD۾ o_q6{4B a];P_&@C);<ΫVdoRex@D VSjxgٍo=4V$LmtΘ7p)"$M!D#*gS7+3ҮLBYb{4L/p*XkPZ Ok4:BBCPԤNxDto b e6.|@,A@%cFT`Xnqk {N3q<=^?em8fe+b BlԁQ;j\ntަGF{ζ3ݣ[vrVq1v#IoCg^gQQBBtǷqa@ If|ғ 9%Q uA}@v& C'MQb] )3JTX7SYBdZR*_GkIRQ}WTi=ޏ?G~.ʊz>'rߺ{aߛCɣVz6XCԨB I$`~]O۞v'h^̌""u!(bj oFFFFEFF0d _ Zc͜7GtF0/~L v~V] jjVJB>>>>>>6=h4ay0_8@Y|%Ѯ7⻪ٞ 0%͗CmZk,XbŊM<#{֝ŠH=h↣&>`ͧj9` v_b>*XSw_:mh޳8\$G)_~s-3 HZR !!UUU<0^ņ-Kths9Vz-[6lٳf͛6lٳf[w̓f͛6lٳf͛6l &L2dɓ&L2ejykhg=r˗.\r˗.\a tC~ӧN:tӧN:uw677! ˗.\r˗.\s/s){W~'SM4M4M4M>ytph?[ѵjիVZjիVZ֣K,,,,xe?n^z:tӧN:m:hѣF4hѣF4_lZmގ:tӧN:tӧ_e"z7[ UǹhǏdNTf8B3xI5_f3vE+ݭ"E#@Y/LO~|0J֧GKVS Yg~daRs~Eq$,8B44=,0U\0LcR 7Ló5=ByLIq"~%CF;ׯӜ8Oa#\GM7a (9U򮼘"8"͐0NT/93Np {>3D>En%UM=3J)[8 \'J>xr/u) xtV8.?#`U>]Ճ&"{)Nx@tvLj,uY [)^~&d,%S50B\&~f ̡]ACɖc#Z,oxoUf* 1̖H?0#h~$œZB%li|)H Q1xStugC8U2t}9BɣR?;k}&RKg18 ÎzP}ƲGU]si C|3=˒kTABJt@Pe&{|LmK)qd C+H6 U~h浊雪\=`I?32]@ Gz&\ٵUr'39x'֬*:*kRt@΢h4KU@W}m@sQM925ؖv0ČU(\v ӁO9Ԅ VAT{|VXt ;'ܴI1g)Qr\^!z0:`IWL&'oݽ~,ԳnA͇z4v u+ gCW:vr3aHXgm+_=Oӏ4Mc"B~K(#!kQj/)q$C Z:Llo٠"OAmi,E~~? F09ԁ- A,XEf;V`JUO;7WJbwzɐQ5 IC bRH GYڱ>HMϟX4UEYR9,N[?9L@\_ts$%ǡ&uo@Z2ŸվY&s\ƲX3.b1Qgv"Q1`bjj;LnǓ7VnɎ.TVΫ_*^G~J`%jjbn-AdP2#@!O9 EjOU;DFe(1|ۏiLE@cđ>RCD b2Tge$25{N H`~"ֳ6MMߢ8ɢ"Z5Vx)V]UxyvOd%X{ %n} ϷhUR;0P*mrJ6F~Mn1 Fg>ԫWqV'n~ue$'cx7!'Xo(f㳒gZZAYQΪaJd= =R5%Nnl]5 .C_k G0G: ;/˫ddJRk dyGѳ[킢y\4 /rM8X#:v Pv"6MmnwaG*vA*4s3;qmγPe/꘏;s4|a,o vP&Y,x*G{I1ЭECdkNd_z颰9Nߎe־ >XݰƂPS[:ah6.Q g؋2ю=6zVG00qsl10,SCPl_@'qDuA0I,F=DL,be,XA)&ם1GyPPAc'7QH'k܁{l'W6ܰ? ?$9?6 $ yܠI uFI(d=$<}r6BPSI)SCaɬLzZbpz[1(&ߤ (DE4gp ;;Ƣbٱp7sUPSR[B)3ny~O<ﳬT̽3r&'\xLHA d5SQѲ`@`"B Rc(X˚r'kAA@9" E XQ>i(y: tbv-ZiPu ѿcIsaIoxcykCKN/jJ E 1 X$]{FR\UWWWWWVuם|XXJpتcV`ͮr>K lkLj;{rDhnJzKbv]Wev]ee=}ކU؊([YMb:kI} Ku{9+A]mjX>P A7ʫ5}MZAQOqIF¶W) 䒦1X 3E2o_vӕt*ϲmmmmmmmm=|Ts{U3o9D6sgR$|"BdWG-<8Oﻥu_}6Bb>do1>$k(~|>`Bvv՟`sWj6XK WBM3i-ExZr1D'9sr&:q;}6}ʿ%=m 6T\e0HGJATZҝ``V = 94 `OAi)2.DŒƌH `DQVq])}.O1ơS[H,b>Oc|FGQ ='O6V_;;ǘxeG버bpPT/è|\=v{F<=NNUZ#a;7S_v-nOn}B~lB^fN#P% n—ëd;vV{wu*5[χ-2V1" e_ZHu~,2Ԕf8XgxEc&ܘ0ma?{^𱽏ຣa.{IL| _iT]4:z$vk&<_ҢE}FBnL'j5>{Ѫ]-+2!bOJ8*`ƖeiW:a!eJ9ɔ}1J,\+i;I7z`V.Z;R{_ FD҂X:rNX̀_,%C7=s,fe)fߥ~'6=K%{5yKoR*eyVjxL rpoG@vBک^5u,IMuh+#T;;nу*!>AC_02! F\,%b4DTXw R?  3xr>A ~ \7U~L1I%,WMzʞ/VY^ P4\Yeޗ@dwFpG*TF_"U`I EpiشrPGK.=| o;F%R緣 nw%ou "+ I$,p`(^uK5<7(k&V?wj"#=by MLat9ҟ6dQYU GXX%fvۈ)-&ڰKsW'3mFq䲐a)+j{x_i":Zxw)ygA/mz27]U1D }L ۣβʕ9eԏ!8KJyTOXC:FH}ֿ n=Yi~R'.[:*u0E!2d7x'/Y\^v9tD>JƊХ3,+N\;nOU F=\Lũs=sz1Ï1On=r9E0! "O4UdTffy}֘ORzEБԥV X\rS'k+CAr)}P~=Uv~ r_wؿ'!x)vE՜[|.3a:r*-v O.ƈ|WXP-Ɔ$:$Qy_{e=HnƌYr@ @  }·aZ~gh6 |:__FruӉ4fYwt>TA!P޷Yo|y­ٲ[s#PEw جMJ̸jY0pc3Dq[Gx=>C&>8eƗ~iV.2FL}aP>tW%<|MOs*eUw3fb)Ԏ~"k omm QSaƅy 2Mv*,}#GvPy6H}v Iqfo󋳽Ge,. >zjA&ڤ F&9Z3k>}\zD^=G'\WП׸ncA- }]MmCFG i zpRV}_Oᇏy=̈R6{,=R%2 u)>?Cl<=pxy7Pok͛G[Vt=HyFgggeӟJw^G>ą㶵ԏ T)IT$ѢlaC,~gzUR?;;gLZaA jn~Dmԩ_^H=oӝ̭RvZn1PzNXM=+K(nB &|/'cy]Ȅj0| x^>o햚d0!/x fQIS!WQ?WX<jBΦb_YyW?\ͥ{;;7͜q(JĎ֯C#K;*BQ2{TadU]k#ڵݦU2bv LL_cwLXcZugk?&młG4~,_V墈sz?>ɦo͚><&W16tD PrUoqp$@H"CPWviK)N^B wAv 5%K.\kMhf x_B3Ӫ'Pf 5lj>2K=0=i_I^qApzk{i$@)x2 54 =ycԈOe/QzW==uUu Cz?T(IePgzԱ%PG4v xGXrfhhU)yr-dY" N!}ֻoB7ʦ@ 4>ד ]_LŨoڏZv(W4Eղ@J|% Grg9n5!*GlB1W}p|^$)l7Pdv,kƀmsD(7*9Mv< m}śhF GR$0 J+EÇ ;9rnOA?~0R+~]_Z_]w:qIF#4úޖ+[{u]QOyMߓ2rтzsji^]j&}s?_g5G6l协/@; ZdpF%񲓼8 bX_FbX2iu]VT4i{%/ddkA_U|b)ST lXZj񼺩!ScW!£ xc83ZƳZ|{/ydʍ[j՟V9Gfc1qg Z[6cud.RX-k{o,k#0,4{On {n1zfQ`t$l,sҸ[Pf"vA,Et6=mkz1}F;/йrI;~dշ ȄC3չ4|ZI t#GaNJ!c)Ceޫ YY݌S;: %81kI%\IVP0dh?bid 3S^&M 1pONN+d:Jme;2-gLP7uwkj^7"iSZ>k_LkW-Q]gC˘s$`;ۯ|IT'TN5FѓkV _fĬTF06wnMJ Mefs[p]M>C%U.TF9O4,Sm6kS4Uڵ}-ڴBzM1@ gz\f[{L;i^>vFF=>?6۝юYʹLFoQ,j~z;vӧT?wRzH2 tg^z؊DnWVGWwIǭ^ٳf͛6Jd2򑑑yf1X|sǏM+nݺ.ݻ'7 f8:vU.vXbŋ,ulz=iwl{^zׯ^-ҲR^:VtRbnS]W3`Ž5|߿~◂c5!.|ɾ|d^ 4ى yqZ?K,×5VZjt$c5%yzf͛6mN,/9t6b  vF@fC`n((hPm4{JL+WvP.R'b fvծO7qPPPnzoyb0vrP{[Hspu9xy@$eP?M^QN1oM-o:,Qsw'5Eu.9_xAEeaqs&G]sq;v8׆\ɌF<j~=|*c-ݯ ab,5#W,el dw1˳|dDWS9n<ȶ5l*j5}U,S-I4l.fų&mY8l  נBK =퇫T]!yt,dXFFGI6XlF+ӟ'+ XL,XbŋL2ddɈ,X$I$lډ`})$I$I$}?Ye%I$I$I$y$JmY eI$I?KRWjZ]I$I$Id9) I$I$v#HBWI$I$,ڹ-#H$I$I?C̖YeYeSJReYeY/䒼SI$I$TI$1$YeYeYeYi[ј^I$I$I$ dK,,,~[R@$I$I$I$I$I$^k<X8 4*ճG[R1Vxk..Fzk_p҉+_\;~zҸE%cs:Mx7Ʌ}LO:dpI+'h r"4LzeF3GH>89n =MHXh3s'+W̯`=6*إ)'7yٵfŋ+سnx+jZ U7Jz_cd:9:'Q?#ةLuaW;rg}?9KUt:D3#y Lړ&,(,ז&{773 q˚8-/gJuKԜ{8l9]?MuN T,TRo<'2affeb&b!.Dds&>a,{Jkt5hh?JF)m"L6NZ A϶͌(T"{9J(8P|&r\,J" 2Ҝ0`(Bx|v*@zMXb#Xr٫[R5@Kt=1)oWm_{*Rpy\2]jPY>GQƧvFga =r|\l(7'gj22/[HUb6*4sR(mD;#œtkUc,}CWV:բXRA1[ʄ,~&A3QiZ(/}N;-?C)p(jqWrz$*CWvr5 /7j|QW"ԀHnq9ivlMjSAUȊn]=n>w,O' /Ӑ$ :dc ]cĄeS%N[R̋'tyR{z159wf BB芫;#4xGIAbt.6쪠bkwtk4TYIeԘ4QR?_ie, `fkLcXEs |h58wcrK$j|_#tx{WT.yoqb. I{F<&Z <DQ.iJycTDS#>AiCۦ,'l(!lR<+EVP8]l xslsQ]u3*a~#22ʩ F6mW`jSN e-5d@QG'Zꏨj`X>6Ns%՚C·n˲;J!m. ѠFQ15bu}HV1SV ×߹& 1)@kp1ڪ?oUBc(!EUH.fR!Dq2Tg)X(~y rɺ8z6ҀE.d90.qBz(xn;9EYJA}Psu`}h#$t/y\qGkqc]g;1BC_p4ݟmg&6 ={.N8{j,3{! xS 4K@iaˉx$~Sђ$K4"|]?$$96T>"$mQԸxqVmMDM$sʛm'R]j̢hwTYjP-?4)hyn6RM^ zRjgm'AHZC0ѐ BZ*f9_rj4NB1JFII7p?GGW@,A7G::A֠_U@@ A$>/u}K$Dz $kߟNUUTFO|g4xlM8@c0H-|Ә I+N1c?(E\u8khMk(Drb@M) ]aig3 y?,+jNG9=J1\_|܌†HB΋){%ꗼկmP<=GCǘƩ󏘜J! t90COXݞ^eu$Ijjp,Ě'iT]#u `Bׅ7R.4] 2VNLy*arN}&c-`@F &>`q$yPΗ׾lx3jq fCLJlLn "%JBlUf,u֎5h0)4I\2R| VZ|PAA@t)VUIg8+k:.'sc쳟 9wsgbZo7=EӃo6@LC^ךO 0< vasAδs<`mm' u\[-ڃ]+O-%O( w2>H֬{\޶ڽU2z@f!<nmWσ{vV 0>jQx+PqM<d1R {u8{C0c^}ox%1JNO`T,ba \GwT/ot|S z0dlNC$?U@S.\_02;O?^dt $u<S6ګJ/˧0X\v cj5{ T~#Ca lDbZF.|xqb1wo҇sϲwۥY,2줨l-MZEҼrOiZ^H"Pb} tsىs D!y] 5n";HlH؉5\'M G-E <!k.]S%h|ΉxD}3%uZLzC֓ Wޭ\ՎϒBS_ܡ}a2u &0~^[ma;#Z7^ !5슕CxׁDzu/0%V3^9Q),>|)[_m-Z#^R@\dbR-oO&[`Z#x5Ã/G^vD!: v!LZ/_@' 3yݭI}va6(_,XIֻJRh4ё\-﭅!qnF;=ӌA|],ÖLs6{.jb2,ѱm>O֬0%oT+iY=R## 7e (.ܒ2fѻk{Ro_:trYpUYL AWW物* S֡'*\fY ]wԱ8'tQ:gJfzeGh\ TcA:.IZs4QVw˽H;83BEVP]]Mrl~4`c^GkEf2UҴdЍqbWQ-4:Gep㿯NcP$[u0@( Op*ݾ}ZD0A1%0 n4`؋Ŧat}&DΊO*1TTp'[^hk~: h|d7-\jX}zP<]?EGfE8R BŽ qFõ-}e444(-*Ǫe8aUHlAr֗m^))_m?wVR}Yd]-  ӚasTnrmGk\^=6( h1ʵBlnuZ(|8'lȯD@Rd0x;klܜX!.n/04ւ?!^Y#l:Zif+|85 Tv3όFA]|r`>r^@S=vvMǢ<+VZ.)Har&kArw,|!a \ZGxk,:N3@' u1z 8V@=tL)q-͔pF;6S 8COU%+' >~Ȫtt;<% q% TO\xcz,9;?z(2Tr(64cpDz9 F*LFΐj l#!\QMܟ>B6$F>UMs7œ؊rTKiijQxPhci:)nj& (0 kZAA2!^:~R!XB'|yiҙ_ >#VlwG[S$NN[Y8VsoB쳓NÜ|m#b)gyOJĄڌ8Y UaCv%_;֕u= 8q d;WDUdIL`sHEVTjl7)ōBg'T[z{yR|a[ L#=-Ss?ø?ܜ7WqS\\`qw]n&fX__Ac|+:?{+;r6N U}Al+Sb^ڙןBsOn^C@Ŏ fQ,NL^z7%Vr:J $}_:m(2 ,o#zۃ?iz"D1,D, /Íc掸)4y7&^s_ bF1 $ CHcqAآ.nؽ/t?{i*$Ǟ$;Izs~Zuxb/ܝRaVQJ> cw`CIKo|c7f]L//>Hbgi gjY< Ag5Kxx:]7 I*wg  'ɔ FtC9ېzP\8ҝ݄mkPUd+ (W\kWR~0jh(G>۸7t!%MV ڎ\MXRoй5Ra؅y ?!Wwы'91B #NC;y7=tdτ1yϠaw)XipI7!1Ai| Ed -gdnd\wV΃p>W^a(w}'pV b1S]qX0Yc I:H`c $ԗ}KF3@`EjhI%2&e.Y%%,o7w Y[ ;>eg$o|`96LTx,s5Eۤh$bž0WeW8Mvg$ڢ~f1^ LMP HYD-Oqv#9[`嬏#j.nC^$}Ctz :'﬽}S)΍eҧg `jcTBo\*+E,hG  ZW*E둚_>GvP&,`.խjAq>GTU_o1j;Ůyfr_G C}]E+ z^ PϝdWÃϔ#2jK&3WoS`{.CDA`#USI|L6",i~Bhi ۮƋ10v۪$ p s&n)̾8K9 U(&"bl]yNs,5+tsadw- Oխ0l!Kyfm4om9t1agh%W oR8Hg*ɤR]IG$39-r+f22 [](oz7q5.HF}f1|Mx7d,l3PԳʼnꢁ9,z NJ ZN`tb )X3ſ 5@ 1tWb!UޓRߚP@}Ҷ}ҥ#8iߗG(Z]ˇHH,5zs]qUv7M>^Pv[5횾S$D[4м}!anM3W#HЊ3z߯hpj1kƀ,hwf5P-z/aMh _!>ƹ46;(/PC Š}_ ƪFJlhju0J_%f_ڣ Dqm5c|aҚ Rt&_6 z-xϢw_/"y bjBHU$exz 9)Ju~K̯9i0?@g">&]:pZ\Q$oAWQ?%qt'*'>+Zcn R! iwA1$q2"Z;5uvB"Y6{_oHwp~1FcZedOl`c{o/zXġ \wO*dA"هNWnGa`&^M@&N4ٜ;^, \BML5wxfh\$1HzM.WvAwe ʈ۾tP*.O.y[(X0qVF_:oO MXD 1ʭxf&šl7P~ BZZ,R 6\F*1n'g}t;->P(MBTRq/ixVˆ$U Pj/L fOYxMNw |Rsp;|~NSAgfD—i~D,yY$Vy4lәL1*v_cHB-+R?Ԩk zL =OiFUL/w}6-RHa4Maq/mҀcz yt})xGV2~oa*H3\Mu7g稵KҔ'tf4`;y5v#7K4eIljT븊mX,@TreGX~Z )E>W_әl+kPVH T7ъ/iHD.R<ƂT%;ҡ!n&P %L\>6MΉ,r@$ye.Qb~YM7]R'ߗk Н >w^>x-(O>uHF=вE˹AjÃ>t;y\}s, Ҡۧ ǿhui:E,ʋe!x~;}.1J Tw @z@,1*+xe)BqAK4~'%T{زZ%C١Q0 )s#y*_g 7}w~<t7|`\a-%ۣt:a_` M_K䟝/|0Be,o%Bkj H^ʊ1Y|t <5bX 0dTCd+v"PnT!zj_Q$j*+ُ"N^ a>uJ]KOZ5t^mzMZxtofc~fU-5%@I"ME@J^Qz^W4p{!c>;7&Mr P$*2CSۂ$iHo؝G7+&?,3e~ 3dFd CWE-wd@ui!n1^](8E' bzύU!X<!7i}3ʋAw0!<&3}/<>@IvT@f;HK XlF&=3j>DFqhDeЗR!Wga=s+@u:{%TZ{Z{Jǘ,TGyVTE^M,45Оu4Amo2>1.MzGqˎSTӯGr*:Î1թ3abC B $c(Ǻ$W̘EC$g$\|䵲 bݬ`"$G]ڟ=@}$۩Ԕ"x(_j*ʍJ\$*W(e>H|B=^H}D&$H6O-$s@? 36e\N3; {,1"k*5L$lTo|'>iLG< m7AM ЄU _!iW3y"w&C= !'<8 ^rѹq,1BqXItq:rK-vc9 O~ K]zG ʼf[L2ٖ_";M8PùPWěwIlV']B{<԰:8|hBK*)u$btϷCXrgADW41ul$78 d yq #S2V3Jhߟv(ldz}нnCd!7a"HE1L IXk#5P+L,"؃~O!v45 4 K´0<p&C hcd:׮W;x9vv(_uFј;U&z&^7@b,pO m7(%QV].2' wowg 8\!Z C 7{NDuzDNq!n t2 ˞AKȆ4;|m?&6Bo#ߧ316(H1T_:tI{5_6q܂sQhEa^ lfExdNZ&L^ϖA; 0*ϼΰ?2X`+%G?hu.K<]PPyxP6i~`u&S"[WF%pTNAƃj#7ߗ&ee_y(c`s%]ă:{.zl\ȗYBgyZd1ms)`ItsUl>ks;i' ҲC4!D0ky@~qyP ӘrGM͑2D'i`,]?T߮3j@^ qK,,hhQ:TCu5wjxF eĒj?|Nf󟪰ʩ1B ^ňm^"1ЋoZB+u,\ݹElF'`K~r_9^iCXEyI}6JQ^y fa-Zwy!he*`ϵIQ)8? @v8<)e#D"D.J>]w|MkGŽ =6EKo"@zd<2 2~,>S{֞F{jN &dA=f!h&:z!vE+(>x%Z2W{5.N'L+z*16$B7:~ @rj ^W _j!HYlI3øޙ/F# ek*?=dX:4Wmm[? #ʻOB-ç3`l0?ĖESgw NaeP%B u ws>g-㽹j HXXwaQ(7Ζ!#0!*(L 9UMS^.GOEe:F\\/! ?.o:ǺdJpU([H@fO~1|n$EIm0(n1!A&QX'Ay]5UluQ^sxZ;I P-SΉu*\4sR/ $3^,x̣03VW9`؂AEúR3j[\Vdw=:z*SX{k3+w9T3 :ێ*;\S}b\nhLLzk rDblzE1RpQ%Ѩ_f4Y G8ߕB:Y[u CMo.KM"_P愭EY%1qON!a.*"- ]C`O Z.; l9Gә͍2 8Y_J8!KilJ>< q-U= 1m jc,N@z1ӚNgS;eRkRcYYAg? cYtu=cFnHD I7ug(w\K,T|=zԋ$"79ȹP-pbQuwݬԓlXަaW`}Kα1qFM_( "[pɭ;X/4dl+4%FyXcd %ZPXYb3rq SV[nJICTh^g}7J婥ڍ)rl0hzܫYpu2][e_fθx' xٞv+5),!2X;ol[r:ԫ\kzsGG$lXTDȩDW:7G8yρ43`{~m&p(*#2kETB̟U`xC:\=i]cЙ2@ N{IC:Dh\u#VQcq?pYu\ 2Zi(>Xh2Tf)1]ZYU5'ɝj4|v Tυ[BWV52zz0~K%q y!UWbb߶Q~v[caq8oB⚛q)wBMɔeES#9n R~v@+ED7).ldž$rOsK `[\^kEOB̦T=e1R2:SD篘_[/Jy*IO'y#~I[ɿMc_4{@|>ڐKW[D^:fЋ"z/07) nzhX7jZj.o8^=zJM{ka16!_L@Ǜ7lStv_B`_{cei: @`]T~ꪠN.k^;A;?~AI9:O=(ު5z"`H'$^y0ӸhnY( [z9g' jN40JS{427,3#(ԗ#n5C1ԍD[ 6AR~~U=,BSfG'.U4bZT(| Ae7ۦ!o ~dhKOXs9d_fo *]zqw-s'}%ɀkU -hz(T' j77C,U]'PK0Ա̢k'O=V00=x&,v!1&@Bgee0I+-|vn#C=ᖕJ2 p\YR2}Jߡ8%„e6"-3}ٻ%'k(nMV{$D* /7*3fZ~2&ˊ+ 4/gY#,9!/a!I55❩4fL$/|"iufzՎ@&Ʈ6R⠯"ɷ\yQ .i絈qZe)1lZC2kF 7v sC,Ut5=J: 4r|N.*J<(Wi[ɰ9u>~ ^Vdzl0I+&4PC[j8/9sv +jC_¥N 0$~9QDz$h ;E2AIhi˳ Ь'c rK[B+w#0;[:UiPJ* oYjC꤉D ;Wz)&/=\- 1uw J+Tk+=\jÛƦ.V5 ~F> z}{MMh(Ҍ.vvM/iG71zg|g-+$ɫߦoD+s d5xKԧA~̉! zWϻqč$j/pC^ffSM 2g pkQ7MFPvIw5R/fof츝aU&g<\B*pC;vV09ؕng(f~Gfj# IIݷ*,Pۭ,p) y+4{e (E s<"@vk . Ce7q/yh?֞ozӾ=wI U˰WbzyrU4zvٶ|9B|I$\͹G" (c\ ;|! LCRDo◆UX<9qm|t9.ץ䏿Tˉם[!7S5PAZ{k}_ =`:h-YuSkw^߷4R7DORW(66=Olη1 qLc[#oRj+-r%uUg8^%L+ oFiMq GHr/.( X%v 9SIS~<ϗ8)vaF`m#կ{gz1y9s>i+TZ*%$Ak sHb;W 1vaVa$T5TSY()YP Ru ڷN]a"QO't&R-.ƐrA_Y-gMq{GeGGSu:e/k[PrRG Ք\gr9kI$Ɉ;Fa-Hk]*}K87$ LΥOoee ?kU#)"YZFq{QVĤ 8|v;njP;yވu3IS3Ns…!; |m8w[_8|t"8y [&s =քOzb]35cC^(h_j-_7>_{nDǝu>;Hܙk5Ns>B ʚ}MCZ[ g;c+b􉗰a:T݀/D3WPMGʞ'RNqQQi㏇MWᡰLT(̘Ey"|6] cF WN?_K$:Ps|KDtfFId9&Wh9eg8Wͮmטm) +t;34=mz Q{?k햹1ك]qP}6(Xjx]T~q&pH/\Q]MbĘp#ә+;S"1@*u)a(MJĄЭiSlFfلбdPuH*2 $5=&#r,DZfo, Tz} qΫgtk!lib@|3Rtޏܒ NP [ b^2]FB f4[(#0b%cl m /b'c~гRB^K}&}%y:e2P`ϧR9^ART3Ǫ 0AB}8PS Y;v\t+$Pdzz! JZ}Xg|dSy3e%5]2'ǵ%› }> cI ;]YNu"N,De>qw'Sm2U6 7mN z7@;+&#fcŔҲ±10EM³)zժ\W'EfV4Lp ޗ/YDk\f2W%ϕK|"Z}RR# d\ i@K Sbnw4_bP6"Q| %-zxh֑յlFR"KIAKt1E;JsuAf& 59ib D&QDMߓq/,_&%ITF o rmc]>(ͱ:*>W-D|ɮ3˼/(AT&J4F^]#((o[S#G&{rO(kū[ǰ&Ç ctJ ,}uvg_AbU]wi.5@}t8hI+ɼLy[v ː2=ϸl{> zOcr *qw>K8tCI&Vi+X(rwtfF`K@6$Me \& !o߃_NFCZR#I D QPau5iizhoXEbI t׷iФ3sɸp*v*E4Wp嚖 a{GR2˃P"WOoӖҠRR[>` UTB3zoO&;>(VK11L/b9DJQs@b, ъ:7)|ѣ6$B`s,'$&}iCp1KR*Z*z!L9[P~=]$*Qz51j,s줈wL1UW~Q_$c:Q<UGTŁHiG9#gAOju8'q~'+ Oړi 0}5—dIqp ;t &!=9- G*\>o.j%QSAH7/xe􏩻܎]VRTwUIISr3vyXg k_%$XDxex[6>xΉj[aP ${[@=γ3v$;.: v;*IGPr͗Ifm\~:z: =ONe.*I$8qadFօx`LѰT1bi)"h/Fy-;"P\F(SU/h?D= 8^Dl"]hBa/PN4AzߧSB2eKo9 |D3=DoQ\$5xź6EV^չ-AyJW&'}$gopMyo6(\GXրd3#g:i++iř߰#hx6fq1_(c*+F]OTzJsY{X%`rolL+lt69VO 1#%F~0DdWs$HV)[ ~$~ONցt̪` ~w):7oCfQSn~:=_V R>izi0gƎ*ktB`#pC Fev^C,D;@"D{}=kY[@Žgl*r5A 0s DÕv;% e }t1H;| TSU"Wk-I/9z%٧:2>q.!Fj<év};#kG^(Z>Ù#Έ`Ȏ=nz8f2Ƃ@=>DvL/pF:-߆@,=.K{ h>5vngisPSЂe4&IQ Y3'\[5>XiQ9SЎch?X#7cwqQT=2o-,=vcDTҚRl1FSPX0c2Yfojܞ ƻ܉d*km˞Y]5`Z8fSs%,BP!{ȸ\<s'UA54P@21]mWR5}k nNX%mMۄq )IT?W?^k:X™IkQיOWB 88gLG0mۢ8t5O 5 0Nٷ4e(S By^CŏV8|mc~#=fL~:ztF* *,pfv='&e`/N2;~1xĥc}iO>0 Mm9-<,rK%͍%`@C?^0 n.X9d" ~f{ Eۺ:MN&<44̝2ߡJFpl$. n ˩)x0/Wi?5K6 rS_=k!--RJU'V OJ%#L cPRaB7 9QlXZ]_ 26!G1XވpcUXl+Ӱ-TJdp͉?W_"+R]12t‡ ?d7njd;j-&Tj>ޯkoȁR zeTKQ8%w@i*f~䒻\L}gǥ˽J~<_xYNweͿ4DΒ$cL+5bcK#Y;V7ÌьV+ =ڗRuc!4&j*]Nuוּ׌ l@AC ZTfY'߁F]I0-qd*Y$_$sTEg" mt`K5l*?\G4/tP"T}ȑB J~le% "eA +M< ]6bQȠ|]J;Z@6oBGm ڍO-~G̱{tC`y,{?N'g#E:'%ҹqNp"i!$ceݶU\nФrEw?_pp0?=ZzȈ.;_궰PmFh'mK]HA|;ZѴZmUk a!3 GКzm2deУO≙I}t6Һ%;`uq1 HGG Ƕe1}IarTwor rY5v=IXesM!u(>Y_.LUD[؄N!F zs6$u4㝽>^|dNΚL E|<8oLHMI{B`^]fԲݏI0,<$2փ,,{*ك?i~ԑN7ϒa1qf1*cl6Ư1! q! 9B8[:( xkt'f(ȕfEHK9"  ]Uv>љK4KTB+#: !On{D+cBb֝VT@JAe2`2vK~Yu >`0MR7Uxļlb-+z@o"PGWeQ#d87㵴`]녔LcB2R*SxsOr,l}=k,,8@i[y{E@J0SSֿg!-O+,ɗ!fo@2D54?隼%- Bm rJe7i3Ko,H`iOcRJENtT%+t6RYKQ`$ҤL ]89#5٫~:T[ʬo;fOie\CWHyֈm":?tgԄ>4a-&ތiV.-![u3\kbp8pJc] Zu4QˑEKp mA艵P.0(RX沥ߍBfw,fMOia~n0%oymihFtW^q#x5s_b$#+%ڶ&tܵoD汴yɹ% fv]<6Ag㸓(Z ES TGDNBPތv#-ї잜.l"} ’7hvS63ߣoNhTa7eO!T}q 6r-Hؖ_ g6}zCA!cFVJ~QPT&^CvigscRjm+Ӯ1}nIE¾~ԑf [ެDm^m:ƊWhP0՟+ MSӯ>0bɪ FaEȌD< u򢠚``/p+ Hw11 o9!fh9 !kqǶ0DΠ׳RR4%|NL#z1W@F{?r0IJqwvrSJYsnm# 2Nq?֒omeAWƴwe77Ux@pcEaݦkP;F 7a4{wbT ztܕEܖZ =֓~#X(IGGbyĥs(PTO*eDoڴ)E sϤQ"ƬOLES}.Ia{ۮυ;tznA/|R49Xߋ]P]as\͝{9 e\Vx<݀ϲNRz'-MByq2ᤱ@ Y!’ q YZ