Skip to content

Commit

Permalink
make headers thread safe
Browse files Browse the repository at this point in the history
add reader lock
  • Loading branch information
saksham-arya-z committed Nov 22, 2024
1 parent e46bd52 commit c2e744e
Showing 1 changed file with 7 additions and 0 deletions.
7 changes: 7 additions & 0 deletions context.go
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,9 @@ type Context struct {
// This mutex protects Keys map.
mu sync.RWMutex

// This mutex protects headers map
hmu sync.RWMutex

// Keys is a key/value pair exclusively for the context of each request.
Keys map[string]any

Expand Down Expand Up @@ -983,6 +986,8 @@ func (c *Context) Status(code int) {
// It writes a header in the response.
// If value == "", this method removes the header `c.Writer.Header().Del(key)`
func (c *Context) Header(key, value string) {
c.hmu.Lock()
defer c.hmu.Unlock()
if value == "" {
c.Writer.Header().Del(key)
return
Expand All @@ -992,6 +997,8 @@ func (c *Context) Header(key, value string) {

// GetHeader returns value from request headers.
func (c *Context) GetHeader(key string) string {
c.hmu.RLock()
defer c.hmu.RUnlock()
return c.requestHeader(key)
}

Expand Down

0 comments on commit c2e744e

Please sign in to comment.