libopenssl3-3.1.4-150600.5.21.1<>,gp9|U(#NE HoL(8ɪX+gUq*D9ٮNM={6"mV<I3 :ݳЁTK߅b!PT4#n $NiT)N7)+"?~ &.\UtM(4TK/),|HEƶ4XQ(c$ o,"[Qe34Z!Ghg.i<"6*qTSE)Қo\w>IK?Kd " N\`lp 8 T p   (`L 8  $ ( 2( F8 Pd9 d:d>A@ABAFBJGB`HBIBXB YC ZC\[Cl\C]C^D}bDcEdFeF fF#lF%uF8vFp wIxJ yJD@zKDKTKXKpKtKxK~KClibopenssl33.1.4150600.5.21.1Secure Sockets and Transport Layer SecurityOpenSSL is a software library to be used in applications that need to secure communications over computer networks against eavesdropping or need to ascertain the identity of the party at the other end. OpenSSL contains an implementation of the SSL and TLS protocols.gh04-ch1bf&SUSE Linux Enterprise 15SUSE LLC Apache-2.0https://www.suse.com/Unspecifiedhttps://www.openssl.org/linuxx86_64AAxXW6 Yh1H'AAA큤ggggggggggggge7ɟ31fdd2c8a52755a9604e63c6fa209e80146513cd77470a90d85f047301d6854ec8dd4a630582d586f3abf66e2699f6b675118fb920adc9170662b18350e15d22898022fa710c57f0a83de47e54c9295732c98a3753dc70fe6de44dd6c86358af6a239204d085a535a541172ceb8b1addc4daeb451bf2bcd7c6d177b254be4ce9c2cb539ea90105be1bc3d48307ecf56dcae9c249cfedae9454fc70c5e970c9eb286c121fa39a39d0f5ee9ceb8e72ac40b34ce98c7b336451f70411f37aa3f8274da09a91786172a18ecfae28c8671187e56b7cc4b4dbf34a30745893d519ca4cec8cfd03bda333033f367809ad11378d30e826cdccc7e8a49907e18a83f81cb37d5450cb2d142651b8afa315b5f238efc805dad827d91ba367d8516bc9d49e7alibcrypto.so.3.1.4libssl.so.3.1.4rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootopenssl-3-3.1.4-150600.5.21.1.src.rpmlibcrypto.so.3()(64bit)libcrypto.so.3(OPENSSL_3.0.0)(64bit)libcrypto.so.3(OPENSSL_3.0.1)(64bit)libcrypto.so.3(OPENSSL_3.0.3)(64bit)libcrypto.so.3(OPENSSL_3.0.8)(64bit)libcrypto.so.3(OPENSSL_3.0.9)(64bit)libcrypto.so.3(OPENSSL_3.1.0)(64bit)libcrypto.so.3(OPENSSL_3.1.4)(64bit)libopenssl3libopenssl3(x86-64)libopenssl3-hmaclibssl.so.3()(64bit)libssl.so.3(OPENSSL_3.0.0)(64bit)@@@@@@@@@@@@@@@@@@@    /sbin/ldconfig/sbin/ldconfigcrypto-policieslibc.so.6()(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.17)(64bit)libc.so.6(GLIBC_2.2.5)(64bit)libc.so.6(GLIBC_2.25)(64bit)libc.so.6(GLIBC_2.3)(64bit)libc.so.6(GLIBC_2.3.4)(64bit)libc.so.6(GLIBC_2.33)(64bit)libc.so.6(GLIBC_2.34)(64bit)libc.so.6(GLIBC_2.38)(64bit)libc.so.6(GLIBC_2.4)(64bit)libcrypto.so.3()(64bit)libcrypto.so.3(OPENSSL_3.0.0)(64bit)libcrypto.so.3(OPENSSL_3.0.1)(64bit)libcrypto.so.3(OPENSSL_3.0.3)(64bit)libjitterentropy.so.3()(64bit)libz.so.1()(64bit)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.0.4-14.6.0-14.0-15.2-1openssl-33.1.4-150600.5.21.14.14.3g@f@f(@fIfIf@f@ff@fr@fffb@fafWfU@fK;@f8@e؈eee@eXeoee{@e{@e@eqeRe7e1@e1@e-%e'e @ddd!d~ddu@dtdkY@dbd*d"d!@dd@dadxc=@ck@ccccj@ccca @ca @ca @c!@b?bK@bK@b@b5b4t@b0b@a aa@a@a7T@a@`@`P@` @`B`}p`v@`/@`&m__H@_@_@_@_9_-B@_@_^@^@^@^^@^@pmonreal@suse.comangel.yankov@suse.comabergmann@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.combwiedemann@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comotto.hollmann@suse.compsimons@suse.commwilck@suse.comgiuliano.belinassi@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comotto.hollmann@suse.comguillaume.gardet@opensuse.orgotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.comjengelh@inai.deotto.hollmann@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.commpluskal@suse.comotto.hollmann@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.compmonreal@suse.comotto.hollmann@suse.comotto.hollmann@suse.comotto.hollmann@suse.combrunopitrus@hotmail.compmonreal@suse.compmonreal@suse.compmonreal@suse.comjsikes@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comdanilo.spinella@suse.comsimonf.lees@suse.comsimonf.lees@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comjsikes@suse.comjsikes@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.compmonreal@suse.comcallumjfarmer13@gmail.comvcizek@suse.compmonrealgonzalez@suse.comvcizek@suse.comvcizek@suse.comjengelh@inai.devcizek@suse.comvcizek@suse.comvcizek@suse.com- Security fix: [bsc#1220262, CVE-2023-50782] * Implicit rejection in PKCS#1 v1.5 * Add openssl-CVE-2023-50782.patch- Security fix: [bsc#1230698, CVE-2024-41996] * Validating the order of the public keys in the Diffie-Hellman Key Agreement Protocol, when an approved safe prime is used. * Added openssl-3-CVE-2024-41996.patch- Security fix: [bsc#1229465, CVE-2024-6119] * possible denial of service in X.509 name checks * openssl-CVE-2024-6119.patch- Build with no-afalgeng [bsc#1226463]- Security fix: [bsc#1227138, CVE-2024-5535] * SSL_select_next_proto buffer overread * Add openssl-CVE-2024-5535.patch- Build with enabled sm2 and sm4 support [bsc#1222899]- Add reproducible.patch to fix bsc#1223336 aes-gcm-avx512.pl: fix non-reproducibility issue- FIPS: Deny SHA-1 signature verification in FIPS provider [bsc#1221365] * SHA-1 is not allowed anymore in FIPS 186-5 for signature verification operations. After 12/31/2030, NIST will disallow SHA-1 for all of its usages. * Add openssl-3-FIPS-Deny-SHA-1-sigver-in-FIPS-provider.patch- FIPS: RSA keygen PCT requirements. * Skip the rsa_keygen_pairwise_test() PCT in rsa_keygen() as the self-test requirements are covered by do_rsa_pct() for both RSA-OAEP and RSA signatures [bsc#1221760] * Enforce error state if rsa_keygen PCT is run and fails [bsc#1221753] * Add openssl-3-FIPS-PCT_rsa_keygen.patch- FIPS: Check that the fips provider is available before setting it as the default provider in FIPS mode. [bsc#1220523] * Rebase openssl-Force-FIPS.patch- FIPS: Port openssl to use jitterentropy [bsc#1220523] * Set the module in error state if the jitter RNG fails either on initialization or entropy gathering because health tests failed. * Add jitterentropy as a seeding source output also in crypto/info.c * Move the jitter entropy collector and the associated lock out of the header file to avoid redefinitions. * Add the fips_local.cnf symlink to the spec file. This simlink points to the openssl_fips.config file that is provided by the crypto-policies package. * Rebase openssl-3-jitterentropy-3.4.0.patch * Rebase openssl-FIPS-enforce-EMS-support.patch- FIPS: Block non-Approved Elliptic Curves [bsc#1221786] * Add patches - openssl-Add-changes-to-ectest-and-eccurve.patch - openssl-Remove-EC-curves.patch - openssl-Disable-explicit-ec.patch - openssl-skipped-tests-EC-curves.patch - openssl-FIPS-services-minimize.patch - FIPS: Service Level Indicator [bsc#1221365] * Add patches: - openssl-FIPS-Expose-a-FIPS-indicator.patch - openssl-FIPS-Remove-X9.31-padding-from-FIPS-prov.patch - openssl-FIPS-Use-digest_sign-digest_verify-in-self-test.patch - openssl-FIPS-RSA-disable-shake.patch - openssl-FIPS-signature-Add-indicator-for-PSS-salt-length.patch - openssl-FIPS-Add-explicit-indicator-for-key-length.patch - openssl-FIPS-limit-rsa-encrypt.patch - openssl-FIPS-enforce-EMS-support.patch - openssl-3-FIPS-GCM-Implement-explicit-indicator-for-IV-gen.patch - openssl-FIPS-services-minimize.patch - openssl-Add-FIPS-indicator-parameter-to-HKDF.patch - openssl-rand-Forbid-truncated-hashes-SHA-3-in-FIPS-prov.patch - openssl-FIPS-enforce-security-checks-during-initialization.patch - TODO: incomplete - FIPS: Output the FIPS-validation name and module version which uniquely identify the FIPS validated module. [bsc#1221751] * Add openssl-FIPS-release_num_in_version_string.patch - FIPS: Add required selftests: [bsc#1221760] * Add patches - openssl-FIPS-Use-digest_sign-digest_verify-in-self-test.patch - openssl-FIPS-Use-FFDHE2048-in-self-test.patch - openssl-FIPS-early-KATS.patch - openssl-FIPS-Use-OAEP-in-KATs-support-fixed-OAEP-seed.patch - openssl-FIPS-140-3-keychecks.patch - FIPS: DH: Disable FIPS 186-4 Domain Parameters [bsc#1221821] Add openssl-DH-Disable-FIPS-186-4-type-parameters-in-FIPS-mode.patch - FIPS: Recommendation for Password-Based Key Derivation [bsc#1221827] * Add additional check required by FIPS 140-3. Minimum value for PBKDF2 password is 20 characters. * Add patches: - openssl-pbkdf2-Set-minimum-password-length-of-8-bytes.patch - openssl-pbkdf2-Set-indicator-if-pkcs5-param-disabled-checks.patch - FIPS: Zeroization is required [bsc#1221752] * Add openssl-FIPS-140-3-zeroization.patch - FIPS: Reseed DRBG [bsc#1220690, bsc#1220693, bsc#1220696] * Enable prediction resistance for primary DRBG * Add oversampling of the noise source to comply with requirements of NIST SP 800-90C * Change CRNG buf size to align with output size of the Jitter RNG * Add openssl-FIPS-140-3-DRBG.patch - FIPS: NIST SP 800-56Brev2 [bsc#1221824] * Add patches: - openssl-FIPS-limit-rsa-encrypt.patch - openssl-FIPS-RSA-encapsulate.patch - openssl-FIPS-Add-SP800-56Br2-6.4.1.2.1-3.c-check.patch - FIPS: Approved Modulus Sizes for RSA Digital Signature for FIPS 186-4 [bsc#1221787] * Add patches: - openssl-FIPS-services-minimize.patch - openssl-Revert-Improve-FIPS-RSA-keygen-performance.patch - openssl-Allow-disabling-of-SHA1-signatures.patch - openssl-Allow-SHA1-in-seclevel-2-if-rh-allow-sha1-signatures.patch - FIPS: Port openssl to use jitterentropy [bsc#1220523] * Add openssl-3-jitterentropy-3.4.0.patch * Add build dependency on jitterentropy-devel >= 3.4.0 and libjitterentropy3 >= 3.4.0 - FIPS: NIST SP 800-56Arev3 [bsc#1221822] * Add openssl-FIPS-140-3-keychecks.patch - FIPS: Error state has to be enforced [bsc#1221753] * Add patches: - openssl-FIPS-140-3-keychecks.patch - openssl-FIPS-Enforce-error-state.patch- Apply "openssl-CVE-2024-4741.patch" to fix a use-after-free security vulnerability. Calling the function SSL_free_buffers() potentially caused memory to be accessed that was previously freed in some situations and a malicious attacker could attempt to engineer a stituation where this occurs to facilitate a denial-of-service attack. [CVE-2024-4741, bsc#1225551]- Fix HDKF key derivation (bsc#1225291, gh#openssl/openssl#23448, gh#openssl/openssl#23456) * Add openssl-Fix-EVP_PKEY_CTX_add1_hkdf_info-behavior.patch * Add openssl-Handle-empty-param-in-EVP_PKEY_CTX_add1_hkdf_info.patch- Enable livepatching support (bsc#1223428)- Security fix: [bsc#1224388, CVE-2024-4603] * Check DSA parameters for excessive sizes before validating * Add openssl-CVE-2024-4603.patch- Security fix: [bsc#1222548, CVE-2024-2511] * Fix unconstrained session cache growth in TLSv1.3 * Add openssl-CVE-2024-2511.patch- Build the 32bit flavor of libopenssl-3-fips-provider [bsc#1220232] * Update baselibs.conf- Add migration script to move old files (bsc#1219562) /etc/ssl/engines.d/* -> /etc/ssl/engines1.1.d.rpmsave /etc/ssl/engdef.d/* -> /etc/ssl/engdef1.1.d.rpmsave They will be later restored by openssl-1_1 package to engines1.1.d and engdef1.1.d- Security fix: [bsc#1219243, CVE-2024-0727] * Add NULL checks where ContentInfo data can be NULL * Add openssl-CVE-2024-0727.patch- Encapsulate the fips provider into a new package called libopenssl-3-fips-provider.- Added openssl-3-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/engines3.d/ and /etc/ssl/engdef3.d/. Also create symbolic links /etc/ssl/engines.d/ and /etc/ssl/engdef.d/ to above versioned directories. - Updated spec file to create the two new necessary directores for the above patch and two symbolic links to above directories. [bsc#1194187, bsc#1207472, bsc#1218933]- Security fix: [bsc#1218810, CVE-2023-6237] * Limit the execution time of RSA public key check * Add openssl-CVE-2023-6237.patch- Rename openssl-Override-default-paths-for-the-CA-directory-tree.patch to openssl-crypto-policies-support.patch- Embed the FIPS hmac. Add openssl-FIPS-embed-hmac.patch- Load the FIPS provider and set FIPS properties implicitly. * Add openssl-Force-FIPS.patch [bsc#1217934] - Disable the fipsinstall command-line utility. * Add openssl-disable-fipsinstall.patch - Add instructions to load legacy provider in openssl.cnf. * openssl-load-legacy-provider.patch - Disable the default provider for the test suite. * openssl-Disable-default-provider-for-test-suite.patch- Security fix: [bsc#1218690, CVE-2023-6129] * POLY1305: Fix vector register clobbering on PowerPC * Add openssl-CVE-2023-6129.patch- Add patch to fix BTI enablement on aarch64: * openssl-Enable-BTI-feature-for-md5-on-aarch64.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- Update to 3.1.4: * Fix incorrect key and IV resizing issues when calling EVP_EncryptInit_ex2(), EVP_DecryptInit_ex2() or EVP_CipherInit_ex2() with OSSL_PARAM parameters that alter the key or IV length [bsc#1216163, CVE-2023-5363]. * Remove patch fixed upstream openssl-CVE-2023-5363.patch- Performance enhancements for cryptography from OpenSSL 3.2 [jsc#PED-5086, jsc#PED-3514] * Add patches: - openssl-ec-Use-static-linkage-on-nistp521-felem_-square-mul-.patch - openssl-ec-56-bit-Limb-Solinas-Strategy-for-secp384r1.patch - openssl-ec-powerpc64le-Add-asm-implementation-of-felem_-squa.patch - openssl-ecc-Remove-extraneous-parentheses-in-secp384r1.patch - openssl-powerpc-ecc-Fix-stack-allocation-secp384r1-asm.patch - openssl-Improve-performance-for-6x-unrolling-with-vpermxor-i.patch- FIPS: Add the FIPS_mode() compatibility macro and flag support. * Add patches: - openssl-Add-FIPS_mode-compatibility-macro.patch - openssl-Add-Kernel-FIPS-mode-flag-support.patch- Security fix: [bsc#1216163, CVE-2023-5363] * Incorrect cipher key and IV length processing * Add openssl-CVE-2023-5363.patch- As of openssl 3.1.3, the devel package installs at least 5200 manpage files and is the owner of the most files in the man3 directory (in second place after lapack-man); move these manpages off to the -doc subpackage to reduce the walltime to install just openssl-3-devel (because there is also an invocation of mandb that runs at some point).- Update to 3.1.3: * Fix POLY1305 MAC implementation corrupting XMM registers on Windows (CVE-2023-4807)- Update to 3.1.2: * 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. * Fix DH_check() excessive time with over sized modulus (bsc#1213487, CVE-2023-3446). 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. * Do not ignore empty associated data entries with AES-SIV (bsc#1213383, CVE-2023-2975). The AES-SIV algorithm allows for authentication of multiple associated data entries along with the encryption. To authenticate empty data the application has to call EVP_EncryptUpdate() (or EVP_CipherUpdate()) with NULL pointer as the output buffer and 0 as the input buffer length. The AES-SIV implementation in OpenSSL just returns success for such call instead of performing the associated data authentication operation. The empty data thus will not be authenticated. The fix changes the authentication tag value and the ciphertext for applications that use empty associated data entries with AES-SIV. To decrypt data encrypted with previous versions of OpenSSL the application has to skip calls to EVP_DecryptUpdate() for empty associated data entries. * When building with the enable-fips option and using the resulting FIPS provider, TLS 1.2 will, by default, mandate the use of an extended master secret (FIPS 140-3 IG G.Q) and the Hash and HMAC DRBGs will not operate with truncated digests (FIPS 140-3 IG G.R). * Update openssl.keyring with the OTC members that sign releases * Remove openssl-z16-s390x.patch fixed upstream in https://github.com/openssl/openssl/pull/21284 * Remove security patches fixed upstream: - openssl-CVE-2023-2975.patch - openssl-CVE-2023-3446.patch - openssl-CVE-2023-3446-test.patch - openssl-3-CVE-2023-3817.patch- Security fix: [bsc#1213853, CVE-2023-3817] * Excessive time spent checking DH q parameter value: 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-3-CVE-2023-3817.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- Security fix: [bsc#1213383, CVE-2023-2975] * AES-SIV implementation ignores empty associated data entries * Add openssl-CVE-2023-2975.patch- Improve cross-package provides/conflicts [boo#1210313] * Add Provides/Conflicts: ssl-devel * Remove explicit conflicts with other devel-libraries * Remove Provides: openssl(cli) - it's managed by meta package- Update to 3.1.1: * Restrict the size of OBJECT IDENTIFIERs that OBJ_obj2txt will translate (CVE-2023-2650, bsc#1211430) * Multiple algorithm implementation fixes for ARM BE platforms. * Added a -pedantic option to fipsinstall that adjusts the various settings to ensure strict FIPS compliance rather than backwards compatibility. * Fixed buffer overread in AES-XTS decryption on ARM 64 bit platforms which happens if the buffer size is 4 mod 5 in 16 byte AES blocks. This can trigger a crash of an application using AES-XTS decryption if the memory just after the buffer being decrypted is not mapped. Thanks to Anton Romanov (Amazon) for discovering the issue. (CVE-2023-1255, bsc#1210714) * Add FIPS provider configuration option to disallow the use of truncated digests with Hash and HMAC DRBGs (q.v. FIPS 140-3 IG D.R.). The option '-no_drbg_truncated_digests' can optionally be supplied to 'openssl fipsinstall'. * Corrected documentation of X509_VERIFY_PARAM_add0_policy() to mention that it does not enable policy checking. Thanks to David Benjamin for discovering this issue. (CVE-2023-0466, bsc#1209873) * Fixed an issue where invalid certificate policies in leaf certificates are silently ignored by OpenSSL and other certificate policy checks are skipped for that certificate. A malicious CA could use this to deliberately assert invalid certificate policies in order to circumvent policy checking on the certificate altogether. (CVE-2023-0465, bsc#1209878) * Limited the number of nodes created in a policy tree to mitigate against CVE-2023-0464. The default limit is set to 1000 nodes, which should be sufficient for most installations. If required, the limit can be adjusted by setting the OPENSSL_POLICY_TREE_NODES_MAX build time define to a desired maximum number of nodes or zero to allow unlimited growth. (CVE-2023-0464, bsc#1209624) * Update openssl.keyring with key A21F AB74 B008 8AA3 6115 2586 B8EF 1A6B A9DA 2D5C (Tomas Mraz) * Rebased patches: - openssl-Add-support-for-PROFILE-SYSTEM-system-default-cipher.patch - openssl-Add_support_for_Windows_CA_certificate_store.patch * Removed patches: - openssl-CVE-2023-0464.patch - openssl-Fix-OBJ_nid2obj-regression.patch - openssl-CVE-2023-0465.patch - openssl-CVE-2023-0466.patch - openssl-CVE-2023-1255.patch - openssl-CVE-2023-2650.patch- FIPS: Merge libopenssl3-hmac package into the library [bsc#1185116]- Security Fix: [CVE-2023-1255, bsc#1210714] * Input buffer over-read in AES-XTS implementation on 64 bit ARM * Add openssl-CVE-2023-1255.patch - Security Fix: [CVE-2023-2650, bsc#1211430] * Possible DoS translating ASN.1 object identifiers * Add openssl-CVE-2023-2650.patch- Add support for Windows CA certificate store [bsc#1209430] https://github.com/openssl/openssl/pull/18070 * Add openssl-Add_support_for_Windows_CA_certificate_store.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- Fix regression in the OBJ_nid2obj() function: [bsc#1209430] * Upstream https://github.com/openssl/openssl/issues/20555 * Add openssl-Fix-OBJ_nid2obj-regression.patch- Fix compiler error "initializer element is not constant" on s390 * Add openssl-z16-s390x.patch- Security Fix: [CVE-2023-0464, bsc#1209624] * Excessive Resource Usage Verifying X.509 Policy Constraints * Add openssl-CVE-2023-0464.patch- Pass over with spec-cleaner- Update to 3.1.0: * Add FIPS provider configuration option to enforce the Extended Master Secret (EMS) check during the TLS1_PRF KDF. The option '-ems-check' can optionally be supplied to 'openssl fipsinstall'. * The FIPS provider includes a few non-approved algorithms for backward compatibility purposes and the "fips=yes" property query must be used for all algorithm fetches to ensure FIPS compliance. The algorithms that are included but not approved are Triple DES ECB, Triple DES CBC and EdDSA. * Added support for KMAC in KBKDF. * RNDR and RNDRRS support in provider functions to provide random number generation for Arm CPUs (aarch64). * s_client and s_server apps now explicitly say when the TLS version does not include the renegotiation mechanism. This avoids confusion between that scenario versus when the TLS version includes secure renegotiation but the peer lacks support for it. * AES-GCM enabled with AVX512 vAES and vPCLMULQDQ. * The various OBJ_* functions have been made thread safe. * Parallel dual-prime 1536/2048-bit modular exponentiation for AVX512_IFMA capable processors. * The functions OPENSSL_LH_stats, OPENSSL_LH_node_stats, OPENSSL_LH_node_usage_stats, OPENSSL_LH_stats_bio, OPENSSL_LH_node_stats_bio and OPENSSL_LH_node_usage_stats_bio are now marked deprecated from OpenSSL 3.1 onwards and can be disabled by defining OPENSSL_NO_DEPRECATED_3_1. The macro DEFINE_LHASH_OF is now deprecated in favour of the macro DEFINE_LHASH_OF_EX, which omits the corresponding type-specific function definitions for these functions regardless of whether OPENSSL_NO_DEPRECATED_3_1 is defined. Users of DEFINE_LHASH_OF may start receiving deprecation warnings for these functions regardless of whether they are using them. It is recommended that users transition to the new macro, DEFINE_LHASH_OF_EX. * When generating safe-prime DH parameters set the recommended private key length equivalent to minimum key lengths as in RFC 7919. * Change the default salt length for PKCS#1 RSASSA-PSS signatures to the maximum size that is smaller or equal to the digest length to comply with FIPS 186-4 section 5. This is implemented by a new option OSSL_PKEY_RSA_PSS_SALT_LEN_AUTO_DIGEST_MAX ("auto-digestmax") for the rsa_pss_saltlen parameter, which is now the default. Signature verification is not affected by this change and continues to work as before. * Update openssl.keyring with key 8657 ABB2 60F0 56B1 E519 0839 D9C4 D26D 0E60 4491 (Matt Caswell)- Build AVX2 enabled hwcaps library for x86_64-v3- Update to version 3.0.8 in SLE15-SP5 [jsc#PED-544] * Fixed NULL dereference during PKCS7 data verification. A NULL pointer can be dereferenced when signatures are being verified on PKCS7 signed or signedAndEnveloped data. In case the hash algorithm used for the signature is known to the OpenSSL library but the implementation of the hash algorithm is not available the digest initialization will fail. There is a missing check for the return value from the initialization function which later leads to invalid usage of the digest API most likely leading to a crash. ([bsc#1207541, CVE-2023-0401]) PKCS7 data is processed by the SMIME library calls and also by the time stamp (TS) library calls. The TLS implementation in OpenSSL does not call these functions however third party applications would be affected if they call these functions to verify signatures on untrusted data. * Fixed X.400 address type confusion in X.509 GeneralName. There is a type confusion vulnerability relating to X.400 address processing inside an X.509 GeneralName. X.400 addresses were parsed as an ASN1_STRING but the public structure definition for GENERAL_NAME incorrectly specified the type of the x400Address field as ASN1_TYPE. This field is subsequently interpreted by the OpenSSL function GENERAL_NAME_cmp as an ASN1_TYPE rather than an ASN1_STRING. When CRL checking is enabled (i.e. the application sets the X509_V_FLAG_CRL_CHECK flag), this vulnerability may allow an attacker to pass arbitrary pointers to a memcmp call, enabling them to read memory contents or enact a denial of service. ([bsc#1207533, CVE-2023-0286]) * Fixed NULL dereference validating DSA public key. An invalid pointer dereference on read can be triggered when an application tries to check a malformed DSA public key by the EVP_PKEY_public_check() function. This will most likely lead to an application crash. This function can be called on public keys supplied from untrusted sources which could allow an attacker to cause a denial of service attack. The TLS implementation in OpenSSL does not call this function but applications might call the function if there are additional security requirements imposed by standards such as FIPS 140-3. ([bsc#1207540, CVE-2023-0217]) * Fixed Invalid pointer dereference in d2i_PKCS7 functions. An invalid pointer dereference on read can be triggered when an application tries to load malformed PKCS7 data with the d2i_PKCS7(), d2i_PKCS7_bio() or d2i_PKCS7_fp() functions. The result of the dereference is an application crash which could lead to a denial of service attack. The TLS implementation in OpenSSL does not call this function however third party applications might call these functions on untrusted data. ([bsc#1207539, CVE-2023-0216]) * Fixed Use-after-free following BIO_new_NDEF. The public API function BIO_new_NDEF is a helper function used for streaming ASN.1 data via a BIO. It is primarily used internally to OpenSSL to support the SMIME, CMS and PKCS7 streaming capabilities, but may also be called directly by end user applications. The function receives a BIO from the caller, prepends a new BIO_f_asn1 filter BIO onto the front of it to form a BIO chain, and then returns the new head of the BIO chain to the caller. Under certain conditions, for example if a CMS recipient public key is invalid, the new filter BIO is freed and the function returns a NULL result indicating a failure. However, in this case, the BIO chain is not properly cleaned up and the BIO passed by the caller still retains internal pointers to the previously freed filter BIO. If the caller then goes on to call BIO_pop() on the BIO then a use-after-free will occur. This will most likely result in a crash. ([bsc#1207536, CVE-2023-0215]) * Fixed Double free after calling PEM_read_bio_ex. The function PEM_read_bio_ex() reads a PEM file from a BIO and parses and decodes the "name" (e.g. "CERTIFICATE"), any header data and the payload data. If the function succeeds then the "name_out", "header" and "data" arguments are populated with pointers to buffers containing the relevant decoded data. The caller is responsible for freeing those buffers. It is possible to construct a PEM file that results in 0 bytes of payload data. In this case PEM_read_bio_ex() will return a failure code but will populate the header argument with a pointer to a buffer that has already been freed. If the caller also frees this buffer then a double free will occur. This will most likely lead to a crash. The functions PEM_read_bio() and PEM_read() are simple wrappers around PEM_read_bio_ex() and therefore these functions are also directly affected. These functions are also called indirectly by a number of other OpenSSL functions including PEM_X509_INFO_read_bio_ex() and SSL_CTX_use_serverinfo_file() which are also vulnerable. Some OpenSSL internal uses of these functions are not vulnerable because the caller does not free the header argument if PEM_read_bio_ex() returns a failure code. ([bsc#1207538, CVE-2022-4450]) * Fixed Timing Oracle in RSA Decryption. A timing based side channel exists in the OpenSSL RSA Decryption implementation which could be sufficient to recover a plaintext across a network in a Bleichenbacher style attack. To achieve a successful decryption an attacker would have to be able to send a very large number of trial messages for decryption. The vulnerability affects all RSA padding modes: PKCS#1 v1.5, RSA-OEAP and RSASVE. ([bsc#1207534, CVE-2022-4304]) * Fixed X.509 Name Constraints Read Buffer Overflow. A read buffer overrun can be triggered in X.509 certificate verification, specifically in name constraint checking. The read buffer overrun might result in a crash which could lead to a denial of service attack. In a TLS client, this can be triggered by connecting to a malicious server. In a TLS server, this can be triggered if the server requests client authentication and a malicious client connects. ([bsc#1207535, CVE-2022-4203]) * Fixed X.509 Policy Constraints Double Locking security issue. If an X.509 certificate contains a malformed policy constraint and policy processing is enabled, then a write lock will be taken twice recursively. On some operating systems (most widely: Windows) this results in a denial of service when the affected process hangs. Policy processing being enabled on a publicly facing server is not considered to be a common setup. ([CVE-2022-3996]) * Our provider implementations of `OSSL_FUNC_KEYMGMT_EXPORT` and `OSSL_FUNC_KEYMGMT_GET_PARAMS` for EC and SM2 keys now honor `OSSL_PKEY_PARAM_EC_POINT_CONVERSION_FORMAT` as set (and default to `POINT_CONVERSION_UNCOMPRESSED`) when exporting `OSSL_PKEY_PARAM_PUB_KEY`, instead of unconditionally using `POINT_CONVERSION_COMPRESSED` as in previous 3.x releases. For symmetry, our implementation of `EVP_PKEY_ASN1_METHOD->export_to` for legacy EC and SM2 keys is also changed similarly to honor the equivalent conversion format flag as specified in the underlying `EC_KEY` object being exported to a provider, when this function is called through `EVP_PKEY_export()`. * Removed openssl-3-Fix-double-locking-problem.patch, contained in upstream. * Rebased openssl-Add-support-for-PROFILE-SYSTEM-system-default-cipher.patch * Update openssl.keyring with key 7953 AC1F BC3D C8B3 B292 393E D5E9 E43F 7DF9 EE8C (Richard Levitte)- Relax the crypto-policies requirements for the regression tests- Set OpenSSL 3.0.7 as the default openssl [bsc#1205042] * Rename openssl-1.1.0-no-html.patch to openssl-no-html-docs.patch * Rebase openssl-Add-support-for-PROFILE-SYSTEM-system-default-cipher.patch * Package a copy of the original default config file called openssl.cnf and name it as openssl-orig.cnf and warn the user if the files differ. * Add openssl-3-devel as conflicting with libopenssl-1_1-devel * Remove patches: - fix-config-in-tests.patch - openssl-use-versioned-config.patch- Create the openssl ca-certificates directory in case the ca-certificates package is not installed. This directory is required by the nodejs regression tests. [bsc#1207484]- Update openssl.keyring: pub rsa4096 2021-07-16 [SC] [expires: 2031-07-14] A21FAB74B0088AA361152586B8EF1A6BA9DA2D5C uid Tomáš Mráz uid Tomáš Mráz uid Tomáš Mráz - Update to version 3.0.7 in SLE15-SP5 [jsc#PED-544] - Remove patches (already present in 3.0.7): * openssl-3-CVE-2022-1343.patch * openssl-CVE-2022-0778.patch * openssl-CVE-2022-0778-tests.patch * openssl-CVE-2022-1292.patch * openssl-3-Fix-EC-ASM-flag-passing.patch * openssl-update_expired_certificates.patch * openssl-3-CVE-2022-3358.patch * openssl-3-Fix-SHA-SHAKE-and-KECCAK-ASM-flag-passing.patch * openssl-3-CVE-2022-3602_2.patch * openssl-3-CVE-2022-3602_1.patch * openssl-CVE-2022-2097.patch * openssl-3-CVE-2022-1434.patch * openssl-3-CVE-2022-1473.patch * openssl-3-Fix-file-operations-in-c_rehash.patch - Enable tests: test_req test_verify_store test_ca test_ssl_old- Fix X.509 Policy Constraints Double Locking [bsc#1206374, CVE-2022-3996] * Add patch: openssl-3-Fix-double-locking-problem.patch- Compute the hmac files for FIPS 140-3 integrity checking of the openssl shared libraries using the brp-50-generate-fips-hmac script. Also computed for the 32bit package.- Temporary disable tests test_ssl_new and test_sslapi because they are failing in openSUSE_Tumbleweed- Update to 3.0.7: [bsc#1204714, CVE-2022-3602,CVE-2022-3786] * Fixed two buffer overflows in punycode decoding functions. A buffer overrun can be triggered in X.509 certificate verification, specifically in name constraint checking. Note that this occurs after certificate chain signature verification and requires either a CA to have signed the malicious certificate or for the application to continue certificate verification despite failure to construct a path to a trusted issuer. In a TLS client, this can be triggered by connecting to a malicious server. In a TLS server, this can be triggered if the server requests client authentication and a malicious client connects. An attacker can craft a malicious email address to overflow an arbitrary number of bytes containing the `.` character (decimal 46) on the stack. This buffer overflow could result in a crash (causing a denial of service). ([CVE-2022-3786]) An attacker can craft a malicious email address to overflow four attacker-controlled bytes on the stack. This buffer overflow could result in a crash (causing a denial of service) or potentially remote code execution depending on stack layout for any given platform/compiler. ([CVE-2022-3602]) * Removed all references to invalid OSSL_PKEY_PARAM_RSA names for CRT parameters in OpenSSL code. Applications should not use the names OSSL_PKEY_PARAM_RSA_FACTOR, OSSL_PKEY_PARAM_RSA_EXPONENT and OSSL_PKEY_PARAM_RSA_COEFFICIENT. Use the numbered names such as OSSL_PKEY_PARAM_RSA_FACTOR1 instead. Using these invalid names may cause algorithms to use slower methods that ignore the CRT parameters. * Fixed a regression introduced in 3.0.6 version raising errors on some stack operations. * Fixed a regression introduced in 3.0.6 version not refreshing the certificate data to be signed before signing the certificate. * Added RIPEMD160 to the default provider. * Ensured that the key share group sent or accepted for the key exchange is allowed for the protocol version.- Update to 3.0.6: [bsc#1204226, CVE-2022-3358] * OpenSSL supports creating a custom cipher via the legacy EVP_CIPHER_meth_new() function and associated function calls. This function was deprecated in OpenSSL 3.0 and application authors are instead encouraged to use the new provider mechanism in order to implement custom ciphers. * OpenSSL versions 3.0.0 to 3.0.5 incorrectly handle legacy custom ciphers passed to the EVP_EncryptInit_ex2(), EVP_DecryptInit_ex2() and EVP_CipherInit_ex2() functions (as well as other similarly named encryption and decryption initialisation functions). Instead of using the custom cipher directly it incorrectly tries to fetch an equivalent cipher from the available providers. An equivalent cipher is found based on the NID passed to EVP_CIPHER_meth_new(). This NID is supposed to represent the unique NID for a given cipher. However it is possible for an application to incorrectly pass NID_undef as this value in the call to EVP_CIPHER_meth_new(). When NID_undef is used in this way the OpenSSL encryption/decryption initialisation function will match the NULL cipher as being equivalent and will fetch this from the available providers. This will succeed if the default provider has been loaded (or if a third party provider has been loaded that offers this cipher). Using the NULL cipher means that the plaintext is emitted as the ciphertext. * Applications are only affected by this issue if they call EVP_CIPHER_meth_new() using NID_undef and subsequently use it in a call to an encryption/decryption initialisation function. Applications that only use SSL/TLS are not impacted by this issue. ([CVE-2022-3358]) * Fix LLVM vs Apple LLVM version numbering confusion that caused build failures on MacOS 10.11 * Fixed the linux-mips64 Configure target which was missing the SIXTY_FOUR_BIT bn_ops flag. This was causing heap corruption on that platform. * Fix handling of a ticket key callback that returns 0 in TLSv1.3 to not send a ticket * Correctly handle a retransmitted ClientHello in DTLS * Fixed detection of ktls support in cross-compile environment on Linux * Fixed some regressions and test failures when running the 3.0.0 FIPS provider against 3.0.x * Fixed SSL_pending() and SSL_has_pending() with DTLS which were failing to report correct results in some cases * Fix UWP builds by defining VirtualLock * For known safe primes use the minimum key length according to RFC 7919. Longer private key sizes unnecessarily raise the cycles needed to compute the shared secret without any increase of the real security. This fixes a regression from 1.1.1 where these shorter keys were generated for the known safe primes. * Added the loongarch64 target * Fixed EC ASM flag passing. Flags for ASM implementations of EC curves were only passed to the FIPS provider and not to the default or legacy provider. * Fixed reported performance degradation on aarch64. Restored the implementation prior to commit 2621751 ("aes/asm/aesv8-armx.pl: avoid 32-bit lane assignment in CTR mode") for 64bit targets only, since it is reportedly 2-17% slower and the silicon errata only affects 32bit targets. The new algorithm is still used for 32 bit targets. * Added a missing header for memcmp that caused compilation failure on some platforms- Do not make libopenssl3-32bit obsolete libopenssl1_1-32bit. They are independent libraries and can be installed simultaneously.- Update to 3.0.5: * The OpenSSL 3.0.4 release introduced a serious bug in the RSA implementation for X86_64 CPUs supporting the AVX512IFMA instructions. This issue makes the RSA implementation with 2048 bit private keys incorrect on such machines and memory corruption will happen during the computation. As a consequence of the memory corruption an attacker may be able to trigger a remote code execution on the machine performing the computation. SSL/TLS servers or other servers using 2048 bit RSA private keys running on machines supporting AVX512IFMA instructions of the X86_64 architecture are affected by this issue. [bsc#1201148, CVE-2022-2274] * AES OCB mode for 32-bit x86 platforms using the AES-NI assembly optimised implementation would not encrypt the entirety of the data under some circumstances. This could reveal sixteen bytes of data that was preexisting in the memory that wasn't written. In the special case of "in place" encryption, sixteen bytes of the plaintext would be revealed. Since OpenSSL does not support OCB based cipher suites for TLS and DTLS, they are both unaffected. [bsc#1201099, CVE-2022-2097] - Rebase patches: * openssl-Add-support-for-PROFILE-SYSTEM-system-default-cipher.patch- Update to 3.0.4: [bsc#1199166, bsc#1200550, CVE-2022-1292, CVE-2022-2068] * In addition to the c_rehash shell command injection identified in CVE-2022-1292, further bugs where the c_rehash script does not properly sanitise shell metacharacters to prevent command injection have been fixed. When the CVE-2022-1292 was fixed it was not discovered that there are other places in the script where the file names of certificates being hashed were possibly passed to a command executed through the shell. This script is distributed by some operating systems in a manner where it is automatically executed. On such operating systems, an attacker could execute arbitrary commands with the privileges of the script. Use of the c_rehash script is considered obsolete and should be replaced by the OpenSSL rehash command line tool. * Case insensitive string comparison no longer uses locales. It has instead been directly implemented.- Update to 3.0.3: * Case insensitive string comparison is reimplemented via new locale-agnostic comparison functions OPENSSL_str[n]casecmp always using the POSIX locale for comparison. The previous implementation had problems when the Turkish locale was used. * Fixed a bug in the c_rehash script which was not properly sanitising shell metacharacters to prevent command injection. This script is distributed by some operating systems in a manner where it is automatically executed. On such operating systems, an attacker could execute arbitrary commands with the privileges of the script. Use of the c_rehash script is considered obsolete and should be replaced by the OpenSSL rehash command line tool. [bsc#1199166, CVE-2022-1292] * Fixed a bug in the function 'OCSP_basic_verify' that verifies the signer certificate on an OCSP response. The bug caused the function in the case where the (non-default) flag OCSP_NOCHECKS is used to return a postivie response (meaning a successful verification) even in the case where the response signing certificate fails to verify. It is anticipated that most users of 'OCSP_basic_verify' will not use the OCSP_NOCHECKS flag. In this case the 'OCSP_basic_verify' function will return a negative value (indicating a fatal error) in the case of a certificate verification failure. The normal expected return value in this case would be 0. This issue also impacts the command line OpenSSL "ocsp" application. When verifying an ocsp response with the "-no_cert_checks" option the command line application will report that the verification is successful even though it has in fact failed. In this case the incorrect successful response will also be accompanied by error messages showing the failure and contradicting the apparently successful result. [bsc#1199167, CVE-2022-1343] * Fixed a bug where the RC4-MD5 ciphersuite incorrectly used the AAD data as the MAC key. This made the MAC key trivially predictable. An attacker could exploit this issue by performing a man-in-the-middle attack to modify data being sent from one endpoint to an OpenSSL 3.0 recipient such that the modified data would still pass the MAC integrity check. Note that data sent from an OpenSSL 3.0 endpoint to a non-OpenSSL 3.0 endpoint will always be rejected by the recipient and the connection will fail at that point. Many application protocols require data to be sent from the client to the server first. Therefore, in such a case, only an OpenSSL 3.0 server would be impacted when talking to a non-OpenSSL 3.0 client. [bsc#1199168, CVE-2022-1434] * Fix a bug in the OPENSSL_LH_flush() function that breaks reuse of the memory occuppied by the removed hash table entries. This function is used when decoding certificates or keys. If a long lived process periodically decodes certificates or keys its memory usage will expand without bounds and the process might be terminated by the operating system causing a denial of service. Also traversing the empty hash table entries will take increasingly more time. Typically such long lived processes might be TLS clients or TLS servers configured to accept client certificate authentication. [bsc#1199169, CVE-2022-1473] * The functions 'OPENSSL_LH_stats' and 'OPENSSL_LH_stats_bio' now only report the 'num_items', 'num_nodes' and 'num_alloc_nodes' statistics. All other statistics are no longer supported. For compatibility, these statistics are still listed in the output but are now always reported as zero.- Added openssl-update_expired_certificates.patch * Openssl failed tests because of expired certificates. * bsc#1185637- Enable zlib compression support [bsc#1195149]- Add crypto-policies support. * Fix some tests that couldn't find the openssl3.cnf location * Rebase patch: openssl-Add-support-for-PROFILE-SYSTEM-system-default-cipher.patch- Update to 3.0.2: [bsc#1196877, CVE-2022-0778] * Security fix [CVE-2022-0778]: Infinite loop for non-prime moduli in BN_mod_sqrt() reachable when parsing certificates. * Add ciphersuites based on DHE_PSK (RFC 4279) and ECDHE_PSK (RFC 5489) to the list of ciphersuites providing Perfect Forward Secrecy as required by SECLEVEL >= 3. * Made the AES constant time code for no-asm configurations optional due to the resulting 95% performance degradation. The AES constant time code can be enabled, for no assembly builds, with: ./config no-asm -DOPENSSL_AES_CONST_TIME * Fixed PEM_write_bio_PKCS8PrivateKey() to make it possible to use empty passphrase strings. * The negative return value handling of the certificate verification callback was reverted. The replacement is to set the verification retry state with the SSL_set_retry_verify() function. * Rebase openssl-use-versioned-config.patch- Keep CA_default and tsa_config1 default paths in openssl3.cnf - Rebase patches: * openssl-Override-default-paths-for-the-CA-directory-tree.patch * openssl-use-versioned-config.patch- Fix conflict with openssl and libressl- Remove /etc/pki/CA from the [jsc#SLE-17856, jsc#SLE-19044] openssl-Override-default-paths-for-the-CA-directory-tree.patch - Remove unused patches- Ship openssl-3 as binary names [jsc#SLE-17856, jsc#SLE-19044] - Use openssl3.cnf * openssl-use-versioned-config.patch * fix-config-in-tests.patch - Support crypto policies * openssl-Add-support-for-PROFILE-SYSTEM-system-default-cipher.patch * openssl-Override-default-paths-for-the-CA-directory-tree.patch - Remove obsolets, not ready to force an upgrade yet- Update to 3.0.1: [bsc#1193740, CVE-2021-4044] * RNDR and RNDRRS support in provider functions to provide random number generation for Arm CPUs (aarch64). * s_client and s_server apps now explicitly say when the TLS version does not include the renegotiation mechanism. This avoids confusion between that scenario versus when the TLS version includes secure renegotiation but the peer lacks support for it. * The default SSL/TLS security level has been changed from 1 to 2. RSA, DSA and DH keys of 1024 bits and above and less than 2048 bits and ECC keys of 160 bits and above and less than 224 bits were previously accepted by default but are now no longer allowed. By default TLS compression was already disabled in previous OpenSSL versions. At security level 2 it cannot be enabled. * The SSL_CTX_set_cipher_list family functions now accept ciphers using their IANA standard names. * The PVK key derivation function has been moved from b2i_PVK_bio_ex() into the legacy crypto provider as an EVP_KDF. Applications requiring this KDF will need to load the legacy crypto provider. * The various OBJ_* functions have been made thread safe. * CCM8 cipher suites in TLS have been downgraded to security level zero because they use a short authentication tag which lowers their strength. * Subject or issuer names in X.509 objects are now displayed as UTF-8 strings by default. * Parallel dual-prime 1536/2048-bit modular exponentiation for AVX512_IFMA capable processors.- Update to 3.0.0 * The full list of changes since version 1.1.1 can be found in: https://github.com/openssl/openssl/blob/master/CHANGES.md#openssl-30 * OpenSSL 3.0 wiki: https://wiki.openssl.org/index.php/OpenSSL_3.0 * The Migration guide: https://github.com/openssl/openssl/blob/master/doc/man7/migration_guide.pod- Update to 3.0.0 Beta 2 * The ERR_GET_FUNC() function was removed. With the loss of meaningful function codes, this function can only cause problems for calling applications. * While a callback function set via 'SSL_CTX_set_cert_verify_callback()' is not allowed to return a value > 1, this is no more taken as failure. * Deprecated the obsolete X9.31 RSA key generation related functions BN_X931_generate_Xpq(), BN_X931_derive_prime_ex(), and BN_X931_generate_prime_ex(). - Remove openssl-ppc64-fix-build.patch fixed upstream- Update to 3.0.0 Beta 1 * Add a configurable flag to output date formats as ISO 8601. Does not change the default date format. * Version of MSVC earlier than 1300 could get link warnings, which could be suppressed if the undocumented -DI_CAN_LIVE_WITH_LNK4049 was set. Support for this flag has been removed. * Rework and make DEBUG macros consistent. Remove unused - DCONF_DEBUG, -DBN_CTX_DEBUG, and REF_PRINT. Add a new tracing category and use it for printing reference counts. Rename - DDEBUG_UNUSED to -DUNUSED_RESULT_DEBUG. Fix BN_DEBUG_RAND so it compiles and, when set, force DEBUG_RAND to be set also. Rename engine_debug_ref to be ENGINE_REF_PRINT also for consistency. * The public definitions of conf_method_st and conf_st have been deprecated. They will be made opaque in a future release. * Many functions in the EVP_ namespace that are getters of values from implementations or contexts were renamed to include get or get0 in their names. Old names are provided as macro aliases for compatibility and are not deprecated. * PKCS#5 PBKDF1 key derivation has been moved from PKCS5_PBE_keyivgen() into the legacy crypto provider as an EVP_KDF. Applications requiring this KDF will need to load the legacy crypto provider. This includes these PBE algorithms which use this KDF: - NID_pbeWithMD2AndDES_CBC - NID_pbeWithMD5AndDES_CBC - NID_pbeWithSHA1AndRC2_CBC - NID_pbeWithMD2AndRC2_CBC - NID_pbeWithMD5AndRC2_CBC - NID_pbeWithSHA1AndDES_CBC * Deprecated obsolete BIO_set_callback(), BIO_get_callback(), and BIO_debug_callback() functions. - Fix build on ppc and ppc64 * Add openssl-ppc64-fix-build.patch * See https://github.com/openssl/openssl/issues/15923- Update to 3.0.0 Alpha 17 * Added migration guide to man7 * Implemented support for fully "pluggable" TLSv1.3 groups * Added convenience functions for generating asymmetric key pairs. * Added a proper HTTP client supporting GET with optional redirection, POST, arbitrary request and response content types, TLS, persistent connections, connections via HTTP(s) proxies, connections and exchange via user-defined BIOs (allowing implicit connections), and timeout checks.- Update to 3.0.0. Alpha 16 * Mark pop/clear error stack in der2key_decode_p8- Update to 3.0.0 Alpha 15 * The default manual page suffix ($MANSUFFIX) has been changed to "ossl" * Added support for Kernel TLS (KTLS). In order to use KTLS, support for it must be compiled in using the "enable-ktls" compile time option. It must also be enabled at run time using the SSL_OP_ENABLE_KTLS option. * The error return values from some control calls (ctrl) have changed. One significant change is that controls which used to return -2 for invalid inputs, now return -1 indicating a generic error condition instead. * Removed EVP_PKEY_set_alias_type(). * All of these low level RSA functions have been deprecated without replacement: RSA_blinding_off, RSA_blinding_on, RSA_clear_flags, RSA_get_version, RSAPrivateKey_dup, RSAPublicKey_dup, RSA_set_flags, RSA_setup_blinding and RSA_test_flags. * All of these RSA flags have been deprecated without replacement: RSA_FLAG_BLINDING, RSA_FLAG_CACHE_PRIVATE, RSA_FLAG_CACHE_PUBLIC, RSA_FLAG_EXT_PKEY, RSA_FLAG_NO_BLINDING, RSA_FLAG_THREAD_SAFE and RSA_METHOD_FLAG_NO_CHECK. * These low level DH functions have been deprecated without replacement: DH_clear_flags, DH_get_1024_160, DH_get_2048_224, DH_get_2048_256, DH_set_flags and DH_test_flags. The DH_FLAG_CACHE_MONT_P flag has been deprecated without replacement. The DH_FLAG_TYPE_DH and DH_FLAG_TYPE_DHX have been deprecated. Use EVP_PKEY_is_a() to determine the type of a key. There is no replacement for setting these flags. * These low level DSA functions have been deprecated without replacement: DSA_clear_flags, DSA_dup_DH, DSAparams_dup, DSA_set_flags and DSA_test_flags. * The DSA_FLAG_CACHE_MONT_P flag has been deprecated without replacement. * Reworked the treatment of EC EVP_PKEYs with the SM2 curve to automatically become EVP_PKEY_SM2 rather than EVP_PKEY_EC. This is a breaking change from previous OpenSSL versions. Unlike in previous OpenSSL versions, this means that applications must not call 'EVP_PKEY_set_alias_type(pkey, EVP_PKEY_SM2)' to get SM2 computations. The 'EVP_PKEY_set_alias_type' function has now been removed. * Parameter and key generation is also reworked to make it possible to generate EVP_PKEY_SM2 parameters and keys. Applications must now generate SM2 keys directly and must not create an EVP_PKEY_EC key first.- Update to 3.0.0 Alpha 14 * A public key check is now performed during EVP_PKEY_derive_set_peer(). Previously DH was internally doing this during EVP_PKEY_derive(). * The EVP_PKEY_CTRL_PKCS7_ENCRYPT, EVP_PKEY_CTRL_PKCS7_DECRYPT, EVP_PKEY_CTRL_PKCS7_SIGN, EVP_PKEY_CTRL_CMS_ENCRYPT, EVP_PKEY_CTRL_CMS_DECRYPT, and EVP_PKEY_CTRL_CMS_SIGN control operations are deprecated. They are not invoked by the OpenSSL library anymore and are replaced by direct checks of the key operation against the key type when the operation is initialized. * The EVP_PKEY_public_check() and EVP_PKEY_param_check() functions now work for more key types including RSA, DSA, ED25519, X25519, ED448 and X448. Previously (in 1.1.1) they would return -2. For key types that do not have parameters then EVP_PKEY_param_check() will always return 1. * The output from numerous "printing" functions such as X509_signature_print(), X509_print_ex(), X509_CRL_print_ex(), and other similar functions has been amended such that there may be cosmetic differences between the output observed in 1.1.1 and 3.0. This also applies to the "-text" output from the x509 and crl applications. * Improved adherence to Enhanced Security Services (ESS, RFC 2634 and RFC 5035) for the TSP and CMS Advanced Electronic Signatures (CAdES) implementations. As required by RFC 5035 check both ESSCertID and ESSCertIDv2 if both present. Correct the semantics of checking the validation chain in case ESSCertID{,v2} contains more than one certificate identifier: This means that all certificates referenced there MUST be part of the validation chain. * Parallel dual-prime 1024-bit modular exponentiation for AVX512_IFMA capable processors. * Added the AuthEnvelopedData content type structure (RFC 5083) with AES-GCM parameter (RFC 5084) for the Cryptographic Message Syntax (CMS). Its purpose is to support encryption and decryption of a digital envelope that is both authenticated and encrypted using AES GCM mode.- Update to 3.0.0 Alpha 13 * A public key check is now performed during EVP_PKEY_derive_set_peer(). Previously DH was internally doing this during EVP_PKEY_derive(). To disable this check use EVP_PKEY_derive_set_peer_ex(dh, peer, 0). This may mean that an error can occur in EVP_PKEY_derive_set_peer() rather than during EVP_PKEY_derive(). * The EVP_PKEY_CTRL_PKCS7_ENCRYPT, EVP_PKEY_CTRL_PKCS7_DECRYPT, EVP_PKEY_CTRL_PKCS7_SIGN, EVP_PKEY_CTRL_CMS_ENCRYPT, EVP_PKEY_CTRL_CMS_DECRYPT, and EVP_PKEY_CTRL_CMS_SIGN control operations are deprecated. They are not invoked by the OpenSSL library anymore and are replaced by direct checks of the key operation against the key type when the operation is initialized. * The EVP_PKEY_public_check() and EVP_PKEY_param_check() functions now work for more key types including RSA, DSA, ED25519, X25519, ED448 and X448. Previously (in 1.1.1) they would return -2. For key types that do not have parameters then EVP_PKEY_param_check() will always return 1. * The output from numerous "printing" functions such as X509_signature_print(), X509_print_ex(), X509_CRL_print_ex(), and other similar functions has been amended such that there may be cosmetic differences between the output observed in 1.1.1 and 3.0. This also applies to the "-text" output from the x509 and crl applications. * Improved adherence to Enhanced Security Services (ESS, RFC 2634 and RFC 5035) for the TSP and CMS Advanced Electronic Signatures (CAdES) implementations. As required by RFC 5035 check both ESSCertID and ESSCertIDv2 if both present. Correct the semantics of checking the validation chain in case ESSCertID{,v2} contains more than one certificate identifier: This means that all certificates referenced there MUST be part of the validation chain. * Parallel dual-prime 1024-bit modular exponentiation for AVX512_IFMA capable processors. * Added the AuthEnvelopedData content type structure (RFC 5083) with AES-GCM parameter (RFC 5084) for the Cryptographic Message Syntax (CMS). Its purpose is to support encryption and decryption of a digital envelope that is both authenticated and encrypted using AES GCM mode.- Update to 3.0.0 Alpha 12 * The SRP APIs have been deprecated. The old APIs do not work via providers, and there is no EVP interface to them. Unfortunately there is no replacement for these APIs at this time. * Add a compile time option to prevent the caching of provider fetched algorithms. This is enabled by including the no-cached-fetch option at configuration time. * Combining the Configure options no-ec and no-dh no longer disables TLSv1.3. Typically if OpenSSL has no EC or DH algorithms then it cannot support connections with TLSv1.3. However OpenSSL now supports "pluggable" groups through providers. * The undocumented function X509_certificate_type() has been deprecated; applications can use X509_get0_pubkey() and X509_get0_signature() to get the same information. * Deprecated the obsolete BN_pseudo_rand() and BN_pseudo_rand_range() functions. They are identical to BN_rand() and BN_rand_range() respectively. * The default key generation method for the regular 2-prime RSA keys was changed to the FIPS 186-4 B.3.6 method (Generation of Probable Primes with Conditions Based on Auxiliary Probable Primes). This method is slower than the original method. * Deprecated the BN_is_prime_ex() and BN_is_prime_fasttest_ex() functions. They are replaced with the BN_check_prime() function that avoids possible misuse and always uses at least 64 rounds of the Miller-Rabin primality test. * Deprecated EVP_MD_CTX_set_update_fn() and EVP_MD_CTX_update_fn() as they are not useful with non-deprecated functions.- Update to 3.0.0 Alpha 11 * Deprecated the obsolete X9.31 RSA key generation related functions BN_X931_generate_Xpq(), BN_X931_derive_prime_ex(), and BN_X931_generate_prime_ex(). * Deprecated the type OCSP_REQ_CTX and the functions OCSP_REQ_CTX_*(). These were used to collect all necessary data to form a HTTP request, and to perform the HTTP transfer with that request. With OpenSSL 3.0, the type is OSSL_HTTP_REQ_CTX, and the deprecated functions are replaced with OSSL_HTTP_REQ_CTX_*(). * Validation of SM2 keys has been separated from the validation of regular EC keys, allowing to improve the SM2 validation process to reject loaded private keys that are not conforming to the SM2 ISO standard. In particular, a private scalar 'k' outside the range '1 <= k < n-1' is now correctly rejected. * Behavior of the 'pkey' app is changed, when using the '-check' or '-pubcheck' switches: a validation failure triggers an early exit, returning a failure exit status to the parent process. * Changed behavior of SSL_CTX_set_ciphersuites() and SSL_set_ciphersuites() to ignore unknown ciphers. * All of the low level EC_KEY functions have been deprecated. * Functions that read and write EC_KEY objects and that assign or obtain EC_KEY objects from an EVP_PKEY are also deprecated. * Added the '-copy_extensions' option to the 'x509' command for use with '-req' and '-x509toreq'. When given with the 'copy' or 'copyall' argument, all extensions in the request are copied to the certificate or vice versa. * Added the '-copy_extensions' option to the 'req' command for use with '-x509'. When given with the 'copy' or 'copyall' argument, all extensions in the certification request are copied to the certificate. * The 'x509', 'req', and 'ca' commands now make sure that X.509v3 certificates they generate are by default RFC 5280 compliant in the following sense: There is a subjectKeyIdentifier extension with a hash value of the public key and for not self-signed certs there is an authorityKeyIdentifier extension with a keyIdentifier field or issuer information identifying the signing key. This is done unless some configuration overrides the new default behavior, such as 'subjectKeyIdentifier = none' and 'authorityKeyIdentifier = none'.- Update to 3.0.0 Alpha 10 (CVE-2020-1971) * See full changelog: www.openssl.org/news/changelog.html * Fixed NULL pointer deref in the GENERAL_NAME_cmp function This function could crash if both GENERAL_NAMEs contain an EDIPARTYNAME. If an attacker can control both items being compared then this could lead to a possible denial of service attack. OpenSSL itself uses the GENERAL_NAME_cmp function for two purposes: 1) Comparing CRL distribution point names between an available CRL and a CRL distribution point embedded in an X509 certificate 2) When verifying that a timestamp response token signer matches the timestamp authority name (exposed via the API functions TS_RESP_verify_response and TS_RESP_verify_token) * The -cipher-commands and -digest-commands options of the command line utility list has been deprecated. Instead use the -cipher-algorithms and -digest-algorithms options. * Additionally functions that read and write DH objects such as d2i_DHparams, i2d_DHparams, PEM_read_DHparam, PEM_write_DHparams and other similar functions have also been deprecated. Applications should instead use the OSSL_DECODER and OSSL_ENCODER APIs to read and write DH files.- Update to 3.0.0 Alpha 9 * See also https://www.openssl.org/news/changelog.html * Deprecated all the libcrypto and libssl error string loading functions. Calling these functions is not necessary since OpenSSL 1.1.0, as OpenSSL now loads error strings automatically. * The functions SSL_CTX_set_tmp_dh_callback and SSL_set_tmp_dh_callback, as well as the macros SSL_CTX_set_tmp_dh() and SSL_set_tmp_dh() have been deprecated. These are used to set the Diffie-Hellman (DH) parameters that are to be used by servers requiring ephemeral DH keys. Instead applications should consider using the built-in DH parameters that are available by calling SSL_CTX_set_dh_auto() or SSL_set_dh_auto(). * The -crypt option to the passwd command line tool has been removed. * The -C option to the x509, dhparam, dsaparam, and ecparam commands has been removed. * Added several checks to X509_verify_cert() according to requirements in RFC 5280 in case 'X509_V_FLAG_X509_STRICT' is set (which may be done by using the CLI option '-x509_strict'): - The basicConstraints of CA certificates must be marked critical. - CA certificates must explicitly include the keyUsage extension. - If a pathlenConstraint is given the key usage keyCertSign must be allowed. - The issuer name of any certificate must not be empty. - The subject name of CA certs, certs with keyUsage crlSign, and certs without subjectAlternativeName must not be empty. - If a subjectAlternativeName extension is given it must not be empty. - The signatureAlgorithm field and the cert signature must be consistent. - Any given authorityKeyIdentifier and any given subjectKeyIdentifier must not be marked critical. - The authorityKeyIdentifier must be given for X.509v3 certs unless they are self-signed. - The subjectKeyIdentifier must be given for all X.509v3 CA certs. * Certificate verification using X509_verify_cert() meanwhile rejects EC keys with explicit curve parameters (specifiedCurve) as required by RFC 5480.- Update to 3.0.0 Alpha 8 * Add support for AES Key Wrap inverse ciphers to the EVP layer. The algorithms are: "AES-128-WRAP-INV", "AES-192-WRAP-INV", "AES-256-WRAP-INV", "AES-128-WRAP-PAD-INV", "AES-192-WRAP-PAD-INV" and "AES-256-WRAP-PAD-INV". The inverse ciphers use AES decryption for wrapping, and AES encryption for unwrapping. * Deprecated EVP_PKEY_set1_tls_encodedpoint() and EVP_PKEY_get1_tls_encodedpoint(). These functions were previously used by libssl to set or get an encoded public key in/from an EVP_PKEY object. With OpenSSL 3.0 these are replaced by the more generic functions EVP_PKEY_set1_encoded_public_key() and EVP_PKEY_get1_encoded_public_key(). The old versions have been converted to deprecated macros that just call the new functions. * The security callback, which can be customised by application code, supports the security operation SSL_SECOP_TMP_DH. This is defined to take an EVP_PKEY in the "other" parameter. In most places this is what is passed. All these places occur server side. However there was one client side call of this security operation and it passed a DH object instead. This is incorrect according to the definition of SSL_SECOP_TMP_DH, and is inconsistent with all of the other locations. Therefore this client side call has been changed to pass an EVP_PKEY instead. * Added new option for 'openssl list', '-providers', which will display the list of loaded providers, their names, version and status. It optionally displays their gettable parameters. * Deprecated pthread fork support methods. These were unused so no replacement is required. OPENSSL_fork_prepare(), OPENSSL_fork_parent() and OPENSSL_fork_child(). - Remove openssl-AES_XTS.patch fixed upstream- Fix build on ppc* architectures * Fix tests failing: 30-test_acvp.t and 30-test_evp.t * https://github.com/openssl/openssl/pull/13133 - Add openssl-AES_XTS.patch for ppc64, ppc64le and aarch64- Re-enable test 81-test_cmp_cli.t fixed upstream- Update to 3.0.0 Alpha 7 * Add PKCS7_get_octet_string() and PKCS7_type_is_other() to the public interface. Their functionality remains unchanged. * Deprecated EVP_PKEY_set_alias_type(). This function was previously needed as a workaround to recognise SM2 keys. With OpenSSL 3.0, this key type is internally recognised so the workaround is no longer needed. * Deprecated EVP_PKEY_CTX_set_rsa_keygen_pubexp() & introduced EVP_PKEY_CTX_set1_rsa_keygen_pubexp(), which is now preferred. * Changed all "STACK" functions to be macros instead of inline functions. Macro parameters are still checked for type safety at compile time via helper inline functions. * Remove the RAND_DRBG API: The RAND_DRBG API did not fit well into the new provider concept as implemented by EVP_RAND and EVP_RAND_CTX. The main reason is that the RAND_DRBG API is a mixture of 'front end' and 'back end' API calls and some of its API calls are rather low-level. This holds in particular for the callback mechanism (RAND_DRBG_set_callbacks()). Adding a compatibility layer to continue supporting the RAND_DRBG API as a legacy API for a regular deprecation period turned out to come at the price of complicating the new provider API unnecessarily. Since the RAND_DRBG API exists only since version 1.1.1, it was decided by the OMC to drop it entirely. * Added the options '-crl_lastupdate' and '-crl_nextupdate' to 'openssl ca', allowing the 'lastUpdate' and 'nextUpdate' fields in the generated CRL to be set explicitly. * 'PKCS12_parse' now maintains the order of the parsed certificates when outputting them via '*ca' (rather than reversing it). - Update openssl-DEFAULT_SUSE_cipher.patch- Removed 0001-Fix-typo-for-SSL_get_peer_certificate.patch: contained in upstream. - Update to 3.0.0 Alpha 6 * Added util/check-format.pl for checking adherence to the coding guidelines. * Allow SSL_set1_host() and SSL_add1_host() to take IP literal addresses as well as actual hostnames. * The 'MinProtocol' and 'MaxProtocol' configuration commands now silently ignore TLS protocol version bounds when configuring DTLS-based contexts, and conversely, silently ignore DTLS protocol version bounds when configuring TLS-based contexts. The commands can be repeated to set bounds of both types. The same applies with the corresponding "min_protocol" and "max_protocol" command-line switches, in case some application uses both TLS and DTLS. SSL_CTX instances that are created for a fixed protocol version (e.g. TLSv1_server_method()) also silently ignore version bounds. Previously attempts to apply bounds to these protocol versions would result in an error. Now only the "version-flexible" SSL_CTX instances are subject to limits in configuration files in command-line options.- Fix linking when the deprecated SSL_get_per_certificate() is in use * https://github.com/openssl/openssl/pull/12468 * add 0001-Fix-typo-for-SSL_get_peer_certificate.patch- Update to 3.0.0 Alpha 5 * Deprecated the 'ENGINE' API. Engines should be replaced with providers going forward. * Reworked the recorded ERR codes to make better space for system errors. To distinguish them, the macro 'ERR_SYSTEM_ERROR()' indicates if the given code is a system error (true) or an OpenSSL error (false). * Reworked the test perl framework to better allow parallel testing. * Added ciphertext stealing algorithms AES-128-CBC-CTS, AES-192-CBC-CTS and AES-256-CBC-CTS to the providers. CS1, CS2 and CS3 variants are supported. * 'Configure' has been changed to figure out the configuration target if none is given on the command line. Consequently, the 'config' script is now only a mere wrapper. All documentation is changed to only mention 'Configure'. * Added a library context that applications as well as other libraries can use to form a separate context within which libcrypto operations are performed. - There are two ways this can be used: 1) Directly, by passing a library context to functions that take such an argument, such as 'EVP_CIPHER_fetch' and similar algorithm fetching functions. 2) Indirectly, by creating a new library context and then assigning it as the new default, with 'OPENSSL_CTX_set0_default'. - All public OpenSSL functions that take an 'OPENSSL_CTX' pointer, apart from the functions directly related to 'OPENSSL_CTX', accept NULL to indicate that the default library context should be used. - Library code that changes the default library context using 'OPENSSL_CTX_set0_default' should take care to restore it with a second call before returning to the caller. * The security strength of SHA1 and MD5 based signatures in TLS has been reduced. This results in SSL 3, TLS 1.0, TLS 1.1 and DTLS 1.0 no longer working at the default security level of 1 and instead requires security level 0. The security level can be changed either using the cipher string with @SECLEVEL, or calling SSL_CTX_set_security_level(). * The SSL option SSL_OP_CLEANSE_PLAINTEXT is introduced. If that option is set, openssl cleanses (zeroize) plaintext bytes from internal buffers after delivering them to the application. Note, the application is still responsible for cleansing other copies (e.g.: data received by SSL_read(3)). - Update openssl-ppc64-config.patch- Update to 3.0.0 Alpha 4 * general improvements to the built-in providers, the providers API and the internal plumbing and the provider-aware mechanisms for libssl * general improvements and fixes in the CLI apps * support for Automated Cryptographic Validation Protocol (ACVP) tests * fully pluggable TLS key exchange capability from providers * finalization of the Certificate Management Protocol (CMP) contribution, adding an impressive amount of tests for the new features * default to the newer SP800-56B compliant algorithm for RSA keygen * provider-rand: PRNG functionality backed by providers * refactored naming scheme for dispatched functions (#12222) * fixes for various issues * extended and improved test coverage * additions and improvements to the documentations - Fix license: Apache-2.0 - temporarily disable broken 81-test_cmp_cli.t test * https://github.com/openssl/openssl/issues/12324- Update to 3.0.0 Alpha 3 * general improvements to the built-in providers, the providers API and the internal plumbing and the provider-aware mechanisms for libssl; * general improvements and fixes in the CLI apps; * cleanup of the EC API: EC_METHOD became an internal-only concept, and functions using or returning EC_METHOD arguments have been deprecated; EC_POINT_make_affine() and EC_POINTs_make_affine() have been deprecated in favor of automatic internal handling of conversions when needed; EC_GROUP_precompute_mult(), EC_GROUP_have_precompute_mult(), and EC_KEY_precompute_mult() have been deprecated, as such precomputation data is now rarely used; EC_POINTs_mul() has been deprecated, as for cryptographic applications EC_POINT_mul() is enough. * the CMS API got support for CAdES-BES signature verification; * introduction of a new SSL_OP_IGNORE_UNEXPECTED_EOF option; * improvements to the RSA OAEP support; * FFDH support in the speed app; * CI: added external testing through the GOST engine; * fixes for various issues; * extended and improved test coverage; * additions and improvements to the documentations.- Use find -exec +. Replace 'pwd' by simply $PWD. - Drop Obsoletes on libopenssl1*. libopenssl3 has a new SONAME and does not conflict with anything previously.- Obsolete openssl 1.1 - Update baselibs.conf - Set man page permissions to 644- Update to 3.0.0 Alpha 2 * general improvements to the built-in providers, the providers API and the internal plumbing; * the removal of legacy API functions related to FIPS mode, replaced by new provider-based mechanisms; * the addition of a new cmp app for RFC 4210; * extended and improved test coverage; * improvements to the documentations; * fixes for various issues. - drop obsolete version.patch- Initial packaging 3.0.0 Alpha 1 * Major Release OpenSSL 3.0 is a major release and consequently any application that currently uses an older version of OpenSSL will at the very least need to be recompiled in order to work with the new version. It is the intention that the large majority of applications will work unchanged with OpenSSL 3.0 if those applications previously worked with OpenSSL 1.1.1. However this is not guaranteed and some changes may be required in some cases. * Providers and FIPS support Providers collect together and make available algorithm implementations. With OpenSSL 3.0 it is possible to specify, either programmatically or via a config file, which providers you want to use for any given application * Low Level APIs Use of the low level APIs have been deprecated. * Legacy Algorithms Some cryptographic algorithms that were available via the EVP APIs are now considered legacy and their use is strongly discouraged. These legacy EVP algorithms are still available in OpenSSL 3.0 but not by default. If you want to use them then you must load the legacy provider. * Engines and "METHOD" APIs The ENGINE API and any function that creates or modifies custom "METHODS" are being deprecated in OpenSSL 3.0 Authors and maintainers of external engines are strongly encouraged to refactor their code transforming engines into providers using the new Provider API and avoiding deprecated methods. * Versioning Scheme The OpenSSL versioning scheme has changed with the 3.0 release. The new versioning scheme has this format: MAJOR.MINOR.PATCH The patch level is indicated by the third number instead of a letter at the end of the release version number. A change in the second (MINOR) number indicates that new features may have been added. OpenSSL versions with the same major number are API and ABI compatible. If the major number changes then API and ABI compatibility is not guaranteed. * Other major new features Implementation of the Certificate Management Protocol (CMP, RFC 4210) also covering CRMF (RFC 4211) and HTTP transfer (RFC 6712). A proper HTTP(S) client in libcrypto supporting GET and POST, redirection, plain and ASN.1-encoded contents, proxies, and timeouts EVP_KDF APIs have been introduced for working with Key Derivation Functions EVP_MAC APIs have been introduced for working with MACs Support for Linux Kernel TLS/sbin/ldconfig/sbin/ldconfiglibopenssl-1_0_0-hmaclibopenssl1_1_0libopenssl1_1_0-hmaclibopenssl3-hmach04-ch1b 1729699611 3.1.4-150600.5.21.13.1.4-150600.5.21.13.1.4-150600.5.21.13.1.4-150600.5.21.1.libcrypto.so.3.hmac.libssl.so.3.hmacengines-3capi.soloader_attic.sopadlock.solibcrypto.so.3libcrypto.so.3.1.4libssl.so.3libssl.so.3.1.4ossl-moduleslegacy.solibopenssl3LICENSE.txt/usr/lib64//usr/lib64/engines-3//usr/lib64/ossl-modules//usr/share/licenses//usr/share/licenses/libopenssl3/-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:36141/SUSE_SLE-15-SP6_Update/1a4c085df5e38b2492d1dbf273362104-openssl-3.SUSE_SLE-15-SP6_Updatedrpmxz5x86_64-suse-linuxASCII textdirectoryELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=de152d0dd67d3aa453dcfdcbc71223e4d3e6285d, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=97e9a86c263d8a4a3fa46a5650f7f8115be65186, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=f399e121d9d8d120f1eabf0a82602ae028573160, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=b1cfc025de54f5bcce956d4db3e93cd92c628df6, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=10ab6af43128efbf8174610cb8764b75cefe19f0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=c64ecc0c326d7dfcfece46e01bc955e4443b9512, stripped ,9 RRR RR RRRRRRRRRRPPPPPPPPPPPPPPRRRRR R R R RRR RRRRP P RRR RR RRRRRRRRR RRRRwY,T[ca-certificates-mozillautf-8f2240ff9511dac876be2d59b46b59e35c4dca264d00bae8a955593901f3ec370?p7zXZ !t/$]"k%AK4"c&H&4RP4 @n!S>UnuŞ5%xY$0QlY\ 0 8lrHhMhx%Rlr&/ j"i3+MJ~[xaHCл7)O1K?_#}v̡ZKDA:KSYW׾l; qR2ŰTK*dE>DBT9'ӧ U_2#lUJ(NrsȇK1J0-Chl{4A:P0+ wJ?L7~Τ L L5TqПG-#l;o&ۤ>jo<|0{S $L67ןJ@Û&X)59~6f\G+i/F)GRYg?}>ru!# *Qe)E݉{qwZe1 BJ`isp@!gZjvp^cn g PhʏѢL]x Ƶ9iax">l#[p)A*`8@$/e..k'>$\E0bs?]8@iq+AAzfyZ9G$@6KI{W4x]|]ZK?d ȝBSXk) `kf+fP\qdm!) 7]32!:8kQPVs"΍B0Bd=uf D1yŔˈE h|T流rӝuwr'"9WJy^lm.%)B(QhxrI@ 2'LG"Y6qGA]\7DӽAYLbۯ{wTX&m3֎ċ~(lDف%X\- [TfFGt2^(&casU;JNO0']8؅W"d⤾ 82@'lQnjngmCoK0 >Zuc, eVu-%~o'pP qS7)GiCҋCickE!#lw!8np;RX{) eY=Fm #rQkUtR/gF*-DZ~zTּ5FYԊlf@˓2ATXUwTAN啔#O-0Y4Tj"T<6kTLiEIzP6piF q>%'U9r<;';Ms2=Xa 7Pöa`32nSCܿVRׁNB2c`=076˯pw N^Z@Ӡ=yi& 󥐱G{&F،?>1v,_"٠=[WN=fq2m5͝%Vsvnty?nOǖo{LG x-/Ԣڭ C~>ۡ$OGe)ϾM5 ز| 8CERвzTA ] 'ckֆZ@ڇzE~C]x[&+ٝJ}H$?튔|(܉( @`rU]muube2&h9mV z?qZu!hm4,ȱ>VuW!J5$֦5 ː7#@rDzP[LjfʴIՏz*CUNn4)=a׬1wv-sjW|4hsٷݒ'0J !Y`2mfGvrB!l&u+񝖰6LG ,qG _3p8p/vO nU|;6̙TX:S E̶xcc^빨hz d|0U ͧ =}ЃL Zַnؠ 2 [Xe_pӠTI֬.2=rI^"y+OI^:;po(=ȵ_8.iB}שlt59~P*. wY\E92Y/ ;889&h$ݪu7KIXcT͠.KZҟI!J? wyZ^aJo|@CωgtYw5Dᚷ [ty/h>Y"~9.́̚VgxU3`ĝ u>ئi4ޕ7NU2O18H^˂L9%h)-KO80P= 1 l% O*naIw=-Ilv݋]z BMDE.4bDkJw1>І뙛/^ b-Új0&D+um@uK6Z"}qz߫3#ϰ8,MyCr\AH !\njei"w`:Xq}uʛ,Wo-~* NhîSǡ4J?(WƘu"j-9XrI]"=deZ1Vl(?+A`v}%dddFJJ"~ǽ`ס3odf>ع!baof*+KM 擉DAcHkDTQWzYZ3#.\f (H; 6{խ\ n)æp^r~YpTtlZe²z_uRoǧ/}>d'z|}6d=iw'{Dʤ&ǃ8Эd#>2쩷حcţH Q:>:^mH#miǣ}I@a[y]Όeoe۱yĭ+{.zoP@p^ ,qIYhWr00b~e_wuzGib☳$krb-o*A0J\ޯJ_tX \gAj{LuvZuP!Z->P80lƠk0vf Ά=b콏 6IEX-\aV 7xS8Ä z̉*`&[ <'("׭UK8PDx&N{* V+]^;&z.ȧ'Dd iIO5O m8JLd[wx7zT2x!੎C3_ELhֶ&`DCZ!(}4zu1xj=ݩ^QZ){:< \IB=Ҡ7N]t|f(ҪVf4-!N'Wpa6=oXU8Gg 8 s9b[3GQ#PAX[sƗ'(Ivai剿9,a m ,HxTeBN~ :x YMU"ݘ74d~0R۱oHTA .Z1jfټ4}&S:Je^R=03Ӷ7dS0/9^WκʑvnjuZ耒0 ?D(EUp65$~= $M|p$msƻ\maLhlulqX(99KSNvq zXuM$,o7uoµuR:: UGԁJ*b8xʥ*LV}d?|sA~*|-.gfn콀bbJZU'~/щ$eK^; V.s,ЂzE N{ (MKT i}8D͛re͑6^g8idD'zJf_N-Dm$w di& 㚝v~A[ݙD6H%6݁n5g8V,F$%l䋛wx;0=i_Mv˚-+7@h+kNAh3ʦX$fùr1J/\|C7eIf],KM.GSe3A t]Gjm3شI!wĒaUH%55 W I$}#^CZf~y9.7+"mߔJ/0r;2¹wY21y\^^8^霚7}6ұ+N<,B@XuS%ohZT#ݗ2PFL3͜%_oj<,@3\F#OHt`VdvJY]ĀEl5j% t}lH๎vˣ$_<4O jz/YzOTrQECc2StU̚D#ҨR*s#☭[)DAgbeh:ߜm8z僤} G3w̸K_+\s}psnȦr.9ĘbbҞŎVV+b{TrJd!cN J/LNYf[u:4N)Υ^+VR&x뻹}:[DE.g[|Efh/SgzNrO9ncb!HxsoMe+*oRV֢&( +ˡNOU&P~FTSHTRkʸ'C+ʹ>v;[:%j2&P4]a52oU# 3Ii?s5 E}>펌Ҡ:_ZW4Gy_/ =jcZXCGqDpNp1H?S{-oClJCKHdDZnR^f q[|3H`H&UuCWѩ!^RDu Dydh})n#6\nJ d~ŌrV *ߠkhWnz("SPb?r*dfb>G>E<8ZFl,HKkwLJRKow늓r87juY^F1?و>#.4g[>p(YX&>kOt <z4(!2e$lnto]Ms3ݎDqWinK_c!OCWəᷯ=֨O諐Miy'Jԓӓ>[-,0FCNG]ha;V) !Fo*U (jhRAlO`WǣT\mp_r%:wl*koQ_VcJXo ׊6 ߻qb)oeb1h3Xh͐x-^Bk3<a[sYAsixֻ0d_ `O%  ?RX/r$1Ne`eǧǭy(c>B4mL.o%q }SIrhcE+Nr(iL+՗JD~e5wQCRO:IA8d/<%7vy=K/99WZerii ಌ @:>3 )FcϪ5|[Ht윦6``0L)/'ammu>\uЧ,I Y Tp+?5U ]JZBC3xPN+Ζ mYoWt4Gq+ \ SŒ,ڱ$Alrي=O.Qa ZiO,o{,C㙔FwV3dT=#+ʛ|!qUUE ܯQjދ$)CvBlH{*.4kAG#Km*m64I#b.Qq,a29HWWp\sdCYlVknA/o8L'kxRH^HB&F̓@G͘sʏ"gr>mg1KM^60j`, j B:qt&Cpoާ: p'9#s7n ǰ,w.ew |~g '맃/M݃BE ^4ȓJ0{X7ܟf_n,BbeI zr?Y[IAȭCݑnũB߁ub VKRs[Mi m7T3c;%NJXPNYE5OD+!1%~ CiFQ 7w"XܑI%x2 }qmYM\3];Ere{[ኖ^51'|8ihƊ.PڹjG)>~a;;"BY{0Lj)5VniTG-C-} 8h-X]}M%r.厪y:L `Tɏ?7%oǥ|6\p3 K)&"n g4E auYg`!j`b^&H?Ps򓌉9zK++h2QWgmGʗڳʘSj0V{2p'ÒM]ҟLsbH?:zƾgxX1g}?*=U|LAcex~EE8r?І:D-1ZYϓ(`G牠Zz}R%H@=}Э^> G+S&QEbr %vWjG7'xP(ؙfP| [ћ/H 6IzL^Z`,D"[5UAkF4lFAY&ZpF-yK,Vh zQmz=Mˆ>e=ۭw_^Un3cc 8zz[k׀ E$M X,5=:wUDM迮}@Mc: ^._V'XYӅKܺк)u~k=c?ߜ)*}FvDyAʊ}><ŏnSdDOQϽ+]W.`KԚIrOF^h@o˔PmٿȠ iVe7h}N`7^zuI@WH3wTjI+& #= *v@߆ A8 &Y֗Zn#V )'yǎ +"~%'?b0t;WN#.ϴ3MpB_|?бJ6Ja i.) 9q5TRΘ趑Wk~d|=Vxy$꧚Tb8:29婘[/2cfnkWV6_lb'2 hNmT)c( Y0k"ދoCoij2$a7G7#3$Џ^[qV{?n u\e 7{\ѹnY0QEusw_,Z .~x#u(= `%,Esc/! EGh(w+ ƗOYi O(!GnӍIf7%S$u[`[l!:5M[Ʉ+zL `Fv xidꐝ$t>qHD,7gb~st[jLK.+}uVLQIIwV&$$5 B"ہMӆtMe+ď8cZ"jz}SsH/CkuSx >"]T⚥)YAh1(I۳Yoۛ#>Qx:*OJ#/Q`Ok*Ji8sG;E'(jI)fk14M;d~7ի8H=[C_-P#7GH/Vf}Պ[e,~kW1:X#<ȬOeĩ_Xm&<7K]]>8?9Z),5|ibxs4w+1u[tZ";S 5f ӎ=VyZ'ҵZ^g*GC4|.ԞŲ[X.Fsg@`^sԱv⭳5etFX9W5pTbZ "a47uϤuMw2(1ӴU bWwvuʍ4c1̈́zǴc"j0D X8rNe2I,eudB7Aj *Q!9ێy+#$Fe3PمF0o3ym͢eCD]3k97j cN: y+͜SYH[  ǎBKZ~-V]]n@cmbAd1PPsښSVnDI 5KU֥E>9t~vb qWƃiɬ?NiT#̴} Kfef`}7ȠhœZh큻?j? c'JP\zNJLמå3\ G"] M/[G0w%S=B †j +ctE0/hB6ݒ*)ɂc\b7]R%u`X$noxIǔ(3z3W`^?bRME9rg[gi(7&c)_5 b10<д'=M LuN;~ 9v 6exlH8s2[d-ӿ.9_1VƏȀ3`|T/<9 /CstyhEH48 yboLG/% (P&eeَcgIqtWl$-[:tsE=]=(O/\ ^7)mC} /(o^P[T"T Q*<rd_:˂,k\puM@~| Ѵ=cž`LD+u3T?sugjR&\jMগ~:+uiyO!JdD1W4;c7ftfdC$MOH&Wyw","g4>]}mhG(7 Oş,Fg UZrp{ x9q - )= ~ Ot0|@Lw[(RVP4Wb` Zzy,jPZz ZseٰFK$G-LU2t}&iOpY5οj")FqZs QmkSEz/_"_KýPCk´ 'ȬlCVvٲ(VZ @A~n+mg NLqCa >/_:IJ~b Ua yD*jd!ӌ_Ls/zCW/\稅WJkWu/v[-(@;Wtϑ8 Tx05Gb; H~(e^H EOܪ}Q4|Fו}  [J +Od,/NuMUP_B ׭GDdsAPB,x^WHq|![jLHMCB-@P}ɵ Z+;5a2lY. )^uP]bru|ہo0<ӬGOvё8!hn0ӉsYW/CA~БQuN^GaJɎO(, K'ʳ]m8p am]S`pK4/㈕_rI!r;Y- s_+V+Xs̈P#ڴBR+JGqϻU>67Bfk6RG>wo H1ptjb|ٸu?і4"p@̭^9P`Bx"`E+Kn=qcHBrcT>εކaFk?ӃQVĀ&!^^x rW)tZJ{Xnژ2XUJjN;^gRZ-Ps-!Ġ{5i⦍Z"j/ bQTzZlZؙ*_}\ (P s vĢ ;0/Pӡ*e~CX^#Ln;P?@:ia;;X=O-~1io񞁣P6I``WBqƶ3VrIL!]П7Dmx9̉e\)|wgjd;f*,:E e8(o]j0pPE~;6HXX^OfN=yA rnTF/G) uj(||X: 7Դc\tݥH(D KN+KJ fޮTT.r9U*"衫F^2f#ҝdD3+x1ڨPȍj%K%xW;;ѕE]ZO!#@&>3*Cu+%Fvұ:H!74kxG6ܻ .$QjfЬ‹l\G>+yu HnhUs^`ivj;H^lEV,}bad/^}'A.mr4=<$l\v@Ez90R﷞Un*zr˄F[>\/tB8!U\;P^'ۡ.=]fZ?tSXTtbhlˆobzFuUA;S 3ҷN9pLvcW՗p:<^}{C{~٨ڐ #B@ P'"ISx; 2U2'OF&A4H{ Hk-#늼fA'hRb- Op+CxfhzK4\:%!Ƚ-`suLa /dCRױN!xP ?teټ5*+%G%5kBhF\UAs!.䚄SbU~'X;쥊niN6~/Z_{[-Έjֺ&RvKug;@'p}!)so4ؤ~QFZWnP;zFmF&[.Mmw \䩥 jqV}B8qDk$毩ۯ~V:+焔T[SJ bqçS>vN1xo!H-Yt#< l:qTaFEq!uBVo aU8Q_'w aaƱmT$ jABJ.W͐7{رR%uNض،䤮hQ`&[4jvKuؾvw @3\s4i$vC{:~7,[oU]tNc1mqއ+F^ 7Wr@$5ڌ(dz .Z: ^7AsߗvJQ P6$Ȃm=ҫ{yf;npVk0 h#Г&|[2,- C⺢U-aeRMH]sYigȊJzA$f!&ϐgc:T2a/ۺl0:z+mW!/yݲZ񘅅eK]+8` Zs8ƎXm횠3e*Z1#H+mU11n"r U+PVI'`C7Z.hc3]q.9vs4FKE"S-ų4[)o҄Ǜ4id4 "ߚlI`MX{˞utXEʒgk4KaHxGU%xznpb4oLs2c"gfd>߇ދY*F2fpJ ƠGBOAVO:2Hg'sli'RnN5Б-Sw!IbvT%j4mozv6<C/|gB ͯ W3lӬєKHB;py%+CWvH!ԨѶkݮk8t9 PuB\a}׷6zZqg#]M(K' hk]K1Co>gnٯ\3:O/ؐAu#ky·Ey3|XD1aa(|L]qhfɮutBx)p+S oM6A@Y q/O@+~yJZSUsŮ)=`>ld+,t }hK!Cn'Nq317&:1r!Kʟ58.zᄔ 0㔛,qiȦ{JN, Ub6fG_T3%aa!e5]C˜z@*Qp3# %.b9J=1$4V9Xa?dXD1:P7o@yaPE7}Cއ!hT?܂Š(܂ x_:Duv"e!oX -?.bi+tQ>I7TOEr+1StL#G$KA>fF :e=0B@uPp ]W񶢵k$ JQ+gӸ4+]2ԧAo7zk^b]_T.]]6Kr.X d({>4#fPw[;>y >ӏĆ+$ZS(.J#xP06rd"ލگGM4 as$\,RyMub(pq~p抁`4i>e"W~a7KB'P=πJ;;3'{]eD."l)we.@1SxjrVcD5L~Ɍp-%f[]BE-㾧+U@l֨YV`ꁈ^;jyP*&ߒ{ҰV^jn-Aj>mUM쾍oFOOq-P8yFo QEb*^b(>iٷly:a 3q')D}q8x5E>SO؎>?0,Qo䴁p@̠Όr^TSD6v]fĽuTloaGqo>0ACgοv}騙aW oƹ"2-SJ@dhB`iJ-rN0;uJZh1 uKG!qi ӟt 60NW9y }O@/J,/WPWy5 벙3r̬zZvhך_S,\2\:D,zCoS)  *`Zs ZͥS>Ul^r/ƺI> Y[tſmOԢQXm'+IBgޝe$1k.m6~~m#86V%(|xfn@l K1Q:v/'zG:UCvj8o?ĥ5%sҮ쾉l_)$Phf+wQ[`5-"|~^KKaa/V;]2iy<̬ Pd'A_ߚܲ[e,^uk5{; s~*ڭȄ;>>]RqɺDL)=뀽yjK'qD7Qm~cD|04mB ,/t_{eDIh+G(~5OӚ-.ZD$d¢Ř8a,ewf^ie,(rwF3[=.j-5(dQX )0˶{N vQ[H7fgƍR>2pkD{@K$B7gG]s `^q 0 !@+/qٍLZN.|gRK70&X5/L4|U" \ )̳c[ q}F_ EZ$vB ̄I=<9`{X(bjAS&ʯg0Y8؞Yԯ7KXc%4{Yz8(dwLʃcƧQn@`Z`LPػpÓ )xk(@/6U] @furwSflOQk]ߙE ڵa{FG3Qh'95غ"R`mj!!B 0bË@׀FBX5GeA,Il>?;%nj^z.G_os'7}Mo _HXWC?#-yv$95 d  <,(MG^yIPEn#&`'QC<2+ԢƤԫ=^$ů "7$o:RLWkFw|_yrU W$:GryP$? 9&u [%O'" k|H(zެ# q(MALMzPL靨]u:͍' sSk0aGAXʹXzDIt laBLEDVvEJa#M Kr,g$E~RJx6)zuo!ܘasbrMWt򖊛^ȴ+l;82+nڨ@>@ ;0vwMGwE*N\ P9h3=xK9*zہ6mׁ;y^/w?\ijk1 f>(et cx?M4jrpo=ܼ鳱FK_g \-`kzikNe_=EHҍP^;`)faCl[؉oȆCn KHq҇w),ԕ*'R5֧V zsK TW;{r7̼W?]DәΘKfi]!tX,w*X~euA(.-3 F)VѨ$U2b&BXLa,Pr8,c*1ܙiµ$< ?֡rta/x&NBKIn\yf5 P`.nv M?GL& xuY>LQ#{!\%֍.ye'yRԓY U᳚N(l4_F=c#4-9kJ"SR`'Oo1Um9ZVyKAܱ4 dх[[Ut1((ׁE1:n&kπ(l+zZЍO]'DrX&`J&+!B%p ya*[:-3を^h7}lG\D[\<@~LT];#I_]yw؏:+ѷuz{ >_Xl63Ns5/<ǛއKˊK-=YCrra5`t'>_( sc Ys૕ʓLnJH"R,ڸvl"İffpKXh/zr(~"4L^pzu3aS/5K(3fxC̞YMlɠ%cѯh}5Bfbz/۴ ̶)/K@1d}wɨu _@NXuLZ*)`z"MoGTY*3^g䭘X$2RΝoD?Gx1L9~4SF.4k| ycco쵲?+&'GP'>;gNN.'׵NmApZ[R#F2m<ĕ4|r9 hR$<3ЯlIwM/KDzvDآayP ZQSW8 E!g`*ͱUjg3,ďr8aG'3 OX_y-@Rwj!oAS 7p_H=s@A `f)9_'q㪰QR{ {kp924^o*Yij+" >I,FLjlp_#`hCG/I|6&1%3SwIs!e~74&\4l[Um1Qg`?!,: m@&ەv5gIANf&8I=Mk~OK*Sp,4dC!!C|( 'vӠְ; cS fN<͘}]MJY{Qt6ڟ #I.Y)1Jo$6nN`\s\X fYK4>DwN˚ &̅0x1>@H"K֩jL_#JgDoHO]_R񈷨e5,'-gӶof9ƽf&2I }~R t#/酿fL IIЊLӏK'ޞ . Gs) ~9}kn(*MK&*֪@/wICEB[9Ⱦoh/OLC>5I'4Y*tI6__Pqf>H~p'pc~˕=0(l8*9?)$n@w,'^ "x(,(. eɓ;/4"iy N_OLm"s'ꅌ?(gx"o 1_%@tx,--X?~J S.ㆵ;}\ً >Y>ȻV)|yqHd VO&by`2SKtþ%CnnGz4=br*v˝(+R3c4 㣚sSzAZa1QXIܿpy*i`Xj6**YNMEgq4jz}T E9UR<9]T .yQA2S\CFSt# Lg@qezτ罹v.Lpv^sNjZ$C77ԢS(g+Iḙy ݜP؈^m? 6tQ8k@g5'4x ''iAo^ޥIJk $SbW].tEcJM{[D:jҖ]W)BI41MVܵV~J<]]zErixTtFSx^|UliQa8&N$  g ꎠLrg{ec>ުKTv}tѿZa%𷋀0}2jf4{z qFSCvbEhB\_jrՇi̧=po:?Jjh綉=0aCw s#KR/c҅ljus]ig"mg4 aitM:Rym.[:z?!cHllO]kFI+ < |?Ny88ċo X O=sz"X=9=PlY6[>Ai˝fa%?L ؤY!iJïYkN5 яQdΎ:s%9F25^z`6ZA44ji 7&t_VmbiW_SK,3(މ [S5 '}}{ .9i/vQG S1fgϓ6bzK+ݟHqTS̞$@ ; 36vI!z >PBɔjx"ꇘ("j#ӝ/ѯ~}-F],3(䫤9mCKs0qj45|yƭ)a9? B;Kǭ $hakkqG @|V`k9k|ϘpGM_}ًvKWdAVN7(TU| xPOzV ʿf4e;ߗ,@-,1DnJؓB%Qq `?x J.?n"A4\ԛq*s_:@Vƴ_tљrviEsSX~@QsU"d+Nc34]헭N*LaB<db;풎&81WI G}Hq-\j|@⛇q)Vpsp{gX32e{h_M6H52FX½<[-N|HR3l1Q"NM/y&0` KUћ@ vX2d9Mu1W_z! tYZsBc-,l\ QJf^%_^ܺy -!lGywx/* 5_A_|a-+l֓w* Vr̍\CsG%GPr1Z'^T-cVըBnh{L9q7Q\;nMXpKI?͟"- _tUJ<|Cdd'vuXNΈl$ O NW1_J!-_~7IIڱ[ћ1Wk=ˬj}TYtW"&w𥂧$֐ :fc4A %N!=ds]'UD%l`251*v;;`lN6´MH#lZћ^!$:H*fۼQc|kD:THA @EuE:]'E ի|ďO;mr91%$mq܋lF0YiU( .bmd?~+Jt"1}RSiǡŸEQΥ{a`^ U A#g*E$v{U?͉*@ZEEMI$BOJ UI1X5šPhf?{ޠ0Bod/anŭL%JU4^Xо*:bwF}€-`)'o}=`wMNWPVޝLv&*e4,H͎`7hC,,_aV:ՁGLR?!m/\+j2퍚M=.n-4 5w^?(OIΕ@9> E\#;͜qfH~ԠљٴMyҥdHyY1ekCU* yuI <$BقU 7pm ߄|=вKWϙ=fO:_)bP/.K)a9 rH&zz#YԹzuD N,4Dn#b"qڽWq4/ R,^lfU VQ~X{QS)F?}!Rtpޖ=UUy(d'f0o`p1U^0qk!tɬb|,W8(3Һnq#/DR!XcxnvJ(kа0e7$R(e1 ZI?\<+^^-]Q^%XR38>m9ԟ%i1^AATxR4=IQùD(0 'ܸ-V: `iޕ}<0ߟ'U#WtXR6P uj|NK]2Y_%UG )M,Ǩ Cw?_k&B X7 6WgY9K*Tk<03R_59/x,5`E<5e Vxjšm_V@դaᾘ ;S"c~xqypwwrSy%^".(e0#حpnyMRI۹":P}AOnhX?kV(.'Yal\C !x[(AYO#dsweu8BP nOPzw ^~[#^|41tmI!TS?S. P֗ԱTkNst4s^0vgsM O"' yCWwqmW+c"جC%t C7Ѝ[id/#ɝTW9 -0D< ]rBm UoMBTGS[k΂wahb [g" 'bl5꼉RV GpS0ϛx?nRi K?۷_hc'Mt;FY0t^ѳ7 32>-Zc0o]rǞ"8^`\1TN[YYDin8L'A}8jD#uԾclfxH *Kh%m !s%743'vbV?!k./7؜^{$H[gF<_;xC4]V!@\0 7B 6&%L]5򮳎; 2;#]9N35 ,,[fGmTV `mM>g8Q^Ew5f^Lb%qVfz(aP@Ѩ5ǰm ITui?f $4i3QT=J|{Ahݜ ?>7~WRm[jd]k0-$)O@DcNk[j0\ӹ< sqJ(]M3o74ЋM4Yv) Չ-nrQhm7ևGFXN ˊ7RM/5]Ėgf:'KЍ9PK C@ip5*dG)PhOif_r8G TE-y#mjڨ@-Q&_@N76E%6g6i}IW2Eijmɻ>j!TAc?"emFy3̵Cmxue˳匱ffai*pUpfG_^dc2V WњVdgߕA!5Uz \YVhy|RDS8]vHŪ6[RbIS G~H06-bgˌ+<NZ ""v>sv{+N=y :'+Vx9~fG"Tb>o}mǑ0X8fw3|m`9J1(u<=V&#c6@|#Dy'8 2\ w nKoCyN^ hbwt8L+9)K1-`"NG+:3ζ2ۈsA!uad7¥"i:TTF5PfNBT(hKϵZ!0 ul{ \W%8 hxA.thz :rT(mhcEj?t]1ظ˭$wr2;8;N׸lߙcrwK醪 mGM-:?} *oy4.yF&"19!8堆#J Y|a+~G,l z:8La{PAlF,G>7):p_yxFr ՍLW~>A)} w><l"ӣ5ک?li4,a؛6#&\۝-yR>qEo פ2_|@߄O^ъTx)ާw%Soʡ(\YznؚUXuT?޶Ʃf9W)j}HRRxl&2ڇs9:A;1rnvtQS5RK}Jb9]&/Gxɪ]լK%-lͨBP c=ڒ88%ԇE51b3(ZU s-4@Kb|j˟tQlƙTaM 3! g}73o+4#;WW+)"E<)j1+O*w)m"_# x#udKb<و\yJ_O2&WjPR2,:kbTԅ!AaI]Р?nP`T - kK p S%3g4y` rݘ~hVtI{PZK#&lA|6AΧb§?-J Za%̫P\BU'w' @Xeg-y>sLƸhHEO4;x-|?2Vjuјz?xD0D5ԙ 'YMыkU7d׾'I۷E qJ NZZi x 0 ?T Y3^^ J? &b/-Xϭ`JGCRKC9W I/bd$ƪ,% YDGi9K= [Ww;Dh1bFTe[@ cP*J%Gx0$/;R!cO${M:*X5UtbŒRG=9;>/`VnT pWB*ac[ؓ"zB%܋X"&qMrgf>mXrb^`HlcqmG `6)We" 2kozO;k7=@mﺪ-Ő\~N^RSޚ3J͔0nFTr R(G[Jy_ѣ3-^"^/&,*al">:\Zd-d+d"Rub[}AtDy%-]DK/.ә='VtS@9 OGynFڧVؘO3zvu/sOh +mʜҽF.nCgwFƂ/έk}!Nzu=sMot GMG%lp#_S%o{ \68D@fO[+ ~up<`Ybĸ\tIH2˚ E9\P?vtw0B秴PjA3R]q :Pr fAD/EuV=D >!}Ze?hfBP)q6 />[?;܍ڜ'ɲYGVVD_ŝRZ-w^Vx`K|9T0IQFOe]J * [k;zgްL$zn!!΁`eZ,+a qh QuWYtΗ4RENT|=b?#ݡ)0݉=J>4΀X 9=ٚKBĸw&8ղ9~uyf/ƽ>y]X_A;00KGo27Zyx { mJ<̉?1%G9Nʫ+[g=6+YϑgJs(u5nv]y\fwl+Lځ R>9nrUY.@SpMv %SpdHc#AM}@`J0 ^u{J*5f*k|jW@Zzsp_W}`q6P%[edu AZNSbLpB =YO`u{D_]adV %3-jX=|{=:>YDur1‚,+1EP8r`4)~?d%=7%X] &-1?/u5Rx1ɪ0icI7ST?N,*?+ifa \I\ǭ($eG-\]헾<0,:D.: 8 wuShQGlﳯB;eN } [a_2;W3ιģEG'ot9!:>q-/{^ܵ&}0I}IB2% vu-6;Э<~~{R9ߚh${KQ8 FIzߌs&B=6X'7~{'Xc ۹C{ppr@|IҪȧS*R/0q8qNaYPb[_c[قC/4f+ij9 '};ZI m?/Dy3';uHp1 j-[m#K x 6eS(ҳsaa]iCVʑz={MiE^ 3t  >,JĚZ8;M^]jjs eUfZ8đvED6 J|W UpoiȝDU"Y{sw] M&M皴U O6.;[W(Uk21*fw8Yf)ߣΧa1)o31;bmB%!eI b65.Weu|UpӚB v<h$ uppX A-glغ%~C7VS# 5|hhmCMR Ҕ?Q`&xm!Z.IuROU9wt>XF>1}Z@Xd?, 5FW>-Y[h92L<0QS<b)#1w:(G Ec/`R,0Lm*ԔpQ{;*( Zmԩ@uc]c4j67@7#+=WFn hFqŊz#/}t2چvT85m쪷Fd6h̪}RUaifIJexi|ϙ1AX@8FrP`\C*oVӡ9_}oG$TT^L׺:T KX' Q4Ct$kwC};Wh9y::E-_GTrΆnN{x|B!/:gg2XxfDII䱤1fgS8:,ݺɶ[_^ U([ `Xф*%s_bdkB.ItGO"c+29(/C 78l/L3\9S-l+ lH9Sぉ15buJC\t&<҆k\f9QfO"":.GyE`DRZ?p9osg *ܚ-:בS|"҇ɺ }c1s>֫[g D^km;|rt%廞S^HQxU36,LXFj18A*&Eafs<>PՅgdkb\`i^g=]Y8rrà1T?|5]qm(?2f(W8ѧ=>G A[RzNWlnRJwY9,k;xfFMWDMU/bz[N.e垖0ˋ`f;z08Hn]،6:wʅ)TC%9ƪs'D+e1P9R^ܜHn(֒iq2 "yӾ55PFk\TƞGA HE8@@CG^S h:] eu@ 9#Zɼ(v-\N[͊QRƜk>&aGK> JRO !}sn-ym5B]n<_Zq QFeʹI*N#iiC=Y+X0&VNӠ٭KCoթ?&O( #p`Eh7[c:a{%W%^*x,U6TEFw{&] Piej"R @!*,&i 6.ȑ=V&t2$)8E9Zg;5!<7?Dө4J,zB?3bbPbſX5oܔS aٞo{TDxL9oC,\}݀:IOvpZ~4݊*LQEEiK%E+~*=>prmʙ]\ަ#=re7$.`8HyT"mb6:&Z?RF<}&/)3r!8XXzl %cٰϱ,^dS^,ylPYu["ҊCm0$P%#9  j5H}z/܎_$Sô|77);cj %ο1V'|-ƈǭ9t^CQXv_W+Q/"D uB};U1V_$EH~G "QE ڀra "O88pnjpvlADP7'[Ɛ87h{3HNA\fPTFcGv‚g#::CV2 :zyhtW-Bgpཱིzt׊ѕγxuho-քi2*(.HBS%{` NjM@JnR`l baZ 3^LG:M9Xl[2J 80%5 =)%WGz vNOOWqJԄȼاRNi1ͣ3kOaS]geW1ٶEGQـ%ߙȱOʊEj[.2Ob"wOUjCXbT0$w )CI_úOt! 0k7MHGvFu.QbD #49t75lm)^ͻٗlj<@/Dѿ] un:o>&g͢sZZ22r _G#`Fjus p'xIf50܌-:ۻ邆dQ7 8b{Vȴ;o7Ju % _*Pʤl'ԜqpszX {9|=y ǟk6-Y[~aq|vڳ z#C̫GvQ(;u[a G=ߎMg ^nI4:Q7)\YpbLVWC4><1qoix98;{j:}\pSv6WOȢHj ιIõe0!Mt1O9 &ZL\M wr,䡩vE)8"zj2B_`]"11q. ɮA8ߐ2 ^r?ť) ~VφEq`aY+uHlwdO*'^`GNlq34 ҏ:54qYoõ\-|gw23ۊ,^O. ;[۵}k1XG=Ѳج @hݘMʌ ZT2ǎr;сmFQJCQ4797{A~e5V #2u t ,:̨irtG4W7Sxin17goB W: XM|: % W߽:;-¡W5j+xs4?ONȷt]r G:NO)q̺[J4iP$"~+8)tK{˙g+e&: 3qM$;ж|-"gFض:0T9@ OO0_(BPH[8sVI`bbgORR}>"X\'u\f1V}ӋAL@2d;:_stoO_X@gG UJ|+O6 p$ޯ"ZJ",Bj!64ibcA]IjvQ|$+NL66H +^($Vpm.ѫ%探 %BBfj5LgQ9+Q~c!uqAp5ޠˠh%ؼ`kf.|#[xHL d"QXn#kfV>y q|G6"0;^HZ[z̬^f*LF7Z|d0CZ!4yv+kn}FFh̒R S8.i?;)3w"LI Owbj ׾<`!X5:cQoJy ݪ6pF3x $ٷAt. g~tpk.٦VAKV(Q| ,z`"4_} z~ZF;{pe?( v Aqx8dIF^9hlY[8jy3`/w3|/ȇ tH2^N6PD:} =N` LqXyTUlx85`}Ƕ;k;>cMWv( NJS$[w|JzUyaf̎E{C8T.4EB_!YAgvߜnW,9 #gS N<]NN&l%z󮒭GPb]$Y>wP|wG`Tp`7$!XM|_6uC݀-2v"ꁉ՛,HvB^gWyho\7, \1IB:0>R{RzatgDŽ7;f9}f/nOϏeDތ%7se7kŽM)j)EV|$ӀϽz%S-yK I;nbG515j4u-"ʏƣ'eN5.~re3ԡoFyḅtĎ!bgZ<}H0UΆU[փ`yHiYGch۶=YC\Z5HjM: T?! C'ELI~nO#X {E:i@8b+b\ >5SsVU/{(OUTo> iYH7~ZJ6ҡAarΤ qoTꧭ CoD}6uB\3TXgT3o%"YxbfUX8YEn0叮rjF0iZG_]f`Y-l[_kȋofs½,xn?SzE*Ja!,?B+mG7w(M~t&KI@5gS~43a3OfbǸtDŽt]9Vh oĪ}=*=Iʷ:DfF}aV2yomXJَW~׽Ai%APfu:G$7tV 4%»1?8D|sqI$H9A:I!b۸U+xW+@%IKYWT~IB:RqlA u .c[Zڦ<(G`$ۖNƣM$*{\IqG)|^{d`U^ ?{O:nnc6җWz@yuTOZs#ҳ?^ o9>UzL"D:&yד^FFO2:] нO5V4 _t k<ͯӣ2M 0rKxpGW4Kt٥{,wg GuLgzS*GH{0T jmiE9}6eҁw08(!|eߵn!.ELr ?o2[ud|V4'+n0 ϫtjp%A2SnȈ@hL@,6E-թ-S-ۮ~_zazg`gT{k@=ry$}[$XH>Jt*$yc1nXiO{HaAVI?tgyW# C@7٢r s?mDs4K?saWe21+- !$7jMNԏpA{{Xt=av@Dٻ'TFP"<>c#[3KI".v,hDJ"@`LF_nTy `],]B-Ń2Qm,Qe"PvjWJ]X>߁p[mϿ,4CeF)ux҄@d={fKţӧSf+X)ŠJ ^m#9asin8?,5GaN䱖Uf#.~ކČV$=_kPBװPU–evsNm$vX͇+h 2s1p$L7f_ݜHl$Hn)?P ϕᇐ<:RPc ܶF*&W? 6Մ~W>#rQjRG0KpED>»Au`=oċɶ!mo':TF͐#CW뚚>A6SiR*/[ c'\xNO6*{w]퐣p |\ۻEV癏W 2s]HݢK1"?>fcIIU,=;-N7F).0Y evne9KD|lec7/sӛF3oC{?/h'PL)s'NwŐ _-ho\!fhE?;Zj̟kij'0-3?z4$`5UZ?rxIl1]eaaÍtc/^6C[`ĎT!5rPBr]kJʅ2FV&1(&tc$˲U w{ ]߼ G磝7Ff] ]MgŌl U >\/~R啟1z~*63VT\ȔǸ5xJ$bGE'oШCM$tlrdi&iMY%>_pv]R+O39 K^>6=X]9V.QJfOMt lWC癩|VOf-|;\b#ak^O/, ךhWO7iO] aX z [H-*dnᶑM[n@7/!0)$\2NF9|3`0~ND//HóvP{`=HuHLdKdOb lGۥҵJ|ذ;Iv?x/K1Nl 4 ..q %AbZPڣZ2; R˃/Q!xEIo-;3s6,* o0\CtJ53*Bc.{w+ӥF~X+Jփ6|+xGXvRCo(m jƪ?xSbJy ?hXy__)Ҕa2-b`S/7Ds.rǯy%9`Lz\Q?YAA>:l'0>}jsOxTl0Xn3C|jZOSM;V)ѷb/XrG,l!hRɦB6Iy4dj@s8Dƛ,H[1BEN(w>ohݔ#jW2ZOX/f]#Duȶ+7WYر=BW u& YRʈjc@DΕ|9!H:2iX8m\? gԪ\Cz0n )XC{& <3*Wrd+c,p;m|;QjTC {TqVmyk;osUYSrdDjُcAst| 9E{3zʿx)Ʃ/orr*xho~g96e?U Xqz!jΔ3+7I={.)r@/3G\~~#6fC Ԧ-o ^ڌ/JDn##Ňk4($R3?1ĀoFF{^+u# 7?AvJ4jERD;Ehwv \UQ,EkRrc׭pvRni;%ހN R.9޵x 9_gfJꪳ8feZKP!L0eϤ1]y㼁d]+YP#0$?C;2_'zԴ@+2kot ֘sjYy9Ȓ T*3TW29!*2g@-]J:c/ڙ;:%a@_vݥC9ܬK9heՋL9_"@o=3U2ˮvҦ{wH*HǓeH~ۑvݍWb21u'g+3 w6d_"# pBL1\Nwbe0q4vRO$y[3 Fog{6-犙ރz+e.(.u iwZt>lmrO:2D/n V1!U8/) 6z+iU㵾,匋{&fAq<IZv_:J֝~6P5y咇H 8@T*udâ7.:`3XԝGX!L50Q!gaDo]Wa @A&K6CMj S#NS+=*OaC" iBn)! ؋p"A,P.q5;5P3: I;RUv13Z]W[K+4οegX1EMY\G4쪃frCc tɗ/d]7Р{5?q_G=e7{'s>ΊR]PVjNJ۵ƍb]uw 9(>͘VlF#'͕Q6,:dL\͢LGcהxb y` &~\ƶ [+ pFwe"7p 8N=<>_3ȟzέ_C-a M&e|ηł/f:,L݈LrxYƏI/iyX[9b4@M[&2oi9sQgug-4VGY9 jkzurw7])ܐ@)p`'pt9N2+D+UGv22zq0{ҠFPaSk~j $qk\<@QiZ#& sU=̻tROg/y I{ oI zYo:_>M\ЍoD ~@)_z5ۛF=G" d WiDYS3RmYa{:Blg˭0ZL ?3y[t1_EM*D.Wncn ƚvEw0dZ2OX];0ʍVZcI}Y9V{7:6zk; ^dg, Jk0 øSuߞz cDJڸ}si@) $t:E4 >m9'q#03`}twz擘 @{0ܤ (P: .v0wD=轈AL-mwO$@gX Sdkʵ;Mwi$u;BZD sCgF)v!9Q-֓l5I z[V J iY{X(@3`4F&!3OX-!_c5}i;[rs꼼I Wmeec'oygjz.ڜC@ъC_KH2c⢜' 1qǕ-ԘE'MВ ?H~՗l"gnT:;j K=Ssr}HewA`JRZIs1VD ٯ˹l*Y|`a+e\ (q%qř7@ k0V[UI3uudW\@>~0 2.,XEwT9#LnLg0'fX B/}8\ݘw#T/ieSZS{$\EN}fWQ8@rm"v^h vh'Jed,JkDgٕhuA`BCUob:*oqԽԁ\ 3}\{-=_AQ&Gu挄QgWH祅gG gV}h|v܋G"0k\nzJ,SK@(uSF ]yy}3@KFCco+@Ce\R64Kq6 A($0H)qd,_-Vn0[8ɶj{,kdQQ`su¶.)N? Hބ Y6޲^ouZGwXMocQ#k45z :t@{GqgӮ4j1ey *2'kMlz8p}QikJ͵9 !1cN a:qՀ\2H#C~n8?X3ߓfoIL3__<7Iju-&W/”x}$IyC8]6fsO^C_/y R%1{l:D_ ͆FؕM(T V349{|j].`Qn85hJ\;]Ub7;W]LC_Ցc ?wx|%/5[.~4yjB|)~ ®>o mEQ27Z?-}dӋѣE҇ɾ}2o }?V.b7-U^EoZdC}A- pO3@y\(y;E|R'ifh^#1-uAy76~TS9G=y`%b9AaTVP,6gkm"β(ܐIg:XL[E%-ld>l10ˁ2 %=}'k JF=Uz=OH@䞂Á@ON)'tRGc``u=3cF!&7J1$VBeWPq~٢3_[0 UDﺽtΔPXgە1xþ?ҟhŭ&H_)~_ ~E݈%SW&gGҪlU9Rr Kɍ yqwr~R^5rW31qJUy;fV^ x X֬,>!LYV3Z 2[~U9u]KY]]MT4]S5T#0: IgMџI y J5nkxaCrwu֢&ΉqYi$ڗ2j:C|HR TqE:3d@ h ϖ>d!rKة!,bdJ{;ZT?n 4o87@5A&^uՓa9wjO!+/G=Qܹک>%\"zPɽ `w`'͙pLl-T.q+u0_L+SI8<“V"A:N.TۀYq&śinI[Ԣ?r9-p@=+|{T8o-3j6# Ciqd _zg.-,\`ibI Y8QD ,< Dw! s~„0 :=0bZ` $bKfErȥU1=6N]t1Ykb΍֑B ,^RA_76lQ05gXw RǸC#Oy}!jB.v KQONFn>1&ev|j FKT(@yGUJ]BM#Ɵ[FF[/We$aciVW+hPk&3FR ;ӄBC=Mo'~_]r'wBQ8bƎXV4u7!;!l]fB9z8XϏ0udi4-UXkh&5Wc*SAIs:sqS/s]bqw1u&?+¦{enjYn".(s̬}q/{vĻwdDJPl`j8Oi/ހ"v@v1z یc"Yf&PR%jrOZ_Vo7¶*_Bk5Xy?еﻜeY\?Ҹ֑ /155͊4k]deYxZ4JzYE=z.z^Vr=}fvK~x3R~]Z@! goBL4<[pka-5юM`# 0iJOMӑ G`?ݮP&+>34FmVttcn _+P+iQLY;)L%-?Da1+ j3Ot!&9z .0-ǂoڻ6T(pxd;Y-tʕ8̀I;uH6P!GZ)}̊XdK'Zh`hт]α7"j]OhAaEdĔ" ~d8wp*ɇmރ.9`)螢~R3g~RWd&π16'QFoF(b_)TF؎̖kp\/"=E>@RG&5B\Qs0:jc{i^ց? @~?f=p?MUѡrF/5p3/)bu== W_n@wa4XŠ8ݳCb-.S& ebPNSw+BQQ h.Ϫ}Ay=Lq[aB}g_zbjJ.3gBL֦rpEj}6U|Tve3`.iG#UǍNw;\I"/ϮT3͘!߁Q+RLË(=R֠f yJIMƂlDG (v#SW[=~ROXnƯ5f-im&Vp B"݉T!6U*9Wk$'+yً.#}CE[k1.jc j[,F+.pJbdo+?<%~*6ɪ0 zaxOQƐhssg?|2ThD$v˕%W&&M"NIwƜ&?W4GfplGꦖ櫲Է$)Le=ȳU";W@ꫫW3>wy'oqa w,jL2Ogh/j7|pY__h ^DN0!H@8ҋ%WCe04z3u[I"3LN[{7 k6rJ$?57ժ JOa鴁N%;mY [Q$l}gW/ۗiwY ߘ&\s$6IXGdv;艢tr FX37t+ʶVN{tW*f6Z'P.L;9(b7Rm_%k;TaSQ)#67 2\˽`@|J:8|ܯ}|/7 q*].'.Q_^]<ց~zNj߂_;]5:Q=#>Ddck䝚(f';s\Z,v:&@^5V:kIOB29N\fjcD^Mφψ_-ZT V=Ln2Nt/}voxMcl2Rkλ9i@lJL>Xk=]Q BxK+Ũ|ڲcu'a ica(L+-[njQT;HIXOy^ M9g-G ^>@c t='Xh]D BSsR c W[ %͆!QdxgDU)7LX o(x>%B۫V6N7p9QGHBAV@ZWt^$7~= g~H=-i'}Nmr/а}s Ŝ±E sqOH`\5u( ^Эun#F!o511Q$ 3 ]Ȯq8 ғ瑆-O^Ŭn`4{%@CEJ7JY%#+83iVM,_JRAKޠ_XbMal{A *,_䅶 WZ^7'lVCHqFl6ylCzI~K e IU^~jO@鯝8j>׶'7ofq3W{t8T q4tI̢dN[Tr:"DaDŽ>iK=by۟6/اDG ~lMx/eF2p'a;l+x M_е =34p UygEϣDpU p>u8bo?sBok294fw]cn)MGh]; Uj?>>*,#Ẽ$Ɓ/9]ٸ9rve%^&lzx,P(~X]ېhe@t gg5+t.P>WKŸ;Uytkx~7w`^Y l[JA6JhP Lk-epJ6cl<+>* sQJR%i,p ګ9go>aZGn^?!W_@ghǁ"e!(Nsx)tA:6BAvI cOIܖH0WMRpTE%٣6~DNP{QB>m*-Zqm{-LxOнTT A8`uiҊׄk"Sm-5CZjN]LRk#LNJ-J^8U"~uSԻRH*1(y^wj׶(YX8x pB2T{0q+d +AzjjbeDƙzM3tR]MT_UwerEK@k"7QF<>JGDf%ߣDlD"Se GvnM 3t 1{'', ˜zgM<+(t8ˆ1:iSF ;sKPwSD HIZ2PۙHe,I4Kj}F鱅$ 2IH2l*ƙ=b%> Dᡌ.-.$>2"4QY` K7ːlt%.*Bi'!GO>&4oϮ3Ha_I:ߒ NA,)_rlĶzZb[?QL 槒 emIU5̾zkB1mniQ|v=Yl@4~ HoYdeN7TNGu)AR!i]Tu{e“"tp/,Z$--_ڱ)6ء, f=P[\!8-4x!T ʔrGb)09{\w-qÓ>h6$TiiA_HRcQո>Ce]s=}X΀]X<|vG-W1>\]$~Ðs"(0{N}jF,h K#FŇ*q-֐1-I(O <߳.s4Nl*6ƲVwĸ-lGаk!i,1H#G''A mok^FsPzZyyl8f-iSzUǕ77ׯz%KsKԇcI[/6LsY1"{& 36kj>.0 +<@;W( UbC͡Uh9*}әVN}ES"a,wu :"kuQdsΕog4Xɜ֨ڇa浅g ^v]HNzV.WW@sm/dLl!= '|$ָ j¬<;,uޝKWY( {ApLm(<"w(Gh>4Mgkݘ%ؘƓD ŴL ړ[:q =ÿZ-f=Cym8bhd=`巿u"O=Iu1wl|Ga h 1z9P[/|2 /?Z?:NrbqhQFתr oeLu>Z sz:F~ٙ~OTqoeXhJ+/+ }qP.b6}%WRjROnq8k0P>R< Q+ݣՋJVwX1|it`/ ڄC -}ٱW= &+I)Vâ?\z`Ҩ$S]oT0EeAAP+o絾[`UT+@) +8gJv뚂)\@ܖk02Y豕VB äƧ q%4%c#_s^<%I?Hv=|])S)U"YG}Z]/!F8p$G n#8$)LQ'e !Ix JV+`V=lnkCaCEKe8>Y{وIZ?-[9z 5FP>nϓ=:Ld  +NɉLWdz.XHke  M4]ϋL5n<|_jK,`L: ,p<f3=%~ )[2Q!ò<ջMBT3p]@^i`IO {d9Ȼ@jyc9ɧN4i>5$⤈BSuԟ&%r}$~s /۞P?-1CkAa7o5^O&'6lol;ѓVxc$I~x\O^~N7eKz2΃xoSl](vXD`ܳU?-]7?kPg:N4r̊j<1kءRZ~l:^F!n0Жڄ,}ZO9ZO]1`7h^_8a ><^Y+ c /Y;`b}q=I@c{_mK\h֛71CDl2W;X4K.DcNJ>dCvզ3Nz0@ːDЈmcR4l?*Ga9pW mDb5_Q&Uϥg:4rQQ=^3gcr z( cifk9,!,'HWܾ8@T8Z".=~m"A\_/O)s]L}})f"禤*lnK5^G>hϫ ɀ|>r:eWW!-b+b&&$Ps8~eʸVW+$e;IGU$=[0UM[R̼(sPH(P%0<sy{oY x,[pj58@v<|`Q%ת04=7pfF\[M4U;Gyai~,8jdB3*3 u TA(PDLB8YB LUKBn;p ֦CI9o WëɼgxQ *ۚ:VnWeYuҎ xS-ҙw`JBeCT*ɭR>O#b[Ky[II{7T32({f{]{W):@a۩CSXuxSEX"Љ*& {=UWB _OxWf@ D:PDjG,t{M|_"Bzގ肥/D*&!!)à=+ݴdë~ I,V} muՎUD-Ke꫒Z9DI%W<{ f ;.6gأ;&Q@3>ԡ2-ӏ"Y,уU ]T'\($AXt`**}Cqf PAe9"8젴@z"atVZf&*)y&'"SQ>N0P+"Τq{$:z;Ci 72`/?k  o z+@F];;õC ^g.?at=:Z;U{ve̫HՍhp@# Uߕ/CȩA5  Z"ȭ M`_#xH$H&WM>cD%[_Vow j#bJvaʥڭk-1 [fK?_,8 NĈѓ'!Ἣǧ?.z;Q^X| q9M?G6AT"}Ω Rum|Li$Iw- pbYTOL Ji8L"+D8HSJIPB+4i70FQzmEgߜq|qp(cbQb>]+[m2.vL={DEݓy(|/kezURUut]:R,dkB(w\a8'ȗ9axA螰{dDVD)uzEuм nUrJ^q<%JՈ9#Ir@ǾN]J8G{}C7{e+=41 )h B^ oZ>$Tao3_NK뚌ʻ5zy۱tkP4sm׈Vx^Z:*AAUW*z9i)I16-R[kq2/FRaI%ceX+%|l֠gi#\BP)sX.@TP$F7\79A] )8"n[` SޡE6DP<~C@ gaC2SA TEڮ}nU㳛q8G3 3!hc&qdke2G@m#QTTvh25>#I$i>:7l6,tj#LGE(!=y]Z/7xj]IpA"ܚG%kNK:,(f>ֹ?۠4*˘ ǵ2E" ".V;T|B=XY^<]YWW]]ifCl1-聈d{H@=gъg֍wVWx]*2ZlXT_=LK&Aύt;մ)D xH 7+ ""]-)IZ`mevXՂ΁4 WfK(V(a8 w'eY„t(tD[wS.U7 XE \ཡM]DF`ctw~ے\ t+Y\>'ƻ OE8ХPXH$3QX;YnkzВh$;.K;Mk69)!U=}5Lǃk~#-X bP,,`qQZfuzpmg9# ҋK}-Ón&RwfuKHk+ӘU T}@: UTguY÷EB^SVbK͑U=@YZ==^цiz7zvv"!IMl+Hk,Q/'hL4P ̃ՈE9" Ax!V&g1 I./ڲ ۩^:A2%TWy7;ʠ22*yv帣uE:!Ӏm$1\"J[vf"vZ^e ,in6v4x|M;+rYChE4U3EEFPDUt38ZŐ)3;.*%q:1(XIMh}%Veul@u ~8 ×T44SZJ(rCF1D#NTJUdwi&+sKPy2ubV @|x9b)Ģ iƂ tms…@IqRx\`Mn$yp"*@x2I8i2" P"VjWO:Ո{a*cfD^qHU2) 3m8Ǝ})Vm\2zy q-H*t)n(o"ty#yΊɷmh刡EUCWӽj1j=-lri]yd4}ߌOMJ@mL ).H9X ЉDShŢI ˖;fʳH(r7xAil1kZ;3b;4|*J8P7ICrX*}{NkvE]0BIzUӢHUAH 4[ " o14.Ŭ͝Vv,xA"D!(!*T)) d.C#Wrf2W5 ]ᭆ+6SY 5"Hc !i TyȈae @vaAǧgyP^p'kҎ4(aIX#gHk2 N[AOs' 43;fR.ᙸktТG%p󸨡ZN,'%=9f8J"#_R*3;fw7 8q\iRH8uQr zn2(ttͤiDhwq^mΨVZMG)$a7Ȩ3"HHHHJR&0BBB Wф!!ƞsw =HR"[;GyF M^VEXpG4׬j3^[ G)x7j@9.@*tʾ:#o+NӸN=p"` cI0Y{tyiLstG@~4w~{'*>x!̳w: +v.ŨF{b!1܊g恣ύu/ Eݰm1>\\F0ƈ%Ø9Bh?`; AulBtcs/dc=W( q86oF h9.9whҌOĊcxӽqmXom6 {,z֌q"J=6[-ƌS9iXˌ:Qώy ~z @Ǽu揸:5}\]g:|f!SZ 0 !\yO>o=獗pwk.g7r_>cO},L^O3g\1/#Us_C+\=up#kaz}G7ccc}b﮿yN-S1箼 NE0C~ꔯ~/gez: lXT:)( ,ԻVo+Cs?c~fdC]:e~y>rTC|_-w_۸/?y7Џ'ro1mfZ.ZDD(uj""\}+@%D&"V`VKh{NrLr⽯ է\ ljx^_T%;>|xtCy6'y!j晁pf>È%.fRRaYq󍱝n6u("|0H &&B f ~1@fDDEࠈ$A@"&c Xg=3c~WS,d bi_`5U4ӈBŃm/C_wKY&qJpI/|5,?xO'^??|/cw:ܬ[(BiL Pp`q@b 3OOmScAy|eWfK&ǡի(iDfՅ8pmY7a|&9ttMNKn##ޗ G%@׼p!iRe ENS1,<ޮ k9O}s~}NwC,=^vr@ :)$_Jj 2b]+&(A  nY  2#m'zŞ)HFg_,EbC B8vns{~ >Xb?,#08xM"lTQeگSd-O+㏢Mܜt^qn={cz!ۭi+y5lWIk|}[|cYnI^z'1=ɣ>rqZlZ5mKd%ƌiS^8#0g}vögDd7)-.ӲOk巁īwyk8o8zuwfmzs9WǤ6^\ޖpm;㥴|soGď?uiZH,pg]:7ohdݑ$%s;oY<N*EAFX1&\]lhSUyuŔNί$H#vSEP$pU- 0۷</w;6x0jeQ˩y-[w-fMWwoP&X7?µip;o4nDۍ}_L,u7/70/Ix(z3w%-"Xjحz@"Qj9ͮ-a^Cy]q K يG@2w8kKV ihZiԸW goAo';٣F )sR"3HE[*] x.eX=Bn>4|zk3a>_c <)L:xqY,-{U`a. l4:z" /07_A wC:z]fszw(@Ã*ws4`[3b8&b1Ab%`*d-#BTH ⸮39 c38O@^` #qXUUo,PS |_u/ɿK^ͯq?|Ox7DsƵe! 4(v7;7?~wz._~?0RěAY&MJLZip‹Lw^4s|\Yi0pD Ȋ+˜3Uv@a LȨG3ɨ\UUk=XКūYƇ ߍ{]'\?r{~WUȍ{e2]" ]w)%U o{ hsnx\weܻδn$HԚ?{'tX/G?\?\oaM^0/}N{/@m/߃U\=NUp5})vaq6u%4]Gs#vG+Mr]ndFHȅ d  BG[$y@i ^t>V0"&Gu6Oɔ=+=<۾Fƪ=*?L}?8_Ӵ: Ac#D_'H~_Kv-H@6f;Q(PBibbB#mW` ~F󾚮<OeBg)Yns.Uޚ^Pkr~'ũ~Ɨd2J(WRDL_P?7 ޟ%mxc'y: {NU} =up<:z9|:'(.3&{?l:`eձ|ly.sޝt0B HJ0@' 7h8/|CD1TDIIR1⻯_KْxpdƱhs }z{:P)Ӓ;5 '6C$%%ks LAYS%*jm,4Й2a/aC4!x4A3f ae Gxk$3&D!$ 1q=߼_Otݚaoۼh-ێ 0ƍym/8h`s1S9 ˃0wGC*׭y'C?.Z2oӺ(d{$t!9"P1T{Ts>* y+p>*_7=6ݍose$uö]CQuVlH3?lTXȳ*qǝo)bZ:""  f~?X[.Ga]{.>n#Ekߘf"c8l=mo]ݧa,{n# y{~gAOEy]9yr a. h{RRik ~_ S`\~ZVxTt d_v {o9u8^wSR4  ]n(JQmwv_0~➺1Yq<{<#%7 Fo[4>ߓ-Wud!ѥz 㐀 )2#W{""cJoV׵mn$btsdxz"[?>S_%1@x=>_](nbx9Plq0Ur«ټ9#񗜟ao'ùCʵ23y:OxsmoMtއSr}|kpR& 6Aܠ v9|t˜G'{^Z]ןf&va&6Z\w}lzpה}A!,4t"wf/DaBp >s"D~Bvg=ñxo2Cf]7?#grF8(5Zaw]k3곗> Q]^ȹ%!B4)BDGl\*AZECc|ijvZqu!/{=z%7iRj H]vyT= K~ }k٦$ZcK<:0+ 5rg//W}(=J+PB±C As v" QVo=>klDRGYa;C=' O3x~`vj"V#y"S^~>Ty Kl~ j*Sׇ=Y~&| o[/HP8T9 %B꜡=F Mqe} e؈Mҳl;X>`%ՙd1r;<*u4xy* LF JK6ׄ>+ x^ɌoGv .*VV z÷m~ߡ Ī>Fـ+0T0D9 %D33w|?߽;:7 & "wmz/X?ox~2b"@}I&뭥HVrIKl)~9Sխr"',uW;Z$}D7} Y]Hd!5fs|7i 3r3# PP 2+)Hs d_2 vͧoɌ?;@d,oSnX>MqlF$0 A%0CAQ,9 >pO<!D]>cJ9L$@:Iֲ11[̀g0SA!U;wxM(AF넨^>'&~<<OCl" ׌i)%Lγ:8DI;?=ֿw0ލe>(Oc1D39  :^/콙R4nZ2q9Ǜ'Y|Ptd=Ւ3{`Gq˯t'5ާwHk sޅ0 yj!@ |;BLpR$HD#]W H3C,||,KȍhE fH2nH;T׭~^%2^ȠM7 ^;l?1gh9\Ckn ։31yr-цYk3|l\Ek* lCT5nC2w%-w-oqOk;Ӑ㷳>sn´`+ߞ.V5Ǐ!uS6%^Cܷ褬:Ne6NϻK;2ʣXjQ@$K$dk\AⰕ29+_>Z6A7Tt7r=G;ywoJŠ"  smb4(3SݽW::ip>3ݰ'6ˆ$g~i;«Y鯯`P]v%+?vEV4«uܱp1CY3y Sdങf367UuV&7 dʰ32\ Ԡ)9i{,/!mۿ} I0Vy!5 ]lumGV5!"Y4 dэ}b5뽦;dvLbr{8M=hX765| yٱrO{M9%gL< gR6k|8v6-o8=~3=*yM(J4 @Hs>|Wy=l۝ï|I(}PP&LPD1BdK#2J3MFM cVn ,iMF!dR`h0 aɅY` H`(_2ac噀rj)Ɖn+93fb˙F˂W/fD(Ff*άda{GYÖ2 2pKaL&2 >8Nي8_[c#;Pޒ6Oo}nž{*Yqyw~BрU"H؄KA*lPJ`ɹjOSz/Wy[fu=M޻# 7%=`$g.ي82@HN'O uTAA?~ָC@IڃW}hvhyfҒmsr;TW|ۙFkg6Y\,q;%Ow ]{aw/\|QH.xޓv5̷{X8!W=𤇹X;iP9JA`kek/tLc1Ɯq(#֭g>še! Y *=4m[& ۧWv}oX߹Ս:yeQ5KZJCd`afc(l``A\w:4X3 OȟH B\ڜow~ˁAE%K1A ./mG591PBI@CW"/!vBU8u<[H" 1$CB"PՈab} wW*5t -,Nŀ y2_3nq $:- ,稀Y «}Y.h@{%qYjc:Z\>9_1[/\۾ A5)0xH*ydt^ITa=$ 12z/5r >)uPnP"0y""Q#Eլ@^{,2E=Ƌ0nKD 4PI,`@ d߂DK)%l&ĭ;lzm{e^O .X;^$"opCU 5ho.*]fِ7%@0@"Ɨ`!y뿟| /Lan@.o{U Ȁ3fJ &uPj :Aq4ӵϢQび~u/4I2 F`4 T%R8"iu}UR5.|mZRLpn/&!"@ gJB@?ĉ) ij[Lo:_?%FfmI>,8E#l 0A:H '%O)~38nkn=ȞHޤEYb+Vݮ ƥfo/{EY帓 `C'3Çrι]˭ t$L]UiC75cu::E1ii@T0 Xkچpu 8Vpҳ7x'Ej;9q9;!;uػ LU"@ sY1p B ^>hyB0~"Ew;y}aUp>`&HJl1]x[ϯ0,s_>HeT'^@f$o+Ys9$Tsx..mu_{^5v[wxD#9+]nţm6כJZ(UxQ{GoGCiǠ]z#[& >ޔX.ua p[=nx{K&ӳ5Y*o?3i25⪫8 {\Uu99*Wz6cUoXicQ7}Ǭ܏cK 3-W^Ǭ$<#Qz>_[_=?؟S;aMOp9mm̈ eKn_Yپ&76VO($ͼ9sq181%6pIE1 \cHdX )Sňƛh+ sGK7={T>߉\یHvZu>H^rrEg+cda:i*Z.6YcdA e5cT8_z>[9ž~w?} P!u+!Iʼ#t-p0>Ȏ+ď^dOfJXc/&5M]TWoc*0'@Pg PpqD~?Y p-n?y/mWm8 A7)6CP@UD^{lҶgﱿGAWZj~vC,?'hfǃffУ( B|ZK Evs߼η7 ^, #HD6XXpl,ȷע;םg3 7Ex`2q+3#$j]N?gP!EHp(ab 01y}1>_S͐8H˃6/%# lViDQ/.x<}3 &X)x0=_2ᄃRa}/SkL d!B2 zF@$ݫ'.*(h*%cZ.'1z.|sy-&ճU?xC3 ةd2`6kK`-]WWsW>gwZ ג90)F29!]tr|؁H]!5y[,m/%(cmFJ:>߉l:0MFa#\oyc> 9z/Yho2cDiǭ0 |_L|{ 4,(`fz/!0aMQNʠ{h<`@A|I3ŭ/6);)Uڰk@Z%6RYt,nz!P4M`1 3ҧsLbe_|OJD`0˲j10F*JH"cکa&]Tpb,Y}D9yR/竽O7Xdq 2ܔrd$(ʎ{N5́cY߱dқ$#hRlFڔfYF+: h0O,JfBCEmiTL ,ͨ51)EdP( cY hnj)clM^5C1)-5YŢA5a&BJ9?x_-~ H")BbBgo{tO0`!ӾӒFֶ)/B}mz{m<t7oA.4;JI D)F(di"4lmbE*b4 _|\YJ(Qh lĵbVop1^5rdjRY(PMHP9!GF}hvݜZ{֝I`} 5N?c1c`N(M3Qs n*wipK;k%}iTTZ],a,\ġPhw d\k!2EpS0F2EN;݄BM0^7QAծ4%5z4.ys}׹>I?_{QmD @R5rZ}5uϏC_þ]qƹ{ג>˲ݟ"S#{yAገaEbAZz; /_lgHH)!\1.m@̈`K@W:%N{ݸlEIdLueE\ erٜb}c^}W;~OW^44Fϯ֐4uv^!@Q0C$3 c4!Ѥ@{?-w !@3D@#=ke", @ (_q{u6ƀ`ff@)A@'ݥƮ=rQ|{< ZfX˷۷c-lypP3 7tߐa( A5%Sۼ/"N:<;3OO[I3-X@ 4 K2F@z :#^R܆N *~acjH y .fZ9v (D5c_Yf*(n`) 2_Gs vs~*d(H7}>? #g8xP;L&;ŻOnÞYZz4nɗ.Lg_g..'Ygy^q_DC0yV{y$3ajG;FhXw~.E4}eFnYD0z K[ݰb>u=ݿÙz{EzMNгs-W};r2t"r|~7e]Y>EXΚ)vC5p`pc8Mz%0dgʼ.ǕU7@2(i4n4cMnOYf@2P41,S(TeBnHW^qDk,Vs"/wV)갏ڵ.?1Vj9{[שl:f*/73ɘY_ˡΣZ9Jk:Ӊ_elYB7XK> %e8k6 ԩTge0s,–_E|F@|t+H\-OөA:'wa)bmI G:Ai*Xu~h쐇sРֽ>_^Hx _^<_@OIdLBGP2|ሄs ^U&Q-n FޯHeEɻ40 6*f8l* sreK)ΓN`ݧonNQ,dt?!~k)כ9O- 5iYluBE 4% ]mgٺ_ gckH$ue;''߉kyI65NS*j9ypQSM0U7ax{P8-·wMUIE!5s2 SbEDN6'Q$&} BNJMw:ώjĖ9&^9ڼxZ'{yo=<]!nFnBi(~;|1 )wWW:ߣ(;3{𓘔NE̜LNEñŸ.6 Lsx(Xc+pMHQe-js|(Ő?&TMcFx+%0l/˞V e`/AVR\W >A7'fXYSxp&s!6X뽭O{)ug[F?8#>zĈj.2PX.oKv?ŕzId}j/}_QZT߃뿗w{_68^.}F}$tmd=nzTs)f$6Ю뫠H#5 }SCUwTB1 z"?PzjrńÔUVݥu#,.EWSYIN2 k}lph^)ԯ O?~?gþ<_U#]:&$ND5xP[}zE>%M 5ܭ Y4{PQIu\ھ )EM^_[W,J] cz8}ˁ-ZtUYIRDyn_{K$%J]QĎBCdwR6**DWB|`ȤR2)L$SAC4)/Y(PY|/K1<ƥt*5^?9ȫF]jFND#f#"hSJ[F*]Ҍ}rPh\vR,)B+ä^J~eI"߹0',qVIQhy -wZ&iW!Xg3Sj!Qouo^NSτ8Ƨxv']t s-<(jXI..l ʰuZ{+أ&-RgSFԼP P[d1 ~BD-VO[3)] 8i;#T 9KY54afb!IBߐ\5[k^Me^MhX͵{E}*{-J.`#4`ػ:OiԦ5ݢ6WSPNR[9l7_ 9q2 A/?Kg닔LH$r?I>/_ ە;aUgIlҩNĘzhͪ-߶SO\@} [c IR:N*hT$,v!md29cKEM^PR=߃~nۑy : ]ȫ/|=~}R=zVJep +zDMYuiJVBQDZ5MwImX!K6B[ā2N8V+T^m 6Zڸ@c!SI rmGɪ; - ]' 2 &Q, 21(*u程| H%QWoO'Y~+Ƭ$ !J|w3jiO=R14`C*QjdnB<A#62OY/Q&?qwS%hna`v j\n`F!$oM XEGG(L G1񟟶B;,.(2bb(Ot-'D@'.Yܿ+? _dy{_+4`X0g[x"fmkf@XW#2{qN,-&bX\V!Gp>gKѥS]bRVqb'h8L~^Eߪ S:'!YeykXpӯ8C~j8eq'D߮辳rdpga* ޭcElgs'S̏s D7ջ9ár CP)oIAvx]~ׇ?Lrxb8#(L?_^Hϣi^&Q-@>c."G(F I s\hgޝ;#>ʪHn!ƄUhBR!YH j~>xL`67(&C~ zKu&OSo_/'7оi&JiфELe 1 A,,ҚKQh-,l*1eIJRE-lITd*mhbV U%mF֍)")~_կZ13$D"d4ddLdaEd&@RE 12LXLhb(T53Ee-ص&[[&6ح6ưV-UhV4PGLLlh?kƵzFLbSNfKBo5x[wX)HqҚm8&&`8"c) 2 jРۖ׋A!A!R@ #9_~{LS!&Q I ᕿ_ayَ8\vS`cxOޏGyO+lh7ψdJP@ (Gi"1@JO9J(+qw}uuٶ~}πA*ngjl-LHܙ2m8 AdH2 ]9¡h oSU:\ހ'=md= S@nT>]M*g5`ܧ񇍊(bibbaA!hPDƙD 06&& LF1LQdddF@ŌɚI&$Hh#"a!4#FHf"a#@h1!B"PX"F" da)Rdc#&fQ2HILd46f)LaF̚1B) P(I2O_cֽIP0]D21C ,bil`̔ D!))*DY( 1$F lbLD$&Jl(F2 &cHRLE"m %12IiLhi3"3BaH4BBIb2)L/L$$BF10DDS45ƒ!DJJLdɉ[ݟlIAO?~wrϫ볂i8z}$AdbhH𾥫QۯD\4i8G')" c-z{>[~[GI+;}I㔯rC` 32 b+{x & Ms.?ğ b6jYdŘ%3m8^kzJgk$>)B!%ç4jy;~wZ:kZXscSxl1F ~6?H7Ԝu3 |$yV|g= {_wXte}h;6Xw3` erw܄z>V}Ҫ:$r=o1#~XAvT۸9FNsy[?*~;钺~65E-~ƃ} oAgiaXkOAesP:߫5TOm\Wq& ^~/8Cmy]y ^WR ̝%~v[a|O؝p7Byޮx;f(_{ jO;7쯿;Zcx\'<;H'|-zv|T'wE31XV>G3l}pwU~TZ*c2Fs8'׳<;|s-/l+ose'o ;[;³F9,;tɅ|Xn~N!:Jޫ=2VV_~{< i?-O=}{ivL3USDNͶt:;]f/ ;!X3w0Uwtx*þ- ,^ cr:1cGB% ·as{G/]5t9eplNʼ, VN)M>X<vT>w~#$(-W?7u h>",O,(Z/gln{Ѻ9\'9mN/-ij˼eo |߿x d9oKp7ZaWhyf9-Sg/U^V/^acpZۙa~kuc/&2W1N?yV]ON~_g0Mϳ-Pn\ߓS+t;n[-np/LOۋ;zi[>0۪\'{!]w=\zlpKy UNux唻:o=7;/AyJp]޿\*-?/Iw&KaೠW|[[{_-gO|}vceF_ǻ/a<@27Y;y?;SNy$2\c{~sPί5|7{2_x&WWeVyoo5uj/˰g׈ӯomnxndu&9ڰOmձ}kfs\cSyy :=vN!Wq7<5^{6*{1wt<;[EL~m /u^FOȸוVzށlѶks\7Muʥe~]roK`|Wx+)Z_SJ獡To;x^+B㱴3D19?WFo+C{;e{KF䱼 -/%[~n?853=Z1ƕ F ~w2miW7 |^# Mñq; .4y5*Y_Ň<ʾg){`v +/-udP,9=WS_} 5ǥcwPdـ ̊uK#hJzރd6dr/Ga @L I@ࠏ}њ>|7=Ik@e1%XGzt_{?Fvq t4ѷ^wt;nAv/w r}B{V>L`Ȉu[dC8á%ca9ig;Hm"zS"O3lrcaq39)g=*wJ 5z7unȀ3`Ld'< tA@=0fCo1d$oL^ ?OMȃEwF9d9SX¼(^齀r:l) |{lY!M<gXCA P74G" y X ]>5CYT^c࢚*B@՛}x^ug"oZŒj{0` (ўl̈́Nied U ^h>n> jO;ۡ]%($ p/Sr O0. E 2ȋZm֮||~E 4MJ/1n>7^)r"!(:X7"^#n*O7I$$"3"]^ DTǀo.b= dF` $(#{)_Ӆz#a<ܱ͛G () H #V%WrUqÞeqzȴ[#Bxtw92 ֆ3"AfˀA &AF:s- g~m.m7((ɶPaJa~fbM›Lgf:2TC{eOg"jBB0D!ImjM#JPӆ#q"Un2J)iL]ܸm\Kx4-OEA ST;L 3e˶e)"vAVRe^uvl`bScLbKݬTŴf 0+D%R%j|rrq<}\{&Ctp!D/TIL0e P6Io؉v( ݕ,*%sXl"Bb Lh%܋:c#5w\w;WVe*src+L۔ͻNJB/:[̊em܌TƑn9@ ")j jeDya$b]a|xʀcMl.D>k{ %~ϞzFꬪf(e9N!u;H[WY#b9B''hO!;wN`.?P_ko}wg@8@>4a βOm3^xËqDe6"bi/n~/y:<{fC6q!0͏?=Q!a4}HJ#0ٯ]̥\b&{ۼ [ۮc";.)9QLKKEA4TLW?ɂiIQS垇1]pn"0"woL4k3#0 5>K@͞hA0څG|q\7AOJ@ ^KR0dQ1M"O602 +9:ױc" RDr$9I™y0FQT^o ۰ߠ8C9 -TKj `. t GR$oE|_0 ToE` #u;P[|\TDn>*/o8~|6]sV K ȃB,H }tak؛F-3N"BeDob@@ap%ܵ(D1VK5%$:%\Թ6B[1kE67OgP]>lP.0N< Q'TRҕ OZN0pW@2@q"~dxfq\nARld" Ğ深àI(›Cp /Z Oi>b{=q)ΩBmd`KM#ľIL=E\ ёQN0i' v>fmrKbXu^V+.Y5t[j4_x9Q؜)Yul<µs`ElO[zׁ"e=@ @"7i*xk<KEpp_PP5%XP$y;jVՋasϭVAibA۝ R9?6w6etk(K.]tϙp. k.uaP߰ɲ!Z|>npy[H;LR+r3vQeJ )686PTuW?׍o_ퟢx:58b1bf׹G-OD|8k?Cϛr$}\,!n"=#jׇuvE[6FN ! 5TQԳUsXj+YѤ ^˚hWn`e)aw>_gS8٦ƪ[g1iCS\zOu[V䷈'GIM*At{YQVM륺M-L"U' Xnd|C56.057"D- ljء.t/.m=f!l&C¬-⟣=)^RW(OkԷok2$ǯS櫯 _uI |}~y sKv|ݢl\+cxݽ+]cs)azV\އm&`p/wYRUTO{ew`/CU{]gzd/j)44@ BCuWX `hA@sI.!#/6]c`0D Ep A˱R ˥ AD}^G~7~g8y,c!at$yfCS 8=yfÄd/ I20 y>sb?zOv /؟F"$޽N87<a78E1agѧ~gN/w+] HA 43AȻ t=סi@> 'O#MC_̑om[qw.|\(ûT^ň RcKumne-DCi$'s^js1a\  ̎  =;Jײc < \uty>+gi+>l2[ 0hWή;.5%`<`uM&?X:yvx`@?A6KbbH7(x*ookT^4C Z|<0&= wPC3ZnJy\.pj Ӆ]#lN\PmTi-~IS4l]1j*UE \F*ÔxJ J\ ?DG{_&C<Ҩ% "ng ŧѱ9 v}J*ol12u aqoz;)&0ZE.n[2jV˕]y#J4]=DOVY5;Nwei5ؼRn-׽K0[APtwy[Gs7Ϧ/EqpUWG{U-cGs<{ۃl#bj^ZצɿB\ L_eyEj?c MUӵȡ(xʈCU#8¿IN0YЫ5Ï1v-_%,)MN٘ôӑs6YKRL+*ui[!ẉC.Ʋ Fx/۱rUc 0uӒn.TfdݼmoV-?DD /g?_Et߆^S]@tE9)_Vk^TCdV3-yNT-gM&XBP T~ `6.KK6|gu 1w,KrZȽ oN0 x{J$|ةCyJ$Q+ƾ[z7_Ad`8|>>|bjn>3ReT={ˉ/Vd- 3-o;\m%fk n!)򧩧-[[y] 1:l']@0_\](q) *DuC[mt$GEĤEnd>f}X۴(̃zʌ'~Gmu_7ƞM_/Z/\.{92  V.ySI0b㑨Y7 HY!sIUsZ"Wj#GIiN TTj2p޺egVXֵaES: ɷjDBlj鈜dֶCYX 2'v'_Dy“GxWK:$)oԾmu!R$0KQU)d&tw\t7-HQ]TWN7r>9BK-eFJc>B*BjA#W֢UX <"STE}u X?pgN5?hZ@1u|)NVNU݇Zq1HK4egk"k'x{8Ox8mųV"wḽD@^Ǟ*'_n.4hKH.noaV5ǖQɕ/ O>>fh{hWX^Di,3A3 S"(&R4(JrӾ>6^: LY9 pT U&,4ac,1^lVNs˴cb{s)*/jc}0|̮zl|Zt Vh}\D:%$צ_%1݁_O]yPm [ajd&" b eǿq]} ՍٯguBۦOidA>q84wƼou4}bѭ:ϸێ7~<[E1n0r191cJh[8ls9z <*Ԣq]0֫:"Sg^ߤy> 5ϛCP`Uf@nbav<4P}³y||*3J I0~"1j(oaԻmhSI)Ui6TBNxʍŷ,_i+c*lLK^Ǎìx+a0XX`arhs=K#ֳ{8mYZsՉF>eT۶ mZHU:$\NփmGa_lGAROoEüEoy2M1iF7aa^`i ae/WCg d|;D=#!䲗R#vmu*CݚF<"CŠ!VyY*l'R_˿iݜ3EKGJ N!FpXL;X imHl^!ckFǭxIz>x WDɧ@Ns]8N '&fx䎰6D0b?_3sY|'sq.bLgFpr%"!ݥZ,cFmSd[cE%Q JdS6f$,P@"IH Vij*-00VjBFb" $B5w#A[|z!?AȘ|kH^:8(YgaC'$TE>}qn'8c=?S|7Gax 2U}n힗gn%TPؿx?{??obvdq˦͓{G[>֋(iLSmY%2 oM7䦤$Fۋon%V.pWރ0%bgGͤ@İ<dKXIn xpy)BA-~Q_Av26`(Mhii33P)nݕEQQ,)+&4`ѣkѢ Lda6.]D%b <1e}EoN|y!|TA%DL:pD.УH8Vү 7sZ"H(hWv40Q1DEZK6QZ!0%*ь3mBZlj#fȡ3Gw!%KK3K&mJ\J 52DsQfRhDvlɥ2X0\6clM_z"lhh,FiAc&*Q)^f F9iK  4QLf TJTllww+ōEJץˍVw$ox:: p@&vϿvܚ 3POai[WֲʰGW54(%,Ll151aI~K^r<+W%L 9Z73-rEsRrF G\Hd&ItHpL1\0\Qp^_O|>W?qЫ/fdErdBxf@[$Po7R M+_O;#CzǩS\+vtEºFoH[{Tv'tS/89<#XrxMd/r\gj)&$A`]iju.:3xEyATrMC!3#տ%R?tң¸zLRϕ(&jp |G4*حM+4cMKynk5^byʗk2neeU!z\a?Ikf)ƠGm+ƞϋME)wcdA#! t>^]>Qq!:$8WۆYYZIiI>=F%Ss[9ҢCBulti¬.;ؕxfIZ ^A\+`j&-Yʎ#<,I UDffRc?}P\_kDvCsbf@&$@ݚL{z;ذekx9f8rMX(`" 1%@PSC$H/,,9g@$ќQQݾیD?S~{99BPR bteT2rF],L4b^:)mΊon_KΌAm>w#ܤd mGkmc"jN5{O5|,LK32ffDd qvu*~Oyݿ{q/Cco};^rLy+FAϳ2>% xsx9ߦC9vGpeΎJtq_>+ͼgۏ"?N|a-4k$) @2/aIt&Ȱ7;wPsVp7.݊\i0o2B`Z1fbtK~''ys>}~W%|bQ(tm$m&rP`2>1 {NW8gweZ싺xIԦoaU~]˾:,.6X mYfo^+5ɜR*_j).=]sV4*ʍWʳlIIwnrX1b.QJ "M"ᒠXKߛӮÂQԿ7 F`Z#bɜ۹-iRM:|:;n|O?%Og?ɬ, ̫Yp Q^_=;jh̾7 ?<3ۿ3P{xgөٷsRQB0f\׈0# >4ӳr޷;ø@!L#ی&<~'s.o2V"?_?s°H#ڋO<87x[  kHߣg:sds1=YEdTشrȦ ~̓nC+CxpWwELYmseCB((o-2J0BH '8pbwAͩh,k"?슾Ќ\d}rT"0g:!#2͑$kYO8$G?ay\yHx+#g:*1;^-~}6kd~kRQXuv8˞yRףжf*Ej%%Ȟ@2xFqHׄ?'{Ʃh`c{mJ*d)aI;A50 ?C!zKt"H @0=7ULTpqg;G4Ht5^6)[ a籰}z:[-d*`!̌#@1nYَO~7>OqoIcoN7Kw>Uʓ@ hbz/[΀KNCRmC@R)!4H Dv"^ț dAb G!imsy=L6QVfBN8\x-ArV%~6&Eu33?l7tFfǓML ,[T> |BqB` EZIǽr=d$_0byL: p8_x]͹ಂ`JK(dAzBTA,҇}YN+#rmܻUF/>xn4Wó+ca߹(xg/-6*}^*0! "!8@̌̐]e?v YݖxΛu@y t{K`3y)'S}`zGY#ca6Əc$S"X`QP0aAR',`qfLcX @HXTđGvVtcneS,bk@G+5âI6uw |hyy=鞳WvƼ8M;k7^&uHN2HdB,"-0  + tg_eC5Ig8at*LתmirRcz丒p&`SLMiݯ?w7ݦ{4B|gWfBR$ ج "G!*Zjs^~t}Oc@E#- IZLcA4Lo) \-.@.fd " Nii^vqrs[/^y.4OE}s.үv^w}ntr?n_=G!?J:~wy>ճc}OpOy'}x\g;˭񾏇O;Ϋ{o^v Nʫ*f \yi۽_F <#`@_E20d;?DCmcyޯ-?-Gss}{_,R_*mV;.WaϾ],r>.X?@`#h< fFaUߥC lrTo_{{N듺/}nx~}T>UIGcn^h1< 3`~Hdq+F?߇pTH^61gH@0ۻ[\b[ .GF~)?[Lz<5{dv654`2O7e"ӳW@tb; SG1T-Nn/wUޥJ<NlW$^s]+9plvC<Br9+pYG{N{=O] oy&A @..$Z&T걕\i\8 6HX.]Sx$n̰5NilS_˕sQ-;TV*1+>f@x$WTxcɷW.Tj8-hd,deRi>}"w);.gM ~bdaWPVg6[([#kU_|Val/MsP6ygU*`d>,'pC_bI,[kxNXӿ/ty-L shQR7gwω ^j|Geu7ٵn*l#%mNF#FH..,FNY#a˩u'y*e4/U?{=?uU1SD/5B¹xlޚ9v~l?3 =.U4AYM;ȜJHU "Vvmzd9*x|'-#J *xhz9L0@"Gj!QBO~BS1=n0]oE?Um悱0]=#{)qo2jNʷxY$WW(:LT¶(>.}Inv8k᯦\]C ='w3&C[߹ʣA_#AeSݭŝ LZ ӯ#fa"t|m6!|3t / Ut3U'*?CF~ aTCXq( *ixMalXbD,]{Oec\qsՙH 1}Abq3&2m=If*i h\*5Ua׷(A:Pm⮩I9(=|3{nU[F|DŽS;zKT CޛMit+%-=uuR@,-61 4;KnrrE#OYaj<N_E\.v\-%.NaO;zJ'I'E_kY3UD>]7?BUUk}2YOM{/u~fL'λ-iɺjF69d'YˠVsF~]+:?d%]y* V\=Q5_,k;_#Y&#Or`'*ESblPg3,rLQ;ķ=|ـ#j@6u @.s#sON(#\texeS#= iv#ÏDԤkbi\<֊^%  |C[hƌfO[MGbJKbx|e[:s^DQ G7R)TN*ApƂ j!Ú_*VO$&=jKAx,XQAB&0V:J'&yc[yeՐ0 )~fB|hcV+mN`ZCȮ]F-z`w QF58|֎|6!s9a- ?9 =wH A|n6c9eZfd+:)w 3u6wXFJ21\24Q?thllΠT_OU%}k4o@ s=8tO. g-<ĸm!YC+xz}k9?x2F;D}Q/DUBa3LOQ0-ةp܆Uf.9T *7>BkfU{?^aS٠2T@ѣB{ /9C/$s'`Fa֝yƽ:Ҙ8B y 3R H4%P8-|k:;zL!5A2V ՑnOP #Ld wbF`$#̽AARLf-$BFF:W%DU+Jo܅`4 2W$L::6g~Xq-#kFwH{MSp84 hmJ8JKRZ;~#=ԘA6;j9F$HzH󇔼bfr)bX՛}W3hV*6]`}DH/(Q1)Q.TDuF*GʥHW_PLN@3=Xy63PʡXce~b15 h!E(jllG!(ʴr XUGa:ي o'%IᗩHBzۨ"pOxsMxxAϼJPkyӎd5m;* f&zk#&U˻δ1g=R0(9sݮ)OeDC_>GQ!\Akr){Ѓ:l~|b“\,񧀛1oF0WfЊUlFvy9^S4Djіa"U$ `b&d^%ͦ90Vw#(%cyA<27kZXj!dU8:mJ@k\  QzL\ri8Q3*w(l_zP s^c[i1Q*͹Cc>o WmxwoޱAmu WDStuU6(0v fWd2B?ث<~E}Z[ ׁN컯ck+a0"CC.Brߣo=z\K50-TѠ " AqXʭm>nQGVeXZUL+P7rX5 @i/ظS jap}Sk)óv FU]S&[S}R&=F@2۞P I~K0zv8;\n1j`/2VU8r) A)heRͩ+PT J(uU$^CIʩ,i٠8[-K~0{+]zg53JBJ`3d)* D;(z^[s=P~{Cpr5x+__Dpf)e7$9+aƕKASvnvm&Cv /B|:YhҤw>o޶ÐԿ2 Gbߖ6ڧ澽{LZx2̘~ܫ_SY؞?8hI fDf#i?k zWX= U7g HX/oIR$$} "(&&ZlQ#QجH[dIEPMF&-QcT[MX" a RD!@QR- %DKbEeJEfԺoRGy iʵvr+KD Q2 \l pE C0ri G%d S@2B W$L MFS-6]Wap@kXa!0 Xa bxxη/JK⺌nvڵ{?*T8yhQɔ}0{ ?O r=f VC|T|He' |>L?.*Hv*y9)Gh{쫽P|JUTPEiAPAt*P HA DDcG|GEeڲмxOۏR6a1vY#x巚>|PXr |nVv }su)D#,HS)0qp L -.Qu]ۺ:USuEIkN?{ ckgyr]K `7/Ea:ȓhDri:#a媟/_2 *[v%`b(W9PD l b ]dSccoTM poU" pv{9&DKYK7 ЏRW"hޏn6|aY:]sA(;HK]O_˧#$zH IJA KᚿF`HCkpoU@CQ}<^ǏXlgO~&!팀X.C|>² ipc60uip:;ڼNu~&f]Xܱ݁N8אE !%!7p\tb0a!A! yyuP`rbGZXO zA:Y=:#yC\[|76$qnSQA@0ـ YsCkD޿.Nmb?{F>+ $UJ WM)!2br@Æs B.z }=>\< 4,!ܕU. hX *u8ĒgNyo r9P,d@,s  M=S"`ܴbneL Or'l?{w''uD K@ȀYg]?vѲ '7 .eL Yӗ̩W7B X !HGQl&,hfO܋ Iu  z Y"{S_o7N@sOH-SF6%LoǸ qq@I@QvQQ@8(]R-F`u11yFv {}I\uUEMcd 0n,&T I{a,}2Ǩ[6UĻ qƏg"rxc7B䙜/z8+3 `1 OX,LC=:^׬ë]ts=#f4Le#M%?7 Df7$n%aY)4(mw2ް"Mӧ9=ve.[}r|tFR{XKmP@ Fّd mSFff`q/y|r<[ c6墅ۡc! TkԥHD)Sy& d2=ngJ wH HIC1)">@o۶/?!XK4_ٮ4jaH%0J"ƫjRZ5ZAĉƴgҲwfЂ-0QNڭ()F!>6 UO\= Ffd@- EXcNDREeMf~"DHS w Hd>3P@*T s2fd5Rdr݌3.Pm)MD#23(RT* Nm*yj =ܮRm,PPgJhA/={M1].Ve34л"A@=ktuUە[ωadXZ^!u\EPS%z-dz6b&#1aJw ¬' O=gL i, ۩ypmo+C3^W踴ǡ:859ʉPֳjB%EYW"\΂hkW55k40FD J &)?Q8v46,C$vP Hm\.e]1Lw2'[_I"9daG]ҶeE/L까1"~8ȱq^P^t PXgm뛮hU9p_9#.|*T8`dOÝ_%5h{cT9ΝXX*BDhR m(ܘV!G4 ?4zGqm xgQ04-ͩ^ ۹]]Jt  ȖüIZ#nF!ys0FaD:'b$F +Ich8AA%-?D%Ɂ>Oy"+]>--6|zCؠHyuy^Q!FðQc <=`$̥lǡ͙c Cpe ~(N&ǍRa`qKTࢭ0#L?1i Lq1Rtة}5ҹ4eqpw'@ Iy骱pϢ4&'CMiYNz|2aiwHKWN רC ˀQHE4 G{ψCQU">6*ŌY1Z0hknJXgd;[KG ŠL~9H3?yjN(Wnь>*e@CGՙpO=9qH +bc.,{c^".qi@{0-»t)s`Vk ;9xgbbxS?ڸ-(=jYJk)%ca4x )=% |+p[oxy,woQ|TVYf\h~&P+#!JkHx2?d&fOgh;A:=Ɠ;υ/$Z'FG D"ByxjrA]Uϛթ߸röGVҭ *f7J`ul|$PbTWlӗ,(_kȐPLI }fӴ;(meO/(8yfWn45W&+JF2MI XwxAkG<߉p`Ⲯ@?]ǞCo ,Ç˒7iQC*沪C.8AHu`2Dc+.~jY[ O%ŷJN0i9O3-#4#R G9v%0cAFZ|-u<"Hsz?x- uRݠtSѱ;'F=m+zwj ha|^ !8C)//(T=S aIX"iP>NW/|luƣYgՁS`byͥQD]($N ZV@6bNx,V:eO |@&bGEE=,S^-@|Gv\(*;j` y7%D:j*xELcH-6_WGk>$'1-E I7ҁx+]/-=0q =ihG!^&`efqYdԯrK0%<4Pf,O# tv}"V:tbqd rzwwlTl"kʪU+jB>T/׶!'x#i<;rqhm n~V:Ηg R99<\AM)$`! SGj y-&pm+Ws,5`DMLGvsa NrFfnG'#(.-\QEwxnk%hoy( 1+=\s hnzkD!oX֝"Ε/?žEH=UIj֝qؗgpRO7mxӮ~Jè9wpHbIk&ypci;~Qu-FCj`25]F1 6rxEa*1Y-i\Ԅ)8+c>DڡKjeC݉?TBʀ6:1 V5׸%x;V} V.eyF3w=k)Yc", /5B ac̲=ŗ=bY %y#&zO O0;?"AtɉLbLs'bR¸_Z7`O;'BЧ!f E( ܣ;ּ5@|k%sx 3?H1{1045O7=ac r rUڀ' B$uhG菹(>K}`޲Q#u2-`jHdISj<%A'{Xhž۩hFobaoHLM hg-U EklS~LQAb_BtUԷu$A@ xX%d3v聩:<\9(@4I)EĎVexCoLSLA-z#k~*^A(2 =T rcfc-{ÃF(Hn`z,M?T>ϙ5 iJGȘiMԚj PD<=g1zq@"OK(P^ W"&G'yݔX!i+}`r-E K '\y VdkEN#8jA, 7-]LT˔GHSԄcXGںu]fʞ"3W SOaUwOgL4;nc%8("w.DUk+&HAn"g = 6e-!=OjXKA8Gt+e!P(2=}bpL&-Ѡkm^[pdiSUP7SޜI}1?0Ө@Ћ,Sٯq&QE >pVܘ 8gEw!j'-I%MWסxI 5o!S~bW&͕ V"[aۦΧ:]ۀ12=Yb,#?ظcе-=JgCyxO3C_{2eyaPdx"hz>P޳ɚESAҧ2#oI Ϻ;]9Uh!Ⱥ*5jSFP{k"Ea쳦Y ,jg jlqF|V?P`z9SN_@ThljK& Zo=Pi~C+mG*%)l0 P27viꨌtx4 -ҫ>GA+{(m_8@vf~iv]E5QN3SK}1ԕvSvpwѬwn qH[k|r40A Ƒ2( jr`a{ixpq_!A:XY+͗U?5!1qwڮm%x!rD;h)莄v(KWBEa#~Yu8@fy+ccfgǚ#c,4 ԅsU÷ ^o Y3i{Vql2em\Pr0g]s3|Wr1NX{5kQHil4H`C'YNX}4P˃ٽ=+Sn4o$Dك}r ́m}vп8OU=D+?%|. =j*a %M|Nyy%t>MR6ETX1*XM +:ٕ>^FƾhCz:uT 鿱":/uCGfZ' 3 aspU]KLO^yq9ַ d+NI^ʢfޜ#liRcޞ'j6\ OT3cҷ C%4H|40TsJ^j-2Z?AMM.4&tJv`(7 b $W0e`f@B.RqQl֐+QkI"2*C0ƽAyAAl Mo MBوEt:H"W(?R~@E*?=4p /(w51Ys'`~Ԅ~?+~UI}6P4wQ*w wMXqa(ȡAj] P~a'îdAv&C2Ĉy76Ja6k%KGzdF11Ԣ|7=4?7s!R:iup~֭li dSI'Ř IfbnB`ݝl?~vnn>mj툷߱xQr ʥڍc \Y WrJ-M) 51@C$.J~ԙB;! D׃ CԈX04.Y0݆X cwLW;YT4 Ӱ"n!2k7˂~Mܒ!zޤ~275;}HCڬ;t"ZVOx7K8э+ ZƻF5y;r"+BkUd(:)oْ?S<{A:31YXa=EiXf+yg5r1i'o2}:PMw[A1߭y3ˤmGZw4a .1hmK7d\uD@CrVV(T"9>0&p-ՀVtB?Nfe_`vdVeRA~ D^< R{xQl4"7x0>OZS['GzVmԎ HOY]kr-ў]n+Q#j=Bkd7IطݭUSu6wRճZ#7|tE`(M@-lm=+-8/5w- |ay|ŠoBdn~1dxsBun,08/էh"}|T?PIDI{֡KSe\]e+EĻ2*b?l]G=9qՎIB 8GAEߥ-^ ѵ(gC0)O/rbҒ~]w˴RU;̉oX.!"ʹGΨD %|w [7<0 W! ͟@t5?V{| p0 G+ jMBv-w`Uoy1}.MKHbB@Ь ZN:Sύz~>/ZFh!r- '[]=PٞExKEnR4AQz*(ůWDlRĵ2-'UMeҫIyMQz)lR4 ty>QH?_[YOǐp ]T ޗ/VHL27SRD)"nrAPкSv&)!H޹@TBpJ?RmՕ2xX!n!,#G=K~:ge-oOLk6oyFP (:v;քG,ǠzY=(kПM [e|wI'aѝm |ƆB5Ȗhן.D WvM44ʱ]30|ή|sYѭɟשmdXu7NA5,]1{`@6>$ֺ⢞m~"f曠vG1gq[e 6u0T7uU۔NO SP,n/`6a <2٥0j /gvPʛ#O]n4vOkۅp)e :n[1)NI[!EUQBAIZdX7NZ"C|8Gj;f^yyԃ)j!m @4(q>Sː*AWu a*<`. Fd\e41UG`i.Kֵm{pBȩ jXBU-nIF*E۽(0ذ'3 -l)H&6N(Xm*|b\-ѡB=P) pg4)$)&[9Wcq_0)Cl O7CUݤWAZ}IqYn*ߢ@gdy]2Ϗ^tʉ' BJyO}3*(BDK\" V™`V.ï%s$!vJ9B lсNgp1@>啎D:Ԝ,Atlqq1w<wR/%"w] '3EhaINwEFչk#WDM4%BWOs]8?2+C 1;%ځS 1U'žGD,moS:&hKnzSVYH~E=_rE@D/ig;H ]Fv(zydr@k̄8s`Xwj| [GwNe.O\{ 9S8Oq:o ҇65HmE@3 ߄]uSW;wu梬n\E@Xnf/ȅDY0i3-m4\r咒sj~ 7 lJdߺ: G!`oWv^тbx{[aG9`)b)yzrOo.-96^ms EX\N F&Cq#V ,H YF7_ ߓUz1vf}""ܧ  !tQ~(2;F[o7kz(L[ǸJ21;f c(@ 5{,g !>EJVE?t+Mj7_W~zc;j[ H94Z G&x5m2Fk+gREHx@jTrUƮc F-;FV9?_fe ~⽮Ա4, &zi &t`;38 )t]G3N~`YL4Z,,iB$A&8_]`3FBzBL df^ah?z{ҕS=)MU@I%a, n_h3M&-1DׄN%DŽd1(Z]6υ}Dv,%1L9k&7 hụh%d llKd]E 3Z <뇐w}s SR.PʨNA~C0?}U9sH]d n-;=L L~91+k=f'FMe;IG+ oWݷ7aw0j#F*B۪v:2Z*hF^LVG_BmeFpO3ܠvUxic?핅_DZJ,4[Cj><1QC8ؽZ! *2a0.mTڂIfj 9-+ȋnp1s-S܅աc#!˓ex?5؜!6A2H/s -!29:ZhrG/JA߷9.[[Tg@ޘ->L6īkIF:)G,65Xd\lXcw%c_GԋK+=4<#kr|tVf9pfNpTMW-h2 gY"nNXKE@&*fg{ ZΙfMRo|h!Zא3ЬB@v{ƍlSc_ ܬT8'H;$+@VrktSEOxa#2\טiZd4pMsl*"// F 0L|3G~5 ]5!S*2SF4H=3?H.ΓD,xk'6DWT5owFk > m~.>ʮK̲另mBm6P3{\ȅhM F7{py?oRMаA0; v U"b+swބi'H.h^hv%e2Ղ\|CWg9ۭ'GE' ==__mǛM1=ݣ$6ss)t߹t,6ނÚA#fYĊiOW%7UDd \q(#{wOH6rPy8Mˢy@2) 4]ğ~셨+N}GBh\&a d@smѺ~ӄP\}A%M爌 {Nu\H`%,OkyOo,fiƷ?m{͟m>?+Kl:M5&]v0ł>~'ft@WhhP< W/0QFΈER)ث\coRyCxs2-kYnx䬬.;=?6֔P OCn,e+lO]\SBSZvghFx~j|HwC)|zH[ծ rJu _ nI,9ƒݺ\?iXނUq[r?͕M4̼3;Ɗ/~lzL$$/ӏ'cR1!9LA  ;kpH$N3$9[^׵Ň\5 zֽ Ga~: S;:.m`:},$Z#XSvVb5m8N& Cc\t풯t/{z} ]̜ʁTf9SKM7.#엕gwrykm` YDCXc!q`*1&,s*p)X™َB}NyoCX( / iAfMUW~ßXKQԈyܧHD ]ĐnjPϦ/>d9@eba^ ,QOhv-. =WR$Bg2f^?Q>I|LSvix1r&-p9q Mn Ք7/ ;oQ1zen`ݮ -wdILVxn}n;ow]'=Se*s?2"E7{ F#}f'~G mnc*>%{dIj{7qUm6<>%0glBTճ}U{ɣҦ>}GsG.|0چjoO<hs[ ý!QÎC _趀B%샑b6o.=Nf8m+eIl}HY}n+1}i7qiO޾*!N+g;3u)lgm5|c`IYk9T]MpA9$%@AcE18ez' ,!L]/>V̜h;Ӓ#D|(mscߍ];Ze1SCb`-tM u8`a/|1ض]:ˊծKꫭFA }= +ml#_7ϛh0gS2_ T<`o'ry3혳CI,\MP$i (56B U8@C?@9`Nvn, =61w ? nj ;ӡh Lzn]p/I'׫8j.MM~~#z\o7AȮELC܆f:z`&H/1T$z:!w.~dhRR?gܾ,ثi;x g]S}hJ5IU?y ^FD jɑ._:XJnd'^[ ! 1_{nD$O\.~b)JpBEbb4@@H'>if%ˊ_`ߐ YF**(9zt&̂?꜆ٜX# g ZMz=jy~Ǖ@$80Naϋ<`XnAT\jp:h͟^n&O_i;Y60\(CH"`D .th |b_jqv~Ι6yGX&0ԿV݆Z`-A_8 Y>mh Q]GŒXBO/àh#hf»1C"Ըr \ t]@FK*b0 m6 RʶK!9t֣Tx:-oܦGFz.6Pٹ*xQl Dݨ}q}t–y 4$#Cm75lmU7EMԆ?X_m#Uw 3F]=O47Mb 06u[eM]HQʻfq$JG9i~R B<>GV&}ƎU)͝-B& sNUup PyHlv>As4x\}g# @X@+mYó| PV毓P7B#oA"ܼ9v*ѽT#F :QrR۸d.] @Db&W =bn(K+ֵN QP˻CNh'/+ o?Qh! }J!b7JT/ ڭ+ITcLS8LPOE!S cck\$Qwh:Ĩ{ M `45$~haw:Μя|4lqe1WAUXEPFU+%`[W$M<&]FTK:` >$w.1F*Ȃ/@6\!&#@e2@.ѷsZȶ b~֯P48trz@%Zgɒ2kxˮ`;sd|=JBZ _w|gʇ?GQ^X쫱 n 7bU0}s gC]wXBP+bt Cm,۱xs:{%:@~61U:>J  _z櫪W/jm ܖM&Ai@(\ЎbQY(suZtrǙ_$jll0@A/L9_fSbQEY_9w=-\M.,;@ۇ$8 `#HKvP#WI.&K:J[Lă%ʲF}8(=c"@ՀBড\`"պm7=Z+L&I 4gImlov厡J u5$eukPRԪɼҮ|flWB~m+ 0D߽Bj7'R} ͺ}i^g)c랊?xk\6RYv93)=Kޯ״!)HxG\hfF^GCxώs U./0#NTW _b3pwV`0,%lKIYRlFfS'\\NvMr6T֛!Ujh~e_].?_4 )``#~[tFʛmR+ndV⮻Ҿpm^?ֲ 6ޑx`( iXISJv fXƸ4b)+09SwC^7J&rLܩ~eg~N8),`7uZ.,6|ldF3k~*΍?,8NJFx^YnMu UYZF X0?B)N1 y~&{f/!dkŠlOe?sUNA2UY& >$bh~iʄ](, z`]x2Z-=$yE&*O1+ t b-%Wkw&?{k!T ƥ+tZ)']bst)F 3)(3<;6Io\: ~J &.}C!v< UHAFݏC\5p&[hKGzbfNvPu#R:=)WP&1wOOZm;I|FAU3=IweD7dz2{z/T6No!N\c]#HzuUPAO?q}qLKx6Þa1>Rԙ~I>ٸ)*'|كTMݩXl)J %ӮO &kx : QѬ)x֢T:>SQr#T>Š).wE ?s9> Nyz ΒC;$inmYy2_?IT݌ {@1kuG}Hh s#8qn8cb JC~>aAm *-=1B¶1z+ʐ7 f$\ Nd{6TBEeYJxqaN;cv.Zɦl+3c(u~[@fV6w!ך`=qtyV7#$I6>1WSjYt1&@^X%w\;38\ edpo7~YcAb̥SEk+@3 ݭ%1Agxa۩Ď=2cΪSAvu1WH0R 1<7aڃlÝz ۻL$'a/W[Y|~*żsO#̷@>\ sHQ9zAo duf4Wu't߈-Omk3lKGOSMz 6G: t 7g[׌[|;/vfw*2&ŮI^wigHoh yuU'!=vh0<Nvd~37_#NL=١D,Jpm.A|e(m 2KN_X]T>ÀSɞ/u4ڦ25qK'sb!b^kZ`GB`7y h;7uPMM{U2ȏU]1žcmxrq< W\r b$}JiЫV啌8wڴ(C[iۣYUy=\ Nm# HN>Y_}wc !F# 1(ZxLRpsԉQHuxǴg=$qKo7(Pit­ U>G_1 O 2p!uYp6Z-gʤAT:0>nA/r ${K}FP" Tޣ!hL<h->mk8`D3FT&S-~b?2yCEaQg-7ٚ>ͯ(cfd€fb@^!o#ÿKx5YU K(Hc&U@'>}q5G]VZUzZ?5za`oK%*aN0 (R N3"} ֘zM//h?NQJ۟zwY|mGUS<*$jJ3|3G6޵eP(Y y+rr%>YS˶lAٿߓ>KÓżއv>qvmе{]M=# 3t:.\۝]Q+cpDW,; ɛdmp'6CeOiĭ"l`I&"egIUW=NsݱRNe0*ݽW>|\MP؄hcЀyȒgro}U`pC[Yގ6IxtCqqA =4 6z[Phji}gnJNӷHK&~l%4/VsD_f^ FQb"#h[/ HɑTe7E~1&1?)-E Q[ u [Qp d ^{d7*~p_}5̺470HucA0Eٞ*:VyiQ]amY(yݽNʥ{Y9.=h%]k7MȽӅH˹hD3uwP_*풣=cg-;g]wK`wɖ: w?d=K  |//yJ|Q!2X vokOpZO:??4qX#xP%Ы9ºX=-0lXث&1l='z@Fgh?lrBMK#Ge\36nDc,lLNa/rI[K(QRSU)Fm?r+~N2t"BM+@]sS[AXx/<6kh9*S" ArNOUGQ<*i#ܛ|B J΍;܏(7 t73t#%rV)7__R|hX1n(C1To-j nc㔆9Ji8I{9"{? @`OuML0 yG\9lfFѭ"hP`{{JՒ3/[<)vethTOse$wYmFCXfmijw0vu5[ R!6bqIH[FGb%J's'u͹,tH$q\Go]Q8,]j ؒ0R<{-$xnv@ s wyaJhWvpU< /)-k @4I?{|YN4 E pjIÉuhۯ`lkg6#vcIïyi Ď< GwH_'T[P/> ă'lFNMިv0fw,@֎^R`Y0f( Ruc+ΔXqv٬hҐ4H0izēNe*S)C+b-|u| X8}:-<9;,w-FOXv -;݉KjW$|)f>P1 )EwGk[sߥ}$V| Ѵ]ZtWNrϼ7hԜ=lleڼr#­(c8`8T_E{ߧLX>ᡓmÓ/063i$f*DgILy]bl咞3ֆo=5,|WWNF,. ):2Z^#aFg'i]p[_ЀV<_3< c0JxޫDX֣S96<Le]e>{q WP\e(a7~h dh~x5A2}=UPTٰYRқWcçیjἽ ߼Dž{m0H)OJ=)$6_cSm#FhCu:HeCʟ֎8 \ d,B3+&?  ]}-8 |jh$3@x|Kl&`| ;'.U W7Fzxp3ƒ;HҴkX 0I4۸J0"rY {t>TMОccAJU3fZ!t,so: M@4{4 :B}uv;FEˊR\ |gg΅਼"?`\#^#n6[[rW>ZMoKr~o&ijNQ|V2q fusS΀'[h *Ȟ#C-*qH/3 *ْ >3ixDTE3\Ci)^_RCr ]@$Cr qE3=&]|؏^[qt+6dL'?VK7M?D@H7azua예ֹsdhDME'5ul#, ^d3/ifv'nP~)YWX+Z{%5Ndؖ+C3C3e~ %@zKd[D0 ¹(BIaajS.H0Wn,A}׻U}":m5cw}?!Ėb/y9?HMqzNh!x"'^ihj<v(KEAjOSq\OZ8;;]nPq [F[02FXsĉ#0ܯ Um Yp&|bH‚&Ӳz5AK n 0EUQrH3O{Eγ&݊.}By+wtm@j'dߵ `Ⱦ3`$l?~=a:~ C o;<G6AiuJ7d%Yyؤ_u[ŻeI2zzlU$O_N`+;2솉"S&r͒yJ A% 5`oyQ<8E twᮔ;k/5mƽYp98m}A|T.)^ Yg1P'|%BLYPF`>"L9Yl xʣvTZMf-^)XTݎR 3p, ) U[rg3MB:qC߻[*oeSo7{&}O䉼l=b oOeec+$<6^]^ Z$hlY4uRxt)۹BO3O@,OoslS|n)IPXzL0W8ۿ" P'KȰƐ: m([?!k5Ê"V Q`zcۡIzşwNO--<=FoQ>]$qގf[*`oJ+2C7/K Q9CǦ#|4w[w0`=@]/;kH amԯ֡^ÖntQ7Fy%(J%8d }v"5oKzuiqB M\Hi#+%E"( pܢ0`oƝLs -CIϵBr;z22.ǠНES1lEYPiŠWE +n9e+VQA(o+P~|po: Z|i@!8Fr& |?z翮l!.K_D6:l$N|ǣxLVu{Ւ)g,+D+Ž9NOuE1ׂ|@ ĥ)Q+2ep93XlofQ}ͥ%FɉJ)ڱg Uϗpͅμfo@0BDI Nn%]~Mi:]~I%3}''1 T}!FHj%%Q @;r|HgpcJ2TM.ݖiJ/3u+@fN%2߀i t@+`83Y3ǻr[8h5Y e'ֱȐOO/,:jߺ+/W *c|\2Zj"e)B*elAmN+V c112G0SސCnc0Blt{9b]\V_CgtLk*=)aɖ܃rΓx%ǾCfJ8GG9WWy5hj^/c:y'ė+^>J.J^Ť1]lY8mbn\S\A)TIQeAŚ , $iƠ|'?8 Q`s+B[_/kp$5ȍ`dUcxAui -jFXZ=! a)̞|%>$.o>bKEn4k⭶Z;xyӠpD <~|vb%~/pVP 0+(7gr @ 7gt[D`:k:ȨS_֐ A]K'!^^iԢ/F,EgHaqع0(Ǐz(A _$ !PmJ.iRz8T>@~iKzY~ؽ3㞖ޓkUK::sq6nz|2[UC]q4`tm3|pP|X0c '#̑1;N]5+EcIu-ihqYC8^RS}9_.^ %VfMKvy |BDh< wYUp/kɪl:۷BiNCҊ0 oÞ޹jolM%qz_~``(^k5 C1\r\ Q;]%g 3L@H}OJ0RaȎ83bck(fGVXUJ]ZAX+!JRKgG/qu0=]:=;XA|`. !;W1ty-LP>u3pIU ōZpD3Q+GjO{Xdzd4BwɁD|1.דX n~> Fl7 I@6 ,=^״w{#"oԿ"* hOZ]":@@ "yÌlTbC&JMz*G1xvQBߌfw.D S}3C쯧#_bmIb ݲd4ѹoa~I*:ϵ2*6{,ƯHߐ6YdxEq &RpbŹcY } eGE'\† j8o*uDD8\.]fY=C.W^fcG7c~MKt5x1<(M`öV`ݶ{=6PI'=Xj2!Upux4'7h-͠gx[l;8/S6jn<S)VqVдFE(Bn8`wRV}8\mBaݴ&Z 3$g֞RY&wʏ_o5r>z5ò= Rgwh %Z0F3' ØxXzG}$dDf ی C{0^}|CZ$!%iZ74ȠMm2ݘp`l SWdj++5Nހd`,lE!ڿJHyG@-҈FߕahT7o^B145A} hĴ#vǓԪvƋYdp(Xձ܋F"Y>`5r>hwWi{燠n(0:n,[s(Mn٪m$Qto_Q~x~XMvG4hL<+IcQe.|QIo'6( rj\,A1 DdQ=C5 Bޯd&f2VddۂĊg6-ӴOYX9@\1_ 4h..vS~ .MzHwVX^ʆz`'[H11띤u!¸ .(03a@D]VDΙLFGU#Y+@WJ1$vH<NG_PC⸻Ϻ7%+ǡ&?ErC)WJ57o .E&}$v6۩*K~=BY "+RscG)!j3۳wץٰ给߳ʓYeDG\Wv8iL8hŻ\vYAH0Γ 4bO{?ne,g KU6sL"lM~*N$=4T[Aw|e6e=]_ R{7PU/>ڼРkZ] ߸͔0gOxmVPvqʂv1p #bnEQ4t]W~1MuB/{x5|rU֚/21zͯdjM˞qתաsgQprp-f-n^J0ENEL0'գ4ee kG1C,w9cHugVRwBe UWM ~JKX3͙%٭i~3*Ʀ.y掚oYpv*ἧ xbE3H<IB m` =FL 1δPSf;CP*@Є5˷҈*F7)Y,a-!NkQo e$%O.y@tKRMM|nׅn!"c_9d =o{7#>AmהEbGX 8@.P\z?27|7'gL٨KHկ@i.@~Z, E ƧoWzA\`e+KN8wjzvvzjXħTy6ޔy¦#1\wkP~cY65RҚ<7kv.9dO f~Ӣt޼}},I(x'$@8g憩Ѻϴ+u݉ J~mu~FqwݭcWjcdMJgaUA,' LG_(NXV$]|2Xfe2nlN)]U$Tb+h'Q)9-EYG+ -!@}o^E{Ѐx bxqkv ]T`7p)*+UI_T]IIqV[_qJYc?\!cP &'~c%􋏶"ݰpɶ4S{ 5LCىQB+5ޱJCH(4ޢqSKoRI{gыɠnj).,PuVddtUfs [;lϸ.rxBDbв&\ݍ>4ۅa~}y鶡eL:!G넦3pQL`AB0&csx &)6ʒ.'ʟm%@ _at}r[!- K򐗭ҖU0^Sc^) RL>8CG(4Yr: 2j; e$ >y}::/gl0GNYT0u6|칏nOl`ea.> [߇؁8nNP &~:G*FF;0"-ÛR1HF"ĖmNS:.:㿍k>22Ha\c 5݌@{qroЎr}/t]ʿU/%&8<ǭ&/Ė b:HKͤpi G} ~2:w^Vglv %KZDӬ ~x[D3׊ix7xsd J=[QWUiw=zq/6TԆe~@PtvGg&SDMgԫK0 e,j#/w澣T1gѷ7=,~H"-gR>TDƜzLr]:;E,z? k9*v}_]Նݘ=h\8ہxN`` -his0gq,m׆~qW1a."Ʋ)^n-{ZF1v@&9$qq42Yu9_u[Ҡ?eɘ+ =¾wSbr+lHov_5'4qZW:NʽmM#\Dy'֘Ўf0}R+:n@x-PvYҭp.\G{[5ϋB]o4X|Cf?uH KfTM{~H?WsPXoᦀ 6R8Xͽw6 &#n mtJ衷&t,/v}E:l|GuT&s~S̓K‘,/IK`)L璌 %d{dd(u xr;*7h䳧U sRmabڑ5nxFє<o|oI7Kt ƍ٢<&@TpS =ͻj^ƏHxղ*t% n_.!Z8l[ ˂J,v8kMS##cl@z/X/7@Pt] d>aq.p7ڪq#ϵL@g_ xKsoqke%+*e󟮪&hF)|/d(\!^$0HI8j}U&4Tآ4j|P3#҈/_FE8LzmH:3Ԯ%;F"3͔RHKn{XKQ-pme6QCTDz,"tMS0 7f0g˓dUlxZeSތQ-5Nduu1hR˭ OBKML hciSصxJkjSc觌\^o"$x'&+y+߮Ӥ2 n۸qTRCز3̷͞=`I`N-r8tU4s)65_:ǰ'EG7xe#ZV^VGM' 4U' G!G!X+ov|?qPg߈ ZMy YZ