mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-24 22:02:04 +02:00 
			
		
		
		
	The io/ioutil package has been deprecated as of Go 1.16 [1]. This commit replaces the existing io/ioutil functions with their new definitions in io and os packages. Reference: https://golang.org/doc/go1.16#ioutil Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
		
			
				
	
	
		
			51 lines
		
	
	
		
			985 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			985 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package ssh_test
 | |
| 
 | |
| import (
 | |
| 	"errors"
 | |
| 	"io"
 | |
| 	"os"
 | |
| 
 | |
| 	"tailscale.com/tempfork/gliderlabs/ssh"
 | |
| )
 | |
| 
 | |
| func ExampleListenAndServe() {
 | |
| 	ssh.ListenAndServe(":2222", func(s ssh.Session) {
 | |
| 		io.WriteString(s, "Hello world\n")
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func ExamplePasswordAuth() {
 | |
| 	ssh.ListenAndServe(":2222", nil,
 | |
| 		ssh.PasswordAuth(func(ctx ssh.Context, pass string) bool {
 | |
| 			return pass == "secret"
 | |
| 		}),
 | |
| 	)
 | |
| }
 | |
| 
 | |
| func ExampleNoPty() {
 | |
| 	ssh.ListenAndServe(":2222", nil, ssh.NoPty())
 | |
| }
 | |
| 
 | |
| func ExamplePublicKeyAuth() {
 | |
| 	ssh.ListenAndServe(":2222", nil,
 | |
| 		ssh.PublicKeyAuth(func(ctx ssh.Context, key ssh.PublicKey) error {
 | |
| 			data, err := os.ReadFile("/path/to/allowed/key.pub")
 | |
| 			if err != nil {
 | |
| 				return err
 | |
| 			}
 | |
| 			allowed, _, _, _, err := ssh.ParseAuthorizedKey(data)
 | |
| 			if err != nil {
 | |
| 				return err
 | |
| 			}
 | |
| 			if !ssh.KeysEqual(key, allowed) {
 | |
| 				return errors.New("some error")
 | |
| 			}
 | |
| 			return nil
 | |
| 		}),
 | |
| 	)
 | |
| }
 | |
| 
 | |
| func ExampleHostKeyFile() {
 | |
| 	ssh.ListenAndServe(":2222", nil, ssh.HostKeyFile("/path/to/host/key"))
 | |
| }
 |