Delete song (#67)

* Changed code to comply with async

* Able to delete song

* Updated readme

* Code formatting and cleanup

* Version bump
This commit was merged in pull request #67.
This commit is contained in:
KD
2025-08-30 13:06:04 -04:00
committed by GitHub
parent e109789b18
commit 11b8cc21d3
5 changed files with 34 additions and 15 deletions
Generated
+1 -1
View File
@@ -479,7 +479,7 @@ dependencies = [
[[package]]
name = "icarus-dm"
version = "0.6.7"
version = "0.6.8"
dependencies = [
"futures",
"http",
+1 -1
View File
@@ -1,6 +1,6 @@
[package]
name = "icarus-dm"
version = "0.6.7"
version = "0.6.8"
rust-version = "1.88"
edition = "2024"
+1 -1
View File
@@ -66,7 +66,7 @@ icarus-dm retrieve -u spacecadet -p stellar40 -h https://icarus.com -ha https://
### Deleting Song
```BASH
icarus-dm delete -u spacecadet -p stellar40 -h https://icarus.com -D e8407fc6-edd2-44c1-993f-08dd7324d91a
icarus-dm delete -u spacecadet -p stellar40 -h https://icarus.com -ha https://auth.icarus.com -D e8407fc6-edd2-44c1-993f-08dd7324d91a
```
+3 -6
View File
@@ -5,7 +5,6 @@ use std::io::{Result, Write};
use std::str::FromStr;
use serde::{Deserialize, Serialize};
use tokio::runtime::Runtime;
use crate::managers;
use crate::models::{self};
@@ -169,11 +168,9 @@ impl CommitManager {
println!("Deleting song..");
let res_fut = del.delete_song(&token, &song);
let result = Runtime::new().unwrap().block_on(res_fut);
match result {
Ok(o) => {
println!("Song (Id {:?}) has been successfully deleted", o.id);
match del.delete_song(&token, &song).await {
Ok((song, _coverart)) => {
println!("Song (Id {:?}) has been successfully deleted", song.id);
}
Err(er) => {
println!("Error {er:?}");
+28 -6
View File
@@ -3,21 +3,39 @@ use std::default::Default;
use reqwest;
use crate::models;
use crate::syncers;
#[derive(Clone, Debug, Default)]
pub struct Delete {
pub api: models::api::Api,
}
mod response {
pub mod delete_song {
#[derive(Debug, serde::Deserialize)]
pub struct SongAndCoverArt {
pub song: icarus_models::song::Song,
pub coverart: icarus_models::coverart::CoverArt,
}
#[derive(Debug, serde::Deserialize)]
pub struct Response {
pub message: String,
pub data: Vec<SongAndCoverArt>,
}
}
}
impl Delete {
pub async fn delete_song(
&mut self,
token: &icarus_models::token::AccessToken,
song: &icarus_models::song::Song,
) -> Result<icarus_models::song::Song, std::io::Error> {
self.api.endpoint = "song/data/delete".to_owned();
let url = syncers::common::retrieve_url(&self.api, true, &song.id);
) -> Result<(icarus_models::song::Song, icarus_models::coverart::CoverArt), std::io::Error>
{
self.api.endpoint = "api/v2/song".to_owned();
let url = format!("{}{}/{}", self.api.url, self.api.endpoint, song.id);
println!("Url: {url:?}");
let client = reqwest::Client::builder().build().unwrap();
let access_token = token.bearer_token();
let response = client
@@ -31,8 +49,12 @@ impl Delete {
reqwest::StatusCode::OK => {
println!("Success!");
match response.json::<icarus_models::song::Song>().await {
Ok(sng) => Ok(sng),
match response.json::<response::delete_song::Response>().await {
Ok(resp) => {
println!("Response message: {:?}", resp.message);
let data = &resp.data[0];
Ok((data.song.clone(), data.coverart.clone()))
}
Err(er) => Err(std::io::Error::other(er.to_string())),
}
}