1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
// SPDX-License-Identifier: AGPL-3.0-only
// SPDX-FileCopyrightText: Copyright (c) 2025 Runxi Yu <https://runxiyu.org>
use fmt;
use htmpl;
use io;
use net::http;
use net::uri;
use strconv;
use strings;
fn handlereq(conn: io::handle, request: *http::request) (void | io::error | nomem | uri::invalid) = {
let segments = segments_from_path(request.target.raw_path)?;
defer strings::freeall(segments);
let trailing_slash: bool = false;
if (segments[len(segments) - 1] == "") {
trailing_slash = true;
free(segments[len(segments) - 1]);
segments = segments[.. len(segments) - 1];
};
if (len(segments) == 0) {
start_response(conn, 200, "text/html")?;
return tp_index(conn, segments);
};
if (segments[0] == ":") {
if (len(segments) == 1) {
start_response(conn, 404, "text/plain")?;
fmt::fprintln(conn, "Error: Blank system endpoint")?;
};
};
};
fn start_response(conn: io::handle, status: uint, content_type: str) (void | io::error | nomem) = { // TODO: add len and other headers
fmt::fprint(conn, "HTTP/1.1 ")?;
fmt::fprint(conn, strconv::utos(status))?;
fmt::fprint(conn, " ")?;
fmt::fprint(conn, http::status_reason(status))?;
fmt::fprint(conn, "\r\n")?;
fmt::fprint(conn, "Content-Type: ")?;
fmt::fprint(conn, content_type)?;
fmt::fprint(conn, "\r\n")?;
fmt::fprint(conn, "\r\n")?;
};
|