Betorder.php 50 KB

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