Compare commits

..

No commits in common. "main" and "v1.0.0" have entirely different histories.
main ... v1.0.0

3 changed files with 9 additions and 12 deletions

View File

@ -27,6 +27,7 @@ package main
import (
"fmt"
"sync"
"git.apihub24.de/admin/events"
)
@ -54,14 +55,15 @@ func main() {
nameSubscription := handler.Subscribe(NameEventType, func(event events.IEvent) {
// read the Name Event Data
data, _ := events.ParseEventData[NameEventData](event)
var data NameEventData
_ = event.Data(&data)
// Publish the Greet Event
_ = handler.Publish(events.NewEvent(GreetEventType, GreetEventData{Greeting: fmt.Sprintf("Hello, %s", data.Name)}))
})
greetSubscription := handler.Subscribe(GreetEventType, func(event events.IEvent) {
data, _ := events.ParseEventData[GreetEventData](event)
println(fmt.Sprintf("%v", data))
var data GreetEventData
_ = event.Data(&data)
})
// publish the Name Event
_ = handler.Publish(nameEvent)

View File

@ -1,7 +0,0 @@
package events
func ParseEventData[T any](event IEvent) (T, error) {
var d T
err := event.Data(&d)
return d, err
}

View File

@ -29,7 +29,8 @@ func Test_EventHandler_ShouldHandleSubscriptions(t *testing.T) {
wg.Add(2)
handler.Subscribe(NameEventType, func(event events.IEvent) {
data, err := events.ParseEventData[NameEventData](event)
var data NameEventData
err := event.Data(&data)
if err != nil {
t.Error(err)
}
@ -41,7 +42,8 @@ func Test_EventHandler_ShouldHandleSubscriptions(t *testing.T) {
})
handler.Subscribe(GreetEventType, func(event events.IEvent) {
data, err := events.ParseEventData[GreetEventData](event)
var data GreetEventData
err := event.Data(&data)
if err != nil {
t.Error(err)
}