|
|
@ -50,8 +50,11 @@ module.exports = function (Plugins) {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
function (next) {
|
|
|
|
function (next) {
|
|
|
|
meta.reloadRequired = true;
|
|
|
|
meta.reloadRequired = true;
|
|
|
|
Plugins.fireHook(isActive ? 'action:plugin.deactivate' : 'action:plugin.activate', {id: id});
|
|
|
|
if (isActive) {
|
|
|
|
next();
|
|
|
|
Plugins.fireHook('action:plugin.deactivate', {id: id});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
setImmediate(next);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
], function (err) {
|
|
|
|
], function (err) {
|
|
|
|
if (err) {
|
|
|
|
if (err) {
|
|
|
@ -68,7 +71,6 @@ module.exports = function (Plugins) {
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
function toggleInstall(id, version, callback) {
|
|
|
|
function toggleInstall(id, version, callback) {
|
|
|
|
var type;
|
|
|
|
|
|
|
|
var installed;
|
|
|
|
var installed;
|
|
|
|
async.waterfall([
|
|
|
|
async.waterfall([
|
|
|
|
function (next) {
|
|
|
|
function (next) {
|
|
|
@ -76,7 +78,6 @@ module.exports = function (Plugins) {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
function (_installed, next) {
|
|
|
|
function (_installed, next) {
|
|
|
|
installed = _installed;
|
|
|
|
installed = _installed;
|
|
|
|
type = installed ? 'uninstall' : 'install';
|
|
|
|
|
|
|
|
Plugins.isActive(id, next);
|
|
|
|
Plugins.isActive(id, next);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
function (active, next) {
|
|
|
|
function (active, next) {
|
|
|
@ -86,17 +87,20 @@ module.exports = function (Plugins) {
|
|
|
|
});
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
next();
|
|
|
|
setImmediate(next);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
function (next) {
|
|
|
|
function (next) {
|
|
|
|
runNpmCommand(type, id, version || 'latest', next);
|
|
|
|
runNpmCommand(installed ? 'uninstall' : 'install', id, version || 'latest', next);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
function (next) {
|
|
|
|
function (next) {
|
|
|
|
Plugins.get(id, next);
|
|
|
|
Plugins.get(id, next);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
function (pluginData, next) {
|
|
|
|
function (pluginData, next) {
|
|
|
|
Plugins.fireHook('action:plugin.' + type, {id: id, version: version});
|
|
|
|
if (installed) {
|
|
|
|
next(null, pluginData);
|
|
|
|
Plugins.fireHook('action:plugin.uninstall', {id: id, version: version});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
setImmediate(next, null, pluginData);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
], callback);
|
|
|
|
], callback);
|
|
|
|
}
|
|
|
|
}
|
|
|
|