From 655fb6c4cc180dfcbc13c1b85e0fbf47019caec0 Mon Sep 17 00:00:00 2001 From: mo khan Date: Tue, 15 Apr 2025 17:46:34 -0600 Subject: feat: create session cookie tied to access token --- pkg/web/cookie/reset.go | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 pkg/web/cookie/reset.go (limited to 'pkg/web/cookie/reset.go') diff --git a/pkg/web/cookie/reset.go b/pkg/web/cookie/reset.go new file mode 100644 index 0000000..1686343 --- /dev/null +++ b/pkg/web/cookie/reset.go @@ -0,0 +1,36 @@ +package cookie + +import ( + "net/http" + "time" + + "github.com/xlgmokha/x/pkg/env" +) + +func Reset(name string) *http.Cookie { + return Clear(&http.Cookie{ + Name: name, + }) +} + +func Expire(w http.ResponseWriter, r *http.Request, name string) { + cookie, err := r.Cookie(name) + if err != nil { + http.SetCookie(w, Reset(name)) + } else { + Clear(cookie) + http.SetCookie(w, cookie) + } +} + +func Clear(cookie *http.Cookie) *http.Cookie { + cookie.Value = "" + cookie.Expires = time.Unix(0, 0) + cookie.MaxAge = -1 + cookie.Path = "/" + cookie.HttpOnly = true + cookie.Secure = true + cookie.SameSite = http.SameSiteNoneMode + cookie.Domain = env.Fetch("HOST", "localhost") + return cookie +} -- cgit v1.2.3