fusefrontend: fix setting xattrs on directories
Directories cannot be opened read-write. Retry with RDONLY.
This commit is contained in:
parent
3365cfc02b
commit
eff35e60b6
@ -71,6 +71,10 @@ func (fs *FS) SetXAttr(relPath string, attr string, data []byte, flags int, cont
|
|||||||
|
|
||||||
// O_NONBLOCK to not block on FIFOs.
|
// O_NONBLOCK to not block on FIFOs.
|
||||||
fd, err := fs.openBackingFile(relPath, syscall.O_WRONLY|syscall.O_NONBLOCK)
|
fd, err := fs.openBackingFile(relPath, syscall.O_WRONLY|syscall.O_NONBLOCK)
|
||||||
|
// Directories cannot be opened read-write. Retry.
|
||||||
|
if err == syscall.EISDIR {
|
||||||
|
fd, err = fs.openBackingFile(relPath, syscall.O_RDONLY|syscall.O_DIRECTORY|syscall.O_NONBLOCK)
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fuse.ToStatus(err)
|
return fuse.ToStatus(err)
|
||||||
}
|
}
|
||||||
@ -100,6 +104,10 @@ func (fs *FS) RemoveXAttr(relPath string, attr string, context *fuse.Context) fu
|
|||||||
|
|
||||||
// O_NONBLOCK to not block on FIFOs.
|
// O_NONBLOCK to not block on FIFOs.
|
||||||
fd, err := fs.openBackingFile(relPath, syscall.O_WRONLY|syscall.O_NONBLOCK)
|
fd, err := fs.openBackingFile(relPath, syscall.O_WRONLY|syscall.O_NONBLOCK)
|
||||||
|
// Directories cannot be opened read-write. Retry.
|
||||||
|
if err == syscall.EISDIR {
|
||||||
|
fd, err = fs.openBackingFile(relPath, syscall.O_RDONLY|syscall.O_DIRECTORY|syscall.O_NONBLOCK)
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fuse.ToStatus(err)
|
return fuse.ToStatus(err)
|
||||||
}
|
}
|
||||||
|
@ -124,6 +124,16 @@ func TestSetGetRmFifo(t *testing.T) {
|
|||||||
setGetRmList(fn)
|
setGetRmList(fn)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Test xattr set, get, rm on a directory. This should not fail with EISDIR.
|
||||||
|
func TestSetGetRmDir(t *testing.T) {
|
||||||
|
fn := test_helpers.DefaultPlainDir + "/TestSetGetRmDir"
|
||||||
|
err := syscall.Mkdir(fn, 0700)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("creating fifo failed: %v", err)
|
||||||
|
}
|
||||||
|
setGetRmList(fn)
|
||||||
|
}
|
||||||
|
|
||||||
func TestXattrSetEmpty(t *testing.T) {
|
func TestXattrSetEmpty(t *testing.T) {
|
||||||
attr := "user.foo"
|
attr := "user.foo"
|
||||||
fn := test_helpers.DefaultPlainDir + "/TestXattrSetEmpty1"
|
fn := test_helpers.DefaultPlainDir + "/TestXattrSetEmpty1"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user