Betorder.php 51 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361
  1. <?php
  2. namespace App\Api\Controller;
  3. use Biz\Money\Moneycopy;
  4. use Biz\Money\Money;
  5. use Biz\Account\AccountManager;
  6. use App\Api\Model\St_odds_code as odds_codeModel;
  7. use App\Api\Model\Dc_user_grade;
  8. use Biz\Db\Redis\Cache as Redis;
  9. use Illuminate\Support\Testing\Fakes\QueueFake;
  10. // use Illuminate\Contracts\Queue\Queue;
  11. /*
  12. * Class Register
  13. * @package App\Api\Controller
  14. * User: junghwi
  15. * Date: 2019/3/21
  16. */
  17. class Betorder extends BaseController{
  18. private $simplex_money = 0; //单式投注总额
  19. public function init() {
  20. $this->time = date('Y-m-d H:i:s',time());
  21. $this->MC = new Moneycopy();
  22. $this->M = new Money();
  23. $this->accountManager = new AccountManager();
  24. $this->commonFunction = C()->get('commonFunction');
  25. }
  26. /**
  27. * 测试写队列 任务
  28. */
  29. public function dd(){
  30. //laterOn
  31. //实例化 队列
  32. $Queue = new QueueFake();
  33. //新建队列 任务
  34. $Queue ->push('a','c','123');
  35. /*
  36. $redis = new Redis();
  37. $redis->set('name','pengjun');
  38. $name = $redis->get('name');
  39. dd($name);
  40. */
  41. }
  42. /**
  43. * 单式串式分类
  44. * @param [array] $res 投注数据
  45. * @return [array] $data
  46. *
  47. */
  48. public function Classify(array $res){
  49. if(empty($res)){
  50. Render($res, '7003',lang('Errors','Api')->get('error-7003'));
  51. }
  52. $data['single'] = [];//单式
  53. $data['bunch'] = [];//串式
  54. $last[] = $res[count($res)-1];
  55. unset($res[count($res)-1]);
  56. foreach ($last as $k =>$v){
  57. foreach ($v as $kk =>$vv){
  58. /*
  59. $num = $kk+1;
  60. //验证球类代码是否有效
  61. $this->verify_gameType($vv['ballId'],$num);
  62. //验证联赛是否存在
  63. $this->verify_league($vv['ballId'],(int)$vv['lg_id'],$num);
  64. //验证赛事/赔率代码是否存在,如果match_id = 0 则为冠军联赛赔率,无需验证
  65. if($vv['match_id'] > 0 and $vv['is_champion'] == 0){
  66. $this->verify_match($vv['ballId'],$vv['match_id'],$num);
  67. //验证赛事下赔率玩法是否有效
  68. $this->verify_odds($vv['ballId'],$vv['odds_only'],$vv['odds'],$vv['condition'],$vv['odds_code'],$num);
  69. }
  70. */
  71. }
  72. }
  73. foreach($res as $k => $v){
  74. //根据类型分组
  75. if($v['type'] == '1'){
  76. $data['single'][$k] = array_merge($last[0][$v['index']],$v);
  77. }else{
  78. $data['bunch'][$k] = $v;
  79. }
  80. }
  81. if(!empty($data['bunch'])){
  82. $data['bunch'] = array_merge_recursive($data['bunch'],$last);
  83. }
  84. return $data;
  85. }
  86. /**
  87. * 根据赛事ID分组
  88. * @param [array] $data 球类数据
  89. * @return [array] $data
  90. */
  91. public function Group_ball($data = []){
  92. if(empty($data)){
  93. return $data;
  94. }
  95. foreach($data as $k => $v){
  96. //普通赛事
  97. if($v['match_id'] > 0){
  98. if(!isset($data[$v['match_id']])){
  99. $data[$v['match_id']][] = $v;
  100. unset($data[$k]);
  101. }else{
  102. $data[$v['match_id']][] = $v;
  103. unset($data[$k]);
  104. }
  105. }
  106. //冠军联赛
  107. if($v['match_id'] == 0){
  108. if(!isset($data[$v['lg_id']])){
  109. $data[$v['lg_id']][] = $v;
  110. unset($data[$k]);
  111. }else{
  112. $data[$v['lg_id']][] = $v;
  113. unset($data[$k]);
  114. }
  115. }
  116. }
  117. return $data;
  118. }
  119. /**
  120. * 单式投注数据处理
  121. * @param [array] $res 单式投注数据
  122. * @return [int] 1 成功 其他失败
  123. * @param [int] $batch_id 批量ID
  124. * 弃用
  125. */
  126. public function Simplex_bet(array $res,array $userInfo,$batch_id){
  127. if(empty($res)||empty($userInfo)||empty($batch_id)){
  128. Render('', '7003',lang('Errors','Api')->get('error-7003'));
  129. }
  130. //验证与判断投注了几种
  131. foreach($res as $k => $v){
  132. $num = $k + 1;
  133. if(empty($v['bet_amount'])){
  134. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5105');
  135. Render([], '5105',$msg);
  136. }
  137. //根据类型分组
  138. if(!isset($res[$v['ballId']])){
  139. $res[$v['ballId']][] = $v;
  140. unset($res[$k]);
  141. }else{
  142. $res[$v['ballId']][] = $v;
  143. unset($res[$k]);
  144. }
  145. }
  146. //球类联赛分类并且插入数据库
  147. foreach($res as $k => $v){
  148. $this->Simplex_bet_insert($v,$userInfo,$k,$batch_id);
  149. /*
  150. $gamedate = $this->Group_ball($res[$k]);
  151. $this->Simplex_bet_insert($gamedate,$userInfo,$k,$batch_id);
  152. */
  153. }
  154. return $odds_ids;
  155. }
  156. //弃用 备份
  157. public function Simplex_bet___(array $res,array $userInfo,$batch_id){
  158. if(empty($res)||empty($userInfo)||empty($batch_id)){
  159. Render('', '7003',lang('Errors','Api')->get('error-7003'));
  160. }
  161. //验证与判断投注了几种
  162. foreach($res as $k => $v){
  163. $num = $k + 1;
  164. if(empty($v['bet_amount'])){
  165. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5105');
  166. Render([], '5105',$msg);
  167. }
  168. //根据类型分组
  169. if(!isset($res[$v['ballId']])){
  170. $res[$v['ballId']][] = $v;
  171. unset($res[$k]);
  172. }else{
  173. $res[$v['ballId']][] = $v;
  174. unset($res[$k]);
  175. }
  176. }
  177. //球类联赛分类并且插入数据库
  178. foreach($res as $k => $v){
  179. $gamedate = $this->Group_ball($res[$k]);
  180. $this->Simplex_bet_insert($gamedate,$userInfo,$k,$batch_id);
  181. }
  182. return $odds_ids;
  183. }
  184. /**
  185. * 单式投注单个球类数据插入
  186. * @param [array] $data 单式投注数据
  187. * @param [array] $userInfo 用户信息
  188. * @param [type] $game_code 球类代码
  189. * @param [int] $batch_id 批量ID
  190. * @return [int] 1 成功 其他失败
  191. */
  192. public function Simplex_bet_insert__($data,$userInfo,$game_code,$batch_id){
  193. if(empty($data)||empty($userInfo)||empty($game_code)){
  194. Render('', '7003',lang('Errors','Api')->get('error-7003'));
  195. }
  196. foreach($data as $k => $v){
  197. $OrderID = OrderID('S');//生成订单ID
  198. $UUID = UUID(); //生成信息ID
  199. $bet_money = 0; //赛事总投注额
  200. $prize_money = 0; //可赢额
  201. //获取投注单中是否有冠军联赛数据
  202. $championData = [];
  203. foreach($v as $kk => $vv){
  204. $bet_money += $vv['bet_amount'];
  205. //计算每个投注玩法下的可赢金额
  206. // $prize_money += $this->commonFunction->getEarnMoney($game_code,$vv['p_code'],$vv['odds'],$vv['bet_amount'],1);
  207. $prize_money += $vv['odds']* $vv['bet_amount'];
  208. //是否是滚球投注
  209. $is_rolling = 0;
  210. if($vv['oddsType']=='StRollBall'){
  211. $is_rolling = 1;
  212. }
  213. $matchData =[
  214. 'odds_id' =>$vv['id'],
  215. 'home_team' => $vv['home_team'],
  216. 'guest_team' => $vv['guest_team'],
  217. 'condition' => $vv['condition'],
  218. 'odds' => $vv['odds'],
  219. 'odds_code' => $vv['odds_code'],
  220. 'p_code' => $vv['p_code'],
  221. 'odds_only' => $vv['odds_only'],
  222. 'match_id' => $vv['match_id'],
  223. 'game_code' => $game_code,
  224. 'lg_id' => $vv['lg_id'],
  225. 'batch_id' => $batch_id,
  226. 'bet_type' => 1,
  227. 'bet_money' => $vv['bet_amount'],
  228. 'ctime' => $this->time,
  229. 'utime' => $this->time,
  230. 'is_rolling' =>$is_rolling,
  231. ];
  232. //插入数据源
  233. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  234. if(!$moneyBuyMatch){
  235. Render('','3205',lang('errors','Api')->get('error-3205'));
  236. }
  237. }
  238. $order =[
  239. 'info_identity' => $UUID,
  240. 'account_name' => $userInfo['account'],
  241. 'account_identity' => $userInfo['account_identity'],
  242. 'order_id' => OrderID('S'),//$OrderID,
  243. 'game_code' => $game_code,
  244. 'batch_id' => $batch_id,
  245. 'match_id' => $k,
  246. 'game_no' => "",
  247. 'prize_money'=> $prize_money,
  248. 'money' => $bet_money, //投注金额
  249. 'money_time' => $this->time
  250. ];
  251. $insert = lm("MoneyBuySimplex",'Api')->insert($order);
  252. if(!$insert){
  253. Render('','3205',lang('errors','Api')->get('error-3205'));
  254. }
  255. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$bet_money,$OrderID,1,"",$UUID,$userInfo);
  256. if($insertMoney!=1){
  257. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  258. }
  259. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$bet_money,$OrderID);//反水
  260. }
  261. }
  262. //按赛事分组 一个赛事一个注单
  263. public function Simplex_bet_insert_v1($data,$userInfo,$game_code,$batch_id){
  264. if(empty($data)||empty($userInfo)||empty($game_code)){
  265. Render('', '7003',lang('Errors','Api')->get('error-7003'));
  266. }
  267. foreach($data as $k => $v){
  268. $OrderID = OrderID('S');//生成订单ID
  269. $UUID = UUID(); //生成信息ID
  270. $bet_money = 0; //赛事总投注额
  271. $prize_money = 0; //可赢额
  272. foreach($v as $kk => $vv){
  273. //是否是冠军投注,如果==0 则为冠军投注
  274. $is_champion = 0;
  275. if($vv['match_id'] == 0){
  276. $is_champion = 1;
  277. }
  278. //获取联赛id lg_id
  279. $lg_id = $vv['lg_id'];
  280. $bet_money += $vv['bet_amount'];
  281. //计算每个投注玩法下的可赢金额
  282. // $prize_money += $this->commonFunction->getEarnMoney($game_code,$vv['p_code'],$vv['odds'],$vv['bet_amount'],1);
  283. $prize_money += $vv['odds']* $vv['bet_amount'];
  284. //是否是滚球投注
  285. $is_rolling = 0;
  286. if($vv['oddsType']=='StRollBall'){
  287. $is_rolling = 1;
  288. }
  289. $matchData =[
  290. 'odds_id' =>$vv['id'],
  291. 'home_team' => $vv['home_team'],
  292. 'guest_team' => $vv['guest_team'],
  293. 'condition' => $vv['condition'],
  294. 'odds' => $vv['odds'],
  295. 'odds_code' => $vv['odds_code'],
  296. 'p_code' => $vv['p_code'],
  297. 'odds_only' => $vv['odds_only'],
  298. 'match_id' => $vv['match_id'],
  299. 'game_code' => $game_code,
  300. 'lg_id' => $vv['lg_id'],
  301. 'batch_id' => $batch_id,
  302. 'bet_type' => 1,
  303. 'bet_money' => $vv['bet_amount'],
  304. 'ctime' => $this->time,
  305. 'utime' => $this->time,
  306. 'is_rolling' =>$is_rolling,
  307. 'is_champion' => $is_champion?:0,//1 冠军投注 0普通赛事投注
  308. 'order_id'=>$OrderID,//追加所属订单id
  309. ];
  310. //插入数据源
  311. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  312. if(!$moneyBuyMatch){
  313. Render('','3205',lang('errors','Api')->get('error-3205'));
  314. }
  315. }
  316. $order = [];
  317. $order =[
  318. 'info_identity' => $UUID,
  319. 'account_name' => $userInfo['account'],
  320. 'account_identity' => $userInfo['account_identity'],
  321. 'order_id' => $OrderID,//$OrderID,
  322. 'game_code' => $game_code,
  323. 'batch_id' => $batch_id,
  324. 'match_id' => $k,
  325. 'lg_id' => $lg_id,
  326. 'game_no' => "",
  327. 'prize_money'=> $prize_money,
  328. 'money' => $bet_money, //投注金额
  329. 'money_time' => $this->time,
  330. 'is_champion' => $is_champion?:0,//1 冠军投注 0普通赛事投注
  331. ];
  332. //如果是冠军投注,追加字段
  333. if($is_champion == 1){
  334. $json_single_result = [
  335. 'lg_id'=> '',
  336. 'game_name' => '',
  337. 'result' => '',
  338. 'updatetime' => '',
  339. ];
  340. $order['single_result'] = json_encode($json_single_result);
  341. }
  342. //如果是滚球投注,追加字段
  343. if($is_rolling == 1 and $game_code == 'zq'){
  344. $order['roll_ratify'] = 2;//未审核滚球投注
  345. }
  346. $insert = lm("MoneyBuySimplex",'Api')->insert($order);
  347. if(!$insert){
  348. Render('','3205',lang('errors','Api')->get('error-3205'));
  349. }
  350. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$bet_money,$OrderID,1,"",$UUID,$userInfo);
  351. if($insertMoney!=1){
  352. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  353. }
  354. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$bet_money,$OrderID);//反水
  355. }
  356. }
  357. //无需按赛事分组
  358. public function Simplex_bet_insert($data,$userInfo,$game_code,$batch_id){
  359. if(empty($data)||empty($userInfo)||empty($game_code)){
  360. Render('', '7003',lang('Errors','Api')->get('error-7003'));
  361. }
  362. foreach($data as $k => $v){
  363. $OrderID = OrderID('S');//生成订单ID
  364. $UUID = UUID(); //生成信息ID
  365. $bet_money = 0; //赛事总投注额
  366. $prize_money = 0; //可赢额
  367. //====处理 投注数据
  368. //是否是冠军投注,如果==0 则为冠军投注
  369. $is_champion = 0;
  370. if($v['match_id'] == 0){
  371. $is_champion = 1;
  372. }
  373. //获取联赛id lg_id
  374. $lg_id = $v['lg_id'];
  375. $bet_money = $v['bet_amount'];
  376. //计算每个投注玩法下的可赢金额
  377. $prize_money = $v['odds']* $v['bet_amount'];
  378. //是否是滚球投注
  379. $is_rolling = 0;
  380. if($v['oddsType']=='StRollBall'){
  381. $is_rolling = 1;
  382. $roll_time=$v['roll_time']?:'';//追加滚球投注时 赛事进行时间
  383. $home_score = $v['home_score']?:0;//主队得分
  384. $guest_score = $v['guest_score']?:0;//客队得分
  385. }
  386. //===追加各球类其他状态码===
  387. //即将
  388. if($v['oddsType']=='StSoon'){
  389. $is_rolling = 2;
  390. }
  391. //今日
  392. if($v['oddsType']=='StToday'){
  393. $is_rolling = 3;
  394. }
  395. //早盘
  396. if($v['oddsType']=='StMorningPlate'){
  397. $is_rolling = 4;
  398. }
  399. //串场
  400. if($v['oddsType']=='StStringScene'){
  401. $is_rolling = 5;
  402. }
  403. //冠军
  404. if($v['oddsType']=='StChampion'){
  405. $is_rolling = 6;
  406. }
  407. //===end===
  408. $matchData =[
  409. 'odds_id' =>$v['id'],
  410. 'home_team' => $v['home_team'],
  411. 'guest_team' => $v['guest_team'],
  412. 'condition' => $v['condition'],
  413. 'odds' => $v['odds'],
  414. 'odds_code' => $v['odds_code'],
  415. 'p_code' => $v['p_code'],
  416. 'odds_only' => $v['odds_only'],
  417. 'match_id' => $v['match_id'],
  418. 'game_code' => $game_code,
  419. 'lg_id' => $lg_id,
  420. 'batch_id' => $batch_id,
  421. 'bet_type' => 1,
  422. 'bet_money' => $bet_money,
  423. 'ctime' => $this->time,
  424. 'utime' => $this->time,
  425. 'is_rolling' =>$is_rolling,
  426. 'is_champion' => $is_champion?:0,//1 冠军投注 0普通赛事投注
  427. 'order_id'=>$OrderID,//追加所属订单id
  428. 'roll_time'=>$roll_time,//追加滚球投注时 赛事进行时间
  429. 'home_score'=>$home_score,//主队得分
  430. 'guest_score'=>$guest_score,//客队得分
  431. ];
  432. //插入数据源
  433. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  434. if(!$moneyBuyMatch){
  435. Render('','3205',lang('errors','Api')->get('error-3205'));
  436. }
  437. //===end===
  438. $order = [];
  439. $order =[
  440. 'info_identity' => $UUID,
  441. 'account_name' => $userInfo['account'],
  442. 'account_identity' => $userInfo['account_identity'],
  443. 'order_id' => $OrderID,//$OrderID,
  444. 'game_code' => $game_code,
  445. 'batch_id' => $batch_id,
  446. 'match_id' => $v['match_id'],
  447. 'lg_id' => $lg_id,
  448. 'game_no' => "",
  449. 'prize_money'=> $prize_money,
  450. 'money' => $bet_money, //投注金额
  451. 'money_time' => $this->time,
  452. 'is_champion' => $is_champion?:0,//1 冠军投注 0普通赛事投注
  453. ];
  454. //如果是冠军投注,追加字段
  455. if($is_champion == 1){
  456. $json_single_result = [
  457. 'lg_id'=> '',
  458. 'game_name' => '',
  459. 'result' => '',
  460. 'updatetime' => '',
  461. ];
  462. $order['single_result'] = json_encode($json_single_result);
  463. }
  464. //如果是滚球投注,追加字段
  465. if($is_rolling == 1 and $game_code == 'zq'){
  466. $order['roll_ratify'] = 2;//未审核滚球投注
  467. }
  468. $insert = lm("MoneyBuySimplex",'Api')->insert($order);
  469. if(!$insert){
  470. Render('','3205',lang('errors','Api')->get('error-3205'));
  471. }
  472. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$bet_money,$OrderID,1,"",$UUID,$userInfo);
  473. if($insertMoney!=1){
  474. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  475. }
  476. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$bet_money,$OrderID);//反水
  477. }
  478. }
  479. public function Bet(){
  480. /*
  481. // 模拟单式数据
  482. $get_data = [
  483. 'data'=>[
  484. [
  485. 'type'=>1,
  486. 'index'=>0,
  487. 'bet_amount'=>100,
  488. ],
  489. [
  490. 'type'=>1,
  491. 'index'=>1,
  492. 'bet_amount'=>100,
  493. ],
  494. [
  495. [
  496. 'id'=>10350565,
  497. 'home_team'=>'什鲁斯伯里',
  498. 'guest_team'=>'彼德堡',
  499. 'name'=>'大',
  500. 'odds'=>1.09,
  501. 'match_id'=>1463,
  502. 'condition'=>'2.5/3',
  503. 'ballId'=>'zq',
  504. 'odds_code'=>'gsb',
  505. 'p_code'=>'GS',
  506. 'play_name'=>'进球大小',
  507. 'score'=>0,
  508. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  509. 'odds_only'=>'6a003dec710a42849a82dd1ea978f572',
  510. 'lg_id'=>17,
  511. 'match_type'=>'',//滚球投注
  512. 'odds_id'=>10350565,
  513. 'repeat'=>'true',
  514. 'is_champion'=>0,//是否是冠军联赛
  515. ],
  516. [
  517. 'id'=>10781633,
  518. 'home_team'=>'什鲁斯伯里',
  519. 'guest_team'=>'彼德堡',
  520. 'name'=>'彼德堡',
  521. 'odds'=>1,
  522. 'match_id'=>1463,
  523. 'condition'=>'-0/0.5',
  524. 'ballId'=>'zq',
  525. 'odds_code'=>'cog',
  526. 'p_code'=>'CO',
  527. 'play_name'=>'让球',
  528. 'score'=>0,
  529. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  530. 'odds_only'=>'390e2b68992587438c0020179abc94f5',
  531. 'lg_id'=>17,
  532. 'match_type'=>'',//滚球投注
  533. 'odds_id'=>10781633,
  534. 'repeat'=>'true',
  535. 'is_champion'=>0,//是否是冠军联赛
  536. ]
  537. ]
  538. ],
  539. 'token'=>'hdetVs15729386035dc1236b1c189',
  540. 'bet_money'=>200,
  541. ];
  542. */
  543. /*
  544. // 模拟串式数据
  545. $get_data = [
  546. 'data'=>[
  547. [
  548. 'type'=>1,
  549. 'index'=>0,
  550. 'bet_amount'=>1,
  551. ],
  552. [
  553. 'type'=>'3串1',
  554. 'bet_amount' =>1,
  555. ],
  556. [
  557. [
  558. 'id'=>229351,
  559. 'home_team'=>'布琳狮子U20',
  560. 'guest_team'=>'圣奥尔本斯U20',
  561. 'name'=>'圣奥尔本斯U20',
  562. 'odds'=>1.01,
  563. 'match_id'=>0,
  564. 'condition'=>'4/4.5',
  565. 'ballId'=>'zq',
  566. 'odds_code'=>'goal_size_big',
  567. 'p_code'=>'goal_size',
  568. 'play_name'=>'大小',
  569. 'score'=>0,
  570. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  571. 'odds_only'=>'908f8bae2233a0384c96c7b1f42e9ea7',
  572. 'lg_id'=>153,
  573. 'repeat'=>'false',
  574. 'match_type'=>'StRollBall',//滚球投注
  575. ],
  576. [
  577. 'id'=>238940,
  578. 'home_team'=>'格罗兹尼艾哈迈德U20',
  579. 'guest_team'=>'奥伦堡U20',
  580. 'name'=>'格罗兹尼艾哈迈德U20',
  581. 'odds'=>0.94,
  582. 'match_id'=>1247,
  583. 'condition'=>'1/1.5',
  584. 'ballId'=>'zq',
  585. 'odds_code'=>'concede_home',
  586. 'p_code'=>'concede',
  587. 'play_name'=>'让球',
  588. 'score'=>0,
  589. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  590. 'odds_only'=>'9125bf40d6649fcdb663c43d8f55bebd',
  591. 'lg_id'=>20,
  592. 'repeat'=>'false',
  593. 'match_type'=>'StRollBall',//滚球投注
  594. ],
  595. [
  596. 'id'=>238958,
  597. 'home_team'=>'巴扬卡拉',
  598. 'guest_team'=>'马都拉联',
  599. 'name'=>'巴扬卡拉',
  600. 'odds'=>1.13,
  601. 'match_id'=>1254,
  602. 'condition'=>'0.5',
  603. 'ballId'=>'zq',
  604. 'odds_code'=>'concede_home',
  605. 'p_code'=>'concede',
  606. 'play_name'=>'让球',
  607. 'score'=>0,
  608. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  609. 'odds_only'=>'3cf81ac0b9765218845fe8bc4de0ad99',
  610. 'lg_id'=>61,
  611. 'repeat'=>'false',
  612. 'match_type'=>'StRollBall',//滚球投注
  613. ],
  614. ]
  615. ],
  616. 'token'=>'ppWGRW15682541865d79a8eacb0b1',
  617. 'bet_money'=>2
  618. ];
  619. */
  620. //如果获取不到data,则为游戏端提交,需转成数组
  621. if(!empty($_POST['game_data'])){
  622. //获取参数转成数组
  623. $get_data = json_decode($_POST['game_data'],true);
  624. $token = $get_data['token'];
  625. $bet_money = $get_data['bet_money'];
  626. $data = $get_data['data'];
  627. // $bet_money_arr = $get_data['bet_money_arr'];
  628. }else{
  629. $data = $_REQUEST['data'];
  630. $bet_money = $_REQUEST['bet_money'];
  631. $token = $_REQUEST['token'];
  632. // $bet_money_arr = $_REQUEST['bet_money_arr'];
  633. }
  634. /*
  635. $data = $get_data['data'];
  636. $bet_money = $get_data['bet_money'];
  637. $token = $get_data['token'];
  638. */
  639. //验证用户token
  640. $userInfo = $this->getAgent($token);
  641. if(empty($data)||empty($bet_money)){
  642. Render('', '51029',lang('Errors','Api')->get('error-51029'));
  643. }
  644. //获取用户金额信息
  645. if(!$this->M->verifyMoney($bet_money,$userInfo['cash'])){
  646. Render('', '4204',lang('Errors','Api')->get('error-4204'));
  647. }
  648. //追加验证用户投注金额限额
  649. $this->bet_money_limit($data,$userInfo);
  650. //获取订单批次号
  651. $batch_id = OrderID();///strtotime(date('Y-m-d H:i:s',time())).mt_rand('1','99');//批量ID
  652. //执行数据插入
  653. try {
  654. _beginTransaction();//开启事务
  655. $data = $this->Classify($data);
  656. if(!empty($data['single'])){
  657. $this->Simplex_bet($data['single'],$userInfo,$batch_id);//单式数据处理
  658. }
  659. if(!empty($data['bunch'])){
  660. $data_all = $data['bunch'][count($data['bunch'])-1];//获取最后一个数组
  661. unset($data['bunch'][count($data['bunch'])-1]);//删除最后一个元素
  662. $this->stringBet($data['bunch'],$data_all,$userInfo,$batch_id);
  663. }
  664. _commit();//提交
  665. Render('', '1',lang('Errors','Api')->get('error-1'));
  666. } catch (Exception $e) {
  667. _rollBack();//回滚
  668. print $e->getMessage();
  669. }
  670. }
  671. /**
  672. * token获取用户详情
  673. */
  674. public function getAgent($token = '') {
  675. $checkToken = $this->accountManager->checkEffectiveTime($token);
  676. if ($checkToken['status'] != 1) {
  677. Render($checkToken['data'], $checkToken['status'], lang('commons')->get('user does login'));
  678. };
  679. $result = $this->accountManager->refreshToken($token);
  680. return $result['data'];
  681. }
  682. //验证联赛是否存在
  683. public function verify_league($game_code,$lg_id,$num = 1){
  684. if(empty($lg_id)){
  685. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5112');
  686. Render([], '5112',$msg);
  687. }
  688. //根据球类代码 获取相关model
  689. $model = $this->commonFunction->getModels($game_code);
  690. $model_league = $model['model_league'];
  691. $info = lm($model_league,'Sports')
  692. ->select('id')
  693. ->where('id',$lg_id)
  694. ->first();
  695. if(empty($info)){
  696. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5113');
  697. Render([], '5113',$msg);
  698. }
  699. }
  700. /**
  701. * 赛事是否存在或结束
  702. * @param [type] $game_code 球类代码
  703. * @param [type] $match_id 赔率ID
  704. * @param [type] $num 循环键值
  705. * $@param [type]type_str 串式
  706. *
  707. */
  708. public function verify_match($game_code,$match_id,$num = 1){
  709. if(empty($match_id)){
  710. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5109');
  711. Render([], '5109',$msg);
  712. }
  713. //根据球类代码 获取相关model
  714. $models = $this->commonFunction->getModels($game_code);
  715. $model_match = $models['model_match'];
  716. $info = lm($model_match,'Sports')
  717. ->select('status')
  718. ->where('status', '<', '2')
  719. // ->where('us_time','>',qgmdate('Y-m-d H:i:s','', -4))
  720. // ->where('source','hg3535')
  721. ->where('id',$match_id)
  722. ->first();
  723. if(empty($info)){
  724. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5103');
  725. Render([], '5103',$msg);
  726. }
  727. $info = $info->toarray();
  728. if($info['status'] == 2){
  729. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5108');
  730. Render([], '5108',$msg);
  731. }
  732. return $info;
  733. }
  734. /**
  735. * 验证球类是否存在
  736. * @param [type] $game_code 球类代码
  737. * @param [type] $num 第几条
  738. */
  739. public function verify_gameType($game_code,$num){
  740. if(empty($game_code)){
  741. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-5102');
  742. Render([], '5102', $msg);
  743. }
  744. $info = lm('GameType','Sports')->where('game_code',$game_code)->first();
  745. if(empty($info)){
  746. $msg = '第' . $num . '条数据' . lang('Errors', 'Api')->get('error-5102');
  747. Render([], '5102', $msg);
  748. }
  749. return $info;
  750. }
  751. /**
  752. * 验证赔率是否存在
  753. * @param [type] $game_code 球类代码
  754. * @param [type] $odds_id 赔率IDkk
  755. *
  756. */
  757. public function verify_odds($game_code,$odds_only,$odds,$condition,$odds_code,$num = 1){
  758. if (empty($odds_only)){
  759. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-5111');
  760. Render([], '5111', $msg);
  761. }
  762. if(empty($odds_code)){
  763. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7052');
  764. Render([], '7052', $msg);
  765. }
  766. if(empty($odds)){
  767. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7029');
  768. Render([], '7029', $msg);
  769. }
  770. $odds_codeNum = odds_codeModel::getOddsCode($odds_code,$game_code);
  771. if($odds_codeNum < 1){
  772. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7053');
  773. Render([], '7053', $msg);
  774. }
  775. //根据球类代码 获取相关model
  776. $models = $this->commonFunction->getModels($game_code);
  777. $model_odds = $models['model_odds'];
  778. $model_odds_record = $models['model_odds_record'];
  779. //匹配赔率是否过期
  780. $odds_info = lm($model_odds,'Sports')
  781. ->join($model_odds_record,$model_odds_record.'.odds_only',$model_odds.'.odds_only')
  782. ->select($model_odds_record.'.odds',$model_odds_record.'.condition')
  783. ->where($model_odds.'.odds_only',$odds_only)
  784. ->first();
  785. if(empty($odds_info)){
  786. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7051');
  787. Render([], '7051', $msg);
  788. }
  789. $odds_info = $odds_info->toarray();
  790. if($condition != $odds_info['condition']){
  791. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7047');
  792. Render([], '7047', $msg);
  793. }
  794. if($odds != $odds_info['odds']){
  795. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7049');
  796. Render([], '7049', $msg);
  797. }
  798. return $odds_info;
  799. }
  800. /**
  801. * 处理串式投注
  802. * $data_str 各串式 数据
  803. * $data_all 所有赛事 数据
  804. * $userInfo 用户数据
  805. * $batch_id 批次号
  806. */
  807. public function stringBet__($data_str=[],$data_all=[],$userInfo=[],$batch_id=0){
  808. //验证串式投注是否合法
  809. $this->verify_stringType($data_all);
  810. //获取串式 总赛事数量
  811. $groupNum = count($data_all);//总数量
  812. $orderData = [];
  813. foreach ($data_str as $k=>$v){
  814. //字符串替换
  815. $str = str_ireplace("串","_",$v['type']);
  816. //获取type 3_12
  817. $after = substr($str,strpos($str,"_")+1);
  818. //当前串式 值
  819. $sonNum = substr($str,0,strrpos($str,"_"));
  820. //获取倍数
  821. if((int)$after == 1){
  822. $multiple = $this->getMultiple($groupNum,(int)$sonNum);
  823. }else{
  824. $multiple =(int)$after;
  825. }
  826. //获取当前串式投注金额及可赢金额
  827. if($after == 1){
  828. $money_all = $this->getmakeMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  829. }else{
  830. $money_all = $this->getStrAllMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  831. }
  832. //投注金额
  833. $moneyData = $money_all['moneyData'];
  834. //可赢金额
  835. $prize_money = $money_all['prize_money'];
  836. $uuid = UUID();
  837. $orderID = OrderID('T');
  838. $orderData[$k]['info_identity'] = $uuid;
  839. $orderData[$k]['account_name'] = $userInfo['account'];
  840. $orderData[$k]['account_identity'] = $userInfo['account_identity'];
  841. $orderData[$k]['order_id'] = $orderID;
  842. $orderData[$k]['game_no'] = "";
  843. $orderData[$k]['money'] = $moneyData;//$pay_money//总投注金额
  844. $orderData[$k]['money_time'] = $this->time;//下注时间
  845. $orderData[$k]['prize_money'] = $prize_money;//$expect_money ;//预期总可赢金额
  846. $orderData[$k]['str_type'] = $v['type'];//串式类型
  847. $orderData[$k]['batch_id'] = $batch_id;//批次号
  848. $orderData[$k]['wait_match_num'] = count($data_all);//批次号
  849. //写资金变动表
  850. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$moneyData,$orderID,1,"",$uuid,$userInfo);
  851. if($insertMoney!=1){
  852. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  853. }
  854. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$moneyData,$orderID);//反水
  855. }
  856. //写注单 表
  857. $moneyBuy = lm('MoneyBuyStr','Api')->insert($orderData);
  858. if(!$moneyBuy){
  859. Render('','3205',lang('errors','Api')->get('error-3205'));
  860. }
  861. foreach ($data_all as $kk=>$vv){
  862. $getModels = $this->commonFunction->getModels($vv['ballId']);
  863. $model_match = $getModels['model_match'];
  864. //获取是否是滚球投注
  865. $is_rolling = 0;
  866. if($vv['match_type'] == 'StRollBall'){
  867. $is_rolling = 1;
  868. }
  869. $matchData[] = [
  870. 'batch_id'=>$batch_id,
  871. 'odds_id'=>$vv['id'],
  872. 'home_team'=>$vv['home_team'],
  873. 'guest_team'=>$vv['guest_team'],
  874. 'condition'=>$vv['condition'],
  875. 'odds'=>$vv['odds'],
  876. 'odds_code'=>$vv['odds_code'],
  877. 'p_code'=>$vv['p_code'],
  878. 'odds_only'=>$vv['odds_only'],
  879. 'status'=>0,
  880. 'match_id'=>$vv['match_id'],
  881. 'game_code'=>$vv['ballId'],
  882. 'lg_id'=> $vv['lg_id'],
  883. 'ctime'=>$this->time,//写入时间
  884. 'utime' => $this->time,
  885. 'bet_type'=>2,
  886. 'is_rolling'=>$is_rolling,
  887. 'order_id'=> $orderID,
  888. ];
  889. }
  890. //写赔率数据表
  891. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  892. if(!$moneyBuyMatch){
  893. Render('','3205',lang('errors','Api')->get('error-3205'));
  894. }
  895. return true;
  896. }
  897. public function stringBet($data_str=[],$data_all=[],$userInfo=[],$batch_id=0){
  898. //验证串式投注是否合法
  899. $this->verify_stringType($data_all);
  900. //获取串式 总赛事数量
  901. $groupNum = count($data_all);//总数量
  902. $orderData = [];
  903. foreach ($data_str as $k=>$v){
  904. //字符串替换
  905. $str = str_ireplace("串","_",$v['type']);
  906. //获取type 3_12
  907. $after = substr($str,strpos($str,"_")+1);
  908. //当前串式 值
  909. $sonNum = substr($str,0,strrpos($str,"_"));
  910. //获取倍数
  911. if((int)$after == 1){
  912. $multiple = $this->getMultiple($groupNum,(int)$sonNum);
  913. }else{
  914. $multiple =(int)$after;
  915. }
  916. //获取当前串式投注金额及可赢金额
  917. if($after == 1){
  918. $money_all = $this->getmakeMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  919. }else{
  920. $money_all = $this->getStrAllMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  921. }
  922. //投注金额
  923. $moneyData = $money_all['moneyData'];
  924. //可赢金额
  925. $prize_money = $money_all['prize_money'];
  926. $uuid = UUID();
  927. $orderID = OrderID('T');
  928. $orderData[$k]['info_identity'] = $uuid;
  929. $orderData[$k]['account_name'] = $userInfo['account'];
  930. $orderData[$k]['account_identity'] = $userInfo['account_identity'];
  931. $orderData[$k]['order_id'] = $orderID;
  932. $orderData[$k]['game_no'] = "";
  933. $orderData[$k]['money'] = $moneyData;//$pay_money//总投注金额
  934. $orderData[$k]['money_time'] = $this->time;//下注时间
  935. $orderData[$k]['prize_money'] = $prize_money;//$expect_money ;//预期总可赢金额
  936. $orderData[$k]['str_type'] = $v['type'];//串式类型
  937. $orderData[$k]['batch_id'] = $batch_id;//批次号
  938. $orderData[$k]['wait_match_num'] = count($data_all);//批次号
  939. //写资金变动表
  940. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$moneyData,$orderID,1,"",$uuid,$userInfo);
  941. if($insertMoney!=1){
  942. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  943. }
  944. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$moneyData,$orderID);//反水
  945. //===处理赛事数据===
  946. foreach ($data_all as $kk=>$vv){
  947. $getModels = $this->commonFunction->getModels($vv['ballId']);
  948. $model_match = $getModels['model_match'];
  949. //获取是否是滚球投注
  950. $is_rolling = 0;
  951. if($vv['match_type'] == 'StRollBall'){
  952. $is_rolling = 1;
  953. }
  954. $matchData[] = [
  955. 'batch_id'=>$batch_id,
  956. 'odds_id'=>$vv['id'],
  957. 'home_team'=>$vv['home_team'],
  958. 'guest_team'=>$vv['guest_team'],
  959. 'condition'=>$vv['condition'],
  960. 'odds'=>$vv['odds'],
  961. 'odds_code'=>$vv['odds_code'],
  962. 'p_code'=>$vv['p_code'],
  963. 'odds_only'=>$vv['odds_only'],
  964. 'status'=>0,
  965. 'match_id'=>$vv['match_id'],
  966. 'game_code'=>$vv['ballId'],
  967. 'lg_id'=> $vv['lg_id'],
  968. 'ctime'=>$this->time,//写入时间
  969. 'utime' => $this->time,
  970. 'bet_type'=>2,
  971. 'is_rolling'=>$is_rolling,
  972. 'order_id'=> $orderID,
  973. ];
  974. }
  975. }
  976. //写赔率数据表
  977. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  978. if(!$moneyBuyMatch){
  979. Render('','3205',lang('errors','Api')->get('error-3205'));
  980. }
  981. //===end===
  982. //写注单 表
  983. $moneyBuy = lm('MoneyBuyStr','Api')->insert($orderData);
  984. if(!$moneyBuy){
  985. Render('','3205',lang('errors','Api')->get('error-3205'));
  986. }
  987. return true;
  988. }
  989. /**
  990. * 计算串式投注 倍率
  991. * $groupNum 总赛事 数量
  992. * $sonNum 当前串式 数量
  993. */
  994. public function getMultiple($groupNum = 0,$sonNum = 0){
  995. if($groupNum and $sonNum){
  996. $group =1;
  997. for($i = $groupNum ; $i >($groupNum - $sonNum);$i--) {
  998. $group = $group * $i;
  999. }
  1000. $son =1;
  1001. for($i = $sonNum ; $i >0;$i--) {
  1002. $son = $son * $i;
  1003. }
  1004. }
  1005. return $group/$son;
  1006. }
  1007. /**
  1008. * @param int $sonNum 当前串式数量
  1009. * @param int $bet_amount 当前串式投注额
  1010. * @param int $multiple 当前串式倍数
  1011. * @param array $data_all 当前注单 所有投注数据
  1012. * @return mixed
  1013. * 计算当前串式投注总额、可赢总额
  1014. */
  1015. public function getmakeMoney($sonNum=0,$bet_amount=0,$multiple=0,$data_all=[],$after = 0){
  1016. $allNum = count($data_all);//所有数量
  1017. $odds_all = [];//所有投注项数据
  1018. foreach ($data_all as $k=>$v){
  1019. $odds_all[] = $v['odds']+1;
  1020. }
  1021. //投注总额
  1022. $data['moneyData'] = (double)$bet_amount*(double)$multiple;
  1023. if($sonNum == $allNum and (int)$after ==1){//N场赛事 N串一
  1024. //获取所有赛事赔率乘积
  1025. $odds = array_product($odds_all) - 1;
  1026. //获取可赢金额
  1027. $data['prize_money'] = sprintf("%.2f",substr(sprintf("%.3f", $bet_amount*$odds), 0, -1));//floor($bet_amount*$odds*100)/100;//保留两位小数
  1028. }
  1029. if($sonNum < $allNum and (int)$after ==1){//例:N场赛事 <N串一
  1030. //计算 组合赔率
  1031. $group = $this->commonFunction->combination($odds_all, $sonNum);
  1032. foreach ($group as $k=>$v){
  1033. $odds[] = array_product($v);
  1034. }
  1035. $odds = (array_sum($odds))-(count($odds));
  1036. //获取可赢金额
  1037. $data['prize_money'] = sprintf("%.2f",substr(sprintf("%.3f", $bet_amount*$odds), 0, -1));//floor($bet_amount*$odds*100)/100;
  1038. }
  1039. return $data;
  1040. }
  1041. /**
  1042. * 获取所有可用串式 N场赛事 2串1,3串1...N串1,N<11
  1043. * 并计算 其投注可赢金额
  1044. */
  1045. public function getStrAllMoney($sonNum=0,$bet_amount=0,$multiple=0,$data_all=[],$after = 0){
  1046. $d = [];
  1047. for ($i=2;$i<($sonNum+1);$i++){
  1048. $d[] = $i;
  1049. }
  1050. foreach ($d as $k=>$v){
  1051. $multiple = $this->getMultiple($sonNum,$v);
  1052. $money[] = $this->getmakeMoney($v,$bet_amount,$multiple,$data_all,1);
  1053. }
  1054. $data=array();
  1055. foreach($money as $k=>$v){
  1056. $data['moneyData']+=$v['moneyData'];
  1057. $data['prize_money']+=$v['prize_money'];
  1058. }
  1059. return $data;
  1060. }
  1061. /**
  1062. * 验证串式投注 是否合法
  1063. * $data 串式 所有赛事
  1064. */
  1065. public function verify_stringType($data=[]){
  1066. if($data){
  1067. foreach($data as $k=>$v){
  1068. if($v['match_id']==$v['match_id'] ){
  1069. $r[$v['match_id']][] = $v;
  1070. }
  1071. }
  1072. }
  1073. if($r){
  1074. foreach ($r as $k=>$v){
  1075. if(count($v) > 1){
  1076. $msg = lang('Errors','Api')->get('error-50038');
  1077. Render([], '50038',$msg);
  1078. }else if( $k == 0){
  1079. $msg = lang('Errors','Api')->get('error-50043');
  1080. Render([], '50043',$msg);
  1081. }
  1082. }
  1083. }
  1084. }
  1085. /**
  1086. * 更新投注项相关数据
  1087. */
  1088. public function getBetData(){
  1089. $data = $_REQUEST;
  1090. // $data = [['game_code'=>'zq','match_id'=>3095448,'odds_id'=>623078],['game_code'=>'zq','match_id'=>3095448,'odds_id'=>623078]];
  1091. foreach ($data as $k=>$v){
  1092. $getModels = $this->commonFunction->getModels($v['game_code']);
  1093. $model_match = $getModels['model_match'];
  1094. $model_odds = $getModels['model_odds'];
  1095. $oddsData = lm($model_match,"Sports")
  1096. ->join($model_odds,$model_odds.'.match_id',$model_match.'.id')
  1097. ->select($model_match.'.id as match_id',$model_match.'.match_date',$model_match.'.home_team',$model_match.'.guest_team',$model_odds.'.id as odds_id',$model_odds.'.p_code',$model_odds.'.odds_code',$model_odds.'.condition',$model_odds.'.odds',$model_odds.'.odds_only',$model_odds.'.status',$model_odds.'.sort')
  1098. // ->where($model_match.'.source',$this->source)
  1099. ->where($model_match.'.id',$v['match_id'])
  1100. ->where($model_odds.'.id',$v['odds_id'])
  1101. //->where($model_odds.'.expire_time','>',date("Y-m-d H:i:s"))
  1102. ->first();
  1103. $oddsData->game_code = $v['game_code'];
  1104. $betData[] = $oddsData;
  1105. }
  1106. Render($betData, '1', lang('Tips','Sports')->get('success'));
  1107. }
  1108. //用户投注限额验证
  1109. public function bet_money_limit($bet_money_arr=[],$userInfo=[]){
  1110. if(!empty($bet_money_arr)){
  1111. foreach($bet_money_arr as $k=>$v){
  1112. if($k == (count($bet_money_arr)-1)){
  1113. unset($bet_money_arr[$k]);
  1114. }
  1115. }
  1116. }
  1117. //===追加验证用户投注金额限额===
  1118. if(empty($bet_money_arr)) Render('', '3605',lang('Errors','Api')->get('error-3605'));
  1119. //获取当前用户分组名称
  1120. $substr = substr($userInfo['group_name'],strpos($userInfo['group_name'],'|')+1);
  1121. $role_name = substr($substr, 0, -1);
  1122. //获取用户分组的投注限额
  1123. $bet_money_limit = Dc_user_grade::get_bet_money_limit($role_name);
  1124. foreach($bet_money_arr as $k=>$v){
  1125. if($v['bet_amount'] < $bet_money_limit->lower_limit) Render(['bet_amount'=>$v['bet_amount'],'lower_limit'=>$bet_money_limit->lower_limit], '3406','第'.($k+1).'条'.lang('Errors','Api')->get('error-3406'));
  1126. if($v['bet_amount'] > $bet_money_limit->upper_limit) Render(['bet_amount'=>$v['bet_amount'],'upper_limit'=>$bet_money_limit->upper_limit], '3401','第'.($k+1).'条'.lang('Errors','Api')->get('error-3401'));
  1127. }
  1128. //===end==
  1129. }
  1130. //根据token获取用户投注限额
  1131. public function getBetMoneyLimit(){
  1132. //验证用户token
  1133. $token = $_REQUEST['token'];
  1134. $userInfo = $this->getAgent($token);
  1135. //获取当前用户分组名称
  1136. $substr = substr($userInfo['group_name'],strpos($userInfo['group_name'],'|')+1);
  1137. $role_name = substr($substr, 0, -1);
  1138. //获取用户分组的投注限额
  1139. $bet_money_limit = Dc_user_grade::get_bet_money_limit($role_name);
  1140. $data['bet_money_limit']=[
  1141. 'lower_limit'=>$bet_money_limit->lower_limit,
  1142. 'upper_limit'=>$bet_money_limit->upper_limit,
  1143. ];
  1144. Render($data, '1', lang('Tips','Sports')->get('success'));
  1145. }
  1146. /**
  1147. * 用户撤单操作 接口
  1148. * 单订单操作
  1149. */
  1150. public function reOrder(){
  1151. //获取球类代码
  1152. $order_id = $_REQUEST['order_id'];
  1153. $token = $_REQUEST['token'];
  1154. try {
  1155. if(empty($order_id)){
  1156. throw new \Exception(Render([], '10001', lang('Tips','Sports')->get('PARAM_ERROR')));
  1157. }
  1158. _beginTransaction();//开启事务
  1159. // 单式 S 串式 T
  1160. if(substr($order_id,0,1) == 'S'){
  1161. //单式订单 model
  1162. $order_model = 'money_buy_simplex';
  1163. }else{
  1164. //串式订单 model
  1165. $order_model = 'money_buy_str';
  1166. }
  1167. //查询订单信息
  1168. $order_data = lm($order_model,"Commons")
  1169. ->where('order_id',$order_id)
  1170. ->first();
  1171. //订单不存在
  1172. if(empty($order_data)) throw new \Exception(Render([], '10030', lang('Tips','Sports')->get('order_null')));
  1173. //订单非投注状态 不可撤单
  1174. if($order_data->status != 1) throw new \Exception(Render([], '10031', lang('Tips','Sports')->get('order_type_err')));
  1175. //获取用户数据
  1176. $userInfo = $this->getAgent($token);
  1177. //验证订单是否属于该用户
  1178. if($order_data->account_identity != $userInfo['account_identity']) throw new \Exception(Render([], '10025', lang('Tips','Sports')->get('auth_error').':不是该用户的订单'));
  1179. //获取用户账户余额
  1180. $cash = $userInfo['cash'];
  1181. //获取订单涉及金额
  1182. $where = [
  1183. ['trade_id','=',$order_id],
  1184. ['status','=',1]
  1185. ];
  1186. $odds_money_data = lm('money_details',"Commons")
  1187. ->select('info_identity','trade_id','account_name','account_identity','money','money_type','money_cash','trade_type','status')
  1188. ->where($where)
  1189. ->get();
  1190. if(empty($odds_money_data)) throw new \Exception(Render([], '10026', lang('Tips','Sports')->get('order_money_err')));
  1191. $odds_money_data = $odds_money_data -> toArray();
  1192. //获取订单投注金额
  1193. $odds_money_bet = 0;
  1194. //获取订单反水金额
  1195. $odds_money_fs = 0;
  1196. foreach($odds_money_data as $k=>$v){
  1197. if($v['trade_type'] == 1){
  1198. $odds_money_bet = $v['money'];
  1199. }
  1200. if($v['trade_type'] == 7){
  1201. $odds_money_fs = $v['money'];
  1202. }
  1203. }
  1204. //更新订单状态为已取消
  1205. $up_order = lm($order_model,"Commons")
  1206. ->where('order_id',$order_id)
  1207. ->update(['status'=>3,'use_mark'=>'用户撤单']);
  1208. if($up_order < 1) throw new \Exception(Render([], '10027', lang('Tips','Sports')->get('order_status_up_err')));
  1209. //===退款===
  1210. //需退回金额 = 投注金额-反水金额
  1211. $money = abs($odds_money_bet - $odds_money_fs);
  1212. //用户剩余金额
  1213. $new_available_cash = $cash + $money;
  1214. //组装新增数据
  1215. $set_money_data = [
  1216. 'info_identity' => UUID(),
  1217. 'trade_id' => $order_id,
  1218. 'account_name' => $userInfo['account'],
  1219. 'account_identity' => $userInfo['account_identity'],
  1220. 'money' => $money,
  1221. 'money_time' => date("Y-m-d H:i:s", time()),
  1222. 'money_type' => 1,
  1223. 'money_cash' => $new_available_cash,
  1224. 'trade_type' => 3,
  1225. 'trade_desc' => '用户撤单,退回投注资金:¥'.$money.';订单号:'.$order_id.'',
  1226. 'status' => 1,
  1227. ];
  1228. //更新用户数据
  1229. $ret_user = lm('account_detailed',"Commons")
  1230. ->where('account_identity', $v['account_identity'])
  1231. ->update(['available_cash' => $new_available_cash, 'cash' => $new_available_cash]);
  1232. if($ret_user < 1) throw new \Exception(Render([], '10028', lang('Tips','Sports')->get('up_user_err')));
  1233. //更新用户资金数据
  1234. $set_money = lm('money_details',"Commons")->insert($set_money_data);
  1235. if($set_money != true) throw new \Exception(Render([], '10029', lang('Tips','Sports')->get('add_money_err')));
  1236. //===end===
  1237. _commit();//提交
  1238. Render('', '1', lang('Tips','Sports')->get('success'));
  1239. } catch (\Exception $e) {
  1240. echo $e->getMessage();
  1241. }
  1242. }
  1243. }