logman/ssh.go

106 lines
2.1 KiB
Go
Raw Normal View History

2019-08-13 09:48:47 -05:00
package main
import (
"fmt"
"golang.org/x/crypto/ssh"
)
2019-08-14 17:31:13 -05:00
// modes := ssh.TerminalModes{
// ssh.ECHO: 0,
// ssh.TTY_OP_ISPEED: 14400,
// ssh.TTY_OP_OSPEED: 14400,
// }
type SSHConnection struct {
2019-08-13 10:10:18 -05:00
Username string
Password string
Port string
Hosts []string
2019-08-13 09:48:47 -05:00
}
2019-08-14 17:31:13 -05:00
type SSHCleints []*ssh.Client
2019-08-16 18:45:01 -05:00
// TODO: I've got two slices of the same type. To take one slice out, some refactoring is needed
type SSHSessions []*ssh.Session
2019-08-16 18:45:01 -05:00
type SSHTarFile []*ssh.Session
type SSHPush []*ssh.Client
type SSHSuccess []error
2019-08-16 22:21:26 -05:00
func initializeConnection(config Configuration) (*SSHConnection, *ssh.ClientConfig) {
sshConn := &SSHConnection{
Username: config.Username,
Password: config.Password,
Port: config.Port,
Hosts: config.Hosts,
}
sshConfig := &ssh.ClientConfig{
User: sshConn.Username,
Auth: []ssh.AuthMethod{
ssh.Password(sshConn.Password),
},
2019-08-14 17:31:13 -05:00
HostKeyCallback: sshConn.getHostKeys(),
}
return sshConn, sshConfig
}
2019-08-14 17:31:13 -05:00
func (s SSHConnection) getHostKeys() ssh.HostKeyCallback {
return ssh.InsecureIgnoreHostKey()
}
func (s SSHConnection) dialConnection(sshConfig *ssh.ClientConfig) SSHCleints {
clientConn := SSHCleints{}
2019-08-14 17:31:13 -05:00
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 {
clientSessions := SSHSessions{}
for _, j := range client {
session, err := j.NewSession()
if err != nil {
fmt.Errorf("Can't open session", err)
}
clientSessions = append(clientSessions, session)
}
2019-08-14 17:31:13 -05:00
return clientSessions
}
2019-08-16 18:45:01 -05:00
func (s SSHConnection) executeTarFile(execute SSHSessions) SSHSuccess {
// execute order 66 lol
success := SSHSuccess{}
for _, j := range execute {
// this is just a placeholder, change to the actual tarring executable
err := j.Run("echo 'hello world'! > test.txt")
if err != nil {
fmt.Errorf("Can't execute program", err)
}
success = append(success, err)
}
return success
}