jabber.xml(5) 1.4.4 jabber.xml(5)
jabberd14 project jabberd14 project
15 Mar 2005
NAME
jabber.xml - jabberd daemon configuration file
SYNOPSIS
The jabber daemon jabberd is configured by an XML configuration file.
By default jabberd will read /usr/local/etc/jabber.xml. The -c command
line option can be used to specify an alternate configuration file.
FILE FORMAT
The configuration file has to be a valid XML document preferably in
the UTF-8 charset (ASCII is valid subset of UTF-8).
<jabber/>
This is the root element of the configuration file.
<service/>
This element is an immediate child element of the <jabber/> root
element. It defines a general purpose component in the jabber
daemon. The jabber daemon will route all stanzas to this
component that have a domain part in the destination JID that
equals the id attribute or any defined additional domains this
component is responsible for using the <host/> child element. An
implementation or relation to an other process is defined using
one of the following child elements: <accept/>, <connect/>,
<dynamic/>, <exec/>, <load/>, <null/>. Any child elements in own
namespaces are ignored by the core jabberd and can be used by
components to store their own configuration.
<xdb/>
This element is an immediate child element of the <jabber/> root
element. It defines a component in the jabber daemon, that is
responsible for XML data storage. This components internal
address is defined by the id attribute. The <host/> child
elements define for which domains this storage component is
managing the data. An empty <host/> element defines, that it is
responsible for all components. With the <ns/> child element you
can limit the responsibility to XML chunks in a given set of
namespaces. You can then for example define one storage component
that handles rosters and an other that handles offline message
storage. An implementation or relation to an other process is
defined using on of the following child elements: <accept/>,
<connect/>, <dynamic/>, <exec/>, <load/>, <null/>. Any child
elements in own namespaces are ignored by the core jabberd and
can be used by components to store their own configuration.
<log/>
This element is an immediate child element of the <jabber/> root
element. It defines a component in the jabber daemon, that acts
as a logging sink. This components internal address is defined
- 1 - Formatted: October 24, 2025
jabber.xml(5) 1.4.4 jabber.xml(5)
jabberd14 project jabberd14 project
15 Mar 2005
by the id attribute. The <host/> child elements define for which
domains this logging sink is logging messages. An empty <host/>
element defines, that it is responsible for all components. With
the <logtype/> child element you can select the types of
messages, that are handled by this component. Where to write the
logging information is defined with one of the following child
elements: <file/>, <stderr/>, <stdout/>, <to/>. With the
<format/> child element you define the format of the logged
message.
<io/>
This element is an immediate child element of the <jabber/> root
element. In this section of the configuration file you can
define different settings that are related to the network I/O
layer. This includes bandwidth limitations (using the <karma/>
element), assigning X.509 certificates to sockets (using the
<ssl/> element), and to limit access to the server to specific IP
address ranges (using the <allow/> and <deny/> elements).
<pidfile/>
This element specifies to which file the server should write its
process ID. If this file already exists when the server is
started, it will fail. You have to remove stale pidfiles before
starting the server yourself. If you omit this element, the
server will not write nor check any pidfile.
<debug/>
This element contains configuration settings controlling the
output of debugging messages. These settings can be changed at
server runtime, the server will reread them on receiving a SIGHUP
signal.
The following elements are used inside the <service/>, <xdb/>, and <log/>
elements, that are defining components. They are used to provide
the jabberd process with information where it can find the
component's implementation.
<load/>
This element can be used inside any component definition. It
specifies, that the implementation of the component can be found
inside a shared object. Any child element of this element defines
a shared object file and a method in this object. jabberd will
load the shared object files which locations are defined in the
cdata elements inside the child elements, the names of the
elements are defining the functions that have to be called. An
optional main attribute in the <load/> element define the main
function in a component, that has to be used to initialize it.
<accept/>
- 2 - Formatted: October 24, 2025
jabber.xml(5) 1.4.4 jabber.xml(5)
jabberd14 project jabberd14 project
15 Mar 2005
This element defines, that jabberd will wait for an incoming
connection using the jabber:component:accept protocol defined in
JEP-0114. With this it is possible to run components in their own
process, even on different hosts and connect it to the main
jabberd routing process. On the other end of the connection there
can be an instance of jabberd again that uses a section with
<connect/> to initiate the connection, but there are libraries in
many programming languages available, that implement JEP-0114 as
well. Inside this element you have to provide an <ip/> element,
that defines the IPv4 or IPv6 address to listen on, a <port/>
element that defines on which port the server will listen for the
connection, and a <secret/> element, that defines a shared secret
to authenticate the other peer.
<connect/>
This element is the opposite of the <accept/> element. Jabberd
will try to connect to an implementation of the
jabber:component:accept protocol defined in JEP-0114. Inside
this element you have to provide an <ip/> element, that defines
the IPv4 or IPv6 address where to connect to, a <port/> element,
that defines the destination port, and a <secret/> element, that
defines a shared secret to authenticate to the other peer.
<dynamic/>
This element defines a directory where components reside.
Incoming packets are routed to the components based on the node
or resource part of the JabberID. The files in this directory
can be shared objects or executables. This is rarely used and
badly tested.
<exec/>
This element is used to start an external component. Instead of
using a TCP socket to communicate with it, the jabberd process
will execute the component and communicate with it using pipes on
stdin and stdout.
<file/>
This element can only be used inside a <log/> section. It is used
to specify that log messages should be appended to a text file.
<null/>
This element specifies an empty component. Everything that is
sent to a JabberID with the domain part of this component is
silently discarded. It can be used to drop stanzas directed to
entities on the Jabber network, that have disappeared (e.g.
update.jabber.org).
<stderr/>
This element can only be used inside a <log/> section. It is used
- 3 - Formatted: October 24, 2025
jabber.xml(5) 1.4.4 jabber.xml(5)
jabberd14 project jabberd14 project
15 Mar 2005
to specify that log messages should be written to the standard
error output stream.
<stdout/>
This element is used to define, that the jabberd process is
communicating with the process, that is implementing the
component. It is the opposite of <exec/>. A process that is
started by <exec/> in an other process can use <stdout/> to
implement the other end of the connecting pipe.
<syslog/>
This element can only be used inside a <log/> section. It is used
to specify that log messages should be written to the syslog.
<to/>
This element can only be used inside a <log/> section. It is used
to reformat log packets as messages and resend them to an entity
with the given JabberID. The JabberID is given as cdata child
element.
<unsubscribe/>
This element can only be used inside a <service/> section. It is
used to bounce messages and iq queries and send unsubscribes to
presences, that are received. It is intended to be used as a
replacement for transports, that are removed from a server. It
will remove the roster items of this transport from the users'
rosters.
AUTHOR
Jabber Software Foundation
- 4 - Formatted: October 24, 2025