diff mod_groups_internal/mod_groups_internal.lua @ 4388:7de3c955cfe2

mod_groups_internal: allow creating MUCs if a MUC host is linked
author Jonas Schäfer <jonas@wielicki.name>
date Mon, 25 Jan 2021 21:47:38 +0100
parents 6357ac65b4eb
children 6cfa313cd524
line wrap: on
line diff
--- a/mod_groups_internal/mod_groups_internal.lua	Mon Jan 25 21:34:32 2021 +0100
+++ b/mod_groups_internal/mod_groups_internal.lua	Mon Jan 25 21:47:38 2021 +0100
@@ -1,4 +1,5 @@
 local rostermanager = require"core.rostermanager";
+local modulemanager = require"core.modulemanager";
 local id = require "util.id";
 local jid = require "util.jid";
 local jid_join = jid.join;
@@ -8,6 +9,9 @@
 local group_members_store = module:open_store("groups");
 local group_memberships = module:open_store("groups", "map");
 
+local muc_host_name = module:get_option("groups_muc_host", "chats."..host);
+local muc_host = nil;
+
 local is_contact_subscribed = rostermanager.is_contact_subscribed;
 
 -- Make a *one-way* subscription. User will see when contact is online,
@@ -96,16 +100,43 @@
 		group_id = id.short();
 	end
 
+	local muc_jid = nil
+	local room = nil
 	if create_muc then
-		return nil, "not-implemented";
+		if not muc_host_name then
+			module:log("error", "cannot create group with MUC: no MUC host configured")
+			return nil, "service-unavailable"
+		end
+		if not muc_host then
+			module:log("error", "cannot create group with MUC: MUC host %s not configured properly", muc_host_name)
+			return nil, "internal-server-error"
+		end
+
+		muc_jid = id.short() .. "@" .. muc_host_name
+		room = muc_host.create_room(muc_jid)
+		if not room then
+			delete_group(group_id)
+			return nil, "internal-server-error"
+		end
+		room:set_public(false)
+		room:set_persistent(true)
+		room:set_members_only(true)
+		room:set_allow_member_invites(false)
+		room:set_moderated(false)
+		room:set_whois("anyone")
 	end
 
 	local ok = group_info_store:set(group_id, {
 		name = group_info.name;
+		muc_jid = muc_jid;
 	});
 	if not ok then
+		if room then
+			muc_host:delete_room(room)
+		end
 		return nil, "internal-server-error";
 	end
+
 	return group_id;
 end
 
@@ -190,3 +221,15 @@
 function groups()
 	return group_info_store:users();
 end
+
+local function handle_server_started()
+	local target_module = modulemanager.get_module(muc_host_name, "muc")
+	if not target_module then
+		module:log("error", "host %s is not a MUC host -- group management will not work correctly", muc_host_name)
+	else
+		module:log("debug", "found MUC host")
+		muc_host = target_module;
+	end
+end
+
+module:hook_global("server-started", handle_server_started)