1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//! Session Management Module
//!
//! Provides multi-user session management, isolation levels, and resource quotas
//! for concurrent ACID transactions in HeliosDB-Lite.
//!
//! # Overview
//!
//! Sessions provide isolated execution contexts for database clients. Each session:
//!
//! - Has its own transaction isolation level
//! - Tracks usage statistics (queries, bytes read/written)
//! - Can be limited by resource quotas
//! - Times out after inactivity
//!
//! # Key Types
//!
//! - [`SessionId`] - Unique session identifier
//! - [`Session`] - Session state and statistics
//! - [`SessionManager`] - Manages active sessions
//! - [`IsolationLevel`] - Transaction isolation level
//! - [`User`] - User credentials with Argon2 password hashing
//!
//! # Example
//!
//! ```rust,no_run
//! use heliosdb_nano::EmbeddedDatabase;
//! use heliosdb_nano::session::IsolationLevel;
//!
//! # fn main() -> Result<(), Box<dyn std::error::Error>> {
//! let db = EmbeddedDatabase::new_in_memory()?;
//!
//! // Create a session for user
//! let session = db.create_session("alice", IsolationLevel::RepeatableRead)?;
//!
//! // Execute queries in session context
//! db.execute_in_session(session, "CREATE TABLE users (id INT)")?;
//! db.execute_in_session(session, "INSERT INTO users VALUES (1)")?;
//!
//! // Clean up
//! db.destroy_session(session)?;
//! # Ok(())
//! # }
//! ```
pub use ;
pub use ;