-
Notifications
You must be signed in to change notification settings - Fork 257
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
permissions error for chmod on new socket files w/ force_owner #629
Comments
Hi, thanks for the report. I tried to reproduce the problem like this: As user 1027:
As user 1026:
2nd terminal:
...but this seems to work ok. Can you reproduce the issue with nc? |
After further investigation, it seems I may have hastily reached some inaccurate conclusions. The issue may not be a regression, and is not related to sockets as much as permissions. It seems now simply that when a mount is made with either the Is this behavior intentional? |
Hmm, cannot reproduce
|
I am having trouble reproducing too, which may simply speak to the sloppiness of my testing. However, where I notice a consistent problem is running an application built on Twisted, which depends on a socket for IPC. The process is to create a socket and to give it mode 666, which consistently fails, except when I run it with a break point. Then, as long as I continue manually without any further interaction, the operation succeeds. These observations suggest a race condition in Twisted, but as it seems none have yet been reported, it may at least be useful also to consider whether the current design or implementation in Gocryptfs opens the possibility for such issues more so than other file systems. |
Thanks, the link helped. I can reproduce this now with nc:
|
Bug in gocryptfs! And this is the fix, will merge soon: diff --git a/internal/fusefrontend/node.go b/internal/fusefrontend/node.go
index 182cda5..21348f2 100644
--- a/internal/fusefrontend/node.go
+++ b/internal/fusefrontend/node.go
@@ -278,6 +278,11 @@ func (n *Node) Mknod(ctx context.Context, name string, mode, rdev uint32, out *f
return
}
inode = n.newChild(ctx, st, out)
+
+ if rn.args.ForceOwner != nil {
+ out.Owner = *rn.args.ForceOwner
+ }
+
return inode, 0
}
|
PS: The reason that the breakpoint fixed things in your testing is that the problem disappears when the FUSE attribute cache expires after 2 seconds. |
I'm glad you were able to find a way to reproduce. I was beginning to feel quite confused about the inconsistency, and embarrassed about the quality of the test cases. For the case you reproduced, the failure depends on an entry previously existing with the same name, leaving artifacts not cleared synchronously? Would the patch be safe to overlay on the head of |
When a socket file is created (MKNOD fuse command), gocryptfs sends the file attributes of the new file to the kernel. The bug is that gocryptfs does not apply force_owner to the attributes at this point. The kernel remembers these attributes for two seconds. After the two seconds, the kernel queries the file attributes again (GETATTR fuse command), and gocryptfs does apply force_owner. Patch is completely safe. |
Ran into this myself:
Then doing any chmod or chown inside |
@balupton I'm not sure if you are seeing the same issue, but if it you are, the patch I just pushed fixes it. |
I have tried working with version 2.2.1-18-g5749e70 (go-fuse v2.1.1-0.20211219085202-934a183ed914; 2021-12-26 go1.13.8 linux/amd64) (built locally from development repository, commit 5749e70), and discovered what I would describe as a regression.
Permission is denied for opening a socket file on the mounted file system.
The problem is not appearing with gocryptfs 1.7.1 (go-fuse 0.0~git20190214.58dcd77) (available through distribution).
Note that I have only tested with
force_owner
andnonempty
options in effect. Options are the same on both tests (expressed with--
syntax on later version). The user attempting to access the socket is the user receiving the forced ownership. This user has sufficient permissions for the file on both the mounted and ciphered sides.The text was updated successfully, but these errors were encountered: