mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
prosody, prosodyctl: Re-jiggle load order again, fixes logging config not being obeyed (thanks darkrain)
This commit is contained in:
parent
2294aed6ce
commit
c6b03a6b35
2 changed files with 43 additions and 34 deletions
65
prosody
65
prosody
|
@ -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();
|
||||
|
|
12
prosodyctl
12
prosodyctl
|
@ -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";
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue