Support 'auto' value in log options, set as default

This commit is contained in:
Badlop 2022-07-21 11:14:17 +02:00
parent 10b1a83bbf
commit cc4702882f
11 changed files with 70 additions and 47 deletions

View File

@ -19,10 +19,8 @@
-include_lib("xmpp/include/xmpp.hrl"). -include_lib("xmpp/include/xmpp.hrl").
-define(PROCNAME, ?MODULE). -define(PROCNAME, ?MODULE).
-define(DEFAULT_PATH, ".").
-define(DEFAULT_FORMAT, text).
-record(config, {path=?DEFAULT_PATH, format=?DEFAULT_FORMAT}). -record(config, {path, format}).
start(Host, Opts) -> start(Host, Opts) ->
?DEBUG(" ~p ~p~n", [Host, Opts]), ?DEBUG(" ~p ~p~n", [Host, Opts]),
@ -44,7 +42,12 @@ 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), Path = case gen_mod:get_opt(path, Opts) of
auto ->
filename:dirname(ejabberd_logger:get_log_path());
PP ->
PP
end,
Format = gen_mod:get_opt(format, Opts), Format = gen_mod:get_opt(format, Opts),
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),
@ -276,13 +279,13 @@ depends(_Host, _Opts) ->
[]. [].
mod_opt_type(host_config) -> econf:list(econf:any()); mod_opt_type(host_config) -> econf:list(econf:any());
mod_opt_type(path) -> econf:directory(write); mod_opt_type(path) -> econf:either(auto, econf:directory(write));
mod_opt_type(format) -> mod_opt_type(format) ->
fun (A) when is_atom(A) -> A end. fun (A) when is_atom(A) -> A end.
mod_options(_Host) -> mod_options(_Host) ->
[{host_config, []}, [{host_config, []},
{path, ?DEFAULT_PATH}, {path, auto},
{format, ?DEFAULT_FORMAT}]. {format, text}].
mod_doc() -> #{}. mod_doc() -> #{}.

View File

@ -21,9 +21,11 @@ Note: to log the failed authentication attempts, you need to patch ejabberd.
----------------------- -----------------------
sessionlog: sessionlog:
Define the name of log files. Define the name of log files, or set to 'auto'.
The keyword @HOST@ will be substituted with the name of each vhost. The keyword @HOST@ is substituted with the name of the vhost.
Default value: "/tmp/ejabberd_logsession_@HOST@.log" If set to 'auto', it will store in the ejabberd log path
with the filename "session_@HOST@.log"
Default value: auto
EXAMPLE CONFIGURATION EXAMPLE CONFIGURATION

View File

@ -49,9 +49,13 @@ start(Host, Opts) ->
ejabberd_hooks:add(forbidden_session_hook, Host, ?MODULE, forbidden, 50), ejabberd_hooks:add(forbidden_session_hook, Host, ?MODULE, forbidden, 50),
ejabberd_hooks:add(c2s_auth_result, Host, ?MODULE, failed_auth, 50), ejabberd_hooks:add(c2s_auth_result, Host, ?MODULE, failed_auth, 50),
ejabberd_commands:register_commands(commands()), ejabberd_commands:register_commands(commands()),
Filename1 = gen_mod:get_opt( Filename1 = case gen_mod:get_opt(sessionlog, Opts) of
sessionlog, auto ->
Opts), filename:join(filename:dirname(ejabberd_logger:get_log_path()),
"session_@HOST@.log");
SL ->
SL
end,
Filename = replace_host(Host, Filename1), Filename = replace_host(Host, Filename1),
File = open_file(Filename), File = open_file(Filename),
register(get_process_name(Host), spawn(?MODULE, loop, [Filename, File, Host])), register(get_process_name(Host), spawn(?MODULE, loop, [Filename, File, Host])),
@ -69,10 +73,10 @@ depends(_Host, _Opts) ->
[]. [].
mod_opt_type(sessionlog) -> mod_opt_type(sessionlog) ->
econf:string(). econf:either(auto, econf:string()).
mod_options(_Host) -> mod_options(_Host) ->
[{sessionlog, "/tmp/ejabberd_logsession_@HOST@.log"}]. [{sessionlog, auto}].
mod_doc() -> #{}. mod_doc() -> #{}.

View File

@ -32,7 +32,8 @@ orientation:
Default value: [send, revc] Default value: [send, revc]
logdir: logdir:
Base filename, including absolute path Base filename, including absolute path
Default value: "/tmp/jabberlogs/" If set to 'auto', it uses the ejabberd log path.
Default value: auto
show_ip: show_ip:
If the IP address of the local user should be logged to file. If the IP address of the local user should be logged to file.
Default value: false Default value: false

View File

@ -24,8 +24,10 @@
%% ------------------- %% -------------------
start(Host, Opts) -> start(Host, Opts) ->
Logdir = gen_mod:get_opt(logdir, Opts), Logdir = case gen_mod:get_opt(logdir, Opts) of
auto -> filename:dirname(ejabberd_logger:get_log_path());
LD -> LD
end,
Rd = case gen_mod:get_opt(rotate_days, Opts) of Rd = case gen_mod:get_opt(rotate_days, Opts) of
0 -> no; 0 -> no;
Rd1 -> Rd1 Rd1 -> Rd1
@ -278,7 +280,7 @@ mod_opt_type(direction) ->
mod_opt_type(orientation) -> mod_opt_type(orientation) ->
econf:list(econf:enum([send, recv])); econf:list(econf:enum([send, recv]));
mod_opt_type(logdir) -> mod_opt_type(logdir) ->
econf:directory(); econf:either(auto, econf:directory(write));
mod_opt_type(show_ip) -> mod_opt_type(show_ip) ->
econf:bool(); econf:bool();
mod_opt_type(rotate_days) -> mod_opt_type(rotate_days) ->
@ -294,7 +296,7 @@ mod_options(_Host) ->
[{stanza, [iq, message, presence, other]}, [{stanza, [iq, message, presence, other]},
{direction, [internal, vhosts, external]}, {direction, [internal, vhosts, external]},
{orientation, [send, recv]}, {orientation, [send, recv]},
{logdir, "/tmp/jabberlogs/"}, {logdir, auto},
{show_ip, false}, {show_ip, false},
{rotate_days, 1}, {rotate_days, 1},
{rotate_megs, 10}, {rotate_megs, 10},

View File

@ -28,3 +28,7 @@ of your ejabberd.yml file:
mod_message_log: mod_message_log:
filename: "/path/to/ejabberd-message.log" filename: "/path/to/ejabberd-message.log"
If the filename option is set to 'auto', it will be set to
the default ejabberd log path, with the file name "message.log".
The filename option takes as default value 'auto'.

View File

@ -53,11 +53,10 @@
-include_lib("xmpp/include/xmpp.hrl"). -include_lib("xmpp/include/xmpp.hrl").
-define(DEFAULT_FILENAME, <<"message.log">>).
-define(FILE_MODES, [append, raw]). -define(FILE_MODES, [append, raw]).
-record(state, {filename = ?DEFAULT_FILENAME :: binary(), -record(state, {filename :: binary(),
iodevice :: io:device()}). iodevice :: io:device()}).
-type direction() :: incoming | outgoing | offline. -type direction() :: incoming | outgoing | offline.
-type state() :: #state{}. -type state() :: #state{}.
@ -97,11 +96,11 @@ stop(Host) ->
-spec mod_opt_type(atom()) -> fun((term()) -> term()). -spec mod_opt_type(atom()) -> fun((term()) -> term()).
mod_opt_type(filename) -> mod_opt_type(filename) ->
fun iolist_to_binary/1. econf:either(auto, econf:file(write)).
-spec mod_options(binary()) -> [{atom(), any()}]. -spec mod_options(binary()) -> [{atom(), any()}].
mod_options(_Host) -> mod_options(_Host) ->
[{filename, ?DEFAULT_FILENAME}]. [{filename, auto}].
-spec depends(binary(), gen_mod:opts()) -> [{module(), hard | soft}]. -spec depends(binary(), gen_mod:opts()) -> [{module(), hard | soft}].
depends(_Host, _Opts) -> depends(_Host, _Opts) ->
@ -116,7 +115,12 @@ mod_doc() -> #{}.
init([_Host, Opts]) -> init([_Host, Opts]) ->
process_flag(trap_exit, true), process_flag(trap_exit, true),
ejabberd_hooks:add(reopen_log_hook, ?MODULE, reopen_log, 42), ejabberd_hooks:add(reopen_log_hook, ?MODULE, reopen_log, 42),
Filename = gen_mod:get_opt(filename, Opts), Filename = case gen_mod:get_opt(filename, Opts) of
auto ->
filename:join(filename:dirname(ejabberd_logger:get_log_path()),
"message.log");
FN -> FN
end,
{ok, IoDevice} = file:open(Filename, ?FILE_MODES), {ok, IoDevice} = file:open(Filename, ?FILE_MODES),
{ok, #state{filename = Filename, iodevice = IoDevice}}. {ok, #state{filename = Filename, iodevice = IoDevice}}.

View File

@ -24,10 +24,10 @@ on mod_muc_log.
listen: listen:
- -
port: 5280 port: 5282
module: ejabberd_http module: ejabberd_http
request_handlers: request_handlers:
"/pub/muclogs": mod_muc_log_http /muclogs: mod_muc_log_http
modules: modules:
mod_muc_log: mod_muc_log:
@ -39,4 +39,4 @@ modules:
===== =====
With the example options, open your web browser at: With the example options, open your web browser at:
http://server:5280/pub/muclogs/ http://server:5282/muclogs/

View File

@ -28,11 +28,11 @@ modules:
To enable the HTTP request handler in the listen section: To enable the HTTP request handler in the listen section:
listen: listen:
- -
port: 5285 port: 5285
module: ejabberd_http module: ejabberd_http
request_handlers: request_handlers:
"/rest": mod_rest /rest: mod_rest
With that configuration, you can send HTTP POST requests to the URL: With that configuration, you can send HTTP POST requests to the URL:
http://localhost:5285/rest http://localhost:5285/rest

View File

@ -43,27 +43,25 @@
-include("logger.hrl"). -include("logger.hrl").
-define(PROCNAME, ?MODULE). -define(PROCNAME, ?MODULE).
-define(DEFAULT_FILENAME, <<"s2s.log">>).
-define(FILE_OPTS, [append,raw]). -define(FILE_OPTS, [append,raw]).
-record(config, {filename=?DEFAULT_FILENAME, iodevice}). -record(config, {filename, iodevice}).
%% For now we only support one log file for all vhosts. %% For now we only support one log file for all vhosts.
start(Host, Opts) -> start(Host, Opts) ->
case whereis(?PROCNAME) of case whereis(?PROCNAME) of
undefined -> undefined ->
Filename = gen_mod:get_opt(filename, Opts), FilenameStr = case gen_mod:get_opt(filename, Opts) of
case filelib:ensure_dir(Filename) of auto ->
ok -> filename:join(filename:dirname(ejabberd_logger:get_log_path()),
"s2s.log");
FN -> FN
end,
Filename = list_to_binary(FilenameStr),
register(?PROCNAME, register(?PROCNAME,
spawn(?MODULE, init, [#config{filename=Filename}])), spawn(?MODULE, init, [#config{filename=Filename}])),
ejabberd_hooks:add(reopen_log_hook, ?MODULE, reopen_log, 55), ejabberd_hooks:add(reopen_log_hook, ?MODULE, reopen_log, 55),
s2s_hooks(Host, add); s2s_hooks(Host, add);
{error, Why} = Err ->
?ERROR_MSG("failed to create directories along the path ~s: ~s",
[Filename, file:format_error(Why)]),
Err
end;
_ -> _ ->
s2s_hooks(Host, add) s2s_hooks(Host, add)
end. end.
@ -115,10 +113,10 @@ depends(_, _) ->
[]. [].
mod_opt_type(filename) -> mod_opt_type(filename) ->
fun iolist_to_binary/1. econf:either(auto, econf:file(write)).
mod_options(_Host) -> mod_options(_Host) ->
[{filename, ?DEFAULT_FILENAME}]. [{filename, auto}].
mod_doc() -> #{}. mod_doc() -> #{}.

View File

@ -44,7 +44,6 @@
%% Copied from ejabberd_sm.erl %% Copied from ejabberd_sm.erl
-record(session, {sid, usr, us, priority, info}). -record(session, {sid, usr, us, priority, info}).
-define(PIXMAPS_DIR, <<"pixmaps">>).
-define(AUTO_ACL, webpresence_auto). -define(AUTO_ACL, webpresence_auto).
%%==================================================================== %%====================================================================
@ -54,7 +53,13 @@ start_link() ->
gen_server:start_link({local, ?MODULE}, ?MODULE, [], []). gen_server:start_link({local, ?MODULE}, ?MODULE, [], []).
start(Host, Opts) -> start(Host, Opts) ->
Dir = gen_mod:get_opt(pixmaps_path, Opts), Dir = case gen_mod:get_opt(pixmaps_path, Opts) of
auto ->
Package = atom_to_list(?MODULE),
filename:join([ext_mod:modules_dir(), Package, "priv", "pixmaps"]);
PP ->
PP
end,
catch ets:new(pixmaps_dirs, [named_table, public]), catch ets:new(pixmaps_dirs, [named_table, public]),
ets:insert(pixmaps_dirs, {directory, Dir}), ets:insert(pixmaps_dirs, {directory, Dir}),
case gen_mod:start_child(?MODULE, Host, Opts) of case gen_mod:start_child(?MODULE, Host, Opts) of
@ -77,7 +82,7 @@ mod_opt_type(host) ->
mod_opt_type(access) -> mod_opt_type(access) ->
econf:acl(); econf:acl();
mod_opt_type(pixmaps_path) -> mod_opt_type(pixmaps_path) ->
econf:directory(); econf:either(auto, econf:directory());
mod_opt_type(port) -> mod_opt_type(port) ->
econf:pos_int(); econf:pos_int();
mod_opt_type(path) -> mod_opt_type(path) ->
@ -89,7 +94,7 @@ mod_opt_type(baseurl) ->
mod_options(Host) -> mod_options(Host) ->
[{host, <<"webpresence.", Host/binary>>}, [{host, <<"webpresence.", Host/binary>>},
{access, local}, {access, local},
{pixmaps_path, ?PIXMAPS_DIR}, {pixmaps_path, auto},
{port, 5280}, {port, 5280},
{path, <<"presence">>}, {path, <<"presence">>},
{baseurl, iolist_to_binary(io_lib:format(<<"http://~s:5280/presence/">>, [Host]))}]. {baseurl, iolist_to_binary(io_lib:format(<<"http://~s:5280/presence/">>, [Host]))}].