Documentation ¶
Overview ¶
Package ws is a websocket library
todo: this client code is bullshit
Index ¶
- Constants
- type Client
- func (r *Client) Auth(c context.T, s signer.I) (err er)
- func (r *Client) Close() error
- func (r *Client) Connect(c context.T) (err error)
- func (r *Client) Context() context.T
- func (r *Client) Count(c context.T, ff *filters.T, opts ...SubscriptionOption) (int, error)
- func (r *Client) Delete(key string)
- func (r *Client) IsConnected() bool
- func (r *Client) MessageReadLoop(conn *Connection)
- func (r *Client) PrepareSubscription(c context.T, f *filters.T, opts ...SubscriptionOption) *Subscription
- func (r *Client) Publish(c context.T, ev *event.T) error
- func (r *Client) QuerySync(c context.T, f *filter.T, opts ...SubscriptionOption) ([]*event.T, error)
- func (r *Client) String() st
- func (r *Client) Subscribe(c context.T, f *filters.T, opts ...SubscriptionOption) (sub *Subscription, err er)
- func (r *Client) URL() st
- func (r *Client) Write(msg []byte) (ch chan error)
- type Connection
- type DirectedFilters
- type EventMessage
- type IncomingEvent
- type MessageType
- type Option
- type PoolOption
- type Serv
- func (ws *Serv) AuthPub() (a by)
- func (ws *Serv) Challenge() (challenge by)
- func (ws *Serv) Close() (err er)
- func (ws *Serv) HasAuth() bo
- func (ws *Serv) Ping() (err er)
- func (ws *Serv) Pong() (err er)
- func (ws *Serv) Remote() (remote st)
- func (ws *Serv) Write(b by) (n no, err er)
- func (ws *Serv) WriteTextMessage(b by) (err er)
- type SimplePool
- func (pool *SimplePool) BatchedSubMany(c cx, dfs []DirectedFilters) chan IncomingEvent
- func (pool *SimplePool) BatchedSubManyEose(c cx, dfs []DirectedFilters) chan IncomingEvent
- func (pool *SimplePool) EnsureRelay(url st) (*Client, er)
- func (pool *SimplePool) QuerySingle(c cx, urls []st, f *filter.T) *IncomingEvent
- func (pool *SimplePool) SubMany(c cx, urls []st, ff *filters.T) chan IncomingEvent
- func (pool *SimplePool) SubManyEose(c cx, urls []st, ff *filters.T) chan IncomingEvent
- func (pool *SimplePool) SubManyEoseNonUnique(c cx, urls []st, ff *filters.T) chan IncomingEvent
- func (pool *SimplePool) SubManyNonUnique(c cx, urls []st, ff *filters.T) chan IncomingEvent
- type Status
- type Subscription
- type SubscriptionOption
- type WithAuthHandler
- type WithEventMiddleware
- type WithLabel
- type WithNoticeHandler
Constants ¶
const ChallengeHRP = "nchal"
const ChallengeLength = 16
const MAX_LOCKS = 50
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Client ¶
type Client struct { // Ctx will be canceled when connection closes Ctx context.T ConnectionContextCancel context.F // RequestHeader e.g. for origin header RequestHeader http.Header Connection *Connection Subscriptions *xsync.MapOf[st, *Subscription] ConnectionError er AuthRequired qu.C AuthEventID *eventid.T Authed qu.C // custom things that aren't often used // AssumeValid bool // skip verifying signatures of events from this relay // contains filtered or unexported fields }
func Connect ¶
Connect returns a relay object connected to url. Once successfully connected, cancelling ctx has no effect. To close the connection, call r.Close().
func ConnectWithAuth ¶
ConnectWithAuth auths with the relay, checks if its NIP-11 says auth-required and uses the provided sec to sign the auth challenge.
func NewClient ¶
NewClient returns a new relay client. The relay connection will be closed when the context is canceled.
func (*Client) Auth ¶
Auth sends an "AUTH" command client->relay as in NIP-42 and waits for an OK response.
func (*Client) Connect ¶
Connect tries to establish a websocket connection to r.URL. If the context expires before the connection is complete, an error is returned. Once successfully connected, context expiration has no effect: call r.Close to close the connection.
The underlying relay connection will use a background context. If you want to pass a custom context to the underlying relay connection, use NewClient() and then Relay.Connect().
func (*Client) Context ¶
Context retrieves the context that is associated with this relay connection.
func (*Client) IsConnected ¶
IsConnected returns true if the connection to this relay seems to be active.
func (*Client) MessageReadLoop ¶
func (r *Client) MessageReadLoop(conn *Connection)
func (*Client) PrepareSubscription ¶
func (r *Client) PrepareSubscription(c context.T, f *filters.T, opts ...SubscriptionOption) *Subscription
PrepareSubscription creates a subscription, but doesn't fire it.
Remember to cancel subscriptions, either by calling `.Unsub()` on them or ensuring their `context.T` will be canceled at some point. Failure to do that will result in a huge number of halted goroutines being created.
func (*Client) Publish ¶
Publish sends an "EVENT" command to the relay r as in NIP-01 and waits for an OK response.
func (*Client) Subscribe ¶
func (r *Client) Subscribe(c context.T, f *filters.T, opts ...SubscriptionOption) (sub *Subscription, err er)
Subscribe sends a "REQ" command to the relay r as in NIP-01. Events are returned through the channel sub.Events. The subscription is closed when context ctx is cancelled ("CLOSE" in NIP-01).
Remember to cancel subscriptions, either by calling `.Unsub()` on them or ensuring their `context.T` will be canceled at some point. Failure to do that will result in a huge number of halted goroutines being created.
type Connection ¶
func NewConnection ¶
func NewConnection(c cx, url by, header http.Header, tlsConfig *tls.Config) (*Connection, er)
func (*Connection) Close ¶
func (cn *Connection) Close() er
func (*Connection) ReadMessage ¶
func (cn *Connection) ReadMessage(c cx, buf io.Writer) er
func (*Connection) WriteMessage ¶
func (cn *Connection) WriteMessage(c cx, data by) (err er)
type DirectedFilters ¶
type EventMessage ¶
type IncomingEvent ¶
func (IncomingEvent) String ¶
func (ie IncomingEvent) String() st
type MessageType ¶
type MessageType no
type Option ¶
type Option interface {
IsRelayOption()
}
Option is the type of the argument passed for that.
type PoolOption ¶
type PoolOption interface {
ApplyPoolOption(*SimplePool)
}
type Serv ¶
type Serv struct { Ctx cx Cancel context.F Conn *w.Conn Request *http.Request // original request Pending atomic.Value // for DM CLI authentication Authed qu.C // contains filtered or unexported fields }
Serv is a wrapper around a fasthttp/websocket with mutex locking and NIP-42 IsAuthed support for handling inbound connections from clients.
func (*Serv) Challenge ¶
func (ws *Serv) Challenge() (challenge by)
Challenge returns the current challenge on a websocket.
func (*Serv) Close ¶
func (ws *Serv) Close() (err er)
Close signals the other side to close the connection.
func (*Serv) Ping ¶
func (ws *Serv) Ping() (err er)
Ping sends a ping to see if the other side is still responsive.
func (*Serv) Pong ¶
func (ws *Serv) Pong() (err er)
Pong sends a Pong message, should be the response to receiving Ping.
func (*Serv) Write ¶
func (ws *Serv) Write(b by) (n no, err er)
Write implements the standard io.Writer interface.
func (*Serv) WriteTextMessage ¶
func (ws *Serv) WriteTextMessage(b by) (err er)
WriteTextMessage writes a text (binary?) message
type SimplePool ¶
type SimplePool struct { Relays *xsync.MapOf[st, *Client] Context cx // custom things not often used SignatureChecker func(*event.T) bo // contains filtered or unexported fields }
func NewSimplePool ¶
func NewSimplePool(c cx, opts ...PoolOption) *SimplePool
func (*SimplePool) BatchedSubMany ¶
func (pool *SimplePool) BatchedSubMany(c cx, dfs []DirectedFilters) chan IncomingEvent
BatchedSubMany fires subscriptions only to specific relays, but batches them when they are the same.
func (*SimplePool) BatchedSubManyEose ¶
func (pool *SimplePool) BatchedSubManyEose(c cx, dfs []DirectedFilters) chan IncomingEvent
BatchedSubManyEose is like BatchedSubMany, but ends upon receiving EOSE from all relays.
func (*SimplePool) EnsureRelay ¶
func (pool *SimplePool) EnsureRelay(url st) (*Client, er)
func (*SimplePool) QuerySingle ¶
func (pool *SimplePool) QuerySingle(c cx, urls []st, f *filter.T) *IncomingEvent
QuerySingle returns the first event returned by the first relay, cancels everything else.
func (*SimplePool) SubMany ¶
func (pool *SimplePool) SubMany(c cx, urls []st, ff *filters.T) chan IncomingEvent
SubMany opens a subscription with the given filters to multiple relays the subscriptions only end when the context is canceled
func (*SimplePool) SubManyEose ¶
func (pool *SimplePool) SubManyEose(c cx, urls []st, ff *filters.T) chan IncomingEvent
SubManyEose is like SubMany, but it stops subscriptions and closes the channel when gets a EOSE
func (*SimplePool) SubManyEoseNonUnique ¶
func (pool *SimplePool) SubManyEoseNonUnique(c cx, urls []st, ff *filters.T) chan IncomingEvent
SubManyEoseNonUnique is like SubManyEose, but returns duplicate events if they come from different relays
func (*SimplePool) SubManyNonUnique ¶
func (pool *SimplePool) SubManyNonUnique(c cx, urls []st, ff *filters.T) chan IncomingEvent
SubManyNonUnique is like SubMany, but returns duplicate events if they come from different relays
type Subscription ¶
type Subscription struct { Relay *Client Filters *filters.T // The Events channel emits all EVENTs that come in a Subscription will be // closed when the subscription ends Events event.C // The EndOfStoredEvents channel is closed when an EOSE comes for that // subscription EndOfStoredEvents qu.C // The ClosedReason channel emits the reason when a CLOSED message is // received ClosedReason chan by // Context will be .Done() when the subscription ends Context cx // contains filtered or unexported fields }
func (*Subscription) Close ¶
func (sub *Subscription) Close()
Close just sends a CLOSE message. You probably want Unsub() instead.
func (*Subscription) Fire ¶
func (sub *Subscription) Fire() (err er)
Fire sends the "REQ" command to the realy.
func (*Subscription) GetID ¶
func (sub *Subscription) GetID() (id *subscription.Id)
GetID return the Nostr subscription ID as given to the Client it is a concatenation of the label and a serial number.
func (*Subscription) Sub ¶
func (sub *Subscription) Sub(_ cx, ff *filters.T)
Sub sets sub.Filters and then calls sub.F1ire(ctx). The subscription will be closed if the context expires.
func (*Subscription) Unsub ¶
func (sub *Subscription) Unsub()
Unsub closes the subscription, sending "CLOSE" to realy as in NIP-01. Unsub() also closes the channel sub.Events and makes a new one.
type SubscriptionOption ¶
type SubscriptionOption interface {
IsSubscriptionOption()
}
SubscriptionOption is the type of the argument passed for that. Some examples are WithLabel.
type WithAuthHandler ¶
WithAuthHandler must be a function that signs the auth event when called. it will be called whenever any relay in the pool returns a `CLOSED` message with the "auth-required:" prefix, only once for each relay
func (WithAuthHandler) ApplyPoolOption ¶
func (h WithAuthHandler) ApplyPoolOption(pool *SimplePool)
type WithEventMiddleware ¶
type WithEventMiddleware func(IncomingEvent)
WithEventMiddleware is a function that will be called with all events received. more than one can be passed at a time.
func (WithEventMiddleware) ApplyPoolOption ¶
func (h WithEventMiddleware) ApplyPoolOption(pool *SimplePool)
type WithLabel ¶
type WithLabel by
WithLabel puts a label on the subscription (it is prepended to the automatic id) that is sent to relays.
func (WithLabel) IsSubscriptionOption ¶
func (_ WithLabel) IsSubscriptionOption()
type WithNoticeHandler ¶
type WithNoticeHandler func(notice by)
WithNoticeHandler just takes notices and is expected to do something with them. when not given, defaults to logging the notices.
func (WithNoticeHandler) IsRelayOption ¶
func (_ WithNoticeHandler) IsRelayOption()