2002-11-18 21:39:47 +01:00
|
|
|
%%%----------------------------------------------------------------------
|
|
|
|
%%% File : ejabberd.erl
|
|
|
|
%%% Author : Alexey Shchepin <alexey@sevcom.net>
|
|
|
|
%%% Purpose :
|
|
|
|
%%% Created : 16 Nov 2002 by Alexey Shchepin <alexey@sevcom.net>
|
|
|
|
%%% Id : $Id$
|
|
|
|
%%%----------------------------------------------------------------------
|
|
|
|
|
|
|
|
-module(ejabberd).
|
|
|
|
-author('alexey@sevcom.net').
|
|
|
|
-vsn('$Revision$ ').
|
|
|
|
|
2002-11-23 21:55:05 +01:00
|
|
|
-export([start/0, init/0]).
|
2002-11-18 21:39:47 +01:00
|
|
|
|
2003-01-14 18:38:03 +01:00
|
|
|
-include("ejabberd.hrl").
|
|
|
|
|
2002-11-18 21:39:47 +01:00
|
|
|
start() ->
|
2002-11-23 21:55:05 +01:00
|
|
|
spawn(?MODULE, init, []).
|
|
|
|
|
|
|
|
init() ->
|
2002-11-20 21:19:20 +01:00
|
|
|
register(ejabberd, self()),
|
2003-01-26 21:16:53 +01:00
|
|
|
% Profiling
|
|
|
|
%eprof:start(),
|
|
|
|
%eprof:profile([self()]),
|
2003-01-18 20:42:48 +01:00
|
|
|
%erlang:system_flag(fullsweep_after, 0),
|
2003-01-14 18:38:03 +01:00
|
|
|
error_logger:logfile({open, ?ERROR_LOG_PATH}),
|
2002-12-13 21:58:27 +01:00
|
|
|
randoms:start(),
|
2002-11-20 21:19:20 +01:00
|
|
|
ok = erl_ddll:load_driver(".", expat_erl),
|
|
|
|
Port = open_port({spawn, expat_erl}, [binary]),
|
2002-11-23 21:55:05 +01:00
|
|
|
db_init(),
|
2002-12-20 21:42:08 +01:00
|
|
|
sha:start(),
|
2003-01-06 20:57:05 +01:00
|
|
|
translate:start(),
|
2003-01-18 20:42:48 +01:00
|
|
|
acl:start(),
|
2003-01-28 20:45:13 +01:00
|
|
|
gen_mod:start(),
|
2003-01-07 20:10:35 +01:00
|
|
|
ejabberd_config:start(),
|
2002-11-23 21:55:05 +01:00
|
|
|
ejabberd_auth:start(),
|
2002-11-27 21:46:29 +01:00
|
|
|
ejabberd_router:start(),
|
2002-11-24 21:36:57 +01:00
|
|
|
ejabberd_sm:start(),
|
2002-12-07 21:27:26 +01:00
|
|
|
ejabberd_s2s:start(),
|
2002-11-30 19:46:16 +01:00
|
|
|
ejabberd_local:start(),
|
2002-11-20 21:19:20 +01:00
|
|
|
ejabberd_listener:start(),
|
2003-01-22 21:40:40 +01:00
|
|
|
load_modules(),
|
2002-11-20 21:19:20 +01:00
|
|
|
loop(Port).
|
|
|
|
|
|
|
|
|
|
|
|
loop(Port) ->
|
|
|
|
receive
|
|
|
|
_ ->
|
|
|
|
loop(Port)
|
|
|
|
end.
|
2002-11-23 21:55:05 +01:00
|
|
|
|
|
|
|
db_init() ->
|
2003-01-21 21:36:55 +01:00
|
|
|
case mnesia:system_info(extra_db_nodes) of
|
|
|
|
[] ->
|
|
|
|
mnesia:create_schema([node()]);
|
|
|
|
_ ->
|
|
|
|
ok
|
|
|
|
end,
|
2002-11-24 21:36:57 +01:00
|
|
|
mnesia:start(),
|
2003-01-21 21:36:55 +01:00
|
|
|
mnesia:wait_for_tables(mnesia:system_info(local_tables), infinity).
|
2003-01-22 21:40:40 +01:00
|
|
|
|
|
|
|
load_modules() ->
|
|
|
|
case ejabberd_config:get_local_option(modules) of
|
|
|
|
undefined ->
|
|
|
|
ok;
|
|
|
|
Modules ->
|
|
|
|
lists:foreach(fun({Module, Args}) ->
|
2003-01-24 21:18:33 +01:00
|
|
|
gen_mod:start_module(Module, Args)
|
2003-01-22 21:40:40 +01:00
|
|
|
end, Modules)
|
|
|
|
end.
|
|
|
|
|