use request and a remote ep plugin only endpoint

This commit is contained in:
John McLear 2014-11-04 17:06:47 +00:00
parent b61d8d99d1
commit c7061e47db
1 changed files with 6 additions and 6 deletions

View File

@ -1,6 +1,7 @@
var plugins = require("ep_etherpad-lite/static/js/pluginfw/plugins"); var plugins = require("ep_etherpad-lite/static/js/pluginfw/plugins");
var hooks = require("ep_etherpad-lite/static/js/pluginfw/hooks"); var hooks = require("ep_etherpad-lite/static/js/pluginfw/hooks");
var npm = require("npm"); var npm = require("npm");
var request = require("request");
var npmIsLoaded = false; var npmIsLoaded = false;
var withNpm = function (npmfn) { var withNpm = function (npmfn) {
@ -60,17 +61,16 @@ exports.availablePlugins = null;
var cacheTimestamp = 0; var cacheTimestamp = 0;
exports.getAvailablePlugins = function(maxCacheAge, cb) { exports.getAvailablePlugins = function(maxCacheAge, cb) {
withNpm(function (er) { request("http://etherpad.org/plugins.json", function(er, response, plugins){
if (er) return cb && cb(er); if (er) return cb && cb(er);
if(exports.availablePlugins && maxCacheAge && Math.round(+new Date/1000)-cacheTimestamp <= maxCacheAge) { if(exports.availablePlugins && maxCacheAge && Math.round(+new Date/1000)-cacheTimestamp <= maxCacheAge) {
return cb && cb(null, exports.availablePlugins) return cb && cb(null, exports.availablePlugins)
} }
npm.commands.search(['ep_'], /*silent?*/true, function(er, results) { console.log("plugins", plugins);
if(er) return cb && cb(er); plugins = JSON.parse(plugins);
exports.availablePlugins = results; exports.availablePlugins = plugins;
cacheTimestamp = Math.round(+new Date/1000); cacheTimestamp = Math.round(+new Date/1000);
cb && cb(null, results) cb && cb(null, plugins)
})
}); });
}; };