2015-07-12 07:54:03 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var _ = require('underscore'),
|
|
|
|
path = require('path'),
|
2016-01-05 11:18:20 +00:00
|
|
|
chokidar = require('chokidar');
|
2015-07-12 07:54:03 +00:00
|
|
|
|
|
|
|
exports.init = function(app, callback) {
|
2016-01-05 11:18:20 +00:00
|
|
|
var logger = app.lib.logger('projects watcher');
|
|
|
|
|
2015-07-12 07:54:03 +00:00
|
|
|
// start file watcher for reloading projects on change
|
|
|
|
var syncProject = function(filename, fileInfo) {
|
2016-01-05 11:18:20 +00:00
|
|
|
var projectName = path.relative(
|
|
|
|
app.config.paths.projects,
|
|
|
|
path.dirname(filename)
|
|
|
|
);
|
2015-07-12 07:54:03 +00:00
|
|
|
|
2016-01-05 11:18:20 +00:00
|
|
|
if (app.projects.get(projectName)) {
|
2015-07-12 07:54:03 +00:00
|
|
|
logger.log('Unload project: "' + projectName + '"');
|
2016-01-05 11:18:20 +00:00
|
|
|
app.projects.unload(projectName);
|
2015-07-12 07:54:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// on add or change (info is falsy on unlink)
|
|
|
|
if (fileInfo) {
|
|
|
|
logger.log('Load project "' + projectName + '" on change');
|
2016-01-05 11:18:20 +00:00
|
|
|
app.projects.load(projectName, function(err) {
|
2015-07-12 07:54:03 +00:00
|
|
|
if (err) {
|
|
|
|
return logger.error(
|
|
|
|
'Error during load project "' + projectName + '": ',
|
|
|
|
err.stack || err
|
|
|
|
);
|
|
|
|
}
|
|
|
|
logger.log(
|
|
|
|
'Project "' + projectName + '" loaded:',
|
2016-01-05 11:18:20 +00:00
|
|
|
JSON.stringify(app.projects.get(projectName), null, 4)
|
2015-07-12 07:54:03 +00:00
|
|
|
);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// NOTE: currently after add remove and then add same file events will
|
|
|
|
// not be emitted
|
|
|
|
var watcher = chokidar.watch(
|
|
|
|
path.join(app.config.paths.projects, '*', 'config.*'),
|
2015-07-14 21:52:25 +00:00
|
|
|
{ignoreInitial: true, depth: 1}
|
2015-07-12 07:54:03 +00:00
|
|
|
);
|
|
|
|
watcher.on('add', syncProject);
|
|
|
|
watcher.on('change', syncProject);
|
|
|
|
watcher.on('unlink', syncProject);
|
|
|
|
|
|
|
|
watcher.on('error', function(err) {
|
|
|
|
logger.error('File watcher error occurred: ', err.stack || err);
|
|
|
|
});
|
|
|
|
|
|
|
|
callback();
|
|
|
|
};
|