Implement new fn create_release()

This commit is contained in:
2025-05-28 20:27:52 -05:00
parent a212dc3ceb
commit 4250deb419
3 changed files with 31 additions and 6 deletions

View File

@@ -1,6 +1,6 @@
use crate::{
structs::release::Release, Result
structs::release::{CreateReleaseOption, Release}, Result
};
pub fn get_release(id: u64) -> Result<Release> { todo!(); }
@@ -31,7 +31,25 @@ pub async fn list_releases(
return Ok(release_list);
}
pub fn create_release() -> Result<Release> { todo!(); }
pub async fn create_release(
client: &reqwest::Client,
gitea_url: &str,
repo: &str,
submission: CreateReleaseOption
) -> Result<Release> {
let request_url = format!("{gitea_url}/api/v1/repos/{repo}/releases");
let req = client
.post(request_url)
.json(&submission)
.send()
.await
.map_err(|e| crate::Error::from(e))?;
let new_release = req
.json::<Release>()
.await
.map_err(|e| crate::Error::from(e))?;
return Ok(new_release);
}
pub fn edit_release(id: u64) -> Result<Release> { todo!(); }
pub fn delete_release(id: u64) -> Result<()> { todo!(); }

View File

@@ -13,8 +13,16 @@ pub struct ApiError {
#[derive(Debug)]
pub enum Error {
Placeholder, // TODO: Enumerate error modes
WrappedReqwestErr(reqwest::Error)
WrappedReqwestErr(reqwest::Error),
MissingAuthToken,
}
impl From<reqwest::Error> for crate::Error {
fn from(value: reqwest::Error) -> Self {
Self::WrappedReqwestErr(value)
}
}
type Result<T> = core::result::Result<T, Error>;
#[derive(Debug, Deserialize, Serialize)]

View File

@@ -55,9 +55,8 @@ async fn main() -> Result<(), gt_tools::Error> {
tag_name,
target_commitish,
};
do_create_release(&client, &args.gitea_url, &args.repo, submission)
.await
.map_err(reqwest_to_gttool)?;
gt_tools::api::release::create_release(&client, &args.gitea_url, &args.repo, submission)
.await?;
}
gt_tools::cli::Commands::UploadRelease {
tag_name,