1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/*
* This file is part of laurelin/api
* Copyright (C) 2023 Jonni Liljamo <jonni@liljamo.com>
*
* Licensed under GPL-3.0-only.
* See LICENSE for licensing information.
*/
use actix_session::Session;
use actix_web::HttpResponse;
use laurelin_shared::error::api::APIError;
pub(crate) fn validate_session(session: &Session) -> Result<String, HttpResponse> {
let user_id: Option<String> = session.get("user_id").unwrap_or(None);
match user_id {
None => Err(HttpResponse::Unauthorized().json(APIError::NotAuthorized)),
Some(id) => {
// keep alive
session.renew();
Ok(id)
}
}
}