use crate::model::{drive::DriveFolder, id::Id};
use serde::Serialize;
use typed_builder::TypedBuilder;
pub mod create;
pub mod delete;
pub mod find;
pub mod show;
pub mod update;
#[derive(Serialize, Default, Debug, Clone, TypedBuilder)]
#[serde(rename_all = "camelCase")]
#[builder(doc)]
pub struct Request {
#[builder(default, setter(strip_option))]
pub folder_id: Option<Id<DriveFolder>>,
#[serde(skip_serializing_if = "Option::is_none")]
#[builder(default, setter(strip_option))]
pub limit: Option<u8>,
#[serde(skip_serializing_if = "Option::is_none")]
#[builder(default, setter(strip_option))]
pub since_id: Option<Id<DriveFolder>>,
#[serde(skip_serializing_if = "Option::is_none")]
#[builder(default, setter(strip_option))]
pub until_id: Option<Id<DriveFolder>>,
}
impl misskey_core::Request for Request {
type Response = Vec<DriveFolder>;
const ENDPOINT: &'static str = "drive/folders";
}
impl_pagination!(Request, DriveFolder);
#[cfg(test)]
mod tests {
use super::Request;
use crate::test::{ClientExt, TestClient};
#[tokio::test]
async fn request() {
let client = TestClient::new();
client.test(Request::default()).await;
}
#[tokio::test]
async fn request_with_folder() {
let client = TestClient::new();
let folder1 = client
.test(crate::endpoint::drive::folders::create::Request {
name: None,
parent_id: None,
})
.await;
client
.test(crate::endpoint::drive::folders::create::Request {
name: None,
parent_id: Some(folder1.id.clone()),
})
.await;
client
.test(Request {
folder_id: Some(folder1.id),
limit: None,
since_id: None,
until_id: None,
})
.await;
}
#[tokio::test]
async fn request_with_limit() {
let client = TestClient::new();
client
.test(Request {
folder_id: None,
limit: Some(100),
since_id: None,
until_id: None,
})
.await;
}
#[tokio::test]
async fn request_paginate() {
let client = TestClient::new();
let folder = client
.test(crate::endpoint::drive::folders::create::Request {
name: None,
parent_id: None,
})
.await;
client
.test(Request {
folder_id: None,
limit: None,
since_id: Some(folder.id.clone()),
until_id: Some(folder.id.clone()),
})
.await;
}
}