diff options
author | Lennart Poettering <lennart@poettering.net> | 2023-11-07 18:19:07 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2024-03-14 11:34:04 +0100 |
commit | 00431b2b66cb59540deda4ea018170a289673585 (patch) | |
tree | 4acd4449315cfd8de5984d53bb847b48f7b0b019 /src/busctl | |
parent | run: allow connecting to capsule instances with --capsule=/-C (diff) | |
download | systemd-00431b2b66cb59540deda4ea018170a289673585.tar.xz systemd-00431b2b66cb59540deda4ea018170a289673585.zip |
busctl: teach busctl a --capsule=/-C switch too
Diffstat (limited to 'src/busctl')
-rw-r--r-- | src/busctl/busctl.c | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/src/busctl/busctl.c b/src/busctl/busctl.c index 9c750fcd53..ec00ed54a2 100644 --- a/src/busctl/busctl.c +++ b/src/busctl/busctl.c @@ -28,6 +28,7 @@ #include "parse-util.h" #include "path-util.h" #include "pretty-print.h" +#include "capsule-util.h" #include "runtime-scope.h" #include "set.h" #include "sort-util.h" @@ -72,6 +73,7 @@ static int json_transform_message(sd_bus_message *m, JsonVariant **ret); static int acquire_bus(bool set_monitor, sd_bus **ret) { _cleanup_(sd_bus_close_unrefp) sd_bus *bus = NULL; + _cleanup_close_ int pin_fd = -EBADF; int r; r = sd_bus_new(&bus); @@ -138,10 +140,13 @@ static int acquire_bus(bool set_monitor, sd_bus **ret) { r = bus_set_address_machine(bus, arg_runtime_scope, arg_host); break; + case BUS_TRANSPORT_CAPSULE: + r = bus_set_address_capsule_bus(bus, arg_host, &pin_fd); + break; + default: assert_not_reached(); } - if (r < 0) return bus_log_address_error(r, arg_transport); @@ -2385,6 +2390,7 @@ static int parse_argv(int argc, char *argv[]) { { "match", required_argument, NULL, ARG_MATCH }, { "host", required_argument, NULL, 'H' }, { "machine", required_argument, NULL, 'M' }, + { "capsule", required_argument, NULL, 'C' }, { "size", required_argument, NULL, ARG_SIZE }, { "list", no_argument, NULL, ARG_LIST }, { "quiet", no_argument, NULL, 'q' }, @@ -2406,7 +2412,7 @@ static int parse_argv(int argc, char *argv[]) { assert(argc >= 0); assert(argv); - while ((c = getopt_long(argc, argv, "hH:M:qjl", options, NULL)) >= 0) + while ((c = getopt_long(argc, argv, "hH:M:C:J:qjl", options, NULL)) >= 0) switch (c) { @@ -2490,6 +2496,17 @@ static int parse_argv(int argc, char *argv[]) { arg_host = optarg; break; + case 'C': + r = capsule_name_is_valid(optarg); + if (r < 0) + return log_error_errno(r, "Unable to validate capsule name '%s': %m", optarg); + if (r == 0) + return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "Invalid capsule name: %s", optarg); + + arg_host = optarg; + arg_transport = BUS_TRANSPORT_CAPSULE; + break; + case 'q': arg_quiet = true; break; |