The shortlink to this wiki page is https://r-7.co/MSF-DEV
This is a guide for setting up a developer environment to contribute modules, documentation, and fixes to the Metasploit Framework. If you just want to use Metasploit for legal, authorized hacking, we recommend instead you:
- Install the open-source Omnibus installer, or
- Use the pre-installed Metasploit on Kali Linux or Parrot Linux.
If you want to contribute to Metasploit, start by reading our CONTRIBUTING.md, then follow the rest of this guide.
Assumptions
- You have installed an apt-based Linux environment, such as Ubuntu or Kali.
- You have created a GitHub account and associated an public ssh key with it.
- You have familiarity with Git and Github, or have completed the Github bootcamp.
- For optional database and REST API functionality, you will need regular user account that is not
root
.
This guide has details for setting up both Linux and Windows.
Install dependencies
Linux
- Open a terminal on your Linux host and set up Git, build tools, and Ruby dependencies:
sudo apt update && sudo apt install -y git autoconf build-essential libpcap-dev libpq-dev zlib1g-dev libsqlite3-dev
Windows
Windows 10 or above
- Install winget
- Install Ruby x64 with DevKit
- Install pcaprub dependencies from your PowerShell terminal:
[System.Net.ServicePointManager]::ServerCertificateValidationCallback = {$true} ; [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile('https://www.winpcap.org/install/bin/WpdPack_4_1_2.zip', 'C:\Windows\Temp\WpdPack_4_1_2.zip')
Expand-Archive -Path "C:\Windows\Temp\WpdPack_4_1_2.zip" -DestinationPath "C:\"
Install a version of PostgreSQL:
Install-Module -Name Microsoft.WinGet.Client
Install-WinGetPackage -id PostgreSQL.PostgreSQL.17
Pre-Windows 10
- Install choco
- Install Ruby x64 with DevKit
- Install pcaprub dependencies from your cmd.exe terminal:
powershell -Command "[System.Net.ServicePointManager]::ServerCertificateValidationCallback = {$true} ; [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile('https://www.winpcap.org/install/bin/WpdPack_4_1_2.zip', 'C:\Windows\Temp\WpdPack_4_1_2.zip')"
choco install 7zip
7z x "C:\Windows\Temp\WpdPack_4_1_2.zip" -o"C:\"
Install a version of PostgreSQL:
choco install postgresql17
Set up your local copy of the repository
You will need to use Github to create a fork for your contributions and receive the latest updates from our repository.
- Login to Github and click the “Fork” button in the top-right corner of the metasploit-framework repository.
- Create a
git
directory in your home folder and clone your fork to your local machine:
export GITHUB_USERNAME=YOUR_USERNAME_FOR_GITHUB
export GITHUB_EMAIL=YOUR_EMAIL_ADDRESS_FOR_GITHUB
mkdir -p ~/git
cd ~/git
git clone [email protected]:$GITHUB_USERNAME/metasploit-framework
cd ~/git/metasploit-framework
- If you encounter a “permission denied” error on the above command, research the error message. If there isn’t an explicit reason given, confirm that your Github SSH key is configured correctly. You will need to associate your public SSH key with your GitHub account, otherwise if you set up a SSH key and don’t associate it with your GitHub account, you will receive this “permission denied” error.
- To receive updates, you will create an
upstream-master
branch to track the Rapid7 remote repository, alongside yourmaster
branch which will point to your personal repository’s fork:
git remote add upstream [email protected]:rapid7/metasploit-framework.git
git fetch upstream
git checkout -b upstream-master --track upstream/master
- Configure your Github username, email address, and username. Ensure your
user.email
matches the email address you registered with your Github account.
git config --global user.name "$GITHUB_USERNAME"
git config --global user.email "$GITHUB_EMAIL"
git config --global github.user "$GITHUB_USERNAME"
- Set up msftidy to run before each
git commit
and after eachgit merge
to quickly identify potential issues with your contributions:
Linux
cd ~/git/metasploit-framework
ln -sf ../../tools/dev/pre-commit-hook.rb .git/hooks/pre-commit
ln -sf ../../tools/dev/pre-commit-hook.rb .git/hooks/post-merge
Windows
cd ~/git/metasploit-framework
mkdir .githooks
git config --local core.hooksPath .githooks/
New-Item -Path pre-commit -ItemType SymbolicLink -Value ..\tools\dev\pre-commit-hook.rb
New-Item -Path post-merge -ItemType SymbolicLink -Value ..\tools\dev\pre-commit-hook.rb
Install Ruby
Note: If you are using Windows, ruby installed in Install dependencies section, so you can skip this section
Linux distributions do not ship with the latest Ruby, nor are package managers routinely updated. Additionally, if you are working with multiple Ruby projects, each one has dependencies and Ruby versions which can start to conflict. For these reasons, it is advisable to use a Ruby manager.
You could just install Ruby directly (eg. sudo apt install ruby-dev
), but you may likely end up with the incorrect version and no way to update. Instead, consider using one of the many different Ruby environment managers available. The Metasploit team prefers rbenv and rvm (note that rvm does require a re-login to complete).
Regardless of your choice, you’ll want to make sure that, when inside the ~/git/metasploit-framework
directory, you are running the correct version of Ruby:
$ cd ~/git/metasploit-framework
$ cat .ruby-version
3.2.5
$ ruby -v
ruby 3.2.5 (2024-07-26 revision 31d0f1a2e7) [x86_64-darwin23]
Note: the Ruby version is likely to change over time, so don’t rely on the output in the above example. Instead, confirm your ruby -v
output with the version number listed in the .ruby-version
file.
If the two versions don’t match, restart your terminal. If that does not work, consult the troubleshooting documentation for your Ruby environment manager. Unfortunately, troubleshooting the Ruby environment is beyond the scope of this document, but feel free to reach out for community support using the links at the bottom of this document.
Install Gems
Before you run Metasploit, you will need to update the gems (Ruby libraries) that Metasploit depends on:
cd ~/git/metasploit-framework/
gem install bundler
bundle install
If you encounter an error with the above command, refer to the bundle
output and search for the error message along with the name of the gem that failed. Likely, you’ll need to apt get install
a dependency that is required by that particular gem.
Congratulations! You have now set up a development environment and the latest version of the Metasploit Framework. If you followed this guide step-by-step, and you ran into any problems, it would be super great if you could open a new issue so we can either help you, or, more likely, update the docs.
Optional: Set up the REST API and PostgreSQL database
Installing the REST API and PostgreSQL is optional, and can be done in two ways. Recommended is to use the Docker approach, and fairly simple to do once you have docker installed on your system, Docker Desktop is recommended, but not mandatory. On Linux systems, simply having docker-cli is sufficient.
Docker Installation
Make sure, you have docker available on your system: Docker Installation Guide
Note: Depending on your environment, these commands might require sudo
- Start the postgres container:
docker run --rm -it -p 127.0.0.1:5433:5432 -e POSTGRES_PASSWORD="mysecretpassword" postgres:14
Wait till the postgres container is fully running.
- Configure the Metasploit database:
cd ~/git/metasploit-framework
./msfdb init --connection-string="postgres://postgres:[email protected]:5433/postgres"
- If the
msfdb init
command succeeds, then confirm that the database is accessible to Metasploit:
$ ./msfconsole -qx "db_status; exit"
Manual Installation
The following optional section describes how to manually install PostgreSQL and set up the Metasploit database. Alternatively, use our Omnibus installer which handles this more reliably.
- Confirm that the PostgreSQL server and client are installed:
sudo apt update && sudo apt-get install -y postgresql postgresql-client
sudo service postgresql start && sudo update-rc.d postgresql enable
- Ensure that you are not running as the root user.
- Initialize the Metasploit database:
cd ~/git/metasploit-framework
./msfdb init
- If you receive an error about a component not being installed, confirm that the binaries shown are in your path using the which and find commands, then modifying your $PATH environment variable. If it was something else, open a new issue to let us know what happened.
- If the
msfdb init
command succeeds, then confirm that the database is accessible to Metasploit:
$ ./msfconsole -qx "db_status; exit"
Congratulations! You have now set up the Metasploit Web Service (REST API) and the backend database.
Optional: Tips to speed up common workflows
The following section is optional but may improve your efficiency.
Making sure you’re in the right directory to run msfconsole
can become tedious, so consider using the following Bash alias:
echo 'alias msfconsole="pushd $HOME/git/metasploit-framework && ./msfconsole && popd"' >> ~/.bash_aliases
Consider generating a GPG key to sign your commits. Read about why and how. Once you have done this, consider enabling automatic signing of all your commits with the following command:
cd *path to your cloned MSF repository on disk*
git config commit.gpgsign true
Developers tend to customize their own git aliases to speed up common commands, but here are a few common ones:
[alias]
# An easy, colored oneline log format that shows signed/unsigned status
nicelog = log --pretty=format:'%Cred%h%Creset -%Creset %s %Cgreen(%cr) %C(bold blue)<%aE>%Creset [%G?]'
# Shorthand commands to always sign (-S) and always edit the commit message.
m = merge -S --no-ff --edit
c = commit -S --edit
# Shorthand to always blame (praise) without looking at whitespace changes
b= blame -w
If you plan on working with other contributor’s pull requests, you may run the following script which makes it easier to do so:
tools/dev/add_pr_fetch.rb
After running the above script, you can checkout
other pull requests more easily:
git fetch upstream
git checkout fixes-to-pr-12345 upstream/pr/12345
Running and writing tests
If you’re writing test cases (which you should), you should first configure your local database:
bundle exec rake db:create db:migrate db:seed RAILS_ENV=test
Then make sure rspec works:
bundle exec rspec
To run tests defined in file(s):
bundle exec rspec ./spec/path/to/your/tests_1.rb ./spec/path/to/your/tests_2.rb
To run the tests defined at a line number - for instance line 23:
bundle exec rspec ./spec/path/to/your/tests_1.rb:23
Newly contributed tests should follow the conventions defined by BetterSpecs.org - with the additional requirement that all it
blocks should have a human readable description.
Great! Now what?
We’re excited to see your upcoming contributions of new modules, documentation, and fixes! If you’re looking for inspiration, keep an eye out for newbie-friendly pull requests and issues. Please submit your new pull requests and reach out to us on Slack for community help.
Finally, we welcome your feedback on this guide, so feel free to reach out to us on Slack or open a new issue. For their significant contributions to this guide, we would like to thank @kernelsmith, @corelanc0d3r, and @ffmike.