bnbweb/admin/shop_config.php
2022-11-14 23:49:28 +08:00

429 lines
14 KiB
PHP
Executable File

<?php
define('IN_ECS', true);
/* 代码 */
require(dirname(__FILE__) . '/includes/init.php');
if($GLOBALS['_CFG']['certificate_id'] == '')
{
$certi_id='error';
}
else
{
$certi_id=$GLOBALS['_CFG']['certificate_id'];
}
$sess_id = $GLOBALS['sess']->get_session_id();
$auth = time();
$ac = md5($certi_id.'SHOPEX_SMS'.$auth);
$url = 'http://service.shopex.cn/sms/index.php?certificate_id='.$certi_id.'&sess_id='.$sess_id.'&auth='.$auth.'&ac='.$ac;
/*------------------------------------------------------ */
//-- 列表编辑 ?act=list_edit
/*------------------------------------------------------ */
if ($_REQUEST['act'] == 'list_edit')
{
/* 检查权限 */
admin_priv('shop_config');
/* 可选语言 */
$dir = opendir('../languages');
$lang_list = array();
while (@$file = readdir($dir))
{
if ($file != '.' && $file != '..' && $file != '.svn' && $file != '_svn' && is_dir('../languages/' .$file))
{
$lang_list[] = $file;
}
}
@closedir($dir);
$smarty->assign('lang_list', $lang_list);
$smarty->assign('ur_here', $_LANG['01_shop_config']);
$smarty->assign('group_list', get_settings(null, array('5')));
// $smarty->assign('countries', get_regions());
if (strpos(strtolower($_SERVER['SERVER_SOFTWARE']), 'iis') !== false)
{
$rewrite_confirm = $_LANG['rewrite_confirm_iis'];
}
else
{
$rewrite_confirm = $_LANG['rewrite_confirm_apache'];
}
$smarty->assign('rewrite_confirm', $rewrite_confirm);
if ($_CFG['shop_country'] > 0)
{
$smarty->assign('provinces', get_regions(1, $_CFG['shop_country']));
if ($_CFG['shop_province'])
{
$smarty->assign('cities', get_regions(2, $_CFG['shop_province']));
}
}
$smarty->assign('cfg', $_CFG);
assign_query_info();
$demo_data['mobile'] = '13812345678';
$demo_data['name'] = '张三';
$demo_data['order_sn'] = '12345678978945';
$demo_data['order_amount'] = '65.00';
$demo_data['delivery_time'] = '4月30号';
$demo_data['sms_sign'] = $GLOBALS['_CFG']['shop_name'];
foreach ($demo_data as $k=>$v) $demo_data[$k] = sprintf("<font color='red'>%s</font>",$v);
require_once(ROOT_PATH . 'languages/' .$_CFG['lang']. '/common.php');
require_once(ROOT_PATH . 'languages/' .$_CFG['lang']. '/shopping_flow.php');
// require_once(ROOT_PATH . 'languages/' .$_CFG['lang']. '/admin/order.php');
$demo_sms_info['sms_order_placed'] = sprintf($_LANG['order_placed_sms'], $demo_data['name'], $demo_data['mobile']);
$demo_sms_info['sms_order_payed'] = sprintf($_LANG['order_payed_sms'], $demo_data['order_sn'], $demo_data['name'], $demo_data['mobile']);
$demo_sms_info['sms_order_payed_to_customer'] = sprintf($_LANG['order_payed_to_customer_sms'], $demo_data['order_sn'], $demo_data['order_amount']);
$demo_sms_info['sms_order_shipped'] = sprintf($_LANG['order_shipped_sms'], $demo_data['order_sn'],
$demo_data['delivery_time'], $demo_data['sms_sign']);
$smarty->assign('demo_sms_info',$demo_sms_info);
$smarty->display('shop_config.htm');
}
/*------------------------------------------------------ */
//-- 邮件服务器设置
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'mail_settings')
{
/* 检查权限 */
admin_priv('shop_config');
$arr = get_settings(array(5));
assign_query_info();
$smarty->assign('ur_here', $_LANG['mail_settings']);
$smarty->assign('cfg', $arr[5]['vars']);
$smarty->display('shop_config_mail_settings.htm');
}
/*------------------------------------------------------ */
//-- 提交 ?act=post
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'post')
{
$type = empty($_POST['type']) ? '' : $_POST['type'];
/* 检查权限 */
admin_priv('shop_config');
/* 允许上传的文件类型 */
$allow_file_types = '|GIF|JPG|PNG|BMP|SWF|DOC|XLS|PPT|MID|WAV|ZIP|RAR|PDF|CHM|RM|TXT|CERT|';
/* 保存变量值 */
$count = count($_POST['value']);
$arr = array();
$sql = 'SELECT id, value FROM ' . $ecs->table('shop_config');
$res= $db->query($sql);
while($row = $db->fetchRow($res))
{
$arr[$row['id']] = $row['value'];
}
foreach ($_POST['value'] AS $key => $val)
{
if($arr[$key] != $val)
{
$sql = "UPDATE " . $ecs->table('shop_config') . " SET value = '" . trim($val) . "' WHERE id = '" . $key . "'";
$db->query($sql);
}
}
if( isset($_POST['value']['247']) and $_POST['value']['247'] ){
include_once(ROOT_PATH . 'includes/cls_certificate.php');
$cert = new certificate();
if( false == $cert->open_logistics_trace() ){
$links[] = array('text' => $_LANG['back_shop_config'], 'href' => 'shop_config.php?act=list_edit');
sys_msg($_LANG['open_logistics_trace_fail'], 0, $links);
}
}
/* 处理上传文件 */
$file_var_list = array();
$sql = "SELECT * FROM " . $ecs->table('shop_config') . " WHERE parent_id > 0 AND type = 'file'";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
$file_var_list[$row['code']] = $row;
}
foreach ($_FILES AS $code => $file)
{
/* 判断用户是否选择了文件 */
if ((isset($file['error']) && $file['error'] == 0) || (!isset($file['error']) && $file['tmp_name'] != 'none'))
{
/* 检查上传的文件类型是否合法 */
if (!check_file_type($file['tmp_name'], $file['name'], $allow_file_types))
{
sys_msg(sprintf($_LANG['msg_invalid_file'], $file['name']));
}
else
{
if ($code == 'shop_logo')
{
include_once('includes/lib_template.php');
$info = get_template_info($_CFG['template']);
$file_name = str_replace('{$template}', $_CFG['template'], $file_var_list[$code]['store_dir']) . $info['logo'];
}
elseif ($code == 'watermark')
{
$file_name_arr = explode('.', $file['name']);
$ext = array_pop($file_name_arr);
$file_name = $file_var_list[$code]['store_dir'] . 'watermark.' . $ext;
if (file_exists($file_var_list[$code]['value']))
{
@unlink($file_var_list[$code]['value']);
}
}
elseif($code == 'wap_logo')
{
$file_name_arr = explode('.', $file['name']);
$ext = array_pop($file_name_arr);
$file_name = $file_var_list[$code]['store_dir'] . 'wap_logo.' . $ext;
if (file_exists($file_var_list[$code]['value']))
{
@unlink($file_var_list[$code]['value']);
}
}
else
{
$file_name = $file_var_list[$code]['store_dir'] . $file['name'];
}
/* 判断是否上传成功 */
if (move_upload_file($file['tmp_name'], $file_name))
{
$sql = "UPDATE " . $ecs->table('shop_config') . " SET value = '$file_name' WHERE code = '$code'";
$db->query($sql);
}
else
{
sys_msg(sprintf($_LANG['msg_upload_failed'], $file['name'], $file_var_list[$code]['store_dir']));
}
}
}
}
/* 处理发票类型及税率 */
if (!empty($_POST['invoice_rate']))
{
foreach ($_POST['invoice_rate'] as $key => $rate)
{
$rate = round(floatval($rate), 2);
if ($rate < 0)
{
$rate = 0;
}
$_POST['invoice_rate'][$key] = $rate;
}
$invoice = array(
'type' => $_POST['invoice_type'],
'rate' => $_POST['invoice_rate']
);
$sql = "UPDATE " . $ecs->table('shop_config') . " SET value = '" . serialize($invoice) . "' WHERE code = 'invoice_type'";
$db->query($sql);
}
/* 记录日志 */
admin_log('', 'edit', 'shop_config');
/* 清除缓存 */
clear_all_files();
$_CFG = load_config();
// $shop_country = $db->getOne("SELECT region_name FROM ".$ecs->table('region')." WHERE region_id='$_CFG[shop_country]'");
// $shop_province = $db->getOne("SELECT region_name FROM ".$ecs->table('region')." WHERE region_id='$_CFG[shop_province]'");
// $shop_city = $db->getOne("SELECT region_name FROM ".$ecs->table('region')." WHERE region_id='$_CFG[shop_city]'");
$spt = '<script type="text/javascript" src="http://api.ecshop.com/record.php?';
$spt .= "url=" .urlencode($ecs->url());
$spt .= "&shop_name=" .urlencode($_CFG['shop_name']);
$spt .= "&shop_title=".urlencode($_CFG['shop_title']);
$spt .= "&shop_desc=" .urlencode($_CFG['shop_desc']);
$spt .= "&shop_keywords=" .urlencode($_CFG['shop_keywords']);
$spt .= "&country=".urlencode($shop_country)."&province=".urlencode($shop_province)."&city=".urlencode($shop_city);
$spt .= "&address=" .urlencode($_CFG['shop_address']);
$spt .= "&qq=$_CFG[qq]&ww=$_CFG[ww]&ym=$_CFG[ym]&msn=$_CFG[msn]";
$spt .= "&email=$_CFG[service_email]&phone=$_CFG[service_phone]&icp=".urlencode($_CFG['icp_number']);
$spt .= "&version=".VERSION."&language=$_CFG[lang]&php_ver=" .PHP_VERSION. "&mysql_ver=" .$db->version();
$spt .= "&charset=".EC_CHARSET;
$spt .= '"></script>';
if ($type == 'mail_setting')
{
$links[] = array('text' => $_LANG['back_mail_settings'], 'href' => 'shop_config.php?act=mail_settings');
sys_msg($_LANG['mail_save_success'].$spt, 0, $links);
}
else
{
$links[] = array('text' => $_LANG['back_shop_config'], 'href' => 'shop_config.php?act=list_edit');
sys_msg($_LANG['save_success'].$spt, 0, $links);
}
}
/*------------------------------------------------------ */
//-- 发送测试邮件
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'send_test_email')
{
/* 检查权限 */
check_authz_json('shop_config');
/* 取得参数 */
$email = trim($_POST['email']);
/* 更新配置 */
$_CFG['mail_service'] = intval($_POST['mail_service']);
$_CFG['smtp_host'] = trim($_POST['smtp_host']);
$_CFG['smtp_port'] = trim($_POST['smtp_port']);
$_CFG['smtp_user'] = json_str_iconv(trim($_POST['smtp_user']));
$_CFG['smtp_pass'] = trim($_POST['smtp_pass']);
$_CFG['smtp_mail'] = trim($_POST['reply_email']);
$_CFG['mail_charset'] = trim($_POST['mail_charset']);
if (send_mail('', $email, $_LANG['test_mail_title'], $_LANG['cfg_name']['email_content'], 0))
{
make_json_result('', $_LANG['sendemail_success'] . $email);
}
else
{
make_json_error(join("\n", $err->_message));
}
}
/*------------------------------------------------------ */
//-- 删除上传文件
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'del')
{
/* 检查权限 */
check_authz_json('shop_config');
/* 取得参数 */
$code = trim($_GET['code']);
$filename = $_CFG[$code];
//删除文件
@unlink($filename);
//更新设置
update_configure($code, '');
/* 记录日志 */
admin_log('', 'edit', 'shop_config');
/* 清除缓存 */
clear_all_files();
sys_msg($_LANG['save_success'], 0);
}
/**
* 设置系统设置
*
* @param string $key
* @param string $val
*
* @return boolean
*/
function update_configure($key, $val='')
{
if (!empty($key))
{
$sql = "UPDATE " . $GLOBALS['ecs']->table('shop_config') . " SET value='$val' WHERE code='$key'";
return $GLOBALS['db']->query($sql);
}
return true;
}
/**
* 获得设置信息
*
* @param array $groups 需要获得的设置组
* @param array $excludes 不需要获得的设置组
*
* @return array
*/
function get_settings($groups=null, $excludes=null)
{
global $db, $ecs, $_LANG;
$config_groups = '';
$excludes_groups = '';
if (!empty($groups))
{
foreach ($groups AS $key=>$val)
{
$config_groups .= " AND (id='$val' OR parent_id='$val')";
}
}
if (!empty($excludes))
{
foreach ($excludes AS $key=>$val)
{
$excludes_groups .= " AND (parent_id<>'$val' AND id<>'$val')";
}
}
/* 取出全部数据:分组和变量 */
$sql = "SELECT * FROM " . $ecs->table('shop_config') .
" WHERE type<>'hidden' $config_groups $excludes_groups ORDER BY parent_id, sort_order, id";
$item_list = $db->getAll($sql);
/* 整理数据 */
$group_list = array();
foreach ($item_list AS $key => $item)
{
$pid = $item['parent_id'];
$item['name'] = isset($_LANG['cfg_name'][$item['code']]) ? $_LANG['cfg_name'][$item['code']] : $item['code'];
$item['desc'] = isset($_LANG['cfg_desc'][$item['code']]) ? $_LANG['cfg_desc'][$item['code']] : '';
if ($item['code'] == 'sms_shop_mobile')
{
$item['url'] = 1;
}
if ($pid == 0)
{
/* 分组 */
if ($item['type'] == 'group')
{
$group_list[$item['id']] = $item;
}
}
else
{
/* 变量 */
if (isset($group_list[$pid]))
{
if ($item['store_range'])
{
$item['store_options'] = explode(',', $item['store_range']);
foreach ($item['store_options'] AS $k => $v)
{
$item['display_options'][$k] = isset($_LANG['cfg_range'][$item['code']][$v]) ?
$_LANG['cfg_range'][$item['code']][$v] : $v;
}
}
$group_list[$pid]['vars'][] = $item;
}
}
}
return $group_list;
}
?>