mirror of
https://git.rwth-aachen.de/acs/public/villas/web-backend-go/
synced 2025-03-30 00:00:12 +01:00
allow update of admin user via CLI args
This commit is contained in:
parent
140973ab27
commit
e32336490c
1 changed files with 41 additions and 23 deletions
|
@ -35,39 +35,42 @@ import (
|
||||||
func AddAdminUser(cfg *config.Config) (string, error) {
|
func AddAdminUser(cfg *config.Config) (string, error) {
|
||||||
DBpool.AutoMigrate(User{})
|
DBpool.AutoMigrate(User{})
|
||||||
|
|
||||||
|
updatedPW := false
|
||||||
|
generatedPW := false
|
||||||
|
|
||||||
|
adminName, _ := cfg.StringOr("admin.user", "admin")
|
||||||
|
adminMail, _ := cfg.StringOr("admin.mail", "admin@example.com")
|
||||||
|
adminPW, err := cfg.String("admin.pass")
|
||||||
|
if err == nil && adminPW != "" {
|
||||||
|
updatedPW = true
|
||||||
|
} else if err != nil || adminPW == "" {
|
||||||
|
adminPW = generatePassword(16)
|
||||||
|
generatedPW = true
|
||||||
|
}
|
||||||
|
|
||||||
|
adminPWEnc, err := bcrypt.GenerateFromPassword([]byte(adminPW), 10)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
// Check if admin user exists in DB
|
// Check if admin user exists in DB
|
||||||
var users []User
|
var users []User
|
||||||
DBpool.Where("Role = ?", "Admin").Find(&users)
|
err = DBpool.Where("Username = ?", adminName).Find(&users).Error
|
||||||
|
if err != nil {
|
||||||
adminPW := ""
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
if len(users) == 0 {
|
if len(users) == 0 {
|
||||||
fmt.Println("No admin user found in DB, adding default admin user.")
|
fmt.Println("No admin user found in DB, adding default admin user.")
|
||||||
|
if generatedPW {
|
||||||
adminName, err := cfg.String("admin.user")
|
|
||||||
if err != nil || adminName == "" {
|
|
||||||
adminName = "admin"
|
|
||||||
}
|
|
||||||
|
|
||||||
adminPW, err = cfg.String("admin.pass")
|
|
||||||
if err != nil || adminPW == "" {
|
|
||||||
adminPW = generatePassword(16)
|
|
||||||
fmt.Printf(" Generated admin password: %s for admin user %s\n", adminPW, adminName)
|
fmt.Printf(" Generated admin password: %s for admin user %s\n", adminPW, adminName)
|
||||||
}
|
}
|
||||||
|
|
||||||
mail, err := cfg.String("admin.mail")
|
|
||||||
if err == nil || mail == "" {
|
|
||||||
mail = "admin@example.com"
|
|
||||||
}
|
|
||||||
|
|
||||||
pwEnc, _ := bcrypt.GenerateFromPassword([]byte(adminPW), 10)
|
|
||||||
|
|
||||||
// create a copy of global test data
|
|
||||||
user := User{
|
user := User{
|
||||||
Username: adminName,
|
Username: adminName,
|
||||||
Password: string(pwEnc),
|
Password: string(adminPWEnc),
|
||||||
Role: "Admin",
|
Role: "Admin",
|
||||||
Mail: mail,
|
Mail: adminMail,
|
||||||
Active: true,
|
Active: true,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,8 +79,23 @@ func AddAdminUser(cfg *config.Config) (string, error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
} else if updatedPW {
|
||||||
|
fmt.Println("Found existing admin user in DB, updating user from CLI parameters.")
|
||||||
|
|
||||||
|
user := users[0]
|
||||||
|
|
||||||
|
user.Password = string(adminPWEnc)
|
||||||
|
user.Role = "Admin"
|
||||||
|
user.Mail = adminMail
|
||||||
|
user.Active = true
|
||||||
|
|
||||||
|
err = DBpool.Model(user).Update(&user).Error
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return adminPW, nil
|
|
||||||
|
return adminPW, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func generatePassword(Len int) string {
|
func generatePassword(Len int) string {
|
||||||
|
|
Loading…
Add table
Reference in a new issue