users.go 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package models
  2. import (
  3. _ "github.com/jinzhu/gorm/dialects/mysql"
  4. )
  5. type User struct {
  6. Model
  7. Name string `json:"name"`
  8. Password string `json:"password"`
  9. Nickname string `json:"nickname"`
  10. Avator string `json:"avator"`
  11. RoleName string `json:"role_name" sql:"-"`
  12. RoleId string `json:"role_id" sql:"-"`
  13. Enabled uint `json:"enabled"`
  14. }
  15. func CreateUser(name string, password string, avator string, nickname string, enabled uint) uint {
  16. user := &User{
  17. Name: name,
  18. Password: password,
  19. Avator: avator,
  20. Nickname: nickname,
  21. Enabled: enabled,
  22. }
  23. DB.Create(user)
  24. return user.ID
  25. }
  26. func UpdateUser(id string, name string, password string, avator string, nickname string, enabled uint) {
  27. user := &User{
  28. Name: name,
  29. Avator: avator,
  30. Nickname: nickname,
  31. Enabled: enabled,
  32. }
  33. if password != "" {
  34. user.Password = password
  35. }
  36. DB.Model(&User{}).Where("id = ?", id).Update(user)
  37. }
  38. func FindUser(username string) User {
  39. var user User
  40. DB.Where("name = ?", username).First(&user)
  41. return user
  42. }
  43. func FindUserById(id interface{}) User {
  44. var user User
  45. DB.Select("user.*,role.name role_name,role.id role_id").Joins("join user_role on user.id=user_role.user_id").Joins("join role on user_role.role_id=role.id").Where("user.id = ?", id).First(&user)
  46. return user
  47. }
  48. func DeleteUserById(id string) {
  49. DB.Where("id = ?", id).Delete(User{})
  50. }
  51. func FindUsers() []User {
  52. var users []User
  53. DB.Select("user.*,role.name role_name").Joins("left join user_role on user.id=user_role.user_id").Joins("left join role on user_role.role_id=role.id").Order("user.id desc").Find(&users)
  54. return users
  55. }
  56. func FindUserRole(query interface{}, id interface{}) User {
  57. var user User
  58. DB.Select(query).Where("user.id = ?", id).Joins("join user_role on user.id=user_role.user_id").Joins("join role on user_role.role_id=role.id").First(&user)
  59. return user
  60. }