func main() { var user p.User var file *clnt.File flag.Parse() user = p.OsUsers.Uid2User(os.Geteuid()) clnt.DefaultDebuglevel = *debuglevel c, oerr := tls.Dial("tcp", *addr, &tls.Config{ Rand: rand.Reader, InsecureSkipVerify: true, }) 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) }
func main() { var user p.User var err error var c *clnt.Clnt var file *clnt.File var d []*p.Dir flag.Parse() user = p.OsUsers.Uid2User(os.Geteuid()) clnt.DefaultDebuglevel = *debuglevel c, err = clnt.Mount("tcp", *addr, "", user) if err != nil { log.Fatal(err) } lsarg := "/" if flag.NArg() == 1 { lsarg = flag.Arg(0) } else if flag.NArg() > 1 { log.Fatal("error: only one argument expected") } file, err = c.FOpen(lsarg, p.OREAD) if err != nil { log.Fatal(err) } for { d, err = file.Readdir(0) if d == nil || len(d) == 0 || err != nil { break } for i := 0; i < len(d); i++ { os.Stdout.WriteString(d[i].Name + "\n") } } file.Close() if err != nil && err != io.EOF { log.Fatal(err) } return }
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) }