mirror of
				https://github.com/zigzap/zap.git
				synced 2025-10-20 15:14:08 +00:00 
			
		
		
		
	Compare commits
	
		
			2 commits
		
	
	
		
			a953fc5969
			...
			302f1e1e44
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 302f1e1e44 | ||
|   | 512c630781 | 
					 4 changed files with 45 additions and 10 deletions
				
			
		|  | @ -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; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -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; | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|  |  | ||||||
|  | @ -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 { | ||||||
|  |  | ||||||
|  | @ -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? | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue