1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- package dbModel
- import (
- "github.com/jinzhu/gorm"
- "github.com/pkg/errors"
- uuid "github.com/satori/go.uuid"
- "main/controller/servers"
- "main/init/qmsql"
- "main/model/modelInterface"
- "main/tools"
- )
- type User struct {
- gorm.Model `json:"-"`
- UUID uuid.UUID `json:"uuid"`
- Username string `json:"-"`
- Password string `json:"-"`
- NickName string `json:"nickName" gorm:"default:'QMPlusUser'"`
- HeaderImg string `json:"headerImg" gorm:"default:'http://www.henrongyi.top/avatar/lufu.jpg'"`
- Authority Authority `json:"authority" form:"ForeignKey:authority_id;AssociationForeignKey:authority_id"`
- AuthorityId float64 `json:"-" gorm:"default:888"`
-
-
- }
- func (u *User) Regist() (err error, userInter *User) {
- var user User
-
- findErr := qmsql.DEFAULTDB.Where("username = ?", u.Username).First(&user).Error
-
- if findErr == nil {
- return errors.New("用户名已注册"), nil
- } else {
-
- u.Password = tools.MD5V(u.Password)
- u.UUID = uuid.NewV4()
- err = qmsql.DEFAULTDB.Create(u).Error
- }
- return err, u
- }
- func (u *User) ChangePassword(newPassword string) (err error, userInter *User) {
- var user User
-
- u.Password = tools.MD5V(u.Password)
- err = qmsql.DEFAULTDB.Where("username = ? AND password = ?", u.Username, u.Password).First(&user).Update("password", tools.MD5V(newPassword)).Error
- return err, u
- }
- func (u *User) UpdataUser() (err error, userInter *User) {
- err = qmsql.DEFAULTDB.Create(u).Error
- return err, u
- }
- func (u *User) Login() (err error, userInter *User) {
- var user User
- u.Password = tools.MD5V(u.Password)
- err = qmsql.DEFAULTDB.Where("username = ? AND password = ?", u.Username, u.Password).First(&user).Error
- err = qmsql.DEFAULTDB.Where("authority_id = ?", user.AuthorityId).First(&user.Authority).Error
- return err, &user
- }
- func (u *User) UploadHeaderImg(username string, filePath string) (err error, userInter *User) {
- var user User
- err = qmsql.DEFAULTDB.Where("username = ?", username).First(&user).Update("header_img", filePath).First(&user).Error
- return err, &user
- }
- func (u *User) GetInfoList(info modelInterface.PageInfo) (err error, list interface{}, total int) {
-
- err, db, total := servers.PagingServer(u, info)
- if err != nil {
- return
- } else {
- var userList []User
- err = db.Find(&userList).Error
- return err, userList, total
- }
- }
|