mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
3ee8f505b7
The main benefit of this is so that authors who make use of .editorconfig don't end up with whitespace changes in their PRs. Spaces vs. tabs has been left alone, although that could do with a tidy-up in SS4 after the switch to PSR-1/2. The command used was this: for match in '*.ss' '*.css' '*.scss' '*.html' '*.yml' '*.php' '*.js' '*.csv' '*.inc' '*.php5'; do find . -path ./thirdparty -not -prune -o -path ./admin/thirdparty -not -prune -o -type f -name "$match" -exec sed -E -i '' 's/[[:space:]]+$//' {} \+ find . -path ./thirdparty -not -prune -o -path ./admin/thirdparty -not -prune -o -type f -name "$match" | xargs perl -pi -e 's/ +$//' done
74 lines
2.6 KiB
PHP
74 lines
2.6 KiB
PHP
<?php
|
|
/**
|
|
* Abstract task representing scheudled tasks.
|
|
*
|
|
* Scheduled tasks are tasks that are run at a certain time or set interval. For example, notify a page owner that
|
|
* their page is about to expire. Scheduled tasks are implemented as singleton instances and a single
|
|
* instance is responsibly directly or indirectly for executing all tasks that should be run at that time.
|
|
*
|
|
* You can use the different subclasses {@link HourlyTask}, {@link DailyTask},
|
|
* {@link WeeklyTask} to determine when a task should be run,
|
|
* and use automation tools such as unix cron to trigger them.
|
|
*
|
|
* <b>Usage</b>
|
|
*
|
|
* Implement a daily task by extending DailyTask and implementing process().
|
|
*
|
|
* <code>
|
|
* class MyTask extends DailyTask {
|
|
* function process() {
|
|
* // implement your task here
|
|
* }
|
|
* }
|
|
* </code>
|
|
*
|
|
* You can also implement the index() method to overwrite which singleton classes are instantiated and processed.
|
|
* By default, all subclasses of the task are instantiated and used. For the DailyTask class, this means
|
|
* that an instance of each subclass of DailyTask will be created.
|
|
*
|
|
* You can test your task from the command line by running the following command
|
|
* (replace <MyTask> is the classname of your task):
|
|
*
|
|
* <code>framework/cli-script.php /<MyTask></code>
|
|
*
|
|
* To perform all Daily tasks, run from the command line:
|
|
*
|
|
* <code>cli-script.php /DailyTask</code>
|
|
*
|
|
* <b>Example Cron Definition</b>
|
|
*
|
|
* <code>
|
|
* # Quarter-hourly task (every hour at 25 minutes past) (remove space between first * and /15)
|
|
* * /15 * * * * www-data /webroot/framework/cli-script.php /QuarterHourlyTask > /var/log/quarterhourlytask.log
|
|
*
|
|
* # HourlyTask (every hour at 25 minutes past)
|
|
* 25 * * * * www-data /webroot/framework/cli-script.php /HourlyTask > /var/log/hourlytask.log
|
|
*
|
|
* # DailyTask (every day at 6:25am)
|
|
* 25 6 * * * www-data /webroot/framework/cli-script.php /DailyTask > /var/log/dailytask.log
|
|
*
|
|
* # WeelkyTask (every Monday at 6:25am)
|
|
* 25 6 1 * * www-data /webroot/framework/cli-script.php /WeeklyTask > /var/log/weeklytask.log
|
|
* </code>
|
|
*
|
|
* @deprecated 3.1
|
|
*
|
|
* @todo Improve documentation
|
|
* @package framework
|
|
* @subpackage cron
|
|
*/
|
|
abstract class ScheduledTask extends CliController {
|
|
// this class exists as a logical extension
|
|
|
|
public function init() {
|
|
Deprecation::notice(
|
|
'3.1',
|
|
'ScheduledTask, QuarterHourlyTask, HourlyTask, DailyTask, MonthlyTask, WeeklyTask and ' .
|
|
'YearlyTask are deprecated, please extend from BuildTask or CliController, ' .
|
|
'and invoke them in self-defined frequencies through Unix cronjobs etc.'
|
|
);
|
|
|
|
parent::init();
|
|
}
|
|
}
|