-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathxmpp-server.xml
285 lines (218 loc) · 10.2 KB
/
xmpp-server.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
<?xml version="1.0" encoding="UTF-8"?>
<chapter xmlns="http://docbook.org/ns/docbook"
xmlns:xlink="http://www.w3.org/1999/xlink" version="5.0"
xml:id="xmpp-server">
<title>XMPP (Jabber) server installation</title>
<sect1 xml:id="xmpp-server-choice">
<title>Choosing an XMPP server</title>
<para>It is recommended that you use the <emphasis>Prosody</emphasis>
XMPP server. It is widely used and relatively easy to configure.
Latest releases of <emphasis>Prosody</emphasis> are being made
available as packages on the major Linux distributions.</para>
<para>You can also use <emphasis>ejabberd</emphasis>,
<emphasis>jabberd2</emphasis> or another server if you
prefer.</para>
</sect1>
<sect1 xml:id="xmpp-server-prosody">
<title>Prosody XMPP server</title>
<sect2>
<title>Package installation</title>
<para>Install the package using the appropriate tool, as
demonstrated in <xref linkend="prosody-install-debian"/> and
<xref linkend="prosody-install-redhat"/>.</para>
<example xml:id="prosody-install-debian">
<title>Installing <emphasis>Prosody</emphasis> on Debian/Ubuntu</title>
<programlisting format="linespecific">$ sudo apt-get install prosody
$ sudo addgroup prosody ssl-cert </programlisting>
</example>
<example xml:id="prosody-install-redhat">
<title>Install <emphasis>Prosody</emphasis> on Fedora/RHEL/CentOS</title>
<programlisting format="linespecific">$ sudo yum install prosody
$ sudo addgroup prosody ssl-cert </programlisting>
</example>
</sect2>
<sect2>
<title>Configuration</title>
<para>Prosody can use the certificates created in <xref linkend="tls"/>.
In the Prosody configuration, you can refer to the PEM files
directly under <code>/etc/ssl</code>. Alternatively, you can copy
the certificate files and private key PEM files to
<code>/etc/prosody/certs</code> or create symbolic links from that
location to the real PEM files. Whichever approach you choose,
make sure that the private key file (or a copy of it) is readable
by the user that Prosody runs as but be careful to ensure they
are not world-readable.</para>
<para>Using the example provided, create configuration files for
each domain you want to host under <code>/etc/prosody/conf.d</code>.
<xref linkend="prosody-domain-config-certbot"/> demonstrates the minimum
configuration for a domain using Let's Encrypt certificates and
<xref linkend="prosody-domain-config-manual"/> demonstrates the
equivalent configuration for a domain using manually maintained
certificates.</para>
<example xml:id="prosody-domain-config-certbot">
<title>Domain configuration file (Let's Encrypt / <literal>certbot</literal>)</title>
<programlisting format="linespecific">-- Section for VirtualHost example.com
VirtualHost "example.org"
ssl = {
key = "/etc/letsencrypt/live/example.org/privkey.pem";
certificate = "/etc/letsencrypt/live/example.org/fullchain.pem";
} </programlisting>
</example>
<example xml:id="prosody-domain-config-manual">
<title>Domain configuration file (manual)</title>
<programlisting format="linespecific">-- Section for VirtualHost example.com
VirtualHost "example.org"
ssl = {
key = "/etc/ssl/private/example.org-key.pem";
certificate = "/etc/ssl/public/example.org.pem";
} </programlisting>
</example>
<para>Edit the file <code>/etc/prosody/prosody.cfg.lua</code>. This
is where you can do things like enabling the LDAP authentication
module or enabling SQL storage for user data.</para>
<para>Once configuration is complete, restart the daemon as
demonstrated in <xref linkend="prosody-restart"/>.</para>
<example xml:id="prosody-restart">
<title>Restarting the <code>prosody</code> daemon (<code>systemd</code>)</title>
<programlisting format="linespecific">$ sudo systemctl restart prosody
Restarting prosody </programlisting>
</example>
</sect2>
<sect2>
<title>User management</title>
<para>It is not necessary to add users manually. If users are
authenticated by LDAP, for example, Prosody will dynamically
create the XMPP account the first time the user logs in. If such a
system is not in use, users can be added manually using the command
line utility <code>prosodyctl</code> or using a web interface.</para>
<para><xref linkend="prosody-add-user"/> demonstrates how to add
a user at the command line.</para>
<example xml:id="prosody-add-user">
<title>Using <code>prosodyctl</code> to add a user</title>
<programlisting format="linespecific">$ sudo prosodyctl adduser alice@example.org </programlisting>
</example>
<para>To use LDAP authentication, make sure that
<code>mod_auth_ldap.lua</code> is in the Prosody <code>lib</code>
directory and add the LDAP settings to <code>prosody.cfg.lua</code>
as demonstrated in <xref linkend="prosody-cfg-ldap"/>.</para>
<example xml:id="prosody-cfg-ldap">
<title><code>prosody.cfg.lua</code> settings for
<code>mod_auth_ldap</code></title>
<programlisting format="linespecific">authentication = "ldap"
ldap_server = "ldap-server.example.org"
ldap_rootdn = ""
ldap_password = ""
ldap_filter = "(mail=$user@$host)"
ldap_scope = "subtree"
ldap_tls = true;
ldap_base = "dc=example,dc=org"
ldap_mode = "bind" </programlisting>
</example>
</sect2>
<sect2>
<title>Further reading</title>
<para>The <link xlink:href="https://prosody.im/doc/install">Prosody web
site gives more detailed documentation about setting up the user
accounts and other steps</link>.</para>
</sect2>
</sect1>
<sect1 xml:id="xmpp-server-ejabberd">
<title>ejabberd XMPP server</title>
<sect2>
<title>Package installation</title>
<para>Install the package using the appropriate tool, as
demonstrated in <xref linkend="ejabberd-install-debian"/> and
<xref linkend="ejabberd-install-redhat"/>.</para>
<example xml:id="ejabberd-install-debian">
<title>Installing <emphasis>ejabberd</emphasis> on
Debian/Ubuntu</title>
<programlisting format="linespecific">$ sudo apt-get install ejabberd
$ sudo addgroup ejabberd ssl-cert </programlisting>
</example>
<example xml:id="ejabberd-install-redhat">
<title>Install <emphasis>ejabberd</emphasis> on
Fedora/RHEL/CentOS</title>
<programlisting format="linespecific">$ sudo yum install ejabberd
$ sudo addgroup ejabberd ssl-cert </programlisting>
</example>
</sect2>
<sect2>
<title>Configuration</title>
<para>Modify the file <code>/etc/ejabberd/ejabberd.cfg</code>, add
the server IP address and the path to the certificate as
demonstrated in <xref linkend="ejabberd-interface-config"/>.</para>
<example xml:id="ejabberd-interface-config">
<title><code>ejabberd</code> interface example</title>
<programlisting format="linespecific">{listen,
[
{5222, ejabberd_c2s, [
{access, c2s},
{ip, {195, 8, 117, 19}},
{shaper, c2s_shaper},
{max_stanza_size, 65536},
%% {certfile, "/etc/ssl/private/example.org-key_combined.pem"},
starttls_required
]}, </programlisting>
</example>
<para>Set up the users: go to
<emphasis role="bold">http://server1.example.org:5280</emphasis>,
log in and set up the user accounts.</para>
</sect2>
</sect1>
<sect1 xml:id="xmpp-server-jabberd2">
<title>jabberd2 XMPP server</title>
<sect2>
<title>Package installation</title>
<para>Install the package using the appropriate tool, as
demonstrated in <xref linkend="jabberd2-install-debian"/> and
<xref linkend="jabberd2-install-redhat"/>.</para>
<example xml:id="jabberd2-install-debian">
<title>Installing <emphasis>jabberd2</emphasis> on
Debian/Ubuntu</title>
<programlisting format="linespecific">$ sudo apt-get install jabberd2
$ sudo addgroup jabber ssl-cert </programlisting>
</example>
<example xml:id="jabberd2-install-redhat">
<title>Install <emphasis>jabberd2</emphasis> on
Fedora/RHEL/CentOS</title>
<programlisting format="linespecific">$ sudo yum install jabberd
$ sudo addgroup jabberd ssl-cert </programlisting>
</example>
</sect2>
<sect2>
<title>Configuration</title>
<para>jabberd2's configuration files are in
<code>/etc/jabberd2/</code> (Debian/Ubuntu) or
<code>/etc/jabberd/</code> (Fedora/RHEL/CentOS). It can use the
certificates created in <xref linkend="tls"/>. jabberd2 is
modular and each of the components needs to be
configured.</para>
<para>The most basic jabberd configuration requires setting the
hostname of the server in c2s.xml as demonstrated in <xref
linkend="jabberd2-c2s-hostname-config"/> and the JID domain in
sm.xml as demonstrated in <xref
linkend="jabberd2-sm-domain-config"/> The default storage module
in sm.xml and authreg module in c2s.xml are sqlite which works
well for most installations.</para>
<example xml:id="jabberd2-c2s-hostname-config">
<title><code>jabberd2</code> c2s.xml example</title>
<programlisting format="linespecific"><id password-change='mu'
require-starttls='mu'
cachain='/etc/ssl/public/example.org.pem'
pemfile='/etc/ssl/private/example.org-key.pem'>
xmpp-gw.example.org
</id></programlisting>
</example>
<example xml:id="jabberd2-sm-domain-config">
<title><code>jabberd2</code> sm.xml example</title>
<programlisting format="linespecific"><id>example.org</id></programlisting>
</example>
</sect2>
<sect2>
<title>Further reading</title>
<para>The <link xlink:href="http://jabberd2.org">jabberd2 web
site</link> gives more detailed documentation about setting up
the server.</para>
</sect2>
</sect1>
</chapter>