micro/examples/server/handler/example.go

37 lines
914 B
Go
Raw Normal View History

2015-01-14 02:31:27 +03:00
package handler
import (
2015-01-31 18:49:21 +03:00
log "github.com/golang/glog"
2015-05-23 13:53:40 +03:00
c "github.com/myodc/go-micro/context"
2015-05-25 20:16:42 +03:00
example "github.com/myodc/go-micro/examples/server/proto/example"
2015-05-05 21:05:06 +03:00
"github.com/myodc/go-micro/server"
2015-05-23 13:53:40 +03:00
"golang.org/x/net/context"
2015-01-14 02:31:27 +03:00
)
type Example struct{}
func (e *Example) Call(ctx context.Context, req *example.Request, rsp *example.Response) error {
2015-05-27 00:39:48 +03:00
md, _ := c.GetMetadata(ctx)
log.Infof("Received Example.Call request with metadata: %v", md)
2015-05-27 00:39:48 +03:00
rsp.Msg = server.Config().Id() + ": Hello " + req.Name
2015-01-14 02:31:27 +03:00
return nil
}
func (e *Example) Stream(ctx context.Context, req *example.StreamingRequest, response func(interface{}) error) error {
log.Infof("Received Example.Stream request with count: %d", req.Count)
for i := 0; i < int(req.Count); i++ {
log.Infof("Responding: %d", i)
r := &example.StreamingResponse{
Count: int64(i),
}
if err := response(r); err != nil {
return err
}
}
return nil
}