Add admin user, and an option to add a user admin on startup
This commit is contained in:
@@ -4,7 +4,6 @@ import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"net/http"
|
||||
"slices"
|
||||
"strings"
|
||||
|
||||
"git.artlef.fr/bibliomane/internal/appcontext"
|
||||
@@ -21,13 +20,19 @@ func CreateUser(ac appcontext.AppContext, username string, password string) erro
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return CreateUserWithHashedPassword(ac, username, string(hashedPassword))
|
||||
|
||||
user := model.User{
|
||||
Name: username,
|
||||
Password: string(hashedPassword),
|
||||
Admin: false,
|
||||
}
|
||||
return CreateUserWithHashedPassword(ac, &user)
|
||||
}
|
||||
|
||||
// only call this method with hashed password
|
||||
func CreateUserWithHashedPassword(ac appcontext.AppContext, username string, hashedPassword string) error {
|
||||
func CreateUserWithHashedPassword(ac appcontext.AppContext, userToCreate *model.User) error {
|
||||
var existingUser model.User
|
||||
err := ac.Db.Where("name = ?", username).First(&existingUser).Error
|
||||
err := ac.Db.Where("name = ?", userToCreate.Name).First(&existingUser).Error
|
||||
if err != nil && !errors.Is(err, gorm.ErrRecordNotFound) {
|
||||
return err
|
||||
}
|
||||
@@ -37,41 +42,72 @@ func CreateUserWithHashedPassword(ac appcontext.AppContext, username string, has
|
||||
Err: errors.New(i18nresource.GetTranslatedMessage(&ac, "UserAlreadyExists")),
|
||||
}
|
||||
}
|
||||
user := model.User{
|
||||
Name: username,
|
||||
Password: hashedPassword,
|
||||
}
|
||||
return ac.Db.Model(&model.User{}).Save(&user).Error
|
||||
return ac.Db.Model(&model.User{}).Save(&userToCreate).Error
|
||||
}
|
||||
|
||||
func CreateDefaultUsers(ac appcontext.AppContext) error {
|
||||
usersPasswordMap, err := createNormalUsersMap(ac)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
err = createDefaultUsersFromMap(ac, usersPasswordMap, false)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
adminUsersPasswordMap, err := createDefaultUsersMap(ac, ac.Config.AddAdminUser)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return createDefaultUsersFromMap(ac, adminUsersPasswordMap, true)
|
||||
}
|
||||
|
||||
func createNormalUsersMap(ac appcontext.AppContext) (map[string]string, error) {
|
||||
usersPasswordMap, err := createDefaultUsersMap(ac, ac.Config.AddUser)
|
||||
if err != nil {
|
||||
return usersPasswordMap, err
|
||||
}
|
||||
_, ok := usersPasswordMap[ac.Config.DemoUsername]
|
||||
if !ok {
|
||||
usersPasswordMap[ac.Config.DemoUsername] = ""
|
||||
}
|
||||
return usersPasswordMap, nil
|
||||
}
|
||||
|
||||
func createDefaultUsersMap(ac appcontext.AppContext, adduser []string) (map[string]string, error) {
|
||||
usersPasswordMap := make(map[string]string)
|
||||
var usernames []string
|
||||
for _, s := range ac.Config.AddUser {
|
||||
for _, s := range adduser {
|
||||
splittedString := strings.Split(s, ":")
|
||||
if len(splittedString) < 2 {
|
||||
return fmt.Errorf(i18nresource.GetTranslatedMessage(&ac, "ErrorWhenCreatingUserFromStr"), s)
|
||||
return usersPasswordMap,
|
||||
fmt.Errorf(i18nresource.GetTranslatedMessage(&ac, "ErrorWhenCreatingUserFromStr"), s)
|
||||
}
|
||||
usernames = append(usernames, splittedString[0])
|
||||
usersPasswordMap[splittedString[0]] = splittedString[1]
|
||||
}
|
||||
if !slices.Contains(usernames, ac.Config.DemoUsername) {
|
||||
usernames = append(usernames, ac.Config.DemoUsername)
|
||||
usersPasswordMap[ac.Config.DemoUsername] = ""
|
||||
return usersPasswordMap, nil
|
||||
}
|
||||
|
||||
}
|
||||
func createDefaultUsersFromMap(
|
||||
ac appcontext.AppContext,
|
||||
usersPasswordMap map[string]string,
|
||||
isAdmin bool) error {
|
||||
|
||||
var existingUsers []model.User
|
||||
err := ac.Db.Where("name IN ?", usernames).Find(&existingUsers).Error
|
||||
err := ac.Db.Where("name IN ?", mapToArrayKey(usersPasswordMap)).Find(&existingUsers).Error
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
for _, username := range usernames {
|
||||
for username, password := range usersPasswordMap {
|
||||
if isInExistingUsers(username, existingUsers) {
|
||||
continue
|
||||
}
|
||||
err = CreateUserWithHashedPassword(ac, username, usersPasswordMap[username])
|
||||
|
||||
user := model.User{
|
||||
Name: username,
|
||||
Password: password,
|
||||
Admin: isAdmin,
|
||||
}
|
||||
err = CreateUserWithHashedPassword(ac, &user)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@@ -87,3 +123,11 @@ func isInExistingUsers(username string, existingUsers []model.User) bool {
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
func mapToArrayKey(m map[string]string) []string {
|
||||
var a []string
|
||||
for k := range m {
|
||||
a = append(a, k)
|
||||
}
|
||||
return a
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user