admin_oper.php 20 KB

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