mirror of https://github.com/qwqdanchun/nps.git
201 lines
5.5 KiB
Go
Executable File
201 lines
5.5 KiB
Go
Executable File
package controllers
|
|
|
|
import (
|
|
"html"
|
|
"math"
|
|
"strconv"
|
|
"strings"
|
|
"time"
|
|
|
|
"ehang.io/nps/lib/common"
|
|
"ehang.io/nps/lib/crypt"
|
|
"ehang.io/nps/lib/file"
|
|
"ehang.io/nps/server"
|
|
"github.com/astaxie/beego"
|
|
)
|
|
|
|
type BaseController struct {
|
|
beego.Controller
|
|
controllerName string
|
|
actionName string
|
|
}
|
|
|
|
//初始化参数
|
|
func (s *BaseController) Prepare() {
|
|
s.Data["web_base_url"] = beego.AppConfig.String("web_base_url")
|
|
controllerName, actionName := s.GetControllerAndAction()
|
|
s.controllerName = strings.ToLower(controllerName[0 : len(controllerName)-10])
|
|
s.actionName = strings.ToLower(actionName)
|
|
// web api verify
|
|
// param 1 is md5(authKey+Current timestamp)
|
|
// param 2 is timestamp (It's limited to 20 seconds.)
|
|
md5Key := s.getEscapeString("auth_key")
|
|
timestamp := s.GetIntNoErr("timestamp")
|
|
configKey := beego.AppConfig.String("auth_key")
|
|
timeNowUnix := time.Now().Unix()
|
|
if !(md5Key!="" && (math.Abs(float64(timeNowUnix-int64(timestamp))) <= 20) && (crypt.Md5(configKey+strconv.Itoa(timestamp)) == md5Key)) {
|
|
if s.GetSession("auth") != true {
|
|
s.Redirect(beego.AppConfig.String("web_base_url")+"/login/index", 302)
|
|
}
|
|
}else {
|
|
s.SetSession("isAdmin",true)
|
|
s.Data["isAdmin"] = true
|
|
}
|
|
if s.GetSession("isAdmin") != nil && !s.GetSession("isAdmin").(bool) {
|
|
s.Ctx.Input.SetData("client_id", s.GetSession("clientId").(int))
|
|
s.Ctx.Input.SetParam("client_id", strconv.Itoa(s.GetSession("clientId").(int)))
|
|
s.Data["isAdmin"] = false
|
|
s.Data["username"] = s.GetSession("username")
|
|
s.CheckUserAuth()
|
|
} else {
|
|
s.Data["isAdmin"] = true
|
|
}
|
|
s.Data["https_just_proxy"], _ = beego.AppConfig.Bool("https_just_proxy")
|
|
s.Data["allow_user_login"], _ = beego.AppConfig.Bool("allow_user_login")
|
|
s.Data["allow_flow_limit"], _ = beego.AppConfig.Bool("allow_flow_limit")
|
|
s.Data["allow_rate_limit"], _ = beego.AppConfig.Bool("allow_rate_limit")
|
|
s.Data["allow_connection_num_limit"], _ = beego.AppConfig.Bool("allow_connection_num_limit")
|
|
s.Data["allow_multi_ip"], _ = beego.AppConfig.Bool("allow_multi_ip")
|
|
s.Data["system_info_display"], _ = beego.AppConfig.Bool("system_info_display")
|
|
s.Data["allow_tunnel_num_limit"], _ = beego.AppConfig.Bool("allow_tunnel_num_limit")
|
|
s.Data["allow_local_proxy"], _ = beego.AppConfig.Bool("allow_local_proxy")
|
|
s.Data["allow_user_change_username"], _ = beego.AppConfig.Bool("allow_user_change_username")
|
|
}
|
|
|
|
//加载模板
|
|
func (s *BaseController) display(tpl ...string) {
|
|
s.Data["web_base_url"] = beego.AppConfig.String("web_base_url")
|
|
var tplname string
|
|
if s.Data["menu"] == nil {
|
|
s.Data["menu"] = s.actionName
|
|
}
|
|
if len(tpl) > 0 {
|
|
tplname = strings.Join([]string{tpl[0], "html"}, ".")
|
|
} else {
|
|
tplname = s.controllerName + "/" + s.actionName + ".html"
|
|
}
|
|
ip := s.Ctx.Request.Host
|
|
s.Data["ip"] = common.GetIpByAddr(ip)
|
|
s.Data["bridgeType"] = beego.AppConfig.String("bridge_type")
|
|
if common.IsWindows() {
|
|
s.Data["win"] = ".exe"
|
|
}
|
|
s.Data["p"] = server.Bridge.TunnelPort
|
|
s.Data["proxyPort"] = beego.AppConfig.String("hostPort")
|
|
s.Layout = "public/layout.html"
|
|
s.TplName = tplname
|
|
}
|
|
|
|
//错误
|
|
func (s *BaseController) error() {
|
|
s.Data["web_base_url"] = beego.AppConfig.String("web_base_url")
|
|
s.Layout = "public/layout.html"
|
|
s.TplName = "public/error.html"
|
|
}
|
|
|
|
//getEscapeString
|
|
func (s *BaseController) getEscapeString(key string) string {
|
|
return html.EscapeString(s.GetString(key))
|
|
}
|
|
|
|
//去掉没有err返回值的int
|
|
func (s *BaseController) GetIntNoErr(key string, def ...int) int {
|
|
strv := s.Ctx.Input.Query(key)
|
|
if len(strv) == 0 && len(def) > 0 {
|
|
return def[0]
|
|
}
|
|
val, _ := strconv.Atoi(strv)
|
|
return val
|
|
}
|
|
|
|
//获取去掉错误的bool值
|
|
func (s *BaseController) GetBoolNoErr(key string, def ...bool) bool {
|
|
strv := s.Ctx.Input.Query(key)
|
|
if len(strv) == 0 && len(def) > 0 {
|
|
return def[0]
|
|
}
|
|
val, _ := strconv.ParseBool(strv)
|
|
return val
|
|
}
|
|
|
|
//ajax正确返回
|
|
func (s *BaseController) AjaxOk(str string) {
|
|
s.Data["json"] = ajax(str, 1)
|
|
s.ServeJSON()
|
|
s.StopRun()
|
|
}
|
|
|
|
//ajax错误返回
|
|
func (s *BaseController) AjaxErr(str string) {
|
|
s.Data["json"] = ajax(str, 0)
|
|
s.ServeJSON()
|
|
s.StopRun()
|
|
}
|
|
|
|
//组装ajax
|
|
func ajax(str string, status int) map[string]interface{} {
|
|
json := make(map[string]interface{})
|
|
json["status"] = status
|
|
json["msg"] = str
|
|
return json
|
|
}
|
|
|
|
//ajax table返回
|
|
func (s *BaseController) AjaxTable(list interface{}, cnt int, recordsTotal int) {
|
|
json := make(map[string]interface{})
|
|
json["rows"] = list
|
|
json["total"] = recordsTotal
|
|
s.Data["json"] = json
|
|
s.ServeJSON()
|
|
s.StopRun()
|
|
}
|
|
|
|
//ajax table参数
|
|
func (s *BaseController) GetAjaxParams() (start, limit int) {
|
|
return s.GetIntNoErr("offset"), s.GetIntNoErr("limit")
|
|
}
|
|
|
|
func (s *BaseController) SetInfo(name string) {
|
|
s.Data["name"] = name
|
|
}
|
|
|
|
func (s *BaseController) SetType(name string) {
|
|
s.Data["type"] = name
|
|
}
|
|
|
|
func (s *BaseController) CheckUserAuth() {
|
|
if s.controllerName == "client" {
|
|
if s.actionName == "add" {
|
|
s.StopRun()
|
|
return
|
|
}
|
|
if id := s.GetIntNoErr("id"); id != 0 {
|
|
if id != s.GetSession("clientId").(int) {
|
|
s.StopRun()
|
|
return
|
|
}
|
|
}
|
|
}
|
|
if s.controllerName == "index" {
|
|
if id := s.GetIntNoErr("id"); id != 0 {
|
|
belong := false
|
|
if strings.Contains(s.actionName, "h") {
|
|
if v, ok := file.GetDb().JsonDb.Hosts.Load(id); ok {
|
|
if v.(*file.Host).Client.Id == s.GetSession("clientId").(int) {
|
|
belong = true
|
|
}
|
|
}
|
|
} else {
|
|
if v, ok := file.GetDb().JsonDb.Tasks.Load(id); ok {
|
|
if v.(*file.Tunnel).Client.Id == s.GetSession("clientId").(int) {
|
|
belong = true
|
|
}
|
|
}
|
|
}
|
|
if !belong {
|
|
s.StopRun()
|
|
}
|
|
}
|
|
}
|
|
}
|