Spaces:
Running
Running
package db | |
import ( | |
"encoding/base64" | |
"github.com/alist-org/alist/v3/internal/model" | |
"github.com/alist-org/alist/v3/pkg/utils" | |
"github.com/go-webauthn/webauthn/webauthn" | |
"github.com/pkg/errors" | |
) | |
func GetUserByRole(role int) (*model.User, error) { | |
user := model.User{Role: role} | |
if err := db.Where(user).Take(&user).Error; err != nil { | |
return nil, err | |
} | |
return &user, nil | |
} | |
func GetUserByName(username string) (*model.User, error) { | |
user := model.User{Username: username} | |
if err := db.Where(user).First(&user).Error; err != nil { | |
return nil, errors.Wrapf(err, "failed find user") | |
} | |
return &user, nil | |
} | |
func GetUserBySSOID(ssoID string) (*model.User, error) { | |
user := model.User{SsoID: ssoID} | |
if err := db.Where(user).First(&user).Error; err != nil { | |
return nil, errors.Wrapf(err, "The single sign on platform is not bound to any users") | |
} | |
return &user, nil | |
} | |
func GetUserById(id uint) (*model.User, error) { | |
var u model.User | |
if err := db.First(&u, id).Error; err != nil { | |
return nil, errors.Wrapf(err, "failed get old user") | |
} | |
return &u, nil | |
} | |
func CreateUser(u *model.User) error { | |
return errors.WithStack(db.Create(u).Error) | |
} | |
func UpdateUser(u *model.User) error { | |
return errors.WithStack(db.Save(u).Error) | |
} | |
func GetUsers(pageIndex, pageSize int) (users []model.User, count int64, err error) { | |
userDB := db.Model(&model.User{}) | |
if err := userDB.Count(&count).Error; err != nil { | |
return nil, 0, errors.Wrapf(err, "failed get users count") | |
} | |
if err := userDB.Offset((pageIndex - 1) * pageSize).Limit(pageSize).Find(&users).Error; err != nil { | |
return nil, 0, errors.Wrapf(err, "failed get find users") | |
} | |
return users, count, nil | |
} | |
func DeleteUserById(id uint) error { | |
return errors.WithStack(db.Delete(&model.User{}, id).Error) | |
} | |
func UpdateAuthn(userID uint, authn string) error { | |
return db.Model(&model.User{ID: userID}).Update("authn", authn).Error | |
} | |
func RegisterAuthn(u *model.User, credential *webauthn.Credential) error { | |
if u == nil { | |
return errors.New("user is nil") | |
} | |
exists := u.WebAuthnCredentials() | |
if credential != nil { | |
exists = append(exists, *credential) | |
} | |
res, err := utils.Json.Marshal(exists) | |
if err != nil { | |
return err | |
} | |
return UpdateAuthn(u.ID, string(res)) | |
} | |
func RemoveAuthn(u *model.User, id string) error { | |
exists := u.WebAuthnCredentials() | |
for i := 0; i < len(exists); i++ { | |
idEncoded := base64.StdEncoding.EncodeToString(exists[i].ID) | |
if idEncoded == id { | |
exists[len(exists)-1], exists[i] = exists[i], exists[len(exists)-1] | |
exists = exists[:len(exists)-1] | |
break | |
} | |
} | |
res, err := utils.Json.Marshal(exists) | |
if err != nil { | |
return err | |
} | |
return UpdateAuthn(u.ID, string(res)) | |
} | |