Add an identity to the agent

This commit is contained in:
Bryce Lampe
2024-03-27 15:16:08 -07:00
parent f9b5ed8f67
commit b455d9037f

View File

@@ -4,6 +4,8 @@
package examples
import (
"crypto/rand"
"crypto/rsa"
"net"
"os"
"path/filepath"
@@ -13,18 +15,18 @@ import (
)
func TestMain(m *testing.M) {
if os.Getenv("SSH_AUTH_SOCK") == "" {
sock := sshagent()
os.Setenv("SSH_AUTH_SOCK", sock)
}
sock := sshagent()
os.Setenv("SSH_AUTH_SOCK", sock)
os.Exit(m.Run())
}
// sshagent crates an in-memory SSH agent with one identity.
func sshagent() string {
dir := os.TempDir()
sock := filepath.Join(dir, "test.sock")
// In case it already exists.
_ = os.Remove(sock)
l, err := net.Listen("unix", sock)
@@ -32,12 +34,18 @@ func sshagent() string {
panic(err)
}
a := agent.NewKeyring()
key, err := rsa.GenerateKey(rand.Reader, 2048)
if err != nil {
panic(err)
}
_ = a.Add(agent.AddedKey{PrivateKey: key})
go func() {
conn, err := l.Accept()
if err != nil {
panic(err)
}
a := agent.NewKeyring()
agent.ServeAgent(a, conn)
}()