Level.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. <?php
  2. namespace app\models\order;
  3. use app\models\system\SystemUserLevel;
  4. use app\models\user\User;
  5. use app\models\user\UserLevel;
  6. use app\models\user\WechatUser;
  7. use crmeb\basic\BaseModel;
  8. use crmeb\services\MiniProgramService;
  9. use crmeb\services\WechatService;
  10. use crmeb\repositories\PaymentRepositories;
  11. use crmeb\traits\ModelTrait;
  12. use app\models\user\UserBill;
  13. use think\facade\Log;
  14. class Level extends BaseModel
  15. {
  16. use ModelTrait;
  17. /**
  18. * 数据表主键
  19. * @var string
  20. */
  21. protected $pk = 'id';
  22. /**
  23. * 模型名称
  24. * @var string
  25. */
  26. protected $name = 'order_level';
  27. protected $insert = ['addtime'];
  28. protected static $payType = ['weixin' => '微信支付', 'yue' => '余额支付', 'alipay' => '支付宝支付'];
  29. /**
  30. * 生成订单唯一id
  31. * @param $uid 用户uid
  32. * @return string
  33. */
  34. public static function getNewOrderId()
  35. {
  36. list($msec, $sec) = explode(' ', microtime());
  37. $msectime = number_format((floatval($msec) + floatval($sec)) * 1000, 0, '', '');
  38. $orderId = 'lv' . $msectime . mt_rand(10000, 99999);
  39. while (self::be(['order_id' => $orderId])) $orderId = 'lv' . $msectime . mt_rand(10000, 99999);
  40. return $orderId;
  41. }
  42. /**
  43. * 创建订单
  44. * @param $uid
  45. * @param $level_id
  46. * @param $payType
  47. * @param $mark
  48. * @return Level|bool|\think\Model
  49. */
  50. public static function createLevelOrder($uid, $level_id, $payType, $spread_uid = 0, $buy_num = 1)
  51. {
  52. self::beginTrans();
  53. try {
  54. //Log::write('会员1:111'.$payType, 'error');
  55. if (!array_key_exists($payType, self::$payType)) return self::setErrorInfo('选择支付方式有误!', true);
  56. $userInfo = User::getUserInfo($uid);
  57. if (!$userInfo) return self::setErrorInfo('用户不存在!', true);
  58. $levelInfo = SystemUserLevel::get(['id' => $level_id, 'is_del' => 0]);
  59. if (!$levelInfo) return self::setErrorInfo('等级不存在', true);
  60. list($where['uid'], $where['level_id'], $where['pay_type'], $where['paid']) = [$uid, $level_id, $payType, 0];
  61. $info = self::where($where)->find();
  62. if ($info) {
  63. return $info;
  64. }
  65. $orderInfo = [
  66. 'uid' => $uid,
  67. 'order_id' => self::getNewOrderId(),
  68. 'level_id' => $level_id,
  69. 'paid' => 0,
  70. 'is_del' => 0,
  71. 'pay_price' => $levelInfo->money,
  72. 'pay_type' => $payType,
  73. 'body' => '开通会员-' . $levelInfo->name,
  74. 'addtime' => time(),
  75. 'spread_uid' => $spread_uid,
  76. 'buy_num' => $buy_num
  77. ];
  78. $order = self::create($orderInfo);
  79. if (!$order) {
  80. Log::write('会员1:订单生成失败', 'error');
  81. return self::setErrorInfo('订单生成失败!', true);
  82. }
  83. self::commitTrans();
  84. return $order;
  85. } catch (\PDOException $e) {
  86. Log::write('会员2:' . $e->getMessage(), 'error');
  87. self::rollbackTrans();
  88. return self::setErrorInfo('生成订单时SQL执行错误错误原因:' . $e->getMessage());
  89. } catch (\Exception $e) {
  90. Log::write('会员3:' . $e->getMessage(), 'error');
  91. self::rollbackTrans();
  92. return self::setErrorInfo('生成订单时系统错误错误原因:' . $e->getMessage());
  93. }
  94. }
  95. public static function paySuccess($orderId, $paytype = 'weixin')
  96. {
  97. $order = self::where('order_id', $orderId)->find()->toArray();
  98. $user = User::where('uid', $order['uid'])->find();
  99. if (!$user) return false;
  100. $res1 = self::where('order_id', $orderId)->update(['paid' => 1, 'pay_type' => $paytype, 'paytime' => time()]);//订单改为支付
  101. $res2 = UserLevel::setUserLevel($order['uid'], $order['level_id']);
  102. $res = $res1 && $res2;
  103. User::setSpreadLevel($order['spread_uid'], $order['uid']);
  104. // WechatUser::buyMemberGiveFreeCoupon($user['uid']); //购买会员送免配券
  105. return false !== $res;
  106. }
  107. /**
  108. * TODO 小程序JS支付
  109. * @param $orderId
  110. * @param string $field
  111. * @return array|string
  112. * @throws \think\db\exception\DataNotFoundException
  113. * @throws \think\db\exception\ModelNotFoundException
  114. * @throws \think\exception\DbException
  115. */
  116. public static function jsPay($orderId, $field = 'order_id')
  117. {
  118. if (is_string($orderId))
  119. $orderInfo = self::where($field, $orderId)->find();
  120. else
  121. $orderInfo = $orderId;
  122. if (!$orderInfo || !isset($orderInfo['paid'])) exception('支付订单不存在!');
  123. if ($orderInfo['paid']) exception('支付已支付!');
  124. if ($orderInfo['pay_price'] <= 0) exception('该支付无需支付!');
  125. $openid = WechatUser::getOpenId($orderInfo['uid']);
  126. $bodyContent = "会员升级-" . SystemUserLevel::where(['id' => $orderInfo['level_id']])->value('name');
  127. $site_name = sys_config('site_name');
  128. if (!$bodyContent && !$site_name) exception('支付参数缺少:请前往后台设置->系统设置-> 填写 网站名称');
  129. return MiniProgramService::jsPay($openid, $orderInfo['order_id'], $orderInfo['buy_num'] * 100, 'user_level', self::getSubstrUTf8($site_name . ' - ' . $bodyContent, 30));
  130. }
  131. /**
  132. * 微信公众号JS支付
  133. * @param $orderId
  134. * @param string $field
  135. * @return array|string
  136. * @throws \think\db\exception\DataNotFoundException
  137. * @throws \think\db\exception\ModelNotFoundException
  138. * @throws \think\exception\DbException
  139. */
  140. public static function wxPay($orderId, $field = 'order_id')
  141. {
  142. if (is_string($orderId))
  143. $orderInfo = self::where($field, $orderId)->find();
  144. else
  145. $orderInfo = $orderId;
  146. if (!$orderInfo || !isset($orderInfo['paid'])) exception('支付订单不存在!');
  147. if ($orderInfo['paid']) exception('支付已支付!');
  148. if ($orderInfo['pay_price'] <= 0) exception('该支付无需支付!');
  149. $openid = WechatUser::uidToOpenid($orderInfo['uid'], 'openid');
  150. $bodyContent = "会员升级-" . SystemUserLevel::where(['id' => $orderInfo['level_id']])->value('name');
  151. $site_name = sys_config('site_name');
  152. if (!$bodyContent && !$site_name) exception('支付参数缺少:请前往后台设置->系统设置-> 填写 网站名称');
  153. return WechatService::jsPay($openid, $orderInfo['order_id'], $orderInfo['pay_price'], 'user_level', self::getSubstrUTf8($site_name . ' - ' . $bodyContent, 30));
  154. }
  155. /**
  156. * 微信h5支付
  157. * @param $orderId
  158. * @param string $field
  159. * @return array|string
  160. * @throws \think\db\exception\DataNotFoundException
  161. * @throws \think\db\exception\ModelNotFoundException
  162. * @throws \think\exception\DbException
  163. */
  164. public static function h5Pay($orderId, $field = 'order_id')
  165. {
  166. if (is_string($orderId))
  167. $orderInfo = self::where($field, $orderId)->find();
  168. else
  169. $orderInfo = $orderId;
  170. if (!$orderInfo || !isset($orderInfo['paid'])) exception('支付订单不存在!');
  171. if ($orderInfo['paid']) exception('支付已支付!');
  172. if ($orderInfo['pay_price'] <= 0) exception('该支付无需支付!');
  173. $bodyContent = "会员升级-" . SystemUserLevel::where(['id' => $orderInfo['level_id']])->value('name');
  174. $site_name = sys_config('site_name');
  175. if (!$bodyContent && !$site_name) exception('支付参数缺少:请前往后台设置->系统设置-> 填写 网站名称');
  176. return WechatService::paymentPrepare(null, $orderInfo['order_id'], $orderInfo['pay_price'], 'user_level', self::getSubstrUTf8($site_name . ' - ' . $bodyContent, 30), '', 'MWEB');
  177. }
  178. /**
  179. * 余额支付
  180. * @param $order_id
  181. * @param $uid
  182. * @param string $formId
  183. * @return bool
  184. * @throws \think\Exception
  185. * @throws \think\db\exception\DataNotFoundException
  186. * @throws \think\db\exception\ModelNotFoundException
  187. * @throws \think\exception\DbException
  188. */
  189. public static function yuePay($order_id, $uid, $formId = '')
  190. {
  191. $orderInfo = self::where('uid', $uid)->where('order_id', $order_id)->find();
  192. if (!$orderInfo) return self::setErrorInfo('订单不存在!');
  193. if ($orderInfo['paid']) return self::setErrorInfo('该订单已支付!');
  194. $userInfo = User::getUserInfo($uid);
  195. if ($userInfo['now_money'] < $orderInfo['pay_price'])
  196. return self::setErrorInfo(['status' => 'pay_deficiency', 'msg' => '余额不足' . floatval($orderInfo['pay_price'])]);
  197. self::beginTrans();
  198. $res1 = false !== User::bcDec($uid, 'now_money', $orderInfo['pay_price'], 'uid');
  199. $res2 = UserBill::expend('会员升级', $uid, 'now_money', 'pay_product', $orderInfo['pay_price'], $orderInfo['id'], $userInfo['now_money'], '余额支付' . floatval($orderInfo['pay_price']) . '元升级' . SystemUserLevel::where(['id' => $orderInfo['level_id']])->value('name'));
  200. $res3 = self::paySuccess($order_id, 'yue');//余额支付成功
  201. try {
  202. PaymentRepositories::yuePayProduct($userInfo, $orderInfo);
  203. } catch (\Exception $e) {
  204. self::rollbackTrans();
  205. return self::setErrorInfo($e->getMessage());
  206. }
  207. $res = $res1 && $res2 && $res3;
  208. self::checkTrans($res);
  209. return $res;
  210. }
  211. public static function jsPayPrice($order_id, $uid, $formId = '')
  212. {
  213. $orderInfo = self::where('uid', $uid)->where('order_id', $order_id)->where('is_del', 0)->find();
  214. if (!$orderInfo) return self::setErrorInfo('订单不存在!');
  215. if ($orderInfo['paid']) return self::setErrorInfo('该订单已支付!');
  216. $userInfo = User::getUserInfo($uid);
  217. self::beginTrans();
  218. $res1 = UserBill::expend('会员升级', $uid, 'now_money', 'pay_product', $orderInfo['pay_price'], $orderInfo['id'], $userInfo['now_money'], '微信支付' . floatval($orderInfo['pay_price']) . '元升级' . SystemUserLevel::where(['id' => $orderInfo['level_id']])->value('name'));
  219. $res2 = self::paySuccess($order_id, 'weixin', $formId);//微信支付为0时
  220. $res = $res1 && $res2;
  221. self::checkTrans($res);
  222. return $res;
  223. }
  224. }