You've already forked AstralRinth
forked from didirus/AstralRinth
* fix tauri config * fix package patch * regen pnpm lock * use new workflow * New GH actions * Update lockfile * update scripts * Fix build script * Fix missing deps * Fix assets eslint * Update libraries lint * Fix all lint configs * update lockfile * add fmt + clippy fails * Separate App Tauri portion * fix app features * Fix lints * install tauri cli * update lockfile * corepack, fix lints * add store path * fix unused import * Fix tests * Issue templates + port over tauri release * fix actions * fix before build command * Add X86 target * Update build matrix * finalize actions * make debug build smaller * Use debug build to make cache smaller * dummy commit * change proj name * update file name * Use release builds for less space use * Remove rust cache * Readd for app build * add merge queue trigger
103 lines
2.7 KiB
Rust
103 lines
2.7 KiB
Rust
use crate::api::Result;
|
|
use theseus::logs::LogType;
|
|
use theseus::{
|
|
logs::{self, CensoredString, LatestLogCursor, Logs},
|
|
prelude::ProfilePathId,
|
|
};
|
|
|
|
/*
|
|
A log is a struct containing the filename string, stdout, and stderr, as follows:
|
|
|
|
pub struct Logs {
|
|
pub filename: String,
|
|
pub stdout: String,
|
|
pub stderr: String,
|
|
}
|
|
*/
|
|
|
|
pub fn init<R: tauri::Runtime>() -> tauri::plugin::TauriPlugin<R> {
|
|
tauri::plugin::Builder::new("logs")
|
|
.invoke_handler(tauri::generate_handler![
|
|
logs_get_logs,
|
|
logs_get_logs_by_filename,
|
|
logs_get_output_by_filename,
|
|
logs_delete_logs,
|
|
logs_delete_logs_by_filename,
|
|
logs_get_latest_log_cursor,
|
|
])
|
|
.build()
|
|
}
|
|
|
|
/// Get all Logs for a profile, sorted by filename
|
|
#[tauri::command]
|
|
pub async fn logs_get_logs(
|
|
profile_path: ProfilePathId,
|
|
clear_contents: Option<bool>,
|
|
) -> Result<Vec<Logs>> {
|
|
let val = logs::get_logs(profile_path, clear_contents).await?;
|
|
|
|
Ok(val)
|
|
}
|
|
|
|
/// Get a Log struct for a profile by profile id and filename string
|
|
#[tauri::command]
|
|
pub async fn logs_get_logs_by_filename(
|
|
profile_path: ProfilePathId,
|
|
log_type: LogType,
|
|
filename: String,
|
|
) -> Result<Logs> {
|
|
Ok(logs::get_logs_by_filename(profile_path, log_type, filename).await?)
|
|
}
|
|
|
|
/// Get the stdout for a profile by profile id and filename string
|
|
#[tauri::command]
|
|
pub async fn logs_get_output_by_filename(
|
|
profile_path: ProfilePathId,
|
|
log_type: LogType,
|
|
filename: String,
|
|
) -> Result<CensoredString> {
|
|
let profile_path = if let Some(p) =
|
|
crate::profile::get(&profile_path, None).await?
|
|
{
|
|
p.profile_id()
|
|
} else {
|
|
return Err(theseus::Error::from(
|
|
theseus::ErrorKind::UnmanagedProfileError(profile_path.to_string()),
|
|
)
|
|
.into());
|
|
};
|
|
|
|
Ok(
|
|
logs::get_output_by_filename(&profile_path, log_type, &filename)
|
|
.await?,
|
|
)
|
|
}
|
|
|
|
/// Delete all logs for a profile by profile id
|
|
#[tauri::command]
|
|
pub async fn logs_delete_logs(profile_path: ProfilePathId) -> Result<()> {
|
|
Ok(logs::delete_logs(profile_path).await?)
|
|
}
|
|
|
|
/// Delete a log for a profile by profile id and filename string
|
|
#[tauri::command]
|
|
pub async fn logs_delete_logs_by_filename(
|
|
profile_path: ProfilePathId,
|
|
log_type: LogType,
|
|
filename: String,
|
|
) -> Result<()> {
|
|
Ok(
|
|
logs::delete_logs_by_filename(profile_path, log_type, &filename)
|
|
.await?,
|
|
)
|
|
}
|
|
|
|
/// Get live log from a cursor
|
|
#[tauri::command]
|
|
pub async fn logs_get_latest_log_cursor(
|
|
profile_path: ProfilePathId,
|
|
cursor: u64, // 0 to start at beginning of file
|
|
) -> Result<LatestLogCursor> {
|
|
Ok(logs::get_latest_log_cursor(profile_path, cursor).await?)
|
|
}
|