[Twisted-Python] twisted.vfs issues

James Y Knight foom at fuhm.net
Wed Sep 28 20:39:34 EDT 2005


On Sep 28, 2005, at 3:49 PM, Andy Gayton wrote:
> There's getMetadata. That let's you return arbitrary attributes.
>
> Would that cover what you're thinking?

No -- one problem is that extended metadata can be potentially very  
large (just as large as the file's normal contents). Another is that  
there may be potentially a large number of such attributes. So, you  
really don't want to return all of it with one call -- you want to  
explicitly ask for certain attributes. See the getxattr, listxattr,  
etc functions for what it the low-level functionality looks like in  
linux. At the moment this interface varies slightly between OSX,  
FreeBSD, and Linux, but they're almost the same. The OSX one adds an  
offset parameter to get/set, and the freebsd one adds a "namespace"  
parameter, to distinguish between root-only attributes and user  
attributes.

I think it may be best to model it as a special kind of child, as it  
seems as if that's the way people are moving their thinking anyhow.
  IFileSystemNode.xattrContainer() -> IFileSystemContainer

That returned object would then allow the use of the same createFile/ 
child/remove/rename/open/read operations as on normal children. It  
would have to throw errors if you try doing excessively "interesting"  
things, like trying to create directories in it, but I think that's  
probably okay.

On the other hand, some people think xattrs are only for small  
metadata, and that "subfiles" or "named forks" are an altogether  
different thing. I'm not sure if that means that it's necessarily a  
bad idea to present both as fileish objects though.

Some interface to this is necessary for properly functioning WebDAV  
(and smb if anyone ever wanted to implement that mess).

> Protocol's should try to get by with as little metadata as they  
> can.  If a backend doesn't supply a bit of metadata a protocol must  
> have, then it won't be able to be used with the protocol.

Support for xattrs can also be optional in a backend.

Eventually, support for POSIX ACLs should also be considered. I don't  
really have the first clue how that should be modeled though.

James




More information about the Twisted-Python mailing list