admin_oper.php 20 KB

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