1 Star 0 Fork 0

h79 / goutils

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
key.go 2.28 KB
一键复制 编辑 原始数据 按行查看 历史
huqiuyun 提交于 2023-04-05 16:09 . scp
package ssh
import (
"golang.org/x/crypto/ssh"
"golang.org/x/crypto/ssh/agent"
"io"
"net"
"os"
)
func WithKey(username string, path string, keyCallBack ssh.HostKeyCallback) (ssh.ClientConfig, error) {
signer, err := readKey(path)
if err != nil {
return ssh.ClientConfig{}, err
}
return AuthKey(username, []ssh.AuthMethod{ssh.PublicKeys(signer)}, keyCallBack)
}
func WithPassphrase(path string, passpharase []byte, username string, keyCallBack ssh.HostKeyCallback) (ssh.ClientConfig, error) {
signer, err := readKeyWithPassphrase(path, passpharase)
if err != nil {
return ssh.ClientConfig{}, err
}
return AuthKey(username, []ssh.AuthMethod{ssh.PublicKeys(signer)}, keyCallBack)
}
func WithAgent(username string, keyCallBack ssh.HostKeyCallback) (ssh.ClientConfig, error) {
socket := os.Getenv("SSH_AUTH_SOCK")
conn, err := net.Dial("unix", socket)
if err != nil {
return ssh.ClientConfig{}, err
}
client := agent.NewClient(conn)
return AuthKey(username, []ssh.AuthMethod{ssh.PublicKeysCallback(client.Signers)}, keyCallBack)
}
func WithPassword(username string, password string, keyCallBack ssh.HostKeyCallback) (ssh.ClientConfig, error) {
return AuthKey(username, []ssh.AuthMethod{ssh.Password(password)}, keyCallBack)
}
func AuthKey(username string, auths []ssh.AuthMethod, keyCallBack ssh.HostKeyCallback) (ssh.ClientConfig, error) {
return ssh.ClientConfig{
User: username,
Auth: auths,
HostKeyCallback: keyCallBack,
}, nil
}
func PublicKey(file string) ssh.AuthMethod {
signer, err := readKey(file)
if err != nil {
return nil
}
return ssh.PublicKeys(signer)
}
func PublicKeys(filenames []string) []ssh.AuthMethod {
var methods []ssh.AuthMethod
for _, filename := range filenames {
signer := PublicKey(filename)
if signer != nil {
methods = append(methods, signer)
}
}
return methods
}
func readKey(filename string) (ssh.Signer, error) {
f, err := os.Open(filename)
if err != nil {
return nil, err
}
defer f.Close()
bytes, _ := io.ReadAll(f)
return ssh.ParsePrivateKey(bytes)
}
func readKeyWithPassphrase(filename string, passpharase []byte) (ssh.Signer, error) {
f, err := os.Open(filename)
if err != nil {
return nil, err
}
defer f.Close()
bytes, _ := io.ReadAll(f)
return ssh.ParsePrivateKeyWithPassphrase(bytes, passpharase)
}
Go
1
https://gitee.com/h79/goutils.git
git@gitee.com:h79/goutils.git
h79
goutils
goutils
v1.20.57

搜索帮助