Silvan 444f682e25
refactor(notification): use new queue package (#9360)
# Which Problems Are Solved

The recently introduced notification queue have potential race conditions.

# How the Problems Are Solved

Current code is refactored to use the queue package, which is safe in
regards of concurrency.

# Additional Changes

- the queue is included in startup
- improved code quality of queue

# Additional Context

- closes https://github.com/zitadel/zitadel/issues/9278
2025-02-27 11:49:12 +01:00

28 lines
579 B
Go

package messages
import (
"net/url"
"github.com/zitadel/schema"
"github.com/zitadel/zitadel/internal/eventstore"
"github.com/zitadel/zitadel/internal/notification/channels"
)
var _ channels.Message = (*Form)(nil)
type Form struct {
Serializable any
TriggeringEventType eventstore.EventType
}
func (msg *Form) GetContent() (string, error) {
values := make(url.Values)
err := schema.NewEncoder().Encode(msg.Serializable, values)
return values.Encode(), err
}
func (msg *Form) GetTriggeringEventType() eventstore.EventType {
return msg.TriggeringEventType
}