summaryrefslogtreecommitdiff
path: root/backend/src/Authentication
diff options
context:
space:
mode:
authorphyscik <mynameisgennadiy@vk.com>2026-04-20 21:52:20 +0500
committerphyscik <mynameisgennadiy@vk.com>2026-04-20 21:52:20 +0500
commitd46bf56209ca250fc4108af46375359652ba7fd8 (patch)
treee58eabb502abfe839ac839c39d2c92896d130b43 /backend/src/Authentication
parent6898919979c914be4c4650158fe0451a21349bb5 (diff)
Cleanup
Diffstat (limited to 'backend/src/Authentication')
-rw-r--r--backend/src/Authentication/Tokens.zig16
1 files changed, 10 insertions, 6 deletions
diff --git a/backend/src/Authentication/Tokens.zig b/backend/src/Authentication/Tokens.zig
index 37bfd5a..a20c200 100644
--- a/backend/src/Authentication/Tokens.zig
+++ b/backend/src/Authentication/Tokens.zig
@@ -8,6 +8,10 @@ const token_ttl: u16 = 43_200; // 12 hours
var prng: std.Random.DefaultPrng= undefined;
var rnd: std.Random = undefined;
+const errors = error {
+ NotFound,
+};
+
pub fn Init() !void {
// Random enough
var seed: u64 = undefined;
@@ -16,7 +20,7 @@ pub fn Init() !void {
rnd = prng.random();
}
-/// Generates a new token in the heap. Expects [64]u8 as an input
+/// Generates a new token in the stack. Expects [64]u8 as an input
fn generateSessionToken(buf: []u8) []u8 {
for (0..64) |i| {
buf[i] = std.Random.intRangeAtMost(rnd, u8, 'A', 'z');
@@ -34,7 +38,7 @@ pub fn GenerateNewSession(allocator: std.mem.Allocator, user: userModel.User) ![
// Redis cache
var string: std.io.Writer.Allocating = .init(allocator);
defer string.deinit();
- try string.writer.print("{f}", .{std.json.fmt(user, .{})});
+ try string.writer.print("{f}", .{ std.json.fmt(user, .{}) });
try redis.WriteToTopic(topicName, redis.Message {
.Key = token,
.Value = string.written(),
@@ -46,12 +50,12 @@ pub fn GenerateNewSession(allocator: std.mem.Allocator, user: userModel.User) ![
pub fn GetUserFromToken(allocator: std.mem.Allocator, token: []const u8) !?std.json.Parsed(userModel.User) {
const saved = try redis.ReadFromTopic(allocator, topicName, token) orelse {
- std.debug.print("The token was not found \n", .{});
- return null;
+ // std.debug.print("The token was not found \n", .{});
+ return errors.NotFound;
};
- std.debug.print("FromRedis: {s}\n", .{ saved });
+
const parsed = try std.json.parseFromSlice(
- userModel.User,
+ userModel.User,
allocator,
saved,
.{