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
use build_it::Builder;
use serde::Serialize;

use crate::{
    error::Result,
    model::{issues::StateType, pulls::PullRequest},
    Client,
};

#[derive(Debug, Clone, Serialize, Builder)]
#[build_it(into)]
pub struct EditPullRequestBuilder {
    #[serde(skip)]
    #[skip]
    owner: String,
    #[serde(skip)]
    #[skip]
    repo: String,
    #[serde(skip)]
    #[skip]
    id: i64,

    allow_maintainer_edit: Option<bool>,
    assignees: Option<Vec<String>>,
    base: Option<String>,
    body: Option<String>,
    due_date: Option<String>,
    labels: Option<Vec<i64>>,
    milestone: Option<i64>,
    state: Option<StateType>,
    title: Option<String>,
    unset_due_date: Option<bool>,
}

impl EditPullRequestBuilder {
    pub fn new(owner: impl ToString, repo: impl ToString, id: i64) -> Self {
        Self {
            owner: owner.to_string(),
            repo: repo.to_string(),
            id,
            allow_maintainer_edit: None,
            assignees: None,
            base: None,
            body: None,
            due_date: None,
            labels: None,
            milestone: None,
            state: None,
            title: None,
            unset_due_date: None,
        }
    }

    /// Sends the request to edit a pull request
    pub async fn send(&self, client: &Client) -> Result<PullRequest> {
        let owner = &self.owner;
        let repo = &self.repo;
        let id = self.id;
        let req = client
            .patch(format!("repos/{owner}/{repo}/pulls/{id}"))
            .json(self)
            .build()?;
        let res = client.make_request(req).await?;
        client.parse_response(res).await
    }
}