NameDateSize

..16-Mar-201612 KiB

.gitignore12-Oct-2015640

.travis.yml19-Oct-20151.7 KiB

asn1/28-Jan-20144 KiB

autogen.sh23-Apr-201452

config/10-Sep-20154 KiB

configure.ac09-Nov-20158.7 KiB

configure.bat28-Jan-2014303

contrib/28-Jan-20144 KiB

COPYING14-Apr-201417.7 KiB

ejabberd.init.template02-Oct-20141.3 KiB

ejabberd.service.template23-Feb-2015341

ejabberd.yml.example20-Nov-201515.5 KiB

ejabberdctl.cfg.example09-Nov-20155.6 KiB

ejabberdctl.template09-Dec-201514.5 KiB

examples/28-Jan-20144 KiB

include/16-Nov-20154 KiB

inetrc28-Jan-2014111

install-sh28-Jan-201413.3 KiB

lib/12-Oct-20154 KiB

m4/09-Apr-20154 KiB

Makefile.in09-Dec-20159.4 KiB

mix.exs09-Dec-20153.1 KiB

mix.lock09-Nov-20152 KiB

priv/28-Jan-20144 KiB

README09-Nov-20155.7 KiB

README.md09-Nov-20155.7 KiB

rebar02-Feb-2015162.1 KiB

rebar.config.script09-Dec-20157.3 KiB

rel/28-Sep-20154 KiB

sql/14-Dec-20154 KiB

src/14-Dec-201512 KiB

test/14-Dec-20154 KiB

tools/30-Nov-20154 KiB

vars.config.in09-Nov-20151.3 KiB

win32/28-Jan-20144 KiB

README

1ejabberd Community Edition [![Build Status](https://travis-ci.org/processone/ejabberd.svg?branch=master)](https://travis-ci.org/processone/ejabberd)
2=========================================
3
4ejabberd is a distributed, fault-tolerant technology that allows the creation
5of large-scale instant messaging applications. The server can reliably support
6thousands of simultaneous users on a single node and has been designed to
7provide exceptional standards of fault tolerance. As an open source
8technology, based on industry-standards, ejabberd can be used to build bespoke
9solutions very cost effectively.
10
11
12Key Features
13------------
14
15- **Cross-platform**  
16  ejabberd runs under Microsoft Windows and Unix-derived systems such as
17  Linux, FreeBSD and NetBSD.
18
19- **Distributed**  
20  You can run ejabberd on a cluster of machines and all of them will serve the
21  same XMPP domain(s). When you need more capacity you can simply add a new
22  cheap node to your cluster. Accordingly, you do not need to buy an expensive
23  high-end machine to support tens of thousands concurrent users.
24
25- **Fault-tolerant**  
26  You can deploy an ejabberd cluster so that all the information required for
27  a properly working service will be replicated permanently on all nodes. This
28  means that if one of the nodes crashes, the others will continue working
29  without disruption. In addition, nodes also can be added or replaced ‘on
30  the fly’.
31
32- **Administrator-friendly**  
33  ejabberd is built on top of the Open Source Erlang. As a result you do not
34  need to install an external database, an external web server, amongst others
35  because everything is already included, and ready to run out of the box.
36  Other administrator benefits include:
37  - Comprehensive documentation.
38  - Straightforward installers for Linux and Mac OS X.
39  - Web administration.
40  - Shared roster groups.
41  - Command line administration tool.
42  - Can integrate with existing authentication mechanisms.
43  - Capability to send announce messages.
44
45- **Internationalized**  
46  ejabberd leads in internationalization. Hence it is very well suited in a
47  globalized world. Related features are:
48  - Translated to 25 languages.
49  - Support for IDNA.
50
51- **Open Standards**  
52  ejabberd is the first Open Source Jabber server claiming to fully comply to
53  the XMPP standard.
54  - Fully XMPP-compliant.
55  - XML-based protocol.
56  - Many protocols supported.
57
58
59Additional Features
60-------------------
61
62Moreover, ejabberd comes with a wide range of other state-of-the-art features:
63
64- **Modularity**
65  - Load only the modules you want.
66  - Extend ejabberd with your own custom modules.
67
68- **Security**
69  - SASL and STARTTLS for c2s and s2s connections.
70  - STARTTLS and Dialback s2s connections.
71  - Web Admin accessible via HTTPS secure access.
72
73- **Databases**
74  - Internal database for fast deployment (Mnesia).
75  - Native MySQL support.
76  - Native PostgreSQL support.
77  - ODBC data storage support.
78  - Microsoft SQL Server support.
79
80- **Authentication**
81  - Internal authentication.
82  - PAM, LDAP and ODBC.
83  - External authentication script.
84
85- **Others**
86  - Support for virtual hosting.
87  - Compressing XML streams with Stream Compression (XEP-0138).
88  - Statistics via Statistics Gathering (XEP-0039).
89  - IPv6 support both for c2s and s2s connections.
90  - Multi-User Chat module with support for clustering and HTML logging.
91  - Users Directory based on users vCards.
92  - Publish-Subscribe component with support for Personal Eventing.
93  - Support for web clients: HTTP Polling and HTTP Binding (BOSH).
94  - IRC transport.
95  - Component support: interface with networks such as AIM, ICQ and MSN.
96
97
98Quickstart guide
99----------------
100
101### 0. Requirements
102
103To compile ejabberd you need:
104
105 - GNU Make.
106 - GCC.
107 - Libexpat 1.95 or higher.
108 - Libyaml 0.1.4 or higher.
109 - Erlang/OTP 17.1 or higher.
110 - OpenSSL 1.0.0 or higher, for STARTTLS, SASL and SSL encryption.
111 - Zlib 1.2.3 or higher, for Stream Compression support (XEP-0138). Optional.
112 - PAM library. Optional. For Pluggable Authentication Modules (PAM).
113 - GNU Iconv 1.8 or higher, for the IRC Transport (mod_irc). Optional. Not
114   needed on systems with GNU Libc.
115 - ImageMagick's Convert program. Optional. For CAPTCHA challenges.
116
117
118### 1. Compile and install on *nix systems
119
120To compile ejabberd, execute the following commands.  The first one is only
121necessary if your source tree didn't come with a `configure` script.
122
123    ./autogen.sh
124    ./configure
125    make
126
127To install ejabberd, run this command with system administrator rights (root
128user):
129
130    sudo make install
131
132These commands will:
133
134- Install the configuration files in `/etc/ejabberd/`
135- Install ejabberd binary, header and runtime files in `/lib/ejabberd/`
136- Install the administration script: `/sbin/ejabberdctl`
137- Install ejabberd documentation in `/share/doc/ejabberd/`
138- Create a spool directory: `/var/lib/ejabberd/`
139- Create a directory for log files: `/var/log/ejabberd/`
140
141
142### 2. Start ejabberd
143
144You can use the `ejabberdctl` command line administration script to
145start and stop ejabberd. For example:
146
147    ejabberdctl start
148
149
150For detailed information please refer to the ejabberd Installation and
151Operation Guide available online and in the `doc` directory of the source
152tarball.
153
154
155Development
156-----------
157
158In order to assist in the development of ejabberd, and particularly the
159execution of the test suite, a Vagrant environment is available at
160https://github.com/processone/ejabberd-vagrant-dev.
161
162To start ejabberd in development mode from the repository directory, you can
163type a command like:
164
165    EJABBERD_CONFIG_PATH=ejabberd.yml erl -pa ebin -pa deps/*/ebin -pa test -s ejabberd
166
167Links
168-----
169
170- Documentation: http://docs.ejabberd.im
171- Community site: https://www.ejabberd.im
172- ejabberd commercial offering and support: https://www.process-one.net/en/ejabberd
173

README.md

1ejabberd Community Edition [![Build Status](https://travis-ci.org/processone/ejabberd.svg?branch=master)](https://travis-ci.org/processone/ejabberd)
2=========================================
3
4ejabberd is a distributed, fault-tolerant technology that allows the creation
5of large-scale instant messaging applications. The server can reliably support
6thousands of simultaneous users on a single node and has been designed to
7provide exceptional standards of fault tolerance. As an open source
8technology, based on industry-standards, ejabberd can be used to build bespoke
9solutions very cost effectively.
10
11
12Key Features
13------------
14
15- **Cross-platform**  
16  ejabberd runs under Microsoft Windows and Unix-derived systems such as
17  Linux, FreeBSD and NetBSD.
18
19- **Distributed**  
20  You can run ejabberd on a cluster of machines and all of them will serve the
21  same XMPP domain(s). When you need more capacity you can simply add a new
22  cheap node to your cluster. Accordingly, you do not need to buy an expensive
23  high-end machine to support tens of thousands concurrent users.
24
25- **Fault-tolerant**  
26  You can deploy an ejabberd cluster so that all the information required for
27  a properly working service will be replicated permanently on all nodes. This
28  means that if one of the nodes crashes, the others will continue working
29  without disruption. In addition, nodes also can be added or replaced ‘on
30  the fly’.
31
32- **Administrator-friendly**  
33  ejabberd is built on top of the Open Source Erlang. As a result you do not
34  need to install an external database, an external web server, amongst others
35  because everything is already included, and ready to run out of the box.
36  Other administrator benefits include:
37  - Comprehensive documentation.
38  - Straightforward installers for Linux and Mac OS X.
39  - Web administration.
40  - Shared roster groups.
41  - Command line administration tool.
42  - Can integrate with existing authentication mechanisms.
43  - Capability to send announce messages.
44
45- **Internationalized**  
46  ejabberd leads in internationalization. Hence it is very well suited in a
47  globalized world. Related features are:
48  - Translated to 25 languages.
49  - Support for IDNA.
50
51- **Open Standards**  
52  ejabberd is the first Open Source Jabber server claiming to fully comply to
53  the XMPP standard.
54  - Fully XMPP-compliant.
55  - XML-based protocol.
56  - Many protocols supported.
57
58
59Additional Features
60-------------------
61
62Moreover, ejabberd comes with a wide range of other state-of-the-art features:
63
64- **Modularity**
65  - Load only the modules you want.
66  - Extend ejabberd with your own custom modules.
67
68- **Security**
69  - SASL and STARTTLS for c2s and s2s connections.
70  - STARTTLS and Dialback s2s connections.
71  - Web Admin accessible via HTTPS secure access.
72
73- **Databases**
74  - Internal database for fast deployment (Mnesia).
75  - Native MySQL support.
76  - Native PostgreSQL support.
77  - ODBC data storage support.
78  - Microsoft SQL Server support.
79
80- **Authentication**
81  - Internal authentication.
82  - PAM, LDAP and ODBC.
83  - External authentication script.
84
85- **Others**
86  - Support for virtual hosting.
87  - Compressing XML streams with Stream Compression (XEP-0138).
88  - Statistics via Statistics Gathering (XEP-0039).
89  - IPv6 support both for c2s and s2s connections.
90  - Multi-User Chat module with support for clustering and HTML logging.
91  - Users Directory based on users vCards.
92  - Publish-Subscribe component with support for Personal Eventing.
93  - Support for web clients: HTTP Polling and HTTP Binding (BOSH).
94  - IRC transport.
95  - Component support: interface with networks such as AIM, ICQ and MSN.
96
97
98Quickstart guide
99----------------
100
101### 0. Requirements
102
103To compile ejabberd you need:
104
105 - GNU Make.
106 - GCC.
107 - Libexpat 1.95 or higher.
108 - Libyaml 0.1.4 or higher.
109 - Erlang/OTP 17.1 or higher.
110 - OpenSSL 1.0.0 or higher, for STARTTLS, SASL and SSL encryption.
111 - Zlib 1.2.3 or higher, for Stream Compression support (XEP-0138). Optional.
112 - PAM library. Optional. For Pluggable Authentication Modules (PAM).
113 - GNU Iconv 1.8 or higher, for the IRC Transport (mod_irc). Optional. Not
114   needed on systems with GNU Libc.
115 - ImageMagick's Convert program. Optional. For CAPTCHA challenges.
116
117
118### 1. Compile and install on *nix systems
119
120To compile ejabberd, execute the following commands.  The first one is only
121necessary if your source tree didn't come with a `configure` script.
122
123    ./autogen.sh
124    ./configure
125    make
126
127To install ejabberd, run this command with system administrator rights (root
128user):
129
130    sudo make install
131
132These commands will:
133
134- Install the configuration files in `/etc/ejabberd/`
135- Install ejabberd binary, header and runtime files in `/lib/ejabberd/`
136- Install the administration script: `/sbin/ejabberdctl`
137- Install ejabberd documentation in `/share/doc/ejabberd/`
138- Create a spool directory: `/var/lib/ejabberd/`
139- Create a directory for log files: `/var/log/ejabberd/`
140
141
142### 2. Start ejabberd
143
144You can use the `ejabberdctl` command line administration script to
145start and stop ejabberd. For example:
146
147    ejabberdctl start
148
149
150For detailed information please refer to the ejabberd Installation and
151Operation Guide available online and in the `doc` directory of the source
152tarball.
153
154
155Development
156-----------
157
158In order to assist in the development of ejabberd, and particularly the
159execution of the test suite, a Vagrant environment is available at
160https://github.com/processone/ejabberd-vagrant-dev.
161
162To start ejabberd in development mode from the repository directory, you can
163type a command like:
164
165    EJABBERD_CONFIG_PATH=ejabberd.yml erl -pa ebin -pa deps/*/ebin -pa test -s ejabberd
166
167Links
168-----
169
170- Documentation: http://docs.ejabberd.im
171- Community site: https://www.ejabberd.im
172- ejabberd commercial offering and support: https://www.process-one.net/en/ejabberd
173