diff options
author | Wolfy-J <[email protected]> | 2018-06-13 00:12:17 +0300 |
---|---|---|
committer | Wolfy-J <[email protected]> | 2018-06-13 00:12:17 +0300 |
commit | 9786e79d05beede8c8d21d9281623ff8b2388b08 (patch) | |
tree | 9fbcff6554ca83158b3af9b0595e4b9f295bd018 /service/http/handler.go | |
parent | 01f4eaa5678d366de55b84dd0b0b4186c47f6dc5 (diff) |
better multithread control
Diffstat (limited to 'service/http/handler.go')
-rw-r--r-- | service/http/handler.go | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/service/http/handler.go b/service/http/handler.go index 1df00e5a..8c604127 100644 --- a/service/http/handler.go +++ b/service/http/handler.go @@ -5,6 +5,7 @@ import ( "strconv" "github.com/spiral/roadrunner" "github.com/pkg/errors" + "sync" ) const ( @@ -33,14 +34,18 @@ type Event struct { // Handler serves http connections to underlying PHP application using PSR-7 protocol. Context will include request headers, // parsed files and query, payload will include parsed form dataTree (if any). type Handler struct { - cfg *Config - listener func(event int, ctx interface{}) - rr *roadrunner.Server + cfg *Config + rr *roadrunner.Server + mul sync.Mutex + lsn func(event int, ctx interface{}) } // AddListener attaches pool event watcher. func (h *Handler) Listen(l func(event int, ctx interface{})) { - h.listener = l + h.mul.Lock() + defer h.mul.Unlock() + + h.lsn = l } // Handle serve using PSR-7 requests passed to underlying application. Attempts to serve static files first if enabled. @@ -107,7 +112,11 @@ func (h *Handler) handleError(w http.ResponseWriter, r *http.Request, err error) // throw invokes event srv if any. func (h *Handler) throw(event int, ctx interface{}) { - if h.listener != nil { - h.listener(event, ctx) + h.mul.Lock() + lsn := h.lsn + h.mul.Unlock() + + if lsn != nil { + lsn(event, ctx) } } |