188 lines
5.9 KiB
PHP
188 lines
5.9 KiB
PHP
<?php
|
|
|
|
/*
|
|
[UCenter] (C)2001-2099 Comsenz Inc.
|
|
This is NOT a freeware, use is subject to license terms
|
|
|
|
$Id: frame.php 1059 2011-03-01 07:25:09Z monkey $
|
|
*/
|
|
|
|
!defined('IN_UC') && exit('Access Denied');
|
|
|
|
class control extends adminbase {
|
|
|
|
var $members;
|
|
var $apps;
|
|
var $friends;
|
|
|
|
function __construct() {
|
|
$this->control();
|
|
}
|
|
|
|
function control() {
|
|
parent::__construct();
|
|
}
|
|
|
|
function onindex() {
|
|
$this->view->assign('sid', $this->view->sid);
|
|
$mainurl = getgpc('mainurl');
|
|
$mainurl = !empty($mainurl) && preg_match("/^admin\.php\?(&*\w+=\w+)*$/i", $mainurl) ? $mainurl : 'admin.php?m=frame&a=main&sid='.$this->view->sid;
|
|
$this->view->assign('mainurl', $mainurl);
|
|
$this->view->display('admin_frame_index');
|
|
}
|
|
|
|
function onmain() {
|
|
$ucinfo = '';
|
|
$this->view->assign('ucinfo', $ucinfo);
|
|
|
|
$members = $this->_get_uc_members();
|
|
$applist = $this->_get_uc_apps();
|
|
$notes = $this->_get_uc_notes();
|
|
$errornotes = $this->_get_uc_errornotes($applist);
|
|
$pms = $this->_get_uc_pms();
|
|
$apps = count($applist);
|
|
$friends = $this->_get_uc_friends();
|
|
$this->view->assign('members', $members);
|
|
$this->view->assign('applist', $applist);
|
|
$this->view->assign('apps', $apps);
|
|
$this->view->assign('friends', $friends);
|
|
$this->view->assign('notes', $notes);
|
|
$this->view->assign('errornotes', $errornotes);
|
|
$this->view->assign('pms', $pms);
|
|
$this->view->assign('iframe', getgpc('iframe', 'G'));
|
|
|
|
$serverinfo = PHP_OS.' / PHP v'.PHP_VERSION;
|
|
$serverinfo .= @ini_get('safe_mode') ? ' Safe Mode' : NULL;
|
|
$dbversion = $this->db->result_first("SELECT VERSION()");
|
|
$fileupload = @ini_get('file_uploads') ? ini_get('upload_max_filesize') : '<font color="red">'.$lang['no'].'</font>';
|
|
$dbsize = 0;
|
|
$tablepre = UC_DBTABLEPRE;
|
|
$query = $tables = $this->db->fetch_all("SHOW TABLE STATUS LIKE '$tablepre%'");
|
|
foreach($tables as $table) {
|
|
$dbsize += $table['Data_length'] + $table['Index_length'];
|
|
}
|
|
$dbsize = $dbsize ? $this->_sizecount($dbsize) : $lang['unknown'];
|
|
$magic_quote_gpc = get_magic_quotes_gpc() ? 'On' : 'Off';
|
|
$allow_url_fopen = ini_get('allow_url_fopen') ? 'On' : 'Off';
|
|
$this->view->assign('serverinfo', $serverinfo);
|
|
$this->view->assign('fileupload', $fileupload);
|
|
$this->view->assign('dbsize', $dbsize);
|
|
$this->view->assign('dbversion', $dbversion);
|
|
$this->view->assign('magic_quote_gpc', $magic_quote_gpc);
|
|
$this->view->assign('allow_url_fopen', $allow_url_fopen);
|
|
|
|
$this->view->display('admin_frame_main');
|
|
}
|
|
|
|
function onmenu() {
|
|
$this->view->display('admin_frame_menu');
|
|
}
|
|
|
|
function onheader() {
|
|
$this->load('app');
|
|
$applist = $_ENV['app']->get_apps();
|
|
$cparray = array(
|
|
'UCHOME' => 'admincp.php',
|
|
'DISCUZ' => 'admincp.php',
|
|
'SUPESITE' => 'admincp.php',
|
|
'XSPACE' => 'admincp.php',
|
|
'SUPEV' => 'admincp.php',
|
|
'ECSHOP' => 'admin/index.php',
|
|
'ECMALL' => 'admin.php'
|
|
);
|
|
$admincp = '';
|
|
if(is_array($applist)) {
|
|
foreach($applist AS $k => $app) {
|
|
if(isset($cparray[$app['type']])) {
|
|
$admincp .= '<li><a href="'.(substr($app['url'], -1) == '/' ? $app['url'] : $app['url'].'/').$cparray[$app['type']].'" target="_blank">'.$app['name'].'</a></li>';
|
|
}
|
|
}
|
|
}
|
|
$this->view->assign('admincp', $admincp);
|
|
$this->view->assign('username', $this->user['username']);
|
|
$this->view->display('admin_frame_header');
|
|
}
|
|
|
|
function _get_uc_members() {
|
|
if(!$this->members) {
|
|
$this->members = $this->db->result_first("SELECT COUNT(*) FROM ".UC_DBTABLEPRE."members");
|
|
}
|
|
return $this->members;
|
|
}
|
|
|
|
function _get_uc_friends() {
|
|
$friends = $this->db->result_first("SELECT COUNT(*) FROM ".UC_DBTABLEPRE."friends");
|
|
return $friends;
|
|
}
|
|
|
|
function _get_uc_apps() {
|
|
if(!$this->apps) {
|
|
$this->apps = $this->db->fetch_all("SELECT * FROM ".UC_DBTABLEPRE."applications");
|
|
}
|
|
return $this->apps;
|
|
}
|
|
function _get_uc_pms() {
|
|
$pms = 0;
|
|
for($i = 0; $i < 10; $i++) {
|
|
$pms += $this->db->result_first("SELECT COUNT(*) FROM ".UC_DBTABLEPRE."pm_messages_".(string)$i);
|
|
}
|
|
return $pms;
|
|
}
|
|
|
|
function _get_uc_notes() {
|
|
$notes = $this->db->result_first("SELECT COUNT(*) FROM ".UC_DBTABLEPRE."notelist WHERE closed='0'");
|
|
return $notes;
|
|
}
|
|
|
|
function _get_uc_errornotes($applist) {
|
|
$notelist = $this->db->fetch_all("SELECT * FROM ".UC_DBTABLEPRE."notelist ORDER BY dateline DESC LIMIT 20");
|
|
$error = array();
|
|
foreach($notelist as $note) {
|
|
foreach($applist as $k => $app) {
|
|
if($note['app'.$app['appid']] < 0) {
|
|
$error[$k]++;
|
|
}
|
|
}
|
|
}
|
|
return $error;
|
|
}
|
|
|
|
function _sizecount($filesize) {
|
|
if($filesize >= 1073741824) {
|
|
$filesize = round($filesize / 1073741824 * 100) / 100 . ' GB';
|
|
} elseif($filesize >= 1048576) {
|
|
$filesize = round($filesize / 1048576 * 100) / 100 . ' MB';
|
|
} elseif($filesize >= 1024) {
|
|
$filesize = round($filesize / 1024 * 100) / 100 . ' KB';
|
|
} else {
|
|
$filesize = $filesize . ' Bytes';
|
|
}
|
|
return $filesize;
|
|
}
|
|
|
|
function _get_uc_info() {
|
|
$update = array('uniqueid' => UC_SITEID, 'version' => UC_SERVER_VERSION, 'release' => UC_SERVER_RELEASE, 'php' => PHP_VERSION, 'mysql' => $this->db->version(), 'charset' => UC_CHARSET);
|
|
$updatetime = @filemtime(UC_ROOT.'./data/updatetime.lock');
|
|
if(empty($updatetime) || ($this->time - $updatetime > 3600 * 4)) {
|
|
@touch(UC_ROOT.'./data/updatetime.lock');
|
|
$update['members'] = $this->_get_uc_members();
|
|
$update['friends'] = $this->_get_uc_friends();
|
|
$apps = $this->_get_uc_apps();
|
|
if($apps) {
|
|
foreach($apps as $app) {
|
|
$update['app_'.$app['appid']] = $app['name']."\t".$app['url']."\t".$app['type'];
|
|
}
|
|
}
|
|
}
|
|
|
|
$data = '';
|
|
foreach($update as $key => $value) {
|
|
$data .= $key.'='.rawurlencode($value).'&';
|
|
}
|
|
|
|
return 'update='.rawurlencode(base64_encode($data)).'&md5hash='.substr(md5($_SERVER['HTTP_USER_AGENT'].implode('', $update).$this->time), 8, 8).'×tamp='.$this->time;
|
|
}
|
|
|
|
}
|
|
|
|
?>
|