Skip to content

Commit dc147d9

Browse files
committed
Fix #1523 by adding secure cookie if SameSite mode is None
1 parent cb15226 commit dc147d9

File tree

2 files changed

+43
-2
lines changed

2 files changed

+43
-2
lines changed

middleware/csrf.go

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -110,8 +110,8 @@ func CSRFWithConfig(config CSRFConfig) echo.MiddlewareFunc {
110110
if config.CookieMaxAge == 0 {
111111
config.CookieMaxAge = DefaultCSRFConfig.CookieMaxAge
112112
}
113-
if config.CookieSameSite == 0 {
114-
config.CookieSameSite = http.SameSiteDefaultMode
113+
if config.CookieSameSite == http.SameSiteNoneMode {
114+
config.CookieSecure = true
115115
}
116116

117117
// Initialize

middleware/csrf_test.go

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
package middleware
22

33
import (
4+
"fmt"
45
"net/http"
56
"net/http/httptest"
67
"net/url"
@@ -117,3 +118,43 @@ func TestCSRFWithoutSameSiteMode(t *testing.T) {
117118
assert.NoError(t, r)
118119
assert.NotRegexp(t, "SameSite=", rec.Header()["Set-Cookie"])
119120
}
121+
122+
func TestCSRFWithSameSiteDefaultMode(t *testing.T) {
123+
e := echo.New()
124+
req := httptest.NewRequest(http.MethodGet, "/", nil)
125+
rec := httptest.NewRecorder()
126+
c := e.NewContext(req, rec)
127+
128+
csrf := CSRFWithConfig(CSRFConfig{
129+
CookieSameSite: http.SameSiteDefaultMode,
130+
})
131+
132+
h := csrf(func(c echo.Context) error {
133+
return c.String(http.StatusOK, "test")
134+
})
135+
136+
r := h(c)
137+
assert.NoError(t, r)
138+
fmt.Println(rec.Header()["Set-Cookie"])
139+
assert.NotRegexp(t, "SameSite=", rec.Header()["Set-Cookie"])
140+
}
141+
142+
func TestCSRFWithSameSiteModeNone(t *testing.T) {
143+
e := echo.New()
144+
req := httptest.NewRequest(http.MethodGet, "/", nil)
145+
rec := httptest.NewRecorder()
146+
c := e.NewContext(req, rec)
147+
148+
csrf := CSRFWithConfig(CSRFConfig{
149+
CookieSameSite: http.SameSiteNoneMode,
150+
})
151+
152+
h := csrf(func(c echo.Context) error {
153+
return c.String(http.StatusOK, "test")
154+
})
155+
156+
r := h(c)
157+
assert.NoError(t, r)
158+
assert.Regexp(t, "SameSite=None", rec.Header()["Set-Cookie"])
159+
assert.Regexp(t, "Secure", rec.Header()["Set-Cookie"])
160+
}

0 commit comments

Comments
 (0)