ejabberd-contrib/mod_cron
Badlop 44f709ba38 Fix mod_cron to work with ejabberd git master 2015-01-28 13:55:56 +01:00
..
ebin Add ebin/ dirs with .keepme file to ensure Git tracks them 2013-04-15 12:18:19 +02:00
src Fix mod_cron to work with ejabberd git master 2015-01-28 13:55:56 +01:00
COPYING Initial import from ejabberd-modules SVN 2013-04-15 12:03:14 +02:00
ChangeLog Initial import from ejabberd-modules SVN 2013-04-15 12:03:14 +02:00
Emakefile Initial import from ejabberd-modules SVN 2013-04-15 12:03:14 +02:00
README.txt Fix mod_cron to work with ejabberd git master 2015-01-28 13:55:56 +01:00
build.bat Update erl(1) command line in build.bat files 2014-05-28 22:16:55 +02:00
build.sh Initial import from ejabberd-modules SVN 2013-04-15 12:03:14 +02:00

README.txt

	mod_cron - Execute scheduled commands

	http://www.ejabberd.im/mod_cron
	Author: Badlop
	Requirements: ejabberd git master


This module allows advanced ejabberd administrators to schedule commands for
periodic and automatic execution. This module is a similar concept than the
*nix's cron program. Obviously, the admin must know in advance which module,
function and arguments to use, so this module is not intended for starting
administrators.

Each time a scheduled task finish its execution, a message is printed in the
ejabberd log file.


	BASIC CONFIGURATION
	===================

Add the module to the modules configuration.
As it requires complex configuration, add this to the ejabberd.yml file:
  include_config_file: "/etc/ejabberd/additional.cfg"
And this to additional.cfg:
{modules, [
  {mod_cron, []},
]}.


	TASK SYNTAX
	===========

Each task is described using a tuple with this syntax:
  {Time, Time_units, Module, Function, Arguments}
Where:
  Time is an integer.
  Time_units indicates the time unit you use. It can be: seconds, minutes, hours, days.
  Module and Function are the exact call you want to schedule.
  Arguments is a list of arguments. It can be emtpy.

For example, let's define some dummy tasks:
 * Every 3 hours, print on the log file some info about mnesia:
    {3, hours, mnesia, info, []}

 * Every day, try to register certain account:
    {1, days, ejabberd_auth, try_register, ["tommy", "jabber.example.org", "MyP455WorD"]}


	TASKS ON EJABBERD.CFG
	=====================

Now that you know how to define new tasks, you can add the ones you want on ejabberd.cfg
For example:
{modules, [
  ...
  {mod_cron, [{tasks, [
    {3, hours, mnesia, info, []},
    {1, days, ejabberd_auth, try_register, ["aaa", "atenea", "aaaaaa"]}
  ]}]},
  ...
]}.


	EJABBERD COMMANDS
	=================

This module provides two new commands that can be executed using ejabberdctl:
 * cron-list: list scheduled tasks
 * cron-del taskid: delete this task from the schedule


	WEB ADMIN
	=========

This module provides a page in the Host section of the Web Admin.
Currently that page only allows to view the tasks scheduled for that host.