scaleway-rs 0.2.8

A pure Rust scaleway API binding.
Documentation
use crate::data::project::{ProjectOrderBy, ScalewayProject, ScalewayProjectsRoot};
use crate::ScalewayApi;
use crate::ScalewayError;

/// Builder for listing Scaleway projects.
///
/// Created by [`ScalewayApi::list_projects`](crate::ScalewayApi::list_projects).
/// Auto-paginates. Call [`run`](Self::run) or [`run_async`](Self::run_async) to execute.
pub struct ScalewayListProjectsBuilder {
    api: ScalewayApi,
    params: Vec<(&'static str, String)>,
}

impl ScalewayListProjectsBuilder {
    pub fn new(api: ScalewayApi) -> Self {
        ScalewayListProjectsBuilder {
            api,
            params: vec![],
        }
    }

    /// Filters by organization UUID.
    pub fn organization_id(mut self, organization_id: &str) -> ScalewayListProjectsBuilder {
        self.params.push(("organization_id", organization_id.to_string()));
        self
    }

    /// Filters by project name (substring match).
    pub fn name(mut self, name: &str) -> ScalewayListProjectsBuilder {
        self.params.push(("name", name.to_string()));
        self
    }

    /// Sets the sort order.
    pub fn order_by(mut self, order_by: ProjectOrderBy) -> ScalewayListProjectsBuilder {
        self.params.push(("order_by", order_by.to_string()));
        self
    }

    /// Number of projects per page (max 100).
    pub fn page_size(mut self, page_size: u32) -> ScalewayListProjectsBuilder {
        self.params.push(("page_size", page_size.to_string()));
        self
    }

    /// Fetches all matching projects, auto-paginating (blocking).
    #[cfg(feature = "blocking")]
    pub fn run(self) -> Result<Vec<ScalewayProject>, ScalewayError> {
        let mut list = vec![];
        let mut page = 1;
        loop {
            let mut params = self.params.clone();
            params.push(("page", page.to_string()));
            let result = self
                .api
                .get("https://api.scaleway.com/account/v3/projects", params)?
                .json::<ScalewayProjectsRoot>()?;
            if result.projects.is_empty() {
                break;
            }
            list.extend(result.projects.into_iter());
            page += 1;
        }
        Ok(list)
    }

    /// Fetches all matching projects, auto-paginating.
    pub async fn run_async(self) -> Result<Vec<ScalewayProject>, ScalewayError> {
        let mut list = vec![];
        let mut page = 1;
        loop {
            let mut params = self.params.clone();
            params.push(("page", page.to_string()));
            let result = self
                .api
                .get_async("https://api.scaleway.com/account/v3/projects", params)
                .await?
                .json::<ScalewayProjectsRoot>()
                .await?;
            if result.projects.is_empty() {
                break;
            }
            list.extend(result.projects.into_iter());
            page += 1;
        }
        Ok(list)
    }
}