2021-03-20 16:59:47 +08:00
|
|
|
package event
|
2021-03-20 15:21:50 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
)
|
|
|
|
|
2021-03-22 19:01:25 +08:00
|
|
|
// Event is an absctraction for all messages that
|
2021-03-20 15:21:50 +08:00
|
|
|
// are sent to quque or received from queue.
|
2021-03-22 19:01:25 +08:00
|
|
|
type Event struct {
|
|
|
|
// Key sets the key of the message for routing policy
|
|
|
|
Key string
|
|
|
|
// Payload for the message
|
|
|
|
Payload []byte
|
|
|
|
// Properties attach application defined properties on the message
|
|
|
|
Properties map[string]string
|
2021-03-20 15:21:50 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Handler is a callback function that processes messages delivered
|
|
|
|
// to asynchronous subscribers.
|
|
|
|
type Handler func(context.Context, Event) error
|
|
|
|
|
|
|
|
// Publisher is absctraction for sending messages
|
|
|
|
// to queue.
|
|
|
|
type Publisher interface {
|
2021-03-22 19:01:25 +08:00
|
|
|
Publish(ctx context.Context, event Event) error
|
2021-03-20 15:21:50 +08:00
|
|
|
Close() error
|
|
|
|
}
|
|
|
|
|
|
|
|
// Subscriber is an absctraction for receiving messages
|
|
|
|
// from queue.
|
|
|
|
type Subscriber interface {
|
|
|
|
Subscribe(ctx context.Context, h Handler) error
|
|
|
|
Close() error
|
|
|
|
}
|