ManyController.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. <?php
  2. namespace app\api\controller\many;
  3. use app\models\many\AuctionPay;
  4. use app\models\many\Many;
  5. use app\models\many\ManyDiscipline;
  6. use app\models\many\ManyGreen;
  7. use app\models\many\ManyOrder;
  8. use app\models\store\StoreOrder;
  9. use app\models\user\User;
  10. use app\models\user\UserBill;
  11. use app\Request;
  12. use crmeb\services\GroupDataService;
  13. use crmeb\services\QrcodeService;
  14. use crmeb\services\SystemConfigService;
  15. use crmeb\services\UtilService;
  16. use crmeb\services\upload\Upload;
  17. use think\facade\Db;
  18. use think\facade\Validate;
  19. /**
  20. * 账单类
  21. * Class UserBillController
  22. * @package app\api\controller\user
  23. */
  24. class ManyController
  25. {
  26. /**
  27. * 众筹列表
  28. * @param Request $request
  29. * @return mixed
  30. */
  31. public function many(Request $request)
  32. {
  33. $where = UtilService::getMore([
  34. ['page', 1],
  35. ['limit', 10],
  36. ['name']
  37. ]);
  38. $list = \app\models\many\Many::list($where);
  39. return app('json')->success($list);
  40. }
  41. /**
  42. * 众筹详情
  43. * @return mixed
  44. * @throws \think\db\exception\DataNotFoundException
  45. * @throws \think\db\exception\DbException
  46. * @throws \think\db\exception\ModelNotFoundException
  47. */
  48. public function details()
  49. {
  50. $where = UtilService::getMore([
  51. ['id'],
  52. ]);
  53. $many = Many::find($where['id']);
  54. if (!$many) return app('json')->fail('没有该场次');
  55. return app('json')->success($many->toArray());
  56. }
  57. /**
  58. * 投注
  59. * @param Request $request
  60. * @return mixed
  61. * @throws \think\db\exception\DataNotFoundException
  62. * @throws \think\db\exception\DbException
  63. * @throws \think\db\exception\ModelNotFoundException
  64. */
  65. public function purchase(Request $request)
  66. {
  67. $data = UtilService::postMore([
  68. ['id'],
  69. ['price']
  70. ]);
  71. Db::startTrans();
  72. $many = Many::where('id', $data['id'])->lock(true)->find();
  73. $surplus = $this->surplus($data['id'], $request->uid(),1);
  74. $user = User::where('uid', $request->uid())->find();
  75. if ($user['blacklist'] < 1) return app('json')->fail('种植失败');
  76. if ($data['price'] < $many['lower_limit']) return app('json')->fail('最小种植数'.$many['lower_limit']);
  77. if (!$many) return app('json')->fail('场次不存在');
  78. if ($many['number'] >= $many['money']) return app('json')->fail('已完成无法种植');
  79. if ($many['status'] == 0) return app('json')->fail('未开启');
  80. if ($many['end_time'] < time()) return app('json')->fail('已结束');
  81. if (($many['number']+$data['price']) > $many['money']) return app('json')->fail('还能最大种植'.($many['money']-$many['number']));
  82. if ($data['price'] > $many['single']) return app('json')->fail('单次最大可种植'.$many['single']);
  83. if ($surplus < $data['price']) return app('json')->fail('超过最大可种植额度');
  84. if ($many['add_time'] > time()) return app('json')->fail('你无法提前种植');
  85. // if ($many['add_time'] > time()){
  86. // $green = ManyGreen::where('uid', $user['uid'])->where('status', 0)->find();
  87. // if (!$green) return app('json')->fail('你无法提前种植');
  88. // $green['status'] = 1;
  89. // }
  90. $integral = $user['white_integral'] + $user['purple_integral'];// 白积分加紫积分的总积分
  91. if ($integral < $data['price']) return app('json')->fail('积分额度不够');
  92. try {
  93. if ($user['white_integral'] < $data['price']){
  94. $white = $user['white_integral'];
  95. if ($white > 0){
  96. User::where('uid', $request->uid())->dec('white_integral',$white)->update();
  97. UserBill::expend('扣除红积分', $user['uid'], 'white_integral', 'bet_white_integral', $white, 0,0,'使用红积分,参与种植-》'.$many['name'].'期数-》'.$many['stage'].'-成功');
  98. }
  99. $user['purple_integral'] -= $data['price'] - $white;
  100. User::where('uid', $request->uid())->dec('purple_integral', $data['price']-$white)->update();
  101. UserBill::expend('扣除阳光积分', $user['uid'], 'purple_integral', 'bet_purple_integral', $data['price']-$white, 0,$user['purple_integral'],'使用阳光积分,参与种植-》'.$many['name'].'期数-》'.$many['stage'].'-成功');
  102. }else{
  103. $user['white_integral'] -= $data['price'];
  104. User::where('uid', $request->uid())->dec('white_integral', $data['price'])->update();
  105. UserBill::expend('扣除红积分', $user['uid'], 'white_integral', 'bet_white_integral', $data['price'], 0,$user['white_integral'],'使用红积分,参与种植-》'.$many['name'].'期数-》'.$many['stage'].'-成功');
  106. }
  107. $number = $many['number'] + $data['price'];
  108. if ($number >= $many['money']){
  109. $many['suc'] = 1;// 众筹成功
  110. $many['status'] = 0;// 众筹成功
  111. // ManyDiscipline::create(['many_id' => $many['id'], 'stage' => $many['stage'], 'status' => 1]);// 成功记录
  112. if ($many['stage'] >= 4){
  113. // 期数如果大于等于4
  114. $stage = $many['stage'] - 3;
  115. ManyOrder::where('many_id', $many['id'])->where('stage', $stage)->update(['is_return' => 1]);// 成功后添加返还状态
  116. }
  117. }
  118. ManyOrder::create([
  119. 'order_id' => StoreOrder::getNewOrderId(),
  120. 'many_id' => $many['id'],
  121. 'uid' => $user['uid'],
  122. 'stage' => $many['stage'],
  123. 'price' => $data['price'],
  124. ]);
  125. Many::where('id', $data['id'])->inc('number', $data['price'])->update();
  126. $many->save();
  127. // if ($many['add_time'] > time()) $green->save();
  128. event('Many', ['many' => $many, 'data' => $data, 'uid' => $request->uid()]);
  129. Db::commit();
  130. return app('json')->success('投注成功');
  131. } catch (\Exception $e) {
  132. Db::rollback();
  133. return app('json')->fail($e->getMessage());
  134. }
  135. }
  136. /**
  137. * 还有多少可投注
  138. * @param $id
  139. * @param $type
  140. * @return float|mixed
  141. * @throws \think\db\exception\DataNotFoundException
  142. * @throws \think\db\exception\DbException
  143. * @throws \think\db\exception\ModelNotFoundException
  144. */
  145. public function surplus($id, $uid,$type = 0)
  146. {
  147. if ($type > 0){
  148. $many = Many::where('id', $id)->find();
  149. if (!$many) return app('json')->fail('场次不存在');
  150. $many_order = ManyOrder::where('many_id', $id)->where('uid', $uid)->where('stage', $many['stage'])->sum('price');
  151. $price = ($many['upper_limit'] - $many_order); // 还可以投注额度
  152. return $price;
  153. }else{
  154. $many = Many::where('id', $id)->find();
  155. if (!$many) return app('json')->fail('场次不存在');
  156. $many_order = ManyOrder::where('many_id', $id)->where('uid', $uid)->where('stage', $many['stage'])->sum('price');
  157. $data['price'] = ($many['upper_limit'] - $many_order); // 还可以投注额度
  158. return app('json')->fail($data);
  159. }
  160. }
  161. /**
  162. * 添加收款方式
  163. * @param Request $request
  164. * @return void
  165. */
  166. public function pay(Request $request)
  167. {
  168. $data = UtilService::postMore([
  169. ['payment'],
  170. ['image'],
  171. ['bank'],
  172. ['name'],
  173. ['type'],
  174. ['phone'],
  175. ['bank_name']
  176. ], $request);
  177. if (!$data['type']) return app('json')->fail('数据传入错误');
  178. $data['uid'] =$request->uid();
  179. $model = new AuctionPay();
  180. $pay = $model->where([['uid', '=', $request->uid()], ['type', '=', $data['type']]])->find();
  181. $res = Validate::rule([
  182. 'phone' => 'mobile'
  183. ]);
  184. $res->message([
  185. 'phone.mobile' => '请填写正确手机格式'
  186. ]);
  187. if (!$res->check($data)){
  188. return app('json')->fail($res->getError());
  189. }
  190. if (!empty($pay)){
  191. if ($data['type'] == 1 ){
  192. // 微信收款方式
  193. if (!$data['payment']) return app('json')->fail('微信账号不能为空');
  194. if (!$data['image']) return app('json')->fail('二维码不能为空');
  195. if (!$data['name']) return app('json')->fail('姓名不能为空');
  196. $pay['payment'] = $data['payment'];
  197. $pay['image'] = $data['image'];
  198. $pay['name'] = $data['name'];
  199. $pay['phone'] = $data['phone'];
  200. }elseif ($data['type'] == 2){
  201. // 支付宝收款方式
  202. if (!$data['payment']) return app('json')->fail('支付宝账号不能为空');
  203. if (!$data['name']) return app('json')->fail('姓名不能为空');
  204. $pay['payment'] = $data['payment'];
  205. $pay['name'] = $data['name'];
  206. $pay['phone'] = $data['phone'];
  207. }elseif ($data['type'] == 3){
  208. // 银行卡收款方式
  209. if (!$data['payment']) return app('json')->fail('银行卡号不能为空');
  210. if (!$data['name']) return app('json')->fail('姓名不能为空');
  211. if (!$data['bank']) return app('json')->fail('开户行不能为空');
  212. if (!$data['bank_name']) return app('json')->fail('开户支行不能为空');
  213. if (!$data['phone']) return app('json')->fail('请填写手机号');
  214. $pay['payment'] = $data['payment'];
  215. $pay['bank'] = $data['bank'];
  216. $pay['bank_name'] = $data['bank_name'];
  217. $pay['phone'] = $data['phone'];
  218. $pay['name'] = $data['name'];
  219. }
  220. $res = $pay->save();
  221. if ($res) return app('json')->successful('修改成功');
  222. return app('json')->fail('修改失败');
  223. }else{
  224. if ($data['type'] == 1 ){
  225. // 微信收款方式
  226. if (!$data['payment']) return app('json')->fail('微信账号不能为空');
  227. if (!$data['image']) return app('json')->fail('二维码不能为空');
  228. if (!$data['name']) return app('json')->fail('姓名不能为空');
  229. if (!$data['phone']) return app('json')->fail('请填写手机号');
  230. }elseif ($data['type'] == 2){
  231. // 支付宝收款方式
  232. if (!$data['payment']) return app('json')->fail('支付宝账号不能为空');
  233. if (!$data['name']) return app('json')->fail('姓名不能为空');
  234. if (!$data['phone']) return app('json')->fail('请填写手机号');
  235. }elseif ($data['type'] == 3){
  236. // 银行卡收款方式
  237. if (!$data['payment']) return app('json')->fail('银行卡号不能为空');
  238. if (!$data['name']) return app('json')->fail('姓名不能为空');
  239. if (!$data['bank']) return app('json')->fail('开户行不能为空');
  240. if (!$data['bank_name']) return app('json')->fail('开户支行不能为空');
  241. if (!$data['phone']) return app('json')->fail('请填写手机号');
  242. }
  243. $res = $model->save($data);
  244. if ($res) return app('json')->successful('添加成功');
  245. return app('json')->fail('添加失败');
  246. }
  247. }
  248. /**
  249. * 收款方式详情
  250. * @param Request $request
  251. * @return mixed
  252. * @throws \think\db\exception\DataNotFoundException
  253. * @throws \think\db\exception\DbException
  254. * @throws \think\db\exception\ModelNotFoundException
  255. */
  256. public function pay_list(Request $request)
  257. {
  258. $model = new AuctionPay();
  259. $list = $model->where('uid', $request->uid())->select();
  260. $list = empty($list)? []: $list->toArray();
  261. $data['wx'] = [];
  262. $data['zfb'] = [];
  263. $data['bank'] = [];
  264. foreach ($list as $k => $v){
  265. if ($v['type'] == 1){
  266. $data['wx'] = $v;
  267. }elseif ($v['type'] == 2){
  268. $data['zfb'] = $v;
  269. }elseif ($v['type'] == 3){
  270. $data['bank'] = $v;
  271. }
  272. }
  273. return app('json')->successful($data);
  274. }
  275. }