DEVELOPMENT ENVIRONMENT

~liljamo/deck-builder

ref: 87f3f31d9d46d0ac597b7c6d58c1b5c36d21aa1a deck-builder/api/src/session.rs -rw-r--r-- 653 bytes
87f3f31dJonni Liljamo feat(schema, shared, api): move all types to shared, separate schema 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)
        }
    }
}