sspi 0.20.0

A Rust implementation of the Security Support Provider Interface (SSPI) API
Documentation
//! Functions for handling Kerberos messages on both client and server sides.

use std::fmt::Debug;

use oid::ObjectIdentifier;
use picky_asn1::wrapper::ObjectIdentifierAsn1;
use picky_krb::gss_api::{ApplicationTag0, KrbMessage};
use serde::Serialize;
use serde::de::DeserializeOwned;

use crate::{Error, ErrorKind, Result};

/// Decodes incoming [KrbMessage] message and extracts [ApReq] Kerberos message.
pub(super) fn decode_krb_message<T: DeserializeOwned>(data: &[u8], token_id: [u8; 2]) -> Result<T> {
    let krb_message = KrbMessage::<T>::decode_application_krb_message(data)?.0;

    if krb_message.krb5_token_id != token_id {
        return Err(Error::new(
            ErrorKind::InvalidToken,
            format!(
                "invalid kerberos token id: expected {:?} but got {:?}",
                token_id, krb_message.krb5_token_id
            ),
        ));
    }

    Ok(krb_message.krb_msg)
}

pub(super) fn generate_krb_message<T: Serialize + Debug + PartialEq>(
    mech_id: ObjectIdentifier,
    krb5_token_id: [u8; 2],
    krb_msg: T,
) -> Result<Vec<u8>> {
    let krb_blob = ApplicationTag0(KrbMessage {
        krb5_oid: ObjectIdentifierAsn1::from(mech_id),
        krb5_token_id,
        krb_msg,
    });

    Ok(picky_asn1_der::to_vec(&krb_blob)?)
}