On Sun, Apr 14, 2019 at 7:40 PM Al Viro <viro@xxxxxxxxxxxxxxxxxx> wrote: > > On Sun, Apr 14, 2019 at 07:04:14PM +0300, Amir Goldstein wrote: > > > Another problem is that they seem to be bypassed by several subsystems. > > cachefiles, ecryptfs, overlayfs and nfsd all call the vfs_rename() helper, but > > only cachefiles bothers to call the security_path_rename() hook. > > This is of course true for all other security_path_ hooks. > > I think that is something that requires fixing regardless of the fanotify pre > > modification hooks. I wonder if tomoyo and apparmor developers > > (LSM that implement security_path_ hooks) are aware of those missing > > hooks? > > First of all, _what_ path? You do realize that there is no such thing > as *the* pathname of dentry, right? Yap. > The same filesystem may be mounted > in any number of places, some of which might be visible in a given > namespace (including "none of them" - and you are not even guaranteed > that they are visible in any namespace at all). > > It's not "bypassed", it's "inapplicable and deeply flawed in general". I am assuming that you are referring to the security_path_ hooks in general. I cannot speak on behalf of Tomoyo and Apparmor, but I think I understand why you view path based security policy as flawed. >From fanotify POV, passing the path that was used to operate on dentries to fanotify lets the users choose if they want to get events for all operations on an inode, all operations on a specific filesystem or all operations where the inode was accessed via a specific mount (FAN_MARK_MOUNT). When looking at userspace applications of kernel filesystem change notifications, like https://facebook.github.io/watchman/ I believe what users really want is a subtree watch. So for example, you may want to monitor your git workspace(s) for changes on a large source tree(s) to save time on git index updates. If you bind mount your git work tree and watch the mount for changes, chances are nobody is messing with your source files from another mount and that you do not have hardlinks pointing outside the git workspace root. But the truth is I would much rather that users have a way to mark a subtree root and ask fanotify for events under that subtree. As a matter of fact, I have some private POC patches that allow users to setup a mark on a "subtree root" dentry, which really marks the super block and keep a reference to the dentry. Than every event on that super block is filtered with is_subdir() against the marked dentry. I am just not convinced that is the most efficient way to implement a subtree filter... another though I had was to filter not by subtree, but by project id and let users worry about populating their subtrees of interest with appropriate projids. More comments about ideas that are deeply flawed are welcome. Those comments would hopefully help me navigate towards the mildly flawed ideas ;-) Thanks, Amir.