func (s *Account) UpdatePassword(ctx context.Context, req *account.UpdatePasswordRequest, rsp *account.UpdatePasswordResponse) error { usr, err := db.Read(req.UserId) if err != nil { return errors.InternalServerError("go.micro.srv.user.updatepassword", err.Error()) } salt, hashed, err := db.SaltAndPassword(usr.Username, usr.Email) if err != nil { return errors.InternalServerError("go.micro.srv.user.updatepassword", err.Error()) } hh, err := base64.StdEncoding.DecodeString(hashed) if err != nil { return errors.InternalServerError("go.micro.srv.user.updatepassword", err.Error()) } if err := bcrypt.CompareHashAndPassword(hh, []byte(x+salt+req.OldPassword)); err != nil { return errors.Unauthorized("go.micro.srv.user.updatepassword", err.Error()) } salt = random(16) h, err := bcrypt.GenerateFromPassword([]byte(x+salt+req.NewPassword), 10) if err != nil { return errors.InternalServerError("go.micro.srv.user.updatepassword", err.Error()) } pp := base64.StdEncoding.EncodeToString(h) if err := db.UpdatePassword(req.UserId, salt, pp); err != nil { return errors.InternalServerError("go.micro.srv.user.updatepassword", err.Error()) } return nil }
func (s *Account) Read(ctx context.Context, req *account.ReadRequest, rsp *account.ReadResponse) error { user, err := db.Read(req.Id) if err != nil { return err } rsp.User = user return nil }