manager.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "html/template"
  5. "strings"
  6. "regexp"
  7. "github.com/lifei6671/godoc/conf"
  8. "github.com/astaxie/beego/logs"
  9. "github.com/lifei6671/godoc/utils"
  10. "github.com/lifei6671/godoc/models"
  11. )
  12. type ManagerController struct {
  13. BaseController
  14. }
  15. func (p *ManagerController) Index() {
  16. p.TplName = "manager/index.tpl"
  17. }
  18. // 用户列表.
  19. func (c *ManagerController) Users() {
  20. c.Prepare()
  21. c.TplName = "manager/users.tpl"
  22. if c.Member.Role != 0 {
  23. c.Abort("403")
  24. }
  25. pageIndex,_ := c.GetInt("page",0)
  26. members,totalCount,err := models.NewMember().FindToPager(pageIndex,15)
  27. if err != nil {
  28. c.Data["ErrorMessage"] = err.Error()
  29. return
  30. }
  31. html := utils.GetPagerHtml(c.Ctx.Request.RequestURI,pageIndex,10,totalCount)
  32. c.Data["PageHtml"] = html
  33. b,err := json.Marshal(members)
  34. if err != nil {
  35. c.Data["Result"] = template.JS("[]")
  36. }else{
  37. c.Data["Result"] = template.JS(string(b))
  38. }
  39. }
  40. // 添加用户
  41. func (c *ManagerController) CreateMember() {
  42. c.Prepare()
  43. if c.Member.Role != 0{
  44. c.Abort("403")
  45. }
  46. account := strings.TrimSpace(c.GetString("account"))
  47. password1 := strings.TrimSpace(c.GetString("password1"))
  48. password2 := strings.TrimSpace(c.GetString("password2"))
  49. email := strings.TrimSpace(c.GetString("email"))
  50. phone := strings.TrimSpace(c.GetString("phone"))
  51. role,_ := c.GetInt("role",1)
  52. status,_ := c.GetInt("status",0)
  53. if ok,err := regexp.MatchString(conf.RegexpAccount,account); account == "" || !ok || err != nil {
  54. c.JsonResult(6001,"账号只能由英文字母数字组成,且在3-50个字符")
  55. }
  56. if l := strings.Count(password1,"") ; password1 == "" || l > 50 || l < 6{
  57. c.JsonResult(6002,"密码必须在6-50个字符之间")
  58. }
  59. if password1 != password2 {
  60. c.JsonResult(6003,"确认密码不正确")
  61. }
  62. if ok,err := regexp.MatchString(conf.RegexpEmail,email); !ok || err != nil || email == "" {
  63. c.JsonResult(6004,"邮箱不能为空")
  64. }
  65. if role != 0 && role != 1 {
  66. role = 1
  67. }
  68. if status != 0 && status != 1 {
  69. status = 0
  70. }
  71. member := models.NewMember()
  72. if err := member.FindByAccount(account); err != nil {
  73. c.JsonResult(6005,"账号已存在")
  74. }
  75. member.Account = account
  76. member.Password = password1
  77. member.Role = role
  78. member.Avatar = conf.GetDefaultAvatar()
  79. member.CreateAt = c.Member.MemberId
  80. member.Email = email
  81. if phone != "" {
  82. member.Phone = phone
  83. }
  84. if err := member.Add(); err != nil {
  85. c.JsonResult(6006,err.Error())
  86. }
  87. c.JsonResult(0,"ok",member)
  88. }
  89. //更新用户状态.
  90. func (c *ManagerController) UpdateMemberStatus() {
  91. c.Prepare()
  92. if c.Member.Role != 0 {
  93. c.Abort("403")
  94. }
  95. member_id,_ := c.GetInt("member_id",0)
  96. status ,_ := c.GetInt("status",0)
  97. if member_id <= 0 {
  98. c.JsonResult(6001,"参数错误")
  99. }
  100. if status != 0 && status != 1 {
  101. status = 0
  102. }
  103. member := models.NewMember()
  104. if err := member.Find(member_id); err != nil {
  105. c.JsonResult(6002,"用户不存在")
  106. }
  107. member.Status = status
  108. if err := member.Update();err != nil {
  109. logs.Error("",err)
  110. c.JsonResult(6003,"用户状态设置失败")
  111. }
  112. c.JsonResult(0,"ok",member)
  113. }
  114. func (c *ManagerController) Books() {
  115. c.Prepare()
  116. c.TplName = "manager/books.tpl"
  117. }
  118. func (c *ManagerController) DeleteBook() {
  119. c.Prepare()
  120. if c.Member.Role != 0 {
  121. c.Abort("403")
  122. }
  123. }
  124. func (c *ManagerController) Comments() {
  125. c.Prepare()
  126. if c.Member.Role != 0 {
  127. c.Abort("403")
  128. }
  129. }
  130. func (c *ManagerController) DeleteComment() {
  131. c.Prepare()
  132. if c.Member.Role != 0 {
  133. c.Abort("403")
  134. }
  135. }