2014-05-27 21:22:42 +02:00
|
|
|
ejabberd-contrib
|
|
|
|
================
|
|
|
|
|
|
|
|
This is a collaborative development area for ejabberd module developers
|
|
|
|
and users.
|
|
|
|
|
|
|
|
|
|
|
|
For users
|
|
|
|
---------
|
|
|
|
|
|
|
|
To use an ejabberd module coming from this repository:
|
|
|
|
|
2015-04-22 23:48:31 +02:00
|
|
|
- You need to have ejabberd installed.
|
2015-12-23 13:32:09 +01:00
|
|
|
|
|
|
|
- If you have not already done it, run `ejabberdctl modules_update_specs`
|
|
|
|
to retrieve the list of available modules.
|
2014-05-27 21:22:42 +02:00
|
|
|
|
2015-04-22 23:48:31 +02:00
|
|
|
- Run `ejabberdctl module_install <module>` to get the source code and to
|
|
|
|
compile and install the `beam` file into ejabberd's module search path.
|
|
|
|
This path is either `~/.ejabberd-modules` or defined by the
|
|
|
|
`CONTRIB_MODULES_PATH` setting in `ejabberdctl.cfg`.
|
2014-05-27 21:22:42 +02:00
|
|
|
|
2015-04-22 23:48:31 +02:00
|
|
|
- Edit the configuration file provided in the `conf` directory of the
|
|
|
|
installed module and update it to your needs. Then apply the changes to
|
|
|
|
your main ejabberd configuration. In a future release, ejabberd will
|
|
|
|
automatically add this file to its runtime configuration without
|
|
|
|
changes.
|
|
|
|
|
|
|
|
- Run `ejabberdctl module_uninstall <module>` to remove a module from
|
|
|
|
ejabberd.
|
2014-05-27 21:22:42 +02:00
|
|
|
|
|
|
|
|
|
|
|
For developers
|
|
|
|
--------------
|
|
|
|
|
|
|
|
The following organization has been set up for the development:
|
|
|
|
|
2015-03-11 14:19:35 +01:00
|
|
|
- Development and compilation of modules is done by ejabberd. You need
|
2015-04-22 23:48:31 +02:00
|
|
|
ejabberd installed. Use `ejabberdctl module_check <module>` to ensure it
|
|
|
|
compiles correctly before committing your work. The sources of your
|
|
|
|
module must be located in `$CONTRIB_MODULES_PATH/sources/<module>`.
|
2014-05-27 21:22:42 +02:00
|
|
|
|
2015-04-22 23:48:31 +02:00
|
|
|
- Compilation can by done manually (if you know what you are doing) so you
|
|
|
|
don't need ejabberd running:
|
2015-04-22 12:03:20 +02:00
|
|
|
```
|
|
|
|
cd /path/of/module
|
|
|
|
mkdir ebin
|
|
|
|
/path/of/ejabberd's/erlc \
|
|
|
|
-o ebin \
|
|
|
|
-I include -I /path/of/ejabberd/lib/ejabberd-XX.YY/include \
|
|
|
|
-DLAGER -DNO_EXT_LIB \
|
|
|
|
src/*erl
|
|
|
|
```
|
|
|
|
|
2014-05-27 21:22:42 +02:00
|
|
|
- The module directory structure is usually the following:
|
|
|
|
* `README.txt`: Module description.
|
2015-03-11 14:19:35 +01:00
|
|
|
* `COPYING`: License for the module.
|
2014-05-27 21:22:42 +02:00
|
|
|
* `doc/`: Documentation directory.
|
2015-03-11 14:19:35 +01:00
|
|
|
* `src/`: Erlang source directory.
|
|
|
|
* `lib/`: Elixir source directory.
|
|
|
|
* `priv/msgs/`: Directory with translation files (pot, po and msg).
|
|
|
|
* `conf/<module>.yml`: Configuration for your module.
|
|
|
|
* `<module>.spec`: Yaml description file for your module.
|
2014-05-27 21:22:42 +02:00
|
|
|
|
|
|
|
- Module developers should note in the `README.txt` file whether the
|
2015-03-11 14:19:35 +01:00
|
|
|
module has requirements or known incompatibilities with other modules.
|
2021-03-16 16:32:36 +01:00
|
|
|
|
|
|
|
- If your module project contains several erlang modules, you should export a
|
|
|
|
function pre_uninstall/0 in the main one listing the other ones.
|
|
|
|
See mod_statsdx as an example.
|
2021-07-06 20:36:42 +02:00
|
|
|
|
|
|
|
|
|
|
|
Broken modules
|
|
|
|
--------------
|
|
|
|
|
|
|
|
This is the list of modules that are known to be broken with latest ejabberd master branch.
|
|
|
|
|
|
|
|
If you feel they are worth it, your help to fix them is welcome:
|
|
|
|
|
|
|
|
- atom_pubsub: "Provides access to all PEP nodes via an AtomPub interface."
|
|
|
|
- ircd: "This is an IRC server frontend to ejabberd."
|
|
|
|
- mod_archive: "Message Archiving (XEP-0136)."
|
|
|
|
- mod_openid: "Transform the Jabber Server in an openid provider."
|
|
|
|
- mod_profile: "User Profile (XEP-0154) in Mnesia table."
|