MarkBase架构升级:Multi-Volume Virtual Tree + Dual-View Management + Git Remote修正
核心功能: - ✅ Categories/Series双视图管理(category_view.rs + import_markdown.rs) - ✅ FUSE Multi-Volume支持(tree_type参数) - ✅ SSH/SFTP/SCP/rsync协议完整实现(4042行) - ✅ NFS/SMB Module Phase 1-3完成 - ✅ Archive Module Phase 1-4完成(2916行) - ✅ Download Center API完整实现 - ✅ S3兼容API实现(560行) Git配置修正: - ✅ 删除错误origin(gitea.momentry.ddns.net) - ✅ 删除m5max128(指向机器名) - ✅ 设置origin = m5max128gitea.momentry.ddns.net/admin/markbase - ✅ 设置m4minigitea = m4minigitea.momentry.ddns.net/warren/markbase 数据清理: - ✅ 删除38个临时SQLite(保留accusys.sqlite、demo.sqlite) - ✅ 删除.bak、test_*.bin、调试脚本等临时文件 - ✅ 删除临时目录(build/、download files/、raid_test/等) - ✅ 更新.gitignore排除临时文件 架构优化: - 52个文件修改,2434行新增,4739行删除 - Workspace成员整合(16个crate) - 数据库状态:accusys.sqlite保留(主demo测试) 远程同步: - ✅ 准备推送到m5max128gitea(远程Gitea) - ✅ 准备推送到m4minigitea(本地Gitea)
This commit is contained in:
80
markbase-fuse/src/fuse_rust_main.rs
Normal file
80
markbase-fuse/src/fuse_rust_main.rs
Normal file
@@ -0,0 +1,80 @@
|
||||
use clap::{Parser, Subcommand};
|
||||
use std::path::PathBuf;
|
||||
use anyhow::Result;
|
||||
|
||||
#[derive(Parser)]
|
||||
#[command(name = "markbase-fuse-rust", about = "MarkBase FUSE (Rust libfuse3)")]
|
||||
struct Cli {
|
||||
#[command(subcommand)]
|
||||
command: Commands,
|
||||
}
|
||||
|
||||
#[derive(Subcommand)]
|
||||
enum Commands {
|
||||
/// Mount FUSE filesystem
|
||||
Mount {
|
||||
/// User ID
|
||||
#[arg(short, long)]
|
||||
user: String,
|
||||
/// Mount path
|
||||
#[arg(short, long)]
|
||||
dir: PathBuf,
|
||||
/// Database path
|
||||
#[arg(long)]
|
||||
db: Option<PathBuf>,
|
||||
},
|
||||
}
|
||||
|
||||
fn main() -> Result<()> {
|
||||
let cli = Cli::parse();
|
||||
|
||||
match cli.command {
|
||||
Commands::Mount { user, dir, db } => {
|
||||
mount_user(user, dir, db)?;
|
||||
}
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn mount_user(user: String, dir: PathBuf, db_path: Option<PathBuf>) -> Result<()> {
|
||||
use markbase_fuse::fuse_rust::MarkBaseFs;
|
||||
use std::env::current_dir;
|
||||
|
||||
let db_path = match db_path {
|
||||
Some(p) => p,
|
||||
None => {
|
||||
let mut path = current_dir()?;
|
||||
path.push("data/users");
|
||||
path.push(format!("{}.sqlite", user));
|
||||
path
|
||||
}
|
||||
};
|
||||
|
||||
if !db_path.exists() {
|
||||
return Err(anyhow::anyhow!("Database not found: {}", db_path.display()));
|
||||
}
|
||||
|
||||
if !dir.exists() {
|
||||
std::fs::create_dir_all(&dir)?;
|
||||
}
|
||||
|
||||
println!("=== MarkBase FUSE (Rust v15 equivalent) ===");
|
||||
println!("User: {}", user);
|
||||
println!("Database: {}", db_path.display());
|
||||
println!("Mount: {}", dir.display());
|
||||
println!("Features:");
|
||||
println!(" - 512KB read chunks");
|
||||
println!(" - Hash-based cache (1000 entries)");
|
||||
println!(" - Path cache (2000 entries)");
|
||||
println!(" - Pre-cache 1000 files");
|
||||
println!(" - Thread-safe Mutex");
|
||||
println!("");
|
||||
|
||||
let fs = MarkBaseFs::new(&db_path.to_string_lossy())?;
|
||||
|
||||
// Mount using fuse crate
|
||||
fuse::mount(fs, &dir, &[]);
|
||||
|
||||
Ok(())
|
||||
}
|
||||
Reference in New Issue
Block a user