use crate::schema::redfish::session::Session as SessionSchema;
use crate::schema::redfish::session_collection::SessionCollection as SessionCollectionSchema;
use crate::session_service::Session;
use crate::session_service::SessionCreate;
use crate::Error;
use crate::NvBmc;
use nv_redfish_core::Bmc;
use nv_redfish_core::EntityTypeRef as _;
use nv_redfish_core::ModificationResponse;
use nv_redfish_core::NavProperty;
use std::sync::Arc;
pub struct SessionCollection<B: Bmc> {
bmc: NvBmc<B>,
collection: Arc<SessionCollectionSchema>,
}
impl<B: Bmc> SessionCollection<B> {
pub(crate) async fn new(
bmc: NvBmc<B>,
collection_ref: &NavProperty<SessionCollectionSchema>,
) -> Result<Self, Error<B>> {
let collection = bmc.expand_property(collection_ref).await?;
Ok(Self { bmc, collection })
}
pub async fn members(&self) -> Result<Vec<Session<B>>, Error<B>> {
let mut members = Vec::with_capacity(self.collection.members.len());
for member in &self.collection.members {
members.push(Session::new(&self.bmc, member).await?);
}
Ok(members)
}
pub async fn create_session(
&self,
create: &SessionCreate,
) -> Result<Option<Session<B>>, Error<B>> {
match self
.bmc
.as_ref()
.create::<_, SessionSchema>(self.collection.as_ref().odata_id(), create)
.await
.map_err(Error::Bmc)?
{
ModificationResponse::Entity(data) => {
Ok(Some(Session::from_data(self.bmc.clone(), data)))
}
ModificationResponse::Task(_) | ModificationResponse::Empty => Ok(None),
}
}
}