func (h *Config) Watch(ctx context.Context, stream server.Streamer) error { m := new(WatchRequest) if err := stream.Recv(m); err != nil { return err } return h.ConfigHandler.Watch(ctx, m, &configWatchStream{stream}) }
func (h *Example) Stream(ctx context.Context, stream server.Streamer) error { m := new(StreamingRequest) if err := stream.Recv(m); err != nil { return err } return h.ExampleHandler.Stream(ctx, m, &exampleStreamStream{stream}) }
func (h *Router) SelectStream(ctx context.Context, stream server.Streamer) error { m := new(SelectRequest) if err := stream.Recv(m); err != nil { return err } return h.RouterHandler.SelectStream(ctx, m, &routerSelectStreamStream{stream}) }
func (h *Event) Stream(ctx context.Context, stream server.Streamer) error { m := new(StreamRequest) if err := stream.Recv(m); err != nil { return err } return h.EventHandler.Stream(ctx, m, &eventStreamStream{stream}) }
func (e *Example) PingPong(ctx context.Context, stream server.Streamer) error { for { req := &example.Ping{} if err := stream.Recv(req); err != nil { return err } log.Printf("Got ping %v", req.Stroke) if err := stream.Send(&example.Pong{Stroke: req.Stroke}); err != nil { return err } } }
func (e *Example) Stream(ctx context.Context, stream server.Streamer) error { log.Info("Executing streaming handler") req := &example.StreamingRequest{} // We just want to receive 1 request and then process here if err := stream.Recv(req); err != nil { log.Errorf("Error receiving streaming request: %v", err) return err } log.Infof("Received Example.Stream request with count: %d", req.Count) for i := 0; i < int(req.Count); i++ { log.Infof("Responding: %d", i) if err := stream.Send(&example.StreamingResponse{ Count: int64(i), }); err != nil { return err } } return nil }