Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 1 | // Pipe To Browser client. |
| 2 | // This executable pipes its sdtin to p2b service running in the browser |
| 3 | package main |
| 4 | |
| 5 | import ( |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 6 | "flag" |
| 7 | "fmt" |
Ali Ghassemi | f88ee31 | 2014-06-13 14:26:37 -0700 | [diff] [blame] | 8 | "io" |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 9 | "os" |
| 10 | |
Ali Ghassemi | ce69243 | 2014-07-15 13:08:07 -0700 | [diff] [blame^] | 11 | "veyron2" |
| 12 | "veyron2/ipc" |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 13 | "veyron2/rt" |
| 14 | |
| 15 | "veyron/examples/pipetobrowser" |
| 16 | ) |
| 17 | |
| 18 | const usage = ` |
Ali Ghassemi | 5dcb6d3 | 2014-06-11 16:42:08 -0700 | [diff] [blame] | 19 | %s is a Pipe To Browser client. It allows one to pipe any stdout stream from console to the browser. |
| 20 | Data being piped to the browser then is displayed in a graphical and formatted way by a "viewer". |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 21 | |
| 22 | Usage: |
| 23 | |
| 24 | %s [<name>/<viewer>] |
| 25 | |
| 26 | For example: |
| 27 | |
Ali Ghassemi | 6e6ec3a | 2014-06-20 10:23:14 -0700 | [diff] [blame] | 28 | ls -l | p2b google/p2b/jane/console |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 29 | |
Ali Ghassemi | 6e6ec3a | 2014-06-20 10:23:14 -0700 | [diff] [blame] | 30 | or |
| 31 | |
| 32 | cat cat.jpg | google/p2b/jane/image |
| 33 | |
Bogdan Caprita | d9281a3 | 2014-07-02 14:40:39 -0700 | [diff] [blame] | 34 | where <name> (google/p2b/jane) is the object name where p2b |
Ali Ghassemi | 6e6ec3a | 2014-06-20 10:23:14 -0700 | [diff] [blame] | 35 | service is running in the browser. <viewer> (console, image) specifies what |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 36 | viewer should be used to display the data. |
| 37 | |
Ali Ghassemi | 6e6ec3a | 2014-06-20 10:23:14 -0700 | [diff] [blame] | 38 | To redirect stderr of a process, in *nix system you can use 2>&1 before piping to P2B. |
| 39 | |
| 40 | For example many daemons may write log lines to stderr instead of stdout: |
| 41 | |
| 42 | serverd -alsologtostderr=true 2>&1 | google/p2b/jane/vlog |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 43 | ` |
| 44 | |
| 45 | func Usage() { |
Ali Ghassemi | 5dcb6d3 | 2014-06-11 16:42:08 -0700 | [diff] [blame] | 46 | fmt.Fprintf(os.Stdout, usage, os.Args[0], os.Args[0]) |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 47 | } |
| 48 | |
Ali Ghassemi | f88ee31 | 2014-06-13 14:26:37 -0700 | [diff] [blame] | 49 | // viewerPipeStreamWriter adapts ViewerPipeStream to io.Writer |
| 50 | type viewerPipeStreamWriter struct { |
| 51 | pipetobrowser.ViewerPipeStream |
| 52 | } |
| 53 | |
| 54 | func (w viewerPipeStreamWriter) Write(p []byte) (n int, err error) { |
| 55 | w.Send(p) |
| 56 | return len(p), nil |
| 57 | } |
| 58 | |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 59 | func main() { |
| 60 | flag.Usage = Usage |
| 61 | runtime := rt.Init() |
| 62 | log := runtime.Logger() |
| 63 | |
| 64 | if flag.NArg() != 1 { |
| 65 | Usage() |
| 66 | return |
| 67 | } |
| 68 | |
| 69 | name := flag.Arg(0) |
| 70 | |
| 71 | // bind to the p2b service |
| 72 | s, err := pipetobrowser.BindViewer(name) |
| 73 | if err != nil { |
| 74 | log.Errorf("error binding to server: %v", err) |
| 75 | return |
| 76 | } |
| 77 | |
Ali Ghassemi | ce69243 | 2014-07-15 13:08:07 -0700 | [diff] [blame^] | 78 | stream, err := s.Pipe(runtime.NewContext(), veyron2.CallTimeout(ipc.NoTimeout)) |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 79 | if err != nil { |
| 80 | log.Errorf("failed to pipe to '%s' please ensure p2b service is running in the browser and name is correct.\nERR:%v", name, err) |
| 81 | return |
| 82 | } |
| 83 | |
Ali Ghassemi | f88ee31 | 2014-06-13 14:26:37 -0700 | [diff] [blame] | 84 | w := viewerPipeStreamWriter{ |
| 85 | stream, |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 86 | } |
Ali Ghassemi | f88ee31 | 2014-06-13 14:26:37 -0700 | [diff] [blame] | 87 | |
Ali Ghassemi | ce69243 | 2014-07-15 13:08:07 -0700 | [diff] [blame^] | 88 | _, err = io.Copy(w, os.Stdin) |
Ali Ghassemi | f88ee31 | 2014-06-13 14:26:37 -0700 | [diff] [blame] | 89 | if err != nil { |
| 90 | log.Errorf("failed to copy the stdin pipe to the outgoing stream\nERR:%v", err) |
| 91 | return |
| 92 | } |
| 93 | |
Ali Ghassemi | ce69243 | 2014-07-15 13:08:07 -0700 | [diff] [blame^] | 94 | _, err = stream.Finish() |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 95 | if err != nil { |
| 96 | log.Errorf("error finishing stream: %v", err) |
| 97 | return |
| 98 | } |
| 99 | |
Ali Ghassemi | 2ebd75b | 2014-06-02 15:16:34 -0700 | [diff] [blame] | 100 | fmt.Println("Finished piping to browser! Thanks for using p2b.") |
| 101 | } |