Core.php 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. namespace Code\Lib;
  3. use Dever;
  4. class Core
  5. {
  6. public function createCodeByOrder($order, $num = 0)
  7. {
  8. $code = '';
  9. if ($order['type'] == 3 && !$order['code']) {
  10. Dever::setInput('set_product_id', $order['product_id']);
  11. # 购买兑换码
  12. $product_num = 1;
  13. $code_num = 1;
  14. if ($order['buy_id'] > 0) {
  15. $buy = Dever::load('act/order')->getBuy($order['buy_id']);
  16. $product_num = $buy['num'];
  17. $code_num = $buy['code'];
  18. }
  19. # 检查之前有多少个兑换码,防止多发
  20. $code_where['order_id'] = $order['order_id'];
  21. $total = Dever::db('code/info')->total($code_where);
  22. if ($total && $total > 0) {
  23. if ($code_num > $total) {
  24. $code_num = $code_num - $total;
  25. } else {
  26. $one = Dever::db('code/info')->one($code_where);
  27. return $one['code'];
  28. }
  29. }
  30. if ($code_num > 1) {
  31. $product_num = intval($product_num/$code_num);
  32. if ($num < 0) {
  33. # 订阅
  34. Dever::load('act/lib/subscribe')->submit($order['uid'], $order['product_id'], 1);
  35. $code = $this->createCode($order['cate_id'] . ',' . $order['product_id'], $order['cate_id'], $order['product_id'], $order['seller_id'], $product_num, $order['uid'], $order['order_id'], 0, 3, 1);
  36. }
  37. $this->createCode($order['cate_id'] . ',' . $order['product_id'], $order['cate_id'], $order['product_id'], $order['seller_id'], $product_num, $order['uid'], $order['order_id'], 0, 1, $code_num + $num);
  38. } else {
  39. # 订阅
  40. Dever::load('act/lib/subscribe')->submit($order['uid'], $order['product_id'], 1);
  41. $code = $this->createCode($order['cate_id'] . ',' . $order['product_id'], $order['cate_id'], $order['product_id'], $order['seller_id'], $product_num, $order['uid'], $order['order_id'], 0, 3);
  42. }
  43. }
  44. return $code;
  45. }
  46. public function createCode($product, $cate_id, $product_id, $seller_id, $product_num = 0, $create_uid = -1, $order_id = false, $score = 0, $type = 1, $num = 1)
  47. {
  48. if ($product_id > 0) {
  49. Dever::setInput('set_product_id', $product_id);
  50. }
  51. //$data['product'] = $product;
  52. $data['cate_id'] = $cate_id;
  53. $data['product_id'] = $product_id;
  54. $data['seller_id'] = $seller_id;
  55. $data['product_num'] = $product_num;
  56. $data['type'] = $type;
  57. if ($order_id) {
  58. $data['order_id'] = $order_id;
  59. }
  60. if ($create_uid > 0) {
  61. $data['create_uid'] = $create_uid;
  62. }
  63. $data['score'] = $score;
  64. $code = Dever::db('code/info')->insert($data, $num);
  65. return $code;
  66. }
  67. }