use crate::context::Pkcs11;
use crate::error::Result;
use cryptoki_sys::*;
use std::cell::Cell;
use std::fmt::Formatter;
use std::marker::PhantomData;
mod decryption;
mod digesting;
mod encapsulation;
mod encryption;
mod key_management;
mod message_decryption;
mod message_encryption;
mod object_management;
mod random;
mod session_info;
mod session_management;
mod signing_macing;
mod slot_token_management;
mod validation;
pub use object_management::ObjectHandleIterator;
pub use session_info::{SessionInfo, SessionState};
pub use validation::ValidationFlagsType;
#[derive(Debug, PartialEq, Eq, Clone, Copy)]
pub(crate) enum CloseOnDrop {
AutomaticallyCloseSession,
DoNotClose,
}
#[derive(Debug)]
pub struct Session {
handle: CK_SESSION_HANDLE,
client: Pkcs11,
_guard: PhantomData<*mut u32>,
close_on_drop: CloseOnDrop,
closed: Cell<bool>,
}
impl std::fmt::Display for Session {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
write!(f, "{}", self.handle)
}
}
impl std::fmt::LowerHex for Session {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
write!(f, "{:08x}", self.handle)
}
}
impl std::fmt::UpperHex for Session {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
write!(f, "{:08X}", self.handle)
}
}
unsafe impl Send for Session {}
impl Session {
pub(crate) fn new(
handle: CK_SESSION_HANDLE,
client: Pkcs11,
close_on_drop: CloseOnDrop,
) -> Self {
Session {
handle,
client,
_guard: PhantomData,
close_on_drop,
closed: Cell::new(false),
}
}
}
impl Session {
pub fn close(self) -> Result<()> {
self.close_inner()
}
pub fn handle(&self) -> CK_SESSION_HANDLE {
self.handle
}
pub(crate) fn client(&self) -> &Pkcs11 {
&self.client
}
}
#[derive(Copy, Clone, Debug)]
pub enum UserType {
So,
User,
ContextSpecific,
VendorExtension(u32),
}
impl From<UserType> for CK_USER_TYPE {
#![allow(clippy::useless_conversion)]
fn from(user_type: UserType) -> CK_USER_TYPE {
match user_type {
UserType::So => CKU_SO,
UserType::User => CKU_USER,
UserType::ContextSpecific => CKU_CONTEXT_SPECIFIC,
UserType::VendorExtension(n) => n.into(),
}
}
}