zuletzt/src/app/views/search.zig
2024-04-10 23:48:22 -04:00

50 lines
1.7 KiB
Zig

const std = @import("std");
const jetzig = @import("jetzig");
const queries = @import("../lib/db.zig");
const sqlite = @import("sqlite");
pub fn index(request: *jetzig.Request, data: *jetzig.Data) !jetzig.View {
var root = try data.array();
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
const allocator = gpa.allocator();
var arena = std.heap.ArenaAllocator.init(allocator);
defer arena.deinit();
var db = try sqlite.Db.init(.{
.mode = sqlite.Db.Mode{ .File = "/home/swebb/Source/zuletzt/src/app/database/data.db" },
.open_flags = .{
.write = true,
.create = true,
},
.threading_mode = .MultiThread,
});
const params = try request.params();
const queryOrNull: ?[]const u8 = if (params.get("q")) |param| param.string.value else null;
if (queryOrNull) |query| {
// sql.search(query, db);
var artistSearch = try db.prepare(queries.getArtistSearch);
defer artistSearch.deinit();
const artistResults = try artistSearch.all(
struct {
artist: []u8,
url: []u8,
},
arena.allocator(),
.{},
.{ .artist = query },
);
for (artistResults) |r| {
std.log.debug("artist: {s}, url: {s}", .{ r.artist, r.url });
try root.append(data.string(r.artist));
try root.append(data.string(r.url));
//std.log.debug("{s}", .{r});
}
} else {
return request.render(.bad_request);
}
//const query = params.get("q");
//try root.put("q",query);
//try root.put("q", data.string("Welcome"));
return request.render(.ok);
}