diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-03 11:11:46 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-03 11:11:46 +0200 |
| commit | 36286212ca5a6e7de85fd05338ca70194707841f (patch) | |
| tree | b08931749c2fa424e59029f5864802795201944e /internal/ssh/ssh.go | |
| parent | 2de007f9ef8ae2724b9fbe2808ee25cbfe4ca876 (diff) | |
Add auth-key fast reconnect integration coverage
Diffstat (limited to 'internal/ssh/ssh.go')
| -rw-r--r-- | internal/ssh/ssh.go | 50 |
1 files changed, 32 insertions, 18 deletions
diff --git a/internal/ssh/ssh.go b/internal/ssh/ssh.go index 7088e89..a191fd5 100644 --- a/internal/ssh/ssh.go +++ b/internal/ssh/ssh.go @@ -48,9 +48,9 @@ func Agent() (gossh.AuthMethod, error) { return AgentWithKeyIndex(-1) } -// AgentWithKeyIndex used for SSH auth with a specific key index from the agent. +// AgentSignersWithKeyIndex returns SSH agent signers. // If keyIndex is -1, all keys are used. Otherwise, only the specified key is used. -func AgentWithKeyIndex(keyIndex int) (gossh.AuthMethod, error) { +func AgentSignersWithKeyIndex(keyIndex int) ([]gossh.Signer, error) { // Use context-aware dialing for SSH agent connection (local Unix socket). // 2-second timeout is reasonable for local socket connections. dialer := &net.Dialer{ @@ -73,28 +73,33 @@ func AgentWithKeyIndex(keyIndex int) (gossh.AuthMethod, error) { dlog.Common.Debug("Public key", i, key) } + signers, err := agentClient.Signers() + if err != nil { + return nil, fmt.Errorf("failed to load SSH agent signers: %w", err) + } + // If no specific key index requested, use all keys (backwards compatible default) if keyIndex < 0 { - return gossh.PublicKeysCallback(agentClient.Signers), nil + return signers, nil } // Use only the specified key index (0-based) - if keyIndex >= len(keys) { - return nil, fmt.Errorf("key index %d out of range (agent has %d keys)", keyIndex, len(keys)) + if keyIndex >= len(signers) { + return nil, fmt.Errorf("key index %d out of range (agent has %d signers)", keyIndex, len(signers)) } dlog.Common.Debug("Using SSH agent key at index", keyIndex) - return gossh.PublicKeysCallback(func() ([]gossh.Signer, error) { - signers, err := agentClient.Signers() - if err != nil { - return nil, err - } - if keyIndex >= len(signers) { - return nil, fmt.Errorf("key index %d out of range (agent has %d signers)", keyIndex, len(signers)) - } - // Return only the specified signer - return []gossh.Signer{signers[keyIndex]}, nil - }), nil + return []gossh.Signer{signers[keyIndex]}, nil +} + +// AgentWithKeyIndex used for SSH auth with a specific key index from the agent. +// If keyIndex is -1, all keys are used. Otherwise, only the specified key is used. +func AgentWithKeyIndex(keyIndex int) (gossh.AuthMethod, error) { + signers, err := AgentSignersWithKeyIndex(keyIndex) + if err != nil { + return nil, err + } + return gossh.PublicKeys(signers...), nil } // EnterKeyPhrase is required to read phrase protected private keys. @@ -108,8 +113,8 @@ func EnterKeyPhrase(keyFile string) []byte { return phrase } -// KeyFile returns the key as a SSH auth method. -func KeyFile(keyFile string) (gossh.AuthMethod, error) { +// PrivateKeySigner returns an SSH signer from the provided private key file. +func PrivateKeySigner(keyFile string) (gossh.Signer, error) { buffer, err := os.ReadFile(keyFile) if err != nil { return nil, err @@ -118,6 +123,15 @@ func KeyFile(keyFile string) (gossh.AuthMethod, error) { if err != nil { return nil, err } + return key, nil +} + +// KeyFile returns the key as a SSH auth method. +func KeyFile(keyFile string) (gossh.AuthMethod, error) { + key, err := PrivateKeySigner(keyFile) + if err != nil { + return nil, err + } // Key phrase support disabled as password will be printed to stdout! /* |
