mod_spam_filter: Update code for ejabberd >= 19.08
Update mod_spam_filter to use ejabberd's new configuration parsing infrastructure. Closes #280.
This commit is contained in:
parent
20ba631f3e
commit
20fb74c363
|
@ -104,31 +104,23 @@ reload(Host, NewOpts, OldOpts) ->
|
||||||
depends(_Host, _Opts) ->
|
depends(_Host, _Opts) ->
|
||||||
[].
|
[].
|
||||||
|
|
||||||
-spec mod_opt_type(atom()) -> fun((term()) -> term()) | [atom()].
|
-spec mod_opt_type(atom()) -> econf:validator().
|
||||||
mod_opt_type(spam_dump_file) ->
|
mod_opt_type(spam_dump_file) ->
|
||||||
fun(none) -> none;
|
econf:either(
|
||||||
(File) -> iolist_to_binary(File)
|
econf:enum([none]),
|
||||||
end;
|
econf:binary());
|
||||||
mod_opt_type(spam_jids_file) ->
|
mod_opt_type(spam_jids_file) ->
|
||||||
fun(none) -> none;
|
econf:either(
|
||||||
(File) ->
|
econf:enum([none]),
|
||||||
{ok, Fd} = file:open(File, [read, raw]),
|
econf:file());
|
||||||
ok = file:close(Fd),
|
|
||||||
iolist_to_binary(File)
|
|
||||||
end;
|
|
||||||
mod_opt_type(spam_urls_file) ->
|
mod_opt_type(spam_urls_file) ->
|
||||||
fun(none) -> none;
|
econf:either(
|
||||||
(File) ->
|
econf:enum([none]),
|
||||||
{ok, Fd} = file:open(File, [read, raw]),
|
econf:file());
|
||||||
ok = file:close(Fd),
|
|
||||||
iolist_to_binary(File)
|
|
||||||
end;
|
|
||||||
mod_opt_type(access_spam) ->
|
mod_opt_type(access_spam) ->
|
||||||
fun acl:access_rules_validator/1;
|
econf:acl();
|
||||||
mod_opt_type(cache_size) ->
|
mod_opt_type(cache_size) ->
|
||||||
fun(I) when is_integer(I), I > 0 -> I;
|
econf:pos_int(unlimited).
|
||||||
(infinity) -> unlimited
|
|
||||||
end.
|
|
||||||
|
|
||||||
-spec mod_options(binary()) -> [{atom(), any()}].
|
-spec mod_options(binary()) -> [{atom(), any()}].
|
||||||
mod_options(_Host) ->
|
mod_options(_Host) ->
|
||||||
|
@ -144,9 +136,9 @@ mod_options(_Host) ->
|
||||||
-spec init(list()) -> {ok, state()} | {stop, term()}.
|
-spec init(list()) -> {ok, state()} | {stop, term()}.
|
||||||
init([Host, Opts]) ->
|
init([Host, Opts]) ->
|
||||||
process_flag(trap_exit, true),
|
process_flag(trap_exit, true),
|
||||||
DumpFile = expand_host(proplists:get_value(spam_dump_file, Opts), Host),
|
DumpFile = expand_host(gen_mod:get_opt(spam_dump_file, Opts), Host),
|
||||||
JIDsFile = proplists:get_value(spam_jids_file, Opts),
|
JIDsFile = gen_mod:get_opt(spam_jids_file, Opts),
|
||||||
URLsFile = proplists:get_value(spam_urls_file, Opts),
|
URLsFile = gen_mod:get_opt(spam_urls_file, Opts),
|
||||||
try read_files(JIDsFile, URLsFile) of
|
try read_files(JIDsFile, URLsFile) of
|
||||||
{JIDsSet, URLsSet} ->
|
{JIDsSet, URLsSet} ->
|
||||||
ejabberd_hooks:add(s2s_in_handle_info, Host, ?MODULE,
|
ejabberd_hooks:add(s2s_in_handle_info, Host, ?MODULE,
|
||||||
|
@ -177,7 +169,7 @@ init([Host, Opts]) ->
|
||||||
jid_set = JIDsSet,
|
jid_set = JIDsSet,
|
||||||
url_set = URLsSet,
|
url_set = URLsSet,
|
||||||
dump_fd = DumpFd,
|
dump_fd = DumpFd,
|
||||||
max_cache_size = proplists:get_value(cache_size, Opts)}}
|
max_cache_size = gen_mod:get_opt(cache_size, Opts)}}
|
||||||
catch {Op, File, Reason} when Op == open;
|
catch {Op, File, Reason} when Op == open;
|
||||||
Op == read ->
|
Op == read ->
|
||||||
?CRITICAL_MSG("Cannot ~s ~s: ~s", [Op, File, format_error(Reason)]),
|
?CRITICAL_MSG("Cannot ~s ~s: ~s", [Op, File, format_error(Reason)]),
|
||||||
|
@ -227,16 +219,16 @@ handle_cast({dump, XML}, #state{dump_fd = Fd} = State) ->
|
||||||
end,
|
end,
|
||||||
{noreply, State};
|
{noreply, State};
|
||||||
handle_cast({reload, NewOpts, OldOpts}, #state{host = Host} = State) ->
|
handle_cast({reload, NewOpts, OldOpts}, #state{host = Host} = State) ->
|
||||||
State1 = case {proplists:get_value(spam_dump_file, OldOpts),
|
State1 = case {gen_mod:get_opt(spam_dump_file, OldOpts),
|
||||||
proplists:get_value(spam_dump_file, NewOpts)} of
|
gen_mod:get_opt(spam_dump_file, NewOpts)} of
|
||||||
{OldDumpFile, NewDumpFile} when NewDumpFile /= OldDumpFile ->
|
{OldDumpFile, NewDumpFile} when NewDumpFile /= OldDumpFile ->
|
||||||
close_dump_file(expand_host(OldDumpFile, Host), State),
|
close_dump_file(expand_host(OldDumpFile, Host), State),
|
||||||
open_dump_file(expand_host(NewDumpFile, Host), State);
|
open_dump_file(expand_host(NewDumpFile, Host), State);
|
||||||
{_OldDumpFile, _NewDumpFile} ->
|
{_OldDumpFile, _NewDumpFile} ->
|
||||||
State
|
State
|
||||||
end,
|
end,
|
||||||
State2 = case {proplists:get_value(cache_size, OldOpts),
|
State2 = case {gen_mod:get_opt(cache_size, OldOpts),
|
||||||
proplists:get_value(cache_size, NewOpts)} of
|
gen_mod:get_opt(cache_size, NewOpts)} of
|
||||||
{OldMax, NewMax} when NewMax < OldMax ->
|
{OldMax, NewMax} when NewMax < OldMax ->
|
||||||
shrink_cache(State1#state{max_cache_size = NewMax});
|
shrink_cache(State1#state{max_cache_size = NewMax});
|
||||||
{OldMax, NewMax} when NewMax > OldMax ->
|
{OldMax, NewMax} when NewMax > OldMax ->
|
||||||
|
@ -244,8 +236,8 @@ handle_cast({reload, NewOpts, OldOpts}, #state{host = Host} = State) ->
|
||||||
{_OldMax, _NewMax} ->
|
{_OldMax, _NewMax} ->
|
||||||
State1
|
State1
|
||||||
end,
|
end,
|
||||||
JIDsFile = proplists:get_value(spam_jids_file, NewOpts),
|
JIDsFile = gen_mod:get_opt(spam_jids_file, NewOpts),
|
||||||
URLsFile = proplists:get_value(spam_urls_file, NewOpts),
|
URLsFile = gen_mod:get_opt(spam_urls_file, NewOpts),
|
||||||
{_Result, State3} = reload_files(JIDsFile, URLsFile, State2),
|
{_Result, State3} = reload_files(JIDsFile, URLsFile, State2),
|
||||||
{noreply, State3};
|
{noreply, State3};
|
||||||
handle_cast(reopen_log, State) ->
|
handle_cast(reopen_log, State) ->
|
||||||
|
|
Loading…
Reference in New Issue