You've already forked AstralRinth
forked from didirus/AstralRinth
* Update Rust version * Update async-compression 0.4.25 -> 0.4.27 * Update async-tungstenite 0.29.1 -> 0.30.0 * Update bytemuck 1.23.0 -> 1.23.1 * Update clap 4.5.40 -> 4.5.43 * Update deadpool-redis 0.21.1 -> 0.22.0 and redis 0.31.0 -> 0.32.4 * Update enumset 1.1.6 -> 1.1.7 * Update hyper-util 0.1.14 -> 0.1.16 * Update indexmap 2.9.0 -> 2.10.0 * Update indicatif 0.17.11 -> 0.18.0 * Update jemalloc_pprof 0.7.0 -> 0.8.1 * Update lettre 0.11.17 -> 0.11.18 * Update meilisearch-sdk 0.28.0 -> 0.29.1 * Update notify 8.0.0 -> 8.2.0 and notify-debouncer-mini 0.6.0 -> 0.7.0 * Update quick-xml 0.37.5 -> 0.38.1 * Fix theseus lint * Update reqwest 0.12.20 -> 0.12.22 * Cargo fmt in theseus * Update rgb 0.8.50 -> 0.8.52 * Update sentry 0.41.0 -> 0.42.0 and sentry-actix 0.41.0 -> 0.42.0 * Update serde_json 1.0.140 -> 1.0.142 * Update serde_with 3.13.0 -> 3.14.0 * Update spdx 0.10.8 -> 0.10.9 * Update sysinfo 0.35.2 -> 0.36.1 * Update tauri suite * Fix build by updating mappings * Update tokio 1.45.1 -> 1.47.1 and tokio-util 0.7.15 -> 0.7.16 * Update tracing-actix-web 0.7.18 -> 0.7.19 * Update zip 4.2.0 -> 4.3.0 * Misc Cargo.lock updates * Update Dockerfiles
76 lines
2.4 KiB
Rust
76 lines
2.4 KiB
Rust
use std::path::PathBuf;
|
|
|
|
use crate::{
|
|
event::{
|
|
CommandPayload,
|
|
emit::{emit_command, emit_warning},
|
|
},
|
|
util::io,
|
|
};
|
|
|
|
/// Handles external functions (such as through URL deep linkage)
|
|
/// Link is extracted value (link) in somewhat URL format, such as
|
|
/// subdomain1/subdomain2
|
|
/// (Does not include modrinth://)
|
|
pub async fn handle_url(sublink: &str) -> crate::Result<CommandPayload> {
|
|
Ok(match sublink.split_once('/') {
|
|
// /mod/{id} - Installs a mod of mod id
|
|
Some(("mod", id)) => CommandPayload::InstallMod { id: id.to_string() },
|
|
// /version/{id} - Installs a specific version of id
|
|
Some(("version", id)) => {
|
|
CommandPayload::InstallVersion { id: id.to_string() }
|
|
}
|
|
// /modpack/{id} - Installs a modpack of modpack id
|
|
Some(("modpack", id)) => {
|
|
CommandPayload::InstallModpack { id: id.to_string() }
|
|
}
|
|
_ => {
|
|
emit_warning(&format!(
|
|
"Invalid command, unrecognized path: {sublink}"
|
|
))
|
|
.await?;
|
|
return Err(crate::ErrorKind::InputError(format!(
|
|
"Invalid command, unrecognized path: {sublink}"
|
|
))
|
|
.into());
|
|
}
|
|
})
|
|
}
|
|
|
|
pub async fn parse_command(
|
|
command_string: &str,
|
|
) -> crate::Result<CommandPayload> {
|
|
tracing::debug!("Parsing command: {}", &command_string);
|
|
|
|
// modrinth://some-command
|
|
// This occurs when following a web redirect link
|
|
if let Some(sublink) = command_string.strip_prefix("modrinth://") {
|
|
Ok(handle_url(sublink).await?)
|
|
} else {
|
|
// We assume anything else is a filepath to an .mrpack file
|
|
let path = PathBuf::from(command_string);
|
|
let path = io::canonicalize(path)?;
|
|
if let Some(ext) = path.extension()
|
|
&& ext == "mrpack"
|
|
{
|
|
return Ok(CommandPayload::RunMRPack { path });
|
|
}
|
|
emit_warning(&format!(
|
|
"Invalid command, unrecognized filetype: {}",
|
|
path.display()
|
|
))
|
|
.await?;
|
|
Err(crate::ErrorKind::InputError(format!(
|
|
"Invalid command, unrecognized filetype: {}",
|
|
path.display()
|
|
))
|
|
.into())
|
|
}
|
|
}
|
|
|
|
pub async fn parse_and_emit_command(command_string: &str) -> crate::Result<()> {
|
|
let command = parse_command(command_string).await?;
|
|
emit_command(command).await?;
|
|
Ok(())
|
|
}
|