mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
prosodyctl: Also switch group when we switch user
This commit is contained in:
parent
59c0104106
commit
3417c24b88
1 changed files with 14 additions and 5 deletions
19
prosodyctl
19
prosodyctl
|
@ -66,19 +66,28 @@ require "util.datamanager".set_data_path(data_path);
|
|||
|
||||
-- Switch away from root and into the prosody user --
|
||||
local switched_user, current_uid;
|
||||
|
||||
local want_pposix_version = "0.3.1";
|
||||
local ok, pposix = pcall(require, "util.pposix");
|
||||
|
||||
if ok and pposix then
|
||||
if pposix._VERSION ~= want_pposix_version then print(string.format("Unknown version (%s) of binary pposix module, expected %s", tostring(pposix._VERSION), want_pposix_version)); return; end
|
||||
current_uid = pposix.getuid();
|
||||
if current_uid == 0 then
|
||||
-- We haz root!
|
||||
local desired_user = config.get("*", "core", "prosody_user") or "prosody";
|
||||
local ok, err = pposix.setuid(desired_user);
|
||||
local desired_group = config.get("*", "core", "prosody_group") or desired_user;
|
||||
local ok, err = pposix.setgid(desired_group);
|
||||
if ok then
|
||||
-- Yay!
|
||||
switched_user = true;
|
||||
else
|
||||
ok, err = pposix.setuid(desired_user);
|
||||
if ok then
|
||||
-- Yay!
|
||||
switched_user = true;
|
||||
end
|
||||
end
|
||||
if not switched_user then
|
||||
-- Boo!
|
||||
print("Warning: Couldn't switch to Prosody user '"..tostring(desired_user).."': "..tostring(err));
|
||||
print("Warning: Couldn't switch to Prosody user/group '"..tostring(desired_user).."'/'"..tostring(desired_group).."': "..tostring(err));
|
||||
end
|
||||
end
|
||||
else
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue