summaryrefslogtreecommitdiff
path: root/backend/src/API
diff options
context:
space:
mode:
authorphyscik <mynameisgennadiy@vk.com>2026-04-14 17:04:21 +0500
committerphyscik <mynameisgennadiy@vk.com>2026-04-14 17:04:21 +0500
commite21c194861198f298af34ac07032c04979ac5c1e (patch)
tree5e664ef5a35dca60366c3ff332617239c11622e1 /backend/src/API
parentb88d91870d40a84ad6941b2394838d6784f81db2 (diff)
get ranged weapons by id
Diffstat (limited to 'backend/src/API')
-rw-r--r--backend/src/API/WeaponsAPI.zig23
1 files changed, 14 insertions, 9 deletions
diff --git a/backend/src/API/WeaponsAPI.zig b/backend/src/API/WeaponsAPI.zig
index 6c24721..d095944 100644
--- a/backend/src/API/WeaponsAPI.zig
+++ b/backend/src/API/WeaponsAPI.zig
@@ -6,8 +6,8 @@ const db = @import("../Database/Connection.zig");
pub fn RegisterEndpoints(router: *httpz.Router(void, *const fn (*httpz.request.Request, *httpz.response.Response) anyerror!void)) void {
router.get("/weapons", testEndpoint, .{});
router.post("/weapons/ranged", newRangedWeapon, .{});
+ router.get("/weapons/ranged/:id", getRangedWeaponById, .{});
router.get("/weapons/ranged", getAllRangedWeapons, .{});
- // router.get("/weapons/ranged/:id", getAllRangedWeapons, .{});
}
fn testEndpoint(_: *httpz.Request, res: *httpz.Response) !void {
@@ -31,13 +31,9 @@ fn testEndpoint(_: *httpz.Request, res: *httpz.Response) !void {
try res.json(testType, .{});
}
-fn getAllRangedWeapons(_: *httpz.Request, res: *httpz.Response) !void {
- var gpa = std.heap.GeneralPurposeAllocator(.{}){};
- const allocator = gpa.allocator();
- defer _ = gpa.deinit();
-
- var found = try db.RangedWeapons.GetAll(allocator);
- defer found.deinit(allocator);
+fn getAllRangedWeapons(req: *httpz.Request, res: *httpz.Response) !void {
+ var found = try db.RangedWeapons.GetAll(req.arena);
+ defer found.deinit(req.arena);
try res.json(found.items, .{});
}
@@ -48,7 +44,16 @@ fn getRangedWeaponById(req: *httpz.Request, res: *httpz.Response) !void {
return;
};
- _ = id;
+ const found = db.RangedWeapons.GetByDisplayName(req.arena, id) catch |err| {
+ // Empty result handling
+ if (err == db.ResultErrors.NotFound) {
+ res.status = 204;
+ return;
+ }
+ return err;
+ };
+
+ try res.json(found, .{});
}
fn newRangedWeapon(req: *httpz.Request, res: *httpz.Response) !void {