|
@ -1,6 +1,8 @@ |
|
|
package msgclient |
|
|
package msgclient |
|
|
|
|
|
|
|
|
import ( |
|
|
import ( |
|
|
|
|
|
"crypto/md5" |
|
|
|
|
|
"hash" |
|
|
"io" |
|
|
"io" |
|
|
"log" |
|
|
"log" |
|
|
|
|
|
|
|
@ -13,6 +15,7 @@ import ( |
|
|
type PubChannel struct { |
|
|
type PubChannel struct { |
|
|
client messaging_pb.SeaweedMessaging_PublishClient |
|
|
client messaging_pb.SeaweedMessaging_PublishClient |
|
|
grpcConnection *grpc.ClientConn |
|
|
grpcConnection *grpc.ClientConn |
|
|
|
|
|
md5hash hash.Hash |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func (mc *MessagingClient) NewPubChannel(chanName string) (*PubChannel, error) { |
|
|
func (mc *MessagingClient) NewPubChannel(chanName string) (*PubChannel, error) { |
|
@ -32,15 +35,20 @@ func (mc *MessagingClient) NewPubChannel(chanName string) (*PubChannel, error) { |
|
|
return &PubChannel{ |
|
|
return &PubChannel{ |
|
|
client: pc, |
|
|
client: pc, |
|
|
grpcConnection: grpcConnection, |
|
|
grpcConnection: grpcConnection, |
|
|
|
|
|
md5hash: md5.New(), |
|
|
}, nil |
|
|
}, nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func (pc *PubChannel) Publish(m []byte) error { |
|
|
func (pc *PubChannel) Publish(m []byte) error { |
|
|
return pc.client.Send(&messaging_pb.PublishRequest{ |
|
|
|
|
|
|
|
|
err := pc.client.Send(&messaging_pb.PublishRequest{ |
|
|
Data: &messaging_pb.Message{ |
|
|
Data: &messaging_pb.Message{ |
|
|
Value: m, |
|
|
Value: m, |
|
|
}, |
|
|
}, |
|
|
}) |
|
|
}) |
|
|
|
|
|
if err == nil { |
|
|
|
|
|
pc.md5hash.Write(m) |
|
|
|
|
|
} |
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
func (pc *PubChannel) Close() error { |
|
|
func (pc *PubChannel) Close() error { |
|
|
|
|
|
|
|
@ -62,3 +70,7 @@ func (pc *PubChannel) Close() error { |
|
|
} |
|
|
} |
|
|
return nil |
|
|
return nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func (pc *PubChannel) Md5() []byte { |
|
|
|
|
|
return pc.md5hash.Sum(nil) |
|
|
|
|
|
} |