-
-
Notifications
You must be signed in to change notification settings - Fork 15.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
update-users-groups.pl: create intermediate home directories as 0755 #50857
Conversation
I am not sure if really we should fix this in NixOS or leave it up to the user to make sure the access is right. We don't really know, what the intention of the users is in that case. The upper directory could be also owned by the user itself. A simple fix could be a user could apply is: systemd.tmpfiles.rules = [
"d /some/home 0755 root root"
]; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Even though this might not be the best solution, it's a solution, and I think this is better to merge this than continue leaving it broken.
Unless somebody brings up a good reason this shouldn't be done I'll merge this soon
make_path($u->{home}, { mode => 0700 }) if ! -e $u->{home}; | ||
if (! -e $u->{home}) { | ||
my @dirs = splitdir($u->{home}); | ||
make_path(catdir(@dirs[0..$#dirs - 1]), { mode => 0755 }); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wouldn't it be simpler to only call make_path
on the last component? That functions seems to create all intermediate directories already
Thank you for your contributions.
|
See my concern above: #50857 (comment) It's easier for someone, who uses weird home directories to also take care of fixing the ownership with tmpfiles rules rather than working around our assumptions that we do when creating the user's home directory. |
Motivation for this change
Creates directories between / and the home directory as 0755 instead of 0700.
Fixes #10888 where users with home dirs outside
/home
receive "No directory, logging in with HOME=/" upon login and cannot access their home directory.In the default installation,
/home/
is 0755 so I used that for other locations.Things done
sandbox
innix.conf
on non-NixOS)nix-shell -p nox --run "nox-review wip"
./result/bin/
)nix path-info -S
before and after)