Protect your data against global mass surveillance programs.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
matchboxbananasynergy aaff8259d4
Remove Neo Store, Rephrase F-droid section (#1821)
3 hours ago
.github Bump crowdin/github-action from 1.4.13 to 1.4.14 4 days ago
.well-known Pull Matrix server configuration (#1656) 1 month ago
data Blog replacement (#1704) 3 weeks ago
docs Remove Neo Store, Rephrase F-droid section (#1821) 3 hours ago
includes Improve Cryptee card (#1814) 1 day ago
mkdocs-material@62d4e1caac Blog replacement (#1704) 3 weeks ago
theme Remove custom theme icons (#1731) 3 weeks ago
.allowed_signers Enable SSH Git commit signing (#1122) 5 months ago
.gitattributes Mark .md files as linguist-detectable 6 months ago
.gitignore Transition to mkdocs (#829) 6 months ago
.gitmodules Remove blog submodule 2 months ago
.markdownlint.yml Listing common threat examples (#1276) 4 months ago
CITATION.cff Create CITATION.cff 1 month ago
LICENSE Proper Content Licensing 1 year ago
Pipfile Disable HTML Minification (#1755) 2 weeks ago
Pipfile.lock Disable HTML Minification (#1755) 2 weeks ago aesthetics (#1748) 2 weeks ago
crowdin.yml Use abbreviations across site (#1060) 5 months ago
mkdocs.production.yml Correct discussions link after feedback (#1802) 5 days ago
mkdocs.yml PrivacyTools FAQ (#1808) 2 days ago

Privacy Guides

Your central privacy and security resource to protect yourself online.


Privacy Guides is a socially motivated website that provides information for protecting your data security and privacy. We are a non-profit collective operated entirely by volunteer team members and contributors.

Our current list of team members can be found here. Additionally, many people have made contributions to the project, and you can too!



GitHub Gitea GitLab Codeberg SourceHut


Committing to this repository requires signing your commits (git config commit.gpgsign true) unless you are making edits via the text editor interface. As of August 2022 the preferred signing method is SSH commit signatures, but GPG signing is also acceptable. You should add your signing key to your GitHub profile.

This website uses mkdocs-material-insiders which offers additional functionality over the open-source mkdocs-material project. For obvious reasons we cannot distribute access to the insiders repository. You can install the website locally with the open-source version of mkdocs-material:

  1. Clone this repository:
    • git clone (then cd
    • git submodule init
    • git submodule update docs/assets/brand
    • git config gpg.ssh.allowedSignersFile .allowed_signers
  2. Install Python 3.6+ (currently only tested with 3.10)
  3. Install dependencies: pip install mkdocs mkdocs-material mkdocs-static-i18n mkdocs-macros-plugin typing-extensions
  4. Serve the site locally: mkdocs serve
    • The site will be available at http://localhost:8000
    • You can build the site locally with mkdocs build
    • Your local version of the site may be missing functionality, which is expected. If you are submitting a PR, please ensure the automatic preview generated for your PR looks correct, as that site will be built with the production insiders build.

Team members should clone the repository with mkdocs-material-insiders directly. This method is identical to production:

  1. Clone this repository and submodules: git clone --recurse-submodules
  2. Enable SSH commit verification with our local .allowed_signers file: git config gpg.ssh.allowedSignersFile .allowed_signers
  3. Install Python 3.10
  4. Install pipenv: pip install pipenv
  5. Install dependencies: pipenv install --dev (install Pillow and CairoSVG as well to generate social cards)
  6. Serve the site locally: pipenv run mkdocs serve --config-file mkdocs.production.yml (set CARDS=true to generate social cards)
    • The site will be available at http://localhost:8000
    • You can build the site locally with pipenv run mkdocs build
    • This version of the site should be identical to the live, production version

If you commit to main with commits signed with your SSH key, you should add your SSH key to .allowed_signers in this repo.


  1. Create a new tag: git tag -s v2.X.X -m 'Some message'
    • View existing tags
    • Tag numbering: Increment the MINOR (2nd) number when making significant changes (adding/deleting pages, etc.), increment the PATCH (3rd) number when making minor changes (typos, bug fixes). Probably leave the MAJOR number at 2 until a massive revamp (v1 -> v2 was the Jekyll to MkDocs transition).
    • Consider enabling GPG tag signing by default (git config tag.gpgSign true) to avoid missing signatures
  2. Push the tag to GitHub: git push --tags
  3. A GitHub Release will be automatically created and deployed to the live site.
    • You may wish to manually check or edit the release changelog/title after it is published for accuracy.