Files
markbase/MarkBaseFS/MarkBaseFS/MarkBaseFSProbe.swift
Warren 1300a4e223
Some checks failed
Test / test (push) Has been cancelled
Test / build (push) Has been cancelled
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)
2026-06-12 12:59:54 +08:00

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)