logman/ssh.go
Wyatt J. Miller a3e1ca6b2b opening new sessions works
now it's time to execute commands and working on tarring directories
2019-08-14 18:57:03 -04:00

81 lines
1.6 KiB
Go

package main
import (
"fmt"
"golang.org/x/crypto/ssh"
)
// modes := ssh.TerminalModes{
// ssh.ECHO: 0,
// ssh.TTY_OP_ISPEED: 14400,
// ssh.TTY_OP_OSPEED: 14400,
// }
type SSHConnection struct {
Username string
Password string
Port string
Hosts []string
}
type SSHCleints []*ssh.Client
type SSHSessions []*ssh.Session
func initializeConnection(config Configuration) (SSHConnection, *ssh.ClientConfig) {
var sshConn SSHConnection
sshConn.Username = config.Username
sshConn.Password = config.Password
sshConn.Port = config.Port
sshConn.Hosts = config.Hosts
sshConfig := &ssh.ClientConfig{
User: sshConn.Username,
Auth: []ssh.AuthMethod{
ssh.Password(sshConn.Password),
},
HostKeyCallback: sshConn.getHostKeys(),
}
return sshConn, sshConfig
}
func (s SSHConnection) getHostKeys() ssh.HostKeyCallback {
return ssh.InsecureIgnoreHostKey()
}
func (s SSHConnection) dialConnection(sshConfig *ssh.ClientConfig) SSHCleints {
clientConn := SSHCleints{}
for _, j := range s.Hosts {
hostPort := fmt.Sprintf("%s:22", j)
connection, err := ssh.Dial("tcp", hostPort, sshConfig)
if err != nil {
fmt.Errorf("Can't connect", err)
}
clientConn = append(clientConn, connection)
}
return clientConn
}
func (s SSHConnection) openSession(client SSHCleints) SSHSessions {
// don't forget there's a return type here
clientSessions := SSHSessions{}
for _, j := range client {
session, err := j.NewSession()
if err != nil {
fmt.Errorf("Can't open session", err)
}
clientSessions = append(clientSessions, session)
}
return clientSessions
}