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: - You need to have ejabberd installed. - If you have not already done it, run `ejabberdctl modules_update_specs` to retrieve the list of available modules. - Run `ejabberdctl module_install ` 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`. - 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 ` to remove a module from ejabberd. For developers -------------- The following organization has been set up for the development: - Development and compilation of modules is done by ejabberd. You need ejabberd installed. Use `ejabberdctl module_check ` to ensure it compiles correctly before committing your work. The sources of your module must be located in `$CONTRIB_MODULES_PATH/sources/`. - Compilation can by done manually (if you know what you are doing) so you don't need ejabberd running: ``` 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 ``` - The module directory structure is usually the following: * `README.txt`: Module description. * `COPYING`: License for the module. * `doc/`: Documentation directory. * `src/`: Erlang source directory. * `lib/`: Elixir source directory. * `priv/msgs/`: Directory with translation files (pot, po and msg). * `conf/.yml`: Configuration for your module. * `.spec`: Yaml description file for your module. - Module developers should note in the `README.txt` file whether the module has requirements or known incompatibilities with other modules. - 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.