diff options
author | Lennart Poettering <lennart@poettering.net> | 2022-12-21 10:00:06 +0100 |
---|---|---|
committer | Yu Watanabe <watanabe.yu+github@gmail.com> | 2022-12-22 10:30:35 +0900 |
commit | 80ce8580f5aa6b03fa13a0b3b30207bc9b5c5fe0 (patch) | |
tree | c18332bf3df4321d274a4a4775091d2bfc82644b /src/gpt-auto-generator | |
parent | e20bae24d138e96aac6d8c99a396df0a8773876e (diff) | |
download | systemd-80ce8580f5aa6b03fa13a0b3b30207bc9b5c5fe0.tar.gz |
dissect-image: let's lock down fstypes a bit
When we dissect images automatically, let's be a bit more conservative
with the file system types we are willing to mount: only mount common
file systems automatically.
Explicit mounts requested by admins should always be OK, but when we do
automatic mounts, let's not permit barely maintained, possibly legacy
file systems.
The list for now covers the four common writable and two common
read-only file systems. Sooner or later we might want to add more to the
list.
Also, it might make sense to eventually make this configurable via the
image dissection policy logic.
Diffstat (limited to 'src/gpt-auto-generator')
-rw-r--r-- | src/gpt-auto-generator/gpt-auto-generator.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/gpt-auto-generator/gpt-auto-generator.c b/src/gpt-auto-generator/gpt-auto-generator.c index d697a9b362..1d626f2a5a 100644 --- a/src/gpt-auto-generator/gpt-auto-generator.c +++ b/src/gpt-auto-generator/gpt-auto-generator.c @@ -170,6 +170,15 @@ static int add_mount( what = crypto_what; fstype = NULL; + } else if (fstype) { + r = dissect_fstype_ok(fstype); + if (r < 0) + return log_error_errno(r, "Unable to determine of dissected file system type '%s' is permitted: %m", fstype); + if (!r) + return log_error_errno( + SYNTHETIC_ERRNO(EIDRM), + "Refusing to automatically mount uncommon file system '%s' to '%s'.", + fstype, where); } r = unit_name_from_path(where, ".mount", &unit); |