1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
use build_it::Builder;
use serde::Serialize;
use teatime_macros::QueryParams;

use crate::{error::Result, model::repos::Repository, Client};

/// Options for forking a repository.
/// All fields are optional.
#[derive(Debug, Clone, Serialize, Builder)]
#[serde(default)]
pub struct CreateForkBuilder {
    /// The owner of the repository to fork.
    /// This is the user or organization that owns the repository you want to fork.
    #[skip]
    #[serde(skip)]
    owner: String,
    /// The name of the repository to fork.
    #[skip]
    #[serde(skip)]
    repo: String,
    /// The name of the new repository.
    /// Will be the same as the original if not set.
    name: Option<String>,
    /// Organization name, if forking into an organization.
    organization: Option<String>,
}

impl CreateForkBuilder {
    pub fn new(owner: impl ToString, repo: impl ToString) -> Self {
        Self {
            owner: owner.to_string(),
            repo: repo.to_string(),
            organization: None,
            name: None,
        }
    }
    /// Send the request to fork the repository.
    pub async fn send(&self, client: &Client) -> Result<Repository> {
        let owner = &self.owner;
        let repo = &self.repo;
        let req = client
            .post(format!("repos/{owner}/{repo}/forks"))
            .json(self)
            .build()?;
        let res = client.make_request(req).await?;
        client.parse_response(res).await
    }
}

/// Options for listing a repository's forks.
/// All fields are optional.
#[derive(Debug, Clone, Serialize, Builder, QueryParams)]
#[serde(default)]
pub struct ListForksBuilder {
    #[skip]
    #[serde(skip)]
    #[query_params(skip)]
    /// The owner of the repository to list forks for.
    owner: String,
    #[skip]
    #[serde(skip)]
    #[query_params(skip)]
    /// The name of the repository to list forks for.
    repo: String,
    #[serde(skip_serializing_if = "Option::is_none")]
    /// Optional page number of the results to fetch (1-based).
    /// Defaults to 1 if not set.
    page: Option<i64>,
    #[serde(skip_serializing_if = "Option::is_none")]
    /// Optional number of forks to return per page (page-size).
    /// Defaults to the maximum your instance allows if not set.
    limit: Option<i64>,
}

impl ListForksBuilder {
    pub fn new(owner: impl ToString, repo: impl ToString) -> Self {
        Self {
            owner: owner.to_string(),
            repo: repo.to_string(),
            page: None,
            limit: None,
        }
    }
    /// Send the request to list the forks.
    pub async fn send(&self, client: &Client) -> Result<Vec<Repository>> {
        let owner = &self.owner;
        let repo = &self.repo;

        let mut req = client.get(format!("repos/{owner}/{repo}/forks")).build()?;
        self.append_query_params(&mut req);
        let res = client.make_request(req).await?;
        client.parse_response(res).await
    }
}