代码拉取完成,页面将自动刷新
/*
Nging is a toolbox for webmasters
Copyright (C) 2018-present Wenhui Shen <swh@admpub.com>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
package model
import (
"encoding/gob"
"errors"
"github.com/webx-top/com"
"github.com/webx-top/db"
"github.com/webx-top/echo"
"github.com/admpub/nging/application/dbschema"
"github.com/admpub/nging/application/library/common"
"github.com/admpub/nging/application/model/base"
)
func init() {
gob.Register(&dbschema.NgingUser{})
}
func NewUser(ctx echo.Context) *User {
m := &User{
NgingUser: &dbschema.NgingUser{},
base: base.New(ctx),
}
m.NgingUser.SetContext(ctx)
return m
}
type User struct {
*dbschema.NgingUser
base *base.Base
}
func (u *User) Exists(username string) (bool, error) {
n, e := u.Param(nil, db.Cond{`username`: username}).Count()
return n > 0, e
}
func (u *User) Exists2(username string, excludeUID uint) (bool, error) {
n, e := u.Param(nil, db.And(
db.Cond{`username`: username},
db.Cond{`id`: db.NotEq(excludeUID)},
)).Count()
return n > 0, e
}
func (u *User) CheckPasswd(username string, password string) (exists bool, err error) {
exists = true
err = u.Get(nil, `username`, username)
if err != nil {
if err == db.ErrNoMoreRows {
exists = false
}
return
}
if u.NgingUser.Disabled == `Y` {
err = errors.New(u.base.T(`该用户已被禁用`))
return
}
if u.NgingUser.Password != com.MakePassword(password, u.NgingUser.Salt) {
err = errors.New(u.base.T(`密码不正确`))
}
return
}
func (u *User) check(editMode bool) (err error) {
ctx := u.base.Context
if len(u.Username) == 0 {
return ctx.E(`用户名不能为空`)
}
if len(u.Email) == 0 {
return ctx.E(`Email不能为空`)
}
if !com.IsUsername(u.Username) {
return errors.New(ctx.T(`用户名不能包含特殊字符(只能由字母、数字、下划线和汉字组成)`))
}
if !ctx.Validate(`email`, u.Email, `email`).Ok() {
return ctx.E(`Email地址"%s"格式不正确`, u.Email)
}
if len(u.Mobile) > 0 && !ctx.Validate(`mobile`, u.Mobile, `mobile`).Ok() {
return ctx.E(`手机号"%s"格式不正确`, u.Mobile)
}
if !editMode || ctx.Form(`modifyPwd`) == `1` {
if len(u.Password) < 8 {
return ctx.E(`密码不能少于8个字符`)
}
}
if len(u.Disabled) == 0 {
u.Disabled = `N`
}
if len(u.Online) == 0 {
u.Online = `N`
}
var exists bool
if editMode {
exists, err = u.Exists2(u.Username, u.Id)
} else {
exists, err = u.Exists(u.Username)
}
if err != nil {
return
}
if exists {
err = ctx.E(`用户名已经存在`)
}
return
}
func (u *User) Add() (err error) {
err = u.check(false)
if err != nil {
return
}
u.Salt = com.Salt()
u.Password = com.MakePassword(u.Password, u.Salt)
_, err = u.NgingUser.Add()
return
}
func (u *User) UpdateField(uid uint, set map[string]interface{}) (err error) {
err = u.check(true)
if err != nil {
return
}
ctx := u.base.Context
if ctx.Form(`modifyPwd`) == `1` {
u.Password = com.MakePassword(u.Password, u.Salt)
set[`password`] = u.Password
}
err = u.SetFields(nil, set, `id`, uid)
return
}
func (u *User) NeedCheckU2F(uid uint) bool {
u2f := &dbschema.NgingUserU2f{}
u2f.SetContext(u.base.Context)
n, _ := u2f.Count(nil, `uid`, uid)
return n > 0
}
func (u *User) GetUserAllU2F(uid uint) ([]*dbschema.NgingUserU2f, error) {
u2f := &dbschema.NgingUserU2f{}
u2f.SetContext(u.base.Context)
all := []*dbschema.NgingUserU2f{}
_, err := u2f.ListByOffset(&all, nil, 0, -1, `uid`, uid)
return all, err
}
func (u *User) U2F(uid uint, typ string) (u2f *dbschema.NgingUserU2f, err error) {
u2f = &dbschema.NgingUserU2f{}
u2f.SetContext(u.base.Context)
err = u2f.Get(nil, db.And(db.Cond{`uid`: uid}, db.Cond{`type`: typ}))
return
}
func (u *User) Register(user, pass, email, roleIds string) error {
if len(user) == 0 {
return u.base.E(`用户名不能为空`)
}
if len(email) == 0 {
return u.base.E(`Email不能为空`)
}
if len(pass) < 8 {
return u.base.E(`密码不能少于8个字符`)
}
if !com.IsUsername(user) {
return u.base.E(`用户名不能包含特殊字符(只能由字母、数字、下划线和汉字组成)`)
}
if !u.base.Validate(`email`, email, `email`).Ok() {
return u.base.E(`Email地址格式不正确`)
}
exists, err := u.Exists(user)
if err != nil {
return err
}
if exists {
return u.base.E(`用户名已经存在`)
}
userSchema := &dbschema.NgingUser{}
userSchema.SetContext(u.base.Context)
userSchema.Username = user
userSchema.Email = email
userSchema.Salt = com.Salt()
userSchema.Password = com.MakePassword(pass, userSchema.Salt)
userSchema.Disabled = `N`
userSchema.RoleIds = roleIds
_, err = userSchema.EventOFF().Add()
u.NgingUser = userSchema
return err
}
func (u *User) SetSession(users ...*dbschema.NgingUser) {
userCopy := u.ClearPasswordData(users...)
u.base.Session().Set(`user`, &userCopy)
}
func (u *User) ClearPasswordData(users ...*dbschema.NgingUser) dbschema.NgingUser {
var user dbschema.NgingUser
if len(users) > 0 {
user = *(users[0])
} else {
user = *(u.NgingUser)
}
user.Password = ``
user.Salt = ``
user.SafePwd = ``
return user
}
func (u *User) UnsetSession() {
u.base.Session().Delete(`user`)
}
func (u *User) VerifySession(users ...*dbschema.NgingUser) error {
var user *dbschema.NgingUser
if len(users) > 0 {
user = users[0]
} else {
user, _ = u.base.Session().Get(`user`).(*dbschema.NgingUser)
}
if user == nil {
return common.ErrUserNotLoggedIn
}
err := u.Get(nil, db.Cond{`id`: user.Id})
if err != nil {
if err != db.ErrNoMoreRows {
return err
}
u.UnsetSession()
return common.ErrUserNotFound
}
if u.NgingUser.Updated != user.Updated {
u.SetSession()
u.base.Set(`user`, user)
}
return nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。