DOLOST is a framework designed to automate the creation and deployment of decoys and deceptive environments in the context of cyber deception operations. It also guides the design of deception operations with a deep understanding of engagement strategies.
-
Ensure Python and Docker are Installed:
Make sure you have Python 3.7 or later installed on your system and Docker installed on your Decoy's host (it could be the same system you are using right now, just keep it in mind for when you configure DOLOST). You can download and install Python from the official Python website (https://www.python.org/downloads/) and Docker from the official Docker website (https://www.docker.com/get-started).
-
Install DOLOST Using pip:
Run the following command to install the project:
# Python 3.7+ required $ python3 -m venv .venv $ source .venv/bin/activate $ pip install DOLOST
-
Final Checks:
Ensure that all required dependencies are installed without any errors. If you encounter any issues during the installation process, refer to the error messages for troubleshooting steps.
To use the framework you need to start it with a first definition of the Docker client to connect with.
Here you have an example for DOLOST execution:
import DOLOST
# Available Docker Client configuration:
# - from_env: Will try to use the current environment configuration to reach dockerd.
# - tcp: Will use the provided host and port to reach dockerd.
# - tcp_ssl: Will use the provided host and port + the SSL certificates to reach dockerd using TCP+SSL.
# - socket: Will use the provided socket path to reach dockerd.
# For more detailed information, refer to "Configuring Docker Client" in the Documentation.
dc = {'from_env': True}
# Available Verbosity Levels:
# - TRACE: Provides detailed tracing information.
# - DEBUG: Displays debug messages for troubleshooting.
# - INFO: Provides general information about the execution.
# - WARN: Displays warnings for potential issues.
# - ERROR: Indicates errors that occurred during execution.
# Note: Each verbosity level includes all levels above it. For example,
# setting verbosity to DEBUG will also display INFO, WARN, and ERROR messages.
verbosity = "INFO"
if __name__ == "__main__":
DOLOST.start(verbosity=verbosity, docker_client=dc)