A
security.txt
file is an industry standard used by organizations to provide a clear point of contact for vulnerability reporting. Adding a signedsecurity.txt
file to your webserver enhances credibility and ensures trust, as the signature allows others to verify its authenticity. This blog will walk you through implementing a signedsecurity.txt
file using PGP (Pretty Good Privacy).
Introduction
The security.txt
file is typically hosted at /.well-known/security.txt
on a webserver. It follows a standardized format to share security contact information, preferred encryption keys, and disclosure policies. However, without proper authentication, anyone could tamper with the file. A signed security.txt
solves this issue by letting others verify the file’s legitimacy using your PGP key. Here’s how to create, sign, and verify a security.txt
file for your webserver.
Step 1: Generate a PGP Key Pair
If you don’t already have a PGP key pair, you’ll need to generate one. A PGP key pair consists of a public key, which you can share publicly, and a private key, which is kept secret.
1. Install GPG (GNU Privacy Guard)
GPG is the most common tool for generating and managing PGP keys. Install it using your package manager:
- Linux:
sudo apt-get install gnupg
- MacOS (via Homebrew):
brew install gnupg
- Windows: Download GPG4Win from https://gpg4win.org.
2. Generate the Key Pair
Run the following command:
gpg --full-generate-key
- Choose RSA and RSA for encryption.
- Select the desired key size (e.g., 4096 bits for stronger security).
- Set an expiration date (it is not recommended to select no expiration for permanent use).
- Enter your name and email address when prompted.
- Set a strong passphrase to secure the private key.
Once complete, your keys are stored in the GPG keyring. You can view your generated key pair by running the following command for both the public and private keys.
- Public key:
gpg --list-keys
- Private key:
gpg --list-secret-keys
3. Export Your Public Key
Others will need your public key to verify your signature:
gpg --armor --export your_email@example.com > pgp-publickey.txt
This will export the public key to a file named pgp-publickey.txt
.
Step 2: Create and Sign the security.txt file
-
Create the security.txt file: Create a plain text file named
security.txt
with the following content (customize as needed):# Security address Contact: mailto:security@example.com # OpenPGP key Encryption: https://example.com/.well-know/pgp-publickey.txt # Expiration of security.txt file Expires: expiration date of your pgp key pair # Privacy Policy Policy: https://example.com/security-policy.html # Languages Preferred-Languages: EN, NL
-
Sign the file with your Private Key: Use the following command to create a cleartext signature:
gpg --clearsign security.txt
After you enter the passphrase to unlock the OpenPGP secret key, a signature file
security.txt.asc
is created. Copy the contents ofsecurity.txt.asc
into the originalsecurity.txt
file. -
Host the files: In the
/.well-known/
folder on your webserver, upload thesecurity.txt
andpgp-publickey.txt
files:https://example.com/.well-known/security.txt https://example.com/.well-known/pgp-publickey.txt
Step 3: Verifying the Signature
To confirm the authenticity of the security.txt
file, anyone can verify it using your public key.
1. Import the Public Key
A user downloads your public key and imports it into their GPG keyring:
gpg --import pgp-publickey.txt
2. Verify the Signature
The user runs the following command to verify the signature:
gpg --verify security.txt
If the file is authentic, they’ll see output confirming the signature, such as:
gpg: Signature made Fri 23 Nov 2024 10:30:00 AM UTC
gpg: using RSA key ABC123DEF4567890
gpg: Good signature from "Your Name <your_email@example.com>"
The user can trust your public key by running: gpg --edit-key Key_ID
, typing trust
at the next prompt, and selecting the option 5 = I trust ultimately
.
Conclusion
Adding a signed security.txt
file to your webserver is a simple yet powerful way to build trust with security researchers and users. It ensures that the contact information provided is legitimate and hasn’t been tampered with. By following these steps, you create a clear and verifiable point of contact for handling vulnerabilities responsibly.