Documentation ¶
Index ¶
- Constants
- func BroadcastEvent(authRequired bool, ev *event.T)
- func GetListeningFilters() *filters.T
- func NewServer(c Ctx, cancel context.F, rl relay.I, dbPath S, opts ...Option) (*Server, E)
- type B
- type Ctx
- type E
- type Listener
- type N
- type Notice
- type Option
- type Options
- type S
- type Server
- func (s *Server) HandleAdmin(w http.ResponseWriter, r *http.Request)
- func (s *Server) HandleNIP11(w http.ResponseWriter, r *http.Request)
- func (s *Server) HandleWebsocket(w http.ResponseWriter, r *http.Request)
- func (s *Server) Router() *http.ServeMux
- func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request)
- func (s *Server) Shutdown()
- func (s *Server) Start(host S, port int, adminHost S, adminPort int, started ...chan bool) E
Constants ¶
const AUTH_CONTEXT_KEY = iota
const ChallengeHRP = "nchal"
const ChallengeLength = 16
Variables ¶
This section is empty.
Functions ¶
func BroadcastEvent ¶ added in v1.0.5
func GetListeningFilters ¶ added in v1.0.5
Types ¶
type Option ¶ added in v1.0.5
type Option func(*Options)
func WithPerConnectionLimiter ¶ added in v1.0.5
type Options ¶ added in v1.0.5
type Options struct {
// contains filtered or unexported fields
}
func DefaultOptions ¶ added in v1.0.5
func DefaultOptions() *Options
type Server ¶
type Server struct { Ctx Cancel context.F Addr, AdminAddr S // contains filtered or unexported fields }
Server is a base for package users to implement nostr relays. It can serve HTTP requests and websockets, passing control over to a relay implementation.
To implement a relay, it is enough to satisfy [Relay] interface. Other interfaces are [Informationer], [CustomWebSocketHandler], [ShutdownAware] and AdvancedXxx types. See their respective doc comments.
The basic usage is to call Start or StartConf, which starts serving immediately. For a more fine-grained control, use NewServer.
func (*Server) HandleAdmin ¶ added in v1.0.16
func (s *Server) HandleAdmin(w http.ResponseWriter, r *http.Request)
func (*Server) HandleNIP11 ¶ added in v1.0.5
func (s *Server) HandleNIP11(w http.ResponseWriter, r *http.Request)
func (*Server) HandleWebsocket ¶ added in v1.0.5
func (s *Server) HandleWebsocket(w http.ResponseWriter, r *http.Request)
func (*Server) ServeHTTP ¶
func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request)
ServeHTTP implements http.Handler interface.
func (*Server) Shutdown ¶
func (s *Server) Shutdown()
Shutdown sends a websocket close control message to all connected clients.
If the realy is ShutdownAware, Shutdown calls its OnShutdown, passing the context as is. Note that the HTTP server make some time to shutdown and so the context deadline, if any, may have been shortened by the time OnShutdown is called.