tools/ejabberd2prosody: Fixed private storage export
[prosody.git] / core / configmanager.lua
index 049862c204c23f6af5dee1b6ae5ee9700011095f..37646017407cbc4f61a8b29bbff7baacd9894da1 100644 (file)
@@ -1,4 +1,4 @@
--- Prosody IM v0.3
+-- Prosody IM v0.4
 -- Copyright (C) 2008-2009 Matthew Wild
 -- Copyright (C) 2008-2009 Waqas Hussain
 -- 
@@ -9,8 +9,10 @@
 
 
 local _G = _G;
-local  setmetatable, loadfile, pcall, rawget, rawset, io, error, dofile = 
-               setmetatable, loadfile, pcall, rawget, rawset, io, error, dofile;
+local  setmetatable, loadfile, pcall, rawget, rawset, io, error, dofile, type = 
+               setmetatable, loadfile, pcall, rawget, rawset, io, error, dofile, type;
+
+local eventmanager = require "core.eventmanager";
 
 module "configmanager"
 
@@ -68,6 +70,9 @@ function load(filename, format)
                if f then 
                        local ok, err = parsers[format].load(f:read("*a"));
                        f:close();
+                       if ok then
+                               eventmanager.fire_event("config-reloaded", { filename = filename, format = format });
+                       end
                        return ok, "parser", err;
                end
                return f, "file", err;
@@ -116,11 +121,15 @@ do
                env.host = env.Host;
                
                function env.Component(name)
+                       set(name, "core", "component_module", "component");
+                       -- Don't load the global modules by default
+                       set(name, "core", "modules_enable", false);
+                       rawset(env, "__currenthost", name);
+       
                        return function (module)
-                                       set(name, "core", "component_module", module);
-                                       -- Don't load the global modules by default
-                                       set(name, "core", "modules_enable", false);
-                                       rawset(env, "__currenthost", name);
+                                       if type(module) == "string" then
+                                               set(name, "core", "component_module", module);
+                                       end
                                end
                end
                env.component = env.Component;