Fix mod_log_chat so it works with Ejabberd 13.12.

This commit is contained in:
pyromania 2014-05-04 22:42:13 -05:00
parent f4963a26e7
commit 9c2a2c44e1
1 changed files with 33 additions and 28 deletions

View File

@ -16,9 +16,10 @@
log_packet_send/3, log_packet_send/3,
log_packet_receive/4]). log_packet_receive/4]).
%-define(ejabberd_debug, true). -define(LAGER, 1).
-include("ejabberd.hrl"). -include("ejabberd.hrl").
-include("logger.hrl").
-include("jlib.hrl"). -include("jlib.hrl").
-define(PROCNAME, ?MODULE). -define(PROCNAME, ?MODULE).
@ -29,7 +30,7 @@
start(Host, Opts) -> start(Host, Opts) ->
?DEBUG(" ~p ~p~n", [Host, Opts]), ?DEBUG(" ~p ~p~n", [Host, Opts]),
case gen_mod:get_opt(host_config, Opts, []) of case gen_mod:get_opt(host_config, Opts, fun(L) when is_list(L) -> L end, []) of
[] -> [] ->
start_vh(Host, Opts); start_vh(Host, Opts);
HostConfig -> HostConfig ->
@ -46,8 +47,8 @@ start_vhs(Host, [{_VHost, _Opts}| Tail]) ->
?DEBUG("start_vhs ~p ~p~n", [Host, [{_VHost, _Opts}| Tail]]), ?DEBUG("start_vhs ~p ~p~n", [Host, [{_VHost, _Opts}| Tail]]),
start_vhs(Host, Tail). start_vhs(Host, Tail).
start_vh(Host, Opts) -> start_vh(Host, Opts) ->
Path = gen_mod:get_opt(path, Opts, ?DEFAULT_PATH), Path = gen_mod:get_opt(path, Opts, fun iolist_to_binary/1, ?DEFAULT_PATH),
Format = gen_mod:get_opt(format, Opts, ?DEFAULT_FORMAT), Format = gen_mod:get_opt(format, Opts, fun(A) when is_atom(A) -> A end, ?DEFAULT_FORMAT),
ejabberd_hooks:add(user_send_packet, Host, ?MODULE, log_packet_send, 55), ejabberd_hooks:add(user_send_packet, Host, ?MODULE, log_packet_send, 55),
ejabberd_hooks:add(user_receive_packet, Host, ?MODULE, log_packet_receive, 55), ejabberd_hooks:add(user_receive_packet, Host, ?MODULE, log_packet_receive, 55),
register(gen_mod:get_module_proc(Host, ?PROCNAME), register(gen_mod:get_module_proc(Host, ?PROCNAME),
@ -82,12 +83,12 @@ log_packet_receive(_JID, From, To, _Packet) when From#jid.lserver == To#jid.lser
log_packet_receive(_JID, From, To, Packet) -> log_packet_receive(_JID, From, To, Packet) ->
log_packet(From, To, Packet, To#jid.lserver). log_packet(From, To, Packet, To#jid.lserver).
log_packet(From, To, Packet = {xmlelement, "message", Attrs, _Els}, Host) -> log_packet(From, To, Packet = #xmlel{name = <<"message">>, attrs = Attrs}, Host) ->
case xml:get_attr_s("type", Attrs) of case xml:get_attr_s(<<"type">>, Attrs) of
"groupchat" -> %% mod_muc_log already does it <<"groupchat">> -> %% mod_muc_log already does it
?DEBUG("dropping groupchat: ~s", [xml:element_to_string(Packet)]), ?DEBUG("dropping groupchat: ~s", [xml:element_to_string(Packet)]),
ok; ok;
"error" -> %% we don't log errors <<"error">> -> %% we don't log errors
?DEBUG("dropping error: ~s", [xml:element_to_string(Packet)]), ?DEBUG("dropping error: ~s", [xml:element_to_string(Packet)]),
ok; ok;
_ -> _ ->
@ -103,21 +104,21 @@ write_packet(From, To, Packet, Host) ->
Result Result
end, end,
Format = Config#config.format, Format = Config#config.format,
{Subject, Body} = {case xml:get_path_s(Packet, [{elem, "subject"}, cdata]) of {Subject, Body} = {case xml:get_subtag(Packet, <<"subject">>) of
false -> false ->
""; "";
Text -> SubjEl ->
escape(Format, Text) escape(Format, xml:get_tag_cdata(SubjEl))
end, end,
escape(Format, xml:get_path_s(Packet, [{elem, "body"}, cdata]))}, escape(Format, xml:get_path_s(Packet, [{elem, <<"body">>}, cdata]))},
case Subject ++ Body of case Subject == [] andalso Body == [] of
"" -> %% don't log empty messages true -> %% don't log empty messages
?DEBUG("not logging empty message from ~s",[jlib:jid_to_string(From)]), ?DEBUG("not logging empty message from ~s",[jlib:jid_to_string(From)]),
ok; ok;
_ -> false ->
Path = Config#config.path, Path = Config#config.path,
FromJid = From#jid.luser++"@"++From#jid.lserver, FromJid = [From#jid.luser, "@", From#jid.lserver],
ToJid = To#jid.luser++"@"++To#jid.lserver, ToJid = [To#jid.luser, "@", To#jid.lserver],
{FilenameTemplate, DateString, Header, MessageType} = {FilenameTemplate, DateString, Header, MessageType} =
case calendar:local_time() of case calendar:local_time() of
{{Y, M, D}, {H, Min, S}} -> {{Y, M, D}, {H, Min, S}} ->
@ -151,13 +152,14 @@ write_packet(From, To, Packet, Host) ->
io:format(NewFile, Header, []), io:format(NewFile, Header, []),
NewFile NewFile
end, end,
MessageText = case Subject of MessageText = case Subject == [] of
"" -> true ->
Body; Body;
_ -> false ->
io_lib:format(template(Format, subject), [Subject])++Body io_lib:format(template(Format, subject), [Subject])++Body
end, end,
?DEBUG("MessageTemplate ~s~n",[template(Format, MessageType)]), ?DEBUG("MessageTemplate ~s~n",[template(Format, MessageType)]),
?DEBUG("Data: ~s ~s ~s ~s ~s ~s ~n",[DateString, FromJid, From#jid.lresource, ToJid, To#jid.lresource, MessageText]),
io:format(File, lists:flatten(template(Format, MessageType)), [DateString, FromJid, From#jid.lresource, ToJid, io:format(File, lists:flatten(template(Format, MessageType)), [DateString, FromJid, From#jid.lresource, ToJid,
To#jid.lresource, MessageText]), To#jid.lresource, MessageText]),
file:close(File) file:close(File)
@ -183,17 +185,20 @@ close_previous_logfile(FilenameTemplate, Format, Date) ->
ok ok
end. end.
escape(html, <<$<, Text/binary>>, Acc) ->
escape(html,Text,<<Acc/binary,"&lt;">>);
escape(html, <<$&, Text/binary>>, Acc) ->
escape(html,Text,<<Acc/binary,"&amp;">>);
escape(html, <<Char, Text/binary>>, Acc) ->
escape(html,Text,<<Acc/binary,Char>>);
escape(html, <<>>, Acc) ->
Acc.
escape(html, Text) -> escape(html,Text,<<>>);
escape(text, Text) -> escape(text, Text) ->
Text; Text;
escape(_, "") -> escape(_, "") ->
""; "".
escape(html, [$< | Text]) ->
"&lt;" ++ escape(html, Text);
escape(html, [$& | Text]) ->
"&amp;" ++ escape(html, Text);
escape(html, [Char | Text]) ->
[Char | escape(html, Text)].
% return the number of occurence of Word in String % return the number of occurence of Word in String
count(String, Word) -> count(String, Word) ->