login.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. package controllers
  2. import (
  3. "time"
  4. "github.com/astaxie/beego"
  5. "github.com/cnlh/nps/lib/common"
  6. "github.com/cnlh/nps/lib/file"
  7. "github.com/cnlh/nps/server"
  8. )
  9. type LoginController struct {
  10. beego.Controller
  11. }
  12. func (self *LoginController) Index() {
  13. self.Data["web_base_url"] = beego.AppConfig.String("web_base_url")
  14. self.Data["register_allow"], _ = beego.AppConfig.Bool("allow_user_register")
  15. self.TplName = "login/index.html"
  16. }
  17. func (self *LoginController) Verify() {
  18. var auth bool
  19. if self.GetString("password") == beego.AppConfig.String("web_password") && self.GetString("username") == beego.AppConfig.String("web_username") {
  20. self.SetSession("isAdmin", true)
  21. self.DelSession("clientId")
  22. self.DelSession("username")
  23. auth = true
  24. server.Bridge.Register.Store(common.GetIpByAddr(self.Ctx.Input.IP()), time.Now().Add(time.Hour*time.Duration(2)))
  25. }
  26. b, err := beego.AppConfig.Bool("allow_user_login")
  27. if err == nil && b && !auth {
  28. file.GetDb().JsonDb.Clients.Range(func(key, value interface{}) bool {
  29. v := value.(*file.Client)
  30. if !v.Status || v.NoDisplay {
  31. return true
  32. }
  33. if v.WebUserName == "" && v.WebPassword == "" {
  34. if self.GetString("username") != "user" || v.VerifyKey != self.GetString("password") {
  35. return true
  36. } else {
  37. auth = true
  38. }
  39. }
  40. if !auth && v.WebPassword == self.GetString("password") && self.GetString("username") == v.WebUserName {
  41. auth = true
  42. }
  43. if auth {
  44. self.SetSession("isAdmin", false)
  45. self.SetSession("clientId", v.Id)
  46. self.SetSession("username", v.WebUserName)
  47. return false
  48. }
  49. return true
  50. })
  51. }
  52. if auth {
  53. self.SetSession("auth", true)
  54. self.Data["json"] = map[string]interface{}{"status": 1, "msg": "login success"}
  55. } else {
  56. self.Data["json"] = map[string]interface{}{"status": 0, "msg": "username or password incorrect"}
  57. }
  58. self.ServeJSON()
  59. }
  60. func (self *LoginController) Register() {
  61. if self.Ctx.Request.Method == "GET" {
  62. self.Data["web_base_url"] = beego.AppConfig.String("web_base_url")
  63. self.TplName = "login/register.html"
  64. } else {
  65. if b, err := beego.AppConfig.Bool("allow_user_register"); err != nil || !b {
  66. self.Data["json"] = map[string]interface{}{"status": 0, "msg": "register is not allow"}
  67. self.ServeJSON()
  68. return
  69. }
  70. if self.GetString("username") == "" || self.GetString("password") == "" || self.GetString("username") == beego.AppConfig.String("web_username") {
  71. self.Data["json"] = map[string]interface{}{"status": 0, "msg": "please check your input"}
  72. self.ServeJSON()
  73. return
  74. }
  75. t := &file.Client{
  76. Id: int(file.GetDb().JsonDb.GetClientId()),
  77. Status: true,
  78. Cnf: &file.Config{},
  79. WebUserName: self.GetString("username"),
  80. WebPassword: self.GetString("password"),
  81. Flow: &file.Flow{},
  82. }
  83. if err := file.GetDb().NewClient(t); err != nil {
  84. self.Data["json"] = map[string]interface{}{"status": 0, "msg": err.Error()}
  85. } else {
  86. self.Data["json"] = map[string]interface{}{"status": 1, "msg": "register success"}
  87. }
  88. self.ServeJSON()
  89. }
  90. }
  91. func (self *LoginController) Out() {
  92. self.SetSession("auth", false)
  93. self.Redirect(beego.AppConfig.String("web_base_url")+"/login/index", 302)
  94. }