configured
[bMailZu.git] / messagesPendingAdmin.php
blobf66fdb4b0e937a81e4d09cdb4b9bf7c98245eb48
1 <?php
2 /**
3 * Display all pending requests for the site.
5 * @author Brian Wong
6 * @author Jeremy Fowler <jfowler06@users.sourceforge.net>
7 * @version 04-03-07
8 * @package MailZu
10 * Copyright (C) 2005 - 2007 MailZu
11 * License: GPL, see LICENSE
13 /**
14 * Include Template class
16 include_once('lib/Template.class.php');
17 /**
18 * Include common output functions
20 include_once('templates/common.template.php');
21 /**
22 * Include quarantine-specific output functions
24 include_once('templates/quarantine.template.php');
26 if (!Auth::is_logged_in()) {
27 Auth::print_login_msg(); // Check if user is logged in
30 // grab the display size limit set in config.php
31 $sizeLimit = isset ( $conf['app']['displaySizeLimit'] ) && is_numeric( $conf['app']['displaySizeLimit'] ) ?
32 $conf['app']['displaySizeLimit'] : 50;
34 $_SESSION['sessionNav'] = "Site Pending Requests";
36 // Get current page number
37 $requestedPage = CmnFns::getGlobalVar('page', GET);
39 $db = new DBEngine();
41 $t = new Template(translate('Site Quarantine'));
43 $t->printHTMLHeader();
44 $t->printWelcome();
45 $t->startMain();
47 // Break table into 2 columns, put quick links on left side and all other tables on the right
48 startQuickLinksCol();
49 showQuickLinks(); // Print out My Quick Links
50 startDataDisplayCol();
52 if (! Auth::isMailAdmin()) {
53 CmnFns::do_error_box(translate('Access Denied'));
55 } else {
56 // Draw search engine
57 printSearchEngine($content_type, $_SERVER['PHP_SELF'], 1);
58 echo '<br>';
60 if ( CmnFns::getGlobalVar('search_action', GET) == translate('Clear search results') ) CmnFns::redirect_js($_SERVER['PHP_SELF']);
62 $search_array1 = $db->convertSearch2SQL( 'msgs.from_addr', CmnFns::getGlobalVar('f_criterion', GET), CmnFns::getGlobalVar('f_string', GET) );
63 $search_array2 = $db->convertSearch2SQL( 'msgs.subject', CmnFns::getGlobalVar('s_criterion', GET), CmnFns::getGlobalVar('s_string', GET) );
64 $search_array3 = $db->convertSearch2SQL( 'recip.email', CmnFns::getGlobalVar('t_criterion', GET), CmnFns::getGlobalVar('t_string', GET) );
65 $search_array4 = $db->convertSearch2SQL( 'msgs.mail_id', CmnFns::getGlobalVar('m_criterion', GET), CmnFns::getGlobalVar('m_string', GET) );
67 $search_array = array_merge( $search_array1, $search_array2, $search_array3, $search_array4 );
69 $order = array('msgs.time_num', 'from_addr', 'msgs.subject', 'spam_level', 'recip.email', 'msgs.content', 'mail_id');
70 // Arbitrary type for Admin
71 $content_type = (CmnFns::get_ctype() ? CmnFns::get_ctype() : 'A');
73 // Print a loading message until database returns...
74 printMessage(translate('Retrieving Messages...'));
76 $messages = $db->get_user_messages($content_type, $_SESSION['sessionMail'], CmnFns::get_value_order($order), CmnFns::get_vert_order(), $search_array, 1, 1, $requestedPage);
78 // Compute maximum number of pages
79 $maxPage = (ceil($db->numRows/$sizeLimit)-1);
81 // If $requestedPage > $maxPage, then redirect to $maxPage instead of $requestedPage
82 if ( $requestedPage > $maxPage ) {
83 $query_string = CmnFns::array_to_query_string( $_GET, array( 'page' ) );
84 $query_string = str_replace ( '&amp;', '&', $query_string );
85 CmnFns::redirect_js($_SERVER['PHP_SELF'].'?'.$query_string.'&page='.$maxPage);
88 showMessagesTable($content_type, $messages, $requestedPage, CmnFns::get_value_order($order), CmnFns::get_vert_order());
90 // Hide the message after the table loads.
91 hideMessage(translate('Retrieving Messages...'));
94 endDataDisplayCol();
95 $t->endMain();
96 $t->printHTMLFooter();