企业级安全套件 - 高危操作确认、自动备份、回滚机制、技能安检
版本: 1.0.0
作者: Cloud
适用: OpenClaw Agent / 企业级 / 个人开发者
7 类高危操作前自动提示确认:
修改文件前自动创建备份:
文件名.YYYYMMDD.NNN.bak自动记录所有高危操作到 CHANGELOG.md:
支持从备份文件恢复:
安装 skill 前自动检查:
# 1. 安装 Skill
clawhub install enterprise-security
# 2. 激活(写入安全规则到记忆)
node ~/.openclaw/workspace/skills/enterprise-security/activate.js
# 3. 重启 Gateway
openclaw gateway restart
完成! AI 会自动执行安全检查。
激活后,AI 会自动在执行高危操作前调用:
AI 准备修改文件 → 自动调用 confirmHighRisk → 用户确认 → 执行
const security = require('./skills/enterprise-security');
// 高危操作确认
await security.confirmHighRisk({
operation: 'modify_file',
file: 'MEMORY.md',
reason: '更新记忆系统'
});
// 自动备份
await security.autoBackup({
filePath: '~/.openclaw/workspace/SOUL.md',
reason: '修改前备份'
});
// 技能安检
const result = await security.checkSkill({
skillName: 'new-skill',
author: 'community-user',
repository: 'github.com/user/new-skill'
});
if (result.risk === 'high') {
throw new Error('高风险技能,拒绝安装');
}
// 回滚
await security.rollback({
file: 'MEMORY.md',
targetVersion: '20260311.001',
reason: '用户要求回滚'
});
编辑 config/rules.json:
{
"high_risk_operations": [
"modify_md_files",
"install_skills",
"restart_gateway",
"delete_files",
"modify_cron",
"modify_env",
"send_external_messages"
],
"auto_backup": {
"enabled": true,
"file_types": [".md", ".json", ".js", ".ts", ".py"],
"max_backups_per_file": 10
},
"changelog": {
"enabled": true,
"path": "memory/CHANGELOG.md"
},
"security_check": {
"enabled": true,
"whitelist": ["github.com/openclaw"]
}
}
高危操作确认
await security.confirmHighRisk({
operation: 'modify_file', // 操作类型
file: 'test.md', // 涉及文件(可选)
reason: '更新配置' // 原因(可选)
});
自动备份
await security.autoBackup({
filePath: 'test.md', // 文件路径
reason: '修改前备份' // 原因(可选)
});
技能安装安检
const result = await security.checkSkill({
skillName: 'new-skill',
author: 'user',
repository: 'github.com/user/skill',
permissions: ['read_file'],
dependencies: []
});
console.log(result.risk); // low/medium/high
console.log(result.recommendations);
回滚操作
await security.rollback({
file: 'test.md', // 文件路径
targetVersion: '20260311.001', // 目标版本
reason: '用户要求回滚' // 原因
});
MIT License
ZIP package — ready to use