mirror of
https://github.com/Hopiu/webapi-eca.git
synced 2026-03-16 22:10:31 +00:00
86 lines
2.6 KiB
JavaScript
86 lines
2.6 KiB
JavaScript
'use strict';
|
|
|
|
var cs = require('coffee-script');
|
|
var fs = require('fs'),
|
|
path = require('path'),
|
|
log = require('./logging');
|
|
|
|
exports = module.exports = function(args) {
|
|
args = args || {};
|
|
log(args);
|
|
return module.exports;
|
|
};
|
|
|
|
exports.requireFromString = function(src, name, dir) {
|
|
if(!dir) dir = __dirname;
|
|
|
|
// Allow coffee scripts!
|
|
console.log(cs.compile(src));
|
|
|
|
var id = path.resolve(dir, name, name + '.vm');
|
|
var vm = require('vm'),
|
|
sandbox = {
|
|
log: log,
|
|
needle: require('needle')
|
|
};
|
|
|
|
var m = vm.runInNewContext(src, sandbox, id + '.vm');
|
|
console.log('module loader');
|
|
console.log(m);
|
|
// var m = new module.constructor(id, module);
|
|
// m.paths = module.paths;
|
|
// try {
|
|
// m._compile(src);
|
|
// } catch(err) {
|
|
// err.addInfo = 'during compilation of module ' + name;
|
|
// log.error('LM', err);
|
|
// // log.error('LM', ' during compilation of ' + name + ': ' + err);
|
|
// }
|
|
return m.exports;
|
|
};
|
|
|
|
exports.loadModule = function(directory, name, callback) {
|
|
try {
|
|
fs.readFile(path.resolve(__dirname, '..', directory, name, name + '.js'), 'utf8', function (err, data) {
|
|
if (err) {
|
|
log.error('LM', 'Loading module file!');
|
|
return;
|
|
}
|
|
var mod = exports.requireFromString(data, name, directory);
|
|
if(mod && fs.existsSync(path.resolve(__dirname, '..', directory, name, 'credentials.json'))) {
|
|
fs.readFile(path.resolve(__dirname, '..', directory, name, 'credentials.json'), 'utf8', function (err, auth) {
|
|
if (err) {
|
|
log.error('LM', 'Loading credentials file for "' + name + '"!');
|
|
callback(name, data, mod, null);
|
|
return;
|
|
}
|
|
if(mod.loadCredentials) mod.loadCredentials(JSON.parse(auth));
|
|
callback(name, data, mod, auth);
|
|
});
|
|
} else {
|
|
// Hand back the name, the string contents and the compiled module
|
|
callback(name, data, mod, null);
|
|
}
|
|
});
|
|
} catch(err) {
|
|
log.error('LM', 'Failed loading module "' + name + '"');
|
|
}
|
|
};
|
|
|
|
exports.loadModules = function(directory, callback) {
|
|
fs.readdir(path.resolve(__dirname, '..', directory), function (err, list) {
|
|
if (err) {
|
|
log.error('LM', 'loading modules directory: ' + err);
|
|
return;
|
|
}
|
|
log.print('LM', 'Loading ' + list.length + ' modules from "' + directory + '"');
|
|
list.forEach(function (file) {
|
|
fs.stat(path.resolve(__dirname, '..', directory, file), function (err, stat) {
|
|
if (stat && stat.isDirectory()) {
|
|
exports.loadModule(directory, file, callback);
|
|
}
|
|
});
|
|
});
|
|
});
|
|
};
|
|
|