Implement new fn create_release()
This commit is contained in:
@@ -1,6 +1,6 @@
|
|||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
structs::release::Release, Result
|
structs::release::{CreateReleaseOption, Release}, Result
|
||||||
};
|
};
|
||||||
|
|
||||||
pub fn get_release(id: u64) -> Result<Release> { todo!(); }
|
pub fn get_release(id: u64) -> Result<Release> { todo!(); }
|
||||||
@@ -31,7 +31,25 @@ pub async fn list_releases(
|
|||||||
return Ok(release_list);
|
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 edit_release(id: u64) -> Result<Release> { todo!(); }
|
||||||
pub fn delete_release(id: u64) -> Result<()> { todo!(); }
|
pub fn delete_release(id: u64) -> Result<()> { todo!(); }
|
||||||
|
|
||||||
|
|||||||
10
src/lib.rs
10
src/lib.rs
@@ -13,8 +13,16 @@ pub struct ApiError {
|
|||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum Error {
|
pub enum Error {
|
||||||
Placeholder, // TODO: Enumerate error modes
|
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>;
|
type Result<T> = core::result::Result<T, Error>;
|
||||||
|
|
||||||
#[derive(Debug, Deserialize, Serialize)]
|
#[derive(Debug, Deserialize, Serialize)]
|
||||||
|
|||||||
@@ -55,9 +55,8 @@ async fn main() -> Result<(), gt_tools::Error> {
|
|||||||
tag_name,
|
tag_name,
|
||||||
target_commitish,
|
target_commitish,
|
||||||
};
|
};
|
||||||
do_create_release(&client, &args.gitea_url, &args.repo, submission)
|
gt_tools::api::release::create_release(&client, &args.gitea_url, &args.repo, submission)
|
||||||
.await
|
.await?;
|
||||||
.map_err(reqwest_to_gttool)?;
|
|
||||||
}
|
}
|
||||||
gt_tools::cli::Commands::UploadRelease {
|
gt_tools::cli::Commands::UploadRelease {
|
||||||
tag_name,
|
tag_name,
|
||||||
|
|||||||
Reference in New Issue
Block a user