libopenssl-1_1-devel-1.1.1l-150400.7.63.1<>, 4ep9|gXzAn5_+[@zi|-Eхۄ5 )2-O`e%.N8_0:I{ zۭm&'yz8yAc<~~ 3aƬHsU9O+%I_اbȩL1N]\`9OKUQh<|ִ"#u:' ˆ)\zm)e=1dP>u[չUJJoA@9LQ ՗Thf5-O$|LM)S(!Mv>G:?:d , J $D]clr4r r r r "r #Lr%r'Nr))r+|+ , , --(-T(-c8-l90(:OpenSSLhttps://www.suse.com/Development/Libraries/C and C++https://www.openssl.org/linuxx86_64 [9_ ^.[7Vw+@4 k(?+0 eC> 5S'w *"IffAeG,,.(-(373$7*((T$; u a>~" GA큤eΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeΦeeΦeΦeΦeΦeΦf6ba27e87d97ea578f01540a8f84b7eab05d42c178badce712d0cc668d8a9981851313b1176baa3d6896aaeeebef56216ebdd38dcdabb39b3eca36b6645352bcdb4883ed3aa74e07338001b31ec7e3e68546521c54bbdfe68c473b33f8511ca6b89b16216ddd35f028f5bfd3fe0db4f2ead6c9415e7749b7115b0393b427ef2f2702f569302248b8228e493177cf0a469f127f1ce5c76bc684bc90fbdfc45743ef96c716cac393f2cd6da304af029155ecd9f021869cd5a4c341ebdf249036bccacc9ca951aa523d3ed6b9df2366022633925a6729d30cd134a05d2ffe5fb15678b055555957eec2bfb4ce5f91b27bdcfdf73128026be9ce85fcca0126fdcd3dad29fe4ef37fd7c4b256b690caf9371a74e29981f6561b94436dac54a61bf74b813b2c7cff888b5b709b90d4da584afef59b5ce1ea888617d682f1af48578faf8f79b29c5ad479186acaae962a598d9868dc434fd5fa49a008eecfaff1b998cadaacb00f416075ae470723f764d0ff9703f4a5fc31e881e1be8937631de7efffa4fa292b903cb8c2ce1761ba4980cf5bdfb66dcadcbb5c8aecc45b012bc64c23722f6ea87711b7c0cb6ee29c15762c2839e5ad17b9ef579b6e81b6121f035c30561bdb2e985458e809e656c60e4bc83e1d6707746dd8b5badbc10b64198d4770a14c51a129b3ae5795dafd98065be0bb0cbf00b4d4528e85adbf629966f42f5375bf95d1da118ff1e2f143ccb7a564d949de440097b97a49725c03976e167b5207e4b0a779c957ef9026d69c0cb5a621ddc2060af967e0dd5e91ac861fdfbdb2086aa0b661ba9de9618afc948a4d1a82df970a406f6c5bb6fa60572a720a62f098a877c62723e6042e4e4740cd1a6e7799df752d9234386d73a28a098e6eb31cf64be205d08af2557187ec19c03678aa9e29f66e428de29cebdd62cd7c3b5515e54341e30523dadc09d821366f5afb13c9286d540b34c1945406918ed588fa21175f86b69b58b0cd1da6c9b27d87ab4e4ed52f37dc76b7895c210c43469504ebabfe26485cd43a80e0c476e628979612ad28a635577baf68eee476850425a498a1296c2f27189183a001af9e3a5d3c833069a6564971f5966c9ed67c5c79970be752d7d3da32a6c009cf264450726367fd69e7c2a4c185d580ce650021d68e7ab27aaf0d39609500b4fce3b3b65f6752116acb30420de1d53943074a481043f0ab6e70b52e341247c4b217883980ff1e98e4453d1020b0b038cdbf096c4ab8a53cb68fbb498e34e19e46f9d41561596ab69ccf78b1d8bdf2f312e892c060015f1adf4ddcb2ee52e6e558f82f4a6b65b8da6de8316e9d66f517e4d7f3b19357f3363b9a3649853b6395022b0bc4e13d6601f46b137d7fba28493d05b982cb5c17390d012756c0a7b90a02d28fdeb7d580fa58fd79cdd4eacd9f2fd512558c6ed6192c31d286f90ee299e07901a733377dce5d0d11aea35e137e9414b8b71594ba7304f17cc9998bd7c16539ae9a5ea545f2e0c64086d5e688caba104b6a7ffecc87c55abdb4755ffc04cd5e35a36d8b1ff2f19f3d8b9c7ef10357a78ff887503b2289f14f11e75ac739d1123651d16e841f3c74e36daa483c1fed9f8c5c144720115f55dc938075b1eaf0ca4c0c15c242f380ca09112ddeba46bc603bc8ee509e95fb89add3bd32b6d43dcf1a51d1839b915e774d7138afaf618e690efbf414bb95fb89add3bd32b6d43dcf1a51d1839b915e774d7138afaf618e690efbf414bbe7dc092ee4e49a79c109727dbe91bd5dfef7ae0edf1dce224937059ebe8fbf800db45763a43c17d78a4a0b3fda207ac0be4781ebdde45f04fd4b07a5ced460866f3d1e91ba1b7971929530cb8ac3ef934c0b82a8cd459caf224e241a3e5ad6e91447263f0a840e8135c586e16c3d858cee939deddf4fd905e391869809b4daa20d1e295f6795c28e2c9f59a9a4ea4326ef3de390086aecc41abc015844ecf713a25db04f62146f597983b908cf63856c35fc5be2d56d65f38f2e686daf25d11c54fc9b14764bc276baa946b90983325283e4754496778579231e8a73a8749e59641a5209964370995d8fb477b257a21be597e21c769263156661515ea2a6d50e052e49c246119d06d4bdc734608b7fd9e0b1835dd2d6aaed8710a464d099257276386c2273f105f54c5749f2fc854573c371ab185f9248ce295a748e126caae8bab682c5cc06027c82d126ed8e65d7dd9dcc75fa464ccbc95d7f168bd69c732d89b0f9ecc3955557687e5ec3e5f8600545a0f3fea614766159d6ba0c55ab884b8109537cee52954b774962dd7da73ac5e4a1a88b0520e1786b5e9f6457c1b4711036e20aba00e0585b96b91a00ae7792dc12501160e117d1f824833de7fe37529e28f0a8d5e2297649af298f5e3209d32fe9486edb1793cc698a757c9127066203d3fc9dceec6c168d219eb9f404ca08b478d5521622834bc24b7d45945702e4a0612a8f7e69e3bc166fc186ca44be1e5b1d020b5da8b5be021f73d48c270b82f13b01ec09c45c2634673d1b9b1a79adbd6ec32bdff94287308e2bb27408e537f4e527987e296a26fc1c06f4f896baa5f457b7e67f94957d176eed469b0fe602dfea0378e40398c6625901ef3597fb225cea86755b1634c2996800901a7db0c44018d7c54e6f19c3230af063f4dbc8523f1450528a4af15a97a0a1ff3fb3ba380ec7330c122ae2b3174df95ddecea65ff661a6152cd0192529dd1411ef3f62a15c7b96ad1e8940a4703f7549fba6413e028a3271e21d86b90593c346b4d7ae6bc73a57b1919601ff8c04f2dc9c62dbd130ef2d3ae39bb0fcdf25bc9e6eaf327ab8bc04480dd9c3fd2f22190d05265e0f1b7027b8ad0686997b25132458c25637f5e6b7aa4728ffce4b8f8500580020dd9bb860bfa9895bbcaa5af7decd9496933a90589e6e7d9f4b23b6cb24e4229ac30fb81d9677080c2b2a8ef4d552b9c8cf32d62036d0c35d03fe7f7ddaaffe3caeafcf984ec16e4db7ed19d3e202e9d7ba6833ee5712125d1ce8f7b52437a752e40c2f4793276859a8228c0de71d35c3e0d91c6016f3c1ba70683b92fde55500ec334777defb6486c41b0a9c4e402aa29597c129c6c9a493d7e5d3af123d96040d87c4e54fc5e41aec450832cb32a634d6967546195d61a4a43a03c790baa4a92e3c0216408033dfb465c3bccbb6db1d16cdc3505c9bb9168a6fad434dd9d9a49ad630b9ae9216bd665b11051e04a709bcecee11e9fbddab20f78a018009e6a2daf287ff5df00679298b137fe9996d9386816fc66b1431d960966f5b3b04fd2760e7391d6a298441e4d571c2303150870c12379cc0a7f168cbff8e08828da72dc0e87773bc6c3bd14c4b57506339b61fa585e01e2c33b07372f559d03e9c7437a2985ccd065d24873e2069b0c0c566c878ec2b9196898bbc45ff2ab00204f93a6f20c974225510f29097ad69a6eeebcdfe6fc023442f524349685d13d50854ad773b12b8c7a153d72d615ab27dd4a3d609c238954a1df23f52362d6e5fa78df2c7a5a2ad6ef9536e489f0a23295efa0cab8c74b93c10a9e83abc17ced3a8021af7506f39a0fadab07b5db2d4faebcf68b6509c4db9081195cf6c9e5fd4683890aeb39509f2997a1989dd5a57cf43039bc275949d324b5d068e666cdcf3dcca53f28d33a788736dbdb476b888ac035dd66f57665dabb37f4f0bd853539d93c64cb8adf37fd9552dc9fad215cc8f47a991c46bf2373dfb10dc5cbc626cf2fe86b9b1c82373d799bdd6be13eedaf7d4540d550bb6745481ac56b67f450d09033e813bf8f6a5f2025e90d5eb539eab1ad5e32382a08bf9a866dec1b7deb66b4077690cee0f6caf91eb00136c5eed4e8d943d06e50e2dd5df6a0db219091cd1c6768a6d319ef6485b16e1f361fce4306784762636106e58fc967645b1312362dda4da82bae901662fdd300cff6276d796b94b877fb557a32488ad44a25420abff8279abd0bd1f4ab768e73d3e1d5c2dab36c0c5d04cfec2a9f9da2aa299f55884215e200b490a6e0a9423255262648bd8a6d1c054a3c784ebfab631d21bb9b7db3ce38167acc0299e8920b5ce6e419a3736930a45ba803bbe14007e494bb24b2ca954f6362ef700a10480efa3d2f3acb159deec1105bad1a309d3122a2cfbdc4098a33e33d50c8118e70bb332f3b7d6ef2bbb58071c66bcc03ed5c2a24f1964f45e8d1a633f3cb4b183c718ded3e25312f8c4e00c9e026a5932a2432e3cdf7defb789610c4272010e51e5ff0471809eabb7aa2dd4104ca8720332b9852f4725d4660a6cf77a52b587e7d96ec263e996c1d0ae2f9bd039ebce7bf6b6e71fc9667e44e017fc0cb7c79c023be1c965894e61b79238b6e1bbc8c53e4f7c054768dec55272d001dfbfee788a85ba8b0c069e08cbbe85903696bd5b9908530f8a8578fef47721f47f3fe8507bac7761473e925e942159f5ea3f5d2e7beb3e81db8c23c6e618e38e511c213fd93a11ef51b9ae4ad03619bb39377c702d9765547ce95f9e758b46a54ee4e2689f892033cf2a4ea57d5d0b38750722d1737083fa8caedfccd3bce574080e35692010d2f91dd303b154af69f1b8b356d649da24236d5aabdfafe047b516b2008d8d5d09da5e99fbc4b4a98cf621ac4c38a89bd010656ca00937773126a7ef348b29a14b04cc5ec5c095b531622499b9aaa546957c802da9aee36794c24c9c7d2e105ae69b47841ecdac6b7a9194b49c21e2cfb96924306d06fdd1df761948e203a9408d16899e5e7abf3c873d17dcca277cd6f6373a30a6e07e1a2c44024a0b980ccccc2533d78bf0c227769029b42ddcbe7d4a8d23e1e6fea9c6ef6c4afe7222ee2135298211eefba3ba1720c3637d765a07a07890059c7a0e24b62af43ddde3d433c4720596e36d8b4d82a54fa7e449d3fef6d060b59f6d6dcbce8af377cff0c3343e79d42619394b9c8bopenssllibcrypto.so.1.1libssl.so.1.1rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootopenssl-1_1-1.1.1l-150400.7.63.1.src.rpmlibopenssl-1_1-devellibopenssl-1_1-devel(x86-64)pkgconfig(libcrypto)pkgconfig(libssl)pkgconfig(openssl)ssl-devel@ @@    /usr/bin/pkg-configjitterentropy-devellibopenssl1_1pkgconfig(libcrypto)pkgconfig(libssl)pkgconfig(zlib)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.4.01.1.1l3.0.4-14.6.0-14.0-15.2-1libopenssl-devellibopenssl-develssl-devel1.1.1l1.1.1l4.14.3eeReSddgd!dddw6dkY@d*dd'@ccccccƍc{h@ctctc[@c=qc$e@c*c@c@cc b?b?bblb@bbobaG@b4t@b0b0b)@b!@b b bOa@aaar@ar@aa@a*@a)@apa=a+va@`m`Y@`?z@`>(_j_~@_Wr@_G@^^t@^_@^V]^O@^E:@^C^0"@^)^(9@^&^&]]]]n]x]v>]g@\@\\ac\G\G\A\@[0[ @[u[u[r@[b@[Xf@[Xf@[2*Z4@Z4@ZZ2@ZH@ZZv@Ze@ZTZOZOYYKY@YV@Y@Ym@Ym@YOY, @YYY i@Y @Y @Y @Y @YtYYX@XXXXXh@Xh@Xh@Xh@Xh@Xh@XXXXX@X6@WSWSW_@W@WW(WWV޾VՄ@VVa@Ub@U'U@U>UzUyx@Ua@U @T TTk4Ti@T\@TFJotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comotto.hollmann@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.compmonreal@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.compmonreal@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comjsikes@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.comjsikes@suse.compmonreal@suse.compmonreal@suse.comvcizek@suse.compmonreal@suse.comvcizek@suse.compmonreal@suse.compmonrealgonzalez@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comjsikes@suse.compmonrealgonzalez@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.compmonrealgonzalez@suse.comvcizek@suse.compmonrealgonzalez@suse.comjsikes@suse.comvcizek@suse.comjsikes@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comsflees@suse.devcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comdimstar@opensuse.orgvcizek@suse.comtchvatal@suse.comschwab@suse.devcizek@suse.comdimstar@opensuse.orgdimstar@opensuse.orgvcizek@suse.comvcizek@suse.commeissner@suse.comjengelh@inai.detchvatal@suse.comvcizek@suse.comjimmy@boombatower.comtchvatal@suse.comvcizek@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comvcizek@suse.comvcizek@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comvcizek@suse.comtchvatal@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comtchvatal@suse.comvcizek@suse.commeissner@suse.comvcizek@suse.comvcizek@suse.commichael@stroeder.comvcizek@suse.comvcizek@suse.comvcizek@suse.comdvaleev@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.comdvaleev@suse.comnormand@linux.vnet.ibm.comcrrodriguez@opensuse.orgvcizek@suse.comvcizek@suse.comvcizek@suse.comvcizek@suse.commeissner@suse.commeissner@suse.combrian@aljex.commeissner@suse.combrian@aljex.comcrrodriguez@opensuse.org- Security fix: [bsc#1219243, CVE-2024-0727] * Add NULL checks where ContentInfo data can be NULL * Add openssl-CVE-2024-0727.patch- Security fix: [bsc#1216922, CVE-2023-5678] * Fix excessive time spent in DH check / generation with large Q parameter value. * Applications that use the functions DH_generate_key() to generate an X9.42 DH key may experience long delays. Likewise, applications that use DH_check_pub_key(), DH_check_pub_key_ex () or EVP_PKEY_public_check() to check an X9.42 DH key or X9.42 DH parameters may experience long delays. Where the key or parameters that are being checked have been obtained from an untrusted source this may lead to a Denial of Service. * Add openssl-CVE-2023-5678.patch- Displays "fips" in the version string (bsc#1215215) * Add openssl-1_1-fips-bsc1215215_fips_in_version_string.patch- Security fix: (bsc#1213853, CVE-2023-3817) * Fix excessive time spent checking DH q parameter value (bsc#1213853, CVE-2023-3817). The function DH_check() performs various checks on DH parameters. After fixing CVE-2023-3446 it was discovered that a large q parameter value can also trigger an overly long computation during some of these checks. A correct q value, if present, cannot be larger than the modulus p parameter, thus it is unnecessary to perform these checks if q is larger than p. If DH_check() is called with such q parameter value, DH_CHECK_INVALID_Q_VALUE return flag is set and the computationally intensive checks are skipped. * Add openssl-1_1-CVE-2023-3817.patch- Dont pass zero length input to EVP_Cipher because assembler optimized AES cannot handle zero size. [bsc#1213517] * Add openssl-dont-pass-zero-length-input-to-EVP_Cipher.patch- Security fix: [bsc#1213487, CVE-2023-3446] * Fix DH_check() excessive time with over sized modulus. * The function DH_check() performs various checks on DH parameters. One of those checks confirms that the modulus ("p" parameter) is not too large. Trying to use a very large modulus is slow and OpenSSL will not normally use a modulus which is over 10,000 bits in length. However the DH_check() function checks numerous aspects of the key or parameters that have been supplied. Some of those checks use the supplied modulus value even if it has already been found to be too large. A new limit has been added to DH_check of 32,768 bits. Supplying a key/parameters with a modulus over this size will simply cause DH_check() to fail. * Add openssl-CVE-2023-3446.patch openssl-CVE-2023-3446-test.patch- Check OCSP RESPONSE in s_client and terminate connection if a revoked certificate is found. Add OCSP_RESPONSE_check_status() function to do that check. [bsc#1212623] * Add openssl-s_client-check-ocsp-status.patch- Security Fix: [bsc#1207534, CVE-2022-4304] * Reworked the Fix for the Timing Oracle in RSA Decryption The previous fix for this timing side channel turned out to cause a severe 2-3x performance regression in the typical use case compared to 1.1.1s. * Add openssl-CVE-2022-4304.patch * Removed patches: - openssl-CVE-2022-4304-1of2.patch - openssl-CVE-2022-4304-2of2.patch * Refreshed patches: - openssl-CVE-2023-0464.patch - openssl-CVE-2023-0465.patch- Update further expiring certificates that affect tests [bsc#1201627] * Add openssl-Update-further-expiring-certificates.patch- Security Fix: [CVE-2023-2650, bsc#1211430] * Possible DoS translating ASN.1 object identifiers * Add openssl-CVE-2023-2650.patch- Security Fix: [CVE-2023-0465, bsc#1209878] * Invalid certificate policies in leaf certificates are silently ignored * Add openssl-CVE-2023-0465.patch - Security Fix: [CVE-2023-0466, bsc#1209873] * Certificate policy check not enabled * Add openssl-CVE-2023-0466.patch- Security Fix: [CVE-2023-0464, bsc#1209624] * Excessive Resource Usage Verifying X.509 Policy Constraints * Add openssl-CVE-2023-0464.patchFIPS: Service-level indicator [bsc#1208998] * Add additional check required by FIPS 140-3. Minimum values for PBKDF2 are: 112 bits for key, 128 bits for salt, 1000 for iteration count and 20 characters for password. * Add openssl-1_1-ossl-sli-008-pbkdf2-salt_pass_iteration.patch- FIPS: Serialize jitterentropy calls [bsc#1207994] * Add openssl-1_1-serialize-jitterentropy-calls.patch- Security Fix: [bsc#1207533, CVE-2023-0286] * Fix X.400 address type confusion in X.509 GENERAL_NAME_cmp for x400Address * Add openssl-CVE-2023-0286.patch- Security Fix: [bsc#1207536, CVE-2023-0215] * Use-after-free following BIO_new_NDEF() * Add patches: - openssl-CVE-2023-0215-1of4.patch - openssl-CVE-2023-0215-2of4.patch - openssl-CVE-2023-0215-3of4.patch - openssl-CVE-2023-0215-4of4.patch- Security Fix: [bsc#1207538, CVE-2022-4450] * Double free after calling PEM_read_bio_ex() * Add patches: - openssl-CVE-2022-4450-1of2.patch - openssl-CVE-2022-4450-2of2.patch- Security Fix: [bsc#1207534, CVE-2022-4304] * Timing Oracle in RSA Decryption * Add patches: - openssl-CVE-2022-4304-1of2.patch - openssl-CVE-2022-4304-2of2.patch- FIPS: Add Pair-wise Consistency Test when generating DH key [bsc#1207182] * Add openssl-fips-DH-Pair-wise-Consistency.patch- FIPS: Service-level indicator [bsc#1190651] * Mark PBKDF2 with key shorter than 112 bits as non-approved * Add openssl-1_1-ossl-sli-007-pbkdf2-keylen.patch- FIPS: Service-level indicator [bsc#1190651] * Consider RSA siggen/sigver with PKCS1 padding also approved * Add openssl-1_1-ossl-sli-006-rsa_pkcs1_padding.patch- FIPS: Service-level indicator [bsc#1190651] * Return the correct indicator for a given EC group order bits * Add openssl-1_1-ossl-sli-005-EC_group_order_bits.patch- FIPS: Add a missing dependency on jitterentropy-devel for libopenssl-1_1-devel [bsc#1202148]- FIPS: OpenSSL service-level indicator - Allow AES XTS 256 [bsc#1190651] * Add patches: openssl-1_1-ossl-sli-004-allow-aes-xts-256.patch- FIPS: Default to RFC-7919 groups for genparam and dhparam * Add openssl-1_1-FIPS-default-RFC7919.patch [bsc#1180995]- FIPS: list only FIPS approved digest and public key algorithms [bsc#1121365, bsc#1190888, bsc#1193859, bsc#1198471, bsc#1198472] * Add openssl-1_1-fips-list-only-approved-digest-and-pubkey-algorithms.patch * Disabled test 15-test_ec.t in FIPS mode- FIPS: Add KAT for the RAND_DRBG implementation [bsc#1203069] * Add openssl-1_1-fips-drbg-selftest.patch- FIPS: openssl: RAND api should call into FIPS DRBG [bsc#1201293] * The FIPS_drbg implementation is not FIPS validated anymore. To provide backwards compatibility for applications that need FIPS compliant RNG number generation and use FIPS_drbg_generate, this function was re-wired to call the FIPS validated DRBG instance instead through the RAND_bytes() call. * Add openssl-1_1-FIPS_drbg-rewire.patch- Fix memory leaks introduced by openssl-1.1.1-fips.patch [bsc#1203046] * Add patch openssl-1.1.1-fips-fix-memory-leaks.patch- FIPS: OpenSSL: Port openssl to use jitterentropy [bsc#1202148, jsc#SLE-24941] * Add openssl-1_1-jitterentropy-3.4.0.patch * Add build dependency on jitterentropy-devel >= 3.4.0 and libjitterentropy3 >= 3.4.0- FIPS: OpenSSL Provide a service-level indicator [bsc#1190651] * Add patches: - openssl-1_1-ossl-sli-000-fix-build-error.patch - openssl-1_1-ossl-sli-001-fix-faults-preventing-make-update.patch - openssl-1_1-ossl-sli-002-ran-make-update.patch - openssl-1_1-ossl-sli-003-add-sli.patch- FIPS: Add zeroization of temporary variables to the hmac integrity function FIPSCHECK_verify(). [bsc#1190653] * Add openssl-1_1-Zeroization.patch- Encrypt the sixteen bytes that were unencrypted in some circumstances on 32-bit x86 platforms. * [bsc#1201099, CVE-2022-2097] * added openssl-CVE-2022-2097.patch- Added openssl-1_1-Fix-file-operations-in-c_rehash.patch * bsc#1200550 * CVE-2022-2068 * Fixed more shell code injection issues in c_rehash- Added openssl-update_expired_certificates.patch * Openssl failed tests because of expired certificates. * bsc#1185637 * Sourced from https://github.com/openssl/openssl/pull/18446/commits- Security fix: [bsc#1199166, CVE-2022-1292] * Added: openssl-CVE-2022-1292.patch * properly sanitise shell metacharacters in c_rehash script.- FIPS: Added signature verification test to bsc1185319-FIPS-KAT-for-ECDSA.patch- FIPS: add bsc1185319-FIPS-KAT-for-ECDSA.patch * Known answer test for ECDSA * bsc#1185319 - FIPS: add bsc1198207-FIPS-add-hash_hmac-drbg-kat.patch * Enable tests for Deterministic Random Bit Generator * bsc#1198207 - Bypass a regression test that fails in FIPS mode. * [openssl-1_1-shortcut-test_afalg_aes_cbc.patch]- FIPS: Additional PBKDF2 requirements for KAT [bsc#1197280] * The IG 10.3.A and SP800-132 require some minimum parameters for the salt length, password length and iteration count. These parameters should be also used in the KAT. * Add openssl-1_1-FIPS-PBKDF2-KAT-requirements.patch- Security Fix: [bsc#1196877, CVE-2022-0778] * Infinite loop in BN_mod_sqrt() reachable when parsing certificates * Add openssl-CVE-2022-0778.patch openssl-CVE-2022-0778-tests.patch- Added openssl-1_1-use-include-directive.patch so that the default /etc/ssl/openssl.cnf file will include any configuration files that other packages might place into /etc/ssl/engines.d/ and /etc/ssl/engdef.d/ This is a fix for bsc#1004463 where scripting was being used to modify the openssl.cnf file. The scripting would fail if either the default openssl.cnf file, or the sample openssl-ibmca configuration file would be changed by upstream. - Updated spec file to create the two new necessary directores for the above patch. [bsc#1194187, bsc#1004463]- FIPS: add openssl-1_1-fips-bsc1190652_release_num_in_version_string.patch * bsc#1190652 - Provide a service to output module name/identifier and version- Security fix: [bsc#1192820, CVE-2002-20001] * Fix DHEATER: The Diffie-Hellman Key Agreement Protocol allows remote attackers (from the client side) to send arbitrary numbers that are actually not public keys, and trigger expensive server-side DHE calculation. * Stop recommending the DHE in SSL_DEFAULT_SUSE_CIPHER_LIST * Rebase openssl-DEFAULT_SUSE_cipher.patch- FIPS: Reintroduce the FFC and ECC checks in openssl-DH.patch that were removed in the update to 1.1.1l [bsc#1185313]- FIPS: Fix sn_objs and ln_objs in crypto/objects/obj_mac.num * Rebase openssl-DH.patch [bsc#1194327] - Merge openssl-keep_EVP_KDF_functions_version.patch into openssl-1.1.1-evp-kdf.patch - Add function codes for pbkdf2, hkdf, tls and ssh selftests. Rebase patches: * openssl-fips-kdf-hkdf-selftest.patch * openssl-kdf-selftest.patch * openssl-kdf-ssh-selftest.patch * openssl-kdf-tls-selftest.patch- Pull libopenssl-1_1 when updating openssl-1_1 with the same version. [bsc#1195792]- FIPS: Fix function and reason error codes [bsc#1182959] * Add openssl-1_1-FIPS-fix-error-reason-codes.patch- Enable zlib compression support [bsc#1195149]- Remove the openssl-has-RSA_get0_pss_params provides as it is now fixed in the nodejs16 side [bsc#1192489]- FIPS: Move the HMAC-SHA2-256 used for integrity test [bsc#1185320] * Add openssl-FIPS-KAT-before-integrity-tests.patch- FIPS: Add missing KAT for HKDF/TLS 1.3/IPSEC IKEv2 [bsc#1192442] * Add openssl-fips-kdf-hkdf-selftest.patch- Add a provides for openssl-has-RSA_get0_pss_params as required by nodejs16. [bsc#1192489]- Backport cryptographic improvements from OpenSSL 3 [jsc#SLE-19742] * Optimize RSA on armv8: openssl-1_1-Optimize-RSA-armv8.patch * Optimize AES-XTS mode for aarch64: openssl-1_1-Optimize-AES-XTS-aarch64.patch * Optimize AES-GCM for uarchs with unroll and new instructions: openssl-1_1-Optimize-AES-GCM-uarchs.patch- Add support for livepatches (jsc#SLE-20049). - Generate ipa-clones tarball artifact when livepatching is enabled.- POWER10 performance enhancements for cryptography [jsc#SLE-18136] * openssl-1_1-Optimize-ppc64.patch- Import centralized crypto policy profile from Factory [jsc#SLE-15832] * openssl-1.1.1-system-cipherlist.patch * openssl-1_1-disable-test_srp-sslapi.patch * openssl-1_1-seclevel.patch * openssl-1_1-use-seclevel2-in-tests.patch- Update to openssl-1.1.1l ('L' as in 'Lima') for SUSE-SLE-15-SP4 * jsc#SLE-19640, jsc#PM-2816 - Changes in 1.1.1l: * [bsc#1189520, CVE-2021-3711] Fixed an SM2 Decryption Buffer Overflow. * [bsc#1189521, CVE-2021-3712] Fixed various read buffer overruns processing ASN.1 strings - Changes in 1.1.1k * Fixed a problem with verifying a certificate chain when using the X509_V_FLAG_X509_STRICT flag. This flag enables additional security checks of the certificates present in a certificate chain. It is not set by default. ([CVE-2021-3450]) [bsc#1183851] * Fixed an issue where an OpenSSL TLS server may crash if sent a maliciously crafted renegotiation ClientHello message from a client. If a TLSv1.2 renegotiation ClientHello omits the signature_algorithms extension (where it was present in the initial ClientHello), but includes a signature_algorithms_cert extension then a NULL pointer dereference will result, leading to a crash and a denial of service attack. A server is only vulnerable if it has TLSv1.2 and renegotiation enabled (which is the default configuration). OpenSSL TLS clients are not impacted by this issue. ([CVE-2021-3449]) [bsc#1183852] - Changes in 1.1.1j * Fixed the X509_issuer_and_serial_hash() function. It attempts to create a unique hash value based on the issuer and serial number data contained within an X509 certificate. However it was failing to correctly handle any errors that may occur while parsing the issuer field [bsc#1182331, CVE-2021-23841] * Fixed the RSA_padding_check_SSLv23() function and the RSA_SSLV23_PADDING padding mode to correctly check for rollback attacks. * Fixed the EVP_CipherUpdate, EVP_EncryptUpdate and EVP_DecryptUpdate functions. Previously they could overflow the output length argument in some cases where the input length is close to the maximum permissable length for an integer on the platform. In such cases the return value from the function call would be 1 (indicating success), but the output length value would be negative. This could cause applications to behave incorrectly or crash. [bsc#1182333, CVE-2021-23840] * Fixed SRP_Calc_client_key so that it runs in constant time. The previous implementation called BN_mod_exp without setting BN_FLG_CONSTTIME. This could be exploited in a side channel attack to recover the password. Since the attack is local host only this is outside of the current OpenSSL threat model and therefore no CVE is assigned. - Changes in 1.1.1i * Fixed NULL pointer deref in GENERAL_NAME_cmp * bsc#1179491, CVE-2020-1971 - Changes in 1.1.1h * Disallow explicit curve parameters in verifications chains when X509_V_FLAG_X509_STRICT is used * Enable 'MinProtocol' and 'MaxProtocol' to configure both TLS and DTLS contexts - Changes in 1.1.1g * Fixed segmentation fault in SSL_check_chain (CVE-2020-1967, bsc#1169407) Server or client applications that call the SSL_check_chain() function during or after a TLS 1.3 handshake may crash due to a NULL pointer dereference as a result of incorrect handling of the "signature_algorithms_cert" TLS extension. The crash occurs if an invalid or unrecognised signature algorithm is received from the peer. This could be exploited by a malicious peer in a Denial of Service attack. * Added AES consttime code for no-asm configurations an optional constant time support for AES was added when building openssl for no-asm. - Changes in 1.1.1f * Revert the unexpected EOF reporting via SSL_ERROR_SSL - Changes in 1.1.1e * Properly detect EOF while reading in libssl. Previously if we hit an EOF while reading in libssl then we would report an error back to the application (SSL_ERROR_SYSCALL) but errno would be 0. We now add an error to the stack (which means we instead return SSL_ERROR_SSL) and therefore give a hint as to what went wrong. * Check that ed25519 and ed448 are allowed by the security level. Previously signature algorithms not using an MD were not being checked that they were allowed by the security level. * Fixed SSL_get_servername() behaviour. The behaviour of SSL_get_servername() was not quite right. The behaviour was not consistent between resumption and normal handshakes, and also not quite consistent with historical behaviour. The behaviour in various scenarios has been clarified and it has been updated to make it match historical behaviour as closely as possible. * Corrected the documentation of the return values from the EVP_DigestSign* set of functions. The documentation mentioned negative values for some errors, but this was never the case, so the mention of negative values was removed. * Added a new method to gather entropy on VMS, based on SYS$GET_ENTROPY. The presence of this system service is determined at run-time. * Added newline escaping functionality to a filename when using openssl dgst. This output format is to replicate the output format found in the '*sum' checksum programs. This aims to preserve backward compatibility. * Print all values for a PKCS#12 attribute with 'openssl pkcs12', not just the first value. - Dropped the following patches: * openssl-1_1-CVE-2019-1551.patch * openssl-fips-dont_run_FIPS_module_installed.patch * openssl-fips_fix_selftests_return_value.patch * openssl-CVE-2020-1967.patch * openssl-CVE-2020-1967-test1.patch * openssl-CVE-2020-1967-test2.patch * openssl-CVE-2020-1967-test3.patch * openssl-CVE-2020-1971.patch * openssl-CVE-2021-23840.patch * openssl-CVE-2021-23841.patch * openssl-1_1-CVE-2021-3449-NULL_pointer_deref_in_signature_algorithms.patch * openssl-1.1.1-fips_list_ciphers.patch * CVE-2021-3711-1-Correctly-calculate-the-length-of-SM2-plaintext-give.patch * CVE-2021-3711-2-Extend-tests-for-SM2-decryption.patch * CVE-2021-3711-3-Check-the-plaintext-buffer-is-large-enough-when-decr.patch * CVE-2021-3712-Fix-read-buffer-overrun-in-X509_aux_print.patch * CVE-2021-3712-other-ASN1_STRING-issues.patch - Rebased the following patches: * 0002-crypto-chacha-asm-chacha-s390x.pl-add-vx-code-path.patch * 0003-crypto-poly1305-asm-poly1305-s390x.pl-add-vx-code-pa.patch * openssl-1.1.0-issuer-hash.patch * openssl-1.1.0-no-html.patch * openssl-1.1.1-evp-kdf.patch * openssl-1.1.1-fips-crng-test.patch * openssl-1.1.1-fips-post-rand.patch * openssl-1.1.1-fips.patch * openssl-1.1.1-ssh-kdf.patch * openssl-DH.patch * openssl-Enable-curve-spefific-ECDSA-implementations-via-EC_M.patch * openssl-assembly-pack-accelerate-scalar-multiplication.patch * openssl-fips_selftest_upstream_drbg.patch * openssl-kdf-selftest.patch * openssl-kdf-ssh-selftest.patch * openssl-kdf-tls-selftest.patch * openssl-s390x-assembly-pack-accelerate-ECDSA.patch * openssl-s390x-assembly-pack-accelerate-X25519-X448-Ed25519-and-Ed448.patch * openssl-s390x-assembly-pack-add-OPENSSL_s390xcap-environment.patch * openssl-s390x-fix-x448-and-x448-test-vector-ctime-for-x25519-and-x448.patch- Other OpenSSL functions that print ASN.1 data have been found to assume that the ASN1_STRING byte array will be NUL terminated, even though this is not guaranteed for strings that have been directly constructed. Where an application requests an ASN.1 structure to be printed, and where that ASN.1 structure contains ASN1_STRINGs that have been directly constructed by the application without NUL terminating the "data" field, then a read buffer overrun can occur. * CVE-2021-3712 continued * bsc#1189521 * Add CVE-2021-3712-other-ASN1_STRING-issues.patch * Sourced from openssl-CVE-2021-3712.tar.bz2 posted on bsc-1189521 2021-08-24 00:47 PDT by Marcus Meissner- A bug in the implementation of the SM2 decryption code means that the calculation of the buffer size required to hold the plaintext returned by the first call to EVP_PKEY_decrypt() can be smaller than the actual size required by the second call. This can lead to a buffer overflow when EVP_PKEY_decrypt() is called by the application a second time with a buffer that is too small. * CVE-2021-3711 * bsc#1189520 * Add: CVE-2021-3711-1-Correctly-calculate-the-length-of-SM2-plaintext-give.patch CVE-2021-3711-2-Extend-tests-for-SM2-decryption.patch CVE-2021-3711-3-Check-the-plaintext-buffer-is-large-enough-when-decr.patch - The function X509_aux_print() has a bug which may cause a read buffer overrun when printing certificate details. A malicious actor could construct a certificate to deliberately hit this bug, which may result in a crash of the application (causing a Denial of Service attack). * CVE-2021-3712 * bsc#1189521 * Add CVE-2021-3712-Fix-read-buffer-overrun-in-X509_aux_print.patch- Don't list disapproved cipher algorithms while in FIPS mode * openssl-1.1.1-fips_list_ciphers.patch * bsc#1161276- Fix NULL pointer deref in signature_algorithms * CVE-2021-3449 * bsc#1183852 * Add openssl-1_1-CVE-2021-3449-NULL_pointer_deref_in_signature_algorithms.patch- Security fixes: * Integer overflow in CipherUpdate: Incorrect SSLv2 rollback protection [bsc#1182333, CVE-2021-23840] * Null pointer deref in X509_issuer_and_serial_hash() [bsc#1182331, CVE-2021-23841] - Add openssl-CVE-2021-23840.patch openssl-CVE-2021-23841.patch- Fix unresolved error codes [bsc#1182959] - Update openssl-1.1.1-fips.patch- Fix EDIPARTYNAME NULL pointer dereference (CVE-2020-1971, bsc#1179491) * add openssl-CVE-2020-1971.patch- Restore private key check in EC_KEY_check_key [bsc#1177479] * Update openssl-DH.patch- Add shared secret KAT to FIPS DH selftest [bsc#1175844] * add openssl-fips-DH_selftest_shared_secret_KAT.patch- Include ECDH/DH Requirements from SP800-56Arev3 [bsc#1175844, bsc#1173470] - Add patches: * openssl-DH.patch * openssl-kdf-selftest.patch * openssl-kdf-tls-selftest.patch * openssl-kdf-ssh-selftest.patch- Security fix: [bsc#1169407, CVE-2020-1967] * Segmentation fault in SSL_check_chain: Server applications that call the SSL_check_chain() function during or after a TLS handshake may crash due to a NULL pointer dereference as a result of incorrect handling of the signature_algorithms_cert TLS extension. - Add patches: * openssl-CVE-2020-1967.patch * openssl-CVE-2020-1967-test1.patch * openssl-CVE-2020-1967-test2.patch * openssl-CVE-2020-1967-test3.patch- openssl dgst: default to SHA256 only when called without a digest, not when it couldn't be found (bsc#1166189) * add openssl-unknown_dgst.patch- Limit the DRBG selftests to not deplete entropy (bsc#1165274) * update openssl-fips_selftest_upstream_drbg.patch- Run FIPS DRBG selftests against the crypto/rand DRBG implementation (bsc#1164557) * add openssl-fips_selftest_upstream_drbg.patch- Use the newly build libcrypto shared library when computing the hmac checksums in order to avoid a bootstrapping issue by BuildRequiring libopenssl1_1 (bsc#1164102)- Fix wrong return values of FIPS DSA and ECDH selftests (bsc#1163569) * add openssl-fips_fix_selftests_return_value.patch- Added SHA3 FIPS self-tests bsc#1155345 * openssl-fips-add-SHA3-selftest.patch- Support for CPACF enhancements - part 2 (crypto) [jsc#SLE-7403] - Add patches: * openssl-s390x-assembly-pack-accelerate-X25519-X448-Ed25519-and-Ed448.patch * openssl-s390x-fix-x448-and-x448-test-vector-ctime-for-x25519-and-x448.patch- Temporarily ignore broken OPENSSL_INIT_NO_ATEXIT due to our layered FIPS initialization (bsc#1161789) * openssl-fips-ignore_broken_atexit_test.patch- Import FIPS patches from SLE-15 * openssl-fips-dont_run_FIPS_module_installed.patch * openssl-fips_mode.patch * openssl-ship_fips_standalone_hmac.patch * openssl-fips-clearerror.patch * openssl-fips-selftests_in_nonfips_mode.patch- Don't run FIPS power-up self-tests when the checksum files aren't installed (bsc#1042392) * add openssl-fips-run_selftests_only_when_module_is_complete.patch- Import FIPS patches from Fedora (bsc#1157702, jsc#SLE-9553) * openssl-1.1.1-fips-crng-test.patch * openssl-1.1.1-fips-post-rand.patch * openssl-1.1.1-fips.patch * openssl-1.1.0-issuer-hash.patch * openssl-1.1.1-evp-kdf.patch * openssl-1.1.1-ssh-kdf.patch replaces openssl-jsc-SLE-8789-backport_KDF.patch - keep EVP_KDF functions at version 1.1.1d for backward compatibility * add openssl-keep_EVP_KDF_functions_version.patch- Support for CPACF enhancements - part 1 (crypto) [bsc#1152695, jsc#SLE-7861] - Add patches: * openssl-s390x-assembly-pack-add-OPENSSL_s390xcap-environment.patch * openssl-s390x-assembly-pack-add-support-for-pcc-and-kma-inst.patch * openssl-s390x-assembly-pack-add-OPENSSL_s390xcap-man-page.patch * openssl-s390x-assembly-pack-update-OPENSSL_s390xcap-3.patch * openssl-s390xcpuid.pl-fix-comment.patch * openssl-assembly-pack-accelerate-scalar-multiplication.patch * openssl-Enable-curve-spefific-ECDSA-implementations-via-EC_M.patch * openssl-s390x-assembly-pack-accelerate-ECDSA.patch * openssl-OPENSSL_s390xcap.pod-list-msa9-facility-bit-155.patch * openssl-s390x-assembly-pack-cleanse-only-sensitive-fields.patch * openssl-s390x-assembly-pack-fix-OPENSSL_s390xcap-z15-cpu-mas.patch * openssl-s390x-assembly-pack-fix-msa3-stfle-bit-detection.patch * openssl-Fix-9bf682f-which-broke-nistp224_method.patch- Obsolete libopenssl-1_0_0-devel and libopenssl-1_0_0-hmac in order to avoid conflict upon upgrade from SLE-12 (bsc#1158499)- Security fix: [bsc#1158809, CVE-2019-1551] * Overflow bug in the x64_64 Montgomery squaring procedure used in exponentiation with 512-bit moduli - Add openssl-1_1-CVE-2019-1551.patch- Fixed EVP_PBE_scrypt() to allow NULL salt values. * Revealed by nodejs12 during bsc#1149572. * Modified openssl-jsc-SLE-8789-backport_KDF.patch- Update to 1.1.1d (bsc#1133925, jsc#SLE-6430) * Fixed a fork protection issue. OpenSSL 1.1.1 introduced a rewritten random number generator (RNG). This was intended to include protection in the event of a fork() system call in order to ensure that the parent and child processes did not share the same RNG state. However this protection was not being used in the default case. (bsc#1150247, CVE-2019-1549) * Compute ECC cofactors if not provided during EC_GROUP construction. Before this change, EC_GROUP_set_generator would accept order and/or cofactor as NULL. After this change, only the cofactor parameter can be NULL. (bsc#1150003, CVE-2019-1547) * Fixed a padding oracle in PKCS7_dataDecode and CMS_decrypt_set1_pkey. (bsc#1150250, CVE-2019-1563) * For built-in EC curves, ensure an EC_GROUP built from the curve name is used even when parsing explicit parameters, when loading a serialized key or calling EC_GROUP_new_from_ecpkparameters()/EC_GROUP_new_from_ecparameters(). * Early start up entropy quality from the DEVRANDOM seed source has been improved for older Linux systems. * Changed DH_check to accept parameters with order q and 2q subgroups. With order 2q subgroups the bit 0 of the private key is not secret but DH_generate_key works around that by clearing bit 0 of the private key for those. This avoids leaking bit 0 of the private key. * Significantly reduce secure memory usage by the randomness pools. * Revert the DEVRANDOM_WAIT feature for Linux systems - drop 0001-build_SYS_str_reasons-Fix-a-crash-caused-by-overlong.patch (upstream) - refresh patches * openssl-1.1.0-no-html.patch * openssl-jsc-SLE-8789-backport_KDF.patch- To avoid seperate certification of openssh server / client move the SSH KDF (Key Derivation Function) into openssl. * jsc#SLE-8789 * Sourced from commit 8d76481b189b7195ef932e0fb8f0e23ab0120771#diff-a9562bc75317360a2e6b8b0748956e34 in openssl master (introduce the SSH KDF) and commit 5a285addbf39f91d567f95f04b2b41764127950d in openssl master (backport EVP/KDF API framework) * added openssl-jsc-SLE-8789-backport_KDF.patch- Upgrade to 1.1.1c (jsc#SLE-9135, bsc#1148799) * Support for TLSv1.3 added * Allow GNU style "make variables" to be used with Configure. * Add a STORE module (OSSL_STORE) * Claim the namespaces OSSL and OPENSSL, represented as symbol prefixes * Add multi-prime RSA (RFC 8017) support * Add SM3 implemented according to GB/T 32905-2016 * Add SM4 implemented according to GB/T 32907-2016. * Add 'Maximum Fragment Length' TLS extension negotiation and support * Add ARIA support * Add SHA3 * Rewrite of devcrypto engine * Add support for SipHash * Grand redesign of the OpenSSL random generator - drop FIPS support * don't build with FIPS mode (not supported in 1.1.1) - drop FIPS patches * openssl-fips-clearerror.patch * openssl-fips_disallow_ENGINE_loading.patch * openssl-fips-dont-fall-back-to-default-digest.patch * openssl-fips-dont_run_FIPS_module_installed.patch * openssl-fips-fix-odd-rsakeybits.patch * openssl-fips-rsagen-d-bits.patch * openssl-fips-selftests_in_nonfips_mode.patch * openssl-rsakeygen-minimum-distance.patch * openssl-1.1.0-fips.patch - add TLS 1.3 ciphers to DEFAULT_SUSE - merge openssl-1.0.1e-add-suse-default-cipher.patch and openssl-1.0.1e-add-test-suse-default-cipher-suite.patch to openssl-DEFAULT_SUSE_cipher.patch - Use upstream patch for the locale crash (bsc#1135550) * https://github.com/openssl/openssl/pull/8966 * add 0001-build_SYS_str_reasons-Fix-a-crash-caused-by-overlong.patch - drop patches (upstream): * openssl-Bleichenbachers_CAT.patch * openssl-CVE-2018-0734.patch * openssl-CVE-2018-0735.patch * openssl-CVE-2019-1543.patch * openssl-disable_rsa_keygen_tests_with_small_modulus.patch * openssl-dsa_paramgen2_check.patch * openssl-One_and_Done.patch * openssl-speed_skip_binary_curves_NO_EC2M.patch * openssl-static-deps.patch * openssl-urandom-reseeding.patch * 0001-Add-a-constant-time-flag-to-one-of-the-bignums-to-av.patch * 0001-Axe-builtin-printf-implementation-use-glibc-instead.patch * 0001-DSA-mod-inverse-fix.patch * 0001-Resume-reading-from-randfile-when-interrupted-by-a-s.patch * 0001-apps-speed-fix-segfault-while-looking-up-algorithm-n.patch - drop s390x patches (rebased): * 0002-s390x-assembly-pack-add-KMA-code-path-for-aes-ctr.patch * 0003-crypto-aes-asm-aes-s390x.pl-replace-decrypt-flag-by-.patch * 0004-s390x-assembly-pack-add-KMA-code-path-for-aes-gcm.patch * 0005-s390x-assembly-pack-add-KMAC-code-path-for-aes-ccm.patch * 0006-s390x-assembly-pack-add-KM-code-path-for-aes-ecb.patch * 0007-s390x-assembly-pack-add-KMO-code-path-for-aes-ofb.patch * 0008-s390x-assembly-pack-add-KMF-code-path-for-aes-cfb-cf.patch * 0009-Fix-undefined-behavior-in-s390x-aes-gcm-ccm.patch * 0001-crypto-poly1305-asm-poly1305-s390x.pl-add-vx-code-pa.patch * 0001-s390x-assembly-pack-extend-s390x-capability-vector.patch - add s390x patches: * 0001-s390x-assembly-pack-perlasm-support.patch * 0002-crypto-chacha-asm-chacha-s390x.pl-add-vx-code-path.patch * 0003-crypto-poly1305-asm-poly1305-s390x.pl-add-vx-code-pa.patch * 0004-s390x-assembly-pack-fix-formal-interface-bug-in-chac.patch * 0005-s390x-assembly-pack-import-chacha-from-cryptogams-re.patch * 0006-s390x-assembly-pack-import-poly-from-cryptogams-repo.patch- Fix segfault in openssl speed when an unknown algorithm is passed (bsc#1125494) * add 0001-apps-speed-fix-segfault-while-looking-up-algorithm-n.patch - Correctly skip binary curves in openssl speed to avoid spitting errors (bsc#1116833) * add openssl-speed_skip_binary_curves_NO_EC2M.patch- OpenSSL Security Advisory [6 March 2019] * Prevent long nonces in ChaCha20-Poly1305 (bsc#1128189, CVE-2019-1543) * add openssl-CVE-2019-1543.patch- Add s390x poly1305 vectorized implementation (fate#326351) * https://github.com/openssl/openssl/pull/7991 - add 0001-crypto-poly1305-asm-poly1305-s390x.pl-add-vx-code-pa.patch- Add vectorized chacha20 implementation for s390x (fate#326561) * https://github.com/openssl/openssl/pull/6919 - add patches: 0001-s390x-assembly-pack-perlasm-support.patch 0002-crypto-chacha-asm-chacha-s390x.pl-add-vx-code-path.patch- Replace fate#321518 s390x patches from closed pull request https://github.com/openssl/openssl/pull/2859 with patches from openssl git master (bsc#1122984) - add patches: 0001-s390x-assembly-pack-extend-s390x-capability-vector.patch 0002-s390x-assembly-pack-add-KMA-code-path-for-aes-ctr.patch 0003-crypto-aes-asm-aes-s390x.pl-replace-decrypt-flag-by-.patch 0004-s390x-assembly-pack-add-KMA-code-path-for-aes-gcm.patch 0005-s390x-assembly-pack-add-KMAC-code-path-for-aes-ccm.patch 0006-s390x-assembly-pack-add-KM-code-path-for-aes-ecb.patch 0007-s390x-assembly-pack-add-KMO-code-path-for-aes-ofb.patch 0008-s390x-assembly-pack-add-KMF-code-path-for-aes-cfb-cf.patch 0009-Fix-undefined-behavior-in-s390x-aes-gcm-ccm.patch - drop patches: 0002-crypto-modes-asm-ghash-s390x.pl-fix-gcm_gmult_4bit-K.patch 0004-s390x-assembly-pack-add-OPENSSL_s390xcap-environment.patch 0005-s390x-assembly-pack-add-OPENSSL_s390xcap-man-page.patch 0006-s390x-assembly-pack-extended-s390x-capability-vector.patch 0007-crypto-evp-e_aes.c-add-foundations-for-extended-s390.patch 0008-s390x-assembly-pack-extended-s390x-capability-vector.patch 0009-crypto-aes-asm-aes-s390x.pl-add-KMA-code-path.patch 0010-doc-man3-OPENSSL_s390xcap.pod-update-KMA.patch 0011-crypto-aes-asm-aes-s390x.pl-add-CFI-annotations-KMA-.patch 0012-s390x-assembly-pack-add-KMA-code-path-for-aes-gcm.patch 0013-crypto-aes-asm-aes-s390x.pl-add-CFI-annotations-KMA-.patch- Fix FIPS RSA generator (bsc#1118913) * import fixed openssl-1.1.0-fips.patch from Fedora * drop openssl-CVE-2018-0737-fips.patch which got merged into openssl-1.1.0-fips.patch * refresh openssl-fips-rsagen-d-bits.patch- The 9 Lives of Bleichenbacher's CAT: Cache ATtacks on TLS Implementations (bsc#1117951) * https://github.com/openssl/openssl/issues/7739 * add patch openssl-Bleichenbachers_CAT.patch- OpenSSL Security Advisory [30 October 2018] * Timing vulnerability in ECDSA signature generation (bsc#1113651, CVE-2018-0735) * Timing vulnerability in DSA signature generation (bsc#1113652, CVE-2018-0734) * And more timing fixes - Add patches: * openssl-CVE-2018-0734.patch * openssl-CVE-2018-0735.patch * 0001-DSA-mod-inverse-fix.patch * 0001-Add-a-constant-time-flag-to-one-of-the-bignums-to-av.patch- Obsolete libopenssl-1_0_0-devel by libopenssl-1_1-devel to avoid conflicts when updating from older distributions (bsc#1106180)- Fix infinite loop in DSA generation with incorrect parameters (bsc#1112209) * add openssl-dsa_paramgen2_check.patch- Fix One&Done side-channel attack on RSA (bsc#1104789) * add openssl-One_and_Done.patch- Update to 1.1.0i - Align with SLE-12-SP4 OpenSSL Security Advisory [12 June 2018] * Reject excessively large primes in DH key generation (bsc#1097158, CVE-2018-0732) * Make EVP_PKEY_asn1_new() a bit stricter about its input * Revert blinding in ECDSA sign and instead make problematic addition length-invariant. Switch even to fixed-length Montgomery multiplication. * Change generating and checking of primes so that the error rate of not being prime depends on the intended use based on the size of the input. * Increase the number of Miller-Rabin rounds for DSA key generating to 64. * Add blinding to ECDSA and DSA signatures to protect against side channel attacks * When unlocking a pass phrase protected PEM file or PKCS#8 container, we now allow empty (zero character) pass phrases. * Certificate time validation (X509_cmp_time) enforces stricter compliance with RFC 5280. Fractional seconds and timezone offsets are no longer allowed. * Fixed a text canonicalisation bug in CMS - drop patches (upstream): * 0001-Limit-scope-of-CN-name-constraints.patch * 0001-Revert-util-dofile.pl-only-quote-stuff-that-actually.patch * 0001-Tolerate-a-Certificate-using-a-non-supported-group-o.patch * 0002-Skip-CN-DNS-name-constraint-checks-when-not-needed.patch * openssl-add-blinding-to-dsa.patch * openssl-add-blinding-to-ecdsa.patch * openssl-CVE-2018-0732.patch - refresh patches: * openssl-1.1.0-fips.patch * openssl-disable_rsa_keygen_tests_with_small_modulus.patch - rename openssl-CVE-2018-0737.patch to openssl-CVE-2018-0737-fips.patch as it now only includes changes to the fips code- Add openssl(cli) Provide so the packages that require the openssl binary can require this instead of the new openssl meta package (bsc#1101470) - Don't Require openssl-1_1 from the devel package, just Recommend it- Suggest libopenssl1_1-hmac from libopenssl1_1 package to avoid dependency issues during updates (bsc#1090765)- Relax CN name restrictions (bsc#1084011) * added patches: 0001-Limit-scope-of-CN-name-constraints.patch 0002-Skip-CN-DNS-name-constraint-checks-when-not-needed.patch- Reject excessively large primes in DH key generation (bsc#1097158, CVE-2018-0732) * openssl-CVE-2018-0732.patch - blinding enhancements for ECDSA and DSA (bsc#1097624, bsc#1098592) * openssl-add-blinding-to-ecdsa.patch * openssl-add-blinding-to-dsa.patch- OpenSSL Security Advisory [16 Apr 2018] * Cache timing vulnerability in RSA Key Generation (CVE-2018-0737, bsc#1089039) * add openssl-CVE-2018-0737.patch- Fix escaping in c_rehash (boo#1091961, bsc#1091963) * add 0001-Revert-util-dofile.pl-only-quote-stuff-that-actually.patch- Tolerate a Certificate using a non-supported group on server side (boo#1084651) * https://github.com/openssl/openssl/pull/5607 * add 0001-Tolerate-a-Certificate-using-a-non-supported-group-o.patch- Update to 1.1.0h OpenSSL Security Advisory [27 Mar 2018] * Constructed ASN.1 types with a recursive definition could exceed the stack (CVE-2018-0739) (bsc#1087102) * rsaz_1024_mul_avx2 overflow bug on x86_64 (CVE-2017-3738) (bsc#1071906) - refresh patches: * 0001-Axe-builtin-printf-implementation-use-glibc-instead.patch * openssl-1.1.0-fips.patch * openssl-pkgconfig.patch * openssl-rsakeygen-minimum-distance.patch * openssl-static-deps.patch- Move the libopenssl1_1_0-32bit obsoletes in baselibs.conf to the new libopenssl1_1-32bit: it does not belong to the devel package.- Renamed from openssl-1_1_0 (bsc#1081335) * All the minor versions of the 1.1.x openssl branch have the same sonum and keep ABI compatibility * obsolete the 1_1_0 packages - update baselibs.conf with the new version names- Remove bit obsolete syntax - Use %license macro- Don't disable afalgeng on aarch64- Add support for s390x CPACF enhancements (fate#321518) patches taken from https://github.com/openssl/openssl/pull/2859: * 0002-crypto-modes-asm-ghash-s390x.pl-fix-gcm_gmult_4bit-K.patch * 0004-s390x-assembly-pack-add-OPENSSL_s390xcap-environment.patch * 0005-s390x-assembly-pack-add-OPENSSL_s390xcap-man-page.patch * 0006-s390x-assembly-pack-extended-s390x-capability-vector.patch * 0007-crypto-evp-e_aes.c-add-foundations-for-extended-s390.patch * 0008-s390x-assembly-pack-extended-s390x-capability-vector.patch * 0009-crypto-aes-asm-aes-s390x.pl-add-KMA-code-path.patch * 0010-doc-man3-OPENSSL_s390xcap.pod-update-KMA.patch * 0011-crypto-aes-asm-aes-s390x.pl-add-CFI-annotations-KMA-.patch * 0012-s390x-assembly-pack-add-KMA-code-path-for-aes-gcm.patch * 0013-crypto-aes-asm-aes-s390x.pl-add-CFI-annotations-KMA-.patch- Do not filter pkgconfig() provides/requires.- Obsolete openssl-1_0_0 by openssl-1_1_0: this is required for a clean upgrade path as an aid to zypp (boo#1070003).- Update to 1.1.0g OpenSSL Security Advisory [02 Nov 2017] * bn_sqrx8x_internal carry bug on x86_64 (CVE-2017-3736) (bsc#1066242) * Malformed X.509 IPAddressFamily could cause OOB read (CVE-2017-3735) (bsc#1056058) - drop 0001-Fix-a-TLSProxy-race-condition.patch (upstream) - refresh 0001-Axe-builtin-printf-implementation-use-glibc-instead.patch- update DEFAULT_SUSE cipher list (bsc#1055825) * add CHACHA20-POLY1305 * add ECDSA ciphers * remove 3DES - modified openssl-1.0.1e-add-suse-default-cipher.patch- do not require openssl1_1_0-targettype in devel-targettype, as it is not built (it has no libraries)- The description is supposed to describe the package, not the development process or history. (Synchronize with the already-updates descriptions in openssl-1_0_0.) - Update historic copypasted boilerplate summaries ("include files mandatory for development")- Disable the verbosity of the tests as we expose yet another race condition in that- Fix a race condition in tests to make the package build reliably * https://github.com/openssl/openssl/issues/3562 * 0001-Fix-a-TLSProxy-race-condition.patch- Add Provides and Conflicts for -devel package in baselibs.conf.- Add patch openssl-no-date.patch to disable date inclusion in most of the binaries - Use autopatch to make things smaller - Enable verbose output on the tests - Paralelize depmod- update to 1.1.0f * bugfix only release - disable RSA keygen tests, because they use too small modulus, which is rejected by our CC/FIPS hardening patches * added openssl-disable_rsa_keygen_tests_with_small_modulus.patch - refreshed openssl-rsakeygen-minimum-distance.patch and 0001-Axe-builtin-printf-implementation-use-glibc-instead.patch- Add conflict for any libopenssl-devel that is not in our version- Avoid the requires conflict between 1.1 and 1.0 openssl- Add conflict on docu packages- drop unnecessary README.SUSE- add openssl-1.1-fix-ppc64.patch from Marcus Meissner to fix build on ppc64- Fix build on aarch64- Remove libpadlock conditional, no longer present- Update baselibs.conf to contain all the renamed packages- re-enable tests on SLE-12 and below despite current failure, so they are automatically run once the issue is resolved- Filter out the pkgconfig provides to force usage of the main openssl package provides- disable tests on SLE-12 and its derivates * they fail because of glibc bug bsc#1035445 - remove README-FIPS.txt (outdated)- drop openssl-fipslocking.patch The locking in 1.1.0 has been rewritten and converted to the new threading API. The fips deadlock (at least bsc#991193) can't be reproduced anymore. - don't ship useless INSTALL* files- simplify openssl-fips-dont-fall-back-to-default-digest.patch The -non-fips-allow option was dropped in OpenSSL 1.1.0 - drop openssl-no-egd.patch as OpenSSL 1.1.0 disables EGD at compile time by default - renumber the patches so the numbers are consequent- Update showciphers.c to work with new openssl- Add patch openssl-static-deps.patch to allow dependencies on statically build libraries - Refresh openssl-1-1.0-fips.patch to take in use the above approach - Silence the install manpage rename phase- Start update to 1.1.0e basing of the 1.0.0 split release - Drop patch merge_from_0.9.8k.patch the ppc64 should work out of the box - Drop patch openssl-engines-path.patch converted to configure option - Drop patch openssl-1.0.2a-padlock64.patch code behind was redone does not apply at all - Drop patch openssl-fix-pod-syntax.diff mostly merged upstream or not applicable - Drop patch compression_methods_switch.patch as we do not need to keep the compat on this release anymore - Drop patch openssl-1.0.2a-ipv6-apps.patch which was upstreamed - Drop upstreamed patch openssl-1.0.2a-default-paths.patch - Drop obsolete patch openssl-1.0.0-c_rehash-compat.diff - Drop obsolete patch openssl-missing_FIPS_ec_group_new_by_curve_name.patch - Drop obsolete patch openssl-print_notice-NULL_crash.patch - Drop obsolete patch openssl-randfile_fread_interrupt.patch - Refresh patch openssl-truststore.patch - Refresh baselibs.conf to correctly reflect soname - Add patch openssl-1.1.0-fips.patch obsoleting bunch of older: * openssl-1.0.2i-fips.patch * openssl-1.0.2a-fips-ec.patch * openssl-1.0.2a-fips-ctor.patch * openssl-1.0.2i-new-fips-reqs.patch * openssl-fips_disallow_x931_rand_method.patch - Add new patch for upstream: * 0001-Resume-reading-from-randfile-when-interrupted-by-a-s.patch - Refresh patch openssl-pkgconfig.patch - Drop patch openssl-gcc-attributes.patch as the code was redone - Rebase patch 0001-Axe-builtin-printf-implementation-use-glibc-instead.patch - Rebase patch openssl-no-egd.patch - Rebase patch openssl-1.0.1e-add-suse-default-cipher.patch and openssl-1.0.1e-add-test-suse-default-cipher-suite.patch - Rebase patch openssl-fips_disallow_ENGINE_loading.patch - Rebase patch openssl-urandom-reseeding.patch - Rebase patch openssl-fips-rsagen-d-bits.patch - Rebase patch openssl-fips-selftests_in_nonfips_mode.patch - Remove switch for ssl2 - no longer present - Remve the buildinf.h parsing, should no longer be needed - Drop the rehash in build, no longer needed - Drop openssl-fips-hidden.patch as it is not really needed - Do not sed in secure_getenv upstream does it in code on their own - Do not install html converted manpages * openssl-1.1.0-no-html.patch- Drop the symbol hiding patches to ease maintenance updates: * 0005-libssl-Hide-library-private-symbols.patch * 0001-libcrypto-Hide-library-private-symbols.patch- Add new patch for engines folders to allow co-installation * openssl-engines-path.patch- Drop openssl-ocloexec.patch as it causes additional maintenance burden we would like to avoid- Drop bug610223.patch as we moved to libdir- Move check to %check phase - Split showciphers to separate file- Move openssl to /usr/lib64 from /lib64- Remove some of the DSO setting code that is not needed - Fix the showciphers binary- Rename to openssl-1_0_0 to allow instalation of multiple versions- Remove O3 from optflags, no need to not rely on distro wide settings - Remove conditions for sle10 and sle11, we care only about sle12+ - USE SUSE instead of SuSE in readme - Pass over with spec-cleaner- fix X509_CERT_FILE path (bsc#1022271) and rename updated openssl-1.0.1e-truststore.diff to openssl-truststore.patch- Updated to openssl 1.0.2k - bsc#1009528 / CVE-2016-7055: openssl: Montgomery multiplication may produce incorrect results - bsc#1019334 / CVE-2016-7056: openssl: ECSDA P-256 timing attack key recovery - bsc#1022085 / CVE-2017-3731: openssl: Truncated packet could crash via OOB read - bsc#1022086 / CVE-2017-3732: openssl: BN_mod_exp may produce incorrect results on x86_64- resume reading from /dev/urandom when interrupted by a signal (bsc#995075) * add openssl-randfile_fread_interrupt.patch- add FIPS changes from SP2: - fix problems with locking in FIPS mode (bsc#992120) * duplicates: bsc#991877, bsc#991193, bsc#990392, bsc#990428 and bsc#990207 * bring back openssl-fipslocking.patch - drop openssl-fips_RSA_compute_d_with_lcm.patch (upstream) (bsc#984323) - don't check for /etc/system-fips (bsc#982268) * add openssl-fips-dont_run_FIPS_module_installed.patch - refresh openssl-fips-rsagen-d-bits.patch- update to openssl-1.0.2j * Missing CRL sanity check (CVE-2016-7052 bsc#1001148)- OpenSSL Security Advisory [22 Sep 2016] (bsc#999665) Severity: High * OCSP Status Request extension unbounded memory growth (CVE-2016-6304) (bsc#999666) Severity: Low * Pointer arithmetic undefined behaviour (CVE-2016-2177) (bsc#982575) * Constant time flag not preserved in DSA signing (CVE-2016-2178) (bsc#983249) * DTLS buffered message DoS (CVE-2016-2179) (bsc#994844) * OOB read in TS_OBJ_print_bio() (CVE-2016-2180) (bsc#990419) * DTLS replay protection DoS (CVE-2016-2181) (bsc#994749) * OOB write in BN_bn2dec() (CVE-2016-2182) (bsc#993819) * Birthday attack against 64-bit block ciphers (SWEET32) (CVE-2016-2183) (bsc#995359) * Malformed SHA512 ticket DoS (CVE-2016-6302) (bsc#995324) * OOB write in MDC2_Update() (CVE-2016-6303) (bsc#995377) * Certificate message OOB reads (CVE-2016-6306) (bsc#999668) - update to openssl-1.0.2i * remove patches: openssl-1.0.2a-new-fips-reqs.patch openssl-1.0.2e-fips.patch * add patches: openssl-1.0.2i-fips.patch openssl-1.0.2i-new-fips-reqs.patch- fix crash in print_notice (bsc#998190) * add openssl-print_notice-NULL_crash.patch- OpenSSL Security Advisory [3rd May 2016] - update to 1.0.2h (boo#977584, boo#977663) * Prevent padding oracle in AES-NI CBC MAC check A MITM attacker can use a padding oracle attack to decrypt traffic when the connection uses an AES CBC cipher and the server support AES-NI. (CVE-2016-2107, boo#977616) * Fix EVP_EncodeUpdate overflow An overflow can occur in the EVP_EncodeUpdate() function which is used for Base64 encoding of binary data. If an attacker is able to supply very large amounts of input data then a length check can overflow resulting in a heap corruption. (CVE-2016-2105, boo#977614) * Fix EVP_EncryptUpdate overflow An overflow can occur in the EVP_EncryptUpdate() function. If an attacker is able to supply very large amounts of input data after a previous call to EVP_EncryptUpdate() with a partial block then a length check can overflow resulting in a heap corruption. (CVE-2016-2106, boo#977615) * Prevent ASN.1 BIO excessive memory allocation When ASN.1 data is read from a BIO using functions such as d2i_CMS_bio() a short invalid encoding can casuse allocation of large amounts of memory potentially consuming excessive resources or exhausting memory. (CVE-2016-2109, boo#976942) * EBCDIC overread ASN1 Strings that are over 1024 bytes can cause an overread in applications using the X509_NAME_oneline() function on EBCDIC systems. This could result in arbitrary stack data being returned in the buffer. (CVE-2016-2176, boo#978224) * Modify behavior of ALPN to invoke callback after SNI/servername callback, such that updates to the SSL_CTX affect ALPN. * Remove LOW from the DEFAULT cipher list. This removes singles DES from the default. * Only remove the SSLv2 methods with the no-ssl2-method option. When the methods are enabled and ssl2 is disabled the methods return NULL.- Remove a hack for bsc#936563 - Drop bsc936563_hack.patch- import fips patches from SLE-12 * openssl-fips-clearerror.patch * openssl-fips-dont-fall-back-to-default-digest.patch * openssl-fips-fix-odd-rsakeybits.patch * openssl-fips-rsagen-d-bits.patch * openssl-fips-selftests_in_nonfips_mode.patch * openssl-fips_RSA_compute_d_with_lcm.patch * openssl-fips_disallow_ENGINE_loading.patch * openssl-fips_disallow_x931_rand_method.patch * openssl-rsakeygen-minimum-distance.patch * openssl-urandom-reseeding.patch- add support for "ciphers" providing no encryption (bsc#937085) * don't build with -DSSL_FORBID_ENULL- update to 1.0.2g (bsc#968044) * Disable weak ciphers in SSLv3 and up in default builds of OpenSSL. Builds that are not configured with "enable-weak-ssl-ciphers" will not provide any "EXPORT" or "LOW" strength ciphers. * Disable SSLv2 default build, default negotiation and weak ciphers. SSLv2 is by default disabled at build-time. Builds that are not configured with "enable-ssl2" will not support SSLv2. Even if "enable-ssl2" is used, users who want to negotiate SSLv2 via the version-flexible SSLv23_method() will need to explicitly call either of: SSL_CTX_clear_options(ctx, SSL_OP_NO_SSLv2); or SSL_clear_options(ssl, SSL_OP_NO_SSLv2); (CVE-2016-0800) * Fix a double-free in DSA code (CVE-2016-0705) * Disable SRP fake user seed to address a server memory leak. Add a new method SRP_VBASE_get1_by_user that handles the seed properly. (CVE-2016-0798) * Fix BN_hex2bn/BN_dec2bn NULL pointer deref/heap corruption (CVE-2016-0797) * ) Side channel attack on modular exponentiation http://cachebleed.info. (CVE-2016-0702) * ) Change the req app to generate a 2048-bit RSA/DSA key by default, if no keysize is specified with default_bits. This fixes an omission in an earlier change that changed all RSA/DSA key generation apps to use 2048 bits by default.- update to 1.0.2f (boo#963410) * ) DH small subgroups (boo#963413) Historically OpenSSL only ever generated DH parameters based on "safe" primes. More recently (in version 1.0.2) support was provided for generating X9.42 style parameter files such as those required for RFC 5114 support. The primes used in such files may not be "safe". Where an application is using DH configured with parameters based on primes that are not "safe" then an attacker could use this fact to find a peer's private DH exponent. This attack requires that the attacker complete multiple handshakes in which the peer uses the same private DH exponent. For example this could be used to discover a TLS server's private DH exponent if it's reusing the private DH exponent or it's using a static DH ciphersuite. (CVE-2016-0701) * ) SSLv2 doesn't block disabled ciphers (boo#963415) A malicious client can negotiate SSLv2 ciphers that have been disabled on the server and complete SSLv2 handshakes even if all SSLv2 ciphers have been disabled, provided that the SSLv2 protocol was not also disabled via SSL_OP_NO_SSLv2. (CVE-2015-3197) * ) Reject DH handshakes with parameters shorter than 1024 bits.- update to 1.0.2e * fixes five security vulnerabilities * Anon DH ServerKeyExchange with 0 p parameter (CVE-2015-1794) (bsc#957984) * BN_mod_exp may produce incorrect results on x86_64 (CVE-2015-3193) (bsc#957814) * Certificate verify crash with missing PSS parameter (CVE-2015-3194) (bsc#957815) * X509_ATTRIBUTE memory leak (CVE-2015-3195) (bsc#957812) * Race condition handling PSK identify hint (CVE-2015-3196) (bsc#957813) - pulled a refreshed fips patch from Fedora * openssl-1.0.2a-fips.patch was replaced by openssl-1.0.2e-fips.patch - refresh openssl-ocloexec.patch- update to 1.0.2d * fixes CVE-2015-1793 (bsc#936746) Alternate chains certificate forgery During certificate verfification, OpenSSL will attempt to find an alternative certificate chain if the first attempt to build such a chain fails. An error in the implementation of this logic can mean that an attacker could cause certain checks on untrusted certificates to be bypassed, such as the CA flag, enabling them to use a valid leaf certificate to act as a CA and "issue" an invalid certificate. - drop openssl-fix_invalid_manpage_name.patch (upstream)- Workaround debugit crash on ppc64le with gcc5 bsc936563_hack.patch (bsc#936563)- update merge_from_0.9.8k.patch replacing __LP64__ by __LP64 this is a change versus previous request 309611 required to avoid build error for ppc64- Build with no-ssl3, for details on why this is needed read rfc7568. Contrary to the "no-ssl2" option, this does not require us to patch dependant packages as the relevant functions are still available (SSLv3_(client|server)_method) but will fail to negotiate. if removing SSL3 methods is desired at a later time, option "no-ssl3-method" needs to be used.- update to 1.0.2c * Fix HMAC ABI incompatibility - refreshed openssl-1.0.2a-fips.patch- update to 1.0.2b * Malformed ECParameters causes infinite loop (CVE-2015-1788) * Exploitable out-of-bounds read in X509_cmp_time (CVE-2015-1789) * PKCS7 crash with missing EnvelopedContent (CVE-2015-1790) * CMS verify infinite loop with unknown hash function (CVE-2015-1792) * Race condition handling NewSessionTicket (CVE-2015-1791) - refreshed patches: * 0001-Axe-builtin-printf-implementation-use-glibc-instead.patch * 0001-libcrypto-Hide-library-private-symbols.patch * openssl-1.0.2a-default-paths.patch * openssl-1.0.2a-fips.patch * compression_methods_switch.patch * openssl-1.0.1e-add-test-suse-default-cipher-suite.patch- update to 1.0.2a * Major changes since 1.0.1: - Suite B support for TLS 1.2 and DTLS 1.2 - Support for DTLS 1.2 - TLS automatic EC curve selection. - API to set TLS supported signature algorithms and curves - SSL_CONF configuration API. - TLS Brainpool support. - ALPN support. - CMS support for RSA-PSS, RSA-OAEP, ECDH and X9.42 DH. - packaging changes: * merged patches modifying CIPHER_LIST into one, dropping: - openssl-1.0.1e-add-suse-default-cipher-header.patch - openssl-libssl-noweakciphers.patch * fix a manpage with invalid name - added openssl-fix_invalid_manpage_name.patch * remove a missing fips function - openssl-missing_FIPS_ec_group_new_by_curve_name.patch * reimported patches from Fedora dropped patches: - openssl-1.0.1c-default-paths.patch - openssl-1.0.1c-ipv6-apps.patch - openssl-1.0.1e-fips-ctor.patch - openssl-1.0.1e-fips-ec.patch - openssl-1.0.1e-fips.patch - openssl-1.0.1e-new-fips-reqs.patch - VIA_padlock_support_on_64systems.patch added patches: - openssl-1.0.2a-default-paths.patch - openssl-1.0.2a-fips-ctor.patch - openssl-1.0.2a-fips-ec.patch - openssl-1.0.2a-fips.patch - openssl-1.0.2a-ipv6-apps.patch - openssl-1.0.2a-new-fips-reqs.patch - openssl-1.0.2a-padlock64.patch * dropped security fixes (upstream) - openssl-CVE-2015-0209.patch - openssl-CVE-2015-0286.patch - openssl-CVE-2015-0287.patch - openssl-CVE-2015-0288.patch - openssl-CVE-2015-0289.patch - openssl-CVE-2015-0293.patch * upstream reformatted the sources, so all the patches have to be refreshed- security update: * CVE-2015-0209 (bnc#919648) - Fix a failure to NULL a pointer freed on error * CVE-2015-0286 (bnc#922496) - Segmentation fault in ASN1_TYPE_cmp * CVE-2015-0287 (bnc#922499) - ASN.1 structure reuse memory corruption * CVE-2015-0288 x509: (bnc#920236) - added missing public key is not NULL check * CVE-2015-0289 (bnc#922500) - PKCS7 NULL pointer dereferences * CVE-2015-0293 (bnc#922488) - Fix reachable assert in SSLv2 servers * added patches: openssl-CVE-2015-0209.patch openssl-CVE-2015-0286.patch openssl-CVE-2015-0287.patch openssl-CVE-2015-0288.patch openssl-CVE-2015-0289.patch openssl-CVE-2015-0293.patch- The DATE stamp moved from crypto/Makefile to crypto/buildinf.h, replace it there (bsc#915947)- openssl 1.0.1k release bsc#912294 CVE-2014-3571: Fix DTLS segmentation fault in dtls1_get_record. bsc#912292 CVE-2015-0206: Fix DTLS memory leak in dtls1_buffer_record. bsc#911399 CVE-2014-3569: Fix issue where no-ssl3 configuration sets method to NULL. bsc#912015 CVE-2014-3572: Abort handshake if server key exchange message is omitted for ephemeral ECDH ciphersuites. bsc#912014 CVE-2015-0204: Remove non-export ephemeral RSA code on client and server. bsc#912293 CVE-2015-0205: Fixed issue where DH client certificates are accepted without verification. bsc#912018 CVE-2014-8275: Fix various certificate fingerprint issues. bsc#912296 CVE-2014-3570: Correct Bignum squaring. and other bugfixes. - openssl.keyring: use Matt Caswells current key. pub 2048R/0E604491 2013-04-30 uid Matt Caswell uid Matt Caswell sub 2048R/E3C21B70 2013-04-30 - openssl-1.0.1e-fips.patch: rediffed - openssl-1.0.1i-noec2m-fix.patch: removed (upstream) - openssl-ocloexec.patch: rediffed- suse_version 10.1 & 10.2 x86_64 can not enable-ec_nistp_64_gcc_128- openssl-1.0.1i-noec2m-fix.patch: only report the Elliptic Curves we actually support (not the binary ones) (bnc#905037)- openSUSE < 11.2 doesn't have accept4()- openSSL 1.0.1j * Fix SRTP Memory Leak (CVE-2014-3513) * Session Ticket Memory Leak (CVE-2014-3567) * Add SSL 3.0 Fallback protection (TLS_FALLBACK_SCSV) * Build option no-ssl3 is incomplete (CVE-2014-3568)libopenssl-1_0_0-devellibopenssl-1_1_0-develh01-ch2d 1707134917  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqr1.1.1l-150400.7.63.11.1.1l-150400.7.63.11.1.1l1.1.1l1.1.1lopensslaes.hasn1.hasn1_mac.hasn1err.hasn1t.hasync.hasyncerr.hbio.hbioerr.hblowfish.hbn.hbnerr.hbuffer.hbuffererr.hcamellia.hcast.hcmac.hcms.hcmserr.hcomp.hcomperr.hconf.hconf_api.hconferr.hcrypto.hcryptoerr.hct.hcterr.hdes.hdh.hdherr.hdsa.hdsaerr.hdtls1.he_os2.hebcdic.hec.hecdh.hecdsa.hecerr.hengine.hengineerr.herr.hevp.hevperr.hfips.hfips_rand.hfips_sli.hhmac.hidea.hkdf.hkdferr.hlhash.hmd2.hmd4.hmd5.hmdc2.hmodes.hobj_mac.hobjects.hobjectserr.hocsp.hocsperr.hopensslconf.hopensslv.hossl_typ.hpem.hpem2.hpemerr.hpkcs12.hpkcs12err.hpkcs7.hpkcs7err.hrand.hrand_drbg.hranderr.hrc2.hrc4.hrc5.hripemd.hrsa.hrsaerr.hsafestack.hseed.hsha.hsrp.hsrtp.hssl.hssl2.hssl3.hsslerr.hstack.hstore.hstoreerr.hsymhacks.htls1.hts.htserr.htxt_db.hui.huierr.hwhrlpool.hx509.hx509_vfy.hx509err.hx509v3.hx509v3err.hssllibcrypto.solibssl.solibcrypto.pclibssl.pcopenssl.pc/usr/include//usr/include/openssl//usr/lib64//usr/lib64/pkgconfig/-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:32465/SUSE_SLE-15-SP4_Update/6f3266c83589823fbf41c9177b2493ac-openssl-1_1.SUSE_SLE-15-SP4_Updatedrpmxz5x86_64-suse-linuxdirectoryC source, ASCII textASCII textpkgconfig filePRPRRPRRRֻzopenssl-1_11.1.1lutf-8aa5e4d826def8953e769ec2583699d33508378d04138acf565c1370b80934c8f?7zXZ !t/+ʩ]"k%AK4"c3i4'*VNxF=YĠw\?HX=@Ka;B(,Kw0brb^qsSǹp\7qE:y#’F= 80>^ڲ<(ul~"'eoCx~zi^ #eg:"V>E:6GgGʋ86'‹ܙ~1*Wr&o)^_k&K*o8D^4!yIK#Dk[0\W(-1yֺW'bY4~N=Jn{_jg8\%Pp^nr!<4硄,`n۱<Rێ2LHw`S&3n ^ѐ)C N8hBcI<٥ ZcIU4>ܞ$j[: t(Г^@py%FX)K xcY C|T{lQC\F?z^*o ܏dS, vRPfi޲(]E&qv D][g]6p-~RJ,# f@o#Lq&^a~sib |~ߔa NXja/Zɜ y@gANi]|[/> hxp 2޷$O4N`i޺aH^=bS!'KGod*BBABu`۝/nD?uVY\vG;IވO}K]WgSY_WJad2&> #QчrSf2%r9ZlB7%:/nHOWme$ l*mb&$Iٙ7 녅XT<n R{P($1h\/JFg^k+9x0FM0VJ~NA|Bx|&2vxZDsABUyHO]&<"0O}sGc=?>H c/QPhI˽ʐ܃GeBRFvfñȂSbZ0>^#D3g,ZP]5BdCS-pF?]B*c>s)ܗ.ByJ&s720,0OxUfk pI7Ƕa܇H5wSZ͌\Jj/0l/e 7ldEf_.w=7wLw=Oɪ{ k:~dlhԿ~8RxxfM}\eE[rn|.Ko]7~L@Q5^Stox h5vA1WPXh~4#hL+\"2YeFHX)O'b/PfD, &iaiA!_3w16(;=) IahּU*6]xSc.w 8A4w%^@Ǭ}e PYVarsfQu aGd$J< MkJYz9t;,^MW!+߇Jn§,n(Eg ;7|?E ՖAJkYRёYן~*[ƚ;e Eead?w+B˘!2[sVx؎0S*em:+ Q!Qa+Eι Q*!Iy \Ou6+ڠ 3V n.m'94i%< ޤǖkOXme2oKNYrضI3Udӆ>U]TxwӤg=]D2xt훘ŚwO$xU^%^1YWΥb'ӫ'F췋ODj$_H<((Xƭ{$?1=bK\W2Xך0(h@Un/Yq[[NE1OzSmen''Iހ.y NfBR(5%{.I ?-})y~鮲4+;L-=ɤEd {{(BS0Ki|rՃ)ʐ!?s  9$rfl(^5fbģ 3CeGv]gFyQ$)e@Λp 1j_QPU$Jزþ4gB<̐j*0i8Ȱ\,p@*e?]a +РחW6Clvz㧒]kb EZ[9+Y~`Ab.h  @K2Dƿao0$ɗ]gxqDeX5ڢRdVV5u˯AؿxLr UP+2PPB0ڞ*̚7ɭ 48aJ落],/MXK3z.s5w3KiZzun y,"5'dѸ?NpYk' WqJY"0.y PC*!kz/P?f`S\$G(uΎrX*2\u}m;qO˖mO|^4{|~x S%!sC?!hQڝ&:i1wPo&ݸs[-=M Yԏs~*ZpAhhk>6LBF!E`~1rWl/׬O9ж̚AU-瑶y#!3G,6pSωl!59,b!cXfTƣ *^صi" }YUVoUUcrU:n_O|Y~=#;p'njp 4o'zeL.z:=r]gQ]DΪ W{),+'.juC^pnl^ju-n2?.+eQ8k2 ǹ <?P'v|~"SuG{EH<+ij1^Йz.Lz뽿58*'Z*X'pA$ʆ R v 6$v8b:USՑfQpC t!}cr{WbimJϿ&7t ֛T_/%:Jie%>7 n1f#hmIZ K"ZL<\%mFvsfd7Y*n}lH' X%ϱէKZv\:;.?|AAOq9_dtn7pYeEf_Gpa/h$(V5NnX_[N3%Ua)y35St 5Uj\)+AzZRK HpEY8ֱk;V oImOm(U6'FRW3̜H6}uUYpuP'b1 +/f cw` /YYh#8:C]tX[,ʸFkw Sٲz'u/yA g#xF;h}v&0Q=!c޹-YzqP$}c>㲶 -p8[,Bh X矘Vt QзVD]|9f?s<#,arχ3ӵہʎqуpiG_XkTĺE <74Mfh_H7a.[&M%?Xk_܉bi~|Q)^kυpW1e|_ʬ8q1T5Q۩=4ok E;anǬf$Ak(7<1pU~B J(2,0U"•|Rqgʾro\]13' XV /%;LV>FkyCTTr"v[(ⶳа˿TGV E34|9yi1I"ad y.]^uWċ^f-6t5˺hƴ*$3c:0[N)"!?C ' KmQCtJ7Y`{U@-ū\WBnG0.-nċ^W/ȱ,$!3@EÏǶpp" شP_Qt†v44w >t /i|R{q{ڜ}w@ѝ󀙰Cw#UzQDWqc6HX/ Knr>r>< 70F\yy$wF)!sW_tER)fnJe~iSz mejkzUCxC`%u(TTD_\YIep LNIuP9xsHm h^",]gݞ>O%{D~Z5ALz{,yg^c[ǚc-}ފA ?5K6$g$y(D^[(.\G.e \n`Ad' 1fth6`L:ARA j!E!R0n_:j*Ej,7=&hK匃4K^"QϳbWwiOt:ƵR\`%3eSv Yyzf20^4ROɥ&>dס No6ts]ފcTph?\~Kwp=ε_\&R2c?M2;vлuge"5-Iv鶦 +⍭;xM#aa [Ɣ4) ,ڗ˃.>:*EnsEsx>gJ =X~\zr!A= ]Ūp_QR6%NƸw~:iY1뉿>bKURίeL%S n: +]b&` YT0N+)=`A|jjz#I $.$0$Xuts͹pEjzሹ ˪& ɉ-unyZgu7%bp\飪CN 92)0Y*C8‚!8]t! Ӑpmqɟ?&Ki!TBM9*#1 4ÚN4c#4A4~_e (2wgY.!-&6DfӺj(HsN9]PORW;RQ~\N p[XnF.pGNM<ƺ|(,A R\u_s/JljՄx}%# .B:P|A`;a»ݚ7tUKy -,Ȝ;VNg<ƐCTo\O> %q2ZW/*n$xr| 2 t 0雿0( wO7%[%N}3wdT 8;bbs`]07V%)#ET"/8 غi#/1 蜾p`aH?e, 1pO[U6 S?םVƀ+b͜]X59X 8?ndWvzl=F!,l5ss~s@B|aZ^Pͺ(q^XBa!vjB`4<)#tД %nGD#WS3Yʺ(и(eqs@Td5z"^s +z F$\T*M 뉨{V'MIRQGS||ϱwߣ=At jƬ5O[ՊiGк3Y.5qcLU5?@eqv>-`@L$6HfЀJ۱o0h~[~QQz>o^jp8kl,nH6yJdls68@e4o˦' 70* oJzǏ;^5L-1z0f?'>^Y@^Ki}<\_M͠!N9 %;N|8HŽl{ou%h] 1No({KiMuLNiaʼn~-xm$=c, pg=M (Җ}7Ěצvl@ vcJj95Qrեplzw.d _g^Pન5ohEJfp;n s%| ^.gf3X Y l|\NcIhQ#(5s#a< ":s] 8ʇe,67'2D1fLS!;ܼ\f&4N"C4 !82Ǝv$LKVz/&[3qp/..YWEqYj> l:L% ہ l *Ql3;J_k^z.`S+­fLazIC$gH1_u<TxY" ڦ0ݐÏ& 5)$Jg'`m o:N 191ꑁe(*ðK"nj3*r{e#q|L>XUMj@~*[nacNFucd^zn菱m1၊QQ}{TfϐI+dQX@ ` c79}ԇ};P2YK4g.FK7t‰τ1Ϧ/CÖ_'.k~*ƭ-@^Yl+vF'gȉ r+V4%%z֭#?$_z{: rRSA&ZIX.>oSUzOrd\Hqe3w:0ȾUvyoEh'$9Y}KfVd UG/ߖ.v獐 W H?uiuU^Ɗ ZOgtYeWI7i"s-!%w`01B3Kv[{]H.Y!kPzHmg`a4L穈s RF%~Lp7XF.,u82^YAc(>#UA3w#gY{6f@+5WK"MIOgC.Uևtɫc7Qj:8Ɠnkk gp3(vZWmlZboɢS(yE DynrNAZ5ߥOkĴWRS?&'*kD[Ѣ/~9d͙"Xwz9/ԝ䲽dJ]koHn){ۋA& [ uÍz;Ə0߷1'yƒٙv;dAMTR(sp&-h?ۀMk5pZq/3i*“5ĕT,Q}M[$گwBOw>dK9C\(BdINYY@ $ H:UTN 0M8A0mp®;4ѥ3?n37w53k<0%b ʿWW0v &e&A @z'VAAԠ]{rK!r\jC3ϟt7hhjwƩR떧$]Jt@y<Q "2k3-؋)+^V"& wJȅ@ = H@ p/#15]l8K|}ffIa'_mPMυ5+\N ]eM-`ﯶsq#~[E&_ׄqz€m ,Cj?7ʮpM~3j$I)^RK@`K9x6 fc=Q1:uAyE%p(\1=JX 0SY[;0b>B5]A*}T:@a.?+DcnSgҢH҇P{tᑍdt V% VlC|jBKvչ`o9gT@dޮLH{Iғ2aG4{ Me?倇v%=);͕*GX!͏/%%Ԯ'=۽VXL<>jvR0aREJD^ "Փ>%|Y~eqWK6q]$ۍ-u-ud]P"Q6®ԑD[laOF hI&T,wa2Ƃ[p40Ca(9hm7~`:; Wo9i@?RjH3T A[nNӶ0+Jay[4hsLqE$EM]~kY OiQ#'Aa:h?q?=Pw =*/zm#/Ya#w92,ZCe*”C)Y>( ] 5n}#V*}1*2^nJ=L-mн]//;ӛ ITy* E%fɨ9 r]w7m kqW9_З(x^yRj24隽Roo\K \V4;UkxRG8Fq֩8~/-}>pLϒ8züoJMW?ɦ1try]\#Cv$f8 O2Q:^jHE̪!A 3}O&a^p;8Fa\Ӄ:DWCX\%94ޚ4J3DX}4#a*&J=f-J5*Xן :) WT]cV% S%%kb#t@8!LzNA"5AA5ۉF B|ʴnu{ޥ^[#^#*|;YV򷨉Ɯ\%_"l_KكW+qg~Ę:妐5w~X#DlE\րPx%`v .2XULb, Nvlo"YΩzSltu>AC`J2zȚ;2<'nȆI8BE͉oM>S CzURM55Y}SW-? k  ђwR˖ iG7GE,U_|12/Ҳ'$tB]BJ$Ec};2ΫDTH{I07섭_{h0%Cy/QcIZ}ξ04G'oΡG 9]ʡh1.!Dm*9 `G~DIq=q_%*k9,_cPuB(ѷ3ˇQIvU4gZt"V fRnD7 QLvbGz9D-1㦨x9x,ޡ;gQJ@I ?wDisY%:+ ^d7.o>H+@A@#i\By1GpbsV;)haG>$?I|^ >hgFWjR!5;?,UEdI>G54T>N&0-!|$ţ]1gѯ'ׁq=a ¸a`<7of%UߊmjɫH53/z"}{G ?pA[<x,ͳ`CF0ĩ1kH_UMō02g rLchM3z'2ZpzL7ȬhS4-= POsàGצiF,53h!dVQذQ%=k OvYY9,k#xt͚ٝ*Ju~tpމg(7lNGfZ$u oJhm˹{%* i_E͆(hYF吂T,F0p (-ܛNxf+@lְk0'^F쯃ҽɗܟdK 4nዎ .Xh*/pWT-]Бo<"~P.@ F}rGsLəj1Y۫phЦo :٢?Nx F$"5MͲ(EEWd/)á^NUkBTXIO2frjf ſYE=N߽'{rCWV%i dBo?f삇IZg# !>uR·\"vI+Vq!ЅV=K։YL_3M3A.8nRtcReqp_Kbϩq85Q DY'08L=^AzfԔ 7V$e90&[q :D)zM/ehrgH#=1HqJFw1zpѝ? =IU>m^" A,v5/ h3/jG$b UcP \-B֘ɃzݡZKx"m(J"e@>72G鑊7Zl*ѵ-UM.߄C+ûd3Jlt߄erc=#8-WPYvhm\JV2:v/x[hstkoí]}P6˟9jo-LWx||]ب,5iNX$r5gfy3ؤD_/1cJ< $?|"0f&C+{9v]7g4,eV\}cB.eguꣴvˣJ.l?-P|(2YTB'r~Tu xeg"^2szr |;Q AsRyt+1N;jl3X.aaW=O2xz FԬGPw["U.ևvTEa#꧱&FTj̽#K;b;* {7C_+dBV.U0IH\ahX[3+?L)N}<2) cFl5zB}}lGJWDv躩j.'?qP,k6@egwtf4_jgModWh%x?BX4c^tIqj gk *vo7x:8j+.U9V&`aM6XImL$Yy|q\v~$yotI~2$Z`0]ѢC:2(hWe?{( ~X;Ӈ/aX:T<>Rd7Р0=IU4ۇ^wCw -mCsXY7ˣlT:g1jڦ Y4~=6o5lla1W?ĂʄTTe~պv)l pfj˜;+%l=wвLI8O-.R -J6=쓮Igw[ܷl;S„%!&hqb,q#."E֎-n@֕jrEJ}gxBA͛ih}CE iBel.8;ݢJG:Md#g 7Uy+ީ)E*&ZSu*n«*re8P6ߘt+ݍ5UmY!/j]eu\jؽxVp80#lX1I%X~&r;5R 3M;Z1mN1II7\kezLi?xXخϏqS$Z6we5(xT]!ahQeiUsP2O^8S|`Z\8卿nHQԆJ4J9<yRQT;Z۶~o[99h3,"կLI4gj,̐?tUfT# ѷB( OǒC"&ʰ{!o@R/;{->W6M9S3-:f]ߌQ:l(1*lǡ(=21v_߿O˟/!_BO! dMlq 0.{ڻd;o0Z+7`g0H9md휊%2߽Z+i^8Nj:{،0J'9؅4@R-M ȸ7v,X/ z+smUp٭Qz5n,8H'JWui HHpK*ݗjl?h6]1ntC pt ȣsR"JR-/˕[ ON@_),jpp,?H{g fV07 m` ƻa(vkqP2lB)LlajʇēČW*5Z;%NQ@iVQ{0Kjo{V?C)ڼTGngdK gh/SHHS0~WK#5e-X_G~yɍSzHC: tA'Fiʅ28 N%/3%s'>IZXQf߀R-o_͟t_5]* p)WQKLg}7|ؠ&%2LOmIÿ D5tΊy,ÚRX?;D왻CEbhĔ6Oj؇X nuuU0H5J+t g}6߄p¡a[ʫJ PqKADlmJ}=2o-g? \WAo[ejq=;~.VlX*b+guv3YSGZ 5gGrH5?$3Ÿ&ԑ9bD(Tc΀ϽT\É'`8CdI|<06vƑHSUjސ`d3z t<~ӊf73 X$oG~u53% bXI #z;;p%ث Wۮ1r2A҂_F`s0;4z["PDvEhEj&2c :ʿf `ݩ`w{뼴_wN m~JV@9,"q|Aj\x\WjNEڻqo EŽ.[D:#$)(t fD)7࿕9Y8R)v)W6> tQe]bw\Bba\4T-zj󌓑KyƷSReqwXHV=BkiѪ4pSslp2Ab\\(p=M]bI=ZelNA/ە 8"Y` c#*Z7f\%+[^ X{ZAS6iN-.Q8^)%ب!#,(`z՗ 4"WVj+ @,EcOYAC.gJrO21 mb,&WU0n۹ƢBDcˆ XUᅲR 5{qbxm 9͐^#+'[M8>\ „#oH4G _A54],RuU4}жc,@M,WM'7ښsudq, hC2h峑{^ڼ ւ9J꾁k9~.$KYKZ|>Y'(fvh3" Ԇ^*zO\8pqy92U6rFOBs^̪ [MP @R_2~YC2^Z1}BS?`u-%=PW.Ẅ {tmXD%ԫJ`5[C^5r.=4ƁeW#\X,ш/v׎[]¹ݣjMzc:>R{5=mf:qPnH*r)ft vIODrufLoseH2;9 lUm,b4Yv"MD0i8-U$!︵B1́GQGB/]1G䏛zchc'2)ťM4:OxVyJaЎ.'xH(I  :2k6"y n9+ui+zYJ2!"rUO@=^I"@Xy(Amj~{J ܟ͎kðm *^Y~@ZAk{!? 6Fn}A:BSGmC,a&,͑ʼjGQy 7oPFwkY|,>|`6CdY "dF8R:ǍXx̓^>bf Ӝfn5 sѺ>[T($rRGT̴$Vl&RD!!NNf]i֢bRVj/G qh]@V4/a$߽v7*`YU(k@6!/deN+#B^鳍7.̓EHS&yZUhCd黗ũҶYZme^1QA*CIVoIˤ7 <Dn$|5i~ ς Y>; *+2n1KȚ]߽&^np&9Aeu'HaBKy1 *czs~42" ӡA;b<˼1tTbk8zRZKQL+.fMV n[1& A/^8ꐛb-A 3W<&1M@ЅtR(A!h$jjtu2l<dӅfAf1I̩*u+iL@"mAoUJljE?7,Y"c_JPnm$y%֬&<С)sp!-ٽʭ8YR a_V]Pwv;Lؗ6[ke[.4A cLY.-jC՛U v"|W?s{>]bH_6-z"Kop[~5P/gZ[G}ϥ̶n(G0(fTj.Ze''s<FM&K\\)\CspKuxe)P^?@ED܄Ee3iG8,iA2$H<98'-SPCfwgvzQtgC+g#eQ:[hgK k%*Ia-ʭWӪxkV0) 2MٝR'~A~SJH|F筜*ٝy/ 7tP?rxسksR8Gʘx-C.,'}ٞLdtV G0I \Su>^ f[F"ԁ-# DĊwVEIF 2\8w?i|IiKfV2 !EIKK 0K\ ݵ,MA2{PV d,Gji&T\\BC\f y͇e' Wmv`Ә2@7N oM'ޜ=sRQ[W"^& (bėYplJ?|G,;E HomȚ(ÍG"Ѥ{̯UyL"r5݉8jG)|sk2lB^ V#`(AKJ4&LU0:UnX/Y4mg47ЎG˵bePW>i+spi=5oA#eBA}NaŞ:5cyAܹp3uZvw\Ey\<_ (hL'i@ej{;{9LWOt#\n }ιtSsbczFOR8{vprc_1S?\ǵJ.>ߡ׻1*'AEtJk1lg[ qY34^TbV ?(&\3nIF&u.c ū3 ͢llKCC.TI7#S -.c,Mwׄ2r 9+]%HJo)f0뻀3a,F\WBP85sŕhu/3[E=&QAVUXWhD+SbQ7DH\`ed)A^S* +BA3 ,ͫ[)xS5a_obaIEr& Q~7/1m7Kҹd`Ĕ)*T; k.|9,*D\8p/ Ԥ˦֭CX~w(W4O,{'ճzr\$BC? Q[(gcn!D sb}1+q{obҜ럞EN!&fk" û>%A"KNl)kˬz$vuӾI/q=f2:Ҡ; GJDooy6T0an٠BT! ,wf\}v# L{Yl oېS6ToD"ݯM/?kOR]*yQ^ {R܄(h-~Z/襨0 g mN~8 :=Ivc[n>y-?/IH;,Ӣ-wbl ,msqrkG!1<('Xa09h'zg4״MU|l(E.lCo~t!w ]U40`8`5&; b`oP05OHIʛ"!@W:r,տI?5ܒ 籰@Ǚ/QzU\cp *oȚ7Z%IJ)DS,zo*m5-Pԉ?[q:,7"1lUxL3qcz) Q+)xWc9nRaz P~ٱdK^[{1t[:_Ň沵NDt$AQ2!W`phՙvo4&5'G/xF1q3TZW[.x/`攞pEf(""p x: T܀>Pltw3nqA c1G002nCQ@>9e O Sh-xW&P.Du84ݟZB6>Bˌމkȿ"P &HlE%k۴i7¡g[V)u4CV |rw"fA1ߌ K^4n-=)A8P R\HZy[n;%˄#"DD&1~\夷Ur/ t{YwsT:^{Y7~8:n7OI>n!bxDģ <%̖dP „iD:rZ1 Έvgb5k/x ?Cj0˵>7%"4g(VN߄xՓ)w 5kMܔk| R#͏lmV8qFT,Emi'vu}^^9E490!ֽłMV/ٞ>p.(%f<o6/O{+,UiJl3l}wl$͵-aw۫R,c}Bm3[@kYz l%qfM}di=,A6!p1:ʅ.c9Jy:/!DQvsgH--1.tF̘yߤЖ,Z₷P_0Y?LC)(dh๖Q!!hY;-,sR%HA7ȥo/瘮&xլ2,QZ Y@26*:Ji\~*N.̰*#7qƏnG2H;3M0EEte.\Tk:86\t?. *d' (ŕg?3c-,[+RY9ݮK'l{ٸX%Hˆ-F[(ݓ=HQɰ7YKnv}$x63qjo)h6uW +L,.yc^TQD!֤(O&]#jŞŸw\΀\i1M˔0(v ^Eϧ6VT]m4{ٺ<>]|" t&"p]3t`\B3OqiP3:_r"= Q:^F>T1q#0>nOwF qX͞g_2~۔'6͢E֫N)kd/p25)GȀ 'L7`t։zHdeRP`@|3>yv~1%Ҳ>K=D+ l^qY9ڒ#:Wt$/'*GH*t<"Y&QӪ+RGz{DniMrWF;5)C@Y.pg3/Hu >- tcT c?-T?Q#.'Vtk|g^:.5f*ݘiN9~ł Ti:g鞞^F"]p8;COgwVbgOp6F.ahHvB@y] 鶣NW_=I̙QzN$_ŜGABUQLU>BqQ;RCx{6tigH%#jF?>,ej ELi~mN"z"<d…x5X"}j.k~Zfdot=d&47aIK<-=fBaQ$vJX;%͋bhpj0~Ӗ($)=5BHSn9gXg֍J)t;0].HUu$J \^Y0Ց*ޓW;:}27Zf*x\58ӫ$~$Ѳ U?Z>sǬCja+ D!L U}tjjxaK]/ZiatA@[wpD鳠?~yu~&`#-mY洸I_LzԈ!}<[q1/<}X/Ϛ>a2;H(]*o! x=_uIIџ7RVjn)t`㛜C^nb:@Eoxssl!Ʊ*F&/%SQ0M#r=[ 4bsےe ,\:Ims˼TDY˸z|<oH2y@7Li[Xw֐aI5hppeI/RPOLK°0s-$!8WNP%q҉&?>/̟u9yrovJ S!IHu߹JF];6ڂZ'b(M$ C"/(o{}^ArQlbmϨ:id)~+9:лO̙Sw)0ܘ-d@a00Wzky%_#Ip-qPkFgPȿ_m-*?C)4S9næb2a~ejɖkm\8^5Aq7rv|7>d$F`b ) [=E nZnС1V[(nkicm[4ԍdp[c>FEC4hÅЈ T+ՎAyTvW=ONrW1baVe+[C2&ǽL̇3H\Џ!MֲqRti-/뇊uP/誊QJ2L%@ N47Hyxƪ Ci" A(Y>LWhN0.]Z/ފTTHҀK5*FyZj k{#+۪QQ#M5? P7 4fܪ+3P *%Vb;rLF Z\v%*K0c=0 Y9vKa%Z ޹^O@p+eܯ? 1h 2O8(][&k##&"à}#K _7~[s=3> BBκq U GtI,U#?^p (q S~Bꏫkf:~z?ᜀ6#Лtq"ϏfX TKy2ee]]_}F&(3ۈ4cI@ۋ;xwmS!#X8LƯM逼;t毁A*Vr<@b"gtHIT>07?'zKQo#!9V;?ɩx/ K|K p YL/_S)Ѥrr=-w_v=^E[c }V6Hoa9{vhx׮;竣@P(B|E,/s ?74\`CZ@^XNa@˕WICyNL])sO3(5$(o6ٓm `jeQf }]jePYqg>PZgVh%ŷZ}F!=\RڊzI, ]/gɹ]z79qΔBnI|`][˧Qeߍ Oq~@4Jr3~&"*0.Z vltKۡM]tN 'urSR%jAUuR|t'f X]> W"9ARt7nDb ~bIAdRlÂg{:LYL߱R8i;_n+tA~:zj?@…McVƵ>΅ngw)*ww,b9%&C_x{WCɥ}"vhxqK_1H[&hR kLȟ1Lw"s1Zv3Wd| 2л4pgat;) IrHvawe=[r !"k.[3UIQCf2v0\V<@ V:LlGg. FF)ɜ[ z Y&(ֳ.cӾ͞_ܖ_ՖC2!i:3YcF;82 ~` ?+'唴z5qg{AM@ZQ~lBUx*b(c|5w~)c#9j-{Ij<%eJ4n\t;d-qc>9LT4d[RD9""(>͢tAw<5V7{#$Ut VSoY鼉OYTdPU.t=ۀ`,,\IJ\:_|*#u_rǢXB͍?&(Lt6}Y~}mtY i *aw(,2v8J@~ /H4E5 ~s$@!o&;y\jrKՀ;"P[Q\ja&ךt;3 ?^kcvM7Uɇi^4m#+ʹKvLs:ps(u?*2iE Ce]c߼o=iG&nd#(GC%x[sF{'n,A oﯴN Dr0!WCR%87׫[P0tV]S *>}ED$"x/[빙($>ɋ_d7U5AňL SIXKU_UbZ3e!*R%_$D"x.$֜A܎66)_:駮f`gPNJ[9(1u5}iN%_ʃRk/zױRa+<#Ol nu 9hlb[z& _Ilr=B' 3g$8wЀpm QH*" :{sζOٔOM5$$!Yˇم^ @p_D'A£LMA+}X2d\15+I >O}0{$0(~V\R̴ E,:į-g)u@A47˃cWD/y"9'Ծ9~n t1,[k\Yty< Ϧy~tܢI3I`*&}h)`Zr6ezE-AD7eGʽ6ܝPEMy'".0A߱<EXAXuM)Fk~`<9{(r3A-l,$Es7p!7HWo{)R5{9tԋL=C +6Q3 saQMT9fc9ZqX#2˶k*I<ƒ#KK_OQo.FBk>Zg=8т:’xzKbη2i/ |w8Cmb' :,uW$N4 x:rPVjE75ƚ|!-7%DH3k>CcT@s0{.ڛCZ7^>`ˈ u9ޜT51NR `{Jݿ!j1(A;3}<ބ b @Gd>̩GV~Qy(Vԣ)~iS) TA2kJ9k u>Ez|]K2SO㾟,- ǁ&ios- d.z ,8\m^WM-'>xf|!x (:ӥ"m Zښv^Ssݧ7Eŀ JPq!^ N'P-$? 9 (+f$ï`Ism&e1ʒ.P jz]Dx9ToՋZ~0YhkLJJ# MUҩH[vtK6YLk [!M=;$y}+"h@B皷¨8T@hM߾SwCp1m f͉/elq*ѹFtq#dn%0p`Ou&fA(Ti=JǼ,|nh7=lz\Е ~BŇzz|0 7,©b{ȉbeD=k<}qkkcy5&Q; jgG"_Lu wey_#*wM ?9'RV :5[""ߢf 4!nJd~qau#킍%,. 8@׻j[ĢDN-a:{yq?ox*_p {SpYTMLfHE$އ $!,aq~~Iqq\(S:k׊Tx>+-܆yɫ]_<^!%׃^3_#Ue5XEm(?r8en6 l@Go$1lJs05ln ,W8#.?fͣͬxı58֫/ ._ݰU{x!~xɲ斅`Ŝ'q`/8pk>}E>( "BM`|$eCav/*P1%7cHtI"\M,j:P)bRfY!`" u)ç&s&8Dpm"*=^1D@ϢH{&`WuG#[ȿ.‘}6-a@@O_-!;|z}佺2.;!.zp22#ԭd&$xudS,w#sG\J"jm* < 웴':d;P=]&4hE/#n1k2@X*c?= w 3)%f{Ʊ]#z+OA(}&o_90]8K)A P ٜZ\ P ̳O "GAJm&2B' =GfFPIi0ZvJ]x6lYa# LQEa{_J91 A˔qןzqKG6䷉pحFz9LsW,f>!+U}^ggfnS>OX(y y[=  y's|ݟP[)tķ DVBeGǭnk,;M'Gg`~:] DL6gZ"-[һ=L:kE;tԯlMo IH7 &JQ SπQt&+֫PNQg{ѐkj4 %%Z~NH.8ҽo|} Y*uޠv.7pj| Vȓ+a!ECqb Yzi^juߴKg&w9xtv_'k=:;~!^A֜z{h& 480Z'N;嘚 m7:a'JZx7=ZAjA9qJlEp.`-0KŜjs- y.{!1!X!V1ɋ_\:v N2FpMDQ:KՒc?{Bҳ'A Ŷ*X2\&BLBz4v9+ v\Uxm"XNh,_v k,V{v=FƔ*O\=Xr%IcEƓ1i\.,~/ϭ,_ ԡORsC+M7ⵚ+Τ)Eb1߮jM"J-<ɔÞ e D4 ܗ7XJF`ps,IyʌQ!bNt1e"GZnl_D:)ƥUʫEqO<ŽnC Ѥ9ɿV!@:De8o~pR@ȴx0W^$G@q+.sg2%C3yC|)0td .Lz|SK!R2]Ss-M!H18E}ȫZ#BmvyZF (,}`+ 7ȄD\"&!QgUbGF,g;-.%UyUA[h2$_jOaOZI@~ƽ& B{,}2 kh]Mϕ. daBpptavom_zlZv#-հ]_qE 'e4(j4xzlGkhTS9˜QV(gg6 .0mKu}Mk'nlk/aQ{tڙ*<"u/2UUY51BK1'P9)BMe)_"GpʡR<9B2iߒ`S=t#HSI k_t>w[ ߸ `g>V0seEÞ5ם9ҴvQ[NR6jnJZh\A/4M yhS&3mO1K|"+Ͷ H2pJ{~CK6ݦq{{Vb?PTmPꔀ߆2XrBDd%vLꩼB{MN 5ǡQϑGϔLiSdiγ,e%cǝ=i_ү9yT ?΋ Dr3Y4'\3[ v3 -T&`9C;k_]$g )EsM>V@ad-Vm{Yml?ڝI&ݜ1WЪ' ɒ78=J;+- @etG-V08 @zd|cA!L6 R"'T v‰+ZHV1/ϋ^zm(ǁ@A\b_Q1m"oTD&b Qd{<5ܲ,Ł*Ӗ5LF*q渿5Ujދp!g*._}}\8R%Zo e gqgCT ʮnV*T#d)rdnȨ!QI;b1h+k垻xz^lq6`&v&C} {Y7<ubeҀE)u/ &3ۨϡAhփ P+ s_Ւ$/Cjh(s2l;11뫨wI&5!Z*N6a uI"XبH{SzUr7l9xj^? UN{X[Q?7 *0,zΉ?h1boT,aq`@/\mWSy =H˜#VWS ~'0Y@kObuddpк]xEB`A(>}o'WGS%]v.&o3'AqF߈i䘸Z5ⲷ>AՌ慨;)0Mgi)"FHWV`6is[ùK[#4VZVǿ j;`pD.XI.3W=w3n'Nyh?-J}MoI/Ie4Sx%@1Xt\ 0q9lzEgd㄄łV ]y Bq?N?ķ=o2OS;`L1^ѿõy* ^Upեv $Ə#}1l NUuWE72Bh8jiI/9if  no%5J m"*G:PhT,/OMkV!.$뿀ewC<d2L#:HԦf oVwLm%\')Az AAj-L:Ns OIXђ y):ټ~W{xtɖ iK~ TkV_rFp]j9hv+(;ʽuz쯞mdI%E;D׽h2%귤?P(VΔYR'J sp? ^!ze< /ˬ.@ knRvʂI$^f x0"H\4,0F7~PlTb)U r+ .)6JG@q *6[O7E҇8ŷ-w%dc.qJ }5OS? | >ÀEmPnJ~H}P~Փ`97Rw@KΤ2}M0BJg\*Ћ׬'ژaOX]sݼL:F4uDEөڨ|$ }4( 7"S&A3$DX 9ģHme*403;0ťF#4-Cf~.rdpRE;˄suG|8Pd6ANȈµX;ϔf|w m"əEf)O ֌׀9| 9Bk]Wg3ȍ $Yhp|}^ xmKɏڄzQ~!8#9'O"dR;FY5gk̈!:C{ ^ӟHOGd{t]mcfbnQz"r44AvRKڿO\`JFr9̌tBtBPuK(-/> "weSoBKuL$I&!+xBLํ-&21޸XCS5jĔmG#'AJut~ xjzF6f:[)2ti%el=xh,wo?|c>v>L};֔S/*j3 95kJ NW1AhIn\)Pq DLh1^q;K}*}vgؘo.tΣ蓬f4{6<|%F.fM 1lGn]ȽM_ydl,%4z^q ^1 RhZILaCa-T@40u!ui 5;7 2!l?{ې٬M'Fl2;,w#Xx>#<*z__|K&;rF4tnĶV~BdE y\gr}9xgC3q6_ސw_D}?dzyA b7#^qkd_+0Edngu@;U(ZƧIMD<ܨˣiQᚓJiveڰ]-:`2p7ud25ofƎd./v4Sv ahJT3$p649͟<%SMŀ %5ٵ),O^L,lT}?`ġgD!i!:\YhC`wiu#E2^pJ*#G#ӳaqӽIc<] [GHݪ( 7,8>IjzZrC]swB 7yj8ؙ oQ=C6u@D Es/B|/CnbWOR>]LQ=1XywlY 4Ws`VĈsF}%Sy%%L3;~b DFbR8+9&qTSe.IF3i%Rq.}7 feik4ް9`a*H0c=FThqŨJ?qM21c]AN. pABثЂf!]lus"HiX1:[|  ͙79pEvƈ0jUA`1r݈Y܅#>Z:{sfƂv'fz.hU9~dGʼncKC[IF4$~M=dj M2[\nm?\;P0/[+VoX<4(N޾OMo)~Ս{9ǗT)N0aKj_/;6\j(XDŽ$ ?D&uu*Y;^| 98P%2$M" 8'+40,a$UObo^&PHiig7C =lw.̫% nkִ#B>]70"\-#Gc@#`N\JmJr?03*tEN[\ayF|/7*;*o 5FN5D`GN1`Zş^ XvC}&!|DQ> |"x\{X Y2xIx7l>[^ِ 5y4yHʛϞD'\8!cЋp g 3¨j):úFޑ Y^~QrH1wT@`#:86Eȧ?_Vc5obD1Ir`oWS ]x4k6nf:|O:sBTnh&ddBl挌uټc0ӌKDGX?a69\y[F Hg2#PƌŪP jͷ]]dR:%9O3fDAcjA+9wȡ5S|XX&O-J.z.td/ % %ШUͪec_^QV#i^xhf>BCZ34u/QƍIPSl F^v@22 )F/5ԓtBrJ C=unD)$}NP/⠪7ν ]bs(Aq񁎂,'?8zD.;ƴimiViK3~{/ V'~D8ISC 4֍lee2cG?g #/t}ǥ*1A4hm~ᘝb+l,هpICRqJ,@(Ike8qC궮>y Pfc`b'b쀍]B`K-fԋL }2!ZNJ]A /ze `cqWU2BѝD־慬uZGZ*4[Zc[p*`3Rsdr/ˣBh^lX0pibՙ_Zyfbe#-aܗs6#lȱ(ϩ-vV#(WP;e֙FS .o.g~`nL{;\o9?KVJ嵤=@lMmyk|pIs1sT_  O w@WM&|Y%a7XTd]mu6 $vpyOcjbIFK=C^$Ǘ,ߛ7ADA :?>!}?wGX`P RmX;C~aN},Cԃ&1ԑu?k)7mPE͹M"6 \m-ޭ=fO>x6ay8,"ORdaڼp8{?h$Q3nn1SH6MOouRM Jp05kWvIuGN5*6c,N.DX#GU^IE 8 X q@,̞CrOzWF8dDNml֜#y W6'h~ߤީOHo]R^m-&)(2<{Λ@ݜ5S/~Iwix]iuxFq0n+[*{}6a=cAq0[vzRLIUʒ7رpZWNmBT({!lMI=P\vT>N8^9''öXar4jB(cwg!E+.3S+BjX%Ne `w=39Xr *-?́;Nj#`Z>t)&>_kMUR .rɕ#&rVNؙcmz*_v$s9[0RjZa_wm~Hm Xu5lKBBwӘ?{?3!E+N K(hwfmg@XihNa KPdW aig[rΐ O}|ۼ͎V: ;EGwe2^Fpbwɴ$)5S8],4$;Ւu{5~ '/MAX ucl1@2WVD|]Sᇰ*NFwroL/=cWwDAU58{ؚ= )P Bʈla=B#VY\]vwi6e aTQ8sA<"Nt/,. bdmP3T@ZfG2Рƻu÷? 薗0*2Wh4djyڂF+SGZC7Nr%pݜCVbF;kouvͲ@vCcVh`_NXQ5eΛ0t)o35(|p3:cHIbsr: E!j7M2x Ri+nAK8#jG4F|hGQ~\ |B6\nn"Ty L~;eX[R}@+1x(,L"QO g0>Q tWуb>sբ6*dc5I"0PN &Sgc\[h ȵ>H%j'PjU{ӫ loз,çrP?]IY:#! [kkL"a i5zl#IWH]p ]j%"5ơfu[qw 2 ZO˒Z}m%D$Lf*Bi;uM awZtE[٤@*V ,3fhiHjI4AST"ޟZzW @:4F J,Y*Ce9}oF: _8_w Ϲ\p;=gPutAWԺ`No|m o_OSm#vYg]MK HMȵ'3Hk dI<.=UcD/5 `ݕim{NOB,V+hԹ#<2aKC ~yk(_aD’"H Fo*෭>wzQ4_tm qo$+P<8+z c'd@'DzRq,݊mxQ3qPO9uIr dүhN[K{#@ }gJvcNH?*DP;0'uʏ!:^&[v^t/:N SutA@"jLdM֐L 0yf9K!gE澏w&9qٿ(y|rJ"""9acI{؎x c,꣋ ͼ[ ?2vX?ýH-€K 4U l$ItDŽ?Z }sN | ̄"(~f25fxZ(!rD¨M0w+ (r(cw(kH~XJ[hL-q'aESJ,ӽ2moJ nÏ{Ń!L|\EvL@jnKO&53ǡ*VEdqb6*?>Mki0V2_K(ÐI uPԤ!tI|msB@{<ɂzqz7 R\N>]LVlB#gXeIݞE_r] H8YTABpjӱ3X LRn.;2 1K1M\Eʅ/TWHqxkM yk rR&s>{ф]{wX+a="'' ^)DկnyiOU'J7޻:#$RF+=+U]ZClT)F0vojĜj߭!-GhyA:x{Aj{Kx ج&lep q}ϹoTQ'Q,J#SSE >Bϓkz@&5 {[F%Eɪe6W2Kz_k8e"dCMjR"Kakw:bQ|jZUjy!82i䃬_ BK:i]FNl* |=ҽL*$j)&DT!p 峿,D\^U"w+c?H3V;vfԘ'R^9vN5qgrZ G϶Ɉ{;hMSu 4ѴA $ȟѨg> U]8'/>w5%9%,<[J|l[ՓIeO,R{,Ӳl 9EoP16:-rr'GC gZ{-GP 2&" $z>$F>3{59+svZT+Vc^(u / ZOI}@A +#.CA%2KP xrZS7:23}U<%]&dLwHm:3_#Oi1ڃ[;6*2Pa#34cVKfG?MJw' J8yÀ؟6"+EGֵYa_-~k,7ʐjc0.Ŗ^5Y>ƞ4I(\b<`W&NY*f=.yzZ2nXwI׫H{_?rIBwӪ#nنF }3,ȫ[x}7fՍ%G;K14w1QYDJ%P??#>HbsXO" dB O<MmTJQ%8X *ˉA-ylyUJ@my2@.E#0Hj3[V 6@#mfJ囨$7DBYFxm;KF1 &_lOjxxeACl􎽊7؇{'#ہ(Җ䬵 8<9U{iy=@ yye]t>F:^ǂ*_M`{_܌Do|=x}(Gy~ظNda*@Po߮:Dɩ\<|D<fkeX;\(b K{E)qF\r Y24.-Ό|=nzq%Q[ݼdVCґʀEA_ !4!#4u2ii :4%М%%3^023 {ER  V!N,: '6<#8^'ūlCCDHe$0zZR^${:j2uK{G33SP!+O;~5dR(2Λ,&n9 9V׈sMt[`H8Aጮ3@P/a``E]O RҼfC Nq|)MkHE,M}\x+OӿsԺ84/@fLdr]rK_v4^\N9@6Y,:1->A8Nm%St|pfFϨ0rnmGZ-T&FBasNW c=40&}%06}SU^Hť+vIʌh&6KZ {'hj -'J4\sICݘ/ ͸g2" ɞV4)-!&30wzka&鴖O# N{jIJG,FBhC.Tϟ#/Zy,$S7}^RrIsMMFO!M@2EtWE)p(Gډ!R6O!PMLmxTBr:аCS}E(D ;?ZS.{/klwňfº"!ۃԶo+%Ubt_3 ciBm!NInc?䫈߷%M*y-?!U#SP*9괛Zwm7iFk9 پ4ș0l f骦uJC<059!kcr̈́-1ja"l\=Y;ǃ &9hk"XW^`Ϲ;GaHKp =^:Pʮ~wgyf1ޤ!`p^1l]q8v-ᗱ|ƈМt#ppS xz3J5rU:v<{i\ gJ(EENcP E8GQD8+#<!l=Z:Jkƛ}1x)C軍b܍|LK_EVuu` v CUqLWg`Vaґ3\{m2|-@Z$ %(%CKAHՒ_,]ro!f.f[S!9#P-/,<*iɚs7ikhuy=%_t7,Λ>+d;-Rvc D^ojQky93jR1N<Cc{9c~qbw,7Il'kh^:IR8/W=[E, sbdg#Ïpׂa 2$Q+Zu\7< ^1wp4x lb{$<<~. -uӦZy'>̒[~̪*9#^,q-.*ɡaνL\s1pJ;?K9o,0 ?HI2?[ߑ9jJCT',xZ+%xx]xd@ 9ޣK1Fv5$wV"+K\?QpaFnh߇ZLC Yuped:Xb$QT#ޭn-$[My,l|3eRf1S +3i1H铔JR&wMH9I "oyK@p7A'+7Y}0"bBr[If!.tTw<,°S8QO0,큽󷜧MإڙN뻊;jxBF7ۜ\In^3F{v`uǁւ);Yejzo˪lINܴP 'G!{ #"ГDEZeIǵ)(_r< T/[ W!tg =": ԛBa*BH%e|#槫I꺪k>5lYtBwx899${WB`}:FZt|Aėx`ńk-m߂Rz#c?z< _K,|u G+2neg3 _U tfah3s3G?}! ,d$^gT?Ri#1x^@:_Q3^?s~IbgZ jΥ>JV,T ]V򫩫*ֽY}սv5;{Ts EU]/$9, rKrd@s 5*b^G(LdNg9DI;*q#(OM$PL؀e\\yD_@SӤ5NBL4SM@0zX8~` eg; dv@NSGu~{kN`ޠ*0 yEq@lĒp~cϝf͸ȤBLV5f+=5.u^138E Opigm>gt'mVoe~ >?IRR 8ќb؋ l5aIҞZewunl K f)ߣXtƘ?T}!7Mo߿znnDe\m6{H1Bu(U43FSy߃"8 j+ .~tƾ $irIOuʠT:ls0ň89]EZg [%kNc!|()oq*FatwV_?'8* i UIEqq>i%KҥfgtF^M`Q{:\0O鿅=!c_[i("(kqN"#WQVǓ!ViBGݗm2ĕ=P0%܊߅ܜ}gQBZa-.Mf >ii]Ѣ>agKԜT A$ ) I*]gbALc̜ UV7+/e8_N۠dO蹼^;)i(w!:cPl HR9`YzW6^S.We\ԂIZk``D4ұK"' _亊r1QK3nQhh//G d[K>5= ji+!TT2 #ottY<@955V.713؞aL5#uc(ݎz8XQݪ6/yԤL?@cG$wRB`Oe)^_sw-_' Ul!fA:QU-SХXG\$oٱ9am3#Zul>fP}:LUYtkKZki$ۇF +Vu>D9PA_hЫdz$X<|]fO`Ys7cƫƼa訅[i>' z";VNWoK‡ƪx-:W8[i5zц eBg|@fN\0v@4v]ΓpX aT[1q {8Mtj5gSs_x;w QcdsͿS@@)Ou3c)9k1˜ܿ#DI,f7QOK\Kfd,n|d%:,5ǓM q2d*,p˅"9gi{;BCp8S4SOxxTݬc~r̰dx8lG^:H Y9YDPϲi=+ff7/le70./{b%?/lqی*x&IS_k%bO-2v]Y-rxr"\u?y^ΗU* ć)W-k0!`l-27 &jDQn~LU5&m7FH!R]UXppZ]r,[m#-3\5SMA@ zѲ (^h؅Q imcVqfJwra͐AވJaMT$0 yXGR:7(|Rs8>PNLx @?}B!O/(?ތlӫy_4FF܉R Z8Dj$'mB &dlݮB|qqDiܧzzeYyWY!ոa>5u% |h>hGޙ|xǻ2[hSƔNݩVvIJY )+l' 66RlN[q;lžlݕ < YZ