Index.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310
  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. * 通配符转换
  11. * @param $str
  12. * @return string
  13. */
  14. public function wildcard($str)
  15. {
  16. $_str = '';
  17. for($i=0; $i<strlen($str); $i++){
  18. if($str{$i} == '*'){
  19. $str{$i} = '%';
  20. }elseif ($str{$i} == "?"){
  21. $str{$i} = '_';
  22. }
  23. $_str .= $str{$i}; //后面一个字符的选择
  24. }
  25. return $_str;
  26. }
  27. /**
  28. * \斜线转义便于MySQL like查询
  29. * @param $str
  30. * @return string
  31. */
  32. public function slashEscap($str)
  33. {
  34. $_str = "";
  35. for ($i = 0; $i < strlen($str); $i++)
  36. {
  37. if($str{$i} == "\\"){
  38. $_str .= "\\\\";
  39. }else {
  40. $_str .= $str{$i};
  41. }
  42. }
  43. return $_str;
  44. }
  45. //获取用户的函数 (根据条件筛选出来)
  46. public function getuser(Request $request){
  47. if ($request->isPost()){
  48. $data = input();
  49. $group = isset($data['group']) ? $data['group']:''; //组
  50. $user = isset($data['user']) ? $data['user']:''; //用户
  51. $order = isset($data['order']) ? $data['order']:''; //用户
  52. $groupArr = explode(",", $group); //使用字符串切割
  53. $user = explode(",", $user); //使用字符串切割
  54. $where1=[]; //通配查询
  55. $whereuser['Login']=['in',$user]; //精准选择(用户成员)
  56. $str = "";
  57. $likeData = [];
  58. foreach ($groupArr as $key=>$value){
  59. if(strpos($value,'*') !== false || strpos($value,'?') !== false){//判断是否存在通配查询
  60. $wildcardStr = $this->wildcard($value);
  61. $str = $this->slashEscap($wildcardStr);
  62. $likeData[] = ["like",$str];
  63. $where1['group'] = $likeData;
  64. unset($groupArr[$key]);
  65. }
  66. }
  67. if(count($likeData) == 1){
  68. $where1['group'] = ["like",$str];
  69. }
  70. $where['Group'] = ['in',$groupArr]; //精准选择(组的成员);
  71. $result = Db::name('mt5_users')->where($where)->whereOr($where1)->whereOr($whereuser)->distinct(true)->select();
  72. $result1 = Db::name('order_progress')->where(['orig_order'=>$order])->select(); //筛选函数(当前跟踪的订单)
  73. //外层筛选出来之前做过的订单
  74. foreach ($result as $key => $value) {
  75. //自己选择的用户
  76. $result[$key]['LOGIN'] = $value["Login"];
  77. $result[$key]['NAME'] = $value['Name'];
  78. $result[$key]['GROUP'] = $value['Group'];
  79. $result[$key]['BALANCE'] = $value['Balance'];
  80. foreach ($result1 as $k => $v) {
  81. if($value['Login']==$v['dest_login']){
  82. unset($result[$key]);
  83. }
  84. }
  85. }
  86. $result = array_values($result); //重新组织数组的键值对
  87. if($result){
  88. return json(['code'=>'00','user'=>$result,'msg'=>'获得数据成功']);
  89. }else{
  90. return json(['code'=>'01','msg'=>'没有对应的数据']);
  91. }
  92. }else{
  93. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  94. }
  95. }
  96. //点击订单后获取到的信息
  97. public function getorder(Request $request){
  98. if ($request->isPost()){
  99. $data = input(); //获取订单的信息
  100. $orderid = trim($data['orderid']);
  101. if(!is_numeric($orderid)){
  102. return json(['code'=>'01','msg'=>'请输入正确的数字类型']);
  103. }
  104. //获取deals表中的信息 判断订单是否平仓 entry为0是正 entry为1时是负
  105. $deals = Db::query("select count(*) as 'num' from mt5_deals WHERE PositionID = {$orderid} and entry in (0,1) group by entry");
  106. $deal = array_column($deals,'num');
  107. if(!$deals || count($deals)<2 || $deal[0] != $deal[1]){
  108. return json(['code'=>'01','msg'=>'没有找到匹配的订单']);
  109. }
  110. /* $deals1 = Db::query("select count(*) as 'num' from mt5_deals WHERE PositionID = {$orderid} and Entry = 0 ");
  111. $deals2 = Db::query("select count(*) as 'num' from mt5_deals WHERE PositionID = {$orderid} and Entry = 1 ");
  112. $deal1 = array_column($deals1,'num');
  113. $deal2 = array_column($deals2,'num');
  114. if( $deal1[0] != $deal2[0]){
  115. return json(['code'=>'01','msg'=>'没有找到匹配的订单333333']);
  116. }*/
  117. //查询开仓信息
  118. $openResult = Db::query("SELECT Price,Time FROM mt5_deals WHERE PositionID={$orderid} and Time = (SELECT MIN(Time) FROM mt5_deals WHERE PositionID={$orderid})");
  119. //通过deals表查询盈利
  120. $earnings = Db::query("SELECT SUM(Commission) as commission,SUM(Profit) as profit FROM mt5_deals WHERE PositionID={$orderid}");
  121. //查询关仓信息
  122. $closeResult = Db::query("SELECT Price,Time,Login,PositionID,Symbol,Volume,PriceTP,PriceSL FROM mt5_deals WHERE PositionID={$orderid} and Time = (SELECT MAX(Time) FROM mt5_deals WHERE PositionID={$orderid})");
  123. //获取订单的所有deal,orders
  124. $result = Db::query("select Deal as 'deal',`Order` from mt5_deals WHERE PositionID = {$orderid}");
  125. $getDeals = array_column($result,'deal');
  126. $order = array_column($result,'Order');
  127. if($closeResult && $result && $openResult){
  128. $openResult = $openResult[0];
  129. $earnings = $earnings[0];
  130. $closeResult = $closeResult[0];
  131. //发送set_current_postion 数据
  132. $send = ['orders'=>$order,'from'=>strtotime($openResult['Time'])-1,'to'=>strtotime($closeResult['Time'])+1,'login'=>$closeResult['Login'],'deals'=>$getDeals];
  133. $data = [
  134. 'OPEN_PRICE' => $openResult["Price"],
  135. 'OPEN_TIME' => $openResult["Time"],
  136. 'CLOSE_TIME' => $closeResult['Time'],
  137. 'CLOSE_PRICE' => $closeResult['Price'],
  138. 'LOGIN' => $closeResult['Login'],
  139. 'TICKET' => $closeResult['PositionID'],
  140. 'SYMBOL' => $closeResult['Symbol'],
  141. 'VOLUME' => $closeResult['Volume'],
  142. 'TP' => $closeResult['PriceTP'],
  143. 'SL' => $closeResult['PriceSL'],
  144. 'PROFIT' => $earnings['profit'],
  145. 'COMMISSION' => $earnings['commission'],
  146. 'send' => $send
  147. ];
  148. return json(['code'=>'00','data'=>$data,'msg'=>'获得数据成功']);
  149. }else{
  150. return json(['code'=>'01','msg'=>'没有找到匹配的订单']);
  151. }
  152. }else{
  153. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  154. }
  155. }
  156. // 点击订单后查询函数(rollback)
  157. public function rollback_order(Request $request){
  158. if ($request->isPost()){
  159. $data = input(); //获取订单的信息
  160. $result = Db::name('order_progress')->where(['type'=>"insert","orig_order"=>$data['orderid'],'error_code'=>0])->select(); //insert成功后插入的订单
  161. $result1 = Db::name('order_progress')->where(['type'=>"rollback","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //rollback失败后的订单
  162. $result2 = Db::name('order_progress')->where(['type'=>"retry","orig_order"=>$data['orderid']])->where('error_code','eq',0)->select(); //retry成功的订单
  163. $result = array_merge($result,$result1,$result2); //对数据进行合并
  164. if($result){
  165. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  166. }else{
  167. return json(['code'=>'01','msg'=>'暂无数据']);
  168. }
  169. }else{
  170. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  171. }
  172. }
  173. // 点击订单后查询函数(retry)
  174. public function retry_order(Request $request){
  175. if ($request->isPost()){
  176. $data = input(); //获取订单的信息
  177. $result = Db::name('order_progress')->where(['type'=>"insert","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //insert失败的订单
  178. $result1 = Db::name('order_progress')->where(['type'=>"retry","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //retry失败的订单
  179. $result2 = Db::name('order_progress')->where(['type'=>"except_rollback","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //except_rollback失败的订单
  180. $result = array_merge($result,$result1,$result2); //对数据进行合并
  181. if($result){
  182. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  183. }else{
  184. return json(['code'=>'01','msg'=>'暂无数据']);
  185. }
  186. }else{
  187. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  188. }
  189. }
  190. //确认密码函数(批量操作的时候需要)
  191. public function querypassword(Request $request){
  192. if ($request->isPost()){
  193. $data = input(); //获取传递的信息
  194. $password = md5($data['password']); //获取加密后的密码
  195. //根据用户来选择数据
  196. if($data['nickname']=="普通管理员"){
  197. $result = Db::name('admin')->where(['id'=>1])->find(); //找到用户(获取原始的密码)
  198. }else{
  199. $result = Db::name('admin')->where(['id'=>2])->find(); //找到用户(获取原始的密码)
  200. }
  201. // 筛选出来的数据进行密码的匹配
  202. if($password==$result['password']){
  203. return json(['code'=>'00','msg'=>'请求数据成功']);
  204. }else{
  205. return json(['code'=>'01','msg'=>'密码填写有误']);
  206. }
  207. }else{
  208. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  209. }
  210. }
  211. //更新梯度函数(retry的时候进行查询)
  212. public function update_percentage(Request $request){
  213. if ($request->isPost()){
  214. $data = input();//获取传递的信息
  215. $where['Login'] = ['in',implode(',',$data)];
  216. $result = Db::name('mt5_users')->where($where)->field(['Balance','Login'])->select();
  217. $result = array_column($result,'Balance','Login');
  218. if($result){
  219. return json(['code'=>'00','data'=>$result,'msg'=>'请求数据成功']);
  220. }else{
  221. return json(['code'=>'01','data'=>$result,'msg'=>'请求数据有误']);
  222. }
  223. }else{
  224. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  225. }
  226. }
  227. }