mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 13:47:41 +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
|
||||||
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
|
-- Load the config-parsing module
|
||||||
config = require "core.configmanager"
|
config = require "core.configmanager"
|
||||||
|
|
||||||
|
@ -119,6 +91,38 @@ function load_libraries()
|
||||||
server = require "net.server"
|
server = require "net.server"
|
||||||
end
|
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()
|
function init_global_state()
|
||||||
bare_sessions = {};
|
bare_sessions = {};
|
||||||
full_sessions = {};
|
full_sessions = {};
|
||||||
|
@ -407,7 +411,12 @@ function cleanup()
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Are you ready? :)
|
-- Are you ready? :)
|
||||||
|
-- These actions are in a strict order, as many depend on
|
||||||
|
-- previous steps to have already been performed
|
||||||
read_config();
|
read_config();
|
||||||
|
init_logging();
|
||||||
|
check_dependencies();
|
||||||
|
sandbox_require();
|
||||||
load_libraries();
|
load_libraries();
|
||||||
init_global_state();
|
init_global_state();
|
||||||
read_version();
|
read_version();
|
||||||
|
|
12
prosodyctl
12
prosodyctl
|
@ -29,12 +29,6 @@ if CFG_DATADIR then
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
require "core.loggingmanager"
|
|
||||||
|
|
||||||
if not require "util.dependencies".check_dependencies() then
|
|
||||||
os.exit(1);
|
|
||||||
end
|
|
||||||
|
|
||||||
config = require "core.configmanager"
|
config = require "core.configmanager"
|
||||||
|
|
||||||
do
|
do
|
||||||
|
@ -63,6 +57,12 @@ do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
require "core.loggingmanager"
|
||||||
|
|
||||||
|
if not require "util.dependencies".check_dependencies() then
|
||||||
|
os.exit(1);
|
||||||
|
end
|
||||||
|
|
||||||
prosody = { hosts = {}, events = events, platform = "posix" };
|
prosody = { hosts = {}, events = events, platform = "posix" };
|
||||||
|
|
||||||
local data_path = config.get("*", "core", "data_path") or CFG_DATADIR or "data";
|
local data_path = config.get("*", "core", "data_path") or CFG_DATADIR or "data";
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue