介绍
CBCTF 是由 0RAYS 维护的 CTF 竞赛平台,基于 Go 语言构建,原生支持 Kubernetes 编排。平台支持动态附件生成、动态容器分发、容器与虚拟机混合部署、网络渗透场景构建等特性。
功能特性
题目类型
每道题目均可配置多个 flag,每个 flag 独立计分。
Flag 类型
flag 前缀可在赛事设置中自定义(默认 CBCTF):
平台能力
- 动态分值 — 一二三血额外获得题目分值的 5% / 3% / 1%
- Frp 内网穿透 — 容器端口转发,保留原始客户端 IP
- SMTP 邮件验证 — 注册验证与密码找回
- Writeup 管理 — 支持收集与批量下载
- OAuth / OIDC — 第三方认证,支持用户组自动分配
- 平台品牌化 — Logo、名称、主题色等全局配置
- 热重载配置 — 所有系统配置修改即时生效,无需重启
- Webhook — GET / POST
- 国际化(i18n) — 多语言界面支持
- Prometheus 监控 — 完整的运行时指标暴露
- Redis 缓存 / 任务队列 + PostgreSQL 数据存储 + NFS 网络存储
构建
也可直接使用 Docker 完成两阶段构建:
动态容器
网络模式
后端通过 docker-compose 配置自动识别网络模式:
配置示例
Pod 模式
VPC 模式(含 KubeVirt 虚拟机)
动态附件
基于 Kubernetes 容器化生成,支持上传 Python 脚本,在隔离环境中为每个队伍生成唯一附件。
生成器合约:
- 容器必须包含
sleep和unzip - 脚本路径固定为
/root/run.sh <team_id> <base64_encoded_flags> - 产物须写入
/root/mnt/attachments/{id}.zip - 禁止使用
latest镜像标签
Kubernetes 依赖
动态容器与动态附件功能依赖以下组件:
许可证
本项目采用 GNU Affero General Public License v3.0 开源协议。
