This commit is contained in:
root
2020-03-01 15:05:26 +08:00
parent 0865c98a7f
commit 0897f84a04
59 changed files with 13628 additions and 25877 deletions

101
web/views/client/add.html Executable file → Normal file
View File

@@ -1,126 +1,116 @@
<div class="row">
<div class="col-md-12 col-md-auto">
<div class="ibox float-e-margins">
<h3 class="ibox-title">add client</h3>
<h3 class="ibox-title" langtag="page-clientadd"></h3>
<div class="ibox-content">
<form class="form-horizontal">
<div class="form-group" id="remark">
<label class="col-sm-2 control-label" langtag="info-remark">备注</label>
<label class="control-label font-bold" langtag="word-remark"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="remark"
placeholder="remark">
<input class="form-control" type="text" name="remark" placeholder="" langtag="word-remark">
</div>
</div>
{{if eq true .allow_flow_limit}}
<div class="form-group" id="flow_limit">
<label class="col-sm-2 control-label" langtag="info-flow-limit">流量限制</label>
<label class="control-label font-bold" langtag="word-flowlimit"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="flow_limit"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none" langtag="info-flow-limit-unit">unit: M</span>
<input class="form-control" type="text" name="flow_limit" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="word-unit"></span>: M
</div>
</div>
{{end}}
{{if eq true .allow_rate_limit}}
<div class="form-group" id="rate_limit">
<label class="control-label col-sm-2" langtag="info-bandwidth">带宽限制</label>
<label class="control-label font-bold" langtag="word-ratelimit"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="rate_limit"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none" langtag="info-bandwidth-unit">unit: KB/S</span>
<input class="form-control" type="text" name="rate_limit" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="word-unit"></span>: KB/S
</div>
</div>
{{end}}
{{if eq true .allow_connection_num_limit}}
<div class="form-group" id="max_conn">
<label class="control-label col-sm-2" langtag="info-max-conn-num">客户端最大连接数量</label>
<label class="control-label font-bold" langtag="word-maxconnections"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="max_conn"
placeholder="empty means to be unrestricted">
<input class="form-control" type="text" name="max_conn" placeholder="" langtag="info-unrestricted">
</div>
</div>
{{end}}
{{if eq true .allow_tunnel_num_limit}}
<div class="form-group" id="max_tunnel">
<label class="control-label col-sm-2" langtag="info-max-tunnel-num">客户端最大隧道数量</label>
<label class="control-label font-bold" langtag="word-maxtunnels"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="max_tunnel"
placeholder="empty means to be unrestricted">
<input class="form-control" type="text" name="max_tunnel" placeholder="" langtag="info-unrestricted">
</div>
</div>
{{end}}
<div class="form-group" id="u">
<label class="control-label col-sm-2" langtag="info-web-auth-username">basic权限认证用户名</label>
<label class="control-label font-bold" langtag="word-basicusername"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="u"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">only socks5 , web, HTTP forward proxy </span>
<input class="form-control" type="text" name="u" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="info-onlyproxy"></span>
</div>
</div>
<div class="form-group" id="p">
<label class="control-label col-sm-2" langtag="info-web-auth-password">basic权限认证密码 </label>
<label class="control-label font-bold" langtag="word-basicpassword"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="p"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">only socks5 , web, HTTP forward proxy </span>
<input class="form-control" type="text" name="p" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="info-onlyproxy"></span>
</div>
</div>
<div class="form-group" id="vkey">
<label class="control-label col-sm-2" langtag="info-client-vkey">客户端验证密钥</label>
<label class="control-label font-bold" langtag="word-verifyKey"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="vkey"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">unique, non-filling will be generated automatically</span>
<input class="form-control" type="text" name="vkey" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="info-autogenerated"></span>
</div>
</div>
{{if eq true .allow_user_login}}
<div class="form-group" id="web_username">
<label class="control-label col-sm-2" langtag="info-client-web-username">web登陆用户名</label>
<label class="control-label font-bold" langtag="word-webusername"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="web_username"
placeholder="empty means to be unrestricted">
<input class="form-control" type="text" name="web_username" placeholder="" langtag="info-unrestricted">
</div>
</div>
<div class="form-group" id="web_password">
<label class="control-label col-sm-2" langtag="info-client-web-password">web登陆密码</label>
<label class="control-label font-bold" langtag="word-webpassword"></label>
<div class="col-sm-10">
<input class="form-control" type="text" name="web_password"
placeholder="empty means to be unrestricted">
<input class="form-control" type="text" name="web_password" placeholder="" langtag="info-unrestricted">
</div>
</div>
{{end}}
<div class="form-group" id="config_conn_allow">
<label class="control-label col-sm-2" langtag="info-config-conn-allow">是否允许客户端以配置文件模式连接</label>
<label class="control-label font-bold" langtag="word-connectbyconfig"></label>
<div class="col-sm-10">
<select class="form-control" name="config_conn_allow">
<option value="1">yes</option>
<option value="0">no</option>
<option value="1" langtag="word-yes"></option>
<option value="0" langtag="word-no"></option>
</select>
</div>
</div>
<div class="form-group" id="compress">
<label class="control-label col-sm-2" langtag="info-compress">压缩</label>
<label class="control-label font-bold" langtag="word-compress"></label>
<div class="col-sm-10">
<select class="form-control" name="compress">
<option value="0">no</option>
<option value="1">yes</option>
<option value="0" langtag="word-no"></option>
<option value="1" langtag="word-yes"></option>
</select>
</div>
</div>
<div class="form-group" id="compress">
<label class="control-label col-sm-2" langtag="info-crypt">加密</label>
<label class="control-label font-bold" langtag="word-crypt"></label>
<div class="col-sm-10">
<select class="form-control" name="crypt">
<option value="0">no</option>
<option value="1">yes</option>
<option value="0" langtag="word-no"></option>
<option value="1" langtag="word-yes"></option>
</select>
</div>
</div>
<div class="hr-line-dashed"></div>
<div class="form-group">
<div class="col-sm-4 col-sm-offset-2">
<button class="btn btn-success" type="button" id="add"><i
class="fa fa-fw fa-lg fa-eye"></i>新增
<button class="btn btn-success" type="button" onclick="submitform('add', '{{.web_base_url}}/client/add', $('form').serializeArray())">
<i class="fa fa-fw fa-lg fa-check-circle"></i> <span langtag="word-add"></span>
</button>
</div>
</div>
@@ -129,20 +119,3 @@
</div>
</div>
</div>
<script>
$(function () {
$("#add").on("click", function () {
$.ajax({
type: "POST",
url: "{{.web_base_url}}/client/add",
data: $("form").serializeArray(),
success: function (res) {
alert(res.msg)
if (res.status) {
history.back(-1)
}
}
})
})
})
</script>

103
web/views/client/edit.html Executable file → Normal file
View File

@@ -1,135 +1,125 @@
<div class="row">
<div class="col-md-12 col-md-auto">
<div class="ibox float-e-margins">
<h3 class="ibox-title">add client</h3>
<h3 class="ibox-title" langtag="page-clientedit"></h3>
<div class="ibox-content">
<form class="form-horizontal">
<input type="hidden" name="id" value="{{.c.Id}}">
<div class="form-group" id="remark">
<label class="col-sm-2 control-label" langtag="info-remark">备注</label>
<label class="control-label font-bold" langtag="word-remark"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.Remark}}" type="text" name="remark"
placeholder="remark">
<input class="form-control" value="{{.c.Remark}}" type="text" name="remark" placeholder="" langtag="word-remark">
</div>
</div>
{{if eq true .isAdmin}}
{{if eq true .allow_flow_limit}}
<div class="form-group" id="flow_limit">
<label class="col-sm-2 control-label" langtag="info-flow-limit">流量限制</label>
<label class="control-label font-bold" langtag="word-flowlimit"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.Flow.FlowLimit}}" type="text" name="flow_limit"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">unit: M</span>
<input class="form-control" value="{{.c.Flow.FlowLimit}}" type="text" name="flow_limit" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="word-unit"></span>: M
</div>
</div>
{{end}}
{{if eq true .allow_rate_limit}}
<div class="form-group" id="rate_limit">
<label class="control-label col-sm-2" langtag="info-bandwidth">带宽限制</label>
<label class="control-label font-bold" langtag="word-ratelimit"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.RateLimit}}" type="text" name="rate_limit"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">unit: KB/S</span>
<input class="form-control" value="{{.c.RateLimit}}" type="text" name="rate_limit" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="word-unit"></span>: KB/S
</div>
</div>
{{end}}
{{if eq true .allow_connection_num_limit}}
<div class="form-group" id="max_conn">
<label class="control-label col-sm-2" langtag="info-max-conn-num">客户端最大连接数</label>
<label class="control-label font-bold" langtag="word-maxconnections"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.MaxConn}}" type="text" name="max_conn"
placeholder="empty means to be unrestricted">
<input class="form-control" value="{{.c.MaxConn}}" type="text" name="max_conn" placeholder="" langtag="info-unrestricted">
</div>
</div>
{{end}}
{{if eq true .allow_tunnel_num_limit}}
<div class="form-group" id="max_tunnel">
<label class="control-label col-sm-2" langtag="info-max-tunnel-num">客户端最大隧道数量</label>
<label class="control-label font-bold" langtag="word-maxtunnels"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.MaxTunnelNum}}" type="text" name="max_tunnel"
placeholder="empty means to be unrestricted">
<input class="form-control" value="{{.c.MaxTunnelNum}}" type="text" name="max_tunnel" placeholder="" langtag="info-unrestricted">
</div>
</div>
{{end}}
{{end}}
<div class="form-group" id="u">
<label class="control-label col-sm-2" langtag="info-web-auth-username">basic权限认证用户名</label>
<label class="control-label font-bold" langtag="word-basicusername"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.Cnf.U}}" type="text" name="u"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">only socks5 , web, HTTP forward proxy </span>
<input class="form-control" value="{{.c.Cnf.U}}" type="text" name="u" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="info-onlyproxy"></span>
</div>
</div>
<div class="form-group" id="p">
<label class="control-label col-sm-2" langtag="info-web-auth-password">basic权限认证密码 </label>
<label class="control-label font-bold" langtag="word-basicpassword"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.Cnf.P}}" type="text" name="p"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">only socks5 , web, HTTP forward proxy </span>
<input class="form-control" value="{{.c.Cnf.P}}" type="text" name="p" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="info-onlyproxy"></span>
</div>
</div>
{{if eq true .isAdmin}}
<div class="form-group" id="vkey">
<label class="control-label col-sm-2" langtag="info-client-vkey">客户端验证密钥</label>
<label class="control-label font-bold" langtag="word-verifyKey"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.VerifyKey}}" type="text" name="vkey"
placeholder="empty means to be unrestricted">
<span class="help-block m-b-none">unique, non-filling will be generated automatically</span>
<input class="form-control" value="{{.c.VerifyKey}}" type="text" name="vkey" placeholder="" langtag="info-unrestricted">
<span class="help-block m-b-none" langtag="info-autogenerated"></span>
</div>
</div>
{{end}}
{{if eq true .allow_user_login}}
{{if or (eq true .allow_user_change_username) (eq true .isAdmin)}}
<div class="form-group" id="web_username">
<label class="control-label col-sm-2" langtag="info-client-web-username">web登陆用户名</label>
<label class="control-label font-bold" langtag="word-webusername"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.WebUserName}}" type="text" name="web_username"
placeholder="empty means to be unrestricted">
<input class="form-control" value="{{.c.WebUserName}}" type="text" name="web_username" placeholder="" langtag="info-unrestricted">
</div>
</div>
{{end}}
<div class="form-group" id="web_password">
<label class="control-label col-sm-2" langtag="info-client-web-password">web登陆密码</label>
<label class="control-label font-bold" langtag="word-webpassword"></label>
<div class="col-sm-10">
<input class="form-control" value="{{.c.WebPassword}}" type="text" name="web_password"
placeholder="empty means to be unrestricted">
<input class="form-control" value="{{.c.WebPassword}}" type="text" name="web_password" placeholder="" langtag="info-unrestricted">
</div>
</div>
{{end}}
<div class="form-group" id="config_conn_allow">
<label class="control-label col-sm-2" langtag="info-config-conn-allow">是否允许客户端以配置文件模式连接</label>
<label class="control-label font-bold" langtag="word-connectbyconfig"></label>
<div class="col-sm-10">
<select class="form-control" name="config_conn_allow">
<option {{if eq true .c.ConfigConnAllow}}selected{{end}} value="1">yes</option>
<option {{if eq false .c.ConfigConnAllow}}selected{{end}} value="0">no</option>
<option {{if eq true .c.ConfigConnAllow}}selected{{end}} value="1" langtag="word-yes"></option>
<option {{if eq false .c.ConfigConnAllow}}selected{{end}} value="0" langtag="word-no"></option>
</select>
</div>
</div>
<div class="form-group" id="compress">
<label class="control-label col-sm-2" langtag="info-compress">压缩</label>
<label class="control-label font-bold" langtag="word-compress"></label>
<div class="col-sm-10">
<select class="form-control" name="compress">
<option {{if eq false .c.Cnf.Compress}}selected{{end}} value="0">no</option>
<option {{if eq true .c.Cnf.Compress}}selected{{end}} value="1">yes</option>
<option {{if eq false .c.Cnf.Compress}}selected{{end}} value="0" langtag="word-no"></option>
<option {{if eq true .c.Cnf.Compress}}selected{{end}} value="1" langtag="word-yes"></option>
</select>
</div>
</div>
<div class="form-group" id="compress">
<label class="control-label col-sm-2" langtag="info-crypt">加密</label>
<label class="control-label font-bold" langtag="word-crypt"></label>
<div class="col-sm-10">
<select class="form-control" name="crypt">
<option {{if eq false .c.Cnf.Crypt}}selected{{end}} value="0">no</option>
<option {{if eq true .c.Cnf.Crypt}}selected{{end}} value="1">yes</option>
<option {{if eq false .c.Cnf.Crypt}}selected{{end}} value="0" langtag="word-no"></option>
<option {{if eq true .c.Cnf.Crypt}}selected{{end}} value="1" langtag="word-yes"></option>
</select>
</div>
</div>
<div class="hr-line-dashed"></div>
<div class="form-group">
<div class="col-sm-4 col-sm-offset-2">
<button class="btn btn-success" type="button" id="add"><i
class="fa fa-fw fa-lg fa-eye"></i><span langtag="info-save">保存</span>
<button class="btn btn-success" type="button" onclick="submitform('add', '{{.web_base_url}}/client/edit', $('form').serializeArray())"> <i
class="fa fa-fw fa-lg fa-save"></i><span langtag="word-save"></span>
</button>
</div>
</div>
@@ -138,22 +128,3 @@
</div>
</div>
</div>
<script>
$(function () {
$("#add").on("click", function () {
$.ajax({
type: "POST",
url: "{{.web_base_url}}/client/edit",
data: $("form").serializeArray(),
success: function (res) {
alert(res.msg)
if (res.status) {
history.back(-1)
}
}
})
})
})
</script>

190
web/views/client/list.html Executable file → Normal file
View File

@@ -4,7 +4,7 @@
<div class="col-lg-12">
<div class="ibox float-e-margins">
<div class="ibox-title">
<h5>client list</h5>
<h5 langtag="page-clientlist"></h5>
<div class="ibox-tools">
<a class="collapse-link">
@@ -20,10 +20,10 @@
<div class="table-responsive">
<div id="toolbar">
<a href="{{.web_base_url}}/client/add" class="btn btn-primary dim" type="button" langtag="info-new">新增</a>
<a href="{{.web_base_url}}/client/add" class="btn btn-primary dim">
<i class="fa fa-fw fa-lg fa-plus"></i> <span langtag="word-add"></span></a>
</div>
<table id="taskList_table" class="table-striped table-hover"
data-mobile-responsive="true"></table>
<table id="taskList_table" class="table-striped table-hover" data-mobile-responsive="true"></table>
</div>
</div>
{{end}}
@@ -38,73 +38,6 @@
</div>
<script>
function del(id) {
if (confirm("Are you sure you want to delete it")) {
$.ajax({
type: "POST",
url: "{{.web_base_url}}/client/del",
data: {"id": id},
success: function (res) {
alert(res.msg)
if (res.status) {
document.location.reload();
}
}
})
}
}
function start(id) {
if (confirm("Are you sure you want to start it")) {
$.ajax({
type: "POST",
url: "{{.web_base_url}}/client/changestatus",
data: {"id": id, "status": 1},
success: function (res) {
alert(res.msg)
if (res.status) {
document.location.reload();
}
}
})
}
}
function stop(id) {
if (confirm("Are you sure you want to stop it")) {
$.ajax({
type: "POST",
url: "{{.web_base_url}}/client/changestatus",
data: {
"id": id, "status": 0
},
success:
function (res) {
alert(res.msg)
if (res.status) {
document.location.reload();
}
}
})
}
}
function edit(id) {
window.location.href = "{{.web_base_url}}/client/edit?id=" + id
}
function add() {
window.location.href = "{{.web_base_url}}/client/add"
}
function tunnel(id) {
window.location.href = "{{.web_base_url}}/index/all?client_id=" + id
}
function host(id) {
window.location.href = "{{.web_base_url}}/index/hostlist?client_id=" + id
}
/*bootstrap table*/
$('#table').bootstrapTable({
toolbar: "#toolbar",
@@ -122,131 +55,158 @@
pageList: [5, 10, 20, 50],//分页步进值
detailView: true,
smartDisplay: true, // 智能显示 pagination 和 cardview 等
onExpandRow: function () {$('body').setLang ('.detail-view');},
onPostBody: function (data) { if ($(this)[0].locale != undefined ) $('body').setLang ('#table'); },
detailFormatter: function (index, row, element) {
return '<b langtag="info-max-conn-num">最大连接数</b>' + row.MaxConn + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-now-conn-num">当前连接数</b>' + row.NowConn + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-flow-limit">流量限制</b>' + row.Flow.FlowLimit + `m&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-rate-limit">带宽限制</b>' + row.RateLimit + `kb/s&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-max-tunnel-num">隧道数限制</b>' + row.MaxTunnelNum + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-client-web-username">web登陆用户名</b>' + row.WebUserName + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-client-web-password">web登陆密码</b>' + row.WebPassword + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp` + "<br/><br>"
+ '<b langtag="info-crypt">加密</b>' + row.Cnf.Crypt + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-compress">压缩</b>' + row.Cnf.Compress + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-config-conn-allow">是否允许配置文件模式连接</b>' + row.ConfigConnAllow + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-web-auth-username">basic认证用户名</b>' + row.Cnf.U + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp`
+ '<b langtag="info-web-auth-password">basic认证密码</b>' + row.Cnf.P + `&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp` + "<br/><br>"
+ '<b langtag="info-command">命令</b>' + "<code>./npc{{.win}} -server={{.ip}}:{{.p}} -vkey=" + row.VerifyKey + " -type=" +{{.bridgeType}} +"</code>"
return '<b langtag="word-maxconnections"></b>: ' + row.MaxConn + '&emsp;'
+ '<b langtag="word-curconnections"></b>: ' + row.NowConn + '&emsp;'
+ '<b langtag="word-flowlimit"></b>: ' + row.Flow.FlowLimit + 'm&emsp;'
+ '<b langtag="word-ratelimit"></b>: ' + row.RateLimit + 'kb/s&emsp;'
+ '<b langtag="word-maxtunnels"></b>: ' + row.MaxTunnelNum + '&emsp;<br/><br/>'
+ '<b langtag="word-webusername"></b>: ' + row.WebUserName + '&emsp;'
+ '<b langtag="word-webpassword"></b>: ' + row.WebPassword + '&emsp;'
+ '<b langtag="word-basicusername"></b>: ' + row.Cnf.U + '&emsp;'
+ '<b langtag="word-basicpassword"></b>: ' + row.Cnf.P + '&emsp;<br/><br/>'
+ '<b langtag="word-crypt"></b>: <span langtag="word-' + row.Cnf.Crypt + '"></span>&emsp;'
+ '<b langtag="word-compress"></b>: <span langtag="word-' + row.Cnf.Compress + '"></span>&emsp;'
+ '<b langtag="word-connectbyconfig"></b>: <span langtag="word-' + row.ConfigConnAllow + '"></span>&emsp;<br/><br/>'
+ '<b langtag="word-commandclient"></b>: ' + "<code>./npc{{.win}} -server={{.ip}}:{{.p}} -vkey=" + row.VerifyKey + " -type=" +{{.bridgeType}} +"</code>"
},
//表格的列
columns: [
{
field: 'Id',//域值
title: 'id',//标题
visible: true,//false表示不显示
title: '<span langtag="word-id"></span>',//标题
halign: 'center',
visible: true//false表示不显示
},
{
field: 'Remark',//域值
title: 'remark',//标题
visible: true,//false表示不显示
title: '<span langtag="word-remark"></span>',//标题
halign: 'center',
visible: true//false表示不显示
},
{
field: 'Version',//域值
title: 'version',//标题
visible: true,//false表示不显示
title: '<span langtag="word-version"></span>',//标题
halign: 'center',
visible: true//false表示不显示
},
{
field: 'VerifyKey',//域值
title: 'vkey',//标题
title: '<span langtag="word-verifykey"></span>',//标题
halign: 'center',
visible: true,//false表示不显示
formatter: function (value, row, index) {
if (!row.NoStore) {
return value
} else {
return "public vkey"
return '<span langtag="word-publicvkey"></span>'
}
}
},
{
field: 'Addr',//域值
title: 'client addr',//标题
visible: true,//false表示不显示
title: '<span langtag="word-address"></span>',//标题
halign: 'center',
visible: true//false表示不显示
},
{
field: 'InletFlow',//域值
title: 'in flow',//标题
title: '<span langtag="word-inletflow"></span>',//标题
halign: 'center',
visible: true,//false表示不显示
sortable: true,//启用排序
formatter: function (value, row, index) {
return change(row.Flow.InletFlow)
return changeunit(row.Flow.InletFlow)
}
},
{
field: 'ExportFlow',//域值
title: 'out flow',//标题
title: '<span langtag="word-exportflow"></span>',//标题
halign: 'center',
visible: true,//false表示不显示
sortable: true,//启用排序
formatter: function (value, row, index) {
return change(row.Flow.ExportFlow)
return changeunit(row.Flow.ExportFlow)
}
},
{
field: 'IsConnect',//域值
title: 'speed',//内容
title: '<span langtag="word-speed"></span>',//内容
halign: 'center',
visible: true,//false表示不显示
formatter: function (value, row, index) {
return change(row.Rate.NowRate) + "/S"
return changeunit(row.Rate.NowRate) + "/S"
}
},
{
field: 'Status',//域值
title: 'run',//内容
title: '<span langtag="word-status"></span>',//内容
align: 'center',
halign: 'center',
visible: true,//false表示不显示
formatter: function (value, row, index) {
if (value) {
return '<span class="badge badge-primary">open</span>'
return '<span class="badge badge-primary" langtag="word-open"></span>'
} else {
return '<span class="badge badge-badge">close</span>'
return '<span class="badge badge-badge" langtag="word-close"></span>'
}
}
},
{
field: 'IsConnect',//域值
title: 'status',//内容
title: '<span langtag="word-connect"></span>',//内容
align: 'center',
halign: 'center',
visible: true,//false表示不显示
formatter: function (value, row, index) {
if (value) {
return '<span class="badge badge-primary">online</span>'
return '<span class="badge badge-primary" langtag="word-online"></span>'
} else {
return '<span class="badge badge-badge">offline</span>'
return '<span class="badge badge-badge" langtag="word-offline"></span>'
}
}
},
{
field: 'option',//域值
title: 'option',//内容
title: '<span langtag="word-option"></span>',//内容
align: 'center',
halign: 'center',
visible: true,//false表示不显示
formatter: function (value, row, index) {
btn_group = '<div class="btn-group">'
btn = `{{if eq true .isAdmin}}<button onclick="del(` + row.Id + `)" class="btn-danger"><i class="fa fa-trash"></i></button>{{end}}<button onclick="edit(` + row.Id + `)" class="btn-primary"><i class="fa fa-edit"></i></button></div>`
{{if eq true .isAdmin}}
if (row.Status) {
return btn_group {{if eq true .isAdmin}}+ `<button onclick="stop(` + row.Id + `)" class="btn-warning"><i class="fa fa-close"></i></button>`{{end}}+ btn
btn_group += '<a onclick="submitform(\'stop\', \'{{.web_base_url}}/client/changestatus\', {\'id\':' + row.Id
btn_group += ', \'status\': 0})" class="btn btn-outline btn-warning"><i class="fa fa-pause"></i></a>'
} else {
return btn_group {{if eq true .isAdmin}}+ `<button onclick="start(` + row.Id + `)" class="btn-warning"><i class="fa fa-check"></i></button>`{{end}}+ btn
btn_group += '<a onclick="submitform(\'start\', \'{{.web_base_url}}/client/changestatus\', {\'id\':' + row.Id
btn_group += ', \'status\': 1})" class="btn btn-outline btn-primary"><i class="fa fa-play"></i></a>'
}
btn_group += '<a onclick="submitform(\'delete\', \'{{.web_base_url}}/client/del\', {\'id\':' + row.Id
btn_group += '})" class="btn btn-outline btn-danger"><i class="fa fa-trash"></i></a>'
{{end}}
btn_group += '<a href="{{.web_base_url}}/client/edit?id=' + row.Id
btn_group += '" class="btn btn-outline btn-success"><i class="fa fa-edit"></i></a></div>'
return btn_group
}
},
{
field: 'show',//域值
title: 'show',//内容
title: '<span langtag="word-show">',//内容
align: 'center',
halign: 'center',
visible: true,//false表示不显示
formatter: function (value, row, index) {
return `<button onclick="tunnel(` + row.Id + `)" class="btn-info">tunnel</button><button onclick="host(` + row.Id + `)" class="btn-primary">host</button>`
return '<div class="btn-group"><a href="{{.web_base_url}}/index/all?client_id=' + row.Id
+ '" class="btn btn-outline btn-primary" langtag="word-tunnel"></a>'
+ '<a href="{{.web_base_url}}/index/hostlist?client_id=' + row.Id
+ '" class="btn btn-outline btn-success" langtag="word-host"></a></div>'
}
}
]
});
</script>