Files
eventbus2/singleton.go
werben 045603dbae add InitSingleton
add InitSingleton
2023-04-27 17:11:32 +08:00

47 lines
1.7 KiB
Go

package eventbus
var (
// singleton is a pointer to a unbuffered EventBus instance, which will be created when necessary.
singleton *EventBus
)
// InitSingleton initializes the singleton instance of EventBus, which will be created only when necessary.
func InitSingleton() {
if singleton == nil {
// If singleton is nil, we create a new instance of EventBus using the New()
// function and assign it to the singleton variable.
singleton = New()
}
}
// Unsubscribe removes handler defined for a topic.
// Returns error if there are no handlers subscribed to the topic.
func Unsubscribe(topic string, handler any) error {
return singleton.Unsubscribe(topic, handler)
}
// Subscribe subscribes to a topic, return an error if the handler is not a function.
// The handler must have two parameters: the first parameter must be a string,
// and the type of the handler's second parameter must be consistent with the type of the payload in `Publish()`
func Subscribe(topic string, handler any) error {
return singleton.Subscribe(topic, handler)
}
// Publish triggers the handlers defined for a topic. The `payload` argument will be passed to the handler.
// The type of the payload must correspond to the second parameter of the handler in `Subscribe()`.
func Publish(topic string, payload any) error {
return singleton.Publish(topic, payload)
}
// PublishSync is a synchronous version of Publish that triggers the handlers defined for a topic with the given payload.
// The type of the payload must correspond to the second parameter of the handler in `Subscribe()`.
func PublishSync(topic string, payload any) error {
return singleton.Publish(topic, payload)
}
// Close closes the singleton instance of EventBus.
func Close() {
singleton.Close()
}