fediglam/src/main/main.zig

102 lines
3.0 KiB
Zig
Raw Normal View History

2022-04-02 20:23:18 +00:00
const std = @import("std");
2022-07-09 22:07:51 +00:00
const http = @import("http");
2022-07-10 05:05:01 +00:00
const db = @import("./db2.zig");
// this thing is overcomplicated and weird. stop this
const Router = http.Router(*RequestServer);
const Route = Router.Route;
const RouteArgs = http.RouteArgs;
const router = Router{
.routes = &[_]Route{
Route.new(.POST, "/object", postObject),
Route.new(.GET, "/object/:id", getObject),
},
};
fn postObject(srv: *RequestServer, ctx: *http.server.Context, _: RouteArgs) !void {
const alloc = srv.alloc;
const headers = http.Headers.init(alloc);
var stream = try ctx.openResponse(&headers, .ok);
const writer = stream.writer();
defer stream.close();
try writer.print("Page for {s}\n", .{ctx.request.path});
const id = srv.doc_db.store(ctx.request.body.?);
try writer.print("{}", .{id});
try stream.finish();
}
fn getObject(srv: *RequestServer, ctx: *http.server.Context, args: RouteArgs) !void {
const alloc = srv.alloc;
const headers = http.Headers.init(alloc);
var stream = try ctx.openResponse(&headers, .ok);
const writer = stream.writer();
defer stream.close();
//try writer.print("id: {s}\n", .{args.get("id").?});
const id = try std.fmt.parseInt(u64, args.get("id").?, 10);
var doc_stream = (try srv.doc_db.getByLocalId(id)).?;
const doc = doc_stream.reader();
var buf: [1 << 8]u8 = undefined;
const count = try doc.readAll(&buf);
try writer.writeAll(buf[0..count]);
try stream.finish();
}
2022-04-23 07:11:40 +00:00
const RequestServer = struct {
2022-07-10 05:05:01 +00:00
alloc: std.mem.Allocator,
doc_db: db.DocDb,
fn init(alloc: std.mem.Allocator) RequestServer {
return RequestServer{
.alloc = alloc,
.doc_db = db.DocDb.init(alloc),
};
}
fn listenAndRun(self: *RequestServer, addr: std.net.Address) noreturn {
var srv = http.Server.listen(addr) catch unreachable;
defer srv.shutdown();
2022-04-04 03:36:32 +00:00
while (true) {
var buf: [1 << 20]u8 = undefined;
var fba = std.heap.FixedBufferAllocator.init(&buf);
const alloc = fba.allocator();
2022-04-02 20:23:18 +00:00
var ctx = srv.accept(alloc) catch unreachable;
defer ctx.close();
2022-04-21 09:34:04 +00:00
2022-07-10 05:05:01 +00:00
router.dispatch(self, &ctx, ctx.request.method, ctx.request.path) catch unreachable;
//handleRequest(alloc, &ctx) catch unreachable;
}
}
2022-04-02 20:23:18 +00:00
fn handleRequest(alloc: std.mem.Allocator, ctx: *http.server.Context) !void {
2022-07-09 22:07:51 +00:00
const headers = http.Headers.init(alloc);
2022-04-02 20:23:18 +00:00
2022-07-09 22:07:51 +00:00
var stream = try ctx.openResponse(&headers, .ok);
const writer = stream.writer();
defer stream.close();
try writer.print("Page for {s}\n", .{ctx.request.path});
if (ctx.request.body) |body| {
try writer.print("Echoing body: \n{s}", .{body});
}
2022-05-20 04:46:39 +00:00
2022-07-09 22:07:51 +00:00
try stream.finish();
}
};
pub fn main() anyerror!void {
2022-07-10 05:05:01 +00:00
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
var srv = RequestServer.init(gpa.allocator());
srv.listenAndRun(std.net.Address.parseIp("0.0.0.0", 8080) catch unreachable);
2022-05-20 04:46:39 +00:00
}