From 6eece930c1f163fcf7b2ed956cd5c2dab09eb8c6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Attila=20Ol=C3=A1h?= Date: Wed, 3 Jul 2024 14:38:01 +0200 Subject: [PATCH] GitHub: don't fail if a user has no SSH keys. (#13) --- pkg/github/sshkeys.go | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/pkg/github/sshkeys.go b/pkg/github/sshkeys.go index f7baf25..6a39e06 100644 --- a/pkg/github/sshkeys.go +++ b/pkg/github/sshkeys.go @@ -23,6 +23,11 @@ func ResolveSSHKeys(ctx context.Context, usernames []string) (map[string][]strin return nil, fmt.Errorf("failed to fetch SSH keys for GitHub user %q: %w", username, err) } + if len(keys) == 0 { + zerolog.Ctx(ctx).Warn().Str("username", username).Dur("took", time.Since(t)).Msg("No keys found") + continue + } + m[username] = keys zerolog.Ctx(ctx).Info().Str("username", username).Dur("took", time.Since(t)).Msg("Resolved keys") @@ -47,7 +52,7 @@ func fetchKeys(username string) ([]string, error) { } var keys []string - for _, line := range strings.Split(strings.TrimSpace(string(contents)), "\n") { + for _, line := range strings.FieldsFunc(strings.TrimSpace(string(contents)), func(r rune) bool { return r == '\n' }) { keys = append(keys, strings.TrimSpace(line)) }