aboutsummaryrefslogtreecommitdiff
path: root/src/ejabberd_app.erl
diff options
context:
space:
mode:
Diffstat (limited to 'src/ejabberd_app.erl')
-rw-r--r--src/ejabberd_app.erl48
1 files changed, 31 insertions, 17 deletions
diff --git a/src/ejabberd_app.erl b/src/ejabberd_app.erl
index 393d7afb2..b9a48bc42 100644
--- a/src/ejabberd_app.erl
+++ b/src/ejabberd_app.erl
@@ -32,21 +32,19 @@
-export([start_modules/0,start/2, get_log_path/0, prep_stop/1, stop/1, init/0]).
-include("ejabberd.hrl").
-
+-include("logger.hrl").
%%%
%%% Application API
%%%
start(normal, _Args) ->
- ejabberd_loglevel:set(4),
+ maybe_start_lager(),
+ ejabberd_logger:set(4),
write_pid_file(),
- application:start(sasl),
+ start_apps(),
randoms:start(),
db_init(),
- sha:start(),
- stringprep_sup:start_link(),
- xml:start(),
start(),
translate:start(),
acl:start(),
@@ -103,20 +101,13 @@ init() ->
%erlang:system_flag(fullsweep_after, 0),
%error_logger:logfile({open, ?LOG_PATH}),
LogPath = get_log_path(),
- error_logger:add_report_handler(ejabberd_logger_h, LogPath),
- erl_ddll:load_driver(ejabberd:get_so_path(), tls_drv),
- case erl_ddll:load_driver(ejabberd:get_so_path(), expat_erl) of
- ok -> ok;
- {error, already_loaded} -> ok
- end,
- Port = open_port({spawn, "expat_erl"}, [binary]),
- loop(Port).
-
+ ejabberd_logger:set_logfile(LogPath),
+ loop().
-loop(Port) ->
+loop() ->
receive
_ ->
- loop(Port)
+ loop()
end.
db_init() ->
@@ -245,3 +236,26 @@ delete_pid_file() ->
PidFilename ->
file:delete(PidFilename)
end.
+
+
+-ifdef(LAGER).
+
+maybe_start_lager() ->
+ lager:start().
+
+-else.
+
+maybe_start_lager() ->
+ ok.
+
+-endif.
+
+
+start_apps() ->
+ ejabberd:start_app(sasl),
+ ejabberd:start_app(ssl),
+ ejabberd:start_app(p1_tls),
+ ejabberd:start_app(p1_xml),
+ ejabberd:start_app(p1_stringprep),
+ ejabberd:start_app(p1_zlib),
+ ejabberd:start_app(p1_cache_tab).