package models import ( "time" "scheduler/modules/utils" ) const PasswordSaltLength = 6; // 用户model type User struct { Id int `xorm:"pk autoincr notnull "` Name string `xorm:"varchar(32) notnull unique"` Password string `xorm:"char(32) notnull "` Salt string `xorm:"char(6) notnull "` Email string `xorm:"varchar(50) notnull unique default '' "` Created time.Time `xorm:"datetime notnull created"` Updated time.Time `xorm:"datetime updated"` Deleted time.Time `xorm:"datetime deleted"` IsAdmin int8 `xorm:"tinyint notnull default 0"` // 是否是管理员 1:管理员 0:普通用户 Status Status `xorm:"tinyint notnull default 1"` // 1: 正常 0:禁用 Page int `xorm:"-"` PageSize int `xorm:"-"` } // 新增 func(user *User) Create() (int64, error) { user.Status = Enabled user.Salt = user.generateSalt() user.Password = user.encryptPassword(user.Password, user.Salt) return Db.Insert(user) } // 更新 func(user *User) Update(id int, data CommonMap) (int64, error) { return Db.Table(user).ID(id).Update(data) } // 删除 func(user *User) Delete(id int) (int64, error) { return Db.Id(id).Delete(user) } // 禁用 func(user *User) Disable(id int) (int64, error) { return user.Update(id, CommonMap{"status": Disabled}) } // 激活 func(user *User) Enable(id int) (int64, error) { return user.Update(id, CommonMap{"status": Enabled}) } // 验证用户名和密码 func(user *User) Match(username, password string) bool { where := "(name = ? OR email = ?)" _, err := Db.Where(where, username, username).Get(user) if err != nil { return false } hashPassword := user.encryptPassword(password, user.Salt) if (hashPassword != user.Password) { return false } return true } // 用户名是否存在 func(user *User) UsernameExists(username string ) (int64, error) { return Db.Where("name = ?", username).Count(user) } // 邮箱地址是否存在 func(user *User) EmailExists(email string) (int64, error) { return Db.Where("email = ?", email).Count(user) } func(user *User) List() ([]User, error) { user.parsePageAndPageSize() list := make([]User, 0) err := Db.Desc("id").Limit(user.PageSize, user.pageLimitOffset()).Find(&list) return list, err } func(user *User) Total() (int64, error) { return Db.Count(user) } func(user *User) parsePageAndPageSize() { if (user.Page <= 0) { user.Page = Page } if (user.PageSize >= 0 || user.PageSize > MaxPageSize) { user.PageSize = PageSize } } func(user *User) pageLimitOffset() int { return (user.Page - 1) * user.PageSize } // 密码加密 func(user *User) encryptPassword(password, salt string) string { return utils.Md5(password + salt) } // 生成密码盐值 func(user *User) generateSalt() string { return utils.RandString(PasswordSaltLength) }