store

package
v1.0.31 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 2, 2024 License: Unlicense Imports: 20 Imported by: 0

README

eventstore

fast, GC enabled, multi-level capable nostr event store

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrDupEvent       = errors.New("duplicate: event already exists")
	ErrEventNotExists = errors.New("unknown: event not known by any source of this realy")
)

Functions

func GetAddrTagElements

func GetAddrTagElements(tagValue S) (k uint16, pkb B, d S)

func Less

func Less(a, b tag.T) bool

func TagSorter

func TagSorter(a, b tag.T) int

Types

type B added in v1.0.0

type B = []byte

type Ctx added in v1.0.0

type Ctx = context.T

type E added in v1.0.0

type E = error

type I

type I interface {
	// Init is called at the very beginning by [Server.Start], after [Relay.Init], allowing a
	// storage to initialize its internal resources. The parameters can be used by the database
	// implementations to set custom parameters such as cache management and other relevant
	// parameters to the specific implementation.
	Init(path S) (err E)
	// Path returns the directory of the database.
	Path() S
	// Close must be called after you're done using the store, to free up resources and so on.
	Close() (err E)
	// Nuke deletes everything in the database.
	Nuke() (err E)
	// 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(c Ctx, f *filter.T) (evs []*event.T, err E)
	// CountEvents performs the same work as QueryEvents but instead of delivering the events
	// that were found it just returns the count of events
	CountEvents(c Ctx, f *filter.T) (count N, approx bool, err E)
	// DeleteEvent is used to handle deletion events, as per NIP-09.
	DeleteEvent(c Ctx, ev *eventid.T) (err E)
	// SaveEvent is called once Relay.AcceptEvent reports true.
	SaveEvent(c Ctx, ev *event.T) (err E)
	// Import reads in a stream of line structured JSON of events to save into the store.
	Import(r io.Reader)
	// Export writes a stream of line structured JSON of all events in the store. If pubkeys are
	// present, only those with these pubkeys in the `pubkey` field will be included.
	Export(c Ctx, w io.Writer, pubkeys ...B)
	// Sync signals the event store to flush its buffers.
	Sync() (err E)
}

I is an types for a persistence layer for nostr events handled by a relay.

type N added in v1.0.0

type N = int

type OK

type OK = okenvelope.T

type RelayInterface added in v1.0.0

type RelayInterface interface {
	Publish(c Ctx, evt *event.T) E
	QuerySync(c Ctx, f *filter.T, opts ...ws.SubscriptionOption) ([]*event.T, E)
}

RelayInterface is a wrapper thing that unifies Store and Relay under a common API.

type RelayWrapper added in v1.0.0

type RelayWrapper struct {
	I
}

func (RelayWrapper) Publish added in v1.0.0

func (w RelayWrapper) Publish(c Ctx, evt *event.T) (err E)

func (RelayWrapper) QuerySync added in v1.0.0

func (w RelayWrapper) QuerySync(c Ctx, f *filter.T,
	opts ...ws.SubscriptionOption) ([]*event.T, E)

type Req

type Req = *http.Request

type Responder

type Responder = http.ResponseWriter

type S added in v1.0.0

type S = string

type SubID

type SubID = subscription.Id

type WS

type WS = *ws.Serv

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL