prosody, prosodyctl: Re-jiggle load order again, fixes logging config not being obeyed (thanks darkrain)

This commit is contained in:
Matthew Wild 2010-02-11 11:31:14 +00:00
parent 2294aed6ce
commit c6b03a6b35
2 changed files with 43 additions and 34 deletions

65
prosody
View file

@ -32,34 +32,6 @@ if CFG_DATADIR then
end
end
-- Initialize logging
require "core.loggingmanager"
-- Check runtime dependencies
if not require "util.dependencies".check_dependencies() then
os.exit(1);
end
-- Replace require() with one that doesn't pollute _G, required
-- for neat sandboxing of modules
do
local _realG = _G;
local _real_require = require;
function require(...)
local curr_env = getfenv(2);
local curr_env_mt = getmetatable(getfenv(2));
local _realG_mt = getmetatable(_realG);
if curr_env_mt and curr_env_mt.__index and not curr_env_mt.__newindex and _realG_mt then
local old_newindex
old_newindex, _realG_mt.__newindex = _realG_mt.__newindex, curr_env;
local ret = _real_require(...);
_realG_mt.__newindex = old_newindex;
return ret;
end
return _real_require(...);
end
end
-- Load the config-parsing module
config = require "core.configmanager"
@ -119,6 +91,38 @@ function load_libraries()
server = require "net.server"
end
function init_logging()
-- Initialize logging
require "core.loggingmanager"
end
function check_dependencies()
-- Check runtime dependencies
if not require "util.dependencies".check_dependencies() then
os.exit(1);
end
end
function sandbox_require()
-- Replace require() with one that doesn't pollute _G, required
-- for neat sandboxing of modules
local _realG = _G;
local _real_require = require;
function require(...)
local curr_env = getfenv(2);
local curr_env_mt = getmetatable(getfenv(2));
local _realG_mt = getmetatable(_realG);
if curr_env_mt and curr_env_mt.__index and not curr_env_mt.__newindex and _realG_mt then
local old_newindex
old_newindex, _realG_mt.__newindex = _realG_mt.__newindex, curr_env;
local ret = _real_require(...);
_realG_mt.__newindex = old_newindex;
return ret;
end
return _real_require(...);
end
end
function init_global_state()
bare_sessions = {};
full_sessions = {};
@ -407,7 +411,12 @@ function cleanup()
end
-- Are you ready? :)
-- These actions are in a strict order, as many depend on
-- previous steps to have already been performed
read_config();
init_logging();
check_dependencies();
sandbox_require();
load_libraries();
init_global_state();
read_version();

View file

@ -29,12 +29,6 @@ if CFG_DATADIR then
end
end
require "core.loggingmanager"
if not require "util.dependencies".check_dependencies() then
os.exit(1);
end
config = require "core.configmanager"
do
@ -63,6 +57,12 @@ do
end
end
require "core.loggingmanager"
if not require "util.dependencies".check_dependencies() then
os.exit(1);
end
prosody = { hosts = {}, events = events, platform = "posix" };
local data_path = config.get("*", "core", "data_path") or CFG_DATADIR or "data";