Compare commits
	
		
			No commits in common. "master" and "v1.1.0-stable" have entirely different histories.
		
	
	
		
			master
			...
			v1.1.0-sta
		
	
		
@ -1,4 +1,4 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"golang.org/x/crypto/ssh"
 | 
			
		||||
@ -6,7 +6,7 @@ import (
 | 
			
		||||
	"net"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func AcceptClients(connection net.Listener, config *ssh.ClientConfig, serverAddrString, remoteAddrString string) {
 | 
			
		||||
func acceptClients(connection net.Listener, config *ssh.ClientConfig) {
 | 
			
		||||
 | 
			
		||||
	// Endless loop
 | 
			
		||||
	for {
 | 
			
		||||
@ -22,7 +22,7 @@ func AcceptClients(connection net.Listener, config *ssh.ClientConfig, serverAddr
 | 
			
		||||
			log.Println(`Client accepted.`)
 | 
			
		||||
 | 
			
		||||
			// Start the forwarding:
 | 
			
		||||
			go forward(localConn, config, serverAddrString, remoteAddrString)
 | 
			
		||||
			go forward(localConn, config)
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
@ -1,4 +1,4 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	maxRetriesLocal  = 16 // How many retries are allowed to create the local end-point?
 | 
			
		||||
@ -1,4 +1,4 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"log"
 | 
			
		||||
@ -6,7 +6,7 @@ import (
 | 
			
		||||
	"time"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func CreateLocalEndPoint(localAddrString string) (localListener net.Listener) {
 | 
			
		||||
func createLocalEndPoint() (localListener net.Listener) {
 | 
			
		||||
 | 
			
		||||
	// Loop for the necessary retries
 | 
			
		||||
	for {
 | 
			
		||||
@ -1,4 +1,4 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"golang.org/x/crypto/ssh"
 | 
			
		||||
@ -7,7 +7,7 @@ import (
 | 
			
		||||
	"time"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func forward(localConn net.Conn, config *ssh.ClientConfig, serverAddrString, remoteAddrString string) {
 | 
			
		||||
func forward(localConn net.Conn, config *ssh.ClientConfig) {
 | 
			
		||||
 | 
			
		||||
	defer localConn.Close()
 | 
			
		||||
	currentRetriesServer := 0
 | 
			
		||||
@ -1,11 +1,11 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"log"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Another auth. method.
 | 
			
		||||
func KeyboardInteractiveChallenge(user, instruction string, questions []string, echos []bool) (answers []string, err error) {
 | 
			
		||||
func keyboardInteractiveChallenge(user, instruction string, questions []string, echos []bool) (answers []string, err error) {
 | 
			
		||||
 | 
			
		||||
	// Log all the provided data:
 | 
			
		||||
	log.Println(`User: ` + user)
 | 
			
		||||
@ -22,7 +22,7 @@ func KeyboardInteractiveChallenge(user, instruction string, questions []string,
 | 
			
		||||
 | 
			
		||||
		// We expect that in this case (only one question is asked), that the server want to know the password ;-)
 | 
			
		||||
		answers = make([]string, countQuestions, countQuestions)
 | 
			
		||||
		answers[0] = callbackPassword
 | 
			
		||||
		answers[0] = password
 | 
			
		||||
 | 
			
		||||
	} else if countQuestions > 1 {
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										23
									
								
								Main.go
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								Main.go
									
									
									
									
									
								
							@ -2,18 +2,14 @@ package main
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"github.com/SommerEngineering/SSHTunnel/Tunnel"
 | 
			
		||||
	"github.com/howeyc/gopass"
 | 
			
		||||
	"golang.org/x/crypto/ssh"
 | 
			
		||||
	"log"
 | 
			
		||||
	"os"
 | 
			
		||||
	"runtime"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func main() {
 | 
			
		||||
 | 
			
		||||
	// Show the current version:
 | 
			
		||||
	log.Println(`SSHTunnel v1.3.0`)
 | 
			
		||||
	fmt.Println(`SSHTunnel v1.1.0`)
 | 
			
		||||
 | 
			
		||||
	// Allow Go to use all CPUs:
 | 
			
		||||
	runtime.GOMAXPROCS(runtime.NumCPU())
 | 
			
		||||
@ -26,32 +22,25 @@ func main() {
 | 
			
		||||
		if password == `` {
 | 
			
		||||
			// Promt for the password:
 | 
			
		||||
			fmt.Println(`Please provide the password for the connection:`)
 | 
			
		||||
			if pass, errPass := gopass.GetPasswd(); errPass != nil {
 | 
			
		||||
				log.Println(`There was an error reading the password securely: ` + errPass.Error())
 | 
			
		||||
				os.Exit(1)
 | 
			
		||||
				return
 | 
			
		||||
			} else {
 | 
			
		||||
				password = string(pass)
 | 
			
		||||
			}
 | 
			
		||||
			fmt.Scanln(&password)
 | 
			
		||||
		} else {
 | 
			
		||||
			break
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create the SSH configuration:
 | 
			
		||||
	Tunnel.SetPassword4Callback(password)
 | 
			
		||||
	config := &ssh.ClientConfig{
 | 
			
		||||
		User: username,
 | 
			
		||||
		Auth: []ssh.AuthMethod{
 | 
			
		||||
			ssh.Password(password),
 | 
			
		||||
			ssh.PasswordCallback(Tunnel.PasswordCallback),
 | 
			
		||||
			ssh.KeyboardInteractive(Tunnel.KeyboardInteractiveChallenge),
 | 
			
		||||
			ssh.PasswordCallback(passwordCallback),
 | 
			
		||||
			ssh.KeyboardInteractive(keyboardInteractiveChallenge),
 | 
			
		||||
		},
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Create the local end-point:
 | 
			
		||||
	localListener := Tunnel.CreateLocalEndPoint(localAddrString)
 | 
			
		||||
	localListener := createLocalEndPoint()
 | 
			
		||||
 | 
			
		||||
	// Accept client connections (will block forever):
 | 
			
		||||
	Tunnel.AcceptClients(localListener, config, serverAddrString, remoteAddrString)
 | 
			
		||||
	acceptClients(localListener, config)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										6
									
								
								PasswordCallback.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								PasswordCallback.go
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,6 @@
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
// Just a callback function for the password request.
 | 
			
		||||
func passwordCallback() (string, error) {
 | 
			
		||||
	return password, nil
 | 
			
		||||
}
 | 
			
		||||
@ -22,7 +22,6 @@ SSHTunnel is a tiny small program to tunnel something through a SSH without any
 | 
			
		||||
- At the moment, SSHTunnel uses only the password authentication methods. Therefore, it is currently not possible to use e.g. a certificate, etc. Nevertheless, the implementation of this feature is possible.
 | 
			
		||||
- The configuration must be provided by using the command-line arguments. It is currently not possible to use e.g. a configuration file.
 | 
			
		||||
- You can avoid the password argument if you prefer to provide the password on demand.
 | 
			
		||||
- [Ocean Remote Connections](https://github.com/SommerEngineering/OceanRemoteConnections) is a simple GUI for SSH Tunnel, PuTTY, RDP and WinSCP.
 | 
			
		||||
 | 
			
		||||
### Download
 | 
			
		||||
Go and get the latest release from the [release page](https://github.com/SommerEngineering/SSHTunnel/releases).
 | 
			
		||||
 | 
			
		||||
@ -1,4 +1,4 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"io"
 | 
			
		||||
@ -1,10 +0,0 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
 | 
			
		||||
// Just a callback function for the password request.
 | 
			
		||||
func PasswordCallback() (string, error) {
 | 
			
		||||
	return callbackPassword, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func SetPassword4Callback(password string) {
 | 
			
		||||
	callbackPassword = password
 | 
			
		||||
}
 | 
			
		||||
@ -1,6 +0,0 @@
 | 
			
		||||
package Tunnel
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	currentRetriesLocal = 0 // Check how many retries are occur for creating the local end-point
 | 
			
		||||
	callbackPassword    = ``
 | 
			
		||||
)
 | 
			
		||||
							
								
								
									
										11
									
								
								Variables.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								Variables.go
									
									
									
									
									
								
							@ -1,9 +1,10 @@
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	username         = `` // The SSH user's name
 | 
			
		||||
	password         = `` // The user's password
 | 
			
		||||
	serverAddrString = `` // The SSH server address
 | 
			
		||||
	localAddrString  = `` // The local end-point
 | 
			
		||||
	remoteAddrString = `` // The remote end-point (on the SSH server's side)
 | 
			
		||||
	username            = `` // The SSH user's name
 | 
			
		||||
	password            = `` // The user's password
 | 
			
		||||
	serverAddrString    = `` // The SSH server address
 | 
			
		||||
	localAddrString     = `` // The local end-point
 | 
			
		||||
	remoteAddrString    = `` // The remote end-point (on the SSH server's side)
 | 
			
		||||
	currentRetriesLocal = 0  // Check how many retries are occur for creating the local end-point
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user