pub mod access_token;
pub mod oidc;
pub mod refresh_access_token;
pub mod user_info;
pub use access_token::UserAccessTokenV1Builder;
pub use oidc::{OidcAccessTokenBuilder, OidcRefreshAccessTokenBuilder, OidcService};
pub use refresh_access_token::RefreshUserAccessTokenV1Builder;
pub use user_info::{UserInfoBuilder, UserInfoService};
use openlark_core::config::Config;
#[derive(Debug)]
pub struct AuthenServiceV1 {
config: Config,
}
impl AuthenServiceV1 {
pub fn new(config: Config) -> Self {
Self { config }
}
pub fn user_info(&self) -> UserInfoService {
UserInfoService::new(self.config.clone())
}
pub fn access_token(&self) -> UserAccessTokenV1Builder {
UserAccessTokenV1Builder::new(self.config.clone())
}
pub fn refresh_access_token(&self) -> RefreshUserAccessTokenV1Builder {
RefreshUserAccessTokenV1Builder::new(self.config.clone())
}
pub fn oidc(&self) -> OidcService {
OidcService::new(self.config.clone())
}
}
#[cfg(test)]
#[allow(unused_imports)]
mod tests {
#[test]
fn test_serialization_roundtrip() {
let json = r#"{"test": "value"}"#;
assert!(serde_json::from_str::<serde_json::Value>(json).is_ok());
}
#[test]
fn test_deserialization_from_json() {
let json = r#"{"field": "data"}"#;
let value: serde_json::Value = serde_json::from_str(json).expect("JSON 反序列化失败");
assert_eq!(value["field"], "data");
}
}