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:
40
markbase-core/src/ssh2_mod/mod.rs
Normal file
40
markbase-core/src/ssh2_mod/mod.rs
Normal file
@@ -0,0 +1,40 @@
|
||||
// ssh2辅助模块(混合方案)
|
||||
// 用于SCP和rsync receiver实现
|
||||
|
||||
pub mod scp_handler;
|
||||
pub mod rsync_receiver;
|
||||
|
||||
pub use scp_handler::ScpHandler;
|
||||
pub use rsync_receiver::RsyncReceiverHandler;
|
||||
|
||||
use anyhow::Result;
|
||||
use ssh2::Session;
|
||||
use std::net::TcpStream;
|
||||
use std::path::Path;
|
||||
|
||||
/// ssh2 Session管理
|
||||
pub struct Ssh2Session {
|
||||
session: Session,
|
||||
}
|
||||
|
||||
impl Ssh2Session {
|
||||
/// 创建新的ssh2 session(从现有TCP连接)
|
||||
pub fn new(tcp_stream: TcpStream) -> Result<Self> {
|
||||
let mut session = Session::new()?;
|
||||
session.set_tcp_stream(tcp_stream);
|
||||
session.handshake()?;
|
||||
|
||||
Ok(Self { session })
|
||||
}
|
||||
|
||||
/// 认证(使用现有MarkBase auth系统)
|
||||
pub fn authenticate(&mut self, user: &str, password: &str) -> Result<()> {
|
||||
self.session.userauth_password(user, password)?;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// 获取session引用
|
||||
pub fn session(&self) -> &Session {
|
||||
&self.session
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user