mirror of
https://github.com/processone/ejabberd.git
synced 2024-11-22 16:20:52 +01:00
* doc/guide.tex: New subsection Database Connection
* doc/guide.html: Likewise SVN Revision: 1697
This commit is contained in:
parent
7348f4a553
commit
60ae1b47c5
@ -1,3 +1,8 @@
|
|||||||
|
2008-12-01 Badlop <badlop@process-one.net>
|
||||||
|
|
||||||
|
* doc/guide.tex: New subsection Database Connection
|
||||||
|
* doc/guide.html: Likewise
|
||||||
|
|
||||||
2008-11-28 Alexey Shchepin <alexey@process-one.net>
|
2008-11-28 Alexey Shchepin <alexey@process-one.net>
|
||||||
|
|
||||||
* src/mod_muc/mod_muc_room.erl: Clean user activity after timeout
|
* src/mod_muc/mod_muc_room.erl: Clean user activity after timeout
|
||||||
|
141
doc/guide.html
141
doc/guide.html
@ -1246,7 +1246,18 @@ different storage systems for modules, and so forth.</P><P>The following databas
|
|||||||
</LI><LI CLASS="li-itemize"><A HREF="http://www.openldap.org/">OpenLDAP</A>
|
</LI><LI CLASS="li-itemize"><A HREF="http://www.openldap.org/">OpenLDAP</A>
|
||||||
</LI><LI CLASS="li-itemize">Normally any LDAP compatible server should work; inform us about your
|
</LI><LI CLASS="li-itemize">Normally any LDAP compatible server should work; inform us about your
|
||||||
success with a not-listed server so that we can list it here.
|
success with a not-listed server so that we can list it here.
|
||||||
</LI></UL><P> <A NAME="mysql"></A> </P><!--TOC subsection MySQL-->
|
</LI></UL><P>Important note about virtual hosting:
|
||||||
|
if you define several domains in ejabberd.cfg (see section <A HREF="#hostnames">3.1.1</A>),
|
||||||
|
you probably want that each virtual host uses a different configuration of database, authentication and storage,
|
||||||
|
so that usernames do not conflict and mix between different virtual hosts.
|
||||||
|
For that purpose, the options described in the next sections
|
||||||
|
must be set inside a <TT>host_cofig</TT> for each vhost (see section <A HREF="#virtualhost">3.1.2</A>).
|
||||||
|
For example:
|
||||||
|
</P><PRE CLASS="verbatim">{host_config, "public.example.org", [
|
||||||
|
{odbc_server, {pgsql, "localhost", "database", "ejabberd", "password"}},
|
||||||
|
{auth_method, [odbc]}
|
||||||
|
]}.
|
||||||
|
</PRE><P> <A NAME="mysql"></A> </P><!--TOC subsection MySQL-->
|
||||||
<H3 CLASS="subsection"><!--SEC ANCHOR --><A NAME="htoc31">3.2.1</A>  <A HREF="#mysql">MySQL</A></H3><!--SEC END --><P> <A NAME="mysql"></A>
|
<H3 CLASS="subsection"><!--SEC ANCHOR --><A NAME="htoc31">3.2.1</A>  <A HREF="#mysql">MySQL</A></H3><!--SEC END --><P> <A NAME="mysql"></A>
|
||||||
</P><P>Although this section will describe <TT>ejabberd</TT>’s configuration when you want to
|
</P><P>Although this section will describe <TT>ejabberd</TT>’s configuration when you want to
|
||||||
use the native MySQL driver, it does not describe MySQL’s installation and
|
use the native MySQL driver, it does not describe MySQL’s installation and
|
||||||
@ -1254,18 +1265,7 @@ database creation. Check the MySQL documentation and the tutorial <A HREF="http:
|
|||||||
Note that the tutorial contains information about <TT>ejabberd</TT>’s configuration
|
Note that the tutorial contains information about <TT>ejabberd</TT>’s configuration
|
||||||
which is duplicate to this section.</P><P>Moreover, the file mysql.sql in the directory src/odbc might be interesting for
|
which is duplicate to this section.</P><P>Moreover, the file mysql.sql in the directory src/odbc might be interesting for
|
||||||
you. This file contains the <TT>ejabberd</TT> schema for MySQL. At the end of the file
|
you. This file contains the <TT>ejabberd</TT> schema for MySQL. At the end of the file
|
||||||
you can find information to update your database schema.</P><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
you can find information to update your database schema.</P><P> <A NAME="compilemysql"></A> </P><!--TOC subsubsection Driver Compilation-->
|
||||||
Use this option to modify the value:
|
|
||||||
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
|
||||||
</PRE><P>You can configure an interval to make a dummy SQL request
|
|
||||||
to keep alive the connections to the database.
|
|
||||||
The default value is ’undefined’, so no keepalive requests are made.
|
|
||||||
Specify in seconds: for example 28800 means 8 hours.
|
|
||||||
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
|
||||||
</PRE><P>If the connection to the database fails, <TT>ejabberd</TT> waits 30 seconds before retrying.
|
|
||||||
You can modify this interval with this option:
|
|
||||||
</P><PRE CLASS="verbatim">{odbc_start_interval, 30}.
|
|
||||||
</PRE><P> <A NAME="compilemysql"></A> </P><!--TOC subsubsection Driver Compilation-->
|
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compilemysql">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compilemysql"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compilemysql">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compilemysql"></A>
|
||||||
</P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
</P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
||||||
if the binary packages of <TT>ejabberd</TT> you are using include support for MySQL.</P><OL CLASS="enumerate" type=1><LI CLASS="li-enumerate">
|
if the binary packages of <TT>ejabberd</TT> you are using include support for MySQL.</P><OL CLASS="enumerate" type=1><LI CLASS="li-enumerate">
|
||||||
@ -1276,14 +1276,9 @@ put them for example in the same directory as your <TT>ejabberd</TT> .beam files
|
|||||||
also needed for native MySQL support!). This can be done, by using next
|
also needed for native MySQL support!). This can be done, by using next
|
||||||
commands:
|
commands:
|
||||||
<PRE CLASS="verbatim">./configure --enable-odbc && make install
|
<PRE CLASS="verbatim">./configure --enable-odbc && make install
|
||||||
</PRE></LI></OL><P> <A NAME="mysqlauth"></A> </P><!--TOC subsubsection Authentication-->
|
</PRE></LI></OL><P> <A NAME="configuremysql"></A> </P><!--TOC subsubsection Database Connection-->
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#mysqlauth">Authentication</A></H4><!--SEC END --><P> <A NAME="mysqlauth"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#configuremysql">Database Connection</A></H4><!--SEC END --><P> <A NAME="configuremysql"></A>
|
||||||
</P><P>The option value name may be misleading, as the <TT>auth_method</TT> name is used
|
</P><P>The actual database access is defined in the option <TT>odbc_server</TT>. Its
|
||||||
for access to a relational database through ODBC, as well as through the native
|
|
||||||
MySQL interface. Anyway, the first configuration step is to define the odbc
|
|
||||||
<TT>auth_method</TT>. For example:
|
|
||||||
</P><PRE CLASS="verbatim">{host_config, "public.example.org", [{auth_method, [odbc]}]}.
|
|
||||||
</PRE><P>The actual database access is defined in the option <TT>odbc_server</TT>. Its
|
|
||||||
value is used to define if we want to use ODBC, or one of the two native
|
value is used to define if we want to use ODBC, or one of the two native
|
||||||
interface available, PostgreSQL or MySQL.</P><P>To use the native MySQL interface, you can pass a tuple of the following form as
|
interface available, PostgreSQL or MySQL.</P><P>To use the native MySQL interface, you can pass a tuple of the following form as
|
||||||
parameter:
|
parameter:
|
||||||
@ -1297,6 +1292,24 @@ can thus take the following form:
|
|||||||
</P><PRE CLASS="verbatim">{mysql, "Server", Port, "Database", "Username", "Password"}
|
</P><PRE CLASS="verbatim">{mysql, "Server", Port, "Database", "Username", "Password"}
|
||||||
</PRE><P>The <TT>Port</TT> value should be an integer, without quotes. For example:
|
</PRE><P>The <TT>Port</TT> value should be an integer, without quotes. For example:
|
||||||
</P><PRE CLASS="verbatim">{odbc_server, {mysql, "localhost", Port, "test", "root", "password"}}.
|
</P><PRE CLASS="verbatim">{odbc_server, {mysql, "localhost", Port, "test", "root", "password"}}.
|
||||||
|
</PRE><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
||||||
|
Use this option to modify the value:
|
||||||
|
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
||||||
|
</PRE><P>You can configure an interval to make a dummy SQL request
|
||||||
|
to keep alive the connections to the database.
|
||||||
|
The default value is ’undefined’, so no keepalive requests are made.
|
||||||
|
Specify in seconds: for example 28800 means 8 hours.
|
||||||
|
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
||||||
|
</PRE><P>If the connection to the database fails, <TT>ejabberd</TT> waits 30 seconds before retrying.
|
||||||
|
You can modify this interval with this option:
|
||||||
|
</P><PRE CLASS="verbatim">{odbc_start_interval, 30}.
|
||||||
|
</PRE><P> <A NAME="mysqlauth"></A> </P><!--TOC subsubsection Authentication-->
|
||||||
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#mysqlauth">Authentication</A></H4><!--SEC END --><P> <A NAME="mysqlauth"></A>
|
||||||
|
</P><P>The option value name may be misleading, as the <TT>auth_method</TT> name is used
|
||||||
|
for access to a relational database through ODBC, as well as through the native
|
||||||
|
MySQL interface. Anyway, the first configuration step is to define the odbc
|
||||||
|
<TT>auth_method</TT>. For example:
|
||||||
|
</P><PRE CLASS="verbatim">{auth_method, [odbc]}.
|
||||||
</PRE><P> <A NAME="mysqlstorage"></A> </P><!--TOC subsubsection Storage-->
|
</PRE><P> <A NAME="mysqlstorage"></A> </P><!--TOC subsubsection Storage-->
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#mysqlstorage">Storage</A></H4><!--SEC END --><P> <A NAME="mysqlstorage"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#mysqlstorage">Storage</A></H4><!--SEC END --><P> <A NAME="mysqlstorage"></A>
|
||||||
</P><P>MySQL also can be used to store information into from several <TT>ejabberd</TT>
|
</P><P>MySQL also can be used to store information into from several <TT>ejabberd</TT>
|
||||||
@ -1314,7 +1327,16 @@ tutorial <A HREF="http://support.process-one.net/doc/display/MESSENGER/Using+eja
|
|||||||
Note that the tutorial contains information about <TT>ejabberd</TT>’s configuration
|
Note that the tutorial contains information about <TT>ejabberd</TT>’s configuration
|
||||||
which is duplicate to this section.</P><P>Moreover, the file mssql.sql in the directory src/odbc might be interesting for
|
which is duplicate to this section.</P><P>Moreover, the file mssql.sql in the directory src/odbc might be interesting for
|
||||||
you. This file contains the <TT>ejabberd</TT> schema for Microsoft SQL Server. At the end
|
you. This file contains the <TT>ejabberd</TT> schema for Microsoft SQL Server. At the end
|
||||||
of the file you can find information to update your database schema.</P><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
of the file you can find information to update your database schema.</P><P> <A NAME="compilemssql"></A> </P><!--TOC subsubsection Driver Compilation-->
|
||||||
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compilemssql">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compilemssql"></A>
|
||||||
|
</P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
||||||
|
if the binary packages of <TT>ejabberd</TT> you are using include support for ODBC.</P><P>If you want to use Microsoft SQL Server with ODBC, you need to configure,
|
||||||
|
compile and install <TT>ejabberd</TT> with support for ODBC and Microsoft SQL Server
|
||||||
|
enabled. This can be done, by using next commands:
|
||||||
|
</P><PRE CLASS="verbatim">./configure --enable-odbc --enable-mssql && make install
|
||||||
|
</PRE><P> <A NAME="configuremssql"></A> </P><!--TOC subsubsection Database Connection-->
|
||||||
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#configuremssql">Database Connection</A></H4><!--SEC END --><P> <A NAME="configuremssql"></A>
|
||||||
|
</P><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
||||||
Use this option to modify the value:
|
Use this option to modify the value:
|
||||||
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
||||||
</PRE><P>You can configure an interval to make a dummy SQL request
|
</PRE><P>You can configure an interval to make a dummy SQL request
|
||||||
@ -1322,13 +1344,6 @@ to keep alive the connections to the database.
|
|||||||
The default value is ’undefined’, so no keepalive requests are made.
|
The default value is ’undefined’, so no keepalive requests are made.
|
||||||
Specify in seconds: for example 28800 means 8 hours.
|
Specify in seconds: for example 28800 means 8 hours.
|
||||||
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
||||||
</PRE><P> <A NAME="compilemssql"></A> </P><!--TOC subsubsection Driver Compilation-->
|
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compilemssql">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compilemssql"></A>
|
|
||||||
</P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
|
||||||
if the binary packages of <TT>ejabberd</TT> you are using include support for ODBC.</P><P>If you want to use Microsoft SQL Server with ODBC, you need to configure,
|
|
||||||
compile and install <TT>ejabberd</TT> with support for ODBC and Microsoft SQL Server
|
|
||||||
enabled. This can be done, by using next commands:
|
|
||||||
</P><PRE CLASS="verbatim">./configure --enable-odbc --enable-mssql && make install
|
|
||||||
</PRE><P> <A NAME="mssqlauth"></A> </P><!--TOC subsubsection Authentication-->
|
</PRE><P> <A NAME="mssqlauth"></A> </P><!--TOC subsubsection Authentication-->
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#mssqlauth">Authentication</A></H4><!--SEC END --><P> <A NAME="mssqlauth"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#mssqlauth">Authentication</A></H4><!--SEC END --><P> <A NAME="mssqlauth"></A>
|
||||||
</P><P>The configuration of Microsoft SQL Server is the same as the configuration of
|
</P><P>The configuration of Microsoft SQL Server is the same as the configuration of
|
||||||
@ -1349,15 +1364,7 @@ and database creation. Check the PostgreSQL documentation and the tutorial <A HR
|
|||||||
Note that the tutorial contains information about <TT>ejabberd</TT>’s configuration
|
Note that the tutorial contains information about <TT>ejabberd</TT>’s configuration
|
||||||
which is duplicate to this section.</P><P>Also the file pg.sql in the directory src/odbc might be interesting for you.
|
which is duplicate to this section.</P><P>Also the file pg.sql in the directory src/odbc might be interesting for you.
|
||||||
This file contains the <TT>ejabberd</TT> schema for PostgreSQL. At the end of the file
|
This file contains the <TT>ejabberd</TT> schema for PostgreSQL. At the end of the file
|
||||||
you can find information to update your database schema.</P><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
you can find information to update your database schema.</P><P> <A NAME="compilepgsql"></A> </P><!--TOC subsubsection Driver Compilation-->
|
||||||
Use this option to modify the value:
|
|
||||||
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
|
||||||
</PRE><P>You can configure an interval to make a dummy SQL request
|
|
||||||
to keep alive the connections to the database.
|
|
||||||
The default value is ’undefined’, so no keepalive requests are made.
|
|
||||||
Specify in seconds: for example 28800 means 8 hours.
|
|
||||||
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
|
||||||
</PRE><P> <A NAME="compilepgsql"></A> </P><!--TOC subsubsection Driver Compilation-->
|
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compilepgsql">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compilepgsql"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compilepgsql">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compilepgsql"></A>
|
||||||
</P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
</P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
||||||
if the binary packages of <TT>ejabberd</TT> you are using include support for
|
if the binary packages of <TT>ejabberd</TT> you are using include support for
|
||||||
@ -1371,14 +1378,9 @@ directory as your <TT>ejabberd</TT> .beam files.
|
|||||||
(this is also needed for native PostgreSQL support!). This can be done, by
|
(this is also needed for native PostgreSQL support!). This can be done, by
|
||||||
using next commands:
|
using next commands:
|
||||||
<PRE CLASS="verbatim">./configure --enable-odbc && make install
|
<PRE CLASS="verbatim">./configure --enable-odbc && make install
|
||||||
</PRE></LI></OL><P> <A NAME="pgsqlauth"></A> </P><!--TOC subsubsection Authentication-->
|
</PRE></LI></OL><P> <A NAME="configurepgsql"></A> </P><!--TOC subsubsection Database Connection-->
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#pgsqlauth">Authentication</A></H4><!--SEC END --><P> <A NAME="pgsqlauth"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#configurepgsql">Database Connection</A></H4><!--SEC END --><P> <A NAME="configurepgsql"></A>
|
||||||
</P><P>The option value name may be misleading, as the <TT>auth_method</TT> name is used
|
</P><P>The actual database access is defined in the option <TT>odbc_server</TT>. Its
|
||||||
for access to a relational database through ODBC, as well as through the native
|
|
||||||
PostgreSQL interface. Anyway, the first configuration step is to define the odbc
|
|
||||||
<TT>auth_method</TT>. For example:
|
|
||||||
</P><PRE CLASS="verbatim">{host_config, "public.example.org", [{auth_method, [odbc]}]}.
|
|
||||||
</PRE><P>The actual database access is defined in the option <TT>odbc_server</TT>. Its
|
|
||||||
value is used to define if we want to use ODBC, or one of the two native
|
value is used to define if we want to use ODBC, or one of the two native
|
||||||
interface available, PostgreSQL or MySQL.</P><P>To use the native PostgreSQL interface, you can pass a tuple of the following
|
interface available, PostgreSQL or MySQL.</P><P>To use the native PostgreSQL interface, you can pass a tuple of the following
|
||||||
form as parameter:
|
form as parameter:
|
||||||
@ -1392,6 +1394,21 @@ can thus take the following form:
|
|||||||
</P><PRE CLASS="verbatim">{pgsql, "Server", Port, "Database", "Username", "Password"}
|
</P><PRE CLASS="verbatim">{pgsql, "Server", Port, "Database", "Username", "Password"}
|
||||||
</PRE><P>The <TT>Port</TT> value should be an integer, without quotes. For example:
|
</PRE><P>The <TT>Port</TT> value should be an integer, without quotes. For example:
|
||||||
</P><PRE CLASS="verbatim">{odbc_server, {pgsql, "localhost", 5432, "database", "ejabberd", "password"}}.
|
</P><PRE CLASS="verbatim">{odbc_server, {pgsql, "localhost", 5432, "database", "ejabberd", "password"}}.
|
||||||
|
</PRE><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
||||||
|
Use this option to modify the value:
|
||||||
|
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
||||||
|
</PRE><P>You can configure an interval to make a dummy SQL request
|
||||||
|
to keep alive the connections to the database.
|
||||||
|
The default value is ’undefined’, so no keepalive requests are made.
|
||||||
|
Specify in seconds: for example 28800 means 8 hours.
|
||||||
|
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
||||||
|
</PRE><P> <A NAME="pgsqlauth"></A> </P><!--TOC subsubsection Authentication-->
|
||||||
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#pgsqlauth">Authentication</A></H4><!--SEC END --><P> <A NAME="pgsqlauth"></A>
|
||||||
|
</P><P>The option value name may be misleading, as the <TT>auth_method</TT> name is used
|
||||||
|
for access to a relational database through ODBC, as well as through the native
|
||||||
|
PostgreSQL interface. Anyway, the first configuration step is to define the odbc
|
||||||
|
<TT>auth_method</TT>. For example:
|
||||||
|
</P><PRE CLASS="verbatim">{auth_method, [odbc]}.
|
||||||
</PRE><P> <A NAME="pgsqlstorage"></A> </P><!--TOC subsubsection Storage-->
|
</PRE><P> <A NAME="pgsqlstorage"></A> </P><!--TOC subsubsection Storage-->
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#pgsqlstorage">Storage</A></H4><!--SEC END --><P> <A NAME="pgsqlstorage"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#pgsqlstorage">Storage</A></H4><!--SEC END --><P> <A NAME="pgsqlstorage"></A>
|
||||||
</P><P>PostgreSQL also can be used to store information into from several <TT>ejabberd</TT>
|
</P><P>PostgreSQL also can be used to store information into from several <TT>ejabberd</TT>
|
||||||
@ -1406,15 +1423,7 @@ Keep in mind that you cannot have several variants of the same module loaded!</P
|
|||||||
use the ODBC driver, it does not describe the installation and database creation
|
use the ODBC driver, it does not describe the installation and database creation
|
||||||
of your database. Check the documentation of your database. The tutorial <A HREF="http://support.process-one.net/doc/display/MESSENGER/Using+ejabberd+with+MySQL+native+driver">Using ejabberd with MySQL native driver</A> also can help you. Note that the tutorial
|
of your database. Check the documentation of your database. The tutorial <A HREF="http://support.process-one.net/doc/display/MESSENGER/Using+ejabberd+with+MySQL+native+driver">Using ejabberd with MySQL native driver</A> also can help you. Note that the tutorial
|
||||||
contains information about <TT>ejabberd</TT>’s configuration which is duplicate to
|
contains information about <TT>ejabberd</TT>’s configuration which is duplicate to
|
||||||
this section.</P><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
this section.</P><P> <A NAME="compileodbc"></A> </P><!--TOC subsubsection Driver Compilation-->
|
||||||
Use this option to modify the value:
|
|
||||||
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
|
||||||
</PRE><P>You can configure an interval to make a dummy SQL request
|
|
||||||
to keep alive the connections to the database.
|
|
||||||
The default value is ’undefined’, so no keepalive requests are made.
|
|
||||||
Specify in seconds: for example 28800 means 8 hours.
|
|
||||||
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
|
||||||
</PRE><P> <A NAME="compileodbc"></A> </P><!--TOC subsubsection Driver Compilation-->
|
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compileodbc">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compileodbc"></A> </P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#compileodbc">Driver Compilation</A></H4><!--SEC END --><P> <A NAME="compileodbc"></A> </P><P>You can skip this step if you installed <TT>ejabberd</TT> using a binary installer or
|
||||||
if the binary packages of <TT>ejabberd</TT> you are using include support for
|
if the binary packages of <TT>ejabberd</TT> you are using include support for
|
||||||
ODBC.</P><OL CLASS="enumerate" type=1><LI CLASS="li-enumerate">
|
ODBC.</P><OL CLASS="enumerate" type=1><LI CLASS="li-enumerate">
|
||||||
@ -1424,16 +1433,26 @@ put them for example in the same directory as your <TT>ejabberd</TT> .beam files
|
|||||||
</LI><LI CLASS="li-enumerate">Then, configure, compile and install <TT>ejabberd</TT> with ODBC support
|
</LI><LI CLASS="li-enumerate">Then, configure, compile and install <TT>ejabberd</TT> with ODBC support
|
||||||
enabled. This can be done, by using next commands:
|
enabled. This can be done, by using next commands:
|
||||||
<PRE CLASS="verbatim">./configure --enable-odbc && make install
|
<PRE CLASS="verbatim">./configure --enable-odbc && make install
|
||||||
</PRE></LI></OL><P> <A NAME="odbcauth"></A> </P><!--TOC subsubsection Authentication-->
|
</PRE></LI></OL><P> <A NAME="configureodbc"></A> </P><!--TOC subsubsection Database Connection-->
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#odbcauth">Authentication</A></H4><!--SEC END --><P> <A NAME="odbcauth"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#configureodbc">Database Connection</A></H4><!--SEC END --><P> <A NAME="configureodbc"></A>
|
||||||
</P><P>The first configuration step is to define the odbc <TT>auth_method</TT>. For
|
</P><P>The actual database access is defined in the option <TT>odbc_server</TT>. Its
|
||||||
example:
|
|
||||||
</P><PRE CLASS="verbatim">{host_config, "public.example.org", [{auth_method, [odbc]}]}.
|
|
||||||
</PRE><P>The actual database access is defined in the option <TT>odbc_server</TT>. Its
|
|
||||||
value is used to defined if we want to use ODBC, or one of the two native
|
value is used to defined if we want to use ODBC, or one of the two native
|
||||||
interface available, PostgreSQL or MySQL.</P><P>To use a relational database through ODBC, you can pass the ODBC connection
|
interface available, PostgreSQL or MySQL.</P><P>To use a relational database through ODBC, you can pass the ODBC connection
|
||||||
string as <TT>odbc_server</TT> parameter. For example:
|
string as <TT>odbc_server</TT> parameter. For example:
|
||||||
</P><PRE CLASS="verbatim">{odbc_server, "DSN=database;UID=ejabberd;PWD=password"}.
|
</P><PRE CLASS="verbatim">{odbc_server, "DSN=database;UID=ejabberd;PWD=password"}.
|
||||||
|
</PRE><P>By default <TT>ejabberd</TT> opens 10 connections to the database for each virtual host.
|
||||||
|
Use this option to modify the value:
|
||||||
|
</P><PRE CLASS="verbatim">{odbc_pool_size, 10}.
|
||||||
|
</PRE><P>You can configure an interval to make a dummy SQL request
|
||||||
|
to keep alive the connections to the database.
|
||||||
|
The default value is ’undefined’, so no keepalive requests are made.
|
||||||
|
Specify in seconds: for example 28800 means 8 hours.
|
||||||
|
</P><PRE CLASS="verbatim">{odbc_keepalive_interval, undefined}.
|
||||||
|
</PRE><P> <A NAME="odbcauth"></A> </P><!--TOC subsubsection Authentication-->
|
||||||
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#odbcauth">Authentication</A></H4><!--SEC END --><P> <A NAME="odbcauth"></A>
|
||||||
|
</P><P>The first configuration step is to define the odbc <TT>auth_method</TT>. For
|
||||||
|
example:
|
||||||
|
</P><PRE CLASS="verbatim">{auth_method, [odbc]}.
|
||||||
</PRE><P> <A NAME="odbcstorage"></A> </P><!--TOC subsubsection Storage-->
|
</PRE><P> <A NAME="odbcstorage"></A> </P><!--TOC subsubsection Storage-->
|
||||||
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#odbcstorage">Storage</A></H4><!--SEC END --><P> <A NAME="odbcstorage"></A>
|
<H4 CLASS="subsubsection"><!--SEC ANCHOR --><A HREF="#odbcstorage">Storage</A></H4><!--SEC END --><P> <A NAME="odbcstorage"></A>
|
||||||
</P><P>An ODBC compatible database also can be used to store information into from
|
</P><P>An ODBC compatible database also can be used to store information into from
|
||||||
|
205
doc/guide.tex
205
doc/guide.tex
@ -1590,6 +1590,21 @@ The following LDAP servers are tested with \ejabberd{}:
|
|||||||
success with a not-listed server so that we can list it here.
|
success with a not-listed server so that we can list it here.
|
||||||
\end{itemize}
|
\end{itemize}
|
||||||
|
|
||||||
|
Important note about virtual hosting:
|
||||||
|
if you define several domains in ejabberd.cfg (see section \ref{hostnames}),
|
||||||
|
you probably want that each virtual host uses a different configuration of database, authentication and storage,
|
||||||
|
so that usernames do not conflict and mix between different virtual hosts.
|
||||||
|
For that purpose, the options described in the next sections
|
||||||
|
must be set inside a \term{host\_cofig} for each vhost (see section \ref{virtualhost}).
|
||||||
|
For example:
|
||||||
|
\begin{verbatim}
|
||||||
|
{host_config, "public.example.org", [
|
||||||
|
{odbc_server, {pgsql, "localhost", "database-public-example-org", "ejabberd", "password"}},
|
||||||
|
{auth_method, [odbc]}
|
||||||
|
]}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
\makesubsection{mysql}{MySQL}
|
\makesubsection{mysql}{MySQL}
|
||||||
\ind{MySQL}\ind{MySQL!schema}
|
\ind{MySQL}\ind{MySQL!schema}
|
||||||
|
|
||||||
@ -1603,26 +1618,6 @@ Moreover, the file mysql.sql in the directory src/odbc might be interesting for
|
|||||||
you. This file contains the \ejabberd{} schema for MySQL. At the end of the file
|
you. This file contains the \ejabberd{} schema for MySQL. At the end of the file
|
||||||
you can find information to update your database schema.
|
you can find information to update your database schema.
|
||||||
|
|
||||||
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
|
||||||
Use this option to modify the value:
|
|
||||||
\begin{verbatim}
|
|
||||||
{odbc_pool_size, 10}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
You can configure an interval to make a dummy SQL request
|
|
||||||
to keep alive the connections to the database.
|
|
||||||
The default value is 'undefined', so no keepalive requests are made.
|
|
||||||
Specify in seconds: for example 28800 means 8 hours.
|
|
||||||
\begin{verbatim}
|
|
||||||
{odbc_keepalive_interval, undefined}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
If the connection to the database fails, \ejabberd{} waits 30 seconds before retrying.
|
|
||||||
You can modify this interval with this option:
|
|
||||||
\begin{verbatim}
|
|
||||||
{odbc_start_interval, 30}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
|
|
||||||
\makesubsubsection{compilemysql}{Driver Compilation}
|
\makesubsubsection{compilemysql}{Driver Compilation}
|
||||||
\ind{MySQL!Driver Compilation}
|
\ind{MySQL!Driver Compilation}
|
||||||
@ -1642,16 +1637,9 @@ if the binary packages of \ejabberd{} you are using include support for MySQL.
|
|||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
\end{enumerate}
|
\end{enumerate}
|
||||||
|
|
||||||
\makesubsubsection{mysqlauth}{Authentication}
|
|
||||||
\ind{MySQL!authentication}
|
|
||||||
|
|
||||||
The option value name may be misleading, as the \term{auth\_method} name is used
|
\makesubsubsection{configuremysql}{Database Connection}
|
||||||
for access to a relational database through ODBC, as well as through the native
|
\ind{MySQL!Database Connection}
|
||||||
MySQL interface. Anyway, the first configuration step is to define the odbc
|
|
||||||
\term{auth\_method}. For example:
|
|
||||||
\begin{verbatim}
|
|
||||||
{host_config, "public.example.org", [{auth_method, [odbc]}]}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
The actual database access is defined in the option \term{odbc\_server}. Its
|
The actual database access is defined in the option \term{odbc\_server}. Its
|
||||||
value is used to define if we want to use ODBC, or one of the two native
|
value is used to define if we want to use ODBC, or one of the two native
|
||||||
@ -1681,6 +1669,38 @@ The \term{Port} value should be an integer, without quotes. For example:
|
|||||||
{odbc_server, {mysql, "localhost", Port, "test", "root", "password"}}.
|
{odbc_server, {mysql, "localhost", Port, "test", "root", "password"}}.
|
||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
|
|
||||||
|
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
||||||
|
Use this option to modify the value:
|
||||||
|
\begin{verbatim}
|
||||||
|
{odbc_pool_size, 10}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
You can configure an interval to make a dummy SQL request
|
||||||
|
to keep alive the connections to the database.
|
||||||
|
The default value is 'undefined', so no keepalive requests are made.
|
||||||
|
Specify in seconds: for example 28800 means 8 hours.
|
||||||
|
\begin{verbatim}
|
||||||
|
{odbc_keepalive_interval, undefined}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
If the connection to the database fails, \ejabberd{} waits 30 seconds before retrying.
|
||||||
|
You can modify this interval with this option:
|
||||||
|
\begin{verbatim}
|
||||||
|
{odbc_start_interval, 30}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
|
\makesubsubsection{mysqlauth}{Authentication}
|
||||||
|
\ind{MySQL!authentication}
|
||||||
|
|
||||||
|
The option value name may be misleading, as the \term{auth\_method} name is used
|
||||||
|
for access to a relational database through ODBC, as well as through the native
|
||||||
|
MySQL interface. Anyway, the first configuration step is to define the odbc
|
||||||
|
\term{auth\_method}. For example:
|
||||||
|
\begin{verbatim}
|
||||||
|
{auth_method, [odbc]}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
\makesubsubsection{mysqlstorage}{Storage}
|
\makesubsubsection{mysqlstorage}{Storage}
|
||||||
\ind{MySQL!storage}
|
\ind{MySQL!storage}
|
||||||
@ -1707,6 +1727,24 @@ Moreover, the file mssql.sql in the directory src/odbc might be interesting for
|
|||||||
you. This file contains the \ejabberd{} schema for Microsoft SQL Server. At the end
|
you. This file contains the \ejabberd{} schema for Microsoft SQL Server. At the end
|
||||||
of the file you can find information to update your database schema.
|
of the file you can find information to update your database schema.
|
||||||
|
|
||||||
|
|
||||||
|
\makesubsubsection{compilemssql}{Driver Compilation}
|
||||||
|
\ind{Microsoft SQL Server!Driver Compilation}
|
||||||
|
|
||||||
|
You can skip this step if you installed \ejabberd{} using a binary installer or
|
||||||
|
if the binary packages of \ejabberd{} you are using include support for ODBC.
|
||||||
|
|
||||||
|
If you want to use Microsoft SQL Server with ODBC, you need to configure,
|
||||||
|
compile and install \ejabberd{} with support for ODBC and Microsoft SQL Server
|
||||||
|
enabled. This can be done, by using next commands:
|
||||||
|
\begin{verbatim}
|
||||||
|
./configure --enable-odbc --enable-mssql && make install
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
|
\makesubsubsection{configuremssql}{Database Connection}
|
||||||
|
\ind{Microsoft SQL Server!Database Connection}
|
||||||
|
|
||||||
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
||||||
Use this option to modify the value:
|
Use this option to modify the value:
|
||||||
\begin{verbatim}
|
\begin{verbatim}
|
||||||
@ -1721,18 +1759,6 @@ Specify in seconds: for example 28800 means 8 hours.
|
|||||||
{odbc_keepalive_interval, undefined}.
|
{odbc_keepalive_interval, undefined}.
|
||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
|
|
||||||
\makesubsubsection{compilemssql}{Driver Compilation}
|
|
||||||
\ind{Microsoft SQL Server!Driver Compilation}
|
|
||||||
|
|
||||||
You can skip this step if you installed \ejabberd{} using a binary installer or
|
|
||||||
if the binary packages of \ejabberd{} you are using include support for ODBC.
|
|
||||||
|
|
||||||
If you want to use Microsoft SQL Server with ODBC, you need to configure,
|
|
||||||
compile and install \ejabberd{} with support for ODBC and Microsoft SQL Server
|
|
||||||
enabled. This can be done, by using next commands:
|
|
||||||
\begin{verbatim}
|
|
||||||
./configure --enable-odbc --enable-mssql && make install
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
\makesubsubsection{mssqlauth}{Authentication}
|
\makesubsubsection{mssqlauth}{Authentication}
|
||||||
\ind{Microsoft SQL Server!authentication}
|
\ind{Microsoft SQL Server!authentication}
|
||||||
@ -1767,19 +1793,6 @@ Also the file pg.sql in the directory src/odbc might be interesting for you.
|
|||||||
This file contains the \ejabberd{} schema for PostgreSQL. At the end of the file
|
This file contains the \ejabberd{} schema for PostgreSQL. At the end of the file
|
||||||
you can find information to update your database schema.
|
you can find information to update your database schema.
|
||||||
|
|
||||||
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
|
||||||
Use this option to modify the value:
|
|
||||||
\begin{verbatim}
|
|
||||||
{odbc_pool_size, 10}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
You can configure an interval to make a dummy SQL request
|
|
||||||
to keep alive the connections to the database.
|
|
||||||
The default value is 'undefined', so no keepalive requests are made.
|
|
||||||
Specify in seconds: for example 28800 means 8 hours.
|
|
||||||
\begin{verbatim}
|
|
||||||
{odbc_keepalive_interval, undefined}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
\makesubsubsection{compilepgsql}{Driver Compilation}
|
\makesubsubsection{compilepgsql}{Driver Compilation}
|
||||||
\ind{PostgreSQL!Driver Compilation}
|
\ind{PostgreSQL!Driver Compilation}
|
||||||
@ -1802,16 +1815,9 @@ PostgreSQL.
|
|||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
\end{enumerate}
|
\end{enumerate}
|
||||||
|
|
||||||
\makesubsubsection{pgsqlauth}{Authentication}
|
|
||||||
\ind{PostgreSQL!authentication}
|
|
||||||
|
|
||||||
The option value name may be misleading, as the \term{auth\_method} name is used
|
\makesubsubsection{configurepgsql}{Database Connection}
|
||||||
for access to a relational database through ODBC, as well as through the native
|
\ind{PostgreSQL!Database Connection}
|
||||||
PostgreSQL interface. Anyway, the first configuration step is to define the odbc
|
|
||||||
\term{auth\_method}. For example:
|
|
||||||
\begin{verbatim}
|
|
||||||
{host_config, "public.example.org", [{auth_method, [odbc]}]}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
The actual database access is defined in the option \term{odbc\_server}. Its
|
The actual database access is defined in the option \term{odbc\_server}. Its
|
||||||
value is used to define if we want to use ODBC, or one of the two native
|
value is used to define if we want to use ODBC, or one of the two native
|
||||||
@ -1840,6 +1846,32 @@ The \term{Port} value should be an integer, without quotes. For example:
|
|||||||
\begin{verbatim}
|
\begin{verbatim}
|
||||||
{odbc_server, {pgsql, "localhost", 5432, "database", "ejabberd", "password"}}.
|
{odbc_server, {pgsql, "localhost", 5432, "database", "ejabberd", "password"}}.
|
||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
|
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
||||||
|
Use this option to modify the value:
|
||||||
|
\begin{verbatim}
|
||||||
|
{odbc_pool_size, 10}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
You can configure an interval to make a dummy SQL request
|
||||||
|
to keep alive the connections to the database.
|
||||||
|
The default value is 'undefined', so no keepalive requests are made.
|
||||||
|
Specify in seconds: for example 28800 means 8 hours.
|
||||||
|
\begin{verbatim}
|
||||||
|
{odbc_keepalive_interval, undefined}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
|
\makesubsubsection{pgsqlauth}{Authentication}
|
||||||
|
\ind{PostgreSQL!authentication}
|
||||||
|
|
||||||
|
The option value name may be misleading, as the \term{auth\_method} name is used
|
||||||
|
for access to a relational database through ODBC, as well as through the native
|
||||||
|
PostgreSQL interface. Anyway, the first configuration step is to define the odbc
|
||||||
|
\term{auth\_method}. For example:
|
||||||
|
\begin{verbatim}
|
||||||
|
{auth_method, [odbc]}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
\makesubsubsection{pgsqlstorage}{Storage}
|
\makesubsubsection{pgsqlstorage}{Storage}
|
||||||
\ind{PostgreSQL!storage}
|
\ind{PostgreSQL!storage}
|
||||||
@ -1861,19 +1893,6 @@ of your database. Check the documentation of your database. The tutorial \footah
|
|||||||
contains information about \ejabberd{}'s configuration which is duplicate to
|
contains information about \ejabberd{}'s configuration which is duplicate to
|
||||||
this section.
|
this section.
|
||||||
|
|
||||||
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
|
||||||
Use this option to modify the value:
|
|
||||||
\begin{verbatim}
|
|
||||||
{odbc_pool_size, 10}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
You can configure an interval to make a dummy SQL request
|
|
||||||
to keep alive the connections to the database.
|
|
||||||
The default value is 'undefined', so no keepalive requests are made.
|
|
||||||
Specify in seconds: for example 28800 means 8 hours.
|
|
||||||
\begin{verbatim}
|
|
||||||
{odbc_keepalive_interval, undefined}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
\makesubsubsection{compileodbc}{Driver Compilation}
|
\makesubsubsection{compileodbc}{Driver Compilation}
|
||||||
|
|
||||||
@ -1892,14 +1911,9 @@ ODBC.
|
|||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
\end{enumerate}
|
\end{enumerate}
|
||||||
|
|
||||||
\makesubsubsection{odbcauth}{Authentication}
|
|
||||||
\ind{ODBC!authentication}
|
|
||||||
|
|
||||||
The first configuration step is to define the odbc \term{auth\_method}. For
|
\makesubsubsection{configureodbc}{Database Connection}
|
||||||
example:
|
\ind{ODBC!Database Connection}
|
||||||
\begin{verbatim}
|
|
||||||
{host_config, "public.example.org", [{auth_method, [odbc]}]}.
|
|
||||||
\end{verbatim}
|
|
||||||
|
|
||||||
The actual database access is defined in the option \term{odbc\_server}. Its
|
The actual database access is defined in the option \term{odbc\_server}. Its
|
||||||
value is used to defined if we want to use ODBC, or one of the two native
|
value is used to defined if we want to use ODBC, or one of the two native
|
||||||
@ -1911,6 +1925,31 @@ string as \term{odbc\_server} parameter. For example:
|
|||||||
{odbc_server, "DSN=database;UID=ejabberd;PWD=password"}.
|
{odbc_server, "DSN=database;UID=ejabberd;PWD=password"}.
|
||||||
\end{verbatim}
|
\end{verbatim}
|
||||||
|
|
||||||
|
By default \ejabberd{} opens 10 connections to the database for each virtual host.
|
||||||
|
Use this option to modify the value:
|
||||||
|
\begin{verbatim}
|
||||||
|
{odbc_pool_size, 10}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
You can configure an interval to make a dummy SQL request
|
||||||
|
to keep alive the connections to the database.
|
||||||
|
The default value is 'undefined', so no keepalive requests are made.
|
||||||
|
Specify in seconds: for example 28800 means 8 hours.
|
||||||
|
\begin{verbatim}
|
||||||
|
{odbc_keepalive_interval, undefined}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
|
\makesubsubsection{odbcauth}{Authentication}
|
||||||
|
\ind{ODBC!authentication}
|
||||||
|
|
||||||
|
The first configuration step is to define the odbc \term{auth\_method}. For
|
||||||
|
example:
|
||||||
|
\begin{verbatim}
|
||||||
|
{auth_method, [odbc]}.
|
||||||
|
\end{verbatim}
|
||||||
|
|
||||||
|
|
||||||
\makesubsubsection{odbcstorage}{Storage}
|
\makesubsubsection{odbcstorage}{Storage}
|
||||||
\ind{ODBC!storage}
|
\ind{ODBC!storage}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user