mirror of
https://github.com/go-micro/go-micro.git
synced 2025-01-11 17:18:28 +02:00
Setup subscription wrappers
This commit is contained in:
parent
cfa676af19
commit
eef155490e
45
examples/client/pub/pub.go
Normal file
45
examples/client/pub/pub.go
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/micro/go-micro/client"
|
||||||
|
"github.com/micro/go-micro/cmd"
|
||||||
|
c "github.com/micro/go-micro/context"
|
||||||
|
example "github.com/micro/go-micro/examples/server/proto/example"
|
||||||
|
"golang.org/x/net/context"
|
||||||
|
)
|
||||||
|
|
||||||
|
// publishes a message
|
||||||
|
func pub(i int) {
|
||||||
|
msg := client.NewPublication("topic.go.micro.srv.example", &example.Message{
|
||||||
|
Say: fmt.Sprintf("This is a publication %d", i),
|
||||||
|
})
|
||||||
|
|
||||||
|
// create context with metadata
|
||||||
|
ctx := c.WithMetadata(context.Background(), map[string]string{
|
||||||
|
"X-User-Id": "john",
|
||||||
|
"X-From-Id": "script",
|
||||||
|
})
|
||||||
|
|
||||||
|
// publish message
|
||||||
|
if err := client.Publish(ctx, msg); err != nil {
|
||||||
|
fmt.Println("pub err: ", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Printf("Published %d: %v\n", i, msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
cmd.Init()
|
||||||
|
fmt.Println("\n--- Publisher example ---\n")
|
||||||
|
// for i := 0; i < 10; i++ {
|
||||||
|
i := 0
|
||||||
|
for {
|
||||||
|
pub(i)
|
||||||
|
i++
|
||||||
|
time.Sleep(time.Millisecond * 5)
|
||||||
|
}
|
||||||
|
}
|
@ -208,7 +208,7 @@ func (s *rpcServer) Register() error {
|
|||||||
defer s.Unlock()
|
defer s.Unlock()
|
||||||
|
|
||||||
for sb, _ := range s.subscribers {
|
for sb, _ := range s.subscribers {
|
||||||
handler := s.createSubHandler(sb)
|
handler := s.createSubHandler(sb, s.opts)
|
||||||
sub, err := config.broker.Subscribe(sb.Topic(), handler)
|
sub, err := config.broker.Subscribe(sb.Topic(), handler)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -279,7 +279,7 @@ func (s *rpcServer) Start() error {
|
|||||||
registerHealthChecker(s)
|
registerHealthChecker(s)
|
||||||
config := s.Config()
|
config := s.Config()
|
||||||
|
|
||||||
ts, err := config.transport.Listen(s.opts.address)
|
ts, err := config.transport.Listen(config.address)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -154,28 +154,23 @@ func validateSubscriber(sub Subscriber) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *rpcServer) createSubHandler(sb *subscriber) broker.Handler {
|
func (s *rpcServer) createSubHandler(sb *subscriber, opts options) broker.Handler {
|
||||||
return func(msg *broker.Message) {
|
return func(msg *broker.Message) {
|
||||||
cf, err := s.newCodec(msg.Header["Content-Type"])
|
cf, err := s.newCodec(msg.Header["Content-Type"])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
b := &buffer{bytes.NewBuffer(msg.Body)}
|
|
||||||
co := cf(b)
|
|
||||||
if err := co.ReadHeader(&codec.Message{}, codec.Publication); err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
hdr := make(map[string]string)
|
hdr := make(map[string]string)
|
||||||
for k, v := range msg.Header {
|
for k, v := range msg.Header {
|
||||||
hdr[k] = v
|
hdr[k] = v
|
||||||
}
|
}
|
||||||
delete(hdr, "Content-Type")
|
delete(hdr, "Content-Type")
|
||||||
ctx := c.WithMetadata(context.Background(), hdr)
|
ctx := c.WithMetadata(context.Background(), hdr)
|
||||||
rctx := reflect.ValueOf(ctx)
|
|
||||||
|
|
||||||
for _, handler := range sb.handlers {
|
for i := 0; i < len(sb.handlers); i++ {
|
||||||
|
handler := sb.handlers[i]
|
||||||
|
|
||||||
var isVal bool
|
var isVal bool
|
||||||
var req reflect.Value
|
var req reflect.Value
|
||||||
|
|
||||||
@ -185,26 +180,45 @@ func (s *rpcServer) createSubHandler(sb *subscriber) broker.Handler {
|
|||||||
req = reflect.New(handler.reqType)
|
req = reflect.New(handler.reqType)
|
||||||
isVal = true
|
isVal = true
|
||||||
}
|
}
|
||||||
|
if isVal {
|
||||||
|
req = req.Elem()
|
||||||
|
}
|
||||||
|
|
||||||
|
b := &buffer{bytes.NewBuffer(msg.Body)}
|
||||||
|
co := cf(b)
|
||||||
|
defer co.Close()
|
||||||
|
|
||||||
|
if err := co.ReadHeader(&codec.Message{}, codec.Publication); err != nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
if err := co.ReadBody(req.Interface()); err != nil {
|
if err := co.ReadBody(req.Interface()); err != nil {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if isVal {
|
fn := func(ctx context.Context, msg interface{}) error {
|
||||||
req = req.Elem()
|
|
||||||
}
|
|
||||||
|
|
||||||
var vals []reflect.Value
|
var vals []reflect.Value
|
||||||
if sb.typ.Kind() != reflect.Func {
|
if sb.typ.Kind() != reflect.Func {
|
||||||
vals = append(vals, sb.rcvr)
|
vals = append(vals, sb.rcvr)
|
||||||
}
|
}
|
||||||
|
|
||||||
if handler.ctxType != nil {
|
if handler.ctxType != nil {
|
||||||
vals = append(vals, rctx)
|
vals = append(vals, reflect.ValueOf(ctx))
|
||||||
}
|
}
|
||||||
|
|
||||||
vals = append(vals, req)
|
vals = append(vals, reflect.ValueOf(msg))
|
||||||
go handler.method.Call(vals)
|
|
||||||
|
returnValues := handler.method.Call(vals)
|
||||||
|
if err := returnValues[0].Interface(); err != nil {
|
||||||
|
return err.(error)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
for i := len(opts.subWrappers); i > 0; i-- {
|
||||||
|
fn = opts.subWrappers[i-1](fn)
|
||||||
|
}
|
||||||
|
|
||||||
|
go fn(ctx, req.Interface())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user