Merge pull request #17 from scrogson/master
Binary conversions for mod_muc_admin
This commit is contained in:
commit
66d414d3a4
|
@ -0,0 +1 @@
|
||||||
|
*.beam
|
|
@ -29,6 +29,7 @@
|
||||||
]).
|
]).
|
||||||
|
|
||||||
-include("ejabberd.hrl").
|
-include("ejabberd.hrl").
|
||||||
|
-include("logger.hrl").
|
||||||
-include("jlib.hrl").
|
-include("jlib.hrl").
|
||||||
-include("mod_muc_room.hrl").
|
-include("mod_muc_room.hrl").
|
||||||
-include("ejabberd_http.hrl").
|
-include("ejabberd_http.hrl").
|
||||||
|
@ -70,7 +71,7 @@ commands() ->
|
||||||
#ejabberd_commands{name = muc_unregister_nick, tags = [muc],
|
#ejabberd_commands{name = muc_unregister_nick, tags = [muc],
|
||||||
desc = "Unregister the nick in the MUC service",
|
desc = "Unregister the nick in the MUC service",
|
||||||
module = ?MODULE, function = muc_unregister_nick,
|
module = ?MODULE, function = muc_unregister_nick,
|
||||||
args = [{nick, string}],
|
args = [{nick, binary}],
|
||||||
result = {res, rescode}},
|
result = {res, rescode}},
|
||||||
|
|
||||||
#ejabberd_commands{name = create_room, tags = [muc_room],
|
#ejabberd_commands{name = create_room, tags = [muc_room],
|
||||||
|
@ -82,8 +83,8 @@ commands() ->
|
||||||
#ejabberd_commands{name = destroy_room, tags = [muc_room],
|
#ejabberd_commands{name = destroy_room, tags = [muc_room],
|
||||||
desc = "Destroy a MUC room",
|
desc = "Destroy a MUC room",
|
||||||
module = ?MODULE, function = destroy_room,
|
module = ?MODULE, function = destroy_room,
|
||||||
args = [{name, string}, {service, string},
|
args = [{name, binary}, {service, binary},
|
||||||
{host, string}],
|
{host, binary}],
|
||||||
result = {res, rescode}},
|
result = {res, rescode}},
|
||||||
#ejabberd_commands{name = create_rooms_file, tags = [muc],
|
#ejabberd_commands{name = create_rooms_file, tags = [muc],
|
||||||
desc = "Create the rooms indicated in file",
|
desc = "Create the rooms indicated in file",
|
||||||
|
@ -98,18 +99,18 @@ commands() ->
|
||||||
#ejabberd_commands{name = rooms_unused_list, tags = [muc],
|
#ejabberd_commands{name = rooms_unused_list, tags = [muc],
|
||||||
desc = "List the rooms that are unused for many days in host",
|
desc = "List the rooms that are unused for many days in host",
|
||||||
module = ?MODULE, function = rooms_unused_list,
|
module = ?MODULE, function = rooms_unused_list,
|
||||||
args = [{host, string}, {days, integer}],
|
args = [{host, binary}, {days, integer}],
|
||||||
result = {rooms, {list, {room, string}}}},
|
result = {rooms, {list, {room, string}}}},
|
||||||
#ejabberd_commands{name = rooms_unused_destroy, tags = [muc],
|
#ejabberd_commands{name = rooms_unused_destroy, tags = [muc],
|
||||||
desc = "Destroy the rooms that are unused for many days in host",
|
desc = "Destroy the rooms that are unused for many days in host",
|
||||||
module = ?MODULE, function = rooms_unused_destroy,
|
module = ?MODULE, function = rooms_unused_destroy,
|
||||||
args = [{host, string}, {days, integer}],
|
args = [{host, binary}, {days, integer}],
|
||||||
result = {rooms, {list, {room, string}}}},
|
result = {rooms, {list, {room, string}}}},
|
||||||
|
|
||||||
#ejabberd_commands{name = get_room_occupants, tags = [muc_room],
|
#ejabberd_commands{name = get_room_occupants, tags = [muc_room],
|
||||||
desc = "Get the list of occupants of a MUC room",
|
desc = "Get the list of occupants of a MUC room",
|
||||||
module = ?MODULE, function = get_room_occupants,
|
module = ?MODULE, function = get_room_occupants,
|
||||||
args = [{name, string}, {service, string}],
|
args = [{name, binary}, {service, binary}],
|
||||||
result = {occupants, {list,
|
result = {occupants, {list,
|
||||||
{occupant, {tuple,
|
{occupant, {tuple,
|
||||||
[{jid, string},
|
[{jid, string},
|
||||||
|
@ -121,33 +122,33 @@ commands() ->
|
||||||
#ejabberd_commands{name = get_room_occupants_number, tags = [muc_room],
|
#ejabberd_commands{name = get_room_occupants_number, tags = [muc_room],
|
||||||
desc = "Get the number of occupants of a MUC room",
|
desc = "Get the number of occupants of a MUC room",
|
||||||
module = ?MODULE, function = get_room_occupants_number,
|
module = ?MODULE, function = get_room_occupants_number,
|
||||||
args = [{name, string}, {service, string}],
|
args = [{name, binary}, {service, binary}],
|
||||||
result = {occupants, integer}},
|
result = {occupants, integer}},
|
||||||
|
|
||||||
#ejabberd_commands{name = send_direct_invitation, tags = [muc_room],
|
#ejabberd_commands{name = send_direct_invitation, tags = [muc_room],
|
||||||
desc = "Send a direct invitation to several destinations",
|
desc = "Send a direct invitation to several destinations",
|
||||||
longdesc = "Password and Message can also be: none. Users JIDs are separated with : ",
|
longdesc = "Password and Message can also be: none. Users JIDs are separated with : ",
|
||||||
module = ?MODULE, function = send_direct_invitation,
|
module = ?MODULE, function = send_direct_invitation,
|
||||||
args = [{room, string}, {password, string}, {reason, string}, {users, string}],
|
args = [{room, binary}, {password, binary}, {reason, binary}, {users, string}],
|
||||||
result = {res, rescode}},
|
result = {res, rescode}},
|
||||||
|
|
||||||
#ejabberd_commands{name = change_room_option, tags = [muc_room],
|
#ejabberd_commands{name = change_room_option, tags = [muc_room],
|
||||||
desc = "Change an option in a MUC room",
|
desc = "Change an option in a MUC room",
|
||||||
module = ?MODULE, function = change_room_option,
|
module = ?MODULE, function = change_room_option,
|
||||||
args = [{name, string}, {service, string},
|
args = [{name, binary}, {service, binary},
|
||||||
{option, string}, {value, string}],
|
{option, string}, {value, string}],
|
||||||
result = {res, rescode}},
|
result = {res, rescode}},
|
||||||
|
|
||||||
#ejabberd_commands{name = set_room_affiliation, tags = [muc_room],
|
#ejabberd_commands{name = set_room_affiliation, tags = [muc_room],
|
||||||
desc = "Change an affiliation in a MUC room",
|
desc = "Change an affiliation in a MUC room",
|
||||||
module = ?MODULE, function = set_room_affiliation,
|
module = ?MODULE, function = set_room_affiliation,
|
||||||
args = [{name, string}, {service, string},
|
args = [{name, binary}, {service, binary},
|
||||||
{jid, string}, {affiliation, string}],
|
{jid, binary}, {affiliation, string}],
|
||||||
result = {res, rescode}},
|
result = {res, rescode}},
|
||||||
#ejabberd_commands{name = get_room_affiliations, tags = [muc_room],
|
#ejabberd_commands{name = get_room_affiliations, tags = [muc_room],
|
||||||
desc = "Get the list of affiliations of a MUC room",
|
desc = "Get the list of affiliations of a MUC room",
|
||||||
module = ?MODULE, function = get_room_affiliations,
|
module = ?MODULE, function = get_room_affiliations,
|
||||||
args = [{name, string}, {service, string}],
|
args = [{name, binary}, {service, binary}],
|
||||||
result = {affiliations, {list,
|
result = {affiliations, {list,
|
||||||
{affiliation, {tuple,
|
{affiliation, {tuple,
|
||||||
[{username, string},
|
[{username, string},
|
||||||
|
@ -372,7 +373,7 @@ prepare_room_info(Room_info) ->
|
||||||
%% Create/Delete Room
|
%% Create/Delete Room
|
||||||
%%----------------------------
|
%%----------------------------
|
||||||
|
|
||||||
%% @spec (Name::string(), Host::string(), ServerHost::string()) ->
|
%% @spec (Name::binary(), Host::binary(), ServerHost::binary()) ->
|
||||||
%% ok | error
|
%% ok | error
|
||||||
%% @doc Create a room immediately with the default options.
|
%% @doc Create a room immediately with the default options.
|
||||||
create_room(Name, Host, ServerHost) ->
|
create_room(Name, Host, ServerHost) ->
|
||||||
|
@ -389,7 +390,7 @@ create_room(Name, Host, ServerHost) ->
|
||||||
AcCreate = gen_mod:get_module_opt(ServerHost, mod_muc, access_create, fun(X) -> X end, all),
|
AcCreate = gen_mod:get_module_opt(ServerHost, mod_muc, access_create, fun(X) -> X end, all),
|
||||||
AcAdmin = gen_mod:get_module_opt(ServerHost, mod_muc, access_admin, fun(X) -> X end, none),
|
AcAdmin = gen_mod:get_module_opt(ServerHost, mod_muc, access_admin, fun(X) -> X end, none),
|
||||||
AcPer = gen_mod:get_module_opt(ServerHost, mod_muc, access_persistent, fun(X) -> X end, all),
|
AcPer = gen_mod:get_module_opt(ServerHost, mod_muc, access_persistent, fun(X) -> X end, all),
|
||||||
PersistHistory = gen_mod:get_module_opt(ServerHost, mod_muc, persist_history, fun(X) -> X end, false),
|
_PersistHistory = gen_mod:get_module_opt(ServerHost, mod_muc, persist_history, fun(X) -> X end, false),
|
||||||
HistorySize = gen_mod:get_module_opt(ServerHost, mod_muc, history_size, fun(X) -> X end, 20),
|
HistorySize = gen_mod:get_module_opt(ServerHost, mod_muc, history_size, fun(X) -> X end, 20),
|
||||||
RoomShaper = gen_mod:get_module_opt(ServerHost, mod_muc, room_shaper, fun(X) -> X end, none),
|
RoomShaper = gen_mod:get_module_opt(ServerHost, mod_muc, room_shaper, fun(X) -> X end, none),
|
||||||
|
|
||||||
|
@ -424,7 +425,7 @@ muc_create_room(ServerHost, {Name, Host, _}, DefRoomOpts) ->
|
||||||
io:format("Creating room ~s@~s~n", [Name, Host]),
|
io:format("Creating room ~s@~s~n", [Name, Host]),
|
||||||
mod_muc:store_room(ServerHost, Host, Name, DefRoomOpts).
|
mod_muc:store_room(ServerHost, Host, Name, DefRoomOpts).
|
||||||
|
|
||||||
%% @spec (Name::string(), Host::string(), ServerHost::string()) ->
|
%% @spec (Name::binary(), Host::binary(), ServerHost::binary()) ->
|
||||||
%% ok | {error, room_not_exists}
|
%% ok | {error, room_not_exists}
|
||||||
%% @doc Destroy the room immediately.
|
%% @doc Destroy the room immediately.
|
||||||
%% If the room has participants, they are not notified that the room was destroyed;
|
%% If the room has participants, they are not notified that the room was destroyed;
|
||||||
|
@ -522,7 +523,7 @@ rooms_unused_destroy(Host, Days) ->
|
||||||
rooms_unused_report(Action, Host, Days) ->
|
rooms_unused_report(Action, Host, Days) ->
|
||||||
{NA, NP, RP} = muc_unused(Action, Host, Days),
|
{NA, NP, RP} = muc_unused(Action, Host, Days),
|
||||||
io:format("Unused rooms: ~p out of ~p~n", [NP, NA]),
|
io:format("Unused rooms: ~p out of ~p~n", [NP, NA]),
|
||||||
[R ++ "@" ++ H || {R, H, _P} <- RP].
|
[[R, <<"@">>, H] || {R, H, _P} <- RP].
|
||||||
|
|
||||||
muc_unused(Action, ServerHost, Days) ->
|
muc_unused(Action, ServerHost, Days) ->
|
||||||
Host = find_host(ServerHost),
|
Host = find_host(ServerHost),
|
||||||
|
@ -672,7 +673,7 @@ send_direct_invitation(RoomString, Password, Reason, UsersString) ->
|
||||||
RoomJid = jlib:string_to_jid(RoomString),
|
RoomJid = jlib:string_to_jid(RoomString),
|
||||||
XmlEl = build_invitation(Password, Reason, RoomString),
|
XmlEl = build_invitation(Password, Reason, RoomString),
|
||||||
UsersStrings = get_users_to_invite(RoomJid, UsersString),
|
UsersStrings = get_users_to_invite(RoomJid, UsersString),
|
||||||
[send_direct_invitation(RoomJid, jlib:string_to_jid(UserStrings), XmlEl)
|
[send_direct_invitation(RoomJid, jlib:string_to_jid(list_to_binary(UserStrings)), XmlEl)
|
||||||
|| UserStrings <- UsersStrings],
|
|| UserStrings <- UsersStrings],
|
||||||
timer:sleep(1000),
|
timer:sleep(1000),
|
||||||
ok.
|
ok.
|
||||||
|
@ -685,7 +686,7 @@ get_users_to_invite(RoomJid, UsersString) ->
|
||||||
|| {JidString, _Nick, _} <- OccupantsTuples],
|
|| {JidString, _Nick, _} <- OccupantsTuples],
|
||||||
lists:filter(
|
lists:filter(
|
||||||
fun(UserString) ->
|
fun(UserString) ->
|
||||||
UserJid = jlib:string_to_jid(UserString),
|
UserJid = jlib:string_to_jid(list_to_binary(UserString)),
|
||||||
%% [{"badlop@localhost/work","badlop","moderator"}]
|
%% [{"badlop@localhost/work","badlop","moderator"}]
|
||||||
lists:all(fun(OccupantJid) ->
|
lists:all(fun(OccupantJid) ->
|
||||||
UserJid#jid.luser /= OccupantJid#jid.luser
|
UserJid#jid.luser /= OccupantJid#jid.luser
|
||||||
|
@ -697,19 +698,19 @@ get_users_to_invite(RoomJid, UsersString) ->
|
||||||
|
|
||||||
build_invitation(Password, Reason, RoomString) ->
|
build_invitation(Password, Reason, RoomString) ->
|
||||||
PasswordAttrList = case Password of
|
PasswordAttrList = case Password of
|
||||||
"none" -> [];
|
<<"none">> -> [];
|
||||||
_ -> [{<<"password">>, Password}]
|
_ -> [{<<"password">>, Password}]
|
||||||
end,
|
end,
|
||||||
ReasonAttrList = case Reason of
|
ReasonAttrList = case Reason of
|
||||||
"none" -> [];
|
<<"none">> -> [];
|
||||||
_ -> [{<<"reason">>, Reason}]
|
_ -> [{<<"reason">>, Reason}]
|
||||||
end,
|
end,
|
||||||
XAttrs = [{<<"xmlns">>, ?NS_XCONFERENCE},
|
XAttrs = [{<<"xmlns">>, ?NS_XCONFERENCE},
|
||||||
{<<"jid">>, RoomString}]
|
{<<"jid">>, RoomString}]
|
||||||
++ PasswordAttrList
|
++ PasswordAttrList
|
||||||
++ ReasonAttrList,
|
++ ReasonAttrList,
|
||||||
XEl = {xmlelement, <<"x">>, XAttrs, []},
|
XEl = {xmlel, <<"x">>, XAttrs, []},
|
||||||
{xmlelement, <<"message">>, [], [XEl]}.
|
{xmlel, <<"message">>, [], [XEl]}.
|
||||||
|
|
||||||
send_direct_invitation(FromJid, UserJid, XmlEl) ->
|
send_direct_invitation(FromJid, UserJid, XmlEl) ->
|
||||||
ejabberd_router:route(FromJid, UserJid, XmlEl).
|
ejabberd_router:route(FromJid, UserJid, XmlEl).
|
||||||
|
@ -783,7 +784,7 @@ change_option(Option, Value, Config) ->
|
||||||
%% Get Room Affiliations
|
%% Get Room Affiliations
|
||||||
%%----------------------------
|
%%----------------------------
|
||||||
|
|
||||||
%% @spec(Name::string(), Service::string()) ->
|
%% @spec(Name::binary(), Service::binary()) ->
|
||||||
%% [{JID::string(), Domain::string(), Role::string(), Reason::string()}]
|
%% [{JID::string(), Domain::string(), Role::string(), Reason::string()}]
|
||||||
%% @doc Get the affiliations of the room Name@Service.
|
%% @doc Get the affiliations of the room Name@Service.
|
||||||
get_room_affiliations(Name, Service) ->
|
get_room_affiliations(Name, Service) ->
|
||||||
|
@ -808,10 +809,10 @@ get_room_affiliations(Name, Service) ->
|
||||||
%%----------------------------
|
%%----------------------------
|
||||||
|
|
||||||
%% @spec(Name, Service, JID, AffiliationString) -> ok | {error, Error}
|
%% @spec(Name, Service, JID, AffiliationString) -> ok | {error, Error}
|
||||||
%% Name = string()
|
%% Name = binary()
|
||||||
%% Service = string()
|
%% Service = binary()
|
||||||
%% JID = string()
|
%% JID = binary()
|
||||||
%% AffiliationString = "outcast" | "none" | "member" | "admin" | "owner"
|
%% AffiliationString = "outcast" | "none" | "member" | "admin" | "owner"
|
||||||
%% @doc Set the affiliation of JID in the room Name@Service.
|
%% @doc Set the affiliation of JID in the room Name@Service.
|
||||||
%% If the affiliation is 'none', the action is to remove,
|
%% If the affiliation is 'none', the action is to remove,
|
||||||
%% In any other case the action will be to create the affiliation.
|
%% In any other case the action will be to create the affiliation.
|
||||||
|
|
Loading…
Reference in New Issue