Skip to content

Commit

Permalink
issue-98: Fixed determination of whether root user exists or not
Browse files Browse the repository at this point in the history
  • Loading branch information
shunki-fujita committed Jun 19, 2024
1 parent 3580f25 commit 64a1fd3
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 3 deletions.
2 changes: 1 addition & 1 deletion cmd/moco-agent/cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -259,7 +259,7 @@ func initializeMySQLForMOCO(ctx context.Context, socketPath string, logger logr.
if err == nil {
break
}
if server.IsAccessDenied(err) {
if server.UserNotExists(err) {
// There is no passwordless 'root'@'localhost' account.
// It means the initialization has been completed.
return nil
Expand Down
11 changes: 9 additions & 2 deletions server/connect.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"errors"
"fmt"
"net"
"slices"
"time"

mocoagent "github.com/cybozu-go/moco-agent"
Expand Down Expand Up @@ -53,9 +54,15 @@ func GetMySQLConnLocalSocket(user, password, socket string) (*sqlx.DB, error) {
return db, nil
}

func IsAccessDenied(err error) bool {
func UserNotExists(err error) bool {
// For security reason, error messages are randomly output when a user does not exist.
// https://github.com/mysql/mysql-server/commit/b40001faf6229dca668c9d03ba75c451f999c9f5
// This function assumes the user does not exist when the following message is output:
// ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
// ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded
codes := []int{1045, 1524}
var merr *mysql.MySQLError
if errors.As(err, &merr) && merr.Number == 1045 {
if errors.As(err, &merr) && slices.Contains(codes, merr.Number) {

Check failure on line 65 in server/connect.go

View workflow job for this annotation

GitHub Actions / Validation

S (type []int) does not satisfy ~[]E (compile)

Check failure on line 65 in server/connect.go

View workflow job for this annotation

GitHub Actions / Validation

S (type []int) does not satisfy ~[]E (compile)

Check failure on line 65 in server/connect.go

View workflow job for this annotation

GitHub Actions / Small Tests (8.0.28)

S (type []int) does not satisfy ~[]E

Check failure on line 65 in server/connect.go

View workflow job for this annotation

GitHub Actions / Small Tests (8.0.36)

S (type []int) does not satisfy ~[]E

Check failure on line 65 in server/connect.go

View workflow job for this annotation

GitHub Actions / Small Tests (8.0.37)

S (type []int) does not satisfy ~[]E

Check failure on line 65 in server/connect.go

View workflow job for this annotation

GitHub Actions / Small Tests (8.4.0)

S (type []int) does not satisfy ~[]E
return true
}

Expand Down

0 comments on commit 64a1fd3

Please sign in to comment.