<?php
/*======================================================================*\
|| #################################################################### ||
|| # vBulletin 4.0.5
|| # ---------------------------------------------------------------- # ||
|| # Copyright ©2000-2010 vBulletin Solutions Inc. All Rights Reserved. ||
|| # This file may not be redistributed in whole or significant part. # ||
|| # ---------------- VBULLETIN IS NOT FREE SOFTWARE ---------------- # ||
|| # http://www.vbulletin.com | http://www.vbulletin.com/license.html # ||
|| #################################################################### ||
\*======================================================================*/
// ######################## SET PHP ENVIRONMENT ###########################
error_reporting(E_ALL & ~E_NOTICE);
// ##################### DEFINE IMPORTANT CONSTANTS #######################
define('CVS_REVISION', '$RCSfile$ - $Revision: 32878 $');
// #################### PRE-CACHE TEMPLATES AND DATA ######################
$phrasegroups = array('logging', 'cron');
$specialtemplates = array();
// ########################## REQUIRE BACK-END ############################
require_once('./global.php');
// ######################## CHECK ADMIN PERMISSIONS #######################
if (!can_administer('canadmincron'))
{
print_cp_no_permission();
}
// ############################# LOG ACTION ###############################
log_admin_action();
// ########################################################################
// ######################### START MAIN SCRIPT ############################
// ########################################################################
print_cp_header($vbphrase['scheduled_task_log']);
if (empty($_REQUEST['do']))
{
$_REQUEST['do'] = 'choose';
}
// ###################### Start view #######################
if ($_REQUEST['do'] == 'view')
{
$vbulletin->input->clean_array_gpc('r', array(
'perpage' => TYPE_INT,
'varname' => TYPE_STR,
'orderby' => TYPE_STR,
'page' => TYPE_INT
));
if (empty($vbulletin->GPC['perpage']))
{
$vbulletin->GPC['perpage'] = 15;
}
$sqlconds = '';
if (!empty($vbulletin->GPC['varname']))
{
$sqlconds = "WHERE cronlog.varname = '" . $db->escape_string($vbulletin->GPC['varname']) . "'";
}
$counter = $db->query_first("
SELECT COUNT(*) AS total
FROM " . TABLE_PREFIX . "cronlog AS cronlog
$sqlconds
");
$totalpages = ceil($counter['total'] / $vbulletin->GPC['perpage']);
if (empty($vbulletin->GPC['page']))
{
$vbulletin->GPC['page'] = 1;
}
$startat = ($vbulletin->GPC['page'] - 1) * $vbulletin->GPC['perpage'];
switch ($vbulletin->GPC['orderby'])
{
case 'action':
$order = 'cronlog.varname ASC, cronlog.dateline DESC';
break;
case 'date':
default:
$order = 'cronlog.dateline DESC';
}
$logs = $db->query_read("
SELECT cronlog.*
FROM " . TABLE_PREFIX . "cronlog AS cronlog
LEFT JOIN " . TABLE_PREFIX . "cron AS cron ON (cronlog.varname = cron.varname)
$sqlconds
ORDER BY $order
LIMIT $startat, " . $vbulletin->GPC['perpage']
);
if ($db->num_rows($logs))
{
if ($vbulletin->GPC['page'] != 1)
{
$prv = $vbulletin->GPC['page'] - 1;
$firstpage = "<input type=\"button\" class=\"button\" tabindex=\"1\" value=\"« " . $vbphrase['first_page'] . "\" onclick=\"window.location='cronlog.php?" . $vbulletin->session->vars['sessionurl'] . "do=view" .
"&varname=" . urlencode($vbulletin->GPC['varname']) .
"&pp=" . $vbulletin->GPC['perpage'] .
"&orderby=" . urlencode($vbulletin->GPC['orderby']) . "&page=1'\">";
$prevpage = "<input type=\"button\" class=\"button\" tabindex=\"1\" value=\"< " . $vbphrase['prev_page'] . "\" onclick=\"window.location='cronlog.php?" . $vbulletin->session->vars['sessionurl'] . "do=view" .
"&varname=" . urlencode($vbulletin->GPC['varname']) .
"&pp=" . $vbulletin->GPC['perpage'] .
"&orderby=" . urlencode($vbulletin->GPC['orderby']) . "&page=$prv'\">";
}
if ($vbulletin->GPC['page'] != $totalpages)
{
$nxt = $vbulletin->GPC['page'] + 1;
$page_button = "cronlog.php?" . $vbulletin->session->vars['sessionurl'] . "do=view&varname=" . urlencode($vbulletin->GPC['varname']) . "&pp=" . $vbulletin->GPC['perpage'] . "&orderby=" . urlencode($vbulletin->GPC['orderby']);
$nextpage = "<input type=\"button\" class=\"button\" tabindex=\"1\" value=\"" . $vbphrase['next_page'] . " >\" onclick=\"window.location='$page_button&page=$nxt'\">";
$lastpage = "<input type=\"button\" class=\"button\" tabindex=\"1\" value=\"" . $vbphrase['last_page'] . " »\" onclick=\"window.location='$page_button&page=$totalpages'\">";
}
print_form_header('cronlog', 'remove');
print_description_row(construct_link_code($vbphrase['restart'], "cronlog.php?" . $vbulletin->session->vars['sessionurl'] . ""), 0, 4, 'thead', vB_Template_Runtime::fetchStyleVar('right'));
print_table_header(construct_phrase($vbphrase['scheduled_task_log_viewer_page_x_y_there_are_z_total_log_entries'], vb_number_format($vbulletin->GPC['page']), vb_number_format($totalpages), vb_number_format($counter['total'])), 4);
$headings = array();
$headings[] = $vbphrase['id'];
$headings[] = "<a href=\"cronlog.php?" . $vbulletin->session->vars['sessionurl'] . "do=view" .
"&varname=" . urlencode($vbulletin->GPC['varname']) .
"&pp=" . $vbulletin->GPC['perpage'] .
"&orderby=action" .
"&page=" . $vbulletin->GPC['page'] . "\" title=\"" . $vbphrase['order_by_action'] . "\">" . $vbphrase['action'] . "</a>";
$headings[] = "<a href=\"cronlog.php?" . $vbulletin->session->vars['sessionurl'] . "do=view" .
"&varname=" . urlencode($vbulletin->GPC['varname']) .
"&pp=" . $vbulletin->GPC['perpage'] .
"&orderby=date" .
"&page=" . $vbulletin->GPC['page'] . "\" title=\"" . $vbphrase['order_by_date'] . "\">" . $vbphrase['date'] . "</a>";
$headings[] = $vbphrase['info'];
print_cells_row($headings, 1);
while ($log = $db->fetch_array($logs))
{
$cell = array();
$cell[] = $log['cronlogid'];
$cell[] = (isset($vbphrase['task_' . $log['varname'] . '_title']) ? $vbphrase['task_' . $log['varname'] . '_title'] : $log['varname']);
$cell[] = '<span class="smallfont">' . vbdate($vbulletin->options['logdateformat'], $log['dateline']) . '</span>';
if ($log['type'])
{
if (isset($vbphrase['task_' . $log['varname'] . '_log']))
{
$phrase = $vbphrase['task_' . $log['varname'] . '_log'];
if ($unserialized = unserialize($log['description']))
{
array_unshift($unserialized, $phrase);
$cell[] = call_user_func_array('construct_phrase', $unserialized);
}
else
{
$cell[] = construct_phrase($phrase, $log['description']);
}
}
else if ($log['description'])
{
// display this, in case the phrase has been deleted
$cell[] = "$log[varname] - $log[description]";
}
else
{
// no phrase, no description, show nothing (varname shown earlier)
$cell[] = ' ';
}
}
else
{
$cell[] = $log['description'];
}
print_cells_row($cell, 0, 0, -4);
}
print_table_footer(4, "$firstpage $prevpage $nextpage $lastpage");
}
else
{
print_stop_message('no_matches_found');
}
}
// ###################### Start prune log #######################
if ($_POST['do'] == 'prunelog')
{
$vbulletin->input->clean_array_gpc('p', array(
'varname' => TYPE_STR,
'daysprune' => TYPE_INT
));
$sqlconds = '';
if ($vbulletin->GPC['varname'])
{
$sqlconds = " AND varname = '" . $db->escape_string($vbulletin->GPC['varname']) . "'";
}
$datecut = TIMENOW - (86400 * $vbulletin->GPC['daysprune']);
$logs = $db->query_first("
SELECT COUNT(*) AS total
FROM " . TABLE_PREFIX . "cronlog
WHERE dateline < $datecut
$sqlconds
");
if ($logs['total'])
{
print_form_header('cronlog', 'doprunelog');
construct_hidden_code('datecut', $datecut);
construct_hidden_code('varname', $vbulletin->GPC['varname']);
print_table_header($vbphrase['prune_scheduled_task_log']);
print_description_row(construct_phrase($vbphrase['are_you_sure_you_want_to_prune_x_log_entries_from_scheduled_task_log'], vb_number_format($logs['total'])));
print_submit_row($vbphrase['yes'], 0, 0, $vbphrase['no']);
}
else
{
print_stop_message('no_matches_found');
}
}
// ###################### Start do prune log #######################
if ($_POST['do'] == 'doprunelog')
{
$vbulletin->input->clean_array_gpc('p', array(
'varname' => TYPE_STR,
'datecut' => TYPE_INT
));
$sqlconds = '';
if (!empty($vbulletin->GPC['varname']))
{
$sqlconds = " AND varname = '" . $db->escape_string($vbulletin->GPC['varname']) . "'";
}
$db->query_write("
DELETE FROM " . TABLE_PREFIX . "cronlog
WHERE dateline < " . $vbulletin->GPC['datecut'] . "
$sqlconds
");
define('CP_REDIRECT', 'cronlog.php?do=choose');
print_stop_message('pruned_scheduled_task_log_successfully');
}
// ###################### Start modify #######################
if ($_REQUEST['do'] == 'choose')
{
$cronjobs = $db->query_read("
SELECT *
FROM " . TABLE_PREFIX . "cron
ORDER BY varname
");
$filelist = array();
$filelist[0] = $vbphrase['all_scheduled_tasks'];
while ($file = $db->fetch_array($cronjobs))
{
$filelist["$file[varname]"] = (isset($vbphrase['task_' . $file['varname'] . '_title']) ?
htmlspecialchars_uni($vbphrase['task_' . $file['varname'] . '_title']) :
$file['varname']
);
}
$perpage = array(5 => 5, 10 => 10, 15 => 15, 20 => 20, 25 => 25, 30 => 30, 40 => 40, 50 => 50, 100 => 100);
$orderby = array('date' => $vbphrase['date'], 'action' => $vbphrase['action']);
print_form_header('cronlog', 'view');
print_table_header($vbphrase['scheduled_task_log_viewer']);
print_select_row($vbphrase['log_entries_to_show_per_page'], 'perpage', $perpage, 15);
print_select_row($vbphrase['show_only_entries_generated_by'], 'varname', $filelist);
print_select_row($vbphrase['order_by'], 'orderby', $orderby);
print_submit_row($vbphrase['view'], 0);
print_form_header('cronlog', 'prunelog');
print_table_header($vbphrase['prune_scheduled_task_log']);
print_select_row($vbphrase['remove_entries_related_to_action'], 'varname', $filelist);
print_input_row($vbphrase['remove_entries_older_than_days'], 'daysprune', 30);
print_submit_row($vbphrase['prune'], 0);
}
print_cp_footer();
/*======================================================================*\
|| ####################################################################
|| # CVS: $RCSfile$ - $Revision: 32878 $
|| ####################################################################
\*======================================================================*/
?>