Index.php 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <?php
  2. namespace app\index\controller;
  3. use think\Controller;
  4. use think\Request;
  5. use think\Db;
  6. use think\Session;
  7. class Index extends Controller
  8. {
  9. //获取用户的函数 (根据条件筛选出来)
  10. public function getuser(Request $request){
  11. if ($request->isPost()){
  12. $data = input();
  13. $group = isset($data['group'])?$data['group']:''; //组
  14. $user = isset($data['user'])?$data['user']:''; //用户
  15. $order = isset($data['order'])?$data['order']:''; //用户
  16. $group = explode(",", $group); //使用字符串切割
  17. $user = explode(",", $user); //使用字符串切割
  18. $where1=[]; //后面一个字符的选择
  19. $where2=[]; //后面多个字符的选择
  20. foreach ($group as $key => $value) {
  21. // 对其中的通配符和单字符进行匹配
  22. $pos = strpos($value,"*"); //是否全字匹配
  23. if($pos===false){
  24. $pos_one = strpos($value,"?");
  25. if($pos_one===false){
  26. continue;
  27. }else{
  28. $value = str_replace("?","",$value);
  29. if($pos_one==0){
  30. $where1['GROUP'] = ['like','_'.$value]; //前面一个字符的选择
  31. }else{
  32. $where1['GROUP'] = ['like',$value.'_']; //后面一个字符的选择
  33. }
  34. unset($group[$key]);
  35. }
  36. }else{
  37. $value = str_replace("*","",$value);
  38. if($pos==0){
  39. $where2['GROUP'] = ['like','%'.$value]; //前面多个字符的选择
  40. }else{
  41. $where2['GROUP'] = ['like',$value.'%']; //后面多个字符的选择
  42. }
  43. unset($group[$key]);
  44. }
  45. }
  46. $where['GROUP'] = ['in',$group]; //精准选择(组的成员)
  47. $whereuser['LOGIN']=['in',$user]; //精准选择(用户成员)
  48. $result = Db::name('mt4_users')->where($where)->whereOr($where1)->whereOr($where2)->whereOr($whereuser)->distinct(true)->select(); //筛选函数
  49. $result1 = Db::name('order_progress')->where(['orig_order'=>$order])->select(); //筛选函数(当前跟踪的订单)
  50. //外层筛选出来之前做过的订单
  51. foreach ($result as $key => $value) {
  52. //自己选择的用户
  53. foreach ($result1 as $k => $v) {
  54. if($value['LOGIN']==$v['dest_login']){
  55. unset($result[$key]);
  56. }
  57. }
  58. }
  59. $result = array_values($result); //重新组织数组的键值对
  60. if($result){
  61. return json(['code'=>'00','user'=>$result,'msg'=>'获得数据成功']);
  62. }else{
  63. return json(['code'=>'01','msg'=>'没有对应的数据']);
  64. }
  65. }else{
  66. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  67. }
  68. }
  69. //点击订单后获取到的信息
  70. public function getorder(Request $request){
  71. if ($request->isPost()){
  72. $data = input(); //获取订单的信息
  73. $result = Db::name('mt4_trades')->where(['TICKET'=>$data['orderid']])->where('CMD','in','0,1')->where('CLOSE_TIME','> time','1970-01-01')->find(); //从数据库获取到订单信息
  74. if($result){
  75. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  76. }else{
  77. return json(['code'=>'01','msg'=>'没有找到匹配的订单']);
  78. }
  79. }else{
  80. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  81. }
  82. }
  83. // 点击订单后查询函数(rollback)
  84. public function rollback_order(Request $request){
  85. if ($request->isPost()){
  86. $data = input(); //获取订单的信息
  87. $result = Db::name('order_progress')->where(['type'=>"insert","orig_order"=>$data['orderid'],'error_code'=>0])->select(); //insert成功后插入的订单
  88. $result1 = Db::name('order_progress')->where(['type'=>"rollback","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //rollback失败后的订单
  89. $result2 = Db::name('order_progress')->where(['type'=>"retry","orig_order"=>$data['orderid']])->where('error_code','eq',0)->select(); //retry成功的订单
  90. $result = array_merge($result,$result1,$result2); //对数据进行合并
  91. if($result){
  92. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  93. }else{
  94. return json(['code'=>'01','msg'=>'暂无数据']);
  95. }
  96. }else{
  97. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  98. }
  99. }
  100. // 点击订单后查询函数(retry)
  101. public function retry_order(Request $request){
  102. if ($request->isPost()){
  103. $data = input(); //获取订单的信息
  104. $result = Db::name('order_progress')->where(['type'=>"insert","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //insert失败的订单
  105. $result1 = Db::name('order_progress')->where(['type'=>"retry","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //retry失败的订单
  106. $result2 = Db::name('order_progress')->where(['type'=>"except_rollback","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //except_rollback失败的订单
  107. $result = array_merge($result,$result1,$result2); //对数据进行合并
  108. if($result){
  109. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  110. }else{
  111. return json(['code'=>'01','msg'=>'暂无数据']);
  112. }
  113. }else{
  114. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  115. }
  116. }
  117. //确认密码函数(批量操作的时候需要)
  118. public function querypassword(Request $request){
  119. if ($request->isPost()){
  120. $data = input(); //获取传递的信息
  121. $password = md5($data['password']); //获取加密后的密码
  122. //根据用户来选择数据
  123. if($data['nickname']=="普通管理员"){
  124. $result = Db::name('admin')->where(['id'=>1])->find(); //找到用户(获取原始的密码)
  125. }else{
  126. $result = Db::name('admin')->where(['id'=>2])->find(); //找到用户(获取原始的密码)
  127. }
  128. // 筛选出来的数据进行密码的匹配
  129. if($password==$result['password']){
  130. return json(['code'=>'00','msg'=>'请求数据成功']);
  131. }else{
  132. return json(['code'=>'01','msg'=>'密码填写有误']);
  133. }
  134. }else{
  135. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  136. }
  137. }
  138. //更新梯度函数(retry的时候进行查询)
  139. public function update_percentage(Request $request){
  140. if ($request->isPost()){
  141. $data = input(); //获取传递的信息
  142. $update_array =[];
  143. foreach ($data as $key => $value) {
  144. $result = Db::name('mt4_users')->where(['LOGIN'=>$value])->find();
  145. $update_array[$value]= $result['BALANCE'];
  146. }
  147. if($update_array){
  148. return json(['code'=>'00','data'=>$update_array,'msg'=>'请求数据成功']);
  149. }else{
  150. return json(['code'=>'01','data'=>$update_array,'msg'=>'请求数据有误']);
  151. }
  152. }else{
  153. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  154. }
  155. }
  156. }