420 Commits

Author SHA1 Message Date
Bob Farrell
b7d750c54f Formalise JetKV interface for store, cache, jobs
Provide configuration for JetKV backend (memory or file allocator).
2024-05-05 12:27:59 +01:00
Bob Farrell
19da5362cf Merge branch 'fix-session-nonce-re-use' 2024-05-02 18:50:52 +01:00
Bob Farrell
439a0c1206 Add bounds check for session decrypt data 2024-05-02 18:48:47 +01:00
Bob Farrell
33a1596238 Remove debug print 2024-05-01 21:30:53 +01:00
bobf
06675dccb8
Merge pull request #62 from jetzig-framework/fix-session-nonce-re-use
Fix session nonce re-use
2024-05-01 21:16:30 +01:00
Bob Farrell
1ea3f6c4ff Fix session nonce re-use
Use a new secure-random nonce for each session encryption.

Many thanks to @Trundle for writing [this gist](https://gist.github.com/Trundle/76c0d8f80999617f4d8373c03f86391a)
highlighting the severity of this issue.
2024-05-01 20:51:39 +01:00
Bob Farrell
3c88d845a8 Catch error.BrokenPipe and close connection
Users have reported this error occurring occasionally, close connection
and continue processing requests when it occurs.
2024-04-29 18:58:07 +01:00
Bob Farrell
ca153eb82c Initialize request with default status code .not_found
Avoid loading an undefined error code if `/errors` view is requested
directly.
2024-04-28 15:13:57 +01:00
bobf
f55a3278ce
Merge pull request #60 from jetzig-framework/custom-error-pages
Custom error pages
2024-04-28 12:01:29 +01:00
Bob Farrell
1c7df8a91d Custom error pages
Render `src/app/views/errors.zig` view (`index` action) when an
unexpected error occurs. If the view does not exist, try rendering
`public/404.html`, `public/500.html` (etc.), finally falling back to a
standard basic HTML/JSON response.
2024-04-28 11:54:05 +01:00
bobf
0c450ff9b0
Merge pull request #59 from jetzig-framework/zmpl-markdown-mode-formatters
Update Zmpl, adds Markdown mode formatters
2024-04-27 23:37:05 +01:00
Bob Farrell
6b940e8a53 0.13 support
Add support for 0.13. For now, we can be compatible with both 0.12 and
0.13. We will drop 0.12 after a while.
2024-04-27 23:03:53 +01:00
Bob Farrell
9d12b5c717 Update Zmpl, adds Markdown mode formatters
Also adds support for `.md.zmpl` templates - root node is Markdown.
2024-04-27 22:22:30 +01:00
bobf
3c47435fd6
Merge pull request #58 from jetzig-framework/email
Email framework
2024-04-21 21:14:44 +01:00
Bob Farrell
47c35632b5 Email framework
Create mailers with `jetzig generate mailer <name>`. Mailers define
default values for email fields (e.g. subject, from address, etc.).
Mailers use Zmpl for rendering text/HTML parts.

Send an email from a request with `request.mail()`. Call
`deliver(.background, .{})` on the return value to use the built-in
mail job to send the email asynchronously.

Improve query/HTTP request body param parsing - unescape `+` and `%XX`
characters.
2024-04-21 21:00:03 +01:00
Bob Farrell
3f6c1a4919 Remove temporary test file 2024-04-15 21:16:02 +01:00
bobf
ba0e488894
Merge pull request #56 from jetzig-framework/background-jobs
Background jobs
2024-04-15 21:06:48 +01:00
Bob Farrell
0c7a11497f Background jobs
Use in-memory KV store (JetKV) for simple job queue.

Build script generates an array of Zig modules in `src/app/jobs/` and
stores their name + run function (`run(allocator, params, logger)`).

View functions schedule jobs with arbitrary params.

Thread pool spawns a (configurable) number of workers and pops jobs from
the queue, then invokes the appropriate run function.
2024-04-15 18:12:40 +01:00
Bob Farrell
25587d4258 Update Zmpl - add support for one-liner slots rendering
```
{{slots}}
```
will render all slots `\n`-separated.
2024-04-13 20:11:44 +01:00
Bob Farrell
0b968c3b44 Minor improvements to request params and headers
Fully disambiguate request params from body and query string and clean
up convoluted code, reduce allocs. Implement
`jetzig.http.Request.queryParams` which always returns only the parsed
query string, never the request body.

Deprecate `headers.getFirstValue` in favour of `headers.get`, implement
`headers.getAll`.
2024-04-13 19:24:40 +01:00
Bob Farrell
4de9f4d248 Update zmpl/zmd - code/block bugfixes 2024-04-13 11:22:02 +01:00
Bob Farrell
b42d0411c1 Update Zmpl and zmd - misc zmd bugfixes 2024-04-12 21:54:41 +01:00
Bob Farrell
2c81c64c93 Update Zmpl - sync zmd versions 2024-04-11 20:50:06 +01:00
Bob Farrell
d5c7f97036 Update zmd - fixes parenthesis parsing 2024-04-11 20:47:38 +01:00
Bob Farrell
88abe2243d Update Zmpl
Numerous fixes and improvements to v2 parser.
2024-04-10 22:06:11 +01:00
Bob Farrell
1cf3dcc106 Update zmpl and zmd - misc. markdown fixes 2024-04-07 21:54:25 +01:00
Bob Farrell
68ca4d3bba jetzig bundle improvements
Generate a bundle that includes markdown files (needed for dynamic
markdown rendering). In future these will be compiled into static
outputs by the bundle command but for now we copy them into the source
tree. `bundle.tar.gz` includes one directory which is named after the
compiled exe, containing a `server` executable, `public` and `static`
directories, and any markdown files.

Windows support removed for now - will re-add when we overhaul all of
this to no longer do command line invocation of `tar` (we will build
tarball/Zip file ourselves).
2024-04-07 15:47:15 +01:00
Bob Farrell
a85389a199 Update Zmpl
Misc. minor bugfixes
2024-04-07 12:20:34 +01:00
bobf
b59292307c
Merge pull request #55 from jetzig-framework/zmpl-v2
Zmpl v2
2024-04-07 10:37:13 +01:00
Bob Farrell
16204a4832 Zmpl v2
Update to Zmpl v2, update demo app to be compatible with v2 syntax. Add
deprecation warning for v1 (v1 is default for now - will force v2 soon).
2024-04-07 10:34:34 +01:00
bobf
8096962cf6
Merge pull request #54 from jetzig-framework/empty-http-params
Closes #53: Add support for empty HTTP query param
2024-04-06 20:49:23 +01:00
Bob Farrell
4579d6c029 Closes #53: Add support for empty HTTP query param
When query param is empty, use `jetzig.data.Data.NullType` - this way
the value is still non-null (i.e. can be captured) and is still a
`jetzig.data.Value` so is consistent with previous implementation.

Add very weird bugfix for 404 responses.

Fix `Bad Request` response code.
2024-04-06 20:20:47 +01:00
bobf
31e8ae36e1
Merge pull request #51 from jetzig-framework/disable-colors-on-windows
Disable colors on Windows
2024-04-03 19:24:56 +01:00
Bob Farrell
336b80ed77 Disable colors on Windows
Too many unknowns trying to make this work reliably on Windows so just
disabling now to declutter output, we can re-enable later and do it
properly.
2024-04-03 19:11:40 +01:00
bobf
36fc3919fd
Merge pull request #50 from jetzig-framework/fix-UAF-in-static-routes
Fix UAF in static routes
2024-04-03 19:03:45 +01:00
Bob Farrell
605c85ca97 Fix UAF in static routes
Dupe resource ID before freeing Data memory.
2024-04-03 18:49:32 +01:00
Bob Farrell
cd4932ff79 Use view_name correctly 2024-04-02 22:39:52 +01:00
Bob Farrell
f1ec5b216d Force unix-style path for view name
Windows compat.
2024-04-02 22:30:21 +01:00
Bob Farrell
eed58edeba Allow responding to HTML when no template present
If no template present, allow the request to render the view and then
only render a 404 if the view does not redirect, otherwise all views
would need a placeholder Zmpl template even if the view does not use it.

Also parse HTTP body as query string if present.
2024-04-02 22:15:18 +01:00
bobf
b94845a415
Merge pull request #49 from jetzig-framework/simplify-route-generation
Simplify route generation
2024-04-02 21:11:00 +01:00
Bob Farrell
116668be3e Closes #48: Simplify route generation
Generate an array of `jetzig.views.Route` in `GenerateRoutes.zig` exe
instead of a meta-route that we later translate into an actual route.
This makes things much simpler for static routes at build time and
dynamic routes at run time as we no longer need to use comptime - we
just have an array of routes ready-made.
2024-04-02 21:02:27 +01:00
bobf
800b72eeb9
Merge pull request #47 from jetzig-framework/auto-routing-markdown
Auto routing markdown
2024-03-29 08:54:04 +00:00
Bob Farrell
ec045cccd6 Add environments, use pretty-printed JSON in development
Fix secret generation - overallocate length to ensure we have enough
bytes.

Error if no secret provided in production mode.
2024-03-28 22:39:58 +00:00
Bob Farrell
95a8330629 Refactor rendering
Render appropriately-formatted errors for HTML/JSON.
2024-03-28 22:39:27 +00:00
Bob Farrell
625257bcfc Allow auto-routing to markdown files
If a route isn't matched but the URI can match directly to a markdown
file, render it directly. This allows putting arbitrary markdown files
in e.g. `/foo/bar/abc.md`, `/foo/bar/def.md` and rendering them as
`/foo/bar/abc.html`, `/foo/bar/def.html`. Since markdown are static
content only (i.e. no template data etc.) it makes sense for them to be
renderable without needing to create a view for each one.
2024-03-28 22:09:29 +00:00
bobf
c2cc9c50f2
Merge pull request #46 from jetzig-framework/replicate-exe-imports
Replicate exe imports
2024-03-28 21:54:14 +00:00
Bob Farrell
29d13917a6 Add a dependency to demo app
Use as a regression test to ensure dependencies always work.
2024-03-28 21:07:16 +00:00
Bob Farrell
e4709e0c73 Replicate exe imports in routes and static routes generator
Allow using dependencies added to main exe in views.
2024-03-28 19:42:36 +00:00
rimuspp
a702d1235b
Merge pull request #45 from axispx/cli-reload
Print message when server detects changes after build failure
2024-03-28 00:07:53 -05:00
axispx
397e76b2d0 Print message when server detects changes after build failure 2024-03-28 10:00:17 +05:45