mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
Merge 0.11->trunk
This commit is contained in:
commit
dba007553f
3 changed files with 67 additions and 12 deletions
|
@ -112,7 +112,12 @@ local function write_pidfile()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local daemonize = module:get_option("daemonize", prosody.installed);
|
local daemonize = prosody.opts.daemonize;
|
||||||
|
|
||||||
|
if daemonize == nil then
|
||||||
|
-- Fall back to config file if not specified on command-line
|
||||||
|
daemonize = module:get_option("daemonize", prosody.installed);
|
||||||
|
end
|
||||||
|
|
||||||
local function remove_log_sinks()
|
local function remove_log_sinks()
|
||||||
local lm = require "core.loggingmanager";
|
local lm = require "core.loggingmanager";
|
||||||
|
|
6
prosody
6
prosody
|
@ -43,11 +43,7 @@ if CFG_DATADIR then
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if #arg > 0 and arg[1] ~= "--config" then
|
|
||||||
print("Unknown command-line option: "..tostring(arg[1]));
|
|
||||||
print("Perhaps you meant to use prosodyctl instead?");
|
|
||||||
return 1;
|
|
||||||
end
|
|
||||||
|
|
||||||
local startup = require "util.startup";
|
local startup = require "util.startup";
|
||||||
local async = require "util.async";
|
local async = require "util.async";
|
||||||
|
|
|
@ -13,16 +13,69 @@ local dependencies = require "util.dependencies";
|
||||||
|
|
||||||
local original_logging_config;
|
local original_logging_config;
|
||||||
|
|
||||||
|
local short_params = { D = "daemonize", F = "no-daemonize" };
|
||||||
|
local value_params = { config = true };
|
||||||
|
|
||||||
|
function startup.parse_args()
|
||||||
|
local parsed_opts = {};
|
||||||
|
|
||||||
|
if #arg > 0 and arg[1] ~= "--config" then
|
||||||
|
while true do
|
||||||
|
local raw_param = arg[1];
|
||||||
|
if not raw_param then
|
||||||
|
break;
|
||||||
|
end
|
||||||
|
|
||||||
|
local prefix = raw_param:match("^%-%-?");
|
||||||
|
if not prefix then
|
||||||
|
break;
|
||||||
|
elseif prefix == "--" and raw_param == "--" then
|
||||||
|
table.remove(arg, 1);
|
||||||
|
break;
|
||||||
|
end
|
||||||
|
local param = table.remove(arg, 1):sub(#prefix+1);
|
||||||
|
if #param == 1 then
|
||||||
|
param = short_params[param];
|
||||||
|
end
|
||||||
|
|
||||||
|
if not param then
|
||||||
|
print("Unknown command-line option: "..tostring(param));
|
||||||
|
print("Perhaps you meant to use prosodyctl instead?");
|
||||||
|
os.exit(1);
|
||||||
|
end
|
||||||
|
|
||||||
|
local param_k, param_v;
|
||||||
|
if value_params[param] then
|
||||||
|
param_k, param_v = param, table.remove(arg, 1);
|
||||||
|
if not param_v then
|
||||||
|
print("Expected a value to follow command-line option: "..raw_param);
|
||||||
|
os.exit(1);
|
||||||
|
end
|
||||||
|
else
|
||||||
|
param_k, param_v = param:match("^([^=]+)=(.+)$");
|
||||||
|
if not param_k then
|
||||||
|
if param:match("^no%-") then
|
||||||
|
param_k, param_v = param:sub(4), false;
|
||||||
|
else
|
||||||
|
param_k, param_v = param, true;
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
parsed_opts[param_k] = param_v;
|
||||||
|
end
|
||||||
|
end
|
||||||
|
prosody.opts = parsed_opts;
|
||||||
|
end
|
||||||
|
|
||||||
function startup.read_config()
|
function startup.read_config()
|
||||||
local filenames = {};
|
local filenames = {};
|
||||||
|
|
||||||
local filename;
|
local filename;
|
||||||
if arg[1] == "--config" and arg[2] then
|
if prosody.opts.config then
|
||||||
table.insert(filenames, arg[2]);
|
table.insert(filenames, prosody.opts.config);
|
||||||
if CFG_CONFIGDIR then
|
if CFG_CONFIGDIR then
|
||||||
table.insert(filenames, CFG_CONFIGDIR.."/"..arg[2]);
|
table.insert(filenames, CFG_CONFIGDIR.."/"..prosody.opts.config);
|
||||||
end
|
end
|
||||||
table.remove(arg, 1); table.remove(arg, 1);
|
|
||||||
elseif os.getenv("PROSODY_CONFIG") then -- Passed by prosodyctl
|
elseif os.getenv("PROSODY_CONFIG") then -- Passed by prosodyctl
|
||||||
table.insert(filenames, os.getenv("PROSODY_CONFIG"));
|
table.insert(filenames, os.getenv("PROSODY_CONFIG"));
|
||||||
else
|
else
|
||||||
|
@ -426,8 +479,7 @@ function startup.switch_user()
|
||||||
os.exit(1);
|
os.exit(1);
|
||||||
end
|
end
|
||||||
prosody.current_uid = pposix.getuid();
|
prosody.current_uid = pposix.getuid();
|
||||||
local arg_root = arg[1] == "--root";
|
local arg_root = prosody.opts.root;
|
||||||
if arg_root then table.remove(arg, 1); end
|
|
||||||
if prosody.current_uid == 0 and config.get("*", "run_as_root") ~= true and not arg_root then
|
if prosody.current_uid == 0 and config.get("*", "run_as_root") ~= true and not arg_root then
|
||||||
-- We haz root!
|
-- We haz root!
|
||||||
local desired_user = config.get("*", "prosody_user") or "prosody";
|
local desired_user = config.get("*", "prosody_user") or "prosody";
|
||||||
|
@ -536,6 +588,7 @@ end
|
||||||
|
|
||||||
-- prosodyctl only
|
-- prosodyctl only
|
||||||
function startup.prosodyctl()
|
function startup.prosodyctl()
|
||||||
|
startup.parse_args();
|
||||||
startup.init_global_state();
|
startup.init_global_state();
|
||||||
startup.read_config();
|
startup.read_config();
|
||||||
startup.force_console_logging();
|
startup.force_console_logging();
|
||||||
|
@ -557,6 +610,7 @@ end
|
||||||
function startup.prosody()
|
function startup.prosody()
|
||||||
-- These actions are in a strict order, as many depend on
|
-- These actions are in a strict order, as many depend on
|
||||||
-- previous steps to have already been performed
|
-- previous steps to have already been performed
|
||||||
|
startup.parse_args();
|
||||||
startup.init_global_state();
|
startup.init_global_state();
|
||||||
startup.read_config();
|
startup.read_config();
|
||||||
startup.init_logging();
|
startup.init_logging();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue