keylime-tpm_cert_store-6.3.2-150400.4.11.1 >  A b߹p9|kxe/z{[Uc /zI rlPD_Bgm. %LEw<1;TV)>g,P+^J))O0a7>ۤISf'vdi_X6:ER**mMżyP0kϢgd/m+t!J ;75Ub䒎9 $`ve692a5630406e2738781562f4db9311905db8b491b01e1c3dbf870f8c39d91bd1c02c35eefc035b9c2d83ccee405ae642c00b8c74b߹p9|!A tk(\1fɿMڴ*b80}-m(VZY-e|[!D#Ǝj}?Fg >l~zG̟?洄3&a2u9(v.e.Ž0A0 {7ssRV08NS|nb)L H>pE0? d - G "(/L44 4 4 4 04 d444>4@d44h'TXe(f8p9:=>FG4H4Ip4XY\4]4^zbcdeflu04vw4x4yzCkeylime-tpm_cert_store6.3.2150400.4.11.1Certify store for the TPMSubpackage of keylime for storing the TPM certificates.b߹goat18@SUSE Linux Enterprise 15SUSE LLC Apache-2.0 AND MIThttps://www.suse.com/Unspecifiedhttps://github.com/keylime/keylimelinuxnoarch/usr/sbin/sysusers2shadow keylime-user.conf <<"EOF" || [ -f /.buildenv ] u keylime - "Keylime agent" /var/lib/keylime EOF [ -z "${TRANSACTIONAL_UPDATE}" -a -x /usr/bin/systemd-tmpfiles ] && /usr/bin/systemd-tmpfiles --create keylime.conf || : # Help the upgrade process when moving to a non-root services # # The '-h' parameter alone will not change the ownership of the linked # file, only of the link itself. This is secure because the user # still cannot read or write the file if the linked file does is from # a different user with restricted permissions. # # The '-h' parameter with '-R' will also do the right thing. In this # case, if the directory is a symlink it will change only the # ownership of the link and will stop changes, i.e. it will not change # ownership of the linked directory files. chown -h -R keylime:tss /var/lib/keylime/ca 2> /dev/null || : chown -h -R keylime:tss /var/lib/keylime/secure 2> /dev/null || : chown -h -R keylime:tss /var/lib/keylime/cv_ca 2> /dev/null || : chown -h -R keylime:tss /var/log/keylime 2> /dev/null || : chown -h -R keylime:tss /run/keylime 2> /dev/null || : chown -h keylime:tss /var/lib/keylime/*.sqlite 2> /dev/null || : chown -h keylime:tss /var/lib/keylime/*.yml 2> /dev/null || : chown -h keylime:tss /etc/keylime.conf 2> /dev/null || :I n~~~~~~~~~~~~~~~nNzbbbbbccAAA큤b߹bbb]b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹b߹f3e3d340592dcded58eb49eacd821fb9c2eeabf330fc863542587501c7c3453e2216947540f0f43ffb0ea2dfec0d35476ee4f339d5d3821feda76fa17fb588c34102884842601f314dad09122e48be0e4195abb884bad94630fa5a27dce63e74b5f76cb9736d1151ab0ac4afd3e516a784ec4b3c3489d54d4eecc263149db24ae2ffa9198a5bbca435dffb1f70db7ccee0bc64c0a8e65feefe4f677cf18f2899fe3e43ad068add661002f5347c6e4693e6ab6a9022161712cc9ec3e5014ef3a07a7439ff573df5bd5497baafb1e6409b367a480aebd2cb8743ee02fe0e0c9e2eca90d2b52aa97a6cb1dc307e95fe05cb756b09bb4fd96c4b920cb142023a7aa5c39b89e52ba681db55dc180002ca8b49d88ec89017a685114f14ebb1fa6df530df2244f9b3c201760d96af60d717402efbc2a33e32fd286f07bec71ace7862032da47a1670ce8f7c2157ab96d94a51f3874612f04c2670fad76531ada045e914b5f76cb9736d1151ab0ac4afd3e516a784ec4b3c3489d54d4eecc263149db24afe3e43ad068add661002f5347c6e4693e6ab6a9022161712cc9ec3e5014ef3a09ad0f9190a35c0fb1b8e5626d310897227c2c2d6bca1d204ee4074218e13bce77a7439ff573df5bd5497baafb1e6409b367a480aebd2cb8743ee02fe0e0c9e2eca90d2b52aa97a6cb1dc307e95fe05cb756b09bb4fd96c4b920cb142023a7aa5c39b89e52ba681db55dc180002ca8b49d88ec89017a685114f14ebb1fa6df530df2244f9b3c201760d96af60d717402efbc2a33e32fd286f07bec71ace78620300eb8bd4b8305df7d91e87acc46dff5f3a2de75fc4a962b16a99de41cb721fbd6c8457a79da5b12a2dc46967e9c964bb9ad0ee27d2cb837efe41396f350a85a02ebfaa96fc6ef369b9e4d82fd44fc32bab279d62f3ef0f39b91a90d304106aba29e56c5530e74f7937fe396ae6dadb73da929fd4cfcca29ea88b102c7070a05cdf2c5e5afd753725d08e0d4de854e2c7e99577854a7e7e9d27f76bbfec4e5df84bb440894a4c35e4a1878a9d6cc519b2ee5743342657d43747f06e620c926a99343b27910c0d69aa54a94e2d1819d0a43f290b42e6334148154e0f5097a0b8af2c5d7bd9f4ac46fab56542eeaa0f92180bb05bd91a9120f36a5c9a999358304f09bbae7bf3158b4dfbd68fb27aef6b4c17b5169167e9045260ad8fe9b217cd0facb50f23fe4a71f7d1d4368d4e4c97f935abb545835bba21cb56e22af11a6c50261af2389b65f0f971df30e0759389e81bcb720e65ad58645d716d46dd3cb2caaa2fa5681e0b91fe65e3d83ea46c681c9f7c44395122a279afb2f18c0a57765a2026305005b147d0c77f23935faede0600973ce4bf2be2c15a66cae15394f28123b9d4a11383c782c4e013f1be9e5e836b892a3d32db56ed54569c1be43c33cd20eae9bcef20c54e3d3555cc458e516c615b7184c1d50f1009f1dcfa4463aa163741c7b7144c212e597ae6d7844d34f0e905e80e9f0594bab6f721f9733bd1efd302db65467a8bc5c3d50d5ae1d271df0d4ae5c69c44c4a52a362a58325b1ab39ffe9b84cd05a83ac73f5d93a6c544e09b305ccfcd12d5a3fd2273e877a17946c1b42c0a03d93b29d45ca7ebc49afdc3b7e15176f7b819e254e404685a9dd194f292d76038ec1ecf00d9fc097c717dc1bc5212d55a34d08b34081c3b238ec57ee295a1004f76d5f90c7594fd2af92b4226a5d905d3ba3fef82ebd41c320658f707d9033e8a2bbd18e311bc1c63e39a1f483020c94ed088000c960571cf51a94ed009af3a0c8d6557812fc39166f4c4263177a3479e2e69daadbeee888a6c82a8ec31c5d0a5baf0b25cd12435a4022d817c85385bbfe34419255e84514958f187ceed5c890c4f80311ff1b21c374e5617b3767ab5bb2f56ff6145398eaa7fa5bc307c034fa070c2fd70fa2d85d3fad445ed2b364923bea4f7ffb13f3596e51847469b5c6673f5f004221b019b784291cf5dc6cd7fe15877980350aca0237c6a24e33162b84c4996da7dc95c7da34eac76eee195c59d4a682a6388a976259644eb8060713ee5c0b1c91ceb6b52acded1086c8a3022da86f623f458512cdf7dda2c8718c1ca766626af61ac1cddf1a713000f0277b1cf4eed71d32813b7f44ad7038144022600b9c04cd6e0338fcb4b77708c10e72a820b7a7c9e24aa6dcf41c59b@keylimerootrootkeylimerootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroottssrootroottssrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootkeylime-6.3.2-150400.4.11.1.src.rpmgroup(keylime)keylime-tpm_cert_storeuser(keylime)     /bin/sh/bin/shpython3-keylimerpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)6.3.23.0.4-14.6.0-14.0.4-14.0-15.2-1rust-keylime4.14.3b@b@bUbbV@bs@bs@b a@a@aaq@aq@aaa@a@acaC1`` @`i@````aplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.comaplanas@suse.com- Drop cfssl default in keylime.conf patch (bsc#1201866)- Use chown -h to adjust persmissions for downgrade migration. This skip following symlinks and make the migration possible (bsc#1201466) - Add logrotate configuration for the services - Create run directory as non-root user - Conflict with rust-keylime - Consolidate in _distconfdir when possible - Add fix_exit.diff patch, to exit properly in SLE- Remove user downgrade mechanism from the package (CVE-2022-31250, bsc#1200885)- Fix "run_as" configuration parameter and set it to keylime:tss - Improve downgrade user migration during package update - Add patches (CVE-2022-1053, boo#1199253): + CVE-2022-1053-01.patch + CVE-2022-1053-02.patch + CVE-2022-1053-03.patch + CVE-2022-1053-04.patch- Update to version v6.3.2: * general: bump Keylime version to 6.3.2 * tpm_main: flush transient objects * pypi: add notice that the Python API is unstable * installer: use OpenSSL by default * Avoid mounting secdir while unmounting it * remove TPM, VTPM and IMA stubbing support * archive: remove all archive files * Change GH reviewers to be from developer group * added suse / opensuse support with zypper * Fix tpm import in test_tpm.py * Fix cfssl configuration in run_tests.sh * tpm_emulator: improve TPM emulator installation * config: Add option to enable DB debugging via DEBUG_DB env var * Enable SQL query cache for JSONPickleType * tpm_emulator: move everything into systemd services * Implement broader key support for Keylime's signing mechanisms * tenant: Use exponential backoff on key verification retries * tenant: Move JSON parsing to capture possible exceptions * tenant: Move verifier stop from do_quote to do_verify * pylint: Fix issues related to W0602 global-variable-not-assigned * tenant: Handle 404 error from registrar gracefully * pylint: Fix remaining code with issue R1732 consider-using-with * pylint: Fix R1732 consider-using-with * pylint: Fix issue detected by pylint-2.13.0 * pylint: Fix issue detected by pylint-2.13.0 * tenant: verify agent quote before adding to verifier * README: remove tpm2-abrmd and OSX sections * pylint: Fix issues related to W0102 dangerous-default-value * pylint: Fix R0201 no-self-use * pylint: remove W1203 logging-format-interpolation from ignore list * pylint: remove R1729 use-a-generator from ignore list * pylint: remove E1120 no-value-for-parameter from ignore list * pylint: remove W1201 logging-not-lazy from ignore list * pylint: fix C0209 consider-using-f-string * pylint: fix C0201 consider-iterating-dictionary * pylint: fix W1509 subprocess-popen-preexec-fn * keylime_tenant non-zero exit code on error * Fix prepare step adjustments in packit-ci.fmf plan * failure: fix Pattern type hint * mypy: add initial Mypy configuration * ima_ast: add type hints * failure: add type hints * logging, config: add type hints for logging module * algorithms: add type hints * json: add type hints and add JSONType as custom type * Full allowlist processing when not adding host * provider, vTPM: remove vTPM manager and provider code * tpm: fix that the set of missing PCRs is not serializable in failure * Restores the option to use keylime agents without mTLS * services: make the services run as keylime user instead of root * State in --help that SHA-256 is used for --allowlist-checksum * config: change cacert.pem to cacert.crt * registrar_client: validate connections against registrar ca certificate * tenant: validate connections against verifier ca certificate * request_client: only add custom adapter if TLS is enabled * setup: add static assets for webapp * Add TESTING.md describing testing details * Fix some remaining log format strings * Fix for database_url parameter with sqlite * Enable test basic-attestation-with-unpriviledged-agent in Packit CI * Use lazy string formatting when logging (#535) * Make Packit CI plan more resource-saving * keylime.conf: Document setting ownership in WORK_DIR (/var/lib/keylime) * agent: Make sure tmpfs is empty even if not mounted or cannot unmount * agent: Drop privileges by switching to normal user and group * agent: Move mounting of tmpfs towards beginning of main() * agent: Read measured boot log near process start * agent: Open file for IMA log file near process start * ima: Refactor read_measurement_list() to take file as argument * Add the policy name to failure event * tpm_main: Check if tpm_cert_store exists (#553) * Remove tag input from container build workflow * Push container images to quay.io/keylime org * Enable code coverage measurement for e2e tests in Packit CI * config: fix config search order * Add defaults for ephemeral keys for agent records * Update outdated greetings Github messages * services: add keylime_agent_secure.mount service * installer.sh: updated tpm2-{tools, tss}, use system packages if possible * revocation_notifier: convert the data to str in the notifiers * revocation_notifier: mark webhook threads as daemon and add timeout * Fix Packit CI test plan Summary * Enable Packit CI testing on CentOS Stream 8 * Enable Packit CI testing on Fedora Rawhide * Remove last trace of TPM 1.2 (hopefully) * verifier: remove start_tornado() function * verifier: wait for connections to be closed before stopping ioloop * revocation_notifier: kill ZeroMQ broker if it blocks more than 5s * Add more e2e tests to Packit CI * Enable EPEL repo on CentOS Stream in packit.yaml - Drop already merged patches * drop_privileges_of_agent_process_after_startup.patch * config_fix_config_search_order.patch * services_add_keylime_agent_secure_mount_service.patch- Add upstream patches: * drop_privileges_of_agent_process_after_startup.patch * config_fix_config_search_order.patch * services_add_keylime_agent_secure_mount_service.patch - Configure the agent to run as non-root (via keylime.conf) - Add keylime sysuser conf file and deploy as part of the tpm certificate subpackage - Prepare the systemd mount unit for /var/lib/keylime/secure- Drop patches beacuse merged upstream: * version.diff * cloud_verifier_tornado-use-fork_processes.patch - Drop binaries not used anymore: * keylime_provider_platform_init * keylime_provider_registrar * keylime_provider_vtpm_add - Update to version v6.3.1: * revocation_notifier: mark webhook threads as daemon and add timeout * Fix Packit CI test plan Summary * Enable Packit CI testing on CentOS Stream 8 * Enable Packit CI testing on Fedora Rawhide * Remove last trace of TPM 1.2 (hopefully) * verifier: remove start_tornado() function * verifier: wait for connections to be closed before stopping ioloop * revocation_notifier: kill ZeroMQ broker if it blocks more than 5s * Add more e2e tests to Packit CI * Enable EPEL repo on CentOS Stream in packit.yaml * agent, crypto: add localhost, server and contact ip to agent certificate * Add better default repo path for run_local.sh * Fix incorrect variable name in test_restful * Run existing agent tests against the rust-keylime agent * Fix small wording mistakes caught while reading the code * agent: move key and certificate logging levels from debug to info * agent: allow absolute paths for rsa_keyname and mtls_cert * Add missing backend parameter * cloud_verifier_tornado: use fork_processes * ci: automatically push release to PyPI * setup.{py,cfg}: Move setup configuration to setup.cfg * Add iproute tool to Dockerfile * Pylint does not like single-line functions. * A small beauty fix * This is a small fix to proactively fix Issue #840 by identifying non-escaped double quotes in the tpm2-tools output * setup.py: add version number and new Python versions, drop unsed binaries * setup.py, config: install default configuration into package path * ci: move old keylime.conf to keylime.conf.orig before running tests * retry: fix pylint issue * Adding Infineon Optiga 034 RSA and ECC certificates for Infineon SLB9675 devices. * Ensure columns "mb_refstate" and "allowlist" are of type LONGTEXT in table "verifiermain" * tenant: add exponential backoff option to retry timings * cloud verifier: add exponential backoff option to retry timings * tpm: add exponential backoff option to retry timings * test, retry: add unit test for retry algorithm * common: add algorithm for retry time calculation * registrar, tpm_main: ensure that correct types are commited to DB. * Fix typo for config param listen_notifications * Lint is _really_ unhappy today. * Linty fixes * Adding a unit test file for tpm_main * tpm_main: check if PCRs for the hash algorithm are available * tpm_main: handle if tpm2_checkquote returns no PCRs for a hash algorithm * agent: output supported_version as result not as a status * Add missing subcommands to -c help message * tests: fix mtls_cert generation in test_restful.py * revocation_notifier: fix socket path permission check * Remove unused database_query config param * Move umask calls only on entry points * config: move directory utilities to fs_util- Change back agent_uuid to hostname - Set tpm_hash_alg to sha256 by default - Update version.diff patch to point to the correct version number - Fix issue with Tornado, when multiple workers are started * Add cloud_verifier_tornado-use-fork_processes.patch (bsc#1195605)- Drop patches beacuse merged upstream: * 0001-Drop-dataclasses-module-usage.patch * 0001-config-support-merge-multiple-config-files.patch * 0001-ca-support-back-old-cyptography-API.patch - Update to version v6.3.0: * Coordinated update to fix: + bsc#1193997 (CVE-2022-23948) + bsc#1193998 (CVE-2021-43310) + bsc#1194000 (CVE-2022-23949) + bsc#1194002 (CVE-2022-23950) + bsc#1194004 (CVE-2022-23951) + bsc#1194005 (CVE-2022-23952) * secure_mount: add umount function * secure_mount: use /proc/self/mountinfo * Validate user ID in all public interfaces * validators: add uuid and agent_id validators * validators: create validators module * revocation_notifier: move zmq socket to /var/run/keylime * Update API version from 1.0 to 2.0 * tpm: do not compress quote with zlib by default * verifier: persist AK and mTLS certificate to DB * verifier: use "supported_version" for agent connections * tenant: add support for "supported_version" option for the verifier * api_version: add the option for basic validation * verifier: add supported_version field to DB and API * agent: add /version to REST API * verifier, tenant: allow agents to not use mTLS * tenant, verifier: allow manual configuration of agent mTLS * tests: migrate to mTLS * tenant: connect to the agent via mTLS * verifier: connect to the agent via mTLS * tornado_requests: handle SSLError * web_util: add mTLS context generation for agent * agent: Enable mTLS for agent REST API * crypto: add helper function for creating self signed certs * registrar: Allow the agent to registrar with a mTLS certificate * request_client: add workaround for handling certificates * request_client: add the option to ignore hostname validation * Better docs and errors about IMA hash mismatches * tests: use JSON instead Python string for IMA tests * verifier: use json.loads(..) instead of ast.literal_eval(..) * Adding Nuvoton certificate for a post 2020 TPM device. The EK cert of the device directs to the following download site: 'https://www.nuvoton.com/security/NTC-TPM-EK-Cert/Nuvoton TPM Root CA 1111.cer' (yes, including the spaces) * Improve revocation notifier IP description in keylime.conf * tornado_requests: set Content-Type header correctly for JSON * tenant: post U key to agent with correct Content-Type header * Explicitly set permissions on new keylime.conf files installed * tpm_main: close file descriptor for aik handle * verifier: do not call finish() twice * agent: fix payload execution * tests: add initial tests for web_util module * config, web_util: move get_restful_params(..) to web_util * verifier: Also retry on HTTP 500 status code * agent: improve startup and shutdown * registrar: cleanup start function * web_util: move echo_json_response(..) out of config.py * verifier: fix failure generation for V key * tornado_requests: cleanup TornadoResponse class * web_util, verifier: move mTLS SSLContext generation into separate module * ca: support back old cyptography API * Fix test branch reference in packit.yaml * ci: disable DeprecationWarning from pylint in tox * Enable new test in Packit CI * tenant: fix reactivate command * config: support merge multiple config files * ci: use only fedora-stable for packit * elchecking: harden example policy against event type manipulation * elchecking: add new tests * tests: fix stdout formatting for agent and verifier * Drop dataclasses module usage * revocation notifier: handle shutdown of process gracefully * verifier: handle SIGINT and SIGTERM correctly * ima_emulator: fix IMA hash validation and add more options * ima_ast: fix handling ToMToU errors * Remove leftovers of TPM 1.2 support * agent: improved validation for post function * agent: better validation for mask and nonce * config: add function to validate hex strings * agent: keys/verify check if challenge was provided * tpm_main: do not append /usr/local/{bin,lib} to default env * db: only set length on Text type if supported * json: do not make sqlalchemy a hard requirement * Enable functional testing with Packit CI * ima_emulator: specify sys.argv as the named parameter argv in main() * elchecking example policy: make it work with Fedora 34 * elchecking example policy: initrd* might be also called initramfs* * scripts: add mb_refstate generator for example policy * config: change tpm_hash_alg to SHA1 by default * parse_mb_bootlog: specify the used hash algorithm used for PCRs * agent: add warning that on kernels <5.10 IMA only works with SHA1 * tpm: explicitly pass hash alg to sim_extend(..) * ima emulator: use IMA AST and support multiple hash algorithms * tests: update IMA allowlist version number * ima: add option 'log_hash_alg' to IMA allowlist * ima: remove hard requirement for SHA1 PCR 10 * algorithms: extend Hash class to simplify computing hash values * config, tpm_main: explicitly handle YAML load errors * config: private_key must be set to -private.pem not -public.pem * agent: add UUID option environment * agent: drop openstack uuid option- Set /var/lib/keylime under the same permissions expected by the code- Add 0001-config-support-merge-multiple-config-files.patch This will allow the merge of config files in /usr/etc and /etc. - Move the configuration file to /usr/etc in new distributions - Add 0001-ca-support-back-old-cyptography-API.patch This is only required for SLE, but the API is compatible with new versions- Add 0001-Drop-dataclasses-module-usage.patch, to support Python 3.6- Fix cfssl bcond logic in Tumbleweed / SLE- Update to version v6.2.1: * Another addition to gitignore * Update .gitignore with more Keylime-specific files * json: add support for sqlalchemy.engine.row.Row in newer sqlalchemy * ima_ast: check if the PCR is the same as in the config * Fix permissions issue on volume mount in run_local.sh * Make run_local.sh use a local copy of the repo * Small updates to GOVERNANCE.md * Move cargo-tarpaulin install to separate command * config: drop registrar_* TLS options in [registrar] section * Fix missing && in Dockerfile * Remove simplejson from scripts and docs * Replace simplejson with built-in json module * Add rust-keylime container dependencies * config: fix getboolean with fallback * Clean up CI scripts and rewrite run_local.sh * ima: for ToMToU errors skip template content validation * ima: Use a set of entry numbers and file offsets to remember multiple positions * Rename CONTRIBUTORS.md to CONTRIBUTING.md * Update GOVERNANCE.md to match MAINTAINERS.md rename * Update MAINTAINERS * Update README: remove Gitter, Travis CI * ca: Use UTC when setting certificate validity * Tenant commands return json * scripts: Allow passing a base policy to create_policy tool * ima: Handle the case of ima-sig with a path with spaces in them * add length to string object * scripts: Implement create_policy to create the JSON allowlist from files * ima: Also add a sha256 default boot_aggregate hash with 64 '0's * ima: Use seek() to get to the last known last entry * ima: Extend allowlist to be able to handle generic ima-buf entries * ima: Extend JSON allowlist with 'ima' entry and 'ignored_keyrings' * ima: Populate verifier keyrings with keys taken from ima-buf log line * ima: Remove methods from ImaKeyring that are now in ImaKeyrings * ima: Start passing ima_keyrings through APIs replacing ima_keyring * Extend AgentAttestState with ima_keyrings field and use it * ima: Implement ImaKeyrings class to support multiple keyrings * verifier: Extend verifier DB to persist learned keyrings * Fix a couple of pylint errors * ima: Fix spurious attestation failures * ima: make ToMToU errors not a failure by default * Simple fix for tenant error message printout. * pylint: Fix errors related to R1714 * pylint: Suppress C0201, C0209 and W0602 newly reported errors * installer: do not install tpm2-abrmd * tpm: by default use /dev/tpmrm0 instead of tpm2-abrmd * verifier: add option to send revocation messages via webhook- Fix keylime configuration file attributes- Requires python-psutil - Disable automatic execution of the payload by default - Use ramdom UUID by default- Introduce a bcond for cfssl detection- Drop cfssl if we are not in openSUSE- Update to version 6.2.0: * Fix bug #757 where revoc cert was treated as text * Code improvement: removal of extra dependencies in measured boot attestation (#755) * Sanitize the exclude list while it is ingested at `tenant` by removing comments (^#) and empty lines. * tenant: show severity level and last event id in status * verifier: move to new failure architecture * pcr validation: move to new failure architecture * measured boot: move to new failure architecture * ima: move to new failure architecture * failure: add infrastructure to tag and collect revocation events in Keylime * Simulating use of SSLContext.minimum_version on ssl v3.6 * verifier: fix minor typos * Add tests for ca_impl_cfssl and ca_util * Replace M2Crypto with python-cryptography * tenant: status now shows if a agent was added to the registrar * tenant: open file to send utf-8 encoded * Correct some comments about and remove vestige in MB policy * fixing a small bug that resulted in malformed refstates not failing MBA * agent: ensure that EK is in PEM format when used as uuid * Solves #703 by adding a "non-trivial" example of a "measured boot policy" (#734) * ci: build and publish container images * codestyle: fix W0612 and R1735 pylint errors * codestyle: fix W1514 pylint error * systemd: Add KillSignal=SIGINT to keylime_agent.service * One-liner to set the minimum version of TLS to v1.2 * pylint fix * Typo fix: return list order confusion between measured_boot.py and tpm_abstract.py * Refactor keylime_logging module * ima: Implement ima-buf validator and validate keys on keyrings (#725) * Remove Python 2 leftovers * Additional fix for the processing of "tpm_policy" * ima: Return an empty allowlist rather than a plain empty list * verifier: convert (v)tpm_policy in DB from string to JSONPickleType * verifier: Create AgentAttestState objects from entries in the db * verifier: Persist the IMA attestation state after running the log verification * db: Add DB migration file for boottime, ima_pcrs, pcr10, and next_ima_ml_entries * verifier: Skip attestation one time if agent's boottime changed * test: Add test case simulating iterative attestation * verifier: Delete an AgentAttestState when deleting an agent * ima: Remember the number of lines successfully processed and last IMA PCR value(s) * ima: Reset the attestation if processing the measurement list fails * debug: Show line number when PCR match occurs * verifier: Extend AgentAttestState with state of the IMA PCR * Consult the AgentAttestState for the next measurement list entry * Introduce an AgentAttestState class for passing state through the APIs * verifier: Request IMA log at entry 0 for now * agent: Get boottime and transfer to verifier * agent: Add support for optional IMA log offset parameter * tests: Add a unit test for the IMA function and run it * agent: Move IMA measurement list reading function to ima.py * Add default verifier-check value * Use tox for pylint * Use Fedora 34 as base image for CI container * Run ci jobs only when needed * config: merge convert and list_convert into the same function * Versioned APIs * Refacator of check_pcrs to parse then validate (#716) * Automatically calculates the boot_aggregate from the measured boot log. (#713) * Set default UUID as lowercase (#699) * tenant: do_cvdelete wait until 404 * Ensures the output of `bulkinfo` command in `keylime_tenant` is JSON * ima: Convert pcrval to bytes to increase efficiency * tests: extend ima tests for signature validation and exclude lists * Allow agents to specify a contact ip address and port for the tenant and CV (#690) * verifer: Fix signature and allowlist evaluation bahavior change * ima: Fix runtime error due to wrong datatype * tenant: add the option to specify the registrar ip and port * measured_boot: drop process_refstate * check_pcrs: match PCR if no mb_refstate is provided * ci: make run_local.sh work with newer docker versions * Fixing pylint errors (#698) * tests: add IMA test where validation should be ignored * ima: Use ima_ast for parsing and validation * tests: Add test for ima AST parser * ima: Introducing a AST for parsing and validation * Make stalebot a bit nicer * enable tenant to fetch all (or verifier specific) agents info in a single call from the verifier * Flush all sessions from TPM device (#682) * multiple named verifiers sharing a single database * webapp: fix tls certs paths (#659) * Corrects markdown to have proper rendering (#673) * ima_file_signatures: Extract keyidv2 from x509 certs * installer: Add '-r' option to cp to copy directory (issue #671) * config: Add optional fallback parameter to get() * agent: Fix the usage of dmidecode during the agent startup (issue #664) * agent: Rename allowlist to ima_allowlist in keylime.conf * Fix decoding error in user_data_encrypt * agent: Fix issue #667 by testing for an empty ima_sign_verification_keys list * Addresses issue #660 (database path while running local tests) (#665) * ima: Return 'None' when ImaKeyring.from_string() called with emtpy string * tests: Move unittests into files with suffix _test.py * Fixes and improvements for database configuration (#654) * Add signature verification support for local and remote IMA signature verification keys (#597) * install: Remove TPM 1.2 support from installer and bundeling scripts * CI/CD: Remove tpm1.2 testing support * Remove duplicated calls to verifier * Remove adding entropy to system rng * Cleanup and fix error case in encryptAIK (#648) * Move measured boot related code into functions to make check_pcrs readable (#642) * Move code related to tpm2_checkquote into its own function (#639) * scripts: Cleanup shell script formatting * installer.sh: Do not delete the local copy of the certificates. * Fix user_data_encrypt to UTF8 decode before print * tpm_abstract: Fix adding of entropy * codestyle: Ignore R1732 implemented by pylint >=2.8.0 * a fix for letting JSON encoding bytes correctly * Adding back reglist to the list of commands that don't need a -t argument * Invoke tpm2_evictcontrol for 4.0 and 4.2 tools if aik_handle exists (#624) * Addresses #436 (#611) * Fixes #620 * Include PCR16 in the quote only when needed * Close leaking file descriptors (#622) * installer.sh: Add missing spaces when efivar is added * More ima_emulator_adapter cleanups (#616) * installer: Add json-c-devel/json-c-dev to BUILD_TOOLS for tpm2-tss build * Remove more commented code in ca_util.py * installer: Only install efi library on x86_64 systems * Create allowlist table and basic API support * installer: Add libuuid-devel/uuid-dev to BUILD_TOOLS for tpm2_tools build * WIP: Some cleanups (#612) * Remove _cLime.c * config: Document the measured boot PCRs and what is using them * Very simple fix for the agent (re: measured boot) The agent code does not need to import "measured boot policies" * ima_emulator_adapater: Remove unnecessary global statement * webapp: Fix private key and certificate path (issue #604) * Add support for keylime_webapp service to read intervals from keylime.conf- Update to Keylime 6.1.1 + keylime_tenant add crash with TypeError: Object of type 'bytes' is not JSON serializable + Whenever Keylime agent starts and cannot contact the registrar, it fails and quits without flushing create EK handles + keylime_tenant -c reglist now requires a "-t" parameter for no reason + Duplicated API calls to verifier in webapp backend + Installer deletes tpm_cert_store files + agent_uuid set to dmidecode crashes Keylime + Copying of tpm_cert_store fails during installation + If the PCR belong to a measured boot list, it is not validated + keylime_tenant --c update fails with a race condition - Drop patches already present in the new version + webapp-fix-tls-certs-paths.patch + check_pcrs-match-PCR-if-no-mb_refstate-is-provided.patch + tenant-do_cvdelete-wait-until-404.patch- Add tenant-do_cvdelete-wait-until-404.patch to fix the update command- Adjust the default revocation notifier binding IP - Default to CFSSL in keylime.conf- Add config-libefivars.diff to adjust the path of the library- Add check_pcrs-match-PCR-if-no-mb_refstate-is-provided.patch (gh#keylime/keylime!695) - Recommends CFSSL in the registrar (actually should be the CA) - Change default value for require_ek_cert to False - Reorder the patches to separate upstream fixes from openSUSE ones- Add webapp-fix-tls-certs-paths.patch (gh#keylime/keylime!659) - Recommend dmidecode for the agent - Require libtss2-tcti-{device0,tabrmd0} to use abrmd service - Add keylime.conf.diff patch to change the default config file - Add keylime.xml for firewalld service definition- Update to version 6.1.0: * Update python cryptography lib to v3.3.2 * installer.sh improvments * run_local.sh: Run unit tests in keylime/tpm/tpm2_objects.py * Fourth and final PR to address #491 (#580) * scripts: Also use pylint-3 if pylint is not installed * agent: Fix the checking for a specific error returned by tpm2_quote * Allowlist verification - Enhancement #16 * Forgot to remove the original, more crude solution (which caused pylint errors) * New and improved code to fix issue #582 * Consistent formatting for logging strings/bin/sh/bin/shgoat18 1658829204    !"#$%&'()*+,-./012346.3.2-150400.4.11.1keylimekeylime-user.confkeylime.confkeylimetpm_cert_storeGS_TPM_RT.pemIFX1.pemIFX15.pemIFX2.pemIFX3.pemIFX4.pemIFX5.pemIFX8.pemIFX_ECC_034.pemIFX_RSA_01I.pemIFX_RSA_02I.pemIFX_RSA_034.pemIFX_RSA_03I.pemIFX_RSA_04I.pemIFX_RSA_05I.pemIFX_RSA_08I.pemIFX_RSA_17I.pemIFX_RSA_18I.pemIFX_RSA_20I.pemIFX_RSA_21I.pemIFX_RSA_RT.pemINF_ECC_010I.pemINF_ECC_010RT.pemINF_ECC_011.pemINF_RSA_010I.pemINF_RSA_010RT.pemINF_RSA_011.pemINF_RSA_022.pemINTEL_I.pemINTEL_RT.pemNTC1.pemNTC2.pemNUVO_0100.pemNUVO_1110.pemNUVO_1111.pemNUVO_2110.pemNUVO_2111.pemSTM_ECC_01I.pemSTM_ECC_01RT.pemSTM_RSA_01I.pemSTM_RSA_02I.pemSTM_RSA_03I.pemSTM_RSA_04I.pemSTM_RSA_05I.pemSTM_RSA_06I.pemSTM_RSA_07I.pemSTM_RSA_RT.pem/run//usr/lib/sysusers.d//usr/lib/tmpfiles.d//var/lib//var/lib/keylime//var/lib/keylime/tpm_cert_store/-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:24762/SUSE_SLE-15-SP4_Update/9473ed405f0a64573c704344dfdc43b1-keylime.SUSE_SLE-15-SP4_Updatecpioxz5noarch-suse-linuxdirectoryASCII textPP.\NOV rutf-8a9ba63c8f7671e6b557be2d84d39fdcc1143d6220b172ff3c50a663db1a2204b?7zXZ !t/GcI] cNſ^J0ht/%KuS!sh0{"#Ήe57){9q`j*NFl:NIngoٚ7t4GϿr 䖌@|+LmY5awLvnyn\t6QK2Ow5K_6<0:'*tnNrWDJhf]ivz˲:_E`ejjxoZX g7gOmN muJS3c"hSx(Q%wgqXj koP~<A0W6Y%ޠ [dMbO?\j3$ĦN#Vc_7DB :Ĥ\sΛ8>` Gf dTK*nS\7ZngllB>+ߺ0&HSﰜ~j4U:>f;1ላ1KҭH#S&}+J"fBkqq~c}jt#6N<띷-bē״3ό%•C -6r74){$@135Iq$ kO1ؾ;òo8فA_:n-LDo{`1\ tPPuDA>"h3#-aa.قa{lG\C k]g(9+Rn,ɮCL]8_I kt -TN5zn=o[;mdc0b$̴A=Ang{ ԶMN"aeX}<͇k汼{,RtXW^NO,!H{xĆX]h}y("/)ITZPiq +d䌃5OT),֎p 6%*B`= ѾH4^ cj'gG(P1~y,DfTRp:5XYWy= ޏ'L\/ q$:Q+ʖVs&ߡ3׏APRM9݃AMy5 Yɓ-cENZ(Q$RWiL'me WYkc4\R8@+|c}rXIGTQ>?^n枷qӍ-Q 7A_Ыo{#7y#0@k"3y_QE6^͡+qTcȥ\(Br 5h ac%R뻖e8773Vsq2z0$e `(9&ݳֵ&y6őυy[=YL,**CӵoSM1Xn}) Q'zOf3ѫOV&Ƶ~!r@A&S}WXikkx,v$y &("p>ȂHPCC@[-=T6>n=YS)D/@ƍq[vfղt2$)VL"IY\v82[}0~`k͔8dx kA }N ik9QwA%z7<7FZΨeʹ BdZ|u탥eX5^&Aí?(cMT4. qȟÉl15Uo.%޲pfl}H(-C<<zn)Wh_Uy?CIU8e4?bػdX5$HޣI0HEcܐc"$i`ѠczGhr v  HaE=*?MsS3f6 {w7MWtYk=1>S[H(~:%X>F+a#(u"=*=978uԠn#u2BTtֹQykZvRһ%q@8MKҵN SA,I{S*Gl#b4Ex/ w9[^˖/R ؉ G)gB|NAR7KQ(H/Fá~=7e;&u!6X#|YƖNV ݷ2=f"]IX[l ;7+n.O]$n= >vKP, `BayicgvMMV-e^9}a+G7'[o^kKX4h"J2E@JH5k6$Gh,kF ]R ^`MxkC)8 . &ݛPU2;/hG5Mם fx?sbxloV_Nx4 "QWJQhu? ҇[C@`GCbnxalҦe|NbE%eV4Ȩub`֧q64u5f|nI<"m ;˲ϿRX B27n:i?))dy)vPw#c "ƞf/ D㌴ }ߺ0@hYTgS-eqg쏢zą~狵̒CQMyG!_Q.q?6J5R^TuO&H n5s{^E ˮ1JgmyjVQM=PO!2j!K:?/5J]y:ި8ڌ9u"Dq Iy[$9t @av^|P\4ɊI?KzP;F}3&.~e?O ̤Cr{.H lk٬NvT0dnlXt嬇JҲIPVu<1*vsn5#ha;l]f|V U*3 Uk5)0Ꜻ=n%0kLtj{OqV<6GĨaD/𴬏l,Pg 91e ( k.:,v`fL,fƋ* 3matV< 2H7>!*^řEB?;^&zIR[tyezdZ;T\zaŖ3+sفHnR1g'?%$aZML=JS*娒6j^\qӽ :Pr5>/c<ݟ vLj?|Xx*aaH)>NϑڍYՍn{ԫz}ʖ 'bo"qgKA,ά~<o,Ypڂ'B'LL2pYnr똅yx Dvخe1+8dp'V!6^f_"4w m_<;AUzIq"Kfΐ3I(VWX 7|yCb_Y3әޟ\t@d(WK1LV @|׻d&Q"|ORCdCvUWw"aε yY!ɏt )NL1Cȳc\q؜-`$LMcd&d Mv[Rڔ%B E:0 #_m Xd*XiJwFWCQ!_gngqR 8IB{5r%PRMo5H1. ڢO8漑6!ĄqP<&8m.8sn-MgEh#֢C#76Ry+\T; :{IEث .'}j['mf+l7.mC=Pj*܅a#ֹƧlDṚ; ]UlgK:uZiPŝ|ަ>m9(lקgGf}}q+4:FE9<tGG$t :PC[N /RE퉅&[-ނfRN+ <}C3VO@aXp-v_}ꮱ3]C G"wPeܭWs9M-}o_:lߞ{~\\=O!]L ϴqҌ+36\Xl7 wpĻPtk5(!#aSۥ>u,Gy 8–ܰ4GeÌ@Сubg)viXx!O$4y] Y_8}YgLkcѭ4h;< RxCқG?fĖ6Xb_G, K0/Ĭ\,-47ǟ"vyُIC-MrH'[eJ2\[U^(zk8`I}%2&RsH&B4=n*=B}+eqGYOwL i0*|v %Z-h"A*OӼ y\f҅| `EbM@⿂"LL5rn.0[LG [ ( QsiDd3/ \V9%H$+۳cPŘg5Dܜ{YÁpĹV#͆W+w1Q;J~scg DI*`q[ǰG*Z1Hv`]R?Czm; H(TB elZA|{d+7,1p$oxܐDZ]@kz;AsҳI!> cژb>%Za$3M8<&ۙOQurqt~, L6rܥ4><'/:\(. qZkďJx l%pNnʽ|ui*~Pn8Xu|;~=gɈ1agfE>Xi4p%:9]jmEx#@T#z76u[St{☖@[oքmǶhf- Qj8)YK%RE{λ1F&_ ]pp cV4-JW2O gOgMHI9+= 0V(frcw|?fW\;"N{Ǣ4M"g(Zhe{Xŷ@n|i<%8_NrMsx){^hH&y֓}wۄYXA8="GxuW~*>Cq6.$( 'R0J';0T`ٟ qKكcYd՝!pc[eS o+TdPyϦ+HR;,gCؤVr0U7fNYn~вSU= r : Or5:ihCJ4d9&2'yFD |V;~*镨<[⪠h%ۓ7c#Cc*]hd:IXrكG 6ܿ{ʏ!8o81Ƅﺃ܀y@Iwg|ʴ0);0nDh43VzT=QE:*[ `GTnE|[F](3̒h2YsC3GvJ^vaҢelZpphqLlGDТ%^}<9a~žg|?n b bmfwEwAvInuXSxF35 ]\sIciDKz W]g:XTdj*V9_͵3⋊Bn؀(Wr&axpF42}96bZ}$9+{a"lo ;|@_F(=:}^:qBKǗ@YM.PDPSR+/ 3?}`YN3!öI6/0ul*R\6S~Sr&p\ :0~K/~10{FU͐ܛ2u90}ߕj,IBɲ LTUqH/^hlwi:MIGJ DcJzƩ$yWq Q@[qot? kUabtzwq-&Ccz+-ϔڋ> > +cru:nm] p@CM[ V2'٢}@'Dgk㟡śL`< h% Odt.^$6khk9/ZC3 ^nAS]x/->2\v9ucܠs? ;/Z(mբĥWR4JLܹk7J hpqs裢FzlXZׁʲoM 㽪Mb݌K,:U*J|,{o ~j^ zcȕ_ruà4iy]_#b.jaSILeT" s/$u- 祖UQUjcVdTSq>'ߎÍls`/ 7<y SmXYz|u"K8"T[Ա6IR2KWAPIo>_ÛkVWa5-yPR|+_<|4'P~$=7RE' [ 6$A+_ϙm¸hAyLm)l},S\OgֈD$AC|g =nx_#a&ӔlvM*ouE`gc|ES;SSu?VQ$Ahx4; n7jX.Aa9N?7b'cd 4$n٠Pl3:*w_4 ^CĊ`i)Am Cm?,m6CRu1&mT]}vP^WLqx&Y:̺ Pj5z.07a ܠ} h,ewŎɬYU\*+s┄lEy-c9:t!sz[~IThgL=8g,eU!c`_ݹ]R&%o(==_ q$%zIP4 .zeywdb#S#e,CW9 ޜ[HO\ #Uߔ VD~>^@NYEۘe2' ߽X^N7}/ ұ'\̞̇ #~f/RTnZ̮t35?jb⢖9,eykF]jbGEQ5AʬClRE3r'5z*!_)(hĭHNgfu5XJnVl'I eT2Q)\CY~oA66 o{x{㎊܆? Iƃ89WLVClB92΅?q,WPxJ3.kN\KeSaA<Ƌ2ZYvc%I"mq<'q/=1P1A3Vڧ =7dr͑Nl8MWC{~9΅v0$+5 ?DT9ٗ K )U6ztЀVY[@"K;@(,P޼U? "{cL/>Euf~c4884!o~+w,'wwjQðV b) 5H"7'/inx-Ux?0D)J 'Wbnt@rQIAnP^d :t%78fc]^+b{d:"o<6.S5y"`U TԇDᐣI& GX>T =I[ ;|d]' Sp$N ھ.AJN 8y4c8 `#+~F7L2}I!emkӁtY,_oŴgqZ^4ӽ0HkauuJpe /XGffs*bt6eT;9kB~̃rznlq2opmF^@bl1.57 A~w(>(g.m̎daX[؀*1<[%.ZG2#S~v1QM DjFtnԉ5% rt6J=<(EIj*1xa1傜)W|8Z>5[°uEBˏ/wkPK3yƨC"!A'R {.qP@)nV"DG%:xRB4yHs%E/JR#\A<|g:"oM2Nlӟ,Pq z4ϑ%c my®VNըe s-.`C^`4'I5S* 45:&2BDO1qH8%:4=ڃANC ]] k뾔PəZ_ @ Azߢoh5CJ7 |S$1͟jn9vqQVWN ( gЪ|5J J\j]oc;=[{%^*1$,gJhuSoGf6mA~~ #t4e"hTh=kyS]rD}jA>pˠGy8lθpX,u_.$td彇Uq |x*4KLN&0AYwϧUȆNۿH ߩn-쨃-`mjsp]Ane@{^ ȆR:XH{P!ޮ^}Av,2$-gisH=8 Lcٗ-q 26tVR<']\'>Im[me;[@ =[J_PyU.+phwM4=Ts2 \cK:?<3zh-fIAT(p^4DF7 /G35'PXk<"8q?o;Q^TML!Ļ18pqs2}/8Yjw۫qݮF-w?Єe 6;9}F1:%+WYhL)AexKRsJno?_B˓aܞ4W()NHU/ y Fq}z1!a.esP4F=d=k)^ Mn&DN|сث]';Ȯ g\xyx;R6솼hn:IJ9ޓc~=q U>Y&2>h3: %Xٗ;;dS;A/mfԘ=`;pub +>fVC<;9aDzmt$7`? P1z'"6͜\ݽ ؈n ^49@5`'y3QPymFlbn vM˟iir7Fg[ipq'scc*Uii3A >-P !〝!:EX02Y LT]ӋRz紀rw깫 n?ަI0Y $Mc`\JvYD_ Yekd=SËZ$P9m&IpMYfW;42-ndBrmv2X˯Tq|Ŷ81(ʾ'=Avq:| ؎Mp(Wy(&h2JA S 6:M,б{h+[-QՇǟfmlED^ b?87h- Fg;2{LrX-ݑ+%IK\^ec#ds b+D;35n`h>l gݳ&C5@ +sgucv | H=?Sd^-6urGU!UK13+5UUq==syI<]}QEr# 󙒙t4qp%keCy:& y:D39ل&k@ɼj1;4gv𐢠K"YXb*i*FtRfnaJ[ Jmfw?PYZNTg}DiW/_iki(bnc_5H4j9Y9sYlj GI,[eh%3"Tr+w3b ^;MouQPx*)bYhLO[S^ ae.g%NnQL@tHka`G+\G \ˁP ,^Dmt =Gꤚc(By p$ı`׹ &-yzk7B!gRJ~Tbh_vOPqrTE D%y'qJO f]*TH^ȃ-x'І 2>,X.`YJnU >aG9[V/̺K` BFŜ_d,$-% erxN-^A5Of[rִѕ+jk`Aھ'ѶuS7:rf9=%⨺qLsrv(gK0fܳأ6VW^-Lsܒ-ýsx0fqJk,=*, #|WoO-ҟM+l$O 5đQ/:{{V|Oc@ᙎ@gdNY_ ݐWwUb&!nzԟYLRJXo E'+;HN\InBuCv={k1 GXpIq{_lM"'l llߔ!)ĸ[m-W:Q)s*^-3L:t $fB @X%qPdVD5u,pi&ҍo&& K70\  ա,?G``U:4{IĢqE%H&w4OU9': EjPt[a̵Mf3E J4Peؐ@ʀOz1Q/ FJ{zh;Ѥ`c3=H0ٚgI\nv2x-t`=;ZvK :c,YtF ?vFZ%k7Y4)Ck\EwVtԱrLi#D66L%L-j>=m픒4Idlʽ>Vuy%SN: 47țO@Sjƾ猜eKVv0 K:x&X.XҾJb(=]t84{Gqe_޴h|-D1$28EgTs#3hu!\}옋)"}a}V/A5zqG,.a)تֿN'Oނ?qV#拾7taŅ*>`1cTK6Ap*ew fJB*x +s@xihxa۪zpٿ2K#8=f0lM '$K2Y\wS i =?Zϗgʹ%wrlP< Zx !JR-\y`OjpU49Bc(TBhiaKϞ/x|9L\Zl'fm9E;+{fWLG<O67JO_1%ȥfxٞvhhT_jZw["sš" O,E iHZnR``Yb&=AE?j|}d;j~=2jL6›R(ъʮL(]3&&QVaD%Rg- X91m K1Hm($y1jQ$[z& {⑚.X[!-h@܎~ rr=g>Vީk1HsUAm<:+U1I1҆aWDt䶉=v/}.nbm(҃"#78H)RQgI D25k(oZ%jn'zQ=_Z\1bs!J&Bێ (9ltDBi b}bېP!D _>Sz5U`P,^X뮃S̍zG3ϊ4 *\GU}/9cO*m%Cs&JH0Q_./~rB_D ,!%O){\*r۽'h3pa]~3~8h$޷]ugA"J\gl{z펲+4Wܞ)92obΏ9޼3sQe/4n0UN2 WZgT8zHgnJ?31\30vQS%ΆHpN*T6`9޺ЂM H|~^-rcq\z{\"3tl :||ߋ-oݬV;/JQؙ3=*3x2r[ ^]dRvϾI*5StVp7ˈg,3qq{읔Eq%%*3~^60%CDI+#!i1)#vӆq\H6'Pkɕ~˖p6`oN٤+dв?*>FBK hѩ[?H@>ܿ磪Y4#SxDa~􌂽FOzM هԱ##!mGA!ьnK*MEd~.`v")Kx[mzv(o  Et2WS4b:jℱ=flWlb|1Mh!YaA+)huO%ZTs9$w 'u%j2웫ECi?JMk64ID078bK%VkXny ƾ?f0ll ɸM81ܟ:F9wll |I%5&Vy^-^s*;VM TM|Șj/bjV2m(l ekHusO7aS-(ҕ\2„ha/V :=̐5-fYb5GZ5\0C2jdН Tzھ;OnW%lj?@#J^ 8!e r:U99 ϑLw61EKoDՖG;ćUD8Y+?EuZAS/~G2RS0u`YaIXug MD ܋1QH#8UIe8CqXSݭ>v<:㛳F3|_ x&0`I/7E[b{J8h)#pUȫ$բ3ל#/L؋k}̭iSP'7h Q;P44 !~oƢSZF&Yd/~ҢޠX^o!*lj+*W7`%{pJx0 B '='ŦCLC8>wN0%c)@t1 wbи@:✕jN18D/2:3w-evE!gZK>~_|r5T(ELߨK5IhϥAC_A((Tk$GsTX5bb$ε[s]T[fK^B,B{([3hDА`;Һԩwhw"!0@;FŠ$Z".KMkpWc !wJ]o`l'us tSAA9Ȳd3k\T 9%aHJDTJ+]򀜬]pPXvT{| 6)tE?.Gp\[uGo"E1r&5j !v7в|3gbt_E(ۀ47!2ϩ!ET/oC_W:9A\[w?xy<}.R{#qJ1E(tbu;*2'ߞ`d,6 Vbq*@,aލt.^t5)gd\F{NG os22^8,vzݔ,XQ`"g`IokV8tL|\xdeUCr,, Mh/󋶤ssCFxzF 5)t`oOqS+9O[ߋ̛,C] &7׫Z¢A;V*ÔZm!SVat^Λ3S^J]+0 G3 *3u' vS ?4rpck$mh$pd-> F6상7f/"3X *ux|l`[`5>s/[ +֞A畮6%g/M{7^C6߿,IR.GL"4wԘ%qÿ2=q}=2;.$ہ E!e$_jr j<Y!A T^٘(]Cxg^Ss׏ FZB LhY%\߆7 a;Irzh% ItUuA9 UCun3*xCYA"XQQT[L^ تJr'Ae)uyj7,"0o19r3sP:FSظ?"=Z(R#D-YfQ\O `A~u,澣L<|ܨ]gm/?!Ϳ=FgFA 3!EFR<-8]R'vT|wd0?}i0vL"d駃pK²]I܉&+,;zK+߂9e#6 "Xo3ÙlZO&.AwUP=";*2l"Blq  (46ܷ[6rdP[m>cd(y1;`4^ĤthA0 5a?q$-v|K8`'+- ep}T*oTfoWbC\,XήJS[S'5<  dWмa=)o[aU}T2$ &ipS=^Uzՙ&hDnhlHlEYh<$;'*,9Nw`^4Oc5h3y2jõI_(-:"Fkv͡&Zp1PE %WW'0<Ӊg웷$*@r]特5 t 'ꢯS%zWopek &A~~&ԩo>CE m8.Qत2?m)3әo0d5}I{u*5HTp2Wa2ZrLG+'kZ;.:p#~RCGM(2 N S8na}R*R}z^gX]<)VeQA!:]v_Ń6%83 0byx `mb6'6x)E~"m!5z8x4Pwz'`)s "Kd^sD, #B jFE]L-[57˪vxWC<(꾵oJzwz?IR{b6j%]!(D6֒L'/;@ڊ;PIJ-Մt2֠~G3p;g ZGQ=Шkߟ/aWRr5й coK+pqyC@%H6ssO[J nbCGgrvbI<0Q(^&vdIY܍BbX)ZnCw0`C֖Ue"3Yj]qC%[&_yK ޼v?}:BxQ8Rz2R&|_]ji?(f,@{[Fsȹù|@Ʉ_%G"B@[+{79!%<@/OfT㕩]OWL,b$ i' l1M{IGk-IHDYGd&r5PR=wq4!_lȦ[8BlĔ/z"R4Xz{8i@4#` c@MBBZϜe{<OK R=@[k@ׯ{J{ bZ(wuNvh ^50cJ֩NW:0K);SEʙiH6(м׊;f0w"HLՖVH}UJfT?7߈$k\H,#0q+] (8DSAKSB1E2[ V"Vffv Xg0SŨޔ{4dei4z9*Ĕthz9:wKCL\QMPY#gW;sZ+o% /GuP,$7Tcr7vfAo_',:ټ 7Ӿv%**YuHܢ'Pb1yp䱪ԑ./qZ -)-3J4ߖ 0,y-xbNvH7j;Ά(oQ;93bm.s%Q;%H%6COƳ(bqtLkG\h'01pC@a *;[c@(p5<-_NSBdENve=ܯD:n'v} `I`۬Y$yQb24&Bd1\νc+9$w* mHͨ)K3تk0^֓ yzTAGN`_J$`arBN!`)ѓ@;H4l >qɀ$F {5Sz> i|EͨpjLb{:yv'k٠]{vrOօ 6s`,=dmCep<~NDO]oOx۬u$T5l΁@'.> \1ǝYԌ8R^nR:=pwr( T٧B r_ !+#Kj`ta5г?]n7ָkB)Ťbȸt9>,O8g+>%R_wbi[a\qm+Nꮨ]2"h ڻpcĂ#YV+F[r6ε`=pve4ؐ>/ `T9hb7 R47ogTO G`IvD)#]hWZ׊3K 2G4 S龬oyh?gHkDgWENS"hi09hF&"j_Eyo*T yZh6ֱ jl`|4*l8H)u:8 YZ