eventstore: more consistent ErrDupEvent firing.
This commit is contained in:
@@ -4,6 +4,7 @@ import (
|
||||
"fmt"
|
||||
|
||||
"fiatjaf.com/nostr"
|
||||
"fiatjaf.com/nostr/eventstore"
|
||||
"fiatjaf.com/nostr/eventstore/codec/betterbinary"
|
||||
"github.com/PowerDNS/lmdb-go/lmdb"
|
||||
)
|
||||
@@ -32,6 +33,10 @@ func (b *LMDBBackend) SaveEvent(evt nostr.Event) error {
|
||||
return b.save(txn, evt)
|
||||
}
|
||||
|
||||
if err == nil {
|
||||
return eventstore.ErrDupEvent
|
||||
}
|
||||
|
||||
return err
|
||||
})
|
||||
}
|
||||
|
||||
@@ -10,6 +10,7 @@ import (
|
||||
"unsafe"
|
||||
|
||||
"fiatjaf.com/nostr"
|
||||
"fiatjaf.com/nostr/eventstore"
|
||||
"fiatjaf.com/nostr/eventstore/codec/betterbinary"
|
||||
"github.com/PowerDNS/lmdb-go/lmdb"
|
||||
)
|
||||
@@ -80,7 +81,7 @@ func (b *MultiMmapManager) storeOn(
|
||||
ilid := binary.BigEndian.Uint16(val[s : s+2])
|
||||
if il.id == ilid {
|
||||
// already on the specified layer, we can end here
|
||||
return false, nil
|
||||
return false, eventstore.ErrDupEvent
|
||||
}
|
||||
}
|
||||
} else if !lmdb.IsNotFound(err) {
|
||||
|
||||
@@ -33,12 +33,11 @@ func (w StorePublisher) Publish(ctx context.Context, evt nostr.Event) error {
|
||||
// regular events are just saved directly
|
||||
if err := w.SaveEvent(evt); err != nil && err != eventstore.ErrDupEvent {
|
||||
return fmt.Errorf("failed to save: %w", err)
|
||||
} else {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// others are replaced
|
||||
w.Store.ReplaceEvent(evt)
|
||||
|
||||
return nil
|
||||
return w.Store.ReplaceEvent(evt)
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
package policies
|
||||
package wrappers
|
||||
|
||||
import (
|
||||
"fiatjaf.com/nostr"
|
||||
Reference in New Issue
Block a user