summaryrefslogtreecommitdiff
path: root/service/http/handler.go
diff options
context:
space:
mode:
authorWolfy-J <[email protected]>2018-06-13 00:12:17 +0300
committerWolfy-J <[email protected]>2018-06-13 00:12:17 +0300
commit9786e79d05beede8c8d21d9281623ff8b2388b08 (patch)
tree9fbcff6554ca83158b3af9b0595e4b9f295bd018 /service/http/handler.go
parent01f4eaa5678d366de55b84dd0b0b4186c47f6dc5 (diff)
better multithread control
Diffstat (limited to 'service/http/handler.go')
-rw-r--r--service/http/handler.go21
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)
}
}