aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNathan Reiner <nathan@nathanreiner.xyz>2025-11-24 21:13:47 +0100
committerNathan Reiner <nathan@nathanreiner.xyz>2025-11-24 21:17:05 +0100
commitf3756dac8a49f3b5599fd50f4c631da4168e9eb0 (patch)
treea84d95e30269d4b368b741ffd1a781b7cfbb1988 /src
parent97b35ce73fab8a84d4d3e6807618a252efcf4cd9 (diff)
add jump-to month
Diffstat (limited to 'src')
-rw-r--r--src/routes/api/auth/root.zig1
-rw-r--r--src/routes/api/profile/create.zig (renamed from src/routes/api/auth/create-user.zig)6
-rw-r--r--src/routes/api/profile/list.zig17
-rw-r--r--src/routes/api/profile/root.zig2
-rw-r--r--src/storage/user.zig18
5 files changed, 40 insertions, 4 deletions
diff --git a/src/routes/api/auth/root.zig b/src/routes/api/auth/root.zig
index fa93c92..5f45891 100644
--- a/src/routes/api/auth/root.zig
+++ b/src/routes/api/auth/root.zig
@@ -2,4 +2,3 @@ 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/api/auth/create-user.zig b/src/routes/api/profile/create.zig
index 6bd9a82..68f32ec 100644
--- a/src/routes/api/auth/create-user.zig
+++ b/src/routes/api/profile/create.zig
@@ -6,21 +6,21 @@ const Storage = memora.Storage;
pub const access = .admins;
-pub const Body = struct {
+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 {
+pub fn post(ctx: *Context, body: Body) !void {
var user = try Storage.User.new(
ctx.storage,
body.name,
body.full_name,
body.birthday,
body.password,
- false,
+ true,
ctx.storage.allocator,
);
defer user.deinit();
diff --git a/src/routes/api/profile/list.zig b/src/routes/api/profile/list.zig
new file mode 100644
index 0000000..59d4684
--- /dev/null
+++ b/src/routes/api/profile/list.zig
@@ -0,0 +1,17 @@
+const std = @import("std");
+
+const memora = @import("memora");
+const Context = memora.Context;
+const Storage = memora.Storage;
+
+pub const access = .admins;
+
+const Response = struct {
+ users: [][]const u8,
+};
+
+pub fn get(ctx: *Context) !Response {
+ return .{
+ .users = try Storage.User.list(ctx.storage, ctx.allocator)
+ };
+}
diff --git a/src/routes/api/profile/root.zig b/src/routes/api/profile/root.zig
index 0bdd064..45dec8e 100644
--- a/src/routes/api/profile/root.zig
+++ b/src/routes/api/profile/root.zig
@@ -4,3 +4,5 @@ const HandlerInfo = memora.routes.HandlerInfo;
pub const image = @import("image/root.zig");
pub const set: HandlerInfo = .from_type(@import("set.zig"));
pub const @"update-password": HandlerInfo = .from_type(@import("update-password.zig"));
+pub const create: HandlerInfo = .from_type(@import("create.zig"));
+pub const list: HandlerInfo = .from_type(@import("list.zig"));
diff --git a/src/storage/user.zig b/src/storage/user.zig
index b817f84..c2cc82a 100644
--- a/src/storage/user.zig
+++ b/src/storage/user.zig
@@ -214,3 +214,21 @@ pub fn set_image(
try file_writer.interface.flush();
}
+
+pub fn list(
+ storage: *Storage,
+ allocator: std.mem.Allocator,
+) ![][]const u8 {
+ var user = try storage.dir.openDir("user", .{ .iterate = true });
+ defer user.close();
+
+ var ids: std.ArrayList([]const u8) = .empty;
+
+ var iterator = user.iterate();
+
+ while (try iterator.next()) |entry| {
+ try ids.append(allocator, try allocator.dupe(u8, entry.name));
+ }
+
+ return ids.toOwnedSlice(allocator);
+}