2016-07-01 05:15:47 +08:00
|
|
|
package commands
|
|
|
|
|
|
|
|
|
|
import (
|
2020-07-02 22:29:10 +08:00
|
|
|
"bufio"
|
2021-06-21 13:51:33 +08:00
|
|
|
"context"
|
2016-07-01 05:15:47 +08:00
|
|
|
"fmt"
|
2020-07-02 22:29:10 +08:00
|
|
|
"os"
|
2016-07-01 05:15:47 +08:00
|
|
|
|
|
|
|
|
"github.com/fatih/color"
|
2022-12-21 21:24:33 +08:00
|
|
|
|
2016-07-01 05:15:47 +08:00
|
|
|
"github.com/grafana/grafana/pkg/cmd/grafana-cli/logger"
|
2019-05-27 16:47:21 +08:00
|
|
|
"github.com/grafana/grafana/pkg/cmd/grafana-cli/utils"
|
2023-03-17 23:36:39 +08:00
|
|
|
"github.com/grafana/grafana/pkg/server"
|
2022-08-02 22:58:05 +08:00
|
|
|
"github.com/grafana/grafana/pkg/services/user"
|
2016-07-01 05:15:47 +08:00
|
|
|
"github.com/grafana/grafana/pkg/util"
|
|
|
|
|
)
|
|
|
|
|
|
2022-12-21 21:24:33 +08:00
|
|
|
const DefaultAdminUserId = 1
|
2016-08-25 02:27:41 +08:00
|
|
|
|
2023-03-17 23:36:39 +08:00
|
|
|
func resetPasswordCommand(c utils.CommandLine, runner server.Runner) error {
|
2020-07-02 22:29:10 +08:00
|
|
|
newPassword := ""
|
2022-12-21 21:24:33 +08:00
|
|
|
adminId := int64(c.Int("user-id"))
|
2020-07-02 22:29:10 +08:00
|
|
|
|
|
|
|
|
if c.Bool("password-from-stdin") {
|
|
|
|
|
logger.Infof("New Password: ")
|
|
|
|
|
|
|
|
|
|
scanner := bufio.NewScanner(os.Stdin)
|
|
|
|
|
if ok := scanner.Scan(); !ok {
|
|
|
|
|
if err := scanner.Err(); err != nil {
|
|
|
|
|
return fmt.Errorf("can't read password from stdin: %w", err)
|
|
|
|
|
}
|
|
|
|
|
return fmt.Errorf("can't read password from stdin")
|
|
|
|
|
}
|
|
|
|
|
newPassword = scanner.Text()
|
|
|
|
|
} else {
|
|
|
|
|
newPassword = c.Args().First()
|
|
|
|
|
}
|
2016-07-01 05:15:47 +08:00
|
|
|
|
2022-12-21 21:24:33 +08:00
|
|
|
err := resetPassword(adminId, newPassword, runner.UserService)
|
|
|
|
|
if err == nil {
|
|
|
|
|
logger.Infof("\n")
|
|
|
|
|
logger.Infof("Admin password changed successfully %s", color.GreenString("✔"))
|
|
|
|
|
}
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func resetPassword(adminId int64, newPassword string, userSvc user.Service) error {
|
2023-01-31 18:04:55 +08:00
|
|
|
password := user.Password(newPassword)
|
2016-12-09 22:25:02 +08:00
|
|
|
if password.IsWeak() {
|
2020-02-26 19:27:31 +08:00
|
|
|
return fmt.Errorf("new password is too short")
|
2016-07-01 05:15:47 +08:00
|
|
|
}
|
|
|
|
|
|
2022-12-21 21:24:33 +08:00
|
|
|
userQuery := user.GetUserByIDQuery{ID: adminId}
|
|
|
|
|
usr, err := userSvc.GetByID(context.Background(), &userQuery)
|
2022-08-02 22:58:05 +08:00
|
|
|
if err != nil {
|
2020-02-26 19:27:31 +08:00
|
|
|
return fmt.Errorf("could not read user from database. Error: %v", err)
|
2016-07-01 05:15:47 +08:00
|
|
|
}
|
2022-12-21 21:24:33 +08:00
|
|
|
if !usr.IsAdmin {
|
|
|
|
|
return ErrMustBeAdmin
|
|
|
|
|
}
|
2016-07-01 05:15:47 +08:00
|
|
|
|
2022-08-02 22:58:05 +08:00
|
|
|
passwordHashed, err := util.EncodePassword(newPassword, usr.Salt)
|
2019-10-23 16:40:12 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2016-07-01 05:15:47 +08:00
|
|
|
|
2022-08-04 21:05:05 +08:00
|
|
|
cmd := user.ChangeUserPasswordCommand{
|
2022-12-21 21:24:33 +08:00
|
|
|
UserID: adminId,
|
2016-07-01 05:15:47 +08:00
|
|
|
NewPassword: passwordHashed,
|
|
|
|
|
}
|
|
|
|
|
|
2022-12-21 21:24:33 +08:00
|
|
|
if err := userSvc.ChangePassword(context.Background(), &cmd); err != nil {
|
2022-06-07 04:30:31 +08:00
|
|
|
return fmt.Errorf("failed to update user password: %w", err)
|
2016-07-01 05:15:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2022-12-21 21:24:33 +08:00
|
|
|
|
|
|
|
|
var ErrMustBeAdmin = fmt.Errorf("reset-admin-password can only be used to reset an admin user account")
|