UserController.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Models\Article;
  4. use App\Http\Models\SsNode;
  5. use App\Http\Models\SsNodeInfo;
  6. use App\Http\Models\SsNodeOnlineLog;
  7. use App\Http\Models\User;
  8. use App\Http\Models\UserTrafficLog;
  9. use Illuminate\Http\Request;
  10. use Redirect;
  11. use Response;
  12. class UserController extends BaseController
  13. {
  14. public function index(Request $request)
  15. {
  16. if (!$request->session()->has('user')) {
  17. return Redirect::to('login');
  18. }
  19. $view['articleList'] = Article::orderBy('sort', 'desc')->orderBy('id', 'desc')->limit(5)->get();
  20. $view['info'] = $request->session()->get('user');
  21. return Response::view('user/index', $view);
  22. }
  23. // 公告详情
  24. public function article(Request $request)
  25. {
  26. $id = $request->get('id');
  27. $view['info'] = Article::where('id', $id)->first();
  28. return Response::view('user/article', $view);
  29. }
  30. // 修改个人资料
  31. public function profile(Request $request)
  32. {
  33. if (!$request->session()->has('user')) {
  34. return Redirect::to('login');
  35. }
  36. $user = $request->session()->get('user');
  37. if ($request->method() == 'POST') {
  38. $old_password = $request->get('old_password');
  39. $new_password = $request->get('new_password');
  40. $port = trim($request->get('port'));
  41. $passwd = trim($request->get('passwd'));
  42. $method = $request->get('method');
  43. $protocol = $request->get('protocol');
  44. $obfs = $request->get('obfs');
  45. // 修改密码
  46. if (!empty($old_password) && !empty($new_password)) {
  47. $old_password = md5(trim($old_password));
  48. $new_password = md5(trim($new_password));
  49. $user = User::where('id', $user['id'])->first();
  50. if ($user->password != $old_password) {
  51. $request->session()->flash('errorMsg', '旧密码错误,请重新输入');
  52. return Redirect::to('user/profile#tab_1');
  53. } else if ($user->password == $new_password) {
  54. $request->session()->flash('errorMsg', '新密码不可与旧密码一样,请重新输入');
  55. return Redirect::to('user/profile#tab_1');
  56. }
  57. $ret = User::where('id', $user['id'])->update(['password' => $new_password]);
  58. if (!$ret) {
  59. $request->session()->flash('errorMsg', '修改失败');
  60. return Redirect::to('user/profile#tab_1');
  61. } else {
  62. $request->session()->flash('successMsg', '修改成功');
  63. return Redirect::to('user/profile#tab_1');
  64. }
  65. }
  66. // 修改SS信息
  67. if (empty($port)) {
  68. $request->session()->flash('errorMsg', '端口不能为空');
  69. return Redirect::to('user/profile#tab_2');
  70. }
  71. if (empty($passwd)) {
  72. $request->session()->flash('errorMsg', '密码不能为空');
  73. return Redirect::to('user/profile#tab_2');
  74. }
  75. $data = [
  76. //'port' => $port,
  77. 'passwd' => $passwd,
  78. 'method' => $method,
  79. 'protocol' => $protocol,
  80. 'obfs' => $obfs
  81. ];
  82. $ret = User::where('id', $user['id'])->update($data);
  83. if (!$ret) {
  84. $request->session()->flash('errorMsg', '修改失败');
  85. return Redirect::to('user/profile#tab_2');
  86. } else {
  87. // 更新session
  88. $user = User::where('id', $user['id'])->first()->toArray();
  89. $request->session()->remove('user');
  90. $request->session()->put('user', $user);
  91. $request->session()->flash('successMsg', '修改成功');
  92. return Redirect::to('user/profile#tab_2');
  93. }
  94. } else {
  95. // 加密方式、协议、混淆
  96. $view['method_list'] = $this->methodList();
  97. $view['protocol_list'] = $this->protocolList();
  98. $view['obfs_list'] = $this->obfsList();
  99. $view['info'] = User::where('id', $user['id'])->first();
  100. return Response::view('user/profile', $view);
  101. }
  102. }
  103. // 节点列表
  104. public function nodeList(Request $request)
  105. {
  106. if (!$request->session()->has('user')) {
  107. return Redirect::to('login');
  108. }
  109. $user = $request->session()->get('user');
  110. $nodeList = SsNode::paginate(10);
  111. foreach ($nodeList as &$node) {
  112. // 在线人数
  113. $online_log = SsNodeOnlineLog::where('node_id', $node->id)->orderBy('id', 'desc')->first();
  114. $node->online_users = empty($online_log) ? 0 : $online_log->online_user;
  115. // 已产生流量
  116. $u = UserTrafficLog::where('node_id', $node->id)->sum('u');
  117. $d = UserTrafficLog::where('node_id', $node->id)->sum('d');
  118. $node->transfer = $this->flowAutoShow($u + $d);
  119. // 负载
  120. $node_info = SsNodeInfo::where('node_id', $node->id)->orderBy('id', 'desc')->first();
  121. $node->load = empty($node_info->load) ? 0 : $node_info->load;
  122. // 生成ssr scheme
  123. $ssr_str = '';
  124. $ssr_str .= $node->server . ':' . $user['port'];
  125. $ssr_str .= ':' . $user['protocol'] . ':' . $user['method'];
  126. $ssr_str .= ':' . $user['obfs'] . ':' . base64_encode($user['passwd']);
  127. $ssr_str .= '/?obfsparam=' . $user['obfs_param'];
  128. $ssr_str .= '&=protoparam' . $user['protocol_param'];
  129. $ssr_str .= '&remarks=' . base64_encode('VPN');
  130. $ssr_str = $this->base64url_encode($ssr_str);
  131. $ssr_scheme = 'ssr://' . $ssr_str;
  132. // 生成ss scheme
  133. $ss_str = '';
  134. $ss_str .= $user['method']. ':' . $user['passwd'] . '@';
  135. $ss_str .= $node->server . ':' . $user['port'];
  136. $ss_str = $this->base64url_encode($ss_str) . '#' . 'VPN';
  137. $ss_scheme = 'ss://' . $ss_str;
  138. // 生成文本配置信息
  139. $txt = <<<TXT
  140. 服务器:{$node->server}
  141. 端口:{$user['port']}
  142. 密码:{$user['passwd']}
  143. 加密方式:{$user['method']}
  144. 协议:{$user['protocol']}
  145. 协议参数:{$user['protocol_param']}
  146. 混淆:{$user['obfs']}
  147. 混淆参数:{$user['obfs_param']}
  148. TXT;
  149. $node->txt = $txt;
  150. $node->ssr_scheme = $ssr_scheme;
  151. $node->ss_scheme = $ss_scheme;
  152. }
  153. $view['nodeList'] = $nodeList;
  154. return Response::view('user/nodeList', $view);
  155. }
  156. // 流量日志
  157. public function trafficLog(Request $request)
  158. {
  159. if (!$request->session()->has('user')) {
  160. return Redirect::to('login');
  161. }
  162. $user = $request->session()->get('user');
  163. // 30天内的流量
  164. $trafficList = \DB::select("SELECT date(from_unixtime(log_time)) AS dd, SUM(u) AS u, SUM(d) AS d FROM `user_traffic_log` WHERE `user_id` = {$user['id']} GROUP BY `dd`");
  165. foreach ($trafficList as $key => &$val) {
  166. $val->total = ($val->u + $val->d) / (1024 * 1024); // 以M为单位
  167. }
  168. $view['trafficList'] = $trafficList;
  169. return Response::view('user/trafficLog', $view);
  170. }
  171. // 邀请码
  172. public function invite(Request $request)
  173. {
  174. if (!$request->session()->has('user')) {
  175. return Redirect::to('login');
  176. }
  177. $user = $request->session()->get('user');
  178. $view = [];
  179. return Response::view('user/invite', $view);
  180. }
  181. }