summaryrefslogtreecommitdiff
path: root/crates/bot-http/src/github.rs
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)
	}
}