jsdav-ext
Version:
jsDAV allows you to easily add WebDAV support to a NodeJS application. jsDAV is meant to cover the entire standard, and attempts to allow integration using an easy to understand API.
126 lines (114 loc) • 3.86 kB
JavaScript
/*
* @package jsDAV
* @subpackage DAV
* @copyright Copyright(c) 2011 Ajax.org B.V. <info AT ajax DOT org>
* @author Mike de Boer <info AT mikedeboer DOT nl>
* @license http://github.com/mikedeboer/jsDAV/blob/master/LICENSE MIT License
*/
;
var jsDAV_Tree = require("./../../tree");
var jsDAV_FS_Directory = require("./directory");
var jsDAV_FS_File = require("./file");
var Fs = require("fs");
var Path = require("path");
var Async = require("asyncjs");
var Util = require("./../../../shared/util");
var Exc = require("./../../../shared/exceptions");
/**
* jsDAV_FS_Tree
*
* Creates this tree
* Supply the path you'd like to share.
*
* @param {String} basePath
* @contructor
*/
var jsDAV_FS_Tree = module.exports = jsDAV_Tree.extend({
initialize: function(basePath) {
this.basePath = basePath;
},
/**
* Returns a new node for the given path
*
* @param {String} path
* @return void
*/
getNodeForPath: function(path, cbfstree) {
var realPath = this.getRealPath(path);
var nicePath = this.stripSandbox(realPath);
if (!this.insideSandbox(realPath))
return cbfstree(new Exc.Forbidden("You are not allowed to access " + nicePath));
Fs.stat(realPath, function(err, stat) {
if (!Util.empty(err))
return cbfstree(new Exc.FileNotFound("File at location " + nicePath + " not found"));
cbfstree(null, stat.isDirectory()
? jsDAV_FS_Directory.new(realPath,path || "/")
: jsDAV_FS_File.new(realPath,path || "/"))
});
},
/**
* Returns the real filesystem path for a webdav url.
*
* @param {String} publicPath
* @return string
*/
getRealPath: function(publicPath) {
return Path.join(Util.rtrim(this.basePath, '/\\\\'), Util.trim(publicPath, '/\\\\'));
},
/**
* Copies a file or directory.
*
* This method must work recursively and delete the destination
* if it exists
*
* @param {String} source
* @param {String} destination
* @return void
*/
copy: function(source, destination, cbfscopy) {
source = this.getRealPath(source);
destination = this.getRealPath(destination);
this.realCopy(source, destination, cbfscopy);
},
/**
* Used by self::copy
*
* @param {String} source
* @param {String} destination
* @return void
*/
realCopy: function(source, destination, cbfsrcopy) {
if (!this.insideSandbox(destination)) {
return cbfsrcopy(new Exc.Forbidden("You are not allowed to copy to " +
this.stripSandbox(destination)));
}
Fs.stat(source, function(err, stat) {
if (!Util.empty(err))
return cbfsrcopy(err);
if (stat.isFile())
Async.copyfile(source, destination, true, cbfsrcopy);
else
Async.copytree(source, destination, cbfsrcopy);
});
},
/**
* Moves a file or directory recursively.
*
* If the destination exists, delete it first.
*
* @param {String} source
* @param {String} destination
* @return void
*/
move: function(source, destination, cbfsmove) {
source = this.getRealPath(source);
destination = this.getRealPath(destination);
if (!this.insideSandbox(destination)) {
return cbfsmove(new Exc.Forbidden("You are not allowed to move to " +
this.stripSandbox(destination)));
}
Fs.rename(source, destination, function(err) {
cbfsmove(err, source, destination);
});
}
});