diff options
| author | physcik <mynameisgennadiy@vk.com> | 2026-04-14 15:49:44 +0500 |
|---|---|---|
| committer | physcik <mynameisgennadiy@vk.com> | 2026-04-14 15:49:44 +0500 |
| commit | 075872c98fbd9a19e684a18b24f471bc1f78d1b1 (patch) | |
| tree | b89ccdb5a326b046d448c9f6e36de40306096f47 /backend/src/API/WeaponsAPI.zig | |
| parent | cc133dd2e36c9eee7f04a29322e5a18181971189 (diff) | |
ranged weapons db connection
Diffstat (limited to 'backend/src/API/WeaponsAPI.zig')
| -rw-r--r-- | backend/src/API/WeaponsAPI.zig | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/backend/src/API/WeaponsAPI.zig b/backend/src/API/WeaponsAPI.zig index 65e3fe8..d2bb15a 100644 --- a/backend/src/API/WeaponsAPI.zig +++ b/backend/src/API/WeaponsAPI.zig @@ -1,12 +1,17 @@ +const std = @import("std"); const httpz = @import("httpz"); const model = @import("../Models/RangedWeapon.zig"); +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", getAllRangedWeapons, .{}); } fn testEndpoint(_: *httpz.Request, res: *httpz.Response) !void { const testType: model.RangedWeaponType = .{ + .Id = 0, .Name = "BudgetArms C-13", .WeaponType = "P", .Accuracy = -1, @@ -16,9 +21,30 @@ fn testEndpoint(_: *httpz.Request, res: *httpz.Response) !void { .Ammunition = "5mm", .NumberOfShots = 8, .RateOfFire = 2, - .Reliability = "ST" + .Reliability = "ST", + .CreatedAt = 0, + .UpdatedAt = 0, }; res.status = 200; 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); + + try res.json(found.items, .{}); +} + +fn newRangedWeapon(req: *httpz.Request, res: *httpz.Response) !void { + if (try req.json(model.RangedWeaponType)) |new| { + try res.json(new, .{}); + return; + } + res.status = 502; +} |
