mirror of
https://github.com/systemd/systemd
synced 2026-04-22 06:54:51 +02:00
Compare commits
9 Commits
ee3d33c415
...
7347b3db83
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7347b3db83 | ||
|
|
4db62561c2 | ||
|
|
e92a3d8fa3 | ||
|
|
6c5f368646 | ||
|
|
835f79fddd | ||
|
|
4f2dba98ad | ||
|
|
963c560a29 | ||
|
|
ce3ca32cb9 | ||
|
|
087a799f64 |
8
NEWS
8
NEWS
@ -9,6 +9,14 @@ CHANGES WITH 251:
|
||||
can still be used by explicitly configuring RouteTable= setting in
|
||||
.netdev files.
|
||||
|
||||
* The org.freedesktop.portable1 methods GetMetadataWithExtensions and
|
||||
GetImageMetadataWithExtensions have been fixed to provide an extra return
|
||||
parameter, containing the actual extensions release metadata. The
|
||||
current implementation was judged to be broken and unusable, and thus
|
||||
the usual procedure of adding a new set of methods is skipped, opting
|
||||
for breaking backward compatibility instead, as nobody should be
|
||||
affected, given the state of the current interface.
|
||||
|
||||
* Services with Restart=always and a failing ExecCondition= will no longer
|
||||
be restarted, to bring ExecCondition= in line with Condition*= settings.
|
||||
|
||||
|
||||
@ -164,6 +164,12 @@ evdev:atkbd:dmi:bvn*:bvr*:bd*:svnAcer*:pnPredator*PH*315-52:*
|
||||
KEYBOARD_KEY_ef=kbdillumup # Fn+F10
|
||||
KEYBOARD_KEY_f0=kbdillumdown # Fn+F9
|
||||
|
||||
# Travelmate B311-31, B311R-31, B311RN-31
|
||||
evdev:atkbd:dmi:bvn*:bvr*:bd*:svnAcer*:pnTravelMateB311-31*:pvr*
|
||||
evdev:atkbd:dmi:bvn*:bvr*:bd*:svnAcer*:pnTravelMateB311R-31*:pvr*
|
||||
evdev:atkbd:dmi:bvn*:bvr*:bd*:svnAcer*:pnTravelMateB311RN-31*:pvr*
|
||||
KEYBOARD_KEY_8a=f20 # Microphone mute
|
||||
|
||||
# Travelmate C300
|
||||
evdev:atkbd:dmi:bvn*:bvr*:bd*:svnAcer*:pnTravelMate*C3[01]0*:*
|
||||
KEYBOARD_KEY_67=f24 # FIXME: rotate screen
|
||||
|
||||
@ -54,6 +54,7 @@ node /org/freedesktop/portable1 {
|
||||
in t flags,
|
||||
out s image,
|
||||
out ay os_release,
|
||||
out a{say} extensions,
|
||||
out a{say} units);
|
||||
GetImageState(in s image,
|
||||
out s state);
|
||||
@ -189,19 +190,12 @@ node /org/freedesktop/portable1 {
|
||||
and a list of portable units contained in the image, in the form of a string (unit name) and
|
||||
an array of bytes with the content.</para>
|
||||
|
||||
<para><function>GetImageMetadataWithExtensions()</function> retrieves metadata associated with an image.
|
||||
This method is a superset of <function>GetImageMetadata()</function> with the addition of
|
||||
a list of extensions as input parameter, which were overlaid on top of the main
|
||||
image via <function>AttachImageWithExtensions()</function>.
|
||||
The <varname>flag</varname> parameter can be used to request that, before the units, the path of
|
||||
each extension and an array of bytes with the content of the respective extension-release file
|
||||
are sent. One such structure will be sent for each extension named in the input arguments. The
|
||||
flag value to enable this functionality is defined as follows:</para>
|
||||
|
||||
<programlisting>
|
||||
#define PORTABLE_INSPECT_EXTENSION_RELEASES (UINT64_C(1) << 1)
|
||||
</programlisting>
|
||||
|
||||
<para><function>GetImageMetadataWithExtensions()</function> retrieves metadata associated with an
|
||||
image. This method is a superset of <function>GetImageMetadata()</function> with the addition of a list
|
||||
of extensions as input parameter, which were overlaid on top of the main image via
|
||||
<function>AttachImageWithExtensions()</function>. The path of each extension and an array of bytes with
|
||||
the content of the respective extension-release file are returned, one such structure for each
|
||||
extension named in the input arguments.</para>
|
||||
|
||||
<para><function>GetImageState()</function> retrieves the image state as one of the following
|
||||
strings:
|
||||
@ -352,6 +346,7 @@ node /org/freedesktop/portable1 {
|
||||
in t flags,
|
||||
out s image,
|
||||
out ay os_release,
|
||||
out a{say} extensions,
|
||||
out a{say} units);
|
||||
GetState(out s state);
|
||||
GetStateWithExtensions(in as extensions,
|
||||
|
||||
@ -149,7 +149,6 @@ node /org/freedesktop/systemd1 {
|
||||
CancelJob(in u id);
|
||||
ClearJobs();
|
||||
ResetFailed();
|
||||
@org.freedesktop.systemd1.Privileged("true")
|
||||
SetShowStatus(in s mode);
|
||||
ListUnits(out a(ssssssouso) units);
|
||||
ListUnitsFiltered(in as states,
|
||||
|
||||
@ -7,7 +7,7 @@ ENV{UDEV_DISABLE_PERSISTENT_STORAGE_RULES_FLAG}=="1", GOTO="persistent_storage_t
|
||||
|
||||
# type 8 devices are "Medium Changers"
|
||||
SUBSYSTEM=="scsi_generic", SUBSYSTEMS=="scsi", ATTRS{type}=="8", IMPORT{program}="scsi_id --sg-version=3 --export --whitelisted -d $devnode", \
|
||||
SYMLINK+="tape/by-id/scsi-$env{ID_SERIAL}"
|
||||
SYMLINK+="tape/by-id/scsi-$env{ID_SERIAL} tape/by-id/scsi-$env{ID_SERIAL}-changer"
|
||||
|
||||
# iSCSI devices from the same host have all the same ID_SERIAL,
|
||||
# but additionally a property named ID_SCSI_SERIAL.
|
||||
@ -23,7 +23,7 @@ KERNEL=="st*[0-9]|nst*[0-9]", ATTRS{ieee1394_id}=="?*", ENV{ID_SERIAL}="$attr{ie
|
||||
KERNEL=="st*[0-9]|nst*[0-9]", ENV{ID_SERIAL}!="?*", SUBSYSTEMS=="usb", IMPORT{builtin}="usb_id"
|
||||
KERNEL=="st*[0-9]|nst*[0-9]", ENV{ID_SERIAL}!="?*", SUBSYSTEMS=="scsi", KERNELS=="[0-9]*:*[0-9]", ENV{.BSG_DEV}="$root/bsg/$id"
|
||||
KERNEL=="st*[0-9]|nst*[0-9]", ENV{ID_SERIAL}!="?*", IMPORT{program}="scsi_id --whitelisted --export --device=$env{.BSG_DEV}", ENV{ID_BUS}="scsi"
|
||||
KERNEL=="st*[0-9]", ENV{ID_SERIAL}=="?*", SYMLINK+="tape/by-id/$env{ID_BUS}-$env{ID_SERIAL}"
|
||||
KERNEL=="st*[0-9]", ENV{ID_SERIAL}=="?*", SYMLINK+="tape/by-id/$env{ID_BUS}-$env{ID_SERIAL}", OPTIONS+="link_priority=10"
|
||||
KERNEL=="st*[0-9]", ENV{ID_SCSI_SERIAL}=="?*", SYMLINK+="tape/by-id/$env{ID_BUS}-$env{ID_SCSI_SERIAL}"
|
||||
KERNEL=="nst*[0-9]", ENV{ID_SERIAL}=="?*", SYMLINK+="tape/by-id/$env{ID_BUS}-$env{ID_SERIAL}-nst"
|
||||
KERNEL=="nst*[0-9]", ENV{ID_SCSI_SERIAL}=="?*", SYMLINK+="tape/by-id/$env{ID_BUS}-$env{ID_SCSI_SERIAL}-nst"
|
||||
|
||||
@ -2710,6 +2710,16 @@ static int method_set_show_status(sd_bus_message *message, void *userdata, sd_bu
|
||||
assert(m);
|
||||
assert(message);
|
||||
|
||||
r = mac_selinux_access_check(message, "reload", error);
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
r = bus_verify_set_environment_async(m, message, error);
|
||||
if (r < 0)
|
||||
return r;
|
||||
if (r == 0)
|
||||
return 1; /* No authorization for now, but the async polkit stuff will call us again when it has it */
|
||||
|
||||
r = sd_bus_message_read(message, "s", &t);
|
||||
if (r < 0)
|
||||
return r;
|
||||
@ -3100,7 +3110,7 @@ const sd_bus_vtable bus_manager_vtable[] = {
|
||||
SD_BUS_PARAM(mode),
|
||||
NULL,,
|
||||
method_set_show_status,
|
||||
SD_BUS_VTABLE_CAPABILITY(CAP_SYS_ADMIN)),
|
||||
SD_BUS_VTABLE_UNPRIVILEGED),
|
||||
SD_BUS_METHOD_WITH_NAMES("ListUnits",
|
||||
NULL,,
|
||||
"a(ssssssouso)",
|
||||
|
||||
@ -228,7 +228,7 @@ _noreturn_ static void freeze_or_exit_or_reboot(void) {
|
||||
freeze();
|
||||
}
|
||||
|
||||
_noreturn_ static void crash(int sig) {
|
||||
_noreturn_ static void crash(int sig, siginfo_t *siginfo, void *context) {
|
||||
struct sigaction sa;
|
||||
pid_t pid;
|
||||
|
||||
@ -273,6 +273,14 @@ _noreturn_ static void crash(int sig) {
|
||||
siginfo_t status;
|
||||
int r;
|
||||
|
||||
if (siginfo) {
|
||||
_cleanup_free_ char *cmdline = NULL;
|
||||
pid_t sender_pid = siginfo->si_pid;
|
||||
|
||||
(void) get_process_cmdline(sender_pid, SIZE_MAX, 0, &cmdline);
|
||||
log_emergency("Caught <%s> from PID "PID_FMT" (%s)", signal_to_string(sig), sender_pid, strna(cmdline));
|
||||
}
|
||||
|
||||
/* Order things nicely. */
|
||||
r = wait_for_terminate(pid, &status);
|
||||
if (r < 0)
|
||||
@ -330,8 +338,8 @@ _noreturn_ static void crash(int sig) {
|
||||
|
||||
static void install_crash_handler(void) {
|
||||
static const struct sigaction sa = {
|
||||
.sa_handler = crash,
|
||||
.sa_flags = SA_NODEFER, /* So that we can raise the signal again from the signal handler */
|
||||
.sa_sigaction = crash,
|
||||
.sa_flags = SA_NODEFER | SA_SIGINFO, /* So that we can raise the signal again from the signal handler */
|
||||
};
|
||||
int r;
|
||||
|
||||
|
||||
@ -21,14 +21,13 @@ typedef struct PortableMetadata {
|
||||
#define PORTABLE_METADATA_IS_UNIT(m) (!IN_SET((m)->name[0], 0, '/'))
|
||||
|
||||
typedef enum PortableFlags {
|
||||
PORTABLE_RUNTIME = 1 << 0,
|
||||
PORTABLE_INSPECT_EXTENSION_RELEASES = 1 << 1, /* Public API via DBUS, do not change */
|
||||
PORTABLE_PREFER_COPY = 1 << 2,
|
||||
PORTABLE_PREFER_SYMLINK = 1 << 3,
|
||||
PORTABLE_REATTACH = 1 << 4,
|
||||
_PORTABLE_MASK_PUBLIC = PORTABLE_RUNTIME | PORTABLE_INSPECT_EXTENSION_RELEASES,
|
||||
PORTABLE_RUNTIME = 1 << 0, /* Public API via DBUS, do not change */
|
||||
PORTABLE_PREFER_COPY = 1 << 1,
|
||||
PORTABLE_PREFER_SYMLINK = 1 << 2,
|
||||
PORTABLE_REATTACH = 1 << 3,
|
||||
_PORTABLE_MASK_PUBLIC = PORTABLE_RUNTIME,
|
||||
_PORTABLE_TYPE_MAX,
|
||||
_PORTABLE_TYPE_INVALID = -EINVAL,
|
||||
_PORTABLE_TYPE_INVALID = -EINVAL,
|
||||
} PortableFlags;
|
||||
|
||||
/* This enum is anonymous, since we usually store it in an 'int', as we overload it with negative errno
|
||||
|
||||
@ -260,7 +260,7 @@ static int maybe_reload(sd_bus **bus) {
|
||||
static int get_image_metadata(sd_bus *bus, const char *image, char **matches, sd_bus_message **reply) {
|
||||
_cleanup_(sd_bus_message_unrefp) sd_bus_message *m = NULL;
|
||||
_cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
|
||||
PortableFlags flags = PORTABLE_INSPECT_EXTENSION_RELEASES;
|
||||
uint64_t flags = 0;
|
||||
const char *method;
|
||||
int r;
|
||||
|
||||
@ -362,71 +362,78 @@ static int inspect_image(int argc, char *argv[], void *userdata) {
|
||||
strna(pretty_os));
|
||||
}
|
||||
|
||||
r = sd_bus_message_enter_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
if (!strv_isempty(arg_extension_images)) {
|
||||
/* If we specified any extensions, we'll first get back exactly the paths (and
|
||||
* extension-release content) for each one of the arguments. */
|
||||
|
||||
/* If we specified any extensions, we'll first get back exactly the
|
||||
* paths (and extension-release content) for each one of the arguments. */
|
||||
for (size_t i = 0; i < strv_length(arg_extension_images); ++i) {
|
||||
const char *name;
|
||||
|
||||
r = sd_bus_message_enter_container(reply, 'e', "say");
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
if (r == 0)
|
||||
break;
|
||||
|
||||
r = sd_bus_message_read(reply, "s", &name);
|
||||
r = sd_bus_message_enter_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
|
||||
r = sd_bus_message_read_array(reply, 'y', &data, &sz);
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
for (size_t i = 0; i < strv_length(arg_extension_images); ++i) {
|
||||
const char *name;
|
||||
|
||||
if (arg_cat) {
|
||||
if (nl)
|
||||
fputc('\n', stdout);
|
||||
|
||||
printf("%s-- Extension Release: %s --%s\n", ansi_highlight(), name, ansi_normal());
|
||||
fwrite(data, sz, 1, stdout);
|
||||
fflush(stdout);
|
||||
nl = true;
|
||||
} else {
|
||||
_cleanup_free_ char *pretty_portable = NULL, *pretty_os = NULL, *sysext_level = NULL,
|
||||
*id = NULL, *version_id = NULL, *sysext_scope = NULL, *portable_prefixes = NULL;
|
||||
_cleanup_fclose_ FILE *f = NULL;
|
||||
|
||||
f = fmemopen_unlocked((void*) data, sz, "re");
|
||||
if (!f)
|
||||
return log_error_errno(errno, "Failed to open extension-release buffer: %m");
|
||||
|
||||
r = parse_env_file(f, name,
|
||||
"ID", &id,
|
||||
"VERSION_ID", &version_id,
|
||||
"SYSEXT_SCOPE", &sysext_scope,
|
||||
"SYSEXT_LEVEL", &sysext_level,
|
||||
"PORTABLE_PRETTY_NAME", &pretty_portable,
|
||||
"PORTABLE_PREFIXES", &portable_prefixes,
|
||||
"PRETTY_NAME", &pretty_os);
|
||||
r = sd_bus_message_enter_container(reply, 'e', "say");
|
||||
if (r < 0)
|
||||
return log_error_errno(r, "Failed to parse extension release from '%s': %m", name);
|
||||
return bus_log_parse_error(r);
|
||||
if (r == 0)
|
||||
break;
|
||||
|
||||
printf("Extension:\n\t%s\n"
|
||||
"\tExtension Scope:\n\t\t%s\n"
|
||||
"\tExtension Compatibility Level:\n\t\t%s\n"
|
||||
"\tPortable Service:\n\t\t%s\n"
|
||||
"\tPortable Prefixes:\n\t\t%s\n"
|
||||
"\tOperating System:\n\t\t%s (%s %s)\n",
|
||||
name,
|
||||
strna(sysext_scope),
|
||||
strna(sysext_level),
|
||||
strna(pretty_portable),
|
||||
strna(portable_prefixes),
|
||||
strna(pretty_os),
|
||||
strna(id),
|
||||
strna(version_id));
|
||||
r = sd_bus_message_read(reply, "s", &name);
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
|
||||
r = sd_bus_message_read_array(reply, 'y', &data, &sz);
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
|
||||
if (arg_cat) {
|
||||
if (nl)
|
||||
fputc('\n', stdout);
|
||||
|
||||
printf("%s-- Extension Release: %s --%s\n", ansi_highlight(), name, ansi_normal());
|
||||
fwrite(data, sz, 1, stdout);
|
||||
fflush(stdout);
|
||||
nl = true;
|
||||
} else {
|
||||
_cleanup_free_ char *pretty_portable = NULL, *pretty_os = NULL, *sysext_level = NULL,
|
||||
*id = NULL, *version_id = NULL, *sysext_scope = NULL, *portable_prefixes = NULL;
|
||||
_cleanup_fclose_ FILE *f = NULL;
|
||||
|
||||
f = fmemopen_unlocked((void*) data, sz, "re");
|
||||
if (!f)
|
||||
return log_error_errno(errno, "Failed to open extension-release buffer: %m");
|
||||
|
||||
r = parse_env_file(f, name,
|
||||
"ID", &id,
|
||||
"VERSION_ID", &version_id,
|
||||
"SYSEXT_SCOPE", &sysext_scope,
|
||||
"SYSEXT_LEVEL", &sysext_level,
|
||||
"PORTABLE_PRETTY_NAME", &pretty_portable,
|
||||
"PORTABLE_PREFIXES", &portable_prefixes,
|
||||
"PRETTY_NAME", &pretty_os);
|
||||
if (r < 0)
|
||||
return log_error_errno(r, "Failed to parse extension release from '%s': %m", name);
|
||||
|
||||
printf("Extension:\n\t%s\n"
|
||||
"\tExtension Scope:\n\t\t%s\n"
|
||||
"\tExtension Compatibility Level:\n\t\t%s\n"
|
||||
"\tPortable Service:\n\t\t%s\n"
|
||||
"\tPortable Prefixes:\n\t\t%s\n"
|
||||
"\tOperating System:\n\t\t%s (%s %s)\n",
|
||||
name,
|
||||
strna(sysext_scope),
|
||||
strna(sysext_level),
|
||||
strna(pretty_portable),
|
||||
strna(portable_prefixes),
|
||||
strna(pretty_os),
|
||||
strna(id),
|
||||
strna(version_id));
|
||||
}
|
||||
|
||||
r = sd_bus_message_exit_container(reply);
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
}
|
||||
|
||||
r = sd_bus_message_exit_container(reply);
|
||||
@ -434,6 +441,10 @@ static int inspect_image(int argc, char *argv[], void *userdata) {
|
||||
return bus_log_parse_error(r);
|
||||
}
|
||||
|
||||
r = sd_bus_message_enter_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
|
||||
for (;;) {
|
||||
const char *name;
|
||||
|
||||
@ -764,18 +775,17 @@ static int maybe_stop_disable(sd_bus *bus, char *image, char *argv[]) {
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
|
||||
r = sd_bus_message_enter_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
|
||||
/* If we specified any extensions, we'll first get back exactly the
|
||||
* paths (and extension-release content) for each one of the arguments. */
|
||||
for (size_t i = 0; i < strv_length(arg_extension_images); ++i) {
|
||||
r = sd_bus_message_skip(reply, "{say}");
|
||||
/* If we specified any extensions, we'll first an array of extension-release metadata. */
|
||||
if (!strv_isempty(arg_extension_images)) {
|
||||
r = sd_bus_message_skip(reply, "a{say}");
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
}
|
||||
|
||||
r = sd_bus_message_enter_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return bus_log_parse_error(r);
|
||||
|
||||
for (;;) {
|
||||
const char *name;
|
||||
|
||||
|
||||
@ -441,6 +441,7 @@ const sd_bus_vtable manager_vtable[] = {
|
||||
"t", flags),
|
||||
SD_BUS_RESULT("s", image,
|
||||
"ay", os_release,
|
||||
"a{say}", extensions,
|
||||
"a{say}", units),
|
||||
method_get_image_metadata,
|
||||
SD_BUS_VTABLE_UNPRIVILEGED),
|
||||
|
||||
@ -108,7 +108,6 @@ int bus_image_common_get_metadata(
|
||||
_cleanup_hashmap_free_ Hashmap *unit_files = NULL;
|
||||
_cleanup_(sd_bus_message_unrefp) sd_bus_message *reply = NULL;
|
||||
_cleanup_free_ PortableMetadata **sorted = NULL;
|
||||
PortableFlags flags = 0;
|
||||
int r;
|
||||
|
||||
assert(name_or_path || image);
|
||||
@ -119,8 +118,10 @@ int bus_image_common_get_metadata(
|
||||
m = image->userdata;
|
||||
}
|
||||
|
||||
if (sd_bus_message_is_method_call(message, NULL, "GetImageMetadataWithExtensions") ||
|
||||
sd_bus_message_is_method_call(message, NULL, "GetMetadataWithExtensions")) {
|
||||
bool have_exti = sd_bus_message_is_method_call(message, NULL, "GetImageMetadataWithExtensions") ||
|
||||
sd_bus_message_is_method_call(message, NULL, "GetMetadataWithExtensions");
|
||||
|
||||
if (have_exti) {
|
||||
r = sd_bus_message_read_strv(message, &extension_images);
|
||||
if (r < 0)
|
||||
return r;
|
||||
@ -130,8 +131,7 @@ int bus_image_common_get_metadata(
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
if (sd_bus_message_is_method_call(message, NULL, "GetImageMetadataWithExtensions") ||
|
||||
sd_bus_message_is_method_call(message, NULL, "GetMetadataWithExtensions")) {
|
||||
if (have_exti) {
|
||||
uint64_t input_flags = 0;
|
||||
|
||||
r = sd_bus_message_read(message, "t", &input_flags);
|
||||
@ -142,7 +142,6 @@ int bus_image_common_get_metadata(
|
||||
return sd_bus_reply_method_errorf(message, SD_BUS_ERROR_INVALID_ARGS,
|
||||
"Invalid 'flags' parameter '%" PRIu64 "'",
|
||||
input_flags);
|
||||
flags |= input_flags;
|
||||
}
|
||||
|
||||
r = bus_image_acquire(m,
|
||||
@ -186,16 +185,16 @@ int bus_image_common_get_metadata(
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
r = sd_bus_message_open_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
/* If it was requested, also send back the extension path and the content
|
||||
* of each extension-release file. Behind a flag, as it's an incompatible
|
||||
* change. */
|
||||
if (FLAGS_SET(flags, PORTABLE_INSPECT_EXTENSION_RELEASES)) {
|
||||
if (have_exti) {
|
||||
PortableMetadata *extension_release;
|
||||
|
||||
r = sd_bus_message_open_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
ORDERED_HASHMAP_FOREACH(extension_release, extension_releases) {
|
||||
|
||||
r = sd_bus_message_open_container(reply, 'e', "say");
|
||||
@ -214,8 +213,16 @@ int bus_image_common_get_metadata(
|
||||
if (r < 0)
|
||||
return r;
|
||||
}
|
||||
|
||||
r = sd_bus_message_close_container(reply);
|
||||
if (r < 0)
|
||||
return r;
|
||||
}
|
||||
|
||||
r = sd_bus_message_open_container(reply, 'a', "{say}");
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
for (size_t i = 0; i < hashmap_size(unit_files); i++) {
|
||||
|
||||
r = sd_bus_message_open_container(reply, 'e', "say");
|
||||
@ -888,6 +895,7 @@ const sd_bus_vtable image_vtable[] = {
|
||||
"t", flags),
|
||||
SD_BUS_RESULT("s", image,
|
||||
"ay", os_release,
|
||||
"a{say}", extensions,
|
||||
"a{say}", units),
|
||||
bus_image_method_get_metadata,
|
||||
SD_BUS_VTABLE_UNPRIVILEGED),
|
||||
|
||||
@ -607,7 +607,7 @@ ExecStart=sleep 120
|
||||
EOF
|
||||
cp "$initdir/usr/lib/systemd/system/minimal-app0.service" "$initdir/usr/lib/systemd/system/minimal-app0-foo.service"
|
||||
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/minimal_0.raw" -noappend -quiet
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/minimal_0.raw" -noappend
|
||||
veritysetup format "$oldinitdir/usr/share/minimal_0.raw" "$oldinitdir/usr/share/minimal_0.verity" | \
|
||||
grep '^Root hash:' | cut -f2 | tr -d '\n' >"$oldinitdir/usr/share/minimal_0.roothash"
|
||||
|
||||
@ -615,7 +615,7 @@ EOF
|
||||
rm "$initdir/usr/lib/systemd/system/minimal-app0-foo.service"
|
||||
cp "$initdir/usr/lib/systemd/system/minimal-app0.service" "$initdir/usr/lib/systemd/system/minimal-app0-bar.service"
|
||||
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/minimal_1.raw" -noappend -quiet
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/minimal_1.raw" -noappend
|
||||
veritysetup format "$oldinitdir/usr/share/minimal_1.raw" "$oldinitdir/usr/share/minimal_1.verity" | \
|
||||
grep '^Root hash:' | cut -f2 | tr -d '\n' >"$oldinitdir/usr/share/minimal_1.roothash"
|
||||
|
||||
@ -647,7 +647,7 @@ cat /usr/lib/extension-release.d/extension-release.app0
|
||||
EOF
|
||||
chmod +x "$initdir/opt/script0.sh"
|
||||
echo MARKER=1 >"$initdir/usr/lib/systemd/system/some_file"
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/app0.raw" -noappend -quiet
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/app0.raw" -noappend
|
||||
|
||||
export initdir="$TESTDIR/app1"
|
||||
mkdir -p "$initdir/usr/lib/extension-release.d" "$initdir/usr/lib/systemd/system" "$initdir/opt"
|
||||
@ -673,7 +673,7 @@ cat /usr/lib/extension-release.d/extension-release.app2
|
||||
EOF
|
||||
chmod +x "$initdir/opt/script1.sh"
|
||||
echo MARKER=1 >"$initdir/usr/lib/systemd/system/other_file"
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/app1.raw" -noappend -quiet
|
||||
mksquashfs "$initdir" "$oldinitdir/usr/share/app1.raw" -noappend
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
@ -47,8 +47,8 @@ portablectl list | grep -q -F "No images."
|
||||
|
||||
# portablectl also works with directory paths rather than images
|
||||
|
||||
unsquashfs -q -dest /tmp/minimal_0 /usr/share/minimal_0.raw
|
||||
unsquashfs -q -dest /tmp/minimal_1 /usr/share/minimal_1.raw
|
||||
unsquashfs -dest /tmp/minimal_0 /usr/share/minimal_0.raw
|
||||
unsquashfs -dest /tmp/minimal_1 /usr/share/minimal_1.raw
|
||||
|
||||
portablectl "${ARGS[@]}" attach --copy=symlink --now --runtime /tmp/minimal_0 minimal-app0
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user