aboutsummaryrefslogtreecommitdiff
path: root/src/routes
diff options
context:
space:
mode:
Diffstat (limited to 'src/routes')
-rw-r--r--src/routes/api/auth/create-user.zig29
-rw-r--r--src/routes/api/auth/root.zig1
-rw-r--r--src/routes/handler-info.zig10
3 files changed, 39 insertions, 1 deletions
diff --git a/src/routes/api/auth/create-user.zig b/src/routes/api/auth/create-user.zig
new file mode 100644
index 0000000..6bd9a82
--- /dev/null
+++ b/src/routes/api/auth/create-user.zig
@@ -0,0 +1,29 @@
+const std = @import("std");
+
+const memora = @import("memora");
+const Context = memora.Context;
+const Storage = memora.Storage;
+
+pub const access = .admins;
+
+pub const Body = struct {
+ name: []const u8,
+ full_name: []const u8,
+ birthday: []const u8,
+ password: []const u8,
+};
+
+pub fn post(ctx: *Context, body: Body) anyerror!void {
+ var user = try Storage.User.new(
+ ctx.storage,
+ body.name,
+ body.full_name,
+ body.birthday,
+ body.password,
+ false,
+ ctx.storage.allocator,
+ );
+ defer user.deinit();
+
+ try user.sync();
+}
diff --git a/src/routes/api/auth/root.zig b/src/routes/api/auth/root.zig
index 5f45891..fa93c92 100644
--- a/src/routes/api/auth/root.zig
+++ b/src/routes/api/auth/root.zig
@@ -2,3 +2,4 @@ const HandlerInfo = @import("../../handler-info.zig");
pub const login: HandlerInfo = .from_type(@import("login.zig"));
pub const @"first-login": HandlerInfo = .from_type(@import("first-login.zig"));
+pub const @"create-user": HandlerInfo = .from_type(@import("create-user.zig"));
diff --git a/src/routes/handler-info.zig b/src/routes/handler-info.zig
index 5183628..9e10bd5 100644
--- a/src/routes/handler-info.zig
+++ b/src/routes/handler-info.zig
@@ -122,6 +122,11 @@ pub fn handle(
.value = context.response.headers.content_type
});
+ try headers.append(allocator, .{
+ .name = "Service-Worker-Allowed",
+ .value = "/",
+ });
+
if (context.response.headers.fingerprint) |auth_token| {
var value = std.Io.Writer.Allocating.init(arena.allocator());
@@ -176,7 +181,10 @@ fn HandlerWrapper(T: type, name: []const u8) type {
ctx.allocator,
writer.written(),
.{},
- ) catch return error.BadRequest;
+ ) catch |err| {
+ log.warn("failed to parse JSON {}", .{err});
+ return error.BadRequest;
+ };
break :args .{ ctx, body };
} else {
@compileError("invalid amount of arguments for request function");