|
|
@@ -2,6 +2,7 @@
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
+use App\Http\Models\Article;
|
|
|
use App\Http\Models\SsNode;
|
|
|
use App\Http\Models\SsNodeInfo;
|
|
|
use App\Http\Models\SsNodeOnlineLog;
|
|
|
@@ -15,7 +16,24 @@ class UserController extends BaseController
|
|
|
{
|
|
|
public function index(Request $request)
|
|
|
{
|
|
|
- return Response::view('user/index');
|
|
|
+ if (!$request->session()->has('user')) {
|
|
|
+ return Redirect::to('login');
|
|
|
+ }
|
|
|
+
|
|
|
+ $view['articleList'] = Article::orderBy('sort', 'desc')->orderBy('id', 'desc')->limit(5)->get();
|
|
|
+ $view['info'] = $request->session()->get('user');
|
|
|
+
|
|
|
+ return Response::view('user/index', $view);
|
|
|
+ }
|
|
|
+
|
|
|
+ // 公告详情
|
|
|
+ public function article(Request $request)
|
|
|
+ {
|
|
|
+ $id = $request->get('id');
|
|
|
+
|
|
|
+ $view['info'] = Article::where('id', $id)->first();
|
|
|
+
|
|
|
+ return Response::view('user/article', $view);
|
|
|
}
|
|
|
|
|
|
// 修改个人资料
|
|
|
@@ -30,29 +48,84 @@ class UserController extends BaseController
|
|
|
if ($request->method() == 'POST') {
|
|
|
$old_password = $request->get('old_password');
|
|
|
$new_password = $request->get('new_password');
|
|
|
+ $port = trim($request->get('port'));
|
|
|
+ $passwd = trim($request->get('passwd'));
|
|
|
+ $method = $request->get('method');
|
|
|
+ $protocol = $request->get('protocol');
|
|
|
+ $obfs = $request->get('obfs');
|
|
|
+
|
|
|
+ // 修改密码
|
|
|
+ if (!empty($old_password) && !empty($new_password)) {
|
|
|
+ $old_password = md5(trim($old_password));
|
|
|
+ $new_password = md5(trim($new_password));
|
|
|
+
|
|
|
+ $user = User::where('id', $user['id'])->first();
|
|
|
+ if ($user->password != $old_password) {
|
|
|
+ $request->session()->flash('errorMsg', '旧密码错误,请重新输入');
|
|
|
+
|
|
|
+ return Redirect::to('user/profile#tab_1');
|
|
|
+ } else if ($user->password == $new_password) {
|
|
|
+ $request->session()->flash('errorMsg', '新密码不可与旧密码一样,请重新输入');
|
|
|
+
|
|
|
+ return Redirect::to('user/profile#tab_1');
|
|
|
+ }
|
|
|
+
|
|
|
+ $ret = User::where('id', $user['id'])->update(['password' => $new_password]);
|
|
|
+ if (!$ret) {
|
|
|
+ $request->session()->flash('errorMsg', '修改失败');
|
|
|
+
|
|
|
+ return Redirect::to('user/profile#tab_1');
|
|
|
+ } else {
|
|
|
+ $request->session()->flash('successMsg', '修改成功');
|
|
|
+
|
|
|
+ return Redirect::to('user/profile#tab_1');
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
- $old_password = md5(trim($old_password));
|
|
|
- $new_password = md5(trim($new_password));
|
|
|
+ // 修改SS信息
|
|
|
+ if (empty($port)) {
|
|
|
+ $request->session()->flash('errorMsg', '端口不能为空');
|
|
|
|
|
|
- $user = User::where('id', $user['id'])->first();
|
|
|
- if ($user->password != $old_password) {
|
|
|
- $request->session()->flash('errorMsg', '旧密码错误,请重新输入');
|
|
|
- return Redirect::back();
|
|
|
- } else if ($user->password == $new_password) {
|
|
|
- $request->session()->flash('errorMsg', '新密码不可与旧密码一样,请重新输入');
|
|
|
- return Redirect::back();
|
|
|
+ return Redirect::to('user/profile#tab_2');
|
|
|
}
|
|
|
|
|
|
- $ret = User::where('id', $user['id'])->update(['password' => $new_password]);
|
|
|
+ if (empty($passwd)) {
|
|
|
+ $request->session()->flash('errorMsg', '密码不能为空');
|
|
|
+
|
|
|
+ return Redirect::to('user/profile#tab_2');
|
|
|
+ }
|
|
|
+
|
|
|
+ $data = [
|
|
|
+ //'port' => $port,
|
|
|
+ 'passwd' => $passwd,
|
|
|
+ 'method' => $method,
|
|
|
+ 'protocol' => $protocol,
|
|
|
+ 'obfs' => $obfs
|
|
|
+ ];
|
|
|
+
|
|
|
+ $ret = User::where('id', $user['id'])->update($data);
|
|
|
if (!$ret) {
|
|
|
$request->session()->flash('errorMsg', '修改失败');
|
|
|
- return Redirect::back();
|
|
|
+
|
|
|
+ return Redirect::to('user/profile#tab_2');
|
|
|
} else {
|
|
|
+ // 更新session
|
|
|
+ $user = User::where('id', $user['id'])->first()->toArray();
|
|
|
+ $request->session()->remove('user');
|
|
|
+ $request->session()->put('user', $user);
|
|
|
+
|
|
|
$request->session()->flash('successMsg', '修改成功');
|
|
|
- return Redirect::back();
|
|
|
+
|
|
|
+ return Redirect::to('user/profile#tab_2');
|
|
|
}
|
|
|
} else {
|
|
|
- return Response::view('user/profile');
|
|
|
+ // 加密方式、协议、混淆
|
|
|
+ $view['method_list'] = $this->methodList();
|
|
|
+ $view['protocol_list'] = $this->protocolList();
|
|
|
+ $view['obfs_list'] = $this->obfsList();
|
|
|
+ $view['info'] = User::where('id', $user['id'])->first();
|
|
|
+
|
|
|
+ return Response::view('user/profile', $view);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -63,6 +136,8 @@ class UserController extends BaseController
|
|
|
return Redirect::to('login');
|
|
|
}
|
|
|
|
|
|
+ $user = $request->session()->get('user');
|
|
|
+
|
|
|
$nodeList = SsNode::paginate(10);
|
|
|
foreach ($nodeList as &$node) {
|
|
|
// 在线人数
|
|
|
@@ -77,6 +152,40 @@ class UserController extends BaseController
|
|
|
// 负载
|
|
|
$node_info = SsNodeInfo::where('node_id', $node->id)->orderBy('id', 'desc')->first();
|
|
|
$node->load = empty($node_info->load) ? 0 : $node_info->load;
|
|
|
+
|
|
|
+ // 生成ssr scheme
|
|
|
+ $ssr_str = '';
|
|
|
+ $ssr_str .= $node->server . ':' . $user['port'];
|
|
|
+ $ssr_str .= ':' . $user['protocol'] . ':' . $user['method'];
|
|
|
+ $ssr_str .= ':' . $user['obfs'] . ':' . base64_encode($user['passwd']);
|
|
|
+ $ssr_str .= '/?obfsparam=' . $user['obfs_param'];
|
|
|
+ $ssr_str .= '&=protoparam' . $user['protocol_param'];
|
|
|
+ $ssr_str .= '&remarks=' . base64_encode('VPN');
|
|
|
+ $ssr_str = $this->base64url_encode($ssr_str);
|
|
|
+ $ssr_scheme = 'ssr://' . $ssr_str;
|
|
|
+
|
|
|
+ // 生成ss scheme
|
|
|
+ $ss_str = '';
|
|
|
+ $ss_str .= $user['method']. ':' . $user['passwd'] . '@';
|
|
|
+ $ss_str .= $node->server . ':' . $user['port'];
|
|
|
+ $ss_str = $this->base64url_encode($ss_str) . '#' . 'VPN';
|
|
|
+ $ss_scheme = 'ss://' . $ss_str;
|
|
|
+
|
|
|
+ // 生成文本配置信息
|
|
|
+ $txt = <<<TXT
|
|
|
+服务器:{$node->server}
|
|
|
+端口:{$user['port']}
|
|
|
+密码:{$user['passwd']}
|
|
|
+加密方式:{$user['method']}
|
|
|
+协议:{$user['protocol']}
|
|
|
+协议参数:{$user['protocol_param']}
|
|
|
+混淆:{$user['obfs']}
|
|
|
+混淆参数:{$user['obfs_param']}
|
|
|
+TXT;
|
|
|
+
|
|
|
+ $node->txt = $txt;
|
|
|
+ $node->ssr_scheme = $ssr_scheme;
|
|
|
+ $node->ss_scheme = $ss_scheme;
|
|
|
}
|
|
|
|
|
|
$view['nodeList'] = $nodeList;
|
|
|
@@ -93,14 +202,13 @@ class UserController extends BaseController
|
|
|
|
|
|
$user = $request->session()->get('user');
|
|
|
|
|
|
- $trafficLogList = UserTrafficLog::with(['User', 'SsNode'])->where('user_id', $user['id'])->orderBy('id', 'desc')->paginate(20);
|
|
|
- foreach ($trafficLogList as &$trafficLog) {
|
|
|
- $trafficLog->u = $this->flowAutoShow($trafficLog->u);
|
|
|
- $trafficLog->d = $this->flowAutoShow($trafficLog->d);
|
|
|
- $trafficLog->log_time = date('Y-m-d H:i:s', $trafficLog->log_time);
|
|
|
+ // 30天内的流量
|
|
|
+ $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`");
|
|
|
+ foreach ($trafficList as $key => &$val) {
|
|
|
+ $val->total = ($val->u + $val->d) / (1024 * 1024); // 以M为单位
|
|
|
}
|
|
|
|
|
|
- $view['trafficLogList'] = $trafficLogList;
|
|
|
+ $view['trafficList'] = $trafficList;
|
|
|
|
|
|
return Response::view('user/trafficLog', $view);
|
|
|
}
|