summaryrefslogtreecommitdiff
path: root/service/http/service.go
diff options
context:
space:
mode:
Diffstat (limited to 'service/http/service.go')
-rw-r--r--service/http/service.go31
1 files changed, 24 insertions, 7 deletions
diff --git a/service/http/service.go b/service/http/service.go
index 5a0d4c16..c31c4a47 100644
--- a/service/http/service.go
+++ b/service/http/service.go
@@ -17,10 +17,11 @@ type Middleware interface {
// Service manages rr, http servers.
type Service struct {
- middleware []Middleware
cfg *Config
+ listener func(event int, ctx interface{})
+ middleware []Middleware
rr *roadrunner.Server
- handler *Handler
+ srv *Server
http *http.Server
}
@@ -28,6 +29,11 @@ func (s *Service) Add(m Middleware) {
s.middleware = append(s.middleware, m)
}
+// Listen attaches server event watcher.
+func (s *Service) Listen(o func(event int, ctx interface{})) {
+ s.listener = o
+}
+
// Configure must return configure service and return true if service hasStatus enabled. Must return error in case of
// misconfiguration. Services must not be used without proper configuration pushed first.
func (s *Service) Configure(cfg service.Config, c service.Container) (bool, error) {
@@ -56,11 +62,18 @@ func (s *Service) Serve() error {
}
defer s.rr.Stop()
- // todo: observer
-
s.rr = rr
- s.handler = &Handler{cfg: s.cfg, rr: s.rr}
- s.http = &http.Server{Addr: s.cfg.httpAddr(), Handler: s}
+ s.srv = &Server{cfg: s.cfg, rr: s.rr}
+ s.http = &http.Server{Addr: s.cfg.httpAddr()}
+
+ s.rr.Listen(s.listener)
+ s.srv.Listen(s.listener)
+
+ if len(s.middleware) == 0 {
+ s.http.Handler = s.srv
+ } else {
+ s.http.Handler = s
+ }
if err := s.http.ListenAndServe(); err != nil {
return err
@@ -71,6 +84,10 @@ func (s *Service) Serve() error {
// Stop stops the service.
func (s *Service) Stop() {
+ if s.http == nil {
+ return
+ }
+
s.http.Shutdown(context.Background())
}
@@ -82,5 +99,5 @@ func (s *Service) ServeHTTP(w http.ResponseWriter, r *http.Request) {
}
}
- s.handler.Handle(w, r)
+ s.srv.ServeHTTP(w, r)
}