Betorder.php 55 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445
  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. //追加滚球投注时 赛事进行时间
  381. $roll_time = 0;
  382. //主队得分
  383. $home_score = 0;
  384. //客队得分
  385. $guest_score = 0;
  386. if($v['oddsType']=='StRollBall'){
  387. $is_rolling = 1;
  388. $roll_time=$v['roll_time']?:'';
  389. $home_score = $v['home_score']?:0;
  390. $guest_score = $v['guest_score']?:0;
  391. }
  392. //===追加各球类其他状态码===
  393. //即将
  394. if($v['oddsType']=='StSoon'){
  395. $is_rolling = 2;
  396. }
  397. //今日
  398. if($v['oddsType']=='StToday'){
  399. $is_rolling = 3;
  400. }
  401. //早盘
  402. if($v['oddsType']=='StMorningPlate'){
  403. $is_rolling = 4;
  404. }
  405. //串场
  406. if($v['oddsType']=='StStringScene'){
  407. $is_rolling = 5;
  408. }
  409. //冠军
  410. if($v['oddsType']=='StChampion'){
  411. $is_rolling = 6;
  412. }
  413. //首页
  414. if($v['oddsType']=='home'){
  415. $is_rolling = 7;
  416. }
  417. //===end===
  418. $matchData =[
  419. 'odds_id' =>$v['id'],
  420. 'home_team' => $v['home_team'],
  421. 'guest_team' => $v['guest_team'],
  422. 'condition' => $v['condition'],
  423. 'odds' => $v['odds'],
  424. 'odds_code' => $v['odds_code'],
  425. 'p_code' => $v['p_code'],
  426. 'odds_only' => $v['odds_only'],
  427. 'match_id' => $v['match_id'],
  428. 'game_code' => $game_code,
  429. 'lg_id' => $lg_id,
  430. 'batch_id' => $batch_id,
  431. 'bet_type' => 1,
  432. 'bet_money' => $bet_money,
  433. 'ctime' => $this->time,
  434. 'utime' => $this->time,
  435. 'is_rolling' =>$is_rolling,
  436. 'is_champion' => $is_champion?:0,//1 冠军投注 0普通赛事投注
  437. 'order_id'=>$OrderID,//追加所属订单id
  438. 'roll_time'=>$roll_time,//追加滚球投注时 赛事进行时间
  439. 'home_score'=>$home_score,//主队得分
  440. 'guest_score'=>$guest_score,//客队得分
  441. ];
  442. //插入数据源
  443. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  444. if(!$moneyBuyMatch){
  445. Render('','3205',lang('errors','Api')->get('error-3205'));
  446. }
  447. //===end===
  448. $order = [];
  449. $order =[
  450. 'info_identity' => $UUID,
  451. 'account_name' => $userInfo['account'],
  452. 'account_identity' => $userInfo['account_identity'],
  453. 'order_id' => $OrderID,//$OrderID,
  454. 'game_code' => $game_code,
  455. 'batch_id' => $batch_id,
  456. 'match_id' => $v['match_id'],
  457. 'lg_id' => $lg_id,
  458. 'game_no' => "",
  459. 'prize_money'=> $prize_money,
  460. 'money' => $bet_money, //投注金额
  461. 'money_time' => $this->time,
  462. 'is_champion' => $is_champion?:0,//1 冠军投注 0普通赛事投注
  463. ];
  464. //如果是冠军投注,追加字段
  465. if($is_champion == 1){
  466. $json_single_result = [
  467. 'lg_id'=> '',
  468. 'game_name' => '',
  469. 'result' => '',
  470. 'updatetime' => '',
  471. ];
  472. $order['single_result'] = json_encode($json_single_result);
  473. }
  474. //如果是滚球投注,追加字段
  475. if($is_rolling == 1 and $game_code == 'zq'){
  476. $order['roll_ratify'] = 2;//未审核滚球投注
  477. }
  478. $insert = lm("MoneyBuySimplex",'Api')->insert($order);
  479. if(!$insert){
  480. Render('','3205',lang('errors','Api')->get('error-3205'));
  481. }
  482. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$bet_money,$OrderID,1,"",$UUID,$userInfo);
  483. if($insertMoney!=1){
  484. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  485. }
  486. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$bet_money,$OrderID);//反水
  487. //===追加写处理队列===
  488. //订单号 比赛id188 开赛日期时间 比赛状态(早盘,今日,串场,滚球), 父级玩法, 子级玩法,排序
  489. //获取开赛时间
  490. //根据球类代码 获取相关model
  491. $models = $this->commonFunction->getModels($v['ballId']);
  492. $model_match = $models['model_match'];
  493. $info = lm($model_match,'Sports')
  494. ->select('match_date','match_time','match_identity')
  495. ->where('id',$v['match_id'])
  496. ->first();
  497. $match_time = $info->match_date.' '.$info->match_time;
  498. $orderData = [
  499. 'order_type'=>1,//订单类型 1单式 2串式
  500. 'order_id'=>$OrderID,//订单ID
  501. 'matchData'=>[
  502. [
  503. 'game_code'=>$v['ballId'],//球类代码
  504. 'other_match_id'=>$v['others_match_id'],//第三方赛事id 188
  505. 'match_id'=>$v['match_id'],//本地赛事id
  506. 'match_uuid'=> $info->match_identity,//赛事uuid
  507. 'odds_code'=>$v['odds_code'],//子玩法代码
  508. 'p_code'=>$v['p_code'],//父玩法代码
  509. 'match_time'=>$match_time,//开赛时间
  510. 'match_type'=>$is_rolling,//比赛盘口
  511. 'sort'=>$v['sort'],//排序
  512. ]
  513. ],
  514. ];
  515. $this->commonFunction->setOrderQueue($orderData);
  516. }
  517. }
  518. public function Bet(){
  519. /*
  520. // 模拟单式数据
  521. $get_data = [
  522. 'data'=>[
  523. [
  524. 'type'=>1,
  525. 'index'=>0,
  526. 'bet_amount'=>100,
  527. ],
  528. [
  529. 'type'=>1,
  530. 'index'=>1,
  531. 'bet_amount'=>100,
  532. ],
  533. [
  534. [
  535. 'id'=>10350565,
  536. 'home_team'=>'什鲁斯伯里',
  537. 'guest_team'=>'彼德堡',
  538. 'name'=>'大',
  539. 'odds'=>1.09,
  540. 'match_id'=>1463,
  541. 'condition'=>'2.5/3',
  542. 'ballId'=>'zq',
  543. 'odds_code'=>'gsb',
  544. 'p_code'=>'GS',
  545. 'play_name'=>'进球大小',
  546. 'score'=>0,
  547. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  548. 'odds_only'=>'6a003dec710a42849a82dd1ea978f572',
  549. 'lg_id'=>17,
  550. 'match_type'=>'',//滚球投注
  551. 'odds_id'=>10350565,
  552. 'repeat'=>'true',
  553. 'is_champion'=>0,//是否是冠军联赛
  554. ],
  555. [
  556. 'id'=>10781633,
  557. 'home_team'=>'什鲁斯伯里',
  558. 'guest_team'=>'彼德堡',
  559. 'name'=>'彼德堡',
  560. 'odds'=>1,
  561. 'match_id'=>1463,
  562. 'condition'=>'-0/0.5',
  563. 'ballId'=>'zq',
  564. 'odds_code'=>'cog',
  565. 'p_code'=>'CO',
  566. 'play_name'=>'让球',
  567. 'score'=>0,
  568. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  569. 'odds_only'=>'390e2b68992587438c0020179abc94f5',
  570. 'lg_id'=>17,
  571. 'match_type'=>'',//滚球投注
  572. 'odds_id'=>10781633,
  573. 'repeat'=>'true',
  574. 'is_champion'=>0,//是否是冠军联赛
  575. ]
  576. ]
  577. ],
  578. 'token'=>'Zj2aXC15738846155dcf92c78385c',
  579. 'bet_money'=>200,
  580. ];
  581. */
  582. /*
  583. // 模拟串式数据
  584. $get_data = [
  585. 'data'=>[
  586. [
  587. 'type'=>1,
  588. 'index'=>0,
  589. 'bet_amount'=>1,
  590. ],
  591. [
  592. 'type'=>'3串1',
  593. 'bet_amount' =>1,
  594. ],
  595. [
  596. [
  597. 'id'=>229351,
  598. 'home_team'=>'布琳狮子U20',
  599. 'guest_team'=>'圣奥尔本斯U20',
  600. 'name'=>'圣奥尔本斯U20',
  601. 'odds'=>1.01,
  602. 'match_id'=>0,
  603. 'condition'=>'4/4.5',
  604. 'ballId'=>'zq',
  605. 'odds_code'=>'goal_size_big',
  606. 'p_code'=>'goal_size',
  607. 'play_name'=>'大小',
  608. 'score'=>0,
  609. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  610. 'odds_only'=>'908f8bae2233a0384c96c7b1f42e9ea7',
  611. 'lg_id'=>153,
  612. 'repeat'=>'false',
  613. 'match_type'=>'StRollBall',//滚球投注
  614. ],
  615. [
  616. 'id'=>238940,
  617. 'home_team'=>'格罗兹尼艾哈迈德U20',
  618. 'guest_team'=>'奥伦堡U20',
  619. 'name'=>'格罗兹尼艾哈迈德U20',
  620. 'odds'=>0.94,
  621. 'match_id'=>1247,
  622. 'condition'=>'1/1.5',
  623. 'ballId'=>'zq',
  624. 'odds_code'=>'concede_home',
  625. 'p_code'=>'concede',
  626. 'play_name'=>'让球',
  627. 'score'=>0,
  628. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  629. 'odds_only'=>'9125bf40d6649fcdb663c43d8f55bebd',
  630. 'lg_id'=>20,
  631. 'repeat'=>'false',
  632. 'match_type'=>'StRollBall',//滚球投注
  633. ],
  634. [
  635. 'id'=>238958,
  636. 'home_team'=>'巴扬卡拉',
  637. 'guest_team'=>'马都拉联',
  638. 'name'=>'巴扬卡拉',
  639. 'odds'=>1.13,
  640. 'match_id'=>1254,
  641. 'condition'=>'0.5',
  642. 'ballId'=>'zq',
  643. 'odds_code'=>'concede_home',
  644. 'p_code'=>'concede',
  645. 'play_name'=>'让球',
  646. 'score'=>0,
  647. 'bettingTime'=>date('Y-m-d H:i:s',time()),
  648. 'odds_only'=>'3cf81ac0b9765218845fe8bc4de0ad99',
  649. 'lg_id'=>61,
  650. 'repeat'=>'false',
  651. 'match_type'=>'StRollBall',//滚球投注
  652. ],
  653. ]
  654. ],
  655. 'token'=>'ppWGRW15682541865d79a8eacb0b1',
  656. 'bet_money'=>2
  657. ];
  658. */
  659. //如果获取不到data,则为游戏端提交,需转成数组
  660. if(!empty($_POST['game_data'])){
  661. //获取参数转成数组
  662. $get_data = json_decode($_POST['game_data'],true);
  663. $token = $get_data['token'];
  664. $bet_money = $get_data['bet_money'];
  665. $data = $get_data['data'];
  666. // $bet_money_arr = $get_data['bet_money_arr'];
  667. }else{
  668. $data = $_REQUEST['data'];
  669. $bet_money = $_REQUEST['bet_money'];
  670. $token = $_REQUEST['token'];
  671. // $bet_money_arr = $_REQUEST['bet_money_arr'];
  672. }
  673. /*
  674. $data = $get_data['data'];
  675. $bet_money = $get_data['bet_money'];
  676. $token = $get_data['token'];
  677. */
  678. //验证用户token
  679. $userInfo = $this->getAgent($token);
  680. if(empty($data)||empty($bet_money)){
  681. Render('', '51029',lang('Errors','Api')->get('error-51029'));
  682. }
  683. //获取用户金额信息
  684. if(!$this->M->verifyMoney($bet_money,$userInfo['cash'])){
  685. Render('', '4204',lang('Errors','Api')->get('error-4204'));
  686. }
  687. //追加验证用户投注金额限额
  688. $this->bet_money_limit($data,$userInfo);
  689. //获取订单批次号
  690. $batch_id = OrderID();///strtotime(date('Y-m-d H:i:s',time())).mt_rand('1','99');//批量ID
  691. //执行数据插入
  692. try {
  693. _beginTransaction();//开启事务
  694. $data = $this->Classify($data);
  695. if(!empty($data['single'])){
  696. $this->Simplex_bet($data['single'],$userInfo,$batch_id);//单式数据处理
  697. }
  698. if(!empty($data['bunch'])){
  699. $data_all = $data['bunch'][count($data['bunch'])-1];//获取最后一个数组
  700. unset($data['bunch'][count($data['bunch'])-1]);//删除最后一个元素
  701. $this->stringBet($data['bunch'],$data_all,$userInfo,$batch_id);
  702. }
  703. _commit();//提交
  704. Render('', '1',lang('Errors','Api')->get('error-1'));
  705. } catch (Exception $e) {
  706. _rollBack();//回滚
  707. print $e->getMessage();
  708. }
  709. }
  710. /**
  711. * token获取用户详情
  712. */
  713. public function getAgent($token = '') {
  714. $checkToken = $this->accountManager->checkEffectiveTime($token);
  715. if ($checkToken['status'] != 1) {
  716. Render($checkToken['data'], $checkToken['status'], lang('commons')->get('user does login'));
  717. };
  718. $result = $this->accountManager->refreshToken($token);
  719. return $result['data'];
  720. }
  721. //验证联赛是否存在
  722. public function verify_league($game_code,$lg_id,$num = 1){
  723. if(empty($lg_id)){
  724. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5112');
  725. Render([], '5112',$msg);
  726. }
  727. //根据球类代码 获取相关model
  728. $model = $this->commonFunction->getModels($game_code);
  729. $model_league = $model['model_league'];
  730. $info = lm($model_league,'Sports')
  731. ->select('id')
  732. ->where('id',$lg_id)
  733. ->first();
  734. if(empty($info)){
  735. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5113');
  736. Render([], '5113',$msg);
  737. }
  738. }
  739. /**
  740. * 赛事是否存在或结束
  741. * @param [type] $game_code 球类代码
  742. * @param [type] $match_id 赔率ID
  743. * @param [type] $num 循环键值
  744. * $@param [type]type_str 串式
  745. *
  746. */
  747. public function verify_match($game_code,$match_id,$num = 1){
  748. if(empty($match_id)){
  749. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5109');
  750. Render([], '5109',$msg);
  751. }
  752. //根据球类代码 获取相关model
  753. $models = $this->commonFunction->getModels($game_code);
  754. $model_match = $models['model_match'];
  755. $info = lm($model_match,'Sports')
  756. ->select('status')
  757. ->where('status', '<', '2')
  758. // ->where('us_time','>',qgmdate('Y-m-d H:i:s','', -4))
  759. // ->where('source','hg3535')
  760. ->where('id',$match_id)
  761. ->first();
  762. if(empty($info)){
  763. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5103');
  764. Render([], '5103',$msg);
  765. }
  766. $info = $info->toarray();
  767. if($info['status'] == 2){
  768. $msg = '第'.$num.'条'.lang('Errors','Api')->get('error-5108');
  769. Render([], '5108',$msg);
  770. }
  771. return $info;
  772. }
  773. /**
  774. * 验证球类是否存在
  775. * @param [type] $game_code 球类代码
  776. * @param [type] $num 第几条
  777. */
  778. public function verify_gameType($game_code,$num){
  779. if(empty($game_code)){
  780. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-5102');
  781. Render([], '5102', $msg);
  782. }
  783. $info = lm('GameType','Sports')->where('game_code',$game_code)->first();
  784. if(empty($info)){
  785. $msg = '第' . $num . '条数据' . lang('Errors', 'Api')->get('error-5102');
  786. Render([], '5102', $msg);
  787. }
  788. return $info;
  789. }
  790. /**
  791. * 验证赔率是否存在
  792. * @param [type] $game_code 球类代码
  793. * @param [type] $odds_id 赔率IDkk
  794. *
  795. */
  796. public function verify_odds($game_code,$odds_only,$odds,$condition,$odds_code,$num = 1){
  797. if (empty($odds_only)){
  798. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-5111');
  799. Render([], '5111', $msg);
  800. }
  801. if(empty($odds_code)){
  802. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7052');
  803. Render([], '7052', $msg);
  804. }
  805. if(empty($odds)){
  806. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7029');
  807. Render([], '7029', $msg);
  808. }
  809. $odds_codeNum = odds_codeModel::getOddsCode($odds_code,$game_code);
  810. if($odds_codeNum < 1){
  811. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7053');
  812. Render([], '7053', $msg);
  813. }
  814. //根据球类代码 获取相关model
  815. $models = $this->commonFunction->getModels($game_code);
  816. $model_odds = $models['model_odds'];
  817. $model_odds_record = $models['model_odds_record'];
  818. //匹配赔率是否过期
  819. $odds_info = lm($model_odds,'Sports')
  820. ->join($model_odds_record,$model_odds_record.'.odds_only',$model_odds.'.odds_only')
  821. ->select($model_odds_record.'.odds',$model_odds_record.'.condition')
  822. ->where($model_odds.'.odds_only',$odds_only)
  823. ->first();
  824. if(empty($odds_info)){
  825. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7051');
  826. Render([], '7051', $msg);
  827. }
  828. $odds_info = $odds_info->toarray();
  829. if($condition != $odds_info['condition']){
  830. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7047');
  831. Render([], '7047', $msg);
  832. }
  833. if($odds != $odds_info['odds']){
  834. $msg = '第'.$num.'条数据'.lang('Errors','Api')->get('error-7049');
  835. Render([], '7049', $msg);
  836. }
  837. return $odds_info;
  838. }
  839. /**
  840. * 处理串式投注
  841. * $data_str 各串式 数据
  842. * $data_all 所有赛事 数据
  843. * $userInfo 用户数据
  844. * $batch_id 批次号
  845. */
  846. public function stringBet__($data_str=[],$data_all=[],$userInfo=[],$batch_id=0){
  847. //验证串式投注是否合法
  848. $this->verify_stringType($data_all);
  849. //获取串式 总赛事数量
  850. $groupNum = count($data_all);//总数量
  851. $orderData = [];
  852. foreach ($data_str as $k=>$v){
  853. //字符串替换
  854. $str = str_ireplace("串","_",$v['type']);
  855. //获取type 3_12
  856. $after = substr($str,strpos($str,"_")+1);
  857. //当前串式 值
  858. $sonNum = substr($str,0,strrpos($str,"_"));
  859. //获取倍数
  860. if((int)$after == 1){
  861. $multiple = $this->getMultiple($groupNum,(int)$sonNum);
  862. }else{
  863. $multiple =(int)$after;
  864. }
  865. //获取当前串式投注金额及可赢金额
  866. if($after == 1){
  867. $money_all = $this->getmakeMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  868. }else{
  869. $money_all = $this->getStrAllMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  870. }
  871. //投注金额
  872. $moneyData = $money_all['moneyData'];
  873. //可赢金额
  874. $prize_money = $money_all['prize_money'];
  875. $uuid = UUID();
  876. $orderID = OrderID('T');
  877. $orderData[$k]['info_identity'] = $uuid;
  878. $orderData[$k]['account_name'] = $userInfo['account'];
  879. $orderData[$k]['account_identity'] = $userInfo['account_identity'];
  880. $orderData[$k]['order_id'] = $orderID;
  881. $orderData[$k]['game_no'] = "";
  882. $orderData[$k]['money'] = $moneyData;//$pay_money//总投注金额
  883. $orderData[$k]['money_time'] = $this->time;//下注时间
  884. $orderData[$k]['prize_money'] = $prize_money;//$expect_money ;//预期总可赢金额
  885. $orderData[$k]['str_type'] = $v['type'];//串式类型
  886. $orderData[$k]['batch_id'] = $batch_id;//批次号
  887. $orderData[$k]['wait_match_num'] = count($data_all);//批次号
  888. //写资金变动表
  889. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$moneyData,$orderID,1,"",$uuid,$userInfo);
  890. if($insertMoney!=1){
  891. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  892. }
  893. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$moneyData,$orderID);//反水
  894. }
  895. //写注单 表
  896. $moneyBuy = lm('MoneyBuyStr','Api')->insert($orderData);
  897. if(!$moneyBuy){
  898. Render('','3205',lang('errors','Api')->get('error-3205'));
  899. }
  900. foreach ($data_all as $kk=>$vv){
  901. $getModels = $this->commonFunction->getModels($vv['ballId']);
  902. $model_match = $getModels['model_match'];
  903. //获取是否是滚球投注
  904. $is_rolling = 0;
  905. if($vv['match_type'] == 'StRollBall'){
  906. $is_rolling = 1;
  907. }
  908. $matchData[] = [
  909. 'batch_id'=>$batch_id,
  910. 'odds_id'=>$vv['id'],
  911. 'home_team'=>$vv['home_team'],
  912. 'guest_team'=>$vv['guest_team'],
  913. 'condition'=>$vv['condition'],
  914. 'odds'=>$vv['odds'],
  915. 'odds_code'=>$vv['odds_code'],
  916. 'p_code'=>$vv['p_code'],
  917. 'odds_only'=>$vv['odds_only'],
  918. 'status'=>0,
  919. 'match_id'=>$vv['match_id'],
  920. 'game_code'=>$vv['ballId'],
  921. 'lg_id'=> $vv['lg_id'],
  922. 'ctime'=>$this->time,//写入时间
  923. 'utime' => $this->time,
  924. 'bet_type'=>2,
  925. 'is_rolling'=>$is_rolling,
  926. 'order_id'=> $orderID,
  927. ];
  928. }
  929. //写赔率数据表
  930. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  931. if(!$moneyBuyMatch){
  932. Render('','3205',lang('errors','Api')->get('error-3205'));
  933. }
  934. return true;
  935. }
  936. public function stringBet($data_str=[],$data_all=[],$userInfo=[],$batch_id=0){
  937. //验证串式投注是否合法
  938. $this->verify_stringType($data_all);
  939. //获取串式 总赛事数量
  940. $groupNum = count($data_all);//总数量
  941. $orderData = [];
  942. foreach ($data_str as $k=>$v){
  943. //字符串替换
  944. $str = str_ireplace("串","_",$v['type']);
  945. //获取type 3_12
  946. $after = substr($str,strpos($str,"_")+1);
  947. //当前串式 值
  948. $sonNum = substr($str,0,strrpos($str,"_"));
  949. //获取倍数
  950. if((int)$after == 1){
  951. $multiple = $this->getMultiple($groupNum,(int)$sonNum);
  952. }else{
  953. $multiple =(int)$after;
  954. }
  955. //获取当前串式投注金额及可赢金额
  956. if($after == 1){
  957. $money_all = $this->getmakeMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  958. }else{
  959. $money_all = $this->getStrAllMoney((int)$sonNum,$v['bet_amount'],$multiple,$data_all,$after);
  960. }
  961. //投注金额
  962. $moneyData = $money_all['moneyData'];
  963. //可赢金额
  964. $prize_money = $money_all['prize_money'];
  965. $uuid = UUID();
  966. $orderID = OrderID('T');
  967. $orderData[$k]['info_identity'] = $uuid;
  968. $orderData[$k]['account_name'] = $userInfo['account'];
  969. $orderData[$k]['account_identity'] = $userInfo['account_identity'];
  970. $orderData[$k]['order_id'] = $orderID;
  971. $orderData[$k]['game_no'] = "";
  972. $orderData[$k]['money'] = $moneyData;//$pay_money//总投注金额
  973. $orderData[$k]['money_time'] = $this->time;//下注时间
  974. $orderData[$k]['prize_money'] = $prize_money;//$expect_money ;//预期总可赢金额
  975. $orderData[$k]['str_type'] = $v['type'];//串式类型
  976. $orderData[$k]['batch_id'] = $batch_id;//批次号
  977. $orderData[$k]['wait_match_num'] = count($data_all);//批次号
  978. //写资金变动表
  979. $insertMoney = $this->M->insertMoney($userInfo['account_identity'],$moneyData,$orderID,1,"",$uuid,$userInfo);
  980. if($insertMoney!=1){
  981. Render('', $insertMoney,lang('Errors','Api')->get('error'.$insertMoney));
  982. }
  983. $this->M->fanshui($userInfo['account_identity'],$userInfo['account'],$moneyData,$orderID);//反水
  984. //===处理赛事数据===
  985. foreach ($data_all as $kk=>$vv){
  986. $getModels = $this->commonFunction->getModels($vv['ballId']);
  987. $model_match = $getModels['model_match'];
  988. //获取是否是滚球投注
  989. $is_rolling = 0;
  990. if($vv['match_type'] == 'StRollBall'){
  991. $is_rolling = 1;
  992. }
  993. $matchData[] = [
  994. 'batch_id'=>$batch_id,
  995. 'odds_id'=>$vv['id'],
  996. 'home_team'=>$vv['home_team'],
  997. 'guest_team'=>$vv['guest_team'],
  998. 'condition'=>$vv['condition'],
  999. 'odds'=>$vv['odds'],
  1000. 'odds_code'=>$vv['odds_code'],
  1001. 'p_code'=>$vv['p_code'],
  1002. 'odds_only'=>$vv['odds_only'],
  1003. 'status'=>0,
  1004. 'match_id'=>$vv['match_id'],
  1005. 'game_code'=>$vv['ballId'],
  1006. 'lg_id'=> $vv['lg_id'],
  1007. 'ctime'=>$this->time,//写入时间
  1008. 'utime' => $this->time,
  1009. 'bet_type'=>2,
  1010. 'is_rolling'=>$is_rolling,
  1011. 'order_id'=> $orderID,
  1012. ];
  1013. //=====拼接赛事数据===
  1014. //获取开赛时间
  1015. //根据球类代码 获取相关model
  1016. $models = $this->commonFunction->getModels($vv['ballId']);
  1017. $model_match = $models['model_match'];
  1018. $info = lm($model_match,'Sports')
  1019. ->select('match_date','match_time','match_identity')
  1020. ->where('id',$vv['match_id'])
  1021. ->first();
  1022. $match_time = $info->match_date.' '.$info->match_time;
  1023. $match_data_order[] = [
  1024. 'game_code'=>$vv['ballId'],//球类代码
  1025. 'other_match_id'=>$vv['others_match_id'],//第三方赛事id 188
  1026. 'match_id'=>$vv['match_id'],//本地赛事id
  1027. 'match_uuid'=> $info->match_identity,//赛事uuid
  1028. 'odds_code'=>$vv['odds_code'],//子玩法代码
  1029. 'p_code'=>$vv['p_code'],//父玩法代码
  1030. 'match_time'=>$match_time,//开赛时间
  1031. 'match_type'=>$is_rolling,//比赛盘口
  1032. 'sort'=>$vv['sort'],//排序
  1033. ];
  1034. //===end===
  1035. }
  1036. //===追加写处理队列===
  1037. //订单号 比赛id188 开赛日期时间 比赛状态(早盘,今日,串场,滚球), 父级玩法, 子级玩法,排序
  1038. //赛事去重
  1039. $match_data_order = $this->commonFunction->array_unset_tt($match_data_order,'match_id');
  1040. $orderData_queue[] = [
  1041. 'order_type'=>2,//订单类型 1单式 2串式
  1042. 'order_id'=>$orderID,//订单ID
  1043. 'matchData'=>$match_data_order
  1044. ];
  1045. }
  1046. //写赔率数据表
  1047. $moneyBuyMatch = lm('MoneyBuyMatch','Api')->insert($matchData);
  1048. if(!$moneyBuyMatch){
  1049. Render('','3205',lang('errors','Api')->get('error-3205'));
  1050. }
  1051. //===end===
  1052. //写注单 表
  1053. $moneyBuy = lm('MoneyBuyStr','Api')->insert($orderData);
  1054. if(!$moneyBuy){
  1055. Render('','3205',lang('errors','Api')->get('error-3205'));
  1056. }
  1057. //写队列
  1058. foreach($orderData_queue as $k=>$v){
  1059. $this->commonFunction->setOrderQueue($v);
  1060. }
  1061. return true;
  1062. }
  1063. /**
  1064. * 计算串式投注 倍率
  1065. * $groupNum 总赛事 数量
  1066. * $sonNum 当前串式 数量
  1067. */
  1068. public function getMultiple($groupNum = 0,$sonNum = 0){
  1069. if($groupNum and $sonNum){
  1070. $group =1;
  1071. for($i = $groupNum ; $i >($groupNum - $sonNum);$i--) {
  1072. $group = $group * $i;
  1073. }
  1074. $son =1;
  1075. for($i = $sonNum ; $i >0;$i--) {
  1076. $son = $son * $i;
  1077. }
  1078. }
  1079. return $group/$son;
  1080. }
  1081. /**
  1082. * @param int $sonNum 当前串式数量
  1083. * @param int $bet_amount 当前串式投注额
  1084. * @param int $multiple 当前串式倍数
  1085. * @param array $data_all 当前注单 所有投注数据
  1086. * @return mixed
  1087. * 计算当前串式投注总额、可赢总额
  1088. */
  1089. public function getmakeMoney($sonNum=0,$bet_amount=0,$multiple=0,$data_all=[],$after = 0){
  1090. $allNum = count($data_all);//所有数量
  1091. $odds_all = [];//所有投注项数据
  1092. foreach ($data_all as $k=>$v){
  1093. $odds_all[] = $v['odds']+1;
  1094. }
  1095. //投注总额
  1096. $data['moneyData'] = (double)$bet_amount*(double)$multiple;
  1097. if($sonNum == $allNum and (int)$after ==1){//N场赛事 N串一
  1098. //获取所有赛事赔率乘积
  1099. $odds = array_product($odds_all) - 1;
  1100. //获取可赢金额
  1101. $data['prize_money'] = sprintf("%.2f",substr(sprintf("%.3f", $bet_amount*$odds), 0, -1));//floor($bet_amount*$odds*100)/100;//保留两位小数
  1102. }
  1103. if($sonNum < $allNum and (int)$after ==1){//例:N场赛事 <N串一
  1104. //计算 组合赔率
  1105. $group = $this->commonFunction->combination($odds_all, $sonNum);
  1106. foreach ($group as $k=>$v){
  1107. $odds[] = array_product($v);
  1108. }
  1109. $odds = (array_sum($odds))-(count($odds));
  1110. //获取可赢金额
  1111. $data['prize_money'] = sprintf("%.2f",substr(sprintf("%.3f", $bet_amount*$odds), 0, -1));//floor($bet_amount*$odds*100)/100;
  1112. }
  1113. return $data;
  1114. }
  1115. /**
  1116. * 获取所有可用串式 N场赛事 2串1,3串1...N串1,N<11
  1117. * 并计算 其投注可赢金额
  1118. */
  1119. public function getStrAllMoney($sonNum=0,$bet_amount=0,$multiple=0,$data_all=[],$after = 0){
  1120. $d = [];
  1121. for ($i=2;$i<($sonNum+1);$i++){
  1122. $d[] = $i;
  1123. }
  1124. foreach ($d as $k=>$v){
  1125. $multiple = $this->getMultiple($sonNum,$v);
  1126. $money[] = $this->getmakeMoney($v,$bet_amount,$multiple,$data_all,1);
  1127. }
  1128. $data=array();
  1129. foreach($money as $k=>$v){
  1130. $data['moneyData']+=$v['moneyData'];
  1131. $data['prize_money']+=$v['prize_money'];
  1132. }
  1133. return $data;
  1134. }
  1135. /**
  1136. * 验证串式投注 是否合法
  1137. * $data 串式 所有赛事
  1138. */
  1139. public function verify_stringType($data=[]){
  1140. if($data){
  1141. foreach($data as $k=>$v){
  1142. if($v['match_id']==$v['match_id'] ){
  1143. $r[$v['match_id']][] = $v;
  1144. }
  1145. }
  1146. }
  1147. if($r){
  1148. foreach ($r as $k=>$v){
  1149. if(count($v) > 1){
  1150. $msg = lang('Errors','Api')->get('error-50038');
  1151. Render([], '50038',$msg);
  1152. }else if( $k == 0){
  1153. $msg = lang('Errors','Api')->get('error-50043');
  1154. Render([], '50043',$msg);
  1155. }
  1156. }
  1157. }
  1158. }
  1159. /**
  1160. * 更新投注项相关数据
  1161. */
  1162. public function getBetData(){
  1163. $data = $_REQUEST;
  1164. // $data = [['game_code'=>'zq','match_id'=>3095448,'odds_id'=>623078],['game_code'=>'zq','match_id'=>3095448,'odds_id'=>623078]];
  1165. foreach ($data as $k=>$v){
  1166. $getModels = $this->commonFunction->getModels($v['game_code']);
  1167. $model_match = $getModels['model_match'];
  1168. $model_odds = $getModels['model_odds'];
  1169. $oddsData = lm($model_match,"Sports")
  1170. ->join($model_odds,$model_odds.'.match_id',$model_match.'.id')
  1171. ->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')
  1172. // ->where($model_match.'.source',$this->source)
  1173. ->where($model_match.'.id',$v['match_id'])
  1174. ->where($model_odds.'.id',$v['odds_id'])
  1175. //->where($model_odds.'.expire_time','>',date("Y-m-d H:i:s"))
  1176. ->first();
  1177. $oddsData->game_code = $v['game_code'];
  1178. $betData[] = $oddsData;
  1179. }
  1180. Render($betData, '1', lang('Tips','Sports')->get('success'));
  1181. }
  1182. //用户投注限额验证
  1183. public function bet_money_limit($bet_money_arr=[],$userInfo=[]){
  1184. if(!empty($bet_money_arr)){
  1185. foreach($bet_money_arr as $k=>$v){
  1186. if($k == (count($bet_money_arr)-1)){
  1187. unset($bet_money_arr[$k]);
  1188. }
  1189. }
  1190. }
  1191. //===追加验证用户投注金额限额===
  1192. if(empty($bet_money_arr)) Render('', '3605',lang('Errors','Api')->get('error-3605'));
  1193. //获取当前用户分组名称
  1194. $substr = substr($userInfo['group_name'],strpos($userInfo['group_name'],'|')+1);
  1195. $role_name = substr($substr, 0, -1);
  1196. //获取用户分组的投注限额
  1197. $bet_money_limit = Dc_user_grade::get_bet_money_limit($role_name);
  1198. foreach($bet_money_arr as $k=>$v){
  1199. 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'));
  1200. 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'));
  1201. }
  1202. //===end==
  1203. }
  1204. //根据token获取用户投注限额
  1205. public function getBetMoneyLimit(){
  1206. //验证用户token
  1207. $token = $_REQUEST['token'];
  1208. $userInfo = $this->getAgent($token);
  1209. //获取当前用户分组名称
  1210. $substr = substr($userInfo['group_name'],strpos($userInfo['group_name'],'|')+1);
  1211. $role_name = substr($substr, 0, -1);
  1212. //获取用户分组的投注限额
  1213. $bet_money_limit = Dc_user_grade::get_bet_money_limit($role_name);
  1214. $data['bet_money_limit']=[
  1215. 'lower_limit'=>$bet_money_limit->lower_limit,
  1216. 'upper_limit'=>$bet_money_limit->upper_limit,
  1217. ];
  1218. Render($data, '1', lang('Tips','Sports')->get('success'));
  1219. }
  1220. /**
  1221. * 用户撤单操作 接口
  1222. * 单订单操作
  1223. */
  1224. public function reOrder(){
  1225. //获取球类代码
  1226. $order_id = $_REQUEST['order_id'];
  1227. $token = $_REQUEST['token'];
  1228. try {
  1229. if(empty($order_id)){
  1230. throw new \Exception(Render([], '10001', lang('Tips','Sports')->get('PARAM_ERROR')));
  1231. }
  1232. _beginTransaction();//开启事务
  1233. // 单式 S 串式 T
  1234. if(substr($order_id,0,1) == 'S'){
  1235. //单式订单 model
  1236. $order_model = 'money_buy_simplex';
  1237. }else{
  1238. //串式订单 model
  1239. $order_model = 'money_buy_str';
  1240. }
  1241. //查询订单信息
  1242. $order_data = lm($order_model,"Commons")
  1243. ->where('order_id',$order_id)
  1244. ->first();
  1245. //订单不存在
  1246. if(empty($order_data)) throw new \Exception(Render([], '10030', lang('Tips','Sports')->get('order_null')));
  1247. //订单非投注状态 不可撤单
  1248. if($order_data->status != 1) throw new \Exception(Render([], '10031', lang('Tips','Sports')->get('order_type_err')));
  1249. //获取用户数据
  1250. $userInfo = $this->getAgent($token);
  1251. //验证订单是否属于该用户
  1252. if($order_data->account_identity != $userInfo['account_identity']) throw new \Exception(Render([], '10025', lang('Tips','Sports')->get('auth_error').':不是该用户的订单'));
  1253. //获取用户账户余额
  1254. $cash = $userInfo['cash'];
  1255. //获取订单涉及金额
  1256. $where = [
  1257. ['trade_id','=',$order_id],
  1258. ['status','=',1]
  1259. ];
  1260. $odds_money_data = lm('money_details',"Commons")
  1261. ->select('info_identity','trade_id','account_name','account_identity','money','money_type','money_cash','trade_type','status')
  1262. ->where($where)
  1263. ->get();
  1264. if(empty($odds_money_data)) throw new \Exception(Render([], '10026', lang('Tips','Sports')->get('order_money_err')));
  1265. $odds_money_data = $odds_money_data -> toArray();
  1266. //获取订单投注金额
  1267. $odds_money_bet = 0;
  1268. //获取订单反水金额
  1269. $odds_money_fs = 0;
  1270. foreach($odds_money_data as $k=>$v){
  1271. if($v['trade_type'] == 1){
  1272. $odds_money_bet = $v['money'];
  1273. }
  1274. if($v['trade_type'] == 7){
  1275. $odds_money_fs = $v['money'];
  1276. }
  1277. }
  1278. //更新订单状态为已取消
  1279. $up_order = lm($order_model,"Commons")
  1280. ->where('order_id',$order_id)
  1281. ->update(['status'=>3,'use_mark'=>'用户撤单']);
  1282. if($up_order < 1) throw new \Exception(Render([], '10027', lang('Tips','Sports')->get('order_status_up_err')));
  1283. //===退款===
  1284. //需退回金额 = 投注金额-反水金额
  1285. $money = abs($odds_money_bet - $odds_money_fs);
  1286. //用户剩余金额
  1287. $new_available_cash = $cash + $money;
  1288. //组装新增数据
  1289. $set_money_data = [
  1290. 'info_identity' => UUID(),
  1291. 'trade_id' => $order_id,
  1292. 'account_name' => $userInfo['account'],
  1293. 'account_identity' => $userInfo['account_identity'],
  1294. 'money' => $money,
  1295. 'money_time' => date("Y-m-d H:i:s", time()),
  1296. 'money_type' => 1,
  1297. 'money_cash' => $new_available_cash,
  1298. 'trade_type' => 3,
  1299. 'trade_desc' => '用户撤单,退回投注资金:¥'.$money.';订单号:'.$order_id.'',
  1300. 'status' => 1,
  1301. ];
  1302. //更新用户数据
  1303. $ret_user = lm('account_detailed',"Commons")
  1304. ->where('account_identity', $v['account_identity'])
  1305. ->update(['available_cash' => $new_available_cash, 'cash' => $new_available_cash]);
  1306. if($ret_user < 1) throw new \Exception(Render([], '10028', lang('Tips','Sports')->get('up_user_err')));
  1307. //更新用户资金数据
  1308. $set_money = lm('money_details',"Commons")->insert($set_money_data);
  1309. if($set_money != true) throw new \Exception(Render([], '10029', lang('Tips','Sports')->get('add_money_err')));
  1310. //===end===
  1311. _commit();//提交
  1312. Render('', '1', lang('Tips','Sports')->get('success'));
  1313. } catch (\Exception $e) {
  1314. echo $e->getMessage();
  1315. }
  1316. }
  1317. }