Changeset

443:bd1397b1dfc9

Merge from waqas
author Matthew Wild <mwild1@gmail.com>
date Thu, 27 Nov 2008 17:12:05 +0000
parents 440:dee02bf4656a (diff) 442:722f63c70a77 (current diff)
children 444:77485b9b840c
files
diffstat 2 files changed, 40 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/core/modulemanager.lua	Thu Nov 27 21:49:31 2008 +0500
+++ b/core/modulemanager.lua	Thu Nov 27 17:12:05 2008 +0000
@@ -27,6 +27,9 @@
 
 
 function load(host, module_name, config)
+	if not (host and module_name) then
+		return nil, "insufficient-parameters";
+	end
 	local mod, err = loadfile("plugins/mod_"..module_name..".lua");
 	if not mod then
 		log("error", "Unable to load module '%s': %s", module_name or "nil", err or "nil");
@@ -59,6 +62,23 @@
 	return true;
 end
 
+function is_loaded(host, name)
+	return modulemap[host] and modulemap[host][name] and true;
+end
+
+function unload(host, name, ...)
+	local mod = modulemap[host] and modulemap[host][name];
+	if not mod then return nil, "module-not-loaded"; end
+	
+	if type(mod.unload) == "function" then
+		local ok, err = pcall(mod.unload, ...)
+		if (not ok) and err then
+			log("warn", "Non-fatal error unloading module '%s' from '%s': %s", name, host, err);
+		end
+	end
+	
+end
+
 function handle_stanza(host, origin, stanza)
 	local name, xmlns, origin_type = stanza.name, stanza.attr.xmlns, origin.type;
 	
--- a/plugins/mod_console.lua	Thu Nov 27 21:49:31 2008 +0500
+++ b/plugins/mod_console.lua	Thu Nov 27 17:12:05 2008 +0000
@@ -37,7 +37,7 @@
 		-- Handle new connection
 		session = console:new_session(conn);
 		sessions[conn] = session;
-		session.print("Welcome to the lxmppd admin console!");
+		printbanner(session);
 	end
 	if data then
 		-- Handle data
@@ -129,9 +129,9 @@
 end
 
 def_env.module = {};
-function def_env.module:load(name)
+function def_env.module:load(name, host)
 	local mm = require "modulemanager";
-	local ok, err = mm.load(name);
+	local ok, err = mm.load(host or self.env.host, name);
 	if not ok then
 		return false, err or "Unknown error loading module";
 	end
@@ -163,3 +163,20 @@
 
 function def_env.hosts:add(name)
 end
+
+-------------
+
+function printbanner(session)
+session.print [[
+                   ____                \   /     _       
+                    |  _ \ _ __ ___  ___  _-_   __| |_   _ 
+                    | |_) | '__/ _ \/ __|/ _ \ / _` | | | |
+                    |  __/| | | (_) \__ \ |_| | (_| | |_| |
+                    |_|   |_|  \___/|___/\___/ \__,_|\__, |
+                    A study in simplicity            |___/ 
+
+]]
+session.print("Welcome to the Prosody administration console. For a list of commands, type: help");
+session.print("You may find more help on using this console in our online documentation at ");
+session.print("http://prosody.im/doc/console\n");
+end