1
0
Fork 0
mirror of https://github.com/zigzap/zap.git synced 2025-10-20 15:14:08 +00:00

Compare commits

..

2 commits

Author SHA1 Message Date
Rene Schallner
302f1e1e44
Merge pull request #174 from pollend/feature/tweak-support-cookies
feat: tweak support for additional cookie fields
2025-08-28 10:45:30 +02:00
Michael Pollind
512c630781 feat: tweak support for additional cookie fields
Signed-off-by: Michael Pollind <mpollind@gmail.com>
2025-08-10 18:59:27 -07:00
4 changed files with 45 additions and 10 deletions

View file

@ -317,12 +317,20 @@ int http_set_cookie(http_s *h, http_cookie_args_s cookie) {
if (cookie.http_only) { if (cookie.http_only) {
fiobj_str_write(c, "HttpOnly;", 9); fiobj_str_write(c, "HttpOnly;", 9);
} }
if (cookie.secure) {
fiobj_str_write(c, "secure;", 7);
}
if(cookie.partitioned) { if(cookie.partitioned) {
fiobj_str_write(c, "Partitioned;", 12); fiobj_str_write(c, "Partitioned;", 12);
} }
if(cookie.same_site == HTTP_COOKIE_SAME_SITE_LAX) {
fiobj_str_write(c, "SameSite=Lax;", 13);
} else if (cookie.same_site == HTTP_COOKIE_SAME_SITE_STRICT) {
fiobj_str_write(c, "SameSite=Strict;", 16);
} else if (cookie.same_site == HTTP_COOKIE_SAME_SITE_NONE) {
fiobj_str_write(c, "SameSite=None;", 14);
}
if (cookie.secure) {
fiobj_str_write(c, "secure;", 7);
}
set_header_add(h->private_data.out_headers, HTTP_HEADER_SET_COOKIE, c); set_header_add(h->private_data.out_headers, HTTP_HEADER_SET_COOKIE, c);
return 0; return 0;
} }

View file

@ -58,6 +58,7 @@ Compile Time Settings
#define FIO_HTTP_EXACT_LOGGING 0 #define FIO_HTTP_EXACT_LOGGING 0
#endif #endif
/** the `http_listen settings, see details in the struct definition. */ /** the `http_listen settings, see details in the struct definition. */
typedef struct http_settings_s http_settings_s; typedef struct http_settings_s http_settings_s;
@ -120,6 +121,16 @@ typedef struct {
void *udata; void *udata;
} http_s; } http_s;
/**
* This determins the SameSite attribute of a cookie.
*/
typedef enum {
HTTP_COOKIE_SAME_SITE_DEFAULT,
HTTP_COOKIE_SAME_SITE_LAX,
HTTP_COOKIE_SAME_SITE_STRICT,
HTTP_COOKIE_SAME_SITE_NONE
} http_cookie_same_site_e;
/** /**
* This is a helper for setting cookie data. * This is a helper for setting cookie data.
@ -155,6 +166,8 @@ typedef struct {
unsigned http_only : 1; unsigned http_only : 1;
/** Partitioned storage, with a separate cookie jar per top-level site */ /** Partitioned storage, with a separate cookie jar per top-level site */
unsigned partitioned: 1; unsigned partitioned: 1;
/** The SameSite attribute, see `http_cookie_same_site_e` for details. */
unsigned same_site : 3;
} http_cookie_args_s; } http_cookie_args_s;
/** /**

View file

@ -103,7 +103,7 @@ pub const http_s = extern struct {
// unsigned http_only : 1; // unsigned http_only : 1;
// } http_cookie_args_s; // } http_cookie_args_s;
pub const http_cookie_args_s = extern struct { pub const http_cookie_args_s = extern struct {
name: [*c]u8, name: [*c]u8,
value: [*c]u8, value: [*c]u8,
domain: [*c]u8, domain: [*c]u8,
@ -114,9 +114,7 @@ pub const http_cookie_args_s = extern struct {
path_len: isize, path_len: isize,
/// in seconds /// in seconds
max_age: c_int, max_age: c_int,
secure: c_uint, flags: c_uint,
http_only: c_uint,
partitioned: c_uint,
}; };
pub const struct_fio_str_info_s = extern struct { pub const struct_fio_str_info_s = extern struct {

View file

@ -263,6 +263,13 @@ pub fn fiobj2HttpParam(a: Allocator, o: fio.FIOBJ) !?HttpParam {
}; };
} }
pub const CookieSameSite = enum(u8) {
Default,
Lax,
Strict,
None
};
/// Args for setting a cookie /// Args for setting a cookie
pub const CookieArgs = struct { pub const CookieArgs = struct {
name: []const u8, name: []const u8,
@ -274,6 +281,7 @@ pub const CookieArgs = struct {
secure: bool = true, secure: bool = true,
http_only: bool = true, http_only: bool = true,
partitioned: bool = false, partitioned: bool = false,
same_site: CookieSameSite = .Default,
}; };
path: ?[]const u8, path: ?[]const u8,
@ -682,9 +690,17 @@ pub fn setCookie(self: *const Request, args: CookieArgs) HttpError!void {
.path = if (args.path) |p| util.toCharPtr(p) else null, .path = if (args.path) |p| util.toCharPtr(p) else null,
.path_len = if (args.path) |p| @as(isize, @intCast(p.len)) else 0, .path_len = if (args.path) |p| @as(isize, @intCast(p.len)) else 0,
.max_age = args.max_age_s, .max_age = args.max_age_s,
.secure = if (args.secure) 1 else 0, .flags = (
.http_only = if (args.http_only) 1 else 0, ((if (args.secure) @as(c_uint,1) else 0) << 0) |
.partitioned = if (args.partitioned) 1 else 0, ((if (args.http_only) @as(c_uint,1) else 0) << 1) |
((if (args.partitioned) @as(c_uint,1) else 0) << 2) |
((switch (args.same_site) {
.Default => @as(c_uint, 0),
.Lax => @as(c_uint,1),
.Strict => @as(c_uint,2),
.None => @as(c_uint,3)
}) << 3)
)
}; };
// TODO WAT? // TODO WAT?