Pay.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. <?php
  2. #新版本的异步支付
  3. namespace Act\Lib;
  4. use Dever;
  5. class Pay
  6. {
  7. private $key = 'jmss_2018';
  8. # 退款操作
  9. public function order($id, $name, $data)
  10. {
  11. $status = Dever::param('status', $data);
  12. if ($status == 5 && $id > 0) {
  13. $send = array();
  14. $info = Dever::db('act/order')->one($id);
  15. $send['pay_project_id'] = 1;
  16. $send['pay_uid'] = $info['uid'];
  17. $send['pay_order_id'] = $info['order_id'] ? $info['order_id'] : Dever::load('act/order')->createOrderId($info, $info['id']);
  18. $send['pay_tk_pic'] = Dever::param('tk_pic', $data);
  19. $send['pay_tk_time'] = Dever::param('tk_time', $data);
  20. $send['pay_tk_desc'] = Dever::param('tk_desc', $data);
  21. $send['pay_status'] = $status;
  22. $send['dever_token'] = $this->key;
  23. if ($info['buy_id'] > 0) {
  24. $buy = Dever::db('journal/buy_num')->one($info['buy_id']);
  25. if ($buy) {
  26. if ($info['buy_num'] > 0) {
  27. $num = $info['buy_num'];
  28. } else {
  29. $num = $buy['num'];
  30. }
  31. # 减少积分
  32. $score = $num * 20;
  33. $user = Dever::db('score/user')->one(array('uid' => $info['uid']));
  34. if ($user) {
  35. $user_id = $user['id'];
  36. $user_score = $user['score'];
  37. $user_score = $user_score - $score;
  38. if ($user_score < 0) {
  39. $user_score = 0;
  40. }
  41. Dever::db('score/user')->update(array('where_id' => $user_id, 'score' => $user_score));
  42. }
  43. # 减少排行榜
  44. $journal_num = Dever::db('act/journal_num')->one(array('uid' => $info['uid'], 'journal_id' => $info['product_id']));
  45. if ($journal_num) {
  46. $journal_num_id = $journal_num['id'];
  47. $journal_num = $journal_num['num'];
  48. $journal_num = $journal_num - $num;
  49. if ($journal_num < 0) {
  50. $journal_num = 0;
  51. }
  52. Dever::db('act/journal_num')->update(array('where_id' => $journal_num_id, 'num' => $journal_num));
  53. }
  54. # 减少订阅本数 这个定时跑就行了 不管了
  55. $journal = Dever::db('journal/info')->one($info['product_id']);
  56. if ($journal) {
  57. $journal_id = $journal['id'];
  58. $journal_num = $journal['num_ding'];
  59. $journal_num = $journal_num - $num;
  60. if ($journal_num < 0) {
  61. $journal_num = 0;
  62. }
  63. Dever::db('journal/info')->update(array('where_id' => $journal_id, 'num_ding' => $journal_num));
  64. }
  65. }
  66. }
  67. Dever::load('pay/lib/set.updateStatus', $send);
  68. }
  69. }
  70. # 退款操作
  71. public function order_bak($id, $name, $data)
  72. {
  73. $status = Dever::param('status', $data);
  74. if ($status == 5 && $id > 0) {
  75. $send = array();
  76. $info = Dever::db('act/order_bak')->one($id);
  77. $send['pay_project_id'] = 1;
  78. $send['pay_uid'] = $info['uid'];
  79. $send['pay_order_id'] = $info['order_id'] ? $info['order_id'] : Dever::load('act/order')->createOrderId($info, $info['id']);
  80. $send['pay_tk_pic'] = Dever::param('tk_pic', $data);
  81. $send['pay_tk_time'] = Dever::param('tk_time', $data);
  82. $send['pay_tk_desc'] = Dever::param('tk_desc', $data);
  83. $send['pay_status'] = $status;
  84. $send['dever_token'] = $this->key;
  85. if ($info['buy_id'] > 0) {
  86. $buy = Dever::db('journal/buy_num')->one($info['buy_id']);
  87. if ($buy) {
  88. if ($info['buy_num'] > 0) {
  89. $num = $info['buy_num'];
  90. } else {
  91. $num = $buy['num'];
  92. }
  93. # 减少积分
  94. $score = $num * 20;
  95. $user = Dever::db('score/user')->one(array('uid' => $info['uid']));
  96. if ($user) {
  97. $user_id = $user['id'];
  98. $user_score = $user['score'];
  99. $user_score = $user_score - $score;
  100. if ($user_score < 0) {
  101. $user_score = 0;
  102. }
  103. Dever::db('score/user')->update(array('where_id' => $user_id, 'score' => $user_score));
  104. }
  105. # 减少排行榜
  106. $journal_num = Dever::db('act/journal_num')->one(array('uid' => $info['uid'], 'journal_id' => $info['product_id']));
  107. if ($journal_num) {
  108. $journal_num_id = $journal_num['id'];
  109. $journal_num = $journal_num['num'];
  110. $journal_num = $journal_num - $num;
  111. if ($journal_num < 0) {
  112. $journal_num = 0;
  113. }
  114. Dever::db('act/journal_num')->update(array('where_id' => $journal_num_id, 'num' => $journal_num));
  115. }
  116. # 减少订阅本数 这个定时跑就行了 不管了
  117. $journal = Dever::db('journal/info')->one($info['product_id']);
  118. if ($journal) {
  119. $journal_id = $journal['id'];
  120. $journal_num = $journal['num_ding'];
  121. $journal_num = $journal_num - $num;
  122. if ($journal_num < 0) {
  123. $journal_num = 0;
  124. }
  125. Dever::db('journal/info')->update(array('where_id' => $journal_id, 'num_ding' => $journal_num));
  126. }
  127. }
  128. }
  129. Dever::load('pay/lib/set.updateStatus', $send);
  130. }
  131. }
  132. /**
  133. * 支付成功后,调取的接口 这里的安全以后再升级吧,升级成和pay/lib/set.updateStatus一样的
  134. *
  135. * @return mixed
  136. */
  137. public function act_api($param = array())
  138. {
  139. }
  140. public function act($param = array())
  141. {
  142. //$send = Dever::preInput('pay_');
  143. $send = $param;
  144. $key = md5($this->key);
  145. ksort($send);
  146. $send['signature'] = md5($key . '&' . http_build_query($send));
  147. $signature = Dever::input('signature');
  148. if ($send['signature'] == $signature) {
  149. $this->act_action($send);
  150. }
  151. return 'ok';
  152. }
  153. public function act_action($send)
  154. {
  155. //$product_id = $send['pay_product_id'];
  156. //$uid = $send['pay_uid'];
  157. //$cash = $send['pay_cash'];
  158. $order_id = $send['pay_order_id'];
  159. $status = $send['pay_status'];
  160. $msg = $send['pay_msg'];
  161. $temp = explode('D', $order_id);
  162. $id = $temp[1];
  163. //$order = Dever::db('act/order_temp')->one(array('order_id' => $order_id, 'uid' => $uid));
  164. $order = Dever::db('act/order_temp')->one($id);
  165. if ($send['pay_status'] == 2 && $order) {
  166. $update = $order;
  167. //$update['where_id'] = $order['id'];
  168. $update['status'] = 2;
  169. if ($order['type'] == 3 && !$order['code']) {
  170. if ($order['system'] == 2) {
  171. $code = Dever::load('code/lib/core')->createCodeByOrder($order);
  172. } else {
  173. $code = Dever::load('code/lib/core')->createCodeByOrder($order, -1);
  174. }
  175. if ($code) {
  176. $update['code'] = $code;
  177. }
  178. }
  179. Dever::db('act/order')->insert($update);
  180. $score = false;
  181. $num = false;
  182. $journal = Dever::load('act/order')->getJournal($order['product_id']);
  183. if ($order['buy_id'] > 0) {
  184. $buy = Dever::load('act/order')->getBuy($order['buy_id']);
  185. if ($buy && $buy['score'] > 0) {
  186. $score = $buy['num'] * $buy['score'];
  187. } else {
  188. if ($order['type'] == 1) {
  189. # 直接购买
  190. $col = 'score';
  191. } elseif ($order['type'] == 3) {
  192. $col = 'dh_score';
  193. }
  194. if ($journal && $buy && $journal[$col] > 0) {
  195. $score = $buy['num'] * $journal[$col];
  196. } elseif ($journal && $buy) {
  197. $num = $buy['num'];
  198. }
  199. }
  200. if ($buy && $buy['num']) {
  201. $active = Dever::load('act/order')->getActive($order['product_id']);
  202. $active_state = true;
  203. if ($active && $active['status'] == 1 && time() > $active['end']) {
  204. $active_state = false;
  205. }
  206. if ($active_state) {
  207. # 增加本数
  208. Dever::load('act/lib/num')->submit($order['product_id'], $order['uid'], $buy['num']);
  209. }
  210. # 增加订阅数
  211. Dever::load('act/lib/num')->setCounter($order['product_id'], $buy['num']);
  212. }
  213. }
  214. # 积分
  215. Dever::score($order['uid'], 'buy_journal', '购买小刊', '', $score, $num);
  216. if ($order['system'] == 2) {
  217. return;
  218. }
  219. # 发消息
  220. $journal['id'] = $order['product_id'];
  221. $journal['name'] = $order['name'];
  222. if (strstr('-', $journal['name'])) {
  223. $name = explode('-', $journal['name']);
  224. $journal['name'] = $name[0];
  225. }
  226. //$journal = Dever::db('journal/info')->one($order['product_id']);
  227. if (Dever::project('message')) {
  228. Dever::load('message/lib/data')->push(-1, $order['uid'], '购买提醒', '购买成功,您获得了 '.$journal['name'].' 的阅读资格!', 11, $order['cate_id'], 1, Dever::load('act/lib/note')->push(4, $journal['id'], $journal['name']));
  229. }
  230. $user = Dever::db('passport/user')->one($order['uid']);
  231. # 发短信
  232. /*
  233. if (isset($user['mobile']) && $user['mobile'] && Dever::project('sms') && $order['cate_id'] == 1) {
  234. $send = array();
  235. $send['name'] = $journal['name'];
  236. Dever::load('sms/api.send', 'buy_journal', $user['mobile'], $send);
  237. }
  238. */
  239. # 发模板消息
  240. $wechat = Dever::db('passport/wechat')->one(array('uid' => $order['uid'], 'type' => 1, 'system_id' => $order['cate_id']));
  241. if ($wechat && Dever::project('wechat_applet')) {
  242. $send['key'] = 'buy_journal';
  243. $send['project_id'] = $order['cate_id'];
  244. $send['touser'] = $wechat['openid'];
  245. $send['page'] = Dever::config('base')->applet_index . '?scene=' . $order['uid'] . ',' . '4,' . $order['product_id'];
  246. $send['data'] = array
  247. (
  248. 'keyword1' => array('value' => date('Y年m月d日 H:i', $order['cdate'])),
  249. 'keyword2' => array('value' => '购买成功,您获得了 '.$journal['name'].' 的阅读资格!'),
  250. );
  251. $send['data'] = json_encode($send['data']);
  252. $send['form_id'] = Dever::load('act/lib/form')->get($order['uid'], 2, $order['cate_id']);
  253. if ($send['form_id']) {
  254. Dever::load('wechat_applet/msg.send', $send);
  255. }
  256. }
  257. } else {
  258. Dever::db('act/order_temp')->update(array('where_id' => $order['id'], 'status' => 3));
  259. }
  260. }
  261. public function send_api()
  262. {
  263. $uid = Dever::input('uid', 8);
  264. # 发模板消息
  265. $wechat = Dever::db('passport/wechat')->one(array('uid' => $uid));
  266. if ($wechat && Dever::project('wechat_applet')) {
  267. $send['key'] = 'buy_journal';
  268. $send['project_id'] = 2;
  269. $send['touser'] = $wechat['openid'];
  270. $send['page'] = Dever::config('base')->applet_index . '?scene=' . Dever::login($uid) . ',' . '4,' . $order['product_id'];
  271. $send['data'] = array
  272. (
  273. 'keyword1' => array('value' => date('Y年m月d日 H:i', $order['cdate'])),
  274. 'keyword2' => array('value' => '购买成功,您获得了 '.$journal['name'].' 的阅读资格!'),
  275. );
  276. $send['data'] = json_encode($send['data']);
  277. $send['form_id'] = Dever::load('act/lib/form')->get($uid, 2, $order['cate_id']);
  278. if ($send['form_id']) {
  279. Dever::load('wechat_applet/msg.send', $send);
  280. }
  281. }
  282. }
  283. }