aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/muc
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/muc')
-rw-r--r--plugins/muc/subject.lib.lua12
1 files changed, 6 insertions, 6 deletions
diff --git a/plugins/muc/subject.lib.lua b/plugins/muc/subject.lib.lua
index b751bc49..56d8d174 100644
--- a/plugins/muc/subject.lib.lua
+++ b/plugins/muc/subject.lib.lua
@@ -13,7 +13,7 @@ local dt = require "util.datetime";
local muc_util = module:require "muc/util";
local valid_roles = muc_util.valid_roles;
-local function create_subject_message(subject, from)
+local function create_subject_message(from, subject)
return st.message({from = from; type = "groupchat"})
:tag("subject"):text(subject or ""):up();
end
@@ -54,7 +54,7 @@ end);
local function get_subject(room)
-- a <message/> stanza from the room JID (or from the occupant JID of the entity that set the subject)
- return room._data.subject, room._data.subject_from or room.jid;
+ return room._data.subject_from or room.jid, room._data.subject;
end
local function send_subject(room, to, time)
@@ -70,14 +70,14 @@ local function send_subject(room, to, time)
room:route_stanza(msg);
end
-local function set_subject(room, subject, from)
+local function set_subject(room, from, subject)
if subject == "" then subject = nil; end
- local old_subject, old_from = get_subject(room);
+ local old_from, old_subject = get_subject(room);
if old_subject == subject and old_from == from then return false; end
room._data.subject_from = from;
room._data.subject = subject;
room._data.subject_time = os.time();
- local msg = create_subject_message(subject, from);
+ local msg = create_subject_message(from, subject);
room:broadcast_message(msg);
return true;
end
@@ -99,7 +99,7 @@ module:hook("muc-occupant-groupchat", function(event)
local role_rank = valid_roles[occupant and occupant.role or "none"];
if role_rank >= valid_roles.moderator or
( role_rank >= valid_roles.participant and get_changesubject(room) ) then -- and participant
- set_subject(room, subject:get_text(), occupant.nick);
+ set_subject(room, occupant.nick, subject:get_text());
room:save();
return true;
else