| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- package models
- import (
- _ "github.com/jinzhu/gorm/dialects/mysql"
- )
- type User struct {
- Model
- Name string `json:"name"`
- Password string `json:"password"`
- Nickname string `json:"nickname"`
- Avator string `json:"avator"`
- RoleName string `json:"role_name" sql:"-"`
- RoleId string `json:"role_id" sql:"-"`
- Enabled uint `json:"enabled"`
- }
- func CreateUser(name string, password string, avator string, nickname string, enabled uint) uint {
- user := &User{
- Name: name,
- Password: password,
- Avator: avator,
- Nickname: nickname,
- Enabled: enabled,
- }
- DB.Create(user)
- return user.ID
- }
- func UpdateUser(id string, name string, password string, avator string, nickname string, enabled uint) {
- user := &User{
- Name: name,
- Avator: avator,
- Nickname: nickname,
- Enabled: enabled,
- }
- if password != "" {
- user.Password = password
- }
- DB.Model(&User{}).Where("id = ?", id).Update(user)
- }
- func FindUser(username string) User {
- var user User
- DB.Where("name = ?", username).First(&user)
- return user
- }
- func FindUserById(id interface{}) User {
- var user User
- 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)
- return user
- }
- func DeleteUserById(id string) {
- DB.Where("id = ?", id).Delete(User{})
- }
- func FindUsers() []User {
- var users []User
- 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)
- return users
- }
- func FindUserRole(query interface{}, id interface{}) User {
- var user User
- 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)
- return user
- }
|