transactional-update-4.1.0-150500.1.4 >  A dRp9|7ԍޖ4#ʗ\M/{k+U,[C%PuMP-Bp4!e43sB*BG-jay)vg`QJǐS+@5ay+V N$1"b8T4 \zxI](&eSyF\|#d8DZKM Ԧɮ2/Pir!e;޴ψuj|-s//}| 4e6895b1281c383a060fedf71c8605eedba890c33890442e63342292bf9f9b33a0451e27bf69d171349cfb3a4ddc6c2e47bdbde62܉dRp9|bqjh)g['.WS2a{jn gGٓ8=$t LE:i>!Rk@(ާA#0ֹTZҨՊV;.K;},%`K6}:(#'_}|]/9|z^1 sI0̗fu;7/_Spj$c>fj0UB57ޔT(KcSt;KMmCd.t-lsOٱ,Q¸n8>pL4?$d ( W- CO=5 `   P  d  x !,!!""`"#($8$$w9&w:-w=M>U?]@eFmGHI X4Y@\t]^ bc<defluvwx,y|z Ctransactional-update4.1.0150500.1.4Transactional Updates with btrfs and snapshotstransactional-update is a tool to update a system in an atomic way with zypper, btrfs and snapshots.dRgoat08SUSE Linux Enterprise 15SUSE LLC GPL-2.0-or-later AND LGPL-2.1-or-laterhttps://www.suse.com/System/Basehttps://github.com/openSUSE/transactional-updatelinuxx86_64: if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : for service in transactional-update.service transactional-update.timer ; do sysv_service=${service%.*} if [ ! -e /usr/lib/systemd/system/$service ] && [ ! -e /etc/init.d/$sysv_service ]; then mkdir -p /run/systemd/rpm/needs-preset touch /run/systemd/rpm/needs-preset/$service elif [ -e /etc/init.d/$sysv_service ] && [ ! -e /var/lib/systemd/migrated/$sysv_service ]; then /usr/sbin/systemd-sysv-convert --save $sysv_service || : mkdir -p /run/systemd/rpm/needs-sysv-convert touch /run/systemd/rpm/needs-sysv-convert/$service fi done fi : if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : for service in transactional-update-cleanup.service transactional-update-cleanup.timer ; do sysv_service=${service%.*} if [ ! -e /usr/lib/systemd/system/$service ] && [ ! -e /etc/init.d/$sysv_service ]; then mkdir -p /run/systemd/rpm/needs-preset touch /run/systemd/rpm/needs-preset/$service elif [ -e /etc/init.d/$sysv_service ] && [ ! -e /var/lib/systemd/migrated/$sysv_service ]; then /usr/sbin/systemd-sysv-convert --save $sysv_service || : mkdir -p /run/systemd/rpm/needs-sysv-convert touch /run/systemd/rpm/needs-sysv-convert/$service fi done fi: if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$YAST_IS_RUNNING" != "instsys" ]; then /usr/bin/systemctl daemon-reload || : fi for service in transactional-update.service transactional-update.timer ; do sysv_service=${service%.*} if [ -e /run/systemd/rpm/needs-preset/$service ]; then /usr/bin/systemctl preset $service || : rm "/run/systemd/rpm/needs-preset/$service" || : elif [ -e /run/systemd/rpm/needs-sysv-convert/$service ]; then /usr/sbin/systemd-sysv-convert --apply $sysv_service || : rm "/run/systemd/rpm/needs-sysv-convert/$service" || : touch /var/lib/systemd/migrated/$sysv_service || : fi done fi : if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$YAST_IS_RUNNING" != "instsys" ]; then /usr/bin/systemctl daemon-reload || : fi for service in transactional-update-cleanup.service transactional-update-cleanup.timer ; do sysv_service=${service%.*} if [ -e /run/systemd/rpm/needs-preset/$service ]; then /usr/bin/systemctl preset $service || : rm "/run/systemd/rpm/needs-preset/$service" || : elif [ -e /run/systemd/rpm/needs-sysv-convert/$service ]; then /usr/sbin/systemd-sysv-convert --apply $sysv_service || : rm "/run/systemd/rpm/needs-sysv-convert/$service" || : touch /var/lib/systemd/migrated/$sysv_service || : fi done fi: test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ "$FIRST_ARG" -eq 0 -a -x /usr/bin/systemctl ]; then # Package removal, not upgrade /usr/bin/systemctl --no-reload disable transactional-update.service transactional-update.timer || : ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_STOP_ON_REMOVAL" && . /etc/sysconfig/services test "$DISABLE_STOP_ON_REMOVAL" = yes -o \ "$DISABLE_STOP_ON_REMOVAL" = 1 && exit 0 /usr/bin/systemctl stop transactional-update.service transactional-update.timer ) || : fi : test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ "$FIRST_ARG" -eq 0 -a -x /usr/bin/systemctl ]; then # Package removal, not upgrade /usr/bin/systemctl --no-reload disable transactional-update-cleanup.service transactional-update-cleanup.timer || : ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_STOP_ON_REMOVAL" && . /etc/sysconfig/services test "$DISABLE_STOP_ON_REMOVAL" = yes -o \ "$DISABLE_STOP_ON_REMOVAL" = 1 && exit 0 /usr/bin/systemctl stop transactional-update-cleanup.service transactional-update-cleanup.timer ) || : fi: test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ $1 -eq 0 ]; then # Package removal for service in transactional-update.service transactional-update.timer ; do sysv_service="${service%.*}" rm -f "/var/lib/systemd/migrated/$sysv_service" || : done fi if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi if [ "$FIRST_ARG" -ge 1 ]; then # Package upgrade, not uninstall if [ -x /usr/bin/systemctl ]; then ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_RESTART_ON_UPDATE" && . /etc/sysconfig/services test "$DISABLE_RESTART_ON_UPDATE" = yes -o \ "$DISABLE_RESTART_ON_UPDATE" = 1 && exit 0 /usr/bin/systemctl try-restart transactional-update.service transactional-update.timer ) || : fi fi : test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ $1 -eq 0 ]; then # Package removal for service in transactional-update-cleanup.service transactional-update-cleanup.timer ; do sysv_service="${service%.*}" rm -f "/var/lib/systemd/migrated/$sysv_service" || : done fi if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi if [ "$FIRST_ARG" -ge 1 ]; then # Package upgrade, not uninstall if [ -x /usr/bin/systemctl ]; then ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_RESTART_ON_UPDATE" && . /etc/sysconfig/services test "$DISABLE_RESTART_ON_UPDATE" = yes -o \ "$DISABLE_RESTART_ON_UPDATE" = 1 && exit 0 /usr/bin/systemctl try-restart transactional-update-cleanup.service transactional-update-cleanup.timer ) || : fi fi`)\Hl//A큤A큤A큤dRdRdRdRdRdRdRdRdRdRdRcYICdRdRcYICdRdRdRdRdR23a08d3f2ffb6f3c5a4faa7c308adb908804547a814bf8e6ee46d9d4481b25dc6cf5fc61b4db3bfbff5ae6b6bfc0713bcb975fb846e480ba5ae5c111628eab03b6be6c251c3efab512a5a0865a3fb7436d39afc344148edd5425d38219798c191364d259643691e2f2f5b633279df22f53b3826867df1724c538a037a44ec883a4dbd8bc49e207e0178385c4588466853118a5af1253204bc3d737d8e22248f3521f0892ae8a7ad78b2e94c574d573be75c4f76c70d9620c79891e584b4653b8ce6b2cf0140f8325733c93a7ac3711b54d5d7ae92367cfbe01842913d8448e78435561888eebb1690bfe776fedea1a1b448ff57ca2f28e094d6ca299276e01ead77fc3cebb7c1c69f0fd1bf742bc9edef93e2931a756301020c6c4ee1f830a58ddee4b41be333a00e70e2e40d53975a3d483a340ffe377a90f1ab6c05867aba585182076949dc5efd35ebf8dc2634e8d904269b92616bde25cb9c3c0c987516c4ec94987f3af0b357c6af2280ebcb5b352e6c5fd51f4c33eed6e89d8f20ccb6cb20fedf44d8e93615a76b674e66fe2fdfc35c40f072a82b482033414021ef07bcc9f75d425050a5a992e332fc5ab988502628ec9388ce825c19537e1135d51eeeb1124a2ff49049b3ec8e8f2045a5a3e44673ffa5def8399e4c3f1be39f88b45eb1124a2ff49049b3ec8e8f2045a5a3e44673ffa5def8399e4c3f1be39f88b45@rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroottransactional-update-4.1.0-150500.1.4.src.rpmconfig(transactional-update)transactional-updatetransactional-update(x86-64)@      /bin/bash/bin/sh/bin/sh/bin/sh/bin/sh/usr/bin/bcconfig(transactional-update)dracut-transactional-updatelogrotatelsofpsmiscrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)tukitzypper4.1.0-150500.1.44.1.0-150500.1.43.0.4-14.6.0-14.0.4-14.0-15.2-14.1.0-150500.1.44.14.3c6@ccobbb@bq@b$@a@aa@araexaLl@aD@a<@a6a,@a /a /a@`@`\{@`KW`KW`H`H`>(`-@`*b@`&m`"y@`>`@`@`@`U_/@_@__t@_@_o-@_h_h_3_+_$_{^^^@^|@^ku^^F^V]^r]X]V]v>\\@\@\\\}@\eX@\eX@\N[[k@[[z@[#@[{@Zz@Z@Z@Z@Z@ZlZ@ZkZZ@ZqZTZ&@Z@Z@YYYV=@YS@YRHYP@Y0X@XX @XXXXX*X@X@X~@XWXRXN@XF@X5X2X2X-X@X@Xx@iforster@suse.comschubi@suse.comfvogt@suse.comiforster@suse.comschubi@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comaplanas@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comngompa13@gmail.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comkukuk@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comkukuk@suse.deiforster@suse.comiforster@suse.comkukuk@suse.deiforster@suse.comiforster@suse.comiforster@suse.comjengelh@inai.deiforster@suse.comiforster@suse.comiforster@suse.comiforster@suse.comkukuk@suse.deiforster@suse.comiforster@suse.comkukuk@suse.dekukuk@suse.dekukuk@suse.derbrown@suse.comrbrown@suse.comkukuk@suse.dekukuk@suse.dekukuk@suse.comkukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.dekukuk@suse.comkukuk@suse.dekukuk@suse.de- Version 4.1.0 - t-u: Add a "setup-kdump" command; implements [jsc#PED-1441] - Export TRANSACTIONAL_UPDATE_ROOT (the path to the snapshot) in the update environment; implements [jsc#PED-1078] - Add support for "notify" reboot method for desktop use [gh#openSUSE/transactional-update#93] - Fix kdump initrd recreation detection; the check was performed in the active snapshot instead of the target snapshot - Document register command [bsc#1202900] - Avoid unnecessary snapshots for register command [bsc#1202901] - Various optimizations for register command - Remove bogus error message when triggering reboot - Rework /etc overlay documentation in "The Transactional Update Guide" - Fix incorrect manpage formatting - Remove leftover "salt" reboot method in configuration example file - Replace deprecated std::mem_fn with lambdas- Migration of logrotate configuration to /usr/etc: Saving user changed configuration files in /etc and restoring them while an RPM update.- Version 4.0.1 - create_dirs_from_rpmdb: Just warn if no default SELinux context found [gh#openSUSE/transactional-update#88], [bsc#1188215] - create_dirs_from_rpmdb: Don't update the rpmdb cookie on failure [gh#openSUSE/transactional-update#88] - Handle directories owned by multiple packages [gh#openSUSE/transactional-update#90], [bsc#1188215]- Version 4.0.0 - Last minute interface change: Changed "List" method of Snapshot D-Bus interface to return a map of properties instead of a comma separated list of strings; this will allow retrieving the snapshot properties even if they contain a comma in their value [boo#1202147] - Remove "Snapshot.hpp" as a public API for now - all public functionality is part of SnapshotManager.hpp - Add header file documentation for SnapshotManager.hpp - Add method to delete snapshot [gh#openSUSE/transactional-update#52] - Allow setting description of snapshot [gh#openSUSE/transactional-update#55] - create_dirs_from_rpmdb: set SELinux file context of missing directories [gh#openSUSE/transactional-update#84], [bsc#1197242] - Fix broken logrotate due to typo in config file [gh#openSUSE/transactional-update#87] - create_dirs_from_rpmdb: Fix handling return code of create_dirs() [gh#openSUSE/transactional-update#86] - Fix broken "shell" prompt after selfupdate - Add documented D-Bus interface definition files - Add tukit_sm_get_current and tukit_sm_get_default to C interface - Fixed typos- Moved logrotate files from user specific directory /etc/logrotate.d to vendor specific directory /usr/etc/logrotate.d.- Version 4.0.0~rc4 - Fix building with GCC 12 - Fix stack overflow with very long commands / ids [bsc#1196149] - Use separate mount namespace for chroot, allowing overwriting the bind mounts from the update environment - this could have lead to data loss of the bind mount previously - Fix C error and exception handling for snapshots- Version 4.0.0~rc3 - Add Snapshot interface - Reworked signal handling: All public signals are sent from the main thread now, keeping the same sender for everything - Implement D-Bus call "Execute" for Transactions - Implement interface for listing Snapshots - Implement Reboot interface - Fix bug when using --continue on old snapshots - Fix hypothetical integer overflow in snapshot list [bsc#1196826] - Fix wrong sort order in status command [gh#openSUSE/transactional-update#80]- Version 4.0.0~rc2 - Fix missing prompt in "shell" command [bsc#1196580] - Add output of tukit commands to log file - Fix compilation error with GCC12 [boo#1194876] - Fixed (non-critical) security review comments [boo#1196149] - Fixed selfupdate - Code cleanup- Version 4.0.0~rc1 This release is API, but not ABI compatible with previous releases; existing applications will have to be recompiled against this new version. Major features: - Introduces a D-Bus service to access the libtukit API via the org.opensuse.tukit.Transaction interface - Introduces a C binding via libtukit.h. Other changes: - t-u: Rework --quiet handling to make sure no output is shown even in error cases; this is necessary for automation, e.g. with Salt. [gh#openSUSE/transactional-update#73] - tukit: Allow storing command output into variable by introducing a new optional parameter for "execute" and "callExt". - Replace multiple and non-standalone occurenses of {} in "callExt" argument. - Split transactional-update.timer into transactional-update.timer and transactional-update-cleanup.timer; the later will clean up old snapshots even when the system does not do automatic updates. - tukit: Remove legacy alias "setDiscard" for "setDiscardIfUnchanged". - Throw exception if snapshot is not found. - Fix various compiler warnings - Update spec file: - Include tukitd D-Bus daemon - Only install one version of the library (as there are no breaking API changes yet) - Add %pre scriplets for systemd services - Replace %systemd_postun scriptlets with %systemd_postun_with_restart to satisfy rpmlint checks - Add transactional-update log file as %ghost file- Version 3.6.2 - Bind mount root file system snapshot on itself, this makes the temporary directory in /tmp unnecessary; also fixes [boo#1188110] to return the correct snapshot's working directory via API call. - Use separate mount namespace for transactional-update; this should fix several applications that fail to run if a mount point has the 'unbindable' mount flag set- Version 3.6.1 - Fix rsyncing /etc into the running system with - -drop-if-no-change [bsc#1192242]- Version 3.6.0 - Simplify mount hierarchy by just using a single slave bind mount as the root of the update environment; this may avoid the error messages of failed unmounts May fix [boo#1191945]- Version 3.5.7 Various fixes affecting Salt support: - t-u: Don't squash stderr messages into stdout - t-u: Correctly handle case when the snapshot has been deleted due to using --drop-if-no-change: Don't show reboot messages and avoid an awk error message [bsc#1191475] - tukit: Make inotify handler less sensitive / ignore more directories [bsc#1191475]- Version 3.5.6 - tukit: Add S/390 bootloader support [bsc#1189807] - t-u: support purge-kernels with t-u patch [bsc#1190788]- Version 3.5.5 - t-u: Use tukit for SUSEConnect call [bsc#1190574] Correctly registers repositories- Version 3.5.4 - tukit: Fix resolved support [boo#1190383]- Version 3.5.3 - t-u: Purge kernels as part of package operations Required for live patching support [bsc#1189728]- Version 3.5.2 - tukit: Fix overlay syncing errors with SELinux [bsc#1188648] - Don't print message for `shell` with --quiet [gh#openSUSE/transactional-update#69]- Version 3.5.1 - t-u: Disable status file generation by default The new experimental `status` command requires the availability of /etc/YaST2/control.xml, which is not present on all systems. Hide the creation of the corresponding status file behind a new EXPERIMENTAL_STATUS option to try out this functionality. - Increase library version- Add tukit.conf to spec file- Version 3.5.0 - Add alias setDiscardIfUnchanged for setDiscard. The old method name wasn't really clear and will be removed if we should have an API break in the future - Replace mkinitrd with direct dracut call [boo#1186213] - tukit: Add configuration file support (/etc/tukit.conf) - Allow users to configure additional bind mounts (see /usr/etc/tukit.conf for an example and limitations) [bsc#1188322] - Add 'transactional-update status' call. This is a POC for obtaining a hash of a system to verify its integrity. The functionality is still experimental! - Internal bugfixes / optimizations- Version 3.4.0 - Apply SElinux context on /etc in transaction [boo#1185625], [boo#1185766] [bsc#1186842], [boo#1186775] - Implement inotify handling in C instead of Bash; this makes the - -drop-if-no-change option work on SLE Micro [bsc#1184529] - Use `tukit call` for up, dup and patch to allow resuming an update after zypper updated itself in the snapshot [bsc#1185226] - Fix obsolete output type messages in initrd [boo#1177149] - Make different base snapshot warning more visible [bsc#1185224]- Version 3.3.0 - Add support for more package managers by bind mounting their directories - Support snapshots without dedicated overlay [boo#1183539], [bsc#1183539] - Link RPM database correctly with older zypper versions [boo#1183521] - Don't discard manual changes in fstab [boo#1183856], [bsc#1192302]- Revert inotify-tools dependency: The package is not available in SLE. This will probably have to be implemented as a native C version.- Version 3.2.2 - Don't skip patches with rebootSuggested flag [bsc#1183442]- Version 3.2.1 - t-u: Forward --quiet option to tukit - Regression: Add /opt as bind mount into update environment - Remove output indicators of the called command to not tamper the result line - Fix /etc syncing with --drop-if-no-change- Requires inotify-tool to have --drop-if-no-change available- Version 3.2.0 - tukit: Add new command 'callext' to execute an application while the snapshot is mounted. '{}' as a parameter will be replaced with the path of the bind mount. - Fix --drop-if-no-change [boo#1182525] - Check whether self-updated version is executable (e.g. on noexec /tmp) [bsc#1173842] - Fix overlay synchronisation with SELinux (again) - Always overwrite supplemental files (e.g. for network configuration) even if they exist in the snapshot already [boo#1182544] - Improve logging and error messages- Version 3.1.4 - SELinux: Fix syncing of SELinux attributes when using overlays - SELinux: Tag the overlay directory itself (again)- Version 3.1.3 - Fix overlay syncing on SELinux systems - Fix resuming transactions where the parent does not exist any more- Version 3.1.2 - libtukit: Report when application was terminated due to a signal, and return the signal number as a return value. This will cause the transaction to be aborted when called via `execute`. - libtukit: Set PATH variable for internal commands to fixed value to find the helper applications, as in some environments such as PolicyKit PATH wouldn't be set. - Fix compiler warnings- Version 3.1.1 - Fix hang in tukit on aarch64 [bsc#1181844] - Prevent deletion of snapshots when resuming a snapshot where no transaction is open - Make tukit work in non-dbus environments [boo#1181934]- Version 3.1.0 - t-u: Support installing RPMs from the user's directory again - Adapt selfupdate to new packaging - Implement signal handling - Remove empty text files- Add libselinux build time dependency - Remove RPM version check- Fix libstdc++ filesystem ABI incompatibility by using newer gcc version on old distributions. [boo#1181582]- Rework packaging based on Fedora packaging to separate all the components to remove the intrinsic requirement for Zypper- Version 3.0.0 - This release changes the internal structure, but should be identical to the previous release feature wise. - Major parts of the previous Bash only application have been rewritten in C++ with the goal to provide an API around transactions; the transactional-update script is using that new interface internally already, however the API should be considered experimental for now - if you are interested to use it, please notify us in https://github.com/openSUSE/transactional-update/issues/52 - A new tool called "tukit" provides a C++ tool that can be wrapped by scripts to leverage the functionality. Please consider it experimental for now, the commands may still change. - Bugfixes: - Implement support for system offline update [boo#1180808] - Add statistics files to update environment [boo#1173282]- Version 2.38.3 - SELinux: Make synchronisation work for both pre-SELinux snapshots and later snapshots; SELinux support should be ready for most tasks now.- Version 2.28.2 - SELinux: Exclude security.selinux attribute from rsyncing (again)- Version 2.28.1 - SELinux: Fixed changing the wrong grub configuration file - SELinux: Move /.autorelabel file to writeable location- Version 2.28 - Add 'setup-selinux' command for easy setup of a SELinux system - Allow complex commands for the 'run' command - SELinux: Fix /etc / overlay labeling- Version 2.27 - Add support for network systemd-resolvd network connections in t-u environment - Mount /var/lib/ca-certificates read-write to prevent SELinux error - Prevent calling transactional-update from within transactional-update- Version 2.26 - Fix broken sync for second snapshot [boo#1176989] - Add new options to allow separate cleanup of snapshots and overlays - Check for existence of inotifywait before using it - Check that mount options don't exceed maximum length- Version 2.25.1 - Fix inotify watcher setup - Use log_{info,error} for more messages to avoid messing up Salt logs- Version 2.25 - Reduce number of overlays: Instead of using transparent overlays for all previous layers only add the previous snapshot's overlay; this will greatly reduce the number of overlays while still making sure that /etc changes in the running system will be visible in the next snapshot - When using --drop-if-no-change synchronize potential /etc changes with running system - Exclude all non-root-fs mounts from inotify watcher- Version 2.24.1 - SELinux: adjust labels for etc, fstab and grub.cfg- Version 2.24 - Add partial SELinux support- Version 2.23 - Add "run" command to be able to execute a single command in a new snapshot - Add "--drop-if-no-change" option to discard snapshots if no changes were perfomed (BETA, required for Salt integration) - Removed previous CaaSP Salt support (gh#openSUSE/transactional-update#33) - Avoid "file not found" message on systems without /var subvol- Remove unused attr requires - Change bc to file requires- Version 2.22 - Use pkgconf to determine installation paths - Enable SSL connections in update shell [boo#1149131] & [boo#1133891] & [boo#1192078]- Version 2.21.1 - Rework error messages on failing umount [boo#1168389]- Update to version 2.21 - Use slave mounts for /proc, /sys & /dev- Update to version 2.20.4 - Mount efivarfs on EFI systems to make sure the bootloader will be installed correctly [boo#1162320] - Fix removal of existing overlay directories- Add dependencies to btrfsprogs, zypper and snapper - most of the functionality is not usable if those applications are not installed. [boo#1166502]- Update to version 2.20.3 - Reintroduce compatibility with RPM < 4.15 for inclusion in SLE / Leap 15.2 - Prepare for removal of /var/lib/alternatives [jsc#SLE-9101]- Update to version 2.20.2 - Use full names for zypper options [bsc#1164543] - Ignore /var/lib/rpm in shadowed file output - Optimize create-dirs-from-rpmdb- Update to version 2.20.1 - Add missing documentation about --continue option - Avoid error message about missing fstab file on first snapshot creation. [boo#1160213]- Update to version 2.20 - Add the option `--continue` to extend an existing snapshot. This can be used to perform multiple operations before rebooting into the new state. [gh#openSUSE/transactional-update#16] - Make sure the dracut service to print warnings on /etc overlay conflicts also runs in the pre-made images. - Add "none" reboot method - Remove conflicting overlay artifacts in case an existing overlay directory will be reused- Update to version 2.17 - Provide network in shell on systems where resolv.conf is pointing to /run directly [boo#1151081] - Print new snapshot number at the end - Always mount /root subvolume when using shell command to preserve history- Update to version 2.16 - Use default command if options, but no command was given [boo#1146116] - Make sure only one process appears in `ps` output [boo#1111897] - Move update check: If a new repository is added (and ZYPPER_AUTO_IMPORT_KEYS is set) adding the new repository key won't fail any more - Avoid unnecessary snapshots / reboots by detecting zypper operations without changes more reliably (e.g. when installing an already installed package) - Update the manpage accordingly - Bugfixes: - Ignore commented lines in fstab when checking for shadowed files - Avoid warning when copying network config - Remove Perl dependency - Building documentation requires Python 3 now- Update to version 2.15 - Move description of interactiveness [boo#1132438] - Enable network during update [boo#1137890] - Add compatibilty with new overlayfs versions [boo#1140057] - Allow updates of the bootloader on EFI systems [boo#1139015] - Add support for /boot/writable [boo#1138725]- Update to version 2.14.2 - Prevent unnecessary error message on systems not installed with YaST (e.g. KIWI)- Add requires for bc, needed for some calculations- Update to version 2.14.1 - Improve non-root fs changes checker based on feedback - Disable snapper's zypper plugin during transactional-update run - Allow parallel installation with snapper's zypper plugin (useful on read-write systems).- Update to version 2.14 - Warn user if contents of /var have been changed during update - Noteworthy: swapped position of upperdir and lowerdir in fstab for better readability - Major update to the transactional-update guide- Update to version 2.13.2 - add hooks for telemetrics- Update to version 2.13.1 - Bugfix: Clean up empty /etc snapshot directories again - Use official release files from GitHub for building- Update to version 2.13 - Fix a serious data loss problem (deleting all files in /etc overlays) in case /var/lib/overlay/etc is not part of any snapshot any more. - Avoid error message in case a system has no /etc/fstab.sys- Update to version 2.12 - Implements support for needs-restart (Fate#326451) - Adds easy rollback to last known working snapshot by using "last" as the snapshot number - Migrate /etc/fstab.sys entires to /etc/fstab for systemd being able to create mount units; this will prevent errors on unmount - Remove implicit --no-allow-vendor-change - this option can be configured in zypper's configuration file now - Add support for mounting the /etc overlay file system as a systemd unit in /etc/fstab on a read-only system (replacing /etc/fstab.sys in the long run) - Various bugfixes: - Only remove /etc overlays on read-only root file systems [boo#1122455] - Disable "Persistent" flag in systemd timer unit to prevent updates during or immediately after the boot phase - Don't set global zypper options during migration - this is not supported by the migration plugin - Fix error handling when interrupting while rsync is running - Filter out security.selinux attributes during rsync- Use noun phrase in summary.- Update to version 2.11 - Update man page to explain new /etc overlay handling - Add special handling for migrating away from old overlay directory - Read default update method for systemd service from config file - Add package "transactional-update-zypp-config" to prevent accidental transactional-update uninstallation on transactional systems (boo#1111319) - Use "up" for systemd service on non-rolling release distributions (boo#1111321)- Update to version 2.10 - Introduce /etc overlays - Each root file system snapshot now has a dedicated /etc overlay in /var/lib/snapshots//etc - Changes in older snapshots will be visible in newer snapshots (if the file hasn't been changed in both snapshots), but not the other way around; this makes it possible to roll back to a previous snapshot even if the configuration is broken - The /etc state of the oldest active snapshot will be synchronized into the new snapshot to prevent ever growing overlays - Removed creation of /etc backup snapshots - Removed complex overlayfs cleanup handling during dracut early boot; only thing left is to output a warning if files have been changed in old and new overlay after snapshot creation - Unused overlays will be removed during "cleanup" operation - Add compatibility with snapper >= 0.7.0 - Correctly detect BTRFS ID when using multiple snapper configurations - Fix disappearing prompt in "shell" command when application was updated - Prevent accidental rollback on fast reboots (boo#1111786) - Use zypper attribute packages-to-change if available (boo#1105992 & boo#1097619) - Add kexec as reboot alternative - Added explicit --with-doc / --without-doc build configure opttions for enforcing or excluding documentation build - Removed precompiled documentation (boo#1088676) - Added more dependency checks to configure script - Small improvements to documentation - Restored compatibility with older rsync versions not supporting the -x filter - Small bugfixes for cleanup in error situations - Fix possible incorrect detection of snapshots numbers during cleanup - Mention parent in snapshot description - Add dependencies for documentation build (boo#1088676)- Update to version 2.6 - Add --interactive and --non-interactive options to change the default interactivity for zypper calls. For previously non-interactive calls (e.g. dup) these options makes it possible to pick the correct solution in case of conflicts or make sure that a script will never be stuck at an input prompt. - Add kured reboot support - Tries to clean up temporary files and mount points if transactional-update quits unexpectedly - Remove trancactional-update-helper (replaced by zypper options) - Create /var/lib/zypp if not available (boo#1104452) - Robustify parsing zypper output (boo#1105992) - Various small fixes - Changed permissions of systemd script again- Update to version 2.5 - Support for overlayfs attributes like trusted.overlay.opaque - this will avoid disappearing configuration files on system updates - Documentation update - Only sync /etc if it's on an overlayfs mount - Use correct locale for zypper - thus updating locale specific packages and avoiding "empty" updates where transactional-update didn't see the change - Add dependency to attr - Fix permissions of systemd script- Update to version 2.4 - Bug fix release- Update to version 2.3 - Reformat help text / synopsis - More detailled output (use --quiet for less output) - Log all error messages into log file - Avoid potential lock file race condition on self update - Accept package names with whitespace - Don't wait for user input during self-update - Fix broken error message output when creating new snapshot without reboot - Fix erroneous mounting of stale grub mounts- Update to version 2.2 - Fix security issue in self update [boo#1091316] - Create dirs in /var more reliably by sorting the list - Rebuild initrd (needed since 2.0)- Update to version 2.1 - Cleanup the code cleaning up /etc- Update to version 2.0 - Create missing directories from rpm database during boot - Merge /etc overlay with root subvolume during update- Update to version 1.29 - Implement self-update - Disable optical media on dup - Ignore certain zypper return codes- Add conflicts with snapper-zypp-plugin- Require perl-HTML-Parser (needed since 1.26) [boo#1085764]- Update to version 1.28 - Adjust for latest grub2- Update to version 1.27 - Fallback to snapper without dbus support if dbus fails - Add workaround for update-alternatives - Add support for /usr/etc/transactional-update.conf- Use %license instead of %doc [bsc#1082318]- Update to version 1.26 - Auto accept repo keys config option - Detect broken snapshots after abort - Ignore user deleted snapshots - Include all error messages in main log file - Add configuration file - Correctly implement migration of major OS versions - Default reboot strategy is configuration option - Salt option is deprecated- Update to version 1.25 - preliminary SELinux support - support for seperate /var subvolume- Update to version 1.24 - Don't save unused snapshots if we may delete them again. Partly fixes [bsc#1071038] - Copy passwd, group and shadow to /usr/etc if modified- Update to version 1.23 - Fix re-registration in rollback case - Fix problems with updating the grub2 bootloader - Add support for migration of products with SCC/SMT - Re-add support to re-write bootloader [bsc#1068933]- Update to version 1.22 - Rewrite cleanup code to be more aggressive- Update to version 1.21 - Reset salt grains even if no update was found- Update to version 1.20 - Improve documentation - Add pkg update option- Update to version 1.19 - Add 'shell' option for debugging and testing- Update to version 1.18 - Auto accept product license in non-interactive mode- Update to version 1.17 - copy modified bootloader config into snapshot - unit file cleanup, no change of behavior- Update to version 1.16 - internal changes [bsc#1045942]- Update to version 1.15 - Rename option ptf to pkg - Add option to set salt grains- Update to version 1.14 - Fix check of return values of commands in pipes [bsc#1034900]- Update to version 1.12 - minor bug fixes- Update to version 1.11 - use --no-allow-vendor-change with "zypper dup" - update manual page- Update to version 1.10 - implement and document rollback option- Update to version 1.9 - fix umounting of special filesystems and subvolumes - fix interactive installation of PTFs [bsc#1023026] - fix dependencies of systemd service- Add Requires for lsof and fuser- Update to version 1.8 - fix references in html docu - build kdump initrd if we build standard initrd, too- Update to version 1.7 - build html docu, too- Update to version 1.6 - Add support for kdump [bsc#1018098]- Update to version 1.5 - Install PTFs in interactive mode - Sync state file between current and new snapshot- Update to version 1.4 - Fix wrong error messages - More debug output if umount fails - Try a second time if umount fails- Update to version 1.3 - Add initrd option- Do some spec file cleanup- Update to version 1.2 - suppport ro-subvolume with overlayfs- Update to version 1.1 - bug fix release - implement lock- Update to version 1.0 - implement and document PTF options- Update to version 0.99 - Support for rebootmgr - Write real manual page- Add empty directory /etc/systemd/system/transactional-update.timer.d/ so to make it easier to override transactional-update.timer entries.- Update to version 0.90 - Finish normal options - Implement support for PTFs- Disable restart on update for post install scripts- Implement activating the new snapshot as new root filesystem- Initial version/bin/sh/bin/sh/bin/sh/bin/shgoat08 1683130307 4.1.0-150500.1.44.1.0-150500.1.44.1.0-150500.1.4 transactional-updateetctransactional-update.conftukit.conftransactional-update-cleanup.servicetransactional-update-cleanup.timertransactional-update.servicetransactional-update.timertransactional-updatetu-rebuild-kdump-initrdtransactional-updateNEWStransactional-update.txttransactional-updateCOPYINGtransactional-update.conf.5.gztransactional-update.8.gztransactional-update.service.8.gztransactional-update.timer.8.gztransactional-update.log/etc/logrotate.d//usr//usr/etc//usr/lib/systemd/system//usr/sbin//usr/share/doc/packages//usr/share/doc/packages/transactional-update//usr/share/licenses//usr/share/licenses/transactional-update//usr/share/man/man5//usr/share/man/man8//var/log/-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:SLE-15-SP5:GA/standard/ca17255e3778f6783b6ed44c65a94c3e-transactional-updatecpioxz5x86_64-suse-linuxASCII textdirectoryBourne-Again shell script, ASCII text executableASCII text, with very long linestroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)troff or preprocessor input, ASCII text, with very long lines (gzip compressed data, max compression, from Unix)cannot open `/home/abuild/rpmbuild/BUILDROOT/transactional-update-4.1.0-150500.1.4.x86_64/var/log/transactional-update.log' (No such file or directory)RRlyfك b-inotify-toolsrebootmgrtukitd4.1.0-150500.1.4utf-8f9301f937b75607a07b4024d7d742ac2b5d167a946658dc48974d6b648cb5cbe?@7zXZ !t/7}] crv(vX0"YCM)| 6ՔU3>ߴNx-pj]hxLlRV뺴+ LO*̓87M'%"l{LCύ

6,[aL&[jqTCh8VCwI*L!Xet׾FҊd=P5ȼ#A!.-OWxB>jcBLt͔ z<+Ϸ#`a싲]wX-?[!TFoSP˶f|e-uŠGƬ9@0܆/)TqRW>ƙ 둜Vc{s?,oGv[8Vћ`[A(J8vAA "L tHMk]AeȰʠ)lcy'&Q#d~Ahp0FF^_Fǡ3I.3Iƀ VWښ!bÛ:ӪSQnRAZ!\۳ 1Sek8@]*_$E,CRI3L[y4r40BSC6GrzБo_l&}E2sZQ.ι8#w5R%v_d@yG-$T0X׻D,̰()yL5Ө k@Qr_ sP0̖wVc*jȺ8G=09:JS똛 w-L3*!#yd0;j2=eF߃U^ ̏ |PeypSGA+!^ (V`Dk7lElŢU%B}vW7XNPvYEAX`1%뗛:Ю͏qn׊eǟ/.{^4 1u9)eCѓW{~Ngߏ)l'$9v/ƃj+mPfc-;E5\mD\t(x$7IU#6mq|} Uzih^޲E $_O e6. Ĝ0(r zXCbgz9s 2mEt#+-Gl,PwJ<|,"{ĭ{Fڌ6 PQ/BlbqXxjk9ScmTfRX'<Ð˿ c,_,{D[_.蘝֥`` uCYaH`6us+ϧ&1 lC :sʨ')P']d$A_%>mXM `VI.Ug{޹4z´JGت/5 Kc!x炊>c%m'p]3ӝ҄72,!5 MS+=Ovk#BRYK3G̓z!N`YMGt@4d4Jˤ*,%!bD^s`d4F'G+i*D\4MDT+p"9B]K< q,=<ʥgun朳)ГK߭|d'9ɽ 2 1V04 0싛S'אvaZՋ.z-k-zhlep'(=Ɯ?~?Npˋ |ɖݒAӬwسhs hHVI[v NkF5k|jZɮ'Jp.\\,0zZcvÍ%K.o%(˟%Z"̔=DSrO&R`4{!fi |C\$mg>X,s j쁗;fg~?ئaqhA.R5ПDpuGw u \1K@(_*w~.K5f`JEB0 0.rKrP|CZئ&7[gaGxgJ$H&9C*wVmv =ݗ)"-&Gc-75o6j;<>wAU\4{- +\b}p+'Hwh**_\ba>:\2AvA=[l=44W8)uxL*z>_M+ǕU?< i+ʠ#"ʩ2dzYI4)){s;Ou_hV5`hyf.7h`pP !(VʧG"\q%9Yt~!<}c`[Tu.,Q'|`> G,]Syt'do.b6mzksQe:&1q莌(*=﯀zL C0@-D{)ub|]"pi;TKGccrWhvC>L^3 :x { ==y+ ϕ3qz6#ȞD|`*t8CCИ =^񸬝,Xqmxp묏WӺ-1ΜLw։sl*c0Ė=[1Q 8s5g Yq>n iJsM |>ήy}OY#MZ7{PV4jk?aH~,&ݭ@~PR|'g`q_5QZK'R6Q4F=(:LʬC 0V]ݚ%GC~nH}N]=udFqX>~WL_?5O^d_ 0BI'mfu' swRQ>e=" 2%T…2v3iX(/y>JJOFBJ9QʀQX+Sp3RNRT p!(Y_hHwg'/ ;w3E6E;%0 8z0KL4պ "NR=cBM*2JH0}'ǂ:rNw.p&DPiI  @5`X⿋ vKgl!dGd_-$`J3X1etRס&>oD뢀p1W혛c!ORWv # @Rٻ-LޜLzڦuBOz(sG: B(iGEM?mm3pn|KcPCptYn$?I h^V)٠Ԫ4 Y^h3?UrIZK}Ex0 wy;ZnTUWEILB*TXқ1\F6|Mėuqj1`:M˔ok TL@.LWqӧ 8É954Ry4uiT%Rȁ# <:Ѻ}Uf JgÕl=A&1 *QTuU-R-AxaYUu6.QaEj̮@: ҜA"c6ղ )`o0 7/\Qӗ ~UXYC@Pk=u58av\8!76˦Q6JʴrXD-[ɽ$GmU>Җ}paw3?xm><4Pq 륥Y n¤f8,oC+e 7n4јFY:k&P(&W (;*?`cZ8fmT:qjZiQ cx F6!bt0?_~gv!E0k+[!D;`ȍySwFVe!."y0A=O,8.Xqc)Ѹw Pm32cCvvwxXEJx xBj;}Хnݶ@D*y\FO̳X_tJ}m_ܽ ;}l(Kw݄gpQM0=V*N5xM9O5*--rF;qb i=%@}U);d3<2adi N Y1}qzڗ4yWn+ߚ O-/Wɀ|ZO/QQ[d3$& Id47OFB${4NW^"1)ohp1n~^/{ ! bG[qVk?pnكZ,w4:)U^ a - %$]׶^4MWG{*A#^h$Z~KvbpUм',[̐pQ4BN9 {Ta`$2ۭCs+<&^,Hi Q!@i_ʅ.s4'?d/l0RMd d $r70tą!=tJXE*c j\ӷ$q2@uudL kEi ,),+?g#7CF}[:5͢YϾgeĒs#ĢxEPƐώ }}t8F)M:mF][9 V;L`b.mĘx~R>M#zw62}:cK4*,mK >>'A*/$Gxd#L)@ٕ|2rXWr_>jRl.:&DhQ^ ya)_Ij0QRa6'l)ʋT%B7,fx҂>s^_( ,RbKe=Lxڒ13ZFS0%ӌ> 2ͧ3.r\O]Q&ܮuw]uU FGl'?"J4'#˃)& !'=&`/۷\#鿳?H=36>=B2; !U-= 0n c>-T хs=+֌wLoնWltM| H&wmA2A+$YՎMꧢ^1NmpNԽxꖴ36 [G .)>2j]qoqY佡안INH ?=b>ЬAx1)DPnjӌ6\5Z0ƇHcVjTǾ*̟h b-9`ݺ櫄V'FMEK+ZxrZ"2Æ}o<螬Z8zZHpjĘW`tPa%Ol?ȩy^$0=IUaH}#.6ţ Rk /Srx׈͉M6rq\Y=(;0sIn2`FE#%)E6+ eSn)GA/vS-mO VSB <0(EZI]m*Q}Q[hp2;:N!pb_6":l#S BE` ;LkNK$Rz&ZB)koh}qVq-KaOo썋:"c'x#3j@Z W.ja$k+>e44: =OH8 LiZ}-9N>#qH3Q7BfϾ˥v-7| ;ڎST!&%ŏxШl7AM ly\G m*^ t[EȭF>+Z]t |kv&ߋ]fX2u6:g3)=03")6 R զm*gMaHT& ;0.vz s>J ϋ@7= F\[ PQ3#U0+ .8;KG^xM Sه XΕ nRxt̊ %U+ؔo9MA/!sn܇2+K]鸭*0P+h~LBAt8KM9]YD/!vUGJL RB}P 4~$BQ3841)=|VIHv,n,.1K&k0L|5 lh=6pInCaq[{C!mA|rW&)VRGoIE4=H!8e?}?&I~i~U:8D'A0 :w6y? C(-AJz?u2`Uآq,*L:z],=Yv *+^w3 PC{>@j&5KZp&i^(F >r P8Xu 7gȈY6Awo{)!/`V&,|ldCeqnu>I'Hi7q;J ѴLM^z#<r_ x8+5"ZHjvK@ @HUIOo6?[ٽ=tCnW(>;ib#^iSxm<[#9 otĶ'g xJΆ'od cq/l.o}5_k+gCo`N0FMZ2a׻LX+ir;=ӫkO+J8n?- 2 q; ~Ujw8Q&/ޥSQ%I3$P^{=ڏE7q qWh fSIl\64kn˜'ʊUl1YSGe Fw;)ϛIVBJr8!7}-= + ( ব鿣2fEK)A(__ɫbrƻuWvR您MkY@? 3_pK($qGUbU@|P3Pd~}cW>{z;}i˄w=W|}X󰓐L?ۊؐcט̌F^5ht ž(:<ƆUIY"S>{A[~/ NXsז^GY2ZMu5f*)>&wY{FACVMŶeWF߳YH >6u^mcZPFTS&"bVB0h>&:s~7\.T O 7kȘ-G2ڲh?9*?hLrQrx;dfP(%oDj:E'>r@$l f>*b#~S5ҴSQWq?lL S ~5(ŏE.|2@XTlVbS7VQI]Q!}t}Ȑg_lR0w^<1`>v (!oE9G:HLR\}ooCT0.;lHН&<}p tsٰePOU^eP|E A$;0ht%L)F#t++6pҪ%aN}O}<3^dsbO~gs8A9n18z_5S{nՅqa!{)0@cI ;[=Xjg`/7ثv*u}>lz jI^9(O櫮u>"*)iW(n_cAxPUA+p$ i p7d>ĂPkJ(|d;uNPgu?b>Y?3'qfǶc-xl-3I#M(K)+$6&5Na/Ƥ1 97@:V3u.5vwUi>*LD&ۗr58+6bRV::pBalz$˫t7%0Ne\=3CRݺIJ۝(Pʄzk&GN.jfȐ,}"U*eKy&hOy[bۥ9vQoT#ݟ e+4ݺ[\2-vp/8R^4uEѠjWN\A~:rg18*ϥ_LܿE#M:\(|w |y;`s3 a1* uw \_z(y' :&,KQq5@э Qz UH~ґ$v"Qs|ɵJVrokWք5@+GNDCg,el5Kۤ^;9"@tHsPzy^7%]PN“| )4+aN/\ȰQgIh$^F#=ɇΒwܵ{NkrwK3]ڽL\4xzҞsVVQx5É3I[,`qb|ɌHPn81KQ-9̌\]D|K}^'>Ɲg ZJP}sb *w!pa˪9ἜX}[ hQ}<IJ:ooٰnh}rŬr0DQ\ y;fFXdJ~C, m3ENWa@M;0h C~]~$ݶ_[n$d<y.%B->54Ű˝ʸ2*h2L)Lv%MJ"tÓ+ $t.p|1N>KЬ{RǮo1ƺf֒"W ffcY +z8TTߚ(# dֺY0Ve__ӅQj9X~vҰS3ObhݟX$at1h&G["IvA/AmH8~YtOH7eN_'`m[GxƜ}H揕 ז*~H>/eEH_' FH1@ :z5"$%[?_0YnʶC$|AEr(kBT5'cN-JPj#ڎUv5Da%VbF6|UeLՀ[K_KíQdΔ(?TOoWK ]ݼQ'ĸRV]JV?ap(\q49C vVn#dОI5 >.U8_Ԁ͍+WhI̼Ah[xlfJ4QD;}s cM"3 S@!CrѭC.Pve$LxRA "hB} @flo~TA/*tlKձOUK5Z3FO\֘^! " ~p+%캞"r= 65̱zj5<~#[Mq,]oP063 F[H;Tvܝ6x[d۞=tzakm-aZчs0%@ .XmQR"LNo[r9 Hb;â. ~dm "4X[MWڏYeV.Ic, ^Dw3(bc[BVd@&RM cs٨E'r@`x6Oam$䗊iᘊ %!r>}V^.7+K&F 9B m| sXj5up 꽕A8헂 Ze)2Hqlq?l3Ҥ*:äE=;Zqjnsf,9OL<"겇[sk %AJ<;Nsy3P>տ]_ x1Yx&ʁ5y}3؂}Iv˘h;&`ggّW_b5sl6Ixj,]Co2>[zxa U/K\ ĩ+u&'6ꊠql'GDGN0\m3$ڊ%Gw45k[Kf/HUmAA1U{uAỜ~mgi"k|tkwxNbDK#T-1>c(H,bG@yh?V$a@$T]ѺM(9aX,&SG@Ct ӍץŮAgyC8)Y+!D|͊ҫj"hX-N!rXX zOGVK s`4?&!@@0n{ Ǖ?Yv s%srTjQ4E lq>Y7TU%IISsy- " '╭ei=0g1bZcQxv[2bxV'1t9u*~ޅLERG2:IH{TOu_V\g5}$pɨ*4u⫶KrX m )hxmlh5,;xXDW1A+Ac|R&™d⷇:XsX09Ҙכعd'0_ zo_Vf3:N'8_tPCp@〼FT^Zv`^>:gDٺټ3lt֪ԣ=93ofQŚ },Zyj[O^FxE:6vOᔉҍ߽3o:Js#v`*l]I#_0ܺALIl1tuCihjB ?Hё,)fLp.G&}NadYί zd9$%0}Yr#4؊AV;]Xuԩ-B+-{v>z3ÇjI3KG&l(o?eA% V^vFRǔxh,J#Њ26lְIڪ!B J;lJ>`2)2"EDFqW#d B{ާ8>DԼg%&1Do$­Gmǽug+d^` f=Ii[5=BTK\': ƳhNH i(_ܥF8ƖvWO$ȟo]]'?Q7DX iĈ[߂km |41E:dTlm}j8j8Hʜ 129%#cHi*nE;-sl/i8x0|Uuq}<'IvLۼ{Nz9b!.xKykAPY h:Fn2 weaQ<( UN3I*CK~>@Ca/Dw߻n=ꍫPEtPx臤>2T`>8 })0/U½tzۂ ;u8Z<9X@F -y{VȾxQƧUi;uC2 |݂eE2@tz7V8h^x3}mwˉ߸I0\>HrAuBpkK- }B ѩQ:5e;*atIxގ'X< m-[Q:i7Ō|7ta0-ͿŰ'Dƛ(Jd jΙ%[؃^ O-֙`-:L{(=- 4člOlS +ў_5q׋Ēr9WSkgӼl>fUVR.qcv9!=92,,Teb9{I5Z6x%th<_2|F6B<"F֕e&jyE_.OuWϦWT"51ݘ;ޗNLÎC"O.\ lkV]H*ϼuUL )vzv={+ﵤP#) -lsY$1@^CWumb^8(*1 XJ"5UV IqQ# ٲl$$.:8<t Nyɸ7rrh|o2}%81e,~m>rȆ8s+Nn;%{ ,NQٔfȢ1bsL0ujM=ΖA˱ ̿\1-;\}JwQWn~2#y9eK1`Gݠdn1IW)AٴVMȝ0U*{%(]A}E V>66h泶=[vNHɫ'^%¥%KIMcLhlۑ/^H1PYߩv4lFR{#z)*{. $W 1WL"|sI0&BҺpW;(1|\`"hE2>@F߽ITb.qd;ncjpLdAW VJ:L,N9hGeYg\DvМ~"q ?xF󦍿?fئ6)_!U4 Xf3Gԗዐc >k~KxN<6 1/7A\cTrҴV:KyߺHv泬iZ!XsS^\L$%QEv֢+G-SdGs7Xl:bLg3V-΁za%oVtcu- lgDG=a2P+!O6FgHԞœ͆KmjpÞΆw[o>*7E$k'6yUB0pv"R3le jYˢkþx$N);+/Sc2"(vjuBRdNNcAnN={ҵ8ewhLR^_Y\[rOР^rók1߷JKC0B \͐!"/K5sل& "NpRK !S8y:P#C,7o&A J "njeV8eB޲z^+^ O > KT; huIe =`Yc8 4~u'2gcFJcBŴ5LX73*s.^F+ut"v e1I 6["PTY)4c籤t4 -VNR"aӪ9n93"XTsm}b=fT \ lZ tѱ !A^_xK{=T hLU]TZKe9)4': {{P!͋N-Zo?Mj= iSth:ؙ Ex kZ^ojE'c9P̞4c*24Ÿt2#EN8UfѦ9sfHl S#§ Ȭ&Jv*uo mߣSC%A' u- wnሞؙv ^1¹= xk{Q6Rq$M}gT5 1)Rtǧ Nq\obSREaSlA#[ӆ`.JN>pN;u8 8ܒb?L"a}|_[a =Tl,cU}-^ȿNpqٿTFm{fcY=ygU[O |v Px)L-@Ү*huU>; /tCJ>!085/TM0QN m G{ D/+-b$Q a KJI-ߚK]俽<ֽ-CjлwtOē XUsxKāzRW@2*)k^V襬u/fuB~AxS]䶘-,"Uc+7l'͎`+ ؇6GD|4_M*v]h'`5r8ByEXmlA<1f DKl kmO'i%˹ BV+a8Z{〜>:>U9hW`c1cͅs/'wɳ} b0wWS];͂j1 d@A&n:a8d T.7TQ@tpmO} 8R]m "̔'ՃepO,0>ga5hx#r7̛:kydAPQAlSSx 5 Pp to1`{?hy72umr]!d, 9F{5e`Lv40\stjuPlX rƂ Dׄb_r' iN}Y]{LR/Ut5KլOZ njRV^Б7gc t퇞1[Kv|< Kpj}(4h ϼ\Xt w$3rs*e=Bn 4*?֞G'1=pLVqYzV;مEGCnEs07ē;$z? S 0~{i>S*-5egt9Fq^}n;)N ]_*|JҰWZ5n[ )4/[+6oC6p(%v&=rD#W.Ao8Fh>G"_ ',7o0DK G"4tu 1ḵ O=t_2%@h7-+K@beZrOI~K=pj>-ku4V!c4bmߚ0NgZ ^><ݓ%Ty]ܨeԚ$;* nX|Q(f Қ6rఋdsu,myG,9EّPcRTB*Jx|1u4[<4°0^b& ),i#RsDbedFzzM+"cLʏzˀb=c䛵"B`hN+^Me=/o 506,sZH $'ul&q>$ "Jmq]S2ܴ}ס @#]&U ew W$ kRJϧ%A6gb2U0^ |w /0E[ ҸOoAM+_r%AD>N*UuH ޕ3M΀'5co{Wjw Al0dZ.X_?J a30Lɍ:ǥyH@ښ4Zh|G_>\- S~SrըM2D5G)O;Q[a }AR2ܽK{"Dt>uDBsc^ʖNmީxUIfv o+ܻ*xMΥCGT9c!䵳 Y t|, 13өIǕߊ S.}4K ?ˀ 2T@A_8%;Obꗐ|<^"a;t:SÓY%XDΟy񴢴pbd/v .eRLdRrZg1u1P %dV ` RWF"E`A7ɷ}v ðyU߅fT5X]gMEyN4I {k6eŋ`#hy6 T+lI@XՅFYC~~. ' IlXc˲DvCha¤# }tz((DUuS4$=< 4h%6G٧4g$D)*V| tExݦ=,6r`Ӟe;=1f"`/#VxF56yj}'&m%jKgalRtygg{ U~eQj tÔt@n)B}H5+2KU@fW X0$JŗjO'$uַ⡭ ỶUing1kxTɮ:DR>PnAufI+ce=([wbLi2ODynzto2 ݖ\RwusgHdKx(޽k %>RA[W89 }@2Ə9LCi9ͼ&K;;,7P>ikqnPY4P",WLʜxT<Ǯe` NY-|vN. ATDvQM o)n+7'[܎1bs1^IIAPCqبI<C0+k>BzxP0GN;>sMhċo&g; cÇpkwظ5:+b)ٗ0m_PJz8r?UV|Ů֖ʠ?1}Igc0v)8s{Ic3 j Og "4\eLRQs]u:"܄/3.(g.b`W ޤp ;P:tNI(|lN!DӰ xUh~v&aw8*'!5xĿWݎV"ͺ8U/ȿ:.,YTT 4c IJy #?mޔ"Ex 3ʡ\;M qwx~ptΥ4|48\)j6E!Uf^nyubGՕ!k-z|[:4A @ـ J=ҀۋȈXH\j= [FQǶ|64Z]t&sJ"sG^V)ǧL[A3%9 ZB}8!^"b%B#վڌ>[j2@CcS(ڿ|+Y$?(*irח[v:j$\l"Oqۃ =LQSZ@aT> tYcu^… *,r3N+iLz }tmE|!#cB>&50Ҡ3zӛ 4D=-C[>ʳCݔ R&ü M3}lpcϠ9CeU tIq$ ҽxccMi6p a'\=ՏkRn{-_Hm(FVZ_hdBsE/UR!0{^ /-ɼ6ac T3T n: ﮁ’X( &"o' kƬ*Y#=ۿ%OsQF;UV?Rs%b/ދwv')ٹeA᫗X6ڢ:W{!ݬiF:qKjshUX-}ZHNFސos-e  P#$H}"jA%Gh:mh4k b"L$pz.îU0}lnů(#v>Gрc_%ӝ\;͊j68{IO}M8Ʉa!A|{yU٭S1ֆB=(*-`uX^T~@qO9+NOK'?-)x_!Zu=ݖU!PO 鮺~t[54lwvCxzQ8 L)9}t}fx;q]gBO]$E n7{UF n$t3#LBWȟ.4!/;XJj *xgt/aI9]9N,⟌#9k=*V B;S\>Co -9Զmf WDu[~Kyɓf=M'dk4d!4fNn>O>2{DK6'N oz'A/b#o@CI_sl-0h>K h fK=!At]BmNbl0 94͎Zo}iT:j\61DYGK6[Ŏ Nh&[OEG6&l^M1Koqy姾ܱdFȨt{t{~4u n%e]6zAhJQb* vES(C@M^؆f@bގX~h3:|(.yWzYUNa9chF1DJkRLncŷn@.KW:OG@)Yk{%EkE9R.wï/YU9Z v9ǵ]S2 Qɑ.P`CWxY Il8WY+Fk%Ԕ{`2=wH!̗Qg헇|3ؓK*kj=8z͵I r6IlUaTqٞi(t&ؑ9&wcD2w{+?-Ka7,4!g\YP4BsP1zty{r]0 X|Isƫ^61jF>~O{8I+n"+ԄQhM'odC'ugḕ72{ULCH+;K@m1A#uoe.7Z-v;Ӥy$7cz6{k+=J9Sgf9@/Lq+Y'{rݍlڝ;kPު9+ѤB)]eFJ*G0.z@>S$$R+6ziF >#5"VN. Eg/ 3$}&^cUx"JFva~1' pexu&=M II,j`Hm_ߺ ZiAjB1T$Yy0Cx=O'Ps(F`3dǵ׵ N٨UC5X=cr})v Ws0S>[C $,fxtWuO;o|L}vU<_ݩц.Wo }"v5Nbk.U}-uLRyV?VсFVL5\.D-`6)Z$2/Ұئ }[Nռ7.HO"'˃(k~Y_^򐷎(EE~kd 7.9M&kpkPUFଣP0rبdF=U_ЁɧUhUS?b\qˆ-)6,ˬ_Z >{{a44(-n:ti֥p+IF%RRRӃM1^qOQ6Q5w$Fws;5 MNϤ>T%5dTb)GGf-JWuOFYSGpDH1: +QSִ˧zT6.c]%kAwcgr'*TQ\-QƆOA8z,=6wx>CAwمEAr<QBP%2B$:G5?ad RJ.$PX8%ޖ.`mx1_d(u [ p"CP~0cLAT%b5XT)8~6P $PmқM-_^xhCHil@ NPA*TI_l(fDѐݱ×\&J9xc USh^m> Jpp(pbbI2'ֳ[nbČ6@޲C|wbTȣ zBЇ-"c='0QC2ڙnG5x"Eڏoz?g^Sq\ & FyVѡuј락~|oZ!n"e16Lb+w-mUt&\ n%c~a4zc\Wvb=q%gbȏv($}})W5}^j:#o'je@^){P_pVbX@QnL7'*j$yB~-9oGy>6 aBEm n˦uT?!)1rHhCUg?kMOA?5kwP D!};wJ{63. xu`au"F+ '~Nk̓cٕb1%^΁!$}MPdmMBy^]*`4GA*/zsP!@xz؇/$Y9Bpn +uv9*Wm¸fQ|8H Aě,3_-_ꚢ5(_nf^o.[4:є6&uVѤLMrި`V<^!H\҂HJ^LQq:4*YJ?UL)eY>"#nh5,]_%^`cڂnfODe?ΐ7lrj*+l`Ykd fnL?{'i'$"(ҏM!f{&Rc|'M0vuȸӡN[4xyc狦ѴUl-_"G5lǿ*̟Qb4]K*&wЀbƙ6c(Fx^L/΃0p;`L-wWVJ5/vsH]*|wZ,u4]/8Mr̩8;=/u/(G+r97nZ~9Xu$/ytּꋸLCm$isf؍  I.,k'1kP>1ߏE@kϷ> NWp+EQl'卾ʀ$v n<,M>ⴲF[7.PD9 hOrcoU pno*m5/9Jx_eK3<8NoCbXZy] iOL'Ǿ٘ H y>f]oRI}K9ɣP–{Fӣ u씡 h'p(+7kFMe&Z4T]y*me"v ;E/3R#@\菅Mɨu_5#A3χ]T2dٌDRubX,.b+IuKz%6B7?RP/hC)O@NfSv:-l+ݗW2L!!uϾo츝bP"> #Ċi2|%[]u1 ,xVo5{۹JtO)!6G(,`0spxт2%cKXa?H(QjlBwk$Fe d1%c_WWd6 >NB7S1}4sܔw?QG$R^=ҧmE!)7}'qYÓ<(QPjtBX n}0j t܀ĄO\H"*&1[G<8 2uA =|Sx48w]G *C̸fTL")Ǫ$# AQqg^&QW:4~HӄSҨ}B4e|OjV+ݼ=Y_^%d`~eqU`4? *.,BE\waÃ5`٨lK}Cƃ q\5 1EղJ;.i nՒPt}7is$xh9^Zm:Uyơ}\c_ biuߺ?(ixBe16ֻ+ۣj8;6J6WMJ@yejT:7g-d($,?S6:  bFZ@rr%:z?颮&$I\ԞU3Ps22[-bJ=2([%dE>P1ԱBxYn/حJ2l(=ve& G3pl\n0MS+{hn RϪUjմFm!y+TMGb>"gOg:ohf @#Sj"8{C@F<MݕʵWTYj 's.D0{ ys|=BwK?",e(;+k$>)qŧ ?t=$'VR-l&u#as ɫMZ1w֞3Dk`-EIAX2AN\Ҭ!J0 u9Aqy^fv#ءg0GĻ?߲$Wq S]P.6H`NL V܅@F-!ԚF%`?[E"Q !J:Y=*"v&"Z5mFV^~} qQ22nY*javy\$AJ9UX nu5TƲY32ϒ)EԼH*3E2a'׆>y(Fğq$qYu֤Zh$3ްSb!UQ j2tSu˜ F37cRVI4 YZ