mirror of
https://github.com/ehang-io/nps.git
synced 2025-07-03 04:53:50 +00:00
144 lines
4.2 KiB
Go
Executable File
144 lines
4.2 KiB
Go
Executable File
package controllers
|
|
|
|
import (
|
|
"math/rand"
|
|
"net"
|
|
"sync"
|
|
"time"
|
|
|
|
"github.com/astaxie/beego"
|
|
"github.com/cnlh/nps/lib/common"
|
|
"github.com/cnlh/nps/lib/file"
|
|
"github.com/cnlh/nps/server"
|
|
)
|
|
|
|
type LoginController struct {
|
|
beego.Controller
|
|
}
|
|
|
|
var ipRecord sync.Map
|
|
|
|
type record struct {
|
|
hasLoginFailTimes int
|
|
lastLoginTime time.Time
|
|
}
|
|
|
|
func (self *LoginController) Index() {
|
|
self.Data["web_base_url"] = beego.AppConfig.String("web_base_url")
|
|
self.Data["register_allow"], _ = beego.AppConfig.Bool("allow_user_register")
|
|
self.TplName = "login/index.html"
|
|
}
|
|
func (self *LoginController) Verify() {
|
|
clearIprecord()
|
|
ip, _, _ := net.SplitHostPort(self.Ctx.Request.RemoteAddr)
|
|
if v, ok := ipRecord.Load(ip); ok {
|
|
vv := v.(*record)
|
|
if (time.Now().Unix() - vv.lastLoginTime.Unix()) >= 60 {
|
|
vv.hasLoginFailTimes = 0
|
|
}
|
|
if vv.hasLoginFailTimes >= 10 {
|
|
self.Data["json"] = map[string]interface{}{"status": 0, "msg": "username or password incorrect"}
|
|
self.ServeJSON()
|
|
return
|
|
}
|
|
}
|
|
var auth bool
|
|
if self.GetString("password") == beego.AppConfig.String("web_password") && self.GetString("username") == beego.AppConfig.String("web_username") {
|
|
self.SetSession("isAdmin", true)
|
|
self.DelSession("clientId")
|
|
self.DelSession("username")
|
|
auth = true
|
|
server.Bridge.Register.Store(common.GetIpByAddr(self.Ctx.Input.IP()), time.Now().Add(time.Hour*time.Duration(2)))
|
|
}
|
|
b, err := beego.AppConfig.Bool("allow_user_login")
|
|
if err == nil && b && !auth {
|
|
file.GetDb().JsonDb.Clients.Range(func(key, value interface{}) bool {
|
|
v := value.(*file.Client)
|
|
if !v.Status || v.NoDisplay {
|
|
return true
|
|
}
|
|
if v.WebUserName == "" && v.WebPassword == "" {
|
|
if self.GetString("username") != "user" || v.VerifyKey != self.GetString("password") {
|
|
return true
|
|
} else {
|
|
auth = true
|
|
}
|
|
}
|
|
if !auth && v.WebPassword == self.GetString("password") && self.GetString("username") == v.WebUserName {
|
|
auth = true
|
|
}
|
|
if auth {
|
|
self.SetSession("isAdmin", false)
|
|
self.SetSession("clientId", v.Id)
|
|
self.SetSession("username", v.WebUserName)
|
|
return false
|
|
}
|
|
return true
|
|
})
|
|
}
|
|
if auth {
|
|
self.SetSession("auth", true)
|
|
self.Data["json"] = map[string]interface{}{"status": 1, "msg": "login success"}
|
|
ipRecord.Delete(ip)
|
|
} else {
|
|
if v, load := ipRecord.LoadOrStore(ip, &record{hasLoginFailTimes: 1, lastLoginTime: time.Now()}); load {
|
|
vv := v.(*record)
|
|
vv.lastLoginTime = time.Now()
|
|
vv.hasLoginFailTimes += 1
|
|
ipRecord.Store(ip, vv)
|
|
}
|
|
self.Data["json"] = map[string]interface{}{"status": 0, "msg": "username or password incorrect"}
|
|
}
|
|
self.ServeJSON()
|
|
}
|
|
func (self *LoginController) Register() {
|
|
if self.Ctx.Request.Method == "GET" {
|
|
self.Data["web_base_url"] = beego.AppConfig.String("web_base_url")
|
|
self.TplName = "login/register.html"
|
|
} else {
|
|
if b, err := beego.AppConfig.Bool("allow_user_register"); err != nil || !b {
|
|
self.Data["json"] = map[string]interface{}{"status": 0, "msg": "register is not allow"}
|
|
self.ServeJSON()
|
|
return
|
|
}
|
|
if self.GetString("username") == "" || self.GetString("password") == "" || self.GetString("username") == beego.AppConfig.String("web_username") {
|
|
self.Data["json"] = map[string]interface{}{"status": 0, "msg": "please check your input"}
|
|
self.ServeJSON()
|
|
return
|
|
}
|
|
t := &file.Client{
|
|
Id: int(file.GetDb().JsonDb.GetClientId()),
|
|
Status: true,
|
|
Cnf: &file.Config{},
|
|
WebUserName: self.GetString("username"),
|
|
WebPassword: self.GetString("password"),
|
|
Flow: &file.Flow{},
|
|
}
|
|
if err := file.GetDb().NewClient(t); err != nil {
|
|
self.Data["json"] = map[string]interface{}{"status": 0, "msg": err.Error()}
|
|
} else {
|
|
self.Data["json"] = map[string]interface{}{"status": 1, "msg": "register success"}
|
|
}
|
|
self.ServeJSON()
|
|
}
|
|
}
|
|
|
|
func (self *LoginController) Out() {
|
|
self.SetSession("auth", false)
|
|
self.Redirect(beego.AppConfig.String("web_base_url")+"/login/index", 302)
|
|
}
|
|
|
|
func clearIprecord() {
|
|
rand.Seed(time.Now().UnixNano())
|
|
x := rand.Intn(100)
|
|
if x == 1 {
|
|
ipRecord.Range(func(key, value interface{}) bool {
|
|
v := value.(*record)
|
|
if time.Now().Unix()-v.lastLoginTime.Unix() >= 60 {
|
|
ipRecord.Delete(key)
|
|
}
|
|
return true
|
|
})
|
|
}
|
|
}
|