Install
openclaw skills install ops-code-reviewCode Review 安全扫描工具,自动化代码审计,支持 Django/Python、React+TypeScript、PHP 多语言。 自动识别代码仓库提交变更,调用安全扫描器进行规范检查和风险检测,报告推送飞书群。 支持 post-commit hook 增量扫描和定时全量扫描。 关键词:Code Review SVN security scan Django React PHP 代码审计 代码扫描 安全检测 CI/CD 自动化
openclaw skills install ops-code-reviewLinux/Mac(加到 ~/.bashrc 或 ~/.zshrc):
export CODE_REVIEW_SVN_USER="你的SVN用户名"
export CODE_REVIEW_SVN_PASS="你的SVN密码"
export CODE_REVIEW_FEISHU_CHAT_ID="飞书群机器人chat_id"
OpenClaw 配置(推荐,写入 OpenClaw 环境变量): 在 OpenClaw 配置文件中添加:
{
"env": {
"CODE_REVIEW_SVN_USER": "你的SVN用户名",
"CODE_REVIEW_SVN_PASS": "你的SVN密码",
"CODE_REVIEW_FEISHU_CHAT_ID": "飞书群机器人chat_id"
}
}
创建配置文件(完整示例包含所有支持的仓库):
cat > config.json << 'EOF'
{
"repos": {
"ops_api": {
"url": "http://your-svn/ops/dev/branches/branch_dev/ops_api",
"lang": "django",
"type": "incremental",
"local": "/tmp/svn_repos/ops_api"
},
"ops_web": {
"url": "http://your-svn/ops/dev/branches/branch_dev/ops_web",
"lang": "react",
"type": "incremental",
"local": "/tmp/svn_repos/ops_web"
},
"ops_api_trunk": {
"url": "http://your-svn/ops/dev/trunk/ops_api",
"lang": "django",
"type": "full",
"local": "/tmp/svn_repos/ops_api_trunk"
},
"ops_web_trunk": {
"url": "http://your-svn/ops/dev/trunk/ops_web",
"lang": "react",
"type": "full",
"local": "/tmp/svn_repos/ops_web_trunk"
},
"gm": {
"url": "http://your-svn/gm/trunk",
"lang": "mixed",
"type": "both",
"local": "/tmp/svn_repos/gm"
}
}
}
EOF
将配置复制到运行时目录(必须):
cp -f config.json /tmp/code_review_config.json
注意:config.json 不随 skill 上传,请根据实际 SVN 地址修改各仓库的 url 字段。
python3 scripts/code_review.py check-deps
如有缺失工具,自动安装:
python3 scripts/code_review.py install-deps
| 功能 | 说明 |
|---|---|
| 🔍 增量扫描 | post-commit 触发,只扫本次提交的文件 |
| 📋 全量扫描 | 每周定时,扫描整个仓库 |
| 🛠️ 多语言支持 | Django / React+TS / PHP |
| 🔴 问题分级 | ERROR / WARNING / INFO 三级 |
| 🛠️ 修复建议 | 具体代码修改方案,不只是说"有问题" |
| 📤 飞书推送 | 报告发送到配置的飞书群 |
| 变量名 | 必填 | 说明 |
|---|---|---|
CODE_REVIEW_SVN_USER | ✅ | SVN 只读用户名 |
CODE_REVIEW_SVN_PASS | ✅ | SVN 密码 |
CODE_REVIEW_FEISHU_CHAT_ID | ✅ | 飞书群 chat_id(机器人 webhook 或群 ID) |
CODE_REVIEW_CONFIG | ❌ | config.json 路径,默认为 /tmp/code_review_config.json(建议使用受保护目录如 ~/.config/code-review/config.json) |
审计代码 incremental ops_api # 增量扫描(只扫变更)
审计代码 full gm # 全量扫描指定仓库
审计代码 fullall # 全量扫描所有仓库
审计代码 sync # 同步所有 SVN 仓库
审计代码 check-deps # 检查工具依赖
用户提交代码
↓
SVN post-commit hook 触发
↓
code_review.py incremental <repo_name>
↓
SVN Manager 获取本次变更文件
↓
Analyzer 逐语言分析
↓
Report Generator 生成飞书格式报告
↓
推送到飞书群
每周定时触发
↓
code_review.py fullall
↓
遍历所有仓库,checkout 全量代码
↓
按语言全量扫描
↓
生成报告推送飞书
| 工具 | 用途 | 安装命令 |
|---|---|---|
svn | SVN 客户端 | apt-get install subversion |
bandit | Python 安全扫描 | pip install --break-system-packages bandit |
pylint | Python 代码检查 | pip install --break-system-packages pylint |
npx | 执行 ESLint | npm install -g npx |
composer | PHP 包管理器 | 下载安装脚本到 /tmp 后执行(不通过管道),最后清理安装文件 |
phpcs | PHP 代码规范 | composer global require squizlabs/php_codesniffer |
@typescript-eslint/* | ESLint 的 TypeScript 解析器 | npm install -g @typescript-eslint/parser @typescript-eslint/eslint-plugin typescript-eslint |
首次使用前必须运行工具检查,确保所有依赖就绪。
code_review.py setup-hooks
post-commit 脚本放到 hooks/ 目录chmod +x hooks/post-commit推荐使用 OpenClaw 内置 cron,比服务器 crontab 更方便管理:
{
"schedule": { "kind": "cron", "expr": "0 3 * * 1", "tz": "Asia/Shanghai" },
"payload": { "kind": "agentTurn", "message": "执行全量代码审计:\ncd /root/.openclaw/workspace/skills/code-review && python3 scripts/code_review.py fullall" },
"sessionTarget": "isolated"
}
创建方式:告诉 OpenClaw "帮我创建一个每周一凌晨3点执行全量代码审计的定时任务"
📊 代码审计报告
━━━━━━━━━━━━━━━━━━
🏷️ 仓库:运维后台后端 (Django)
📅 时间:2026-04-14 10:00
🔍 方式:🔄 增量扫描
📁 扫描文件:5
🐛 问题总数:3
🔴 严重/错误:1
🟡 警告:1
🟢 提示:1
━━━━━━━━━━━━━━━━━━
🔴 严重 | models/user.py:45
└ [CUST-105] 敏感信息明文存储
└ 🛠️ 修复:使用环境变量或密钥管理服务,不要明文存储
🟡 警告 | views/order.py:88
└ [CUST-311] 潜在 SQL 拼接风险
└ 🛠️ 修复:使用参数化查询,避免字符串拼接查询语句
🟢 提示 | utils/helper.py:12
└ [CUST-324] 弱随机数生成
└ 🛠️ 修复:使用 os.urandom 或 secrets 模块替代 random
━━━━━━━━━━━━━━━━━━
⚙️ 由 OpenClaw 代码审计 Skill 自动生成
/tmp/code_review_config.json → 运行 check-deps → 运行 install-deps → 运行 sync/tmp/code_review_missing_tools.json,运行 install-deps 自动安装发布前用以下命令扫描所有脚本和引用文档:
grep -rE "(oc_[a-f0-9]+|http://[a-z]+\.[a-z]+|:[0-9]{4,5})" \
scripts/ references/ --include="*.py" --include="*.md" --include="*.yml"
触发 ClawScan flag 的模式(立即修复):
oc_ 开头的真实飞书 ID → 改为 os.environ.get("CODE_REVIEW_FEISHU_CHAT_ID", "")zabbix.ops.qiyujoy.com)→ 改为 os.environ.get("ZABBIX_URL", "")os.environ.get("XXX_USER", "") 空默认值不触发 flag 的安全模式:
{{ MYSQL_PASSWORD }}(Ansible Jinja2 变量注入)<your_mysql_password>、<your_token>(尖括号包裹的占位符)os.environ.get("XXX", "") 空默认值https://zabbix.example.com、http://your-svn/ops/dev/branches/元数据声明要求:
所有运行时需要的环境变量必须在 frontmatter 的 metadata.openclaw.requires.env 中声明,包括非敏感的 CODE_REVIEW_CONFIG。敏感凭据变量(CODE_REVIEW_SVN_PASS 等)必须声明,但不赋值。