summaryrefslogtreecommitdiff
path: root/service/http
diff options
context:
space:
mode:
Diffstat (limited to 'service/http')
-rw-r--r--service/http/service.go12
-rw-r--r--service/http/service_test.go15
2 files changed, 14 insertions, 13 deletions
diff --git a/service/http/service.go b/service/http/service.go
index 460175b9..710cd60c 100644
--- a/service/http/service.go
+++ b/service/http/service.go
@@ -13,8 +13,8 @@ import (
// ID contains default svc name.
const ID = "http"
-// must return true if request/response pair is handled within the middleware.
-type middleware func(w http.ResponseWriter, r *http.Request) bool
+// http middleware type.
+type middleware func(f http.HandlerFunc) http.HandlerFunc
// Service manages rr, http servers.
type Service struct {
@@ -114,13 +114,13 @@ func (s *Service) Stop() {
// middleware handles connection using set of mdws and rr PSR-7 server.
func (s *Service) ServeHTTP(w http.ResponseWriter, r *http.Request) {
r = InitAttributes(r)
+
+ f := s.srv.ServeHTTP
for _, m := range s.mdws {
- if m(w, r) {
- return
- }
+ f = m(f)
}
- s.srv.ServeHTTP(w, r)
+ f(w, r)
}
func (s *Service) listener(event int, ctx interface{}) {
diff --git a/service/http/service_test.go b/service/http/service_test.go
index 02d1c3f0..50836b4b 100644
--- a/service/http/service_test.go
+++ b/service/http/service_test.go
@@ -253,14 +253,15 @@ func Test_Service_Middleware(t *testing.T) {
assert.NotNil(t, s)
assert.Equal(t, service.StatusConfigured, st)
- s.(*Service).AddMiddleware(func(w http.ResponseWriter, r *http.Request) bool {
- if r.URL.Path == "/halt" {
- w.WriteHeader(500)
- w.Write([]byte("halted"))
- return true
+ s.(*Service).AddMiddleware(func(f http.HandlerFunc) http.HandlerFunc {
+ return func(w http.ResponseWriter, r *http.Request) {
+ if r.URL.Path == "/halt" {
+ w.WriteHeader(500)
+ w.Write([]byte("halted"))
+ } else {
+ f(w, r)
+ }
}
-
- return false
})
go func() { c.Serve() }()