alist/internal/bootstrap/data/user.go

82 lines
2.0 KiB
Go
Raw Normal View History

2022-06-27 07:51:02 +00:00
package data
2022-06-25 14:05:02 +00:00
import (
"os"
2022-08-07 05:09:59 +00:00
"github.com/alist-org/alist/v3/cmd/flags"
2022-06-25 14:05:02 +00:00
"github.com/alist-org/alist/v3/internal/db"
"github.com/alist-org/alist/v3/internal/model"
"github.com/alist-org/alist/v3/internal/op"
2022-08-30 08:13:01 +00:00
"github.com/alist-org/alist/v3/pkg/utils"
2022-06-25 14:05:02 +00:00
"github.com/alist-org/alist/v3/pkg/utils/random"
"github.com/pkg/errors"
"gorm.io/gorm"
)
func initUser() {
admin, err := op.GetAdmin()
2022-06-26 11:09:28 +00:00
adminPassword := random.String(8)
envpass := os.Getenv("ALIST_ADMIN_PASSWORD")
2022-08-07 05:09:59 +00:00
if flags.Dev {
2022-06-26 11:09:28 +00:00
adminPassword = "admin"
} else if len(envpass) > 0 {
adminPassword = envpass
2022-06-26 11:09:28 +00:00
}
2022-06-25 14:05:02 +00:00
if err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
salt := random.String(16)
2022-06-25 14:05:02 +00:00
admin = &model.User{
Username: "admin",
Salt: salt,
PwdHash: model.TwoHashPwd(adminPassword, salt),
2022-06-25 14:05:02 +00:00
Role: model.ADMIN,
BasePath: "/",
}
if err := op.CreateUser(admin); err != nil {
2022-06-25 14:05:02 +00:00
panic(err)
2022-08-07 05:09:59 +00:00
} else {
utils.Log.Infof("Successfully created the admin user and the initial password is: %s", adminPassword)
2022-06-25 14:05:02 +00:00
}
} else {
utils.Log.Fatalf("[init user] Failed to get admin user: %v", err)
2022-06-25 14:05:02 +00:00
}
}
guest, err := op.GetGuest()
2022-06-25 14:05:02 +00:00
if err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
salt := random.String(16)
2022-06-25 14:05:02 +00:00
guest = &model.User{
2022-06-29 10:03:12 +00:00
Username: "guest",
PwdHash: model.TwoHashPwd("guest", salt),
2022-06-29 10:03:12 +00:00
Role: model.GUEST,
BasePath: "/",
2022-07-27 13:53:21 +00:00
Permission: 0,
Disabled: true,
2022-06-25 14:05:02 +00:00
}
if err := db.CreateUser(guest); err != nil {
utils.Log.Fatalf("[init user] Failed to create guest user: %v", err)
2022-06-25 14:05:02 +00:00
}
} else {
utils.Log.Fatalf("[init user] Failed to get guest user: %v", err)
}
}
hashPwdForOldVersion()
}
func hashPwdForOldVersion() {
users, _, err := op.GetUsers(1, -1)
if err != nil {
utils.Log.Fatalf("[hash pwd for old version] failed get users: %v", err)
}
for i := range users {
user := users[i]
if user.PwdHash == "" {
user.SetPassword(user.Password)
user.Password = ""
if err := db.UpdateUser(&user); err != nil {
utils.Log.Fatalf("[hash pwd for old version] failed update user: %v", err)
}
2022-06-25 14:05:02 +00:00
}
}
}