aboutsummaryrefslogblamecommitdiff
path: root/src/ejabberd_logger.erl
blob: afb1f3f3d4fa8f9e89ef0d5e58a6da84831f284e (plain) (tree)





































































                                                                                
%%%-------------------------------------------------------------------
%%% @author Evgeniy Khramtsov <ekhramtsov@process-one.net>
%%% @copyright (C) 2013, Evgeniy Khramtsov
%%% @doc
%%%
%%% @end
%%% Created : 12 May 2013 by Evgeniy Khramtsov <ekhramtsov@process-one.net>
%%%-------------------------------------------------------------------
-module(ejabberd_logger).

%% API
-export([start/0, set_logfile/1, reopen_log/0, get/0, set/1,
         debug_msg/4, info_msg/4, warning_msg/4, error_msg/4,
         critical_msg/4]).

%%%===================================================================
%%% API
%%%===================================================================
start() ->
    ok.

set_logfile(FileName) ->
    error_logger:add_report_handler(p1_logger_h, FileName).

reopen_log() ->
    %% TODO: Use the Reopen log API for logger_h ?
    p1_logger_h:reopen_log(),
    case application:get_env(sasl,sasl_error_logger) of
	{ok, {file, SASLfile}} ->
	    error_logger:delete_report_handler(sasl_report_file_h),
	    p1_logger_h:rotate_log(SASLfile),
	    error_logger:add_report_handler(sasl_report_file_h,
	        {SASLfile, get_sasl_error_logger_type()});
	_ -> false
	end,
    ok.

get() ->
    p1_loglevel:get().

set(LogLevel) ->
    p1_loglevel:set(LogLevel).

debug_msg(Mod, Line, Format, Args) ->
    p1_logger:debug_msg(Mod, Line, Format, Args).

info_msg(Mod, Line, Format, Args) ->
    p1_logger:info_msg(Mod, Line, Format, Args).

warning_msg(Mod, Line, Format, Args) ->
    p1_logger:warning_msg(Mod, Line, Format, Args).

error_msg(Mod, Line, Format, Args) ->
    p1_logger:error_msg(Mod, Line, Format, Args).

critical_msg(Mod, Line, Format, Args) ->
    p1_logger:critical_msg(Mod, Line, Format, Args).

%%%===================================================================
%%% Internal functions
%%%===================================================================
%% Function copied from Erlang/OTP lib/sasl/src/sasl.erl which doesn't export it
get_sasl_error_logger_type () ->
    case application:get_env (sasl, errlog_type) of
	{ok, error} -> error;
	{ok, progress} -> progress;
	{ok, all} -> all;
	{ok, Bad} -> exit ({bad_config, {sasl, {errlog_type, Bad}}});
	_ -> all
    end.