/
tls.go
94 lines (78 loc) · 1.71 KB
/
tls.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
// Connects to a server over TLS and lists the specified directory
package main
import (
"code.google.com/p/go9p/p"
"code.google.com/p/go9p/p/clnt"
"crypto/rand"
"crypto/tls"
"crypto/x509"
"io/ioutil"
"flag"
"fmt"
"log"
"os"
)
var debuglevel = flag.Int("d", 0, "debuglevel")
var addr = flag.String("addr", ":5640", "network address")
func main() {
var user p.User
var file *clnt.File
flag.Parse()
user = p.OsUsers.Uid2User(os.Geteuid())
clnt.DefaultDebuglevel = *debuglevel
certpool := x509.NewCertPool()
pem, err := ioutil.ReadFile("ca.crt.pem")
success := certpool.AppendCertsFromPEM(pem)
if ! success {
log.Println("can't parse cert pool")
return
}
cert, err := tls.LoadX509KeyPair("client.crt.pem", "client.key.pem")
if err != nil {
log.Println(fmt.Sprintf("Error: %s", err))
return
}
c, oerr := tls.Dial("tcp", *addr, &tls.Config{
ServerName: "localhost",
Rand: rand.Reader,
Certificates: []tls.Certificate{cert},
CipherSuites: []uint16{tls.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA},
RootCAs: certpool,
InsecureSkipVerify: false,
})
if oerr != nil {
log.Println("can't dial", oerr)
return
}
clnt, err := clnt.MountConn(c, "", user)
if err != nil {
goto error
}
if flag.NArg() != 1 {
log.Println("invalid arguments")
return
}
file, oerr = clnt.FOpen(flag.Arg(0), p.OREAD)
if oerr != nil {
goto oerror
}
for {
d, oerr := file.Readdir(0)
if oerr != nil {
goto oerror
}
if d == nil || len(d) == 0 {
break
}
for i := 0; i < len(d); i++ {
os.Stdout.WriteString(d[i].Name + "\n")
}
}
file.Close()
return
error:
log.Println(fmt.Sprintf("Error: %s", err))
return
oerror:
log.Println("Error", oerr)
}