transactional-update-4.0.0~rc3-150300.3.3.1 >  A bp9|&m8w(v_M"!ySҨR[.w޽j*tX!ApB㔋azTA7iSq{M=ħʷ`d_&dD4EI9/XeiD,m(##Qu Ëe+Ws`nJ)4nnCsĎ%;mJd'"ÿ9nڲpjLiߏ2+Y;|7bZܚQ֕oP227bc483e79353abec997ee619bb46e0aa57bd7edf6399d8356da1b80104b8b06d2f8a805ac27b1d4ffd42f3b2b3248036b78ad0bp9|7h@(S޺$\\9bOͫӝ[WzOU;JpKз+~7<.4G W')ak 1ӕ x1;={C]kbaF=-r_|˝%L\av?vaE=׍G] Ûe ٢0Yi@pL?d! . ]5 KWE=d   T  h  | !0!!""h"#($Y8$`q9&$q:-cq=Q>Y?a@iFqGHI$X8YD\]^ bcTdefl!u4vw`xyz48@G`djCtransactional-update4.0.0~rc3150300.3.3.1Transactional Updates with btrfs and snapshotstransactional-update is a tool to update a system in an atomic way with zypper, btrfs and snapshots.bqsheep15`SUSE 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 "/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 "/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 fiX+QAl//A큤A큤A큤bmbmbmbmbmbmbmbmbmbmbpbqbmbp_)bmbmbmbmbpa29e470963a8143b37f3f9895cfaf1a21d4de6cea40954d101ff8da44c0555ead40b96b2e80310fc1c836fd54015445066272ac2efbbd34a7887d2e7224c1f68b6be6c251c3efab512a5a0865a3fb7436d39afc344148edd5425d38219798c191364d259643691e2f2f5b633279df22f53b3826867df1724c538a037a44ec883a4dbd8bc49e207e0178385c4588466853118a5af1253204bc3d737d8e22248f3521f0892ae8a7ad78b2e94c574d573be75c4f76c70d9620c79891e584b4653b8b15637138df535dd96a612688bd5a89382191ac15e9c13d2e6c406100c8ea6624b1322b8cb021f7f5b8435d0f1616cb8c68a036d3523f8fcf799c117f89cd8f9d77fc3cebb7c1c69f0fd1bf742bc9edef93e2931a756301020c6c4ee1f830a58de6baca06bc4f46e757662506d819a8e1d06cf5fbb6babd4fcf4485ffd9a88c27fd8014ea39fd39a0d7dde1adc07690a86b659c3457dec2f1a88d319556f9dec328dedc1731f8853949759740a19d06c4bdba9d7c21260dcd545fd7a242650363c6a33d9c064693bc1a92aa3cd6e701a606876275530437064d1c1d38ece567ebdf5fd3f3b15f79e6a3ac6771dd695b844deb32ee9d0ed5e4c36edc29548b72feb1124a2ff49049b3ec8e8f2045a5a3e44673ffa5def8399e4c3f1be39f88b45eb1124a2ff49049b3ec8e8f2045a5a3e44673ffa5def8399e4c3f1be39f88b45@rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroottransactional-update-4.0.0~rc3-150300.3.3.1.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)rpmlib(TildeInVersions)tukitzypper4.0.0~rc3-150300.3.3.14.0.0~rc3-150300.3.3.13.0.4-14.6.0-14.0.4-14.0-15.2-14.10.0-14.0.0~rc3-150300.3.3.14.14.3bq@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.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.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/shsheep15 1656353137 4.0.0~rc3-150300.3.3.14.0.0~rc3-150300.3.3.14.0.0~rc3-150300.3.3.1 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:Maintenance:24849/SUSE_SLE-15-SP3_Update_Products_MicroOS52_Update/c51a444d1a520bc5f951e8bcdf4fd114-transactional-update.SUSE_SLE-15-SP3_Update_Products_MicroOS52_Updatecpioxz5x86_64-suse-linuxASCII textdirectoryBourne-Again shell script, ASCII text executableUTF-8 Unicode 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.0.0~rc3-150300.3.3.1.x86_64/var/log/transactional-update.log' (No such file or directory)RR@ &pw7+/|5l1r<5YFտu*fW*b+6Uԗ@]:DIyD5OsBد{Т"Y aq_k:R ,f6Iw-f:-3kB<ԏP56M-)uNb?- ]p'k2_b96 *JUQ(tF`0@Yӊ;JA5^ M -lF.m^4F\Ul-1Y޶,O]Cŋ·\V}la^ 7b:jnG<5Q/ ?'KN,0wqlu̕"6>ymz p7 3uNǧ4=[ԼvZl9C|2ǘհ5Ea,/ه-]ҹKuPՠH_tx^m榕9JZ&P4bMd+$aXxuخZ9x7#LzWNX"J&1ȳ_#pC5Q1X)(pxRX2A΍%0 Hu M0 V[?'\{hb-XXW=SO\_xQ1F$&t늏l*NnedN nNP0ݷy5}w-լ!Yݪ?/|%Zb5A-fx@LxW᫚`Lv.;=L}AD΍"#` |t|( u@=!tuGEO,=I< #Ha[., %zޯcJ֚2ޛ .6Ѿrvo8kP܌3,O[&B,],OKQw4C$$2_׊,x88^sYD {5qJlBjVrx7ePlliM[!@/VfmL,Uz7j$ ~ſqs#5g'{ѿ>Z\}ԒX羗LL)]fppfveo?⩙т8iLbҮ$܈?2wU8a BXe Jwiμkv? B8g C8&u[o?)vAJ@^eu ,Iajdyڬd \q?oH3rӟ/pA_:ۧj3p BLuBQ>VpoRRKuЇѣr {vCn4g CE"ZR2.#[J8"5ԥ|?%ȯ%²6;2UPꮬ<վ0f<+CCnxlVDS3'D g7r4TV^r7rt$4 2H w\fm&}>ՊaҝiT>2ipzV|NxvնZ{M:5"w'}mK+m2%ZѺ= vG&S+"TX(tD 9 piq䖼ޭR(]I\:iR`4(5, @ !ӔVFWV);SO,iŐ.n8p(PH @I0=gN-!R&]+Km\M ԤE0ᐪv?yۆvȶ\ {?5E*\8SZ H\ 92hfn>hQoSj [X ~4E:2Pͻ;#:17T`Cnj֔'b]$rǓ\Y.@jRo~tyL4 _(bsKgc/űu+Nw_^EP+cHi؈p=Un/e E [ߗFG *-֡ uXe͎d/hv,͟_A(~DEѦCA`CeXS3E`SP G{-]]ڷƦQEr.ЉD7g͙3ef>,pqISZVaØYyrĞu󊢔 2^ƴS^ |tQJ@ID$6C\ Y+Ւ|"P ovȒH AclPr{NG8IHEadapj bBkbLl' V" uJ1ЍK+VVT) S縉cVm!R?zBoFGwOg7WR܁Rz9OD? ǎo?B:/&S٠4xMчhz Ӳ2L/aZ _1 |tmEڽ́d?,o[$MGpےjw6s/- p$}JjJ2c\}bKXRɮxdaZjyM َ訮'Na(VXTaŪx'~Dž?cu'F IypMw P2m#w>~M۩}}F2JQpUdn#CZfY5ym=xslcbFĶ8qeo4^W ѵ7jҗ"60ד~7o =jh jw2;Óu-Жh>;ob(,5$'@/i:>AV(O@UV9֎?,翼UiaJa/Ě ,BL!yF~>]I 0*jj\8hbsi-$~Sa.[5#2?ofw 6wiQ($X麪X-,-wV &FJ[)~^Ox:@ߚo~R@I35 чsŜ/c3ۀ:}HGfdž.jEpcC.CLs.I aZmNJ4y|ቪO(%(dT v+/^fTĂIֻ4kχ#)'sYp4ƫXhL:ߑ^Ht7@+ ?CnbDl5G;=q:~3j|oYH8bgpV:PkVaM  S vdkXl>Fxu%Y`rU/0Ru VI2B~@3[!ȁdNrpZʨ76u2b#@$2F , NjpzHc%>E⸰RX K6{A]@b% qa/elY *J>g;BgtVEPظE-U0L4"P^~! dH5 _ /":Ā߉(#1@j`riVd"k־=%l351op5FL pfk'[G{0UB ~%`(ڐ.2.}G& q:ngTV- m 0v/;?ٰ g8&/,5DPqnQ?laD=`[%=E^3Q>C$%Q38[|:tUUi=aiH5S#bÝFcw~N $ksjߝؐꍜIz_!~$ 3rv{3JoMAk+8Sb h׻!.ƣ@D>|{RrjR)4\J؞@.ˏ]i+sr׊UtG0oA(MU)tӫ$ZݠL#kۧ o8X+.SF(dU;wMlhXs!$"Pa(Q9~U5gwlQfn +g xGT;e$>)՗)m%rpu~CQm);ȶJH{fQw|+ ʘ,=Ղ~|SԇkL^(f ;sPsw(95ݸRG\'NLg!U~eɷ WK }jA`]n`H$2c w$\Oc;{;aЫPo䅕#qjki8O[Cjt\{+28Ij#ORj^ZvghJH>(سkz)KMٻhTV$iPRJgj;7unљiFt+7Z6Ξӣ7@BxKR t5y{ff~ƘtbDAs#*-rzm`HvbfZDoO][.K$;˯D&D$:PmUfyaYi8Bl$+ƷYΠSF̊*)"A@Vj~_ful^~ȃ>t58gs&i Hn.]oo⟊̀ qsm]~C &Kz kL!]Ε/@!gX0h[@[Խuj^\0Ky-qMv0*e ' n--,R(pTRO;ۦ_Z嬉ԜC v|9g4rkgIS\~D9>:wK6{i$! bedk*ihחw^^jKWĈ.V?<8#w6BÖQK ֟0]=e)|d:V f~l N@lJPsS(.  YFGW5a*ZHw%o[̐FHvم}1;ęk9xj(/= J;O= dڤUBE5,͕ι"45X9GM1 Gc3Iqi;?d#~1IXRdl9Ju5 ϐ*m!avy~i:9H*o#Ʌf^ (ؑK7 a Y90ä-dj~6=6O9僝1jKCSZ)yI ~>޵~>]JC+3/3oq2V@dm_}) 9eǣ8aqxV2DbTk dlxPHPGRȸyἴ\-BDiP_Ѽ/OX yT²ey qɓԺ! ^ !,! Gi\͔$\.iRo X];s$p^>8|-JqΝ)O18:_1 ޙSźhmM9m-Ew>'^'%5w)Z]@F.mӑ-' Lyu/ BJLPMk0O3=.Ҋ.qȟ:< k$Seĕ$󜹗A+*pbd_5-{TBHQAw]W&͸ڄ#Jc*Ku[&=j$ÍF C~T|!U$r&<@ș`)<"ߕ7|ˎ=mQ`x^ZnY& oN7z?[[bH:2)Lbm:XNk,7)l0[oQ]&}61ATDzg޲v=fP5۸+90_34nÚ" $j$G lZR|H i @6y|1%ҍ\-s7Vq C"E|lBЙ -Pg*4P3M+t]&K;%QD}e$d> U "7vYčO 0NN7߭pTKś*?R7gT2JJM簫K.`0ipi rj}s8wY )*,#:#֦E վ]$!C, 3(Z^iSSۑT ? E}Z_ e\{wҷJ. ױhɏU*?1- +ߏc쐲Dg\uݤ QdiSvG﹇FKu!"d_8RNyjHP sO>#q@[ LSOi~# sC C2 *<sHpTsZ@__NwGח`-n}rɜQ߻== vu}W~cd'{Um(2s#-(ĬrT޷:ʉ܈:mޤW'/aLAV~fDPJW(C[M BlAT``,@rW_GڢX5@{ #d2%s5{h0Lh}ml}#>e4(|us3UP6{!"9<_©icnkOrRs^,5dɃ hi-yZ+,NF#Ίۉ/mu)B!>CǵNRno7M\@g@+(5|_jM>8FYwzY6ǗV{tn$GF̛ibCM 2.OX$44;]3SRw*s&-6Z)>Hu$I]=@>IU5H5d -%mQ'Ӥߙn:%(lK j.g,\ 0e;fz ']EǤVel{u5=" eeҌ՚3{`(祼<ŏ6$Pm`MKR<i֝(N&{ĥ|2*ZӖc:" 7_p&I`bK^0IϠ9 ʄH;+N~c5 "ic\N^ /-#QߖhAO+tFhOs?LsNOs\`t\;}N\n nmߣ5'iDfV cfGzd<2r%_8%(-(EZelIy)Phs \tAr 8>C c|pq:]b_׸_'PnbрL%LPSI&t{a6l'"6 =p)I4D)p"G@Yx^ť7PSBywMv%|r[>| `@2p$dg?S44<}Xx@M#m;dޤrb:{KOd`8DN[shv(㦯m0 H[61,eLr,/xx$?y16;J{۸}R\©oÖeЗ%|јvJNPSC ֠E ~#AշNDjGa&ڽԈ 9W-wQTCtG+/}k >{,^1¼?UWc^IUq.=`@j{^YKA f o G/ %@:yR^ 6KZf*x3ZE*@AH "&j95UZ,b C .ᘂrд<687bՊj-jڱ@ pd1/DղA,8C$[h(?(8^ok±=,D9c<3gBE;&)bя0:3IyX֭Stz5ǺAY|_J%|>ZE~~/dfY5c!oC!l'j2BnSD̚dv[N&@Q]I o<*_eu^dЎI9֘<mldn]/@"ѵס}@ А7A뿐<~_]'34j5~[C X8"u3xD WY_]SF}6?)(YB]̒SNj5Ш/*?WFA(9̀uuv(! [$C4a )&&<Ӏ|GѼ9Gȱ" C7Aώ^:,z0Aje1KWań(p1:Fn#CZV^iLF7X>+Ȕ{ī1 Lq/[bYߴ?G)ntD}'Q3c'Fl+pzDk^{+]0" _p']4] /%)j3 .߀Au 0yUapHi hlk{&{{F ل䤤Q㮧oDy0_hKZ}/!V 1iiљw"Đ(9 Z&8](ΎH**r9#N/Z2snJC۰CHѢ{ I5{-Ӝk>h_1t\fS= i~YHhߓ_im8f ) ivTZI`4KxmZ&N2ܑ:8Du8Cp 3aR"& FR(r+ީ?*Dj(g֚u=@0btyÎ2t\ha0&cceaÊ`qlN#PK"_`V }ɚ(U<_*H=kw&k\ޕ?[ļ?k4* WL娴%2JXD@|4&?i A &Ψ\vy1;5n#+eQƢ_~XhEO(frx,}Mn&9Lw"eQ6}'ܗ:LQϴן! H0aUǬčEQ%*1!dh d@l9W~ᒴsdjtx RIfP_`*B ţպ$w8-Z-rdz2;^SAK>&^њתpK͍O9$T--fs(=hF k"f5e5a[9[lu7_k0 @q!T;y'/1.曊e@>arf՘CCBVS9_Ŗf{tB;nZnKf vQ#zTV?=d%S1mo-qR>Lpo49T^\;DXK BE*[5v8S1ǔ(D<"tVhH :ĵPv:Fbͅº{=bi#5 ĜDE7q9@ 5YI \r煮xDr߭N-JwHnkCS=21ۓ5ŐSxw=(/FL']p!T-V/ȏӌlڔ-"[̈́! DDsH9v>}dе7 Kj& ,:l:df +,zg8 nq: xPT}t#ڪ4Z,)Tʃ)wJ ~|ua@?s@KU*JYTGD%qBq*/a7RIļP4]09!ܩA,`hXd#;Ǯ_99NDQm g1ݺJש V37LRnOi5?}bh1SXcT6<2TAcԹ]B %zti_\)ėUbݝL;Oj^|Z1`NX1X"ܓ^ .ŇeԁDHV%/ΧYQw db`0#(N3 &@$ j{ѺU{ .{Y / rjM}"%j}vz7(w}ۂW~H{H:btfFA4AY~ [ &O=JӗW?5[Bb$6 S7Jv3LL<6蓊UDUӼ92z qzY(\.WP}YW  5N+! /?qg^Xg0 tt1zݣ:]j킇ew(brX녷Nc=-hj_K%&Ron ܄ ;0+A$_M6J=0u/>))gFFy6uP}{iE =B<'me#>ͳ,тVd'E3k6E h.-Q#TTGh%Z&MJ|WapPM~BSad676ɶjx 頝#`?ϛ;ᩛ*ě:_:&ɹCAr>wFn R \ƁGرЏgu(4%0ipC4.n\sLu[<-#19?UZD /4I:T[R;Ș݉O8(=$7(0]&nvkqn>;Mh+.b\YSM6rkbT+vI.JZБ~IZxhve]8w~+ \w#s[ph4X+HrsuuyZ:vWvĢ+r1J٦ψ)Z˯5W#PE_+{d-3k૩/wpl9gh0d60QEI[ZX 1m'ey:npWC㚢Q㵘:Q аM:[h3I aHN.rh5,3u=|D<ء*m64YLknٹmb-a;Cb `yd!W`gpeP~mrԦSg Kz4c26y`($rS5 s8QʤB gJq塥!ZLb/+yc.5v!8aK-(;vDޏ:~yG[aQ D|r/ݵ~d)o'[n[UYB\1Ұ8ҙ@* vuP_ha_GXs<8ىkLBkXETǥ=%Y 8>mxQoDR9]s}[f 4>takrjCLY';ʮhrn YdI6\ۅ,zsiM( W2d#ZAr JK4I S+w,Π~½(M]6ZUS ~ e% bxfj0#Ss#Ձ^bN ײ Y.nˏ Ej1 ;0,y90Uq!ea^{(^(UpN5"ӈV]P>A]Ik9E˜|)Y<@=֠r&e88j=bx uY>8x[49*#3DWP8_7-Jru-G0NPo^p =P\x44d[nxho Z,9Izc qхG2>\dM,8ƫ^bY߼#r6D%%R;Rq^(Ls`x2=3*sS F~= _.>;7}(wt7cIR9 =:)g1TڙԇJI+P)XrG{Էb!0XxqB>AFOByE^P9V3|s,K'=4ĕ"c (Y)$9{™H?rۖ;06V  J&fb[s(a SUSy߸|o7fthMrHXT<4> }$yHtcUMԧU#tEs`ݥҒEi @$ÅV-0)xMSDchGG a:p>l>˥rw6fܬR6h;G\iW5KYEO97{_"II)Ƃ`$hjaō;MH?l{>8gT (@*";לW0i oRpyNw҈3,m K?HIoHkj^`koh@ud:eD&iJ.n{/=6D,CѻvyxH{ ,i,6zXb`N O1'z/(b5y%QI.LHܤMH:Kة/z]X\2 TJkq^!wŒpͽxiX*cf,.7%̟N{W{b$QAFi6u_jG 5Ymed{w-{vd1v XIdMazM띑qH+:B[/s{PG?1MO#adYuj=a/PrXJH >M) '9;հ$rM -v֟py )s7scЛ6I{h0ep]7U#c3cNaYrאu '6IjR=I$kc|D`רrxk}^Ft!K?Rn)vd~"y[ff)B&/>"_gbM-~"R ʐhWU\*{(p, w^]a呰h-UG#2Ll$221.2~Tȉ…RE:QOd3f,-c=@}z7hXߪnA8(wq?+Nƾ |+\+ɣv1ڳnEvD!(*t%RNlxNIeb.ֲa !: _Db{(9#i=t~ieZ2SP$:G?wqJÒb5&;$bTGCB U-ܿ1 N >a9JUP͞{c|}Yw{~2,~ʾZ1Lǐp$a{i,)}lg?m}tA=*'@&'7(ջw[~Yኹ!9eW;uuUxQlZlaⲗ%fTJ=' ҼWm) 5ss@H_wXI^\҅ nf)_L{0ꩍ^LpJ_&" &3>\ \tB%-7J2&L=&pT&|'xmޞ](Հ &A a9 L@<9'uj] @·@#裖d:n&ȰRaewHO=q;-!Jpq*75͞9̓H|K|la뫓O{ܐ8jܫY*c!`]fgx;&Lk*4'H=F:Lސ(D gpa6IdzE']UezZNٿy dj+dy#%X@٤4QK.r`<ޮa؆$;x!0ϕAbƄۥ/ΡLr_ǮsFtЮP *|~ב(uJ8TnXe8~xP_}6xj8dQȧI4)u:/̂Rpwᆦ)RDcQ^'8o@ޘhg/K@˸(-i8'vrQ~гK- QqJn1!kGoYNjn<|w7yjy )ckmnV߰e: fX+A6k%A@w .9Ӻ=uV ++/)_CX644tbVW° ucއӎJД5 Գ)=loзhRڝ*:p@~;Ul 3Wg|B{+R~ RzT"#'.[O[;yK߿[JjzAPvn^9g>8-S> /S#R3moh/nX<d2q9Y bBɢw$ VI&solqYͧfB6W?#qjxyСšʒɒh>ąw{6E/XEMމ@ A?6<3ZLᫌS<_VmVɽn׮#L9_E:8Sfat:179 FM.!BC 5Hgq4-ԣ"G$'͔E(o DԼ̀ @7ϩKN nF(.J<izϕuIqnXUMF"S`OؔP`A浐k0gpzVKNjёs_N$>]G>\W_ 㐠v{# 7'Vc% ̜og]0z2&\#z[Dft_ q$-x\_ PƫJfQwew,K~MV6*ṃ H OyE[j$,uMѵHFβ>Tnx|G;.~͔_#~[&M9;B7 2FXX@QQĎבj("A72<#1%Jg-]c%O:p7f=M c5FЕo*]h9.u=IT>|;3h7>kwHΓ5惂Oc cwFoOIjHParNF)MIqMa^Rlj2OvTGF۶mr IMtڝ"!Ʉk:>^x'Z1thMuu^JqNNޫk @FIGEETX&5gZrh%1'aFmУd<@{ziҮDw@>)sOn/5`ER q|{`H a E1٪Xux>>S`cx kW4zZ /nPY_ƝOwDDtFﯕ"؃M)oV)u1:+~P_E (|9*w5+0Zs\)n- j6?JLah=x m*2Xw@#HD Re֤ L/ŵpLk9:gr4( gC9mf}sEjv@ "5J ֣WSqeI:MQYJ'tF/A=+Oϼ1z~-TM4wG⾍{+z~}l#G|8trZd@ƒ9G)"qGɺ1ix.0p} E73׃ #.+! <*UZ€3O%7t[[rdL๓iIW*`Q2Bw*@-`N-ˠn45g#. h`Q[d-uZZwrvhktv;lXV#Ğ(+=@dSڡZ4QXd|N0q;d)-]ױ븱iN o; 0 B,pQ,N ԂZvLϳpdL "2~ uؽq~@/‘DJ3@w@ FZ,cY}S i];brdzw=`\ ";w$'Ԓwu"mNCb;>_hxccb8o}+q_~x9Ȥ+-|m#\J/ !@I`5 -q.Cl>`1jyp?{@z#XK+-6]utZ/"ѻUZ;S05SzìP&/*ڵ'nQVQ{*F6V$XBa(GB{9@)`؄a4v~.hLFO˂`pi窧.I0<ERgtSOaSXX U"u`_9Eipe΁ex4OcJdcukUmulW=%AR* xFZ~lGnaCĩgEfdC;vG Xi A`IL!T9.h*.|QN k]2v2ep"nu-A\7c-GEȇgw|v+ Hӵ0CJRJ}~E& 4۔ 0#)\ɲ 3*GeuF$ 韢 !ӡ=-&*GBȵđYw?4&/hm}C/ .E3|V3ں+ǁ'Qtɒ0!SpF i/CqB$;ag9[^Qnc~M23FbSJkOD~D?jv)Jepu<km >̚l9PWu /PH|":%ȋexz0_FnsN%`jF59}=@ ;Ns37}zf[IrŒdhSlɨ 混K8#CGrk+:#5+#$T+? +AK}kVo}K7A|"|bя@VB7~DW5 :] ]+} z5@0 ylnNO݋d5>(&(+`Yw$>+W 6$_ 2²5gEYIic̦ m_Lo%[5xl:c&bc:d u/?=12/7ā{H n^$w68׏V TG-[)}5r[2v^xkxN9{f~=zR9=gj!~BHxg/,9AYŨ'`I%#j ]Y]1',tJ!S[tN5B4x(ݎ|x62sMnZf1QAM&]_b^:VFB3]3YZ_pٖKRVe!#86~bg|_" ֓!\h)|7B뗲0`L37 Aʊa;l: JTHPXpޝ&+b|F])$)&WW1$7_6dT}["}.}wUdX2PryhҢ jU̢_y\vˆt.MFODh{G Ȍp$$)=:qG;wY+u0E+HU= qQ!nkkH5@ .:wۈع#${m7[ӈ^@Rx'jTtޔv%Ç$:0\_Tw 1¬Q:} =ĤMS hu~?˘ $&0>R©4Zc 7%GHx|_p*IxI?:)S w-*)J:͹Vb);⺦ͯ 2s3{Hls78-xx^ylؙkc rmR u; ~?9`.Cj{zx֍6R[/\NZ))&J[h+j~R<5p7n"ZL\OG,:Q2X eE^7fh;8N {"DZf)SK07[9T{>ˬ9vlu{~>(xC ֙φ?#ceUڂ PT  Q^ws۲n qKFmzDq!͹V]dTB0؈ffo #9.aנo΃8s lkM( i]^4*ѣȽ4}'5FxV/r|emmY@y%qԼ1~8XǽZaW?Hwg$pf2\@€)6sɴ#D[:OC:X؟0nq x?,|.ែF#8襚&KY 0̀v9fcU sP̲x wHպρB)2M\"ƙ9%l4ʀ`u1d@Gɱ-s%N9%TJ4t-9njQti)JH)LӑVGްzAjiOѦwdT\Z}?N޾arUtmu)둃ݩDSkuS$~ T`e4HOUait;.v.P{9-p)\#j݅x ; wGA uBC!P`Jv BW/u"ue*Xdmk N/ /JbڞUz4q&Z o^HQdX P9MXU* q>auMߊcJq*";_ж' Z,ET福@RW\0m7bPYшg`S8-oF'v`yUUB=ܗ7E]ζ !*פd~Z&@X72lqCgbr u-y>/5\Zb\3(e/åcq};qe Hы@=~fwL\bK!|Kah(`1Hz+cvX/TtM%?ǥ˦;l;ﶆs2&o bV~+ D ҠOF~7$y5 mƂW=L&ob biL:,Z,: hr[%v9kNj($kt332B -רJ׏[D٣N9T(R^=4퐕[Gz%VCN\YŠc0y8OR5DTX{ %;eɛcs;WHpu:zc4~7D|as+bXhތ4S7MxL };n?7Zxn6pk[ZuLՙF([rfm$\m2ދ{bc7SFzX}bTO/{"ȫxIF?N. 8tQut ?i-tN4%Brp{ x8Y^ j֩+JŨe T?F@{ԉ[ђGQXU4fvuzT ,7t0. T`h~ic^x ]hR=,YvȒ9 ES6\UsƊ % 2y,H7ihle)*e .MrTΛ6{ӽz) ֳ`Tg/QUow /Gxl3<`!ydMXɑĿCs4n1rkg@ X+B > J-Q+%sCMW/u&HOm\|4ŵb0WEFx-JLKa'Y(IɄJ}sm=.[x,m>\ܸn0wk, O9 Z4_@>>)jz`u4vFrL#'ʫEI7^TVC <@MDj_Rok!ز깲J^M%3>z=x7v(_ >4rdRzC7ի8s8",T $ "a6JEbNU^'Es"kpۊڎ'/ )Gxzb^PX'}t?\G@%aFTXwK<}sXs}lO O1Y=ݿ2*?uewʷ)CRi1Z{= mͲJc%cV*XB 뿛aK=(S\S6I|lpj)3Xח'yvI[I5^eN/#~?5U{MFo9ONaQq!NN0)kڝ`F쌧!?P>`2`C|06]0ZdaCd"}\.,&+l[f<9p5X+Ta&W[_sܗ\,ڣHWGwzHH/*7V}x`NVdCyE"l WbwaCb﹬P|͵ܓCIb z|NK|Zh6X"+W&0r٭pwe󗆵AX!@Tca F5a d?gcK,ͯ2TS Bʆ*\~ǰQ*yyER񭚶 TW*3 D/П(P#n3md5c~%z^ʩ>CCE<tuT #.1,[,`YZ H~4…|*4榜'8*38KUn!ZTLn|j\qjжؙzl@v&?F\{Xd >~":3tp,*b1D_~-0'6 -MG̣ӓC~Roi"OM𘺡Ֆ^Gc,j{?D-Q}CsӵDh0Ěyb9\3" 1u~RDɯ vM0!}RZ B77dQQUiPtǛ8Whn<Ȓj dZW*fygDz֡2rb+LFV耧 maBzWXGjy>y0,uÛ$*h0q+.vzP0H~:i&btcXu$^̳Nz4]OY1̈́j5̆b(-FDc{vXCatٸ-JK;4/2/D OʾS䲗MQEϣW+}(#Co b51ye)jq4Y]!yhM4ZMMIK4K c[*FC$N5Q_Y`nH3zuF$"8#5KH'uKnsCwNk-D#ʮDWӧpM`@wp5;RwL[mˢ$I͸ :@ѶIIϘ}Jc=w;\Y [DGxLXL(D#}Bي>>"SH+7Ɏ"[!s"FTqdFv]kxQ !..^vBd+fue5qt?4Cj>!S/GtNOE6 SV}wWP 4bai˿^)fOtaUبTpϖܛ'z`I/Huyu|\ѝHFվJ* + G;6Ӑ>ţZYb"T d4h] 7C j,)trq +r&GB?5:b&!$.JӯBW}{7˘x2))iR émήz{ku6@8 ۈ7U#@zJ&qկ}J-!4A)v{ka*[*p]o>UKZ_dž\ 6UB'O.ň1Oe"`we^TSVp/>-Ku}jtϥ1B00y7i77?/7 C˰eTdоHOP nvE\O:'rD]ˆL%'+O^~+_~|dЈRjR9Gͥ3Y,BCJR\䠂e`Y @LK-BG8sTYW+H8q4`AK-hsN̅)][}O+Fd)ǖ(7Å^xv>* Uԍ$5R1IfBǎɬ6ĝa$L}y<