-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathevent_store.go
70 lines (59 loc) · 1.71 KB
/
event_store.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package gddd
import (
"context"
"database/sql"
"time"
)
type EventStore interface {
Name() (name string)
GetDB(ctx context.Context) *sql.DB
InitDomainEventStoreTable(ctx context.Context, aggregateName string)
ReadEvents(ctx context.Context, aggregateName string, aggregateId int64, lastEventId int64) (events []StoredEvent, err error)
StoreEvents(ctx context.Context, events []StoredEvent) (err error)
CheckEvents(ctx context.Context, events []StoredEvent) (err error)
MakeSnapshot(ctx context.Context, aggregate Aggregate) (err error)
LoadSnapshot(ctx context.Context, aggregateId int64, aggregate Aggregate) (lastEventId int64, err error)
}
type StoredEvent interface {
AggregateId() int64
AggregateName() string
EventId() int64
EventName() string
EventBodyRaw() []byte
EventCreateTime() time.Time
}
type jsonStoredEvent struct {
aggregateId int64
aggregateName string
eventId int64
eventName string
eventBodyRaw []byte
}
func newJsonStoredEvent(aggregateId int64, aggregateName string, eventId int64, eventName string, eventByte []byte) (event *jsonStoredEvent, err error) {
event = &jsonStoredEvent{
aggregateId: aggregateId,
aggregateName: aggregateName,
eventId: eventId,
eventName: eventName,
eventBodyRaw: eventByte,
}
return
}
func (e *jsonStoredEvent) AggregateId() int64 {
return e.aggregateId
}
func (e *jsonStoredEvent) AggregateName() string {
return e.aggregateName
}
func (e *jsonStoredEvent) EventId() int64 {
return e.eventId
}
func (e *jsonStoredEvent) EventName() string {
return e.eventName
}
func (e *jsonStoredEvent) EventBodyRaw() []byte {
return e.eventBodyRaw
}
func (e *jsonStoredEvent) EventCreateTime() time.Time {
return NodeTime(e.eventId)
}