Skip to content
/ LuWu Public
forked from QAX-A-Team/LuWu

红队基础设施自动化部署工具

License

Notifications You must be signed in to change notification settings

boothook/LuWu

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

陆吾

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

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/backendenv.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, 目前支持VultrDigitalOcean
  • C2 Profile, 即CS的 profile
  • SSH KEY, 这里的SSH KEY会被写入到被创建的VPS,所以也可以通过页面提供的私钥直接连接目标VPS
  • 网站模板, 目前是NGINX反代静态网站的模式,所以需要上传zip压缩打包后的静态网站文件

引用的开源项目

About

红队基础设施自动化部署工具

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 44.9%
  • Vue 37.9%
  • TypeScript 13.1%
  • Shell 1.5%
  • Makefile 1.1%
  • Dockerfile 0.9%
  • Other 0.6%