package main import "fmt" import "log" import "net" import "os" import "io" import "bytes" import "strconv" import "image/color" import "github.com/golang/protobuf/proto" import pb "git.wit.com/wit/witProtobuf" // import "github.com/andlabs/ui" // import _ "github.com/andlabs/ui/winmanifest" import "git.wit.com/wit/gui" var mychannel chan *pb.Event func initChannel() { mychannel = make(chan *pb.Event) } // func processEvents(mychannel chan *pb.Event) { func processEvents() { for { message := <-mychannel log.Println("processEvents() START on channel recieved a message = ", message) if (message.Type == pb.Event_DEMO) { log.Println("processEvents() do Event DEMO") // figure out how to interact with the GUI here // go ui.Main(gui.SetupDemoUI) } else { count := countVMS(message) mh := addVmsTab(count) ReadReceivedData(message, mh) } log.Println("processEvents() END on channel") } } func countVMS(data *pb.Event) int { vms := data.GetVms() log.Println("NUMBER OF vms=", len(vms)) // os.Exit(-1) return len(vms) } func ReadReceivedData(data *pb.Event, mh *gui.TableData) { msgItems := data.GetResults() log.Println("ReadReceivedData() Event msgItems=", msgItems) for _, item := range msgItems { log.Println(item) } nets := data.GetNetworks() log.Println("ReadReceivedData() Event networks=", nets) for _, item := range nets { log.Println(item) } vms := data.GetVms() log.Println("ReadReceivedData() Event vms=", vms) for row, item := range vms { if (row % 2) == 1 { mh.Rows[row].HumanData[0].Color = color.RGBA{0, 0, 0, 42} // makes the background of each other row grey } else { mh.Rows[row].HumanData[0].Color = color.RGBA{0, 0, 0, 0} } mh.Rows[row].HumanData[1].Text = item.Name mh.Rows[row].HumanData[1].Color = color.RGBA{0, 0, 0, 0} mh.Rows[row].HumanData[2].Text = item.Hostname mh.Rows[row].HumanData[2].Color = color.RGBA{0, 0, 0, 0} mh.Rows[row].HumanData[3].Text = fmt.Sprintf("%d",item.Cpus) mh.Rows[row].HumanData[3].Color = color.RGBA{0, 0, 0, 0} mh.Rows[row].HumanData[4].Text = fmt.Sprintf("%d",item.Memory) mh.Rows[row].HumanData[4].Color = color.RGBA{0, 0, 0, 0} mh.Rows[row].HumanData[5].Text = fmt.Sprintf("%d",item.Disk) mh.Rows[row].HumanData[5].Color = color.RGBA{0, 0, 0, 0} mh.Rows[row].HumanData[6].Text = fmt.Sprintf("Details %s",item.Name) log.Println("\titem=", item) log.Println("\titem.Name=", item.Name) log.Println("\tRows[row]=", mh.Rows[row]) log.Println("\tRows[row]=", row) log.Println("\tRows[row].Name=", mh.Rows[row].Name) log.Println(item) row += 1 } /* log.Println("ReadReceivedData() mh rows") for row := 0; row < mh.RowCount; row++ { log.Println("\trow=", row) log.Println("\tRows[row]=", mh.Rows[row]) } */ } func addSampleEvent() { msg := pb.CreateSampleEvent() msg.Name = "generated in addSampleEvent()" addEvent(msg) } // Marshal & Unmarshal just to see if it ever fails func addEvent(msg *pb.Event) { data, err := proto.Marshal(msg) if (err != nil) { log.Printf("addEvent() something fucked up happened in Marshal") } pdata := new(pb.Event) err = proto.Unmarshal(data, pdata) if (err != nil) { log.Printf("addEvent() something fucked up happened in Unmarshal") } mychannel <- pdata } func sendDataToDest() { msg := pb.CreateSampleEvent() msg.Name = "from dnssecsockettest()" data, err := proto.Marshal(msg) if (err != nil) { log.Printf("something fucked up happened") } conn, err := net.Dial("tcp", "localhost:8080") if err != nil { log.Println("Fatal error: %s", err.Error()) return } n, err := conn.Write(data) if err != nil { // fmt.Fprintf(os.Stderr, "Fatal error: %s", err.Error()) log.Println("Fatal error: %s", err.Error()) return } pb.DumpEventData(msg) log.Println("Sent " + strconv.Itoa(n) + " bytes") // time.Sleep(3 * 1000 * 1000 * 1000) conn.Close() } func handleProtoClient(conn net.Conn) { fmt.Println("Connected!") defer conn.Close() var buf bytes.Buffer _, err := io.Copy(&buf, conn) if err != nil { fmt.Fprintf(os.Stderr, "Fatal error: %s", err.Error()) return } pdata := pb.CreateSampleEvent() err = proto.Unmarshal(buf.Bytes(), pdata) if err != nil { fmt.Fprintf(os.Stderr, "Fatal error: %s", err.Error()) return } mychannel <- pdata }