123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- 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 !((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)
- }
- }
- 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()
- }
- }
- }
- }
|