grafana/pkg/cmd/grafana-cli/commands/reset_password_command.go

69 lines
1.7 KiB
Go
Raw Normal View History

2016-06-30 16:15:47 -05:00
package commands
import (
"bufio"
"context"
2016-06-30 16:15:47 -05:00
"fmt"
"os"
2016-06-30 16:15:47 -05:00
"github.com/fatih/color"
"github.com/grafana/grafana/pkg/bus"
"github.com/grafana/grafana/pkg/cmd/grafana-cli/logger"
"github.com/grafana/grafana/pkg/cmd/grafana-cli/utils"
2016-06-30 16:15:47 -05:00
"github.com/grafana/grafana/pkg/models"
"github.com/grafana/grafana/pkg/services/sqlstore"
2016-06-30 16:15:47 -05:00
"github.com/grafana/grafana/pkg/util"
"github.com/grafana/grafana/pkg/util/errutil"
2016-06-30 16:15:47 -05:00
)
2016-08-24 13:27:41 -05:00
const AdminUserId = 1
func resetPasswordCommand(c utils.CommandLine, sqlStore *sqlstore.SQLStore) error {
newPassword := ""
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-06-30 16:15:47 -05:00
password := models.Password(newPassword)
if password.IsWeak() {
return fmt.Errorf("new password is too short")
2016-06-30 16:15:47 -05:00
}
2016-08-24 13:27:41 -05:00
userQuery := models.GetUserByIdQuery{Id: AdminUserId}
2016-06-30 16:15:47 -05:00
if err := bus.Dispatch(context.Background(), &userQuery); err != nil {
return fmt.Errorf("could not read user from database. Error: %v", err)
2016-06-30 16:15:47 -05:00
}
passwordHashed, err := util.EncodePassword(newPassword, userQuery.Result.Salt)
if err != nil {
return err
}
2016-06-30 16:15:47 -05:00
cmd := models.ChangeUserPasswordCommand{
2016-08-24 13:27:41 -05:00
UserId: AdminUserId,
2016-06-30 16:15:47 -05:00
NewPassword: passwordHashed,
}
if err := bus.Dispatch(context.Background(), &cmd); err != nil {
return errutil.Wrapf(err, "failed to update user password")
2016-06-30 16:15:47 -05:00
}
logger.Infof("\n")
2016-06-30 16:15:47 -05:00
logger.Infof("Admin password changed successfully %s", color.GreenString("✔"))
return nil
}