diff options
author | Ondrej Fabry <ofabry@cisco.com> | 2019-06-26 16:28:20 +0200 |
---|---|---|
committer | Ondrej Fabry <ofabry@cisco.com> | 2019-06-27 07:33:14 +0200 |
commit | ef471318d66dd2832df4dc929d312f7cd5f7009a (patch) | |
tree | 49dda363eaa7ac3102425aba9f13a503b2a04f48 /examples/simple-client | |
parent | da15c397b3dbbba07d159b3af767aa13d443cfd6 (diff) |
Improvements for binapi-generator and support VPP 19.04 in statsclient
- RPC service client implementation for dumps requests
now streams responses
- RPC service generation is now enabled by default
- examples now allow setting binapi socket address
- input dir flag for binapi-generator will recursively look
into dirs to support core/plugins in /usr/share/vpp/api
- minor improvements in debug logs
- add support for VPP 19.04 for statsclient
Change-Id: I0939ee3aa6e9f850d073fc5c87aff4ccc56b0d70
Signed-off-by: Ondrej Fabry <ofabry@cisco.com>
Diffstat (limited to 'examples/simple-client')
-rw-r--r-- | examples/simple-client/simple_client.go | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/examples/simple-client/simple_client.go b/examples/simple-client/simple_client.go index f3ee412..609a25d 100644 --- a/examples/simple-client/simple_client.go +++ b/examples/simple-client/simple_client.go @@ -17,6 +17,7 @@ package main import ( + "flag" "fmt" "log" "net" @@ -24,6 +25,7 @@ import ( "strings" "git.fd.io/govpp.git" + "git.fd.io/govpp.git/adapter/socketclient" "git.fd.io/govpp.git/api" "git.fd.io/govpp.git/core" "git.fd.io/govpp.git/examples/binapi/acl" @@ -31,11 +33,17 @@ import ( "git.fd.io/govpp.git/examples/binapi/ip" ) +var ( + sockAddr = flag.String("sock", socketclient.DefaultSocketName, "Path to VPP binary API socket file") +) + func main() { - fmt.Println("Starting simple VPP client...") + flag.Parse() + + fmt.Println("Starting simple client example") // connect to VPP - conn, conev, err := govpp.AsyncConnect("", core.DefaultMaxReconnectAttempts, core.DefaultReconnectInterval) + conn, conev, err := govpp.AsyncConnect(*sockAddr, core.DefaultMaxReconnectAttempts, core.DefaultReconnectInterval) if err != nil { log.Fatalln("ERROR:", err) } @@ -44,14 +52,14 @@ func main() { select { case e := <-conev: if e.State != core.Connected { - log.Fatalf("failed to connect: %v", e.Error) + log.Fatalln("ERROR: connecting to VPP failed:", err) } } // create an API channel that will be used in the examples ch, err := conn.NewAPIChannel() if err != nil { - log.Fatalln("ERROR:", err) + log.Fatalln("ERROR: creating channel failed:", err) } defer ch.Close() @@ -115,10 +123,6 @@ func aclConfig(ch api.Channel) { fmt.Println("ERROR:", err) return } - if reply.Retval != 0 { - fmt.Println("Retval:", reply.Retval) - return - } fmt.Printf("ACL add replace reply: %+v\n", reply) @@ -154,6 +158,7 @@ func interfaceDump(ch api.Channel) { } if err != nil { fmt.Println("ERROR:", err) + return } ifaceName := strings.TrimFunc(string(msg.InterfaceName), func(r rune) bool { return r == 0x00 @@ -178,6 +183,7 @@ func ipAddressDump(ch api.Channel) { } if err != nil { fmt.Println("ERROR:", err) + return } fmt.Printf("ip address details: %d %+v\n", msg.SwIfIndex, msg) } @@ -214,6 +220,7 @@ func ipUnnumberedDump(ch api.Channel) { } if err != nil { fmt.Println("ERROR:", err) + return } fmt.Printf("IP unnumbered details: %+v\n", msg) } |