eventstore

package
v1.0.10 Latest Latest
Warning

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

Go to latest
Published: Jan 11, 2024 License: CC0-1.0, Unlicense Imports: 10 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var ErrDupEvent = errors.New("duplicate: event already exists")

Functions

func GetAddrTagElements

func GetAddrTagElements(tagValue string) (k uint16, pkb []byte, d string)

func TagSorter

func TagSorter(a, b tags.Tag) int

Types

type RelayInterface

type RelayInterface interface {
	Publish(c context.T, evt *event.T) error
	QuerySync(c context.T, f *filter.T, opts ...relay.SubscriptionOption) ([]*event.T, error)
}

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

type RelayWrapper

type RelayWrapper struct {
	Store
}

func (RelayWrapper) Publish

func (w RelayWrapper) Publish(c context.T, evt *event.T) (e error)

func (RelayWrapper) QuerySync

func (w RelayWrapper) QuerySync(c context.T, f *filter.T, opts ...relay.SubscriptionOption) ([]*event.T, error)

type Store

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.T, *filter.T) (chan *event.T, error)
	// DeleteEvent is used to handle deletion events, as per NIP-09.
	DeleteEvent(context.T, *event.T) error
	// SaveEvent is called once Relay.AcceptEvent reports true.
	SaveEvent(context.T, *event.T) error
}

Store is a persistence layer for nostr events handled by a relay.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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