Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var ErrDupEvent = errors.New("duplicate: event already exists")
Functions ¶
func GetAddrTagElements ¶
Types ¶
type RelayInterface ¶
type RelayInterface interface { Publish(ctx context.Context, event nip1.Event) error QuerySync(ctx context.Context, filter *nip1.Filter, opts ...SubscriptionOption) ([]*nip1.Event, error) }
RelayInterface is a wrapper thing that unifies Store and nostr.Relay under a common API.
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.Context, *nip1.Filter) (chan *nip1.Event, error) // DeleteEvent is used to handle deletion events, as per NIP-09. DeleteEvent(context.Context, *nip1.Event) error // SaveEvent is called once Relay.AcceptEvent reports true. SaveEvent(context.Context, *nip1.Event) error }
Store is a persistence layer for nostr events handled by a relay.
type SubscriptionOption ¶
type SubscriptionOption interface {
IsSubscriptionOption()
}
SubscriptionOption is the type of the argument passed for that. Some examples are WithLabel.
Click to show internal directories.
Click to hide internal directories.