2008-11-26 14:50:40 -08:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* AgileBill - Open Billing Software
|
|
|
|
*
|
|
|
|
* This body of work is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the Open AgileBill License
|
|
|
|
* License as published at http://www.agileco.com/agilebill/license1-4.txt
|
2009-08-03 14:10:16 +10:00
|
|
|
*
|
|
|
|
* Originally authored by Tony Landis, AgileBill LLC
|
|
|
|
*
|
|
|
|
* Recent modifications by Deon George
|
|
|
|
*
|
|
|
|
* @author Deon George <deonATleenooksDOTnet>
|
|
|
|
* @copyright 2009 Deon George
|
|
|
|
* @link http://osb.leenooks.net
|
2008-11-26 14:50:40 -08:00
|
|
|
*
|
|
|
|
* @link http://www.agileco.com/
|
|
|
|
* @copyright 2004-2008 Agileco, LLC.
|
|
|
|
* @license http://www.agileco.com/agilebill/license1-4.txt
|
2009-08-03 14:10:16 +10:00
|
|
|
* @author Tony Landis <tony@agileco.com>
|
2008-11-26 14:50:40 -08:00
|
|
|
* @package AgileBill
|
2009-08-03 14:10:16 +10:00
|
|
|
* @subpackage Module:Task
|
2008-11-26 14:50:40 -08:00
|
|
|
*/
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
/**
|
|
|
|
* The main AgileBill Task Class
|
|
|
|
*
|
|
|
|
* @package AgileBill
|
|
|
|
* @subpackage Module:Task
|
|
|
|
*/
|
|
|
|
class task extends OSB_module {
|
|
|
|
/**
|
|
|
|
* Run all scheduled tasks
|
|
|
|
*/
|
|
|
|
public function run_all() {
|
|
|
|
# Ensure that tasks complete and dont hang on running=1
|
|
|
|
set_time_limit(2*60*60);
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
# Loop through the tasks:
|
|
|
|
global $VAR;
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
$db = &DB();
|
|
|
|
$result = $db->Execute(sqlSelect($db,'task','*','(running=0 OR running IS NULL) AND status=1'));
|
|
|
|
if ($result && $result->RecordCount() > 0) {
|
|
|
|
include_once(PATH_INCLUDES.'cron/cron.inc.php');
|
2008-11-26 14:50:40 -08:00
|
|
|
$cron = new cron;
|
2009-08-03 14:10:16 +10:00
|
|
|
|
|
|
|
while (! $result->EOF) {
|
2008-11-26 14:50:40 -08:00
|
|
|
$_r = false;
|
|
|
|
$_s = (int) $result->fields['date_start'];
|
|
|
|
$_e = (int) $result->fields['date_expire'];
|
2009-08-03 14:10:16 +10:00
|
|
|
$_l = (int) $result->fields['date_run'];
|
|
|
|
$_c = sprintf('%s %s %s %s %s',
|
|
|
|
$result->fields['int_min'],
|
|
|
|
$result->fields['int_hour'],
|
|
|
|
$result->fields['int_month_day'],
|
|
|
|
$result->fields['int_month'],
|
|
|
|
$result->fields['int_week_day']);
|
2008-11-26 14:50:40 -08:00
|
|
|
$_n = (int) time();
|
2009-08-03 14:10:16 +10:00
|
|
|
if (! $_l > 0)
|
|
|
|
$_l = $_n-86400*365;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
# Verify it has not expired:
|
2009-08-03 14:10:16 +10:00
|
|
|
if ($_s <= $_n || $_s == '' || $_s == '0') {
|
2008-11-26 14:50:40 -08:00
|
|
|
# Verify it is past the start date:
|
2009-08-03 14:10:16 +10:00
|
|
|
if ($_e >= $_n || $_e == '' || $_e == '0') {
|
2008-11-26 14:50:40 -08:00
|
|
|
# Verify that it is time to run:
|
2009-08-03 14:10:16 +10:00
|
|
|
if ($cron->due($_l,$_n,$_c)) {
|
2008-11-26 14:50:40 -08:00
|
|
|
# Run the task:
|
|
|
|
$this->id = $result->fields['id'];
|
2009-08-03 14:10:16 +10:00
|
|
|
$this->run($VAR);
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$result->MoveNext();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
/**
|
|
|
|
* Run a task
|
|
|
|
*
|
|
|
|
* @uses task_log
|
|
|
|
*/
|
|
|
|
public function run($VAR) {
|
|
|
|
global $VAR,$C_auth,$_ENV,$_SERVER,$_COOKIE,$C_list;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
$noauth = false;
|
|
|
|
$debug_out = false;
|
2009-08-03 14:10:16 +10:00
|
|
|
if (isset($_ENV['S']) ||
|
|
|
|
(isset($_ENV['SESSIONNAME']) && $_ENV['SESSIONNAME'] == 'Console') ||
|
|
|
|
(isset($_SERVER['SESSIONNAME']) && $_SERVER['SESSIONNAME'] == 'Console') ||
|
|
|
|
(isset($_SERVER['CLIENTNAME']) && $_SERVER['CLIENTNAME'] == 'Console') ||
|
|
|
|
empty($_COOKIE)) {
|
2008-11-26 14:50:40 -08:00
|
|
|
$debug_out = true;
|
|
|
|
$noauth = true;
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2008-11-26 14:50:40 -08:00
|
|
|
} elseif($C_auth->auth_method_by_name('task','run')) {
|
|
|
|
$noauth = true;
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2008-11-26 14:50:40 -08:00
|
|
|
} else {
|
|
|
|
$noauth = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($this->id))
|
2009-08-03 14:10:16 +10:00
|
|
|
$id = $this->id;
|
|
|
|
elseif (isset($VAR['id']))
|
|
|
|
$id = $VAR['id'];
|
|
|
|
else
|
|
|
|
return;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
# Get task details
|
2009-08-03 14:10:16 +10:00
|
|
|
$db = &DB();
|
|
|
|
$result = $db->Execute(sqlSelect($db,'task','*',array('id'=>$id)));
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if (! $result || $result->RecordCount() == 0)
|
|
|
|
return;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
$type = $result->fields['type'];
|
|
|
|
$cmd = $result->fields['command'];
|
|
|
|
$log = $result->fields['log'];
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Record task running
|
|
|
|
$db->Execute(sqlUpdate($db,'task',array('running'=>1),array('id'=>$id)));
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
# Run task
|
2009-08-03 14:10:16 +10:00
|
|
|
switch ($type) {
|
|
|
|
case 0:
|
|
|
|
# Internal function:
|
|
|
|
global $C_method;
|
|
|
|
$arr = explode(":",$cmd);
|
|
|
|
|
|
|
|
if ($noauth) {
|
|
|
|
# run from console, no auth req
|
|
|
|
$C_method->exe_noauth($arr[0],$arr[1]);
|
|
|
|
} else {
|
|
|
|
# run from web, auth required
|
|
|
|
$C_method->exe($arr[0],$arr[1]);
|
|
|
|
}
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if ($C_method->result)
|
|
|
|
$result = 1;
|
|
|
|
else
|
|
|
|
$result = 0;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
@$message = $C_method->error;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
$message = `$cmd`;
|
2008-11-26 14:50:40 -08:00
|
|
|
$result = 1;
|
2009-08-03 14:10:16 +10:00
|
|
|
break;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
default:
|
|
|
|
printf('ERROR: Unknown task type [%s]',$type);
|
|
|
|
}
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
# Update last run date & flip run toggle
|
2009-08-03 14:10:16 +10:00
|
|
|
$db->Execute(sqlUpdate($db,'task',array('running'=>0,'date_run'=>time()),array('id'=>$id)));
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
# Store task log if required
|
2009-08-03 14:10:16 +10:00
|
|
|
if ($log && $C_list->is_installed('task_log')) {
|
|
|
|
include_once(PATH_MODULES.'task_log/task_log.inc.php');
|
|
|
|
$tl = new task_log;
|
|
|
|
|
|
|
|
$VAR['task_log_task_id'] = $id;
|
|
|
|
$VAR['task_log_result'] = $result;
|
|
|
|
$VAR['task_log_message'] = $message;
|
|
|
|
if (! isset($VAR['_page_current']))
|
|
|
|
$VAR['_page_current'] = '';
|
|
|
|
$result = $tl->add($VAR);
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
# If admin, print success message
|
2009-08-03 14:10:16 +10:00
|
|
|
if (DEFAULT_ADMIN_THEME == SESS_THEME) {
|
|
|
|
global $C_translate,$C_debug;
|
|
|
|
$C_debug->alert($C_translate->translate('true','',''));
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-08-03 14:10:16 +10:00
|
|
|
?>
|