/** * 模板安装 */ public function install() { $tpl_name = I('get.tpl_name'); $tpl_fg = I('get.tpl_fg', 0); $data['value'] = $tpl_name; $condition['code'] = 'template'; $this->model->table('touch_shop_config')->data($data)->where($condition)->update(); $data['value'] = $tpl_fg; $condition['code'] = 'stylename'; $this->model->table('touch_shop_config')->data($data)->where($condition)->update(); clear_all_files(); //清除模板编译文件 make_json_result($this->read_style_and_tpl($tpl_name, $tpl_fg), L('install_template_success')); }
/** * 编辑分类信息 */ public function edit() { if (IS_POST) { $cat_id = I('cat_id'); $cat_info = I('data'); /* 数据验证 */ $msg = Check::rule(array(array(Check::must($cat_info['cat_name']), L('catname_empty')))); /* 提示信息 */ if ($msg !== true) { $this->message($msg, NULL, 'error'); } /* 判断上级目录是否合法 */ $children = array_keys(cat_list($cat_id, 0, false)); // 获得当前分类的所有下级分类 if (in_array($cat_info['parent_id'], $children)) { $this->message(L('is_leaf_error'), NULL, 'error'); } /* 更新栏目 */ $this->cat_update($cat_id, $cat_info); /* 更新栏目图标 */ if ($_FILES['cat_image']['name']) { /* cat_image图标 */ $result = $this->ectouchUpload('cat_image', 'cat_image'); if ($result['error'] > 0) { $this->message($result['message'], NULL, 'error'); } $data['cat_image'] = substr($result['message']['cat_image']['savepath'], 2) . $result['message']['cat_image']['savename']; $this->model->table('touch_category')->data($data)->where('cat_id=' . $cat_id)->update(); } /* 清除缓存 */ clear_all_files(); $this->message(L('catedit_succed'), url('index')); } $cat_id = I('cat_id'); //查询附表信息 $result = $this->model->table('touch_category')->where('cat_id=' . $cat_id)->find(); if (empty($result)) { $data['cat_id'] = $cat_id; $this->model->table('touch_category')->data($data)->insert(); } // 查询分类信息数据 $cat_info = $this->get_cat_info($cat_id); /* 模板赋值 */ $this->assign('ur_here', L('category_edit')); $this->assign('cat_info', $cat_info); $this->assign('cat_select', cat_list(0, $cat_info['parent_id'], true)); $this->display(); }
/** * 编辑文章 */ public function edit() { $id = I('cat_id'); if (IS_POST) { $data = I('data'); //更新数据库 $touch_result = $this->model->table('touch_article_cat')->where('cat_id=' . $id)->find(); if (!empty($touch_result)) { $this->model->table('touch_article_cat')->data($data)->where('cat_id=' . $id)->update(); } clear_all_files(); $this->message(L('catedit_succed'), url('index')); } $cat = $this->model->table('touch_article_cat')->field('*')->where(array('cat_id' => $id))->find(); /* 模板赋值 */ $options = model('ArticleBase')->article_cat_list(0, $cat['parent_id'], false); $select = ''; $selected = $cat['parent_id']; foreach ($options as $var) { if ($var['cat_id'] == $id) { continue; } $select .= '<option value="' . $var['cat_id'] . '" '; $select .= ($selected == $var['cat_id']) ? "selected='ture'" : ''; $select .= '>'; if ($var['level'] > 0) { $select .= str_repeat(' ', $var['level'] * 4); } $select .= htmlspecialchars($var['cat_name']) . '</option>'; } unset($options); $this->assign('cat_select',$select ); $this->assign('cat', $cat); $this->assign('ur_here', L('articlecat_edit')); $this->display(); }
function put_affiliate($config) { $temp = serialize($config); $sql = "UPDATE " . $GLOBALS['ecs']->table('shop_config') . "SET value = '{$temp}'" . "WHERE code = 'affiliate'"; $GLOBALS['db']->query($sql); clear_all_files(); }
/** * 删除文章分类 */ public function del() { $id = I('get.cat_id'); $count = $this->model->table('touch_article_cat')->field('COUNT(*)')->where("parent_id = '{$id}'")->getOne(); if ($count > 0) { /* 还有子分类,不能删除 */ $this->message(L('is_fullcat'), url('index')); } /* 非空的分类不允许删除 */ $count = $this->model->table('touch_article')->field('COUNT(*)')->where("cat_id = '{$id}'")->getOne(); if ($count > 0) { $this->message(L('not_emptycat'), url('index')); } else { $condition['cat_id'] = $id; $this->model->table('touch_article_cat')->where($condition)->delete(); clear_all_files(); $this->message(L('drop_succeed'), url('index')); } }
/** * 删除文章 */ public function del() { $id = I('id'); $condition['article_id'] = $id; $this->model->table('touch_article')->where($condition)->delete(); clear_all_files(); $this->message(L('drop_succeed'), url('index')); }
/** * 提交订单 */ public function done() { /* 取得购物类型 */ $flow_type = isset($_SESSION['flow_type']) ? intval($_SESSION['flow_type']) : CART_GENERAL_GOODS; /* 检查购物车中是否有商品 */ $condition = " session_id = '" . SESS_ID . "' " . "AND parent_id = 0 AND is_gift = 0 AND rec_type = '{$flow_type}'"; $count = $this->model->table('cart')->field('COUNT(*)')->where($condition)->getOne(); if ($count == 0) { show_message(L('no_goods_in_cart'), '', '', 'warning'); } /* 如果使用库存,且下订单时减库存,则减少库存 */ if (C('use_storage') == '1' && C('stock_dec_time') == SDT_PLACE) { $cart_goods_stock = model('Order')->get_cart_goods(); $_cart_goods_stock = array(); foreach ($cart_goods_stock['goods_list'] as $value) { $_cart_goods_stock[$value['rec_id']] = $value['goods_number']; } model('Flow')->flow_cart_stock($_cart_goods_stock); unset($cart_goods_stock, $_cart_goods_stock); } // 检查用户是否已经登录 如果用户已经登录了则检查是否有默认的收货地址 如果没有登录则跳转到登录和注册页面 if (empty($_SESSION['direct_shopping']) && $_SESSION['user_id'] == 0) { /* 用户没有登录且没有选定匿名购物,转向到登录页面 */ ecs_header("Location: " . url('user/login') . "\n"); } // 获取收货人信息 $consignee = model('Order')->get_consignee($_SESSION['user_id']); /* 检查收货人信息是否完整 */ if (!model('Order')->check_consignee_info($consignee, $flow_type)) { /* 如果不完整则转向到收货人信息填写界面 */ ecs_header("Location: " . url('flow/consignee') . "\n"); } // 处理接收信息 $how_oos = I('post.how_oos', 0); $inv_type = I('post.inv_type', ''); $inv_payee = I('post.inv_payee', ''); $inv_content = I('post.inv_content', ''); $postscript = I('post.postscript', ''); $oos = L('oos.' . $how_oos); // 订单信息 $order = array('shipping_id' => I('post.shipping'), 'pay_id' => I('post.payment'), 'surplus' => isset($_POST['surplus']) ? floatval($_POST['surplus']) : 0.0, 'integral' => isset($_POST['integral']) ? intval($_POST['integral']) : 0, 'need_inv' => empty($_POST['need_inv']) ? 0 : 1, 'inv_type' => $_POST['inv_type'], 'inv_payee' => trim($_POST['inv_payee']), 'inv_content' => $_POST['inv_content'], 'postscript' => trim($_POST['postscript']), 'how_oos' => isset($oos) ? addslashes("{$oos}") : '', 'need_insure' => isset($_POST['need_insure']) ? intval($_POST['need_insure']) : 0, 'user_id' => $_SESSION['user_id'], 'add_time' => gmtime(), 'order_status' => OS_UNCONFIRMED, 'shipping_status' => SS_UNSHIPPED, 'pay_status' => PS_UNPAYED, 'agency_id' => model('Order')->get_agency_by_regions(array($consignee['country'], $consignee['province'], $consignee['city'], $consignee['district'])), 'mobile_order' => 1, 'mobile_pay' => 1); /* 扩展信息 */ if (isset($_SESSION['flow_type']) && intval($_SESSION['flow_type']) != CART_GENERAL_GOODS) { $order['extension_code'] = $_SESSION['extension_code']; $order['extension_id'] = $_SESSION['extension_id']; } else { $order['extension_code'] = ''; $order['extension_id'] = 0; } /* 检查积分余额是否合法 */ $user_id = $_SESSION['user_id']; if ($user_id > 0) { $user_info = model('Order')->user_info($user_id); $order['surplus'] = min($order['surplus'], $user_info['user_money'] + $user_info['credit_line']); if ($order['surplus'] < 0) { $order['surplus'] = 0; } // 查询用户有多少积分 $flow_points = model('Flow')->flow_available_points(); // 该订单允许使用的积分 $user_points = $user_info['pay_points']; // 用户的积分总数 $order['integral'] = min($order['integral'], $user_points, $flow_points); if ($order['integral'] < 0) { $order['integral'] = 0; } } else { $order['surplus'] = 0; $order['integral'] = 0; } /* 订单中的商品 */ $cart_goods = model('Order')->cart_goods($flow_type); if (empty($cart_goods)) { show_message(L('no_goods_in_cart'), L('back_home'), './', 'warning'); } /* 检查商品总额是否达到最低限购金额 */ if ($flow_type == CART_GENERAL_GOODS && model('Order')->cart_amount(true, CART_GENERAL_GOODS) < C('min_goods_amount')) { show_message(sprintf(L('goods_amount_not_enough'), price_format(C('min_goods_amount'), false))); } /* 收货人信息 */ foreach ($consignee as $key => $value) { $order[$key] = addslashes($value); } /* 判断是不是实体商品 */ foreach ($cart_goods as $val) { /* 统计实体商品的个数 */ if ($val['is_real']) { $is_real_good = 1; } } if (isset($is_real_good)) { $res = $this->model->table('shipping')->field('shipping_id')->where("shipping_id=" . $order['shipping_id'] . " AND enabled =1")->getOne(); if (!$res) { show_message(L('flow_no_shipping')); } } /* 订单中的总额 */ $total = model('Users')->order_fee($order, $cart_goods, $consignee); $order['goods_amount'] = $total['goods_price']; $order['discount'] = $total['discount']; $order['surplus'] = $total['surplus']; $order['tax'] = $total['tax']; // 购物车中的商品能享受红包支付的总额 $discount_amout = model('Order')->compute_discount_amount(); // 红包和积分最多能支付的金额为商品总额 $temp_amout = $order['goods_amount'] - $discount_amout; /* 配送方式 */ if ($order['shipping_id'] > 0) { $shipping = model('Shipping')->shipping_info($order['shipping_id']); $order['shipping_name'] = addslashes($shipping['shipping_name']); } $order['shipping_fee'] = $total['shipping_fee']; $order['insure_fee'] = $total['shipping_insure']; /* 支付方式 */ if ($order['pay_id'] > 0) { $payment = model('Order')->payment_info($order['pay_id']); $order['pay_name'] = addslashes($payment['pay_name']); } $order['pay_fee'] = $total['pay_fee']; $order['cod_fee'] = $total['cod_fee']; $order['order_amount'] = number_format($total['amount'], 2, '.', ''); /* 如果全部使用余额支付,检查余额是否足够 */ if ($payment['pay_code'] == 'balance' && $order['order_amount'] > 0) { if ($order['surplus'] > 0) { // 余额支付里如果输入了一个金额 $order['order_amount'] = $order['order_amount'] + $order['surplus']; $order['surplus'] = 0; } if ($order['order_amount'] > $user_info['user_money'] + $user_info['credit_line']) { show_message(L('balance_not_enough')); } else { $order['surplus'] = $order['order_amount']; $order['order_amount'] = 0; } } /* 如果订单金额为0(使用余额或积分或红包支付),修改订单状态为已确认、已付款 */ if ($order['order_amount'] <= 0) { $order['order_status'] = OS_CONFIRMED; $order['confirm_time'] = gmtime(); $order['pay_status'] = PS_PAYED; $order['pay_time'] = gmtime(); $order['order_amount'] = 0; } $order['integral_money'] = $total['integral_money']; $order['integral'] = $total['integral']; if ($order['extension_code'] == 'exchange_goods') { $order['integral_money'] = 0; $order['integral'] = $total['exchange_integral']; } $order['from_ad'] = !empty($_SESSION['from_ad']) ? $_SESSION['from_ad'] : '0'; $order['referer'] = !empty($_SESSION['referer']) ? addslashes($_SESSION['referer']) : ''; /* 记录扩展信息 */ if ($flow_type != CART_GENERAL_GOODS) { $order['extension_code'] = $_SESSION['extension_code']; $order['extension_id'] = $_SESSION['extension_id']; } $affiliate = unserialize(C('affiliate')); if (isset($affiliate['on']) && $affiliate['on'] == 1 && $affiliate['config']['separate_by'] == 1) { // 推荐订单分成 $parent_id = model('Users')->get_affiliate(); if ($user_id == $parent_id) { $parent_id = 0; } } elseif (isset($affiliate['on']) && $affiliate['on'] == 1 && $affiliate['config']['separate_by'] == 0) { // 推荐注册分成 $parent_id = 0; } else { // 分成功能关闭 $parent_id = 0; } $order['parent_id'] = $parent_id; //分销 start $parent_id = model('Sale')->get_parent_id($parent_id); $order['parent_id'] = $parent_id; /* 插入订单表 */ $error_no = 0; do { $order['order_sn'] = get_order_sn(); // 获取新订单号 $new_order = model('Common')->filter_field('order_info', $order); $this->model->table('order_info')->data($new_order)->insert(); $error_no = M()->errno(); if ($error_no > 0 && $error_no != 1062) { die(M()->errorMsg()); } } while ($error_no == 1062); // 如果是订单号重复则重新提交数据 $new_order_id = M()->insert_id(); $order['order_id'] = $new_order_id; /* 插入订单商品 */ $sql = "INSERT INTO " . $this->model->pre . "order_goods( " . "order_id, goods_id, goods_name, goods_sn, product_id, goods_number, market_price, " . "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id) " . " SELECT '{$new_order_id}', goods_id, goods_name, goods_sn, product_id, goods_number, market_price, " . "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id" . " FROM " . $this->model->pre . "cart WHERE session_id = '" . SESS_ID . "' AND rec_type = '{$flow_type}'"; $this->model->query($sql); /* 处理余额、积分、红包 */ if ($order['user_id'] > 0 && $order['surplus'] > 0) { model('ClipsBase')->log_account_change($order['user_id'], $order['surplus'] * -1, 0, 0, 0, sprintf(L('pay_order'), $order['order_sn'])); } if ($order['user_id'] > 0 && $order['integral'] > 0) { model('ClipsBase')->log_account_change($order['user_id'], 0, 0, 0, $order['integral'] * -1, sprintf(L('pay_order'), $order['order_sn'])); } /* 如果使用库存,且下订单时减库存,则减少库存 */ if (C('use_storage') == '1' && C('stock_dec_time') == SDT_PLACE) { model('Order')->change_order_goods_storage($order['order_id'], true, SDT_PLACE); } /* 给商家发邮件 */ /* 增加是否给客服发送邮件选项 */ if (C('send_service_email') && C('service_email') != '') { $tpl = model('Base')->get_mail_template('remind_of_new_order'); $this->assign('order', $order); $this->assign('goods_list', $cart_goods); $this->assign('shop_name', C('shop_name')); $this->assign('send_date', date(C('time_format'))); $content = ECTouch::$view->fetch('str:' . $tpl['template_content']); send_mail(C('shop_name'), C('service_email'), $tpl['template_subject'], $content, $tpl['is_html']); } /* 如果需要,发短信 */ if (C('sms_order_placed') == '1' && C('sms_shop_mobile') != '') { $sms = new EcsSms(); $msg = $order['pay_status'] == PS_UNPAYED ? L('order_placed_sms') : L('order_placed_sms') . '[' . L('sms_paid') . ']'; $sms->send(C('sms_shop_mobile'), sprintf($msg, $order['consignee'], $order['mobile']), '', 13, 1); } /* 如果需要,微信通知 by wanglu */ if (method_exists('WechatController', 'do_oauth')) { $order_url = __HOST__ . url('user/order_detail', array('order_id' => $order['order_id'])); $order_url = urlencode(base64_encode($order_url)); send_wechat_message('order_remind', '', $order['order_sn'] . L('order_effective'), $order_url, $order['order_sn']); } /* 如果订单金额为0 处理虚拟卡 */ if ($order['order_amount'] <= 0) { $sql = "SELECT goods_id, goods_name, goods_number AS num FROM " . $this->model->pre . "cart WHERE is_real = 0 AND extension_code = 'virtual_card'" . " AND session_id = '" . SESS_ID . "' AND rec_type = '{$flow_type}'"; $res = $this->model->query($sql); $virtual_goods = array(); foreach ($res as $row) { $virtual_goods['virtual_card'][] = array('goods_id' => $row['goods_id'], 'goods_name' => $row['goods_name'], 'num' => $row['num']); } if ($virtual_goods) { /* 虚拟卡发货 */ if (model('OrderBase')->virtual_goods_ship($virtual_goods, $msg, $order['order_sn'], true)) { /* 如果没有实体商品,修改发货状态,送积分和红包 */ $count = $this->model->table('order_goods')->field('COUNT(*)')->where("order_id = '{$order['order_id']}' " . " AND is_real = 1")->getOne(); if ($count <= 0) { /* 修改订单状态 */ model('Users')->update_order($order['order_id'], array('shipping_status' => SS_SHIPPED, 'shipping_time' => gmtime())); /* 如果订单用户不为空,计算积分,并发给用户;发红包 */ if ($order['user_id'] > 0) { /* 取得用户信息 */ $user = model('Order')->user_info($order['user_id']); /* 计算并发放积分 */ $integral = model('Order')->integral_to_give($order); model('ClipsBase')->log_account_change($order['user_id'], 0, 0, intval($integral['rank_points']), intval($integral['custom_points']), sprintf(L('order_gift_integral'), $order['order_sn'])); } } } } } // 销量 model('Flow')->add_touch_goods($flow_type, $order['extension_code']); /* 记录供应商信息 */ $sql = "update " . $this->model->pre . "order_goods og , " . $this->model->pre . "goods g set og.suppliers_id=g.suppliers_id\r\n where og.goods_id=g.goods_id and og.order_id='" . $order['order_id'] . "'"; $this->model->query($sql); /* 清空购物车 */ model('Order')->clear_cart($flow_type); /* 清除缓存,否则买了商品,但是前台页面读取缓存,商品数量不减少 */ clear_all_files(); /* 插入支付日志 */ $order['log_id'] = model('ClipsBase')->insert_pay_log($new_order_id, $order['order_amount'], PAY_ORDER); /* 取得支付信息,生成支付代码 */ if ($order['order_amount'] > 0) { $payment = model('Order')->payment_info($order['pay_id']); include_once ROOT_PATH . 'plugins/payment/' . $payment['pay_code'] . '.php'; $pay_obj = new $payment['pay_code'](); $pay_online = $pay_obj->get_code($order, unserialize_config($payment['pay_config'])); $order['pay_desc'] = $payment['pay_desc']; $this->assign('pay_online', $pay_online); } if (!empty($order['shipping_name'])) { $order['shipping_name'] = trim(stripcslashes($order['shipping_name'])); } // 货到付款不显示 if ($payment['pay_code'] != 'balance') { /* 生成订单后,修改支付,配送方式 */ // 支付方式 $payment_list = model('Order')->available_payment_list(0); if (isset($payment_list)) { foreach ($payment_list as $key => $payment) { /* 如果有易宝神州行支付 如果订单金额大于300 则不显示 */ if ($payment['pay_code'] == 'yeepayszx' && $total['amount'] > 300) { unset($payment_list[$key]); } // 过滤掉当前的支付方式 if ($payment['pay_id'] == $order['pay_id']) { unset($payment_list[$key]); } /* 如果有余额支付 */ if ($payment['pay_code'] == 'balance') { /* 如果未登录,不显示 */ if ($_SESSION['user_id'] == 0) { unset($payment_list[$key]); } else { if ($_SESSION['flow_order']['pay_id'] == $payment['pay_id']) { $this->assign('disable_surplus', 1); } } } // 如果不是微信浏览器访问并且不是微信会员 则不显示微信支付 if ($payment['pay_code'] == 'wxpay' && !is_wechat_browser() && empty($_SESSION['openid'])) { unset($payment_list[$key]); } // 兼容过滤ecjia支付方式 if (substr($payment['pay_code'], 0, 4) == 'pay_') { unset($payment_list[$key]); } } } $this->assign('payment_list', $payment_list); $this->assign('pay_code', 'no_balance'); } // 如果是银行汇款或货到付款 则显示支付描述 if ($payment['pay_code'] == 'bank' || $payment['pay_code'] == 'cod') { if (empty($order['pay_name'])) { $order['pay_name'] = trim(stripcslashes($payment['pay_name'])); } $this->assign('pay_desc', $order['pay_desc']); } /* 订单信息 */ $this->assign('order', $order); $this->assign('total', $total); $this->assign('goods_list', $cart_goods); $this->assign('order_submit_back', sprintf(L('order_submit_back'), L('back_home'), L('goto_user_center'))); // 返回提示 user_uc_call('add_feed', array($order['order_id'], BUY_GOODS)); // 推送feed到uc unset($_SESSION['flow_consignee']); // 清除session中保存的收货人信息 unset($_SESSION['flow_order']); unset($_SESSION['direct_shopping']); $this->assign('currency_format', C('currency_format')); $this->assign('integral_scale', C('integral_scale')); $this->assign('step', ACTION_NAME); $this->assign('title', L('order_submit')); $this->display('flow.dwt'); }
public function clearCache() { clear_all_files(); $this->message(L('caches_cleared')); }
/** * 删除上传文件 */ public function del() { /* 取得参数 */ $code = I('code'); $filename = C($code); //删除文件 @unlink($filename); //更新设置 $this->update_configure($code, ''); /* 清除缓存 */ clear_all_files(); $this->message(L('save_success')); }
function action_post() { $user = $GLOBALS['user']; $_CFG = $GLOBALS['_CFG']; $_LANG = $GLOBALS['_LANG']; $smarty = $GLOBALS['smarty']; $db = $GLOBALS['db']; $ecs = $GLOBALS['ecs']; $user_id = $_SESSION['user_id']; $chat_keys = $GLOBALS['chat_keys']; // 检查shop_config $sql = "select * from " . $ecs->table("shop_config") . " where code = 'chat'"; $row = $db->getRow($sql, true); if ($row == false) { $sql = "select max(parent_id) from " . $ecs->table("shop_config") . ""; $parent_id = $db->getOne($sql) + 1; $chat = array("id" => $parent_id, "code" => "chat", "parent_id" => 0, "type" => "group", "value" => ""); $db->autoExecute($ecs->table('shop_config'), $chat, 'INSERT'); } else { $parent_id = $row['id']; } $chat_server_ip = empty($_POST['chat_server_ip']) ? '' : $_POST['chat_server_ip']; $chat_server_port = empty($_POST['chat_server_port']) ? '9090' : $_POST['chat_server_port']; $chat_http_bind_port = empty($_POST['chat_http_bind_port']) ? '7070' : $_POST['chat_http_bind_port']; $chat_server_admin_username = empty($_POST['chat_server_admin_username']) ? 'admin' : $_POST['chat_server_admin_username']; $chat_server_admin_password = $_POST['chat_server_admin_password']; $chat = array("chat_server_ip" => $chat_server_ip, "chat_server_port" => $chat_server_port, "chat_http_bind_port" => $chat_http_bind_port, "chat_server_admin_username" => $chat_server_admin_username); if (!empty($chat_server_admin_password)) { $chat['chat_server_admin_password'] = $chat_server_admin_password; } $sql = "select * from " . $ecs->table("shop_config") . " where parent_id = '" . $parent_id . "'"; $rows = $db->getAll($sql); $records = array(); foreach ($rows as $row) { $key = $row['code']; $value = $row['value']; $records[$key] = $row; } foreach ($chat as $key => $value) { if ($key == 'chat_server_admin_password') { $record = array("code" => $key, "value" => $value, "type" => "password", "parent_id" => $parent_id); } else { $record = array("code" => $key, "value" => $value, "type" => "text", "parent_id" => $parent_id); } if (isset($records[$key])) { $id = $records[$key]['id']; if ($value != $records[$key]['value']) { $db->autoExecute($ecs->table('shop_config'), $record, 'UPDATE', "id = '{$id}'"); } } else { $db->autoExecute($ecs->table('shop_config'), $record, 'INSERT', "parent_id = '{$parent_id}'"); } } /* 清除缓存 */ clear_all_files(); $_CFG = load_config(); /* 提示信息 */ $links = array(array('href' => 'chat_settings.php', 'text' => "返回上一页")); sys_msg("修改聊天服务设置成功!", 0, $links); }
public function done () { global $ecs,$db,$_CFG; include_once(RPC_ROOT.'includes/lib_clips_ec.php'); include_once(RPC_ROOT.'includes/lib_payment.php'); /* 取得购物类型 */ $flow_type = isset($_SESSION['flow_type']) ? intval($_SESSION['flow_type']) : CART_GENERAL_GOODS; /* 检查购物车中是否有商品 */ $sql = "SELECT COUNT(*) FROM " . $ecs->table('cart') ." WHERE session_id = '" . SESS_ID . "' " . "AND parent_id = 0 AND is_gift = 0 AND rec_type = '$flow_type'"; if ($db->getOne($sql) == 0) { $msg = rpcLang('flow.php', 'no_goods_in_cart'); jsonExit("{\"status\":\"$msg\"}"); } /* 检查商品库存,如果使用库存,且下订单时减库存,则减少库存 */ if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE) { $cart_goods_stock = get_cart_goods(); $_cart_goods_stock = array(); foreach ($cart_goods_stock['goods_list'] as $value) { $_cart_goods_stock[$value['rec_id']] = $value['goods_number']; } zy_flow_cart_stock($_cart_goods_stock); unset($cart_goods_stock, $_cart_goods_stock); } /* * 检查用户是否已经登录 * 如果用户已经登录了则检查是否有默认的收货地址 * 如果没有登录则跳转到登录和注册页面 */ if (empty($_SESSION['direct_shopping']) && $_SESSION['user_id'] == 0) { /* 用户没有登录且没有选定匿名购物,转向到登录页面 */ $msg = rpcLang('user.php', 'nologin'); jsonExit("{\"status\":\"$msg\"}"); } $consignee = get_consignee($_SESSION['user_id']); /* 检查收货人信息是否完整 */ if (!check_consignee_info($consignee, $flow_type)) { $msg = rpcLang('flow.php', 'user_address_not_full'); jsonExit("{\"status\":\"$msg\"}"); } $_GET['how_oos'] = isset($_GET['how_oos']) ? intval($_GET['how_oos']) : 0; $_GET['card_message'] = isset($_GET['card_message']) ? htmlspecialchars($_GET['card_message']) : ''; $_GET['inv_type'] = !empty($_GET['inv_type']) ? htmlspecialchars($_GET['inv_type']) : ''; $_GET['inv_payee'] = isset($_GET['inv_payee']) ? htmlspecialchars($_GET['inv_payee']) : ''; $_GET['inv_content'] = isset($_GET['inv_content']) ? htmlspecialchars($_GET['inv_content']) : ''; $_GET['postscript'] = isset($_GET['postscript']) ? htmlspecialchars($_GET['postscript']) : ''; $referer = empty($_GET['referer']) ? 'Android':trim($_GET['referer']); $order = array( //'shipping_id' => intval($_POST['shipping']), 'shipping_id' => intval($_GET['shipping']),//快递id 'pay_id' => intval($_GET['payment']),//支付方式id 'pack_id' => isset($_GET['pack']) ? intval($_GET['pack']) : 0,//包装 'card_id' => isset($_GET['card']) ? intval($_GET['card']) : 0,//贺卡 'card_message' => trim($_GET['card_message']), 'surplus' => isset($_POST['surplus']) ? floatval($_POST['surplus']) : 0.00, 'integral' => isset($_POST['integral']) ? intval($_POST['integral']) : 0, 'bonus_id' => isset($_GET['bonus']) ? intval($_GET['bonus']) : 0, 'need_inv' => empty($_POST['need_inv']) ? 0 : 1, 'postscript' => trim($_POST['postscript']), 'how_oos' => isset($_LANG['oos'][$_POST['how_oos']]) ? addslashes($_LANG['oos'][$_POST['how_oos']]) : '', 'need_insure' => isset($_POST['need_insure']) ? intval($_POST['need_insure']) : 0, 'user_id' => $_SESSION['user_id'], 'add_time' => gmtime(), 'order_status' => OS_UNCONFIRMED, 'shipping_status' => SS_UNSHIPPED, 'pay_status' => PS_UNPAYED, 'agency_id' => get_agency_by_regions(array($consignee['country'], $consignee['province'], $consignee['city'], $consignee['district'])) ); if(EC_CHARSET == 'utf-8'){ $order['inv_type'] = gbktoutf8($_GET['inv_type']); $order['inv_payee'] = gbktoutf8(trim($_GET['inv_payee'])); $order['inv_content'] = gbktoutf8($_GET['inv_content']); }else{ $order['inv_type'] = utf8togbk($_GET['inv_type']); $order['inv_payee'] = utf8togbk(trim($_GET['inv_payee'])); $order['inv_content'] = utf8togbk($_GET['inv_content']); } /* 扩展信息 */ if (isset($_SESSION['flow_type']) && intval($_SESSION['flow_type']) != CART_GENERAL_GOODS) { $order['extension_code'] = $_SESSION['extension_code']; $order['extension_id'] = $_SESSION['extension_id']; } else { $order['extension_code'] = ''; $order['extension_id'] = 0; } $user_id = $_SESSION['user_id']; /* #检查积分余额是否合法 $user_id = $_SESSION['user_id']; if ($user_id > 0) { $user_info = user_info($user_id); $order['surplus'] = min($order['surplus'], $user_info['user_money'] + $user_info['credit_line']); if ($order['surplus'] < 0) { $order['surplus'] = 0; } // 查询用户有多少积分 $flow_points = flow_available_points(); // 该订单允许使用的积分 $user_points = $user_info['pay_points']; // 用户的积分总数 $order['integral'] = min($order['integral'], $user_points, $flow_points); if ($order['integral'] < 0) { $order['integral'] = 0; } } else { $order['surplus'] = 0; $order['integral'] = 0; }*/ #检查红包是否存在 if ($order['bonus_id'] > 0) { $bonus = bonus_info($order['bonus_id']); if (empty($bonus) || $bonus['user_id'] != $user_id || $bonus['order_id'] > 0 || $bonus['min_goods_amount'] > cart_amount(true, $flow_type)) { $order['bonus_id'] = 0; } } elseif (isset($_POST['bonus_sn'])) { $bonus_sn = trim($_POST['bonus_sn']); $bonus = bonus_info(0, $bonus_sn); $now = gmtime(); if (empty($bonus) || $bonus['user_id'] > 0 || $bonus['order_id'] > 0 || $bonus['min_goods_amount'] > cart_amount(true, $flow_type) || $now > $bonus['use_end_date']) { } else { if ($user_id > 0) { $sql = "UPDATE " . $ecs->table('user_bonus') . " SET user_id = '$user_id' WHERE bonus_id = '$bonus[bonus_id]' LIMIT 1"; $db->query($sql); } $order['bonus_id'] = $bonus['bonus_id']; $order['bonus_sn'] = $bonus_sn; } } /* 订单中的商品 */ $cart_goods = cart_goods($flow_type); if (empty($cart_goods)) { $msg = rpcLang('flow.php', 'no_goods_in_cart'); jsonExit("{\"status\":\"$msg\"}"); } /* 检查商品总额是否达到最低限购金额 */ if ($flow_type == CART_GENERAL_GOODS && cart_amount(true, CART_GENERAL_GOODS) < $_CFG['min_goods_amount']) { $msg = rpcLang('flow.php', 'goods_amount_not_enough'); jsonExit("{\"status\":\"$msg\"}"); } /* 收货人信息 */ foreach ($consignee as $key => $value) { $order[$key] = addslashes($value); } /* 订单中的总额 */ $total = order_fee($order, $cart_goods, $consignee); $order['bonus'] = $total['bonus']; $order['goods_amount'] = $total['goods_price']; $order['discount'] = $total['discount']; $order['surplus'] = $total['surplus']; $order['tax'] = $total['tax']; #购物车中的商品能享受红包支付的总额 $discount_amout = compute_discount_amount(); #红包和积分最多能支付的金额为商品总额 $temp_amout = $order['goods_amount'] - $discount_amout; if ($temp_amout <= 0) { $order['bonus_id'] = 0; } /* 配送方式 */ if ($order['shipping_id'] > 0) { $shipping = shipping_info($order['shipping_id']); $order['shipping_name'] = addslashes($shipping['shipping_name']); } $order['shipping_fee'] = $total['shipping_fee']; $order['insure_fee'] = $total['shipping_insure']; /* 支付方式 */ if ($order['pay_id'] > 0) { $payment = payment_info($order['pay_id']); $order['pay_name'] = addslashes($payment['pay_name']); } $order['pay_fee'] = $total['pay_fee']; $order['cod_fee'] = $total['cod_fee']; /* 商品包装 */ if ($order['pack_id'] > 0) { $pack = pack_info($order['pack_id']); $order['pack_name'] = addslashes($pack['pack_name']); } $order['pack_fee'] = $total['pack_fee']; /* 祝福贺卡 */ if ($order['card_id'] > 0) { $card = card_info($order['card_id']); $order['card_name'] = addslashes($card['card_name']); } $order['card_fee'] = $total['card_fee']; $order['order_amount'] = number_format($total['amount'], 2, '.', ''); /* 如果全部使用余额支付,检查余额是否足够 */ if ($payment['pay_code'] == 'balance' && $order['order_amount'] > 0) { if($order['surplus'] >0) //余额支付里如果输入了一个金额 { $order['order_amount'] = $order['order_amount'] + $order['surplus']; $order['surplus'] = 0; } if ($order['order_amount'] > ($user_info['user_money'] + $user_info['credit_line'])) { show_message($_LANG['balance_not_enough']); } else { $order['surplus'] = $order['order_amount']; $order['order_amount'] = 0; } } /* 如果订单金额为0(使用余额或积分或红包支付),修改订单状态为已确认、已付款 */ if ($order['order_amount'] <= 0) { $order['order_status'] = OS_CONFIRMED; $order['confirm_time'] = gmtime(); $order['pay_status'] = PS_PAYED; $order['pay_time'] = gmtime(); $order['order_amount'] = 0; } $order['integral_money'] = $total['integral_money']; $order['integral'] = $total['integral']; if ($order['extension_code'] == 'exchange_goods') { $order['integral_money'] = 0; $order['integral'] = $total['exchange_integral']; } $order['from_ad'] = !empty($_SESSION['from_ad']) ? $_SESSION['from_ad'] : '0'; $order['referer'] = !empty($_SESSION['referer']) ? addslashes($_SESSION['referer']) : ''; /* 记录扩展信息 */ if ($flow_type != CART_GENERAL_GOODS) { $order['extension_code'] = $_SESSION['extension_code']; $order['extension_id'] = $_SESSION['extension_id']; } $affiliate = unserialize($_CFG['affiliate']); if(isset($affiliate['on']) && $affiliate['on'] == 1 && $affiliate['config']['separate_by'] == 1) { //推荐订单分成 $parent_id = get_affiliate(); if($user_id == $parent_id) { $parent_id = 0; } } elseif(isset($affiliate['on']) && $affiliate['on'] == 1 && $affiliate['config']['separate_by'] == 0) { //推荐注册分成 $parent_id = 0; } else { //分成功能关闭 $parent_id = 0; } $order['parent_id'] = $parent_id; /* 插入订单表 */ $error_no = 0; do { $order['order_sn'] = get_order_sn(); //获取新订单号 $GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_info'), $order, 'INSERT'); $error_no = $GLOBALS['db']->errno(); if ($error_no > 0 && $error_no != 1062) { die($GLOBALS['db']->errorMsg()); } } while ($error_no == 1062); //如果是订单号重复则重新提交数据 $new_order_id = $db->insert_id(); $order['order_id'] = $new_order_id; /* 插入订单商品 */ $sql = "INSERT INTO " . $ecs->table('order_goods') . "( " . "order_id, goods_id, goods_name, goods_sn, goods_number, market_price, ". "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id) ". " SELECT '$new_order_id', goods_id, goods_name, goods_sn, goods_number, market_price, ". "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id". " FROM " .$ecs->table('cart') . " WHERE session_id = '".SESS_ID."' AND rec_type = '$flow_type'"; $db->query($sql); /* 修改拍卖活动状态 */ if ($order['extension_code']=='auction') { $sql = "UPDATE ". $ecs->table('goods_activity') ." SET is_finished='2' WHERE act_id=".$order['extension_id']; $db->query($sql); } /* 处理余额、积分、红包 */ if ($order['user_id'] > 0 && $order['surplus'] > 0) { log_account_change($order['user_id'], $order['surplus'] * (-1), 0, 0, 0, sprintf($_LANG['pay_order'], $order['order_sn'])); } if ($order['user_id'] > 0 && $order['integral'] > 0) { log_account_change($order['user_id'], 0, 0, 0, $order['integral'] * (-1), sprintf($_LANG['pay_order'], $order['order_sn'])); } if ($order['bonus_id'] > 0 && $temp_amout > 0) { use_bonus($order['bonus_id'], $new_order_id); } /* 如果使用库存,且下订单时减库存,则减少库存 */ if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE) { //change_order_goods_storage($order['order_id'], true, SDT_PLACE); } error_log('1',3,'flow.log'); /* 给商家发邮件 */ /* 增加是否给客服发送邮件选项 */ if ($_CFG['send_service_email'] && $_CFG['service_email'] != '') { error_log('2',3,'flow.log'); $tpl = get_mail_template('remind_of_new_order'); /* $smarty->assign('order', $order); $smarty->assign('goods_list', $cart_goods); $smarty->assign('shop_name', $_CFG['shop_name']); $smarty->assign('send_date', date($_CFG['time_format'])); $content = $smarty->fetch('str:' . $tpl['template_content']); */ send_mail($_CFG['shop_name'], $_CFG['service_email'], $tpl['template_subject'], $content, $tpl['is_html']); } error_log('2',3,'flow.log'); /* 如果需要,发短信 */ if ($_CFG['sms_order_placed'] == '1' && $_CFG['sms_shop_mobile'] != '') { include_once(RPC_ROOT.'includes/cls_sms.php'); $sms = new sms(); $msg = $order['pay_status'] == PS_UNPAYED ? $_LANG['order_placed_sms'] : $_LANG['order_placed_sms'] . '[' . $_LANG['sms_paid'] . ']'; $sms->send($_CFG['sms_shop_mobile'], sprintf($msg, $order['consignee'], $order['tel']), 0); } error_log('3',3,'flow.log'); /* 如果订单金额为0 处理虚拟卡 */ if ($order['order_amount'] <= 0) { $sql = " SELECT goods_id, goods_name, goods_number AS num FROM ".$GLOBALS['ecs']->table('cart') . " WHERE is_real = 0 AND extension_code = 'virtual_card'". " AND session_id = '".SESS_ID."' AND rec_type = '$flow_type'"; $res = $GLOBALS['db']->getAll($sql); error_log('4',3,'flow.log'); $virtual_goods = array(); foreach ($res AS $row) { $virtual_goods['virtual_card'][] = array('goods_id' => $row['goods_id'], 'goods_name' => $row['goods_name'], 'num' => $row['num']); } if ($virtual_goods AND $flow_type != CART_GROUP_BUY_GOODS) { /* 虚拟卡发货 */ if (virtual_goods_ship($virtual_goods,$msg, $order['order_sn'], true)) { /* 如果没有实体商品,修改发货状态,送积分和红包 */ $sql = "SELECT COUNT(*)" . " FROM " . $ecs->table('order_goods') . " WHERE order_id = '$order[order_id]' " . " AND is_real = 1"; if ($db->getOne($sql) <= 0) { /* 修改订单状态 */ update_order($order['order_id'], array('shipping_status' => SS_SHIPPED, 'shipping_time' => gmtime())); error_log('5',3,'flow.log'); /* 如果订单用户不为空,计算积分,并发给用户;发红包 */ if ($order['user_id'] > 0) { /* 取得用户信息 */ $user = user_info($order['user_id']); /* 计算并发放积分 */ $integral = integral_to_give($order); log_account_change($order['user_id'], 0, 0, intval($integral['rank_points']), intval($integral['custom_points']), sprintf($_LANG['order_gift_integral'], $order['order_sn'])); error_log('6',3,'flow.log'); /* 发放红包 */ send_order_bonus($order['order_id']); } } } } } /* 清空购物车 */ clear_cart($flow_type); error_log('7',3,'flow.log'); /* 清除缓存,否则买了商品,但是前台页面读取缓存,商品数量不减少 */ clear_all_files(); /* 插入支付日志 */ //$order['log_id'] = insert_pay_log($new_order_id, $order['order_amount'], PAY_ORDER); error_log('8',3,'flow.log'); /*取得支付代码 #取得支付信息,生成支付代码 if ($order['order_amount'] > 0) { $payment = payment_info($order['pay_id']); include_once('includes/modules/payment/' . $payment['pay_code'] . '.php'); $pay_obj = new $payment['pay_code']; $pay_online = $pay_obj->get_code($order, unserialize_config($payment['pay_config'])); $order['pay_desc'] = $payment['pay_desc']; $smarty->assign('pay_online', $pay_online); } */ if(!empty($order['shipping_name'])) { $order['shipping_name']=trim(stripcslashes($order['shipping_name'])); } error_log('9',3,'flow.log'); /* #订单信息 $smarty->assign('order', $order); $smarty->assign('total', $total); $smarty->assign('goods_list', $cart_goods); $smarty->assign('order_submit_back', sprintf($_LANG['order_submit_back'], $_LANG['back_home'], $_LANG['goto_user_center'])); // 返回提示 */ //user_uc_call('add_feed', array($order['order_id'], BUY_GOODS)); //推送feed到uc unset($_SESSION['flow_consignee']); // 清除session中保存的收货人信息 unset($_SESSION['flow_order']); unset($_SESSION['direct_shopping']); $order_done = array('order'=>$order,'total'=>$total,'cart_goods'=>$cart_goods); //var_dump($order_done);exit; error_log('10',3,'flow.log'); $order_id = $order['order_id']; $price = $order['order_amount']; $order = array ('order_id'=>$order_id,'order_number'=>$order['order_sn'],'price'=>$price) ; error_log('11',3,'flow.log'); //print_r($order);die; jsonExit($order); }
if ($_REQUEST['act'] == 'install') { check_authz_json('backup_setting'); $tpl_name = trim($_GET['tpl_name']); $tpl_fg=0; $tpl_fg = trim($_GET['tpl_fg']); $sql = "UPDATE " .$GLOBALS['ecs']->table('ecsmart_shop_config',1). " SET value = '$tpl_name' WHERE code = 'template'"; $step_one = $db->query($sql, 'SILENT'); $sql = "UPDATE " .$GLOBALS['ecs']->table('ecsmart_shop_config',1). " SET value = '$tpl_fg' WHERE code = 'stylename'"; $step_two = $db->query($sql, 'SILENT'); if ($step_one && $step_two) { clear_all_files(); //清除模板编译文件 $error_msg = ''; if (move_plugin_library($tpl_name, $error_msg)) { make_json_error($error_msg); } else { make_json_result(read_style_and_tpl($tpl_name, $tpl_fg), $_LANG['install_template_success']); } } else { make_json_error($db->error()); }
function put_affiliate($temp) { $sql = "UPDATE " . $GLOBALS['ecs']->table('shop_config') . "SET value = '{$temp}'" . "WHERE code = 'compensate_instal'"; $GLOBALS['db']->query($sql); clear_all_files(); }
/** * 删除专题 */ public function del() { $id = I('id'); if (!$id) { $this->redirect(url('index')); } /* 删除该品牌的图标 */ $topic = $this->model->table('touch_topic')->field('*')->where('topic_id = ' . $id)->find(); $topic_img = $topic['topic_img']; $title_pic = $topic['title_pic']; $intro = html_out($topic['intro']); //删除编辑器中的附件 $match = array(); preg_match_all("/(src|href)\\=\"\\/(.*?)\"/i", $intro, $match); if (is_array($match[2])) { foreach ($match[2] as $vo) { $index = strpos($vo, 'data/'); @unlink(ROOT_PATH . substr($vo, $index)); } } //删除logo if (!empty($topic_img)) { $index = strpos($topic_img, 'data/'); @unlink(ROOT_PATH . substr($topic_img, $index)); } //删除分类图标 if (!empty($title_pic)) { $index = strpos($title_pic, 'data/'); @unlink(ROOT_PATH . substr($title_pic, $index)); } //删除品牌 $this->model->table('touch_topic')->where(array('topic_id' => $id))->delete(); clear_all_files(); $this->message(L('succed'), url('index')); }
/** * 删除品牌 */ public function del() { $id = I('id'); /* 删除该品牌的图标 */ $sql = "SELECT a.brand_logo,b.brand_banner,b.brand_content FROM " . $this->model->pre . "brand as a left join " . $this->model->pre . "touch_brand as b on a.brand_id = b.brand_id WHERE a.brand_id = '$id'"; $result = $this->model->query($sql); $brand_logo = $result[0]['brand_logo']; $brand_banner = $result[0]['brand_banner']; $brand_content = html_out($result[0]['brand_content']); //删除编辑器中的附件 preg_match_all("/(src|href)\=\"\/(.*?)\"/i", $brand_content, $match); if (is_array($match[2])) { foreach ($match[2] as $vo) { $index = strpos($vo, 'data/'); @unlink(ROOT_PATH . substr($vo, $index)); } } //删除logo if (!empty($brand_logo)) { $index = strpos($brand_logo, 'data/'); @unlink(ROOT_PATH . substr($brand_logo, $index)); } //删除广告位 if (!empty($brand_banner)) { $index = strpos($brand_banner, 'data/'); @unlink(ROOT_PATH . substr($brand_banner, $index)); } //更新商品的品牌编号 $this->model->table('goods')->data('brand_id=0')->where('brand_id=' . $id)->update(); //删除品牌 $condition['brand_id'] = $id; $this->model->table('brand')->where($condition)->delete(); $this->model->table('touch_brand')->where($condition)->delete(); clear_all_files(); $this->message(L('drop_succeed'), url('index')); }
/** * 删除菜单 */ public function del() { $condition['id'] = I('id'); $this->model->table('touch_nav')->where($condition)->delete(); clear_all_files(); $this->message(L('edit_ok'), url('index')); }
/** * 删除广告 */ public function ad_del() { $id = I('get.id'); //删除广告 $condition['ad_id'] = $id; //得到广告的图片路径 删除 $img = $this->get_ad_code($id); //排除远程图片 if (strpos($img, 'http://') === false && strpos($img, 'https://') === false) { $filename = __URL__ . $img; @unlink($filename); } $this->model->table('touch_ad')->where($condition)->delete(); clear_all_files(); $this->message(L('drop_ad_succeed'), url('index')); }
/* 安装,检查该支付方式是否曾经安装过 */ $sql = "SELECT COUNT(*) FROM " . $ecs->table('payment') . " WHERE pay_code = '{$payment}'"; if ($db->GetOne($sql) > 0) { $sql = "UPDATE " . $ecs->table('payment') . " SET pay_config = '{$pay_config}'," . " enabled = '1' " . "WHERE pay_code = '{$payment}' LIMIT 1"; $db->query($sql); } else { // $modules = read_modules('../includes/modules/payment'); $payment_info = array(); $payment_info['name'] = $_LANG[$modules[0]['code']]; $payment_info['pay_fee'] = empty($modules[0]['pay_fee']) ? 0 : $modules[0]['pay_fee']; $payment_info['desc'] = $_LANG[$modules[0]['desc']]; $sql = "INSERT INTO " . $ecs->table('payment') . " (pay_code, pay_name, pay_desc, pay_config, is_cod, pay_fee, enabled, is_online)" . "VALUES ('{$payment}', '{$payment_info['name']}', '{$payment_info['desc']}', '{$pay_config}', '0', '{$payment_info['pay_fee']}', '1', '1')"; $db->query($sql); } } clear_all_files(); assign_query_info(); $smarty->assign('ur_here', $_LANG['ur_add']); $smarty->display('setting_second.htm'); } elseif ($_REQUEST['act'] == 'third') { admin_priv('goods_manage'); $good_name = empty($_POST['good_name']) ? '' : $_POST['good_name']; $good_number = empty($_POST['good_number']) ? '' : $_POST['good_number']; $good_category = empty($_POST['good_category']) ? '' : $_POST['good_category']; $good_brand = empty($_POST['good_brand']) ? '' : $_POST['good_brand']; $good_price = empty($_POST['good_price']) ? 0 : $_POST['good_price']; $good_name = empty($_POST['good_name']) ? '' : $_POST['good_name']; $is_best = empty($_POST['is_best']) ? 0 : 1; $is_new = empty($_POST['is_new']) ? 0 : 1; $is_hot = empty($_POST['is_hot']) ? 0 : 1; $good_brief = empty($_POST['good_brief']) ? '' : $_POST['good_brief'];
/** * 提交订单 */ public function done_receive() { $sn_id = I('post.gift_sn'); if (!$sn_id) { ecs_header("Location: " . url('receive/receive_fail') . "\n"); } /* 取得购物类型 */ $flow_type = CART_RECEIVE_GIFTS; /* 检查购物车中是否有商品 */ $condition = " session_id = '" . SESS_ID . "' " . "AND parent_id = 0 AND is_gift = 0 AND rec_type = '{$flow_type}'"; $count = $this->model->table('cart')->field('COUNT(*)')->where($condition)->getOne(); if ($count == 0) { show_message(L('no_goods_in_cart'), '', '', 'warning'); } /* 如果使用库存,且下订单时减库存,则减少库存 */ if (C('use_storage') == '1' && C('stock_dec_time') == SDT_PLACE) { $cart_goods_stock = model('Order')->get_cart_goods(); $_cart_goods_stock = array(); foreach ($cart_goods_stock['goods_list'] as $value) { $_cart_goods_stock[$value['rec_id']] = $value['goods_number']; } model('Flow')->flow_cart_stock($_cart_goods_stock); unset($cart_goods_stock, $_cart_goods_stock); } // 检查用户是否已经登录 如果用户已经登录了则检查是否有默认的收货地址 如果没有登录则跳转到登录和注册页面 if (empty($_SESSION['direct_shopping']) && $_SESSION['user_id'] == 0) { /* 用户没有登录且没有选定匿名购物,转向到登录页面 */ ecs_header("Location: " . url('user/login') . "\n"); } // 获取收货人信息 $consignee = model('Order')->get_consignee($_SESSION['user_id']); /* 检查收货人信息是否完整 */ if (!model('Order')->check_consignee_info($consignee, $flow_type)) { /* 如果不完整则转向到收货人信息填写界面 */ ecs_header("Location: " . url('flow/consignee') . "\n"); } // 处理接收信息 $how_oos = I('post.how_oos', 0); $oos = L('oos.' . $how_oos); // 订单信息 $order = array('shipping_id' => I('post.shipping'), 'pay_id' => I('post.payment'), 'surplus' => isset($_POST['surplus']) ? floatval($_POST['surplus']) : 0.0, 'integral' => isset($_POST['integral']) ? intval($_POST['integral']) : 0, 'need_inv' => empty($_POST['need_inv']) ? 0 : 1, 'inv_type' => $_POST['inv_type'], 'inv_payee' => trim($_POST['inv_payee']), 'inv_content' => $_POST['inv_content'], 'postscript' => trim($_POST['postscript']), 'how_oos' => isset($oos) ? addslashes("{$oos}") : '', 'need_insure' => isset($_POST['need_insure']) ? intval($_POST['need_insure']) : 0, 'user_id' => $_SESSION['user_id'], 'add_time' => gmtime(), 'order_status' => OS_UNCONFIRMED, 'shipping_status' => SS_UNSHIPPED, 'pay_status' => PS_UNPAYED, 'agency_id' => model('Order')->get_agency_by_regions(array($consignee['country'], $consignee['province'], $consignee['city'], $consignee['district'])), 'mobile_order' => 1, 'mobile_pay' => 1); /* 扩展信息 */ if (isset($_SESSION['flow_type']) && intval($_SESSION['flow_type']) != CART_GENERAL_GOODS) { $order['extension_code'] = $_SESSION['extension_code']; $order['extension_id'] = $_SESSION['extension_id']; } else { $order['extension_code'] = ''; $order['extension_id'] = 0; } /* 订单中的商品 */ $cart_goods = model('Order')->cart_goods($flow_type); if (empty($cart_goods)) { show_message(L('no_goods_in_cart'), L('back_home'), './', 'warning'); } /* 检查商品总额是否达到最低限购金额 */ if ($flow_type == CART_GENERAL_GOODS && model('Order')->cart_amount(true, CART_GENERAL_GOODS) < C('min_goods_amount')) { show_message(sprintf(L('goods_amount_not_enough'), price_format(C('min_goods_amount'), false))); } /* 收货人信息 */ foreach ($consignee as $key => $value) { $order[$key] = addslashes($value); } /* 订单中的总额 */ $total = model('Users')->order_fee($order, $cart_goods, $consignee); $order['goods_amount'] = $total['goods_price']; $order['discount'] = $total['discount']; $order['surplus'] = $total['surplus']; $order['tax'] = $total['tax']; /* 配送方式 */ $order['shipping_fee'] = $total['shipping_fee']; $order['insure_fee'] = $total['shipping_insure']; /* 支付方式 */ $order['pay_fee'] = $total['pay_fee']; $order['cod_fee'] = $total['cod_fee']; $order['order_amount'] = number_format($total['amount'], 2, '.', ''); $order['order_amount'] = 0; /* 如果订单金额为0(使用余额或积分或红包支付),修改订单状态为已确认、已付款 */ if ($order['order_amount'] <= 0) { $order['order_status'] = OS_CONFIRMED; $order['confirm_time'] = gmtime(); $order['pay_status'] = PS_PAYED; $order['pay_time'] = gmtime(); $order['order_amount'] = 0; } $order['integral_money'] = $total['integral_money']; $order['integral'] = $total['integral']; if ($order['extension_code'] == 'exchange_goods') { $order['integral_money'] = 0; $order['integral'] = $total['exchange_integral']; } $order['from_ad'] = !empty($_SESSION['from_ad']) ? $_SESSION['from_ad'] : '0'; $order['referer'] = !empty($_SESSION['referer']) ? addslashes($_SESSION['referer']) : ''; /* 记录扩展信息 */ if ($flow_type != CART_GENERAL_GOODS) { $order['extension_code'] = $_SESSION['extension_code']; $order['extension_id'] = $_SESSION['extension_id']; } $order['parent_id'] = 0; /* 插入订单表 */ $error_no = 0; do { $order['order_sn'] = get_order_sn(); // 获取新订单号 $new_order = model('Common')->filter_field('order_info', $order); $this->model->table('order_info')->data($new_order)->insert(); $error_no = M()->errno(); if ($error_no > 0 && $error_no != 1062) { die(M()->errorMsg()); } } while ($error_no == 1062); // 如果是订单号重复则重新提交数据 $new_order_id = M()->insert_id(); $order['order_id'] = $new_order_id; /* 插入订单商品 */ $sql = "INSERT INTO " . $this->model->pre . "order_goods( " . "order_id, goods_id, goods_name, goods_sn, product_id, goods_number, market_price, " . "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id) " . " SELECT '{$new_order_id}', goods_id, goods_name, goods_sn, product_id, goods_number, market_price, " . "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id" . " FROM " . $this->model->pre . "cart WHERE session_id = '" . SESS_ID . "' AND rec_type = '{$flow_type}'"; $this->model->query($sql); /* 如果使用库存,且下订单时减库存,则减少库存 */ if (C('use_storage') == '1' && C('stock_dec_time') == SDT_PLACE) { model('Order')->change_order_goods_storage($order['order_id'], true, SDT_PLACE); } /* 减少礼包中的商品数 */ if ($cart_goods[0]['goods_number']) { model('Order')->change_gift_storage($sn_id, $cart_goods[0]['goods_number']); } /* 插入日志 */ $Gift = $this->model->table('gift_sn')->where("sn_id='" . $sn_id . "'")->find(); if ($Gift['type'] == 1) { $data_l['type'] = 3; } $data_l['type'] = 2; $data_l['sn_id'] = $sn_id; $data_l['sn'] = $Gift['sn']; $data_l['create_user_id'] = $Gift['user_id']; $data_l['receive_user_id'] = $_SESSION['user_id']; $data_l['goods_id'] = $Gift['goods_id']; $data_l['goods_name'] = $Gift['goods_name']; $data_l['count'] = $cart_goods[0]['goods_number']; $data_l['time'] = gmtime(); $data_l['order_id'] = $new_order_id; $this->model->table('gift_log')->data($data_l)->insert(); /* 给商家发邮件 */ /* 增加是否给客服发送邮件选项 */ if (C('send_service_email') && C('service_email') != '') { $tpl = model('Base')->get_mail_template('remind_of_new_order'); $this->assign('order', $order); $this->assign('goods_list', $cart_goods); $this->assign('shop_name', C('shop_name')); $this->assign('send_date', date(C('time_format'))); $content = ECTouch::$view->fetch('str:' . $tpl['template_content']); send_mail(C('shop_name'), C('service_email'), $tpl['template_subject'], $content, $tpl['is_html']); } /* 如果需要,发短信 */ if (C('sms_order_placed') == '1' && C('sms_shop_mobile') != '') { $sms = new EcsSms(); $msg = $order['pay_status'] == PS_UNPAYED ? L('order_placed_sms') : L('order_placed_sms') . '[' . L('sms_paid') . ']'; $sms->send(C('sms_shop_mobile'), sprintf($msg, $order['consignee'], $order['mobile']), '', 13, 1); } /* 如果需要,微信通知 by wanglu */ if (method_exists('WechatController', 'do_oauth')) { $order_url = __HOST__ . url('user/order_detail', array('order_id' => $order['order_id'])); $order_url = urlencode(base64_encode($order_url)); send_wechat_message('order_remind', '', $order['order_sn'] . L('order_effective'), $order_url, $order['order_sn']); } // 销量 model('Flow')->add_touch_goods($flow_type, $order['extension_code']); /* 记录供应商信息 */ $sql = "update " . $this->model->pre . "order_goods og , " . $this->model->pre . "goods g set og.suppliers_id=g.suppliers_id\r\n where og.goods_id=g.goods_id and og.order_id='" . $order['order_id'] . "'"; $this->model->query($sql); /* 清空购物车 */ model('Order')->clear_cart($flow_type); /* 清除缓存,否则买了商品,但是前台页面读取缓存,商品数量不减少 */ clear_all_files(); /* 插入支付日志 */ $order['log_id'] = model('ClipsBase')->insert_pay_log($new_order_id, $order['order_amount'], PAY_ORDER); /* 订单信息 */ $this->assign('order', $order); $total['amount_formated'] = "¥0.00元"; $this->assign('total', $total); $this->assign('goods_list', $cart_goods); //$this->assign('order_submit_back', sprintf(L('order_submit_back'), L('back_home'), L('goto_user_center'))); // 返回提示 user_uc_call('add_feed', array($order['order_id'], BUY_GOODS)); // 推送feed到uc unset($_SESSION['flow_consignee']); // 清除session中保存的收货人信息 unset($_SESSION['flow_order']); unset($_SESSION['direct_shopping']); $this->assign('currency_format', C('currency_format')); $this->assign('integral_scale', C('integral_scale')); $this->assign('step', ACTION_NAME); $this->assign('title', L('order_submit')); $this->display('flow.dwt'); }