admin_oper.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539
  1. <?php
  2. defined('InShopNC') or exit('Access Invalid!');
  3. require_once(BASE_ROOT_PATH . "/helper/kdn_helper.php");
  4. require_once(BASE_ROOT_PATH . "/helper/predeposit_helper.php");
  5. require_once(BASE_ROOT_PATH . "/helper/pay_helper.php");
  6. require_once(BASE_ROOT_PATH . "/helper/bonus/witholder.php");
  7. require_once(BASE_ROOT_PATH . '/helper/relation_helper.php');
  8. class admin_operControl extends mbMemberControl
  9. {
  10. public function __construct()
  11. {
  12. parent::__construct();
  13. // if($_SESSION['member_id'] != 36429) {
  14. // throw new Exception("必须是管理员才能操作此项功能");
  15. // }
  16. }
  17. private function parse_rate($bonus_rate,&$total_num,&$toal_amount,&$max_rate)
  18. {
  19. $toal_amount = 0;
  20. $total_num = 0;
  21. $max_rate = 0;
  22. $params = explode('#', urldecode($bonus_rate));
  23. $result = [];
  24. foreach ($params as $val)
  25. {
  26. if(preg_match_all('/^(\d{1,3})\|(\d{1,4})\|(\d{1,6})$/', $val, $match))
  27. {
  28. $item['rate'] = intval($match[1][0]);
  29. $item['amount'] = intval($match[2][0]);
  30. $item['num'] = intval($match[3][0]);
  31. $toal_amount += $item['amount'];
  32. $total_num += $item['num'];
  33. if($item['rate'] > $max_rate) {
  34. $max_rate = $item['rate'];
  35. }
  36. $result[] = $item;
  37. }
  38. }
  39. if(empty($result)) {
  40. return false;
  41. }
  42. else {
  43. return $result;
  44. }
  45. }
  46. public function make_activityOp()
  47. {
  48. if(empty($_GET['bonus_rate'])) {
  49. return self::outerr(errcode::ErrParamter,"bonus_rate 参数为空");
  50. }
  51. $rate_moneys = $this->parse_rate($_GET['bonus_rate'],$total_num,$toal_amount,$max_rate);
  52. if($rate_moneys == false) {
  53. return self::outerr(errcode::ErrParamter,"bonus_rate 参数错误");
  54. } else {
  55. $_GET['total_amount'] = $toal_amount;
  56. $_GET['total_num'] = $total_num;
  57. }
  58. $param_active = bonus_helper::check_activity($_GET,$ret);
  59. if($param_active == false) {
  60. return self::outerr($ret['code'],$ret['msg']);
  61. }
  62. $param_personal = bonus_helper::check_personal($_GET,$ret);
  63. if($param_personal == false) {
  64. return self::outerr($ret['code'],$ret['msg']);
  65. }
  66. $param = array_merge($param_active,$param_personal);
  67. $param['sender_id'] = $_SESSION['member_id'];
  68. $param['sender_mobile'] = $_SESSION['member_mobile'];
  69. $param['sender_name'] = session_helper::nickname();
  70. $type = \bonus\type::crate_by_input($param);
  71. $type->set_rate($max_rate);
  72. $pre_helper = new predeposit_helper($_SESSION['member_id']);
  73. $ret = $pre_helper->admin_make_bonus($type->get_param(),$rate_moneys);
  74. if($ret === false) {
  75. return self::outerr(errcode::ErrBonus,"生成红包失败.");
  76. } else {
  77. $type_sn = $ret['type_sn'];
  78. $url = BASE_SITE_URL . "/mobile/index.php?act=bonusex&op=open&client_type=wap&type_sn={$type_sn}";
  79. return self::outsuccess(array('type_sn' => $ret,'url' => "{$url}"));
  80. }
  81. }
  82. public function makeOp()
  83. {
  84. if(empty($_GET['bonus_rate'])) {
  85. return self::outerr(errcode::ErrParamter,"bonus_rate 参数为空");
  86. }
  87. $rate_moneys = $this->parse_rate($_GET['bonus_rate'],$total_num,$toal_amount,$max_rate);
  88. if($rate_moneys == false) {
  89. return self::outerr(errcode::ErrParamter,"bonus_rate 参数错误");
  90. } else {
  91. $_GET['total_amount'] = $toal_amount;
  92. $_GET['total_num'] = $total_num;
  93. }
  94. $param = bonus_helper::check_personal($_GET,$ret);
  95. if($param == false) {
  96. return self::outerr($ret['code'],$ret['msg']);
  97. }
  98. $param['sender_id'] = $_SESSION['member_id'];
  99. $param['sender_mobile'] = $_SESSION['member_mobile'];
  100. $param['sender_name'] = session_helper::nickname();
  101. $type = bonus_helper::create_type($param);
  102. $type->set_rate($max_rate);
  103. $pre_helper = new predeposit_helper($_SESSION['member_id']);
  104. $ret = $pre_helper->admin_make_bonus($type->get_param(),$rate_moneys);
  105. if($ret === false) {
  106. return self::outerr(errcode::ErrBonus,"生成红包失败.");
  107. } else {
  108. $type_sn = $ret['type_sn'];
  109. $url = BASE_SITE_URL . "/mobile/index.php?act=bonusex&op=open&client_type=wap&type_sn={$type_sn}";
  110. return self::outsuccess(array('type_sn' => $ret,'url' => "{$url}"));
  111. }
  112. }
  113. public function resort_realtaionOp()
  114. {
  115. $mod = Model('member_relation');
  116. $items = $mod->field('member_mobile')->limit(false)->select();
  117. foreach ($items as $item)
  118. {
  119. try
  120. {
  121. $mobile = intval($item['member_mobile']);
  122. $relation = new \relation\mem_relation(0,$mobile);
  123. $relation->sort_mobile();
  124. }
  125. catch (Exception $ex) {
  126. Log::record($ex->getMessage(),Log::ERR);
  127. }
  128. }
  129. }
  130. public function putomsOp()
  131. {
  132. $pay_sn = $_GET['pay_sn'];
  133. $trade_no = $_GET['trade_no'];
  134. if(empty($pay_sn) || empty($trade_no)) {
  135. return self::outerr(errcode::ErrApptype);
  136. }
  137. $logic_delivery = Logic('delivery');
  138. $ret = $logic_delivery->putOrder($pay_sn, $trade_no);
  139. if($ret == true) {
  140. return self::outsuccess(array('state' => true));
  141. } else {
  142. return self::outerr(array('state' => false));
  143. }
  144. }
  145. public function putallOp()
  146. {
  147. $order = Model('order');
  148. $items = $order->table('order')->field('pay_sn,trade_no')->where(array('order_state' => array('in',array(ORDER_STATE_PAY))))->limit(false)->select();
  149. foreach($items as $val)
  150. {
  151. $pay_sn = $val['pay_sn'];
  152. $trade_no = $val['trade_no'];
  153. $logic_delivery = Logic('delivery');
  154. $ret = $logic_delivery->putOrder($pay_sn, $trade_no);
  155. if(!$ret) {
  156. Log::record("putallOp pay_sn={$pay_sn} trade_no = {$trade_no}");
  157. }
  158. }
  159. }
  160. public function reset_bonus_typeOp()
  161. {
  162. $bonus_type = Model('bonus_type');
  163. $ret = $bonus_type->where(array('type_id' => array('gt',0),'bonus_rate' => 0))->update(array('bonus_rate' => 30));
  164. if($ret == false) {
  165. return self::outerr(errcode::ErrDB);
  166. } else {
  167. return self::outsuccess(null);
  168. }
  169. }
  170. public function reset_bonus_snOp()
  171. {
  172. $bonus_type = Model('bonus_type');
  173. $types = $bonus_type->field('type_id,type_sn')->where(array('type_id' => array('gt',0)))->limit(false)->select();
  174. foreach ($types as $type)
  175. {
  176. $type_id = intval($type['type_id']);
  177. $type_sn = $type['type_sn'];
  178. $user_bonus = Model('user_bonus');
  179. $bonuses = $user_bonus->field('bonus_id,bonus_sn')->where(array('type_id' => $type_id))->limit(false)->select();
  180. $count = count($bonuses);
  181. if($count <= 0) {
  182. continue;
  183. } elseif($count <= 10) {
  184. $format = "%d";
  185. } elseif($count <= 100) {
  186. $format = "%02d";
  187. } elseif ($count <= 1000) {
  188. $format = "%03d";
  189. } else {
  190. $format = "%04d";
  191. }
  192. $pos = 0;
  193. foreach ($bonuses as $bonus) {
  194. $bonus_sn = $type_sn . sprintf($format,$pos);
  195. $user_bonus->where(array('bonus_id' => intval($bonus['bonus_id'])))->update(array('bonus_sn' => $bonus_sn));
  196. if($user_bonus->affected_rows() <= 0) {
  197. Log::record("update bonus_sn error",Log::ERR);
  198. }
  199. $pos++;
  200. }
  201. }
  202. }
  203. // // 更新商品序列号
  204. // public function updateGoodsSerialOp()
  205. // {
  206. // $sku_map = Model()->table('sku_map')->limit(10000)->select();
  207. //
  208. // foreach ($sku_map as $value) {
  209. //
  210. // $condition = array('goods_serial_tm' => trim($value['tmsku']));
  211. // $updateinfo = array('goods_serial' => $value['psku']);
  212. //
  213. // $ret = Model('goods_common')->where($condition)->update($updateinfo);
  214. // }
  215. //
  216. // joutput_data(array("ret" => 'complete'));
  217. // }
  218. //
  219. // private function getSign($data)
  220. // {
  221. // return md5(self::$appkey . self::$appPassWord . $data);
  222. // }
  223. //
  224. // public function omsOp()
  225. // {
  226. // $outdata = '{"type":"PUT_TRADE","data":[{"tid":"8000000000026501","total_fee":"360.00","discount_fee":"","post_fee":"0.00","created":"2016-01-11 14:51:39","pay_time":"2016-01-11 14:51:39","buyer_message":"","express_code":"","pay_account_type":"\u5fae\u4fe1\u652f\u4ed8","pay_account_id":"","pay_account_no":"1007070763201601112636550146","buyer_nick":"anonymous_36365","buyer_email":"","trade_memo":"","receiver_name":"\u6c5f\u6d77\u82d7","receiver_state":"\u4e0a\u6d77","receiver_city":"\u4e0a\u6d77\u5e02","receiver_district":"\u5f90\u6c47\u533a","receiver_address":"\u756a\u79ba\u8def876\u53f7","receiver_zip":"000000","receiver_mobile":"13911129867","receiver_phone":"","order_size":1,"orderList":[{"oid":"80000000000265010","tid":"8000000000026501","title":"DQ\u8482\u73c2 \u5378\u5986\u6cb9170ml 170ml","price":"360.00","num":"1","outer_sku_id":"P0300292","outer_sku_properties_name":"DQ\u8482\u73c2 \u5378\u5986\u6cb9170ml 170ml","buyer_nick":"anonymous_36365"}]}]}';
  227. // $sign = $this->getSign($outdata);
  228. // $headers = array('v_appkey: ' . self::$appkey, 'v_sign: ' . $sign, 'Content-Type: application/json');
  229. // http_request(self::$appURL, $outdata, 'POST', false, $headers);
  230. // }
  231. //
  232. // public function test_callbackOp()
  233. // {
  234. // $param['order_sn'] = $_POST['tid'];
  235. // $status = $_POST['status'];
  236. // //$param['consign_time'] = $_POST['consign_time'];
  237. // $param['shipping_code'] = $_POST['logistics_no'];
  238. // $param['oms_code'] = $_POST['logistics_company'];
  239. //
  240. // if (intval($status) === 1) {
  241. // $logic_delivery = Logic('delivery');
  242. // $ret = $logic_delivery->handleCallback($param);
  243. // joutput_data($ret);
  244. // } else {
  245. //
  246. // }
  247. // }
  248. //
  249. // /**
  250. // * 首页
  251. // */
  252. // public function indexOp()
  253. // {
  254. //
  255. // $t = time();
  256. //
  257. // $t1 = date("D F d Y", 1452355200);
  258. //
  259. //// $payment = 500;
  260. //// $payment = $payment = $this->getAndUpdateBonus(36218,$payment);
  261. //// joutput_data(array('$payment'=>$payment));
  262. //
  263. // // 修改地址
  264. // $order_id = "order_id in (297, 401, 923, 928,1097,1145,1150,1154,1244,1248,1281)";
  265. // $model = Model('order_common')->where($order_id)->select();
  266. // $model_address = Model('area');
  267. // $recv_info_array = array();
  268. // if ($model != null) {
  269. //
  270. // foreach ($model as $val) {
  271. // $recv_info = unserialize($val['reciver_info']);
  272. //
  273. // $recv_info['area'] = $model_address->formatAddress($recv_info['area']);
  274. // Model()->table('recv_info')->insert(array('order_id' => $val['order_id'], 'reciver_info' => serialize($recv_info)));
  275. //
  276. // Model('order_common')->where(array('order_id' => $val['order_id']))->update(array('reciver_info' => serialize($recv_info)));
  277. //
  278. // array_push($recv_info_array, $recv_info);
  279. // }
  280. // }
  281. //
  282. // joutput_data($recv_info_array);
  283. // }
  284. //
  285. // public function getAndUpdateBonus($user_id, $pay_amount)
  286. // {
  287. //
  288. // $condition['user_id'] = $user_id;
  289. // $condition['type_id'] = 1;
  290. // $bonus_list = Model()->table("user_bonus")->where($condition)->select();
  291. //
  292. // $ret_value = 0;
  293. // if (!empty($bonus_list)) {
  294. //
  295. // foreach ($bonus_list as $value) {
  296. // $bonus_value = doubleval($value['bonus_value']);
  297. //
  298. // if (($pay_amount - $bonus_value) > 0.0000001) {
  299. //
  300. // $data['bonus_value'] = 0;
  301. // $ret = Model()->table('user_bonus')->where(array('bonus_id' => $value['bonus_id']))->update($data);
  302. //
  303. // if ($ret) {
  304. // $pay_amount -= $bonus_value;
  305. // }
  306. // } else {
  307. //
  308. // $data['bonus_value'] = $bonus_value - $pay_amount;
  309. // $ret = Model()->table('user_bonus')->where(array('bonus_id' => $value['bonus_id']))->update($data);
  310. //
  311. // if ($ret) {
  312. // $pay_amount = 0;
  313. // }
  314. // break;
  315. // }
  316. // }
  317. // }
  318. //
  319. // return $pay_amount;
  320. // }
  321. //
  322. // /**
  323. // * order_sn
  324. // * member_id
  325. // *
  326. // * 手动退款接口
  327. // */
  328. // public function refundOp()
  329. // {
  330. // $model_trade = Model('trade');
  331. // $order_info = Model('order')->getOrderInfo(array('order_sn' => $_GET['order_sn']));
  332. // if (empty($order_info)) return;
  333. //
  334. // $model_refund = Model('refund_return');
  335. // $order_id = intval($order_info['order_id']);
  336. // $condition = array();
  337. // $condition['buyer_id'] = $order_info['buyer_id'];
  338. // $condition['order_id'] = $order_id;
  339. // $order = $model_refund->getRightOrderList($condition);
  340. // $order_amount = $order['order_amount'];//订单金额
  341. // $condition = array();
  342. // $condition['buyer_id'] = $order['buyer_id'];
  343. // $condition['order_id'] = $order['order_id'];
  344. // $condition['goods_id'] = '0';
  345. // $condition['seller_state'] = array('lt', '3');
  346. // $refund_list = $model_refund->getRefundReturnList($condition);
  347. // $refund = array();
  348. // if (!empty($refund_list) && is_array($refund_list)) {
  349. // $refund = $refund_list[0];
  350. // }
  351. // $order_paid = $model_trade->getOrderState('order_paid');//订单状态20:已付款
  352. // $payment_code = $order['payment_code'];//支付方式
  353. // if ($refund['refund_id'] > 0 || $order['order_state'] != $order_paid || $payment_code == 'offline') {//检查订单状态,防止页面刷新不及时造成数据错误
  354. // joutput_error(array("result" => false));
  355. // return false;
  356. // }
  357. //
  358. // $refund_array = array();
  359. // $refund_array['refund_type'] = '1';//类型:1为退款,2为退货
  360. // $refund_array['seller_state'] = '1';//状态:1为待审核,2为同意,3为不同意
  361. // $refund_array['order_lock'] = '2';//锁定类型:1为不用锁定,2为需要锁定
  362. // $refund_array['goods_id'] = '0';
  363. // $refund_array['order_goods_id'] = '0';
  364. // $refund_array['reason_id'] = '0';
  365. // $refund_array['reason_info'] = '取消订单,全部退款';
  366. // $refund_array['goods_name'] = '订单商品全部退款';
  367. // $refund_array['refund_amount'] = ncPriceFormat($order_amount);
  368. // $refund_array['buyer_message'] = $_POST['buyer_message'];
  369. // $refund_array['add_time'] = time();
  370. //
  371. // $pic_array = array();
  372. // $pic_array['buyer'] = '';//$this->upload_pic();//上传凭证
  373. // $info = serialize($pic_array);
  374. // $refund_array['pic_info'] = $info;
  375. // $state = $model_refund->addRefundReturn($refund_array, $order);
  376. //
  377. // if ($state) {
  378. // $model_refund->editOrderLock($order_id);
  379. // joutput_data(array("result" => true));
  380. // return true;
  381. // } else {
  382. // joutput_error(array("result" => false));
  383. // return false;
  384. // }
  385. // }
  386. //
  387. // public function subscribe_kdnOp()
  388. // {
  389. // $ordersn = $_GET['order_sn'];
  390. // kdn_helper::req_subscribe('YD', '3941561454548', $ordersn);
  391. // }
  392. //
  393. // private function merge_user($mod_member,$mobile,$name,$passwd,$balance)
  394. // {
  395. // $user = $mod_member->where(array('member_mobile' => $mobile))->limit(false)->find();
  396. // if(empty($user))
  397. // {
  398. // $data = array();
  399. // $data['member_mobile'] = $mobile;
  400. // $data['member_name'] = $mobile;
  401. // $data['member_passwd'] = $passwd;
  402. // $data['member_nickname'] = $name;
  403. // $data['available_predeposit'] = $balance;
  404. //
  405. // $mod_member->insert($data);
  406. // }
  407. // else
  408. // {
  409. // $data = array();
  410. // $data['member_name'] = $mobile;
  411. // $data['member_nickname'] = $name;
  412. //
  413. // $mod_member->where(array('member_id' => $user['member_id']))->update($data);
  414. // $money = intval($balance * 100 + 0.5);
  415. //
  416. // if($money > 0) {
  417. // $pd_helper = new predeposit_helper($user['member_id']);
  418. // $pd_helper->transform_money($name,$balance);
  419. // }
  420. // }
  421. // }
  422. //
  423. // public function imolduserOp()
  424. // {
  425. // $mod_users = Model('users');
  426. // $mod_member = Model('member');
  427. //
  428. // $users = $mod_users->field('*')->limit(false)->select();
  429. // foreach($users as $val)
  430. // {
  431. // $mobile = $val['mobile'];
  432. // $name = $val['name'];
  433. // $passwd = $val['encrypted_password'];
  434. // $balance = $val['remain_balance'];
  435. //
  436. // $this->merge_user($mod_member,$mobile,$name,$passwd,$balance);
  437. //
  438. // }
  439. // }
  440. //
  441. // public function sendbonusOp()
  442. // {
  443. // $pay_sn = '210510764647050484';
  444. //
  445. // $pay = new pay_helper();
  446. // $pay->success($pay_sn);
  447. //
  448. // }
  449. //
  450. // public function balance_pdbonusOp()
  451. // {
  452. // $member_ids = Model()->table("member")->field("member_id")->order("member_id asc")->limit(false)->select();
  453. // foreach($member_ids as $val) {
  454. // $member_id = $val["member_id"];
  455. //
  456. // $pd = new predeposit_helper($member_id);
  457. // $ret = $pd->get_predeposit();
  458. // $total = intval($ret['total_value'] * 100 + $ret['freeze_value'] * 100 + 0.5);
  459. //
  460. // $holder = new bonus\witholder($member_id);
  461. // $usable_amount = intval($holder->usable_amount() * 100 + 0.5);
  462. //
  463. // echo "total={$total},usable_amout={$usable_amount}<br/>";
  464. // if($total < $usable_amount) {
  465. // echo "witholding<br/>";
  466. // $holder->withold(($usable_amount - $total) / 100);
  467. // }
  468. // }
  469. // }
  470. //
  471. // public function init_relationOp()
  472. // {
  473. // $member_ids = Model()->table("member")->field("member_id")->order("member_id asc")->limit(false)->select();
  474. // foreach($member_ids as $val) {
  475. //
  476. // $member_id = $val["member_id"];
  477. // echo ("add member_id = {$member_id}<br/>");
  478. // relation_helper::onRegister($member_id);
  479. // }
  480. // }
  481. //
  482. // public function add_bonus_expiretimeOp()
  483. // {
  484. // $is_dev = $_GET["dev"];
  485. // $day_secs = 3600 * 24;
  486. //
  487. // if (isset($is_dev) && !empty($is_dev)) {
  488. // $left_secs = $day_secs;
  489. // } else {
  490. // $left_secs = $day_secs * 30;
  491. // }
  492. //
  493. // echo "add bonus expire left seconds: {$left_secs} <br/>";
  494. //
  495. // $expire_time = time() + $left_secs;
  496. //
  497. // $cond = array("bonus_status" => 3);
  498. // $data = array("usable_time" => $expire_time);
  499. //
  500. // $model = Model("user_bonus");
  501. // $ret = $model->edit($cond, $data);
  502. // if ($ret == false) {
  503. // echo 'failed';
  504. // } else {
  505. // echo 'update affect rows: ' . $model->affected_rows();
  506. // }
  507. //
  508. // }
  509. }