well-goknown/vendor/github.com/fiatjaf/eventstore
2024-09-23 19:50:50 -04:00
..
postgresql upgrades, add some policies 2024-09-23 19:50:50 -04:00
.gitignore upgrades, add some policies 2024-09-23 19:50:50 -04:00
errors.go replace context with caller for zerolog, add vendor 2024-09-16 21:01:50 -04:00
helpers.go replace context with caller for zerolog, add vendor 2024-09-16 21:01:50 -04:00
LICENSE replace context with caller for zerolog, add vendor 2024-09-16 21:01:50 -04:00
README.md replace context with caller for zerolog, add vendor 2024-09-16 21:01:50 -04:00
relay_interface.go replace context with caller for zerolog, add vendor 2024-09-16 21:01:50 -04:00
store.go replace context with caller for zerolog, add vendor 2024-09-16 21:01:50 -04:00
utils.go replace context with caller for zerolog, add vendor 2024-09-16 21:01:50 -04:00

eventstore

A collection of reusable database connectors, wrappers and schemas that store Nostr events and expose a simple Go interface:

type Store interface {
	// Init is called at the very beginning by [Server.Start], after [Relay.Init],
	// allowing a storage to initialize its internal resources.
	Init() error

	// Close must be called after you're done using the store, to free up resources and so on.
	Close()

	// QueryEvents is invoked upon a client's REQ as described in NIP-01.
	// it should return a channel with the events as they're recovered from a database.
	// the channel should be closed after the events are all delivered.
	QueryEvents(context.Context, nostr.Filter) (chan *nostr.Event, error)

	// DeleteEvent is used to handle deletion events, as per NIP-09.
	DeleteEvent(context.Context, *nostr.Event) error

	// SaveEvent is called once Relay.AcceptEvent reports true.
	SaveEvent(context.Context, *nostr.Event) error
}

Go Reference Run Tests

command-line tool

There is an eventstore command-line tool that can be used to query these databases directly.