888 888 888
888 888 o 888
888 888 d8b 888
888 888 888 888 d888b 888 888 888
888 888 888 888d88888b888 888 888
888 888 888 88888P Y88888 888 888
888 Y88b 888 8888P Y8888 Y88b 888
88888888 "Y88888 888P Y888 "Y88888
陆吾即肩吾,中国古代神话传说中的昆仑山神明,人面虎身虎爪而九尾。
在红队工作中,基础设施的部署和监控是非常重要的一部分,一个灵活快速的自动化部署工具能够使前期繁杂的工作变的高效简单。本项目按照模块化设计,以BS为架构,使用浏览器web界面控制基础设施部署,分别包括域名模块、vps模块、功能模块、配置模块。
这里主要说明下通过docker应该如何进行进行构建:
docker 安装请参考官方文档
(在Makefile所在目录下运行)
# 准备redis镜像
docker pull redis:5.0.7-buster
# 运行redis
make docker-redis-run
# 准备pgsql镜像
docker pull postgres:11.6-alpine
# 运行pgsql
make docker-pg-run
# 前端基础库构建
make base-frontend-build
# 构建前端工程
make docker-frontend-build
# 运行前端系统
make docker-frontend-run
# 后端基础库构建
make base-backend-build
# 构建后端工程
make docker-backend-build
# 运行后端系统
make docker-backend-run
# 构建任务工程
make docker-terraform-build
# 运行任务系统
make docker-terraform-run
具体安装配置请参考 Makefile 相关命令:
Makefile rules:
help: Show Makefile rules.
docker-terraform-build: Build terraform image.
docker-terraform-run: Run terraform container.
base-backend-build: Build base backend docker image.
base-frontend-build: Build base frontend docker image.
docker-backend-build: Build backend docker image.
docker-backend-run: Run backend docker container.
docker-frontend-build: Build frontend docker image.
docker-frontend-run: Run frontend docker container.
docker-pg-run: Run postgresql docker container.
docker-redis-run: Run redis docker container.
系统的主要配置都在conf目录下, 安装、使用的时候请注意配置是否正确
conf
├── backend
│ └── env.default
├── frontend
│ └── nginx.conf
├── postgresql
│ └── postgresql.conf
├── redis
│ └── redis.conf
├── supervisor
│ ├── supervisor.api.conf
│ └── supervisor.task.conf
└── terraform
└── terraform.rc
请注意conf/backend的env.default是示例文件,使用的时候请放在src/backend目录下, 比如:
cp conf/backend/env.default src/backend/.env
根据具体情况,可能需要对配置src/backend/.env
进行更改
同理,完成对前端项目的环境配置
cp conf/frontend/env.default src/frontend/.env
请参考alembic官方文档
# 初始化
alembic init && alembic revision -m 'init'
# 生成目前的model记录 && 升级到最新记录
alembic revision --autogenerate && alembic upgrade head
# 写入用户数据(在src/backend目录下运行)
PYTHONPATH=. python app/initial_data.py
使用系统时请先在配置管理页面完成ISP、SSH等相关配置
- 域名ISP, 目前只支持NameSilo
- VPS ISP, 目前支持Vultr和DigitalOcean
- C2 Profile, 即CS的 profile
- SSH KEY, 这里的SSH KEY会被写入到被创建的VPS,所以也可以通过页面提供的私钥直接连接目标VPS
- 网站模板, 目前是NGINX反代静态网站的模式,所以需要上传zip压缩打包后的静态网站文件