octocrab 0.49.9

A modern, extensible GitHub API client.
Documentation
use super::*;

/// A builder pattern struct for listing hooks deliveries.
///
/// created by [`HooksHandler::list_deliveries`]
///
/// [`HooksHandler::list_deliveries`]: ./struct.HooksHandler.html#method.list_deliveries
#[derive(serde::Serialize)]
pub struct ListHooksDeliveriesBuilder<'octo, 'r> {
    #[serde(skip)]
    handler: &'r HooksHandler<'octo>,
    #[serde(skip)]
    hook_id: HookId,
    #[serde(skip_serializing_if = "Option::is_none")]
    per_page: Option<u8>,
    #[serde(skip_serializing_if = "Option::is_none")]
    page: Option<u32>,
}
impl<'octo, 'r> ListHooksDeliveriesBuilder<'octo, 'r> {
    pub(crate) fn new(handler: &'r HooksHandler<'octo>, hook_id: HookId) -> Self {
        Self {
            handler,
            hook_id,
            per_page: None,
            page: None,
        }
    }

    /// Results per page (max 100).
    pub fn per_page(mut self, per_page: impl Into<u8>) -> Self {
        self.per_page = Some(per_page.into());
        self
    }

    /// Page number of the results to fetch.
    pub fn page(mut self, page: impl Into<u32>) -> Self {
        self.page = Some(page.into());
        self
    }

    /// Send the actual request.
    pub async fn send(self) -> crate::Result<crate::Page<crate::models::hooks::Delivery>> {
        let route = match self.handler.repo.clone() {
            Some(repo) => format!(
                "/repos/{}/{}/hooks/{}/deliveries",
                self.handler.owner, repo, self.hook_id
            ),
            None => format!(
                "/orgs/{}/hooks/{}/deliveries",
                self.handler.owner, self.hook_id
            ),
        };
        self.handler.crab.get(route, Some(&self)).await
    }
}