Documentation ¶
Index ¶
- type EventStore
- func (s *EventStore) Close() error
- func (s *EventStore) Load(ctx context.Context, id uuid.UUID) ([]eh.Event, error)
- func (s *EventStore) LoadFrom(ctx context.Context, id uuid.UUID, version int) ([]eh.Event, error)
- func (s *EventStore) LoadSnapshot(ctx context.Context, id uuid.UUID) (*eh.Snapshot, error)
- func (s *EventStore) Save(ctx context.Context, events []eh.Event, originalVersion int) error
- func (s *EventStore) SaveSnapshot(ctx context.Context, id uuid.UUID, snapshot eh.Snapshot) error
- type Option
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type EventStore ¶
type EventStore struct {
// contains filtered or unexported fields
}
EventStore is an eventhorizon.EventStore for PostgreSQL, using one collection for all events and another to keep track of all aggregates/streams. It also keep tracks of the global position of events, stored as metadata.
func NewEventStore ¶
NewEventStore creates a new EventStore with a Postgres URI: `postgres://user:password@hostname:port/db?options`
func (*EventStore) LoadFrom ¶
LoadFrom implements LoadFrom method of the eventhorizon.SnapshotStore interface.
func (*EventStore) LoadSnapshot ¶ added in v0.2.0
func (*EventStore) SaveSnapshot ¶ added in v0.2.0
type Option ¶
type Option func(*EventStore) error
Option is an option setter used to configure creation.
func WithEventHandler ¶
func WithEventHandler(h eh.EventHandler) Option
WithEventHandler adds an event handler that will be called after saving events. An example would be to add an event bus to publish events.
func WithEventHandlerInTX ¶
func WithEventHandlerInTX(h eh.EventHandler) Option
WithEventHandlerInTX adds an event handler that will be called during saving of events. An example would be to add an outbox to further process events. For an outbox to be atomic it needs to use the same transaction as the save operation, which is passed down using the context.