1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-05 13:18:06 +03:00

sysupdated: Make sure targets we skip are skipped

We'd log that we're skipping the target, but it would never actually get
removed from the manager's list. Thus, we'd advertise targets that don't
actually exist to clients.

In the original version of the sysupdated PR, this was handled by
removing the target from the manager's list in target_free, and using a
_cleanup_ attribute to free the target when skipping. However, this
changed at some point during review. So, this commit takes the
alternative approach
This commit is contained in:
Adrian Vovk 2024-11-06 12:43:48 -05:00
parent d145d1d410
commit a509603b2e
No known key found for this signature in database
GPG Key ID: 90A7B546533E15FB

View File

@ -714,7 +714,6 @@ DEFINE_HASH_OPS_WITH_VALUE_DESTRUCTOR(target_hash_ops, char, string_hash_func, s
static int target_new(Manager *m, TargetClass class, const char *name, const char *path, Target **ret) { static int target_new(Manager *m, TargetClass class, const char *name, const char *path, Target **ret) {
_cleanup_(target_freep) Target *t = NULL; _cleanup_(target_freep) Target *t = NULL;
int r;
assert(m); assert(m);
assert(ret); assert(ret);
@ -744,10 +743,6 @@ static int target_new(Manager *m, TargetClass class, const char *name, const cha
if (!t->id) if (!t->id)
return -ENOMEM; return -ENOMEM;
r = hashmap_ensure_put(&m->targets, &target_hash_ops, t->id, t);
if (r < 0)
return r;
*ret = TAKE_PTR(t); *ret = TAKE_PTR(t);
return 0; return 0;
} }
@ -1805,7 +1800,7 @@ static int manager_enumerate_image_class(Manager *m, TargetClass class) {
return r; return r;
HASHMAP_FOREACH(image, images) { HASHMAP_FOREACH(image, images) {
Target *t = NULL; _cleanup_(target_freep) Target *t = NULL;
bool have = false; bool have = false;
if (IMAGE_IS_HOST(image)) if (IMAGE_IS_HOST(image))
@ -1823,6 +1818,11 @@ static int manager_enumerate_image_class(Manager *m, TargetClass class) {
log_debug("Skipping %s because it has no default component", image->path); log_debug("Skipping %s because it has no default component", image->path);
continue; continue;
} }
r = hashmap_ensure_put(&m->targets, &target_hash_ops, t->id, t);
if (r < 0)
return r;
TAKE_PTR(t);
} }
return 0; return 0;
@ -1831,7 +1831,6 @@ static int manager_enumerate_image_class(Manager *m, TargetClass class) {
static int manager_enumerate_components(Manager *m) { static int manager_enumerate_components(Manager *m) {
_cleanup_strv_free_ char **components = NULL; _cleanup_strv_free_ char **components = NULL;
bool have_default; bool have_default;
Target *t;
int r; int r;
r = target_list_components(NULL, &components, &have_default); r = target_list_components(NULL, &components, &have_default);
@ -1839,13 +1838,21 @@ static int manager_enumerate_components(Manager *m) {
return r; return r;
if (have_default) { if (have_default) {
_cleanup_(target_freep) Target *t = NULL;
r = target_new(m, TARGET_HOST, "host", "sysupdate.d", &t); r = target_new(m, TARGET_HOST, "host", "sysupdate.d", &t);
if (r < 0) if (r < 0)
return r; return r;
r = hashmap_ensure_put(&m->targets, &target_hash_ops, t->id, t);
if (r < 0)
return r;
TAKE_PTR(t);
} }
STRV_FOREACH(component, components) { STRV_FOREACH(component, components) {
_cleanup_free_ char *path = NULL; _cleanup_free_ char *path = NULL;
_cleanup_(target_freep) Target *t = NULL;
path = strjoin("sysupdate.", *component, ".d"); path = strjoin("sysupdate.", *component, ".d");
if (!path) if (!path)
@ -1854,6 +1861,11 @@ static int manager_enumerate_components(Manager *m) {
r = target_new(m, TARGET_COMPONENT, *component, path, &t); r = target_new(m, TARGET_COMPONENT, *component, path, &t);
if (r < 0) if (r < 0)
return r; return r;
r = hashmap_ensure_put(&m->targets, &target_hash_ops, t->id, t);
if (r < 0)
return r;
TAKE_PTR(t);
} }
return 0; return 0;