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:
67
markbase-core/src/ssh2_server/channel.rs
Normal file
67
markbase-core/src/ssh2_server/channel.rs
Normal file
@@ -0,0 +1,67 @@
|
||||
// Channel管理(辅助模块)
|
||||
// 管理ssh2::Channel生命周期和路由
|
||||
|
||||
use anyhow::Result;
|
||||
use ssh2::Channel;
|
||||
use log::{info, debug};
|
||||
|
||||
/// Channel Manager
|
||||
pub struct ChannelManager {
|
||||
channel: Channel,
|
||||
}
|
||||
|
||||
impl ChannelManager {
|
||||
pub fn new(channel: Channel) -> Self {
|
||||
Self { channel }
|
||||
}
|
||||
|
||||
/// 读取数据
|
||||
pub fn read(&mut self, buf: &mut [u8]) -> Result<usize> {
|
||||
let len = self.channel.read(buf)?;
|
||||
debug!("Read {} bytes from channel", len);
|
||||
Ok(len)
|
||||
}
|
||||
|
||||
/// 写入数据
|
||||
pub fn write(&mut self, data: &[u8]) -> Result<()> {
|
||||
self.channel.write_all(data)?;
|
||||
debug!("Write {} bytes to channel", data.len());
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// 读取字符串
|
||||
pub fn read_string(&mut self) -> Result<String> {
|
||||
let mut buf = String::new();
|
||||
self.channel.read_to_string(&mut buf)?;
|
||||
debug!("Read string: {} bytes", buf.len());
|
||||
Ok(buf)
|
||||
}
|
||||
|
||||
/// 发送EOF
|
||||
pub fn send_eof(&mut self) -> Result<()> {
|
||||
self.channel.send_eof()?;
|
||||
info!("Sent EOF to channel");
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// 等待EOF
|
||||
pub fn wait_eof(&mut self) -> Result<()> {
|
||||
self.channel.wait_eof()?;
|
||||
info!("Wait EOF completed");
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// 关闭channel
|
||||
pub fn close(&mut self) -> Result<()> {
|
||||
self.channel.close()?;
|
||||
info!("Channel closed");
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// 等待关闭
|
||||
pub fn wait_close(&mut self) -> Result<()> {
|
||||
self.channel.wait_close()?;
|
||||
info!("Channel wait close completed");
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user