核心功能: - ✅ 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)
114 lines
3.1 KiB
Swift
114 lines
3.1 KiB
Swift
import Foundation
|
|
import SQLite3
|
|
|
|
// MarkBaseFS FSKit Probe Tool
|
|
// Checks database integrity and returns probe result to fskitd
|
|
|
|
func probeMarkBaseFS() -> Bool {
|
|
print("=== MarkBaseFS Probe Tool ===")
|
|
print("Date: \(Date())")
|
|
print("")
|
|
|
|
// Step 1: Check database file exists
|
|
let dbPath = "/Users/accusys/markbase/data/users/warren.sqlite"
|
|
|
|
print("Checking database file: \(dbPath)")
|
|
|
|
if !FileManager.default.fileExists(atPath: dbPath) {
|
|
print(" ❌ Database file NOT found")
|
|
return false
|
|
}
|
|
|
|
print(" ✅ Database file found")
|
|
|
|
// Step 2: Check database integrity
|
|
print("Checking database integrity...")
|
|
|
|
var db: OpaquePointer?
|
|
|
|
if sqlite3_open(dbPath, &db) != SQLITE_OK {
|
|
print(" ❌ Failed to open database")
|
|
return false
|
|
}
|
|
|
|
print(" ✅ Database opened successfully")
|
|
|
|
// Step 3: Check file_nodes table exists
|
|
print("Checking file_nodes table...")
|
|
|
|
let query = "SELECT name FROM sqlite_master WHERE type='table' AND name='file_nodes'"
|
|
var stmt: OpaquePointer?
|
|
|
|
if sqlite3_prepare_v2(db, query, -1, &stmt, nil) != SQLITE_OK {
|
|
print(" ❌ Failed to prepare query")
|
|
sqlite3_close(db)
|
|
return false
|
|
}
|
|
|
|
if sqlite3_step(stmt) == SQLITE_ROW {
|
|
let tableName = String(cString: sqlite3_column_text(stmt, 0))
|
|
print(" ✅ Table found: \(tableName)")
|
|
sqlite3_finalize(stmt)
|
|
sqlite3_close(db)
|
|
|
|
// Step 4: Check data count
|
|
print("Checking data count...")
|
|
|
|
var db2: OpaquePointer?
|
|
if sqlite3_open(dbPath, &db2) == SQLITE_OK {
|
|
let countQuery = "SELECT COUNT(*) FROM file_nodes"
|
|
var stmt2: OpaquePointer?
|
|
if sqlite3_prepare_v2(db2, countQuery, -1, &stmt2, nil) == SQLITE_OK {
|
|
if sqlite3_step(stmt2) == SQLITE_ROW {
|
|
let count = sqlite3_column_int(stmt2, 0)
|
|
print(" ✅ Found \(count) nodes in database")
|
|
sqlite3_finalize(stmt2)
|
|
sqlite3_close(db2)
|
|
return count > 0
|
|
}
|
|
sqlite3_finalize(stmt2)
|
|
}
|
|
sqlite3_close(db2)
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
print(" ❌ file_nodes table NOT found")
|
|
sqlite3_finalize(stmt)
|
|
sqlite3_close(db)
|
|
return false
|
|
}
|
|
|
|
// Main entry point
|
|
print("Arguments: \(CommandLine.arguments)")
|
|
print("")
|
|
|
|
// Handle probe request
|
|
if CommandLine.arguments.contains("-p") {
|
|
print("Probe request received (-p flag)")
|
|
print("")
|
|
|
|
let result = probeMarkBaseFS()
|
|
|
|
print("")
|
|
print("=== Probe Result ===")
|
|
print("Result: \(result ? "YES" : "NO")")
|
|
|
|
// Return result to fskitd (stdout)
|
|
// fskitd expects "YES" or "NO"
|
|
print(result ? "YES" : "NO")
|
|
|
|
exit(result ? 0 : 1)
|
|
}
|
|
|
|
// Handle other requests
|
|
if CommandLine.arguments.count > 1 {
|
|
print("Unknown command: \(CommandLine.arguments[1])")
|
|
print("Supported commands: -p (probe)")
|
|
exit(1)
|
|
}
|
|
|
|
print("No arguments provided")
|
|
print("Usage: MarkBaseFSProbe -p")
|
|
exit(1) |