Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fabaff/fsl-test-bench
FSL Test bench - Ansible playbook repository to setup a save environment for security auditing and testing. It can be used for teaching security testing methodologies, testing tools, learning, and playing.
https://github.com/fabaff/fsl-test-bench
ansible fedora fedora-security-lab pentesting playground security vulnerable
Last synced: 3 months ago
JSON representation
FSL Test bench - Ansible playbook repository to setup a save environment for security auditing and testing. It can be used for teaching security testing methodologies, testing tools, learning, and playing.
- Host: GitHub
- URL: https://github.com/fabaff/fsl-test-bench
- Owner: fabaff
- Created: 2013-04-02T13:11:00.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2024-06-23T20:34:58.000Z (7 months ago)
- Last Synced: 2024-10-04T12:48:40.306Z (4 months ago)
- Topics: ansible, fedora, fedora-security-lab, pentesting, playground, security, vulnerable
- Language: Jinja
- Homepage: https://labs.fedoraproject.org/en/security/
- Size: 3 MB
- Stars: 27
- Watchers: 5
- Forks: 11
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# FSL Test bench
The **FSL Test bench** provides a save environment for security auditing and
testing and can be used for teaching security testing methodologies. At the
moment the focus lies on web applications. All application are running on
top of a current Fedora installation with
a Lighttpd web server and a MySQL server.The FSL Test bench includes:
* Vulnerable web applications (DVWA, bWAPP, SQLI Labs, MIRC and more)
* PHP shells (PHP Shell, b374k and DNA Shell)
* Low-interaction honeypots
* Helper tools (Log viewer, CGIs, linfo and phpmyadmin)All applications are directly accessible from a [bootstrap](http://twitter.github.io/bootstrap/)-based website.
The FSL Test bench repository contains a subset of playbooks from the
[**fedora-ansible** git repository](https://github.com/fabaff/fedora-ansible)
maintained by [Fabian Affolter](http://fabian-affolter.ch).If you have just found Ansible or the Fedora Security Lab, you should start here:
* [Fedora Security Lab](https://pagure.io/security-lab)
## Prerequisites
The setup of Ansible is explained on the
[Ansible Getting Started](http://ansible.cc/docs/gettingstarted.html) page.
Here is only the setup of the managed nodes and special details for the
management system covered. For every system you want to manage, you need to
have the client's SSH key in the *authorized_keys* file of the managed system
and Python.### Packages
Make sure that [Python](http://www.python.org/) is installed. If not, install
the Python package on the managed node(s). If you have performed a minimal
Fedora installation Python is available.```bash
$ sudo dnf -y install python
```
The playbooks will use DNF as package management software instead of `yum` as
soon as DNF is the default Package management tool in Fedora. But for now,
everything is done with `yum`.### SSH key
Add the SSH key to the *authorized_keys* file. Assuming you are logged-in with
SSH on your management system.```bash
sudo ssh-copy-id -i /root/.ssh/id_rsa.pub root@[IP address of your managed note]
```### /etc/ansible/hosts
The file */etc/ansible/hosts* shall contain all hosts to be setup up.
- **fsl-tb**: Default group name for machine which uses the all-in-one playbook
- **fsl-tb-vpn**: Default group name for machine which acts as VPN servers
- **fsl-tb-master**: Hosts for FSL Test bench guests when using visualization
- **fsl_hosts**: Hosts to install the Fedora Security Lab package set### Variables
After cloning this git repository, edit the [variables/sensitive.yml](https://github.com/fabaff/fsl-test-bench/blob/master/variables/sensitive.yml) file if you don't want to use *password* as default password.
## Documentation
The documentation is available at [Read the Docs](https://fedora-security-lab-test-bench.readthedocs.org/en/latest/).
## Structure
At the moment the structure of the repository looks like this:
```bash
.
├── all-in-one.yml -------- FSL Test bench on a single machine
├── docs ------------------ Documentation
├── files ----------------- Template files
│ ├── cgi --------------- Source files for CGI
│ ├── kickstart --------- Kickstart files
│ └── web-interface ----- All files for the web interface
├── fsl-packages-sync.py -- Python script to sync with FSL package list
├── fsl-tb-detect.nse ----- nmap script for the Test bench detection
├── fsl.yml ---------------
├── handlers -------------- Handlers for services
├── INSTALL.md ------------ Installation guide
├── local-setup.yml -------
├── openvpn-server.yml ----
├── README.md ------------- This files
├── tasks ----------------- A collection of tasks (all playbooks)
│ ├── apps -------------- Vulnerable web applications
│ ├── cgi --------------- CGI
│ ├── db-servers -------- Database servers
│ ├── directory-servers - Directory Servers
│ ├── file-servers ------ File servers
│ ├── ftp-servers ------- FTP servers
│ ├── helpers ----------- Helper tools
│ ├── honeypots --------- Low-interaction honeypots
│ ├── mail-servers ------ Mail server
│ ├── misc-servers ------ Various servers
│ └── shells ------------ PHP shells
│ └── web-servers ------- Web servers
└── variables ------------- Storage files for variables
```## Warning
The file *variables/sensitive.yml* contains most application passwords. If you
don't want to run with default password, edit this file according your needs
and keep it save outside the repository.## Licensing
All playbook content is assumed to be Creative Commons 3.0 Attribution licensed.
Non-commercial or No-derivatives CC extensions are not acceptable, to encourage
easy use by all users, regardless of purpose.