mirror of
				https://github.com/ehang-io/nps
				synced 2025-10-26 14:42:42 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			208 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Go
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			208 lines
		
	
	
		
			5.6 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, kwargs map[string]interface{}) {
 | |
| 	json := make(map[string]interface{})
 | |
| 	json["rows"] = list
 | |
| 	json["total"] = recordsTotal
 | |
| 	if kwargs != nil {
 | |
| 		for k, v := range kwargs {
 | |
| 			if v != nil {
 | |
| 				json[k] = v
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	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()
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 | 
