\documentclass[a4paper,10pt]{article} %% Packages \usepackage{float} \usepackage{graphics} \usepackage{hevea} \usepackage[pdftex,colorlinks,unicode,urlcolor=blue,linkcolor=blue, pdftitle=Ejabberd\ Installation\ and\ Operation\ Guide,pdfauthor=Alexey\ Shchepin,pdfsubject=ejabberd,pdfkeywords=ejabberd, pdfpagelabels=false]{hyperref} \usepackage{makeidx} %\usepackage{showidx} % Only for verifying the index entries. \usepackage{verbatim} \usepackage{geometry} %% Index \makeindex % Remove the index anchors from the HTML version to save size and bandwith. \newcommand{\ind}[1]{\begin{latexonly}\index{#1}\end{latexonly}} %% Images \newcommand{\logoscale}{0.7} \newcommand{\imgscale}{0.58} \newcommand{\insimg}[1]{\insscaleimg{\imgscale}{#1}} \newcommand{\insscaleimg}[2]{ \imgsrc{#2}{} \begin{latexonly} \scalebox{#1}{\includegraphics{#2}} \end{latexonly} } %% Various \newcommand{\bracehack}{\def\{{\char"7B}\def\}{\char"7D}} \newcommand{\titem}[1]{\item[\bracehack\texttt{#1}]} \newcommand{\ns}[1]{\texttt{#1}} \newcommand{\jid}[1]{\texttt{#1}} \newcommand{\option}[1]{\texttt{#1}} \newcommand{\poption}[1]{{\bracehack\texttt{#1}}} \newcommand{\node}[1]{\texttt{#1}} \newcommand{\term}[1]{\texttt{#1}} \newcommand{\shell}[1]{\texttt{#1}} \newcommand{\ejabberd}{\texttt{ejabberd}} \newcommand{\Jabber}{Jabber} %% Modules \newcommand{\module}[1]{\texttt{#1}} \newcommand{\modadhoc}{\module{mod\_adhoc}} \newcommand{\modannounce}{\module{mod\_announce}} \newcommand{\modconfigure}{\module{mod\_configure}} \newcommand{\moddisco}{\module{mod\_disco}} \newcommand{\modecho}{\module{mod\_echo}} \newcommand{\modirc}{\module{mod\_irc}} \newcommand{\modlast}{\module{mod\_last}} \newcommand{\modlastodbc}{\module{mod\_last\_odbc}} \newcommand{\modmuc}{\module{mod\_muc}} \newcommand{\modmuclog}{\module{mod\_muc\_log}} \newcommand{\modoffline}{\module{mod\_offline}} \newcommand{\modofflineodbc}{\module{mod\_offline\_odbc}} \newcommand{\modprivacy}{\module{mod\_privacy}} \newcommand{\modprivate}{\module{mod\_private}} \newcommand{\modpubsub}{\module{mod\_pubsub}} \newcommand{\modregister}{\module{mod\_register}} \newcommand{\modroster}{\module{mod\_roster}} \newcommand{\modrosterodbc}{\module{mod\_roster\_odbc}} \newcommand{\modservicelog}{\module{mod\_service\_log}} \newcommand{\modsharedroster}{\module{mod\_shared\_roster}} \newcommand{\modstats}{\module{mod\_stats}} \newcommand{\modtime}{\module{mod\_time}} \newcommand{\modvcard}{\module{mod\_vcard}} \newcommand{\modvcardldap}{\module{mod\_vcard\_ldap}} \newcommand{\modvcardodbc}{\module{mod\_vcard\_odbc}} \newcommand{\modversion}{\module{mod\_version}} %% Common options \newcommand{\iqdiscitem}[1]{\titem{iqdisc} \ind{options!iqdisc}This specifies the processing discipline for #1 IQ queries (see section~\ref{sec:modiqdiscoption}).} \newcommand{\hostitem}[1]{ \titem{hosts} \ind{options!hosts} This option defines the hostnames of the service (see section~\ref{sec:modhostsoption}). If neither \texttt{hosts} nor the old \texttt{host} is present, the prefix ``\jid{#1.}'' is added to all \ejabberd{} hostnames. } %% Title page \include{version} \title{Ejabberd \version\ Installation and Operation Guide} \author{Alexey Shchepin \\ \ahrefurl{mailto:alexey@sevcom.net} \\ \ahrefurl{xmpp:aleksey@jabber.ru}} %% Options \newcommand{\marking}[1]{#1} % Marking disabled \newcommand{\quoting}[2][yozhik]{} % Quotes disabled \newcommand{\new}{\begin{latexonly}\marginpar{\textsc{new}}\end{latexonly}} % Highlight new features \newcommand{\improved}{\begin{latexonly}\marginpar{\textsc{improved}}\end{latexonly}} % Highlight improved features \newcommand{\moreinfo}[1]{} % Hide details %% Footnotes \begin{latexonly} \global\parskip=9pt plus 3pt minus 1pt \global\parindent=0pt \gdef\ahrefurl#1{\href{#1}{\texttt{#1}}} \gdef\footahref#1#2{#2\footnote{\href{#1}{\texttt{#1}}}} \end{latexonly} \newcommand{\tjepref}[2]{\footahref{http://www.jabber.org/jeps/jep-#1.html}{#2}} \newcommand{\jepref}[1]{\tjepref{#1}{JEP-#1}} \begin{document} \label{sec:titlepage} \begin{titlepage} \maketitle{} \begin{center} {\insscaleimg{\logoscale}{logo.png} \par } \end{center} \begin{quotation}\textit{I can thoroughly recommend ejabberd for ease of setup -- Kevin Smith, Current maintainer of the Psi project}\end{quotation} \end{titlepage} % Set the page counter to 2 so that the titlepage and the second page do not % have the same page number. This fixes the PDFLaTeX warning "destination with % the same identifier". \begin{latexonly} \setcounter{page}{2} \end{latexonly} \tableofcontents{} % Input introduction.tex \input{introduction} \section{Installation from Source} \label{sec:installation} \ind{installation} \subsection{Installation Requirements} \label{sec:installreq} \subsubsection{``Unix-like'' operating systems} \label{sec:installrequnix} \ind{installation!requirements for ``Unix-like'' operating systems} To compile \ejabberd{} on a ``Unix-like'' operating system, you need: \begin{itemize} \item GNU Make; \item GCC; \item libexpat 1.95 or higher; \item Erlang/OTP R9C-2 or higher; \item OpenSSL 0.9.6 or higher (optional). \item Zlib 1.2.3 or higher (optional). \item GNU Iconv 1.8 or higher (optional, not needed at all on systems with GNU libc). \end{itemize} \subsubsection{Windows} \label{sec:installreqwin} \ind{installation!requirements for Windows} To compile \ejabberd{} on a Windows flavour, you need: \begin{itemize} \item MS Visual C++ 6.0 Compiler \item \footahref{http://erlang.org/download.html}{Erlang/OTP R9C-2 or higher} \item \footahref{http://sourceforge.net/project/showfiles.php?group\_id=10127\&package\_id=11277}{Expat 1.95.7 or higher} \item \footahref{http://www.gnu.org/software/libiconv/}{GNU Iconv 1.9.1} (optional) \item \footahref{http://www.slproweb.com/products/Win32OpenSSL.html}{Shining Light OpenSSL} (to enable SSL connections) \item \footahref{http://www.zlib.net/}{Zlib 1.2.3 or higher} \end{itemize} \subsection{Obtaining \ejabberd{}} \label{sec:obtaining} \ind{download} Released versions of \ejabberd{} can be obtained from \\ \ahrefurl{http://www.process-one.net/en/projects/ejabberd/download.html}. \ind{Subversion repository} The latest development version can be retrieved from the Subversion repository\@. \begin{verbatim} svn co http://svn.process-one.net/ejabberd/trunk ejabberd \end{verbatim} \subsection{Compilation} \label{sec:compilation} \ind{compilation} \subsubsection{``Unix-like'' operating systems} \label{sec:compilationunix} \ind{compilation!on ``Unix-like'' operating systems} Compile \ejabberd{} on a ``Unix-like'' operating system by executing: \begin{verbatim} ./configure make su make install \end{verbatim} These commands will: \begin{itemize} \item install \ejabberd{} into the directory \verb|/var/lib/ejabberd|, \item install the configuration file into \verb|/etc/ejabberd|, \item create a directory called \verb|/var/log/ejabberd| to store log files. \end{itemize} \subsubsection{Windows} \label{sec:compilationwin} \ind{compilation!on Windows} \begin{itemize} \item Install Erlang emulator (for example, into \verb|C:\Program Files\erl5.3|). \item Install Expat library into \verb|C:\Program Files\Expat-1.95.7| directory. Copy file \verb|C:\Program Files\Expat-1.95.7\Libs\libexpat.dll| to your Windows system directory (for example, \verb|C:\WINNT| or \verb|C:\WINNT\System32|) \item Build and install the Iconv library into the directory \verb|C:\Program Files\iconv-1.9.1|. Copy file \verb|C:\Program Files\iconv-1.9.1\bin\iconv.dll| to your Windows system directory (more installation instructions can be found in the file README.woe32 in the iconv distribution). Note: instead of copying libexpat.dll and iconv.dll to the Windows directory, you can add the directories \verb|C:\Program Files\Expat-1.95.7\Libs| and \verb|C:\Program Files\iconv-1.9.1\bin| to the \verb|PATH| environment variable. \item While in the directory \verb|ejabberd\src| run: \begin{verbatim} configure.bat nmake -f Makefile.win32 \end{verbatim} \item Edit the file \verb|ejabberd\src\ejabberd.cfg| and run \begin{verbatim} werl -s ejabberd -name ejabberd \end{verbatim} \end{itemize} \subsection{Starting} \label{sec:starting} \ind{starting} Execute the following command to start \ejabberd{}: \begin{verbatim} erl -pa /var/lib/ejabberd/ebin -name ejabberd -s ejabberd \end{verbatim} or \begin{verbatim} erl -pa /var/lib/ejabberd/ebin -sname ejabberd -s ejabberd \end{verbatim} In the latter case the Erlang node will be identified using only the first part of the host name, i.\,e. other Erlang nodes outside this domain can't contact this node. Note that when using the above command, \ejabberd{} will search for the configuration file in the current directory and will use the current directory for storing its user database and for logging. To specify the path to the configuration file, the log files and the Mnesia database directory, you may use the following command: \begin{verbatim} erl -pa /var/lib/ejabberd/ebin \ -sname ejabberd \ -s ejabberd \ -ejabberd config \"/etc/ejabberd/ejabberd.cfg\" \ log_path \"/var/log/ejabberd/ejabberd.log\" \ -sasl sasl_error_logger \{file,\"/var/log/ejabberd/sasl.log\"\} \ -mnesia dir \"/var/lib/ejabberd/spool\" \end{verbatim} You can find other useful options in the Erlang manual page (\shell{erl -man erl}). To use more than 1024 connections, you should set the environment variable \verb|ERL_MAX_PORTS|: \begin{verbatim} export ERL_MAX_PORTS=32000 \end{verbatim} Note that with this value, \ejabberd{} will use more memory (approximately 6\,MB more). To reduce memory usage, you may set the environment variable \verb|ERL_FULLSWEEP_AFTER|: \begin{verbatim} export ERL_FULLSWEEP_AFTER=0 \end{verbatim} But in this case \ejabberd{} can start to work slower. \section{Configuration} \label{sec:configuration} \subsection{Initial Configuration} \label{sec:initconfig} \ind{configuration file} The configuration file will be loaded the first time you start \ejabberd{}. The content from this file will be parsed and stored in a database. Subsequently the configuration will be loaded from the database and any commands in the configuration file are appended to the entries in the database. The configuration file contains a sequence of Erlang terms. Lines beginning with a \term{`\%'} sign are ignored. Each term is a tuple of which the first element is the name of an option, and any further elements are that option's values. If the configuration file do not contain for instance the ``hosts'' option, the old host name(s) stored in the database will be used. You can override the old values stored in the database by adding next lines to the configuration file: \begin{verbatim} override_global. override_local. override_acls. \end{verbatim} With these lines the old global options, local options and ACLs will be removed before new ones are added. \subsubsection{Host Names} \label{sec:confighostname} \ind{options!hosts}\ind{host names} The option \option{hosts} defines a list containing one or more domains that \ejabberd{} will serve. Examples: \begin{itemize} \item Serving one domain: \begin{itemize} \item \begin{verbatim} {hosts, ["example.org"]}. \end{verbatim} \item Backwards compatibility with older \ejabberd{} versions can be retained with: \begin{verbatim} {host, "example.org"}. \end{verbatim} \end{itemize} \item Serving two domains: \begin{verbatim} {hosts, ["example.net", "example.com"]}. \end{verbatim} \end{itemize} \subsubsection{Default Language} \label{sec:configlanguage} \ind{options!language}\ind{language} The option \option{language} defines the default language of server strings that can be seen by \Jabber{} clients. If a \Jabber{} client do not support \option{xml:lang}, the specified language is used. The default value for the option \option{language} is \term{"en"}. In order to take effect there must be a translation file \term{.msg} in \ejabberd{}'s \term{msgs} directory. Examples: \begin{itemize} \item To set Russian as default language: \begin{verbatim} {language, "ru"}. \end{verbatim} \item To set Spanish as default language: \begin{verbatim} {language, "es"}. \end{verbatim} \end{itemize} \subsubsection{Access Rules} \label{sec:configaccess} \ind{options!acl}\ind{access rules}\ind{ACL}\ind{Access Control List} Access control in \ejabberd{} is performed via Access Control Lists (ACLs). The declarations of ACLs in the configuration file have the following syntax: \begin{verbatim} {acl, , {, ...}}. \end{verbatim} \term{} can be one of the following: \begin{description} \titem{all} Matches all JIDs. Example: \begin{verbatim} {acl, all, all}. \end{verbatim} \titem{\{user, \}} Matches the user with the name \term{} at the first virtual host. Example: \begin{verbatim} {acl, admin, {user, "yozhik"}}. \end{verbatim} \titem{\{user, , \}} Matches the user with the JID \term{@} and any resource. Example: \begin{verbatim} {acl, admin, {user, "yozhik", "example.org"}}. \end{verbatim} \titem{\{server, \}} Matches any JID from server \term{}. Example: \begin{verbatim} {acl, exampleorg, {server, "example.org"}}. \end{verbatim} \titem{\{user\_regexp, \}} Matches any local user with a name that matches \term{} at the first virtual host. Example: \begin{verbatim} {acl, tests, {user, "^test[0-9]*$"}}. \end{verbatim} %$ \titem{\{user\_regexp, , \}} Matches any user with a name that matches \term{} at server \term{}. Example: \begin{verbatim} {acl, tests, {user, "^test", "example.org"}}. \end{verbatim} \titem{\{server\_regexp, \}} Matches any JID from the server that matches \term{}. Example: \begin{verbatim} {acl, icq, {server, "^icq\\."}}. \end{verbatim} \titem{\{node\_regexp, , \}} Matches any user with a name that matches \term{} at any server that matches \term{}. Example: \begin{verbatim} {acl, yohzik, {node_regexp, "^yohzik$", "^example.(com|org)$"}}. \end{verbatim} \titem{\{user\_glob, \}} \titem{\{user\_glob, , \}} \titem{\{server\_glob, \}} \titem{\{node\_glob, , \}} This is the same as above. However, it uses shell glob patterns instead of regexp. These patterns can have the following special characters: \begin{description} \titem{*} matches any string including the null string. \titem{?} matches any single character. \titem{[...]} matches any of the enclosed characters. Character ranges are specified by a pair of characters separated by a \term{`-'}. If the first character after \term{`['} is a \term{`!'}, any character not enclosed is matched. \end{description} \end{description} The following ACLs are pre-defined: \begin{description} \titem{all} Matches any JID. \titem{none} Matches no JID. \end{description} An entry allowing or denying access to different services looks similar to this: \begin{verbatim} {access, , [{allow, }, {deny, }, ... ]}. \end{verbatim} When a JID is checked to have access to \term{}, the server sequentially checks if that JID mathes any of the ACLs that are named in the second elements of the tuples in the list. If it matches, the first element of the first matched tuple is returned, otherwise ``\term{deny}'' is returned. Example: \begin{verbatim} {access, configure, [{allow, admin}]}. {access, something, [{deny, badmans}, {allow, all}]}. \end{verbatim} The following access rules are pre-defined: \begin{description} \titem{all} Always returns ``\term{allow}'' \titem{none} Always returns ``\term{deny}'' \end{description} \subsubsection{Shapers} \label{sec:configshaper} \ind{options!shaper}\ind{options!maxrate}\ind{shapers}\ind{maxrate}\ind{traffic speed} Shapers enable you to limit connection traffic. The syntax of shapers is like this: \begin{verbatim} {shaper, , }. \end{verbatim} Currently only one kind of shaper called \term{maxrate} is available. It has the following syntax: \begin{verbatim} {maxrate, } \end{verbatim} where \term{} stands for the maximum allowed incomig rate in bytes per second. Examples: \begin{itemize} \item To define a shaper named ``\term{normal}'' with traffic speed limited to 1,000\,bytes/second: \begin{verbatim} {shaper, normal, {maxrate, 1000}}. \end{verbatim} \item To define a shaper named ``\term{fast}'' with traffic speed limited to 50,000\,bytes/second: \begin{verbatim} {shaper, fast, {maxrate, 50000}}. \end{verbatim} \end{itemize} \subsubsection{Limitation of the number of opened sessions} \label{sec:configmaxsessions} \ind{options!max\_user\_sessions} This option specifies the maximum number of sessions (authenticated connections) per user. If a user tries to open more than the maximum number of allowed sessions, with different resources, the first opened session will be disconnected. The error ``\term{session replaced}'' is send to the disconnected session. This value is either a number or \term{infinity}. For example \verb|{max\_user\_sessions, 10}|. The default value is \term{10}. This option can be define per virtual host. See section~\ref{sec:configvirtualhost}. \subsubsection{Listened Sockets} \label{sec:configlistened} \ind{options!listen} The option \option{listen} defines for which addresses and ports \ejabberd{} will listen and what services will be run on them. Each element of the list is a tuple with the following elements: \begin{itemize} \item Port number. \item Module that serves this port. \item Options to this module. \end{itemize} \ind{modules!ejabberd\_c2s}\ind{modules!ejabberd\_s2s\_in}\ind{modules!ejabberd\_service}\ind{modules!ejabberd\_http}\ind{protocols!JEP-0114: Jabber Component Protocol} Currently next modules are implemented: \begin{table}[H] \centering \def\arraystretch{1.4} \begin{tabular}{|l|l|p{87mm}|} \hline \texttt{ejabberd\_c2s}& Description& Handles c2s connections.\\ \cline{2-3} & Options& \texttt{access}, \texttt{certfile}, \texttt{inet6}, \texttt{ip}, \texttt{max\_stanza\_size}, \texttt{shaper}, \texttt{ssl}, \texttt{tls}, \texttt{starttls}, \texttt{starttls\_required}, \texttt{zlib}\\ \hline \texttt{ejabberd\_s2s\_in}& Description& Handles incoming s2s connections.\\ \cline{2-3} & Options& \texttt{inet6}, \texttt{ip}, \texttt{max\_stanza\_size}\\ \hline \texttt{ejabberd\_service}& Description& Interacts with external components (*).\\ \cline{2-3} & Options& \texttt{access}, \texttt{hosts}, \texttt{inet6}, \texttt{ip}, \texttt{shaper}\\ \hline \texttt{ejabberd\_http}& Description& Handles incoming HTTP connections.\\ \cline{2-3} & Options& \texttt{certfile}, \texttt{http\_poll}, \texttt{inet6}, \texttt{ip}, \texttt{tls}, \texttt{web\_admin}\\ \hline \end{tabular} \end{table} (*) The mechanism for \footahref{http://ejabberd.jabber.ru/tutorials-transports}{external components} is defined in Jabber Component Protocol (\jepref{0114}). The following options are available: \begin{description} \titem{\{access, \}} \ind{options!access}This option defines access to the port. The default value is ``\term{all}''. \titem{\{certfile, Path\}} Path to a file containing the SSL certificate. \titem{\{hosts, [Hostnames], [HostOptions]\}} \ind{options!hosts}This option defines one or more hostnames of connected services and enables you to specify additional options including \poption{\{password, Secret\}}. \titem{http\_poll} \ind{options!http\_poll}\ind{protocols!JEP-0025: HTTP Polling}\ind{JWChat}\ind{web-based Jabber client} This option enables HTTP Polling (\jepref{0025}) support. HTTP Polling enables access via HTTP requests to \ejabberd{} from behind firewalls which do not allow outgoing sockets on port 5222. If HTTP Polling is enabled, it will be available at \verb|http://server:port/http-poll/|. Be aware that support for HTTP Polling is also needed in the \Jabber{} client. Remark also that HTTP Polling can be interesting to host a web-based \Jabber{} client such as \footahref{http://jwchat.sourceforge.net/}{JWChat} (there is a tutorial to \footahref{http://ejabberd.jabber.ru/jwchat}{install JWChat} with instructions for \ejabberd{}). \titem{inet6} \ind{options!inet6}\ind{IPv6}Set up the socket for IPv6. \titem{\{ip, IPAddress\}} \ind{options!ip}This option specifies which network interface to listen for. For example \verb|{ip, {192, 168, 1, 1}}|. \titem{\{max\_stanza\_size, Size\}} \ind{options!max\_stanza\_size}This option specifies an approximate maximal size in bytes of XML stanzas. For example \verb|{max\_stanza\_size, 65536}|. The default value is ``\term{infinity}''. \titem{\{shaper, \}} \ind{options!shaper}This option defines a shaper for the port (see section~\ref{sec:configshaper}). The default value is ``\term{none}''. \titem{ssl} \ind{options!ssl}\ind{SSL}This option specifies that traffic on the port will be encrypted using SSL. You should also set the \option{certfile} option. It is recommended to use the \term{tls} option instead. \titem{starttls} \ind{options!starttls}\ind{modules!STARTTLS}This option specifies that STARTTLS encryption is available on connections to the port. You should also set the \option{certfile} option. \titem{starttls\_required} \ind{options!starttls\_required}This option specifies that STARTTLS encryption is required on connections to the port. No unencrypted connections will be allowed. You should also set the \option{certfile} option. \titem{tls} \ind{options!tls}\ind{TLS}This option specifies that traffic on the port will be encrypted using SSL immediately after connecting. You should also set the \option{certfile} option. \titem{zlib} \ind{options!zlib}\ind{protocols!JEP-0138: Stream Compression}\ind{Zlib}This option specifies that Zlib stream compression (as defined in \jepref{0138}) is available on connections to the port. Client cannot use stream compression and stream encryption simultaneously, so if you specify both \option{tls} (or \option{ssl}) and \option{zlib} the latter option will not affect connection at all. \titem{web\_admin} \ind{options!web\_admin}\ind{web interface}This option enables the web interface for \ejabberd{} administration which is available at \verb|http://server:port/admin/|. Login and password are the username and password of one of the registered users who are granted access by the ``configure'' access rule. \end{description} Also the following global options are available for s2s connections: \begin{description} \titem{\{s2s\_use\_starttls, true|false\}} \ind{options!s2s\_use\_starttls}This option defines whether to use STARTTLS for s2s connections. \titem{\{s2s\_certfile, Path\}} \ind{options!s2s\_certificate}Path to the file containing the SSL certificate. \titem{\{domain\_certfile, Domain, Path\}} \ind{options!domain\_certfile}Path to the file containing the SSL certificate for the specified domain. \end{description} For instance, the following configuration defines that: \begin{itemize} \item c2s connections are listened for on port 5222 and 5223 (SSL) and denied for the user ``\term{bad}'' \item s2s connections are listened for on port 5269 with STARTTLS for secured traffic enabled. \item Port 5280 is serving the web interface and the HTTP Polling service. Note that it is also possible to serve them on different ports. The second example in section~\ref{sec:webadm} shows how exactly this can be done. \item All users except for the administrators have a traffic of limit 1,000\,Bytes/second \item \ind{transports!AIM}The \footahref{http://ejabberd.jabber.ru/pyaimt}{AIM transport} \jid{aim.example.org} is connected to port 5233 with password ``\term{aimsecret}'' \item \ind{transports!ICQ}The ICQ transport JIT (\jid{icq.example.org} and \jid{sms.example.org}) is connected to port 5234 with password ``\term{jitsecret}'' \item \ind{transports!MSN}The \footahref{http://ejabberd.jabber.ru/pymsnt}{MSN transport} \jid{msn.example.org} is connected to port 5235 with password ``\term{msnsecret}'' \item \ind{transports!Yahoo}The \footahref{http://ejabberd.jabber.ru/yahoo-transport-2}{Yahoo! transport} \jid{yahoo.example.org} is connected to port 5236 with password ``\term{yahoosecret}'' \item \ind{transports!Gadu-Gadu}The \footahref{http://ejabberd.jabber.ru/jabber-gg-transport}{Gadu-Gadu transport} \jid{gg.example.org} is connected to port 5237 with password ``\term{ggsecret}'' \item \ind{transports!email notifier}The \footahref{http://ejabberd.jabber.ru/jmc}{Jabber Mail Component} \jid{jmc.example.org} is connected to port 5238 with password ``\term{jmcsecret}'' \end{itemize} \begin{verbatim} {acl, blocked, {user, "bad"}}. {access, c2s, [{deny, blocked}, {allow, all}]}. {shaper, normal, {maxrate, 1000}}. {access, c2s_shaper, [{none, admin}, {normal, all}]}. {listen, [{5222, ejabberd_c2s, [{access, c2s}, {shaper, c2s_shaper}]}, {5223, ejabberd_c2s, [{access, c2s}, ssl, {certfile, "/path/to/ssl.pem"}]}, {5269, ejabberd_s2s_in, []}, {5280, ejabberd_http, [http_poll, web_admin]}, {5233, ejabberd_service, [{host, "aim.example.org", [{password, "aimsecret"}]}]}, {5234, ejabberd_service, [{hosts, ["icq.example.org", "sms.example.org"], [{password, "jitsecret"}]}]}, {5235, ejabberd_service, [{host, "msn.example.org", [{password, "msnsecret"}]}]}, {5236, ejabberd_service, [{host, "yahoo.example.org", [{password, "yahoosecret"}]}]}, {5237, ejabberd_service, [{host, "gg.example.org", [{password, "ggsecret"}]}]}, {5238, ejabberd_service, [{host, "jmc.example.org", [{password, "jmcsecret"}]}]} ] }. {s2s_use_starttls, true}. {s2s_certfile, "/path/to/ssl.pem"}. \end{verbatim} Note, that for \ind{jabberd 1.4}jabberd 1.4- or \ind{WPJabber}WPJabber-based services you have to make the transports log and do \ind{XDB}XDB by themselves: \begin{verbatim} %d: [%t] (%h): %s /var/log/jabber/service.log /usr/lib/jabber/xdb_file.so /var/spool/jabber \end{verbatim} \subsubsection{Modules} \label{sec:configmodules} \ind{modules} The option \term{modules} defines the list of modules that will be loaded after \ejabberd{}'s startup. Each entry in the list is a tuple in which the first element is the name of a module and the second is a list of options for that module. Read section~\ref{sec:modules} for detailed information about modules. Examples: \begin{itemize} \item In this simple example, only the module \modecho{} is loaded and no options are specified between square brackets: \begin{verbatim} {modules, [{mod_echo, []} ]}. \end{verbatim} \item The second example is also simple: the modules \modecho{}, \modtime{}, and \modversion{} are loaded without options. Remark that, besides the last entry, all entries end with a comma: \begin{verbatim} {modules, [{mod_echo, []}, {mod_time, []}, {mod_version, []} ]}. \end{verbatim} \end{itemize} \subsubsection{Virtual Hosting} \label{sec:configvirtualhost} \ind{virtual hosting}\ind{virtual hosts} Options can be defined separately for every virtual host using the \term{host\_config} option.\ind{options!host\_config} It has the following syntax: \begin{verbatim} {host_config, , [