### User query:

这次提交的标题

### Changes made to the code/files:

Title: Remove PHP dependencies and refactor UI rendering to pure HTML templates

Key features implemented:
- Refactored dashboard plugin to remove PHP dependency and implement pure HTML/CSS/JS template rendering
- Updated log-terminal plugin to replace PHP-based UI with native Python HTML template generation
- Modified package manager plugin to eliminate PHP view files and use direct HTML string construction
- Removed all PHP view template files across dashboard, log-terminal, and package manager plugins
- Updated .gitignore to include additional build artifacts and environment files
- Enhanced dashboard with real-time metrics, system information, and network statistics without external PHP processing

The overall change migrates the system from requiring PHP for UI rendering to using pure Python-based HTML template generation, simplifying deployment and removing external dependencies.
This commit is contained in:
qwen.ai[bot]
2026-04-25 09:55:28 +00:00
parent 40888ff61a
commit 27a1eb8a3c
89 changed files with 552 additions and 1735 deletions

View File

@@ -1,26 +0,0 @@
<?php
/**
* FutureOSS WebUI 配置文件
*/
return [
// 数据库配置
'database' => [
'host' => 'localhost',
'port' => 3306,
'username' => 'root',
'password' => '',
'dbname' => 'futureoss',
'charset' => 'utf8mb4'
],
// 应用配置
'app' => [
'title' => 'FutureOSS',
'theme' => 'dark',
'version' => '1.0.0'
],
// 其他插件可以添加配置
'plugins' => []
];

View File

@@ -1,115 +0,0 @@
<?php
/**
* 数据库连接类
* 提供 MySQL 数据库连接和基础查询功能
*/
class Database {
private static $instance = null;
private $connection;
private $config;
private function __construct() {
$configFile = __DIR__ . '/../config/config.php';
if (!file_exists($configFile)) {
throw new Exception('配置文件不存在: ' . $configFile);
}
$this->config = include $configFile;
$dbConfig = $this->config['database'];
try {
$dsn = "mysql:host={$dbConfig['host']};port={$dbConfig['port']};dbname={$dbConfig['dbname']};charset={$dbConfig['charset']}";
$this->connection = new PDO($dsn, $dbConfig['username'], $dbConfig['password']);
$this->connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$this->connection->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
} catch (PDOException $e) {
// 数据库连接失败时记录日志但不阻止页面加载
error_log('[FutureOSS WebUI] 数据库连接失败: ' . $e->getMessage());
$this->connection = null;
}
}
/**
* 获取单例实例
*/
public static function getInstance() {
if (self::$instance === null) {
self::$instance = new self();
}
return self::$instance;
}
/**
* 获取数据库连接
*/
public function getConnection() {
return $this->connection;
}
/**
* 检查数据库是否可用
*/
public function isConnected() {
return $this->connection !== null;
}
/**
* 执行查询
*/
public function query($sql, $params = []) {
if (!$this->isConnected()) {
return false;
}
try {
$stmt = $this->connection->prepare($sql);
$stmt->execute($params);
return $stmt;
} catch (PDOException $e) {
error_log('[FutureOSS WebUI] 数据库查询错误: ' . $e->getMessage());
return false;
}
}
/**
* 获取所有结果
*/
public function fetchAll($sql, $params = []) {
$stmt = $this->query($sql, $params);
return $stmt ? $stmt->fetchAll() : [];
}
/**
* 获取单条结果
*/
public function fetchOne($sql, $params = []) {
$stmt = $this->query($sql, $params);
return $stmt ? $stmt->fetch() : null;
}
/**
* 插入数据并返回 ID
*/
public function insert($sql, $params = []) {
$stmt = $this->query($sql, $params);
return $stmt ? $this->connection->lastInsertId() : false;
}
/**
* 防止 SQL 注入
*/
public function escape($value) {
if (!$this->isConnected()) {
return addslashes($value);
}
return $this->connection->quote($value);
}
// 防止克隆
private function __clone() {}
public function __wakeup() {
throw new Exception("Cannot unserialize singleton");
}
}