Awesome
evfs: Erlang Virtual Filesystem
This application allows to create virtual filesystems on top of standard
file
API. Imagine if you can do this:
> {ok, Bin} = file:read_file("http://www.google.com/").
Or this:
> {ok, Bin} = file:read_file("config://host").
Looks interesting, right? Now, basically, because of the way evfs operates,
you can feed unsuspecting Erlang code file names that are served off your VFSes.
That's where the fun begins. (By the way, there's already some limited support
for HTTP, just register evfs_httpc_handler
: evfs:register(evfs_httpc_handler, default)
).
Also, the way evfs is organized, you are not limited to this "scheme" way of overriding the filesystem. You can override particular files, for example, or whole directories -- or do that basing on some external state. So, for example, if some application expects a file at a hard coded location, just override it with your VFS.
You can register any number of virtual FS handlers using evfs:register/2
function.
Also, by default, you get the handler that redirects file:// and plain filename requests
to the original file server, but you can unregiser it with evfs:unregister/1
if you need.
Please bear in mind that this is a very early prototype.
For an example on how to build a VFS, look into test/evfs_test_fs.erl
. Hopefully
it will help.