DEVELOPMENT ENVIRONMENT

~liljamo/deck-builder

ref: 5b6558cd0dc6791d7504f28428324a5022a78178 deck-builder/api/src/session.rs -rw-r--r-- 653 bytes
5b6558cdJonni Liljamo feat(client, server): finally handle AfterAuth properly 1 year, 9 months ago
                                                                                
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)
        }
    }
}