admin_attachments.php
来自「这是php编的论坛的原代码」· PHP 代码 · 共 1,428 行 · 第 1/3 页
PHP
1,428 行
if ( !@file_exists(@amod_realpath($upload_dir)) )
{
$error = TRUE;
$error_msg = sprintf($lang['Directory_does_not_exist'], $upload_dir) . '<br />';
}
}
if (!$error && !is_dir($upload_dir))
{
$error = TRUE;
$error_msg = sprintf($lang['Directory_is_not_a_dir'], $upload_dir) . '<br />';
}
if (!$error)
{
if ( !($fp = @fopen($upload_dir . '/0_000000.000', 'w')) )
{
$error = TRUE;
$error_msg = sprintf($lang['Directory_not_writeable'], $upload_dir) . '<br />';
}
else
{
@fclose($fp);
@unlink($upload_dir . '/0_000000.000');
}
}
}
else if ( (intval($attach_config['allow_ftp_upload'])) && (intval($attach_config['img_create_thumbnail'])) )
{
//
// Check FTP Settings
//
$server = ( empty($attach_config['ftp_server']) ) ? 'localhost' : $attach_config['ftp_server'];
$conn_id = @ftp_connect($server);
if (!$conn_id)
{
$error = TRUE;
$error_msg = sprintf($lang['Ftp_error_connect'], $server) . '<br />';
}
$login_result = @ftp_login($conn_id, $attach_config['ftp_user'], $attach_config['ftp_pass']);
if ( (!$login_result) && (!$error) )
{
$error = TRUE;
$error_msg = sprintf($lang['Ftp_error_login'], $attach_config['ftp_user']) . '<br />';
}
if (!@ftp_pasv($conn_id, intval($attach_config['ftp_pasv_mode'])))
{
$error = TRUE;
$error_msg = $lang['Ftp_error_pasv_mode'];
}
if (!$error)
{
//
// Check Upload
//
$tmpfname = @tempnam('/tmp', 't0000');
@unlink($tmpfname); // unlink for safety on php4.0.3+
$fp = @fopen($tmpfname, 'w');
@fwrite($fp, 'test');
@fclose($fp);
$result = @ftp_chdir($conn_id, $attach_config['ftp_path'] . '/' . THUMB_DIR);
if (!$result)
{
@ftp_mkdir($conn_id, $attach_config['ftp_path'] . '/' . THUMB_DIR);
}
$result = @ftp_chdir($conn_id, $attach_config['ftp_path'] . '/' . THUMB_DIR);
if (!$result)
{
$error = TRUE;
$error_msg = sprintf($lang['Ftp_error_path'], $attach_config['ftp_path'] . '/' . THUMB_DIR) . '<br />';
}
else
{
$res = @ftp_put($conn_id, 't0000', $tmpfname, FTP_ASCII);
if (!$res)
{
$error = TRUE;
$error_msg = sprintf($lang['Ftp_error_upload'], $attach_config['ftp_path'] . '/' . THUMB_DIR) . '<br />';
}
else
{
$res = @ftp_delete($conn_id, 't0000');
if (!$res)
{
$error = TRUE;
$error_msg = sprintf($lang['Ftp_error_delete'], $attach_config['ftp_path'] . '/' . THUMB_DIR) . '<br />';
}
}
}
@ftp_quit($conn_id);
@unlink($tmpfname);
}
}
if (!$error)
{
message_die(GENERAL_MESSAGE, $lang['Test_settings_successful'] . '<br /><br />' . sprintf($lang['Click_return_attach_config'], '<a href="' . append_sid("admin_attachments.$phpEx?mode=cats") . '">', '</a>') . '<br /><br />' . sprintf($lang['Click_return_admin_index'], '<a href="' . append_sid("index.$phpEx?pane=right") . '">', '</a>'));
}
}
if ($mode == 'sync')
{
$info = '';
@set_time_limit(0);
print_r('Sync Topics');
$sql = "SELECT topic_id FROM " . TOPICS_TABLE;
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not get topic ID', '', __LINE__, __FILE__, $sql);
}
print_r('<br />');
while( $row = $db->sql_fetchrow($result) )
{
print_r('.');
attachment_sync_topic($row['topic_id']);
}
print_r('<br /><br />');
print_r('Sync Thumbnails');
// Sync Thumbnails (if a thumbnail is no longer there, delete it)
// Get all Posts/PM's with the Thumbnail Flag set
// Go through all of them and make sure the Thumbnail exist. If it does not exist, unset the Thumbnail Flag
$sql = "SELECT attach_id, physical_filename, thumbnail FROM " . ATTACHMENTS_DESC_TABLE . " WHERE thumbnail = 1";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not get thumbnail informations', '', __LINE__, __FILE__, $sql);
}
print_r('<br />');
while ($row = $db->sql_fetchrow($result))
{
print_r('.');
if (!thumbnail_exists($row['physical_filename']))
{
$info .= sprintf($lang['Sync_thumbnail_resetted'], $row['physical_filename']) . '<br />';
$sql = "UPDATE " . ATTACHMENTS_DESC_TABLE . " SET thumbnail = 0 WHERE attach_id = " . $row['attach_id'];
if ( !($db->sql_query($sql)) )
{
$error = $db->sql_error();
die('Could not update thumbnail informations -> ' . $error['message'] . ' -> ' . $sql);
}
}
}
die('<br /><br /><br />' . $lang['Attach_sync_finished'] . '<br /><br />' . $info);
exit();
}
// Quota Limit Settings
if ($submit && $mode == 'quota')
{
//
// Change Quota Limit
//
$quota_change_list = ( isset($HTTP_POST_VARS['quota_change_list']) ) ? $HTTP_POST_VARS['quota_change_list'] : array();
$quota_desc_list = ( isset($HTTP_POST_VARS['quota_desc_list']) ) ? $HTTP_POST_VARS['quota_desc_list'] : array();
$filesize_list = ( isset($HTTP_POST_VARS['max_filesize_list']) ) ? $HTTP_POST_VARS['max_filesize_list'] : array();
$size_select_list = ( isset($HTTP_POST_VARS['size_select_list']) ) ? $HTTP_POST_VARS['size_select_list'] : array();
$allowed_list = array();
for ($i = 0; $i < count($quota_change_list); $i++)
{
$filesize_list[$i] = ( $size_select_list[$i] == 'kb' ) ? round($filesize_list[$i] * 1024) : ( ($size_select_list[$i] == 'mb') ? round($filesize_list[$i] * 1048576) : $filesize_list[$i] );
$sql = "UPDATE " . QUOTA_LIMITS_TABLE . "
SET quota_desc = '" . trim(strip_tags($quota_desc_list[$i])) . "', quota_limit = " . $filesize_list[$i] . "
WHERE quota_limit_id = " . $quota_change_list[$i];
if ( !($db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Couldn\'t update Quota Limits', '', __LINE__, __FILE__, $sql);
}
}
//
// Delete Quota Limits
//
$quota_id_list = ( isset($HTTP_POST_VARS['quota_id_list']) ) ? $HTTP_POST_VARS['quota_id_list'] : array();
$quota_id_sql = implode(', ', $quota_id_list);
if ($quota_id_sql != '')
{
$sql = 'DELETE
FROM ' . QUOTA_LIMITS_TABLE . '
WHERE quota_limit_id IN (' . $quota_id_sql . ')';
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not delete Quota Limits', '', __LINE__, __FILE__, $sql);
}
// Delete Quotas linked to this setting
$sql = 'DELETE
FROM ' . QUOTA_TABLE . '
WHERE quota_limit_id IN (' . $quota_id_sql . ')';
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not delete Quotas', '', __LINE__, __FILE__, $sql);
}
}
//
// Add Quota Limit ?
//
$quota_desc = ( isset($HTTP_POST_VARS['quota_description']) ) ? trim(strip_tags($HTTP_POST_VARS['quota_description'])) : '';
$filesize = ( isset($HTTP_POST_VARS['add_max_filesize']) ) ? $HTTP_POST_VARS['add_max_filesize'] : '';
$size_select = ( isset($HTTP_POST_VARS['add_size_select']) ) ? $HTTP_POST_VARS['add_size_select'] : '';
$add = ( isset($HTTP_POST_VARS['add_quota_check']) ) ? TRUE : FALSE;
if ($quota_desc != '' && $add)
{
//
// check Quota Description
//
$sql = 'SELECT quota_desc
FROM ' . QUOTA_LIMITS_TABLE;
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not query Quota Limits Table', '', __LINE__, __FILE__, $sql);
}
$row = $db->sql_fetchrowset($result);
$num_rows = $db->sql_numrows($result);
if ( $num_rows > 0 )
{
for ($i = 0; $i < $num_rows; $i++)
{
if ($row[$i]['quota_desc'] == $quota_desc)
{
$error = TRUE;
if( isset($error_msg) )
{
$error_msg .= '<br />';
}
$error_msg .= sprintf($lang['Quota_limit_exist'], $extension_group);
}
}
}
if (!$error)
{
$filesize = ( $size_select == 'kb' ) ? round($filesize * 1024) : ( ($size_select == 'mb') ? round($filesize * 1048576) : $filesize );
$sql = "INSERT INTO " . QUOTA_LIMITS_TABLE . " (quota_desc, quota_limit)
VALUES ('" . $quota_desc . "', " . $filesize . ")";
if ( !($db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not add Quota Limit', '', __LINE__, __FILE__, $sql);
}
}
}
if (!$error)
{
$message = $lang['Attach_config_updated'] . '<br /><br />' . sprintf($lang['Click_return_attach_config'], '<a href="' . append_sid("admin_attachments.$phpEx?mode=quota") . '">', '</a>') . '<br /><br />' . sprintf($lang['Click_return_admin_index'], '<a href="' . append_sid("index.$phpEx?pane=right") . '">', '</a>');
message_die(GENERAL_MESSAGE, $message);
}
}
if ($mode == 'quota')
{
$template->set_filenames(array(
'body' => 'admin/attach_quota_body.tpl')
);
$max_add_filesize = intval($attach_config['max_filesize']);
$size = ($max_add_filesize >= 1048576) ? 'mb' : ( ($max_add_filesize >= 1024) ? 'kb' : 'b' );
if ($max_add_filesize >= 1048576)
{
$max_add_filesize = round($max_add_filesize / 1048576 * 100) / 100;
}
else if ( $max_add_filesize >= 1024)
{
$max_add_filesize = round($max_add_filesize / 1024 * 100) / 100;
}
$template->assign_vars(array(
'L_MANAGE_QUOTAS_TITLE' => $lang['Manage_quotas'],
'L_MANAGE_QUOTAS_EXPLAIN' => $lang['Manage_quotas_explain'],
'L_SUBMIT' => $lang['Submit'],
'L_RESET' => $lang['Reset'],
'L_EDIT' => $lang['Edit'],
'L_VIEW' => $lang['View'],
'L_DESCRIPTION' => $lang['Description'],
'L_SIZE' => $lang['Max_filesize_attach'],
'L_ADD_NEW' => $lang['Add_new'],
'L_DELETE' => $lang['Delete'],
'MAX_FILESIZE' => $max_add_filesize,
'S_FILESIZE' => size_select('add_size_select', $size),
'L_REMOVE_SELECTED' => $lang['Remove_selected'],
'S_ATTACH_ACTION' => append_sid('admin_attachments.' . $phpEx . '?mode=quota'))
);
$sql = "SELECT * FROM " . QUOTA_LIMITS_TABLE . " ORDER BY quota_limit DESC";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not get quota limits', '', __LINE__, __FILE__, $sql);
}
$rows = $db->sql_fetchrowset($result);
for ($i = 0; $i < count($rows); $i++)
{
$size_format = ($rows[$i]['quota_limit'] >= 1048576) ? 'mb' : ( ($rows[$i]['quota_limit'] >= 1024) ? 'kb' : 'b' );
if ( $rows[$i]['quota_limit'] >= 1048576)
{
$rows[$i]['quota_limit'] = round($rows[$i]['quota_limit'] / 1048576 * 100) / 100;
}
else if($rows[$i]['quota_limit'] >= 1024)
{
$rows[$i]['quota_limit'] = round($rows[$i]['quota_limit'] / 1024 * 100) / 100;
}
$template->assign_block_vars('limit_row', array(
'QUOTA_NAME' => stripslashes($rows[$i]['quota_desc']),
'QUOTA_ID' => $rows[$i]['quota_limit_id'],
'S_FILESIZE' => size_select('size_select_list[]', $size_format),
'U_VIEW' => append_sid("admin_attachments.$phpEx?mode=$mode&e_mode=view_quota&quota_id=" . $rows[$i]['quota_limit_id']),
'MAX_FILESIZE' => $rows[$i]['quota_limit'])
);
}
}
if ($mode == 'quota' && $e_mode == 'view_quota')
{
if( isset($HTTP_POST_VARS['quota_id']) || isset($HTTP_GET_VARS['quota_id']) )
{
$quota_id = ( isset($HTTP_POST_VARS['quota_id']) ) ? intval($HTTP_POST_VARS['quota_id']) : intval($HTTP_GET_VARS['quota_id']);
}
else
{
message_die(GENERAL_MESSAGE, 'Invalid Call');
}
$template->assign_block_vars('switch_quota_limit_desc', array());
$sql = "SELECT * FROM " . QUOTA_LIMITS_TABLE . " WHERE quota_limit_id = " . $quota_id . " LIMIT 1";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not get quota limits', '', __LINE__, __FILE__, $sql);
}
$row = $db->sql_fetchrow($result);
$template->assign_vars(array(
'L_QUOTA_LIMIT_DESC' => $row['quota_desc'],
'L_ASSIGNED_USERS' => $lang['Assigned_users'],
'L_ASSIGNED_GROUPS' => $lang['Assigned_groups'],
'L_UPLOAD_QUOTA' => $lang['Upload_quota'],
'L_PM_QUOTA' => $lang['Pm_quota'])
);
$sql = "SELECT q.user_id, u.username, q.quota_type FROM " . QUOTA_TABLE . " q, " . USERS_TABLE . " u
WHERE q.quota_limit_id = " . $quota_id . " AND q.user_id <> 0 AND q.user_id = u.user_id";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not get quota limits', '', __LINE__, __FILE__, $sql);
}
$rows = $db->sql_fetchrowset($result);
$num_rows = $db->sql_numrows($result);
for ($i = 0; $i < $num_rows; $i++)
{
if ($rows[$i]['quota_type'] == QUOTA_UPLOAD_LIMIT)
{
$template->assign_block_vars('users_upload_row', array(
'USER_ID' => $rows[$i]['user_id'],
'USERNAME' => $rows[$i]['username'])
);
}
else if ($rows[$i]['quota_type'] == QUOTA_PM_LIMIT)
{
$template->assign_block_vars('users_pm_row', array(
'USER_ID' => $rows[$i]['user_id'],
'USERNAME' => $rows[$i]['username'])
);
}
}
$sql = "SELECT q.group_id, g.group_name, q.quota_type FROM " . QUOTA_TABLE . " q, " . GROUPS_TABLE . " g
WHERE q.quota_limit_id = " . $quota_id . " AND q.group_id <> 0 AND q.group_id = g.group_id";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not get quota limits', '', __LINE__, __FILE__, $sql);
}
$rows = $db->sql_fetchrowset($result);
$num_rows = $db->sql_numrows($result);
for ($i = 0; $i < $num_rows; $i++)
{
if ($rows[$i]['quota_type'] == QUOTA_UPLOAD_LIMIT)
{
$template->assign_block_vars('groups_upload_row', array(
'GROUP_ID' => $rows[$i]['group_id'],
'GROUPNAME' => $rows[$i]['group_name'])
);
}
else if ($rows[$i]['quota_type'] == QUOTA_PM_LIMIT)
{
$template->assign_block_vars('groups_pm_row', array(
'GROUP_ID' => $rows[$i]['group_id'],
'GROUPNAME' => $rows[$i]['group_name'])
);
}
}
}
if ($error)
{
$template->set_filenames(array(
'reg_header' => 'error_body.tpl')
);
$template->assign_vars(array(
'ERROR_MESSAGE' => $error_msg)
);
$template->assign_var_from_handle('ERROR_BOX', 'reg_header');
}
$template->pparse('body');
include('page_footer_admin.'.$phpEx);
?>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?