admin_oper.php 20 KB

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