blob: 7822eb890286b18e3c0a3883b4ed93b97836560d (
plain)
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
|
use super::{ClientExt as _, Error};
use crate::model::PullRequest;
use std::future::Future;
const GITHUB_API: &str = "https://api.github.com";
pub trait ClientExt {
/// Get the commit that merged [`pr`] in [`repo_owner`]/[`repo_name`]
///
/// # Errors
///
/// Will return [`Err`] if the merge commit cannot be found
fn merge_commit_for(
&self,
repo_owner: &str,
repo_name: &str,
pr: u64,
) -> impl Future<Output = Result<Option<String>, Error>> + Send;
}
impl ClientExt for super::Client {
async fn merge_commit_for(
&self,
repo_owner: &str,
repo_name: &str,
pr: u64,
) -> Result<Option<String>, Error> {
let url = format!("{GITHUB_API}/repos/{repo_owner}/{repo_name}/pulls/{pr}");
let resp: PullRequest = self.get_json(&url).await?;
let merge_commit = resp.merge_commit_sha;
Ok(merge_commit)
}
}
|