mirror of
https://github.com/cnodejs/nodeclub.git
synced 2025-12-08 19:55:55 +00:00
36 lines
1.0 KiB
JavaScript
36 lines
1.0 KiB
JavaScript
var fs = require('fs');
|
|
var path = require('path');
|
|
var ndir = require('ndir');
|
|
var config = require('../config').config;
|
|
|
|
exports.uploadImage = function (req, res, next) {
|
|
if (!req.session || !req.session.user) {
|
|
res.send({ status: 'forbidden' });
|
|
return;
|
|
}
|
|
var file = req.files && req.files.userfile;
|
|
if (!file) {
|
|
res.send({ status: 'failed', message: 'no file' });
|
|
return;
|
|
}
|
|
var uid = req.session.user._id.toString();
|
|
var userDir = path.join(config.upload_dir, uid);
|
|
ndir.mkdir(userDir, function (err) {
|
|
if (err) {
|
|
return next(err);
|
|
}
|
|
var filename = Date.now() + '_' + file.name;
|
|
var savepath = path.resolve(path.join(userDir, filename));
|
|
if (savepath.indexOf(path.resolve(userDir)) !== 0) {
|
|
return res.send({status: 'forbidden'});
|
|
}
|
|
fs.rename(file.path, savepath, function (err) {
|
|
if (err) {
|
|
return next(err);
|
|
}
|
|
var url = '/upload/' + uid + '/' + encodeURIComponent(filename);
|
|
res.send({ status: 'success', url: url });
|
|
});
|
|
});
|
|
};
|